From 7bcbb8b6c3ac81f16341957b9b54e3a61e44caf8 Mon Sep 17 00:00:00 2001 From: staszekscp Date: Tue, 11 Apr 2023 15:54:08 +0200 Subject: [PATCH 01/51] add flavors --- android/app/build.gradle | 36 ++++++++++---- .../assets/airshipconfig.properties | 0 android/app/src/adhoc/google-services.json | 47 ++++++++++++++++++ .../src/adhoc/res/mipmap-hdpi/icon-adhoc.png | Bin 0 -> 5539 bytes .../src/adhoc/res/mipmap-mdpi/icon-adhoc.png | Bin 0 -> 3467 bytes .../src/adhoc/res/mipmap-xhdpi/icon-adhoc.png | Bin 0 -> 7713 bytes .../adhoc/res/mipmap-xxhdpi/icon-adhoc.png | Bin 0 -> 12706 bytes .../adhoc/res/mipmap-xxxhdpi/icon-adhoc.png | Bin 0 -> 18087 bytes android/app/src/adhoc/res/values/strings.xml | 3 ++ .../assets/airshipconfig.properties | 8 +++ .../res/mipmap-hdpi/ic_launcher.png | Bin 0 -> 5552 bytes .../res/mipmap-mdpi/ic_launcher.png | Bin 0 -> 3499 bytes .../res/mipmap-xhdpi/ic_launcher.png | Bin 0 -> 7673 bytes .../res/mipmap-xxhdpi/ic_launcher.png | Bin 0 -> 12529 bytes .../res/mipmap-xxxhdpi/ic_launcher.png | Bin 0 -> 17895 bytes .../src/development/res/values/strings.xml | 3 ++ package-lock.json | 2 +- 17 files changed, 87 insertions(+), 12 deletions(-) rename android/app/src/{internalRelease => adhoc}/assets/airshipconfig.properties (100%) create mode 100644 android/app/src/adhoc/google-services.json create mode 100644 android/app/src/adhoc/res/mipmap-hdpi/icon-adhoc.png create mode 100644 android/app/src/adhoc/res/mipmap-mdpi/icon-adhoc.png create mode 100644 android/app/src/adhoc/res/mipmap-xhdpi/icon-adhoc.png create mode 100644 android/app/src/adhoc/res/mipmap-xxhdpi/icon-adhoc.png create mode 100644 android/app/src/adhoc/res/mipmap-xxxhdpi/icon-adhoc.png create mode 100644 android/app/src/adhoc/res/values/strings.xml create mode 100644 android/app/src/development/assets/airshipconfig.properties create mode 100644 android/app/src/development/res/mipmap-hdpi/ic_launcher.png create mode 100644 android/app/src/development/res/mipmap-mdpi/ic_launcher.png create mode 100644 android/app/src/development/res/mipmap-xhdpi/ic_launcher.png create mode 100644 android/app/src/development/res/mipmap-xxhdpi/ic_launcher.png create mode 100644 android/app/src/development/res/mipmap-xxxhdpi/ic_launcher.png create mode 100644 android/app/src/development/res/values/strings.xml diff --git a/android/app/build.gradle b/android/app/build.gradle index 48bdbcfea049..a9ec87369b22 100644 --- a/android/app/build.gradle +++ b/android/app/build.gradle @@ -85,8 +85,14 @@ project.ext.react = [ ] project.ext.envConfigFiles = [ - debug: ".env", - release: ".env.production", + productiondebug: ".env.production", + productionrelease: ".env.production", + stagingrelease: ".env.staging", + stagingdebug: ".env.staging", + adhocrelease: ".env.adhoc", + adhocdebug: ".env.adhoc", + developmentrelease: ".env", + developmentdebug: ".env" ] apply from: "../../node_modules/react-native/react.gradle" @@ -219,6 +225,22 @@ android { } } + flavorDimensions "default" + productFlavors { + production { + applicationId "com.expensify.chat" + } + staging { + applicationId "com.expensify.chat" + } + adhoc { + applicationId "com.expensify.chat.internal" + } + development { + applicationId "com.expensify.chat.dev" + } + } + splits { abi { reset() @@ -258,11 +280,6 @@ android { matchingFallbacks = ['release'] signingConfig signingConfigs.debug } - internalRelease { - initWith release - matchingFallbacks = ['release'] - signingConfig signingConfigs.debug - } } // applicationVariants are e.g. debug, release @@ -365,10 +382,7 @@ task copyDownloadableDepsToLibs(type: Copy) { } apply from: file("../../node_modules/@react-native-community/cli-platform-android/native_modules.gradle"); applyNativeModulesAppBuildGradle(project) -def googleServicesFile = rootProject.file('app/google-services.json') -if (googleServicesFile.exists()) { - apply plugin: 'com.google.gms.google-services' // Google Play services Gradle plugin -} +apply plugin: 'com.google.gms.google-services' // Google Play services Gradle plugin apply plugin: 'com.google.firebase.crashlytics' def isNewArchitectureEnabled() { diff --git a/android/app/src/internalRelease/assets/airshipconfig.properties b/android/app/src/adhoc/assets/airshipconfig.properties similarity index 100% rename from android/app/src/internalRelease/assets/airshipconfig.properties rename to android/app/src/adhoc/assets/airshipconfig.properties diff --git a/android/app/src/adhoc/google-services.json b/android/app/src/adhoc/google-services.json new file mode 100644 index 000000000000..14e4faddd130 --- /dev/null +++ b/android/app/src/adhoc/google-services.json @@ -0,0 +1,47 @@ +{ + "project_info": { + "project_number": "921154746561", + "firebase_url": "https://expensify-chat.firebaseio.com", + "project_id": "expensify-chat", + "storage_bucket": "expensify-chat.appspot.com" + }, + "client": [ + { + "client_info": { + "mobilesdk_app_id": "1:921154746561:android:4f04268f25f84eaf027c40", + "android_client_info": { + "package_name": "com.expensify.chat.internal" + } + }, + "oauth_client": [ + { + "client_id": "921154746561-gpsoaqgqfuqrfsjdf8l7vohfkfj7b9up.apps.googleusercontent.com", + "client_type": 3 + } + ], + "api_key": [ + { + "current_key": "AIzaSyCVwQb9lBI06bDIwHOw10AkdJyquXoMngk" + } + ], + "services": { + "appinvite_service": { + "other_platform_oauth_client": [ + { + "client_id": "921154746561-gpsoaqgqfuqrfsjdf8l7vohfkfj7b9up.apps.googleusercontent.com", + "client_type": 3 + }, + { + "client_id": "921154746561-s3uqn2oe4m85tufi6mqflbfbuajrm2i3.apps.googleusercontent.com", + "client_type": 2, + "ios_info": { + "bundle_id": "com.chat.expensify.chat" + } + } + ] + } + } + } + ], + "configuration_version": "1" +} diff --git a/android/app/src/adhoc/res/mipmap-hdpi/icon-adhoc.png b/android/app/src/adhoc/res/mipmap-hdpi/icon-adhoc.png new file mode 100644 index 0000000000000000000000000000000000000000..e23e1d1e08db41756506cdd2e499400b743f29fa GIT binary patch literal 5539 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 literal 0 HcmV?d00001 diff --git a/android/app/src/adhoc/res/mipmap-mdpi/icon-adhoc.png b/android/app/src/adhoc/res/mipmap-mdpi/icon-adhoc.png new file mode 100644 index 0000000000000000000000000000000000000000..d9aa017d4d2eec8bbaa12a777a03e91405fceece GIT binary patch literal 3467 zcmV;64RrE}P)Px?MM*?KRA@uhS!<9K)fN8kz1=;JotfPQbYY_gvna2Hh>+4mvM6F$dC5aTwo=i= zDy)#86?`QzMnj@TgRdltF%^?C27>_w9}5~#k!VDtC?L8Nh#KA?`!D5CnM4*2e=t9`E!g2m#w6yJ!h8DJ2Zp+)=4;TD4+N^Zvt4|K1z0w2KXe2)YA6 zUU#aitE0&)M$gaI4V+^P>^CHDvY0a1F>X;xfiVXEv%4sC-WPDM4l}u`BiF8Ww=`9} zw&#h1kG`=4d-tY12KcDEY+VX~MqM`c%r854PJ28zu%Z^}JXF>OQ&5bo)S;!vy$CZF z2)6f~AN=FR+1-aJ1_sULjYP4n^^KM13?7;M!|a!3 zi1%R~`8+ri;ACZq#3xMTLArx8KydeymQ;Wv-A@8Vzo54&x)h{ROe#l~S*FO^M=Gyf zdBMSTTQ?U2QMijXu&Syma^$ZKZ#$=y4`v-X8wNj0;P$OG+JAnWCQ z$N*v%P-eNHGB%KNT(G5q5NKOPEyLK|+EjV@($NPF97ua1?@a7M0A#2g|3Uo??F+}= z%|A=!VQ{k~pB?2IO~&tOg?f7r)Ykp(b!)~oQfIgTON4<_%E3nT2OISTeXajaU_>_@ zvt?fPiI}kmH{O)I>$$rDXd8W-iba5jRxj9;ujwdY=+^Gv=nfj3^BMiM6K8Y`M1qLa~hx=Aewx!60D{lSalqThg`#w zS*U$Us2zuaPnv=DoJ*a`2zbL;V3URdwk)1q3gkqlviVH;H=i8byzQe;gSillfR@cZ z<3@b7`QhoW3tK6z3c*FjlLzw-N3wJ00wzGqmxDnq35{Q>;>XsGXld z{e3&shFuyMQhD&-P6zw)0Daw=_`%;*P|9R1cGdE)w!QYj8$nq;20&u!n2VG5O=%RV zyi}a|t%K`fQWjf6E?NtP@S=1rVEd_RQ4%m#kpzIj0N%Y4flFdB;nx=gIi< zYrwA^3sAKs)$t{=WQ*k~7J(zW`LgQg2StFQmoK1`RE~;SBDCPCS?TBBd#YOi*2LP` z_QSK6v9_!O;UzG6v^)g$*Y_ZQztJ`Rf*SA}&UaNr_Y4LQHr+^-5)}eS-p%BX$|%*2 zG83xtL&!h83I6S`fK40j(#sbCT@y@^xbFEmtt;PpvReR=$)hgM{$~0UESYlwkU`|( zy=`!=e-21yz=oU*{>w?O$0_+DCREcws5RSxun2Td1w0}`W*o5kGrjest$NxfDaBp{`5ut z9h)=+d|{pYcY4O7P~_T`4IRe?Fm=@2>;uzX01QH_&Y=!C*F6UuY6qJ<6#V)+pw$a8 z@i!KNdSwUXUF$U+bYv)@iC#fEkuk{}_-z3I^qr!MZysw_w2KnoM=mg`p*MkkM0yTG@cU%B3?|{7XWj6xEajFHQ ztAQ-F3?2&lAisUlifu1mmdKiKzSHAk_NkU1o#c(Tmyow0v#U+V4>2` ze#DlW8lg7t1N+9A;6EDgSLvQdpls@>xv2-HFXg_BDg}9CqtNA?}{!M%k8*N`!^+-Q^9rHOHe6CGmq4 zfs6yo5NJue>a)8QeE!$K=8Qbbe=@2t0z@GyW&;vnHGN!9llo9!M-=?d7$9mLO>{q! z)NYrDp_aV|`OrUgvnLi$0V*OywO#=5b0C>@5HyHDay3jMbL$ar7J z$;-9}V9Cth1IXkZ84rp0!e<-WR{rbw0MaC*1mHv|L<)6AKd>>UxODQRGHifP8LAbh zvsQFc$gB1xDAZ#BiRokJChwiPlm{wtuame_h3bHoK*E!FrKpuIauO?*#9k$qajRz$ zhy?2Z%{{uvXf^m<)I#)BMhgItx2dBoC8MMXB%@pQflV9?{=*A8Wt4iMiW?gnnpeEp zLkf|MQX!)zZdI_5T?{t#r%vj3W zv+jAIu$fDQz<*H>HsmDt1VyXI%^Zhl%R&9@La1+?;WlfO4`H{Bz%4HTZ8;cIh64-7 zLix>{*NyhFka_2U!gjhPt<{Aun&`?Ttg}_ zUAs*^7b);hFl~;j*Pey(Z&f3b;!uIX9@;Xx@MR(r>&`!fM=p2=IYWUvdR*!C zLM!H^8{g~xKvOZ}+?lP5>sN@5yrT+7DuU}!vs24~co;Bw=Q&x+BOOlkDZ1;CO#e?v z-1q2(nDP1hOU{&2t{NSp!fWx7@^FVaLs#)#NztjDZ zGBIV$q~!gRpXVuCB6z6R%@`d%4EH$5nLfm*clUx#uhpGuu|vI347o@a6W$qwM}9XE zNBU&p?_%rS5N-?4V|4p{A$v|}a@e}DPp)S4}g z-JZxQzdroDmPcm(gWE-BLR!$gxlq=IbLBGNvy@f~Hg=#sWwAkh-Db_Bhmah(LNa8VoYxUbhE>i2i_Lp- zY;r@>Yo+EwdazYqdumPFpXR`@DhCT%r+!KxEl zodg8(sYAGWQ$23R<&YB;Ol3gX3NkGrvl1-iPH*Tt8Y5&gHjH%+el_VWEV<-OWpzZD zozG>>*^ds-?l`!!6aYV^EdI>AciFJ&AxPzEDt2@>6g=M&ov8Et*c&ar@rfIag3%%e zhqO}|6dj6Hr#*_iQpklI7*PSIL+bYllsh6Opt2H_3K7Eu>rj|=<0@>gJ}eCpVd}$u zAKKF%K8wzDUXtl{pl|@9r*p>qaf{T=6K}!6qzzM)o=gXaySrPV-tmUJbWN(_O{aOt zf{fd^>`PbRwtWqVw9vc|VE*`>yiWy@yGfif^H?W2%rei8As1xfY6 zi>jW9DTZVuhjq1|plRSC7)fEHJZv~k`#&zb?6Gs&+uIKXZg&$t$O`XTQ^^?8f1Lcw zmCv%uXdJC+8-jEF4ykZn>Tl447aUwNJhB#E23Ats@PQGyE)%LbM>w5Ew$=_Rpi1dk^nw>p*zN#N~2|KON>8vai z*0Un&)4O>uQ6#dZztZkdS^!i>Hlsd0vP-Sr`b^}pO%JBi>3^3pz7&OmKh*hREgp~e z%T$C0%F5^fR9Fdw%!s3;2^zxdB}lHc&!s-WQ;`+)4}*j{I<9pT=YmP;(BGA0QVB2{ zSv!rkTnj&v+8=Joew<7u4||53@N3o}&B(|ezdi4j_e{z%;z4!e*n=yAetsS_~ZZp002ovPDHLkV1nwBkLv&c literal 0 HcmV?d00001 diff --git a/android/app/src/adhoc/res/mipmap-xhdpi/icon-adhoc.png b/android/app/src/adhoc/res/mipmap-xhdpi/icon-adhoc.png new file mode 100644 index 0000000000000000000000000000000000000000..24b60bf467e6ae2e8358fa0be059b48d56ea3e1a GIT binary patch literal 7713 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

bfSLPlv*&3jmMDgVwgTFz34Nc6*^k!eK3{ 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 rH^Pb!yf1+hIxR%Z0RLa%&mWP_z)~*YWRdXM3; + New Expensify Internal + diff --git a/android/app/src/development/assets/airshipconfig.properties b/android/app/src/development/assets/airshipconfig.properties new file mode 100644 index 000000000000..490f74552f11 --- /dev/null +++ b/android/app/src/development/assets/airshipconfig.properties @@ -0,0 +1,8 @@ +appKey = uulSSfTDQJ2r0PMpjRrhmQ +appSecret = D4Bhf0HrQEehrPua74Tyiw +inProduction = false +developmentLogLevel = VERBOSE + +# Notification Customization +notificationIcon = ic_notification +notificationAccentColor = #2EAAE2 \ No newline at end of file diff --git a/android/app/src/development/res/mipmap-hdpi/ic_launcher.png b/android/app/src/development/res/mipmap-hdpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..7c1304d1d30c619a764f62f40d18c4b465e5a79a GIT binary patch literal 5552 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 Z{ulNBE1ID7QDguB002ovPDHLkV1mn7uuA{{ literal 0 HcmV?d00001 diff --git a/android/app/src/development/res/mipmap-xhdpi/ic_launcher.png b/android/app/src/development/res/mipmap-xhdpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..71e97528f1f6607e21a3d8740aa49b0d45bab010 GIT binary patch literal 7673 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 literal 0 HcmV?d00001 diff --git a/android/app/src/development/res/mipmap-xxhdpi/ic_launcher.png b/android/app/src/development/res/mipmap-xxhdpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..16a50496ae3defcb0b6b3b34f50d52bfb4f8531f GIT binary patch literal 12529 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 VLKjn@bo04ID>&ekf2&_?_P;3SkW&Bv literal 0 HcmV?d00001 diff --git a/android/app/src/development/res/values/strings.xml b/android/app/src/development/res/values/strings.xml new file mode 100644 index 000000000000..545b4a07a105 --- /dev/null +++ b/android/app/src/development/res/values/strings.xml @@ -0,0 +1,3 @@ + + New Expensify Dev + diff --git a/package-lock.json b/package-lock.json index 245495b1376f..d7f235bff7c2 100644 --- a/package-lock.json +++ b/package-lock.json @@ -136,7 +136,7 @@ "css-loader": "^6.7.2", "diff-so-fancy": "^1.3.0", "dotenv": "^16.0.3", - "electron": "^22.3.5", + "electron": "22.3.5", "electron-builder": "23.5.0", "electron-notarize": "^1.2.1", "eslint": "^7.6.0", From b84fefe58270848bfa7c5d0209a84d4e32e97118 Mon Sep 17 00:00:00 2001 From: staszekscp Date: Thu, 13 Apr 2023 12:05:39 +0200 Subject: [PATCH 02/51] support flavors on android --- android/app/build.gradle | 2 +- android/app/google-services.json | 170 ++++++++++++++---- android/app/src/adhoc/google-services.json | 47 ----- .../res/mipmap-anydpi-v26/ic_launcher.xml | 5 + .../mipmap-anydpi-v26/ic_launcher_round.xml | 5 + .../src/adhoc/res/mipmap-hdpi/ic_launcher.png | Bin 0 -> 4486 bytes .../mipmap-hdpi/ic_launcher_foreground.png | Bin 0 -> 13148 bytes .../res/mipmap-hdpi/ic_launcher_round.png | Bin 0 -> 6391 bytes .../src/adhoc/res/mipmap-hdpi/icon-adhoc.png | Bin 5539 -> 0 bytes .../src/adhoc/res/mipmap-ldpi/ic_launcher.png | Bin 0 -> 1748 bytes .../src/adhoc/res/mipmap-mdpi/ic_launcher.png | Bin 0 -> 2499 bytes .../mipmap-mdpi/ic_launcher_foreground.png | Bin 0 -> 6428 bytes .../res/mipmap-mdpi/ic_launcher_round.png | Bin 0 -> 3581 bytes .../src/adhoc/res/mipmap-mdpi/icon-adhoc.png | Bin 3467 -> 0 bytes .../adhoc/res/mipmap-xhdpi/ic_launcher.png | Bin 0 -> 5280 bytes .../mipmap-xhdpi/ic_launcher_foreground.png | Bin 0 -> 16902 bytes .../res/mipmap-xhdpi/ic_launcher_round.png | Bin 0 -> 7532 bytes .../src/adhoc/res/mipmap-xhdpi/icon-adhoc.png | Bin 7713 -> 0 bytes .../adhoc/res/mipmap-xxhdpi/ic_launcher.png | Bin 0 -> 11398 bytes .../mipmap-xxhdpi/ic_launcher_foreground.png | Bin 0 -> 50362 bytes .../res/mipmap-xxhdpi/ic_launcher_round.png | Bin 0 -> 14975 bytes .../adhoc/res/mipmap-xxhdpi/icon-adhoc.png | Bin 12706 -> 0 bytes .../adhoc/res/mipmap-xxxhdpi/ic_launcher.png | Bin 0 -> 14025 bytes .../mipmap-xxxhdpi/ic_launcher_foreground.png | Bin 0 -> 75340 bytes .../res/mipmap-xxxhdpi/ic_launcher_round.png | Bin 0 -> 18245 bytes .../adhoc/res/mipmap-xxxhdpi/icon-adhoc.png | Bin 18087 -> 0 bytes .../res/mipmap-anydpi-v26/ic_launcher.xml | 5 + .../mipmap-anydpi-v26/ic_launcher_round.xml | 5 + .../res/mipmap-hdpi/ic_launcher.png | Bin 5552 -> 4567 bytes .../mipmap-hdpi/ic_launcher_foreground.png | Bin 0 -> 12852 bytes .../res/mipmap-hdpi/ic_launcher_round.png | Bin 0 -> 6253 bytes .../res/mipmap-ldpi/ic_launcher.png | Bin 0 -> 1753 bytes .../res/mipmap-mdpi/ic_launcher.png | Bin 3499 -> 2506 bytes .../mipmap-mdpi/ic_launcher_foreground.png | Bin 0 -> 6368 bytes .../res/mipmap-mdpi/ic_launcher_round.png | Bin 0 -> 3501 bytes .../res/mipmap-xhdpi/ic_launcher.png | Bin 7673 -> 5187 bytes .../mipmap-xhdpi/ic_launcher_foreground.png | Bin 0 -> 16232 bytes .../res/mipmap-xhdpi/ic_launcher_round.png | Bin 0 -> 7410 bytes .../res/mipmap-xxhdpi/ic_launcher.png | Bin 12529 -> 11394 bytes .../mipmap-xxhdpi/ic_launcher_foreground.png | Bin 0 -> 49036 bytes .../res/mipmap-xxhdpi/ic_launcher_round.png | Bin 0 -> 14506 bytes .../res/mipmap-xxxhdpi/ic_launcher.png | Bin 17895 -> 13942 bytes .../mipmap-xxxhdpi/ic_launcher_foreground.png | Bin 0 -> 72988 bytes .../res/mipmap-xxxhdpi/ic_launcher_round.png | Bin 0 -> 17913 bytes 44 files changed, 154 insertions(+), 85 deletions(-) delete mode 100644 android/app/src/adhoc/google-services.json create mode 100644 android/app/src/adhoc/res/mipmap-anydpi-v26/ic_launcher.xml create mode 100644 android/app/src/adhoc/res/mipmap-anydpi-v26/ic_launcher_round.xml create mode 100644 android/app/src/adhoc/res/mipmap-hdpi/ic_launcher.png create mode 100644 android/app/src/adhoc/res/mipmap-hdpi/ic_launcher_foreground.png create mode 100644 android/app/src/adhoc/res/mipmap-hdpi/ic_launcher_round.png delete mode 100644 android/app/src/adhoc/res/mipmap-hdpi/icon-adhoc.png create mode 100644 android/app/src/adhoc/res/mipmap-ldpi/ic_launcher.png create mode 100644 android/app/src/adhoc/res/mipmap-mdpi/ic_launcher.png create mode 100644 android/app/src/adhoc/res/mipmap-mdpi/ic_launcher_foreground.png create mode 100644 android/app/src/adhoc/res/mipmap-mdpi/ic_launcher_round.png delete mode 100644 android/app/src/adhoc/res/mipmap-mdpi/icon-adhoc.png create mode 100644 android/app/src/adhoc/res/mipmap-xhdpi/ic_launcher.png create mode 100644 android/app/src/adhoc/res/mipmap-xhdpi/ic_launcher_foreground.png create mode 100644 android/app/src/adhoc/res/mipmap-xhdpi/ic_launcher_round.png delete mode 100644 android/app/src/adhoc/res/mipmap-xhdpi/icon-adhoc.png create mode 100644 android/app/src/adhoc/res/mipmap-xxhdpi/ic_launcher.png create mode 100644 android/app/src/adhoc/res/mipmap-xxhdpi/ic_launcher_foreground.png create mode 100644 android/app/src/adhoc/res/mipmap-xxhdpi/ic_launcher_round.png delete mode 100644 android/app/src/adhoc/res/mipmap-xxhdpi/icon-adhoc.png create mode 100644 android/app/src/adhoc/res/mipmap-xxxhdpi/ic_launcher.png create mode 100644 android/app/src/adhoc/res/mipmap-xxxhdpi/ic_launcher_foreground.png create mode 100644 android/app/src/adhoc/res/mipmap-xxxhdpi/ic_launcher_round.png delete mode 100644 android/app/src/adhoc/res/mipmap-xxxhdpi/icon-adhoc.png create mode 100644 android/app/src/development/res/mipmap-anydpi-v26/ic_launcher.xml create mode 100644 android/app/src/development/res/mipmap-anydpi-v26/ic_launcher_round.xml create mode 100644 android/app/src/development/res/mipmap-hdpi/ic_launcher_foreground.png create mode 100644 android/app/src/development/res/mipmap-hdpi/ic_launcher_round.png create mode 100644 android/app/src/development/res/mipmap-ldpi/ic_launcher.png create mode 100644 android/app/src/development/res/mipmap-mdpi/ic_launcher_foreground.png create mode 100644 android/app/src/development/res/mipmap-mdpi/ic_launcher_round.png create mode 100644 android/app/src/development/res/mipmap-xhdpi/ic_launcher_foreground.png create mode 100644 android/app/src/development/res/mipmap-xhdpi/ic_launcher_round.png create mode 100644 android/app/src/development/res/mipmap-xxhdpi/ic_launcher_foreground.png create mode 100644 android/app/src/development/res/mipmap-xxhdpi/ic_launcher_round.png create mode 100644 android/app/src/development/res/mipmap-xxxhdpi/ic_launcher_foreground.png create mode 100644 android/app/src/development/res/mipmap-xxxhdpi/ic_launcher_round.png diff --git a/android/app/build.gradle b/android/app/build.gradle index a9ec87369b22..2061f1702fb9 100644 --- a/android/app/build.gradle +++ b/android/app/build.gradle @@ -234,7 +234,7 @@ android { applicationId "com.expensify.chat" } adhoc { - applicationId "com.expensify.chat.internal" + applicationId "com.expensify.chat.adhoc" } development { applicationId "com.expensify.chat.dev" diff --git a/android/app/google-services.json b/android/app/google-services.json index 545f49d765bf..7e076c3bd124 100644 --- a/android/app/google-services.json +++ b/android/app/google-services.json @@ -1,47 +1,143 @@ { "project_info": { - "project_number": "921154746561", - "firebase_url": "https://expensify-chat.firebaseio.com", - "project_id": "expensify-chat", - "storage_bucket": "expensify-chat.appspot.com" + "project_number": "921154746561", + "firebase_url": "https://expensify-chat.firebaseio.com", + "project_id": "expensify-chat", + "storage_bucket": "expensify-chat.appspot.com" }, "client": [ - { - "client_info": { - "mobilesdk_app_id": "1:921154746561:android:4f04268f25f84eaf027c40", - "android_client_info": { - "package_name": "com.expensify.chat" - } - }, - "oauth_client": [ - { - "client_id": "921154746561-gpsoaqgqfuqrfsjdf8l7vohfkfj7b9up.apps.googleusercontent.com", - "client_type": 3 - } - ], - "api_key": [ - { - "current_key": "AIzaSyCVwQb9lBI06bDIwHOw10AkdJyquXoMngk" + { + "client_info": { + "mobilesdk_app_id": "1:921154746561:android:4f04268f25f84eaf027c40", + "android_client_info": { + "package_name": "com.expensify.chat" + } + }, + "oauth_client": [ + { + "client_id": "921154746561-o0pgqgc84e3e97s9iljlmimcb5nesqad.apps.googleusercontent.com", + "client_type": 1, + "android_info": { + "package_name": "com.expensify.chat", + "certificate_hash": "5e8f16062ea3cd2c4a0d547876baa6f38cabf625" + } + }, + { + "client_id": "921154746561-gpsoaqgqfuqrfsjdf8l7vohfkfj7b9up.apps.googleusercontent.com", + "client_type": 3 + } + ], + "api_key": [ + { + "current_key": "AIzaSyCVwQb9lBI06bDIwHOw10AkdJyquXoMngk" + } + ], + "services": { + "appinvite_service": { + "other_platform_oauth_client": [ + { + "client_id": "921154746561-gpsoaqgqfuqrfsjdf8l7vohfkfj7b9up.apps.googleusercontent.com", + "client_type": 3 + }, + { + "client_id": "921154746561-080fav7kvk6s70k6nd70mt50isubgff4.apps.googleusercontent.com", + "client_type": 2, + "ios_info": { + "bundle_id": "com.expensify.chat.adhoc" } - ], - "services": { - "appinvite_service": { - "other_platform_oauth_client": [ - { - "client_id": "921154746561-gpsoaqgqfuqrfsjdf8l7vohfkfj7b9up.apps.googleusercontent.com", - "client_type": 3 - }, - { - "client_id": "921154746561-s3uqn2oe4m85tufi6mqflbfbuajrm2i3.apps.googleusercontent.com", - "client_type": 2, - "ios_info": { - "bundle_id": "com.chat.expensify.chat" - } - } - ] + } + ] + } + } + }, + { + "client_info": { + "mobilesdk_app_id": "1:921154746561:android:333e293a7fef83a8027c40", + "android_client_info": { + "package_name": "com.expensify.chat.adhoc" + } + }, + "oauth_client": [ + { + "client_id": "921154746561-cbegir0tnc2gan6k1gre5vtn75p60hom.apps.googleusercontent.com", + "client_type": 1, + "android_info": { + "package_name": "com.expensify.chat.adhoc", + "certificate_hash": "5e8f16062ea3cd2c4a0d547876baa6f38cabf625" + } + }, + { + "client_id": "921154746561-gpsoaqgqfuqrfsjdf8l7vohfkfj7b9up.apps.googleusercontent.com", + "client_type": 3 + } + ], + "api_key": [ + { + "current_key": "AIzaSyCVwQb9lBI06bDIwHOw10AkdJyquXoMngk" + } + ], + "services": { + "appinvite_service": { + "other_platform_oauth_client": [ + { + "client_id": "921154746561-gpsoaqgqfuqrfsjdf8l7vohfkfj7b9up.apps.googleusercontent.com", + "client_type": 3 + }, + { + "client_id": "921154746561-080fav7kvk6s70k6nd70mt50isubgff4.apps.googleusercontent.com", + "client_type": 2, + "ios_info": { + "bundle_id": "com.expensify.chat.adhoc" } + } + ] + } + } + }, + { + "client_info": { + "mobilesdk_app_id": "1:921154746561:android:3b19fdbaedb5b586027c40", + "android_client_info": { + "package_name": "com.expensify.chat.dev" + } + }, + "oauth_client": [ + { + "client_id": "921154746561-svjnccrcn6vet45kn9o7sibb3jemipa6.apps.googleusercontent.com", + "client_type": 1, + "android_info": { + "package_name": "com.expensify.chat.dev", + "certificate_hash": "5e8f16062ea3cd2c4a0d547876baa6f38cabf625" } + }, + { + "client_id": "921154746561-gpsoaqgqfuqrfsjdf8l7vohfkfj7b9up.apps.googleusercontent.com", + "client_type": 3 + } + ], + "api_key": [ + { + "current_key": "AIzaSyCVwQb9lBI06bDIwHOw10AkdJyquXoMngk" + } + ], + "services": { + "appinvite_service": { + "other_platform_oauth_client": [ + { + "client_id": "921154746561-gpsoaqgqfuqrfsjdf8l7vohfkfj7b9up.apps.googleusercontent.com", + "client_type": 3 + }, + { + "client_id": "921154746561-080fav7kvk6s70k6nd70mt50isubgff4.apps.googleusercontent.com", + "client_type": 2, + "ios_info": { + "bundle_id": "com.expensify.chat.adhoc" + } + } + ] + } } + } ], "configuration_version": "1" -} + } \ No newline at end of file diff --git a/android/app/src/adhoc/google-services.json b/android/app/src/adhoc/google-services.json deleted file mode 100644 index 14e4faddd130..000000000000 --- a/android/app/src/adhoc/google-services.json +++ /dev/null @@ -1,47 +0,0 @@ -{ - "project_info": { - "project_number": "921154746561", - "firebase_url": "https://expensify-chat.firebaseio.com", - "project_id": "expensify-chat", - "storage_bucket": "expensify-chat.appspot.com" - }, - "client": [ - { - "client_info": { - "mobilesdk_app_id": "1:921154746561:android:4f04268f25f84eaf027c40", - "android_client_info": { - "package_name": "com.expensify.chat.internal" - } - }, - "oauth_client": [ - { - "client_id": "921154746561-gpsoaqgqfuqrfsjdf8l7vohfkfj7b9up.apps.googleusercontent.com", - "client_type": 3 - } - ], - "api_key": [ - { - "current_key": "AIzaSyCVwQb9lBI06bDIwHOw10AkdJyquXoMngk" - } - ], - "services": { - "appinvite_service": { - "other_platform_oauth_client": [ - { - "client_id": "921154746561-gpsoaqgqfuqrfsjdf8l7vohfkfj7b9up.apps.googleusercontent.com", - "client_type": 3 - }, - { - "client_id": "921154746561-s3uqn2oe4m85tufi6mqflbfbuajrm2i3.apps.googleusercontent.com", - "client_type": 2, - "ios_info": { - "bundle_id": "com.chat.expensify.chat" - } - } - ] - } - } - } - ], - "configuration_version": "1" -} diff --git a/android/app/src/adhoc/res/mipmap-anydpi-v26/ic_launcher.xml b/android/app/src/adhoc/res/mipmap-anydpi-v26/ic_launcher.xml new file mode 100644 index 000000000000..036d09bc5fd5 --- /dev/null +++ b/android/app/src/adhoc/res/mipmap-anydpi-v26/ic_launcher.xml @@ -0,0 +1,5 @@ + + + + + \ No newline at end of file diff --git a/android/app/src/adhoc/res/mipmap-anydpi-v26/ic_launcher_round.xml b/android/app/src/adhoc/res/mipmap-anydpi-v26/ic_launcher_round.xml new file mode 100644 index 000000000000..036d09bc5fd5 --- /dev/null +++ b/android/app/src/adhoc/res/mipmap-anydpi-v26/ic_launcher_round.xml @@ -0,0 +1,5 @@ + + + + + \ No newline at end of file diff --git a/android/app/src/adhoc/res/mipmap-hdpi/ic_launcher.png b/android/app/src/adhoc/res/mipmap-hdpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..995f52ee9d7cf35db951a929e2dd23c17e016c98 GIT binary patch literal 4486 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 FV1f+Vb94Xz literal 0 HcmV?d00001 diff --git a/android/app/src/adhoc/res/mipmap-hdpi/icon-adhoc.png b/android/app/src/adhoc/res/mipmap-hdpi/icon-adhoc.png deleted file mode 100644 index e23e1d1e08db41756506cdd2e499400b743f29fa..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 5539 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 diff --git a/android/app/src/adhoc/res/mipmap-ldpi/ic_launcher.png b/android/app/src/adhoc/res/mipmap-ldpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..30c0e84843091da8ea4cf08833ade97603107d9a GIT binary patch literal 1748 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 DKUD0) literal 0 HcmV?d00001 diff --git a/android/app/src/adhoc/res/mipmap-mdpi/icon-adhoc.png b/android/app/src/adhoc/res/mipmap-mdpi/icon-adhoc.png deleted file mode 100644 index d9aa017d4d2eec8bbaa12a777a03e91405fceece..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3467 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 diff --git a/android/app/src/adhoc/res/mipmap-xhdpi/ic_launcher.png b/android/app/src/adhoc/res/mipmap-xhdpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..962973c754148ddf4ede278dc645ee5d190053bb GIT binary patch literal 5280 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 m+##E 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 U32Dihx&QzG07*qoM6N<$g7O;1nE(I) literal 0 HcmV?d00001 diff --git a/android/app/src/adhoc/res/mipmap-xxhdpi/ic_launcher_foreground.png b/android/app/src/adhoc/res/mipmap-xxhdpi/ic_launcher_foreground.png new file mode 100644 index 0000000000000000000000000000000000000000..f9ae0e7eb8e9a326236ae6d4bbab392d6715d6f6 GIT binary patch literal 50362 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

bfSLPlv*&3jmMDgVwgTFz34Nc6*^k!eK3{ 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%0AY_!^%7Xd}WT`@?-q$`)a$0RpS&^aD? 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 X)!PNOc5X@n2zbF%w3N#pJ`eqWIWG`% literal 0 HcmV?d00001 diff --git a/android/app/src/adhoc/res/mipmap-xxxhdpi/ic_launcher_round.png b/android/app/src/adhoc/res/mipmap-xxxhdpi/ic_launcher_round.png new file mode 100644 index 0000000000000000000000000000000000000000..0d17c0f1d1aa106eb3422372481a732e404c9854 GIT binary patch literal 18245 zcmXtAWmFq&ur8qiiWhe%P@LlK?(Xi=;_edM9g4eC+}+)wxE1%{Za3e(=lKLnYyGbjciWFdpU@t)m-n zi#fQ@yts%xOiQy6XPJ{suN5EKTCy_dztNp~%3gc$o_feU z$KR5aJr1=LNz^^oA~=>!#VwFC<|jTSsV7Z6Zd+zMSm}ad&n?NP*=rzW?M*zQ;j80Z z_1N|#YVOnB*wbihSW*s^(<>8pXeD)sKZ~2Dm(l@vE#LXWRyUEfVtf05>a@+`D1M?I zuxZx{uM@qfPH>N_8zzIB!%`=zj1Z}JT6Gqc84r}136;_MV8OD=o_m%xVEmD$FXjc( z5BiZLKjWGUjHe)h#{)7^k!X@Ykt=3>9ug8qjVVBclK9MpHvcca7U6{%Bc&g=1CA~U zoLxaLBgax6)8Ed&U~5Fyr>@HIxe1_yx+0iol%}^1qewlK>-lLJ;Y?@`H;E7CzNE>| zD3!Zha~x<>94T z8#R7d)Qqa}?I!&DVkLNR>(eXNkC$#d3`;F`|0AcI81p~+G1sR(m~e+swI14MWA+PT zyQRD+uLRp&x$&WBhlh9~8=705J-+a&bo(^R!j{VPKcyD%gzc9~)S)#17vk=;mXTiK z_Ey&P_VoQz#zRV7DBcMBy%WI(IQcP0d&)b?>_X zqsBlgZtx+~;L^0qMU+*9CuqGE&*Z_4VT2FHR>9_@@0)@CB9d4c+k0}pAd-R)b0$`m z_@4SdLe;&>vY-|X>7xp%R~e{@D{hbp}(z~c`V5SL4L z8h$V+5-(47y@kET#-(=4WPX&CRKgxN6bj~T^EyNa78lYYE?7yS;{JhtV z`zY?IGnL%-SG@YyV?(}RyoCVaRPNHJ9F_P;c-Zv6lrW+j2mXI)VL&CI>Ccs~j2_#E zDho9AMOeEplfHjY>Jb?~^;!rtazSs2KO&Q2o9Q$O#<>0^oAL^2h+(4A4Z6&V+Scja z$XPv`e%X)u%?E_%dnrp5A})GrMQX%c1-!i`%T-=>hpU`LpDgO{;|Tz^i<3yX(6b!PZC}wJ zQ=Yx2pt;O!j8Y7k;K<6$-Q&0$%E|U;A&^OuK_eMU_-jONT&rFX{k6u(UGyX#8~GcSK-^;N$PjH-rY`Zicgzh{=& zTK^3w?@wQ$G304#Z=qL$jr|mQj{Vi>FWo9*o|Z?%a%7Y!(e?N3xw_=icK55&5Evw% zpPyw-mr9zWfVbFi#L8cH%^PE50l|bTjstgjVrn&ELVNutP%rf(EIF&|OG_FY-rX2g zI`9onhw?XFmF-ooq96KVo=z1Mz}H7aV7ZkydG2+u-+KKUCC8?_iJoWpt9s|())o7r z%?yw6^X4tvO*e2=2H`djd?$ct!=ZjLb^}^Jw8px2FDA>pW$A0zO_!6~hWE>P^HT62 z!;rGG{b;A)d8{8d@7HYfF`ux{Lbf(oAAizlLMnSYm}Nj{oE>xcUEp=Wxt}n(8JD# z)aR>{3G5tK{amgZrT3IruiQeP_|tF9;~Dy4hW9hh z?lFwg>gws&w>9Y5_mDjSs`cD@#jNKdLBUmFUf?jrY{9O*I|gBU>(RKe>t2N5moqoFQPs5RgN29VMYO z|EoUo^iq&GU5h4Lh?D z$jFU^D|2^dg!$bvw-IWk3$N9h&szISEvk!rqV=bz*O>Qnzw7ws?B~%s6?xG6+4TFw zZKuzP&(DGn#YWhP3ON_m*(>tr5uw}OH+y^5>9s=?mUq8sf7Tf#{D%gZFViE+6Wdw}&k|Uz>e}&1{TL{MnnWmbU3m8N1fCJ)BLUDCyO)N!Z$YK+}ST3`{)m2*(&?E z+-4X@uM!`Bjt7_b80gwMPrT0PLhc9VkGjvr{BF@Q!wyvpY|2%T8G=V`qDk%6PS}Hn z7!?JaC6n|H2k{NMPv;bdxb&!Io>2V0JuA=OE)mQ=sD<9sWdpV~Z-0l*+VLU0b?3kI z-!~a=HX`Y7L)gpt1108K6X#K`6c4G^4vEleD$a0CAXXxj_#+7ZY>oWRTcQZOG_5-hc3Fj zL=&$#dBAc>FDyZjJ%-N_iRS|gLM1lIg`;)nB4`mWHXYv@|Q>|Nz>Xvb|@^1iE z3BxydQ!8x8O&ZOG&-6+Iruds@ZECt2mHCNMoZKKVt|R3Ra<(&{+QP{uct8**Y|ym9S{oF>xj9X}low2TpU!l*BT z_E}TM32%?y9`#-JTGzAJ_?4wpl%RC`?gIvNWH2~-RXm+&iCM>=x8qR?%zK!6&u(2tx>3+rzL zIydJ+m4$gOcyl$FY-DeTlO0VPfC|vN!g&tte02&^1$^r>HV03dBvlyo0G zKiM>IsPneAS@N#&KRGq#*By4>m)G83`PV~#JE5RZU{}CgG=+HsI~{d{9bi+ttPX-j zV49rUSjwyQB1Hqts`PWG^id9M6}kio7%dfOi%Wn$Yg|Vv&_^iueO>5aLC-EEUz%_t zJh8IF5ra0n%(z)UT}G|9Sqx6j0?Hp-kgghrzVbX zW36f){Wa%*(7?Uf?e{WBwcSy+8NqC+rMLXjUq-8a@tNDV<$}6y?I8 zv1q6RdcP$PDsCKk-_auecX0Nq(ba7BD7ovf$mPUra4;SMnH|?!1I?}C5wxZmFqyj=Wg)kO~`p_Xzxkf3-|C z8?Y~HukFHPX+i7fZ~C4JFD7D7`nlDA%(9hy3uOrK&go&n;EP7$kC_ZI3!fD?cOeWa z!8`^({ki|b@&1nK5^e2(hMHyI96!pakJ^`tzD=Xsir6+UFiBUJH5LKt-l`KLu{+Wn zhJ!+6OSDC}{hMOselSb^Awgu($5YCk#sIPVKPdY0e#~7l571(zjzzXr_?Go7l9rvY z>t6OCQJUz?wrQRhbDE&MlE%oK58+gc)TOLthqq+_$ct{3uk2KKjE zL%o@7WB4Er)GE6_NAF+H4*jC|XHir(L!hV;UL9*mb z!IW5bF1n1}{U~Nqi4>ci;YyD1FXGieD=*-0y{{G=cqX+*d#Hz#MUYF^gR4?XWg7`+5!R=!^g>6 z|F)8w%g-uPY44ETBfjYXr(bixI8?8@7;vDDMwRX{!&5>9rt~&YDYv+|_#Xn&ZnHmD z^tWFUpj${zFbSpYE~x+NbXp{-Bci96Wu^d%k@FlMs|V(@)OzmU9_6VNWa#|uJ?!6Y zW@Tf0IyD}|DE*6WEkmo*P%qi7?28zdJ~3X1|*M zz#FOC0%L>7z`vAxgYh>(mZ0A)^FiCq!H;UO@b*Gp6X$-G=v|G?nJzQR@9MM@A%}9H zfL_B#cg{DRm5<=j3VxumCE8oJ7frVbq}+IWYSqIo7t(+)!V9W``<;&-IruK3mP>Hk z)XSxZd73NWKI<~m$Xq9oL z#qgLnUtZsSA8n-2*US-5Y@+yK3{M-x@1?H1&s5C?&-(mg?_g1r$<7q+P_ zZ50(2sSB#Z2)FwTek+CZ$Cr{+K6+pD|ItpQxeM(HF8I`Vu`)dnl7ffim+YJ#cFXF9 zixXJ0!5EU518~=1gxrE!QS$GXqRd+ef1?2VX5>k2KeFUQyI;*d@LFkL);2Vq)knD zu2&mdy{qBRuXfYNuJZ(2r;APv-y+7G)1>oIz)l|v0f480{Mrj=M7^)!qUAFGRid(- z1jxkEC}U3Ook3Iq)z5e zF7M)Rb-%u}B=@j^2za==d*ZMvAgBrh*sL~$mylAf6-PNqfup9ERWks!7eS{F4Dx!^ z9Uk9xYgXM>O^G0-2EV}6- z14lBZ?^6V(uN*LZ9!ZQV+Qq3TyYAzdU3dQzF_fz1#$?2gL4^UI=7V%4LkCt54Q6^V zyTXthMmwr1NZy#;*qL%)^#9K+PKJU%v=H>rPyF9VGc zIod_+@d@a|b@>*;xW_v_c@}ahXVn}eQ4mgZe za~)2RcY84IU5fe@h+t-gVemBX_(r zl8~BnYJ5g+9LCz)e=<2{xh9OM> zyR<|Pj5+I3{9m4*8HZB06;HgyoOFl|1_u|e0H7}WKa7u#b7(FGQb}sPlgX>wzof!1 ztxn3g)N-7-H<}Ojr0dsVZ=X!S-M>6Q-Zs6BQ33GgoJrhUI40gVP>co)GlSR$QH|`p zSQFNhV(KJ=Su=gqs6QjSICWPDPc;O+=-ez@-9gg91}qGdWdnNAHN6FHPVPas`{Fm+PfD10zWz_2Q34%W@{9OWobS|^n_m3Ur zQAL$4h0&Ezn?Osyd3b%aZ=G`_FN zK$;?fku})V>rzZA{QBye#psM%EgF+PDq{=XXi=Nx>qG;2)cMHZ??|c#HE(;EsvxSP zc&4pg*ZTF@)qg*H?g_a?KqsHvnp-Y}vjYL~&NE~M3*k#BuODhsIBQIh%Qdau?!0_4 zB-JJvbcUA746iXpI3B6M@Yo_C$J^nYbhKqJ6ubM)4y?w0vDP|6?>1!;pk;K684EU0 zczZ+>0)bEhA~f98EL?6Uq(Q=YikFh)voh*#0*9AT1Kf(#dLviLafKb0mr+TL#}8*hGCprZQOtjq~_lUCB9xc=QQlIA2> z+NvEzP6LrL$q?zPksNlkNp+M<)dsOlL*&sm(}PO+-&*UvD-e54tWf!kXAx+Qlr)b#yKM;(k=kG+i)1{6KGd(?@1Q|^lsIi3{S`X%m^`(ByAh0H1Z<=N&Gq*5(7E-ZiASw=NQN$9{ zls3GZ4FnoqKUK>_i$H}1A1*1D~P8BH@p%%m$q5 z22|BVWxdy_F@9#O!rqC9mb{W~H@)Gjp70eFu76y_0n0da{y>?7?St=p4=VE zs=;kL)mvP;*5^*qLTXBC_zelvdrbV}yBs$=gj9X+I^#y9Le(xWwBlbfCtCPT{WzW2 zs%Ulssyekf@xj7OduvH2bH){5I=k=OUUuiYvK_4-@AmZ$P(rl0YK>h(%3Q$f^<4Hs z3N=YkM~|s_2STx6ZQQ9)s?`sYY`}1Ko}h~~=x;4};#L=9B&>bhS&d3jNF75lH!eLX zOmiBETL7Mwn>(U>HH-~R(}x2a#&cjHjCDX#&tq{OsgmJ ze8=xL7Z}@^7KFj;;wDykE-p{4G^K=5BPUrpOC`-8~u&#=Ao@r5taIB%7{gGk6=h$iRHU6eceXT{f26&(wrKO_dFdPHt(kktgFiO8A8HlRM zGb2Y0#5dZE#{fnv+Kg;;Vya4iAt%zSYU137)(2@y6i2$=jUNbowS^O+)5U~m74aT6 zkvG&;W7+iXf2C67&T1k}_~{U^3&cH-rA6qt)~~^)LYt_(&b$k05DP7quBa!VQVhR5 z1+}Rn5$D`el{3=x4+?Bo};KPE4;MA%KH7J7}Alp^}>ic=EGSzGDS3+vp8g(6=&QD@4M= z%ZqqZBll1UxY(A4AKW*g)pB(aM*2$u;mU|==x<=oFzxb?!)A6*zxZsCKm z(y1sBp;r2CEcZ(!f4hc>0?dg#0l{RefR6pj{;CS3j-~YI1Uc+wF##3zSpkp8ieXNC zxdy|`sl|+rw%E`0(Equ_1)+GXd`mP%&VBlhur!N+b@vPJ907IOz4W!YKBwhBj;7Xj z%SRe{Is1=P87ZgmwC`loI{Q~2Cr6*UrWUZ(bSOAC6T=Al;%I(R-FT6n{p$_1-s<8@ zmM#iuPn-o6#H$V?0!|at7P?zN6T!eAU?F0D&WFf4O0*+%3C7MU1uhxNUja_s<}W%q zE)^I8&T+2;dEHxBTaBu)5`dAlrnU-ev1`m)m}P#?5xwFcPDfa%dukhWo^P?l1yAly znDR&R;;{bPhK#A)?w2GOl^<8TTK`+=$rUN%e#PD7CFBu|$7txXKBXI)n4hyfb}kt^ zZ0n_Yo`G^R+0YG9hI#rV{(>ZiYA&}OWka3cPQ3;u>{f5c5^-BfqbI_DMv|_n zzsO5^c$*^n&~%?JQ5Oj=^sU%eM1R{_RJ97Yn-!^oEd}_PzTjC#tE<6Yu25ZY6b@x` zEVO8-NkH1draB9=O?0D<>oHm!6N;t6{1^3Nk=@oc%!ZLKIx&D`OYHqxCh*!Y^n0Qi zKfLEh*Ls)mlYR?wr=XK@8PSiCmsNLPN%I-ldrVA6T%Q1#R_jikriH(GL4RaJhyD{6 z#gtgxaV>p++1DZX$?sOe&or7TTpXXXj(=9MWz@I{t>vX@z=dA8%N^Q>8v=kU9o&4VujJ_ zD&yipl`rUfHk$(-FG=ouTG^bU2RI+bR3hma*u6qzbe}aH2a8k2QO9&VRzLb4Du6n+ z*e0uhqghmUS3ksOi90{TibJ%1^)UE822}$AV_aydmam^j@TY{i@vMaV9oM(4tfSfE zJQhsHZ4GBCD$IVOK+=VOR(5t%Id>feriZNwDSKwLj!$kn#>k|pP!%8SD*izW6o(Fl z%5rr&YEti?@B(J!4unbW|u}<;(0QKT-*T>BCjSbe$l8rlmaRb6FnrVh`#1fFUAfTX(njICF5 z7*5At)tjoA#moKvgz%J+3jp1|ylND1vkv(71gQk3WJk66rk_jmyE*@{r^odcF-7Vk zU?7lnyEts0%zI*8sEOHbT6m=m8ojKOEW_WwLLJ$NZ8mWE6-skY^t2#VlcCG&qS|c& z36vJj$l}bFJ|1g7keCLe4aM#3A%NxD+8R$sU%UlFsx5Ad0KrzOjDX@b5^eSr*H{xO z0fG?(|GTdy4mnFS1Y#?Ny$rAO(TK#KDCSCjx;d!twDe(kF9oRk1s2HHsyTDYXP+o4 zLLu05`g<&~PhS|AY}gM2um^Nt)H(Akpg}#C5TGIQ^x}{E;{MFw^;N9jI(WU+3DR{> zx-ZQO=yA2oQd_>VOt$3A)!@9YHjbdb9Wfv)3WBaH8Da@1b>QI*H;f*-mr`A>ICF&` zM$Oq#stk7x@hgT*L{)1b39a$-+z)7ATx3OR!*1+SN!fUccJZBElSw+1O23mxVdRBLc;I&lxy65Y?1+eArX7?S!6fue!>5=uaL zRgn%&cnn8C$MK5Gy5k4%kHBWY)hk}GiZru9y7Xw!8JCHqyPP3U7rGjG45 zRmTYimH%ak`yr9x@35$(<&V%-dw*f-K~4C*m#vSkP5XYNn6Mgd^mE?^m)C&NIP@`3 zU(udeCn&W7Y{9rqbxy8xoBl(M1r{L-H^cWgtK8m=uaBx&@51){(Ko{t!+1}7oxiVp zVSgCzi(+gU0}YniRhMlL4-x9gWS5OMaVexikHKEWP=9<|(}Bt~xeez}^3!dK1n1 z!;{_1(lhD6!sgH7?)}RVZ;*S0kIaOlQ=0ocb`oTB00Er7uPs0A>~dI#&U|-AB8D&Q z@K=}#q(iObKy{kw1(%zVaU3?{C@}$QrgAK|O>Ic|@<(#t-M?X2PFkY-c`lu3Zg#Vj{T(s%#IJnzmJM2KwS;|2CzpNTNzN7roI zC+$kDWI&&6JFdi;(0+e13L0e0)^!Y+Ex+*_qDNV4QH(c*$<+cN`e&el7)Eq_$Z<_|FD+` zFFGtGF1F9r;i(lDp1O%6HS!wj!YS`#bKNc+-B{#X^;x1n8#=)rgdogJ5=!<=&`t~* zZ{_CF*=9u8PqN^52-&5G(;KYg#o902bb8<1c^$}lVc`dz#<+o_S9=&xk;&1*&jzq3 zOs>acvBf~2ydE!&qL>PL606fJJ@#J9imyD21Xl$@-sYf>SfE?SVrj?;-N88bkpg1f zPpsVWe>f*p#6VL#9SPw0gSx)}kYJ!tK=APQBO(qZAyVcW{T@*uIt{NaX+Th96$)HD z7SIMr8jdRDO&#u`k1k}>7UE7z-yc@Mu-|9$+X>Ojq zYErkJWA0=~n;))rQehtW@L8ahWiLFO2o1yI_ceWESext38cL-El?8kHzPk77lYH<& zc0Ad!vnRpwLPiw-<03j?VCxqF$9_=J9e^YDs-hdeF?QO%HP)-Za8h^cM9J6$9=9=m7ugK_@!7t|R26i3F z35lq!y6_a6);W4`Y%Y9ejAU{RAIHlbEkkkjhaJt)Pit+it9~Vz3%u=~9AdMh?62tz zQM1lQ6XWCF=2(XnpAGlfz_iiGANx%5ua=p!p(UKRzlSA>q-w9z)d6xL$xCe+7{n_~ z10xC)IB!qnq3_0VWrrm{xtpO7S#D9dLZ+@lxTt4VP08K&$%@)stZa3}iv7IDzeM5BAL38Vk6$)6m+ScYe=l z+uIo_)?JK{Zo#wnC2xE>5YSTEbjwx$ND0c)!-WhDEynMG{HpVdw!v0ZI3{+bSErng zIM{8g7HciRkHhKIOwRh*8zrNArhiDm4Z=XKDo)Owsi79WmW&wKR{cR>!Q21$W>R1AhQdtCR@n~J+` z6v;QCfX(U)^A8^`LS8$0AoyjXqU`f21Htm3TJ{Ci3wZRm8)FHc2LB0xwdcN5j> z?yy>cpnvDxqK=K9pWhhHO&!%kw}s{1t`&N`te#@-0o*~>VY^i@O`hO>jasT~FNC?a zMBM*A+HLglqA=@~I9Bg(3l01)%)XSI$%1H;#DCvN=dC$o<6l_YdJ&Ne4;AeSnnlx-nPja(W)tgSCF z6(^kQ$4!u!4_XR>d#d`<1j~6kzv0~7T|f?WjC!79V>yRtIe{cnL4>{UYcetZ_V!i= zp%h_aNqN1x>nj9dN{xz%=R6Kjw(Q364E1kc?kdrC65}47zt!JWTW7%U1>P=gi0yi? zVzpXly$BzAWlvt%s1VF}*8p~<++9(9Tv6Eol}I(^qk2u9O-RSTgxBzM2lZOZp?0-J z6Pqu}7Z(PV{+6Fcr%UFOIXGKJOvF1N6R-7Qt$vdr(T!a7)Iz5qCwQ+AQXXa@sd+v~ zX6>dBubFhYPRpI~ltPa_9W;y{KJZA%e-*w1p-;j$9EH~?KOW5%xb}x2 z1(rYG$X$iVaUfRy>NdHXwY_^dR{avG5!)CLP6_2S2;)32eY@5^JB;ixjpIe>L>2`! zR>R2(nQeL5!wZ0k=DCLh=2D;W)8c<=GeNt$qxm^}$1Yd0K}50N0)5pm2&HfBkAm3N>$O*+n&UODiS+?hMFqo#(Fm6_6e4Jm)L~eL{t!`L>z-iBlz|R)Ui2IhN9% zf(}FxSd4iW!m1UK|5I$P6XK>vz?FggzHX84+pw_|%qk^cwPh2@#+PdR5OpN$C=Oo#OQ)~6 zbe@ZDN{I%(x&vr3KSK56ym#@p7$L>PAdZt6-b-)wJ%Ps!!|G6aT{J=6h7sH4EAb7P z34}+wY{!?eWs}c7HW}kI{8u8&dxZF4b z$wa(~oN)@WWg?QcA5l2p9LU8ysZ`=rM|NSSc_uz?bWjqITg0iXN~>_JvR*CyE@FjK zyPFsJQ)MZJ1uj7-6Th6XBe40tsv~cCU35N!-MV>9qHqyNtaGfvp5;IDE$C92)Xss9 zY24FNrT(C7_6NPs(MFuSCsT0Pmo!|!7G~TfsVeK1pkxr{rcHqMcNXwJSr0y?dw22C zD6Zw7gYr7eCdg@tDHE13l(xOn@1C^atDgwzOY|(Z4ixp-KOS0GY^0FPC6No)ooIkp z0mkSle`gU#3#d7&(3VKR+tuAau^C)rF`^>b$?=$TI6Jm$84nEnbF{4#x<1}6rrX!c zCvq!JfHXs158y^pX2e(C@&nlJweI`m(U zQW~N|CT|t+QtX>a+onvEw;zP!CVLs_1Ov&X=V@_o8}E$_5`SMmJ+_7+UTm~4+0|C; zJYDU63RV|b6N7{u;mE2o9D)DprYW~Bm1riF9@7l;UwVmA&H|gvn>&wfa@G7laCXi9 z8P~7|8?F6<@Lzwh@Nz>@XDBHB*rC~lr$!|`Qy|`19jdTIVx6vTu3$O)oK$Vl8A-`b zG)@>>e#!G@_0lZQ;cKAQjnt7OU8LOo@zQ-!vZrmM%L2(6TkrSH=XXm67oPzj2eqsd zd5MfQ=H6_|3`%2oI$R)4C_b5e@2|abIdFEN$(K}F&jZ6_DpW!3c|@*$-4%Okp)bl2 z+H|n5%PSHq4(IcQfmI+TIAZQqme;ncCgSpw4bp38io`1gceP{)f6w1L`0m5pi{j(M zm=4pp^Dx_MZ`G<=PK-3(fu!@>Y)xN8l}9ZTQSa7#{im~qJZlbZHi9pP>~190I78=m>j4r08v_MD$d(KSb@~WSEq%3vF&ta62H`k4Y!<*ht3N*O)CXJ8vWH!Rjpz1 zX>y1tTuL?|xgQM~LXn>sld!1D&UM^!T#*z#ob?2jTv30sEHXT*2!< z?OL`&J~I-a?&>lw{PiGB0`ua?xg#ie=V?SJs6pXD&!W~fVctLhkYxP$NY8b`xIiek zU0ti2i^*~*ARzaf=r6H2iACb#3JYk9=tlG!{gf9=@y>0~JvF~ue?M=B*{3_tnF?_Y za(>R`8&$Y^^hYR0_uXg?^Cj`6D2O@aDEcB8-(T)8wsKZl9Ck@A6LXW7Lt#7vzSLsB z)tT{TwtMm;^|It+$_1$*K+j%y;ELyfXyY}*)J zwK2Sg*$A+l#p8x&WuqzDRC>aL4)v1VeauzIwgx9ZD5^PGtHv7dVBxk)ohq59LXBNQ z&^#>Z1wL2op^vZ}+4x6`GTCijwlMdbMKSRzqgUMVT7) zCZmgcx#-@?lz6qK!zWi8`#WH}A4 zNx%5?00RL1hCp}d8U{Wtjfmh5QB6)@ImU0kkGpEW4aj6&oN#yrzJu)hecMN;r{UTg zt$c_Jk(`PeUmNu}8p9a0V$@gTQ4(58d`++XG|WUL(zKmCeV4(nW;E%>HS|+G5mG}Y zQp`~FGjbRZh(hdS3&quf_TvEn>dCIHtsS6mUQa+eNtz)N&_{#c8#Z`ZU6R$&(fO<0 zE~d7%jq?`m#S@eBa6Xk+s;Cn&U*sEaG5W3^kU1O(hd+HEcy^Ef7i)H8x zGAEYv-XkL(UHsyw$7S}Igu za=sVw`Fcw)0w&Rh5MLp%(Xv%lt9V96#%`LdIUEkWai)e`Q$v$^fSi|!N}lXJl*2V7 zrD&yaKD19b6d+yd1X}G}5b573Yfg5TpYWAGYjP40@q1hs-oW}@!mgN3SIGZGTf&5- zM}xN$4LK(#r^GO8toUYt9T#fWrmNRO{5|yS04}_$g!`Lwk`An=1SHM6LVpyOZ)q(2 zrlg>t5O|)AHMej-g|uM~4$!HwbiYXdD7Qi?XITisp>5>_8V6a;i!*$<9?qP6v^#QU zI$L<06q8O6A3mbei4fHGttmJcRtapf;nZEDg444@qnIQTMos&g3tNAPm7+7uSi2ui zWtIM#!I|IYoO1ozx|pxgwT`;=8qEex51ao*@SByAk(QC_jjrvA;c{HqHK<@?7cwDZ zz~2*6dlMo-T{f#Egkk2`aGp=_bf@VpvF2iZs_pH#+Hl*VUu&|dr&a$G1|3Ms?9aR! z{{>cGU~v(n32g;C1DR8Q1jsq*iu$%HQiikv@g@cDSzGH7JxS8Hj3Ev03c(S4LLcuvr2w$;;A z;}JEbwa2vgkUm??Y0N%*v^~7KysBv)%vp>*9F9HB0=N|Q>$-K&x(sTr*=tS`{rmQ> zq`XZ+Gz5i^JL$P!;I-d+<#F6g>z^5flrSpraU%c=86^I7$Xw`g{pta2FQt8Ukkgc9 z{USgc+8?-$@%KAhIg01*a6k<==D|57x3WewB%+pi;JVAI`N5pQe+C4`?2_AdJsqqp zmC`|LrC^jMW%Ia!Ss}x4(SlhlNCEmoePJnlM9g8=+P%fB;aq}NJ_rSN2P~6bWG@I0 z9{HaD?*$P0sFX!0cl>k_RRwitao0LA-g0tf>ay{+(U=V!0GMr1yz;57>wRSv} zN@aX|bDmam+E5_xx1jOu+_{tK>1jftP%sz_wy0`1aGt7O2y6#7PaCIeZ*V;JVDxzS zh447zCjY`VCGQN$A1HK^6xXogdvf#|-@VzBK1*M4T>;1koNIbgROL(6f8Q~GoGmuQ zxv3VeOmwEUWLn}4HZTOd4D1q-XMpELWFV8tjHlD-OhZEhzV~s}4Rxs&KJ6$_Ir-){ zziCu87z_quK$og+#O)O>1U3V`qbA+P()(sbh_Ob)2*r-MC4qrQLGb@)oHP9 zV}VR`Uqd{+w_(b>+z>ZI;S}+JLq_IX!>c4-0|}_m=mh9WhuJ(Gvs>bgcGGk$)#?Nj zAvL3_ItU!{Ec}bWerxSOC=?n|)p#nE%8ZVV;;qxK3tDn2@vjU8noV}>*kRh++f62u z35G(Un259it5vmEL^c9v0lh%Cs+3U{HfEtMaI|{K`_Gxo}@!9~WG30TUAwG&eUJV@xoWN@W{Fi>kJJ4WmO< zyMRvbe;d%`ePTcq2&!rrZ!1a>F-7_VSXH&24jB6x9`fZcf7z^BwTet8V`8zG z$z(ENAgroUASxo+ir)k@scNZpDv_NVf7%0+Xsb z2_!@$0i=S#U@9Ju+h8zgj~zRPH;}Cxno-aA3?~@XOGO+ea7m;2`(+*rQH4be(M9s WNJ6Qp=RT(Z0000E(Ct14JGcjTcS3L{IKe%*LxKi(cLD_G!QI`1ySqbhcXxex@2&d}?uVKA zFjae`db+w-ueHMz`g%3=M*5t2-IdNP+&@HMKT68~MxD zwV8sZR4&_vRqx7wtVmX?&DeUG+6&3dZ~9tV;r;y*zsrk+y}Sg5MEicoLvoO(%EB!#{ zv{??!$srH)7ung}k8n7E1b-cz7{OeyUSIoIC6bnfB}C)iV0&H;aI9;v8mKGzvAEVu z#8h5hR8rDi5J}MI&=>u~XtpYbwG|ehi!=PQn*i};TlO*c%LT>7W=Lk|R`x|h`M z&R~t1br+nz;5zz+Y8s3683ZGyIj~0hX@5fF$aY()>PEL<#woK<%@_g6Ef{_;cx{0l z2aPjb3P2qhzS z8!qw~hya%COy6yDK@SovNH=7U&A@5c0Xd0`*gB>|r1g(K)!BxynXE3mxIEwR zCPh*78Ha((`>lW9`WKK5fB4_8TRAX~voj~y7n0d;x@=pFGcMS=>~vIT++&Oo{gc5- zPNK?zKl}xsiMv~gbv$c^9N}w2XLo_-=wd+eJL1o}F!euJP24J8IPX7>)voN_(!H7~ zr;|km1I{dbeylT0{ha!Hq<87lcn+4Mv6HDnXEo|)BF>%?I0)NHfRu^t-1USd8?RX| ze4)hsucC{MsX6M`_@SttZO>?ZhSglvntDy=(PAm&!10XxvfQs6XZKLJ9{A08&x6DTCfKpH+)21{}bud^-J@1Zt!NeN68Xah@aATb!z9c4K>$&r2S z>d2ZzM)_w7<0Y%E-A!ajNXX-+mL{pJnnVo4PdEnqPOAYB)*$qGF)ci4xvNuJ=Q5LR zV*Q!ocJSL5LV~0;)C`@fCREJy>#Rg})R*0ti7ps7xl0#cwh@*IclA(z?n!EBmE^_y z)xowxIaWYo*xZP}t$E)UDyyKNpR_`#u7JMdkwB$`M4+*V zu3nqQS)N}eC>A&E7g-DPOevIMElfn>YxPO-#M>gJbr2{C778BN{aSm~?(h;uiq`R;$0m@tts*)K*YodhE2%|z8=+d%I?Y`OZ7a{qNn8y+*S1bj z#TdxYKwi7gV3G1Yvbg|SI@{K+nyj^2R>xMQ3xnhBlY zgw&LumX^0LEv*u-Y*4SrfXEAl8Hv)AU+B(yEMM+z`)O4A8kR4EUOd>$+cxBJzx1#3l=BcNVya_Y+oz3Qt?mFfY zvV7Y-`%*2ImN-@PO9GVTuk+AxZ96@&_^x4bL>j^DM@MXlNp~C%U z`RM59!gT&OivLn-euIS3JAPfp3|wiOwFjP_5(W!Cc)sZ3v3!=c7bq`Ccjc1m@nutI z?VSj>@j0C(@^QZua_(&^WIxF;e{jQ`jQ* zui%`{29ygqzOIEvfIxfqJ(bsYJ_{Pkv|d846APQ8#et2A3?dfH+@-h!Vi4O6mS-({0MX{}}t;w1tKK+)z_SsVyh)u}+S6gv}=At2VT5&c)73RJ1_V?FWLZfvuR&aHeoT8r zUQq$(>#ybUDI!Pk#pGfJ$0=PxE70wZ6c0zI!VKvA>-leg(n+2hoYAE-M}#o&x*b`- zNy-5bgFeBkuzZ8L+)flinBPpX2BaJj~OM5t<8l*;TLV3jqA%OZ)ffo@80n3HSmkl^-Z!E z_`h6J#J{H|Kl0MRAZ1%9+lNv4Nq5rTK*BnsaN(Q>akKbILhXM9oD>VQmeYp6!g@Ts zrsj6IUTFa~H5F;(bTpvOpGu`nv_4~{0!~AGWrKX;b)*I!f1Ywxku$%|uX{IOd;WrY z_;>8v&p9M5z%2dZcmvmUUpFn2pQ9jt!d{X6Xb_^|o304oFrf%P-AN3A9;frtTF~M> zrU+SehH#999&%63oZLLP3;>h6_dvQ^K})yBxrr_ zPVDBpQuivHA|1G}I_`L`9I;*sFkFTlMw0XSAvq2dWua~#j}#Y}UKw@R@ZW9TZf5fT z%8mQ^N2PMSq@+aW_VyNi`*I|6f6iFpt0Z>|=31aeNQ@s$nXTXLf#gP|4_#RId7{`R zbfbdFXi49Dcr~FYb}{}$806ax*OsuPm~T4K7tr!wIAA*%I3@envx`M{6IA2j#>^pe z<>6@g*uVey{eGMhu1>|-SH+eo&C_i=7zO$5IsATuQzF8QbNVsK3+|T}0%uUp2BJo% z`xd5wWFa&Z`nQrmlG12~1v-HUB-LH~$WsC=p)b`2WVcE$i%KRmNY*fccdUv>A$O6* z289ZV#LUVO@z!x(4AixdoIS1evcDm9l|NU`RHMlX0n%_?oe-cB~HlwpA1&%)udM# zMV$LI2DJVH;}+_C2~lVBrz{>)Yb=Dpm{;;Vb&@XO?X2Si9%88FrRRWjKDlLHc8w^- z-~ea?txv%_Kb|64(s0_(>j%b+V2q=~A)K9;88=Y=O$ zh|xgYZdZ%`eQ(CW}AYCIodh{o3ZYoG*hva!GT*8Ry;jXMrq{Z7%XRcdG=3_@Z&X`{|m1 zTu8ErLM*vW;Dq`wd6rlpe+|T{-=d0wo^opDRW%2{Sfsi)E~-Uom8M{!2!KN8jr?H_ zY0ZXrbs=I5SF>8Co5MjLI0!&j*vFXSauQDc0%bMsNas~U=WlgI8{P)%<9L`puaNn2 z_OY4PkIj$)d0CBTTCS3S;`i@|HWn74_zK>ZpiJH?0*HwpoYY~BAk<5kX%(?1eVD&$ z@Y>N+_=U7a!T6X;uwObiyj4H0p%?-h-D}z&JCV^j6RvT9t%>=cI7i@wrM zp(VzFc^unMpb*u+=rEJEd_-CDHeMU(ZA9L~``=dr*Yj(4wKGC9obKJW`y(ApVStkt z68mqTUyDoiI^)qLQMrLof`~F1-_xmF~1?1S}7B_P|nNVU&qi_5?+q- z)+Rqs>L?eho8ZnYc2hr0BX3OjFslh%-N(6n%m3*p=?Bdm4SKyVgo<~P33FO9LPG?a zoIINkIj%=NyV!e;6SVuOBe^9%Q}h@qJfO2}&Zys2nEla6LK<}~%*dkG5f{2?B8t^MiYnV>6E2jy*3 zf{tns{*Ua_)H8a~H%|;ed~Mb8QyR&y^)sn*>{pw}1>2`t-tCMYIuu0>4V>cAQUXoD zQQCL&G3aUg{hBx!Tb)$4g&9d0$u~6fW?Ke8n6p)UFVpijF4OsC*seoNV#V3OUK)?lGs33NsQWsf9&EKjmhA3S^MI}J* zTQ$8}l2kF=S(l1v}+`i)!nDb~*XDcrhq&yq9!dtf93T`*4pVjxUcPKgiz1%bX z{#xE6hEQ$yejCD7*kPD&1*2HBe5HM3>!A2{FGn@3nnI z*8-~2daJ%4J@8TWpv|x>PM3GhW6`SZVuDIKJTfRnpWH zDw$&nB;1#?q3dO-mfTRbiJ|42v3jrmQHb|zn6PQ_&WlIO@HUpPh0Tyemcp<)6`k-> zd9Q2e;cdtb7GT%ov>8AHy{^@^SRo=^D!51oh}|4w7jAq+4B{T45y)0w+!iDA%8vEp z&*WtskH;5SLWRKbdm#7M=Qa}1 z_)b2`p>NI}$zw5z1s2jszO+$zrygGg-B!IlCB_5f$Ft)^;ac4R{Xg%Me#Oa_bRYoh zFVC{qr)m?$Y%6PRQd_lYos7l8=(3gEYCiluKvf^Bel_+yOXm4wn|SXGMwr#I9L-3M z-PE)R%jNk!Kh$BmNLuDJjXG!7%VF)6Uf$JY8hs(C9NupuQN^S}mD;*<6?EarSuAY$ z`Uk#ndx{5fig?(H7)=fL?Z|DTwwx_xDSb`h0_DHyjq?Bg5MM@M3@kF&A5N+7RTK=? ziw2zyk2voWe7%*%{Z135P#rMLcF^(P-_rhW_<4LG>3G!m{dv310DZ1?tyfufDL^fG zL(o3+`<^I{fS+?t6VeTsoTy_EO7PuS^S*7yAqv&a**RFurp0-xYx-YYiL3gU<&aB; z-jmzjLHqG|Lz}1*{2>NeTcae-bRvRX^Y4v^#;Sd-7Ax4rlYl%2vbn!!Ho>$M?CZJ5 zI0BB&50NZy;<*%`lE(82_{0}seBole)^3CprtXS(cdAxt(xVWph! z-SxJ~Ptg+RzvORY)-~XW*#4SwEg2=>^eMU{4@s=Sg1?7ltZg4(@_8hDpwW(n62@L{ zLOy6rrYh^Tf?O)wXh+89s}I)9@4V(1$+_ zKCfY_lDfwsY$7-!W0r#Xu|SOKe4zQ?a2oyP02;_AA2ffix2h(V2@jUP&$!7TLbnj& zfjwCqzEML@@u;aywDpsghm$Efc0MyDs&n2RGJyLda$={fn}!f?ia{z0RC!I#kFf;2 zyF`wfE0{fCfc_jg%wt)+dzd^yqaphCA(Jo3t7{eI&-2RI#}H$_WGw{8uTD6z}iC0O-b4L!ZThXT)omkgOc}CD`amd zoLX7U$i+}Pp~{NGH)RJ!20$CY>0?W0^{JDZ#fEq={zoKsj21qeJaY4Syjh&d=E}3t zX4L!QnBw2SHHZPf4*+35r9*Q;!^gd9a)>Nay}yeG;uDm%=n@)If_9B z-@Vm|vL7rv+I&739^gMyB=l_(dR)t_2)Rw-YF^+GZx+Q`cEa0u<6)UR%PTKA*L%m9 zXNrh}@~yy7CS^SOUH@Gry}0E7A#jLWSiMNND3Aczne+r5jtUSbt@HuC1jr51EYH7I zzuO%&rfrp-RVE6WL!YC7O%Y$V+%B-4%}>Q_3==5W^K~kar2`#%D#D-)p-R9``Cqv| zL2`%kkb3LKSbb`W_W6CTUS1~eUP8f1j^;e_8T&xhb6~G~;F)XNKAS3AFr9Q%gM(b- zh9Ch|r_C>bhP+GW^>Lr3s%V_+`!duN&u()(T}Ov5);8;FsiSY5H85AiHRmd3Tal|8 z8ue$;$DR@G)4R@`e*qKpbqFG8xhIS7xr_<=H1^Pdp6oLbY{IP{>qm(Lql#T~;T`TJ zzy^tF_eU}Z_Htvioy35wn8~3GfSsPtC|#14V;w#%J$3*O`2zGK8|O{|qH~y%vYV`ILl$K})jd;VzEKi^nYO_?iVoh#*DoZLy5|&E1N_?fWmjF)(K`HknMp-X z1B?b}1x(BHI0&ST-DZ0 z!3vw^6Cfjx?|_$psxwc_G_4exnfHXJ>&W8C_BfH-0eG$=aA$NBD0N8zkP0e#c8}C5 z?Pw*NBaNZXAf=Mbm(CQ#TfT2kTca)VvanJ9Z}?fHH%uUQheqt~)v=xeW;mv_;!s z?Y@IZ%PD)+rfPBGmb1NPN+63U+oZ3jAS;#bJS@E55J~AX0%*sI@8Xn1gvz}q* zlJt$t=2{Inp`!m|EvwWy*t+-QyRaeUe^Oc(m!etkd$XgkooO{7XbYyQ&wb8%o(PB} z3Lzz^sBY>Nyo_d&l5l==1XhkPy*X9hcZA%h+%rVm^md{h+p<3x@?webE5VTj`{F67 zriFaQvM}A#C2&=9BxSisljc+!G}U+$OR5Wg0g@sVsEW-?L2ci69NUD+*%-9hd6ltp z&LlZi+6kW0*MZ=@{4=eSF+xX|sJ6zc3uv!8y1z$1TjYYEakbO5HkFN7CVlt7r^JwN zbC8DTi9ZZu&3BJG^pQmBg}S;$>*f+r2J+H?6A8@>X1r}WaM3ce6O~x}G(Q95d)nUM zE%#hoe$?(7=3v2<4(80~=h#bF)>^R`-PtX6s_qktBi! zLPIIsES4w*qm1Eem2Cxd>e~7VwekObUY4K6Oz`+3Q8>@ez)ZkSpiGuV7aGP?-{Mrg z(#fRcoNZsIYll{ZUV3ny`GZ9Y1z7D_kdNHE?_jtilW$f?J%z{kUM;C073pT$0&Q@; zpEr-4(-hy>`gYJie+Tc?~MiZp61(xvwvBN_xnq5A}#FZ&=K6ioKipy=*$Oo{slFT zplb*A?6>gq?k@vKZoiOh2xIfVnr zx;s?ubJj%<{C`}4#*3NJ7Lkr-(NR4tNU3e$Z7ELd!ksfrH+}YNo!JCJU`*n<>bQIv zvYkg_FUb2E;ep{54Z?77@C0*RQy|d%g(~LbMKQ7ZG}F4Ns^ouFjZW0fx{p_dY&M&W zW1lhrJAZdGbfEAcD&Jc>aw2bvBJ}-{#Z=E?vqj%mWeu#PkBZSKLE~cucL&avVt>Ew z1Syav+#To+*^wnL@XtB0tpt)y`pB)4){Qy^*wJHmuT?2f^t={fIjx%rk{dzl@bnb^ zN!*SN%s$tuvFUIl#Az*7T1u}F<&=JBrs_#Iq&d(3gOwclVS?0}4HB)CPCyYS0VT*i zW$`7!* zIiI@{1|CH8xqTIlYvxf{9%Nu!2Cwd=gEQarie?*KxGk~>-vV>EOG++pI&yR40<=o>j zKBfoC;ZcWPzNPUaVxxAtcjCnFimI19|M^=yGBG3Oacc;lY3bj&MdLocaX#quhB;D~ zWp1#krC-y#<+J)x1R)(>!2Zlje+JNIJ>AH%;%9ldn=XDC@5zsPr+)%r7IBB$^3;QvYN^3Gt6zt)#m-ct-Y9H4rdX@&>!wO*PypRLYO<~Br`4};@#?!7w4iUtuiuG+HFMX&fJ zREv@`BcNOXAGO;pW;d%V%RZzv>jn3@PnT}keM|80FlmU=PX#!Tp60%Ep+T7Nzz;D{ z)VnB5L^KaFP`uHt5jAIfFU*04NX)3HwD9(fVe4gC(T1&HL-?$^86DozW)X}&iqYeU zY?U6M18L-(ti`vU>|M^`#9nb&8mcuSjsKL+lkLXzxdZOVv|R%Wx)q95nkXMHA-dMI=etzv~f=WJ`v_QWLyjZ3OHZg+U{fv zJ;pnzZ}aVJW+=DoqtNstV&rKQ9^59zmc6SC-Gre~y&i!@+nwbRUHZDKUi+Jx(Ua0~ zX;VBu73RmVfjD#R+0Wro4AzE*iz`3>&S0iu;{qo znjP{K19rxD$(il`9oFQGhBb8>!1*r26x3r3E-%7MV4gq6&F-oeGv^GLhMj++#hfKe4xr?=1X#5;^n zbLtqP%l6xL*6We$&}%y5(x?P*A`>K)`$fkEP;@F}Xy|_Gb6CY>$LoQ{o$+6cyE8Zv z%`DJX1#Kk2YIb3WZVMWRXya+iKIXJzFckr}w!XuBs(H6(ENx$JpOdM!xPjsm%EoAQ*rhnZIsdbZc4m>2|T1X(OHJXM}J_uJ4J9JGrF!xrJIxSd|<$LH|6-;Elh_!%hIQ@SwR@zsJt>Di5 znJ(rEc@lt~QcEuTDNjVzOXqwoO+L`}=O;#6Xb4_%T|V@4B}uSX15#J$9{)p6-MYQ) zS^Ng!)6%$tlNq-lNeAXis4(K+>{O)0#G@X}-ve8pt_1Mg zdCrgbv`aI~%gP)%*x8Y20abc2O`*Ci)ej&OeOZ(+C9c3{R1A_kirj8hYn7AA*j%KV zrB8_JJlk}mnuYa)W+n+8>Aya-%b-nESG)e_1n$?@u;kWkEOF45G+<81Pt;m6%z_|A z&C|;r2mzK|`4Xeof@x5Hbmkn*L7u+aIW>22WU#@yc$D?=T&*D0o(qk6nx9@5l{p&v zf_zI#=v}PQ%u#6{NA3~moH3H z{AZekiup;M1_-)7lSKC1A(M_V@LsF@r4MlN4&5j^k;DiQT35@dloE^HloH{f><4&4z!}u0?9|Wqfc8~yB zW{L}9T;RW4<>pCIGBy*_{1zV|8>d_HiPWDc8p?8Phc}}fvMwc#C=z}FD2-Nrxq~;5 zLOd&(m7gEK1*6!(+aE+Er2F)X&u84PUS#D5H07J{KocHw6_v1Bg5Q%nSa?|Ssa8#G zSHjC{Hu>`=_uB#0`%vgJ!`p2r1$tq0a#az<5`krBDxdfnTB;6;^BQ~ArD$5@*8={& zaa~$mTBs(Q&BTzXu1DL`kW-j+|7R5T&4G^m$yXl5<+GmL5T9Uuy&L-EVrjz|`njbu zyM?q61xS1QRl>)e=Xz&>3`##B`N?qO2Z|)7GaLXiC0kk{Et=fQubLv+d^E}bUq_tH zZH$BC@nU-DAjKNQ=4oK6>7t&V9ozA1V;$p{5tp`#Q0bqahL=4b1{RKfod#8QVcWxp zB}^Oss^Ukr>sr~)J+IJ>l>@3;CFObf*=+BO93_w}!Zq@5QrbE~_mrfe>NS8}DEJXZ zHO`smf&2ac@bOyT(3my(ksJA)DI4~K3^YCZ`C{eR@_HgHE!R7HXgrZLI^)7!LVLE5 zyc>tiCipm?&XR1^)zl7`$U%(jWC>roQS~1X{LxW0g+RheSq8KX-jmuXq#KJ#w8jda zX4!4RX+lTgMpnk3iQjt`HY4#vf2z+H3k>0cm!K(&zXpe0dsm@Z4yPK5{ce}}0LL;J ziqeHDscRg^;MCOAtU5u8y1J)Y&5m@6y44+mKI5ej@#|+Iz{|8Rk36PXY|6C0D^NS> zN5`x_?FeP)##=k9&7%kMxQByK-A+hgp{W9|Y)-)@590 zi8IRgvCb(QANS`h3D(kz3eH4k-Qks)epxn>jvFVjGNY^`oqU(K(;C z@Dr}I%*UQi;Gz+HnkurJn^RbHo7rQ>u?oi|tl+cU?n(IQuMVhe{jaZdpQLz2M>^~2 zi){?s78lfQ4vpc;!=785s^X|cQoa5ZF`)SrTEZ$aO)~}C=|R@DR3kI_ooG|8{j<)u zP-}ZI?*3#H{=-1pFhpSxTmN_Xj5OJX&yI>t+Z&C|n(fBU%9Tyi<$_e@PndQl>a;`+ z=O;0e`?_?ZG`X<#$eEx`n6l7rj-)vFiT3PbqtU!A;@ONjsHLY?do(8mTf@bcecb0_ zaPsPw0HOfo94g8z14YHfpA#9sZ*^C-eqHdlZL>sX!Hq!MrTDkmUe^sq>DN#o`mg9jTRT5DF4cGi&5z72W@!$q#}sV6hOWuZf? zKFM^Jh<;qn1odBiO^Hn+(M`6XAI{55{!YCOn#z4DpgAC=I8A4G1|Iu06D%sJmSd2%J0E+3(SqbD23tPA+g%lT9mBiM461 z6iCoBn0X}Wstt`Sv`Q*GNu`S$!cbzYZ3vjZU;JR-cj;!WU+aURMIAh!*L>Z3I>2)w z5pTix;Ohp$5d!g^1~k2gPbwNr-SO!9qQ1@ZY)^uGC|he{i+-%5=Pc09(9Ivliq4JB z-}eQT5ahgvwe-v1xgz^qZPN?3i}d9!143O%6dv;Kxy;Mf zl0OwcAXNGf*Y>{*z5QH2Tm>DTOcK_kvNCAku+rKvc|F%F^pulGpwC$K&4WfQ;fFz7 zh(D1K{K=oG&Ph)?5h*QN>8+}JDK{T8PfmQ)S5sX?wTj{GhyyiIAe)=vS7 zfkj0e2|XR^_cud8&0)ZJd%eN%IzY}Yi6GR9OG)!|K(K=(g2i?XTBF!+N&~qk+_q9= zA4lW>27eTgTrUfUVuB|Nt5VmGY zOD0rNIh>n6MzL^MaG9^LIN6RV-gnwo z@smM>DzD(-$V}-z@(Fb5;KiM4cH!))(^f;mW+S9G?}Z;0_rWe8U)5t2M3_0Z#r;NO z=p>p~&ntoL>bD9BtCWR6betr^lXr#z9HB&jG|Co>Ao*zn+RD2Leyp+%9<1P4_Uu5x zs{!-*FdAF)`rnv;&+#LESr!%LkcqZ^lZ+EmrY^OxBoIg@AhAiUj6()sctH3_5BmGo zy*{1G>ao;_dnB+~e~^W|V0}Cf1?HpQUx}3e9xE<<4{7#;0fM52M@GCNBO}w7-wAIK zonMQ&vWt5HvrVHB#2B)cpQaK88(SGwXa}Lh*6;5W*GS17mmmH^+L;P6Pzgc24V7br z8NM=c(B~~8j}Vp+`gJxyOd_4}NlucIB^*j4vRkwf2wcGsPOZZd|A`gxA;s3s?K4{d87S-^bK@GQK`a?AMEpQ-nHDe!>#a(SBofC zKH1nQh!;_}1}`j<2=KzeXYp_}S(nwPnl6$QE4$2M4U&rXIx&g?>bfl=XxswZ*XQNf zKNFRT5dR54;zhc)EY$aQ124bsjKlqgm8+_$I*Yzmu?Y!3GPv0s%44%>c=eA)hnq!o6EK7A%LIN~jL84~zS+H9 zsRJ)`-4#e>WvA>lIH!5rcp1u>+HEYl{!Hz@k-5`%6`_%Pk;Sk2;>tb0(hPrkE3%_- zX*lXK5+w4C6F@)rc2R>ECqWV@18qrIsNd_ssb{v`dmXkt@ot!#c&FVZmRvc;;xsy@ zu=KXXOpx>@!N0ntXC%>`I3k{IBh+HrvWDE4tnjLo0)dy-9@0+ZXm*lzZybo#4XxM} zYZ8HSBVWVxMOSmajXtltL+47iR2f1o0Z_~!3u$;@C7I2h_kAC`lKki4Qfjs-&fMhL zo{tBPX2bUq(H)G_av7|MV@--=Zb83r!J&hK1A9NXvR;;N+|p|FH~ukXaxoT8OvP&1 zwA^?Lsw2W-UVH&;Jx=B{jw(GJ^m|4m_pXjtXpU^&E-AR~X7K&qw%qEv9q9iuZP5XS z5^5+%LQa9jz>7Ud|EpE6jSg)cmH(~JvVS7ivXZMEG4<-_PpM}~dZb`qpLJZ8$yM#3 zG1kpyB|B6X_$|(Gr(_VKrFR>A`FR5(m&MYk(PtDb2YejAfRm6pE*mUoIFP)VpS>#u zY&)%OKaY?nJ{HlLie6gwes=0@4Eu>BSEOZ*o<$HJLLl z4)Tl2|{D26A+vfeOpW$1$4h%LeVHXv8FJc zSoEFq^J4@>ap&ajgdYv5-P^hQ$F#hRs6?4?K~u5|$3eW|C}W}qrfBJwU%!^yV}DHY zldOHV`K1q5aCN{W^XTrd6OUYCx7xZI67>+Isy3jMXad0}O zJzg_={Kwg$$q6EDUv85ppXSGAk>}r}Bbw7bv~<4ldecKq?Hl1f+Z&$;aw$f1vM*=y z$Xl^cAMD}EU`R&pB6jAoE9?&eGGeSS)r^P#qW6tCH61H@>XsGbT=>uE-Z_@bQSgi@ z(_(#ux?#u$WOT^wwwkd{avYjbmdmQ(Kd9lUuz%U&JNJvmYfLzy z4u@Gsmdt;K>6Br3!mJ7wTPfV-)6C?1&k+e8JaGssD{3Yf)4`^R-X}ZTmyOpr{aF3nRHlS@7Tu||V48sB1LLJn z@PYU9Bi`J^I2$$APpWgd>=Fv~4IdDcIrez>`G|MWr&6`q^)u;^VW_7m@ye~C+#`>P zSNIC{ead1MpM&E)27SiYM|(DEhG)Qbw{4oncL*@Kw?*Sj#j5>&3cE1 zrdTaV)x}i2>|0vlt(Pcqr|z=3;y*I^FrS{Oz25ZfYISbaxSDAKbtB{JI6#}WHSS0P zMMdS!&K07|mF675v43%%Yl^BEfH4*Y2ICFybXi!zStE6=YazZpaxOV0*#``ch-NB( ztJbD931*2~v%MshXz4e28|*L&)%z{~QENi4c_bZID4B?QA!TkdBjZdwJ<P5(Xw6#);k*G5jz)zr+ZvyeDKJT476*i+S&vPoFB_v@vQq9B=6J*+F*N#BE+WV? zK@Q8tqo z)92+10m=3zi-Uy{W49*%OW@B)<=I0KV?$uQ!}0UlKih!O_l4)IdbE3%n?u*bTFKFO zw}*cXjWMdE%0ANwzC0*^)>=vmzSmGJRXncwM%L8K&0~^4M5wf~a8Z@O)DrQfi+Gv| z>K{YdL$ux^-rNnjQ-EVicO7hHfj#EQW14|MOY21b6K+VAf`!UZH5|q-h%>uD0jyPx zQ#Oklk24rv|5@CCA|fkkkKzQ`@T4EC^ZcMx^yv6oD(>t?%yh{gD61oQ+Wr$Ar+aYl z-&z$&L3O|~ZehFMVZAqHbIi^qcBEE;o#9mtA2DTrQ~>WbRgkJ*OGRbougOqs-D>84 z0I(W|rHpfRjX1eR%xS~@3hRBix!x1yj2WDWqE6Php9qd&Qvo)jJl-h|6Nd*~1Cu};S5PL|{T6wcC>$ubB1|iXn)@US;cMpYxM0)6 z9NnU=Xt82QH?ztPa?IPQqDpsOtte|Q0!LDD7xt9lk5BEmOTXPXMlO4^8N{JjTow<$ z?IwAu&$26}RMvhdbN3IBC-lr)1YMT@<=nwbuQHX-$bQA|nWj1t{Vo#rc9SrX&2HOT zhVd_e|LY<6tJ)uQ!-03oVKlX$iQ&X9Ua<&R6hg+Tw40JROc*^Eu>9OdwNuM zSo*5eI|iHc@V8`%4STS@muN?TA55$;_0nrlY|k3e{a#3K_gnc&r{SUUg;J7%vZW*Ge z%or1R2kAY3ZadZeD*hV56>K|W69?jOzE<*kYLzeYJ*WgqCxeKF-=z7vy_d55f{@72 zjXdJ-4DonqFUuDPE;^$1O_+7={N=t>H~Wwvg`H)l!5d*IXSKGjtS&BUN;%}MI`$)< zOpA5|6hwU}^;(XgpQ_lFJWDqCXFcLx0-#}6>Iw5a*J4;=#v z>h`Dkp?rMynXi)+79L-{HAvA&=Oop9cqCrHWpu6f(Mi3ofrF%XJ;zRmJ{=b#qqrVO zS^-NM43pagr*1TVG^7|Sa(7}4h)r_L&m;b|qz)IE<_wl@w>ed&;Jj~RSZL)fo}$#% z{i$5ynNT=EV*~r*Mxzyfbu%KVR_g2dJ;3bqI|)bjE2&X$ zt0dinnX{h#6BbtBzvX4#lQYyPH}5AX;09^>-n7e8Pfw7SH~F)*7*(dnrI6wdLBu#A z#D3Ox0(gA(vLPDttKTzyf1nmzt>a~3iFR>xtW(p_2uWhrl_^(XBOhU-0>!)Mw|-S+ zRUr*GL&2>l>2SH@M;anvP%fw~cVv@Hc;$l=JwG*Yv-+}F^3V}m>=S?yV3S2{ogfta?TD5$eM!ck|VoEh0$J*DUvU`9GB$3|vwG04x2!{{_fgNvB_+p>Tf}284@6 z>818ApI_gENrln3tGxT`Fc%e~->FEn8=@h}F?!sZ0cIZbKU{=t@K$mVy1uehISG_{l z&itPV29Dz+YDkR9)lk{yYLp|AqoIXZJu1gco^t1?m{6l_ZdznK*lw)%TmR!(whGNoVx& zVfNObzXKJc#DRUXM^s%<&a;0o;mYJ=apzJWMVHCIp_F@}Vs%;J%>`qb*xGm-JU}UBGbwZORh<+dE=lN4vOF=7^ zaIN4mjMQeUMq_hi4wB~AzK{8jb&QL%Drd*+;q~=4u(WjhPfsdUunu6uQw|a3qq;#> z1`?8as4U4tq3RC#JM7IRfjw{Aenl1Hx5tgIj%xLJRXC4!ucGj3 zO~9o!*Hq3LgE`4=0aBsJ?ok%^D??^SReB|Ng@z@Q4MIAp-5eI^uw19hjY^@Qr#FA> z%e>E&_Pol!YaVn=O6+W#mkja3Gq8^MXu?`oX^eZUnbqB3@wLsHD5daYQ5~lr30Fbwg@46+ z1smS%G19X=juQa&bW>j|GsxD-hq^?Ln&gAhx!-E?8*kymPmYr~wJ$jA(tpFH8o869 z@=ZWuOuLsF^R29?NYBr}Qz`sI=^XzwNy>nU2J%U^Wci6^tk^1jh!B$CkR*lKQy6LH1H@C zcZRjS3bm{-byr+u6jOPSKO^-s@N@9U%Ujq|P7K?P^}B_k%+`YsD=q)RvR9J_bA87{ zws4MVxjBK$Uy}JwhH}yb4Cv$sQgHY~4Y?Amn7GJS_`UlcG75cQL@ZsvCc9r95ThI+?TPEDRb#RChQa!i3ASe8+zf*^N_m#rq{M)QU5ub*_|MU^rVkwf(vp%5)=BMg4?`&+fckmG$npNwquUh z-`C%#4rXp^8eS}*6%FI)xx2lSm;$!(L5xdd5>&m4p@TZvThGZ0O5X}t5<95h)D*%M zFa_Vt8+)=F&Iq0(1=Tb7Q=9?Vn6HFjD8UnT97X^RHL(5Q#sSaQ+O_2qRcT; z4UbNezr8${&u?frGtFdzALczXS}jiHFHc4tQI88%Pa3wWT+s$x5(Cx;2;Hk0Ws zoE%dC8J8eSpM!f}+F%!jB1$_ty!NcNwwqL8M%B8yy6!eMHfQ8b_Em1UyQgR_z7d|U z>KLGP?i6o0Z56awF~z>!OBuM6vs4iAd3E{~iMq(G23#_c`1lBhH>0;oIA7}fh^VTm zxsAi&h+0CRyo;74n{ILCVlhK4oMu6;+9hVRO9SxH+mp@B%6%`u^8wy>hpe4N5A!zF rH^Pb!yf1+hIxR%Z0RLa%&mWP_z)~*YWRdXM3; + + + + \ No newline at end of file diff --git a/android/app/src/development/res/mipmap-anydpi-v26/ic_launcher_round.xml b/android/app/src/development/res/mipmap-anydpi-v26/ic_launcher_round.xml new file mode 100644 index 000000000000..036d09bc5fd5 --- /dev/null +++ b/android/app/src/development/res/mipmap-anydpi-v26/ic_launcher_round.xml @@ -0,0 +1,5 @@ + + + + + \ No newline at end of file diff --git a/android/app/src/development/res/mipmap-hdpi/ic_launcher.png b/android/app/src/development/res/mipmap-hdpi/ic_launcher.png index 7c1304d1d30c619a764f62f40d18c4b465e5a79a..2e1c7dd1f16a19314124ed2e64cb4d8a8497a565 100644 GIT binary patch literal 4567 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 XV6QFY%!*`?00000NkvXXu0mjf_iGEd literal 0 HcmV?d00001 diff --git a/android/app/src/development/res/mipmap-ldpi/ic_launcher.png b/android/app/src/development/res/mipmap-ldpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..380afcaa536919032308f23b7dd415efd83138f0 GIT binary patch literal 1753 zcmV;~1}6E5P)0Dkx7GcSFX{a3&IRK4V#w<6;r8R8X-bOb2;ueE5(3K4mh{|xQv&EcP1zq@$# zok;nvg#hgA^&d~K5AnmM(U%p8?ocYp|xAr36-8S|vVAb{OShaqnA|$0gIMJcq;ilX`!x9jH(_jSUYT1q1uF63+kc!*5^YZfMO1e9CnpNXW-5d zj7loT{N6p<(IS$T6#&&1y0i|9tFT#hpa2Rv7%9RFQ^+%;Pz++TNYbC3Gcv^cBvMYh z8mNLX$^9q_^$@+f3~%3o2m3HN2$dpKh8*Kw16H=+-4*nS68fdn$dxmQmoP#Xn6)vg z9zb!*MdnFcM-|wpqJR1r-du)LCHTTDa$y{X3Xu05phg?EYv_$NxOLwFdubjiWM+OQ z9dcPO7y#-m2j-32@a#Bz?F@3dg5?A0*cZTN%88N z%W!oWo*hSi@FEyNcWUTXHCuy90hul%v%}brHqqB_!ufH`<+F!nyKRw|vMtnA23#h+ zbqB^u@bVeNH)yL3f4c{NSWak}0Q8l4xO5tf2Z0aGHe6dqFU>)JfFuv-F;X_5E|XPs zX~PBZi?c9S>3mn%sl&e>W^QMv5yhg6m(X)hz;AD%OY6vmC&47^TeLEOJvxTE)>&MI z$w6dc{BXO^oWliBA2Cy zv1ID^9pSQw1PsX2r_iyI>rEFYVRqQX%}^iA3@7+wNc{z$ zTq8uRqW5;Nf4@(7sz~kW(R2;Upu-N8u5fh~wLgb`@ie@<0viVokY^mYnF_H<6{9e< zQ{(#|KVaysB`0e0fOhqOt*JqNsmi)0&q#rbvMd^5MX_|Ix#U13SI)Yw9eCJ}HX-jL zVyAOHo`U)5KfkLTsZXU))(MFBW|K@#uboo3Vjt%sJ$+VD*B@x>@r-&y= z!TDZazX{E@YX=JxP>#os`McZ9ZXIBz&tWF#kiiPN^#H;UyKVR5yMBkhwdH7!0=1mS&p$WE zds7t$rfngev4@(g1&jz*JcBk`5ahD6q8K0x6EHsl)y|MF@G$T5tDMKJ`#bcv+L5KL z2>W@D_ogcB<$Y*`Zmd0-%LMT~H}f=Fkk6&dXV-8d(4UVxcjx}K1-wx%q}oMl7Osb& zisVgaWR8qMFCfz&nhifE`%R&23IW;((fwN7$-B3_WQb)=qe-K7=k$)7B=C{G90&w$ zvp*R68%ZmrTsE~Ad{FiD+KwN7wIw=;Z@}arY`c4y;%)-R9p3w{d-D~6J~t7F6#^^! zW3Bw#GY7#39ObgHU;ksJ^3CUdx>acZIYei=vNO;51f)R0n$?MF?l0r-Z!VF%`6NIY zz#3yHm&=Tfj^g`1p6AhSx5?#l7-I;-5WuRc`=29X0n=X%Fs&`If0epZ=B-SbHR{a@(6SVXjHKu{`400000NkvXXu0mjf3@2AB literal 0 HcmV?d00001 diff --git a/android/app/src/development/res/mipmap-mdpi/ic_launcher.png b/android/app/src/development/res/mipmap-mdpi/ic_launcher.png index fad5b364cbcb799e065749d5988517d6c980f1b9..572baff08c8bed64b80c7f40a6f5b6a828308f32 100644 GIT binary patch delta 2496 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 KMNUMnLSTXhoWv>s delta 3497 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 X_5LfGp!HE?00000NkvXXu0mjfYVx}U diff --git a/android/app/src/development/res/mipmap-mdpi/ic_launcher_foreground.png b/android/app/src/development/res/mipmap-mdpi/ic_launcher_foreground.png new file mode 100644 index 0000000000000000000000000000000000000000..17b72cfd1e911629e2d518e94e3b5101f8290c70 GIT binary patch literal 6368 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 bD5L)alB6Y{bm}6L00000NkvXXu0mjfatNsN literal 0 HcmV?d00001 diff --git a/android/app/src/development/res/mipmap-xhdpi/ic_launcher.png b/android/app/src/development/res/mipmap-xhdpi/ic_launcher.png index 71e97528f1f6607e21a3d8740aa49b0d45bab010..f976fda82ca32f7a5842978cf32dce0b3ab79e2e 100644 GIT binary patch literal 5187 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 diff --git a/android/app/src/development/res/mipmap-xhdpi/ic_launcher_foreground.png b/android/app/src/development/res/mipmap-xhdpi/ic_launcher_foreground.png new file mode 100644 index 0000000000000000000000000000000000000000..0d28460566db6492cd1714adad22ad4763215451 GIT binary patch literal 16232 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 D)qNX$ literal 0 HcmV?d00001 diff --git a/android/app/src/development/res/mipmap-xhdpi/ic_launcher_round.png b/android/app/src/development/res/mipmap-xhdpi/ic_launcher_round.png new file mode 100644 index 0000000000000000000000000000000000000000..813936bb500dd296b54e730b1809f1dca9951888 GIT binary patch literal 7410 zcmVFXfyZ65P-TUqLiU0^?hX5dRT>li4M6SXA z6z2h-65s;kQvzII5H2zzh)1s%xNE7Ms*5Yhs+NK<7vM^O<^ZSyPy?WN=wlsvECC=m z^yvhno5806^g!YabfXWN?B<{EOUR$TcTvf-i-rK|e_apU+fd3@%LV{ffv}7iRUlLX zZ~}0G05FjDof(m#PY;8;iRlP{kC4z_7cKq1#KxaZ_bcUv3q}CtYimJ|T( z0DlIc0Yvs`ZJ0R*;1C19g5-nnMUKe-^>&zl_wfZ;83aHb`aM-07$)f0`XokGTH!eK zEoj8+L39@gp8-${bC#b^L;!Svc?UCoi=XY=VLbiLc_+eoTLH?^ZwUZZ%(xri`v9yR zkB6KejPSE}33v%ozREjK_Q=0}ML!>{D?>e)R#>+`23chLEP%fS;SmtkgUD=|=mLL+ z`+!*>Tn|BuF{dmpT=tW^uXWmI$3$7s_!hFu3gzkhth{pe4Iq3Kz&#V|;spZZ6)=8A zAD!K4{P~sy;?uJrri}%uyS`D(rH;Fq@FYO9r>mW5gamMg7*A0|dqrRUKf=?|$dnVn za`;;+1B;}=J*=z+)hIrl4OJD-;G@r3-er=GW{>ym@TWT2dh^AWieBtE)rX z%U`H9h`$NKi`;RKyyohD=L9f2gq)j%I<;~e{YEzKa8#V`w7W}3CV!X zn>XXNnf|Y^$#z^5X*dm%!CfKn?~VgInt?rSKyx23n3$Nif&oM|pltv+(F-*70i8i} zg*dHK#-<3UXNxkhNxkyGfddC7@_b=2;nLs!r8PX$eVZ=u5~e`M=WrZ2GXVbG3E*Te zrpw|SflUP#R)TI{0L&=`xu-;7OQ@3Wb2j#E_ix->keyKQ07hmOEiz2LKgq#oa3BtT zSCbO2~-yW9y_Sm4p#U<6x+NAirmjCjqK| z^%vIu1tnk91wWVXGnv5tDERGW;Ej{!;ABIQ4OmbKTzwg+x(KLn0}d<5Dln{iCRYq| zpfw4OCV<{SaCZp!umd>J1BBw)+j3fgFD-{yGuu>SCl0Af`s$oc`Qpjjzn2#)%1a2> z*4D!Jm#c5liGKiscS2n=B)HuVes&MAuMJ2T$=3@BL9@J|RWm_1)tM?OGvJQ`M#_rN3{zk)nE`TH(}n(Ud*hdr zBwQIT5+@#WT;05X|Ne1@B`Q0nZT!g;H`&&)4t4FO}QJmeF5mp zDOo ayZRJzmevnqfxG#r%j8L2C;@|gzlBOPn2^WtaY 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 IM6N<$f+4N8t^fc4 literal 0 HcmV?d00001 diff --git a/android/app/src/development/res/mipmap-xxxhdpi/ic_launcher.png b/android/app/src/development/res/mipmap-xxxhdpi/ic_launcher.png index fdbac43ec06f531841d66f0fc50696f93aa24a26..0c5bfb54114d49407c8d4fb393e7e3fc4a548754 100644 GIT binary patch literal 13942 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 literal 17895 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 VLKjn@bo04ID>&ekf2&_?_P;3SkW&Bv diff --git a/android/app/src/development/res/mipmap-xxxhdpi/ic_launcher_foreground.png b/android/app/src/development/res/mipmap-xxxhdpi/ic_launcher_foreground.png new file mode 100644 index 0000000000000000000000000000000000000000..a327f55472b2b4960069307302330a61abd78272 GIT binary patch literal 72988 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 IxZ)b|f6WD6VE_OC literal 0 HcmV?d00001 diff --git a/android/app/src/development/res/mipmap-xxxhdpi/ic_launcher_round.png b/android/app/src/development/res/mipmap-xxxhdpi/ic_launcher_round.png new file mode 100644 index 0000000000000000000000000000000000000000..bdb6e96cf503ffba03003be31fb0d809ba79d13c GIT binary patch literal 17913 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 KMNUMnLSTYN2)_vc literal 0 HcmV?d00001 From c2189e47474296d4f30ad8e3c3df871a56d36490 Mon Sep 17 00:00:00 2001 From: staszekscp Date: Thu, 13 Apr 2023 12:06:26 +0200 Subject: [PATCH 03/51] fix name --- android/app/src/adhoc/res/values/strings.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/android/app/src/adhoc/res/values/strings.xml b/android/app/src/adhoc/res/values/strings.xml index 8b49604f4766..f59d0656694b 100644 --- a/android/app/src/adhoc/res/values/strings.xml +++ b/android/app/src/adhoc/res/values/strings.xml @@ -1,3 +1,3 @@ - New Expensify Internal + New Expensify AdHoc From 991ed0297da3fd01ca7ec3b4038593ec9e04f826 Mon Sep 17 00:00:00 2001 From: staszekscp Date: Thu, 13 Apr 2023 15:10:04 +0200 Subject: [PATCH 04/51] improve android splashscreen --- .../adhoc/res/mipmap-hdpi/bootsplash_logo.png | Bin 0 -> 9898 bytes .../adhoc/res/mipmap-ldpi/bootsplash_logo.png | Bin 0 -> 3364 bytes .../adhoc/res/mipmap-mdpi/bootsplash_logo.png | Bin 0 -> 5276 bytes .../adhoc/res/mipmap-xhdpi/bootsplash_logo.png | Bin 0 -> 15477 bytes .../adhoc/res/mipmap-xxhdpi/bootsplash_logo.png | Bin 0 -> 30111 bytes .../res/mipmap-xxxhdpi/bootsplash_logo.png | Bin 0 -> 48760 bytes .../res/mipmap-hdpi/bootsplash_logo.png | Bin 0 -> 13381 bytes .../res/mipmap-ldpi/bootsplash_logo.png | Bin 0 -> 4463 bytes .../res/mipmap-mdpi/bootsplash_logo.png | Bin 0 -> 6749 bytes .../res/mipmap-xhdpi/bootsplash_logo.png | Bin 0 -> 21982 bytes .../res/mipmap-xxhdpi/bootsplash_logo.png | Bin 0 -> 42564 bytes .../res/mipmap-xxxhdpi/bootsplash_logo.png | Bin 0 -> 69345 bytes 12 files changed, 0 insertions(+), 0 deletions(-) create mode 100644 android/app/src/adhoc/res/mipmap-hdpi/bootsplash_logo.png create mode 100644 android/app/src/adhoc/res/mipmap-ldpi/bootsplash_logo.png create mode 100644 android/app/src/adhoc/res/mipmap-mdpi/bootsplash_logo.png create mode 100644 android/app/src/adhoc/res/mipmap-xhdpi/bootsplash_logo.png create mode 100644 android/app/src/adhoc/res/mipmap-xxhdpi/bootsplash_logo.png create mode 100644 android/app/src/adhoc/res/mipmap-xxxhdpi/bootsplash_logo.png create mode 100644 android/app/src/development/res/mipmap-hdpi/bootsplash_logo.png create mode 100644 android/app/src/development/res/mipmap-ldpi/bootsplash_logo.png create mode 100644 android/app/src/development/res/mipmap-mdpi/bootsplash_logo.png create mode 100644 android/app/src/development/res/mipmap-xhdpi/bootsplash_logo.png create mode 100644 android/app/src/development/res/mipmap-xxhdpi/bootsplash_logo.png create mode 100644 android/app/src/development/res/mipmap-xxxhdpi/bootsplash_logo.png diff --git a/android/app/src/adhoc/res/mipmap-hdpi/bootsplash_logo.png b/android/app/src/adhoc/res/mipmap-hdpi/bootsplash_logo.png new file mode 100644 index 0000000000000000000000000000000000000000..96af2444f98203ca25f326b2322a0789eba99c04 GIT binary patch literal 9898 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 literal 0 HcmV?d00001 diff --git a/android/app/src/adhoc/res/mipmap-xxhdpi/bootsplash_logo.png b/android/app/src/adhoc/res/mipmap-xxhdpi/bootsplash_logo.png new file mode 100644 index 0000000000000000000000000000000000000000..976b98b36c5e8ca3d8feee92bb1840892c904b1d GIT binary patch literal 30111 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 z

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 Z{|8mCCQ3WaMdAPe002ovPDHLkV1lI3`MdxC literal 0 HcmV?d00001 diff --git a/android/app/src/adhoc/res/mipmap-xxxhdpi/bootsplash_logo.png b/android/app/src/adhoc/res/mipmap-xxxhdpi/bootsplash_logo.png new file mode 100644 index 0000000000000000000000000000000000000000..b613dd200413be33ae872c088dcced7df65f9807 GIT binary patch literal 48760 zcmXt<<^}s9(GdGsp)!+L>?#)^#?c);sWl)gyVylF4B-A@b~NXLHMOizinb_5u?{; z^whlcP_2j|eeWO*Rvn511nEbFM*#?SElO2|X&{jP6!?N8jvCh*$;S?KhD@1yh;p!#Z67+Fx8KMV4 z=^%wJ#0V=K`B)fn0MaiD5VLjnuqztq7bH=`b5aR5#{8dJM;unw1$so75xI17Rud)o$pQ2`@pUPvH$NIxp&L&_j-s1ixP<9aHF0n)yBIkMAQ{;oX3 z@f-Bf-aplp{EVWzJt*Jia3IFnA%hpZ74$un#8CkuXpk9X0}oRO=(f6vB9@I} zihxm5X3RA${xsy({+p zsp;_i{q>|loV7Kh9?IfcmUg7`Yut9al!@l^wQ(}vR2+uebd8;XIeG?$u&8@wz-i3eyx z+Ysu4qB&3Em2)3x6%sKHON1kA1)dmt7i83b0So#h z#{}{=pNr7$CK5Bv{IdRqHi*Ce%D8`m*D3FIMJ1QUlmv}ybAa72jU{h#me9vb5*G>b zs7|w=d375Y?yx0v%DwTD#Ie>0@@udM|HcqX5Va{`;+2D#-lFd`RE!Dmr}BIZORZ-E z=0ZN8g!9+!*V#TKV3sN$PURoAAn8;v;2)Q8z?@ne#FCuLf;m%{dpLR&@Uz@RDQ@d) z*~HyHL5*ci>tmFB%{gVQPca3+K7{+g-hfL1(eWCHm^EOX^Lu>F8WlrFy| z_Xzj>Nw&w*8&oAZILskFn6yMm|CBU8iz+AEt$w7Hq>C&;d7|2`*|HZYVbAUS5dABpOx#nZJcLWx)4$v6Sh3G7u(J-2fjT$DsErCNU zy`slh%p82+klEt(OA|2O!JFkDr=0LgN;=Pm1Y_ehpcwK=Qry`pW`ijp z9f5z+B=@Xq3g$o^teltIgstgK(ywBDDNT99kFYCoT0yYdNJUJ)gIUEol1Ry~YF3(T z)Y@3;jbVhJj)e?CxxA_+mcD8Uqb0ZBgux$y9Da)nr@#GPI77!x@h84o#iCb1B%2I3 z-PFgj|K$$=(xAuCS(Q8^B|~llhZ~dYob>yd(&ys9U%c0X@|?rdv|@3D+SpOCW@@2P z=~#=-y}&=7A9du7UDr(5t(PJ?r%Al8B#7kTewVBP-1o+>!gB>3-(P3uvhh$!aYs*Y zR>w}PS=6~N(w?y)lfZidY^pxe>iSd|6g^uU{@@$UXwdV=UQmlur9_}Lr1i$yL=tC! zFC^nYz{o3!UwX+!2LOYi%md(2oqC|Pa@FBcqKNzu+qtt3Wj9V9w ziGeWsbrg_FB#s!pm?%RvS*ntZ485Ptw3-sWVz8HNX+Un)j$RNj%^BVSq>arAN#tq; z1bP;_Zqgo-q1-5VK3$fHwlCCa7Ur-bm5sMh~YeoV8%r z2H>sC*|HUvwc4QH{Csn`2AMiNkzCr}lrie8lXo^Ph&s{w|Aw`!R^aPNdp}~4f$?=( zykfl=(55o&Cya(3v<2c~C*=q^1%YOE)N9aLjLe>I3++SidyVLy@b)$tx zd=~x%+4L00toqvAlSE?w@Jt8#fYcCLpV8%d4tBBSIjL`y^yQ2pOh{=*l<$P2jdBK~ zhaB=HP=7E!Gu~s&jTyN#brGQ|mUM>4cuA3FDJ=$K$-PbEy+W_qYieIcu98G=<4=Kz zO&bmRVb2G#EZifuXal5G8aK(WGDN#=-+$kbl#vmr7{w~upmzVj`h&#Jb_T}!UgS-U z?2R^X0TGg|HkT%1Kww_fss;<%hPj4bC20b9F7!HhV%jQn*~}t4BDLg=>KW=ZSPk?H!TI;quq& z-Z@To{pn_%xlXH4NL@c69NN9SG_|Sk6pCyk@5Itk%mxx-DI1z5i!=1c9W|8D(Loh* z@|QeNFim@uV**&!0nrI+Au{ei!Y1@eRT8Q-dWpr49H$WLlll>m#_WLx%I_#99e8zp zPmw6qCaSWxl|CAk= zXAC+Zw!s>FDL_=^Z^rrE60-wHuPL5NuS9TyKOBF`MTTbdToY93D}O|X*+$@`OUCA+ z1effXVOHU<=3t75ZNL>E0UDt4Fm3&h;9V5ZppxC-rs4%ZWyCW$eh4NX`<30)voj=6 zD#~|%ggig7HGaNuLj$OWk@}CEDa_l4GF1BCuZ-&Uze7$9+4CPWd)b1mMAzh_~%VauZ(B`rRgV8A_^e=;C#n>4@DI+3II!nccBaz6On7F*8NblY{gk?(ih;0$S)V?&}V8s3IF_OvXl z6$uP{BwGpGTU~M^S~xfD=~Nv<{ZGSYfbaae()<2OPYlCPsFiTX78WPZCmrK^vveSB1p=bACkC1En_I z&Yk`vCnqLg8v&35kSXB-WR{@z!6G}q$K}qZm0?T3J*Ep4Ey^f2Q+#6Mt$d=fP1Z5r zR3M3JcZyS_G!~H&R&(!(y~u!5yljuO^v{QBh%7g zR&*~}Q(&=O$j>q|{VaLM68v@^#2glvxGBK!GlRrS*7s1HSO1fb`zxk0h}SP3%O6dI z==v^!@m_GeKeB*u$syKFU~o}4R*96#p)BtR35WE(R&wNC?zkCiZKMK`6e`w?)ukDm z#_AZtD@VqGwe)wmRGdEg;XRJy) zz`tJ_H@KNe?3L(SrVYar9?b^bR*(w7PX&a)2-5mIZr3;vAc^S_lc1u_$xA31|g>qwKtC**iQb(FpX1f zJwN%UM@L=V+P_==9c=xOoT~9_4Vyu5M_g{FYDx%l% z2j_I3UzMUVu*uKsdTh^kt@EA@;1`GK&Hz;;YMw^l4ngl`MKWiDH!3x3A18W7Y{rFg z$&ZPDt{uIzvnvcYOyx0{Xq3EA9_bQ4gHn-%pBt}S5(Jzpl7M10D1C@O9M)YOuQhMwxj0CbunMot~N3r5JLc$1qb0JMUW5R*DZs zK)Ug}pl?Tz^TJufm~!nNI2RMhB9kF19FB{pB4pmG>|&oZ2y(XYUv11^8h!;Vfc6X| zE%kAST4h>A&{w&@AnC|X1pFg zs7?{oh*C_i{&z*!O^;YsIwjR6!33a>PVH#N@U&JNweJ0MhE8FJDBLRklW+aS?!vQv zKJ6b)$Ki@lWv0+m2{ce&!sX%v%eSF?42kbv$AvC9k&p86Q>ebi(u@Y5#ab9sYlgo( zo5PE1z)wU@Es$(!cHR4S{mRV9+HVi~<%nH#>m`{=5U!hygvDnK8zZ`NKxko1VWwif zi|wVPA-TfiL#fo-{)mF_p)xj62IzL1hrrnfu%YzMs$9MXG>*V?g7)eAx$}O@dH02% zGz=s9x#E$x<#M#mNNM|B{)$k3@YxND$l#%UJpga&&7j@F6B^8-hLb^-HiXFY`)HC+ zDtzx~gN=3JE!v3=TUvbF+u*X|CztW+d9c%W3hwql!kt-$G4Yd<7=bAoElC&d z2)#6%D)N*m`6P7V%J8)MR{ae^2w3O7cblmNq&k#1x6X_BtW*;b!re#`gF$0hf=Yul z@k<-Y6|s4^3Dlxo(E;f+$AP2%r!z!LmcFH*5%&)oMZON`w%`TZk8HnH6xFk`TT*JJ zC1O&VCdm|p;w*VXRgx9KY?aTB7&bgqg4ELBt6~ zpM#@#Oql?IL<+mRJ~pp^exjreUfuS#C45|@Q|vvNLjJ!0X^+8`gp*S7CXQC1VaXx$7P+V4T}GMo-T-}FqH77qc@gbcop)? z+GmfP(Ey$qPx!+y@TnI5#DDaWhgBPI`^tJXg*^fs6%8-JDB#SokwsRw`B_1%WId5D z@~Cgc2Ody0g;4=F8p^3DQJQkmfLK(&lO9IX$er9$3N-oNrQ&f17 zX?R%#X@j9Lv)JcudKS~HmNX_;_69>7VlVC-3=1*Qs2FTExd(aJiYk*u52vXXykOA6 zqU_Av-lNCN{nXveE5eO`fEJ;9==A%s7B=M7FbA0iT%{kR4z^CqhAM+jA2d-)+2=uy zzT!6@+qZ)iJ(|TwguD=FO4S#&<7Kh5Wu{j|G6@~O>yed436^v{Dj!BSDy%N2NSdmT z7f!S&@v_$}#SXiTqUf5-SR!^AZredCsD2{Ue~8k`SPp1L_*&i*szn?X6uQT)t}zoB zYbA3&kyKNk&>57V0N>5eySsC_U#MqDG5#rYQ+aJmM1I+ZJJ2nw*fx7MW=R)O2dN%g zg*5A&L1tB5OcEDy+dF#p9mP?syAX~~b~wso4PmIRQT3aM8rK4=5PWbewvlG3OkI#c zCXsT2TC$Cil+V&e^)wTIHC)}bdQ!mlJbA%`@maJkz-phpE!HPerFrlGrwQH7xz~&P z1rBs8n1a?HW+!k@5UTZHcG}j8jh49;0|)`jGVhG=ya#j%xxq17q-&9xw&*F)9{@8YKnorX2aF zOT#Nt1=PNWd?68AUvcGCn73WFdbgxRy>&kyI#5*feY!d zJSl9#mYt$dm9aOU!bO&rH2BGN&qFABv^0_1H#{#a*bv_SFH>_ZWAE<)^2HqA)A93j zirtY$FD>YAMW8|}d*hQ7vj-~FU8>L1BfK^+1`W(xU-RIUp$gCY`Bn>K>DAEWkkXpQVdnz{30#HZDb>_NHR5kAjuDhk3AdlB=(Qmeam#c=dWS` zafjpIR0$Kd?GZ3x?55Da)<;A_Ryp&V!XVqCZQ6u<`)uD;5o9K70i)2H_S13R=P#KPfR=ByY(`JipK$qaAxeo3uG>N$!$IyTEJo^N)0E%J-_z{ zLpJwp1ZRasj~qpwTI)6jFE0#y%`!ou_H{3`-;SvFii0`h)*9 zBUisrLimP{*yykJ^c87w=N;uOYpNmH1GmE~V#3Cl=b(<8!C+DJZIvQpF%&%jVTJjO zE_tDuf!Hx+wGmAC{nv!D00$Ta#+QsI#gDJt4-jLlCpu`UR1WnD{KK6>5sYi!nOdVI zs*QqlAVpZAkn(6iuRc?gEPkpi-9D(spo=+q{{L(d=jE6HNq#tcV-(&E1Zs~hkaKfSvp7WeY0ASgM^ zNg?$2MDKU?CWn8{)jfGHwL#~R7l~F@bEGX+(xnOq^6N~N*M@IVu%=v-E%k$M%9(mD z@c9!wVxaZ<1jZV6roLH6?+E&pI=R{%-1lrtdnSPckUvAo#7;mMI1*~mGd6%YF*HmR z_~AGsa0#O1cyKxA`LHkY+I%rmEQ8!#f+vxL6cg&y3BUK)dj5FsQg;##!5Un3j`rT zj4(+6xdOk6()#+h5re@LldPl#$fAsv=UzK#NF(p2E%H(Fp~9kMYyItf%6%(StfPYU zjTVIXVyf;=zl=Yii{B@#>9@{1VnIiyJ$r$rs}gcBnr&^TZg5VVJJ86|(rNpIY8*T_>>?-Mpa_O%+1 zZVZ~bMED^Py}wEUDL-pMNC{)<$K<0nEqkyAm#7u&{hkZU$20m`zDm=)?Ua>PZ;3MY z*QX%PJs1vltIiw_E^h$<{uZoP1ir!~c2=wT3zLwEqp_DE^t9dkjuI%)g;%uB^n+98YCGMw6 zV`~gHeM+e_P_J4%^v>S0i?r+t6H(iX-5dR(lI<126wqTR4Th* zNFL!uO7kY&jP1KY>q9U(Fx(DQRKJ29+`B7~HUWrXuEcIV{mOmM#j zZkt$9PSVZQJY8{7W_?t~O0wDK>|14*+z9m=A~;*AV6FH~WoekYV6TR6w1A~)<~&c3 z0a^D||4=w)8@YycIiibQ`U5O$n>4+M#E77AH?f}}eDawwd-9+mA=mNyJIhp81`flP z;G5auWjS_v{d8Ngyr!vGDxSSf8&`*IH@rnySFZqZOZK_Td#wZAZ^8b`pT@An8ucpI zkI0V;Zx@DPcH1lOab4kl1q75y_RlVtP9qFOi6FT)o1R!MDTT2j7fu46Vu`+iS$-kp zeXDZoLwmXLr=ew&Yd1AUDF}M^+m?bU5I5bOrulPo$f{~_Ml=0ioIhK;2q3EpKXkT? z`nWZ$-ULfGvsofZ=Av$M_rJ6ap`)QlJ0AF(o};%(?Yo%9Y=!>tZ@oDdY91O16X)2R zSDWdsvR3Qp4pS#2sB6RIo*x{Geg}Q*)_d}O`fD?9|K?qDt1EPFG9P}u=3k+iR13V9 zhSeEepLP$UgwZX|H*w^N2d&u#Y&jMz^OY06*Fi|1`{w;%0K2zz^-b?3A%Kz2| z5`EwkJ4GWguMM zl_7Wo85~pY=t=!Z162FRKgGfjzPRAD!8Eq!JiJb?e9_{d1L)rn6Pb5l?nHMA2jq8YlgmGiKi?yWg`M`1d&DLOsaEuK`>OE?t>KKD>&a^ zr|>mhL~}%T2QaYYF{6B*7LU7t(Jb%Vd`@-yH_@;IK=E?E0+hz(;Px*^J4bge3Y+tQ zxUbq&(v;G9!7Z+9PT6Y`?z=MWOWc2z!k6JSo=s&PVNDLkGXreieq;p-Dq28J)D6lG zbYEB`&3Y`;MwTh@oSz?{)VlO-7D{}exHb^s9;v9lK573+D6I(Pq+?zqsNKFbxH;}9 z?vXM*S7u`2E`uD5XthFl`KhF3nS*Gy`rCT@t@n zEQFK3D=vw$uRq)(#{+$`=JO@a+P78dv$xkMJj7k{Hn)s*wF`JO18$a?eu+nmMR&7P zPBnvIaaC2r{XKRRrraIQYNj5fJ@CXz+-4FON`7kIJeP$j!JzW`jbi$-n8Sn$X^ zGPcR(+530Kjq4NQOf3SzEV`s(|8s_263|=U8qRQ(@-=?@qoX4y0-^<}2g z08`kVKxWO4Y>eRuB!68GL8PB43$0;)Td)+kwuT6UnL#&EE3*3&ghEky9_Zv{-jxL26)9(Dy0{bNh#1^ppD^eEl_$Od){pmv z$L8ue(R1%wRjhgDP2CH?7u3V*7^27-e3XM?d@_Z#@g8-_7NSfq^p)0#XS!QT*w*f1 z0d48DD=&(m*wsZC;VJbMVQ?JvJQdQN9mH;rI!s&uUCkE>7K6^ORt8?E2I;t>eiFi1 z-^UIj@5nqTd|Nvq(9o+$L=B03Z(glF7VmTmtGu0}DQ8(cZ9*^}yDt}YvZZQT)nf82 zYDz0Ce1=wK$jv&D{d-Tzp#1rVM^N{bt#z)$kg^9@F9@SUwfQ-P77Lwqjuxv88LK?59~uYA@Lggq}E&!oY7#7N<#0IQUSTrM>M6X zbZU+m$niTC>CSqg*bqT~=s$2HTyto*8&X;~J<7XVk=e`LC$kE`GRvij$%NT9U?i0D z2}$a!v4j0dj-zbS5&_^%U?aJYQNXPZNehdab`%NP%a|Mi>-1#D)&;@ln7u&wyIk3s z+dLbH4rjDc_{R@tlbec}YagUdOECHGWJx5$4g4dWq7y(5VsU=sJTE=q**|mrS5Y^V zOAgd6vaqADb&4@EiQ9mP?xC#=->@h{uN#Dg%b=_wSn=o7UOF}sdf%YnRqzKO(MT3h zSg`nT&$(5|{kooZHm&D~5@sBixiaYr{A74k4m)3RY+nL0bl69C3rUNq!t>wR;q;~% zGIp)f1V+Npk-WIoA8GZY%F^WOUBgOg$!J%{Y7&g)zkvpQ73+3{xcopcU9)!z=MR)q z2+C{t^ z5FrDb-al@BY+D}+hJ(N^6b$EiP;>}cleCataU2ntAF^3pL=g@QG9*WNsK(~2Y32Ap zk~kZbNXFpf2j_(l`#Ew&}2t z7KQ%vD=X~ax0bPkfbm|wXCgV=z5F|(^pXZlel}P{Uf}ljZ_SW>(8+yFr)|dwm|fch zXc`(cnL;Ghmw|e5I~e>q>Fx*A^QyTpZ8ji8>-$MxQP^+2NXBezAGLmxs}Hyl8&t6{ zro@MPRldW6>yKb!gy6#Px!?rylB-DQBjp;3=`-r=DOYztB@4yr#5PwIUK1{hyXmT8 z4!l^;26iTg+9=|vKj6Y7?9LuKJ~uNfQn!Du!9A<#e%Hygk0^38Ni%LJ%kw9~k=3Fb zho07I&avV|n6|?#x*H@;=~Yxs7th=UJmb@xlVSNU&CM8np)#iPz>8mJ*s^9a3VM0) zShu8JsHg&Ptm|uQe@fKDqwx*fw5ALwushQNRCivNQCq^bIu?T2q5K$TRk&S*kH_|J zoq~;zm%5|-0!b&Sm@gux(C>RM34E}#IVg@1A?JcBRjp^c#IU?S{6C!=eaf?IYSAs!F zZv@SpHPKCm&@b_sG`ApD&9kzA_Nzx97AL#k(G>-e-%GYiAr9C!BCn0JnFGD^zYEL^(cd*{Bw zGha6CJC@qQ1x&v5DWht+O(NE7EWjf&SqsNuESv*$XbtZ@P#wY@vr#fJKj@YLV#CEcwrVXEXp2eUysagFU~lqpTChanvq= zG47p%*zvC^lP_H9hg3e+J3Xvhe}@vK$@R9aIRE%+lZ$j5uuJEG6KcYy8{6{;9hCtq z9rwAEsHaJ{w>aLo{e^XjpKlb*G2@>Swx-D7x7_z1+zrUaZ8G$Lrush_P{yCE+BMdK zq~bBu7pWsAred3QlyQGjC8uwDX2i3De5uO!(WIt1KA({0ItIo^iS!pGaR2?M?Xm5q z-ext}X7)!*LDdEo3`tcib^%B>>#4G*>IM1Y0B%387W!Ch}6%P=!p5(dU|gim3e`ZG<-|Ft~Y|s zyUas%VC|2Md~Qx%-5!&+hTsk3`azB9&f>5+V9qfWGx2I_7Zt8fEDfMN zmu+T(F_8uyhFKR>p0#Ae3ug)dU0SEYu+zHJ)A?O>HZN6$lFuFuoJ@!cjg4Xe8Ly5} ze~7TEp#I@g=a3AXeKx~Nd&fhcy3$66B%W#c8>3gSe>p z$7scea6uw3!bIo$>ZrvuXPMRF*QGOAmdvS_mP;iOA#`?X`~-wK=UF&l9=-f_0A1GU z<|)3~pexog8^y9?-o1Bg^hw`kn03D{qrHlLh_5+K&X&Uh+kl(wPOEMQSl3dp?6B8=9k14!o0m2etZWdiL?mdaZVnQ2#TKF9{z@q@ zpadUL4NdKrJC%#n)a1@xdCX?+4?~ey#MgBAauvUfmx$%duc)Ij67_7YGXnm}upxK{ z%6f#5^QVQT#qsqQ#blmKEl`y_KMYEPhaj8Gxc&j&X!f>e-L>hB(j&fd-ycNL1Vk>r zS_-;-z3H|f={Jeks#^Fc@}(}XoL45>Sgw>shG_P(reJUST4yh%lV_sGY=#}+P)*dl zm}<-0#B_{*|7ke6z5B`T==9PAtt}pa9{j)yJ?&=`id1j~+&&LX_y}K8Pz1c;Q4xb1 zdKHJgxB!GEpP?NDt_=SZy)$hlkckAhX?)3EK zGt7YT%e~ zO&@Vl#oE*DG3)AsDulz;f;!)>w^zvY}SOAIgRyB(-TKZ_pD~ z()l7V8buwp0PH|-2~gozJ3v7<)#+J`DV2sOr2wkwX3GJR>25u>qt<}HFTHRe?GRlc z<ZvzczdI=R+7zQ*H1zSsdM@EJRoWW|-mm@rn7b6z zJy;T0lsR#h2=)}$xq;_4?i>WgE1){#)jj-;ED>*R{D%d;tLyDCO)P1 zskz6r41`Z}N}>?E>2L;g}=mi^(qkk;Wz847gk4Q!Mfd*FciVu(nc zajH=$#&+`bIb#c{Ct%Y_Im_?!&@LKh-v2g4Dx**{<_JidPi^GxEc zBD|O+uVSbc)0?Sx0AzG_jO|3{$#AoKs;L0{eg--gV2vfdIh@$pkD@{_I>7tgXnkkw zFO!DFQu*|^1*I`LLft%zfi~H+_yIB(CRw~+&PZWF^e|~z^0$BANS}o1bIDX*Wci;O&l(lTI`W42Q*ak;oFS+A zZKmV-DQqbOfRaZq`^?(HzKQ@Sd(YMwho*#&Hv*s3_J`gtD<*&w{A*HgPVnt=ly_Tq4(4Z&zL6p^?|sdc_O0LRy8W6M zKYEpO_^^M)j}7J@sA=agQRUHHfqMmtdwm8WZLnKb>=jyf6>VzSM@X%4)Y`<3EjW!o zn4floX!2|wrtoYt8ppz4+hpKbqzPC-&cE{d?T>9)PuDHJ@ORp1QGqjn=Y#(a>AtRbH$MN-s#(FM!ePwCI(?{t8}~B^!}hYtUydL4`$f+ zkmwcJyYnwPE8S=NW~rq3c5z9B!{?2)c3~cmy>7XJKv*xX3BR24Wad3ZwuG` z)i1cy**}X8<1xp<#=W=KQikuA%GaS9C+$U_^hRX4 ziSo^}!>n`%`RD;y*n^v;VDQbb$7x|BQ8?dm_`qzU`*e}HesH%&8{Au4KR>o4uj2xV za1Y~5mvzC}os2thX?*?a$!gyl!Q~YnafeT>2XOKjlQomU>|PLHrb7C*feB12)ftYw z-KwYuItaB_`5FBfB@@|w_IOAo3bzh^9Uqh=L5UE1Lfq~oB3M;TlnpDzQVyeaG6$JX z>TnIS*^2A^Vk3D$9$BRnLDvO^x2lWiUJ|bMK}JNxRB>KRn2eSr=g#(d_KyM{-&8XF zgB|-Ti)xy~130031g@ji~Q;9W0yvyf}NUw67$9Afpm=0{xy=YxKJF(^Blt9pRu@ zhp7m~=HMY@Ub9>Tyr~{hebNwva8qWGh!Q(DfaF=SW6TzUxLy7I&ylM@9RUWe?~zfI zfY*O&tc5-+9Qh3g;L2mLJ6HWsZ~S+=U|$1QMBcQ6g}&U5;Fs4D4U7TTI5zYQb!C4k zsvoT60Dm^Ppaa(WFdG5y1n0pnh7ww-TE^;5OX`+($k`jihLc+^H88Vylm2{N)=%2` z76H31TXVk--<$<`cId@hS*-_APK0`?dA}97%K24s^|t`XPwv%D0&~xY5jlj9UIK%Y z6X?=j%}W>~0-r9|(gyyCSp7!q37xy+5YG~0@EWJ|aj!*)h76&x*dApup{(_viekjS zt(%ZdKT%NFn^(YZeh>P^J#)zGciJfSkT;xwd6+p`>~xu32Z)#BcMwoFC+G}2>D@6f zayJLTOwBBYFVca5^4ppEu=G#Q<+7YKLxhxt0fFRyG+Y&Tm-mn2&c_eEsnbq;HEZ)v z-}u-sPPqtWhD?BxKbU^V6T=Ct@U=O=A19NaJOLQ0J0F`o(Os2$rIAa;p8Uo~F{Yk% z_MAK?OxOSpufyu8d7JdDF^$VAq3An*hSt-`Kz=d; zV~&Nl935hNxa>Xk-=u_|EfAcuor0eVD2JbsBiErNNU=>}&K9Xp4RJj|kfrHPy`~bz}zk?4p@TthT*E z$Jec$vii9YVFo+^O5*{;IqdCifpwk9%0v31=!jCCEkPzVy3k3KJ4*S&A-#`7Fpez7 zbbxW;Row6;$ypDlN8a7oFlSH;fd6L5o(pT<`$FU{?0Tlrw=8gwlRWI~L)ijd6Z_fu z%f*c--}-C467Ji+tAtw??*F!kPIcFPxuP#W2t<`P)RXMX`Uwpu7Xjjg;Cr5)peS=M z!U@9u-4Jydr9k*Z;ira5-4pVVW%vNhJXS}Ri>AQv{m`?Y-PSon8;mZc)6d(io(9(y zFw$m?H_sEJnefHa0J>x;CkkAZE(@Qj#S!<)aXH#|OpK}Ac*LN-0AWFxL%wj4?B^?1V0C_=tJVeBc#IBzRNYl?Dl z_Le`K>L}i=5HYomh2DO=V=PLTn-y#F+Zo9gMc$xOXIEdO2$gkR|4x?C4!|TNzwZ)7 zx>uF=eH*^D!w4+r+C`c$3H|`#MxCRqnln zehlam9~ct?#9_u2E03Z#n(HYhET_(Jn1rMcDeS!)F<=V(dO{KTFhhz_4LbH_y++ls zgDmnpe5ZIrv9gZjKO(BN7W&jN!MpU9A)ag=UCJ9?cD??|1a{y0{E!TBr_%c)hh^V{ z?7zkqgoE&JckdK3MDm)rmaamYj6z!if$m5Xs7;o=PY6gR*jJwbySxnq-75d67Z+yPrwk$#oxL5f~|@RrM+%1>BE z6qt7wh33lg|5$)hJNIL@OCKLY%?SdZBIEXK5~8dA`Bxbpr8nkq>fGV=DX zk1$+k?k-jC_&f%begdYWUd&hc_}2lq60s<%X5;cpNG~2x2hxsEbvn5Ga-4B%q3|-$ zv+_;U;6tX`h0k7QU`)Sra5Z?Ce&FruCp*wI$&o>tykOzd_1)7uau!{L?0O~q;3lwG zU=9jXm*iQ~-W9T#cgEBt?G2O^$b)=;d+nLaVu*6?{U;9IY|-Fie?SYjhWXRt|6}Vd z!=n76x6zqlfT4#jfuU2nb3jr$q+%4S{elD5*3ho$KQMY z*Llym-jDNTo@ej9_Py?PuY2z&PeJa3p5DpL;4|Kw8|j@s_(&HEPgU__6q^DDe2d^0 zS7c}s^({9c!|R3{&IdR7vxJE2>-9-K8W;Dv$WlV99~r<)R${3G%{!hgXjrh?Clza} zS@Ul(nxW5$($mM7_}5(k8<&{D3lVh#Do;j#VCizA@xJkHD{sW1Nq~v0D&m3E^HY5w zEu#0n<+=RCG00IuzZ2&6fmtr4=E)~$YIPj)LC#a)W>W1nl2`Gx>`Q1eIm&4HW!Cto z%=4%1XD{tXp;N)M9va66o8-ikGvD8d52kS>=lv&!E)7#$nf#02bsP=RP&JAuD$gZF&6 z$c4UEo-{nMfa|2fWu<)qV9ue@^-$H|{X+vP^x{n@a9iXTq2GMWN33`mN zr6c7K4Z5(wsB{g3wXFyQ-uoEL+lQkboD_@UEVjSFuO@n0K9o%NHmHJdj=PKrL1DP+MYG)rGfT+ny9U;S2=>He7YxX&qG* zT}G;7UI)8vp!6x-6cw1XJ5K@k_|4aOZ8kugOO{B&W_68`+7;mk_pnhEQ%?3R z#w)7E)A*nm3bXGVE74IMa;A;=-JGck$yBA^oxN*5X<2P2mjY-(b#Hz>bUuKi#CVAWi7=+VF-;css2E00W~meeR>u zLoe1(5z`w>JHf!7+b5Vm;@FY6$i1pF$lEZ~k3c@WfpHrJb;U0cByo-z&l)Zh%r}e_ zKy*+;fhlHPO?x^vW{_9I3^o@r(h$qv{U)|joQ8O~6L&ig){9H2Zgg&gw2_%jy>KPdy7$VzBtgRhrwd9|8FU_HB z?QV1M&vnfjJmys%3=w3~Km&lHRg_90KDc#FjMp}NjKY_Trw@OyG=(igS6`dqT4d;% zz|nH7;FrbK#l$Y7VOEd_U+lnn1@Oq=6Ay8!BG$t1=3!pB({wH@B{po7DLKXWcXU2; zlY&K`e$b;GlFr?bX>dP!nV2|rbnn^cqDW^{RTR$ue@9+&n{Yfx%{1q~ZPyQnk} zzn$?n-2pqK`r48}d5%b)k;WE3wdq+|CEjct>2+gu@EF*bQYk9};xQF$o&hP`bdQO& z{{4=^>uVn#i#T=cTkr6`$10V4pK`%k`>6n@^exWWS${f2 z=7;Ai<|Nwx(Or4&`?|-GK}hNSn4AKN6j=bJ54%V}{WW*h(eK9F%0p71v#S#e%0QY2 zQy99KyKN+}LX`v&McCBV%wFBd)euQ8rS~sA7tVZaZ645D8L#A4HVgZnC`8Ld>v9&; zN1j`k58#57)qVPhqRzcWr1%V8cqL|%ZQm?v5q_mi`0O6+adaS2+Mma&KU~=fESQjw z*BOYxSzWoe7?Iy#(HN@irUYvB12nkq>MK;RHIvbT#Z6MZ41qD(V`6OpIe5lshnNE+ zY_8+L!~2(#&O)5Asz;@{T|Hi_W-){TxuWiv5WBEdSWhE#|Gq;Jkks+!qw*!ySw724 z0ueB>Ynp@C=UY{(rARt0b40K>@yP{sJ{P119g5-mRX_i2-e4TR+^;k0}P0xs}N%59@* z5gzzSNh2013e@~JDzZ30Z9s^nKX`%M_Jak03++x*7DkIOz+Z*J$`d3#LN z{^b>js@?W5a9$3ox+1TlP1N{9(4;ALzEk*(6+oXEX_(>oIS<45+q?8E6@Dqd_{CqL z_#-Ks%$fp!xu3492|RuLCKPE7rD7=CtSbuthWt||U3*_n$Zjwzr`*b5ypL1JfS)Sn z31_aCq}&>C)HCK!t7%Et+kXF^R&Ut}h|9Z}j^f3Waml(SN9qs#xnY;5u^tM9tPo5+ z2dKYi0V3RTMmXp0R*df^ZO*p{7H{HzFUyffuam-~fWPNnfji?+pU~GiS&7P~iG8N`3SZSx)V8ceC8TxO3Y>y`_mD z$xTsqdY5}o^m_2XlQwf5@h90_Qq_tp3CWIp%6xEm0r6%4wh?%bLDDMdnifCa`T_1~ z419KPc8p^$!#^R6*({HkJ&h?QO{27JEhly# zjtRD9fWNRRd$rJL1ofywKJ&{NPo&1P`{f$uM$S*B@GM{rzCv_hVtm6xo%{Zq@52M( zAR}3An1@KpD7-{h3r8GoQ&5=k_?pT7&fkxQfT;5yc6Kse(w(G1-UiXOt%@!18xuN7 zguQ`9gFa}DZAHK=6{{)LM868xwo}^Fd^W+!z<^Vw#WM~F00MzWp0AL$QB?wbyZ6f( zPnkDx3a4ZL{*?ypFi-iP^4NaKW9j2UJPOkV9DJ&)H`AuaI_D}evi3-~{!SDEa&}hg zgoyYh9U1!UtRJxyuBJ~C8rQ}>xuLL^*-IU`(Q`ttv;mE-Re?%j5ZJdi(~W8E#9W@$ zLe=XLth_H>Sz^lzLp2}*>kB@O(XG|k&p}B77#ho)@xPtg?QysfAN^glUmLz%=@*7l zdAs_9sJx$?NUg*WFE-m`kDalRpv}M<8%%EvflhCeHzLKtL;$8#E6P4CZz65XSxAAxyqbh(QnQ@>H zdB(BznmO}wW+uWt^|F}WeawO+(wEbwiwrA6!K1&;R)0Ut;}NP$&^SZ&33&M=^b;mC zq`N&WPVZX+(^bALqe+d(dtXKBE{vIwt;CDcX$ZbB2p~)1@fPI-A;wQYCh#yMM!iyX zV9jOikR=Rn$;=9L=V$ur{~=>E(9}A&%R{!AQ@l-@$R)I^|zAONy^{? zNlmfQ-h<={rC0SuKg?i`Q)Yk~K&$h!!UO#ds3?S(Ytb zRQmVKhvb?&SDu@wo_xUHVg7ecCI2|PlzXykkGuJ(NBVQ=oOGk<_8ORm`dGd_F@xS; zs6xLI$o)V=T{M201NqE}N&z8L$gXzb0(jYI3)XJu`R&v!v$u2x=1+-PA%%z1u3B__ zegC*~h(AOA4_;(Ps}QLzjf@kyKQi@Y2VcAD#$%{LdMc`m`!UF$a+;J)SR4Ce{);*~ zA6&}2@<0C*u%k~-a0>g9+-%+KK2q>CVClm`;)Z^c*q6^Hi2_w1kAMax-&$?D-h;-} z6xihv|K_?;3uVhVSdRB9S6*et$^1e)9}s}?N*mA<_QI-Sh7@i^9ap>5z$qq8OTqh^ z*i!KTOI0i`b9rtg(7RxY_kcNGMV`V!7HOfEn$_DY1mU3rd7vedz6J_yM*JL|1fk5- z!#&;I+rffFG`fXJ3rPciwSBe7p-r#(qTS3U1f2SUyjMVl8+6Jyt4nL`WhT7$3`3k^ zKmdfAC2BM3x_@4ispMxlTudnl07vBse!P#RY0fyp0(U}TmF_spV;Q>=(Zr50LR6X?%JE5|>1U#op z^o~I@HsPY+3R!JHu#<47jrw3HtzJ@DgMhf9a$C3ucw=!iO;|~PKq~r!RT0-cJv-jkM5(>qcci+ zJ?P)8;ZKXKgBVZ0Q{nbVz8RHeJ`>*XE@`b1$4x1GAsK<1Wp@+M?S3B{{mL;0;fXcpduujjIaO0Cf=jQCoI0{G&tXduNk|O-G zYQcW@$_rT1&$3vnMgP&Ki4(gGc$nyj19zbp7SyV3aEMc=jsHX}(f`D~lE1W;P|)XN zb{CpGjPBTK7q=(7P`d9JP?CT+#`s3*?msz!Bm`B9ZwXP8-z(2_BRLRWw#4S-oGVZCwZzi|E{(8(o;sgxzDk zcL!c6NIZLYo{0IzE+yhIF?`pkEpuz3ujxhv`Ct_!eMMgDw}0#9#{441-iOPUs_P<_ z9eGkXw|?^bA1=B0@D6#~c@`Ca0&lL8^rSR6;MqGO zst@kc>=)`Az_4F@4{Hi&#^lbpOnHF*7fR*#Qli!7^cz3FQ7evOUGLEYLNPZwPYiVL zdw6}gm{S@)7nzy@+l~74EP>EEj9Ugz-|@lB0IrWj)^9G%;5$S|4$^35XM{Lreus`U zW{j`Tg(isMy^l#3D+3X~7xszaji0xCgI5f78ZiwtEbrMQZhdn2_p8CNVz7H@dRpml zLq-3#hS;tN1zsvtXb2&CR7f^IYk1A0Il)4t$?T!$`Rh%$4ZXb3O zH}#kR_gVvdM=1zats>-b)6b37HM|dEY)$OQHF!(iEc&hL5*3Y(r#=C&*C)0jD>dv# zS6TWnN;@&P*P141IZS}0_KFjQ4naVX_(M8cbxgY?AzOr0_KQjg9BJJRYVR7_2Pfg)xHXcrz=Gp)!#$eec z^etVoI;UzmyCTqW*E<$@#H*Cn5-iiyh}tlNnJic@`|9CAlRKWN6Q2JgrRDI>O8Yvj zrDuDcuL{_aZlL)(w@dI;T{OCDjZDAQvD3&K+u{xP!%#KB4c8)MVnkk~5h0DaJ>RwT zlg9r1Lbc>I&mOs7nsxO51B#W?hU-y&yKw91Tds;7XzhVA!Or?YI11mCu^e-I7EWsv zl<9H<@j;}LeT*9@)m?jYMoT-Q&4eI5Xw;Nt_u%VC=ac^r^vI4rD=yWsBDX*M&hfVr z!j7Hyn#Pe6)czKk@ETyQwPA-BJE%8-(~Zt5hW@x=G7&<@4jy0RI-bYzy;DY!!b^#d z)qlSN?Wq@kB{!Q7sw->l3{flk%@oe5kcKW|UE#;-i$oP8}Bm2jWNj?6Fmt2T+I2?Pc=PxH`m_DR)y?)C4ErEHDm z(ZxvS$L;vrc~6CyGp7_IgrK(BAIZ%aqa&38RQYyT>gCn!zgUW|zQKyq=#E9$>sgFa z%l?!${>ukE`N379=zQQTExVpQ*s*jlb6jj|r=s@97ipy_#?G&eC!SXlDZFgx@)U$Z zy?Lu#sstbt9oTSE4q!wCRWpB(js7OlCbsi`$p#!5G zj3r3pRO!Q*vR&njiP|BEq_X}GEPNigQ7C&jA0S}Nn2xjg8QsTc5^a3{w?AF&ur|pl za4beJp>klWT!;`O`WloB9Y`A>xo`JAk9JRrOAVgL$d9EO2Z*dGv`qiC48#9JDH)Do zoGGOrM);TOo(x@$V!YDw|BrH^^L?6AfgQ1>h6iUXE$g^u1uY%P>j-gWanNGtz?h%| zIEh`D-cFMy8oI>mAu=R}f3#LKb~JpnQX#xV{~vk&Ke!0ia7FqL5>=~`D^~d?y@Ti+ zJ{26gC>?KZBqb>b##`tOOc?_G3Sey4N9EL;J{i0$(x}IqdC4Bov)RA+A8k1JFS)pN z`)N=iqCr|Q{saVdZ}??O-I{SF70+OWMR?%Am5vbHOhs!FWT!AbV}lvR>F609v#4@> ztL@1XhSINp3Y~2WiQ$|LK5ref3)GnZBXK@*+=jwN`>jC zsqs>xAEPhyV4Q+s9e(GxOx`D=e_FgLzYxugEL(bE7oMQu*sIjPpM2>666gF0uF1CE zFa&9BdeqkfAK~N!eX#gX!3}F%<9Fw;<;6yB^ke*XdGRHSxK%BAo#>GrFy5yXcv|?L_nNpqGnIY=dN++6j9CBW`!^doS69=v#{rGc}0_^9AmyW+TiZXCc2h?7!trSyco zX(hj?=l%8@#-ohMexy|Y?)^7XpP^Ihu!od`86oSNyEG83ImW2P$=O1%zqZEMkAF3R zFZZx-_T$S38GL8X$Kjg_kYatoZAk1T>^S_){*ir1OxFJs_Ee4z0F-m1>9JulemI4~ zV;xTqHw6J}}*TJT)?kYaoyRn=<2kJv4c5}RCyDjhm&05=1NK^D~>!Z|B*<50I zO#OzC6v&SG2-d8<@p*oOb^P!7i6tb5617aZPa)Zqqd_W*#I7< zE>2{-PS@$xYhJI(@LTWhtUkTqNUFu&;C0ZT*-0!!TbpqFC!&KWghINxlcN83rL>xI zLwIQoZmrF9!tZ;UP{#sn*XX^EDYI+1Xb#fca0chl0at*uL=m3ZWbMR}cv$N1Kag*5 zvYN>U3`|SE{wDWAj(7Y=M&~uFe z0$%=%N%?kviD&oQm6(@)B=}ki=e}7`fF5uLvdb?Q&>VNU>E98Q?{PV=0$BLc_`%*N zds@<-Y}67AO(xAf@Jx)kfa#&5{rl4kW*^XK|JW|Lhd!*9xiA-q5M2H~O!3zWcI!hD z!P@>XS!*;KAr%)4&3}JJ_BhA5<>j!qvxtH~ALEuYpzK%SUpHy4cM8{ON56>lub#c- zbb(J(sNOmqx0~uf{w`H5OSRg zU36K%$r3C>ANCXKVfA1pbx**t|<4oY^*VWhJzZ23?PfMIPx9V1jH)$pwz+$t zUA2yWhGj4bc1&|9Wl(EuU4(s&E*d5t&kCjLmeMLdm;Z{UQ}P1iy=lQzXpt34T9h!L z5Y!;j&!iv*>=tMlT-U<1z&$nD$`IwfC1FlrSGT%8U6J}Ui?uF*wVoTKPa@I?)MRMgvE$a$xp>>q=t zjBi4*d`&kgMH55AvgGzz{u75Y#}|Md!4)R31IF2M8^bZuJy(#kq8q+TcTWb+Q>wUsFWZs6iAJC9)@v;_pA2~}PW>fou&D!gY`AgDPrLbjCJ=7j{;>e#Ov zuM;)l9C!~s9iG+TbgsJhraCJW9gH|+!F1?gB))i!vEt1@U1OX1jM{-+1&RRsG&e>rD>S2ApxtEdKeR{7yN~T zFtPrF|N0eZF@YC8p79ih*7-;{{!0GS`RZkjXbncJfIcxP)c|D-nzZyTnSLxF0oLNS z!gLXFKbFRL%R30-%jFBfC(aILHlj`x@|{mhG2+SMKW`7s09NJz`*DkQ^dnr&n_;l~ zekC*f1nU5y!Q}K|f>2|0X>MS&@E+F|KfEi+qYat$e0Fw5#ggP#5#ziPF%cs^k%abV z5@0(=i)WMof?qP$ha7!Mb~*yP(i zw)+f{%K&Z-3I(G)86y&`y}Rt(4#$DHtuoqSL4wNl6s;a4?2YUe^{#P%T&>~eZ%>FR zVzBs)B6v-JD+?)|F7aF*kVl-w?w(-XBp-<^Sj*hs24)qQ{?{z+}L=1jvg z^50wME#{SWfp5Jwxlpn+IZGm=WM%^7kG0%u6anadw4edA*)#IO-!H&%Tzji=$z0Zw zzbj|>uK=U#I9GWMOVqI7VrY$rR-Ea;~Ol$K(F{Z3`+Sv1$N1@c@JSZYf;HenmNn6|Ak}w~n z`IvZ!FmBaazksoMK|-4ArCbZs7!)f=e`*yF?QQu@xEga~D9$%-1;@!1byhQQwDRZe z5`Fs@w5t4HW2T&VRCuio7JV&P%14~bVxt!?>CBrsKPHpw^H;9<%ExmpSv2TTy&N<0 zXkta$Eb#>3*@bN2u-Lb&W}ncLhHL-|=Y%&u51Vu(1qVdlM0lbJ@*u}6T5K37>-f^D zG}9{V>tmADjJ~cH`ukj86|0zGM1vcc5ogx})hn%Nhr;8_iP!-IXH7cDd!KPtgo`|4 z)eBQvX-_zI7x7zB__AMwvqi=u=N!!MF*1Kyt<4N|v+(ROKTz4%N)ds+nEnhzeuw!! zS^Pd>ILHye+_%Ag8q5Yn?8bA-4{_sIFgg*cQa1B5vc64#E+H0izwN5tv&Bn>#MIZu zK8p>~G0rMRqk_i9t?j=s_pp37!~U$8S)UGHU?IYou>bi3E@S&fox!hA*rV`GdsAV^ z5)^w0X+m^z;{sX?dcd?McUU%l$zh2z$PJV5nG%kdYVpOUR7#nA^5@(I%e^^97w^wP z^IsN$=Y(jv@PGUjXq?8xD{j=~mlXUX$rM-7NnE7X%{B8BaGL5&-OZXH5^e7=OME<( ziuPED0*^i=O^|)(G(0Dx;w>E~2T!uI&lISOIlfMFeb&Mr^cpG1_#3Rl z=5a5O45x-vPtMs_6{*d)V^~=}-un#b)lt@z35eX#>hBHDwvd+ z8eNo0N6STzhvjD+@to|(pV3r7`m(cDDF{V_XyG?AD&nAx*~3pCKFMw2peBLI@Bqls z1Oc8@{7arMj}+7);**~+E2wp*jb1*u32dh&CTNonZh+rPT$g{s4gG-$ZVQT&iiZ2f z3S_y1ZrS3LDju6j>K4^M!#X5r*5xPA4YbBfzpdsJfnw`DK@0BFj(>Z9`G9F&GGkEG zmW|Jm>;iq+P!*in!CFeMdWK?ZwqkVA$Hr$OeR-~lLf^i)oWw!VA$T4!Y!zp_@Jk;; zP?%8`grmctc8o;1&@!Wdk3Gm$&Fq@+U?I^zntXV=Y*T0_3V1^92k{;o=wz}`MwtoP?F3nqNY@b^Q`;HJADx{N=&Krv6RFKXZN9pGgu%%0dz?Okt>wnJGcznj$x}^6kO$c|vFai4!bN(w zPxjI&u0=KtFmTMBZtBVDMEUtAi69QHx;jM>fJu83LGn>U+Az^sZfGhJ-Z zBM|_0DO>plUBmuHSV5`}bo1QkCZ ziC!e^jmePG02Us98BXb(a4CWW+YfS$0JBF`G zG+ds}v?XnJR}{9wLl8e3OSj$fXSd(LQ&(2J(c?{W7Hv-KU5URvOmtx#NU6!k|VSCr#Y8hCqU^1YsZrTE$Uucr15i*a0*>CN`a&XKseuChXpbFQljOy|Wz*cbyeUghNvqr=3rs;zaQ6L&} zY&c#JlRHqIJF}dIZ*OZ<>FGB|{6tEC_xQ(JU{>*VmVB%t{;)rmcovy0=sE!~UD!8F z3YXAF4QpD+N<~1v!K}QcSU$5@YOIR5NIQfeAU=9ukv0zFnGRKj0UOo81vd*|Z%L4+zV62#Yxf92y^ zP@#1w3xLzq`W8-MF6YKu(iPF<$AkjHZK>^~h6^Yd9xKDA{UJ?a2gcn;VG*GGW@_oE z^n^b)r`&&<*4|i1Wvzugu#jGehPNeTYP^tsYx){c?!0M!o2xQq#uRF6@>_Uu31l{R zgt^tp?~JbBfF<&w3G7I;>2z?NP`(vi5_nbHLigIq~ znUkaMp4GSn>k!ULozRgh+jk~*;7^NyYsvYWaw`LVC8mY2(XhId{?gK@Iga;ISb(5> zrm-$+_zSj~aMU4R_TKcb24|*3%CM}zJHoPUXN^Ceuk~*1(j;iVk@@FNI*uZI1>(S- zwYao`l6jJkai@Vz`I~?pd+P=Xk*+2BIzJ?tmWWMUN4g90@1>bLmH$;1I+WTt)ny## z?sIye1QL^W#RsMquadW08mGV?exA_oFzQ93?TL!@QhU|D7o()`KAPGKG@n48017@+ zOY5Iytb^kaeD5@*v%Eg7QW)@UNB0D2W(9NM4z&$?bM7wPajk zcf25rFV-1N6ijq4`Spy-eEIt4sVUtm@N(uvlTgwhG)1gCX`ET^$+H-BxO$CZs9Jee z)B)6wL6bP4w>^t!_ zY(iyaS#55z@9|E}J7DWkmGVf%L7`|j`K(N#x@R;%2U73++Z%gByK@1DPQs79Fl(r| z-jq6PJYDhL+jnB$JWv9uJ@ADTuI;df@JH+UMk?Qq#au?`5URZ&U6b&-v8TltX9rMl z&R6&1BUG0s>byPp8=LLD#}c_U$z9n`dYt*(%Dvj?7>m+1ptEa$11(i`sa1Ikgt2LF zt=7S;1+UOzQ(=BmmJ>XZG&6=Yg#3(CXc7IK(53&jvISl6rEE~2zkC@IZz~fIX9a)j z$3!9DrPlFMU`y3;@ZaDQ+bgp7Gaw^+lJ##h;`_yona{hf9&6D}jx8rH9}t z6BGNJ;DoJ3bCoSFoEb-cf~RKmpf{sflEYFSO<@)c&k9zN6%XcnTDx7yNmToA9RTa2 z_#ZbuX}376uG55%)3*P(=8bIKs4fA^X0*FMS#6asI^6}Et_`^(Mx z{>gIZjB*G`CQ{Oww=QN>}nI%t}(P=27!Rn$C+ z$CUq-;a7J|bhlz68MU5+E@L+?*urm8xN>Pgv`PHaUMZjV$WgI0@5}!PwMxp)jevU%O?VrR$FhXn6ym=-|&?wP5;P1;d%SQfQi+zC z%a+#9k1uaOrpiJ$e(|nR{BD)6XU6@WmwCVOKHo?V`2y`nKw>p5bZ()CTDbc2P8~$b z!!iyc#@iHR{iLg&!N>2i_(qxiO&`d2 zO-wL$a5?Xm^Suel$8fd3P0gRtYYaF>w)2Xb-!yFS`;n}b&YU$TX|>2`11bhqwP`QF zXKEN3-KT~$F6;DmTmEh?XRIU(df7|}LFDGHb@!^uX$bTLb@{Fx+Ndc|JgmWZ zuI=V%9E&zAB_Xf1XjKbI+yZ}ctLY2{@)4I;2gS-m78vbOQHy4qa}nMRpP${Cxu2&>lNn+DiF=2~tx_|Xs3 z9t~Og_b?jq-D{yoJ|_i*(5}Vu9cVhxEAZY4D>!&uvZidaD)zV&HrpGt*jTr6`(=j| zo(hrwE>uryQ^mda6H{F*T#FuL{UQ$f)J9bRLJ9sOg;PhhnKv4Vt(y>$nfel&Eu!m+ z9JN9JQ2Tq06ve)|-N-~3$45}2&T1~dsXi9trUq`hy>wXkxJ~3IfeDUK*t%8d-tfA| zik&Ct(YDe0!;+cMX;#|RcT3prvG@3~$cNf09Ne$Z_&Yy8$Hy?hoT4L9K{o-nKamdd6aZwg4DAo^)a}MCQhM~aJ&Y3p`e`v& zSM_vA^+ZJbY7N$w%NdqJE-EIrzF9i@5kSr*6pJ5*)vzG7iL>z?TKC|FMaphJ6@JbZ z@AlrKspK={HRi_8qH+sU7(MeDamgA<_Fy@+88HYoPcD@7nHbi&^X4KU z&x^h&!h&Iv<&{7j5yx%1VI4)4;0^J2myQ?~r)00X=3VsgFz11W73|1lqCM=6O~*Lp zr~xu6zr6%LKYRIVj1(=|U&+hgi$cQk&{r2Mig?s$fn)ZO&mY_o(pxwPM568Kp8-n=E*o#-v7I;57%KpN;N`hjzK*a|pu7O&E80 zOnxB!M*wI6FB^+(X>lKyMM5!Gm83p@HlSY^JTyPhF(iP#GAv~{Y;AL=w?5LM7Vg%V63cA?+OzlyK-Nu$18;|5`J>ZcTK-)PAX!5QzM&j zG&b*LA;+x^;LgA{7ME4jclFUp>%kky15iZJ;IeW~PtT5da07NJ4pKih%bQ}H?=K#( za?HeEd2pxS=FAY&NDq^uHmDDO1|Hy`I$Fg<<`{Eo@G6Dcyn9D_0c?EtE(fOqyGw4K z@v~}ihm11hr$MJ`E(LUq8C9{LpM>SkW-338J*@C&@F`E;r-!_}7UbSK)OF$z5h+@zOxZ}D!k zu}gCQ{vpyYhwsY}cX7Bx9+`a|t8DWKo(SGBRNN{P1nVsMX$uPpnzixP%S$tCDIgQz zJmDz;?ZS_6#H(D2vc9T%$pZ>X(V84#l zl-fI70ehrgV!40adW@5UVPj;i)n1i)fc1_U83|TA>h{w!-e#fA?0DNjKlK|B%|<-1 z`yEatuC|d9OT^ku!EbIcZo|hfnC$fMmDQjYl9pf2;JT2FHk^p$VqIE9WB_tk2BVlU zydQN9rKocTXAO}_Xe;MYhJA)85)YU__?Y?msGZE-oa>GUojI~j@^h;LPOg0X+&Gr_ zd4#|606)Xm2wxbWd0AU>x*I2JlGA&Cl14t9e)X)x)ivGN3B-x^gaOI8x72*nJle^N zQ7s>MxWNLr^a(u+oU6C38f;C^ifzZo`pohgC|s@oLv~edbInAdD)KwO|3{rk#o=)+ zgev!shh4Y*yU_g2cWlV@Hlr4&;b!rOx-hhHSP`NnGl{92Td)Oh@z;&!!)ne+5FoVH z`k}*`p}$*hYvDLY3a5nA{A$D319=2u$W^OgM`O=V#2i_i`Pk9W-Mc8kM;RaoK9Z$r0*chpHG4v3#bad@C4SdVKK^)1gub9C8M&2{#8O zJUhSXdH19B60)%uN*k`PNjexyTGQ{t;uhHq)-X^I()rW?noOC&wH&`Bk5!;#HUG zJT885In2YTF34P-F?iAFGhM^mmGk)d>$$chS&IdMzb=~A24=0s>-kC1=#O}Kzi0Vs z><#RK3nc17wzhZjClyB>Y?>X4C#qu852okL_2K%O^bXE=r4DJn29f^Ck)MBeedG-J zSav4a_+*Kn+;!*RF4U4TAQ>P#@3q*zg~h!FJV@Z_cqXAX_ja)I0g)1012r_+T&Ukv zYZeu`q!MJduUj`{5?{0oAARK(O}^U;bD&^$ z9x)iBh~}s#4Z8wy3$0}$5*i3NNtLd|VZv{19iYr8u^?m5XO%`60K3Vpx?j;yGSWcUhXOC-65I^Eo zbyo;r%)Z>9eb;y~bD$Ol5L^!7mn*CFs$gcEz!JEThH&4}V<;@k%WBce>IzF@oy``e zB>3J>*a}oj#vha}ItgD3juK~fxeufyOw1B>T={E$sebZZ{BZDVSuGSFQ+!~jhczOA zkzO8=iF_YPjr$=TQB!Do$;kd88!BFpm%+9IMTJ3%}RhoSSwld{Moh+b$e(ox?BarNqK zC?VM-j%&AftU6bGYxu~OH!i`}+pQ7aF2>y1&I#;IN*8VxvR$>Ej=n@rcyhV3!aw1% zZZC+o3TwnWj28m~>Usj_R(UU94L_9xpUKzKxPJJupXS#^Ku8dt>@T@yQstyI8cCh|Td3RG=IO8xx@K^`2mSwupji#c)Q z*o}VxO)CrzrrKf*?h|~$u1+eKX1BlCrx^hYy~`nsH%->oW}n}|YRSY4P%iSksysUb zGAWiySanqA5k)wEtOHIIKPg}RkOoyS)_Yxl+DJtUp=F2>ti&?YgeYNC7;DzeN=#K4@nwRlizFvA9p^0U0n;S>ut5~+PRBqpF zpx4K<3befF$v!&!tNxuM`{`g*YAw)H$zdzg#ni@=%(wr{1UaeXc@EvGERN7(>U6&& z>=x;XL`~EkJzAo8t`cn`B^h7DS(1hCBsiv)!iGb&-~0D&A%u?rZZh{%7?F%4{`4F} zArSLeEE-$VhOU~Rxa>#erbC^Hk8ZLp#xyHnH%d^}D%s{)Fv=foVMlIesCUwOEzwrQ z4&yk2&oWsVR2-AvGlybbJTw$BsXtHZ3LRzEu?CCsE&Biyc_YT31MJl@G50_~AD+7( zl4*G?*xkLq2*9`;YVuu?h7Lecd0uw@R^u0V)_;u1or%Un&WrSAM8qsW9_r)oJ`71jD#zUQ9)R_>`tDk3XOilTPyTtK(w(YX9of! ztyXl^=l(NG*&s~mLo4%uR4H_4Oc{FD`}>`R&o_=hVo6W-qHr~z;y&y?623o7bU*yj)mCscu_?YBjGGQ<&)paXeI%ipEBL$ZddCB9 zXGrPtC0(Hc<}__>D!6)hja905kxvEOL*U#PLG3aTKVE0U_>FMF(&CL_9$btWQiaoc zm|9Nmq>*1pL@}dj6GkF5Lk>qCX8#I-)P`IqDn=p*u4OJh`0L_NU<)U02&*z<&Ywwx z&Hp%<-!vYBv)`FZKK00nqLFuP6I~3sZpt`5eto=~445$4f6KM2kweYl!O3Fbg4(I~ zs(sJ;!Yq5kz{KH{n0xPAo7&(eqn zXomlo!o^TqUU*4jg=t>m?nMcABvbd#y_*s!p)D!{0kQ5xIL+6i-zv9$FKF|6?;x&j zN#VQ>9)8x3aQm-d%|d{eNrik+H7%_+y4e}wR9C=6yto@r2zR!TZ8jbM^-SjZRE7K- z()Liz7w)cN&_%DCUSi#;kP03?f>=xtg?hGS{C4R@<;6+fDypeq^?)!W8ADtiQB_EQ zq(L4r>N`qEKa^e<94>|2XY ziy8VHwX_kep*(9wvn(SpFLy}1M+iF1=n3^iZuyYZVhAK{vqH@q3koj|X#37jyg#ik zvw~Gk$2y;EGND#^wcw3rpzJS7Mb=|8Gjc|&h3=ZK|Cu;R{!}-w$$5w_w|1=0wh`_ zI1iv>klqHdMh3e89A5O)45uyhiKTB5z{gG8x?*NvI9Jjf8ce0tG=ZZa4Cy=|J||rD zho^)H21UrFx5F-{`!A>=u-a6Z|Iju+c{~FB83Fg@ziK(mB^?{8h`Osn@=7Z#_*jIm z-|z3w16&c?*(PW$g|&d$Y*5^>t9ILt<*Sz4&Mcj!43wRv?-D>`Zam_S3j&4{06Ug6 zV>(v=wIXW(RY5KnsY^@&B{?XFR=TYpsmU51WsHxEjSm&$_y89D!>6)fMR50(cm#SG zf%SK+ueEW_uu$2N3Zv@`c&*d+A?PI4-PKc%xnAypuRa9?3Iz6A=mUbANv>%t6xR$< zls{EC<>aLQNb#WW62R`isX|k2HL8MYfLV8C4Xb5sO>!|9icmulBMSqI*oc8nQ9Nma zpee6n9?IlVKnKpC150xi)zMC2Abk@afj>f^@s{+50k;j_DyS87F;9FpEa=%{6`SiL(>(1@BqRFQgi$WUmX<0o%p%axEKHrk zFvCJD1X&xz#in+XIXx)y`=&LWd^>#xf%VH8FE*^2P1!k;t|D<|FY9OZnZA2Nx`jX@ z9YJV^$QK#&MTv)46&_yr#FR7rV+-h$`m3D5h6w=*J40l%Ss0VWaGJ!|$7Y3EbR=K= zvvV%$*B6h#fI{Hi+qcgNnfa1nuY+(YsY_k*_5syN-Ppb}dqo)sniUQBf*MplsTve${4e*8SB#-P3JM zezeWZ&$QX}*Ywx?jM+$#*~~~KtC<>gktKDps#F9?un4Xo31UeQTkiR`h`2s>JR%Ya z5L+fP!2}Q&7WN+Uy@hqt~MjNgk z2kjk_${#}X4+OF+BSuvA$|y%Ef#pbmw9)6GIOf&=NHqMLYO^;}8i3`9u>5W*fjcCD zcmA7qhU1`b6sbNa;(y-(zo)>qoZ`9U{JBH-;odoov;p4{$cJ9>mu*e|QbRXc8i2LD z!|Zmp@j!$zghp5~4~L*5NNb9Lw&Frv(GQO{JnBfWe}4)b@>bDLZliMCw-R{s#SgZs z`kfBpJ}7=0g5QGb*nKOI^1@d~0)kHf{CS%C|0B`fRA~TKN37RA3hAxG#%KgTio{n{ zTor)^NF_z!QvrHV*L6YA?rLui8!B_SfF6z=OYzd-bS0gWfR@4E z^?lp!hS^O3`l={?!p8EY0a&eD_QrT0s=a>HTr-OOp!#r7H62qY+nvgG)x2^u>(QD( zG=ZWc;#z<%cnI;hNqC(W)md?FCJurb#GM(`7g{(yn&O3VdIcpkv|9IU9UtfI-~aII zo^2kTvif(g2p&?s?f%$bx?)##a5aIe2&}Zs34GThZF%@Mi6yT;BoqXF4ne~K?#rq~ zQ-#I~?J3kNluvK|%Ku;MNfyqbB5;vF@{Kd_9S`5(F%;l&mrl*W=FNTWT51mB0MB#B z3eWTNeR7?j4iQ%pY4aFizVZM0C20cN_nPNk&NH<1JV7>RlM#>4>$)@JJlHP)@^grg zKEE8RB7x)MV^N&$@QLhH_&p+c0MN}O>r!CYDMAQBC>#Xd1AK&8sh5bbi49s%ZA0Xu zC?>q%jEMgi91kkGey3bA-yKC^H~e4c}Fy^C^<~)Qo^B;{4V3 z{51^#4N}nL79h-DX(-~!#5OYoxneI)N2Sg4bMDbdc0Dv6>Abh|^ObYBoe|{E$aYQAi&GJ zjE_5f{ZfQ&JHtw}@Ib2ReueB8=wqV(afOUQP|Mp`-sn^cRS%IAiVN1;Q*c66f9*ux zNz(KLD%Dw_HHVp!$xp^s<6 zXrywF##J*fgrz$p=&N}QZSFFB7V{>Q0X zIA-~kyHo;ifA6E;SJguRiQf$R;kG*IpG%ZqV_yx8{dLrKR$+>%;?O69erab4-yoD&Z8e=tr--Mr6}>6unKXljJP-~BsBWpC zx;3)b%9h9sKKa45(O2_Yo*8O&iVuKcx^c@dl|xA;PW-h~+H0)6=}LsFC@4HG@A%7)CK zWd=5raRF}?9srL+17*iIqnTc5uvY0g7GO@HpNlv)kT0nqZcDD8{}03AT>GHFAM_%R zL2)3j)~w{Kwa}Ij;8NfwgK3}HZ!CpDLPQ3o1)v4NIjFv?z%d7XKXLK__Wy^^Z+6J? z^Sf69Z@>7_AF0YIfCVb!W=3#Wt#ps;qqWxLdR`+Hg z5;a9x-(5v*chz3&4^(acxwl)Gd#i=`LX3EdEAq>$dB!2aA$kiT`VaQm7W6x`PxKbg z(LT|&^A>|EeV(hbA+&4fW>8iUcUUTE+8Tu^=ia3l@%aR;k28bRyBKE}{*w5D#YP%g zY=nlD9#VZz)w~NDN`uRU@s>PJ(aWH+?wQO`bx!rrIoUPCwfaL^5IqZkTYPiHwE8o+ z`;YkX|5AlJQ>&!W*0d+zg6KEJ;}I3?2C#M2E>J*7h;;!|fF1{MT%jL}1Rpxp6W03D zV-^*(fJOe824upojfY-C)+$l}{Clct#0n#tJ=uYCmf1F&U6PJhi3M8P1G&s^Z zQmyz()l2OU75dL|2q;$*t1~HEF^^>UdjFGzaQaM1S!N9bt{1ryjnO&XHAUC@pkr{& z)nlmvpkm|7obUx-3Dr<(89pBo3JGnap|Fe{8k&ioc>pv3#p;)HTPp)V51@#1@Om4M z)zN&kZg3IL%lXEWX%=kmdJ9++%a1lhsN@iiDR96PbnDX&I-mCpGUH~-+=&^n#(_RG zAFG3261}6K5##~s%vhMgn@ueaz;kmB7W8fe=5f(*bw2Cbdm6o^kk@TK1?-kM3y~S9 zvKFZv%a*`<|NX8I*yX)EE~@|7m>M(Xe+P!l^9BlVPT_wA=&!`dM@cGYa4|fCF?gJZ z$Mf_YUe+>e=nmYHRXW8RfA&TcoDUjxKibzyTYn&eKLzAFt91Cq!*Hd`;4g9Z#-nwM z0r0&+8L^szN@fzv0xF;vDxw=104h%^bTb@Oh!e5l=0$+jaQ!Vg)=uLy8X6|gz;5UB z%+PQ}O=GcU2H<>Rt9&YC#y$p~YhvK(Mi$&%@HU?ee(Bl&iO}eFuI3CZuB*p|*Y0#3l4O&+A4KByBB@i7OKj@J@4b`Us9L%@IvJbSf9lER^fS46O z0ndPrp7tUWqB;iZGMt_8%7Zmj34d&_m=Y?obSxGnuvPHvKP+J87xM<67?!`}Nm}Xw@VkZb zEHG@}@{4f=DqSkW%2Ry7mZ*2p_&;W zZdA~jVvaL7E9UwM=DE;Y;(ql#H8Tc9dMPudZ0>I?AY@!&LzanTp4F3mcIzzIeKA4z zY-SiO@SUfp79K#fAvB}Z*jG2%^Z4{e=8m>7|Mr5-Yn2A?B7?s@MjcB7umY)u$Nt@S zy~l5f;5miv6bSj*?^JJA{sb8tNFc=i(ITcN&~pszsLFc+ydQXfqUUe{j~%>Nri`xO zCVvIHkO8#O*BWv`IOG(+CyGCU)d8&T;A)fb1R;=UD6|zZSFV;Xzu*m$u&kAeVCwJY zF#Y$lwkoz1#U;Vcr3QdlwFPv!YRxx#5*7ns%rkNpc#bxPXg<-0{wMmftecuMPhsk{ zIZXX@){ehc27s}L!sDs$u9z3Z)%xt43z&POW%FLFTgZ#nY*imQs}bM|of%J*9pfnU zR%q;|emaM#*JcgwvB0&(FKXy}sA}E zFQKuW{@EO+|LeSY4y!b1-aTuP2>6u-;8vxoDmeU-!=7OmRL8yt;15*r4G|1MF}!Li zdbc{CrQcIsfXJlv{#5xu;6G5vrxM6nr*gI@ejbr;p;v9AG7{r|pNvbdU?qZH+kIaD z#_RRk#*yJP^&_E#zYFLe0{G@?owW$aQt=Hu(`U-8z_eM2l;$apT#a&t&a4_!KtG!| zNP;W+rC9V82B4MZxHtotOd-8?;MfAS%+z_RVXzbNbqRr~pUh(N)j4R_n}@*QY!L)z zaC+hW4i?^TX93{ZtI|O0SsJK8JA}0M)y%M59Ry|#!N615byv4V7C2^RPN8J^eafK- zU|%hFdJ6;3Hf;V83+RSJE0~+)-2cn01(O?()Xb~k@oU>Ew&I_Adja$Bwhhl``slUr z{GdOtsd%_*X`}oIlZL;xK*i=+4E}$BAi1dXvW_MH@AV*PL(x{j1yQ{S#d#5#@QSm9h*(1qcsbjxgfp1iGJ|LT`KmrqYj92X z-63B;bgJ&=Cr6{GIwC247XtPGAPL;<4_nD*^a@n4O#K{uu3@YG#hm=f)D$cs46bqs zbujgk8&}7KMtZCc&eg|C3;?$F{`t`(15*Ua(uZjr~oq))@@Hi?6 z-w&hYY^NHY#RKD=^)vBuCX~RbL#OIzd(#`F=QadE_)i4#BA~1Dj4|z>)u(l5E7aj{ zH!<|>ehb*PnQ?NmXN67i`Pe?Ef#7PIx$X-ewimxcto*hNz(BAFkz@+KYB~H|&1v7`U0I;oupJ`Zdw+MjJ6G)~KTbUE)V4&0jx~F;u=`c%&TM-Cekq5A7 z0H{D~rcliQ{AwOEzsd|iK?6}30D28Z!N4sq7+V^QHrj=pZoyJ2>&_~WuVnxRzMgqL zJcp67`4t#|JvEb|8Gw0j9>ny|=TP5OMIQspgwIUY0p{OpTYSI_Kv83`s*Cv*J+Y+$ zShmVQVRpd0(e8x?nDBVz-3rqZ68RnHm(bTP?E*)l@7 zVlcQYWHqgdRrWHjz?J=VA)v2k9zao)W#?Xw2e8xt%=yI_0u?`HO2beZfP3v1{@Hk~ zp}oPRTNzB#Wc?d}Ys;UxWHSn#5s_0_WidVxRuwyZ7Hh=nz#e?ug?iTK_YgMYtW()b z%p6#KXY^isPHy9RmSzEkir>>!%mO0T&8(Eg44WLnNG8)PI60LXw$80G8d-X1byJj) zl`VKP05iYLQbLPLSz`4?B`|a8v*M`h1c7sS!(spr*Nu9?s&IFbBEe-i{Lkl+7BPTL zmtz1_?1X39%+JqxfEX)SGyuf^>lv>Pae8iC-Cr{Z{7l0FxlBhTCl3S6JTEuPbYku0 zbyny!pauC|5vV5AH2rsTnELxUTlq6aKpC4Cvmr$5!;ZxV%(#*Hle|LLh%wMZGaBn0 z`?q{pPUQystng7|ajA!7KvWq7zEvq68z;X{6Vj%IRPx3~nRD7$Rq7Dwn1h_cIZN>@uX`-PTbB!?2>E1Wa3LCxGMBz)X_Pn20@|8o+K>U1 z!RMKu&Dk{;R1nu%>R1r?@jg38K_Ex3#L_^2I&07w<0dq;MIf7%!i;Uqy|sXt1aH%+ zDfO!dm4C6183K}^deU;Rc3@S5z?bU)$~4er{7`i~#CxbAM9sw(1ZJ83s-@^HVz{E`1rR+9Ef0Ny_O5o9kB)x_w z6||(QRtd~iG^_gAuKk=<-O>Xw1$_-)*J3ARKYg;#m`7Q~OL_^L`>V_X zs#q2f4L~ig9%h>8!nD`o*=CIge#2tdG_fQ$U%KH2>>1=6~I~X>W#QJegJr zERdF}mX*M_EVv~N-UIah1aOC-_$I^(z^c~h6ME;ooFXW#3 zioA6Tj*|SX;V|^ACI-LRpVL0%-Lj0hEqlK>a{gMvM&=0&1r`g)s#06%5;8iU*f9$O zz(y$y78|ug9yn&;wkUKe_-^QRP)U-unJZjEI;?Uv1^*_?S=O);cq+B5qbz`%1#)Q! zn4?ccOLDp*5N_U(vJ#l^Qr2&PMP7t>IDd^{0cl?E>_21yY$KRsWi@$*2y;DBGY^ZD z5k+-0VJ7k=6}o-M&eOkG#4p;jvPiR%YSo9*`!(jnq0a{+cjzQ!eV()<|WiJBggaBt# zm9y|MDP^ZH-|gTV|B>_*WsKl9ZcD}nieP*FcrYI(f2@!n2;?8%4jZWD#}gtM3NiGJ zCI-LJw3WLBRY^&Z!xC2%C*@f+WWmf7X3aWbwLb2m^)VG?&kDn+s0sr>WyuuM-ua9^ zny<`v&w31Gm9A8B)`83#y@XcWR8$RHD(Yulc&sn$ z8&Gf<5pp@*%b>4RExV}5N}_V7XTm}{uI#y@r)Si%?5IxG%w{;W&-+<$_Ef`Ulq_UC z|5hM(ylWKFcKog`c0Z%>DB=tJjNhSm!Q!`t_pVLGw~|LqAZ)Bj*!PmElx(0Y5n}kx zzxypO_#Lq{P~8qE+n{%h3SuQwUim(xoN$&-IwQaY1fMJLxhOst_>)PB3y9ntz-nVn z(5t3sw^KwL5)3S)xHOUCnXM_LE^188HA1+Y&f1#htjb`I5v6B;7OG`GfR)HJ zdiUQy=~I7DoIIrh62d*Tx-`%$nbn%@L(M?;K&~8SpfV*+CIQX70>v~0Gf>P5DQ3Zj z_A(m*N1c1h`BUi{!i75!6DeAlV#6GbCyFu1(I)hn}CNMyzo zMbZ=_QOv#5GT6iL^qDKE6)dmbWzYxNGP#oF%H1zyZ4p@+Jo{G5lxAT7EcZU|Z)-R@ z8_F}^ByX))G+WOomsxL+DO;n0KHbaOL@s1;g|+ektRDcYhC{JHvtjO!)Jy?07QpK+ zjF@HWFkI@yj1rZ;6^^mXSw}4^icMkYIgq`R`xUhaMXOAsgkb9JSmyB*$F?58c})Nf z1_ROTXPi-Wz>KW*Fd!tAx3j!nKjY;+4R#503i;ex&O*zMV9OPtegD0GyCsrft50zN zsw~<6CxGz*-FqXeF3t#~tiO{rvd>-_Kz6dAEGko(V%$Ik1`+xEHAwV)Hw-V}zQ%xKYag#f9m1?2*C4U>PQYZBr3PkTJ(yuSnA?K+?pORu}*((Sj{B>notyO5ZveNY)yXJ%TSKi@{k!9JcbG z%De^c&sFxC8Gwm6pARyqW@|=?ZP3fZS;g^E7ps`QHF9wot7j4CXi-5Q&!8EL7qEYC z-nD@lNQ`w5)?q-~=pi1gE*c2y4@mJWX_!NggYqy~?9;BbI<+=#46|lGN-C@ zqPPSn7XZB|ii;4v=pmQH%akCUf=X9{r~^&Av1$(*lG>VahaQ@>F3z3n;m3pBdzPq< zairt_s)F7q6?p~iUKM>(0i;q}DkiQ(=a06`3$WEFA&_h2rW3pGdn5}?a^Iq-tpz5Jw#)!DN$mDy z!|?ALjluvB9x^WdGYp1itsR%fALwZi2C;qx`NoyF^$U2vZ3>qixUT34yp#-XUzSP3 zR90&;lQ(N2oatTB!gAGq?ZR$g`i?-} zW^z|)09GPd)&vBtYOU9|F_z?@I6R@yCj|1CD)z4Akaz7qMa8jI9ZMTfrkL3)A229` z%DO;qA~D!Vro8C1h?|D@GX@tqnQ=at>4uob1g7uVj3WJu04Lt-ug}N*sdEF~`$0Gv zP_Kh37<4N9|B$L5`ppk^>^^v6Y|jH<3~k#!*{p1xZbsE!utsoc1tr(&eC zvCNdB7cW<@*C>7>q+!_iSe7nn*)T;cfUpfA8wPY)Rm&d3HyB0FUuL&3^Cy}21|eN- zd`vOtGzvxFn5*TCOaF4C79M9&;WEpK*JiC4BU{^ul>Se&L|MNJW|KQH~W$;OM_@RKjSNN3fGcVXFEah&%(22x3`5Ea$kj zrtmAC#Jb;+eG6iE(A_+zz&QxBiEu$xFTja;3nFsCIX&O2rspy5dq``FCWucc(!T6h zmdq>Sref28;?yaiJE+)xNzoh4K5tJbp4qB+Etkpj`xS=|1BVV|pT7d&<(D&G{pyS* zHG~&<|f-wM&ObF^*v;S8v2~Lk@ouI=R!MQ;}G%vs=AY2dx zEx~l3AZ!ap>uljusYrLkiyKkFD7#$= zhrSp_v$Jdj$dn=j!An=@%swfU+70uz$RNs=g(Q))Ez2lk4S*>`D;~?ehgHh|vb4y> zb7t>3jHiDt&G~e4$R)o`MXIT#yISM*z?65<;HC(;UW92jUBxJn;v5ZZytgat)}R~ zqh3$Zz2Gs>%rlezGYwOwwy6A%{8@<6tpR4|15`IUwA%qHaOideMB)&@A+E4(R)`8h zgc8Ds5qfD9g+ZhN*!wSnx=0frA<&2+(EM+86|Fc39fD{kk`vc9KEUoJQJ| zRwS0bXtWVjh+Y?a39rTjR0L8@0q0Fuj1nQIsj&R{t2&dJJU>!C}?Ow)*F_Ia*f|ujI0%C$Y-1yw-dadQwz= zs184b`svaD+|E<0;||9!MZ|P#L9#JPb(;da#N+D_`I;(r!l56Ef!jIFUA}J?4HU_$ zju|`_N!XA&3nq(&&{&jWO{xWnhs=s7V+JfhTOf?Yx&(-8L44b*wyknmeH&idkf0?V z9R%8u03D=AcpPy_++|IbgfY6U1Wprp-@|CVi`_4G7yBg>n?LbN6_?soI9Gv}5Y@gA znncy88>$Z@RfGr-DuOC}Qd9PT@LGo{c2`%Cx>Hl~bp)=asqceG9ne0g#f64N_#8;2 z@D->q;z*ET>6ZOXHQYGUaGPfuZuj{CdG7cYJooVy3@@E``ye- zSt=`Y67y3PM(1Yx-{dNbhCF7l^7*c*EU!JEPXYXS5AmN%PbW(QaO;oejlX$pyjhRq z!9;bVui&7-9aP`}QEXPoW{9$9a3il5DCK@*X)YL*HLDdB?aUjXqR)7Y7+-*BNBCY{ z_BYXv1(~5;GcKZuXLYj=xYAFM(gUIK@v$Hz>leL>{3q=MA{9ka;R+t6>@D{`giAxm zS5w#$D6|SOkB-&fH8ulMj~bjT{y+2jtVvK^ftmmVW(0)yUjstB6QUlBIGBcGH2>W%pS;G)#vG_rrg>0Bkzrz zm?uHSPY8%*sao_sb@V)n9;hCwd{6$P6e^hk5G5EC*p?}0XVf0THK@P*p1c4aA;gq8 zzt1>NNbi8@;si|inRyFYWq7gCV9;1(#ay>Q8&Zt}aN9i7z;}-Az<1u?fvr;wRO8V8 zUXD@%%ap(cC>V1)=GFhG)9e1tOwh;T&T_1}1jrk-XV{@KvLgs9Pl_tNfybeE9HQGZ zMPmvlcLY~`2IT?o5ebaW*YVwVcjAS2cVg$oe)M-LXsjR@e2<8uyo{Ag;8TcvBG7kI zbw6#m^tF9|wXX~UuUwut*mHc`VgG)?lkW{jNxH*BcQ}vB=;^jftn*;`1Reb&UW_<0F&De8p2wSEa*fc{lu^goYmL-9=n8OCaTkyf#shfWL z*}s04v9)rnfds^&RV?}mN9*XKFY?&zQ@_PQAM~P6i{cptHUj8}pl=Q4P#*FgkN{IZ z_njHVqZ1=|WMTvlPYjzOC`T!QWl2Ers;K+~D!-B-IB_OUPyF7G_Lh~v%M#-4eEF^M zp;|Q_Ok%fFoIdS=XT-@?c-^Ri5eVw=%FGdZ134?m?VPaO_g;`dEe^5$QWM)Io7jJP z1D^V943C}K0OtjPiiI!AQA*%C5@2ksmnECx{}l~>~w(KHq2oVWx#L5KMTel9U-i z>-y$>wUe6^$O$rkLiJUjx}QAtqlez-l;}HVujRP&60qhnuL$0m-vFs^3M1X(Q{C-U zcB|7ZfQ&&gmNAUVu+~~C zwUZ)pL_OXVhoe2`j(+|Be(2QF@0JGOt9f=Z5`q)sRm^qjs0MxL$w1`N0q@;b759KZ z_aMs}dI*qB#vYk%fv^0=tiK5`1;q>G zeS!WM>V7PcGd>DVKlOh-FkKpe^>@R7qIRHv<5-yDK~3aAak5WE_ZhcPMkmpqSD03o zQ&hAbFSnf2@+H8O(2cWw*gVz1v!8CV)KFFmN2x=Uu(YHc_qzmGs;F68S8{2+t?GUl zxXKS>bm!*gD)TSA_5iDa7f1Qbtd}RoY6p%9_Uvh*BBQ7TBSB0G3E3>rEqUF*HbD6| zdIan}K<*e)7L<{|^>QEAa30JEBJR(C@KYzoaPYG+>^VOO7K@F{)!@pEpf!~KU2|w= z{hUzXGl+XTQ2ALH*M64hWOuUnME8Z)$h}n>fc1MfNibIgiAhct)vM5SV<7sd2D(qY zJgS0yB49I`D#SQx%1Ge)y`!r(Gp2kxg#~^eJGlXmpW0}30S{al#P0KhB}dSzN&0R+ zkhCEBOQ`#Wz#nx!eDCqbp7&lk@QS`X{<0+wmj>W&xxWSr{gy-H!~lGCN01~tRdlBd zWT&QVM(>6oIxLDoCE-}Mu@?ae%}S$ix7_Dt&XZ(tJ1-8{_Taf8JbHQrkDeJtqZ@%< zLX?ya;W9;fFMNGLRoR!D4PRbY(Vq+OfhZ;p{_v4A*So+H0$R_vzQ`6jfeNO&{Ro0) z6v%)I1~l~}3fbIOZM{)BSZxg0rglTolK>_+N^XU-S^4s&_WdKl$U$WY@jsC=I~f_LwkM@Etg8 zY1N_C-GSE!6xb_@N4UXZSXG7rr6DL{1O?}Oxiq}n?)OdRyJfn8r#{_;r$5_d0pabF zO^nXfEgryX;qnK5kKOR4_`Qf%W6QOk8pomf4ixVM;@;{xef!zJe&piKuD*OeZYH7i z_IcqI93P1=H#v$LMndm5s!PXQicJb`vI!0wvlfHcki$dFAS!bP*W3NP&G`(pD%f#p z06Q-ATRdRj#0Yj>96(<;vaReLaGL^N-@A7KP|05e5dL z24H>P;Ol#C`=Jf0(l6kdlj-pm_5XzvU1#05+GGX z&1fM)%M2n-#QxKx7@4nGc2F4)xTkLS)fY3T04bi2E0j#1KlioD+dWizr}6XNONU=# z*S#B#(g55{LU+^Wq?&m5-;PznV9clKR)yP{#Rp^)#5{sgwk%XZU104B>+D*!q{xg7 zOv-T=Nx&LP-n_D7F@a`W9Uf1@-2%aPXI@ZF>Tx`8z6yBsj~{pxiP8VssqlX@8w=g0U8!I(nF zL}d`d?^qkd@|n0B?(>p47OXDWs=sD55s#i8HTF$`Y$rSHwIxcsr-OhWg<=O6#eDrWj>sD=Y@;jX~@-3r|$BD>Fu#%uD-FO(q;|LM^Xhnr>P&=YwFU`C zBB!GY8Bt`fj14%&u!0_fvbJClkbYJ4i|;ou6Lt!*M))B1Lp_Z zd%qY?9y~YfA3QgRdM9l5#bF~%UD<(d9pA&NrbcQ971bGtFxB&{6MYZj-b>*>hJ+^v zVm-C@M|&9%UiK&rz_LYl7w*8!p~EjZD=OQ1Ho`en(CkK7a21GD5QPoIaWinTL7i-e zx4MGO5Z$bbO+t23#t>L}T#j`wfxx?7y&Fz8y3yprXNS87Pi#s_CB12;Z{x^(bz?0K z%WSZ9e;2a}Dv$!23gk3^qu%?YaP9-=<-=OF?^JK$Qs;?pKG7z(|4J^YGyp4++P$@p z;MMUe`rB3Xg+oZOEpXVzbW)2Kh;D?sjZodl9tC6~aH8Z2Naw31n7B@F8?k-8^9!>lY1vdy3c;PCH>kbn`P&P{w-s(eVZF` zIIQ&QtYA=h-*_KO?{01G*-DPedrQ)`HlVW#%#u48ilabqR8&v)s_Cic{?A9*=;gLX zX#j3ZeD}!Cgow6}1el+!BaHjue1D{2Lsc6ZxCW3mkxElV2c5VRZeuvcffvs~$D}Hw#FXgWVynpynzdqLWy-o147v4W5f~Qna*) zw?PGp$WmBf8AtcGVOiLtFaiY@*(`khB^Ef@4;`wpHMW!sq$H(0dj{Ts&)l+gwjrk<61O1cfob9 z=JUVZE4ashY_}_(a(|Nm)zvF`<#93}VW1gdHt$d-ol1o`aui1DJ&Vk0szC#)gM^Iu z3K3%}C2J`J1IU`&3@CI!Af%|EvLSR-q@Ui)f+vp8jqW=OdgcT|jCU4-Stw=|YOfHn zS8+NE$ebj8K_XdzcWqJa^(+RUJ-A*BG_sgL_vHR?+g+eBr%D7M34mjF9e=@DQHV1fT~tg-}z96r!g6{!Fd3Y>xBGz6am`Z*L6 zUej|?5S&LCE=-2qR{!w+?x$0S{jF5@E@!%>0a%W-%J1G-0&o1U5u%SPs5R?w$zYVo zkot5;B^)RWf}=rDH>mJ50+w#d6{iw5(u};$K?0>QP-UB|!YJgyWpRLJ@A(;<;jmUA z^Bl5o^R>u#Cj^x_71`g6AMIM6M!qs97?Z7<(8vcG5lcr+?;zW4S%3(OYEohA7B zd$IQd?>&UyNgzlh>)OQC-yDD$ft!W+8Bc}pWd?#7G375aaj3KKeiqfV1>fpm?|)iR z%HOqa-qG(LACs29yOTf|_YZSbrhmk6qnu<;NODiDg@ALakqo*)o2+;$Hr zeW8eHaPFg@O99FF#pi+d8kz;|Ra1yHVo4O52wYd8ojh27Mir;U$w^f?0hgXY;xF`T zG`06fd$}-J({VrDq%{>}d2nQHEe{+BFpLm0-8!7Bp(iyssX>BjC^6xnnx?2BbXEAY z260tQwF=?pYEb2VRj0nDgpky8|0+~!fU@~b4I))Q`8hL?DiDnTW*{t<(%_VWMRXCMP(3<$Gs48j4l3vr$7RXQ-t zUb_P6dO|r)v%lFUT?q*B_%2+~LE^g-pu_JZvFn2GJ8>6bt%J1NMPJ%MwJ*jABzR%` zimpz#^Xwh{oi7^Q@KS%|YW;#_I8{F^aKnHb7WiR^vU+?_NI@=aNh(c18}N+tkV=I2 z0#yMj%n$=4B#x(M5bldnEEGJS1@p)V*+H}C0MdeD0ip{6%&E#8oJ@4<6OJ`EA zGf+1jBArqRrZlW9Oi!Qayztr!SF~?j3u%@HU@fG2e;+ejKNB)~nS$6ac*1)7&vr54btIsb4-7=9x+>~k3(<_a^%w^uD+)(Q{AB27YDVP z1bvB1wPI|u*g*!3c3gzTf_)0@gEHP@UYdCWt2NJcd>mUm2#{(9 z>n#XmUd24SIjEl&l}Qy$s>(Si&aazlP7PN)%gped~i|~;Ks*-sEq50Fk z*MzHhGXxGD(R_99q%EE+dAFxvxX)1lyq?5!c;wVLk1l?|ma3Ddwo1!(JVzQayd3qKv(~x{+Kl+>9K=TR?!M%s~ z0(t{Am8ui1h|@|nsYIQ?M@W67>cc=>;NSueA2=tjm->K~H6`eFAB;dkMas2+s#BLb z1gTe_rtqo2B~FqAfr}+|v3lvDCOxlny`iC@&hGzhH{rpr^f|aMZqj}59F~_@N}!ZL zDS>56pfmu>7FoGNDS=V~r3CH`36uul-nftDRg@AaB~VIW*%BxXz_LYF?odjglt3wg cdqV>MKQcan6>S8>V*mgE07*qoM6N<$g6iae*8l(j literal 0 HcmV?d00001 diff --git a/android/app/src/development/res/mipmap-hdpi/bootsplash_logo.png b/android/app/src/development/res/mipmap-hdpi/bootsplash_logo.png new file mode 100644 index 0000000000000000000000000000000000000000..4c3f367462a5338223e460e3739f34e4a63f9bb4 GIT binary patch literal 13381 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 literal 0 HcmV?d00001 diff --git a/android/app/src/development/res/mipmap-xhdpi/bootsplash_logo.png b/android/app/src/development/res/mipmap-xhdpi/bootsplash_logo.png new file mode 100644 index 0000000000000000000000000000000000000000..b7bdb170915e4d309d506091ba73b596151f2175 GIT binary patch literal 21982 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 BoofI9 literal 0 HcmV?d00001 diff --git a/android/app/src/development/res/mipmap-xxhdpi/bootsplash_logo.png b/android/app/src/development/res/mipmap-xxhdpi/bootsplash_logo.png new file mode 100644 index 0000000000000000000000000000000000000000..b42eb5b7145454b852b035ee92f6b6873408e54d GIT binary patch literal 42564 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%0Davt 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 literal 0 HcmV?d00001 diff --git a/android/app/src/development/res/mipmap-xxxhdpi/bootsplash_logo.png b/android/app/src/development/res/mipmap-xxxhdpi/bootsplash_logo.png new file mode 100644 index 0000000000000000000000000000000000000000..c3797f6edccf53cc7e0e742dae1ae1030fb31b21 GIT binary patch literal 69345 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�=Y~H9ltNs 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 literal 0 HcmV?d00001 From f9f7a9a0f74aebf7b624b9b985bbe0bca862ee3a Mon Sep 17 00:00:00 2001 From: staszekscp Date: Thu, 13 Apr 2023 15:14:21 +0200 Subject: [PATCH 05/51] fix android script in package.json --- android/app/google-services.json | 2 +- package.json | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/android/app/google-services.json b/android/app/google-services.json index 7e076c3bd124..35f7f5b68921 100644 --- a/android/app/google-services.json +++ b/android/app/google-services.json @@ -140,4 +140,4 @@ } ], "configuration_version": "1" - } \ No newline at end of file + } diff --git a/package.json b/package.json index 90d6c9281cd8..bb467b3f4f63 100644 --- a/package.json +++ b/package.json @@ -9,7 +9,7 @@ "scripts": { "postinstall": "npx patch-package && cd desktop && npm install", "clean": "npx react-native clean-project-auto", - "android": "scripts/set-pusher-suffix.sh && npx react-native run-android --port=8083", + "android": "scripts/set-pusher-suffix.sh && npx react-native run-android --port=8083 --variant=developmentDebug --appId=com.expensify.chat.dev", "ios": "scripts/set-pusher-suffix.sh && npx react-native run-ios --port=8082", "ipad": "npx react-native run-ios --port=8082 --simulator=\"iPad Pro (12.9-inch) (4th generation)\"", "ipad-sm": "npx react-native run-ios --port=8082 --simulator=\"iPad Pro (9.7-inch)\"", From 6e6c1ffdd92641132eec412071ba6b62e78bf103 Mon Sep 17 00:00:00 2001 From: staszekscp Date: Thu, 13 Apr 2023 15:38:27 +0200 Subject: [PATCH 06/51] fix last lines --- android/app/src/adhoc/res/mipmap-anydpi-v26/ic_launcher.xml | 2 +- .../app/src/adhoc/res/mipmap-anydpi-v26/ic_launcher_round.xml | 2 +- .../app/src/development/res/mipmap-anydpi-v26/ic_launcher.xml | 2 +- .../src/development/res/mipmap-anydpi-v26/ic_launcher_round.xml | 2 +- android/app/src/main/res/mipmap-anydpi-v26/ic_launcher.xml | 2 +- .../app/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml | 2 +- android/app/src/main/res/values/ic_launcher_background.xml | 2 +- 7 files changed, 7 insertions(+), 7 deletions(-) diff --git a/android/app/src/adhoc/res/mipmap-anydpi-v26/ic_launcher.xml b/android/app/src/adhoc/res/mipmap-anydpi-v26/ic_launcher.xml index 036d09bc5fd5..80b730f3673e 100644 --- a/android/app/src/adhoc/res/mipmap-anydpi-v26/ic_launcher.xml +++ b/android/app/src/adhoc/res/mipmap-anydpi-v26/ic_launcher.xml @@ -2,4 +2,4 @@ - \ No newline at end of file + diff --git a/android/app/src/adhoc/res/mipmap-anydpi-v26/ic_launcher_round.xml b/android/app/src/adhoc/res/mipmap-anydpi-v26/ic_launcher_round.xml index 036d09bc5fd5..80b730f3673e 100644 --- a/android/app/src/adhoc/res/mipmap-anydpi-v26/ic_launcher_round.xml +++ b/android/app/src/adhoc/res/mipmap-anydpi-v26/ic_launcher_round.xml @@ -2,4 +2,4 @@ - \ No newline at end of file + diff --git a/android/app/src/development/res/mipmap-anydpi-v26/ic_launcher.xml b/android/app/src/development/res/mipmap-anydpi-v26/ic_launcher.xml index 036d09bc5fd5..80b730f3673e 100644 --- a/android/app/src/development/res/mipmap-anydpi-v26/ic_launcher.xml +++ b/android/app/src/development/res/mipmap-anydpi-v26/ic_launcher.xml @@ -2,4 +2,4 @@ - \ No newline at end of file + diff --git a/android/app/src/development/res/mipmap-anydpi-v26/ic_launcher_round.xml b/android/app/src/development/res/mipmap-anydpi-v26/ic_launcher_round.xml index 036d09bc5fd5..80b730f3673e 100644 --- a/android/app/src/development/res/mipmap-anydpi-v26/ic_launcher_round.xml +++ b/android/app/src/development/res/mipmap-anydpi-v26/ic_launcher_round.xml @@ -2,4 +2,4 @@ - \ No newline at end of file + diff --git a/android/app/src/main/res/mipmap-anydpi-v26/ic_launcher.xml b/android/app/src/main/res/mipmap-anydpi-v26/ic_launcher.xml index 036d09bc5fd5..80b730f3673e 100644 --- a/android/app/src/main/res/mipmap-anydpi-v26/ic_launcher.xml +++ b/android/app/src/main/res/mipmap-anydpi-v26/ic_launcher.xml @@ -2,4 +2,4 @@ - \ No newline at end of file + diff --git a/android/app/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml b/android/app/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml index 036d09bc5fd5..80b730f3673e 100644 --- a/android/app/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml +++ b/android/app/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml @@ -2,4 +2,4 @@ - \ No newline at end of file + diff --git a/android/app/src/main/res/values/ic_launcher_background.xml b/android/app/src/main/res/values/ic_launcher_background.xml index 4e823a09e75e..ad6f6d9631c0 100644 --- a/android/app/src/main/res/values/ic_launcher_background.xml +++ b/android/app/src/main/res/values/ic_launcher_background.xml @@ -1,4 +1,4 @@ #3DDC84 - \ No newline at end of file + From 627444330b56452c6c16f7603f3d88d317ebac2e Mon Sep 17 00:00:00 2001 From: staszekscp Date: Thu, 13 Apr 2023 15:38:38 +0200 Subject: [PATCH 07/51] fix fastfile --- fastlane/Fastfile | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/fastlane/Fastfile b/fastlane/Fastfile index 70f3cf223647..7dc2fcc3196f 100644 --- a/fastlane/Fastfile +++ b/fastlane/Fastfile @@ -33,6 +33,7 @@ platform :android do gradle( project_dir: './android', task: 'assemble', + flavor: 'Production', build_type: 'Release', ) end @@ -44,7 +45,8 @@ platform :android do gradle( project_dir: './android', task: 'assemble', - build_type: 'InternalRelease', + flavor: 'Adhoc', + build_type: 'Release', ) aws_s3( @@ -67,6 +69,7 @@ platform :android do gradle( project_dir: './android', task: 'bundle', + flavor: 'Production', build_type: 'Release', ) From 4c4ae64d1cf615c5a9707172ab357a71d3093cdc Mon Sep 17 00:00:00 2001 From: staszekscp Date: Tue, 18 Apr 2023 12:54:44 +0200 Subject: [PATCH 08/51] add basic scheme support for ios --- ios/NewExpensify.xcodeproj/project.pbxproj | 816 +++++++++++++++++- ....xcscheme => New Expensify AdHoc.xcscheme} | 16 +- .../xcschemes/New Expensify Staging.xcscheme | 88 ++ .../xcschemes/New Expensify.xcscheme | 88 ++ .../xcschemes/NewExpensifyDev.xcscheme | 88 ++ ios/Podfile | 12 +- ios/Podfile.lock | 2 +- package.json | 2 +- 8 files changed, 1065 insertions(+), 47 deletions(-) rename ios/NewExpensify.xcodeproj/xcshareddata/xcschemes/{NewExpensify.xcscheme => New Expensify AdHoc.xcscheme} (89%) create mode 100644 ios/NewExpensify.xcodeproj/xcshareddata/xcschemes/New Expensify Staging.xcscheme create mode 100644 ios/NewExpensify.xcodeproj/xcshareddata/xcschemes/New Expensify.xcscheme create mode 100644 ios/NewExpensify.xcodeproj/xcshareddata/xcschemes/NewExpensifyDev.xcscheme diff --git a/ios/NewExpensify.xcodeproj/project.pbxproj b/ios/NewExpensify.xcodeproj/project.pbxproj index 439c46e6cfeb..60291a1361e2 100644 --- a/ios/NewExpensify.xcodeproj/project.pbxproj +++ b/ios/NewExpensify.xcodeproj/project.pbxproj @@ -30,7 +30,7 @@ B54A7C3AA98189A600323C02 /* libPods-NewExpensify-NewExpensifyTests.a in Frameworks */ = {isa = PBXBuildFile; fileRef = F679A86058F8C4B331D239C3 /* libPods-NewExpensify-NewExpensifyTests.a */; }; BDB853621F354EBB84E619C2 /* ExpensifyNewKansas-MediumItalic.otf in Resources */ = {isa = PBXBuildFile; fileRef = D2AFB39EC1D44BF9B91D3227 /* ExpensifyNewKansas-MediumItalic.otf */; }; DD79042B2792E76D004484B4 /* RCTBootSplash.m in Sources */ = {isa = PBXBuildFile; fileRef = DD79042A2792E76D004484B4 /* RCTBootSplash.m */; }; - E51DC681C7DEE40AEBDDFBFE /* BuildFile in Frameworks */ = {isa = PBXBuildFile; }; + E51DC681C7DEE40AEBDDFBFE /* (null) in Frameworks */ = {isa = PBXBuildFile; }; E9DF872D2525201700607FDC /* AirshipConfig.plist in Resources */ = {isa = PBXBuildFile; fileRef = E9DF872C2525201700607FDC /* AirshipConfig.plist */; }; F0C450EA2705020500FD2970 /* colors.json in Resources */ = {isa = PBXBuildFile; fileRef = F0C450E92705020500FD2970 /* colors.json */; }; FF941A8D48F849269AB85C9A /* ExpensifyNewKansas-Medium.otf in Resources */ = {isa = PBXBuildFile; fileRef = 44BF435285B94E5B95F90994 /* ExpensifyNewKansas-Medium.otf */; }; @@ -50,41 +50,57 @@ 008F07F21AC5B25A0029DE68 /* main.jsbundle */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = main.jsbundle; sourceTree = ""; }; 00E356EE1AD99517003FC87E /* NewExpensifyTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = NewExpensifyTests.xctest; sourceTree = BUILT_PRODUCTS_DIR; }; 00E356F11AD99517003FC87E /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; }; + 04AE503EFB65C54C6421A21C /* Pods-NewExpensify.debug development.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-NewExpensify.debug development.xcconfig"; path = "Target Support Files/Pods-NewExpensify/Pods-NewExpensify.debug development.xcconfig"; sourceTree = ""; }; 0CDA8E33287DD650004ECBEC /* AppDelegate.mm */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.objcpp; name = AppDelegate.mm; path = NewExpensify/AppDelegate.mm; sourceTree = ""; }; 0CDA8E36287DD6A0004ECBEC /* Images.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; name = Images.xcassets; path = NewExpensify/Images.xcassets; sourceTree = ""; }; 0F5BE0CD252686320097D869 /* GoogleService-Info.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; path = "GoogleService-Info.plist"; sourceTree = ""; }; 0F5E534E263B73D5004CA14F /* EnvironmentChecker.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = EnvironmentChecker.h; sourceTree = ""; }; 0F5E534F263B73FD004CA14F /* EnvironmentChecker.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = EnvironmentChecker.m; sourceTree = ""; }; - 13B07F961A680F5B00A75B9A /* New Expensify.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = "New Expensify.app"; sourceTree = BUILT_PRODUCTS_DIR; }; + 13B07F961A680F5B00A75B9A /* New Expensify Dev.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = "New Expensify Dev.app"; sourceTree = BUILT_PRODUCTS_DIR; }; 13B07FAF1A68108700A75B9A /* AppDelegate.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = AppDelegate.h; path = NewExpensify/AppDelegate.h; sourceTree = ""; }; 13B07FB61A68108700A75B9A /* Info.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; name = Info.plist; path = NewExpensify/Info.plist; sourceTree = ""; }; 13B07FB71A68108700A75B9A /* main.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = main.m; path = NewExpensify/main.m; sourceTree = ""; }; + 15A9AE9FCEA8582EC9D4B818 /* Pods-NewExpensify.release adhoc.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-NewExpensify.release adhoc.xcconfig"; path = "Target Support Files/Pods-NewExpensify/Pods-NewExpensify.release adhoc.xcconfig"; sourceTree = ""; }; 177D06D4BF2346EB90E37D3D /* ExpensifyMono-Bold.otf */ = {isa = PBXFileReference; explicitFileType = undefined; fileEncoding = 9; includeInIndex = 0; lastKnownFileType = unknown; name = "ExpensifyMono-Bold.otf"; path = "../assets/fonts/native/ExpensifyMono-Bold.otf"; sourceTree = ""; }; 18D050DF262400AF000D658B /* BridgingFile.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = BridgingFile.swift; sourceTree = ""; }; 1977066010294D51AEB35F3B /* ExpensifyNeue-Italic.otf */ = {isa = PBXFileReference; explicitFileType = undefined; fileEncoding = 9; includeInIndex = 0; lastKnownFileType = unknown; name = "ExpensifyNeue-Italic.otf"; path = "../assets/fonts/native/ExpensifyNeue-Italic.otf"; sourceTree = ""; }; 1B3F09A4E4EA4CFFA5E4E7CD /* ExpensifyMono-Regular.otf */ = {isa = PBXFileReference; explicitFileType = undefined; fileEncoding = 9; includeInIndex = 0; lastKnownFileType = unknown; name = "ExpensifyMono-Regular.otf"; path = "../assets/fonts/native/ExpensifyMono-Regular.otf"; sourceTree = ""; }; + 217521EF395019214E1FD024 /* Pods-NewExpensify.release development.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-NewExpensify.release development.xcconfig"; path = "Target Support Files/Pods-NewExpensify/Pods-NewExpensify.release development.xcconfig"; sourceTree = ""; }; + 2BD7C0A42E732390A568AE4A /* Pods-NewExpensify-NewExpensifyTests.release staging.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-NewExpensify-NewExpensifyTests.release staging.xcconfig"; path = "Target Support Files/Pods-NewExpensify-NewExpensifyTests/Pods-NewExpensify-NewExpensifyTests.release staging.xcconfig"; sourceTree = ""; }; + 2E0F63FDD5228F12D38D693D /* Pods-NewExpensify-NewExpensifyTests.debug development.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-NewExpensify-NewExpensifyTests.debug development.xcconfig"; path = "Target Support Files/Pods-NewExpensify-NewExpensifyTests/Pods-NewExpensify-NewExpensifyTests.debug development.xcconfig"; sourceTree = ""; }; 2FD35F00FB84D9FCF60D56A7 /* libPods-NewExpensify.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = "libPods-NewExpensify.a"; sourceTree = BUILT_PRODUCTS_DIR; }; + 328C74F32E375D88644E0DF9 /* Pods-NewExpensify-NewExpensifyTests.debug production.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-NewExpensify-NewExpensifyTests.debug production.xcconfig"; path = "Target Support Files/Pods-NewExpensify-NewExpensifyTests/Pods-NewExpensify-NewExpensifyTests.debug production.xcconfig"; sourceTree = ""; }; + 350474CA00D741EB18BA356D /* Pods-NewExpensify.debug adhoc.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-NewExpensify.debug adhoc.xcconfig"; path = "Target Support Files/Pods-NewExpensify/Pods-NewExpensify.debug adhoc.xcconfig"; sourceTree = ""; }; + 3683D6B1B41C28DB0618AE1D /* Pods-NewExpensify-NewExpensifyTests.release development.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-NewExpensify-NewExpensifyTests.release development.xcconfig"; path = "Target Support Files/Pods-NewExpensify-NewExpensifyTests/Pods-NewExpensify-NewExpensifyTests.release development.xcconfig"; sourceTree = ""; }; 374FB8D528A133A7000D84EF /* OriginImageRequestHandler.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; name = OriginImageRequestHandler.h; path = NewExpensify/OriginImageRequestHandler.h; sourceTree = ""; }; 374FB8D628A133FE000D84EF /* OriginImageRequestHandler.mm */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.cpp.objcpp; name = OriginImageRequestHandler.mm; path = NewExpensify/OriginImageRequestHandler.mm; sourceTree = ""; }; 37F6DD6E91B4C55BD8DDC895 /* Pods-NewExpensify.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-NewExpensify.debug.xcconfig"; path = "Target Support Files/Pods-NewExpensify/Pods-NewExpensify.debug.xcconfig"; sourceTree = ""; }; 38E61473EAA34C598CB6B345 /* ExpensifyNeue-BoldItalic.otf */ = {isa = PBXFileReference; explicitFileType = undefined; fileEncoding = 9; includeInIndex = 0; lastKnownFileType = unknown; name = "ExpensifyNeue-BoldItalic.otf"; path = "../assets/fonts/native/ExpensifyNeue-BoldItalic.otf"; sourceTree = ""; }; 391B5D1DB6CFBAC16FD11DC4 /* Pods-NewExpensify.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-NewExpensify.release.xcconfig"; path = "Target Support Files/Pods-NewExpensify/Pods-NewExpensify.release.xcconfig"; sourceTree = ""; }; 44BF435285B94E5B95F90994 /* ExpensifyNewKansas-Medium.otf */ = {isa = PBXFileReference; explicitFileType = undefined; fileEncoding = 9; includeInIndex = 0; lastKnownFileType = unknown; name = "ExpensifyNewKansas-Medium.otf"; path = "../assets/fonts/native/ExpensifyNewKansas-Medium.otf"; sourceTree = ""; }; + 57FD1888584D79CD28FA33E1 /* Pods-NewExpensify-NewExpensifyTests.debug staging.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-NewExpensify-NewExpensifyTests.debug staging.xcconfig"; path = "Target Support Files/Pods-NewExpensify-NewExpensifyTests/Pods-NewExpensify-NewExpensifyTests.debug staging.xcconfig"; sourceTree = ""; }; 6BEDED270C49437581EBE50D /* ExpensifyNeue-Regular.otf */ = {isa = PBXFileReference; explicitFileType = undefined; fileEncoding = 9; includeInIndex = 0; lastKnownFileType = unknown; name = "ExpensifyNeue-Regular.otf"; path = "../assets/fonts/native/ExpensifyNeue-Regular.otf"; sourceTree = ""; }; 7041848326A8E40900E09F4D /* RCTStartupTimer.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; name = RCTStartupTimer.h; path = NewExpensify/RCTStartupTimer.h; sourceTree = ""; }; 7041848426A8E47D00E09F4D /* RCTStartupTimer.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; name = RCTStartupTimer.m; path = NewExpensify/RCTStartupTimer.m; sourceTree = ""; }; 70CF6E81262E297300711ADC /* BootSplash.storyboard */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = file.storyboard; name = BootSplash.storyboard; path = NewExpensify/BootSplash.storyboard; sourceTree = ""; }; + A367462309D615D06C35884B /* Pods-NewExpensify-NewExpensifyTests.release adhoc.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-NewExpensify-NewExpensifyTests.release adhoc.xcconfig"; path = "Target Support Files/Pods-NewExpensify-NewExpensifyTests/Pods-NewExpensify-NewExpensifyTests.release adhoc.xcconfig"; sourceTree = ""; }; B37C757CE02B734BFED38097 /* Pods-NewExpensify-NewExpensifyTests.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-NewExpensify-NewExpensifyTests.debug.xcconfig"; path = "Target Support Files/Pods-NewExpensify-NewExpensifyTests/Pods-NewExpensify-NewExpensifyTests.debug.xcconfig"; sourceTree = ""; }; + BE5D56AF4DB6A25E47D361DC /* Pods-NewExpensify.debug production.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-NewExpensify.debug production.xcconfig"; path = "Target Support Files/Pods-NewExpensify/Pods-NewExpensify.debug production.xcconfig"; sourceTree = ""; }; CA3A3642AEED7CF2D4CD3716 /* Pods-NewExpensify-NewExpensifyTests.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-NewExpensify-NewExpensifyTests.release.xcconfig"; path = "Target Support Files/Pods-NewExpensify-NewExpensifyTests/Pods-NewExpensify-NewExpensifyTests.release.xcconfig"; sourceTree = ""; }; D2AFB39EC1D44BF9B91D3227 /* ExpensifyNewKansas-MediumItalic.otf */ = {isa = PBXFileReference; explicitFileType = undefined; fileEncoding = 9; includeInIndex = 0; lastKnownFileType = unknown; name = "ExpensifyNewKansas-MediumItalic.otf"; path = "../assets/fonts/native/ExpensifyNewKansas-MediumItalic.otf"; sourceTree = ""; }; + D75E95E752F1B927C07EFEAA /* Pods-NewExpensify.debug staging.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-NewExpensify.debug staging.xcconfig"; path = "Target Support Files/Pods-NewExpensify/Pods-NewExpensify.debug staging.xcconfig"; sourceTree = ""; }; DD7904292792E76D004484B4 /* RCTBootSplash.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = RCTBootSplash.h; path = NewExpensify/RCTBootSplash.h; sourceTree = ""; }; DD79042A2792E76D004484B4 /* RCTBootSplash.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = RCTBootSplash.m; path = NewExpensify/RCTBootSplash.m; sourceTree = ""; }; + E712484BD80786FA65A23C8B /* Pods-NewExpensify-NewExpensifyTests.debug adhoc.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-NewExpensify-NewExpensifyTests.debug adhoc.xcconfig"; path = "Target Support Files/Pods-NewExpensify-NewExpensifyTests/Pods-NewExpensify-NewExpensifyTests.debug adhoc.xcconfig"; sourceTree = ""; }; E9DF872C2525201700607FDC /* AirshipConfig.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; path = AirshipConfig.plist; sourceTree = ""; }; + EB898CE48C59A29BD2334AD7 /* Pods-NewExpensify.release production.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-NewExpensify.release production.xcconfig"; path = "Target Support Files/Pods-NewExpensify/Pods-NewExpensify.release production.xcconfig"; sourceTree = ""; }; ED297162215061F000B7C4FE /* JavaScriptCore.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = JavaScriptCore.framework; path = System/Library/Frameworks/JavaScriptCore.framework; sourceTree = SDKROOT; }; ED2971642150620600B7C4FE /* JavaScriptCore.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = JavaScriptCore.framework; path = Platforms/AppleTVOS.platform/Developer/SDKs/AppleTVOS12.0.sdk/System/Library/Frameworks/JavaScriptCore.framework; sourceTree = DEVELOPER_DIR; }; EDFC169F9D7A43BDB924151F /* ExpensifyNeue-Bold.otf */ = {isa = PBXFileReference; explicitFileType = undefined; fileEncoding = 9; includeInIndex = 0; lastKnownFileType = unknown; name = "ExpensifyNeue-Bold.otf"; path = "../assets/fonts/native/ExpensifyNeue-Bold.otf"; sourceTree = ""; }; F0C450E92705020500FD2970 /* colors.json */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.json; name = colors.json; path = ../colors.json; sourceTree = ""; }; + F4F0B7C0AC6C039305740937 /* Pods-NewExpensify-NewExpensifyTests.release production.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-NewExpensify-NewExpensifyTests.release production.xcconfig"; path = "Target Support Files/Pods-NewExpensify-NewExpensifyTests/Pods-NewExpensify-NewExpensifyTests.release production.xcconfig"; sourceTree = ""; }; F679A86058F8C4B331D239C3 /* libPods-NewExpensify-NewExpensifyTests.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = "libPods-NewExpensify-NewExpensifyTests.a"; sourceTree = BUILT_PRODUCTS_DIR; }; + F760457136098BA2628C3A90 /* Pods-NewExpensify.release staging.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-NewExpensify.release staging.xcconfig"; path = "Target Support Files/Pods-NewExpensify/Pods-NewExpensify.release staging.xcconfig"; sourceTree = ""; }; /* End PBXFileReference section */ /* Begin PBXFrameworksBuildPhase section */ @@ -100,7 +116,7 @@ isa = PBXFrameworksBuildPhase; buildActionMask = 2147483647; files = ( - E51DC681C7DEE40AEBDDFBFE /* BuildFile in Frameworks */, + E51DC681C7DEE40AEBDDFBFE /* (null) in Frameworks */, 9A65F0F374EC04ABB5FF40AF /* libPods-NewExpensify.a in Frameworks */, ); runOnlyForDeploymentPostprocessing = 0; @@ -187,7 +203,7 @@ 83CBBA001A601CBA00E9B192 /* Products */ = { isa = PBXGroup; children = ( - 13B07F961A680F5B00A75B9A /* New Expensify.app */, + 13B07F961A680F5B00A75B9A /* New Expensify Dev.app */, 00E356EE1AD99517003FC87E /* NewExpensifyTests.xctest */, ); name = Products; @@ -215,6 +231,22 @@ 391B5D1DB6CFBAC16FD11DC4 /* Pods-NewExpensify.release.xcconfig */, B37C757CE02B734BFED38097 /* Pods-NewExpensify-NewExpensifyTests.debug.xcconfig */, CA3A3642AEED7CF2D4CD3716 /* Pods-NewExpensify-NewExpensifyTests.release.xcconfig */, + 04AE503EFB65C54C6421A21C /* Pods-NewExpensify.debug development.xcconfig */, + 350474CA00D741EB18BA356D /* Pods-NewExpensify.debug adhoc.xcconfig */, + D75E95E752F1B927C07EFEAA /* Pods-NewExpensify.debug staging.xcconfig */, + BE5D56AF4DB6A25E47D361DC /* Pods-NewExpensify.debug production.xcconfig */, + 217521EF395019214E1FD024 /* Pods-NewExpensify.release development.xcconfig */, + 15A9AE9FCEA8582EC9D4B818 /* Pods-NewExpensify.release adhoc.xcconfig */, + F760457136098BA2628C3A90 /* Pods-NewExpensify.release staging.xcconfig */, + EB898CE48C59A29BD2334AD7 /* Pods-NewExpensify.release production.xcconfig */, + 2E0F63FDD5228F12D38D693D /* Pods-NewExpensify-NewExpensifyTests.debug development.xcconfig */, + E712484BD80786FA65A23C8B /* Pods-NewExpensify-NewExpensifyTests.debug adhoc.xcconfig */, + 57FD1888584D79CD28FA33E1 /* Pods-NewExpensify-NewExpensifyTests.debug staging.xcconfig */, + 328C74F32E375D88644E0DF9 /* Pods-NewExpensify-NewExpensifyTests.debug production.xcconfig */, + 3683D6B1B41C28DB0618AE1D /* Pods-NewExpensify-NewExpensifyTests.release development.xcconfig */, + A367462309D615D06C35884B /* Pods-NewExpensify-NewExpensifyTests.release adhoc.xcconfig */, + 2BD7C0A42E732390A568AE4A /* Pods-NewExpensify-NewExpensifyTests.release staging.xcconfig */, + F4F0B7C0AC6C039305740937 /* Pods-NewExpensify-NewExpensifyTests.release production.xcconfig */, ); path = Pods; sourceTree = ""; @@ -264,7 +296,7 @@ ); name = NewExpensify; productName = NewExpensify; - productReference = 13B07F961A680F5B00A75B9A /* New Expensify.app */; + productReference = 13B07F961A680F5B00A75B9A /* New Expensify Dev.app */; productType = "com.apple.product-type.application"; }; /* End PBXNativeTarget section */ @@ -277,6 +309,7 @@ TargetAttributes = { 00E356ED1AD99517003FC87E = { CreatedOnToolsVersion = 6.2; + DevelopmentTeam = 368M544MTT; ProvisioningStyle = Automatic; TestTargetID = 13B07F861A680F5B00A75B9A; }; @@ -592,9 +625,9 @@ /* End PBXTargetDependency section */ /* Begin XCBuildConfiguration section */ - 00E356F61AD99517003FC87E /* Debug */ = { + 00E356F61AD99517003FC87E /* DebugDevelopment */ = { isa = XCBuildConfiguration; - baseConfigurationReference = B37C757CE02B734BFED38097 /* Pods-NewExpensify-NewExpensifyTests.debug.xcconfig */; + baseConfigurationReference = 2E0F63FDD5228F12D38D693D /* Pods-NewExpensify-NewExpensifyTests.debug development.xcconfig */; buildSettings = { ALWAYS_EMBED_SWIFT_STANDARD_LIBRARIES = YES; BUNDLE_LOADER = "$(TEST_HOST)"; @@ -615,11 +648,11 @@ PRODUCT_NAME = "$(TARGET_NAME)"; TEST_HOST = "$(BUILT_PRODUCTS_DIR)/NewExpensify.app/NewExpensify"; }; - name = Debug; + name = DebugDevelopment; }; - 00E356F71AD99517003FC87E /* Release */ = { + 00E356F71AD99517003FC87E /* Release Development */ = { isa = XCBuildConfiguration; - baseConfigurationReference = CA3A3642AEED7CF2D4CD3716 /* Pods-NewExpensify-NewExpensifyTests.release.xcconfig */; + baseConfigurationReference = 3683D6B1B41C28DB0618AE1D /* Pods-NewExpensify-NewExpensifyTests.release development.xcconfig */; buildSettings = { ALWAYS_EMBED_SWIFT_STANDARD_LIBRARIES = YES; BUNDLE_LOADER = "$(TEST_HOST)"; @@ -638,11 +671,11 @@ PRODUCT_NAME = "$(TARGET_NAME)"; TEST_HOST = "$(BUILT_PRODUCTS_DIR)/NewExpensify.app/NewExpensify"; }; - name = Release; + name = "Release Development"; }; - 13B07F941A680F5B00A75B9A /* Debug */ = { + 13B07F941A680F5B00A75B9A /* DebugDevelopment */ = { isa = XCBuildConfiguration; - baseConfigurationReference = 37F6DD6E91B4C55BD8DDC895 /* Pods-NewExpensify.debug.xcconfig */; + baseConfigurationReference = 04AE503EFB65C54C6421A21C /* Pods-NewExpensify.debug development.xcconfig */; buildSettings = { ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; CLANG_ENABLE_MODULES = YES; @@ -662,19 +695,19 @@ "-ObjC", "-lc++", ); - PRODUCT_BUNDLE_IDENTIFIER = com.chat.expensify.chat; - PRODUCT_NAME = "New Expensify"; + PRODUCT_BUNDLE_IDENTIFIER = com.chat.expensify.chat.dev; + PRODUCT_NAME = "New Expensify Dev"; PROVISIONING_PROFILE_SPECIFIER = chat_expensify_appstore; SWIFT_OPTIMIZATION_LEVEL = "-Onone"; SWIFT_VERSION = 5.0; TARGETED_DEVICE_FAMILY = "1,2"; VERSIONING_SYSTEM = "apple-generic"; }; - name = Debug; + name = DebugDevelopment; }; - 13B07F951A680F5B00A75B9A /* Release */ = { + 13B07F951A680F5B00A75B9A /* Release Development */ = { isa = XCBuildConfiguration; - baseConfigurationReference = 391B5D1DB6CFBAC16FD11DC4 /* Pods-NewExpensify.release.xcconfig */; + baseConfigurationReference = 217521EF395019214E1FD024 /* Pods-NewExpensify.release development.xcconfig */; buildSettings = { ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; CLANG_ENABLE_MODULES = YES; @@ -693,21 +726,21 @@ "-ObjC", "-lc++", ); - PRODUCT_BUNDLE_IDENTIFIER = com.chat.expensify.chat; - PRODUCT_NAME = "New Expensify"; + PRODUCT_BUNDLE_IDENTIFIER = com.chat.expensify.chat.dev; + PRODUCT_NAME = "New Expensify Dev"; PROVISIONING_PROFILE_SPECIFIER = chat_expensify_appstore; SWIFT_VERSION = 5.0; TARGETED_DEVICE_FAMILY = "1,2"; VERSIONING_SYSTEM = "apple-generic"; }; - name = Release; + name = "Release Development"; }; - 83CBBA201A601CBA00E9B192 /* Debug */ = { + 83CBBA201A601CBA00E9B192 /* DebugDevelopment */ = { isa = XCBuildConfiguration; buildSettings = { ALWAYS_SEARCH_USER_PATHS = NO; CLANG_ANALYZER_LOCALIZABILITY_NONLOCALIZED = YES; - CLANG_CXX_LANGUAGE_STANDARD = "c++17"; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++14"; CLANG_CXX_LIBRARY = "libc++"; CLANG_ENABLE_MODULES = YES; CLANG_ENABLE_OBJC_ARC = YES; @@ -759,17 +792,18 @@ ); MTL_ENABLE_DEBUG_INFO = YES; ONLY_ACTIVE_ARCH = YES; + PRODUCT_BUNDLE_IDENTIFIER = ""; REACT_NATIVE_PATH = "${PODS_ROOT}/../../node_modules/react-native"; SDKROOT = iphoneos; }; - name = Debug; + name = DebugDevelopment; }; - 83CBBA211A601CBA00E9B192 /* Release */ = { + 83CBBA211A601CBA00E9B192 /* Release Development */ = { isa = XCBuildConfiguration; buildSettings = { ALWAYS_SEARCH_USER_PATHS = NO; CLANG_ANALYZER_LOCALIZABILITY_NONLOCALIZED = YES; - CLANG_CXX_LANGUAGE_STANDARD = "c++17"; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++14"; CLANG_CXX_LIBRARY = "libc++"; CLANG_ENABLE_MODULES = YES; CLANG_ENABLE_OBJC_ARC = YES; @@ -813,11 +847,703 @@ "\"$(inherited)\"", ); MTL_ENABLE_DEBUG_INFO = NO; + PRODUCT_BUNDLE_IDENTIFIER = ""; + PRODUCT_NAME = ""; REACT_NATIVE_PATH = "${PODS_ROOT}/../../node_modules/react-native"; SDKROOT = iphoneos; VALIDATE_PRODUCT = YES; }; - name = Release; + name = "Release Development"; + }; + CF9AF93E29EE9276001FA527 /* Debug Production */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_LOCALIZABILITY_NONLOCALIZED = YES; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++14"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_COMMA = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; + CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; + CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; + CLANG_WARN_STRICT_PROTOTYPES = YES; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; + COPY_PHASE_STRIP = NO; + ENABLE_STRICT_OBJC_MSGSEND = YES; + ENABLE_TESTABILITY = YES; + "EXCLUDED_ARCHS[sdk=iphonesimulator*]" = i386; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_DYNAMIC_NO_PIC = NO; + GCC_NO_COMMON_BLOCKS = YES; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "DEBUG=1", + "$(inherited)", + ); + GCC_SYMBOLS_PRIVATE_EXTERN = NO; + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 16.1; + LD_RUNPATH_SEARCH_PATHS = "/usr/lib/swift $(inherited)"; + LIBRARY_SEARCH_PATHS = ( + "$(SDKROOT)/usr/lib/swift", + "\"$(TOOLCHAIN_DIR)/usr/lib/swift/$(PLATFORM_NAME)\"", + "\"$(inherited)\"", + ); + MTL_ENABLE_DEBUG_INFO = YES; + ONLY_ACTIVE_ARCH = YES; + PRODUCT_BUNDLE_IDENTIFIER = ""; + REACT_NATIVE_PATH = "${PODS_ROOT}/../../node_modules/react-native"; + SDKROOT = iphoneos; + }; + name = "Debug Production"; + }; + CF9AF93F29EE9276001FA527 /* Debug Production */ = { + isa = XCBuildConfiguration; + baseConfigurationReference = BE5D56AF4DB6A25E47D361DC /* Pods-NewExpensify.debug production.xcconfig */; + buildSettings = { + ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + CLANG_ENABLE_MODULES = YES; + CODE_SIGN_ENTITLEMENTS = NewExpensify/Chat.entitlements; + CODE_SIGN_IDENTITY = "iPhone Distribution"; + CODE_SIGN_STYLE = Manual; + CURRENT_PROJECT_VERSION = 3; + DEVELOPMENT_TEAM = 368M544MTT; + ENABLE_BITCODE = NO; + "EXCLUDED_ARCHS[sdk=iphonesimulator*]" = arm64; + INFOPLIST_FILE = "$(SRCROOT)/NewExpensify/Info.plist"; + IPHONEOS_DEPLOYMENT_TARGET = 13.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks"; + MARKETING_VERSION = 1.0.0; + OTHER_LDFLAGS = ( + "$(inherited)", + "-ObjC", + "-lc++", + ); + PRODUCT_BUNDLE_IDENTIFIER = com.chat.expensify.chat; + PRODUCT_NAME = "New Expensify"; + PROVISIONING_PROFILE_SPECIFIER = chat_expensify_appstore; + SWIFT_OPTIMIZATION_LEVEL = "-Onone"; + SWIFT_VERSION = 5.0; + TARGETED_DEVICE_FAMILY = "1,2"; + VERSIONING_SYSTEM = "apple-generic"; + }; + name = "Debug Production"; + }; + CF9AF94029EE9276001FA527 /* Debug Production */ = { + isa = XCBuildConfiguration; + baseConfigurationReference = 328C74F32E375D88644E0DF9 /* Pods-NewExpensify-NewExpensifyTests.debug production.xcconfig */; + buildSettings = { + ALWAYS_EMBED_SWIFT_STANDARD_LIBRARIES = YES; + BUNDLE_LOADER = "$(TEST_HOST)"; + CODE_SIGN_STYLE = Automatic; + GCC_PREPROCESSOR_DEFINITIONS = ( + "DEBUG=1", + "$(inherited)", + ); + INFOPLIST_FILE = NewExpensifyTests/Info.plist; + IPHONEOS_DEPLOYMENT_TARGET = 11.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; + OTHER_LDFLAGS = ( + "-ObjC", + "-lc++", + "$(inherited)", + ); + PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)"; + PRODUCT_NAME = "$(TARGET_NAME)"; + TEST_HOST = "$(BUILT_PRODUCTS_DIR)/NewExpensify.app/NewExpensify"; + }; + name = "Debug Production"; + }; + CF9AF94129EE9278001FA527 /* Debug Staging */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_LOCALIZABILITY_NONLOCALIZED = YES; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++14"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_COMMA = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; + CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; + CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; + CLANG_WARN_STRICT_PROTOTYPES = YES; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; + COPY_PHASE_STRIP = NO; + ENABLE_STRICT_OBJC_MSGSEND = YES; + ENABLE_TESTABILITY = YES; + "EXCLUDED_ARCHS[sdk=iphonesimulator*]" = i386; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_DYNAMIC_NO_PIC = NO; + GCC_NO_COMMON_BLOCKS = YES; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "DEBUG=1", + "$(inherited)", + ); + GCC_SYMBOLS_PRIVATE_EXTERN = NO; + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 16.1; + LD_RUNPATH_SEARCH_PATHS = "/usr/lib/swift $(inherited)"; + LIBRARY_SEARCH_PATHS = ( + "$(SDKROOT)/usr/lib/swift", + "\"$(TOOLCHAIN_DIR)/usr/lib/swift/$(PLATFORM_NAME)\"", + "\"$(inherited)\"", + ); + MTL_ENABLE_DEBUG_INFO = YES; + ONLY_ACTIVE_ARCH = YES; + PRODUCT_BUNDLE_IDENTIFIER = ""; + PRODUCT_NAME = ""; + REACT_NATIVE_PATH = "${PODS_ROOT}/../../node_modules/react-native"; + SDKROOT = iphoneos; + }; + name = "Debug Staging"; + }; + CF9AF94229EE9278001FA527 /* Debug Staging */ = { + isa = XCBuildConfiguration; + baseConfigurationReference = D75E95E752F1B927C07EFEAA /* Pods-NewExpensify.debug staging.xcconfig */; + buildSettings = { + ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + CLANG_ENABLE_MODULES = YES; + CODE_SIGN_ENTITLEMENTS = NewExpensify/Chat.entitlements; + CODE_SIGN_IDENTITY = "iPhone Distribution"; + CODE_SIGN_STYLE = Manual; + CURRENT_PROJECT_VERSION = 3; + DEVELOPMENT_TEAM = 368M544MTT; + ENABLE_BITCODE = NO; + "EXCLUDED_ARCHS[sdk=iphonesimulator*]" = arm64; + INFOPLIST_FILE = "$(SRCROOT)/NewExpensify/Info.plist"; + IPHONEOS_DEPLOYMENT_TARGET = 13.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks"; + MARKETING_VERSION = 1.0.0; + OTHER_LDFLAGS = ( + "$(inherited)", + "-ObjC", + "-lc++", + ); + PRODUCT_BUNDLE_IDENTIFIER = com.chat.expensify.chat; + PRODUCT_NAME = "New Expensify Staging"; + PROVISIONING_PROFILE_SPECIFIER = chat_expensify_appstore; + SWIFT_OPTIMIZATION_LEVEL = "-Onone"; + SWIFT_VERSION = 5.0; + TARGETED_DEVICE_FAMILY = "1,2"; + VERSIONING_SYSTEM = "apple-generic"; + }; + name = "Debug Staging"; + }; + CF9AF94329EE9278001FA527 /* Debug Staging */ = { + isa = XCBuildConfiguration; + baseConfigurationReference = 57FD1888584D79CD28FA33E1 /* Pods-NewExpensify-NewExpensifyTests.debug staging.xcconfig */; + buildSettings = { + ALWAYS_EMBED_SWIFT_STANDARD_LIBRARIES = YES; + BUNDLE_LOADER = "$(TEST_HOST)"; + CODE_SIGN_STYLE = Automatic; + GCC_PREPROCESSOR_DEFINITIONS = ( + "DEBUG=1", + "$(inherited)", + ); + INFOPLIST_FILE = NewExpensifyTests/Info.plist; + IPHONEOS_DEPLOYMENT_TARGET = 11.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; + OTHER_LDFLAGS = ( + "-ObjC", + "-lc++", + "$(inherited)", + ); + PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)"; + PRODUCT_NAME = "$(TARGET_NAME)"; + TEST_HOST = "$(BUILT_PRODUCTS_DIR)/NewExpensify.app/NewExpensify"; + }; + name = "Debug Staging"; + }; + CF9AF94429EE927A001FA527 /* Debug AdHoc */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_LOCALIZABILITY_NONLOCALIZED = YES; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++14"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_COMMA = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; + CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; + CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; + CLANG_WARN_STRICT_PROTOTYPES = YES; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; + COPY_PHASE_STRIP = NO; + ENABLE_STRICT_OBJC_MSGSEND = YES; + ENABLE_TESTABILITY = YES; + "EXCLUDED_ARCHS[sdk=iphonesimulator*]" = i386; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_DYNAMIC_NO_PIC = NO; + GCC_NO_COMMON_BLOCKS = YES; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "DEBUG=1", + "$(inherited)", + ); + GCC_SYMBOLS_PRIVATE_EXTERN = NO; + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 16.1; + LD_RUNPATH_SEARCH_PATHS = "/usr/lib/swift $(inherited)"; + LIBRARY_SEARCH_PATHS = ( + "$(SDKROOT)/usr/lib/swift", + "\"$(TOOLCHAIN_DIR)/usr/lib/swift/$(PLATFORM_NAME)\"", + "\"$(inherited)\"", + ); + MTL_ENABLE_DEBUG_INFO = YES; + ONLY_ACTIVE_ARCH = YES; + PRODUCT_BUNDLE_IDENTIFIER = ""; + REACT_NATIVE_PATH = "${PODS_ROOT}/../../node_modules/react-native"; + SDKROOT = iphoneos; + }; + name = "Debug AdHoc"; + }; + CF9AF94529EE927A001FA527 /* Debug AdHoc */ = { + isa = XCBuildConfiguration; + baseConfigurationReference = 350474CA00D741EB18BA356D /* Pods-NewExpensify.debug adhoc.xcconfig */; + buildSettings = { + ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + CLANG_ENABLE_MODULES = YES; + CODE_SIGN_ENTITLEMENTS = NewExpensify/Chat.entitlements; + CODE_SIGN_IDENTITY = "iPhone Distribution"; + CODE_SIGN_STYLE = Manual; + CURRENT_PROJECT_VERSION = 3; + DEVELOPMENT_TEAM = 368M544MTT; + ENABLE_BITCODE = NO; + "EXCLUDED_ARCHS[sdk=iphonesimulator*]" = arm64; + INFOPLIST_FILE = "$(SRCROOT)/NewExpensify/Info.plist"; + IPHONEOS_DEPLOYMENT_TARGET = 13.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks"; + MARKETING_VERSION = 1.0.0; + OTHER_LDFLAGS = ( + "$(inherited)", + "-ObjC", + "-lc++", + ); + PRODUCT_BUNDLE_IDENTIFIER = com.chat.expensify.chat.adhoc; + PRODUCT_NAME = "New Expensify AdHoc"; + PROVISIONING_PROFILE_SPECIFIER = chat_expensify_appstore; + SWIFT_OPTIMIZATION_LEVEL = "-Onone"; + SWIFT_VERSION = 5.0; + TARGETED_DEVICE_FAMILY = "1,2"; + VERSIONING_SYSTEM = "apple-generic"; + }; + name = "Debug AdHoc"; + }; + CF9AF94629EE927A001FA527 /* Debug AdHoc */ = { + isa = XCBuildConfiguration; + baseConfigurationReference = E712484BD80786FA65A23C8B /* Pods-NewExpensify-NewExpensifyTests.debug adhoc.xcconfig */; + buildSettings = { + ALWAYS_EMBED_SWIFT_STANDARD_LIBRARIES = YES; + BUNDLE_LOADER = "$(TEST_HOST)"; + CODE_SIGN_STYLE = Automatic; + GCC_PREPROCESSOR_DEFINITIONS = ( + "DEBUG=1", + "$(inherited)", + ); + INFOPLIST_FILE = NewExpensifyTests/Info.plist; + IPHONEOS_DEPLOYMENT_TARGET = 11.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; + OTHER_LDFLAGS = ( + "-ObjC", + "-lc++", + "$(inherited)", + ); + PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)"; + PRODUCT_NAME = "$(TARGET_NAME)"; + TEST_HOST = "$(BUILT_PRODUCTS_DIR)/NewExpensify.app/NewExpensify"; + }; + name = "Debug AdHoc"; + }; + CF9AF94729EE928E001FA527 /* Release Production */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_LOCALIZABILITY_NONLOCALIZED = YES; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++14"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_COMMA = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; + CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; + CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; + CLANG_WARN_STRICT_PROTOTYPES = YES; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; + COPY_PHASE_STRIP = YES; + ENABLE_NS_ASSERTIONS = NO; + ENABLE_STRICT_OBJC_MSGSEND = YES; + "EXCLUDED_ARCHS[sdk=iphonesimulator*]" = i386; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_NO_COMMON_BLOCKS = YES; + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 16.1; + LD_RUNPATH_SEARCH_PATHS = "/usr/lib/swift $(inherited)"; + LIBRARY_SEARCH_PATHS = ( + "$(SDKROOT)/usr/lib/swift", + "\"$(TOOLCHAIN_DIR)/usr/lib/swift/$(PLATFORM_NAME)\"", + "\"$(inherited)\"", + ); + MTL_ENABLE_DEBUG_INFO = NO; + PRODUCT_BUNDLE_IDENTIFIER = ""; + PRODUCT_NAME = ""; + REACT_NATIVE_PATH = "${PODS_ROOT}/../../node_modules/react-native"; + SDKROOT = iphoneos; + VALIDATE_PRODUCT = YES; + }; + name = "Release Production"; + }; + CF9AF94829EE928E001FA527 /* Release Production */ = { + isa = XCBuildConfiguration; + baseConfigurationReference = EB898CE48C59A29BD2334AD7 /* Pods-NewExpensify.release production.xcconfig */; + buildSettings = { + ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + CLANG_ENABLE_MODULES = YES; + CODE_SIGN_ENTITLEMENTS = NewExpensify/Chat.entitlements; + CODE_SIGN_IDENTITY = "iPhone Distribution"; + CODE_SIGN_STYLE = Manual; + CURRENT_PROJECT_VERSION = 3; + DEVELOPMENT_TEAM = 368M544MTT; + "EXCLUDED_ARCHS[sdk=iphonesimulator*]" = arm64; + INFOPLIST_FILE = NewExpensify/Info.plist; + IPHONEOS_DEPLOYMENT_TARGET = 13.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks"; + MARKETING_VERSION = 1.0.0; + OTHER_LDFLAGS = ( + "$(inherited)", + "-ObjC", + "-lc++", + ); + PRODUCT_BUNDLE_IDENTIFIER = com.chat.expensify.chat; + PRODUCT_NAME = "New Expensify"; + PROVISIONING_PROFILE_SPECIFIER = chat_expensify_appstore; + SWIFT_VERSION = 5.0; + TARGETED_DEVICE_FAMILY = "1,2"; + VERSIONING_SYSTEM = "apple-generic"; + }; + name = "Release Production"; + }; + CF9AF94929EE928E001FA527 /* Release Production */ = { + isa = XCBuildConfiguration; + baseConfigurationReference = F4F0B7C0AC6C039305740937 /* Pods-NewExpensify-NewExpensifyTests.release production.xcconfig */; + buildSettings = { + ALWAYS_EMBED_SWIFT_STANDARD_LIBRARIES = YES; + BUNDLE_LOADER = "$(TEST_HOST)"; + CODE_SIGN_STYLE = Automatic; + COPY_PHASE_STRIP = NO; + DEVELOPMENT_TEAM = 368M544MTT; + INFOPLIST_FILE = NewExpensifyTests/Info.plist; + IPHONEOS_DEPLOYMENT_TARGET = 11.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; + OTHER_LDFLAGS = ( + "-ObjC", + "-lc++", + "$(inherited)", + ); + PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)"; + PRODUCT_NAME = "$(TARGET_NAME)"; + TEST_HOST = "$(BUILT_PRODUCTS_DIR)/NewExpensify.app/NewExpensify"; + }; + name = "Release Production"; + }; + CF9AF94A29EE9290001FA527 /* Release Staging */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_LOCALIZABILITY_NONLOCALIZED = YES; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++14"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_COMMA = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; + CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; + CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; + CLANG_WARN_STRICT_PROTOTYPES = YES; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; + COPY_PHASE_STRIP = YES; + ENABLE_NS_ASSERTIONS = NO; + ENABLE_STRICT_OBJC_MSGSEND = YES; + "EXCLUDED_ARCHS[sdk=iphonesimulator*]" = i386; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_NO_COMMON_BLOCKS = YES; + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 16.1; + LD_RUNPATH_SEARCH_PATHS = "/usr/lib/swift $(inherited)"; + LIBRARY_SEARCH_PATHS = ( + "$(SDKROOT)/usr/lib/swift", + "\"$(TOOLCHAIN_DIR)/usr/lib/swift/$(PLATFORM_NAME)\"", + "\"$(inherited)\"", + ); + MTL_ENABLE_DEBUG_INFO = NO; + PRODUCT_NAME = ""; + REACT_NATIVE_PATH = "${PODS_ROOT}/../../node_modules/react-native"; + SDKROOT = iphoneos; + VALIDATE_PRODUCT = YES; + }; + name = "Release Staging"; + }; + CF9AF94B29EE9290001FA527 /* Release Staging */ = { + isa = XCBuildConfiguration; + baseConfigurationReference = F760457136098BA2628C3A90 /* Pods-NewExpensify.release staging.xcconfig */; + buildSettings = { + ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + CLANG_ENABLE_MODULES = YES; + CODE_SIGN_ENTITLEMENTS = NewExpensify/Chat.entitlements; + CODE_SIGN_IDENTITY = "iPhone Distribution"; + CODE_SIGN_STYLE = Manual; + CURRENT_PROJECT_VERSION = 3; + DEVELOPMENT_TEAM = 368M544MTT; + "EXCLUDED_ARCHS[sdk=iphonesimulator*]" = arm64; + INFOPLIST_FILE = NewExpensify/Info.plist; + IPHONEOS_DEPLOYMENT_TARGET = 13.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks"; + MARKETING_VERSION = 1.0.0; + OTHER_LDFLAGS = ( + "$(inherited)", + "-ObjC", + "-lc++", + ); + PRODUCT_BUNDLE_IDENTIFIER = com.chat.expensify.chat; + PRODUCT_NAME = "New Expensify Staging"; + PROVISIONING_PROFILE_SPECIFIER = chat_expensify_appstore; + SWIFT_VERSION = 5.0; + TARGETED_DEVICE_FAMILY = "1,2"; + VERSIONING_SYSTEM = "apple-generic"; + }; + name = "Release Staging"; + }; + CF9AF94C29EE9290001FA527 /* Release Staging */ = { + isa = XCBuildConfiguration; + baseConfigurationReference = 2BD7C0A42E732390A568AE4A /* Pods-NewExpensify-NewExpensifyTests.release staging.xcconfig */; + buildSettings = { + ALWAYS_EMBED_SWIFT_STANDARD_LIBRARIES = YES; + BUNDLE_LOADER = "$(TEST_HOST)"; + CODE_SIGN_STYLE = Automatic; + COPY_PHASE_STRIP = NO; + DEVELOPMENT_TEAM = 368M544MTT; + INFOPLIST_FILE = NewExpensifyTests/Info.plist; + IPHONEOS_DEPLOYMENT_TARGET = 11.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; + OTHER_LDFLAGS = ( + "-ObjC", + "-lc++", + "$(inherited)", + ); + PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)"; + PRODUCT_NAME = "$(TARGET_NAME)"; + TEST_HOST = "$(BUILT_PRODUCTS_DIR)/NewExpensify.app/NewExpensify"; + }; + name = "Release Staging"; + }; + CF9AF94D29EE9293001FA527 /* Release AdHoc */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ANALYZER_LOCALIZABILITY_NONLOCALIZED = YES; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++14"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_COMMA = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; + CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; + CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; + CLANG_WARN_STRICT_PROTOTYPES = YES; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; + COPY_PHASE_STRIP = YES; + ENABLE_NS_ASSERTIONS = NO; + ENABLE_STRICT_OBJC_MSGSEND = YES; + "EXCLUDED_ARCHS[sdk=iphonesimulator*]" = i386; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_NO_COMMON_BLOCKS = YES; + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 16.1; + LD_RUNPATH_SEARCH_PATHS = "/usr/lib/swift $(inherited)"; + LIBRARY_SEARCH_PATHS = ( + "$(SDKROOT)/usr/lib/swift", + "\"$(TOOLCHAIN_DIR)/usr/lib/swift/$(PLATFORM_NAME)\"", + "\"$(inherited)\"", + ); + MTL_ENABLE_DEBUG_INFO = NO; + PRODUCT_BUNDLE_IDENTIFIER = ""; + PRODUCT_NAME = ""; + REACT_NATIVE_PATH = "${PODS_ROOT}/../../node_modules/react-native"; + SDKROOT = iphoneos; + VALIDATE_PRODUCT = YES; + }; + name = "Release AdHoc"; + }; + CF9AF94E29EE9293001FA527 /* Release AdHoc */ = { + isa = XCBuildConfiguration; + baseConfigurationReference = 15A9AE9FCEA8582EC9D4B818 /* Pods-NewExpensify.release adhoc.xcconfig */; + buildSettings = { + ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + CLANG_ENABLE_MODULES = YES; + CODE_SIGN_ENTITLEMENTS = NewExpensify/Chat.entitlements; + CODE_SIGN_IDENTITY = "iPhone Distribution"; + CODE_SIGN_STYLE = Manual; + CURRENT_PROJECT_VERSION = 3; + DEVELOPMENT_TEAM = 368M544MTT; + "EXCLUDED_ARCHS[sdk=iphonesimulator*]" = arm64; + INFOPLIST_FILE = NewExpensify/Info.plist; + IPHONEOS_DEPLOYMENT_TARGET = 13.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks"; + MARKETING_VERSION = 1.0.0; + OTHER_LDFLAGS = ( + "$(inherited)", + "-ObjC", + "-lc++", + ); + PRODUCT_BUNDLE_IDENTIFIER = com.chat.expensify.chat.adhoc; + PRODUCT_NAME = "New Expensify AdHoc"; + PROVISIONING_PROFILE_SPECIFIER = chat_expensify_appstore; + SWIFT_VERSION = 5.0; + TARGETED_DEVICE_FAMILY = "1,2"; + VERSIONING_SYSTEM = "apple-generic"; + }; + name = "Release AdHoc"; + }; + CF9AF94F29EE9293001FA527 /* Release AdHoc */ = { + isa = XCBuildConfiguration; + baseConfigurationReference = A367462309D615D06C35884B /* Pods-NewExpensify-NewExpensifyTests.release adhoc.xcconfig */; + buildSettings = { + ALWAYS_EMBED_SWIFT_STANDARD_LIBRARIES = YES; + BUNDLE_LOADER = "$(TEST_HOST)"; + CODE_SIGN_STYLE = Automatic; + COPY_PHASE_STRIP = NO; + DEVELOPMENT_TEAM = 368M544MTT; + INFOPLIST_FILE = NewExpensifyTests/Info.plist; + IPHONEOS_DEPLOYMENT_TARGET = 11.0; + LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; + OTHER_LDFLAGS = ( + "-ObjC", + "-lc++", + "$(inherited)", + ); + PRODUCT_BUNDLE_IDENTIFIER = "org.reactjs.native.example.$(PRODUCT_NAME:rfc1034identifier)"; + PRODUCT_NAME = "$(TARGET_NAME)"; + TEST_HOST = "$(BUILT_PRODUCTS_DIR)/NewExpensify.app/NewExpensify"; + }; + name = "Release AdHoc"; }; /* End XCBuildConfiguration section */ @@ -825,29 +1551,47 @@ 00E357021AD99517003FC87E /* Build configuration list for PBXNativeTarget "NewExpensifyTests" */ = { isa = XCConfigurationList; buildConfigurations = ( - 00E356F61AD99517003FC87E /* Debug */, - 00E356F71AD99517003FC87E /* Release */, + 00E356F61AD99517003FC87E /* DebugDevelopment */, + CF9AF94629EE927A001FA527 /* Debug AdHoc */, + CF9AF94329EE9278001FA527 /* Debug Staging */, + CF9AF94029EE9276001FA527 /* Debug Production */, + 00E356F71AD99517003FC87E /* Release Development */, + CF9AF94F29EE9293001FA527 /* Release AdHoc */, + CF9AF94C29EE9290001FA527 /* Release Staging */, + CF9AF94929EE928E001FA527 /* Release Production */, ); defaultConfigurationIsVisible = 0; - defaultConfigurationName = Release; + defaultConfigurationName = "Release Development"; }; 13B07F931A680F5B00A75B9A /* Build configuration list for PBXNativeTarget "NewExpensify" */ = { isa = XCConfigurationList; buildConfigurations = ( - 13B07F941A680F5B00A75B9A /* Debug */, - 13B07F951A680F5B00A75B9A /* Release */, + 13B07F941A680F5B00A75B9A /* DebugDevelopment */, + CF9AF94529EE927A001FA527 /* Debug AdHoc */, + CF9AF94229EE9278001FA527 /* Debug Staging */, + CF9AF93F29EE9276001FA527 /* Debug Production */, + 13B07F951A680F5B00A75B9A /* Release Development */, + CF9AF94E29EE9293001FA527 /* Release AdHoc */, + CF9AF94B29EE9290001FA527 /* Release Staging */, + CF9AF94829EE928E001FA527 /* Release Production */, ); defaultConfigurationIsVisible = 0; - defaultConfigurationName = Release; + defaultConfigurationName = "Release Development"; }; 83CBB9FA1A601CBA00E9B192 /* Build configuration list for PBXProject "NewExpensify" */ = { isa = XCConfigurationList; buildConfigurations = ( - 83CBBA201A601CBA00E9B192 /* Debug */, - 83CBBA211A601CBA00E9B192 /* Release */, + 83CBBA201A601CBA00E9B192 /* DebugDevelopment */, + CF9AF94429EE927A001FA527 /* Debug AdHoc */, + CF9AF94129EE9278001FA527 /* Debug Staging */, + CF9AF93E29EE9276001FA527 /* Debug Production */, + 83CBBA211A601CBA00E9B192 /* Release Development */, + CF9AF94D29EE9293001FA527 /* Release AdHoc */, + CF9AF94A29EE9290001FA527 /* Release Staging */, + CF9AF94729EE928E001FA527 /* Release Production */, ); defaultConfigurationIsVisible = 0; - defaultConfigurationName = Release; + defaultConfigurationName = "Release Development"; }; /* End XCConfigurationList section */ }; diff --git a/ios/NewExpensify.xcodeproj/xcshareddata/xcschemes/NewExpensify.xcscheme b/ios/NewExpensify.xcodeproj/xcshareddata/xcschemes/New Expensify AdHoc.xcscheme similarity index 89% rename from ios/NewExpensify.xcodeproj/xcshareddata/xcschemes/NewExpensify.xcscheme rename to ios/NewExpensify.xcodeproj/xcshareddata/xcschemes/New Expensify AdHoc.xcscheme index 87aa0146de0d..414feec17bc8 100644 --- a/ios/NewExpensify.xcodeproj/xcshareddata/xcschemes/NewExpensify.xcscheme +++ b/ios/NewExpensify.xcodeproj/xcshareddata/xcschemes/New Expensify AdHoc.xcscheme @@ -15,7 +15,7 @@ @@ -23,7 +23,7 @@ @@ -41,7 +41,7 @@ + buildConfiguration = "Debug AdHoc"> diff --git a/ios/NewExpensify.xcodeproj/xcshareddata/xcschemes/New Expensify Staging.xcscheme b/ios/NewExpensify.xcodeproj/xcshareddata/xcschemes/New Expensify Staging.xcscheme new file mode 100644 index 000000000000..a5514e2e71cf --- /dev/null +++ b/ios/NewExpensify.xcodeproj/xcshareddata/xcschemes/New Expensify Staging.xcscheme @@ -0,0 +1,88 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/ios/NewExpensify.xcodeproj/xcshareddata/xcschemes/New Expensify.xcscheme b/ios/NewExpensify.xcodeproj/xcshareddata/xcschemes/New Expensify.xcscheme new file mode 100644 index 000000000000..578a015059b7 --- /dev/null +++ b/ios/NewExpensify.xcodeproj/xcshareddata/xcschemes/New Expensify.xcscheme @@ -0,0 +1,88 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/ios/NewExpensify.xcodeproj/xcshareddata/xcschemes/NewExpensifyDev.xcscheme b/ios/NewExpensify.xcodeproj/xcshareddata/xcschemes/NewExpensifyDev.xcscheme new file mode 100644 index 000000000000..62c6886c1b2c --- /dev/null +++ b/ios/NewExpensify.xcodeproj/xcshareddata/xcschemes/NewExpensifyDev.xcscheme @@ -0,0 +1,88 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/ios/Podfile b/ios/Podfile index dd2fbbd2eeea..92f06aa7192d 100644 --- a/ios/Podfile +++ b/ios/Podfile @@ -13,7 +13,7 @@ prepare_react_native_project! # dependencies: { # ...(process.env.NO_FLIPPER ? { 'react-native-flipper': { platforms: { ios: null } } } : {}), # ``` -flipper_config = ENV['NO_FLIPPER'] == "1" ? FlipperConfiguration.disabled : FlipperConfiguration.enabled +flipper_config = ENV['NO_FLIPPER'] == "1" ? FlipperConfiguration.disabled : FlipperConfiguration.enabled(['Debug Production', 'Debug Development', 'Debug AdHoc', 'Debug Staging']) linkage = ENV['USE_FRAMEWORKS'] if linkage != nil @@ -24,6 +24,16 @@ end target 'NewExpensify' do permissions_path = '../node_modules/react-native-permissions/ios' + project 'NewExpensify', + 'Debug Development' => :debug, + 'Debug AdHoc' => :debug, + 'Debug Staging' => :debug, + 'Debug Production' => :debug, + 'Release Development' => :release, + 'Release AdHoc' => :release, + 'Release Staging' => :release, + 'Release Production' => :release + pod 'Permission-LocationAccuracy', :path => "#{permissions_path}/LocationAccuracy" pod 'Permission-LocationAlways', :path => "#{permissions_path}/LocationAlways" pod 'Permission-LocationWhenInUse', :path => "#{permissions_path}/LocationWhenInUse" diff --git a/ios/Podfile.lock b/ios/Podfile.lock index 86707162d74c..61e8cbad4ef9 100644 --- a/ios/Podfile.lock +++ b/ios/Podfile.lock @@ -1119,6 +1119,6 @@ SPEC CHECKSUMS: Yoga: f87bd008d34c18bf990d4371200802f2866ce18c YogaKit: f782866e155069a2cca2517aafea43200b01fd5a -PODFILE CHECKSUM: cd132e281e9e3d7e6ec2c99c08e6ec32b37886f8 +PODFILE CHECKSUM: 89d9156f0768c9b437c69034259f28fd5a53af75 COCOAPODS: 1.11.3 diff --git a/package.json b/package.json index e7dcca0db188..0a44c1b9ebb6 100644 --- a/package.json +++ b/package.json @@ -10,7 +10,7 @@ "postinstall": "npx patch-package && cd desktop && npm install", "clean": "npx react-native clean-project-auto", "android": "scripts/set-pusher-suffix.sh && npx react-native run-android --port=8083 --variant=developmentDebug --appId=com.expensify.chat.dev", - "ios": "scripts/set-pusher-suffix.sh && npx react-native run-ios --port=8082", + "ios": "scripts/set-pusher-suffix.sh && npx react-native run-ios --port=8082 --configuration=\"DebugDevelopment\" --scheme=\"NewExpensifyDev\"", "ipad": "npx react-native run-ios --port=8082 --simulator=\"iPad Pro (12.9-inch) (4th generation)\"", "ipad-sm": "npx react-native run-ios --port=8082 --simulator=\"iPad Pro (9.7-inch)\"", "start": "npx react-native start", From d5e9a410f3d1184f1b35465ecf2cbe802e1787ab Mon Sep 17 00:00:00 2001 From: staszekscp Date: Tue, 18 Apr 2023 15:30:10 +0200 Subject: [PATCH 09/51] add icon to schemes --- fastlane/Fastfile | 6 +- ios/NewExpensify.xcodeproj/project.pbxproj | 34 +++-- ...ev.xcscheme => New Expensify Dev.xcscheme} | 6 +- .../AppIconAdHoc.appiconset/Contents.json | 122 ++++++++++++++++++ .../Icon-App-20x20@1x.png | Bin 0 -> 829 bytes .../Icon-App-20x20@2x.png | Bin 0 -> 2341 bytes .../Icon-App-20x20@3x.png | Bin 0 -> 4336 bytes .../Icon-App-29x29@1x.png | Bin 0 -> 1442 bytes .../Icon-App-29x29@2x.png | Bin 0 -> 4084 bytes .../Icon-App-29x29@3x.png | Bin 0 -> 7186 bytes .../Icon-App-40x40@1x.png | Bin 0 -> 2341 bytes .../Icon-App-40x40@2x.png | Bin 0 -> 6825 bytes .../Icon-App-40x40@3x.png | Bin 0 -> 12766 bytes .../Icon-App-60x60@2x.png | Bin 0 -> 12766 bytes .../Icon-App-60x60@3x.png | Bin 0 -> 26911 bytes .../Icon-App-76x76@1x.png | Bin 0 -> 6168 bytes .../Icon-App-76x76@2x.png | Bin 0 -> 18894 bytes .../Icon-App-83.5x83.5@2x.png | Bin 0 -> 21552 bytes .../ItunesArtwork@2x.png | Bin 0 -> 116147 bytes .../AppIconDev.appiconset/Contents.json | 122 ++++++++++++++++++ .../Icon-App-20x20@1x.png | Bin 0 -> 844 bytes .../Icon-App-20x20@2x.png | Bin 0 -> 2291 bytes .../Icon-App-20x20@3x.png | Bin 0 -> 4276 bytes .../Icon-App-29x29@1x.png | Bin 0 -> 1434 bytes .../Icon-App-29x29@2x.png | Bin 0 -> 4054 bytes .../Icon-App-29x29@3x.png | Bin 0 -> 7009 bytes .../Icon-App-40x40@1x.png | Bin 0 -> 2291 bytes .../Icon-App-40x40@2x.png | Bin 0 -> 6698 bytes .../Icon-App-40x40@3x.png | Bin 0 -> 12652 bytes .../Icon-App-60x60@2x.png | Bin 0 -> 12652 bytes .../Icon-App-60x60@3x.png | Bin 0 -> 26242 bytes .../Icon-App-76x76@1x.png | Bin 0 -> 5998 bytes .../Icon-App-76x76@2x.png | Bin 0 -> 18319 bytes .../Icon-App-83.5x83.5@2x.png | Bin 0 -> 21173 bytes .../ItunesArtwork@2x.png | Bin 0 -> 110040 bytes .../BootSplashLogo.imageset/Contents.json | 26 ++-- .../Contents.json | 23 ++++ .../bootsplash_logo.png | Bin 0 -> 2379 bytes .../bootsplash_logo@2x.png | Bin 0 -> 4073 bytes .../bootsplash_logo@3x.png | Bin 0 -> 5701 bytes .../BootSplashLogoDev.imageset/Contents.json | 23 ++++ .../bootsplash_logo.png | Bin 0 -> 2379 bytes .../bootsplash_logo@2x.png | Bin 0 -> 4073 bytes .../bootsplash_logo@3x.png | Bin 0 -> 5701 bytes .../Images.xcassets/Contents.json | 4 +- 45 files changed, 332 insertions(+), 34 deletions(-) rename ios/NewExpensify.xcodeproj/xcshareddata/xcschemes/{NewExpensifyDev.xcscheme => New Expensify Dev.xcscheme} (95%) create mode 100644 ios/NewExpensify/Images.xcassets/AppIconAdHoc.appiconset/Contents.json create mode 100644 ios/NewExpensify/Images.xcassets/AppIconAdHoc.appiconset/Icon-App-20x20@1x.png create mode 100644 ios/NewExpensify/Images.xcassets/AppIconAdHoc.appiconset/Icon-App-20x20@2x.png create mode 100644 ios/NewExpensify/Images.xcassets/AppIconAdHoc.appiconset/Icon-App-20x20@3x.png create mode 100644 ios/NewExpensify/Images.xcassets/AppIconAdHoc.appiconset/Icon-App-29x29@1x.png create mode 100644 ios/NewExpensify/Images.xcassets/AppIconAdHoc.appiconset/Icon-App-29x29@2x.png create mode 100644 ios/NewExpensify/Images.xcassets/AppIconAdHoc.appiconset/Icon-App-29x29@3x.png create mode 100644 ios/NewExpensify/Images.xcassets/AppIconAdHoc.appiconset/Icon-App-40x40@1x.png create mode 100644 ios/NewExpensify/Images.xcassets/AppIconAdHoc.appiconset/Icon-App-40x40@2x.png create mode 100644 ios/NewExpensify/Images.xcassets/AppIconAdHoc.appiconset/Icon-App-40x40@3x.png create mode 100644 ios/NewExpensify/Images.xcassets/AppIconAdHoc.appiconset/Icon-App-60x60@2x.png create mode 100644 ios/NewExpensify/Images.xcassets/AppIconAdHoc.appiconset/Icon-App-60x60@3x.png create mode 100644 ios/NewExpensify/Images.xcassets/AppIconAdHoc.appiconset/Icon-App-76x76@1x.png create mode 100644 ios/NewExpensify/Images.xcassets/AppIconAdHoc.appiconset/Icon-App-76x76@2x.png create mode 100644 ios/NewExpensify/Images.xcassets/AppIconAdHoc.appiconset/Icon-App-83.5x83.5@2x.png create mode 100644 ios/NewExpensify/Images.xcassets/AppIconAdHoc.appiconset/ItunesArtwork@2x.png create mode 100644 ios/NewExpensify/Images.xcassets/AppIconDev.appiconset/Contents.json create mode 100644 ios/NewExpensify/Images.xcassets/AppIconDev.appiconset/Icon-App-20x20@1x.png create mode 100644 ios/NewExpensify/Images.xcassets/AppIconDev.appiconset/Icon-App-20x20@2x.png create mode 100644 ios/NewExpensify/Images.xcassets/AppIconDev.appiconset/Icon-App-20x20@3x.png create mode 100644 ios/NewExpensify/Images.xcassets/AppIconDev.appiconset/Icon-App-29x29@1x.png create mode 100644 ios/NewExpensify/Images.xcassets/AppIconDev.appiconset/Icon-App-29x29@2x.png create mode 100644 ios/NewExpensify/Images.xcassets/AppIconDev.appiconset/Icon-App-29x29@3x.png create mode 100644 ios/NewExpensify/Images.xcassets/AppIconDev.appiconset/Icon-App-40x40@1x.png create mode 100644 ios/NewExpensify/Images.xcassets/AppIconDev.appiconset/Icon-App-40x40@2x.png create mode 100644 ios/NewExpensify/Images.xcassets/AppIconDev.appiconset/Icon-App-40x40@3x.png create mode 100644 ios/NewExpensify/Images.xcassets/AppIconDev.appiconset/Icon-App-60x60@2x.png create mode 100644 ios/NewExpensify/Images.xcassets/AppIconDev.appiconset/Icon-App-60x60@3x.png create mode 100644 ios/NewExpensify/Images.xcassets/AppIconDev.appiconset/Icon-App-76x76@1x.png create mode 100644 ios/NewExpensify/Images.xcassets/AppIconDev.appiconset/Icon-App-76x76@2x.png create mode 100644 ios/NewExpensify/Images.xcassets/AppIconDev.appiconset/Icon-App-83.5x83.5@2x.png create mode 100644 ios/NewExpensify/Images.xcassets/AppIconDev.appiconset/ItunesArtwork@2x.png create mode 100644 ios/NewExpensify/Images.xcassets/BootSplashLogoAdHoc.imageset/Contents.json create mode 100644 ios/NewExpensify/Images.xcassets/BootSplashLogoAdHoc.imageset/bootsplash_logo.png create mode 100644 ios/NewExpensify/Images.xcassets/BootSplashLogoAdHoc.imageset/bootsplash_logo@2x.png create mode 100644 ios/NewExpensify/Images.xcassets/BootSplashLogoAdHoc.imageset/bootsplash_logo@3x.png create mode 100644 ios/NewExpensify/Images.xcassets/BootSplashLogoDev.imageset/Contents.json create mode 100644 ios/NewExpensify/Images.xcassets/BootSplashLogoDev.imageset/bootsplash_logo.png create mode 100644 ios/NewExpensify/Images.xcassets/BootSplashLogoDev.imageset/bootsplash_logo@2x.png create mode 100644 ios/NewExpensify/Images.xcassets/BootSplashLogoDev.imageset/bootsplash_logo@3x.png diff --git a/fastlane/Fastfile b/fastlane/Fastfile index 7dc2fcc3196f..5459752496d1 100644 --- a/fastlane/Fastfile +++ b/fastlane/Fastfile @@ -114,7 +114,7 @@ platform :ios do build_app( workspace: "./ios/NewExpensify.xcworkspace", - scheme: "NewExpensify" + scheme: "New Expensify" ) end @@ -147,7 +147,7 @@ platform :ios do build_app( workspace: "./ios/NewExpensify.xcworkspace", skip_profile_detection: true, - scheme: "NewExpensify", + scheme: "New Expensify AdHoc", xcargs: { :PROVISIONING_PROFILE_SPECIFIER => "chat_expensify_adhoc", }, export_method: "ad-hoc", export_options: { @@ -200,7 +200,7 @@ platform :ios do build_app( workspace: "./ios/NewExpensify.xcworkspace", - scheme: "NewExpensify", + scheme: "New Expensify", export_options: { manageAppVersionAndBuildNumber: false } diff --git a/ios/NewExpensify.xcodeproj/project.pbxproj b/ios/NewExpensify.xcodeproj/project.pbxproj index 60291a1361e2..ac424af58151 100644 --- a/ios/NewExpensify.xcodeproj/project.pbxproj +++ b/ios/NewExpensify.xcodeproj/project.pbxproj @@ -625,7 +625,7 @@ /* End PBXTargetDependency section */ /* Begin XCBuildConfiguration section */ - 00E356F61AD99517003FC87E /* DebugDevelopment */ = { + 00E356F61AD99517003FC87E /* Debug Development */ = { isa = XCBuildConfiguration; baseConfigurationReference = 2E0F63FDD5228F12D38D693D /* Pods-NewExpensify-NewExpensifyTests.debug development.xcconfig */; buildSettings = { @@ -648,7 +648,7 @@ PRODUCT_NAME = "$(TARGET_NAME)"; TEST_HOST = "$(BUILT_PRODUCTS_DIR)/NewExpensify.app/NewExpensify"; }; - name = DebugDevelopment; + name = "Debug Development"; }; 00E356F71AD99517003FC87E /* Release Development */ = { isa = XCBuildConfiguration; @@ -673,11 +673,12 @@ }; name = "Release Development"; }; - 13B07F941A680F5B00A75B9A /* DebugDevelopment */ = { + 13B07F941A680F5B00A75B9A /* Debug Development */ = { isa = XCBuildConfiguration; baseConfigurationReference = 04AE503EFB65C54C6421A21C /* Pods-NewExpensify.debug development.xcconfig */; buildSettings = { - ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + ASSETCATALOG_COMPILER_APPICON_NAME = AppIconDev; + ASSETCATALOG_COMPILER_INCLUDE_ALL_APPICON_ASSETS = NO; CLANG_ENABLE_MODULES = YES; CODE_SIGN_ENTITLEMENTS = NewExpensify/Chat.entitlements; CODE_SIGN_IDENTITY = "iPhone Distribution"; @@ -703,13 +704,14 @@ TARGETED_DEVICE_FAMILY = "1,2"; VERSIONING_SYSTEM = "apple-generic"; }; - name = DebugDevelopment; + name = "Debug Development"; }; 13B07F951A680F5B00A75B9A /* Release Development */ = { isa = XCBuildConfiguration; baseConfigurationReference = 217521EF395019214E1FD024 /* Pods-NewExpensify.release development.xcconfig */; buildSettings = { - ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + ASSETCATALOG_COMPILER_APPICON_NAME = AppIconDev; + ASSETCATALOG_COMPILER_INCLUDE_ALL_APPICON_ASSETS = NO; CLANG_ENABLE_MODULES = YES; CODE_SIGN_ENTITLEMENTS = NewExpensify/Chat.entitlements; CODE_SIGN_IDENTITY = "iPhone Distribution"; @@ -735,7 +737,7 @@ }; name = "Release Development"; }; - 83CBBA201A601CBA00E9B192 /* DebugDevelopment */ = { + 83CBBA201A601CBA00E9B192 /* Debug Development */ = { isa = XCBuildConfiguration; buildSettings = { ALWAYS_SEARCH_USER_PATHS = NO; @@ -796,7 +798,7 @@ REACT_NATIVE_PATH = "${PODS_ROOT}/../../node_modules/react-native"; SDKROOT = iphoneos; }; - name = DebugDevelopment; + name = "Debug Development"; }; 83CBBA211A601CBA00E9B192 /* Release Development */ = { isa = XCBuildConfiguration; @@ -923,6 +925,7 @@ baseConfigurationReference = BE5D56AF4DB6A25E47D361DC /* Pods-NewExpensify.debug production.xcconfig */; buildSettings = { ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + ASSETCATALOG_COMPILER_INCLUDE_ALL_APPICON_ASSETS = NO; CLANG_ENABLE_MODULES = YES; CODE_SIGN_ENTITLEMENTS = NewExpensify/Chat.entitlements; CODE_SIGN_IDENTITY = "iPhone Distribution"; @@ -1044,6 +1047,7 @@ baseConfigurationReference = D75E95E752F1B927C07EFEAA /* Pods-NewExpensify.debug staging.xcconfig */; buildSettings = { ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + ASSETCATALOG_COMPILER_INCLUDE_ALL_APPICON_ASSETS = NO; CLANG_ENABLE_MODULES = YES; CODE_SIGN_ENTITLEMENTS = NewExpensify/Chat.entitlements; CODE_SIGN_IDENTITY = "iPhone Distribution"; @@ -1163,7 +1167,8 @@ isa = XCBuildConfiguration; baseConfigurationReference = 350474CA00D741EB18BA356D /* Pods-NewExpensify.debug adhoc.xcconfig */; buildSettings = { - ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + ASSETCATALOG_COMPILER_APPICON_NAME = AppIconAdHoc; + ASSETCATALOG_COMPILER_INCLUDE_ALL_APPICON_ASSETS = NO; CLANG_ENABLE_MODULES = YES; CODE_SIGN_ENTITLEMENTS = NewExpensify/Chat.entitlements; CODE_SIGN_IDENTITY = "iPhone Distribution"; @@ -1278,6 +1283,7 @@ baseConfigurationReference = EB898CE48C59A29BD2334AD7 /* Pods-NewExpensify.release production.xcconfig */; buildSettings = { ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + ASSETCATALOG_COMPILER_INCLUDE_ALL_APPICON_ASSETS = NO; CLANG_ENABLE_MODULES = YES; CODE_SIGN_ENTITLEMENTS = NewExpensify/Chat.entitlements; CODE_SIGN_IDENTITY = "iPhone Distribution"; @@ -1387,6 +1393,7 @@ baseConfigurationReference = F760457136098BA2628C3A90 /* Pods-NewExpensify.release staging.xcconfig */; buildSettings = { ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + ASSETCATALOG_COMPILER_INCLUDE_ALL_APPICON_ASSETS = NO; CLANG_ENABLE_MODULES = YES; CODE_SIGN_ENTITLEMENTS = NewExpensify/Chat.entitlements; CODE_SIGN_IDENTITY = "iPhone Distribution"; @@ -1496,7 +1503,8 @@ isa = XCBuildConfiguration; baseConfigurationReference = 15A9AE9FCEA8582EC9D4B818 /* Pods-NewExpensify.release adhoc.xcconfig */; buildSettings = { - ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + ASSETCATALOG_COMPILER_APPICON_NAME = AppIconAdHoc; + ASSETCATALOG_COMPILER_INCLUDE_ALL_APPICON_ASSETS = NO; CLANG_ENABLE_MODULES = YES; CODE_SIGN_ENTITLEMENTS = NewExpensify/Chat.entitlements; CODE_SIGN_IDENTITY = "iPhone Distribution"; @@ -1551,7 +1559,7 @@ 00E357021AD99517003FC87E /* Build configuration list for PBXNativeTarget "NewExpensifyTests" */ = { isa = XCConfigurationList; buildConfigurations = ( - 00E356F61AD99517003FC87E /* DebugDevelopment */, + 00E356F61AD99517003FC87E /* Debug Development */, CF9AF94629EE927A001FA527 /* Debug AdHoc */, CF9AF94329EE9278001FA527 /* Debug Staging */, CF9AF94029EE9276001FA527 /* Debug Production */, @@ -1566,7 +1574,7 @@ 13B07F931A680F5B00A75B9A /* Build configuration list for PBXNativeTarget "NewExpensify" */ = { isa = XCConfigurationList; buildConfigurations = ( - 13B07F941A680F5B00A75B9A /* DebugDevelopment */, + 13B07F941A680F5B00A75B9A /* Debug Development */, CF9AF94529EE927A001FA527 /* Debug AdHoc */, CF9AF94229EE9278001FA527 /* Debug Staging */, CF9AF93F29EE9276001FA527 /* Debug Production */, @@ -1581,7 +1589,7 @@ 83CBB9FA1A601CBA00E9B192 /* Build configuration list for PBXProject "NewExpensify" */ = { isa = XCConfigurationList; buildConfigurations = ( - 83CBBA201A601CBA00E9B192 /* DebugDevelopment */, + 83CBBA201A601CBA00E9B192 /* Debug Development */, CF9AF94429EE927A001FA527 /* Debug AdHoc */, CF9AF94129EE9278001FA527 /* Debug Staging */, CF9AF93E29EE9276001FA527 /* Debug Production */, diff --git a/ios/NewExpensify.xcodeproj/xcshareddata/xcschemes/NewExpensifyDev.xcscheme b/ios/NewExpensify.xcodeproj/xcshareddata/xcschemes/New Expensify Dev.xcscheme similarity index 95% rename from ios/NewExpensify.xcodeproj/xcshareddata/xcschemes/NewExpensifyDev.xcscheme rename to ios/NewExpensify.xcodeproj/xcshareddata/xcschemes/New Expensify Dev.xcscheme index 62c6886c1b2c..77f512242f67 100644 --- a/ios/NewExpensify.xcodeproj/xcshareddata/xcschemes/NewExpensifyDev.xcscheme +++ b/ios/NewExpensify.xcodeproj/xcshareddata/xcschemes/New Expensify Dev.xcscheme @@ -23,7 +23,7 @@ @@ -41,7 +41,7 @@ + buildConfiguration = "Debug Development"> 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 LNkvXXu0mjfTAqAc literal 0 HcmV?d00001 diff --git a/ios/NewExpensify/Images.xcassets/AppIconAdHoc.appiconset/Icon-App-20x20@3x.png b/ios/NewExpensify/Images.xcassets/AppIconAdHoc.appiconset/Icon-App-20x20@3x.png new file mode 100644 index 0000000000000000000000000000000000000000..4daded6a892afa92e5156865086e5803d3caf6dc GIT binary patch literal 4336 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 literal 0 HcmV?d00001 diff --git a/ios/NewExpensify/Images.xcassets/AppIconAdHoc.appiconset/Icon-App-29x29@2x.png b/ios/NewExpensify/Images.xcassets/AppIconAdHoc.appiconset/Icon-App-29x29@2x.png new file mode 100644 index 0000000000000000000000000000000000000000..67c46ea89251fb1cf5be11b5197e536e417367e2 GIT binary patch literal 4084 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 LNkvXXu0mjfTAqAc literal 0 HcmV?d00001 diff --git a/ios/NewExpensify/Images.xcassets/AppIconAdHoc.appiconset/Icon-App-40x40@2x.png b/ios/NewExpensify/Images.xcassets/AppIconAdHoc.appiconset/Icon-App-40x40@2x.png new file mode 100644 index 0000000000000000000000000000000000000000..cb7de08d070ad14cc1b884ec059d1b76d238b148 GIT binary patch literal 6825 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 Xt&1mhdVQqt00000NkvXXu0mjfk=9(& literal 0 HcmV?d00001 diff --git a/ios/NewExpensify/Images.xcassets/AppIconAdHoc.appiconset/Icon-App-40x40@3x.png b/ios/NewExpensify/Images.xcassets/AppIconAdHoc.appiconset/Icon-App-40x40@3x.png new file mode 100644 index 0000000000000000000000000000000000000000..66e5579d084f30f6da7b8f6368bc8424fc134533 GIT binary patch literal 12766 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 literal 0 HcmV?d00001 diff --git a/ios/NewExpensify/Images.xcassets/AppIconAdHoc.appiconset/ItunesArtwork@2x.png b/ios/NewExpensify/Images.xcassets/AppIconAdHoc.appiconset/ItunesArtwork@2x.png new file mode 100644 index 0000000000000000000000000000000000000000..0f23e388ce693af14b140717dbe879ea9457dfa6 GIT binary patch literal 116147 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 Wq#z#Pkqc6N9(Q{-&v=Oqwu56SLJ^MvAwh(c zcb@n|_4``z!H z^PO``qECOVpn#y*;jig~xO-XF!M~H-gD&rr4x+{J3d4)LTAu(EMNrqEmjU>;_Jx;n zX|HU>0xINJuO6DJyB8u-yrn@^-8i}SWlR=6)5{m)i4)f$|80&Hb$z`(g9US@4JCU@ z{-yX)asYE9rR`ekQwCgKiIR5@1)|adiUX8JPEC;SoVWqCusUPjgK%ScW28P-Y{&=_ z_nAPX1&5XrrtHfMoSQUOn8Yxe+BuxTEVk~I5Ly*zR-sveS_C1eNY2ui(wZ(x)iG#| zIdFbuo@x=td}6@PCvb2MyKms-861ybFojv-00yv9gS7_SxB|C2u+@fk4UIg=$^jhzfyGz^BF>pov0%44>`6KVQMuCy*p?wFz&p8#~>GnNl#&Cu4Yh z4tssrJA?gmJKw(zKin}lD4RA#ojB6Oo490JoX?9IxWgg*{W<*Y8T2QxwE_>f;K3$r zx1m+F2~*clGxu;}puRkSuMVKshZkq?@ESy6Dk*l!X;_ZX%)~*q5cTsU3g;K_kLU35 zH|A&e*Nug{>#$l+&FWRfgVYMps6eL)J6GWThAs3~2ciIt6OaIcEV?rd7gGlVSk#w- z&kZK<=^lLa%N42s#dR=+&-X1LwpPrnZ*`GsWb7Ud;ZOgC=WjAuC?5f4(hq+CH#-@l^@>gT z_z>1xu+xT4Bh|_8WRO@*=bj#0v_9N2pR0!1dL}U(4&Y@!^%nw9fqxcba2gl=YrAb0 z**mj2UJsyMhp?O|QXkafz>~R&@WIfelSHcS@QXGtpV3pi}E2@fV8TG^sTFP z8}m^Q4hA;Y&5mWBOBu{Z(s%~1&R{x+opoDrE?Tv02LZmn2EVv(j-Q3J0bZ?vPjiBe zwY_TR(LTI-W4_$1lz`-Q(2J5P45x53f-o=<_6#gLytGt9XxGf~J-E;T45U0StW@Dz z+cffc1fvOPW0{Hb^a*HUiGMJ)%+PH>B{UWAUa(LlDLgxYKYVEc00!=62j07Zw5usH zBUjK$m}Q@VD>igd4io}lp#t{pCJS4L z1vb|#URsZq0BYgo;vvi5`{;};GXQ4VFvvxAetd^Sq%>6COe_QFj!IzX#mwZyGgl(7 zFz2lfJluqai^NdO$K10Dh`K`Fm2X_kEg>{2E|)JtSp*n}1;t9$a_7kyW(gYQd}twx z#p=GF-Zj7SeH^Q4QSH~HYT9@*G?3e?E)W+H76E!qYgS>c2~V7e4yWe)msuV)?R+z4 zfnp~!T8WB5Hk#Vlabj~dmn%h42mK0~6=USHp4D@`zR5==Ol!o7f6VROBkH|V1VQ5j{pJK6jv21kdA3&PktoNi z#NR11l3g?m;8xeltQTiyhQKBOOd4)q&08bAiYhy&BYyeloDW}~urrzxsv^ExpT^J# znN;A#?lHgZHu&R%Z4Osz3w!w-z)VJbdexPxWdpZ|;B;)oW<4@#@FhQ(`P?v-dBRU# zobanJUU73GL~A=%NyjnLY@yQ$jECrK%GR3!wST?jb-T`=?`|?ptD!Gldy zU>lryVrBYYpIH5Oe*@mxOf^h%o2L3?#>4$Ht_>!HtLucf?m?{q^(IoSksQAU5%lDM zX!k$d=wEQ}Xu!v}*O*2j*Ietys7=gF~E)JOX!Lq72X zlX=2pi8*YCTptgSyeRS>rOF5637bc|gozjS0FuOt zrT}{DEq?dTHlJMYG7SUEEQvZCLX_n{F&PQG+-LOp+%5td1*V7Xn$>%k{5*Qzs`8rv zzBnFm=X6AE9vAa5Fswy9?Y8*jMwk87y5;D(QwcE&BP+wj5Kre;y;Q@}21raI$O4GS zl~aw1?ORHv+6>{DD0^FNYV(9pwV160;vnE65~g8@YGU$}s3ie0P01Jx#q#Jhh6}YM z?|%jXi0PQ$Tcnhx8;w*1@qfw`xTuC)l%yl$&;?B#yPcl{7fNcj$nlYFX23d+=f+|v z5Clt#%iJX2dgS}$SX7KHe+H8KLndijj#88Pz^FJt^B88%Cz3dG#PSw3WoB9Xw;isS zkic9j3Um8nNy~yL+sLHtj_%-Y>259i+Q+jn~4D7R{Wp6R=s{ru1A zHp$2TC1fkbvnZepzsm}}dX&OFFK8L|taSR$OBYV%724UIXqEbty&aFF2B>cs@ z5&ka0z4F#I+G=2=x;BBPP5r-E^AmSzz!=MTgP_HblpBa3fn>y~&1cS-V55*3Pk5{N zY%=jx^J~9JV2$Dl*`wIhm1Mm2Nu5ZkPZ5tPcR-D4yx&9VyG#GOH?K4(Z@=<>@IPGZ zF{sl_Z7=bUsq7p~Y0?3Mf~VC$l9k}>ZY!M87m&~3b@Tk~B$!kC9^92vJ_40 zIZXsi7|>iA^oY_ZUF~I@*?Ut~(}U-7)~Cgkfxq-&38m*BPzz?BKf7IU5fa2PR0u2z zm}fA};A#%z1u|VgX6GakbP`xg_0vtEl|ULnWbA3iSX ztif7}B++t=G_p)%6B}hLQWp^nNtt!rC!*3|EjqiLSeb%2rj3ETP=-z};eXEI!5KUr z!o@@dkQJ)+CO?l1Br$Xo*y_Tq4fxAlxVHm`eWaH{?2{6vy&(F#Ga?|jGmP;~y2eL+ zm4AS{=cN=8QImZ-gg>0X=g;8D5H4qG(g1O!noR8{wtM8x>~mP;FqrD+$pAio4!8R7 z#tnG)5N>WDtpuW`Fy{qYK+_#!hR3>9cag@Z5xm% zM1?cYmAU6v@OYpC{O$rqb2uNv$4?-N;6@)hX+1-f>C0V*nZl1!#%I{~*;V<{rXCUG zat6PA2)}v=Pe*E+?N}Ln=MdgHfTKS2Qq^|k0-f<}#&hWHF5KFL*Y@De8}R8V{P9Eu zFw0;(gWNf!Z*hUUt)SbDq(V5Rf+7B#GH8nhFu7{>KOVxreF>wP&e`e0d$-{y$MDKF zbW^QbjFW90(3pT&iGetVc7klK!JQp=_ef*HyySiTO!zB?|6os1B*Dv7Lk2IJVl)(@0!iRS;`#ms< zYNV+R}JVdKVc9%;aPZ4d75KqpzkAAuCgaSg+|gE(r7T%+Z0 zzt@1WC}6j%(euN*n7tk*vXx3vXsViKs*!7CSx*GktvU(PQJ3)HFv!f?rxW78&^R&?7foVrJJshw%WQ{z#pD!>KQLIK)rVxKDdk7U#oW+W;uNE3_g3N zO#hJ4N#Ly;>a(4sf{M;erRi}e6j)_4dA0kFr5G2nKeMa1^qVM->1X`j>a_7ba!(DzCBl3zIdh?VJ$_H zcsT?GtX=QJ#vV9XC|rCpROUC@ntG166*+}NtdN{phXj~lt{+j;NYhUZ_1O_caI^t$ zA1FQ_&XlG>NdkEd_Pc^ySb@IZq@m9hMVvs z3j0nkwdw)b?x_E+rPOS+i2Pok6}{-T;-yxxhDIpP^sUrg+OE!9F#n=AI&_O3A?)4xqFXrKJ_y+^j96X4rZi!(uAQh`@BA z5){-V*HVb1)da0NQBX_y*MZ*7By zz53DhsQez3Yp^XfnpO<|UM6t4XrAYq0X`IUI3V0lP#Ris75s8bYuN4y#&XcA%{SLr zh|t_`F^!i?Q$j3l8h&4@cVH1KHv*lO=I1!7?$!432shX^aIT0Bltu?FYf;??RgKUx01h25Cob}`1F5}_$XjEU zeaCmf2-sbN5ASGaBMKObBfY=Y3YhhnbQjLm#&e~~p#5xDY}6Oj_-SC+RJE!x8ccdE zy`JYVnCbr|%t&3JO^WZe;Qk)Gwy*HfU+#ore_ys8o#ZMwW|~g_YOLbs39&g7Ehg0aZ83wd%GKud2}Xen!LjLQaL zNtG2!!`WEl%6g)JsGBy>a$WJT6fBJT#=*Ki5g1t9`sf1g@9I6bXRS363`g_J3H<6i zZ45N=>te>+2U-zz(&~mkf4tDb;bN-aw>ogp_W;o{qsOhpp`~&dlL@V)$RUF z(uiu`%G~D>9~t$Jzt~k^o)_BF`t%g0S=p1Uh<3i%aI#RPHuuTAkNYj`gIS*x5oEm3 zv%kC0HS2AqZKr1i8J1{u`c~A#RFPV21iZJSSa&$nw#}y}@S`Iw_57}f+dGNWB_;hV!wOWuHBR z!wqXno-~t4i}?3$|KKKG+=^)*^k^?K;;TBOmdS$R%TqWRA(61y>M(m_pT%Kc@qNfc zgBv##54OBAYDpsYp=htAPXeBfwBniN+VaVZ`dU}Xys-~=xAES4S{|N^(!AhkH09mX zA@80IIr#YnsYop>$RdaD2S`7r=*L`aw)v`M_^(rhIa^ zNwE~FtMAv8hZS{Y>NgxY<|W@b)2c)K_SlL`eC# z)Co}CrL)L+=XA)ui!reXCQXQsUnRQ#SCHpKS3^v%PqcGD@%(#=(Gb&WBQKwW2*nq_ zBbrayznbx*rvrZW`T>`1?}wBX zDpP|LLVPu&KbVqc?vbhiDUh=hWI7?*Il%NbRJ)@Aa`K4iogZU*eTr{BL1t66bP?7U z8SSj_lm%e`OKJ@I*6hPf|BW`sq?2GfRaEqJq<~;B)r#usxx&Blm4|h$h0C^#fkjSs zIpgy2Ig2c>!iNZ^w*l=gG8@C?1*X5Pemt8XS3}JDCdJ?!GVP!g#xPD3<}O8w&rsz~ zNiCMR*Y#?VS}NuP0Anzkqwj4)`@Ujs_fpGfrcJxyRC9J3sfN?IYL@2(vn=O91g9G@ z8?6{qWXRbmMRy&F9C`5++Fhc(Lu5KZCRY?+{2sdN$l0lC9=PZve6!nQ*iI{j6;y6% z|5gvvB2&Fu6hp0<=hw*P(2Y!Fkah}pwpEjF9q6;32WN`CFQ#hh^IU^kU}AG)_+!iP z?`sj89m9T6!0976J5dafWe`Oa55Ka7|AN9PC0DB$bP_(gwaqW?>@srQ6cOd65LK(w zFjzF@8fICpWnb7vU8?JiQjdYG-X`0urp(R{%tCj;I+ z8L~T`lN9v`>r1~dFlwiKv(w`jcX#=6zt7MC9T5$pnSFiAc2Nvql8^tXdi^^qV7AaZ ztyo_&@d3PJ-1q`;2`jV)4^sLO)B05TDyprn3=oOX&2qLT3)bd2QB!U0wlpwHVg~Jm zQ9B_oAEJpeI=4WmlVakiJR>RLqZr%yvyU!jIkZrX`IcO>Y8So4Dm|F!M|7~os0$$8 z(?L780Is5htG1sl1Bm9oZB#>XHsEIVh1LR9n$xZoUQ}rfMMg<%A4-cdy~u5S8UWL! zxAh20Iybf9N0%~ceP#osg`9TSfBLzbC%|Fv%JvA(C(DY;kWhga>i`vx>Rv7_K>BkoOx#lT4k!-K!EwtO3gN@k+aDK}(NXDwngBXks)kr*U1XJ`vYM z)8=uFxn8@>ixt@56*@7prVAi z6$rQypl0By!XSpNeOTUxjUIH5AWk84Fja@nI4n%S%otQdA0-biS*}Ov2y+BiGRWS? zDZJc&Uws6(=AjY6 zVGO+?Z!ITqVHz$?o06qXSlxlE9dxb<;*bJi!}4jhu>Q4fA-z6pfTyak-h&6ru-h*m z5$yeE3ozTXy^THi={X$5Fg*q}DV1*-R56x5-mo0rIS)+>7u!eh+Y8v(hd_)-nWEF< z7T#HJ#MzdS?eBHCJrA?35>dla$B7dQY4^}bGuQGtQ44#V+H<)LAGWPNQ5dVjOalay zpKHS64E(%eW!4_IdOp$9L1JMHoF`3K?u^;z!UTMN(MToU>uNYMz80FdfwQ_ECQuo< zS^yOT?H(CvChHc)lWOYGI&AxzZB{J}?@c3Fn{*B)8>XjwXw9V&6+sKPN}?9x(B*Bd z1e=Mz+Jnsl^RnH5#WtcPO{ODsmX0J#;Rz*!laXMY`d(Rp&CV`Nz@;f`5aShSk9)bo zic_oi&{;&@$=+&UtbO|0!hAtXtjpJ88@^l|88jb*;3ri@)7K=93Je zpw};)SE59j381roM0NEIq)Pg5jb!_P?u}X2CTa|hO(kI|!{RUH8*|W4tQ#qoul6{6 zaT$`#MnzOvT;JvE$FI2k@CCKZla&c~J99 zJg>2A+^7a(WC8fbR|9rlTy_L%D( z(K;F;s($7YAKt9DN_qAo5V+DYHa=RnUK%*-E}>%(r!2>P_Qz@jn`_9pg32amr!j_7ETE$v-dG2t9#{&ZV4@adg1!9ePz5oCK07*qoM6N<$f~u;k8vpoe}Jb9+|y zs=G-2ma`mFVY?*H5L6DTDG^L{---Z)inNU>KfbxwnQyw*H0u6YH|xs08cp?i1|q2W zBDHxNe&`eIX~-9P6LZ@Lyvum}A>KrHY~iy~o8v6bAP7c;sN$1%21?UFl<{P<5uG-D zc;ow);YAZuxlo#Db+2Y^3xdHQMu-q;q<<>`b(+1vC4STuAQ#AT`?24hK#hSgfXMz0 zjDEaeSA>j0WBv_qACH#8a$OQIf)R)+iz-~2hCJr~w2ogeX}@Ozs|;pqm@Z+mg2@u5 zD_E={wFgB3bRy`tV99>!Y%6J_DInFfT%-{tEfJw^4*WB1y~Top_w#;$pU`5fxn!? zcb9N}3-guk5r?qbfh2}*3)+#ItO3#-mKn@eaJ$kqms7QXpKjnq0{?UXpB%x-5ZP&C zf}j-m2HifbK1x#sMjL6TA$S&ev~Y4k))~CNg>T-&|Gb6ouVA#$`GXc5CUDeOb3Eul z(pE-eHAQ7KRjpsn;Nn)T;Nn*O`iCpHp22vb=RUs&-GGfzn6fE-5`f&&Zoo(l>$-*h z7Y}rc1JYTp1pWCGzC2ZvU96!K!@~hQ-G`6%;X$Gr?Zyy=)u<|>{+i~h&Cx=A`fpeI zc{hQZ1^jpgCqwvfU-!QgG&K0A)lSuPT@uEd=wOxoN77u)^NZK;$5(JRQQ_Sm!1F_R zegseUVAxgP3YEEP(kO=@8hM934MZnHcy<6U-fKV`v|+yoap197-J^m;{i_8KGDM{< z*H$=woi@cv|Ke7)_{A%DGg3`G*@4d=B|gMmsuFq_$_5+EHEFol363e}hQ`zox< znfm#I0kmVt1j((1Szq6ZCVkDCA{coT6iL_RAqyySQGfaCg_`WUi5_;c2fsOnPancz zUkR(lf@Zkal)F*$?#8O!qeSn8fd;8e4As_M?H;-Pw`@{(eSHx z>XQN-?<$l3{0MWe4^g1!tg~v)yi4N#aJe-KF=3z#f@*QJfIq!~Z!VO{&mY6HL!=vF zTU_7 z6NPmzuQktsrjTDAsaBm&`er^`D^hwl(e?hJ_2A@wM;4XM)*BFxz$i@oXs8-}d97CS z@>-eg#HB@*>7&BwW(JlTf>>pm-(HV2-wj%tCy)2^0JBAkxomzMGIvWH+$;c%Y5ooh zHjel7?4+fL>eWco+bV5HFVzcCExVS(SYl@@HO2F(PCHB#3=F%NU{i99dja$!cr<`P zr`eH0qiJQ>vv|0S5(XeJ$grzt|9B14D@}E$6FAw2PODasREKA}&L1ezP%at-&Tkc} zwL-Yx*Xp7jS@`}_ zfkxVUi2{q!LTQ^U%b@2JRU1_w6)Y&Whh(|dlH;W=PGSY<-I{NDP-|mUtXj%XE(#rU zJ0~zUAZ^7uN^LLJNT0;I&v>bfX0|T-`+&hGoKmCHl@`qgm15G?gib9EIcB$Ilj#z^ zK2vm6XQpG3(4!qpE41V|c2jn=tx)rs`e zB=rJ*ZSmEc1^oUen~qF%-LMP4J=UDq3d(%w%-b?-M3BJxa$AdW*16{S%(;$urCNE; z-HhhB0)PTY+s{UYL$k^FK{*u|t(xbEz$~r$8I(cMhdl-h6KzAym3oqIFz1ivV6^>$ zqrjU|k8n-eu6_4^2d2E{fQJu9i^>4+F^MPa3O)6MN;<2IdYcwZILV2qR#N}|wnM!A z9RIBl_B&o6vwH?;B;DoHqL{ z)q()iwI=D*RyQIwJ(|j&%IL=M;XZtPUp3$_5md8*E4S>UgeEzzGfgKm+kkVu;V3AB zQN#HS-6n5@0qnH(V~hn4Q%yHT=y(1i}2DhHZFuVE4$&ZsF}p z&33n=urdgmuzWGLYt$w2q@`xn4q>r^i>V@#y>5w)3Pf}V99*XGcC6+ZHi+C%Lcl@C znqtlWbAi!PX_&9o?+?1#aj3h)os1fPmZ+5awrw$Jt0d2FwfuT8upI?uwy5swX~u0g zT4+PdYOl8GiMg?iKHkxqGphm*ab|x#(>>nb>YAfOE23^>OTIdj zC8*!Ty8aKB7LF3_5A|B=8{c2Ss~e4c6?63xVh||tf%kEFu@0b$YvR%7r3=^P_~}N^ zo~#s(ez2<=ZQYG~ph=^3?T3N-K6U&b9yMtVjZ*4XaP?YgzQ;l~xc%zsNfy4Aj(zy|R6>;j~i3fG8CnOcs28 zdc&_zZ+Q0Nj6s$YdQ(M2^X77i?8YoxA@3yR%Zo8z?6mp*AYs-Di)Q;jz^D>ujLT?7 z6Z3~dy>&9w#{>@s5C+nR_9{f>vrl>hqpAzvR2SVm1~?M_CWC@JuO1ZawReoqlj9BST6b2a7ZO3}}5 zN3RF<=3|j?i@oDqczQME-@iTM*QYlOQV6 z^Q$R=2q91K ze8^PT2)$Ltug=DNdNyXTN(s6N;Rnw!hYykE0#*ymU=P!3lTRnGm?MiRCS4<=E85o= zJQ>aTm(vk{Jl^MhzfJ1mg;d?9+8is|D8B05!y?(R2yq?!Z!RyxEU^FNlC7N=s=kW4Ing8)xyLI;xO*I4Wi8lsW zXUKSg6isfIV{^z-B+oIDL!LpphS@E|E!aB%1X;`=&oF*(*voQt^jND$y`a(f5xAP_AAfp!rYLe3lbO*4SlV6>y zhNB3X&tP&5c}9M9j?AYZ!XgYg@3$FsVshi-pN)Fdl~%5@sFgVtORiNXfzcA_*?}hR zlc7E)cr{Yry}Ia(YEQgp0{`1Ke6`;qi6B|d;mr?lbph#0O}5p6xTP9gui)Kl zWW7X|OID%b)ozzBAMWxt>5%#_g5=`4if_8cXvvi2V1kB=YwDIby2Y)WR+TqWUP)fSvwc@57PeIKab)-r6rt10Mqsh_cX zp(@q=K`Wn5#7)xXcm0Ul<(l7|k9m4MBUz>dTM(5PSXy)a^3g7TINs;m!-S=K$mE)3 z22~iUkkUsT@LuOy0zp~K)|e~`9D6}Lq(c-y6f48KozhBDD{1HZ_7%A_3V0J3#%ab^ zPlnvPUC~=-+ZhGcQNT?n=55mEy5D9Q+4mbVOM9McF%nR?O5}2!2pU{6+u{@;#%own z{pzmPF27#3v}SQ8&n7WnX4AR10ZSO00O5uCOvsg|dxfpIORsu3{cF>k!J+Q8e06 zH)+|o(!%P?jPCu=$OE(Xt0mZCR07*9POUlnhc~_;?EkJ`YnWg7_7?kYy6l7z1P~iF z)hL8o7u63Yk(0PWSr6A@E0&ghc{sP5S?v|uSF5MU z7qaobxc~c7wEY8nppPTn__?px{C|dT%Js09amVB*tgrw*UYD07*qo IM6N<$g5as?*8l(j literal 0 HcmV?d00001 diff --git a/ios/NewExpensify/Images.xcassets/AppIconDev.appiconset/Icon-App-29x29@3x.png b/ios/NewExpensify/Images.xcassets/AppIconDev.appiconset/Icon-App-29x29@3x.png new file mode 100644 index 0000000000000000000000000000000000000000..4499c44f08bb19ebf94d8de33750b2b48da50e48 GIT binary patch literal 7009 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 literal 0 HcmV?d00001 diff --git a/ios/NewExpensify/Images.xcassets/AppIconDev.appiconset/Icon-App-40x40@1x.png b/ios/NewExpensify/Images.xcassets/AppIconDev.appiconset/Icon-App-40x40@1x.png new file mode 100644 index 0000000000000000000000000000000000000000..799e00d4dab071b5de5eff90f43d3edc0acfb697 GIT binary patch literal 2291 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 ALjV8( literal 0 HcmV?d00001 diff --git a/ios/NewExpensify/Images.xcassets/AppIconDev.appiconset/Icon-App-40x40@3x.png b/ios/NewExpensify/Images.xcassets/AppIconDev.appiconset/Icon-App-40x40@3x.png new file mode 100644 index 0000000000000000000000000000000000000000..b5b433515b0f946195120b6a3c001bc07548e0ff GIT binary patch literal 12652 zcmV-yF_X@TP)WW zDEY~6cKE?h{vV`&!2gEdErr8Y1nCeNVUx6YiKMkFE_aDNabspMz+ler?DRucRcB>Y ze=}>Fc0~-(Uw2hj-kEiDHC1o@C4&f3*!@QU`QPr^J(9Zq2LNVQm*RW2oi3#7#Z4O+ zE%z0g0^fB)s!ixqKQqXXsbgV>I^^zU=!|gTl-85_we&~r)y)VG4_CEicR>n>>$eI5 zV~sc)U^$B1C7F)ni}u2dM6rBZM#Hd(sTmHExfdyhql?vpS@o?Fv$|;&J3Qj%ItYT} z=WPmXOM(Yt{7C^K*N=vyh3?QT6r}bJEn@!9A{sP_+KJEz20+^SRYR+}2~3W0@q}qS zH4OnCHI+##fp43!Mh}3w`3p+p=_RAMXzoY2D}EchN}2BaYQfL5J6=re4)5+yJ-DEqd3J(Jl*v08WHopw)u4>(=o+5stGyjjIkhIxYifrBz#lRf232 zGSB>v8OGwBB^VUwv1qZX>lx>1(i%XDR)d3y>s8zfCznyb>5sVNJgth+%{|0%%Ev`k zMEGm3M78N72t~PRBA`};YxnJML|Sf`#YRAFZ51J;VAwRq{s^dN60%q=*!=GWZJtNM zRKitNs>tPLk!vYIVH?0%uNt{g&meX}rMTaqs9v}&?vvEDFWx|cyE5(Ki{`iP4>?>i zZKQC71;}+~e53GfX7wS!dyIo;NW#5TiKMHnvlUMEKa4 zq&rlK5bBU7%Gc+{LUe4kCac?8FOaxLC8?-ggfybqZRybMgQYre5y5J)Vl#q2E`hpi=MU949&%CvP2qBy17pRA|}9)W%~ z_-H0(gHm$YYHuy)giGfFhk}ivvlA+%U$*(r9wP z-%~dNEJlJ~&TU$w)!)`om@`YAfe%ernz{X(-i;MNr+jjInm8l{^{nC zJIrJU+!z_F+p{ycjGNYtPgDX0m&wFNO4~#hVPRQ+uiV*5$zDK(ntlzas0-&#?TnJ# zv-qp$Z7dA!8scUO+4NJi8*QUe-f~mO9#{rQPP3zjIq9lL!Bw5YP2^m3u72d^RoppM zaRlY)it+}E?-RxDo+)jcV}%VpApwJmGMYzTsW@uaxagoD-bDx`9hM@5ED{kAb?xg| zrsw8#qk0M!F``5%wDr$VP%Pq%(AhB1UnrQ?T9cB~s08-EDD?mN>^}Ud52GDc9lcYppa_|jaeY+WimF+4P7+B{*u%^ zZJg5@7}wy@1Q<+!qcQks1RRXOg9$L1%6zuBf~o|16|m5izxfW(uYhg^bPAv-B2O6; zKjYSElD0sH_XH`}Y>GgtK0)YVG~p!4lNePD+;moFT(dSDYqiz_lhR_sIbvF#hmc*1 zKyfexKRE_JJ_NQ7fz3VO@eyz^0*=SPcq(*wPvqehB!8U}Jl6phyTJN9aA6rZzW}T+ zfY#^03q28dNf9a$zLCB19$e zfRyFH39b#My1HftFs;QJpBw>?_JKRQ^7mj5*gXb@(?*avch9prK_mEH39Qb6FD(OC zSApkNfs0GPnR&7DvdE4mXLOdabhH#zQRfcUn-PGLz!Nb_vO8-WyQ?Po0Gjg{G41-L++=ffW3x#Vhe8;fy6nJ_JJR1PFcY)t*f?wMJK6eqgu_l5h zq(VzVnhzlg&uHZ=z&4bsu>9k+|aF#4w4F;BEWy_!llgiiScCzbQA@xuK6&7|rvVC3(BMD=z%qE%4_q z0&iRfo?8X=%7#xGr7Y{T5@aexR;+kxJ!Z%^NIe(4tEhpVQOP0G5(?6)+LBse>69PN zYIl#pzuf|UdK>s)2RIxfJ4G6n&8X4Vf+XARb%3QVu+#$|iW8!Q(^V&QtIoUISh^53J6Cl1U*Gwi13Il6TZkh~fIC zhN~1+yLI+4*a{*W%9J~^NZ1Tot6H1Ub0cJ)GI0MH_-A*4U*D4qc|29jRUHOg+;zVK zR{Frk5^!l*{?_NkW%{vg=`2|@nHiYW;Nb*xGzRYvB|CqxCx4s!!0telpyrh6nr#Q8 z5JvdnKJbUvfD21b$iA&%s*k}o#%lP{4>r%J;YGOb`cNLIidqqb+04R_s1FnG+Df7@ zR{NXZTr)5jgWul)zJE)yj1WNbZ>NfJCc27mAvc>ghQ?-}sqxDj?ltNT5vrQZHfuK(f{@g$yRJ+_kg8nrabafS(=# zzq|+h@MF>ZagAsWHzW!qZuY{G2==uN(DgN7xz|iMoP>`aK6s0;uFe7}Nhb5pErQnP zffv`oubdYlzqbuM+?RN5+cOI-)4J(fyNVbwW!2h!LkYJfmYWhe2t`{J#a6rU5GuC? z(w0Yo=|-bGpAUz?Pw$B3KHP66Dtu$TdbQM(p~#o705{HnR{CPG8cCZ)CgFjj>Itr3 zM5{aDf!haF6*AfJ`bF@yHQ?p*qMUC%lH^QVQ@4~!kp=IbHGgx=%iwHpSva~aAr*RT z!IbaE`>klJEApC^xIse+*Uf)VkH9~@1AOmyGOh%W&hQX0R{_`7fH$v#-nf#_Ock9` zf)dSC83lu9h_B-r<@+z<%Bn4OO3?ZOcx@hdVI6$)9Psly!2M?upZgu)#dYADH-P22 z7!S(f;_+aB^xF&`N1M9<(eh{rIm+vWwo<8TvM>WMVup5`is&R=M=V?=>=1K*c~30Y z3pezw;4Jrm&tC-IybgMC9hmR7cqWBg4&S7zVoqq|8LZm+Tp{d~K%@**5_okU^oQ5L z&#eHTJO%a!z;YjWejRjWS*$*{djp6SI>^HG%L%ia=NflA`iT@byV#HsvQ;GAQFxw- z)w&GE;I|(FKl)gPK~aCMT~PpQec;V&z&CGzE-V9`Vg^*BcoBX|Sh+9~_@@|}+oWK3 zI{Icr;JFUy#k0V*GZJ&lLhvm#<8oeyGX1jQw^8~qMX7~qkkw(1w15+(w+#uY+s!sK z#VxQ;Yw-Jzf&cyyaQB&;ZiEs9M7SG^z}K$<-?#x@7Q? zq9LetdyV1VZ~}gJ3;6YYnW0J&IRe(^fUjQ%eZ>pc#xD~@TNF4!CTqDW=B1K~+lKn2 z`ZX~>0;7?krrN;}{EIul&+h_9Be}VA1PrI(r7q|zS7oj|QR-aL-lnbSc&=x%G#}d( z#1qoW+~y`TOT7L2+cMVGQ+!@CmwS>>edC6>W$U^lWVrd)$MBOFkzCIz85d*}fJ$qv zoWVI(6n=atvtWm#hVfID`R<>5B3p!BSZ~KCLd6R=Lr*|~(G0m-ldQ&vN5hM@of_7? zfr0%I_*eH`+^vz6ekDVpZ%RTH80BB2(qTcn%)=4*y)EEi`02v(|4AXp%GAr}K?~i~ zZANRr#=^$6nu1l{Z(IW(JOTgmE^vMkwA?eDD#^C#XyCt#;|$oLU=>N;As55bOgD@V zz%{V|Pgxf0-+m}dezp|kCNZvqE-Xu;5x`{Jr*{9l$H4dA6YuckPNS}W1 zlTFNQM(x=J0BiH$*Ds2j-Wwp9d3v-Dy!8NlbrrNar;;`elOnjY6U|uJWKuU+r)3Hn zCPap%T(}W5kEgPS>YYtldW#Ys7T5f_i=Z!EmKmySpB_`K~ zR6M|(*0Qzr;~lq;N_R*y8UNBbSrzgV89Jy$ao$)_uux5#a+kAQY?dBVl5M9gJn@N4 z4h}_?nww<-dVXD2q53u|l6bn0cVsunq;BZR!B6HYID>7|*1Q1TM$oKhxq zC%~hFX7{6Cs4M`SUj$y=04?_u1e>vGt}_$!bO}176O=a3pt=aUWUL`_f4R_=y1{H` z+D#K=ThXfj8MU6P;h)t1ti-}2$g}Hux2TgNeXSF{SsU|1vT22^y%NQO?3A*P z`qlID=7e%w03AqZgPjPvJzqF^F8Z|PU??ww4Mt6$UPF5w;4^1|wSFd7Qc4shP5CPA#fJ;m zF$1Uy&_BBgtj)(sn8r;jY@7RIG_Rc6K6C5m35|-pwK?GCIoW1=JW<54?6bbJEA!WL zRm<9sW`@4jv^4kKYLcz!8GcgSQ{~CAxRL7@@DHwT$I3Tz*^jS&jS3GP2Ff@fx!q*O8sNX1A`&}afY+Cz9P(VvO~$mGVwWpPbW zTZ6eDdPD-S8f+6h#Z9*N6~3(7+G}5}C7GEOm$jR2%NcUrb_?Lrl1zF;-i!s0hx@>2 z8pAj-jO6JvD%3`#qQDXY$OiD8Bh`^|=}Yctgwm*>b<@el0^Lumx#sas+-zHY#Te4{ z4ZK-n^oSoB!?4!`8A+U7kVThV**TIo7=4=)E!I|Q_}j7`tdX9{Au+WotihPEf;A5EL1?N8-5Di6UG21d1 zz-S8o55EL=T8>(nRr(e1XD@+XSQmlhN+eY62~?c6?DPsf-<3@S1*sh>uEAg|rvwE< z{1h@VC4N6R7vpBZ_F?02oW3~55abuTZh}3pVfo~NlkiA#Kaq|wXcdg#N^yE~U1fe8$ouEv%QLb*JAU@+|BTtnfM@n>pD^4uY-`6hM zU65+v`D)vjg(!Ytjl!X>C9gSgrOzUm(onT4$SM53Pr&pW@!GNo&HK6mY{pvJ_If3q zwUkIfbMk3c8>m(&VwH37VGb>DF`(*5T`85$HmxQkF4X|cS{60#HzYjDqgaG;xj?2` zoTqr}X&BjBKa3J`ai5wxp5E*bPt)KNxVDhy`f~Nmf#BKE7vpdPg zP@Z^FHf?j5w@JXbIPGODm;4-LzLOZv$Ojnzxy0Ft*o3d8?UPbpVx$3AxZ z1^-rW(x&0c`iNwerBGVN4gp3Sp929%6~gcQAVs8AJo9pPLx{d-a7`kR_7*MP=(HX^ z$~P!g@Z^IYs?;pJnVQZR&B|3yKUxq?tH_r+2kyEIB^r_84wnB z&Qg3uoeg_|hhv`-x*E5ao9|6Zl4vwatAXlJm0O%(r8wF+^lks&#AV8Lrcyz&8#5@m z31OL>LY``TeGCrUPjdb&$3SJN9+}0SFeJR$<{pPhkO{D=VQ7X#H(~@mBTq^Mqqb-i zuUi8D=1b~01>IM!y~3j^fE#Br0#rEJSvWFq+9qh2{+pBr>Lu+=_t`5isA8BYCY$XO_doj`Xw}BRho9NrR6uHguiFb?Q200ea&yXl>r~ zrIp4AC|Vm=mTQ*@VT7yeTRgnC32;bwvOkJpcp=Vp+$2awxirj#C(g4eJWjFcPQ^Ax ziV#6&eHOKqcozy_e+WJps`U!xM(pNp9mmMrZ`(#1UFWQm(%aetC9c+3GI55vwylC2 zc*GH@Nxug}*=VON(v!I84k!;H!Q-TPMzFdW<0dyx4p3wno6)L%1)QBnUS zeqspvh1Eb80K+V zpI7^*HGEsyprU~}7G#zSjkdDsAo_Czbt_O-SPD4_URPAbF*&npxxWDJly!K$-MX!<<1lm@>d=6ukCLx~NTy$G3w$G_y zR#}LPUY$b|GhC@z4))wRitocPEds49i}iz+LWnIViMc>tVN9h+k&Gf|ac+Z^>(`Z< z<(m>)2X2UD!p~}7T=dL!Xf}VD80^X^j&MjD+1~^JXXfP_2b=rm4SbSgf+uCIZ* zHksiBURnq(dq@!rCc;R{Xd+)?Ik5;X8lwaSJ^7HukMj9~Q&+)pYCJ^6sed+xXbEx6$Xcz+xC@@4S(MHN1bdyKT% z`uZFm95W!wwn>f){=o-wYThYJUbrONT;I3?TIs8hWjstY^z!c8;pBz<^jJ=?9ZnpY zs>gmuc(~Y&Lu`^?WKe9mQN_Z|FfuFO%*}2g$gTFBfK{m(xc3ZvXBTv4-kk!cE2wyv z6z#sP+cbFSsZwHDa{KgZBpVrvL77WYqvf=`StI z4%F~9v&Pl7Ik0wAq-_yD*8kgtBA3LtEYWM=nR(#mS=lWZjR{Fy(z{!7uH(cpE4wJJ z`Uo29Vq9x=`+$(rV60!qxTq<|%(ZQEqX=8HOZC;qHSqBh;Jq!``)rp57khHJ`I&jQ z2TW^+=YbDp)@74Hqxq#azPE6%EeB#CjLjVHsqapR-B?V&by%}}66c*Q@Uvk|d{nF( zW|hF?>MM`phb0l?tw2ybhCS=GhyS|pgB;S)ib{|xUnd_>)CvP<3GLV zLb{G=;_jU=RY~b(n~?)D_j_SU-h=H`XvUiE`SDnY{OF0C02eGg!49clGUj53U94lImm#m4i-pT%syJ|d)_LD8KzGm=8JM!(P!6c@US$OsQy6{e~ezo=O`-(`-`|Bcg z#hJq9I{d{_CW5^G`^tG>J@fKZ&2p;DFYf`*jz!2(?8~`Y|39T}%}yjl^U2<_bq-+^ zAoAqyV%7qJhV7L%yIg2$?;ZpH;664IHb5u^Ker$+hA;OOI7;~*02;ovg$gjtS-qmk z$*o*~*Uxl=ZV7t+4Di_vcdCr<-BlV+fPZ=f{+|!z+(wPPU2ar31@{#0=_-oQfRh)# zQl99qjTT)$LvuivQwxT=@2ee;h1TCZ656!@0pZbW8^W`$ef!ejmdK#F(dIm=7{QDb z+rqPdsGpO|QI`9_7cNQ0_{r18z51kTZwUPS4*2p4=;m2<@(dawC)-_JDF~RaWW~j9 zO#6Kmf~@ZN4TK>H%k;0k2(z3p`^&qsG#GLkr9>B(fX`n77W*?&64TDZS6M$JIkN~r zG7fHS zm}FbiT;`^JEOtR}Tn68MDu<%^k4bt4j3y#@y(cNch0;WZ30UZYzHsSO#GS6R#~)%w zXIf)vIKjr@5SJhBVr4i%cT%5XofVQ?-Pr*b46HOK%1!|sg7Em_5+2@M$4;lfaShZS zsFg_$MVoF|SLzy^elA*fl7zxEHWHDXMe*h}S!lTD&z5w6`W=}Ss&YvTkl&8#98ozV z(`-99H3nqh`=HqnS=Nm6heLe%-Y(v}vxC<+_i%0Z7)!$mI(6MTH6ER%N|60%%O$Wl z7wXgij=Nj?Dsm2!K(BlDVflp8#Yx5q+IgRR)SnrJR&p{ z_DayJ=jCv;{h>Rn5wh0#;yQ3+T`h|lpKM)Uc&w8T8wZvDYb!RUg$)Xga6&GBM*sj3 z5=lfsRJ)TJFYFxPU%vAIe|l>R*LM%GFm_g}(+)R2_rIBaf-0XfAcqeF@(L1~Sh)z` z++cziKibBZHuvzAd%O7VOB?v{jk9>P)B`8mh;25jcr~NU*!XU_Vyx6NDykEAOhn+- zIr)~~q?Rv&jcZ9PzIg+5WhG8Zbda*b4UZGwl=S{KSlXsv5X>FvOpHxQ*wY9bs)S!hd}IGM>zA8SOcZBaKI6GSTgC!+wL z)?h>Zd}4LxXoNqzwTVCeXdCNCBl$#@G8iIK`c4WAxoE-7{RCxiyZ$+wwm`*f4Gf}{Q-!%iG$unb~>QSz3a>jOeer( z+z6`M1Iki$#ctC-0d)8(e&b#?*Ui~3y88O4TZ z=Te$sQuZiAn{A?TQ%UUPjBvHZQCz(-O8^X>*7EtCU)+@mlF<}cn*+ao5%k4N;FUR0 z>EM2v^SeT)`ZA4U^P?%gbbl8&pB$nSoy_iBYgM9r`HLuSz7Fbi!ILrS&3l-B@DBL# zL!j43^~G8-cHqoGnd#=>}t zuio3mjVDKVywFdF!CF)a9~^TXkD3^)ndX_0eBI0e&@m|_TPn`zcXHTbLME0l$`3!EE*0LU!Q!+rUH$C3Iv2}6cfzrF`Nd!^Dm>gbRG5MO%&H(28ILh zqdVf};gyMl=UW(0aP`?SdXpN%%J4ecpimnUV|tq;D=^8sQV-NHDjIvX1ZlRyH+_2- zt)CCZ?qnJL%n>}C0JnGLOyzgCfLAuaFP{TlU6Wy$|6ZVqW$~8QwjvD(z~XRfq z`PWUK7IlqM#a{MOrWP2?;PDVV8i2|QR1{z$6umxZbsgx>gC}F4tiVsUQQ!Xr<>ec| z;0Uz3j>)fo1RUQCy#Zx@o*T%SQ240Q0zx@uj5wlocs zgn?yM`syn9YgZ+?dho2-6dol-4Ajn|AMVTg>N}6*9OjKhIcNFOvaCffc0mhWaL>Kk zTBviQxt6d{%PIBs!5Bw(pW$FMO+9?{gCtAt&jHJ8D6ZWUYkd3=_0fSORUf~H@elqQ zy!#lKOo07eV0et_hwq?x{#8_8`D5_WKI)I(6$Ma=q-~}q!d|a~v0sEB!*7*H`PDko z@^$h_zaQ)$`c2u|ZR_O93epQ84c-m**%(P6FnF;i-|}1T0YAA7eDGM3t>l|pA@h;{ zkH+$P>h_^**`4di{-&j_95lAj6|3%+?$sK|&}CeUq8tn{Js4u=aD>fb3hq(zB7;tB zinVj-eCXP1AH%Xxg4LS94ZHOLI00`7Z&ed?lrYIPsv)0G4Gc8` z^lp9D#J=(l`IO$p!2nm*DN03*}(CFkAl_ z>dWBKi+zgsHM=!+WoS+|RK5L|G23f^hZEU>Ki6>|uF4hdQ(6Q(GaTFCu5o6W@c8&C z@b&{)Zrna}rv>mS6Q~Rh+5KPQ3AzRF=Zh8o>TC}$c8mD%5`s)lEG~oQmjEij^%OWd z1RozrCR~)Dl{HXrK7!B3hrr&h{9ITT_kQpUe0&t|Mph^dssjJzl?(Xy-~J44uPz|U z=&do0r@--8K0n{Bl9jef{|JgwkT7{NZ3L`k5ye%G07ezr+|wJmqj;hUkuY!9FQi|b2MkDZ1&G^T`6#wIBg0p1@XG%>60bGOk zcENkk0z7H%Xqircr`xDqR?cdHB8+wSpUR&_&DDcL?e^*%zW15)c(gRvu+!tBCymttZ>*7B@%0aO;i${g_81@P5X zao3+bmH7N%PreT^7^_p}b7rkF7bqMfdgcDZ3FE&WOmMAJ;LZ6G^91;raILGNC)!;$ zWRjg_;~0Y&JBl9=@T_0qyDx3v=U3M;s){DL((yXv1su+mCNjJSdefo?5Fk-BYfyJW48>rFo@-l-}27}a$TzHzWgk4t@-vfp9V2liI*^0OcaEAPc_&j~;y-X%R=Jsa3X*G zN?ER_6fx2|CTV=4( z&=#QT?Y}an<|@<-9!PzoCGWxWsNL7H~WU%HHf_ zTN1u!1Pe5YgJ&?H;QH*B4sF5cN#Mt?Fz zcgnJbC-Gcp+RsASDfGA`466d8vQQSQ0EGDo?fu|f^H97|uQCU=`R3jjD0kAG`=1~a z_}vQZPh}%=8^HZsuVPHH0d5Ad-Zj@iYzi6gU|~|`UX;8UMbQGyB|wRE%p*tExGXWY z=U!)vHMiWoTpisnM~W6ARb9)>-C!b1rd>A;>*)?rt$|x43-e0GC`eu?^L~EdfY)}3 zs)e8?+fct}xcERxeA(JfD;y0##V-Gwa`k4w3~h7w+xneVEDnhIuImNMtsVbIjZCT% z1SP-BYcxfOfjK+@*+tQD00CLAJsvk7ZpxJ$6A}wMZSfk~)>Z&-J$)}nqT!wDi8e(W8)qZ$}lZT0{)>^2uSGne9gEH+hUmpH$O zZd*%h{U0-|ZN_ubaFnap{gSE2EDI-l$HHqOV6F@5cSIH;^Y;m#|4k9>s>!+xQi-vV z+s9miLGmGvG>=i zeRf_ma6A%EIho3vAic`P-J%h!#yuFA5;%u#vx-~Esjuo02wW8s*b6t@A5Psg;aHAR z>XoM$O0_Umdy}?g%JT12e4J59zd3m#h#=(_+**WtDuw0dd~H8DLnQHbt}98j^dR56EpM#$(8xF8Agorx?j`mu7il3A~4Ck2$7R=~Wb!9Hs-Nw)P)Bbif_ zQ^T8qpPs&r;;br~m$hqCyBW68RE%Wk1lx7Ppsw4jP!{>(=w88ta6B(*)W!A3e)&TY^`a*Zj*uAGBmBl1^dkkL?YB)33Mx&V=jxvNB|X1b2z1Lt@-?A8~(FsbAqA*;IaT! zvbw>3-gjEZ=Vf{K;*&Q3`J_Z&XhG$WF)qds*qZo-OO>q5?5C}GPc%coULf8>YQcxO zhC*hgDlr%;)dE5!Tx)d-&kXs^+l6c@hX&NdsU)#+F`Eid!9ZDn>k>3|+Bs!;9mQ*? zcS)Lu;UE@MPD-3kOsr058_{9z>oQAc+Vsr-rlzuA5(FtP<`xNprIrMg1fs$S7IFB@ z>0XO7sv7B2p1{^MUv=RvvH*xnpkjbaus`m=Zwm7>V0PbhTg>{sl@nq-xJh2@GrP}* z3`e2sxqh^>a>GuzL=^-XhDM7X8V*u^M~g1{kqNILbwZukE}X`KSLIfoXi^N8N<`-JJlcd?X^jMuFK(AGR7qscjUZTkuc zBi8ajv(~;(%k-IQ-crAfz~5(~e2$T==Pvb|BvEWPmPCyZqvIX{eZweB0`q^jk55xfV{X-acgx+2yqrp+?2A_#FE6(sWQ(}) a;C}%?T_k2vV;xQa0000WW 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 literal 0 HcmV?d00001 diff --git a/ios/NewExpensify/Images.xcassets/AppIconDev.appiconset/Icon-App-76x76@2x.png b/ios/NewExpensify/Images.xcassets/AppIconDev.appiconset/Icon-App-76x76@2x.png new file mode 100644 index 0000000000000000000000000000000000000000..30fc9231d7b30c67120435198a038b6622f374ed GIT binary patch literal 18319 zcmV)~KzhH4P)1^@s67{VYS00009a7bBm000ie z000ie0hKEb8vpWct8w;)+HZx!^9jT22Gi4XcK7sIU3b+x z()GbJB0W4j^1a4F6vM3QWoATpxO?~&M@CZp&Oc)S03l7>{*tG+x zmQj=PwtgA32dv7ZGhP=6;UL1ER#W$vbqJ}B*PRw_+0?a3A=)R~oK9P+J7ATk)>3i>I4wA2oQCIP!N)qnMr+1sMh9! zMM~<0YYkfoY{17OAao|FXGxjBP%>6cwVTxquxU=;_qZ>sf3Yn}^Rs$}ce<^tj-^FE z^749!VGp66aO81ZBopeaM&e$q#aS>uNMa^nz8kTyjOq4>(!#;!KGr8wPPtdI9jEG& zp>NSX@H*4&U}c3gJ_{vMh5$M38BOy{k*7=r1)B@oJR_h^ER7~yH0ea1-_ za1aDNFwl60=Pmw$eMz246x!wVS;lLt_^L=wiz-aIU#yFS1!M^8bHBa8Y0J2I7AKRf zfUKh_$vqoa?i3}Pnc^%;XKadvlfhGrDV8y*L`tTtrcPGgQ=}5%LAyBbO6Jz+kOQAn zd@@DP5OA)gyqTszS|FRZQZYoPgSjD*joh4i`k9B1?hxuqD2q%gd?ANNZrkp&yick)=S9d(vgLAgdz1@6 zs}b_cO1Kn!MVN~u!4(2OmGZgJhLh%%%Yq_Ds2A=Cw}JFJ>nj64uAtaIRW=h!V{M63 zKDS+}`wr}Bn1)}XImanoD#|RErxCeHj3AlCA`{6XR1mCA+F*hWr;SBBv6LKFlfeqi z^4icAA~*TP_7++`vl8UE=8zX%pN(@UB_pe>VLEMS8UpxAi~s{bW93UMUsu?X4c)&c zO9adYuAv1&rx6KnI1}guDbktYUgKv4*&xRNlDLQ*%_IjmEeKYdSuui;%(*2vsCJ`j z>*NWNve0^Dkl{xi!`zX9!C$*d&!WXqx@sp1rutv4dqWjC>AftCO=G~&c)37zs= zr&ACnzzZGX4qeeA5Q>=&Q-&&i;4xFB=vD!jh@>oadFBg5|GvWx76*Xp^PVg4Rf7R?HUkaPzHO($y`F`9ROH657>icjH4Y;Oht{%`0cz zsaK5c19cl7HENP63oSg+D9Or= zpp{bFP60pdVHQbofTdu1)iZFMvNg0FMwl_)=A5?7^K_}6gKZ8&&kgnMR&e1cGtExE zXKIzD>t@_F5Z$O2EGw*VI^DG4<~c>@l_y(4;h0VHlq^)}NE;Fqyo~h{q%wOvLV|0_ z(}undqe`m~RA>i!%XF4Fy=Df_TB0i}zFI}d{MlP;`KTi@nPS9btM>PUzf5 zU`(Yu&}bp6%B5YI1jIlwu?V56sjKm@b9HW8njS+~_RMHuaCuDwZW>_5phmeuGPQ_6 z0|HkBs;Z7RahgYWq!uniPqwPAc<#of)^e*hERAIAsE46lYcDLnL-7j0v?I^A;%VJF z0&sBcTn+=XCi>%4ZS-#uP}*=pv?^yoWoB42PImy1%xl@Q8Gh|NPs6~Z0ZyjC@dSK4 z1@_0l{t0-m{XLpU{7daBm-Ya3}(H zJO#!xB=cG&y=h%KFAYSn)|Y_IRbXpf{?4y~&aQyZECXvxpy8lhMgua7oOF)1E{?_Z zEM34y^Eh}2cY?PkIkG1LM&PCqv08v5+lEQjS_b6D zGZD`Fhrs8LgkN<9oEm{ItO1u#15a!KS2lo)YryFduvCKvt)gjblD%}ImD0gM^Gok| zi31%gP~^~7FqIls5cmOsXAOud$CaiAq>jL2+>j!}O?w>}kuliPudGU6AZR;~+P33% z?Z8asR+4&FwUn?igD2AAe0LxCd>i;|8~AEhEY;yeT)xN5c&$5AU1%CD3YNa{OswLA zL*U~F!0HgZwGLc84Lp4oc>0W3x%ClfY0w$^uCh9OJOv&efxmnNT)!`Zb!T5J*rYKP zQqV4LeTtGjc3e-WK5Kxz6R~oiZv*e$0WPkAuWbS^oCluV05(@aqq-B~1e|TGrw@vV za{kCCL_H23Mk|-d1chk}tAt4mR>ZH3KN=QOpJZv%i-IfhT#Vvad_zXLR8M$PY76-c zKA8b`_rae$06x4Yg7x4KIGO^DW34nUy@KMHsFM4%;e`jA8JIHg@DO-(1bndrynhFL z?JV%>7Vzvj;KCYcN$Wl(R~+C(SJ$T@mM$+@mtQg(iZG&f;HO=>GEi-u+GmuMi|(w@a%5rG|4COT+W)1k^5%`z)fS=t0K6xk|H=c=dgmRfnC@?X& zg;>wDuW`r#%yDhHc|hydP2i2oz>60^=T?A087 ztuBeBh;1quo+4Un;-!RC$0A!JVn@@|%9I`)Izm<_wGw|X^FAC#k42YYI2*UP6s(_~ z3u9e?(vC`)l;X(K2Kagp{Fh$>Z{GrL?y6~pwh*DHRelQXlMHAEm4pVv8d$32KJcPp zaSxLQ7`Jm|vo@S)8bud7eQX3%r-p@&Te~tEz3~A2%`3ono&;Sw1q|Ey4bL0sX^Lzw zo6}hD=&z8nsDT7$Fo4QYz+{@jK#4-4wMH||N`oet9RX2DB^U=HbMtGc0hqyiWAHET z0)O@y@XLD=II}HIY1I<*1_TV-`Kz@Nu(<-9Uz1>aV_D|3mIm@Ss5-^40=7Q}?;HaU zkAVC8@*C#UCNm{;4q3?qRcJf~KHUcHAA-Ml1pfZhpqIBmr$#*oPZWbpy1u2Ap0NVOy#}!`5o)5FuIGX;Z^8Cp2k5;~DsP z0_>g0^vKN};Hw>puXazm=@HkJCXDOa**yk+ejB)V0RG+q@ZG0G0SI$Qw(ioxR;ysl8P&Qo%?_!E~A;uE()sW|2#GV)YaeR+6(YPr1nWtKlk3#ta@ez-JG^ zfBLB~`_YlOq>OIHmLR!vi+$hxaF$;c%LpwYZUS=6(HMpL$A@tI{U@cldB|M;m) zKOBycZX3x^?_gI1tPFvR>%jBpL9bi@uALS4Hyi*}Rp6V)RIQ~ti*jYGM4)MDAg=fP z8t8>{;NN@__-q^e(LE8i+q>;Fis#M@QL{$e@B4Rv*DkgKW|d#zqXjigR%g#OokrvJ z-Z;Ai7tn2&4&xTTq@1){cb%j=j9Wo2`C_HnMd|3;$xO4mh^vWfH@NMO!EfIJ{^(;_ zewoa=HZl!VHv<4`OEP)+@)q#Y1<=!H#9Ac__BJ_g08kdI6rU9E2{Bu{Y(%3Pe0~k| z$`<&GN5C)c0w3O$6^4Ux?X zQc*;jI|eycIB|u^E(rz0EE}Y-VIHco%)p}~@Lzug{QFPDJv55qxG--3Q){uVoC03I z1iXF;^yCI;ZP>ZL*i=DKl3z=-u^6FE)399H*@^GSONPtuzBGqaf;sjuD^aTFaQh z+lSzvegXW48!}{{>2?cRKB$26t0Gw6x(d2>7C1Em4IDREmH?+J zW8qnl%i%zFR%|STubu|pzA2%>(L^>cKD!C}=2hUyjc$uiq%rH1IqjB`5x%~Si-hj| z3|4<;mZ3X2Ov;U^ca6`?V&)M++AR&iK6TI9EHwU%qw7p@3eTnsLs2EO++=p#}Ta1RwwQ(ns<%`@^(r{&Y?DQ9j!ov!Q+{%CI0bs6VN-&63LRu zbDO~LJO_I7NohE9|YE|UH31$U;cRAKX>x3{v(*Y$!GH8?qmDgsuApw(dsa$ohw zPo5Eu8U2Q$v>*^}>SXk2tyf|yRYnp!1=lm*MG$NdOyJo}CQ<+7hQuB22ufL-AdW`Q0=BbO9O47_T;6k^!0AxmB-!?gr@~% z1wOw_lfuio&9<#53eiQT5bEBo!NqoMhXQUOZJuS_$t-)g{`51ML=E#?+REsfD>d-y z7U+l1gI?YeVM`Xy9UNT?%xReed}vkiW8p%)x>!W=J%4w^5|dD4JC zya)XB3z?l}1v7CgB+EK4T>$;?`A)cW`yQ2^!066PVz3enMO!8~rhNrJ^Ok)vjNzPT&c-@F1E4qCVYvI1=Ji#(yE9}>J;p1CYh z-QRP3lYW}|-CW9paB&*PCBM{ZQ3Kgr_h+BC6RAyFmQ?dK)fnE{6D9rPku0ExeQC#2 z;M0e|kK4&=)`ArP7#icX-xz~CZx~{*B0~h{Dgk7CY^Q-bX3-kwfG2dq7Jn6R0&qB% z&4M4^m7M|_2YVXg<`*2dh&=Zc`fCB1W3Pto*Vn?Izm*ef6LQbMlC z>@Es1idxo6x~O4!4e$1zTBlWQjAy_{_rQPkrL1+j408Z`IFvRuXi%E>Ef4w+KbaRO zYce1L)nSCf0E#w`GbvRndkcEm2R|XU533+%shclrohgzY~U-a+ke_b z0G4W@Z)Cf`@z<_(ZFzApN#8n8cD6!-{=dD2=J|7|zHu2m2=6kQCKJ$B(1UWSKDO;y z-nNhZAYW-$xlc@ICqaIIWlS&w{P0Nj(BIq@R~eb11r%bf-nat#drznHTqVn88w%xb z?}Go;FJyOUX%YE9b*cz><}B#$5p{r!RdJD-=Y{@#C*j$wgll6r#>c@lCBpzQ^To9cGOO0{lXRMYpW6zm)e~f zPi%lMoe~!chz5A8fgOJXl1F;HT%ZCXgSochVubNE7P z6)?G;Cv>XZg>~SqCxCOShHeAn-U0Blo3fQVyw11i$VLB}xygAD%IAY=IKPr-F~WK> z1>bl8+;}K4L(+(`y!v3<+gSePX4dt8*1#uoROBv{XZ7ho=`fgT9mM&a68 z5}mbNgI>P`ymC<%#WNXg3r`#1({1qe`|{pE)}EIfBVgv~I4heXT-Y=GE2bpoQj*!Q z>_h+HuDsD4M_;;gSX{@I)4;c`$_X{@T$XpO;4Gw>UKz{m1q86DeC%G%DQS{*&jo=a z0&T7WZ(Rj0pK^k375;1=$u8Q5N1YY-5Mc9HLYPQR5O^-5_k_b-3FfBQnht^hp3LN| zh|jj$_ZJO9;eKTZeB&bMnX{mJkhb01|81KQuC;axBd~t)$~A@cB0Qi*4Cp;G)W%zP5jz`f^E*imCh3hm$x0wVGtboAa0} z4jWmfBd*_VR(53ZfAkA11hU( zc$?I9=p%qmFN=U(-Ed-IRrTQ^@bUfpeNqk7;FR8mzLvjvGL}xXns&MiFWxZ(N9z^J zx8gZ#z<2g#R{3a>Tb=-BWeB{o1$y#~Y*#5+E|}-~Gs9W=KJtx)T4W*kanm9O%RMiZ zdPaCban0k3Ku?~LrL+}0x7G>;v&`^+z74*!C&z@kI9cSiM+p6E!kdDNsromOBhixX zg4Ct4r?FUjKW^lWpt}d@_GgU;0l0KZ1Z;hjma*+yOOseK3x5Hj@vM-?lDXTFG>ks$ zw_suvJxlakx-gNzSi*+GR?DP08 zEIOXKi8~lz)ZGgXWlNM3@A#0=!Fmc}I+bOLd;4$`LuT!-Yyj8JO6+A}v%2sY9|hV7 z?%ZVz6}#DZhasb}|Lr>x8~)l8fx;W-utH;ETM&}nt2Tg748DA^malCJPwyReJ5}uT z#e)NR_u=KORM73du{fIcl~#R4UEzyJQ=M7_+bNX%q=CF9Qg^PhHv41QqjYFj@>S8* zA@IUE(3$0qkl0>N+>@M;n3J8?S6SHsx`r+SFd$SfT>#btUYvGP(S>l@pE4| zj}9zt*>&?l+0LwpoBa45us1dyuB~u5k@p|=$DI;IxX5t}Uh6RjLxufd+yS(NMIUSf zS*PKhV>!)v)?-aJmO;;K%BI5DPAG3;Jq;!iF7>PNO6n-f;G*L(u4QtJ0YiM^#D;PB zt{<^aixy7Oc?z+lZa_!DO4?#Y7XwQJ;pwSm1y9oi314pS0*?;6lPop=Z0rpfMQ~&$ z!Bz6B6t3gjNj*+>G+2{vQkcCD?$K_xV~APzTg`xWg*_pSg3Rf2U2c6Oyd8#@J_7$$vHh|1(R7A#GS)3qHrsxh zSM_bx=xlIpoSiE*! zG(08n%#X6TE>J7HjvMk6g&@-uS5J2v8k3Nsy`MI6INr$=IiJaG(z@-O{9r^xfO^&< zyZ0EASH!!P{5}b;>bN~QS#K*&%rMIb2rjJo!*!QB-G-MRw6sS^7*4*eSBiCz)2e5* zL);YP%XsvR21Z)X#+ep2O!>b1x&m#j%XCO2z=#90On`^O@OrIx`)8Dwbx4pHRN-mY zvyQ3f?7}vzxTtqUh9!yZLkG$Brvh+xMUJhEUvRU6Tr#~@+l;Glt+Eyrqn&Xy=2()% z^_nI<7aZM?&f^@mt{du+;b}5xQQ<)hClqWwVIJbJjb-7nW|tMlhllMFp0$*roVjL$ zSHeh}7*%u+j$7%h@4SuNtUu(}>SkUcQ;)*fIoD?-o6TT$vkL9n?c=h1mjvkfaFu2s&v4^H=dZk^5 z4^Xn(FPa_OwJrswA~`d4DV#ML@*HgsmBm{MR!4%BWr@GS>587D{0oRw1o#1Xk(>4`#m6KX*3$8gH$~l&8&nX#Z8XZ+0Hv0 zqxs+e-D4X^H=SAr{>g91+fl_yQ>64I$k}UC#&z!i>H%nDMcyQ$CIu4&W;~Nqv71&{ zB3{a?C4+;s9cEU`!iuLYPCcKJ(N;wR2*Sl3lC~!sfDcX(gJ3Nb;kvGXQ(--hl%NEd zj+qJCZ)O`$T^eQ-hB{RE36ty<-Ot3%KyiZX-%|E|7ECX?@2p#p_s1-CK*E zkitMsX3f*|N81MPoq#e!t=%e2R~US(Qba2mV=#-Q>dcT8|8g^#{fumKzz?>yH zkKXO8j7Y=5jOh*yp7qLT)rB%?gu~fFIVV|R2dREhUV=>}tsL5F=-ndvI)eek?-vlY zd=9H5WXiXAc;~{#?x$Q?6684T3)PH_B1u27$uZ|PCGsU$aMOOK*ag|b9Iqk?E&u=^ z07*naR8}e`(Rmhe2e)L=UBwl;(>#)rQ6AE3O-z(24XCF>xfOWb0Sv=mM6^D{eG&W4qe;7UjTex_8)@TdeE>;_kZ8B9YlKeYn7AMA zU|3^~_DFXfaa6Ioap!QVi9(U@!84jTP&VjXjUQbw8B|mksb4#iBb+1mQlR3*Q zR%nr~RJ(5bj*H4nwJxq0?8TNY9)&XAXx3Zo)o#psT(iZclWip-Zn)9W%eLb)yg0{8 z*Rg!o&Di^h2B+Hmy6NXqwaO(&D(ghHCQ)JaH8*f0V+|meP@nBt$8IY29z{@lA_$mTpLX-O!2k zAGcd|IS(-yNM9LqOuJpW(s25MUl(t$(7c$({3772Ed^)Rp7mA0IdiY3MnuzSV^-Y6 zSV0g1pMwkah$+dxDc>1>N}mNqa^Q3``3bWPvL!-dU~60%LHvH7rp%h|V*~C=fpT+p zdBf9U%~ZFX!${qRPMP7R6s}gFqJ<`3W_0~%4V*SLP%RvKy|aY3R=imQOdLhlP1FO& zV}&{#A9Ei~Sv{#+`7sUU$ikK}w;BeKb1ac5GikrKm=Mk#<833_G89nBVt``%>V};L zv(Y7TL0r`Md4ml-T25S?E$6^4#g|D4p&pNC>U{`F9Zp3>^PVpl z17&Ek>P+o^3d-yP$t1h|g6XRU{T{S;?<$V#cx;$sTPPU6K;s-gsyclh;!`x_PIn zRwNG(w;3z!b6mAEiJ9TnmtTTSB)oli*nS<@1t5L2zLb97DFNqMwyqF4&$PQ&FMafw zV@L42ddNG7AV{w-rO$L_X5jt-_}DB0Ki0gBMUMQ(Ub1VgS~W}7QERVbY>Vji;bM2p z+R6)!a-HX4)93vI)wd3;QzJ13iQVw{0zVRQ(hcoy%mF!62y5hCA^Dzvxsvk!%0-YuT+%^`P%L3&WmLhvD6Bf4r>~g z56W*J8C(pUvn%O$2a-_0_~j@j1#5250iZ{bE``X5^kgyHvcbS;D91a-;E_7F7YZMY zW#7IILX}(3PXDvZAhvyS^1S51fOaE`NM|AbDBQSoihW|_Ee*T zvB6cr39q-gCnK7&g``8VB(?Nb_JL0U{JbbTj?Esm-#;8yZdEXVqbd02ZhIJ7+9pGN zU^5FSso$mdC2d3#q)Id|D6I3EEn3S36K5ADKkXMjnaW%BC)3oj>*{seN2NK-UfTM+ zUYEKczbJ}c^lOmF&MjaWot$44AMYW|kO{z>J8H|Wmz3+A$K)h?0XJu1Jyypn20v~L ztDgs4Gv}cyCHwa0G!kGQjDfFq@<~=*=G2m$;;p{{uHSngeecskMFMpUmJ!wCB1?ps zW~pk=4!y9ZC^DeJSykceun1DeW39RI0&K5*bQcRsi`~an%JxqfA)#XA~;>Yqb zP_V4B#|?)-@2E4R8OyQl_YRz68&o)PVGVS4B|rQ`H=oUqvC8iYDT0esA(C6rJwDR{ zDp0$zEQk6IDkn~B;q4xSZ#)F+7j(%8RU}$HODqp{owKON({WhTRHt6TpPuJ|e=V*$ zB|ZC7Hs>E4ky4T59AG=(Hi;#bQ6bZD!stBkNiwv%!3)D`RJZ= z9ObVeksRMdTkEn+GdH+589gjwW*Iqt@<6t&mq4x#V}La69H=xWXLS@tsVL5?fF&E0LZ_fi+-&Q`5I3TNejbntka{^ zqY3bT{B(}M|B9(1@Uxr1fA_ka4xObwVheepZyE-F`an+3N!(+wlpiJXD zCA0-I{@QO9Svt~-yphB$QJ3E?zfc8WYYlw$v>c;3HRn`>(cr@)@JIJSuWZSnK>PP- zHTADeK~P!^E1>Q&%-sRowo|gYJyF3zsUmsVb=D}PN}5};UWsez__TKdd~{Ea$Mh;P zWB~TW2I%6c_Rv2sdHC2kM3-}lAqM%D$Z$Q!T#+qj0ziTs4RGzO{OTs+aZV&N&e!jQ zzkJjhK-Dgx6#ylW86K3DpJ!z)5qiIwRu+aIo6U2-Hb_r13U#6%a;m6s#r3CBk7o@2 zd|TXOd?(c;f~-A0z1bcSimnTj5ZlCIv28YB$tSCQR%M0bW%$BrkF;i6S2gjiRahFx z7sW2FtG(fb4D{D~z(@DxG(=4l8`ym=YhD0cs+5#B=DrAPUL&0Rq=+pLXC_KQNtQcO zWysXThj-;%+>($J0bA>!r_X?v%$I{b_!i~DQJQXIJ&JTPIlY%>dC=EzX(7AS2 z1+t&Q2Ju4Rrt7_dO;qVbN$)onZBqJH_(@?d3Lushg)TD ziDWVLh4a8U{jEZc7|A@?7mtAV?sTzFAT~}zD29Z3p`iPkT7eeo$;>_><5te^we_^P z1l&t$A;YF!xm5@T?;Qj0eJ$VNj0)+%IJYW&vA)#tS9_v3FPQmEg`^3KdcrvM;%#4V zXxnKUb$pUue*{2F1JILll5|{_&;lF49gKl@Z-YPE24|b(jEl?!%2BI%9j22W{q}k@ zHkU^8tuT33wl{g^uY_}3X4-&1eF(gJM?66(jRwHAv+^~S;2w(`H~UPP$+KaM5^nV= znUatx#@NN`OxhI)Jwr~AlXPCbASWPaxVHrxmJgW!?M*pbEO}eV(rB4qxbA=0J&(N6 z8d-2reOqki;o0XbO2(p8uC>Jc;84CIe0vvYoEM%09-FK3EhzmZyTlQB4LTNGdqQh# zOtr!XN!hq?%}^5*TAZ}|((*VOf}TAGJf}~T=B{i=$5Y__JKzuQ%7SfXF?4cV(W0?Z z2BRgUwCHblZ-o4LF^dM{mNRjSS2uf8Dkw9{cR1g_(|$#GYRafS7*@cun=u( z#RKM6TOa#Yat!F5N+Dm<5}&ERMCjNltJ^}Fr%|RP(~#$Q1P!c(#SHKl+rVFZ?tIBk zSso%;)P6&FPjNz-l$S7ZmF1!KOa>h{wcf5g(VCehFV-rxqAgRWNi?c~7cYQc-IAS_ zCljX`l0)A<-3H#i2|RTcSZ(8lI7%tu+O`+s3W8Y6bE`6N_|NI1@aI-rOD^Yf>5w!@ zP65?=Oy+^ES%T3N~nnPXDW2 zUbK9%l~7Gt<2J93QtG|$-I!G0_kLi zX731C9RQ=W_6)#r13an+xcB@f?q5BH0{~NN-E{KaaLT4vsC#a=swYK)i`0QxLBsRM zG3rwg19ED35woci91yTN1byd8@aK@kEC6I_?z zJc^6oR+GKz;Xy$}m{B(k&hL-$#+@B}^VSYtzq5;{A06V{;TS8efLV4LDq>4XyOSAk zVU(3`030&oVO8O?@d@62?fU$Y*r4~)Dd780%U8d?*lFM0Q{_*MfNPuW8fM#&#x?e*QOSslmIAApk6|m^ zms+wyKG`him!29=@!Hor_`MJB;0K@G!!z55Se-PFXR-PO+*`0_;0zJ20C?@|9sJJ2 zeSC6u4L`ni4nKN+3-4Usz|QgzO}3#hG*F-|D)jnlH*f<k$%)MCBjELmpl@AmCuX&UwCyEkr+~ZH0otNz9Cgfr?w*XmTH5Vw zILVQj7Y}|M31TeCNwYSRYSi=x)Ik(CkQXge%5p23JS7*2gn^4p=1{28C3vpu7bY%6!6+b84cBy zxX0Cze2F#b2xGyD!iB8=T^u~&joF^?syxleOxYM4#}oYUlY96l?|g;V@9tsLZvGR9 zL69kDUn^7;-H@gyRrKsg^e#jFvZ^Z(muC%Ly}O71_3bZkur$E`^U4+MEe~^Az2H5- z^443^3xI)oAzxZFkG5l5<{&UJCC=M{K^2SDTB!}Am75B%W4=-U!~*wOSBEa`5{s70 zCPy$-8ciF#aeD{<%?G#f+TA@YPrLY1iAOiCN{nPrdkJ3i$&0nK_>(bg8oYG>0RPL+ zzru~pb^O&6XE7a+13}TMl`?ElVAGgkNV-%+>JLD+Dj!{na(mEa1&KtM$&#BR5ogIO z>aIPDsPJNDIX!09$j9e zlfczNM#weGsQBEN&BC<#9UMNM0(bYpU$yU4t}lVEZh*JeWwl^2CAS3iXT^ST%$CxH zxJw61Qwq8{MEA2}(M~A@7KURKu+Te#b?&06QxP?D{ehaf~IV=#LdZ|=db(OSS z-A!yNK`=Z`Tgz->v6L4B6cYpKL3H{zlwt7h3HWC>fuDXUy9XvSU^oC@JOzCF3E=fh zz~-uqQtdK_JCCEvBr%w7K6UL~2%!94n}7Ovf;VpO;F(8<7?{{60XrOG@WLCYzx@Ny z+G&9}nV@-i2eV(kgXXi3fc+g{w1WDZzlHkE??GO2P$=#_!t|5(Fu3|G_~aPVKmRx2 z`*) zH>+i!&}T&hvkaM*21|PK@p}0gFyq3(7%x89$LZqQdClaxHy|k~s0q9bdC*la z7cux6xdG4;a+o@d>7X@gq#%`%7Rt5qu^S@Zlb+OHZMG;u#E{ehIUW zehx6Bdgc|->N=X6pMv*yTfF_A88G9@-Z7roIl`A`R=R%3++I#|vO?n&*WcSsnH!|m zju4W-y%i?A8Lza&l3=DfFhS7Ml=gRjEH8(Q3!m6y$W+It+j1nqhxfp*YymHC$%`lJ zOX6j$@Ms}Rl1B%_?I{8V3~U}vB=+(#j1^<+vl)2%KAO)y1V4I!=9Bk9^%91^``=>l z+JAxO%j?RL5Qqp&@+uJT?|^r=F}wag>bHIy)l<)dPM-yu27{+x1Wu07eEcpj9kSTtiyGLpNa@TIcV`~f&FU3h&$ATG+W_H|xVRF`C+80pzJZz;&b`a!-d z)xw#m9EVJ1Y{x7(H&gJzE@q#+hx)hvOH}7CftE(1#%rfhfA=4ue&sEI8}Mw3$xnWS z=}-O;&F#<7+_?$bx{B(`HK1ug=P#qV{RNs^p9$=UIFRcSp>7ywjwf9i9acD$guG~4ToOM{j`eT=tt|nUPXV7lYTuj*k*dW%2m{MO z!#B2po4ev(FP{dUKL>hd6TG!9s|lllyy2XM4FCS`WAN;&0%myy)9deo4|Y@dG32zX02)6p zG)O9|M+~Z}tVpQWe+aN$;V+f5`R=w4-MT_vdrND;Y#V1+KyO|J-`|hs@KmWIw{_MvRgE4@^Jv|ATlH7F>Wi{uUA({f+NpaP1X2vwmqA&CWwi|MXvD_TkT@EHh|z9mC)LebnFnolZJW4l(|h z|0kwz{}_05AF~@DVDQ?vfu_Oi`g`q^hUo*v>R=3}1bn?d!j~H>dA{w#Kz}qoK;O)P zIcJRkRI<_^+^F3m65z#Som9Q#6U)JsnL&oOf;JI>h6CV5oq<4Je-cfj~-z5$@`dHe-Aj^2SzKH-FP4P@xKPBO3|I1fcLf~=s!9{ z^Zs9Bx^`NoK7R2waD1GSnDw3T`lKGDJ1G>c7K9dH#rWL@c;|SA&n7j_4#LNva!{B~(cJg|lUtw5vJL>A&BP_1 z9D$og%8rjQefOuBef+MY!wvXgKaLV-pMQ+mJ(;n`;hsF#WZC*8O7Zpj2>;=^^Ee(3 z<_MR{3}Hf;($YevHXn2rEMchpQAKh<@3a91@&-&IJekR*TuZ`*wQi-3FIldLxG~3r z3UpyzPE)*gMrQIqxC4B)ExToprjDC8@mV$`FW}$~DAIJ?Fg_SJ`03FUPY;JUUqeM; zYK?;#I6eX&A9ece$TT+$I@|{z?w3&rK&NBy?!!(E4co~SX8=d_0Dtn#IlOyu12a7u zw3?&)ogs#2*0kSU*Ydzgqjl#hjOd2l4S>WNaS5S7p>3onKpOcHytYi1ZSYgm1vILG zD;pA|KX*^W$GTrUG-jHAk#JIScdpNmBvuUOI(8c=a+Ktd05!v#DK4p>SeSp)0$2FpCR8 z1gs(fHe;afu`UrWC2XaUoUXIT-Ysi!B5ac?0xb{0mrsMvuK~}W2kz|4%c-Al%lm_O z_hk-k7T_9~i52F~1u*&rO{HUIynWo@4|b>6tO&0y4=_ZqWSRwv>3VK0qM|H@7BmL9 z{U8{(&nbj8Ef6O4zNJDr{LTotes&H2{Ea8@^UG&29XRh`XLPn<%dC+QWKfBF?^)}u zW9;O(NK^zGRN%=(=8*>BJkcKEa5c_rBX$kR)-AgLH|a=*zX+rOt{Zej(uDv_Sys3RDl} zYZm9%ffp~x$nen-c>733o_F`<@8O{=F&$6469U63OSXMj;YK9$Wy>{iY8g1U3f@}7 zovn5Ji}S14I~n7je)KioyuE|bq(PN!OHv3&DKjb2zg&Ej?P`mr<5z~r=W#v2yBAO4 zpTF@0{_us1`1;f`*sd;Ug|Q7x8#%#;TG_CN3Yt{A9TOl{5Fo<}IGTx&t&h5V>Tz#z zlx9^vF-8mN~4GsR-546gW7MiPPN^xjr1r z%fD0g3FraI($aD*2fD3~K&M9XF2ULourdTK4}qlt?$#Cl7B3e!y9+8 zbuhtbIzz=;Fw#!WNL5FOW_$57S)i75$(Rx0xUO(#ZG`{$%sKpvS1;pdSI%HBzP85B zh`?bsa~obX?MF;otFBU zAANim-@f$-Tl*(ip3YD=3`22$_}cHxB97Cl!f{>U_Nfv6=E_<8$+PG1&czKpSQ}wF zsM7P57fB~m;L#zdsz7T?A_w{f-V6h31uWjHVU1qoo;2X&G5C1We!y~Bv^b&DGw+K~ z&}Y?9c(!2j_9|sI!nyCWqQ63lY+^Jm_=mXp+3PG?(t!Z=p`hz~~M&L%Bm-<5!x}D9yB!fvFvlhV6QFa@u$9 zEe;+)H{>Lj7SjLvqKynMO3OJ>hzl%JzV^@RBo+yH;wEN zJ{(JvOLeD^d)|1lYP4>fBalT@-=I7H?ga)Jfc3r*{@s7pBxwM9VA>ggjNouDh~^t?DNh zR#|wn2Q8AX4RdVAq-?ZbQ0~YRmOee6N*~V}@X`QSYK5!PJaO9M?mGRPpS5C&@e+%* zLbg=P@3fJj{IOo|gKxn!ZDy31y+n}+fG*o(ldZ+E>!P7hB5a{zr+M*>^u)EcKwYww zGN|X>$5Sl+!IB#~qSf_CbgWVfC(5l?BpRwhSdqkkN{|~C%XM%pZzK%|(R#_kyweYw z7wWg22V=OMmd(LkM z=8?43i9+Z30*#mFYE842=D_ppC?rbD>ZYS*R`|2V%44iUtC!+j7-V|pXdEpUhJ$ub zoVH$;9^Fn#aGex%aS3j+mF|k#vFD)U&3Gyw0+`NZCOeKz9ge%R{|Yhf9+SETQN5qv zt|3yPUUDR*CzOiO5r-fM7H{pFdQi1&NS>?0Rvc3)TxOc3gr zB+D8FD;khdFbLf8QwyWx)-vm%tW$@Wu^0@EiWY8`)r!3%33mo0>$s!3i@P)$go2S!ylGQyWhgi0ifM5UDhL^Ysg{=v zDgsWX;G-#Uyf2?BSs!&TP9#FCI+)rOe z^N`?_^EUBc$mjalS-%hMw-2?#B*M|5o(NR()w}?sz0LZz#eLd{Vc0*B`(Xtd4UJoL z1j!3~9QjG#i_DZa5n0m-04fHxd#RZq^JNu*PiDZQW0}fWA4zOhS1J5V`qi%4sC)*m z%%!yt6Rp*BXe;C3pL{mP3ahq28a`0Q$yzFVpu> ztfR3AR=f3vMs>FfC7F)UJhh#m6wERH`4?}E4KR0xbP*fuhSPz+Bj zs>6>22aBhA9QfG);C8Wo(#V?P(HJyo_jD~Qp$ZeJVX#I4j_rd$pHX5h)YSK0WCFx= zy#5WhwID?879Xyw^sSpc*`+|k3OpRhI@X|S2{8-Bm9-YirRp{#!>y2MF6&EbxlO`w zOVp(gi{5!?el2wg$yiPGVstyz?K@QlSohpjL(dA*DpIjImc#UzC{xBrO3DTc~yJ8@iDL(;rd0CVCc-wHv2 zQHe{nW%K)P)C`pIEi_wL3QE_^gC~G^iYoL4wO&JniU#CtGa|oD-OpAmN{URRU;0qx zqeKEZH068sFg%(~bZ##E)+BqX3V)ze@2Fi(@Z@b~1k z9t7`XJZe!iwGq?kQ%7Uc6`66P$o{TCcTZu4UVDN{f^`ae=qsewiWD46F`GOxzX^o_ z+3uNd!6FB3MWTQe$nq z{O+RLJFi@?vO;=qJ*j%>T$jpEgux(At$=~L^+LU+D!u`viM7^OC&QG|1i3a~X2RP) zfG!qf_*_>Fm3pbz`$0e{rKc4j8_y@|`=3qfbH$}{C6D02NqQ{LwkAd|j|kU(qa7QZYs7r{1=FWk{zfvV2c_l;ugb;TWN`X496pO=x1sWcDsgERss* z)MJWwZ_E8%aQSuAS8yCxx-h@y8RA|LJv>oaRj)F|4RNL=&tj5uAA^5ep1V999rqGT z&My_7D}+e>#m7pJNj$nt7wYWe&-QJ!@gP*#yvs1%vME1G8MYV>D?Hv??63sL?F z0N9ryVRMD<5^jc z&WTdMP~TV-nlV5nO=kx}K}wS$t^On*D3mEONxZp+gRBc9X9ksrRGk=t5e1HtCK;V& z+sevJftwHg#6(?0)s2zkkRcl5HIrBHVwENfWTdMkjo+md(~;bbLq=?)%t`oD1-=y~ zrPKT#Iy`9xMK1L;T*bpvhiURzWdS*3*Kn)hDcYi+dgCMpwJ;WWc0%l_V9R_Y7@td~ z3EyQw1fgDvZVr>%Wc_2ZiY}JS5+nx$nd&P#gF)j!cT+1E^krT78eu1BoRGuUk zJXP8(O$WUtT%+9nWQJ7bXcY+1Z z1zzFZD5FY#vg=ht!c?J_?O@?Lfet{o;NmVEbx>t#8VNl6rmF4=tSU~NGotJT)X^A0 zA{C9^rN1Yc3YHD4L&a{cN^LtTkD!viow$onT#3^OHNKgon^cyfTPKYk#s(1ib_BZ{ z&wd6Jm_oIOAbTJiA4d37a4 zWrMjAv|mipWlnUNO9p|mk-1RoYK+j&5VIJj=n1+aW!dI??VDMK(3Y_{WkOWdSC?9w zBAB*Qhd7Wb%@R5_MbL$k;uo`{Of-R}3ls%_vipG27EBTK_kxEe389)0<1m#ZdWy_o z4w9q_FUw77YWec-)69CXd?J9PIyJLUh6TAMP~Y-=H9kns31(TQ$H=fWWO;Imud}RR zC6IcTX(eEiF%DPqy_*%?DZ`M2$y_!BfyxU18w~x7k%~Dzh455%uQ1RdnVZvpEhR16 zPLGl)FX!%a*$(NA{ z@qiK~S`#Q2LXo?3IkGP4MkGoyH)dgQ>pM#xF#*4d@GH`k@BN5T7SCmic1;&(Gl26rj&UO7 zY=@4ospK?fCE$~w$uyQWIizyX6>kmMB1xP{1h#ocNc|*9g=D2^B&VL-o+_<>lr-wF zUpUjPToje5RuQiWnWe8uCRXnm>KbsBcWhXbiqugeLQ6=y4jP_k%vcWRmK2o;)Pz^9 zb+hk5h6Lf^xtB;KE*fJ(p@seA9vyQ|wK`M@Bp!mq2{a)nhO9_mOZPHVj~DfcYBMi4 zBur|K5Y=nwq)}vrtPK6Rc+WbTlTXF$hsGb3b`fdrL?q)vGP^~f4Ar}G*;F8GoBq8*q5Jo z2nIl{XV`{HbF|7@R?o;oQ({=ryw7_Pg+uX(xaVqgz56%@X2t6d9e>Qro(0XV2L*FHoWU zm+e#uFM+4a;L2hJrz^+~Kn>!!r+bFMf^Re~Nj5TUz9JajBeADs70ohvu)5ZydYGW9 z{LYl|ZB_}g8d<6NjKfHnX09;`e(2x=PKk;HnL1OFqf?M*fv++JD?+;|WUoTJP2?$U z8VK5QC!&+UdNWEgXs5G?c&_+hSTau7DV8WpX+jTSc(HBF~tVIR0F6ko)NkR%Y z7L2FGh>XdtJdSYFS3f1>>u*^`RMdkZM^iC-W*g^FEYG36?no6iEJ>|IUv?`m1@&Y>BbxkY5{H-<#>RKw$#ye$!XyNL?(2DAIG?v#ME|- zex49a#?;6c-?a#`UZ&Gkg-V~CLD+CydaiW@x#~T&E{y^%vwOPLr!Irwrq*ikr~BBQ zj0kAFWNkI`3tS2qL6W-q^$Wmpxr7t9P$C8cK->B#t?K=1gtYUdrqK1Q(Ns%$pSY-^ z_z>sctOS-IvC@lD<3w|oMYU2L$RJlC zyf}~3QnuP)6MAqLBX*@Xzj>OJeJ}nM%Tn5cGvLQn75}G|PAA^Myb7;M6J}M&;#fu6 zxM{OPwtJV-FX0GDPDu7=D*zb^4+Wka)cTYn%{K}+WK*-N7QyDRlxGLu>3S3$aEf`n zOn6h-A0*5oVMZpWBxb-#<7u`{2U2lNQ|Tx% zQG+DZIx){f^5>L^EFcVE+zPBjx+rzUd!@{YJ+GRtRAi1JY6=bsN1=+6c1z#1DhzqE z1)@<4tZxIWTi}%~;K3HKHUw{M1H&;gx3(SugB~z90PmUs7H5IIv%s!dVAlZXcbocC z1%oN_PbJ4NU@f=1cecJx2sM6FcydFamK}o@bG~&!n7ooEg_glBg9nXa3#oD~~Uiz7I4_Nf$xCG1)e$r zoZJiAHwVo05-cHoLenL1q45nPQ;%XqeC`xYB}pyiA!nI4(2d`mimRbO%v{NjD!(9Rodm40K|Tn?+IL;NhC7O6Bqk>*%nWlxSG+9w1b^X6`&V zwQgC@QZ3dd-FF(g%s4X$wa%%3up~y*R!(*D(kA%L>%gm5fsgJ24>qHBeo-c);L*r1 znyMC#)-vxzj*x1f%_uWS#$6pcd->9R@O!txUpWbS_84g2LiCo%szixZgH=&0Di;)f ze-IZ0nt*5CZn{Gs4%lj4Hjt1a+U_vX?GV$G0-KqGV+G~5iwqC8(EjWq z@bgQ+xe%b zJ6zU=;N?x={swSo&Hb$o9rFhJHM4WI4I9!Vdn`t^EpT%USh@thybS)<4}QH2C%!@YW6R zFD^TYI%*9d5*VvTc1xun+y=jT74-cl%Ec359+mXY-<;J`ii@3v(Bh)kN-17p!TMAZ zyR&i7`wSx-R4QLVW+DUz_|6*mFV6!nUv!QbT{ZC&e7Hu%8PXWnD=rxWhA3p?q`yA-$BTj9Ts$YP{%b?P;tc3(r@@~;41Vnz@Uu(6rTdOarFheJ*_IQ1_=7nC z6Y3PfDkfw=4lHH&B9V;Lp={~Ewg9I~>*+J%$FF3DoNxLA=%myBybb(LQ-#X zxONg}S_o4jHhiY~0W=Nh)IQJ;c7e|wbPEpWZv!h^Ku{(#ec<>W(09&(o;U(TW>L~g z&OW#^gp{Uk63YfW1Cs{vnDMJxKIN3A+%lbbD*Hwrj%O5gkeA4yVfk-b^JhUWTZP`i zx^E#eXeVPbz*iqQRsQPLoH3I=E<=x;wEWuVK;L`>bYhS9L!BHld}13)!W#83@J8l@ zp}4%5(h{_f>1)7!-24Fa#go8^J>b``xdGFIEyp-Vb^*^F2R(fZm=X2XQ*jJ8NzZoU zmWPaS%4k%}W*B&rM>1*BD=}L}-UO#VnRqhT630au4AaGX9dQ8MsQjOO;8gjzYdS@Q zUgPEuzk3e!9o5LTjS)ABBig6HDexfo$&Y`(BVbr z#lJpur@ZZ%b1Pb;a|S60FD!G39_M5y(njKFrDL_#unbW(B zgGiFWpWp?PsjTz~1}v-&!GHas8w zG(7+}fJ$mK*}8hb!v6Tjq^#rlQ=ajPQ&i=v>gD<1NvQnrkWJtl0!*rOb!Vor!7b0A z%Q5`Bg+#?Kj#4|WK zCYFSv((bjGn3AT52g+(3qLj?lon9u4^^{zdfy-4xunUs}Otza$o!M}K=1RShR8s+k z)=3B^0)^va$iPz)C&HyHDj)O&2$b`HuBQ|@QE(@*-p|u(;_J;#oaz_6oC6Z5*cK{; zN+eto(fHDmTPwf0k_aI&k8SPY4|>42A9YR+$95x)KvTAO%7*Gz5^sfI)+WUvS5Y99 zDvH&6l5zrVeO0uC72B3`;V4apxb&#&Q=p?NCDN`B!SCDzzjfWMv&a3xjl) zl3D`G=17%#4+G$M9Zxu>Tb3JXtLPpCqMQdM?FrwZ+Q}mu{W)1A)eUhi>FqIHDS`XL`VIdB!}tTl6^1EKo!)ap@{12BC7}G1MYsG4Y$R$53{j@AK9gU=K?_&tSDi}qh%2Hw2p{2#LnrG!Gi0lsz`&G(-W zj49I@dCZzj#4P2N>bfIc;c{8aw?{i<*?U$!Zx?pdnB={>#DS%UchDTg%`N?>I+}rOgVV z#m8RbM&;js(rulU2Z}`%s`9Y>W>j!uDAViC?o#g#)$0#{*RQ3Wr&?U!-vC~@0RG^%r~?eG6M96{$I{f#Qbjy5H9N;3XK7J@SN3{z z$0vQ&Tt~1eo9vgR4Y$(q>3#1%s`AOaJ#zDy-+Kb|$bnp9hV_5*kW7mdtoW71ul%#( zMcWoIblw~;x18+YERUT(jy;4qU3LonjdF$vs`bW-b84#mpy6qC}6gdCe3Jp15&%Ja00}H#~hiKl}?BJ^H znP9v1Zg(9rY-a}(|32hn`%EO^jE8FcyXJ)yMwJtE+A^nrSC`7zDRg{^IA{%Fm1@7};4ZSV3aGaSi-WUU%L- ze_O-+0QC1>0Dk+?{JSP=Y`dD6a~&7^=A7GLB}s&NcMW*;D){U{&?Ea0b#|>O$pa`? zW>TIE$C^Ok?6F^bH}a8a)9_y45xsHp!s578m?;dn0}tN50eo~vtedl_sCXYVz~_&E zzWIn-lJvDDz~9cMTPjr~3_v)e65J?tYg|ff4M%obO_ZuFHX&F}81g;9X&S$D>)z9( zynips6%0x_cm_Zx_kvID1+G2l)>JJ6AKwMPa|3i_(fPf~l_i!AK=QWXBnwMC6OLs! zlD13wG?hn0ac^ZPSR0;(y%%Sme4gMC!Pi%SH*YwPnriUn9$5ta_E~pqpk;7n!{KDa zm=_47Ow)xfQzfgvmrlQlVA<%f%&Q!|Ooe9O{haQeInY;6J3r4!gN6rN!0Xq*SC_q2 zz(!d?ASscg*#ao05bGgGuW+()urtjuq4@RbT;X}IXXbQC7KzK9LLj7ko7>+1L0>p3-1$ks6B15Rh7tkO#ZOa8HUxa8l!AWJSP&_x!dSLQA4U*` z1QqF25eT%4;8Q{tuu|8IxsyC^$W64raKh15;;8=sx9RTvTh6JZ#7dMDIwlwO&Fo6E zLsYa6k!Q|WBW*{DUxsUVIR&9tU&N?W5-h=R@qBaD9TT%Ugb=GGt_=aF_kvzJcFa6)5Y z0Q%M$xAnPEG|`;Bz74!_9eisw@<)EdbDoz#IXxt^MzpoYHN>o^WA{`NbZ0L6WasIP zmP#Cs!58ki^NW-LTo7u$?@qBexd*ySlE6&bUiKZ7niz$RlAeR(t)_)(PIT2hL`%F$ z(Zs;RU_MEjcpX@^=#W~snqwLUK&SQr-+08GR2T5zAnhp^LKp9WKfap|s>ph77;%RZ za?3u+@*ES&UrRc8`YW5$u5q>{L6n@3G4fSZ1ut&^Z(eu3QX41Pyd}9g%`csF1B2Ya z0Kl%HqDkU0m6MOs{D^r=#iwfXWlQ z&-%GyuE7JaF>=y#X(Jbev0W>jO|(lcFJv1Tc#HQ5mt^IpuJ&2z424MmxButrvfEk^ zBoC`h;c&>=9`IXd-O(=<@J`4~SS6VXVKS1~nxr$BwxcvbH1h~4H(|9XWeclN)8eF2 z^nL*Q=7DcN>gcRZ6piOccibNOahqbisgNhP@w9MFj?EROV%E%QtM#;aZ%F`@W<&)Z zZ*IF2g_rdR-N=0Q0O+|B75k*iu(nk8v^~lA-en*C#=^9m_8WxX5a`)sZddB0u(Aby z_oh3lypTE%6KE<@sw=JQg=J=#)e}OQQSC@+;4?070q@)@)kwxq{f#nS z{#ME?KXMd$l}rE?S6b`D!iUf>)MGyJ$7Wgvk6Q4>`@pqjLz+uthTZw+FF2_=?H(Qp zYDYmcq9qWlZ=nNbtsUOQZ+Mn}mb$Uhn@9#!?TU7>Y+()%xs7tich?CQ+VaMV8yIb? z$$P4st1f$uXDm$@5e2xoBx{1*V1f=8tgp_Rv^p#WYh?rPFuuZ$V zXefLFcNWn#tgY|DrrbAgoI%uG^p3+^ADHb=Y?(NQ)F!-{Hm4=+o&~;g8hm9L#j>;n zHe%rI8{n^=c6TOaqx24?nso+Qyy|?VT%3GK7RAN;9=20}$*752;l z&mT_>ACstejk47$Y@{pF?2w}vz`_jZKmWSh<@o<+AOam+n9Oi~j&pKN7}>q>40l!J z^Cy5Gf8@skqJ`svfzSJiKPh@)rdYkr#zZxmi_YU#t%RAzib1*NY%EhuWyBfwBdO@C z%kG|^YH>cp;|JYoZ#A`M^ss2(iO`(-2ea} z07*naRHD%&qg9C{BaKUCrE|ZLPmeAF=MDm|T~#=8p6%`i@aYn8Y)`KFG-_2mHRx`m zRSk%AZgnmrSz6I3Tn>r==TLn9u2<n2la{g`LS-u6f&d!X1kH^wCsUt;3JT;PbcLmF8;7X~%fVF-9d_ z@`N|lq9Aa_NM-rOpgI`61ZPBlbVuMp;#t^0d;IZ#rVrt7B4|@VJhMut)5MOxj1f!COu~jbtZd<_h z6@`p$Xa-L0bv}odMz=Lr@jQ9?(t<@O_aW)REwy36LEcj*X=jzy=37SQ7^6s67!$gq zO~R81IJn@pR+~7BPJMI5wP&q=RdBS^b!)9A|6zPzN4E>w~L0A_m5U(-*WOuCppv_Znfm*v;X2ryNRvos1>qkt2#3WPKnbE$QF ztDuOfNLDvDyZ>t7l|;`>!LFrU9cFv(a)wFUGR7_V@^XP65tVrI!sw@y2VG3``DwMMmcQ!X=3GL@%-B2~IDt;}UvNyA_U?VfeEXIG&_z^&DM zrKl56!&EG2BpyUuGj-!2x1X)=**p2)^=;?!uSaK`VdXBNn(tS5m}4C>``5xz!xxP} zmY?Rd)tB((x8Oisfk!!39q^4b3Ank$o08R!xd9oShp0hZZYo!Z!w1hQQi( z-d0p=6@%UkxYLad^Ge{^eKBi+SOw<_oihv0p4iA)tdGvOd{H0}QUTL*Kd#HJt%LW#@jXXeN9mRnb^APm5*r|+FF zw*00OeX_f_7-{QcGodhzf z)^C7agAThtX%1fA!UTh(z%zVu7SiNXV>*^E$?A$#(Oo#11oLifSSNI_<7Rs9YLaQk zTo$fVXH;{4lUg?LeU~Ax(I)o{baZ3m2BL6S9mAM|BaEMlU%6xrgnGC(=i!-kpDctJ5RE^U`MG5kp>N+d#% z%B)!!%m)45EmRskqOFIAQXbCPV^Y?B6VE<+$Wm0k8k7m=)=wJCLW3+J6nOte!(_&)W@9UzQln-E5J@cI!nRkEX;A=f!x@op zi%FCcDtW@e6Irbag%ISdouS+DgN!5Q$)p3qrv9|l$~NB8e#>0z5{1+ME?X6%;mAe| zxdZM*3DUW)T#NH~7F#hQf})p5rt=?*Ey9X{sz!cLk*Mx2sbTAKk}5GUo5Cr>yJC2E z@v?{xI2JW!BQXe#xq46u+F3a(z?ULz#LNKBJTA2DW*f&D`B>0ta_cD=)5uWco6!#S zpz5IMnhrND+gdSxIA1+$H2FxLwYsF1R&Vl83uc{xS>Wjr3F2A9oeIw!wLG~2(|>64 zZdb^}gg{_&!TJKpb$CJs~{x+j$3tophntF|2R5W9jF#E{Xd=Fvs#<1a;@To zgt1_nHbxiRj@IOK!HeY(R3ukun(fZ)d?B`5Bcq@tAx$?aJPSM~^yw_4is*3sAi??h z=Wb^iGab9BxLNQY~jO9rmm8mCXJk5Go~ORwt=mLY)65PQJ4> zl#R1I10aDQflFeTV7^dhFG|%cA*&zRd4}V1`>%!ET=Ij617cya#5;(hL`1}~Ui%!+ zy2{?ibM}~9~Ju<2x$u(N9R)WzsWxgp?ZD(NQv**GN zvdWK1>V#+Qx<~co5eImtjy5nA#pmXj=$I`7TicE~gBg?g-KNeG@7FXtGE8k#oRJi5 zM5|I!t>=|1t2^Nv8GIEY_RLCbb151|SmV}tSZ}v(o~^U=Xf;*i%k+{U8bzrSGvw+h z%=CcYdqSzU&lu+W&Y#lT=-DPW|3ACoLWImVFC=q$+H^H`+=5q!;v!t3YlQ>^5omE% zC{{r?uQBR3aY)FNy=h|i^95R!ARv^awOLkqB~wCycF%%md%)&MATLm404>1xH$dBC z^UU%R?MZf8E#5Hxx=x;`<(=)j%cS(a24UT%DwpP2MPq3hZr}aEGMk+nB3^ z)QhwJ@PUprEr9!$3mW_XU5r!HnL16UZr^#xKuXn1`L8ZBFb^46s8yYEJv=W*9!rq& z1@@z)g^M&o7D3>pkA*!sH@3BWZW5DN=peCin%&hRYv zt($_>u)ii6qyDAexDzENWxTWQ?44>iG?*)FW-In5aRt{d24$4ePDUF&T&5=&`BlS( z#`O4B?{1Ikwjw#r{Y@%Of`;z7Y>{SV%bm&sole0#vM9y|Ii9)4S6wQmc!j&@Tx$0v z@`j{xq!)ihHcPu@nNIB!QlkQJedwg;s4d!=&|Qw};93%;SWC4f;F_2dLd^>D4WHpn z>84$`ojS)tzB}}V28cj4-B`rSs2sMOddg|(Cv=3mCcur*Z?6Iy!$iv((N66}us1V2 zRU7L`zw#1`?oQUd!7U0PkAm*FejZC6CvI^Lo!XmvTBJ!3{r+`02CggtTcgalF9}aZ zXVe^{dYaBM6+qj1lY}Ox65KK#6B0f}^i3Gbxn`&74I;_?{kXXh^MyxQ{RFG5~vL-2tW5a(uY5 z!@9G2O+-Zd4yW?G)@&Jnpq6*IrHDutNGiR1p5V~R;XtRW=sa;&sr^4dT$CCBu+%C!6J1fs^u=6NaFvmEK<_@u&g;xEzF zzmv9Ck?iDVKgD!!cTk(0!O>4D z2Zc=z6C^_j1wD*>!PM}!9mCsM2sF#pZ8pvz2{W9gBHrO;TgI4Ljf$Fz8Gu~iiv?d2 zs+UqH;&2aXSZb{eh-P}ACk{uCB)OoRrYaDEO62X_>O%Gyu%tUt9scdoH^m zi-jRy7F#+u>;$)|(n$tq2JUaVXM$)*GV)-0k)qSj_T7@Al4Ql8+sYf29xJ8@D&2<% zo8VtvvGI^$rU!cZ7-%+Z*p)z8bl~(YqC^(R3aw+N;*u<#kWEQaJ@c`v5&8{qWhaFPgA;w(%;hmSSM3Lp(e?6Nqc(KNUz zngWSBp|7kCfmbd$$D0gq4T^xLkGdm+1U*wp=~?1Q8eb-nvqo#5hvN#7g;fHa#>f*I zhv83hvjffbK~Eh?27bmnjO@VHkMDxtxv3;bW;_|ib86(MhEuoJOL-FS1pl)Hq29?6 zI2(BAv>F!%;&NM&Jc%EIl_VA5;-$D^4}w$DmcegcOB3%P(H@HCduCm`&B-B3;0aYV zR^?_l^|8V<&?_TA{61N&7wB{(pOmI)fD?P1VND_f8JRanz)wB_%X>0SwUcAVMv_2t zhT+~7GK2=wAu?K5(L%lF=;RpaGBRXDPh~(4F11Fk#hIXWDFpEHCh*e>>X0?nq2TNO z#9?<{d{3{H2VrOz*2N2~=~bj=eLiPdZH6?rG^eAaOf&^l8vjT8=78sp=gXO_5`o;R z#rZqnUtg_new#K>*S?hu3F9*xOw<9Qkl0Z9r|9CEF$3*%QY}I)txq}D41mWi_*a*K zPwt7%Y4tvKE|1S2cee~nN0mxdOwD8|WV14PXgZ0Fu#HqTuCxMlyZJTTB7IQzGkwsx z1HhvPD>V^BS|2*wGn*Ujw!KQzgW}qHVFLjjy;rBrRgN8eyh$uA&MS2{Y)%f&-V(Rq zaf7JnJBxP;%CBHuT?T%3$?%^|DI<>O4uZ}e^jlIgJIv5hHtoZqz0q+!RI^G-2WP^4 z>$1Pqfy6M4fFroG-=8_^dS&=#@mtHlr%T|UU2+G4#X=O5h_$|QB0e!k*I7fI_)eWx zi3p_(()ZNBS)@!eLE3Ughw19YV7D6d@$ODgG_zk{1;2O8 zJQFiE?@pM=z_$uGE5t}-`6$+WAt!zdg>d%W9Q;(|hNDF~7AT`l+qyyK>(^Xor%(q2 zrv|{;1E41lgNz&Xq&HTv#4hoiCREz4DMrARgxTjhPkN$o^jI;IHUv7k2YBIx8@aR5 zo5BYMaB~&>Hy7M}MhYKCBTpn7ElfIWDnhh;6HS9Df6Q8jq3l%6yb42J=q?9p95xfr|%Wu1Y-1nj3WJ4&{j- zhQXrg2Dsj7F<*9tN6ciLfjd6{J$=+k#MiE+?WlS=5pZ5JAKV7NaSi0R2o&W`G6i+$ zHEtJS+ZvI7OTug~UVRfgqbZ%rmM&Vx4={1zUUDdwFk*6Y+U&7Ipl6O6_mHM!8jBh( z_IDw%*-q2X3d;O3g+lfoJ+Y&c@107uXvQQGa4aj~_#W_=Pr7?;ZmyQd%X}+az$f>> zE1S+4f>l!eE~}+F6$8NYC)}l6U1y*F+YSu@hjvx#7bUxR*Y0wWN!!*9ETvmq;Y;8% zA6fvuatd^OFR1Zwf{!ib4mRneJ6AXIX|wcVSfJHv2{c75m=D|7d85L*U@3~Ua17=7U= z=-Feypz$*W0$BSbTW8$< zl{oJv6Nu2GxVCEu?(893C^G9sf-aNhL36v)hD&DJ$?#MRGX^c=)bcvMap^9;e)%3A zySs)XYg?G#Zqa;}RjiF|;MBZHlpz>*M~q8@K3>~Dz|U7U@WK25E3*T%!q}}exqCL? z>Tf|taRQkDDYEqQuUsU^8p5mhqCkzb8~}2KK}3h7#}9$O@rc_h5WIbq;{#@Uz~NmW z;oI0H!xFxE$FRKON;PEGs?Y{I3aTe*=na7R;TTWde1JcB<1)VY(QO=G*+ehqspI2* z(*L4fGE`12CNwxb0A2v_gZHju>B4RN;?#cp@6VpZ%V!Sa?!qkE#tm~adsY?LsfS3I z2PFbUm@ptxAq;>fWtpb+q~z;2XkK~*?bT)A=bxsdYeHxUIKCV7>~VK6m=P?ZWczSJ zn$G%7sKi5XWwgmuX8G11w>Y)Dfj@fZ8veuAui%lTb@T-8EM$8!8d5`ZOjV*d&9{If zu{&0=2gbpTZG8X3TX^yEef;prqxhe{^f|nJY%ey&#jR3(hj(3q#Juxl7(;UQn*ZXr z|Jwp{z!@PegZn*yUV9y`Ms1qUSp>oPE*{$Dr03euc_tBn`5EB!KHzuGq50}*b8`Mh zogcM$`qm1by1jxsyJm4^?>t5grID9xMr~heU?h-e88m7^O_S~ekd_gl;%uy>cA@FA z(TI^rCNFLLYI$^eAMp2H0KazCZFC!rfy0ZSXOFqPE9P~}b|8-@YvUJ)y1lSfh0dSM zR{J-hz%5gy1~cnVRaK1@* z$s3B~O_4~q$uzz6GpI!XrQ=US&UbKrkkq(YhUiT@kS4(qq#mZMP|)MiE8G$Tvf%g+ z`__l}!}qV__dmRa#o<_41Drh9Nd3vOr5g227W_eCn-h>NCui`u?jlP_)878CVc^L- zYxpn!)h9T)yq;Eug1Y8z%9#g_#ma=oR8iZ23-N)N!kx;NIC(!e%Qx^SF|MRR#ZDsK zVm5+PVpe9NP(}%d!hg=`lH_I`e!p$;+>K@Y;rlmmXl)CD#=+k@kUg4cKr&AP=P{s1 zcN8RZ;h>$ClS4VK$PPW9ktn%r5Hr5<={@}2x2~ce51FMbTaJ`^DNWTp7keVW+`NHx$?1?&|rC}%60vT(hC9RNRNe?xZQ$pJOHje0FPSGzB$l|z3y}h^P*9psMZ95 zDeF@cIGx+6eV+Xr+xYe;cktA$Rawi*6S+Y{>JDIT4RzyVdp*1VXAaQ>wCW6gBIgVa zlsB8Gu&~|Y-+k{o{`{$9`0&u~+T7zE6iJ)Xm4G?`23sTJ2!yw z$YnTm9J9asM?kNXIlR7#@ud&Y961GA+>7m(|0($9)yS}P;0Ola{sDOH0Y1bp|V z&scI#!;H@@ZQ#3~+`&f&7u^-uUbGf%E@&W?aS=!*Ms44^z=u6S!UVjwd9%WVi=11b zsdvA4G$1Fbm=Co4VOE(GHNyHf+8@3TymB!+X9)ms{ee6D;DtM&Z=C_1+6(TfZBx45 zvNuf7{JA`rtSYC(lfnmpx$ziJ-dV+C_i|r?Y?RI+H-YANq5tCVqW9<*;x}%`;Po}M zH!flOpZ}j2{rY8KxB=RC5QE?SW6)q$wHwghzYYG2RrH>G0llZcg7(%`jPKqAZx2De zK6>Y##^8JZ9>(v!iqS9s@DgdnPga@y%A}xnpru17;;bU z^J-}^PF=>c;KXz$*{@Q42^ctdo6;TGDLylZ!{NY6Ohy{z zYRWB+utnf3V?Wbxxbbl_iW`{V90)ZmfvA zpl*!u`>&(@#_yx|H41@SPt38}58}ZpRp3_yBz2eY6+e z2j9Aa<_ljz^VqX!Z(c#~^f@#~Ph6TL#pEfHnBp3A0WbEagx+O?$+z#sJp(T0Is4-b;4X&LjQakRO!PAHzO z=8nSEXXJagfZ--+VG)?|XBZKoIeY@MfApV3fV@4#@JIg}wy#}q1D^MOjo#zWq5s8~ zF#hGgMDLle0qqFm_g({5ms4Q@Z>ymR=rOP`8mpR$WJ>j9CVg=K>)2l-B&QJL(r9cg z>S?B`pYT=-Sv9&^+|28dYY6m(qu@7g_*)>NF7XKs`$v{LV&Kzd@ReoYuRnA<4WB*+ zKD!?{umD;ZfM@$aKi%JH4RTO4jWiLwZ5(nEVY@i-q%rj_(B>0z5(~?qvNCz~QbpL&yoX#6W(gVnTxzM&R(D4TvH$=QPf0{URA9C?5G(L$ zZbz8k3y2oOGRmmZM#%-MVzh+;n!odTvz0aKk)>lAt3+O%Z9QrT*t{cVw^2gv!e?~-@D}oSMR-w{xe_0;HB>aZHv*nzXCQl1YHQ(;kRlf48&L)^l)YGyc&$l zUY5+6jMVHqi{7QG_$T*DijvB+v*!w`Y{@MJf8JxV%2WfVveaxqh_hh`skmnj&F?%0 zKD`h8@&(}Co51aLv3ae-A}&!DaqO6DYXscg06x46G;ov7jo%;_98-cD8M8Bm!qw2j zQM$vtWvn%X^Lq!_oSnl08OD&u$C&{_`s_J?ncw+i@HhVen3(|$X3;L)annn0{Q}tb zgDenm^b}_Q z4e0YnKt~tRK5-cM)fM2QJ5F6^Fea$1E;IvSTdz*^b%+w5N}V?$*eC zXzyId@X!9CYbO?FFah8e?aDGRb{&Wh4#vrCII+?}9;WGnF zxG`q@i?tD6n(yKCpb?2u{x~Zz8lk;=Tfr{4-u(=>(B4d^6munQfX&Nyfn{wMT4q!p zKO(|U&K|;B$M)u_;^5HLGuA>jd+Q}5MwegHaq!0nHJ>L~b=yH1jxzwOk$X-Xs< zVmX~XPrwlL$U^L#j+r+Zcx8Qzzg`>RPxcNl+fX)0F2#j%eij22Lg-V16*C1O#FlF6 zTpk+VO{oa|^X-ysMMVx006Z@kUG;ZB>F=W+=BFees%v7}}a^v@R z3`cGN&Mhqs~j0!fZU$XJMGmG@P9nm#$z)LzB%7VPu)cstRRj#R6Au~ z*@}Y7P((`VrIfmdL_}H==TsDHQBw12V1GsD7I>9kw z15mF4567TU>!wy@BF!+Q7^dW(qR#beT7q=dnI#aJ21%L~c)`t49^DNbTm(IF2>ji1 zz{UIS4xaP3-R8PsTWjI&5V$F;pV3-AjG6JP%@+UT{UP=?gs10vdJztG+bD_jkRi$0 z>Fc>R=;0rI+8((})8ZyM%9>FI+u2we3SoELaO4~) z1`Vi503{FPN0lU1#S&~PB?cDh)1_82U6dsvh3s?$O>RyYNNd5p_X${>b&elL7eOza z0IzHTSC+x&Z#&!c`bydbnt5hbm?KEtOhDE;ocr1AHTco&40`()@n1D9p57RuX_IGH zPP5Pngc3B>aIi-{$a)5db(CfLu#KHg^cHZgbsmgLy_D)7xJ;574MLmf?OliEA zxpKJ0!dv0*M{a4d-vccS9HV~m1bBPwJe_W=0GF5CVXHS*ot?Tq^hZ^*pRWrb4Glu! zmz+toYsPuzAKUG2Qa-&8TSs@}|J^mf&6^MK4}Sg$zWM1rEDT3zGBrurwp*=nqo=!3 zXUET?!+U&fO~sx+Df9zu6XD|i1^mOWpT+<6^hrF3Q%7=R9Etx@Sco!4V_<#T9YPzo zn~TmY#b;o@{#$>_1!03>8X91G?5>(#9|AKy@c#S==9FiLsxa2bvL|)A#&=Mq11J%O zS=gGUj>*f&race@M`mxNY@^mm(zT&GPkn969g4Lva`YLsX%yNcw|X=`a16O;)}2(c zYsMW4(RU4#>f?$!va*SP|II7-yYF1ZBTJiD*dC!j2IBacBx0)BDkhVYY)L{!9TW#L zs^y3~>!9HnwBT3Pf^!War*lFO z)PMU=jZ^$ZO_?3hhb^!%1aEDF_j#v?0!baD!mhCH6g*8rY!pgWIzkIT5p2hLzl$;& zS{9)BLWCfQ^9Dy`hKyf0?+g@d9#B>(YFnII+Q9eE-^6z=+`*aqYginPF&MYv6cE`y zPBL~Ml+eY+?!6^o)HGNd^l)v@EM7gaAOHNZ!+7J^UaZgbl`!HsmzwRFDmsrh3f709 z`|Iuy+WCR^P3YyQ7(!|?a{^v^w!qdlcw-2Fzz60h9&(UP>l8(FNXw!lQpP0H$mgl$ zxG0lLJ-6;p^8+U}2MwG93v$|Ni)-qZ?vZ20 zao-J$R<@k|)C(n)J-1jXFe9zFyl8pZeWr*ynBIb3Bp1vzt#wh~i3yT0H4A&XlyDPtHG%CC*w}Mpb8I2AxAgbZ1arGuuW;$8it>^$azF6G?Hn&0j zMmfmnawJTOJzX&;)nB9ZY}|D%O%n$QkcXOf+~8I#r!YNg_(V3cncJB_QbNeIo&`Eh zvtTP(<<*Xjkgt|F;cRU>e&dinl&88OsqV&kJ<4+ zQN*_ltZjkThHffyrtemS!o<6TBX8{s-@T?RH_p^T=s~^4-2gn>bLFgV0qfh~HeKj3 zP3YngN2i^ft(I`-{52~p@QKSILMo zh7l4DZp)K^L=FHdR$v+OKM-fCEd&r!EY=An}xR zU@Et4uuB<^Mv^B^XDP+E{Bi+-r#CAo{!cmFQ^^zwM_-?D8yOSK!0aHY^ImZB5U_2l zL_oJzh|C@;d#6XHA4chYXEqESgYviq7H5q^URgAdQK-56Wg%xXb!r5w15goD4?8g> zb`o-fFEzOCV8-VHr%)dj^_~WU(rhV8kxUzNB&LcCOh`g&)H*f3y5&02jGHo|nVz3) z4~>?ptp;6<;nAxeXUq|35nRspsYvonn=rnB6MSxwjE0?)RjRdV7t#K zyrYBr_83^+05*pHZl}PQL7fKxm2x3yqRQ>p)R#i@;xpcJM{i9lQ1!1@q890B_l z+yPn!g)N4Vxm@4BDyMqvTZBRfDD! zxt`H)Kr{fF2He1HT^)|VH&@(x@;<+s6rCaLhAlCvSFWhnPQ@k+MbGAA6~|htdfsX2 zT+cDR(P5blb@=*gZhwlz%uZS^xwHGJ-vDzx=g=`LY|J>H`S5s_Cw|E7pt`S`x)EZE zz)vqV4Y(oDa15+%yQ!w#v(6SB_KIiQj&xe^W{iP)&V{*DL!W%m*IA@Znwbdrdu6kIMqGV zi@#|Fh-?;;c+?oTRO_5-P@IiCMF{%#I<) z3=Bu0^=)TYw(OYD|514E_uMRw-V;>mxZOl{p?g47F%`@}K%A)e+dIfJC-)nm-#T@$ zvF*H6`fehh2Yt|>iF08rVNfVvi7T4eru8aI>C1WJO$&2k+G^xZ2s#1OB={`fO@A%F z&Dnnrrx~~Gd@r}%2_-ZfrQMRf2AFLWQ~CoXx;CplWH6XhR8SWbH*ld&HG=ST?)mlj z2HbBQ6OP*C`?$UhVt*Jw(}1I6v#)HAq7(*&SpkX+8_^JWCUr-Jv>^W$;^lm(GBUF2 zB+5u7T~f_{v&2Yw4n|@jc}i$`HI^z{xAh&c6rAb!M=w`R*u9Ai|?IC_kXCV_@6^#$)g(s0^<* z+7{e0XzZn{D9#-&Kxx&9oFzq3>?xu=WY486bA7gST38w5c{*0NLTUKIcGRq$H3zAP zLe(pI>D4ufJOL*H{7EL{PucU^ae`#*J0TMsfRdz~Mp~Li#Y7ckY;dFU(Go#5TSDjU zh2F*Pxotp$&~qJga_f)0X&K<8UMS2D3j2)V8yf@=oBj`^n4nMqDt*`^FE`*?jFRGm z46fV#x{OF7R%s-V4*Ke31f;qP_&E|u%Y@hLfsnk88vh)2Mm9*ds|D#84ljddN{_I~ zY#kg}s*bE8xmwSb*fbzQ;q`2Z7b_4_1%q9~jBv{mh4;88C&VMo8^#9E5`1S?Sq(k; zJ1Jf5JqFuCNO>%jEnotU;IX_zTJ}XOJKuYx#j#sa^h_3fET!!jZAp<%YO2^<1Yeky zm?9Xwq^6Q4aQL*$Xa!jz0-_ruGGooW>$kCWx26UI7!y&_qrr}vd%1RD6ZT? zB%kA_Nd-^Km^!KNg_Z#q_s*k?+$kZtkx&K0h_~`sOl9Srgo}Reu+z-EU5qJknr@qd z0m5Ruz)Z+ZKCAd@Ka-k|)2~m{eUMj{-(cKIIh~n;FS#-bUJ%#$UxSyk?rLUU0C2wJ^cRxIf1U#XxB>OY4-Ne@Hf9`>Z>lFP<5d%8Sn7Wy zzwhcQ6)ny$XnHZbKbFoUEgaatnzdO{R@VKi>mx(-_KdHuUMi~z^%WWk5ibkFzZBWd z>q<{V81$4EdlLD}$S|^Sxj;ci9%Docnsiv@jo%*Y|MTJ!qIQRjlT7*x__B7w0HFCD!~Y)g1t9+? zH;R_CS{00C{U~sDs&oUl|CzMXX z(Aa!5VkT61Q|3~W>!SS-ng>DgNu|TD<8e-*(ewm@cKEnd2zk8(f9?1c&PjfMuU9_H ztJsgf1(DS&zhQ}5$?u%VAK;svVcw|Qln(s2;L(Sz-gg?y)E#xf?uRO)x7s!d4+H~I zTZERjLw_?rD|0_|%gTu?=lW4FZto@!9fs$|sks0Ed0mkfsOa64V{Mx|kMDC*mD>oj z4DA?Ok-8!u>oZXN@?}u_jqiCk{=I5uR=~Cp7p_b{TU}iuM}5XFL}VezW5Sy&5#;{Q zo!v7na?q5ZHX5`aZiN?iD`YEY*GDP79wyA{dQ?5NH#R08QGwVb^`b2~ruG}sa8~;P z@5|lTU4_&jrtFRb1!;>%y6t(*KJ|D)YEX+mB~NzQ>S+2fZ=iGV;1z4|%!&ZT?@CnH z@>VihUP0$ufZJ+F4{X48Y0rWjEEIxdMWkF${u>zF7-5yni(kl_YcW3dyONi-xQVWu z-V)aO)7`32Hs>WrAeQ1oG*PdoSL(O7ro|7wm9`iYcT3bQC&XWu{QJAxV?|GgF$Z^= z-1+iyCpJ05g?WW&FVsqwi@1v?)+n+>TfcEjOz>}8`LjRI7g3!>D?U?Rt)*cB*!{Wi zmv2J*g8Y-ki9{zq*5Z?@Bhn1GwO7E6oc-DAeQ)IUuR{&H>t~Z26`Bp~JH`D%$e3cp zdQrh&J0&i^RW>1}%D0_n_rL!Wm9-By4L&3*x7NJks}+y29l#2b(xw;k@twV}m~=F! zvhI)a!08H2f8ium{jtb|aP5f!C33*=M(?JVF6Dgd^v1$$p4!7hQV;2>PzzZ>cDH4_ zt=wM(H3g4@hdwu9seNtdf+RwX*T{>=9h*)peB0Ce>5v z?G%daf{T!!*2xdjo^H1Lt$>l|C2V&srMzWi%NMgu$f3&Ny+2vt_03p$PE2EXeEoA< zOZ%i=G}>u)>-&Psj#o8t$7(Nm#^((J_ct~OF>N#Karg4=w2;{`ITUegfJ;g_mA5`* zw(3YYL3Zm3Cmmkv_3?2dm9?*HkK55-^QvPJ<&{#OR2tX2ntwj1uxwlbGfB;%fq9?`&rmbgP$hyKjjYv4OEwI zSiLSdG%a5!iEp+)*HczFr%H`kxCu`7m&gJr!bkPa*nCg)@Df5b!?Q`e$^*S(lzFK7 zZMru|p(o9wCJ$SGi2tRsZGv?p2bsWL6Uehmo#+ts=M_K1`nxpA=CKge*zS5DjDKs( zP%h3?gf(=}HiZ%87W&xFK?uLQWhtN3+5ivz=)c*&j?yEaccNs7*rahm1cS#V1}JsE zUcaaiUqLv8Peo7NVdMSBx^Q4ag7BB5F0c^mM|Aj@Pa&Jzl1n__p%yI~CNlj6e1lkngxpk|2cO z7UYH(V6~ke%R_LX(WF3yF>DBmP;ydMxa+5P=r8>IHUm=j253oc*0#U&1s$bXuS}*< zRzrWX3kS z6FLunuY73?4{QnlcPJ03xC{)*RU03iCAb~x!97Z{AQojI#ocO`07fnOH@jE==QIXCHm zAj!-9<+I&*a(mK~SXc5s&c#LG!^vX)f65`39 z_KR0Qa<_?Vt$#vrm6F z;MY4);A@?P*WuXF-t%1P{f&jdgI^>N0Nn}yK63HZtukN3-@AMFm8==Lrrs)Fh5o&1 z3q1}lx{G^k2*LovDJABXg*S|#AnV?XfZ~HCp2BqB{c5kKX(Gh_;-t?-TaaX^`RyKc zz&gvt_pkEc)ejosFcaQ(eJUR_U|=} z2PDqzEG2!(dVyI!>~%X*m@eSvK^j4~k!QdivM5U_n|lHBSo2RmO9aZ9ji~pcsej$}ksDx}AbdhzJXM5IN` z`^e5(hl_@%im*Ol|K%@Z3s{T29noxO@_2&{f1q=}rlau`8JZ^Xf5egIcOm>vP$65| zD)VOIVBiLWHsd1R`x-hQroI{j$MB! zhNevkZ>Cco!2Q!Ffi7+U+1zN52PP!|a8y;Z!NurtY6Fq=e!kh2!^)yO1+HhOHgHGK z;MP(c(k;(eA4JhaKXd`!8vzxCMtq+(K+q2E@9+`mHqZrNR9XzqK;Il_oV|Vu-=p0| z93eXTYss!zJ89*YDr#O^%+_y*Rk)l1ti7mDS&*J7jK3kEx)tm5>O5sqY5c5f&v#R0S8o&$Hin7JJ~OKg0DntXXcWnP5@xD6ZKF9LBvYCp`2Z1Mro0a zu!t3!&!9-}ZWZn_ffPgCHc7=_)Z3MRxeRDnwiY~#0RdiUg$Bm>2B>Ju$Gz95&l?U+ z8bO20gcbR$SuX(Nz7ww%WU<&r_g^bTB(LdHr!i7nqoLT4RyG^rOAs*Np3RKDYA~E|g3aT1;Jc{z>^iV&~GsMEAwhA!Wa~Cn75zz?8=cPj7ttL8eLt zMjiv!Q_h~$gGZo?0DPxFt#|L-tYbU_7|y(-E7eU|KYizomOLZqqwt&kI|GM%CU#e_ z_@ivCuaFA*|BKy6h!b9Evaz%_xWf8ib z{ARE5yjtiYY{Zl0p)Z=~n*as*?|tmCE7*3gI9*Q-5vD{p+&#$te(`%iaYFFAH$EYQ znTK*M=ya6L-nUlo;-8i<&UxJhG$F4{GX%!2K0CnZKVwD~-M!bO-g#;|jM9ffFq7N!EcJpa<81g-(`=7adEr?_A)fKXR*ObhPb34fYAP4XN5>8lk)4XS!TG1k zcK*0bBoH&wM0Qb&H{C!AuwCoPOb$u;xS{`6Ap#YBB5MZw@!}HnA1dL}RlsOT9C0Mw zaLOlFq;*@djZ&#TDyk6%%6?C${UNO3>hw(a7NcODeq`Wg_s$e(+$kl(Rx(&A!lUn(2b!3_U zqCP{qlKc+0YNHLH-NUCzyz`KOH|&7Xyl3+1K-&VI#Z z@J7S5id09+DUSxvp~3e7SN6I-$8_dtVf(YUXb69>0fy8-&wL#>8_)lk?uzN93crjR zya8+v?~ai7jL2R;$SuzoPZd#A|Dgr&bvOP<1B9xTToFG=Hn6V7x5fJiPC5v(%F{eU z^>obwb`l&7`y4tud=_&LE&%@bG*Mf6>_Y|SXS{wmQlkFz1;~#ncF=~mlSmB`(U-6B zH>%7i(sue)qL&6Pl-TzP|dbW&e?q4800OlaFUsMVAy|1Mqx{Lh8{NObnmN+O;PUePC6Mx|Fn6_OvW z2+ZZ!!O9g%d@4nbVADx&P9n~7ok9e_qQ@@OeNXGnl7Q} z%?x8>0^CT9o6<0T1~i?kGFt@G-TwsDIbQYFJ%@Q-Jh1$g)mLM+boQR?F4|lE2;!@w zaCf2#afN%@Bf}QloZD}z_VBIMMnf!3I*nI=6Mm+T;OI3)lZX!fQ``gGZoYP+-$dDy z%d=EuM25$4;Riz9FLyV;SxY=6bN3}F9aRNTgtS=;00Fzgm2-uJX(;7@>%S7SwP;HK}X?T-@6PtcBwFqTS&KZ2)J#r~3Gw8eY6E=`59{N+b*enC_H zOyoBewq&yT`f`D^>i>4gsM&~Y-xzha3dZCH)m&MUg7X9e(6@}A>O#j~vJp6yRH1*3 zU;EO!Id5Tty<1&q(f}i_S$Z$6a#S|Q@1&Nvf&MY4cnx2$eQI%Fx_{O6V5ke)z$ywz z*6J<6-#Xm!*gW^YJyMZlb{pwz3hT!wJ0~Ki-y?jl`TivjLmQY|hnvmQUeB96Mx8rn za4HA*I3p2}rUhmsRM|-Sb-m-yObPH$)V~lK0ws_Br~2mYlI-Qy5_safEMxX0DtCqY zo-~Whv&h6QprM}G0CH*hztw~>@iO1A`0;&RxfqB!TX9hoIOmUlWk~rI?wYe#uGjEt z_H@w#!HFWwnDEf?mSpCW=QnOxhbonEsR*75yQ80S!bR@Iau$;{ga6wCa}TeSoYPA< zi?oP^R79ah4(f~X>3Mih=1S{RrvxGp&thoD8byf3p*qebf`?Rct^zD3t(RyV4W#*y zQ5#oJXAl#0=6b1iP?;^wG`K<-@t?JTWRau)tjMW!&0U+fTQgpZ7FlCRkNIH)`F>!A zj?@Cwse#QqmvwqV-F=Blr-%fIj$$5bV}~GLI(Q=5*3j^;q!p(dbi6l6|C5yHWlW!a z`)=O|G-kQDrg>Yb=Mt`1k1G59fK}Po6XBg_|AFX&`R@q4)kZ0Q!;J_AWTG7@vGAtZ zZ+!CC6DHt}@i^PvhG!1d!sBg!w*nZ_gI5~A^Vh@P_0C|9_yKNy*|aS&UdqCeV+qX# zG^(%q>76rI{VJNXoHI~vc4s?)RT6jFAHitu^2yo zZ*$M?p=M#yRMw(_u$Zz}^2e1XydS@^4+N*S1~(isI>eu&D}ZjfK|5 zTkztEgU_@V0Bc$2Nt6)VpCc>dLVuB@{6cY^yu##nmmOqk*B$O@J2#_peGC2=rfKE< z^(HGi1ZQX&V{X;rh8)JpT@WBy?clNFO4|8KF|6yG{*dEP=h0jh7f!aXeEOxg#|l?C zJ0}!yD&w;;Yp$fRl5~<^FAhNBp7Z&m#(MxEZ7-?jx0vP?`ezUb@}|O2SI={ADB#;! zVp(Z3Y?T)MOPD&c{lMeifr{^gG;{83sW_EF@if!U5V^`uHf@}zbR~+gfPb!?uP;n} zX?~0AE%2xX{%81Ac%1b5upfKx!)^1MIEmaqm)V_7ac7FDczu>yUsDaX0)q*C9!d%9 zBmY#HA-CCAN%sj62sWKCd)9`x99_Sukd||{L%<~zK1(Qu6qw7Q3RtVxEudU_fBd8~ zqCl*h-}X0igfHYnpgHVM{c(~Yah2Ui_(}&1Z}9CIalMza%bF4BQkB;s!Q%`IKx{~zMJ{@lr{%9a6vGSQa=7dRpAOyv8Vr5$L|dA>Gq&9 zHgq$p#DEJ5ZDOB%N$UG8v%|yj?WlEU{waA}9iBqra_!PlO2;LKJmPnR`iEF{Qp)@y zt{?ohJ;15EmgY4eT#L|8^I0&1B;26vi|Yh?LGS(cVWhcDDh;m5yXr-ps;DeE{O@frl_!&o5xIL6U+_9X;JfdAtrNDnHU_gZS^ z(QM|@%5}I0WANG}#N+Lz6|~zkLfi@o@&59;v%25ADAK+d=j%!btx^{R3rt2;+KckREI=tU==l_ z;vCDZs8R!j{OSF(JKvN0x7I`Q|5?fC&gj~W735&x*J1~vM;A747bY}ac<-k#dN!4+ zyQLjvn}4fgmG)UP)AeA#@v45(GYiL&m8&##+Ra&k&Ca*t;+96hWNm3#G^F0AYA1}j z@|9&pGXxp@ZE<3n^7KS)e!2G&ZjO!`&~RF7S0i;Sj~sRG-6O;o1|ys^yU4Z*`Y`p< zFR+v@Kh-@#WI@t*Sep4ejJOyb*8q>b>y=;9rp2zA0cdQ^Duhn3m+k#ksK>{L<7Kb& zhrjl2O&L;+b(I9_m7B$6FE85sRLoR?0CL3})1h0rwvJ&7pBc8CX8?x)cRy88sIL@o zfw_+~5DJ)r8AlIaqR(9O^Yv-?ekm0~tcn{GfE8NE082e?Y*6TzRhuVme>#?lo%4ZT z>rAgz!cx(cT3ahE5uN)l-xWe}O)j!);|d~!l?E1+2SYWKS@x*^(m6J7rHvx+S71_a4>@p7e2r^}_~;qV9e>IcMUQLW&1 zoFxTdRdxmfZ@k5-9Q%w`_nMY4HS;pUk4Y)r_stsumNwAFmNE>f&>+S_qhwi}DdhW? zy5W*u)TVk+WW|Z%9R;>zwNF>6gtWBX<05`AI;esTDvvl_+gc#$+$!yaH4+uQBZO;O zN(Gu(f%hL3u4ppztP-g(@jGb))mv{9NPBIO+t_inwyn3rBa4!@0tinj|KJbHrzwj-yNG)AsICRw^o%n8d)(LV#^)`&z(w zn0kEY38iF)9$1tmS2t4d*S~im9xcHDf4xGMkE?hG$AVdr?^_EQ#NLXH*=8sHX;zi} zkf%{wfo#j~hrV@ErREyb-~8e(+7*#hGnQcWjv;JFepT7xWK%>ycf1m#Sn$k%ao+J! zig&*ONb%GXO+ecfDvmI+XK;Zi0S8=c)()pEQDB=7BxjZvw6b8pVQ+|GbME@Hf z>Lnk~BQVpNUlsTM9g-1oeV~?#|JMrasixHP)uGy9j;Vu9wUhDM5Sul!vk>;x1y^<5h#!zWKYcfAIdb3+>{50wQg5v5Ire!G0njKbW` z=d~vhrRb8bx;OESm6&CQrNu|wEj^nG0kNta*H5EqVoRiG?{Hj6X`H;@a`}KkCu_Oe z2XLkZm{ z4Fwh(f_2F(7LyZjyCW#@L~CMi;%m&}LJQ@({~lz{7#~Y^@82(6Rwe}U;8DW36=C^8 zSR7@#`g`d81B7^`PQSn77s6$gOZ_*&Cd9+tMz|xEjS|=_eK7u5VnmlmN`X#0Obo^gEk=O`2 z;XAa@DrQP5feF|HR>d>@<_z4v5Walqn?PUH*eb{E8jPtN!@>0IC`5feLt8jokP4_OoKX{0E80h7{zuk!qN_t1Z&p!I_wu5;AyKwt9-DXVquYi{XT zVA^t1uuo+MV$GWOx7TBBrS~8*-#Cx*+3kAFX4mq*pQ_|MOnrsW85>%3M8)(xZqkrl zD#`Ux5#rhs%+aD0*=;D}YVi|ui*e}8THM+*%B|sZ?|bPLwouf7?(M8Cn^tBA7HV!P zYkC0*sfeVd)V$9^KYi_wuz#4K$m>_A=Ho>Mxr+7)!j}A#M~(bgCL;n}jz3nq7Ef9z z%p(kq(Q%qEeAO1COQ-L2k*{2+oQa|IrVbaW3!8i5-Vu94Rx5aqa5>Bug8#&=eRx{z z8u@He7O1m)%D`RAU;XB5gO<}3u?ia;(z}@|-{LZGrzT;t$p$4D;svqhsT9F3{Z=`_ zTB(^R;r+%W2N4n#!oBLI`NHHcdrWdn!o}_PeOW$fX6)as>}|~_S}AQdE3GbNjnIzQ zJ5V`}?BMpIaoiNW}@! z?Y{nC2XtJdJY(D8dbdOZ5;UEA7o!Je#~o?BRR^1$Wcw|AdTIZOFTuAoGfzt1A!R4h zg$2(5Q(b1IQd}otLab-Dt3M$dK5E>49{lX;7+=uOXvZKb;ECjjl6l%i5v-f$>=WS5 zd~4nb_ET;|*8bLu!4XCBLS!ECNM+A)(F3oryhk-6dJvaCc(*o0 z8go9KWm?vG;v=*)tuEh=9thBp98YfwSWzgy!(&Y^MpGvQ#FS6|t0Iw^%^+4)v6Nc@ zuU^mr(F2|PMDqAKyybr0x5wnqZc}ahi{-RQYanj8NcoeH5NgfgFRV=r=8fvjv6L|@ zMeeoLfGrF^-g;~t`1g99OX0Ubn^Z{VyPB~W#}7|Kdd=GaU%iyysN5vR)pq>-(Kl23 z;>qya*`Glb^uB(5wmu!akDhnC4XB-iyUxlGOq5n}d3_5Myav0@VtII7Fm?$e#CJCn zVLcV_mLWSwd*`b5Qo2v$dX60=!`Hb8;}(^>&>F+cU1$|FTEGav`<8_KrblT2;yj|R ze_`XNbC0UM4&8`5#PCVUJnZ~k!c30DnwyH`XG)>d7YZzE>K|o_UXzKlV1V=sA{XxA z7zR^6nXXjPS7xd1SK(_mp-WAvJIH?POc*?jMnc&2+Lm94ZM88Pd-9mepii~%N z6>woPl4)r4-=;w>uk!JQteS1Rm)~fWtLPmgjAPTRXM+uYD@JpM>m&FUbi86D6(&fvd6b-U_!>_F_YJ#PzMfF zUy&Y;6xz$`aR|iosUr^1(bNm)F4XNeUtZ09KB3~F{>}WR2~#gq6V6JC1H+5suBXdSI!lmwmRq(0erggol4wqT+MtT4Wx$ z>&6fwsjL7Ml8|z&_qgT-|0{np$e&r$Nw=QX*?Mlw!=d~$!%q5{uX+Ft*HKDu>4kcw zIw>FqtQWO*8&c@>%qJLb3**)AY3t+DbBy-M;H#AIQC{gA8y! zlq=UVaM;+$FyK;y!TSfagS69c|8^Z057TLPq`9S2^rs7|cd7n>Wd9KPYN}rCfC}*F z`MKfv=U;N~%ndO(Bamg_8-+gFT@aZEU6MBi9ekFD3@@pixvn|naA#Ke84S?H^cu6K z=IZ<1qBQbJT(;oNwoFEZa9ae&+@ReiJ}ab;rcbYm2}km zLl-hv`6GM5TOjf>A>e`xzBShScihSIVy@o~YO2@M*?&94Tm-ToZ+Zw##%&3ARq@BF|DxM=!tQ~a?N5oagMHf*(_in7A zW)dNKN7R6?Vw-6AXU`aXu_vL6h?!}GDm8!++pcP?0pmMGBYmOERRe{pnWmjqA9n5R3)PDy%hi3misO?EJRsTlyU4P9X^(E=p}7Fb{tuf>BCP>o7D^fa*``7 zCb~T+KYds^k;|`3hsrehhMvB~1>jDM@bZNpe-M{Ig%YLV2suVCBHd^=Wl7^?I5D&_ zp^1lobEP%%YwR*pcF()Z^tR`Jj&3$_s`I&UkhpYnhvXgRU99u7Oz*jVj>$O-M87n~ z!C2m)^ZIIe_sG?C+(5PPuWY1JY?#W zoJ8dt?$cGw+;%X1V117_WYx<=#?c~Y$b>Mc-kHSwsTT6G2;%Q78<+_8J^1(%R1DB+74XGMux$BllyxUbeZhT{e3Fu%|Kq;j6(r#COM=*yJ00~jL z?ZnZ|@#VVEO?4?MJgPi5qHX^<+i8^0fdSU8?4tR%=#xe-<2ThnKn!Pa89}-+3DVDv zfca6(`KhFfzq94(=A6tZzxm=?7Htd!4^o>v%{Tvb;_zC?k6%N9Y(1e*N-JC#rF0rV z#dv~(dmCv_B0UBDbak82H=V1SbjVtLw}(T2hpP%FeR?xw9H$P3>V^w757O$I&eG4V z{yKSIJlIoTy=B^3{leFZQsm+>40BHBgEaioX9C>mc4{uk5?f=%(|X|Noj(+d%x_VA zT@%Z&mQ$ghPN*=;`fk@l)n(Sz#<;Vr*oKVY`K|j)_qYL;GMq} zz_&HzE|H;U??p+pV4N#N&9xU<0olLPE=uyXaRb4b~(`_2DUTr24(qm+AyYQ8`HP^%YS~;>;78%QSU&fb6HYk(M1z z_h%ni80R}~T|ll}cKmSc0frflovr9xbe1~2X%|7hndu{lL#(ME&>_P|ufKILRw_*G zLboPF$qXhNtoDW7dO<@a%LryI5|4Hi(}DoWd6w7jE0s`NCNhHd)BWXHeY*nEdopz(! zdBHR8gRyaMB)O1%Z}usXqCZR`4^6fW4O#)r;8O~t0VO^KEV9$s7bJ?L!O}EHmBePJ zRZU$o1>e1V1mDm5+wqDD>}5*r4BFmf3>r*b#KJZE()P=_a+3*z6nyEvr>$jnBgmL4GrXq#e);n zS!l_4OG~9p(PhBYh=lM}+Ehht5xqv~DjpqX{N;sZnfp-ovi8X;CvGs!7a@42vC$na zt<$cw-JIRG@#5ipXz;3f5FK6m8#(iy20u?8e@$h`<-s;!v15%K zUr~Y$(3RQhrEDvoOea$IURVUK*}trhF7PHovVY}Ut?4deE!DX$7mp2=X;Stz0&9gy zfAhQtV`V3*jiBrwW};8@fLk2DbZ_P92+3w&oBZU#HN_$Z_51-OIZ`DUfB{d_vvl9N zi4{el+-EWp6IDHGeQzZmKkn&k*O<%w{Oe5vsv-{H z{b=pji^6Mw@2GffBMRk~TW^xIi+GUY2l{=`;Z*eHTWJ*d&Z0Rrz8I1NxyQ;h-SP+5 zTlKi+8c}zUFaCN`^aXv%W3`w06VB>=1CXe`1)vHWr@{p_61Q++YswRe2Wb`ZFF z(?9k0N}_aPl+Y6FXfbMX5G;@zV^*_MHK{tF)UL-%0y$WE!6O(y_e!^gK77?ysu|`=b1KrsYVvw{mZ3ARynew$- z*5`E}rj6p=q?}=VQw2j^zYKhRgTB;F|NhFmXV)M1xM-%jCqSll!8Wd6%q|zdBf%yt z^iB5s(953&PT~ihhkGKl&%p11k(ewsx*YWCXr6_wS&OlfyO@I~v4+Wrd<8*QU z90jARN3%(G>2ILUv*DfEN^{(qFV4I{gtEP&Y5!oUlfO6DE-q*F^nk9RI3-dv%{&KO ztS5s;lU&`I8{P23yf0DH>mh{($xilAcc8AeAj){HR{EhE?ttNVxa9YPTTM2=QdBXi9ZQ#1!4@6$U z%hfY4h=B9a-x6=Bn}LhBmD%(_1;*iBBgRa;)#l07*5Bk+?=K`YHHf|&umw8KBP7>_ z7-6{zL*JM(iPCSm8K?3Bj2|LwG6@eGK3%1g;#tqIWGbzOoe6s#`t=`Yv;!14HXpi> z(!{RjCcISs&NK3{%=O7i++>paLL7l^7%)^T`-Ns|B}>me-5FApfC9yBQzREDjkdKd z2IRqQEB1n2DdXX8bZd;lY!_vKX>bWN5B-^WC82=2Eep@aU<{!S}_3QxVqNcE)KpsKe25dnTOwoqlU;`GUNp_w>bb*&%>Kbx#D~+bf>V7_+zbjw-Faka>QZFb9nhgT_9MC#?pIjr9aDUGlDZ*6L<1VMTW6I ztATBzZY6Tb`(F@hVPS*`oBkUz`}1(jp-Z>Ld)g`sDx$6=$TZP~^LI>D*b%iq&%oy! zmEu3ODSrTSZ#J#it#U&Z7;DS8O}$w0ABb8CQ3a2M*b8aVyyv0N*V}~(1r#A-d#Hik zAIz*Bjg_YHU(J-5yvZT_+yEqsVv&O89YC=rG3LN~{e39?SdVrxte3NYdP{>}%4 z`#(Y@tKjwh_-8{Zt8knqt|@LI$!F~-&6n`R!f|ZLCbmrmD-8dkUL@NX`10e1l<}ti z9V4}wEOUvY-Y}m-5C~eA?0b#n(|dQ;-Td|gqv9XFV0QS;`Chw#0cN0p#r^z*w$4j}acoE+-iStJGi%b}q{wRkn7BqdZD{ADZ#!@p> z=BpNvEdtfsr@0<+Gm*#$qErvpoxUz|Yims-8G)`?BH0uPGy17L;|$6FIvd)XbRcu) zZcES&Ui1({;fc@GQAMWulI}7O(PI&vq-R^lkWmtA>=)-a_|U*{OaLR6)`OE$a_6?C znt4-;4dS8aKL69V|KHnRVWwW$9Qik6?gCp%A?MUlu8VY+8;!Nefp?^|aZf#`Q(sg7 zl<7pWFS$hb z^1!XE`R7mCO!tM(@(@bXe8!_?lYUbA!fLPyL0&JD%MWuwP^CO2b8rwdXpu0{YogI8 zZPrZgOO*D=>43kEwZs7Ri7NQ6`{bAoMIyuRMdm%rb6@kB+?;7$1h zR6F(zPkUd}Q?)zPBwCq2QN?MctEs*(0&;Nmu$qz_6cRQTc&|QGd{bw>cqPR8*BGh)^@k zw!Gf1!>c7m;EMTPWLoJ@)6FqXjLV>2ZIE;<0^u@3!dhB9U%&lpB5xe)Tm1Ikj>mb# zQ-yK^)WBc2vD`0Fc?k4GeH5iT3&)YX-lIe3mCAJ-HLkt07o$ec1%+4l4o@}y=w4Hh zR;OB@#*2ixqHu)ORRk)%(q;9apx zRnDX}coKFmjgi6M;%v5>vMMD{g9b2efhg2ZXezXEFo!51Gi%(h1>pXYo#6N1?4SAy z8!Vx$MLrW(vaR3z{4pPUkmj?mb0{Ed9oM4`?n`YK8GS!nukUUuyIigUY}9Cf)`^m)!h=2BXr*h>p{yv4;xbIj;o zD*lbSB^hW;?{#b;vD%koG({eT0)e$JAV^Za-C6O=eMz`f8su5(1%Bzie1`GBt<=1C z&p#px9IlhiZOqiwZ49W`KSZ9dXCD-|z4v43+|aO00? z+RbWRla`7af=@!`1u`kNx|2>ltrPH+_O0_4EDYoHz571S4;026-`H5(uxmclLNL`C zNb>MjdlVY&e6~Z4y-pHO?IG<9%e*@6dpu=yNetV|vOCj)uH#-#&ccb&+s9qia~P^1 zZUpGEMzUFIre+}OsiZGY6_lDbxJqI8@A-1w8V&p{kC|AdF^8j?pHND1tGNjTb z8mhEs@<%FtGMbh8Fg?i|7nXM4&IW5c1`xEOrv{&>vgx%A=5$5+X0!L_DxyN-8A-Z}f|mPEp)o}+nEypxv#m4;iEMwtcEsOc(fUn*pc z-tm0m9#R+q%=O#cr%gPNpt}$ttew9*6YE0+le+$A(C*9O7G&8%pX;Qgh>q||v ze5@=^4J}_=f;3Lq<4W%D5hBnTKDp#*&@sZ_QV)y|YmV_ah{qEApRcr;(tVLl%2z6+ zOzUzUv4}y+1kcR1Ca*{5v91Ouo&}bqIIPbb*DCW*KfW6RaQ8RuRRX$XPve;I1ift0 zlgq_fq)iPnSi)Z!kQ@L@P&1OZme8IV&K+$}=y^ztjZ$DlE& z4&RWtN%R=Ov;6~jmSAv6@nre;8uaPANeI|kFAJA6aunqi%l2MA0EpQB+|BX+a6;b? z2OXfNuX|D$@3k>l1n{5#cZq8uj|mWHox?x43KV^T#q|?*-GuXWr6f;aZ1J0L=1M4n zC-#tiusCFu+xz(FyIsLuuvNjH(*Un_g=hU*p>s`csF=2EuX0%XASmHKUbRmVv(V9l zS&r``8)P)nKu@8fKn)Q(IkY);(P3)#Xt!x6CL4rys zoaN3x-Hn!B!=jZXyRF`pHd63tA{f`NRT=T|oV(L3t@-Ccx7|sOa=2?-wE4VJ3-}d= z=6gHEj2memjCPMuZeS6VtG{F%8-U6yE6V2lcyhhY*>LwDEK)5LVLJx*Ex8diUPVe7 zVv=hyy;FU?%ArlRW>pf@*7{~&k@dp=a~9yVbN0) zo(Rix4*{!J1Tra}9#weK2WN3~k{b5fxXcJ;CvtyT zanp~_SN@kWtsb;8(x9F;I>_!SWOGb4&bgM^Ppn1@Y=4hfJy`G69T0G`7ERPQbCkLM zr{MmBh8f^p%Nv*N_ zM_#L+UpSfisrquz6!x?`DAc3PlB2$hhGIE2=mb}rS?fCB0%W>unYA4E6_3s}f2~$; znHU)#i)7HbGT!!Wi4KxeD~%1SkuQ`+58nY-r^}3z>utVl7S~e+4#uLjq zdFb1ISX^0jPEVrDC_YW1k(A^kM>*C98}tK&K{H)49A>J5L8Hu&l0tlJCWfEo4=^o} z$5@6^*B#usJ(FPh#mE~@VR9zHWeNh1;>sVE{X(h@4Dh=8JWmq<5A&Y(9UA|(<6 z0s_({-7|_xcQ;CR_spDU^ZoswH+*>VTx;#?yu(OrmH%sjug41e?!X7CK%Qm? zFA{w0_`_Qk86My*wP6;=<;*LG&CdkRADlkR?Jvpu7oJE;Y8OgK?%5{4A;gLOem&M* z>thQCpHBa5<`tUk9Tw)Cee|(lz;Y|P{`+N5u~%{_9~rjj>m4|^%mnxC%pXm-EAm50 zu3`B-lh4y%ViuL17Hb!gz0^4Zz>yrwRT*Pw7;hi{dK_vk{wO;21<7QIg6U|A3Hd?wEyHqE? zI&yvZmh_}RSWX2xoD-rDt@w6HNJa%F(fXBoL)(`v~_JmFG82?~cmN zFIFR8y()`_b33mRc5T2i@bD{V+sycT0xrt;wwF8EjzafNlz?7{37(CZIDAm~VOn*3 zfoxM^(H%b3HX-moYFF;SepfAiVLYmJM(!R?l?yR!Ef%~>H@I_xyk z0^2^2os0?Gzw28gLRe@yupM3u($a{*ZM;V`)yAxF*#Fv)653aEJ=is~7*!^Gzm@!u z(K%!ILP=ffXw7gZWf)=van->&Ru~ecDzUmEOLG4!cvyvbYD_; zZ(89I=;q;J8#S(mi(1QY4R4p$DV?Dk>|*Cmz{-C*U}GkE8B#;k*ku5$V7s-*7b6F$ ztBzD#l6HMtPd1Y7<;s18=i6>J61`q5o@g4c)J+7(e91Q4e_|!UZyf?D-6yh!2WwMh zr?IdPwEpX~mT`|0J}Xf!;>H(Dqq-<>=lxZ#T~bptd1zz2+*Hv?_iY!xom>`8Xo}mj zGd&@MN{pFu>0MLGXFm9wNnsYA$V4>|7B`n9DQ|Ww+J12Ukj-l&UT{_*wypnDA+)%b zJdrbMPYnVj?dT}Ki}57^KR=nSq;EhoYDy4c&foc53)ydy%y8ld#vgVsZuob>%|+Vb z8<9dP9?R0dGD1m-8nS>bSvcUTSl=nR8sL3>y=v}&?ZXkOI!SccGmfFex&N&{a0l4(?<$z2x2FYn2_0f(2Si~1_3Qs_B3s`@!R{pW3)k+Drox-BIWwHOn|H;-el7- z!wqYl@wj7~e5>N)*7TkJ($FzaThVB_4WKU+++8hjCN*o0*nBh2`!VsaM1dG7l=C6D z9M*eBjB8xXv#k410QKn_^n_JL|LPEF%X70mSGW7ECT3~x0cxI=8@^|>HxCc=%c*CXk2MM~J7tNTUnbpTy`AeV;X{bA67Ng;*ca%MvtukuI=-$e5 zSTXt014oc9+)mZUr}7N*6tm@_NPZ0gJBhW4z11tZSerX7tI-3G1?3#1qyOY)f@|5c zJ1(IElmg$MkkF54OpVuk|L+RX2Smp?cWB7trvJvG-k0buMHg?^ui?2u+jHoePeA;J z_H{;JxI_w`N?CC%Jz$Ct9kYM9UOSN=U~hy*pAkyv%N*r%8nRy#2HX|RA-OALkex)X zag3aU>NDs32v++}8a`IU#o2lKK65OkwyUO2;_ z9}|2@XX3k6=vm12FZ@`at`w`DCF!>N_m374kj?DfXZrP7*TI|G1Wnn#P0hl~hsBW& z$2mYUZbi$F`S>na^(tUj=jamqUfOx0>NDGe3NMJOd;2|7QfD5RwAT}YkdV?o=ub%r z!jIyZo+Ls_1(AA2RNR+TTPG90q$14RN26h&u4)R`_94a}_C+o-L#)|?yN4qN686em zo@d=(6(5MiZZLlAK7N|LqbwOpqu#lQ0KD$=9T9_}ZACk^)Vdu-<1ssgE)T0{@`i?_ z(!Wf?TaS^CpcxZ6bf5$mzSAsp*vnQakws%z-jG0W?(I4Y+7o_K5NUnY{ZTUu4kEzj z7E?ULE02kFeNX%}$c0W12~^7^LWC1N5Q?uU)&0u0g<9N7ErK-qoFfXCjO)x1L8&5z z4`(u+)hxdm5+~1>U7>B-LHl(+?u`4mhXj|*jcI2;a_oGw*Z1Y`&+Qf#D3hJHsDuTn zAe_P9>YZFqB2eq+5#ZsfKDxy|eUVH@Cm+;$%`fW{wy$DGvbysM(C1bN5Im4{Pha-v-xvS2ib{k0dnTk@`t0}0fhJKkWPC9 zKJwbmBB*;ciC8=@!A;&d%F)oWfI2zTx06z-VKm;Pe4e;_=r+wY$`0#HvbA-ME-69| z2yd(Y&%h&WrK4dw`Q?6)K=IeV9L~XB!Zgh~_6v=qm2JOT<4(q%9|BGl?QgAC)%eog zi9Am*$sxs<)Jz*uHR9%LbB6$X3!vE{Sg2c24&xQ+4dWe_5Mvp6q z?8*!nUEdk5^hv`il*$l`=^P@~OqyP!Jhkp296tXV{rJt5ck7SoeWXC!awR;f>JB` zcs)-xH*)pykh^Fg=4MAwWz2NRw0}5h%H5m%ieE)71CS}c`;25AS6j9-`)!xM zMF0|M(C`2(9#pu8SZw7O`4=)Z7%`revo)Q_K=i+ibI&y)gD{=H#XGF*I0#{l+NbdR z*aE))7_BEZk9`&o1Vbms3r|k=UG=DBGlPa$X^EooY!QQWW7v@JN&d@^R6QcG_REcDJAr8?hfM1@{x18lr8u5AL$q& zuA>yy&%~#oR6T}^ogH(rno>GjkzH`pyY>T)3P+Obf~$+fBQ4pNtw06J0F${B5K4Xi zCoyW7ywP%AIx<-Os$4tggEIzmy34^Ar$7CAH0ERB)A8JKAEGy3-{Au{_}I^IO2UgM zGmRQtyvrPE*sIyeIV)U-bvxzv)2*t883lA9Za;mG)4~QOjZ)m}+^Ps7xHv~pOdijH z&9tU^Kizl_fLL&OCpysGYF82dJ8&O==^R)}+QVd7ZOsB&+^_cVY>=eeDH43^_8R>W znERdgPfXW=LfAW`UCs9)Z9TLsF!e#I~9oYd=k8b zl_wkJSEg+r0!DzV`y1fiy5r+`Tx4FQEM7u2@^K{1!gSe{we5-xrHN$gWQzf2?HzQB z`XRU6jdv9abcNNprTV&WK$qIET~+DNP!CHrh*owqnTNw5Q}uO93l{E8XgYuUI3cSuKfa)Bz2S>#ama!E!2|;HCa!R4XZ6bRe$ZY%i#gMq zMIQs`QF@M&S?DKjXvVprRxG^`gCB@{yt7&St=sq*@KsaBXVF7dvQWY2W6|?AgI`Pu@Y>|4`>a9bwF75MZt3@I;=5KUHF+Bi#sPJ=C*r;S zyK<81{h#St3CHkY(aH*2SHhc5iPA`t5_}2t9;r(6`MlWLCd;=>Wid@LRr(RX^@`yY z#5AW}#iGbTIsK>Z*P6=8nr*I-snfNYlnh2Vf-YGDW1ATR*H?DBi{2MMPZl)vN@fLV zN^9;b)OloA)4dC;DKqtd`0n9@!2DZ1%o!FRH{{9HiM(2BJjFWOq<8p;xQ*IsXWDAI zO8HYM0Yrw7p;cY%bZ#>9tqu)rV5h z@YGVEt@!QuN$J|tp%ckfR(hL45|+>xKO8B~OW%jl6M}C9oEKMWL_fMap=9yIC9~}(a-a-{~VC@4MW9Y{Pcee z=r9Uj#H6%Suwx-I8^X^Nd!1dk9w?WqX?SUHk|c6KP+723XQGgqf(8%xk1?Sc=l?Yb z!w;zrp`brjjA&i#i4gZzkU7+EyNs?H@6(1O(C+QbXk{-kpYG!aFA&c~DV|J1N(W<3 z1;^Nf+Dj?_wQ3-_nOda#T8XLM+-L#?-la$}M0K>gq;ZESt&;h;=?-}pwgJ(|ievZm z#I#6)gQ=UB!7SoPI9(ti92+0b3emwF(zx_S%|pT$;uwRa|KKvwNt4v>4VjX z?j5U3494?{sdgfB{bDW(y`hSSc(iPHFB35yHMw{^sNga($i&l4ny?MFSlKE&q(Is^ zm%RGm^!&O46h(gDsd042Vxd^0HZa}_{SI=e#%mtv72&gS(*NP-sb49+#V>=ueS~m_ z!^2k*y~PdCkpp4Q$M-I7_JbN!o#O>LXb3VMJI#2MpQ+BuQ&-Xv*Tf1oXMqy_OHxAl($n1!SB9v zs4`lQ_p3^8Z!<*<4KK!h-ntqtk{^xOq8~R9rXRhm;TZ{ECsBBe=|ATpfy!dwgCpmy z1mK3a1OGq?jE_u@7rG(t1&Q=3zcJWaWvkC`!^zdamBU@j?Fb=pFrSk|3v$v|xe%J7 z+qjdOiQ|2Z_b0{s(i|6WmLV};D<#rH#GzUtZWr@F?*cy}8b&TvnQ8crk>Wf@Ek2#C z@TRu|81sU(QWUA16heEO2ID4kG{|t4x_j{mMBIGVTgI2x@aSDW0$29f%BF8o4EjaW z?PPn8*VFd4^fQ_9>!)0hBg@NEsCwt@^p#V;{`|7imX9cL>?^I*x0n}k@MRD<`FUQR zRFzbZH!5FdtN-d8d~~roVP#J7-yHmu9mRf#350ev`EaUq3#a$Ydfr|n!^|$RfWv0! zy_SD^5SCB0k0Jhik9M6h(4zG7ya~PEVIs=OkvRB>g(hB(b=X9c7%UCiG0eV64X&|MveT8l7jGs(8ui2V;LB zf1R6~y#UP64$ihzCq$m-{<{X>p@zBbKinwE(RfWD*HsWFIlJ6F z2jNV*`q4K&73Az*dx1J9e3vg@P7nD=QK17PNDYIL7{<(m%DGkNB1W%2T|kVz9O8%q6i77ca^lFSfyi9RiWV zRF_Cs2jtQN{qpb|=#OPA`s^osd1KaZOJP*MTaWSUhhpql@`|58X-i!@uyW@uTF>8b zld^MDLJS;olWdE_teD2%9daK)nb4TMb>w!b82R5mNB?fyL`I>pt`Y8<^q6gg-FtoN zU+2y&X;GjhRq-X@gsz`{)=ss=#8G+No*Cra@}=v-2ITs|n!ZZy|8F5DxBgt{8`x#@ z^bwGCcdybv4*2`mdXvzt&4zwV5-Fxx~k$3^P`#@Pi64JyJv2;DfwCZZO_&1#|ZI(Tf1 zrN?XRFxkO4E=hhyg>LD141p7i{ZM`${7N)wrK5Rq)Fe41DZD+6zq{icK5<)vl8(_K z=g-6EjG;w%%iAINX)IFF2vRgf&gQJy=ma>@y{s`<+e`|OM!zbIflZ+=(UJ zNmC)3>{X1xfreCw+T^3N^uaKheHVd=?d1f^(f zdjj8H5NikruY4-pq4)&?l^StA*a@{%b?ZZ0IvT_{%?CO+U8M*g{&in`c9d1JQ*$8x z)R=W*ZPk>(iFtRSGR;Y*F^nteqXHQdC1h3E86+*0UaLk*VQF?A!Ih0$CQ0~D=~Kzp zv?N*W$@G4Z29@;kkNPoGM4bUekM(y&5DWPDkeNMW%DFG&EK+_aWGk^$EhDS=j%fE} z*AtQqyK5v|FXzR}MT{5zC|Suhfy}f6Eov;SZxt6_pEy<1j-wEz4Z^0Pxc(UI!%eKL zDuVc`a7536XE%)YC#|3Ar^dXYeXKasrU*jfGyV@1S3d;#P|Ktu`YEK7?2`WF%alCi zE(<0jV_sGlg?i34qSD4++t%O$$(K$F40i9XFDh! zmEcT^iAf=@xz4A)d$-j3ZPZHP@h!`3i!9Huz?z|g-~Flwbx+EW@AW^VWO(`BC#N!7lkfHT+ZUVz;&RzaRN`Hg609$U07?e$&cDvj$4bYzYN*Y8d_YWJ#nA<_+4$YaRG8w{<750c;Zfy7 zI7IA_;A{yU6>S`&8?pu9X8A(YOs#A+H?W3m#;Z8NK9%?Vp-%ejA-Lv?QCU*CMAy7~ zo41ni7ea3Gm&YF79>N5ET3QdzK;Ut2*gedcLtpH#d+*h9R)gE$aDJ$QDNV>O6CfCq zpLYb@fzsc%3P;?G_`@1*$=G<~J22yq(3(TzxOCjHi@ z`&U79g3SvA2#UtYc=r|&-9&^-+_#f%=F}}XngGxJM(N6sv4%vsAn+4!lRM2oT!_Ed zKwLB==*`8i%cks9@wCD(4H#$5;8+|@fY_*XJKs`5Gs`MOFHPYg zhRIpsJl)ReIf$bS{K;AMU2!_>2S1Z`sPbrFO{#DZ+6V$3{)a(S^Ok&sll1*V(v1r9 zMnw{nJ>cD>E)#=xFy|p2gouDR2Ne@$eo<4Uz#%3ye))oQl2Twp+aLaIaYee91WdlN z9FK7qMuTek_FI{ym&QRX0qbl%+n#FNPnlS6rzw1~imV~v=KUqOy5nva2q{8OIySJ* z*RcM#t4N;&3u)0nc;CX_eIJm(bYUsivH_SNxz(xQGC_VY#&%)m*O?R8f&#X{kO5sw zG8GwQT3jyBD`=uQJW8VkMhgDlT!87{yP+y&S2X#ej*$!1`G(}O3Nv76=o3$-{v-Qa zR^YKN#X^i(Yz-||(JFbpt7YfrvejC!*!~8On3snvLwW7vcpBu)Dr%;aGg+~IND0a( zoV|SGpgbHyv9rtMBKsC^>Kx=fJYUJ%C41F8&W`)1cQhMn*DKQ!BZZtj*z>D|zumY| zbl`lk>Jc%7-;3t@15Xq*&V00c`ky?M`m-mN?gZAqN)&T_`CNMKXdAbi_{le#+j&c6!_4(XQv1yWJ?lR-H@ zH*!hze(*Sgr?dx#zL0k`kPK9N&WVUZ-lUY6hp}I5KM@vJOH=hFDvTOR&^2`bFTrUL z{Sc=RcsqH9)`N-m-_%F*=fR~eq(3V{ceD*1%Zse%K(O*mZsIyD)8-K&90@v_VF-7B zrEdmbe3;)O9TGlG4dk^4@@E}kw4O^tQL`6P?YJ4jjUuniSWwC&K^Z=y-Fd#$d;caK z5zV7*FiSuoVy3L`?A>A>Jp=i2DiTA-XvSu{510QNKQCfKKOF>W`|Tela^sXZ2+~$D zk1)u%SB8g_IB)CAfl=50MC_;OWACSvibnEm7M;a%v`hf;QLX2kj4uyt0qu@kO2hMh zLI+Y59)_4_8D)GRb!&$%4c{hH_`m~q8_swXj5B8U?v@|;>3#$x&gkqgU6%d`eYwsL8{JyE1S2v}zy?ee_s7&v$KOlK|{dSRwoiUS#N4KI0 z9cC5;YYeWl@1!lz4WvMtXsZ}FU&ckOKT+9d49&4}{&%jIV0EJX!q4Vh=I7VayLAG| zpr>EHLCW0Oj5F~9EvDtE!dX<6cth*7{L^AGoD{hWab3*}o8d>~fHXWUqrtCwUU^Cl z#xcVL>Z9%RN8`ao_z+il=Fxx8+c5LQZymZU<{-TU3%5T*^7KKD!Gh zTJ1z=i9t$xGU+7mVg!FG4367Ak6bztCQS+C@Y??u(9?SvBP=olo}no`REd`U0>z7) zHTH<9eR<1=>@4xPJL8{c8KRo`0~29-PDGZ#61W_&dT^{VLpy6Ij}24_b}p<@83@Rw{umkxf3_73iZeI7#Q z%+7K37?9Z_KiqBkO}#Ly+{~Oi;lX@4?=>68`#P>*mTpDEI;h|_?gBBLAD{A4xAbLd zhb6ZLkD}4t!1@7#=kTsvgeBEQRQ(j{Kn|ow&_b;e3YNGOtIl>#J)I;$ht zfaGsaFyc}6pf(v5cENW1%{j}NcAgnIQODFE=thYCu|eH*!E}{xovlLsy+Px*<8lAG z2he%1RgnLQ&Dj;PjI7o$5An>i3T;#klY!2oU7^EO#QsqCAm$3FigTm~w_BtKUjGWq zyr>e|1TcWEYf(+K9sUR$YOH`%Nv>r3%JbyG;bu_u{%&a=VuJ((;C#L!vgD?mKO|t` zyAm#vWP$aN!iW9KhWjbCb^l~=?T8-dANXvCc{o2HZTR)J^eO1Od?ovXnTe;%T84{* zKJ#epl;19rr1exSTP!p4(1K#)KsshW>CIE)*0wqAomg9UKc_l8&-iX?w{^dvcYIup z)+9BC+`c6=-0tok(nG#K6t>pcSJd#ij+9y_k|A6M`onhfgI*v@{+)$`T?1ZO;nuqI z62VG*CcD8y5=YA`SpW!Y03TN4$&1c zD-(5i#f%=eRw2QSGl2HkH(C#*M!DLTaqA=)IpUl7ocjtJS;I3w81o$RF=g}Edwaa4 zvG7w0qsKgp;xqna9n7^SnzcKdb!;TkD?jVkPz}s8Ie2H+8jPmT(b%-LqO0#UpFvof^cuq) z*CKA*er8wz_+EggqYZVBTaXjgLLF+RntXR1vE>W(JAVJ)wiOAU?|fXJ49d34$Y010 z3qU*2lBxg|lZg_TXUfa>MeC3~&%_sAd`9mtu07Bv9%E)Vg6RA-23y*#e?{ayPGd_wh-eL^{|4?81FH&DeVpshRN6n8)Cl=&IH9EG@+iCbUi9O#Z$g{Y5FTo&>l~A*A|7q=0UoHEkT6 z%kXP7`W0#YQqvkKTkzt_|4v@5)Z*9Eg3~!08fW$7Ox!;EPE{oC@|}})o{qa_8nv}d z(M@!|WcjKPq@%ODD|G$X@h@a#xGy55^(34cQi2JQp9hLPjJbU!UkgH_{e!UTr~P#6 zK{O=$W3vJyb+7P1k>b`Roa@mj@8!#5vClnzqoc>ZEAjN8ZCLHUHw7<;cPR#mE5ROl(bmc8xB5C7U|CRpE z@A5%*^i2L&7n}6zDeB?2pFS4*?*=0j6|2aFm$KWt`>f$%<)Nu?7OswAPQ(Ux`kf4N zP~2cgmCGA%!vKcMSLjeRMInVnDuH8^U&&o!#&8LjOU&q=g73^AQRHtghVBWz_ajKH zEn`=EVt$Hv`zPpR->Di=$WMQyN}3>q=?~2!bk}ThVeSv0=%kmRX5$%aF6lL7W6Za) zSON*yj22ndJW_g*tkG)6A2p=%#ixJjnH2Dkx*@&kT~jNkJc0A_RSuhqKb84lm`E$l zvC1jFaY`;Ldn^TeApI-o77s-vE^%*-?i6b%Lktg-Nh_ouUM_twgdKaOaUicb5gv_= zmu&o|n&*gsy=aZPE3R&v7_tacze?`k6+OP~xqCT*-=FWd=_e1pI8KN=?^FHz4QXT% zm<4Crxv!AKr+WOmY<-nf!t{9a6=qYLKmHx(UF9-^u52mNjGY-428m}n*_0_6e&6Wo z*l_c|axSuGc)l_Udn2n#`QcvYqk7tXzwTaWeA>dWo!28T(cSt*?+2q3L~0b-utU6Tt^%93v|vN-RLlFuhobDKncxFm?nPx zEmXXa_}9WcDlBLD1LAhZorzh_WO(0jW)RByP2qIqh|EQvX5iFmwEM+jX=SII0_noJ ztw{HVtN=6#^|7xn)FWR{UO;mq!oANPX-%G@ zB?sS^_N(X|b??0C?9L-{c~uNf-?_A9Wb$zJ2GgX#u{m{p1DWuGl7r9LN~k?7s=20; zQ6qy{G9M5|FQfQOw>5+W625qoxG>}9sh27+@hA>#`KsLf*Y~!#o+^XXw;>uUH8!y+ z27%I@%pksk9%?yn>Gr}D8hRxLHOgRiolTLTj?}1JOda%G6(B8X@x31+hJuvUZPJFz zuJ?8~UM>7r7)?GGpvhP7=NM4T_q3+le)v4%C+p6z`%DuFtCty4(-5^V&ihW`fdZXG zwf=VZ=U5Rdd2mJe?o5VKgRG1$h2a5=nRy2N(ypoTnZpO29(% znk5Wozpjtg>BYT!0X=3hpm$-mFT8ZA>VD6LV3|d};{6v8h63~9-WjazY%`{I;6^K` zMFvIGp5fS4%{bkA3FhM)ND%9lnO-1SJ`Vce<{vkUS2A=WahFL08{U>1rOiX9930K` z^5@EcI;(p0D0SN6R0saIXVKiWa`HUzum78rX9+KVkI-2*n7s|nQXVfF?|anyz}QTr zXQ{?8wVw>YMcPK>6h>)_tA&N@wlXU@v6>@s5$sgFr*kb}n>3OAfsMcJH=?|+ zOj5cGys`Dc-I2;S|Mi>tgxcrY+Dgf*{ie8K3cbz*V^wOsy29jpdF2C4!yZH1yuY(_ZZ+3z(ChVe%hs?}f|0*^w{fDNu z-9#-uYvJt^i*Rgu(fY@4^FiXd5|*U^K6#vkC})*aAEOxAHLCK~07TVClpDZoZtwjn z7h1WyM{k?Q@K=?@sM8aMC;qLJkR_fdI;^U=j*!(h7V(bM+5uqTxo%4S@b+wxmxP-j zHm=(e*HO{4dwoDMD3Do@=j4I}@nI|%)KXgb8}ja62&;gkceA^r*3ZRwTh0vIPa@3( zEaQaUbR34@hRH>p4=@DDo*VFmJ78xbEs-qJD|Z9EsjG#zhTYXes>G;a&r%iB^;v6R5^lS80RnuqY(#nHP+vDo5^*2<}mm zO|+R#wRhi(3~=2U3W`f@UJ9B!INWg}!Mo7nJ-*(73}w31dGVn8NCKs|xsGVg8s7u( z3aP)`J%YzQ&3}@-5+`|mj`z_mf_&jjffb8zHYg}-73jZ-PIF9c40i>q_)` zHo)xxu(hHLc$pK2l#G11_`qWywjA1!uJBkZdnmE%erx#q%&k6IXno~z=)08hjmU$4 z{~1e8R6SMTZzaB-A*LaEZ!oktAe6=C)+s>8C;esQBB>PQkD@lfxze2lpd|SOLS+`s zO{4}mbJJ1JiB}P1M{xEqu3I?vrR6*!4J z*eN>X`c~OAS-SK%S=5+RGV@E89MN{9bm}sJPhOM|&AAxe+&*@I*?BGixlGrm6v9j2 ztJGt$ZSu!&VfhQ-oTpFee_fzLLTC^!9UOHgy)}z|knDwnAIR3FgqRfCRJ; zVy%kjDRr`@#MP<$F%+)=YcPBW+F}E$)`X;;B_ryu;h9lE#B<{>1bUd#3=o(QvoXbh z_ZO4|aoRb9Fkf^7i##Aa@&$+w434=txVFCZX`VUv-Y;s8R6mnlo9Ly(l>E<8lC*`h zBniUh*M6EmSiK`d%W}7cQi2jH_@s7=Og5uz`-4hk9HkXAB8GG>USK`gPXTe43I#pMCqy0jO6a1AbUspj@g6b-Cb30hF*dr zi~ARR_vJ!gdx7DXlru?Ri=cA7eE{yYu#p+;F6Lw_9vXOQdc|BwxG#Hu?MUA{hf;V{ zYyaKL_pqCn>GfUHzmeJ?fmoODuIf^TXSRIdhe{8GdWDdar;4V~uy{)(3yzKjH$Tz! z4;@6chniUpNZ6#Un06c{H_9RcuuK1nJyk*^YVP!2!)Cm|7m71!giBT5g#=}TD{b!F zHjGLnFGgNmgC;u*E+F(SJ#LRX4THn^0yXHKPqIPy`rgI!y?I5udik(vN7-E|=KJAz zL1@b@ZO{o7d3xq64s)!=>l@?-dmFq0WNX^q23rnVOFw&f`wXDjCv_-Z<_Mj*(|4gy?oz=O@_tk> zple5O7*^c6BdGu|pBMDp93isz6RoMPN`}|P2tqCj!FU3D!tXQPO03I7X)4Fyk1>}M zuYEWiEAkX<+~rX>wLR9$N*CsK(_&*?S*!MgaD2cQy!f|pa26(HV?^(f zA=02bX|r#vO~u>)JVti1$|u3Vg%#QP6V_G>VJz7)*^V3SnOy>Fn%fb+vpU$j0A|< zUu;VsHKsDVmoS@h{}62aJGY45$C!r7A>@cN$`QL}Q{jhPheVB`SqfH_S|PJ&x0Jh8 zOpzgu`m0O|PHo*#l+d(ug~6?~pT&Z)ceT!HOjl%bL{QZ*F64W#AB>PDTSzO6h0)#x zES?~mr~6;+^MqIuc}5OyS@uD0^24M|NpHtoDUG_IVWlZ!R0^V&6CgbRhk-cj%S}5d z^!#4c@FV8Qp?4`-H*gML2}a#E2lt)iALQc?QJoNLWspYxnho${W$ghfk9vctOU@IRMj{`gZ&TUls2XM9$K-^0R;3Sb8auHWLkra%^My0NTs!8&DdO2Iw zbq3&rDuG{*Y%?Fk{$YocD2*p#tOE*Y-C5m{>VjBQ(H-;V9mQ=@y|>B z=XWy6``tYEVdurDs$pNO&^`WEO4U>ij0$B<@{h+Sm`z(|@P#8ijXl=ZMdss=fhk{7 z+I8_@RQl(&VK9bb<59q*e~|Xik(lb!ObUvAvJd@UUH@pJUoE(xBb|G}*l< zl9VC3G5b}=naND-_+_qVZ^cC4bL+ZyidHy2Rt>K>rN%h=aaB%M;r*_KrRgR1se6Ac zKnqNTOW4U#R)jcOjQ(&NK)rQL81@@GDV`PYI4e5nEP%>ni@TT{$2;)-*R8&vZI$%B z=U`rBU@g>lq0bF7%SmmI=t->4ZqT19Q1_;~h}7!fZb4UNH02o>Lhlr`Kd$7#^VF;% z1{IRuMYYCvgPJ1lZ^$Xk>>$tVhHj1x=W1Rn)RIO+{YG$dG#z}L2VUUq)qou75(F^; zRL!w_9`DCV9z6%ciNvfv7ULItW9J*G+I75a%kZKUmMzPyJI#ms<8dR6EAXGCHrP3$ zoD663qtU**^;Kgv2{4b!6XC33@!6 zgmrYGR$|rsQHw57T}A+|Ss{hoeCn`{4zlNZy?g|(Kf0y8Iy=xcga%TkJCOSbDVb0q zIjC8c_w<7Dsm?tBG^kvJhKU24={J2Tj7pwmhfl%pZvjI(r6%8*%sQXjzb(1Bj1A40 z^Wzni{oC_K^#ZD&VrMn>pr9dfIdm+G>XW@kqzRUE*Dj4^RU@p|_N)No1?@r+>ewwu zKem|M!0OoIMK`O!CPh>x?vx>O5#`9mN+yb;GUV+GA6(lTREH&UX`U8>5gl>KmP?Gk zL8w`Ml2K-EF+GKD?tRoi&e5=L#pJi@N_!R#@?1G^Vxn&#;0or3o7lv0MhGeu`VpRLe%U};#V=w&b_XC2pzWw< ze|bqshX~rVbj^8Ih-?WI;BRqUXUzNEuB|P-vz-GuQDERKC_ol(o=J929{=&i+<|<`$i>6C zMaak8j_sVfmG#nQJ4MMfnsI@bq}LFQD8}dBLa|;mVlgL!U}&zBx8|t_XI||CN7o(a z{$CLr@mW%*aCWp4Y03Ou5}^I^efp;apfg`rtg0qMi>=dYwq3Lzzv$I(j)F~KRAX%nz?!sxXK#29DC@Y$l* zkv;o};-5B`z{2z5>pNYB$s_zkv2w_%O73`ZZjEwI49!nH=k6>eG)X-hXzJ63ZyfqO zta|bUyAw`YGxb-E~hdt@PNhoTKw_EG)Qg{cxG5zwkA8RM$#)WZXC$XKLGc8 zVUeXj=q>!SNAgAg;R}Md-1BKWa|f1}Rnmi0-3|!BkEN-d8?3c-&$1#{r62B3l(>pg;C~#rxYC)G=X{-AfAcmd)UM3Zq6q^nlkVp zCW^Efi^Qq(vDFG~%F9J~%)=I0!TJt=S<@Dq{2S=}zh@glddHx^dzTU;W?+*ujii-L z3|jJwvbE9`!sI_`PID#)b-~R@M0YRsxl$bJ^w`nxlc8a?Fdt(Y9(&bdWd)OW~T33MBDjMPSl`RJ3U=Hbe&CB?0(19(T&WgbKUlLGG){?Sev6!-3z$~_>(!hWkJw6JdCev4_wHrTXZ^}W zyUHE{TCfb?H)}d9m%M}0mGVC^D`wjj zc%t+lIwd29_(r%SKAX5Za(2S!S)oSIuB+zRZXH)DU;1P79W<|xnWJn;#0@7d+*sV| zpp{VQ%I_!T#>$0#C{PrP%$!??kCsc{zN^%)NwGgczkIr_*xg%R8yN=6}6)M#tgQ=-PeiVBaH$(R%D`wI^x&u1MIgeOnG)aq_J#(wJIo3`MqxB~P zZtHoZQJL+u+GB}haZESz%Iq8vEr%y+e~Szw`6sSi;!;t+g5>3&o21z3Cv}nSWh@XH zQ`kzU+dXB$vG^&q_m_N889r0rW`Doe0P7380ng=7a1=eK`=h?xL zGOR~gmMiqS>Xsqucd}XJ${to6{cX;DfpAH&Nd0Jd67YT!eOF3*2i>vhEDvTxv8h0r z$WW~o!MFa&$j$o(-IoB}ZD=bn19LPe-u@EVgmE(xAD+ypNc z|2ii+2w{@DK>%;z9T22&B7Z6RV_ntW94SDT(i4}?W(aM3)Mb>=_Y1c0>|JTB+^Zq+ zwFtMEG?g%ZnJG~*qwf77D~go!G2gi1qS&{y4(7(6AdQm%maN%(1{><{-TV1|9LLQ` z*W~KX%hm?>XBkjP>L=~m6mnH^tT5fCZli-H28FE(>C=Q7R471iik2WRdI2U2RpekD zno(qDMIz98bfjq?h=UEkT-*6l+oPWfg4`zF_=xpvk2@eb{(VfHp{2Mb=Xv4oR5(Tj zDNdnBh4adPHdHaIR7tSl%d1me{CbgyH+s2)(eAfk z-AjQ4NP5kR1JPz`GjWlDBi|$h==*v5@N49T@?IPIKbq3^G_zWL`5)Z~W+^|iEA%?2 zXH5EnBrSU9O_UO*vzczWFOAocRUXlUEYpW^vew1SifOgqY{o6t2mljHFhDp!V+;;8k zhi0_058*)CJrV@8fNv8#cvR7I2CO+QKo?^z}CB_aeJFY=din!OIX@w+8 zA79c9uGVD1rop~9EB-oiRaS&-=$@Xbfvoq>)WUh^hM^+AXDvrLR3Gkgm!>f*-Kc#f z5z3uyiG#A{k&YR~R1%mPxuh$r6xIGOEBi!(v2L0vr)Bwp4~vf2Se{+aG56S1%%XBU zt$KLN*RBc3As!xcLu8KO$(OeD&VrwBYvoOggm4>&==TxE51tOuU@k(>hN*%Nu|L6v5D0PQr@e1viK`ZygJXux}cRIzR~%`KHD74i?8#o(Ujo7Y8JK z4R?so>`ELw2iW&Lr@|piZc}PZ1YMJxMrSGT=pll@bh}-= zocrpbRsl_k<-9lID6{7F1EKJ%kOcw=)MzE%+uh?DtT%f&PI@AgHf*u2n11ahG{!k2 zGq3qmP`aXzlH7M<-yqR(LH4>LrAqkV0j5Ezj7=^@UhWmCz8cPf{gUCQ-;a_Cov3o& zofTS{E{6D6ig8GC&@QRj1p!2mdmb-TPqA^?DsHs3XZ~p(fBO4f;vXfHAAs%2IaslC z+^MA5ItJ!x!?8{fdwInl>SFP|$B&1}k#ueo zQM5f-tIhtgU)|7xaGlTuw(w{&A~Fmt;aE{xk;{Q2$|chx_*Q^ys zpnoI@%C$_~8tZy3rJ)6ZWq)}M-t5`|*ynT%Dyn$ik}qP=$K1t?6#8^C6tuQ2A?H9I zkiqAUTYn8uq`HTHArAg4qB`udg%8KwHgOD8&?bfjyrFeH_XP|vmiH4 z(@73ADL)2a>}AU5oFv=h4M%ZDRCacqQcYGRbTL4|;C_?sb9I;P=+$$VvT-QbNiqg* zeZ^MZ%eG#$BS82}jt@u=@vpQOFs)a1H4;e+-)i{sG?Ooq?!~04^`qC2Y)x#7dP!-? zi01U&*KQ6eA!DY2`j}TsmAB5(EsOO#nfkYEjEb#JEcFG0N>vNU2u$QV`ei%fH+=$1HQcK=a6~FOkG01Vkev&?fV)a14vy_z z*=5@9IpT%oYFpo~RzjNTT#*ODZ&e?{0};sz2d#y>ipW!$s%5#!{n`uc8@kmB(h+-* zvIX8K!W7Cn0b5>ypZ?m#N3o+z1~@1W<=mAvFQfY%Tc-&B+pfx>38-^mL26^m)%x1R zGmPwSe!0%hO{O}|u+`*Bmd$vYN%uiLcjz_aMLvUD^}+mp@d#roZd>5?rWib_UAMrX zPm)c@ocUmEb>?q+2<)BBAD3P|Q9P#yiqY4Q#I49})@Vm=n5KQ<`dkHNyajL@NQXo= zO;KJ|fS^mr=Z8K6!ahab`I`A<%pLZphTt}(fsbU!zC z@yGr<0W;mo==@@IqNB*!p(0r-SZ`0*iJ0H8o7Lr}kQsgh{4Jy^t_RXrd> zgeixmYo5`&HZ18+kK&(9k z$;x!Xvv+AZYcJTO(;9tUI9BYm~5E)??nYK9a1pDy?1)Klu|SN zvE8{SpgpUz5R}BP*``T4^(uxMWC@?%1vx)78n_w0dH$FH*ApQW|GTLTM9~A_Ek~s| z_7K_HA?;FqTefMvrS#T}#C_8~>uKYM-Iz$gmNnq{B>_vIlHgB>O$D+~m zbaZuIB}k>nX=ADzo=}Gv%^I$5@2nwp#_Vjconc%@**}hHaQb=r100y>7P2Y{AU!g` zmyelra`60l6&d28Fu?G}fDUm#h|t zurbnJw)9_=ha(%$t?`J?@)_eAetu);rXWSo2j5$eANwc_o|82K!v8IAKW4?tg&q9K zjUaNF|8T<`73T$8zepxF{kf<}!n_tK%jV#nVxLlqF6UX%lX_lj2h1FN;Rk2}E&n=! z5%{^gz{KT^w~q&e00w_EcU+V+A*;E$V~je&ZM1fE{=GXA@cO*tsMios_mKZR)-1T} zEGQLtLqL+o@CQ2cUkDJWxu0ATQC$$TeQ^JwE9bd^+60uYbf3795z z7hqDwfX`>~-k--}fKZ~9Ih>7Me|gHqy*H(+>N%5MuI%n9NYkTCnsM~~{BSa)9WVoO z`yyzk;Bu;nL;Pi53je__n?rlxcIL`@Yke%stIn9CN8mHE$I{3?`D_11YM_r+mO(0C z6+hAPW7#2Jxl7S^$^>)Nh0rwJ{=wr7p{JRNchnkYD>odUIPI-vXcHks(9dlW*X7w> zCSx&81aFOIPseOU+s<&MKK1_FX-B8}$&dwlNm|*Ml1(%_<0*&jVP~_Z9(od5aWW}T zr>Pr}`*!}->~D666=@fmEb)UcyMwC%H4Nnj)_b<gXm@?(y1F9FG z_Ks`{DUqHl@xrM{>hRc=z~@nS*wcE`=FBZ?g^XVgS0^gxOebSYJxMT4PME2I-LGWX zB=7#T4embntV3OA$A#Oa7xO1aW7eCX1cbdR^l3a~!JZbrV6~LB@#;l-6i|&Xm~21G zQwJ-lS7rX8!`81ANC0o$w$>vTZZfHe$E(;bpFgB3$`&Nxw?<7z&xy69zyHmFRg}KA z^Yf&}rOWKyNe){})}^4R#hpqfDkX!Q#AawS{IOt!$gQs%n@>YF;&*`i^<*W+4H384 zC4Utv$SArgU)!CXvk**O%1|7ePJw)v00{ofj!J_rQCUTQz5cL1WU;b&W9e-1nbHna4MU6Q4D3${bgGbN zXTa;S2f+SzU-8_D!9_b6uCrc+u404(M?d2{5#$_$v<&Wa zN7-Ws?%1I5aVX*y1e9{H8#E%NZ*G?e$84@A7XB{wQ_ucL@l#INR0HV0JMz2G|6R)G zILE(N?HN2rVxSK7?ffsyQ!Jz(W6wj&rhI3F=ynLoL-$13*O)+mB7c0?uKd!`Q~=Ni zDO3O2PfP?z@nKR#U@qxBW)qDi`DDr7sGHZxa$jEH-Rh7~aWB?MNZY9pi=G#{Y^yH4 zPNVeJUSV~d#>^Uo-+#MOGq&h3j};laWjaEi!+CP`qk~!ieCF(uXE8%)Y+Z2@kba-^ zUbtp8kexUS*eUH?Rd$0JAT=M|DY+@xs}m2u;ei*LM!y{(jj52eTeE~{_YQ!W72J{B z27~u!x4b!UpXcjCP~F+U_4dtw%!%(Qs2V(Z<9q2qKBN%Eoj=)I*3Y79^@-HPEWhIeYvzIYvM)XhEu8)Wl<+A*s!ctL)h$}l6o|;@Hjc`HykK5qxQ~cP1HsRVKJtHT;$z_<3LgK`5 z0$j3tYN6u{li>Gvk!?w`44{|3(Z-^*~#&Yy=MkvY_} z0O|-ldbQ9e-4^t#yigy^%XHip%<}nwlztbmC*h(4+AoYpk}`t9YAB$J3~(ES#88{{ znEe*P>o+P5ubp2VtPm61+Mc)Rk<@pf*BxdwX(2-}$q@H_-Sr_ccO;&0SDC{{5kdu; z3icOpV-C$UDH*O#!Wx&wT%20rux1$oJ;Z#**~UxM;?1O6PC*`7)bzH^hiyX?Hg zj&D_2hI!;O5F2caf>N&6nVx`<)l}8)e@_HzVuAO-bNuz%8aC70n**X5HjbhL53o_s zuIuBcY17kt#yn3~T8BjY0j|eh?^rkme4}%br$NyhrxBJlMWwp{pU(7@;5DwMvo2=t z)bWx}hfc|mFoH#-z1XNSS&AiJlt#S7D+5wN`+NG!&AmaAPqdoEj$}6+-GtDs-)?{G zd-BI8vJA89g$T@~6AIx2a7|Gs7qZX0&|peo8`vdtmp|nB%*?wXpAD=`0P4TGn2^lySYYycvew}CPKvEnlg6!uZpro zW--=LHD{7c8~heG99P93g>y2OpBr#!K!)Wy+g;LWdVU8vme7>UzpZd;^xM3a)Wk&B zCI4=_I1X)_TRwcI0akSkLpJ@=lDpjy#z6DdPqJxG>Y9IL?a$3Y$Y3ia3VqZYooVP) z1;Y~q08CZdsm-2wl}z#UN?GLo^A{tW5z4gI#TfPBy%sF}IKaorW3`0d zZpPu~8b3arPUUoS#S@EEyQiqhACU;fTP54Z^D!MJe|~zMDo)jX8f>}5RJYlX#j8r% zw|6zb$$Q;*+de;g9$SoElcEE=FrX~HB8{dR_h{Lo9X55##*E%WBly&$9KWibvyI>j zMk0KkZ8GcriLM?}?e!0O(1*297oF(_D%dQRz@4kD7bHmIN}5C3kwXtP%JY(dGJNpt zLlIKbXuDG0qO9hM42R~Xum?@}nYz3#MjuVI^zXjO9_pKvRdrQfdkn9~cbmaS@_7Qd zI62h;ye01qB-~?qJ|9U2@ZL0~ecF*_6&Zi+zs|zLy_s=fwKA4`G9zrF(+0;~siz!lz`(qNp{b{{@fK3E0i} z(i46~Gj(@PSGn9&B-8W9y-km)Ju(26c18H)RXu+7_!yB`6M$2XJFeYMG$tjI0{ z6$Ja%PHB;jp&GSwJX+$ejVFaO40Xn>EyE}l?%C(9>`h)6#P3;qOAa3hDR zwL3D7ru^6raGP@FBv`QqW=ysP{AM;tdnPrvORRuj!&x0 z{65Z$n=_o&fV;lnPqEzbVV9+ntjU~8AZ8tdDG4Uib#pDW)|>s$5CxQ5t|ZWcOv7ABqH8r?;E{_9BJ zse-pM%j){x6pNk`swn_$Jqz=RU2S~NUtclpxv2;ERR1TAzE*w%B{si)?6}7`;Tqfm zi0?q&g9r@AVbzo|V!iE&F#buWS;Yt3>`2BJ)U#1SX(qRrYI|{{{N|r$cRQ?2ZgJ63 zGd;HNEYiUHl58uQJ-PfTh`-!0W!C_drm$ys?i=+L^cq0KjAHCkwgme*J_JqbS#3t>!ZB{R4#3Vym9(rVh5#Y?bDJ#qwx zHLwgq5Qe8^R`8oBGUynjfDJZd@p#_XFH970x{l~B+{sUtY~s>9Y|ka9ouozNf5WUf z9ha5vbcW+*ca^_a9svS>De#7)N1}7WeP4wYXNX`!(sKD++4iMCK84z`Wji*zB&ZnQ zFX{6)c|f_mogbHD$wfs+q`Vp*-yYQ?fG;V2;YR4Pse@(nS4-IM$M*)O$gF(ioTj^i z2JkY^FgxC@YT(In>rV}!XN3h3BE?S0KO*aKioV^Z-hT`Bg1WWXyer=e(naiqw5lY9 zAA@BQ?KO<3{?RmO03Nk9Tc0^#-iE;gp@?CBZIx{*$e2lwGC$(kbKeC4()Pb+Iuhqo z?Nm21sfT*2)D?^l63fPH=$=2on=0kCuTv0yIh}YF6(_yqyfoHLn3<9QU1sCUOb0)aNXJ>n(?8JaZ)+MiE$(jTiA11du#PR2gcKc=E}Het<5Dx{r`xG;oS)s|^7T4rqg8q?x4}6Acj(=-?#2(jW zClFM4&^nHIitvpsAw`H>$*saq&&BhrE^%_PP`mr~<)5{GHu2n_fvOp_d!C3^T&fP| zYk%UY;~?VY)FPO4*!+}nTRI%gj!;&ybv2s3oL{BI!RlEl=$#8 zNy*I-j!8LBy(^iFMyJH@$>c%1t)KQHHG}eB_e~KWQL#^52IOXxfEVY_|(~T{)d6hDe1zxc`bRmN$8FSqu?O zcmxCK&a}V{^=P6mL>5fn4g1+%9oEDytsf|5(wlc!4kp_0jQ^J4d)#Mi`kSsVTdvx= z5ZQYW)roBh`&CgStYN!1GpG-Byr#3H2b3dikO~G^pE8BQPoZIW$v2KqNxRsCiHqEb z^O+y6=Id^yNSjWKjaso!b$L_duGq#~#x?=D*~M7(?0Rw*q47CRIsgv_Owi86@XeQB z_o^z~FQxrKrS}&)xEIGSunS!fZF!sT=0*P`4S_1z#fe zfH85N2`qlOC)5!NcM0(hw5&#AG$8Cl58XfZ<$tWB2fMWb$g$ zh+6=t;7#8{bvg$anyca;(}w2@iUxquMKn2i^>K2Uf?UlfHquZIroqWBH}|)@O*5NH zM^q}b;%*Vl^zkv4P~O)lnoP^@ZHGKh?T`-$K9Jw7A6bO`0WHk=l$r z4?5BJylUFy8t|Ocyv0VjM>mgjBwdgU3@?_{XgvI=>w`W^Dq#6ub=DpAHg`%p-0HxPVps?0d zf_zs)3H))*-TZCHP54EyXTJ^7fhj^h`(sU>Y}^tNNK5vS$JW;8v+QbJKeIjdPUDNA z>3D9j^2-u3-uOvPSPK_9*AE{n(CJC(7}$uV5#3YvAahirb#$Z|!SwjhW@JlbiM(H# zQU85yD{z45RC^qTR!Zsjs)50$tC#)}l8$B$kRWiK=6jU3zR~vTE?AVxeO-9sqFM6C z%<05Z}b{`&;$$FDk!3%{!0EzsDskQzgKAlPb%|0dgu zt>3wMX+_$AsfWPFhmWGavQJ*Xw4OegTD1Wa3p&JA_E$RW5>5{XN~YhEn;P~3HjNT< zFY_kNdo;n&&AU9O;#Ont!?w|CIvP)dkxDVApWp_`1+pV?ewdXMW0ZjbL4gn+(u+Ie z>e0Eh>*q3zX9#i|Nr?kSv%;kstrMFn6qXC`tI5a1|Sri5R=pGUWOkc8| z)8^rlmh6N|kmb`3JS(4G;_EAYKgJ7*pG4-ZDlZW^gfVU5iDrFI&4Ick>bpL7fH{^a3`|K3YEPUC*6*!`FSD zed`A9`eMbTK*ba9;s>8nyfk^Rwd>EDavk2ptj-ERZ+pYbLlyk`BEEsYyHOkW;mIIr z=KH~p1fx9pkoWiME8P=12TL`3pY`|@X@()3wa@2MJ9i$C>B_(KG5bF*z=&pDfN(r# zt#PJ)q5jlx5h*;R+}Kh?!h-x?4A=SNXa&?bUmRG-KXkm86p_~?_1_Ljsek$0Jp3|< zFyOBh(QMtKz`z;ZP#|@5k0n8G><*nEaeyh6tS{uADS*H&oc43*2T(fFWCY7}$djI5 zhr-G0ET3E~D2;voxOMVjaEH0~f|6yZ=n~f~r2yU=8yUZ6Uu3O5vw2O3kc+M0R`1~y7y*T zp4G=`I!Os)$NgkP@9L^yzgmtz`Q%q$EKOT5B!piT3GM(}HAf37`V6?`*h(CRRH9UE zka+q=4={4hQ?8v1B694UBjgUu;=15C`20g_*&tfMKz+iu(qyKR5nmk6~=RJvUa z;H3RSt80T>C71y(0#Uf$b;ke72gaRt%`1-wJqiNu1;`nZ))4q`zCWX*5iu`;F}RykxR8vKi$isy!@ z7nB@1j}~Z@^js$pL-l)5LLY%r_fa=$d{KzL89dOp9|Cu3uNj3D$pU28G}6f@&Gf}%YR5aq_0vt zfzGfd@vL(andk}Q{IXNj%4Xur-~Im4X�QVZ?b{274XgA5sn})oc|QZf@{)p~S5i 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 XUaQ{A<7gKkAua~@AM2KDJBI%k4W6wb literal 0 HcmV?d00001 diff --git a/ios/NewExpensify/Images.xcassets/BootSplashLogo.imageset/Contents.json b/ios/NewExpensify/Images.xcassets/BootSplashLogo.imageset/Contents.json index 570652dfdaa0..a8927aa86e2b 100644 --- a/ios/NewExpensify/Images.xcassets/BootSplashLogo.imageset/Contents.json +++ b/ios/NewExpensify/Images.xcassets/BootSplashLogo.imageset/Contents.json @@ -1,23 +1,23 @@ { - "images": [ + "images" : [ { - "idiom": "universal", - "filename": "bootsplash_logo.png", - "scale": "1x" + "filename" : "bootsplash_logo.png", + "idiom" : "universal", + "scale" : "1x" }, { - "idiom": "universal", - "filename": "bootsplash_logo@2x.png", - "scale": "2x" + "filename" : "bootsplash_logo@2x.png", + "idiom" : "universal", + "scale" : "2x" }, { - "idiom": "universal", - "filename": "bootsplash_logo@3x.png", - "scale": "3x" + "filename" : "bootsplash_logo@3x.png", + "idiom" : "universal", + "scale" : "3x" } ], - "info": { - "version": 1, - "author": "xcode" + "info" : { + "author" : "xcode", + "version" : 1 } } diff --git a/ios/NewExpensify/Images.xcassets/BootSplashLogoAdHoc.imageset/Contents.json b/ios/NewExpensify/Images.xcassets/BootSplashLogoAdHoc.imageset/Contents.json new file mode 100644 index 000000000000..a8927aa86e2b --- /dev/null +++ b/ios/NewExpensify/Images.xcassets/BootSplashLogoAdHoc.imageset/Contents.json @@ -0,0 +1,23 @@ +{ + "images" : [ + { + "filename" : "bootsplash_logo.png", + "idiom" : "universal", + "scale" : "1x" + }, + { + "filename" : "bootsplash_logo@2x.png", + "idiom" : "universal", + "scale" : "2x" + }, + { + "filename" : "bootsplash_logo@3x.png", + "idiom" : "universal", + "scale" : "3x" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/ios/NewExpensify/Images.xcassets/BootSplashLogoAdHoc.imageset/bootsplash_logo.png b/ios/NewExpensify/Images.xcassets/BootSplashLogoAdHoc.imageset/bootsplash_logo.png new file mode 100644 index 0000000000000000000000000000000000000000..8fbef1c5ab06a55d035c06a8606028df254856b3 GIT binary patch literal 2379 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 V>I@H8AMocLWT0!TQ>S$e{Xf47qZ0rC literal 0 HcmV?d00001 diff --git a/ios/NewExpensify/Images.xcassets/BootSplashLogoAdHoc.imageset/bootsplash_logo@3x.png b/ios/NewExpensify/Images.xcassets/BootSplashLogoAdHoc.imageset/bootsplash_logo@3x.png new file mode 100644 index 0000000000000000000000000000000000000000..e208d1e0f8abc0ffe0677c5e52aedc4b1604149b GIT binary patch literal 5701 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 literal 0 HcmV?d00001 diff --git a/ios/NewExpensify/Images.xcassets/BootSplashLogoDev.imageset/Contents.json b/ios/NewExpensify/Images.xcassets/BootSplashLogoDev.imageset/Contents.json new file mode 100644 index 000000000000..a8927aa86e2b --- /dev/null +++ b/ios/NewExpensify/Images.xcassets/BootSplashLogoDev.imageset/Contents.json @@ -0,0 +1,23 @@ +{ + "images" : [ + { + "filename" : "bootsplash_logo.png", + "idiom" : "universal", + "scale" : "1x" + }, + { + "filename" : "bootsplash_logo@2x.png", + "idiom" : "universal", + "scale" : "2x" + }, + { + "filename" : "bootsplash_logo@3x.png", + "idiom" : "universal", + "scale" : "3x" + } + ], + "info" : { + "author" : "xcode", + "version" : 1 + } +} diff --git a/ios/NewExpensify/Images.xcassets/BootSplashLogoDev.imageset/bootsplash_logo.png b/ios/NewExpensify/Images.xcassets/BootSplashLogoDev.imageset/bootsplash_logo.png new file mode 100644 index 0000000000000000000000000000000000000000..8fbef1c5ab06a55d035c06a8606028df254856b3 GIT binary patch literal 2379 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 V>I@H8AMocLWT0!TQ>S$e{Xf47qZ0rC literal 0 HcmV?d00001 diff --git a/ios/NewExpensify/Images.xcassets/BootSplashLogoDev.imageset/bootsplash_logo@3x.png b/ios/NewExpensify/Images.xcassets/BootSplashLogoDev.imageset/bootsplash_logo@3x.png new file mode 100644 index 0000000000000000000000000000000000000000..e208d1e0f8abc0ffe0677c5e52aedc4b1604149b GIT binary patch literal 5701 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 literal 0 HcmV?d00001 diff --git a/ios/NewExpensify/Images.xcassets/Contents.json b/ios/NewExpensify/Images.xcassets/Contents.json index 2d92bd53fdb2..73c00596a7fc 100644 --- a/ios/NewExpensify/Images.xcassets/Contents.json +++ b/ios/NewExpensify/Images.xcassets/Contents.json @@ -1,6 +1,6 @@ { "info" : { - "version" : 1, - "author" : "xcode" + "author" : "xcode", + "version" : 1 } } From a2bd8a06e058510846cb07c3d306ad99d78e15e9 Mon Sep 17 00:00:00 2001 From: staszekscp Date: Tue, 18 Apr 2023 15:34:48 +0200 Subject: [PATCH 10/51] fix package.json --- package.json | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/package.json b/package.json index 0a44c1b9ebb6..739b3922d363 100644 --- a/package.json +++ b/package.json @@ -10,9 +10,9 @@ "postinstall": "npx patch-package && cd desktop && npm install", "clean": "npx react-native clean-project-auto", "android": "scripts/set-pusher-suffix.sh && npx react-native run-android --port=8083 --variant=developmentDebug --appId=com.expensify.chat.dev", - "ios": "scripts/set-pusher-suffix.sh && npx react-native run-ios --port=8082 --configuration=\"DebugDevelopment\" --scheme=\"NewExpensifyDev\"", - "ipad": "npx react-native run-ios --port=8082 --simulator=\"iPad Pro (12.9-inch) (4th generation)\"", - "ipad-sm": "npx react-native run-ios --port=8082 --simulator=\"iPad Pro (9.7-inch)\"", + "ios": "scripts/set-pusher-suffix.sh && npx react-native run-ios --port=8082 --configuration=\"Debug Development\" --scheme=\"New Expensify Dev\"", + "ipad": "npx react-native run-ios --port=8082 --simulator=\"iPad Pro (12.9-inch) (4th generation)\" --configuration=\"Debug Development\" --scheme=\"New Expensify Dev\"", + "ipad-sm": "npx react-native run-ios --port=8082 --simulator=\"iPad Pro (9.7-inch)\" --configuration=\"Debug Development\" --scheme=\"New Expensify Dev\"", "start": "npx react-native start", "web": "scripts/set-pusher-suffix.sh && concurrently npm:web-proxy npm:web-server", "web-proxy": "node web/proxy.js", From 70545fe4a9edf894d42a25d8a0cbd089c7cfca7f Mon Sep 17 00:00:00 2001 From: staszekscp Date: Tue, 18 Apr 2023 16:57:39 +0200 Subject: [PATCH 11/51] add .env detection --- .../xcschemes/New Expensify AdHoc.xcscheme | 36 ++++++++++++++++++- .../xcschemes/New Expensify Staging.xcscheme | 36 ++++++++++++++++++- .../xcschemes/New Expensify.xcscheme | 36 ++++++++++++++++++- ios/tmp.xcconfig | 10 ++++++ main.jsbundle.map | 1 + 5 files changed, 116 insertions(+), 3 deletions(-) create mode 100644 ios/tmp.xcconfig create mode 100644 main.jsbundle.map diff --git a/ios/NewExpensify.xcodeproj/xcshareddata/xcschemes/New Expensify AdHoc.xcscheme b/ios/NewExpensify.xcodeproj/xcshareddata/xcschemes/New Expensify AdHoc.xcscheme index 414feec17bc8..0e0fad6399a0 100644 --- a/ios/NewExpensify.xcodeproj/xcshareddata/xcschemes/New Expensify AdHoc.xcscheme +++ b/ios/NewExpensify.xcodeproj/xcshareddata/xcschemes/New Expensify AdHoc.xcscheme @@ -1,10 +1,44 @@ + version = "1.7"> + + + + + + + + + + + + + + + + + + + version = "1.7"> + + + + + + + + + + + + + + + + + + + version = "1.7"> + + + + + + + + + + + + + + + + + + . Not iterable and doesn't have a `length`.\n// This is compatible with actual arrays as well as with objects that look like\n// {0: 'value', 1: '...'}\nglobal.__r = metroRequire;\nglobal[`${__METRO_GLOBAL_PREFIX__}__d`] = define;\nglobal.__c = clear;\nglobal.__registerSegment = registerSegment;\nvar modules = clear();\n\n// Don't use a Symbol here, it would pull in an extra polyfill with all sorts of\n// additional stuff (e.g. Array.from).\nconst EMPTY = {};\nconst CYCLE_DETECTED = {};\nconst { hasOwnProperty } = {};\nif (__DEV__) {\n global.$RefreshReg$ = () => {};\n global.$RefreshSig$ = () => (type) => type;\n}\nfunction clear() {\n modules = Object.create(null);\n\n // We return modules here so that we can assign an initial value to modules\n // when defining it. Otherwise, we would have to do \"let modules = null\",\n // which will force us to add \"nullthrows\" everywhere.\n return modules;\n}\nif (__DEV__) {\n var verboseNamesToModuleIds = Object.create(null);\n var initializingModuleIds = [];\n}\nfunction define(factory, moduleId, dependencyMap) {\n if (modules[moduleId] != null) {\n if (__DEV__) {\n // (We take `inverseDependencies` from `arguments` to avoid an unused\n // named parameter in `define` in production.\n const inverseDependencies = arguments[4];\n\n // If the module has already been defined and the define method has been\n // called with inverseDependencies, we can hot reload it.\n if (inverseDependencies) {\n global.__accept(moduleId, factory, dependencyMap, inverseDependencies);\n }\n }\n\n // prevent repeated calls to `global.nativeRequire` to overwrite modules\n // that are already loaded\n return;\n }\n const mod = {\n dependencyMap,\n factory,\n hasError: false,\n importedAll: EMPTY,\n importedDefault: EMPTY,\n isInitialized: false,\n publicModule: {\n exports: {},\n },\n };\n modules[moduleId] = mod;\n if (__DEV__) {\n // HMR\n mod.hot = createHotReloadingObject();\n\n // DEBUGGABLE MODULES NAMES\n // we take `verboseName` from `arguments` to avoid an unused named parameter\n // in `define` in production.\n const verboseName = arguments[3];\n if (verboseName) {\n mod.verboseName = verboseName;\n verboseNamesToModuleIds[verboseName] = moduleId;\n }\n }\n}\nfunction metroRequire(moduleId) {\n if (__DEV__ && typeof moduleId === \"string\") {\n const verboseName = moduleId;\n moduleId = verboseNamesToModuleIds[verboseName];\n if (moduleId == null) {\n throw new Error(`Unknown named module: \"${verboseName}\"`);\n } else {\n console.warn(\n `Requiring module \"${verboseName}\" by name is only supported for ` +\n \"debugging purposes and will BREAK IN PRODUCTION!\"\n );\n }\n }\n\n //$FlowFixMe: at this point we know that moduleId is a number\n const moduleIdReallyIsNumber = moduleId;\n if (__DEV__) {\n const initializingIndex = initializingModuleIds.indexOf(\n moduleIdReallyIsNumber\n );\n if (initializingIndex !== -1) {\n const cycle = initializingModuleIds\n .slice(initializingIndex)\n .map((id) => (modules[id] ? modules[id].verboseName : \"[unknown]\"));\n if (shouldPrintRequireCycle(cycle)) {\n cycle.push(cycle[0]); // We want to print A -> B -> A:\n console.warn(\n `Require cycle: ${cycle.join(\" -> \")}\\n\\n` +\n \"Require cycles are allowed, but can result in uninitialized values. \" +\n \"Consider refactoring to remove the need for a cycle.\"\n );\n }\n }\n }\n const module = modules[moduleIdReallyIsNumber];\n return module && module.isInitialized\n ? module.publicModule.exports\n : guardedLoadModule(moduleIdReallyIsNumber, module);\n}\n\n// We print require cycles unless they match a pattern in the\n// `requireCycleIgnorePatterns` configuration.\nfunction shouldPrintRequireCycle(modules) {\n const regExps =\n global[__METRO_GLOBAL_PREFIX__ + \"__requireCycleIgnorePatterns\"];\n if (!Array.isArray(regExps)) {\n return true;\n }\n const isIgnored = (module) =>\n module != null && regExps.some((regExp) => regExp.test(module));\n\n // Print the cycle unless any part of it is ignored\n return modules.every((module) => !isIgnored(module));\n}\nfunction metroImportDefault(moduleId) {\n if (__DEV__ && typeof moduleId === \"string\") {\n const verboseName = moduleId;\n moduleId = verboseNamesToModuleIds[verboseName];\n }\n\n //$FlowFixMe: at this point we know that moduleId is a number\n const moduleIdReallyIsNumber = moduleId;\n if (\n modules[moduleIdReallyIsNumber] &&\n modules[moduleIdReallyIsNumber].importedDefault !== EMPTY\n ) {\n return modules[moduleIdReallyIsNumber].importedDefault;\n }\n const exports = metroRequire(moduleIdReallyIsNumber);\n const importedDefault =\n exports && exports.__esModule ? exports.default : exports;\n\n // $FlowFixMe The metroRequire call above will throw if modules[id] is null\n return (modules[moduleIdReallyIsNumber].importedDefault = importedDefault);\n}\nmetroRequire.importDefault = metroImportDefault;\nfunction metroImportAll(moduleId) {\n if (__DEV__ && typeof moduleId === \"string\") {\n const verboseName = moduleId;\n moduleId = verboseNamesToModuleIds[verboseName];\n }\n\n //$FlowFixMe: at this point we know that moduleId is a number\n const moduleIdReallyIsNumber = moduleId;\n if (\n modules[moduleIdReallyIsNumber] &&\n modules[moduleIdReallyIsNumber].importedAll !== EMPTY\n ) {\n return modules[moduleIdReallyIsNumber].importedAll;\n }\n const exports = metroRequire(moduleIdReallyIsNumber);\n let importedAll;\n if (exports && exports.__esModule) {\n importedAll = exports;\n } else {\n importedAll = {};\n\n // Refrain from using Object.assign, it has to work in ES3 environments.\n if (exports) {\n for (const key in exports) {\n if (hasOwnProperty.call(exports, key)) {\n importedAll[key] = exports[key];\n }\n }\n }\n importedAll.default = exports;\n }\n\n // $FlowFixMe The metroRequire call above will throw if modules[id] is null\n return (modules[moduleIdReallyIsNumber].importedAll = importedAll);\n}\nmetroRequire.importAll = metroImportAll;\n\n// The `require.context()` syntax is never executed in the runtime because it is converted\n// to `require()` in `metro/src/ModuleGraph/worker/collectDependencies.js` after collecting\n// dependencies. If the feature flag is not enabled then the conversion never takes place and this error is thrown (development only).\nmetroRequire.context = function fallbackRequireContext() {\n if (__DEV__) {\n throw new Error(\n \"The experimental Metro feature `require.context` is not enabled in your project.\\nThis can be enabled by setting the `transformer.unstable_allowRequireContext` property to `true` in your Metro configuration.\"\n );\n }\n throw new Error(\n \"The experimental Metro feature `require.context` is not enabled in your project.\"\n );\n};\nlet inGuard = false;\nfunction guardedLoadModule(moduleId, module) {\n if (!inGuard && global.ErrorUtils) {\n inGuard = true;\n let returnValue;\n try {\n returnValue = loadModuleImplementation(moduleId, module);\n } catch (e) {\n // TODO: (moti) T48204692 Type this use of ErrorUtils.\n global.ErrorUtils.reportFatalError(e);\n }\n inGuard = false;\n return returnValue;\n } else {\n return loadModuleImplementation(moduleId, module);\n }\n}\nconst ID_MASK_SHIFT = 16;\nconst LOCAL_ID_MASK = ~0 >>> ID_MASK_SHIFT;\nfunction unpackModuleId(moduleId) {\n const segmentId = moduleId >>> ID_MASK_SHIFT;\n const localId = moduleId & LOCAL_ID_MASK;\n return {\n segmentId,\n localId,\n };\n}\nmetroRequire.unpackModuleId = unpackModuleId;\nfunction packModuleId(value) {\n return (value.segmentId << ID_MASK_SHIFT) + value.localId;\n}\nmetroRequire.packModuleId = packModuleId;\nconst moduleDefinersBySegmentID = [];\nconst definingSegmentByModuleID = new Map();\nfunction registerSegment(segmentId, moduleDefiner, moduleIds) {\n moduleDefinersBySegmentID[segmentId] = moduleDefiner;\n if (__DEV__) {\n if (segmentId === 0 && moduleIds) {\n throw new Error(\n \"registerSegment: Expected moduleIds to be null for main segment\"\n );\n }\n if (segmentId !== 0 && !moduleIds) {\n throw new Error(\n \"registerSegment: Expected moduleIds to be passed for segment #\" +\n segmentId\n );\n }\n }\n if (moduleIds) {\n moduleIds.forEach((moduleId) => {\n if (!modules[moduleId] && !definingSegmentByModuleID.has(moduleId)) {\n definingSegmentByModuleID.set(moduleId, segmentId);\n }\n });\n }\n}\nfunction loadModuleImplementation(moduleId, module) {\n if (!module && moduleDefinersBySegmentID.length > 0) {\n var _definingSegmentByMod;\n const segmentId =\n (_definingSegmentByMod = definingSegmentByModuleID.get(moduleId)) !==\n null && _definingSegmentByMod !== void 0\n ? _definingSegmentByMod\n : 0;\n const definer = moduleDefinersBySegmentID[segmentId];\n if (definer != null) {\n definer(moduleId);\n module = modules[moduleId];\n definingSegmentByModuleID.delete(moduleId);\n }\n }\n const nativeRequire = global.nativeRequire;\n if (!module && nativeRequire) {\n const { segmentId, localId } = unpackModuleId(moduleId);\n nativeRequire(localId, segmentId);\n module = modules[moduleId];\n }\n if (!module) {\n throw unknownModuleError(moduleId);\n }\n if (module.hasError) {\n throw module.error;\n }\n if (__DEV__) {\n var Systrace = requireSystrace();\n var Refresh = requireRefresh();\n }\n\n // We must optimistically mark module as initialized before running the\n // factory to keep any require cycles inside the factory from causing an\n // infinite require loop.\n module.isInitialized = true;\n const { factory, dependencyMap } = module;\n if (__DEV__) {\n initializingModuleIds.push(moduleId);\n }\n try {\n if (__DEV__) {\n // $FlowIgnore: we know that __DEV__ is const and `Systrace` exists\n Systrace.beginEvent(\"JS_require_\" + (module.verboseName || moduleId));\n }\n const moduleObject = module.publicModule;\n if (__DEV__) {\n moduleObject.hot = module.hot;\n var prevRefreshReg = global.$RefreshReg$;\n var prevRefreshSig = global.$RefreshSig$;\n if (Refresh != null) {\n const RefreshRuntime = Refresh;\n global.$RefreshReg$ = (type, id) => {\n RefreshRuntime.register(type, moduleId + \" \" + id);\n };\n global.$RefreshSig$ =\n RefreshRuntime.createSignatureFunctionForTransform;\n }\n }\n moduleObject.id = moduleId;\n\n // keep args in sync with with defineModuleCode in\n // metro/src/Resolver/index.js\n // and metro/src/ModuleGraph/worker.js\n factory(\n global,\n metroRequire,\n metroImportDefault,\n metroImportAll,\n moduleObject,\n moduleObject.exports,\n dependencyMap\n );\n\n // avoid removing factory in DEV mode as it breaks HMR\n if (!__DEV__) {\n // $FlowFixMe: This is only sound because we never access `factory` again\n module.factory = undefined;\n module.dependencyMap = undefined;\n }\n if (__DEV__) {\n // $FlowIgnore: we know that __DEV__ is const and `Systrace` exists\n Systrace.endEvent();\n if (Refresh != null) {\n registerExportsForReactRefresh(Refresh, moduleObject.exports, moduleId);\n }\n }\n return moduleObject.exports;\n } catch (e) {\n module.hasError = true;\n module.error = e;\n module.isInitialized = false;\n module.publicModule.exports = undefined;\n throw e;\n } finally {\n if (__DEV__) {\n if (initializingModuleIds.pop() !== moduleId) {\n throw new Error(\n \"initializingModuleIds is corrupt; something is terribly wrong\"\n );\n }\n global.$RefreshReg$ = prevRefreshReg;\n global.$RefreshSig$ = prevRefreshSig;\n }\n }\n}\nfunction unknownModuleError(id) {\n let message = 'Requiring unknown module \"' + id + '\".';\n if (__DEV__) {\n message +=\n \" If you are sure the module exists, try restarting Metro. \" +\n \"You may also want to run `yarn` or `npm install`.\";\n }\n return Error(message);\n}\nif (__DEV__) {\n // $FlowFixMe[prop-missing]\n metroRequire.Systrace = {\n beginEvent: () => {},\n endEvent: () => {},\n };\n // $FlowFixMe[prop-missing]\n metroRequire.getModules = () => {\n return modules;\n };\n\n // HOT MODULE RELOADING\n var createHotReloadingObject = function () {\n const hot = {\n _acceptCallback: null,\n _disposeCallback: null,\n _didAccept: false,\n accept: (callback) => {\n hot._didAccept = true;\n hot._acceptCallback = callback;\n },\n dispose: (callback) => {\n hot._disposeCallback = callback;\n },\n };\n return hot;\n };\n let reactRefreshTimeout = null;\n const metroHotUpdateModule = function (\n id,\n factory,\n dependencyMap,\n inverseDependencies\n ) {\n const mod = modules[id];\n if (!mod) {\n if (factory) {\n // New modules are going to be handled by the define() method.\n return;\n }\n throw unknownModuleError(id);\n }\n if (!mod.hasError && !mod.isInitialized) {\n // The module hasn't actually been executed yet,\n // so we can always safely replace it.\n mod.factory = factory;\n mod.dependencyMap = dependencyMap;\n return;\n }\n const Refresh = requireRefresh();\n const refreshBoundaryIDs = new Set();\n\n // In this loop, we will traverse the dependency tree upwards from the\n // changed module. Updates \"bubble\" up to the closest accepted parent.\n //\n // If we reach the module root and nothing along the way accepted the update,\n // we know hot reload is going to fail. In that case we return false.\n //\n // The main purpose of this loop is to figure out whether it's safe to apply\n // a hot update. It is only safe when the update was accepted somewhere\n // along the way upwards for each of its parent dependency module chains.\n //\n // We perform a topological sort because we may discover the same\n // module more than once in the list of things to re-execute, and\n // we want to execute modules before modules that depend on them.\n //\n // If we didn't have this check, we'd risk re-evaluating modules that\n // have side effects and lead to confusing and meaningless crashes.\n\n let didBailOut = false;\n let updatedModuleIDs;\n try {\n updatedModuleIDs = topologicalSort(\n [id],\n // Start with the changed module and go upwards\n (pendingID) => {\n const pendingModule = modules[pendingID];\n if (pendingModule == null) {\n // Nothing to do.\n return [];\n }\n const pendingHot = pendingModule.hot;\n if (pendingHot == null) {\n throw new Error(\n \"[Refresh] Expected module.hot to always exist in DEV.\"\n );\n }\n // A module can be accepted manually from within itself.\n let canAccept = pendingHot._didAccept;\n if (!canAccept && Refresh != null) {\n // Or React Refresh may mark it accepted based on exports.\n const isBoundary = isReactRefreshBoundary(\n Refresh,\n pendingModule.publicModule.exports\n );\n if (isBoundary) {\n canAccept = true;\n refreshBoundaryIDs.add(pendingID);\n }\n }\n if (canAccept) {\n // Don't look at parents.\n return [];\n }\n // If we bubble through the roof, there is no way to do a hot update.\n // Bail out altogether. This is the failure case.\n const parentIDs = inverseDependencies[pendingID];\n if (parentIDs.length === 0) {\n // Reload the app because the hot reload can't succeed.\n // This should work both on web and React Native.\n performFullRefresh(\"No root boundary\", {\n source: mod,\n failed: pendingModule,\n });\n didBailOut = true;\n return [];\n }\n // This module can't handle the update but maybe all its parents can?\n // Put them all in the queue to run the same set of checks.\n return parentIDs;\n },\n () => didBailOut // Should we stop?\n ).reverse();\n } catch (e) {\n if (e === CYCLE_DETECTED) {\n performFullRefresh(\"Dependency cycle\", {\n source: mod,\n });\n return;\n }\n throw e;\n }\n if (didBailOut) {\n return;\n }\n\n // If we reached here, it is likely that hot reload will be successful.\n // Run the actual factories.\n const seenModuleIDs = new Set();\n for (let i = 0; i < updatedModuleIDs.length; i++) {\n const updatedID = updatedModuleIDs[i];\n if (seenModuleIDs.has(updatedID)) {\n continue;\n }\n seenModuleIDs.add(updatedID);\n const updatedMod = modules[updatedID];\n if (updatedMod == null) {\n throw new Error(\"[Refresh] Expected to find the updated module.\");\n }\n const prevExports = updatedMod.publicModule.exports;\n const didError = runUpdatedModule(\n updatedID,\n updatedID === id ? factory : undefined,\n updatedID === id ? dependencyMap : undefined\n );\n const nextExports = updatedMod.publicModule.exports;\n if (didError) {\n // The user was shown a redbox about module initialization.\n // There's nothing for us to do here until it's fixed.\n return;\n }\n if (refreshBoundaryIDs.has(updatedID)) {\n // Since we just executed the code for it, it's possible\n // that the new exports make it ineligible for being a boundary.\n const isNoLongerABoundary = !isReactRefreshBoundary(\n Refresh,\n nextExports\n );\n // It can also become ineligible if its exports are incompatible\n // with the previous exports.\n // For example, if you add/remove/change exports, we'll want\n // to re-execute the importing modules, and force those components\n // to re-render. Similarly, if you convert a class component\n // to a function, we want to invalidate the boundary.\n const didInvalidate = shouldInvalidateReactRefreshBoundary(\n Refresh,\n prevExports,\n nextExports\n );\n if (isNoLongerABoundary || didInvalidate) {\n // We'll be conservative. The only case in which we won't do a full\n // reload is if all parent modules are also refresh boundaries.\n // In that case we'll add them to the current queue.\n const parentIDs = inverseDependencies[updatedID];\n if (parentIDs.length === 0) {\n // Looks like we bubbled to the root. Can't recover from that.\n performFullRefresh(\n isNoLongerABoundary\n ? \"No longer a boundary\"\n : \"Invalidated boundary\",\n {\n source: mod,\n failed: updatedMod,\n }\n );\n return;\n }\n // Schedule all parent refresh boundaries to re-run in this loop.\n for (let j = 0; j < parentIDs.length; j++) {\n const parentID = parentIDs[j];\n const parentMod = modules[parentID];\n if (parentMod == null) {\n throw new Error(\"[Refresh] Expected to find parent module.\");\n }\n const canAcceptParent = isReactRefreshBoundary(\n Refresh,\n parentMod.publicModule.exports\n );\n if (canAcceptParent) {\n // All parents will have to re-run too.\n refreshBoundaryIDs.add(parentID);\n updatedModuleIDs.push(parentID);\n } else {\n performFullRefresh(\"Invalidated boundary\", {\n source: mod,\n failed: parentMod,\n });\n return;\n }\n }\n }\n }\n }\n if (Refresh != null) {\n // Debounce a little in case there are multiple updates queued up.\n // This is also useful because __accept may be called multiple times.\n if (reactRefreshTimeout == null) {\n reactRefreshTimeout = setTimeout(() => {\n reactRefreshTimeout = null;\n // Update React components.\n Refresh.performReactRefresh();\n }, 30);\n }\n }\n };\n const topologicalSort = function (roots, getEdges, earlyStop) {\n const result = [];\n const visited = new Set();\n const stack = new Set();\n function traverseDependentNodes(node) {\n if (stack.has(node)) {\n throw CYCLE_DETECTED;\n }\n if (visited.has(node)) {\n return;\n }\n visited.add(node);\n stack.add(node);\n const dependentNodes = getEdges(node);\n if (earlyStop(node)) {\n stack.delete(node);\n return;\n }\n dependentNodes.forEach((dependent) => {\n traverseDependentNodes(dependent);\n });\n stack.delete(node);\n result.push(node);\n }\n roots.forEach((root) => {\n traverseDependentNodes(root);\n });\n return result;\n };\n const runUpdatedModule = function (id, factory, dependencyMap) {\n const mod = modules[id];\n if (mod == null) {\n throw new Error(\"[Refresh] Expected to find the module.\");\n }\n const { hot } = mod;\n if (!hot) {\n throw new Error(\"[Refresh] Expected module.hot to always exist in DEV.\");\n }\n if (hot._disposeCallback) {\n try {\n hot._disposeCallback();\n } catch (error) {\n console.error(\n `Error while calling dispose handler for module ${id}: `,\n error\n );\n }\n }\n if (factory) {\n mod.factory = factory;\n }\n if (dependencyMap) {\n mod.dependencyMap = dependencyMap;\n }\n mod.hasError = false;\n mod.error = undefined;\n mod.importedAll = EMPTY;\n mod.importedDefault = EMPTY;\n mod.isInitialized = false;\n const prevExports = mod.publicModule.exports;\n mod.publicModule.exports = {};\n hot._didAccept = false;\n hot._acceptCallback = null;\n hot._disposeCallback = null;\n metroRequire(id);\n if (mod.hasError) {\n // This error has already been reported via a redbox.\n // We know it's likely a typo or some mistake that was just introduced.\n // Our goal now is to keep the rest of the application working so that by\n // the time user fixes the error, the app isn't completely destroyed\n // underneath the redbox. So we'll revert the module object to the last\n // successful export and stop propagating this update.\n mod.hasError = false;\n mod.isInitialized = true;\n mod.error = null;\n mod.publicModule.exports = prevExports;\n // We errored. Stop the update.\n return true;\n }\n if (hot._acceptCallback) {\n try {\n hot._acceptCallback();\n } catch (error) {\n console.error(\n `Error while calling accept handler for module ${id}: `,\n error\n );\n }\n }\n // No error.\n return false;\n };\n const performFullRefresh = (reason, modules) => {\n /* global window */\n if (\n typeof window !== \"undefined\" &&\n window.location != null &&\n typeof window.location.reload === \"function\"\n ) {\n window.location.reload();\n } else {\n const Refresh = requireRefresh();\n if (Refresh != null) {\n var _modules$source$verbo,\n _modules$source,\n _modules$failed$verbo,\n _modules$failed;\n const sourceName =\n (_modules$source$verbo =\n (_modules$source = modules.source) === null ||\n _modules$source === void 0\n ? void 0\n : _modules$source.verboseName) !== null &&\n _modules$source$verbo !== void 0\n ? _modules$source$verbo\n : \"unknown\";\n const failedName =\n (_modules$failed$verbo =\n (_modules$failed = modules.failed) === null ||\n _modules$failed === void 0\n ? void 0\n : _modules$failed.verboseName) !== null &&\n _modules$failed$verbo !== void 0\n ? _modules$failed$verbo\n : \"unknown\";\n Refresh.performFullRefresh(\n `Fast Refresh - ${reason} <${sourceName}> <${failedName}>`\n );\n } else {\n console.warn(\"Could not reload the application after an edit.\");\n }\n }\n };\n\n // Modules that only export components become React Refresh boundaries.\n var isReactRefreshBoundary = function (Refresh, moduleExports) {\n if (Refresh.isLikelyComponentType(moduleExports)) {\n return true;\n }\n if (moduleExports == null || typeof moduleExports !== \"object\") {\n // Exit if we can't iterate over exports.\n return false;\n }\n let hasExports = false;\n let areAllExportsComponents = true;\n for (const key in moduleExports) {\n hasExports = true;\n if (key === \"__esModule\") {\n continue;\n }\n const desc = Object.getOwnPropertyDescriptor(moduleExports, key);\n if (desc && desc.get) {\n // Don't invoke getters as they may have side effects.\n return false;\n }\n const exportValue = moduleExports[key];\n if (!Refresh.isLikelyComponentType(exportValue)) {\n areAllExportsComponents = false;\n }\n }\n return hasExports && areAllExportsComponents;\n };\n var shouldInvalidateReactRefreshBoundary = (\n Refresh,\n prevExports,\n nextExports\n ) => {\n const prevSignature = getRefreshBoundarySignature(Refresh, prevExports);\n const nextSignature = getRefreshBoundarySignature(Refresh, nextExports);\n if (prevSignature.length !== nextSignature.length) {\n return true;\n }\n for (let i = 0; i < nextSignature.length; i++) {\n if (prevSignature[i] !== nextSignature[i]) {\n return true;\n }\n }\n return false;\n };\n\n // When this signature changes, it's unsafe to stop at this refresh boundary.\n var getRefreshBoundarySignature = (Refresh, moduleExports) => {\n const signature = [];\n signature.push(Refresh.getFamilyByType(moduleExports));\n if (moduleExports == null || typeof moduleExports !== \"object\") {\n // Exit if we can't iterate over exports.\n // (This is important for legacy environments.)\n return signature;\n }\n for (const key in moduleExports) {\n if (key === \"__esModule\") {\n continue;\n }\n const desc = Object.getOwnPropertyDescriptor(moduleExports, key);\n if (desc && desc.get) {\n continue;\n }\n const exportValue = moduleExports[key];\n signature.push(key);\n signature.push(Refresh.getFamilyByType(exportValue));\n }\n return signature;\n };\n var registerExportsForReactRefresh = (Refresh, moduleExports, moduleID) => {\n Refresh.register(moduleExports, moduleID + \" %exports%\");\n if (moduleExports == null || typeof moduleExports !== \"object\") {\n // Exit if we can't iterate over exports.\n // (This is important for legacy environments.)\n return;\n }\n for (const key in moduleExports) {\n const desc = Object.getOwnPropertyDescriptor(moduleExports, key);\n if (desc && desc.get) {\n // Don't invoke getters as they may have side effects.\n continue;\n }\n const exportValue = moduleExports[key];\n const typeID = moduleID + \" %exports% \" + key;\n Refresh.register(exportValue, typeID);\n }\n };\n global.__accept = metroHotUpdateModule;\n}\nif (__DEV__) {\n // The metro require polyfill can not have module dependencies.\n // The Systrace and ReactRefresh dependencies are, therefore, made publicly\n // available. Ideally, the dependency would be inversed in a way that\n // Systrace / ReactRefresh could integrate into Metro rather than\n // having to make them publicly available.\n\n var requireSystrace = function requireSystrace() {\n return (\n // $FlowFixMe[prop-missing]\n global[__METRO_GLOBAL_PREFIX__ + \"__SYSTRACE\"] || metroRequire.Systrace\n );\n };\n var requireRefresh = function requireRefresh() {\n return (\n // $FlowFixMe[prop-missing]\n global[__METRO_GLOBAL_PREFIX__ + \"__ReactRefresh\"] || metroRequire.Refresh\n );\n };\n}\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 * @polyfill\n * @nolint\n * @format\n */\n\n/* eslint-disable no-shadow, eqeqeq, curly, no-unused-vars, no-void, no-control-regex */\n\n/**\n * This pipes all of our console logging functions to native logging so that\n * JavaScript errors in required modules show up in Xcode via NSLog.\n */\nconst inspect = (function() {\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 // https://github.com/joyent/node/blob/master/lib/util.js\n\n function inspect(obj, opts) {\n var ctx = {\n seen: [],\n formatValueCalls: 0,\n stylize: stylizeNoColor,\n };\n return formatValue(ctx, obj, opts.depth);\n }\n\n function stylizeNoColor(str, styleType) {\n return str;\n }\n\n function arrayToHash(array) {\n var hash = {};\n\n array.forEach(function(val, idx) {\n hash[val] = true;\n });\n\n return hash;\n }\n\n function formatValue(ctx, value, recurseTimes) {\n ctx.formatValueCalls++;\n if (ctx.formatValueCalls > 200) {\n return `[TOO BIG formatValueCalls ${ctx.formatValueCalls} exceeded limit of 200]`;\n }\n\n // Primitive types cannot have properties\n var primitive = formatPrimitive(ctx, value);\n if (primitive) {\n return primitive;\n }\n\n // Look up the keys of the object.\n var keys = Object.keys(value);\n var visibleKeys = arrayToHash(keys);\n\n // IE doesn't make error fields non-enumerable\n // http://msdn.microsoft.com/en-us/library/ie/dww52sbt(v=vs.94).aspx\n if (\n isError(value) &&\n (keys.indexOf('message') >= 0 || keys.indexOf('description') >= 0)\n ) {\n return formatError(value);\n }\n\n // Some type of object without properties can be shortcutted.\n if (keys.length === 0) {\n if (isFunction(value)) {\n var name = value.name ? ': ' + value.name : '';\n return ctx.stylize('[Function' + name + ']', 'special');\n }\n if (isRegExp(value)) {\n return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');\n }\n if (isDate(value)) {\n return ctx.stylize(Date.prototype.toString.call(value), 'date');\n }\n if (isError(value)) {\n return formatError(value);\n }\n }\n\n var base = '',\n array = false,\n braces = ['{', '}'];\n\n // Make Array say that they are Array\n if (isArray(value)) {\n array = true;\n braces = ['[', ']'];\n }\n\n // Make functions say that they are functions\n if (isFunction(value)) {\n var n = value.name ? ': ' + value.name : '';\n base = ' [Function' + n + ']';\n }\n\n // Make RegExps say that they are RegExps\n if (isRegExp(value)) {\n base = ' ' + RegExp.prototype.toString.call(value);\n }\n\n // Make dates with properties first say the date\n if (isDate(value)) {\n base = ' ' + Date.prototype.toUTCString.call(value);\n }\n\n // Make error with message first say the error\n if (isError(value)) {\n base = ' ' + formatError(value);\n }\n\n if (keys.length === 0 && (!array || value.length == 0)) {\n return braces[0] + base + braces[1];\n }\n\n if (recurseTimes < 0) {\n if (isRegExp(value)) {\n return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');\n } else {\n return ctx.stylize('[Object]', 'special');\n }\n }\n\n ctx.seen.push(value);\n\n var output;\n if (array) {\n output = formatArray(ctx, value, recurseTimes, visibleKeys, keys);\n } else {\n output = keys.map(function(key) {\n return formatProperty(\n ctx,\n value,\n recurseTimes,\n visibleKeys,\n key,\n array,\n );\n });\n }\n\n ctx.seen.pop();\n\n return reduceToSingleString(output, base, braces);\n }\n\n function formatPrimitive(ctx, value) {\n if (isUndefined(value)) return ctx.stylize('undefined', 'undefined');\n if (isString(value)) {\n var simple =\n \"'\" +\n JSON.stringify(value)\n .replace(/^\"|\"$/g, '')\n .replace(/'/g, \"\\\\'\")\n .replace(/\\\\\"/g, '\"') +\n \"'\";\n return ctx.stylize(simple, 'string');\n }\n if (isNumber(value)) return ctx.stylize('' + value, 'number');\n if (isBoolean(value)) return ctx.stylize('' + value, 'boolean');\n // For some reason typeof null is \"object\", so special case here.\n if (isNull(value)) return ctx.stylize('null', 'null');\n }\n\n function formatError(value) {\n return '[' + Error.prototype.toString.call(value) + ']';\n }\n\n function formatArray(ctx, value, recurseTimes, visibleKeys, keys) {\n var output = [];\n for (var i = 0, l = value.length; i < l; ++i) {\n if (hasOwnProperty(value, String(i))) {\n output.push(\n formatProperty(\n ctx,\n value,\n recurseTimes,\n visibleKeys,\n String(i),\n true,\n ),\n );\n } else {\n output.push('');\n }\n }\n keys.forEach(function(key) {\n if (!key.match(/^\\d+$/)) {\n output.push(\n formatProperty(ctx, value, recurseTimes, visibleKeys, key, true),\n );\n }\n });\n return output;\n }\n\n function formatProperty(ctx, value, recurseTimes, visibleKeys, key, array) {\n var name, str, desc;\n desc = Object.getOwnPropertyDescriptor(value, key) || {value: value[key]};\n if (desc.get) {\n if (desc.set) {\n str = ctx.stylize('[Getter/Setter]', 'special');\n } else {\n str = ctx.stylize('[Getter]', 'special');\n }\n } else {\n if (desc.set) {\n str = ctx.stylize('[Setter]', 'special');\n }\n }\n if (!hasOwnProperty(visibleKeys, key)) {\n name = '[' + key + ']';\n }\n if (!str) {\n if (ctx.seen.indexOf(desc.value) < 0) {\n if (isNull(recurseTimes)) {\n str = formatValue(ctx, desc.value, null);\n } else {\n str = formatValue(ctx, desc.value, recurseTimes - 1);\n }\n if (str.indexOf('\\n') > -1) {\n if (array) {\n str = str\n .split('\\n')\n .map(function(line) {\n return ' ' + line;\n })\n .join('\\n')\n .substr(2);\n } else {\n str =\n '\\n' +\n str\n .split('\\n')\n .map(function(line) {\n return ' ' + line;\n })\n .join('\\n');\n }\n }\n } else {\n str = ctx.stylize('[Circular]', 'special');\n }\n }\n if (isUndefined(name)) {\n if (array && key.match(/^\\d+$/)) {\n return str;\n }\n name = JSON.stringify('' + key);\n if (name.match(/^\"([a-zA-Z_][a-zA-Z_0-9]*)\"$/)) {\n name = name.substr(1, name.length - 2);\n name = ctx.stylize(name, 'name');\n } else {\n name = name\n .replace(/'/g, \"\\\\'\")\n .replace(/\\\\\"/g, '\"')\n .replace(/(^\"|\"$)/g, \"'\");\n name = ctx.stylize(name, 'string');\n }\n }\n\n return name + ': ' + str;\n }\n\n function reduceToSingleString(output, base, braces) {\n var numLinesEst = 0;\n var length = output.reduce(function(prev, cur) {\n numLinesEst++;\n if (cur.indexOf('\\n') >= 0) numLinesEst++;\n return prev + cur.replace(/\\u001b\\[\\d\\d?m/g, '').length + 1;\n }, 0);\n\n if (length > 60) {\n return (\n braces[0] +\n (base === '' ? '' : base + '\\n ') +\n ' ' +\n output.join(',\\n ') +\n ' ' +\n braces[1]\n );\n }\n\n return braces[0] + base + ' ' + output.join(', ') + ' ' + braces[1];\n }\n\n // NOTE: These type checking functions intentionally don't use `instanceof`\n // because it is fragile and can be easily faked with `Object.create()`.\n function isArray(ar) {\n return Array.isArray(ar);\n }\n\n function isBoolean(arg) {\n return typeof arg === 'boolean';\n }\n\n function isNull(arg) {\n return arg === null;\n }\n\n function isNullOrUndefined(arg) {\n return arg == null;\n }\n\n function isNumber(arg) {\n return typeof arg === 'number';\n }\n\n function isString(arg) {\n return typeof arg === 'string';\n }\n\n function isSymbol(arg) {\n return typeof arg === 'symbol';\n }\n\n function isUndefined(arg) {\n return arg === void 0;\n }\n\n function isRegExp(re) {\n return isObject(re) && objectToString(re) === '[object RegExp]';\n }\n\n function isObject(arg) {\n return typeof arg === 'object' && arg !== null;\n }\n\n function isDate(d) {\n return isObject(d) && objectToString(d) === '[object Date]';\n }\n\n function isError(e) {\n return (\n isObject(e) &&\n (objectToString(e) === '[object Error]' || e instanceof Error)\n );\n }\n\n function isFunction(arg) {\n return typeof arg === 'function';\n }\n\n function objectToString(o) {\n return Object.prototype.toString.call(o);\n }\n\n function hasOwnProperty(obj, prop) {\n return Object.prototype.hasOwnProperty.call(obj, prop);\n }\n\n return inspect;\n})();\n\nconst OBJECT_COLUMN_NAME = '(index)';\nconst LOG_LEVELS = {\n trace: 0,\n info: 1,\n warn: 2,\n error: 3,\n};\nconst INSPECTOR_LEVELS = [];\nINSPECTOR_LEVELS[LOG_LEVELS.trace] = 'debug';\nINSPECTOR_LEVELS[LOG_LEVELS.info] = 'log';\nINSPECTOR_LEVELS[LOG_LEVELS.warn] = 'warning';\nINSPECTOR_LEVELS[LOG_LEVELS.error] = 'error';\n\n// Strip the inner function in getNativeLogFunction(), if in dev also\n// strip method printing to originalConsole.\nconst INSPECTOR_FRAMES_TO_SKIP = __DEV__ ? 2 : 1;\n\nfunction getNativeLogFunction(level) {\n return function() {\n let str;\n if (arguments.length === 1 && typeof arguments[0] === 'string') {\n str = arguments[0];\n } else {\n str = Array.prototype.map\n .call(arguments, function(arg) {\n return inspect(arg, {depth: 10});\n })\n .join(', ');\n }\n\n // TRICKY\n // If more than one argument is provided, the code above collapses them all\n // into a single formatted string. This transform wraps string arguments in\n // single quotes (e.g. \"foo\" -> \"'foo'\") which then breaks the \"Warning:\"\n // check below. So it's important that we look at the first argument, rather\n // than the formatted argument string.\n const firstArg = arguments[0];\n\n let logLevel = level;\n if (\n typeof firstArg === 'string' &&\n firstArg.slice(0, 9) === 'Warning: ' &&\n logLevel >= LOG_LEVELS.error\n ) {\n // React warnings use console.error so that a stack trace is shown,\n // but we don't (currently) want these to show a redbox\n // (Note: Logic duplicated in ExceptionsManager.js.)\n logLevel = LOG_LEVELS.warn;\n }\n if (global.__inspectorLog) {\n global.__inspectorLog(\n INSPECTOR_LEVELS[logLevel],\n str,\n [].slice.call(arguments),\n INSPECTOR_FRAMES_TO_SKIP,\n );\n }\n if (groupStack.length) {\n str = groupFormat('', str);\n }\n global.nativeLoggingHook(str, logLevel);\n };\n}\n\nfunction repeat(element, n) {\n return Array.apply(null, Array(n)).map(function() {\n return element;\n });\n}\n\nfunction consoleTablePolyfill(rows) {\n // convert object -> array\n if (!Array.isArray(rows)) {\n var data = rows;\n rows = [];\n for (var key in data) {\n if (data.hasOwnProperty(key)) {\n var row = data[key];\n row[OBJECT_COLUMN_NAME] = key;\n rows.push(row);\n }\n }\n }\n if (rows.length === 0) {\n global.nativeLoggingHook('', LOG_LEVELS.info);\n return;\n }\n\n var columns = Object.keys(rows[0]).sort();\n var stringRows = [];\n var columnWidths = [];\n\n // Convert each cell to a string. Also\n // figure out max cell width for each column\n columns.forEach(function(k, i) {\n columnWidths[i] = k.length;\n for (var j = 0; j < rows.length; j++) {\n var cellStr = (rows[j][k] || '?').toString();\n stringRows[j] = stringRows[j] || [];\n stringRows[j][i] = cellStr;\n columnWidths[i] = Math.max(columnWidths[i], cellStr.length);\n }\n });\n\n // Join all elements in the row into a single string with | separators\n // (appends extra spaces to each cell to make separators | aligned)\n function joinRow(row, space) {\n var cells = row.map(function(cell, i) {\n var extraSpaces = repeat(' ', columnWidths[i] - cell.length).join('');\n return cell + extraSpaces;\n });\n space = space || ' ';\n return cells.join(space + '|' + space);\n }\n\n var separators = columnWidths.map(function(columnWidth) {\n return repeat('-', columnWidth).join('');\n });\n var separatorRow = joinRow(separators, '-');\n var header = joinRow(columns);\n var table = [header, separatorRow];\n\n for (var i = 0; i < rows.length; i++) {\n table.push(joinRow(stringRows[i]));\n }\n\n // Notice extra empty line at the beginning.\n // Native logging hook adds \"RCTLog >\" at the front of every\n // logged string, which would shift the header and screw up\n // the table\n global.nativeLoggingHook('\\n' + table.join('\\n'), LOG_LEVELS.info);\n}\n\nconst GROUP_PAD = '\\u2502'; // Box light vertical\nconst GROUP_OPEN = '\\u2510'; // Box light down+left\nconst GROUP_CLOSE = '\\u2518'; // Box light up+left\n\nconst groupStack = [];\n\nfunction groupFormat(prefix, msg) {\n // Insert group formatting before the console message\n return groupStack.join('') + prefix + ' ' + (msg || '');\n}\n\nfunction consoleGroupPolyfill(label) {\n global.nativeLoggingHook(groupFormat(GROUP_OPEN, label), LOG_LEVELS.info);\n groupStack.push(GROUP_PAD);\n}\n\nfunction consoleGroupCollapsedPolyfill(label) {\n global.nativeLoggingHook(groupFormat(GROUP_CLOSE, label), LOG_LEVELS.info);\n groupStack.push(GROUP_PAD);\n}\n\nfunction consoleGroupEndPolyfill() {\n groupStack.pop();\n global.nativeLoggingHook(groupFormat(GROUP_CLOSE), LOG_LEVELS.info);\n}\n\nfunction consoleAssertPolyfill(expression, label) {\n if (!expression) {\n global.nativeLoggingHook('Assertion failed: ' + label, LOG_LEVELS.error);\n }\n}\n\nif (global.nativeLoggingHook) {\n const originalConsole = global.console;\n // Preserve the original `console` as `originalConsole`\n if (__DEV__ && originalConsole) {\n const descriptor = Object.getOwnPropertyDescriptor(global, 'console');\n if (descriptor) {\n Object.defineProperty(global, 'originalConsole', descriptor);\n }\n }\n\n global.console = {\n error: getNativeLogFunction(LOG_LEVELS.error),\n info: getNativeLogFunction(LOG_LEVELS.info),\n log: getNativeLogFunction(LOG_LEVELS.info),\n warn: getNativeLogFunction(LOG_LEVELS.warn),\n trace: getNativeLogFunction(LOG_LEVELS.trace),\n debug: getNativeLogFunction(LOG_LEVELS.trace),\n table: consoleTablePolyfill,\n group: consoleGroupPolyfill,\n groupEnd: consoleGroupEndPolyfill,\n groupCollapsed: consoleGroupCollapsedPolyfill,\n assert: consoleAssertPolyfill,\n };\n\n Object.defineProperty(console, '_isPolyfilled', {\n value: true,\n enumerable: false,\n });\n\n // If available, also call the original `console` method since that is\n // sometimes useful. Ex: on OS X, this will let you see rich output in\n // the Safari Web Inspector console.\n if (__DEV__ && originalConsole) {\n Object.keys(console).forEach(methodName => {\n const reactNativeMethod = console[methodName];\n if (originalConsole[methodName]) {\n console[methodName] = function() {\n originalConsole[methodName](...arguments);\n reactNativeMethod.apply(console, arguments);\n };\n }\n });\n\n // The following methods are not supported by this polyfill but\n // we still should pass them to original console if they are\n // supported by it.\n ['clear', 'dir', 'dirxml', 'profile', 'profileEnd'].forEach(methodName => {\n if (typeof originalConsole[methodName] === 'function') {\n console[methodName] = function() {\n originalConsole[methodName](...arguments);\n };\n }\n });\n }\n} else if (!global.console) {\n function stub() {}\n const log = global.print || stub;\n\n global.console = {\n debug: log,\n error: log,\n info: log,\n log: log,\n trace: log,\n warn: log,\n assert(expression, label) {\n if (!expression) {\n log('Assertion failed: ' + label);\n }\n },\n clear: stub,\n dir: stub,\n dirxml: stub,\n group: stub,\n groupCollapsed: stub,\n groupEnd: stub,\n profile: stub,\n profileEnd: stub,\n table: stub,\n };\n\n Object.defineProperty(console, '_isPolyfilled', {\n value: true,\n enumerable: false,\n });\n}\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 * @format\n * @flow strict\n * @polyfill\n */\n\nlet _inGuard = 0;\n\ntype ErrorHandler = (error: mixed, isFatal: boolean) => void;\ntype Fn = (...Args) => Return;\n\n/**\n * This is the error handler that is called when we encounter an exception\n * when loading a module. This will report any errors encountered before\n * ExceptionsManager is configured.\n */\nlet _globalHandler: ErrorHandler = function onError(\n e: mixed,\n isFatal: boolean,\n) {\n throw e;\n};\n\n/**\n * The particular require runtime that we are using looks for a global\n * `ErrorUtils` object and if it exists, then it requires modules with the\n * error handler specified via ErrorUtils.setGlobalHandler by calling the\n * require function with applyWithGuard. Since the require module is loaded\n * before any of the modules, this ErrorUtils must be defined (and the handler\n * set) globally before requiring anything.\n */\nconst ErrorUtils = {\n setGlobalHandler(fun: ErrorHandler): void {\n _globalHandler = fun;\n },\n getGlobalHandler(): ErrorHandler {\n return _globalHandler;\n },\n reportError(error: mixed): void {\n _globalHandler && _globalHandler(error, false);\n },\n reportFatalError(error: mixed): void {\n // NOTE: This has an untyped call site in Metro.\n _globalHandler && _globalHandler(error, true);\n },\n applyWithGuard, TOut>(\n fun: Fn,\n context?: ?mixed,\n args?: ?TArgs,\n // Unused, but some code synced from www sets it to null.\n unused_onError?: null,\n // Some callers pass a name here, which we ignore.\n unused_name?: ?string,\n ): ?TOut {\n try {\n _inGuard++;\n /* $FlowFixMe[incompatible-call] : TODO T48204745 (1) apply(context,\n * null) is fine. (2) array -> rest array should work */\n /* $FlowFixMe[incompatible-type] : TODO T48204745 (1) apply(context,\n * null) is fine. (2) array -> rest array should work */\n return fun.apply(context, args);\n } catch (e) {\n ErrorUtils.reportError(e);\n } finally {\n _inGuard--;\n }\n return null;\n },\n applyWithGuardIfNeeded, TOut>(\n fun: Fn,\n context?: ?mixed,\n args?: ?TArgs,\n ): ?TOut {\n if (ErrorUtils.inGuard()) {\n /* $FlowFixMe[incompatible-call] : TODO T48204745 (1) apply(context,\n * null) is fine. (2) array -> rest array should work */\n /* $FlowFixMe[incompatible-type] : TODO T48204745 (1) apply(context,\n * null) is fine. (2) array -> rest array should work */\n return fun.apply(context, args);\n } else {\n ErrorUtils.applyWithGuard(fun, context, args);\n }\n return null;\n },\n inGuard(): boolean {\n return !!_inGuard;\n },\n guard, TOut>(\n fun: Fn,\n name?: ?string,\n context?: ?mixed,\n ): ?(...TArgs) => ?TOut {\n // TODO: (moti) T48204753 Make sure this warning is never hit and remove it - types\n // should be sufficient.\n if (typeof fun !== 'function') {\n console.warn('A function must be passed to ErrorUtils.guard, got ', fun);\n return null;\n }\n const guardName = name ?? fun.name ?? '';\n function guarded(...args: TArgs): ?TOut {\n return ErrorUtils.applyWithGuard(\n fun,\n context ?? this,\n args,\n null,\n guardName,\n );\n }\n\n return guarded;\n },\n};\n\nglobal.ErrorUtils = ErrorUtils;\n\nexport type ErrorUtilsT = typeof ErrorUtils;\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 * @format\n * @polyfill\n * @nolint\n */\n\n(function() {\n 'use strict';\n\n const hasOwnProperty = Object.prototype.hasOwnProperty;\n\n /**\n * Returns an array of the given object's own enumerable entries.\n * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/entries\n */\n if (typeof Object.entries !== 'function') {\n Object.entries = function(object) {\n // `null` and `undefined` values are not allowed.\n if (object == null) {\n throw new TypeError('Object.entries called on non-object');\n }\n\n const entries = [];\n for (const key in object) {\n if (hasOwnProperty.call(object, key)) {\n entries.push([key, object[key]]);\n }\n }\n return entries;\n };\n }\n\n /**\n * Returns an array of the given object's own enumerable entries.\n * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/values\n */\n if (typeof Object.values !== 'function') {\n Object.values = function(object) {\n // `null` and `undefined` values are not allowed.\n if (object == null) {\n throw new TypeError('Object.values called on non-object');\n }\n\n const values = [];\n for (const key in object) {\n if (hasOwnProperty.call(object, key)) {\n values.push(object[key]);\n }\n }\n return values;\n };\n }\n})();\n","/**\n * @format\n */\n\nimport 'react-native-gesture-handler';\nimport {AppRegistry} from 'react-native';\nimport App from './src/App';\nimport Config from './src/CONFIG';\nimport additionalAppSetup from './src/setup';\n\nAppRegistry.registerComponent(Config.APP_NAME, () => App);\nadditionalAppSetup();\n","import { initialize } from './init';\n\nexport { Directions } from './Directions';\nexport { State } from './State';\nexport { default as gestureHandlerRootHOC } from './gestureHandlerRootHOC';\nexport { default as GestureHandlerRootView } from './GestureHandlerRootView';\nexport type {\n // event types\n GestureEvent,\n HandlerStateChangeEvent,\n // event payloads types\n GestureEventPayload,\n HandlerStateChangeEventPayload,\n // pointer events\n GestureTouchEvent,\n TouchData,\n // new api event types\n GestureUpdateEvent,\n GestureStateChangeEvent,\n} from './handlers/gestureHandlerCommon';\nexport type { GestureType } from './handlers/gestures/gesture';\nexport type {\n TapGestureHandlerEventPayload,\n TapGestureHandlerProps,\n} from './handlers/TapGestureHandler';\nexport type {\n ForceTouchGestureHandlerEventPayload,\n ForceTouchGestureHandlerProps,\n} from './handlers/ForceTouchGestureHandler';\nexport type { ForceTouchGestureChangeEventPayload } from './handlers/gestures/forceTouchGesture';\nexport type {\n LongPressGestureHandlerEventPayload,\n LongPressGestureHandlerProps,\n} from './handlers/LongPressGestureHandler';\nexport type {\n PanGestureHandlerEventPayload,\n PanGestureHandlerProps,\n} from './handlers/PanGestureHandler';\nexport type { PanGestureChangeEventPayload } from './handlers/gestures/panGesture';\nexport type {\n PinchGestureHandlerEventPayload,\n PinchGestureHandlerProps,\n} from './handlers/PinchGestureHandler';\nexport type { PinchGestureChangeEventPayload } from './handlers/gestures/pinchGesture';\nexport type {\n RotationGestureHandlerEventPayload,\n RotationGestureHandlerProps,\n} from './handlers/RotationGestureHandler';\nexport type {\n FlingGestureHandlerEventPayload,\n FlingGestureHandlerProps,\n} from './handlers/FlingGestureHandler';\nexport { TapGestureHandler } from './handlers/TapGestureHandler';\nexport { ForceTouchGestureHandler } from './handlers/ForceTouchGestureHandler';\nexport { LongPressGestureHandler } from './handlers/LongPressGestureHandler';\nexport { PanGestureHandler } from './handlers/PanGestureHandler';\nexport { PinchGestureHandler } from './handlers/PinchGestureHandler';\nexport { RotationGestureHandler } from './handlers/RotationGestureHandler';\nexport { FlingGestureHandler } from './handlers/FlingGestureHandler';\nexport { default as createNativeWrapper } from './handlers/createNativeWrapper';\nexport type {\n NativeViewGestureHandlerPayload,\n NativeViewGestureHandlerProps,\n} from './handlers/NativeViewGestureHandler';\nexport { GestureDetector } from './handlers/gestures/GestureDetector';\nexport { GestureObjects as Gesture } from './handlers/gestures/gestureObjects';\nexport type { TapGestureType as TapGesture } from './handlers/gestures/tapGesture';\nexport type { PanGestureType as PanGesture } from './handlers/gestures/panGesture';\nexport type { FlingGestureType as FlingGesture } from './handlers/gestures/flingGesture';\nexport type { LongPressGestureType as LongPressGesture } from './handlers/gestures/longPressGesture';\nexport type { PinchGestureType as PinchGesture } from './handlers/gestures/pinchGesture';\nexport type { RotationGestureType as RotationGesture } from './handlers/gestures/rotationGesture';\nexport type { ForceTouchGestureType as ForceTouchGesture } from './handlers/gestures/forceTouchGesture';\nexport type { NativeGestureType as NativeGesture } from './handlers/gestures/nativeGesture';\nexport type { ManualGestureType as ManualGesture } from './handlers/gestures/manualGesture';\nexport type {\n ComposedGestureType as ComposedGesture,\n RaceGestureType as RaceGesture,\n SimultaneousGestureType as SimultaneousGesture,\n ExclusiveGestureType as ExclusiveGesture,\n} from './handlers/gestures/gestureComposition';\nexport type { GestureStateManagerType as GestureStateManager } from './handlers/gestures/gestureStateManager';\nexport { NativeViewGestureHandler } from './handlers/NativeViewGestureHandler';\nexport type {\n RawButtonProps,\n BaseButtonProps,\n RectButtonProps,\n BorderlessButtonProps,\n} from './components/GestureButtons';\nexport {\n RawButton,\n BaseButton,\n RectButton,\n BorderlessButton,\n} from './components/GestureButtons';\nexport {\n TouchableHighlight,\n TouchableNativeFeedback,\n TouchableOpacity,\n TouchableWithoutFeedback,\n} from './components/touchables';\nexport {\n ScrollView,\n Switch,\n TextInput,\n DrawerLayoutAndroid,\n FlatList,\n RefreshControl,\n} from './components/GestureComponents';\nexport type {\n //events\n GestureHandlerGestureEvent,\n GestureHandlerStateChangeEvent,\n //event payloads\n GestureHandlerGestureEventNativeEvent,\n GestureHandlerStateChangeNativeEvent,\n NativeViewGestureHandlerGestureEvent,\n NativeViewGestureHandlerStateChangeEvent,\n TapGestureHandlerGestureEvent,\n TapGestureHandlerStateChangeEvent,\n ForceTouchGestureHandlerGestureEvent,\n ForceTouchGestureHandlerStateChangeEvent,\n LongPressGestureHandlerGestureEvent,\n LongPressGestureHandlerStateChangeEvent,\n PanGestureHandlerGestureEvent,\n PanGestureHandlerStateChangeEvent,\n PinchGestureHandlerGestureEvent,\n PinchGestureHandlerStateChangeEvent,\n RotationGestureHandlerGestureEvent,\n RotationGestureHandlerStateChangeEvent,\n FlingGestureHandlerGestureEvent,\n FlingGestureHandlerStateChangeEvent,\n // handlers props\n NativeViewGestureHandlerProperties,\n TapGestureHandlerProperties,\n LongPressGestureHandlerProperties,\n PanGestureHandlerProperties,\n PinchGestureHandlerProperties,\n RotationGestureHandlerProperties,\n FlingGestureHandlerProperties,\n ForceTouchGestureHandlerProperties,\n // buttons props\n RawButtonProperties,\n BaseButtonProperties,\n RectButtonProperties,\n BorderlessButtonProperties,\n} from './handlers/gestureHandlerTypesCompat';\n\nexport { default as Swipeable } from './components/Swipeable';\nexport type {\n DrawerLayoutProps,\n DrawerPosition,\n DrawerState,\n DrawerType,\n DrawerLockMode,\n DrawerKeyboardDismissMode,\n} from './components/DrawerLayout';\nexport { default as DrawerLayout } from './components/DrawerLayout';\n\nexport { enableExperimentalWebImplementation } from './EnableExperimentalWebImplementation';\n\ninitialize();\n","import * as React from 'react';\nimport {\n Animated,\n Platform,\n processColor,\n StyleSheet,\n StyleProp,\n ViewStyle,\n} from 'react-native';\n\nimport createNativeWrapper from '../handlers/createNativeWrapper';\nimport GestureHandlerButton from './GestureHandlerButton';\nimport { State } from '../State';\n\nimport {\n GestureEvent,\n HandlerStateChangeEvent,\n} from '../handlers/gestureHandlerCommon';\nimport {\n NativeViewGestureHandlerPayload,\n NativeViewGestureHandlerProps,\n} from '../handlers/NativeViewGestureHandler';\n\nexport interface RawButtonProps extends NativeViewGestureHandlerProps {\n /**\n * Defines if more than one button could be pressed simultaneously. By default\n * set true.\n */\n exclusive?: boolean;\n // TODO: we should transform props in `createNativeWrapper`\n\n /**\n * Android only.\n *\n * Defines color of native ripple animation used since API level 21.\n */\n rippleColor?: any; // it was present in BaseButtonProps before but is used here in code\n\n /**\n * Android only.\n *\n * Defines radius of native ripple animation used since API level 21.\n */\n rippleRadius?: number | null;\n\n /**\n * Android only.\n *\n * Set this to true if you want the ripple animation to render outside the view bounds.\n */\n borderless?: boolean;\n\n /**\n * Android only.\n *\n * Defines whether the ripple animation should be drawn on the foreground of the view.\n */\n foreground?: boolean;\n\n /**\n * Android only.\n *\n * Set this to true if you don't want the system to play sound when the button is pressed.\n */\n touchSoundDisabled?: boolean;\n}\n\nexport interface BaseButtonProps extends RawButtonProps {\n /**\n * Called when the button gets pressed (analogous to `onPress` in\n * `TouchableHighlight` from RN core).\n */\n onPress?: (pointerInside: boolean) => void;\n\n /**\n * Called when the button gets pressed and is held for `delayLongPress`\n * milliseconds.\n */\n onLongPress?: () => void;\n\n /**\n * Called when button changes from inactive to active and vice versa. It\n * passes active state as a boolean variable as a first parameter for that\n * method.\n */\n onActiveStateChange?: (active: boolean) => void;\n style?: StyleProp;\n testID?: string;\n\n /**\n * Delay, in milliseconds, after which the `onLongPress` callback gets called.\n * Defaults to 600.\n */\n delayLongPress?: number;\n}\n\nexport interface RectButtonProps extends BaseButtonProps {\n /**\n * Background color that will be dimmed when button is in active state.\n */\n underlayColor?: string;\n\n /**\n * iOS only.\n *\n * Opacity applied to the underlay when button is in active state.\n */\n activeOpacity?: number;\n}\n\nexport interface BorderlessButtonProps extends BaseButtonProps {\n /**\n * iOS only.\n *\n * Opacity applied to the button when it is in an active state.\n */\n activeOpacity?: number;\n}\n\nexport const RawButton = createNativeWrapper(GestureHandlerButton, {\n shouldCancelWhenOutside: false,\n shouldActivateOnStart: false,\n});\n\nexport class BaseButton extends React.Component {\n static defaultProps = {\n delayLongPress: 600,\n };\n\n private lastActive: boolean;\n private longPressTimeout: ReturnType | undefined;\n private longPressDetected: boolean;\n\n constructor(props: BaseButtonProps) {\n super(props);\n this.lastActive = false;\n this.longPressDetected = false;\n }\n\n private handleEvent = ({\n nativeEvent,\n }: HandlerStateChangeEvent) => {\n const { state, oldState, pointerInside } = nativeEvent;\n const active = pointerInside && state === State.ACTIVE;\n\n if (active !== this.lastActive && this.props.onActiveStateChange) {\n this.props.onActiveStateChange(active);\n }\n\n if (\n !this.longPressDetected &&\n oldState === State.ACTIVE &&\n state !== State.CANCELLED &&\n this.lastActive &&\n this.props.onPress\n ) {\n this.props.onPress(active);\n }\n\n if (\n !this.lastActive &&\n // NativeViewGestureHandler sends different events based on platform\n state === (Platform.OS !== 'android' ? State.ACTIVE : State.BEGAN) &&\n pointerInside\n ) {\n this.longPressDetected = false;\n if (this.props.onLongPress) {\n this.longPressTimeout = setTimeout(\n this.onLongPress,\n this.props.delayLongPress\n );\n }\n } else if (\n // cancel longpress timeout if it's set and the finger moved out of the view\n state === State.ACTIVE &&\n !pointerInside &&\n this.longPressTimeout !== undefined\n ) {\n clearTimeout(this.longPressTimeout);\n this.longPressTimeout = undefined;\n } else if (\n // cancel longpress timeout if it's set and the gesture has finished\n this.longPressTimeout !== undefined &&\n (state === State.END ||\n state === State.CANCELLED ||\n state === State.FAILED)\n ) {\n clearTimeout(this.longPressTimeout);\n this.longPressTimeout = undefined;\n }\n\n this.lastActive = active;\n };\n\n private onLongPress = () => {\n this.longPressDetected = true;\n this.props.onLongPress?.();\n };\n\n // Normally, the parent would execute it's handler first, then forward the\n // event to listeners. However, here our handler is virtually only forwarding\n // events to listeners, so we reverse the order to keep the proper order of\n // the callbacks (from \"raw\" ones to \"processed\").\n private onHandlerStateChange = (\n e: HandlerStateChangeEvent\n ) => {\n this.props.onHandlerStateChange?.(e);\n this.handleEvent(e);\n };\n\n private onGestureEvent = (\n e: GestureEvent\n ) => {\n this.props.onGestureEvent?.(e);\n this.handleEvent(\n e as HandlerStateChangeEvent\n ); // TODO: maybe it is not correct\n };\n\n render() {\n const { rippleColor, ...rest } = this.props;\n\n return (\n \n );\n }\n}\n\nconst AnimatedBaseButton = Animated.createAnimatedComponent(BaseButton);\n\nconst btnStyles = StyleSheet.create({\n underlay: {\n position: 'absolute',\n left: 0,\n right: 0,\n bottom: 0,\n top: 0,\n },\n});\n\nexport class RectButton extends React.Component {\n static defaultProps = {\n activeOpacity: 0.105,\n underlayColor: 'black',\n };\n\n private opacity: Animated.Value;\n\n constructor(props: RectButtonProps) {\n super(props);\n this.opacity = new Animated.Value(0);\n }\n\n private onActiveStateChange = (active: boolean) => {\n if (Platform.OS !== 'android') {\n this.opacity.setValue(active ? this.props.activeOpacity! : 0);\n }\n\n this.props.onActiveStateChange?.(active);\n };\n\n render() {\n const { children, style, ...rest } = this.props;\n\n const resolvedStyle = StyleSheet.flatten(style ?? {});\n\n return (\n \n \n {children}\n \n );\n }\n}\n\nexport class BorderlessButton extends React.Component {\n static defaultProps = {\n activeOpacity: 0.3,\n borderless: true,\n };\n\n private opacity: Animated.Value;\n\n constructor(props: BorderlessButtonProps) {\n super(props);\n this.opacity = new Animated.Value(1);\n }\n\n private onActiveStateChange = (active: boolean) => {\n if (Platform.OS !== 'android') {\n this.opacity.setValue(active ? this.props.activeOpacity! : 1);\n }\n\n this.props.onActiveStateChange?.(active);\n };\n\n render() {\n const { children, style, ...rest } = this.props;\n\n return (\n \n {children}\n \n );\n }\n}\n\nexport { default as PureNativeButton } from './GestureHandlerButton';\n","function _interopRequireDefault(obj) {\n return obj && obj.__esModule ? obj : {\n \"default\": obj\n };\n}\n\nmodule.exports = _interopRequireDefault, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var objectWithoutPropertiesLoose = require(\"./objectWithoutPropertiesLoose.js\");\n\nfunction _objectWithoutProperties(source, excluded) {\n if (source == null) return {};\n var target = objectWithoutPropertiesLoose(source, excluded);\n var key, i;\n\n if (Object.getOwnPropertySymbols) {\n var sourceSymbolKeys = Object.getOwnPropertySymbols(source);\n\n for (i = 0; i < sourceSymbolKeys.length; i++) {\n key = sourceSymbolKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;\n target[key] = source[key];\n }\n }\n\n return target;\n}\n\nmodule.exports = _objectWithoutProperties, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n\n for (i = 0; i < sourceKeys.length; i++) {\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n\n return target;\n}\n\nmodule.exports = _objectWithoutPropertiesLoose, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}\n\nmodule.exports = _classCallCheck, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n}\n\nfunction _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n Object.defineProperty(Constructor, \"prototype\", {\n writable: false\n });\n return Constructor;\n}\n\nmodule.exports = _createClass, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var setPrototypeOf = require(\"./setPrototypeOf.js\");\n\nfunction _inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n writable: true,\n configurable: true\n }\n });\n Object.defineProperty(subClass, \"prototype\", {\n writable: false\n });\n if (superClass) setPrototypeOf(subClass, superClass);\n}\n\nmodule.exports = _inherits, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _setPrototypeOf(o, p) {\n module.exports = _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n return _setPrototypeOf(o, p);\n}\n\nmodule.exports = _setPrototypeOf, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var _typeof = require(\"./typeof.js\")[\"default\"];\n\nvar assertThisInitialized = require(\"./assertThisInitialized.js\");\n\nfunction _possibleConstructorReturn(self, call) {\n if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) {\n return call;\n } else if (call !== void 0) {\n throw new TypeError(\"Derived constructors may only return object or undefined\");\n }\n\n return assertThisInitialized(self);\n}\n\nmodule.exports = _possibleConstructorReturn, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _typeof(obj) {\n \"@babel/helpers - typeof\";\n\n return (module.exports = _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) {\n return typeof obj;\n } : function (obj) {\n return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports), _typeof(obj);\n}\n\nmodule.exports = _typeof, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n\n return self;\n}\n\nmodule.exports = _assertThisInitialized, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _getPrototypeOf(o) {\n module.exports = _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) {\n return o.__proto__ || Object.getPrototypeOf(o);\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n return _getPrototypeOf(o);\n}\n\nmodule.exports = _getPrototypeOf, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react.production.min.js');\n} else {\n module.exports = require('./cjs/react.development.js');\n}\n","/**\n * @license React\n * react.production.min.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'use strict';var l=Symbol.for(\"react.element\"),n=Symbol.for(\"react.portal\"),p=Symbol.for(\"react.fragment\"),q=Symbol.for(\"react.strict_mode\"),r=Symbol.for(\"react.profiler\"),t=Symbol.for(\"react.provider\"),u=Symbol.for(\"react.context\"),v=Symbol.for(\"react.forward_ref\"),w=Symbol.for(\"react.suspense\"),x=Symbol.for(\"react.memo\"),y=Symbol.for(\"react.lazy\"),z=Symbol.iterator;function A(a){if(null===a||\"object\"!==typeof a)return null;a=z&&a[z]||a[\"@@iterator\"];return\"function\"===typeof a?a:null}\nvar B={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},C=Object.assign,D={};function E(a,b,e){this.props=a;this.context=b;this.refs=D;this.updater=e||B}E.prototype.isReactComponent={};\nE.prototype.setState=function(a,b){if(\"object\"!==typeof a&&\"function\"!==typeof a&&null!=a)throw Error(\"setState(...): takes an object of state variables to update or a function which returns an object of state variables.\");this.updater.enqueueSetState(this,a,b,\"setState\")};E.prototype.forceUpdate=function(a){this.updater.enqueueForceUpdate(this,a,\"forceUpdate\")};function F(){}F.prototype=E.prototype;function G(a,b,e){this.props=a;this.context=b;this.refs=D;this.updater=e||B}var H=G.prototype=new F;\nH.constructor=G;C(H,E.prototype);H.isPureReactComponent=!0;var I=Array.isArray,J=Object.prototype.hasOwnProperty,K={current:null},L={key:!0,ref:!0,__self:!0,__source:!0};\nfunction M(a,b,e){var d,c={},k=null,h=null;if(null!=b)for(d in void 0!==b.ref&&(h=b.ref),void 0!==b.key&&(k=\"\"+b.key),b)J.call(b,d)&&!L.hasOwnProperty(d)&&(c[d]=b[d]);var g=arguments.length-2;if(1===g)c.children=e;else if(1 = _HostComponentInternal;\n\nconst invariant = require('invariant');\nconst warnOnce = require('./Libraries/Utilities/warnOnce');\n\nmodule.exports = {\n // Components\n get AccessibilityInfo(): AccessibilityInfo {\n return require('./Libraries/Components/AccessibilityInfo/AccessibilityInfo')\n .default;\n },\n get ActivityIndicator(): ActivityIndicator {\n return require('./Libraries/Components/ActivityIndicator/ActivityIndicator');\n },\n get Button(): Button {\n return require('./Libraries/Components/Button');\n },\n // $FlowFixMe[value-as-type]\n get DatePickerIOS(): DatePickerIOS {\n warnOnce(\n 'DatePickerIOS-merged',\n 'DatePickerIOS has been merged with DatePickerAndroid and will be removed in a future release. ' +\n \"It can now be installed and imported from '@react-native-community/datetimepicker' instead of 'react-native'. \" +\n 'See https://github.com/react-native-datetimepicker/datetimepicker',\n );\n return require('./Libraries/Components/DatePicker/DatePickerIOS');\n },\n // $FlowFixMe[value-as-type]\n get DrawerLayoutAndroid(): DrawerLayoutAndroid {\n return require('./Libraries/Components/DrawerAndroid/DrawerLayoutAndroid');\n },\n get FlatList(): FlatList {\n return require('./Libraries/Lists/FlatList');\n },\n get Image(): Image {\n return require('./Libraries/Image/Image');\n },\n get ImageBackground(): ImageBackground {\n return require('./Libraries/Image/ImageBackground');\n },\n get InputAccessoryView(): InputAccessoryView {\n return require('./Libraries/Components/TextInput/InputAccessoryView');\n },\n get KeyboardAvoidingView(): KeyboardAvoidingView {\n return require('./Libraries/Components/Keyboard/KeyboardAvoidingView')\n .default;\n },\n get Modal(): Modal {\n return require('./Libraries/Modal/Modal');\n },\n get Pressable(): Pressable {\n return require('./Libraries/Components/Pressable/Pressable').default;\n },\n // $FlowFixMe[value-as-type]\n get ProgressBarAndroid(): ProgressBarAndroid {\n warnOnce(\n 'progress-bar-android-moved',\n 'ProgressBarAndroid has been extracted from react-native core and will be removed in a future release. ' +\n \"It can now be installed and imported from '@react-native-community/progress-bar-android' instead of 'react-native'. \" +\n 'See https://github.com/react-native-progress-view/progress-bar-android',\n );\n return require('./Libraries/Components/ProgressBarAndroid/ProgressBarAndroid');\n },\n // $FlowFixMe[value-as-type]\n get ProgressViewIOS(): ProgressViewIOS {\n warnOnce(\n 'progress-view-ios-moved',\n 'ProgressViewIOS has been extracted from react-native core and will be removed in a future release. ' +\n \"It can now be installed and imported from '@react-native-community/progress-view' instead of 'react-native'. \" +\n 'See https://github.com/react-native-progress-view/progress-view',\n );\n return require('./Libraries/Components/ProgressViewIOS/ProgressViewIOS');\n },\n get RefreshControl(): RefreshControl {\n return require('./Libraries/Components/RefreshControl/RefreshControl');\n },\n get SafeAreaView(): SafeAreaView {\n return require('./Libraries/Components/SafeAreaView/SafeAreaView').default;\n },\n get ScrollView(): ScrollView {\n return require('./Libraries/Components/ScrollView/ScrollView');\n },\n get SectionList(): SectionList {\n return require('./Libraries/Lists/SectionList').default;\n },\n get Slider(): Slider {\n warnOnce(\n 'slider-moved',\n 'Slider has been extracted from react-native core and will be removed in a future release. ' +\n \"It can now be installed and imported from '@react-native-community/slider' instead of 'react-native'. \" +\n 'See https://github.com/callstack/react-native-slider',\n );\n return require('./Libraries/Components/Slider/Slider');\n },\n get StatusBar(): StatusBar {\n return require('./Libraries/Components/StatusBar/StatusBar');\n },\n get Switch(): Switch {\n return require('./Libraries/Components/Switch/Switch').default;\n },\n get Text(): Text {\n return require('./Libraries/Text/Text');\n },\n get TextInput(): TextInput {\n return require('./Libraries/Components/TextInput/TextInput');\n },\n get Touchable(): Touchable {\n return require('./Libraries/Components/Touchable/Touchable');\n },\n get TouchableHighlight(): TouchableHighlight {\n return require('./Libraries/Components/Touchable/TouchableHighlight');\n },\n get TouchableNativeFeedback(): TouchableNativeFeedback {\n return require('./Libraries/Components/Touchable/TouchableNativeFeedback');\n },\n get TouchableOpacity(): TouchableOpacity {\n return require('./Libraries/Components/Touchable/TouchableOpacity');\n },\n get TouchableWithoutFeedback(): TouchableWithoutFeedback {\n return require('./Libraries/Components/Touchable/TouchableWithoutFeedback');\n },\n get View(): View {\n return require('./Libraries/Components/View/View');\n },\n get VirtualizedList(): VirtualizedList {\n return require('./Libraries/Lists/VirtualizedList').default;\n },\n get VirtualizedSectionList(): VirtualizedSectionList {\n return require('./Libraries/Lists/VirtualizedSectionList');\n },\n\n // APIs\n get ActionSheetIOS(): ActionSheetIOS {\n return require('./Libraries/ActionSheetIOS/ActionSheetIOS');\n },\n get Alert(): Alert {\n return require('./Libraries/Alert/Alert');\n },\n // Include any types exported in the Animated module together with its default export, so\n // you can references types such as Animated.Numeric\n get Animated(): {...$Diff, ...Animated} {\n // $FlowExpectedError[prop-missing]: we only return the default export, all other exports are types\n return require('./Libraries/Animated/Animated').default;\n },\n get Appearance(): Appearance {\n return require('./Libraries/Utilities/Appearance');\n },\n get AppRegistry(): AppRegistry {\n return require('./Libraries/ReactNative/AppRegistry');\n },\n get AppState(): AppState {\n return require('./Libraries/AppState/AppState');\n },\n get BackHandler(): BackHandler {\n return require('./Libraries/Utilities/BackHandler');\n },\n get Clipboard(): Clipboard {\n warnOnce(\n 'clipboard-moved',\n 'Clipboard has been extracted from react-native core and will be removed in a future release. ' +\n \"It can now be installed and imported from '@react-native-clipboard/clipboard' instead of 'react-native'. \" +\n 'See https://github.com/react-native-clipboard/clipboard',\n );\n return require('./Libraries/Components/Clipboard/Clipboard');\n },\n get DeviceInfo(): DeviceInfo {\n return require('./Libraries/Utilities/DeviceInfo');\n },\n get DevSettings(): DevSettings {\n return require('./Libraries/Utilities/DevSettings');\n },\n get Dimensions(): Dimensions {\n return require('./Libraries/Utilities/Dimensions');\n },\n get Easing(): Easing {\n return require('./Libraries/Animated/Easing').default;\n },\n get findNodeHandle(): $PropertyType {\n return require('./Libraries/ReactNative/RendererProxy').findNodeHandle;\n },\n get I18nManager(): I18nManager {\n return require('./Libraries/ReactNative/I18nManager');\n },\n get InteractionManager(): InteractionManager {\n return require('./Libraries/Interaction/InteractionManager');\n },\n get Keyboard(): Keyboard {\n return require('./Libraries/Components/Keyboard/Keyboard');\n },\n get LayoutAnimation(): LayoutAnimation {\n return require('./Libraries/LayoutAnimation/LayoutAnimation');\n },\n get Linking(): Linking {\n return require('./Libraries/Linking/Linking');\n },\n get LogBox(): LogBox {\n return require('./Libraries/LogBox/LogBox');\n },\n get NativeDialogManagerAndroid(): NativeDialogManagerAndroid {\n return require('./Libraries/NativeModules/specs/NativeDialogManagerAndroid')\n .default;\n },\n get NativeEventEmitter(): NativeEventEmitter {\n return require('./Libraries/EventEmitter/NativeEventEmitter').default;\n },\n get Networking(): Networking {\n return require('./Libraries/Network/RCTNetworking');\n },\n get PanResponder(): PanResponder {\n return require('./Libraries/Interaction/PanResponder');\n },\n get PermissionsAndroid(): PermissionsAndroid {\n return require('./Libraries/PermissionsAndroid/PermissionsAndroid');\n },\n get PixelRatio(): PixelRatio {\n return require('./Libraries/Utilities/PixelRatio');\n },\n get PushNotificationIOS(): PushNotificationIOS {\n warnOnce(\n 'pushNotificationIOS-moved',\n 'PushNotificationIOS has been extracted from react-native core and will be removed in a future release. ' +\n \"It can now be installed and imported from '@react-native-community/push-notification-ios' instead of 'react-native'. \" +\n 'See https://github.com/react-native-push-notification-ios/push-notification-ios',\n );\n return require('./Libraries/PushNotificationIOS/PushNotificationIOS');\n },\n get Settings(): Settings {\n return require('./Libraries/Settings/Settings');\n },\n get Share(): Share {\n return require('./Libraries/Share/Share');\n },\n get StyleSheet(): StyleSheet {\n return require('./Libraries/StyleSheet/StyleSheet');\n },\n get Systrace(): Systrace {\n return require('./Libraries/Performance/Systrace');\n },\n // $FlowFixMe[value-as-type]\n get ToastAndroid(): ToastAndroid {\n return require('./Libraries/Components/ToastAndroid/ToastAndroid');\n },\n get TurboModuleRegistry(): TurboModuleRegistry {\n return require('./Libraries/TurboModule/TurboModuleRegistry');\n },\n get UIManager(): UIManager {\n return require('./Libraries/ReactNative/UIManager');\n },\n get unstable_batchedUpdates(): $PropertyType<\n ReactNative,\n 'unstable_batchedUpdates',\n > {\n return require('./Libraries/ReactNative/RendererProxy')\n .unstable_batchedUpdates;\n },\n get useAnimatedValue(): useAnimatedValue {\n return require('./Libraries/Animated/useAnimatedValue').default;\n },\n get useColorScheme(): useColorScheme {\n return require('./Libraries/Utilities/useColorScheme').default;\n },\n get useWindowDimensions(): useWindowDimensions {\n return require('./Libraries/Utilities/useWindowDimensions').default;\n },\n get UTFSequence(): UTFSequence {\n return require('./Libraries/UTFSequence');\n },\n get Vibration(): Vibration {\n return require('./Libraries/Vibration/Vibration');\n },\n get YellowBox(): YellowBox {\n return require('./Libraries/YellowBox/YellowBoxDeprecated');\n },\n\n // Plugins\n get DeviceEventEmitter(): RCTDeviceEventEmitter {\n return require('./Libraries/EventEmitter/RCTDeviceEventEmitter').default;\n },\n get DynamicColorIOS(): DynamicColorIOS {\n return require('./Libraries/StyleSheet/PlatformColorValueTypesIOS')\n .DynamicColorIOS;\n },\n get NativeAppEventEmitter(): RCTNativeAppEventEmitter {\n return require('./Libraries/EventEmitter/RCTNativeAppEventEmitter');\n },\n get NativeModules(): NativeModules {\n return require('./Libraries/BatchedBridge/NativeModules');\n },\n get Platform(): Platform {\n return require('./Libraries/Utilities/Platform');\n },\n get PlatformColor(): PlatformColor {\n return require('./Libraries/StyleSheet/PlatformColorValueTypes')\n .PlatformColor;\n },\n get processColor(): processColor {\n return require('./Libraries/StyleSheet/processColor');\n },\n get requireNativeComponent(): (\n uiViewClassName: string,\n ) => HostComponent {\n return require('./Libraries/ReactNative/requireNativeComponent');\n },\n get RootTagContext(): RootTagContext {\n return require('./Libraries/ReactNative/RootTag').RootTagContext;\n },\n get unstable_enableLogBox(): () => void {\n return () =>\n console.warn(\n 'LogBox is enabled by default so there is no need to call unstable_enableLogBox() anymore. This is a no op and will be removed in the next version.',\n );\n },\n // Deprecated Prop Types\n get ColorPropType(): $FlowFixMe {\n console.error(\n 'ColorPropType will be removed from React Native, along with all ' +\n 'other PropTypes. We recommend that you migrate away from PropTypes ' +\n 'and switch to a type system like TypeScript. If you need to ' +\n 'continue using ColorPropType, migrate to the ' +\n \"'deprecated-react-native-prop-types' package.\",\n );\n return require('deprecated-react-native-prop-types').ColorPropType;\n },\n get EdgeInsetsPropType(): $FlowFixMe {\n console.error(\n 'EdgeInsetsPropType will be removed from React Native, along with all ' +\n 'other PropTypes. We recommend that you migrate away from PropTypes ' +\n 'and switch to a type system like TypeScript. If you need to ' +\n 'continue using EdgeInsetsPropType, migrate to the ' +\n \"'deprecated-react-native-prop-types' package.\",\n );\n return require('deprecated-react-native-prop-types').EdgeInsetsPropType;\n },\n get PointPropType(): $FlowFixMe {\n console.error(\n 'PointPropType will be removed from React Native, along with all ' +\n 'other PropTypes. We recommend that you migrate away from PropTypes ' +\n 'and switch to a type system like TypeScript. If you need to ' +\n 'continue using PointPropType, migrate to the ' +\n \"'deprecated-react-native-prop-types' package.\",\n );\n return require('deprecated-react-native-prop-types').PointPropType;\n },\n get ViewPropTypes(): $FlowFixMe {\n console.error(\n 'ViewPropTypes will be removed from React Native, along with all ' +\n 'other PropTypes. We recommend that you migrate away from PropTypes ' +\n 'and switch to a type system like TypeScript. If you need to ' +\n 'continue using ViewPropTypes, migrate to the ' +\n \"'deprecated-react-native-prop-types' package.\",\n );\n return require('deprecated-react-native-prop-types').ViewPropTypes;\n },\n};\n\nif (__DEV__) {\n /* $FlowFixMe[prop-missing] This is intentional: Flow will error when\n * attempting to access ART. */\n /* $FlowFixMe[invalid-export] This is intentional: Flow will error when\n * attempting to access ART. */\n Object.defineProperty(module.exports, 'ART', {\n configurable: true,\n get() {\n invariant(\n false,\n 'ART has been removed from React Native. ' +\n \"It can now be installed and imported from '@react-native-community/art' instead of 'react-native'. \" +\n 'See https://github.com/react-native-art/art',\n );\n },\n });\n\n /* $FlowFixMe[prop-missing] This is intentional: Flow will error when\n * attempting to access ListView. */\n /* $FlowFixMe[invalid-export] This is intentional: Flow will error when\n * attempting to access ListView. */\n Object.defineProperty(module.exports, 'ListView', {\n configurable: true,\n get() {\n invariant(\n false,\n 'ListView has been removed from React Native. ' +\n 'See https://fb.me/nolistview for more information or use ' +\n '`deprecated-react-native-listview`.',\n );\n },\n });\n\n /* $FlowFixMe[prop-missing] This is intentional: Flow will error when\n * attempting to access SwipeableListView. */\n /* $FlowFixMe[invalid-export] This is intentional: Flow will error when\n * attempting to access SwipeableListView. */\n Object.defineProperty(module.exports, 'SwipeableListView', {\n configurable: true,\n get() {\n invariant(\n false,\n 'SwipeableListView has been removed from React Native. ' +\n 'See https://fb.me/nolistview for more information or use ' +\n '`deprecated-react-native-swipeable-listview`.',\n );\n },\n });\n\n /* $FlowFixMe[prop-missing] This is intentional: Flow will error when\n * attempting to access WebView. */\n /* $FlowFixMe[invalid-export] This is intentional: Flow will error when\n * attempting to access WebView. */\n Object.defineProperty(module.exports, 'WebView', {\n configurable: true,\n get() {\n invariant(\n false,\n 'WebView has been removed from React Native. ' +\n \"It can now be installed and imported from 'react-native-webview' instead of 'react-native'. \" +\n 'See https://github.com/react-native-webview/react-native-webview',\n );\n },\n });\n\n /* $FlowFixMe[prop-missing] This is intentional: Flow will error when\n * attempting to access NetInfo. */\n /* $FlowFixMe[invalid-export] This is intentional: Flow will error when\n * attempting to access NetInfo. */\n Object.defineProperty(module.exports, 'NetInfo', {\n configurable: true,\n get() {\n invariant(\n false,\n 'NetInfo has been removed from React Native. ' +\n \"It can now be installed and imported from '@react-native-community/netinfo' instead of 'react-native'. \" +\n 'See https://github.com/react-native-netinfo/react-native-netinfo',\n );\n },\n });\n\n /* $FlowFixMe[prop-missing] This is intentional: Flow will error when\n * attempting to access CameraRoll. */\n /* $FlowFixMe[invalid-export] This is intentional: Flow will error when\n * attempting to access CameraRoll. */\n Object.defineProperty(module.exports, 'CameraRoll', {\n configurable: true,\n get() {\n invariant(\n false,\n 'CameraRoll has been removed from React Native. ' +\n \"It can now be installed and imported from '@react-native-community/cameraroll' instead of 'react-native'. \" +\n 'See https://github.com/react-native-cameraroll/react-native-cameraroll',\n );\n },\n });\n\n /* $FlowFixMe[prop-missing] This is intentional: Flow will error when\n * attempting to access ImageStore. */\n /* $FlowFixMe[invalid-export] This is intentional: Flow will error when\n * attempting to access ImageStore. */\n Object.defineProperty(module.exports, 'ImageStore', {\n configurable: true,\n get() {\n invariant(\n false,\n 'ImageStore has been removed from React Native. ' +\n 'To get a base64-encoded string from a local image use either of the following third-party libraries:' +\n \"* expo-file-system: `readAsStringAsync(filepath, 'base64')`\" +\n \"* react-native-fs: `readFile(filepath, 'base64')`\",\n );\n },\n });\n\n /* $FlowFixMe[prop-missing] This is intentional: Flow will error when\n * attempting to access ImageEditor. */\n /* $FlowFixMe[invalid-export] This is intentional: Flow will error when\n * attempting to access ImageEditor. */\n Object.defineProperty(module.exports, 'ImageEditor', {\n configurable: true,\n get() {\n invariant(\n false,\n 'ImageEditor has been removed from React Native. ' +\n \"It can now be installed and imported from '@react-native-community/image-editor' instead of 'react-native'. \" +\n 'See https://github.com/callstack/react-native-image-editor',\n );\n },\n });\n\n /* $FlowFixMe[prop-missing] This is intentional: Flow will error when\n * attempting to access TimePickerAndroid. */\n /* $FlowFixMe[invalid-export] This is intentional: Flow will error when\n * attempting to access TimePickerAndroid. */\n Object.defineProperty(module.exports, 'TimePickerAndroid', {\n configurable: true,\n get() {\n invariant(\n false,\n 'TimePickerAndroid has been removed from React Native. ' +\n \"It can now be installed and imported from '@react-native-community/datetimepicker' instead of 'react-native'. \" +\n 'See https://github.com/react-native-datetimepicker/datetimepicker',\n );\n },\n });\n\n /* $FlowFixMe[prop-missing] This is intentional: Flow will error when\n * attempting to access ToolbarAndroid. */\n /* $FlowFixMe[invalid-export] This is intentional: Flow will error when\n * attempting to access ToolbarAndroid. */\n Object.defineProperty(module.exports, 'ToolbarAndroid', {\n configurable: true,\n get() {\n invariant(\n false,\n 'ToolbarAndroid has been removed from React Native. ' +\n \"It can now be installed and imported from '@react-native-community/toolbar-android' instead of 'react-native'. \" +\n 'See https://github.com/react-native-toolbar-android/toolbar-android',\n );\n },\n });\n\n /* $FlowFixMe[prop-missing] This is intentional: Flow will error when\n * attempting to access ViewPagerAndroid. */\n /* $FlowFixMe[invalid-export] This is intentional: Flow will error when\n * attempting to access ViewPagerAndroid. */\n Object.defineProperty(module.exports, 'ViewPagerAndroid', {\n configurable: true,\n get() {\n invariant(\n false,\n 'ViewPagerAndroid has been removed from React Native. ' +\n \"It can now be installed and imported from 'react-native-pager-view' instead of 'react-native'. \" +\n 'See https://github.com/callstack/react-native-pager-view',\n );\n },\n });\n\n /* $FlowFixMe[prop-missing] This is intentional: Flow will error when\n * attempting to access CheckBox. */\n /* $FlowFixMe[invalid-export] This is intentional: Flow will error when\n * attempting to access CheckBox. */\n Object.defineProperty(module.exports, 'CheckBox', {\n configurable: true,\n get() {\n invariant(\n false,\n 'CheckBox has been removed from React Native. ' +\n \"It can now be installed and imported from '@react-native-community/checkbox' instead of 'react-native'. \" +\n 'See https://github.com/react-native-checkbox/react-native-checkbox',\n );\n },\n });\n\n /* $FlowFixMe[prop-missing] This is intentional: Flow will error when\n * attempting to access SegmentedControlIOS. */\n /* $FlowFixMe[invalid-export] This is intentional: Flow will error when\n * attempting to access SegmentedControlIOS. */\n Object.defineProperty(module.exports, 'SegmentedControlIOS', {\n configurable: true,\n get() {\n invariant(\n false,\n 'SegmentedControlIOS has been removed from React Native. ' +\n \"It can now be installed and imported from '@react-native-community/segmented-checkbox' instead of 'react-native'.\" +\n 'See https://github.com/react-native-segmented-control/segmented-control',\n );\n },\n });\n\n /* $FlowFixMe[prop-missing] This is intentional: Flow will error when\n * attempting to access StatusBarIOS. */\n /* $FlowFixMe[invalid-export] This is intentional: Flow will error when\n * attempting to access StatusBarIOS. */\n Object.defineProperty(module.exports, 'StatusBarIOS', {\n configurable: true,\n get() {\n invariant(\n false,\n 'StatusBarIOS has been removed from React Native. ' +\n 'Has been merged with StatusBar. ' +\n 'See https://reactnative.dev/docs/statusbar',\n );\n },\n });\n\n /* $FlowFixMe[prop-missing] This is intentional: Flow will error when\n * attempting to access PickerIOS. */\n /* $FlowFixMe[invalid-export] This is intentional: Flow will error when\n * attempting to access PickerIOS. */\n Object.defineProperty(module.exports, 'PickerIOS', {\n configurable: true,\n get() {\n invariant(\n false,\n 'PickerIOS has been removed from React Native. ' +\n \"It can now be installed and imported from '@react-native-picker/picker' instead of 'react-native'. \" +\n 'See https://github.com/react-native-picker/picker',\n );\n },\n });\n\n /* $FlowFixMe[prop-missing] This is intentional: Flow will error when\n * attempting to access Picker. */\n /* $FlowFixMe[invalid-export] This is intentional: Flow will error when\n * attempting to access Picker. */\n Object.defineProperty(module.exports, 'Picker', {\n configurable: true,\n get() {\n invariant(\n false,\n 'Picker has been removed from React Native. ' +\n \"It can now be installed and imported from '@react-native-picker/picker' instead of 'react-native'. \" +\n 'See https://github.com/react-native-picker/picker',\n );\n },\n });\n /* $FlowFixMe[prop-missing] This is intentional: Flow will error when\n * attempting to access DatePickerAndroid. */\n /* $FlowFixMe[invalid-export] This is intentional: Flow will error when\n * attempting to access DatePickerAndroid. */\n Object.defineProperty(module.exports, 'DatePickerAndroid', {\n configurable: true,\n get() {\n invariant(\n false,\n 'DatePickerAndroid has been removed from React Native. ' +\n \"It can now be installed and imported from '@react-native-community/datetimepicker' instead of 'react-native'. \" +\n 'See https://github.com/react-native-datetimepicker/datetimepicker',\n );\n },\n });\n /* $FlowFixMe[prop-missing] This is intentional: Flow will error when\n * attempting to access MaskedViewIOS. */\n /* $FlowFixMe[invalid-export] This is intentional: Flow will error when\n * attempting to access MaskedViewIOS. */\n Object.defineProperty(module.exports, 'MaskedViewIOS', {\n configurable: true,\n get() {\n invariant(\n false,\n 'MaskedViewIOS has been removed from React Native. ' +\n \"It can now be installed and imported from '@react-native-community/react-native-masked-view' instead of 'react-native'. \" +\n 'See https://github.com/react-native-masked-view/masked-view',\n );\n },\n });\n /* $FlowFixMe[prop-missing] This is intentional: Flow will error when\n * attempting to access AsyncStorage. */\n /* $FlowFixMe[invalid-export] This is intentional: Flow will error when\n * attempting to access AsyncStorage. */\n Object.defineProperty(module.exports, 'AsyncStorage', {\n configurable: true,\n get() {\n invariant(\n false,\n 'AsyncStorage has been removed from react-native core. ' +\n \"It can now be installed and imported from '@react-native-async-storage/async-storage' instead of 'react-native'. \" +\n 'See https://github.com/react-native-async-storage/async-storage',\n );\n },\n });\n /* $FlowFixMe[prop-missing] This is intentional: Flow will error when\n * attempting to access ImagePickerIOS. */\n /* $FlowFixMe[invalid-export] This is intentional: Flow will error when\n * attempting to access ImagePickerIOS. */\n Object.defineProperty(module.exports, 'ImagePickerIOS', {\n configurable: true,\n get() {\n invariant(\n false,\n 'ImagePickerIOS has been removed from React Native. ' +\n \"Please upgrade to use either '@react-native-community/react-native-image-picker' or 'expo-image-picker'. \" +\n \"If you cannot upgrade to a different library, please install the deprecated '@react-native-community/image-picker-ios' package. \" +\n 'See https://github.com/rnc-archive/react-native-image-picker-ios',\n );\n },\n });\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 * @flow strict-local\n * @format\n */\n\nimport type {HostComponent} from '../../Renderer/shims/ReactNativeTypes';\nimport type {EventSubscription} from '../../vendor/emitter/EventEmitter';\nimport type {AccessibilityInfoType} from './AccessibilityInfo.flow';\nimport type {ElementRef} from 'react';\n\nimport RCTDeviceEventEmitter from '../../EventEmitter/RCTDeviceEventEmitter';\nimport {sendAccessibilityEvent} from '../../ReactNative/RendererProxy';\nimport Platform from '../../Utilities/Platform';\nimport legacySendAccessibilityEvent from './legacySendAccessibilityEvent';\nimport NativeAccessibilityInfoAndroid from './NativeAccessibilityInfo';\nimport NativeAccessibilityManagerIOS from './NativeAccessibilityManager';\n\n// Events that are only supported on Android.\ntype AccessibilityEventDefinitionsAndroid = {\n accessibilityServiceChanged: [boolean],\n};\n\n// Events that are only supported on iOS.\ntype AccessibilityEventDefinitionsIOS = {\n announcementFinished: [{announcement: string, success: boolean}],\n boldTextChanged: [boolean],\n grayscaleChanged: [boolean],\n invertColorsChanged: [boolean],\n reduceTransparencyChanged: [boolean],\n};\n\ntype AccessibilityEventDefinitions = {\n ...AccessibilityEventDefinitionsAndroid,\n ...AccessibilityEventDefinitionsIOS,\n change: [boolean], // screenReaderChanged\n reduceMotionChanged: [boolean],\n screenReaderChanged: [boolean],\n};\n\ntype AccessibilityEventTypes = 'click' | 'focus';\n\n// Mapping of public event names to platform-specific event names.\nconst EventNames: Map<\n $Keys,\n string,\n> = Platform.OS === 'android'\n ? new Map([\n ['change', 'touchExplorationDidChange'],\n ['reduceMotionChanged', 'reduceMotionDidChange'],\n ['screenReaderChanged', 'touchExplorationDidChange'],\n ['accessibilityServiceChanged', 'accessibilityServiceDidChange'],\n ])\n : new Map([\n ['announcementFinished', 'announcementFinished'],\n ['boldTextChanged', 'boldTextChanged'],\n ['change', 'screenReaderChanged'],\n ['grayscaleChanged', 'grayscaleChanged'],\n ['invertColorsChanged', 'invertColorsChanged'],\n ['reduceMotionChanged', 'reduceMotionChanged'],\n ['reduceTransparencyChanged', 'reduceTransparencyChanged'],\n ['screenReaderChanged', 'screenReaderChanged'],\n ]);\n\n/**\n * Sometimes it's useful to know whether or not the device has a screen reader\n * that is currently active. The `AccessibilityInfo` API is designed for this\n * purpose. You can use it to query the current state of the screen reader as\n * well as to register to be notified when the state of the screen reader\n * changes.\n *\n * See https://reactnative.dev/docs/accessibilityinfo\n */\nconst AccessibilityInfo: AccessibilityInfoType = {\n /**\n * Query whether bold text is currently enabled.\n *\n * Returns a promise which resolves to a boolean.\n * The result is `true` when bold text is enabled and `false` otherwise.\n *\n * See https://reactnative.dev/docs/accessibilityinfo#isBoldTextEnabled\n */\n isBoldTextEnabled(): Promise {\n if (Platform.OS === 'android') {\n return Promise.resolve(false);\n } else {\n return new Promise((resolve, reject) => {\n if (NativeAccessibilityManagerIOS != null) {\n NativeAccessibilityManagerIOS.getCurrentBoldTextState(\n resolve,\n reject,\n );\n } else {\n reject(null);\n }\n });\n }\n },\n\n /**\n * Query whether grayscale is currently enabled.\n *\n * Returns a promise which resolves to a boolean.\n * The result is `true` when grayscale is enabled and `false` otherwise.\n *\n * See https://reactnative.dev/docs/accessibilityinfo#isGrayscaleEnabled\n */\n isGrayscaleEnabled(): Promise {\n if (Platform.OS === 'android') {\n return Promise.resolve(false);\n } else {\n return new Promise((resolve, reject) => {\n if (NativeAccessibilityManagerIOS != null) {\n NativeAccessibilityManagerIOS.getCurrentGrayscaleState(\n resolve,\n reject,\n );\n } else {\n reject(null);\n }\n });\n }\n },\n\n /**\n * Query whether inverted colors are currently enabled.\n *\n * Returns a promise which resolves to a boolean.\n * The result is `true` when invert color is enabled and `false` otherwise.\n *\n * See https://reactnative.dev/docs/accessibilityinfo#isInvertColorsEnabled\n */\n isInvertColorsEnabled(): Promise {\n if (Platform.OS === 'android') {\n return Promise.resolve(false);\n } else {\n return new Promise((resolve, reject) => {\n if (NativeAccessibilityManagerIOS != null) {\n NativeAccessibilityManagerIOS.getCurrentInvertColorsState(\n resolve,\n reject,\n );\n } else {\n reject(null);\n }\n });\n }\n },\n\n /**\n * Query whether reduced motion is currently enabled.\n *\n * Returns a promise which resolves to a boolean.\n * The result is `true` when a reduce motion is enabled and `false` otherwise.\n *\n * See https://reactnative.dev/docs/accessibilityinfo#isReduceMotionEnabled\n */\n isReduceMotionEnabled(): Promise {\n return new Promise((resolve, reject) => {\n if (Platform.OS === 'android') {\n if (NativeAccessibilityInfoAndroid != null) {\n NativeAccessibilityInfoAndroid.isReduceMotionEnabled(resolve);\n } else {\n reject(null);\n }\n } else {\n if (NativeAccessibilityManagerIOS != null) {\n NativeAccessibilityManagerIOS.getCurrentReduceMotionState(\n resolve,\n reject,\n );\n } else {\n reject(null);\n }\n }\n });\n },\n\n /**\n * Query whether reduce motion and prefer cross-fade transitions settings are currently enabled.\n *\n * Returns a promise which resolves to a boolean.\n * The result is `true` when prefer cross-fade transitions is enabled and `false` otherwise.\n *\n * See https://reactnative.dev/docs/accessibilityinfo#prefersCrossFadeTransitions\n */\n prefersCrossFadeTransitions(): Promise {\n return new Promise((resolve, reject) => {\n if (Platform.OS === 'android') {\n return Promise.resolve(false);\n } else {\n if (\n NativeAccessibilityManagerIOS?.getCurrentPrefersCrossFadeTransitionsState !=\n null\n ) {\n NativeAccessibilityManagerIOS.getCurrentPrefersCrossFadeTransitionsState(\n resolve,\n reject,\n );\n } else {\n reject(null);\n }\n }\n });\n },\n\n /**\n * Query whether reduced transparency is currently enabled.\n *\n * Returns a promise which resolves to a boolean.\n * The result is `true` when a reduce transparency is enabled and `false` otherwise.\n *\n * See https://reactnative.dev/docs/accessibilityinfo#isReduceTransparencyEnabled\n */\n isReduceTransparencyEnabled(): Promise {\n if (Platform.OS === 'android') {\n return Promise.resolve(false);\n } else {\n return new Promise((resolve, reject) => {\n if (NativeAccessibilityManagerIOS != null) {\n NativeAccessibilityManagerIOS.getCurrentReduceTransparencyState(\n resolve,\n reject,\n );\n } else {\n reject(null);\n }\n });\n }\n },\n\n /**\n * Query whether a screen reader is currently enabled.\n *\n * Returns a promise which resolves to a boolean.\n * The result is `true` when a screen reader is enabled and `false` otherwise.\n *\n * See https://reactnative.dev/docs/accessibilityinfo#isScreenReaderEnabled\n */\n isScreenReaderEnabled(): Promise {\n return new Promise((resolve, reject) => {\n if (Platform.OS === 'android') {\n if (NativeAccessibilityInfoAndroid != null) {\n NativeAccessibilityInfoAndroid.isTouchExplorationEnabled(resolve);\n } else {\n reject(null);\n }\n } else {\n if (NativeAccessibilityManagerIOS != null) {\n NativeAccessibilityManagerIOS.getCurrentVoiceOverState(\n resolve,\n reject,\n );\n } else {\n reject(null);\n }\n }\n });\n },\n\n /**\n * Query whether Accessibility Service is currently enabled.\n *\n * Returns a promise which resolves to a boolean.\n * The result is `true` when any service is enabled and `false` otherwise.\n *\n * @platform android\n *\n * See https://reactnative.dev/docs/accessibilityinfo/#isaccessibilityserviceenabled-android\n */\n isAccessibilityServiceEnabled(): Promise {\n return new Promise((resolve, reject) => {\n if (Platform.OS === 'android') {\n if (\n NativeAccessibilityInfoAndroid != null &&\n NativeAccessibilityInfoAndroid.isAccessibilityServiceEnabled != null\n ) {\n NativeAccessibilityInfoAndroid.isAccessibilityServiceEnabled(resolve);\n } else {\n reject(null);\n }\n } else {\n reject(null);\n }\n });\n },\n\n /**\n * Add an event handler. Supported events:\n *\n * - `reduceMotionChanged`: Fires when the state of the reduce motion toggle changes.\n * The argument to the event handler is a boolean. The boolean is `true` when a reduce\n * motion is enabled (or when \"Transition Animation Scale\" in \"Developer options\" is\n * \"Animation off\") and `false` otherwise.\n * - `screenReaderChanged`: Fires when the state of the screen reader changes. The argument\n * to the event handler is a boolean. The boolean is `true` when a screen\n * reader is enabled and `false` otherwise.\n *\n * These events are only supported on iOS:\n *\n * - `boldTextChanged`: iOS-only event. Fires when the state of the bold text toggle changes.\n * The argument to the event handler is a boolean. The boolean is `true` when a bold text\n * is enabled and `false` otherwise.\n * - `grayscaleChanged`: iOS-only event. Fires when the state of the gray scale toggle changes.\n * The argument to the event handler is a boolean. The boolean is `true` when a gray scale\n * is enabled and `false` otherwise.\n * - `invertColorsChanged`: iOS-only event. Fires when the state of the invert colors toggle\n * changes. The argument to the event handler is a boolean. The boolean is `true` when a invert\n * colors is enabled and `false` otherwise.\n * - `reduceTransparencyChanged`: iOS-only event. Fires when the state of the reduce transparency\n * toggle changes. The argument to the event handler is a boolean. The boolean is `true`\n * when a reduce transparency is enabled and `false` otherwise.\n * - `announcementFinished`: iOS-only event. Fires when the screen reader has\n * finished making an announcement. The argument to the event handler is a\n * dictionary with these keys:\n * - `announcement`: The string announced by the screen reader.\n * - `success`: A boolean indicating whether the announcement was\n * successfully made.\n *\n * See https://reactnative.dev/docs/accessibilityinfo#addeventlistener\n */\n addEventListener>(\n eventName: K,\n // $FlowIssue[incompatible-type] - Flow bug with unions and generics (T128099423)\n handler: (...$ElementType) => void,\n ): EventSubscription {\n const deviceEventName = EventNames.get(eventName);\n return deviceEventName == null\n ? {remove(): void {}}\n : // $FlowFixMe[incompatible-call]\n RCTDeviceEventEmitter.addListener(deviceEventName, handler);\n },\n\n /**\n * Set accessibility focus to a React component.\n *\n * See https://reactnative.dev/docs/accessibilityinfo#setaccessibilityfocus\n */\n setAccessibilityFocus(reactTag: number): void {\n legacySendAccessibilityEvent(reactTag, 'focus');\n },\n\n /**\n * Send a named accessibility event to a HostComponent.\n */\n sendAccessibilityEvent(\n handle: ElementRef>,\n eventType: AccessibilityEventTypes,\n ) {\n // iOS only supports 'focus' event types\n if (Platform.OS === 'ios' && eventType === 'click') {\n return;\n }\n // route through React renderer to distinguish between Fabric and non-Fabric handles\n sendAccessibilityEvent(handle, eventType);\n },\n\n /**\n * Post a string to be announced by the screen reader.\n *\n * See https://reactnative.dev/docs/accessibilityinfo#announceforaccessibility\n */\n announceForAccessibility(announcement: string): void {\n if (Platform.OS === 'android') {\n NativeAccessibilityInfoAndroid?.announceForAccessibility(announcement);\n } else {\n NativeAccessibilityManagerIOS?.announceForAccessibility(announcement);\n }\n },\n\n /**\n * Post a string to be announced by the screen reader.\n * - `announcement`: The string announced by the screen reader.\n * - `options`: An object that configures the reading options.\n * - `queue`: The announcement will be queued behind existing announcements. iOS only.\n */\n announceForAccessibilityWithOptions(\n announcement: string,\n options: {queue?: boolean},\n ): void {\n if (Platform.OS === 'android') {\n NativeAccessibilityInfoAndroid?.announceForAccessibility(announcement);\n } else {\n if (NativeAccessibilityManagerIOS?.announceForAccessibilityWithOptions) {\n NativeAccessibilityManagerIOS?.announceForAccessibilityWithOptions(\n announcement,\n options,\n );\n } else {\n NativeAccessibilityManagerIOS?.announceForAccessibility(announcement);\n }\n }\n },\n\n /**\n * Get the recommended timeout for changes to the UI needed by this user.\n *\n * See https://reactnative.dev/docs/accessibilityinfo#getrecommendedtimeoutmillis\n */\n getRecommendedTimeoutMillis(originalTimeout: number): Promise {\n if (Platform.OS === 'android') {\n return new Promise((resolve, reject) => {\n if (NativeAccessibilityInfoAndroid?.getRecommendedTimeoutMillis) {\n NativeAccessibilityInfoAndroid.getRecommendedTimeoutMillis(\n originalTimeout,\n resolve,\n );\n } else {\n resolve(originalTimeout);\n }\n });\n } else {\n return Promise.resolve(originalTimeout);\n }\n },\n};\n\nexport default AccessibilityInfo;\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 * @flow strict\n * @format\n */\n\nimport type {IEventEmitter} from '../vendor/emitter/EventEmitter';\n\nimport EventEmitter from '../vendor/emitter/EventEmitter';\n\n// FIXME: use typed events\ntype RCTDeviceEventDefinitions = $FlowFixMe;\n\n/**\n * Global EventEmitter used by the native platform to emit events to JavaScript.\n * Events are identified by globally unique event names.\n *\n * NativeModules that emit events should instead subclass `NativeEventEmitter`.\n */\nexport default (new EventEmitter(): IEventEmitter);\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 * @flow strict\n * @format\n */\n\nexport interface EventSubscription {\n remove(): void;\n}\n\nexport interface IEventEmitter {\n addListener>(\n eventType: TEvent,\n listener: (...args: $ElementType) => mixed,\n context?: mixed,\n ): EventSubscription;\n\n emit>(\n eventType: TEvent,\n ...args: $ElementType\n ): void;\n\n removeAllListeners>(eventType?: ?TEvent): void;\n\n listenerCount>(eventType: TEvent): number;\n}\n\ninterface Registration {\n +context: mixed;\n +listener: (...args: TArgs) => mixed;\n +remove: () => void;\n}\n\ntype Registry = $ObjMap<\n TEventToArgsMap,\n (TArgs) => Set>,\n>;\n\n/**\n * EventEmitter manages listeners and publishes events to them.\n *\n * EventEmitter accepts a single type parameter that defines the valid events\n * and associated listener argument(s).\n *\n * @example\n *\n * const emitter = new EventEmitter<{\n * success: [number, string],\n * error: [Error],\n * }>();\n *\n * emitter.on('success', (statusCode, responseText) => {...});\n * emitter.emit('success', 200, '...');\n *\n * emitter.on('error', error => {...});\n * emitter.emit('error', new Error('Resource not found'));\n *\n */\nexport default class EventEmitter\n implements IEventEmitter\n{\n _registry: Registry = {};\n\n /**\n * Registers a listener that is called when the supplied event is emitted.\n * Returns a subscription that has a `remove` method to undo registration.\n */\n addListener>(\n eventType: TEvent,\n listener: (...args: $ElementType) => mixed,\n context: mixed,\n ): EventSubscription {\n const registrations = allocate(this._registry, eventType);\n const registration: Registration<$ElementType> = {\n context,\n listener,\n remove(): void {\n registrations.delete(registration);\n },\n };\n registrations.add(registration);\n return registration;\n }\n\n /**\n * Emits the supplied event. Additional arguments supplied to `emit` will be\n * passed through to each of the registered listeners.\n *\n * If a listener modifies the listeners registered for the same event, those\n * changes will not be reflected in the current invocation of `emit`.\n */\n emit>(\n eventType: TEvent,\n ...args: $ElementType\n ): void {\n const registrations: ?Set<\n Registration<$ElementType>,\n > = this._registry[eventType];\n if (registrations != null) {\n for (const registration of [...registrations]) {\n registration.listener.apply(registration.context, args);\n }\n }\n }\n\n /**\n * Removes all registered listeners.\n */\n removeAllListeners>(\n eventType?: ?TEvent,\n ): void {\n if (eventType == null) {\n this._registry = {};\n } else {\n delete this._registry[eventType];\n }\n }\n\n /**\n * Returns the number of registered listeners for the supplied event.\n */\n listenerCount>(eventType: TEvent): number {\n const registrations: ?Set> = this._registry[eventType];\n return registrations == null ? 0 : registrations.size;\n }\n}\n\nfunction allocate<\n TEventToArgsMap: {...},\n TEvent: $Keys,\n TEventArgs: $ElementType,\n>(\n registry: Registry,\n eventType: TEvent,\n): Set> {\n let registrations: ?Set> = registry[eventType];\n if (registrations == null) {\n registrations = new Set();\n registry[eventType] = registrations;\n }\n return registrations;\n}\n","var arrayWithoutHoles = require(\"./arrayWithoutHoles.js\");\n\nvar iterableToArray = require(\"./iterableToArray.js\");\n\nvar unsupportedIterableToArray = require(\"./unsupportedIterableToArray.js\");\n\nvar nonIterableSpread = require(\"./nonIterableSpread.js\");\n\nfunction _toConsumableArray(arr) {\n return arrayWithoutHoles(arr) || iterableToArray(arr) || unsupportedIterableToArray(arr) || nonIterableSpread();\n}\n\nmodule.exports = _toConsumableArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var arrayLikeToArray = require(\"./arrayLikeToArray.js\");\n\nfunction _arrayWithoutHoles(arr) {\n if (Array.isArray(arr)) return arrayLikeToArray(arr);\n}\n\nmodule.exports = _arrayWithoutHoles, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n\n for (var i = 0, arr2 = new Array(len); i < len; i++) {\n arr2[i] = arr[i];\n }\n\n return arr2;\n}\n\nmodule.exports = _arrayLikeToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _iterableToArray(iter) {\n if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter);\n}\n\nmodule.exports = _iterableToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var arrayLikeToArray = require(\"./arrayLikeToArray.js\");\n\nfunction _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return arrayLikeToArray(o, minLen);\n}\n\nmodule.exports = _unsupportedIterableToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _nonIterableSpread() {\n throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\n\nmodule.exports = _nonIterableSpread, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","/**\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 * @format\n * @flow strict\n */\n\nimport NativePlatformConstantsIOS from './NativePlatformConstantsIOS';\n\nexport type PlatformSelectSpec = {\n default?: T,\n native?: T,\n ios?: T,\n ...\n};\n\nconst Platform = {\n __constants: null,\n OS: 'ios',\n // $FlowFixMe[unsafe-getters-setters]\n get Version(): string {\n // $FlowFixMe[object-this-reference]\n return this.constants.osVersion;\n },\n // $FlowFixMe[unsafe-getters-setters]\n get constants(): {|\n forceTouchAvailable: boolean,\n interfaceIdiom: string,\n isTesting: boolean,\n osVersion: string,\n reactNativeVersion: {|\n major: number,\n minor: number,\n patch: number,\n prerelease: ?number,\n |},\n systemName: string,\n |} {\n // $FlowFixMe[object-this-reference]\n if (this.__constants == null) {\n // $FlowFixMe[object-this-reference]\n this.__constants = NativePlatformConstantsIOS.getConstants();\n }\n // $FlowFixMe[object-this-reference]\n return this.__constants;\n },\n // $FlowFixMe[unsafe-getters-setters]\n get isPad(): boolean {\n // $FlowFixMe[object-this-reference]\n return this.constants.interfaceIdiom === 'pad';\n },\n // $FlowFixMe[unsafe-getters-setters]\n get isTV(): boolean {\n // $FlowFixMe[object-this-reference]\n return this.constants.interfaceIdiom === 'tv';\n },\n // $FlowFixMe[unsafe-getters-setters]\n get isTesting(): boolean {\n if (__DEV__) {\n // $FlowFixMe[object-this-reference]\n return this.constants.isTesting;\n }\n return false;\n },\n select: (spec: PlatformSelectSpec): T =>\n // $FlowFixMe[incompatible-return]\n 'ios' in spec ? spec.ios : 'native' in spec ? spec.native : spec.default,\n};\n\nmodule.exports = Platform;\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 * @flow strict\n * @format\n */\n\nimport type {TurboModule} from '../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../TurboModule/TurboModuleRegistry';\n\nexport interface Spec extends TurboModule {\n +getConstants: () => {|\n isTesting: boolean,\n reactNativeVersion: {|\n major: number,\n minor: number,\n patch: number,\n prerelease: ?number,\n |},\n forceTouchAvailable: boolean,\n osVersion: string,\n systemName: string,\n interfaceIdiom: string,\n |};\n}\n\nexport default (TurboModuleRegistry.getEnforcing(\n 'PlatformConstants',\n): Spec);\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 * @flow strict\n * @format\n */\n\nimport type {TurboModule} from './RCTExport';\n\nimport invariant from 'invariant';\n\nconst NativeModules = require('../BatchedBridge/NativeModules');\n\nconst turboModuleProxy = global.__turboModuleProxy;\n\nfunction requireModule(name: string): ?T {\n // Bridgeless mode requires TurboModules\n if (global.RN$Bridgeless !== true) {\n // Backward compatibility layer during migration.\n const legacyModule = NativeModules[name];\n if (legacyModule != null) {\n return ((legacyModule: $FlowFixMe): T);\n }\n }\n\n if (turboModuleProxy != null) {\n const module: ?T = turboModuleProxy(name);\n return module;\n }\n\n return null;\n}\n\nexport function get(name: string): ?T {\n return requireModule(name);\n}\n\nexport function getEnforcing(name: string): T {\n const module = requireModule(name);\n invariant(\n module != null,\n `TurboModuleRegistry.getEnforcing(...): '${name}' could not be found. ` +\n 'Verify that a module by this name is registered in the native binary.',\n );\n return module;\n}\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\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'use strict';\n\n/**\n * Use invariant() to assert state which your program assumes to be true.\n *\n * Provide sprintf-style format (only %s is supported) and arguments\n * to provide information about what broke and what you were\n * expecting.\n *\n * The invariant message will be stripped in production, but the invariant\n * will remain to ensure logic does not differ in production.\n */\n\nvar invariant = function(condition, format, a, b, c, d, e, f) {\n if (process.env.NODE_ENV !== 'production') {\n if (format === undefined) {\n throw new Error('invariant requires an error message argument');\n }\n }\n\n if (!condition) {\n var error;\n if (format === undefined) {\n error = new Error(\n 'Minified exception occurred; use the non-minified dev environment ' +\n 'for the full error message and additional helpful warnings.'\n );\n } else {\n var args = [a, b, c, d, e, f];\n var argIndex = 0;\n error = new Error(\n format.replace(/%s/g, function() { return args[argIndex++]; })\n );\n error.name = 'Invariant Violation';\n }\n\n error.framesToPop = 1; // we don't care about invariant's own frame\n throw error;\n }\n};\n\nmodule.exports = invariant;\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 * @format\n * @flow strict\n */\n\n'use strict';\n\nimport type {ExtendedError} from '../Core/ExtendedError';\n\nconst BatchedBridge = require('./BatchedBridge');\nconst invariant = require('invariant');\n\nexport type ModuleConfig = [\n string /* name */,\n ?{...} /* constants */,\n ?$ReadOnlyArray /* functions */,\n ?$ReadOnlyArray /* promise method IDs */,\n ?$ReadOnlyArray /* sync method IDs */,\n];\n\nexport type MethodType = 'async' | 'promise' | 'sync';\n\nfunction genModule(\n config: ?ModuleConfig,\n moduleID: number,\n): ?{\n name: string,\n module?: {...},\n ...\n} {\n if (!config) {\n return null;\n }\n\n const [moduleName, constants, methods, promiseMethods, syncMethods] = config;\n invariant(\n !moduleName.startsWith('RCT') && !moduleName.startsWith('RK'),\n \"Module name prefixes should've been stripped by the native side \" +\n \"but wasn't for \" +\n moduleName,\n );\n\n if (!constants && !methods) {\n // Module contents will be filled in lazily later\n return {name: moduleName};\n }\n\n const module: {[string]: mixed} = {};\n methods &&\n methods.forEach((methodName, methodID) => {\n const isPromise =\n (promiseMethods && arrayContains(promiseMethods, methodID)) || false;\n const isSync =\n (syncMethods && arrayContains(syncMethods, methodID)) || false;\n invariant(\n !isPromise || !isSync,\n 'Cannot have a method that is both async and a sync hook',\n );\n const methodType = isPromise ? 'promise' : isSync ? 'sync' : 'async';\n module[methodName] = genMethod(moduleID, methodID, methodType);\n });\n\n Object.assign(module, constants);\n\n if (module.getConstants == null) {\n module.getConstants = () => constants || Object.freeze({});\n } else {\n console.warn(\n `Unable to define method 'getConstants()' on NativeModule '${moduleName}'. NativeModule '${moduleName}' already has a constant or method called 'getConstants'. Please remove it.`,\n );\n }\n\n if (__DEV__) {\n BatchedBridge.createDebugLookup(moduleID, moduleName, methods);\n }\n\n return {name: moduleName, module};\n}\n\n// export this method as a global so we can call it from native\nglobal.__fbGenNativeModule = genModule;\n\nfunction loadModule(name: string, moduleID: number): ?{...} {\n invariant(\n global.nativeRequireModuleConfig,\n \"Can't lazily create module without nativeRequireModuleConfig\",\n );\n const config = global.nativeRequireModuleConfig(name);\n const info = genModule(config, moduleID);\n return info && info.module;\n}\n\nfunction genMethod(moduleID: number, methodID: number, type: MethodType) {\n let fn = null;\n if (type === 'promise') {\n fn = function promiseMethodWrapper(...args: Array) {\n // In case we reject, capture a useful stack trace here.\n /* $FlowFixMe[class-object-subtyping] added when improving typing for\n * this parameters */\n const enqueueingFrameError: ExtendedError = new Error();\n return new Promise((resolve, reject) => {\n BatchedBridge.enqueueNativeCall(\n moduleID,\n methodID,\n args,\n data => resolve(data),\n errorData =>\n reject(\n updateErrorWithErrorData(\n (errorData: $FlowFixMe),\n enqueueingFrameError,\n ),\n ),\n );\n });\n };\n } else {\n fn = function nonPromiseMethodWrapper(...args: Array) {\n const lastArg = args.length > 0 ? args[args.length - 1] : null;\n const secondLastArg = args.length > 1 ? args[args.length - 2] : null;\n const hasSuccessCallback = typeof lastArg === 'function';\n const hasErrorCallback = typeof secondLastArg === 'function';\n hasErrorCallback &&\n invariant(\n hasSuccessCallback,\n 'Cannot have a non-function arg after a function arg.',\n );\n // $FlowFixMe[incompatible-type]\n const onSuccess: ?(mixed) => void = hasSuccessCallback ? lastArg : null;\n // $FlowFixMe[incompatible-type]\n const onFail: ?(mixed) => void = hasErrorCallback ? secondLastArg : null;\n const callbackCount = hasSuccessCallback + hasErrorCallback;\n const newArgs = args.slice(0, args.length - callbackCount);\n if (type === 'sync') {\n return BatchedBridge.callNativeSyncHook(\n moduleID,\n methodID,\n newArgs,\n onFail,\n onSuccess,\n );\n } else {\n BatchedBridge.enqueueNativeCall(\n moduleID,\n methodID,\n newArgs,\n onFail,\n onSuccess,\n );\n }\n };\n }\n // $FlowFixMe[prop-missing]\n fn.type = type;\n return fn;\n}\n\nfunction arrayContains(array: $ReadOnlyArray, value: T): boolean {\n return array.indexOf(value) !== -1;\n}\n\nfunction updateErrorWithErrorData(\n errorData: {message: string, ...},\n error: ExtendedError,\n): ExtendedError {\n /* $FlowFixMe[class-object-subtyping] added when improving typing for this\n * parameters */\n return Object.assign(error, errorData || {});\n}\n\nlet NativeModules: {[moduleName: string]: $FlowFixMe, ...} = {};\nif (global.nativeModuleProxy) {\n NativeModules = global.nativeModuleProxy;\n} else if (!global.nativeExtensions) {\n const bridgeConfig = global.__fbBatchedBridgeConfig;\n invariant(\n bridgeConfig,\n '__fbBatchedBridgeConfig is not set, cannot invoke native modules',\n );\n\n const defineLazyObjectProperty = require('../Utilities/defineLazyObjectProperty');\n (bridgeConfig.remoteModuleConfig || []).forEach(\n (config: ModuleConfig, moduleID: number) => {\n // Initially this config will only contain the module name when running in JSC. The actual\n // configuration of the module will be lazily loaded.\n const info = genModule(config, moduleID);\n if (!info) {\n return;\n }\n\n if (info.module) {\n NativeModules[info.name] = info.module;\n }\n // If there's no module config, define a lazy getter\n else {\n defineLazyObjectProperty(NativeModules, info.name, {\n get: () => loadModule(info.name, moduleID),\n });\n }\n },\n );\n}\n\nmodule.exports = NativeModules;\n","var arrayWithHoles = require(\"./arrayWithHoles.js\");\n\nvar iterableToArrayLimit = require(\"./iterableToArrayLimit.js\");\n\nvar unsupportedIterableToArray = require(\"./unsupportedIterableToArray.js\");\n\nvar nonIterableRest = require(\"./nonIterableRest.js\");\n\nfunction _slicedToArray(arr, i) {\n return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || unsupportedIterableToArray(arr, i) || nonIterableRest();\n}\n\nmodule.exports = _slicedToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n}\n\nmodule.exports = _arrayWithHoles, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _iterableToArrayLimit(arr, i) {\n var _i = arr == null ? null : typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"];\n\n if (_i == null) return;\n var _arr = [];\n var _n = true;\n var _d = false;\n\n var _s, _e;\n\n try {\n for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) {\n _arr.push(_s.value);\n\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally {\n try {\n if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n } finally {\n if (_d) throw _e;\n }\n }\n\n return _arr;\n}\n\nmodule.exports = _iterableToArrayLimit, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\n\nmodule.exports = _nonIterableRest, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","/**\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 * @format\n * @flow strict\n */\n\n'use strict';\n\nconst MessageQueue = require('./MessageQueue');\n\nconst BatchedBridge: MessageQueue = new MessageQueue();\n\n// Wire up the batched bridge on the global object so that we can call into it.\n// Ideally, this would be the inverse relationship. I.e. the native environment\n// provides this global directly with its script embedded. Then this module\n// would export it. A possible fix would be to trim the dependencies in\n// MessageQueue to its minimal features and embed that in the native runtime.\n\nObject.defineProperty(global, '__fbBatchedBridge', {\n configurable: true,\n value: BatchedBridge,\n});\n\nmodule.exports = BatchedBridge;\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 * @flow strict\n * @format\n */\n\n'use strict';\n\nconst Systrace = require('../Performance/Systrace');\nconst deepFreezeAndThrowOnMutationInDev = require('../Utilities/deepFreezeAndThrowOnMutationInDev');\nconst stringifySafe = require('../Utilities/stringifySafe').default;\nconst warnOnce = require('../Utilities/warnOnce');\nconst ErrorUtils = require('../vendor/core/ErrorUtils');\nconst invariant = require('invariant');\n\nexport type SpyData = {\n type: number,\n module: ?string,\n method: string | number,\n args: mixed[],\n ...\n};\n\nconst TO_JS = 0;\nconst TO_NATIVE = 1;\n\nconst MODULE_IDS = 0;\nconst METHOD_IDS = 1;\nconst PARAMS = 2;\nconst MIN_TIME_BETWEEN_FLUSHES_MS = 5;\n\n// eslint-disable-next-line no-bitwise\nconst TRACE_TAG_REACT_APPS = 1 << 17;\n\nconst DEBUG_INFO_LIMIT = 32;\n\nclass MessageQueue {\n _lazyCallableModules: {[key: string]: (void) => {...}, ...};\n _queue: [number[], number[], mixed[], number];\n _successCallbacks: Map void>;\n _failureCallbacks: Map void>;\n _callID: number;\n _lastFlush: number;\n _eventLoopStartTime: number;\n _reactNativeMicrotasksCallback: ?() => void;\n\n _debugInfo: {[number]: [number, number], ...};\n _remoteModuleTable: {[number]: string, ...};\n _remoteMethodTable: {[number]: $ReadOnlyArray, ...};\n\n __spy: ?(data: SpyData) => void;\n\n constructor() {\n this._lazyCallableModules = {};\n this._queue = [[], [], [], 0];\n this._successCallbacks = new Map();\n this._failureCallbacks = new Map();\n this._callID = 0;\n this._lastFlush = 0;\n this._eventLoopStartTime = Date.now();\n this._reactNativeMicrotasksCallback = null;\n\n if (__DEV__) {\n this._debugInfo = {};\n this._remoteModuleTable = {};\n this._remoteMethodTable = {};\n }\n\n // $FlowFixMe[cannot-write]\n this.callFunctionReturnFlushedQueue =\n // $FlowFixMe[method-unbinding] added when improving typing for this parameters\n this.callFunctionReturnFlushedQueue.bind(this);\n // $FlowFixMe[cannot-write]\n // $FlowFixMe[method-unbinding] added when improving typing for this parameters\n this.flushedQueue = this.flushedQueue.bind(this);\n\n // $FlowFixMe[cannot-write]\n this.invokeCallbackAndReturnFlushedQueue =\n // $FlowFixMe[method-unbinding] added when improving typing for this parameters\n this.invokeCallbackAndReturnFlushedQueue.bind(this);\n }\n\n /**\n * Public APIs\n */\n\n static spy(spyOrToggle: boolean | ((data: SpyData) => void)) {\n if (spyOrToggle === true) {\n MessageQueue.prototype.__spy = info => {\n console.log(\n `${info.type === TO_JS ? 'N->JS' : 'JS->N'} : ` +\n `${info.module != null ? info.module + '.' : ''}${info.method}` +\n `(${JSON.stringify(info.args)})`,\n );\n };\n } else if (spyOrToggle === false) {\n MessageQueue.prototype.__spy = null;\n } else {\n MessageQueue.prototype.__spy = spyOrToggle;\n }\n }\n\n callFunctionReturnFlushedQueue(\n module: string,\n method: string,\n args: mixed[],\n ): null | [Array, Array, Array, number] {\n this.__guard(() => {\n this.__callFunction(module, method, args);\n });\n\n return this.flushedQueue();\n }\n\n invokeCallbackAndReturnFlushedQueue(\n cbID: number,\n args: mixed[],\n ): null | [Array, Array, Array, number] {\n this.__guard(() => {\n this.__invokeCallback(cbID, args);\n });\n\n return this.flushedQueue();\n }\n\n flushedQueue(): null | [Array, Array, Array, number] {\n this.__guard(() => {\n this.__callReactNativeMicrotasks();\n });\n\n const queue = this._queue;\n this._queue = [[], [], [], this._callID];\n return queue[0].length ? queue : null;\n }\n\n getEventLoopRunningTime(): number {\n return Date.now() - this._eventLoopStartTime;\n }\n\n registerCallableModule(name: string, module: {...}) {\n this._lazyCallableModules[name] = () => module;\n }\n\n registerLazyCallableModule(name: string, factory: void => interface {}) {\n let module: interface {};\n let getValue: ?(void) => interface {} = factory;\n this._lazyCallableModules[name] = () => {\n if (getValue) {\n module = getValue();\n getValue = null;\n }\n /* $FlowFixMe[class-object-subtyping] added when improving typing for\n * this parameters */\n return module;\n };\n }\n\n getCallableModule(name: string): {...} | null {\n const getValue = this._lazyCallableModules[name];\n return getValue ? getValue() : null;\n }\n\n callNativeSyncHook(\n moduleID: number,\n methodID: number,\n params: mixed[],\n onFail: ?(...mixed[]) => void,\n onSucc: ?(...mixed[]) => void,\n ): mixed {\n if (__DEV__) {\n invariant(\n global.nativeCallSyncHook,\n 'Calling synchronous methods on native ' +\n 'modules is not supported in Chrome.\\n\\n Consider providing alternative ' +\n 'methods to expose this method in debug mode, e.g. by exposing constants ' +\n 'ahead-of-time.',\n );\n }\n this.processCallbacks(moduleID, methodID, params, onFail, onSucc);\n return global.nativeCallSyncHook(moduleID, methodID, params);\n }\n\n processCallbacks(\n moduleID: number,\n methodID: number,\n params: mixed[],\n onFail: ?(...mixed[]) => void,\n onSucc: ?(...mixed[]) => void,\n ): void {\n if (onFail || onSucc) {\n if (__DEV__) {\n this._debugInfo[this._callID] = [moduleID, methodID];\n if (this._callID > DEBUG_INFO_LIMIT) {\n delete this._debugInfo[this._callID - DEBUG_INFO_LIMIT];\n }\n if (this._successCallbacks.size > 500) {\n const info: {[number]: {method: string, module: string}} = {};\n this._successCallbacks.forEach((_, callID) => {\n const debug = this._debugInfo[callID];\n const module = debug && this._remoteModuleTable[debug[0]];\n const method = debug && this._remoteMethodTable[debug[0]][debug[1]];\n info[callID] = {module, method};\n });\n warnOnce(\n 'excessive-number-of-pending-callbacks',\n `Please report: Excessive number of pending callbacks: ${\n this._successCallbacks.size\n }. Some pending callbacks that might have leaked by never being called from native code: ${stringifySafe(\n info,\n )}`,\n );\n }\n }\n // Encode callIDs into pairs of callback identifiers by shifting left and using the rightmost bit\n // to indicate fail (0) or success (1)\n // eslint-disable-next-line no-bitwise\n onFail && params.push(this._callID << 1);\n // eslint-disable-next-line no-bitwise\n onSucc && params.push((this._callID << 1) | 1);\n this._successCallbacks.set(this._callID, onSucc);\n this._failureCallbacks.set(this._callID, onFail);\n }\n if (__DEV__) {\n global.nativeTraceBeginAsyncFlow &&\n global.nativeTraceBeginAsyncFlow(\n TRACE_TAG_REACT_APPS,\n 'native',\n this._callID,\n );\n }\n this._callID++;\n }\n\n enqueueNativeCall(\n moduleID: number,\n methodID: number,\n params: mixed[],\n onFail: ?(...mixed[]) => void,\n onSucc: ?(...mixed[]) => void,\n ): void {\n this.processCallbacks(moduleID, methodID, params, onFail, onSucc);\n\n this._queue[MODULE_IDS].push(moduleID);\n this._queue[METHOD_IDS].push(methodID);\n\n if (__DEV__) {\n // Validate that parameters passed over the bridge are\n // folly-convertible. As a special case, if a prop value is a\n // function it is permitted here, and special-cased in the\n // conversion.\n const isValidArgument = (val: mixed): boolean => {\n switch (typeof val) {\n case 'undefined':\n case 'boolean':\n case 'string':\n return true;\n case 'number':\n return isFinite(val);\n case 'object':\n if (val == null) {\n return true;\n }\n\n if (Array.isArray(val)) {\n return val.every(isValidArgument);\n }\n\n for (const k in val) {\n if (typeof val[k] !== 'function' && !isValidArgument(val[k])) {\n return false;\n }\n }\n\n return true;\n case 'function':\n return false;\n default:\n return false;\n }\n };\n\n // Replacement allows normally non-JSON-convertible values to be\n // seen. There is ambiguity with string values, but in context,\n // it should at least be a strong hint.\n const replacer = (key: string, val: $FlowFixMe) => {\n const t = typeof val;\n if (t === 'function') {\n return '<>';\n } else if (t === 'number' && !isFinite(val)) {\n return '<<' + val.toString() + '>>';\n } else {\n return val;\n }\n };\n\n // Note that JSON.stringify\n invariant(\n isValidArgument(params),\n '%s is not usable as a native method argument',\n JSON.stringify(params, replacer),\n );\n\n // The params object should not be mutated after being queued\n deepFreezeAndThrowOnMutationInDev(params);\n }\n this._queue[PARAMS].push(params);\n\n const now = Date.now();\n if (\n global.nativeFlushQueueImmediate &&\n now - this._lastFlush >= MIN_TIME_BETWEEN_FLUSHES_MS\n ) {\n const queue = this._queue;\n this._queue = [[], [], [], this._callID];\n this._lastFlush = now;\n global.nativeFlushQueueImmediate(queue);\n }\n Systrace.counterEvent('pending_js_to_native_queue', this._queue[0].length);\n if (__DEV__ && this.__spy && isFinite(moduleID)) {\n // $FlowFixMe[not-a-function]\n this.__spy({\n type: TO_NATIVE,\n module: this._remoteModuleTable[moduleID],\n method: this._remoteMethodTable[moduleID][methodID],\n args: params,\n });\n } else if (this.__spy) {\n this.__spy({\n type: TO_NATIVE,\n module: moduleID + '',\n method: methodID,\n args: params,\n });\n }\n }\n\n createDebugLookup(\n moduleID: number,\n name: string,\n methods: ?$ReadOnlyArray,\n ) {\n if (__DEV__) {\n this._remoteModuleTable[moduleID] = name;\n this._remoteMethodTable[moduleID] = methods || [];\n }\n }\n\n // For JSTimers to register its callback. Otherwise a circular dependency\n // between modules is introduced. Note that only one callback may be\n // registered at a time.\n setReactNativeMicrotasksCallback(fn: () => void) {\n this._reactNativeMicrotasksCallback = fn;\n }\n\n /**\n * Private methods\n */\n\n __guard(fn: () => void) {\n if (this.__shouldPauseOnThrow()) {\n fn();\n } else {\n try {\n fn();\n } catch (error) {\n ErrorUtils.reportFatalError(error);\n }\n }\n }\n\n // MessageQueue installs a global handler to catch all exceptions where JS users can register their own behavior\n // This handler makes all exceptions to be propagated from inside MessageQueue rather than by the VM at their origin\n // This makes stacktraces to be placed at MessageQueue rather than at where they were launched\n // The parameter DebuggerInternal.shouldPauseOnThrow is used to check before catching all exceptions and\n // can be configured by the VM or any Inspector\n __shouldPauseOnThrow(): boolean {\n return (\n // $FlowFixMe[cannot-resolve-name]\n typeof DebuggerInternal !== 'undefined' &&\n DebuggerInternal.shouldPauseOnThrow === true\n );\n }\n\n __callReactNativeMicrotasks() {\n Systrace.beginEvent('JSTimers.callReactNativeMicrotasks()');\n if (this._reactNativeMicrotasksCallback != null) {\n this._reactNativeMicrotasksCallback();\n }\n Systrace.endEvent();\n }\n\n __callFunction(module: string, method: string, args: mixed[]): void {\n this._lastFlush = Date.now();\n this._eventLoopStartTime = this._lastFlush;\n if (__DEV__ || this.__spy) {\n Systrace.beginEvent(`${module}.${method}(${stringifySafe(args)})`);\n } else {\n Systrace.beginEvent(`${module}.${method}(...)`);\n }\n if (this.__spy) {\n this.__spy({type: TO_JS, module, method, args});\n }\n const moduleMethods = this.getCallableModule(module);\n if (!moduleMethods) {\n const callableModuleNames = Object.keys(this._lazyCallableModules);\n const n = callableModuleNames.length;\n const callableModuleNameList = callableModuleNames.join(', ');\n\n // TODO(T122225939): Remove after investigation: Why are we getting to this line in bridgeless mode?\n const isBridgelessMode = global.RN$Bridgeless === true ? 'true' : 'false';\n invariant(\n false,\n `Failed to call into JavaScript module method ${module}.${method}(). Module has not been registered as callable. Bridgeless Mode: ${isBridgelessMode}. Registered callable JavaScript modules (n = ${n}): ${callableModuleNameList}.\n A frequent cause of the error is that the application entry file path is incorrect. This can also happen when the JS bundle is corrupt or there is an early initialization error when loading React Native.`,\n );\n }\n if (!moduleMethods[method]) {\n invariant(\n false,\n `Failed to call into JavaScript module method ${module}.${method}(). Module exists, but the method is undefined.`,\n );\n }\n moduleMethods[method].apply(moduleMethods, args);\n Systrace.endEvent();\n }\n\n __invokeCallback(cbID: number, args: mixed[]): void {\n this._lastFlush = Date.now();\n this._eventLoopStartTime = this._lastFlush;\n\n // The rightmost bit of cbID indicates fail (0) or success (1), the other bits are the callID shifted left.\n // eslint-disable-next-line no-bitwise\n const callID = cbID >>> 1;\n // eslint-disable-next-line no-bitwise\n const isSuccess = cbID & 1;\n const callback = isSuccess\n ? this._successCallbacks.get(callID)\n : this._failureCallbacks.get(callID);\n\n if (__DEV__) {\n const debug = this._debugInfo[callID];\n const module = debug && this._remoteModuleTable[debug[0]];\n const method = debug && this._remoteMethodTable[debug[0]][debug[1]];\n invariant(\n callback,\n `No callback found with cbID ${cbID} and callID ${callID} for ` +\n (method\n ? ` ${module}.${method} - most likely the callback was already invoked`\n : `module ${module || ''}`) +\n `. Args: '${stringifySafe(args)}'`,\n );\n const profileName = debug\n ? ''\n : cbID;\n if (callback && this.__spy) {\n this.__spy({type: TO_JS, module: null, method: profileName, args});\n }\n Systrace.beginEvent(\n `MessageQueue.invokeCallback(${profileName}, ${stringifySafe(args)})`,\n );\n }\n\n if (!callback) {\n return;\n }\n\n this._successCallbacks.delete(callID);\n this._failureCallbacks.delete(callID);\n callback(...args);\n\n if (__DEV__) {\n Systrace.endEvent();\n }\n }\n}\n\nmodule.exports = MessageQueue;\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 * @flow strict\n * @format\n */\n\nimport typeof * as SystraceModule from './Systrace';\n\nconst TRACE_TAG_REACT_APPS = 1 << 17; // eslint-disable-line no-bitwise\n\nlet _asyncCookie = 0;\n\ntype EventName = string | (() => string);\ntype EventArgs = ?{[string]: string};\n\n/**\n * Indicates if the application is currently being traced.\n *\n * Calling methods on this module when the application isn't being traced is\n * cheap, but this method can be used to avoid computing expensive values for\n * those functions.\n *\n * @example\n * if (Systrace.isEnabled()) {\n * const expensiveArgs = computeExpensiveArgs();\n * Systrace.beginEvent('myEvent', expensiveArgs);\n * }\n */\nexport function isEnabled(): boolean {\n return global.nativeTraceIsTracing\n ? global.nativeTraceIsTracing(TRACE_TAG_REACT_APPS)\n : Boolean(global.__RCTProfileIsProfiling);\n}\n\n/**\n * @deprecated This function is now a no-op but it's left for backwards\n * compatibility. `isEnabled` will now synchronously check if we're actively\n * profiling or not. This is necessary because we don't have callbacks to know\n * when profiling has started/stopped on Android APIs.\n */\nexport function setEnabled(_doEnable: boolean): void {}\n\n/**\n * Marks the start of a synchronous event that should end in the same stack\n * frame. The end of this event should be marked using the `endEvent` function.\n */\nexport function beginEvent(eventName: EventName, args?: EventArgs): void {\n if (isEnabled()) {\n const eventNameString =\n typeof eventName === 'function' ? eventName() : eventName;\n global.nativeTraceBeginSection(TRACE_TAG_REACT_APPS, eventNameString, args);\n }\n}\n\n/**\n * Marks the end of a synchronous event started in the same stack frame.\n */\nexport function endEvent(args?: EventArgs): void {\n if (isEnabled()) {\n global.nativeTraceEndSection(TRACE_TAG_REACT_APPS, args);\n }\n}\n\n/**\n * Marks the start of a potentially asynchronous event. The end of this event\n * should be marked calling the `endAsyncEvent` function with the cookie\n * returned by this function.\n */\nexport function beginAsyncEvent(\n eventName: EventName,\n args?: EventArgs,\n): number {\n const cookie = _asyncCookie;\n if (isEnabled()) {\n _asyncCookie++;\n const eventNameString =\n typeof eventName === 'function' ? eventName() : eventName;\n global.nativeTraceBeginAsyncSection(\n TRACE_TAG_REACT_APPS,\n eventNameString,\n cookie,\n args,\n );\n }\n return cookie;\n}\n\n/**\n * Marks the end of a potentially asynchronous event, which was started with\n * the given cookie.\n */\nexport function endAsyncEvent(\n eventName: EventName,\n cookie: number,\n args?: EventArgs,\n): void {\n if (isEnabled()) {\n const eventNameString =\n typeof eventName === 'function' ? eventName() : eventName;\n global.nativeTraceEndAsyncSection(\n TRACE_TAG_REACT_APPS,\n eventNameString,\n cookie,\n args,\n );\n }\n}\n\n/**\n * Registers a new value for a counter event.\n */\nexport function counterEvent(eventName: EventName, value: number): void {\n if (isEnabled()) {\n const eventNameString =\n typeof eventName === 'function' ? eventName() : eventName;\n global.nativeTraceCounter &&\n global.nativeTraceCounter(TRACE_TAG_REACT_APPS, eventNameString, value);\n }\n}\n\nif (__DEV__) {\n const Systrace: SystraceModule = {\n isEnabled,\n setEnabled,\n beginEvent,\n endEvent,\n beginAsyncEvent,\n endAsyncEvent,\n counterEvent,\n };\n\n // The metro require polyfill can not have dependencies (true for all polyfills).\n // Ensure that `Systrace` is available in polyfill by exposing it globally.\n global[(global.__METRO_GLOBAL_PREFIX__ || '') + '__SYSTRACE'] = Systrace;\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 * @format\n * @flow strict\n */\n\nimport type {ErrorUtilsT} from '@react-native/polyfills/error-guard';\n\n/**\n * The particular require runtime that we are using looks for a global\n * `ErrorUtils` object and if it exists, then it requires modules with the\n * error handler specified via ErrorUtils.setGlobalHandler by calling the\n * require function with applyWithGuard. Since the require module is loaded\n * before any of the modules, this ErrorUtils must be defined (and the handler\n * set) globally before requiring anything.\n *\n * However, we still want to treat ErrorUtils as a module so that other modules\n * that use it aren't just using a global variable, so simply export the global\n * variable here. ErrorUtils is originally defined in a file named error-guard.js.\n */\nmodule.exports = (global.ErrorUtils: ErrorUtilsT);\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 * @format\n * @flow strict\n */\n\nimport invariant from 'invariant';\n\n/**\n * Tries to stringify with JSON.stringify and toString, but catches exceptions\n * (e.g. from circular objects) and always returns a string and never throws.\n */\nexport function createStringifySafeWithLimits(limits: {|\n maxDepth?: number,\n maxStringLimit?: number,\n maxArrayLimit?: number,\n maxObjectKeysLimit?: number,\n|}): mixed => string {\n const {\n maxDepth = Number.POSITIVE_INFINITY,\n maxStringLimit = Number.POSITIVE_INFINITY,\n maxArrayLimit = Number.POSITIVE_INFINITY,\n maxObjectKeysLimit = Number.POSITIVE_INFINITY,\n } = limits;\n const stack: Array<\n string | {+[string]: mixed} | {'...(truncated keys)...': number},\n > = [];\n /* $FlowFixMe[missing-this-annot] The 'this' type annotation(s) required by\n * Flow's LTI update could not be added via codemod */\n function replacer(key: string, value: mixed): mixed {\n while (stack.length && this !== stack[0]) {\n stack.shift();\n }\n\n if (typeof value === 'string') {\n const truncatedString = '...(truncated)...';\n if (value.length > maxStringLimit + truncatedString.length) {\n return value.substring(0, maxStringLimit) + truncatedString;\n }\n return value;\n }\n if (typeof value !== 'object' || value === null) {\n return value;\n }\n\n let retval:\n | string\n | {+[string]: mixed}\n | $TEMPORARY$object<{'...(truncated keys)...': number}> = value;\n if (Array.isArray(value)) {\n if (stack.length >= maxDepth) {\n retval = `[ ... array with ${value.length} values ... ]`;\n } else if (value.length > maxArrayLimit) {\n retval = value\n .slice(0, maxArrayLimit)\n .concat([\n `... extra ${value.length - maxArrayLimit} values truncated ...`,\n ]);\n }\n } else {\n // Add refinement after Array.isArray call.\n invariant(typeof value === 'object', 'This was already found earlier');\n let keys = Object.keys(value);\n if (stack.length >= maxDepth) {\n retval = `{ ... object with ${keys.length} keys ... }`;\n } else if (keys.length > maxObjectKeysLimit) {\n // Return a sample of the keys.\n retval = ({}: {[string]: mixed});\n for (let k of keys.slice(0, maxObjectKeysLimit)) {\n retval[k] = value[k];\n }\n const truncatedKey = '...(truncated keys)...';\n retval[truncatedKey] = keys.length - maxObjectKeysLimit;\n }\n }\n stack.unshift(retval);\n return retval;\n }\n\n return function stringifySafe(arg: mixed): string {\n if (arg === undefined) {\n return 'undefined';\n } else if (arg === null) {\n return 'null';\n } else if (typeof arg === 'function') {\n try {\n return arg.toString();\n } catch (e) {\n return '[function unknown]';\n }\n } else if (arg instanceof Error) {\n return arg.name + ': ' + arg.message;\n } else {\n // Perform a try catch, just in case the object has a circular\n // reference or stringify throws for some other reason.\n try {\n const ret = JSON.stringify(arg, replacer);\n if (ret === undefined) {\n return '[\"' + typeof arg + '\" failed to stringify]';\n }\n return ret;\n } catch (e) {\n if (typeof arg.toString === 'function') {\n try {\n // $FlowFixMe[incompatible-use] : toString shouldn't take any arguments in general.\n return arg.toString();\n } catch (E) {}\n }\n }\n }\n return '[\"' + typeof arg + '\" failed to stringify]';\n };\n}\n\nconst stringifySafe: mixed => string = createStringifySafeWithLimits({\n maxDepth: 10,\n maxStringLimit: 100,\n maxArrayLimit: 50,\n maxObjectKeysLimit: 50,\n});\n\nexport default stringifySafe;\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 * @format\n * @flow strict\n */\n\n'use strict';\n\n/**\n * Defines a lazily evaluated property on the supplied `object`.\n */\nfunction defineLazyObjectProperty(\n object: interface {},\n name: string,\n descriptor: {\n get: () => T,\n enumerable?: boolean,\n writable?: boolean,\n ...\n },\n): void {\n const {get} = descriptor;\n const enumerable = descriptor.enumerable !== false;\n const writable = descriptor.writable !== false;\n\n let value;\n let valueSet = false;\n function getValue(): T {\n // WORKAROUND: A weird infinite loop occurs where calling `getValue` calls\n // `setValue` which calls `Object.defineProperty` which somehow triggers\n // `getValue` again. Adding `valueSet` breaks this loop.\n if (!valueSet) {\n // Calling `get()` here can trigger an infinite loop if it fails to\n // remove the getter on the property, which can happen when executing\n // JS in a V8 context. `valueSet = true` will break this loop, and\n // sets the value of the property to undefined, until the code in `get()`\n // finishes, at which point the property is set to the correct value.\n valueSet = true;\n setValue(get());\n }\n return value;\n }\n function setValue(newValue: T): void {\n value = newValue;\n valueSet = true;\n Object.defineProperty(object, name, {\n value: newValue,\n configurable: true,\n enumerable,\n writable,\n });\n }\n\n Object.defineProperty(object, name, {\n get: getValue,\n set: setValue,\n configurable: true,\n enumerable,\n });\n}\n\nmodule.exports = defineLazyObjectProperty;\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 * @format\n * @flow strict-local\n */\n\nimport NativeAccessibilityManager from './NativeAccessibilityManager';\n\n/**\n * This is a function exposed to the React Renderer that can be used by the\n * pre-Fabric renderer to emit accessibility events to pre-Fabric nodes.\n */\nfunction legacySendAccessibilityEvent(\n reactTag: number,\n eventType: string,\n): void {\n if (eventType === 'focus' && NativeAccessibilityManager) {\n NativeAccessibilityManager.setAccessibilityFocus(reactTag);\n }\n}\n\nmodule.exports = legacySendAccessibilityEvent;\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 * @flow\n * @format\n */\n\nimport type {TurboModule} from '../../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../../TurboModule/TurboModuleRegistry';\n\nexport interface Spec extends TurboModule {\n +getCurrentBoldTextState: (\n onSuccess: (isBoldTextEnabled: boolean) => void,\n onError: (error: Object) => void,\n ) => void;\n +getCurrentGrayscaleState: (\n onSuccess: (isGrayscaleEnabled: boolean) => void,\n onError: (error: Object) => void,\n ) => void;\n +getCurrentInvertColorsState: (\n onSuccess: (isInvertColorsEnabled: boolean) => void,\n onError: (error: Object) => void,\n ) => void;\n +getCurrentReduceMotionState: (\n onSuccess: (isReduceMotionEnabled: boolean) => void,\n onError: (error: Object) => void,\n ) => void;\n +getCurrentPrefersCrossFadeTransitionsState?: (\n onSuccess: (prefersCrossFadeTransitions: boolean) => void,\n onError: (error: Object) => void,\n ) => void;\n +getCurrentReduceTransparencyState: (\n onSuccess: (isReduceTransparencyEnabled: boolean) => void,\n onError: (error: Object) => void,\n ) => void;\n +getCurrentVoiceOverState: (\n onSuccess: (isScreenReaderEnabled: boolean) => void,\n onError: (error: Object) => void,\n ) => void;\n +setAccessibilityContentSizeMultipliers: (JSMultipliers: {|\n +extraSmall?: ?number,\n +small?: ?number,\n +medium?: ?number,\n +large?: ?number,\n +extraLarge?: ?number,\n +extraExtraLarge?: ?number,\n +extraExtraExtraLarge?: ?number,\n +accessibilityMedium?: ?number,\n +accessibilityLarge?: ?number,\n +accessibilityExtraLarge?: ?number,\n +accessibilityExtraExtraLarge?: ?number,\n +accessibilityExtraExtraExtraLarge?: ?number,\n |}) => void;\n +setAccessibilityFocus: (reactTag: number) => void;\n +announceForAccessibility: (announcement: string) => void;\n +announceForAccessibilityWithOptions?: (\n announcement: string,\n options: {queue?: boolean},\n ) => void;\n}\n\nexport default (TurboModuleRegistry.get('AccessibilityManager'): ?Spec);\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 * @flow strict\n * @format\n */\n\nimport type {TurboModule} from '../../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../../TurboModule/TurboModuleRegistry';\n\nexport interface Spec extends TurboModule {\n +isReduceMotionEnabled: (\n onSuccess: (isReduceMotionEnabled: boolean) => void,\n ) => void;\n +isTouchExplorationEnabled: (\n onSuccess: (isScreenReaderEnabled: boolean) => void,\n ) => void;\n +isAccessibilityServiceEnabled?: ?(\n onSuccess: (isAccessibilityServiceEnabled: boolean) => void,\n ) => void;\n +setAccessibilityFocus: (reactTag: number) => void;\n +announceForAccessibility: (announcement: string) => void;\n +getRecommendedTimeoutMillis?: (\n mSec: number,\n onSuccess: (recommendedTimeoutMillis: number) => void,\n ) => void;\n}\n\nexport default (TurboModuleRegistry.get('AccessibilityInfo'): ?Spec);\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 * @format\n * @flow strict-local\n */\n\n/**\n * This module exists to allow apps to select their renderer implementation\n * (e.g.: Fabric-only, Paper-only) without having to pull all the renderer\n * implementations into their app bundle, which affects app size.\n *\n * By default, the setup will be:\n * -> RendererProxy\n * -> RendererImplementation (which uses Fabric or Paper depending on a flag at runtime)\n *\n * But this will allow a setup like this without duplicating logic:\n * -> RendererProxy (fork)\n * -> RendererImplementation (which uses Fabric or Paper depending on a flag at runtime)\n * or -> OtherImplementation (which uses Fabric only)\n */\n\nexport * from './RendererImplementation';\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 * @format\n * @flow strict-local\n */\n\nimport type {HostComponent} from '../Renderer/shims/ReactNativeTypes';\nimport type {Element, ElementRef, ElementType} from 'react';\n\nimport {type RootTag} from './RootTag';\n\nexport function renderElement({\n element,\n rootTag,\n useFabric,\n useConcurrentRoot,\n}: {\n element: Element,\n rootTag: number,\n useFabric: boolean,\n useConcurrentRoot: boolean,\n}): void {\n if (useFabric) {\n require('../Renderer/shims/ReactFabric').render(\n element,\n rootTag,\n null,\n useConcurrentRoot,\n );\n } else {\n require('../Renderer/shims/ReactNative').render(element, rootTag);\n }\n}\n\nexport function findHostInstance_DEPRECATED(\n componentOrHandle: ?(ElementRef | number),\n): ?ElementRef> {\n return require('../Renderer/shims/ReactNative').findHostInstance_DEPRECATED(\n componentOrHandle,\n );\n}\n\nexport function findNodeHandle(\n componentOrHandle: ?(ElementRef | number),\n): ?number {\n return require('../Renderer/shims/ReactNative').findNodeHandle(\n componentOrHandle,\n );\n}\n\nexport function dispatchCommand(\n handle: ElementRef>,\n command: string,\n args: Array,\n): void {\n if (global.RN$Bridgeless === true) {\n // Note: this function has the same implementation in the legacy and new renderer.\n // However, evaluating the old renderer comes with some side effects.\n return require('../Renderer/shims/ReactFabric').dispatchCommand(\n handle,\n command,\n args,\n );\n } else {\n return require('../Renderer/shims/ReactNative').dispatchCommand(\n handle,\n command,\n args,\n );\n }\n}\n\nexport function sendAccessibilityEvent(\n handle: ElementRef>,\n eventType: string,\n): void {\n return require('../Renderer/shims/ReactNative').sendAccessibilityEvent(\n handle,\n eventType,\n );\n}\n\n/**\n * This method is used by AppRegistry to unmount a root when using the old\n * React Native renderer (Paper).\n */\nexport function unmountComponentAtNodeAndRemoveContainer(rootTag: RootTag) {\n // $FlowExpectedError[incompatible-type] rootTag is an opaque type so we can't really cast it as is.\n const rootTagAsNumber: number = rootTag;\n require('../Renderer/shims/ReactNative').unmountComponentAtNodeAndRemoveContainer(\n rootTagAsNumber,\n );\n}\n\nexport function unstable_batchedUpdates(\n fn: T => void,\n bookkeeping: T,\n): void {\n // This doesn't actually do anything when batching updates for a Fabric root.\n return require('../Renderer/shims/ReactNative').unstable_batchedUpdates(\n fn,\n bookkeeping,\n );\n}\n\nexport function isProfilingRenderer(): boolean {\n return Boolean(__DEV__);\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 * @noformat\n * @flow\n * @generated SignedSource<>\n *\n * This file was sync'd from the facebook/react repository.\n */\n\n'use strict';\n\nimport {BatchedBridge} from 'react-native/Libraries/ReactPrivate/ReactNativePrivateInterface';\n\nimport type {ReactFabricType} from './ReactNativeTypes';\n\nlet ReactFabric;\n\nif (__DEV__) {\n ReactFabric = require('../implementations/ReactFabric-dev');\n} else {\n ReactFabric = require('../implementations/ReactFabric-prod');\n}\n\nif (global.RN$Bridgeless) {\n global.RN$stopSurface = ReactFabric.stopSurface;\n} else {\n BatchedBridge.registerCallableModule('ReactFabric', ReactFabric);\n}\n\nmodule.exports = (ReactFabric: ReactFabricType);\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 * @noflow\n * @nolint\n * @providesModule ReactFabric-prod\n * @preventMunge\n * @generated SignedSource<>\n */\n\n\"use strict\";\nrequire(\"react-native/Libraries/ReactPrivate/ReactNativePrivateInitializeCore\");\nvar ReactNativePrivateInterface = require(\"react-native/Libraries/ReactPrivate/ReactNativePrivateInterface\"),\n React = require(\"react\"),\n Scheduler = require(\"scheduler\");\nfunction invokeGuardedCallbackImpl(name, func, context, a, b, c, d, e, f) {\n var funcArgs = Array.prototype.slice.call(arguments, 3);\n try {\n func.apply(context, funcArgs);\n } catch (error) {\n this.onError(error);\n }\n}\nvar hasError = !1,\n caughtError = null,\n hasRethrowError = !1,\n rethrowError = null,\n reporter = {\n onError: function(error) {\n hasError = !0;\n caughtError = error;\n }\n };\nfunction invokeGuardedCallback(name, func, context, a, b, c, d, e, f) {\n hasError = !1;\n caughtError = null;\n invokeGuardedCallbackImpl.apply(reporter, arguments);\n}\nfunction invokeGuardedCallbackAndCatchFirstError(\n name,\n func,\n context,\n a,\n b,\n c,\n d,\n e,\n f\n) {\n invokeGuardedCallback.apply(this, arguments);\n if (hasError) {\n if (hasError) {\n var error = caughtError;\n hasError = !1;\n caughtError = null;\n } else\n throw Error(\n \"clearCaughtError was called but no error was captured. This error is likely caused by a bug in React. Please file an issue.\"\n );\n hasRethrowError || ((hasRethrowError = !0), (rethrowError = error));\n }\n}\nvar isArrayImpl = Array.isArray,\n getFiberCurrentPropsFromNode = null,\n getInstanceFromNode = null,\n getNodeFromInstance = null;\nfunction executeDispatch(event, listener, inst) {\n var type = event.type || \"unknown-event\";\n event.currentTarget = getNodeFromInstance(inst);\n invokeGuardedCallbackAndCatchFirstError(type, listener, void 0, event);\n event.currentTarget = null;\n}\nfunction executeDirectDispatch(event) {\n var dispatchListener = event._dispatchListeners,\n dispatchInstance = event._dispatchInstances;\n if (isArrayImpl(dispatchListener))\n throw Error(\"executeDirectDispatch(...): Invalid `event`.\");\n event.currentTarget = dispatchListener\n ? getNodeFromInstance(dispatchInstance)\n : null;\n dispatchListener = dispatchListener ? dispatchListener(event) : null;\n event.currentTarget = null;\n event._dispatchListeners = null;\n event._dispatchInstances = null;\n return dispatchListener;\n}\nvar assign = Object.assign;\nfunction functionThatReturnsTrue() {\n return !0;\n}\nfunction functionThatReturnsFalse() {\n return !1;\n}\nfunction SyntheticEvent(\n dispatchConfig,\n targetInst,\n nativeEvent,\n nativeEventTarget\n) {\n this.dispatchConfig = dispatchConfig;\n this._targetInst = targetInst;\n this.nativeEvent = nativeEvent;\n this._dispatchInstances = this._dispatchListeners = null;\n dispatchConfig = this.constructor.Interface;\n for (var propName in dispatchConfig)\n dispatchConfig.hasOwnProperty(propName) &&\n ((targetInst = dispatchConfig[propName])\n ? (this[propName] = targetInst(nativeEvent))\n : \"target\" === propName\n ? (this.target = nativeEventTarget)\n : (this[propName] = nativeEvent[propName]));\n this.isDefaultPrevented = (null != nativeEvent.defaultPrevented\n ? nativeEvent.defaultPrevented\n : !1 === nativeEvent.returnValue)\n ? functionThatReturnsTrue\n : functionThatReturnsFalse;\n this.isPropagationStopped = functionThatReturnsFalse;\n return this;\n}\nassign(SyntheticEvent.prototype, {\n preventDefault: function() {\n this.defaultPrevented = !0;\n var event = this.nativeEvent;\n event &&\n (event.preventDefault\n ? event.preventDefault()\n : \"unknown\" !== typeof event.returnValue && (event.returnValue = !1),\n (this.isDefaultPrevented = functionThatReturnsTrue));\n },\n stopPropagation: function() {\n var event = this.nativeEvent;\n event &&\n (event.stopPropagation\n ? event.stopPropagation()\n : \"unknown\" !== typeof event.cancelBubble && (event.cancelBubble = !0),\n (this.isPropagationStopped = functionThatReturnsTrue));\n },\n persist: function() {\n this.isPersistent = functionThatReturnsTrue;\n },\n isPersistent: functionThatReturnsFalse,\n destructor: function() {\n var Interface = this.constructor.Interface,\n propName;\n for (propName in Interface) this[propName] = null;\n this.nativeEvent = this._targetInst = this.dispatchConfig = null;\n this.isPropagationStopped = this.isDefaultPrevented = functionThatReturnsFalse;\n this._dispatchInstances = this._dispatchListeners = null;\n }\n});\nSyntheticEvent.Interface = {\n type: null,\n target: null,\n currentTarget: function() {\n return null;\n },\n eventPhase: null,\n bubbles: null,\n cancelable: null,\n timeStamp: function(event) {\n return event.timeStamp || Date.now();\n },\n defaultPrevented: null,\n isTrusted: null\n};\nSyntheticEvent.extend = function(Interface) {\n function E() {}\n function Class() {\n return Super.apply(this, arguments);\n }\n var Super = this;\n E.prototype = Super.prototype;\n var prototype = new E();\n assign(prototype, Class.prototype);\n Class.prototype = prototype;\n Class.prototype.constructor = Class;\n Class.Interface = assign({}, Super.Interface, Interface);\n Class.extend = Super.extend;\n addEventPoolingTo(Class);\n return Class;\n};\naddEventPoolingTo(SyntheticEvent);\nfunction createOrGetPooledEvent(\n dispatchConfig,\n targetInst,\n nativeEvent,\n nativeInst\n) {\n if (this.eventPool.length) {\n var instance = this.eventPool.pop();\n this.call(instance, dispatchConfig, targetInst, nativeEvent, nativeInst);\n return instance;\n }\n return new this(dispatchConfig, targetInst, nativeEvent, nativeInst);\n}\nfunction releasePooledEvent(event) {\n if (!(event instanceof this))\n throw Error(\n \"Trying to release an event instance into a pool of a different type.\"\n );\n event.destructor();\n 10 > this.eventPool.length && this.eventPool.push(event);\n}\nfunction addEventPoolingTo(EventConstructor) {\n EventConstructor.getPooled = createOrGetPooledEvent;\n EventConstructor.eventPool = [];\n EventConstructor.release = releasePooledEvent;\n}\nvar ResponderSyntheticEvent = SyntheticEvent.extend({\n touchHistory: function() {\n return null;\n }\n});\nfunction isStartish(topLevelType) {\n return \"topTouchStart\" === topLevelType;\n}\nfunction isMoveish(topLevelType) {\n return \"topTouchMove\" === topLevelType;\n}\nvar startDependencies = [\"topTouchStart\"],\n moveDependencies = [\"topTouchMove\"],\n endDependencies = [\"topTouchCancel\", \"topTouchEnd\"],\n touchBank = [],\n touchHistory = {\n touchBank: touchBank,\n numberActiveTouches: 0,\n indexOfSingleActiveTouch: -1,\n mostRecentTimeStamp: 0\n };\nfunction timestampForTouch(touch) {\n return touch.timeStamp || touch.timestamp;\n}\nfunction getTouchIdentifier(_ref) {\n _ref = _ref.identifier;\n if (null == _ref) throw Error(\"Touch object is missing identifier.\");\n return _ref;\n}\nfunction recordTouchStart(touch) {\n var identifier = getTouchIdentifier(touch),\n touchRecord = touchBank[identifier];\n touchRecord\n ? ((touchRecord.touchActive = !0),\n (touchRecord.startPageX = touch.pageX),\n (touchRecord.startPageY = touch.pageY),\n (touchRecord.startTimeStamp = timestampForTouch(touch)),\n (touchRecord.currentPageX = touch.pageX),\n (touchRecord.currentPageY = touch.pageY),\n (touchRecord.currentTimeStamp = timestampForTouch(touch)),\n (touchRecord.previousPageX = touch.pageX),\n (touchRecord.previousPageY = touch.pageY),\n (touchRecord.previousTimeStamp = timestampForTouch(touch)))\n : ((touchRecord = {\n touchActive: !0,\n startPageX: touch.pageX,\n startPageY: touch.pageY,\n startTimeStamp: timestampForTouch(touch),\n currentPageX: touch.pageX,\n currentPageY: touch.pageY,\n currentTimeStamp: timestampForTouch(touch),\n previousPageX: touch.pageX,\n previousPageY: touch.pageY,\n previousTimeStamp: timestampForTouch(touch)\n }),\n (touchBank[identifier] = touchRecord));\n touchHistory.mostRecentTimeStamp = timestampForTouch(touch);\n}\nfunction recordTouchMove(touch) {\n var touchRecord = touchBank[getTouchIdentifier(touch)];\n touchRecord &&\n ((touchRecord.touchActive = !0),\n (touchRecord.previousPageX = touchRecord.currentPageX),\n (touchRecord.previousPageY = touchRecord.currentPageY),\n (touchRecord.previousTimeStamp = touchRecord.currentTimeStamp),\n (touchRecord.currentPageX = touch.pageX),\n (touchRecord.currentPageY = touch.pageY),\n (touchRecord.currentTimeStamp = timestampForTouch(touch)),\n (touchHistory.mostRecentTimeStamp = timestampForTouch(touch)));\n}\nfunction recordTouchEnd(touch) {\n var touchRecord = touchBank[getTouchIdentifier(touch)];\n touchRecord &&\n ((touchRecord.touchActive = !1),\n (touchRecord.previousPageX = touchRecord.currentPageX),\n (touchRecord.previousPageY = touchRecord.currentPageY),\n (touchRecord.previousTimeStamp = touchRecord.currentTimeStamp),\n (touchRecord.currentPageX = touch.pageX),\n (touchRecord.currentPageY = touch.pageY),\n (touchRecord.currentTimeStamp = timestampForTouch(touch)),\n (touchHistory.mostRecentTimeStamp = timestampForTouch(touch)));\n}\nvar instrumentationCallback,\n ResponderTouchHistoryStore = {\n instrument: function(callback) {\n instrumentationCallback = callback;\n },\n recordTouchTrack: function(topLevelType, nativeEvent) {\n null != instrumentationCallback &&\n instrumentationCallback(topLevelType, nativeEvent);\n if (isMoveish(topLevelType))\n nativeEvent.changedTouches.forEach(recordTouchMove);\n else if (isStartish(topLevelType))\n nativeEvent.changedTouches.forEach(recordTouchStart),\n (touchHistory.numberActiveTouches = nativeEvent.touches.length),\n 1 === touchHistory.numberActiveTouches &&\n (touchHistory.indexOfSingleActiveTouch =\n nativeEvent.touches[0].identifier);\n else if (\n \"topTouchEnd\" === topLevelType ||\n \"topTouchCancel\" === topLevelType\n )\n if (\n (nativeEvent.changedTouches.forEach(recordTouchEnd),\n (touchHistory.numberActiveTouches = nativeEvent.touches.length),\n 1 === touchHistory.numberActiveTouches)\n )\n for (\n topLevelType = 0;\n topLevelType < touchBank.length;\n topLevelType++\n )\n if (\n ((nativeEvent = touchBank[topLevelType]),\n null != nativeEvent && nativeEvent.touchActive)\n ) {\n touchHistory.indexOfSingleActiveTouch = topLevelType;\n break;\n }\n },\n touchHistory: touchHistory\n };\nfunction accumulate(current, next) {\n if (null == next)\n throw Error(\n \"accumulate(...): Accumulated items must not be null or undefined.\"\n );\n return null == current\n ? next\n : isArrayImpl(current)\n ? current.concat(next)\n : isArrayImpl(next)\n ? [current].concat(next)\n : [current, next];\n}\nfunction accumulateInto(current, next) {\n if (null == next)\n throw Error(\n \"accumulateInto(...): Accumulated items must not be null or undefined.\"\n );\n if (null == current) return next;\n if (isArrayImpl(current)) {\n if (isArrayImpl(next)) return current.push.apply(current, next), current;\n current.push(next);\n return current;\n }\n return isArrayImpl(next) ? [current].concat(next) : [current, next];\n}\nfunction forEachAccumulated(arr, cb, scope) {\n Array.isArray(arr) ? arr.forEach(cb, scope) : arr && cb.call(scope, arr);\n}\nvar responderInst = null,\n trackedTouchCount = 0;\nfunction changeResponder(nextResponderInst, blockHostResponder) {\n var oldResponderInst = responderInst;\n responderInst = nextResponderInst;\n if (null !== ResponderEventPlugin.GlobalResponderHandler)\n ResponderEventPlugin.GlobalResponderHandler.onChange(\n oldResponderInst,\n nextResponderInst,\n blockHostResponder\n );\n}\nvar eventTypes = {\n startShouldSetResponder: {\n phasedRegistrationNames: {\n bubbled: \"onStartShouldSetResponder\",\n captured: \"onStartShouldSetResponderCapture\"\n },\n dependencies: startDependencies\n },\n scrollShouldSetResponder: {\n phasedRegistrationNames: {\n bubbled: \"onScrollShouldSetResponder\",\n captured: \"onScrollShouldSetResponderCapture\"\n },\n dependencies: [\"topScroll\"]\n },\n selectionChangeShouldSetResponder: {\n phasedRegistrationNames: {\n bubbled: \"onSelectionChangeShouldSetResponder\",\n captured: \"onSelectionChangeShouldSetResponderCapture\"\n },\n dependencies: [\"topSelectionChange\"]\n },\n moveShouldSetResponder: {\n phasedRegistrationNames: {\n bubbled: \"onMoveShouldSetResponder\",\n captured: \"onMoveShouldSetResponderCapture\"\n },\n dependencies: moveDependencies\n },\n responderStart: {\n registrationName: \"onResponderStart\",\n dependencies: startDependencies\n },\n responderMove: {\n registrationName: \"onResponderMove\",\n dependencies: moveDependencies\n },\n responderEnd: {\n registrationName: \"onResponderEnd\",\n dependencies: endDependencies\n },\n responderRelease: {\n registrationName: \"onResponderRelease\",\n dependencies: endDependencies\n },\n responderTerminationRequest: {\n registrationName: \"onResponderTerminationRequest\",\n dependencies: []\n },\n responderGrant: { registrationName: \"onResponderGrant\", dependencies: [] },\n responderReject: { registrationName: \"onResponderReject\", dependencies: [] },\n responderTerminate: {\n registrationName: \"onResponderTerminate\",\n dependencies: []\n }\n};\nfunction getParent(inst) {\n do inst = inst.return;\n while (inst && 5 !== inst.tag);\n return inst ? inst : null;\n}\nfunction traverseTwoPhase(inst, fn, arg) {\n for (var path = []; inst; ) path.push(inst), (inst = getParent(inst));\n for (inst = path.length; 0 < inst--; ) fn(path[inst], \"captured\", arg);\n for (inst = 0; inst < path.length; inst++) fn(path[inst], \"bubbled\", arg);\n}\nfunction getListener(inst, registrationName) {\n inst = inst.stateNode;\n if (null === inst) return null;\n inst = getFiberCurrentPropsFromNode(inst);\n if (null === inst) return null;\n if ((inst = inst[registrationName]) && \"function\" !== typeof inst)\n throw Error(\n \"Expected `\" +\n registrationName +\n \"` listener to be a function, instead got a value of `\" +\n typeof inst +\n \"` type.\"\n );\n return inst;\n}\nfunction accumulateDirectionalDispatches(inst, phase, event) {\n if (\n (phase = getListener(\n inst,\n event.dispatchConfig.phasedRegistrationNames[phase]\n ))\n )\n (event._dispatchListeners = accumulateInto(\n event._dispatchListeners,\n phase\n )),\n (event._dispatchInstances = accumulateInto(\n event._dispatchInstances,\n inst\n ));\n}\nfunction accumulateDirectDispatchesSingle(event) {\n if (event && event.dispatchConfig.registrationName) {\n var inst = event._targetInst;\n if (inst && event && event.dispatchConfig.registrationName) {\n var listener = getListener(inst, event.dispatchConfig.registrationName);\n listener &&\n ((event._dispatchListeners = accumulateInto(\n event._dispatchListeners,\n listener\n )),\n (event._dispatchInstances = accumulateInto(\n event._dispatchInstances,\n inst\n )));\n }\n }\n}\nfunction accumulateTwoPhaseDispatchesSingleSkipTarget(event) {\n if (event && event.dispatchConfig.phasedRegistrationNames) {\n var targetInst = event._targetInst;\n targetInst = targetInst ? getParent(targetInst) : null;\n traverseTwoPhase(targetInst, accumulateDirectionalDispatches, event);\n }\n}\nfunction accumulateTwoPhaseDispatchesSingle(event) {\n event &&\n event.dispatchConfig.phasedRegistrationNames &&\n traverseTwoPhase(event._targetInst, accumulateDirectionalDispatches, event);\n}\nvar ResponderEventPlugin = {\n _getResponder: function() {\n return responderInst;\n },\n eventTypes: eventTypes,\n extractEvents: function(\n topLevelType,\n targetInst,\n nativeEvent,\n nativeEventTarget\n ) {\n if (isStartish(topLevelType)) trackedTouchCount += 1;\n else if (\n \"topTouchEnd\" === topLevelType ||\n \"topTouchCancel\" === topLevelType\n )\n if (0 <= trackedTouchCount) --trackedTouchCount;\n else return null;\n ResponderTouchHistoryStore.recordTouchTrack(topLevelType, nativeEvent);\n if (\n targetInst &&\n ((\"topScroll\" === topLevelType && !nativeEvent.responderIgnoreScroll) ||\n (0 < trackedTouchCount && \"topSelectionChange\" === topLevelType) ||\n isStartish(topLevelType) ||\n isMoveish(topLevelType))\n ) {\n var shouldSetEventType = isStartish(topLevelType)\n ? eventTypes.startShouldSetResponder\n : isMoveish(topLevelType)\n ? eventTypes.moveShouldSetResponder\n : \"topSelectionChange\" === topLevelType\n ? eventTypes.selectionChangeShouldSetResponder\n : eventTypes.scrollShouldSetResponder;\n if (responderInst)\n b: {\n var JSCompiler_temp = responderInst;\n for (\n var depthA = 0, tempA = JSCompiler_temp;\n tempA;\n tempA = getParent(tempA)\n )\n depthA++;\n tempA = 0;\n for (var tempB = targetInst; tempB; tempB = getParent(tempB))\n tempA++;\n for (; 0 < depthA - tempA; )\n (JSCompiler_temp = getParent(JSCompiler_temp)), depthA--;\n for (; 0 < tempA - depthA; )\n (targetInst = getParent(targetInst)), tempA--;\n for (; depthA--; ) {\n if (\n JSCompiler_temp === targetInst ||\n JSCompiler_temp === targetInst.alternate\n )\n break b;\n JSCompiler_temp = getParent(JSCompiler_temp);\n targetInst = getParent(targetInst);\n }\n JSCompiler_temp = null;\n }\n else JSCompiler_temp = targetInst;\n targetInst = JSCompiler_temp;\n JSCompiler_temp = targetInst === responderInst;\n shouldSetEventType = ResponderSyntheticEvent.getPooled(\n shouldSetEventType,\n targetInst,\n nativeEvent,\n nativeEventTarget\n );\n shouldSetEventType.touchHistory =\n ResponderTouchHistoryStore.touchHistory;\n JSCompiler_temp\n ? forEachAccumulated(\n shouldSetEventType,\n accumulateTwoPhaseDispatchesSingleSkipTarget\n )\n : forEachAccumulated(\n shouldSetEventType,\n accumulateTwoPhaseDispatchesSingle\n );\n b: {\n JSCompiler_temp = shouldSetEventType._dispatchListeners;\n targetInst = shouldSetEventType._dispatchInstances;\n if (isArrayImpl(JSCompiler_temp))\n for (\n depthA = 0;\n depthA < JSCompiler_temp.length &&\n !shouldSetEventType.isPropagationStopped();\n depthA++\n ) {\n if (\n JSCompiler_temp[depthA](shouldSetEventType, targetInst[depthA])\n ) {\n JSCompiler_temp = targetInst[depthA];\n break b;\n }\n }\n else if (\n JSCompiler_temp &&\n JSCompiler_temp(shouldSetEventType, targetInst)\n ) {\n JSCompiler_temp = targetInst;\n break b;\n }\n JSCompiler_temp = null;\n }\n shouldSetEventType._dispatchInstances = null;\n shouldSetEventType._dispatchListeners = null;\n shouldSetEventType.isPersistent() ||\n shouldSetEventType.constructor.release(shouldSetEventType);\n if (JSCompiler_temp && JSCompiler_temp !== responderInst)\n if (\n ((shouldSetEventType = ResponderSyntheticEvent.getPooled(\n eventTypes.responderGrant,\n JSCompiler_temp,\n nativeEvent,\n nativeEventTarget\n )),\n (shouldSetEventType.touchHistory =\n ResponderTouchHistoryStore.touchHistory),\n forEachAccumulated(\n shouldSetEventType,\n accumulateDirectDispatchesSingle\n ),\n (targetInst = !0 === executeDirectDispatch(shouldSetEventType)),\n responderInst)\n )\n if (\n ((depthA = ResponderSyntheticEvent.getPooled(\n eventTypes.responderTerminationRequest,\n responderInst,\n nativeEvent,\n nativeEventTarget\n )),\n (depthA.touchHistory = ResponderTouchHistoryStore.touchHistory),\n forEachAccumulated(depthA, accumulateDirectDispatchesSingle),\n (tempA =\n !depthA._dispatchListeners || executeDirectDispatch(depthA)),\n depthA.isPersistent() || depthA.constructor.release(depthA),\n tempA)\n ) {\n depthA = ResponderSyntheticEvent.getPooled(\n eventTypes.responderTerminate,\n responderInst,\n nativeEvent,\n nativeEventTarget\n );\n depthA.touchHistory = ResponderTouchHistoryStore.touchHistory;\n forEachAccumulated(depthA, accumulateDirectDispatchesSingle);\n var JSCompiler_temp$jscomp$0 = accumulate(\n JSCompiler_temp$jscomp$0,\n [shouldSetEventType, depthA]\n );\n changeResponder(JSCompiler_temp, targetInst);\n } else\n (shouldSetEventType = ResponderSyntheticEvent.getPooled(\n eventTypes.responderReject,\n JSCompiler_temp,\n nativeEvent,\n nativeEventTarget\n )),\n (shouldSetEventType.touchHistory =\n ResponderTouchHistoryStore.touchHistory),\n forEachAccumulated(\n shouldSetEventType,\n accumulateDirectDispatchesSingle\n ),\n (JSCompiler_temp$jscomp$0 = accumulate(\n JSCompiler_temp$jscomp$0,\n shouldSetEventType\n ));\n else\n (JSCompiler_temp$jscomp$0 = accumulate(\n JSCompiler_temp$jscomp$0,\n shouldSetEventType\n )),\n changeResponder(JSCompiler_temp, targetInst);\n else JSCompiler_temp$jscomp$0 = null;\n } else JSCompiler_temp$jscomp$0 = null;\n shouldSetEventType = responderInst && isStartish(topLevelType);\n JSCompiler_temp = responderInst && isMoveish(topLevelType);\n targetInst =\n responderInst &&\n (\"topTouchEnd\" === topLevelType || \"topTouchCancel\" === topLevelType);\n if (\n (shouldSetEventType = shouldSetEventType\n ? eventTypes.responderStart\n : JSCompiler_temp\n ? eventTypes.responderMove\n : targetInst\n ? eventTypes.responderEnd\n : null)\n )\n (shouldSetEventType = ResponderSyntheticEvent.getPooled(\n shouldSetEventType,\n responderInst,\n nativeEvent,\n nativeEventTarget\n )),\n (shouldSetEventType.touchHistory =\n ResponderTouchHistoryStore.touchHistory),\n forEachAccumulated(\n shouldSetEventType,\n accumulateDirectDispatchesSingle\n ),\n (JSCompiler_temp$jscomp$0 = accumulate(\n JSCompiler_temp$jscomp$0,\n shouldSetEventType\n ));\n shouldSetEventType = responderInst && \"topTouchCancel\" === topLevelType;\n if (\n (topLevelType =\n responderInst &&\n !shouldSetEventType &&\n (\"topTouchEnd\" === topLevelType || \"topTouchCancel\" === topLevelType))\n )\n a: {\n if ((topLevelType = nativeEvent.touches) && 0 !== topLevelType.length)\n for (\n JSCompiler_temp = 0;\n JSCompiler_temp < topLevelType.length;\n JSCompiler_temp++\n )\n if (\n ((targetInst = topLevelType[JSCompiler_temp].target),\n null !== targetInst &&\n void 0 !== targetInst &&\n 0 !== targetInst)\n ) {\n depthA = getInstanceFromNode(targetInst);\n b: {\n for (targetInst = responderInst; depthA; ) {\n if (\n targetInst === depthA ||\n targetInst === depthA.alternate\n ) {\n targetInst = !0;\n break b;\n }\n depthA = getParent(depthA);\n }\n targetInst = !1;\n }\n if (targetInst) {\n topLevelType = !1;\n break a;\n }\n }\n topLevelType = !0;\n }\n if (\n (topLevelType = shouldSetEventType\n ? eventTypes.responderTerminate\n : topLevelType\n ? eventTypes.responderRelease\n : null)\n )\n (nativeEvent = ResponderSyntheticEvent.getPooled(\n topLevelType,\n responderInst,\n nativeEvent,\n nativeEventTarget\n )),\n (nativeEvent.touchHistory = ResponderTouchHistoryStore.touchHistory),\n forEachAccumulated(nativeEvent, accumulateDirectDispatchesSingle),\n (JSCompiler_temp$jscomp$0 = accumulate(\n JSCompiler_temp$jscomp$0,\n nativeEvent\n )),\n changeResponder(null);\n return JSCompiler_temp$jscomp$0;\n },\n GlobalResponderHandler: null,\n injection: {\n injectGlobalResponderHandler: function(GlobalResponderHandler) {\n ResponderEventPlugin.GlobalResponderHandler = GlobalResponderHandler;\n }\n }\n },\n eventPluginOrder = null,\n namesToPlugins = {};\nfunction recomputePluginOrdering() {\n if (eventPluginOrder)\n for (var pluginName in namesToPlugins) {\n var pluginModule = namesToPlugins[pluginName],\n pluginIndex = eventPluginOrder.indexOf(pluginName);\n if (-1 >= pluginIndex)\n throw Error(\n \"EventPluginRegistry: Cannot inject event plugins that do not exist in the plugin ordering, `\" +\n (pluginName + \"`.\")\n );\n if (!plugins[pluginIndex]) {\n if (!pluginModule.extractEvents)\n throw Error(\n \"EventPluginRegistry: Event plugins must implement an `extractEvents` method, but `\" +\n (pluginName + \"` does not.\")\n );\n plugins[pluginIndex] = pluginModule;\n pluginIndex = pluginModule.eventTypes;\n for (var eventName in pluginIndex) {\n var JSCompiler_inline_result = void 0;\n var dispatchConfig = pluginIndex[eventName],\n eventName$jscomp$0 = eventName;\n if (eventNameDispatchConfigs.hasOwnProperty(eventName$jscomp$0))\n throw Error(\n \"EventPluginRegistry: More than one plugin attempted to publish the same event name, `\" +\n (eventName$jscomp$0 + \"`.\")\n );\n eventNameDispatchConfigs[eventName$jscomp$0] = dispatchConfig;\n var phasedRegistrationNames = dispatchConfig.phasedRegistrationNames;\n if (phasedRegistrationNames) {\n for (JSCompiler_inline_result in phasedRegistrationNames)\n phasedRegistrationNames.hasOwnProperty(\n JSCompiler_inline_result\n ) &&\n publishRegistrationName(\n phasedRegistrationNames[JSCompiler_inline_result],\n pluginModule,\n eventName$jscomp$0\n );\n JSCompiler_inline_result = !0;\n } else\n dispatchConfig.registrationName\n ? (publishRegistrationName(\n dispatchConfig.registrationName,\n pluginModule,\n eventName$jscomp$0\n ),\n (JSCompiler_inline_result = !0))\n : (JSCompiler_inline_result = !1);\n if (!JSCompiler_inline_result)\n throw Error(\n \"EventPluginRegistry: Failed to publish event `\" +\n eventName +\n \"` for plugin `\" +\n pluginName +\n \"`.\"\n );\n }\n }\n }\n}\nfunction publishRegistrationName(registrationName, pluginModule) {\n if (registrationNameModules[registrationName])\n throw Error(\n \"EventPluginRegistry: More than one plugin attempted to publish the same registration name, `\" +\n (registrationName + \"`.\")\n );\n registrationNameModules[registrationName] = pluginModule;\n}\nvar plugins = [],\n eventNameDispatchConfigs = {},\n registrationNameModules = {};\nfunction getListeners(\n inst,\n registrationName,\n phase,\n dispatchToImperativeListeners\n) {\n var stateNode = inst.stateNode;\n if (null === stateNode) return null;\n inst = getFiberCurrentPropsFromNode(stateNode);\n if (null === inst) return null;\n if ((inst = inst[registrationName]) && \"function\" !== typeof inst)\n throw Error(\n \"Expected `\" +\n registrationName +\n \"` listener to be a function, instead got a value of `\" +\n typeof inst +\n \"` type.\"\n );\n if (\n !(\n dispatchToImperativeListeners &&\n stateNode.canonical &&\n stateNode.canonical._eventListeners\n )\n )\n return inst;\n var listeners = [];\n inst && listeners.push(inst);\n var requestedPhaseIsCapture = \"captured\" === phase,\n mangledImperativeRegistrationName = requestedPhaseIsCapture\n ? \"rn:\" + registrationName.replace(/Capture$/, \"\")\n : \"rn:\" + registrationName;\n stateNode.canonical._eventListeners[mangledImperativeRegistrationName] &&\n 0 <\n stateNode.canonical._eventListeners[mangledImperativeRegistrationName]\n .length &&\n stateNode.canonical._eventListeners[\n mangledImperativeRegistrationName\n ].forEach(function(listenerObj) {\n if (\n (null != listenerObj.options.capture && listenerObj.options.capture) ===\n requestedPhaseIsCapture\n ) {\n var listenerFnWrapper = function(syntheticEvent) {\n var eventInst = new ReactNativePrivateInterface.CustomEvent(\n mangledImperativeRegistrationName,\n { detail: syntheticEvent.nativeEvent }\n );\n eventInst.isTrusted = !0;\n eventInst.setSyntheticEvent(syntheticEvent);\n for (\n var _len = arguments.length,\n args = Array(1 < _len ? _len - 1 : 0),\n _key = 1;\n _key < _len;\n _key++\n )\n args[_key - 1] = arguments[_key];\n listenerObj.listener.apply(listenerObj, [eventInst].concat(args));\n };\n listenerObj.options.once\n ? listeners.push(function() {\n stateNode.canonical.removeEventListener_unstable(\n mangledImperativeRegistrationName,\n listenerObj.listener,\n listenerObj.capture\n );\n listenerObj.invalidated ||\n ((listenerObj.invalidated = !0),\n listenerObj.listener.apply(listenerObj, arguments));\n })\n : listeners.push(listenerFnWrapper);\n }\n });\n return 0 === listeners.length\n ? null\n : 1 === listeners.length\n ? listeners[0]\n : listeners;\n}\nvar customBubblingEventTypes =\n ReactNativePrivateInterface.ReactNativeViewConfigRegistry\n .customBubblingEventTypes,\n customDirectEventTypes =\n ReactNativePrivateInterface.ReactNativeViewConfigRegistry\n .customDirectEventTypes;\nfunction accumulateListenersAndInstances(inst, event, listeners) {\n var listenersLength = listeners\n ? isArrayImpl(listeners)\n ? listeners.length\n : 1\n : 0;\n if (0 < listenersLength)\n if (\n ((event._dispatchListeners = accumulateInto(\n event._dispatchListeners,\n listeners\n )),\n null == event._dispatchInstances && 1 === listenersLength)\n )\n event._dispatchInstances = inst;\n else\n for (\n event._dispatchInstances = event._dispatchInstances || [],\n isArrayImpl(event._dispatchInstances) ||\n (event._dispatchInstances = [event._dispatchInstances]),\n listeners = 0;\n listeners < listenersLength;\n listeners++\n )\n event._dispatchInstances.push(inst);\n}\nfunction accumulateDirectionalDispatches$1(inst, phase, event) {\n phase = getListeners(\n inst,\n event.dispatchConfig.phasedRegistrationNames[phase],\n phase,\n !0\n );\n accumulateListenersAndInstances(inst, event, phase);\n}\nfunction traverseTwoPhase$1(inst, fn, arg, skipBubbling) {\n for (var path = []; inst; ) {\n path.push(inst);\n do inst = inst.return;\n while (inst && 5 !== inst.tag);\n inst = inst ? inst : null;\n }\n for (inst = path.length; 0 < inst--; ) fn(path[inst], \"captured\", arg);\n if (skipBubbling) fn(path[0], \"bubbled\", arg);\n else\n for (inst = 0; inst < path.length; inst++) fn(path[inst], \"bubbled\", arg);\n}\nfunction accumulateTwoPhaseDispatchesSingle$1(event) {\n event &&\n event.dispatchConfig.phasedRegistrationNames &&\n traverseTwoPhase$1(\n event._targetInst,\n accumulateDirectionalDispatches$1,\n event,\n !1\n );\n}\nfunction accumulateDirectDispatchesSingle$1(event) {\n if (event && event.dispatchConfig.registrationName) {\n var inst = event._targetInst;\n if (inst && event && event.dispatchConfig.registrationName) {\n var listeners = getListeners(\n inst,\n event.dispatchConfig.registrationName,\n \"bubbled\",\n !1\n );\n accumulateListenersAndInstances(inst, event, listeners);\n }\n }\n}\nif (eventPluginOrder)\n throw Error(\n \"EventPluginRegistry: Cannot inject event plugin ordering more than once. You are likely trying to load more than one copy of React.\"\n );\neventPluginOrder = Array.prototype.slice.call([\n \"ResponderEventPlugin\",\n \"ReactNativeBridgeEventPlugin\"\n]);\nrecomputePluginOrdering();\nvar injectedNamesToPlugins$jscomp$inline_223 = {\n ResponderEventPlugin: ResponderEventPlugin,\n ReactNativeBridgeEventPlugin: {\n eventTypes: {},\n extractEvents: function(\n topLevelType,\n targetInst,\n nativeEvent,\n nativeEventTarget\n ) {\n if (null == targetInst) return null;\n var bubbleDispatchConfig = customBubblingEventTypes[topLevelType],\n directDispatchConfig = customDirectEventTypes[topLevelType];\n if (!bubbleDispatchConfig && !directDispatchConfig)\n throw Error(\n 'Unsupported top level event type \"' + topLevelType + '\" dispatched'\n );\n topLevelType = SyntheticEvent.getPooled(\n bubbleDispatchConfig || directDispatchConfig,\n targetInst,\n nativeEvent,\n nativeEventTarget\n );\n if (bubbleDispatchConfig)\n null != topLevelType &&\n null != topLevelType.dispatchConfig.phasedRegistrationNames &&\n topLevelType.dispatchConfig.phasedRegistrationNames.skipBubbling\n ? topLevelType &&\n topLevelType.dispatchConfig.phasedRegistrationNames &&\n traverseTwoPhase$1(\n topLevelType._targetInst,\n accumulateDirectionalDispatches$1,\n topLevelType,\n !0\n )\n : forEachAccumulated(\n topLevelType,\n accumulateTwoPhaseDispatchesSingle$1\n );\n else if (directDispatchConfig)\n forEachAccumulated(topLevelType, accumulateDirectDispatchesSingle$1);\n else return null;\n return topLevelType;\n }\n }\n },\n isOrderingDirty$jscomp$inline_224 = !1,\n pluginName$jscomp$inline_225;\nfor (pluginName$jscomp$inline_225 in injectedNamesToPlugins$jscomp$inline_223)\n if (\n injectedNamesToPlugins$jscomp$inline_223.hasOwnProperty(\n pluginName$jscomp$inline_225\n )\n ) {\n var pluginModule$jscomp$inline_226 =\n injectedNamesToPlugins$jscomp$inline_223[pluginName$jscomp$inline_225];\n if (\n !namesToPlugins.hasOwnProperty(pluginName$jscomp$inline_225) ||\n namesToPlugins[pluginName$jscomp$inline_225] !==\n pluginModule$jscomp$inline_226\n ) {\n if (namesToPlugins[pluginName$jscomp$inline_225])\n throw Error(\n \"EventPluginRegistry: Cannot inject two different event plugins using the same name, `\" +\n (pluginName$jscomp$inline_225 + \"`.\")\n );\n namesToPlugins[\n pluginName$jscomp$inline_225\n ] = pluginModule$jscomp$inline_226;\n isOrderingDirty$jscomp$inline_224 = !0;\n }\n }\nisOrderingDirty$jscomp$inline_224 && recomputePluginOrdering();\nfunction getInstanceFromInstance(instanceHandle) {\n return instanceHandle;\n}\ngetFiberCurrentPropsFromNode = function(inst) {\n return inst.canonical.currentProps;\n};\ngetInstanceFromNode = getInstanceFromInstance;\ngetNodeFromInstance = function(inst) {\n inst = inst.stateNode.canonical;\n if (!inst._nativeTag) throw Error(\"All native instances should have a tag.\");\n return inst;\n};\nResponderEventPlugin.injection.injectGlobalResponderHandler({\n onChange: function(from, to, blockNativeResponder) {\n var fromOrTo = from || to;\n (fromOrTo = fromOrTo && fromOrTo.stateNode) &&\n fromOrTo.canonical._internalInstanceHandle\n ? (from &&\n nativeFabricUIManager.setIsJSResponder(\n from.stateNode.node,\n !1,\n blockNativeResponder || !1\n ),\n to &&\n nativeFabricUIManager.setIsJSResponder(\n to.stateNode.node,\n !0,\n blockNativeResponder || !1\n ))\n : null !== to\n ? ReactNativePrivateInterface.UIManager.setJSResponder(\n to.stateNode.canonical._nativeTag,\n blockNativeResponder\n )\n : ReactNativePrivateInterface.UIManager.clearJSResponder();\n }\n});\nvar ReactSharedInternals =\n React.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED,\n REACT_ELEMENT_TYPE = Symbol.for(\"react.element\"),\n REACT_PORTAL_TYPE = Symbol.for(\"react.portal\"),\n REACT_FRAGMENT_TYPE = Symbol.for(\"react.fragment\"),\n REACT_STRICT_MODE_TYPE = Symbol.for(\"react.strict_mode\"),\n REACT_PROFILER_TYPE = Symbol.for(\"react.profiler\"),\n REACT_PROVIDER_TYPE = Symbol.for(\"react.provider\"),\n REACT_CONTEXT_TYPE = Symbol.for(\"react.context\"),\n REACT_FORWARD_REF_TYPE = Symbol.for(\"react.forward_ref\"),\n REACT_SUSPENSE_TYPE = Symbol.for(\"react.suspense\"),\n REACT_SUSPENSE_LIST_TYPE = Symbol.for(\"react.suspense_list\"),\n REACT_MEMO_TYPE = Symbol.for(\"react.memo\"),\n REACT_LAZY_TYPE = Symbol.for(\"react.lazy\");\nSymbol.for(\"react.scope\");\nSymbol.for(\"react.debug_trace_mode\");\nvar REACT_OFFSCREEN_TYPE = Symbol.for(\"react.offscreen\");\nSymbol.for(\"react.legacy_hidden\");\nSymbol.for(\"react.cache\");\nSymbol.for(\"react.tracing_marker\");\nvar MAYBE_ITERATOR_SYMBOL = Symbol.iterator;\nfunction getIteratorFn(maybeIterable) {\n if (null === maybeIterable || \"object\" !== typeof maybeIterable) return null;\n maybeIterable =\n (MAYBE_ITERATOR_SYMBOL && maybeIterable[MAYBE_ITERATOR_SYMBOL]) ||\n maybeIterable[\"@@iterator\"];\n return \"function\" === typeof maybeIterable ? maybeIterable : null;\n}\nfunction getComponentNameFromType(type) {\n if (null == type) return null;\n if (\"function\" === typeof type) return type.displayName || type.name || null;\n if (\"string\" === typeof type) return type;\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 (\"object\" === typeof type)\n switch (type.$$typeof) {\n case REACT_CONTEXT_TYPE:\n return (type.displayName || \"Context\") + \".Consumer\";\n case REACT_PROVIDER_TYPE:\n return (type._context.displayName || \"Context\") + \".Provider\";\n case REACT_FORWARD_REF_TYPE:\n var innerType = type.render;\n type = type.displayName;\n type ||\n ((type = innerType.displayName || innerType.name || \"\"),\n (type = \"\" !== type ? \"ForwardRef(\" + type + \")\" : \"ForwardRef\"));\n return type;\n case REACT_MEMO_TYPE:\n return (\n (innerType = type.displayName || null),\n null !== innerType\n ? innerType\n : getComponentNameFromType(type.type) || \"Memo\"\n );\n case REACT_LAZY_TYPE:\n innerType = type._payload;\n type = type._init;\n try {\n return getComponentNameFromType(type(innerType));\n } catch (x) {}\n }\n return null;\n}\nfunction getComponentNameFromFiber(fiber) {\n var type = fiber.type;\n switch (fiber.tag) {\n case 24:\n return \"Cache\";\n case 9:\n return (type.displayName || \"Context\") + \".Consumer\";\n case 10:\n return (type._context.displayName || \"Context\") + \".Provider\";\n case 18:\n return \"DehydratedFragment\";\n case 11:\n return (\n (fiber = type.render),\n (fiber = fiber.displayName || fiber.name || \"\"),\n type.displayName ||\n (\"\" !== fiber ? \"ForwardRef(\" + fiber + \")\" : \"ForwardRef\")\n );\n case 7:\n return \"Fragment\";\n case 5:\n return type;\n case 4:\n return \"Portal\";\n case 3:\n return \"Root\";\n case 6:\n return \"Text\";\n case 16:\n return getComponentNameFromType(type);\n case 8:\n return type === REACT_STRICT_MODE_TYPE ? \"StrictMode\" : \"Mode\";\n case 22:\n return \"Offscreen\";\n case 12:\n return \"Profiler\";\n case 21:\n return \"Scope\";\n case 13:\n return \"Suspense\";\n case 19:\n return \"SuspenseList\";\n case 25:\n return \"TracingMarker\";\n case 1:\n case 0:\n case 17:\n case 2:\n case 14:\n case 15:\n if (\"function\" === typeof type)\n return type.displayName || type.name || null;\n if (\"string\" === typeof type) return type;\n }\n return null;\n}\nfunction getNearestMountedFiber(fiber) {\n var node = fiber,\n nearestMounted = fiber;\n if (fiber.alternate) for (; node.return; ) node = node.return;\n else {\n fiber = node;\n do\n (node = fiber),\n 0 !== (node.flags & 4098) && (nearestMounted = node.return),\n (fiber = node.return);\n while (fiber);\n }\n return 3 === node.tag ? nearestMounted : null;\n}\nfunction assertIsMounted(fiber) {\n if (getNearestMountedFiber(fiber) !== fiber)\n throw Error(\"Unable to find node on an unmounted component.\");\n}\nfunction findCurrentFiberUsingSlowPath(fiber) {\n var alternate = fiber.alternate;\n if (!alternate) {\n alternate = getNearestMountedFiber(fiber);\n if (null === alternate)\n throw Error(\"Unable to find node on an unmounted component.\");\n return alternate !== fiber ? null : fiber;\n }\n for (var a = fiber, b = alternate; ; ) {\n var parentA = a.return;\n if (null === parentA) break;\n var parentB = parentA.alternate;\n if (null === parentB) {\n b = parentA.return;\n if (null !== b) {\n a = b;\n continue;\n }\n break;\n }\n if (parentA.child === parentB.child) {\n for (parentB = parentA.child; parentB; ) {\n if (parentB === a) return assertIsMounted(parentA), fiber;\n if (parentB === b) return assertIsMounted(parentA), alternate;\n parentB = parentB.sibling;\n }\n throw Error(\"Unable to find node on an unmounted component.\");\n }\n if (a.return !== b.return) (a = parentA), (b = parentB);\n else {\n for (var didFindChild = !1, child$0 = parentA.child; child$0; ) {\n if (child$0 === a) {\n didFindChild = !0;\n a = parentA;\n b = parentB;\n break;\n }\n if (child$0 === b) {\n didFindChild = !0;\n b = parentA;\n a = parentB;\n break;\n }\n child$0 = child$0.sibling;\n }\n if (!didFindChild) {\n for (child$0 = parentB.child; child$0; ) {\n if (child$0 === a) {\n didFindChild = !0;\n a = parentB;\n b = parentA;\n break;\n }\n if (child$0 === b) {\n didFindChild = !0;\n b = parentB;\n a = parentA;\n break;\n }\n child$0 = child$0.sibling;\n }\n if (!didFindChild)\n throw Error(\n \"Child was not found in either parent set. This indicates a bug in React related to the return pointer. Please file an issue.\"\n );\n }\n }\n if (a.alternate !== b)\n throw Error(\n \"Return fibers should always be each others' alternates. This error is likely caused by a bug in React. Please file an issue.\"\n );\n }\n if (3 !== a.tag)\n throw Error(\"Unable to find node on an unmounted component.\");\n return a.stateNode.current === a ? fiber : alternate;\n}\nfunction findCurrentHostFiber(parent) {\n parent = findCurrentFiberUsingSlowPath(parent);\n return null !== parent ? findCurrentHostFiberImpl(parent) : null;\n}\nfunction findCurrentHostFiberImpl(node) {\n if (5 === node.tag || 6 === node.tag) return node;\n for (node = node.child; null !== node; ) {\n var match = findCurrentHostFiberImpl(node);\n if (null !== match) return match;\n node = node.sibling;\n }\n return null;\n}\nfunction mountSafeCallback_NOT_REALLY_SAFE(context, callback) {\n return function() {\n if (\n callback &&\n (\"boolean\" !== typeof context.__isMounted || context.__isMounted)\n )\n return callback.apply(context, arguments);\n };\n}\nvar emptyObject = {},\n removedKeys = null,\n removedKeyCount = 0,\n deepDifferOptions = { unsafelyIgnoreFunctions: !0 };\nfunction defaultDiffer(prevProp, nextProp) {\n return \"object\" !== typeof nextProp || null === nextProp\n ? !0\n : ReactNativePrivateInterface.deepDiffer(\n prevProp,\n nextProp,\n deepDifferOptions\n );\n}\nfunction restoreDeletedValuesInNestedArray(\n updatePayload,\n node,\n validAttributes\n) {\n if (isArrayImpl(node))\n for (var i = node.length; i-- && 0 < removedKeyCount; )\n restoreDeletedValuesInNestedArray(\n updatePayload,\n node[i],\n validAttributes\n );\n else if (node && 0 < removedKeyCount)\n for (i in removedKeys)\n if (removedKeys[i]) {\n var nextProp = node[i];\n if (void 0 !== nextProp) {\n var attributeConfig = validAttributes[i];\n if (attributeConfig) {\n \"function\" === typeof nextProp && (nextProp = !0);\n \"undefined\" === typeof nextProp && (nextProp = null);\n if (\"object\" !== typeof attributeConfig)\n updatePayload[i] = nextProp;\n else if (\n \"function\" === typeof attributeConfig.diff ||\n \"function\" === typeof attributeConfig.process\n )\n (nextProp =\n \"function\" === typeof attributeConfig.process\n ? attributeConfig.process(nextProp)\n : nextProp),\n (updatePayload[i] = nextProp);\n removedKeys[i] = !1;\n removedKeyCount--;\n }\n }\n }\n}\nfunction diffNestedProperty(\n updatePayload,\n prevProp,\n nextProp,\n validAttributes\n) {\n if (!updatePayload && prevProp === nextProp) return updatePayload;\n if (!prevProp || !nextProp)\n return nextProp\n ? addNestedProperty(updatePayload, nextProp, validAttributes)\n : prevProp\n ? clearNestedProperty(updatePayload, prevProp, validAttributes)\n : updatePayload;\n if (!isArrayImpl(prevProp) && !isArrayImpl(nextProp))\n return diffProperties(updatePayload, prevProp, nextProp, validAttributes);\n if (isArrayImpl(prevProp) && isArrayImpl(nextProp)) {\n var minLength =\n prevProp.length < nextProp.length ? prevProp.length : nextProp.length,\n i;\n for (i = 0; i < minLength; i++)\n updatePayload = diffNestedProperty(\n updatePayload,\n prevProp[i],\n nextProp[i],\n validAttributes\n );\n for (; i < prevProp.length; i++)\n updatePayload = clearNestedProperty(\n updatePayload,\n prevProp[i],\n validAttributes\n );\n for (; i < nextProp.length; i++)\n updatePayload = addNestedProperty(\n updatePayload,\n nextProp[i],\n validAttributes\n );\n return updatePayload;\n }\n return isArrayImpl(prevProp)\n ? diffProperties(\n updatePayload,\n ReactNativePrivateInterface.flattenStyle(prevProp),\n nextProp,\n validAttributes\n )\n : diffProperties(\n updatePayload,\n prevProp,\n ReactNativePrivateInterface.flattenStyle(nextProp),\n validAttributes\n );\n}\nfunction addNestedProperty(updatePayload, nextProp, validAttributes) {\n if (!nextProp) return updatePayload;\n if (!isArrayImpl(nextProp))\n return diffProperties(\n updatePayload,\n emptyObject,\n nextProp,\n validAttributes\n );\n for (var i = 0; i < nextProp.length; i++)\n updatePayload = addNestedProperty(\n updatePayload,\n nextProp[i],\n validAttributes\n );\n return updatePayload;\n}\nfunction clearNestedProperty(updatePayload, prevProp, validAttributes) {\n if (!prevProp) return updatePayload;\n if (!isArrayImpl(prevProp))\n return diffProperties(\n updatePayload,\n prevProp,\n emptyObject,\n validAttributes\n );\n for (var i = 0; i < prevProp.length; i++)\n updatePayload = clearNestedProperty(\n updatePayload,\n prevProp[i],\n validAttributes\n );\n return updatePayload;\n}\nfunction diffProperties(updatePayload, prevProps, nextProps, validAttributes) {\n var attributeConfig, propKey;\n for (propKey in nextProps)\n if ((attributeConfig = validAttributes[propKey])) {\n var prevProp = prevProps[propKey];\n var nextProp = nextProps[propKey];\n \"function\" === typeof nextProp &&\n ((nextProp = !0), \"function\" === typeof prevProp && (prevProp = !0));\n \"undefined\" === typeof nextProp &&\n ((nextProp = null),\n \"undefined\" === typeof prevProp && (prevProp = null));\n removedKeys && (removedKeys[propKey] = !1);\n if (updatePayload && void 0 !== updatePayload[propKey])\n if (\"object\" !== typeof attributeConfig)\n updatePayload[propKey] = nextProp;\n else {\n if (\n \"function\" === typeof attributeConfig.diff ||\n \"function\" === typeof attributeConfig.process\n )\n (attributeConfig =\n \"function\" === typeof attributeConfig.process\n ? attributeConfig.process(nextProp)\n : nextProp),\n (updatePayload[propKey] = attributeConfig);\n }\n else if (prevProp !== nextProp)\n if (\"object\" !== typeof attributeConfig)\n defaultDiffer(prevProp, nextProp) &&\n ((updatePayload || (updatePayload = {}))[propKey] = nextProp);\n else if (\n \"function\" === typeof attributeConfig.diff ||\n \"function\" === typeof attributeConfig.process\n ) {\n if (\n void 0 === prevProp ||\n (\"function\" === typeof attributeConfig.diff\n ? attributeConfig.diff(prevProp, nextProp)\n : defaultDiffer(prevProp, nextProp))\n )\n (attributeConfig =\n \"function\" === typeof attributeConfig.process\n ? attributeConfig.process(nextProp)\n : nextProp),\n ((updatePayload || (updatePayload = {}))[\n propKey\n ] = attributeConfig);\n } else\n (removedKeys = null),\n (removedKeyCount = 0),\n (updatePayload = diffNestedProperty(\n updatePayload,\n prevProp,\n nextProp,\n attributeConfig\n )),\n 0 < removedKeyCount &&\n updatePayload &&\n (restoreDeletedValuesInNestedArray(\n updatePayload,\n nextProp,\n attributeConfig\n ),\n (removedKeys = null));\n }\n for (var propKey$2 in prevProps)\n void 0 === nextProps[propKey$2] &&\n (!(attributeConfig = validAttributes[propKey$2]) ||\n (updatePayload && void 0 !== updatePayload[propKey$2]) ||\n ((prevProp = prevProps[propKey$2]),\n void 0 !== prevProp &&\n (\"object\" !== typeof attributeConfig ||\n \"function\" === typeof attributeConfig.diff ||\n \"function\" === typeof attributeConfig.process\n ? (((updatePayload || (updatePayload = {}))[propKey$2] = null),\n removedKeys || (removedKeys = {}),\n removedKeys[propKey$2] ||\n ((removedKeys[propKey$2] = !0), removedKeyCount++))\n : (updatePayload = clearNestedProperty(\n updatePayload,\n prevProp,\n attributeConfig\n )))));\n return updatePayload;\n}\nfunction batchedUpdatesImpl(fn, bookkeeping) {\n return fn(bookkeeping);\n}\nvar isInsideEventHandler = !1;\nfunction batchedUpdates(fn, bookkeeping) {\n if (isInsideEventHandler) return fn(bookkeeping);\n isInsideEventHandler = !0;\n try {\n return batchedUpdatesImpl(fn, bookkeeping);\n } finally {\n isInsideEventHandler = !1;\n }\n}\nvar eventQueue = null;\nfunction executeDispatchesAndReleaseTopLevel(e) {\n if (e) {\n var dispatchListeners = e._dispatchListeners,\n dispatchInstances = e._dispatchInstances;\n if (isArrayImpl(dispatchListeners))\n for (\n var i = 0;\n i < dispatchListeners.length && !e.isPropagationStopped();\n i++\n )\n executeDispatch(e, dispatchListeners[i], dispatchInstances[i]);\n else\n dispatchListeners &&\n executeDispatch(e, dispatchListeners, dispatchInstances);\n e._dispatchListeners = null;\n e._dispatchInstances = null;\n e.isPersistent() || e.constructor.release(e);\n }\n}\nfunction dispatchEvent(target, topLevelType, nativeEvent) {\n var eventTarget = null;\n if (null != target) {\n var stateNode = target.stateNode;\n null != stateNode && (eventTarget = stateNode.canonical);\n }\n batchedUpdates(function() {\n var event = { eventName: topLevelType, nativeEvent: nativeEvent };\n ReactNativePrivateInterface.RawEventEmitter.emit(topLevelType, event);\n ReactNativePrivateInterface.RawEventEmitter.emit(\"*\", event);\n event = eventTarget;\n for (\n var events = null, legacyPlugins = plugins, i = 0;\n i < legacyPlugins.length;\n i++\n ) {\n var possiblePlugin = legacyPlugins[i];\n possiblePlugin &&\n (possiblePlugin = possiblePlugin.extractEvents(\n topLevelType,\n target,\n nativeEvent,\n event\n )) &&\n (events = accumulateInto(events, possiblePlugin));\n }\n event = events;\n null !== event && (eventQueue = accumulateInto(eventQueue, event));\n event = eventQueue;\n eventQueue = null;\n if (event) {\n forEachAccumulated(event, executeDispatchesAndReleaseTopLevel);\n if (eventQueue)\n throw Error(\n \"processEventQueue(): Additional events were enqueued while processing an event queue. Support for this has not yet been implemented.\"\n );\n if (hasRethrowError)\n throw ((event = rethrowError),\n (hasRethrowError = !1),\n (rethrowError = null),\n event);\n }\n });\n}\nvar scheduleCallback = Scheduler.unstable_scheduleCallback,\n cancelCallback = Scheduler.unstable_cancelCallback,\n shouldYield = Scheduler.unstable_shouldYield,\n requestPaint = Scheduler.unstable_requestPaint,\n now = Scheduler.unstable_now,\n ImmediatePriority = Scheduler.unstable_ImmediatePriority,\n UserBlockingPriority = Scheduler.unstable_UserBlockingPriority,\n NormalPriority = Scheduler.unstable_NormalPriority,\n IdlePriority = Scheduler.unstable_IdlePriority,\n rendererID = null,\n injectedHook = null;\nfunction onCommitRoot(root) {\n if (injectedHook && \"function\" === typeof injectedHook.onCommitFiberRoot)\n try {\n injectedHook.onCommitFiberRoot(\n rendererID,\n root,\n void 0,\n 128 === (root.current.flags & 128)\n );\n } catch (err) {}\n}\nvar clz32 = Math.clz32 ? Math.clz32 : clz32Fallback,\n log = Math.log,\n LN2 = Math.LN2;\nfunction clz32Fallback(x) {\n x >>>= 0;\n return 0 === x ? 32 : (31 - ((log(x) / LN2) | 0)) | 0;\n}\nvar nextTransitionLane = 64,\n nextRetryLane = 4194304;\nfunction getHighestPriorityLanes(lanes) {\n switch (lanes & -lanes) {\n case 1:\n return 1;\n case 2:\n return 2;\n case 4:\n return 4;\n case 8:\n return 8;\n case 16:\n return 16;\n case 32:\n return 32;\n case 64:\n case 128:\n case 256:\n case 512:\n case 1024:\n case 2048:\n case 4096:\n case 8192:\n case 16384:\n case 32768:\n case 65536:\n case 131072:\n case 262144:\n case 524288:\n case 1048576:\n case 2097152:\n return lanes & 4194240;\n case 4194304:\n case 8388608:\n case 16777216:\n case 33554432:\n case 67108864:\n return lanes & 130023424;\n case 134217728:\n return 134217728;\n case 268435456:\n return 268435456;\n case 536870912:\n return 536870912;\n case 1073741824:\n return 1073741824;\n default:\n return lanes;\n }\n}\nfunction getNextLanes(root, wipLanes) {\n var pendingLanes = root.pendingLanes;\n if (0 === pendingLanes) return 0;\n var nextLanes = 0,\n suspendedLanes = root.suspendedLanes,\n pingedLanes = root.pingedLanes,\n nonIdlePendingLanes = pendingLanes & 268435455;\n if (0 !== nonIdlePendingLanes) {\n var nonIdleUnblockedLanes = nonIdlePendingLanes & ~suspendedLanes;\n 0 !== nonIdleUnblockedLanes\n ? (nextLanes = getHighestPriorityLanes(nonIdleUnblockedLanes))\n : ((pingedLanes &= nonIdlePendingLanes),\n 0 !== pingedLanes &&\n (nextLanes = getHighestPriorityLanes(pingedLanes)));\n } else\n (nonIdlePendingLanes = pendingLanes & ~suspendedLanes),\n 0 !== nonIdlePendingLanes\n ? (nextLanes = getHighestPriorityLanes(nonIdlePendingLanes))\n : 0 !== pingedLanes &&\n (nextLanes = getHighestPriorityLanes(pingedLanes));\n if (0 === nextLanes) return 0;\n if (\n 0 !== wipLanes &&\n wipLanes !== nextLanes &&\n 0 === (wipLanes & suspendedLanes) &&\n ((suspendedLanes = nextLanes & -nextLanes),\n (pingedLanes = wipLanes & -wipLanes),\n suspendedLanes >= pingedLanes ||\n (16 === suspendedLanes && 0 !== (pingedLanes & 4194240)))\n )\n return wipLanes;\n 0 !== (nextLanes & 4) && (nextLanes |= pendingLanes & 16);\n wipLanes = root.entangledLanes;\n if (0 !== wipLanes)\n for (root = root.entanglements, wipLanes &= nextLanes; 0 < wipLanes; )\n (pendingLanes = 31 - clz32(wipLanes)),\n (suspendedLanes = 1 << pendingLanes),\n (nextLanes |= root[pendingLanes]),\n (wipLanes &= ~suspendedLanes);\n return nextLanes;\n}\nfunction computeExpirationTime(lane, currentTime) {\n switch (lane) {\n case 1:\n case 2:\n case 4:\n return currentTime + 250;\n case 8:\n case 16:\n case 32:\n case 64:\n case 128:\n case 256:\n case 512:\n case 1024:\n case 2048:\n case 4096:\n case 8192:\n case 16384:\n case 32768:\n case 65536:\n case 131072:\n case 262144:\n case 524288:\n case 1048576:\n case 2097152:\n return currentTime + 5e3;\n case 4194304:\n case 8388608:\n case 16777216:\n case 33554432:\n case 67108864:\n return -1;\n case 134217728:\n case 268435456:\n case 536870912:\n case 1073741824:\n return -1;\n default:\n return -1;\n }\n}\nfunction getLanesToRetrySynchronouslyOnError(root) {\n root = root.pendingLanes & -1073741825;\n return 0 !== root ? root : root & 1073741824 ? 1073741824 : 0;\n}\nfunction claimNextTransitionLane() {\n var lane = nextTransitionLane;\n nextTransitionLane <<= 1;\n 0 === (nextTransitionLane & 4194240) && (nextTransitionLane = 64);\n return lane;\n}\nfunction createLaneMap(initial) {\n for (var laneMap = [], i = 0; 31 > i; i++) laneMap.push(initial);\n return laneMap;\n}\nfunction markRootUpdated(root, updateLane, eventTime) {\n root.pendingLanes |= updateLane;\n 536870912 !== updateLane &&\n ((root.suspendedLanes = 0), (root.pingedLanes = 0));\n root = root.eventTimes;\n updateLane = 31 - clz32(updateLane);\n root[updateLane] = eventTime;\n}\nfunction markRootFinished(root, remainingLanes) {\n var noLongerPendingLanes = root.pendingLanes & ~remainingLanes;\n root.pendingLanes = remainingLanes;\n root.suspendedLanes = 0;\n root.pingedLanes = 0;\n root.expiredLanes &= remainingLanes;\n root.mutableReadLanes &= remainingLanes;\n root.entangledLanes &= remainingLanes;\n remainingLanes = root.entanglements;\n var eventTimes = root.eventTimes;\n for (root = root.expirationTimes; 0 < noLongerPendingLanes; ) {\n var index$7 = 31 - clz32(noLongerPendingLanes),\n lane = 1 << index$7;\n remainingLanes[index$7] = 0;\n eventTimes[index$7] = -1;\n root[index$7] = -1;\n noLongerPendingLanes &= ~lane;\n }\n}\nfunction markRootEntangled(root, entangledLanes) {\n var rootEntangledLanes = (root.entangledLanes |= entangledLanes);\n for (root = root.entanglements; rootEntangledLanes; ) {\n var index$8 = 31 - clz32(rootEntangledLanes),\n lane = 1 << index$8;\n (lane & entangledLanes) | (root[index$8] & entangledLanes) &&\n (root[index$8] |= entangledLanes);\n rootEntangledLanes &= ~lane;\n }\n}\nvar currentUpdatePriority = 0;\nfunction lanesToEventPriority(lanes) {\n lanes &= -lanes;\n return 1 < lanes\n ? 4 < lanes\n ? 0 !== (lanes & 268435455)\n ? 16\n : 536870912\n : 4\n : 1;\n}\nfunction shim$1() {\n throw Error(\n \"The current renderer does not support hydration. This error is likely caused by a bug in React. Please file an issue.\"\n );\n}\nvar _nativeFabricUIManage = nativeFabricUIManager,\n createNode = _nativeFabricUIManage.createNode,\n cloneNode = _nativeFabricUIManage.cloneNode,\n cloneNodeWithNewChildren = _nativeFabricUIManage.cloneNodeWithNewChildren,\n cloneNodeWithNewChildrenAndProps =\n _nativeFabricUIManage.cloneNodeWithNewChildrenAndProps,\n cloneNodeWithNewProps = _nativeFabricUIManage.cloneNodeWithNewProps,\n createChildNodeSet = _nativeFabricUIManage.createChildSet,\n appendChildNode = _nativeFabricUIManage.appendChild,\n appendChildNodeToSet = _nativeFabricUIManage.appendChildToSet,\n completeRoot = _nativeFabricUIManage.completeRoot,\n registerEventHandler = _nativeFabricUIManage.registerEventHandler,\n fabricMeasure = _nativeFabricUIManage.measure,\n fabricMeasureInWindow = _nativeFabricUIManage.measureInWindow,\n fabricMeasureLayout = _nativeFabricUIManage.measureLayout,\n FabricDiscretePriority = _nativeFabricUIManage.unstable_DiscreteEventPriority,\n fabricGetCurrentEventPriority =\n _nativeFabricUIManage.unstable_getCurrentEventPriority,\n getViewConfigForType =\n ReactNativePrivateInterface.ReactNativeViewConfigRegistry.get,\n nextReactTag = 2;\nregisterEventHandler && registerEventHandler(dispatchEvent);\nvar ReactFabricHostComponent = (function() {\n function ReactFabricHostComponent(\n tag,\n viewConfig,\n props,\n internalInstanceHandle\n ) {\n this._nativeTag = tag;\n this.viewConfig = viewConfig;\n this.currentProps = props;\n this._internalInstanceHandle = internalInstanceHandle;\n }\n var _proto = ReactFabricHostComponent.prototype;\n _proto.blur = function() {\n ReactNativePrivateInterface.TextInputState.blurTextInput(this);\n };\n _proto.focus = function() {\n ReactNativePrivateInterface.TextInputState.focusTextInput(this);\n };\n _proto.measure = function(callback) {\n var stateNode = this._internalInstanceHandle.stateNode;\n null != stateNode &&\n fabricMeasure(\n stateNode.node,\n mountSafeCallback_NOT_REALLY_SAFE(this, callback)\n );\n };\n _proto.measureInWindow = function(callback) {\n var stateNode = this._internalInstanceHandle.stateNode;\n null != stateNode &&\n fabricMeasureInWindow(\n stateNode.node,\n mountSafeCallback_NOT_REALLY_SAFE(this, callback)\n );\n };\n _proto.measureLayout = function(relativeToNativeNode, onSuccess, onFail) {\n if (\n \"number\" !== typeof relativeToNativeNode &&\n relativeToNativeNode instanceof ReactFabricHostComponent\n ) {\n var toStateNode = this._internalInstanceHandle.stateNode;\n relativeToNativeNode =\n relativeToNativeNode._internalInstanceHandle.stateNode;\n null != toStateNode &&\n null != relativeToNativeNode &&\n fabricMeasureLayout(\n toStateNode.node,\n relativeToNativeNode.node,\n mountSafeCallback_NOT_REALLY_SAFE(this, onFail),\n mountSafeCallback_NOT_REALLY_SAFE(this, onSuccess)\n );\n }\n };\n _proto.setNativeProps = function() {};\n _proto.addEventListener_unstable = function(eventType, listener, options) {\n if (\"string\" !== typeof eventType)\n throw Error(\"addEventListener_unstable eventType must be a string\");\n if (\"function\" !== typeof listener)\n throw Error(\"addEventListener_unstable listener must be a function\");\n var optionsObj =\n \"object\" === typeof options && null !== options ? options : {};\n options =\n (\"boolean\" === typeof options ? options : optionsObj.capture) || !1;\n var once = optionsObj.once || !1;\n optionsObj = optionsObj.passive || !1;\n var eventListeners = this._eventListeners || {};\n null == this._eventListeners && (this._eventListeners = eventListeners);\n var namedEventListeners = eventListeners[eventType] || [];\n null == eventListeners[eventType] &&\n (eventListeners[eventType] = namedEventListeners);\n namedEventListeners.push({\n listener: listener,\n invalidated: !1,\n options: {\n capture: options,\n once: once,\n passive: optionsObj,\n signal: null\n }\n });\n };\n _proto.removeEventListener_unstable = function(eventType, listener, options) {\n var optionsObj =\n \"object\" === typeof options && null !== options ? options : {},\n capture =\n (\"boolean\" === typeof options ? options : optionsObj.capture) || !1;\n (options = this._eventListeners) &&\n (optionsObj = options[eventType]) &&\n (options[eventType] = optionsObj.filter(function(listenerObj) {\n return !(\n listenerObj.listener === listener &&\n listenerObj.options.capture === capture\n );\n }));\n };\n return ReactFabricHostComponent;\n})();\nfunction createTextInstance(\n text,\n rootContainerInstance,\n hostContext,\n internalInstanceHandle\n) {\n hostContext = nextReactTag;\n nextReactTag += 2;\n return {\n node: createNode(\n hostContext,\n \"RCTRawText\",\n rootContainerInstance,\n { text: text },\n internalInstanceHandle\n )\n };\n}\nvar scheduleTimeout = setTimeout,\n cancelTimeout = clearTimeout;\nfunction cloneHiddenInstance(instance) {\n var node = instance.node;\n var JSCompiler_inline_result = diffProperties(\n null,\n emptyObject,\n { style: { display: \"none\" } },\n instance.canonical.viewConfig.validAttributes\n );\n return {\n node: cloneNodeWithNewProps(node, JSCompiler_inline_result),\n canonical: instance.canonical\n };\n}\nfunction describeComponentFrame(name, source, ownerName) {\n source = \"\";\n ownerName && (source = \" (created by \" + ownerName + \")\");\n return \"\\n in \" + (name || \"Unknown\") + source;\n}\nfunction describeFunctionComponentFrame(fn, source) {\n return fn\n ? describeComponentFrame(fn.displayName || fn.name || null, source, null)\n : \"\";\n}\nvar hasOwnProperty = Object.prototype.hasOwnProperty,\n valueStack = [],\n index = -1;\nfunction createCursor(defaultValue) {\n return { current: defaultValue };\n}\nfunction pop(cursor) {\n 0 > index ||\n ((cursor.current = valueStack[index]), (valueStack[index] = null), index--);\n}\nfunction push(cursor, value) {\n index++;\n valueStack[index] = cursor.current;\n cursor.current = value;\n}\nvar emptyContextObject = {},\n contextStackCursor = createCursor(emptyContextObject),\n didPerformWorkStackCursor = createCursor(!1),\n previousContext = emptyContextObject;\nfunction getMaskedContext(workInProgress, unmaskedContext) {\n var contextTypes = workInProgress.type.contextTypes;\n if (!contextTypes) return emptyContextObject;\n var instance = workInProgress.stateNode;\n if (\n instance &&\n instance.__reactInternalMemoizedUnmaskedChildContext === unmaskedContext\n )\n return instance.__reactInternalMemoizedMaskedChildContext;\n var context = {},\n key;\n for (key in contextTypes) context[key] = unmaskedContext[key];\n instance &&\n ((workInProgress = workInProgress.stateNode),\n (workInProgress.__reactInternalMemoizedUnmaskedChildContext = unmaskedContext),\n (workInProgress.__reactInternalMemoizedMaskedChildContext = context));\n return context;\n}\nfunction isContextProvider(type) {\n type = type.childContextTypes;\n return null !== type && void 0 !== type;\n}\nfunction popContext() {\n pop(didPerformWorkStackCursor);\n pop(contextStackCursor);\n}\nfunction pushTopLevelContextObject(fiber, context, didChange) {\n if (contextStackCursor.current !== emptyContextObject)\n throw Error(\n \"Unexpected context found on stack. This error is likely caused by a bug in React. Please file an issue.\"\n );\n push(contextStackCursor, context);\n push(didPerformWorkStackCursor, didChange);\n}\nfunction processChildContext(fiber, type, parentContext) {\n var instance = fiber.stateNode;\n type = type.childContextTypes;\n if (\"function\" !== typeof instance.getChildContext) return parentContext;\n instance = instance.getChildContext();\n for (var contextKey in instance)\n if (!(contextKey in type))\n throw Error(\n (getComponentNameFromFiber(fiber) || \"Unknown\") +\n '.getChildContext(): key \"' +\n contextKey +\n '\" is not defined in childContextTypes.'\n );\n return assign({}, parentContext, instance);\n}\nfunction pushContextProvider(workInProgress) {\n workInProgress =\n ((workInProgress = workInProgress.stateNode) &&\n workInProgress.__reactInternalMemoizedMergedChildContext) ||\n emptyContextObject;\n previousContext = contextStackCursor.current;\n push(contextStackCursor, workInProgress);\n push(didPerformWorkStackCursor, didPerformWorkStackCursor.current);\n return !0;\n}\nfunction invalidateContextProvider(workInProgress, type, didChange) {\n var instance = workInProgress.stateNode;\n if (!instance)\n throw Error(\n \"Expected to have an instance by this point. This error is likely caused by a bug in React. Please file an issue.\"\n );\n didChange\n ? ((workInProgress = processChildContext(\n workInProgress,\n type,\n previousContext\n )),\n (instance.__reactInternalMemoizedMergedChildContext = workInProgress),\n pop(didPerformWorkStackCursor),\n pop(contextStackCursor),\n push(contextStackCursor, workInProgress))\n : pop(didPerformWorkStackCursor);\n push(didPerformWorkStackCursor, didChange);\n}\nfunction is(x, y) {\n return (x === y && (0 !== x || 1 / x === 1 / y)) || (x !== x && y !== y);\n}\nvar objectIs = \"function\" === typeof Object.is ? Object.is : is,\n syncQueue = null,\n includesLegacySyncCallbacks = !1,\n isFlushingSyncQueue = !1;\nfunction flushSyncCallbacks() {\n if (!isFlushingSyncQueue && null !== syncQueue) {\n isFlushingSyncQueue = !0;\n var i = 0,\n previousUpdatePriority = currentUpdatePriority;\n try {\n var queue = syncQueue;\n for (currentUpdatePriority = 1; i < queue.length; i++) {\n var callback = queue[i];\n do callback = callback(!0);\n while (null !== callback);\n }\n syncQueue = null;\n includesLegacySyncCallbacks = !1;\n } catch (error) {\n throw (null !== syncQueue && (syncQueue = syncQueue.slice(i + 1)),\n scheduleCallback(ImmediatePriority, flushSyncCallbacks),\n error);\n } finally {\n (currentUpdatePriority = previousUpdatePriority),\n (isFlushingSyncQueue = !1);\n }\n }\n return null;\n}\nvar forkStack = [],\n forkStackIndex = 0,\n treeForkProvider = null,\n idStack = [],\n idStackIndex = 0,\n treeContextProvider = null;\nfunction popTreeContext(workInProgress) {\n for (; workInProgress === treeForkProvider; )\n (treeForkProvider = forkStack[--forkStackIndex]),\n (forkStack[forkStackIndex] = null),\n --forkStackIndex,\n (forkStack[forkStackIndex] = null);\n for (; workInProgress === treeContextProvider; )\n (treeContextProvider = idStack[--idStackIndex]),\n (idStack[idStackIndex] = null),\n --idStackIndex,\n (idStack[idStackIndex] = null),\n --idStackIndex,\n (idStack[idStackIndex] = null);\n}\nvar hydrationErrors = null,\n ReactCurrentBatchConfig = ReactSharedInternals.ReactCurrentBatchConfig;\nfunction shallowEqual(objA, objB) {\n if (objectIs(objA, objB)) return !0;\n if (\n \"object\" !== typeof objA ||\n null === objA ||\n \"object\" !== typeof objB ||\n null === objB\n )\n return !1;\n var keysA = Object.keys(objA),\n keysB = Object.keys(objB);\n if (keysA.length !== keysB.length) return !1;\n for (keysB = 0; keysB < keysA.length; keysB++) {\n var currentKey = keysA[keysB];\n if (\n !hasOwnProperty.call(objB, currentKey) ||\n !objectIs(objA[currentKey], objB[currentKey])\n )\n return !1;\n }\n return !0;\n}\nfunction describeFiber(fiber) {\n switch (fiber.tag) {\n case 5:\n return describeComponentFrame(fiber.type, null, null);\n case 16:\n return describeComponentFrame(\"Lazy\", null, null);\n case 13:\n return describeComponentFrame(\"Suspense\", null, null);\n case 19:\n return describeComponentFrame(\"SuspenseList\", null, null);\n case 0:\n case 2:\n case 15:\n return describeFunctionComponentFrame(fiber.type, null);\n case 11:\n return describeFunctionComponentFrame(fiber.type.render, null);\n case 1:\n return (fiber = describeFunctionComponentFrame(fiber.type, null)), fiber;\n default:\n return \"\";\n }\n}\nfunction resolveDefaultProps(Component, baseProps) {\n if (Component && Component.defaultProps) {\n baseProps = assign({}, baseProps);\n Component = Component.defaultProps;\n for (var propName in Component)\n void 0 === baseProps[propName] &&\n (baseProps[propName] = Component[propName]);\n return baseProps;\n }\n return baseProps;\n}\nvar valueCursor = createCursor(null),\n currentlyRenderingFiber = null,\n lastContextDependency = null,\n lastFullyObservedContext = null;\nfunction resetContextDependencies() {\n lastFullyObservedContext = lastContextDependency = currentlyRenderingFiber = null;\n}\nfunction popProvider(context) {\n var currentValue = valueCursor.current;\n pop(valueCursor);\n context._currentValue2 = currentValue;\n}\nfunction scheduleContextWorkOnParentPath(parent, renderLanes, propagationRoot) {\n for (; null !== parent; ) {\n var alternate = parent.alternate;\n (parent.childLanes & renderLanes) !== renderLanes\n ? ((parent.childLanes |= renderLanes),\n null !== alternate && (alternate.childLanes |= renderLanes))\n : null !== alternate &&\n (alternate.childLanes & renderLanes) !== renderLanes &&\n (alternate.childLanes |= renderLanes);\n if (parent === propagationRoot) break;\n parent = parent.return;\n }\n}\nfunction prepareToReadContext(workInProgress, renderLanes) {\n currentlyRenderingFiber = workInProgress;\n lastFullyObservedContext = lastContextDependency = null;\n workInProgress = workInProgress.dependencies;\n null !== workInProgress &&\n null !== workInProgress.firstContext &&\n (0 !== (workInProgress.lanes & renderLanes) && (didReceiveUpdate = !0),\n (workInProgress.firstContext = null));\n}\nfunction readContext(context) {\n var value = context._currentValue2;\n if (lastFullyObservedContext !== context)\n if (\n ((context = { context: context, memoizedValue: value, next: null }),\n null === lastContextDependency)\n ) {\n if (null === currentlyRenderingFiber)\n throw Error(\n \"Context can only be read while React is rendering. In classes, you can read it in the render method or getDerivedStateFromProps. In function components, you can read it directly in the function body, but not inside Hooks like useReducer() or useMemo().\"\n );\n lastContextDependency = context;\n currentlyRenderingFiber.dependencies = {\n lanes: 0,\n firstContext: context\n };\n } else lastContextDependency = lastContextDependency.next = context;\n return value;\n}\nvar concurrentQueues = null;\nfunction pushConcurrentUpdateQueue(queue) {\n null === concurrentQueues\n ? (concurrentQueues = [queue])\n : concurrentQueues.push(queue);\n}\nfunction enqueueConcurrentHookUpdate(fiber, queue, update, lane) {\n var interleaved = queue.interleaved;\n null === interleaved\n ? ((update.next = update), pushConcurrentUpdateQueue(queue))\n : ((update.next = interleaved.next), (interleaved.next = update));\n queue.interleaved = update;\n return markUpdateLaneFromFiberToRoot(fiber, lane);\n}\nfunction markUpdateLaneFromFiberToRoot(sourceFiber, lane) {\n sourceFiber.lanes |= lane;\n var alternate = sourceFiber.alternate;\n null !== alternate && (alternate.lanes |= lane);\n alternate = sourceFiber;\n for (sourceFiber = sourceFiber.return; null !== sourceFiber; )\n (sourceFiber.childLanes |= lane),\n (alternate = sourceFiber.alternate),\n null !== alternate && (alternate.childLanes |= lane),\n (alternate = sourceFiber),\n (sourceFiber = sourceFiber.return);\n return 3 === alternate.tag ? alternate.stateNode : null;\n}\nvar hasForceUpdate = !1;\nfunction initializeUpdateQueue(fiber) {\n fiber.updateQueue = {\n baseState: fiber.memoizedState,\n firstBaseUpdate: null,\n lastBaseUpdate: null,\n shared: { pending: null, interleaved: null, lanes: 0 },\n effects: null\n };\n}\nfunction cloneUpdateQueue(current, workInProgress) {\n current = current.updateQueue;\n workInProgress.updateQueue === current &&\n (workInProgress.updateQueue = {\n baseState: current.baseState,\n firstBaseUpdate: current.firstBaseUpdate,\n lastBaseUpdate: current.lastBaseUpdate,\n shared: current.shared,\n effects: current.effects\n });\n}\nfunction createUpdate(eventTime, lane) {\n return {\n eventTime: eventTime,\n lane: lane,\n tag: 0,\n payload: null,\n callback: null,\n next: null\n };\n}\nfunction enqueueUpdate(fiber, update, lane) {\n var updateQueue = fiber.updateQueue;\n if (null === updateQueue) return null;\n updateQueue = updateQueue.shared;\n if (0 !== (executionContext & 2)) {\n var pending = updateQueue.pending;\n null === pending\n ? (update.next = update)\n : ((update.next = pending.next), (pending.next = update));\n updateQueue.pending = update;\n return markUpdateLaneFromFiberToRoot(fiber, lane);\n }\n pending = updateQueue.interleaved;\n null === pending\n ? ((update.next = update), pushConcurrentUpdateQueue(updateQueue))\n : ((update.next = pending.next), (pending.next = update));\n updateQueue.interleaved = update;\n return markUpdateLaneFromFiberToRoot(fiber, lane);\n}\nfunction entangleTransitions(root, fiber, lane) {\n fiber = fiber.updateQueue;\n if (null !== fiber && ((fiber = fiber.shared), 0 !== (lane & 4194240))) {\n var queueLanes = fiber.lanes;\n queueLanes &= root.pendingLanes;\n lane |= queueLanes;\n fiber.lanes = lane;\n markRootEntangled(root, lane);\n }\n}\nfunction enqueueCapturedUpdate(workInProgress, capturedUpdate) {\n var queue = workInProgress.updateQueue,\n current = workInProgress.alternate;\n if (\n null !== current &&\n ((current = current.updateQueue), queue === current)\n ) {\n var newFirst = null,\n newLast = null;\n queue = queue.firstBaseUpdate;\n if (null !== queue) {\n do {\n var clone = {\n eventTime: queue.eventTime,\n lane: queue.lane,\n tag: queue.tag,\n payload: queue.payload,\n callback: queue.callback,\n next: null\n };\n null === newLast\n ? (newFirst = newLast = clone)\n : (newLast = newLast.next = clone);\n queue = queue.next;\n } while (null !== queue);\n null === newLast\n ? (newFirst = newLast = capturedUpdate)\n : (newLast = newLast.next = capturedUpdate);\n } else newFirst = newLast = capturedUpdate;\n queue = {\n baseState: current.baseState,\n firstBaseUpdate: newFirst,\n lastBaseUpdate: newLast,\n shared: current.shared,\n effects: current.effects\n };\n workInProgress.updateQueue = queue;\n return;\n }\n workInProgress = queue.lastBaseUpdate;\n null === workInProgress\n ? (queue.firstBaseUpdate = capturedUpdate)\n : (workInProgress.next = capturedUpdate);\n queue.lastBaseUpdate = capturedUpdate;\n}\nfunction processUpdateQueue(\n workInProgress$jscomp$0,\n props,\n instance,\n renderLanes\n) {\n var queue = workInProgress$jscomp$0.updateQueue;\n hasForceUpdate = !1;\n var firstBaseUpdate = queue.firstBaseUpdate,\n lastBaseUpdate = queue.lastBaseUpdate,\n pendingQueue = queue.shared.pending;\n if (null !== pendingQueue) {\n queue.shared.pending = null;\n var lastPendingUpdate = pendingQueue,\n firstPendingUpdate = lastPendingUpdate.next;\n lastPendingUpdate.next = null;\n null === lastBaseUpdate\n ? (firstBaseUpdate = firstPendingUpdate)\n : (lastBaseUpdate.next = firstPendingUpdate);\n lastBaseUpdate = lastPendingUpdate;\n var current = workInProgress$jscomp$0.alternate;\n null !== current &&\n ((current = current.updateQueue),\n (pendingQueue = current.lastBaseUpdate),\n pendingQueue !== lastBaseUpdate &&\n (null === pendingQueue\n ? (current.firstBaseUpdate = firstPendingUpdate)\n : (pendingQueue.next = firstPendingUpdate),\n (current.lastBaseUpdate = lastPendingUpdate)));\n }\n if (null !== firstBaseUpdate) {\n var newState = queue.baseState;\n lastBaseUpdate = 0;\n current = firstPendingUpdate = lastPendingUpdate = null;\n pendingQueue = firstBaseUpdate;\n do {\n var updateLane = pendingQueue.lane,\n updateEventTime = pendingQueue.eventTime;\n if ((renderLanes & updateLane) === updateLane) {\n null !== current &&\n (current = current.next = {\n eventTime: updateEventTime,\n lane: 0,\n tag: pendingQueue.tag,\n payload: pendingQueue.payload,\n callback: pendingQueue.callback,\n next: null\n });\n a: {\n var workInProgress = workInProgress$jscomp$0,\n update = pendingQueue;\n updateLane = props;\n updateEventTime = instance;\n switch (update.tag) {\n case 1:\n workInProgress = update.payload;\n if (\"function\" === typeof workInProgress) {\n newState = workInProgress.call(\n updateEventTime,\n newState,\n updateLane\n );\n break a;\n }\n newState = workInProgress;\n break a;\n case 3:\n workInProgress.flags = (workInProgress.flags & -65537) | 128;\n case 0:\n workInProgress = update.payload;\n updateLane =\n \"function\" === typeof workInProgress\n ? workInProgress.call(updateEventTime, newState, updateLane)\n : workInProgress;\n if (null === updateLane || void 0 === updateLane) break a;\n newState = assign({}, newState, updateLane);\n break a;\n case 2:\n hasForceUpdate = !0;\n }\n }\n null !== pendingQueue.callback &&\n 0 !== pendingQueue.lane &&\n ((workInProgress$jscomp$0.flags |= 64),\n (updateLane = queue.effects),\n null === updateLane\n ? (queue.effects = [pendingQueue])\n : updateLane.push(pendingQueue));\n } else\n (updateEventTime = {\n eventTime: updateEventTime,\n lane: updateLane,\n tag: pendingQueue.tag,\n payload: pendingQueue.payload,\n callback: pendingQueue.callback,\n next: null\n }),\n null === current\n ? ((firstPendingUpdate = current = updateEventTime),\n (lastPendingUpdate = newState))\n : (current = current.next = updateEventTime),\n (lastBaseUpdate |= updateLane);\n pendingQueue = pendingQueue.next;\n if (null === pendingQueue)\n if (((pendingQueue = queue.shared.pending), null === pendingQueue))\n break;\n else\n (updateLane = pendingQueue),\n (pendingQueue = updateLane.next),\n (updateLane.next = null),\n (queue.lastBaseUpdate = updateLane),\n (queue.shared.pending = null);\n } while (1);\n null === current && (lastPendingUpdate = newState);\n queue.baseState = lastPendingUpdate;\n queue.firstBaseUpdate = firstPendingUpdate;\n queue.lastBaseUpdate = current;\n props = queue.shared.interleaved;\n if (null !== props) {\n queue = props;\n do (lastBaseUpdate |= queue.lane), (queue = queue.next);\n while (queue !== props);\n } else null === firstBaseUpdate && (queue.shared.lanes = 0);\n workInProgressRootSkippedLanes |= lastBaseUpdate;\n workInProgress$jscomp$0.lanes = lastBaseUpdate;\n workInProgress$jscomp$0.memoizedState = newState;\n }\n}\nfunction commitUpdateQueue(finishedWork, finishedQueue, instance) {\n finishedWork = finishedQueue.effects;\n finishedQueue.effects = null;\n if (null !== finishedWork)\n for (\n finishedQueue = 0;\n finishedQueue < finishedWork.length;\n finishedQueue++\n ) {\n var effect = finishedWork[finishedQueue],\n callback = effect.callback;\n if (null !== callback) {\n effect.callback = null;\n if (\"function\" !== typeof callback)\n throw Error(\n \"Invalid argument passed as callback. Expected a function. Instead received: \" +\n callback\n );\n callback.call(instance);\n }\n }\n}\nvar emptyRefsObject = new React.Component().refs;\nfunction applyDerivedStateFromProps(\n workInProgress,\n ctor,\n getDerivedStateFromProps,\n nextProps\n) {\n ctor = workInProgress.memoizedState;\n getDerivedStateFromProps = getDerivedStateFromProps(nextProps, ctor);\n getDerivedStateFromProps =\n null === getDerivedStateFromProps || void 0 === getDerivedStateFromProps\n ? ctor\n : assign({}, ctor, getDerivedStateFromProps);\n workInProgress.memoizedState = getDerivedStateFromProps;\n 0 === workInProgress.lanes &&\n (workInProgress.updateQueue.baseState = getDerivedStateFromProps);\n}\nvar classComponentUpdater = {\n isMounted: function(component) {\n return (component = component._reactInternals)\n ? getNearestMountedFiber(component) === component\n : !1;\n },\n enqueueSetState: function(inst, payload, callback) {\n inst = inst._reactInternals;\n var eventTime = requestEventTime(),\n lane = requestUpdateLane(inst),\n update = createUpdate(eventTime, lane);\n update.payload = payload;\n void 0 !== callback && null !== callback && (update.callback = callback);\n payload = enqueueUpdate(inst, update, lane);\n null !== payload &&\n (scheduleUpdateOnFiber(payload, inst, lane, eventTime),\n entangleTransitions(payload, inst, lane));\n },\n enqueueReplaceState: function(inst, payload, callback) {\n inst = inst._reactInternals;\n var eventTime = requestEventTime(),\n lane = requestUpdateLane(inst),\n update = createUpdate(eventTime, lane);\n update.tag = 1;\n update.payload = payload;\n void 0 !== callback && null !== callback && (update.callback = callback);\n payload = enqueueUpdate(inst, update, lane);\n null !== payload &&\n (scheduleUpdateOnFiber(payload, inst, lane, eventTime),\n entangleTransitions(payload, inst, lane));\n },\n enqueueForceUpdate: function(inst, callback) {\n inst = inst._reactInternals;\n var eventTime = requestEventTime(),\n lane = requestUpdateLane(inst),\n update = createUpdate(eventTime, lane);\n update.tag = 2;\n void 0 !== callback && null !== callback && (update.callback = callback);\n callback = enqueueUpdate(inst, update, lane);\n null !== callback &&\n (scheduleUpdateOnFiber(callback, inst, lane, eventTime),\n entangleTransitions(callback, inst, lane));\n }\n};\nfunction checkShouldComponentUpdate(\n workInProgress,\n ctor,\n oldProps,\n newProps,\n oldState,\n newState,\n nextContext\n) {\n workInProgress = workInProgress.stateNode;\n return \"function\" === typeof workInProgress.shouldComponentUpdate\n ? workInProgress.shouldComponentUpdate(newProps, newState, nextContext)\n : ctor.prototype && ctor.prototype.isPureReactComponent\n ? !shallowEqual(oldProps, newProps) || !shallowEqual(oldState, newState)\n : !0;\n}\nfunction constructClassInstance(workInProgress, ctor, props) {\n var isLegacyContextConsumer = !1,\n unmaskedContext = emptyContextObject;\n var context = ctor.contextType;\n \"object\" === typeof context && null !== context\n ? (context = readContext(context))\n : ((unmaskedContext = isContextProvider(ctor)\n ? previousContext\n : contextStackCursor.current),\n (isLegacyContextConsumer = ctor.contextTypes),\n (context = (isLegacyContextConsumer =\n null !== isLegacyContextConsumer && void 0 !== isLegacyContextConsumer)\n ? getMaskedContext(workInProgress, unmaskedContext)\n : emptyContextObject));\n ctor = new ctor(props, context);\n workInProgress.memoizedState =\n null !== ctor.state && void 0 !== ctor.state ? ctor.state : null;\n ctor.updater = classComponentUpdater;\n workInProgress.stateNode = ctor;\n ctor._reactInternals = workInProgress;\n isLegacyContextConsumer &&\n ((workInProgress = workInProgress.stateNode),\n (workInProgress.__reactInternalMemoizedUnmaskedChildContext = unmaskedContext),\n (workInProgress.__reactInternalMemoizedMaskedChildContext = context));\n return ctor;\n}\nfunction callComponentWillReceiveProps(\n workInProgress,\n instance,\n newProps,\n nextContext\n) {\n workInProgress = instance.state;\n \"function\" === typeof instance.componentWillReceiveProps &&\n instance.componentWillReceiveProps(newProps, nextContext);\n \"function\" === typeof instance.UNSAFE_componentWillReceiveProps &&\n instance.UNSAFE_componentWillReceiveProps(newProps, nextContext);\n instance.state !== workInProgress &&\n classComponentUpdater.enqueueReplaceState(instance, instance.state, null);\n}\nfunction mountClassInstance(workInProgress, ctor, newProps, renderLanes) {\n var instance = workInProgress.stateNode;\n instance.props = newProps;\n instance.state = workInProgress.memoizedState;\n instance.refs = emptyRefsObject;\n initializeUpdateQueue(workInProgress);\n var contextType = ctor.contextType;\n \"object\" === typeof contextType && null !== contextType\n ? (instance.context = readContext(contextType))\n : ((contextType = isContextProvider(ctor)\n ? previousContext\n : contextStackCursor.current),\n (instance.context = getMaskedContext(workInProgress, contextType)));\n instance.state = workInProgress.memoizedState;\n contextType = ctor.getDerivedStateFromProps;\n \"function\" === typeof contextType &&\n (applyDerivedStateFromProps(workInProgress, ctor, contextType, newProps),\n (instance.state = workInProgress.memoizedState));\n \"function\" === typeof ctor.getDerivedStateFromProps ||\n \"function\" === typeof instance.getSnapshotBeforeUpdate ||\n (\"function\" !== typeof instance.UNSAFE_componentWillMount &&\n \"function\" !== typeof instance.componentWillMount) ||\n ((ctor = instance.state),\n \"function\" === typeof instance.componentWillMount &&\n instance.componentWillMount(),\n \"function\" === typeof instance.UNSAFE_componentWillMount &&\n instance.UNSAFE_componentWillMount(),\n ctor !== instance.state &&\n classComponentUpdater.enqueueReplaceState(instance, instance.state, null),\n processUpdateQueue(workInProgress, newProps, instance, renderLanes),\n (instance.state = workInProgress.memoizedState));\n \"function\" === typeof instance.componentDidMount &&\n (workInProgress.flags |= 4);\n}\nfunction coerceRef(returnFiber, current, element) {\n returnFiber = element.ref;\n if (\n null !== returnFiber &&\n \"function\" !== typeof returnFiber &&\n \"object\" !== typeof returnFiber\n ) {\n if (element._owner) {\n element = element._owner;\n if (element) {\n if (1 !== element.tag)\n throw Error(\n \"Function components cannot have string refs. We recommend using useRef() instead. Learn more about using refs safely here: https://reactjs.org/link/strict-mode-string-ref\"\n );\n var inst = element.stateNode;\n }\n if (!inst)\n throw Error(\n \"Missing owner for string ref \" +\n returnFiber +\n \". This error is likely caused by a bug in React. Please file an issue.\"\n );\n var resolvedInst = inst,\n stringRef = \"\" + returnFiber;\n if (\n null !== current &&\n null !== current.ref &&\n \"function\" === typeof current.ref &&\n current.ref._stringRef === stringRef\n )\n return current.ref;\n current = function(value) {\n var refs = resolvedInst.refs;\n refs === emptyRefsObject && (refs = resolvedInst.refs = {});\n null === value ? delete refs[stringRef] : (refs[stringRef] = value);\n };\n current._stringRef = stringRef;\n return current;\n }\n if (\"string\" !== typeof returnFiber)\n throw Error(\n \"Expected ref to be a function, a string, an object returned by React.createRef(), or null.\"\n );\n if (!element._owner)\n throw Error(\n \"Element ref was specified as a string (\" +\n returnFiber +\n \") but no owner was set. This could happen for one of the following reasons:\\n1. You may be adding a ref to a function component\\n2. You may be adding a ref to a component that was not created inside a component's render method\\n3. You have multiple copies of React loaded\\nSee https://reactjs.org/link/refs-must-have-owner for more information.\"\n );\n }\n return returnFiber;\n}\nfunction throwOnInvalidObjectType(returnFiber, newChild) {\n returnFiber = Object.prototype.toString.call(newChild);\n throw Error(\n \"Objects are not valid as a React child (found: \" +\n (\"[object Object]\" === returnFiber\n ? \"object with keys {\" + Object.keys(newChild).join(\", \") + \"}\"\n : returnFiber) +\n \"). If you meant to render a collection of children, use an array instead.\"\n );\n}\nfunction resolveLazy(lazyType) {\n var init = lazyType._init;\n return init(lazyType._payload);\n}\nfunction ChildReconciler(shouldTrackSideEffects) {\n function deleteChild(returnFiber, childToDelete) {\n if (shouldTrackSideEffects) {\n var deletions = returnFiber.deletions;\n null === deletions\n ? ((returnFiber.deletions = [childToDelete]), (returnFiber.flags |= 16))\n : deletions.push(childToDelete);\n }\n }\n function deleteRemainingChildren(returnFiber, currentFirstChild) {\n if (!shouldTrackSideEffects) return null;\n for (; null !== currentFirstChild; )\n deleteChild(returnFiber, currentFirstChild),\n (currentFirstChild = currentFirstChild.sibling);\n return null;\n }\n function mapRemainingChildren(returnFiber, currentFirstChild) {\n for (returnFiber = new Map(); null !== currentFirstChild; )\n null !== currentFirstChild.key\n ? returnFiber.set(currentFirstChild.key, currentFirstChild)\n : returnFiber.set(currentFirstChild.index, currentFirstChild),\n (currentFirstChild = currentFirstChild.sibling);\n return returnFiber;\n }\n function useFiber(fiber, pendingProps) {\n fiber = createWorkInProgress(fiber, pendingProps);\n fiber.index = 0;\n fiber.sibling = null;\n return fiber;\n }\n function placeChild(newFiber, lastPlacedIndex, newIndex) {\n newFiber.index = newIndex;\n if (!shouldTrackSideEffects)\n return (newFiber.flags |= 1048576), lastPlacedIndex;\n newIndex = newFiber.alternate;\n if (null !== newIndex)\n return (\n (newIndex = newIndex.index),\n newIndex < lastPlacedIndex\n ? ((newFiber.flags |= 2), lastPlacedIndex)\n : newIndex\n );\n newFiber.flags |= 2;\n return lastPlacedIndex;\n }\n function placeSingleChild(newFiber) {\n shouldTrackSideEffects &&\n null === newFiber.alternate &&\n (newFiber.flags |= 2);\n return newFiber;\n }\n function updateTextNode(returnFiber, current, textContent, lanes) {\n if (null === current || 6 !== current.tag)\n return (\n (current = createFiberFromText(textContent, returnFiber.mode, lanes)),\n (current.return = returnFiber),\n current\n );\n current = useFiber(current, textContent);\n current.return = returnFiber;\n return current;\n }\n function updateElement(returnFiber, current, element, lanes) {\n var elementType = element.type;\n if (elementType === REACT_FRAGMENT_TYPE)\n return updateFragment(\n returnFiber,\n current,\n element.props.children,\n lanes,\n element.key\n );\n if (\n null !== current &&\n (current.elementType === elementType ||\n (\"object\" === typeof elementType &&\n null !== elementType &&\n elementType.$$typeof === REACT_LAZY_TYPE &&\n resolveLazy(elementType) === current.type))\n )\n return (\n (lanes = useFiber(current, element.props)),\n (lanes.ref = coerceRef(returnFiber, current, element)),\n (lanes.return = returnFiber),\n lanes\n );\n lanes = createFiberFromTypeAndProps(\n element.type,\n element.key,\n element.props,\n null,\n returnFiber.mode,\n lanes\n );\n lanes.ref = coerceRef(returnFiber, current, element);\n lanes.return = returnFiber;\n return lanes;\n }\n function updatePortal(returnFiber, current, portal, lanes) {\n if (\n null === current ||\n 4 !== current.tag ||\n current.stateNode.containerInfo !== portal.containerInfo ||\n current.stateNode.implementation !== portal.implementation\n )\n return (\n (current = createFiberFromPortal(portal, returnFiber.mode, lanes)),\n (current.return = returnFiber),\n current\n );\n current = useFiber(current, portal.children || []);\n current.return = returnFiber;\n return current;\n }\n function updateFragment(returnFiber, current, fragment, lanes, key) {\n if (null === current || 7 !== current.tag)\n return (\n (current = createFiberFromFragment(\n fragment,\n returnFiber.mode,\n lanes,\n key\n )),\n (current.return = returnFiber),\n current\n );\n current = useFiber(current, fragment);\n current.return = returnFiber;\n return current;\n }\n function createChild(returnFiber, newChild, lanes) {\n if (\n (\"string\" === typeof newChild && \"\" !== newChild) ||\n \"number\" === typeof newChild\n )\n return (\n (newChild = createFiberFromText(\n \"\" + newChild,\n returnFiber.mode,\n lanes\n )),\n (newChild.return = returnFiber),\n newChild\n );\n if (\"object\" === typeof newChild && null !== newChild) {\n switch (newChild.$$typeof) {\n case REACT_ELEMENT_TYPE:\n return (\n (lanes = createFiberFromTypeAndProps(\n newChild.type,\n newChild.key,\n newChild.props,\n null,\n returnFiber.mode,\n lanes\n )),\n (lanes.ref = coerceRef(returnFiber, null, newChild)),\n (lanes.return = returnFiber),\n lanes\n );\n case REACT_PORTAL_TYPE:\n return (\n (newChild = createFiberFromPortal(\n newChild,\n returnFiber.mode,\n lanes\n )),\n (newChild.return = returnFiber),\n newChild\n );\n case REACT_LAZY_TYPE:\n var init = newChild._init;\n return createChild(returnFiber, init(newChild._payload), lanes);\n }\n if (isArrayImpl(newChild) || getIteratorFn(newChild))\n return (\n (newChild = createFiberFromFragment(\n newChild,\n returnFiber.mode,\n lanes,\n null\n )),\n (newChild.return = returnFiber),\n newChild\n );\n throwOnInvalidObjectType(returnFiber, newChild);\n }\n return null;\n }\n function updateSlot(returnFiber, oldFiber, newChild, lanes) {\n var key = null !== oldFiber ? oldFiber.key : null;\n if (\n (\"string\" === typeof newChild && \"\" !== newChild) ||\n \"number\" === typeof newChild\n )\n return null !== key\n ? null\n : updateTextNode(returnFiber, oldFiber, \"\" + newChild, lanes);\n if (\"object\" === typeof newChild && null !== newChild) {\n switch (newChild.$$typeof) {\n case REACT_ELEMENT_TYPE:\n return newChild.key === key\n ? updateElement(returnFiber, oldFiber, newChild, lanes)\n : null;\n case REACT_PORTAL_TYPE:\n return newChild.key === key\n ? updatePortal(returnFiber, oldFiber, newChild, lanes)\n : null;\n case REACT_LAZY_TYPE:\n return (\n (key = newChild._init),\n updateSlot(returnFiber, oldFiber, key(newChild._payload), lanes)\n );\n }\n if (isArrayImpl(newChild) || getIteratorFn(newChild))\n return null !== key\n ? null\n : updateFragment(returnFiber, oldFiber, newChild, lanes, null);\n throwOnInvalidObjectType(returnFiber, newChild);\n }\n return null;\n }\n function updateFromMap(\n existingChildren,\n returnFiber,\n newIdx,\n newChild,\n lanes\n ) {\n if (\n (\"string\" === typeof newChild && \"\" !== newChild) ||\n \"number\" === typeof newChild\n )\n return (\n (existingChildren = existingChildren.get(newIdx) || null),\n updateTextNode(returnFiber, existingChildren, \"\" + newChild, lanes)\n );\n if (\"object\" === typeof newChild && null !== newChild) {\n switch (newChild.$$typeof) {\n case REACT_ELEMENT_TYPE:\n return (\n (existingChildren =\n existingChildren.get(\n null === newChild.key ? newIdx : newChild.key\n ) || null),\n updateElement(returnFiber, existingChildren, newChild, lanes)\n );\n case REACT_PORTAL_TYPE:\n return (\n (existingChildren =\n existingChildren.get(\n null === newChild.key ? newIdx : newChild.key\n ) || null),\n updatePortal(returnFiber, existingChildren, newChild, lanes)\n );\n case REACT_LAZY_TYPE:\n var init = newChild._init;\n return updateFromMap(\n existingChildren,\n returnFiber,\n newIdx,\n init(newChild._payload),\n lanes\n );\n }\n if (isArrayImpl(newChild) || getIteratorFn(newChild))\n return (\n (existingChildren = existingChildren.get(newIdx) || null),\n updateFragment(returnFiber, existingChildren, newChild, lanes, null)\n );\n throwOnInvalidObjectType(returnFiber, newChild);\n }\n return null;\n }\n function reconcileChildrenArray(\n returnFiber,\n currentFirstChild,\n newChildren,\n lanes\n ) {\n for (\n var resultingFirstChild = null,\n previousNewFiber = null,\n oldFiber = currentFirstChild,\n newIdx = (currentFirstChild = 0),\n nextOldFiber = null;\n null !== oldFiber && newIdx < newChildren.length;\n newIdx++\n ) {\n oldFiber.index > newIdx\n ? ((nextOldFiber = oldFiber), (oldFiber = null))\n : (nextOldFiber = oldFiber.sibling);\n var newFiber = updateSlot(\n returnFiber,\n oldFiber,\n newChildren[newIdx],\n lanes\n );\n if (null === newFiber) {\n null === oldFiber && (oldFiber = nextOldFiber);\n break;\n }\n shouldTrackSideEffects &&\n oldFiber &&\n null === newFiber.alternate &&\n deleteChild(returnFiber, oldFiber);\n currentFirstChild = placeChild(newFiber, currentFirstChild, newIdx);\n null === previousNewFiber\n ? (resultingFirstChild = newFiber)\n : (previousNewFiber.sibling = newFiber);\n previousNewFiber = newFiber;\n oldFiber = nextOldFiber;\n }\n if (newIdx === newChildren.length)\n return (\n deleteRemainingChildren(returnFiber, oldFiber), resultingFirstChild\n );\n if (null === oldFiber) {\n for (; newIdx < newChildren.length; newIdx++)\n (oldFiber = createChild(returnFiber, newChildren[newIdx], lanes)),\n null !== oldFiber &&\n ((currentFirstChild = placeChild(\n oldFiber,\n currentFirstChild,\n newIdx\n )),\n null === previousNewFiber\n ? (resultingFirstChild = oldFiber)\n : (previousNewFiber.sibling = oldFiber),\n (previousNewFiber = oldFiber));\n return resultingFirstChild;\n }\n for (\n oldFiber = mapRemainingChildren(returnFiber, oldFiber);\n newIdx < newChildren.length;\n newIdx++\n )\n (nextOldFiber = updateFromMap(\n oldFiber,\n returnFiber,\n newIdx,\n newChildren[newIdx],\n lanes\n )),\n null !== nextOldFiber &&\n (shouldTrackSideEffects &&\n null !== nextOldFiber.alternate &&\n oldFiber.delete(\n null === nextOldFiber.key ? newIdx : nextOldFiber.key\n ),\n (currentFirstChild = placeChild(\n nextOldFiber,\n currentFirstChild,\n newIdx\n )),\n null === previousNewFiber\n ? (resultingFirstChild = nextOldFiber)\n : (previousNewFiber.sibling = nextOldFiber),\n (previousNewFiber = nextOldFiber));\n shouldTrackSideEffects &&\n oldFiber.forEach(function(child) {\n return deleteChild(returnFiber, child);\n });\n return resultingFirstChild;\n }\n function reconcileChildrenIterator(\n returnFiber,\n currentFirstChild,\n newChildrenIterable,\n lanes\n ) {\n var iteratorFn = getIteratorFn(newChildrenIterable);\n if (\"function\" !== typeof iteratorFn)\n throw Error(\n \"An object is not an iterable. This error is likely caused by a bug in React. Please file an issue.\"\n );\n newChildrenIterable = iteratorFn.call(newChildrenIterable);\n if (null == newChildrenIterable)\n throw Error(\"An iterable object provided no iterator.\");\n for (\n var previousNewFiber = (iteratorFn = null),\n oldFiber = currentFirstChild,\n newIdx = (currentFirstChild = 0),\n nextOldFiber = null,\n step = newChildrenIterable.next();\n null !== oldFiber && !step.done;\n newIdx++, step = newChildrenIterable.next()\n ) {\n oldFiber.index > newIdx\n ? ((nextOldFiber = oldFiber), (oldFiber = null))\n : (nextOldFiber = oldFiber.sibling);\n var newFiber = updateSlot(returnFiber, oldFiber, step.value, lanes);\n if (null === newFiber) {\n null === oldFiber && (oldFiber = nextOldFiber);\n break;\n }\n shouldTrackSideEffects &&\n oldFiber &&\n null === newFiber.alternate &&\n deleteChild(returnFiber, oldFiber);\n currentFirstChild = placeChild(newFiber, currentFirstChild, newIdx);\n null === previousNewFiber\n ? (iteratorFn = newFiber)\n : (previousNewFiber.sibling = newFiber);\n previousNewFiber = newFiber;\n oldFiber = nextOldFiber;\n }\n if (step.done)\n return deleteRemainingChildren(returnFiber, oldFiber), iteratorFn;\n if (null === oldFiber) {\n for (; !step.done; newIdx++, step = newChildrenIterable.next())\n (step = createChild(returnFiber, step.value, lanes)),\n null !== step &&\n ((currentFirstChild = placeChild(step, currentFirstChild, newIdx)),\n null === previousNewFiber\n ? (iteratorFn = step)\n : (previousNewFiber.sibling = step),\n (previousNewFiber = step));\n return iteratorFn;\n }\n for (\n oldFiber = mapRemainingChildren(returnFiber, oldFiber);\n !step.done;\n newIdx++, step = newChildrenIterable.next()\n )\n (step = updateFromMap(oldFiber, returnFiber, newIdx, step.value, lanes)),\n null !== step &&\n (shouldTrackSideEffects &&\n null !== step.alternate &&\n oldFiber.delete(null === step.key ? newIdx : step.key),\n (currentFirstChild = placeChild(step, currentFirstChild, newIdx)),\n null === previousNewFiber\n ? (iteratorFn = step)\n : (previousNewFiber.sibling = step),\n (previousNewFiber = step));\n shouldTrackSideEffects &&\n oldFiber.forEach(function(child) {\n return deleteChild(returnFiber, child);\n });\n return iteratorFn;\n }\n function reconcileChildFibers(\n returnFiber,\n currentFirstChild,\n newChild,\n lanes\n ) {\n \"object\" === typeof newChild &&\n null !== newChild &&\n newChild.type === REACT_FRAGMENT_TYPE &&\n null === newChild.key &&\n (newChild = newChild.props.children);\n if (\"object\" === typeof newChild && null !== newChild) {\n switch (newChild.$$typeof) {\n case REACT_ELEMENT_TYPE:\n a: {\n for (\n var key = newChild.key, child = currentFirstChild;\n null !== child;\n\n ) {\n if (child.key === key) {\n key = newChild.type;\n if (key === REACT_FRAGMENT_TYPE) {\n if (7 === child.tag) {\n deleteRemainingChildren(returnFiber, child.sibling);\n currentFirstChild = useFiber(\n child,\n newChild.props.children\n );\n currentFirstChild.return = returnFiber;\n returnFiber = currentFirstChild;\n break a;\n }\n } else if (\n child.elementType === key ||\n (\"object\" === typeof key &&\n null !== key &&\n key.$$typeof === REACT_LAZY_TYPE &&\n resolveLazy(key) === child.type)\n ) {\n deleteRemainingChildren(returnFiber, child.sibling);\n currentFirstChild = useFiber(child, newChild.props);\n currentFirstChild.ref = coerceRef(\n returnFiber,\n child,\n newChild\n );\n currentFirstChild.return = returnFiber;\n returnFiber = currentFirstChild;\n break a;\n }\n deleteRemainingChildren(returnFiber, child);\n break;\n } else deleteChild(returnFiber, child);\n child = child.sibling;\n }\n newChild.type === REACT_FRAGMENT_TYPE\n ? ((currentFirstChild = createFiberFromFragment(\n newChild.props.children,\n returnFiber.mode,\n lanes,\n newChild.key\n )),\n (currentFirstChild.return = returnFiber),\n (returnFiber = currentFirstChild))\n : ((lanes = createFiberFromTypeAndProps(\n newChild.type,\n newChild.key,\n newChild.props,\n null,\n returnFiber.mode,\n lanes\n )),\n (lanes.ref = coerceRef(\n returnFiber,\n currentFirstChild,\n newChild\n )),\n (lanes.return = returnFiber),\n (returnFiber = lanes));\n }\n return placeSingleChild(returnFiber);\n case REACT_PORTAL_TYPE:\n a: {\n for (child = newChild.key; null !== currentFirstChild; ) {\n if (currentFirstChild.key === child)\n if (\n 4 === currentFirstChild.tag &&\n currentFirstChild.stateNode.containerInfo ===\n newChild.containerInfo &&\n currentFirstChild.stateNode.implementation ===\n newChild.implementation\n ) {\n deleteRemainingChildren(\n returnFiber,\n currentFirstChild.sibling\n );\n currentFirstChild = useFiber(\n currentFirstChild,\n newChild.children || []\n );\n currentFirstChild.return = returnFiber;\n returnFiber = currentFirstChild;\n break a;\n } else {\n deleteRemainingChildren(returnFiber, currentFirstChild);\n break;\n }\n else deleteChild(returnFiber, currentFirstChild);\n currentFirstChild = currentFirstChild.sibling;\n }\n currentFirstChild = createFiberFromPortal(\n newChild,\n returnFiber.mode,\n lanes\n );\n currentFirstChild.return = returnFiber;\n returnFiber = currentFirstChild;\n }\n return placeSingleChild(returnFiber);\n case REACT_LAZY_TYPE:\n return (\n (child = newChild._init),\n reconcileChildFibers(\n returnFiber,\n currentFirstChild,\n child(newChild._payload),\n lanes\n )\n );\n }\n if (isArrayImpl(newChild))\n return reconcileChildrenArray(\n returnFiber,\n currentFirstChild,\n newChild,\n lanes\n );\n if (getIteratorFn(newChild))\n return reconcileChildrenIterator(\n returnFiber,\n currentFirstChild,\n newChild,\n lanes\n );\n throwOnInvalidObjectType(returnFiber, newChild);\n }\n return (\"string\" === typeof newChild && \"\" !== newChild) ||\n \"number\" === typeof newChild\n ? ((newChild = \"\" + newChild),\n null !== currentFirstChild && 6 === currentFirstChild.tag\n ? (deleteRemainingChildren(returnFiber, currentFirstChild.sibling),\n (currentFirstChild = useFiber(currentFirstChild, newChild)),\n (currentFirstChild.return = returnFiber),\n (returnFiber = currentFirstChild))\n : (deleteRemainingChildren(returnFiber, currentFirstChild),\n (currentFirstChild = createFiberFromText(\n newChild,\n returnFiber.mode,\n lanes\n )),\n (currentFirstChild.return = returnFiber),\n (returnFiber = currentFirstChild)),\n placeSingleChild(returnFiber))\n : deleteRemainingChildren(returnFiber, currentFirstChild);\n }\n return reconcileChildFibers;\n}\nvar reconcileChildFibers = ChildReconciler(!0),\n mountChildFibers = ChildReconciler(!1),\n NO_CONTEXT = {},\n contextStackCursor$1 = createCursor(NO_CONTEXT),\n contextFiberStackCursor = createCursor(NO_CONTEXT),\n rootInstanceStackCursor = createCursor(NO_CONTEXT);\nfunction requiredContext(c) {\n if (c === NO_CONTEXT)\n throw Error(\n \"Expected host context to exist. This error is likely caused by a bug in React. Please file an issue.\"\n );\n return c;\n}\nfunction pushHostContainer(fiber, nextRootInstance) {\n push(rootInstanceStackCursor, nextRootInstance);\n push(contextFiberStackCursor, fiber);\n push(contextStackCursor$1, NO_CONTEXT);\n pop(contextStackCursor$1);\n push(contextStackCursor$1, { isInAParentText: !1 });\n}\nfunction popHostContainer() {\n pop(contextStackCursor$1);\n pop(contextFiberStackCursor);\n pop(rootInstanceStackCursor);\n}\nfunction pushHostContext(fiber) {\n requiredContext(rootInstanceStackCursor.current);\n var context = requiredContext(contextStackCursor$1.current);\n var JSCompiler_inline_result = fiber.type;\n JSCompiler_inline_result =\n \"AndroidTextInput\" === JSCompiler_inline_result ||\n \"RCTMultilineTextInputView\" === JSCompiler_inline_result ||\n \"RCTSinglelineTextInputView\" === JSCompiler_inline_result ||\n \"RCTText\" === JSCompiler_inline_result ||\n \"RCTVirtualText\" === JSCompiler_inline_result;\n JSCompiler_inline_result =\n context.isInAParentText !== JSCompiler_inline_result\n ? { isInAParentText: JSCompiler_inline_result }\n : context;\n context !== JSCompiler_inline_result &&\n (push(contextFiberStackCursor, fiber),\n push(contextStackCursor$1, JSCompiler_inline_result));\n}\nfunction popHostContext(fiber) {\n contextFiberStackCursor.current === fiber &&\n (pop(contextStackCursor$1), pop(contextFiberStackCursor));\n}\nvar suspenseStackCursor = createCursor(0);\nfunction findFirstSuspended(row) {\n for (var node = row; null !== node; ) {\n if (13 === node.tag) {\n var state = node.memoizedState;\n if (null !== state && (null === state.dehydrated || shim$1() || shim$1()))\n return node;\n } else if (19 === node.tag && void 0 !== node.memoizedProps.revealOrder) {\n if (0 !== (node.flags & 128)) return node;\n } else if (null !== node.child) {\n node.child.return = node;\n node = node.child;\n continue;\n }\n if (node === row) break;\n for (; null === node.sibling; ) {\n if (null === node.return || node.return === row) return null;\n node = node.return;\n }\n node.sibling.return = node.return;\n node = node.sibling;\n }\n return null;\n}\nvar workInProgressSources = [];\nfunction resetWorkInProgressVersions() {\n for (var i = 0; i < workInProgressSources.length; i++)\n workInProgressSources[i]._workInProgressVersionSecondary = null;\n workInProgressSources.length = 0;\n}\nvar ReactCurrentDispatcher$1 = ReactSharedInternals.ReactCurrentDispatcher,\n ReactCurrentBatchConfig$1 = ReactSharedInternals.ReactCurrentBatchConfig,\n renderLanes = 0,\n currentlyRenderingFiber$1 = null,\n currentHook = null,\n workInProgressHook = null,\n didScheduleRenderPhaseUpdate = !1,\n didScheduleRenderPhaseUpdateDuringThisPass = !1,\n globalClientIdCounter = 0;\nfunction throwInvalidHookError() {\n throw Error(\n \"Invalid hook call. Hooks can only be called inside of the body of a function component. This could happen for one of the following reasons:\\n1. You might have mismatching versions of React and the renderer (such as React DOM)\\n2. You might be breaking the Rules of Hooks\\n3. You might have more than one copy of React in the same app\\nSee https://reactjs.org/link/invalid-hook-call for tips about how to debug and fix this problem.\"\n );\n}\nfunction areHookInputsEqual(nextDeps, prevDeps) {\n if (null === prevDeps) return !1;\n for (var i = 0; i < prevDeps.length && i < nextDeps.length; i++)\n if (!objectIs(nextDeps[i], prevDeps[i])) return !1;\n return !0;\n}\nfunction renderWithHooks(\n current,\n workInProgress,\n Component,\n props,\n secondArg,\n nextRenderLanes\n) {\n renderLanes = nextRenderLanes;\n currentlyRenderingFiber$1 = workInProgress;\n workInProgress.memoizedState = null;\n workInProgress.updateQueue = null;\n workInProgress.lanes = 0;\n ReactCurrentDispatcher$1.current =\n null === current || null === current.memoizedState\n ? HooksDispatcherOnMount\n : HooksDispatcherOnUpdate;\n current = Component(props, secondArg);\n if (didScheduleRenderPhaseUpdateDuringThisPass) {\n nextRenderLanes = 0;\n do {\n didScheduleRenderPhaseUpdateDuringThisPass = !1;\n if (25 <= nextRenderLanes)\n throw Error(\n \"Too many re-renders. React limits the number of renders to prevent an infinite loop.\"\n );\n nextRenderLanes += 1;\n workInProgressHook = currentHook = null;\n workInProgress.updateQueue = null;\n ReactCurrentDispatcher$1.current = HooksDispatcherOnRerender;\n current = Component(props, secondArg);\n } while (didScheduleRenderPhaseUpdateDuringThisPass);\n }\n ReactCurrentDispatcher$1.current = ContextOnlyDispatcher;\n workInProgress = null !== currentHook && null !== currentHook.next;\n renderLanes = 0;\n workInProgressHook = currentHook = currentlyRenderingFiber$1 = null;\n didScheduleRenderPhaseUpdate = !1;\n if (workInProgress)\n throw Error(\n \"Rendered fewer hooks than expected. This may be caused by an accidental early return statement.\"\n );\n return current;\n}\nfunction mountWorkInProgressHook() {\n var hook = {\n memoizedState: null,\n baseState: null,\n baseQueue: null,\n queue: null,\n next: null\n };\n null === workInProgressHook\n ? (currentlyRenderingFiber$1.memoizedState = workInProgressHook = hook)\n : (workInProgressHook = workInProgressHook.next = hook);\n return workInProgressHook;\n}\nfunction updateWorkInProgressHook() {\n if (null === currentHook) {\n var nextCurrentHook = currentlyRenderingFiber$1.alternate;\n nextCurrentHook =\n null !== nextCurrentHook ? nextCurrentHook.memoizedState : null;\n } else nextCurrentHook = currentHook.next;\n var nextWorkInProgressHook =\n null === workInProgressHook\n ? currentlyRenderingFiber$1.memoizedState\n : workInProgressHook.next;\n if (null !== nextWorkInProgressHook)\n (workInProgressHook = nextWorkInProgressHook),\n (currentHook = nextCurrentHook);\n else {\n if (null === nextCurrentHook)\n throw Error(\"Rendered more hooks than during the previous render.\");\n currentHook = nextCurrentHook;\n nextCurrentHook = {\n memoizedState: currentHook.memoizedState,\n baseState: currentHook.baseState,\n baseQueue: currentHook.baseQueue,\n queue: currentHook.queue,\n next: null\n };\n null === workInProgressHook\n ? (currentlyRenderingFiber$1.memoizedState = workInProgressHook = nextCurrentHook)\n : (workInProgressHook = workInProgressHook.next = nextCurrentHook);\n }\n return workInProgressHook;\n}\nfunction basicStateReducer(state, action) {\n return \"function\" === typeof action ? action(state) : action;\n}\nfunction updateReducer(reducer) {\n var hook = updateWorkInProgressHook(),\n queue = hook.queue;\n if (null === queue)\n throw Error(\n \"Should have a queue. This is likely a bug in React. Please file an issue.\"\n );\n queue.lastRenderedReducer = reducer;\n var current = currentHook,\n baseQueue = current.baseQueue,\n pendingQueue = queue.pending;\n if (null !== pendingQueue) {\n if (null !== baseQueue) {\n var baseFirst = baseQueue.next;\n baseQueue.next = pendingQueue.next;\n pendingQueue.next = baseFirst;\n }\n current.baseQueue = baseQueue = pendingQueue;\n queue.pending = null;\n }\n if (null !== baseQueue) {\n pendingQueue = baseQueue.next;\n current = current.baseState;\n var newBaseQueueFirst = (baseFirst = null),\n newBaseQueueLast = null,\n update = pendingQueue;\n do {\n var updateLane = update.lane;\n if ((renderLanes & updateLane) === updateLane)\n null !== newBaseQueueLast &&\n (newBaseQueueLast = newBaseQueueLast.next = {\n lane: 0,\n action: update.action,\n hasEagerState: update.hasEagerState,\n eagerState: update.eagerState,\n next: null\n }),\n (current = update.hasEagerState\n ? update.eagerState\n : reducer(current, update.action));\n else {\n var clone = {\n lane: updateLane,\n action: update.action,\n hasEagerState: update.hasEagerState,\n eagerState: update.eagerState,\n next: null\n };\n null === newBaseQueueLast\n ? ((newBaseQueueFirst = newBaseQueueLast = clone),\n (baseFirst = current))\n : (newBaseQueueLast = newBaseQueueLast.next = clone);\n currentlyRenderingFiber$1.lanes |= updateLane;\n workInProgressRootSkippedLanes |= updateLane;\n }\n update = update.next;\n } while (null !== update && update !== pendingQueue);\n null === newBaseQueueLast\n ? (baseFirst = current)\n : (newBaseQueueLast.next = newBaseQueueFirst);\n objectIs(current, hook.memoizedState) || (didReceiveUpdate = !0);\n hook.memoizedState = current;\n hook.baseState = baseFirst;\n hook.baseQueue = newBaseQueueLast;\n queue.lastRenderedState = current;\n }\n reducer = queue.interleaved;\n if (null !== reducer) {\n baseQueue = reducer;\n do\n (pendingQueue = baseQueue.lane),\n (currentlyRenderingFiber$1.lanes |= pendingQueue),\n (workInProgressRootSkippedLanes |= pendingQueue),\n (baseQueue = baseQueue.next);\n while (baseQueue !== reducer);\n } else null === baseQueue && (queue.lanes = 0);\n return [hook.memoizedState, queue.dispatch];\n}\nfunction rerenderReducer(reducer) {\n var hook = updateWorkInProgressHook(),\n queue = hook.queue;\n if (null === queue)\n throw Error(\n \"Should have a queue. This is likely a bug in React. Please file an issue.\"\n );\n queue.lastRenderedReducer = reducer;\n var dispatch = queue.dispatch,\n lastRenderPhaseUpdate = queue.pending,\n newState = hook.memoizedState;\n if (null !== lastRenderPhaseUpdate) {\n queue.pending = null;\n var update = (lastRenderPhaseUpdate = lastRenderPhaseUpdate.next);\n do (newState = reducer(newState, update.action)), (update = update.next);\n while (update !== lastRenderPhaseUpdate);\n objectIs(newState, hook.memoizedState) || (didReceiveUpdate = !0);\n hook.memoizedState = newState;\n null === hook.baseQueue && (hook.baseState = newState);\n queue.lastRenderedState = newState;\n }\n return [newState, dispatch];\n}\nfunction updateMutableSource() {}\nfunction updateSyncExternalStore(subscribe, getSnapshot) {\n var fiber = currentlyRenderingFiber$1,\n hook = updateWorkInProgressHook(),\n nextSnapshot = getSnapshot(),\n snapshotChanged = !objectIs(hook.memoizedState, nextSnapshot);\n snapshotChanged &&\n ((hook.memoizedState = nextSnapshot), (didReceiveUpdate = !0));\n hook = hook.queue;\n updateEffect(subscribeToStore.bind(null, fiber, hook, subscribe), [\n subscribe\n ]);\n if (\n hook.getSnapshot !== getSnapshot ||\n snapshotChanged ||\n (null !== workInProgressHook && workInProgressHook.memoizedState.tag & 1)\n ) {\n fiber.flags |= 2048;\n pushEffect(\n 9,\n updateStoreInstance.bind(null, fiber, hook, nextSnapshot, getSnapshot),\n void 0,\n null\n );\n if (null === workInProgressRoot)\n throw Error(\n \"Expected a work-in-progress root. This is a bug in React. Please file an issue.\"\n );\n 0 !== (renderLanes & 30) ||\n pushStoreConsistencyCheck(fiber, getSnapshot, nextSnapshot);\n }\n return nextSnapshot;\n}\nfunction pushStoreConsistencyCheck(fiber, getSnapshot, renderedSnapshot) {\n fiber.flags |= 16384;\n fiber = { getSnapshot: getSnapshot, value: renderedSnapshot };\n getSnapshot = currentlyRenderingFiber$1.updateQueue;\n null === getSnapshot\n ? ((getSnapshot = { lastEffect: null, stores: null }),\n (currentlyRenderingFiber$1.updateQueue = getSnapshot),\n (getSnapshot.stores = [fiber]))\n : ((renderedSnapshot = getSnapshot.stores),\n null === renderedSnapshot\n ? (getSnapshot.stores = [fiber])\n : renderedSnapshot.push(fiber));\n}\nfunction updateStoreInstance(fiber, inst, nextSnapshot, getSnapshot) {\n inst.value = nextSnapshot;\n inst.getSnapshot = getSnapshot;\n checkIfSnapshotChanged(inst) && forceStoreRerender(fiber);\n}\nfunction subscribeToStore(fiber, inst, subscribe) {\n return subscribe(function() {\n checkIfSnapshotChanged(inst) && forceStoreRerender(fiber);\n });\n}\nfunction checkIfSnapshotChanged(inst) {\n var latestGetSnapshot = inst.getSnapshot;\n inst = inst.value;\n try {\n var nextValue = latestGetSnapshot();\n return !objectIs(inst, nextValue);\n } catch (error) {\n return !0;\n }\n}\nfunction forceStoreRerender(fiber) {\n var root = markUpdateLaneFromFiberToRoot(fiber, 1);\n null !== root && scheduleUpdateOnFiber(root, fiber, 1, -1);\n}\nfunction mountState(initialState) {\n var hook = mountWorkInProgressHook();\n \"function\" === typeof initialState && (initialState = initialState());\n hook.memoizedState = hook.baseState = initialState;\n initialState = {\n pending: null,\n interleaved: null,\n lanes: 0,\n dispatch: null,\n lastRenderedReducer: basicStateReducer,\n lastRenderedState: initialState\n };\n hook.queue = initialState;\n initialState = initialState.dispatch = dispatchSetState.bind(\n null,\n currentlyRenderingFiber$1,\n initialState\n );\n return [hook.memoizedState, initialState];\n}\nfunction pushEffect(tag, create, destroy, deps) {\n tag = { tag: tag, create: create, destroy: destroy, deps: deps, next: null };\n create = currentlyRenderingFiber$1.updateQueue;\n null === create\n ? ((create = { lastEffect: null, stores: null }),\n (currentlyRenderingFiber$1.updateQueue = create),\n (create.lastEffect = tag.next = tag))\n : ((destroy = create.lastEffect),\n null === destroy\n ? (create.lastEffect = tag.next = tag)\n : ((deps = destroy.next),\n (destroy.next = tag),\n (tag.next = deps),\n (create.lastEffect = tag)));\n return tag;\n}\nfunction updateRef() {\n return updateWorkInProgressHook().memoizedState;\n}\nfunction mountEffectImpl(fiberFlags, hookFlags, create, deps) {\n var hook = mountWorkInProgressHook();\n currentlyRenderingFiber$1.flags |= fiberFlags;\n hook.memoizedState = pushEffect(\n 1 | hookFlags,\n create,\n void 0,\n void 0 === deps ? null : deps\n );\n}\nfunction updateEffectImpl(fiberFlags, hookFlags, create, deps) {\n var hook = updateWorkInProgressHook();\n deps = void 0 === deps ? null : deps;\n var destroy = void 0;\n if (null !== currentHook) {\n var prevEffect = currentHook.memoizedState;\n destroy = prevEffect.destroy;\n if (null !== deps && areHookInputsEqual(deps, prevEffect.deps)) {\n hook.memoizedState = pushEffect(hookFlags, create, destroy, deps);\n return;\n }\n }\n currentlyRenderingFiber$1.flags |= fiberFlags;\n hook.memoizedState = pushEffect(1 | hookFlags, create, destroy, deps);\n}\nfunction mountEffect(create, deps) {\n return mountEffectImpl(8390656, 8, create, deps);\n}\nfunction updateEffect(create, deps) {\n return updateEffectImpl(2048, 8, create, deps);\n}\nfunction updateInsertionEffect(create, deps) {\n return updateEffectImpl(4, 2, create, deps);\n}\nfunction updateLayoutEffect(create, deps) {\n return updateEffectImpl(4, 4, create, deps);\n}\nfunction imperativeHandleEffect(create, ref) {\n if (\"function\" === typeof ref)\n return (\n (create = create()),\n ref(create),\n function() {\n ref(null);\n }\n );\n if (null !== ref && void 0 !== ref)\n return (\n (create = create()),\n (ref.current = create),\n function() {\n ref.current = null;\n }\n );\n}\nfunction updateImperativeHandle(ref, create, deps) {\n deps = null !== deps && void 0 !== deps ? deps.concat([ref]) : null;\n return updateEffectImpl(\n 4,\n 4,\n imperativeHandleEffect.bind(null, create, ref),\n deps\n );\n}\nfunction mountDebugValue() {}\nfunction updateCallback(callback, deps) {\n var hook = updateWorkInProgressHook();\n deps = void 0 === deps ? null : deps;\n var prevState = hook.memoizedState;\n if (\n null !== prevState &&\n null !== deps &&\n areHookInputsEqual(deps, prevState[1])\n )\n return prevState[0];\n hook.memoizedState = [callback, deps];\n return callback;\n}\nfunction updateMemo(nextCreate, deps) {\n var hook = updateWorkInProgressHook();\n deps = void 0 === deps ? null : deps;\n var prevState = hook.memoizedState;\n if (\n null !== prevState &&\n null !== deps &&\n areHookInputsEqual(deps, prevState[1])\n )\n return prevState[0];\n nextCreate = nextCreate();\n hook.memoizedState = [nextCreate, deps];\n return nextCreate;\n}\nfunction updateDeferredValueImpl(hook, prevValue, value) {\n if (0 === (renderLanes & 21))\n return (\n hook.baseState && ((hook.baseState = !1), (didReceiveUpdate = !0)),\n (hook.memoizedState = value)\n );\n objectIs(value, prevValue) ||\n ((value = claimNextTransitionLane()),\n (currentlyRenderingFiber$1.lanes |= value),\n (workInProgressRootSkippedLanes |= value),\n (hook.baseState = !0));\n return prevValue;\n}\nfunction startTransition(setPending, callback) {\n var previousPriority = currentUpdatePriority;\n currentUpdatePriority =\n 0 !== previousPriority && 4 > previousPriority ? previousPriority : 4;\n setPending(!0);\n var prevTransition = ReactCurrentBatchConfig$1.transition;\n ReactCurrentBatchConfig$1.transition = {};\n try {\n setPending(!1), callback();\n } finally {\n (currentUpdatePriority = previousPriority),\n (ReactCurrentBatchConfig$1.transition = prevTransition);\n }\n}\nfunction updateId() {\n return updateWorkInProgressHook().memoizedState;\n}\nfunction dispatchReducerAction(fiber, queue, action) {\n var lane = requestUpdateLane(fiber);\n action = {\n lane: lane,\n action: action,\n hasEagerState: !1,\n eagerState: null,\n next: null\n };\n if (isRenderPhaseUpdate(fiber)) enqueueRenderPhaseUpdate(queue, action);\n else if (\n ((action = enqueueConcurrentHookUpdate(fiber, queue, action, lane)),\n null !== action)\n ) {\n var eventTime = requestEventTime();\n scheduleUpdateOnFiber(action, fiber, lane, eventTime);\n entangleTransitionUpdate(action, queue, lane);\n }\n}\nfunction dispatchSetState(fiber, queue, action) {\n var lane = requestUpdateLane(fiber),\n update = {\n lane: lane,\n action: action,\n hasEagerState: !1,\n eagerState: null,\n next: null\n };\n if (isRenderPhaseUpdate(fiber)) enqueueRenderPhaseUpdate(queue, update);\n else {\n var alternate = fiber.alternate;\n if (\n 0 === fiber.lanes &&\n (null === alternate || 0 === alternate.lanes) &&\n ((alternate = queue.lastRenderedReducer), null !== alternate)\n )\n try {\n var currentState = queue.lastRenderedState,\n eagerState = alternate(currentState, action);\n update.hasEagerState = !0;\n update.eagerState = eagerState;\n if (objectIs(eagerState, currentState)) {\n var interleaved = queue.interleaved;\n null === interleaved\n ? ((update.next = update), pushConcurrentUpdateQueue(queue))\n : ((update.next = interleaved.next), (interleaved.next = update));\n queue.interleaved = update;\n return;\n }\n } catch (error) {\n } finally {\n }\n action = enqueueConcurrentHookUpdate(fiber, queue, update, lane);\n null !== action &&\n ((update = requestEventTime()),\n scheduleUpdateOnFiber(action, fiber, lane, update),\n entangleTransitionUpdate(action, queue, lane));\n }\n}\nfunction isRenderPhaseUpdate(fiber) {\n var alternate = fiber.alternate;\n return (\n fiber === currentlyRenderingFiber$1 ||\n (null !== alternate && alternate === currentlyRenderingFiber$1)\n );\n}\nfunction enqueueRenderPhaseUpdate(queue, update) {\n didScheduleRenderPhaseUpdateDuringThisPass = didScheduleRenderPhaseUpdate = !0;\n var pending = queue.pending;\n null === pending\n ? (update.next = update)\n : ((update.next = pending.next), (pending.next = update));\n queue.pending = update;\n}\nfunction entangleTransitionUpdate(root, queue, lane) {\n if (0 !== (lane & 4194240)) {\n var queueLanes = queue.lanes;\n queueLanes &= root.pendingLanes;\n lane |= queueLanes;\n queue.lanes = lane;\n markRootEntangled(root, lane);\n }\n}\nvar ContextOnlyDispatcher = {\n readContext: readContext,\n useCallback: throwInvalidHookError,\n useContext: throwInvalidHookError,\n useEffect: throwInvalidHookError,\n useImperativeHandle: throwInvalidHookError,\n useInsertionEffect: throwInvalidHookError,\n useLayoutEffect: throwInvalidHookError,\n useMemo: throwInvalidHookError,\n useReducer: throwInvalidHookError,\n useRef: throwInvalidHookError,\n useState: throwInvalidHookError,\n useDebugValue: throwInvalidHookError,\n useDeferredValue: throwInvalidHookError,\n useTransition: throwInvalidHookError,\n useMutableSource: throwInvalidHookError,\n useSyncExternalStore: throwInvalidHookError,\n useId: throwInvalidHookError,\n unstable_isNewReconciler: !1\n },\n HooksDispatcherOnMount = {\n readContext: readContext,\n useCallback: function(callback, deps) {\n mountWorkInProgressHook().memoizedState = [\n callback,\n void 0 === deps ? null : deps\n ];\n return callback;\n },\n useContext: readContext,\n useEffect: mountEffect,\n useImperativeHandle: function(ref, create, deps) {\n deps = null !== deps && void 0 !== deps ? deps.concat([ref]) : null;\n return mountEffectImpl(\n 4,\n 4,\n imperativeHandleEffect.bind(null, create, ref),\n deps\n );\n },\n useLayoutEffect: function(create, deps) {\n return mountEffectImpl(4, 4, create, deps);\n },\n useInsertionEffect: function(create, deps) {\n return mountEffectImpl(4, 2, create, deps);\n },\n useMemo: function(nextCreate, deps) {\n var hook = mountWorkInProgressHook();\n deps = void 0 === deps ? null : deps;\n nextCreate = nextCreate();\n hook.memoizedState = [nextCreate, deps];\n return nextCreate;\n },\n useReducer: function(reducer, initialArg, init) {\n var hook = mountWorkInProgressHook();\n initialArg = void 0 !== init ? init(initialArg) : initialArg;\n hook.memoizedState = hook.baseState = initialArg;\n reducer = {\n pending: null,\n interleaved: null,\n lanes: 0,\n dispatch: null,\n lastRenderedReducer: reducer,\n lastRenderedState: initialArg\n };\n hook.queue = reducer;\n reducer = reducer.dispatch = dispatchReducerAction.bind(\n null,\n currentlyRenderingFiber$1,\n reducer\n );\n return [hook.memoizedState, reducer];\n },\n useRef: function(initialValue) {\n var hook = mountWorkInProgressHook();\n initialValue = { current: initialValue };\n return (hook.memoizedState = initialValue);\n },\n useState: mountState,\n useDebugValue: mountDebugValue,\n useDeferredValue: function(value) {\n return (mountWorkInProgressHook().memoizedState = value);\n },\n useTransition: function() {\n var _mountState = mountState(!1),\n isPending = _mountState[0];\n _mountState = startTransition.bind(null, _mountState[1]);\n mountWorkInProgressHook().memoizedState = _mountState;\n return [isPending, _mountState];\n },\n useMutableSource: function() {},\n useSyncExternalStore: function(subscribe, getSnapshot) {\n var fiber = currentlyRenderingFiber$1,\n hook = mountWorkInProgressHook();\n var nextSnapshot = getSnapshot();\n if (null === workInProgressRoot)\n throw Error(\n \"Expected a work-in-progress root. This is a bug in React. Please file an issue.\"\n );\n 0 !== (renderLanes & 30) ||\n pushStoreConsistencyCheck(fiber, getSnapshot, nextSnapshot);\n hook.memoizedState = nextSnapshot;\n var inst = { value: nextSnapshot, getSnapshot: getSnapshot };\n hook.queue = inst;\n mountEffect(subscribeToStore.bind(null, fiber, inst, subscribe), [\n subscribe\n ]);\n fiber.flags |= 2048;\n pushEffect(\n 9,\n updateStoreInstance.bind(null, fiber, inst, nextSnapshot, getSnapshot),\n void 0,\n null\n );\n return nextSnapshot;\n },\n useId: function() {\n var hook = mountWorkInProgressHook(),\n identifierPrefix = workInProgressRoot.identifierPrefix,\n globalClientId = globalClientIdCounter++;\n identifierPrefix =\n \":\" + identifierPrefix + \"r\" + globalClientId.toString(32) + \":\";\n return (hook.memoizedState = identifierPrefix);\n },\n unstable_isNewReconciler: !1\n },\n HooksDispatcherOnUpdate = {\n readContext: readContext,\n useCallback: updateCallback,\n useContext: readContext,\n useEffect: updateEffect,\n useImperativeHandle: updateImperativeHandle,\n useInsertionEffect: updateInsertionEffect,\n useLayoutEffect: updateLayoutEffect,\n useMemo: updateMemo,\n useReducer: updateReducer,\n useRef: updateRef,\n useState: function() {\n return updateReducer(basicStateReducer);\n },\n useDebugValue: mountDebugValue,\n useDeferredValue: function(value) {\n var hook = updateWorkInProgressHook();\n return updateDeferredValueImpl(hook, currentHook.memoizedState, value);\n },\n useTransition: function() {\n var isPending = updateReducer(basicStateReducer)[0],\n start = updateWorkInProgressHook().memoizedState;\n return [isPending, start];\n },\n useMutableSource: updateMutableSource,\n useSyncExternalStore: updateSyncExternalStore,\n useId: updateId,\n unstable_isNewReconciler: !1\n },\n HooksDispatcherOnRerender = {\n readContext: readContext,\n useCallback: updateCallback,\n useContext: readContext,\n useEffect: updateEffect,\n useImperativeHandle: updateImperativeHandle,\n useInsertionEffect: updateInsertionEffect,\n useLayoutEffect: updateLayoutEffect,\n useMemo: updateMemo,\n useReducer: rerenderReducer,\n useRef: updateRef,\n useState: function() {\n return rerenderReducer(basicStateReducer);\n },\n useDebugValue: mountDebugValue,\n useDeferredValue: function(value) {\n var hook = updateWorkInProgressHook();\n return null === currentHook\n ? (hook.memoizedState = value)\n : updateDeferredValueImpl(hook, currentHook.memoizedState, value);\n },\n useTransition: function() {\n var isPending = rerenderReducer(basicStateReducer)[0],\n start = updateWorkInProgressHook().memoizedState;\n return [isPending, start];\n },\n useMutableSource: updateMutableSource,\n useSyncExternalStore: updateSyncExternalStore,\n useId: updateId,\n unstable_isNewReconciler: !1\n };\nfunction createCapturedValueAtFiber(value, source) {\n try {\n var info = \"\",\n node = source;\n do (info += describeFiber(node)), (node = node.return);\n while (node);\n var JSCompiler_inline_result = info;\n } catch (x) {\n JSCompiler_inline_result =\n \"\\nError generating stack: \" + x.message + \"\\n\" + x.stack;\n }\n return {\n value: value,\n source: source,\n stack: JSCompiler_inline_result,\n digest: null\n };\n}\nfunction createCapturedValue(value, digest, stack) {\n return {\n value: value,\n source: null,\n stack: null != stack ? stack : null,\n digest: null != digest ? digest : null\n };\n}\nif (\n \"function\" !==\n typeof ReactNativePrivateInterface.ReactFiberErrorDialog.showErrorDialog\n)\n throw Error(\n \"Expected ReactFiberErrorDialog.showErrorDialog to be a function.\"\n );\nfunction logCapturedError(boundary, errorInfo) {\n try {\n !1 !==\n ReactNativePrivateInterface.ReactFiberErrorDialog.showErrorDialog({\n componentStack: null !== errorInfo.stack ? errorInfo.stack : \"\",\n error: errorInfo.value,\n errorBoundary:\n null !== boundary && 1 === boundary.tag ? boundary.stateNode : null\n }) && console.error(errorInfo.value);\n } catch (e) {\n setTimeout(function() {\n throw e;\n });\n }\n}\nvar PossiblyWeakMap = \"function\" === typeof WeakMap ? WeakMap : Map;\nfunction createRootErrorUpdate(fiber, errorInfo, lane) {\n lane = createUpdate(-1, lane);\n lane.tag = 3;\n lane.payload = { element: null };\n var error = errorInfo.value;\n lane.callback = function() {\n hasUncaughtError || ((hasUncaughtError = !0), (firstUncaughtError = error));\n logCapturedError(fiber, errorInfo);\n };\n return lane;\n}\nfunction createClassErrorUpdate(fiber, errorInfo, lane) {\n lane = createUpdate(-1, lane);\n lane.tag = 3;\n var getDerivedStateFromError = fiber.type.getDerivedStateFromError;\n if (\"function\" === typeof getDerivedStateFromError) {\n var error = errorInfo.value;\n lane.payload = function() {\n return getDerivedStateFromError(error);\n };\n lane.callback = function() {\n logCapturedError(fiber, errorInfo);\n };\n }\n var inst = fiber.stateNode;\n null !== inst &&\n \"function\" === typeof inst.componentDidCatch &&\n (lane.callback = function() {\n logCapturedError(fiber, errorInfo);\n \"function\" !== typeof getDerivedStateFromError &&\n (null === legacyErrorBoundariesThatAlreadyFailed\n ? (legacyErrorBoundariesThatAlreadyFailed = new Set([this]))\n : legacyErrorBoundariesThatAlreadyFailed.add(this));\n var stack = errorInfo.stack;\n this.componentDidCatch(errorInfo.value, {\n componentStack: null !== stack ? stack : \"\"\n });\n });\n return lane;\n}\nfunction attachPingListener(root, wakeable, lanes) {\n var pingCache = root.pingCache;\n if (null === pingCache) {\n pingCache = root.pingCache = new PossiblyWeakMap();\n var threadIDs = new Set();\n pingCache.set(wakeable, threadIDs);\n } else\n (threadIDs = pingCache.get(wakeable)),\n void 0 === threadIDs &&\n ((threadIDs = new Set()), pingCache.set(wakeable, threadIDs));\n threadIDs.has(lanes) ||\n (threadIDs.add(lanes),\n (root = pingSuspendedRoot.bind(null, root, wakeable, lanes)),\n wakeable.then(root, root));\n}\nvar ReactCurrentOwner$1 = ReactSharedInternals.ReactCurrentOwner,\n didReceiveUpdate = !1;\nfunction reconcileChildren(current, workInProgress, nextChildren, renderLanes) {\n workInProgress.child =\n null === current\n ? mountChildFibers(workInProgress, null, nextChildren, renderLanes)\n : reconcileChildFibers(\n workInProgress,\n current.child,\n nextChildren,\n renderLanes\n );\n}\nfunction updateForwardRef(\n current,\n workInProgress,\n Component,\n nextProps,\n renderLanes\n) {\n Component = Component.render;\n var ref = workInProgress.ref;\n prepareToReadContext(workInProgress, renderLanes);\n nextProps = renderWithHooks(\n current,\n workInProgress,\n Component,\n nextProps,\n ref,\n renderLanes\n );\n if (null !== current && !didReceiveUpdate)\n return (\n (workInProgress.updateQueue = current.updateQueue),\n (workInProgress.flags &= -2053),\n (current.lanes &= ~renderLanes),\n bailoutOnAlreadyFinishedWork(current, workInProgress, renderLanes)\n );\n workInProgress.flags |= 1;\n reconcileChildren(current, workInProgress, nextProps, renderLanes);\n return workInProgress.child;\n}\nfunction updateMemoComponent(\n current,\n workInProgress,\n Component,\n nextProps,\n renderLanes\n) {\n if (null === current) {\n var type = Component.type;\n if (\n \"function\" === typeof type &&\n !shouldConstruct(type) &&\n void 0 === type.defaultProps &&\n null === Component.compare &&\n void 0 === Component.defaultProps\n )\n return (\n (workInProgress.tag = 15),\n (workInProgress.type = type),\n updateSimpleMemoComponent(\n current,\n workInProgress,\n type,\n nextProps,\n renderLanes\n )\n );\n current = createFiberFromTypeAndProps(\n Component.type,\n null,\n nextProps,\n workInProgress,\n workInProgress.mode,\n renderLanes\n );\n current.ref = workInProgress.ref;\n current.return = workInProgress;\n return (workInProgress.child = current);\n }\n type = current.child;\n if (0 === (current.lanes & renderLanes)) {\n var prevProps = type.memoizedProps;\n Component = Component.compare;\n Component = null !== Component ? Component : shallowEqual;\n if (Component(prevProps, nextProps) && current.ref === workInProgress.ref)\n return bailoutOnAlreadyFinishedWork(current, workInProgress, renderLanes);\n }\n workInProgress.flags |= 1;\n current = createWorkInProgress(type, nextProps);\n current.ref = workInProgress.ref;\n current.return = workInProgress;\n return (workInProgress.child = current);\n}\nfunction updateSimpleMemoComponent(\n current,\n workInProgress,\n Component,\n nextProps,\n renderLanes\n) {\n if (null !== current) {\n var prevProps = current.memoizedProps;\n if (\n shallowEqual(prevProps, nextProps) &&\n current.ref === workInProgress.ref\n )\n if (\n ((didReceiveUpdate = !1),\n (workInProgress.pendingProps = nextProps = prevProps),\n 0 !== (current.lanes & renderLanes))\n )\n 0 !== (current.flags & 131072) && (didReceiveUpdate = !0);\n else\n return (\n (workInProgress.lanes = current.lanes),\n bailoutOnAlreadyFinishedWork(current, workInProgress, renderLanes)\n );\n }\n return updateFunctionComponent(\n current,\n workInProgress,\n Component,\n nextProps,\n renderLanes\n );\n}\nfunction updateOffscreenComponent(current, workInProgress, renderLanes) {\n var nextProps = workInProgress.pendingProps,\n nextChildren = nextProps.children,\n prevState = null !== current ? current.memoizedState : null;\n if (\"hidden\" === nextProps.mode)\n if (0 === (workInProgress.mode & 1))\n (workInProgress.memoizedState = {\n baseLanes: 0,\n cachePool: null,\n transitions: null\n }),\n push(subtreeRenderLanesCursor, subtreeRenderLanes),\n (subtreeRenderLanes |= renderLanes);\n else {\n if (0 === (renderLanes & 1073741824))\n return (\n (current =\n null !== prevState\n ? prevState.baseLanes | renderLanes\n : renderLanes),\n (workInProgress.lanes = workInProgress.childLanes = 1073741824),\n (workInProgress.memoizedState = {\n baseLanes: current,\n cachePool: null,\n transitions: null\n }),\n (workInProgress.updateQueue = null),\n push(subtreeRenderLanesCursor, subtreeRenderLanes),\n (subtreeRenderLanes |= current),\n null\n );\n workInProgress.memoizedState = {\n baseLanes: 0,\n cachePool: null,\n transitions: null\n };\n nextProps = null !== prevState ? prevState.baseLanes : renderLanes;\n push(subtreeRenderLanesCursor, subtreeRenderLanes);\n subtreeRenderLanes |= nextProps;\n }\n else\n null !== prevState\n ? ((nextProps = prevState.baseLanes | renderLanes),\n (workInProgress.memoizedState = null))\n : (nextProps = renderLanes),\n push(subtreeRenderLanesCursor, subtreeRenderLanes),\n (subtreeRenderLanes |= nextProps);\n reconcileChildren(current, workInProgress, nextChildren, renderLanes);\n return workInProgress.child;\n}\nfunction markRef(current, workInProgress) {\n var ref = workInProgress.ref;\n if (\n (null === current && null !== ref) ||\n (null !== current && current.ref !== ref)\n )\n workInProgress.flags |= 512;\n}\nfunction updateFunctionComponent(\n current,\n workInProgress,\n Component,\n nextProps,\n renderLanes\n) {\n var context = isContextProvider(Component)\n ? previousContext\n : contextStackCursor.current;\n context = getMaskedContext(workInProgress, context);\n prepareToReadContext(workInProgress, renderLanes);\n Component = renderWithHooks(\n current,\n workInProgress,\n Component,\n nextProps,\n context,\n renderLanes\n );\n if (null !== current && !didReceiveUpdate)\n return (\n (workInProgress.updateQueue = current.updateQueue),\n (workInProgress.flags &= -2053),\n (current.lanes &= ~renderLanes),\n bailoutOnAlreadyFinishedWork(current, workInProgress, renderLanes)\n );\n workInProgress.flags |= 1;\n reconcileChildren(current, workInProgress, Component, renderLanes);\n return workInProgress.child;\n}\nfunction updateClassComponent(\n current,\n workInProgress,\n Component,\n nextProps,\n renderLanes\n) {\n if (isContextProvider(Component)) {\n var hasContext = !0;\n pushContextProvider(workInProgress);\n } else hasContext = !1;\n prepareToReadContext(workInProgress, renderLanes);\n if (null === workInProgress.stateNode)\n resetSuspendedCurrentOnMountInLegacyMode(current, workInProgress),\n constructClassInstance(workInProgress, Component, nextProps),\n mountClassInstance(workInProgress, Component, nextProps, renderLanes),\n (nextProps = !0);\n else if (null === current) {\n var instance = workInProgress.stateNode,\n oldProps = workInProgress.memoizedProps;\n instance.props = oldProps;\n var oldContext = instance.context,\n contextType = Component.contextType;\n \"object\" === typeof contextType && null !== contextType\n ? (contextType = readContext(contextType))\n : ((contextType = isContextProvider(Component)\n ? previousContext\n : contextStackCursor.current),\n (contextType = getMaskedContext(workInProgress, contextType)));\n var getDerivedStateFromProps = Component.getDerivedStateFromProps,\n hasNewLifecycles =\n \"function\" === typeof getDerivedStateFromProps ||\n \"function\" === typeof instance.getSnapshotBeforeUpdate;\n hasNewLifecycles ||\n (\"function\" !== typeof instance.UNSAFE_componentWillReceiveProps &&\n \"function\" !== typeof instance.componentWillReceiveProps) ||\n ((oldProps !== nextProps || oldContext !== contextType) &&\n callComponentWillReceiveProps(\n workInProgress,\n instance,\n nextProps,\n contextType\n ));\n hasForceUpdate = !1;\n var oldState = workInProgress.memoizedState;\n instance.state = oldState;\n processUpdateQueue(workInProgress, nextProps, instance, renderLanes);\n oldContext = workInProgress.memoizedState;\n oldProps !== nextProps ||\n oldState !== oldContext ||\n didPerformWorkStackCursor.current ||\n hasForceUpdate\n ? (\"function\" === typeof getDerivedStateFromProps &&\n (applyDerivedStateFromProps(\n workInProgress,\n Component,\n getDerivedStateFromProps,\n nextProps\n ),\n (oldContext = workInProgress.memoizedState)),\n (oldProps =\n hasForceUpdate ||\n checkShouldComponentUpdate(\n workInProgress,\n Component,\n oldProps,\n nextProps,\n oldState,\n oldContext,\n contextType\n ))\n ? (hasNewLifecycles ||\n (\"function\" !== typeof instance.UNSAFE_componentWillMount &&\n \"function\" !== typeof instance.componentWillMount) ||\n (\"function\" === typeof instance.componentWillMount &&\n instance.componentWillMount(),\n \"function\" === typeof instance.UNSAFE_componentWillMount &&\n instance.UNSAFE_componentWillMount()),\n \"function\" === typeof instance.componentDidMount &&\n (workInProgress.flags |= 4))\n : (\"function\" === typeof instance.componentDidMount &&\n (workInProgress.flags |= 4),\n (workInProgress.memoizedProps = nextProps),\n (workInProgress.memoizedState = oldContext)),\n (instance.props = nextProps),\n (instance.state = oldContext),\n (instance.context = contextType),\n (nextProps = oldProps))\n : (\"function\" === typeof instance.componentDidMount &&\n (workInProgress.flags |= 4),\n (nextProps = !1));\n } else {\n instance = workInProgress.stateNode;\n cloneUpdateQueue(current, workInProgress);\n oldProps = workInProgress.memoizedProps;\n contextType =\n workInProgress.type === workInProgress.elementType\n ? oldProps\n : resolveDefaultProps(workInProgress.type, oldProps);\n instance.props = contextType;\n hasNewLifecycles = workInProgress.pendingProps;\n oldState = instance.context;\n oldContext = Component.contextType;\n \"object\" === typeof oldContext && null !== oldContext\n ? (oldContext = readContext(oldContext))\n : ((oldContext = isContextProvider(Component)\n ? previousContext\n : contextStackCursor.current),\n (oldContext = getMaskedContext(workInProgress, oldContext)));\n var getDerivedStateFromProps$jscomp$0 = Component.getDerivedStateFromProps;\n (getDerivedStateFromProps =\n \"function\" === typeof getDerivedStateFromProps$jscomp$0 ||\n \"function\" === typeof instance.getSnapshotBeforeUpdate) ||\n (\"function\" !== typeof instance.UNSAFE_componentWillReceiveProps &&\n \"function\" !== typeof instance.componentWillReceiveProps) ||\n ((oldProps !== hasNewLifecycles || oldState !== oldContext) &&\n callComponentWillReceiveProps(\n workInProgress,\n instance,\n nextProps,\n oldContext\n ));\n hasForceUpdate = !1;\n oldState = workInProgress.memoizedState;\n instance.state = oldState;\n processUpdateQueue(workInProgress, nextProps, instance, renderLanes);\n var newState = workInProgress.memoizedState;\n oldProps !== hasNewLifecycles ||\n oldState !== newState ||\n didPerformWorkStackCursor.current ||\n hasForceUpdate\n ? (\"function\" === typeof getDerivedStateFromProps$jscomp$0 &&\n (applyDerivedStateFromProps(\n workInProgress,\n Component,\n getDerivedStateFromProps$jscomp$0,\n nextProps\n ),\n (newState = workInProgress.memoizedState)),\n (contextType =\n hasForceUpdate ||\n checkShouldComponentUpdate(\n workInProgress,\n Component,\n contextType,\n nextProps,\n oldState,\n newState,\n oldContext\n ) ||\n !1)\n ? (getDerivedStateFromProps ||\n (\"function\" !== typeof instance.UNSAFE_componentWillUpdate &&\n \"function\" !== typeof instance.componentWillUpdate) ||\n (\"function\" === typeof instance.componentWillUpdate &&\n instance.componentWillUpdate(nextProps, newState, oldContext),\n \"function\" === typeof instance.UNSAFE_componentWillUpdate &&\n instance.UNSAFE_componentWillUpdate(\n nextProps,\n newState,\n oldContext\n )),\n \"function\" === typeof instance.componentDidUpdate &&\n (workInProgress.flags |= 4),\n \"function\" === typeof instance.getSnapshotBeforeUpdate &&\n (workInProgress.flags |= 1024))\n : (\"function\" !== typeof instance.componentDidUpdate ||\n (oldProps === current.memoizedProps &&\n oldState === current.memoizedState) ||\n (workInProgress.flags |= 4),\n \"function\" !== typeof instance.getSnapshotBeforeUpdate ||\n (oldProps === current.memoizedProps &&\n oldState === current.memoizedState) ||\n (workInProgress.flags |= 1024),\n (workInProgress.memoizedProps = nextProps),\n (workInProgress.memoizedState = newState)),\n (instance.props = nextProps),\n (instance.state = newState),\n (instance.context = oldContext),\n (nextProps = contextType))\n : (\"function\" !== typeof instance.componentDidUpdate ||\n (oldProps === current.memoizedProps &&\n oldState === current.memoizedState) ||\n (workInProgress.flags |= 4),\n \"function\" !== typeof instance.getSnapshotBeforeUpdate ||\n (oldProps === current.memoizedProps &&\n oldState === current.memoizedState) ||\n (workInProgress.flags |= 1024),\n (nextProps = !1));\n }\n return finishClassComponent(\n current,\n workInProgress,\n Component,\n nextProps,\n hasContext,\n renderLanes\n );\n}\nfunction finishClassComponent(\n current,\n workInProgress,\n Component,\n shouldUpdate,\n hasContext,\n renderLanes\n) {\n markRef(current, workInProgress);\n var didCaptureError = 0 !== (workInProgress.flags & 128);\n if (!shouldUpdate && !didCaptureError)\n return (\n hasContext && invalidateContextProvider(workInProgress, Component, !1),\n bailoutOnAlreadyFinishedWork(current, workInProgress, renderLanes)\n );\n shouldUpdate = workInProgress.stateNode;\n ReactCurrentOwner$1.current = workInProgress;\n var nextChildren =\n didCaptureError && \"function\" !== typeof Component.getDerivedStateFromError\n ? null\n : shouldUpdate.render();\n workInProgress.flags |= 1;\n null !== current && didCaptureError\n ? ((workInProgress.child = reconcileChildFibers(\n workInProgress,\n current.child,\n null,\n renderLanes\n )),\n (workInProgress.child = reconcileChildFibers(\n workInProgress,\n null,\n nextChildren,\n renderLanes\n )))\n : reconcileChildren(current, workInProgress, nextChildren, renderLanes);\n workInProgress.memoizedState = shouldUpdate.state;\n hasContext && invalidateContextProvider(workInProgress, Component, !0);\n return workInProgress.child;\n}\nfunction pushHostRootContext(workInProgress) {\n var root = workInProgress.stateNode;\n root.pendingContext\n ? pushTopLevelContextObject(\n workInProgress,\n root.pendingContext,\n root.pendingContext !== root.context\n )\n : root.context &&\n pushTopLevelContextObject(workInProgress, root.context, !1);\n pushHostContainer(workInProgress, root.containerInfo);\n}\nvar SUSPENDED_MARKER = { dehydrated: null, treeContext: null, retryLane: 0 };\nfunction mountSuspenseOffscreenState(renderLanes) {\n return { baseLanes: renderLanes, cachePool: null, transitions: null };\n}\nfunction updateSuspenseComponent(current, workInProgress, renderLanes) {\n var nextProps = workInProgress.pendingProps,\n suspenseContext = suspenseStackCursor.current,\n showFallback = !1,\n didSuspend = 0 !== (workInProgress.flags & 128),\n JSCompiler_temp;\n (JSCompiler_temp = didSuspend) ||\n (JSCompiler_temp =\n null !== current && null === current.memoizedState\n ? !1\n : 0 !== (suspenseContext & 2));\n if (JSCompiler_temp) (showFallback = !0), (workInProgress.flags &= -129);\n else if (null === current || null !== current.memoizedState)\n suspenseContext |= 1;\n push(suspenseStackCursor, suspenseContext & 1);\n if (null === current) {\n current = workInProgress.memoizedState;\n if (null !== current && null !== current.dehydrated)\n return (\n 0 === (workInProgress.mode & 1)\n ? (workInProgress.lanes = 1)\n : shim$1()\n ? (workInProgress.lanes = 8)\n : (workInProgress.lanes = 1073741824),\n null\n );\n didSuspend = nextProps.children;\n current = nextProps.fallback;\n return showFallback\n ? ((nextProps = workInProgress.mode),\n (showFallback = workInProgress.child),\n (didSuspend = { mode: \"hidden\", children: didSuspend }),\n 0 === (nextProps & 1) && null !== showFallback\n ? ((showFallback.childLanes = 0),\n (showFallback.pendingProps = didSuspend))\n : (showFallback = createFiberFromOffscreen(\n didSuspend,\n nextProps,\n 0,\n null\n )),\n (current = createFiberFromFragment(\n current,\n nextProps,\n renderLanes,\n null\n )),\n (showFallback.return = workInProgress),\n (current.return = workInProgress),\n (showFallback.sibling = current),\n (workInProgress.child = showFallback),\n (workInProgress.child.memoizedState = mountSuspenseOffscreenState(\n renderLanes\n )),\n (workInProgress.memoizedState = SUSPENDED_MARKER),\n current)\n : mountSuspensePrimaryChildren(workInProgress, didSuspend);\n }\n suspenseContext = current.memoizedState;\n if (\n null !== suspenseContext &&\n ((JSCompiler_temp = suspenseContext.dehydrated), null !== JSCompiler_temp)\n )\n return updateDehydratedSuspenseComponent(\n current,\n workInProgress,\n didSuspend,\n nextProps,\n JSCompiler_temp,\n suspenseContext,\n renderLanes\n );\n if (showFallback) {\n showFallback = nextProps.fallback;\n didSuspend = workInProgress.mode;\n suspenseContext = current.child;\n JSCompiler_temp = suspenseContext.sibling;\n var primaryChildProps = { mode: \"hidden\", children: nextProps.children };\n 0 === (didSuspend & 1) && workInProgress.child !== suspenseContext\n ? ((nextProps = workInProgress.child),\n (nextProps.childLanes = 0),\n (nextProps.pendingProps = primaryChildProps),\n (workInProgress.deletions = null))\n : ((nextProps = createWorkInProgress(suspenseContext, primaryChildProps)),\n (nextProps.subtreeFlags = suspenseContext.subtreeFlags & 14680064));\n null !== JSCompiler_temp\n ? (showFallback = createWorkInProgress(JSCompiler_temp, showFallback))\n : ((showFallback = createFiberFromFragment(\n showFallback,\n didSuspend,\n renderLanes,\n null\n )),\n (showFallback.flags |= 2));\n showFallback.return = workInProgress;\n nextProps.return = workInProgress;\n nextProps.sibling = showFallback;\n workInProgress.child = nextProps;\n nextProps = showFallback;\n showFallback = workInProgress.child;\n didSuspend = current.child.memoizedState;\n didSuspend =\n null === didSuspend\n ? mountSuspenseOffscreenState(renderLanes)\n : {\n baseLanes: didSuspend.baseLanes | renderLanes,\n cachePool: null,\n transitions: didSuspend.transitions\n };\n showFallback.memoizedState = didSuspend;\n showFallback.childLanes = current.childLanes & ~renderLanes;\n workInProgress.memoizedState = SUSPENDED_MARKER;\n return nextProps;\n }\n showFallback = current.child;\n current = showFallback.sibling;\n nextProps = createWorkInProgress(showFallback, {\n mode: \"visible\",\n children: nextProps.children\n });\n 0 === (workInProgress.mode & 1) && (nextProps.lanes = renderLanes);\n nextProps.return = workInProgress;\n nextProps.sibling = null;\n null !== current &&\n ((renderLanes = workInProgress.deletions),\n null === renderLanes\n ? ((workInProgress.deletions = [current]), (workInProgress.flags |= 16))\n : renderLanes.push(current));\n workInProgress.child = nextProps;\n workInProgress.memoizedState = null;\n return nextProps;\n}\nfunction mountSuspensePrimaryChildren(workInProgress, primaryChildren) {\n primaryChildren = createFiberFromOffscreen(\n { mode: \"visible\", children: primaryChildren },\n workInProgress.mode,\n 0,\n null\n );\n primaryChildren.return = workInProgress;\n return (workInProgress.child = primaryChildren);\n}\nfunction retrySuspenseComponentWithoutHydrating(\n current,\n workInProgress,\n renderLanes,\n recoverableError\n) {\n null !== recoverableError &&\n (null === hydrationErrors\n ? (hydrationErrors = [recoverableError])\n : hydrationErrors.push(recoverableError));\n reconcileChildFibers(workInProgress, current.child, null, renderLanes);\n current = mountSuspensePrimaryChildren(\n workInProgress,\n workInProgress.pendingProps.children\n );\n current.flags |= 2;\n workInProgress.memoizedState = null;\n return current;\n}\nfunction updateDehydratedSuspenseComponent(\n current,\n workInProgress,\n didSuspend,\n nextProps,\n suspenseInstance,\n suspenseState,\n renderLanes\n) {\n if (didSuspend) {\n if (workInProgress.flags & 256)\n return (\n (workInProgress.flags &= -257),\n (suspenseState = createCapturedValue(\n Error(\n \"There was an error while hydrating this Suspense boundary. Switched to client rendering.\"\n )\n )),\n retrySuspenseComponentWithoutHydrating(\n current,\n workInProgress,\n renderLanes,\n suspenseState\n )\n );\n if (null !== workInProgress.memoizedState)\n return (\n (workInProgress.child = current.child),\n (workInProgress.flags |= 128),\n null\n );\n suspenseState = nextProps.fallback;\n didSuspend = workInProgress.mode;\n nextProps = createFiberFromOffscreen(\n { mode: \"visible\", children: nextProps.children },\n didSuspend,\n 0,\n null\n );\n suspenseState = createFiberFromFragment(\n suspenseState,\n didSuspend,\n renderLanes,\n null\n );\n suspenseState.flags |= 2;\n nextProps.return = workInProgress;\n suspenseState.return = workInProgress;\n nextProps.sibling = suspenseState;\n workInProgress.child = nextProps;\n 0 !== (workInProgress.mode & 1) &&\n reconcileChildFibers(workInProgress, current.child, null, renderLanes);\n workInProgress.child.memoizedState = mountSuspenseOffscreenState(\n renderLanes\n );\n workInProgress.memoizedState = SUSPENDED_MARKER;\n return suspenseState;\n }\n if (0 === (workInProgress.mode & 1))\n return retrySuspenseComponentWithoutHydrating(\n current,\n workInProgress,\n renderLanes,\n null\n );\n if (shim$1())\n return (\n (suspenseState = shim$1().digest),\n (suspenseState = createCapturedValue(\n Error(\n \"The server could not finish this Suspense boundary, likely due to an error during server rendering. Switched to client rendering.\"\n ),\n suspenseState,\n void 0\n )),\n retrySuspenseComponentWithoutHydrating(\n current,\n workInProgress,\n renderLanes,\n suspenseState\n )\n );\n didSuspend = 0 !== (renderLanes & current.childLanes);\n if (didReceiveUpdate || didSuspend) {\n nextProps = workInProgressRoot;\n if (null !== nextProps) {\n switch (renderLanes & -renderLanes) {\n case 4:\n didSuspend = 2;\n break;\n case 16:\n didSuspend = 8;\n break;\n case 64:\n case 128:\n case 256:\n case 512:\n case 1024:\n case 2048:\n case 4096:\n case 8192:\n case 16384:\n case 32768:\n case 65536:\n case 131072:\n case 262144:\n case 524288:\n case 1048576:\n case 2097152:\n case 4194304:\n case 8388608:\n case 16777216:\n case 33554432:\n case 67108864:\n didSuspend = 32;\n break;\n case 536870912:\n didSuspend = 268435456;\n break;\n default:\n didSuspend = 0;\n }\n didSuspend =\n 0 !== (didSuspend & (nextProps.suspendedLanes | renderLanes))\n ? 0\n : didSuspend;\n 0 !== didSuspend &&\n didSuspend !== suspenseState.retryLane &&\n ((suspenseState.retryLane = didSuspend),\n markUpdateLaneFromFiberToRoot(current, didSuspend),\n scheduleUpdateOnFiber(nextProps, current, didSuspend, -1));\n }\n renderDidSuspendDelayIfPossible();\n suspenseState = createCapturedValue(\n Error(\n \"This Suspense boundary received an update before it finished hydrating. This caused the boundary to switch to client rendering. The usual way to fix this is to wrap the original update in startTransition.\"\n )\n );\n return retrySuspenseComponentWithoutHydrating(\n current,\n workInProgress,\n renderLanes,\n suspenseState\n );\n }\n if (shim$1())\n return (\n (workInProgress.flags |= 128),\n (workInProgress.child = current.child),\n retryDehydratedSuspenseBoundary.bind(null, current),\n shim$1(),\n null\n );\n current = mountSuspensePrimaryChildren(workInProgress, nextProps.children);\n current.flags |= 4096;\n return current;\n}\nfunction scheduleSuspenseWorkOnFiber(fiber, renderLanes, propagationRoot) {\n fiber.lanes |= renderLanes;\n var alternate = fiber.alternate;\n null !== alternate && (alternate.lanes |= renderLanes);\n scheduleContextWorkOnParentPath(fiber.return, renderLanes, propagationRoot);\n}\nfunction initSuspenseListRenderState(\n workInProgress,\n isBackwards,\n tail,\n lastContentRow,\n tailMode\n) {\n var renderState = workInProgress.memoizedState;\n null === renderState\n ? (workInProgress.memoizedState = {\n isBackwards: isBackwards,\n rendering: null,\n renderingStartTime: 0,\n last: lastContentRow,\n tail: tail,\n tailMode: tailMode\n })\n : ((renderState.isBackwards = isBackwards),\n (renderState.rendering = null),\n (renderState.renderingStartTime = 0),\n (renderState.last = lastContentRow),\n (renderState.tail = tail),\n (renderState.tailMode = tailMode));\n}\nfunction updateSuspenseListComponent(current, workInProgress, renderLanes) {\n var nextProps = workInProgress.pendingProps,\n revealOrder = nextProps.revealOrder,\n tailMode = nextProps.tail;\n reconcileChildren(current, workInProgress, nextProps.children, renderLanes);\n nextProps = suspenseStackCursor.current;\n if (0 !== (nextProps & 2))\n (nextProps = (nextProps & 1) | 2), (workInProgress.flags |= 128);\n else {\n if (null !== current && 0 !== (current.flags & 128))\n a: for (current = workInProgress.child; null !== current; ) {\n if (13 === current.tag)\n null !== current.memoizedState &&\n scheduleSuspenseWorkOnFiber(current, renderLanes, workInProgress);\n else if (19 === current.tag)\n scheduleSuspenseWorkOnFiber(current, renderLanes, workInProgress);\n else if (null !== current.child) {\n current.child.return = current;\n current = current.child;\n continue;\n }\n if (current === workInProgress) break a;\n for (; null === current.sibling; ) {\n if (null === current.return || current.return === workInProgress)\n break a;\n current = current.return;\n }\n current.sibling.return = current.return;\n current = current.sibling;\n }\n nextProps &= 1;\n }\n push(suspenseStackCursor, nextProps);\n if (0 === (workInProgress.mode & 1)) workInProgress.memoizedState = null;\n else\n switch (revealOrder) {\n case \"forwards\":\n renderLanes = workInProgress.child;\n for (revealOrder = null; null !== renderLanes; )\n (current = renderLanes.alternate),\n null !== current &&\n null === findFirstSuspended(current) &&\n (revealOrder = renderLanes),\n (renderLanes = renderLanes.sibling);\n renderLanes = revealOrder;\n null === renderLanes\n ? ((revealOrder = workInProgress.child),\n (workInProgress.child = null))\n : ((revealOrder = renderLanes.sibling), (renderLanes.sibling = null));\n initSuspenseListRenderState(\n workInProgress,\n !1,\n revealOrder,\n renderLanes,\n tailMode\n );\n break;\n case \"backwards\":\n renderLanes = null;\n revealOrder = workInProgress.child;\n for (workInProgress.child = null; null !== revealOrder; ) {\n current = revealOrder.alternate;\n if (null !== current && null === findFirstSuspended(current)) {\n workInProgress.child = revealOrder;\n break;\n }\n current = revealOrder.sibling;\n revealOrder.sibling = renderLanes;\n renderLanes = revealOrder;\n revealOrder = current;\n }\n initSuspenseListRenderState(\n workInProgress,\n !0,\n renderLanes,\n null,\n tailMode\n );\n break;\n case \"together\":\n initSuspenseListRenderState(workInProgress, !1, null, null, void 0);\n break;\n default:\n workInProgress.memoizedState = null;\n }\n return workInProgress.child;\n}\nfunction resetSuspendedCurrentOnMountInLegacyMode(current, workInProgress) {\n 0 === (workInProgress.mode & 1) &&\n null !== current &&\n ((current.alternate = null),\n (workInProgress.alternate = null),\n (workInProgress.flags |= 2));\n}\nfunction bailoutOnAlreadyFinishedWork(current, workInProgress, renderLanes) {\n null !== current && (workInProgress.dependencies = current.dependencies);\n workInProgressRootSkippedLanes |= workInProgress.lanes;\n if (0 === (renderLanes & workInProgress.childLanes)) return null;\n if (null !== current && workInProgress.child !== current.child)\n throw Error(\"Resuming work not yet implemented.\");\n if (null !== workInProgress.child) {\n current = workInProgress.child;\n renderLanes = createWorkInProgress(current, current.pendingProps);\n workInProgress.child = renderLanes;\n for (renderLanes.return = workInProgress; null !== current.sibling; )\n (current = current.sibling),\n (renderLanes = renderLanes.sibling = createWorkInProgress(\n current,\n current.pendingProps\n )),\n (renderLanes.return = workInProgress);\n renderLanes.sibling = null;\n }\n return workInProgress.child;\n}\nfunction attemptEarlyBailoutIfNoScheduledUpdate(\n current,\n workInProgress,\n renderLanes\n) {\n switch (workInProgress.tag) {\n case 3:\n pushHostRootContext(workInProgress);\n break;\n case 5:\n pushHostContext(workInProgress);\n break;\n case 1:\n isContextProvider(workInProgress.type) &&\n pushContextProvider(workInProgress);\n break;\n case 4:\n pushHostContainer(workInProgress, workInProgress.stateNode.containerInfo);\n break;\n case 10:\n var context = workInProgress.type._context,\n nextValue = workInProgress.memoizedProps.value;\n push(valueCursor, context._currentValue2);\n context._currentValue2 = nextValue;\n break;\n case 13:\n context = workInProgress.memoizedState;\n if (null !== context) {\n if (null !== context.dehydrated)\n return (\n push(suspenseStackCursor, suspenseStackCursor.current & 1),\n (workInProgress.flags |= 128),\n null\n );\n if (0 !== (renderLanes & workInProgress.child.childLanes))\n return updateSuspenseComponent(current, workInProgress, renderLanes);\n push(suspenseStackCursor, suspenseStackCursor.current & 1);\n current = bailoutOnAlreadyFinishedWork(\n current,\n workInProgress,\n renderLanes\n );\n return null !== current ? current.sibling : null;\n }\n push(suspenseStackCursor, suspenseStackCursor.current & 1);\n break;\n case 19:\n context = 0 !== (renderLanes & workInProgress.childLanes);\n if (0 !== (current.flags & 128)) {\n if (context)\n return updateSuspenseListComponent(\n current,\n workInProgress,\n renderLanes\n );\n workInProgress.flags |= 128;\n }\n nextValue = workInProgress.memoizedState;\n null !== nextValue &&\n ((nextValue.rendering = null),\n (nextValue.tail = null),\n (nextValue.lastEffect = null));\n push(suspenseStackCursor, suspenseStackCursor.current);\n if (context) break;\n else return null;\n case 22:\n case 23:\n return (\n (workInProgress.lanes = 0),\n updateOffscreenComponent(current, workInProgress, renderLanes)\n );\n }\n return bailoutOnAlreadyFinishedWork(current, workInProgress, renderLanes);\n}\nfunction hadNoMutationsEffects(current, completedWork) {\n if (null !== current && current.child === completedWork.child) return !0;\n if (0 !== (completedWork.flags & 16)) return !1;\n for (current = completedWork.child; null !== current; ) {\n if (0 !== (current.flags & 12854) || 0 !== (current.subtreeFlags & 12854))\n return !1;\n current = current.sibling;\n }\n return !0;\n}\nvar appendAllChildren,\n updateHostContainer,\n updateHostComponent$1,\n updateHostText$1;\nappendAllChildren = function(\n parent,\n workInProgress,\n needsVisibilityToggle,\n isHidden\n) {\n for (var node = workInProgress.child; null !== node; ) {\n if (5 === node.tag) {\n var instance = node.stateNode;\n needsVisibilityToggle &&\n isHidden &&\n (instance = cloneHiddenInstance(instance));\n appendChildNode(parent.node, instance.node);\n } else if (6 === node.tag) {\n instance = node.stateNode;\n if (needsVisibilityToggle && isHidden)\n throw Error(\"Not yet implemented.\");\n appendChildNode(parent.node, instance.node);\n } else if (4 !== node.tag)\n if (22 === node.tag && null !== node.memoizedState)\n (instance = node.child),\n null !== instance && (instance.return = node),\n appendAllChildren(parent, node, !0, !0);\n else if (null !== node.child) {\n node.child.return = node;\n node = node.child;\n continue;\n }\n if (node === workInProgress) break;\n for (; null === node.sibling; ) {\n if (null === node.return || node.return === workInProgress) return;\n node = node.return;\n }\n node.sibling.return = node.return;\n node = node.sibling;\n }\n};\nfunction appendAllChildrenToContainer(\n containerChildSet,\n workInProgress,\n needsVisibilityToggle,\n isHidden\n) {\n for (var node = workInProgress.child; null !== node; ) {\n if (5 === node.tag) {\n var instance = node.stateNode;\n needsVisibilityToggle &&\n isHidden &&\n (instance = cloneHiddenInstance(instance));\n appendChildNodeToSet(containerChildSet, instance.node);\n } else if (6 === node.tag) {\n instance = node.stateNode;\n if (needsVisibilityToggle && isHidden)\n throw Error(\"Not yet implemented.\");\n appendChildNodeToSet(containerChildSet, instance.node);\n } else if (4 !== node.tag)\n if (22 === node.tag && null !== node.memoizedState)\n (instance = node.child),\n null !== instance && (instance.return = node),\n appendAllChildrenToContainer(containerChildSet, node, !0, !0);\n else if (null !== node.child) {\n node.child.return = node;\n node = node.child;\n continue;\n }\n if (node === workInProgress) break;\n for (; null === node.sibling; ) {\n if (null === node.return || node.return === workInProgress) return;\n node = node.return;\n }\n node.sibling.return = node.return;\n node = node.sibling;\n }\n}\nupdateHostContainer = function(current, workInProgress) {\n var portalOrRoot = workInProgress.stateNode;\n if (!hadNoMutationsEffects(current, workInProgress)) {\n current = portalOrRoot.containerInfo;\n var newChildSet = createChildNodeSet(current);\n appendAllChildrenToContainer(newChildSet, workInProgress, !1, !1);\n portalOrRoot.pendingChildren = newChildSet;\n workInProgress.flags |= 4;\n completeRoot(current, newChildSet);\n }\n};\nupdateHostComponent$1 = function(current, workInProgress, type, newProps) {\n type = current.stateNode;\n var oldProps = current.memoizedProps;\n if (\n (current = hadNoMutationsEffects(current, workInProgress)) &&\n oldProps === newProps\n )\n workInProgress.stateNode = type;\n else {\n var recyclableInstance = workInProgress.stateNode;\n requiredContext(contextStackCursor$1.current);\n var updatePayload = null;\n oldProps !== newProps &&\n ((oldProps = diffProperties(\n null,\n oldProps,\n newProps,\n recyclableInstance.canonical.viewConfig.validAttributes\n )),\n (recyclableInstance.canonical.currentProps = newProps),\n (updatePayload = oldProps));\n current && null === updatePayload\n ? (workInProgress.stateNode = type)\n : ((newProps = updatePayload),\n (oldProps = type.node),\n (type = {\n node: current\n ? null !== newProps\n ? cloneNodeWithNewProps(oldProps, newProps)\n : cloneNode(oldProps)\n : null !== newProps\n ? cloneNodeWithNewChildrenAndProps(oldProps, newProps)\n : cloneNodeWithNewChildren(oldProps),\n canonical: type.canonical\n }),\n (workInProgress.stateNode = type),\n current\n ? (workInProgress.flags |= 4)\n : appendAllChildren(type, workInProgress, !1, !1));\n }\n};\nupdateHostText$1 = function(current, workInProgress, oldText, newText) {\n oldText !== newText\n ? ((current = requiredContext(rootInstanceStackCursor.current)),\n (oldText = requiredContext(contextStackCursor$1.current)),\n (workInProgress.stateNode = createTextInstance(\n newText,\n current,\n oldText,\n workInProgress\n )),\n (workInProgress.flags |= 4))\n : (workInProgress.stateNode = current.stateNode);\n};\nfunction cutOffTailIfNeeded(renderState, hasRenderedATailFallback) {\n switch (renderState.tailMode) {\n case \"hidden\":\n hasRenderedATailFallback = renderState.tail;\n for (var lastTailNode = null; null !== hasRenderedATailFallback; )\n null !== hasRenderedATailFallback.alternate &&\n (lastTailNode = hasRenderedATailFallback),\n (hasRenderedATailFallback = hasRenderedATailFallback.sibling);\n null === lastTailNode\n ? (renderState.tail = null)\n : (lastTailNode.sibling = null);\n break;\n case \"collapsed\":\n lastTailNode = renderState.tail;\n for (var lastTailNode$62 = null; null !== lastTailNode; )\n null !== lastTailNode.alternate && (lastTailNode$62 = lastTailNode),\n (lastTailNode = lastTailNode.sibling);\n null === lastTailNode$62\n ? hasRenderedATailFallback || null === renderState.tail\n ? (renderState.tail = null)\n : (renderState.tail.sibling = null)\n : (lastTailNode$62.sibling = null);\n }\n}\nfunction bubbleProperties(completedWork) {\n var didBailout =\n null !== completedWork.alternate &&\n completedWork.alternate.child === completedWork.child,\n newChildLanes = 0,\n subtreeFlags = 0;\n if (didBailout)\n for (var child$63 = completedWork.child; null !== child$63; )\n (newChildLanes |= child$63.lanes | child$63.childLanes),\n (subtreeFlags |= child$63.subtreeFlags & 14680064),\n (subtreeFlags |= child$63.flags & 14680064),\n (child$63.return = completedWork),\n (child$63 = child$63.sibling);\n else\n for (child$63 = completedWork.child; null !== child$63; )\n (newChildLanes |= child$63.lanes | child$63.childLanes),\n (subtreeFlags |= child$63.subtreeFlags),\n (subtreeFlags |= child$63.flags),\n (child$63.return = completedWork),\n (child$63 = child$63.sibling);\n completedWork.subtreeFlags |= subtreeFlags;\n completedWork.childLanes = newChildLanes;\n return didBailout;\n}\nfunction completeWork(current, workInProgress, renderLanes) {\n var newProps = workInProgress.pendingProps;\n popTreeContext(workInProgress);\n switch (workInProgress.tag) {\n case 2:\n case 16:\n case 15:\n case 0:\n case 11:\n case 7:\n case 8:\n case 12:\n case 9:\n case 14:\n return bubbleProperties(workInProgress), null;\n case 1:\n return (\n isContextProvider(workInProgress.type) && popContext(),\n bubbleProperties(workInProgress),\n null\n );\n case 3:\n return (\n (renderLanes = workInProgress.stateNode),\n popHostContainer(),\n pop(didPerformWorkStackCursor),\n pop(contextStackCursor),\n resetWorkInProgressVersions(),\n renderLanes.pendingContext &&\n ((renderLanes.context = renderLanes.pendingContext),\n (renderLanes.pendingContext = null)),\n (null !== current && null !== current.child) ||\n null === current ||\n (current.memoizedState.isDehydrated &&\n 0 === (workInProgress.flags & 256)) ||\n ((workInProgress.flags |= 1024),\n null !== hydrationErrors &&\n (queueRecoverableErrors(hydrationErrors),\n (hydrationErrors = null))),\n updateHostContainer(current, workInProgress),\n bubbleProperties(workInProgress),\n null\n );\n case 5:\n popHostContext(workInProgress);\n renderLanes = requiredContext(rootInstanceStackCursor.current);\n var type = workInProgress.type;\n if (null !== current && null != workInProgress.stateNode)\n updateHostComponent$1(\n current,\n workInProgress,\n type,\n newProps,\n renderLanes\n ),\n current.ref !== workInProgress.ref && (workInProgress.flags |= 512);\n else {\n if (!newProps) {\n if (null === workInProgress.stateNode)\n throw Error(\n \"We must have new props for new mounts. This error is likely caused by a bug in React. Please file an issue.\"\n );\n bubbleProperties(workInProgress);\n return null;\n }\n requiredContext(contextStackCursor$1.current);\n current = nextReactTag;\n nextReactTag += 2;\n type = getViewConfigForType(type);\n var updatePayload = diffProperties(\n null,\n emptyObject,\n newProps,\n type.validAttributes\n );\n renderLanes = createNode(\n current,\n type.uiViewClassName,\n renderLanes,\n updatePayload,\n workInProgress\n );\n current = new ReactFabricHostComponent(\n current,\n type,\n newProps,\n workInProgress\n );\n current = { node: renderLanes, canonical: current };\n appendAllChildren(current, workInProgress, !1, !1);\n workInProgress.stateNode = current;\n null !== workInProgress.ref && (workInProgress.flags |= 512);\n }\n bubbleProperties(workInProgress);\n return null;\n case 6:\n if (current && null != workInProgress.stateNode)\n updateHostText$1(\n current,\n workInProgress,\n current.memoizedProps,\n newProps\n );\n else {\n if (\"string\" !== typeof newProps && null === workInProgress.stateNode)\n throw Error(\n \"We must have new props for new mounts. This error is likely caused by a bug in React. Please file an issue.\"\n );\n current = requiredContext(rootInstanceStackCursor.current);\n renderLanes = requiredContext(contextStackCursor$1.current);\n workInProgress.stateNode = createTextInstance(\n newProps,\n current,\n renderLanes,\n workInProgress\n );\n }\n bubbleProperties(workInProgress);\n return null;\n case 13:\n pop(suspenseStackCursor);\n newProps = workInProgress.memoizedState;\n if (\n null === current ||\n (null !== current.memoizedState &&\n null !== current.memoizedState.dehydrated)\n ) {\n if (null !== newProps && null !== newProps.dehydrated) {\n if (null === current) {\n throw Error(\n \"A dehydrated suspense component was completed without a hydrated node. This is probably a bug in React.\"\n );\n throw Error(\n \"Expected prepareToHydrateHostSuspenseInstance() to never be called. This error is likely caused by a bug in React. Please file an issue.\"\n );\n }\n 0 === (workInProgress.flags & 128) &&\n (workInProgress.memoizedState = null);\n workInProgress.flags |= 4;\n bubbleProperties(workInProgress);\n type = !1;\n } else\n null !== hydrationErrors &&\n (queueRecoverableErrors(hydrationErrors), (hydrationErrors = null)),\n (type = !0);\n if (!type) return workInProgress.flags & 65536 ? workInProgress : null;\n }\n if (0 !== (workInProgress.flags & 128))\n return (workInProgress.lanes = renderLanes), workInProgress;\n renderLanes = null !== newProps;\n renderLanes !== (null !== current && null !== current.memoizedState) &&\n renderLanes &&\n ((workInProgress.child.flags |= 8192),\n 0 !== (workInProgress.mode & 1) &&\n (null === current || 0 !== (suspenseStackCursor.current & 1)\n ? 0 === workInProgressRootExitStatus &&\n (workInProgressRootExitStatus = 3)\n : renderDidSuspendDelayIfPossible()));\n null !== workInProgress.updateQueue && (workInProgress.flags |= 4);\n bubbleProperties(workInProgress);\n return null;\n case 4:\n return (\n popHostContainer(),\n updateHostContainer(current, workInProgress),\n bubbleProperties(workInProgress),\n null\n );\n case 10:\n return (\n popProvider(workInProgress.type._context),\n bubbleProperties(workInProgress),\n null\n );\n case 17:\n return (\n isContextProvider(workInProgress.type) && popContext(),\n bubbleProperties(workInProgress),\n null\n );\n case 19:\n pop(suspenseStackCursor);\n type = workInProgress.memoizedState;\n if (null === type) return bubbleProperties(workInProgress), null;\n newProps = 0 !== (workInProgress.flags & 128);\n updatePayload = type.rendering;\n if (null === updatePayload)\n if (newProps) cutOffTailIfNeeded(type, !1);\n else {\n if (\n 0 !== workInProgressRootExitStatus ||\n (null !== current && 0 !== (current.flags & 128))\n )\n for (current = workInProgress.child; null !== current; ) {\n updatePayload = findFirstSuspended(current);\n if (null !== updatePayload) {\n workInProgress.flags |= 128;\n cutOffTailIfNeeded(type, !1);\n current = updatePayload.updateQueue;\n null !== current &&\n ((workInProgress.updateQueue = current),\n (workInProgress.flags |= 4));\n workInProgress.subtreeFlags = 0;\n current = renderLanes;\n for (renderLanes = workInProgress.child; null !== renderLanes; )\n (newProps = renderLanes),\n (type = current),\n (newProps.flags &= 14680066),\n (updatePayload = newProps.alternate),\n null === updatePayload\n ? ((newProps.childLanes = 0),\n (newProps.lanes = type),\n (newProps.child = null),\n (newProps.subtreeFlags = 0),\n (newProps.memoizedProps = null),\n (newProps.memoizedState = null),\n (newProps.updateQueue = null),\n (newProps.dependencies = null),\n (newProps.stateNode = null))\n : ((newProps.childLanes = updatePayload.childLanes),\n (newProps.lanes = updatePayload.lanes),\n (newProps.child = updatePayload.child),\n (newProps.subtreeFlags = 0),\n (newProps.deletions = null),\n (newProps.memoizedProps = updatePayload.memoizedProps),\n (newProps.memoizedState = updatePayload.memoizedState),\n (newProps.updateQueue = updatePayload.updateQueue),\n (newProps.type = updatePayload.type),\n (type = updatePayload.dependencies),\n (newProps.dependencies =\n null === type\n ? null\n : {\n lanes: type.lanes,\n firstContext: type.firstContext\n })),\n (renderLanes = renderLanes.sibling);\n push(\n suspenseStackCursor,\n (suspenseStackCursor.current & 1) | 2\n );\n return workInProgress.child;\n }\n current = current.sibling;\n }\n null !== type.tail &&\n now() > workInProgressRootRenderTargetTime &&\n ((workInProgress.flags |= 128),\n (newProps = !0),\n cutOffTailIfNeeded(type, !1),\n (workInProgress.lanes = 4194304));\n }\n else {\n if (!newProps)\n if (\n ((current = findFirstSuspended(updatePayload)), null !== current)\n ) {\n if (\n ((workInProgress.flags |= 128),\n (newProps = !0),\n (current = current.updateQueue),\n null !== current &&\n ((workInProgress.updateQueue = current),\n (workInProgress.flags |= 4)),\n cutOffTailIfNeeded(type, !0),\n null === type.tail &&\n \"hidden\" === type.tailMode &&\n !updatePayload.alternate)\n )\n return bubbleProperties(workInProgress), null;\n } else\n 2 * now() - type.renderingStartTime >\n workInProgressRootRenderTargetTime &&\n 1073741824 !== renderLanes &&\n ((workInProgress.flags |= 128),\n (newProps = !0),\n cutOffTailIfNeeded(type, !1),\n (workInProgress.lanes = 4194304));\n type.isBackwards\n ? ((updatePayload.sibling = workInProgress.child),\n (workInProgress.child = updatePayload))\n : ((current = type.last),\n null !== current\n ? (current.sibling = updatePayload)\n : (workInProgress.child = updatePayload),\n (type.last = updatePayload));\n }\n if (null !== type.tail)\n return (\n (workInProgress = type.tail),\n (type.rendering = workInProgress),\n (type.tail = workInProgress.sibling),\n (type.renderingStartTime = now()),\n (workInProgress.sibling = null),\n (current = suspenseStackCursor.current),\n push(suspenseStackCursor, newProps ? (current & 1) | 2 : current & 1),\n workInProgress\n );\n bubbleProperties(workInProgress);\n return null;\n case 22:\n case 23:\n return (\n popRenderLanes(),\n (renderLanes = null !== workInProgress.memoizedState),\n null !== current &&\n (null !== current.memoizedState) !== renderLanes &&\n (workInProgress.flags |= 8192),\n renderLanes && 0 !== (workInProgress.mode & 1)\n ? 0 !== (subtreeRenderLanes & 1073741824) &&\n bubbleProperties(workInProgress)\n : bubbleProperties(workInProgress),\n null\n );\n case 24:\n return null;\n case 25:\n return null;\n }\n throw Error(\n \"Unknown unit of work tag (\" +\n workInProgress.tag +\n \"). This error is likely caused by a bug in React. Please file an issue.\"\n );\n}\nfunction unwindWork(current, workInProgress) {\n popTreeContext(workInProgress);\n switch (workInProgress.tag) {\n case 1:\n return (\n isContextProvider(workInProgress.type) && popContext(),\n (current = workInProgress.flags),\n current & 65536\n ? ((workInProgress.flags = (current & -65537) | 128), workInProgress)\n : null\n );\n case 3:\n return (\n popHostContainer(),\n pop(didPerformWorkStackCursor),\n pop(contextStackCursor),\n resetWorkInProgressVersions(),\n (current = workInProgress.flags),\n 0 !== (current & 65536) && 0 === (current & 128)\n ? ((workInProgress.flags = (current & -65537) | 128), workInProgress)\n : null\n );\n case 5:\n return popHostContext(workInProgress), null;\n case 13:\n pop(suspenseStackCursor);\n current = workInProgress.memoizedState;\n if (\n null !== current &&\n null !== current.dehydrated &&\n null === workInProgress.alternate\n )\n throw Error(\n \"Threw in newly mounted dehydrated component. This is likely a bug in React. Please file an issue.\"\n );\n current = workInProgress.flags;\n return current & 65536\n ? ((workInProgress.flags = (current & -65537) | 128), workInProgress)\n : null;\n case 19:\n return pop(suspenseStackCursor), null;\n case 4:\n return popHostContainer(), null;\n case 10:\n return popProvider(workInProgress.type._context), null;\n case 22:\n case 23:\n return popRenderLanes(), null;\n case 24:\n return null;\n default:\n return null;\n }\n}\nvar PossiblyWeakSet = \"function\" === typeof WeakSet ? WeakSet : Set,\n nextEffect = null;\nfunction safelyDetachRef(current, nearestMountedAncestor) {\n var ref = current.ref;\n if (null !== ref)\n if (\"function\" === typeof ref)\n try {\n ref(null);\n } catch (error) {\n captureCommitPhaseError(current, nearestMountedAncestor, error);\n }\n else ref.current = null;\n}\nfunction safelyCallDestroy(current, nearestMountedAncestor, destroy) {\n try {\n destroy();\n } catch (error) {\n captureCommitPhaseError(current, nearestMountedAncestor, error);\n }\n}\nvar shouldFireAfterActiveInstanceBlur = !1;\nfunction commitBeforeMutationEffects(root, firstChild) {\n for (nextEffect = firstChild; null !== nextEffect; )\n if (\n ((root = nextEffect),\n (firstChild = root.child),\n 0 !== (root.subtreeFlags & 1028) && null !== firstChild)\n )\n (firstChild.return = root), (nextEffect = firstChild);\n else\n for (; null !== nextEffect; ) {\n root = nextEffect;\n try {\n var current = root.alternate;\n if (0 !== (root.flags & 1024))\n switch (root.tag) {\n case 0:\n case 11:\n case 15:\n break;\n case 1:\n if (null !== current) {\n var prevProps = current.memoizedProps,\n prevState = current.memoizedState,\n instance = root.stateNode,\n snapshot = instance.getSnapshotBeforeUpdate(\n root.elementType === root.type\n ? prevProps\n : resolveDefaultProps(root.type, prevProps),\n prevState\n );\n instance.__reactInternalSnapshotBeforeUpdate = snapshot;\n }\n break;\n case 3:\n break;\n case 5:\n case 6:\n case 4:\n case 17:\n break;\n default:\n throw Error(\n \"This unit of work tag should not have side-effects. This error is likely caused by a bug in React. Please file an issue.\"\n );\n }\n } catch (error) {\n captureCommitPhaseError(root, root.return, error);\n }\n firstChild = root.sibling;\n if (null !== firstChild) {\n firstChild.return = root.return;\n nextEffect = firstChild;\n break;\n }\n nextEffect = root.return;\n }\n current = shouldFireAfterActiveInstanceBlur;\n shouldFireAfterActiveInstanceBlur = !1;\n return current;\n}\nfunction commitHookEffectListUnmount(\n flags,\n finishedWork,\n nearestMountedAncestor\n) {\n var updateQueue = finishedWork.updateQueue;\n updateQueue = null !== updateQueue ? updateQueue.lastEffect : null;\n if (null !== updateQueue) {\n var effect = (updateQueue = updateQueue.next);\n do {\n if ((effect.tag & flags) === flags) {\n var destroy = effect.destroy;\n effect.destroy = void 0;\n void 0 !== destroy &&\n safelyCallDestroy(finishedWork, nearestMountedAncestor, destroy);\n }\n effect = effect.next;\n } while (effect !== updateQueue);\n }\n}\nfunction commitHookEffectListMount(flags, finishedWork) {\n finishedWork = finishedWork.updateQueue;\n finishedWork = null !== finishedWork ? finishedWork.lastEffect : null;\n if (null !== finishedWork) {\n var effect = (finishedWork = finishedWork.next);\n do {\n if ((effect.tag & flags) === flags) {\n var create$75 = effect.create;\n effect.destroy = create$75();\n }\n effect = effect.next;\n } while (effect !== finishedWork);\n }\n}\nfunction detachFiberAfterEffects(fiber) {\n var alternate = fiber.alternate;\n null !== alternate &&\n ((fiber.alternate = null), detachFiberAfterEffects(alternate));\n fiber.child = null;\n fiber.deletions = null;\n fiber.sibling = null;\n fiber.stateNode = null;\n fiber.return = null;\n fiber.dependencies = null;\n fiber.memoizedProps = null;\n fiber.memoizedState = null;\n fiber.pendingProps = null;\n fiber.stateNode = null;\n fiber.updateQueue = null;\n}\nfunction recursivelyTraverseDeletionEffects(\n finishedRoot,\n nearestMountedAncestor,\n parent\n) {\n for (parent = parent.child; null !== parent; )\n commitDeletionEffectsOnFiber(finishedRoot, nearestMountedAncestor, parent),\n (parent = parent.sibling);\n}\nfunction commitDeletionEffectsOnFiber(\n finishedRoot,\n nearestMountedAncestor,\n deletedFiber\n) {\n if (injectedHook && \"function\" === typeof injectedHook.onCommitFiberUnmount)\n try {\n injectedHook.onCommitFiberUnmount(rendererID, deletedFiber);\n } catch (err) {}\n switch (deletedFiber.tag) {\n case 5:\n safelyDetachRef(deletedFiber, nearestMountedAncestor);\n case 6:\n recursivelyTraverseDeletionEffects(\n finishedRoot,\n nearestMountedAncestor,\n deletedFiber\n );\n break;\n case 18:\n break;\n case 4:\n createChildNodeSet(deletedFiber.stateNode.containerInfo);\n recursivelyTraverseDeletionEffects(\n finishedRoot,\n nearestMountedAncestor,\n deletedFiber\n );\n break;\n case 0:\n case 11:\n case 14:\n case 15:\n var updateQueue = deletedFiber.updateQueue;\n if (\n null !== updateQueue &&\n ((updateQueue = updateQueue.lastEffect), null !== updateQueue)\n ) {\n var effect = (updateQueue = updateQueue.next);\n do {\n var _effect = effect,\n destroy = _effect.destroy;\n _effect = _effect.tag;\n void 0 !== destroy &&\n (0 !== (_effect & 2)\n ? safelyCallDestroy(deletedFiber, nearestMountedAncestor, destroy)\n : 0 !== (_effect & 4) &&\n safelyCallDestroy(\n deletedFiber,\n nearestMountedAncestor,\n destroy\n ));\n effect = effect.next;\n } while (effect !== updateQueue);\n }\n recursivelyTraverseDeletionEffects(\n finishedRoot,\n nearestMountedAncestor,\n deletedFiber\n );\n break;\n case 1:\n safelyDetachRef(deletedFiber, nearestMountedAncestor);\n updateQueue = deletedFiber.stateNode;\n if (\"function\" === typeof updateQueue.componentWillUnmount)\n try {\n (updateQueue.props = deletedFiber.memoizedProps),\n (updateQueue.state = deletedFiber.memoizedState),\n updateQueue.componentWillUnmount();\n } catch (error) {\n captureCommitPhaseError(deletedFiber, nearestMountedAncestor, error);\n }\n recursivelyTraverseDeletionEffects(\n finishedRoot,\n nearestMountedAncestor,\n deletedFiber\n );\n break;\n case 21:\n recursivelyTraverseDeletionEffects(\n finishedRoot,\n nearestMountedAncestor,\n deletedFiber\n );\n break;\n case 22:\n recursivelyTraverseDeletionEffects(\n finishedRoot,\n nearestMountedAncestor,\n deletedFiber\n );\n break;\n default:\n recursivelyTraverseDeletionEffects(\n finishedRoot,\n nearestMountedAncestor,\n deletedFiber\n );\n }\n}\nfunction attachSuspenseRetryListeners(finishedWork) {\n var wakeables = finishedWork.updateQueue;\n if (null !== wakeables) {\n finishedWork.updateQueue = null;\n var retryCache = finishedWork.stateNode;\n null === retryCache &&\n (retryCache = finishedWork.stateNode = new PossiblyWeakSet());\n wakeables.forEach(function(wakeable) {\n var retry = resolveRetryWakeable.bind(null, finishedWork, wakeable);\n retryCache.has(wakeable) ||\n (retryCache.add(wakeable), wakeable.then(retry, retry));\n });\n }\n}\nfunction recursivelyTraverseMutationEffects(root, parentFiber) {\n var deletions = parentFiber.deletions;\n if (null !== deletions)\n for (var i = 0; i < deletions.length; i++) {\n var childToDelete = deletions[i];\n try {\n commitDeletionEffectsOnFiber(root, parentFiber, childToDelete);\n var alternate = childToDelete.alternate;\n null !== alternate && (alternate.return = null);\n childToDelete.return = null;\n } catch (error) {\n captureCommitPhaseError(childToDelete, parentFiber, error);\n }\n }\n if (parentFiber.subtreeFlags & 12854)\n for (parentFiber = parentFiber.child; null !== parentFiber; )\n commitMutationEffectsOnFiber(parentFiber, root),\n (parentFiber = parentFiber.sibling);\n}\nfunction commitMutationEffectsOnFiber(finishedWork, root) {\n var current = finishedWork.alternate,\n flags = finishedWork.flags;\n switch (finishedWork.tag) {\n case 0:\n case 11:\n case 14:\n case 15:\n recursivelyTraverseMutationEffects(root, finishedWork);\n commitReconciliationEffects(finishedWork);\n if (flags & 4) {\n try {\n commitHookEffectListUnmount(3, finishedWork, finishedWork.return),\n commitHookEffectListMount(3, finishedWork);\n } catch (error) {\n captureCommitPhaseError(finishedWork, finishedWork.return, error);\n }\n try {\n commitHookEffectListUnmount(5, finishedWork, finishedWork.return);\n } catch (error$79) {\n captureCommitPhaseError(finishedWork, finishedWork.return, error$79);\n }\n }\n break;\n case 1:\n recursivelyTraverseMutationEffects(root, finishedWork);\n commitReconciliationEffects(finishedWork);\n flags & 512 &&\n null !== current &&\n safelyDetachRef(current, current.return);\n break;\n case 5:\n recursivelyTraverseMutationEffects(root, finishedWork);\n commitReconciliationEffects(finishedWork);\n flags & 512 &&\n null !== current &&\n safelyDetachRef(current, current.return);\n break;\n case 6:\n recursivelyTraverseMutationEffects(root, finishedWork);\n commitReconciliationEffects(finishedWork);\n break;\n case 3:\n recursivelyTraverseMutationEffects(root, finishedWork);\n commitReconciliationEffects(finishedWork);\n break;\n case 4:\n recursivelyTraverseMutationEffects(root, finishedWork);\n commitReconciliationEffects(finishedWork);\n break;\n case 13:\n recursivelyTraverseMutationEffects(root, finishedWork);\n commitReconciliationEffects(finishedWork);\n root = finishedWork.child;\n root.flags & 8192 &&\n ((current = null !== root.memoizedState),\n (root.stateNode.isHidden = current),\n !current ||\n (null !== root.alternate && null !== root.alternate.memoizedState) ||\n (globalMostRecentFallbackTime = now()));\n flags & 4 && attachSuspenseRetryListeners(finishedWork);\n break;\n case 22:\n recursivelyTraverseMutationEffects(root, finishedWork);\n commitReconciliationEffects(finishedWork);\n flags & 8192 &&\n (finishedWork.stateNode.isHidden = null !== finishedWork.memoizedState);\n break;\n case 19:\n recursivelyTraverseMutationEffects(root, finishedWork);\n commitReconciliationEffects(finishedWork);\n flags & 4 && attachSuspenseRetryListeners(finishedWork);\n break;\n case 21:\n break;\n default:\n recursivelyTraverseMutationEffects(root, finishedWork),\n commitReconciliationEffects(finishedWork);\n }\n}\nfunction commitReconciliationEffects(finishedWork) {\n var flags = finishedWork.flags;\n flags & 2 && (finishedWork.flags &= -3);\n flags & 4096 && (finishedWork.flags &= -4097);\n}\nfunction commitLayoutEffects(finishedWork) {\n for (nextEffect = finishedWork; null !== nextEffect; ) {\n var fiber = nextEffect,\n firstChild = fiber.child;\n if (0 !== (fiber.subtreeFlags & 8772) && null !== firstChild)\n (firstChild.return = fiber), (nextEffect = firstChild);\n else\n for (fiber = finishedWork; null !== nextEffect; ) {\n firstChild = nextEffect;\n if (0 !== (firstChild.flags & 8772)) {\n var current = firstChild.alternate;\n try {\n if (0 !== (firstChild.flags & 8772))\n switch (firstChild.tag) {\n case 0:\n case 11:\n case 15:\n commitHookEffectListMount(5, firstChild);\n break;\n case 1:\n var instance = firstChild.stateNode;\n if (firstChild.flags & 4)\n if (null === current) instance.componentDidMount();\n else {\n var prevProps =\n firstChild.elementType === firstChild.type\n ? current.memoizedProps\n : resolveDefaultProps(\n firstChild.type,\n current.memoizedProps\n );\n instance.componentDidUpdate(\n prevProps,\n current.memoizedState,\n instance.__reactInternalSnapshotBeforeUpdate\n );\n }\n var updateQueue = firstChild.updateQueue;\n null !== updateQueue &&\n commitUpdateQueue(firstChild, updateQueue, instance);\n break;\n case 3:\n var updateQueue$76 = firstChild.updateQueue;\n if (null !== updateQueue$76) {\n current = null;\n if (null !== firstChild.child)\n switch (firstChild.child.tag) {\n case 5:\n current = firstChild.child.stateNode.canonical;\n break;\n case 1:\n current = firstChild.child.stateNode;\n }\n commitUpdateQueue(firstChild, updateQueue$76, current);\n }\n break;\n case 5:\n if (null === current && firstChild.flags & 4)\n throw Error(\n \"The current renderer does not support mutation. This error is likely caused by a bug in React. Please file an issue.\"\n );\n break;\n case 6:\n break;\n case 4:\n break;\n case 12:\n break;\n case 13:\n break;\n case 19:\n case 17:\n case 21:\n case 22:\n case 23:\n case 25:\n break;\n default:\n throw Error(\n \"This unit of work tag should not have side-effects. This error is likely caused by a bug in React. Please file an issue.\"\n );\n }\n if (firstChild.flags & 512) {\n current = void 0;\n var ref = firstChild.ref;\n if (null !== ref) {\n var instance$jscomp$0 = firstChild.stateNode;\n switch (firstChild.tag) {\n case 5:\n current = instance$jscomp$0.canonical;\n break;\n default:\n current = instance$jscomp$0;\n }\n \"function\" === typeof ref\n ? ref(current)\n : (ref.current = current);\n }\n }\n } catch (error) {\n captureCommitPhaseError(firstChild, firstChild.return, error);\n }\n }\n if (firstChild === fiber) {\n nextEffect = null;\n break;\n }\n current = firstChild.sibling;\n if (null !== current) {\n current.return = firstChild.return;\n nextEffect = current;\n break;\n }\n nextEffect = firstChild.return;\n }\n }\n}\nvar ceil = Math.ceil,\n ReactCurrentDispatcher$2 = ReactSharedInternals.ReactCurrentDispatcher,\n ReactCurrentOwner$2 = ReactSharedInternals.ReactCurrentOwner,\n ReactCurrentBatchConfig$2 = ReactSharedInternals.ReactCurrentBatchConfig,\n executionContext = 0,\n workInProgressRoot = null,\n workInProgress = null,\n workInProgressRootRenderLanes = 0,\n subtreeRenderLanes = 0,\n subtreeRenderLanesCursor = createCursor(0),\n workInProgressRootExitStatus = 0,\n workInProgressRootFatalError = null,\n workInProgressRootSkippedLanes = 0,\n workInProgressRootInterleavedUpdatedLanes = 0,\n workInProgressRootPingedLanes = 0,\n workInProgressRootConcurrentErrors = null,\n workInProgressRootRecoverableErrors = null,\n globalMostRecentFallbackTime = 0,\n workInProgressRootRenderTargetTime = Infinity,\n workInProgressTransitions = null,\n hasUncaughtError = !1,\n firstUncaughtError = null,\n legacyErrorBoundariesThatAlreadyFailed = null,\n rootDoesHavePassiveEffects = !1,\n rootWithPendingPassiveEffects = null,\n pendingPassiveEffectsLanes = 0,\n nestedUpdateCount = 0,\n rootWithNestedUpdates = null,\n currentEventTime = -1,\n currentEventTransitionLane = 0;\nfunction requestEventTime() {\n return 0 !== (executionContext & 6)\n ? now()\n : -1 !== currentEventTime\n ? currentEventTime\n : (currentEventTime = now());\n}\nfunction requestUpdateLane(fiber) {\n if (0 === (fiber.mode & 1)) return 1;\n if (0 !== (executionContext & 2) && 0 !== workInProgressRootRenderLanes)\n return workInProgressRootRenderLanes & -workInProgressRootRenderLanes;\n if (null !== ReactCurrentBatchConfig.transition)\n return (\n 0 === currentEventTransitionLane &&\n (currentEventTransitionLane = claimNextTransitionLane()),\n currentEventTransitionLane\n );\n fiber = currentUpdatePriority;\n if (0 === fiber)\n a: {\n fiber = fabricGetCurrentEventPriority\n ? fabricGetCurrentEventPriority()\n : null;\n if (null != fiber)\n switch (fiber) {\n case FabricDiscretePriority:\n fiber = 1;\n break a;\n }\n fiber = 16;\n }\n return fiber;\n}\nfunction scheduleUpdateOnFiber(root, fiber, lane, eventTime) {\n if (50 < nestedUpdateCount)\n throw ((nestedUpdateCount = 0),\n (rootWithNestedUpdates = null),\n Error(\n \"Maximum update depth exceeded. This can happen when a component repeatedly calls setState inside componentWillUpdate or componentDidUpdate. React limits the number of nested updates to prevent infinite loops.\"\n ));\n markRootUpdated(root, lane, eventTime);\n if (0 === (executionContext & 2) || root !== workInProgressRoot)\n root === workInProgressRoot &&\n (0 === (executionContext & 2) &&\n (workInProgressRootInterleavedUpdatedLanes |= lane),\n 4 === workInProgressRootExitStatus &&\n markRootSuspended$1(root, workInProgressRootRenderLanes)),\n ensureRootIsScheduled(root, eventTime),\n 1 === lane &&\n 0 === executionContext &&\n 0 === (fiber.mode & 1) &&\n ((workInProgressRootRenderTargetTime = now() + 500),\n includesLegacySyncCallbacks && flushSyncCallbacks());\n}\nfunction ensureRootIsScheduled(root, currentTime) {\n for (\n var existingCallbackNode = root.callbackNode,\n suspendedLanes = root.suspendedLanes,\n pingedLanes = root.pingedLanes,\n expirationTimes = root.expirationTimes,\n lanes = root.pendingLanes;\n 0 < lanes;\n\n ) {\n var index$5 = 31 - clz32(lanes),\n lane = 1 << index$5,\n expirationTime = expirationTimes[index$5];\n if (-1 === expirationTime) {\n if (0 === (lane & suspendedLanes) || 0 !== (lane & pingedLanes))\n expirationTimes[index$5] = computeExpirationTime(lane, currentTime);\n } else expirationTime <= currentTime && (root.expiredLanes |= lane);\n lanes &= ~lane;\n }\n suspendedLanes = getNextLanes(\n root,\n root === workInProgressRoot ? workInProgressRootRenderLanes : 0\n );\n if (0 === suspendedLanes)\n null !== existingCallbackNode && cancelCallback(existingCallbackNode),\n (root.callbackNode = null),\n (root.callbackPriority = 0);\n else if (\n ((currentTime = suspendedLanes & -suspendedLanes),\n root.callbackPriority !== currentTime)\n ) {\n null != existingCallbackNode && cancelCallback(existingCallbackNode);\n if (1 === currentTime)\n 0 === root.tag\n ? ((existingCallbackNode = performSyncWorkOnRoot.bind(null, root)),\n (includesLegacySyncCallbacks = !0),\n null === syncQueue\n ? (syncQueue = [existingCallbackNode])\n : syncQueue.push(existingCallbackNode))\n : ((existingCallbackNode = performSyncWorkOnRoot.bind(null, root)),\n null === syncQueue\n ? (syncQueue = [existingCallbackNode])\n : syncQueue.push(existingCallbackNode)),\n scheduleCallback(ImmediatePriority, flushSyncCallbacks),\n (existingCallbackNode = null);\n else {\n switch (lanesToEventPriority(suspendedLanes)) {\n case 1:\n existingCallbackNode = ImmediatePriority;\n break;\n case 4:\n existingCallbackNode = UserBlockingPriority;\n break;\n case 16:\n existingCallbackNode = NormalPriority;\n break;\n case 536870912:\n existingCallbackNode = IdlePriority;\n break;\n default:\n existingCallbackNode = NormalPriority;\n }\n existingCallbackNode = scheduleCallback$1(\n existingCallbackNode,\n performConcurrentWorkOnRoot.bind(null, root)\n );\n }\n root.callbackPriority = currentTime;\n root.callbackNode = existingCallbackNode;\n }\n}\nfunction performConcurrentWorkOnRoot(root, didTimeout) {\n currentEventTime = -1;\n currentEventTransitionLane = 0;\n if (0 !== (executionContext & 6))\n throw Error(\"Should not already be working.\");\n var originalCallbackNode = root.callbackNode;\n if (flushPassiveEffects() && root.callbackNode !== originalCallbackNode)\n return null;\n var lanes = getNextLanes(\n root,\n root === workInProgressRoot ? workInProgressRootRenderLanes : 0\n );\n if (0 === lanes) return null;\n if (0 !== (lanes & 30) || 0 !== (lanes & root.expiredLanes) || didTimeout)\n didTimeout = renderRootSync(root, lanes);\n else {\n didTimeout = lanes;\n var prevExecutionContext = executionContext;\n executionContext |= 2;\n var prevDispatcher = pushDispatcher();\n if (\n workInProgressRoot !== root ||\n workInProgressRootRenderLanes !== didTimeout\n )\n (workInProgressTransitions = null),\n (workInProgressRootRenderTargetTime = now() + 500),\n prepareFreshStack(root, didTimeout);\n do\n try {\n workLoopConcurrent();\n break;\n } catch (thrownValue) {\n handleError(root, thrownValue);\n }\n while (1);\n resetContextDependencies();\n ReactCurrentDispatcher$2.current = prevDispatcher;\n executionContext = prevExecutionContext;\n null !== workInProgress\n ? (didTimeout = 0)\n : ((workInProgressRoot = null),\n (workInProgressRootRenderLanes = 0),\n (didTimeout = workInProgressRootExitStatus));\n }\n if (0 !== didTimeout) {\n 2 === didTimeout &&\n ((prevExecutionContext = getLanesToRetrySynchronouslyOnError(root)),\n 0 !== prevExecutionContext &&\n ((lanes = prevExecutionContext),\n (didTimeout = recoverFromConcurrentError(root, prevExecutionContext))));\n if (1 === didTimeout)\n throw ((originalCallbackNode = workInProgressRootFatalError),\n prepareFreshStack(root, 0),\n markRootSuspended$1(root, lanes),\n ensureRootIsScheduled(root, now()),\n originalCallbackNode);\n if (6 === didTimeout) markRootSuspended$1(root, lanes);\n else {\n prevExecutionContext = root.current.alternate;\n if (\n 0 === (lanes & 30) &&\n !isRenderConsistentWithExternalStores(prevExecutionContext) &&\n ((didTimeout = renderRootSync(root, lanes)),\n 2 === didTimeout &&\n ((prevDispatcher = getLanesToRetrySynchronouslyOnError(root)),\n 0 !== prevDispatcher &&\n ((lanes = prevDispatcher),\n (didTimeout = recoverFromConcurrentError(root, prevDispatcher)))),\n 1 === didTimeout)\n )\n throw ((originalCallbackNode = workInProgressRootFatalError),\n prepareFreshStack(root, 0),\n markRootSuspended$1(root, lanes),\n ensureRootIsScheduled(root, now()),\n originalCallbackNode);\n root.finishedWork = prevExecutionContext;\n root.finishedLanes = lanes;\n switch (didTimeout) {\n case 0:\n case 1:\n throw Error(\"Root did not complete. This is a bug in React.\");\n case 2:\n commitRoot(\n root,\n workInProgressRootRecoverableErrors,\n workInProgressTransitions\n );\n break;\n case 3:\n markRootSuspended$1(root, lanes);\n if (\n (lanes & 130023424) === lanes &&\n ((didTimeout = globalMostRecentFallbackTime + 500 - now()),\n 10 < didTimeout)\n ) {\n if (0 !== getNextLanes(root, 0)) break;\n prevExecutionContext = root.suspendedLanes;\n if ((prevExecutionContext & lanes) !== lanes) {\n requestEventTime();\n root.pingedLanes |= root.suspendedLanes & prevExecutionContext;\n break;\n }\n root.timeoutHandle = scheduleTimeout(\n commitRoot.bind(\n null,\n root,\n workInProgressRootRecoverableErrors,\n workInProgressTransitions\n ),\n didTimeout\n );\n break;\n }\n commitRoot(\n root,\n workInProgressRootRecoverableErrors,\n workInProgressTransitions\n );\n break;\n case 4:\n markRootSuspended$1(root, lanes);\n if ((lanes & 4194240) === lanes) break;\n didTimeout = root.eventTimes;\n for (prevExecutionContext = -1; 0 < lanes; ) {\n var index$4 = 31 - clz32(lanes);\n prevDispatcher = 1 << index$4;\n index$4 = didTimeout[index$4];\n index$4 > prevExecutionContext && (prevExecutionContext = index$4);\n lanes &= ~prevDispatcher;\n }\n lanes = prevExecutionContext;\n lanes = now() - lanes;\n lanes =\n (120 > lanes\n ? 120\n : 480 > lanes\n ? 480\n : 1080 > lanes\n ? 1080\n : 1920 > lanes\n ? 1920\n : 3e3 > lanes\n ? 3e3\n : 4320 > lanes\n ? 4320\n : 1960 * ceil(lanes / 1960)) - lanes;\n if (10 < lanes) {\n root.timeoutHandle = scheduleTimeout(\n commitRoot.bind(\n null,\n root,\n workInProgressRootRecoverableErrors,\n workInProgressTransitions\n ),\n lanes\n );\n break;\n }\n commitRoot(\n root,\n workInProgressRootRecoverableErrors,\n workInProgressTransitions\n );\n break;\n case 5:\n commitRoot(\n root,\n workInProgressRootRecoverableErrors,\n workInProgressTransitions\n );\n break;\n default:\n throw Error(\"Unknown root exit status.\");\n }\n }\n }\n ensureRootIsScheduled(root, now());\n return root.callbackNode === originalCallbackNode\n ? performConcurrentWorkOnRoot.bind(null, root)\n : null;\n}\nfunction recoverFromConcurrentError(root, errorRetryLanes) {\n var errorsFromFirstAttempt = workInProgressRootConcurrentErrors;\n root.current.memoizedState.isDehydrated &&\n (prepareFreshStack(root, errorRetryLanes).flags |= 256);\n root = renderRootSync(root, errorRetryLanes);\n 2 !== root &&\n ((errorRetryLanes = workInProgressRootRecoverableErrors),\n (workInProgressRootRecoverableErrors = errorsFromFirstAttempt),\n null !== errorRetryLanes && queueRecoverableErrors(errorRetryLanes));\n return root;\n}\nfunction queueRecoverableErrors(errors) {\n null === workInProgressRootRecoverableErrors\n ? (workInProgressRootRecoverableErrors = errors)\n : workInProgressRootRecoverableErrors.push.apply(\n workInProgressRootRecoverableErrors,\n errors\n );\n}\nfunction isRenderConsistentWithExternalStores(finishedWork) {\n for (var node = finishedWork; ; ) {\n if (node.flags & 16384) {\n var updateQueue = node.updateQueue;\n if (\n null !== updateQueue &&\n ((updateQueue = updateQueue.stores), null !== updateQueue)\n )\n for (var i = 0; i < updateQueue.length; i++) {\n var check = updateQueue[i],\n getSnapshot = check.getSnapshot;\n check = check.value;\n try {\n if (!objectIs(getSnapshot(), check)) return !1;\n } catch (error) {\n return !1;\n }\n }\n }\n updateQueue = node.child;\n if (node.subtreeFlags & 16384 && null !== updateQueue)\n (updateQueue.return = node), (node = updateQueue);\n else {\n if (node === finishedWork) break;\n for (; null === node.sibling; ) {\n if (null === node.return || node.return === finishedWork) return !0;\n node = node.return;\n }\n node.sibling.return = node.return;\n node = node.sibling;\n }\n }\n return !0;\n}\nfunction markRootSuspended$1(root, suspendedLanes) {\n suspendedLanes &= ~workInProgressRootPingedLanes;\n suspendedLanes &= ~workInProgressRootInterleavedUpdatedLanes;\n root.suspendedLanes |= suspendedLanes;\n root.pingedLanes &= ~suspendedLanes;\n for (root = root.expirationTimes; 0 < suspendedLanes; ) {\n var index$6 = 31 - clz32(suspendedLanes),\n lane = 1 << index$6;\n root[index$6] = -1;\n suspendedLanes &= ~lane;\n }\n}\nfunction performSyncWorkOnRoot(root) {\n if (0 !== (executionContext & 6))\n throw Error(\"Should not already be working.\");\n flushPassiveEffects();\n var lanes = getNextLanes(root, 0);\n if (0 === (lanes & 1)) return ensureRootIsScheduled(root, now()), null;\n var exitStatus = renderRootSync(root, lanes);\n if (0 !== root.tag && 2 === exitStatus) {\n var errorRetryLanes = getLanesToRetrySynchronouslyOnError(root);\n 0 !== errorRetryLanes &&\n ((lanes = errorRetryLanes),\n (exitStatus = recoverFromConcurrentError(root, errorRetryLanes)));\n }\n if (1 === exitStatus)\n throw ((exitStatus = workInProgressRootFatalError),\n prepareFreshStack(root, 0),\n markRootSuspended$1(root, lanes),\n ensureRootIsScheduled(root, now()),\n exitStatus);\n if (6 === exitStatus)\n throw Error(\"Root did not complete. This is a bug in React.\");\n root.finishedWork = root.current.alternate;\n root.finishedLanes = lanes;\n commitRoot(\n root,\n workInProgressRootRecoverableErrors,\n workInProgressTransitions\n );\n ensureRootIsScheduled(root, now());\n return null;\n}\nfunction popRenderLanes() {\n subtreeRenderLanes = subtreeRenderLanesCursor.current;\n pop(subtreeRenderLanesCursor);\n}\nfunction prepareFreshStack(root, lanes) {\n root.finishedWork = null;\n root.finishedLanes = 0;\n var timeoutHandle = root.timeoutHandle;\n -1 !== timeoutHandle &&\n ((root.timeoutHandle = -1), cancelTimeout(timeoutHandle));\n if (null !== workInProgress)\n for (timeoutHandle = workInProgress.return; null !== timeoutHandle; ) {\n var interruptedWork = timeoutHandle;\n popTreeContext(interruptedWork);\n switch (interruptedWork.tag) {\n case 1:\n interruptedWork = interruptedWork.type.childContextTypes;\n null !== interruptedWork &&\n void 0 !== interruptedWork &&\n popContext();\n break;\n case 3:\n popHostContainer();\n pop(didPerformWorkStackCursor);\n pop(contextStackCursor);\n resetWorkInProgressVersions();\n break;\n case 5:\n popHostContext(interruptedWork);\n break;\n case 4:\n popHostContainer();\n break;\n case 13:\n pop(suspenseStackCursor);\n break;\n case 19:\n pop(suspenseStackCursor);\n break;\n case 10:\n popProvider(interruptedWork.type._context);\n break;\n case 22:\n case 23:\n popRenderLanes();\n }\n timeoutHandle = timeoutHandle.return;\n }\n workInProgressRoot = root;\n workInProgress = root = createWorkInProgress(root.current, null);\n workInProgressRootRenderLanes = subtreeRenderLanes = lanes;\n workInProgressRootExitStatus = 0;\n workInProgressRootFatalError = null;\n workInProgressRootPingedLanes = workInProgressRootInterleavedUpdatedLanes = workInProgressRootSkippedLanes = 0;\n workInProgressRootRecoverableErrors = workInProgressRootConcurrentErrors = null;\n if (null !== concurrentQueues) {\n for (lanes = 0; lanes < concurrentQueues.length; lanes++)\n if (\n ((timeoutHandle = concurrentQueues[lanes]),\n (interruptedWork = timeoutHandle.interleaved),\n null !== interruptedWork)\n ) {\n timeoutHandle.interleaved = null;\n var firstInterleavedUpdate = interruptedWork.next,\n lastPendingUpdate = timeoutHandle.pending;\n if (null !== lastPendingUpdate) {\n var firstPendingUpdate = lastPendingUpdate.next;\n lastPendingUpdate.next = firstInterleavedUpdate;\n interruptedWork.next = firstPendingUpdate;\n }\n timeoutHandle.pending = interruptedWork;\n }\n concurrentQueues = null;\n }\n return root;\n}\nfunction handleError(root$jscomp$0, thrownValue) {\n do {\n var erroredWork = workInProgress;\n try {\n resetContextDependencies();\n ReactCurrentDispatcher$1.current = ContextOnlyDispatcher;\n if (didScheduleRenderPhaseUpdate) {\n for (\n var hook = currentlyRenderingFiber$1.memoizedState;\n null !== hook;\n\n ) {\n var queue = hook.queue;\n null !== queue && (queue.pending = null);\n hook = hook.next;\n }\n didScheduleRenderPhaseUpdate = !1;\n }\n renderLanes = 0;\n workInProgressHook = currentHook = currentlyRenderingFiber$1 = null;\n didScheduleRenderPhaseUpdateDuringThisPass = !1;\n ReactCurrentOwner$2.current = null;\n if (null === erroredWork || null === erroredWork.return) {\n workInProgressRootExitStatus = 1;\n workInProgressRootFatalError = thrownValue;\n workInProgress = null;\n break;\n }\n a: {\n var root = root$jscomp$0,\n returnFiber = erroredWork.return,\n sourceFiber = erroredWork,\n value = thrownValue;\n thrownValue = workInProgressRootRenderLanes;\n sourceFiber.flags |= 32768;\n if (\n null !== value &&\n \"object\" === typeof value &&\n \"function\" === typeof value.then\n ) {\n var wakeable = value,\n sourceFiber$jscomp$0 = sourceFiber,\n tag = sourceFiber$jscomp$0.tag;\n if (\n 0 === (sourceFiber$jscomp$0.mode & 1) &&\n (0 === tag || 11 === tag || 15 === tag)\n ) {\n var currentSource = sourceFiber$jscomp$0.alternate;\n currentSource\n ? ((sourceFiber$jscomp$0.updateQueue = currentSource.updateQueue),\n (sourceFiber$jscomp$0.memoizedState =\n currentSource.memoizedState),\n (sourceFiber$jscomp$0.lanes = currentSource.lanes))\n : ((sourceFiber$jscomp$0.updateQueue = null),\n (sourceFiber$jscomp$0.memoizedState = null));\n }\n b: {\n sourceFiber$jscomp$0 = returnFiber;\n do {\n var JSCompiler_temp;\n if ((JSCompiler_temp = 13 === sourceFiber$jscomp$0.tag)) {\n var nextState = sourceFiber$jscomp$0.memoizedState;\n JSCompiler_temp =\n null !== nextState\n ? null !== nextState.dehydrated\n ? !0\n : !1\n : !0;\n }\n if (JSCompiler_temp) {\n var suspenseBoundary = sourceFiber$jscomp$0;\n break b;\n }\n sourceFiber$jscomp$0 = sourceFiber$jscomp$0.return;\n } while (null !== sourceFiber$jscomp$0);\n suspenseBoundary = null;\n }\n if (null !== suspenseBoundary) {\n suspenseBoundary.flags &= -257;\n value = suspenseBoundary;\n sourceFiber$jscomp$0 = thrownValue;\n if (0 === (value.mode & 1))\n if (value === returnFiber) value.flags |= 65536;\n else {\n value.flags |= 128;\n sourceFiber.flags |= 131072;\n sourceFiber.flags &= -52805;\n if (1 === sourceFiber.tag)\n if (null === sourceFiber.alternate) sourceFiber.tag = 17;\n else {\n var update = createUpdate(-1, 1);\n update.tag = 2;\n enqueueUpdate(sourceFiber, update, 1);\n }\n sourceFiber.lanes |= 1;\n }\n else (value.flags |= 65536), (value.lanes = sourceFiber$jscomp$0);\n suspenseBoundary.mode & 1 &&\n attachPingListener(root, wakeable, thrownValue);\n thrownValue = suspenseBoundary;\n root = wakeable;\n var wakeables = thrownValue.updateQueue;\n if (null === wakeables) {\n var updateQueue = new Set();\n updateQueue.add(root);\n thrownValue.updateQueue = updateQueue;\n } else wakeables.add(root);\n break a;\n } else {\n if (0 === (thrownValue & 1)) {\n attachPingListener(root, wakeable, thrownValue);\n renderDidSuspendDelayIfPossible();\n break a;\n }\n value = Error(\n \"A component suspended while responding to synchronous input. This will cause the UI to be replaced with a loading indicator. To fix, updates that suspend should be wrapped with startTransition.\"\n );\n }\n }\n root = value = createCapturedValueAtFiber(value, sourceFiber);\n 4 !== workInProgressRootExitStatus &&\n (workInProgressRootExitStatus = 2);\n null === workInProgressRootConcurrentErrors\n ? (workInProgressRootConcurrentErrors = [root])\n : workInProgressRootConcurrentErrors.push(root);\n root = returnFiber;\n do {\n switch (root.tag) {\n case 3:\n wakeable = value;\n root.flags |= 65536;\n thrownValue &= -thrownValue;\n root.lanes |= thrownValue;\n var update$jscomp$0 = createRootErrorUpdate(\n root,\n wakeable,\n thrownValue\n );\n enqueueCapturedUpdate(root, update$jscomp$0);\n break a;\n case 1:\n wakeable = value;\n var ctor = root.type,\n instance = root.stateNode;\n if (\n 0 === (root.flags & 128) &&\n (\"function\" === typeof ctor.getDerivedStateFromError ||\n (null !== instance &&\n \"function\" === typeof instance.componentDidCatch &&\n (null === legacyErrorBoundariesThatAlreadyFailed ||\n !legacyErrorBoundariesThatAlreadyFailed.has(instance))))\n ) {\n root.flags |= 65536;\n thrownValue &= -thrownValue;\n root.lanes |= thrownValue;\n var update$32 = createClassErrorUpdate(\n root,\n wakeable,\n thrownValue\n );\n enqueueCapturedUpdate(root, update$32);\n break a;\n }\n }\n root = root.return;\n } while (null !== root);\n }\n completeUnitOfWork(erroredWork);\n } catch (yetAnotherThrownValue) {\n thrownValue = yetAnotherThrownValue;\n workInProgress === erroredWork &&\n null !== erroredWork &&\n (workInProgress = erroredWork = erroredWork.return);\n continue;\n }\n break;\n } while (1);\n}\nfunction pushDispatcher() {\n var prevDispatcher = ReactCurrentDispatcher$2.current;\n ReactCurrentDispatcher$2.current = ContextOnlyDispatcher;\n return null === prevDispatcher ? ContextOnlyDispatcher : prevDispatcher;\n}\nfunction renderDidSuspendDelayIfPossible() {\n if (\n 0 === workInProgressRootExitStatus ||\n 3 === workInProgressRootExitStatus ||\n 2 === workInProgressRootExitStatus\n )\n workInProgressRootExitStatus = 4;\n null === workInProgressRoot ||\n (0 === (workInProgressRootSkippedLanes & 268435455) &&\n 0 === (workInProgressRootInterleavedUpdatedLanes & 268435455)) ||\n markRootSuspended$1(workInProgressRoot, workInProgressRootRenderLanes);\n}\nfunction renderRootSync(root, lanes) {\n var prevExecutionContext = executionContext;\n executionContext |= 2;\n var prevDispatcher = pushDispatcher();\n if (workInProgressRoot !== root || workInProgressRootRenderLanes !== lanes)\n (workInProgressTransitions = null), prepareFreshStack(root, lanes);\n do\n try {\n workLoopSync();\n break;\n } catch (thrownValue) {\n handleError(root, thrownValue);\n }\n while (1);\n resetContextDependencies();\n executionContext = prevExecutionContext;\n ReactCurrentDispatcher$2.current = prevDispatcher;\n if (null !== workInProgress)\n throw Error(\n \"Cannot commit an incomplete root. This error is likely caused by a bug in React. Please file an issue.\"\n );\n workInProgressRoot = null;\n workInProgressRootRenderLanes = 0;\n return workInProgressRootExitStatus;\n}\nfunction workLoopSync() {\n for (; null !== workInProgress; ) performUnitOfWork(workInProgress);\n}\nfunction workLoopConcurrent() {\n for (; null !== workInProgress && !shouldYield(); )\n performUnitOfWork(workInProgress);\n}\nfunction performUnitOfWork(unitOfWork) {\n var next = beginWork$1(unitOfWork.alternate, unitOfWork, subtreeRenderLanes);\n unitOfWork.memoizedProps = unitOfWork.pendingProps;\n null === next ? completeUnitOfWork(unitOfWork) : (workInProgress = next);\n ReactCurrentOwner$2.current = null;\n}\nfunction completeUnitOfWork(unitOfWork) {\n var completedWork = unitOfWork;\n do {\n var current = completedWork.alternate;\n unitOfWork = completedWork.return;\n if (0 === (completedWork.flags & 32768)) {\n if (\n ((current = completeWork(current, completedWork, subtreeRenderLanes)),\n null !== current)\n ) {\n workInProgress = current;\n return;\n }\n } else {\n current = unwindWork(current, completedWork);\n if (null !== current) {\n current.flags &= 32767;\n workInProgress = current;\n return;\n }\n if (null !== unitOfWork)\n (unitOfWork.flags |= 32768),\n (unitOfWork.subtreeFlags = 0),\n (unitOfWork.deletions = null);\n else {\n workInProgressRootExitStatus = 6;\n workInProgress = null;\n return;\n }\n }\n completedWork = completedWork.sibling;\n if (null !== completedWork) {\n workInProgress = completedWork;\n return;\n }\n workInProgress = completedWork = unitOfWork;\n } while (null !== completedWork);\n 0 === workInProgressRootExitStatus && (workInProgressRootExitStatus = 5);\n}\nfunction commitRoot(root, recoverableErrors, transitions) {\n var previousUpdateLanePriority = currentUpdatePriority,\n prevTransition = ReactCurrentBatchConfig$2.transition;\n try {\n (ReactCurrentBatchConfig$2.transition = null),\n (currentUpdatePriority = 1),\n commitRootImpl(\n root,\n recoverableErrors,\n transitions,\n previousUpdateLanePriority\n );\n } finally {\n (ReactCurrentBatchConfig$2.transition = prevTransition),\n (currentUpdatePriority = previousUpdateLanePriority);\n }\n return null;\n}\nfunction commitRootImpl(\n root,\n recoverableErrors,\n transitions,\n renderPriorityLevel\n) {\n do flushPassiveEffects();\n while (null !== rootWithPendingPassiveEffects);\n if (0 !== (executionContext & 6))\n throw Error(\"Should not already be working.\");\n transitions = root.finishedWork;\n var lanes = root.finishedLanes;\n if (null === transitions) return null;\n root.finishedWork = null;\n root.finishedLanes = 0;\n if (transitions === root.current)\n throw Error(\n \"Cannot commit the same tree as before. This error is likely caused by a bug in React. Please file an issue.\"\n );\n root.callbackNode = null;\n root.callbackPriority = 0;\n var remainingLanes = transitions.lanes | transitions.childLanes;\n markRootFinished(root, remainingLanes);\n root === workInProgressRoot &&\n ((workInProgress = workInProgressRoot = null),\n (workInProgressRootRenderLanes = 0));\n (0 === (transitions.subtreeFlags & 2064) &&\n 0 === (transitions.flags & 2064)) ||\n rootDoesHavePassiveEffects ||\n ((rootDoesHavePassiveEffects = !0),\n scheduleCallback$1(NormalPriority, function() {\n flushPassiveEffects();\n return null;\n }));\n remainingLanes = 0 !== (transitions.flags & 15990);\n if (0 !== (transitions.subtreeFlags & 15990) || remainingLanes) {\n remainingLanes = ReactCurrentBatchConfig$2.transition;\n ReactCurrentBatchConfig$2.transition = null;\n var previousPriority = currentUpdatePriority;\n currentUpdatePriority = 1;\n var prevExecutionContext = executionContext;\n executionContext |= 4;\n ReactCurrentOwner$2.current = null;\n commitBeforeMutationEffects(root, transitions);\n commitMutationEffectsOnFiber(transitions, root);\n root.current = transitions;\n commitLayoutEffects(transitions, root, lanes);\n requestPaint();\n executionContext = prevExecutionContext;\n currentUpdatePriority = previousPriority;\n ReactCurrentBatchConfig$2.transition = remainingLanes;\n } else root.current = transitions;\n rootDoesHavePassiveEffects &&\n ((rootDoesHavePassiveEffects = !1),\n (rootWithPendingPassiveEffects = root),\n (pendingPassiveEffectsLanes = lanes));\n remainingLanes = root.pendingLanes;\n 0 === remainingLanes && (legacyErrorBoundariesThatAlreadyFailed = null);\n onCommitRoot(transitions.stateNode, renderPriorityLevel);\n ensureRootIsScheduled(root, now());\n if (null !== recoverableErrors)\n for (\n renderPriorityLevel = root.onRecoverableError, transitions = 0;\n transitions < recoverableErrors.length;\n transitions++\n )\n (lanes = recoverableErrors[transitions]),\n renderPriorityLevel(lanes.value, {\n componentStack: lanes.stack,\n digest: lanes.digest\n });\n if (hasUncaughtError)\n throw ((hasUncaughtError = !1),\n (root = firstUncaughtError),\n (firstUncaughtError = null),\n root);\n 0 !== (pendingPassiveEffectsLanes & 1) &&\n 0 !== root.tag &&\n flushPassiveEffects();\n remainingLanes = root.pendingLanes;\n 0 !== (remainingLanes & 1)\n ? root === rootWithNestedUpdates\n ? nestedUpdateCount++\n : ((nestedUpdateCount = 0), (rootWithNestedUpdates = root))\n : (nestedUpdateCount = 0);\n flushSyncCallbacks();\n return null;\n}\nfunction flushPassiveEffects() {\n if (null !== rootWithPendingPassiveEffects) {\n var renderPriority = lanesToEventPriority(pendingPassiveEffectsLanes),\n prevTransition = ReactCurrentBatchConfig$2.transition,\n previousPriority = currentUpdatePriority;\n try {\n ReactCurrentBatchConfig$2.transition = null;\n currentUpdatePriority = 16 > renderPriority ? 16 : renderPriority;\n if (null === rootWithPendingPassiveEffects)\n var JSCompiler_inline_result = !1;\n else {\n renderPriority = rootWithPendingPassiveEffects;\n rootWithPendingPassiveEffects = null;\n pendingPassiveEffectsLanes = 0;\n if (0 !== (executionContext & 6))\n throw Error(\"Cannot flush passive effects while already rendering.\");\n var prevExecutionContext = executionContext;\n executionContext |= 4;\n for (nextEffect = renderPriority.current; null !== nextEffect; ) {\n var fiber = nextEffect,\n child = fiber.child;\n if (0 !== (nextEffect.flags & 16)) {\n var deletions = fiber.deletions;\n if (null !== deletions) {\n for (var i = 0; i < deletions.length; i++) {\n var fiberToDelete = deletions[i];\n for (nextEffect = fiberToDelete; null !== nextEffect; ) {\n var fiber$jscomp$0 = nextEffect;\n switch (fiber$jscomp$0.tag) {\n case 0:\n case 11:\n case 15:\n commitHookEffectListUnmount(8, fiber$jscomp$0, fiber);\n }\n var child$jscomp$0 = fiber$jscomp$0.child;\n if (null !== child$jscomp$0)\n (child$jscomp$0.return = fiber$jscomp$0),\n (nextEffect = child$jscomp$0);\n else\n for (; null !== nextEffect; ) {\n fiber$jscomp$0 = nextEffect;\n var sibling = fiber$jscomp$0.sibling,\n returnFiber = fiber$jscomp$0.return;\n detachFiberAfterEffects(fiber$jscomp$0);\n if (fiber$jscomp$0 === fiberToDelete) {\n nextEffect = null;\n break;\n }\n if (null !== sibling) {\n sibling.return = returnFiber;\n nextEffect = sibling;\n break;\n }\n nextEffect = returnFiber;\n }\n }\n }\n var previousFiber = fiber.alternate;\n if (null !== previousFiber) {\n var detachedChild = previousFiber.child;\n if (null !== detachedChild) {\n previousFiber.child = null;\n do {\n var detachedSibling = detachedChild.sibling;\n detachedChild.sibling = null;\n detachedChild = detachedSibling;\n } while (null !== detachedChild);\n }\n }\n nextEffect = fiber;\n }\n }\n if (0 !== (fiber.subtreeFlags & 2064) && null !== child)\n (child.return = fiber), (nextEffect = child);\n else\n b: for (; null !== nextEffect; ) {\n fiber = nextEffect;\n if (0 !== (fiber.flags & 2048))\n switch (fiber.tag) {\n case 0:\n case 11:\n case 15:\n commitHookEffectListUnmount(9, fiber, fiber.return);\n }\n var sibling$jscomp$0 = fiber.sibling;\n if (null !== sibling$jscomp$0) {\n sibling$jscomp$0.return = fiber.return;\n nextEffect = sibling$jscomp$0;\n break b;\n }\n nextEffect = fiber.return;\n }\n }\n var finishedWork = renderPriority.current;\n for (nextEffect = finishedWork; null !== nextEffect; ) {\n child = nextEffect;\n var firstChild = child.child;\n if (0 !== (child.subtreeFlags & 2064) && null !== firstChild)\n (firstChild.return = child), (nextEffect = firstChild);\n else\n b: for (child = finishedWork; null !== nextEffect; ) {\n deletions = nextEffect;\n if (0 !== (deletions.flags & 2048))\n try {\n switch (deletions.tag) {\n case 0:\n case 11:\n case 15:\n commitHookEffectListMount(9, deletions);\n }\n } catch (error) {\n captureCommitPhaseError(deletions, deletions.return, error);\n }\n if (deletions === child) {\n nextEffect = null;\n break b;\n }\n var sibling$jscomp$1 = deletions.sibling;\n if (null !== sibling$jscomp$1) {\n sibling$jscomp$1.return = deletions.return;\n nextEffect = sibling$jscomp$1;\n break b;\n }\n nextEffect = deletions.return;\n }\n }\n executionContext = prevExecutionContext;\n flushSyncCallbacks();\n if (\n injectedHook &&\n \"function\" === typeof injectedHook.onPostCommitFiberRoot\n )\n try {\n injectedHook.onPostCommitFiberRoot(rendererID, renderPriority);\n } catch (err) {}\n JSCompiler_inline_result = !0;\n }\n return JSCompiler_inline_result;\n } finally {\n (currentUpdatePriority = previousPriority),\n (ReactCurrentBatchConfig$2.transition = prevTransition);\n }\n }\n return !1;\n}\nfunction captureCommitPhaseErrorOnRoot(rootFiber, sourceFiber, error) {\n sourceFiber = createCapturedValueAtFiber(error, sourceFiber);\n sourceFiber = createRootErrorUpdate(rootFiber, sourceFiber, 1);\n rootFiber = enqueueUpdate(rootFiber, sourceFiber, 1);\n sourceFiber = requestEventTime();\n null !== rootFiber &&\n (markRootUpdated(rootFiber, 1, sourceFiber),\n ensureRootIsScheduled(rootFiber, sourceFiber));\n}\nfunction captureCommitPhaseError(sourceFiber, nearestMountedAncestor, error) {\n if (3 === sourceFiber.tag)\n captureCommitPhaseErrorOnRoot(sourceFiber, sourceFiber, error);\n else\n for (\n nearestMountedAncestor = sourceFiber.return;\n null !== nearestMountedAncestor;\n\n ) {\n if (3 === nearestMountedAncestor.tag) {\n captureCommitPhaseErrorOnRoot(\n nearestMountedAncestor,\n sourceFiber,\n error\n );\n break;\n } else if (1 === nearestMountedAncestor.tag) {\n var instance = nearestMountedAncestor.stateNode;\n if (\n \"function\" ===\n typeof nearestMountedAncestor.type.getDerivedStateFromError ||\n (\"function\" === typeof instance.componentDidCatch &&\n (null === legacyErrorBoundariesThatAlreadyFailed ||\n !legacyErrorBoundariesThatAlreadyFailed.has(instance)))\n ) {\n sourceFiber = createCapturedValueAtFiber(error, sourceFiber);\n sourceFiber = createClassErrorUpdate(\n nearestMountedAncestor,\n sourceFiber,\n 1\n );\n nearestMountedAncestor = enqueueUpdate(\n nearestMountedAncestor,\n sourceFiber,\n 1\n );\n sourceFiber = requestEventTime();\n null !== nearestMountedAncestor &&\n (markRootUpdated(nearestMountedAncestor, 1, sourceFiber),\n ensureRootIsScheduled(nearestMountedAncestor, sourceFiber));\n break;\n }\n }\n nearestMountedAncestor = nearestMountedAncestor.return;\n }\n}\nfunction pingSuspendedRoot(root, wakeable, pingedLanes) {\n var pingCache = root.pingCache;\n null !== pingCache && pingCache.delete(wakeable);\n wakeable = requestEventTime();\n root.pingedLanes |= root.suspendedLanes & pingedLanes;\n workInProgressRoot === root &&\n (workInProgressRootRenderLanes & pingedLanes) === pingedLanes &&\n (4 === workInProgressRootExitStatus ||\n (3 === workInProgressRootExitStatus &&\n (workInProgressRootRenderLanes & 130023424) ===\n workInProgressRootRenderLanes &&\n 500 > now() - globalMostRecentFallbackTime)\n ? prepareFreshStack(root, 0)\n : (workInProgressRootPingedLanes |= pingedLanes));\n ensureRootIsScheduled(root, wakeable);\n}\nfunction retryTimedOutBoundary(boundaryFiber, retryLane) {\n 0 === retryLane &&\n (0 === (boundaryFiber.mode & 1)\n ? (retryLane = 1)\n : ((retryLane = nextRetryLane),\n (nextRetryLane <<= 1),\n 0 === (nextRetryLane & 130023424) && (nextRetryLane = 4194304)));\n var eventTime = requestEventTime();\n boundaryFiber = markUpdateLaneFromFiberToRoot(boundaryFiber, retryLane);\n null !== boundaryFiber &&\n (markRootUpdated(boundaryFiber, retryLane, eventTime),\n ensureRootIsScheduled(boundaryFiber, eventTime));\n}\nfunction retryDehydratedSuspenseBoundary(boundaryFiber) {\n var suspenseState = boundaryFiber.memoizedState,\n retryLane = 0;\n null !== suspenseState && (retryLane = suspenseState.retryLane);\n retryTimedOutBoundary(boundaryFiber, retryLane);\n}\nfunction resolveRetryWakeable(boundaryFiber, wakeable) {\n var retryLane = 0;\n switch (boundaryFiber.tag) {\n case 13:\n var retryCache = boundaryFiber.stateNode;\n var suspenseState = boundaryFiber.memoizedState;\n null !== suspenseState && (retryLane = suspenseState.retryLane);\n break;\n case 19:\n retryCache = boundaryFiber.stateNode;\n break;\n default:\n throw Error(\n \"Pinged unknown suspense boundary type. This is probably a bug in React.\"\n );\n }\n null !== retryCache && retryCache.delete(wakeable);\n retryTimedOutBoundary(boundaryFiber, retryLane);\n}\nvar beginWork$1;\nbeginWork$1 = function(current, workInProgress, renderLanes) {\n if (null !== current)\n if (\n current.memoizedProps !== workInProgress.pendingProps ||\n didPerformWorkStackCursor.current\n )\n didReceiveUpdate = !0;\n else {\n if (\n 0 === (current.lanes & renderLanes) &&\n 0 === (workInProgress.flags & 128)\n )\n return (\n (didReceiveUpdate = !1),\n attemptEarlyBailoutIfNoScheduledUpdate(\n current,\n workInProgress,\n renderLanes\n )\n );\n didReceiveUpdate = 0 !== (current.flags & 131072) ? !0 : !1;\n }\n else didReceiveUpdate = !1;\n workInProgress.lanes = 0;\n switch (workInProgress.tag) {\n case 2:\n var Component = workInProgress.type;\n resetSuspendedCurrentOnMountInLegacyMode(current, workInProgress);\n current = workInProgress.pendingProps;\n var context = getMaskedContext(\n workInProgress,\n contextStackCursor.current\n );\n prepareToReadContext(workInProgress, renderLanes);\n context = renderWithHooks(\n null,\n workInProgress,\n Component,\n current,\n context,\n renderLanes\n );\n workInProgress.flags |= 1;\n if (\n \"object\" === typeof context &&\n null !== context &&\n \"function\" === typeof context.render &&\n void 0 === context.$$typeof\n ) {\n workInProgress.tag = 1;\n workInProgress.memoizedState = null;\n workInProgress.updateQueue = null;\n if (isContextProvider(Component)) {\n var hasContext = !0;\n pushContextProvider(workInProgress);\n } else hasContext = !1;\n workInProgress.memoizedState =\n null !== context.state && void 0 !== context.state\n ? context.state\n : null;\n initializeUpdateQueue(workInProgress);\n context.updater = classComponentUpdater;\n workInProgress.stateNode = context;\n context._reactInternals = workInProgress;\n mountClassInstance(workInProgress, Component, current, renderLanes);\n workInProgress = finishClassComponent(\n null,\n workInProgress,\n Component,\n !0,\n hasContext,\n renderLanes\n );\n } else\n (workInProgress.tag = 0),\n reconcileChildren(null, workInProgress, context, renderLanes),\n (workInProgress = workInProgress.child);\n return workInProgress;\n case 16:\n Component = workInProgress.elementType;\n a: {\n resetSuspendedCurrentOnMountInLegacyMode(current, workInProgress);\n current = workInProgress.pendingProps;\n context = Component._init;\n Component = context(Component._payload);\n workInProgress.type = Component;\n context = workInProgress.tag = resolveLazyComponentTag(Component);\n current = resolveDefaultProps(Component, current);\n switch (context) {\n case 0:\n workInProgress = updateFunctionComponent(\n null,\n workInProgress,\n Component,\n current,\n renderLanes\n );\n break a;\n case 1:\n workInProgress = updateClassComponent(\n null,\n workInProgress,\n Component,\n current,\n renderLanes\n );\n break a;\n case 11:\n workInProgress = updateForwardRef(\n null,\n workInProgress,\n Component,\n current,\n renderLanes\n );\n break a;\n case 14:\n workInProgress = updateMemoComponent(\n null,\n workInProgress,\n Component,\n resolveDefaultProps(Component.type, current),\n renderLanes\n );\n break a;\n }\n throw Error(\n \"Element type is invalid. Received a promise that resolves to: \" +\n Component +\n \". Lazy element type must resolve to a class or function.\"\n );\n }\n return workInProgress;\n case 0:\n return (\n (Component = workInProgress.type),\n (context = workInProgress.pendingProps),\n (context =\n workInProgress.elementType === Component\n ? context\n : resolveDefaultProps(Component, context)),\n updateFunctionComponent(\n current,\n workInProgress,\n Component,\n context,\n renderLanes\n )\n );\n case 1:\n return (\n (Component = workInProgress.type),\n (context = workInProgress.pendingProps),\n (context =\n workInProgress.elementType === Component\n ? context\n : resolveDefaultProps(Component, context)),\n updateClassComponent(\n current,\n workInProgress,\n Component,\n context,\n renderLanes\n )\n );\n case 3:\n pushHostRootContext(workInProgress);\n if (null === current)\n throw Error(\"Should have a current fiber. This is a bug in React.\");\n context = workInProgress.pendingProps;\n Component = workInProgress.memoizedState.element;\n cloneUpdateQueue(current, workInProgress);\n processUpdateQueue(workInProgress, context, null, renderLanes);\n context = workInProgress.memoizedState.element;\n context === Component\n ? (workInProgress = bailoutOnAlreadyFinishedWork(\n current,\n workInProgress,\n renderLanes\n ))\n : (reconcileChildren(current, workInProgress, context, renderLanes),\n (workInProgress = workInProgress.child));\n return workInProgress;\n case 5:\n return (\n pushHostContext(workInProgress),\n (Component = workInProgress.pendingProps.children),\n markRef(current, workInProgress),\n reconcileChildren(current, workInProgress, Component, renderLanes),\n workInProgress.child\n );\n case 6:\n return null;\n case 13:\n return updateSuspenseComponent(current, workInProgress, renderLanes);\n case 4:\n return (\n pushHostContainer(\n workInProgress,\n workInProgress.stateNode.containerInfo\n ),\n (Component = workInProgress.pendingProps),\n null === current\n ? (workInProgress.child = reconcileChildFibers(\n workInProgress,\n null,\n Component,\n renderLanes\n ))\n : reconcileChildren(current, workInProgress, Component, renderLanes),\n workInProgress.child\n );\n case 11:\n return (\n (Component = workInProgress.type),\n (context = workInProgress.pendingProps),\n (context =\n workInProgress.elementType === Component\n ? context\n : resolveDefaultProps(Component, context)),\n updateForwardRef(\n current,\n workInProgress,\n Component,\n context,\n renderLanes\n )\n );\n case 7:\n return (\n reconcileChildren(\n current,\n workInProgress,\n workInProgress.pendingProps,\n renderLanes\n ),\n workInProgress.child\n );\n case 8:\n return (\n reconcileChildren(\n current,\n workInProgress,\n workInProgress.pendingProps.children,\n renderLanes\n ),\n workInProgress.child\n );\n case 12:\n return (\n reconcileChildren(\n current,\n workInProgress,\n workInProgress.pendingProps.children,\n renderLanes\n ),\n workInProgress.child\n );\n case 10:\n a: {\n Component = workInProgress.type._context;\n context = workInProgress.pendingProps;\n hasContext = workInProgress.memoizedProps;\n var newValue = context.value;\n push(valueCursor, Component._currentValue2);\n Component._currentValue2 = newValue;\n if (null !== hasContext)\n if (objectIs(hasContext.value, newValue)) {\n if (\n hasContext.children === context.children &&\n !didPerformWorkStackCursor.current\n ) {\n workInProgress = bailoutOnAlreadyFinishedWork(\n current,\n workInProgress,\n renderLanes\n );\n break a;\n }\n } else\n for (\n hasContext = workInProgress.child,\n null !== hasContext && (hasContext.return = workInProgress);\n null !== hasContext;\n\n ) {\n var list = hasContext.dependencies;\n if (null !== list) {\n newValue = hasContext.child;\n for (\n var dependency = list.firstContext;\n null !== dependency;\n\n ) {\n if (dependency.context === Component) {\n if (1 === hasContext.tag) {\n dependency = createUpdate(-1, renderLanes & -renderLanes);\n dependency.tag = 2;\n var updateQueue = hasContext.updateQueue;\n if (null !== updateQueue) {\n updateQueue = updateQueue.shared;\n var pending = updateQueue.pending;\n null === pending\n ? (dependency.next = dependency)\n : ((dependency.next = pending.next),\n (pending.next = dependency));\n updateQueue.pending = dependency;\n }\n }\n hasContext.lanes |= renderLanes;\n dependency = hasContext.alternate;\n null !== dependency && (dependency.lanes |= renderLanes);\n scheduleContextWorkOnParentPath(\n hasContext.return,\n renderLanes,\n workInProgress\n );\n list.lanes |= renderLanes;\n break;\n }\n dependency = dependency.next;\n }\n } else if (10 === hasContext.tag)\n newValue =\n hasContext.type === workInProgress.type\n ? null\n : hasContext.child;\n else if (18 === hasContext.tag) {\n newValue = hasContext.return;\n if (null === newValue)\n throw Error(\n \"We just came from a parent so we must have had a parent. This is a bug in React.\"\n );\n newValue.lanes |= renderLanes;\n list = newValue.alternate;\n null !== list && (list.lanes |= renderLanes);\n scheduleContextWorkOnParentPath(\n newValue,\n renderLanes,\n workInProgress\n );\n newValue = hasContext.sibling;\n } else newValue = hasContext.child;\n if (null !== newValue) newValue.return = hasContext;\n else\n for (newValue = hasContext; null !== newValue; ) {\n if (newValue === workInProgress) {\n newValue = null;\n break;\n }\n hasContext = newValue.sibling;\n if (null !== hasContext) {\n hasContext.return = newValue.return;\n newValue = hasContext;\n break;\n }\n newValue = newValue.return;\n }\n hasContext = newValue;\n }\n reconcileChildren(\n current,\n workInProgress,\n context.children,\n renderLanes\n );\n workInProgress = workInProgress.child;\n }\n return workInProgress;\n case 9:\n return (\n (context = workInProgress.type),\n (Component = workInProgress.pendingProps.children),\n prepareToReadContext(workInProgress, renderLanes),\n (context = readContext(context)),\n (Component = Component(context)),\n (workInProgress.flags |= 1),\n reconcileChildren(current, workInProgress, Component, renderLanes),\n workInProgress.child\n );\n case 14:\n return (\n (Component = workInProgress.type),\n (context = resolveDefaultProps(Component, workInProgress.pendingProps)),\n (context = resolveDefaultProps(Component.type, context)),\n updateMemoComponent(\n current,\n workInProgress,\n Component,\n context,\n renderLanes\n )\n );\n case 15:\n return updateSimpleMemoComponent(\n current,\n workInProgress,\n workInProgress.type,\n workInProgress.pendingProps,\n renderLanes\n );\n case 17:\n return (\n (Component = workInProgress.type),\n (context = workInProgress.pendingProps),\n (context =\n workInProgress.elementType === Component\n ? context\n : resolveDefaultProps(Component, context)),\n resetSuspendedCurrentOnMountInLegacyMode(current, workInProgress),\n (workInProgress.tag = 1),\n isContextProvider(Component)\n ? ((current = !0), pushContextProvider(workInProgress))\n : (current = !1),\n prepareToReadContext(workInProgress, renderLanes),\n constructClassInstance(workInProgress, Component, context),\n mountClassInstance(workInProgress, Component, context, renderLanes),\n finishClassComponent(\n null,\n workInProgress,\n Component,\n !0,\n current,\n renderLanes\n )\n );\n case 19:\n return updateSuspenseListComponent(current, workInProgress, renderLanes);\n case 22:\n return updateOffscreenComponent(current, workInProgress, renderLanes);\n }\n throw Error(\n \"Unknown unit of work tag (\" +\n workInProgress.tag +\n \"). This error is likely caused by a bug in React. Please file an issue.\"\n );\n};\nfunction scheduleCallback$1(priorityLevel, callback) {\n return scheduleCallback(priorityLevel, callback);\n}\nfunction FiberNode(tag, pendingProps, key, mode) {\n this.tag = tag;\n this.key = key;\n this.sibling = this.child = this.return = this.stateNode = this.type = this.elementType = null;\n this.index = 0;\n this.ref = null;\n this.pendingProps = pendingProps;\n this.dependencies = this.memoizedState = this.updateQueue = this.memoizedProps = null;\n this.mode = mode;\n this.subtreeFlags = this.flags = 0;\n this.deletions = null;\n this.childLanes = this.lanes = 0;\n this.alternate = null;\n}\nfunction createFiber(tag, pendingProps, key, mode) {\n return new FiberNode(tag, pendingProps, key, mode);\n}\nfunction shouldConstruct(Component) {\n Component = Component.prototype;\n return !(!Component || !Component.isReactComponent);\n}\nfunction resolveLazyComponentTag(Component) {\n if (\"function\" === typeof Component)\n return shouldConstruct(Component) ? 1 : 0;\n if (void 0 !== Component && null !== Component) {\n Component = Component.$$typeof;\n if (Component === REACT_FORWARD_REF_TYPE) return 11;\n if (Component === REACT_MEMO_TYPE) return 14;\n }\n return 2;\n}\nfunction createWorkInProgress(current, pendingProps) {\n var workInProgress = current.alternate;\n null === workInProgress\n ? ((workInProgress = createFiber(\n current.tag,\n pendingProps,\n current.key,\n current.mode\n )),\n (workInProgress.elementType = current.elementType),\n (workInProgress.type = current.type),\n (workInProgress.stateNode = current.stateNode),\n (workInProgress.alternate = current),\n (current.alternate = workInProgress))\n : ((workInProgress.pendingProps = pendingProps),\n (workInProgress.type = current.type),\n (workInProgress.flags = 0),\n (workInProgress.subtreeFlags = 0),\n (workInProgress.deletions = null));\n workInProgress.flags = current.flags & 14680064;\n workInProgress.childLanes = current.childLanes;\n workInProgress.lanes = current.lanes;\n workInProgress.child = current.child;\n workInProgress.memoizedProps = current.memoizedProps;\n workInProgress.memoizedState = current.memoizedState;\n workInProgress.updateQueue = current.updateQueue;\n pendingProps = current.dependencies;\n workInProgress.dependencies =\n null === pendingProps\n ? null\n : { lanes: pendingProps.lanes, firstContext: pendingProps.firstContext };\n workInProgress.sibling = current.sibling;\n workInProgress.index = current.index;\n workInProgress.ref = current.ref;\n return workInProgress;\n}\nfunction createFiberFromTypeAndProps(\n type,\n key,\n pendingProps,\n owner,\n mode,\n lanes\n) {\n var fiberTag = 2;\n owner = type;\n if (\"function\" === typeof type) shouldConstruct(type) && (fiberTag = 1);\n else if (\"string\" === typeof type) fiberTag = 5;\n else\n a: switch (type) {\n case REACT_FRAGMENT_TYPE:\n return createFiberFromFragment(pendingProps.children, mode, lanes, key);\n case REACT_STRICT_MODE_TYPE:\n fiberTag = 8;\n mode |= 8;\n break;\n case REACT_PROFILER_TYPE:\n return (\n (type = createFiber(12, pendingProps, key, mode | 2)),\n (type.elementType = REACT_PROFILER_TYPE),\n (type.lanes = lanes),\n type\n );\n case REACT_SUSPENSE_TYPE:\n return (\n (type = createFiber(13, pendingProps, key, mode)),\n (type.elementType = REACT_SUSPENSE_TYPE),\n (type.lanes = lanes),\n type\n );\n case REACT_SUSPENSE_LIST_TYPE:\n return (\n (type = createFiber(19, pendingProps, key, mode)),\n (type.elementType = REACT_SUSPENSE_LIST_TYPE),\n (type.lanes = lanes),\n type\n );\n case REACT_OFFSCREEN_TYPE:\n return createFiberFromOffscreen(pendingProps, mode, lanes, key);\n default:\n if (\"object\" === typeof type && null !== type)\n switch (type.$$typeof) {\n case REACT_PROVIDER_TYPE:\n fiberTag = 10;\n break a;\n case REACT_CONTEXT_TYPE:\n fiberTag = 9;\n break a;\n case REACT_FORWARD_REF_TYPE:\n fiberTag = 11;\n break a;\n case REACT_MEMO_TYPE:\n fiberTag = 14;\n break a;\n case REACT_LAZY_TYPE:\n fiberTag = 16;\n owner = null;\n break a;\n }\n throw Error(\n \"Element type is invalid: expected a string (for built-in components) or a class/function (for composite components) but got: \" +\n ((null == type ? type : typeof type) + \".\")\n );\n }\n key = createFiber(fiberTag, pendingProps, key, mode);\n key.elementType = type;\n key.type = owner;\n key.lanes = lanes;\n return key;\n}\nfunction createFiberFromFragment(elements, mode, lanes, key) {\n elements = createFiber(7, elements, key, mode);\n elements.lanes = lanes;\n return elements;\n}\nfunction createFiberFromOffscreen(pendingProps, mode, lanes, key) {\n pendingProps = createFiber(22, pendingProps, key, mode);\n pendingProps.elementType = REACT_OFFSCREEN_TYPE;\n pendingProps.lanes = lanes;\n pendingProps.stateNode = { isHidden: !1 };\n return pendingProps;\n}\nfunction createFiberFromText(content, mode, lanes) {\n content = createFiber(6, content, null, mode);\n content.lanes = lanes;\n return content;\n}\nfunction createFiberFromPortal(portal, mode, lanes) {\n mode = createFiber(\n 4,\n null !== portal.children ? portal.children : [],\n portal.key,\n mode\n );\n mode.lanes = lanes;\n mode.stateNode = {\n containerInfo: portal.containerInfo,\n pendingChildren: null,\n implementation: portal.implementation\n };\n return mode;\n}\nfunction FiberRootNode(\n containerInfo,\n tag,\n hydrate,\n identifierPrefix,\n onRecoverableError\n) {\n this.tag = tag;\n this.containerInfo = containerInfo;\n this.finishedWork = this.pingCache = this.current = this.pendingChildren = null;\n this.timeoutHandle = -1;\n this.callbackNode = this.pendingContext = this.context = null;\n this.callbackPriority = 0;\n this.eventTimes = createLaneMap(0);\n this.expirationTimes = createLaneMap(-1);\n this.entangledLanes = this.finishedLanes = this.mutableReadLanes = this.expiredLanes = this.pingedLanes = this.suspendedLanes = this.pendingLanes = 0;\n this.entanglements = createLaneMap(0);\n this.identifierPrefix = identifierPrefix;\n this.onRecoverableError = onRecoverableError;\n}\nfunction createPortal(children, containerInfo, implementation) {\n var key =\n 3 < arguments.length && void 0 !== arguments[3] ? arguments[3] : null;\n return {\n $$typeof: REACT_PORTAL_TYPE,\n key: null == key ? null : \"\" + key,\n children: children,\n containerInfo: containerInfo,\n implementation: implementation\n };\n}\nfunction findHostInstance(component) {\n var fiber = component._reactInternals;\n if (void 0 === fiber) {\n if (\"function\" === typeof component.render)\n throw Error(\"Unable to find node on an unmounted component.\");\n component = Object.keys(component).join(\",\");\n throw Error(\n \"Argument appears to not be a ReactComponent. Keys: \" + component\n );\n }\n component = findCurrentHostFiber(fiber);\n return null === component ? null : component.stateNode;\n}\nfunction updateContainer(element, container, parentComponent, callback) {\n var current = container.current,\n eventTime = requestEventTime(),\n lane = requestUpdateLane(current);\n a: if (parentComponent) {\n parentComponent = parentComponent._reactInternals;\n b: {\n if (\n getNearestMountedFiber(parentComponent) !== parentComponent ||\n 1 !== parentComponent.tag\n )\n throw Error(\n \"Expected subtree parent to be a mounted class component. This error is likely caused by a bug in React. Please file an issue.\"\n );\n var JSCompiler_inline_result = parentComponent;\n do {\n switch (JSCompiler_inline_result.tag) {\n case 3:\n JSCompiler_inline_result =\n JSCompiler_inline_result.stateNode.context;\n break b;\n case 1:\n if (isContextProvider(JSCompiler_inline_result.type)) {\n JSCompiler_inline_result =\n JSCompiler_inline_result.stateNode\n .__reactInternalMemoizedMergedChildContext;\n break b;\n }\n }\n JSCompiler_inline_result = JSCompiler_inline_result.return;\n } while (null !== JSCompiler_inline_result);\n throw Error(\n \"Found unexpected detached subtree parent. This error is likely caused by a bug in React. Please file an issue.\"\n );\n }\n if (1 === parentComponent.tag) {\n var Component = parentComponent.type;\n if (isContextProvider(Component)) {\n parentComponent = processChildContext(\n parentComponent,\n Component,\n JSCompiler_inline_result\n );\n break a;\n }\n }\n parentComponent = JSCompiler_inline_result;\n } else parentComponent = emptyContextObject;\n null === container.context\n ? (container.context = parentComponent)\n : (container.pendingContext = parentComponent);\n container = createUpdate(eventTime, lane);\n container.payload = { element: element };\n callback = void 0 === callback ? null : callback;\n null !== callback && (container.callback = callback);\n element = enqueueUpdate(current, container, lane);\n null !== element &&\n (scheduleUpdateOnFiber(element, current, lane, eventTime),\n entangleTransitions(element, current, lane));\n return lane;\n}\nfunction emptyFindFiberByHostInstance() {\n return null;\n}\nfunction findNodeHandle(componentOrHandle) {\n if (null == componentOrHandle) return null;\n if (\"number\" === typeof componentOrHandle) return componentOrHandle;\n if (componentOrHandle._nativeTag) return componentOrHandle._nativeTag;\n if (componentOrHandle.canonical && componentOrHandle.canonical._nativeTag)\n return componentOrHandle.canonical._nativeTag;\n componentOrHandle = findHostInstance(componentOrHandle);\n return null == componentOrHandle\n ? componentOrHandle\n : componentOrHandle.canonical\n ? componentOrHandle.canonical._nativeTag\n : componentOrHandle._nativeTag;\n}\nfunction onRecoverableError(error) {\n console.error(error);\n}\nbatchedUpdatesImpl = function(fn, a) {\n var prevExecutionContext = executionContext;\n executionContext |= 1;\n try {\n return fn(a);\n } finally {\n (executionContext = prevExecutionContext),\n 0 === executionContext &&\n ((workInProgressRootRenderTargetTime = now() + 500),\n includesLegacySyncCallbacks && flushSyncCallbacks());\n }\n};\nvar roots = new Map(),\n devToolsConfig$jscomp$inline_938 = {\n findFiberByHostInstance: getInstanceFromInstance,\n bundleType: 0,\n version: \"18.2.0-next-9e3b772b8-20220608\",\n rendererPackageName: \"react-native-renderer\",\n rendererConfig: {\n getInspectorDataForViewTag: function() {\n throw Error(\n \"getInspectorDataForViewTag() is not available in production\"\n );\n },\n getInspectorDataForViewAtPoint: function() {\n throw Error(\n \"getInspectorDataForViewAtPoint() is not available in production.\"\n );\n }.bind(null, findNodeHandle)\n }\n };\nvar internals$jscomp$inline_1180 = {\n bundleType: devToolsConfig$jscomp$inline_938.bundleType,\n version: devToolsConfig$jscomp$inline_938.version,\n rendererPackageName: devToolsConfig$jscomp$inline_938.rendererPackageName,\n rendererConfig: devToolsConfig$jscomp$inline_938.rendererConfig,\n overrideHookState: null,\n overrideHookStateDeletePath: null,\n overrideHookStateRenamePath: null,\n overrideProps: null,\n overridePropsDeletePath: null,\n overridePropsRenamePath: null,\n setErrorHandler: null,\n setSuspenseHandler: null,\n scheduleUpdate: null,\n currentDispatcherRef: ReactSharedInternals.ReactCurrentDispatcher,\n findHostInstanceByFiber: function(fiber) {\n fiber = findCurrentHostFiber(fiber);\n return null === fiber ? null : fiber.stateNode;\n },\n findFiberByHostInstance:\n devToolsConfig$jscomp$inline_938.findFiberByHostInstance ||\n emptyFindFiberByHostInstance,\n findHostInstancesForRefresh: null,\n scheduleRefresh: null,\n scheduleRoot: null,\n setRefreshHandler: null,\n getCurrentFiber: null,\n reconcilerVersion: \"18.2.0-next-9e3b772b8-20220608\"\n};\nif (\"undefined\" !== typeof __REACT_DEVTOOLS_GLOBAL_HOOK__) {\n var hook$jscomp$inline_1181 = __REACT_DEVTOOLS_GLOBAL_HOOK__;\n if (\n !hook$jscomp$inline_1181.isDisabled &&\n hook$jscomp$inline_1181.supportsFiber\n )\n try {\n (rendererID = hook$jscomp$inline_1181.inject(\n internals$jscomp$inline_1180\n )),\n (injectedHook = hook$jscomp$inline_1181);\n } catch (err) {}\n}\nexports.createPortal = function(children, containerTag) {\n return createPortal(\n children,\n containerTag,\n null,\n 2 < arguments.length && void 0 !== arguments[2] ? arguments[2] : null\n );\n};\nexports.dispatchCommand = function(handle, command, args) {\n null != handle._nativeTag &&\n (null != handle._internalInstanceHandle\n ? ((handle = handle._internalInstanceHandle.stateNode),\n null != handle &&\n nativeFabricUIManager.dispatchCommand(handle.node, command, args))\n : ReactNativePrivateInterface.UIManager.dispatchViewManagerCommand(\n handle._nativeTag,\n command,\n args\n ));\n};\nexports.findHostInstance_DEPRECATED = function(componentOrHandle) {\n if (null == componentOrHandle) return null;\n if (componentOrHandle._nativeTag) return componentOrHandle;\n if (componentOrHandle.canonical && componentOrHandle.canonical._nativeTag)\n return componentOrHandle.canonical;\n componentOrHandle = findHostInstance(componentOrHandle);\n return null == componentOrHandle\n ? componentOrHandle\n : componentOrHandle.canonical\n ? componentOrHandle.canonical\n : componentOrHandle;\n};\nexports.findNodeHandle = findNodeHandle;\nexports.getInspectorDataForInstance = void 0;\nexports.render = function(element, containerTag, callback, concurrentRoot) {\n var root = roots.get(containerTag);\n root ||\n ((root = concurrentRoot ? 1 : 0),\n (concurrentRoot = new FiberRootNode(\n containerTag,\n root,\n !1,\n \"\",\n onRecoverableError\n )),\n (root = createFiber(3, null, null, 1 === root ? 1 : 0)),\n (concurrentRoot.current = root),\n (root.stateNode = concurrentRoot),\n (root.memoizedState = {\n element: null,\n isDehydrated: !1,\n cache: null,\n transitions: null,\n pendingSuspenseBoundaries: null\n }),\n initializeUpdateQueue(root),\n (root = concurrentRoot),\n roots.set(containerTag, root));\n updateContainer(element, root, null, callback);\n a: if (((element = root.current), element.child))\n switch (element.child.tag) {\n case 5:\n element = element.child.stateNode.canonical;\n break a;\n default:\n element = element.child.stateNode;\n }\n else element = null;\n return element;\n};\nexports.sendAccessibilityEvent = function(handle, eventType) {\n null != handle._nativeTag &&\n (null != handle._internalInstanceHandle\n ? ((handle = handle._internalInstanceHandle.stateNode),\n null != handle &&\n nativeFabricUIManager.sendAccessibilityEvent(handle.node, eventType))\n : ReactNativePrivateInterface.legacySendAccessibilityEvent(\n handle._nativeTag,\n eventType\n ));\n};\nexports.stopSurface = function(containerTag) {\n var root = roots.get(containerTag);\n root &&\n updateContainer(null, root, null, function() {\n roots.delete(containerTag);\n });\n};\nexports.unmountComponentAtNode = function(containerTag) {\n this.stopSurface(containerTag);\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 * @format\n * @flow strict-local\n */\n\nimport '../Core/InitializeCore';\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 * @format\n * @flow strict-local\n */\n\n/**\n * Sets up global variables typical in most JavaScript environments.\n *\n * 1. Global timers (via `setTimeout` etc).\n * 2. Global console object.\n * 3. Hooks for printing stack traces with source maps.\n *\n * Leaves enough room in the environment for implementing your own:\n *\n * 1. Require system.\n * 2. Bridged modules.\n *\n */\n\n'use strict';\n\nconst start = Date.now();\n\nrequire('./setUpGlobals');\nrequire('./setUpPerformance');\nrequire('./setUpErrorHandling');\nrequire('./polyfillPromise');\nrequire('./setUpRegeneratorRuntime');\nrequire('./setUpTimers');\nrequire('./setUpXHR');\nrequire('./setUpAlert');\nrequire('./setUpNavigator');\nrequire('./setUpBatchedBridge');\nrequire('./setUpSegmentFetcher');\nif (__DEV__) {\n require('./checkNativeVersion');\n require('./setUpDeveloperTools');\n require('../LogBox/LogBox').install();\n}\n\nrequire('../ReactNative/AppRegistry');\n\nconst GlobalPerformanceLogger = require('../Utilities/GlobalPerformanceLogger');\n// We could just call GlobalPerformanceLogger.markPoint at the top of the file,\n// but then we'd be excluding the time it took to require the logger.\n// Instead, we just use Date.now and backdate the timestamp.\nGlobalPerformanceLogger.markPoint(\n 'initializeCore_start',\n GlobalPerformanceLogger.currentTimestamp() - (Date.now() - start),\n);\nGlobalPerformanceLogger.markPoint('initializeCore_end');\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 * @flow strict\n * @format\n */\n\n'use strict';\n\n/**\n * Sets up global variables for React Native.\n * You can use this module directly, or just require InitializeCore.\n */\nif (global.window === undefined) {\n // $FlowFixMe[cannot-write]\n global.window = global;\n}\n\nif (global.self === undefined) {\n // $FlowFixMe[cannot-write]\n global.self = global;\n}\n\n// Set up process\nglobal.process = global.process || {};\nglobal.process.env = global.process.env || {};\nif (!global.process.env.NODE_ENV) {\n global.process.env.NODE_ENV = __DEV__ ? 'development' : 'production';\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 * @flow strict\n * @format\n */\n\n'use strict';\n\nif (!global.performance) {\n global.performance = ({}: {now?: () => number});\n}\n\n/**\n * Returns a double, measured in milliseconds.\n * https://developer.mozilla.org/en-US/docs/Web/API/Performance/now\n */\nif (typeof global.performance.now !== 'function') {\n global.performance.now = function () {\n const performanceNow = global.nativePerformanceNow || Date.now;\n return performanceNow();\n };\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 * @flow strict-local\n * @format\n */\n\n'use strict';\n\n/**\n * Sets up the console and exception handling (redbox) for React Native.\n * You can use this module directly, or just require InitializeCore.\n */\nconst ExceptionsManager = require('./ExceptionsManager');\nExceptionsManager.installConsoleErrorReporter();\n\n// Set up error handler\nif (!global.__fbDisableExceptionsManager) {\n const handleError = (e: mixed, isFatal: boolean) => {\n try {\n ExceptionsManager.handleException(e, isFatal);\n } catch (ee) {\n console.log('Failed to print error: ', ee.message);\n throw e;\n }\n };\n\n const ErrorUtils = require('../vendor/core/ErrorUtils');\n ErrorUtils.setGlobalHandler(handleError);\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 * @format\n * @flow strict\n */\n\n'use strict';\n\nimport type {ExtendedError} from './ExtendedError';\nimport type {ExceptionData} from './NativeExceptionsManager';\n\nclass SyntheticError extends Error {\n name: string = '';\n}\n\ntype ExceptionDecorator = ExceptionData => ExceptionData;\n\nlet userExceptionDecorator: ?ExceptionDecorator;\nlet inUserExceptionDecorator = false;\n\n// This Symbol is used to decorate an ExtendedError with extra data in select usecases.\n// Note that data passed using this method should be strictly contained,\n// as data that's not serializable/too large may cause issues with passing the error to the native code.\nconst decoratedExtraDataKey: symbol = Symbol('decoratedExtraDataKey');\n\n/**\n * Allows the app to add information to the exception report before it is sent\n * to native. This API is not final.\n */\n\nfunction unstable_setExceptionDecorator(\n exceptionDecorator: ?ExceptionDecorator,\n) {\n userExceptionDecorator = exceptionDecorator;\n}\n\nfunction preprocessException(data: ExceptionData): ExceptionData {\n if (userExceptionDecorator && !inUserExceptionDecorator) {\n inUserExceptionDecorator = true;\n try {\n return userExceptionDecorator(data);\n } catch {\n // Fall through\n } finally {\n inUserExceptionDecorator = false;\n }\n }\n return data;\n}\n\n/**\n * Handles the developer-visible aspect of errors and exceptions\n */\nlet exceptionID = 0;\nfunction reportException(\n e: ExtendedError,\n isFatal: boolean,\n reportToConsole: boolean, // only true when coming from handleException; the error has not yet been logged\n) {\n const parseErrorStack = require('./Devtools/parseErrorStack');\n const stack = parseErrorStack(e?.stack);\n const currentExceptionID = ++exceptionID;\n const originalMessage = e.message || '';\n let message = originalMessage;\n if (e.componentStack != null) {\n message += `\\n\\nThis error is located at:${e.componentStack}`;\n }\n const namePrefix = e.name == null || e.name === '' ? '' : `${e.name}: `;\n\n if (!message.startsWith(namePrefix)) {\n message = namePrefix + message;\n }\n\n message =\n e.jsEngine == null ? message : `${message}, js engine: ${e.jsEngine}`;\n\n const data = preprocessException({\n message,\n originalMessage: message === originalMessage ? null : originalMessage,\n name: e.name == null || e.name === '' ? null : e.name,\n componentStack:\n typeof e.componentStack === 'string' ? e.componentStack : null,\n stack,\n id: currentExceptionID,\n isFatal,\n extraData: {\n // $FlowFixMe[incompatible-use] we can't define a type with a Symbol-keyed field in flow\n ...e[decoratedExtraDataKey],\n jsEngine: e.jsEngine,\n rawStack: e.stack,\n },\n });\n\n if (reportToConsole) {\n // we feed back into console.error, to make sure any methods that are\n // monkey patched on top of console.error are called when coming from\n // handleException\n console.error(data.message);\n }\n\n if (__DEV__) {\n const LogBox = require('../LogBox/LogBox');\n LogBox.addException({\n ...data,\n isComponentError: !!e.isComponentError,\n });\n } else if (isFatal || e.type !== 'warn') {\n const NativeExceptionsManager =\n require('./NativeExceptionsManager').default;\n if (NativeExceptionsManager) {\n NativeExceptionsManager.reportException(data);\n }\n }\n}\n\ndeclare var console: typeof console & {\n _errorOriginal: typeof console.error,\n reportErrorsAsExceptions: boolean,\n ...\n};\n\n// If we trigger console.error _from_ handleException,\n// we do want to make sure that console.error doesn't trigger error reporting again\nlet inExceptionHandler = false;\n\n/**\n * Logs exceptions to the (native) console and displays them\n */\nfunction handleException(e: mixed, isFatal: boolean) {\n let error: Error;\n if (e instanceof Error) {\n error = e;\n } else {\n // Workaround for reporting errors caused by `throw 'some string'`\n // Unfortunately there is no way to figure out the stacktrace in this\n // case, so if you ended up here trying to trace an error, look for\n // `throw ''` somewhere in your codebase.\n error = new SyntheticError(e);\n }\n try {\n inExceptionHandler = true;\n /* $FlowFixMe[class-object-subtyping] added when improving typing for this\n * parameters */\n reportException(error, isFatal, /*reportToConsole*/ true);\n } finally {\n inExceptionHandler = false;\n }\n}\n\n/* $FlowFixMe[missing-local-annot] The type annotation(s) required by Flow's\n * LTI update could not be added via codemod */\nfunction reactConsoleErrorHandler(...args) {\n // bubble up to any original handlers\n console._errorOriginal(...args);\n if (!console.reportErrorsAsExceptions) {\n return;\n }\n if (inExceptionHandler) {\n // The fundamental trick here is that are multiple entry point to logging errors:\n // (see D19743075 for more background)\n //\n // 1. An uncaught exception being caught by the global handler\n // 2. An error being logged throw console.error\n //\n // However, console.error is monkey patched multiple times: by this module, and by the\n // DevTools setup that sends messages to Metro.\n // The patching order cannot be relied upon.\n //\n // So, some scenarios that are handled by this flag:\n //\n // Logging an error:\n // 1. console.error called from user code\n // 2. (possibly) arrives _first_ at DevTool handler, send to Metro\n // 3. Bubbles to here\n // 4. goes into report Exception.\n // 5. should not trigger console.error again, to avoid looping / logging twice\n // 6. should still bubble up to original console\n // (which might either be console.log, or the DevTools handler in case it patched _earlier_ and (2) didn't happen)\n //\n // Throwing an uncaught exception:\n // 1. exception thrown\n // 2. picked up by handleException\n // 3. should be send to console.error (not console._errorOriginal, as DevTools might have patched _later_ and it needs to send it to Metro)\n // 4. that _might_ bubble again to the `reactConsoleErrorHandle` defined here\n // -> should not handle exception _again_, to avoid looping / showing twice (this code branch)\n // 5. should still bubble up to original console (which might either be console.log, or the DevTools handler in case that one patched _earlier_)\n return;\n }\n\n let error;\n\n const firstArg = args[0];\n if (firstArg?.stack) {\n // reportException will console.error this with high enough fidelity.\n error = firstArg;\n } else {\n const stringifySafe = require('../Utilities/stringifySafe').default;\n if (typeof firstArg === 'string' && firstArg.startsWith('Warning: ')) {\n // React warnings use console.error so that a stack trace is shown, but\n // we don't (currently) want these to show a redbox\n // (Note: Logic duplicated in polyfills/console.js.)\n return;\n }\n const message = args\n .map(arg => (typeof arg === 'string' ? arg : stringifySafe(arg)))\n .join(' ');\n\n error = new SyntheticError(message);\n error.name = 'console.error';\n }\n\n reportException(\n /* $FlowFixMe[class-object-subtyping] added when improving typing for this\n * parameters */\n error,\n false, // isFatal\n false, // reportToConsole\n );\n}\n\n/**\n * Shows a redbox with stacktrace for all console.error messages. Disable by\n * setting `console.reportErrorsAsExceptions = false;` in your app.\n */\nfunction installConsoleErrorReporter() {\n // Enable reportErrorsAsExceptions\n if (console._errorOriginal) {\n return; // already installed\n }\n // Flow doesn't like it when you set arbitrary values on a global object\n console._errorOriginal = console.error.bind(console);\n console.error = reactConsoleErrorHandler;\n if (console.reportErrorsAsExceptions === undefined) {\n // Individual apps can disable this\n // Flow doesn't like it when you set arbitrary values on a global object\n console.reportErrorsAsExceptions = true;\n }\n}\n\nmodule.exports = {\n decoratedExtraDataKey,\n handleException,\n installConsoleErrorReporter,\n SyntheticError,\n unstable_setExceptionDecorator,\n};\n","var getPrototypeOf = require(\"./getPrototypeOf.js\");\n\nvar setPrototypeOf = require(\"./setPrototypeOf.js\");\n\nvar isNativeFunction = require(\"./isNativeFunction.js\");\n\nvar construct = require(\"./construct.js\");\n\nfunction _wrapNativeSuper(Class) {\n var _cache = typeof Map === \"function\" ? new Map() : undefined;\n\n module.exports = _wrapNativeSuper = function _wrapNativeSuper(Class) {\n if (Class === null || !isNativeFunction(Class)) return Class;\n\n if (typeof Class !== \"function\") {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n\n if (typeof _cache !== \"undefined\") {\n if (_cache.has(Class)) return _cache.get(Class);\n\n _cache.set(Class, Wrapper);\n }\n\n function Wrapper() {\n return construct(Class, arguments, getPrototypeOf(this).constructor);\n }\n\n Wrapper.prototype = Object.create(Class.prototype, {\n constructor: {\n value: Wrapper,\n enumerable: false,\n writable: true,\n configurable: true\n }\n });\n return setPrototypeOf(Wrapper, Class);\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n return _wrapNativeSuper(Class);\n}\n\nmodule.exports = _wrapNativeSuper, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _isNativeFunction(fn) {\n return Function.toString.call(fn).indexOf(\"[native code]\") !== -1;\n}\n\nmodule.exports = _isNativeFunction, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var setPrototypeOf = require(\"./setPrototypeOf.js\");\n\nvar isNativeReflectConstruct = require(\"./isNativeReflectConstruct.js\");\n\nfunction _construct(Parent, args, Class) {\n if (isNativeReflectConstruct()) {\n module.exports = _construct = Reflect.construct.bind(), module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n } else {\n module.exports = _construct = function _construct(Parent, args, Class) {\n var a = [null];\n a.push.apply(a, args);\n var Constructor = Function.bind.apply(Parent, a);\n var instance = new Constructor();\n if (Class) setPrototypeOf(instance, Class.prototype);\n return instance;\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n }\n\n return _construct.apply(null, arguments);\n}\n\nmodule.exports = _construct, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _isNativeReflectConstruct() {\n if (typeof Reflect === \"undefined\" || !Reflect.construct) return false;\n if (Reflect.construct.sham) return false;\n if (typeof Proxy === \"function\") return true;\n\n try {\n Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {}));\n return true;\n } catch (e) {\n return false;\n }\n}\n\nmodule.exports = _isNativeReflectConstruct, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","/**\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 * @format\n * @flow strict\n */\n\n'use strict';\n\nimport type {StackFrame} from '../NativeExceptionsManager';\nimport type {HermesParsedStack} from './parseHermesStack';\n\nconst parseHermesStack = require('./parseHermesStack');\n\nfunction convertHermesStack(stack: HermesParsedStack): Array {\n const frames: Array = [];\n for (const entry of stack.entries) {\n if (entry.type !== 'FRAME') {\n continue;\n }\n const {location, functionName} = entry;\n if (location.type === 'NATIVE') {\n continue;\n }\n frames.push({\n methodName: functionName,\n file: location.sourceUrl,\n lineNumber: location.line1Based,\n column:\n location.type === 'SOURCE'\n ? location.column1Based - 1\n : location.virtualOffset0Based,\n });\n }\n return frames;\n}\n\nfunction parseErrorStack(errorStack?: string): Array {\n if (errorStack == null) {\n return [];\n }\n\n const stacktraceParser = require('stacktrace-parser');\n const parsedStack = Array.isArray(errorStack)\n ? errorStack\n : global.HermesInternal\n ? convertHermesStack(parseHermesStack(errorStack))\n : stacktraceParser.parse(errorStack).map(frame => ({\n ...frame,\n column: frame.column != null ? frame.column - 1 : null,\n }));\n\n return parsedStack;\n}\n\nmodule.exports = parseErrorStack;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar UNKNOWN_FUNCTION = '';\n/**\n * This parses the different stack traces and puts them into one format\n * This borrows heavily from TraceKit (https://github.com/csnover/TraceKit)\n */\n\nfunction parse(stackString) {\n var lines = stackString.split('\\n');\n return lines.reduce(function (stack, line) {\n var parseResult = parseChrome(line) || parseWinjs(line) || parseGecko(line) || parseNode(line) || parseJSC(line);\n\n if (parseResult) {\n stack.push(parseResult);\n }\n\n return stack;\n }, []);\n}\nvar chromeRe = /^\\s*at (.*?) ?\\(((?:file|https?|blob|chrome-extension|native|eval|webpack||\\/|[a-z]:\\\\|\\\\\\\\).*?)(?::(\\d+))?(?::(\\d+))?\\)?\\s*$/i;\nvar chromeEvalRe = /\\((\\S*)(?::(\\d+))(?::(\\d+))\\)/;\n\nfunction parseChrome(line) {\n var parts = chromeRe.exec(line);\n\n if (!parts) {\n return null;\n }\n\n var isNative = parts[2] && parts[2].indexOf('native') === 0; // start of line\n\n var isEval = parts[2] && parts[2].indexOf('eval') === 0; // start of line\n\n var submatch = chromeEvalRe.exec(parts[2]);\n\n if (isEval && submatch != null) {\n // throw out eval line/column and use top-most line/column number\n parts[2] = submatch[1]; // url\n\n parts[3] = submatch[2]; // line\n\n parts[4] = submatch[3]; // column\n }\n\n return {\n file: !isNative ? parts[2] : null,\n methodName: parts[1] || UNKNOWN_FUNCTION,\n arguments: isNative ? [parts[2]] : [],\n lineNumber: parts[3] ? +parts[3] : null,\n column: parts[4] ? +parts[4] : null\n };\n}\n\nvar winjsRe = /^\\s*at (?:((?:\\[object object\\])?.+) )?\\(?((?:file|ms-appx|https?|webpack|blob):.*?):(\\d+)(?::(\\d+))?\\)?\\s*$/i;\n\nfunction parseWinjs(line) {\n var parts = winjsRe.exec(line);\n\n if (!parts) {\n return null;\n }\n\n return {\n file: parts[2],\n methodName: parts[1] || UNKNOWN_FUNCTION,\n arguments: [],\n lineNumber: +parts[3],\n column: parts[4] ? +parts[4] : null\n };\n}\n\nvar geckoRe = /^\\s*(.*?)(?:\\((.*?)\\))?(?:^|@)((?:file|https?|blob|chrome|webpack|resource|\\[native).*?|[^@]*bundle)(?::(\\d+))?(?::(\\d+))?\\s*$/i;\nvar geckoEvalRe = /(\\S+) line (\\d+)(?: > eval line \\d+)* > eval/i;\n\nfunction parseGecko(line) {\n var parts = geckoRe.exec(line);\n\n if (!parts) {\n return null;\n }\n\n var isEval = parts[3] && parts[3].indexOf(' > eval') > -1;\n var submatch = geckoEvalRe.exec(parts[3]);\n\n if (isEval && submatch != null) {\n // throw out eval line/column and use top-most line number\n parts[3] = submatch[1];\n parts[4] = submatch[2];\n parts[5] = null; // no column when eval\n }\n\n return {\n file: parts[3],\n methodName: parts[1] || UNKNOWN_FUNCTION,\n arguments: parts[2] ? parts[2].split(',') : [],\n lineNumber: parts[4] ? +parts[4] : null,\n column: parts[5] ? +parts[5] : null\n };\n}\n\nvar javaScriptCoreRe = /^\\s*(?:([^@]*)(?:\\((.*?)\\))?@)?(\\S.*?):(\\d+)(?::(\\d+))?\\s*$/i;\n\nfunction parseJSC(line) {\n var parts = javaScriptCoreRe.exec(line);\n\n if (!parts) {\n return null;\n }\n\n return {\n file: parts[3],\n methodName: parts[1] || UNKNOWN_FUNCTION,\n arguments: [],\n lineNumber: +parts[4],\n column: parts[5] ? +parts[5] : null\n };\n}\n\nvar nodeRe = /^\\s*at (?:((?:\\[object object\\])?[^\\\\/]+(?: \\[as \\S+\\])?) )?\\(?(.*?):(\\d+)(?::(\\d+))?\\)?\\s*$/i;\n\nfunction parseNode(line) {\n var parts = nodeRe.exec(line);\n\n if (!parts) {\n return null;\n }\n\n return {\n file: parts[2],\n methodName: parts[1] || UNKNOWN_FUNCTION,\n arguments: [],\n lineNumber: +parts[3],\n column: parts[4] ? +parts[4] : null\n };\n}\n\nexports.parse = parse;\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 * @format\n * @flow strict\n */\n\n'use strict';\n\ntype HermesStackLocationNative = {|\n +type: 'NATIVE',\n|};\n\ntype HermesStackLocationSource = {|\n +type: 'SOURCE',\n +sourceUrl: string,\n +line1Based: number,\n +column1Based: number,\n|};\n\ntype HermesStackLocationBytecode = {|\n +type: 'BYTECODE',\n +sourceUrl: string,\n +line1Based: number,\n +virtualOffset0Based: number,\n|};\n\ntype HermesStackLocation =\n | HermesStackLocationNative\n | HermesStackLocationSource\n | HermesStackLocationBytecode;\n\ntype HermesStackEntryFrame = {|\n +type: 'FRAME',\n +location: HermesStackLocation,\n +functionName: string,\n|};\n\ntype HermesStackEntrySkipped = {|\n +type: 'SKIPPED',\n +count: number,\n|};\n\ntype HermesStackEntry = HermesStackEntryFrame | HermesStackEntrySkipped;\n\nexport type HermesParsedStack = {|\n +message: string,\n +entries: $ReadOnlyArray,\n|};\n\n// Capturing groups:\n// 1. function name\n// 2. is this a native stack frame?\n// 3. is this a bytecode address or a source location?\n// 4. source URL (filename)\n// 5. line number (1 based)\n// 6. column number (1 based) or virtual offset (0 based)\nconst RE_FRAME =\n /^ {4}at (.+?)(?: \\((native)\\)?| \\((address at )?(.*?):(\\d+):(\\d+)\\))$/;\n\n// Capturing groups:\n// 1. count of skipped frames\nconst RE_SKIPPED = /^ {4}... skipping (\\d+) frames$/;\n\nfunction parseLine(line: string): ?HermesStackEntry {\n const asFrame = line.match(RE_FRAME);\n if (asFrame) {\n return {\n type: 'FRAME',\n functionName: asFrame[1],\n location:\n asFrame[2] === 'native'\n ? {type: 'NATIVE'}\n : asFrame[3] === 'address at '\n ? {\n type: 'BYTECODE',\n sourceUrl: asFrame[4],\n line1Based: Number.parseInt(asFrame[5], 10),\n virtualOffset0Based: Number.parseInt(asFrame[6], 10),\n }\n : {\n type: 'SOURCE',\n sourceUrl: asFrame[4],\n line1Based: Number.parseInt(asFrame[5], 10),\n column1Based: Number.parseInt(asFrame[6], 10),\n },\n };\n }\n const asSkipped = line.match(RE_SKIPPED);\n if (asSkipped) {\n return {\n type: 'SKIPPED',\n count: Number.parseInt(asSkipped[1], 10),\n };\n }\n}\n\nmodule.exports = function parseHermesStack(stack: string): HermesParsedStack {\n const lines = stack.split(/\\n/);\n let entries: Array = [];\n let lastMessageLine = -1;\n for (let i = 0; i < lines.length; ++i) {\n const line = lines[i];\n if (!line) {\n continue;\n }\n const entry = parseLine(line);\n if (entry) {\n entries.push(entry);\n continue;\n }\n // No match - we're still in the message\n lastMessageLine = i;\n entries = [];\n }\n const message = lines.slice(0, lastMessageLine + 1).join('\\n');\n return {message, entries};\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 * @flow strict\n * @format\n */\n\nimport type {TurboModule} from '../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../TurboModule/TurboModuleRegistry';\n\nconst Platform = require('../Utilities/Platform');\n\nexport type StackFrame = {|\n column: ?number,\n file: ?string,\n lineNumber: ?number,\n methodName: string,\n collapse?: boolean,\n|};\nexport type ExceptionData = {\n message: string,\n originalMessage: ?string,\n name: ?string,\n componentStack: ?string,\n stack: Array,\n id: number,\n isFatal: boolean,\n // flowlint-next-line unclear-type:off\n extraData?: Object,\n ...\n};\nexport interface Spec extends TurboModule {\n // Deprecated: Use `reportException`\n +reportFatalException: (\n message: string,\n stack: Array,\n exceptionId: number,\n ) => void;\n // Deprecated: Use `reportException`\n +reportSoftException: (\n message: string,\n stack: Array,\n exceptionId: number,\n ) => void;\n +reportException?: (data: ExceptionData) => void;\n +updateExceptionMessage: (\n message: string,\n stack: Array,\n exceptionId: number,\n ) => void;\n // TODO(T53311281): This is a noop on iOS now. Implement it.\n +dismissRedbox?: () => void;\n}\n\nconst NativeModule =\n TurboModuleRegistry.getEnforcing('ExceptionsManager');\n\nconst ExceptionsManager = {\n reportFatalException(\n message: string,\n stack: Array,\n exceptionId: number,\n ) {\n NativeModule.reportFatalException(message, stack, exceptionId);\n },\n reportSoftException(\n message: string,\n stack: Array,\n exceptionId: number,\n ) {\n NativeModule.reportSoftException(message, stack, exceptionId);\n },\n updateExceptionMessage(\n message: string,\n stack: Array,\n exceptionId: number,\n ) {\n NativeModule.updateExceptionMessage(message, stack, exceptionId);\n },\n dismissRedbox(): void {\n if (Platform.OS !== 'ios' && NativeModule.dismissRedbox) {\n // TODO(T53311281): This is a noop on iOS now. Implement it.\n NativeModule.dismissRedbox();\n }\n },\n reportException(data: ExceptionData): void {\n if (NativeModule.reportException) {\n NativeModule.reportException(data);\n return;\n }\n if (data.isFatal) {\n ExceptionsManager.reportFatalException(data.message, data.stack, data.id);\n } else {\n ExceptionsManager.reportSoftException(data.message, data.stack, data.id);\n }\n },\n};\n\nexport default ExceptionsManager;\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 * @flow strict\n * @format\n */\n\n'use strict';\n\nconst {polyfillGlobal} = require('../Utilities/PolyfillFunctions');\n\n/**\n * Set up Promise. The native Promise implementation throws the following error:\n * ERROR: Event loop not supported.\n *\n * If you don't need these polyfills, don't use InitializeCore; just directly\n * require the modules you need from InitializeCore for setup.\n */\n\n// If global.Promise is provided by Hermes, we are confident that it can provide\n// all the methods needed by React Native, so we can directly use it.\nif (global?.HermesInternal?.hasPromise?.()) {\n const HermesPromise = global.Promise;\n\n if (__DEV__) {\n if (typeof HermesPromise !== 'function') {\n console.error('HermesPromise does not exist');\n }\n global.HermesInternal?.enablePromiseRejectionTracker?.(\n require('../promiseRejectionTrackingOptions').default,\n );\n }\n} else {\n polyfillGlobal('Promise', () => require('../Promise'));\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 * @flow strict\n * @format\n */\n\n'use strict';\n\nconst defineLazyObjectProperty = require('./defineLazyObjectProperty');\n\n/**\n * Sets an object's property. If a property with the same name exists, this will\n * replace it but maintain its descriptor configuration. The property will be\n * replaced with a lazy getter.\n *\n * In DEV mode the original property value will be preserved as `original[PropertyName]`\n * so that, if necessary, it can be restored. For example, if you want to route\n * network requests through DevTools (to trace them):\n *\n * global.XMLHttpRequest = global.originalXMLHttpRequest;\n *\n * @see https://github.com/facebook/react-native/issues/934\n */\nfunction polyfillObjectProperty(\n object: {...},\n name: string,\n getValue: () => T,\n): void {\n const descriptor = Object.getOwnPropertyDescriptor<$FlowFixMe>(object, name);\n if (__DEV__ && descriptor) {\n const backupName = `original${name[0].toUpperCase()}${name.substr(1)}`;\n Object.defineProperty(object, backupName, descriptor);\n }\n\n const {enumerable, writable, configurable = false} = descriptor || {};\n if (descriptor && !configurable) {\n console.error('Failed to set polyfill. ' + name + ' is not configurable.');\n return;\n }\n\n defineLazyObjectProperty(object, name, {\n get: getValue,\n enumerable: enumerable !== false,\n writable: writable !== false,\n });\n}\n\nfunction polyfillGlobal(name: string, getValue: () => T): void {\n polyfillObjectProperty(global, name, getValue);\n}\n\nmodule.exports = {polyfillObjectProperty, polyfillGlobal};\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 * @format\n * @flow strict\n */\n\n'use strict';\n\nconst Promise = require('promise/setimmediate/es6-extensions');\n\nrequire('promise/setimmediate/finally');\n\nif (__DEV__) {\n require('promise/setimmediate/rejection-tracking').enable(\n require('./promiseRejectionTrackingOptions').default,\n );\n}\n\nmodule.exports = Promise;\n","'use strict';\n\nvar Promise = require('./core.js');\n\nmodule.exports = Promise;\nPromise.prototype.finally = function (f) {\n return this.then(function (value) {\n return Promise.resolve(f()).then(function () {\n return value;\n });\n }, function (err) {\n return Promise.resolve(f()).then(function () {\n throw err;\n });\n });\n};\n","'use strict';\n\n\n\nfunction noop() {}\n\n// States:\n//\n// 0 - pending\n// 1 - fulfilled with _value\n// 2 - rejected with _value\n// 3 - adopted the state of another promise, _value\n//\n// once the state is no longer pending (0) it is immutable\n\n// All `_` prefixed properties will be reduced to `_{random number}`\n// at build time to obfuscate them and discourage their use.\n// We don't use symbols or Object.defineProperty to fully hide them\n// because the performance isn't good enough.\n\n\n// to avoid using try/catch inside critical functions, we\n// extract them to here.\nvar LAST_ERROR = null;\nvar IS_ERROR = {};\nfunction getThen(obj) {\n try {\n return obj.then;\n } catch (ex) {\n LAST_ERROR = ex;\n return IS_ERROR;\n }\n}\n\nfunction tryCallOne(fn, a) {\n try {\n return fn(a);\n } catch (ex) {\n LAST_ERROR = ex;\n return IS_ERROR;\n }\n}\nfunction tryCallTwo(fn, a, b) {\n try {\n fn(a, b);\n } catch (ex) {\n LAST_ERROR = ex;\n return IS_ERROR;\n }\n}\n\nmodule.exports = Promise;\n\nfunction Promise(fn) {\n if (typeof this !== 'object') {\n throw new TypeError('Promises must be constructed via new');\n }\n if (typeof fn !== 'function') {\n throw new TypeError('Promise constructor\\'s argument is not a function');\n }\n this._x = 0;\n this._y = 0;\n this._z = null;\n this._A = null;\n if (fn === noop) return;\n doResolve(fn, this);\n}\nPromise._B = null;\nPromise._C = null;\nPromise._D = noop;\n\nPromise.prototype.then = function(onFulfilled, onRejected) {\n if (this.constructor !== Promise) {\n return safeThen(this, onFulfilled, onRejected);\n }\n var res = new Promise(noop);\n handle(this, new Handler(onFulfilled, onRejected, res));\n return res;\n};\n\nfunction safeThen(self, onFulfilled, onRejected) {\n return new self.constructor(function (resolve, reject) {\n var res = new Promise(noop);\n res.then(resolve, reject);\n handle(self, new Handler(onFulfilled, onRejected, res));\n });\n}\nfunction handle(self, deferred) {\n while (self._y === 3) {\n self = self._z;\n }\n if (Promise._B) {\n Promise._B(self);\n }\n if (self._y === 0) {\n if (self._x === 0) {\n self._x = 1;\n self._A = deferred;\n return;\n }\n if (self._x === 1) {\n self._x = 2;\n self._A = [self._A, deferred];\n return;\n }\n self._A.push(deferred);\n return;\n }\n handleResolved(self, deferred);\n}\n\nfunction handleResolved(self, deferred) {\n setImmediate(function() {\n var cb = self._y === 1 ? deferred.onFulfilled : deferred.onRejected;\n if (cb === null) {\n if (self._y === 1) {\n resolve(deferred.promise, self._z);\n } else {\n reject(deferred.promise, self._z);\n }\n return;\n }\n var ret = tryCallOne(cb, self._z);\n if (ret === IS_ERROR) {\n reject(deferred.promise, LAST_ERROR);\n } else {\n resolve(deferred.promise, ret);\n }\n });\n}\nfunction resolve(self, newValue) {\n // Promise Resolution Procedure: https://github.com/promises-aplus/promises-spec#the-promise-resolution-procedure\n if (newValue === self) {\n return reject(\n self,\n new TypeError('A promise cannot be resolved with itself.')\n );\n }\n if (\n newValue &&\n (typeof newValue === 'object' || typeof newValue === 'function')\n ) {\n var then = getThen(newValue);\n if (then === IS_ERROR) {\n return reject(self, LAST_ERROR);\n }\n if (\n then === self.then &&\n newValue instanceof Promise\n ) {\n self._y = 3;\n self._z = newValue;\n finale(self);\n return;\n } else if (typeof then === 'function') {\n doResolve(then.bind(newValue), self);\n return;\n }\n }\n self._y = 1;\n self._z = newValue;\n finale(self);\n}\n\nfunction reject(self, newValue) {\n self._y = 2;\n self._z = newValue;\n if (Promise._C) {\n Promise._C(self, newValue);\n }\n finale(self);\n}\nfunction finale(self) {\n if (self._x === 1) {\n handle(self, self._A);\n self._A = null;\n }\n if (self._x === 2) {\n for (var i = 0; i < self._A.length; i++) {\n handle(self, self._A[i]);\n }\n self._A = null;\n }\n}\n\nfunction Handler(onFulfilled, onRejected, promise){\n this.onFulfilled = typeof onFulfilled === 'function' ? onFulfilled : null;\n this.onRejected = typeof onRejected === 'function' ? onRejected : null;\n this.promise = promise;\n}\n\n/**\n * Take a potentially misbehaving resolver function and make sure\n * onFulfilled and onRejected are only called once.\n *\n * Makes no guarantees about asynchrony.\n */\nfunction doResolve(fn, promise) {\n var done = false;\n var res = tryCallTwo(fn, function (value) {\n if (done) return;\n done = true;\n resolve(promise, value);\n }, function (reason) {\n if (done) return;\n done = true;\n reject(promise, reason);\n });\n if (!done && res === IS_ERROR) {\n done = true;\n reject(promise, LAST_ERROR);\n }\n}\n","'use strict';\n\n//This file contains the ES6 extensions to the core Promises/A+ API\n\nvar Promise = require('./core.js');\n\nmodule.exports = Promise;\n\n/* Static Functions */\n\nvar TRUE = valuePromise(true);\nvar FALSE = valuePromise(false);\nvar NULL = valuePromise(null);\nvar UNDEFINED = valuePromise(undefined);\nvar ZERO = valuePromise(0);\nvar EMPTYSTRING = valuePromise('');\n\nfunction valuePromise(value) {\n var p = new Promise(Promise._D);\n p._y = 1;\n p._z = value;\n return p;\n}\nPromise.resolve = function (value) {\n if (value instanceof Promise) return value;\n\n if (value === null) return NULL;\n if (value === undefined) return UNDEFINED;\n if (value === true) return TRUE;\n if (value === false) return FALSE;\n if (value === 0) return ZERO;\n if (value === '') return EMPTYSTRING;\n\n if (typeof value === 'object' || typeof value === 'function') {\n try {\n var then = value.then;\n if (typeof then === 'function') {\n return new Promise(then.bind(value));\n }\n } catch (ex) {\n return new Promise(function (resolve, reject) {\n reject(ex);\n });\n }\n }\n return valuePromise(value);\n};\n\nvar iterableToArray = function (iterable) {\n if (typeof Array.from === 'function') {\n // ES2015+, iterables exist\n iterableToArray = Array.from;\n return Array.from(iterable);\n }\n\n // ES5, only arrays and array-likes exist\n iterableToArray = function (x) { return Array.prototype.slice.call(x); };\n return Array.prototype.slice.call(iterable);\n}\n\nPromise.all = function (arr) {\n var args = iterableToArray(arr);\n\n return new Promise(function (resolve, reject) {\n if (args.length === 0) return resolve([]);\n var remaining = args.length;\n function res(i, val) {\n if (val && (typeof val === 'object' || typeof val === 'function')) {\n if (val instanceof Promise && val.then === Promise.prototype.then) {\n while (val._y === 3) {\n val = val._z;\n }\n if (val._y === 1) return res(i, val._z);\n if (val._y === 2) reject(val._z);\n val.then(function (val) {\n res(i, val);\n }, reject);\n return;\n } else {\n var then = val.then;\n if (typeof then === 'function') {\n var p = new Promise(then.bind(val));\n p.then(function (val) {\n res(i, val);\n }, reject);\n return;\n }\n }\n }\n args[i] = val;\n if (--remaining === 0) {\n resolve(args);\n }\n }\n for (var i = 0; i < args.length; i++) {\n res(i, args[i]);\n }\n });\n};\n\nfunction onSettledFulfill(value) {\n return { status: 'fulfilled', value: value };\n}\nfunction onSettledReject(reason) {\n return { status: 'rejected', reason: reason };\n}\nfunction mapAllSettled(item) {\n if(item && (typeof item === 'object' || typeof item === 'function')){\n if(item instanceof Promise && item.then === Promise.prototype.then){\n return item.then(onSettledFulfill, onSettledReject);\n }\n var then = item.then;\n if (typeof then === 'function') {\n return new Promise(then.bind(item)).then(onSettledFulfill, onSettledReject)\n }\n }\n\n return onSettledFulfill(item);\n}\nPromise.allSettled = function (iterable) {\n return Promise.all(iterableToArray(iterable).map(mapAllSettled));\n};\n\nPromise.reject = function (value) {\n return new Promise(function (resolve, reject) {\n reject(value);\n });\n};\n\nPromise.race = function (values) {\n return new Promise(function (resolve, reject) {\n iterableToArray(values).forEach(function(value){\n Promise.resolve(value).then(resolve, reject);\n });\n });\n};\n\n/* Prototype Methods */\n\nPromise.prototype['catch'] = function (onRejected) {\n return this.then(null, onRejected);\n};\n\nfunction getAggregateError(errors){\n if(typeof AggregateError === 'function'){\n return new AggregateError(errors,'All promises were rejected');\n }\n\n var error = new Error('All promises were rejected');\n\n error.name = 'AggregateError';\n error.errors = errors;\n\n return error;\n}\n\nPromise.any = function promiseAny(values) {\n return new Promise(function(resolve, reject) {\n var promises = iterableToArray(values);\n var hasResolved = false;\n var rejectionReasons = [];\n\n function resolveOnce(value) {\n if (!hasResolved) {\n hasResolved = true;\n resolve(value);\n }\n }\n\n function rejectionCheck(reason) {\n rejectionReasons.push(reason);\n\n if (rejectionReasons.length === promises.length) {\n reject(getAggregateError(rejectionReasons));\n }\n }\n\n if(promises.length === 0){\n reject(getAggregateError(rejectionReasons));\n } else {\n promises.forEach(function(value){\n Promise.resolve(value).then(resolveOnce, rejectionCheck);\n });\n }\n });\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 * @flow strict-local\n * @format\n */\n\n'use strict';\n\nconst {hasNativeConstructor} = require('../Utilities/FeatureDetection');\nconst {polyfillGlobal} = require('../Utilities/PolyfillFunctions');\n\n/**\n * Set up regenerator.\n * You can use this module directly, or just require InitializeCore.\n */\n\nlet hasNativeGenerator;\ntry {\n // If this function was lowered by regenerator-transform, it will try to\n // access `global.regeneratorRuntime` which doesn't exist yet and will throw.\n hasNativeGenerator = hasNativeConstructor(function* () {},\n 'GeneratorFunction');\n} catch {\n // In this case, we know generators are not provided natively.\n hasNativeGenerator = false;\n}\n\n// If generators are provided natively, which suggests that there was no\n// regenerator-transform, then there is no need to set up the runtime.\nif (!hasNativeGenerator) {\n polyfillGlobal('regeneratorRuntime', () => {\n // The require just sets up the global, so make sure when we first\n // invoke it the global does not exist\n delete global.regeneratorRuntime;\n\n // regenerator-runtime/runtime exports the regeneratorRuntime object, so we\n // can return it safely.\n return require('regenerator-runtime/runtime'); // flowlint-line untyped-import:off\n });\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 * @flow\n * @format\n */\n\n/**\n * @return whether or not a @param {function} f is provided natively by calling\n * `toString` and check if the result includes `[native code]` in it.\n *\n * Note that a polyfill can technically fake this behavior but few does it.\n * Therefore, this is usually good enough for our purpose.\n */\nfunction isNativeFunction(f: Function): boolean {\n return typeof f === 'function' && f.toString().indexOf('[native code]') > -1;\n}\n\n/**\n * @return whether or not the constructor of @param {object} o is an native\n * function named with @param {string} expectedName.\n */\nfunction hasNativeConstructor(o: Object, expectedName: string): boolean {\n const con = Object.getPrototypeOf(o).constructor;\n return con.name === expectedName && isNativeFunction(con);\n}\n\nmodule.exports = {isNativeFunction, hasNativeConstructor};\n","/**\n * Copyright (c) 2014-present, Facebook, Inc.\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\nvar runtime = (function (exports) {\n \"use strict\";\n\n var Op = Object.prototype;\n var hasOwn = Op.hasOwnProperty;\n var undefined; // More compressible than void 0.\n var $Symbol = typeof Symbol === \"function\" ? Symbol : {};\n var iteratorSymbol = $Symbol.iterator || \"@@iterator\";\n var asyncIteratorSymbol = $Symbol.asyncIterator || \"@@asyncIterator\";\n var toStringTagSymbol = $Symbol.toStringTag || \"@@toStringTag\";\n\n function define(obj, key, value) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n return obj[key];\n }\n try {\n // IE 8 has a broken Object.defineProperty that only works on DOM objects.\n define({}, \"\");\n } catch (err) {\n define = function(obj, key, value) {\n return obj[key] = value;\n };\n }\n\n function wrap(innerFn, outerFn, self, tryLocsList) {\n // If outerFn provided and outerFn.prototype is a Generator, then outerFn.prototype instanceof Generator.\n var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator;\n var generator = Object.create(protoGenerator.prototype);\n var context = new Context(tryLocsList || []);\n\n // The ._invoke method unifies the implementations of the .next,\n // .throw, and .return methods.\n generator._invoke = makeInvokeMethod(innerFn, self, context);\n\n return generator;\n }\n exports.wrap = wrap;\n\n // Try/catch helper to minimize deoptimizations. Returns a completion\n // record like context.tryEntries[i].completion. This interface could\n // have been (and was previously) designed to take a closure to be\n // invoked without arguments, but in all the cases we care about we\n // already have an existing method we want to call, so there's no need\n // to create a new function object. We can even get away with assuming\n // the method takes exactly one argument, since that happens to be true\n // in every case, so we don't have to touch the arguments object. The\n // only additional allocation required is the completion record, which\n // has a stable shape and so hopefully should be cheap to allocate.\n function tryCatch(fn, obj, arg) {\n try {\n return { type: \"normal\", arg: fn.call(obj, arg) };\n } catch (err) {\n return { type: \"throw\", arg: err };\n }\n }\n\n var GenStateSuspendedStart = \"suspendedStart\";\n var GenStateSuspendedYield = \"suspendedYield\";\n var GenStateExecuting = \"executing\";\n var GenStateCompleted = \"completed\";\n\n // Returning this object from the innerFn has the same effect as\n // breaking out of the dispatch switch statement.\n var ContinueSentinel = {};\n\n // Dummy constructor functions that we use as the .constructor and\n // .constructor.prototype properties for functions that return Generator\n // objects. For full spec compliance, you may wish to configure your\n // minifier not to mangle the names of these two functions.\n function Generator() {}\n function GeneratorFunction() {}\n function GeneratorFunctionPrototype() {}\n\n // This is a polyfill for %IteratorPrototype% for environments that\n // don't natively support it.\n var IteratorPrototype = {};\n define(IteratorPrototype, iteratorSymbol, function () {\n return this;\n });\n\n var getProto = Object.getPrototypeOf;\n var NativeIteratorPrototype = getProto && getProto(getProto(values([])));\n if (NativeIteratorPrototype &&\n NativeIteratorPrototype !== Op &&\n hasOwn.call(NativeIteratorPrototype, iteratorSymbol)) {\n // This environment has a native %IteratorPrototype%; use it instead\n // of the polyfill.\n IteratorPrototype = NativeIteratorPrototype;\n }\n\n var Gp = GeneratorFunctionPrototype.prototype =\n Generator.prototype = Object.create(IteratorPrototype);\n GeneratorFunction.prototype = GeneratorFunctionPrototype;\n define(Gp, \"constructor\", GeneratorFunctionPrototype);\n define(GeneratorFunctionPrototype, \"constructor\", GeneratorFunction);\n GeneratorFunction.displayName = define(\n GeneratorFunctionPrototype,\n toStringTagSymbol,\n \"GeneratorFunction\"\n );\n\n // Helper for defining the .next, .throw, and .return methods of the\n // Iterator interface in terms of a single ._invoke method.\n function defineIteratorMethods(prototype) {\n [\"next\", \"throw\", \"return\"].forEach(function(method) {\n define(prototype, method, function(arg) {\n return this._invoke(method, arg);\n });\n });\n }\n\n exports.isGeneratorFunction = function(genFun) {\n var ctor = typeof genFun === \"function\" && genFun.constructor;\n return ctor\n ? ctor === GeneratorFunction ||\n // For the native GeneratorFunction constructor, the best we can\n // do is to check its .name property.\n (ctor.displayName || ctor.name) === \"GeneratorFunction\"\n : false;\n };\n\n exports.mark = function(genFun) {\n if (Object.setPrototypeOf) {\n Object.setPrototypeOf(genFun, GeneratorFunctionPrototype);\n } else {\n genFun.__proto__ = GeneratorFunctionPrototype;\n define(genFun, toStringTagSymbol, \"GeneratorFunction\");\n }\n genFun.prototype = Object.create(Gp);\n return genFun;\n };\n\n // Within the body of any async function, `await x` is transformed to\n // `yield regeneratorRuntime.awrap(x)`, so that the runtime can test\n // `hasOwn.call(value, \"__await\")` to determine if the yielded value is\n // meant to be awaited.\n exports.awrap = function(arg) {\n return { __await: arg };\n };\n\n function AsyncIterator(generator, PromiseImpl) {\n function invoke(method, arg, resolve, reject) {\n var record = tryCatch(generator[method], generator, arg);\n if (record.type === \"throw\") {\n reject(record.arg);\n } else {\n var result = record.arg;\n var value = result.value;\n if (value &&\n typeof value === \"object\" &&\n hasOwn.call(value, \"__await\")) {\n return PromiseImpl.resolve(value.__await).then(function(value) {\n invoke(\"next\", value, resolve, reject);\n }, function(err) {\n invoke(\"throw\", err, resolve, reject);\n });\n }\n\n return PromiseImpl.resolve(value).then(function(unwrapped) {\n // When a yielded Promise is resolved, its final value becomes\n // the .value of the Promise<{value,done}> result for the\n // current iteration.\n result.value = unwrapped;\n resolve(result);\n }, function(error) {\n // If a rejected Promise was yielded, throw the rejection back\n // into the async generator function so it can be handled there.\n return invoke(\"throw\", error, resolve, reject);\n });\n }\n }\n\n var previousPromise;\n\n function enqueue(method, arg) {\n function callInvokeWithMethodAndArg() {\n return new PromiseImpl(function(resolve, reject) {\n invoke(method, arg, resolve, reject);\n });\n }\n\n return previousPromise =\n // If enqueue has been called before, then we want to wait until\n // all previous Promises have been resolved before calling invoke,\n // so that results are always delivered in the correct order. If\n // enqueue has not been called before, then it is important to\n // call invoke immediately, without waiting on a callback to fire,\n // so that the async generator function has the opportunity to do\n // any necessary setup in a predictable way. This predictability\n // is why the Promise constructor synchronously invokes its\n // executor callback, and why async functions synchronously\n // execute code before the first await. Since we implement simple\n // async functions in terms of async generators, it is especially\n // important to get this right, even though it requires care.\n previousPromise ? previousPromise.then(\n callInvokeWithMethodAndArg,\n // Avoid propagating failures to Promises returned by later\n // invocations of the iterator.\n callInvokeWithMethodAndArg\n ) : callInvokeWithMethodAndArg();\n }\n\n // Define the unified helper method that is used to implement .next,\n // .throw, and .return (see defineIteratorMethods).\n this._invoke = enqueue;\n }\n\n defineIteratorMethods(AsyncIterator.prototype);\n define(AsyncIterator.prototype, asyncIteratorSymbol, function () {\n return this;\n });\n exports.AsyncIterator = AsyncIterator;\n\n // Note that simple async functions are implemented on top of\n // AsyncIterator objects; they just return a Promise for the value of\n // the final result produced by the iterator.\n exports.async = function(innerFn, outerFn, self, tryLocsList, PromiseImpl) {\n if (PromiseImpl === void 0) PromiseImpl = Promise;\n\n var iter = new AsyncIterator(\n wrap(innerFn, outerFn, self, tryLocsList),\n PromiseImpl\n );\n\n return exports.isGeneratorFunction(outerFn)\n ? iter // If outerFn is a generator, return the full iterator.\n : iter.next().then(function(result) {\n return result.done ? result.value : iter.next();\n });\n };\n\n function makeInvokeMethod(innerFn, self, context) {\n var state = GenStateSuspendedStart;\n\n return function invoke(method, arg) {\n if (state === GenStateExecuting) {\n throw new Error(\"Generator is already running\");\n }\n\n if (state === GenStateCompleted) {\n if (method === \"throw\") {\n throw arg;\n }\n\n // Be forgiving, per 25.3.3.3.3 of the spec:\n // https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume\n return doneResult();\n }\n\n context.method = method;\n context.arg = arg;\n\n while (true) {\n var delegate = context.delegate;\n if (delegate) {\n var delegateResult = maybeInvokeDelegate(delegate, context);\n if (delegateResult) {\n if (delegateResult === ContinueSentinel) continue;\n return delegateResult;\n }\n }\n\n if (context.method === \"next\") {\n // Setting context._sent for legacy support of Babel's\n // function.sent implementation.\n context.sent = context._sent = context.arg;\n\n } else if (context.method === \"throw\") {\n if (state === GenStateSuspendedStart) {\n state = GenStateCompleted;\n throw context.arg;\n }\n\n context.dispatchException(context.arg);\n\n } else if (context.method === \"return\") {\n context.abrupt(\"return\", context.arg);\n }\n\n state = GenStateExecuting;\n\n var record = tryCatch(innerFn, self, context);\n if (record.type === \"normal\") {\n // If an exception is thrown from innerFn, we leave state ===\n // GenStateExecuting and loop back for another invocation.\n state = context.done\n ? GenStateCompleted\n : GenStateSuspendedYield;\n\n if (record.arg === ContinueSentinel) {\n continue;\n }\n\n return {\n value: record.arg,\n done: context.done\n };\n\n } else if (record.type === \"throw\") {\n state = GenStateCompleted;\n // Dispatch the exception by looping back around to the\n // context.dispatchException(context.arg) call above.\n context.method = \"throw\";\n context.arg = record.arg;\n }\n }\n };\n }\n\n // Call delegate.iterator[context.method](context.arg) and handle the\n // result, either by returning a { value, done } result from the\n // delegate iterator, or by modifying context.method and context.arg,\n // setting context.delegate to null, and returning the ContinueSentinel.\n function maybeInvokeDelegate(delegate, context) {\n var method = delegate.iterator[context.method];\n if (method === undefined) {\n // A .throw or .return when the delegate iterator has no .throw\n // method always terminates the yield* loop.\n context.delegate = null;\n\n if (context.method === \"throw\") {\n // Note: [\"return\"] must be used for ES3 parsing compatibility.\n if (delegate.iterator[\"return\"]) {\n // If the delegate iterator has a return method, give it a\n // chance to clean up.\n context.method = \"return\";\n context.arg = undefined;\n maybeInvokeDelegate(delegate, context);\n\n if (context.method === \"throw\") {\n // If maybeInvokeDelegate(context) changed context.method from\n // \"return\" to \"throw\", let that override the TypeError below.\n return ContinueSentinel;\n }\n }\n\n context.method = \"throw\";\n context.arg = new TypeError(\n \"The iterator does not provide a 'throw' method\");\n }\n\n return ContinueSentinel;\n }\n\n var record = tryCatch(method, delegate.iterator, context.arg);\n\n if (record.type === \"throw\") {\n context.method = \"throw\";\n context.arg = record.arg;\n context.delegate = null;\n return ContinueSentinel;\n }\n\n var info = record.arg;\n\n if (! info) {\n context.method = \"throw\";\n context.arg = new TypeError(\"iterator result is not an object\");\n context.delegate = null;\n return ContinueSentinel;\n }\n\n if (info.done) {\n // Assign the result of the finished delegate to the temporary\n // variable specified by delegate.resultName (see delegateYield).\n context[delegate.resultName] = info.value;\n\n // Resume execution at the desired location (see delegateYield).\n context.next = delegate.nextLoc;\n\n // If context.method was \"throw\" but the delegate handled the\n // exception, let the outer generator proceed normally. If\n // context.method was \"next\", forget context.arg since it has been\n // \"consumed\" by the delegate iterator. If context.method was\n // \"return\", allow the original .return call to continue in the\n // outer generator.\n if (context.method !== \"return\") {\n context.method = \"next\";\n context.arg = undefined;\n }\n\n } else {\n // Re-yield the result returned by the delegate method.\n return info;\n }\n\n // The delegate iterator is finished, so forget it and continue with\n // the outer generator.\n context.delegate = null;\n return ContinueSentinel;\n }\n\n // Define Generator.prototype.{next,throw,return} in terms of the\n // unified ._invoke helper method.\n defineIteratorMethods(Gp);\n\n define(Gp, toStringTagSymbol, \"Generator\");\n\n // A Generator should always return itself as the iterator object when the\n // @@iterator function is called on it. Some browsers' implementations of the\n // iterator prototype chain incorrectly implement this, causing the Generator\n // object to not be returned from this call. This ensures that doesn't happen.\n // See https://github.com/facebook/regenerator/issues/274 for more details.\n define(Gp, iteratorSymbol, function() {\n return this;\n });\n\n define(Gp, \"toString\", function() {\n return \"[object Generator]\";\n });\n\n function pushTryEntry(locs) {\n var entry = { tryLoc: locs[0] };\n\n if (1 in locs) {\n entry.catchLoc = locs[1];\n }\n\n if (2 in locs) {\n entry.finallyLoc = locs[2];\n entry.afterLoc = locs[3];\n }\n\n this.tryEntries.push(entry);\n }\n\n function resetTryEntry(entry) {\n var record = entry.completion || {};\n record.type = \"normal\";\n delete record.arg;\n entry.completion = record;\n }\n\n function Context(tryLocsList) {\n // The root entry object (effectively a try statement without a catch\n // or a finally block) gives us a place to store values thrown from\n // locations where there is no enclosing try statement.\n this.tryEntries = [{ tryLoc: \"root\" }];\n tryLocsList.forEach(pushTryEntry, this);\n this.reset(true);\n }\n\n exports.keys = function(object) {\n var keys = [];\n for (var key in object) {\n keys.push(key);\n }\n keys.reverse();\n\n // Rather than returning an object with a next method, we keep\n // things simple and return the next function itself.\n return function next() {\n while (keys.length) {\n var key = keys.pop();\n if (key in object) {\n next.value = key;\n next.done = false;\n return next;\n }\n }\n\n // To avoid creating an additional object, we just hang the .value\n // and .done properties off the next function object itself. This\n // also ensures that the minifier will not anonymize the function.\n next.done = true;\n return next;\n };\n };\n\n function values(iterable) {\n if (iterable) {\n var iteratorMethod = iterable[iteratorSymbol];\n if (iteratorMethod) {\n return iteratorMethod.call(iterable);\n }\n\n if (typeof iterable.next === \"function\") {\n return iterable;\n }\n\n if (!isNaN(iterable.length)) {\n var i = -1, next = function next() {\n while (++i < iterable.length) {\n if (hasOwn.call(iterable, i)) {\n next.value = iterable[i];\n next.done = false;\n return next;\n }\n }\n\n next.value = undefined;\n next.done = true;\n\n return next;\n };\n\n return next.next = next;\n }\n }\n\n // Return an iterator with no values.\n return { next: doneResult };\n }\n exports.values = values;\n\n function doneResult() {\n return { value: undefined, done: true };\n }\n\n Context.prototype = {\n constructor: Context,\n\n reset: function(skipTempReset) {\n this.prev = 0;\n this.next = 0;\n // Resetting context._sent for legacy support of Babel's\n // function.sent implementation.\n this.sent = this._sent = undefined;\n this.done = false;\n this.delegate = null;\n\n this.method = \"next\";\n this.arg = undefined;\n\n this.tryEntries.forEach(resetTryEntry);\n\n if (!skipTempReset) {\n for (var name in this) {\n // Not sure about the optimal order of these conditions:\n if (name.charAt(0) === \"t\" &&\n hasOwn.call(this, name) &&\n !isNaN(+name.slice(1))) {\n this[name] = undefined;\n }\n }\n }\n },\n\n stop: function() {\n this.done = true;\n\n var rootEntry = this.tryEntries[0];\n var rootRecord = rootEntry.completion;\n if (rootRecord.type === \"throw\") {\n throw rootRecord.arg;\n }\n\n return this.rval;\n },\n\n dispatchException: function(exception) {\n if (this.done) {\n throw exception;\n }\n\n var context = this;\n function handle(loc, caught) {\n record.type = \"throw\";\n record.arg = exception;\n context.next = loc;\n\n if (caught) {\n // If the dispatched exception was caught by a catch block,\n // then let that catch block handle the exception normally.\n context.method = \"next\";\n context.arg = undefined;\n }\n\n return !! caught;\n }\n\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n var record = entry.completion;\n\n if (entry.tryLoc === \"root\") {\n // Exception thrown outside of any try block that could handle\n // it, so set the completion value of the entire function to\n // throw the exception.\n return handle(\"end\");\n }\n\n if (entry.tryLoc <= this.prev) {\n var hasCatch = hasOwn.call(entry, \"catchLoc\");\n var hasFinally = hasOwn.call(entry, \"finallyLoc\");\n\n if (hasCatch && hasFinally) {\n if (this.prev < entry.catchLoc) {\n return handle(entry.catchLoc, true);\n } else if (this.prev < entry.finallyLoc) {\n return handle(entry.finallyLoc);\n }\n\n } else if (hasCatch) {\n if (this.prev < entry.catchLoc) {\n return handle(entry.catchLoc, true);\n }\n\n } else if (hasFinally) {\n if (this.prev < entry.finallyLoc) {\n return handle(entry.finallyLoc);\n }\n\n } else {\n throw new Error(\"try statement without catch or finally\");\n }\n }\n }\n },\n\n abrupt: function(type, arg) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.tryLoc <= this.prev &&\n hasOwn.call(entry, \"finallyLoc\") &&\n this.prev < entry.finallyLoc) {\n var finallyEntry = entry;\n break;\n }\n }\n\n if (finallyEntry &&\n (type === \"break\" ||\n type === \"continue\") &&\n finallyEntry.tryLoc <= arg &&\n arg <= finallyEntry.finallyLoc) {\n // Ignore the finally entry if control is not jumping to a\n // location outside the try/catch block.\n finallyEntry = null;\n }\n\n var record = finallyEntry ? finallyEntry.completion : {};\n record.type = type;\n record.arg = arg;\n\n if (finallyEntry) {\n this.method = \"next\";\n this.next = finallyEntry.finallyLoc;\n return ContinueSentinel;\n }\n\n return this.complete(record);\n },\n\n complete: function(record, afterLoc) {\n if (record.type === \"throw\") {\n throw record.arg;\n }\n\n if (record.type === \"break\" ||\n record.type === \"continue\") {\n this.next = record.arg;\n } else if (record.type === \"return\") {\n this.rval = this.arg = record.arg;\n this.method = \"return\";\n this.next = \"end\";\n } else if (record.type === \"normal\" && afterLoc) {\n this.next = afterLoc;\n }\n\n return ContinueSentinel;\n },\n\n finish: function(finallyLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.finallyLoc === finallyLoc) {\n this.complete(entry.completion, entry.afterLoc);\n resetTryEntry(entry);\n return ContinueSentinel;\n }\n }\n },\n\n \"catch\": function(tryLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.tryLoc === tryLoc) {\n var record = entry.completion;\n if (record.type === \"throw\") {\n var thrown = record.arg;\n resetTryEntry(entry);\n }\n return thrown;\n }\n }\n\n // The context.catch method must only be called with a location\n // argument that corresponds to a known catch block.\n throw new Error(\"illegal catch attempt\");\n },\n\n delegateYield: function(iterable, resultName, nextLoc) {\n this.delegate = {\n iterator: values(iterable),\n resultName: resultName,\n nextLoc: nextLoc\n };\n\n if (this.method === \"next\") {\n // Deliberately forget the last sent value so that we don't\n // accidentally pass it on to the delegate.\n this.arg = undefined;\n }\n\n return ContinueSentinel;\n }\n };\n\n // Regardless of whether this script is executing as a CommonJS module\n // or not, return the runtime object so that we can declare the variable\n // regeneratorRuntime in the outer scope, which allows this module to be\n // injected easily by `bin/regenerator --include-runtime script.js`.\n return exports;\n\n}(\n // If this script is executing as a CommonJS module, use module.exports\n // as the regeneratorRuntime namespace. Otherwise create a new empty\n // object. Either way, the resulting object will be used to initialize\n // the regeneratorRuntime variable at the top of this file.\n typeof module === \"object\" ? module.exports : {}\n));\n\ntry {\n regeneratorRuntime = runtime;\n} catch (accidentalStrictMode) {\n // This module should not be running in strict mode, so the above\n // assignment should always work unless something is misconfigured. Just\n // in case runtime.js accidentally runs in strict mode, in modern engines\n // we can explicitly access globalThis. In older engines we can escape\n // strict mode using a global Function call. This could conceivably fail\n // if a Content Security Policy forbids using Function, but in that case\n // the proper solution is to fix the accidental strict mode problem. If\n // you've misconfigured your bundler to force strict mode and applied a\n // CSP to forbid Function, and you're not willing to fix either of those\n // problems, please detail your unique predicament in a GitHub issue.\n if (typeof globalThis === \"object\") {\n globalThis.regeneratorRuntime = runtime;\n } else {\n Function(\"r\", \"regeneratorRuntime = r\")(runtime);\n }\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 * @flow strict-local\n * @format\n */\n\n'use strict';\n\nconst {isNativeFunction} = require('../Utilities/FeatureDetection');\nconst {polyfillGlobal} = require('../Utilities/PolyfillFunctions');\n\nif (__DEV__) {\n if (typeof global.Promise !== 'function') {\n console.error('Promise should exist before setting up timers.');\n }\n}\n\n// Currently, Hermes `Promise` is implemented via Internal Bytecode.\nconst hasHermesPromiseQueuedToJSVM =\n global.HermesInternal?.hasPromise?.() === true &&\n global.HermesInternal?.useEngineQueue?.() === true;\n\nconst hasNativePromise = isNativeFunction(Promise);\nconst hasPromiseQueuedToJSVM = hasNativePromise || hasHermesPromiseQueuedToJSVM;\n\n// In bridgeless mode, timers are host functions installed from cpp.\nif (global.RN$Bridgeless !== true) {\n /**\n * Set up timers.\n * You can use this module directly, or just require InitializeCore.\n */\n const defineLazyTimer = (\n name:\n | $TEMPORARY$string<'cancelAnimationFrame'>\n | $TEMPORARY$string<'cancelIdleCallback'>\n | $TEMPORARY$string<'clearInterval'>\n | $TEMPORARY$string<'clearTimeout'>\n | $TEMPORARY$string<'requestAnimationFrame'>\n | $TEMPORARY$string<'requestIdleCallback'>\n | $TEMPORARY$string<'setInterval'>\n | $TEMPORARY$string<'setTimeout'>,\n ) => {\n polyfillGlobal(name, () => require('./Timers/JSTimers')[name]);\n };\n defineLazyTimer('setTimeout');\n defineLazyTimer('clearTimeout');\n defineLazyTimer('setInterval');\n defineLazyTimer('clearInterval');\n defineLazyTimer('requestAnimationFrame');\n defineLazyTimer('cancelAnimationFrame');\n defineLazyTimer('requestIdleCallback');\n defineLazyTimer('cancelIdleCallback');\n}\n\n/**\n * Set up immediate APIs, which is required to use the same microtask queue\n * as the Promise.\n */\nif (hasPromiseQueuedToJSVM) {\n // When promise queues to the JSVM microtasks queue, we shim the immedaite\n // APIs via `queueMicrotask` to maintain the backward compatibility.\n polyfillGlobal(\n 'setImmediate',\n () => require('./Timers/immediateShim').setImmediate,\n );\n polyfillGlobal(\n 'clearImmediate',\n () => require('./Timers/immediateShim').clearImmediate,\n );\n} else {\n // When promise was polyfilled hence is queued to the RN microtask queue,\n // we polyfill the immediate APIs as aliases to the ReactNativeMicrotask APIs.\n // Note that in bridgeless mode, immediate APIs are installed from cpp.\n if (global.RN$Bridgeless !== true) {\n polyfillGlobal(\n 'setImmediate',\n () => require('./Timers/JSTimers').queueReactNativeMicrotask,\n );\n polyfillGlobal(\n 'clearImmediate',\n () => require('./Timers/JSTimers').clearReactNativeMicrotask,\n );\n }\n}\n\n/**\n * Set up the microtask queueing API, which is required to use the same\n * microtask queue as the Promise.\n */\nif (hasHermesPromiseQueuedToJSVM) {\n // Fast path for Hermes.\n polyfillGlobal('queueMicrotask', () => global.HermesInternal?.enqueueJob);\n} else {\n // Polyfill it with promise (regardless it's polyfiled or native) otherwise.\n polyfillGlobal(\n 'queueMicrotask',\n () => require('./Timers/queueMicrotask.js').default,\n );\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 * @format\n * @flow\n */\n\nimport NativeTiming from './NativeTiming';\n\nconst BatchedBridge = require('../../BatchedBridge/BatchedBridge');\nconst Systrace = require('../../Performance/Systrace');\nconst invariant = require('invariant');\n\n/**\n * JS implementation of timer functions. Must be completely driven by an\n * external clock signal, all that's stored here is timerID, timer type, and\n * callback.\n */\n\nexport type JSTimerType =\n | 'setTimeout'\n | 'setInterval'\n | 'requestAnimationFrame'\n | 'queueReactNativeMicrotask'\n | 'requestIdleCallback';\n\n// These timing constants should be kept in sync with the ones in native ios and\n// android `RCTTiming` module.\nconst FRAME_DURATION = 1000 / 60;\nconst IDLE_CALLBACK_FRAME_DEADLINE = 1;\n\n// Parallel arrays\nconst callbacks: Array = [];\nconst types: Array = [];\nconst timerIDs: Array = [];\nlet reactNativeMicrotasks: Array = [];\nlet requestIdleCallbacks: Array = [];\nconst requestIdleCallbackTimeouts: {[number]: number, ...} = {};\n\nlet GUID = 1;\nconst errors: Array = [];\n\nlet hasEmittedTimeDriftWarning = false;\n\n// Returns a free index if one is available, and the next consecutive index otherwise.\nfunction _getFreeIndex(): number {\n let freeIndex = timerIDs.indexOf(null);\n if (freeIndex === -1) {\n freeIndex = timerIDs.length;\n }\n return freeIndex;\n}\n\nfunction _allocateCallback(func: Function, type: JSTimerType): number {\n const id = GUID++;\n const freeIndex = _getFreeIndex();\n timerIDs[freeIndex] = id;\n callbacks[freeIndex] = func;\n types[freeIndex] = type;\n return id;\n}\n\n/**\n * Calls the callback associated with the ID. Also unregister that callback\n * if it was a one time timer (setTimeout), and not unregister it if it was\n * recurring (setInterval).\n */\nfunction _callTimer(timerID: number, frameTime: number, didTimeout: ?boolean) {\n if (timerID > GUID) {\n console.warn(\n 'Tried to call timer with ID %s but no such timer exists.',\n timerID,\n );\n }\n\n // timerIndex of -1 means that no timer with that ID exists. There are\n // two situations when this happens, when a garbage timer ID was given\n // and when a previously existing timer was deleted before this callback\n // fired. In both cases we want to ignore the timer id, but in the former\n // case we warn as well.\n const timerIndex = timerIDs.indexOf(timerID);\n if (timerIndex === -1) {\n return;\n }\n\n const type = types[timerIndex];\n const callback = callbacks[timerIndex];\n if (!callback || !type) {\n console.error('No callback found for timerID ' + timerID);\n return;\n }\n\n if (__DEV__) {\n Systrace.beginEvent(type + ' [invoke]');\n }\n\n // Clear the metadata\n if (type !== 'setInterval') {\n _clearIndex(timerIndex);\n }\n\n try {\n if (\n type === 'setTimeout' ||\n type === 'setInterval' ||\n type === 'queueReactNativeMicrotask'\n ) {\n callback();\n } else if (type === 'requestAnimationFrame') {\n callback(global.performance.now());\n } else if (type === 'requestIdleCallback') {\n callback({\n timeRemaining: function () {\n // TODO: Optimisation: allow running for longer than one frame if\n // there are no pending JS calls on the bridge from native. This\n // would require a way to check the bridge queue synchronously.\n return Math.max(\n 0,\n FRAME_DURATION - (global.performance.now() - frameTime),\n );\n },\n didTimeout: !!didTimeout,\n });\n } else {\n console.error('Tried to call a callback with invalid type: ' + type);\n }\n } catch (e) {\n // Don't rethrow so that we can run all timers.\n errors.push(e);\n }\n\n if (__DEV__) {\n Systrace.endEvent();\n }\n}\n\n/**\n * Performs a single pass over the enqueued reactNativeMicrotasks. Returns whether\n * more reactNativeMicrotasks are queued up (can be used as a condition a while loop).\n */\nfunction _callReactNativeMicrotasksPass() {\n if (reactNativeMicrotasks.length === 0) {\n return false;\n }\n\n if (__DEV__) {\n Systrace.beginEvent('callReactNativeMicrotasksPass()');\n }\n\n // The main reason to extract a single pass is so that we can track\n // in the system trace\n const passReactNativeMicrotasks = reactNativeMicrotasks;\n reactNativeMicrotasks = [];\n\n // Use for loop rather than forEach as per @vjeux's advice\n // https://github.com/facebook/react-native/commit/c8fd9f7588ad02d2293cac7224715f4af7b0f352#commitcomment-14570051\n for (let i = 0; i < passReactNativeMicrotasks.length; ++i) {\n _callTimer(passReactNativeMicrotasks[i], 0);\n }\n\n if (__DEV__) {\n Systrace.endEvent();\n }\n return reactNativeMicrotasks.length > 0;\n}\n\nfunction _clearIndex(i: number) {\n timerIDs[i] = null;\n callbacks[i] = null;\n types[i] = null;\n}\n\nfunction _freeCallback(timerID: number) {\n // timerIDs contains nulls after timers have been removed;\n // ignore nulls upfront so indexOf doesn't find them\n if (timerID == null) {\n return;\n }\n\n const index = timerIDs.indexOf(timerID);\n // See corresponding comment in `callTimers` for reasoning behind this\n if (index !== -1) {\n const type = types[index];\n _clearIndex(index);\n if (\n type !== 'queueReactNativeMicrotask' &&\n type !== 'requestIdleCallback'\n ) {\n deleteTimer(timerID);\n }\n }\n}\n\n/**\n * JS implementation of timer functions. Must be completely driven by an\n * external clock signal, all that's stored here is timerID, timer type, and\n * callback.\n */\nconst JSTimers = {\n /**\n * @param {function} func Callback to be invoked after `duration` ms.\n * @param {number} duration Number of milliseconds.\n */\n setTimeout: function (\n func: Function,\n duration: number,\n ...args: any\n ): number {\n const id = _allocateCallback(\n () => func.apply(undefined, args),\n 'setTimeout',\n );\n createTimer(id, duration || 0, Date.now(), /* recurring */ false);\n return id;\n },\n\n /**\n * @param {function} func Callback to be invoked every `duration` ms.\n * @param {number} duration Number of milliseconds.\n */\n setInterval: function (\n func: Function,\n duration: number,\n ...args: any\n ): number {\n const id = _allocateCallback(\n () => func.apply(undefined, args),\n 'setInterval',\n );\n createTimer(id, duration || 0, Date.now(), /* recurring */ true);\n return id;\n },\n\n /**\n * The React Native microtask mechanism is used to back public APIs e.g.\n * `queueMicrotask`, `clearImmediate`, and `setImmediate` (which is used by\n * the Promise polyfill) when the JSVM microtask mechanism is not used.\n *\n * @param {function} func Callback to be invoked before the end of the\n * current JavaScript execution loop.\n */\n queueReactNativeMicrotask: function (func: Function, ...args: any): number {\n const id = _allocateCallback(\n () => func.apply(undefined, args),\n 'queueReactNativeMicrotask',\n );\n reactNativeMicrotasks.push(id);\n return id;\n },\n\n /**\n * @param {function} func Callback to be invoked every frame.\n */\n requestAnimationFrame: function (func: Function): any | number {\n const id = _allocateCallback(func, 'requestAnimationFrame');\n createTimer(id, 1, Date.now(), /* recurring */ false);\n return id;\n },\n\n /**\n * @param {function} func Callback to be invoked every frame and provided\n * with time remaining in frame.\n * @param {?object} options\n */\n requestIdleCallback: function (\n func: Function,\n options: ?Object,\n ): any | number {\n if (requestIdleCallbacks.length === 0) {\n setSendIdleEvents(true);\n }\n\n const timeout = options && options.timeout;\n const id: number = _allocateCallback(\n timeout != null\n ? (deadline: any) => {\n const timeoutId: number = requestIdleCallbackTimeouts[id];\n if (timeoutId) {\n JSTimers.clearTimeout(timeoutId);\n delete requestIdleCallbackTimeouts[id];\n }\n return func(deadline);\n }\n : func,\n 'requestIdleCallback',\n );\n requestIdleCallbacks.push(id);\n\n if (timeout != null) {\n const timeoutId: number = JSTimers.setTimeout(() => {\n const index: number = requestIdleCallbacks.indexOf(id);\n if (index > -1) {\n requestIdleCallbacks.splice(index, 1);\n _callTimer(id, global.performance.now(), true);\n }\n delete requestIdleCallbackTimeouts[id];\n if (requestIdleCallbacks.length === 0) {\n setSendIdleEvents(false);\n }\n }, timeout);\n requestIdleCallbackTimeouts[id] = timeoutId;\n }\n return id;\n },\n\n cancelIdleCallback: function (timerID: number) {\n _freeCallback(timerID);\n const index = requestIdleCallbacks.indexOf(timerID);\n if (index !== -1) {\n requestIdleCallbacks.splice(index, 1);\n }\n\n const timeoutId = requestIdleCallbackTimeouts[timerID];\n if (timeoutId) {\n JSTimers.clearTimeout(timeoutId);\n delete requestIdleCallbackTimeouts[timerID];\n }\n\n if (requestIdleCallbacks.length === 0) {\n setSendIdleEvents(false);\n }\n },\n\n clearTimeout: function (timerID: number) {\n _freeCallback(timerID);\n },\n\n clearInterval: function (timerID: number) {\n _freeCallback(timerID);\n },\n\n clearReactNativeMicrotask: function (timerID: number) {\n _freeCallback(timerID);\n const index = reactNativeMicrotasks.indexOf(timerID);\n if (index !== -1) {\n reactNativeMicrotasks.splice(index, 1);\n }\n },\n\n cancelAnimationFrame: function (timerID: number) {\n _freeCallback(timerID);\n },\n\n /**\n * This is called from the native side. We are passed an array of timerIDs,\n * and\n */\n callTimers: function (timersToCall: Array): any | void {\n invariant(\n timersToCall.length !== 0,\n 'Cannot call `callTimers` with an empty list of IDs.',\n );\n\n errors.length = 0;\n for (let i = 0; i < timersToCall.length; i++) {\n _callTimer(timersToCall[i], 0);\n }\n\n const errorCount = errors.length;\n if (errorCount > 0) {\n if (errorCount > 1) {\n // Throw all the other errors in a setTimeout, which will throw each\n // error one at a time\n for (let ii = 1; ii < errorCount; ii++) {\n JSTimers.setTimeout(\n ((error: Error) => {\n throw error;\n }).bind(null, errors[ii]),\n 0,\n );\n }\n }\n throw errors[0];\n }\n },\n\n callIdleCallbacks: function (frameTime: number) {\n if (\n FRAME_DURATION - (global.performance.now() - frameTime) <\n IDLE_CALLBACK_FRAME_DEADLINE\n ) {\n return;\n }\n\n errors.length = 0;\n if (requestIdleCallbacks.length > 0) {\n const passIdleCallbacks = requestIdleCallbacks;\n requestIdleCallbacks = [];\n\n for (let i = 0; i < passIdleCallbacks.length; ++i) {\n _callTimer(passIdleCallbacks[i], frameTime);\n }\n }\n\n if (requestIdleCallbacks.length === 0) {\n setSendIdleEvents(false);\n }\n\n errors.forEach(error =>\n JSTimers.setTimeout(() => {\n throw error;\n }, 0),\n );\n },\n\n /**\n * This is called after we execute any command we receive from native but\n * before we hand control back to native.\n */\n callReactNativeMicrotasks() {\n errors.length = 0;\n while (_callReactNativeMicrotasksPass()) {}\n errors.forEach(error =>\n JSTimers.setTimeout(() => {\n throw error;\n }, 0),\n );\n },\n\n /**\n * Called from native (in development) when environment times are out-of-sync.\n */\n emitTimeDriftWarning(warningMessage: string) {\n if (hasEmittedTimeDriftWarning) {\n return;\n }\n hasEmittedTimeDriftWarning = true;\n console.warn(warningMessage);\n },\n};\n\nfunction createTimer(\n callbackID: number,\n duration: number,\n jsSchedulingTime: number,\n repeats: boolean,\n): void {\n invariant(NativeTiming, 'NativeTiming is available');\n NativeTiming.createTimer(callbackID, duration, jsSchedulingTime, repeats);\n}\n\nfunction deleteTimer(timerID: number): void {\n invariant(NativeTiming, 'NativeTiming is available');\n NativeTiming.deleteTimer(timerID);\n}\n\nfunction setSendIdleEvents(sendIdleEvents: boolean): void {\n invariant(NativeTiming, 'NativeTiming is available');\n NativeTiming.setSendIdleEvents(sendIdleEvents);\n}\n\nlet ExportedJSTimers: {|\n callIdleCallbacks: (frameTime: number) => any | void,\n callReactNativeMicrotasks: () => void,\n callTimers: (timersToCall: Array) => any | void,\n cancelAnimationFrame: (timerID: number) => void,\n cancelIdleCallback: (timerID: number) => void,\n clearReactNativeMicrotask: (timerID: number) => void,\n clearInterval: (timerID: number) => void,\n clearTimeout: (timerID: number) => void,\n emitTimeDriftWarning: (warningMessage: string) => any | void,\n requestAnimationFrame: (func: any) => any | number,\n requestIdleCallback: (func: any, options: ?any) => any | number,\n queueReactNativeMicrotask: (func: any, ...args: any) => number,\n setInterval: (func: any, duration: number, ...args: any) => number,\n setTimeout: (func: any, duration: number, ...args: any) => number,\n|};\n\nif (!NativeTiming) {\n console.warn(\"Timing native module is not available, can't set timers.\");\n // $FlowFixMe[prop-missing] : we can assume timers are generally available\n ExportedJSTimers = ({\n callReactNativeMicrotasks: JSTimers.callReactNativeMicrotasks,\n queueReactNativeMicrotask: JSTimers.queueReactNativeMicrotask,\n }: typeof JSTimers);\n} else {\n ExportedJSTimers = JSTimers;\n}\n\nBatchedBridge.setReactNativeMicrotasksCallback(\n JSTimers.callReactNativeMicrotasks,\n);\n\nmodule.exports = ExportedJSTimers;\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 * @flow strict\n * @format\n */\n\nimport type {TurboModule} from '../../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../../TurboModule/TurboModuleRegistry';\n\nexport interface Spec extends TurboModule {\n +createTimer: (\n callbackID: number,\n duration: number,\n jsSchedulingTime: number,\n repeats: boolean,\n ) => void;\n +deleteTimer: (timerID: number) => void;\n +setSendIdleEvents: (sendIdleEvents: boolean) => void;\n}\n\nexport default (TurboModuleRegistry.get('Timing'): ?Spec);\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 * @format\n * @flow\n */\n\n'use strict';\n\n// Globally Unique Immediate ID.\nlet GUIID = 1;\n\n// A global set of the currently cleared immediates.\nconst clearedImmediates: Set = new Set();\n\n/**\n * Shim the setImmediate API on top of queueMicrotask.\n * @param {function} func Callback to be invoked before the end of the\n * current JavaScript execution loop.\n */\nfunction setImmediate(callback: Function, ...args: any): number {\n if (arguments.length < 1) {\n throw new TypeError(\n 'setImmediate must be called with at least one argument (a function to call)',\n );\n }\n if (typeof callback !== 'function') {\n throw new TypeError(\n 'The first argument to setImmediate must be a function.',\n );\n }\n\n const id = GUIID++;\n // This is an edgey case in which the sequentially assigned ID has been\n // \"guessed\" and \"cleared\" ahead of time, so we need to clear it up first.\n if (clearedImmediates.has(id)) {\n clearedImmediates.delete(id);\n }\n\n global.queueMicrotask(() => {\n if (!clearedImmediates.has(id)) {\n callback.apply(undefined, args);\n } else {\n // Free up the Set entry.\n clearedImmediates.delete(id);\n }\n });\n\n return id;\n}\n\n/**\n * @param {number} immediateID The ID of the immediate to be clearred.\n */\nfunction clearImmediate(immediateID: number) {\n clearedImmediates.add(immediateID);\n}\n\nconst immediateShim = {\n setImmediate: setImmediate,\n clearImmediate: clearImmediate,\n};\n\nmodule.exports = immediateShim;\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 * @format\n * @flow\n */\n\n'use strict';\n\nlet resolvedPromise;\n\n/**\n * Polyfill for the microtask queuening API defined by WHATWG HTMP spec.\n * https://html.spec.whatwg.org/multipage/timers-and-user-prompts.html#dom-queuemicrotask\n *\n * The method must queue a microtask to invoke @param {function} callback, and\n * if the callback throws an exception, report the exception.\n */\nexport default function queueMicrotask(callback: Function) {\n if (arguments.length < 1) {\n throw new TypeError(\n 'queueMicrotask must be called with at least one argument (a function to call)',\n );\n }\n if (typeof callback !== 'function') {\n throw new TypeError('The argument to queueMicrotask must be a function.');\n }\n\n // Try to reuse a lazily allocated resolved promise from closure.\n (resolvedPromise || (resolvedPromise = Promise.resolve()))\n .then(callback)\n .catch(error =>\n // Report the exception until the next tick.\n setTimeout(() => {\n throw error;\n }, 0),\n );\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 * @flow strict-local\n * @format\n */\n\n'use strict';\n\nconst {polyfillGlobal} = require('../Utilities/PolyfillFunctions');\n\n/**\n * Set up XMLHttpRequest. The native XMLHttpRequest in Chrome dev tools is CORS\n * aware and won't let you fetch anything from the internet.\n *\n * You can use this module directly, or just require InitializeCore.\n */\npolyfillGlobal('XMLHttpRequest', () => require('../Network/XMLHttpRequest'));\npolyfillGlobal('FormData', () => require('../Network/FormData'));\n\npolyfillGlobal('fetch', () => require('../Network/fetch').fetch);\npolyfillGlobal('Headers', () => require('../Network/fetch').Headers);\npolyfillGlobal('Request', () => require('../Network/fetch').Request);\npolyfillGlobal('Response', () => require('../Network/fetch').Response);\npolyfillGlobal('WebSocket', () => require('../WebSocket/WebSocket'));\npolyfillGlobal('Blob', () => require('../Blob/Blob'));\npolyfillGlobal('File', () => require('../Blob/File'));\npolyfillGlobal('FileReader', () => require('../Blob/FileReader'));\npolyfillGlobal('URL', () => require('../Blob/URL').URL); // flowlint-line untyped-import:off\npolyfillGlobal('URLSearchParams', () => require('../Blob/URL').URLSearchParams); // flowlint-line untyped-import:off\npolyfillGlobal(\n 'AbortController',\n () => require('abort-controller/dist/abort-controller').AbortController, // flowlint-line untyped-import:off\n);\npolyfillGlobal(\n 'AbortSignal',\n () => require('abort-controller/dist/abort-controller').AbortSignal, // flowlint-line untyped-import:off\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 * @format\n * @flow\n */\n\n'use strict';\n\nimport type {IPerformanceLogger} from '../Utilities/createPerformanceLogger';\n\nimport {type EventSubscription} from '../vendor/emitter/EventEmitter';\n\nconst BlobManager = require('../Blob/BlobManager');\nconst GlobalPerformanceLogger = require('../Utilities/GlobalPerformanceLogger');\nconst RCTNetworking = require('./RCTNetworking');\nconst base64 = require('base64-js');\nconst EventTarget = require('event-target-shim');\nconst invariant = require('invariant');\n\nconst DEBUG_NETWORK_SEND_DELAY: false = false; // Set to a number of milliseconds when debugging\n\nexport type NativeResponseType = 'base64' | 'blob' | 'text';\nexport type ResponseType =\n | ''\n | 'arraybuffer'\n | 'blob'\n | 'document'\n | 'json'\n | 'text';\nexport type Response = ?Object | string;\n\ntype XHRInterceptor = interface {\n requestSent(id: number, url: string, method: string, headers: Object): void,\n responseReceived(\n id: number,\n url: string,\n status: number,\n headers: Object,\n ): void,\n dataReceived(id: number, data: string): void,\n loadingFinished(id: number, encodedDataLength: number): void,\n loadingFailed(id: number, error: string): void,\n};\n\n// The native blob module is optional so inject it here if available.\nif (BlobManager.isAvailable) {\n BlobManager.addNetworkingHandler();\n}\n\nconst UNSENT = 0;\nconst OPENED = 1;\nconst HEADERS_RECEIVED = 2;\nconst LOADING = 3;\nconst DONE = 4;\n\nconst SUPPORTED_RESPONSE_TYPES = {\n arraybuffer: typeof global.ArrayBuffer === 'function',\n blob: typeof global.Blob === 'function',\n document: false,\n json: true,\n text: true,\n '': true,\n};\n\nconst REQUEST_EVENTS = [\n 'abort',\n 'error',\n 'load',\n 'loadstart',\n 'progress',\n 'timeout',\n 'loadend',\n];\n\nconst XHR_EVENTS = REQUEST_EVENTS.concat('readystatechange');\n\nclass XMLHttpRequestEventTarget extends (EventTarget(...REQUEST_EVENTS): any) {\n onload: ?Function;\n onloadstart: ?Function;\n onprogress: ?Function;\n ontimeout: ?Function;\n onerror: ?Function;\n onabort: ?Function;\n onloadend: ?Function;\n}\n\n/**\n * Shared base for platform-specific XMLHttpRequest implementations.\n */\nclass XMLHttpRequest extends (EventTarget(...XHR_EVENTS): any) {\n static UNSENT: number = UNSENT;\n static OPENED: number = OPENED;\n static HEADERS_RECEIVED: number = HEADERS_RECEIVED;\n static LOADING: number = LOADING;\n static DONE: number = DONE;\n\n static _interceptor: ?XHRInterceptor = null;\n\n UNSENT: number = UNSENT;\n OPENED: number = OPENED;\n HEADERS_RECEIVED: number = HEADERS_RECEIVED;\n LOADING: number = LOADING;\n DONE: number = DONE;\n\n // EventTarget automatically initializes these to `null`.\n onload: ?Function;\n onloadstart: ?Function;\n onprogress: ?Function;\n ontimeout: ?Function;\n onerror: ?Function;\n onabort: ?Function;\n onloadend: ?Function;\n onreadystatechange: ?Function;\n\n readyState: number = UNSENT;\n responseHeaders: ?Object;\n status: number = 0;\n timeout: number = 0;\n responseURL: ?string;\n withCredentials: boolean = true;\n\n upload: XMLHttpRequestEventTarget = new XMLHttpRequestEventTarget();\n\n _requestId: ?number;\n _subscriptions: Array;\n\n _aborted: boolean = false;\n _cachedResponse: Response;\n _hasError: boolean = false;\n _headers: Object;\n _lowerCaseResponseHeaders: Object;\n _method: ?string = null;\n _perfKey: ?string = null;\n _responseType: ResponseType;\n _response: string = '';\n _sent: boolean;\n _url: ?string = null;\n _timedOut: boolean = false;\n _trackingName: string = 'unknown';\n _incrementalEvents: boolean = false;\n _performanceLogger: IPerformanceLogger = GlobalPerformanceLogger;\n\n static setInterceptor(interceptor: ?XHRInterceptor) {\n XMLHttpRequest._interceptor = interceptor;\n }\n\n constructor() {\n super();\n this._reset();\n }\n\n _reset(): void {\n this.readyState = this.UNSENT;\n this.responseHeaders = undefined;\n this.status = 0;\n delete this.responseURL;\n\n this._requestId = null;\n\n this._cachedResponse = undefined;\n this._hasError = false;\n this._headers = {};\n this._response = '';\n this._responseType = '';\n this._sent = false;\n this._lowerCaseResponseHeaders = {};\n\n this._clearSubscriptions();\n this._timedOut = false;\n }\n\n get responseType(): ResponseType {\n return this._responseType;\n }\n\n set responseType(responseType: ResponseType): void {\n if (this._sent) {\n throw new Error(\n \"Failed to set the 'responseType' property on 'XMLHttpRequest': The \" +\n 'response type cannot be set after the request has been sent.',\n );\n }\n if (!SUPPORTED_RESPONSE_TYPES.hasOwnProperty(responseType)) {\n console.warn(\n `The provided value '${responseType}' is not a valid 'responseType'.`,\n );\n return;\n }\n\n // redboxes early, e.g. for 'arraybuffer' on ios 7\n invariant(\n SUPPORTED_RESPONSE_TYPES[responseType] || responseType === 'document',\n `The provided value '${responseType}' is unsupported in this environment.`,\n );\n\n if (responseType === 'blob') {\n invariant(\n BlobManager.isAvailable,\n 'Native module BlobModule is required for blob support',\n );\n }\n this._responseType = responseType;\n }\n\n get responseText(): string {\n if (this._responseType !== '' && this._responseType !== 'text') {\n throw new Error(\n \"The 'responseText' property is only available if 'responseType' \" +\n `is set to '' or 'text', but it is '${this._responseType}'.`,\n );\n }\n if (this.readyState < LOADING) {\n return '';\n }\n return this._response;\n }\n\n get response(): Response {\n const {responseType} = this;\n if (responseType === '' || responseType === 'text') {\n return this.readyState < LOADING || this._hasError ? '' : this._response;\n }\n\n if (this.readyState !== DONE) {\n return null;\n }\n\n if (this._cachedResponse !== undefined) {\n return this._cachedResponse;\n }\n\n switch (responseType) {\n case 'document':\n this._cachedResponse = null;\n break;\n\n case 'arraybuffer':\n this._cachedResponse = base64.toByteArray(this._response).buffer;\n break;\n\n case 'blob':\n if (typeof this._response === 'object' && this._response) {\n this._cachedResponse = BlobManager.createFromOptions(this._response);\n } else if (this._response === '') {\n this._cachedResponse = BlobManager.createFromParts([]);\n } else {\n throw new Error(`Invalid response for blob: ${this._response}`);\n }\n break;\n\n case 'json':\n try {\n this._cachedResponse = JSON.parse(this._response);\n } catch (_) {\n this._cachedResponse = null;\n }\n break;\n\n default:\n this._cachedResponse = null;\n }\n\n return this._cachedResponse;\n }\n\n // exposed for testing\n __didCreateRequest(requestId: number): void {\n this._requestId = requestId;\n\n XMLHttpRequest._interceptor &&\n XMLHttpRequest._interceptor.requestSent(\n requestId,\n this._url || '',\n this._method || 'GET',\n this._headers,\n );\n }\n\n // exposed for testing\n __didUploadProgress(\n requestId: number,\n progress: number,\n total: number,\n ): void {\n if (requestId === this._requestId) {\n this.upload.dispatchEvent({\n type: 'progress',\n lengthComputable: true,\n loaded: progress,\n total,\n });\n }\n }\n\n __didReceiveResponse(\n requestId: number,\n status: number,\n responseHeaders: ?Object,\n responseURL: ?string,\n ): void {\n if (requestId === this._requestId) {\n this._perfKey != null &&\n this._performanceLogger.stopTimespan(this._perfKey);\n this.status = status;\n this.setResponseHeaders(responseHeaders);\n this.setReadyState(this.HEADERS_RECEIVED);\n if (responseURL || responseURL === '') {\n this.responseURL = responseURL;\n } else {\n delete this.responseURL;\n }\n\n XMLHttpRequest._interceptor &&\n XMLHttpRequest._interceptor.responseReceived(\n requestId,\n responseURL || this._url || '',\n status,\n responseHeaders || {},\n );\n }\n }\n\n __didReceiveData(requestId: number, response: string): void {\n if (requestId !== this._requestId) {\n return;\n }\n this._response = response;\n this._cachedResponse = undefined; // force lazy recomputation\n this.setReadyState(this.LOADING);\n\n XMLHttpRequest._interceptor &&\n XMLHttpRequest._interceptor.dataReceived(requestId, response);\n }\n\n __didReceiveIncrementalData(\n requestId: number,\n responseText: string,\n progress: number,\n total: number,\n ) {\n if (requestId !== this._requestId) {\n return;\n }\n if (!this._response) {\n this._response = responseText;\n } else {\n this._response += responseText;\n }\n\n XMLHttpRequest._interceptor &&\n XMLHttpRequest._interceptor.dataReceived(requestId, responseText);\n\n this.setReadyState(this.LOADING);\n this.__didReceiveDataProgress(requestId, progress, total);\n }\n\n __didReceiveDataProgress(\n requestId: number,\n loaded: number,\n total: number,\n ): void {\n if (requestId !== this._requestId) {\n return;\n }\n this.dispatchEvent({\n type: 'progress',\n lengthComputable: total >= 0,\n loaded,\n total,\n });\n }\n\n // exposed for testing\n __didCompleteResponse(\n requestId: number,\n error: string,\n timeOutError: boolean,\n ): void {\n if (requestId === this._requestId) {\n if (error) {\n if (this._responseType === '' || this._responseType === 'text') {\n this._response = error;\n }\n this._hasError = true;\n if (timeOutError) {\n this._timedOut = true;\n }\n }\n this._clearSubscriptions();\n this._requestId = null;\n this.setReadyState(this.DONE);\n\n if (error) {\n XMLHttpRequest._interceptor &&\n XMLHttpRequest._interceptor.loadingFailed(requestId, error);\n } else {\n XMLHttpRequest._interceptor &&\n XMLHttpRequest._interceptor.loadingFinished(\n requestId,\n this._response.length,\n );\n }\n }\n }\n\n _clearSubscriptions(): void {\n (this._subscriptions || []).forEach(sub => {\n if (sub) {\n sub.remove();\n }\n });\n this._subscriptions = [];\n }\n\n getAllResponseHeaders(): ?string {\n if (!this.responseHeaders) {\n // according to the spec, return null if no response has been received\n return null;\n }\n\n // Assign to non-nullable local variable.\n const responseHeaders = this.responseHeaders;\n\n const unsortedHeaders: Map<\n string,\n {lowerHeaderName: string, upperHeaderName: string, headerValue: string},\n > = new Map();\n for (const rawHeaderName of Object.keys(responseHeaders)) {\n const headerValue = responseHeaders[rawHeaderName];\n const lowerHeaderName = rawHeaderName.toLowerCase();\n const header = unsortedHeaders.get(lowerHeaderName);\n if (header) {\n header.headerValue += ', ' + headerValue;\n unsortedHeaders.set(lowerHeaderName, header);\n } else {\n unsortedHeaders.set(lowerHeaderName, {\n lowerHeaderName,\n upperHeaderName: rawHeaderName.toUpperCase(),\n headerValue,\n });\n }\n }\n\n // Sort in ascending order, with a being less than b if a's name is legacy-uppercased-byte less than b's name.\n const sortedHeaders = [...unsortedHeaders.values()].sort((a, b) => {\n if (a.upperHeaderName < b.upperHeaderName) {\n return -1;\n }\n if (a.upperHeaderName > b.upperHeaderName) {\n return 1;\n }\n return 0;\n });\n\n // Combine into single text response.\n return (\n sortedHeaders\n .map(header => {\n return header.lowerHeaderName + ': ' + header.headerValue;\n })\n .join('\\r\\n') + '\\r\\n'\n );\n }\n\n getResponseHeader(header: string): ?string {\n const value = this._lowerCaseResponseHeaders[header.toLowerCase()];\n return value !== undefined ? value : null;\n }\n\n setRequestHeader(header: string, value: any): void {\n if (this.readyState !== this.OPENED) {\n throw new Error('Request has not been opened');\n }\n this._headers[header.toLowerCase()] = String(value);\n }\n\n /**\n * Custom extension for tracking origins of request.\n */\n setTrackingName(trackingName: string): XMLHttpRequest {\n this._trackingName = trackingName;\n return this;\n }\n\n /**\n * Custom extension for setting a custom performance logger\n */\n setPerformanceLogger(performanceLogger: IPerformanceLogger): XMLHttpRequest {\n this._performanceLogger = performanceLogger;\n return this;\n }\n\n open(method: string, url: string, async: ?boolean): void {\n /* Other optional arguments are not supported yet */\n if (this.readyState !== this.UNSENT) {\n throw new Error('Cannot open, already sending');\n }\n if (async !== undefined && !async) {\n // async is default\n throw new Error('Synchronous http requests are not supported');\n }\n if (!url) {\n throw new Error('Cannot load an empty url');\n }\n this._method = method.toUpperCase();\n this._url = url;\n this._aborted = false;\n this.setReadyState(this.OPENED);\n }\n\n send(data: any): void {\n if (this.readyState !== this.OPENED) {\n throw new Error('Request has not been opened');\n }\n if (this._sent) {\n throw new Error('Request has already been sent');\n }\n this._sent = true;\n const incrementalEvents =\n this._incrementalEvents || !!this.onreadystatechange || !!this.onprogress;\n\n this._subscriptions.push(\n RCTNetworking.addListener('didSendNetworkData', args =>\n this.__didUploadProgress(...args),\n ),\n );\n this._subscriptions.push(\n RCTNetworking.addListener('didReceiveNetworkResponse', args =>\n this.__didReceiveResponse(...args),\n ),\n );\n this._subscriptions.push(\n RCTNetworking.addListener('didReceiveNetworkData', args =>\n this.__didReceiveData(...args),\n ),\n );\n this._subscriptions.push(\n RCTNetworking.addListener('didReceiveNetworkIncrementalData', args =>\n this.__didReceiveIncrementalData(...args),\n ),\n );\n this._subscriptions.push(\n RCTNetworking.addListener('didReceiveNetworkDataProgress', args =>\n this.__didReceiveDataProgress(...args),\n ),\n );\n this._subscriptions.push(\n RCTNetworking.addListener('didCompleteNetworkResponse', args =>\n this.__didCompleteResponse(...args),\n ),\n );\n\n let nativeResponseType: NativeResponseType = 'text';\n if (this._responseType === 'arraybuffer') {\n nativeResponseType = 'base64';\n }\n if (this._responseType === 'blob') {\n nativeResponseType = 'blob';\n }\n\n const doSend = () => {\n const friendlyName =\n this._trackingName !== 'unknown' ? this._trackingName : this._url;\n this._perfKey = 'network_XMLHttpRequest_' + String(friendlyName);\n this._performanceLogger.startTimespan(this._perfKey);\n invariant(\n this._method,\n 'XMLHttpRequest method needs to be defined (%s).',\n friendlyName,\n );\n invariant(\n this._url,\n 'XMLHttpRequest URL needs to be defined (%s).',\n friendlyName,\n );\n RCTNetworking.sendRequest(\n this._method,\n this._trackingName,\n this._url,\n this._headers,\n data,\n /* $FlowFixMe(>=0.78.0 site=react_native_android_fb) This issue was found\n * when making Flow check .android.js files. */\n nativeResponseType,\n incrementalEvents,\n this.timeout,\n // $FlowFixMe[method-unbinding] added when improving typing for this parameters\n this.__didCreateRequest.bind(this),\n this.withCredentials,\n );\n };\n if (DEBUG_NETWORK_SEND_DELAY) {\n setTimeout(doSend, DEBUG_NETWORK_SEND_DELAY);\n } else {\n doSend();\n }\n }\n\n abort(): void {\n this._aborted = true;\n if (this._requestId) {\n RCTNetworking.abortRequest(this._requestId);\n }\n // only call onreadystatechange if there is something to abort,\n // below logic is per spec\n if (\n !(\n this.readyState === this.UNSENT ||\n (this.readyState === this.OPENED && !this._sent) ||\n this.readyState === this.DONE\n )\n ) {\n this._reset();\n this.setReadyState(this.DONE);\n }\n // Reset again after, in case modified in handler\n this._reset();\n }\n\n setResponseHeaders(responseHeaders: ?Object): void {\n this.responseHeaders = responseHeaders || null;\n const headers = responseHeaders || {};\n this._lowerCaseResponseHeaders = Object.keys(headers).reduce<{\n [string]: any,\n }>((lcaseHeaders, headerName) => {\n lcaseHeaders[headerName.toLowerCase()] = headers[headerName];\n return lcaseHeaders;\n }, {});\n }\n\n setReadyState(newState: number): void {\n this.readyState = newState;\n this.dispatchEvent({type: 'readystatechange'});\n if (newState === this.DONE) {\n if (this._aborted) {\n this.dispatchEvent({type: 'abort'});\n } else if (this._hasError) {\n if (this._timedOut) {\n this.dispatchEvent({type: 'timeout'});\n } else {\n this.dispatchEvent({type: 'error'});\n }\n } else {\n this.dispatchEvent({type: 'load'});\n }\n this.dispatchEvent({type: 'loadend'});\n }\n }\n\n /* global EventListener */\n addEventListener(type: string, listener: EventListener): void {\n // If we dont' have a 'readystatechange' event handler, we don't\n // have to send repeated LOADING events with incremental updates\n // to responseText, which will avoid a bunch of native -> JS\n // bridge traffic.\n if (type === 'readystatechange' || type === 'progress') {\n this._incrementalEvents = true;\n }\n super.addEventListener(type, listener);\n }\n}\n\nmodule.exports = XMLHttpRequest;\n","var superPropBase = require(\"./superPropBase.js\");\n\nfunction _get() {\n if (typeof Reflect !== \"undefined\" && Reflect.get) {\n module.exports = _get = Reflect.get.bind(), module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n } else {\n module.exports = _get = function _get(target, property, receiver) {\n var base = superPropBase(target, property);\n if (!base) return;\n var desc = Object.getOwnPropertyDescriptor(base, property);\n\n if (desc.get) {\n return desc.get.call(arguments.length < 3 ? target : receiver);\n }\n\n return desc.value;\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n }\n\n return _get.apply(this, arguments);\n}\n\nmodule.exports = _get, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var getPrototypeOf = require(\"./getPrototypeOf.js\");\n\nfunction _superPropBase(object, property) {\n while (!Object.prototype.hasOwnProperty.call(object, property)) {\n object = getPrototypeOf(object);\n if (object === null) break;\n }\n\n return object;\n}\n\nmodule.exports = _superPropBase, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","/**\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 * @flow strict-local\n * @format\n */\n\nimport type {BlobCollector, BlobData, BlobOptions} from './BlobTypes';\n\nimport NativeBlobModule from './NativeBlobModule';\nimport invariant from 'invariant';\n\nconst Blob = require('./Blob');\nconst BlobRegistry = require('./BlobRegistry');\n\n/*eslint-disable no-bitwise */\n/*eslint-disable eqeqeq */\n\n/**\n * Based on the rfc4122-compliant solution posted at\n * http://stackoverflow.com/questions/105034\n */\nfunction uuidv4(): string {\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\n// **Temporary workaround**\n// TODO(#24654): Use turbomodules for the Blob module.\n// Blob collector is a jsi::HostObject that is used by native to know\n// when the a Blob instance is deallocated. This allows to free the\n// underlying native resources. This is a hack to workaround the fact\n// that the current bridge infra doesn't allow to track js objects\n// deallocation. Ideally the whole Blob object should be a jsi::HostObject.\nfunction createBlobCollector(blobId: string): BlobCollector | null {\n if (global.__blobCollectorProvider == null) {\n return null;\n } else {\n return global.__blobCollectorProvider(blobId);\n }\n}\n\n/**\n * Module to manage blobs. Wrapper around the native blob module.\n */\nclass BlobManager {\n /**\n * If the native blob module is available.\n */\n static isAvailable: boolean = !!NativeBlobModule;\n\n /**\n * Create blob from existing array of blobs.\n */\n static createFromParts(\n parts: Array,\n options?: BlobOptions,\n ): Blob {\n invariant(NativeBlobModule, 'NativeBlobModule is available.');\n\n const blobId = uuidv4();\n const items = parts.map(part => {\n if (\n part instanceof ArrayBuffer ||\n (global.ArrayBufferView && part instanceof global.ArrayBufferView)\n ) {\n throw new Error(\n \"Creating blobs from 'ArrayBuffer' and 'ArrayBufferView' are not supported\",\n );\n }\n if (part instanceof Blob) {\n return {\n data: part.data,\n type: 'blob',\n };\n } else {\n return {\n data: String(part),\n type: 'string',\n };\n }\n });\n const size = items.reduce((acc, curr) => {\n if (curr.type === 'string') {\n return acc + global.unescape(encodeURI(curr.data)).length;\n } else {\n return acc + curr.data.size;\n }\n }, 0);\n\n NativeBlobModule.createFromParts(items, blobId);\n\n return BlobManager.createFromOptions({\n blobId,\n offset: 0,\n size,\n type: options ? options.type : '',\n lastModified: options ? options.lastModified : Date.now(),\n });\n }\n\n /**\n * Create blob instance from blob data from native.\n * Used internally by modules like XHR, WebSocket, etc.\n */\n static createFromOptions(options: BlobData): Blob {\n BlobRegistry.register(options.blobId);\n // $FlowFixMe[prop-missing]\n return Object.assign(Object.create(Blob.prototype), {\n data:\n // Reuse the collector instance when creating from an existing blob.\n // This will make sure that the underlying resource is only deallocated\n // when all blobs that refer to it are deallocated.\n options.__collector == null\n ? {\n ...options,\n __collector: createBlobCollector(options.blobId),\n }\n : options,\n });\n }\n\n /**\n * Deallocate resources for a blob.\n */\n static release(blobId: string): void {\n invariant(NativeBlobModule, 'NativeBlobModule is available.');\n\n BlobRegistry.unregister(blobId);\n if (BlobRegistry.has(blobId)) {\n return;\n }\n NativeBlobModule.release(blobId);\n }\n\n /**\n * Inject the blob content handler in the networking module to support blob\n * requests and responses.\n */\n static addNetworkingHandler(): void {\n invariant(NativeBlobModule, 'NativeBlobModule is available.');\n\n NativeBlobModule.addNetworkingHandler();\n }\n\n /**\n * Indicate the websocket should return a blob for incoming binary\n * messages.\n */\n static addWebSocketHandler(socketId: number): void {\n invariant(NativeBlobModule, 'NativeBlobModule is available.');\n\n NativeBlobModule.addWebSocketHandler(socketId);\n }\n\n /**\n * Indicate the websocket should no longer return a blob for incoming\n * binary messages.\n */\n static removeWebSocketHandler(socketId: number): void {\n invariant(NativeBlobModule, 'NativeBlobModule is available.');\n\n NativeBlobModule.removeWebSocketHandler(socketId);\n }\n\n /**\n * Send a blob message to a websocket.\n */\n static sendOverSocket(blob: Blob, socketId: number): void {\n invariant(NativeBlobModule, 'NativeBlobModule is available.');\n\n NativeBlobModule.sendOverSocket(blob.data, socketId);\n }\n}\n\nmodule.exports = BlobManager;\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 * @flow\n * @format\n */\n\nimport type {TurboModule} from '../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../TurboModule/TurboModuleRegistry';\n\nexport interface Spec extends TurboModule {\n +getConstants: () => {|BLOB_URI_SCHEME: ?string, BLOB_URI_HOST: ?string|};\n +addNetworkingHandler: () => void;\n +addWebSocketHandler: (id: number) => void;\n +removeWebSocketHandler: (id: number) => void;\n +sendOverSocket: (blob: Object, socketID: number) => void;\n +createFromParts: (parts: Array, withId: string) => void;\n +release: (blobId: string) => void;\n}\n\nconst NativeModule = TurboModuleRegistry.get('BlobModule');\n\nlet constants = null;\nlet NativeBlobModule = null;\n\nif (NativeModule != null) {\n NativeBlobModule = {\n getConstants(): {|BLOB_URI_SCHEME: ?string, BLOB_URI_HOST: ?string|} {\n if (constants == null) {\n constants = NativeModule.getConstants();\n }\n return constants;\n },\n addNetworkingHandler(): void {\n NativeModule.addNetworkingHandler();\n },\n addWebSocketHandler(id: number): void {\n NativeModule.addWebSocketHandler(id);\n },\n removeWebSocketHandler(id: number): void {\n NativeModule.removeWebSocketHandler(id);\n },\n sendOverSocket(blob: Object, socketID: number): void {\n NativeModule.sendOverSocket(blob, socketID);\n },\n createFromParts(parts: Array, withId: string): void {\n NativeModule.createFromParts(parts, withId);\n },\n release(blobId: string): void {\n NativeModule.release(blobId);\n },\n };\n}\n\nexport default (NativeBlobModule: ?Spec);\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 * @flow strict-local\n * @format\n */\n\n'use strict';\n\nimport type {BlobData, BlobOptions} from './BlobTypes';\n\n/**\n * Opaque JS representation of some binary data in native.\n *\n * The API is modeled after the W3C Blob API, with one caveat\n * regarding explicit deallocation. Refer to the `close()`\n * method for further details.\n *\n * Example usage in a React component:\n *\n * class WebSocketImage extends React.Component {\n * state = {blob: null};\n * componentDidMount() {\n * let ws = this.ws = new WebSocket(...);\n * ws.binaryType = 'blob';\n * ws.onmessage = (event) => {\n * if (this.state.blob) {\n * this.state.blob.close();\n * }\n * this.setState({blob: event.data});\n * };\n * }\n * componentUnmount() {\n * if (this.state.blob) {\n * this.state.blob.close();\n * }\n * this.ws.close();\n * }\n * render() {\n * if (!this.state.blob) {\n * return ;\n * }\n * return ;\n * }\n * }\n *\n * Reference: https://developer.mozilla.org/en-US/docs/Web/API/Blob\n */\nclass Blob {\n _data: ?BlobData;\n\n /**\n * Constructor for JS consumers.\n * Currently we only support creating Blobs from other Blobs.\n * Reference: https://developer.mozilla.org/en-US/docs/Web/API/Blob/Blob\n */\n constructor(parts: Array = [], options?: BlobOptions) {\n const BlobManager = require('./BlobManager');\n this.data = BlobManager.createFromParts(parts, options).data;\n }\n\n /*\n * This method is used to create a new Blob object containing\n * the data in the specified range of bytes of the source Blob.\n * Reference: https://developer.mozilla.org/en-US/docs/Web/API/Blob/slice\n */\n // $FlowFixMe[unsafe-getters-setters]\n set data(data: ?BlobData) {\n this._data = data;\n }\n\n // $FlowFixMe[unsafe-getters-setters]\n get data(): BlobData {\n if (!this._data) {\n throw new Error('Blob has been closed and is no longer available');\n }\n\n return this._data;\n }\n\n slice(start?: number, end?: number): Blob {\n const BlobManager = require('./BlobManager');\n let {offset, size} = this.data;\n\n if (typeof start === 'number') {\n if (start > size) {\n // $FlowFixMe[reassign-const]\n start = size;\n }\n offset += start;\n size -= start;\n\n if (typeof end === 'number') {\n if (end < 0) {\n // $FlowFixMe[reassign-const]\n end = this.size + end;\n }\n size = end - start;\n }\n }\n return BlobManager.createFromOptions({\n blobId: this.data.blobId,\n offset,\n size,\n });\n }\n\n /**\n * This method is in the standard, but not actually implemented by\n * any browsers at this point. It's important for how Blobs work in\n * React Native, however, since we cannot de-allocate resources automatically,\n * so consumers need to explicitly de-allocate them.\n *\n * Note that the semantics around Blobs created via `blob.slice()`\n * and `new Blob([blob])` are different. `blob.slice()` creates a\n * new *view* onto the same binary data, so calling `close()` on any\n * of those views is enough to deallocate the data, whereas\n * `new Blob([blob, ...])` actually copies the data in memory.\n */\n close() {\n const BlobManager = require('./BlobManager');\n BlobManager.release(this.data.blobId);\n this.data = null;\n }\n\n /**\n * Size of the data contained in the Blob object, in bytes.\n */\n // $FlowFixMe[unsafe-getters-setters]\n get size(): number {\n return this.data.size;\n }\n\n /*\n * String indicating the MIME type of the data contained in the Blob.\n * If the type is unknown, this string is empty.\n */\n // $FlowFixMe[unsafe-getters-setters]\n get type(): string {\n return this.data.type || '';\n }\n}\n\nmodule.exports = Blob;\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 * @flow strict\n * @format\n */\n\nconst registry: {[key: string]: number, ...} = {};\n\nconst register = (id: string) => {\n if (registry[id]) {\n registry[id]++;\n } else {\n registry[id] = 1;\n }\n};\n\nconst unregister = (id: string) => {\n if (registry[id]) {\n registry[id]--;\n if (registry[id] <= 0) {\n delete registry[id];\n }\n }\n};\n\nconst has = (id: string): number | boolean => {\n return registry[id] && registry[id] > 0;\n};\n\nmodule.exports = {\n register,\n unregister,\n has,\n};\n","/**\n * @author Toru Nagashima \n * @copyright 2015 Toru Nagashima. All rights reserved.\n * See LICENSE file in root directory for full license.\n */\n'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\n/**\n * @typedef {object} PrivateData\n * @property {EventTarget} eventTarget The event target.\n * @property {{type:string}} event The original event object.\n * @property {number} eventPhase The current event phase.\n * @property {EventTarget|null} currentTarget The current event target.\n * @property {boolean} canceled The flag to prevent default.\n * @property {boolean} stopped The flag to stop propagation.\n * @property {boolean} immediateStopped The flag to stop propagation immediately.\n * @property {Function|null} passiveListener The listener if the current listener is passive. Otherwise this is null.\n * @property {number} timeStamp The unix time.\n * @private\n */\n\n/**\n * Private data for event wrappers.\n * @type {WeakMap}\n * @private\n */\nconst privateData = new WeakMap();\n\n/**\n * Cache for wrapper classes.\n * @type {WeakMap}\n * @private\n */\nconst wrappers = new WeakMap();\n\n/**\n * Get private data.\n * @param {Event} event The event object to get private data.\n * @returns {PrivateData} The private data of the event.\n * @private\n */\nfunction pd(event) {\n const retv = privateData.get(event);\n console.assert(\n retv != null,\n \"'this' is expected an Event object, but got\",\n event\n );\n return retv\n}\n\n/**\n * https://dom.spec.whatwg.org/#set-the-canceled-flag\n * @param data {PrivateData} private data.\n */\nfunction setCancelFlag(data) {\n if (data.passiveListener != null) {\n if (\n typeof console !== \"undefined\" &&\n typeof console.error === \"function\"\n ) {\n console.error(\n \"Unable to preventDefault inside passive event listener invocation.\",\n data.passiveListener\n );\n }\n return\n }\n if (!data.event.cancelable) {\n return\n }\n\n data.canceled = true;\n if (typeof data.event.preventDefault === \"function\") {\n data.event.preventDefault();\n }\n}\n\n/**\n * @see https://dom.spec.whatwg.org/#interface-event\n * @private\n */\n/**\n * The event wrapper.\n * @constructor\n * @param {EventTarget} eventTarget The event target of this dispatching.\n * @param {Event|{type:string}} event The original event to wrap.\n */\nfunction Event(eventTarget, event) {\n privateData.set(this, {\n eventTarget,\n event,\n eventPhase: 2,\n currentTarget: eventTarget,\n canceled: false,\n stopped: false,\n immediateStopped: false,\n passiveListener: null,\n timeStamp: event.timeStamp || Date.now(),\n });\n\n // https://heycam.github.io/webidl/#Unforgeable\n Object.defineProperty(this, \"isTrusted\", { value: false, enumerable: true });\n\n // Define accessors\n const keys = Object.keys(event);\n for (let i = 0; i < keys.length; ++i) {\n const key = keys[i];\n if (!(key in this)) {\n Object.defineProperty(this, key, defineRedirectDescriptor(key));\n }\n }\n}\n\n// Should be enumerable, but class methods are not enumerable.\nEvent.prototype = {\n /**\n * The type of this event.\n * @type {string}\n */\n get type() {\n return pd(this).event.type\n },\n\n /**\n * The target of this event.\n * @type {EventTarget}\n */\n get target() {\n return pd(this).eventTarget\n },\n\n /**\n * The target of this event.\n * @type {EventTarget}\n */\n get currentTarget() {\n return pd(this).currentTarget\n },\n\n /**\n * @returns {EventTarget[]} The composed path of this event.\n */\n composedPath() {\n const currentTarget = pd(this).currentTarget;\n if (currentTarget == null) {\n return []\n }\n return [currentTarget]\n },\n\n /**\n * Constant of NONE.\n * @type {number}\n */\n get NONE() {\n return 0\n },\n\n /**\n * Constant of CAPTURING_PHASE.\n * @type {number}\n */\n get CAPTURING_PHASE() {\n return 1\n },\n\n /**\n * Constant of AT_TARGET.\n * @type {number}\n */\n get AT_TARGET() {\n return 2\n },\n\n /**\n * Constant of BUBBLING_PHASE.\n * @type {number}\n */\n get BUBBLING_PHASE() {\n return 3\n },\n\n /**\n * The target of this event.\n * @type {number}\n */\n get eventPhase() {\n return pd(this).eventPhase\n },\n\n /**\n * Stop event bubbling.\n * @returns {void}\n */\n stopPropagation() {\n const data = pd(this);\n\n data.stopped = true;\n if (typeof data.event.stopPropagation === \"function\") {\n data.event.stopPropagation();\n }\n },\n\n /**\n * Stop event bubbling.\n * @returns {void}\n */\n stopImmediatePropagation() {\n const data = pd(this);\n\n data.stopped = true;\n data.immediateStopped = true;\n if (typeof data.event.stopImmediatePropagation === \"function\") {\n data.event.stopImmediatePropagation();\n }\n },\n\n /**\n * The flag to be bubbling.\n * @type {boolean}\n */\n get bubbles() {\n return Boolean(pd(this).event.bubbles)\n },\n\n /**\n * The flag to be cancelable.\n * @type {boolean}\n */\n get cancelable() {\n return Boolean(pd(this).event.cancelable)\n },\n\n /**\n * Cancel this event.\n * @returns {void}\n */\n preventDefault() {\n setCancelFlag(pd(this));\n },\n\n /**\n * The flag to indicate cancellation state.\n * @type {boolean}\n */\n get defaultPrevented() {\n return pd(this).canceled\n },\n\n /**\n * The flag to be composed.\n * @type {boolean}\n */\n get composed() {\n return Boolean(pd(this).event.composed)\n },\n\n /**\n * The unix time of this event.\n * @type {number}\n */\n get timeStamp() {\n return pd(this).timeStamp\n },\n\n /**\n * The target of this event.\n * @type {EventTarget}\n * @deprecated\n */\n get srcElement() {\n return pd(this).eventTarget\n },\n\n /**\n * The flag to stop event bubbling.\n * @type {boolean}\n * @deprecated\n */\n get cancelBubble() {\n return pd(this).stopped\n },\n set cancelBubble(value) {\n if (!value) {\n return\n }\n const data = pd(this);\n\n data.stopped = true;\n if (typeof data.event.cancelBubble === \"boolean\") {\n data.event.cancelBubble = true;\n }\n },\n\n /**\n * The flag to indicate cancellation state.\n * @type {boolean}\n * @deprecated\n */\n get returnValue() {\n return !pd(this).canceled\n },\n set returnValue(value) {\n if (!value) {\n setCancelFlag(pd(this));\n }\n },\n\n /**\n * Initialize this event object. But do nothing under event dispatching.\n * @param {string} type The event type.\n * @param {boolean} [bubbles=false] The flag to be possible to bubble up.\n * @param {boolean} [cancelable=false] The flag to be possible to cancel.\n * @deprecated\n */\n initEvent() {\n // Do nothing.\n },\n};\n\n// `constructor` is not enumerable.\nObject.defineProperty(Event.prototype, \"constructor\", {\n value: Event,\n configurable: true,\n writable: true,\n});\n\n// Ensure `event instanceof window.Event` is `true`.\nif (typeof window !== \"undefined\" && typeof window.Event !== \"undefined\") {\n Object.setPrototypeOf(Event.prototype, window.Event.prototype);\n\n // Make association for wrappers.\n wrappers.set(window.Event.prototype, Event);\n}\n\n/**\n * Get the property descriptor to redirect a given property.\n * @param {string} key Property name to define property descriptor.\n * @returns {PropertyDescriptor} The property descriptor to redirect the property.\n * @private\n */\nfunction defineRedirectDescriptor(key) {\n return {\n get() {\n return pd(this).event[key]\n },\n set(value) {\n pd(this).event[key] = value;\n },\n configurable: true,\n enumerable: true,\n }\n}\n\n/**\n * Get the property descriptor to call a given method property.\n * @param {string} key Property name to define property descriptor.\n * @returns {PropertyDescriptor} The property descriptor to call the method property.\n * @private\n */\nfunction defineCallDescriptor(key) {\n return {\n value() {\n const event = pd(this).event;\n return event[key].apply(event, arguments)\n },\n configurable: true,\n enumerable: true,\n }\n}\n\n/**\n * Define new wrapper class.\n * @param {Function} BaseEvent The base wrapper class.\n * @param {Object} proto The prototype of the original event.\n * @returns {Function} The defined wrapper class.\n * @private\n */\nfunction defineWrapper(BaseEvent, proto) {\n const keys = Object.keys(proto);\n if (keys.length === 0) {\n return BaseEvent\n }\n\n /** CustomEvent */\n function CustomEvent(eventTarget, event) {\n BaseEvent.call(this, eventTarget, event);\n }\n\n CustomEvent.prototype = Object.create(BaseEvent.prototype, {\n constructor: { value: CustomEvent, configurable: true, writable: true },\n });\n\n // Define accessors.\n for (let i = 0; i < keys.length; ++i) {\n const key = keys[i];\n if (!(key in BaseEvent.prototype)) {\n const descriptor = Object.getOwnPropertyDescriptor(proto, key);\n const isFunc = typeof descriptor.value === \"function\";\n Object.defineProperty(\n CustomEvent.prototype,\n key,\n isFunc\n ? defineCallDescriptor(key)\n : defineRedirectDescriptor(key)\n );\n }\n }\n\n return CustomEvent\n}\n\n/**\n * Get the wrapper class of a given prototype.\n * @param {Object} proto The prototype of the original event to get its wrapper.\n * @returns {Function} The wrapper class.\n * @private\n */\nfunction getWrapper(proto) {\n if (proto == null || proto === Object.prototype) {\n return Event\n }\n\n let wrapper = wrappers.get(proto);\n if (wrapper == null) {\n wrapper = defineWrapper(getWrapper(Object.getPrototypeOf(proto)), proto);\n wrappers.set(proto, wrapper);\n }\n return wrapper\n}\n\n/**\n * Wrap a given event to management a dispatching.\n * @param {EventTarget} eventTarget The event target of this dispatching.\n * @param {Object} event The event to wrap.\n * @returns {Event} The wrapper instance.\n * @private\n */\nfunction wrapEvent(eventTarget, event) {\n const Wrapper = getWrapper(Object.getPrototypeOf(event));\n return new Wrapper(eventTarget, event)\n}\n\n/**\n * Get the immediateStopped flag of a given event.\n * @param {Event} event The event to get.\n * @returns {boolean} The flag to stop propagation immediately.\n * @private\n */\nfunction isStopped(event) {\n return pd(event).immediateStopped\n}\n\n/**\n * Set the current event phase of a given event.\n * @param {Event} event The event to set current target.\n * @param {number} eventPhase New event phase.\n * @returns {void}\n * @private\n */\nfunction setEventPhase(event, eventPhase) {\n pd(event).eventPhase = eventPhase;\n}\n\n/**\n * Set the current target of a given event.\n * @param {Event} event The event to set current target.\n * @param {EventTarget|null} currentTarget New current target.\n * @returns {void}\n * @private\n */\nfunction setCurrentTarget(event, currentTarget) {\n pd(event).currentTarget = currentTarget;\n}\n\n/**\n * Set a passive listener of a given event.\n * @param {Event} event The event to set current target.\n * @param {Function|null} passiveListener New passive listener.\n * @returns {void}\n * @private\n */\nfunction setPassiveListener(event, passiveListener) {\n pd(event).passiveListener = passiveListener;\n}\n\n/**\n * @typedef {object} ListenerNode\n * @property {Function} listener\n * @property {1|2|3} listenerType\n * @property {boolean} passive\n * @property {boolean} once\n * @property {ListenerNode|null} next\n * @private\n */\n\n/**\n * @type {WeakMap>}\n * @private\n */\nconst listenersMap = new WeakMap();\n\n// Listener types\nconst CAPTURE = 1;\nconst BUBBLE = 2;\nconst ATTRIBUTE = 3;\n\n/**\n * Check whether a given value is an object or not.\n * @param {any} x The value to check.\n * @returns {boolean} `true` if the value is an object.\n */\nfunction isObject(x) {\n return x !== null && typeof x === \"object\" //eslint-disable-line no-restricted-syntax\n}\n\n/**\n * Get listeners.\n * @param {EventTarget} eventTarget The event target to get.\n * @returns {Map} The listeners.\n * @private\n */\nfunction getListeners(eventTarget) {\n const listeners = listenersMap.get(eventTarget);\n if (listeners == null) {\n throw new TypeError(\n \"'this' is expected an EventTarget object, but got another value.\"\n )\n }\n return listeners\n}\n\n/**\n * Get the property descriptor for the event attribute of a given event.\n * @param {string} eventName The event name to get property descriptor.\n * @returns {PropertyDescriptor} The property descriptor.\n * @private\n */\nfunction defineEventAttributeDescriptor(eventName) {\n return {\n get() {\n const listeners = getListeners(this);\n let node = listeners.get(eventName);\n while (node != null) {\n if (node.listenerType === ATTRIBUTE) {\n return node.listener\n }\n node = node.next;\n }\n return null\n },\n\n set(listener) {\n if (typeof listener !== \"function\" && !isObject(listener)) {\n listener = null; // eslint-disable-line no-param-reassign\n }\n const listeners = getListeners(this);\n\n // Traverse to the tail while removing old value.\n let prev = null;\n let node = listeners.get(eventName);\n while (node != null) {\n if (node.listenerType === ATTRIBUTE) {\n // Remove old value.\n if (prev !== null) {\n prev.next = node.next;\n } else if (node.next !== null) {\n listeners.set(eventName, node.next);\n } else {\n listeners.delete(eventName);\n }\n } else {\n prev = node;\n }\n\n node = node.next;\n }\n\n // Add new value.\n if (listener !== null) {\n const newNode = {\n listener,\n listenerType: ATTRIBUTE,\n passive: false,\n once: false,\n next: null,\n };\n if (prev === null) {\n listeners.set(eventName, newNode);\n } else {\n prev.next = newNode;\n }\n }\n },\n configurable: true,\n enumerable: true,\n }\n}\n\n/**\n * Define an event attribute (e.g. `eventTarget.onclick`).\n * @param {Object} eventTargetPrototype The event target prototype to define an event attrbite.\n * @param {string} eventName The event name to define.\n * @returns {void}\n */\nfunction defineEventAttribute(eventTargetPrototype, eventName) {\n Object.defineProperty(\n eventTargetPrototype,\n `on${eventName}`,\n defineEventAttributeDescriptor(eventName)\n );\n}\n\n/**\n * Define a custom EventTarget with event attributes.\n * @param {string[]} eventNames Event names for event attributes.\n * @returns {EventTarget} The custom EventTarget.\n * @private\n */\nfunction defineCustomEventTarget(eventNames) {\n /** CustomEventTarget */\n function CustomEventTarget() {\n EventTarget.call(this);\n }\n\n CustomEventTarget.prototype = Object.create(EventTarget.prototype, {\n constructor: {\n value: CustomEventTarget,\n configurable: true,\n writable: true,\n },\n });\n\n for (let i = 0; i < eventNames.length; ++i) {\n defineEventAttribute(CustomEventTarget.prototype, eventNames[i]);\n }\n\n return CustomEventTarget\n}\n\n/**\n * EventTarget.\n *\n * - This is constructor if no arguments.\n * - This is a function which returns a CustomEventTarget constructor if there are arguments.\n *\n * For example:\n *\n * class A extends EventTarget {}\n * class B extends EventTarget(\"message\") {}\n * class C extends EventTarget(\"message\", \"error\") {}\n * class D extends EventTarget([\"message\", \"error\"]) {}\n */\nfunction EventTarget() {\n /*eslint-disable consistent-return */\n if (this instanceof EventTarget) {\n listenersMap.set(this, new Map());\n return\n }\n if (arguments.length === 1 && Array.isArray(arguments[0])) {\n return defineCustomEventTarget(arguments[0])\n }\n if (arguments.length > 0) {\n const types = new Array(arguments.length);\n for (let i = 0; i < arguments.length; ++i) {\n types[i] = arguments[i];\n }\n return defineCustomEventTarget(types)\n }\n throw new TypeError(\"Cannot call a class as a function\")\n /*eslint-enable consistent-return */\n}\n\n// Should be enumerable, but class methods are not enumerable.\nEventTarget.prototype = {\n /**\n * Add a given listener to this event target.\n * @param {string} eventName The event name to add.\n * @param {Function} listener The listener to add.\n * @param {boolean|{capture?:boolean,passive?:boolean,once?:boolean}} [options] The options for this listener.\n * @returns {void}\n */\n addEventListener(eventName, listener, options) {\n if (listener == null) {\n return\n }\n if (typeof listener !== \"function\" && !isObject(listener)) {\n throw new TypeError(\"'listener' should be a function or an object.\")\n }\n\n const listeners = getListeners(this);\n const optionsIsObj = isObject(options);\n const capture = optionsIsObj\n ? Boolean(options.capture)\n : Boolean(options);\n const listenerType = capture ? CAPTURE : BUBBLE;\n const newNode = {\n listener,\n listenerType,\n passive: optionsIsObj && Boolean(options.passive),\n once: optionsIsObj && Boolean(options.once),\n next: null,\n };\n\n // Set it as the first node if the first node is null.\n let node = listeners.get(eventName);\n if (node === undefined) {\n listeners.set(eventName, newNode);\n return\n }\n\n // Traverse to the tail while checking duplication..\n let prev = null;\n while (node != null) {\n if (\n node.listener === listener &&\n node.listenerType === listenerType\n ) {\n // Should ignore duplication.\n return\n }\n prev = node;\n node = node.next;\n }\n\n // Add it.\n prev.next = newNode;\n },\n\n /**\n * Remove a given listener from this event target.\n * @param {string} eventName The event name to remove.\n * @param {Function} listener The listener to remove.\n * @param {boolean|{capture?:boolean,passive?:boolean,once?:boolean}} [options] The options for this listener.\n * @returns {void}\n */\n removeEventListener(eventName, listener, options) {\n if (listener == null) {\n return\n }\n\n const listeners = getListeners(this);\n const capture = isObject(options)\n ? Boolean(options.capture)\n : Boolean(options);\n const listenerType = capture ? CAPTURE : BUBBLE;\n\n let prev = null;\n let node = listeners.get(eventName);\n while (node != null) {\n if (\n node.listener === listener &&\n node.listenerType === listenerType\n ) {\n if (prev !== null) {\n prev.next = node.next;\n } else if (node.next !== null) {\n listeners.set(eventName, node.next);\n } else {\n listeners.delete(eventName);\n }\n return\n }\n\n prev = node;\n node = node.next;\n }\n },\n\n /**\n * Dispatch a given event.\n * @param {Event|{type:string}} event The event to dispatch.\n * @returns {boolean} `false` if canceled.\n */\n dispatchEvent(event) {\n if (event == null || typeof event.type !== \"string\") {\n throw new TypeError('\"event.type\" should be a string.')\n }\n\n // If listeners aren't registered, terminate.\n const listeners = getListeners(this);\n const eventName = event.type;\n let node = listeners.get(eventName);\n if (node == null) {\n return true\n }\n\n // Since we cannot rewrite several properties, so wrap object.\n const wrappedEvent = wrapEvent(this, event);\n\n // This doesn't process capturing phase and bubbling phase.\n // This isn't participating in a tree.\n let prev = null;\n while (node != null) {\n // Remove this listener if it's once\n if (node.once) {\n if (prev !== null) {\n prev.next = node.next;\n } else if (node.next !== null) {\n listeners.set(eventName, node.next);\n } else {\n listeners.delete(eventName);\n }\n } else {\n prev = node;\n }\n\n // Call this listener\n setPassiveListener(\n wrappedEvent,\n node.passive ? node.listener : null\n );\n if (typeof node.listener === \"function\") {\n try {\n node.listener.call(this, wrappedEvent);\n } catch (err) {\n if (\n typeof console !== \"undefined\" &&\n typeof console.error === \"function\"\n ) {\n console.error(err);\n }\n }\n } else if (\n node.listenerType !== ATTRIBUTE &&\n typeof node.listener.handleEvent === \"function\"\n ) {\n node.listener.handleEvent(wrappedEvent);\n }\n\n // Break if `event.stopImmediatePropagation` was called.\n if (isStopped(wrappedEvent)) {\n break\n }\n\n node = node.next;\n }\n setPassiveListener(wrappedEvent, null);\n setEventPhase(wrappedEvent, 0);\n setCurrentTarget(wrappedEvent, null);\n\n return !wrappedEvent.defaultPrevented\n },\n};\n\n// `constructor` is not enumerable.\nObject.defineProperty(EventTarget.prototype, \"constructor\", {\n value: EventTarget,\n configurable: true,\n writable: true,\n});\n\n// Ensure `eventTarget instanceof window.EventTarget` is `true`.\nif (\n typeof window !== \"undefined\" &&\n typeof window.EventTarget !== \"undefined\"\n) {\n Object.setPrototypeOf(EventTarget.prototype, window.EventTarget.prototype);\n}\n\nexports.defineEventAttribute = defineEventAttribute;\nexports.EventTarget = EventTarget;\nexports.default = EventTarget;\n\nmodule.exports = EventTarget\nmodule.exports.EventTarget = module.exports[\"default\"] = EventTarget\nmodule.exports.defineEventAttribute = defineEventAttribute\n//# sourceMappingURL=event-target-shim.js.map\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 * @flow strict\n * @format\n */\n\nimport type {IPerformanceLogger} from './createPerformanceLogger';\n\nimport createPerformanceLogger from './createPerformanceLogger';\n\n/**\n * This is a global shared instance of IPerformanceLogger that is created with\n * createPerformanceLogger().\n * This logger should be used only for global performance metrics like the ones\n * that are logged during loading bundle. If you want to log something from your\n * React component you should use PerformanceLoggerContext instead.\n */\nconst GlobalPerformanceLogger: IPerformanceLogger = createPerformanceLogger();\n\nmodule.exports = GlobalPerformanceLogger;\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 * @flow strict\n * @format\n */\n\nconst Systrace = require('../Performance/Systrace');\nconst infoLog = require('./infoLog');\n\nexport type Timespan = {\n startTime: number,\n endTime?: number,\n totalTime?: number,\n startExtras?: Extras,\n endExtras?: Extras,\n};\n\n// Extra values should be serializable primitives\nexport type ExtraValue = number | string | boolean;\n\nexport type Extras = {[key: string]: ExtraValue};\n\nexport interface IPerformanceLogger {\n addTimespan(\n key: string,\n startTime: number,\n endTime: number,\n startExtras?: Extras,\n endExtras?: Extras,\n ): void;\n append(logger: IPerformanceLogger): void;\n clear(): void;\n clearCompleted(): void;\n close(): void;\n currentTimestamp(): number;\n getExtras(): $ReadOnly<{[key: string]: ?ExtraValue, ...}>;\n getPoints(): $ReadOnly<{[key: string]: ?number, ...}>;\n getPointExtras(): $ReadOnly<{[key: string]: ?Extras, ...}>;\n getTimespans(): $ReadOnly<{[key: string]: ?Timespan, ...}>;\n hasTimespan(key: string): boolean;\n isClosed(): boolean;\n logEverything(): void;\n markPoint(key: string, timestamp?: number, extras?: Extras): void;\n removeExtra(key: string): ?ExtraValue;\n setExtra(key: string, value: ExtraValue): void;\n startTimespan(key: string, timestamp?: number, extras?: Extras): void;\n stopTimespan(key: string, timestamp?: number, extras?: Extras): void;\n}\n\nconst _cookies: {[key: string]: number, ...} = {};\n\nconst PRINT_TO_CONSOLE: false = false; // Type as false to prevent accidentally committing `true`;\n\nexport const getCurrentTimestamp: () => number =\n global.nativeQPLTimestamp ?? global.performance.now.bind(global.performance);\n\nclass PerformanceLogger implements IPerformanceLogger {\n _timespans: {[key: string]: ?Timespan} = {};\n _extras: {[key: string]: ?ExtraValue} = {};\n _points: {[key: string]: ?number} = {};\n _pointExtras: {[key: string]: ?Extras, ...} = {};\n _closed: boolean = false;\n\n addTimespan(\n key: string,\n startTime: number,\n endTime: number,\n startExtras?: Extras,\n endExtras?: Extras,\n ) {\n if (this._closed) {\n if (PRINT_TO_CONSOLE && __DEV__) {\n infoLog('PerformanceLogger: addTimespan - has closed ignoring: ', key);\n }\n return;\n }\n if (this._timespans[key]) {\n if (PRINT_TO_CONSOLE && __DEV__) {\n infoLog(\n 'PerformanceLogger: Attempting to add a timespan that already exists ',\n key,\n );\n }\n return;\n }\n\n this._timespans[key] = {\n startTime,\n endTime,\n totalTime: endTime - (startTime || 0),\n startExtras,\n endExtras,\n };\n }\n\n append(performanceLogger: IPerformanceLogger) {\n this._timespans = {\n ...performanceLogger.getTimespans(),\n ...this._timespans,\n };\n this._extras = {...performanceLogger.getExtras(), ...this._extras};\n this._points = {...performanceLogger.getPoints(), ...this._points};\n this._pointExtras = {\n ...performanceLogger.getPointExtras(),\n ...this._pointExtras,\n };\n }\n\n clear() {\n this._timespans = {};\n this._extras = {};\n this._points = {};\n if (PRINT_TO_CONSOLE) {\n infoLog('PerformanceLogger.js', 'clear');\n }\n }\n\n clearCompleted() {\n for (const key in this._timespans) {\n if (this._timespans[key]?.totalTime != null) {\n delete this._timespans[key];\n }\n }\n this._extras = {};\n this._points = {};\n if (PRINT_TO_CONSOLE) {\n infoLog('PerformanceLogger.js', 'clearCompleted');\n }\n }\n\n close() {\n this._closed = true;\n }\n\n currentTimestamp(): number {\n return getCurrentTimestamp();\n }\n\n getExtras(): {[key: string]: ?ExtraValue} {\n return this._extras;\n }\n\n getPoints(): {[key: string]: ?number} {\n return this._points;\n }\n\n getPointExtras(): {[key: string]: ?Extras} {\n return this._pointExtras;\n }\n\n getTimespans(): {[key: string]: ?Timespan} {\n return this._timespans;\n }\n\n hasTimespan(key: string): boolean {\n return !!this._timespans[key];\n }\n\n isClosed(): boolean {\n return this._closed;\n }\n\n logEverything() {\n if (PRINT_TO_CONSOLE) {\n // log timespans\n for (const key in this._timespans) {\n if (this._timespans[key]?.totalTime != null) {\n infoLog(key + ': ' + this._timespans[key].totalTime + 'ms');\n }\n }\n\n // log extras\n infoLog(this._extras);\n\n // log points\n for (const key in this._points) {\n if (this._points[key] != null) {\n infoLog(key + ': ' + this._points[key] + 'ms');\n }\n }\n }\n }\n\n markPoint(\n key: string,\n timestamp?: number = getCurrentTimestamp(),\n extras?: Extras,\n ) {\n if (this._closed) {\n if (PRINT_TO_CONSOLE && __DEV__) {\n infoLog('PerformanceLogger: markPoint - has closed ignoring: ', key);\n }\n return;\n }\n if (this._points[key] != null) {\n if (PRINT_TO_CONSOLE && __DEV__) {\n infoLog(\n 'PerformanceLogger: Attempting to mark a point that has been already logged ',\n key,\n );\n }\n return;\n }\n this._points[key] = timestamp;\n if (extras) {\n this._pointExtras[key] = extras;\n }\n }\n\n removeExtra(key: string): ?ExtraValue {\n const value = this._extras[key];\n delete this._extras[key];\n return value;\n }\n\n setExtra(key: string, value: ExtraValue) {\n if (this._closed) {\n if (PRINT_TO_CONSOLE && __DEV__) {\n infoLog('PerformanceLogger: setExtra - has closed ignoring: ', key);\n }\n return;\n }\n\n if (this._extras.hasOwnProperty(key)) {\n if (PRINT_TO_CONSOLE && __DEV__) {\n infoLog(\n 'PerformanceLogger: Attempting to set an extra that already exists ',\n {key, currentValue: this._extras[key], attemptedValue: value},\n );\n }\n return;\n }\n this._extras[key] = value;\n }\n\n startTimespan(\n key: string,\n timestamp?: number = getCurrentTimestamp(),\n extras?: Extras,\n ) {\n if (this._closed) {\n if (PRINT_TO_CONSOLE && __DEV__) {\n infoLog(\n 'PerformanceLogger: startTimespan - has closed ignoring: ',\n key,\n );\n }\n return;\n }\n\n if (this._timespans[key]) {\n if (PRINT_TO_CONSOLE && __DEV__) {\n infoLog(\n 'PerformanceLogger: Attempting to start a timespan that already exists ',\n key,\n );\n }\n return;\n }\n\n this._timespans[key] = {\n startTime: timestamp,\n startExtras: extras,\n };\n _cookies[key] = Systrace.beginAsyncEvent(key);\n if (PRINT_TO_CONSOLE) {\n infoLog('PerformanceLogger.js', 'start: ' + key);\n }\n }\n\n stopTimespan(\n key: string,\n timestamp?: number = getCurrentTimestamp(),\n extras?: Extras,\n ) {\n if (this._closed) {\n if (PRINT_TO_CONSOLE && __DEV__) {\n infoLog('PerformanceLogger: stopTimespan - has closed ignoring: ', key);\n }\n return;\n }\n\n const timespan = this._timespans[key];\n if (!timespan || timespan.startTime == null) {\n if (PRINT_TO_CONSOLE && __DEV__) {\n infoLog(\n 'PerformanceLogger: Attempting to end a timespan that has not started ',\n key,\n );\n }\n return;\n }\n if (timespan.endTime != null) {\n if (PRINT_TO_CONSOLE && __DEV__) {\n infoLog(\n 'PerformanceLogger: Attempting to end a timespan that has already ended ',\n key,\n );\n }\n return;\n }\n\n timespan.endExtras = extras;\n timespan.endTime = timestamp;\n timespan.totalTime = timespan.endTime - (timespan.startTime || 0);\n if (PRINT_TO_CONSOLE) {\n infoLog('PerformanceLogger.js', 'end: ' + key);\n }\n\n if (_cookies[key] != null) {\n Systrace.endAsyncEvent(key, _cookies[key]);\n delete _cookies[key];\n }\n }\n}\n\n/**\n * This function creates performance loggers that can be used to collect and log\n * various performance data such as timespans, points and extras.\n * The loggers need to have minimal overhead since they're used in production.\n */\nexport default function createPerformanceLogger(): IPerformanceLogger {\n return new PerformanceLogger();\n}\n","'use strict'\n\nexports.byteLength = byteLength\nexports.toByteArray = toByteArray\nexports.fromByteArray = fromByteArray\n\nvar lookup = []\nvar revLookup = []\nvar Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array\n\nvar code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'\nfor (var i = 0, len = code.length; i < len; ++i) {\n lookup[i] = code[i]\n revLookup[code.charCodeAt(i)] = i\n}\n\n// Support decoding URL-safe base64 strings, as Node.js does.\n// See: https://en.wikipedia.org/wiki/Base64#URL_applications\nrevLookup['-'.charCodeAt(0)] = 62\nrevLookup['_'.charCodeAt(0)] = 63\n\nfunction getLens (b64) {\n var len = b64.length\n\n if (len % 4 > 0) {\n throw new Error('Invalid string. Length must be a multiple of 4')\n }\n\n // Trim off extra bytes after placeholder bytes are found\n // See: https://github.com/beatgammit/base64-js/issues/42\n var validLen = b64.indexOf('=')\n if (validLen === -1) validLen = len\n\n var placeHoldersLen = validLen === len\n ? 0\n : 4 - (validLen % 4)\n\n return [validLen, placeHoldersLen]\n}\n\n// base64 is 4/3 + up to two characters of the original data\nfunction byteLength (b64) {\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction _byteLength (b64, validLen, placeHoldersLen) {\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction toByteArray (b64) {\n var tmp\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n\n var arr = new Arr(_byteLength(b64, validLen, placeHoldersLen))\n\n var curByte = 0\n\n // if there are placeholders, only get up to the last complete 4 chars\n var len = placeHoldersLen > 0\n ? validLen - 4\n : validLen\n\n var i\n for (i = 0; i < len; i += 4) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 18) |\n (revLookup[b64.charCodeAt(i + 1)] << 12) |\n (revLookup[b64.charCodeAt(i + 2)] << 6) |\n revLookup[b64.charCodeAt(i + 3)]\n arr[curByte++] = (tmp >> 16) & 0xFF\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 2) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 2) |\n (revLookup[b64.charCodeAt(i + 1)] >> 4)\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 1) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 10) |\n (revLookup[b64.charCodeAt(i + 1)] << 4) |\n (revLookup[b64.charCodeAt(i + 2)] >> 2)\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n return arr\n}\n\nfunction tripletToBase64 (num) {\n return lookup[num >> 18 & 0x3F] +\n lookup[num >> 12 & 0x3F] +\n lookup[num >> 6 & 0x3F] +\n lookup[num & 0x3F]\n}\n\nfunction encodeChunk (uint8, start, end) {\n var tmp\n var output = []\n for (var i = start; i < end; i += 3) {\n tmp =\n ((uint8[i] << 16) & 0xFF0000) +\n ((uint8[i + 1] << 8) & 0xFF00) +\n (uint8[i + 2] & 0xFF)\n output.push(tripletToBase64(tmp))\n }\n return output.join('')\n}\n\nfunction fromByteArray (uint8) {\n var tmp\n var len = uint8.length\n var extraBytes = len % 3 // if we have 1 byte left, pad 2 bytes\n var parts = []\n var maxChunkLength = 16383 // must be multiple of 3\n\n // go through the array every three bytes, we'll deal with trailing stuff later\n for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) {\n parts.push(encodeChunk(uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength)))\n }\n\n // pad the end with zeros, but make sure to not forget the extra bytes\n if (extraBytes === 1) {\n tmp = uint8[len - 1]\n parts.push(\n lookup[tmp >> 2] +\n lookup[(tmp << 4) & 0x3F] +\n '=='\n )\n } else if (extraBytes === 2) {\n tmp = (uint8[len - 2] << 8) + uint8[len - 1]\n parts.push(\n lookup[tmp >> 10] +\n lookup[(tmp >> 4) & 0x3F] +\n lookup[(tmp << 2) & 0x3F] +\n '='\n )\n }\n\n return parts.join('')\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 * @flow strict-local\n * @format\n */\n\n'use strict';\n\nimport RCTDeviceEventEmitter from '../EventEmitter/RCTDeviceEventEmitter';\nimport {type EventSubscription} from '../vendor/emitter/EventEmitter';\nimport convertRequestBody, {type RequestBody} from './convertRequestBody';\nimport NativeNetworkingIOS from './NativeNetworkingIOS';\nimport {type NativeResponseType} from './XMLHttpRequest';\n\ntype RCTNetworkingEventDefinitions = $ReadOnly<{\n didSendNetworkData: [\n [\n number, // requestId\n number, // progress\n number, // total\n ],\n ],\n didReceiveNetworkResponse: [\n [\n number, // requestId\n number, // status\n ?{[string]: string}, // responseHeaders\n ?string, // responseURL\n ],\n ],\n didReceiveNetworkData: [\n [\n number, // requestId\n string, // response\n ],\n ],\n didReceiveNetworkIncrementalData: [\n [\n number, // requestId\n string, // responseText\n number, // progress\n number, // total\n ],\n ],\n didReceiveNetworkDataProgress: [\n [\n number, // requestId\n number, // loaded\n number, // total\n ],\n ],\n didCompleteNetworkResponse: [\n [\n number, // requestId\n string, // error\n boolean, // timeOutError\n ],\n ],\n}>;\n\nconst RCTNetworking = {\n addListener>(\n eventType: K,\n listener: (...$ElementType) => mixed,\n context?: mixed,\n ): EventSubscription {\n // $FlowFixMe[incompatible-call]\n return RCTDeviceEventEmitter.addListener(eventType, listener, context);\n },\n\n sendRequest(\n method: string,\n trackingName: string,\n url: string,\n headers: {...},\n data: RequestBody,\n responseType: NativeResponseType,\n incrementalUpdates: boolean,\n timeout: number,\n callback: (requestId: number) => void,\n withCredentials: boolean,\n ) {\n const body = convertRequestBody(data);\n NativeNetworkingIOS.sendRequest(\n {\n method,\n url,\n data: {...body, trackingName},\n headers,\n responseType,\n incrementalUpdates,\n timeout,\n withCredentials,\n },\n callback,\n );\n },\n\n abortRequest(requestId: number) {\n NativeNetworkingIOS.abortRequest(requestId);\n },\n\n clearCookies(callback: (result: boolean) => void) {\n NativeNetworkingIOS.clearCookies(callback);\n },\n};\n\nmodule.exports = RCTNetworking;\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 * @flow\n * @format\n */\n\n'use strict';\n\nconst Blob = require('../Blob/Blob');\nconst binaryToBase64 = require('../Utilities/binaryToBase64');\nconst FormData = require('./FormData');\n\nexport type RequestBody =\n | string\n | Blob\n | FormData\n | {uri: string, ...}\n | ArrayBuffer\n | $ArrayBufferView;\n\nfunction convertRequestBody(body: RequestBody): Object {\n if (typeof body === 'string') {\n return {string: body};\n }\n if (body instanceof Blob) {\n return {blob: body.data};\n }\n if (body instanceof FormData) {\n return {formData: body.getParts()};\n }\n if (body instanceof ArrayBuffer || ArrayBuffer.isView(body)) {\n /* $FlowFixMe[incompatible-call] : no way to assert that 'body' is indeed\n * an ArrayBufferView */\n return {base64: binaryToBase64(body)};\n }\n return body;\n}\n\nmodule.exports = convertRequestBody;\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 * @format\n * @flow strict\n */\n\n'use strict';\n\ntype FormDataValue = string | {name?: string, type?: string, uri: string};\ntype FormDataNameValuePair = [string, FormDataValue];\n\ntype Headers = {[name: string]: string, ...};\ntype FormDataPart =\n | {\n string: string,\n headers: Headers,\n ...\n }\n | {\n uri: string,\n headers: Headers,\n name?: string,\n type?: string,\n ...\n };\n\n/**\n * Polyfill for XMLHttpRequest2 FormData API, allowing multipart POST requests\n * with mixed data (string, native files) to be submitted via XMLHttpRequest.\n *\n * Example:\n *\n * var photo = {\n * uri: uriFromCameraRoll,\n * type: 'image/jpeg',\n * name: 'photo.jpg',\n * };\n *\n * var body = new FormData();\n * body.append('authToken', 'secret');\n * body.append('photo', photo);\n * body.append('title', 'A beautiful photo!');\n *\n * xhr.open('POST', serverURL);\n * xhr.send(body);\n */\nclass FormData {\n _parts: Array;\n\n constructor() {\n this._parts = [];\n }\n\n append(key: string, value: FormDataValue) {\n // The XMLHttpRequest spec doesn't specify if duplicate keys are allowed.\n // MDN says that any new values should be appended to existing values.\n // In any case, major browsers allow duplicate keys, so that's what we'll do\n // too. They'll simply get appended as additional form data parts in the\n // request body, leaving the server to deal with them.\n this._parts.push([key, value]);\n }\n\n getAll(key: string): Array {\n return this._parts\n .filter(([name]) => name === key)\n .map(([, value]) => value);\n }\n\n getParts(): Array {\n return this._parts.map(([name, value]) => {\n const contentDisposition = 'form-data; name=\"' + name + '\"';\n\n const headers: Headers = {'content-disposition': contentDisposition};\n\n // The body part is a \"blob\", which in React Native just means\n // an object with a `uri` attribute. Optionally, it can also\n // have a `name` and `type` attribute to specify filename and\n // content type (cf. web Blob interface.)\n if (typeof value === 'object' && !Array.isArray(value) && value) {\n if (typeof value.name === 'string') {\n headers['content-disposition'] += '; filename=\"' + value.name + '\"';\n }\n if (typeof value.type === 'string') {\n headers['content-type'] = value.type;\n }\n return {...value, headers, fieldName: name};\n }\n // Convert non-object values to strings as per FormData.append() spec\n return {string: String(value), headers, fieldName: name};\n });\n }\n}\n\nmodule.exports = FormData;\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 * @format\n * @flow strict\n */\n\n'use strict';\n\nconst base64 = require('base64-js');\n\nfunction binaryToBase64(data: ArrayBuffer | $ArrayBufferView): string {\n if (data instanceof ArrayBuffer) {\n // $FlowFixMe[reassign-const]\n data = new Uint8Array(data);\n }\n if (data instanceof Uint8Array) {\n return base64.fromByteArray(data);\n }\n if (!ArrayBuffer.isView(data)) {\n throw new Error('data must be ArrayBuffer or typed array');\n }\n // Already checked that `data` is `DataView` in `ArrayBuffer.isView(data)`\n const {buffer, byteOffset, byteLength} = ((data: $FlowFixMe): DataView);\n return base64.fromByteArray(new Uint8Array(buffer, byteOffset, byteLength));\n}\n\nmodule.exports = binaryToBase64;\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 * @flow\n * @format\n */\n\nimport type {TurboModule} from '../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../TurboModule/TurboModuleRegistry';\n\nexport interface Spec extends TurboModule {\n +sendRequest: (\n query: {|\n method: string,\n url: string,\n data: Object,\n headers: Object,\n responseType: string,\n incrementalUpdates: boolean,\n timeout: number,\n withCredentials: boolean,\n |},\n callback: (requestId: number) => void,\n ) => void;\n +abortRequest: (requestId: number) => void;\n +clearCookies: (callback: (result: boolean) => void) => void;\n\n // RCTEventEmitter\n +addListener: (eventName: string) => void;\n +removeListeners: (count: number) => void;\n}\n\nexport default (TurboModuleRegistry.getEnforcing('Networking'): Spec);\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 * @flow strict\n * @format\n */\n\n/* globals Headers, Request, Response */\n\n'use strict';\n\n// side-effectful require() to put fetch,\n// Headers, Request, Response in global scope\nrequire('whatwg-fetch');\n\nmodule.exports = {fetch, Headers, Request, Response};\n","(function (global, factory) {\n typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports) :\n typeof define === 'function' && define.amd ? define(['exports'], factory) :\n (factory((global.WHATWGFetch = {})));\n}(this, (function (exports) { 'use strict';\n\n var global =\n (typeof globalThis !== 'undefined' && globalThis) ||\n (typeof self !== 'undefined' && self) ||\n (typeof global !== 'undefined' && global);\n\n var support = {\n searchParams: 'URLSearchParams' in global,\n iterable: 'Symbol' in global && 'iterator' in Symbol,\n blob:\n 'FileReader' in global &&\n 'Blob' in global &&\n (function() {\n try {\n new Blob();\n return true\n } catch (e) {\n return false\n }\n })(),\n formData: 'FormData' in global,\n arrayBuffer: 'ArrayBuffer' in global\n };\n\n function isDataView(obj) {\n return obj && DataView.prototype.isPrototypeOf(obj)\n }\n\n if (support.arrayBuffer) {\n var viewClasses = [\n '[object Int8Array]',\n '[object Uint8Array]',\n '[object Uint8ClampedArray]',\n '[object Int16Array]',\n '[object Uint16Array]',\n '[object Int32Array]',\n '[object Uint32Array]',\n '[object Float32Array]',\n '[object Float64Array]'\n ];\n\n var isArrayBufferView =\n ArrayBuffer.isView ||\n function(obj) {\n return obj && viewClasses.indexOf(Object.prototype.toString.call(obj)) > -1\n };\n }\n\n function normalizeName(name) {\n if (typeof name !== 'string') {\n name = String(name);\n }\n if (/[^a-z0-9\\-#$%&'*+.^_`|~!]/i.test(name) || name === '') {\n throw new TypeError('Invalid character in header field name: \"' + name + '\"')\n }\n return name.toLowerCase()\n }\n\n function normalizeValue(value) {\n if (typeof value !== 'string') {\n value = String(value);\n }\n return value\n }\n\n // Build a destructive iterator for the value list\n function iteratorFor(items) {\n var iterator = {\n next: function() {\n var value = items.shift();\n return {done: value === undefined, value: value}\n }\n };\n\n if (support.iterable) {\n iterator[Symbol.iterator] = function() {\n return iterator\n };\n }\n\n return iterator\n }\n\n function Headers(headers) {\n this.map = {};\n\n if (headers instanceof Headers) {\n headers.forEach(function(value, name) {\n this.append(name, value);\n }, this);\n } else if (Array.isArray(headers)) {\n headers.forEach(function(header) {\n this.append(header[0], header[1]);\n }, this);\n } else if (headers) {\n Object.getOwnPropertyNames(headers).forEach(function(name) {\n this.append(name, headers[name]);\n }, this);\n }\n }\n\n Headers.prototype.append = function(name, value) {\n name = normalizeName(name);\n value = normalizeValue(value);\n var oldValue = this.map[name];\n this.map[name] = oldValue ? oldValue + ', ' + value : value;\n };\n\n Headers.prototype['delete'] = function(name) {\n delete this.map[normalizeName(name)];\n };\n\n Headers.prototype.get = function(name) {\n name = normalizeName(name);\n return this.has(name) ? this.map[name] : null\n };\n\n Headers.prototype.has = function(name) {\n return this.map.hasOwnProperty(normalizeName(name))\n };\n\n Headers.prototype.set = function(name, value) {\n this.map[normalizeName(name)] = normalizeValue(value);\n };\n\n Headers.prototype.forEach = function(callback, thisArg) {\n for (var name in this.map) {\n if (this.map.hasOwnProperty(name)) {\n callback.call(thisArg, this.map[name], name, this);\n }\n }\n };\n\n Headers.prototype.keys = function() {\n var items = [];\n this.forEach(function(value, name) {\n items.push(name);\n });\n return iteratorFor(items)\n };\n\n Headers.prototype.values = function() {\n var items = [];\n this.forEach(function(value) {\n items.push(value);\n });\n return iteratorFor(items)\n };\n\n Headers.prototype.entries = function() {\n var items = [];\n this.forEach(function(value, name) {\n items.push([name, value]);\n });\n return iteratorFor(items)\n };\n\n if (support.iterable) {\n Headers.prototype[Symbol.iterator] = Headers.prototype.entries;\n }\n\n function consumed(body) {\n if (body.bodyUsed) {\n return Promise.reject(new TypeError('Already read'))\n }\n body.bodyUsed = true;\n }\n\n function fileReaderReady(reader) {\n return new Promise(function(resolve, reject) {\n reader.onload = function() {\n resolve(reader.result);\n };\n reader.onerror = function() {\n reject(reader.error);\n };\n })\n }\n\n function readBlobAsArrayBuffer(blob) {\n var reader = new FileReader();\n var promise = fileReaderReady(reader);\n reader.readAsArrayBuffer(blob);\n return promise\n }\n\n function readBlobAsText(blob) {\n var reader = new FileReader();\n var promise = fileReaderReady(reader);\n reader.readAsText(blob);\n return promise\n }\n\n function readArrayBufferAsText(buf) {\n var view = new Uint8Array(buf);\n var chars = new Array(view.length);\n\n for (var i = 0; i < view.length; i++) {\n chars[i] = String.fromCharCode(view[i]);\n }\n return chars.join('')\n }\n\n function bufferClone(buf) {\n if (buf.slice) {\n return buf.slice(0)\n } else {\n var view = new Uint8Array(buf.byteLength);\n view.set(new Uint8Array(buf));\n return view.buffer\n }\n }\n\n function Body() {\n this.bodyUsed = false;\n\n this._initBody = function(body) {\n /*\n fetch-mock wraps the Response object in an ES6 Proxy to\n provide useful test harness features such as flush. However, on\n ES5 browsers without fetch or Proxy support pollyfills must be used;\n the proxy-pollyfill is unable to proxy an attribute unless it exists\n on the object before the Proxy is created. This change ensures\n Response.bodyUsed exists on the instance, while maintaining the\n semantic of setting Request.bodyUsed in the constructor before\n _initBody is called.\n */\n this.bodyUsed = this.bodyUsed;\n this._bodyInit = body;\n if (!body) {\n this._bodyText = '';\n } else if (typeof body === 'string') {\n this._bodyText = body;\n } else if (support.blob && Blob.prototype.isPrototypeOf(body)) {\n this._bodyBlob = body;\n } else if (support.formData && FormData.prototype.isPrototypeOf(body)) {\n this._bodyFormData = body;\n } else if (support.searchParams && URLSearchParams.prototype.isPrototypeOf(body)) {\n this._bodyText = body.toString();\n } else if (support.arrayBuffer && support.blob && isDataView(body)) {\n this._bodyArrayBuffer = bufferClone(body.buffer);\n // IE 10-11 can't handle a DataView body.\n this._bodyInit = new Blob([this._bodyArrayBuffer]);\n } else if (support.arrayBuffer && (ArrayBuffer.prototype.isPrototypeOf(body) || isArrayBufferView(body))) {\n this._bodyArrayBuffer = bufferClone(body);\n } else {\n this._bodyText = body = Object.prototype.toString.call(body);\n }\n\n if (!this.headers.get('content-type')) {\n if (typeof body === 'string') {\n this.headers.set('content-type', 'text/plain;charset=UTF-8');\n } else if (this._bodyBlob && this._bodyBlob.type) {\n this.headers.set('content-type', this._bodyBlob.type);\n } else if (support.searchParams && URLSearchParams.prototype.isPrototypeOf(body)) {\n this.headers.set('content-type', 'application/x-www-form-urlencoded;charset=UTF-8');\n }\n }\n };\n\n if (support.blob) {\n this.blob = function() {\n var rejected = consumed(this);\n if (rejected) {\n return rejected\n }\n\n if (this._bodyBlob) {\n return Promise.resolve(this._bodyBlob)\n } else if (this._bodyArrayBuffer) {\n return Promise.resolve(new Blob([this._bodyArrayBuffer]))\n } else if (this._bodyFormData) {\n throw new Error('could not read FormData body as blob')\n } else {\n return Promise.resolve(new Blob([this._bodyText]))\n }\n };\n\n this.arrayBuffer = function() {\n if (this._bodyArrayBuffer) {\n var isConsumed = consumed(this);\n if (isConsumed) {\n return isConsumed\n }\n if (ArrayBuffer.isView(this._bodyArrayBuffer)) {\n return Promise.resolve(\n this._bodyArrayBuffer.buffer.slice(\n this._bodyArrayBuffer.byteOffset,\n this._bodyArrayBuffer.byteOffset + this._bodyArrayBuffer.byteLength\n )\n )\n } else {\n return Promise.resolve(this._bodyArrayBuffer)\n }\n } else {\n return this.blob().then(readBlobAsArrayBuffer)\n }\n };\n }\n\n this.text = function() {\n var rejected = consumed(this);\n if (rejected) {\n return rejected\n }\n\n if (this._bodyBlob) {\n return readBlobAsText(this._bodyBlob)\n } else if (this._bodyArrayBuffer) {\n return Promise.resolve(readArrayBufferAsText(this._bodyArrayBuffer))\n } else if (this._bodyFormData) {\n throw new Error('could not read FormData body as text')\n } else {\n return Promise.resolve(this._bodyText)\n }\n };\n\n if (support.formData) {\n this.formData = function() {\n return this.text().then(decode)\n };\n }\n\n this.json = function() {\n return this.text().then(JSON.parse)\n };\n\n return this\n }\n\n // HTTP methods whose capitalization should be normalized\n var methods = ['DELETE', 'GET', 'HEAD', 'OPTIONS', 'POST', 'PUT'];\n\n function normalizeMethod(method) {\n var upcased = method.toUpperCase();\n return methods.indexOf(upcased) > -1 ? upcased : method\n }\n\n function Request(input, options) {\n if (!(this instanceof Request)) {\n throw new TypeError('Please use the \"new\" operator, this DOM object constructor cannot be called as a function.')\n }\n\n options = options || {};\n var body = options.body;\n\n if (input instanceof Request) {\n if (input.bodyUsed) {\n throw new TypeError('Already read')\n }\n this.url = input.url;\n this.credentials = input.credentials;\n if (!options.headers) {\n this.headers = new Headers(input.headers);\n }\n this.method = input.method;\n this.mode = input.mode;\n this.signal = input.signal;\n if (!body && input._bodyInit != null) {\n body = input._bodyInit;\n input.bodyUsed = true;\n }\n } else {\n this.url = String(input);\n }\n\n this.credentials = options.credentials || this.credentials || 'same-origin';\n if (options.headers || !this.headers) {\n this.headers = new Headers(options.headers);\n }\n this.method = normalizeMethod(options.method || this.method || 'GET');\n this.mode = options.mode || this.mode || null;\n this.signal = options.signal || this.signal;\n this.referrer = null;\n\n if ((this.method === 'GET' || this.method === 'HEAD') && body) {\n throw new TypeError('Body not allowed for GET or HEAD requests')\n }\n this._initBody(body);\n\n if (this.method === 'GET' || this.method === 'HEAD') {\n if (options.cache === 'no-store' || options.cache === 'no-cache') {\n // Search for a '_' parameter in the query string\n var reParamSearch = /([?&])_=[^&]*/;\n if (reParamSearch.test(this.url)) {\n // If it already exists then set the value with the current time\n this.url = this.url.replace(reParamSearch, '$1_=' + new Date().getTime());\n } else {\n // Otherwise add a new '_' parameter to the end with the current time\n var reQueryString = /\\?/;\n this.url += (reQueryString.test(this.url) ? '&' : '?') + '_=' + new Date().getTime();\n }\n }\n }\n }\n\n Request.prototype.clone = function() {\n return new Request(this, {body: this._bodyInit})\n };\n\n function decode(body) {\n var form = new FormData();\n body\n .trim()\n .split('&')\n .forEach(function(bytes) {\n if (bytes) {\n var split = bytes.split('=');\n var name = split.shift().replace(/\\+/g, ' ');\n var value = split.join('=').replace(/\\+/g, ' ');\n form.append(decodeURIComponent(name), decodeURIComponent(value));\n }\n });\n return form\n }\n\n function parseHeaders(rawHeaders) {\n var headers = new Headers();\n // Replace instances of \\r\\n and \\n followed by at least one space or horizontal tab with a space\n // https://tools.ietf.org/html/rfc7230#section-3.2\n var preProcessedHeaders = rawHeaders.replace(/\\r?\\n[\\t ]+/g, ' ');\n // Avoiding split via regex to work around a common IE11 bug with the core-js 3.6.0 regex polyfill\n // https://github.com/github/fetch/issues/748\n // https://github.com/zloirock/core-js/issues/751\n preProcessedHeaders\n .split('\\r')\n .map(function(header) {\n return header.indexOf('\\n') === 0 ? header.substr(1, header.length) : header\n })\n .forEach(function(line) {\n var parts = line.split(':');\n var key = parts.shift().trim();\n if (key) {\n var value = parts.join(':').trim();\n headers.append(key, value);\n }\n });\n return headers\n }\n\n Body.call(Request.prototype);\n\n function Response(bodyInit, options) {\n if (!(this instanceof Response)) {\n throw new TypeError('Please use the \"new\" operator, this DOM object constructor cannot be called as a function.')\n }\n if (!options) {\n options = {};\n }\n\n this.type = 'default';\n this.status = options.status === undefined ? 200 : options.status;\n this.ok = this.status >= 200 && this.status < 300;\n this.statusText = options.statusText === undefined ? '' : '' + options.statusText;\n this.headers = new Headers(options.headers);\n this.url = options.url || '';\n this._initBody(bodyInit);\n }\n\n Body.call(Response.prototype);\n\n Response.prototype.clone = function() {\n return new Response(this._bodyInit, {\n status: this.status,\n statusText: this.statusText,\n headers: new Headers(this.headers),\n url: this.url\n })\n };\n\n Response.error = function() {\n var response = new Response(null, {status: 0, statusText: ''});\n response.type = 'error';\n return response\n };\n\n var redirectStatuses = [301, 302, 303, 307, 308];\n\n Response.redirect = function(url, status) {\n if (redirectStatuses.indexOf(status) === -1) {\n throw new RangeError('Invalid status code')\n }\n\n return new Response(null, {status: status, headers: {location: url}})\n };\n\n exports.DOMException = global.DOMException;\n try {\n new exports.DOMException();\n } catch (err) {\n exports.DOMException = function(message, name) {\n this.message = message;\n this.name = name;\n var error = Error(message);\n this.stack = error.stack;\n };\n exports.DOMException.prototype = Object.create(Error.prototype);\n exports.DOMException.prototype.constructor = exports.DOMException;\n }\n\n function fetch(input, init) {\n return new Promise(function(resolve, reject) {\n var request = new Request(input, init);\n\n if (request.signal && request.signal.aborted) {\n return reject(new exports.DOMException('Aborted', 'AbortError'))\n }\n\n var xhr = new XMLHttpRequest();\n\n function abortXhr() {\n xhr.abort();\n }\n\n xhr.onload = function() {\n var options = {\n status: xhr.status,\n statusText: xhr.statusText,\n headers: parseHeaders(xhr.getAllResponseHeaders() || '')\n };\n options.url = 'responseURL' in xhr ? xhr.responseURL : options.headers.get('X-Request-URL');\n var body = 'response' in xhr ? xhr.response : xhr.responseText;\n setTimeout(function() {\n resolve(new Response(body, options));\n }, 0);\n };\n\n xhr.onerror = function() {\n setTimeout(function() {\n reject(new TypeError('Network request failed'));\n }, 0);\n };\n\n xhr.ontimeout = function() {\n setTimeout(function() {\n reject(new TypeError('Network request failed'));\n }, 0);\n };\n\n xhr.onabort = function() {\n setTimeout(function() {\n reject(new exports.DOMException('Aborted', 'AbortError'));\n }, 0);\n };\n\n function fixUrl(url) {\n try {\n return url === '' && global.location.href ? global.location.href : url\n } catch (e) {\n return url\n }\n }\n\n xhr.open(request.method, fixUrl(request.url), true);\n\n if (request.credentials === 'include') {\n xhr.withCredentials = true;\n } else if (request.credentials === 'omit') {\n xhr.withCredentials = false;\n }\n\n if ('responseType' in xhr) {\n if (support.blob) {\n xhr.responseType = 'blob';\n } else if (\n support.arrayBuffer &&\n request.headers.get('Content-Type') &&\n request.headers.get('Content-Type').indexOf('application/octet-stream') !== -1\n ) {\n xhr.responseType = 'arraybuffer';\n }\n }\n\n if (init && typeof init.headers === 'object' && !(init.headers instanceof Headers)) {\n Object.getOwnPropertyNames(init.headers).forEach(function(name) {\n xhr.setRequestHeader(name, normalizeValue(init.headers[name]));\n });\n } else {\n request.headers.forEach(function(value, name) {\n xhr.setRequestHeader(name, value);\n });\n }\n\n if (request.signal) {\n request.signal.addEventListener('abort', abortXhr);\n\n xhr.onreadystatechange = function() {\n // DONE (success or failure)\n if (xhr.readyState === 4) {\n request.signal.removeEventListener('abort', abortXhr);\n }\n };\n }\n\n xhr.send(typeof request._bodyInit === 'undefined' ? null : request._bodyInit);\n })\n }\n\n fetch.polyfill = true;\n\n if (!global.fetch) {\n global.fetch = fetch;\n global.Headers = Headers;\n global.Request = Request;\n global.Response = Response;\n }\n\n exports.Headers = Headers;\n exports.Request = Request;\n exports.Response = Response;\n exports.fetch = fetch;\n\n Object.defineProperty(exports, '__esModule', { value: true });\n\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 * @format\n * @flow\n */\n\nimport type {BlobData} from '../Blob/BlobTypes';\nimport type {EventSubscription} from '../vendor/emitter/EventEmitter';\n\nimport Blob from '../Blob/Blob';\nimport BlobManager from '../Blob/BlobManager';\nimport NativeEventEmitter from '../EventEmitter/NativeEventEmitter';\nimport binaryToBase64 from '../Utilities/binaryToBase64';\nimport Platform from '../Utilities/Platform';\nimport NativeWebSocketModule from './NativeWebSocketModule';\nimport WebSocketEvent from './WebSocketEvent';\nimport base64 from 'base64-js';\nimport EventTarget from 'event-target-shim';\nimport invariant from 'invariant';\n\ntype ArrayBufferView =\n | Int8Array\n | Uint8Array\n | Uint8ClampedArray\n | Int16Array\n | Uint16Array\n | Int32Array\n | Uint32Array\n | Float32Array\n | Float64Array\n | DataView;\n\ntype BinaryType = 'blob' | 'arraybuffer';\n\nconst CONNECTING = 0;\nconst OPEN = 1;\nconst CLOSING = 2;\nconst CLOSED = 3;\n\nconst CLOSE_NORMAL = 1000;\n\n// Abnormal closure where no code is provided in a control frame\n// https://www.rfc-editor.org/rfc/rfc6455.html#section-7.1.5\nconst CLOSE_ABNORMAL = 1006;\n\nconst WEBSOCKET_EVENTS = ['close', 'error', 'message', 'open'];\n\nlet nextWebSocketId = 0;\n\ntype WebSocketEventDefinitions = {\n websocketOpen: [{id: number, protocol: string}],\n websocketClosed: [{id: number, code: number, reason: string}],\n websocketMessage: [\n | {type: 'binary', id: number, data: string}\n | {type: 'text', id: number, data: string}\n | {type: 'blob', id: number, data: BlobData},\n ],\n websocketFailed: [{id: number, message: string}],\n};\n\n/**\n * Browser-compatible WebSockets implementation.\n *\n * See https://developer.mozilla.org/en-US/docs/Web/API/WebSocket\n * See https://github.com/websockets/ws\n */\nclass WebSocket extends (EventTarget(...WEBSOCKET_EVENTS): any) {\n static CONNECTING: number = CONNECTING;\n static OPEN: number = OPEN;\n static CLOSING: number = CLOSING;\n static CLOSED: number = CLOSED;\n\n CONNECTING: number = CONNECTING;\n OPEN: number = OPEN;\n CLOSING: number = CLOSING;\n CLOSED: number = CLOSED;\n\n _socketId: number;\n _eventEmitter: NativeEventEmitter;\n _subscriptions: Array;\n _binaryType: ?BinaryType;\n\n onclose: ?Function;\n onerror: ?Function;\n onmessage: ?Function;\n onopen: ?Function;\n\n bufferedAmount: number;\n extension: ?string;\n protocol: ?string;\n readyState: number = CONNECTING;\n url: ?string;\n\n constructor(\n url: string,\n protocols: ?string | ?Array,\n options: ?{headers?: {origin?: string, ...}, ...},\n ) {\n super();\n this.url = url;\n if (typeof protocols === 'string') {\n protocols = [protocols];\n }\n\n const {headers = {}, ...unrecognized} = options || {};\n\n // Preserve deprecated backwards compatibility for the 'origin' option\n // $FlowFixMe[prop-missing]\n if (unrecognized && typeof unrecognized.origin === 'string') {\n console.warn(\n 'Specifying `origin` as a WebSocket connection option is deprecated. Include it under `headers` instead.',\n );\n /* $FlowFixMe[prop-missing] (>=0.54.0 site=react_native_fb,react_native_\n * oss) This comment suppresses an error found when Flow v0.54 was\n * deployed. To see the error delete this comment and run Flow. */\n headers.origin = unrecognized.origin;\n /* $FlowFixMe[prop-missing] (>=0.54.0 site=react_native_fb,react_native_\n * oss) This comment suppresses an error found when Flow v0.54 was\n * deployed. To see the error delete this comment and run Flow. */\n delete unrecognized.origin;\n }\n\n // Warn about and discard anything else\n if (Object.keys(unrecognized).length > 0) {\n console.warn(\n 'Unrecognized WebSocket connection option(s) `' +\n Object.keys(unrecognized).join('`, `') +\n '`. ' +\n 'Did you mean to put these under `headers`?',\n );\n }\n\n if (!Array.isArray(protocols)) {\n protocols = null;\n }\n\n this._eventEmitter = new NativeEventEmitter(\n // T88715063: NativeEventEmitter only used this parameter on iOS. Now it uses it on all platforms, so this code was modified automatically to preserve its behavior\n // If you want to use the native module on other platforms, please remove this condition and test its behavior\n Platform.OS !== 'ios' ? null : NativeWebSocketModule,\n );\n this._socketId = nextWebSocketId++;\n this._registerEvents();\n NativeWebSocketModule.connect(url, protocols, {headers}, this._socketId);\n }\n\n get binaryType(): ?BinaryType {\n return this._binaryType;\n }\n\n set binaryType(binaryType: BinaryType): void {\n if (binaryType !== 'blob' && binaryType !== 'arraybuffer') {\n throw new Error(\"binaryType must be either 'blob' or 'arraybuffer'\");\n }\n if (this._binaryType === 'blob' || binaryType === 'blob') {\n invariant(\n BlobManager.isAvailable,\n 'Native module BlobModule is required for blob support',\n );\n if (binaryType === 'blob') {\n BlobManager.addWebSocketHandler(this._socketId);\n } else {\n BlobManager.removeWebSocketHandler(this._socketId);\n }\n }\n this._binaryType = binaryType;\n }\n\n close(code?: number, reason?: string): void {\n if (this.readyState === this.CLOSING || this.readyState === this.CLOSED) {\n return;\n }\n\n this.readyState = this.CLOSING;\n this._close(code, reason);\n }\n\n send(data: string | ArrayBuffer | ArrayBufferView | Blob): void {\n if (this.readyState === this.CONNECTING) {\n throw new Error('INVALID_STATE_ERR');\n }\n\n if (data instanceof Blob) {\n invariant(\n BlobManager.isAvailable,\n 'Native module BlobModule is required for blob support',\n );\n BlobManager.sendOverSocket(data, this._socketId);\n return;\n }\n\n if (typeof data === 'string') {\n NativeWebSocketModule.send(data, this._socketId);\n return;\n }\n\n if (data instanceof ArrayBuffer || ArrayBuffer.isView(data)) {\n NativeWebSocketModule.sendBinary(binaryToBase64(data), this._socketId);\n return;\n }\n\n throw new Error('Unsupported data type');\n }\n\n ping(): void {\n if (this.readyState === this.CONNECTING) {\n throw new Error('INVALID_STATE_ERR');\n }\n\n NativeWebSocketModule.ping(this._socketId);\n }\n\n _close(code?: number, reason?: string): void {\n // See https://developer.mozilla.org/en-US/docs/Web/API/CloseEvent\n const statusCode = typeof code === 'number' ? code : CLOSE_NORMAL;\n const closeReason = typeof reason === 'string' ? reason : '';\n NativeWebSocketModule.close(statusCode, closeReason, this._socketId);\n\n if (BlobManager.isAvailable && this._binaryType === 'blob') {\n BlobManager.removeWebSocketHandler(this._socketId);\n }\n }\n\n _unregisterEvents(): void {\n this._subscriptions.forEach(e => e.remove());\n this._subscriptions = [];\n }\n\n _registerEvents(): void {\n this._subscriptions = [\n this._eventEmitter.addListener('websocketMessage', ev => {\n if (ev.id !== this._socketId) {\n return;\n }\n let data: Blob | BlobData | ArrayBuffer | string = ev.data;\n switch (ev.type) {\n case 'binary':\n data = base64.toByteArray(ev.data).buffer;\n break;\n case 'blob':\n data = BlobManager.createFromOptions(ev.data);\n break;\n }\n this.dispatchEvent(new WebSocketEvent('message', {data}));\n }),\n this._eventEmitter.addListener('websocketOpen', ev => {\n if (ev.id !== this._socketId) {\n return;\n }\n this.readyState = this.OPEN;\n this.protocol = ev.protocol;\n this.dispatchEvent(new WebSocketEvent('open'));\n }),\n this._eventEmitter.addListener('websocketClosed', ev => {\n if (ev.id !== this._socketId) {\n return;\n }\n this.readyState = this.CLOSED;\n this.dispatchEvent(\n new WebSocketEvent('close', {\n code: ev.code,\n reason: ev.reason,\n // TODO: missing `wasClean` (exposed on iOS as `clean` but missing on Android)\n }),\n );\n this._unregisterEvents();\n this.close();\n }),\n this._eventEmitter.addListener('websocketFailed', ev => {\n if (ev.id !== this._socketId) {\n return;\n }\n this.readyState = this.CLOSED;\n this.dispatchEvent(\n new WebSocketEvent('error', {\n message: ev.message,\n }),\n );\n this.dispatchEvent(\n new WebSocketEvent('close', {\n code: CLOSE_ABNORMAL,\n reason: ev.message,\n // TODO: Expose `wasClean`\n }),\n );\n this._unregisterEvents();\n this.close();\n }),\n ];\n }\n}\n\nmodule.exports = WebSocket;\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 * @flow strict-local\n * @format\n */\n\n'use strict';\n\nimport type {\n EventSubscription,\n IEventEmitter,\n} from '../vendor/emitter/EventEmitter';\n\nimport Platform from '../Utilities/Platform';\nimport RCTDeviceEventEmitter from './RCTDeviceEventEmitter';\nimport invariant from 'invariant';\n\ninterface NativeModule {\n addListener(eventType: string): void;\n removeListeners(count: number): void;\n}\n\nexport type {EventSubscription};\n\n/**\n * `NativeEventEmitter` is intended for use by Native Modules to emit events to\n * JavaScript listeners. If a `NativeModule` is supplied to the constructor, it\n * will be notified (via `addListener` and `removeListeners`) when the listener\n * count changes to manage \"native memory\".\n *\n * Currently, all native events are fired via a global `RCTDeviceEventEmitter`.\n * This means event names must be globally unique, and it means that call sites\n * can theoretically listen to `RCTDeviceEventEmitter` (although discouraged).\n */\nexport default class NativeEventEmitter\n implements IEventEmitter\n{\n _nativeModule: ?NativeModule;\n\n constructor(nativeModule: ?NativeModule) {\n if (Platform.OS === 'ios') {\n invariant(\n nativeModule != null,\n '`new NativeEventEmitter()` requires a non-null argument.',\n );\n }\n\n const hasAddListener =\n // $FlowFixMe[method-unbinding] added when improving typing for this parameters\n !!nativeModule && typeof nativeModule.addListener === 'function';\n const hasRemoveListeners =\n // $FlowFixMe[method-unbinding] added when improving typing for this parameters\n !!nativeModule && typeof nativeModule.removeListeners === 'function';\n\n if (nativeModule && hasAddListener && hasRemoveListeners) {\n this._nativeModule = nativeModule;\n } else if (nativeModule != null) {\n if (!hasAddListener) {\n console.warn(\n '`new NativeEventEmitter()` was called with a non-null argument without the required `addListener` method.',\n );\n }\n if (!hasRemoveListeners) {\n console.warn(\n '`new NativeEventEmitter()` was called with a non-null argument without the required `removeListeners` method.',\n );\n }\n }\n }\n\n addListener>(\n eventType: TEvent,\n listener: (...args: $ElementType) => mixed,\n context?: mixed,\n ): EventSubscription {\n this._nativeModule?.addListener(eventType);\n let subscription: ?EventSubscription = RCTDeviceEventEmitter.addListener(\n eventType,\n listener,\n context,\n );\n\n return {\n remove: () => {\n if (subscription != null) {\n this._nativeModule?.removeListeners(1);\n // $FlowFixMe[incompatible-use]\n subscription.remove();\n subscription = null;\n }\n },\n };\n }\n\n emit>(\n eventType: TEvent,\n ...args: $ElementType\n ): void {\n // Generally, `RCTDeviceEventEmitter` is directly invoked. But this is\n // included for completeness.\n RCTDeviceEventEmitter.emit(eventType, ...args);\n }\n\n removeAllListeners>(\n eventType?: ?TEvent,\n ): void {\n invariant(\n eventType != null,\n '`NativeEventEmitter.removeAllListener()` requires a non-null argument.',\n );\n this._nativeModule?.removeListeners(this.listenerCount(eventType));\n RCTDeviceEventEmitter.removeAllListeners(eventType);\n }\n\n listenerCount>(eventType: TEvent): number {\n return RCTDeviceEventEmitter.listenerCount(eventType);\n }\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 * @flow\n * @format\n */\n\nimport type {TurboModule} from '../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../TurboModule/TurboModuleRegistry';\n\nexport interface Spec extends TurboModule {\n +connect: (\n url: string,\n protocols: ?Array,\n options: {|headers?: Object|},\n socketID: number,\n ) => void;\n +send: (message: string, forSocketID: number) => void;\n +sendBinary: (base64String: string, forSocketID: number) => void;\n +ping: (socketID: number) => void;\n +close: (code: number, reason: string, socketID: number) => void;\n\n // RCTEventEmitter\n +addListener: (eventName: string) => void;\n +removeListeners: (count: number) => void;\n}\n\nexport default (TurboModuleRegistry.getEnforcing(\n 'WebSocketModule',\n): Spec);\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 * @format\n */\n\n'use strict';\n\n/**\n * Event object passed to the `onopen`, `onclose`, `onmessage`, `onerror`\n * callbacks of `WebSocket`.\n *\n * The `type` property is \"open\", \"close\", \"message\", \"error\" respectively.\n *\n * In case of \"message\", the `data` property contains the incoming data.\n */\nclass WebSocketEvent {\n constructor(type, eventInitDict) {\n this.type = type.toString();\n Object.assign(this, eventInitDict);\n }\n}\n\nmodule.exports = WebSocketEvent;\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport type {BlobOptions} from './BlobTypes';\n\nconst Blob = require('./Blob');\nconst invariant = require('invariant');\n\n/**\n * The File interface provides information about files.\n */\nclass File extends Blob {\n /**\n * Constructor for JS consumers.\n */\n constructor(\n parts: Array,\n name: string,\n options?: BlobOptions,\n ) {\n invariant(\n parts != null && name != null,\n 'Failed to construct `File`: Must pass both `parts` and `name` arguments.',\n );\n\n super(parts, options);\n this.data.name = name;\n }\n\n /**\n * Name of the file.\n */\n get name(): string {\n invariant(this.data.name != null, 'Files must have a name set.');\n return this.data.name;\n }\n\n /*\n * Last modified time of the file.\n */\n get lastModified(): number {\n return this.data.lastModified || 0;\n }\n}\n\nmodule.exports = File;\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 * @flow\n * @format\n */\n\nimport type Blob from './Blob';\n\nimport NativeFileReaderModule from './NativeFileReaderModule';\n\nconst EventTarget = require('event-target-shim');\n\ntype ReadyState =\n | 0 // EMPTY\n | 1 // LOADING\n | 2; // DONE\n\ntype ReaderResult = string | ArrayBuffer;\n\nconst READER_EVENTS = [\n 'abort',\n 'error',\n 'load',\n 'loadstart',\n 'loadend',\n 'progress',\n];\n\nconst EMPTY = 0;\nconst LOADING = 1;\nconst DONE = 2;\n\nclass FileReader extends (EventTarget(...READER_EVENTS): any) {\n static EMPTY: number = EMPTY;\n static LOADING: number = LOADING;\n static DONE: number = DONE;\n\n EMPTY: number = EMPTY;\n LOADING: number = LOADING;\n DONE: number = DONE;\n\n _readyState: ReadyState;\n _error: ?Error;\n _result: ?ReaderResult;\n _aborted: boolean = false;\n\n constructor() {\n super();\n this._reset();\n }\n\n _reset(): void {\n this._readyState = EMPTY;\n this._error = null;\n this._result = null;\n }\n\n _setReadyState(newState: ReadyState) {\n this._readyState = newState;\n this.dispatchEvent({type: 'readystatechange'});\n if (newState === DONE) {\n if (this._aborted) {\n this.dispatchEvent({type: 'abort'});\n } else if (this._error) {\n this.dispatchEvent({type: 'error'});\n } else {\n this.dispatchEvent({type: 'load'});\n }\n this.dispatchEvent({type: 'loadend'});\n }\n }\n\n readAsArrayBuffer(): any {\n throw new Error('FileReader.readAsArrayBuffer is not implemented');\n }\n\n readAsDataURL(blob: ?Blob): void {\n this._aborted = false;\n\n if (blob == null) {\n throw new TypeError(\n \"Failed to execute 'readAsDataURL' on 'FileReader': parameter 1 is not of type 'Blob'\",\n );\n }\n\n NativeFileReaderModule.readAsDataURL(blob.data).then(\n (text: string) => {\n if (this._aborted) {\n return;\n }\n this._result = text;\n this._setReadyState(DONE);\n },\n error => {\n if (this._aborted) {\n return;\n }\n this._error = error;\n this._setReadyState(DONE);\n },\n );\n }\n\n readAsText(blob: ?Blob, encoding: string = 'UTF-8'): void {\n this._aborted = false;\n\n if (blob == null) {\n throw new TypeError(\n \"Failed to execute 'readAsText' on 'FileReader': parameter 1 is not of type 'Blob'\",\n );\n }\n\n NativeFileReaderModule.readAsText(blob.data, encoding).then(\n (text: string) => {\n if (this._aborted) {\n return;\n }\n this._result = text;\n this._setReadyState(DONE);\n },\n error => {\n if (this._aborted) {\n return;\n }\n this._error = error;\n this._setReadyState(DONE);\n },\n );\n }\n\n abort() {\n this._aborted = true;\n // only call onreadystatechange if there is something to abort, as per spec\n if (this._readyState !== EMPTY && this._readyState !== DONE) {\n this._reset();\n this._setReadyState(DONE);\n }\n // Reset again after, in case modified in handler\n this._reset();\n }\n\n get readyState(): ReadyState {\n return this._readyState;\n }\n\n get error(): ?Error {\n return this._error;\n }\n\n get result(): ?ReaderResult {\n return this._result;\n }\n}\n\nmodule.exports = FileReader;\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 * @flow\n * @format\n */\n\nimport type {TurboModule} from '../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../TurboModule/TurboModuleRegistry';\n\nexport interface Spec extends TurboModule {\n +readAsDataURL: (data: Object) => Promise;\n +readAsText: (data: Object, encoding: string) => Promise;\n}\n\nexport default (TurboModuleRegistry.getEnforcing(\n 'FileReaderModule',\n): Spec);\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 * @format\n * @flow\n */\n\nimport type Blob from './Blob';\n\nimport NativeBlobModule from './NativeBlobModule';\n\nlet BLOB_URL_PREFIX = null;\n\nif (\n NativeBlobModule &&\n typeof NativeBlobModule.getConstants().BLOB_URI_SCHEME === 'string'\n) {\n const constants = NativeBlobModule.getConstants();\n // $FlowFixMe[incompatible-type] asserted above\n BLOB_URL_PREFIX = constants.BLOB_URI_SCHEME + ':';\n if (typeof constants.BLOB_URI_HOST === 'string') {\n BLOB_URL_PREFIX += `//${constants.BLOB_URI_HOST}/`;\n }\n}\n\n/**\n * To allow Blobs be accessed via `content://` URIs,\n * you need to register `BlobProvider` as a ContentProvider in your app's `AndroidManifest.xml`:\n *\n * ```xml\n * \n * \n * \n * \n * \n * ```\n * And then define the `blob_provider_authority` string in `res/values/strings.xml`.\n * Use a dotted name that's entirely unique to your app:\n *\n * ```xml\n * \n * your.app.package.blobs\n * \n * ```\n */\n\n// Small subset from whatwg-url: https://github.com/jsdom/whatwg-url/tree/master/src\n// The reference code bloat comes from Unicode issues with URLs, so those won't work here.\nexport class URLSearchParams {\n _searchParams: Array> = [];\n\n constructor(params: any) {\n if (typeof params === 'object') {\n Object.keys(params).forEach(key => this.append(key, params[key]));\n }\n }\n\n append(key: string, value: string): void {\n this._searchParams.push([key, value]);\n }\n\n delete(name: string): void {\n throw new Error('URLSearchParams.delete is not implemented');\n }\n\n get(name: string): void {\n throw new Error('URLSearchParams.get is not implemented');\n }\n\n getAll(name: string): void {\n throw new Error('URLSearchParams.getAll is not implemented');\n }\n\n has(name: string): void {\n throw new Error('URLSearchParams.has is not implemented');\n }\n\n set(name: string, value: string): void {\n throw new Error('URLSearchParams.set is not implemented');\n }\n\n sort(): void {\n throw new Error('URLSearchParams.sort is not implemented');\n }\n\n // $FlowFixMe[unsupported-syntax]\n // $FlowFixMe[missing-local-annot]\n [Symbol.iterator]() {\n return this._searchParams[Symbol.iterator]();\n }\n\n toString(): string {\n if (this._searchParams.length === 0) {\n return '';\n }\n const last = this._searchParams.length - 1;\n return this._searchParams.reduce((acc, curr, index) => {\n return (\n acc +\n encodeURIComponent(curr[0]) +\n '=' +\n encodeURIComponent(curr[1]) +\n (index === last ? '' : '&')\n );\n }, '');\n }\n}\n\nfunction validateBaseUrl(url: string) {\n // from this MIT-licensed gist: https://gist.github.com/dperini/729294\n return /^(?:(?:(?:https?|ftp):)?\\/\\/)(?:(?:[1-9]\\d?|1\\d\\d|2[01]\\d|22[0-3])(?:\\.(?:1?\\d{1,2}|2[0-4]\\d|25[0-5])){2}(?:\\.(?:[1-9]\\d?|1\\d\\d|2[0-4]\\d|25[0-4]))|(?:(?:[a-z0-9\\u00a1-\\uffff][a-z0-9\\u00a1-\\uffff_-]{0,62})?[a-z0-9\\u00a1-\\uffff]\\.)*(?:[a-z\\u00a1-\\uffff]{2,}\\.?))(?::\\d{2,5})?(?:[/?#]\\S*)?$/.test(\n url,\n );\n}\n\nexport class URL {\n _url: string;\n _searchParamsInstance = null;\n\n static createObjectURL(blob: Blob): string {\n if (BLOB_URL_PREFIX === null) {\n throw new Error('Cannot create URL for blob!');\n }\n return `${BLOB_URL_PREFIX}${blob.data.blobId}?offset=${blob.data.offset}&size=${blob.size}`;\n }\n\n static revokeObjectURL(url: string) {\n // Do nothing.\n }\n\n // $FlowFixMe[missing-local-annot]\n constructor(url: string, base: string | URL) {\n let baseUrl = null;\n if (!base || validateBaseUrl(url)) {\n this._url = url;\n if (!this._url.endsWith('/')) {\n this._url += '/';\n }\n } else {\n if (typeof base === 'string') {\n baseUrl = base;\n if (!validateBaseUrl(baseUrl)) {\n throw new TypeError(`Invalid base URL: ${baseUrl}`);\n }\n } else {\n baseUrl = base.toString();\n }\n if (baseUrl.endsWith('/')) {\n baseUrl = baseUrl.slice(0, baseUrl.length - 1);\n }\n if (!url.startsWith('/')) {\n url = `/${url}`;\n }\n if (baseUrl.endsWith(url)) {\n url = '';\n }\n this._url = `${baseUrl}${url}`;\n }\n }\n\n get hash(): string {\n throw new Error('URL.hash is not implemented');\n }\n\n get host(): string {\n throw new Error('URL.host is not implemented');\n }\n\n get hostname(): string {\n throw new Error('URL.hostname is not implemented');\n }\n\n get href(): string {\n return this.toString();\n }\n\n get origin(): string {\n throw new Error('URL.origin is not implemented');\n }\n\n get password(): string {\n throw new Error('URL.password is not implemented');\n }\n\n get pathname(): string {\n throw new Error('URL.pathname not implemented');\n }\n\n get port(): string {\n throw new Error('URL.port is not implemented');\n }\n\n get protocol(): string {\n throw new Error('URL.protocol is not implemented');\n }\n\n get search(): string {\n throw new Error('URL.search is not implemented');\n }\n\n get searchParams(): URLSearchParams {\n if (this._searchParamsInstance == null) {\n this._searchParamsInstance = new URLSearchParams();\n }\n return this._searchParamsInstance;\n }\n\n toJSON(): string {\n return this.toString();\n }\n\n toString(): string {\n if (this._searchParamsInstance === null) {\n return this._url;\n }\n const instanceString = this._searchParamsInstance.toString();\n const separator = this._url.indexOf('?') > -1 ? '&' : '?';\n return this._url + separator + instanceString;\n }\n\n get username(): string {\n throw new Error('URL.username is not implemented');\n }\n}\n","/**\n * @author Toru Nagashima \n * See LICENSE file in root directory for full license.\n */\n'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar eventTargetShim = require('event-target-shim');\n\n/**\n * The signal class.\n * @see https://dom.spec.whatwg.org/#abortsignal\n */\nclass AbortSignal extends eventTargetShim.EventTarget {\n /**\n * AbortSignal cannot be constructed directly.\n */\n constructor() {\n super();\n throw new TypeError(\"AbortSignal cannot be constructed directly\");\n }\n /**\n * Returns `true` if this `AbortSignal`'s `AbortController` has signaled to abort, and `false` otherwise.\n */\n get aborted() {\n const aborted = abortedFlags.get(this);\n if (typeof aborted !== \"boolean\") {\n throw new TypeError(`Expected 'this' to be an 'AbortSignal' object, but got ${this === null ? \"null\" : typeof this}`);\n }\n return aborted;\n }\n}\neventTargetShim.defineEventAttribute(AbortSignal.prototype, \"abort\");\n/**\n * Create an AbortSignal object.\n */\nfunction createAbortSignal() {\n const signal = Object.create(AbortSignal.prototype);\n eventTargetShim.EventTarget.call(signal);\n abortedFlags.set(signal, false);\n return signal;\n}\n/**\n * Abort a given signal.\n */\nfunction abortSignal(signal) {\n if (abortedFlags.get(signal) !== false) {\n return;\n }\n abortedFlags.set(signal, true);\n signal.dispatchEvent({ type: \"abort\" });\n}\n/**\n * Aborted flag for each instances.\n */\nconst abortedFlags = new WeakMap();\n// Properties should be enumerable.\nObject.defineProperties(AbortSignal.prototype, {\n aborted: { enumerable: true },\n});\n// `toString()` should return `\"[object AbortSignal]\"`\nif (typeof Symbol === \"function\" && typeof Symbol.toStringTag === \"symbol\") {\n Object.defineProperty(AbortSignal.prototype, Symbol.toStringTag, {\n configurable: true,\n value: \"AbortSignal\",\n });\n}\n\n/**\n * The AbortController.\n * @see https://dom.spec.whatwg.org/#abortcontroller\n */\nclass AbortController {\n /**\n * Initialize this controller.\n */\n constructor() {\n signals.set(this, createAbortSignal());\n }\n /**\n * Returns the `AbortSignal` object associated with this object.\n */\n get signal() {\n return getSignal(this);\n }\n /**\n * Abort and signal to any observers that the associated activity is to be aborted.\n */\n abort() {\n abortSignal(getSignal(this));\n }\n}\n/**\n * Associated signals.\n */\nconst signals = new WeakMap();\n/**\n * Get the associated signal of a given controller.\n */\nfunction getSignal(controller) {\n const signal = signals.get(controller);\n if (signal == null) {\n throw new TypeError(`Expected 'this' to be an 'AbortController' object, but got ${controller === null ? \"null\" : typeof controller}`);\n }\n return signal;\n}\n// Properties should be enumerable.\nObject.defineProperties(AbortController.prototype, {\n signal: { enumerable: true },\n abort: { enumerable: true },\n});\nif (typeof Symbol === \"function\" && typeof Symbol.toStringTag === \"symbol\") {\n Object.defineProperty(AbortController.prototype, Symbol.toStringTag, {\n configurable: true,\n value: \"AbortController\",\n });\n}\n\nexports.AbortController = AbortController;\nexports.AbortSignal = AbortSignal;\nexports.default = AbortController;\n\nmodule.exports = AbortController\nmodule.exports.AbortController = module.exports[\"default\"] = AbortController\nmodule.exports.AbortSignal = AbortSignal\n//# sourceMappingURL=abort-controller.js.map\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 * @flow strict-local\n * @format\n */\n\n'use strict';\n\n/**\n * Set up alert().\n * You can use this module directly, or just require InitializeCore.\n */\nif (!global.alert) {\n global.alert = function (text) {\n // Require Alert on demand. Requiring it too early can lead to issues\n // with things like Platform not being fully initialized.\n require('../Alert/Alert').alert('Alert', '' + text);\n };\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 * @format\n * @flow\n */\n\nimport type {DialogOptions} from '../NativeModules/specs/NativeDialogManagerAndroid';\n\nimport Platform from '../Utilities/Platform';\nimport RCTAlertManager from './RCTAlertManager';\n\nexport type AlertType =\n | 'default'\n | 'plain-text'\n | 'secure-text'\n | 'login-password';\nexport type AlertButtonStyle = 'default' | 'cancel' | 'destructive';\nexport type Buttons = Array<{\n text?: string,\n onPress?: ?Function,\n isPreferred?: boolean,\n style?: AlertButtonStyle,\n ...\n}>;\n\ntype Options = {\n cancelable?: ?boolean,\n userInterfaceStyle?: 'unspecified' | 'light' | 'dark',\n onDismiss?: ?() => void,\n ...\n};\n\n/**\n * Launches an alert dialog with the specified title and message.\n *\n * See https://reactnative.dev/docs/alert\n */\nclass Alert {\n static alert(\n title: ?string,\n message?: ?string,\n buttons?: Buttons,\n options?: Options,\n ): void {\n if (Platform.OS === 'ios') {\n Alert.prompt(\n title,\n message,\n buttons,\n 'default',\n undefined,\n undefined,\n options,\n );\n } else if (Platform.OS === 'android') {\n const NativeDialogManagerAndroid =\n require('../NativeModules/specs/NativeDialogManagerAndroid').default;\n if (!NativeDialogManagerAndroid) {\n return;\n }\n const constants = NativeDialogManagerAndroid.getConstants();\n\n const config: DialogOptions = {\n title: title || '',\n message: message || '',\n cancelable: false,\n };\n\n if (options && options.cancelable) {\n config.cancelable = options.cancelable;\n }\n // At most three buttons (neutral, negative, positive). Ignore rest.\n // The text 'OK' should be probably localized. iOS Alert does that in native.\n const defaultPositiveText = 'OK';\n const validButtons: Buttons = buttons\n ? buttons.slice(0, 3)\n : [{text: defaultPositiveText}];\n const buttonPositive = validButtons.pop();\n const buttonNegative = validButtons.pop();\n const buttonNeutral = validButtons.pop();\n\n if (buttonNeutral) {\n config.buttonNeutral = buttonNeutral.text || '';\n }\n if (buttonNegative) {\n config.buttonNegative = buttonNegative.text || '';\n }\n if (buttonPositive) {\n config.buttonPositive = buttonPositive.text || defaultPositiveText;\n }\n\n /* $FlowFixMe[missing-local-annot] The type annotation(s) required by\n * Flow's LTI update could not be added via codemod */\n const onAction = (action, buttonKey) => {\n if (action === constants.buttonClicked) {\n if (buttonKey === constants.buttonNeutral) {\n buttonNeutral.onPress && buttonNeutral.onPress();\n } else if (buttonKey === constants.buttonNegative) {\n buttonNegative.onPress && buttonNegative.onPress();\n } else if (buttonKey === constants.buttonPositive) {\n buttonPositive.onPress && buttonPositive.onPress();\n }\n } else if (action === constants.dismissed) {\n options && options.onDismiss && options.onDismiss();\n }\n };\n const onError = (errorMessage: string) => console.warn(errorMessage);\n NativeDialogManagerAndroid.showAlert(config, onError, onAction);\n }\n }\n\n static prompt(\n title: ?string,\n message?: ?string,\n callbackOrButtons?: ?(((text: string) => void) | Buttons),\n type?: ?AlertType = 'plain-text',\n defaultValue?: string,\n keyboardType?: string,\n options?: Options,\n ): void {\n if (Platform.OS === 'ios') {\n let callbacks: Array = [];\n const buttons = [];\n let cancelButtonKey;\n let destructiveButtonKey;\n let preferredButtonKey;\n if (typeof callbackOrButtons === 'function') {\n callbacks = [callbackOrButtons];\n } else if (Array.isArray(callbackOrButtons)) {\n callbackOrButtons.forEach((btn, index) => {\n callbacks[index] = btn.onPress;\n if (btn.style === 'cancel') {\n cancelButtonKey = String(index);\n } else if (btn.style === 'destructive') {\n destructiveButtonKey = String(index);\n }\n if (btn.isPreferred) {\n preferredButtonKey = String(index);\n }\n if (btn.text || index < (callbackOrButtons || []).length - 1) {\n const btnDef: {[number]: string} = {};\n btnDef[index] = btn.text || '';\n buttons.push(btnDef);\n }\n });\n }\n\n RCTAlertManager.alertWithArgs(\n {\n title: title || '',\n message: message || undefined,\n buttons,\n type: type || undefined,\n defaultValue,\n cancelButtonKey,\n destructiveButtonKey,\n preferredButtonKey,\n keyboardType,\n userInterfaceStyle: options?.userInterfaceStyle || undefined,\n },\n (id, value) => {\n const cb = callbacks[id];\n cb && cb(value);\n },\n );\n }\n }\n}\n\nmodule.exports = Alert;\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 * @format\n * @flow strict-local\n */\n\nimport type {Args} from './NativeAlertManager';\n\nimport NativeAlertManager from './NativeAlertManager';\n\nmodule.exports = {\n alertWithArgs(\n args: Args,\n callback: (id: number, value: string) => void,\n ): void {\n if (NativeAlertManager == null) {\n return;\n }\n NativeAlertManager.alertWithArgs(args, callback);\n },\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 * @flow\n * @format\n */\n\nimport type {TurboModule} from '../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../TurboModule/TurboModuleRegistry';\n\nexport type Args = {|\n title?: string,\n message?: string,\n buttons?: Array, // TODO(T67565166): have a better type\n type?: string,\n defaultValue?: string,\n cancelButtonKey?: string,\n destructiveButtonKey?: string,\n preferredButtonKey?: string,\n keyboardType?: string,\n userInterfaceStyle?: string,\n|};\n\nexport interface Spec extends TurboModule {\n +alertWithArgs: (\n args: Args,\n callback: (id: number, value: string) => void,\n ) => void;\n}\n\nexport default (TurboModuleRegistry.get('AlertManager'): ?Spec);\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 * @flow strict\n * @format\n */\n\nimport type {TurboModule} from '../../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../../TurboModule/TurboModuleRegistry';\n\n/* 'buttonClicked' | 'dismissed' */\ntype DialogAction = string;\n/*\n buttonPositive = -1,\n buttonNegative = -2,\n buttonNeutral = -3\n*/\ntype DialogButtonKey = number;\nexport type DialogOptions = {|\n title?: string,\n message?: string,\n buttonPositive?: string,\n buttonNegative?: string,\n buttonNeutral?: string,\n items?: Array,\n cancelable?: boolean,\n|};\n\nexport interface Spec extends TurboModule {\n +getConstants: () => {|\n +buttonClicked: DialogAction,\n +dismissed: DialogAction,\n +buttonPositive: DialogButtonKey,\n +buttonNegative: DialogButtonKey,\n +buttonNeutral: DialogButtonKey,\n |};\n +showAlert: (\n config: DialogOptions,\n onError: (error: string) => void,\n onAction: (action: DialogAction, buttonKey?: DialogButtonKey) => void,\n ) => void;\n}\n\nexport default (TurboModuleRegistry.get('DialogManagerAndroid'): ?Spec);\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 * @flow strict\n * @format\n */\n\n'use strict';\n\nconst {polyfillObjectProperty} = require('../Utilities/PolyfillFunctions');\n\nlet navigator = global.navigator;\nif (navigator === undefined) {\n global.navigator = navigator = {};\n}\n\n// see https://github.com/facebook/react-native/issues/10881\npolyfillObjectProperty(navigator, 'product', () => 'ReactNative');\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 * @flow strict-local\n * @format\n */\n\n'use strict';\n\nlet registerModule;\nif (global.RN$Bridgeless === true && global.RN$registerCallableModule) {\n registerModule = global.RN$registerCallableModule;\n} else {\n const BatchedBridge = require('../BatchedBridge/BatchedBridge');\n registerModule = (\n moduleName:\n | $TEMPORARY$string<'GlobalPerformanceLogger'>\n | $TEMPORARY$string<'HMRClient'>\n | $TEMPORARY$string<'HeapCapture'>\n | $TEMPORARY$string<'JSTimers'>\n | $TEMPORARY$string<'RCTDeviceEventEmitter'>\n | $TEMPORARY$string<'RCTLog'>\n | $TEMPORARY$string<'RCTNativeAppEventEmitter'>\n | $TEMPORARY$string<'SamplingProfiler'>\n | $TEMPORARY$string<'Systrace'>,\n /* $FlowFixMe[missing-local-annot] The type annotation(s) required by\n * Flow's LTI update could not be added via codemod */\n factory,\n ) => BatchedBridge.registerLazyCallableModule(moduleName, factory);\n}\n\nregisterModule('Systrace', () => require('../Performance/Systrace'));\nif (!(global.RN$Bridgeless === true)) {\n registerModule('JSTimers', () => require('./Timers/JSTimers'));\n}\nregisterModule('HeapCapture', () => require('../HeapCapture/HeapCapture'));\nregisterModule('SamplingProfiler', () =>\n require('../Performance/SamplingProfiler'),\n);\nregisterModule('RCTLog', () => require('../Utilities/RCTLog'));\nregisterModule(\n 'RCTDeviceEventEmitter',\n () => require('../EventEmitter/RCTDeviceEventEmitter').default,\n);\nregisterModule('RCTNativeAppEventEmitter', () =>\n require('../EventEmitter/RCTNativeAppEventEmitter'),\n);\nregisterModule('GlobalPerformanceLogger', () =>\n require('../Utilities/GlobalPerformanceLogger'),\n);\n\nif (__DEV__) {\n registerModule('HMRClient', () => require('../Utilities/HMRClient'));\n} else {\n registerModule('HMRClient', () => require('../Utilities/HMRClientProdShim'));\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 * @format\n * @flow strict\n */\n\nimport NativeJSCHeapCapture from './NativeJSCHeapCapture';\n\nconst HeapCapture = {\n captureHeap: function (path: string) {\n let error = null;\n try {\n global.nativeCaptureHeap(path);\n console.log('HeapCapture.captureHeap succeeded: ' + path);\n } catch (e) {\n console.log('HeapCapture.captureHeap error: ' + e.toString());\n error = e.toString();\n }\n if (NativeJSCHeapCapture) {\n NativeJSCHeapCapture.captureComplete(path, error);\n }\n },\n};\n\nmodule.exports = HeapCapture;\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 * @flow strict\n * @format\n */\n\nimport type {TurboModule} from '../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../TurboModule/TurboModuleRegistry';\n\nexport interface Spec extends TurboModule {\n +captureComplete: (path: string, error: ?string) => void;\n}\n\nexport default (TurboModuleRegistry.get('JSCHeapCapture'): ?Spec);\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 * @format\n * @flow strict\n */\n\n'use strict';\n\nconst SamplingProfiler = {\n poke: function (token: number): void {\n let error = null;\n let result = null;\n try {\n result = global.pokeSamplingProfiler();\n if (result === null) {\n console.log('The JSC Sampling Profiler has started');\n } else {\n console.log('The JSC Sampling Profiler has stopped');\n }\n } catch (e) {\n console.log(\n 'Error occurred when restarting Sampling Profiler: ' + e.toString(),\n );\n error = e.toString();\n }\n\n const NativeJSCSamplingProfiler =\n require('./NativeJSCSamplingProfiler').default;\n if (NativeJSCSamplingProfiler) {\n NativeJSCSamplingProfiler.operationComplete(token, result, error);\n }\n },\n};\n\nmodule.exports = SamplingProfiler;\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 * @flow strict\n * @format\n */\n\nimport type {TurboModule} from '../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../TurboModule/TurboModuleRegistry';\n\nexport interface Spec extends TurboModule {\n +operationComplete: (token: number, result: ?string, error: ?string) => void;\n}\n\nexport default (TurboModuleRegistry.get('JSCSamplingProfiler'): ?Spec);\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 * @format\n * @flow strict\n */\n\n'use strict';\n\nconst invariant = require('invariant');\n\nconst levelsMap = {\n log: 'log',\n info: 'info',\n warn: 'warn',\n error: 'error',\n fatal: 'error',\n};\n\nlet warningHandler: ?(...Array) => void = null;\n\nconst RCTLog = {\n // level one of log, info, warn, error, mustfix\n logIfNoNativeHook(level: string, ...args: Array): void {\n // We already printed in the native console, so only log here if using a js debugger\n if (typeof global.nativeLoggingHook === 'undefined') {\n RCTLog.logToConsole(level, ...args);\n } else {\n // Report native warnings to LogBox\n if (warningHandler && level === 'warn') {\n warningHandler(...args);\n }\n }\n },\n\n // Log to console regardless of nativeLoggingHook\n logToConsole(level: string, ...args: Array): void {\n const logFn = levelsMap[level];\n invariant(\n logFn,\n 'Level \"' + level + '\" not one of ' + Object.keys(levelsMap).toString(),\n );\n\n console[logFn](...args);\n },\n\n setWarningHandler(handler: typeof warningHandler): void {\n warningHandler = handler;\n },\n};\n\nmodule.exports = RCTLog;\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 * @format\n * @flow strict-local\n */\n\nimport RCTDeviceEventEmitter from './RCTDeviceEventEmitter';\n\n/**\n * Deprecated - subclass NativeEventEmitter to create granular event modules instead of\n * adding all event listeners directly to RCTNativeAppEventEmitter.\n */\nconst RCTNativeAppEventEmitter = RCTDeviceEventEmitter;\nmodule.exports = RCTNativeAppEventEmitter;\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 * @format\n * @flow strict-local\n */\n\n'use strict';\n\nimport type {HMRClientNativeInterface} from './HMRClient';\n\n// This shim ensures DEV binary builds don't crash in JS\n// when they're combined with a PROD JavaScript build.\nconst HMRClientProdShim: HMRClientNativeInterface = {\n setup() {},\n enable() {\n console.error(\n 'Fast Refresh is disabled in JavaScript bundles built in production mode. ' +\n 'Did you forget to run Metro?',\n );\n },\n disable() {},\n registerBundle() {},\n log() {},\n};\n\nmodule.exports = HMRClientProdShim;\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 * @flow strict-local\n * @format\n */\n\n'use strict';\n\nexport type FetchSegmentFunction = typeof __fetchSegment;\nexport type GetSegmentFunction = typeof __getSegment;\n\n/**\n * Set up SegmentFetcher.\n * You can use this module directly, or just require InitializeCore.\n */\n\nfunction __fetchSegment(\n segmentId: number,\n options: $ReadOnly<{\n otaBuildNumber: ?string,\n requestedModuleName: string,\n segmentHash: string,\n }>,\n callback: (?Error) => void,\n) {\n const SegmentFetcher =\n require('./SegmentFetcher/NativeSegmentFetcher').default;\n SegmentFetcher.fetchSegment(\n segmentId,\n options,\n (\n errorObject: ?{\n message: string,\n code: string,\n ...\n },\n ) => {\n if (errorObject) {\n const error = new Error(errorObject.message);\n (error: any).code = errorObject.code; // flowlint-line unclear-type: off\n callback(error);\n }\n\n callback(null);\n },\n );\n}\n\nglobal.__fetchSegment = __fetchSegment;\n\nfunction __getSegment(\n segmentId: number,\n options: $ReadOnly<{\n otaBuildNumber: ?string,\n requestedModuleName: string,\n segmentHash: string,\n }>,\n callback: (?Error, ?string) => void,\n) {\n const SegmentFetcher =\n require('./SegmentFetcher/NativeSegmentFetcher').default;\n\n if (!SegmentFetcher.getSegment) {\n throw new Error('SegmentFetcher.getSegment must be defined');\n }\n\n SegmentFetcher.getSegment(\n segmentId,\n options,\n (\n errorObject: ?{\n message: string,\n code: string,\n ...\n },\n path: ?string,\n ) => {\n if (errorObject) {\n const error = new Error(errorObject.message);\n (error: any).code = errorObject.code; // flowlint-line unclear-type: off\n callback(error);\n }\n\n callback(null, path);\n },\n );\n}\n\nglobal.__getSegment = __getSegment;\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 * @flow strict\n * @format\n */\n\nimport type {TurboModule} from '../../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../../TurboModule/TurboModuleRegistry';\n\nexport interface Spec extends TurboModule {\n +fetchSegment: (\n segmentId: number,\n options: Object, // flowlint-line unclear-type: off\n callback: (error: ?Object) => void, // flowlint-line unclear-type: off\n ) => void;\n +getSegment?: (\n segmentId: number,\n options: Object, // flowlint-line unclear-type: off\n callback: (error: ?Object, path: ?string) => void, // flowlint-line unclear-type: off\n ) => void;\n}\n\nexport default (TurboModuleRegistry.getEnforcing('SegmentFetcher'): Spec);\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 * @flow\n * @format\n */\n\nimport type {RootTag} from '../Types/RootTagTypes';\nimport type {IPerformanceLogger} from '../Utilities/createPerformanceLogger';\n\nimport BatchedBridge from '../BatchedBridge/BatchedBridge';\nimport BugReporting from '../BugReporting/BugReporting';\nimport createPerformanceLogger from '../Utilities/createPerformanceLogger';\nimport infoLog from '../Utilities/infoLog';\nimport SceneTracker from '../Utilities/SceneTracker';\nimport {coerceDisplayMode} from './DisplayMode';\nimport HeadlessJsTaskError from './HeadlessJsTaskError';\nimport NativeHeadlessJsTaskSupport from './NativeHeadlessJsTaskSupport';\nimport renderApplication from './renderApplication';\nimport {unmountComponentAtNodeAndRemoveContainer} from './RendererProxy';\nimport invariant from 'invariant';\n\ntype Task = (taskData: any) => Promise;\nexport type TaskProvider = () => Task;\ntype TaskCanceller = () => void;\ntype TaskCancelProvider = () => TaskCanceller;\n\nexport type ComponentProvider = () => React$ComponentType;\nexport type ComponentProviderInstrumentationHook = (\n component: ComponentProvider,\n scopedPerformanceLogger: IPerformanceLogger,\n) => React$ComponentType;\nexport type AppConfig = {\n appKey: string,\n component?: ComponentProvider,\n run?: Function,\n section?: boolean,\n ...\n};\nexport type Runnable = {\n component?: ComponentProvider,\n run: Function,\n ...\n};\nexport type Runnables = {[appKey: string]: Runnable, ...};\nexport type Registry = {\n sections: Array,\n runnables: Runnables,\n ...\n};\nexport type WrapperComponentProvider = (\n appParameters: any,\n) => React$ComponentType;\n\nconst runnables: Runnables = {};\nlet runCount = 1;\nconst sections: Runnables = {};\nconst taskProviders: Map = new Map();\nconst taskCancelProviders: Map = new Map();\nlet componentProviderInstrumentationHook: ComponentProviderInstrumentationHook =\n (component: ComponentProvider) => component();\n\nlet wrapperComponentProvider: ?WrapperComponentProvider;\nlet showArchitectureIndicator = false;\n\n/**\n * `AppRegistry` is the JavaScript entry point to running all React Native apps.\n *\n * See https://reactnative.dev/docs/appregistry\n */\nconst AppRegistry = {\n setWrapperComponentProvider(provider: WrapperComponentProvider) {\n wrapperComponentProvider = provider;\n },\n\n enableArchitectureIndicator(enabled: boolean): void {\n showArchitectureIndicator = enabled;\n },\n\n registerConfig(config: Array): void {\n config.forEach(appConfig => {\n if (appConfig.run) {\n AppRegistry.registerRunnable(appConfig.appKey, appConfig.run);\n } else {\n invariant(\n appConfig.component != null,\n 'AppRegistry.registerConfig(...): Every config is expected to set ' +\n 'either `run` or `component`, but `%s` has neither.',\n appConfig.appKey,\n );\n AppRegistry.registerComponent(\n appConfig.appKey,\n appConfig.component,\n appConfig.section,\n );\n }\n });\n },\n\n /**\n * Registers an app's root component.\n *\n * See https://reactnative.dev/docs/appregistry#registercomponent\n */\n registerComponent(\n appKey: string,\n componentProvider: ComponentProvider,\n section?: boolean,\n ): string {\n let scopedPerformanceLogger = createPerformanceLogger();\n runnables[appKey] = {\n componentProvider,\n run: (appParameters, displayMode) => {\n const concurrentRootEnabled =\n appParameters.initialProps?.concurrentRoot ||\n appParameters.concurrentRoot;\n renderApplication(\n componentProviderInstrumentationHook(\n componentProvider,\n scopedPerformanceLogger,\n ),\n appParameters.initialProps,\n appParameters.rootTag,\n wrapperComponentProvider && wrapperComponentProvider(appParameters),\n appParameters.fabric,\n showArchitectureIndicator,\n scopedPerformanceLogger,\n appKey === 'LogBox',\n appKey,\n coerceDisplayMode(displayMode),\n concurrentRootEnabled,\n );\n },\n };\n if (section) {\n sections[appKey] = runnables[appKey];\n }\n return appKey;\n },\n\n registerRunnable(appKey: string, run: Function): string {\n runnables[appKey] = {run};\n return appKey;\n },\n\n registerSection(appKey: string, component: ComponentProvider): void {\n AppRegistry.registerComponent(appKey, component, true);\n },\n\n getAppKeys(): Array {\n return Object.keys(runnables);\n },\n\n getSectionKeys(): Array {\n return Object.keys(sections);\n },\n\n getSections(): Runnables {\n return {\n ...sections,\n };\n },\n\n getRunnable(appKey: string): ?Runnable {\n return runnables[appKey];\n },\n\n getRegistry(): Registry {\n return {\n sections: AppRegistry.getSectionKeys(),\n runnables: {...runnables},\n };\n },\n\n setComponentProviderInstrumentationHook(\n hook: ComponentProviderInstrumentationHook,\n ) {\n componentProviderInstrumentationHook = hook;\n },\n\n /**\n * Loads the JavaScript bundle and runs the app.\n *\n * See https://reactnative.dev/docs/appregistry#runapplication\n */\n runApplication(\n appKey: string,\n appParameters: any,\n displayMode?: number,\n ): void {\n if (appKey !== 'LogBox') {\n const logParams = __DEV__\n ? '\" with ' + JSON.stringify(appParameters)\n : '';\n const msg = 'Running \"' + appKey + logParams;\n infoLog(msg);\n BugReporting.addSource(\n 'AppRegistry.runApplication' + runCount++,\n () => msg,\n );\n }\n invariant(\n runnables[appKey] && runnables[appKey].run,\n `\"${appKey}\" has not been registered. This can happen if:\\n` +\n '* Metro (the local dev server) is run from the wrong folder. ' +\n 'Check if Metro is running, stop it and restart it in the current project.\\n' +\n \"* A module failed to load due to an error and `AppRegistry.registerComponent` wasn't called.\",\n );\n\n SceneTracker.setActiveScene({name: appKey});\n runnables[appKey].run(appParameters, displayMode);\n },\n\n /**\n * Update initial props for a surface that's already rendered\n */\n setSurfaceProps(\n appKey: string,\n appParameters: any,\n displayMode?: number,\n ): void {\n if (appKey !== 'LogBox') {\n const msg =\n 'Updating props for Surface \"' +\n appKey +\n '\" with ' +\n JSON.stringify(appParameters);\n infoLog(msg);\n BugReporting.addSource(\n 'AppRegistry.setSurfaceProps' + runCount++,\n () => msg,\n );\n }\n invariant(\n runnables[appKey] && runnables[appKey].run,\n `\"${appKey}\" has not been registered. This can happen if:\\n` +\n '* Metro (the local dev server) is run from the wrong folder. ' +\n 'Check if Metro is running, stop it and restart it in the current project.\\n' +\n \"* A module failed to load due to an error and `AppRegistry.registerComponent` wasn't called.\",\n );\n\n runnables[appKey].run(appParameters, displayMode);\n },\n\n /**\n * Stops an application when a view should be destroyed.\n *\n * See https://reactnative.dev/docs/appregistry#unmountapplicationcomponentatroottag\n */\n unmountApplicationComponentAtRootTag(rootTag: RootTag): void {\n unmountComponentAtNodeAndRemoveContainer(rootTag);\n },\n\n /**\n * Register a headless task. A headless task is a bit of code that runs without a UI.\n *\n * See https://reactnative.dev/docs/appregistry#registerheadlesstask\n */\n registerHeadlessTask(taskKey: string, taskProvider: TaskProvider): void {\n // $FlowFixMe[object-this-reference]\n this.registerCancellableHeadlessTask(taskKey, taskProvider, () => () => {\n /* Cancel is no-op */\n });\n },\n\n /**\n * Register a cancellable headless task. A headless task is a bit of code that runs without a UI.\n *\n * See https://reactnative.dev/docs/appregistry#registercancellableheadlesstask\n */\n registerCancellableHeadlessTask(\n taskKey: string,\n taskProvider: TaskProvider,\n taskCancelProvider: TaskCancelProvider,\n ): void {\n if (taskProviders.has(taskKey)) {\n console.warn(\n `registerHeadlessTask or registerCancellableHeadlessTask called multiple times for same key '${taskKey}'`,\n );\n }\n taskProviders.set(taskKey, taskProvider);\n taskCancelProviders.set(taskKey, taskCancelProvider);\n },\n\n /**\n * Only called from native code. Starts a headless task.\n *\n * See https://reactnative.dev/docs/appregistry#startheadlesstask\n */\n startHeadlessTask(taskId: number, taskKey: string, data: any): void {\n const taskProvider = taskProviders.get(taskKey);\n if (!taskProvider) {\n console.warn(`No task registered for key ${taskKey}`);\n if (NativeHeadlessJsTaskSupport) {\n NativeHeadlessJsTaskSupport.notifyTaskFinished(taskId);\n }\n return;\n }\n taskProvider()(data)\n .then(() => {\n if (NativeHeadlessJsTaskSupport) {\n NativeHeadlessJsTaskSupport.notifyTaskFinished(taskId);\n }\n })\n .catch(reason => {\n console.error(reason);\n\n if (\n NativeHeadlessJsTaskSupport &&\n reason instanceof HeadlessJsTaskError\n ) {\n NativeHeadlessJsTaskSupport.notifyTaskRetry(taskId).then(\n retryPosted => {\n if (!retryPosted) {\n NativeHeadlessJsTaskSupport.notifyTaskFinished(taskId);\n }\n },\n );\n }\n });\n },\n\n /**\n * Only called from native code. Cancels a headless task.\n *\n * See https://reactnative.dev/docs/appregistry#cancelheadlesstask\n */\n cancelHeadlessTask(taskId: number, taskKey: string): void {\n const taskCancelProvider = taskCancelProviders.get(taskKey);\n if (!taskCancelProvider) {\n throw new Error(`No task canceller registered for key '${taskKey}'`);\n }\n taskCancelProvider()();\n },\n};\n\nif (!(global.RN$Bridgeless === true)) {\n BatchedBridge.registerCallableModule('AppRegistry', AppRegistry);\n\n if (__DEV__) {\n const LogBoxInspector =\n require('../LogBox/LogBoxInspectorContainer').default;\n AppRegistry.registerComponent('LogBox', () => LogBoxInspector);\n } else {\n AppRegistry.registerComponent(\n 'LogBox',\n () =>\n function NoOp() {\n return null;\n },\n );\n }\n}\n\nmodule.exports = AppRegistry;\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 * @format\n * @flow strict-local\n */\n\nimport RCTDeviceEventEmitter from '../EventEmitter/RCTDeviceEventEmitter';\nimport NativeRedBox from '../NativeModules/specs/NativeRedBox';\nimport {type EventSubscription} from '../vendor/emitter/EventEmitter';\nimport NativeBugReporting from './NativeBugReporting';\n\ntype ExtraData = {[key: string]: string, ...};\ntype SourceCallback = () => string;\ntype DebugData = {\n extras: ExtraData,\n files: ExtraData,\n ...\n};\n\nfunction defaultExtras() {\n BugReporting.addFileSource('react_hierarchy.txt', () =>\n require('./dumpReactTree')(),\n );\n}\n\n/**\n * A simple class for collecting bug report data. Components can add sources that will be queried when a bug report\n * is created via `collectExtraData`. For example, a list component might add a source that provides the list of rows\n * that are currently visible on screen. Components should also remember to call `remove()` on the object that is\n * returned by `addSource` when they are unmounted.\n */\nclass BugReporting {\n static _extraSources: Map = new Map();\n static _fileSources: Map = new Map();\n static _subscription: ?EventSubscription = null;\n static _redboxSubscription: ?EventSubscription = null;\n\n static _maybeInit() {\n if (!BugReporting._subscription) {\n BugReporting._subscription = RCTDeviceEventEmitter.addListener(\n 'collectBugExtraData',\n // $FlowFixMe[method-unbinding]\n BugReporting.collectExtraData,\n null,\n );\n defaultExtras();\n }\n\n if (!BugReporting._redboxSubscription) {\n BugReporting._redboxSubscription = RCTDeviceEventEmitter.addListener(\n 'collectRedBoxExtraData',\n // $FlowFixMe[method-unbinding]\n BugReporting.collectExtraData,\n null,\n );\n }\n }\n\n /**\n * Maps a string key to a simple callback that should return a string payload to be attached\n * to a bug report. Source callbacks are called when `collectExtraData` is called.\n *\n * Returns an object to remove the source when the component unmounts.\n *\n * Conflicts trample with a warning.\n */\n static addSource(\n key: string,\n callback: SourceCallback,\n ): {remove: () => void, ...} {\n return this._addSource(key, callback, BugReporting._extraSources);\n }\n\n /**\n * Maps a string key to a simple callback that should return a string payload to be attached\n * to a bug report. Source callbacks are called when `collectExtraData` is called.\n *\n * Returns an object to remove the source when the component unmounts.\n *\n * Conflicts trample with a warning.\n */\n static addFileSource(\n key: string,\n callback: SourceCallback,\n ): {remove: () => void, ...} {\n return this._addSource(key, callback, BugReporting._fileSources);\n }\n\n static _addSource(\n key: string,\n callback: SourceCallback,\n source: Map,\n ): {remove: () => void, ...} {\n BugReporting._maybeInit();\n if (source.has(key)) {\n console.warn(\n `BugReporting.add* called multiple times for same key '${key}'`,\n );\n }\n source.set(key, callback);\n return {\n remove: () => {\n source.delete(key);\n },\n };\n }\n\n /**\n * This can be called from a native bug reporting flow, or from JS code.\n *\n * If available, this will call `NativeModules.BugReporting.setExtraData(extraData)`\n * after collecting `extraData`.\n */\n static collectExtraData(): DebugData {\n const extraData: ExtraData = {};\n for (const [key, callback] of BugReporting._extraSources) {\n extraData[key] = callback();\n }\n const fileData: ExtraData = {};\n for (const [key, callback] of BugReporting._fileSources) {\n fileData[key] = callback();\n }\n\n if (NativeBugReporting != null && NativeBugReporting.setExtraData != null) {\n NativeBugReporting.setExtraData(extraData, fileData);\n }\n\n if (NativeRedBox != null && NativeRedBox.setExtraData != null) {\n NativeRedBox.setExtraData(extraData, 'From BugReporting.js');\n }\n\n return {extras: extraData, files: fileData};\n }\n}\n\nmodule.exports = BugReporting;\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 * @flow\n * @format\n */\n\nimport type {TurboModule} from '../../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../../TurboModule/TurboModuleRegistry';\n\nexport interface Spec extends TurboModule {\n +setExtraData: (extraData: Object, forIdentifier: string) => void;\n +dismiss: () => void;\n}\n\nexport default (TurboModuleRegistry.get('RedBox'): ?Spec);\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 * @format\n * @flow\n */\n\nimport type {TurboModule} from '../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../TurboModule/TurboModuleRegistry';\n\nexport interface Spec extends TurboModule {\n +startReportAProblemFlow: () => void;\n +setExtraData: (extraData: Object, extraFiles: Object) => void;\n +setCategoryID: (categoryID: string) => void;\n}\n\nexport default (TurboModuleRegistry.get('BugReporting'): ?Spec);\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 * @format\n * @flow strict\n */\n\n'use strict';\n\n/*\nconst getReactData = require('getReactData');\n\nconst INDENTATION_SIZE = 2;\nconst MAX_DEPTH = 2;\nconst MAX_STRING_LENGTH = 50;\n*/\n\n/**\n * Dump all React Native root views and their content. This function tries\n * it best to get the content but ultimately relies on implementation details\n * of React and will fail in future versions.\n */\nfunction dumpReactTree(): string {\n try {\n return getReactTree();\n } catch (e) {\n return 'Failed to dump react tree: ' + e;\n }\n}\n\nfunction getReactTree() {\n // TODO(sema): Reenable tree dumps using the Fiber tree structure. #15945684\n return (\n 'React tree dumps have been temporarily disabled while React is ' +\n 'upgraded to Fiber.'\n );\n /*\n let output = '';\n const rootIds = Object.getOwnPropertyNames(ReactNativeMount._instancesByContainerID);\n for (const rootId of rootIds) {\n const instance = ReactNativeMount._instancesByContainerID[rootId];\n output += `============ Root ID: ${rootId} ============\\n`;\n output += dumpNode(instance, 0);\n output += `============ End root ID: ${rootId} ============\\n`;\n }\n return output;\n*/\n}\n\n/*\nfunction dumpNode(node: Object, indentation: number) {\n const data = getReactData(node);\n if (data.nodeType === 'Text') {\n return indent(indentation) + data.text + '\\n';\n } else if (data.nodeType === 'Empty') {\n return '';\n }\n let output = indent(indentation) + `<${data.name}`;\n if (data.nodeType === 'Composite') {\n for (const propName of Object.getOwnPropertyNames(data.props || {})) {\n if (isNormalProp(propName)) {\n try {\n const value = convertValue(data.props[propName]);\n if (value) {\n output += ` ${propName}=${value}`;\n }\n } catch (e) {\n const message = `[Failed to get property: ${e}]`;\n output += ` ${propName}=${message}`;\n }\n }\n }\n }\n let childOutput = '';\n for (const child of data.children || []) {\n childOutput += dumpNode(child, indentation + 1);\n }\n\n if (childOutput) {\n output += '>\\n' + childOutput + indent(indentation) + `\\n`;\n } else {\n output += ' />\\n';\n }\n\n return output;\n}\n\nfunction isNormalProp(name: string): boolean {\n switch (name) {\n case 'children':\n case 'key':\n case 'ref':\n return false;\n default:\n return true;\n }\n}\n\nfunction convertObject(object: Object, depth: number) {\n if (depth >= MAX_DEPTH) {\n return '[...omitted]';\n }\n let output = '{';\n let first = true;\n for (const key of Object.getOwnPropertyNames(object)) {\n if (!first) {\n output += ', ';\n }\n output += `${key}: ${convertValue(object[key], depth + 1)}`;\n first = false;\n }\n return output + '}';\n}\n\nfunction convertValue(value, depth = 0): ?string {\n if (!value) {\n return null;\n }\n\n switch (typeof value) {\n case 'string':\n return JSON.stringify(possiblyEllipsis(value).replace('\\n', '\\\\n'));\n case 'boolean':\n case 'number':\n return JSON.stringify(value);\n case 'function':\n return '[function]';\n case 'object':\n return convertObject(value, depth);\n default:\n return null;\n }\n}\n\nfunction possiblyEllipsis(value: string) {\n if (value.length > MAX_STRING_LENGTH) {\n return value.slice(0, MAX_STRING_LENGTH) + '...';\n } else {\n return value;\n }\n}\n\nfunction indent(size: number) {\n return ' '.repeat(size * INDENTATION_SIZE);\n}\n*/\n\nmodule.exports = dumpReactTree;\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 * @format\n * @flow strict\n */\n\n'use strict';\n\n/**\n * Intentional info-level logging for clear separation from ad-hoc console debug logging.\n */\nfunction infoLog(...args: Array): void {\n return console.log(...args);\n}\n\nmodule.exports = infoLog;\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 * @format\n * @flow strict\n */\n\n'use strict';\n\nexport type Scene = {name: string, ...};\n\nlet _listeners: Array<(scene: Scene) => void> = [];\n\nlet _activeScene = {name: 'default'};\n\nconst SceneTracker = {\n setActiveScene(scene: Scene) {\n _activeScene = scene;\n _listeners.forEach(listener => listener(_activeScene));\n },\n\n getActiveScene(): Scene {\n return _activeScene;\n },\n\n addActiveSceneChangedListener(callback: (scene: Scene) => void): {\n remove: () => void,\n ...\n } {\n _listeners.push(callback);\n return {\n remove: () => {\n _listeners = _listeners.filter(listener => callback !== listener);\n },\n };\n },\n};\n\nmodule.exports = SceneTracker;\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 * @flow strict-local\n * @format\n */\n\nexport default class HeadlessJsTaskError extends Error {}\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 * @flow strict\n * @format\n */\n\nimport type {TurboModule} from '../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../TurboModule/TurboModuleRegistry';\n\nexport interface Spec extends TurboModule {\n +notifyTaskFinished: (taskId: number) => void;\n +notifyTaskRetry: (taskId: number) => Promise;\n}\n\nexport default (TurboModuleRegistry.get('HeadlessJsTaskSupport'): ?Spec);\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 * @format\n * @flow\n */\n\nimport type {IPerformanceLogger} from '../Utilities/createPerformanceLogger';\n\nimport GlobalPerformanceLogger from '../Utilities/GlobalPerformanceLogger';\nimport PerformanceLoggerContext from '../Utilities/PerformanceLoggerContext';\nimport AppContainer from './AppContainer';\nimport DisplayMode, {type DisplayModeType} from './DisplayMode';\nimport getCachedComponentWithDebugName from './getCachedComponentWithDebugName';\nimport * as Renderer from './RendererProxy';\nimport invariant from 'invariant';\nimport * as React from 'react';\n\n// require BackHandler so it sets the default handler that exits the app if no listeners respond\nimport '../Utilities/BackHandler';\n\ntype OffscreenType = React.AbstractComponent<{\n mode: 'visible' | 'hidden',\n children: React.Node,\n}>;\n\nexport default function renderApplication(\n RootComponent: React.ComponentType,\n initialProps: Props,\n rootTag: any,\n WrapperComponent?: ?React.ComponentType,\n fabric?: boolean,\n showArchitectureIndicator?: boolean,\n scopedPerformanceLogger?: IPerformanceLogger,\n isLogBox?: boolean,\n debugName?: string,\n displayMode?: ?DisplayModeType,\n useConcurrentRoot?: boolean,\n useOffscreen?: boolean,\n) {\n invariant(rootTag, 'Expect to have a valid rootTag, instead got ', rootTag);\n\n const performanceLogger = scopedPerformanceLogger ?? GlobalPerformanceLogger;\n\n let renderable: React.MixedElement = (\n \n \n \n \n \n );\n\n if (__DEV__ && debugName) {\n const RootComponentWithMeaningfulName = getCachedComponentWithDebugName(\n `${debugName}(RootComponent)`,\n );\n renderable = (\n \n {renderable}\n \n );\n }\n\n if (useOffscreen && displayMode != null) {\n // $FlowFixMe[incompatible-type]\n // $FlowFixMe[prop-missing]\n const Offscreen: OffscreenType = React.unstable_Offscreen;\n\n renderable = (\n \n {renderable}\n \n );\n }\n\n performanceLogger.startTimespan('renderApplication_React_render');\n performanceLogger.setExtra(\n 'usedReactConcurrentRoot',\n useConcurrentRoot ? '1' : '0',\n );\n performanceLogger.setExtra('usedReactFabric', fabric ? '1' : '0');\n performanceLogger.setExtra(\n 'usedReactProfiler',\n Renderer.isProfilingRenderer(),\n );\n Renderer.renderElement({\n element: renderable,\n rootTag,\n useFabric: Boolean(fabric),\n useConcurrentRoot: Boolean(useConcurrentRoot),\n });\n performanceLogger.stopTimespan('renderApplication_React_render');\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 * @flow strict\n * @format\n */\n\nimport type {IPerformanceLogger} from './createPerformanceLogger';\n\nimport GlobalPerformanceLogger from './GlobalPerformanceLogger';\nimport * as React from 'react';\nimport {useContext} from 'react';\n\n/**\n * This is a React Context that provides a scoped instance of IPerformanceLogger.\n * We wrap every with a Provider for this context so the logger\n * should be available in every component.\n * See React docs about using Context: https://reactjs.org/docs/context.html\n */\nconst PerformanceLoggerContext: React.Context =\n React.createContext(GlobalPerformanceLogger);\nif (__DEV__) {\n PerformanceLoggerContext.displayName = 'PerformanceLoggerContext';\n}\n\nexport function usePerformanceLogger(): IPerformanceLogger {\n return useContext(PerformanceLoggerContext);\n}\n\nexport default PerformanceLoggerContext;\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 * @format\n * @flow\n */\n\nimport type {RootTag} from './RootTag';\n\nimport View from '../Components/View/View';\nimport RCTDeviceEventEmitter from '../EventEmitter/RCTDeviceEventEmitter';\nimport StyleSheet from '../StyleSheet/StyleSheet';\nimport {type EventSubscription} from '../vendor/emitter/EventEmitter';\nimport {RootTagContext, createRootTag} from './RootTag';\nimport * as React from 'react';\n\ntype Props = $ReadOnly<{|\n children?: React.Node,\n fabric?: boolean,\n useConcurrentRoot?: boolean,\n rootTag: number | RootTag,\n initialProps?: {...},\n showArchitectureIndicator?: boolean,\n WrapperComponent?: ?React.ComponentType,\n internal_excludeLogBox?: ?boolean,\n internal_excludeInspector?: ?boolean,\n|}>;\n\ntype State = {|\n inspector: ?React.Node,\n devtoolsOverlay: ?React.Node,\n mainKey: number,\n hasError: boolean,\n|};\n\nclass AppContainer extends React.Component {\n state: State = {\n inspector: null,\n devtoolsOverlay: null,\n mainKey: 1,\n hasError: false,\n };\n _mainRef: ?React.ElementRef;\n _subscription: ?EventSubscription = null;\n\n static getDerivedStateFromError: any = undefined;\n\n componentDidMount(): void {\n if (__DEV__) {\n if (!this.props.internal_excludeInspector) {\n this._subscription = RCTDeviceEventEmitter.addListener(\n 'toggleElementInspector',\n () => {\n const Inspector = require('../Inspector/Inspector');\n const inspector = this.state.inspector ? null : (\n {\n this.setState(\n s => ({mainKey: s.mainKey + 1}),\n () => updateInspectedView(this._mainRef),\n );\n }}\n />\n );\n this.setState({inspector});\n },\n );\n if (window.__REACT_DEVTOOLS_GLOBAL_HOOK__ != null) {\n const DevtoolsOverlay =\n require('../Inspector/DevtoolsOverlay').default;\n const devtoolsOverlay = (\n \n );\n this.setState({devtoolsOverlay});\n }\n }\n }\n }\n\n componentWillUnmount(): void {\n if (this._subscription != null) {\n this._subscription.remove();\n }\n }\n\n render(): React.Node {\n let logBox = null;\n if (__DEV__) {\n if (!this.props.internal_excludeLogBox) {\n const LogBoxNotificationContainer =\n require('../LogBox/LogBoxNotificationContainer').default;\n logBox = ;\n }\n }\n\n let innerView: React.Node = (\n {\n this._mainRef = ref;\n }}>\n {this.props.children}\n \n );\n\n const Wrapper = this.props.WrapperComponent;\n if (Wrapper != null) {\n innerView = (\n \n {innerView}\n \n );\n }\n return (\n \n \n {!this.state.hasError && innerView}\n {this.state.devtoolsOverlay}\n {this.state.inspector}\n {logBox}\n \n \n );\n }\n}\n\nconst styles = StyleSheet.create({\n appContainer: {\n flex: 1,\n },\n});\n\nmodule.exports = AppContainer;\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 * @format\n * @flow strict-local\n */\n\nimport type {ViewProps} from './ViewPropTypes';\n\nimport flattenStyle from '../../StyleSheet/flattenStyle';\nimport TextAncestor from '../../Text/TextAncestor';\nimport {getAccessibilityRoleFromRole} from '../../Utilities/AcessibilityMapping';\nimport ViewNativeComponent from './ViewNativeComponent';\nimport * as React from 'react';\n\nexport type Props = ViewProps;\n\n/**\n * The most fundamental component for building a UI, View is a container that\n * supports layout with flexbox, style, some touch handling, and accessibility\n * controls.\n *\n * @see https://reactnative.dev/docs/view\n */\nconst View: React.AbstractComponent<\n ViewProps,\n React.ElementRef,\n> = React.forwardRef(\n (\n {\n accessibilityElementsHidden,\n accessibilityLabel,\n accessibilityLabelledBy,\n accessibilityLiveRegion,\n accessibilityRole,\n accessibilityState,\n accessibilityValue,\n 'aria-busy': ariaBusy,\n 'aria-checked': ariaChecked,\n 'aria-disabled': ariaDisabled,\n 'aria-expanded': ariaExpanded,\n 'aria-hidden': ariaHidden,\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabelledBy,\n 'aria-live': ariaLive,\n 'aria-selected': ariaSelected,\n 'aria-valuemax': ariaValueMax,\n 'aria-valuemin': ariaValueMin,\n 'aria-valuenow': ariaValueNow,\n 'aria-valuetext': ariaValueText,\n focusable,\n id,\n importantForAccessibility,\n nativeID,\n pointerEvents,\n role,\n style,\n tabIndex,\n ...otherProps\n }: ViewProps,\n forwardedRef,\n ) => {\n const _accessibilityLabelledBy =\n ariaLabelledBy?.split(/\\s*,\\s*/g) ?? accessibilityLabelledBy;\n\n const _accessibilityState = {\n busy: ariaBusy ?? accessibilityState?.busy,\n checked: ariaChecked ?? accessibilityState?.checked,\n disabled: ariaDisabled ?? accessibilityState?.disabled,\n expanded: ariaExpanded ?? accessibilityState?.expanded,\n selected: ariaSelected ?? accessibilityState?.selected,\n };\n\n const _accessibilityValue = {\n max: ariaValueMax ?? accessibilityValue?.max,\n min: ariaValueMin ?? accessibilityValue?.min,\n now: ariaValueNow ?? accessibilityValue?.now,\n text: ariaValueText ?? accessibilityValue?.text,\n };\n\n const flattenedStyle = flattenStyle(style);\n const newPointerEvents = flattenedStyle?.pointerEvents || pointerEvents;\n\n return (\n \n \n \n );\n },\n);\n\nView.displayName = 'View';\n\nmodule.exports = View;\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 * @flow strict-local\n * @format\n */\n\n'use strict';\n\nimport type {DangerouslyImpreciseStyleProp} from './StyleSheet';\nimport type {____FlattenStyleProp_Internal} from './StyleSheetTypes';\n\nfunction flattenStyle<+TStyleProp: DangerouslyImpreciseStyleProp>(\n style: ?TStyleProp,\n): ?____FlattenStyleProp_Internal {\n if (style === null || typeof style !== 'object') {\n return undefined;\n }\n\n if (!Array.isArray(style)) {\n return style;\n }\n\n const result: {[string]: $FlowFixMe} = {};\n for (let i = 0, styleLength = style.length; i < styleLength; ++i) {\n const computedStyle = flattenStyle(style[i]);\n if (computedStyle) {\n for (const key in computedStyle) {\n result[key] = computedStyle[key];\n }\n }\n }\n return result;\n}\n\nmodule.exports = flattenStyle;\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 * @flow strict\n * @format\n */\n\n'use strict';\n\nconst React = require('react');\n\n/**\n * Whether the current element is the descendant of a element.\n */\nconst TextAncestorContext = (React.createContext(\n false,\n): React$Context<$FlowFixMe>);\nif (__DEV__) {\n TextAncestorContext.displayName = 'TextAncestorContext';\n}\nmodule.exports = TextAncestorContext;\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 * @flow strict-local\n * @format\n */\n\nimport type {\n HostComponent,\n PartialViewConfig,\n} from '../../Renderer/shims/ReactNativeTypes';\n\nimport * as NativeComponentRegistry from '../../NativeComponent/NativeComponentRegistry';\nimport codegenNativeCommands from '../../Utilities/codegenNativeCommands';\nimport Platform from '../../Utilities/Platform';\nimport {type ViewProps as Props} from './ViewPropTypes';\nimport * as React from 'react';\n\nexport const __INTERNAL_VIEW_CONFIG: PartialViewConfig =\n Platform.OS === 'android'\n ? {\n uiViewClassName: 'RCTView',\n validAttributes: {\n // ReactClippingViewManager @ReactProps\n removeClippedSubviews: true,\n\n // ReactViewManager @ReactProps\n accessible: true,\n hasTVPreferredFocus: true,\n nextFocusDown: true,\n nextFocusForward: true,\n nextFocusLeft: true,\n nextFocusRight: true,\n nextFocusUp: true,\n\n borderRadius: true,\n borderTopLeftRadius: true,\n borderTopRightRadius: true,\n borderBottomRightRadius: true,\n borderBottomLeftRadius: true,\n borderTopStartRadius: true,\n borderTopEndRadius: true,\n borderBottomStartRadius: true,\n borderBottomEndRadius: true,\n\n borderStyle: true,\n hitSlop: true,\n pointerEvents: true,\n nativeBackgroundAndroid: true,\n nativeForegroundAndroid: true,\n needsOffscreenAlphaCompositing: true,\n\n borderWidth: true,\n borderLeftWidth: true,\n borderRightWidth: true,\n borderTopWidth: true,\n borderBottomWidth: true,\n borderStartWidth: true,\n borderEndWidth: true,\n\n borderColor: {process: require('../../StyleSheet/processColor')},\n borderLeftColor: {process: require('../../StyleSheet/processColor')},\n borderRightColor: {process: require('../../StyleSheet/processColor')},\n borderTopColor: {process: require('../../StyleSheet/processColor')},\n borderBottomColor: {\n process: require('../../StyleSheet/processColor'),\n },\n borderStartColor: {process: require('../../StyleSheet/processColor')},\n borderEndColor: {process: require('../../StyleSheet/processColor')},\n\n focusable: true,\n overflow: true,\n backfaceVisibility: true,\n },\n }\n : {\n uiViewClassName: 'RCTView',\n };\n\nconst ViewNativeComponent: HostComponent =\n NativeComponentRegistry.get('RCTView', () => __INTERNAL_VIEW_CONFIG);\n\ninterface NativeCommands {\n +hotspotUpdate: (\n viewRef: React.ElementRef>,\n x: number,\n y: number,\n ) => void;\n +setPressed: (\n viewRef: React.ElementRef>,\n pressed: boolean,\n ) => void;\n}\n\nexport const Commands: NativeCommands = codegenNativeCommands({\n supportedCommands: ['hotspotUpdate', 'setPressed'],\n});\n\nexport default ViewNativeComponent;\n\nexport type ViewNativeComponentType = HostComponent;\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 * @flow strict-local\n * @format\n */\n\nimport type {\n HostComponent,\n PartialViewConfig,\n} from '../Renderer/shims/ReactNativeTypes';\n\nimport getNativeComponentAttributes from '../ReactNative/getNativeComponentAttributes';\nimport UIManager from '../ReactNative/UIManager';\nimport ReactNativeViewConfigRegistry from '../Renderer/shims/ReactNativeViewConfigRegistry';\nimport verifyComponentAttributeEquivalence from '../Utilities/verifyComponentAttributeEquivalence';\nimport * as StaticViewConfigValidator from './StaticViewConfigValidator';\nimport {createViewConfig} from './ViewConfig';\nimport invariant from 'invariant';\nimport * as React from 'react';\n\nlet getRuntimeConfig;\n\n/**\n * Configures a function that is called to determine whether a given component\n * should be registered using reflection of the native component at runtime.\n *\n * The provider should return null if the native component is unavailable in\n * the current environment.\n */\nexport function setRuntimeConfigProvider(\n runtimeConfigProvider: (name: string) => ?{\n native: boolean,\n strict: boolean,\n verify: boolean,\n },\n): void {\n invariant(\n getRuntimeConfig == null,\n 'NativeComponentRegistry.setRuntimeConfigProvider() called more than once.',\n );\n getRuntimeConfig = runtimeConfigProvider;\n}\n\n/**\n * Gets a `NativeComponent` that can be rendered by React Native.\n *\n * The supplied `viewConfigProvider` may or may not be invoked and utilized,\n * depending on how `setRuntimeConfigProvider` is configured.\n */\nexport function get(\n name: string,\n viewConfigProvider: () => PartialViewConfig,\n): HostComponent {\n ReactNativeViewConfigRegistry.register(name, () => {\n const {native, strict, verify} = getRuntimeConfig?.(name) ?? {\n native: true,\n strict: false,\n verify: false,\n };\n\n const viewConfig = native\n ? getNativeComponentAttributes(name)\n : createViewConfig(viewConfigProvider());\n\n if (verify) {\n const nativeViewConfig = native\n ? viewConfig\n : getNativeComponentAttributes(name);\n const staticViewConfig = native\n ? createViewConfig(viewConfigProvider())\n : viewConfig;\n\n if (strict) {\n const validationOutput = StaticViewConfigValidator.validate(\n name,\n nativeViewConfig,\n staticViewConfig,\n );\n\n if (validationOutput.type === 'invalid') {\n console.error(\n StaticViewConfigValidator.stringifyValidationResult(\n name,\n validationOutput,\n ),\n );\n }\n } else {\n verifyComponentAttributeEquivalence(nativeViewConfig, staticViewConfig);\n }\n }\n\n return viewConfig;\n });\n\n // $FlowFixMe[incompatible-return] `NativeComponent` is actually string!\n return name;\n}\n\n/**\n * Same as `NativeComponentRegistry.get(...)`, except this will check either\n * the `setRuntimeConfigProvider` configuration or use native reflection (slow)\n * to determine whether this native component is available.\n *\n * If the native component is not available, a stub component is returned. Note\n * that the return value of this is not `HostComponent` because the returned\n * component instance is not guaranteed to have native methods.\n */\nexport function getWithFallback_DEPRECATED(\n name: string,\n viewConfigProvider: () => PartialViewConfig,\n): React.AbstractComponent {\n if (getRuntimeConfig == null) {\n // `getRuntimeConfig == null` when static view configs are disabled\n // If `setRuntimeConfigProvider` is not configured, use native reflection.\n if (hasNativeViewConfig(name)) {\n return get(name, viewConfigProvider);\n }\n } else {\n // If there is no runtime config, then the native component is unavailable.\n if (getRuntimeConfig(name) != null) {\n return get(name, viewConfigProvider);\n }\n }\n\n const FallbackNativeComponent = function (props: Config): React.Node {\n return null;\n };\n FallbackNativeComponent.displayName = `Fallback(${name})`;\n return FallbackNativeComponent;\n}\n\nfunction hasNativeViewConfig(name: string): boolean {\n invariant(getRuntimeConfig == null, 'Unexpected invocation!');\n return UIManager.getViewManagerConfig(name) != null;\n}\n\n/**\n * Unstable API. Do not use!\n *\n * This method returns if there is a StaticViewConfig registered for the\n * component name received as a parameter.\n */\nexport function unstable_hasStaticViewConfig(name: string): boolean {\n const {native} = getRuntimeConfig?.(name) ?? {\n native: true,\n };\n return !native;\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 * @flow\n * @format\n */\n\n'use strict';\n\nconst ReactNativeStyleAttributes = require('../Components/View/ReactNativeStyleAttributes');\nconst resolveAssetSource = require('../Image/resolveAssetSource');\nconst processColor = require('../StyleSheet/processColor');\nconst processColorArray = require('../StyleSheet/processColorArray');\nconst insetsDiffer = require('../Utilities/differ/insetsDiffer');\nconst matricesDiffer = require('../Utilities/differ/matricesDiffer');\nconst pointsDiffer = require('../Utilities/differ/pointsDiffer');\nconst sizesDiffer = require('../Utilities/differ/sizesDiffer');\nconst UIManager = require('./UIManager');\nconst invariant = require('invariant');\n\nfunction getNativeComponentAttributes(uiViewClassName: string): any {\n const viewConfig = UIManager.getViewManagerConfig(uiViewClassName);\n\n invariant(\n viewConfig != null && viewConfig.NativeProps != null,\n 'requireNativeComponent: \"%s\" was not found in the UIManager.',\n uiViewClassName,\n );\n\n // TODO: This seems like a whole lot of runtime initialization for every\n // native component that can be either avoided or simplified.\n let {baseModuleName, bubblingEventTypes, directEventTypes} = viewConfig;\n let nativeProps = viewConfig.NativeProps;\n\n bubblingEventTypes = bubblingEventTypes ?? {};\n directEventTypes = directEventTypes ?? {};\n\n while (baseModuleName) {\n const baseModule = UIManager.getViewManagerConfig(baseModuleName);\n if (!baseModule) {\n baseModuleName = null;\n } else {\n bubblingEventTypes = {\n ...baseModule.bubblingEventTypes,\n ...bubblingEventTypes,\n };\n directEventTypes = {\n ...baseModule.directEventTypes,\n ...directEventTypes,\n };\n nativeProps = {\n ...baseModule.NativeProps,\n ...nativeProps,\n };\n baseModuleName = baseModule.baseModuleName;\n }\n }\n\n const validAttributes: {[string]: mixed} = {};\n\n for (const key in nativeProps) {\n const typeName = nativeProps[key];\n const diff = getDifferForType(typeName);\n const process = getProcessorForType(typeName);\n\n // If diff or process == null, omit the corresponding property from the Attribute\n // Why:\n // 1. Consistency with AttributeType flow type\n // 2. Consistency with Static View Configs, which omit the null properties\n validAttributes[key] =\n diff == null\n ? process == null\n ? true\n : {process}\n : process == null\n ? {diff}\n : {diff, process};\n }\n\n // Unfortunately, the current setup declares style properties as top-level\n // props. This makes it so we allow style properties in the `style` prop.\n // TODO: Move style properties into a `style` prop and disallow them as\n // top-level props on the native side.\n validAttributes.style = ReactNativeStyleAttributes;\n\n Object.assign(viewConfig, {\n uiViewClassName,\n validAttributes,\n bubblingEventTypes,\n directEventTypes,\n });\n\n attachDefaultEventTypes(viewConfig);\n\n return viewConfig;\n}\n\nfunction attachDefaultEventTypes(viewConfig: any) {\n // This is supported on UIManager platforms (ex: Android),\n // as lazy view managers are not implemented for all platforms.\n // See [UIManager] for details on constants and implementations.\n const constants = UIManager.getConstants();\n if (constants.ViewManagerNames || constants.LazyViewManagersEnabled) {\n // Lazy view managers enabled.\n viewConfig = merge(viewConfig, UIManager.getDefaultEventTypes());\n } else {\n viewConfig.bubblingEventTypes = merge(\n viewConfig.bubblingEventTypes,\n constants.genericBubblingEventTypes,\n );\n viewConfig.directEventTypes = merge(\n viewConfig.directEventTypes,\n constants.genericDirectEventTypes,\n );\n }\n}\n\n// TODO: Figure out how to avoid all this runtime initialization cost.\nfunction merge(destination: ?Object, source: ?Object): ?Object {\n if (!source) {\n return destination;\n }\n if (!destination) {\n return source;\n }\n\n for (const key in source) {\n if (!source.hasOwnProperty(key)) {\n continue;\n }\n\n let sourceValue = source[key];\n if (destination.hasOwnProperty(key)) {\n const destinationValue = destination[key];\n if (\n typeof sourceValue === 'object' &&\n typeof destinationValue === 'object'\n ) {\n sourceValue = merge(destinationValue, sourceValue);\n }\n }\n destination[key] = sourceValue;\n }\n return destination;\n}\n\nfunction getDifferForType(\n typeName: string,\n): ?(prevProp: any, nextProp: any) => boolean {\n switch (typeName) {\n // iOS Types\n case 'CATransform3D':\n return matricesDiffer;\n case 'CGPoint':\n return pointsDiffer;\n case 'CGSize':\n return sizesDiffer;\n case 'UIEdgeInsets':\n return insetsDiffer;\n // Android Types\n case 'Point':\n return pointsDiffer;\n case 'EdgeInsets':\n return insetsDiffer;\n }\n return null;\n}\n\nfunction getProcessorForType(typeName: string): ?(nextProp: any) => any {\n switch (typeName) {\n // iOS Types\n case 'CGColor':\n case 'UIColor':\n return processColor;\n case 'CGColorArray':\n case 'UIColorArray':\n return processColorArray;\n case 'CGImage':\n case 'UIImage':\n case 'RCTImageSource':\n return resolveAssetSource;\n // Android Types\n case 'Color':\n return processColor;\n case 'ColorArray':\n return processColorArray;\n case 'ImageSource':\n return resolveAssetSource;\n }\n return null;\n}\n\nmodule.exports = getNativeComponentAttributes;\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 * @flow\n * @format\n */\n\nimport type {RootTag} from '../Types/RootTagTypes';\nimport type {Spec} from './NativeUIManager';\n\nexport interface UIManagerJSInterface extends Spec {\n +getViewManagerConfig: (viewManagerName: string) => Object;\n +hasViewManagerConfig: (viewManagerName: string) => boolean;\n +createView: (\n reactTag: ?number,\n viewName: string,\n rootTag: RootTag,\n props: Object,\n ) => void;\n +updateView: (reactTag: number, viewName: string, props: Object) => void;\n +manageChildren: (\n containerTag: ?number,\n moveFromIndices: Array,\n moveToIndices: Array,\n addChildReactTags: Array,\n addAtIndices: Array,\n removeAtIndices: Array,\n ) => void;\n}\n\nconst UIManager: UIManagerJSInterface =\n global.RN$Bridgeless === true\n ? require('./BridgelessUIManager')\n : require('./PaperUIManager');\n\nmodule.exports = UIManager;\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport type {RootTag} from '../Types/RootTagTypes';\n\nimport {unstable_hasComponent} from '../NativeComponent/NativeComponentRegistryUnstable';\n\nconst errorMessageForMethod = (methodName: string): string =>\n \"[ReactNative Architecture][JS] '\" +\n methodName +\n \"' is not available in the new React Native architecture.\";\n\nmodule.exports = {\n getViewManagerConfig: (viewManagerName: string): mixed => {\n console.error(\n errorMessageForMethod('getViewManagerConfig') +\n 'Use hasViewManagerConfig instead. viewManagerName: ' +\n viewManagerName,\n );\n return null;\n },\n hasViewManagerConfig: (viewManagerName: string): boolean => {\n return unstable_hasComponent(viewManagerName);\n },\n getConstants: (): Object => {\n console.error(errorMessageForMethod('getConstants'));\n return {};\n },\n getConstantsForViewManager: (viewManagerName: string): Object => {\n console.error(errorMessageForMethod('getConstantsForViewManager'));\n return {};\n },\n getDefaultEventTypes: (): Array => {\n console.error(errorMessageForMethod('getDefaultEventTypes'));\n return [];\n },\n lazilyLoadView: (name: string): Object => {\n console.error(errorMessageForMethod('lazilyLoadView'));\n return {};\n },\n createView: (\n reactTag: ?number,\n viewName: string,\n rootTag: RootTag,\n props: Object,\n ): void => console.error(errorMessageForMethod('createView')),\n updateView: (reactTag: number, viewName: string, props: Object): void =>\n console.error(errorMessageForMethod('updateView')),\n focus: (reactTag: ?number): void =>\n console.error(errorMessageForMethod('focus')),\n blur: (reactTag: ?number): void =>\n console.error(errorMessageForMethod('blur')),\n findSubviewIn: (\n reactTag: ?number,\n point: Array,\n callback: (\n nativeViewTag: number,\n left: number,\n top: number,\n width: number,\n height: number,\n ) => void,\n ): void => console.error(errorMessageForMethod('findSubviewIn')),\n dispatchViewManagerCommand: (\n reactTag: ?number,\n commandID: number,\n commandArgs: ?Array,\n ): void => console.error(errorMessageForMethod('dispatchViewManagerCommand')),\n measure: (\n reactTag: ?number,\n callback: (\n left: number,\n top: number,\n width: number,\n height: number,\n pageX: number,\n pageY: number,\n ) => void,\n ): void => console.error(errorMessageForMethod('measure')),\n measureInWindow: (\n reactTag: ?number,\n callback: (x: number, y: number, width: number, height: number) => void,\n ): void => console.error(errorMessageForMethod('measureInWindow')),\n viewIsDescendantOf: (\n reactTag: ?number,\n ancestorReactTag: ?number,\n callback: (result: Array) => void,\n ): void => console.error(errorMessageForMethod('viewIsDescendantOf')),\n measureLayout: (\n reactTag: ?number,\n ancestorReactTag: ?number,\n errorCallback: (error: Object) => void,\n callback: (\n left: number,\n top: number,\n width: number,\n height: number,\n ) => void,\n ): void => console.error(errorMessageForMethod('measureLayout')),\n measureLayoutRelativeToParent: (\n reactTag: ?number,\n errorCallback: (error: Object) => void,\n callback: (\n left: number,\n top: number,\n width: number,\n height: number,\n ) => void,\n ): void =>\n console.error(errorMessageForMethod('measureLayoutRelativeToParent')),\n setJSResponder: (reactTag: ?number, blockNativeResponder: boolean): void =>\n console.error(errorMessageForMethod('setJSResponder')),\n clearJSResponder: (): void => {}, // Don't log error here because we're aware it gets called\n configureNextLayoutAnimation: (\n config: Object,\n callback: () => void,\n errorCallback: (error: Object) => void,\n ): void =>\n console.error(errorMessageForMethod('configureNextLayoutAnimation')),\n removeSubviewsFromContainerWithID: (containerID: number): void =>\n console.error(errorMessageForMethod('removeSubviewsFromContainerWithID')),\n replaceExistingNonRootView: (reactTag: ?number, newReactTag: ?number): void =>\n console.error(errorMessageForMethod('replaceExistingNonRootView')),\n setChildren: (containerTag: ?number, reactTags: Array): void =>\n console.error(errorMessageForMethod('setChildren')),\n manageChildren: (\n containerTag: ?number,\n moveFromIndices: Array,\n moveToIndices: Array,\n addChildReactTags: Array,\n addAtIndices: Array,\n removeAtIndices: Array,\n ): void => console.error(errorMessageForMethod('manageChildren')),\n\n // Android only\n setLayoutAnimationEnabledExperimental: (enabled: boolean): void => {\n console.error(\n errorMessageForMethod('setLayoutAnimationEnabledExperimental'),\n );\n },\n // Please use AccessibilityInfo.sendAccessibilityEvent instead.\n // See SetAccessibilityFocusExample in AccessibilityExample.js for a migration example.\n sendAccessibilityEvent: (reactTag: ?number, eventType: number): void =>\n console.error(errorMessageForMethod('sendAccessibilityEvent')),\n showPopupMenu: (\n reactTag: ?number,\n items: Array,\n error: (error: Object) => void,\n success: (event: string, selected?: number) => void,\n ): void => console.error(errorMessageForMethod('showPopupMenu')),\n dismissPopupMenu: (): void =>\n console.error(errorMessageForMethod('dismissPopupMenu')),\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\nlet componentNameToExists: Map = new Map();\n\n/**\n * Unstable API. Do not use!\n *\n * This method returns if the component with name received as a parameter\n * is registed in the native platform.\n */\nexport function unstable_hasComponent(name: string): boolean {\n let hasNativeComponent = componentNameToExists.get(name);\n if (hasNativeComponent == null) {\n if (global.__nativeComponentRegistry__hasComponent) {\n hasNativeComponent = global.__nativeComponentRegistry__hasComponent(name);\n componentNameToExists.set(name, hasNativeComponent);\n } else {\n throw `unstable_hasComponent('${name}'): Global function is not registered`;\n }\n }\n return hasNativeComponent;\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 * @flow\n * @format\n */\n\nimport type {RootTag} from '../Types/RootTagTypes';\n\nimport NativeUIManager from './NativeUIManager';\n\nconst NativeModules = require('../BatchedBridge/NativeModules');\nconst defineLazyObjectProperty = require('../Utilities/defineLazyObjectProperty');\nconst Platform = require('../Utilities/Platform');\nconst UIManagerProperties = require('./UIManagerProperties');\n\nconst viewManagerConfigs: {[string]: any | null} = {};\n\nconst triedLoadingConfig = new Set();\n\nlet NativeUIManagerConstants = {};\nlet isNativeUIManagerConstantsSet = false;\nfunction getConstants(): Object {\n if (!isNativeUIManagerConstantsSet) {\n NativeUIManagerConstants = NativeUIManager.getConstants();\n isNativeUIManagerConstantsSet = true;\n }\n return NativeUIManagerConstants;\n}\n\nfunction getViewManagerConfig(viewManagerName: string): any {\n if (\n viewManagerConfigs[viewManagerName] === undefined &&\n global.nativeCallSyncHook && // If we're in the Chrome Debugger, let's not even try calling the sync method\n NativeUIManager.getConstantsForViewManager\n ) {\n try {\n viewManagerConfigs[viewManagerName] =\n NativeUIManager.getConstantsForViewManager(viewManagerName);\n } catch (e) {\n console.error(\n \"NativeUIManager.getConstantsForViewManager('\" +\n viewManagerName +\n \"') threw an exception.\",\n e,\n );\n viewManagerConfigs[viewManagerName] = null;\n }\n }\n\n const config = viewManagerConfigs[viewManagerName];\n if (config) {\n return config;\n }\n\n // If we're in the Chrome Debugger, let's not even try calling the sync\n // method.\n if (!global.nativeCallSyncHook) {\n return config;\n }\n\n if (\n NativeUIManager.lazilyLoadView &&\n !triedLoadingConfig.has(viewManagerName)\n ) {\n const result = NativeUIManager.lazilyLoadView(viewManagerName);\n triedLoadingConfig.add(viewManagerName);\n if (result != null && result.viewConfig != null) {\n getConstants()[viewManagerName] = result.viewConfig;\n lazifyViewManagerConfig(viewManagerName);\n }\n }\n\n return viewManagerConfigs[viewManagerName];\n}\n\n/* $FlowFixMe[cannot-spread-interface] (>=0.123.0 site=react_native_fb) This\n * comment suppresses an error found when Flow v0.123.0 was deployed. To see\n * the error, delete this comment and run Flow. */\nconst UIManagerJS = {\n ...NativeUIManager,\n createView(\n reactTag: ?number,\n viewName: string,\n rootTag: RootTag,\n props: Object,\n ): void {\n if (Platform.OS === 'ios' && viewManagerConfigs[viewName] === undefined) {\n // This is necessary to force the initialization of native viewManager\n // classes in iOS when using static ViewConfigs\n getViewManagerConfig(viewName);\n }\n\n NativeUIManager.createView(reactTag, viewName, rootTag, props);\n },\n getConstants(): Object {\n return getConstants();\n },\n getViewManagerConfig(viewManagerName: string): any {\n return getViewManagerConfig(viewManagerName);\n },\n hasViewManagerConfig(viewManagerName: string): boolean {\n return getViewManagerConfig(viewManagerName) != null;\n },\n};\n\n// TODO (T45220498): Remove this.\n// 3rd party libs may be calling `NativeModules.UIManager.getViewManagerConfig()`\n// instead of `UIManager.getViewManagerConfig()` off UIManager.js.\n// This is a workaround for now.\n// $FlowFixMe[prop-missing]\nNativeUIManager.getViewManagerConfig = UIManagerJS.getViewManagerConfig;\n\nfunction lazifyViewManagerConfig(viewName: string) {\n const viewConfig = getConstants()[viewName];\n viewManagerConfigs[viewName] = viewConfig;\n if (viewConfig.Manager) {\n defineLazyObjectProperty(viewConfig, 'Constants', {\n get: () => {\n const viewManager = NativeModules[viewConfig.Manager];\n const constants: {[string]: mixed} = {};\n viewManager &&\n Object.keys(viewManager).forEach(key => {\n const value = viewManager[key];\n if (typeof value !== 'function') {\n constants[key] = value;\n }\n });\n return constants;\n },\n });\n defineLazyObjectProperty(viewConfig, 'Commands', {\n get: () => {\n const viewManager = NativeModules[viewConfig.Manager];\n const commands: {[string]: number} = {};\n let index = 0;\n viewManager &&\n Object.keys(viewManager).forEach(key => {\n const value = viewManager[key];\n if (typeof value === 'function') {\n commands[key] = index++;\n }\n });\n return commands;\n },\n });\n }\n}\n\n/**\n * Copies the ViewManager constants and commands into UIManager. This is\n * only needed for iOS, which puts the constants in the ViewManager\n * namespace instead of UIManager, unlike Android.\n */\nif (Platform.OS === 'ios') {\n Object.keys(getConstants()).forEach(viewName => {\n lazifyViewManagerConfig(viewName);\n });\n} else if (getConstants().ViewManagerNames) {\n NativeUIManager.getConstants().ViewManagerNames.forEach(viewManagerName => {\n defineLazyObjectProperty(NativeUIManager, viewManagerName, {\n get: () => NativeUIManager.getConstantsForViewManager(viewManagerName),\n });\n });\n}\n\nif (!global.nativeCallSyncHook) {\n Object.keys(getConstants()).forEach(viewManagerName => {\n if (!UIManagerProperties.includes(viewManagerName)) {\n if (!viewManagerConfigs[viewManagerName]) {\n viewManagerConfigs[viewManagerName] = getConstants()[viewManagerName];\n }\n defineLazyObjectProperty(NativeUIManager, viewManagerName, {\n get: () => {\n console.warn(\n `Accessing view manager configs directly off UIManager via UIManager['${viewManagerName}'] ` +\n `is no longer supported. Use UIManager.getViewManagerConfig('${viewManagerName}') instead.`,\n );\n\n return UIManagerJS.getViewManagerConfig(viewManagerName);\n },\n });\n }\n });\n}\n\nmodule.exports = UIManagerJS;\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 * @flow\n * @format\n */\n\nimport type {RootTag} from '../TurboModule/RCTExport';\nimport type {TurboModule} from '../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../TurboModule/TurboModuleRegistry';\n\nexport interface Spec extends TurboModule {\n +getConstants: () => Object;\n +getConstantsForViewManager: (viewManagerName: string) => Object;\n +getDefaultEventTypes: () => Array;\n +lazilyLoadView: (name: string) => Object; // revisit return\n +createView: (\n reactTag: ?number,\n viewName: string,\n rootTag: RootTag,\n props: Object,\n ) => void;\n +updateView: (reactTag: number, viewName: string, props: Object) => void;\n +focus: (reactTag: ?number) => void;\n +blur: (reactTag: ?number) => void;\n +findSubviewIn: (\n reactTag: ?number,\n point: Array,\n callback: (\n nativeViewTag: number,\n left: number,\n top: number,\n width: number,\n height: number,\n ) => void,\n ) => void;\n +dispatchViewManagerCommand: (\n reactTag: ?number,\n commandID: number,\n commandArgs: ?Array,\n ) => void;\n +measure: (\n reactTag: ?number,\n callback: (\n left: number,\n top: number,\n width: number,\n height: number,\n pageX: number,\n pageY: number,\n ) => void,\n ) => void;\n +measureInWindow: (\n reactTag: ?number,\n callback: (x: number, y: number, width: number, height: number) => void,\n ) => void;\n +viewIsDescendantOf: (\n reactTag: ?number,\n ancestorReactTag: ?number,\n callback: (result: Array) => void,\n ) => void;\n +measureLayout: (\n reactTag: ?number,\n ancestorReactTag: ?number,\n errorCallback: (error: Object) => void,\n callback: (\n left: number,\n top: number,\n width: number,\n height: number,\n ) => void,\n ) => void;\n +measureLayoutRelativeToParent: (\n reactTag: ?number,\n errorCallback: (error: Object) => void,\n callback: (\n left: number,\n top: number,\n width: number,\n height: number,\n ) => void,\n ) => void;\n +setJSResponder: (reactTag: ?number, blockNativeResponder: boolean) => void;\n +clearJSResponder: () => void;\n +configureNextLayoutAnimation: (\n config: Object,\n callback: () => void, // check what is returned here\n errorCallback: (error: Object) => void,\n ) => void;\n +removeSubviewsFromContainerWithID: (containerID: number) => void;\n +replaceExistingNonRootView: (\n reactTag: ?number,\n newReactTag: ?number,\n ) => void;\n +setChildren: (containerTag: ?number, reactTags: Array) => void;\n +manageChildren: (\n containerTag: ?number,\n moveFromIndices: Array,\n moveToIndices: Array,\n addChildReactTags: Array,\n addAtIndices: Array,\n removeAtIndices: Array,\n ) => void;\n\n // Android only\n +setLayoutAnimationEnabledExperimental: (enabled: boolean) => void;\n +sendAccessibilityEvent: (reactTag: ?number, eventType: number) => void;\n +showPopupMenu: (\n reactTag: ?number,\n items: Array,\n error: (error: Object) => void,\n success: (event: string, selected?: number) => void,\n ) => void;\n +dismissPopupMenu: () => void;\n}\n\nexport default (TurboModuleRegistry.getEnforcing('UIManager'): Spec);\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 * @flow strict\n * @format\n */\n\n'use strict';\n\n/**\n * The list of non-ViewManager related UIManager properties.\n *\n * In an effort to improve startup performance by lazily loading view managers,\n * the interface to access view managers will change from\n * UIManager['viewManagerName'] to UIManager.getViewManagerConfig('viewManagerName').\n * By using a function call instead of a property access, the UIManager will\n * be able to initialize and load the required view manager from native\n * synchronously. All of React Native's core components have been updated to\n * use getViewManagerConfig(). For the next few releases, any usage of\n * UIManager['viewManagerName'] will result in a warning. Because React Native\n * does not support Proxy objects, a view manager access is implied if any of\n * UIManager's properties that are not one of the properties below is being\n * accessed. Once UIManager property accesses for view managers has been fully\n * deprecated, this file will also be removed.\n */\nmodule.exports = [\n 'clearJSResponder',\n 'configureNextLayoutAnimation',\n 'createView',\n 'dismissPopupMenu',\n 'dispatchViewManagerCommand',\n 'findSubviewIn',\n 'getConstantsForViewManager',\n 'getDefaultEventTypes',\n 'manageChildren',\n 'measure',\n 'measureInWindow',\n 'measureLayout',\n 'measureLayoutRelativeToParent',\n 'removeRootView',\n 'removeSubviewsFromContainerWithID',\n 'replaceExistingNonRootView',\n 'sendAccessibilityEvent',\n 'setChildren',\n 'setJSResponder',\n 'setLayoutAnimationEnabledExperimental',\n 'showPopupMenu',\n 'updateView',\n 'viewIsDescendantOf',\n 'PopupMenu',\n 'LazyViewManagersEnabled',\n 'ViewManagerNames',\n 'StyleConstants',\n 'AccessibilityEventTypes',\n 'UIView',\n 'getViewManagerConfig',\n 'hasViewManagerConfig',\n 'blur',\n 'focus',\n 'genericBubblingEventTypes',\n 'genericDirectEventTypes',\n 'lazilyLoadView',\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 * @format strict-local\n * @flow\n */\n\nimport type {AnyAttributeType} from '../../Renderer/shims/ReactNativeTypes';\n\nimport processAspectRatio from '../../StyleSheet/processAspectRatio';\nimport processColor from '../../StyleSheet/processColor';\nimport processFontVariant from '../../StyleSheet/processFontVariant';\nimport processTransform from '../../StyleSheet/processTransform';\nimport sizesDiffer from '../../Utilities/differ/sizesDiffer';\n\nconst colorAttributes = {process: processColor};\n\nconst ReactNativeStyleAttributes: {[string]: AnyAttributeType, ...} = {\n /**\n * Layout\n */\n alignContent: true,\n alignItems: true,\n alignSelf: true,\n aspectRatio: {process: processAspectRatio},\n borderBottomWidth: true,\n borderEndWidth: true,\n borderLeftWidth: true,\n borderRightWidth: true,\n borderStartWidth: true,\n borderTopWidth: true,\n columnGap: true,\n borderWidth: true,\n bottom: true,\n direction: true,\n display: true,\n end: true,\n flex: true,\n flexBasis: true,\n flexDirection: true,\n flexGrow: true,\n flexShrink: true,\n flexWrap: true,\n gap: true,\n height: true,\n justifyContent: true,\n left: true,\n margin: true,\n marginBottom: true,\n marginEnd: true,\n marginHorizontal: true,\n marginLeft: true,\n marginRight: true,\n marginStart: true,\n marginTop: true,\n marginVertical: true,\n maxHeight: true,\n maxWidth: true,\n minHeight: true,\n minWidth: true,\n overflow: true,\n padding: true,\n paddingBottom: true,\n paddingEnd: true,\n paddingHorizontal: true,\n paddingLeft: true,\n paddingRight: true,\n paddingStart: true,\n paddingTop: true,\n paddingVertical: true,\n position: true,\n right: true,\n rowGap: true,\n start: true,\n top: true,\n width: true,\n zIndex: true,\n\n /**\n * Shadow\n */\n elevation: true,\n shadowColor: colorAttributes,\n shadowOffset: {diff: sizesDiffer},\n shadowOpacity: true,\n shadowRadius: true,\n\n /**\n * Transform\n */\n transform: {process: processTransform},\n\n /**\n * View\n */\n backfaceVisibility: true,\n backgroundColor: colorAttributes,\n borderBottomColor: colorAttributes,\n borderBottomEndRadius: true,\n borderBottomLeftRadius: true,\n borderBottomRightRadius: true,\n borderBottomStartRadius: true,\n borderColor: colorAttributes,\n borderCurve: true,\n borderEndColor: colorAttributes,\n borderLeftColor: colorAttributes,\n borderRadius: true,\n borderRightColor: colorAttributes,\n borderStartColor: colorAttributes,\n borderStyle: true,\n borderTopColor: colorAttributes,\n borderTopEndRadius: true,\n borderTopLeftRadius: true,\n borderTopRightRadius: true,\n borderTopStartRadius: true,\n opacity: true,\n pointerEvents: true,\n\n /**\n * Text\n */\n color: colorAttributes,\n fontFamily: true,\n fontSize: true,\n fontStyle: true,\n fontVariant: {process: processFontVariant},\n fontWeight: true,\n includeFontPadding: true,\n letterSpacing: true,\n lineHeight: true,\n textAlign: true,\n textAlignVertical: true,\n textDecorationColor: colorAttributes,\n textDecorationLine: true,\n textDecorationStyle: true,\n textShadowColor: colorAttributes,\n textShadowOffset: true,\n textShadowRadius: true,\n textTransform: true,\n userSelect: true,\n verticalAlign: true,\n writingDirection: true,\n\n /**\n * Image\n */\n overlayColor: colorAttributes,\n resizeMode: true,\n tintColor: colorAttributes,\n objectFit: true,\n};\n\nmodule.exports = ReactNativeStyleAttributes;\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 * @format\n * @flow\n */\n\n'use strict';\n\nconst invariant = require('invariant');\n\nfunction processAspectRatio(aspectRatio?: number | string): ?number {\n if (typeof aspectRatio === 'number') {\n return aspectRatio;\n }\n if (typeof aspectRatio !== 'string') {\n if (__DEV__) {\n invariant(\n !aspectRatio,\n 'aspectRatio must either be a number, a ratio string or `auto`. You passed: %s',\n aspectRatio,\n );\n }\n return;\n }\n\n const matches = aspectRatio.split('/').map(s => s.trim());\n\n if (matches.includes('auto')) {\n if (__DEV__) {\n invariant(\n matches.length,\n 'aspectRatio does not support `auto `. You passed: %s',\n aspectRatio,\n );\n }\n return;\n }\n\n const hasNonNumericValues = matches.some(n => Number.isNaN(Number(n)));\n if (__DEV__) {\n invariant(\n !hasNonNumericValues && (matches.length === 1 || matches.length === 2),\n 'aspectRatio must either be a number, a ratio string or `auto`. You passed: %s',\n aspectRatio,\n );\n }\n\n if (hasNonNumericValues) {\n return;\n }\n\n if (matches.length === 2) {\n return Number(matches[0]) / Number(matches[1]);\n }\n\n return Number(matches[0]);\n}\n\nmodule.exports = processAspectRatio;\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 * @format\n * @flow strict-local\n */\n\n'use strict';\n\nimport type {NativeColorValue} from './PlatformColorValueTypes';\nimport type {ColorValue} from './StyleSheet';\n\nconst Platform = require('../Utilities/Platform');\nconst normalizeColor = require('./normalizeColor');\n\nexport type ProcessedColorValue = number | NativeColorValue;\n\n/* eslint no-bitwise: 0 */\nfunction processColor(color?: ?(number | ColorValue)): ?ProcessedColorValue {\n if (color === undefined || color === null) {\n return color;\n }\n\n let normalizedColor = normalizeColor(color);\n if (normalizedColor === null || normalizedColor === undefined) {\n return undefined;\n }\n\n if (typeof normalizedColor === 'object') {\n const processColorObject =\n require('./PlatformColorValueTypes').processColorObject;\n\n const processedColorObj = processColorObject(normalizedColor);\n\n if (processedColorObj != null) {\n return processedColorObj;\n }\n }\n\n if (typeof normalizedColor !== 'number') {\n return null;\n }\n\n // Converts 0xrrggbbaa into 0xaarrggbb\n normalizedColor = ((normalizedColor << 24) | (normalizedColor >>> 8)) >>> 0;\n\n if (Platform.OS === 'android') {\n // Android use 32 bit *signed* integer to represent the color\n // We utilize the fact that bitwise operations in JS also operates on\n // signed 32 bit integers, so that we can use those to convert from\n // *unsigned* to *signed* 32bit int that way.\n normalizedColor = normalizedColor | 0x0;\n }\n return normalizedColor;\n}\n\nmodule.exports = processColor;\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 * @format\n * @flow\n */\n\n/* eslint no-bitwise: 0 */\n\nimport type {ProcessedColorValue} from './processColor';\nimport type {ColorValue} from './StyleSheet';\n\nimport _normalizeColor from '@react-native/normalize-color';\n\nfunction normalizeColor(\n color: ?(ColorValue | ProcessedColorValue),\n): ?ProcessedColorValue {\n if (typeof color === 'object' && color != null) {\n const {normalizeColorObject} = require('./PlatformColorValueTypes');\n const normalizedColor = normalizeColorObject(color);\n if (normalizedColor != null) {\n return normalizedColor;\n }\n }\n\n if (typeof color === 'string' || typeof color === 'number') {\n return _normalizeColor(color);\n }\n}\n\nmodule.exports = normalizeColor;\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 * @format\n * @noflow\n */\n\n/* eslint no-bitwise: 0 */\n\n'use strict';\n\nfunction normalizeColor(color) {\n if (typeof color === 'number') {\n if (color >>> 0 === color && color >= 0 && color <= 0xffffffff) {\n return color;\n }\n return null;\n }\n\n if (typeof color !== 'string') {\n return null;\n }\n\n const matchers = getMatchers();\n let match;\n\n // Ordered based on occurrences on Facebook codebase\n if ((match = matchers.hex6.exec(color))) {\n return parseInt(match[1] + 'ff', 16) >>> 0;\n }\n\n const colorFromKeyword = normalizeKeyword(color);\n if (colorFromKeyword != null) {\n return colorFromKeyword;\n }\n\n if ((match = matchers.rgb.exec(color))) {\n return (\n ((parse255(match[1]) << 24) | // r\n (parse255(match[2]) << 16) | // g\n (parse255(match[3]) << 8) | // b\n 0x000000ff) >>> // a\n 0\n );\n }\n\n if ((match = matchers.rgba.exec(color))) {\n // rgba(R G B / A) notation\n if (match[6] !== undefined) {\n return (\n ((parse255(match[6]) << 24) | // r\n (parse255(match[7]) << 16) | // g\n (parse255(match[8]) << 8) | // b\n parse1(match[9])) >>> // a\n 0\n );\n }\n\n // rgba(R, G, B, A) notation\n return (\n ((parse255(match[2]) << 24) | // r\n (parse255(match[3]) << 16) | // g\n (parse255(match[4]) << 8) | // b\n parse1(match[5])) >>> // a\n 0\n );\n }\n\n if ((match = matchers.hex3.exec(color))) {\n return (\n parseInt(\n match[1] +\n match[1] + // r\n match[2] +\n match[2] + // g\n match[3] +\n match[3] + // b\n 'ff', // a\n 16,\n ) >>> 0\n );\n }\n\n // https://drafts.csswg.org/css-color-4/#hex-notation\n if ((match = matchers.hex8.exec(color))) {\n return parseInt(match[1], 16) >>> 0;\n }\n\n if ((match = matchers.hex4.exec(color))) {\n return (\n parseInt(\n match[1] +\n match[1] + // r\n match[2] +\n match[2] + // g\n match[3] +\n match[3] + // b\n match[4] +\n match[4], // a\n 16,\n ) >>> 0\n );\n }\n\n if ((match = matchers.hsl.exec(color))) {\n return (\n (hslToRgb(\n parse360(match[1]), // h\n parsePercentage(match[2]), // s\n parsePercentage(match[3]), // l\n ) |\n 0x000000ff) >>> // a\n 0\n );\n }\n\n if ((match = matchers.hsla.exec(color))) {\n // hsla(H S L / A) notation\n if (match[6] !== undefined) {\n return (\n (hslToRgb(\n parse360(match[6]), // h\n parsePercentage(match[7]), // s\n parsePercentage(match[8]), // l\n ) |\n parse1(match[9])) >>> // a\n 0\n );\n }\n\n // hsla(H, S, L, A) notation\n return (\n (hslToRgb(\n parse360(match[2]), // h\n parsePercentage(match[3]), // s\n parsePercentage(match[4]), // l\n ) |\n parse1(match[5])) >>> // a\n 0\n );\n }\n\n if ((match = matchers.hwb.exec(color))) {\n return (\n (hwbToRgb(\n parse360(match[1]), // h\n parsePercentage(match[2]), // w\n parsePercentage(match[3]), // b\n ) |\n 0x000000ff) >>> // a\n 0\n );\n }\n\n return null;\n}\n\nfunction hue2rgb(p, q, t) {\n if (t < 0) {\n t += 1;\n }\n if (t > 1) {\n t -= 1;\n }\n if (t < 1 / 6) {\n return p + (q - p) * 6 * t;\n }\n if (t < 1 / 2) {\n return q;\n }\n if (t < 2 / 3) {\n return p + (q - p) * (2 / 3 - t) * 6;\n }\n return p;\n}\n\nfunction hslToRgb(h, s, l) {\n const q = l < 0.5 ? l * (1 + s) : l + s - l * s;\n const p = 2 * l - q;\n const r = hue2rgb(p, q, h + 1 / 3);\n const g = hue2rgb(p, q, h);\n const b = hue2rgb(p, q, h - 1 / 3);\n\n return (\n (Math.round(r * 255) << 24) |\n (Math.round(g * 255) << 16) |\n (Math.round(b * 255) << 8)\n );\n}\n\nfunction hwbToRgb(h, w, b) {\n if (w + b >= 1) {\n const gray = Math.round((w * 255) / (w + b));\n\n return (gray << 24) | (gray << 16) | (gray << 8);\n }\n\n const red = hue2rgb(0, 1, h + 1 / 3) * (1 - w - b) + w;\n const green = hue2rgb(0, 1, h) * (1 - w - b) + w;\n const blue = hue2rgb(0, 1, h - 1 / 3) * (1 - w - b) + w;\n\n return (\n (Math.round(red * 255) << 24) |\n (Math.round(green * 255) << 16) |\n (Math.round(blue * 255) << 8)\n );\n}\n\nconst NUMBER = '[-+]?\\\\d*\\\\.?\\\\d+';\nconst PERCENTAGE = NUMBER + '%';\n\nfunction call(...args) {\n return '\\\\(\\\\s*(' + args.join(')\\\\s*,?\\\\s*(') + ')\\\\s*\\\\)';\n}\n\nfunction callWithSlashSeparator(...args) {\n return (\n '\\\\(\\\\s*(' +\n args.slice(0, args.length - 1).join(')\\\\s*,?\\\\s*(') +\n ')\\\\s*/\\\\s*(' +\n args[args.length - 1] +\n ')\\\\s*\\\\)'\n );\n}\n\nfunction commaSeparatedCall(...args) {\n return '\\\\(\\\\s*(' + args.join(')\\\\s*,\\\\s*(') + ')\\\\s*\\\\)';\n}\n\nlet cachedMatchers;\n\nfunction getMatchers() {\n if (cachedMatchers === undefined) {\n cachedMatchers = {\n rgb: new RegExp('rgb' + call(NUMBER, NUMBER, NUMBER)),\n rgba: new RegExp(\n 'rgba(' +\n commaSeparatedCall(NUMBER, NUMBER, NUMBER, NUMBER) +\n '|' +\n callWithSlashSeparator(NUMBER, NUMBER, NUMBER, NUMBER) +\n ')',\n ),\n hsl: new RegExp('hsl' + call(NUMBER, PERCENTAGE, PERCENTAGE)),\n hsla: new RegExp(\n 'hsla(' +\n commaSeparatedCall(NUMBER, PERCENTAGE, PERCENTAGE, NUMBER) +\n '|' +\n callWithSlashSeparator(NUMBER, PERCENTAGE, PERCENTAGE, NUMBER) +\n ')',\n ),\n hwb: new RegExp('hwb' + call(NUMBER, PERCENTAGE, PERCENTAGE)),\n hex3: /^#([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,\n hex4: /^#([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,\n hex6: /^#([0-9a-fA-F]{6})$/,\n hex8: /^#([0-9a-fA-F]{8})$/,\n };\n }\n return cachedMatchers;\n}\n\nfunction parse255(str) {\n const int = parseInt(str, 10);\n if (int < 0) {\n return 0;\n }\n if (int > 255) {\n return 255;\n }\n return int;\n}\n\nfunction parse360(str) {\n const int = parseFloat(str);\n return (((int % 360) + 360) % 360) / 360;\n}\n\nfunction parse1(str) {\n const num = parseFloat(str);\n if (num < 0) {\n return 0;\n }\n if (num > 1) {\n return 255;\n }\n return Math.round(num * 255);\n}\n\nfunction parsePercentage(str) {\n // parseFloat conveniently ignores the final %\n const int = parseFloat(str);\n if (int < 0) {\n return 0;\n }\n if (int > 100) {\n return 1;\n }\n return int / 100;\n}\n\nfunction normalizeKeyword(name) {\n // prettier-ignore\n switch (name) {\n case 'transparent': return 0x00000000;\n // http://www.w3.org/TR/css3-color/#svg-color\n case 'aliceblue': return 0xf0f8ffff;\n case 'antiquewhite': return 0xfaebd7ff;\n case 'aqua': return 0x00ffffff;\n case 'aquamarine': return 0x7fffd4ff;\n case 'azure': return 0xf0ffffff;\n case 'beige': return 0xf5f5dcff;\n case 'bisque': return 0xffe4c4ff;\n case 'black': return 0x000000ff;\n case 'blanchedalmond': return 0xffebcdff;\n case 'blue': return 0x0000ffff;\n case 'blueviolet': return 0x8a2be2ff;\n case 'brown': return 0xa52a2aff;\n case 'burlywood': return 0xdeb887ff;\n case 'burntsienna': return 0xea7e5dff;\n case 'cadetblue': return 0x5f9ea0ff;\n case 'chartreuse': return 0x7fff00ff;\n case 'chocolate': return 0xd2691eff;\n case 'coral': return 0xff7f50ff;\n case 'cornflowerblue': return 0x6495edff;\n case 'cornsilk': return 0xfff8dcff;\n case 'crimson': return 0xdc143cff;\n case 'cyan': return 0x00ffffff;\n case 'darkblue': return 0x00008bff;\n case 'darkcyan': return 0x008b8bff;\n case 'darkgoldenrod': return 0xb8860bff;\n case 'darkgray': return 0xa9a9a9ff;\n case 'darkgreen': return 0x006400ff;\n case 'darkgrey': return 0xa9a9a9ff;\n case 'darkkhaki': return 0xbdb76bff;\n case 'darkmagenta': return 0x8b008bff;\n case 'darkolivegreen': return 0x556b2fff;\n case 'darkorange': return 0xff8c00ff;\n case 'darkorchid': return 0x9932ccff;\n case 'darkred': return 0x8b0000ff;\n case 'darksalmon': return 0xe9967aff;\n case 'darkseagreen': return 0x8fbc8fff;\n case 'darkslateblue': return 0x483d8bff;\n case 'darkslategray': return 0x2f4f4fff;\n case 'darkslategrey': return 0x2f4f4fff;\n case 'darkturquoise': return 0x00ced1ff;\n case 'darkviolet': return 0x9400d3ff;\n case 'deeppink': return 0xff1493ff;\n case 'deepskyblue': return 0x00bfffff;\n case 'dimgray': return 0x696969ff;\n case 'dimgrey': return 0x696969ff;\n case 'dodgerblue': return 0x1e90ffff;\n case 'firebrick': return 0xb22222ff;\n case 'floralwhite': return 0xfffaf0ff;\n case 'forestgreen': return 0x228b22ff;\n case 'fuchsia': return 0xff00ffff;\n case 'gainsboro': return 0xdcdcdcff;\n case 'ghostwhite': return 0xf8f8ffff;\n case 'gold': return 0xffd700ff;\n case 'goldenrod': return 0xdaa520ff;\n case 'gray': return 0x808080ff;\n case 'green': return 0x008000ff;\n case 'greenyellow': return 0xadff2fff;\n case 'grey': return 0x808080ff;\n case 'honeydew': return 0xf0fff0ff;\n case 'hotpink': return 0xff69b4ff;\n case 'indianred': return 0xcd5c5cff;\n case 'indigo': return 0x4b0082ff;\n case 'ivory': return 0xfffff0ff;\n case 'khaki': return 0xf0e68cff;\n case 'lavender': return 0xe6e6faff;\n case 'lavenderblush': return 0xfff0f5ff;\n case 'lawngreen': return 0x7cfc00ff;\n case 'lemonchiffon': return 0xfffacdff;\n case 'lightblue': return 0xadd8e6ff;\n case 'lightcoral': return 0xf08080ff;\n case 'lightcyan': return 0xe0ffffff;\n case 'lightgoldenrodyellow': return 0xfafad2ff;\n case 'lightgray': return 0xd3d3d3ff;\n case 'lightgreen': return 0x90ee90ff;\n case 'lightgrey': return 0xd3d3d3ff;\n case 'lightpink': return 0xffb6c1ff;\n case 'lightsalmon': return 0xffa07aff;\n case 'lightseagreen': return 0x20b2aaff;\n case 'lightskyblue': return 0x87cefaff;\n case 'lightslategray': return 0x778899ff;\n case 'lightslategrey': return 0x778899ff;\n case 'lightsteelblue': return 0xb0c4deff;\n case 'lightyellow': return 0xffffe0ff;\n case 'lime': return 0x00ff00ff;\n case 'limegreen': return 0x32cd32ff;\n case 'linen': return 0xfaf0e6ff;\n case 'magenta': return 0xff00ffff;\n case 'maroon': return 0x800000ff;\n case 'mediumaquamarine': return 0x66cdaaff;\n case 'mediumblue': return 0x0000cdff;\n case 'mediumorchid': return 0xba55d3ff;\n case 'mediumpurple': return 0x9370dbff;\n case 'mediumseagreen': return 0x3cb371ff;\n case 'mediumslateblue': return 0x7b68eeff;\n case 'mediumspringgreen': return 0x00fa9aff;\n case 'mediumturquoise': return 0x48d1ccff;\n case 'mediumvioletred': return 0xc71585ff;\n case 'midnightblue': return 0x191970ff;\n case 'mintcream': return 0xf5fffaff;\n case 'mistyrose': return 0xffe4e1ff;\n case 'moccasin': return 0xffe4b5ff;\n case 'navajowhite': return 0xffdeadff;\n case 'navy': return 0x000080ff;\n case 'oldlace': return 0xfdf5e6ff;\n case 'olive': return 0x808000ff;\n case 'olivedrab': return 0x6b8e23ff;\n case 'orange': return 0xffa500ff;\n case 'orangered': return 0xff4500ff;\n case 'orchid': return 0xda70d6ff;\n case 'palegoldenrod': return 0xeee8aaff;\n case 'palegreen': return 0x98fb98ff;\n case 'paleturquoise': return 0xafeeeeff;\n case 'palevioletred': return 0xdb7093ff;\n case 'papayawhip': return 0xffefd5ff;\n case 'peachpuff': return 0xffdab9ff;\n case 'peru': return 0xcd853fff;\n case 'pink': return 0xffc0cbff;\n case 'plum': return 0xdda0ddff;\n case 'powderblue': return 0xb0e0e6ff;\n case 'purple': return 0x800080ff;\n case 'rebeccapurple': return 0x663399ff;\n case 'red': return 0xff0000ff;\n case 'rosybrown': return 0xbc8f8fff;\n case 'royalblue': return 0x4169e1ff;\n case 'saddlebrown': return 0x8b4513ff;\n case 'salmon': return 0xfa8072ff;\n case 'sandybrown': return 0xf4a460ff;\n case 'seagreen': return 0x2e8b57ff;\n case 'seashell': return 0xfff5eeff;\n case 'sienna': return 0xa0522dff;\n case 'silver': return 0xc0c0c0ff;\n case 'skyblue': return 0x87ceebff;\n case 'slateblue': return 0x6a5acdff;\n case 'slategray': return 0x708090ff;\n case 'slategrey': return 0x708090ff;\n case 'snow': return 0xfffafaff;\n case 'springgreen': return 0x00ff7fff;\n case 'steelblue': return 0x4682b4ff;\n case 'tan': return 0xd2b48cff;\n case 'teal': return 0x008080ff;\n case 'thistle': return 0xd8bfd8ff;\n case 'tomato': return 0xff6347ff;\n case 'turquoise': return 0x40e0d0ff;\n case 'violet': return 0xee82eeff;\n case 'wheat': return 0xf5deb3ff;\n case 'white': return 0xffffffff;\n case 'whitesmoke': return 0xf5f5f5ff;\n case 'yellow': return 0xffff00ff;\n case 'yellowgreen': return 0x9acd32ff;\n }\n return null;\n}\n\nmodule.exports = normalizeColor;\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 * @format\n * @flow strict-local\n */\n\nimport type {ProcessedColorValue} from './processColor';\nimport type {ColorValue} from './StyleSheet';\n\nexport opaque type NativeColorValue = {\n semantic?: Array,\n dynamic?: {\n light: ?(ColorValue | ProcessedColorValue),\n dark: ?(ColorValue | ProcessedColorValue),\n highContrastLight?: ?(ColorValue | ProcessedColorValue),\n highContrastDark?: ?(ColorValue | ProcessedColorValue),\n },\n};\n\nexport const PlatformColor = (...names: Array): ColorValue => {\n return {semantic: names};\n};\n\nexport type DynamicColorIOSTuplePrivate = {\n light: ColorValue,\n dark: ColorValue,\n highContrastLight?: ColorValue,\n highContrastDark?: ColorValue,\n};\n\nexport const DynamicColorIOSPrivate = (\n tuple: DynamicColorIOSTuplePrivate,\n): ColorValue => {\n return {\n dynamic: {\n light: tuple.light,\n dark: tuple.dark,\n highContrastLight: tuple.highContrastLight,\n highContrastDark: tuple.highContrastDark,\n },\n };\n};\n\nexport const normalizeColorObject = (\n color: NativeColorValue,\n): ?ProcessedColorValue => {\n if ('semantic' in color) {\n // an ios semantic color\n return color;\n } else if ('dynamic' in color && color.dynamic !== undefined) {\n const normalizeColor = require('./normalizeColor');\n\n // a dynamic, appearance aware color\n const dynamic = color.dynamic;\n const dynamicColor: NativeColorValue = {\n dynamic: {\n // $FlowFixMe[incompatible-use]\n light: normalizeColor(dynamic.light),\n // $FlowFixMe[incompatible-use]\n dark: normalizeColor(dynamic.dark),\n // $FlowFixMe[incompatible-use]\n highContrastLight: normalizeColor(dynamic.highContrastLight),\n // $FlowFixMe[incompatible-use]\n highContrastDark: normalizeColor(dynamic.highContrastDark),\n },\n };\n return dynamicColor;\n }\n\n return null;\n};\n\nexport const processColorObject = (\n color: NativeColorValue,\n): ?NativeColorValue => {\n if ('dynamic' in color && color.dynamic != null) {\n const processColor = require('./processColor');\n const dynamic = color.dynamic;\n const dynamicColor: NativeColorValue = {\n dynamic: {\n // $FlowFixMe[incompatible-use]\n light: processColor(dynamic.light),\n // $FlowFixMe[incompatible-use]\n dark: processColor(dynamic.dark),\n // $FlowFixMe[incompatible-use]\n highContrastLight: processColor(dynamic.highContrastLight),\n // $FlowFixMe[incompatible-use]\n highContrastDark: processColor(dynamic.highContrastDark),\n },\n };\n return dynamicColor;\n }\n return color;\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 * @format\n * @flow\n */\n\n'use strict';\n\nimport type {____FontVariantArray_Internal} from './StyleSheetTypes';\n\nfunction processFontVariant(\n fontVariant: ____FontVariantArray_Internal | string,\n): ?____FontVariantArray_Internal {\n if (Array.isArray(fontVariant)) {\n return fontVariant;\n }\n\n // $FlowFixMe[incompatible-type]\n const match: ?____FontVariantArray_Internal = fontVariant\n .split(' ')\n .filter(Boolean);\n\n return match;\n}\n\nmodule.exports = processFontVariant;\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 * @format\n * @flow\n */\n\n'use strict';\n\nconst stringifySafe = require('../Utilities/stringifySafe').default;\nconst invariant = require('invariant');\n\n/**\n * Generate a transform matrix based on the provided transforms, and use that\n * within the style object instead.\n *\n * This allows us to provide an API that is similar to CSS, where transforms may\n * be applied in an arbitrary order, and yet have a universal, singular\n * interface to native code.\n */\nfunction processTransform(\n transform: Array | string,\n): Array | Array {\n if (typeof transform === 'string') {\n const regex = new RegExp(/(\\w+)\\(([^)]+)\\)/g);\n let transformArray: Array = [];\n let matches;\n\n while ((matches = regex.exec(transform))) {\n const {key, value} = _getKeyAndValueFromCSSTransform(\n matches[1],\n matches[2],\n );\n\n if (value !== undefined) {\n transformArray.push({[key]: value});\n }\n }\n transform = transformArray;\n }\n\n if (__DEV__) {\n _validateTransforms(transform);\n }\n\n return transform;\n}\n\nconst _getKeyAndValueFromCSSTransform: (\n key:\n | string\n | $TEMPORARY$string<'matrix'>\n | $TEMPORARY$string<'perspective'>\n | $TEMPORARY$string<'rotate'>\n | $TEMPORARY$string<'rotateX'>\n | $TEMPORARY$string<'rotateY'>\n | $TEMPORARY$string<'rotateZ'>\n | $TEMPORARY$string<'scale'>\n | $TEMPORARY$string<'scaleX'>\n | $TEMPORARY$string<'scaleY'>\n | $TEMPORARY$string<'skewX'>\n | $TEMPORARY$string<'skewY'>\n | $TEMPORARY$string<'translate'>\n | $TEMPORARY$string<'translate3d'>\n | $TEMPORARY$string<'translateX'>\n | $TEMPORARY$string<'translateY'>,\n args: string,\n) => {key: string, value?: number[] | number | string} = (key, args) => {\n const argsWithUnitsRegex = new RegExp(/([+-]?\\d+(\\.\\d+)?)([a-zA-Z]+)?/g);\n\n switch (key) {\n case 'matrix':\n return {key, value: args.match(/[+-]?\\d+(\\.\\d+)?/g)?.map(Number)};\n case 'translate':\n case 'translate3d':\n const parsedArgs = [];\n let missingUnitOfMeasurement = false;\n\n let matches;\n while ((matches = argsWithUnitsRegex.exec(args))) {\n const value = Number(matches[1]);\n const unitOfMeasurement = matches[3];\n\n if (value !== 0 && !unitOfMeasurement) {\n missingUnitOfMeasurement = true;\n }\n\n parsedArgs.push(value);\n }\n\n if (__DEV__) {\n invariant(\n !missingUnitOfMeasurement,\n `Transform with key ${key} must have units unless the provided value is 0, found %s`,\n `${key}(${args})`,\n );\n\n if (key === 'translate') {\n invariant(\n parsedArgs?.length === 1 || parsedArgs?.length === 2,\n 'Transform with key translate must be an string with 1 or 2 parameters, found %s: %s',\n parsedArgs?.length,\n `${key}(${args})`,\n );\n } else {\n invariant(\n parsedArgs?.length === 3,\n 'Transform with key translate3d must be an string with 3 parameters, found %s: %s',\n parsedArgs?.length,\n `${key}(${args})`,\n );\n }\n }\n\n if (parsedArgs?.length === 1) {\n parsedArgs.push(0);\n }\n\n return {key: 'translate', value: parsedArgs};\n case 'translateX':\n case 'translateY':\n case 'perspective':\n const argMatches = argsWithUnitsRegex.exec(args);\n\n if (!argMatches?.length) {\n return {key, value: undefined};\n }\n\n const value = Number(argMatches[1]);\n const unitOfMeasurement = argMatches[3];\n\n if (__DEV__) {\n invariant(\n value === 0 || unitOfMeasurement,\n `Transform with key ${key} must have units unless the provided value is 0, found %s`,\n `${key}(${args})`,\n );\n }\n\n return {key, value};\n\n default:\n return {key, value: !isNaN(args) ? Number(args) : args};\n }\n};\n\nfunction _validateTransforms(transform: Array): void {\n transform.forEach(transformation => {\n const keys = Object.keys(transformation);\n invariant(\n keys.length === 1,\n 'You must specify exactly one property per transform object. Passed properties: %s',\n stringifySafe(transformation),\n );\n const key = keys[0];\n const value = transformation[key];\n _validateTransform(key, value, transformation);\n });\n}\n\nfunction _validateTransform(\n key:\n | string\n | $TEMPORARY$string<'matrix'>\n | $TEMPORARY$string<'perspective'>\n | $TEMPORARY$string<'rotate'>\n | $TEMPORARY$string<'rotateX'>\n | $TEMPORARY$string<'rotateY'>\n | $TEMPORARY$string<'rotateZ'>\n | $TEMPORARY$string<'scale'>\n | $TEMPORARY$string<'scaleX'>\n | $TEMPORARY$string<'scaleY'>\n | $TEMPORARY$string<'skewX'>\n | $TEMPORARY$string<'skewY'>\n | $TEMPORARY$string<'translate'>\n | $TEMPORARY$string<'translateX'>\n | $TEMPORARY$string<'translateY'>,\n value: any | number | string,\n transformation: any,\n) {\n invariant(\n !value.getValue,\n 'You passed an Animated.Value to a normal component. ' +\n 'You need to wrap that component in an Animated. For example, ' +\n 'replace by .',\n );\n\n const multivalueTransforms = ['matrix', 'translate'];\n if (multivalueTransforms.indexOf(key) !== -1) {\n invariant(\n Array.isArray(value),\n 'Transform with key of %s must have an array as the value: %s',\n key,\n stringifySafe(transformation),\n );\n }\n switch (key) {\n case 'matrix':\n invariant(\n value.length === 9 || value.length === 16,\n 'Matrix transform must have a length of 9 (2d) or 16 (3d). ' +\n 'Provided matrix has a length of %s: %s',\n /* $FlowFixMe[prop-missing] (>=0.84.0 site=react_native_fb) This\n * comment suppresses an error found when Flow v0.84 was deployed. To\n * see the error, delete this comment and run Flow. */\n value.length,\n stringifySafe(transformation),\n );\n break;\n case 'translate':\n invariant(\n value.length === 2 || value.length === 3,\n 'Transform with key translate must be an array of length 2 or 3, found %s: %s',\n /* $FlowFixMe[prop-missing] (>=0.84.0 site=react_native_fb) This\n * comment suppresses an error found when Flow v0.84 was deployed. To\n * see the error, delete this comment and run Flow. */\n value.length,\n stringifySafe(transformation),\n );\n break;\n case 'rotateX':\n case 'rotateY':\n case 'rotateZ':\n case 'rotate':\n case 'skewX':\n case 'skewY':\n invariant(\n typeof value === 'string',\n 'Transform with key of \"%s\" must be a string: %s',\n key,\n stringifySafe(transformation),\n );\n invariant(\n value.indexOf('deg') > -1 || value.indexOf('rad') > -1,\n 'Rotate transform must be expressed in degrees (deg) or radians ' +\n '(rad): %s',\n stringifySafe(transformation),\n );\n break;\n case 'perspective':\n invariant(\n typeof value === 'number',\n 'Transform with key of \"%s\" must be a number: %s',\n key,\n stringifySafe(transformation),\n );\n invariant(\n value !== 0,\n 'Transform with key of \"%s\" cannot be zero: %s',\n key,\n stringifySafe(transformation),\n );\n break;\n case 'translateX':\n case 'translateY':\n case 'scale':\n case 'scaleX':\n case 'scaleY':\n invariant(\n typeof value === 'number',\n 'Transform with key of \"%s\" must be a number: %s',\n key,\n stringifySafe(transformation),\n );\n break;\n default:\n invariant(\n false,\n 'Invalid transform %s: %s',\n key,\n stringifySafe(transformation),\n );\n }\n}\n\nmodule.exports = processTransform;\n","function _defineProperty(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n\n return obj;\n}\n\nmodule.exports = _defineProperty, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","/**\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 * @flow strict\n * @format\n */\n\n'use strict';\n\nconst dummySize = {width: undefined, height: undefined};\ntype Size = {width: ?number, height: ?number};\n\nconst sizesDiffer = function (one: Size, two: Size): boolean {\n const defaultedOne = one || dummySize;\n const defaultedTwo = two || dummySize;\n return (\n defaultedOne !== defaultedTwo &&\n (defaultedOne.width !== defaultedTwo.width ||\n defaultedOne.height !== defaultedTwo.height)\n );\n};\n\nmodule.exports = sizesDiffer;\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 * @format\n * @flow strict\n */\n\n'use strict';\n\n/**\n * Unrolls an array comparison specially for matrices. Prioritizes\n * checking of indices that are most likely to change so that the comparison\n * bails as early as possible.\n *\n * @param {MatrixMath.Matrix} one First matrix.\n * @param {MatrixMath.Matrix} two Second matrix.\n * @return {boolean} Whether or not the two matrices differ.\n */\nconst matricesDiffer = function (\n one: ?Array,\n two: ?Array,\n): boolean {\n if (one === two) {\n return false;\n }\n return (\n !one ||\n !two ||\n one[12] !== two[12] ||\n one[13] !== two[13] ||\n one[14] !== two[14] ||\n one[5] !== two[5] ||\n one[10] !== two[10] ||\n one[0] !== two[0] ||\n one[1] !== two[1] ||\n one[2] !== two[2] ||\n one[3] !== two[3] ||\n one[4] !== two[4] ||\n one[6] !== two[6] ||\n one[7] !== two[7] ||\n one[8] !== two[8] ||\n one[9] !== two[9] ||\n one[11] !== two[11] ||\n one[15] !== two[15]\n );\n};\n\nmodule.exports = matricesDiffer;\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 * @format\n * @flow\n */\n\n'use strict';\n\ntype Point = {\n x: ?number,\n y: ?number,\n ...\n};\n\nconst dummyPoint = {x: undefined, y: undefined};\n\nconst pointsDiffer = function (one: ?Point, two: ?Point): boolean {\n one = one || dummyPoint;\n two = two || dummyPoint;\n return one !== two && (one.x !== two.x || one.y !== two.y);\n};\n\nmodule.exports = pointsDiffer;\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 * @format\n * @flow\n */\n\n'use strict';\n\ntype Inset = {\n top: ?number,\n left: ?number,\n right: ?number,\n bottom: ?number,\n ...\n};\n\nconst dummyInsets = {\n top: undefined,\n left: undefined,\n right: undefined,\n bottom: undefined,\n};\n\nconst insetsDiffer = function (one: Inset, two: Inset): boolean {\n one = one || dummyInsets;\n two = two || dummyInsets;\n return (\n one !== two &&\n (one.top !== two.top ||\n one.left !== two.left ||\n one.right !== two.right ||\n one.bottom !== two.bottom)\n );\n};\n\nmodule.exports = insetsDiffer;\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 * @format\n * @flow strict-local\n */\n\n'use strict';\n\nimport type {ColorValue} from './StyleSheet';\n\nimport processColor, {type ProcessedColorValue} from './processColor';\n\nconst TRANSPARENT = 0; // rgba(0, 0, 0, 0)\n\nfunction processColorArray(\n colors: ?$ReadOnlyArray,\n): ?$ReadOnlyArray {\n return colors == null ? null : colors.map(processColorElement);\n}\n\nfunction processColorElement(color: ColorValue): ProcessedColorValue {\n const value = processColor(color);\n // For invalid colors, fallback to transparent.\n if (value == null) {\n console.error('Invalid value in color array:', color);\n return TRANSPARENT;\n }\n return value;\n}\n\nmodule.exports = processColorArray;\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 * @format\n * @flow\n */\n\n// Resolves an asset into a `source` for `Image`.\n\n'use strict';\n\nimport type {ResolvedAssetSource} from './AssetSourceResolver';\n\nconst AssetSourceResolver = require('./AssetSourceResolver');\nconst {pickScale} = require('./AssetUtils');\nconst AssetRegistry = require('@react-native/assets/registry');\n\nlet _customSourceTransformer, _serverURL, _scriptURL;\n\nlet _sourceCodeScriptURL: ?string;\nfunction getSourceCodeScriptURL(): ?string {\n if (_sourceCodeScriptURL) {\n return _sourceCodeScriptURL;\n }\n\n let sourceCode =\n global.nativeExtensions && global.nativeExtensions.SourceCode;\n if (!sourceCode) {\n sourceCode = require('../NativeModules/specs/NativeSourceCode').default;\n }\n _sourceCodeScriptURL = sourceCode.getConstants().scriptURL;\n return _sourceCodeScriptURL;\n}\n\nfunction getDevServerURL(): ?string {\n if (_serverURL === undefined) {\n const sourceCodeScriptURL = getSourceCodeScriptURL();\n const match =\n sourceCodeScriptURL && sourceCodeScriptURL.match(/^https?:\\/\\/.*?\\//);\n if (match) {\n // jsBundle was loaded from network\n _serverURL = match[0];\n } else {\n // jsBundle was loaded from file\n _serverURL = null;\n }\n }\n return _serverURL;\n}\n\nfunction _coerceLocalScriptURL(scriptURL: ?string): ?string {\n if (scriptURL) {\n if (scriptURL.startsWith('assets://')) {\n // android: running from within assets, no offline path to use\n return null;\n }\n scriptURL = scriptURL.substring(0, scriptURL.lastIndexOf('/') + 1);\n if (!scriptURL.includes('://')) {\n // Add file protocol in case we have an absolute file path and not a URL.\n // This shouldn't really be necessary. scriptURL should be a URL.\n scriptURL = 'file://' + scriptURL;\n }\n }\n return scriptURL;\n}\n\nfunction getScriptURL(): ?string {\n if (_scriptURL === undefined) {\n _scriptURL = _coerceLocalScriptURL(getSourceCodeScriptURL());\n }\n return _scriptURL;\n}\n\nfunction setCustomSourceTransformer(\n transformer: (resolver: AssetSourceResolver) => ResolvedAssetSource,\n): void {\n _customSourceTransformer = transformer;\n}\n\n/**\n * `source` is either a number (opaque type returned by require('./foo.png'))\n * or an `ImageSource` like { uri: '' }\n */\nfunction resolveAssetSource(source: any): ?ResolvedAssetSource {\n if (typeof source === 'object') {\n return source;\n }\n\n const asset = AssetRegistry.getAssetByID(source);\n if (!asset) {\n return null;\n }\n\n const resolver = new AssetSourceResolver(\n getDevServerURL(),\n getScriptURL(),\n asset,\n );\n if (_customSourceTransformer) {\n return _customSourceTransformer(resolver);\n }\n return resolver.defaultAsset();\n}\n\nresolveAssetSource.pickScale = pickScale;\nresolveAssetSource.setCustomSourceTransformer = setCustomSourceTransformer;\nmodule.exports = resolveAssetSource;\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 * @flow strict\n * @format\n */\n\nimport type {TurboModule} from '../../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../../TurboModule/TurboModuleRegistry';\n\nexport interface Spec extends TurboModule {\n +getConstants: () => {|\n scriptURL: string,\n |};\n}\n\nconst NativeModule = TurboModuleRegistry.getEnforcing('SourceCode');\nlet constants = null;\n\nconst NativeSourceCode = {\n getConstants(): {|\n scriptURL: string,\n |} {\n if (constants == null) {\n constants = NativeModule.getConstants();\n }\n\n return constants;\n },\n};\n\nexport default NativeSourceCode;\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 * @flow strict\n * @format\n */\n\n'use strict';\n\nexport type PackagerAsset = {\n +__packager_asset: boolean,\n +fileSystemLocation: string,\n +httpServerLocation: string,\n +width: ?number,\n +height: ?number,\n +scales: Array,\n +hash: string,\n +name: string,\n +type: string,\n ...\n};\n\nconst assets: Array = [];\n\nfunction registerAsset(asset: PackagerAsset): number {\n // `push` returns new array length, so the first asset will\n // get id 1 (not 0) to make the value truthy\n return assets.push(asset);\n}\n\nfunction getAssetByID(assetId: number): PackagerAsset {\n return assets[assetId - 1];\n}\n\nmodule.exports = {registerAsset, getAssetByID};\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 * @flow\n * @format\n */\n\n'use strict';\n\nexport type ResolvedAssetSource = {|\n +__packager_asset: boolean,\n +width: ?number,\n +height: ?number,\n +uri: string,\n +scale: number,\n|};\n\nimport type {PackagerAsset} from '@react-native/assets/registry';\n\nconst PixelRatio = require('../Utilities/PixelRatio');\nconst Platform = require('../Utilities/Platform');\nconst {pickScale} = require('./AssetUtils');\nconst {\n getAndroidResourceFolderName,\n getAndroidResourceIdentifier,\n getBasePath,\n} = require('@react-native/assets/path-support');\nconst invariant = require('invariant');\n\n/**\n * Returns a path like 'assets/AwesomeModule/icon@2x.png'\n */\nfunction getScaledAssetPath(asset: PackagerAsset): string {\n const scale = pickScale(asset.scales, PixelRatio.get());\n const scaleSuffix = scale === 1 ? '' : '@' + scale + 'x';\n const assetDir = getBasePath(asset);\n return assetDir + '/' + asset.name + scaleSuffix + '.' + asset.type;\n}\n\n/**\n * Returns a path like 'drawable-mdpi/icon.png'\n */\nfunction getAssetPathInDrawableFolder(asset: PackagerAsset): string {\n const scale = pickScale(asset.scales, PixelRatio.get());\n const drawableFolder = getAndroidResourceFolderName(asset, scale);\n const fileName = getAndroidResourceIdentifier(asset);\n return drawableFolder + '/' + fileName + '.' + asset.type;\n}\n\nclass AssetSourceResolver {\n serverUrl: ?string;\n // where the jsbundle is being run from\n jsbundleUrl: ?string;\n // the asset to resolve\n asset: PackagerAsset;\n\n constructor(serverUrl: ?string, jsbundleUrl: ?string, asset: PackagerAsset) {\n this.serverUrl = serverUrl;\n this.jsbundleUrl = jsbundleUrl;\n this.asset = asset;\n }\n\n isLoadedFromServer(): boolean {\n return !!this.serverUrl;\n }\n\n isLoadedFromFileSystem(): boolean {\n return !!(this.jsbundleUrl && this.jsbundleUrl.startsWith('file://'));\n }\n\n defaultAsset(): ResolvedAssetSource {\n if (this.isLoadedFromServer()) {\n return this.assetServerURL();\n }\n\n if (Platform.OS === 'android') {\n return this.isLoadedFromFileSystem()\n ? this.drawableFolderInBundle()\n : this.resourceIdentifierWithoutScale();\n } else {\n return this.scaledAssetURLNearBundle();\n }\n }\n\n /**\n * Returns an absolute URL which can be used to fetch the asset\n * from the devserver\n */\n assetServerURL(): ResolvedAssetSource {\n invariant(!!this.serverUrl, 'need server to load from');\n return this.fromSource(\n this.serverUrl +\n getScaledAssetPath(this.asset) +\n '?platform=' +\n Platform.OS +\n '&hash=' +\n this.asset.hash,\n );\n }\n\n /**\n * Resolves to just the scaled asset filename\n * E.g. 'assets/AwesomeModule/icon@2x.png'\n */\n scaledAssetPath(): ResolvedAssetSource {\n return this.fromSource(getScaledAssetPath(this.asset));\n }\n\n /**\n * Resolves to where the bundle is running from, with a scaled asset filename\n * E.g. 'file:///sdcard/bundle/assets/AwesomeModule/icon@2x.png'\n */\n scaledAssetURLNearBundle(): ResolvedAssetSource {\n const path = this.jsbundleUrl || 'file://';\n return this.fromSource(\n // Assets can have relative paths outside of the project root.\n // When bundling them we replace `../` with `_` to make sure they\n // don't end up outside of the expected assets directory.\n path + getScaledAssetPath(this.asset).replace(/\\.\\.\\//g, '_'),\n );\n }\n\n /**\n * The default location of assets bundled with the app, located by\n * resource identifier\n * The Android resource system picks the correct scale.\n * E.g. 'assets_awesomemodule_icon'\n */\n resourceIdentifierWithoutScale(): ResolvedAssetSource {\n invariant(\n Platform.OS === 'android',\n 'resource identifiers work on Android',\n );\n return this.fromSource(getAndroidResourceIdentifier(this.asset));\n }\n\n /**\n * If the jsbundle is running from a sideload location, this resolves assets\n * relative to its location\n * E.g. 'file:///sdcard/AwesomeModule/drawable-mdpi/icon.png'\n */\n drawableFolderInBundle(): ResolvedAssetSource {\n const path = this.jsbundleUrl || 'file://';\n return this.fromSource(path + getAssetPathInDrawableFolder(this.asset));\n }\n\n fromSource(source: string): ResolvedAssetSource {\n return {\n __packager_asset: true,\n width: this.asset.width,\n height: this.asset.height,\n uri: source,\n scale: pickScale(this.asset.scales, PixelRatio.get()),\n };\n }\n\n static pickScale: (scales: Array, deviceScale?: number) => number =\n pickScale;\n}\n\nmodule.exports = AssetSourceResolver;\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 * @flow\n * @format\n */\n\nimport PixelRatio from '../Utilities/PixelRatio';\n\nlet cacheBreaker;\nlet warnIfCacheBreakerUnset = true;\n\nexport function pickScale(scales: Array, deviceScale?: number): number {\n if (deviceScale == null) {\n deviceScale = PixelRatio.get();\n }\n // Packager guarantees that `scales` array is sorted\n for (let i = 0; i < scales.length; i++) {\n if (scales[i] >= deviceScale) {\n return scales[i];\n }\n }\n\n // If nothing matches, device scale is larger than any available\n // scales, so we return the biggest one. Unless the array is empty,\n // in which case we default to 1\n return scales[scales.length - 1] || 1;\n}\n\nexport function setUrlCacheBreaker(appendage: string) {\n cacheBreaker = appendage;\n}\n\nexport function getUrlCacheBreaker(): string {\n if (cacheBreaker == null) {\n if (__DEV__ && warnIfCacheBreakerUnset) {\n warnIfCacheBreakerUnset = false;\n console.warn(\n 'AssetUtils.getUrlCacheBreaker: Cache breaker value is unset',\n );\n }\n return '';\n }\n return cacheBreaker;\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 * @format\n * @flow strict-local\n */\n\n'use strict';\n\nconst Dimensions = require('./Dimensions');\n\n/**\n * PixelRatio class gives access to the device pixel density.\n *\n * ## Fetching a correctly sized image\n *\n * You should get a higher resolution image if you are on a high pixel density\n * device. A good rule of thumb is to multiply the size of the image you display\n * by the pixel ratio.\n *\n * ```\n * var image = getImage({\n * width: PixelRatio.getPixelSizeForLayoutSize(200),\n * height: PixelRatio.getPixelSizeForLayoutSize(100),\n * });\n * \n * ```\n *\n * ## Pixel grid snapping\n *\n * In iOS, you can specify positions and dimensions for elements with arbitrary\n * precision, for example 29.674825. But, ultimately the physical display only\n * have a fixed number of pixels, for example 640×960 for iPhone 4 or 750×1334\n * for iPhone 6. iOS tries to be as faithful as possible to the user value by\n * spreading one original pixel into multiple ones to trick the eye. The\n * downside of this technique is that it makes the resulting element look\n * blurry.\n *\n * In practice, we found out that developers do not want this feature and they\n * have to work around it by doing manual rounding in order to avoid having\n * blurry elements. In React Native, we are rounding all the pixels\n * automatically.\n *\n * We have to be careful when to do this rounding. You never want to work with\n * rounded and unrounded values at the same time as you're going to accumulate\n * rounding errors. Having even one rounding error is deadly because a one\n * pixel border may vanish or be twice as big.\n *\n * In React Native, everything in JavaScript and within the layout engine works\n * with arbitrary precision numbers. It's only when we set the position and\n * dimensions of the native element on the main thread that we round. Also,\n * rounding is done relative to the root rather than the parent, again to avoid\n * accumulating rounding errors.\n *\n */\nclass PixelRatio {\n /**\n * Returns the device pixel density. Some examples:\n *\n * - PixelRatio.get() === 1\n * - mdpi Android devices (160 dpi)\n * - PixelRatio.get() === 1.5\n * - hdpi Android devices (240 dpi)\n * - PixelRatio.get() === 2\n * - iPhone 4, 4S\n * - iPhone 5, 5c, 5s\n * - iPhone 6\n * - iPhone 7\n * - iPhone 8\n * - iPhone SE\n * - xhdpi Android devices (320 dpi)\n * - PixelRatio.get() === 3\n * - iPhone 6 Plus\n * - iPhone 7 Plus\n * - iPhone 8 Plus\n * - iPhone X\n * - xxhdpi Android devices (480 dpi)\n * - PixelRatio.get() === 3.5\n * - Nexus 6\n */\n static get(): number {\n return Dimensions.get('window').scale;\n }\n\n /**\n * Returns the scaling factor for font sizes. This is the ratio that is used to calculate the\n * absolute font size, so any elements that heavily depend on that should use this to do\n * calculations.\n *\n * If a font scale is not set, this returns the device pixel ratio.\n *\n * This reflects the user preference set in:\n * - Settings > Display > Font size on Android,\n * - Settings > Display & Brightness > Text Size on iOS.\n */\n static getFontScale(): number {\n return Dimensions.get('window').fontScale || PixelRatio.get();\n }\n\n /**\n * Converts a layout size (dp) to pixel size (px).\n *\n * Guaranteed to return an integer number.\n */\n static getPixelSizeForLayoutSize(layoutSize: number): number {\n return Math.round(layoutSize * PixelRatio.get());\n }\n\n /**\n * Rounds a layout size (dp) to the nearest layout size that corresponds to\n * an integer number of pixels. For example, on a device with a PixelRatio\n * of 3, `PixelRatio.roundToNearestPixel(8.4) = 8.33`, which corresponds to\n * exactly (8.33 * 3) = 25 pixels.\n */\n static roundToNearestPixel(layoutSize: number): number {\n const ratio = PixelRatio.get();\n return Math.round(layoutSize * ratio) / ratio;\n }\n\n // No-op for iOS, but used on the web. Should not be documented.\n static startDetecting() {}\n}\n\nmodule.exports = PixelRatio;\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 * @format\n * @flow\n */\n\nimport RCTDeviceEventEmitter from '../EventEmitter/RCTDeviceEventEmitter';\nimport EventEmitter, {\n type EventSubscription,\n} from '../vendor/emitter/EventEmitter';\nimport NativeDeviceInfo, {\n type DimensionsPayload,\n type DisplayMetrics,\n type DisplayMetricsAndroid,\n} from './NativeDeviceInfo';\nimport invariant from 'invariant';\n\nconst eventEmitter = new EventEmitter<{\n change: [DimensionsPayload],\n}>();\nlet dimensionsInitialized = false;\nlet dimensions: DimensionsPayload;\n\nclass Dimensions {\n /**\n * NOTE: `useWindowDimensions` is the preferred API for React components.\n *\n * Initial dimensions are set before `runApplication` is called so they should\n * be available before any other require's are run, but may be updated later.\n *\n * Note: Although dimensions are available immediately, they may change (e.g\n * due to device rotation) so any rendering logic or styles that depend on\n * these constants should try to call this function on every render, rather\n * than caching the value (for example, using inline styles rather than\n * setting a value in a `StyleSheet`).\n *\n * Example: `const {height, width} = Dimensions.get('window');`\n *\n * @param {string} dim Name of dimension as defined when calling `set`.\n * @returns {DisplayMetrics? | DisplayMetricsAndroid?} Value for the dimension.\n */\n static get(dim: string): DisplayMetrics | DisplayMetricsAndroid {\n invariant(dimensions[dim], 'No dimension set for key ' + dim);\n return dimensions[dim];\n }\n\n /**\n * This should only be called from native code by sending the\n * didUpdateDimensions event.\n *\n * @param {DimensionsPayload} dims Simple string-keyed object of dimensions to set\n */\n static set(dims: $ReadOnly): void {\n // We calculate the window dimensions in JS so that we don't encounter loss of\n // precision in transferring the dimensions (which could be non-integers) over\n // the bridge.\n let {screen, window} = dims;\n const {windowPhysicalPixels} = dims;\n if (windowPhysicalPixels) {\n window = {\n width: windowPhysicalPixels.width / windowPhysicalPixels.scale,\n height: windowPhysicalPixels.height / windowPhysicalPixels.scale,\n scale: windowPhysicalPixels.scale,\n fontScale: windowPhysicalPixels.fontScale,\n };\n }\n const {screenPhysicalPixels} = dims;\n if (screenPhysicalPixels) {\n screen = {\n width: screenPhysicalPixels.width / screenPhysicalPixels.scale,\n height: screenPhysicalPixels.height / screenPhysicalPixels.scale,\n scale: screenPhysicalPixels.scale,\n fontScale: screenPhysicalPixels.fontScale,\n };\n } else if (screen == null) {\n screen = window;\n }\n\n dimensions = {window, screen};\n if (dimensionsInitialized) {\n // Don't fire 'change' the first time the dimensions are set.\n eventEmitter.emit('change', dimensions);\n } else {\n dimensionsInitialized = true;\n }\n }\n\n /**\n * Add an event handler. Supported events:\n *\n * - `change`: Fires when a property within the `Dimensions` object changes. The argument\n * to the event handler is an object with `window` and `screen` properties whose values\n * are the same as the return values of `Dimensions.get('window')` and\n * `Dimensions.get('screen')`, respectively.\n */\n static addEventListener(\n type: 'change',\n handler: Function,\n ): EventSubscription {\n invariant(\n type === 'change',\n 'Trying to subscribe to unknown event: \"%s\"',\n type,\n );\n return eventEmitter.addListener(type, handler);\n }\n}\n\nlet initialDims: ?$ReadOnly =\n global.nativeExtensions &&\n global.nativeExtensions.DeviceInfo &&\n global.nativeExtensions.DeviceInfo.Dimensions;\nif (!initialDims) {\n // Subscribe before calling getConstants to make sure we don't miss any updates in between.\n RCTDeviceEventEmitter.addListener(\n 'didUpdateDimensions',\n (update: DimensionsPayload) => {\n Dimensions.set(update);\n },\n );\n initialDims = NativeDeviceInfo.getConstants().Dimensions;\n}\n\nDimensions.set(initialDims);\n\nmodule.exports = Dimensions;\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 * @flow strict\n * @format\n */\n\nimport type {TurboModule} from '../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../TurboModule/TurboModuleRegistry';\n\nexport type DisplayMetricsAndroid = {|\n width: number,\n height: number,\n scale: number,\n fontScale: number,\n densityDpi: number,\n|};\n\nexport type DisplayMetrics = {|\n width: number,\n height: number,\n scale: number,\n fontScale: number,\n|};\n\nexport type DimensionsPayload = {|\n window?: DisplayMetrics,\n screen?: DisplayMetrics,\n windowPhysicalPixels?: DisplayMetricsAndroid,\n screenPhysicalPixels?: DisplayMetricsAndroid,\n|};\n\nexport interface Spec extends TurboModule {\n +getConstants: () => {|\n +Dimensions: DimensionsPayload,\n +isIPhoneX_deprecated?: boolean,\n |};\n}\n\nconst NativeModule: Spec = TurboModuleRegistry.getEnforcing('DeviceInfo');\nlet constants = null;\n\nconst NativeDeviceInfo = {\n getConstants(): {|\n +Dimensions: DimensionsPayload,\n +isIPhoneX_deprecated?: boolean,\n |} {\n if (constants == null) {\n constants = NativeModule.getConstants();\n }\n return constants;\n },\n};\n\nexport default NativeDeviceInfo;\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 * @format\n * @flow strict\n */\n\n'use strict';\n\nimport type {PackagerAsset} from './registry.js';\n\nconst androidScaleSuffix = {\n '0.75': 'ldpi',\n '1': 'mdpi',\n '1.5': 'hdpi',\n '2': 'xhdpi',\n '3': 'xxhdpi',\n '4': 'xxxhdpi',\n};\n\n/**\n * FIXME: using number to represent discrete scale numbers is fragile in essence because of\n * floating point numbers imprecision.\n */\nfunction getAndroidAssetSuffix(scale: number): string {\n if (scale.toString() in androidScaleSuffix) {\n return androidScaleSuffix[scale.toString()];\n }\n\n throw new Error('no such scale ' + scale.toString());\n}\n\n// See https://developer.android.com/guide/topics/resources/drawable-resource.html\nconst drawableFileTypes = new Set([\n 'gif',\n 'jpeg',\n 'jpg',\n 'png',\n 'svg',\n 'webp',\n 'xml',\n]);\n\nfunction getAndroidResourceFolderName(\n asset: PackagerAsset,\n scale: number,\n): string | $TEMPORARY$string<'raw'> {\n if (!drawableFileTypes.has(asset.type)) {\n return 'raw';\n }\n const suffix = getAndroidAssetSuffix(scale);\n if (!suffix) {\n throw new Error(\n \"Don't know which android drawable suffix to use for scale: \" +\n scale +\n '\\nAsset: ' +\n JSON.stringify(asset, null, '\\t') +\n '\\nPossible scales are:' +\n JSON.stringify(androidScaleSuffix, null, '\\t'),\n );\n }\n return 'drawable-' + suffix;\n}\n\nfunction getAndroidResourceIdentifier(asset: PackagerAsset): string {\n return (getBasePath(asset) + '/' + asset.name)\n .toLowerCase()\n .replace(/\\//g, '_') // Encode folder structure in file name\n .replace(/([^a-z0-9_])/g, '') // Remove illegal chars\n .replace(/^assets_/, ''); // Remove \"assets_\" prefix\n}\n\nfunction getBasePath(asset: PackagerAsset): string {\n const basePath = asset.httpServerLocation;\n return basePath.startsWith('/') ? basePath.substr(1) : basePath;\n}\n\nmodule.exports = {\n getAndroidResourceFolderName,\n getAndroidResourceIdentifier,\n getBasePath,\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 * @noformat\n * @flow strict-local\n * @generated SignedSource<>\n *\n * This file was sync'd from the facebook/react repository.\n */\n\n'use strict';\n\nimport {type ViewConfig} from './ReactNativeTypes';\nimport invariant from 'invariant';\n\n// Event configs\nconst customBubblingEventTypes: {\n [eventName: string]: $ReadOnly<{\n phasedRegistrationNames: $ReadOnly<{\n captured: string,\n bubbled: string,\n skipBubbling?: ?boolean,\n }>,\n }>,\n ...,\n} = {};\nconst customDirectEventTypes: {\n [eventName: string]: $ReadOnly<{\n registrationName: string,\n }>,\n ...,\n} = {};\n\nexports.customBubblingEventTypes = customBubblingEventTypes;\nexports.customDirectEventTypes = customDirectEventTypes;\n\nconst viewConfigCallbacks = new Map();\nconst viewConfigs = new Map();\n\nfunction processEventTypes(viewConfig: ViewConfig): void {\n const {bubblingEventTypes, directEventTypes} = viewConfig;\n\n if (__DEV__) {\n if (bubblingEventTypes != null && directEventTypes != null) {\n for (const topLevelType in directEventTypes) {\n invariant(\n bubblingEventTypes[topLevelType] == null,\n 'Event cannot be both direct and bubbling: %s',\n topLevelType,\n );\n }\n }\n }\n\n if (bubblingEventTypes != null) {\n for (const topLevelType in bubblingEventTypes) {\n if (customBubblingEventTypes[topLevelType] == null) {\n customBubblingEventTypes[topLevelType] =\n bubblingEventTypes[topLevelType];\n }\n }\n }\n\n if (directEventTypes != null) {\n for (const topLevelType in directEventTypes) {\n if (customDirectEventTypes[topLevelType] == null) {\n customDirectEventTypes[topLevelType] = directEventTypes[topLevelType];\n }\n }\n }\n}\n\n/**\n * Registers a native view/component by name.\n * A callback is provided to load the view config from UIManager.\n * The callback is deferred until the view is actually rendered.\n */\nexports.register = function(name: string, callback: () => ViewConfig): string {\n invariant(\n !viewConfigCallbacks.has(name),\n 'Tried to register two views with the same name %s',\n name,\n );\n invariant(\n typeof callback === 'function',\n 'View config getter callback for component `%s` must be a function (received `%s`)',\n name,\n callback === null ? 'null' : typeof callback,\n );\n viewConfigCallbacks.set(name, callback);\n return name;\n};\n\n/**\n * Retrieves a config for the specified view.\n * If this is the first time the view has been used,\n * This configuration will be lazy-loaded from UIManager.\n */\nexports.get = function(name: string): ViewConfig {\n let viewConfig;\n if (!viewConfigs.has(name)) {\n const callback = viewConfigCallbacks.get(name);\n if (typeof callback !== 'function') {\n invariant(\n false,\n 'View config getter callback for component `%s` must be a function (received `%s`).%s',\n name,\n callback === null ? 'null' : typeof callback,\n typeof name[0] === 'string' && /[a-z]/.test(name[0])\n ? ' Make sure to start component names with a capital letter.'\n : '',\n );\n }\n viewConfig = callback();\n processEventTypes(viewConfig);\n viewConfigs.set(name, viewConfig);\n\n // Clear the callback after the config is set so that\n // we don't mask any errors during registration.\n viewConfigCallbacks.set(name, null);\n } else {\n viewConfig = viewConfigs.get(name);\n }\n invariant(viewConfig, 'View config not found for name %s', name);\n return viewConfig;\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 * @format\n * @flow\n */\n\nimport PlatformBaseViewConfig from '../NativeComponent/PlatformBaseViewConfig';\nimport {type ViewConfig} from '../Renderer/shims/ReactNativeTypes';\n\nconst IGNORED_KEYS = ['transform', 'hitSlop'];\n\n/**\n * The purpose of this function is to validate that the view config that\n * native exposes for a given view manager is the same as the view config\n * that is specified for that view manager in JS.\n *\n * In order to improve perf, we want to avoid calling into native to get\n * the view config when each view manager is used. To do this, we are moving\n * the configs to JS. In the future we will use these JS based view configs\n * to codegen the view manager on native to ensure they stay in sync without\n * this runtime check.\n *\n * If this function fails, that likely means a change was made to the native\n * view manager without updating the JS config as well. Ideally you can make\n * that direct change to the JS config. If you don't know what the differences\n * are, the best approach I've found is to create a view that prints\n * the return value of getNativeComponentAttributes, and then copying that\n * text and pasting it back into JS:\n * {JSON.stringify(getNativeComponentAttributes('RCTView'))}\n *\n * This is meant to be a stopgap until the time comes when we only have a\n * single source of truth. I wonder if this message will still be here two\n * years from now...\n */\nexport default function verifyComponentAttributeEquivalence(\n nativeViewConfig: ViewConfig,\n staticViewConfig: ViewConfig,\n) {\n for (const prop of [\n 'validAttributes',\n 'bubblingEventTypes',\n 'directEventTypes',\n ]) {\n const diff = Object.keys(\n lefthandObjectDiff(nativeViewConfig[prop], staticViewConfig[prop]),\n );\n\n if (diff.length > 0) {\n const name =\n staticViewConfig.uiViewClassName ?? nativeViewConfig.uiViewClassName;\n console.error(\n `'${name}' has a view config that does not match native. ` +\n `'${prop}' is missing: ${diff.join(', ')}`,\n );\n }\n }\n}\n\n// Return the different key-value pairs of the right object, by iterating through the keys in the left object\n// Note it won't return a difference where a key is missing in the left but exists the right.\nfunction lefthandObjectDiff(leftObj: Object, rightObj: Object): Object {\n const differentKeys: {[string]: any | {...}} = {};\n\n function compare(leftItem: any, rightItem: any, key: string) {\n if (typeof leftItem !== typeof rightItem && leftItem != null) {\n differentKeys[key] = rightItem;\n return;\n }\n\n if (typeof leftItem === 'object') {\n const objDiff = lefthandObjectDiff(leftItem, rightItem);\n if (Object.keys(objDiff).length > 1) {\n differentKeys[key] = objDiff;\n }\n return;\n }\n\n if (leftItem !== rightItem) {\n differentKeys[key] = rightItem;\n return;\n }\n }\n\n for (const key in leftObj) {\n if (IGNORED_KEYS.includes(key)) {\n continue;\n }\n\n if (!rightObj) {\n differentKeys[key] = {};\n } else if (leftObj.hasOwnProperty(key)) {\n compare(leftObj[key], rightObj[key], key);\n }\n }\n\n return differentKeys;\n}\n\nexport function getConfigWithoutViewProps(\n viewConfig: ViewConfig,\n propName: string,\n): {...} {\n if (!viewConfig[propName]) {\n return {};\n }\n\n return Object.keys(viewConfig[propName])\n .filter(prop => !PlatformBaseViewConfig[propName][prop])\n .reduce<{[string]: any}>((obj, prop) => {\n obj[prop] = viewConfig[propName][prop];\n return obj;\n }, {});\n}\n\nexport function stringifyViewConfig(viewConfig: any): string {\n return JSON.stringify(\n viewConfig,\n (key, val) => {\n if (typeof val === 'function') {\n return `ƒ ${val.name}`;\n }\n return val;\n },\n 2,\n );\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 * @format\n * @flow strict-local\n */\n\nimport type {PartialViewConfig} from '../Renderer/shims/ReactNativeTypes';\n\nimport BaseViewConfig from './BaseViewConfig';\n\nexport type PartialViewConfigWithoutName = $Rest<\n PartialViewConfig,\n {uiViewClassName: string},\n>;\n\nconst PlatformBaseViewConfig: PartialViewConfigWithoutName = BaseViewConfig;\n\n// In Wilde/FB4A, use RNHostComponentListRoute in Bridge mode to verify\n// whether the JS props defined here match the native props defined\n// in RCTViewManagers in iOS, and ViewManagers in Android.\nexport default PlatformBaseViewConfig;\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 * @format\n * @flow strict-local\n */\n\nimport type {PartialViewConfigWithoutName} from './PlatformBaseViewConfig';\n\nimport ReactNativeStyleAttributes from '../Components/View/ReactNativeStyleAttributes';\nimport {\n ConditionallyIgnoredEventHandlers,\n DynamicallyInjectedByGestureHandler,\n} from './ViewConfigIgnore';\n\nconst bubblingEventTypes = {\n // Generic Events\n topPress: {\n phasedRegistrationNames: {\n bubbled: 'onPress',\n captured: 'onPressCapture',\n },\n },\n topChange: {\n phasedRegistrationNames: {\n bubbled: 'onChange',\n captured: 'onChangeCapture',\n },\n },\n topFocus: {\n phasedRegistrationNames: {\n bubbled: 'onFocus',\n captured: 'onFocusCapture',\n },\n },\n topBlur: {\n phasedRegistrationNames: {\n bubbled: 'onBlur',\n captured: 'onBlurCapture',\n },\n },\n topSubmitEditing: {\n phasedRegistrationNames: {\n bubbled: 'onSubmitEditing',\n captured: 'onSubmitEditingCapture',\n },\n },\n topEndEditing: {\n phasedRegistrationNames: {\n bubbled: 'onEndEditing',\n captured: 'onEndEditingCapture',\n },\n },\n topKeyPress: {\n phasedRegistrationNames: {\n bubbled: 'onKeyPress',\n captured: 'onKeyPressCapture',\n },\n },\n\n // Touch Events\n topTouchStart: {\n phasedRegistrationNames: {\n bubbled: 'onTouchStart',\n captured: 'onTouchStartCapture',\n },\n },\n topTouchMove: {\n phasedRegistrationNames: {\n bubbled: 'onTouchMove',\n captured: 'onTouchMoveCapture',\n },\n },\n topTouchCancel: {\n phasedRegistrationNames: {\n bubbled: 'onTouchCancel',\n captured: 'onTouchCancelCapture',\n },\n },\n topTouchEnd: {\n phasedRegistrationNames: {\n bubbled: 'onTouchEnd',\n captured: 'onTouchEndCapture',\n },\n },\n\n // Experimental/Work in Progress Pointer Events (not yet ready for use)\n topPointerCancel: {\n phasedRegistrationNames: {\n captured: 'onPointerCancelCapture',\n bubbled: 'onPointerCancel',\n },\n },\n topPointerDown: {\n phasedRegistrationNames: {\n captured: 'onPointerDownCapture',\n bubbled: 'onPointerDown',\n },\n },\n topPointerMove: {\n phasedRegistrationNames: {\n captured: 'onPointerMoveCapture',\n bubbled: 'onPointerMove',\n },\n },\n topPointerUp: {\n phasedRegistrationNames: {\n captured: 'onPointerUpCapture',\n bubbled: 'onPointerUp',\n },\n },\n topPointerEnter: {\n phasedRegistrationNames: {\n captured: 'onPointerEnterCapture',\n bubbled: 'onPointerEnter',\n skipBubbling: true,\n },\n },\n topPointerLeave: {\n phasedRegistrationNames: {\n captured: 'onPointerLeaveCapture',\n bubbled: 'onPointerLeave',\n skipBubbling: true,\n },\n },\n topPointerOver: {\n phasedRegistrationNames: {\n captured: 'onPointerOverCapture',\n bubbled: 'onPointerOver',\n },\n },\n topPointerOut: {\n phasedRegistrationNames: {\n captured: 'onPointerOutCapture',\n bubbled: 'onPointerOut',\n },\n },\n};\n\nconst directEventTypes = {\n topAccessibilityAction: {\n registrationName: 'onAccessibilityAction',\n },\n topAccessibilityTap: {\n registrationName: 'onAccessibilityTap',\n },\n topMagicTap: {\n registrationName: 'onMagicTap',\n },\n topAccessibilityEscape: {\n registrationName: 'onAccessibilityEscape',\n },\n topLayout: {\n registrationName: 'onLayout',\n },\n onGestureHandlerEvent: DynamicallyInjectedByGestureHandler({\n registrationName: 'onGestureHandlerEvent',\n }),\n onGestureHandlerStateChange: DynamicallyInjectedByGestureHandler({\n registrationName: 'onGestureHandlerStateChange',\n }),\n};\n\nconst validAttributesForNonEventProps = {\n // View Props\n accessible: true,\n accessibilityActions: true,\n accessibilityLabel: true,\n accessibilityHint: true,\n accessibilityLanguage: true,\n accessibilityValue: true,\n accessibilityViewIsModal: true,\n accessibilityElementsHidden: true,\n accessibilityIgnoresInvertColors: true,\n testID: true,\n backgroundColor: {process: require('../StyleSheet/processColor')},\n backfaceVisibility: true,\n opacity: true,\n shadowColor: {process: require('../StyleSheet/processColor')},\n shadowOffset: {diff: require('../Utilities/differ/sizesDiffer')},\n shadowOpacity: true,\n shadowRadius: true,\n needsOffscreenAlphaCompositing: true,\n overflow: true,\n shouldRasterizeIOS: true,\n transform: {diff: require('../Utilities/differ/matricesDiffer')},\n accessibilityRole: true,\n accessibilityState: true,\n nativeID: true,\n pointerEvents: true,\n removeClippedSubviews: true,\n borderRadius: true,\n borderColor: {process: require('../StyleSheet/processColor')},\n borderCurve: true,\n borderWidth: true,\n borderStyle: true,\n hitSlop: {diff: require('../Utilities/differ/insetsDiffer')},\n collapsable: true,\n\n borderTopWidth: true,\n borderTopColor: {process: require('../StyleSheet/processColor')},\n borderRightWidth: true,\n borderRightColor: {process: require('../StyleSheet/processColor')},\n borderBottomWidth: true,\n borderBottomColor: {process: require('../StyleSheet/processColor')},\n borderLeftWidth: true,\n borderLeftColor: {process: require('../StyleSheet/processColor')},\n borderStartWidth: true,\n borderStartColor: {process: require('../StyleSheet/processColor')},\n borderEndWidth: true,\n borderEndColor: {process: require('../StyleSheet/processColor')},\n\n borderTopLeftRadius: true,\n borderTopRightRadius: true,\n borderTopStartRadius: true,\n borderTopEndRadius: true,\n borderBottomLeftRadius: true,\n borderBottomRightRadius: true,\n borderBottomStartRadius: true,\n borderBottomEndRadius: true,\n display: true,\n zIndex: true,\n\n // ShadowView properties\n top: true,\n right: true,\n start: true,\n end: true,\n bottom: true,\n left: true,\n\n width: true,\n height: true,\n\n minWidth: true,\n maxWidth: true,\n minHeight: true,\n maxHeight: true,\n\n // Also declared as ViewProps\n // borderTopWidth: true,\n // borderRightWidth: true,\n // borderBottomWidth: true,\n // borderLeftWidth: true,\n // borderStartWidth: true,\n // borderEndWidth: true,\n // borderWidth: true,\n\n marginTop: true,\n marginRight: true,\n marginBottom: true,\n marginLeft: true,\n marginStart: true,\n marginEnd: true,\n marginVertical: true,\n marginHorizontal: true,\n margin: true,\n\n paddingTop: true,\n paddingRight: true,\n paddingBottom: true,\n paddingLeft: true,\n paddingStart: true,\n paddingEnd: true,\n paddingVertical: true,\n paddingHorizontal: true,\n padding: true,\n\n flex: true,\n flexGrow: true,\n rowGap: true,\n columnGap: true,\n gap: true,\n flexShrink: true,\n flexBasis: true,\n flexDirection: true,\n flexWrap: true,\n justifyContent: true,\n alignItems: true,\n alignSelf: true,\n alignContent: true,\n position: true,\n aspectRatio: true,\n\n // Also declared as ViewProps\n // overflow: true,\n // display: true,\n\n direction: true,\n\n style: ReactNativeStyleAttributes,\n};\n\n// Props for bubbling and direct events\nconst validAttributesForEventProps = ConditionallyIgnoredEventHandlers({\n onLayout: true,\n onMagicTap: true,\n\n // Accessibility\n onAccessibilityAction: true,\n onAccessibilityEscape: true,\n onAccessibilityTap: true,\n\n // PanResponder handlers\n onMoveShouldSetResponder: true,\n onMoveShouldSetResponderCapture: true,\n onStartShouldSetResponder: true,\n onStartShouldSetResponderCapture: true,\n onResponderGrant: true,\n onResponderReject: true,\n onResponderStart: true,\n onResponderEnd: true,\n onResponderRelease: true,\n onResponderMove: true,\n onResponderTerminate: true,\n onResponderTerminationRequest: true,\n onShouldBlockNativeResponder: true,\n\n // Touch events\n onTouchStart: true,\n onTouchMove: true,\n onTouchEnd: true,\n onTouchCancel: true,\n\n // Pointer events\n onPointerUp: true,\n onPointerDown: true,\n onPointerCancel: true,\n onPointerEnter: true,\n onPointerMove: true,\n onPointerLeave: true,\n onPointerOver: true,\n onPointerOut: true,\n});\n\n/**\n * On iOS, view managers define all of a component's props.\n * All view managers extend RCTViewManager, and RCTViewManager declares these props.\n */\nconst PlatformBaseViewConfigIos: PartialViewConfigWithoutName = {\n bubblingEventTypes,\n directEventTypes,\n validAttributes: {\n ...validAttributesForNonEventProps,\n ...validAttributesForEventProps,\n },\n};\n\nexport default PlatformBaseViewConfigIos;\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 * @flow strict\n * @format\n */\n\nimport Platform from '../Utilities/Platform';\n\nconst ignoredViewConfigProps = new WeakSet<{...}>();\n\n/**\n * Decorates ViewConfig values that are dynamically injected by the library,\n * react-native-gesture-handler. (T45765076)\n */\nexport function DynamicallyInjectedByGestureHandler(object: T): T {\n ignoredViewConfigProps.add(object);\n return object;\n}\n\n/**\n * On iOS, ViewManager event declarations generate {eventName}: true entries\n * in ViewConfig valueAttributes. These entries aren't generated for Android.\n * This annotation allows Static ViewConfigs to insert these entries into\n * iOS but not Android.\n *\n * In the future, we want to remove this platform-inconsistency. We want\n * to set RN$ViewConfigEventValidAttributesDisabled = true server-side,\n * so that iOS does not generate validAttributes from event props in iOS RCTViewManager,\n * since Android does not generate validAttributes from events props in Android ViewManager.\n *\n * TODO(T110872225): Remove this logic, after achieving platform-consistency\n */\nexport function ConditionallyIgnoredEventHandlers(\n value: T,\n): T | void {\n if (\n Platform.OS === 'ios' &&\n !(global.RN$ViewConfigEventValidAttributesDisabled === true)\n ) {\n return value;\n }\n return undefined;\n}\n\nexport function isIgnored(value: mixed): boolean {\n if (typeof value === 'object' && value != null) {\n return ignoredViewConfigProps.has(value);\n }\n return false;\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 * @flow strict\n * @format\n */\n\nimport {type ViewConfig} from '../Renderer/shims/ReactNativeTypes';\nimport {isIgnored} from './ViewConfigIgnore';\n\nexport type Difference =\n | {\n type: 'missing',\n path: Array,\n nativeValue: mixed,\n }\n | {\n type: 'unequal',\n path: Array,\n nativeValue: mixed,\n staticValue: mixed,\n }\n | {\n type: 'unexpected',\n path: Array,\n staticValue: mixed,\n };\n\nexport type ValidationResult = ValidResult | InvalidResult;\ntype ValidResult = {\n type: 'valid',\n};\ntype InvalidResult = {\n type: 'invalid',\n differences: Array,\n};\n\n/**\n * During the migration from native view configs to static view configs, this is\n * used to validate that the two are equivalent.\n */\nexport function validate(\n name: string,\n nativeViewConfig: ViewConfig,\n staticViewConfig: ViewConfig,\n): ValidationResult {\n const differences: Array = [];\n accumulateDifferences(\n differences,\n [],\n {\n bubblingEventTypes: nativeViewConfig.bubblingEventTypes,\n directEventTypes: nativeViewConfig.directEventTypes,\n uiViewClassName: nativeViewConfig.uiViewClassName,\n validAttributes: nativeViewConfig.validAttributes,\n },\n {\n bubblingEventTypes: staticViewConfig.bubblingEventTypes,\n directEventTypes: staticViewConfig.directEventTypes,\n uiViewClassName: staticViewConfig.uiViewClassName,\n validAttributes: staticViewConfig.validAttributes,\n },\n );\n\n if (differences.length === 0) {\n return {type: 'valid'};\n }\n\n return {\n type: 'invalid',\n differences,\n };\n}\n\nexport function stringifyValidationResult(\n name: string,\n validationResult: InvalidResult,\n): string {\n const {differences} = validationResult;\n return [\n `StaticViewConfigValidator: Invalid static view config for '${name}'.`,\n '',\n ...differences.map(difference => {\n const {type, path} = difference;\n switch (type) {\n case 'missing':\n return `- '${path.join('.')}' is missing.`;\n case 'unequal':\n return `- '${path.join('.')}' is the wrong value.`;\n case 'unexpected':\n return `- '${path.join('.')}' is present but not expected to be.`;\n }\n }),\n '',\n ].join('\\n');\n}\n\nfunction accumulateDifferences(\n differences: Array,\n path: Array,\n nativeObject: {...},\n staticObject: {...},\n): void {\n for (const nativeKey in nativeObject) {\n const nativeValue = nativeObject[nativeKey];\n\n if (!staticObject.hasOwnProperty(nativeKey)) {\n differences.push({\n path: [...path, nativeKey],\n type: 'missing',\n nativeValue,\n });\n continue;\n }\n\n const staticValue = staticObject[nativeKey];\n\n const nativeValueIfObject = ifObject(nativeValue);\n if (nativeValueIfObject != null) {\n const staticValueIfObject = ifObject(staticValue);\n if (staticValueIfObject != null) {\n path.push(nativeKey);\n accumulateDifferences(\n differences,\n path,\n nativeValueIfObject,\n staticValueIfObject,\n );\n path.pop();\n continue;\n }\n }\n\n if (nativeValue !== staticValue) {\n differences.push({\n path: [...path, nativeKey],\n type: 'unequal',\n nativeValue,\n staticValue,\n });\n }\n }\n\n for (const staticKey in staticObject) {\n if (\n !nativeObject.hasOwnProperty(staticKey) &&\n !isIgnored(staticObject[staticKey])\n ) {\n differences.push({\n path: [...path, staticKey],\n type: 'unexpected',\n staticValue: staticObject[staticKey],\n });\n }\n }\n}\n\nfunction ifObject(value: mixed): ?{...} {\n return typeof value === 'object' && !Array.isArray(value) ? value : null;\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 * @flow strict-local\n * @format\n */\n\nimport type {\n PartialViewConfig,\n ViewConfig,\n} from '../Renderer/shims/ReactNativeTypes';\n\nimport PlatformBaseViewConfig from './PlatformBaseViewConfig';\n\n/**\n * Creates a complete `ViewConfig` from a `PartialViewConfig`.\n */\nexport function createViewConfig(\n partialViewConfig: PartialViewConfig,\n): ViewConfig {\n return {\n uiViewClassName: partialViewConfig.uiViewClassName,\n Commands: {},\n bubblingEventTypes: composeIndexers(\n PlatformBaseViewConfig.bubblingEventTypes,\n partialViewConfig.bubblingEventTypes,\n ),\n directEventTypes: composeIndexers(\n PlatformBaseViewConfig.directEventTypes,\n partialViewConfig.directEventTypes,\n ),\n validAttributes: composeIndexers(\n // $FlowFixMe[incompatible-call] `style` property confuses Flow.\n PlatformBaseViewConfig.validAttributes,\n // $FlowFixMe[incompatible-call] `style` property confuses Flow.\n partialViewConfig.validAttributes,\n ),\n };\n}\n\nfunction composeIndexers(\n maybeA: ?{+[string]: T},\n maybeB: ?{+[string]: T},\n): {+[string]: T} {\n return maybeA == null || maybeB == null\n ? maybeA ?? maybeB ?? {}\n : {...maybeA, ...maybeB};\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 * @format\n * @flow\n */\n\nconst {dispatchCommand} = require('../ReactNative/RendererProxy');\n\ntype Options = $ReadOnly<{|\n supportedCommands: $ReadOnlyArray,\n|}>;\n\nfunction codegenNativeCommands(options: Options<$Keys>): T {\n const commandObj: {[$Keys]: (...$ReadOnlyArray) => void} = {};\n\n options.supportedCommands.forEach(command => {\n commandObj[command] = (ref, ...args) => {\n dispatchCommand(ref, command, args);\n };\n });\n\n return ((commandObj: any): T);\n}\n\nexport default codegenNativeCommands;\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react-jsx-runtime.production.min.js');\n} else {\n module.exports = require('./cjs/react-jsx-runtime.development.js');\n}\n","/**\n * @license React\n * react-jsx-runtime.production.min.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'use strict';var f=require(\"react\"),k=Symbol.for(\"react.element\"),l=Symbol.for(\"react.fragment\"),m=Object.prototype.hasOwnProperty,n=f.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,p={key:!0,ref:!0,__self:!0,__source:!0};\nfunction q(c,a,g){var b,d={},e=null,h=null;void 0!==g&&(e=\"\"+g);void 0!==a.key&&(e=\"\"+a.key);void 0!==a.ref&&(h=a.ref);for(b in a)m.call(a,b)&&!p.hasOwnProperty(b)&&(d[b]=a[b]);if(c&&c.defaultProps)for(b in a=c.defaultProps,a)void 0===d[b]&&(d[b]=a[b]);return{$$typeof:k,type:c,key:e,ref:h,props:d,_owner:n.current}}exports.Fragment=l;exports.jsx=q;exports.jsxs=q;\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 * @flow strict-local\n * @format\n */\n\n'use strict';\n\nimport type {\n AccessibilityRole,\n Role,\n} from '../Components/View/ViewAccessibility';\n\n// Map role values to AccessibilityRole values\nexport function getAccessibilityRoleFromRole(role: Role): ?AccessibilityRole {\n switch (role) {\n case 'alert':\n return 'alert';\n case 'alertdialog':\n return undefined;\n case 'application':\n return undefined;\n case 'article':\n return undefined;\n case 'banner':\n return undefined;\n case 'button':\n return 'button';\n case 'cell':\n return undefined;\n case 'checkbox':\n return 'checkbox';\n case 'columnheader':\n return undefined;\n case 'combobox':\n return 'combobox';\n case 'complementary':\n return undefined;\n case 'contentinfo':\n return undefined;\n case 'definition':\n return undefined;\n case 'dialog':\n return undefined;\n case 'directory':\n return undefined;\n case 'document':\n return undefined;\n case 'feed':\n return undefined;\n case 'figure':\n return undefined;\n case 'form':\n return undefined;\n case 'grid':\n return 'grid';\n case 'group':\n return undefined;\n case 'heading':\n return 'header';\n case 'img':\n return 'image';\n case 'link':\n return 'link';\n case 'list':\n return 'list';\n case 'listitem':\n return undefined;\n case 'log':\n return undefined;\n case 'main':\n return undefined;\n case 'marquee':\n return undefined;\n case 'math':\n return undefined;\n case 'menu':\n return 'menu';\n case 'menubar':\n return 'menubar';\n case 'menuitem':\n return 'menuitem';\n case 'meter':\n return undefined;\n case 'navigation':\n return undefined;\n case 'none':\n return 'none';\n case 'note':\n return undefined;\n case 'option':\n return undefined;\n case 'presentation':\n return 'none';\n case 'progressbar':\n return 'progressbar';\n case 'radio':\n return 'radio';\n case 'radiogroup':\n return 'radiogroup';\n case 'region':\n return undefined;\n case 'row':\n return undefined;\n case 'rowgroup':\n return undefined;\n case 'rowheader':\n return undefined;\n case 'scrollbar':\n return 'scrollbar';\n case 'searchbox':\n return 'search';\n case 'separator':\n return undefined;\n case 'slider':\n return 'adjustable';\n case 'spinbutton':\n return 'spinbutton';\n case 'status':\n return undefined;\n case 'summary':\n return 'summary';\n case 'switch':\n return 'switch';\n case 'tab':\n return 'tab';\n case 'table':\n return undefined;\n case 'tablist':\n return 'tablist';\n case 'tabpanel':\n return undefined;\n case 'term':\n return undefined;\n case 'timer':\n return 'timer';\n case 'toolbar':\n return 'toolbar';\n case 'tooltip':\n return undefined;\n case 'tree':\n return undefined;\n case 'treegrid':\n return undefined;\n case 'treeitem':\n return undefined;\n }\n\n return undefined;\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport type {\n ____ColorValue_Internal,\n ____DangerouslyImpreciseStyle_Internal,\n ____DangerouslyImpreciseStyleProp_Internal,\n ____ImageStyle_Internal,\n ____ImageStyleProp_Internal,\n ____Styles_Internal,\n ____TextStyle_Internal,\n ____TextStyleProp_Internal,\n ____ViewStyle_Internal,\n ____ViewStyleProp_Internal,\n} from './StyleSheetTypes';\n\nconst ReactNativeStyleAttributes = require('../Components/View/ReactNativeStyleAttributes');\nconst PixelRatio = require('../Utilities/PixelRatio');\nconst flatten = require('./flattenStyle');\n\n/**\n * This type should be used as the type for anything that is a color. It is\n * most useful when using DynamicColorIOS which can be a string or a dynamic\n * color object.\n *\n * type props = {backgroundColor: ColorValue};\n */\nexport type ColorValue = ____ColorValue_Internal;\n\n/**\n * This type should be used as the type for a prop that is passed through\n * to a 's `style` prop. This ensures call sites of the component\n * can't pass styles that View doesn't support such as `fontSize`.`\n *\n * type Props = {style: ViewStyleProp}\n * const MyComponent = (props: Props) => \n */\nexport type ViewStyleProp = ____ViewStyleProp_Internal;\n\n/**\n * This type should be used as the type for a prop that is passed through\n * to a 's `style` prop. This ensures call sites of the component\n * can't pass styles that Text doesn't support such as `resizeMode`.`\n *\n * type Props = {style: TextStyleProp}\n * const MyComponent = (props: Props) => \n */\nexport type TextStyleProp = ____TextStyleProp_Internal;\n\n/**\n * This type should be used as the type for a prop that is passed through\n * to an 's `style` prop. This ensures call sites of the component\n * can't pass styles that Image doesn't support such as `fontSize`.`\n *\n * type Props = {style: ImageStyleProp}\n * const MyComponent = (props: Props) => \n */\nexport type ImageStyleProp = ____ImageStyleProp_Internal;\n\n/**\n * WARNING: You probably shouldn't be using this type. This type\n * is similar to the ones above except it allows styles that are accepted\n * by all of View, Text, or Image. It is therefore very unsafe to pass this\n * through to an underlying component. Using this is almost always a mistake\n * and using one of the other more restrictive types is likely the right choice.\n */\nexport type DangerouslyImpreciseStyleProp =\n ____DangerouslyImpreciseStyleProp_Internal;\n\n/**\n * Utility type for getting the values for specific style keys.\n *\n * The following is bad because position is more restrictive than 'string':\n * ```\n * type Props = {position: string};\n * ```\n *\n * You should use the following instead:\n *\n * ```\n * type Props = {position: TypeForStyleKey<'position'>};\n * ```\n *\n * This will correctly give you the type 'absolute' | 'relative'\n */\nexport type TypeForStyleKey<\n +key: $Keys<____DangerouslyImpreciseStyle_Internal>,\n> = $ElementType<____DangerouslyImpreciseStyle_Internal, key>;\n\n/**\n * This type is an object of the different possible style\n * properties that can be specified for View.\n *\n * Note that this isn't a safe way to type a style prop for a component as\n * results from StyleSheet.create return an internal identifier, not\n * an object of styles.\n *\n * If you want to type the style prop of a function,\n * consider using ViewStyleProp.\n *\n * A reasonable usage of this type is for helper functions that return an\n * object of styles to pass to a View that can't be precomputed with\n * StyleSheet.create.\n */\nexport type ViewStyle = ____ViewStyle_Internal;\n\n/**\n * This type is an object of the different possible style\n * properties that can be specified for Text.\n *\n * Note that this isn't a safe way to type a style prop for a component as\n * results from StyleSheet.create return an internal identifier, not\n * an object of styles.\n *\n * If you want to type the style prop of a function,\n * consider using TextStyleProp.\n *\n * A reasonable usage of this type is for helper functions that return an\n * object of styles to pass to a Text that can't be precomputed with\n * StyleSheet.create.\n */\nexport type TextStyle = ____TextStyle_Internal;\n\n/**\n * This type is an object of the different possible style\n * properties that can be specified for Image.\n *\n * Note that this isn't a safe way to type a style prop for a component as\n * results from StyleSheet.create return an internal identifier, not\n * an object of styles.\n *\n * If you want to type the style prop of a function,\n * consider using ImageStyleProp.\n *\n * A reasonable usage of this type is for helper functions that return an\n * object of styles to pass to an Image that can't be precomputed with\n * StyleSheet.create.\n */\nexport type ImageStyle = ____ImageStyle_Internal;\n\n/**\n * WARNING: You probably shouldn't be using this type. This type is an object\n * with all possible style keys and their values. Note that this isn't\n * a safe way to type a style prop for a component as results from\n * StyleSheet.create return an internal identifier, not an object of styles.\n *\n * If you want to type the style prop of a function, consider using\n * ViewStyleProp, TextStyleProp, or ImageStyleProp.\n *\n * This should only be used by very core utilities that operate on an object\n * containing any possible style value.\n */\nexport type DangerouslyImpreciseStyle = ____DangerouslyImpreciseStyle_Internal;\n\nlet hairlineWidth: number = PixelRatio.roundToNearestPixel(0.4);\nif (hairlineWidth === 0) {\n hairlineWidth = 1 / PixelRatio.get();\n}\n\nconst absoluteFill = {\n position: 'absolute',\n left: 0,\n right: 0,\n top: 0,\n bottom: 0,\n};\nif (__DEV__) {\n Object.freeze(absoluteFill);\n}\n\n/**\n * A StyleSheet is an abstraction similar to CSS StyleSheets\n *\n * Create a new StyleSheet:\n *\n * ```\n * const styles = StyleSheet.create({\n * container: {\n * borderRadius: 4,\n * borderWidth: 0.5,\n * borderColor: '#d6d7da',\n * },\n * title: {\n * fontSize: 19,\n * fontWeight: 'bold',\n * },\n * activeTitle: {\n * color: 'red',\n * },\n * });\n * ```\n *\n * Use a StyleSheet:\n *\n * ```\n * \n * \n * \n * ```\n *\n * Code quality:\n *\n * - By moving styles away from the render function, you're making the code\n * easier to understand.\n * - Naming the styles is a good way to add meaning to the low level components\n * in the render function.\n *\n * Performance:\n *\n * - Making a stylesheet from a style object makes it possible to refer to it\n * by ID instead of creating a new style object every time.\n * - It also allows to send the style only once through the bridge. All\n * subsequent uses are going to refer an id (not implemented yet).\n */\nmodule.exports = {\n /**\n * This is defined as the width of a thin line on the platform. It can be\n * used as the thickness of a border or division between two elements.\n * Example:\n * ```\n * {\n * borderBottomColor: '#bbb',\n * borderBottomWidth: StyleSheet.hairlineWidth\n * }\n * ```\n *\n * This constant will always be a round number of pixels (so a line defined\n * by it look crisp) and will try to match the standard width of a thin line\n * on the underlying platform. However, you should not rely on it being a\n * constant size, because on different platforms and screen densities its\n * value may be calculated differently.\n *\n * A line with hairline width may not be visible if your simulator is downscaled.\n */\n hairlineWidth,\n\n /**\n * A very common pattern is to create overlays with position absolute and zero positioning,\n * so `absoluteFill` can be used for convenience and to reduce duplication of these repeated\n * styles.\n */\n absoluteFill: (absoluteFill: any), // TODO: This should be updated after we fix downstream Flow sites.\n\n /**\n * Sometimes you may want `absoluteFill` but with a couple tweaks - `absoluteFillObject` can be\n * used to create a customized entry in a `StyleSheet`, e.g.:\n *\n * const styles = StyleSheet.create({\n * wrapper: {\n * ...StyleSheet.absoluteFillObject,\n * top: 10,\n * backgroundColor: 'transparent',\n * },\n * });\n */\n absoluteFillObject: absoluteFill,\n\n /**\n * Combines two styles such that `style2` will override any styles in `style1`.\n * If either style is falsy, the other one is returned without allocating an\n * array, saving allocations and maintaining reference equality for\n * PureComponent checks.\n */\n compose(\n style1: ?T,\n style2: ?T,\n ): ?T | $ReadOnlyArray {\n if (style1 != null && style2 != null) {\n return ([style1, style2]: $ReadOnlyArray);\n } else {\n return style1 != null ? style1 : style2;\n }\n },\n\n /**\n * Flattens an array of style objects, into one aggregated style object.\n * Alternatively, this method can be used to lookup IDs, returned by\n * StyleSheet.register.\n *\n * > **NOTE**: Exercise caution as abusing this can tax you in terms of\n * > optimizations.\n * >\n * > IDs enable optimizations through the bridge and memory in general. Referring\n * > to style objects directly will deprive you of these optimizations.\n *\n * Example:\n * ```\n * const styles = StyleSheet.create({\n * listItem: {\n * flex: 1,\n * fontSize: 16,\n * color: 'white'\n * },\n * selectedListItem: {\n * color: 'green'\n * }\n * });\n *\n * StyleSheet.flatten([styles.listItem, styles.selectedListItem])\n * // returns { flex: 1, fontSize: 16, color: 'green' }\n * ```\n * Alternative use:\n * ```\n * StyleSheet.flatten(styles.listItem);\n * // return { flex: 1, fontSize: 16, color: 'white' }\n * // Simply styles.listItem would return its ID (number)\n * ```\n * This method internally uses `StyleSheetRegistry.getStyleByID(style)`\n * to resolve style objects represented by IDs. Thus, an array of style\n * objects (instances of StyleSheet.create), are individually resolved to,\n * their respective objects, merged as one and then returned. This also explains\n * the alternative use.\n */\n flatten,\n\n /**\n * WARNING: EXPERIMENTAL. Breaking changes will probably happen a lot and will\n * not be reliably announced. The whole thing might be deleted, who knows? Use\n * at your own risk.\n *\n * Sets a function to use to pre-process a style property value. This is used\n * internally to process color and transform values. You should not use this\n * unless you really know what you are doing and have exhausted other options.\n */\n setStyleAttributePreprocessor(\n property: string,\n process: (nextProp: mixed) => mixed,\n ) {\n let value;\n\n if (ReactNativeStyleAttributes[property] === true) {\n value = {process};\n } else if (typeof ReactNativeStyleAttributes[property] === 'object') {\n value = {...ReactNativeStyleAttributes[property], process};\n } else {\n console.error(`${property} is not a valid style attribute`);\n return;\n }\n\n if (\n __DEV__ &&\n typeof value.process === 'function' &&\n typeof ReactNativeStyleAttributes[property]?.process === 'function' &&\n value.process !== ReactNativeStyleAttributes[property]?.process\n ) {\n console.warn(`Overwriting ${property} style attribute preprocessor`);\n }\n\n ReactNativeStyleAttributes[property] = value;\n },\n\n /**\n * Creates a StyleSheet style reference from the given object.\n */\n create<+S: ____Styles_Internal>(obj: S): $ReadOnly {\n // TODO: This should return S as the return type. But first,\n // we need to codemod all the callsites that are typing this\n // return value as a number (even though it was opaque).\n if (__DEV__) {\n for (const key in obj) {\n if (obj[key]) {\n Object.freeze(obj[key]);\n }\n }\n }\n return obj;\n },\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 * @flow strict\n * @format\n */\n\nimport * as React from 'react';\n\nexport opaque type RootTag = number;\n\nexport const RootTagContext: React$Context =\n React.createContext(0);\n\nif (__DEV__) {\n RootTagContext.displayName = 'RootTagContext';\n}\n\n/**\n * Intended to only be used by `AppContainer`.\n */\nexport function createRootTag(rootTag: number | RootTag): RootTag {\n return rootTag;\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 * @flow strict-local\n * @format\n */\n\nexport opaque type DisplayModeType = number;\n\n/** DisplayMode should be in sync with the method displayModeToInt from\n * react/renderer/uimanager/primitives.h. */\nconst DisplayMode: {[string]: DisplayModeType} = Object.freeze({\n VISIBLE: 1,\n SUSPENDED: 2,\n HIDDEN: 3,\n});\n\nexport function coerceDisplayMode(value: ?number): DisplayModeType {\n switch (value) {\n case DisplayMode.SUSPENDED:\n return DisplayMode.SUSPENDED;\n case DisplayMode.HIDDEN:\n return DisplayMode.HIDDEN;\n default:\n return DisplayMode.VISIBLE;\n }\n}\n\nexport default DisplayMode;\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 * @flow strict\n * @format\n */\n\nimport type {AbstractComponent, Node} from 'react';\n\ntype NoopComponent = AbstractComponent<{children: Node}>;\n\nconst cache: Map<\n string, // displayName\n NoopComponent, // ComponentWithDisplayName\n> = new Map();\n\nexport default function getCachedComponentWithDisplayName(\n displayName: string,\n): NoopComponent {\n let ComponentWithDisplayName = cache.get(displayName);\n\n if (!ComponentWithDisplayName) {\n ComponentWithDisplayName = ({\n children,\n }: $TEMPORARY$object<{children: Node}>) => children;\n // $FlowFixMe[prop-missing]\n ComponentWithDisplayName.displayName = displayName;\n cache.set(displayName, ComponentWithDisplayName);\n }\n\n return ComponentWithDisplayName;\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 * @format\n * @flow\n */\n\n'use strict';\n\nmodule.exports = require('../Components/UnimplementedViews/UnimplementedView');\n\ntype BackPressEventName = 'backPress' | 'hardwareBackPress';\n\nfunction emptyFunction(): void {}\n\ntype TBackHandler = {|\n +exitApp: () => void,\n +addEventListener: (\n eventName: BackPressEventName,\n handler: () => ?boolean,\n ) => {remove: () => void, ...},\n +removeEventListener: (\n eventName: BackPressEventName,\n handler: () => ?boolean,\n ) => void,\n|};\n\nlet BackHandler: TBackHandler = {\n exitApp: emptyFunction,\n addEventListener(_eventName: BackPressEventName, _handler: Function) {\n return {\n remove: emptyFunction,\n };\n },\n removeEventListener(_eventName: BackPressEventName, _handler: Function) {},\n};\n\nmodule.exports = BackHandler;\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 * @flow strict-local\n * @format\n */\n\n'use strict';\nimport StyleSheet from '../../StyleSheet/StyleSheet';\nimport * as React from 'react';\n\n/**\n * Common implementation for a simple stubbed view. Simply applies the view's styles to the inner\n * View component and renders its children.\n */\nclass UnimplementedView extends React.Component<$FlowFixMeProps> {\n render(): React.Node {\n // Workaround require cycle from requireNativeComponent\n const View = require('../View/View');\n return (\n \n {this.props.children}\n \n );\n }\n}\n\nconst styles = StyleSheet.create({\n unimplementedView: __DEV__\n ? {\n alignSelf: 'flex-start',\n borderColor: 'red',\n borderWidth: 1,\n }\n : {},\n});\n\nmodule.exports = UnimplementedView;\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 * @format\n * @flow strict-local\n */\n\nimport typeof BatchedBridge from '../BatchedBridge/BatchedBridge';\nimport typeof legacySendAccessibilityEvent from '../Components/AccessibilityInfo/legacySendAccessibilityEvent';\nimport typeof TextInputState from '../Components/TextInput/TextInputState';\nimport typeof ExceptionsManager from '../Core/ExceptionsManager';\nimport typeof RawEventEmitter from '../Core/RawEventEmitter';\nimport typeof ReactFiberErrorDialog from '../Core/ReactFiberErrorDialog';\nimport typeof RCTEventEmitter from '../EventEmitter/RCTEventEmitter';\nimport typeof CustomEvent from '../Events/CustomEvent';\nimport typeof UIManager from '../ReactNative/UIManager';\nimport typeof ReactNativeViewConfigRegistry from '../Renderer/shims/ReactNativeViewConfigRegistry';\nimport typeof flattenStyle from '../StyleSheet/flattenStyle';\nimport typeof deepFreezeAndThrowOnMutationInDev from '../Utilities/deepFreezeAndThrowOnMutationInDev';\nimport typeof deepDiffer from '../Utilities/differ/deepDiffer';\nimport typeof Platform from '../Utilities/Platform';\n\nimport {type DangerouslyImpreciseStyleProp} from '../StyleSheet/StyleSheet';\n\n// flowlint unsafe-getters-setters:off\nmodule.exports = {\n get BatchedBridge(): BatchedBridge {\n return require('../BatchedBridge/BatchedBridge');\n },\n get ExceptionsManager(): ExceptionsManager {\n return require('../Core/ExceptionsManager');\n },\n get Platform(): Platform {\n return require('../Utilities/Platform');\n },\n get RCTEventEmitter(): RCTEventEmitter {\n return require('../EventEmitter/RCTEventEmitter');\n },\n get ReactNativeViewConfigRegistry(): ReactNativeViewConfigRegistry {\n return require('../Renderer/shims/ReactNativeViewConfigRegistry');\n },\n get TextInputState(): TextInputState {\n return require('../Components/TextInput/TextInputState');\n },\n get UIManager(): UIManager {\n return require('../ReactNative/UIManager');\n },\n get deepDiffer(): deepDiffer {\n return require('../Utilities/differ/deepDiffer');\n },\n get deepFreezeAndThrowOnMutationInDev(): deepFreezeAndThrowOnMutationInDev<\n {...} | Array,\n > {\n return require('../Utilities/deepFreezeAndThrowOnMutationInDev');\n },\n get flattenStyle(): flattenStyle {\n return require('../StyleSheet/flattenStyle');\n },\n get ReactFiberErrorDialog(): ReactFiberErrorDialog {\n return require('../Core/ReactFiberErrorDialog').default;\n },\n get legacySendAccessibilityEvent(): legacySendAccessibilityEvent {\n return require('../Components/AccessibilityInfo/legacySendAccessibilityEvent');\n },\n get RawEventEmitter(): RawEventEmitter {\n return require('../Core/RawEventEmitter').default;\n },\n get CustomEvent(): CustomEvent {\n return require('../Events/CustomEvent').default;\n },\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 * @format\n * @flow\n */\n\n'use strict';\n\nconst BatchedBridge = require('../BatchedBridge/BatchedBridge');\n\nconst RCTEventEmitter = {\n register(eventEmitter: any) {\n if (global.RN$Bridgeless) {\n global.RN$registerCallableModule('RCTEventEmitter', () => eventEmitter);\n } else {\n BatchedBridge.registerCallableModule('RCTEventEmitter', eventEmitter);\n }\n },\n};\n\nmodule.exports = RCTEventEmitter;\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 * @format\n * @flow strict-local\n */\n\n// This class is responsible for coordinating the \"focused\" state for\n// TextInputs. All calls relating to the keyboard should be funneled\n// through here.\n\nimport type {\n HostComponent,\n MeasureInWindowOnSuccessCallback,\n MeasureLayoutOnSuccessCallback,\n MeasureOnSuccessCallback,\n} from '../../Renderer/shims/ReactNativeTypes';\n\nimport {Commands as AndroidTextInputCommands} from '../../Components/TextInput/AndroidTextInputNativeComponent';\nimport {Commands as iOSTextInputCommands} from '../../Components/TextInput/RCTSingelineTextInputNativeComponent';\n\nconst {findNodeHandle} = require('../../ReactNative/RendererProxy');\nconst Platform = require('../../Utilities/Platform');\nconst React = require('react');\ntype ComponentRef = React.ElementRef>;\n\nlet currentlyFocusedInputRef: ?ComponentRef = null;\nconst inputs = new Set<{\n blur(): void,\n focus(): void,\n measure(callback: MeasureOnSuccessCallback): void,\n measureInWindow(callback: MeasureInWindowOnSuccessCallback): void,\n measureLayout(\n relativeToNativeNode: number | React.ElementRef>,\n onSuccess: MeasureLayoutOnSuccessCallback,\n onFail?: () => void,\n ): void,\n setNativeProps(nativeProps: {...}): void,\n}>();\n\nfunction currentlyFocusedInput(): ?ComponentRef {\n return currentlyFocusedInputRef;\n}\n\n/**\n * Returns the ID of the currently focused text field, if one exists\n * If no text field is focused it returns null\n */\nfunction currentlyFocusedField(): ?number {\n if (__DEV__) {\n console.error(\n 'currentlyFocusedField is deprecated and will be removed in a future release. Use currentlyFocusedInput',\n );\n }\n\n return findNodeHandle(currentlyFocusedInputRef);\n}\n\nfunction focusInput(textField: ?ComponentRef): void {\n if (currentlyFocusedInputRef !== textField && textField != null) {\n currentlyFocusedInputRef = textField;\n }\n}\n\nfunction blurInput(textField: ?ComponentRef): void {\n if (currentlyFocusedInputRef === textField && textField != null) {\n currentlyFocusedInputRef = null;\n }\n}\n\nfunction focusField(textFieldID: ?number): void {\n if (__DEV__) {\n console.error('focusField no longer works. Use focusInput');\n }\n\n return;\n}\n\nfunction blurField(textFieldID: ?number) {\n if (__DEV__) {\n console.error('blurField no longer works. Use blurInput');\n }\n\n return;\n}\n\n/**\n * @param {number} TextInputID id of the text field to focus\n * Focuses the specified text field\n * noop if the text field was already focused or if the field is not editable\n */\nfunction focusTextInput(textField: ?ComponentRef) {\n if (typeof textField === 'number') {\n if (__DEV__) {\n console.error(\n 'focusTextInput must be called with a host component. Passing a react tag is deprecated.',\n );\n }\n\n return;\n }\n\n if (textField != null) {\n const fieldCanBeFocused =\n currentlyFocusedInputRef !== textField &&\n // $FlowFixMe - `currentProps` is missing in `NativeMethods`\n textField.currentProps?.editable !== false;\n\n if (!fieldCanBeFocused) {\n return;\n }\n focusInput(textField);\n if (Platform.OS === 'ios') {\n // This isn't necessarily a single line text input\n // But commands don't actually care as long as the thing being passed in\n // actually has a command with that name. So this should work with single\n // and multiline text inputs. Ideally we'll merge them into one component\n // in the future.\n iOSTextInputCommands.focus(textField);\n } else if (Platform.OS === 'android') {\n AndroidTextInputCommands.focus(textField);\n }\n }\n}\n\n/**\n * @param {number} textFieldID id of the text field to unfocus\n * Unfocuses the specified text field\n * noop if it wasn't focused\n */\nfunction blurTextInput(textField: ?ComponentRef) {\n if (typeof textField === 'number') {\n if (__DEV__) {\n console.error(\n 'blurTextInput must be called with a host component. Passing a react tag is deprecated.',\n );\n }\n\n return;\n }\n\n if (currentlyFocusedInputRef === textField && textField != null) {\n blurInput(textField);\n if (Platform.OS === 'ios') {\n // This isn't necessarily a single line text input\n // But commands don't actually care as long as the thing being passed in\n // actually has a command with that name. So this should work with single\n // and multiline text inputs. Ideally we'll merge them into one component\n // in the future.\n iOSTextInputCommands.blur(textField);\n } else if (Platform.OS === 'android') {\n AndroidTextInputCommands.blur(textField);\n }\n }\n}\n\nfunction registerInput(textField: ComponentRef) {\n if (typeof textField === 'number') {\n if (__DEV__) {\n console.error(\n 'registerInput must be called with a host component. Passing a react tag is deprecated.',\n );\n }\n\n return;\n }\n\n inputs.add(textField);\n}\n\nfunction unregisterInput(textField: ComponentRef) {\n if (typeof textField === 'number') {\n if (__DEV__) {\n console.error(\n 'unregisterInput must be called with a host component. Passing a react tag is deprecated.',\n );\n }\n\n return;\n }\n inputs.delete(textField);\n}\n\nfunction isTextInput(textField: ComponentRef): boolean {\n if (typeof textField === 'number') {\n if (__DEV__) {\n console.error(\n 'isTextInput must be called with a host component. Passing a react tag is deprecated.',\n );\n }\n\n return false;\n }\n\n return inputs.has(textField);\n}\n\nmodule.exports = {\n currentlyFocusedInput,\n focusInput,\n blurInput,\n\n currentlyFocusedField,\n focusField,\n blurField,\n focusTextInput,\n blurTextInput,\n registerInput,\n unregisterInput,\n isTextInput,\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 * @flow strict-local\n * @format\n */\n\nimport type {\n HostComponent,\n PartialViewConfig,\n} from '../../Renderer/shims/ReactNativeTypes';\nimport type {TextInputNativeCommands} from './TextInputNativeCommands';\n\nimport * as NativeComponentRegistry from '../../NativeComponent/NativeComponentRegistry';\nimport codegenNativeCommands from '../../Utilities/codegenNativeCommands';\nimport RCTTextInputViewConfig from './RCTTextInputViewConfig';\n\ntype NativeType = HostComponent;\n\ntype NativeCommands = TextInputNativeCommands;\n\nexport const Commands: NativeCommands = codegenNativeCommands({\n supportedCommands: ['focus', 'blur', 'setTextAndSelection'],\n});\n\nexport const __INTERNAL_VIEW_CONFIG: PartialViewConfig = {\n uiViewClassName: 'RCTSinglelineTextInputView',\n ...RCTTextInputViewConfig,\n};\n\nconst SinglelineTextInputNativeComponent: HostComponent =\n NativeComponentRegistry.get(\n 'RCTSinglelineTextInputView',\n () => __INTERNAL_VIEW_CONFIG,\n );\n\n// flowlint-next-line unclear-type:off\nexport default ((SinglelineTextInputNativeComponent: any): HostComponent);\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 * @flow strict-local\n * @format\n */\n\nimport type {PartialViewConfig} from '../../Renderer/shims/ReactNativeTypes';\n\nimport {ConditionallyIgnoredEventHandlers} from '../../NativeComponent/ViewConfigIgnore';\n\ntype PartialViewConfigWithoutName = $Rest<\n PartialViewConfig,\n {uiViewClassName: string},\n>;\n\nconst RCTTextInputViewConfig = {\n bubblingEventTypes: {\n topBlur: {\n phasedRegistrationNames: {\n bubbled: 'onBlur',\n captured: 'onBlurCapture',\n },\n },\n topChange: {\n phasedRegistrationNames: {\n bubbled: 'onChange',\n captured: 'onChangeCapture',\n },\n },\n topContentSizeChange: {\n phasedRegistrationNames: {\n captured: 'onContentSizeChangeCapture',\n bubbled: 'onContentSizeChange',\n },\n },\n topEndEditing: {\n phasedRegistrationNames: {\n bubbled: 'onEndEditing',\n captured: 'onEndEditingCapture',\n },\n },\n topFocus: {\n phasedRegistrationNames: {\n bubbled: 'onFocus',\n captured: 'onFocusCapture',\n },\n },\n topKeyPress: {\n phasedRegistrationNames: {\n bubbled: 'onKeyPress',\n captured: 'onKeyPressCapture',\n },\n },\n topSubmitEditing: {\n phasedRegistrationNames: {\n bubbled: 'onSubmitEditing',\n captured: 'onSubmitEditingCapture',\n },\n },\n topTouchCancel: {\n phasedRegistrationNames: {\n bubbled: 'onTouchCancel',\n captured: 'onTouchCancelCapture',\n },\n },\n topTouchEnd: {\n phasedRegistrationNames: {\n bubbled: 'onTouchEnd',\n captured: 'onTouchEndCapture',\n },\n },\n\n topTouchMove: {\n phasedRegistrationNames: {\n bubbled: 'onTouchMove',\n captured: 'onTouchMoveCapture',\n },\n },\n },\n directEventTypes: {\n topTextInput: {\n registrationName: 'onTextInput',\n },\n topKeyPressSync: {\n registrationName: 'onKeyPressSync',\n },\n topScroll: {\n registrationName: 'onScroll',\n },\n topSelectionChange: {\n registrationName: 'onSelectionChange',\n },\n topChangeSync: {\n registrationName: 'onChangeSync',\n },\n },\n validAttributes: {\n fontSize: true,\n fontWeight: true,\n fontVariant: true,\n // flowlint-next-line untyped-import:off\n textShadowOffset: {diff: require('../../Utilities/differ/sizesDiffer')},\n allowFontScaling: true,\n fontStyle: true,\n textTransform: true,\n textAlign: true,\n fontFamily: true,\n lineHeight: true,\n isHighlighted: true,\n writingDirection: true,\n textDecorationLine: true,\n textShadowRadius: true,\n letterSpacing: true,\n textDecorationStyle: true,\n textDecorationColor: {process: require('../../StyleSheet/processColor')},\n color: {process: require('../../StyleSheet/processColor')},\n maxFontSizeMultiplier: true,\n textShadowColor: {process: require('../../StyleSheet/processColor')},\n editable: true,\n inputAccessoryViewID: true,\n caretHidden: true,\n enablesReturnKeyAutomatically: true,\n placeholderTextColor: {process: require('../../StyleSheet/processColor')},\n clearButtonMode: true,\n keyboardType: true,\n selection: true,\n returnKeyType: true,\n submitBehavior: true,\n mostRecentEventCount: true,\n scrollEnabled: true,\n selectionColor: {process: require('../../StyleSheet/processColor')},\n contextMenuHidden: true,\n secureTextEntry: true,\n placeholder: true,\n autoCorrect: true,\n multiline: true,\n numberOfLines: true,\n maximumNumberOfLines: true,\n textContentType: true,\n maxLength: true,\n autoCapitalize: true,\n keyboardAppearance: true,\n passwordRules: true,\n spellCheck: true,\n selectTextOnFocus: true,\n text: true,\n clearTextOnFocus: true,\n showSoftInputOnFocus: true,\n autoFocus: true,\n lineBreakStrategyIOS: true,\n smartInsertDelete: true,\n ...ConditionallyIgnoredEventHandlers({\n onChange: true,\n onSelectionChange: true,\n onContentSizeChange: true,\n onScroll: true,\n onChangeSync: true,\n onKeyPressSync: true,\n onTextInput: true,\n }),\n },\n};\n\nmodule.exports = (RCTTextInputViewConfig: PartialViewConfigWithoutName);\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 * @format\n * @flow\n */\n\n'use strict';\n\nlet logListeners;\n\ntype LogListeners = {|\n +onDifferentFunctionsIgnored: (nameOne: ?string, nameTwo: ?string) => void,\n|};\n\ntype Options = {|+unsafelyIgnoreFunctions?: boolean|};\n\nfunction unstable_setLogListeners(listeners: ?LogListeners) {\n logListeners = listeners;\n}\n\n/*\n * @returns {bool} true if different, false if equal\n */\nconst deepDiffer = function (\n one: any,\n two: any,\n maxDepthOrOptions: Options | number = -1,\n maybeOptions?: Options,\n): boolean {\n const options =\n typeof maxDepthOrOptions === 'number' ? maybeOptions : maxDepthOrOptions;\n const maxDepth =\n typeof maxDepthOrOptions === 'number' ? maxDepthOrOptions : -1;\n if (maxDepth === 0) {\n return true;\n }\n if (one === two) {\n // Short circuit on identical object references instead of traversing them.\n return false;\n }\n if (typeof one === 'function' && typeof two === 'function') {\n // We consider all functions equal unless explicitly configured otherwise\n let unsafelyIgnoreFunctions = options?.unsafelyIgnoreFunctions;\n if (unsafelyIgnoreFunctions == null) {\n if (\n logListeners &&\n logListeners.onDifferentFunctionsIgnored &&\n (!options || !('unsafelyIgnoreFunctions' in options))\n ) {\n logListeners.onDifferentFunctionsIgnored(one.name, two.name);\n }\n unsafelyIgnoreFunctions = true;\n }\n return !unsafelyIgnoreFunctions;\n }\n if (typeof one !== 'object' || one === null) {\n // Primitives can be directly compared\n return one !== two;\n }\n if (typeof two !== 'object' || two === null) {\n // We know they are different because the previous case would have triggered\n // otherwise.\n return true;\n }\n if (one.constructor !== two.constructor) {\n return true;\n }\n if (Array.isArray(one)) {\n // We know two is also an array because the constructors are equal\n const len = one.length;\n if (two.length !== len) {\n return true;\n }\n for (let ii = 0; ii < len; ii++) {\n if (deepDiffer(one[ii], two[ii], maxDepth - 1, options)) {\n return true;\n }\n }\n } else {\n for (const key in one) {\n if (deepDiffer(one[key], two[key], maxDepth - 1, options)) {\n return true;\n }\n }\n for (const twoKey in two) {\n // The only case we haven't checked yet is keys that are in two but aren't\n // in one, which means they are different.\n if (one[twoKey] === undefined && two[twoKey] !== undefined) {\n return true;\n }\n }\n }\n return false;\n};\n\ndeepDiffer.unstable_setLogListeners = unstable_setLogListeners;\nmodule.exports = deepDiffer;\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 * @format\n * @flow strict\n */\n\n'use strict';\n\n/**\n * If your application is accepting different values for the same field over\n * time and is doing a diff on them, you can either (1) create a copy or\n * (2) ensure that those values are not mutated behind two passes.\n * This function helps you with (2) by freezing the object and throwing if\n * the user subsequently modifies the value.\n *\n * There are two caveats with this function:\n * - If the call site is not in strict mode, it will only throw when\n * mutating existing fields, adding a new one\n * will unfortunately fail silently :(\n * - If the object is already frozen or sealed, it will not continue the\n * deep traversal and will leave leaf nodes unfrozen.\n *\n * Freezing the object and adding the throw mechanism is expensive and will\n * only be used in DEV.\n */\nfunction deepFreezeAndThrowOnMutationInDev>(\n object: T,\n): T {\n if (__DEV__) {\n if (\n typeof object !== 'object' ||\n object === null ||\n Object.isFrozen(object) ||\n Object.isSealed(object)\n ) {\n return object;\n }\n\n // $FlowFixMe[not-an-object] `object` can be an array, but Object.keys works with arrays too\n const keys = Object.keys((object: {...} | Array));\n // $FlowFixMe[method-unbinding] added when improving typing for this parameters\n const hasOwnProperty = Object.prototype.hasOwnProperty;\n\n for (let i = 0; i < keys.length; i++) {\n const key = keys[i];\n if (hasOwnProperty.call(object, key)) {\n Object.defineProperty(object, key, {\n get: identity.bind(null, object[key]),\n });\n Object.defineProperty(object, key, {\n set: throwOnImmutableMutation.bind(null, key),\n });\n }\n }\n\n Object.freeze(object);\n Object.seal(object);\n\n for (let i = 0; i < keys.length; i++) {\n const key = keys[i];\n if (hasOwnProperty.call(object, key)) {\n deepFreezeAndThrowOnMutationInDev(object[key]);\n }\n }\n }\n return object;\n}\n\n/* $FlowFixMe[missing-local-annot] The type annotation(s) required by Flow's\n * LTI update could not be added via codemod */\nfunction throwOnImmutableMutation(key: empty, value) {\n throw Error(\n 'You attempted to set the key `' +\n key +\n '` with the value `' +\n JSON.stringify(value) +\n '` on an object that is meant to be immutable ' +\n 'and has been frozen.',\n );\n}\n\nfunction identity(value: mixed) {\n return value;\n}\n\nmodule.exports = deepFreezeAndThrowOnMutationInDev;\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 * @format\n * @flow strict-local\n */\n\nimport type {ExtendedError} from './ExtendedError';\n\nimport {SyntheticError, handleException} from './ExceptionsManager';\n\nexport type CapturedError = {\n +componentStack: string,\n +error: mixed,\n +errorBoundary: ?{...},\n ...\n};\n\nconst ReactFiberErrorDialog = {\n /**\n * Intercept lifecycle errors and ensure they are shown with the correct stack\n * trace within the native redbox component.\n */\n showErrorDialog({componentStack, error: errorValue}: CapturedError): boolean {\n let error: ?ExtendedError;\n\n // Typically, `errorValue` should be an error. However, other values such as\n // strings (or even null) are sometimes thrown.\n if (errorValue instanceof Error) {\n /* $FlowFixMe[class-object-subtyping] added when improving typing for\n * this parameters */\n error = (errorValue: ExtendedError);\n } else if (typeof errorValue === 'string') {\n /* $FlowFixMe[class-object-subtyping] added when improving typing for\n * this parameters */\n error = (new SyntheticError(errorValue): ExtendedError);\n } else {\n /* $FlowFixMe[class-object-subtyping] added when improving typing for\n * this parameters */\n error = (new SyntheticError('Unspecified error'): ExtendedError);\n }\n try {\n error.componentStack = componentStack;\n error.isComponentError = true;\n } catch {\n // Ignored.\n }\n\n handleException(error, false);\n\n // Return false here to prevent ReactFiberErrorLogger default behavior of\n // logging error details to console.error. Calls to console.error are\n // automatically routed to the native redbox controller, which we've already\n // done above by calling ExceptionsManager.\n return false;\n },\n};\n\nexport default ReactFiberErrorDialog;\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 * @flow strict-local\n * @format\n */\n\nimport type {IEventEmitter} from '../vendor/emitter/EventEmitter';\n\nimport EventEmitter from '../vendor/emitter/EventEmitter';\n\nexport type RawEventEmitterEvent = $ReadOnly<{|\n eventName: string,\n // We expect, but do not/cannot require, that nativeEvent is an object\n // with the properties: key, elementType (string), type (string), tag (numeric),\n // and a stateNode of the native element/Fiber the event was emitted to.\n nativeEvent: {[string]: mixed},\n|}>;\n\ntype RawEventDefinitions = {\n [eventChannel: string]: [RawEventEmitterEvent],\n};\n\nconst RawEventEmitter: IEventEmitter =\n new EventEmitter();\n\n// See the React renderer / react repo for how this is used.\n// Raw events are emitted here when they are received in JS\n// and before any event Plugins process them or before components\n// have a chance to respond to them. This allows you to implement\n// app-specific perf monitoring, which is unimplemented by default,\n// making this entire RawEventEmitter do nothing by default until\n// *you* add listeners for your own app.\n// Besides perf monitoring and maybe debugging, this RawEventEmitter\n// should not be used.\nexport default RawEventEmitter;\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 * @format\n * @flow strict-local\n */\n\n// Make sure global Event is defined\nimport EventPolyfill from './EventPolyfill';\n\ntype CustomEvent$Options = $ReadOnly<{|\n bubbles?: boolean,\n cancelable?: boolean,\n composed?: boolean,\n detail?: {...},\n|}>;\n\nclass CustomEvent extends EventPolyfill {\n detail: ?{...};\n\n constructor(typeArg: string, options: CustomEvent$Options) {\n const {bubbles, cancelable, composed} = options;\n super(typeArg, {bubbles, cancelable, composed});\n\n this.detail = options.detail; // this would correspond to `NativeEvent` in SyntheticEvent\n }\n}\n\nexport default CustomEvent;\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 * @format\n * @flow strict-local\n */\n\n// https://dom.spec.whatwg.org/#dictdef-eventinit\ntype Event$Init = {\n bubbles?: boolean,\n cancelable?: boolean,\n composed?: boolean,\n /** Non-standard. See `composed` instead. */\n scoped?: boolean,\n ...\n};\n\n/**\n * This is a copy of the Event interface defined in Flow:\n * https://github.com/facebook/flow/blob/741104e69c43057ebd32804dd6bcc1b5e97548ea/lib/dom.js\n * which is itself a faithful interface of the W3 spec:\n * https://dom.spec.whatwg.org/#interface-event\n *\n * Since Flow assumes that Event is provided and is on the global object,\n * we must provide an implementation of Event for CustomEvent (and future\n * alignment of React Native's event system with the W3 spec).\n */\ninterface IEvent {\n constructor(type: string, eventInitDict?: Event$Init): void;\n /**\n * Returns the type of event, e.g. \"click\", \"hashchange\", or \"submit\".\n */\n +type: string;\n /**\n * Returns the object to which event is dispatched (its target).\n */\n +target: EventTarget; // TODO: nullable\n /** @deprecated */\n +srcElement: Element; // TODO: nullable\n /**\n * Returns the object whose event listener's callback is currently being invoked.\n */\n +currentTarget: EventTarget; // TODO: nullable\n /**\n * Returns the invocation target objects of event's path (objects on which\n * listeners will be invoked), except for any nodes in shadow trees of which\n * the shadow root's mode is \"closed\" that are not reachable from event's\n * currentTarget.\n */\n composedPath(): Array;\n\n +NONE: number;\n +AT_TARGET: number;\n +BUBBLING_PHASE: number;\n +CAPTURING_PHASE: number;\n /**\n * Returns the event's phase, which is one of NONE, CAPTURING_PHASE, AT_TARGET,\n * and BUBBLING_PHASE.\n */\n +eventPhase: number;\n\n /**\n * When dispatched in a tree, invoking this method prevents event from reaching\n * any objects other than the current object.\n */\n stopPropagation(): void;\n /**\n * Invoking this method prevents event from reaching any registered event\n * listeners after the current one finishes running and, when dispatched in a\n * tree, also prevents event from reaching any other objects.\n */\n stopImmediatePropagation(): void;\n\n /**\n * Returns true or false depending on how event was initialized. True if\n * event goes through its target's ancestors in reverse tree order, and\n * false otherwise.\n */\n +bubbles: boolean;\n /**\n * Returns true or false depending on how event was initialized. Its\n * return value does not always carry meaning, but true can indicate\n * that part of the operation during which event was dispatched, can\n * be canceled by invoking the preventDefault() method.\n */\n +cancelable: boolean;\n // returnValue: boolean; // legacy, and some subclasses still define it as a string!\n /**\n * If invoked when the cancelable attribute value is true, and while\n * executing a listener for the event with passive set to false, signals to\n * the operation that caused event to be dispatched that it needs to be\n * canceled.\n */\n preventDefault(): void;\n /**\n * Returns true if preventDefault() was invoked successfully to indicate\n * cancelation, and false otherwise.\n */\n +defaultPrevented: boolean;\n /**\n * Returns true or false depending on how event was initialized. True if\n * event invokes listeners past a ShadowRoot node that is the root of its\n * target, and false otherwise.\n */\n +composed: boolean;\n\n /**\n * Returns true if event was dispatched by the user agent, and false otherwise.\n */\n +isTrusted: boolean;\n /**\n * Returns the event's timestamp as the number of milliseconds measured relative\n * to the time origin.\n */\n +timeStamp: number;\n\n /** Non-standard. See Event.prototype.composedPath */\n +deepPath?: () => EventTarget[];\n /** Non-standard. See Event.prototype.composed */\n +scoped: boolean;\n\n /**\n * @deprecated\n */\n initEvent(type: string, bubbles: boolean, cancelable: boolean): void;\n}\n\nclass EventPolyfill implements IEvent {\n type: string;\n bubbles: boolean;\n cancelable: boolean;\n composed: boolean;\n // Non-standard. See `composed` instead.\n scoped: boolean;\n isTrusted: boolean;\n defaultPrevented: boolean;\n timeStamp: number;\n\n // https://developer.mozilla.org/en-US/docs/Web/API/Event/eventPhase\n NONE: number;\n AT_TARGET: number;\n BUBBLING_PHASE: number;\n CAPTURING_PHASE: number;\n\n eventPhase: number;\n\n currentTarget: EventTarget; // TODO: nullable\n target: EventTarget; // TODO: nullable\n /** @deprecated */\n srcElement: Element; // TODO: nullable\n\n // React Native-specific: proxy data to a SyntheticEvent when\n // certain methods are called.\n // SyntheticEvent will also have a reference to this instance -\n // it is circular - and both classes use this reference to keep\n // data with the other in sync.\n _syntheticEvent: mixed;\n\n constructor(type: string, eventInitDict?: Event$Init): void {\n this.type = type;\n this.bubbles = !!(eventInitDict?.bubbles || false);\n this.cancelable = !!(eventInitDict?.cancelable || false);\n this.composed = !!(eventInitDict?.composed || false);\n this.scoped = !!(eventInitDict?.scoped || false);\n\n // TODO: somehow guarantee that only \"private\" instantiations of Event\n // can set this to true\n this.isTrusted = false;\n\n // TODO: in the future we'll want to make sure this has the same\n // time-basis as events originating from native\n this.timeStamp = Date.now();\n\n this.defaultPrevented = false;\n\n // https://developer.mozilla.org/en-US/docs/Web/API/Event/eventPhase\n this.NONE = 0;\n this.AT_TARGET = 1;\n this.BUBBLING_PHASE = 2;\n this.CAPTURING_PHASE = 3;\n this.eventPhase = this.NONE;\n\n // $FlowFixMe\n this.currentTarget = null;\n // $FlowFixMe\n this.target = null;\n // $FlowFixMe\n this.srcElement = null;\n }\n\n composedPath(): Array {\n throw new Error('TODO: not yet implemented');\n }\n\n preventDefault(): void {\n this.defaultPrevented = true;\n\n if (this._syntheticEvent != null) {\n // $FlowFixMe\n this._syntheticEvent.preventDefault();\n }\n }\n\n initEvent(type: string, bubbles: boolean, cancelable: boolean): void {\n throw new Error(\n 'TODO: not yet implemented. This method is also deprecated.',\n );\n }\n\n stopImmediatePropagation(): void {\n throw new Error('TODO: not yet implemented');\n }\n\n stopPropagation(): void {\n if (this._syntheticEvent != null) {\n // $FlowFixMe\n this._syntheticEvent.stopPropagation();\n }\n }\n\n setSyntheticEvent(value: mixed): void {\n this._syntheticEvent = value;\n }\n}\n\n// Assertion magic for polyfill follows.\ndeclare var checkEvent: Event; // eslint-disable-line no-unused-vars\n\n/*::\n// This can be a strict mode error at runtime so put it in a Flow comment.\n(checkEvent: IEvent);\n*/\n\nglobal.Event = EventPolyfill;\n\nexport default EventPolyfill;\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/scheduler.production.min.js');\n} else {\n module.exports = require('./cjs/scheduler.development.js');\n}\n","/**\n * @license React\n * scheduler.production.min.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'use strict';function f(a,b){var c=a.length;a.push(b);a:for(;0>>1,e=a[d];if(0>>1;dg(C,c))ng(x,C)?(a[d]=x,a[n]=c,d=n):(a[d]=C,a[m]=c,d=m);else if(ng(x,c))a[d]=x,a[n]=c,d=n;else break a}}return b}\nfunction g(a,b){var c=a.sortIndex-b.sortIndex;return 0!==c?c:a.id-b.id}if(\"object\"===typeof performance&&\"function\"===typeof performance.now){var l=performance;exports.unstable_now=function(){return l.now()}}else{var p=Date,q=p.now();exports.unstable_now=function(){return p.now()-q}}var r=[],t=[],u=1,v=null,y=3,z=!1,A=!1,B=!1,D=\"function\"===typeof setTimeout?setTimeout:null,E=\"function\"===typeof clearTimeout?clearTimeout:null,F=\"undefined\"!==typeof setImmediate?setImmediate:null;\n\"undefined\"!==typeof navigator&&void 0!==navigator.scheduling&&void 0!==navigator.scheduling.isInputPending&&navigator.scheduling.isInputPending.bind(navigator.scheduling);function G(a){for(var b=h(t);null!==b;){if(null===b.callback)k(t);else if(b.startTime<=a)k(t),b.sortIndex=b.expirationTime,f(r,b);else break;b=h(t)}}function H(a){B=!1;G(a);if(!A)if(null!==h(r))A=!0,I(J);else{var b=h(t);null!==b&&K(H,b.startTime-a)}}\nfunction J(a,b){A=!1;B&&(B=!1,E(L),L=-1);z=!0;var c=y;try{G(b);for(v=h(r);null!==v&&(!(v.expirationTime>b)||a&&!M());){var d=v.callback;if(\"function\"===typeof d){v.callback=null;y=v.priorityLevel;var e=d(v.expirationTime<=b);b=exports.unstable_now();\"function\"===typeof e?v.callback=e:v===h(r)&&k(r);G(b)}else k(r);v=h(r)}if(null!==v)var w=!0;else{var m=h(t);null!==m&&K(H,m.startTime-b);w=!1}return w}finally{v=null,y=c,z=!1}}var N=!1,O=null,L=-1,P=5,Q=-1;\nfunction M(){return exports.unstable_now()-Qa||125d?(a.sortIndex=c,f(t,a),null===h(r)&&a===h(t)&&(B?(E(L),L=-1):B=!0,K(H,c-d))):(a.sortIndex=e,f(r,a),A||z||(A=!0,I(J)));return a};\nexports.unstable_shouldYield=M;exports.unstable_wrapCallback=function(a){var b=y;return function(){var c=y;y=b;try{return a.apply(this,arguments)}finally{y=c}}};\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 * @noformat\n * @flow\n * @generated SignedSource<<744176db456e2656dac661d36e55f42a>>\n *\n * This file was sync'd from the facebook/react repository.\n */\n\n'use strict';\n\nimport type {ReactNativeType} from './ReactNativeTypes';\n\nlet ReactNative;\n\nif (__DEV__) {\n ReactNative = require('../implementations/ReactNativeRenderer-dev');\n} else {\n ReactNative = require('../implementations/ReactNativeRenderer-prod');\n}\n\nmodule.exports = (ReactNative: ReactNativeType);\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 * @noflow\n * @nolint\n * @providesModule ReactNativeRenderer-prod\n * @preventMunge\n * @generated SignedSource<<07cf699c0d1c149943b7a02432aa1550>>\n */\n\n\"use strict\";\nrequire(\"react-native/Libraries/ReactPrivate/ReactNativePrivateInitializeCore\");\nvar ReactNativePrivateInterface = require(\"react-native/Libraries/ReactPrivate/ReactNativePrivateInterface\"),\n React = require(\"react\"),\n Scheduler = require(\"scheduler\");\nfunction invokeGuardedCallbackImpl(name, func, context, a, b, c, d, e, f) {\n var funcArgs = Array.prototype.slice.call(arguments, 3);\n try {\n func.apply(context, funcArgs);\n } catch (error) {\n this.onError(error);\n }\n}\nvar hasError = !1,\n caughtError = null,\n hasRethrowError = !1,\n rethrowError = null,\n reporter = {\n onError: function(error) {\n hasError = !0;\n caughtError = error;\n }\n };\nfunction invokeGuardedCallback(name, func, context, a, b, c, d, e, f) {\n hasError = !1;\n caughtError = null;\n invokeGuardedCallbackImpl.apply(reporter, arguments);\n}\nfunction invokeGuardedCallbackAndCatchFirstError(\n name,\n func,\n context,\n a,\n b,\n c,\n d,\n e,\n f\n) {\n invokeGuardedCallback.apply(this, arguments);\n if (hasError) {\n if (hasError) {\n var error = caughtError;\n hasError = !1;\n caughtError = null;\n } else\n throw Error(\n \"clearCaughtError was called but no error was captured. This error is likely caused by a bug in React. Please file an issue.\"\n );\n hasRethrowError || ((hasRethrowError = !0), (rethrowError = error));\n }\n}\nvar isArrayImpl = Array.isArray,\n getFiberCurrentPropsFromNode = null,\n getInstanceFromNode = null,\n getNodeFromInstance = null;\nfunction executeDispatch(event, listener, inst) {\n var type = event.type || \"unknown-event\";\n event.currentTarget = getNodeFromInstance(inst);\n invokeGuardedCallbackAndCatchFirstError(type, listener, void 0, event);\n event.currentTarget = null;\n}\nfunction executeDirectDispatch(event) {\n var dispatchListener = event._dispatchListeners,\n dispatchInstance = event._dispatchInstances;\n if (isArrayImpl(dispatchListener))\n throw Error(\"executeDirectDispatch(...): Invalid `event`.\");\n event.currentTarget = dispatchListener\n ? getNodeFromInstance(dispatchInstance)\n : null;\n dispatchListener = dispatchListener ? dispatchListener(event) : null;\n event.currentTarget = null;\n event._dispatchListeners = null;\n event._dispatchInstances = null;\n return dispatchListener;\n}\nvar assign = Object.assign;\nfunction functionThatReturnsTrue() {\n return !0;\n}\nfunction functionThatReturnsFalse() {\n return !1;\n}\nfunction SyntheticEvent(\n dispatchConfig,\n targetInst,\n nativeEvent,\n nativeEventTarget\n) {\n this.dispatchConfig = dispatchConfig;\n this._targetInst = targetInst;\n this.nativeEvent = nativeEvent;\n this._dispatchInstances = this._dispatchListeners = null;\n dispatchConfig = this.constructor.Interface;\n for (var propName in dispatchConfig)\n dispatchConfig.hasOwnProperty(propName) &&\n ((targetInst = dispatchConfig[propName])\n ? (this[propName] = targetInst(nativeEvent))\n : \"target\" === propName\n ? (this.target = nativeEventTarget)\n : (this[propName] = nativeEvent[propName]));\n this.isDefaultPrevented = (null != nativeEvent.defaultPrevented\n ? nativeEvent.defaultPrevented\n : !1 === nativeEvent.returnValue)\n ? functionThatReturnsTrue\n : functionThatReturnsFalse;\n this.isPropagationStopped = functionThatReturnsFalse;\n return this;\n}\nassign(SyntheticEvent.prototype, {\n preventDefault: function() {\n this.defaultPrevented = !0;\n var event = this.nativeEvent;\n event &&\n (event.preventDefault\n ? event.preventDefault()\n : \"unknown\" !== typeof event.returnValue && (event.returnValue = !1),\n (this.isDefaultPrevented = functionThatReturnsTrue));\n },\n stopPropagation: function() {\n var event = this.nativeEvent;\n event &&\n (event.stopPropagation\n ? event.stopPropagation()\n : \"unknown\" !== typeof event.cancelBubble && (event.cancelBubble = !0),\n (this.isPropagationStopped = functionThatReturnsTrue));\n },\n persist: function() {\n this.isPersistent = functionThatReturnsTrue;\n },\n isPersistent: functionThatReturnsFalse,\n destructor: function() {\n var Interface = this.constructor.Interface,\n propName;\n for (propName in Interface) this[propName] = null;\n this.nativeEvent = this._targetInst = this.dispatchConfig = null;\n this.isPropagationStopped = this.isDefaultPrevented = functionThatReturnsFalse;\n this._dispatchInstances = this._dispatchListeners = null;\n }\n});\nSyntheticEvent.Interface = {\n type: null,\n target: null,\n currentTarget: function() {\n return null;\n },\n eventPhase: null,\n bubbles: null,\n cancelable: null,\n timeStamp: function(event) {\n return event.timeStamp || Date.now();\n },\n defaultPrevented: null,\n isTrusted: null\n};\nSyntheticEvent.extend = function(Interface) {\n function E() {}\n function Class() {\n return Super.apply(this, arguments);\n }\n var Super = this;\n E.prototype = Super.prototype;\n var prototype = new E();\n assign(prototype, Class.prototype);\n Class.prototype = prototype;\n Class.prototype.constructor = Class;\n Class.Interface = assign({}, Super.Interface, Interface);\n Class.extend = Super.extend;\n addEventPoolingTo(Class);\n return Class;\n};\naddEventPoolingTo(SyntheticEvent);\nfunction createOrGetPooledEvent(\n dispatchConfig,\n targetInst,\n nativeEvent,\n nativeInst\n) {\n if (this.eventPool.length) {\n var instance = this.eventPool.pop();\n this.call(instance, dispatchConfig, targetInst, nativeEvent, nativeInst);\n return instance;\n }\n return new this(dispatchConfig, targetInst, nativeEvent, nativeInst);\n}\nfunction releasePooledEvent(event) {\n if (!(event instanceof this))\n throw Error(\n \"Trying to release an event instance into a pool of a different type.\"\n );\n event.destructor();\n 10 > this.eventPool.length && this.eventPool.push(event);\n}\nfunction addEventPoolingTo(EventConstructor) {\n EventConstructor.getPooled = createOrGetPooledEvent;\n EventConstructor.eventPool = [];\n EventConstructor.release = releasePooledEvent;\n}\nvar ResponderSyntheticEvent = SyntheticEvent.extend({\n touchHistory: function() {\n return null;\n }\n});\nfunction isStartish(topLevelType) {\n return \"topTouchStart\" === topLevelType;\n}\nfunction isMoveish(topLevelType) {\n return \"topTouchMove\" === topLevelType;\n}\nvar startDependencies = [\"topTouchStart\"],\n moveDependencies = [\"topTouchMove\"],\n endDependencies = [\"topTouchCancel\", \"topTouchEnd\"],\n touchBank = [],\n touchHistory = {\n touchBank: touchBank,\n numberActiveTouches: 0,\n indexOfSingleActiveTouch: -1,\n mostRecentTimeStamp: 0\n };\nfunction timestampForTouch(touch) {\n return touch.timeStamp || touch.timestamp;\n}\nfunction getTouchIdentifier(_ref) {\n _ref = _ref.identifier;\n if (null == _ref) throw Error(\"Touch object is missing identifier.\");\n return _ref;\n}\nfunction recordTouchStart(touch) {\n var identifier = getTouchIdentifier(touch),\n touchRecord = touchBank[identifier];\n touchRecord\n ? ((touchRecord.touchActive = !0),\n (touchRecord.startPageX = touch.pageX),\n (touchRecord.startPageY = touch.pageY),\n (touchRecord.startTimeStamp = timestampForTouch(touch)),\n (touchRecord.currentPageX = touch.pageX),\n (touchRecord.currentPageY = touch.pageY),\n (touchRecord.currentTimeStamp = timestampForTouch(touch)),\n (touchRecord.previousPageX = touch.pageX),\n (touchRecord.previousPageY = touch.pageY),\n (touchRecord.previousTimeStamp = timestampForTouch(touch)))\n : ((touchRecord = {\n touchActive: !0,\n startPageX: touch.pageX,\n startPageY: touch.pageY,\n startTimeStamp: timestampForTouch(touch),\n currentPageX: touch.pageX,\n currentPageY: touch.pageY,\n currentTimeStamp: timestampForTouch(touch),\n previousPageX: touch.pageX,\n previousPageY: touch.pageY,\n previousTimeStamp: timestampForTouch(touch)\n }),\n (touchBank[identifier] = touchRecord));\n touchHistory.mostRecentTimeStamp = timestampForTouch(touch);\n}\nfunction recordTouchMove(touch) {\n var touchRecord = touchBank[getTouchIdentifier(touch)];\n touchRecord &&\n ((touchRecord.touchActive = !0),\n (touchRecord.previousPageX = touchRecord.currentPageX),\n (touchRecord.previousPageY = touchRecord.currentPageY),\n (touchRecord.previousTimeStamp = touchRecord.currentTimeStamp),\n (touchRecord.currentPageX = touch.pageX),\n (touchRecord.currentPageY = touch.pageY),\n (touchRecord.currentTimeStamp = timestampForTouch(touch)),\n (touchHistory.mostRecentTimeStamp = timestampForTouch(touch)));\n}\nfunction recordTouchEnd(touch) {\n var touchRecord = touchBank[getTouchIdentifier(touch)];\n touchRecord &&\n ((touchRecord.touchActive = !1),\n (touchRecord.previousPageX = touchRecord.currentPageX),\n (touchRecord.previousPageY = touchRecord.currentPageY),\n (touchRecord.previousTimeStamp = touchRecord.currentTimeStamp),\n (touchRecord.currentPageX = touch.pageX),\n (touchRecord.currentPageY = touch.pageY),\n (touchRecord.currentTimeStamp = timestampForTouch(touch)),\n (touchHistory.mostRecentTimeStamp = timestampForTouch(touch)));\n}\nvar instrumentationCallback,\n ResponderTouchHistoryStore = {\n instrument: function(callback) {\n instrumentationCallback = callback;\n },\n recordTouchTrack: function(topLevelType, nativeEvent) {\n null != instrumentationCallback &&\n instrumentationCallback(topLevelType, nativeEvent);\n if (isMoveish(topLevelType))\n nativeEvent.changedTouches.forEach(recordTouchMove);\n else if (isStartish(topLevelType))\n nativeEvent.changedTouches.forEach(recordTouchStart),\n (touchHistory.numberActiveTouches = nativeEvent.touches.length),\n 1 === touchHistory.numberActiveTouches &&\n (touchHistory.indexOfSingleActiveTouch =\n nativeEvent.touches[0].identifier);\n else if (\n \"topTouchEnd\" === topLevelType ||\n \"topTouchCancel\" === topLevelType\n )\n if (\n (nativeEvent.changedTouches.forEach(recordTouchEnd),\n (touchHistory.numberActiveTouches = nativeEvent.touches.length),\n 1 === touchHistory.numberActiveTouches)\n )\n for (\n topLevelType = 0;\n topLevelType < touchBank.length;\n topLevelType++\n )\n if (\n ((nativeEvent = touchBank[topLevelType]),\n null != nativeEvent && nativeEvent.touchActive)\n ) {\n touchHistory.indexOfSingleActiveTouch = topLevelType;\n break;\n }\n },\n touchHistory: touchHistory\n };\nfunction accumulate(current, next) {\n if (null == next)\n throw Error(\n \"accumulate(...): Accumulated items must not be null or undefined.\"\n );\n return null == current\n ? next\n : isArrayImpl(current)\n ? current.concat(next)\n : isArrayImpl(next)\n ? [current].concat(next)\n : [current, next];\n}\nfunction accumulateInto(current, next) {\n if (null == next)\n throw Error(\n \"accumulateInto(...): Accumulated items must not be null or undefined.\"\n );\n if (null == current) return next;\n if (isArrayImpl(current)) {\n if (isArrayImpl(next)) return current.push.apply(current, next), current;\n current.push(next);\n return current;\n }\n return isArrayImpl(next) ? [current].concat(next) : [current, next];\n}\nfunction forEachAccumulated(arr, cb, scope) {\n Array.isArray(arr) ? arr.forEach(cb, scope) : arr && cb.call(scope, arr);\n}\nvar responderInst = null,\n trackedTouchCount = 0;\nfunction changeResponder(nextResponderInst, blockHostResponder) {\n var oldResponderInst = responderInst;\n responderInst = nextResponderInst;\n if (null !== ResponderEventPlugin.GlobalResponderHandler)\n ResponderEventPlugin.GlobalResponderHandler.onChange(\n oldResponderInst,\n nextResponderInst,\n blockHostResponder\n );\n}\nvar eventTypes = {\n startShouldSetResponder: {\n phasedRegistrationNames: {\n bubbled: \"onStartShouldSetResponder\",\n captured: \"onStartShouldSetResponderCapture\"\n },\n dependencies: startDependencies\n },\n scrollShouldSetResponder: {\n phasedRegistrationNames: {\n bubbled: \"onScrollShouldSetResponder\",\n captured: \"onScrollShouldSetResponderCapture\"\n },\n dependencies: [\"topScroll\"]\n },\n selectionChangeShouldSetResponder: {\n phasedRegistrationNames: {\n bubbled: \"onSelectionChangeShouldSetResponder\",\n captured: \"onSelectionChangeShouldSetResponderCapture\"\n },\n dependencies: [\"topSelectionChange\"]\n },\n moveShouldSetResponder: {\n phasedRegistrationNames: {\n bubbled: \"onMoveShouldSetResponder\",\n captured: \"onMoveShouldSetResponderCapture\"\n },\n dependencies: moveDependencies\n },\n responderStart: {\n registrationName: \"onResponderStart\",\n dependencies: startDependencies\n },\n responderMove: {\n registrationName: \"onResponderMove\",\n dependencies: moveDependencies\n },\n responderEnd: {\n registrationName: \"onResponderEnd\",\n dependencies: endDependencies\n },\n responderRelease: {\n registrationName: \"onResponderRelease\",\n dependencies: endDependencies\n },\n responderTerminationRequest: {\n registrationName: \"onResponderTerminationRequest\",\n dependencies: []\n },\n responderGrant: { registrationName: \"onResponderGrant\", dependencies: [] },\n responderReject: { registrationName: \"onResponderReject\", dependencies: [] },\n responderTerminate: {\n registrationName: \"onResponderTerminate\",\n dependencies: []\n }\n};\nfunction getParent(inst) {\n do inst = inst.return;\n while (inst && 5 !== inst.tag);\n return inst ? inst : null;\n}\nfunction traverseTwoPhase(inst, fn, arg) {\n for (var path = []; inst; ) path.push(inst), (inst = getParent(inst));\n for (inst = path.length; 0 < inst--; ) fn(path[inst], \"captured\", arg);\n for (inst = 0; inst < path.length; inst++) fn(path[inst], \"bubbled\", arg);\n}\nfunction getListener(inst, registrationName) {\n inst = inst.stateNode;\n if (null === inst) return null;\n inst = getFiberCurrentPropsFromNode(inst);\n if (null === inst) return null;\n if ((inst = inst[registrationName]) && \"function\" !== typeof inst)\n throw Error(\n \"Expected `\" +\n registrationName +\n \"` listener to be a function, instead got a value of `\" +\n typeof inst +\n \"` type.\"\n );\n return inst;\n}\nfunction accumulateDirectionalDispatches(inst, phase, event) {\n if (\n (phase = getListener(\n inst,\n event.dispatchConfig.phasedRegistrationNames[phase]\n ))\n )\n (event._dispatchListeners = accumulateInto(\n event._dispatchListeners,\n phase\n )),\n (event._dispatchInstances = accumulateInto(\n event._dispatchInstances,\n inst\n ));\n}\nfunction accumulateDirectDispatchesSingle(event) {\n if (event && event.dispatchConfig.registrationName) {\n var inst = event._targetInst;\n if (inst && event && event.dispatchConfig.registrationName) {\n var listener = getListener(inst, event.dispatchConfig.registrationName);\n listener &&\n ((event._dispatchListeners = accumulateInto(\n event._dispatchListeners,\n listener\n )),\n (event._dispatchInstances = accumulateInto(\n event._dispatchInstances,\n inst\n )));\n }\n }\n}\nfunction accumulateTwoPhaseDispatchesSingleSkipTarget(event) {\n if (event && event.dispatchConfig.phasedRegistrationNames) {\n var targetInst = event._targetInst;\n targetInst = targetInst ? getParent(targetInst) : null;\n traverseTwoPhase(targetInst, accumulateDirectionalDispatches, event);\n }\n}\nfunction accumulateTwoPhaseDispatchesSingle(event) {\n event &&\n event.dispatchConfig.phasedRegistrationNames &&\n traverseTwoPhase(event._targetInst, accumulateDirectionalDispatches, event);\n}\nvar ResponderEventPlugin = {\n _getResponder: function() {\n return responderInst;\n },\n eventTypes: eventTypes,\n extractEvents: function(\n topLevelType,\n targetInst,\n nativeEvent,\n nativeEventTarget\n ) {\n if (isStartish(topLevelType)) trackedTouchCount += 1;\n else if (\n \"topTouchEnd\" === topLevelType ||\n \"topTouchCancel\" === topLevelType\n )\n if (0 <= trackedTouchCount) --trackedTouchCount;\n else return null;\n ResponderTouchHistoryStore.recordTouchTrack(topLevelType, nativeEvent);\n if (\n targetInst &&\n ((\"topScroll\" === topLevelType && !nativeEvent.responderIgnoreScroll) ||\n (0 < trackedTouchCount && \"topSelectionChange\" === topLevelType) ||\n isStartish(topLevelType) ||\n isMoveish(topLevelType))\n ) {\n var shouldSetEventType = isStartish(topLevelType)\n ? eventTypes.startShouldSetResponder\n : isMoveish(topLevelType)\n ? eventTypes.moveShouldSetResponder\n : \"topSelectionChange\" === topLevelType\n ? eventTypes.selectionChangeShouldSetResponder\n : eventTypes.scrollShouldSetResponder;\n if (responderInst)\n b: {\n var JSCompiler_temp = responderInst;\n for (\n var depthA = 0, tempA = JSCompiler_temp;\n tempA;\n tempA = getParent(tempA)\n )\n depthA++;\n tempA = 0;\n for (var tempB = targetInst; tempB; tempB = getParent(tempB))\n tempA++;\n for (; 0 < depthA - tempA; )\n (JSCompiler_temp = getParent(JSCompiler_temp)), depthA--;\n for (; 0 < tempA - depthA; )\n (targetInst = getParent(targetInst)), tempA--;\n for (; depthA--; ) {\n if (\n JSCompiler_temp === targetInst ||\n JSCompiler_temp === targetInst.alternate\n )\n break b;\n JSCompiler_temp = getParent(JSCompiler_temp);\n targetInst = getParent(targetInst);\n }\n JSCompiler_temp = null;\n }\n else JSCompiler_temp = targetInst;\n targetInst = JSCompiler_temp;\n JSCompiler_temp = targetInst === responderInst;\n shouldSetEventType = ResponderSyntheticEvent.getPooled(\n shouldSetEventType,\n targetInst,\n nativeEvent,\n nativeEventTarget\n );\n shouldSetEventType.touchHistory =\n ResponderTouchHistoryStore.touchHistory;\n JSCompiler_temp\n ? forEachAccumulated(\n shouldSetEventType,\n accumulateTwoPhaseDispatchesSingleSkipTarget\n )\n : forEachAccumulated(\n shouldSetEventType,\n accumulateTwoPhaseDispatchesSingle\n );\n b: {\n JSCompiler_temp = shouldSetEventType._dispatchListeners;\n targetInst = shouldSetEventType._dispatchInstances;\n if (isArrayImpl(JSCompiler_temp))\n for (\n depthA = 0;\n depthA < JSCompiler_temp.length &&\n !shouldSetEventType.isPropagationStopped();\n depthA++\n ) {\n if (\n JSCompiler_temp[depthA](shouldSetEventType, targetInst[depthA])\n ) {\n JSCompiler_temp = targetInst[depthA];\n break b;\n }\n }\n else if (\n JSCompiler_temp &&\n JSCompiler_temp(shouldSetEventType, targetInst)\n ) {\n JSCompiler_temp = targetInst;\n break b;\n }\n JSCompiler_temp = null;\n }\n shouldSetEventType._dispatchInstances = null;\n shouldSetEventType._dispatchListeners = null;\n shouldSetEventType.isPersistent() ||\n shouldSetEventType.constructor.release(shouldSetEventType);\n if (JSCompiler_temp && JSCompiler_temp !== responderInst)\n if (\n ((shouldSetEventType = ResponderSyntheticEvent.getPooled(\n eventTypes.responderGrant,\n JSCompiler_temp,\n nativeEvent,\n nativeEventTarget\n )),\n (shouldSetEventType.touchHistory =\n ResponderTouchHistoryStore.touchHistory),\n forEachAccumulated(\n shouldSetEventType,\n accumulateDirectDispatchesSingle\n ),\n (targetInst = !0 === executeDirectDispatch(shouldSetEventType)),\n responderInst)\n )\n if (\n ((depthA = ResponderSyntheticEvent.getPooled(\n eventTypes.responderTerminationRequest,\n responderInst,\n nativeEvent,\n nativeEventTarget\n )),\n (depthA.touchHistory = ResponderTouchHistoryStore.touchHistory),\n forEachAccumulated(depthA, accumulateDirectDispatchesSingle),\n (tempA =\n !depthA._dispatchListeners || executeDirectDispatch(depthA)),\n depthA.isPersistent() || depthA.constructor.release(depthA),\n tempA)\n ) {\n depthA = ResponderSyntheticEvent.getPooled(\n eventTypes.responderTerminate,\n responderInst,\n nativeEvent,\n nativeEventTarget\n );\n depthA.touchHistory = ResponderTouchHistoryStore.touchHistory;\n forEachAccumulated(depthA, accumulateDirectDispatchesSingle);\n var JSCompiler_temp$jscomp$0 = accumulate(\n JSCompiler_temp$jscomp$0,\n [shouldSetEventType, depthA]\n );\n changeResponder(JSCompiler_temp, targetInst);\n } else\n (shouldSetEventType = ResponderSyntheticEvent.getPooled(\n eventTypes.responderReject,\n JSCompiler_temp,\n nativeEvent,\n nativeEventTarget\n )),\n (shouldSetEventType.touchHistory =\n ResponderTouchHistoryStore.touchHistory),\n forEachAccumulated(\n shouldSetEventType,\n accumulateDirectDispatchesSingle\n ),\n (JSCompiler_temp$jscomp$0 = accumulate(\n JSCompiler_temp$jscomp$0,\n shouldSetEventType\n ));\n else\n (JSCompiler_temp$jscomp$0 = accumulate(\n JSCompiler_temp$jscomp$0,\n shouldSetEventType\n )),\n changeResponder(JSCompiler_temp, targetInst);\n else JSCompiler_temp$jscomp$0 = null;\n } else JSCompiler_temp$jscomp$0 = null;\n shouldSetEventType = responderInst && isStartish(topLevelType);\n JSCompiler_temp = responderInst && isMoveish(topLevelType);\n targetInst =\n responderInst &&\n (\"topTouchEnd\" === topLevelType || \"topTouchCancel\" === topLevelType);\n if (\n (shouldSetEventType = shouldSetEventType\n ? eventTypes.responderStart\n : JSCompiler_temp\n ? eventTypes.responderMove\n : targetInst\n ? eventTypes.responderEnd\n : null)\n )\n (shouldSetEventType = ResponderSyntheticEvent.getPooled(\n shouldSetEventType,\n responderInst,\n nativeEvent,\n nativeEventTarget\n )),\n (shouldSetEventType.touchHistory =\n ResponderTouchHistoryStore.touchHistory),\n forEachAccumulated(\n shouldSetEventType,\n accumulateDirectDispatchesSingle\n ),\n (JSCompiler_temp$jscomp$0 = accumulate(\n JSCompiler_temp$jscomp$0,\n shouldSetEventType\n ));\n shouldSetEventType = responderInst && \"topTouchCancel\" === topLevelType;\n if (\n (topLevelType =\n responderInst &&\n !shouldSetEventType &&\n (\"topTouchEnd\" === topLevelType || \"topTouchCancel\" === topLevelType))\n )\n a: {\n if ((topLevelType = nativeEvent.touches) && 0 !== topLevelType.length)\n for (\n JSCompiler_temp = 0;\n JSCompiler_temp < topLevelType.length;\n JSCompiler_temp++\n )\n if (\n ((targetInst = topLevelType[JSCompiler_temp].target),\n null !== targetInst &&\n void 0 !== targetInst &&\n 0 !== targetInst)\n ) {\n depthA = getInstanceFromNode(targetInst);\n b: {\n for (targetInst = responderInst; depthA; ) {\n if (\n targetInst === depthA ||\n targetInst === depthA.alternate\n ) {\n targetInst = !0;\n break b;\n }\n depthA = getParent(depthA);\n }\n targetInst = !1;\n }\n if (targetInst) {\n topLevelType = !1;\n break a;\n }\n }\n topLevelType = !0;\n }\n if (\n (topLevelType = shouldSetEventType\n ? eventTypes.responderTerminate\n : topLevelType\n ? eventTypes.responderRelease\n : null)\n )\n (nativeEvent = ResponderSyntheticEvent.getPooled(\n topLevelType,\n responderInst,\n nativeEvent,\n nativeEventTarget\n )),\n (nativeEvent.touchHistory = ResponderTouchHistoryStore.touchHistory),\n forEachAccumulated(nativeEvent, accumulateDirectDispatchesSingle),\n (JSCompiler_temp$jscomp$0 = accumulate(\n JSCompiler_temp$jscomp$0,\n nativeEvent\n )),\n changeResponder(null);\n return JSCompiler_temp$jscomp$0;\n },\n GlobalResponderHandler: null,\n injection: {\n injectGlobalResponderHandler: function(GlobalResponderHandler) {\n ResponderEventPlugin.GlobalResponderHandler = GlobalResponderHandler;\n }\n }\n },\n eventPluginOrder = null,\n namesToPlugins = {};\nfunction recomputePluginOrdering() {\n if (eventPluginOrder)\n for (var pluginName in namesToPlugins) {\n var pluginModule = namesToPlugins[pluginName],\n pluginIndex = eventPluginOrder.indexOf(pluginName);\n if (-1 >= pluginIndex)\n throw Error(\n \"EventPluginRegistry: Cannot inject event plugins that do not exist in the plugin ordering, `\" +\n (pluginName + \"`.\")\n );\n if (!plugins[pluginIndex]) {\n if (!pluginModule.extractEvents)\n throw Error(\n \"EventPluginRegistry: Event plugins must implement an `extractEvents` method, but `\" +\n (pluginName + \"` does not.\")\n );\n plugins[pluginIndex] = pluginModule;\n pluginIndex = pluginModule.eventTypes;\n for (var eventName in pluginIndex) {\n var JSCompiler_inline_result = void 0;\n var dispatchConfig = pluginIndex[eventName],\n eventName$jscomp$0 = eventName;\n if (eventNameDispatchConfigs.hasOwnProperty(eventName$jscomp$0))\n throw Error(\n \"EventPluginRegistry: More than one plugin attempted to publish the same event name, `\" +\n (eventName$jscomp$0 + \"`.\")\n );\n eventNameDispatchConfigs[eventName$jscomp$0] = dispatchConfig;\n var phasedRegistrationNames = dispatchConfig.phasedRegistrationNames;\n if (phasedRegistrationNames) {\n for (JSCompiler_inline_result in phasedRegistrationNames)\n phasedRegistrationNames.hasOwnProperty(\n JSCompiler_inline_result\n ) &&\n publishRegistrationName(\n phasedRegistrationNames[JSCompiler_inline_result],\n pluginModule,\n eventName$jscomp$0\n );\n JSCompiler_inline_result = !0;\n } else\n dispatchConfig.registrationName\n ? (publishRegistrationName(\n dispatchConfig.registrationName,\n pluginModule,\n eventName$jscomp$0\n ),\n (JSCompiler_inline_result = !0))\n : (JSCompiler_inline_result = !1);\n if (!JSCompiler_inline_result)\n throw Error(\n \"EventPluginRegistry: Failed to publish event `\" +\n eventName +\n \"` for plugin `\" +\n pluginName +\n \"`.\"\n );\n }\n }\n }\n}\nfunction publishRegistrationName(registrationName, pluginModule) {\n if (registrationNameModules[registrationName])\n throw Error(\n \"EventPluginRegistry: More than one plugin attempted to publish the same registration name, `\" +\n (registrationName + \"`.\")\n );\n registrationNameModules[registrationName] = pluginModule;\n}\nvar plugins = [],\n eventNameDispatchConfigs = {},\n registrationNameModules = {};\nfunction getListeners(\n inst,\n registrationName,\n phase,\n dispatchToImperativeListeners\n) {\n var stateNode = inst.stateNode;\n if (null === stateNode) return null;\n inst = getFiberCurrentPropsFromNode(stateNode);\n if (null === inst) return null;\n if ((inst = inst[registrationName]) && \"function\" !== typeof inst)\n throw Error(\n \"Expected `\" +\n registrationName +\n \"` listener to be a function, instead got a value of `\" +\n typeof inst +\n \"` type.\"\n );\n if (\n !(\n dispatchToImperativeListeners &&\n stateNode.canonical &&\n stateNode.canonical._eventListeners\n )\n )\n return inst;\n var listeners = [];\n inst && listeners.push(inst);\n var requestedPhaseIsCapture = \"captured\" === phase,\n mangledImperativeRegistrationName = requestedPhaseIsCapture\n ? \"rn:\" + registrationName.replace(/Capture$/, \"\")\n : \"rn:\" + registrationName;\n stateNode.canonical._eventListeners[mangledImperativeRegistrationName] &&\n 0 <\n stateNode.canonical._eventListeners[mangledImperativeRegistrationName]\n .length &&\n stateNode.canonical._eventListeners[\n mangledImperativeRegistrationName\n ].forEach(function(listenerObj) {\n if (\n (null != listenerObj.options.capture && listenerObj.options.capture) ===\n requestedPhaseIsCapture\n ) {\n var listenerFnWrapper = function(syntheticEvent) {\n var eventInst = new ReactNativePrivateInterface.CustomEvent(\n mangledImperativeRegistrationName,\n { detail: syntheticEvent.nativeEvent }\n );\n eventInst.isTrusted = !0;\n eventInst.setSyntheticEvent(syntheticEvent);\n for (\n var _len = arguments.length,\n args = Array(1 < _len ? _len - 1 : 0),\n _key = 1;\n _key < _len;\n _key++\n )\n args[_key - 1] = arguments[_key];\n listenerObj.listener.apply(listenerObj, [eventInst].concat(args));\n };\n listenerObj.options.once\n ? listeners.push(function() {\n stateNode.canonical.removeEventListener_unstable(\n mangledImperativeRegistrationName,\n listenerObj.listener,\n listenerObj.capture\n );\n listenerObj.invalidated ||\n ((listenerObj.invalidated = !0),\n listenerObj.listener.apply(listenerObj, arguments));\n })\n : listeners.push(listenerFnWrapper);\n }\n });\n return 0 === listeners.length\n ? null\n : 1 === listeners.length\n ? listeners[0]\n : listeners;\n}\nvar customBubblingEventTypes =\n ReactNativePrivateInterface.ReactNativeViewConfigRegistry\n .customBubblingEventTypes,\n customDirectEventTypes =\n ReactNativePrivateInterface.ReactNativeViewConfigRegistry\n .customDirectEventTypes;\nfunction accumulateListenersAndInstances(inst, event, listeners) {\n var listenersLength = listeners\n ? isArrayImpl(listeners)\n ? listeners.length\n : 1\n : 0;\n if (0 < listenersLength)\n if (\n ((event._dispatchListeners = accumulateInto(\n event._dispatchListeners,\n listeners\n )),\n null == event._dispatchInstances && 1 === listenersLength)\n )\n event._dispatchInstances = inst;\n else\n for (\n event._dispatchInstances = event._dispatchInstances || [],\n isArrayImpl(event._dispatchInstances) ||\n (event._dispatchInstances = [event._dispatchInstances]),\n listeners = 0;\n listeners < listenersLength;\n listeners++\n )\n event._dispatchInstances.push(inst);\n}\nfunction accumulateDirectionalDispatches$1(inst, phase, event) {\n phase = getListeners(\n inst,\n event.dispatchConfig.phasedRegistrationNames[phase],\n phase,\n !0\n );\n accumulateListenersAndInstances(inst, event, phase);\n}\nfunction traverseTwoPhase$1(inst, fn, arg, skipBubbling) {\n for (var path = []; inst; ) {\n path.push(inst);\n do inst = inst.return;\n while (inst && 5 !== inst.tag);\n inst = inst ? inst : null;\n }\n for (inst = path.length; 0 < inst--; ) fn(path[inst], \"captured\", arg);\n if (skipBubbling) fn(path[0], \"bubbled\", arg);\n else\n for (inst = 0; inst < path.length; inst++) fn(path[inst], \"bubbled\", arg);\n}\nfunction accumulateTwoPhaseDispatchesSingle$1(event) {\n event &&\n event.dispatchConfig.phasedRegistrationNames &&\n traverseTwoPhase$1(\n event._targetInst,\n accumulateDirectionalDispatches$1,\n event,\n !1\n );\n}\nfunction accumulateDirectDispatchesSingle$1(event) {\n if (event && event.dispatchConfig.registrationName) {\n var inst = event._targetInst;\n if (inst && event && event.dispatchConfig.registrationName) {\n var listeners = getListeners(\n inst,\n event.dispatchConfig.registrationName,\n \"bubbled\",\n !1\n );\n accumulateListenersAndInstances(inst, event, listeners);\n }\n }\n}\nif (eventPluginOrder)\n throw Error(\n \"EventPluginRegistry: Cannot inject event plugin ordering more than once. You are likely trying to load more than one copy of React.\"\n );\neventPluginOrder = Array.prototype.slice.call([\n \"ResponderEventPlugin\",\n \"ReactNativeBridgeEventPlugin\"\n]);\nrecomputePluginOrdering();\nvar injectedNamesToPlugins$jscomp$inline_229 = {\n ResponderEventPlugin: ResponderEventPlugin,\n ReactNativeBridgeEventPlugin: {\n eventTypes: {},\n extractEvents: function(\n topLevelType,\n targetInst,\n nativeEvent,\n nativeEventTarget\n ) {\n if (null == targetInst) return null;\n var bubbleDispatchConfig = customBubblingEventTypes[topLevelType],\n directDispatchConfig = customDirectEventTypes[topLevelType];\n if (!bubbleDispatchConfig && !directDispatchConfig)\n throw Error(\n 'Unsupported top level event type \"' + topLevelType + '\" dispatched'\n );\n topLevelType = SyntheticEvent.getPooled(\n bubbleDispatchConfig || directDispatchConfig,\n targetInst,\n nativeEvent,\n nativeEventTarget\n );\n if (bubbleDispatchConfig)\n null != topLevelType &&\n null != topLevelType.dispatchConfig.phasedRegistrationNames &&\n topLevelType.dispatchConfig.phasedRegistrationNames.skipBubbling\n ? topLevelType &&\n topLevelType.dispatchConfig.phasedRegistrationNames &&\n traverseTwoPhase$1(\n topLevelType._targetInst,\n accumulateDirectionalDispatches$1,\n topLevelType,\n !0\n )\n : forEachAccumulated(\n topLevelType,\n accumulateTwoPhaseDispatchesSingle$1\n );\n else if (directDispatchConfig)\n forEachAccumulated(topLevelType, accumulateDirectDispatchesSingle$1);\n else return null;\n return topLevelType;\n }\n }\n },\n isOrderingDirty$jscomp$inline_230 = !1,\n pluginName$jscomp$inline_231;\nfor (pluginName$jscomp$inline_231 in injectedNamesToPlugins$jscomp$inline_229)\n if (\n injectedNamesToPlugins$jscomp$inline_229.hasOwnProperty(\n pluginName$jscomp$inline_231\n )\n ) {\n var pluginModule$jscomp$inline_232 =\n injectedNamesToPlugins$jscomp$inline_229[pluginName$jscomp$inline_231];\n if (\n !namesToPlugins.hasOwnProperty(pluginName$jscomp$inline_231) ||\n namesToPlugins[pluginName$jscomp$inline_231] !==\n pluginModule$jscomp$inline_232\n ) {\n if (namesToPlugins[pluginName$jscomp$inline_231])\n throw Error(\n \"EventPluginRegistry: Cannot inject two different event plugins using the same name, `\" +\n (pluginName$jscomp$inline_231 + \"`.\")\n );\n namesToPlugins[\n pluginName$jscomp$inline_231\n ] = pluginModule$jscomp$inline_232;\n isOrderingDirty$jscomp$inline_230 = !0;\n }\n }\nisOrderingDirty$jscomp$inline_230 && recomputePluginOrdering();\nvar instanceCache = new Map(),\n instanceProps = new Map();\nfunction getInstanceFromTag(tag) {\n return instanceCache.get(tag) || null;\n}\nfunction batchedUpdatesImpl(fn, bookkeeping) {\n return fn(bookkeeping);\n}\nvar isInsideEventHandler = !1;\nfunction batchedUpdates(fn, bookkeeping) {\n if (isInsideEventHandler) return fn(bookkeeping);\n isInsideEventHandler = !0;\n try {\n return batchedUpdatesImpl(fn, bookkeeping);\n } finally {\n isInsideEventHandler = !1;\n }\n}\nvar eventQueue = null;\nfunction executeDispatchesAndReleaseTopLevel(e) {\n if (e) {\n var dispatchListeners = e._dispatchListeners,\n dispatchInstances = e._dispatchInstances;\n if (isArrayImpl(dispatchListeners))\n for (\n var i = 0;\n i < dispatchListeners.length && !e.isPropagationStopped();\n i++\n )\n executeDispatch(e, dispatchListeners[i], dispatchInstances[i]);\n else\n dispatchListeners &&\n executeDispatch(e, dispatchListeners, dispatchInstances);\n e._dispatchListeners = null;\n e._dispatchInstances = null;\n e.isPersistent() || e.constructor.release(e);\n }\n}\nvar EMPTY_NATIVE_EVENT = {};\nfunction _receiveRootNodeIDEvent(rootNodeID, topLevelType, nativeEventParam) {\n var nativeEvent = nativeEventParam || EMPTY_NATIVE_EVENT,\n inst = getInstanceFromTag(rootNodeID),\n target = null;\n null != inst && (target = inst.stateNode);\n batchedUpdates(function() {\n var JSCompiler_inline_result = target;\n for (\n var events = null, legacyPlugins = plugins, i = 0;\n i < legacyPlugins.length;\n i++\n ) {\n var possiblePlugin = legacyPlugins[i];\n possiblePlugin &&\n (possiblePlugin = possiblePlugin.extractEvents(\n topLevelType,\n inst,\n nativeEvent,\n JSCompiler_inline_result\n )) &&\n (events = accumulateInto(events, possiblePlugin));\n }\n JSCompiler_inline_result = events;\n null !== JSCompiler_inline_result &&\n (eventQueue = accumulateInto(eventQueue, JSCompiler_inline_result));\n JSCompiler_inline_result = eventQueue;\n eventQueue = null;\n if (JSCompiler_inline_result) {\n forEachAccumulated(\n JSCompiler_inline_result,\n executeDispatchesAndReleaseTopLevel\n );\n if (eventQueue)\n throw Error(\n \"processEventQueue(): Additional events were enqueued while processing an event queue. Support for this has not yet been implemented.\"\n );\n if (hasRethrowError)\n throw ((JSCompiler_inline_result = rethrowError),\n (hasRethrowError = !1),\n (rethrowError = null),\n JSCompiler_inline_result);\n }\n });\n}\nReactNativePrivateInterface.RCTEventEmitter.register({\n receiveEvent: function(rootNodeID, topLevelType, nativeEventParam) {\n _receiveRootNodeIDEvent(rootNodeID, topLevelType, nativeEventParam);\n },\n receiveTouches: function(eventTopLevelType, touches, changedIndices) {\n if (\n \"topTouchEnd\" === eventTopLevelType ||\n \"topTouchCancel\" === eventTopLevelType\n ) {\n var JSCompiler_temp = [];\n for (var i = 0; i < changedIndices.length; i++) {\n var index$0 = changedIndices[i];\n JSCompiler_temp.push(touches[index$0]);\n touches[index$0] = null;\n }\n for (i = changedIndices = 0; i < touches.length; i++)\n (index$0 = touches[i]),\n null !== index$0 && (touches[changedIndices++] = index$0);\n touches.length = changedIndices;\n } else\n for (JSCompiler_temp = [], i = 0; i < changedIndices.length; i++)\n JSCompiler_temp.push(touches[changedIndices[i]]);\n for (\n changedIndices = 0;\n changedIndices < JSCompiler_temp.length;\n changedIndices++\n ) {\n i = JSCompiler_temp[changedIndices];\n i.changedTouches = JSCompiler_temp;\n i.touches = touches;\n index$0 = null;\n var target = i.target;\n null === target || void 0 === target || 1 > target || (index$0 = target);\n _receiveRootNodeIDEvent(index$0, eventTopLevelType, i);\n }\n }\n});\ngetFiberCurrentPropsFromNode = function(stateNode) {\n return instanceProps.get(stateNode._nativeTag) || null;\n};\ngetInstanceFromNode = getInstanceFromTag;\ngetNodeFromInstance = function(inst) {\n inst = inst.stateNode;\n var tag = inst._nativeTag;\n void 0 === tag && ((inst = inst.canonical), (tag = inst._nativeTag));\n if (!tag) throw Error(\"All native instances should have a tag.\");\n return inst;\n};\nResponderEventPlugin.injection.injectGlobalResponderHandler({\n onChange: function(from, to, blockNativeResponder) {\n null !== to\n ? ReactNativePrivateInterface.UIManager.setJSResponder(\n to.stateNode._nativeTag,\n blockNativeResponder\n )\n : ReactNativePrivateInterface.UIManager.clearJSResponder();\n }\n});\nvar ReactSharedInternals =\n React.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED,\n REACT_ELEMENT_TYPE = Symbol.for(\"react.element\"),\n REACT_PORTAL_TYPE = Symbol.for(\"react.portal\"),\n REACT_FRAGMENT_TYPE = Symbol.for(\"react.fragment\"),\n REACT_STRICT_MODE_TYPE = Symbol.for(\"react.strict_mode\"),\n REACT_PROFILER_TYPE = Symbol.for(\"react.profiler\"),\n REACT_PROVIDER_TYPE = Symbol.for(\"react.provider\"),\n REACT_CONTEXT_TYPE = Symbol.for(\"react.context\"),\n REACT_FORWARD_REF_TYPE = Symbol.for(\"react.forward_ref\"),\n REACT_SUSPENSE_TYPE = Symbol.for(\"react.suspense\"),\n REACT_SUSPENSE_LIST_TYPE = Symbol.for(\"react.suspense_list\"),\n REACT_MEMO_TYPE = Symbol.for(\"react.memo\"),\n REACT_LAZY_TYPE = Symbol.for(\"react.lazy\");\nSymbol.for(\"react.scope\");\nSymbol.for(\"react.debug_trace_mode\");\nvar REACT_OFFSCREEN_TYPE = Symbol.for(\"react.offscreen\");\nSymbol.for(\"react.legacy_hidden\");\nSymbol.for(\"react.cache\");\nSymbol.for(\"react.tracing_marker\");\nvar MAYBE_ITERATOR_SYMBOL = Symbol.iterator;\nfunction getIteratorFn(maybeIterable) {\n if (null === maybeIterable || \"object\" !== typeof maybeIterable) return null;\n maybeIterable =\n (MAYBE_ITERATOR_SYMBOL && maybeIterable[MAYBE_ITERATOR_SYMBOL]) ||\n maybeIterable[\"@@iterator\"];\n return \"function\" === typeof maybeIterable ? maybeIterable : null;\n}\nfunction getComponentNameFromType(type) {\n if (null == type) return null;\n if (\"function\" === typeof type) return type.displayName || type.name || null;\n if (\"string\" === typeof type) return type;\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 (\"object\" === typeof type)\n switch (type.$$typeof) {\n case REACT_CONTEXT_TYPE:\n return (type.displayName || \"Context\") + \".Consumer\";\n case REACT_PROVIDER_TYPE:\n return (type._context.displayName || \"Context\") + \".Provider\";\n case REACT_FORWARD_REF_TYPE:\n var innerType = type.render;\n type = type.displayName;\n type ||\n ((type = innerType.displayName || innerType.name || \"\"),\n (type = \"\" !== type ? \"ForwardRef(\" + type + \")\" : \"ForwardRef\"));\n return type;\n case REACT_MEMO_TYPE:\n return (\n (innerType = type.displayName || null),\n null !== innerType\n ? innerType\n : getComponentNameFromType(type.type) || \"Memo\"\n );\n case REACT_LAZY_TYPE:\n innerType = type._payload;\n type = type._init;\n try {\n return getComponentNameFromType(type(innerType));\n } catch (x) {}\n }\n return null;\n}\nfunction getComponentNameFromFiber(fiber) {\n var type = fiber.type;\n switch (fiber.tag) {\n case 24:\n return \"Cache\";\n case 9:\n return (type.displayName || \"Context\") + \".Consumer\";\n case 10:\n return (type._context.displayName || \"Context\") + \".Provider\";\n case 18:\n return \"DehydratedFragment\";\n case 11:\n return (\n (fiber = type.render),\n (fiber = fiber.displayName || fiber.name || \"\"),\n type.displayName ||\n (\"\" !== fiber ? \"ForwardRef(\" + fiber + \")\" : \"ForwardRef\")\n );\n case 7:\n return \"Fragment\";\n case 5:\n return type;\n case 4:\n return \"Portal\";\n case 3:\n return \"Root\";\n case 6:\n return \"Text\";\n case 16:\n return getComponentNameFromType(type);\n case 8:\n return type === REACT_STRICT_MODE_TYPE ? \"StrictMode\" : \"Mode\";\n case 22:\n return \"Offscreen\";\n case 12:\n return \"Profiler\";\n case 21:\n return \"Scope\";\n case 13:\n return \"Suspense\";\n case 19:\n return \"SuspenseList\";\n case 25:\n return \"TracingMarker\";\n case 1:\n case 0:\n case 17:\n case 2:\n case 14:\n case 15:\n if (\"function\" === typeof type)\n return type.displayName || type.name || null;\n if (\"string\" === typeof type) return type;\n }\n return null;\n}\nfunction getNearestMountedFiber(fiber) {\n var node = fiber,\n nearestMounted = fiber;\n if (fiber.alternate) for (; node.return; ) node = node.return;\n else {\n fiber = node;\n do\n (node = fiber),\n 0 !== (node.flags & 4098) && (nearestMounted = node.return),\n (fiber = node.return);\n while (fiber);\n }\n return 3 === node.tag ? nearestMounted : null;\n}\nfunction assertIsMounted(fiber) {\n if (getNearestMountedFiber(fiber) !== fiber)\n throw Error(\"Unable to find node on an unmounted component.\");\n}\nfunction findCurrentFiberUsingSlowPath(fiber) {\n var alternate = fiber.alternate;\n if (!alternate) {\n alternate = getNearestMountedFiber(fiber);\n if (null === alternate)\n throw Error(\"Unable to find node on an unmounted component.\");\n return alternate !== fiber ? null : fiber;\n }\n for (var a = fiber, b = alternate; ; ) {\n var parentA = a.return;\n if (null === parentA) break;\n var parentB = parentA.alternate;\n if (null === parentB) {\n b = parentA.return;\n if (null !== b) {\n a = b;\n continue;\n }\n break;\n }\n if (parentA.child === parentB.child) {\n for (parentB = parentA.child; parentB; ) {\n if (parentB === a) return assertIsMounted(parentA), fiber;\n if (parentB === b) return assertIsMounted(parentA), alternate;\n parentB = parentB.sibling;\n }\n throw Error(\"Unable to find node on an unmounted component.\");\n }\n if (a.return !== b.return) (a = parentA), (b = parentB);\n else {\n for (var didFindChild = !1, child$1 = parentA.child; child$1; ) {\n if (child$1 === a) {\n didFindChild = !0;\n a = parentA;\n b = parentB;\n break;\n }\n if (child$1 === b) {\n didFindChild = !0;\n b = parentA;\n a = parentB;\n break;\n }\n child$1 = child$1.sibling;\n }\n if (!didFindChild) {\n for (child$1 = parentB.child; child$1; ) {\n if (child$1 === a) {\n didFindChild = !0;\n a = parentB;\n b = parentA;\n break;\n }\n if (child$1 === b) {\n didFindChild = !0;\n b = parentB;\n a = parentA;\n break;\n }\n child$1 = child$1.sibling;\n }\n if (!didFindChild)\n throw Error(\n \"Child was not found in either parent set. This indicates a bug in React related to the return pointer. Please file an issue.\"\n );\n }\n }\n if (a.alternate !== b)\n throw Error(\n \"Return fibers should always be each others' alternates. This error is likely caused by a bug in React. Please file an issue.\"\n );\n }\n if (3 !== a.tag)\n throw Error(\"Unable to find node on an unmounted component.\");\n return a.stateNode.current === a ? fiber : alternate;\n}\nfunction findCurrentHostFiber(parent) {\n parent = findCurrentFiberUsingSlowPath(parent);\n return null !== parent ? findCurrentHostFiberImpl(parent) : null;\n}\nfunction findCurrentHostFiberImpl(node) {\n if (5 === node.tag || 6 === node.tag) return node;\n for (node = node.child; null !== node; ) {\n var match = findCurrentHostFiberImpl(node);\n if (null !== match) return match;\n node = node.sibling;\n }\n return null;\n}\nvar emptyObject = {},\n removedKeys = null,\n removedKeyCount = 0,\n deepDifferOptions = { unsafelyIgnoreFunctions: !0 };\nfunction defaultDiffer(prevProp, nextProp) {\n return \"object\" !== typeof nextProp || null === nextProp\n ? !0\n : ReactNativePrivateInterface.deepDiffer(\n prevProp,\n nextProp,\n deepDifferOptions\n );\n}\nfunction restoreDeletedValuesInNestedArray(\n updatePayload,\n node,\n validAttributes\n) {\n if (isArrayImpl(node))\n for (var i = node.length; i-- && 0 < removedKeyCount; )\n restoreDeletedValuesInNestedArray(\n updatePayload,\n node[i],\n validAttributes\n );\n else if (node && 0 < removedKeyCount)\n for (i in removedKeys)\n if (removedKeys[i]) {\n var nextProp = node[i];\n if (void 0 !== nextProp) {\n var attributeConfig = validAttributes[i];\n if (attributeConfig) {\n \"function\" === typeof nextProp && (nextProp = !0);\n \"undefined\" === typeof nextProp && (nextProp = null);\n if (\"object\" !== typeof attributeConfig)\n updatePayload[i] = nextProp;\n else if (\n \"function\" === typeof attributeConfig.diff ||\n \"function\" === typeof attributeConfig.process\n )\n (nextProp =\n \"function\" === typeof attributeConfig.process\n ? attributeConfig.process(nextProp)\n : nextProp),\n (updatePayload[i] = nextProp);\n removedKeys[i] = !1;\n removedKeyCount--;\n }\n }\n }\n}\nfunction diffNestedProperty(\n updatePayload,\n prevProp,\n nextProp,\n validAttributes\n) {\n if (!updatePayload && prevProp === nextProp) return updatePayload;\n if (!prevProp || !nextProp)\n return nextProp\n ? addNestedProperty(updatePayload, nextProp, validAttributes)\n : prevProp\n ? clearNestedProperty(updatePayload, prevProp, validAttributes)\n : updatePayload;\n if (!isArrayImpl(prevProp) && !isArrayImpl(nextProp))\n return diffProperties(updatePayload, prevProp, nextProp, validAttributes);\n if (isArrayImpl(prevProp) && isArrayImpl(nextProp)) {\n var minLength =\n prevProp.length < nextProp.length ? prevProp.length : nextProp.length,\n i;\n for (i = 0; i < minLength; i++)\n updatePayload = diffNestedProperty(\n updatePayload,\n prevProp[i],\n nextProp[i],\n validAttributes\n );\n for (; i < prevProp.length; i++)\n updatePayload = clearNestedProperty(\n updatePayload,\n prevProp[i],\n validAttributes\n );\n for (; i < nextProp.length; i++)\n updatePayload = addNestedProperty(\n updatePayload,\n nextProp[i],\n validAttributes\n );\n return updatePayload;\n }\n return isArrayImpl(prevProp)\n ? diffProperties(\n updatePayload,\n ReactNativePrivateInterface.flattenStyle(prevProp),\n nextProp,\n validAttributes\n )\n : diffProperties(\n updatePayload,\n prevProp,\n ReactNativePrivateInterface.flattenStyle(nextProp),\n validAttributes\n );\n}\nfunction addNestedProperty(updatePayload, nextProp, validAttributes) {\n if (!nextProp) return updatePayload;\n if (!isArrayImpl(nextProp))\n return diffProperties(\n updatePayload,\n emptyObject,\n nextProp,\n validAttributes\n );\n for (var i = 0; i < nextProp.length; i++)\n updatePayload = addNestedProperty(\n updatePayload,\n nextProp[i],\n validAttributes\n );\n return updatePayload;\n}\nfunction clearNestedProperty(updatePayload, prevProp, validAttributes) {\n if (!prevProp) return updatePayload;\n if (!isArrayImpl(prevProp))\n return diffProperties(\n updatePayload,\n prevProp,\n emptyObject,\n validAttributes\n );\n for (var i = 0; i < prevProp.length; i++)\n updatePayload = clearNestedProperty(\n updatePayload,\n prevProp[i],\n validAttributes\n );\n return updatePayload;\n}\nfunction diffProperties(updatePayload, prevProps, nextProps, validAttributes) {\n var attributeConfig, propKey;\n for (propKey in nextProps)\n if ((attributeConfig = validAttributes[propKey])) {\n var prevProp = prevProps[propKey];\n var nextProp = nextProps[propKey];\n \"function\" === typeof nextProp &&\n ((nextProp = !0), \"function\" === typeof prevProp && (prevProp = !0));\n \"undefined\" === typeof nextProp &&\n ((nextProp = null),\n \"undefined\" === typeof prevProp && (prevProp = null));\n removedKeys && (removedKeys[propKey] = !1);\n if (updatePayload && void 0 !== updatePayload[propKey])\n if (\"object\" !== typeof attributeConfig)\n updatePayload[propKey] = nextProp;\n else {\n if (\n \"function\" === typeof attributeConfig.diff ||\n \"function\" === typeof attributeConfig.process\n )\n (attributeConfig =\n \"function\" === typeof attributeConfig.process\n ? attributeConfig.process(nextProp)\n : nextProp),\n (updatePayload[propKey] = attributeConfig);\n }\n else if (prevProp !== nextProp)\n if (\"object\" !== typeof attributeConfig)\n defaultDiffer(prevProp, nextProp) &&\n ((updatePayload || (updatePayload = {}))[propKey] = nextProp);\n else if (\n \"function\" === typeof attributeConfig.diff ||\n \"function\" === typeof attributeConfig.process\n ) {\n if (\n void 0 === prevProp ||\n (\"function\" === typeof attributeConfig.diff\n ? attributeConfig.diff(prevProp, nextProp)\n : defaultDiffer(prevProp, nextProp))\n )\n (attributeConfig =\n \"function\" === typeof attributeConfig.process\n ? attributeConfig.process(nextProp)\n : nextProp),\n ((updatePayload || (updatePayload = {}))[\n propKey\n ] = attributeConfig);\n } else\n (removedKeys = null),\n (removedKeyCount = 0),\n (updatePayload = diffNestedProperty(\n updatePayload,\n prevProp,\n nextProp,\n attributeConfig\n )),\n 0 < removedKeyCount &&\n updatePayload &&\n (restoreDeletedValuesInNestedArray(\n updatePayload,\n nextProp,\n attributeConfig\n ),\n (removedKeys = null));\n }\n for (var propKey$3 in prevProps)\n void 0 === nextProps[propKey$3] &&\n (!(attributeConfig = validAttributes[propKey$3]) ||\n (updatePayload && void 0 !== updatePayload[propKey$3]) ||\n ((prevProp = prevProps[propKey$3]),\n void 0 !== prevProp &&\n (\"object\" !== typeof attributeConfig ||\n \"function\" === typeof attributeConfig.diff ||\n \"function\" === typeof attributeConfig.process\n ? (((updatePayload || (updatePayload = {}))[propKey$3] = null),\n removedKeys || (removedKeys = {}),\n removedKeys[propKey$3] ||\n ((removedKeys[propKey$3] = !0), removedKeyCount++))\n : (updatePayload = clearNestedProperty(\n updatePayload,\n prevProp,\n attributeConfig\n )))));\n return updatePayload;\n}\nfunction mountSafeCallback_NOT_REALLY_SAFE(context, callback) {\n return function() {\n if (\n callback &&\n (\"boolean\" !== typeof context.__isMounted || context.__isMounted)\n )\n return callback.apply(context, arguments);\n };\n}\nvar ReactNativeFiberHostComponent = (function() {\n function ReactNativeFiberHostComponent(tag, viewConfig) {\n this._nativeTag = tag;\n this._children = [];\n this.viewConfig = viewConfig;\n }\n var _proto = ReactNativeFiberHostComponent.prototype;\n _proto.blur = function() {\n ReactNativePrivateInterface.TextInputState.blurTextInput(this);\n };\n _proto.focus = function() {\n ReactNativePrivateInterface.TextInputState.focusTextInput(this);\n };\n _proto.measure = function(callback) {\n ReactNativePrivateInterface.UIManager.measure(\n this._nativeTag,\n mountSafeCallback_NOT_REALLY_SAFE(this, callback)\n );\n };\n _proto.measureInWindow = function(callback) {\n ReactNativePrivateInterface.UIManager.measureInWindow(\n this._nativeTag,\n mountSafeCallback_NOT_REALLY_SAFE(this, callback)\n );\n };\n _proto.measureLayout = function(relativeToNativeNode, onSuccess, onFail) {\n if (\"number\" === typeof relativeToNativeNode)\n var relativeNode = relativeToNativeNode;\n else\n relativeToNativeNode._nativeTag &&\n (relativeNode = relativeToNativeNode._nativeTag);\n null != relativeNode &&\n ReactNativePrivateInterface.UIManager.measureLayout(\n this._nativeTag,\n relativeNode,\n mountSafeCallback_NOT_REALLY_SAFE(this, onFail),\n mountSafeCallback_NOT_REALLY_SAFE(this, onSuccess)\n );\n };\n _proto.setNativeProps = function(nativeProps) {\n nativeProps = diffProperties(\n null,\n emptyObject,\n nativeProps,\n this.viewConfig.validAttributes\n );\n null != nativeProps &&\n ReactNativePrivateInterface.UIManager.updateView(\n this._nativeTag,\n this.viewConfig.uiViewClassName,\n nativeProps\n );\n };\n return ReactNativeFiberHostComponent;\n })(),\n scheduleCallback = Scheduler.unstable_scheduleCallback,\n cancelCallback = Scheduler.unstable_cancelCallback,\n shouldYield = Scheduler.unstable_shouldYield,\n requestPaint = Scheduler.unstable_requestPaint,\n now = Scheduler.unstable_now,\n ImmediatePriority = Scheduler.unstable_ImmediatePriority,\n UserBlockingPriority = Scheduler.unstable_UserBlockingPriority,\n NormalPriority = Scheduler.unstable_NormalPriority,\n IdlePriority = Scheduler.unstable_IdlePriority,\n rendererID = null,\n injectedHook = null;\nfunction onCommitRoot(root) {\n if (injectedHook && \"function\" === typeof injectedHook.onCommitFiberRoot)\n try {\n injectedHook.onCommitFiberRoot(\n rendererID,\n root,\n void 0,\n 128 === (root.current.flags & 128)\n );\n } catch (err) {}\n}\nvar clz32 = Math.clz32 ? Math.clz32 : clz32Fallback,\n log = Math.log,\n LN2 = Math.LN2;\nfunction clz32Fallback(x) {\n x >>>= 0;\n return 0 === x ? 32 : (31 - ((log(x) / LN2) | 0)) | 0;\n}\nvar nextTransitionLane = 64,\n nextRetryLane = 4194304;\nfunction getHighestPriorityLanes(lanes) {\n switch (lanes & -lanes) {\n case 1:\n return 1;\n case 2:\n return 2;\n case 4:\n return 4;\n case 8:\n return 8;\n case 16:\n return 16;\n case 32:\n return 32;\n case 64:\n case 128:\n case 256:\n case 512:\n case 1024:\n case 2048:\n case 4096:\n case 8192:\n case 16384:\n case 32768:\n case 65536:\n case 131072:\n case 262144:\n case 524288:\n case 1048576:\n case 2097152:\n return lanes & 4194240;\n case 4194304:\n case 8388608:\n case 16777216:\n case 33554432:\n case 67108864:\n return lanes & 130023424;\n case 134217728:\n return 134217728;\n case 268435456:\n return 268435456;\n case 536870912:\n return 536870912;\n case 1073741824:\n return 1073741824;\n default:\n return lanes;\n }\n}\nfunction getNextLanes(root, wipLanes) {\n var pendingLanes = root.pendingLanes;\n if (0 === pendingLanes) return 0;\n var nextLanes = 0,\n suspendedLanes = root.suspendedLanes,\n pingedLanes = root.pingedLanes,\n nonIdlePendingLanes = pendingLanes & 268435455;\n if (0 !== nonIdlePendingLanes) {\n var nonIdleUnblockedLanes = nonIdlePendingLanes & ~suspendedLanes;\n 0 !== nonIdleUnblockedLanes\n ? (nextLanes = getHighestPriorityLanes(nonIdleUnblockedLanes))\n : ((pingedLanes &= nonIdlePendingLanes),\n 0 !== pingedLanes &&\n (nextLanes = getHighestPriorityLanes(pingedLanes)));\n } else\n (nonIdlePendingLanes = pendingLanes & ~suspendedLanes),\n 0 !== nonIdlePendingLanes\n ? (nextLanes = getHighestPriorityLanes(nonIdlePendingLanes))\n : 0 !== pingedLanes &&\n (nextLanes = getHighestPriorityLanes(pingedLanes));\n if (0 === nextLanes) return 0;\n if (\n 0 !== wipLanes &&\n wipLanes !== nextLanes &&\n 0 === (wipLanes & suspendedLanes) &&\n ((suspendedLanes = nextLanes & -nextLanes),\n (pingedLanes = wipLanes & -wipLanes),\n suspendedLanes >= pingedLanes ||\n (16 === suspendedLanes && 0 !== (pingedLanes & 4194240)))\n )\n return wipLanes;\n 0 !== (nextLanes & 4) && (nextLanes |= pendingLanes & 16);\n wipLanes = root.entangledLanes;\n if (0 !== wipLanes)\n for (root = root.entanglements, wipLanes &= nextLanes; 0 < wipLanes; )\n (pendingLanes = 31 - clz32(wipLanes)),\n (suspendedLanes = 1 << pendingLanes),\n (nextLanes |= root[pendingLanes]),\n (wipLanes &= ~suspendedLanes);\n return nextLanes;\n}\nfunction computeExpirationTime(lane, currentTime) {\n switch (lane) {\n case 1:\n case 2:\n case 4:\n return currentTime + 250;\n case 8:\n case 16:\n case 32:\n case 64:\n case 128:\n case 256:\n case 512:\n case 1024:\n case 2048:\n case 4096:\n case 8192:\n case 16384:\n case 32768:\n case 65536:\n case 131072:\n case 262144:\n case 524288:\n case 1048576:\n case 2097152:\n return currentTime + 5e3;\n case 4194304:\n case 8388608:\n case 16777216:\n case 33554432:\n case 67108864:\n return -1;\n case 134217728:\n case 268435456:\n case 536870912:\n case 1073741824:\n return -1;\n default:\n return -1;\n }\n}\nfunction getLanesToRetrySynchronouslyOnError(root) {\n root = root.pendingLanes & -1073741825;\n return 0 !== root ? root : root & 1073741824 ? 1073741824 : 0;\n}\nfunction claimNextTransitionLane() {\n var lane = nextTransitionLane;\n nextTransitionLane <<= 1;\n 0 === (nextTransitionLane & 4194240) && (nextTransitionLane = 64);\n return lane;\n}\nfunction createLaneMap(initial) {\n for (var laneMap = [], i = 0; 31 > i; i++) laneMap.push(initial);\n return laneMap;\n}\nfunction markRootUpdated(root, updateLane, eventTime) {\n root.pendingLanes |= updateLane;\n 536870912 !== updateLane &&\n ((root.suspendedLanes = 0), (root.pingedLanes = 0));\n root = root.eventTimes;\n updateLane = 31 - clz32(updateLane);\n root[updateLane] = eventTime;\n}\nfunction markRootFinished(root, remainingLanes) {\n var noLongerPendingLanes = root.pendingLanes & ~remainingLanes;\n root.pendingLanes = remainingLanes;\n root.suspendedLanes = 0;\n root.pingedLanes = 0;\n root.expiredLanes &= remainingLanes;\n root.mutableReadLanes &= remainingLanes;\n root.entangledLanes &= remainingLanes;\n remainingLanes = root.entanglements;\n var eventTimes = root.eventTimes;\n for (root = root.expirationTimes; 0 < noLongerPendingLanes; ) {\n var index$8 = 31 - clz32(noLongerPendingLanes),\n lane = 1 << index$8;\n remainingLanes[index$8] = 0;\n eventTimes[index$8] = -1;\n root[index$8] = -1;\n noLongerPendingLanes &= ~lane;\n }\n}\nfunction markRootEntangled(root, entangledLanes) {\n var rootEntangledLanes = (root.entangledLanes |= entangledLanes);\n for (root = root.entanglements; rootEntangledLanes; ) {\n var index$9 = 31 - clz32(rootEntangledLanes),\n lane = 1 << index$9;\n (lane & entangledLanes) | (root[index$9] & entangledLanes) &&\n (root[index$9] |= entangledLanes);\n rootEntangledLanes &= ~lane;\n }\n}\nvar currentUpdatePriority = 0;\nfunction lanesToEventPriority(lanes) {\n lanes &= -lanes;\n return 1 < lanes\n ? 4 < lanes\n ? 0 !== (lanes & 268435455)\n ? 16\n : 536870912\n : 4\n : 1;\n}\nfunction shim() {\n throw Error(\n \"The current renderer does not support hydration. This error is likely caused by a bug in React. Please file an issue.\"\n );\n}\nvar getViewConfigForType =\n ReactNativePrivateInterface.ReactNativeViewConfigRegistry.get,\n UPDATE_SIGNAL = {},\n nextReactTag = 3;\nfunction allocateTag() {\n var tag = nextReactTag;\n 1 === tag % 10 && (tag += 2);\n nextReactTag = tag + 2;\n return tag;\n}\nfunction recursivelyUncacheFiberNode(node) {\n if (\"number\" === typeof node)\n instanceCache.delete(node), instanceProps.delete(node);\n else {\n var tag = node._nativeTag;\n instanceCache.delete(tag);\n instanceProps.delete(tag);\n node._children.forEach(recursivelyUncacheFiberNode);\n }\n}\nfunction finalizeInitialChildren(parentInstance) {\n if (0 === parentInstance._children.length) return !1;\n var nativeTags = parentInstance._children.map(function(child) {\n return \"number\" === typeof child ? child : child._nativeTag;\n });\n ReactNativePrivateInterface.UIManager.setChildren(\n parentInstance._nativeTag,\n nativeTags\n );\n return !1;\n}\nvar scheduleTimeout = setTimeout,\n cancelTimeout = clearTimeout;\nfunction describeComponentFrame(name, source, ownerName) {\n source = \"\";\n ownerName && (source = \" (created by \" + ownerName + \")\");\n return \"\\n in \" + (name || \"Unknown\") + source;\n}\nfunction describeFunctionComponentFrame(fn, source) {\n return fn\n ? describeComponentFrame(fn.displayName || fn.name || null, source, null)\n : \"\";\n}\nvar hasOwnProperty = Object.prototype.hasOwnProperty,\n valueStack = [],\n index = -1;\nfunction createCursor(defaultValue) {\n return { current: defaultValue };\n}\nfunction pop(cursor) {\n 0 > index ||\n ((cursor.current = valueStack[index]), (valueStack[index] = null), index--);\n}\nfunction push(cursor, value) {\n index++;\n valueStack[index] = cursor.current;\n cursor.current = value;\n}\nvar emptyContextObject = {},\n contextStackCursor = createCursor(emptyContextObject),\n didPerformWorkStackCursor = createCursor(!1),\n previousContext = emptyContextObject;\nfunction getMaskedContext(workInProgress, unmaskedContext) {\n var contextTypes = workInProgress.type.contextTypes;\n if (!contextTypes) return emptyContextObject;\n var instance = workInProgress.stateNode;\n if (\n instance &&\n instance.__reactInternalMemoizedUnmaskedChildContext === unmaskedContext\n )\n return instance.__reactInternalMemoizedMaskedChildContext;\n var context = {},\n key;\n for (key in contextTypes) context[key] = unmaskedContext[key];\n instance &&\n ((workInProgress = workInProgress.stateNode),\n (workInProgress.__reactInternalMemoizedUnmaskedChildContext = unmaskedContext),\n (workInProgress.__reactInternalMemoizedMaskedChildContext = context));\n return context;\n}\nfunction isContextProvider(type) {\n type = type.childContextTypes;\n return null !== type && void 0 !== type;\n}\nfunction popContext() {\n pop(didPerformWorkStackCursor);\n pop(contextStackCursor);\n}\nfunction pushTopLevelContextObject(fiber, context, didChange) {\n if (contextStackCursor.current !== emptyContextObject)\n throw Error(\n \"Unexpected context found on stack. This error is likely caused by a bug in React. Please file an issue.\"\n );\n push(contextStackCursor, context);\n push(didPerformWorkStackCursor, didChange);\n}\nfunction processChildContext(fiber, type, parentContext) {\n var instance = fiber.stateNode;\n type = type.childContextTypes;\n if (\"function\" !== typeof instance.getChildContext) return parentContext;\n instance = instance.getChildContext();\n for (var contextKey in instance)\n if (!(contextKey in type))\n throw Error(\n (getComponentNameFromFiber(fiber) || \"Unknown\") +\n '.getChildContext(): key \"' +\n contextKey +\n '\" is not defined in childContextTypes.'\n );\n return assign({}, parentContext, instance);\n}\nfunction pushContextProvider(workInProgress) {\n workInProgress =\n ((workInProgress = workInProgress.stateNode) &&\n workInProgress.__reactInternalMemoizedMergedChildContext) ||\n emptyContextObject;\n previousContext = contextStackCursor.current;\n push(contextStackCursor, workInProgress);\n push(didPerformWorkStackCursor, didPerformWorkStackCursor.current);\n return !0;\n}\nfunction invalidateContextProvider(workInProgress, type, didChange) {\n var instance = workInProgress.stateNode;\n if (!instance)\n throw Error(\n \"Expected to have an instance by this point. This error is likely caused by a bug in React. Please file an issue.\"\n );\n didChange\n ? ((workInProgress = processChildContext(\n workInProgress,\n type,\n previousContext\n )),\n (instance.__reactInternalMemoizedMergedChildContext = workInProgress),\n pop(didPerformWorkStackCursor),\n pop(contextStackCursor),\n push(contextStackCursor, workInProgress))\n : pop(didPerformWorkStackCursor);\n push(didPerformWorkStackCursor, didChange);\n}\nfunction is(x, y) {\n return (x === y && (0 !== x || 1 / x === 1 / y)) || (x !== x && y !== y);\n}\nvar objectIs = \"function\" === typeof Object.is ? Object.is : is,\n syncQueue = null,\n includesLegacySyncCallbacks = !1,\n isFlushingSyncQueue = !1;\nfunction flushSyncCallbacks() {\n if (!isFlushingSyncQueue && null !== syncQueue) {\n isFlushingSyncQueue = !0;\n var i = 0,\n previousUpdatePriority = currentUpdatePriority;\n try {\n var queue = syncQueue;\n for (currentUpdatePriority = 1; i < queue.length; i++) {\n var callback = queue[i];\n do callback = callback(!0);\n while (null !== callback);\n }\n syncQueue = null;\n includesLegacySyncCallbacks = !1;\n } catch (error) {\n throw (null !== syncQueue && (syncQueue = syncQueue.slice(i + 1)),\n scheduleCallback(ImmediatePriority, flushSyncCallbacks),\n error);\n } finally {\n (currentUpdatePriority = previousUpdatePriority),\n (isFlushingSyncQueue = !1);\n }\n }\n return null;\n}\nvar forkStack = [],\n forkStackIndex = 0,\n treeForkProvider = null,\n idStack = [],\n idStackIndex = 0,\n treeContextProvider = null;\nfunction popTreeContext(workInProgress) {\n for (; workInProgress === treeForkProvider; )\n (treeForkProvider = forkStack[--forkStackIndex]),\n (forkStack[forkStackIndex] = null),\n --forkStackIndex,\n (forkStack[forkStackIndex] = null);\n for (; workInProgress === treeContextProvider; )\n (treeContextProvider = idStack[--idStackIndex]),\n (idStack[idStackIndex] = null),\n --idStackIndex,\n (idStack[idStackIndex] = null),\n --idStackIndex,\n (idStack[idStackIndex] = null);\n}\nvar hydrationErrors = null,\n ReactCurrentBatchConfig = ReactSharedInternals.ReactCurrentBatchConfig;\nfunction shallowEqual(objA, objB) {\n if (objectIs(objA, objB)) return !0;\n if (\n \"object\" !== typeof objA ||\n null === objA ||\n \"object\" !== typeof objB ||\n null === objB\n )\n return !1;\n var keysA = Object.keys(objA),\n keysB = Object.keys(objB);\n if (keysA.length !== keysB.length) return !1;\n for (keysB = 0; keysB < keysA.length; keysB++) {\n var currentKey = keysA[keysB];\n if (\n !hasOwnProperty.call(objB, currentKey) ||\n !objectIs(objA[currentKey], objB[currentKey])\n )\n return !1;\n }\n return !0;\n}\nfunction describeFiber(fiber) {\n switch (fiber.tag) {\n case 5:\n return describeComponentFrame(fiber.type, null, null);\n case 16:\n return describeComponentFrame(\"Lazy\", null, null);\n case 13:\n return describeComponentFrame(\"Suspense\", null, null);\n case 19:\n return describeComponentFrame(\"SuspenseList\", null, null);\n case 0:\n case 2:\n case 15:\n return describeFunctionComponentFrame(fiber.type, null);\n case 11:\n return describeFunctionComponentFrame(fiber.type.render, null);\n case 1:\n return (fiber = describeFunctionComponentFrame(fiber.type, null)), fiber;\n default:\n return \"\";\n }\n}\nfunction getStackByFiberInDevAndProd(workInProgress) {\n try {\n var info = \"\";\n do\n (info += describeFiber(workInProgress)),\n (workInProgress = workInProgress.return);\n while (workInProgress);\n return info;\n } catch (x) {\n return \"\\nError generating stack: \" + x.message + \"\\n\" + x.stack;\n }\n}\nfunction resolveDefaultProps(Component, baseProps) {\n if (Component && Component.defaultProps) {\n baseProps = assign({}, baseProps);\n Component = Component.defaultProps;\n for (var propName in Component)\n void 0 === baseProps[propName] &&\n (baseProps[propName] = Component[propName]);\n return baseProps;\n }\n return baseProps;\n}\nvar valueCursor = createCursor(null),\n currentlyRenderingFiber = null,\n lastContextDependency = null,\n lastFullyObservedContext = null;\nfunction resetContextDependencies() {\n lastFullyObservedContext = lastContextDependency = currentlyRenderingFiber = null;\n}\nfunction popProvider(context) {\n var currentValue = valueCursor.current;\n pop(valueCursor);\n context._currentValue = currentValue;\n}\nfunction scheduleContextWorkOnParentPath(parent, renderLanes, propagationRoot) {\n for (; null !== parent; ) {\n var alternate = parent.alternate;\n (parent.childLanes & renderLanes) !== renderLanes\n ? ((parent.childLanes |= renderLanes),\n null !== alternate && (alternate.childLanes |= renderLanes))\n : null !== alternate &&\n (alternate.childLanes & renderLanes) !== renderLanes &&\n (alternate.childLanes |= renderLanes);\n if (parent === propagationRoot) break;\n parent = parent.return;\n }\n}\nfunction prepareToReadContext(workInProgress, renderLanes) {\n currentlyRenderingFiber = workInProgress;\n lastFullyObservedContext = lastContextDependency = null;\n workInProgress = workInProgress.dependencies;\n null !== workInProgress &&\n null !== workInProgress.firstContext &&\n (0 !== (workInProgress.lanes & renderLanes) && (didReceiveUpdate = !0),\n (workInProgress.firstContext = null));\n}\nfunction readContext(context) {\n var value = context._currentValue;\n if (lastFullyObservedContext !== context)\n if (\n ((context = { context: context, memoizedValue: value, next: null }),\n null === lastContextDependency)\n ) {\n if (null === currentlyRenderingFiber)\n throw Error(\n \"Context can only be read while React is rendering. In classes, you can read it in the render method or getDerivedStateFromProps. In function components, you can read it directly in the function body, but not inside Hooks like useReducer() or useMemo().\"\n );\n lastContextDependency = context;\n currentlyRenderingFiber.dependencies = {\n lanes: 0,\n firstContext: context\n };\n } else lastContextDependency = lastContextDependency.next = context;\n return value;\n}\nvar concurrentQueues = null;\nfunction pushConcurrentUpdateQueue(queue) {\n null === concurrentQueues\n ? (concurrentQueues = [queue])\n : concurrentQueues.push(queue);\n}\nfunction enqueueConcurrentHookUpdate(fiber, queue, update, lane) {\n var interleaved = queue.interleaved;\n null === interleaved\n ? ((update.next = update), pushConcurrentUpdateQueue(queue))\n : ((update.next = interleaved.next), (interleaved.next = update));\n queue.interleaved = update;\n return markUpdateLaneFromFiberToRoot(fiber, lane);\n}\nfunction markUpdateLaneFromFiberToRoot(sourceFiber, lane) {\n sourceFiber.lanes |= lane;\n var alternate = sourceFiber.alternate;\n null !== alternate && (alternate.lanes |= lane);\n alternate = sourceFiber;\n for (sourceFiber = sourceFiber.return; null !== sourceFiber; )\n (sourceFiber.childLanes |= lane),\n (alternate = sourceFiber.alternate),\n null !== alternate && (alternate.childLanes |= lane),\n (alternate = sourceFiber),\n (sourceFiber = sourceFiber.return);\n return 3 === alternate.tag ? alternate.stateNode : null;\n}\nvar hasForceUpdate = !1;\nfunction initializeUpdateQueue(fiber) {\n fiber.updateQueue = {\n baseState: fiber.memoizedState,\n firstBaseUpdate: null,\n lastBaseUpdate: null,\n shared: { pending: null, interleaved: null, lanes: 0 },\n effects: null\n };\n}\nfunction cloneUpdateQueue(current, workInProgress) {\n current = current.updateQueue;\n workInProgress.updateQueue === current &&\n (workInProgress.updateQueue = {\n baseState: current.baseState,\n firstBaseUpdate: current.firstBaseUpdate,\n lastBaseUpdate: current.lastBaseUpdate,\n shared: current.shared,\n effects: current.effects\n });\n}\nfunction createUpdate(eventTime, lane) {\n return {\n eventTime: eventTime,\n lane: lane,\n tag: 0,\n payload: null,\n callback: null,\n next: null\n };\n}\nfunction enqueueUpdate(fiber, update, lane) {\n var updateQueue = fiber.updateQueue;\n if (null === updateQueue) return null;\n updateQueue = updateQueue.shared;\n if (0 !== (executionContext & 2)) {\n var pending = updateQueue.pending;\n null === pending\n ? (update.next = update)\n : ((update.next = pending.next), (pending.next = update));\n updateQueue.pending = update;\n return markUpdateLaneFromFiberToRoot(fiber, lane);\n }\n pending = updateQueue.interleaved;\n null === pending\n ? ((update.next = update), pushConcurrentUpdateQueue(updateQueue))\n : ((update.next = pending.next), (pending.next = update));\n updateQueue.interleaved = update;\n return markUpdateLaneFromFiberToRoot(fiber, lane);\n}\nfunction entangleTransitions(root, fiber, lane) {\n fiber = fiber.updateQueue;\n if (null !== fiber && ((fiber = fiber.shared), 0 !== (lane & 4194240))) {\n var queueLanes = fiber.lanes;\n queueLanes &= root.pendingLanes;\n lane |= queueLanes;\n fiber.lanes = lane;\n markRootEntangled(root, lane);\n }\n}\nfunction enqueueCapturedUpdate(workInProgress, capturedUpdate) {\n var queue = workInProgress.updateQueue,\n current = workInProgress.alternate;\n if (\n null !== current &&\n ((current = current.updateQueue), queue === current)\n ) {\n var newFirst = null,\n newLast = null;\n queue = queue.firstBaseUpdate;\n if (null !== queue) {\n do {\n var clone = {\n eventTime: queue.eventTime,\n lane: queue.lane,\n tag: queue.tag,\n payload: queue.payload,\n callback: queue.callback,\n next: null\n };\n null === newLast\n ? (newFirst = newLast = clone)\n : (newLast = newLast.next = clone);\n queue = queue.next;\n } while (null !== queue);\n null === newLast\n ? (newFirst = newLast = capturedUpdate)\n : (newLast = newLast.next = capturedUpdate);\n } else newFirst = newLast = capturedUpdate;\n queue = {\n baseState: current.baseState,\n firstBaseUpdate: newFirst,\n lastBaseUpdate: newLast,\n shared: current.shared,\n effects: current.effects\n };\n workInProgress.updateQueue = queue;\n return;\n }\n workInProgress = queue.lastBaseUpdate;\n null === workInProgress\n ? (queue.firstBaseUpdate = capturedUpdate)\n : (workInProgress.next = capturedUpdate);\n queue.lastBaseUpdate = capturedUpdate;\n}\nfunction processUpdateQueue(\n workInProgress$jscomp$0,\n props,\n instance,\n renderLanes\n) {\n var queue = workInProgress$jscomp$0.updateQueue;\n hasForceUpdate = !1;\n var firstBaseUpdate = queue.firstBaseUpdate,\n lastBaseUpdate = queue.lastBaseUpdate,\n pendingQueue = queue.shared.pending;\n if (null !== pendingQueue) {\n queue.shared.pending = null;\n var lastPendingUpdate = pendingQueue,\n firstPendingUpdate = lastPendingUpdate.next;\n lastPendingUpdate.next = null;\n null === lastBaseUpdate\n ? (firstBaseUpdate = firstPendingUpdate)\n : (lastBaseUpdate.next = firstPendingUpdate);\n lastBaseUpdate = lastPendingUpdate;\n var current = workInProgress$jscomp$0.alternate;\n null !== current &&\n ((current = current.updateQueue),\n (pendingQueue = current.lastBaseUpdate),\n pendingQueue !== lastBaseUpdate &&\n (null === pendingQueue\n ? (current.firstBaseUpdate = firstPendingUpdate)\n : (pendingQueue.next = firstPendingUpdate),\n (current.lastBaseUpdate = lastPendingUpdate)));\n }\n if (null !== firstBaseUpdate) {\n var newState = queue.baseState;\n lastBaseUpdate = 0;\n current = firstPendingUpdate = lastPendingUpdate = null;\n pendingQueue = firstBaseUpdate;\n do {\n var updateLane = pendingQueue.lane,\n updateEventTime = pendingQueue.eventTime;\n if ((renderLanes & updateLane) === updateLane) {\n null !== current &&\n (current = current.next = {\n eventTime: updateEventTime,\n lane: 0,\n tag: pendingQueue.tag,\n payload: pendingQueue.payload,\n callback: pendingQueue.callback,\n next: null\n });\n a: {\n var workInProgress = workInProgress$jscomp$0,\n update = pendingQueue;\n updateLane = props;\n updateEventTime = instance;\n switch (update.tag) {\n case 1:\n workInProgress = update.payload;\n if (\"function\" === typeof workInProgress) {\n newState = workInProgress.call(\n updateEventTime,\n newState,\n updateLane\n );\n break a;\n }\n newState = workInProgress;\n break a;\n case 3:\n workInProgress.flags = (workInProgress.flags & -65537) | 128;\n case 0:\n workInProgress = update.payload;\n updateLane =\n \"function\" === typeof workInProgress\n ? workInProgress.call(updateEventTime, newState, updateLane)\n : workInProgress;\n if (null === updateLane || void 0 === updateLane) break a;\n newState = assign({}, newState, updateLane);\n break a;\n case 2:\n hasForceUpdate = !0;\n }\n }\n null !== pendingQueue.callback &&\n 0 !== pendingQueue.lane &&\n ((workInProgress$jscomp$0.flags |= 64),\n (updateLane = queue.effects),\n null === updateLane\n ? (queue.effects = [pendingQueue])\n : updateLane.push(pendingQueue));\n } else\n (updateEventTime = {\n eventTime: updateEventTime,\n lane: updateLane,\n tag: pendingQueue.tag,\n payload: pendingQueue.payload,\n callback: pendingQueue.callback,\n next: null\n }),\n null === current\n ? ((firstPendingUpdate = current = updateEventTime),\n (lastPendingUpdate = newState))\n : (current = current.next = updateEventTime),\n (lastBaseUpdate |= updateLane);\n pendingQueue = pendingQueue.next;\n if (null === pendingQueue)\n if (((pendingQueue = queue.shared.pending), null === pendingQueue))\n break;\n else\n (updateLane = pendingQueue),\n (pendingQueue = updateLane.next),\n (updateLane.next = null),\n (queue.lastBaseUpdate = updateLane),\n (queue.shared.pending = null);\n } while (1);\n null === current && (lastPendingUpdate = newState);\n queue.baseState = lastPendingUpdate;\n queue.firstBaseUpdate = firstPendingUpdate;\n queue.lastBaseUpdate = current;\n props = queue.shared.interleaved;\n if (null !== props) {\n queue = props;\n do (lastBaseUpdate |= queue.lane), (queue = queue.next);\n while (queue !== props);\n } else null === firstBaseUpdate && (queue.shared.lanes = 0);\n workInProgressRootSkippedLanes |= lastBaseUpdate;\n workInProgress$jscomp$0.lanes = lastBaseUpdate;\n workInProgress$jscomp$0.memoizedState = newState;\n }\n}\nfunction commitUpdateQueue(finishedWork, finishedQueue, instance) {\n finishedWork = finishedQueue.effects;\n finishedQueue.effects = null;\n if (null !== finishedWork)\n for (\n finishedQueue = 0;\n finishedQueue < finishedWork.length;\n finishedQueue++\n ) {\n var effect = finishedWork[finishedQueue],\n callback = effect.callback;\n if (null !== callback) {\n effect.callback = null;\n if (\"function\" !== typeof callback)\n throw Error(\n \"Invalid argument passed as callback. Expected a function. Instead received: \" +\n callback\n );\n callback.call(instance);\n }\n }\n}\nvar emptyRefsObject = new React.Component().refs;\nfunction applyDerivedStateFromProps(\n workInProgress,\n ctor,\n getDerivedStateFromProps,\n nextProps\n) {\n ctor = workInProgress.memoizedState;\n getDerivedStateFromProps = getDerivedStateFromProps(nextProps, ctor);\n getDerivedStateFromProps =\n null === getDerivedStateFromProps || void 0 === getDerivedStateFromProps\n ? ctor\n : assign({}, ctor, getDerivedStateFromProps);\n workInProgress.memoizedState = getDerivedStateFromProps;\n 0 === workInProgress.lanes &&\n (workInProgress.updateQueue.baseState = getDerivedStateFromProps);\n}\nvar classComponentUpdater = {\n isMounted: function(component) {\n return (component = component._reactInternals)\n ? getNearestMountedFiber(component) === component\n : !1;\n },\n enqueueSetState: function(inst, payload, callback) {\n inst = inst._reactInternals;\n var eventTime = requestEventTime(),\n lane = requestUpdateLane(inst),\n update = createUpdate(eventTime, lane);\n update.payload = payload;\n void 0 !== callback && null !== callback && (update.callback = callback);\n payload = enqueueUpdate(inst, update, lane);\n null !== payload &&\n (scheduleUpdateOnFiber(payload, inst, lane, eventTime),\n entangleTransitions(payload, inst, lane));\n },\n enqueueReplaceState: function(inst, payload, callback) {\n inst = inst._reactInternals;\n var eventTime = requestEventTime(),\n lane = requestUpdateLane(inst),\n update = createUpdate(eventTime, lane);\n update.tag = 1;\n update.payload = payload;\n void 0 !== callback && null !== callback && (update.callback = callback);\n payload = enqueueUpdate(inst, update, lane);\n null !== payload &&\n (scheduleUpdateOnFiber(payload, inst, lane, eventTime),\n entangleTransitions(payload, inst, lane));\n },\n enqueueForceUpdate: function(inst, callback) {\n inst = inst._reactInternals;\n var eventTime = requestEventTime(),\n lane = requestUpdateLane(inst),\n update = createUpdate(eventTime, lane);\n update.tag = 2;\n void 0 !== callback && null !== callback && (update.callback = callback);\n callback = enqueueUpdate(inst, update, lane);\n null !== callback &&\n (scheduleUpdateOnFiber(callback, inst, lane, eventTime),\n entangleTransitions(callback, inst, lane));\n }\n};\nfunction checkShouldComponentUpdate(\n workInProgress,\n ctor,\n oldProps,\n newProps,\n oldState,\n newState,\n nextContext\n) {\n workInProgress = workInProgress.stateNode;\n return \"function\" === typeof workInProgress.shouldComponentUpdate\n ? workInProgress.shouldComponentUpdate(newProps, newState, nextContext)\n : ctor.prototype && ctor.prototype.isPureReactComponent\n ? !shallowEqual(oldProps, newProps) || !shallowEqual(oldState, newState)\n : !0;\n}\nfunction constructClassInstance(workInProgress, ctor, props) {\n var isLegacyContextConsumer = !1,\n unmaskedContext = emptyContextObject;\n var context = ctor.contextType;\n \"object\" === typeof context && null !== context\n ? (context = readContext(context))\n : ((unmaskedContext = isContextProvider(ctor)\n ? previousContext\n : contextStackCursor.current),\n (isLegacyContextConsumer = ctor.contextTypes),\n (context = (isLegacyContextConsumer =\n null !== isLegacyContextConsumer && void 0 !== isLegacyContextConsumer)\n ? getMaskedContext(workInProgress, unmaskedContext)\n : emptyContextObject));\n ctor = new ctor(props, context);\n workInProgress.memoizedState =\n null !== ctor.state && void 0 !== ctor.state ? ctor.state : null;\n ctor.updater = classComponentUpdater;\n workInProgress.stateNode = ctor;\n ctor._reactInternals = workInProgress;\n isLegacyContextConsumer &&\n ((workInProgress = workInProgress.stateNode),\n (workInProgress.__reactInternalMemoizedUnmaskedChildContext = unmaskedContext),\n (workInProgress.__reactInternalMemoizedMaskedChildContext = context));\n return ctor;\n}\nfunction callComponentWillReceiveProps(\n workInProgress,\n instance,\n newProps,\n nextContext\n) {\n workInProgress = instance.state;\n \"function\" === typeof instance.componentWillReceiveProps &&\n instance.componentWillReceiveProps(newProps, nextContext);\n \"function\" === typeof instance.UNSAFE_componentWillReceiveProps &&\n instance.UNSAFE_componentWillReceiveProps(newProps, nextContext);\n instance.state !== workInProgress &&\n classComponentUpdater.enqueueReplaceState(instance, instance.state, null);\n}\nfunction mountClassInstance(workInProgress, ctor, newProps, renderLanes) {\n var instance = workInProgress.stateNode;\n instance.props = newProps;\n instance.state = workInProgress.memoizedState;\n instance.refs = emptyRefsObject;\n initializeUpdateQueue(workInProgress);\n var contextType = ctor.contextType;\n \"object\" === typeof contextType && null !== contextType\n ? (instance.context = readContext(contextType))\n : ((contextType = isContextProvider(ctor)\n ? previousContext\n : contextStackCursor.current),\n (instance.context = getMaskedContext(workInProgress, contextType)));\n instance.state = workInProgress.memoizedState;\n contextType = ctor.getDerivedStateFromProps;\n \"function\" === typeof contextType &&\n (applyDerivedStateFromProps(workInProgress, ctor, contextType, newProps),\n (instance.state = workInProgress.memoizedState));\n \"function\" === typeof ctor.getDerivedStateFromProps ||\n \"function\" === typeof instance.getSnapshotBeforeUpdate ||\n (\"function\" !== typeof instance.UNSAFE_componentWillMount &&\n \"function\" !== typeof instance.componentWillMount) ||\n ((ctor = instance.state),\n \"function\" === typeof instance.componentWillMount &&\n instance.componentWillMount(),\n \"function\" === typeof instance.UNSAFE_componentWillMount &&\n instance.UNSAFE_componentWillMount(),\n ctor !== instance.state &&\n classComponentUpdater.enqueueReplaceState(instance, instance.state, null),\n processUpdateQueue(workInProgress, newProps, instance, renderLanes),\n (instance.state = workInProgress.memoizedState));\n \"function\" === typeof instance.componentDidMount &&\n (workInProgress.flags |= 4);\n}\nfunction coerceRef(returnFiber, current, element) {\n returnFiber = element.ref;\n if (\n null !== returnFiber &&\n \"function\" !== typeof returnFiber &&\n \"object\" !== typeof returnFiber\n ) {\n if (element._owner) {\n element = element._owner;\n if (element) {\n if (1 !== element.tag)\n throw Error(\n \"Function components cannot have string refs. We recommend using useRef() instead. Learn more about using refs safely here: https://reactjs.org/link/strict-mode-string-ref\"\n );\n var inst = element.stateNode;\n }\n if (!inst)\n throw Error(\n \"Missing owner for string ref \" +\n returnFiber +\n \". This error is likely caused by a bug in React. Please file an issue.\"\n );\n var resolvedInst = inst,\n stringRef = \"\" + returnFiber;\n if (\n null !== current &&\n null !== current.ref &&\n \"function\" === typeof current.ref &&\n current.ref._stringRef === stringRef\n )\n return current.ref;\n current = function(value) {\n var refs = resolvedInst.refs;\n refs === emptyRefsObject && (refs = resolvedInst.refs = {});\n null === value ? delete refs[stringRef] : (refs[stringRef] = value);\n };\n current._stringRef = stringRef;\n return current;\n }\n if (\"string\" !== typeof returnFiber)\n throw Error(\n \"Expected ref to be a function, a string, an object returned by React.createRef(), or null.\"\n );\n if (!element._owner)\n throw Error(\n \"Element ref was specified as a string (\" +\n returnFiber +\n \") but no owner was set. This could happen for one of the following reasons:\\n1. You may be adding a ref to a function component\\n2. You may be adding a ref to a component that was not created inside a component's render method\\n3. You have multiple copies of React loaded\\nSee https://reactjs.org/link/refs-must-have-owner for more information.\"\n );\n }\n return returnFiber;\n}\nfunction throwOnInvalidObjectType(returnFiber, newChild) {\n returnFiber = Object.prototype.toString.call(newChild);\n throw Error(\n \"Objects are not valid as a React child (found: \" +\n (\"[object Object]\" === returnFiber\n ? \"object with keys {\" + Object.keys(newChild).join(\", \") + \"}\"\n : returnFiber) +\n \"). If you meant to render a collection of children, use an array instead.\"\n );\n}\nfunction resolveLazy(lazyType) {\n var init = lazyType._init;\n return init(lazyType._payload);\n}\nfunction ChildReconciler(shouldTrackSideEffects) {\n function deleteChild(returnFiber, childToDelete) {\n if (shouldTrackSideEffects) {\n var deletions = returnFiber.deletions;\n null === deletions\n ? ((returnFiber.deletions = [childToDelete]), (returnFiber.flags |= 16))\n : deletions.push(childToDelete);\n }\n }\n function deleteRemainingChildren(returnFiber, currentFirstChild) {\n if (!shouldTrackSideEffects) return null;\n for (; null !== currentFirstChild; )\n deleteChild(returnFiber, currentFirstChild),\n (currentFirstChild = currentFirstChild.sibling);\n return null;\n }\n function mapRemainingChildren(returnFiber, currentFirstChild) {\n for (returnFiber = new Map(); null !== currentFirstChild; )\n null !== currentFirstChild.key\n ? returnFiber.set(currentFirstChild.key, currentFirstChild)\n : returnFiber.set(currentFirstChild.index, currentFirstChild),\n (currentFirstChild = currentFirstChild.sibling);\n return returnFiber;\n }\n function useFiber(fiber, pendingProps) {\n fiber = createWorkInProgress(fiber, pendingProps);\n fiber.index = 0;\n fiber.sibling = null;\n return fiber;\n }\n function placeChild(newFiber, lastPlacedIndex, newIndex) {\n newFiber.index = newIndex;\n if (!shouldTrackSideEffects)\n return (newFiber.flags |= 1048576), lastPlacedIndex;\n newIndex = newFiber.alternate;\n if (null !== newIndex)\n return (\n (newIndex = newIndex.index),\n newIndex < lastPlacedIndex\n ? ((newFiber.flags |= 2), lastPlacedIndex)\n : newIndex\n );\n newFiber.flags |= 2;\n return lastPlacedIndex;\n }\n function placeSingleChild(newFiber) {\n shouldTrackSideEffects &&\n null === newFiber.alternate &&\n (newFiber.flags |= 2);\n return newFiber;\n }\n function updateTextNode(returnFiber, current, textContent, lanes) {\n if (null === current || 6 !== current.tag)\n return (\n (current = createFiberFromText(textContent, returnFiber.mode, lanes)),\n (current.return = returnFiber),\n current\n );\n current = useFiber(current, textContent);\n current.return = returnFiber;\n return current;\n }\n function updateElement(returnFiber, current, element, lanes) {\n var elementType = element.type;\n if (elementType === REACT_FRAGMENT_TYPE)\n return updateFragment(\n returnFiber,\n current,\n element.props.children,\n lanes,\n element.key\n );\n if (\n null !== current &&\n (current.elementType === elementType ||\n (\"object\" === typeof elementType &&\n null !== elementType &&\n elementType.$$typeof === REACT_LAZY_TYPE &&\n resolveLazy(elementType) === current.type))\n )\n return (\n (lanes = useFiber(current, element.props)),\n (lanes.ref = coerceRef(returnFiber, current, element)),\n (lanes.return = returnFiber),\n lanes\n );\n lanes = createFiberFromTypeAndProps(\n element.type,\n element.key,\n element.props,\n null,\n returnFiber.mode,\n lanes\n );\n lanes.ref = coerceRef(returnFiber, current, element);\n lanes.return = returnFiber;\n return lanes;\n }\n function updatePortal(returnFiber, current, portal, lanes) {\n if (\n null === current ||\n 4 !== current.tag ||\n current.stateNode.containerInfo !== portal.containerInfo ||\n current.stateNode.implementation !== portal.implementation\n )\n return (\n (current = createFiberFromPortal(portal, returnFiber.mode, lanes)),\n (current.return = returnFiber),\n current\n );\n current = useFiber(current, portal.children || []);\n current.return = returnFiber;\n return current;\n }\n function updateFragment(returnFiber, current, fragment, lanes, key) {\n if (null === current || 7 !== current.tag)\n return (\n (current = createFiberFromFragment(\n fragment,\n returnFiber.mode,\n lanes,\n key\n )),\n (current.return = returnFiber),\n current\n );\n current = useFiber(current, fragment);\n current.return = returnFiber;\n return current;\n }\n function createChild(returnFiber, newChild, lanes) {\n if (\n (\"string\" === typeof newChild && \"\" !== newChild) ||\n \"number\" === typeof newChild\n )\n return (\n (newChild = createFiberFromText(\n \"\" + newChild,\n returnFiber.mode,\n lanes\n )),\n (newChild.return = returnFiber),\n newChild\n );\n if (\"object\" === typeof newChild && null !== newChild) {\n switch (newChild.$$typeof) {\n case REACT_ELEMENT_TYPE:\n return (\n (lanes = createFiberFromTypeAndProps(\n newChild.type,\n newChild.key,\n newChild.props,\n null,\n returnFiber.mode,\n lanes\n )),\n (lanes.ref = coerceRef(returnFiber, null, newChild)),\n (lanes.return = returnFiber),\n lanes\n );\n case REACT_PORTAL_TYPE:\n return (\n (newChild = createFiberFromPortal(\n newChild,\n returnFiber.mode,\n lanes\n )),\n (newChild.return = returnFiber),\n newChild\n );\n case REACT_LAZY_TYPE:\n var init = newChild._init;\n return createChild(returnFiber, init(newChild._payload), lanes);\n }\n if (isArrayImpl(newChild) || getIteratorFn(newChild))\n return (\n (newChild = createFiberFromFragment(\n newChild,\n returnFiber.mode,\n lanes,\n null\n )),\n (newChild.return = returnFiber),\n newChild\n );\n throwOnInvalidObjectType(returnFiber, newChild);\n }\n return null;\n }\n function updateSlot(returnFiber, oldFiber, newChild, lanes) {\n var key = null !== oldFiber ? oldFiber.key : null;\n if (\n (\"string\" === typeof newChild && \"\" !== newChild) ||\n \"number\" === typeof newChild\n )\n return null !== key\n ? null\n : updateTextNode(returnFiber, oldFiber, \"\" + newChild, lanes);\n if (\"object\" === typeof newChild && null !== newChild) {\n switch (newChild.$$typeof) {\n case REACT_ELEMENT_TYPE:\n return newChild.key === key\n ? updateElement(returnFiber, oldFiber, newChild, lanes)\n : null;\n case REACT_PORTAL_TYPE:\n return newChild.key === key\n ? updatePortal(returnFiber, oldFiber, newChild, lanes)\n : null;\n case REACT_LAZY_TYPE:\n return (\n (key = newChild._init),\n updateSlot(returnFiber, oldFiber, key(newChild._payload), lanes)\n );\n }\n if (isArrayImpl(newChild) || getIteratorFn(newChild))\n return null !== key\n ? null\n : updateFragment(returnFiber, oldFiber, newChild, lanes, null);\n throwOnInvalidObjectType(returnFiber, newChild);\n }\n return null;\n }\n function updateFromMap(\n existingChildren,\n returnFiber,\n newIdx,\n newChild,\n lanes\n ) {\n if (\n (\"string\" === typeof newChild && \"\" !== newChild) ||\n \"number\" === typeof newChild\n )\n return (\n (existingChildren = existingChildren.get(newIdx) || null),\n updateTextNode(returnFiber, existingChildren, \"\" + newChild, lanes)\n );\n if (\"object\" === typeof newChild && null !== newChild) {\n switch (newChild.$$typeof) {\n case REACT_ELEMENT_TYPE:\n return (\n (existingChildren =\n existingChildren.get(\n null === newChild.key ? newIdx : newChild.key\n ) || null),\n updateElement(returnFiber, existingChildren, newChild, lanes)\n );\n case REACT_PORTAL_TYPE:\n return (\n (existingChildren =\n existingChildren.get(\n null === newChild.key ? newIdx : newChild.key\n ) || null),\n updatePortal(returnFiber, existingChildren, newChild, lanes)\n );\n case REACT_LAZY_TYPE:\n var init = newChild._init;\n return updateFromMap(\n existingChildren,\n returnFiber,\n newIdx,\n init(newChild._payload),\n lanes\n );\n }\n if (isArrayImpl(newChild) || getIteratorFn(newChild))\n return (\n (existingChildren = existingChildren.get(newIdx) || null),\n updateFragment(returnFiber, existingChildren, newChild, lanes, null)\n );\n throwOnInvalidObjectType(returnFiber, newChild);\n }\n return null;\n }\n function reconcileChildrenArray(\n returnFiber,\n currentFirstChild,\n newChildren,\n lanes\n ) {\n for (\n var resultingFirstChild = null,\n previousNewFiber = null,\n oldFiber = currentFirstChild,\n newIdx = (currentFirstChild = 0),\n nextOldFiber = null;\n null !== oldFiber && newIdx < newChildren.length;\n newIdx++\n ) {\n oldFiber.index > newIdx\n ? ((nextOldFiber = oldFiber), (oldFiber = null))\n : (nextOldFiber = oldFiber.sibling);\n var newFiber = updateSlot(\n returnFiber,\n oldFiber,\n newChildren[newIdx],\n lanes\n );\n if (null === newFiber) {\n null === oldFiber && (oldFiber = nextOldFiber);\n break;\n }\n shouldTrackSideEffects &&\n oldFiber &&\n null === newFiber.alternate &&\n deleteChild(returnFiber, oldFiber);\n currentFirstChild = placeChild(newFiber, currentFirstChild, newIdx);\n null === previousNewFiber\n ? (resultingFirstChild = newFiber)\n : (previousNewFiber.sibling = newFiber);\n previousNewFiber = newFiber;\n oldFiber = nextOldFiber;\n }\n if (newIdx === newChildren.length)\n return (\n deleteRemainingChildren(returnFiber, oldFiber), resultingFirstChild\n );\n if (null === oldFiber) {\n for (; newIdx < newChildren.length; newIdx++)\n (oldFiber = createChild(returnFiber, newChildren[newIdx], lanes)),\n null !== oldFiber &&\n ((currentFirstChild = placeChild(\n oldFiber,\n currentFirstChild,\n newIdx\n )),\n null === previousNewFiber\n ? (resultingFirstChild = oldFiber)\n : (previousNewFiber.sibling = oldFiber),\n (previousNewFiber = oldFiber));\n return resultingFirstChild;\n }\n for (\n oldFiber = mapRemainingChildren(returnFiber, oldFiber);\n newIdx < newChildren.length;\n newIdx++\n )\n (nextOldFiber = updateFromMap(\n oldFiber,\n returnFiber,\n newIdx,\n newChildren[newIdx],\n lanes\n )),\n null !== nextOldFiber &&\n (shouldTrackSideEffects &&\n null !== nextOldFiber.alternate &&\n oldFiber.delete(\n null === nextOldFiber.key ? newIdx : nextOldFiber.key\n ),\n (currentFirstChild = placeChild(\n nextOldFiber,\n currentFirstChild,\n newIdx\n )),\n null === previousNewFiber\n ? (resultingFirstChild = nextOldFiber)\n : (previousNewFiber.sibling = nextOldFiber),\n (previousNewFiber = nextOldFiber));\n shouldTrackSideEffects &&\n oldFiber.forEach(function(child) {\n return deleteChild(returnFiber, child);\n });\n return resultingFirstChild;\n }\n function reconcileChildrenIterator(\n returnFiber,\n currentFirstChild,\n newChildrenIterable,\n lanes\n ) {\n var iteratorFn = getIteratorFn(newChildrenIterable);\n if (\"function\" !== typeof iteratorFn)\n throw Error(\n \"An object is not an iterable. This error is likely caused by a bug in React. Please file an issue.\"\n );\n newChildrenIterable = iteratorFn.call(newChildrenIterable);\n if (null == newChildrenIterable)\n throw Error(\"An iterable object provided no iterator.\");\n for (\n var previousNewFiber = (iteratorFn = null),\n oldFiber = currentFirstChild,\n newIdx = (currentFirstChild = 0),\n nextOldFiber = null,\n step = newChildrenIterable.next();\n null !== oldFiber && !step.done;\n newIdx++, step = newChildrenIterable.next()\n ) {\n oldFiber.index > newIdx\n ? ((nextOldFiber = oldFiber), (oldFiber = null))\n : (nextOldFiber = oldFiber.sibling);\n var newFiber = updateSlot(returnFiber, oldFiber, step.value, lanes);\n if (null === newFiber) {\n null === oldFiber && (oldFiber = nextOldFiber);\n break;\n }\n shouldTrackSideEffects &&\n oldFiber &&\n null === newFiber.alternate &&\n deleteChild(returnFiber, oldFiber);\n currentFirstChild = placeChild(newFiber, currentFirstChild, newIdx);\n null === previousNewFiber\n ? (iteratorFn = newFiber)\n : (previousNewFiber.sibling = newFiber);\n previousNewFiber = newFiber;\n oldFiber = nextOldFiber;\n }\n if (step.done)\n return deleteRemainingChildren(returnFiber, oldFiber), iteratorFn;\n if (null === oldFiber) {\n for (; !step.done; newIdx++, step = newChildrenIterable.next())\n (step = createChild(returnFiber, step.value, lanes)),\n null !== step &&\n ((currentFirstChild = placeChild(step, currentFirstChild, newIdx)),\n null === previousNewFiber\n ? (iteratorFn = step)\n : (previousNewFiber.sibling = step),\n (previousNewFiber = step));\n return iteratorFn;\n }\n for (\n oldFiber = mapRemainingChildren(returnFiber, oldFiber);\n !step.done;\n newIdx++, step = newChildrenIterable.next()\n )\n (step = updateFromMap(oldFiber, returnFiber, newIdx, step.value, lanes)),\n null !== step &&\n (shouldTrackSideEffects &&\n null !== step.alternate &&\n oldFiber.delete(null === step.key ? newIdx : step.key),\n (currentFirstChild = placeChild(step, currentFirstChild, newIdx)),\n null === previousNewFiber\n ? (iteratorFn = step)\n : (previousNewFiber.sibling = step),\n (previousNewFiber = step));\n shouldTrackSideEffects &&\n oldFiber.forEach(function(child) {\n return deleteChild(returnFiber, child);\n });\n return iteratorFn;\n }\n function reconcileChildFibers(\n returnFiber,\n currentFirstChild,\n newChild,\n lanes\n ) {\n \"object\" === typeof newChild &&\n null !== newChild &&\n newChild.type === REACT_FRAGMENT_TYPE &&\n null === newChild.key &&\n (newChild = newChild.props.children);\n if (\"object\" === typeof newChild && null !== newChild) {\n switch (newChild.$$typeof) {\n case REACT_ELEMENT_TYPE:\n a: {\n for (\n var key = newChild.key, child = currentFirstChild;\n null !== child;\n\n ) {\n if (child.key === key) {\n key = newChild.type;\n if (key === REACT_FRAGMENT_TYPE) {\n if (7 === child.tag) {\n deleteRemainingChildren(returnFiber, child.sibling);\n currentFirstChild = useFiber(\n child,\n newChild.props.children\n );\n currentFirstChild.return = returnFiber;\n returnFiber = currentFirstChild;\n break a;\n }\n } else if (\n child.elementType === key ||\n (\"object\" === typeof key &&\n null !== key &&\n key.$$typeof === REACT_LAZY_TYPE &&\n resolveLazy(key) === child.type)\n ) {\n deleteRemainingChildren(returnFiber, child.sibling);\n currentFirstChild = useFiber(child, newChild.props);\n currentFirstChild.ref = coerceRef(\n returnFiber,\n child,\n newChild\n );\n currentFirstChild.return = returnFiber;\n returnFiber = currentFirstChild;\n break a;\n }\n deleteRemainingChildren(returnFiber, child);\n break;\n } else deleteChild(returnFiber, child);\n child = child.sibling;\n }\n newChild.type === REACT_FRAGMENT_TYPE\n ? ((currentFirstChild = createFiberFromFragment(\n newChild.props.children,\n returnFiber.mode,\n lanes,\n newChild.key\n )),\n (currentFirstChild.return = returnFiber),\n (returnFiber = currentFirstChild))\n : ((lanes = createFiberFromTypeAndProps(\n newChild.type,\n newChild.key,\n newChild.props,\n null,\n returnFiber.mode,\n lanes\n )),\n (lanes.ref = coerceRef(\n returnFiber,\n currentFirstChild,\n newChild\n )),\n (lanes.return = returnFiber),\n (returnFiber = lanes));\n }\n return placeSingleChild(returnFiber);\n case REACT_PORTAL_TYPE:\n a: {\n for (child = newChild.key; null !== currentFirstChild; ) {\n if (currentFirstChild.key === child)\n if (\n 4 === currentFirstChild.tag &&\n currentFirstChild.stateNode.containerInfo ===\n newChild.containerInfo &&\n currentFirstChild.stateNode.implementation ===\n newChild.implementation\n ) {\n deleteRemainingChildren(\n returnFiber,\n currentFirstChild.sibling\n );\n currentFirstChild = useFiber(\n currentFirstChild,\n newChild.children || []\n );\n currentFirstChild.return = returnFiber;\n returnFiber = currentFirstChild;\n break a;\n } else {\n deleteRemainingChildren(returnFiber, currentFirstChild);\n break;\n }\n else deleteChild(returnFiber, currentFirstChild);\n currentFirstChild = currentFirstChild.sibling;\n }\n currentFirstChild = createFiberFromPortal(\n newChild,\n returnFiber.mode,\n lanes\n );\n currentFirstChild.return = returnFiber;\n returnFiber = currentFirstChild;\n }\n return placeSingleChild(returnFiber);\n case REACT_LAZY_TYPE:\n return (\n (child = newChild._init),\n reconcileChildFibers(\n returnFiber,\n currentFirstChild,\n child(newChild._payload),\n lanes\n )\n );\n }\n if (isArrayImpl(newChild))\n return reconcileChildrenArray(\n returnFiber,\n currentFirstChild,\n newChild,\n lanes\n );\n if (getIteratorFn(newChild))\n return reconcileChildrenIterator(\n returnFiber,\n currentFirstChild,\n newChild,\n lanes\n );\n throwOnInvalidObjectType(returnFiber, newChild);\n }\n return (\"string\" === typeof newChild && \"\" !== newChild) ||\n \"number\" === typeof newChild\n ? ((newChild = \"\" + newChild),\n null !== currentFirstChild && 6 === currentFirstChild.tag\n ? (deleteRemainingChildren(returnFiber, currentFirstChild.sibling),\n (currentFirstChild = useFiber(currentFirstChild, newChild)),\n (currentFirstChild.return = returnFiber),\n (returnFiber = currentFirstChild))\n : (deleteRemainingChildren(returnFiber, currentFirstChild),\n (currentFirstChild = createFiberFromText(\n newChild,\n returnFiber.mode,\n lanes\n )),\n (currentFirstChild.return = returnFiber),\n (returnFiber = currentFirstChild)),\n placeSingleChild(returnFiber))\n : deleteRemainingChildren(returnFiber, currentFirstChild);\n }\n return reconcileChildFibers;\n}\nvar reconcileChildFibers = ChildReconciler(!0),\n mountChildFibers = ChildReconciler(!1),\n NO_CONTEXT = {},\n contextStackCursor$1 = createCursor(NO_CONTEXT),\n contextFiberStackCursor = createCursor(NO_CONTEXT),\n rootInstanceStackCursor = createCursor(NO_CONTEXT);\nfunction requiredContext(c) {\n if (c === NO_CONTEXT)\n throw Error(\n \"Expected host context to exist. This error is likely caused by a bug in React. Please file an issue.\"\n );\n return c;\n}\nfunction pushHostContainer(fiber, nextRootInstance) {\n push(rootInstanceStackCursor, nextRootInstance);\n push(contextFiberStackCursor, fiber);\n push(contextStackCursor$1, NO_CONTEXT);\n pop(contextStackCursor$1);\n push(contextStackCursor$1, { isInAParentText: !1 });\n}\nfunction popHostContainer() {\n pop(contextStackCursor$1);\n pop(contextFiberStackCursor);\n pop(rootInstanceStackCursor);\n}\nfunction pushHostContext(fiber) {\n requiredContext(rootInstanceStackCursor.current);\n var context = requiredContext(contextStackCursor$1.current);\n var JSCompiler_inline_result = fiber.type;\n JSCompiler_inline_result =\n \"AndroidTextInput\" === JSCompiler_inline_result ||\n \"RCTMultilineTextInputView\" === JSCompiler_inline_result ||\n \"RCTSinglelineTextInputView\" === JSCompiler_inline_result ||\n \"RCTText\" === JSCompiler_inline_result ||\n \"RCTVirtualText\" === JSCompiler_inline_result;\n JSCompiler_inline_result =\n context.isInAParentText !== JSCompiler_inline_result\n ? { isInAParentText: JSCompiler_inline_result }\n : context;\n context !== JSCompiler_inline_result &&\n (push(contextFiberStackCursor, fiber),\n push(contextStackCursor$1, JSCompiler_inline_result));\n}\nfunction popHostContext(fiber) {\n contextFiberStackCursor.current === fiber &&\n (pop(contextStackCursor$1), pop(contextFiberStackCursor));\n}\nvar suspenseStackCursor = createCursor(0);\nfunction findFirstSuspended(row) {\n for (var node = row; null !== node; ) {\n if (13 === node.tag) {\n var state = node.memoizedState;\n if (null !== state && (null === state.dehydrated || shim() || shim()))\n return node;\n } else if (19 === node.tag && void 0 !== node.memoizedProps.revealOrder) {\n if (0 !== (node.flags & 128)) return node;\n } else if (null !== node.child) {\n node.child.return = node;\n node = node.child;\n continue;\n }\n if (node === row) break;\n for (; null === node.sibling; ) {\n if (null === node.return || node.return === row) return null;\n node = node.return;\n }\n node.sibling.return = node.return;\n node = node.sibling;\n }\n return null;\n}\nvar workInProgressSources = [];\nfunction resetWorkInProgressVersions() {\n for (var i = 0; i < workInProgressSources.length; i++)\n workInProgressSources[i]._workInProgressVersionPrimary = null;\n workInProgressSources.length = 0;\n}\nvar ReactCurrentDispatcher$1 = ReactSharedInternals.ReactCurrentDispatcher,\n ReactCurrentBatchConfig$1 = ReactSharedInternals.ReactCurrentBatchConfig,\n renderLanes = 0,\n currentlyRenderingFiber$1 = null,\n currentHook = null,\n workInProgressHook = null,\n didScheduleRenderPhaseUpdate = !1,\n didScheduleRenderPhaseUpdateDuringThisPass = !1,\n globalClientIdCounter = 0;\nfunction throwInvalidHookError() {\n throw Error(\n \"Invalid hook call. Hooks can only be called inside of the body of a function component. This could happen for one of the following reasons:\\n1. You might have mismatching versions of React and the renderer (such as React DOM)\\n2. You might be breaking the Rules of Hooks\\n3. You might have more than one copy of React in the same app\\nSee https://reactjs.org/link/invalid-hook-call for tips about how to debug and fix this problem.\"\n );\n}\nfunction areHookInputsEqual(nextDeps, prevDeps) {\n if (null === prevDeps) return !1;\n for (var i = 0; i < prevDeps.length && i < nextDeps.length; i++)\n if (!objectIs(nextDeps[i], prevDeps[i])) return !1;\n return !0;\n}\nfunction renderWithHooks(\n current,\n workInProgress,\n Component,\n props,\n secondArg,\n nextRenderLanes\n) {\n renderLanes = nextRenderLanes;\n currentlyRenderingFiber$1 = workInProgress;\n workInProgress.memoizedState = null;\n workInProgress.updateQueue = null;\n workInProgress.lanes = 0;\n ReactCurrentDispatcher$1.current =\n null === current || null === current.memoizedState\n ? HooksDispatcherOnMount\n : HooksDispatcherOnUpdate;\n current = Component(props, secondArg);\n if (didScheduleRenderPhaseUpdateDuringThisPass) {\n nextRenderLanes = 0;\n do {\n didScheduleRenderPhaseUpdateDuringThisPass = !1;\n if (25 <= nextRenderLanes)\n throw Error(\n \"Too many re-renders. React limits the number of renders to prevent an infinite loop.\"\n );\n nextRenderLanes += 1;\n workInProgressHook = currentHook = null;\n workInProgress.updateQueue = null;\n ReactCurrentDispatcher$1.current = HooksDispatcherOnRerender;\n current = Component(props, secondArg);\n } while (didScheduleRenderPhaseUpdateDuringThisPass);\n }\n ReactCurrentDispatcher$1.current = ContextOnlyDispatcher;\n workInProgress = null !== currentHook && null !== currentHook.next;\n renderLanes = 0;\n workInProgressHook = currentHook = currentlyRenderingFiber$1 = null;\n didScheduleRenderPhaseUpdate = !1;\n if (workInProgress)\n throw Error(\n \"Rendered fewer hooks than expected. This may be caused by an accidental early return statement.\"\n );\n return current;\n}\nfunction mountWorkInProgressHook() {\n var hook = {\n memoizedState: null,\n baseState: null,\n baseQueue: null,\n queue: null,\n next: null\n };\n null === workInProgressHook\n ? (currentlyRenderingFiber$1.memoizedState = workInProgressHook = hook)\n : (workInProgressHook = workInProgressHook.next = hook);\n return workInProgressHook;\n}\nfunction updateWorkInProgressHook() {\n if (null === currentHook) {\n var nextCurrentHook = currentlyRenderingFiber$1.alternate;\n nextCurrentHook =\n null !== nextCurrentHook ? nextCurrentHook.memoizedState : null;\n } else nextCurrentHook = currentHook.next;\n var nextWorkInProgressHook =\n null === workInProgressHook\n ? currentlyRenderingFiber$1.memoizedState\n : workInProgressHook.next;\n if (null !== nextWorkInProgressHook)\n (workInProgressHook = nextWorkInProgressHook),\n (currentHook = nextCurrentHook);\n else {\n if (null === nextCurrentHook)\n throw Error(\"Rendered more hooks than during the previous render.\");\n currentHook = nextCurrentHook;\n nextCurrentHook = {\n memoizedState: currentHook.memoizedState,\n baseState: currentHook.baseState,\n baseQueue: currentHook.baseQueue,\n queue: currentHook.queue,\n next: null\n };\n null === workInProgressHook\n ? (currentlyRenderingFiber$1.memoizedState = workInProgressHook = nextCurrentHook)\n : (workInProgressHook = workInProgressHook.next = nextCurrentHook);\n }\n return workInProgressHook;\n}\nfunction basicStateReducer(state, action) {\n return \"function\" === typeof action ? action(state) : action;\n}\nfunction updateReducer(reducer) {\n var hook = updateWorkInProgressHook(),\n queue = hook.queue;\n if (null === queue)\n throw Error(\n \"Should have a queue. This is likely a bug in React. Please file an issue.\"\n );\n queue.lastRenderedReducer = reducer;\n var current = currentHook,\n baseQueue = current.baseQueue,\n pendingQueue = queue.pending;\n if (null !== pendingQueue) {\n if (null !== baseQueue) {\n var baseFirst = baseQueue.next;\n baseQueue.next = pendingQueue.next;\n pendingQueue.next = baseFirst;\n }\n current.baseQueue = baseQueue = pendingQueue;\n queue.pending = null;\n }\n if (null !== baseQueue) {\n pendingQueue = baseQueue.next;\n current = current.baseState;\n var newBaseQueueFirst = (baseFirst = null),\n newBaseQueueLast = null,\n update = pendingQueue;\n do {\n var updateLane = update.lane;\n if ((renderLanes & updateLane) === updateLane)\n null !== newBaseQueueLast &&\n (newBaseQueueLast = newBaseQueueLast.next = {\n lane: 0,\n action: update.action,\n hasEagerState: update.hasEagerState,\n eagerState: update.eagerState,\n next: null\n }),\n (current = update.hasEagerState\n ? update.eagerState\n : reducer(current, update.action));\n else {\n var clone = {\n lane: updateLane,\n action: update.action,\n hasEagerState: update.hasEagerState,\n eagerState: update.eagerState,\n next: null\n };\n null === newBaseQueueLast\n ? ((newBaseQueueFirst = newBaseQueueLast = clone),\n (baseFirst = current))\n : (newBaseQueueLast = newBaseQueueLast.next = clone);\n currentlyRenderingFiber$1.lanes |= updateLane;\n workInProgressRootSkippedLanes |= updateLane;\n }\n update = update.next;\n } while (null !== update && update !== pendingQueue);\n null === newBaseQueueLast\n ? (baseFirst = current)\n : (newBaseQueueLast.next = newBaseQueueFirst);\n objectIs(current, hook.memoizedState) || (didReceiveUpdate = !0);\n hook.memoizedState = current;\n hook.baseState = baseFirst;\n hook.baseQueue = newBaseQueueLast;\n queue.lastRenderedState = current;\n }\n reducer = queue.interleaved;\n if (null !== reducer) {\n baseQueue = reducer;\n do\n (pendingQueue = baseQueue.lane),\n (currentlyRenderingFiber$1.lanes |= pendingQueue),\n (workInProgressRootSkippedLanes |= pendingQueue),\n (baseQueue = baseQueue.next);\n while (baseQueue !== reducer);\n } else null === baseQueue && (queue.lanes = 0);\n return [hook.memoizedState, queue.dispatch];\n}\nfunction rerenderReducer(reducer) {\n var hook = updateWorkInProgressHook(),\n queue = hook.queue;\n if (null === queue)\n throw Error(\n \"Should have a queue. This is likely a bug in React. Please file an issue.\"\n );\n queue.lastRenderedReducer = reducer;\n var dispatch = queue.dispatch,\n lastRenderPhaseUpdate = queue.pending,\n newState = hook.memoizedState;\n if (null !== lastRenderPhaseUpdate) {\n queue.pending = null;\n var update = (lastRenderPhaseUpdate = lastRenderPhaseUpdate.next);\n do (newState = reducer(newState, update.action)), (update = update.next);\n while (update !== lastRenderPhaseUpdate);\n objectIs(newState, hook.memoizedState) || (didReceiveUpdate = !0);\n hook.memoizedState = newState;\n null === hook.baseQueue && (hook.baseState = newState);\n queue.lastRenderedState = newState;\n }\n return [newState, dispatch];\n}\nfunction updateMutableSource() {}\nfunction updateSyncExternalStore(subscribe, getSnapshot) {\n var fiber = currentlyRenderingFiber$1,\n hook = updateWorkInProgressHook(),\n nextSnapshot = getSnapshot(),\n snapshotChanged = !objectIs(hook.memoizedState, nextSnapshot);\n snapshotChanged &&\n ((hook.memoizedState = nextSnapshot), (didReceiveUpdate = !0));\n hook = hook.queue;\n updateEffect(subscribeToStore.bind(null, fiber, hook, subscribe), [\n subscribe\n ]);\n if (\n hook.getSnapshot !== getSnapshot ||\n snapshotChanged ||\n (null !== workInProgressHook && workInProgressHook.memoizedState.tag & 1)\n ) {\n fiber.flags |= 2048;\n pushEffect(\n 9,\n updateStoreInstance.bind(null, fiber, hook, nextSnapshot, getSnapshot),\n void 0,\n null\n );\n if (null === workInProgressRoot)\n throw Error(\n \"Expected a work-in-progress root. This is a bug in React. Please file an issue.\"\n );\n 0 !== (renderLanes & 30) ||\n pushStoreConsistencyCheck(fiber, getSnapshot, nextSnapshot);\n }\n return nextSnapshot;\n}\nfunction pushStoreConsistencyCheck(fiber, getSnapshot, renderedSnapshot) {\n fiber.flags |= 16384;\n fiber = { getSnapshot: getSnapshot, value: renderedSnapshot };\n getSnapshot = currentlyRenderingFiber$1.updateQueue;\n null === getSnapshot\n ? ((getSnapshot = { lastEffect: null, stores: null }),\n (currentlyRenderingFiber$1.updateQueue = getSnapshot),\n (getSnapshot.stores = [fiber]))\n : ((renderedSnapshot = getSnapshot.stores),\n null === renderedSnapshot\n ? (getSnapshot.stores = [fiber])\n : renderedSnapshot.push(fiber));\n}\nfunction updateStoreInstance(fiber, inst, nextSnapshot, getSnapshot) {\n inst.value = nextSnapshot;\n inst.getSnapshot = getSnapshot;\n checkIfSnapshotChanged(inst) && forceStoreRerender(fiber);\n}\nfunction subscribeToStore(fiber, inst, subscribe) {\n return subscribe(function() {\n checkIfSnapshotChanged(inst) && forceStoreRerender(fiber);\n });\n}\nfunction checkIfSnapshotChanged(inst) {\n var latestGetSnapshot = inst.getSnapshot;\n inst = inst.value;\n try {\n var nextValue = latestGetSnapshot();\n return !objectIs(inst, nextValue);\n } catch (error) {\n return !0;\n }\n}\nfunction forceStoreRerender(fiber) {\n var root = markUpdateLaneFromFiberToRoot(fiber, 1);\n null !== root && scheduleUpdateOnFiber(root, fiber, 1, -1);\n}\nfunction mountState(initialState) {\n var hook = mountWorkInProgressHook();\n \"function\" === typeof initialState && (initialState = initialState());\n hook.memoizedState = hook.baseState = initialState;\n initialState = {\n pending: null,\n interleaved: null,\n lanes: 0,\n dispatch: null,\n lastRenderedReducer: basicStateReducer,\n lastRenderedState: initialState\n };\n hook.queue = initialState;\n initialState = initialState.dispatch = dispatchSetState.bind(\n null,\n currentlyRenderingFiber$1,\n initialState\n );\n return [hook.memoizedState, initialState];\n}\nfunction pushEffect(tag, create, destroy, deps) {\n tag = { tag: tag, create: create, destroy: destroy, deps: deps, next: null };\n create = currentlyRenderingFiber$1.updateQueue;\n null === create\n ? ((create = { lastEffect: null, stores: null }),\n (currentlyRenderingFiber$1.updateQueue = create),\n (create.lastEffect = tag.next = tag))\n : ((destroy = create.lastEffect),\n null === destroy\n ? (create.lastEffect = tag.next = tag)\n : ((deps = destroy.next),\n (destroy.next = tag),\n (tag.next = deps),\n (create.lastEffect = tag)));\n return tag;\n}\nfunction updateRef() {\n return updateWorkInProgressHook().memoizedState;\n}\nfunction mountEffectImpl(fiberFlags, hookFlags, create, deps) {\n var hook = mountWorkInProgressHook();\n currentlyRenderingFiber$1.flags |= fiberFlags;\n hook.memoizedState = pushEffect(\n 1 | hookFlags,\n create,\n void 0,\n void 0 === deps ? null : deps\n );\n}\nfunction updateEffectImpl(fiberFlags, hookFlags, create, deps) {\n var hook = updateWorkInProgressHook();\n deps = void 0 === deps ? null : deps;\n var destroy = void 0;\n if (null !== currentHook) {\n var prevEffect = currentHook.memoizedState;\n destroy = prevEffect.destroy;\n if (null !== deps && areHookInputsEqual(deps, prevEffect.deps)) {\n hook.memoizedState = pushEffect(hookFlags, create, destroy, deps);\n return;\n }\n }\n currentlyRenderingFiber$1.flags |= fiberFlags;\n hook.memoizedState = pushEffect(1 | hookFlags, create, destroy, deps);\n}\nfunction mountEffect(create, deps) {\n return mountEffectImpl(8390656, 8, create, deps);\n}\nfunction updateEffect(create, deps) {\n return updateEffectImpl(2048, 8, create, deps);\n}\nfunction updateInsertionEffect(create, deps) {\n return updateEffectImpl(4, 2, create, deps);\n}\nfunction updateLayoutEffect(create, deps) {\n return updateEffectImpl(4, 4, create, deps);\n}\nfunction imperativeHandleEffect(create, ref) {\n if (\"function\" === typeof ref)\n return (\n (create = create()),\n ref(create),\n function() {\n ref(null);\n }\n );\n if (null !== ref && void 0 !== ref)\n return (\n (create = create()),\n (ref.current = create),\n function() {\n ref.current = null;\n }\n );\n}\nfunction updateImperativeHandle(ref, create, deps) {\n deps = null !== deps && void 0 !== deps ? deps.concat([ref]) : null;\n return updateEffectImpl(\n 4,\n 4,\n imperativeHandleEffect.bind(null, create, ref),\n deps\n );\n}\nfunction mountDebugValue() {}\nfunction updateCallback(callback, deps) {\n var hook = updateWorkInProgressHook();\n deps = void 0 === deps ? null : deps;\n var prevState = hook.memoizedState;\n if (\n null !== prevState &&\n null !== deps &&\n areHookInputsEqual(deps, prevState[1])\n )\n return prevState[0];\n hook.memoizedState = [callback, deps];\n return callback;\n}\nfunction updateMemo(nextCreate, deps) {\n var hook = updateWorkInProgressHook();\n deps = void 0 === deps ? null : deps;\n var prevState = hook.memoizedState;\n if (\n null !== prevState &&\n null !== deps &&\n areHookInputsEqual(deps, prevState[1])\n )\n return prevState[0];\n nextCreate = nextCreate();\n hook.memoizedState = [nextCreate, deps];\n return nextCreate;\n}\nfunction updateDeferredValueImpl(hook, prevValue, value) {\n if (0 === (renderLanes & 21))\n return (\n hook.baseState && ((hook.baseState = !1), (didReceiveUpdate = !0)),\n (hook.memoizedState = value)\n );\n objectIs(value, prevValue) ||\n ((value = claimNextTransitionLane()),\n (currentlyRenderingFiber$1.lanes |= value),\n (workInProgressRootSkippedLanes |= value),\n (hook.baseState = !0));\n return prevValue;\n}\nfunction startTransition(setPending, callback) {\n var previousPriority = currentUpdatePriority;\n currentUpdatePriority =\n 0 !== previousPriority && 4 > previousPriority ? previousPriority : 4;\n setPending(!0);\n var prevTransition = ReactCurrentBatchConfig$1.transition;\n ReactCurrentBatchConfig$1.transition = {};\n try {\n setPending(!1), callback();\n } finally {\n (currentUpdatePriority = previousPriority),\n (ReactCurrentBatchConfig$1.transition = prevTransition);\n }\n}\nfunction updateId() {\n return updateWorkInProgressHook().memoizedState;\n}\nfunction dispatchReducerAction(fiber, queue, action) {\n var lane = requestUpdateLane(fiber);\n action = {\n lane: lane,\n action: action,\n hasEagerState: !1,\n eagerState: null,\n next: null\n };\n if (isRenderPhaseUpdate(fiber)) enqueueRenderPhaseUpdate(queue, action);\n else if (\n ((action = enqueueConcurrentHookUpdate(fiber, queue, action, lane)),\n null !== action)\n ) {\n var eventTime = requestEventTime();\n scheduleUpdateOnFiber(action, fiber, lane, eventTime);\n entangleTransitionUpdate(action, queue, lane);\n }\n}\nfunction dispatchSetState(fiber, queue, action) {\n var lane = requestUpdateLane(fiber),\n update = {\n lane: lane,\n action: action,\n hasEagerState: !1,\n eagerState: null,\n next: null\n };\n if (isRenderPhaseUpdate(fiber)) enqueueRenderPhaseUpdate(queue, update);\n else {\n var alternate = fiber.alternate;\n if (\n 0 === fiber.lanes &&\n (null === alternate || 0 === alternate.lanes) &&\n ((alternate = queue.lastRenderedReducer), null !== alternate)\n )\n try {\n var currentState = queue.lastRenderedState,\n eagerState = alternate(currentState, action);\n update.hasEagerState = !0;\n update.eagerState = eagerState;\n if (objectIs(eagerState, currentState)) {\n var interleaved = queue.interleaved;\n null === interleaved\n ? ((update.next = update), pushConcurrentUpdateQueue(queue))\n : ((update.next = interleaved.next), (interleaved.next = update));\n queue.interleaved = update;\n return;\n }\n } catch (error) {\n } finally {\n }\n action = enqueueConcurrentHookUpdate(fiber, queue, update, lane);\n null !== action &&\n ((update = requestEventTime()),\n scheduleUpdateOnFiber(action, fiber, lane, update),\n entangleTransitionUpdate(action, queue, lane));\n }\n}\nfunction isRenderPhaseUpdate(fiber) {\n var alternate = fiber.alternate;\n return (\n fiber === currentlyRenderingFiber$1 ||\n (null !== alternate && alternate === currentlyRenderingFiber$1)\n );\n}\nfunction enqueueRenderPhaseUpdate(queue, update) {\n didScheduleRenderPhaseUpdateDuringThisPass = didScheduleRenderPhaseUpdate = !0;\n var pending = queue.pending;\n null === pending\n ? (update.next = update)\n : ((update.next = pending.next), (pending.next = update));\n queue.pending = update;\n}\nfunction entangleTransitionUpdate(root, queue, lane) {\n if (0 !== (lane & 4194240)) {\n var queueLanes = queue.lanes;\n queueLanes &= root.pendingLanes;\n lane |= queueLanes;\n queue.lanes = lane;\n markRootEntangled(root, lane);\n }\n}\nvar ContextOnlyDispatcher = {\n readContext: readContext,\n useCallback: throwInvalidHookError,\n useContext: throwInvalidHookError,\n useEffect: throwInvalidHookError,\n useImperativeHandle: throwInvalidHookError,\n useInsertionEffect: throwInvalidHookError,\n useLayoutEffect: throwInvalidHookError,\n useMemo: throwInvalidHookError,\n useReducer: throwInvalidHookError,\n useRef: throwInvalidHookError,\n useState: throwInvalidHookError,\n useDebugValue: throwInvalidHookError,\n useDeferredValue: throwInvalidHookError,\n useTransition: throwInvalidHookError,\n useMutableSource: throwInvalidHookError,\n useSyncExternalStore: throwInvalidHookError,\n useId: throwInvalidHookError,\n unstable_isNewReconciler: !1\n },\n HooksDispatcherOnMount = {\n readContext: readContext,\n useCallback: function(callback, deps) {\n mountWorkInProgressHook().memoizedState = [\n callback,\n void 0 === deps ? null : deps\n ];\n return callback;\n },\n useContext: readContext,\n useEffect: mountEffect,\n useImperativeHandle: function(ref, create, deps) {\n deps = null !== deps && void 0 !== deps ? deps.concat([ref]) : null;\n return mountEffectImpl(\n 4,\n 4,\n imperativeHandleEffect.bind(null, create, ref),\n deps\n );\n },\n useLayoutEffect: function(create, deps) {\n return mountEffectImpl(4, 4, create, deps);\n },\n useInsertionEffect: function(create, deps) {\n return mountEffectImpl(4, 2, create, deps);\n },\n useMemo: function(nextCreate, deps) {\n var hook = mountWorkInProgressHook();\n deps = void 0 === deps ? null : deps;\n nextCreate = nextCreate();\n hook.memoizedState = [nextCreate, deps];\n return nextCreate;\n },\n useReducer: function(reducer, initialArg, init) {\n var hook = mountWorkInProgressHook();\n initialArg = void 0 !== init ? init(initialArg) : initialArg;\n hook.memoizedState = hook.baseState = initialArg;\n reducer = {\n pending: null,\n interleaved: null,\n lanes: 0,\n dispatch: null,\n lastRenderedReducer: reducer,\n lastRenderedState: initialArg\n };\n hook.queue = reducer;\n reducer = reducer.dispatch = dispatchReducerAction.bind(\n null,\n currentlyRenderingFiber$1,\n reducer\n );\n return [hook.memoizedState, reducer];\n },\n useRef: function(initialValue) {\n var hook = mountWorkInProgressHook();\n initialValue = { current: initialValue };\n return (hook.memoizedState = initialValue);\n },\n useState: mountState,\n useDebugValue: mountDebugValue,\n useDeferredValue: function(value) {\n return (mountWorkInProgressHook().memoizedState = value);\n },\n useTransition: function() {\n var _mountState = mountState(!1),\n isPending = _mountState[0];\n _mountState = startTransition.bind(null, _mountState[1]);\n mountWorkInProgressHook().memoizedState = _mountState;\n return [isPending, _mountState];\n },\n useMutableSource: function() {},\n useSyncExternalStore: function(subscribe, getSnapshot) {\n var fiber = currentlyRenderingFiber$1,\n hook = mountWorkInProgressHook();\n var nextSnapshot = getSnapshot();\n if (null === workInProgressRoot)\n throw Error(\n \"Expected a work-in-progress root. This is a bug in React. Please file an issue.\"\n );\n 0 !== (renderLanes & 30) ||\n pushStoreConsistencyCheck(fiber, getSnapshot, nextSnapshot);\n hook.memoizedState = nextSnapshot;\n var inst = { value: nextSnapshot, getSnapshot: getSnapshot };\n hook.queue = inst;\n mountEffect(subscribeToStore.bind(null, fiber, inst, subscribe), [\n subscribe\n ]);\n fiber.flags |= 2048;\n pushEffect(\n 9,\n updateStoreInstance.bind(null, fiber, inst, nextSnapshot, getSnapshot),\n void 0,\n null\n );\n return nextSnapshot;\n },\n useId: function() {\n var hook = mountWorkInProgressHook(),\n identifierPrefix = workInProgressRoot.identifierPrefix,\n globalClientId = globalClientIdCounter++;\n identifierPrefix =\n \":\" + identifierPrefix + \"r\" + globalClientId.toString(32) + \":\";\n return (hook.memoizedState = identifierPrefix);\n },\n unstable_isNewReconciler: !1\n },\n HooksDispatcherOnUpdate = {\n readContext: readContext,\n useCallback: updateCallback,\n useContext: readContext,\n useEffect: updateEffect,\n useImperativeHandle: updateImperativeHandle,\n useInsertionEffect: updateInsertionEffect,\n useLayoutEffect: updateLayoutEffect,\n useMemo: updateMemo,\n useReducer: updateReducer,\n useRef: updateRef,\n useState: function() {\n return updateReducer(basicStateReducer);\n },\n useDebugValue: mountDebugValue,\n useDeferredValue: function(value) {\n var hook = updateWorkInProgressHook();\n return updateDeferredValueImpl(hook, currentHook.memoizedState, value);\n },\n useTransition: function() {\n var isPending = updateReducer(basicStateReducer)[0],\n start = updateWorkInProgressHook().memoizedState;\n return [isPending, start];\n },\n useMutableSource: updateMutableSource,\n useSyncExternalStore: updateSyncExternalStore,\n useId: updateId,\n unstable_isNewReconciler: !1\n },\n HooksDispatcherOnRerender = {\n readContext: readContext,\n useCallback: updateCallback,\n useContext: readContext,\n useEffect: updateEffect,\n useImperativeHandle: updateImperativeHandle,\n useInsertionEffect: updateInsertionEffect,\n useLayoutEffect: updateLayoutEffect,\n useMemo: updateMemo,\n useReducer: rerenderReducer,\n useRef: updateRef,\n useState: function() {\n return rerenderReducer(basicStateReducer);\n },\n useDebugValue: mountDebugValue,\n useDeferredValue: function(value) {\n var hook = updateWorkInProgressHook();\n return null === currentHook\n ? (hook.memoizedState = value)\n : updateDeferredValueImpl(hook, currentHook.memoizedState, value);\n },\n useTransition: function() {\n var isPending = rerenderReducer(basicStateReducer)[0],\n start = updateWorkInProgressHook().memoizedState;\n return [isPending, start];\n },\n useMutableSource: updateMutableSource,\n useSyncExternalStore: updateSyncExternalStore,\n useId: updateId,\n unstable_isNewReconciler: !1\n };\nfunction createCapturedValueAtFiber(value, source) {\n return {\n value: value,\n source: source,\n stack: getStackByFiberInDevAndProd(source),\n digest: null\n };\n}\nfunction createCapturedValue(value, digest, stack) {\n return {\n value: value,\n source: null,\n stack: null != stack ? stack : null,\n digest: null != digest ? digest : null\n };\n}\nif (\n \"function\" !==\n typeof ReactNativePrivateInterface.ReactFiberErrorDialog.showErrorDialog\n)\n throw Error(\n \"Expected ReactFiberErrorDialog.showErrorDialog to be a function.\"\n );\nfunction logCapturedError(boundary, errorInfo) {\n try {\n !1 !==\n ReactNativePrivateInterface.ReactFiberErrorDialog.showErrorDialog({\n componentStack: null !== errorInfo.stack ? errorInfo.stack : \"\",\n error: errorInfo.value,\n errorBoundary:\n null !== boundary && 1 === boundary.tag ? boundary.stateNode : null\n }) && console.error(errorInfo.value);\n } catch (e) {\n setTimeout(function() {\n throw e;\n });\n }\n}\nvar PossiblyWeakMap = \"function\" === typeof WeakMap ? WeakMap : Map;\nfunction createRootErrorUpdate(fiber, errorInfo, lane) {\n lane = createUpdate(-1, lane);\n lane.tag = 3;\n lane.payload = { element: null };\n var error = errorInfo.value;\n lane.callback = function() {\n hasUncaughtError || ((hasUncaughtError = !0), (firstUncaughtError = error));\n logCapturedError(fiber, errorInfo);\n };\n return lane;\n}\nfunction createClassErrorUpdate(fiber, errorInfo, lane) {\n lane = createUpdate(-1, lane);\n lane.tag = 3;\n var getDerivedStateFromError = fiber.type.getDerivedStateFromError;\n if (\"function\" === typeof getDerivedStateFromError) {\n var error = errorInfo.value;\n lane.payload = function() {\n return getDerivedStateFromError(error);\n };\n lane.callback = function() {\n logCapturedError(fiber, errorInfo);\n };\n }\n var inst = fiber.stateNode;\n null !== inst &&\n \"function\" === typeof inst.componentDidCatch &&\n (lane.callback = function() {\n logCapturedError(fiber, errorInfo);\n \"function\" !== typeof getDerivedStateFromError &&\n (null === legacyErrorBoundariesThatAlreadyFailed\n ? (legacyErrorBoundariesThatAlreadyFailed = new Set([this]))\n : legacyErrorBoundariesThatAlreadyFailed.add(this));\n var stack = errorInfo.stack;\n this.componentDidCatch(errorInfo.value, {\n componentStack: null !== stack ? stack : \"\"\n });\n });\n return lane;\n}\nfunction attachPingListener(root, wakeable, lanes) {\n var pingCache = root.pingCache;\n if (null === pingCache) {\n pingCache = root.pingCache = new PossiblyWeakMap();\n var threadIDs = new Set();\n pingCache.set(wakeable, threadIDs);\n } else\n (threadIDs = pingCache.get(wakeable)),\n void 0 === threadIDs &&\n ((threadIDs = new Set()), pingCache.set(wakeable, threadIDs));\n threadIDs.has(lanes) ||\n (threadIDs.add(lanes),\n (root = pingSuspendedRoot.bind(null, root, wakeable, lanes)),\n wakeable.then(root, root));\n}\nvar ReactCurrentOwner$1 = ReactSharedInternals.ReactCurrentOwner,\n didReceiveUpdate = !1;\nfunction reconcileChildren(current, workInProgress, nextChildren, renderLanes) {\n workInProgress.child =\n null === current\n ? mountChildFibers(workInProgress, null, nextChildren, renderLanes)\n : reconcileChildFibers(\n workInProgress,\n current.child,\n nextChildren,\n renderLanes\n );\n}\nfunction updateForwardRef(\n current,\n workInProgress,\n Component,\n nextProps,\n renderLanes\n) {\n Component = Component.render;\n var ref = workInProgress.ref;\n prepareToReadContext(workInProgress, renderLanes);\n nextProps = renderWithHooks(\n current,\n workInProgress,\n Component,\n nextProps,\n ref,\n renderLanes\n );\n if (null !== current && !didReceiveUpdate)\n return (\n (workInProgress.updateQueue = current.updateQueue),\n (workInProgress.flags &= -2053),\n (current.lanes &= ~renderLanes),\n bailoutOnAlreadyFinishedWork(current, workInProgress, renderLanes)\n );\n workInProgress.flags |= 1;\n reconcileChildren(current, workInProgress, nextProps, renderLanes);\n return workInProgress.child;\n}\nfunction updateMemoComponent(\n current,\n workInProgress,\n Component,\n nextProps,\n renderLanes\n) {\n if (null === current) {\n var type = Component.type;\n if (\n \"function\" === typeof type &&\n !shouldConstruct(type) &&\n void 0 === type.defaultProps &&\n null === Component.compare &&\n void 0 === Component.defaultProps\n )\n return (\n (workInProgress.tag = 15),\n (workInProgress.type = type),\n updateSimpleMemoComponent(\n current,\n workInProgress,\n type,\n nextProps,\n renderLanes\n )\n );\n current = createFiberFromTypeAndProps(\n Component.type,\n null,\n nextProps,\n workInProgress,\n workInProgress.mode,\n renderLanes\n );\n current.ref = workInProgress.ref;\n current.return = workInProgress;\n return (workInProgress.child = current);\n }\n type = current.child;\n if (0 === (current.lanes & renderLanes)) {\n var prevProps = type.memoizedProps;\n Component = Component.compare;\n Component = null !== Component ? Component : shallowEqual;\n if (Component(prevProps, nextProps) && current.ref === workInProgress.ref)\n return bailoutOnAlreadyFinishedWork(current, workInProgress, renderLanes);\n }\n workInProgress.flags |= 1;\n current = createWorkInProgress(type, nextProps);\n current.ref = workInProgress.ref;\n current.return = workInProgress;\n return (workInProgress.child = current);\n}\nfunction updateSimpleMemoComponent(\n current,\n workInProgress,\n Component,\n nextProps,\n renderLanes\n) {\n if (null !== current) {\n var prevProps = current.memoizedProps;\n if (\n shallowEqual(prevProps, nextProps) &&\n current.ref === workInProgress.ref\n )\n if (\n ((didReceiveUpdate = !1),\n (workInProgress.pendingProps = nextProps = prevProps),\n 0 !== (current.lanes & renderLanes))\n )\n 0 !== (current.flags & 131072) && (didReceiveUpdate = !0);\n else\n return (\n (workInProgress.lanes = current.lanes),\n bailoutOnAlreadyFinishedWork(current, workInProgress, renderLanes)\n );\n }\n return updateFunctionComponent(\n current,\n workInProgress,\n Component,\n nextProps,\n renderLanes\n );\n}\nfunction updateOffscreenComponent(current, workInProgress, renderLanes) {\n var nextProps = workInProgress.pendingProps,\n nextChildren = nextProps.children,\n prevState = null !== current ? current.memoizedState : null;\n if (\"hidden\" === nextProps.mode)\n if (0 === (workInProgress.mode & 1))\n (workInProgress.memoizedState = {\n baseLanes: 0,\n cachePool: null,\n transitions: null\n }),\n push(subtreeRenderLanesCursor, subtreeRenderLanes),\n (subtreeRenderLanes |= renderLanes);\n else {\n if (0 === (renderLanes & 1073741824))\n return (\n (current =\n null !== prevState\n ? prevState.baseLanes | renderLanes\n : renderLanes),\n (workInProgress.lanes = workInProgress.childLanes = 1073741824),\n (workInProgress.memoizedState = {\n baseLanes: current,\n cachePool: null,\n transitions: null\n }),\n (workInProgress.updateQueue = null),\n push(subtreeRenderLanesCursor, subtreeRenderLanes),\n (subtreeRenderLanes |= current),\n null\n );\n workInProgress.memoizedState = {\n baseLanes: 0,\n cachePool: null,\n transitions: null\n };\n nextProps = null !== prevState ? prevState.baseLanes : renderLanes;\n push(subtreeRenderLanesCursor, subtreeRenderLanes);\n subtreeRenderLanes |= nextProps;\n }\n else\n null !== prevState\n ? ((nextProps = prevState.baseLanes | renderLanes),\n (workInProgress.memoizedState = null))\n : (nextProps = renderLanes),\n push(subtreeRenderLanesCursor, subtreeRenderLanes),\n (subtreeRenderLanes |= nextProps);\n reconcileChildren(current, workInProgress, nextChildren, renderLanes);\n return workInProgress.child;\n}\nfunction markRef(current, workInProgress) {\n var ref = workInProgress.ref;\n if (\n (null === current && null !== ref) ||\n (null !== current && current.ref !== ref)\n )\n workInProgress.flags |= 512;\n}\nfunction updateFunctionComponent(\n current,\n workInProgress,\n Component,\n nextProps,\n renderLanes\n) {\n var context = isContextProvider(Component)\n ? previousContext\n : contextStackCursor.current;\n context = getMaskedContext(workInProgress, context);\n prepareToReadContext(workInProgress, renderLanes);\n Component = renderWithHooks(\n current,\n workInProgress,\n Component,\n nextProps,\n context,\n renderLanes\n );\n if (null !== current && !didReceiveUpdate)\n return (\n (workInProgress.updateQueue = current.updateQueue),\n (workInProgress.flags &= -2053),\n (current.lanes &= ~renderLanes),\n bailoutOnAlreadyFinishedWork(current, workInProgress, renderLanes)\n );\n workInProgress.flags |= 1;\n reconcileChildren(current, workInProgress, Component, renderLanes);\n return workInProgress.child;\n}\nfunction updateClassComponent(\n current,\n workInProgress,\n Component,\n nextProps,\n renderLanes\n) {\n if (isContextProvider(Component)) {\n var hasContext = !0;\n pushContextProvider(workInProgress);\n } else hasContext = !1;\n prepareToReadContext(workInProgress, renderLanes);\n if (null === workInProgress.stateNode)\n resetSuspendedCurrentOnMountInLegacyMode(current, workInProgress),\n constructClassInstance(workInProgress, Component, nextProps),\n mountClassInstance(workInProgress, Component, nextProps, renderLanes),\n (nextProps = !0);\n else if (null === current) {\n var instance = workInProgress.stateNode,\n oldProps = workInProgress.memoizedProps;\n instance.props = oldProps;\n var oldContext = instance.context,\n contextType = Component.contextType;\n \"object\" === typeof contextType && null !== contextType\n ? (contextType = readContext(contextType))\n : ((contextType = isContextProvider(Component)\n ? previousContext\n : contextStackCursor.current),\n (contextType = getMaskedContext(workInProgress, contextType)));\n var getDerivedStateFromProps = Component.getDerivedStateFromProps,\n hasNewLifecycles =\n \"function\" === typeof getDerivedStateFromProps ||\n \"function\" === typeof instance.getSnapshotBeforeUpdate;\n hasNewLifecycles ||\n (\"function\" !== typeof instance.UNSAFE_componentWillReceiveProps &&\n \"function\" !== typeof instance.componentWillReceiveProps) ||\n ((oldProps !== nextProps || oldContext !== contextType) &&\n callComponentWillReceiveProps(\n workInProgress,\n instance,\n nextProps,\n contextType\n ));\n hasForceUpdate = !1;\n var oldState = workInProgress.memoizedState;\n instance.state = oldState;\n processUpdateQueue(workInProgress, nextProps, instance, renderLanes);\n oldContext = workInProgress.memoizedState;\n oldProps !== nextProps ||\n oldState !== oldContext ||\n didPerformWorkStackCursor.current ||\n hasForceUpdate\n ? (\"function\" === typeof getDerivedStateFromProps &&\n (applyDerivedStateFromProps(\n workInProgress,\n Component,\n getDerivedStateFromProps,\n nextProps\n ),\n (oldContext = workInProgress.memoizedState)),\n (oldProps =\n hasForceUpdate ||\n checkShouldComponentUpdate(\n workInProgress,\n Component,\n oldProps,\n nextProps,\n oldState,\n oldContext,\n contextType\n ))\n ? (hasNewLifecycles ||\n (\"function\" !== typeof instance.UNSAFE_componentWillMount &&\n \"function\" !== typeof instance.componentWillMount) ||\n (\"function\" === typeof instance.componentWillMount &&\n instance.componentWillMount(),\n \"function\" === typeof instance.UNSAFE_componentWillMount &&\n instance.UNSAFE_componentWillMount()),\n \"function\" === typeof instance.componentDidMount &&\n (workInProgress.flags |= 4))\n : (\"function\" === typeof instance.componentDidMount &&\n (workInProgress.flags |= 4),\n (workInProgress.memoizedProps = nextProps),\n (workInProgress.memoizedState = oldContext)),\n (instance.props = nextProps),\n (instance.state = oldContext),\n (instance.context = contextType),\n (nextProps = oldProps))\n : (\"function\" === typeof instance.componentDidMount &&\n (workInProgress.flags |= 4),\n (nextProps = !1));\n } else {\n instance = workInProgress.stateNode;\n cloneUpdateQueue(current, workInProgress);\n oldProps = workInProgress.memoizedProps;\n contextType =\n workInProgress.type === workInProgress.elementType\n ? oldProps\n : resolveDefaultProps(workInProgress.type, oldProps);\n instance.props = contextType;\n hasNewLifecycles = workInProgress.pendingProps;\n oldState = instance.context;\n oldContext = Component.contextType;\n \"object\" === typeof oldContext && null !== oldContext\n ? (oldContext = readContext(oldContext))\n : ((oldContext = isContextProvider(Component)\n ? previousContext\n : contextStackCursor.current),\n (oldContext = getMaskedContext(workInProgress, oldContext)));\n var getDerivedStateFromProps$jscomp$0 = Component.getDerivedStateFromProps;\n (getDerivedStateFromProps =\n \"function\" === typeof getDerivedStateFromProps$jscomp$0 ||\n \"function\" === typeof instance.getSnapshotBeforeUpdate) ||\n (\"function\" !== typeof instance.UNSAFE_componentWillReceiveProps &&\n \"function\" !== typeof instance.componentWillReceiveProps) ||\n ((oldProps !== hasNewLifecycles || oldState !== oldContext) &&\n callComponentWillReceiveProps(\n workInProgress,\n instance,\n nextProps,\n oldContext\n ));\n hasForceUpdate = !1;\n oldState = workInProgress.memoizedState;\n instance.state = oldState;\n processUpdateQueue(workInProgress, nextProps, instance, renderLanes);\n var newState = workInProgress.memoizedState;\n oldProps !== hasNewLifecycles ||\n oldState !== newState ||\n didPerformWorkStackCursor.current ||\n hasForceUpdate\n ? (\"function\" === typeof getDerivedStateFromProps$jscomp$0 &&\n (applyDerivedStateFromProps(\n workInProgress,\n Component,\n getDerivedStateFromProps$jscomp$0,\n nextProps\n ),\n (newState = workInProgress.memoizedState)),\n (contextType =\n hasForceUpdate ||\n checkShouldComponentUpdate(\n workInProgress,\n Component,\n contextType,\n nextProps,\n oldState,\n newState,\n oldContext\n ) ||\n !1)\n ? (getDerivedStateFromProps ||\n (\"function\" !== typeof instance.UNSAFE_componentWillUpdate &&\n \"function\" !== typeof instance.componentWillUpdate) ||\n (\"function\" === typeof instance.componentWillUpdate &&\n instance.componentWillUpdate(nextProps, newState, oldContext),\n \"function\" === typeof instance.UNSAFE_componentWillUpdate &&\n instance.UNSAFE_componentWillUpdate(\n nextProps,\n newState,\n oldContext\n )),\n \"function\" === typeof instance.componentDidUpdate &&\n (workInProgress.flags |= 4),\n \"function\" === typeof instance.getSnapshotBeforeUpdate &&\n (workInProgress.flags |= 1024))\n : (\"function\" !== typeof instance.componentDidUpdate ||\n (oldProps === current.memoizedProps &&\n oldState === current.memoizedState) ||\n (workInProgress.flags |= 4),\n \"function\" !== typeof instance.getSnapshotBeforeUpdate ||\n (oldProps === current.memoizedProps &&\n oldState === current.memoizedState) ||\n (workInProgress.flags |= 1024),\n (workInProgress.memoizedProps = nextProps),\n (workInProgress.memoizedState = newState)),\n (instance.props = nextProps),\n (instance.state = newState),\n (instance.context = oldContext),\n (nextProps = contextType))\n : (\"function\" !== typeof instance.componentDidUpdate ||\n (oldProps === current.memoizedProps &&\n oldState === current.memoizedState) ||\n (workInProgress.flags |= 4),\n \"function\" !== typeof instance.getSnapshotBeforeUpdate ||\n (oldProps === current.memoizedProps &&\n oldState === current.memoizedState) ||\n (workInProgress.flags |= 1024),\n (nextProps = !1));\n }\n return finishClassComponent(\n current,\n workInProgress,\n Component,\n nextProps,\n hasContext,\n renderLanes\n );\n}\nfunction finishClassComponent(\n current,\n workInProgress,\n Component,\n shouldUpdate,\n hasContext,\n renderLanes\n) {\n markRef(current, workInProgress);\n var didCaptureError = 0 !== (workInProgress.flags & 128);\n if (!shouldUpdate && !didCaptureError)\n return (\n hasContext && invalidateContextProvider(workInProgress, Component, !1),\n bailoutOnAlreadyFinishedWork(current, workInProgress, renderLanes)\n );\n shouldUpdate = workInProgress.stateNode;\n ReactCurrentOwner$1.current = workInProgress;\n var nextChildren =\n didCaptureError && \"function\" !== typeof Component.getDerivedStateFromError\n ? null\n : shouldUpdate.render();\n workInProgress.flags |= 1;\n null !== current && didCaptureError\n ? ((workInProgress.child = reconcileChildFibers(\n workInProgress,\n current.child,\n null,\n renderLanes\n )),\n (workInProgress.child = reconcileChildFibers(\n workInProgress,\n null,\n nextChildren,\n renderLanes\n )))\n : reconcileChildren(current, workInProgress, nextChildren, renderLanes);\n workInProgress.memoizedState = shouldUpdate.state;\n hasContext && invalidateContextProvider(workInProgress, Component, !0);\n return workInProgress.child;\n}\nfunction pushHostRootContext(workInProgress) {\n var root = workInProgress.stateNode;\n root.pendingContext\n ? pushTopLevelContextObject(\n workInProgress,\n root.pendingContext,\n root.pendingContext !== root.context\n )\n : root.context &&\n pushTopLevelContextObject(workInProgress, root.context, !1);\n pushHostContainer(workInProgress, root.containerInfo);\n}\nvar SUSPENDED_MARKER = { dehydrated: null, treeContext: null, retryLane: 0 };\nfunction mountSuspenseOffscreenState(renderLanes) {\n return { baseLanes: renderLanes, cachePool: null, transitions: null };\n}\nfunction updateSuspenseComponent(current, workInProgress, renderLanes) {\n var nextProps = workInProgress.pendingProps,\n suspenseContext = suspenseStackCursor.current,\n showFallback = !1,\n didSuspend = 0 !== (workInProgress.flags & 128),\n JSCompiler_temp;\n (JSCompiler_temp = didSuspend) ||\n (JSCompiler_temp =\n null !== current && null === current.memoizedState\n ? !1\n : 0 !== (suspenseContext & 2));\n if (JSCompiler_temp) (showFallback = !0), (workInProgress.flags &= -129);\n else if (null === current || null !== current.memoizedState)\n suspenseContext |= 1;\n push(suspenseStackCursor, suspenseContext & 1);\n if (null === current) {\n current = workInProgress.memoizedState;\n if (null !== current && null !== current.dehydrated)\n return (\n 0 === (workInProgress.mode & 1)\n ? (workInProgress.lanes = 1)\n : shim()\n ? (workInProgress.lanes = 8)\n : (workInProgress.lanes = 1073741824),\n null\n );\n didSuspend = nextProps.children;\n current = nextProps.fallback;\n return showFallback\n ? ((nextProps = workInProgress.mode),\n (showFallback = workInProgress.child),\n (didSuspend = { mode: \"hidden\", children: didSuspend }),\n 0 === (nextProps & 1) && null !== showFallback\n ? ((showFallback.childLanes = 0),\n (showFallback.pendingProps = didSuspend))\n : (showFallback = createFiberFromOffscreen(\n didSuspend,\n nextProps,\n 0,\n null\n )),\n (current = createFiberFromFragment(\n current,\n nextProps,\n renderLanes,\n null\n )),\n (showFallback.return = workInProgress),\n (current.return = workInProgress),\n (showFallback.sibling = current),\n (workInProgress.child = showFallback),\n (workInProgress.child.memoizedState = mountSuspenseOffscreenState(\n renderLanes\n )),\n (workInProgress.memoizedState = SUSPENDED_MARKER),\n current)\n : mountSuspensePrimaryChildren(workInProgress, didSuspend);\n }\n suspenseContext = current.memoizedState;\n if (\n null !== suspenseContext &&\n ((JSCompiler_temp = suspenseContext.dehydrated), null !== JSCompiler_temp)\n )\n return updateDehydratedSuspenseComponent(\n current,\n workInProgress,\n didSuspend,\n nextProps,\n JSCompiler_temp,\n suspenseContext,\n renderLanes\n );\n if (showFallback) {\n showFallback = nextProps.fallback;\n didSuspend = workInProgress.mode;\n suspenseContext = current.child;\n JSCompiler_temp = suspenseContext.sibling;\n var primaryChildProps = { mode: \"hidden\", children: nextProps.children };\n 0 === (didSuspend & 1) && workInProgress.child !== suspenseContext\n ? ((nextProps = workInProgress.child),\n (nextProps.childLanes = 0),\n (nextProps.pendingProps = primaryChildProps),\n (workInProgress.deletions = null))\n : ((nextProps = createWorkInProgress(suspenseContext, primaryChildProps)),\n (nextProps.subtreeFlags = suspenseContext.subtreeFlags & 14680064));\n null !== JSCompiler_temp\n ? (showFallback = createWorkInProgress(JSCompiler_temp, showFallback))\n : ((showFallback = createFiberFromFragment(\n showFallback,\n didSuspend,\n renderLanes,\n null\n )),\n (showFallback.flags |= 2));\n showFallback.return = workInProgress;\n nextProps.return = workInProgress;\n nextProps.sibling = showFallback;\n workInProgress.child = nextProps;\n nextProps = showFallback;\n showFallback = workInProgress.child;\n didSuspend = current.child.memoizedState;\n didSuspend =\n null === didSuspend\n ? mountSuspenseOffscreenState(renderLanes)\n : {\n baseLanes: didSuspend.baseLanes | renderLanes,\n cachePool: null,\n transitions: didSuspend.transitions\n };\n showFallback.memoizedState = didSuspend;\n showFallback.childLanes = current.childLanes & ~renderLanes;\n workInProgress.memoizedState = SUSPENDED_MARKER;\n return nextProps;\n }\n showFallback = current.child;\n current = showFallback.sibling;\n nextProps = createWorkInProgress(showFallback, {\n mode: \"visible\",\n children: nextProps.children\n });\n 0 === (workInProgress.mode & 1) && (nextProps.lanes = renderLanes);\n nextProps.return = workInProgress;\n nextProps.sibling = null;\n null !== current &&\n ((renderLanes = workInProgress.deletions),\n null === renderLanes\n ? ((workInProgress.deletions = [current]), (workInProgress.flags |= 16))\n : renderLanes.push(current));\n workInProgress.child = nextProps;\n workInProgress.memoizedState = null;\n return nextProps;\n}\nfunction mountSuspensePrimaryChildren(workInProgress, primaryChildren) {\n primaryChildren = createFiberFromOffscreen(\n { mode: \"visible\", children: primaryChildren },\n workInProgress.mode,\n 0,\n null\n );\n primaryChildren.return = workInProgress;\n return (workInProgress.child = primaryChildren);\n}\nfunction retrySuspenseComponentWithoutHydrating(\n current,\n workInProgress,\n renderLanes,\n recoverableError\n) {\n null !== recoverableError &&\n (null === hydrationErrors\n ? (hydrationErrors = [recoverableError])\n : hydrationErrors.push(recoverableError));\n reconcileChildFibers(workInProgress, current.child, null, renderLanes);\n current = mountSuspensePrimaryChildren(\n workInProgress,\n workInProgress.pendingProps.children\n );\n current.flags |= 2;\n workInProgress.memoizedState = null;\n return current;\n}\nfunction updateDehydratedSuspenseComponent(\n current,\n workInProgress,\n didSuspend,\n nextProps,\n suspenseInstance,\n suspenseState,\n renderLanes\n) {\n if (didSuspend) {\n if (workInProgress.flags & 256)\n return (\n (workInProgress.flags &= -257),\n (suspenseState = createCapturedValue(\n Error(\n \"There was an error while hydrating this Suspense boundary. Switched to client rendering.\"\n )\n )),\n retrySuspenseComponentWithoutHydrating(\n current,\n workInProgress,\n renderLanes,\n suspenseState\n )\n );\n if (null !== workInProgress.memoizedState)\n return (\n (workInProgress.child = current.child),\n (workInProgress.flags |= 128),\n null\n );\n suspenseState = nextProps.fallback;\n didSuspend = workInProgress.mode;\n nextProps = createFiberFromOffscreen(\n { mode: \"visible\", children: nextProps.children },\n didSuspend,\n 0,\n null\n );\n suspenseState = createFiberFromFragment(\n suspenseState,\n didSuspend,\n renderLanes,\n null\n );\n suspenseState.flags |= 2;\n nextProps.return = workInProgress;\n suspenseState.return = workInProgress;\n nextProps.sibling = suspenseState;\n workInProgress.child = nextProps;\n 0 !== (workInProgress.mode & 1) &&\n reconcileChildFibers(workInProgress, current.child, null, renderLanes);\n workInProgress.child.memoizedState = mountSuspenseOffscreenState(\n renderLanes\n );\n workInProgress.memoizedState = SUSPENDED_MARKER;\n return suspenseState;\n }\n if (0 === (workInProgress.mode & 1))\n return retrySuspenseComponentWithoutHydrating(\n current,\n workInProgress,\n renderLanes,\n null\n );\n if (shim())\n return (\n (suspenseState = shim().digest),\n (suspenseState = createCapturedValue(\n Error(\n \"The server could not finish this Suspense boundary, likely due to an error during server rendering. Switched to client rendering.\"\n ),\n suspenseState,\n void 0\n )),\n retrySuspenseComponentWithoutHydrating(\n current,\n workInProgress,\n renderLanes,\n suspenseState\n )\n );\n didSuspend = 0 !== (renderLanes & current.childLanes);\n if (didReceiveUpdate || didSuspend) {\n nextProps = workInProgressRoot;\n if (null !== nextProps) {\n switch (renderLanes & -renderLanes) {\n case 4:\n didSuspend = 2;\n break;\n case 16:\n didSuspend = 8;\n break;\n case 64:\n case 128:\n case 256:\n case 512:\n case 1024:\n case 2048:\n case 4096:\n case 8192:\n case 16384:\n case 32768:\n case 65536:\n case 131072:\n case 262144:\n case 524288:\n case 1048576:\n case 2097152:\n case 4194304:\n case 8388608:\n case 16777216:\n case 33554432:\n case 67108864:\n didSuspend = 32;\n break;\n case 536870912:\n didSuspend = 268435456;\n break;\n default:\n didSuspend = 0;\n }\n didSuspend =\n 0 !== (didSuspend & (nextProps.suspendedLanes | renderLanes))\n ? 0\n : didSuspend;\n 0 !== didSuspend &&\n didSuspend !== suspenseState.retryLane &&\n ((suspenseState.retryLane = didSuspend),\n markUpdateLaneFromFiberToRoot(current, didSuspend),\n scheduleUpdateOnFiber(nextProps, current, didSuspend, -1));\n }\n renderDidSuspendDelayIfPossible();\n suspenseState = createCapturedValue(\n Error(\n \"This Suspense boundary received an update before it finished hydrating. This caused the boundary to switch to client rendering. The usual way to fix this is to wrap the original update in startTransition.\"\n )\n );\n return retrySuspenseComponentWithoutHydrating(\n current,\n workInProgress,\n renderLanes,\n suspenseState\n );\n }\n if (shim())\n return (\n (workInProgress.flags |= 128),\n (workInProgress.child = current.child),\n retryDehydratedSuspenseBoundary.bind(null, current),\n shim(),\n null\n );\n current = mountSuspensePrimaryChildren(workInProgress, nextProps.children);\n current.flags |= 4096;\n return current;\n}\nfunction scheduleSuspenseWorkOnFiber(fiber, renderLanes, propagationRoot) {\n fiber.lanes |= renderLanes;\n var alternate = fiber.alternate;\n null !== alternate && (alternate.lanes |= renderLanes);\n scheduleContextWorkOnParentPath(fiber.return, renderLanes, propagationRoot);\n}\nfunction initSuspenseListRenderState(\n workInProgress,\n isBackwards,\n tail,\n lastContentRow,\n tailMode\n) {\n var renderState = workInProgress.memoizedState;\n null === renderState\n ? (workInProgress.memoizedState = {\n isBackwards: isBackwards,\n rendering: null,\n renderingStartTime: 0,\n last: lastContentRow,\n tail: tail,\n tailMode: tailMode\n })\n : ((renderState.isBackwards = isBackwards),\n (renderState.rendering = null),\n (renderState.renderingStartTime = 0),\n (renderState.last = lastContentRow),\n (renderState.tail = tail),\n (renderState.tailMode = tailMode));\n}\nfunction updateSuspenseListComponent(current, workInProgress, renderLanes) {\n var nextProps = workInProgress.pendingProps,\n revealOrder = nextProps.revealOrder,\n tailMode = nextProps.tail;\n reconcileChildren(current, workInProgress, nextProps.children, renderLanes);\n nextProps = suspenseStackCursor.current;\n if (0 !== (nextProps & 2))\n (nextProps = (nextProps & 1) | 2), (workInProgress.flags |= 128);\n else {\n if (null !== current && 0 !== (current.flags & 128))\n a: for (current = workInProgress.child; null !== current; ) {\n if (13 === current.tag)\n null !== current.memoizedState &&\n scheduleSuspenseWorkOnFiber(current, renderLanes, workInProgress);\n else if (19 === current.tag)\n scheduleSuspenseWorkOnFiber(current, renderLanes, workInProgress);\n else if (null !== current.child) {\n current.child.return = current;\n current = current.child;\n continue;\n }\n if (current === workInProgress) break a;\n for (; null === current.sibling; ) {\n if (null === current.return || current.return === workInProgress)\n break a;\n current = current.return;\n }\n current.sibling.return = current.return;\n current = current.sibling;\n }\n nextProps &= 1;\n }\n push(suspenseStackCursor, nextProps);\n if (0 === (workInProgress.mode & 1)) workInProgress.memoizedState = null;\n else\n switch (revealOrder) {\n case \"forwards\":\n renderLanes = workInProgress.child;\n for (revealOrder = null; null !== renderLanes; )\n (current = renderLanes.alternate),\n null !== current &&\n null === findFirstSuspended(current) &&\n (revealOrder = renderLanes),\n (renderLanes = renderLanes.sibling);\n renderLanes = revealOrder;\n null === renderLanes\n ? ((revealOrder = workInProgress.child),\n (workInProgress.child = null))\n : ((revealOrder = renderLanes.sibling), (renderLanes.sibling = null));\n initSuspenseListRenderState(\n workInProgress,\n !1,\n revealOrder,\n renderLanes,\n tailMode\n );\n break;\n case \"backwards\":\n renderLanes = null;\n revealOrder = workInProgress.child;\n for (workInProgress.child = null; null !== revealOrder; ) {\n current = revealOrder.alternate;\n if (null !== current && null === findFirstSuspended(current)) {\n workInProgress.child = revealOrder;\n break;\n }\n current = revealOrder.sibling;\n revealOrder.sibling = renderLanes;\n renderLanes = revealOrder;\n revealOrder = current;\n }\n initSuspenseListRenderState(\n workInProgress,\n !0,\n renderLanes,\n null,\n tailMode\n );\n break;\n case \"together\":\n initSuspenseListRenderState(workInProgress, !1, null, null, void 0);\n break;\n default:\n workInProgress.memoizedState = null;\n }\n return workInProgress.child;\n}\nfunction resetSuspendedCurrentOnMountInLegacyMode(current, workInProgress) {\n 0 === (workInProgress.mode & 1) &&\n null !== current &&\n ((current.alternate = null),\n (workInProgress.alternate = null),\n (workInProgress.flags |= 2));\n}\nfunction bailoutOnAlreadyFinishedWork(current, workInProgress, renderLanes) {\n null !== current && (workInProgress.dependencies = current.dependencies);\n workInProgressRootSkippedLanes |= workInProgress.lanes;\n if (0 === (renderLanes & workInProgress.childLanes)) return null;\n if (null !== current && workInProgress.child !== current.child)\n throw Error(\"Resuming work not yet implemented.\");\n if (null !== workInProgress.child) {\n current = workInProgress.child;\n renderLanes = createWorkInProgress(current, current.pendingProps);\n workInProgress.child = renderLanes;\n for (renderLanes.return = workInProgress; null !== current.sibling; )\n (current = current.sibling),\n (renderLanes = renderLanes.sibling = createWorkInProgress(\n current,\n current.pendingProps\n )),\n (renderLanes.return = workInProgress);\n renderLanes.sibling = null;\n }\n return workInProgress.child;\n}\nfunction attemptEarlyBailoutIfNoScheduledUpdate(\n current,\n workInProgress,\n renderLanes\n) {\n switch (workInProgress.tag) {\n case 3:\n pushHostRootContext(workInProgress);\n break;\n case 5:\n pushHostContext(workInProgress);\n break;\n case 1:\n isContextProvider(workInProgress.type) &&\n pushContextProvider(workInProgress);\n break;\n case 4:\n pushHostContainer(workInProgress, workInProgress.stateNode.containerInfo);\n break;\n case 10:\n var context = workInProgress.type._context,\n nextValue = workInProgress.memoizedProps.value;\n push(valueCursor, context._currentValue);\n context._currentValue = nextValue;\n break;\n case 13:\n context = workInProgress.memoizedState;\n if (null !== context) {\n if (null !== context.dehydrated)\n return (\n push(suspenseStackCursor, suspenseStackCursor.current & 1),\n (workInProgress.flags |= 128),\n null\n );\n if (0 !== (renderLanes & workInProgress.child.childLanes))\n return updateSuspenseComponent(current, workInProgress, renderLanes);\n push(suspenseStackCursor, suspenseStackCursor.current & 1);\n current = bailoutOnAlreadyFinishedWork(\n current,\n workInProgress,\n renderLanes\n );\n return null !== current ? current.sibling : null;\n }\n push(suspenseStackCursor, suspenseStackCursor.current & 1);\n break;\n case 19:\n context = 0 !== (renderLanes & workInProgress.childLanes);\n if (0 !== (current.flags & 128)) {\n if (context)\n return updateSuspenseListComponent(\n current,\n workInProgress,\n renderLanes\n );\n workInProgress.flags |= 128;\n }\n nextValue = workInProgress.memoizedState;\n null !== nextValue &&\n ((nextValue.rendering = null),\n (nextValue.tail = null),\n (nextValue.lastEffect = null));\n push(suspenseStackCursor, suspenseStackCursor.current);\n if (context) break;\n else return null;\n case 22:\n case 23:\n return (\n (workInProgress.lanes = 0),\n updateOffscreenComponent(current, workInProgress, renderLanes)\n );\n }\n return bailoutOnAlreadyFinishedWork(current, workInProgress, renderLanes);\n}\nvar appendAllChildren,\n updateHostContainer,\n updateHostComponent$1,\n updateHostText$1;\nappendAllChildren = function(parent, workInProgress) {\n for (var node = workInProgress.child; null !== node; ) {\n if (5 === node.tag || 6 === node.tag) parent._children.push(node.stateNode);\n else if (4 !== node.tag && null !== node.child) {\n node.child.return = node;\n node = node.child;\n continue;\n }\n if (node === workInProgress) break;\n for (; null === node.sibling; ) {\n if (null === node.return || node.return === workInProgress) return;\n node = node.return;\n }\n node.sibling.return = node.return;\n node = node.sibling;\n }\n};\nupdateHostContainer = function() {};\nupdateHostComponent$1 = function(current, workInProgress, type, newProps) {\n current.memoizedProps !== newProps &&\n (requiredContext(contextStackCursor$1.current),\n (workInProgress.updateQueue = UPDATE_SIGNAL)) &&\n (workInProgress.flags |= 4);\n};\nupdateHostText$1 = function(current, workInProgress, oldText, newText) {\n oldText !== newText && (workInProgress.flags |= 4);\n};\nfunction cutOffTailIfNeeded(renderState, hasRenderedATailFallback) {\n switch (renderState.tailMode) {\n case \"hidden\":\n hasRenderedATailFallback = renderState.tail;\n for (var lastTailNode = null; null !== hasRenderedATailFallback; )\n null !== hasRenderedATailFallback.alternate &&\n (lastTailNode = hasRenderedATailFallback),\n (hasRenderedATailFallback = hasRenderedATailFallback.sibling);\n null === lastTailNode\n ? (renderState.tail = null)\n : (lastTailNode.sibling = null);\n break;\n case \"collapsed\":\n lastTailNode = renderState.tail;\n for (var lastTailNode$62 = null; null !== lastTailNode; )\n null !== lastTailNode.alternate && (lastTailNode$62 = lastTailNode),\n (lastTailNode = lastTailNode.sibling);\n null === lastTailNode$62\n ? hasRenderedATailFallback || null === renderState.tail\n ? (renderState.tail = null)\n : (renderState.tail.sibling = null)\n : (lastTailNode$62.sibling = null);\n }\n}\nfunction bubbleProperties(completedWork) {\n var didBailout =\n null !== completedWork.alternate &&\n completedWork.alternate.child === completedWork.child,\n newChildLanes = 0,\n subtreeFlags = 0;\n if (didBailout)\n for (var child$63 = completedWork.child; null !== child$63; )\n (newChildLanes |= child$63.lanes | child$63.childLanes),\n (subtreeFlags |= child$63.subtreeFlags & 14680064),\n (subtreeFlags |= child$63.flags & 14680064),\n (child$63.return = completedWork),\n (child$63 = child$63.sibling);\n else\n for (child$63 = completedWork.child; null !== child$63; )\n (newChildLanes |= child$63.lanes | child$63.childLanes),\n (subtreeFlags |= child$63.subtreeFlags),\n (subtreeFlags |= child$63.flags),\n (child$63.return = completedWork),\n (child$63 = child$63.sibling);\n completedWork.subtreeFlags |= subtreeFlags;\n completedWork.childLanes = newChildLanes;\n return didBailout;\n}\nfunction completeWork(current, workInProgress, renderLanes) {\n var newProps = workInProgress.pendingProps;\n popTreeContext(workInProgress);\n switch (workInProgress.tag) {\n case 2:\n case 16:\n case 15:\n case 0:\n case 11:\n case 7:\n case 8:\n case 12:\n case 9:\n case 14:\n return bubbleProperties(workInProgress), null;\n case 1:\n return (\n isContextProvider(workInProgress.type) && popContext(),\n bubbleProperties(workInProgress),\n null\n );\n case 3:\n return (\n (renderLanes = workInProgress.stateNode),\n popHostContainer(),\n pop(didPerformWorkStackCursor),\n pop(contextStackCursor),\n resetWorkInProgressVersions(),\n renderLanes.pendingContext &&\n ((renderLanes.context = renderLanes.pendingContext),\n (renderLanes.pendingContext = null)),\n (null !== current && null !== current.child) ||\n null === current ||\n (current.memoizedState.isDehydrated &&\n 0 === (workInProgress.flags & 256)) ||\n ((workInProgress.flags |= 1024),\n null !== hydrationErrors &&\n (queueRecoverableErrors(hydrationErrors),\n (hydrationErrors = null))),\n updateHostContainer(current, workInProgress),\n bubbleProperties(workInProgress),\n null\n );\n case 5:\n popHostContext(workInProgress);\n renderLanes = requiredContext(rootInstanceStackCursor.current);\n var type = workInProgress.type;\n if (null !== current && null != workInProgress.stateNode)\n updateHostComponent$1(\n current,\n workInProgress,\n type,\n newProps,\n renderLanes\n ),\n current.ref !== workInProgress.ref && (workInProgress.flags |= 512);\n else {\n if (!newProps) {\n if (null === workInProgress.stateNode)\n throw Error(\n \"We must have new props for new mounts. This error is likely caused by a bug in React. Please file an issue.\"\n );\n bubbleProperties(workInProgress);\n return null;\n }\n requiredContext(contextStackCursor$1.current);\n current = allocateTag();\n type = getViewConfigForType(type);\n var updatePayload = diffProperties(\n null,\n emptyObject,\n newProps,\n type.validAttributes\n );\n ReactNativePrivateInterface.UIManager.createView(\n current,\n type.uiViewClassName,\n renderLanes,\n updatePayload\n );\n renderLanes = new ReactNativeFiberHostComponent(\n current,\n type,\n workInProgress\n );\n instanceCache.set(current, workInProgress);\n instanceProps.set(current, newProps);\n appendAllChildren(renderLanes, workInProgress, !1, !1);\n workInProgress.stateNode = renderLanes;\n finalizeInitialChildren(renderLanes) && (workInProgress.flags |= 4);\n null !== workInProgress.ref && (workInProgress.flags |= 512);\n }\n bubbleProperties(workInProgress);\n return null;\n case 6:\n if (current && null != workInProgress.stateNode)\n updateHostText$1(\n current,\n workInProgress,\n current.memoizedProps,\n newProps\n );\n else {\n if (\"string\" !== typeof newProps && null === workInProgress.stateNode)\n throw Error(\n \"We must have new props for new mounts. This error is likely caused by a bug in React. Please file an issue.\"\n );\n current = requiredContext(rootInstanceStackCursor.current);\n if (!requiredContext(contextStackCursor$1.current).isInAParentText)\n throw Error(\n \"Text strings must be rendered within a component.\"\n );\n renderLanes = allocateTag();\n ReactNativePrivateInterface.UIManager.createView(\n renderLanes,\n \"RCTRawText\",\n current,\n { text: newProps }\n );\n instanceCache.set(renderLanes, workInProgress);\n workInProgress.stateNode = renderLanes;\n }\n bubbleProperties(workInProgress);\n return null;\n case 13:\n pop(suspenseStackCursor);\n newProps = workInProgress.memoizedState;\n if (\n null === current ||\n (null !== current.memoizedState &&\n null !== current.memoizedState.dehydrated)\n ) {\n if (null !== newProps && null !== newProps.dehydrated) {\n if (null === current) {\n throw Error(\n \"A dehydrated suspense component was completed without a hydrated node. This is probably a bug in React.\"\n );\n throw Error(\n \"Expected prepareToHydrateHostSuspenseInstance() to never be called. This error is likely caused by a bug in React. Please file an issue.\"\n );\n }\n 0 === (workInProgress.flags & 128) &&\n (workInProgress.memoizedState = null);\n workInProgress.flags |= 4;\n bubbleProperties(workInProgress);\n type = !1;\n } else\n null !== hydrationErrors &&\n (queueRecoverableErrors(hydrationErrors), (hydrationErrors = null)),\n (type = !0);\n if (!type) return workInProgress.flags & 65536 ? workInProgress : null;\n }\n if (0 !== (workInProgress.flags & 128))\n return (workInProgress.lanes = renderLanes), workInProgress;\n renderLanes = null !== newProps;\n renderLanes !== (null !== current && null !== current.memoizedState) &&\n renderLanes &&\n ((workInProgress.child.flags |= 8192),\n 0 !== (workInProgress.mode & 1) &&\n (null === current || 0 !== (suspenseStackCursor.current & 1)\n ? 0 === workInProgressRootExitStatus &&\n (workInProgressRootExitStatus = 3)\n : renderDidSuspendDelayIfPossible()));\n null !== workInProgress.updateQueue && (workInProgress.flags |= 4);\n bubbleProperties(workInProgress);\n return null;\n case 4:\n return (\n popHostContainer(),\n updateHostContainer(current, workInProgress),\n bubbleProperties(workInProgress),\n null\n );\n case 10:\n return (\n popProvider(workInProgress.type._context),\n bubbleProperties(workInProgress),\n null\n );\n case 17:\n return (\n isContextProvider(workInProgress.type) && popContext(),\n bubbleProperties(workInProgress),\n null\n );\n case 19:\n pop(suspenseStackCursor);\n type = workInProgress.memoizedState;\n if (null === type) return bubbleProperties(workInProgress), null;\n newProps = 0 !== (workInProgress.flags & 128);\n updatePayload = type.rendering;\n if (null === updatePayload)\n if (newProps) cutOffTailIfNeeded(type, !1);\n else {\n if (\n 0 !== workInProgressRootExitStatus ||\n (null !== current && 0 !== (current.flags & 128))\n )\n for (current = workInProgress.child; null !== current; ) {\n updatePayload = findFirstSuspended(current);\n if (null !== updatePayload) {\n workInProgress.flags |= 128;\n cutOffTailIfNeeded(type, !1);\n current = updatePayload.updateQueue;\n null !== current &&\n ((workInProgress.updateQueue = current),\n (workInProgress.flags |= 4));\n workInProgress.subtreeFlags = 0;\n current = renderLanes;\n for (renderLanes = workInProgress.child; null !== renderLanes; )\n (newProps = renderLanes),\n (type = current),\n (newProps.flags &= 14680066),\n (updatePayload = newProps.alternate),\n null === updatePayload\n ? ((newProps.childLanes = 0),\n (newProps.lanes = type),\n (newProps.child = null),\n (newProps.subtreeFlags = 0),\n (newProps.memoizedProps = null),\n (newProps.memoizedState = null),\n (newProps.updateQueue = null),\n (newProps.dependencies = null),\n (newProps.stateNode = null))\n : ((newProps.childLanes = updatePayload.childLanes),\n (newProps.lanes = updatePayload.lanes),\n (newProps.child = updatePayload.child),\n (newProps.subtreeFlags = 0),\n (newProps.deletions = null),\n (newProps.memoizedProps = updatePayload.memoizedProps),\n (newProps.memoizedState = updatePayload.memoizedState),\n (newProps.updateQueue = updatePayload.updateQueue),\n (newProps.type = updatePayload.type),\n (type = updatePayload.dependencies),\n (newProps.dependencies =\n null === type\n ? null\n : {\n lanes: type.lanes,\n firstContext: type.firstContext\n })),\n (renderLanes = renderLanes.sibling);\n push(\n suspenseStackCursor,\n (suspenseStackCursor.current & 1) | 2\n );\n return workInProgress.child;\n }\n current = current.sibling;\n }\n null !== type.tail &&\n now() > workInProgressRootRenderTargetTime &&\n ((workInProgress.flags |= 128),\n (newProps = !0),\n cutOffTailIfNeeded(type, !1),\n (workInProgress.lanes = 4194304));\n }\n else {\n if (!newProps)\n if (\n ((current = findFirstSuspended(updatePayload)), null !== current)\n ) {\n if (\n ((workInProgress.flags |= 128),\n (newProps = !0),\n (current = current.updateQueue),\n null !== current &&\n ((workInProgress.updateQueue = current),\n (workInProgress.flags |= 4)),\n cutOffTailIfNeeded(type, !0),\n null === type.tail &&\n \"hidden\" === type.tailMode &&\n !updatePayload.alternate)\n )\n return bubbleProperties(workInProgress), null;\n } else\n 2 * now() - type.renderingStartTime >\n workInProgressRootRenderTargetTime &&\n 1073741824 !== renderLanes &&\n ((workInProgress.flags |= 128),\n (newProps = !0),\n cutOffTailIfNeeded(type, !1),\n (workInProgress.lanes = 4194304));\n type.isBackwards\n ? ((updatePayload.sibling = workInProgress.child),\n (workInProgress.child = updatePayload))\n : ((current = type.last),\n null !== current\n ? (current.sibling = updatePayload)\n : (workInProgress.child = updatePayload),\n (type.last = updatePayload));\n }\n if (null !== type.tail)\n return (\n (workInProgress = type.tail),\n (type.rendering = workInProgress),\n (type.tail = workInProgress.sibling),\n (type.renderingStartTime = now()),\n (workInProgress.sibling = null),\n (current = suspenseStackCursor.current),\n push(suspenseStackCursor, newProps ? (current & 1) | 2 : current & 1),\n workInProgress\n );\n bubbleProperties(workInProgress);\n return null;\n case 22:\n case 23:\n return (\n popRenderLanes(),\n (renderLanes = null !== workInProgress.memoizedState),\n null !== current &&\n (null !== current.memoizedState) !== renderLanes &&\n (workInProgress.flags |= 8192),\n renderLanes && 0 !== (workInProgress.mode & 1)\n ? 0 !== (subtreeRenderLanes & 1073741824) &&\n (bubbleProperties(workInProgress),\n workInProgress.subtreeFlags & 6 && (workInProgress.flags |= 8192))\n : bubbleProperties(workInProgress),\n null\n );\n case 24:\n return null;\n case 25:\n return null;\n }\n throw Error(\n \"Unknown unit of work tag (\" +\n workInProgress.tag +\n \"). This error is likely caused by a bug in React. Please file an issue.\"\n );\n}\nfunction unwindWork(current, workInProgress) {\n popTreeContext(workInProgress);\n switch (workInProgress.tag) {\n case 1:\n return (\n isContextProvider(workInProgress.type) && popContext(),\n (current = workInProgress.flags),\n current & 65536\n ? ((workInProgress.flags = (current & -65537) | 128), workInProgress)\n : null\n );\n case 3:\n return (\n popHostContainer(),\n pop(didPerformWorkStackCursor),\n pop(contextStackCursor),\n resetWorkInProgressVersions(),\n (current = workInProgress.flags),\n 0 !== (current & 65536) && 0 === (current & 128)\n ? ((workInProgress.flags = (current & -65537) | 128), workInProgress)\n : null\n );\n case 5:\n return popHostContext(workInProgress), null;\n case 13:\n pop(suspenseStackCursor);\n current = workInProgress.memoizedState;\n if (\n null !== current &&\n null !== current.dehydrated &&\n null === workInProgress.alternate\n )\n throw Error(\n \"Threw in newly mounted dehydrated component. This is likely a bug in React. Please file an issue.\"\n );\n current = workInProgress.flags;\n return current & 65536\n ? ((workInProgress.flags = (current & -65537) | 128), workInProgress)\n : null;\n case 19:\n return pop(suspenseStackCursor), null;\n case 4:\n return popHostContainer(), null;\n case 10:\n return popProvider(workInProgress.type._context), null;\n case 22:\n case 23:\n return popRenderLanes(), null;\n case 24:\n return null;\n default:\n return null;\n }\n}\nvar PossiblyWeakSet = \"function\" === typeof WeakSet ? WeakSet : Set,\n nextEffect = null;\nfunction safelyDetachRef(current, nearestMountedAncestor) {\n var ref = current.ref;\n if (null !== ref)\n if (\"function\" === typeof ref)\n try {\n ref(null);\n } catch (error) {\n captureCommitPhaseError(current, nearestMountedAncestor, error);\n }\n else ref.current = null;\n}\nfunction safelyCallDestroy(current, nearestMountedAncestor, destroy) {\n try {\n destroy();\n } catch (error) {\n captureCommitPhaseError(current, nearestMountedAncestor, error);\n }\n}\nvar shouldFireAfterActiveInstanceBlur = !1;\nfunction commitBeforeMutationEffects(root, firstChild) {\n for (nextEffect = firstChild; null !== nextEffect; )\n if (\n ((root = nextEffect),\n (firstChild = root.child),\n 0 !== (root.subtreeFlags & 1028) && null !== firstChild)\n )\n (firstChild.return = root), (nextEffect = firstChild);\n else\n for (; null !== nextEffect; ) {\n root = nextEffect;\n try {\n var current = root.alternate;\n if (0 !== (root.flags & 1024))\n switch (root.tag) {\n case 0:\n case 11:\n case 15:\n break;\n case 1:\n if (null !== current) {\n var prevProps = current.memoizedProps,\n prevState = current.memoizedState,\n instance = root.stateNode,\n snapshot = instance.getSnapshotBeforeUpdate(\n root.elementType === root.type\n ? prevProps\n : resolveDefaultProps(root.type, prevProps),\n prevState\n );\n instance.__reactInternalSnapshotBeforeUpdate = snapshot;\n }\n break;\n case 3:\n break;\n case 5:\n case 6:\n case 4:\n case 17:\n break;\n default:\n throw Error(\n \"This unit of work tag should not have side-effects. This error is likely caused by a bug in React. Please file an issue.\"\n );\n }\n } catch (error) {\n captureCommitPhaseError(root, root.return, error);\n }\n firstChild = root.sibling;\n if (null !== firstChild) {\n firstChild.return = root.return;\n nextEffect = firstChild;\n break;\n }\n nextEffect = root.return;\n }\n current = shouldFireAfterActiveInstanceBlur;\n shouldFireAfterActiveInstanceBlur = !1;\n return current;\n}\nfunction commitHookEffectListUnmount(\n flags,\n finishedWork,\n nearestMountedAncestor\n) {\n var updateQueue = finishedWork.updateQueue;\n updateQueue = null !== updateQueue ? updateQueue.lastEffect : null;\n if (null !== updateQueue) {\n var effect = (updateQueue = updateQueue.next);\n do {\n if ((effect.tag & flags) === flags) {\n var destroy = effect.destroy;\n effect.destroy = void 0;\n void 0 !== destroy &&\n safelyCallDestroy(finishedWork, nearestMountedAncestor, destroy);\n }\n effect = effect.next;\n } while (effect !== updateQueue);\n }\n}\nfunction commitHookEffectListMount(flags, finishedWork) {\n finishedWork = finishedWork.updateQueue;\n finishedWork = null !== finishedWork ? finishedWork.lastEffect : null;\n if (null !== finishedWork) {\n var effect = (finishedWork = finishedWork.next);\n do {\n if ((effect.tag & flags) === flags) {\n var create$75 = effect.create;\n effect.destroy = create$75();\n }\n effect = effect.next;\n } while (effect !== finishedWork);\n }\n}\nfunction detachFiberAfterEffects(fiber) {\n var alternate = fiber.alternate;\n null !== alternate &&\n ((fiber.alternate = null), detachFiberAfterEffects(alternate));\n fiber.child = null;\n fiber.deletions = null;\n fiber.sibling = null;\n fiber.stateNode = null;\n fiber.return = null;\n fiber.dependencies = null;\n fiber.memoizedProps = null;\n fiber.memoizedState = null;\n fiber.pendingProps = null;\n fiber.stateNode = null;\n fiber.updateQueue = null;\n}\nfunction isHostParent(fiber) {\n return 5 === fiber.tag || 3 === fiber.tag || 4 === fiber.tag;\n}\nfunction getHostSibling(fiber) {\n a: for (;;) {\n for (; null === fiber.sibling; ) {\n if (null === fiber.return || isHostParent(fiber.return)) return null;\n fiber = fiber.return;\n }\n fiber.sibling.return = fiber.return;\n for (\n fiber = fiber.sibling;\n 5 !== fiber.tag && 6 !== fiber.tag && 18 !== fiber.tag;\n\n ) {\n if (fiber.flags & 2) continue a;\n if (null === fiber.child || 4 === fiber.tag) continue a;\n else (fiber.child.return = fiber), (fiber = fiber.child);\n }\n if (!(fiber.flags & 2)) return fiber.stateNode;\n }\n}\nfunction insertOrAppendPlacementNodeIntoContainer(node, before, parent) {\n var tag = node.tag;\n if (5 === tag || 6 === tag)\n if (((node = node.stateNode), before)) {\n if (\"number\" === typeof parent)\n throw Error(\"Container does not support insertBefore operation\");\n } else\n ReactNativePrivateInterface.UIManager.setChildren(parent, [\n \"number\" === typeof node ? node : node._nativeTag\n ]);\n else if (4 !== tag && ((node = node.child), null !== node))\n for (\n insertOrAppendPlacementNodeIntoContainer(node, before, parent),\n node = node.sibling;\n null !== node;\n\n )\n insertOrAppendPlacementNodeIntoContainer(node, before, parent),\n (node = node.sibling);\n}\nfunction insertOrAppendPlacementNode(node, before, parent) {\n var tag = node.tag;\n if (5 === tag || 6 === tag)\n if (((node = node.stateNode), before)) {\n tag = parent._children;\n var index = tag.indexOf(node);\n 0 <= index\n ? (tag.splice(index, 1),\n (before = tag.indexOf(before)),\n tag.splice(before, 0, node),\n ReactNativePrivateInterface.UIManager.manageChildren(\n parent._nativeTag,\n [index],\n [before],\n [],\n [],\n []\n ))\n : ((before = tag.indexOf(before)),\n tag.splice(before, 0, node),\n ReactNativePrivateInterface.UIManager.manageChildren(\n parent._nativeTag,\n [],\n [],\n [\"number\" === typeof node ? node : node._nativeTag],\n [before],\n []\n ));\n } else\n (before = \"number\" === typeof node ? node : node._nativeTag),\n (tag = parent._children),\n (index = tag.indexOf(node)),\n 0 <= index\n ? (tag.splice(index, 1),\n tag.push(node),\n ReactNativePrivateInterface.UIManager.manageChildren(\n parent._nativeTag,\n [index],\n [tag.length - 1],\n [],\n [],\n []\n ))\n : (tag.push(node),\n ReactNativePrivateInterface.UIManager.manageChildren(\n parent._nativeTag,\n [],\n [],\n [before],\n [tag.length - 1],\n []\n ));\n else if (4 !== tag && ((node = node.child), null !== node))\n for (\n insertOrAppendPlacementNode(node, before, parent), node = node.sibling;\n null !== node;\n\n )\n insertOrAppendPlacementNode(node, before, parent), (node = node.sibling);\n}\nvar hostParent = null,\n hostParentIsContainer = !1;\nfunction recursivelyTraverseDeletionEffects(\n finishedRoot,\n nearestMountedAncestor,\n parent\n) {\n for (parent = parent.child; null !== parent; )\n commitDeletionEffectsOnFiber(finishedRoot, nearestMountedAncestor, parent),\n (parent = parent.sibling);\n}\nfunction commitDeletionEffectsOnFiber(\n finishedRoot,\n nearestMountedAncestor,\n deletedFiber\n) {\n if (injectedHook && \"function\" === typeof injectedHook.onCommitFiberUnmount)\n try {\n injectedHook.onCommitFiberUnmount(rendererID, deletedFiber);\n } catch (err) {}\n switch (deletedFiber.tag) {\n case 5:\n safelyDetachRef(deletedFiber, nearestMountedAncestor);\n case 6:\n var prevHostParent = hostParent,\n prevHostParentIsContainer = hostParentIsContainer;\n hostParent = null;\n recursivelyTraverseDeletionEffects(\n finishedRoot,\n nearestMountedAncestor,\n deletedFiber\n );\n hostParent = prevHostParent;\n hostParentIsContainer = prevHostParentIsContainer;\n null !== hostParent &&\n (hostParentIsContainer\n ? ((finishedRoot = hostParent),\n recursivelyUncacheFiberNode(deletedFiber.stateNode),\n ReactNativePrivateInterface.UIManager.manageChildren(\n finishedRoot,\n [],\n [],\n [],\n [],\n [0]\n ))\n : ((finishedRoot = hostParent),\n (nearestMountedAncestor = deletedFiber.stateNode),\n recursivelyUncacheFiberNode(nearestMountedAncestor),\n (deletedFiber = finishedRoot._children),\n (nearestMountedAncestor = deletedFiber.indexOf(\n nearestMountedAncestor\n )),\n deletedFiber.splice(nearestMountedAncestor, 1),\n ReactNativePrivateInterface.UIManager.manageChildren(\n finishedRoot._nativeTag,\n [],\n [],\n [],\n [],\n [nearestMountedAncestor]\n )));\n break;\n case 18:\n null !== hostParent && shim(hostParent, deletedFiber.stateNode);\n break;\n case 4:\n prevHostParent = hostParent;\n prevHostParentIsContainer = hostParentIsContainer;\n hostParent = deletedFiber.stateNode.containerInfo;\n hostParentIsContainer = !0;\n recursivelyTraverseDeletionEffects(\n finishedRoot,\n nearestMountedAncestor,\n deletedFiber\n );\n hostParent = prevHostParent;\n hostParentIsContainer = prevHostParentIsContainer;\n break;\n case 0:\n case 11:\n case 14:\n case 15:\n prevHostParent = deletedFiber.updateQueue;\n if (\n null !== prevHostParent &&\n ((prevHostParent = prevHostParent.lastEffect), null !== prevHostParent)\n ) {\n prevHostParentIsContainer = prevHostParent = prevHostParent.next;\n do {\n var _effect = prevHostParentIsContainer,\n destroy = _effect.destroy;\n _effect = _effect.tag;\n void 0 !== destroy &&\n (0 !== (_effect & 2)\n ? safelyCallDestroy(deletedFiber, nearestMountedAncestor, destroy)\n : 0 !== (_effect & 4) &&\n safelyCallDestroy(\n deletedFiber,\n nearestMountedAncestor,\n destroy\n ));\n prevHostParentIsContainer = prevHostParentIsContainer.next;\n } while (prevHostParentIsContainer !== prevHostParent);\n }\n recursivelyTraverseDeletionEffects(\n finishedRoot,\n nearestMountedAncestor,\n deletedFiber\n );\n break;\n case 1:\n safelyDetachRef(deletedFiber, nearestMountedAncestor);\n prevHostParent = deletedFiber.stateNode;\n if (\"function\" === typeof prevHostParent.componentWillUnmount)\n try {\n (prevHostParent.props = deletedFiber.memoizedProps),\n (prevHostParent.state = deletedFiber.memoizedState),\n prevHostParent.componentWillUnmount();\n } catch (error) {\n captureCommitPhaseError(deletedFiber, nearestMountedAncestor, error);\n }\n recursivelyTraverseDeletionEffects(\n finishedRoot,\n nearestMountedAncestor,\n deletedFiber\n );\n break;\n case 21:\n recursivelyTraverseDeletionEffects(\n finishedRoot,\n nearestMountedAncestor,\n deletedFiber\n );\n break;\n case 22:\n recursivelyTraverseDeletionEffects(\n finishedRoot,\n nearestMountedAncestor,\n deletedFiber\n );\n break;\n default:\n recursivelyTraverseDeletionEffects(\n finishedRoot,\n nearestMountedAncestor,\n deletedFiber\n );\n }\n}\nfunction attachSuspenseRetryListeners(finishedWork) {\n var wakeables = finishedWork.updateQueue;\n if (null !== wakeables) {\n finishedWork.updateQueue = null;\n var retryCache = finishedWork.stateNode;\n null === retryCache &&\n (retryCache = finishedWork.stateNode = new PossiblyWeakSet());\n wakeables.forEach(function(wakeable) {\n var retry = resolveRetryWakeable.bind(null, finishedWork, wakeable);\n retryCache.has(wakeable) ||\n (retryCache.add(wakeable), wakeable.then(retry, retry));\n });\n }\n}\nfunction recursivelyTraverseMutationEffects(root$jscomp$0, parentFiber) {\n var deletions = parentFiber.deletions;\n if (null !== deletions)\n for (var i = 0; i < deletions.length; i++) {\n var childToDelete = deletions[i];\n try {\n var root = root$jscomp$0,\n returnFiber = parentFiber,\n parent = returnFiber;\n a: for (; null !== parent; ) {\n switch (parent.tag) {\n case 5:\n hostParent = parent.stateNode;\n hostParentIsContainer = !1;\n break a;\n case 3:\n hostParent = parent.stateNode.containerInfo;\n hostParentIsContainer = !0;\n break a;\n case 4:\n hostParent = parent.stateNode.containerInfo;\n hostParentIsContainer = !0;\n break a;\n }\n parent = parent.return;\n }\n if (null === hostParent)\n throw Error(\n \"Expected to find a host parent. This error is likely caused by a bug in React. Please file an issue.\"\n );\n commitDeletionEffectsOnFiber(root, returnFiber, childToDelete);\n hostParent = null;\n hostParentIsContainer = !1;\n var alternate = childToDelete.alternate;\n null !== alternate && (alternate.return = null);\n childToDelete.return = null;\n } catch (error) {\n captureCommitPhaseError(childToDelete, parentFiber, error);\n }\n }\n if (parentFiber.subtreeFlags & 12854)\n for (parentFiber = parentFiber.child; null !== parentFiber; )\n commitMutationEffectsOnFiber(parentFiber, root$jscomp$0),\n (parentFiber = parentFiber.sibling);\n}\nfunction commitMutationEffectsOnFiber(finishedWork, root) {\n var current = finishedWork.alternate,\n flags = finishedWork.flags;\n switch (finishedWork.tag) {\n case 0:\n case 11:\n case 14:\n case 15:\n recursivelyTraverseMutationEffects(root, finishedWork);\n commitReconciliationEffects(finishedWork);\n if (flags & 4) {\n try {\n commitHookEffectListUnmount(3, finishedWork, finishedWork.return),\n commitHookEffectListMount(3, finishedWork);\n } catch (error) {\n captureCommitPhaseError(finishedWork, finishedWork.return, error);\n }\n try {\n commitHookEffectListUnmount(5, finishedWork, finishedWork.return);\n } catch (error$85) {\n captureCommitPhaseError(finishedWork, finishedWork.return, error$85);\n }\n }\n break;\n case 1:\n recursivelyTraverseMutationEffects(root, finishedWork);\n commitReconciliationEffects(finishedWork);\n flags & 512 &&\n null !== current &&\n safelyDetachRef(current, current.return);\n break;\n case 5:\n recursivelyTraverseMutationEffects(root, finishedWork);\n commitReconciliationEffects(finishedWork);\n flags & 512 &&\n null !== current &&\n safelyDetachRef(current, current.return);\n if (flags & 4) {\n var instance$87 = finishedWork.stateNode;\n if (null != instance$87) {\n var newProps = finishedWork.memoizedProps,\n oldProps = null !== current ? current.memoizedProps : newProps,\n updatePayload = finishedWork.updateQueue;\n finishedWork.updateQueue = null;\n if (null !== updatePayload)\n try {\n var viewConfig = instance$87.viewConfig;\n instanceProps.set(instance$87._nativeTag, newProps);\n var updatePayload$jscomp$0 = diffProperties(\n null,\n oldProps,\n newProps,\n viewConfig.validAttributes\n );\n null != updatePayload$jscomp$0 &&\n ReactNativePrivateInterface.UIManager.updateView(\n instance$87._nativeTag,\n viewConfig.uiViewClassName,\n updatePayload$jscomp$0\n );\n } catch (error$88) {\n captureCommitPhaseError(\n finishedWork,\n finishedWork.return,\n error$88\n );\n }\n }\n }\n break;\n case 6:\n recursivelyTraverseMutationEffects(root, finishedWork);\n commitReconciliationEffects(finishedWork);\n if (flags & 4) {\n if (null === finishedWork.stateNode)\n throw Error(\n \"This should have a text node initialized. This error is likely caused by a bug in React. Please file an issue.\"\n );\n viewConfig = finishedWork.stateNode;\n updatePayload$jscomp$0 = finishedWork.memoizedProps;\n try {\n ReactNativePrivateInterface.UIManager.updateView(\n viewConfig,\n \"RCTRawText\",\n { text: updatePayload$jscomp$0 }\n );\n } catch (error$89) {\n captureCommitPhaseError(finishedWork, finishedWork.return, error$89);\n }\n }\n break;\n case 3:\n recursivelyTraverseMutationEffects(root, finishedWork);\n commitReconciliationEffects(finishedWork);\n break;\n case 4:\n recursivelyTraverseMutationEffects(root, finishedWork);\n commitReconciliationEffects(finishedWork);\n break;\n case 13:\n recursivelyTraverseMutationEffects(root, finishedWork);\n commitReconciliationEffects(finishedWork);\n viewConfig = finishedWork.child;\n viewConfig.flags & 8192 &&\n ((updatePayload$jscomp$0 = null !== viewConfig.memoizedState),\n (viewConfig.stateNode.isHidden = updatePayload$jscomp$0),\n !updatePayload$jscomp$0 ||\n (null !== viewConfig.alternate &&\n null !== viewConfig.alternate.memoizedState) ||\n (globalMostRecentFallbackTime = now()));\n flags & 4 && attachSuspenseRetryListeners(finishedWork);\n break;\n case 22:\n recursivelyTraverseMutationEffects(root, finishedWork);\n commitReconciliationEffects(finishedWork);\n if (flags & 8192)\n a: for (\n viewConfig = null !== finishedWork.memoizedState,\n finishedWork.stateNode.isHidden = viewConfig,\n updatePayload$jscomp$0 = null,\n current = finishedWork;\n ;\n\n ) {\n if (5 === current.tag) {\n if (null === updatePayload$jscomp$0) {\n updatePayload$jscomp$0 = current;\n try {\n if (((instance$87 = current.stateNode), viewConfig))\n (newProps = instance$87.viewConfig),\n (oldProps = diffProperties(\n null,\n emptyObject,\n { style: { display: \"none\" } },\n newProps.validAttributes\n )),\n ReactNativePrivateInterface.UIManager.updateView(\n instance$87._nativeTag,\n newProps.uiViewClassName,\n oldProps\n );\n else {\n updatePayload = current.stateNode;\n var props = current.memoizedProps,\n viewConfig$jscomp$0 = updatePayload.viewConfig,\n prevProps = assign({}, props, {\n style: [props.style, { display: \"none\" }]\n });\n var updatePayload$jscomp$1 = diffProperties(\n null,\n prevProps,\n props,\n viewConfig$jscomp$0.validAttributes\n );\n ReactNativePrivateInterface.UIManager.updateView(\n updatePayload._nativeTag,\n viewConfig$jscomp$0.uiViewClassName,\n updatePayload$jscomp$1\n );\n }\n } catch (error) {\n captureCommitPhaseError(\n finishedWork,\n finishedWork.return,\n error\n );\n }\n }\n } else if (6 === current.tag) {\n if (null === updatePayload$jscomp$0)\n try {\n throw Error(\"Not yet implemented.\");\n } catch (error$80) {\n captureCommitPhaseError(\n finishedWork,\n finishedWork.return,\n error$80\n );\n }\n } else if (\n ((22 !== current.tag && 23 !== current.tag) ||\n null === current.memoizedState ||\n current === finishedWork) &&\n null !== current.child\n ) {\n current.child.return = current;\n current = current.child;\n continue;\n }\n if (current === finishedWork) break a;\n for (; null === current.sibling; ) {\n if (null === current.return || current.return === finishedWork)\n break a;\n updatePayload$jscomp$0 === current &&\n (updatePayload$jscomp$0 = null);\n current = current.return;\n }\n updatePayload$jscomp$0 === current && (updatePayload$jscomp$0 = null);\n current.sibling.return = current.return;\n current = current.sibling;\n }\n break;\n case 19:\n recursivelyTraverseMutationEffects(root, finishedWork);\n commitReconciliationEffects(finishedWork);\n flags & 4 && attachSuspenseRetryListeners(finishedWork);\n break;\n case 21:\n break;\n default:\n recursivelyTraverseMutationEffects(root, finishedWork),\n commitReconciliationEffects(finishedWork);\n }\n}\nfunction commitReconciliationEffects(finishedWork) {\n var flags = finishedWork.flags;\n if (flags & 2) {\n try {\n a: {\n for (var parent = finishedWork.return; null !== parent; ) {\n if (isHostParent(parent)) {\n var JSCompiler_inline_result = parent;\n break a;\n }\n parent = parent.return;\n }\n throw Error(\n \"Expected to find a host parent. This error is likely caused by a bug in React. Please file an issue.\"\n );\n }\n switch (JSCompiler_inline_result.tag) {\n case 5:\n var parent$jscomp$0 = JSCompiler_inline_result.stateNode;\n JSCompiler_inline_result.flags & 32 &&\n (JSCompiler_inline_result.flags &= -33);\n var before = getHostSibling(finishedWork);\n insertOrAppendPlacementNode(finishedWork, before, parent$jscomp$0);\n break;\n case 3:\n case 4:\n var parent$81 = JSCompiler_inline_result.stateNode.containerInfo,\n before$82 = getHostSibling(finishedWork);\n insertOrAppendPlacementNodeIntoContainer(\n finishedWork,\n before$82,\n parent$81\n );\n break;\n default:\n throw Error(\n \"Invalid host parent fiber. This error is likely caused by a bug in React. Please file an issue.\"\n );\n }\n } catch (error) {\n captureCommitPhaseError(finishedWork, finishedWork.return, error);\n }\n finishedWork.flags &= -3;\n }\n flags & 4096 && (finishedWork.flags &= -4097);\n}\nfunction commitLayoutEffects(finishedWork) {\n for (nextEffect = finishedWork; null !== nextEffect; ) {\n var fiber = nextEffect,\n firstChild = fiber.child;\n if (0 !== (fiber.subtreeFlags & 8772) && null !== firstChild)\n (firstChild.return = fiber), (nextEffect = firstChild);\n else\n for (fiber = finishedWork; null !== nextEffect; ) {\n firstChild = nextEffect;\n if (0 !== (firstChild.flags & 8772)) {\n var current = firstChild.alternate;\n try {\n if (0 !== (firstChild.flags & 8772))\n switch (firstChild.tag) {\n case 0:\n case 11:\n case 15:\n commitHookEffectListMount(5, firstChild);\n break;\n case 1:\n var instance = firstChild.stateNode;\n if (firstChild.flags & 4)\n if (null === current) instance.componentDidMount();\n else {\n var prevProps =\n firstChild.elementType === firstChild.type\n ? current.memoizedProps\n : resolveDefaultProps(\n firstChild.type,\n current.memoizedProps\n );\n instance.componentDidUpdate(\n prevProps,\n current.memoizedState,\n instance.__reactInternalSnapshotBeforeUpdate\n );\n }\n var updateQueue = firstChild.updateQueue;\n null !== updateQueue &&\n commitUpdateQueue(firstChild, updateQueue, instance);\n break;\n case 3:\n var updateQueue$76 = firstChild.updateQueue;\n if (null !== updateQueue$76) {\n current = null;\n if (null !== firstChild.child)\n switch (firstChild.child.tag) {\n case 5:\n current = firstChild.child.stateNode;\n break;\n case 1:\n current = firstChild.child.stateNode;\n }\n commitUpdateQueue(firstChild, updateQueue$76, current);\n }\n break;\n case 5:\n break;\n case 6:\n break;\n case 4:\n break;\n case 12:\n break;\n case 13:\n break;\n case 19:\n case 17:\n case 21:\n case 22:\n case 23:\n case 25:\n break;\n default:\n throw Error(\n \"This unit of work tag should not have side-effects. This error is likely caused by a bug in React. Please file an issue.\"\n );\n }\n if (firstChild.flags & 512) {\n current = void 0;\n var ref = firstChild.ref;\n if (null !== ref) {\n var instance$jscomp$0 = firstChild.stateNode;\n switch (firstChild.tag) {\n case 5:\n current = instance$jscomp$0;\n break;\n default:\n current = instance$jscomp$0;\n }\n \"function\" === typeof ref\n ? ref(current)\n : (ref.current = current);\n }\n }\n } catch (error) {\n captureCommitPhaseError(firstChild, firstChild.return, error);\n }\n }\n if (firstChild === fiber) {\n nextEffect = null;\n break;\n }\n current = firstChild.sibling;\n if (null !== current) {\n current.return = firstChild.return;\n nextEffect = current;\n break;\n }\n nextEffect = firstChild.return;\n }\n }\n}\nvar ceil = Math.ceil,\n ReactCurrentDispatcher$2 = ReactSharedInternals.ReactCurrentDispatcher,\n ReactCurrentOwner$2 = ReactSharedInternals.ReactCurrentOwner,\n ReactCurrentBatchConfig$2 = ReactSharedInternals.ReactCurrentBatchConfig,\n executionContext = 0,\n workInProgressRoot = null,\n workInProgress = null,\n workInProgressRootRenderLanes = 0,\n subtreeRenderLanes = 0,\n subtreeRenderLanesCursor = createCursor(0),\n workInProgressRootExitStatus = 0,\n workInProgressRootFatalError = null,\n workInProgressRootSkippedLanes = 0,\n workInProgressRootInterleavedUpdatedLanes = 0,\n workInProgressRootPingedLanes = 0,\n workInProgressRootConcurrentErrors = null,\n workInProgressRootRecoverableErrors = null,\n globalMostRecentFallbackTime = 0,\n workInProgressRootRenderTargetTime = Infinity,\n workInProgressTransitions = null,\n hasUncaughtError = !1,\n firstUncaughtError = null,\n legacyErrorBoundariesThatAlreadyFailed = null,\n rootDoesHavePassiveEffects = !1,\n rootWithPendingPassiveEffects = null,\n pendingPassiveEffectsLanes = 0,\n nestedUpdateCount = 0,\n rootWithNestedUpdates = null,\n currentEventTime = -1,\n currentEventTransitionLane = 0;\nfunction requestEventTime() {\n return 0 !== (executionContext & 6)\n ? now()\n : -1 !== currentEventTime\n ? currentEventTime\n : (currentEventTime = now());\n}\nfunction requestUpdateLane(fiber) {\n if (0 === (fiber.mode & 1)) return 1;\n if (0 !== (executionContext & 2) && 0 !== workInProgressRootRenderLanes)\n return workInProgressRootRenderLanes & -workInProgressRootRenderLanes;\n if (null !== ReactCurrentBatchConfig.transition)\n return (\n 0 === currentEventTransitionLane &&\n (currentEventTransitionLane = claimNextTransitionLane()),\n currentEventTransitionLane\n );\n fiber = currentUpdatePriority;\n return 0 !== fiber ? fiber : 16;\n}\nfunction scheduleUpdateOnFiber(root, fiber, lane, eventTime) {\n if (50 < nestedUpdateCount)\n throw ((nestedUpdateCount = 0),\n (rootWithNestedUpdates = null),\n Error(\n \"Maximum update depth exceeded. This can happen when a component repeatedly calls setState inside componentWillUpdate or componentDidUpdate. React limits the number of nested updates to prevent infinite loops.\"\n ));\n markRootUpdated(root, lane, eventTime);\n if (0 === (executionContext & 2) || root !== workInProgressRoot)\n root === workInProgressRoot &&\n (0 === (executionContext & 2) &&\n (workInProgressRootInterleavedUpdatedLanes |= lane),\n 4 === workInProgressRootExitStatus &&\n markRootSuspended$1(root, workInProgressRootRenderLanes)),\n ensureRootIsScheduled(root, eventTime),\n 1 === lane &&\n 0 === executionContext &&\n 0 === (fiber.mode & 1) &&\n ((workInProgressRootRenderTargetTime = now() + 500),\n includesLegacySyncCallbacks && flushSyncCallbacks());\n}\nfunction ensureRootIsScheduled(root, currentTime) {\n for (\n var existingCallbackNode = root.callbackNode,\n suspendedLanes = root.suspendedLanes,\n pingedLanes = root.pingedLanes,\n expirationTimes = root.expirationTimes,\n lanes = root.pendingLanes;\n 0 < lanes;\n\n ) {\n var index$6 = 31 - clz32(lanes),\n lane = 1 << index$6,\n expirationTime = expirationTimes[index$6];\n if (-1 === expirationTime) {\n if (0 === (lane & suspendedLanes) || 0 !== (lane & pingedLanes))\n expirationTimes[index$6] = computeExpirationTime(lane, currentTime);\n } else expirationTime <= currentTime && (root.expiredLanes |= lane);\n lanes &= ~lane;\n }\n suspendedLanes = getNextLanes(\n root,\n root === workInProgressRoot ? workInProgressRootRenderLanes : 0\n );\n if (0 === suspendedLanes)\n null !== existingCallbackNode && cancelCallback(existingCallbackNode),\n (root.callbackNode = null),\n (root.callbackPriority = 0);\n else if (\n ((currentTime = suspendedLanes & -suspendedLanes),\n root.callbackPriority !== currentTime)\n ) {\n null != existingCallbackNode && cancelCallback(existingCallbackNode);\n if (1 === currentTime)\n 0 === root.tag\n ? ((existingCallbackNode = performSyncWorkOnRoot.bind(null, root)),\n (includesLegacySyncCallbacks = !0),\n null === syncQueue\n ? (syncQueue = [existingCallbackNode])\n : syncQueue.push(existingCallbackNode))\n : ((existingCallbackNode = performSyncWorkOnRoot.bind(null, root)),\n null === syncQueue\n ? (syncQueue = [existingCallbackNode])\n : syncQueue.push(existingCallbackNode)),\n scheduleCallback(ImmediatePriority, flushSyncCallbacks),\n (existingCallbackNode = null);\n else {\n switch (lanesToEventPriority(suspendedLanes)) {\n case 1:\n existingCallbackNode = ImmediatePriority;\n break;\n case 4:\n existingCallbackNode = UserBlockingPriority;\n break;\n case 16:\n existingCallbackNode = NormalPriority;\n break;\n case 536870912:\n existingCallbackNode = IdlePriority;\n break;\n default:\n existingCallbackNode = NormalPriority;\n }\n existingCallbackNode = scheduleCallback$1(\n existingCallbackNode,\n performConcurrentWorkOnRoot.bind(null, root)\n );\n }\n root.callbackPriority = currentTime;\n root.callbackNode = existingCallbackNode;\n }\n}\nfunction performConcurrentWorkOnRoot(root, didTimeout) {\n currentEventTime = -1;\n currentEventTransitionLane = 0;\n if (0 !== (executionContext & 6))\n throw Error(\"Should not already be working.\");\n var originalCallbackNode = root.callbackNode;\n if (flushPassiveEffects() && root.callbackNode !== originalCallbackNode)\n return null;\n var lanes = getNextLanes(\n root,\n root === workInProgressRoot ? workInProgressRootRenderLanes : 0\n );\n if (0 === lanes) return null;\n if (0 !== (lanes & 30) || 0 !== (lanes & root.expiredLanes) || didTimeout)\n didTimeout = renderRootSync(root, lanes);\n else {\n didTimeout = lanes;\n var prevExecutionContext = executionContext;\n executionContext |= 2;\n var prevDispatcher = pushDispatcher();\n if (\n workInProgressRoot !== root ||\n workInProgressRootRenderLanes !== didTimeout\n )\n (workInProgressTransitions = null),\n (workInProgressRootRenderTargetTime = now() + 500),\n prepareFreshStack(root, didTimeout);\n do\n try {\n workLoopConcurrent();\n break;\n } catch (thrownValue) {\n handleError(root, thrownValue);\n }\n while (1);\n resetContextDependencies();\n ReactCurrentDispatcher$2.current = prevDispatcher;\n executionContext = prevExecutionContext;\n null !== workInProgress\n ? (didTimeout = 0)\n : ((workInProgressRoot = null),\n (workInProgressRootRenderLanes = 0),\n (didTimeout = workInProgressRootExitStatus));\n }\n if (0 !== didTimeout) {\n 2 === didTimeout &&\n ((prevExecutionContext = getLanesToRetrySynchronouslyOnError(root)),\n 0 !== prevExecutionContext &&\n ((lanes = prevExecutionContext),\n (didTimeout = recoverFromConcurrentError(root, prevExecutionContext))));\n if (1 === didTimeout)\n throw ((originalCallbackNode = workInProgressRootFatalError),\n prepareFreshStack(root, 0),\n markRootSuspended$1(root, lanes),\n ensureRootIsScheduled(root, now()),\n originalCallbackNode);\n if (6 === didTimeout) markRootSuspended$1(root, lanes);\n else {\n prevExecutionContext = root.current.alternate;\n if (\n 0 === (lanes & 30) &&\n !isRenderConsistentWithExternalStores(prevExecutionContext) &&\n ((didTimeout = renderRootSync(root, lanes)),\n 2 === didTimeout &&\n ((prevDispatcher = getLanesToRetrySynchronouslyOnError(root)),\n 0 !== prevDispatcher &&\n ((lanes = prevDispatcher),\n (didTimeout = recoverFromConcurrentError(root, prevDispatcher)))),\n 1 === didTimeout)\n )\n throw ((originalCallbackNode = workInProgressRootFatalError),\n prepareFreshStack(root, 0),\n markRootSuspended$1(root, lanes),\n ensureRootIsScheduled(root, now()),\n originalCallbackNode);\n root.finishedWork = prevExecutionContext;\n root.finishedLanes = lanes;\n switch (didTimeout) {\n case 0:\n case 1:\n throw Error(\"Root did not complete. This is a bug in React.\");\n case 2:\n commitRoot(\n root,\n workInProgressRootRecoverableErrors,\n workInProgressTransitions\n );\n break;\n case 3:\n markRootSuspended$1(root, lanes);\n if (\n (lanes & 130023424) === lanes &&\n ((didTimeout = globalMostRecentFallbackTime + 500 - now()),\n 10 < didTimeout)\n ) {\n if (0 !== getNextLanes(root, 0)) break;\n prevExecutionContext = root.suspendedLanes;\n if ((prevExecutionContext & lanes) !== lanes) {\n requestEventTime();\n root.pingedLanes |= root.suspendedLanes & prevExecutionContext;\n break;\n }\n root.timeoutHandle = scheduleTimeout(\n commitRoot.bind(\n null,\n root,\n workInProgressRootRecoverableErrors,\n workInProgressTransitions\n ),\n didTimeout\n );\n break;\n }\n commitRoot(\n root,\n workInProgressRootRecoverableErrors,\n workInProgressTransitions\n );\n break;\n case 4:\n markRootSuspended$1(root, lanes);\n if ((lanes & 4194240) === lanes) break;\n didTimeout = root.eventTimes;\n for (prevExecutionContext = -1; 0 < lanes; ) {\n var index$5 = 31 - clz32(lanes);\n prevDispatcher = 1 << index$5;\n index$5 = didTimeout[index$5];\n index$5 > prevExecutionContext && (prevExecutionContext = index$5);\n lanes &= ~prevDispatcher;\n }\n lanes = prevExecutionContext;\n lanes = now() - lanes;\n lanes =\n (120 > lanes\n ? 120\n : 480 > lanes\n ? 480\n : 1080 > lanes\n ? 1080\n : 1920 > lanes\n ? 1920\n : 3e3 > lanes\n ? 3e3\n : 4320 > lanes\n ? 4320\n : 1960 * ceil(lanes / 1960)) - lanes;\n if (10 < lanes) {\n root.timeoutHandle = scheduleTimeout(\n commitRoot.bind(\n null,\n root,\n workInProgressRootRecoverableErrors,\n workInProgressTransitions\n ),\n lanes\n );\n break;\n }\n commitRoot(\n root,\n workInProgressRootRecoverableErrors,\n workInProgressTransitions\n );\n break;\n case 5:\n commitRoot(\n root,\n workInProgressRootRecoverableErrors,\n workInProgressTransitions\n );\n break;\n default:\n throw Error(\"Unknown root exit status.\");\n }\n }\n }\n ensureRootIsScheduled(root, now());\n return root.callbackNode === originalCallbackNode\n ? performConcurrentWorkOnRoot.bind(null, root)\n : null;\n}\nfunction recoverFromConcurrentError(root, errorRetryLanes) {\n var errorsFromFirstAttempt = workInProgressRootConcurrentErrors;\n root.current.memoizedState.isDehydrated &&\n (prepareFreshStack(root, errorRetryLanes).flags |= 256);\n root = renderRootSync(root, errorRetryLanes);\n 2 !== root &&\n ((errorRetryLanes = workInProgressRootRecoverableErrors),\n (workInProgressRootRecoverableErrors = errorsFromFirstAttempt),\n null !== errorRetryLanes && queueRecoverableErrors(errorRetryLanes));\n return root;\n}\nfunction queueRecoverableErrors(errors) {\n null === workInProgressRootRecoverableErrors\n ? (workInProgressRootRecoverableErrors = errors)\n : workInProgressRootRecoverableErrors.push.apply(\n workInProgressRootRecoverableErrors,\n errors\n );\n}\nfunction isRenderConsistentWithExternalStores(finishedWork) {\n for (var node = finishedWork; ; ) {\n if (node.flags & 16384) {\n var updateQueue = node.updateQueue;\n if (\n null !== updateQueue &&\n ((updateQueue = updateQueue.stores), null !== updateQueue)\n )\n for (var i = 0; i < updateQueue.length; i++) {\n var check = updateQueue[i],\n getSnapshot = check.getSnapshot;\n check = check.value;\n try {\n if (!objectIs(getSnapshot(), check)) return !1;\n } catch (error) {\n return !1;\n }\n }\n }\n updateQueue = node.child;\n if (node.subtreeFlags & 16384 && null !== updateQueue)\n (updateQueue.return = node), (node = updateQueue);\n else {\n if (node === finishedWork) break;\n for (; null === node.sibling; ) {\n if (null === node.return || node.return === finishedWork) return !0;\n node = node.return;\n }\n node.sibling.return = node.return;\n node = node.sibling;\n }\n }\n return !0;\n}\nfunction markRootSuspended$1(root, suspendedLanes) {\n suspendedLanes &= ~workInProgressRootPingedLanes;\n suspendedLanes &= ~workInProgressRootInterleavedUpdatedLanes;\n root.suspendedLanes |= suspendedLanes;\n root.pingedLanes &= ~suspendedLanes;\n for (root = root.expirationTimes; 0 < suspendedLanes; ) {\n var index$7 = 31 - clz32(suspendedLanes),\n lane = 1 << index$7;\n root[index$7] = -1;\n suspendedLanes &= ~lane;\n }\n}\nfunction performSyncWorkOnRoot(root) {\n if (0 !== (executionContext & 6))\n throw Error(\"Should not already be working.\");\n flushPassiveEffects();\n var lanes = getNextLanes(root, 0);\n if (0 === (lanes & 1)) return ensureRootIsScheduled(root, now()), null;\n var exitStatus = renderRootSync(root, lanes);\n if (0 !== root.tag && 2 === exitStatus) {\n var errorRetryLanes = getLanesToRetrySynchronouslyOnError(root);\n 0 !== errorRetryLanes &&\n ((lanes = errorRetryLanes),\n (exitStatus = recoverFromConcurrentError(root, errorRetryLanes)));\n }\n if (1 === exitStatus)\n throw ((exitStatus = workInProgressRootFatalError),\n prepareFreshStack(root, 0),\n markRootSuspended$1(root, lanes),\n ensureRootIsScheduled(root, now()),\n exitStatus);\n if (6 === exitStatus)\n throw Error(\"Root did not complete. This is a bug in React.\");\n root.finishedWork = root.current.alternate;\n root.finishedLanes = lanes;\n commitRoot(\n root,\n workInProgressRootRecoverableErrors,\n workInProgressTransitions\n );\n ensureRootIsScheduled(root, now());\n return null;\n}\nfunction popRenderLanes() {\n subtreeRenderLanes = subtreeRenderLanesCursor.current;\n pop(subtreeRenderLanesCursor);\n}\nfunction prepareFreshStack(root, lanes) {\n root.finishedWork = null;\n root.finishedLanes = 0;\n var timeoutHandle = root.timeoutHandle;\n -1 !== timeoutHandle &&\n ((root.timeoutHandle = -1), cancelTimeout(timeoutHandle));\n if (null !== workInProgress)\n for (timeoutHandle = workInProgress.return; null !== timeoutHandle; ) {\n var interruptedWork = timeoutHandle;\n popTreeContext(interruptedWork);\n switch (interruptedWork.tag) {\n case 1:\n interruptedWork = interruptedWork.type.childContextTypes;\n null !== interruptedWork &&\n void 0 !== interruptedWork &&\n popContext();\n break;\n case 3:\n popHostContainer();\n pop(didPerformWorkStackCursor);\n pop(contextStackCursor);\n resetWorkInProgressVersions();\n break;\n case 5:\n popHostContext(interruptedWork);\n break;\n case 4:\n popHostContainer();\n break;\n case 13:\n pop(suspenseStackCursor);\n break;\n case 19:\n pop(suspenseStackCursor);\n break;\n case 10:\n popProvider(interruptedWork.type._context);\n break;\n case 22:\n case 23:\n popRenderLanes();\n }\n timeoutHandle = timeoutHandle.return;\n }\n workInProgressRoot = root;\n workInProgress = root = createWorkInProgress(root.current, null);\n workInProgressRootRenderLanes = subtreeRenderLanes = lanes;\n workInProgressRootExitStatus = 0;\n workInProgressRootFatalError = null;\n workInProgressRootPingedLanes = workInProgressRootInterleavedUpdatedLanes = workInProgressRootSkippedLanes = 0;\n workInProgressRootRecoverableErrors = workInProgressRootConcurrentErrors = null;\n if (null !== concurrentQueues) {\n for (lanes = 0; lanes < concurrentQueues.length; lanes++)\n if (\n ((timeoutHandle = concurrentQueues[lanes]),\n (interruptedWork = timeoutHandle.interleaved),\n null !== interruptedWork)\n ) {\n timeoutHandle.interleaved = null;\n var firstInterleavedUpdate = interruptedWork.next,\n lastPendingUpdate = timeoutHandle.pending;\n if (null !== lastPendingUpdate) {\n var firstPendingUpdate = lastPendingUpdate.next;\n lastPendingUpdate.next = firstInterleavedUpdate;\n interruptedWork.next = firstPendingUpdate;\n }\n timeoutHandle.pending = interruptedWork;\n }\n concurrentQueues = null;\n }\n return root;\n}\nfunction handleError(root$jscomp$0, thrownValue) {\n do {\n var erroredWork = workInProgress;\n try {\n resetContextDependencies();\n ReactCurrentDispatcher$1.current = ContextOnlyDispatcher;\n if (didScheduleRenderPhaseUpdate) {\n for (\n var hook = currentlyRenderingFiber$1.memoizedState;\n null !== hook;\n\n ) {\n var queue = hook.queue;\n null !== queue && (queue.pending = null);\n hook = hook.next;\n }\n didScheduleRenderPhaseUpdate = !1;\n }\n renderLanes = 0;\n workInProgressHook = currentHook = currentlyRenderingFiber$1 = null;\n didScheduleRenderPhaseUpdateDuringThisPass = !1;\n ReactCurrentOwner$2.current = null;\n if (null === erroredWork || null === erroredWork.return) {\n workInProgressRootExitStatus = 1;\n workInProgressRootFatalError = thrownValue;\n workInProgress = null;\n break;\n }\n a: {\n var root = root$jscomp$0,\n returnFiber = erroredWork.return,\n sourceFiber = erroredWork,\n value = thrownValue;\n thrownValue = workInProgressRootRenderLanes;\n sourceFiber.flags |= 32768;\n if (\n null !== value &&\n \"object\" === typeof value &&\n \"function\" === typeof value.then\n ) {\n var wakeable = value,\n sourceFiber$jscomp$0 = sourceFiber,\n tag = sourceFiber$jscomp$0.tag;\n if (\n 0 === (sourceFiber$jscomp$0.mode & 1) &&\n (0 === tag || 11 === tag || 15 === tag)\n ) {\n var currentSource = sourceFiber$jscomp$0.alternate;\n currentSource\n ? ((sourceFiber$jscomp$0.updateQueue = currentSource.updateQueue),\n (sourceFiber$jscomp$0.memoizedState =\n currentSource.memoizedState),\n (sourceFiber$jscomp$0.lanes = currentSource.lanes))\n : ((sourceFiber$jscomp$0.updateQueue = null),\n (sourceFiber$jscomp$0.memoizedState = null));\n }\n b: {\n sourceFiber$jscomp$0 = returnFiber;\n do {\n var JSCompiler_temp;\n if ((JSCompiler_temp = 13 === sourceFiber$jscomp$0.tag)) {\n var nextState = sourceFiber$jscomp$0.memoizedState;\n JSCompiler_temp =\n null !== nextState\n ? null !== nextState.dehydrated\n ? !0\n : !1\n : !0;\n }\n if (JSCompiler_temp) {\n var suspenseBoundary = sourceFiber$jscomp$0;\n break b;\n }\n sourceFiber$jscomp$0 = sourceFiber$jscomp$0.return;\n } while (null !== sourceFiber$jscomp$0);\n suspenseBoundary = null;\n }\n if (null !== suspenseBoundary) {\n suspenseBoundary.flags &= -257;\n value = suspenseBoundary;\n sourceFiber$jscomp$0 = thrownValue;\n if (0 === (value.mode & 1))\n if (value === returnFiber) value.flags |= 65536;\n else {\n value.flags |= 128;\n sourceFiber.flags |= 131072;\n sourceFiber.flags &= -52805;\n if (1 === sourceFiber.tag)\n if (null === sourceFiber.alternate) sourceFiber.tag = 17;\n else {\n var update = createUpdate(-1, 1);\n update.tag = 2;\n enqueueUpdate(sourceFiber, update, 1);\n }\n sourceFiber.lanes |= 1;\n }\n else (value.flags |= 65536), (value.lanes = sourceFiber$jscomp$0);\n suspenseBoundary.mode & 1 &&\n attachPingListener(root, wakeable, thrownValue);\n thrownValue = suspenseBoundary;\n root = wakeable;\n var wakeables = thrownValue.updateQueue;\n if (null === wakeables) {\n var updateQueue = new Set();\n updateQueue.add(root);\n thrownValue.updateQueue = updateQueue;\n } else wakeables.add(root);\n break a;\n } else {\n if (0 === (thrownValue & 1)) {\n attachPingListener(root, wakeable, thrownValue);\n renderDidSuspendDelayIfPossible();\n break a;\n }\n value = Error(\n \"A component suspended while responding to synchronous input. This will cause the UI to be replaced with a loading indicator. To fix, updates that suspend should be wrapped with startTransition.\"\n );\n }\n }\n root = value = createCapturedValueAtFiber(value, sourceFiber);\n 4 !== workInProgressRootExitStatus &&\n (workInProgressRootExitStatus = 2);\n null === workInProgressRootConcurrentErrors\n ? (workInProgressRootConcurrentErrors = [root])\n : workInProgressRootConcurrentErrors.push(root);\n root = returnFiber;\n do {\n switch (root.tag) {\n case 3:\n wakeable = value;\n root.flags |= 65536;\n thrownValue &= -thrownValue;\n root.lanes |= thrownValue;\n var update$jscomp$0 = createRootErrorUpdate(\n root,\n wakeable,\n thrownValue\n );\n enqueueCapturedUpdate(root, update$jscomp$0);\n break a;\n case 1:\n wakeable = value;\n var ctor = root.type,\n instance = root.stateNode;\n if (\n 0 === (root.flags & 128) &&\n (\"function\" === typeof ctor.getDerivedStateFromError ||\n (null !== instance &&\n \"function\" === typeof instance.componentDidCatch &&\n (null === legacyErrorBoundariesThatAlreadyFailed ||\n !legacyErrorBoundariesThatAlreadyFailed.has(instance))))\n ) {\n root.flags |= 65536;\n thrownValue &= -thrownValue;\n root.lanes |= thrownValue;\n var update$34 = createClassErrorUpdate(\n root,\n wakeable,\n thrownValue\n );\n enqueueCapturedUpdate(root, update$34);\n break a;\n }\n }\n root = root.return;\n } while (null !== root);\n }\n completeUnitOfWork(erroredWork);\n } catch (yetAnotherThrownValue) {\n thrownValue = yetAnotherThrownValue;\n workInProgress === erroredWork &&\n null !== erroredWork &&\n (workInProgress = erroredWork = erroredWork.return);\n continue;\n }\n break;\n } while (1);\n}\nfunction pushDispatcher() {\n var prevDispatcher = ReactCurrentDispatcher$2.current;\n ReactCurrentDispatcher$2.current = ContextOnlyDispatcher;\n return null === prevDispatcher ? ContextOnlyDispatcher : prevDispatcher;\n}\nfunction renderDidSuspendDelayIfPossible() {\n if (\n 0 === workInProgressRootExitStatus ||\n 3 === workInProgressRootExitStatus ||\n 2 === workInProgressRootExitStatus\n )\n workInProgressRootExitStatus = 4;\n null === workInProgressRoot ||\n (0 === (workInProgressRootSkippedLanes & 268435455) &&\n 0 === (workInProgressRootInterleavedUpdatedLanes & 268435455)) ||\n markRootSuspended$1(workInProgressRoot, workInProgressRootRenderLanes);\n}\nfunction renderRootSync(root, lanes) {\n var prevExecutionContext = executionContext;\n executionContext |= 2;\n var prevDispatcher = pushDispatcher();\n if (workInProgressRoot !== root || workInProgressRootRenderLanes !== lanes)\n (workInProgressTransitions = null), prepareFreshStack(root, lanes);\n do\n try {\n workLoopSync();\n break;\n } catch (thrownValue) {\n handleError(root, thrownValue);\n }\n while (1);\n resetContextDependencies();\n executionContext = prevExecutionContext;\n ReactCurrentDispatcher$2.current = prevDispatcher;\n if (null !== workInProgress)\n throw Error(\n \"Cannot commit an incomplete root. This error is likely caused by a bug in React. Please file an issue.\"\n );\n workInProgressRoot = null;\n workInProgressRootRenderLanes = 0;\n return workInProgressRootExitStatus;\n}\nfunction workLoopSync() {\n for (; null !== workInProgress; ) performUnitOfWork(workInProgress);\n}\nfunction workLoopConcurrent() {\n for (; null !== workInProgress && !shouldYield(); )\n performUnitOfWork(workInProgress);\n}\nfunction performUnitOfWork(unitOfWork) {\n var next = beginWork$1(unitOfWork.alternate, unitOfWork, subtreeRenderLanes);\n unitOfWork.memoizedProps = unitOfWork.pendingProps;\n null === next ? completeUnitOfWork(unitOfWork) : (workInProgress = next);\n ReactCurrentOwner$2.current = null;\n}\nfunction completeUnitOfWork(unitOfWork) {\n var completedWork = unitOfWork;\n do {\n var current = completedWork.alternate;\n unitOfWork = completedWork.return;\n if (0 === (completedWork.flags & 32768)) {\n if (\n ((current = completeWork(current, completedWork, subtreeRenderLanes)),\n null !== current)\n ) {\n workInProgress = current;\n return;\n }\n } else {\n current = unwindWork(current, completedWork);\n if (null !== current) {\n current.flags &= 32767;\n workInProgress = current;\n return;\n }\n if (null !== unitOfWork)\n (unitOfWork.flags |= 32768),\n (unitOfWork.subtreeFlags = 0),\n (unitOfWork.deletions = null);\n else {\n workInProgressRootExitStatus = 6;\n workInProgress = null;\n return;\n }\n }\n completedWork = completedWork.sibling;\n if (null !== completedWork) {\n workInProgress = completedWork;\n return;\n }\n workInProgress = completedWork = unitOfWork;\n } while (null !== completedWork);\n 0 === workInProgressRootExitStatus && (workInProgressRootExitStatus = 5);\n}\nfunction commitRoot(root, recoverableErrors, transitions) {\n var previousUpdateLanePriority = currentUpdatePriority,\n prevTransition = ReactCurrentBatchConfig$2.transition;\n try {\n (ReactCurrentBatchConfig$2.transition = null),\n (currentUpdatePriority = 1),\n commitRootImpl(\n root,\n recoverableErrors,\n transitions,\n previousUpdateLanePriority\n );\n } finally {\n (ReactCurrentBatchConfig$2.transition = prevTransition),\n (currentUpdatePriority = previousUpdateLanePriority);\n }\n return null;\n}\nfunction commitRootImpl(\n root,\n recoverableErrors,\n transitions,\n renderPriorityLevel\n) {\n do flushPassiveEffects();\n while (null !== rootWithPendingPassiveEffects);\n if (0 !== (executionContext & 6))\n throw Error(\"Should not already be working.\");\n transitions = root.finishedWork;\n var lanes = root.finishedLanes;\n if (null === transitions) return null;\n root.finishedWork = null;\n root.finishedLanes = 0;\n if (transitions === root.current)\n throw Error(\n \"Cannot commit the same tree as before. This error is likely caused by a bug in React. Please file an issue.\"\n );\n root.callbackNode = null;\n root.callbackPriority = 0;\n var remainingLanes = transitions.lanes | transitions.childLanes;\n markRootFinished(root, remainingLanes);\n root === workInProgressRoot &&\n ((workInProgress = workInProgressRoot = null),\n (workInProgressRootRenderLanes = 0));\n (0 === (transitions.subtreeFlags & 2064) &&\n 0 === (transitions.flags & 2064)) ||\n rootDoesHavePassiveEffects ||\n ((rootDoesHavePassiveEffects = !0),\n scheduleCallback$1(NormalPriority, function() {\n flushPassiveEffects();\n return null;\n }));\n remainingLanes = 0 !== (transitions.flags & 15990);\n if (0 !== (transitions.subtreeFlags & 15990) || remainingLanes) {\n remainingLanes = ReactCurrentBatchConfig$2.transition;\n ReactCurrentBatchConfig$2.transition = null;\n var previousPriority = currentUpdatePriority;\n currentUpdatePriority = 1;\n var prevExecutionContext = executionContext;\n executionContext |= 4;\n ReactCurrentOwner$2.current = null;\n commitBeforeMutationEffects(root, transitions);\n commitMutationEffectsOnFiber(transitions, root);\n root.current = transitions;\n commitLayoutEffects(transitions, root, lanes);\n requestPaint();\n executionContext = prevExecutionContext;\n currentUpdatePriority = previousPriority;\n ReactCurrentBatchConfig$2.transition = remainingLanes;\n } else root.current = transitions;\n rootDoesHavePassiveEffects &&\n ((rootDoesHavePassiveEffects = !1),\n (rootWithPendingPassiveEffects = root),\n (pendingPassiveEffectsLanes = lanes));\n remainingLanes = root.pendingLanes;\n 0 === remainingLanes && (legacyErrorBoundariesThatAlreadyFailed = null);\n onCommitRoot(transitions.stateNode, renderPriorityLevel);\n ensureRootIsScheduled(root, now());\n if (null !== recoverableErrors)\n for (\n renderPriorityLevel = root.onRecoverableError, transitions = 0;\n transitions < recoverableErrors.length;\n transitions++\n )\n (lanes = recoverableErrors[transitions]),\n renderPriorityLevel(lanes.value, {\n componentStack: lanes.stack,\n digest: lanes.digest\n });\n if (hasUncaughtError)\n throw ((hasUncaughtError = !1),\n (root = firstUncaughtError),\n (firstUncaughtError = null),\n root);\n 0 !== (pendingPassiveEffectsLanes & 1) &&\n 0 !== root.tag &&\n flushPassiveEffects();\n remainingLanes = root.pendingLanes;\n 0 !== (remainingLanes & 1)\n ? root === rootWithNestedUpdates\n ? nestedUpdateCount++\n : ((nestedUpdateCount = 0), (rootWithNestedUpdates = root))\n : (nestedUpdateCount = 0);\n flushSyncCallbacks();\n return null;\n}\nfunction flushPassiveEffects() {\n if (null !== rootWithPendingPassiveEffects) {\n var renderPriority = lanesToEventPriority(pendingPassiveEffectsLanes),\n prevTransition = ReactCurrentBatchConfig$2.transition,\n previousPriority = currentUpdatePriority;\n try {\n ReactCurrentBatchConfig$2.transition = null;\n currentUpdatePriority = 16 > renderPriority ? 16 : renderPriority;\n if (null === rootWithPendingPassiveEffects)\n var JSCompiler_inline_result = !1;\n else {\n renderPriority = rootWithPendingPassiveEffects;\n rootWithPendingPassiveEffects = null;\n pendingPassiveEffectsLanes = 0;\n if (0 !== (executionContext & 6))\n throw Error(\"Cannot flush passive effects while already rendering.\");\n var prevExecutionContext = executionContext;\n executionContext |= 4;\n for (nextEffect = renderPriority.current; null !== nextEffect; ) {\n var fiber = nextEffect,\n child = fiber.child;\n if (0 !== (nextEffect.flags & 16)) {\n var deletions = fiber.deletions;\n if (null !== deletions) {\n for (var i = 0; i < deletions.length; i++) {\n var fiberToDelete = deletions[i];\n for (nextEffect = fiberToDelete; null !== nextEffect; ) {\n var fiber$jscomp$0 = nextEffect;\n switch (fiber$jscomp$0.tag) {\n case 0:\n case 11:\n case 15:\n commitHookEffectListUnmount(8, fiber$jscomp$0, fiber);\n }\n var child$jscomp$0 = fiber$jscomp$0.child;\n if (null !== child$jscomp$0)\n (child$jscomp$0.return = fiber$jscomp$0),\n (nextEffect = child$jscomp$0);\n else\n for (; null !== nextEffect; ) {\n fiber$jscomp$0 = nextEffect;\n var sibling = fiber$jscomp$0.sibling,\n returnFiber = fiber$jscomp$0.return;\n detachFiberAfterEffects(fiber$jscomp$0);\n if (fiber$jscomp$0 === fiberToDelete) {\n nextEffect = null;\n break;\n }\n if (null !== sibling) {\n sibling.return = returnFiber;\n nextEffect = sibling;\n break;\n }\n nextEffect = returnFiber;\n }\n }\n }\n var previousFiber = fiber.alternate;\n if (null !== previousFiber) {\n var detachedChild = previousFiber.child;\n if (null !== detachedChild) {\n previousFiber.child = null;\n do {\n var detachedSibling = detachedChild.sibling;\n detachedChild.sibling = null;\n detachedChild = detachedSibling;\n } while (null !== detachedChild);\n }\n }\n nextEffect = fiber;\n }\n }\n if (0 !== (fiber.subtreeFlags & 2064) && null !== child)\n (child.return = fiber), (nextEffect = child);\n else\n b: for (; null !== nextEffect; ) {\n fiber = nextEffect;\n if (0 !== (fiber.flags & 2048))\n switch (fiber.tag) {\n case 0:\n case 11:\n case 15:\n commitHookEffectListUnmount(9, fiber, fiber.return);\n }\n var sibling$jscomp$0 = fiber.sibling;\n if (null !== sibling$jscomp$0) {\n sibling$jscomp$0.return = fiber.return;\n nextEffect = sibling$jscomp$0;\n break b;\n }\n nextEffect = fiber.return;\n }\n }\n var finishedWork = renderPriority.current;\n for (nextEffect = finishedWork; null !== nextEffect; ) {\n child = nextEffect;\n var firstChild = child.child;\n if (0 !== (child.subtreeFlags & 2064) && null !== firstChild)\n (firstChild.return = child), (nextEffect = firstChild);\n else\n b: for (child = finishedWork; null !== nextEffect; ) {\n deletions = nextEffect;\n if (0 !== (deletions.flags & 2048))\n try {\n switch (deletions.tag) {\n case 0:\n case 11:\n case 15:\n commitHookEffectListMount(9, deletions);\n }\n } catch (error) {\n captureCommitPhaseError(deletions, deletions.return, error);\n }\n if (deletions === child) {\n nextEffect = null;\n break b;\n }\n var sibling$jscomp$1 = deletions.sibling;\n if (null !== sibling$jscomp$1) {\n sibling$jscomp$1.return = deletions.return;\n nextEffect = sibling$jscomp$1;\n break b;\n }\n nextEffect = deletions.return;\n }\n }\n executionContext = prevExecutionContext;\n flushSyncCallbacks();\n if (\n injectedHook &&\n \"function\" === typeof injectedHook.onPostCommitFiberRoot\n )\n try {\n injectedHook.onPostCommitFiberRoot(rendererID, renderPriority);\n } catch (err) {}\n JSCompiler_inline_result = !0;\n }\n return JSCompiler_inline_result;\n } finally {\n (currentUpdatePriority = previousPriority),\n (ReactCurrentBatchConfig$2.transition = prevTransition);\n }\n }\n return !1;\n}\nfunction captureCommitPhaseErrorOnRoot(rootFiber, sourceFiber, error) {\n sourceFiber = createCapturedValueAtFiber(error, sourceFiber);\n sourceFiber = createRootErrorUpdate(rootFiber, sourceFiber, 1);\n rootFiber = enqueueUpdate(rootFiber, sourceFiber, 1);\n sourceFiber = requestEventTime();\n null !== rootFiber &&\n (markRootUpdated(rootFiber, 1, sourceFiber),\n ensureRootIsScheduled(rootFiber, sourceFiber));\n}\nfunction captureCommitPhaseError(sourceFiber, nearestMountedAncestor, error) {\n if (3 === sourceFiber.tag)\n captureCommitPhaseErrorOnRoot(sourceFiber, sourceFiber, error);\n else\n for (\n nearestMountedAncestor = sourceFiber.return;\n null !== nearestMountedAncestor;\n\n ) {\n if (3 === nearestMountedAncestor.tag) {\n captureCommitPhaseErrorOnRoot(\n nearestMountedAncestor,\n sourceFiber,\n error\n );\n break;\n } else if (1 === nearestMountedAncestor.tag) {\n var instance = nearestMountedAncestor.stateNode;\n if (\n \"function\" ===\n typeof nearestMountedAncestor.type.getDerivedStateFromError ||\n (\"function\" === typeof instance.componentDidCatch &&\n (null === legacyErrorBoundariesThatAlreadyFailed ||\n !legacyErrorBoundariesThatAlreadyFailed.has(instance)))\n ) {\n sourceFiber = createCapturedValueAtFiber(error, sourceFiber);\n sourceFiber = createClassErrorUpdate(\n nearestMountedAncestor,\n sourceFiber,\n 1\n );\n nearestMountedAncestor = enqueueUpdate(\n nearestMountedAncestor,\n sourceFiber,\n 1\n );\n sourceFiber = requestEventTime();\n null !== nearestMountedAncestor &&\n (markRootUpdated(nearestMountedAncestor, 1, sourceFiber),\n ensureRootIsScheduled(nearestMountedAncestor, sourceFiber));\n break;\n }\n }\n nearestMountedAncestor = nearestMountedAncestor.return;\n }\n}\nfunction pingSuspendedRoot(root, wakeable, pingedLanes) {\n var pingCache = root.pingCache;\n null !== pingCache && pingCache.delete(wakeable);\n wakeable = requestEventTime();\n root.pingedLanes |= root.suspendedLanes & pingedLanes;\n workInProgressRoot === root &&\n (workInProgressRootRenderLanes & pingedLanes) === pingedLanes &&\n (4 === workInProgressRootExitStatus ||\n (3 === workInProgressRootExitStatus &&\n (workInProgressRootRenderLanes & 130023424) ===\n workInProgressRootRenderLanes &&\n 500 > now() - globalMostRecentFallbackTime)\n ? prepareFreshStack(root, 0)\n : (workInProgressRootPingedLanes |= pingedLanes));\n ensureRootIsScheduled(root, wakeable);\n}\nfunction retryTimedOutBoundary(boundaryFiber, retryLane) {\n 0 === retryLane &&\n (0 === (boundaryFiber.mode & 1)\n ? (retryLane = 1)\n : ((retryLane = nextRetryLane),\n (nextRetryLane <<= 1),\n 0 === (nextRetryLane & 130023424) && (nextRetryLane = 4194304)));\n var eventTime = requestEventTime();\n boundaryFiber = markUpdateLaneFromFiberToRoot(boundaryFiber, retryLane);\n null !== boundaryFiber &&\n (markRootUpdated(boundaryFiber, retryLane, eventTime),\n ensureRootIsScheduled(boundaryFiber, eventTime));\n}\nfunction retryDehydratedSuspenseBoundary(boundaryFiber) {\n var suspenseState = boundaryFiber.memoizedState,\n retryLane = 0;\n null !== suspenseState && (retryLane = suspenseState.retryLane);\n retryTimedOutBoundary(boundaryFiber, retryLane);\n}\nfunction resolveRetryWakeable(boundaryFiber, wakeable) {\n var retryLane = 0;\n switch (boundaryFiber.tag) {\n case 13:\n var retryCache = boundaryFiber.stateNode;\n var suspenseState = boundaryFiber.memoizedState;\n null !== suspenseState && (retryLane = suspenseState.retryLane);\n break;\n case 19:\n retryCache = boundaryFiber.stateNode;\n break;\n default:\n throw Error(\n \"Pinged unknown suspense boundary type. This is probably a bug in React.\"\n );\n }\n null !== retryCache && retryCache.delete(wakeable);\n retryTimedOutBoundary(boundaryFiber, retryLane);\n}\nvar beginWork$1;\nbeginWork$1 = function(current, workInProgress, renderLanes) {\n if (null !== current)\n if (\n current.memoizedProps !== workInProgress.pendingProps ||\n didPerformWorkStackCursor.current\n )\n didReceiveUpdate = !0;\n else {\n if (\n 0 === (current.lanes & renderLanes) &&\n 0 === (workInProgress.flags & 128)\n )\n return (\n (didReceiveUpdate = !1),\n attemptEarlyBailoutIfNoScheduledUpdate(\n current,\n workInProgress,\n renderLanes\n )\n );\n didReceiveUpdate = 0 !== (current.flags & 131072) ? !0 : !1;\n }\n else didReceiveUpdate = !1;\n workInProgress.lanes = 0;\n switch (workInProgress.tag) {\n case 2:\n var Component = workInProgress.type;\n resetSuspendedCurrentOnMountInLegacyMode(current, workInProgress);\n current = workInProgress.pendingProps;\n var context = getMaskedContext(\n workInProgress,\n contextStackCursor.current\n );\n prepareToReadContext(workInProgress, renderLanes);\n context = renderWithHooks(\n null,\n workInProgress,\n Component,\n current,\n context,\n renderLanes\n );\n workInProgress.flags |= 1;\n if (\n \"object\" === typeof context &&\n null !== context &&\n \"function\" === typeof context.render &&\n void 0 === context.$$typeof\n ) {\n workInProgress.tag = 1;\n workInProgress.memoizedState = null;\n workInProgress.updateQueue = null;\n if (isContextProvider(Component)) {\n var hasContext = !0;\n pushContextProvider(workInProgress);\n } else hasContext = !1;\n workInProgress.memoizedState =\n null !== context.state && void 0 !== context.state\n ? context.state\n : null;\n initializeUpdateQueue(workInProgress);\n context.updater = classComponentUpdater;\n workInProgress.stateNode = context;\n context._reactInternals = workInProgress;\n mountClassInstance(workInProgress, Component, current, renderLanes);\n workInProgress = finishClassComponent(\n null,\n workInProgress,\n Component,\n !0,\n hasContext,\n renderLanes\n );\n } else\n (workInProgress.tag = 0),\n reconcileChildren(null, workInProgress, context, renderLanes),\n (workInProgress = workInProgress.child);\n return workInProgress;\n case 16:\n Component = workInProgress.elementType;\n a: {\n resetSuspendedCurrentOnMountInLegacyMode(current, workInProgress);\n current = workInProgress.pendingProps;\n context = Component._init;\n Component = context(Component._payload);\n workInProgress.type = Component;\n context = workInProgress.tag = resolveLazyComponentTag(Component);\n current = resolveDefaultProps(Component, current);\n switch (context) {\n case 0:\n workInProgress = updateFunctionComponent(\n null,\n workInProgress,\n Component,\n current,\n renderLanes\n );\n break a;\n case 1:\n workInProgress = updateClassComponent(\n null,\n workInProgress,\n Component,\n current,\n renderLanes\n );\n break a;\n case 11:\n workInProgress = updateForwardRef(\n null,\n workInProgress,\n Component,\n current,\n renderLanes\n );\n break a;\n case 14:\n workInProgress = updateMemoComponent(\n null,\n workInProgress,\n Component,\n resolveDefaultProps(Component.type, current),\n renderLanes\n );\n break a;\n }\n throw Error(\n \"Element type is invalid. Received a promise that resolves to: \" +\n Component +\n \". Lazy element type must resolve to a class or function.\"\n );\n }\n return workInProgress;\n case 0:\n return (\n (Component = workInProgress.type),\n (context = workInProgress.pendingProps),\n (context =\n workInProgress.elementType === Component\n ? context\n : resolveDefaultProps(Component, context)),\n updateFunctionComponent(\n current,\n workInProgress,\n Component,\n context,\n renderLanes\n )\n );\n case 1:\n return (\n (Component = workInProgress.type),\n (context = workInProgress.pendingProps),\n (context =\n workInProgress.elementType === Component\n ? context\n : resolveDefaultProps(Component, context)),\n updateClassComponent(\n current,\n workInProgress,\n Component,\n context,\n renderLanes\n )\n );\n case 3:\n pushHostRootContext(workInProgress);\n if (null === current)\n throw Error(\"Should have a current fiber. This is a bug in React.\");\n context = workInProgress.pendingProps;\n Component = workInProgress.memoizedState.element;\n cloneUpdateQueue(current, workInProgress);\n processUpdateQueue(workInProgress, context, null, renderLanes);\n context = workInProgress.memoizedState.element;\n context === Component\n ? (workInProgress = bailoutOnAlreadyFinishedWork(\n current,\n workInProgress,\n renderLanes\n ))\n : (reconcileChildren(current, workInProgress, context, renderLanes),\n (workInProgress = workInProgress.child));\n return workInProgress;\n case 5:\n return (\n pushHostContext(workInProgress),\n (Component = workInProgress.pendingProps.children),\n markRef(current, workInProgress),\n reconcileChildren(current, workInProgress, Component, renderLanes),\n workInProgress.child\n );\n case 6:\n return null;\n case 13:\n return updateSuspenseComponent(current, workInProgress, renderLanes);\n case 4:\n return (\n pushHostContainer(\n workInProgress,\n workInProgress.stateNode.containerInfo\n ),\n (Component = workInProgress.pendingProps),\n null === current\n ? (workInProgress.child = reconcileChildFibers(\n workInProgress,\n null,\n Component,\n renderLanes\n ))\n : reconcileChildren(current, workInProgress, Component, renderLanes),\n workInProgress.child\n );\n case 11:\n return (\n (Component = workInProgress.type),\n (context = workInProgress.pendingProps),\n (context =\n workInProgress.elementType === Component\n ? context\n : resolveDefaultProps(Component, context)),\n updateForwardRef(\n current,\n workInProgress,\n Component,\n context,\n renderLanes\n )\n );\n case 7:\n return (\n reconcileChildren(\n current,\n workInProgress,\n workInProgress.pendingProps,\n renderLanes\n ),\n workInProgress.child\n );\n case 8:\n return (\n reconcileChildren(\n current,\n workInProgress,\n workInProgress.pendingProps.children,\n renderLanes\n ),\n workInProgress.child\n );\n case 12:\n return (\n reconcileChildren(\n current,\n workInProgress,\n workInProgress.pendingProps.children,\n renderLanes\n ),\n workInProgress.child\n );\n case 10:\n a: {\n Component = workInProgress.type._context;\n context = workInProgress.pendingProps;\n hasContext = workInProgress.memoizedProps;\n var newValue = context.value;\n push(valueCursor, Component._currentValue);\n Component._currentValue = newValue;\n if (null !== hasContext)\n if (objectIs(hasContext.value, newValue)) {\n if (\n hasContext.children === context.children &&\n !didPerformWorkStackCursor.current\n ) {\n workInProgress = bailoutOnAlreadyFinishedWork(\n current,\n workInProgress,\n renderLanes\n );\n break a;\n }\n } else\n for (\n hasContext = workInProgress.child,\n null !== hasContext && (hasContext.return = workInProgress);\n null !== hasContext;\n\n ) {\n var list = hasContext.dependencies;\n if (null !== list) {\n newValue = hasContext.child;\n for (\n var dependency = list.firstContext;\n null !== dependency;\n\n ) {\n if (dependency.context === Component) {\n if (1 === hasContext.tag) {\n dependency = createUpdate(-1, renderLanes & -renderLanes);\n dependency.tag = 2;\n var updateQueue = hasContext.updateQueue;\n if (null !== updateQueue) {\n updateQueue = updateQueue.shared;\n var pending = updateQueue.pending;\n null === pending\n ? (dependency.next = dependency)\n : ((dependency.next = pending.next),\n (pending.next = dependency));\n updateQueue.pending = dependency;\n }\n }\n hasContext.lanes |= renderLanes;\n dependency = hasContext.alternate;\n null !== dependency && (dependency.lanes |= renderLanes);\n scheduleContextWorkOnParentPath(\n hasContext.return,\n renderLanes,\n workInProgress\n );\n list.lanes |= renderLanes;\n break;\n }\n dependency = dependency.next;\n }\n } else if (10 === hasContext.tag)\n newValue =\n hasContext.type === workInProgress.type\n ? null\n : hasContext.child;\n else if (18 === hasContext.tag) {\n newValue = hasContext.return;\n if (null === newValue)\n throw Error(\n \"We just came from a parent so we must have had a parent. This is a bug in React.\"\n );\n newValue.lanes |= renderLanes;\n list = newValue.alternate;\n null !== list && (list.lanes |= renderLanes);\n scheduleContextWorkOnParentPath(\n newValue,\n renderLanes,\n workInProgress\n );\n newValue = hasContext.sibling;\n } else newValue = hasContext.child;\n if (null !== newValue) newValue.return = hasContext;\n else\n for (newValue = hasContext; null !== newValue; ) {\n if (newValue === workInProgress) {\n newValue = null;\n break;\n }\n hasContext = newValue.sibling;\n if (null !== hasContext) {\n hasContext.return = newValue.return;\n newValue = hasContext;\n break;\n }\n newValue = newValue.return;\n }\n hasContext = newValue;\n }\n reconcileChildren(\n current,\n workInProgress,\n context.children,\n renderLanes\n );\n workInProgress = workInProgress.child;\n }\n return workInProgress;\n case 9:\n return (\n (context = workInProgress.type),\n (Component = workInProgress.pendingProps.children),\n prepareToReadContext(workInProgress, renderLanes),\n (context = readContext(context)),\n (Component = Component(context)),\n (workInProgress.flags |= 1),\n reconcileChildren(current, workInProgress, Component, renderLanes),\n workInProgress.child\n );\n case 14:\n return (\n (Component = workInProgress.type),\n (context = resolveDefaultProps(Component, workInProgress.pendingProps)),\n (context = resolveDefaultProps(Component.type, context)),\n updateMemoComponent(\n current,\n workInProgress,\n Component,\n context,\n renderLanes\n )\n );\n case 15:\n return updateSimpleMemoComponent(\n current,\n workInProgress,\n workInProgress.type,\n workInProgress.pendingProps,\n renderLanes\n );\n case 17:\n return (\n (Component = workInProgress.type),\n (context = workInProgress.pendingProps),\n (context =\n workInProgress.elementType === Component\n ? context\n : resolveDefaultProps(Component, context)),\n resetSuspendedCurrentOnMountInLegacyMode(current, workInProgress),\n (workInProgress.tag = 1),\n isContextProvider(Component)\n ? ((current = !0), pushContextProvider(workInProgress))\n : (current = !1),\n prepareToReadContext(workInProgress, renderLanes),\n constructClassInstance(workInProgress, Component, context),\n mountClassInstance(workInProgress, Component, context, renderLanes),\n finishClassComponent(\n null,\n workInProgress,\n Component,\n !0,\n current,\n renderLanes\n )\n );\n case 19:\n return updateSuspenseListComponent(current, workInProgress, renderLanes);\n case 22:\n return updateOffscreenComponent(current, workInProgress, renderLanes);\n }\n throw Error(\n \"Unknown unit of work tag (\" +\n workInProgress.tag +\n \"). This error is likely caused by a bug in React. Please file an issue.\"\n );\n};\nfunction scheduleCallback$1(priorityLevel, callback) {\n return scheduleCallback(priorityLevel, callback);\n}\nfunction FiberNode(tag, pendingProps, key, mode) {\n this.tag = tag;\n this.key = key;\n this.sibling = this.child = this.return = this.stateNode = this.type = this.elementType = null;\n this.index = 0;\n this.ref = null;\n this.pendingProps = pendingProps;\n this.dependencies = this.memoizedState = this.updateQueue = this.memoizedProps = null;\n this.mode = mode;\n this.subtreeFlags = this.flags = 0;\n this.deletions = null;\n this.childLanes = this.lanes = 0;\n this.alternate = null;\n}\nfunction createFiber(tag, pendingProps, key, mode) {\n return new FiberNode(tag, pendingProps, key, mode);\n}\nfunction shouldConstruct(Component) {\n Component = Component.prototype;\n return !(!Component || !Component.isReactComponent);\n}\nfunction resolveLazyComponentTag(Component) {\n if (\"function\" === typeof Component)\n return shouldConstruct(Component) ? 1 : 0;\n if (void 0 !== Component && null !== Component) {\n Component = Component.$$typeof;\n if (Component === REACT_FORWARD_REF_TYPE) return 11;\n if (Component === REACT_MEMO_TYPE) return 14;\n }\n return 2;\n}\nfunction createWorkInProgress(current, pendingProps) {\n var workInProgress = current.alternate;\n null === workInProgress\n ? ((workInProgress = createFiber(\n current.tag,\n pendingProps,\n current.key,\n current.mode\n )),\n (workInProgress.elementType = current.elementType),\n (workInProgress.type = current.type),\n (workInProgress.stateNode = current.stateNode),\n (workInProgress.alternate = current),\n (current.alternate = workInProgress))\n : ((workInProgress.pendingProps = pendingProps),\n (workInProgress.type = current.type),\n (workInProgress.flags = 0),\n (workInProgress.subtreeFlags = 0),\n (workInProgress.deletions = null));\n workInProgress.flags = current.flags & 14680064;\n workInProgress.childLanes = current.childLanes;\n workInProgress.lanes = current.lanes;\n workInProgress.child = current.child;\n workInProgress.memoizedProps = current.memoizedProps;\n workInProgress.memoizedState = current.memoizedState;\n workInProgress.updateQueue = current.updateQueue;\n pendingProps = current.dependencies;\n workInProgress.dependencies =\n null === pendingProps\n ? null\n : { lanes: pendingProps.lanes, firstContext: pendingProps.firstContext };\n workInProgress.sibling = current.sibling;\n workInProgress.index = current.index;\n workInProgress.ref = current.ref;\n return workInProgress;\n}\nfunction createFiberFromTypeAndProps(\n type,\n key,\n pendingProps,\n owner,\n mode,\n lanes\n) {\n var fiberTag = 2;\n owner = type;\n if (\"function\" === typeof type) shouldConstruct(type) && (fiberTag = 1);\n else if (\"string\" === typeof type) fiberTag = 5;\n else\n a: switch (type) {\n case REACT_FRAGMENT_TYPE:\n return createFiberFromFragment(pendingProps.children, mode, lanes, key);\n case REACT_STRICT_MODE_TYPE:\n fiberTag = 8;\n mode |= 8;\n break;\n case REACT_PROFILER_TYPE:\n return (\n (type = createFiber(12, pendingProps, key, mode | 2)),\n (type.elementType = REACT_PROFILER_TYPE),\n (type.lanes = lanes),\n type\n );\n case REACT_SUSPENSE_TYPE:\n return (\n (type = createFiber(13, pendingProps, key, mode)),\n (type.elementType = REACT_SUSPENSE_TYPE),\n (type.lanes = lanes),\n type\n );\n case REACT_SUSPENSE_LIST_TYPE:\n return (\n (type = createFiber(19, pendingProps, key, mode)),\n (type.elementType = REACT_SUSPENSE_LIST_TYPE),\n (type.lanes = lanes),\n type\n );\n case REACT_OFFSCREEN_TYPE:\n return createFiberFromOffscreen(pendingProps, mode, lanes, key);\n default:\n if (\"object\" === typeof type && null !== type)\n switch (type.$$typeof) {\n case REACT_PROVIDER_TYPE:\n fiberTag = 10;\n break a;\n case REACT_CONTEXT_TYPE:\n fiberTag = 9;\n break a;\n case REACT_FORWARD_REF_TYPE:\n fiberTag = 11;\n break a;\n case REACT_MEMO_TYPE:\n fiberTag = 14;\n break a;\n case REACT_LAZY_TYPE:\n fiberTag = 16;\n owner = null;\n break a;\n }\n throw Error(\n \"Element type is invalid: expected a string (for built-in components) or a class/function (for composite components) but got: \" +\n ((null == type ? type : typeof type) + \".\")\n );\n }\n key = createFiber(fiberTag, pendingProps, key, mode);\n key.elementType = type;\n key.type = owner;\n key.lanes = lanes;\n return key;\n}\nfunction createFiberFromFragment(elements, mode, lanes, key) {\n elements = createFiber(7, elements, key, mode);\n elements.lanes = lanes;\n return elements;\n}\nfunction createFiberFromOffscreen(pendingProps, mode, lanes, key) {\n pendingProps = createFiber(22, pendingProps, key, mode);\n pendingProps.elementType = REACT_OFFSCREEN_TYPE;\n pendingProps.lanes = lanes;\n pendingProps.stateNode = { isHidden: !1 };\n return pendingProps;\n}\nfunction createFiberFromText(content, mode, lanes) {\n content = createFiber(6, content, null, mode);\n content.lanes = lanes;\n return content;\n}\nfunction createFiberFromPortal(portal, mode, lanes) {\n mode = createFiber(\n 4,\n null !== portal.children ? portal.children : [],\n portal.key,\n mode\n );\n mode.lanes = lanes;\n mode.stateNode = {\n containerInfo: portal.containerInfo,\n pendingChildren: null,\n implementation: portal.implementation\n };\n return mode;\n}\nfunction FiberRootNode(\n containerInfo,\n tag,\n hydrate,\n identifierPrefix,\n onRecoverableError\n) {\n this.tag = tag;\n this.containerInfo = containerInfo;\n this.finishedWork = this.pingCache = this.current = this.pendingChildren = null;\n this.timeoutHandle = -1;\n this.callbackNode = this.pendingContext = this.context = null;\n this.callbackPriority = 0;\n this.eventTimes = createLaneMap(0);\n this.expirationTimes = createLaneMap(-1);\n this.entangledLanes = this.finishedLanes = this.mutableReadLanes = this.expiredLanes = this.pingedLanes = this.suspendedLanes = this.pendingLanes = 0;\n this.entanglements = createLaneMap(0);\n this.identifierPrefix = identifierPrefix;\n this.onRecoverableError = onRecoverableError;\n}\nfunction createPortal(children, containerInfo, implementation) {\n var key =\n 3 < arguments.length && void 0 !== arguments[3] ? arguments[3] : null;\n return {\n $$typeof: REACT_PORTAL_TYPE,\n key: null == key ? null : \"\" + key,\n children: children,\n containerInfo: containerInfo,\n implementation: implementation\n };\n}\nfunction findHostInstance(component) {\n var fiber = component._reactInternals;\n if (void 0 === fiber) {\n if (\"function\" === typeof component.render)\n throw Error(\"Unable to find node on an unmounted component.\");\n component = Object.keys(component).join(\",\");\n throw Error(\n \"Argument appears to not be a ReactComponent. Keys: \" + component\n );\n }\n component = findCurrentHostFiber(fiber);\n return null === component ? null : component.stateNode;\n}\nfunction updateContainer(element, container, parentComponent, callback) {\n var current = container.current,\n eventTime = requestEventTime(),\n lane = requestUpdateLane(current);\n a: if (parentComponent) {\n parentComponent = parentComponent._reactInternals;\n b: {\n if (\n getNearestMountedFiber(parentComponent) !== parentComponent ||\n 1 !== parentComponent.tag\n )\n throw Error(\n \"Expected subtree parent to be a mounted class component. This error is likely caused by a bug in React. Please file an issue.\"\n );\n var JSCompiler_inline_result = parentComponent;\n do {\n switch (JSCompiler_inline_result.tag) {\n case 3:\n JSCompiler_inline_result =\n JSCompiler_inline_result.stateNode.context;\n break b;\n case 1:\n if (isContextProvider(JSCompiler_inline_result.type)) {\n JSCompiler_inline_result =\n JSCompiler_inline_result.stateNode\n .__reactInternalMemoizedMergedChildContext;\n break b;\n }\n }\n JSCompiler_inline_result = JSCompiler_inline_result.return;\n } while (null !== JSCompiler_inline_result);\n throw Error(\n \"Found unexpected detached subtree parent. This error is likely caused by a bug in React. Please file an issue.\"\n );\n }\n if (1 === parentComponent.tag) {\n var Component = parentComponent.type;\n if (isContextProvider(Component)) {\n parentComponent = processChildContext(\n parentComponent,\n Component,\n JSCompiler_inline_result\n );\n break a;\n }\n }\n parentComponent = JSCompiler_inline_result;\n } else parentComponent = emptyContextObject;\n null === container.context\n ? (container.context = parentComponent)\n : (container.pendingContext = parentComponent);\n container = createUpdate(eventTime, lane);\n container.payload = { element: element };\n callback = void 0 === callback ? null : callback;\n null !== callback && (container.callback = callback);\n element = enqueueUpdate(current, container, lane);\n null !== element &&\n (scheduleUpdateOnFiber(element, current, lane, eventTime),\n entangleTransitions(element, current, lane));\n return lane;\n}\nfunction emptyFindFiberByHostInstance() {\n return null;\n}\nfunction findNodeHandle(componentOrHandle) {\n if (null == componentOrHandle) return null;\n if (\"number\" === typeof componentOrHandle) return componentOrHandle;\n if (componentOrHandle._nativeTag) return componentOrHandle._nativeTag;\n if (componentOrHandle.canonical && componentOrHandle.canonical._nativeTag)\n return componentOrHandle.canonical._nativeTag;\n componentOrHandle = findHostInstance(componentOrHandle);\n return null == componentOrHandle\n ? componentOrHandle\n : componentOrHandle.canonical\n ? componentOrHandle.canonical._nativeTag\n : componentOrHandle._nativeTag;\n}\nfunction onRecoverableError(error) {\n console.error(error);\n}\nfunction unmountComponentAtNode(containerTag) {\n var root = roots.get(containerTag);\n root &&\n updateContainer(null, root, null, function() {\n roots.delete(containerTag);\n });\n}\nbatchedUpdatesImpl = function(fn, a) {\n var prevExecutionContext = executionContext;\n executionContext |= 1;\n try {\n return fn(a);\n } finally {\n (executionContext = prevExecutionContext),\n 0 === executionContext &&\n ((workInProgressRootRenderTargetTime = now() + 500),\n includesLegacySyncCallbacks && flushSyncCallbacks());\n }\n};\nvar roots = new Map(),\n devToolsConfig$jscomp$inline_979 = {\n findFiberByHostInstance: getInstanceFromTag,\n bundleType: 0,\n version: \"18.2.0-next-9e3b772b8-20220608\",\n rendererPackageName: \"react-native-renderer\",\n rendererConfig: {\n getInspectorDataForViewTag: function() {\n throw Error(\n \"getInspectorDataForViewTag() is not available in production\"\n );\n },\n getInspectorDataForViewAtPoint: function() {\n throw Error(\n \"getInspectorDataForViewAtPoint() is not available in production.\"\n );\n }.bind(null, findNodeHandle)\n }\n };\nvar internals$jscomp$inline_1247 = {\n bundleType: devToolsConfig$jscomp$inline_979.bundleType,\n version: devToolsConfig$jscomp$inline_979.version,\n rendererPackageName: devToolsConfig$jscomp$inline_979.rendererPackageName,\n rendererConfig: devToolsConfig$jscomp$inline_979.rendererConfig,\n overrideHookState: null,\n overrideHookStateDeletePath: null,\n overrideHookStateRenamePath: null,\n overrideProps: null,\n overridePropsDeletePath: null,\n overridePropsRenamePath: null,\n setErrorHandler: null,\n setSuspenseHandler: null,\n scheduleUpdate: null,\n currentDispatcherRef: ReactSharedInternals.ReactCurrentDispatcher,\n findHostInstanceByFiber: function(fiber) {\n fiber = findCurrentHostFiber(fiber);\n return null === fiber ? null : fiber.stateNode;\n },\n findFiberByHostInstance:\n devToolsConfig$jscomp$inline_979.findFiberByHostInstance ||\n emptyFindFiberByHostInstance,\n findHostInstancesForRefresh: null,\n scheduleRefresh: null,\n scheduleRoot: null,\n setRefreshHandler: null,\n getCurrentFiber: null,\n reconcilerVersion: \"18.2.0-next-9e3b772b8-20220608\"\n};\nif (\"undefined\" !== typeof __REACT_DEVTOOLS_GLOBAL_HOOK__) {\n var hook$jscomp$inline_1248 = __REACT_DEVTOOLS_GLOBAL_HOOK__;\n if (\n !hook$jscomp$inline_1248.isDisabled &&\n hook$jscomp$inline_1248.supportsFiber\n )\n try {\n (rendererID = hook$jscomp$inline_1248.inject(\n internals$jscomp$inline_1247\n )),\n (injectedHook = hook$jscomp$inline_1248);\n } catch (err) {}\n}\nexports.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED = {\n computeComponentStackForErrorReporting: function(reactTag) {\n return (reactTag = getInstanceFromTag(reactTag))\n ? getStackByFiberInDevAndProd(reactTag)\n : \"\";\n }\n};\nexports.createPortal = function(children, containerTag) {\n return createPortal(\n children,\n containerTag,\n null,\n 2 < arguments.length && void 0 !== arguments[2] ? arguments[2] : null\n );\n};\nexports.dispatchCommand = function(handle, command, args) {\n null != handle._nativeTag &&\n (null != handle._internalInstanceHandle\n ? ((handle = handle._internalInstanceHandle.stateNode),\n null != handle &&\n nativeFabricUIManager.dispatchCommand(handle.node, command, args))\n : ReactNativePrivateInterface.UIManager.dispatchViewManagerCommand(\n handle._nativeTag,\n command,\n args\n ));\n};\nexports.findHostInstance_DEPRECATED = function(componentOrHandle) {\n if (null == componentOrHandle) return null;\n if (componentOrHandle._nativeTag) return componentOrHandle;\n if (componentOrHandle.canonical && componentOrHandle.canonical._nativeTag)\n return componentOrHandle.canonical;\n componentOrHandle = findHostInstance(componentOrHandle);\n return null == componentOrHandle\n ? componentOrHandle\n : componentOrHandle.canonical\n ? componentOrHandle.canonical\n : componentOrHandle;\n};\nexports.findNodeHandle = findNodeHandle;\nexports.getInspectorDataForInstance = void 0;\nexports.render = function(element, containerTag, callback) {\n var root = roots.get(containerTag);\n if (!root) {\n root = new FiberRootNode(containerTag, 0, !1, \"\", onRecoverableError);\n var JSCompiler_inline_result = createFiber(3, null, null, 0);\n root.current = JSCompiler_inline_result;\n JSCompiler_inline_result.stateNode = root;\n JSCompiler_inline_result.memoizedState = {\n element: null,\n isDehydrated: !1,\n cache: null,\n transitions: null,\n pendingSuspenseBoundaries: null\n };\n initializeUpdateQueue(JSCompiler_inline_result);\n roots.set(containerTag, root);\n }\n updateContainer(element, root, null, callback);\n a: if (((element = root.current), element.child))\n switch (element.child.tag) {\n case 5:\n element = element.child.stateNode;\n break a;\n default:\n element = element.child.stateNode;\n }\n else element = null;\n return element;\n};\nexports.sendAccessibilityEvent = function(handle, eventType) {\n null != handle._nativeTag &&\n (null != handle._internalInstanceHandle\n ? ((handle = handle._internalInstanceHandle.stateNode),\n null != handle &&\n nativeFabricUIManager.sendAccessibilityEvent(handle.node, eventType))\n : ReactNativePrivateInterface.legacySendAccessibilityEvent(\n handle._nativeTag,\n eventType\n ));\n};\nexports.unmountComponentAtNode = unmountComponentAtNode;\nexports.unmountComponentAtNodeAndRemoveContainer = function(containerTag) {\n unmountComponentAtNode(containerTag);\n ReactNativePrivateInterface.UIManager.removeRootView(containerTag);\n};\nexports.unstable_batchedUpdates = batchedUpdates;\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 * @format\n * @flow\n * @generate-docs\n */\n\n'use strict';\nimport type {ViewProps} from '../View/ViewPropTypes';\nimport type {ActivityIndicator as ActivityIndicatorType} from './ActivityIndicator.flow';\n\nimport StyleSheet, {type ColorValue} from '../../StyleSheet/StyleSheet';\nimport Platform from '../../Utilities/Platform';\nimport View from '../View/View';\nimport * as React from 'react';\n\nconst PlatformActivityIndicator =\n Platform.OS === 'android'\n ? require('../ProgressBarAndroid/ProgressBarAndroid')\n : require('./ActivityIndicatorViewNativeComponent').default;\n\nconst GRAY = '#999999';\n\ntype IndicatorSize = number | 'small' | 'large';\n\ntype IOSProps = $ReadOnly<{|\n /**\n Whether the indicator should hide when not animating.\n\n @platform ios\n */\n hidesWhenStopped?: ?boolean,\n|}>;\ntype Props = $ReadOnly<{|\n ...ViewProps,\n ...IOSProps,\n\n /**\n \tWhether to show the indicator (`true`) or hide it (`false`).\n */\n animating?: ?boolean,\n\n /**\n The foreground color of the spinner.\n\n @default {@platform android} `null` (system accent default color)\n @default {@platform ios} '#999999'\n */\n color?: ?ColorValue,\n\n /**\n Size of the indicator.\n\n @type enum(`'small'`, `'large'`)\n @type {@platform android} number\n */\n size?: ?IndicatorSize,\n|}>;\n\nconst ActivityIndicator = (\n {\n animating = true,\n color = Platform.OS === 'ios' ? GRAY : null,\n hidesWhenStopped = true,\n onLayout,\n size = 'small',\n style,\n ...restProps\n }: Props,\n forwardedRef?: any,\n) => {\n let sizeStyle;\n let sizeProp;\n\n switch (size) {\n case 'small':\n sizeStyle = styles.sizeSmall;\n sizeProp = 'small';\n break;\n case 'large':\n sizeStyle = styles.sizeLarge;\n sizeProp = 'large';\n break;\n default:\n sizeStyle = {height: size, width: size};\n break;\n }\n\n const nativeProps = {\n animating,\n color,\n hidesWhenStopped,\n ...restProps,\n ref: forwardedRef,\n style: sizeStyle,\n size: sizeProp,\n };\n\n const androidProps = {\n styleAttr: 'Normal',\n indeterminate: true,\n };\n\n return (\n \n {Platform.OS === 'android' ? (\n // $FlowFixMe[prop-missing] Flow doesn't know when this is the android component\n \n ) : (\n /* $FlowFixMe[prop-missing] (>=0.106.0 site=react_native_android_fb) This comment\n * suppresses an error found when Flow v0.106 was deployed. To see the\n * error, delete this comment and run Flow. */\n \n )}\n \n );\n};\n\n/**\n Displays a circular loading indicator.\n\n ```SnackPlayer name=ActivityIndicator%20Function%20Component%20Example\n import React from \"react\";\n import { ActivityIndicator, StyleSheet, Text, View } from \"react-native\";\n\n const App = () => (\n \n \n \n \n \n \n );\n\n const styles = StyleSheet.create({\n container: {\n flex: 1,\n justifyContent: \"center\"\n },\n horizontal: {\n flexDirection: \"row\",\n justifyContent: \"space-around\",\n padding: 10\n }\n });\n export default App;\n ```\n\n ```SnackPlayer name=ActivityIndicator%20Class%20Component%20Example\n import React, { Component } from \"react\";\n import { ActivityIndicator, StyleSheet, Text, View } from \"react-native\";\n\n class App extends Component {\n render() {\n return (\n \n \n \n \n \n \n );\n }\n }\n\n const styles = StyleSheet.create({\n container: {\n flex: 1,\n justifyContent: \"center\"\n },\n horizontal: {\n flexDirection: \"row\",\n justifyContent: \"space-around\",\n padding: 10\n }\n });\n export default App;\n ```\n*/\n\nconst ActivityIndicatorWithRef: ActivityIndicatorType =\n React.forwardRef(ActivityIndicator);\nActivityIndicatorWithRef.displayName = 'ActivityIndicator';\n\nconst styles = StyleSheet.create({\n container: {\n alignItems: 'center',\n justifyContent: 'center',\n },\n sizeSmall: {\n width: 20,\n height: 20,\n },\n sizeLarge: {\n width: 36,\n height: 36,\n },\n});\n\nmodule.exports = ActivityIndicatorWithRef;\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 * @format\n */\n\n'use strict';\n\nmodule.exports = require('../UnimplementedViews/UnimplementedView');\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 * @format\n * @flow strict-local\n */\n\nimport type {HostComponent} from '../../Renderer/shims/ReactNativeTypes';\nimport type {ColorValue} from '../../StyleSheet/StyleSheet';\nimport type {WithDefault} from '../../Types/CodegenTypes';\nimport type {ViewProps} from '../View/ViewPropTypes';\n\nimport codegenNativeComponent from '../../Utilities/codegenNativeComponent';\n\ntype NativeProps = $ReadOnly<{|\n ...ViewProps,\n\n /**\n * Whether the indicator should hide when not animating (true by default).\n *\n * See https://reactnative.dev/docs/activityindicator#hideswhenstopped\n */\n hidesWhenStopped?: WithDefault,\n\n /**\n * Whether to show the indicator (true, the default) or hide it (false).\n *\n * See https://reactnative.dev/docs/activityindicator#animating\n */\n animating?: WithDefault,\n\n /**\n * The foreground color of the spinner (default is gray).\n *\n * See https://reactnative.dev/docs/activityindicator#color\n */\n color?: ?ColorValue,\n\n /**\n * Size of the indicator (default is 'small').\n * Passing a number to the size prop is only supported on Android.\n *\n * See https://reactnative.dev/docs/activityindicator#size\n */\n size?: WithDefault<'small' | 'large', 'small'>,\n|}>;\n\nexport default (codegenNativeComponent('ActivityIndicatorView', {\n paperComponentName: 'RCTActivityIndicatorView',\n}): HostComponent);\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 * @format\n * @flow strict-local\n */\n\n// TODO: move this file to shims/ReactNative (requires React update and sync)\n\nimport type {HostComponent} from '../../Libraries/Renderer/shims/ReactNativeTypes';\n\nimport requireNativeComponent from '../../Libraries/ReactNative/requireNativeComponent';\nimport UIManager from '../ReactNative/UIManager';\n\n// TODO: import from CodegenSchema once workspaces are enabled\ntype Options = $ReadOnly<{|\n interfaceOnly?: boolean,\n paperComponentName?: string,\n paperComponentNameDeprecated?: string,\n excludedPlatforms?: $ReadOnlyArray<'iOS' | 'android'>,\n|}>;\n\nexport type NativeComponentType = HostComponent;\n\n// If this function runs then that means the view configs were not\n// generated at build time using `GenerateViewConfigJs.js`. Thus\n// we need to `requireNativeComponent` to get the view configs from view managers.\n// `requireNativeComponent` is not available in Bridgeless mode.\n// e.g. This function runs at runtime if `codegenNativeComponent` was not called\n// from a file suffixed with NativeComponent.js.\nfunction codegenNativeComponent(\n componentName: string,\n options?: Options,\n): NativeComponentType {\n if (global.RN$Bridgeless === true) {\n const errorMessage =\n \"Native Component '\" +\n componentName +\n \"' that calls codegenNativeComponent was not code generated at build time. Please check its definition.\";\n console.error(errorMessage);\n }\n\n let componentNameInUse =\n options && options.paperComponentName != null\n ? options.paperComponentName\n : componentName;\n\n if (options != null && options.paperComponentNameDeprecated != null) {\n if (UIManager.hasViewManagerConfig(componentName)) {\n componentNameInUse = componentName;\n } else if (\n options.paperComponentNameDeprecated != null &&\n UIManager.hasViewManagerConfig(options.paperComponentNameDeprecated)\n ) {\n // $FlowFixMe[incompatible-type]\n componentNameInUse = options.paperComponentNameDeprecated;\n } else {\n throw new Error(\n `Failed to find native component for either ${componentName} or ${\n options.paperComponentNameDeprecated ?? '(unknown)'\n }`,\n );\n }\n }\n\n return (requireNativeComponent(\n // $FlowFixMe[incompatible-call]\n componentNameInUse,\n ): HostComponent);\n}\n\nexport default codegenNativeComponent;\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport type {HostComponent} from '../Renderer/shims/ReactNativeTypes';\n\nconst createReactNativeComponentClass = require('../Renderer/shims/createReactNativeComponentClass');\nconst getNativeComponentAttributes = require('./getNativeComponentAttributes');\n\n/**\n * Creates values that can be used like React components which represent native\n * view managers. You should create JavaScript modules that wrap these values so\n * that the results are memoized. Example:\n *\n * const View = requireNativeComponent('RCTView');\n *\n */\n\nconst requireNativeComponent = (uiViewClassName: string): HostComponent =>\n ((createReactNativeComponentClass(uiViewClassName, () =>\n getNativeComponentAttributes(uiViewClassName),\n ): any): HostComponent);\n\nmodule.exports = requireNativeComponent;\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 * @noformat\n * @flow strict-local\n * @generated SignedSource<<7d3d4090dadea2daa09d92e5e66f6e5d>>\n *\n * This file was sync'd from the facebook/react repository.\n */\n\n'use strict';\n\nimport {ReactNativeViewConfigRegistry} from 'react-native/Libraries/ReactPrivate/ReactNativePrivateInterface';\nimport {type ViewConfig} from './ReactNativeTypes';\n\nconst {register} = ReactNativeViewConfigRegistry;\n\n/**\n * Creates a renderable ReactNative host component.\n * Use this method for view configs that are loaded from UIManager.\n * Use createReactNativeComponentClass() for view configs defined within JavaScript.\n *\n * @param {string} config iOS View configuration.\n * @private\n */\nconst createReactNativeComponentClass = function(\n name: string,\n callback: () => ViewConfig,\n): string {\n return register(name, callback);\n};\n\nmodule.exports = createReactNativeComponentClass;\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 * @format\n * @flow\n * @generate-docs\n */\n\n'use strict';\n\nimport type {PressEvent} from '../Types/CoreEventTypes';\nimport type {Button as ButtonType} from './Button.flow';\nimport type {\n AccessibilityActionEvent,\n AccessibilityActionInfo,\n AccessibilityState,\n} from './View/ViewAccessibility';\n\nimport StyleSheet, {type ColorValue} from '../StyleSheet/StyleSheet';\nimport Text from '../Text/Text';\nimport Platform from '../Utilities/Platform';\nimport TouchableNativeFeedback from './Touchable/TouchableNativeFeedback';\nimport TouchableOpacity from './Touchable/TouchableOpacity';\nimport View from './View/View';\nimport invariant from 'invariant';\nimport * as React from 'react';\n\ntype ButtonProps = $ReadOnly<{|\n /**\n Text to display inside the button. On Android the given title will be\n converted to the uppercased form.\n */\n title: string,\n\n /**\n Handler to be called when the user taps the button. The first function\n argument is an event in form of [PressEvent](pressevent).\n */\n onPress: (event?: PressEvent) => mixed,\n\n /**\n If `true`, doesn't play system sound on touch.\n\n @platform android\n\n @default false\n */\n touchSoundDisabled?: ?boolean,\n\n /**\n Color of the text (iOS), or background color of the button (Android).\n\n @default {@platform android} '#2196F3'\n @default {@platform ios} '#007AFF'\n */\n color?: ?ColorValue,\n\n /**\n TV preferred focus.\n\n @platform tv\n\n @default false\n */\n hasTVPreferredFocus?: ?boolean,\n\n /**\n Designates the next view to receive focus when the user navigates down. See\n the [Android documentation][android:nextFocusDown].\n\n [android:nextFocusDown]:\n https://developer.android.com/reference/android/view/View.html#attr_android:nextFocusDown\n\n @platform android, tv\n */\n nextFocusDown?: ?number,\n\n /**\n Designates the next view to receive focus when the user navigates forward.\n See the [Android documentation][android:nextFocusForward].\n\n [android:nextFocusForward]:\n https://developer.android.com/reference/android/view/View.html#attr_android:nextFocusForward\n\n @platform android, tv\n */\n nextFocusForward?: ?number,\n\n /**\n Designates the next view to receive focus when the user navigates left. See\n the [Android documentation][android:nextFocusLeft].\n\n [android:nextFocusLeft]:\n https://developer.android.com/reference/android/view/View.html#attr_android:nextFocusLeft\n\n @platform android, tv\n */\n nextFocusLeft?: ?number,\n\n /**\n Designates the next view to receive focus when the user navigates right. See\n the [Android documentation][android:nextFocusRight].\n\n [android:nextFocusRight]:\n https://developer.android.com/reference/android/view/View.html#attr_android:nextFocusRight\n\n @platform android, tv\n */\n nextFocusRight?: ?number,\n\n /**\n Designates the next view to receive focus when the user navigates up. See\n the [Android documentation][android:nextFocusUp].\n\n [android:nextFocusUp]:\n https://developer.android.com/reference/android/view/View.html#attr_android:nextFocusUp\n\n @platform android, tv\n */\n nextFocusUp?: ?number,\n\n /**\n Text to display for blindness accessibility features.\n */\n accessibilityLabel?: ?string,\n /**\n * Alias for accessibilityLabel https://reactnative.dev/docs/view#accessibilitylabel\n * https://github.com/facebook/react-native/issues/34424\n */\n 'aria-label'?: ?string,\n /**\n If `true`, disable all interactions for this component.\n\n @default false\n */\n disabled?: ?boolean,\n\n /**\n Used to locate this view in end-to-end tests.\n */\n testID?: ?string,\n\n /**\n * Accessibility props.\n */\n accessible?: ?boolean,\n accessibilityActions?: ?$ReadOnlyArray,\n onAccessibilityAction?: ?(event: AccessibilityActionEvent) => mixed,\n accessibilityState?: ?AccessibilityState,\n\n /**\n * alias for accessibilityState\n *\n * see https://reactnative.dev/docs/accessibility#accessibilitystate\n */\n 'aria-busy'?: ?boolean,\n 'aria-checked'?: ?boolean | 'mixed',\n 'aria-disabled'?: ?boolean,\n 'aria-expanded'?: ?boolean,\n 'aria-selected'?: ?boolean,\n\n /**\n * [Android] Controlling if a view fires accessibility events and if it is reported to accessibility services.\n */\n importantForAccessibility?: ?('auto' | 'yes' | 'no' | 'no-hide-descendants'),\n accessibilityHint?: ?string,\n accessibilityLanguage?: ?Stringish,\n|}>;\n\n/**\n A basic button component that should render nicely on any platform. Supports a\n minimal level of customization.\n\n If this button doesn't look right for your app, you can build your own button\n using [TouchableOpacity](touchableopacity) or\n [TouchableWithoutFeedback](touchablewithoutfeedback). For inspiration, look at\n the [source code for this button component][button:source]. Or, take a look at\n the [wide variety of button components built by the community]\n [button:examples].\n\n [button:source]:\n https://github.com/facebook/react-native/blob/HEAD/Libraries/Components/Button.js\n\n [button:examples]:\n https://js.coach/?menu%5Bcollections%5D=React%20Native&page=1&query=button\n\n ```jsx\n \n ```\n\n ```SnackPlayer name=Button%20Example\n import React from 'react';\n import { StyleSheet, Button, View, SafeAreaView, Text, Alert } from 'react-native';\n\n const Separator = () => (\n \n );\n\n const App = () => (\n \n \n \n The title and onPress handler are required. It is recommended to set accessibilityLabel to help make your app usable by everyone.\n \n Alert.alert('Simple Button pressed')}\n />\n \n \n \n \n Adjust the color in a way that looks standard on each platform. On iOS, the color prop controls the color of the text. On Android, the color adjusts the background color of the button.\n \n Alert.alert('Button with adjusted color pressed')}\n />\n \n \n \n \n All interaction for the component are disabled.\n \n Alert.alert('Cannot press this one')}\n />\n \n \n \n \n This layout strategy lets the title define the width of the button.\n \n \n Alert.alert('Left button pressed')}\n />\n Alert.alert('Right button pressed')}\n />\n \n \n \n );\n\n const styles = StyleSheet.create({\n container: {\n flex: 1,\n justifyContent: 'center',\n marginHorizontal: 16,\n },\n title: {\n textAlign: 'center',\n marginVertical: 8,\n },\n fixToText: {\n flexDirection: 'row',\n justifyContent: 'space-between',\n },\n separator: {\n marginVertical: 8,\n borderBottomColor: '#737373',\n borderBottomWidth: StyleSheet.hairlineWidth,\n },\n });\n\n export default App;\n ```\n */\n\nclass Button extends React.Component {\n render(): React.Node {\n const {\n accessibilityLabel,\n accessibilityState,\n 'aria-busy': ariaBusy,\n 'aria-checked': ariaChecked,\n 'aria-disabled': ariaDisabled,\n 'aria-expanded': ariaExpanded,\n 'aria-label': ariaLabel,\n 'aria-selected': ariaSelected,\n importantForAccessibility,\n color,\n onPress,\n touchSoundDisabled,\n title,\n hasTVPreferredFocus,\n nextFocusDown,\n nextFocusForward,\n nextFocusLeft,\n nextFocusRight,\n nextFocusUp,\n testID,\n accessible,\n accessibilityActions,\n accessibilityHint,\n accessibilityLanguage,\n onAccessibilityAction,\n } = this.props;\n const buttonStyles = [styles.button];\n const textStyles = [styles.text];\n if (color) {\n if (Platform.OS === 'ios') {\n textStyles.push({color: color});\n } else {\n buttonStyles.push({backgroundColor: color});\n }\n }\n\n let _accessibilityState = {\n busy: ariaBusy ?? accessibilityState?.busy,\n checked: ariaChecked ?? accessibilityState?.checked,\n disabled: ariaDisabled ?? accessibilityState?.disabled,\n expanded: ariaExpanded ?? accessibilityState?.expanded,\n selected: ariaSelected ?? accessibilityState?.selected,\n };\n\n const disabled =\n this.props.disabled != null\n ? this.props.disabled\n : _accessibilityState?.disabled;\n\n _accessibilityState =\n disabled !== _accessibilityState?.disabled\n ? {..._accessibilityState, disabled}\n : _accessibilityState;\n\n if (disabled) {\n buttonStyles.push(styles.buttonDisabled);\n textStyles.push(styles.textDisabled);\n }\n\n invariant(\n typeof title === 'string',\n 'The title prop of a Button must be a string',\n );\n const formattedTitle =\n Platform.OS === 'android' ? title.toUpperCase() : title;\n const Touchable =\n Platform.OS === 'android' ? TouchableNativeFeedback : TouchableOpacity;\n\n // If `no` is specified for `importantForAccessibility`, it will be changed to `no-hide-descendants` because the text inside should not be focused.\n const _importantForAccessibility =\n importantForAccessibility === 'no'\n ? 'no-hide-descendants'\n : importantForAccessibility;\n\n return (\n \n \n \n {formattedTitle}\n \n \n \n );\n }\n}\n\nconst styles = StyleSheet.create({\n button: Platform.select({\n ios: {},\n android: {\n elevation: 4,\n // Material design blue from https://material.google.com/style/color.html#color-color-palette\n backgroundColor: '#2196F3',\n borderRadius: 2,\n },\n }),\n text: {\n textAlign: 'center',\n margin: 8,\n ...Platform.select({\n ios: {\n // iOS blue from https://developer.apple.com/ios/human-interface-guidelines/visual-design/color/\n color: '#007AFF',\n fontSize: 18,\n },\n android: {\n color: 'white',\n fontWeight: '500',\n },\n }),\n },\n buttonDisabled: Platform.select({\n ios: {},\n android: {\n elevation: 0,\n backgroundColor: '#dfdfdf',\n },\n }),\n textDisabled: Platform.select({\n ios: {\n color: '#cdcdcd',\n },\n android: {\n color: '#a1a1a1',\n },\n }),\n});\n\nmodule.exports = (Button: ButtonType);\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 * @flow strict-local\n * @format\n */\n\nimport type {PressEvent} from '../Types/CoreEventTypes';\n\nimport * as PressabilityDebug from '../Pressability/PressabilityDebug';\nimport usePressability from '../Pressability/usePressability';\nimport flattenStyle from '../StyleSheet/flattenStyle';\nimport processColor from '../StyleSheet/processColor';\nimport StyleSheet from '../StyleSheet/StyleSheet';\nimport {getAccessibilityRoleFromRole} from '../Utilities/AcessibilityMapping';\nimport Platform from '../Utilities/Platform';\nimport TextAncestor from './TextAncestor';\nimport {NativeText, NativeVirtualText} from './TextNativeComponent';\nimport {type TextProps} from './TextProps';\nimport * as React from 'react';\nimport {useContext, useMemo, useState} from 'react';\n\n/**\n * Text is the fundamental component for displaying text.\n *\n * @see https://reactnative.dev/docs/text\n */\nconst Text: React.AbstractComponent<\n TextProps,\n React.ElementRef,\n> = React.forwardRef((props: TextProps, forwardedRef) => {\n const {\n accessible,\n accessibilityLabel,\n accessibilityRole,\n allowFontScaling,\n 'aria-busy': ariaBusy,\n 'aria-checked': ariaChecked,\n 'aria-disabled': ariaDisabled,\n 'aria-expanded': ariaExpanded,\n 'aria-label': ariaLabel,\n 'aria-selected': ariaSelected,\n ellipsizeMode,\n id,\n nativeID,\n onLongPress,\n onPress,\n onPressIn,\n onPressOut,\n onResponderGrant,\n onResponderMove,\n onResponderRelease,\n onResponderTerminate,\n onResponderTerminationRequest,\n onStartShouldSetResponder,\n pressRetentionOffset,\n role,\n suppressHighlighting,\n numberOfLines,\n ...restProps\n } = props;\n\n const [isHighlighted, setHighlighted] = useState(false);\n\n const _accessibilityState = {\n busy: ariaBusy ?? props.accessibilityState?.busy,\n checked: ariaChecked ?? props.accessibilityState?.checked,\n disabled: ariaDisabled ?? props.accessibilityState?.disabled,\n expanded: ariaExpanded ?? props.accessibilityState?.expanded,\n selected: ariaSelected ?? props.accessibilityState?.selected,\n };\n\n const _disabled =\n restProps.disabled != null\n ? restProps.disabled\n : _accessibilityState?.disabled;\n\n const nativeTextAccessibilityState =\n _disabled !== _accessibilityState?.disabled\n ? {..._accessibilityState, disabled: _disabled}\n : _accessibilityState;\n\n const isPressable =\n (onPress != null ||\n onLongPress != null ||\n onStartShouldSetResponder != null) &&\n _disabled !== true;\n\n const initialized = useLazyInitialization(isPressable);\n const config = useMemo(\n () =>\n initialized\n ? {\n disabled: !isPressable,\n pressRectOffset: pressRetentionOffset,\n onLongPress,\n onPress,\n onPressIn(event: PressEvent) {\n setHighlighted(!suppressHighlighting);\n onPressIn?.(event);\n },\n onPressOut(event: PressEvent) {\n setHighlighted(false);\n onPressOut?.(event);\n },\n onResponderTerminationRequest_DEPRECATED:\n onResponderTerminationRequest,\n onStartShouldSetResponder_DEPRECATED: onStartShouldSetResponder,\n }\n : null,\n [\n initialized,\n isPressable,\n pressRetentionOffset,\n onLongPress,\n onPress,\n onPressIn,\n onPressOut,\n onResponderTerminationRequest,\n onStartShouldSetResponder,\n suppressHighlighting,\n ],\n );\n\n const eventHandlers = usePressability(config);\n const eventHandlersForText = useMemo(\n () =>\n eventHandlers == null\n ? null\n : {\n onResponderGrant(event: PressEvent) {\n eventHandlers.onResponderGrant(event);\n if (onResponderGrant != null) {\n onResponderGrant(event);\n }\n },\n onResponderMove(event: PressEvent) {\n eventHandlers.onResponderMove(event);\n if (onResponderMove != null) {\n onResponderMove(event);\n }\n },\n onResponderRelease(event: PressEvent) {\n eventHandlers.onResponderRelease(event);\n if (onResponderRelease != null) {\n onResponderRelease(event);\n }\n },\n onResponderTerminate(event: PressEvent) {\n eventHandlers.onResponderTerminate(event);\n if (onResponderTerminate != null) {\n onResponderTerminate(event);\n }\n },\n onClick: eventHandlers.onClick,\n onResponderTerminationRequest:\n eventHandlers.onResponderTerminationRequest,\n onStartShouldSetResponder: eventHandlers.onStartShouldSetResponder,\n },\n [\n eventHandlers,\n onResponderGrant,\n onResponderMove,\n onResponderRelease,\n onResponderTerminate,\n ],\n );\n\n // TODO: Move this processing to the view configuration.\n const selectionColor =\n restProps.selectionColor == null\n ? null\n : processColor(restProps.selectionColor);\n\n let style = flattenStyle(restProps.style);\n\n let _selectable = restProps.selectable;\n if (style?.userSelect != null) {\n _selectable = userSelectToSelectableMap[style.userSelect];\n }\n\n if (style?.verticalAlign != null) {\n style = StyleSheet.compose(style, {\n textAlignVertical:\n verticalAlignToTextAlignVerticalMap[style.verticalAlign],\n });\n }\n\n if (__DEV__) {\n if (PressabilityDebug.isEnabled() && onPress != null) {\n style = StyleSheet.compose(restProps.style, {\n color: 'magenta',\n });\n }\n }\n\n let numberOfLinesValue = numberOfLines;\n if (numberOfLines != null && !(numberOfLines >= 0)) {\n console.error(\n `'numberOfLines' in must be a non-negative number, received: ${numberOfLines}. The value will be set to 0.`,\n );\n numberOfLinesValue = 0;\n }\n\n const hasTextAncestor = useContext(TextAncestor);\n\n const _accessible = Platform.select({\n ios: accessible !== false,\n default: accessible,\n });\n\n let flattenedStyle = flattenStyle(style);\n\n if (typeof flattenedStyle?.fontWeight === 'number') {\n flattenedStyle.fontWeight = flattenedStyle?.fontWeight.toString();\n }\n\n const _hasOnPressOrOnLongPress =\n props.onPress != null || props.onLongPress != null;\n\n return hasTextAncestor ? (\n \n ) : (\n \n \n \n );\n});\n\nText.displayName = 'Text';\n\n/**\n * Switch to `deprecated-react-native-prop-types` for compatibility with future\n * releases. This is deprecated and will be removed in the future.\n */\nText.propTypes = require('deprecated-react-native-prop-types').TextPropTypes;\n\n/**\n * Returns false until the first time `newValue` is true, after which this will\n * always return true. This is necessary to lazily initialize `Pressability` so\n * we do not eagerly create one for every pressable `Text` component.\n */\nfunction useLazyInitialization(newValue: boolean): boolean {\n const [oldValue, setValue] = useState(newValue);\n if (!oldValue && newValue) {\n setValue(newValue);\n }\n return oldValue;\n}\n\nconst userSelectToSelectableMap = {\n auto: true,\n text: true,\n none: false,\n contain: true,\n all: true,\n};\n\nconst verticalAlignToTextAlignVerticalMap = {\n auto: 'auto',\n top: 'top',\n bottom: 'bottom',\n middle: 'center',\n};\n\nmodule.exports = Text;\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 * @flow strict-local\n * @format\n */\n\nimport type {ColorValue} from '../StyleSheet/StyleSheet';\n\nimport View from '../Components/View/View';\nimport normalizeColor from '../StyleSheet/normalizeColor';\nimport {type RectOrSize, normalizeRect} from '../StyleSheet/Rect';\nimport * as React from 'react';\n\ntype Props = $ReadOnly<{|\n color: ColorValue,\n hitSlop: ?RectOrSize,\n|}>;\n\n/**\n * Displays a debug overlay to visualize press targets when enabled via the\n * React Native Inspector. Calls to this module should be guarded by `__DEV__`,\n * for example:\n *\n * return (\n * \n * {children}\n * {__DEV__ ? (\n * \n * ) : null}\n * \n * );\n *\n */\nexport function PressabilityDebugView(props: Props): React.Node {\n if (__DEV__) {\n if (isEnabled()) {\n const normalizedColor = normalizeColor(props.color);\n if (typeof normalizedColor !== 'number') {\n return null;\n }\n const baseColor =\n '#' + (normalizedColor ?? 0).toString(16).padStart(8, '0');\n const hitSlop = normalizeRect(props.hitSlop);\n return (\n \n );\n }\n }\n return null;\n}\n\nlet isDebugEnabled = false;\n\nexport function isEnabled(): boolean {\n if (__DEV__) {\n return isDebugEnabled;\n }\n return false;\n}\n\nexport function setEnabled(value: boolean): void {\n if (__DEV__) {\n isDebugEnabled = value;\n }\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 * @flow strict-local\n * @format\n */\n\nimport Pressability, {\n type EventHandlers,\n type PressabilityConfig,\n} from './Pressability';\nimport {useEffect, useRef} from 'react';\n\n/**\n * Creates a persistent instance of `Pressability` that automatically configures\n * itself and resets. Accepts null `config` to support lazy initialization. Once\n * initialized, will not un-initialize until the component has been unmounted.\n */\nexport default function usePressability(\n config: ?PressabilityConfig,\n): ?EventHandlers {\n const pressabilityRef = useRef(null);\n if (config != null && pressabilityRef.current == null) {\n pressabilityRef.current = new Pressability(config);\n }\n const pressability = pressabilityRef.current;\n\n // On the initial mount, this is a no-op. On updates, `pressability` will be\n // re-configured to use the new configuration.\n useEffect(() => {\n if (config != null && pressability != null) {\n pressability.configure(config);\n }\n }, [config, pressability]);\n\n // On unmount, reset pending state and timers inside `pressability`. This is\n // a separate effect because we do not want to reset when `config` changes.\n useEffect(() => {\n if (pressability != null) {\n return () => {\n pressability.reset();\n };\n }\n }, [pressability]);\n\n return pressability == null ? null : pressability.getEventHandlers();\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 * @flow strict-local\n * @format\n */\n\nimport type {HostComponent} from '../Renderer/shims/ReactNativeTypes';\nimport type {\n BlurEvent,\n FocusEvent,\n MouseEvent,\n PressEvent,\n} from '../Types/CoreEventTypes';\n\nimport SoundManager from '../Components/Sound/SoundManager';\nimport ReactNativeFeatureFlags from '../ReactNative/ReactNativeFeatureFlags';\nimport UIManager from '../ReactNative/UIManager';\nimport {type RectOrSize, normalizeRect} from '../StyleSheet/Rect';\nimport {type PointerEvent} from '../Types/CoreEventTypes';\nimport Platform from '../Utilities/Platform';\nimport {isHoverEnabled} from './HoverState';\nimport PressabilityPerformanceEventEmitter from './PressabilityPerformanceEventEmitter.js';\nimport {type PressabilityTouchSignal as TouchSignal} from './PressabilityTypes.js';\nimport invariant from 'invariant';\nimport * as React from 'react';\n\nexport type PressabilityConfig = $ReadOnly<{|\n /**\n * Whether a press gesture can be interrupted by a parent gesture such as a\n * scroll event. Defaults to true.\n */\n cancelable?: ?boolean,\n\n /**\n * Whether to disable initialization of the press gesture.\n */\n disabled?: ?boolean,\n\n /**\n * Amount to extend the `VisualRect` by to create `HitRect`.\n */\n hitSlop?: ?RectOrSize,\n\n /**\n * Amount to extend the `HitRect` by to create `PressRect`.\n */\n pressRectOffset?: ?RectOrSize,\n\n /**\n * Whether to disable the systemm sound when `onPress` fires on Android.\n **/\n android_disableSound?: ?boolean,\n\n /**\n * Duration to wait after hover in before calling `onHoverIn`.\n */\n delayHoverIn?: ?number,\n\n /**\n * Duration to wait after hover out before calling `onHoverOut`.\n */\n delayHoverOut?: ?number,\n\n /**\n * Duration (in addition to `delayPressIn`) after which a press gesture is\n * considered a long press gesture. Defaults to 500 (milliseconds).\n */\n delayLongPress?: ?number,\n\n /**\n * Duration to wait after press down before calling `onPressIn`.\n */\n delayPressIn?: ?number,\n\n /**\n * Duration to wait after letting up before calling `onPressOut`.\n */\n delayPressOut?: ?number,\n\n /**\n * Minimum duration to wait between calling `onPressIn` and `onPressOut`.\n */\n minPressDuration?: ?number,\n\n /**\n * Called after the element loses focus.\n */\n onBlur?: ?(event: BlurEvent) => mixed,\n\n /**\n * Called after the element is focused.\n */\n onFocus?: ?(event: FocusEvent) => mixed,\n\n /**\n * Called when the hover is activated to provide visual feedback.\n */\n onHoverIn?: ?(event: MouseEvent) => mixed,\n\n /**\n * Called when the hover is deactivated to undo visual feedback.\n */\n onHoverOut?: ?(event: MouseEvent) => mixed,\n\n /**\n * Called when a long press gesture has been triggered.\n */\n onLongPress?: ?(event: PressEvent) => mixed,\n\n /**\n * Called when a press gestute has been triggered.\n */\n onPress?: ?(event: PressEvent) => mixed,\n\n /**\n * Called when the press is activated to provide visual feedback.\n */\n onPressIn?: ?(event: PressEvent) => mixed,\n\n /**\n * Called when the press location moves. (This should rarely be used.)\n */\n onPressMove?: ?(event: PressEvent) => mixed,\n\n /**\n * Called when the press is deactivated to undo visual feedback.\n */\n onPressOut?: ?(event: PressEvent) => mixed,\n\n /**\n * Returns whether a long press gesture should cancel the press gesture.\n * Defaults to true.\n */\n onLongPressShouldCancelPress_DEPRECATED?: ?() => boolean,\n\n /**\n * If `cancelable` is set, this will be ignored.\n *\n * Returns whether to yield to a lock termination request (e.g. if a native\n * scroll gesture attempts to steal the responder lock).\n */\n onResponderTerminationRequest_DEPRECATED?: ?() => boolean,\n\n /**\n * If `disabled` is set, this will be ignored.\n *\n * Returns whether to start a press gesture.\n *\n * @deprecated\n */\n onStartShouldSetResponder_DEPRECATED?: ?() => boolean,\n|}>;\n\nexport type EventHandlers = $ReadOnly<{|\n onBlur: (event: BlurEvent) => void,\n onClick: (event: PressEvent) => void,\n onFocus: (event: FocusEvent) => void,\n onMouseEnter?: (event: MouseEvent) => void,\n onMouseLeave?: (event: MouseEvent) => void,\n onPointerEnter?: (event: PointerEvent) => void,\n onPointerLeave?: (event: PointerEvent) => void,\n onResponderGrant: (event: PressEvent) => void,\n onResponderMove: (event: PressEvent) => void,\n onResponderRelease: (event: PressEvent) => void,\n onResponderTerminate: (event: PressEvent) => void,\n onResponderTerminationRequest: () => boolean,\n onStartShouldSetResponder: () => boolean,\n|}>;\n\ntype TouchState =\n | 'NOT_RESPONDER'\n | 'RESPONDER_INACTIVE_PRESS_IN'\n | 'RESPONDER_INACTIVE_PRESS_OUT'\n | 'RESPONDER_ACTIVE_PRESS_IN'\n | 'RESPONDER_ACTIVE_PRESS_OUT'\n | 'RESPONDER_ACTIVE_LONG_PRESS_IN'\n | 'RESPONDER_ACTIVE_LONG_PRESS_OUT'\n | 'ERROR';\n\nconst Transitions = Object.freeze({\n NOT_RESPONDER: {\n DELAY: 'ERROR',\n RESPONDER_GRANT: 'RESPONDER_INACTIVE_PRESS_IN',\n RESPONDER_RELEASE: 'ERROR',\n RESPONDER_TERMINATED: 'ERROR',\n ENTER_PRESS_RECT: 'ERROR',\n LEAVE_PRESS_RECT: 'ERROR',\n LONG_PRESS_DETECTED: 'ERROR',\n },\n RESPONDER_INACTIVE_PRESS_IN: {\n DELAY: 'RESPONDER_ACTIVE_PRESS_IN',\n RESPONDER_GRANT: 'ERROR',\n RESPONDER_RELEASE: 'NOT_RESPONDER',\n RESPONDER_TERMINATED: 'NOT_RESPONDER',\n ENTER_PRESS_RECT: 'RESPONDER_INACTIVE_PRESS_IN',\n LEAVE_PRESS_RECT: 'RESPONDER_INACTIVE_PRESS_OUT',\n LONG_PRESS_DETECTED: 'ERROR',\n },\n RESPONDER_INACTIVE_PRESS_OUT: {\n DELAY: 'RESPONDER_ACTIVE_PRESS_OUT',\n RESPONDER_GRANT: 'ERROR',\n RESPONDER_RELEASE: 'NOT_RESPONDER',\n RESPONDER_TERMINATED: 'NOT_RESPONDER',\n ENTER_PRESS_RECT: 'RESPONDER_INACTIVE_PRESS_IN',\n LEAVE_PRESS_RECT: 'RESPONDER_INACTIVE_PRESS_OUT',\n LONG_PRESS_DETECTED: 'ERROR',\n },\n RESPONDER_ACTIVE_PRESS_IN: {\n DELAY: 'ERROR',\n RESPONDER_GRANT: 'ERROR',\n RESPONDER_RELEASE: 'NOT_RESPONDER',\n RESPONDER_TERMINATED: 'NOT_RESPONDER',\n ENTER_PRESS_RECT: 'RESPONDER_ACTIVE_PRESS_IN',\n LEAVE_PRESS_RECT: 'RESPONDER_ACTIVE_PRESS_OUT',\n LONG_PRESS_DETECTED: 'RESPONDER_ACTIVE_LONG_PRESS_IN',\n },\n RESPONDER_ACTIVE_PRESS_OUT: {\n DELAY: 'ERROR',\n RESPONDER_GRANT: 'ERROR',\n RESPONDER_RELEASE: 'NOT_RESPONDER',\n RESPONDER_TERMINATED: 'NOT_RESPONDER',\n ENTER_PRESS_RECT: 'RESPONDER_ACTIVE_PRESS_IN',\n LEAVE_PRESS_RECT: 'RESPONDER_ACTIVE_PRESS_OUT',\n LONG_PRESS_DETECTED: 'ERROR',\n },\n RESPONDER_ACTIVE_LONG_PRESS_IN: {\n DELAY: 'ERROR',\n RESPONDER_GRANT: 'ERROR',\n RESPONDER_RELEASE: 'NOT_RESPONDER',\n RESPONDER_TERMINATED: 'NOT_RESPONDER',\n ENTER_PRESS_RECT: 'RESPONDER_ACTIVE_LONG_PRESS_IN',\n LEAVE_PRESS_RECT: 'RESPONDER_ACTIVE_LONG_PRESS_OUT',\n LONG_PRESS_DETECTED: 'RESPONDER_ACTIVE_LONG_PRESS_IN',\n },\n RESPONDER_ACTIVE_LONG_PRESS_OUT: {\n DELAY: 'ERROR',\n RESPONDER_GRANT: 'ERROR',\n RESPONDER_RELEASE: 'NOT_RESPONDER',\n RESPONDER_TERMINATED: 'NOT_RESPONDER',\n ENTER_PRESS_RECT: 'RESPONDER_ACTIVE_LONG_PRESS_IN',\n LEAVE_PRESS_RECT: 'RESPONDER_ACTIVE_LONG_PRESS_OUT',\n LONG_PRESS_DETECTED: 'ERROR',\n },\n ERROR: {\n DELAY: 'NOT_RESPONDER',\n RESPONDER_GRANT: 'RESPONDER_INACTIVE_PRESS_IN',\n RESPONDER_RELEASE: 'NOT_RESPONDER',\n RESPONDER_TERMINATED: 'NOT_RESPONDER',\n ENTER_PRESS_RECT: 'NOT_RESPONDER',\n LEAVE_PRESS_RECT: 'NOT_RESPONDER',\n LONG_PRESS_DETECTED: 'NOT_RESPONDER',\n },\n});\n\nconst isActiveSignal = (signal: TouchState) =>\n signal === 'RESPONDER_ACTIVE_PRESS_IN' ||\n signal === 'RESPONDER_ACTIVE_LONG_PRESS_IN';\n\nconst isActivationSignal = (signal: TouchState) =>\n signal === 'RESPONDER_ACTIVE_PRESS_OUT' ||\n signal === 'RESPONDER_ACTIVE_PRESS_IN';\n\nconst isPressInSignal = (signal: TouchState) =>\n signal === 'RESPONDER_INACTIVE_PRESS_IN' ||\n signal === 'RESPONDER_ACTIVE_PRESS_IN' ||\n signal === 'RESPONDER_ACTIVE_LONG_PRESS_IN';\n\nconst isTerminalSignal = (signal: TouchSignal) =>\n signal === 'RESPONDER_TERMINATED' || signal === 'RESPONDER_RELEASE';\n\nconst DEFAULT_LONG_PRESS_DELAY_MS = 500;\nconst DEFAULT_PRESS_RECT_OFFSETS = {\n bottom: 30,\n left: 20,\n right: 20,\n top: 20,\n};\nconst DEFAULT_MIN_PRESS_DURATION = 130;\n\n/**\n * Pressability implements press handling capabilities.\n *\n * =========================== Pressability Tutorial ===========================\n *\n * The `Pressability` class helps you create press interactions by analyzing the\n * geometry of elements and observing when another responder (e.g. ScrollView)\n * has stolen the touch lock. It offers hooks for your component to provide\n * interaction feedback to the user:\n *\n * - When a press has activated (e.g. highlight an element)\n * - When a press has deactivated (e.g. un-highlight an element)\n * - When a press sould trigger an action, meaning it activated and deactivated\n * while within the geometry of the element without the lock being stolen.\n *\n * A high quality interaction isn't as simple as you might think. There should\n * be a slight delay before activation. Moving your finger beyond an element's\n * bounds should trigger deactivation, but moving the same finger back within an\n * element's bounds should trigger reactivation.\n *\n * In order to use `Pressability`, do the following:\n *\n * 1. Instantiate `Pressability` and store it on your component's state.\n *\n * state = {\n * pressability: new Pressability({\n * // ...\n * }),\n * };\n *\n * 2. Choose the rendered component who should collect the press events. On that\n * element, spread `pressability.getEventHandlers()` into its props.\n *\n * return (\n * \n * );\n *\n * 3. Reset `Pressability` when your component unmounts.\n *\n * componentWillUnmount() {\n * this.state.pressability.reset();\n * }\n *\n * ==================== Pressability Implementation Details ====================\n *\n * `Pressability` only assumes that there exists a `HitRect` node. The `PressRect`\n * is an abstract box that is extended beyond the `HitRect`.\n *\n * # Geometry\n *\n * ┌────────────────────────┐\n * │ ┌──────────────────┐ │ - Presses start anywhere within `HitRect`, which\n * │ │ ┌────────────┐ │ │ is expanded via the prop `hitSlop`.\n * │ │ │ VisualRect │ │ │\n * │ │ └────────────┘ │ │ - When pressed down for sufficient amount of time\n * │ │ HitRect │ │ before letting up, `VisualRect` activates for\n * │ └──────────────────┘ │ as long as the press stays within `PressRect`.\n * │ PressRect o │\n * └────────────────────│───┘\n * Out Region └────── `PressRect`, which is expanded via the prop\n * `pressRectOffset`, allows presses to move\n * beyond `HitRect` while maintaining activation\n * and being eligible for a \"press\".\n *\n * # State Machine\n *\n * ┌───────────────┐ ◀──── RESPONDER_RELEASE\n * │ NOT_RESPONDER │\n * └───┬───────────┘ ◀──── RESPONDER_TERMINATED\n * │\n * │ RESPONDER_GRANT (HitRect)\n * │\n * ▼\n * ┌─────────────────────┐ ┌───────────────────┐ ┌───────────────────┐\n * │ RESPONDER_INACTIVE_ │ DELAY │ RESPONDER_ACTIVE_ │ T + DELAY │ RESPONDER_ACTIVE_ │\n * │ PRESS_IN ├────────▶ │ PRESS_IN ├────────────▶ │ LONG_PRESS_IN │\n * └─┬───────────────────┘ └─┬─────────────────┘ └─┬─────────────────┘\n * │ ▲ │ ▲ │ ▲\n * │LEAVE_ │ │LEAVE_ │ │LEAVE_ │\n * │PRESS_RECT │ENTER_ │PRESS_RECT │ENTER_ │PRESS_RECT │ENTER_\n * │ │PRESS_RECT │ │PRESS_RECT │ │PRESS_RECT\n * ▼ │ ▼ │ ▼ │\n * ┌─────────────┴───────┐ ┌─────────────┴─────┐ ┌─────────────┴─────┐\n * │ RESPONDER_INACTIVE_ │ DELAY │ RESPONDER_ACTIVE_ │ │ RESPONDER_ACTIVE_ │\n * │ PRESS_OUT ├────────▶ │ PRESS_OUT │ │ LONG_PRESS_OUT │\n * └─────────────────────┘ └───────────────────┘ └───────────────────┘\n *\n * T + DELAY => LONG_PRESS_DELAY + DELAY\n *\n * Not drawn are the side effects of each transition. The most important side\n * effect is the invocation of `onPress` and `onLongPress` that occur when a\n * responder is release while in the \"press in\" states.\n */\nexport default class Pressability {\n _config: PressabilityConfig;\n _eventHandlers: ?EventHandlers = null;\n _hoverInDelayTimeout: ?TimeoutID = null;\n _hoverOutDelayTimeout: ?TimeoutID = null;\n _isHovered: boolean = false;\n _longPressDelayTimeout: ?TimeoutID = null;\n _pressDelayTimeout: ?TimeoutID = null;\n _pressOutDelayTimeout: ?TimeoutID = null;\n _responderID: ?number | React.ElementRef> = null;\n _responderRegion: ?$ReadOnly<{|\n bottom: number,\n left: number,\n right: number,\n top: number,\n |}> = null;\n _touchActivatePosition: ?$ReadOnly<{|\n pageX: number,\n pageY: number,\n |}>;\n _touchActivateTime: ?number;\n _touchState: TouchState = 'NOT_RESPONDER';\n\n constructor(config: PressabilityConfig) {\n this.configure(config);\n }\n\n configure(config: PressabilityConfig): void {\n this._config = config;\n }\n\n /**\n * Resets any pending timers. This should be called on unmount.\n */\n reset(): void {\n this._cancelHoverInDelayTimeout();\n this._cancelHoverOutDelayTimeout();\n this._cancelLongPressDelayTimeout();\n this._cancelPressDelayTimeout();\n this._cancelPressOutDelayTimeout();\n\n // Ensure that, if any async event handlers are fired after unmount\n // due to a race, we don't call any configured callbacks.\n this._config = Object.freeze({});\n }\n\n /**\n * Returns a set of props to spread into the interactive element.\n */\n getEventHandlers(): EventHandlers {\n if (this._eventHandlers == null) {\n this._eventHandlers = this._createEventHandlers();\n }\n return this._eventHandlers;\n }\n\n _createEventHandlers(): EventHandlers {\n const focusEventHandlers = {\n onBlur: (event: BlurEvent): void => {\n const {onBlur} = this._config;\n if (onBlur != null) {\n onBlur(event);\n }\n },\n onFocus: (event: FocusEvent): void => {\n const {onFocus} = this._config;\n if (onFocus != null) {\n onFocus(event);\n }\n },\n };\n\n const responderEventHandlers = {\n onStartShouldSetResponder: (): boolean => {\n const {disabled} = this._config;\n if (disabled == null) {\n const {onStartShouldSetResponder_DEPRECATED} = this._config;\n return onStartShouldSetResponder_DEPRECATED == null\n ? true\n : onStartShouldSetResponder_DEPRECATED();\n }\n return !disabled;\n },\n\n onResponderGrant: (event: PressEvent): void => {\n event.persist();\n\n this._cancelPressOutDelayTimeout();\n\n this._responderID = event.currentTarget;\n this._touchState = 'NOT_RESPONDER';\n this._receiveSignal('RESPONDER_GRANT', event);\n\n const delayPressIn = normalizeDelay(this._config.delayPressIn);\n if (delayPressIn > 0) {\n this._pressDelayTimeout = setTimeout(() => {\n this._receiveSignal('DELAY', event);\n }, delayPressIn);\n } else {\n this._receiveSignal('DELAY', event);\n }\n\n const delayLongPress = normalizeDelay(\n this._config.delayLongPress,\n 10,\n DEFAULT_LONG_PRESS_DELAY_MS - delayPressIn,\n );\n this._longPressDelayTimeout = setTimeout(() => {\n this._handleLongPress(event);\n }, delayLongPress + delayPressIn);\n },\n\n onResponderMove: (event: PressEvent): void => {\n const {onPressMove} = this._config;\n if (onPressMove != null) {\n onPressMove(event);\n }\n\n // Region may not have finished being measured, yet.\n const responderRegion = this._responderRegion;\n if (responderRegion == null) {\n return;\n }\n\n const touch = getTouchFromPressEvent(event);\n if (touch == null) {\n this._cancelLongPressDelayTimeout();\n this._receiveSignal('LEAVE_PRESS_RECT', event);\n return;\n }\n\n if (this._touchActivatePosition != null) {\n const deltaX = this._touchActivatePosition.pageX - touch.pageX;\n const deltaY = this._touchActivatePosition.pageY - touch.pageY;\n if (Math.hypot(deltaX, deltaY) > 10) {\n this._cancelLongPressDelayTimeout();\n }\n }\n\n if (this._isTouchWithinResponderRegion(touch, responderRegion)) {\n this._receiveSignal('ENTER_PRESS_RECT', event);\n } else {\n this._cancelLongPressDelayTimeout();\n this._receiveSignal('LEAVE_PRESS_RECT', event);\n }\n },\n\n onResponderRelease: (event: PressEvent): void => {\n this._receiveSignal('RESPONDER_RELEASE', event);\n },\n\n onResponderTerminate: (event: PressEvent): void => {\n this._receiveSignal('RESPONDER_TERMINATED', event);\n },\n\n onResponderTerminationRequest: (): boolean => {\n const {cancelable} = this._config;\n if (cancelable == null) {\n const {onResponderTerminationRequest_DEPRECATED} = this._config;\n return onResponderTerminationRequest_DEPRECATED == null\n ? true\n : onResponderTerminationRequest_DEPRECATED();\n }\n return cancelable;\n },\n\n onClick: (event: PressEvent): void => {\n const {onPress, disabled} = this._config;\n if (onPress != null && disabled !== true) {\n onPress(event);\n }\n },\n };\n\n if (process.env.NODE_ENV === 'test') {\n // We are setting this in order to find this node in ReactNativeTestTools\n // $FlowFixMe[prop-missing]\n responderEventHandlers.onStartShouldSetResponder.testOnly_pressabilityConfig =\n () => this._config;\n }\n\n if (\n ReactNativeFeatureFlags.shouldPressibilityUseW3CPointerEventsForHover()\n ) {\n const hoverPointerEvents = {\n onPointerEnter: undefined,\n onPointerLeave: undefined,\n };\n const {onHoverIn, onHoverOut} = this._config;\n if (onHoverIn != null) {\n hoverPointerEvents.onPointerEnter = (event: PointerEvent) => {\n this._isHovered = true;\n this._cancelHoverOutDelayTimeout();\n if (onHoverIn != null) {\n const delayHoverIn = normalizeDelay(this._config.delayHoverIn);\n if (delayHoverIn > 0) {\n event.persist();\n this._hoverInDelayTimeout = setTimeout(() => {\n onHoverIn(convertPointerEventToMouseEvent(event));\n }, delayHoverIn);\n } else {\n onHoverIn(convertPointerEventToMouseEvent(event));\n }\n }\n };\n }\n if (onHoverOut != null) {\n hoverPointerEvents.onPointerLeave = (event: PointerEvent) => {\n if (this._isHovered) {\n this._isHovered = false;\n this._cancelHoverInDelayTimeout();\n if (onHoverOut != null) {\n const delayHoverOut = normalizeDelay(this._config.delayHoverOut);\n if (delayHoverOut > 0) {\n event.persist();\n this._hoverOutDelayTimeout = setTimeout(() => {\n onHoverOut(convertPointerEventToMouseEvent(event));\n }, delayHoverOut);\n } else {\n onHoverOut(convertPointerEventToMouseEvent(event));\n }\n }\n }\n };\n }\n return {\n ...focusEventHandlers,\n ...responderEventHandlers,\n ...hoverPointerEvents,\n };\n } else {\n const mouseEventHandlers =\n Platform.OS === 'ios' || Platform.OS === 'android'\n ? null\n : {\n onMouseEnter: (event: MouseEvent): void => {\n if (isHoverEnabled()) {\n this._isHovered = true;\n this._cancelHoverOutDelayTimeout();\n const {onHoverIn} = this._config;\n if (onHoverIn != null) {\n const delayHoverIn = normalizeDelay(\n this._config.delayHoverIn,\n );\n if (delayHoverIn > 0) {\n event.persist();\n this._hoverInDelayTimeout = setTimeout(() => {\n onHoverIn(event);\n }, delayHoverIn);\n } else {\n onHoverIn(event);\n }\n }\n }\n },\n\n onMouseLeave: (event: MouseEvent): void => {\n if (this._isHovered) {\n this._isHovered = false;\n this._cancelHoverInDelayTimeout();\n const {onHoverOut} = this._config;\n if (onHoverOut != null) {\n const delayHoverOut = normalizeDelay(\n this._config.delayHoverOut,\n );\n if (delayHoverOut > 0) {\n event.persist();\n this._hoverInDelayTimeout = setTimeout(() => {\n onHoverOut(event);\n }, delayHoverOut);\n } else {\n onHoverOut(event);\n }\n }\n }\n },\n };\n return {\n ...focusEventHandlers,\n ...responderEventHandlers,\n ...mouseEventHandlers,\n };\n }\n }\n\n /**\n * Receives a state machine signal, performs side effects of the transition\n * and stores the new state. Validates the transition as well.\n */\n _receiveSignal(signal: TouchSignal, event: PressEvent): void {\n // Especially on iOS, not all events have timestamps associated.\n // For telemetry purposes, this doesn't matter too much, as long as *some* do.\n // Since the native timestamp is integral for logging telemetry, just skip\n // events if they don't have a timestamp attached.\n if (event.nativeEvent.timestamp != null) {\n PressabilityPerformanceEventEmitter.emitEvent(() => {\n return {\n signal,\n nativeTimestamp: event.nativeEvent.timestamp,\n };\n });\n }\n\n const prevState = this._touchState;\n const nextState = Transitions[prevState]?.[signal];\n if (this._responderID == null && signal === 'RESPONDER_RELEASE') {\n return;\n }\n invariant(\n nextState != null && nextState !== 'ERROR',\n 'Pressability: Invalid signal `%s` for state `%s` on responder: %s',\n signal,\n prevState,\n typeof this._responderID === 'number'\n ? this._responderID\n : '<>',\n );\n if (prevState !== nextState) {\n this._performTransitionSideEffects(prevState, nextState, signal, event);\n this._touchState = nextState;\n }\n }\n\n /**\n * Performs a transition between touchable states and identify any activations\n * or deactivations (and callback invocations).\n */\n _performTransitionSideEffects(\n prevState: TouchState,\n nextState: TouchState,\n signal: TouchSignal,\n event: PressEvent,\n ): void {\n if (isTerminalSignal(signal)) {\n this._touchActivatePosition = null;\n this._cancelLongPressDelayTimeout();\n }\n\n const isInitialTransition =\n prevState === 'NOT_RESPONDER' &&\n nextState === 'RESPONDER_INACTIVE_PRESS_IN';\n\n const isActivationTransition =\n !isActivationSignal(prevState) && isActivationSignal(nextState);\n\n if (isInitialTransition || isActivationTransition) {\n this._measureResponderRegion();\n }\n\n if (isPressInSignal(prevState) && signal === 'LONG_PRESS_DETECTED') {\n const {onLongPress} = this._config;\n if (onLongPress != null) {\n onLongPress(event);\n }\n }\n\n const isPrevActive = isActiveSignal(prevState);\n const isNextActive = isActiveSignal(nextState);\n\n if (!isPrevActive && isNextActive) {\n this._activate(event);\n } else if (isPrevActive && !isNextActive) {\n this._deactivate(event);\n }\n\n if (isPressInSignal(prevState) && signal === 'RESPONDER_RELEASE') {\n // If we never activated (due to delays), activate and deactivate now.\n if (!isNextActive && !isPrevActive) {\n this._activate(event);\n this._deactivate(event);\n }\n const {onLongPress, onPress, android_disableSound} = this._config;\n if (onPress != null) {\n const isPressCanceledByLongPress =\n onLongPress != null &&\n prevState === 'RESPONDER_ACTIVE_LONG_PRESS_IN' &&\n this._shouldLongPressCancelPress();\n if (!isPressCanceledByLongPress) {\n if (Platform.OS === 'android' && android_disableSound !== true) {\n SoundManager.playTouchSound();\n }\n onPress(event);\n }\n }\n }\n\n this._cancelPressDelayTimeout();\n }\n\n _activate(event: PressEvent): void {\n const {onPressIn} = this._config;\n const {pageX, pageY} = getTouchFromPressEvent(event);\n this._touchActivatePosition = {pageX, pageY};\n this._touchActivateTime = Date.now();\n if (onPressIn != null) {\n onPressIn(event);\n }\n }\n\n _deactivate(event: PressEvent): void {\n const {onPressOut} = this._config;\n if (onPressOut != null) {\n const minPressDuration = normalizeDelay(\n this._config.minPressDuration,\n 0,\n DEFAULT_MIN_PRESS_DURATION,\n );\n const pressDuration = Date.now() - (this._touchActivateTime ?? 0);\n const delayPressOut = Math.max(\n minPressDuration - pressDuration,\n normalizeDelay(this._config.delayPressOut),\n );\n if (delayPressOut > 0) {\n event.persist();\n this._pressOutDelayTimeout = setTimeout(() => {\n onPressOut(event);\n }, delayPressOut);\n } else {\n onPressOut(event);\n }\n }\n this._touchActivateTime = null;\n }\n\n _measureResponderRegion(): void {\n if (this._responderID == null) {\n return;\n }\n\n if (typeof this._responderID === 'number') {\n UIManager.measure(this._responderID, this._measureCallback);\n } else {\n this._responderID.measure(this._measureCallback);\n }\n }\n\n _measureCallback = (\n left: number,\n top: number,\n width: number,\n height: number,\n pageX: number,\n pageY: number,\n ) => {\n if (!left && !top && !width && !height && !pageX && !pageY) {\n return;\n }\n this._responderRegion = {\n bottom: pageY + height,\n left: pageX,\n right: pageX + width,\n top: pageY,\n };\n };\n\n _isTouchWithinResponderRegion(\n touch: $PropertyType,\n responderRegion: $ReadOnly<{|\n bottom: number,\n left: number,\n right: number,\n top: number,\n |}>,\n ): boolean {\n const hitSlop = normalizeRect(this._config.hitSlop);\n const pressRectOffset = normalizeRect(this._config.pressRectOffset);\n\n let regionBottom = responderRegion.bottom;\n let regionLeft = responderRegion.left;\n let regionRight = responderRegion.right;\n let regionTop = responderRegion.top;\n\n if (hitSlop != null) {\n if (hitSlop.bottom != null) {\n regionBottom += hitSlop.bottom;\n }\n if (hitSlop.left != null) {\n regionLeft -= hitSlop.left;\n }\n if (hitSlop.right != null) {\n regionRight += hitSlop.right;\n }\n if (hitSlop.top != null) {\n regionTop -= hitSlop.top;\n }\n }\n\n regionBottom +=\n pressRectOffset?.bottom ?? DEFAULT_PRESS_RECT_OFFSETS.bottom;\n regionLeft -= pressRectOffset?.left ?? DEFAULT_PRESS_RECT_OFFSETS.left;\n regionRight += pressRectOffset?.right ?? DEFAULT_PRESS_RECT_OFFSETS.right;\n regionTop -= pressRectOffset?.top ?? DEFAULT_PRESS_RECT_OFFSETS.top;\n\n return (\n touch.pageX > regionLeft &&\n touch.pageX < regionRight &&\n touch.pageY > regionTop &&\n touch.pageY < regionBottom\n );\n }\n\n _handleLongPress(event: PressEvent): void {\n if (\n this._touchState === 'RESPONDER_ACTIVE_PRESS_IN' ||\n this._touchState === 'RESPONDER_ACTIVE_LONG_PRESS_IN'\n ) {\n this._receiveSignal('LONG_PRESS_DETECTED', event);\n }\n }\n\n _shouldLongPressCancelPress(): boolean {\n return (\n this._config.onLongPressShouldCancelPress_DEPRECATED == null ||\n this._config.onLongPressShouldCancelPress_DEPRECATED()\n );\n }\n\n _cancelHoverInDelayTimeout(): void {\n if (this._hoverInDelayTimeout != null) {\n clearTimeout(this._hoverInDelayTimeout);\n this._hoverInDelayTimeout = null;\n }\n }\n\n _cancelHoverOutDelayTimeout(): void {\n if (this._hoverOutDelayTimeout != null) {\n clearTimeout(this._hoverOutDelayTimeout);\n this._hoverOutDelayTimeout = null;\n }\n }\n\n _cancelLongPressDelayTimeout(): void {\n if (this._longPressDelayTimeout != null) {\n clearTimeout(this._longPressDelayTimeout);\n this._longPressDelayTimeout = null;\n }\n }\n\n _cancelPressDelayTimeout(): void {\n if (this._pressDelayTimeout != null) {\n clearTimeout(this._pressDelayTimeout);\n this._pressDelayTimeout = null;\n }\n }\n\n _cancelPressOutDelayTimeout(): void {\n if (this._pressOutDelayTimeout != null) {\n clearTimeout(this._pressOutDelayTimeout);\n this._pressOutDelayTimeout = null;\n }\n }\n}\n\nfunction normalizeDelay(\n delay: ?number,\n min: number = 0,\n fallback: number = 0,\n): number {\n return Math.max(min, delay ?? fallback);\n}\n\nconst getTouchFromPressEvent = (event: PressEvent) => {\n const {changedTouches, touches} = event.nativeEvent;\n\n if (touches != null && touches.length > 0) {\n return touches[0];\n }\n if (changedTouches != null && changedTouches.length > 0) {\n return changedTouches[0];\n }\n return event.nativeEvent;\n};\n\nfunction convertPointerEventToMouseEvent(input: PointerEvent): MouseEvent {\n const {clientX, clientY} = input.nativeEvent;\n return {\n ...input,\n nativeEvent: {\n clientX,\n clientY,\n pageX: clientX,\n pageY: clientY,\n timestamp: input.timeStamp,\n },\n };\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 * @format\n * @flow strict\n */\n\nimport NativeSoundManager from './NativeSoundManager';\n\nconst SoundManager = {\n playTouchSound: function (): void {\n if (NativeSoundManager) {\n NativeSoundManager.playTouchSound();\n }\n },\n};\n\nmodule.exports = SoundManager;\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 * @flow strict\n * @format\n */\n\nimport type {TurboModule} from '../../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../../TurboModule/TurboModuleRegistry';\n\n/**\n * Native Module used for playing sounds in native platform.\n */\nexport interface Spec extends TurboModule {\n +playTouchSound: () => void;\n}\n\nexport default (TurboModuleRegistry.get('SoundManager'): ?Spec);\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 * @flow strict-local\n * @format\n */\n\n'use strict';\n\nexport type FeatureFlags = {|\n /**\n * Function used to enable / disabled Layout Animations in React Native.\n * Default value = true.\n */\n isLayoutAnimationEnabled: () => boolean,\n /**\n * Function used to enable / disable W3C pointer event emitting in React Native.\n * If enabled you must also flip the equivalent native flags on each platform:\n * iOS -> RCTSetDispatchW3CPointerEvents\n * Android -> ReactFeatureFlags.dispatchPointerEvents\n */\n shouldEmitW3CPointerEvents: () => boolean,\n /**\n * Function used to enable / disable Pressibility from using W3C Pointer Events\n * for its hover callbacks\n */\n shouldPressibilityUseW3CPointerEventsForHover: () => boolean,\n /**\n * Enables an experimental flush-queue debouncing in Animated.js.\n */\n animatedShouldDebounceQueueFlush: () => boolean,\n /**\n * Enables an experimental mega-operation for Animated.js that replaces\n * many calls to native with a single call into native, to reduce JSI/JNI\n * traffic.\n */\n animatedShouldUseSingleOp: () => boolean,\n /**\n * This feature flag enables an experimental render system that allows\n * to render react components driven by classes written in C++.\n */\n enableCppRenderSystem: () => boolean,\n\n removeListenersOnDetach: () => boolean,\n|};\n\nconst ReactNativeFeatureFlags: FeatureFlags = {\n isLayoutAnimationEnabled: () => true,\n shouldEmitW3CPointerEvents: () => false,\n shouldPressibilityUseW3CPointerEventsForHover: () => false,\n animatedShouldDebounceQueueFlush: () => false,\n animatedShouldUseSingleOp: () => false,\n enableCppRenderSystem: () => false,\n removeListenersOnDetach: () => false,\n};\n\nmodule.exports = ReactNativeFeatureFlags;\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 * @flow strict-local\n * @format\n */\n\nimport {type PressabilityTouchSignal as TouchSignal} from './PressabilityTypes.js';\n\nexport type PressabilityPerformanceEvent = $ReadOnly<{|\n signal: TouchSignal,\n nativeTimestamp: number,\n|}>;\nexport type PressabilityPerformanceEventListener =\n PressabilityPerformanceEvent => void;\n\nclass PressabilityPerformanceEventEmitter {\n _listeners: Array = [];\n\n constructor() {}\n\n addListener(listener: PressabilityPerformanceEventListener): void {\n this._listeners.push(listener);\n }\n\n removeListener(listener: PressabilityPerformanceEventListener): void {\n const index = this._listeners.indexOf(listener);\n if (index > -1) {\n this._listeners.splice(index, 1);\n }\n }\n\n emitEvent(constructEvent: () => PressabilityPerformanceEvent): void {\n if (this._listeners.length === 0) {\n return;\n }\n\n const event = constructEvent();\n this._listeners.forEach(listener => listener(event));\n }\n}\n\nconst PressabilityPerformanceEventEmitterSingleton: PressabilityPerformanceEventEmitter =\n new PressabilityPerformanceEventEmitter();\n\nexport default PressabilityPerformanceEventEmitterSingleton;\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 * @flow strict\n * @format\n */\n\nimport Platform from '../Utilities/Platform';\n\nlet isEnabled = false;\n\nif (Platform.OS === 'web') {\n const canUseDOM = Boolean(\n typeof window !== 'undefined' &&\n window.document &&\n window.document.createElement,\n );\n\n if (canUseDOM) {\n /**\n * Web browsers emulate mouse events (and hover states) after touch events.\n * This code infers when the currently-in-use modality supports hover\n * (including for multi-modality devices) and considers \"hover\" to be enabled\n * if a mouse movement occurs more than 1 second after the last touch event.\n * This threshold is long enough to account for longer delays between the\n * browser firing touch and mouse events on low-powered devices.\n */\n const HOVER_THRESHOLD_MS = 1000;\n let lastTouchTimestamp = 0;\n\n const enableHover = () => {\n if (isEnabled || Date.now() - lastTouchTimestamp < HOVER_THRESHOLD_MS) {\n return;\n }\n isEnabled = true;\n };\n\n const disableHover = () => {\n lastTouchTimestamp = Date.now();\n if (isEnabled) {\n isEnabled = false;\n }\n };\n\n document.addEventListener('touchstart', disableHover, true);\n document.addEventListener('touchmove', disableHover, true);\n document.addEventListener('mousemove', enableHover, true);\n }\n}\n\nexport function isHoverEnabled(): boolean {\n return isEnabled;\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 * @format\n * @flow strict\n */\n\nexport type Rect = $ReadOnly<{|\n bottom?: ?number,\n left?: ?number,\n right?: ?number,\n top?: ?number,\n|}>;\n\nexport type RectOrSize = Rect | number;\n\nexport function createSquare(size: number): Rect {\n return {bottom: size, left: size, right: size, top: size};\n}\n\nexport function normalizeRect(rectOrSize: ?RectOrSize): ?Rect {\n return typeof rectOrSize === 'number' ? createSquare(rectOrSize) : rectOrSize;\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 * @flow\n * @format\n */\n\nimport {createViewConfig} from '../NativeComponent/ViewConfig';\nimport UIManager from '../ReactNative/UIManager';\nimport createReactNativeComponentClass from '../Renderer/shims/createReactNativeComponentClass';\nimport {type HostComponent} from '../Renderer/shims/ReactNativeTypes';\nimport {type ProcessedColorValue} from '../StyleSheet/processColor';\nimport {type PressEvent} from '../Types/CoreEventTypes';\nimport {type TextProps} from './TextProps';\n\ntype NativeTextProps = $ReadOnly<{\n ...TextProps,\n maximumNumberOfLines?: ?number,\n isHighlighted?: ?boolean,\n selectionColor?: ?ProcessedColorValue,\n onClick?: ?(event: PressEvent) => mixed,\n // This is only needed for platforms that optimize text hit testing, e.g.,\n // react-native-windows. It can be used to only hit test virtual text spans\n // that have pressable events attached to them.\n isPressable?: ?boolean,\n}>;\n\nconst textViewConfig = {\n validAttributes: {\n isHighlighted: true,\n isPressable: true,\n maximumNumberOfLines: true,\n ellipsizeMode: true,\n allowFontScaling: true,\n dynamicTypeRamp: true,\n maxFontSizeMultiplier: true,\n disabled: true,\n selectable: true,\n selectionColor: true,\n adjustsFontSizeToFit: true,\n minimumFontScale: true,\n textBreakStrategy: true,\n onTextLayout: true,\n onInlineViewLayout: true,\n dataDetectorType: true,\n android_hyphenationFrequency: true,\n lineBreakStrategyIOS: true,\n },\n directEventTypes: {\n topTextLayout: {\n registrationName: 'onTextLayout',\n },\n topInlineViewLayout: {\n registrationName: 'onInlineViewLayout',\n },\n },\n uiViewClassName: 'RCTText',\n};\n\nconst virtualTextViewConfig = {\n validAttributes: {\n isHighlighted: true,\n isPressable: true,\n maxFontSizeMultiplier: true,\n },\n uiViewClassName: 'RCTVirtualText',\n};\n\nexport const NativeText: HostComponent =\n (createReactNativeComponentClass('RCTText', () =>\n createViewConfig(textViewConfig),\n ): any);\n\nexport const NativeVirtualText: HostComponent =\n !global.RN$Bridgeless && !UIManager.hasViewManagerConfig('RCTVirtualText')\n ? NativeText\n : (createReactNativeComponentClass('RCTVirtualText', () =>\n createViewConfig(virtualTextViewConfig),\n ): any);\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 * @format\n * @flow\n */\n\n'use strict';\n\nmodule.exports = {\n get ColorPropType() {\n return require('./DeprecatedColorPropType');\n },\n get EdgeInsetsPropType() {\n return require('./DeprecatedEdgeInsetsPropType');\n },\n get ImagePropTypes() {\n return require('./DeprecatedImagePropType');\n },\n get PointPropType() {\n return require('./DeprecatedPointPropType');\n },\n get TextInputPropTypes() {\n return require('./DeprecatedTextInputPropTypes');\n },\n get TextPropTypes() {\n return require('./DeprecatedTextPropTypes');\n },\n get ViewPropTypes() {\n return require('./DeprecatedViewPropTypes');\n },\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 * @format\n */\n\n'use strict';\n\nconst normalizeColor = require('@react-native/normalize-color');\n\n/**\n * @see facebook/react-native/Libraries/StyleSheet/StyleSheetTypes.js\n */\nconst colorPropType = function(\n isRequired,\n props,\n propName,\n componentName,\n location,\n propFullName,\n) {\n const color = props[propName];\n\n if (color == null) {\n if (isRequired) {\n return new Error(\n 'Required ' +\n location +\n ' `' +\n (propFullName || propName) +\n '` was not specified in `' +\n componentName +\n '`.',\n );\n }\n return;\n }\n\n if (typeof color === 'number') {\n // Developers should not use a number, but we are using the prop type\n // both for user provided colors and for transformed ones. This isn't ideal\n // and should be fixed but will do for now...\n return;\n }\n\n if (typeof color === 'string' && normalizeColor(color) === null) {\n return new Error(\n 'Invalid ' +\n location +\n ' `' +\n (propFullName || propName) +\n '` supplied to `' +\n componentName +\n '`: ' +\n color +\n '\\n' +\n `Valid color formats are\n - '#f0f' (#rgb)\n - '#f0fc' (#rgba)\n - '#ff00ff' (#rrggbb)\n - '#ff00ff00' (#rrggbbaa)\n - 'rgb(255, 255, 255)'\n - 'rgba(255, 255, 255, 1.0)'\n - 'hsl(360, 100%, 100%)'\n - 'hsla(360, 100%, 100%, 1.0)'\n - 'transparent'\n - 'red'\n - 0xff00ff00 (0xrrggbbaa)\n`,\n );\n }\n};\n\nconst ColorPropType = colorPropType.bind(null, false /* isRequired */);\nColorPropType.isRequired = colorPropType.bind(null, true /* isRequired */);\n\nmodule.exports = ColorPropType;\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 * @format\n */\n\n'use strict';\n\nconst PropTypes = require('prop-types');\n\n/**\n * @see facebook/react-native/Libraries/StyleSheet/Rect.js\n */\nconst DeprecatedEdgeInsetsPropType = PropTypes.shape({\n bottom: PropTypes.number,\n left: PropTypes.number,\n right: PropTypes.number,\n top: PropTypes.number,\n});\n\nmodule.exports = DeprecatedEdgeInsetsPropType;\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\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\nif (process.env.NODE_ENV !== 'production') {\n var ReactIs = require('react-is');\n\n // By explicitly using `prop-types` you are opting into new development behavior.\n // http://fb.me/prop-types-in-prod\n var throwOnDirectAccess = true;\n module.exports = require('./factoryWithTypeCheckers')(ReactIs.isElement, throwOnDirectAccess);\n} else {\n // By explicitly using `prop-types` you are opting into new production behavior.\n // http://fb.me/prop-types-in-prod\n module.exports = require('./factoryWithThrowingShims')();\n}\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\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'use strict';\n\nvar ReactPropTypesSecret = require('./lib/ReactPropTypesSecret');\n\nfunction emptyFunction() {}\nfunction emptyFunctionWithReset() {}\nemptyFunctionWithReset.resetWarningCache = emptyFunction;\n\nmodule.exports = function() {\n function shim(props, propName, componentName, location, propFullName, secret) {\n if (secret === ReactPropTypesSecret) {\n // It is still safe when called from React.\n return;\n }\n var err = new Error(\n 'Calling PropTypes validators directly is not supported by the `prop-types` package. ' +\n 'Use PropTypes.checkPropTypes() to call them. ' +\n 'Read more at http://fb.me/use-check-prop-types'\n );\n err.name = 'Invariant Violation';\n throw err;\n };\n shim.isRequired = shim;\n function getShim() {\n return shim;\n };\n // Important!\n // Keep this list in sync with production version in `./factoryWithTypeCheckers.js`.\n var ReactPropTypes = {\n array: shim,\n bigint: shim,\n bool: shim,\n func: shim,\n number: shim,\n object: shim,\n string: shim,\n symbol: shim,\n\n any: shim,\n arrayOf: getShim,\n element: shim,\n elementType: shim,\n instanceOf: getShim,\n node: shim,\n objectOf: getShim,\n oneOf: getShim,\n oneOfType: getShim,\n shape: getShim,\n exact: getShim,\n\n checkPropTypes: emptyFunctionWithReset,\n resetWarningCache: emptyFunction\n };\n\n ReactPropTypes.PropTypes = ReactPropTypes;\n\n return ReactPropTypes;\n};\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\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'use strict';\n\nvar ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED';\n\nmodule.exports = ReactPropTypesSecret;\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 * @format\n */\n\n'use strict';\n\nconst DeprecatedColorPropType = require('./DeprecatedColorPropType');\nconst DeprecatedEdgeInsetsPropType = require('./DeprecatedEdgeInsetsPropType');\nconst DeprecatedImageSourcePropType = require('./DeprecatedImageSourcePropType');\nconst DeprecatedImageStylePropTypes = require('./DeprecatedImageStylePropTypes');\nconst DeprecatedStyleSheetPropType = require('./DeprecatedStyleSheetPropType');\nconst DeprecatedViewPropTypes = require('./DeprecatedViewPropTypes');\nconst PropTypes = require('prop-types');\n\n/**\n * @see facebook/react-native/Libraries/Image/ImageProps.js\n */\nconst DeprecatedImagePropType = {\n ...DeprecatedViewPropTypes,\n alt: PropTypes.string,\n blurRadius: PropTypes.number,\n capInsets: DeprecatedEdgeInsetsPropType,\n crossOrigin: PropTypes.oneOf(['anonymous', 'use-credentials']),\n defaultSource: DeprecatedImageSourcePropType,\n fadeDuration: PropTypes.number,\n height: PropTypes.number,\n internal_analyticTag: PropTypes.string,\n loadingIndicatorSource: PropTypes.oneOfType([\n PropTypes.shape({\n uri: PropTypes.string,\n }),\n PropTypes.number,\n ]),\n onError: PropTypes.func,\n onLoad: PropTypes.func,\n onLoadEnd: PropTypes.func,\n onLoadStart: PropTypes.func,\n onPartialLoad: PropTypes.func,\n onProgress: PropTypes.func,\n progressiveRenderingEnabled: PropTypes.bool,\n referrerPolicy: PropTypes.oneOf([\n 'no-referrer',\n 'no-referrer-when-downgrade',\n 'origin',\n 'origin-when-cross-origin',\n 'same-origin',\n 'strict-origin',\n 'strict-origin-when-cross-origin',\n 'unsafe-url',\n ]),\n resizeMethod: PropTypes.oneOf(['auto', 'resize', 'scale']),\n resizeMode: PropTypes.oneOf([\n 'cover',\n 'contain',\n 'stretch',\n 'repeat',\n 'center',\n ]),\n source: DeprecatedImageSourcePropType,\n src: PropTypes.string,\n srcSet: PropTypes.string,\n style: DeprecatedStyleSheetPropType(DeprecatedImageStylePropTypes),\n testID: PropTypes.string,\n tintColor: DeprecatedColorPropType,\n width: PropTypes.number,\n};\n\nmodule.exports = DeprecatedImagePropType;\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 * @format\n */\n\n'use strict';\n\nconst DeprecatedEdgeInsetsPropType = require('./DeprecatedEdgeInsetsPropType');\nconst DeprecatedStyleSheetPropType = require('./DeprecatedStyleSheetPropType');\nconst {\n AccessibilityActionInfoPropType,\n AccessibilityRolePropType,\n AccessibilityStatePropType,\n AccessibilityValuePropType,\n RolePropType,\n} = require('./DeprecatedViewAccessibility');\nconst DeprecatedViewStylePropTypes = require('./DeprecatedViewStylePropTypes');\nconst PropTypes = require('prop-types');\n\nconst MouseEventPropTypes = {\n onMouseEnter: PropTypes.func,\n onMouseLeave: PropTypes.func,\n};\n\n// Experimental/Work in Progress Pointer Event Callbacks (not yet ready for use)\nconst PointerEventPropTypes = {\n onPointerEnter: PropTypes.func,\n onPointerEnterCapture: PropTypes.func,\n onPointerLeave: PropTypes.func,\n onPointerLeaveCapture: PropTypes.func,\n onPointerMove: PropTypes.func,\n onPointerMoveCapture: PropTypes.func,\n onPointerCancel: PropTypes.func,\n onPointerCancelCapture: PropTypes.func,\n onPointerDown: PropTypes.func,\n onPointerDownCapture: PropTypes.func,\n onPointerUp: PropTypes.func,\n onPointerUpCapture: PropTypes.func,\n onPointerOver: PropTypes.func,\n onPointerOverCapture: PropTypes.func,\n onPointerOut: PropTypes.func,\n onPointerOutCapture: PropTypes.func,\n};\n\nconst FocusEventPropTypes = {\n onBlur: PropTypes.func,\n onBlurCapture: PropTypes.func,\n onFocus: PropTypes.func,\n onFocusCapture: PropTypes.func,\n};\n\nconst TouchEventPropTypes = {\n onTouchCancel: PropTypes.func,\n onTouchCancelCapture: PropTypes.func,\n onTouchEnd: PropTypes.func,\n onTouchEndCapture: PropTypes.func,\n onTouchMove: PropTypes.func,\n onTouchMoveCapture: PropTypes.func,\n onTouchStart: PropTypes.func,\n onTouchStartCapture: PropTypes.func,\n};\n\nconst GestureResponderEventPropTypes = {\n onMoveShouldSetResponder: PropTypes.func,\n onMoveShouldSetResponderCapture: PropTypes.func,\n onResponderEnd: PropTypes.func,\n onResponderGrant: PropTypes.func,\n onResponderMove: PropTypes.func,\n onResponderReject: PropTypes.func,\n onResponderRelease: PropTypes.func,\n onResponderStart: PropTypes.func,\n onResponderTerminate: PropTypes.func,\n onResponderTerminationRequest: PropTypes.func,\n onStartShouldSetResponder: PropTypes.func,\n onStartShouldSetResponderCapture: PropTypes.func,\n};\n\n/**\n * @see facebook/react-native/Libraries/Components/View/ViewPropTypes.js\n */\nconst DeprecatedViewPropTypes = {\n ...MouseEventPropTypes,\n ...PointerEventPropTypes,\n ...FocusEventPropTypes,\n ...TouchEventPropTypes,\n ...GestureResponderEventPropTypes,\n 'aria-busy': PropTypes.bool,\n 'aria-checked': PropTypes.oneOfType([\n PropTypes.bool,\n PropTypes.oneOf(['mixed']),\n ]),\n 'aria-disabled': PropTypes.bool,\n 'aria-expanded': PropTypes.bool,\n 'aria-hidden': PropTypes.bool,\n 'aria-label': PropTypes.string,\n 'aria-labelledby': PropTypes.string,\n 'aria-live': PropTypes.oneOf(['polite' | 'assertive' | 'off']),\n 'aria-modal': PropTypes.bool,\n 'aria-selected': PropTypes.bool,\n 'aria-valuemax': PropTypes.number,\n 'aria-valuemin': PropTypes.number,\n 'aria-valuenow': PropTypes.number,\n 'aria-valuetext': PropTypes.string,\n accessibilityActions: PropTypes.arrayOf(AccessibilityActionInfoPropType),\n accessibilityElementsHidden: PropTypes.bool,\n accessibilityHint: PropTypes.string,\n accessibilityIgnoresInvertColors: PropTypes.bool,\n accessibilityLabel: PropTypes.node,\n accessibilityLabelledBy: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.arrayOf(PropTypes.string),\n ]),\n accessibilityLanguage: PropTypes.string,\n accessibilityLiveRegion: PropTypes.oneOf(['assertive', 'none', 'polite']),\n accessibilityRole: AccessibilityRolePropType,\n accessibilityState: AccessibilityStatePropType,\n accessibilityValue: AccessibilityValuePropType,\n accessibilityViewIsModal: PropTypes.bool,\n accessible: PropTypes.bool,\n collapsable: PropTypes.bool,\n focusable: PropTypes.bool,\n hitSlop: PropTypes.oneOfType([\n DeprecatedEdgeInsetsPropType,\n PropTypes.number,\n ]),\n importantForAccessibility: PropTypes.oneOf([\n 'auto',\n 'no',\n 'no-hide-descendants',\n 'yes',\n ]),\n nativeBackgroundAndroid: PropTypes.object,\n nativeForegroundAndroid: PropTypes.object,\n nativeID: PropTypes.string,\n needsOffscreenAlphaCompositing: PropTypes.bool,\n onAccessibilityAction: PropTypes.func,\n onAccessibilityEscape: PropTypes.func,\n onAccessibilityTap: PropTypes.func,\n onClick: PropTypes.func,\n onLayout: PropTypes.func,\n onMagicTap: PropTypes.func,\n pointerEvents: PropTypes.oneOf(['auto', 'box-none', 'box-only', 'none']),\n removeClippedSubviews: PropTypes.bool,\n renderToHardwareTextureAndroid: PropTypes.bool,\n role: RolePropType,\n shouldRasterizeIOS: PropTypes.bool,\n style: DeprecatedStyleSheetPropType(DeprecatedViewStylePropTypes),\n tabIndex: PropTypes.oneOf([0, -1]),\n testID: PropTypes.string,\n};\n\nmodule.exports = DeprecatedViewPropTypes;\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 * @format\n */\n\n'use strict';\n\nconst PropTypes = require('prop-types');\n\n/**\n * @see facebook/react-native/Libraries/Components/View/ViewAccessibility.js\n */\nconst DeprecatedViewAccessibility = {\n AccessibilityRolePropType: PropTypes.oneOf([\n 'adjustable',\n 'alert',\n 'button',\n 'checkbox',\n 'combobox',\n 'drawerlayout',\n 'dropdownlist',\n 'grid',\n 'header',\n 'horizontalscrollview',\n 'iconmenu',\n 'image',\n 'imagebutton',\n 'keyboardkey',\n 'link',\n 'list',\n 'menu',\n 'menubar',\n 'menuitem',\n 'none',\n 'pager',\n 'progressbar',\n 'radio',\n 'radiogroup',\n 'scrollbar',\n 'scrollview',\n 'search',\n 'slidingdrawer',\n 'spinbutton',\n 'summary',\n 'switch',\n 'tab',\n 'tabbar',\n 'tablist',\n 'text',\n 'timer',\n 'togglebutton',\n 'toolbar',\n 'viewgroup',\n 'webview',\n ]),\n AccessibilityStatePropType: PropTypes.object,\n AccessibilityActionInfoPropType: PropTypes.object,\n AccessibilityValuePropType: PropTypes.object,\n RolePropType: PropTypes.oneOf([\n 'alert',\n 'alertdialog',\n 'application',\n 'article',\n 'banner',\n 'button',\n 'cell',\n 'checkbox',\n 'columnheader',\n 'combobox',\n 'complementary',\n 'contentinfo',\n 'definition',\n 'dialog',\n 'directory',\n 'document',\n 'feed',\n 'figure',\n 'form',\n 'grid',\n 'group',\n 'heading',\n 'img',\n 'link',\n 'list',\n 'listitem',\n 'log',\n 'main',\n 'marquee',\n 'math',\n 'menu',\n 'menubar',\n 'menuitem',\n 'meter',\n 'navigation',\n 'none',\n 'note',\n 'option',\n 'presentation',\n 'progressbar',\n 'radio',\n 'radiogroup',\n 'region',\n 'row',\n 'rowgroup',\n 'rowheader',\n 'scrollbar',\n 'searchbox',\n 'separator',\n 'slider',\n 'spinbutton',\n 'status',\n 'summary',\n 'switch',\n 'tab',\n 'table',\n 'tablist',\n 'tabpanel',\n 'term',\n 'timer',\n 'toolbar',\n 'tooltip',\n 'tree',\n 'treegrid',\n 'treeitem',\n ]),\n};\n\nmodule.exports = DeprecatedViewAccessibility;\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 * @format\n */\n\n'use strict';\n\nconst deprecatedCreateStrictShapeTypeChecker = require('./deprecatedCreateStrictShapeTypeChecker');\n\nfunction DeprecatedStyleSheetPropType(shape) {\n const shapePropType = deprecatedCreateStrictShapeTypeChecker(shape);\n return function(props, propName, componentName, location, ...rest) {\n let newProps = props;\n if (props[propName]) {\n // Just make a dummy prop object with only the flattened style\n newProps = {};\n newProps[propName] = flattenStyle(props[propName]);\n }\n return shapePropType(newProps, propName, componentName, location, ...rest);\n };\n}\n\nfunction flattenStyle(style) {\n if (style === null || typeof style !== 'object') {\n return undefined;\n }\n\n if (!Array.isArray(style)) {\n return style;\n }\n\n const result = {};\n for (let i = 0, styleLength = style.length; i < styleLength; ++i) {\n const computedStyle = flattenStyle(style[i]);\n if (computedStyle) {\n for (const key in computedStyle) {\n result[key] = computedStyle[key];\n }\n }\n }\n return result;\n}\n\nmodule.exports = DeprecatedStyleSheetPropType;\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 * @format\n */\n\n'use strict';\n\nconst invariant = require('invariant');\n\nfunction deprecatedCreateStrictShapeTypeChecker(shapeTypes) {\n function checkType(\n isRequired,\n props,\n propName,\n componentName,\n location,\n ...rest\n ) {\n if (!props[propName]) {\n if (isRequired) {\n invariant(\n false,\n `Required object \\`${propName}\\` was not specified in ` +\n `\\`${componentName}\\`.`,\n );\n }\n return;\n }\n const propValue = props[propName];\n const propType = typeof propValue;\n const locationName = location || '(unknown)';\n if (propType !== 'object') {\n invariant(\n false,\n `Invalid ${locationName} \\`${propName}\\` of type \\`${propType}\\` ` +\n `supplied to \\`${componentName}\\`, expected \\`object\\`.`,\n );\n }\n // We need to check all keys in case some are required but missing from\n // props.\n const allKeys = {...props[propName], ...shapeTypes};\n for (const key in allKeys) {\n const checker = shapeTypes[key];\n if (!checker) {\n invariant(\n false,\n `Invalid props.${propName} key \\`${key}\\` supplied to \\`${componentName}\\`.` +\n '\\nBad object: ' +\n JSON.stringify(props[propName], null, ' ') +\n '\\nValid keys: ' +\n JSON.stringify(Object.keys(shapeTypes), null, ' '),\n );\n }\n const error = checker(propValue, key, componentName, location, ...rest);\n if (error) {\n invariant(\n false,\n error.message +\n '\\nBad object: ' +\n JSON.stringify(props[propName], null, ' '),\n );\n }\n }\n }\n function chainedCheckType(props, propName, componentName, location, ...rest) {\n return checkType(false, props, propName, componentName, location, ...rest);\n }\n chainedCheckType.isRequired = checkType.bind(null, true);\n return chainedCheckType;\n}\n\nmodule.exports = deprecatedCreateStrictShapeTypeChecker;\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 * @format\n */\n\n'use strict';\n\nconst DeprecatedColorPropType = require('./DeprecatedColorPropType');\nconst DeprecatedLayoutPropTypes = require('./DeprecatedLayoutPropTypes');\nconst DeprecatedShadowPropTypesIOS = require('./DeprecatedShadowPropTypesIOS');\nconst DeprecatedTransformPropTypes = require('./DeprecatedTransformPropTypes');\nconst PropTypes = require('prop-types');\n\n/**\n * @see facebook/react-native/Libraries/StyleSheet/StyleSheetTypes.js\n */\nconst DeprecatedViewStylePropTypes = {\n ...DeprecatedLayoutPropTypes,\n ...DeprecatedShadowPropTypesIOS,\n ...DeprecatedTransformPropTypes,\n backfaceVisibility: PropTypes.oneOf(['hidden', 'visible']),\n backgroundColor: DeprecatedColorPropType,\n borderBottomColor: DeprecatedColorPropType,\n borderBottomEndRadius: PropTypes.number,\n borderBottomLeftRadius: PropTypes.number,\n borderBottomRightRadius: PropTypes.number,\n borderBottomStartRadius: PropTypes.number,\n borderBottomWidth: PropTypes.number,\n borderColor: DeprecatedColorPropType,\n borderCurve: PropTypes.oneOf(['circular', 'continuous']),\n borderEndColor: DeprecatedColorPropType,\n borderLeftColor: DeprecatedColorPropType,\n borderLeftWidth: PropTypes.number,\n borderRadius: PropTypes.number,\n borderRightColor: DeprecatedColorPropType,\n borderRightWidth: PropTypes.number,\n borderStartColor: DeprecatedColorPropType,\n borderStyle: PropTypes.oneOf(['dashed', 'dotted', 'solid']),\n borderTopColor: DeprecatedColorPropType,\n borderTopEndRadius: PropTypes.number,\n borderTopLeftRadius: PropTypes.number,\n borderTopRightRadius: PropTypes.number,\n borderTopStartRadius: PropTypes.number,\n borderTopWidth: PropTypes.number,\n borderWidth: PropTypes.number,\n elevation: PropTypes.number,\n opacity: PropTypes.number,\n pointerEvents: PropTypes.oneOf(['auto', 'box-none', 'box-only', 'none']),\n};\n\nmodule.exports = DeprecatedViewStylePropTypes;\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 * @format\n */\n\n'use strict';\n\nconst PropTypes = require('prop-types');\n\nconst DimensionValuePropType = PropTypes.oneOfType([\n PropTypes.number,\n PropTypes.string,\n]);\n\n/**\n * @see facebook/react-native/Libraries/StyleSheet/StyleSheetTypes.js\n */\nconst DeprecatedLayoutPropTypes = {\n alignContent: PropTypes.oneOf([\n 'center',\n 'flex-end',\n 'flex-start',\n 'space-around',\n 'space-between',\n 'stretch',\n ]),\n alignItems: PropTypes.oneOf([\n 'baseline',\n 'center',\n 'flex-end',\n 'flex-start',\n 'stretch',\n ]),\n alignSelf: PropTypes.oneOf([\n 'auto',\n 'baseline',\n 'center',\n 'flex-end',\n 'flex-start',\n 'stretch',\n ]),\n aspectRatio: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n borderBottomWidth: PropTypes.number,\n borderEndWidth: PropTypes.number,\n borderLeftWidth: PropTypes.number,\n borderRightWidth: PropTypes.number,\n borderStartWidth: PropTypes.number,\n borderTopWidth: PropTypes.number,\n borderWidth: PropTypes.number,\n bottom: DimensionValuePropType,\n columnGap: PropTypes.number,\n direction: PropTypes.oneOf(['inherit', 'ltr', 'rtl']),\n display: PropTypes.oneOf(['flex', 'none']),\n end: DimensionValuePropType,\n flex: PropTypes.number,\n flexBasis: DimensionValuePropType,\n flexDirection: PropTypes.oneOf([\n 'column',\n 'column-reverse',\n 'row',\n 'row-reverse',\n ]),\n flexGrow: PropTypes.number,\n flexShrink: PropTypes.number,\n flexWrap: PropTypes.oneOf(['nowrap', 'wrap', 'wrap-reverse']),\n gap: PropTypes.number,\n height: DimensionValuePropType,\n justifyContent: PropTypes.oneOf([\n 'center',\n 'flex-end',\n 'flex-start',\n 'space-around',\n 'space-between',\n 'space-evenly',\n ]),\n left: DimensionValuePropType,\n margin: DimensionValuePropType,\n marginBlock: DimensionValuePropType,\n marginBlockEnd: DimensionValuePropType,\n marginBlockStart: DimensionValuePropType,\n marginBottom: DimensionValuePropType,\n marginEnd: DimensionValuePropType,\n marginHorizontal: DimensionValuePropType,\n marginInline: DimensionValuePropType,\n marginInlineEnd: DimensionValuePropType,\n marginInlineStart: DimensionValuePropType,\n marginLeft: DimensionValuePropType,\n marginRight: DimensionValuePropType,\n marginStart: DimensionValuePropType,\n marginTop: DimensionValuePropType,\n marginVertical: DimensionValuePropType,\n maxHeight: DimensionValuePropType,\n maxWidth: DimensionValuePropType,\n minHeight: DimensionValuePropType,\n minWidth: DimensionValuePropType,\n overflow: PropTypes.oneOf(['hidden', 'scroll', 'visible']),\n padding: DimensionValuePropType,\n paddingBlock: DimensionValuePropType,\n paddingBlockEnd: DimensionValuePropType,\n paddingBlockStart: DimensionValuePropType,\n paddingBottom: DimensionValuePropType,\n paddingEnd: DimensionValuePropType,\n paddingHorizontal: DimensionValuePropType,\n paddingInline: DimensionValuePropType,\n paddingInlineEnd: DimensionValuePropType,\n paddingInlineStart: DimensionValuePropType,\n paddingLeft: DimensionValuePropType,\n paddingRight: DimensionValuePropType,\n paddingStart: DimensionValuePropType,\n paddingTop: DimensionValuePropType,\n paddingVertical: DimensionValuePropType,\n position: PropTypes.oneOf(['absolute', 'relative']),\n right: DimensionValuePropType,\n rowGap: PropTypes.number,\n start: DimensionValuePropType,\n top: DimensionValuePropType,\n width: DimensionValuePropType,\n zIndex: PropTypes.number,\n};\n\nmodule.exports = DeprecatedLayoutPropTypes;\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 * @format\n */\n\n'use strict';\n\nconst DeprecatedColorPropType = require('./DeprecatedColorPropType');\nconst PropTypes = require('prop-types');\n\n/**\n * @see facebook/react-native/Libraries/StyleSheet/StyleSheetTypes.js\n */\nconst DeprecatedShadowPropTypesIOS = {\n shadowColor: DeprecatedColorPropType,\n shadowOffset: PropTypes.shape({\n height: PropTypes.number,\n width: PropTypes.number,\n }),\n shadowOpacity: PropTypes.number,\n shadowRadius: PropTypes.number,\n};\n\nmodule.exports = DeprecatedShadowPropTypesIOS;\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 * @format\n */\n\n'use strict';\n\nconst PropTypes = require('prop-types');\n\n/**\n * @see facebook/react-native/Libraries/StyleSheet/private/_TransformStyle.js\n */\nconst DeprecatedTransformPropTypes = {\n transform: PropTypes.arrayOf(\n PropTypes.oneOfType([\n PropTypes.shape({perspective: PropTypes.number}),\n PropTypes.shape({rotate: PropTypes.string}),\n PropTypes.shape({rotateX: PropTypes.string}),\n PropTypes.shape({rotateY: PropTypes.string}),\n PropTypes.shape({rotateZ: PropTypes.string}),\n PropTypes.shape({scale: PropTypes.number}),\n PropTypes.shape({scaleX: PropTypes.number}),\n PropTypes.shape({scaleY: PropTypes.number}),\n PropTypes.shape({skewX: PropTypes.string}),\n PropTypes.shape({skewY: PropTypes.string}),\n PropTypes.shape({translateX: PropTypes.number}),\n PropTypes.shape({translateY: PropTypes.number}),\n ]),\n ),\n};\n\nmodule.exports = DeprecatedTransformPropTypes;\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 * @format\n */\n\n'use strict';\n\nconst PropTypes = require('prop-types');\n\n/**\n * @see facebook/react-native/Libraries/Image/ImageSource.js\n */\nconst ImageURISourcePropType = PropTypes.shape({\n body: PropTypes.string,\n bundle: PropTypes.string,\n cache: PropTypes.oneOf([\n 'default',\n 'force-cache',\n 'only-if-cached',\n 'reload',\n ]),\n headers: PropTypes.objectOf(PropTypes.string),\n height: PropTypes.number,\n method: PropTypes.string,\n scale: PropTypes.number,\n uri: PropTypes.string,\n width: PropTypes.number,\n});\n\nconst ImageSourcePropType = PropTypes.oneOfType([\n ImageURISourcePropType,\n PropTypes.number,\n PropTypes.arrayOf(ImageURISourcePropType),\n]);\n\nmodule.exports = ImageSourcePropType;\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 * @format\n */\n\n'use strict';\n\nconst DeprecatedColorPropType = require('./DeprecatedColorPropType');\nconst DeprecatedLayoutPropTypes = require('./DeprecatedLayoutPropTypes');\nconst DeprecatedShadowPropTypesIOS = require('./DeprecatedShadowPropTypesIOS');\nconst DeprecatedTransformPropTypes = require('./DeprecatedTransformPropTypes');\nconst PropTypes = require('prop-types');\n\n/**\n * @see facebook/react-native/Libraries/StyleSheet/StyleSheetTypes.js\n */\nconst DeprecatedImageStylePropTypes = {\n ...DeprecatedLayoutPropTypes,\n ...DeprecatedShadowPropTypesIOS,\n ...DeprecatedTransformPropTypes,\n backfaceVisibility: PropTypes.oneOf(['hidden', 'visible']),\n backgroundColor: DeprecatedColorPropType,\n borderBottomLeftRadius: PropTypes.number,\n borderBottomRightRadius: PropTypes.number,\n borderColor: DeprecatedColorPropType,\n borderRadius: PropTypes.number,\n borderTopLeftRadius: PropTypes.number,\n borderTopRightRadius: PropTypes.number,\n borderWidth: PropTypes.number,\n objectFit: PropTypes.oneOf(['contain', 'cover', 'fill', 'scale-down']),\n opacity: PropTypes.number,\n overflow: PropTypes.oneOf(['hidden', 'visible']),\n overlayColor: PropTypes.string,\n tintColor: DeprecatedColorPropType,\n resizeMode: PropTypes.oneOf([\n 'center',\n 'contain',\n 'cover',\n 'repeat',\n 'stretch',\n ]),\n};\n\nmodule.exports = DeprecatedImageStylePropTypes;\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 * @format\n */\n\n'use strict';\n\nconst PropTypes = require('prop-types');\n\n/**\n * @see facebook/react-native/Libraries/StyleSheet/StyleSheetTypes.js\n */\nconst PointPropType = PropTypes.shape({\n x: PropTypes.number,\n y: PropTypes.number,\n});\n\nmodule.exports = PointPropType;\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 * @format\n */\n\n'use strict';\n\nconst DeprecatedColorPropType = require('./DeprecatedColorPropType');\nconst DeprecatedTextPropTypes = require('./DeprecatedTextPropTypes');\nconst DeprecatedViewPropTypes = require('./DeprecatedViewPropTypes');\nconst PropTypes = require('prop-types');\n\nconst DataDetectorTypes = [\n 'address',\n 'all',\n 'calendarEvent',\n 'link',\n 'none',\n 'phoneNumber',\n];\n\n/**\n * @see facebook/react-native/Libraries/TextInput/TextInput.js\n */\nconst DeprecatedTextInputPropTypes = {\n ...DeprecatedViewPropTypes,\n allowFontScaling: PropTypes.bool,\n autoCapitalize: PropTypes.oneOf(['none', 'sentences', 'words', 'characters']),\n autoComplete: PropTypes.oneOf([\n 'additional-name',\n 'address-line1',\n 'address-line2',\n 'bday',\n 'bday-day',\n 'bday-month',\n 'bday-year',\n 'birthdate-day',\n 'birthdate-full',\n 'birthdate-month',\n 'birthdate-year',\n 'cc-csc',\n 'cc-exp',\n 'cc-exp-day',\n 'cc-exp-month',\n 'cc-exp-year',\n 'cc-number',\n 'country',\n 'current-password',\n 'email',\n 'family-name',\n 'gender',\n 'given-name',\n 'honorific-prefix',\n 'honorific-suffix',\n 'name',\n 'name-family',\n 'name-given',\n 'name-middle',\n 'name-middle-initial',\n 'name-prefix',\n 'name-suffix',\n 'new-password',\n 'nickname',\n 'off',\n 'one-time-code',\n 'organization',\n 'organization-title',\n 'password',\n 'password-new',\n 'postal-address',\n 'postal-address-country',\n 'postal-address-extended',\n 'postal-address-extended-postal-code',\n 'postal-address-locality',\n 'postal-address-region',\n 'postal-code',\n 'sex',\n 'sms-otp',\n 'street-address',\n 'tel',\n 'tel-country-code',\n 'tel-device',\n 'tel-national',\n 'url',\n 'username',\n 'username-new',\n ]),\n autoCorrect: PropTypes.bool,\n autoFocus: PropTypes.bool,\n blurOnSubmit: PropTypes.bool,\n caretHidden: PropTypes.bool,\n clearButtonMode: PropTypes.oneOf([\n 'always',\n 'never',\n 'unless-editing',\n 'while-editing',\n ]),\n clearTextOnFocus: PropTypes.bool,\n cursorColor: DeprecatedColorPropType,\n contextMenuHidden: PropTypes.bool,\n dataDetectorTypes: PropTypes.oneOfType([\n PropTypes.oneOf(DataDetectorTypes),\n PropTypes.arrayOf(PropTypes.oneOf(DataDetectorTypes)),\n ]),\n defaultValue: PropTypes.string,\n disableFullscreenUI: PropTypes.bool,\n editable: PropTypes.bool,\n enablesReturnKeyAutomatically: PropTypes.bool,\n enterKeyHint: PropTypes.oneOf([\n 'done',\n 'enter',\n 'go',\n 'next',\n 'previous',\n 'search',\n 'send',\n ]),\n inlineImageLeft: PropTypes.string,\n inlineImagePadding: PropTypes.number,\n inputAccessoryViewID: PropTypes.string,\n inputMode: PropTypes.oneOf([\n 'decimal',\n 'email',\n 'none',\n 'numeric',\n 'search',\n 'tel',\n 'text',\n 'url',\n ]),\n keyboardAppearance: PropTypes.oneOf(['default', 'dark', 'light']),\n keyboardType: PropTypes.oneOf([\n 'ascii-capable',\n 'ascii-capable-number-pad',\n 'decimal-pad',\n 'default',\n 'email-address',\n 'name-phone-pad',\n 'number-pad',\n 'numbers-and-punctuation',\n 'numeric',\n 'phone-pad',\n 'twitter',\n 'url',\n 'visible-password',\n 'web-search',\n ]),\n lineBreakStrategyIOS: PropTypes.oneOf([\n 'hangul-word',\n 'none',\n 'push-out',\n 'standard',\n ]),\n maxFontSizeMultiplier: PropTypes.number,\n maxLength: PropTypes.number,\n multiline: PropTypes.bool,\n numberOfLines: PropTypes.number,\n onBlur: PropTypes.func,\n onChange: PropTypes.func,\n onChangeText: PropTypes.func,\n onContentSizeChange: PropTypes.func,\n onEndEditing: PropTypes.func,\n onFocus: PropTypes.func,\n onKeyPress: PropTypes.func,\n onLayout: PropTypes.func,\n onScroll: PropTypes.func,\n onSelectionChange: PropTypes.func,\n onSubmitEditing: PropTypes.func,\n onTextInput: PropTypes.func,\n placeholder: PropTypes.string,\n placeholderTextColor: DeprecatedColorPropType,\n readOnly: PropTypes.bool,\n rejectResponderTermination: PropTypes.bool,\n returnKeyLabel: PropTypes.string,\n returnKeyType: PropTypes.oneOf([\n 'default',\n 'done',\n 'emergency-call',\n 'go',\n 'google',\n 'join',\n 'next',\n 'none',\n 'previous',\n 'route',\n 'search',\n 'send',\n 'yahoo',\n ]),\n rows: PropTypes.number,\n scrollEnabled: PropTypes.bool,\n secureTextEntry: PropTypes.bool,\n selection: PropTypes.shape({\n end: PropTypes.number,\n start: PropTypes.number.isRequired,\n }),\n selectionColor: DeprecatedColorPropType,\n selectTextOnFocus: PropTypes.bool,\n showSoftInputOnFocus: PropTypes.bool,\n spellCheck: PropTypes.bool,\n style: DeprecatedTextPropTypes.style,\n submitBehavior: PropTypes.oneOf(['blurAndSubmit', 'newline', 'submit']),\n textBreakStrategy: PropTypes.oneOf(['balanced', 'highQuality', 'simple']),\n textContentType: PropTypes.oneOf([\n 'addressCity',\n 'addressCityAndState',\n 'addressState',\n 'countryName',\n 'creditCardNumber',\n 'emailAddress',\n 'familyName',\n 'fullStreetAddress',\n 'givenName',\n 'jobTitle',\n 'location',\n 'middleName',\n 'name',\n 'namePrefix',\n 'nameSuffix',\n 'newPassword',\n 'nickname',\n 'none',\n 'oneTimeCode',\n 'organizationName',\n 'password',\n 'postalCode',\n 'streetAddressLine1',\n 'streetAddressLine2',\n 'sublocality',\n 'telephoneNumber',\n 'URL',\n 'username',\n ]),\n underlineColorAndroid: DeprecatedColorPropType,\n value: PropTypes.string,\n};\n\nmodule.exports = DeprecatedTextInputPropTypes;\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 * @format\n */\n\n'use strict';\n\nconst DeprecatedColorPropType = require('./DeprecatedColorPropType');\nconst DeprecatedEdgeInsetsPropType = require('./DeprecatedEdgeInsetsPropType');\nconst DeprecatedStyleSheetPropType = require('./DeprecatedStyleSheetPropType');\nconst DeprecatedTextStylePropTypes = require('./DeprecatedTextStylePropTypes');\nconst {\n AccessibilityActionInfoPropType,\n AccessibilityRolePropType,\n AccessibilityStatePropType,\n AccessibilityValuePropType,\n RolePropType,\n} = require('./DeprecatedViewAccessibility');\nconst PropTypes = require('prop-types');\n\n/**\n * @see facebook/react-native/Libraries/Text/TextProps.js\n */\nconst DeprecatedTextPropTypes = {\n 'aria-busy': PropTypes.bool,\n 'aria-checked': PropTypes.oneOfType([\n PropTypes.bool,\n PropTypes.oneOf(['mixed']),\n ]),\n 'aria-disabled': PropTypes.bool,\n 'aria-expanded': PropTypes.bool,\n 'aria-label': PropTypes.string,\n 'aria-labelledby': PropTypes.string,\n 'aria-selected': PropTypes.bool,\n accessibilityActions: PropTypes.arrayOf(AccessibilityActionInfoPropType),\n accessibilityHint: PropTypes.string,\n accessibilityLabel: PropTypes.string,\n accessibilityLanguage: PropTypes.string,\n accessibilityRole: AccessibilityRolePropType,\n accessibilityState: AccessibilityStatePropType,\n accessible: PropTypes.bool,\n adjustsFontSizeToFit: PropTypes.bool,\n allowFontScaling: PropTypes.bool,\n dataDetectorType: PropTypes.oneOf([\n 'all',\n 'email',\n 'link',\n 'none',\n 'phoneNumber',\n ]),\n disabled: PropTypes.bool,\n dynamicTypeRamp: PropTypes.oneOf([\n 'body',\n 'callout',\n 'caption1',\n 'caption2',\n 'footnote',\n 'headline',\n 'largeTitle',\n 'subheadline',\n 'title1',\n 'title2',\n 'title3',\n ]),\n ellipsizeMode: PropTypes.oneOf(['clip', 'head', 'middle', 'tail']),\n id: PropTypes.string,\n lineBreakStrategyIOS: PropTypes.oneOf([\n 'hangul-word',\n 'none',\n 'push-out',\n 'standard',\n ]),\n maxFontSizeMultiplier: PropTypes.number,\n minimumFontScale: PropTypes.number,\n nativeID: PropTypes.string,\n numberOfLines: PropTypes.number,\n onAccessibilityAction: PropTypes.func,\n onLayout: PropTypes.func,\n onLongPress: PropTypes.func,\n onMoveShouldSetResponder: PropTypes.func,\n onPress: PropTypes.func,\n onPressIn: PropTypes.func,\n onPressOut: PropTypes.func,\n onResponderGrant: PropTypes.func,\n onResponderMove: PropTypes.func,\n onResponderRelease: PropTypes.func,\n onResponderTerminate: PropTypes.func,\n onResponderTerminationRequest: PropTypes.func,\n onStartShouldSetResponder: PropTypes.func,\n onTextLayout: PropTypes.func,\n pressRetentionOffset: DeprecatedEdgeInsetsPropType,\n role: RolePropType,\n selectable: PropTypes.bool,\n selectionColor: DeprecatedColorPropType,\n style: DeprecatedStyleSheetPropType(DeprecatedTextStylePropTypes),\n suppressHighlighting: PropTypes.bool,\n testID: PropTypes.string,\n textBreakStrategy: PropTypes.oneOf(['balanced', 'highQuality', 'simple']),\n};\n\nmodule.exports = DeprecatedTextPropTypes;\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 * @format\n */\n\n'use strict';\n\nconst DeprecatedColorPropType = require('./DeprecatedColorPropType');\nconst DeprecatedViewStylePropTypes = require('./DeprecatedViewStylePropTypes');\nconst PropTypes = require('prop-types');\n\n/**\n * @see facebook/react-native/Libraries/StyleSheet/StyleSheetTypes.js\n */\nconst DeprecatedTextStylePropTypes = {\n ...DeprecatedViewStylePropTypes,\n color: DeprecatedColorPropType,\n fontFamily: PropTypes.string,\n fontSize: PropTypes.number,\n fontStyle: PropTypes.oneOf(['italic', 'normal']),\n fontVariant: PropTypes.oneOfType([\n PropTypes.arrayOf(\n PropTypes.oneOf([\n 'lining-nums',\n 'oldstyle-nums',\n 'proportional-nums',\n 'small-caps',\n 'stylistic-eight',\n 'stylistic-eighteen',\n 'stylistic-eleven',\n 'stylistic-fifteen',\n 'stylistic-five',\n 'stylistic-four',\n 'stylistic-fourteen',\n 'stylistic-nine',\n 'stylistic-nineteen',\n 'stylistic-one',\n 'stylistic-seven',\n 'stylistic-seventeen',\n 'stylistic-six',\n 'stylistic-sixteen',\n 'stylistic-ten',\n 'stylistic-thirteen',\n 'stylistic-three',\n 'stylistic-twelve',\n 'stylistic-twenty',\n 'stylistic-two',\n 'tabular-nums',\n ]),\n ),\n PropTypes.string,\n ]),\n fontWeight: PropTypes.oneOf([\n '100',\n '200',\n '300',\n '400',\n '500',\n '600',\n '700',\n '800',\n '900',\n 'black',\n 'bold',\n 'condensed',\n 'condensedBold',\n 'heavy',\n 'light',\n 'medium',\n 'normal',\n 'regular',\n 'semibold',\n 'thin',\n 'ultralight',\n 100,\n 200,\n 300,\n 400,\n 500,\n 600,\n 700,\n 800,\n 900,\n ]),\n includeFontPadding: PropTypes.bool,\n letterSpacing: PropTypes.number,\n lineHeight: PropTypes.number,\n textAlign: PropTypes.oneOf(['auto', 'center', 'justify', 'left', 'right']),\n textAlignVertical: PropTypes.oneOf(['auto', 'bottom', 'center', 'top']),\n textDecorationColor: DeprecatedColorPropType,\n textDecorationLine: PropTypes.oneOf([\n 'line-through',\n 'none',\n 'underline line-through',\n 'underline',\n ]),\n textDecorationStyle: PropTypes.oneOf(['dashed', 'dotted', 'double', 'solid']),\n textShadowColor: DeprecatedColorPropType,\n textShadowOffset: PropTypes.shape({\n height: PropTypes.number,\n width: PropTypes.number,\n }),\n textShadowRadius: PropTypes.number,\n textTransform: PropTypes.oneOf([\n 'capitalize',\n 'lowercase',\n 'none',\n 'uppercase',\n ]),\n userSelect: PropTypes.oneOf(['all', 'auto', 'contain', 'none', 'text']),\n verticalAlign: PropTypes.oneOf(['auto', 'bottom', 'middle', 'top']),\n writingDirection: PropTypes.oneOf(['auto', 'ltr', 'rtl']),\n};\n\nmodule.exports = DeprecatedTextStylePropTypes;\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 * @flow strict-local\n * @format\n */\n\nimport type {PressEvent} from '../../Types/CoreEventTypes';\nimport typeof TouchableWithoutFeedback from './TouchableWithoutFeedback';\n\nimport View from '../../Components/View/View';\nimport Pressability, {\n type PressabilityConfig,\n} from '../../Pressability/Pressability';\nimport {PressabilityDebugView} from '../../Pressability/PressabilityDebug';\nimport {findHostInstance_DEPRECATED} from '../../ReactNative/RendererProxy';\nimport processColor from '../../StyleSheet/processColor';\nimport Platform from '../../Utilities/Platform';\nimport {Commands} from '../View/ViewNativeComponent';\nimport invariant from 'invariant';\nimport * as React from 'react';\n\ntype Props = $ReadOnly<{|\n ...React.ElementConfig,\n\n /**\n * Determines the type of background drawable that's going to be used to\n * display feedback. It takes an object with `type` property and extra data\n * depending on the `type`. It's recommended to use one of the static\n * methods to generate that dictionary.\n */\n background?: ?(\n | $ReadOnly<{|\n type: 'ThemeAttrAndroid',\n attribute:\n | 'selectableItemBackground'\n | 'selectableItemBackgroundBorderless',\n rippleRadius: ?number,\n |}>\n | $ReadOnly<{|\n type: 'RippleAndroid',\n color: ?number,\n borderless: boolean,\n rippleRadius: ?number,\n |}>\n ),\n\n /**\n * TV preferred focus (see documentation for the View component).\n */\n hasTVPreferredFocus?: ?boolean,\n\n /**\n * TV next focus down (see documentation for the View component).\n */\n nextFocusDown?: ?number,\n\n /**\n * TV next focus forward (see documentation for the View component).\n */\n nextFocusForward?: ?number,\n\n /**\n * TV next focus left (see documentation for the View component).\n */\n nextFocusLeft?: ?number,\n\n /**\n * TV next focus right (see documentation for the View component).\n */\n nextFocusRight?: ?number,\n\n /**\n * TV next focus up (see documentation for the View component).\n */\n nextFocusUp?: ?number,\n\n /**\n * Set to true to add the ripple effect to the foreground of the view, instead\n * of the background. This is useful if one of your child views has a\n * background of its own, or you're e.g. displaying images, and you don't want\n * the ripple to be covered by them.\n *\n * Check TouchableNativeFeedback.canUseNativeForeground() first, as this is\n * only available on Android 6.0 and above. If you try to use this on older\n * versions, this will fallback to background.\n */\n useForeground?: ?boolean,\n|}>;\n\ntype State = $ReadOnly<{|\n pressability: Pressability,\n|}>;\n\nclass TouchableNativeFeedback extends React.Component {\n /**\n * Creates a value for the `background` prop that uses the Android theme's\n * default background for selectable elements.\n */\n static SelectableBackground: (rippleRadius: ?number) => $ReadOnly<{|\n attribute: 'selectableItemBackground',\n type: 'ThemeAttrAndroid',\n rippleRadius: ?number,\n |}> = (rippleRadius: ?number) => ({\n type: 'ThemeAttrAndroid',\n attribute: 'selectableItemBackground',\n rippleRadius,\n });\n\n /**\n * Creates a value for the `background` prop that uses the Android theme's\n * default background for borderless selectable elements. Requires API 21+.\n */\n static SelectableBackgroundBorderless: (rippleRadius: ?number) => $ReadOnly<{|\n attribute: 'selectableItemBackgroundBorderless',\n type: 'ThemeAttrAndroid',\n rippleRadius: ?number,\n |}> = (rippleRadius: ?number) => ({\n type: 'ThemeAttrAndroid',\n attribute: 'selectableItemBackgroundBorderless',\n rippleRadius,\n });\n\n /**\n * Creates a value for the `background` prop that uses the Android ripple with\n * the supplied color. If `borderless` is true, the ripple will render outside\n * of the view bounds. Requires API 21+.\n */\n static Ripple: (\n color: string,\n borderless: boolean,\n rippleRadius: ?number,\n ) => $ReadOnly<{|\n borderless: boolean,\n color: ?number,\n rippleRadius: ?number,\n type: 'RippleAndroid',\n |}> = (color: string, borderless: boolean, rippleRadius: ?number) => {\n const processedColor = processColor(color);\n invariant(\n processedColor == null || typeof processedColor === 'number',\n 'Unexpected color given for Ripple color',\n );\n return {\n type: 'RippleAndroid',\n color: processedColor,\n borderless,\n rippleRadius,\n };\n };\n\n /**\n * Whether `useForeground` is supported.\n */\n static canUseNativeForeground: () => boolean = () =>\n Platform.OS === 'android' && Platform.Version >= 23;\n\n state: State = {\n pressability: new Pressability(this._createPressabilityConfig()),\n };\n\n _createPressabilityConfig(): PressabilityConfig {\n const accessibilityStateDisabled =\n this.props['aria-disabled'] ?? this.props.accessibilityState?.disabled;\n return {\n cancelable: !this.props.rejectResponderTermination,\n disabled:\n this.props.disabled != null\n ? this.props.disabled\n : accessibilityStateDisabled,\n hitSlop: this.props.hitSlop,\n delayLongPress: this.props.delayLongPress,\n delayPressIn: this.props.delayPressIn,\n delayPressOut: this.props.delayPressOut,\n minPressDuration: 0,\n pressRectOffset: this.props.pressRetentionOffset,\n android_disableSound: this.props.touchSoundDisabled,\n onLongPress: this.props.onLongPress,\n onPress: this.props.onPress,\n onPressIn: event => {\n if (Platform.OS === 'android') {\n this._dispatchHotspotUpdate(event);\n this._dispatchPressedStateChange(true);\n }\n if (this.props.onPressIn != null) {\n this.props.onPressIn(event);\n }\n },\n onPressMove: event => {\n if (Platform.OS === 'android') {\n this._dispatchHotspotUpdate(event);\n }\n },\n onPressOut: event => {\n if (Platform.OS === 'android') {\n this._dispatchPressedStateChange(false);\n }\n if (this.props.onPressOut != null) {\n this.props.onPressOut(event);\n }\n },\n };\n }\n\n _dispatchPressedStateChange(pressed: boolean): void {\n if (Platform.OS === 'android') {\n const hostComponentRef = findHostInstance_DEPRECATED(this);\n if (hostComponentRef == null) {\n console.warn(\n 'Touchable: Unable to find HostComponent instance. ' +\n 'Has your Touchable component been unmounted?',\n );\n } else {\n Commands.setPressed(hostComponentRef, pressed);\n }\n }\n }\n\n _dispatchHotspotUpdate(event: PressEvent): void {\n if (Platform.OS === 'android') {\n const {locationX, locationY} = event.nativeEvent;\n const hostComponentRef = findHostInstance_DEPRECATED(this);\n if (hostComponentRef == null) {\n console.warn(\n 'Touchable: Unable to find HostComponent instance. ' +\n 'Has your Touchable component been unmounted?',\n );\n } else {\n Commands.hotspotUpdate(\n hostComponentRef,\n locationX ?? 0,\n locationY ?? 0,\n );\n }\n }\n }\n\n render(): React.Node {\n const element = React.Children.only(this.props.children);\n const children = [element.props.children];\n if (__DEV__) {\n if (element.type === View) {\n children.push(\n ,\n );\n }\n }\n\n // BACKWARD-COMPATIBILITY: Focus and blur events were never supported before\n // adopting `Pressability`, so preserve that behavior.\n const {onBlur, onFocus, ...eventHandlersWithoutBlurAndFocus} =\n this.state.pressability.getEventHandlers();\n\n let _accessibilityState = {\n busy: this.props['aria-busy'] ?? this.props.accessibilityState?.busy,\n checked:\n this.props['aria-checked'] ?? this.props.accessibilityState?.checked,\n disabled:\n this.props['aria-disabled'] ?? this.props.accessibilityState?.disabled,\n expanded:\n this.props['aria-expanded'] ?? this.props.accessibilityState?.expanded,\n selected:\n this.props['aria-selected'] ?? this.props.accessibilityState?.selected,\n };\n\n _accessibilityState =\n this.props.disabled != null\n ? {\n ..._accessibilityState,\n disabled: this.props.disabled,\n }\n : _accessibilityState;\n\n const accessibilityValue = {\n max: this.props['aria-valuemax'] ?? this.props.accessibilityValue?.max,\n min: this.props['aria-valuemin'] ?? this.props.accessibilityValue?.min,\n now: this.props['aria-valuenow'] ?? this.props.accessibilityValue?.now,\n text: this.props['aria-valuetext'] ?? this.props.accessibilityValue?.text,\n };\n\n const accessibilityLiveRegion =\n this.props['aria-live'] === 'off'\n ? 'none'\n : this.props['aria-live'] ?? this.props.accessibilityLiveRegion;\n\n const accessibilityLabel =\n this.props['aria-label'] ?? this.props.accessibilityLabel;\n return React.cloneElement(\n element,\n {\n ...eventHandlersWithoutBlurAndFocus,\n ...getBackgroundProp(\n this.props.background === undefined\n ? TouchableNativeFeedback.SelectableBackground()\n : this.props.background,\n this.props.useForeground === true,\n ),\n accessible: this.props.accessible !== false,\n accessibilityHint: this.props.accessibilityHint,\n accessibilityLanguage: this.props.accessibilityLanguage,\n accessibilityLabel: accessibilityLabel,\n accessibilityRole: this.props.accessibilityRole,\n accessibilityState: _accessibilityState,\n accessibilityActions: this.props.accessibilityActions,\n onAccessibilityAction: this.props.onAccessibilityAction,\n accessibilityValue: accessibilityValue,\n importantForAccessibility:\n this.props['aria-hidden'] === true\n ? 'no-hide-descendants'\n : this.props.importantForAccessibility,\n accessibilityViewIsModal:\n this.props['aria-modal'] ?? this.props.accessibilityViewIsModal,\n accessibilityLiveRegion: accessibilityLiveRegion,\n accessibilityElementsHidden:\n this.props['aria-hidden'] ?? this.props.accessibilityElementsHidden,\n hasTVPreferredFocus: this.props.hasTVPreferredFocus,\n hitSlop: this.props.hitSlop,\n focusable:\n this.props.focusable !== false &&\n this.props.onPress !== undefined &&\n !this.props.disabled,\n nativeID: this.props.nativeID,\n nextFocusDown: this.props.nextFocusDown,\n nextFocusForward: this.props.nextFocusForward,\n nextFocusLeft: this.props.nextFocusLeft,\n nextFocusRight: this.props.nextFocusRight,\n nextFocusUp: this.props.nextFocusUp,\n onLayout: this.props.onLayout,\n testID: this.props.testID,\n },\n ...children,\n );\n }\n\n componentDidUpdate(prevProps: Props, prevState: State) {\n this.state.pressability.configure(this._createPressabilityConfig());\n }\n\n componentWillUnmount(): void {\n this.state.pressability.reset();\n }\n}\n\nconst getBackgroundProp =\n Platform.OS === 'android'\n ? /* $FlowFixMe[missing-local-annot] The type annotation(s) required by\n * Flow's LTI update could not be added via codemod */\n (background, useForeground: boolean) =>\n useForeground && TouchableNativeFeedback.canUseNativeForeground()\n ? {nativeForegroundAndroid: background}\n : {nativeBackgroundAndroid: background}\n : /* $FlowFixMe[missing-local-annot] The type annotation(s) required by\n * Flow's LTI update could not be added via codemod */\n (background, useForeground: boolean) => null;\n\nTouchableNativeFeedback.displayName = 'TouchableNativeFeedback';\n\nmodule.exports = TouchableNativeFeedback;\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 * @flow strict-local\n * @format\n */\n\nimport type {ViewStyleProp} from '../../StyleSheet/StyleSheet';\nimport typeof TouchableWithoutFeedback from './TouchableWithoutFeedback';\n\nimport Animated from '../../Animated/Animated';\nimport Easing from '../../Animated/Easing';\nimport Pressability, {\n type PressabilityConfig,\n} from '../../Pressability/Pressability';\nimport {PressabilityDebugView} from '../../Pressability/PressabilityDebug';\nimport flattenStyle from '../../StyleSheet/flattenStyle';\nimport Platform from '../../Utilities/Platform';\nimport * as React from 'react';\n\ntype TVProps = $ReadOnly<{|\n hasTVPreferredFocus?: ?boolean,\n nextFocusDown?: ?number,\n nextFocusForward?: ?number,\n nextFocusLeft?: ?number,\n nextFocusRight?: ?number,\n nextFocusUp?: ?number,\n|}>;\n\ntype Props = $ReadOnly<{|\n ...React.ElementConfig,\n ...TVProps,\n\n activeOpacity?: ?number,\n style?: ?ViewStyleProp,\n\n hostRef?: ?React.Ref,\n|}>;\n\ntype State = $ReadOnly<{|\n anim: Animated.Value,\n pressability: Pressability,\n|}>;\n\n/**\n * A wrapper for making views respond properly to touches.\n * On press down, the opacity of the wrapped view is decreased, dimming it.\n *\n * Opacity is controlled by wrapping the children in an Animated.View, which is\n * added to the view hierarchy. Be aware that this can affect layout.\n *\n * Example:\n *\n * ```\n * renderButton: function() {\n * return (\n * \n * \n * \n * );\n * },\n * ```\n * ### Example\n *\n * ```ReactNativeWebPlayer\n * import React, { Component } from 'react'\n * import {\n * AppRegistry,\n * StyleSheet,\n * TouchableOpacity,\n * Text,\n * View,\n * } from 'react-native'\n *\n * class App extends Component {\n * state = { count: 0 }\n *\n * onPress = () => {\n * this.setState(state => ({\n * count: state.count + 1\n * }));\n * };\n *\n * render() {\n * return (\n * \n * \n * Touch Here \n * \n * \n * \n * { this.state.count !== 0 ? this.state.count: null}\n * \n * \n * \n * )\n * }\n * }\n *\n * const styles = StyleSheet.create({\n * container: {\n * flex: 1,\n * justifyContent: 'center',\n * paddingHorizontal: 10\n * },\n * button: {\n * alignItems: 'center',\n * backgroundColor: '#DDDDDD',\n * padding: 10\n * },\n * countContainer: {\n * alignItems: 'center',\n * padding: 10\n * },\n * countText: {\n * color: '#FF00FF'\n * }\n * })\n *\n * AppRegistry.registerComponent('App', () => App)\n * ```\n *\n */\nclass TouchableOpacity extends React.Component {\n state: State = {\n anim: new Animated.Value(this._getChildStyleOpacityWithDefault()),\n pressability: new Pressability(this._createPressabilityConfig()),\n };\n\n _createPressabilityConfig(): PressabilityConfig {\n return {\n cancelable: !this.props.rejectResponderTermination,\n disabled:\n this.props.disabled ??\n this.props['aria-disabled'] ??\n this.props.accessibilityState?.disabled,\n hitSlop: this.props.hitSlop,\n delayLongPress: this.props.delayLongPress,\n delayPressIn: this.props.delayPressIn,\n delayPressOut: this.props.delayPressOut,\n minPressDuration: 0,\n pressRectOffset: this.props.pressRetentionOffset,\n onBlur: event => {\n if (Platform.isTV) {\n this._opacityInactive(250);\n }\n if (this.props.onBlur != null) {\n this.props.onBlur(event);\n }\n },\n onFocus: event => {\n if (Platform.isTV) {\n this._opacityActive(150);\n }\n if (this.props.onFocus != null) {\n this.props.onFocus(event);\n }\n },\n onLongPress: this.props.onLongPress,\n onPress: this.props.onPress,\n onPressIn: event => {\n this._opacityActive(\n event.dispatchConfig.registrationName === 'onResponderGrant'\n ? 0\n : 150,\n );\n if (this.props.onPressIn != null) {\n this.props.onPressIn(event);\n }\n },\n onPressOut: event => {\n this._opacityInactive(250);\n if (this.props.onPressOut != null) {\n this.props.onPressOut(event);\n }\n },\n };\n }\n\n /**\n * Animate the touchable to a new opacity.\n */\n _setOpacityTo(toValue: number, duration: number): void {\n Animated.timing(this.state.anim, {\n toValue,\n duration,\n easing: Easing.inOut(Easing.quad),\n useNativeDriver: true,\n }).start();\n }\n\n _opacityActive(duration: number): void {\n this._setOpacityTo(this.props.activeOpacity ?? 0.2, duration);\n }\n\n _opacityInactive(duration: number): void {\n this._setOpacityTo(this._getChildStyleOpacityWithDefault(), duration);\n }\n\n _getChildStyleOpacityWithDefault(): number {\n const opacity = flattenStyle(this.props.style)?.opacity;\n return typeof opacity === 'number' ? opacity : 1;\n }\n\n render(): React.Node {\n // BACKWARD-COMPATIBILITY: Focus and blur events were never supported before\n // adopting `Pressability`, so preserve that behavior.\n const {onBlur, onFocus, ...eventHandlersWithoutBlurAndFocus} =\n this.state.pressability.getEventHandlers();\n\n let _accessibilityState = {\n busy: this.props['aria-busy'] ?? this.props.accessibilityState?.busy,\n checked:\n this.props['aria-checked'] ?? this.props.accessibilityState?.checked,\n disabled:\n this.props['aria-disabled'] ?? this.props.accessibilityState?.disabled,\n expanded:\n this.props['aria-expanded'] ?? this.props.accessibilityState?.expanded,\n selected:\n this.props['aria-selected'] ?? this.props.accessibilityState?.selected,\n };\n\n _accessibilityState =\n this.props.disabled != null\n ? {\n ..._accessibilityState,\n disabled: this.props.disabled,\n }\n : _accessibilityState;\n\n const accessibilityValue = {\n max: this.props['aria-valuemax'] ?? this.props.accessibilityValue?.max,\n min: this.props['aria-valuemin'] ?? this.props.accessibilityValue?.min,\n now: this.props['aria-valuenow'] ?? this.props.accessibilityValue?.now,\n text: this.props['aria-valuetext'] ?? this.props.accessibilityValue?.text,\n };\n\n const accessibilityLiveRegion =\n this.props['aria-live'] === 'off'\n ? 'none'\n : this.props['aria-live'] ?? this.props.accessibilityLiveRegion;\n\n const accessibilityLabel =\n this.props['aria-label'] ?? this.props.accessibilityLabel;\n return (\n \n {this.props.children}\n {__DEV__ ? (\n \n ) : null}\n \n );\n }\n\n componentDidUpdate(prevProps: Props, prevState: State) {\n this.state.pressability.configure(this._createPressabilityConfig());\n if (\n this.props.disabled !== prevProps.disabled ||\n (flattenStyle(prevProps.style)?.opacity !==\n flattenStyle(this.props.style)?.opacity) !==\n undefined\n ) {\n this._opacityInactive(250);\n }\n }\n\n componentWillUnmount(): void {\n this.state.pressability.reset();\n }\n}\n\nconst Touchable = (React.forwardRef((props, ref) => (\n \n)): React.AbstractComponent>);\n\nTouchable.displayName = 'TouchableOpacity';\n\nmodule.exports = Touchable;\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 * @flow\n * @format\n */\n\nexport type {CompositeAnimation, Numeric} from './AnimatedImplementation';\n\nimport typeof AnimatedFlatList from './components/AnimatedFlatList';\nimport typeof AnimatedImage from './components/AnimatedImage';\nimport typeof AnimatedScrollView from './components/AnimatedScrollView';\nimport typeof AnimatedSectionList from './components/AnimatedSectionList';\nimport typeof AnimatedText from './components/AnimatedText';\nimport typeof AnimatedView from './components/AnimatedView';\n\nimport Platform from '../Utilities/Platform';\nimport AnimatedImplementation from './AnimatedImplementation';\nimport AnimatedMock from './AnimatedMock';\n\nconst Animated = ((Platform.isTesting\n ? AnimatedMock\n : AnimatedImplementation): typeof AnimatedImplementation);\n\nexport default {\n get FlatList(): AnimatedFlatList {\n return require('./components/AnimatedFlatList').default;\n },\n get Image(): AnimatedImage {\n return require('./components/AnimatedImage').default;\n },\n get ScrollView(): AnimatedScrollView {\n return require('./components/AnimatedScrollView').default;\n },\n get SectionList(): AnimatedSectionList {\n return require('./components/AnimatedSectionList').default;\n },\n get Text(): AnimatedText {\n return require('./components/AnimatedText').default;\n },\n get View(): AnimatedView {\n return require('./components/AnimatedView').default;\n },\n ...Animated,\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport type {EventConfig, Mapping} from './AnimatedEvent';\nimport type {\n AnimationConfig,\n EndCallback,\n EndResult,\n} from './animations/Animation';\nimport type {DecayAnimationConfig} from './animations/DecayAnimation';\nimport type {SpringAnimationConfig} from './animations/SpringAnimation';\nimport type {TimingAnimationConfig} from './animations/TimingAnimation';\n\nimport {AnimatedEvent, attachNativeEvent} from './AnimatedEvent';\nimport DecayAnimation from './animations/DecayAnimation';\nimport SpringAnimation from './animations/SpringAnimation';\nimport TimingAnimation from './animations/TimingAnimation';\nimport createAnimatedComponent from './createAnimatedComponent';\nimport AnimatedAddition from './nodes/AnimatedAddition';\nimport AnimatedColor from './nodes/AnimatedColor';\nimport AnimatedDiffClamp from './nodes/AnimatedDiffClamp';\nimport AnimatedDivision from './nodes/AnimatedDivision';\nimport AnimatedInterpolation from './nodes/AnimatedInterpolation';\nimport AnimatedModulo from './nodes/AnimatedModulo';\nimport AnimatedMultiplication from './nodes/AnimatedMultiplication';\nimport AnimatedNode from './nodes/AnimatedNode';\nimport AnimatedSubtraction from './nodes/AnimatedSubtraction';\nimport AnimatedTracking from './nodes/AnimatedTracking';\nimport AnimatedValue from './nodes/AnimatedValue';\nimport AnimatedValueXY from './nodes/AnimatedValueXY';\n\nexport type CompositeAnimation = {\n start: (callback?: ?EndCallback) => void,\n stop: () => void,\n reset: () => void,\n _startNativeLoop: (iterations?: number) => void,\n _isUsingNativeDriver: () => boolean,\n ...\n};\n\nconst add = function (\n a: AnimatedNode | number,\n b: AnimatedNode | number,\n): AnimatedAddition {\n return new AnimatedAddition(a, b);\n};\n\nconst subtract = function (\n a: AnimatedNode | number,\n b: AnimatedNode | number,\n): AnimatedSubtraction {\n return new AnimatedSubtraction(a, b);\n};\n\nconst divide = function (\n a: AnimatedNode | number,\n b: AnimatedNode | number,\n): AnimatedDivision {\n return new AnimatedDivision(a, b);\n};\n\nconst multiply = function (\n a: AnimatedNode | number,\n b: AnimatedNode | number,\n): AnimatedMultiplication {\n return new AnimatedMultiplication(a, b);\n};\n\nconst modulo = function (a: AnimatedNode, modulus: number): AnimatedModulo {\n return new AnimatedModulo(a, modulus);\n};\n\nconst diffClamp = function (\n a: AnimatedNode,\n min: number,\n max: number,\n): AnimatedDiffClamp {\n return new AnimatedDiffClamp(a, min, max);\n};\n\nconst _combineCallbacks = function (\n callback: ?EndCallback,\n config: $ReadOnly<{...AnimationConfig, ...}>,\n) {\n if (callback && config.onComplete) {\n return (...args: Array) => {\n config.onComplete && config.onComplete(...args);\n callback && callback(...args);\n };\n } else {\n return callback || config.onComplete;\n }\n};\n\nconst maybeVectorAnim = function (\n value: AnimatedValue | AnimatedValueXY | AnimatedColor,\n config: Object,\n anim: (value: AnimatedValue, config: Object) => CompositeAnimation,\n): ?CompositeAnimation {\n if (value instanceof AnimatedValueXY) {\n const configX = {...config};\n const configY = {...config};\n for (const key in config) {\n const {x, y} = config[key];\n if (x !== undefined && y !== undefined) {\n configX[key] = x;\n configY[key] = y;\n }\n }\n const aX = anim((value: AnimatedValueXY).x, configX);\n const aY = anim((value: AnimatedValueXY).y, configY);\n // We use `stopTogether: false` here because otherwise tracking will break\n // because the second animation will get stopped before it can update.\n return parallel([aX, aY], {stopTogether: false});\n } else if (value instanceof AnimatedColor) {\n const configR = {...config};\n const configG = {...config};\n const configB = {...config};\n const configA = {...config};\n for (const key in config) {\n const {r, g, b, a} = config[key];\n if (\n r !== undefined &&\n g !== undefined &&\n b !== undefined &&\n a !== undefined\n ) {\n configR[key] = r;\n configG[key] = g;\n configB[key] = b;\n configA[key] = a;\n }\n }\n const aR = anim((value: AnimatedColor).r, configR);\n const aG = anim((value: AnimatedColor).g, configG);\n const aB = anim((value: AnimatedColor).b, configB);\n const aA = anim((value: AnimatedColor).a, configA);\n // We use `stopTogether: false` here because otherwise tracking will break\n // because the second animation will get stopped before it can update.\n return parallel([aR, aG, aB, aA], {stopTogether: false});\n }\n return null;\n};\n\nconst spring = function (\n value: AnimatedValue | AnimatedValueXY | AnimatedColor,\n config: SpringAnimationConfig,\n): CompositeAnimation {\n const start = function (\n animatedValue: AnimatedValue | AnimatedValueXY | AnimatedColor,\n configuration: SpringAnimationConfig,\n callback?: ?EndCallback,\n ): void {\n callback = _combineCallbacks(callback, configuration);\n const singleValue: any = animatedValue;\n const singleConfig: any = configuration;\n singleValue.stopTracking();\n if (configuration.toValue instanceof AnimatedNode) {\n singleValue.track(\n new AnimatedTracking(\n singleValue,\n configuration.toValue,\n SpringAnimation,\n singleConfig,\n callback,\n ),\n );\n } else {\n singleValue.animate(new SpringAnimation(singleConfig), callback);\n }\n };\n return (\n maybeVectorAnim(value, config, spring) || {\n start: function (callback?: ?EndCallback): void {\n start(value, config, callback);\n },\n\n stop: function (): void {\n value.stopAnimation();\n },\n\n reset: function (): void {\n value.resetAnimation();\n },\n\n _startNativeLoop: function (iterations?: number): void {\n const singleConfig = {...config, iterations};\n start(value, singleConfig);\n },\n\n _isUsingNativeDriver: function (): boolean {\n return config.useNativeDriver || false;\n },\n }\n );\n};\n\nconst timing = function (\n value: AnimatedValue | AnimatedValueXY | AnimatedColor,\n config: TimingAnimationConfig,\n): CompositeAnimation {\n const start = function (\n animatedValue: AnimatedValue | AnimatedValueXY | AnimatedColor,\n configuration: TimingAnimationConfig,\n callback?: ?EndCallback,\n ): void {\n callback = _combineCallbacks(callback, configuration);\n const singleValue: any = animatedValue;\n const singleConfig: any = configuration;\n singleValue.stopTracking();\n if (configuration.toValue instanceof AnimatedNode) {\n singleValue.track(\n new AnimatedTracking(\n singleValue,\n configuration.toValue,\n TimingAnimation,\n singleConfig,\n callback,\n ),\n );\n } else {\n singleValue.animate(new TimingAnimation(singleConfig), callback);\n }\n };\n\n return (\n maybeVectorAnim(value, config, timing) || {\n start: function (callback?: ?EndCallback): void {\n start(value, config, callback);\n },\n\n stop: function (): void {\n value.stopAnimation();\n },\n\n reset: function (): void {\n value.resetAnimation();\n },\n\n _startNativeLoop: function (iterations?: number): void {\n const singleConfig = {...config, iterations};\n start(value, singleConfig);\n },\n\n _isUsingNativeDriver: function (): boolean {\n return config.useNativeDriver || false;\n },\n }\n );\n};\n\nconst decay = function (\n value: AnimatedValue | AnimatedValueXY | AnimatedColor,\n config: DecayAnimationConfig,\n): CompositeAnimation {\n const start = function (\n animatedValue: AnimatedValue | AnimatedValueXY | AnimatedColor,\n configuration: DecayAnimationConfig,\n callback?: ?EndCallback,\n ): void {\n callback = _combineCallbacks(callback, configuration);\n const singleValue: any = animatedValue;\n const singleConfig: any = configuration;\n singleValue.stopTracking();\n singleValue.animate(new DecayAnimation(singleConfig), callback);\n };\n\n return (\n maybeVectorAnim(value, config, decay) || {\n start: function (callback?: ?EndCallback): void {\n start(value, config, callback);\n },\n\n stop: function (): void {\n value.stopAnimation();\n },\n\n reset: function (): void {\n value.resetAnimation();\n },\n\n _startNativeLoop: function (iterations?: number): void {\n const singleConfig = {...config, iterations};\n start(value, singleConfig);\n },\n\n _isUsingNativeDriver: function (): boolean {\n return config.useNativeDriver || false;\n },\n }\n );\n};\n\nconst sequence = function (\n animations: Array,\n): CompositeAnimation {\n let current = 0;\n return {\n start: function (callback?: ?EndCallback) {\n const onComplete = function (result: EndResult) {\n if (!result.finished) {\n callback && callback(result);\n return;\n }\n\n current++;\n\n if (current === animations.length) {\n callback && callback(result);\n return;\n }\n\n animations[current].start(onComplete);\n };\n\n if (animations.length === 0) {\n callback && callback({finished: true});\n } else {\n animations[current].start(onComplete);\n }\n },\n\n stop: function () {\n if (current < animations.length) {\n animations[current].stop();\n }\n },\n\n reset: function () {\n animations.forEach((animation, idx) => {\n if (idx <= current) {\n animation.reset();\n }\n });\n current = 0;\n },\n\n _startNativeLoop: function () {\n throw new Error(\n 'Loops run using the native driver cannot contain Animated.sequence animations',\n );\n },\n\n _isUsingNativeDriver: function (): boolean {\n return false;\n },\n };\n};\n\ntype ParallelConfig = {\n // If one is stopped, stop all. default: true\n stopTogether?: boolean,\n ...\n};\nconst parallel = function (\n animations: Array,\n config?: ?ParallelConfig,\n): CompositeAnimation {\n let doneCount = 0;\n // Make sure we only call stop() at most once for each animation\n const hasEnded: {[number]: boolean} = {};\n const stopTogether = !(config && config.stopTogether === false);\n\n const result = {\n start: function (callback?: ?EndCallback) {\n if (doneCount === animations.length) {\n callback && callback({finished: true});\n return;\n }\n\n animations.forEach((animation, idx) => {\n const cb = function (endResult: EndResult | {finished: boolean}) {\n hasEnded[idx] = true;\n doneCount++;\n if (doneCount === animations.length) {\n doneCount = 0;\n callback && callback(endResult);\n return;\n }\n\n if (!endResult.finished && stopTogether) {\n result.stop();\n }\n };\n\n if (!animation) {\n cb({finished: true});\n } else {\n animation.start(cb);\n }\n });\n },\n\n stop: function (): void {\n animations.forEach((animation, idx) => {\n !hasEnded[idx] && animation.stop();\n hasEnded[idx] = true;\n });\n },\n\n reset: function (): void {\n animations.forEach((animation, idx) => {\n animation.reset();\n hasEnded[idx] = false;\n doneCount = 0;\n });\n },\n\n _startNativeLoop: function (): empty {\n throw new Error(\n 'Loops run using the native driver cannot contain Animated.parallel animations',\n );\n },\n\n _isUsingNativeDriver: function (): boolean {\n return false;\n },\n };\n\n return result;\n};\n\nconst delay = function (time: number): CompositeAnimation {\n // Would be nice to make a specialized implementation\n return timing(new AnimatedValue(0), {\n toValue: 0,\n delay: time,\n duration: 0,\n useNativeDriver: false,\n });\n};\n\nconst stagger = function (\n time: number,\n animations: Array,\n): CompositeAnimation {\n return parallel(\n animations.map((animation, i) => {\n return sequence([delay(time * i), animation]);\n }),\n );\n};\n\ntype LoopAnimationConfig = {\n iterations: number,\n resetBeforeIteration?: boolean,\n ...\n};\n\nconst loop = function (\n animation: CompositeAnimation,\n // $FlowFixMe[prop-missing]\n {iterations = -1, resetBeforeIteration = true}: LoopAnimationConfig = {},\n): CompositeAnimation {\n let isFinished = false;\n let iterationsSoFar = 0;\n return {\n start: function (callback?: ?EndCallback) {\n const restart = function (result: EndResult = {finished: true}): void {\n if (\n isFinished ||\n iterationsSoFar === iterations ||\n result.finished === false\n ) {\n callback && callback(result);\n } else {\n iterationsSoFar++;\n resetBeforeIteration && animation.reset();\n animation.start(restart);\n }\n };\n if (!animation || iterations === 0) {\n callback && callback({finished: true});\n } else {\n if (animation._isUsingNativeDriver()) {\n animation._startNativeLoop(iterations);\n } else {\n restart(); // Start looping recursively on the js thread\n }\n }\n },\n\n stop: function (): void {\n isFinished = true;\n animation.stop();\n },\n\n reset: function (): void {\n iterationsSoFar = 0;\n isFinished = false;\n animation.reset();\n },\n\n _startNativeLoop: function () {\n throw new Error(\n 'Loops run using the native driver cannot contain Animated.loop animations',\n );\n },\n\n _isUsingNativeDriver: function (): boolean {\n return animation._isUsingNativeDriver();\n },\n };\n};\n\nfunction forkEvent(\n event: ?AnimatedEvent | ?Function,\n listener: Function,\n): AnimatedEvent | Function {\n if (!event) {\n return listener;\n } else if (event instanceof AnimatedEvent) {\n event.__addListener(listener);\n return event;\n } else {\n return (...args) => {\n typeof event === 'function' && event(...args);\n listener(...args);\n };\n }\n}\n\nfunction unforkEvent(\n event: ?AnimatedEvent | ?Function,\n listener: Function,\n): void {\n if (event && event instanceof AnimatedEvent) {\n event.__removeListener(listener);\n }\n}\n\nconst event = function (\n argMapping: $ReadOnlyArray,\n config: EventConfig,\n): any {\n const animatedEvent = new AnimatedEvent(argMapping, config);\n if (animatedEvent.__isNative) {\n return animatedEvent;\n } else {\n return animatedEvent.__getHandler();\n }\n};\n\n// All types of animated nodes that represent scalar numbers and can be interpolated (etc)\ntype AnimatedNumeric =\n | AnimatedAddition\n | AnimatedDiffClamp\n | AnimatedDivision\n | AnimatedInterpolation\n | AnimatedModulo\n | AnimatedMultiplication\n | AnimatedSubtraction\n | AnimatedValue;\n\nexport type {AnimatedNumeric as Numeric};\n\n/**\n * The `Animated` library is designed to make animations fluid, powerful, and\n * easy to build and maintain. `Animated` focuses on declarative relationships\n * between inputs and outputs, with configurable transforms in between, and\n * simple `start`/`stop` methods to control time-based animation execution.\n * If additional transforms are added, be sure to include them in\n * AnimatedMock.js as well.\n *\n * See https://reactnative.dev/docs/animated\n */\nexport default {\n /**\n * Standard value class for driving animations. Typically initialized with\n * `new Animated.Value(0);`\n *\n * See https://reactnative.dev/docs/animated#value\n */\n Value: AnimatedValue,\n /**\n * 2D value class for driving 2D animations, such as pan gestures.\n *\n * See https://reactnative.dev/docs/animatedvaluexy\n */\n ValueXY: AnimatedValueXY,\n /**\n * Value class for driving color animations.\n */\n Color: AnimatedColor,\n /**\n * Exported to use the Interpolation type in flow.\n *\n * See https://reactnative.dev/docs/animated#interpolation\n */\n Interpolation: AnimatedInterpolation,\n /**\n * Exported for ease of type checking. All animated values derive from this\n * class.\n *\n * See https://reactnative.dev/docs/animated#node\n */\n Node: AnimatedNode,\n\n /**\n * Animates a value from an initial velocity to zero based on a decay\n * coefficient.\n *\n * See https://reactnative.dev/docs/animated#decay\n */\n decay,\n /**\n * Animates a value along a timed easing curve. The Easing module has tons of\n * predefined curves, or you can use your own function.\n *\n * See https://reactnative.dev/docs/animated#timing\n */\n timing,\n /**\n * Animates a value according to an analytical spring model based on\n * damped harmonic oscillation.\n *\n * See https://reactnative.dev/docs/animated#spring\n */\n spring,\n\n /**\n * Creates a new Animated value composed from two Animated values added\n * together.\n *\n * See https://reactnative.dev/docs/animated#add\n */\n add,\n\n /**\n * Creates a new Animated value composed by subtracting the second Animated\n * value from the first Animated value.\n *\n * See https://reactnative.dev/docs/animated#subtract\n */\n subtract,\n\n /**\n * Creates a new Animated value composed by dividing the first Animated value\n * by the second Animated value.\n *\n * See https://reactnative.dev/docs/animated#divide\n */\n divide,\n\n /**\n * Creates a new Animated value composed from two Animated values multiplied\n * together.\n *\n * See https://reactnative.dev/docs/animated#multiply\n */\n multiply,\n\n /**\n * Creates a new Animated value that is the (non-negative) modulo of the\n * provided Animated value.\n *\n * See https://reactnative.dev/docs/animated#modulo\n */\n modulo,\n\n /**\n * Create a new Animated value that is limited between 2 values. It uses the\n * difference between the last value so even if the value is far from the\n * bounds it will start changing when the value starts getting closer again.\n *\n * See https://reactnative.dev/docs/animated#diffclamp\n */\n diffClamp,\n\n /**\n * Starts an animation after the given delay.\n *\n * See https://reactnative.dev/docs/animated#delay\n */\n delay,\n /**\n * Starts an array of animations in order, waiting for each to complete\n * before starting the next. If the current running animation is stopped, no\n * following animations will be started.\n *\n * See https://reactnative.dev/docs/animated#sequence\n */\n sequence,\n /**\n * Starts an array of animations all at the same time. By default, if one\n * of the animations is stopped, they will all be stopped. You can override\n * this with the `stopTogether` flag.\n *\n * See https://reactnative.dev/docs/animated#parallel\n */\n parallel,\n /**\n * Array of animations may run in parallel (overlap), but are started in\n * sequence with successive delays. Nice for doing trailing effects.\n *\n * See https://reactnative.dev/docs/animated#stagger\n */\n stagger,\n /**\n * Loops a given animation continuously, so that each time it reaches the\n * end, it resets and begins again from the start.\n *\n * See https://reactnative.dev/docs/animated#loop\n */\n loop,\n\n /**\n * Takes an array of mappings and extracts values from each arg accordingly,\n * then calls `setValue` on the mapped outputs.\n *\n * See https://reactnative.dev/docs/animated#event\n */\n event,\n\n /**\n * Make any React component Animatable. Used to create `Animated.View`, etc.\n *\n * See https://reactnative.dev/docs/animated#createanimatedcomponent\n */\n createAnimatedComponent,\n\n /**\n * Imperative API to attach an animated value to an event on a view. Prefer\n * using `Animated.event` with `useNativeDrive: true` if possible.\n *\n * See https://reactnative.dev/docs/animated#attachnativeevent\n */\n attachNativeEvent,\n\n /**\n * Advanced imperative API for snooping on animated events that are passed in\n * through props. Use values directly where possible.\n *\n * See https://reactnative.dev/docs/animated#forkevent\n */\n forkEvent,\n unforkEvent,\n\n /**\n * Expose Event class, so it can be used as a type for type checkers.\n */\n Event: AnimatedEvent,\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport type {PlatformConfig} from '../AnimatedPlatformConfig';\nimport type AnimatedValue from '../nodes/AnimatedValue';\nimport type {AnimationConfig, EndCallback} from './Animation';\n\nimport NativeAnimatedHelper from '../NativeAnimatedHelper';\nimport Animation from './Animation';\n\nexport type DecayAnimationConfig = {\n ...AnimationConfig,\n velocity:\n | number\n | {\n x: number,\n y: number,\n ...\n },\n deceleration?: number,\n};\n\nexport type DecayAnimationConfigSingle = {\n ...AnimationConfig,\n velocity: number,\n deceleration?: number,\n};\n\nexport default class DecayAnimation extends Animation {\n _startTime: number;\n _lastValue: number;\n _fromValue: number;\n _deceleration: number;\n _velocity: number;\n _onUpdate: (value: number) => void;\n _animationFrame: any;\n _useNativeDriver: boolean;\n _platformConfig: ?PlatformConfig;\n\n constructor(config: DecayAnimationConfigSingle) {\n super();\n this._deceleration = config.deceleration ?? 0.998;\n this._velocity = config.velocity;\n this._useNativeDriver = NativeAnimatedHelper.shouldUseNativeDriver(config);\n this._platformConfig = config.platformConfig;\n this.__isInteraction = config.isInteraction ?? !this._useNativeDriver;\n this.__iterations = config.iterations ?? 1;\n }\n\n __getNativeAnimationConfig(): {|\n deceleration: number,\n iterations: number,\n platformConfig: ?PlatformConfig,\n type: $TEMPORARY$string<'decay'>,\n velocity: number,\n |} {\n return {\n type: 'decay',\n deceleration: this._deceleration,\n velocity: this._velocity,\n iterations: this.__iterations,\n platformConfig: this._platformConfig,\n };\n }\n\n start(\n fromValue: number,\n onUpdate: (value: number) => void,\n onEnd: ?EndCallback,\n previousAnimation: ?Animation,\n animatedValue: AnimatedValue,\n ): void {\n this.__active = true;\n this._lastValue = fromValue;\n this._fromValue = fromValue;\n this._onUpdate = onUpdate;\n this.__onEnd = onEnd;\n this._startTime = Date.now();\n if (this._useNativeDriver) {\n this.__startNativeAnimation(animatedValue);\n } else {\n // $FlowFixMe[method-unbinding] added when improving typing for this parameters\n this._animationFrame = requestAnimationFrame(this.onUpdate.bind(this));\n }\n }\n\n onUpdate(): void {\n const now = Date.now();\n\n const value =\n this._fromValue +\n (this._velocity / (1 - this._deceleration)) *\n (1 - Math.exp(-(1 - this._deceleration) * (now - this._startTime)));\n\n this._onUpdate(value);\n\n if (Math.abs(this._lastValue - value) < 0.1) {\n this.__debouncedOnEnd({finished: true});\n return;\n }\n\n this._lastValue = value;\n if (this.__active) {\n // $FlowFixMe[method-unbinding] added when improving typing for this parameters\n this._animationFrame = requestAnimationFrame(this.onUpdate.bind(this));\n }\n }\n\n stop(): void {\n super.stop();\n this.__active = false;\n global.cancelAnimationFrame(this._animationFrame);\n this.__debouncedOnEnd({finished: false});\n }\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 * @flow strict-local\n * @format\n */\n\nimport type {EventSubscription} from '../vendor/emitter/EventEmitter';\nimport type {EventConfig} from './AnimatedEvent';\nimport type {AnimationConfig, EndCallback} from './animations/Animation';\nimport type {\n AnimatedNodeConfig,\n AnimatingNodeConfig,\n EventMapping,\n} from './NativeAnimatedModule';\nimport type {InterpolationConfigType} from './nodes/AnimatedInterpolation';\n\nimport NativeEventEmitter from '../EventEmitter/NativeEventEmitter';\nimport RCTDeviceEventEmitter from '../EventEmitter/RCTDeviceEventEmitter';\nimport ReactNativeFeatureFlags from '../ReactNative/ReactNativeFeatureFlags';\nimport Platform from '../Utilities/Platform';\nimport NativeAnimatedNonTurboModule from './NativeAnimatedModule';\nimport NativeAnimatedTurboModule from './NativeAnimatedTurboModule';\nimport invariant from 'invariant';\n\n// TODO T69437152 @petetheheat - Delete this fork when Fabric ships to 100%.\nconst NativeAnimatedModule =\n Platform.OS === 'ios' && global.RN$Bridgeless === true\n ? NativeAnimatedTurboModule\n : NativeAnimatedNonTurboModule;\n\nlet __nativeAnimatedNodeTagCount = 1; /* used for animated nodes */\nlet __nativeAnimationIdCount = 1; /* used for started animations */\n\nlet nativeEventEmitter;\n\nlet waitingForQueuedOperations = new Set();\nlet queueOperations = false;\nlet queue: Array<() => void> = [];\n// $FlowFixMe\nlet singleOpQueue: Array = [];\n\nconst useSingleOpBatching =\n Platform.OS === 'android' &&\n !!NativeAnimatedModule?.queueAndExecuteBatchedOperations &&\n ReactNativeFeatureFlags.animatedShouldUseSingleOp();\nlet flushQueueTimeout = null;\n\nconst eventListenerGetValueCallbacks: {\n [$FlowFixMe | number]: ((value: number) => void) | void,\n} = {};\nconst eventListenerAnimationFinishedCallbacks: {\n [$FlowFixMe | number]: EndCallback | void,\n} = {};\nlet globalEventEmitterGetValueListener: ?EventSubscription = null;\nlet globalEventEmitterAnimationFinishedListener: ?EventSubscription = null;\n\nconst nativeOps: ?typeof NativeAnimatedModule = useSingleOpBatching\n ? ((function () {\n const apis = [\n 'createAnimatedNode', // 1\n 'updateAnimatedNodeConfig', // 2\n 'getValue', // 3\n 'startListeningToAnimatedNodeValue', // 4\n 'stopListeningToAnimatedNodeValue', // 5\n 'connectAnimatedNodes', // 6\n 'disconnectAnimatedNodes', // 7\n 'startAnimatingNode', // 8\n 'stopAnimation', // 9\n 'setAnimatedNodeValue', // 10\n 'setAnimatedNodeOffset', // 11\n 'flattenAnimatedNodeOffset', // 12\n 'extractAnimatedNodeOffset', // 13\n 'connectAnimatedNodeToView', // 14\n 'disconnectAnimatedNodeFromView', // 15\n 'restoreDefaultValues', // 16\n 'dropAnimatedNode', // 17\n 'addAnimatedEventToView', // 18\n 'removeAnimatedEventFromView', // 19\n 'addListener', // 20\n 'removeListener', // 21\n ];\n return apis.reduce<{[string]: number}>((acc, functionName, i) => {\n // These indices need to be kept in sync with the indices in native (see NativeAnimatedModule in Java, or the equivalent for any other native platform).\n // $FlowFixMe[prop-missing]\n acc[functionName] = i + 1;\n return acc;\n }, {});\n })(): $FlowFixMe)\n : NativeAnimatedModule;\n\n/**\n * Wrappers around NativeAnimatedModule to provide flow and autocomplete support for\n * the native module methods, and automatic queue management on Android\n */\nconst API = {\n getValue: function (\n tag: number,\n saveValueCallback: (value: number) => void,\n ): void {\n invariant(nativeOps, 'Native animated module is not available');\n if (useSingleOpBatching) {\n if (saveValueCallback) {\n eventListenerGetValueCallbacks[tag] = saveValueCallback;\n }\n // $FlowFixMe\n API.queueOperation(nativeOps.getValue, tag);\n } else {\n API.queueOperation(nativeOps.getValue, tag, saveValueCallback);\n }\n },\n setWaitingForIdentifier: function (id: string): void {\n waitingForQueuedOperations.add(id);\n queueOperations = true;\n if (\n ReactNativeFeatureFlags.animatedShouldDebounceQueueFlush() &&\n flushQueueTimeout\n ) {\n clearTimeout(flushQueueTimeout);\n }\n },\n unsetWaitingForIdentifier: function (id: string): void {\n waitingForQueuedOperations.delete(id);\n\n if (waitingForQueuedOperations.size === 0) {\n queueOperations = false;\n API.disableQueue();\n }\n },\n disableQueue: function (): void {\n invariant(nativeOps, 'Native animated module is not available');\n\n if (ReactNativeFeatureFlags.animatedShouldDebounceQueueFlush()) {\n const prevTimeout = flushQueueTimeout;\n clearImmediate(prevTimeout);\n flushQueueTimeout = setImmediate(API.flushQueue);\n } else {\n API.flushQueue();\n }\n },\n flushQueue: function (): void {\n invariant(NativeAnimatedModule, 'Native animated module is not available');\n flushQueueTimeout = null;\n\n // Early returns before calling any APIs\n if (useSingleOpBatching && singleOpQueue.length === 0) {\n return;\n }\n if (!useSingleOpBatching && queue.length === 0) {\n return;\n }\n\n if (useSingleOpBatching) {\n // Set up event listener for callbacks if it's not set up\n if (\n !globalEventEmitterGetValueListener ||\n !globalEventEmitterAnimationFinishedListener\n ) {\n setupGlobalEventEmitterListeners();\n }\n // Single op batching doesn't use callback functions, instead we\n // use RCTDeviceEventEmitter. This reduces overhead of sending lots of\n // JSI functions across to native code; but also, TM infrastructure currently\n // does not support packing a function into native arrays.\n NativeAnimatedModule.queueAndExecuteBatchedOperations?.(singleOpQueue);\n singleOpQueue.length = 0;\n } else {\n Platform.OS === 'android' && NativeAnimatedModule.startOperationBatch?.();\n for (let q = 0, l = queue.length; q < l; q++) {\n queue[q]();\n }\n queue.length = 0;\n Platform.OS === 'android' &&\n NativeAnimatedModule.finishOperationBatch?.();\n }\n },\n queueOperation: , Fn: (...Args) => void>(\n fn: Fn,\n ...args: Args\n ): void => {\n if (useSingleOpBatching) {\n // Get the command ID from the queued function, and push that ID and any arguments needed to execute the operation\n // $FlowFixMe: surprise, fn is actually a number\n singleOpQueue.push(fn, ...args);\n return;\n }\n\n // If queueing is explicitly on, *or* the queue has not yet\n // been flushed, use the queue. This is to prevent operations\n // from being executed out of order.\n if (queueOperations || queue.length !== 0) {\n queue.push(() => fn(...args));\n } else {\n fn(...args);\n }\n },\n createAnimatedNode: function (tag: number, config: AnimatedNodeConfig): void {\n invariant(nativeOps, 'Native animated module is not available');\n API.queueOperation(nativeOps.createAnimatedNode, tag, config);\n },\n updateAnimatedNodeConfig: function (\n tag: number,\n config: AnimatedNodeConfig,\n ): void {\n invariant(nativeOps, 'Native animated module is not available');\n if (nativeOps.updateAnimatedNodeConfig) {\n API.queueOperation(nativeOps.updateAnimatedNodeConfig, tag, config);\n }\n },\n startListeningToAnimatedNodeValue: function (tag: number) {\n invariant(nativeOps, 'Native animated module is not available');\n API.queueOperation(nativeOps.startListeningToAnimatedNodeValue, tag);\n },\n stopListeningToAnimatedNodeValue: function (tag: number) {\n invariant(nativeOps, 'Native animated module is not available');\n API.queueOperation(nativeOps.stopListeningToAnimatedNodeValue, tag);\n },\n connectAnimatedNodes: function (parentTag: number, childTag: number): void {\n invariant(nativeOps, 'Native animated module is not available');\n API.queueOperation(nativeOps.connectAnimatedNodes, parentTag, childTag);\n },\n disconnectAnimatedNodes: function (\n parentTag: number,\n childTag: number,\n ): void {\n invariant(nativeOps, 'Native animated module is not available');\n API.queueOperation(nativeOps.disconnectAnimatedNodes, parentTag, childTag);\n },\n startAnimatingNode: function (\n animationId: number,\n nodeTag: number,\n config: AnimatingNodeConfig,\n endCallback: EndCallback,\n ): void {\n invariant(nativeOps, 'Native animated module is not available');\n if (useSingleOpBatching) {\n if (endCallback) {\n eventListenerAnimationFinishedCallbacks[animationId] = endCallback;\n }\n // $FlowFixMe\n API.queueOperation(\n nativeOps.startAnimatingNode,\n animationId,\n nodeTag,\n config,\n );\n } else {\n API.queueOperation(\n nativeOps.startAnimatingNode,\n animationId,\n nodeTag,\n config,\n endCallback,\n );\n }\n },\n stopAnimation: function (animationId: number) {\n invariant(nativeOps, 'Native animated module is not available');\n API.queueOperation(nativeOps.stopAnimation, animationId);\n },\n setAnimatedNodeValue: function (nodeTag: number, value: number): void {\n invariant(nativeOps, 'Native animated module is not available');\n API.queueOperation(nativeOps.setAnimatedNodeValue, nodeTag, value);\n },\n setAnimatedNodeOffset: function (nodeTag: number, offset: number): void {\n invariant(nativeOps, 'Native animated module is not available');\n API.queueOperation(nativeOps.setAnimatedNodeOffset, nodeTag, offset);\n },\n flattenAnimatedNodeOffset: function (nodeTag: number): void {\n invariant(nativeOps, 'Native animated module is not available');\n API.queueOperation(nativeOps.flattenAnimatedNodeOffset, nodeTag);\n },\n extractAnimatedNodeOffset: function (nodeTag: number): void {\n invariant(nativeOps, 'Native animated module is not available');\n API.queueOperation(nativeOps.extractAnimatedNodeOffset, nodeTag);\n },\n connectAnimatedNodeToView: function (nodeTag: number, viewTag: number): void {\n invariant(nativeOps, 'Native animated module is not available');\n API.queueOperation(nativeOps.connectAnimatedNodeToView, nodeTag, viewTag);\n },\n disconnectAnimatedNodeFromView: function (\n nodeTag: number,\n viewTag: number,\n ): void {\n invariant(nativeOps, 'Native animated module is not available');\n API.queueOperation(\n nativeOps.disconnectAnimatedNodeFromView,\n nodeTag,\n viewTag,\n );\n },\n restoreDefaultValues: function (nodeTag: number): void {\n invariant(nativeOps, 'Native animated module is not available');\n // Backwards compat with older native runtimes, can be removed later.\n if (nativeOps.restoreDefaultValues != null) {\n API.queueOperation(nativeOps.restoreDefaultValues, nodeTag);\n }\n },\n dropAnimatedNode: function (tag: number): void {\n invariant(nativeOps, 'Native animated module is not available');\n API.queueOperation(nativeOps.dropAnimatedNode, tag);\n },\n addAnimatedEventToView: function (\n viewTag: number,\n eventName: string,\n eventMapping: EventMapping,\n ) {\n invariant(nativeOps, 'Native animated module is not available');\n API.queueOperation(\n nativeOps.addAnimatedEventToView,\n viewTag,\n eventName,\n eventMapping,\n );\n },\n removeAnimatedEventFromView(\n viewTag: number,\n eventName: string,\n animatedNodeTag: number,\n ) {\n invariant(nativeOps, 'Native animated module is not available');\n API.queueOperation(\n nativeOps.removeAnimatedEventFromView,\n viewTag,\n eventName,\n animatedNodeTag,\n );\n },\n};\n\nfunction setupGlobalEventEmitterListeners() {\n globalEventEmitterGetValueListener = RCTDeviceEventEmitter.addListener(\n 'onNativeAnimatedModuleGetValue',\n function (params) {\n const {tag} = params;\n const callback = eventListenerGetValueCallbacks[tag];\n if (!callback) {\n return;\n }\n callback(params.value);\n delete eventListenerGetValueCallbacks[tag];\n },\n );\n globalEventEmitterAnimationFinishedListener =\n RCTDeviceEventEmitter.addListener(\n 'onNativeAnimatedModuleAnimationFinished',\n function (params) {\n const {animationId} = params;\n const callback = eventListenerAnimationFinishedCallbacks[animationId];\n if (!callback) {\n return;\n }\n callback(params);\n delete eventListenerAnimationFinishedCallbacks[animationId];\n },\n );\n}\n\n/**\n * Styles allowed by the native animated implementation.\n *\n * In general native animated implementation should support any numeric or color property that\n * doesn't need to be updated through the shadow view hierarchy (all non-layout properties).\n */\nconst SUPPORTED_COLOR_STYLES = {\n backgroundColor: true,\n borderBottomColor: true,\n borderColor: true,\n borderEndColor: true,\n borderLeftColor: true,\n borderRightColor: true,\n borderStartColor: true,\n borderTopColor: true,\n color: true,\n tintColor: true,\n};\n\nconst SUPPORTED_STYLES = {\n ...SUPPORTED_COLOR_STYLES,\n borderBottomEndRadius: true,\n borderBottomLeftRadius: true,\n borderBottomRightRadius: true,\n borderBottomStartRadius: true,\n borderRadius: true,\n borderTopEndRadius: true,\n borderTopLeftRadius: true,\n borderTopRightRadius: true,\n borderTopStartRadius: true,\n elevation: true,\n opacity: true,\n transform: true,\n zIndex: true,\n /* ios styles */\n shadowOpacity: true,\n shadowRadius: true,\n /* legacy android transform properties */\n scaleX: true,\n scaleY: true,\n translateX: true,\n translateY: true,\n};\n\nconst SUPPORTED_TRANSFORMS = {\n translateX: true,\n translateY: true,\n scale: true,\n scaleX: true,\n scaleY: true,\n rotate: true,\n rotateX: true,\n rotateY: true,\n rotateZ: true,\n perspective: true,\n};\n\nconst SUPPORTED_INTERPOLATION_PARAMS = {\n inputRange: true,\n outputRange: true,\n extrapolate: true,\n extrapolateRight: true,\n extrapolateLeft: true,\n};\n\nfunction addWhitelistedStyleProp(prop: string): void {\n // $FlowFixMe[prop-missing]\n SUPPORTED_STYLES[prop] = true;\n}\n\nfunction addWhitelistedTransformProp(prop: string): void {\n // $FlowFixMe[prop-missing]\n SUPPORTED_TRANSFORMS[prop] = true;\n}\n\nfunction addWhitelistedInterpolationParam(param: string): void {\n // $FlowFixMe[prop-missing]\n SUPPORTED_INTERPOLATION_PARAMS[param] = true;\n}\n\nfunction isSupportedColorStyleProp(prop: string): boolean {\n return SUPPORTED_COLOR_STYLES.hasOwnProperty(prop);\n}\n\nfunction isSupportedStyleProp(prop: string): boolean {\n return SUPPORTED_STYLES.hasOwnProperty(prop);\n}\n\nfunction isSupportedTransformProp(prop: string): boolean {\n return SUPPORTED_TRANSFORMS.hasOwnProperty(prop);\n}\n\nfunction isSupportedInterpolationParam(param: string): boolean {\n return SUPPORTED_INTERPOLATION_PARAMS.hasOwnProperty(param);\n}\n\nfunction validateTransform(\n configs: Array<\n | {\n type: 'animated',\n property: string,\n nodeTag: ?number,\n ...\n }\n | {\n type: 'static',\n property: string,\n value: number | string,\n ...\n },\n >,\n): void {\n configs.forEach(config => {\n if (!isSupportedTransformProp(config.property)) {\n throw new Error(\n `Property '${config.property}' is not supported by native animated module`,\n );\n }\n });\n}\n\nfunction validateStyles(styles: {[key: string]: ?number, ...}): void {\n for (const key in styles) {\n if (!isSupportedStyleProp(key)) {\n throw new Error(\n `Style property '${key}' is not supported by native animated module`,\n );\n }\n }\n}\n\nfunction validateInterpolation(\n config: InterpolationConfigType,\n): void {\n for (const key in config) {\n if (!isSupportedInterpolationParam(key)) {\n throw new Error(\n `Interpolation property '${key}' is not supported by native animated module`,\n );\n }\n }\n}\n\nfunction generateNewNodeTag(): number {\n return __nativeAnimatedNodeTagCount++;\n}\n\nfunction generateNewAnimationId(): number {\n return __nativeAnimationIdCount++;\n}\n\nfunction assertNativeAnimatedModule(): void {\n invariant(NativeAnimatedModule, 'Native animated module is not available');\n}\n\nlet _warnedMissingNativeAnimated = false;\n\nfunction shouldUseNativeDriver(\n config: $ReadOnly<{...AnimationConfig, ...}> | EventConfig,\n): boolean {\n if (config.useNativeDriver == null) {\n console.warn(\n 'Animated: `useNativeDriver` was not specified. This is a required ' +\n 'option and must be explicitly set to `true` or `false`',\n );\n }\n\n if (config.useNativeDriver === true && !NativeAnimatedModule) {\n if (process.env.NODE_ENV !== 'test') {\n if (!_warnedMissingNativeAnimated) {\n console.warn(\n 'Animated: `useNativeDriver` is not supported because the native ' +\n 'animated module is missing. Falling back to JS-based animation. To ' +\n 'resolve this, add `RCTAnimation` module to this app, or remove ' +\n '`useNativeDriver`. ' +\n 'Make sure to run `bundle exec pod install` first. Read more about autolinking: https://github.com/react-native-community/cli/blob/master/docs/autolinking.md',\n );\n _warnedMissingNativeAnimated = true;\n }\n }\n return false;\n }\n\n return config.useNativeDriver || false;\n}\n\nfunction transformDataType(value: number | string): number | string {\n // Change the string type to number type so we can reuse the same logic in\n // iOS and Android platform\n if (typeof value !== 'string') {\n return value;\n }\n if (/deg$/.test(value)) {\n const degrees = parseFloat(value) || 0;\n const radians = (degrees * Math.PI) / 180.0;\n return radians;\n } else {\n return value;\n }\n}\n\nexport default {\n API,\n isSupportedColorStyleProp,\n isSupportedStyleProp,\n isSupportedTransformProp,\n isSupportedInterpolationParam,\n addWhitelistedStyleProp,\n addWhitelistedTransformProp,\n addWhitelistedInterpolationParam,\n validateStyles,\n validateTransform,\n validateInterpolation,\n generateNewNodeTag,\n generateNewAnimationId,\n assertNativeAnimatedModule,\n shouldUseNativeDriver,\n transformDataType,\n // $FlowExpectedError[unsafe-getters-setters] - unsafe getter lint suppresion\n // $FlowExpectedError[missing-type-arg] - unsafe getter lint suppresion\n get nativeEventEmitter(): NativeEventEmitter {\n if (!nativeEventEmitter) {\n nativeEventEmitter = new NativeEventEmitter(\n // T88715063: NativeEventEmitter only used this parameter on iOS. Now it uses it on all platforms, so this code was modified automatically to preserve its behavior\n // If you want to use the native module on other platforms, please remove this condition and test its behavior\n Platform.OS !== 'ios' ? null : NativeAnimatedModule,\n );\n }\n return nativeEventEmitter;\n },\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 * @flow\n * @format\n */\n\nimport type {TurboModule} from '../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../TurboModule/TurboModuleRegistry';\n\ntype EndResult = {finished: boolean, ...};\ntype EndCallback = (result: EndResult) => void;\ntype SaveValueCallback = (value: number) => void;\n\nexport type EventMapping = {|\n nativeEventPath: Array,\n animatedValueTag: ?number,\n|};\n\n// The config has different keys depending on the type of the Node\n// TODO(T54896888): Make these types strict\nexport type AnimatedNodeConfig = Object;\nexport type AnimatingNodeConfig = Object;\n\nexport interface Spec extends TurboModule {\n +startOperationBatch: () => void;\n +finishOperationBatch: () => void;\n +createAnimatedNode: (tag: number, config: AnimatedNodeConfig) => void;\n +updateAnimatedNodeConfig?: (tag: number, config: AnimatedNodeConfig) => void;\n +getValue: (tag: number, saveValueCallback: SaveValueCallback) => void;\n +startListeningToAnimatedNodeValue: (tag: number) => void;\n +stopListeningToAnimatedNodeValue: (tag: number) => void;\n +connectAnimatedNodes: (parentTag: number, childTag: number) => void;\n +disconnectAnimatedNodes: (parentTag: number, childTag: number) => void;\n +startAnimatingNode: (\n animationId: number,\n nodeTag: number,\n config: AnimatingNodeConfig,\n endCallback: EndCallback,\n ) => void;\n +stopAnimation: (animationId: number) => void;\n +setAnimatedNodeValue: (nodeTag: number, value: number) => void;\n +setAnimatedNodeOffset: (nodeTag: number, offset: number) => void;\n +flattenAnimatedNodeOffset: (nodeTag: number) => void;\n +extractAnimatedNodeOffset: (nodeTag: number) => void;\n +connectAnimatedNodeToView: (nodeTag: number, viewTag: number) => void;\n +disconnectAnimatedNodeFromView: (nodeTag: number, viewTag: number) => void;\n +restoreDefaultValues: (nodeTag: number) => void;\n +dropAnimatedNode: (tag: number) => void;\n +addAnimatedEventToView: (\n viewTag: number,\n eventName: string,\n eventMapping: EventMapping,\n ) => void;\n +removeAnimatedEventFromView: (\n viewTag: number,\n eventName: string,\n animatedNodeTag: number,\n ) => void;\n\n // Events\n +addListener: (eventName: string) => void;\n +removeListeners: (count: number) => void;\n\n // All of the above in a batched mode\n +queueAndExecuteBatchedOperations?: (operationsAndArgs: Array) => void;\n}\n\nexport default (TurboModuleRegistry.get('NativeAnimatedModule'): ?Spec);\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 * @flow\n * @format\n */\n\nimport type {TurboModule} from '../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../TurboModule/TurboModuleRegistry';\n\ntype EndResult = {finished: boolean, ...};\ntype EndCallback = (result: EndResult) => void;\ntype SaveValueCallback = (value: number) => void;\n\nexport type EventMapping = {|\n nativeEventPath: Array,\n animatedValueTag: ?number,\n|};\n\n// The config has different keys depending on the type of the Node\n// TODO(T54896888): Make these types strict\nexport type AnimatedNodeConfig = Object;\nexport type AnimatingNodeConfig = Object;\n\nexport interface Spec extends TurboModule {\n +startOperationBatch: () => void;\n +finishOperationBatch: () => void;\n +createAnimatedNode: (tag: number, config: AnimatedNodeConfig) => void;\n +updateAnimatedNodeConfig?: (tag: number, config: AnimatedNodeConfig) => void;\n +getValue: (tag: number, saveValueCallback: SaveValueCallback) => void;\n +startListeningToAnimatedNodeValue: (tag: number) => void;\n +stopListeningToAnimatedNodeValue: (tag: number) => void;\n +connectAnimatedNodes: (parentTag: number, childTag: number) => void;\n +disconnectAnimatedNodes: (parentTag: number, childTag: number) => void;\n +startAnimatingNode: (\n animationId: number,\n nodeTag: number,\n config: AnimatingNodeConfig,\n endCallback: EndCallback,\n ) => void;\n +stopAnimation: (animationId: number) => void;\n +setAnimatedNodeValue: (nodeTag: number, value: number) => void;\n +setAnimatedNodeOffset: (nodeTag: number, offset: number) => void;\n +flattenAnimatedNodeOffset: (nodeTag: number) => void;\n +extractAnimatedNodeOffset: (nodeTag: number) => void;\n +connectAnimatedNodeToView: (nodeTag: number, viewTag: number) => void;\n +disconnectAnimatedNodeFromView: (nodeTag: number, viewTag: number) => void;\n +restoreDefaultValues: (nodeTag: number) => void;\n +dropAnimatedNode: (tag: number) => void;\n +addAnimatedEventToView: (\n viewTag: number,\n eventName: string,\n eventMapping: EventMapping,\n ) => void;\n +removeAnimatedEventFromView: (\n viewTag: number,\n eventName: string,\n animatedNodeTag: number,\n ) => void;\n\n // Events\n +addListener: (eventName: string) => void;\n +removeListeners: (count: number) => void;\n\n // All of the above in a batched mode\n +queueAndExecuteBatchedOperations?: (operationsAndArgs: Array) => void;\n}\n\nexport default (TurboModuleRegistry.get(\n 'NativeAnimatedTurboModule',\n): ?Spec);\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport type {PlatformConfig} from '../AnimatedPlatformConfig';\nimport type AnimatedValue from '../nodes/AnimatedValue';\n\nimport NativeAnimatedHelper from '../NativeAnimatedHelper';\n\nexport type EndResult = {finished: boolean, ...};\nexport type EndCallback = (result: EndResult) => void;\n\nexport type AnimationConfig = {\n isInteraction?: boolean,\n useNativeDriver: boolean,\n platformConfig?: PlatformConfig,\n onComplete?: ?EndCallback,\n iterations?: number,\n};\n\nlet startNativeAnimationNextId = 1;\n\n// Important note: start() and stop() will only be called at most once.\n// Once an animation has been stopped or finished its course, it will\n// not be reused.\nexport default class Animation {\n __active: boolean;\n __isInteraction: boolean;\n __nativeId: number;\n __onEnd: ?EndCallback;\n __iterations: number;\n start(\n fromValue: number,\n onUpdate: (value: number) => void,\n onEnd: ?EndCallback,\n previousAnimation: ?Animation,\n animatedValue: AnimatedValue,\n ): void {}\n stop(): void {\n if (this.__nativeId) {\n NativeAnimatedHelper.API.stopAnimation(this.__nativeId);\n }\n }\n __getNativeAnimationConfig(): any {\n // Subclasses that have corresponding animation implementation done in native\n // should override this method\n throw new Error('This animation type cannot be offloaded to native');\n }\n // Helper function for subclasses to make sure onEnd is only called once.\n __debouncedOnEnd(result: EndResult): void {\n const onEnd = this.__onEnd;\n this.__onEnd = null;\n onEnd && onEnd(result);\n }\n __startNativeAnimation(animatedValue: AnimatedValue): void {\n const startNativeAnimationWaitId = `${startNativeAnimationNextId}:startAnimation`;\n startNativeAnimationNextId += 1;\n NativeAnimatedHelper.API.setWaitingForIdentifier(\n startNativeAnimationWaitId,\n );\n try {\n const config = this.__getNativeAnimationConfig();\n animatedValue.__makeNative(config.platformConfig);\n this.__nativeId = NativeAnimatedHelper.generateNewAnimationId();\n NativeAnimatedHelper.API.startAnimatingNode(\n this.__nativeId,\n animatedValue.__getNativeTag(),\n config,\n // $FlowFixMe[method-unbinding] added when improving typing for this parameters\n this.__debouncedOnEnd.bind(this),\n );\n } catch (e) {\n throw e;\n } finally {\n NativeAnimatedHelper.API.unsetWaitingForIdentifier(\n startNativeAnimationWaitId,\n );\n }\n }\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport type {PlatformConfig} from '../AnimatedPlatformConfig';\nimport type AnimatedInterpolation from '../nodes/AnimatedInterpolation';\nimport type AnimatedValue from '../nodes/AnimatedValue';\nimport type AnimatedValueXY from '../nodes/AnimatedValueXY';\nimport type {AnimationConfig, EndCallback} from './Animation';\n\nimport NativeAnimatedHelper from '../NativeAnimatedHelper';\nimport AnimatedColor from '../nodes/AnimatedColor';\nimport * as SpringConfig from '../SpringConfig';\nimport Animation from './Animation';\nimport invariant from 'invariant';\n\nexport type SpringAnimationConfig = {\n ...AnimationConfig,\n toValue:\n | number\n | AnimatedValue\n | {\n x: number,\n y: number,\n ...\n }\n | AnimatedValueXY\n | {\n r: number,\n g: number,\n b: number,\n a: number,\n ...\n }\n | AnimatedColor\n | AnimatedInterpolation,\n overshootClamping?: boolean,\n restDisplacementThreshold?: number,\n restSpeedThreshold?: number,\n velocity?:\n | number\n | {\n x: number,\n y: number,\n ...\n },\n bounciness?: number,\n speed?: number,\n tension?: number,\n friction?: number,\n stiffness?: number,\n damping?: number,\n mass?: number,\n delay?: number,\n};\n\nexport type SpringAnimationConfigSingle = {\n ...AnimationConfig,\n toValue: number,\n overshootClamping?: boolean,\n restDisplacementThreshold?: number,\n restSpeedThreshold?: number,\n velocity?: number,\n bounciness?: number,\n speed?: number,\n tension?: number,\n friction?: number,\n stiffness?: number,\n damping?: number,\n mass?: number,\n delay?: number,\n};\n\nexport default class SpringAnimation extends Animation {\n _overshootClamping: boolean;\n _restDisplacementThreshold: number;\n _restSpeedThreshold: number;\n _lastVelocity: number;\n _startPosition: number;\n _lastPosition: number;\n _fromValue: number;\n _toValue: number;\n _stiffness: number;\n _damping: number;\n _mass: number;\n _initialVelocity: number;\n _delay: number;\n _timeout: any;\n _startTime: number;\n _lastTime: number;\n _frameTime: number;\n _onUpdate: (value: number) => void;\n _animationFrame: any;\n _useNativeDriver: boolean;\n _platformConfig: ?PlatformConfig;\n\n constructor(config: SpringAnimationConfigSingle) {\n super();\n\n this._overshootClamping = config.overshootClamping ?? false;\n this._restDisplacementThreshold = config.restDisplacementThreshold ?? 0.001;\n this._restSpeedThreshold = config.restSpeedThreshold ?? 0.001;\n this._initialVelocity = config.velocity ?? 0;\n this._lastVelocity = config.velocity ?? 0;\n this._toValue = config.toValue;\n this._delay = config.delay ?? 0;\n this._useNativeDriver = NativeAnimatedHelper.shouldUseNativeDriver(config);\n this._platformConfig = config.platformConfig;\n this.__isInteraction = config.isInteraction ?? !this._useNativeDriver;\n this.__iterations = config.iterations ?? 1;\n\n if (\n config.stiffness !== undefined ||\n config.damping !== undefined ||\n config.mass !== undefined\n ) {\n invariant(\n config.bounciness === undefined &&\n config.speed === undefined &&\n config.tension === undefined &&\n config.friction === undefined,\n 'You can define one of bounciness/speed, tension/friction, or stiffness/damping/mass, but not more than one',\n );\n this._stiffness = config.stiffness ?? 100;\n this._damping = config.damping ?? 10;\n this._mass = config.mass ?? 1;\n } else if (config.bounciness !== undefined || config.speed !== undefined) {\n // Convert the origami bounciness/speed values to stiffness/damping\n // We assume mass is 1.\n invariant(\n config.tension === undefined &&\n config.friction === undefined &&\n config.stiffness === undefined &&\n config.damping === undefined &&\n config.mass === undefined,\n 'You can define one of bounciness/speed, tension/friction, or stiffness/damping/mass, but not more than one',\n );\n const springConfig = SpringConfig.fromBouncinessAndSpeed(\n config.bounciness ?? 8,\n config.speed ?? 12,\n );\n this._stiffness = springConfig.stiffness;\n this._damping = springConfig.damping;\n this._mass = 1;\n } else {\n // Convert the origami tension/friction values to stiffness/damping\n // We assume mass is 1.\n const springConfig = SpringConfig.fromOrigamiTensionAndFriction(\n config.tension ?? 40,\n config.friction ?? 7,\n );\n this._stiffness = springConfig.stiffness;\n this._damping = springConfig.damping;\n this._mass = 1;\n }\n\n invariant(this._stiffness > 0, 'Stiffness value must be greater than 0');\n invariant(this._damping > 0, 'Damping value must be greater than 0');\n invariant(this._mass > 0, 'Mass value must be greater than 0');\n }\n\n __getNativeAnimationConfig(): {|\n damping: number,\n initialVelocity: number,\n iterations: number,\n mass: number,\n platformConfig: ?PlatformConfig,\n overshootClamping: boolean,\n restDisplacementThreshold: number,\n restSpeedThreshold: number,\n stiffness: number,\n toValue: any,\n type: $TEMPORARY$string<'spring'>,\n |} {\n return {\n type: 'spring',\n overshootClamping: this._overshootClamping,\n restDisplacementThreshold: this._restDisplacementThreshold,\n restSpeedThreshold: this._restSpeedThreshold,\n stiffness: this._stiffness,\n damping: this._damping,\n mass: this._mass,\n initialVelocity: this._initialVelocity ?? this._lastVelocity,\n toValue: this._toValue,\n iterations: this.__iterations,\n platformConfig: this._platformConfig,\n };\n }\n\n start(\n fromValue: number,\n onUpdate: (value: number) => void,\n onEnd: ?EndCallback,\n previousAnimation: ?Animation,\n animatedValue: AnimatedValue,\n ): void {\n this.__active = true;\n this._startPosition = fromValue;\n this._lastPosition = this._startPosition;\n\n this._onUpdate = onUpdate;\n this.__onEnd = onEnd;\n this._lastTime = Date.now();\n this._frameTime = 0.0;\n\n if (previousAnimation instanceof SpringAnimation) {\n const internalState = previousAnimation.getInternalState();\n this._lastPosition = internalState.lastPosition;\n this._lastVelocity = internalState.lastVelocity;\n // Set the initial velocity to the last velocity\n this._initialVelocity = this._lastVelocity;\n this._lastTime = internalState.lastTime;\n }\n\n const start = () => {\n if (this._useNativeDriver) {\n this.__startNativeAnimation(animatedValue);\n } else {\n this.onUpdate();\n }\n };\n\n // If this._delay is more than 0, we start after the timeout.\n if (this._delay) {\n this._timeout = setTimeout(start, this._delay);\n } else {\n start();\n }\n }\n\n getInternalState(): Object {\n return {\n lastPosition: this._lastPosition,\n lastVelocity: this._lastVelocity,\n lastTime: this._lastTime,\n };\n }\n\n /**\n * This spring model is based off of a damped harmonic oscillator\n * (https://en.wikipedia.org/wiki/Harmonic_oscillator#Damped_harmonic_oscillator).\n *\n * We use the closed form of the second order differential equation:\n *\n * x'' + (2ζ⍵_0)x' + ⍵^2x = 0\n *\n * where\n * ⍵_0 = √(k / m) (undamped angular frequency of the oscillator),\n * ζ = c / 2√mk (damping ratio),\n * c = damping constant\n * k = stiffness\n * m = mass\n *\n * The derivation of the closed form is described in detail here:\n * http://planetmath.org/sites/default/files/texpdf/39745.pdf\n *\n * This algorithm happens to match the algorithm used by CASpringAnimation,\n * a QuartzCore (iOS) API that creates spring animations.\n */\n onUpdate(): void {\n // If for some reason we lost a lot of frames (e.g. process large payload or\n // stopped in the debugger), we only advance by 4 frames worth of\n // computation and will continue on the next frame. It's better to have it\n // running at faster speed than jumping to the end.\n const MAX_STEPS = 64;\n let now = Date.now();\n if (now > this._lastTime + MAX_STEPS) {\n now = this._lastTime + MAX_STEPS;\n }\n\n const deltaTime = (now - this._lastTime) / 1000;\n this._frameTime += deltaTime;\n\n const c: number = this._damping;\n const m: number = this._mass;\n const k: number = this._stiffness;\n const v0: number = -this._initialVelocity;\n\n const zeta = c / (2 * Math.sqrt(k * m)); // damping ratio\n const omega0 = Math.sqrt(k / m); // undamped angular frequency of the oscillator (rad/ms)\n const omega1 = omega0 * Math.sqrt(1.0 - zeta * zeta); // exponential decay\n const x0 = this._toValue - this._startPosition; // calculate the oscillation from x0 = 1 to x = 0\n\n let position = 0.0;\n let velocity = 0.0;\n const t = this._frameTime;\n if (zeta < 1) {\n // Under damped\n const envelope = Math.exp(-zeta * omega0 * t);\n position =\n this._toValue -\n envelope *\n (((v0 + zeta * omega0 * x0) / omega1) * Math.sin(omega1 * t) +\n x0 * Math.cos(omega1 * t));\n // This looks crazy -- it's actually just the derivative of the\n // oscillation function\n velocity =\n zeta *\n omega0 *\n envelope *\n ((Math.sin(omega1 * t) * (v0 + zeta * omega0 * x0)) / omega1 +\n x0 * Math.cos(omega1 * t)) -\n envelope *\n (Math.cos(omega1 * t) * (v0 + zeta * omega0 * x0) -\n omega1 * x0 * Math.sin(omega1 * t));\n } else {\n // Critically damped\n const envelope = Math.exp(-omega0 * t);\n position = this._toValue - envelope * (x0 + (v0 + omega0 * x0) * t);\n velocity =\n envelope * (v0 * (t * omega0 - 1) + t * x0 * (omega0 * omega0));\n }\n\n this._lastTime = now;\n this._lastPosition = position;\n this._lastVelocity = velocity;\n\n this._onUpdate(position);\n if (!this.__active) {\n // a listener might have stopped us in _onUpdate\n return;\n }\n\n // Conditions for stopping the spring animation\n let isOvershooting = false;\n if (this._overshootClamping && this._stiffness !== 0) {\n if (this._startPosition < this._toValue) {\n isOvershooting = position > this._toValue;\n } else {\n isOvershooting = position < this._toValue;\n }\n }\n const isVelocity = Math.abs(velocity) <= this._restSpeedThreshold;\n let isDisplacement = true;\n if (this._stiffness !== 0) {\n isDisplacement =\n Math.abs(this._toValue - position) <= this._restDisplacementThreshold;\n }\n\n if (isOvershooting || (isVelocity && isDisplacement)) {\n if (this._stiffness !== 0) {\n // Ensure that we end up with a round value\n this._lastPosition = this._toValue;\n this._lastVelocity = 0;\n this._onUpdate(this._toValue);\n }\n\n this.__debouncedOnEnd({finished: true});\n return;\n }\n // $FlowFixMe[method-unbinding] added when improving typing for this parameters\n this._animationFrame = requestAnimationFrame(this.onUpdate.bind(this));\n }\n\n stop(): void {\n super.stop();\n this.__active = false;\n clearTimeout(this._timeout);\n global.cancelAnimationFrame(this._animationFrame);\n this.__debouncedOnEnd({finished: false});\n }\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport type {NativeColorValue} from '../../StyleSheet/PlatformColorValueTypes';\nimport type {ProcessedColorValue} from '../../StyleSheet/processColor';\nimport type {ColorValue} from '../../StyleSheet/StyleSheet';\nimport type {PlatformConfig} from '../AnimatedPlatformConfig';\n\nimport normalizeColor from '../../StyleSheet/normalizeColor';\nimport {processColorObject} from '../../StyleSheet/PlatformColorValueTypes';\nimport NativeAnimatedHelper from '../NativeAnimatedHelper';\nimport AnimatedValue from './AnimatedValue';\nimport AnimatedWithChildren from './AnimatedWithChildren';\n\nexport type AnimatedColorConfig = $ReadOnly<{\n useNativeDriver: boolean,\n}>;\n\ntype ColorListenerCallback = (value: ColorValue) => mixed;\n\nexport type RgbaValue = {\n +r: number,\n +g: number,\n +b: number,\n +a: number,\n ...\n};\n\ntype RgbaAnimatedValue = {\n +r: AnimatedValue,\n +g: AnimatedValue,\n +b: AnimatedValue,\n +a: AnimatedValue,\n ...\n};\n\nconst NativeAnimatedAPI = NativeAnimatedHelper.API;\n\nconst defaultColor: RgbaValue = {r: 0, g: 0, b: 0, a: 1.0};\nlet _uniqueId = 1;\n\n/* eslint no-bitwise: 0 */\nfunction processColor(\n color?: ?(ColorValue | RgbaValue),\n): ?(RgbaValue | NativeColorValue) {\n if (color === undefined || color === null) {\n return null;\n }\n\n if (isRgbaValue(color)) {\n // $FlowIgnore[incompatible-cast] - Type is verified above\n return (color: RgbaValue);\n }\n\n let normalizedColor: ?ProcessedColorValue = normalizeColor(\n // $FlowIgnore[incompatible-cast] - Type is verified above\n (color: ColorValue),\n );\n if (normalizedColor === undefined || normalizedColor === null) {\n return null;\n }\n\n if (typeof normalizedColor === 'object') {\n const processedColorObj: ?NativeColorValue =\n processColorObject(normalizedColor);\n if (processedColorObj != null) {\n return processedColorObj;\n }\n } else if (typeof normalizedColor === 'number') {\n const r: number = (normalizedColor & 0xff000000) >>> 24;\n const g: number = (normalizedColor & 0x00ff0000) >>> 16;\n const b: number = (normalizedColor & 0x0000ff00) >>> 8;\n const a: number = (normalizedColor & 0x000000ff) / 255;\n\n return {r, g, b, a};\n }\n\n return null;\n}\n\nfunction isRgbaValue(value: any): boolean {\n return (\n value &&\n typeof value.r === 'number' &&\n typeof value.g === 'number' &&\n typeof value.b === 'number' &&\n typeof value.a === 'number'\n );\n}\n\nfunction isRgbaAnimatedValue(value: any): boolean {\n return (\n value &&\n value.r instanceof AnimatedValue &&\n value.g instanceof AnimatedValue &&\n value.b instanceof AnimatedValue &&\n value.a instanceof AnimatedValue\n );\n}\n\nexport default class AnimatedColor extends AnimatedWithChildren {\n r: AnimatedValue;\n g: AnimatedValue;\n b: AnimatedValue;\n a: AnimatedValue;\n nativeColor: ?NativeColorValue;\n _listeners: {\n [key: string]: {\n r: string,\n g: string,\n b: string,\n a: string,\n ...\n },\n ...\n } = {};\n\n constructor(\n valueIn?: ?(RgbaValue | RgbaAnimatedValue | ColorValue),\n config?: ?AnimatedColorConfig,\n ) {\n super();\n let value: RgbaValue | RgbaAnimatedValue | ColorValue =\n valueIn ?? defaultColor;\n if (isRgbaAnimatedValue(value)) {\n // $FlowIgnore[incompatible-cast] - Type is verified above\n const rgbaAnimatedValue: RgbaAnimatedValue = (value: RgbaAnimatedValue);\n this.r = rgbaAnimatedValue.r;\n this.g = rgbaAnimatedValue.g;\n this.b = rgbaAnimatedValue.b;\n this.a = rgbaAnimatedValue.a;\n } else {\n const processedColor: RgbaValue | NativeColorValue =\n // $FlowIgnore[incompatible-cast] - Type is verified above\n processColor((value: ColorValue | RgbaValue)) ?? defaultColor;\n let initColor: RgbaValue = defaultColor;\n if (isRgbaValue(processedColor)) {\n // $FlowIgnore[incompatible-cast] - Type is verified above\n initColor = (processedColor: RgbaValue);\n } else {\n // $FlowIgnore[incompatible-cast] - Type is verified above\n this.nativeColor = (processedColor: NativeColorValue);\n }\n\n this.r = new AnimatedValue(initColor.r);\n this.g = new AnimatedValue(initColor.g);\n this.b = new AnimatedValue(initColor.b);\n this.a = new AnimatedValue(initColor.a);\n }\n if (this.nativeColor || (config && config.useNativeDriver)) {\n this.__makeNative();\n }\n }\n\n /**\n * Directly set the value. This will stop any animations running on the value\n * and update all the bound properties.\n */\n setValue(value: RgbaValue | ColorValue): void {\n let shouldUpdateNodeConfig = false;\n if (this.__isNative) {\n const nativeTag = this.__getNativeTag();\n NativeAnimatedAPI.setWaitingForIdentifier(nativeTag.toString());\n }\n\n const processedColor: RgbaValue | NativeColorValue =\n processColor(value) ?? defaultColor;\n if (isRgbaValue(processedColor)) {\n // $FlowIgnore[incompatible-type] - Type is verified above\n const rgbaValue: RgbaValue = processedColor;\n this.r.setValue(rgbaValue.r);\n this.g.setValue(rgbaValue.g);\n this.b.setValue(rgbaValue.b);\n this.a.setValue(rgbaValue.a);\n if (this.nativeColor != null) {\n this.nativeColor = null;\n shouldUpdateNodeConfig = true;\n }\n } else {\n // $FlowIgnore[incompatible-type] - Type is verified above\n const nativeColor: NativeColorValue = processedColor;\n if (this.nativeColor !== nativeColor) {\n this.nativeColor = nativeColor;\n shouldUpdateNodeConfig = true;\n }\n }\n\n if (this.__isNative) {\n const nativeTag = this.__getNativeTag();\n if (shouldUpdateNodeConfig) {\n NativeAnimatedAPI.updateAnimatedNodeConfig(\n nativeTag,\n this.__getNativeConfig(),\n );\n }\n NativeAnimatedAPI.unsetWaitingForIdentifier(nativeTag.toString());\n }\n }\n\n /**\n * Sets an offset that is applied on top of whatever value is set, whether\n * via `setValue`, an animation, or `Animated.event`. Useful for compensating\n * things like the start of a pan gesture.\n */\n setOffset(offset: RgbaValue): void {\n this.r.setOffset(offset.r);\n this.g.setOffset(offset.g);\n this.b.setOffset(offset.b);\n this.a.setOffset(offset.a);\n }\n\n /**\n * Merges the offset value into the base value and resets the offset to zero.\n * The final output of the value is unchanged.\n */\n flattenOffset(): void {\n this.r.flattenOffset();\n this.g.flattenOffset();\n this.b.flattenOffset();\n this.a.flattenOffset();\n }\n\n /**\n * Sets the offset value to the base value, and resets the base value to\n * zero. The final output of the value is unchanged.\n */\n extractOffset(): void {\n this.r.extractOffset();\n this.g.extractOffset();\n this.b.extractOffset();\n this.a.extractOffset();\n }\n\n /**\n * Adds an asynchronous listener to the value so you can observe updates from\n * animations. This is useful because there is no way to synchronously read\n * the value because it might be driven natively.\n *\n * Returns a string that serves as an identifier for the listener.\n */\n addListener(callback: ColorListenerCallback): string {\n const id = String(_uniqueId++);\n const jointCallback = ({value: number}: any) => {\n callback(this.__getValue());\n };\n this._listeners[id] = {\n r: this.r.addListener(jointCallback),\n g: this.g.addListener(jointCallback),\n b: this.b.addListener(jointCallback),\n a: this.a.addListener(jointCallback),\n };\n return id;\n }\n\n /**\n * Unregister a listener. The `id` param shall match the identifier\n * previously returned by `addListener()`.\n */\n removeListener(id: string): void {\n this.r.removeListener(this._listeners[id].r);\n this.g.removeListener(this._listeners[id].g);\n this.b.removeListener(this._listeners[id].b);\n this.a.removeListener(this._listeners[id].a);\n delete this._listeners[id];\n }\n\n /**\n * Remove all registered listeners.\n */\n removeAllListeners(): void {\n this.r.removeAllListeners();\n this.g.removeAllListeners();\n this.b.removeAllListeners();\n this.a.removeAllListeners();\n this._listeners = {};\n }\n\n /**\n * Stops any running animation or tracking. `callback` is invoked with the\n * final value after stopping the animation, which is useful for updating\n * state to match the animation position with layout.\n */\n stopAnimation(callback?: ColorListenerCallback): void {\n this.r.stopAnimation();\n this.g.stopAnimation();\n this.b.stopAnimation();\n this.a.stopAnimation();\n callback && callback(this.__getValue());\n }\n\n /**\n * Stops any animation and resets the value to its original.\n */\n resetAnimation(callback?: ColorListenerCallback): void {\n this.r.resetAnimation();\n this.g.resetAnimation();\n this.b.resetAnimation();\n this.a.resetAnimation();\n callback && callback(this.__getValue());\n }\n\n __getValue(): ColorValue {\n if (this.nativeColor != null) {\n return this.nativeColor;\n } else {\n return `rgba(${this.r.__getValue()}, ${this.g.__getValue()}, ${this.b.__getValue()}, ${this.a.__getValue()})`;\n }\n }\n\n __attach(): void {\n this.r.__addChild(this);\n this.g.__addChild(this);\n this.b.__addChild(this);\n this.a.__addChild(this);\n super.__attach();\n }\n\n __detach(): void {\n this.r.__removeChild(this);\n this.g.__removeChild(this);\n this.b.__removeChild(this);\n this.a.__removeChild(this);\n super.__detach();\n }\n\n __makeNative(platformConfig: ?PlatformConfig) {\n this.r.__makeNative(platformConfig);\n this.g.__makeNative(platformConfig);\n this.b.__makeNative(platformConfig);\n this.a.__makeNative(platformConfig);\n super.__makeNative(platformConfig);\n }\n\n __getNativeConfig(): {...} {\n return {\n type: 'color',\n r: this.r.__getNativeTag(),\n g: this.g.__getNativeTag(),\n b: this.b.__getNativeTag(),\n a: this.a.__getNativeTag(),\n nativeColor: this.nativeColor,\n };\n }\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport type Animation, {EndCallback} from '../animations/Animation';\nimport type {InterpolationConfigType} from './AnimatedInterpolation';\nimport type AnimatedNode from './AnimatedNode';\nimport type AnimatedTracking from './AnimatedTracking';\n\nimport InteractionManager from '../../Interaction/InteractionManager';\nimport NativeAnimatedHelper from '../NativeAnimatedHelper';\nimport AnimatedInterpolation from './AnimatedInterpolation';\nimport AnimatedWithChildren from './AnimatedWithChildren';\n\nexport type AnimatedValueConfig = $ReadOnly<{\n useNativeDriver: boolean,\n}>;\n\nconst NativeAnimatedAPI = NativeAnimatedHelper.API;\n\n/**\n * Animated works by building a directed acyclic graph of dependencies\n * transparently when you render your Animated components.\n *\n * new Animated.Value(0)\n * .interpolate() .interpolate() new Animated.Value(1)\n * opacity translateY scale\n * style transform\n * View#234 style\n * View#123\n *\n * A) Top Down phase\n * When an Animated.Value is updated, we recursively go down through this\n * graph in order to find leaf nodes: the views that we flag as needing\n * an update.\n *\n * B) Bottom Up phase\n * When a view is flagged as needing an update, we recursively go back up\n * in order to build the new value that it needs. The reason why we need\n * this two-phases process is to deal with composite props such as\n * transform which can receive values from multiple parents.\n */\nfunction _flush(rootNode: AnimatedValue): void {\n const animatedStyles = new Set();\n function findAnimatedStyles(node: AnimatedValue | AnimatedNode) {\n /* $FlowFixMe[prop-missing] (>=0.68.0 site=react_native_fb) This comment\n * suppresses an error found when Flow v0.68 was deployed. To see the error\n * delete this comment and run Flow. */\n if (typeof node.update === 'function') {\n animatedStyles.add(node);\n } else {\n node.__getChildren().forEach(findAnimatedStyles);\n }\n }\n findAnimatedStyles(rootNode);\n // $FlowFixMe[prop-missing]\n animatedStyles.forEach(animatedStyle => animatedStyle.update());\n}\n\n/**\n * Some operations are executed only on batch end, which is _mostly_ scheduled when\n * Animated component props change. For some of the changes which require immediate execution\n * (e.g. setValue), we create a separate batch in case none is scheduled.\n */\nfunction _executeAsAnimatedBatch(id: string, operation: () => void) {\n NativeAnimatedAPI.setWaitingForIdentifier(id);\n operation();\n NativeAnimatedAPI.unsetWaitingForIdentifier(id);\n}\n\n/**\n * Standard value for driving animations. One `Animated.Value` can drive\n * multiple properties in a synchronized fashion, but can only be driven by one\n * mechanism at a time. Using a new mechanism (e.g. starting a new animation,\n * or calling `setValue`) will stop any previous ones.\n *\n * See https://reactnative.dev/docs/animatedvalue\n */\nexport default class AnimatedValue extends AnimatedWithChildren {\n _value: number;\n _startingValue: number;\n _offset: number;\n _animation: ?Animation;\n _tracking: ?AnimatedTracking;\n\n // $FlowFixMe[missing-local-annot]\n constructor(value: number, config?: ?AnimatedValueConfig) {\n super();\n if (typeof value !== 'number') {\n throw new Error('AnimatedValue: Attempting to set value to undefined');\n }\n this._startingValue = this._value = value;\n this._offset = 0;\n this._animation = null;\n if (config && config.useNativeDriver) {\n this.__makeNative();\n }\n }\n\n __detach() {\n if (this.__isNative) {\n NativeAnimatedAPI.getValue(this.__getNativeTag(), value => {\n this._value = value - this._offset;\n });\n }\n this.stopAnimation();\n super.__detach();\n }\n\n __getValue(): number {\n return this._value + this._offset;\n }\n\n /**\n * Directly set the value. This will stop any animations running on the value\n * and update all the bound properties.\n *\n * See https://reactnative.dev/docs/animatedvalue#setvalue\n */\n setValue(value: number): void {\n if (this._animation) {\n this._animation.stop();\n this._animation = null;\n }\n this._updateValue(\n value,\n !this.__isNative /* don't perform a flush for natively driven values */,\n );\n if (this.__isNative) {\n _executeAsAnimatedBatch(this.__getNativeTag().toString(), () =>\n NativeAnimatedAPI.setAnimatedNodeValue(this.__getNativeTag(), value),\n );\n }\n }\n\n /**\n * Sets an offset that is applied on top of whatever value is set, whether via\n * `setValue`, an animation, or `Animated.event`. Useful for compensating\n * things like the start of a pan gesture.\n *\n * See https://reactnative.dev/docs/animatedvalue#setoffset\n */\n setOffset(offset: number): void {\n this._offset = offset;\n if (this.__isNative) {\n NativeAnimatedAPI.setAnimatedNodeOffset(this.__getNativeTag(), offset);\n }\n }\n\n /**\n * Merges the offset value into the base value and resets the offset to zero.\n * The final output of the value is unchanged.\n *\n * See https://reactnative.dev/docs/animatedvalue#flattenoffset\n */\n flattenOffset(): void {\n this._value += this._offset;\n this._offset = 0;\n if (this.__isNative) {\n NativeAnimatedAPI.flattenAnimatedNodeOffset(this.__getNativeTag());\n }\n }\n\n /**\n * Sets the offset value to the base value, and resets the base value to zero.\n * The final output of the value is unchanged.\n *\n * See https://reactnative.dev/docs/animatedvalue#extractoffset\n */\n extractOffset(): void {\n this._offset += this._value;\n this._value = 0;\n if (this.__isNative) {\n NativeAnimatedAPI.extractAnimatedNodeOffset(this.__getNativeTag());\n }\n }\n\n /**\n * Stops any running animation or tracking. `callback` is invoked with the\n * final value after stopping the animation, which is useful for updating\n * state to match the animation position with layout.\n *\n * See https://reactnative.dev/docs/animatedvalue#stopanimation\n */\n stopAnimation(callback?: ?(value: number) => void): void {\n this.stopTracking();\n this._animation && this._animation.stop();\n this._animation = null;\n if (callback) {\n if (this.__isNative) {\n NativeAnimatedAPI.getValue(this.__getNativeTag(), callback);\n } else {\n callback(this.__getValue());\n }\n }\n }\n\n /**\n * Stops any animation and resets the value to its original.\n *\n * See https://reactnative.dev/docs/animatedvalue#resetanimation\n */\n resetAnimation(callback?: ?(value: number) => void): void {\n this.stopAnimation(callback);\n this._value = this._startingValue;\n if (this.__isNative) {\n NativeAnimatedAPI.setAnimatedNodeValue(\n this.__getNativeTag(),\n this._startingValue,\n );\n }\n }\n\n __onAnimatedValueUpdateReceived(value: number): void {\n this._updateValue(value, false /*flush*/);\n }\n\n /**\n * Interpolates the value before updating the property, e.g. mapping 0-1 to\n * 0-10.\n */\n interpolate(\n config: InterpolationConfigType,\n ): AnimatedInterpolation {\n return new AnimatedInterpolation(this, config);\n }\n\n /**\n * Typically only used internally, but could be used by a custom Animation\n * class.\n *\n * See https://reactnative.dev/docs/animatedvalue#animate\n */\n animate(animation: Animation, callback: ?EndCallback): void {\n let handle = null;\n if (animation.__isInteraction) {\n handle = InteractionManager.createInteractionHandle();\n }\n const previousAnimation = this._animation;\n this._animation && this._animation.stop();\n this._animation = animation;\n animation.start(\n this._value,\n value => {\n // Natively driven animations will never call into that callback, therefore we can always\n // pass flush = true to allow the updated value to propagate to native with setNativeProps\n this._updateValue(value, true /* flush */);\n },\n result => {\n this._animation = null;\n if (handle !== null) {\n InteractionManager.clearInteractionHandle(handle);\n }\n callback && callback(result);\n },\n previousAnimation,\n this,\n );\n }\n\n /**\n * Typically only used internally.\n */\n stopTracking(): void {\n this._tracking && this._tracking.__detach();\n this._tracking = null;\n }\n\n /**\n * Typically only used internally.\n */\n track(tracking: AnimatedTracking): void {\n this.stopTracking();\n this._tracking = tracking;\n // Make sure that the tracking animation starts executing\n this._tracking && this._tracking.update();\n }\n\n _updateValue(value: number, flush: boolean): void {\n if (value === undefined) {\n throw new Error('AnimatedValue: Attempting to set value to undefined');\n }\n\n this._value = value;\n if (flush) {\n _flush(this);\n }\n super.__callListeners(this.__getValue());\n }\n\n __getNativeConfig(): Object {\n return {\n type: 'value',\n value: this._value,\n offset: this._offset,\n };\n }\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 * @format\n * @flow strict-local\n */\n\nimport type {Task} from './TaskQueue';\n\nimport EventEmitter from '../vendor/emitter/EventEmitter';\n\nconst BatchedBridge = require('../BatchedBridge/BatchedBridge');\nconst infoLog = require('../Utilities/infoLog');\nconst TaskQueue = require('./TaskQueue');\nconst invariant = require('invariant');\n\nexport type Handle = number;\n\nconst _emitter = new EventEmitter<{\n interactionComplete: [],\n interactionStart: [],\n}>();\n\nconst DEBUG_DELAY: 0 = 0;\nconst DEBUG: false = false;\n\n/**\n * InteractionManager allows long-running work to be scheduled after any\n * interactions/animations have completed. In particular, this allows JavaScript\n * animations to run smoothly.\n *\n * Applications can schedule tasks to run after interactions with the following:\n *\n * ```\n * InteractionManager.runAfterInteractions(() => {\n * // ...long-running synchronous task...\n * });\n * ```\n *\n * Compare this to other scheduling alternatives:\n *\n * - requestAnimationFrame(): for code that animates a view over time.\n * - setImmediate/setTimeout(): run code later, note this may delay animations.\n * - runAfterInteractions(): run code later, without delaying active animations.\n *\n * The touch handling system considers one or more active touches to be an\n * 'interaction' and will delay `runAfterInteractions()` callbacks until all\n * touches have ended or been cancelled.\n *\n * InteractionManager also allows applications to register animations by\n * creating an interaction 'handle' on animation start, and clearing it upon\n * completion:\n *\n * ```\n * var handle = InteractionManager.createInteractionHandle();\n * // run animation... (`runAfterInteractions` tasks are queued)\n * // later, on animation completion:\n * InteractionManager.clearInteractionHandle(handle);\n * // queued tasks run if all handles were cleared\n * ```\n *\n * `runAfterInteractions` takes either a plain callback function, or a\n * `PromiseTask` object with a `gen` method that returns a `Promise`. If a\n * `PromiseTask` is supplied, then it is fully resolved (including asynchronous\n * dependencies that also schedule more tasks via `runAfterInteractions`) before\n * starting on the next task that might have been queued up synchronously\n * earlier.\n *\n * By default, queued tasks are executed together in a loop in one\n * `setImmediate` batch. If `setDeadline` is called with a positive number, then\n * tasks will only be executed until the deadline (in terms of js event loop run\n * time) approaches, at which point execution will yield via setTimeout,\n * allowing events such as touches to start interactions and block queued tasks\n * from executing, making apps more responsive.\n */\nconst InteractionManager = {\n Events: {\n interactionStart: 'interactionStart',\n interactionComplete: 'interactionComplete',\n },\n\n /**\n * Schedule a function to run after all interactions have completed. Returns a cancellable\n * \"promise\".\n */\n runAfterInteractions(task: ?Task): {\n then: (\n onFulfill?: ?(void) => ?(Promise | U),\n onReject?: ?(error: mixed) => ?(Promise | U),\n ) => Promise,\n cancel: () => void,\n ...\n } {\n const tasks: Array = [];\n const promise = new Promise((resolve: () => void) => {\n _scheduleUpdate();\n if (task) {\n tasks.push(task);\n }\n tasks.push({\n run: resolve,\n name: 'resolve ' + ((task && task.name) || '?'),\n });\n _taskQueue.enqueueTasks(tasks);\n });\n return {\n // $FlowFixMe[method-unbinding] added when improving typing for this parameters\n then: promise.then.bind(promise),\n cancel: function () {\n _taskQueue.cancelTasks(tasks);\n },\n };\n },\n\n /**\n * Notify manager that an interaction has started.\n */\n createInteractionHandle(): Handle {\n DEBUG && infoLog('InteractionManager: create interaction handle');\n _scheduleUpdate();\n const handle = ++_inc;\n _addInteractionSet.add(handle);\n return handle;\n },\n\n /**\n * Notify manager that an interaction has completed.\n */\n clearInteractionHandle(handle: Handle) {\n DEBUG && infoLog('InteractionManager: clear interaction handle');\n invariant(!!handle, 'InteractionManager: Must provide a handle to clear.');\n _scheduleUpdate();\n _addInteractionSet.delete(handle);\n _deleteInteractionSet.add(handle);\n },\n\n // $FlowFixMe[method-unbinding] added when improving typing for this parameters\n addListener: (_emitter.addListener.bind(_emitter): $FlowFixMe),\n\n /**\n * A positive number will use setTimeout to schedule any tasks after the\n * eventLoopRunningTime hits the deadline value, otherwise all tasks will be\n * executed in one setImmediate batch (default).\n */\n setDeadline(deadline: number) {\n _deadline = deadline;\n },\n};\n\nconst _interactionSet = new Set();\nconst _addInteractionSet = new Set();\nconst _deleteInteractionSet = new Set();\nconst _taskQueue = new TaskQueue({onMoreTasks: _scheduleUpdate});\nlet _nextUpdateHandle: $FlowFixMe | TimeoutID = 0;\nlet _inc = 0;\nlet _deadline = -1;\n\n/**\n * Schedule an asynchronous update to the interaction state.\n */\nfunction _scheduleUpdate() {\n if (!_nextUpdateHandle) {\n if (_deadline > 0) {\n _nextUpdateHandle = setTimeout(_processUpdate, 0 + DEBUG_DELAY);\n } else {\n _nextUpdateHandle = setImmediate(_processUpdate);\n }\n }\n}\n\n/**\n * Notify listeners, process queue, etc\n */\nfunction _processUpdate() {\n _nextUpdateHandle = 0;\n\n const interactionCount = _interactionSet.size;\n _addInteractionSet.forEach(handle => _interactionSet.add(handle));\n _deleteInteractionSet.forEach(handle => _interactionSet.delete(handle));\n const nextInteractionCount = _interactionSet.size;\n\n if (interactionCount !== 0 && nextInteractionCount === 0) {\n // transition from 1+ --> 0 interactions\n _emitter.emit(InteractionManager.Events.interactionComplete);\n } else if (interactionCount === 0 && nextInteractionCount !== 0) {\n // transition from 0 --> 1+ interactions\n _emitter.emit(InteractionManager.Events.interactionStart);\n }\n\n // process the queue regardless of a transition\n if (nextInteractionCount === 0) {\n while (_taskQueue.hasTasksToProcess()) {\n _taskQueue.processNext();\n if (\n _deadline > 0 &&\n BatchedBridge.getEventLoopRunningTime() >= _deadline\n ) {\n // Hit deadline before processing all tasks, so process more later.\n _scheduleUpdate();\n break;\n }\n }\n }\n _addInteractionSet.clear();\n _deleteInteractionSet.clear();\n}\n\nmodule.exports = InteractionManager;\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 * @format\n * @flow strict\n */\n\n'use strict';\n\nconst infoLog = require('../Utilities/infoLog');\nconst invariant = require('invariant');\n\ntype SimpleTask = {\n name: string,\n run: () => void,\n};\ntype PromiseTask = {\n name: string,\n gen: () => Promise,\n};\nexport type Task = SimpleTask | PromiseTask | (() => void);\n\nconst DEBUG: false = false;\n\n/**\n * TaskQueue - A system for queueing and executing a mix of simple callbacks and\n * trees of dependent tasks based on Promises. No tasks are executed unless\n * `processNext` is called.\n *\n * `enqueue` takes a Task object with either a simple `run` callback, or a\n * `gen` function that returns a `Promise` and puts it in the queue. If a gen\n * function is supplied, then the promise it returns will block execution of\n * tasks already in the queue until it resolves. This can be used to make sure\n * the first task is fully resolved (including asynchronous dependencies that\n * also schedule more tasks via `enqueue`) before starting on the next task.\n * The `onMoreTasks` constructor argument is used to inform the owner that an\n * async task has resolved and that the queue should be processed again.\n *\n * Note: Tasks are only actually executed with explicit calls to `processNext`.\n */\nclass TaskQueue {\n /**\n * TaskQueue instances are self contained and independent, so multiple tasks\n * of varying semantics and priority can operate together.\n *\n * `onMoreTasks` is invoked when `PromiseTask`s resolve if there are more\n * tasks to process.\n */\n constructor({onMoreTasks}: {onMoreTasks: () => void, ...}) {\n this._onMoreTasks = onMoreTasks;\n this._queueStack = [{tasks: [], popable: false}];\n }\n\n /**\n * Add a task to the queue. It is recommended to name your tasks for easier\n * async debugging. Tasks will not be executed until `processNext` is called\n * explicitly.\n */\n enqueue(task: Task): void {\n this._getCurrentQueue().push(task);\n }\n\n enqueueTasks(tasks: Array): void {\n tasks.forEach(task => this.enqueue(task));\n }\n\n cancelTasks(tasksToCancel: Array): void {\n // search through all tasks and remove them.\n this._queueStack = this._queueStack\n .map(queue => ({\n ...queue,\n tasks: queue.tasks.filter(task => tasksToCancel.indexOf(task) === -1),\n }))\n .filter((queue, idx) => queue.tasks.length > 0 || idx === 0);\n }\n\n /**\n * Check to see if `processNext` should be called.\n *\n * @returns {boolean} Returns true if there are tasks that are ready to be\n * processed with `processNext`, or returns false if there are no more tasks\n * to be processed right now, although there may be tasks in the queue that\n * are blocked by earlier `PromiseTask`s that haven't resolved yet.\n * `onMoreTasks` will be called after each `PromiseTask` resolves if there are\n * tasks ready to run at that point.\n */\n hasTasksToProcess(): boolean {\n return this._getCurrentQueue().length > 0;\n }\n\n /**\n * Executes the next task in the queue.\n */\n processNext(): void {\n const queue = this._getCurrentQueue();\n if (queue.length) {\n const task = queue.shift();\n try {\n if (typeof task === 'object' && task.gen) {\n DEBUG && infoLog('TaskQueue: genPromise for task ' + task.name);\n this._genPromise(task);\n } else if (typeof task === 'object' && task.run) {\n DEBUG && infoLog('TaskQueue: run task ' + task.name);\n task.run();\n } else {\n invariant(\n typeof task === 'function',\n 'Expected Function, SimpleTask, or PromiseTask, but got:\\n' +\n JSON.stringify(task, null, 2),\n );\n DEBUG && infoLog('TaskQueue: run anonymous task');\n task();\n }\n } catch (e) {\n e.message =\n 'TaskQueue: Error with task ' + (task.name || '') + ': ' + e.message;\n throw e;\n }\n }\n }\n\n _queueStack: Array<{\n tasks: Array,\n popable: boolean,\n ...\n }>;\n _onMoreTasks: () => void;\n\n _getCurrentQueue(): Array {\n const stackIdx = this._queueStack.length - 1;\n const queue = this._queueStack[stackIdx];\n if (\n queue.popable &&\n queue.tasks.length === 0 &&\n this._queueStack.length > 1\n ) {\n this._queueStack.pop();\n DEBUG &&\n infoLog('TaskQueue: popped queue: ', {\n stackIdx,\n queueStackSize: this._queueStack.length,\n });\n return this._getCurrentQueue();\n } else {\n return queue.tasks;\n }\n }\n\n _genPromise(task: PromiseTask) {\n // Each async task pushes it's own queue onto the queue stack. This\n // effectively defers execution of previously queued tasks until the promise\n // resolves, at which point we allow the new queue to be popped, which\n // happens once it is fully processed.\n this._queueStack.push({tasks: [], popable: false});\n const stackIdx = this._queueStack.length - 1;\n const stackItem = this._queueStack[stackIdx];\n DEBUG && infoLog('TaskQueue: push new queue: ', {stackIdx});\n DEBUG && infoLog('TaskQueue: exec gen task ' + task.name);\n task\n .gen()\n .then(() => {\n DEBUG &&\n infoLog('TaskQueue: onThen for gen task ' + task.name, {\n stackIdx,\n queueStackSize: this._queueStack.length,\n });\n stackItem.popable = true;\n this.hasTasksToProcess() && this._onMoreTasks();\n })\n .catch(ex => {\n setTimeout(() => {\n ex.message = `TaskQueue: Error resolving Promise in task ${task.name}: ${ex.message}`;\n throw ex;\n }, 0);\n });\n }\n}\n\nmodule.exports = TaskQueue;\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 * @flow\n * @format\n */\n\n/* eslint no-bitwise: 0 */\n\n'use strict';\n\nimport type {PlatformConfig} from '../AnimatedPlatformConfig';\nimport type AnimatedNode from './AnimatedNode';\n\nimport normalizeColor from '../../StyleSheet/normalizeColor';\nimport NativeAnimatedHelper from '../NativeAnimatedHelper';\nimport AnimatedWithChildren from './AnimatedWithChildren';\nimport invariant from 'invariant';\n\ntype ExtrapolateType = 'extend' | 'identity' | 'clamp';\n\nexport type InterpolationConfigType = $ReadOnly<{\n inputRange: $ReadOnlyArray,\n outputRange: $ReadOnlyArray,\n easing?: (input: number) => number,\n extrapolate?: ExtrapolateType,\n extrapolateLeft?: ExtrapolateType,\n extrapolateRight?: ExtrapolateType,\n}>;\n\nconst linear = (t: number) => t;\n\n/**\n * Very handy helper to map input ranges to output ranges with an easing\n * function and custom behavior outside of the ranges.\n */\nfunction createInterpolation(\n config: InterpolationConfigType,\n): (input: number) => OutputT {\n if (config.outputRange && typeof config.outputRange[0] === 'string') {\n return (createInterpolationFromStringOutputRange((config: any)): any);\n }\n\n const outputRange: $ReadOnlyArray = (config.outputRange: any);\n\n const inputRange = config.inputRange;\n\n if (__DEV__) {\n checkInfiniteRange('outputRange', outputRange);\n checkInfiniteRange('inputRange', inputRange);\n checkValidInputRange(inputRange);\n\n invariant(\n inputRange.length === outputRange.length,\n 'inputRange (' +\n inputRange.length +\n ') and outputRange (' +\n outputRange.length +\n ') must have the same length',\n );\n }\n\n const easing = config.easing || linear;\n\n let extrapolateLeft: ExtrapolateType = 'extend';\n if (config.extrapolateLeft !== undefined) {\n extrapolateLeft = config.extrapolateLeft;\n } else if (config.extrapolate !== undefined) {\n extrapolateLeft = config.extrapolate;\n }\n\n let extrapolateRight: ExtrapolateType = 'extend';\n if (config.extrapolateRight !== undefined) {\n extrapolateRight = config.extrapolateRight;\n } else if (config.extrapolate !== undefined) {\n extrapolateRight = config.extrapolate;\n }\n\n return input => {\n invariant(\n typeof input === 'number',\n 'Cannot interpolation an input which is not a number',\n );\n\n const range = findRange(input, inputRange);\n return (interpolate(\n input,\n inputRange[range],\n inputRange[range + 1],\n outputRange[range],\n outputRange[range + 1],\n easing,\n extrapolateLeft,\n extrapolateRight,\n ): any);\n };\n}\n\nfunction interpolate(\n input: number,\n inputMin: number,\n inputMax: number,\n outputMin: number,\n outputMax: number,\n easing: (input: number) => number,\n extrapolateLeft: ExtrapolateType,\n extrapolateRight: ExtrapolateType,\n) {\n let result = input;\n\n // Extrapolate\n if (result < inputMin) {\n if (extrapolateLeft === 'identity') {\n return result;\n } else if (extrapolateLeft === 'clamp') {\n result = inputMin;\n } else if (extrapolateLeft === 'extend') {\n // noop\n }\n }\n\n if (result > inputMax) {\n if (extrapolateRight === 'identity') {\n return result;\n } else if (extrapolateRight === 'clamp') {\n result = inputMax;\n } else if (extrapolateRight === 'extend') {\n // noop\n }\n }\n\n if (outputMin === outputMax) {\n return outputMin;\n }\n\n if (inputMin === inputMax) {\n if (input <= inputMin) {\n return outputMin;\n }\n return outputMax;\n }\n\n // Input Range\n if (inputMin === -Infinity) {\n result = -result;\n } else if (inputMax === Infinity) {\n result = result - inputMin;\n } else {\n result = (result - inputMin) / (inputMax - inputMin);\n }\n\n // Easing\n result = easing(result);\n\n // Output Range\n if (outputMin === -Infinity) {\n result = -result;\n } else if (outputMax === Infinity) {\n result = result + outputMin;\n } else {\n result = result * (outputMax - outputMin) + outputMin;\n }\n\n return result;\n}\n\nfunction colorToRgba(input: string): string {\n let normalizedColor = normalizeColor(input);\n if (normalizedColor === null || typeof normalizedColor !== 'number') {\n return input;\n }\n\n normalizedColor = normalizedColor || 0;\n\n const r = (normalizedColor & 0xff000000) >>> 24;\n const g = (normalizedColor & 0x00ff0000) >>> 16;\n const b = (normalizedColor & 0x0000ff00) >>> 8;\n const a = (normalizedColor & 0x000000ff) / 255;\n\n return `rgba(${r}, ${g}, ${b}, ${a})`;\n}\n\nconst stringShapeRegex = /[+-]?(?:\\d+\\.?\\d*|\\.\\d+)(?:[eE][+-]?\\d+)?/g;\n\n/**\n * Supports string shapes by extracting numbers so new values can be computed,\n * and recombines those values into new strings of the same shape. Supports\n * things like:\n *\n * rgba(123, 42, 99, 0.36) // colors\n * -45deg // values with units\n */\nfunction createInterpolationFromStringOutputRange(\n config: InterpolationConfigType,\n): (input: number) => string {\n let outputRange: Array = (config.outputRange: any);\n invariant(outputRange.length >= 2, 'Bad output range');\n outputRange = outputRange.map(colorToRgba);\n checkPattern(outputRange);\n\n // ['rgba(0, 100, 200, 0)', 'rgba(50, 150, 250, 0.5)']\n // ->\n // [\n // [0, 50],\n // [100, 150],\n // [200, 250],\n // [0, 0.5],\n // ]\n /* $FlowFixMe[incompatible-use] (>=0.18.0): `outputRange[0].match()` can\n * return `null`. Need to guard against this possibility. */\n const outputRanges = outputRange[0].match(stringShapeRegex).map(() => []);\n outputRange.forEach(value => {\n /* $FlowFixMe[incompatible-use] (>=0.18.0): `value.match()` can return\n * `null`. Need to guard against this possibility. */\n value.match(stringShapeRegex).forEach((number, i) => {\n outputRanges[i].push(+number);\n });\n });\n\n const interpolations = outputRange[0]\n .match(stringShapeRegex)\n /* $FlowFixMe[incompatible-use] (>=0.18.0): `outputRange[0].match()` can\n * return `null`. Need to guard against this possibility. */\n /* $FlowFixMe[incompatible-call] (>=0.18.0): `outputRange[0].match()` can\n * return `null`. Need to guard against this possibility. */\n .map((value, i) => {\n return createInterpolation({\n ...config,\n outputRange: outputRanges[i],\n });\n });\n\n // rgba requires that the r,g,b are integers.... so we want to round them, but we *dont* want to\n // round the opacity (4th column).\n const shouldRound = isRgbOrRgba(outputRange[0]);\n\n return input => {\n let i = 0;\n // 'rgba(0, 100, 200, 0)'\n // ->\n // 'rgba(${interpolations[0](input)}, ${interpolations[1](input)}, ...'\n return outputRange[0].replace(stringShapeRegex, () => {\n let val = +interpolations[i++](input);\n if (shouldRound) {\n val = i < 4 ? Math.round(val) : Math.round(val * 1000) / 1000;\n }\n return String(val);\n });\n };\n}\n\nfunction isRgbOrRgba(range: string) {\n return typeof range === 'string' && range.startsWith('rgb');\n}\n\nfunction checkPattern(arr: $ReadOnlyArray) {\n const pattern = arr[0].replace(stringShapeRegex, '');\n for (let i = 1; i < arr.length; ++i) {\n invariant(\n pattern === arr[i].replace(stringShapeRegex, ''),\n 'invalid pattern ' + arr[0] + ' and ' + arr[i],\n );\n }\n}\n\nfunction findRange(input: number, inputRange: $ReadOnlyArray) {\n let i;\n for (i = 1; i < inputRange.length - 1; ++i) {\n if (inputRange[i] >= input) {\n break;\n }\n }\n return i - 1;\n}\n\nfunction checkValidInputRange(arr: $ReadOnlyArray) {\n invariant(arr.length >= 2, 'inputRange must have at least 2 elements');\n const message =\n 'inputRange must be monotonically non-decreasing ' + String(arr);\n for (let i = 1; i < arr.length; ++i) {\n invariant(arr[i] >= arr[i - 1], message);\n }\n}\n\nfunction checkInfiniteRange(name: string, arr: $ReadOnlyArray) {\n invariant(arr.length >= 2, name + ' must have at least 2 elements');\n invariant(\n arr.length !== 2 || arr[0] !== -Infinity || arr[1] !== Infinity,\n /* $FlowFixMe[incompatible-type] (>=0.13.0) - In the addition expression\n * below this comment, one or both of the operands may be something that\n * doesn't cleanly convert to a string, like undefined, null, and object,\n * etc. If you really mean this implicit string conversion, you can do\n * something like String(myThing) */\n name + 'cannot be ]-infinity;+infinity[ ' + arr,\n );\n}\n\nexport default class AnimatedInterpolation<\n OutputT: number | string,\n> extends AnimatedWithChildren {\n // Export for testing.\n static __createInterpolation: (\n config: InterpolationConfigType,\n ) => (input: number) => OutputT = createInterpolation;\n\n _parent: AnimatedNode;\n _config: InterpolationConfigType;\n _interpolation: (input: number) => OutputT;\n\n constructor(parent: AnimatedNode, config: InterpolationConfigType) {\n super();\n this._parent = parent;\n this._config = config;\n this._interpolation = createInterpolation(config);\n }\n\n __makeNative(platformConfig: ?PlatformConfig) {\n this._parent.__makeNative(platformConfig);\n super.__makeNative(platformConfig);\n }\n\n __getValue(): number | string {\n const parentValue: number = this._parent.__getValue();\n invariant(\n typeof parentValue === 'number',\n 'Cannot interpolate an input which is not a number.',\n );\n return this._interpolation(parentValue);\n }\n\n interpolate(\n config: InterpolationConfigType,\n ): AnimatedInterpolation {\n return new AnimatedInterpolation(this, config);\n }\n\n __attach(): void {\n this._parent.__addChild(this);\n }\n\n __detach(): void {\n this._parent.__removeChild(this);\n super.__detach();\n }\n\n __transformDataType(range: $ReadOnlyArray): Array {\n return range.map(NativeAnimatedHelper.transformDataType);\n }\n\n __getNativeConfig(): any {\n if (__DEV__) {\n NativeAnimatedHelper.validateInterpolation(this._config);\n }\n\n return {\n inputRange: this._config.inputRange,\n // Only the `outputRange` can contain strings so we don't need to transform `inputRange` here\n outputRange: this.__transformDataType(this._config.outputRange),\n extrapolateLeft:\n this._config.extrapolateLeft || this._config.extrapolate || 'extend',\n extrapolateRight:\n this._config.extrapolateRight || this._config.extrapolate || 'extend',\n type: 'interpolation',\n };\n }\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 * @flow strict-local\n * @format\n */\n\n'use strict';\n\nimport type {PlatformConfig} from '../AnimatedPlatformConfig';\n\nimport NativeAnimatedHelper from '../NativeAnimatedHelper';\nimport AnimatedNode from './AnimatedNode';\n\nexport default class AnimatedWithChildren extends AnimatedNode {\n _children: Array;\n\n constructor() {\n super();\n this._children = [];\n }\n\n __makeNative(platformConfig: ?PlatformConfig) {\n if (!this.__isNative) {\n this.__isNative = true;\n for (const child of this._children) {\n child.__makeNative(platformConfig);\n NativeAnimatedHelper.API.connectAnimatedNodes(\n this.__getNativeTag(),\n child.__getNativeTag(),\n );\n }\n }\n super.__makeNative(platformConfig);\n }\n\n __addChild(child: AnimatedNode): void {\n if (this._children.length === 0) {\n this.__attach();\n }\n this._children.push(child);\n if (this.__isNative) {\n // Only accept \"native\" animated nodes as children\n child.__makeNative(this.__getPlatformConfig());\n NativeAnimatedHelper.API.connectAnimatedNodes(\n this.__getNativeTag(),\n child.__getNativeTag(),\n );\n }\n }\n\n __removeChild(child: AnimatedNode): void {\n const index = this._children.indexOf(child);\n if (index === -1) {\n console.warn(\"Trying to remove a child that doesn't exist\");\n return;\n }\n if (this.__isNative && child.__isNative) {\n NativeAnimatedHelper.API.disconnectAnimatedNodes(\n this.__getNativeTag(),\n child.__getNativeTag(),\n );\n }\n this._children.splice(index, 1);\n if (this._children.length === 0) {\n this.__detach();\n }\n }\n\n __getChildren(): Array {\n return this._children;\n }\n\n __callListeners(value: number): void {\n super.__callListeners(value);\n if (!this.__isNative) {\n for (const child of this._children) {\n // $FlowFixMe[method-unbinding] added when improving typing for this parameters\n if (child.__getValue) {\n child.__callListeners(child.__getValue());\n }\n }\n }\n }\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport type {PlatformConfig} from '../AnimatedPlatformConfig';\n\nimport ReactNativeFeatureFlags from '../../ReactNative/ReactNativeFeatureFlags';\nimport NativeAnimatedHelper from '../NativeAnimatedHelper';\nimport invariant from 'invariant';\n\nconst NativeAnimatedAPI = NativeAnimatedHelper.API;\n\ntype ValueListenerCallback = (state: {value: number, ...}) => mixed;\n\nlet _uniqueId = 1;\n\n// Note(vjeux): this would be better as an interface but flow doesn't\n// support them yet\nexport default class AnimatedNode {\n _listeners: {[key: string]: ValueListenerCallback, ...};\n _platformConfig: ?PlatformConfig;\n __nativeAnimatedValueListener: ?any;\n __attach(): void {}\n __detach(): void {\n if (ReactNativeFeatureFlags.removeListenersOnDetach()) {\n this.removeAllListeners();\n }\n if (this.__isNative && this.__nativeTag != null) {\n NativeAnimatedHelper.API.dropAnimatedNode(this.__nativeTag);\n this.__nativeTag = undefined;\n }\n }\n __getValue(): any {}\n __getAnimatedValue(): any {\n return this.__getValue();\n }\n __addChild(child: AnimatedNode) {}\n __removeChild(child: AnimatedNode) {}\n __getChildren(): Array {\n return [];\n }\n\n /* Methods and props used by native Animated impl */\n __isNative: boolean;\n __nativeTag: ?number;\n __shouldUpdateListenersForNewNativeTag: boolean;\n\n constructor() {\n this._listeners = {};\n }\n\n __makeNative(platformConfig: ?PlatformConfig): void {\n if (!this.__isNative) {\n throw new Error('This node cannot be made a \"native\" animated node');\n }\n\n this._platformConfig = platformConfig;\n if (this.hasListeners()) {\n this._startListeningToNativeValueUpdates();\n }\n }\n\n /**\n * Adds an asynchronous listener to the value so you can observe updates from\n * animations. This is useful because there is no way to\n * synchronously read the value because it might be driven natively.\n *\n * See https://reactnative.dev/docs/animatedvalue#addlistener\n */\n addListener(callback: (value: any) => mixed): string {\n const id = String(_uniqueId++);\n this._listeners[id] = callback;\n if (this.__isNative) {\n this._startListeningToNativeValueUpdates();\n }\n return id;\n }\n\n /**\n * Unregister a listener. The `id` param shall match the identifier\n * previously returned by `addListener()`.\n *\n * See https://reactnative.dev/docs/animatedvalue#removelistener\n */\n removeListener(id: string): void {\n delete this._listeners[id];\n if (this.__isNative && !this.hasListeners()) {\n this._stopListeningForNativeValueUpdates();\n }\n }\n\n /**\n * Remove all registered listeners.\n *\n * See https://reactnative.dev/docs/animatedvalue#removealllisteners\n */\n removeAllListeners(): void {\n this._listeners = {};\n if (this.__isNative) {\n this._stopListeningForNativeValueUpdates();\n }\n }\n\n hasListeners(): boolean {\n return !!Object.keys(this._listeners).length;\n }\n\n _startListeningToNativeValueUpdates() {\n if (\n this.__nativeAnimatedValueListener &&\n !this.__shouldUpdateListenersForNewNativeTag\n ) {\n return;\n }\n\n if (this.__shouldUpdateListenersForNewNativeTag) {\n this.__shouldUpdateListenersForNewNativeTag = false;\n this._stopListeningForNativeValueUpdates();\n }\n\n NativeAnimatedAPI.startListeningToAnimatedNodeValue(this.__getNativeTag());\n this.__nativeAnimatedValueListener =\n NativeAnimatedHelper.nativeEventEmitter.addListener(\n 'onAnimatedValueUpdate',\n data => {\n if (data.tag !== this.__getNativeTag()) {\n return;\n }\n this.__onAnimatedValueUpdateReceived(data.value);\n },\n );\n }\n\n __onAnimatedValueUpdateReceived(value: number) {\n this.__callListeners(value);\n }\n\n __callListeners(value: number): void {\n for (const key in this._listeners) {\n this._listeners[key]({value});\n }\n }\n\n _stopListeningForNativeValueUpdates() {\n if (!this.__nativeAnimatedValueListener) {\n return;\n }\n\n this.__nativeAnimatedValueListener.remove();\n this.__nativeAnimatedValueListener = null;\n NativeAnimatedAPI.stopListeningToAnimatedNodeValue(this.__getNativeTag());\n }\n\n __getNativeTag(): number {\n NativeAnimatedHelper.assertNativeAnimatedModule();\n invariant(\n this.__isNative,\n 'Attempt to get native tag from node not marked as \"native\"',\n );\n\n const nativeTag =\n this.__nativeTag ?? NativeAnimatedHelper.generateNewNodeTag();\n\n if (this.__nativeTag == null) {\n this.__nativeTag = nativeTag;\n const config = this.__getNativeConfig();\n if (this._platformConfig) {\n config.platformConfig = this._platformConfig;\n }\n NativeAnimatedHelper.API.createAnimatedNode(nativeTag, config);\n this.__shouldUpdateListenersForNewNativeTag = true;\n }\n\n return nativeTag;\n }\n __getNativeConfig(): Object {\n throw new Error(\n 'This JS animated node type cannot be used as native animated node',\n );\n }\n toJSON(): any {\n return this.__getValue();\n }\n\n __getPlatformConfig(): ?PlatformConfig {\n return this._platformConfig;\n }\n __setPlatformConfig(platformConfig: ?PlatformConfig) {\n this._platformConfig = platformConfig;\n }\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 * @format\n * @flow strict\n */\n\n'use strict';\n\ntype SpringConfigType = {\n stiffness: number,\n damping: number,\n ...\n};\n\nfunction stiffnessFromOrigamiValue(oValue: number) {\n return (oValue - 30) * 3.62 + 194;\n}\n\nfunction dampingFromOrigamiValue(oValue: number) {\n return (oValue - 8) * 3 + 25;\n}\n\nexport function fromOrigamiTensionAndFriction(\n tension: number,\n friction: number,\n): SpringConfigType {\n return {\n stiffness: stiffnessFromOrigamiValue(tension),\n damping: dampingFromOrigamiValue(friction),\n };\n}\n\nexport function fromBouncinessAndSpeed(\n bounciness: number,\n speed: number,\n): SpringConfigType {\n function normalize(value: number, startValue: number, endValue: number) {\n return (value - startValue) / (endValue - startValue);\n }\n\n function projectNormal(n: number, start: number, end: number) {\n return start + n * (end - start);\n }\n\n function linearInterpolation(t: number, start: number, end: number) {\n return t * end + (1 - t) * start;\n }\n\n function quadraticOutInterpolation(t: number, start: number, end: number) {\n return linearInterpolation(2 * t - t * t, start, end);\n }\n\n function b3Friction1(x: number) {\n return 0.0007 * Math.pow(x, 3) - 0.031 * Math.pow(x, 2) + 0.64 * x + 1.28;\n }\n\n function b3Friction2(x: number) {\n return 0.000044 * Math.pow(x, 3) - 0.006 * Math.pow(x, 2) + 0.36 * x + 2;\n }\n\n function b3Friction3(x: number) {\n return (\n 0.00000045 * Math.pow(x, 3) -\n 0.000332 * Math.pow(x, 2) +\n 0.1078 * x +\n 5.84\n );\n }\n\n function b3Nobounce(tension: number) {\n if (tension <= 18) {\n return b3Friction1(tension);\n } else if (tension > 18 && tension <= 44) {\n return b3Friction2(tension);\n } else {\n return b3Friction3(tension);\n }\n }\n\n let b = normalize(bounciness / 1.7, 0, 20);\n b = projectNormal(b, 0, 0.8);\n const s = normalize(speed / 1.7, 0, 20);\n const bouncyTension = projectNormal(s, 0.5, 200);\n const bouncyFriction = quadraticOutInterpolation(\n b,\n b3Nobounce(bouncyTension),\n 0.01,\n );\n\n return {\n stiffness: stiffnessFromOrigamiValue(bouncyTension),\n damping: dampingFromOrigamiValue(bouncyFriction),\n };\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport type {PlatformConfig} from '../AnimatedPlatformConfig';\nimport type {RgbaValue} from '../nodes/AnimatedColor';\nimport type AnimatedInterpolation from '../nodes/AnimatedInterpolation';\nimport type AnimatedValue from '../nodes/AnimatedValue';\nimport type AnimatedValueXY from '../nodes/AnimatedValueXY';\nimport type {AnimationConfig, EndCallback} from './Animation';\n\nimport NativeAnimatedHelper from '../NativeAnimatedHelper';\nimport AnimatedColor from '../nodes/AnimatedColor';\nimport Animation from './Animation';\n\nexport type TimingAnimationConfig = $ReadOnly<{\n ...AnimationConfig,\n toValue:\n | number\n | AnimatedValue\n | {\n x: number,\n y: number,\n ...\n }\n | AnimatedValueXY\n | RgbaValue\n | AnimatedColor\n | AnimatedInterpolation,\n easing?: (value: number) => number,\n duration?: number,\n delay?: number,\n}>;\n\nexport type TimingAnimationConfigSingle = $ReadOnly<{\n ...AnimationConfig,\n toValue: number,\n easing?: (value: number) => number,\n duration?: number,\n delay?: number,\n}>;\n\nlet _easeInOut;\nfunction easeInOut() {\n if (!_easeInOut) {\n const Easing = require('../Easing').default;\n _easeInOut = Easing.inOut(Easing.ease);\n }\n return _easeInOut;\n}\n\nexport default class TimingAnimation extends Animation {\n _startTime: number;\n _fromValue: number;\n _toValue: number;\n _duration: number;\n _delay: number;\n _easing: (value: number) => number;\n _onUpdate: (value: number) => void;\n _animationFrame: any;\n _timeout: any;\n _useNativeDriver: boolean;\n _platformConfig: ?PlatformConfig;\n\n constructor(config: TimingAnimationConfigSingle) {\n super();\n this._toValue = config.toValue;\n this._easing = config.easing ?? easeInOut();\n this._duration = config.duration ?? 500;\n this._delay = config.delay ?? 0;\n this.__iterations = config.iterations ?? 1;\n this._useNativeDriver = NativeAnimatedHelper.shouldUseNativeDriver(config);\n this._platformConfig = config.platformConfig;\n this.__isInteraction = config.isInteraction ?? !this._useNativeDriver;\n }\n\n __getNativeAnimationConfig(): any {\n const frameDuration = 1000.0 / 60.0;\n const frames = [];\n const numFrames = Math.round(this._duration / frameDuration);\n for (let frame = 0; frame < numFrames; frame++) {\n frames.push(this._easing(frame / numFrames));\n }\n frames.push(this._easing(1));\n return {\n type: 'frames',\n frames,\n toValue: this._toValue,\n iterations: this.__iterations,\n platformConfig: this._platformConfig,\n };\n }\n\n start(\n fromValue: number,\n onUpdate: (value: number) => void,\n onEnd: ?EndCallback,\n previousAnimation: ?Animation,\n animatedValue: AnimatedValue,\n ): void {\n this.__active = true;\n this._fromValue = fromValue;\n this._onUpdate = onUpdate;\n this.__onEnd = onEnd;\n\n const start = () => {\n // Animations that sometimes have 0 duration and sometimes do not\n // still need to use the native driver when duration is 0 so as to\n // not cause intermixed JS and native animations.\n if (this._duration === 0 && !this._useNativeDriver) {\n this._onUpdate(this._toValue);\n this.__debouncedOnEnd({finished: true});\n } else {\n this._startTime = Date.now();\n if (this._useNativeDriver) {\n this.__startNativeAnimation(animatedValue);\n } else {\n this._animationFrame = requestAnimationFrame(\n // $FlowFixMe[method-unbinding] added when improving typing for this parameters\n this.onUpdate.bind(this),\n );\n }\n }\n };\n if (this._delay) {\n this._timeout = setTimeout(start, this._delay);\n } else {\n start();\n }\n }\n\n onUpdate(): void {\n const now = Date.now();\n if (now >= this._startTime + this._duration) {\n if (this._duration === 0) {\n this._onUpdate(this._toValue);\n } else {\n this._onUpdate(\n this._fromValue + this._easing(1) * (this._toValue - this._fromValue),\n );\n }\n this.__debouncedOnEnd({finished: true});\n return;\n }\n\n this._onUpdate(\n this._fromValue +\n this._easing((now - this._startTime) / this._duration) *\n (this._toValue - this._fromValue),\n );\n if (this.__active) {\n // $FlowFixMe[method-unbinding] added when improving typing for this parameters\n this._animationFrame = requestAnimationFrame(this.onUpdate.bind(this));\n }\n }\n\n stop(): void {\n super.stop();\n this.__active = false;\n clearTimeout(this._timeout);\n global.cancelAnimationFrame(this._animationFrame);\n this.__debouncedOnEnd({finished: false});\n }\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 * @format\n * @flow strict\n */\n\n'use strict';\n\nlet ease;\n\n/**\n * The `Easing` module implements common easing functions. This module is used\n * by [Animate.timing()](docs/animate.html#timing) to convey physically\n * believable motion in animations.\n *\n * You can find a visualization of some common easing functions at\n * http://easings.net/\n *\n * ### Predefined animations\n *\n * The `Easing` module provides several predefined animations through the\n * following methods:\n *\n * - [`back`](docs/easing.html#back) provides a simple animation where the\n * object goes slightly back before moving forward\n * - [`bounce`](docs/easing.html#bounce) provides a bouncing animation\n * - [`ease`](docs/easing.html#ease) provides a simple inertial animation\n * - [`elastic`](docs/easing.html#elastic) provides a simple spring interaction\n *\n * ### Standard functions\n *\n * Three standard easing functions are provided:\n *\n * - [`linear`](docs/easing.html#linear)\n * - [`quad`](docs/easing.html#quad)\n * - [`cubic`](docs/easing.html#cubic)\n *\n * The [`poly`](docs/easing.html#poly) function can be used to implement\n * quartic, quintic, and other higher power functions.\n *\n * ### Additional functions\n *\n * Additional mathematical functions are provided by the following methods:\n *\n * - [`bezier`](docs/easing.html#bezier) provides a cubic bezier curve\n * - [`circle`](docs/easing.html#circle) provides a circular function\n * - [`sin`](docs/easing.html#sin) provides a sinusoidal function\n * - [`exp`](docs/easing.html#exp) provides an exponential function\n *\n * The following helpers are used to modify other easing functions.\n *\n * - [`in`](docs/easing.html#in) runs an easing function forwards\n * - [`inOut`](docs/easing.html#inout) makes any easing function symmetrical\n * - [`out`](docs/easing.html#out) runs an easing function backwards\n */\nconst Easing = {\n /**\n * A stepping function, returns 1 for any positive value of `n`.\n */\n step0(n: number): number {\n return n > 0 ? 1 : 0;\n },\n\n /**\n * A stepping function, returns 1 if `n` is greater than or equal to 1.\n */\n step1(n: number): number {\n return n >= 1 ? 1 : 0;\n },\n\n /**\n * A linear function, `f(t) = t`. Position correlates to elapsed time one to\n * one.\n *\n * http://cubic-bezier.com/#0,0,1,1\n */\n linear(t: number): number {\n return t;\n },\n\n /**\n * A simple inertial interaction, similar to an object slowly accelerating to\n * speed.\n *\n * http://cubic-bezier.com/#.42,0,1,1\n */\n ease(t: number): number {\n if (!ease) {\n ease = Easing.bezier(0.42, 0, 1, 1);\n }\n return ease(t);\n },\n\n /**\n * A quadratic function, `f(t) = t * t`. Position equals the square of elapsed\n * time.\n *\n * http://easings.net/#easeInQuad\n */\n quad(t: number): number {\n return t * t;\n },\n\n /**\n * A cubic function, `f(t) = t * t * t`. Position equals the cube of elapsed\n * time.\n *\n * http://easings.net/#easeInCubic\n */\n cubic(t: number): number {\n return t * t * t;\n },\n\n /**\n * A power function. Position is equal to the Nth power of elapsed time.\n *\n * n = 4: http://easings.net/#easeInQuart\n * n = 5: http://easings.net/#easeInQuint\n */\n poly(n: number): (t: number) => number {\n return (t: number) => Math.pow(t, n);\n },\n\n /**\n * A sinusoidal function.\n *\n * http://easings.net/#easeInSine\n */\n sin(t: number): number {\n return 1 - Math.cos((t * Math.PI) / 2);\n },\n\n /**\n * A circular function.\n *\n * http://easings.net/#easeInCirc\n */\n circle(t: number): number {\n return 1 - Math.sqrt(1 - t * t);\n },\n\n /**\n * An exponential function.\n *\n * http://easings.net/#easeInExpo\n */\n exp(t: number): number {\n return Math.pow(2, 10 * (t - 1));\n },\n\n /**\n * A simple elastic interaction, similar to a spring oscillating back and\n * forth.\n *\n * Default bounciness is 1, which overshoots a little bit once. 0 bounciness\n * doesn't overshoot at all, and bounciness of N > 1 will overshoot about N\n * times.\n *\n * http://easings.net/#easeInElastic\n */\n elastic(bounciness: number = 1): (t: number) => number {\n const p = bounciness * Math.PI;\n return t => 1 - Math.pow(Math.cos((t * Math.PI) / 2), 3) * Math.cos(t * p);\n },\n\n /**\n * Use with `Animated.parallel()` to create a simple effect where the object\n * animates back slightly as the animation starts.\n *\n * https://easings.net/#easeInBack\n */\n back(s: number = 1.70158): (t: number) => number {\n return t => t * t * ((s + 1) * t - s);\n },\n\n /**\n * Provides a simple bouncing effect.\n *\n * http://easings.net/#easeInBounce\n */\n bounce(t: number): number {\n if (t < 1 / 2.75) {\n return 7.5625 * t * t;\n }\n\n if (t < 2 / 2.75) {\n const t2 = t - 1.5 / 2.75;\n return 7.5625 * t2 * t2 + 0.75;\n }\n\n if (t < 2.5 / 2.75) {\n const t2 = t - 2.25 / 2.75;\n return 7.5625 * t2 * t2 + 0.9375;\n }\n\n const t2 = t - 2.625 / 2.75;\n return 7.5625 * t2 * t2 + 0.984375;\n },\n\n /**\n * Provides a cubic bezier curve, equivalent to CSS Transitions'\n * `transition-timing-function`.\n *\n * A useful tool to visualize cubic bezier curves can be found at\n * http://cubic-bezier.com/\n */\n bezier(\n x1: number,\n y1: number,\n x2: number,\n y2: number,\n ): (t: number) => number {\n const _bezier = require('./bezier').default;\n return _bezier(x1, y1, x2, y2);\n },\n\n /**\n * Runs an easing function forwards.\n */\n in(easing: (t: number) => number): (t: number) => number {\n return easing;\n },\n\n /**\n * Runs an easing function backwards.\n */\n out(easing: (t: number) => number): (t: number) => number {\n return t => 1 - easing(1 - t);\n },\n\n /**\n * Makes any easing function symmetrical. The easing function will run\n * forwards for half of the duration, then backwards for the rest of the\n * duration.\n */\n inOut(easing: (t: number) => number): (t: number) => number {\n return t => {\n if (t < 0.5) {\n return easing(t * 2) / 2;\n }\n return 1 - easing((1 - t) * 2) / 2;\n };\n },\n};\n\nexport default Easing;\n","/**\n * Portions 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 * @flow strict\n * @format\n */\n\n/**\n * BezierEasing - use bezier curve for transition easing function\n * https://github.com/gre/bezier-easing\n * @copyright 2014-2015 Gaëtan Renaudeau. MIT License.\n */\n\n'use strict';\n\n// These values are established by empiricism with tests (tradeoff: performance VS precision)\nconst NEWTON_ITERATIONS = 4;\nconst NEWTON_MIN_SLOPE = 0.001;\nconst SUBDIVISION_PRECISION = 0.0000001;\nconst SUBDIVISION_MAX_ITERATIONS = 10;\n\nconst kSplineTableSize = 11;\nconst kSampleStepSize = 1.0 / (kSplineTableSize - 1.0);\n\nconst float32ArraySupported = typeof Float32Array === 'function';\n\nfunction A(aA1: number, aA2: number) {\n return 1.0 - 3.0 * aA2 + 3.0 * aA1;\n}\nfunction B(aA1: number, aA2: number) {\n return 3.0 * aA2 - 6.0 * aA1;\n}\nfunction C(aA1: number) {\n return 3.0 * aA1;\n}\n\n// Returns x(t) given t, x1, and x2, or y(t) given t, y1, and y2.\nfunction calcBezier(aT: number, aA1: number, aA2: number) {\n return ((A(aA1, aA2) * aT + B(aA1, aA2)) * aT + C(aA1)) * aT;\n}\n\n// Returns dx/dt given t, x1, and x2, or dy/dt given t, y1, and y2.\nfunction getSlope(aT: number, aA1: number, aA2: number) {\n return 3.0 * A(aA1, aA2) * aT * aT + 2.0 * B(aA1, aA2) * aT + C(aA1);\n}\n\nfunction binarySubdivide(\n aX: number,\n _aA: number,\n _aB: number,\n mX1: number,\n mX2: number,\n) {\n let currentX,\n currentT,\n i = 0,\n aA = _aA,\n aB = _aB;\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 (\n Math.abs(currentX) > SUBDIVISION_PRECISION &&\n ++i < SUBDIVISION_MAX_ITERATIONS\n );\n return currentT;\n}\n\nfunction newtonRaphsonIterate(\n aX: number,\n _aGuessT: number,\n mX1: number,\n mX2: number,\n) {\n let aGuessT = _aGuessT;\n for (let i = 0; i < NEWTON_ITERATIONS; ++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\nexport default function bezier(\n mX1: number,\n mY1: number,\n mX2: number,\n mY2: number,\n): (x: number) => number {\n if (!(mX1 >= 0 && mX1 <= 1 && mX2 >= 0 && mX2 <= 1)) {\n throw new Error('bezier x values must be in [0, 1] range');\n }\n\n // Precompute samples table\n const sampleValues = float32ArraySupported\n ? new Float32Array(kSplineTableSize)\n : new Array(kSplineTableSize);\n if (mX1 !== mY1 || mX2 !== mY2) {\n for (let i = 0; i < kSplineTableSize; ++i) {\n sampleValues[i] = calcBezier(i * kSampleStepSize, mX1, mX2);\n }\n }\n\n function getTForX(aX: number) {\n let intervalStart = 0.0;\n let currentSample = 1;\n const lastSample = kSplineTableSize - 1;\n\n for (\n ;\n currentSample !== lastSample && sampleValues[currentSample] <= aX;\n ++currentSample\n ) {\n intervalStart += kSampleStepSize;\n }\n --currentSample;\n\n // Interpolate to provide an initial guess for t\n const dist =\n (aX - sampleValues[currentSample]) /\n (sampleValues[currentSample + 1] - sampleValues[currentSample]);\n const guessForT = intervalStart + dist * kSampleStepSize;\n\n const initialSlope = getSlope(guessForT, mX1, mX2);\n if (initialSlope >= NEWTON_MIN_SLOPE) {\n return newtonRaphsonIterate(aX, guessForT, mX1, mX2);\n } else if (initialSlope === 0.0) {\n return guessForT;\n } else {\n return binarySubdivide(\n aX,\n intervalStart,\n intervalStart + kSampleStepSize,\n mX1,\n mX2,\n );\n }\n }\n\n return function BezierEasing(x: number): number {\n if (mX1 === mY1 && mX2 === mY2) {\n return x; // linear\n }\n // Because JavaScript number are imprecise, we should guarantee the extremes are right.\n if (x === 0) {\n return 0;\n }\n if (x === 1) {\n return 1;\n }\n return calcBezier(getTForX(x), mY1, mY2);\n };\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport View from '../Components/View/View';\nimport setAndForwardRef from '../Utilities/setAndForwardRef';\nimport {AnimatedEvent} from './AnimatedEvent';\nimport * as createAnimatedComponentInjection from './createAnimatedComponentInjection';\nimport NativeAnimatedHelper from './NativeAnimatedHelper';\nimport AnimatedProps from './nodes/AnimatedProps';\nimport invariant from 'invariant';\nimport * as React from 'react';\n\nlet animatedComponentNextId = 1;\n\nexport type AnimatedComponentType<\n -Props: {+[string]: mixed, ...},\n +Instance = mixed,\n> = React.AbstractComponent<\n $ObjMap<\n Props &\n $ReadOnly<{\n passthroughAnimatedPropExplicitValues?: React.ElementConfig<\n typeof View,\n >,\n }>,\n () => any,\n >,\n Instance,\n>;\n\nfunction createAnimatedComponent(\n Component: React.AbstractComponent,\n): AnimatedComponentType {\n invariant(\n typeof Component !== 'function' ||\n (Component.prototype && Component.prototype.isReactComponent),\n '`createAnimatedComponent` does not support stateless functional components; ' +\n 'use a class component instead.',\n );\n\n class AnimatedComponent extends React.Component {\n _component: any; // TODO T53738161: flow type this, and the whole file\n _invokeAnimatedPropsCallbackOnMount: boolean = false;\n _prevComponent: any;\n _propsAnimated: AnimatedProps;\n _eventDetachers: Array = [];\n\n // Only to be used in this file, and only in Fabric.\n _animatedComponentId: string = `${animatedComponentNextId++}:animatedComponent`;\n\n _attachNativeEvents() {\n // Make sure to get the scrollable node for components that implement\n // `ScrollResponder.Mixin`.\n const scrollableNode = this._component?.getScrollableNode\n ? this._component.getScrollableNode()\n : this._component;\n\n for (const key in this.props) {\n const prop = this.props[key];\n if (prop instanceof AnimatedEvent && prop.__isNative) {\n prop.__attach(scrollableNode, key);\n this._eventDetachers.push(() => prop.__detach(scrollableNode, key));\n }\n }\n }\n\n _detachNativeEvents() {\n this._eventDetachers.forEach(remove => remove());\n this._eventDetachers = [];\n }\n\n _isFabric = (): boolean => {\n // When called during the first render, `_component` is always null.\n // Therefore, even if a component is rendered in Fabric, we can't detect\n // that until ref is set, which happens sometime after the first render.\n // In cases where this value switching between \"false\" and \"true\" on Fabric\n // causes issues, add an additional check for _component nullity.\n if (this._component == null) {\n return false;\n }\n return (\n // eslint-disable-next-line dot-notation\n this._component['_internalInstanceHandle']?.stateNode?.canonical !=\n null ||\n // Some components have a setNativeProps function but aren't a host component\n // such as lists like FlatList and SectionList. These should also use\n // forceUpdate in Fabric since setNativeProps doesn't exist on the underlying\n // host component. This crazy hack is essentially special casing those lists and\n // ScrollView itself to use forceUpdate in Fabric.\n // If these components end up using forwardRef then these hacks can go away\n // as this._component would actually be the underlying host component and the above check\n // would be sufficient.\n (this._component.getNativeScrollRef != null &&\n this._component.getNativeScrollRef() != null &&\n // eslint-disable-next-line dot-notation\n this._component.getNativeScrollRef()['_internalInstanceHandle']\n ?.stateNode?.canonical != null) ||\n (this._component.getScrollResponder != null &&\n this._component.getScrollResponder() != null &&\n this._component.getScrollResponder().getNativeScrollRef != null &&\n this._component.getScrollResponder().getNativeScrollRef() != null &&\n this._component.getScrollResponder().getNativeScrollRef()[\n // eslint-disable-next-line dot-notation\n '_internalInstanceHandle'\n ]?.stateNode?.canonical != null)\n );\n };\n\n _waitForUpdate = (): void => {\n if (this._isFabric()) {\n NativeAnimatedHelper.API.setWaitingForIdentifier(\n this._animatedComponentId,\n );\n }\n };\n\n _markUpdateComplete = (): void => {\n if (this._isFabric()) {\n NativeAnimatedHelper.API.unsetWaitingForIdentifier(\n this._animatedComponentId,\n );\n }\n };\n\n // The system is best designed when setNativeProps is implemented. It is\n // able to avoid re-rendering and directly set the attributes that changed.\n // However, setNativeProps can only be implemented on leaf native\n // components. If you want to animate a composite component, you need to\n // re-render it. In this case, we have a fallback that uses forceUpdate.\n // This fallback is also called in Fabric.\n _animatedPropsCallback = (): void => {\n if (this._component == null) {\n // AnimatedProps is created in will-mount because it's used in render.\n // But this callback may be invoked before mount in async mode,\n // In which case we should defer the setNativeProps() call.\n // React may throw away uncommitted work in async mode,\n // So a deferred call won't always be invoked.\n this._invokeAnimatedPropsCallbackOnMount = true;\n } else if (\n process.env.NODE_ENV === 'test' ||\n // For animating properties of non-leaf/non-native components\n typeof this._component.setNativeProps !== 'function' ||\n // In Fabric, force animations to go through forceUpdate and skip setNativeProps\n this._isFabric()\n ) {\n this.forceUpdate();\n } else if (!this._propsAnimated.__isNative) {\n this._component.setNativeProps(\n this._propsAnimated.__getAnimatedValue(),\n );\n } else {\n throw new Error(\n 'Attempting to run JS driven animation on animated ' +\n 'node that has been moved to \"native\" earlier by starting an ' +\n 'animation with `useNativeDriver: true`',\n );\n }\n };\n\n _attachProps(nextProps: any) {\n const oldPropsAnimated = this._propsAnimated;\n\n this._propsAnimated = new AnimatedProps(\n nextProps,\n this._animatedPropsCallback,\n );\n this._propsAnimated.__attach();\n\n // When you call detach, it removes the element from the parent list\n // of children. If it goes to 0, then the parent also detaches itself\n // and so on.\n // An optimization is to attach the new elements and THEN detach the old\n // ones instead of detaching and THEN attaching.\n // This way the intermediate state isn't to go to 0 and trigger\n // this expensive recursive detaching to then re-attach everything on\n // the very next operation.\n if (oldPropsAnimated) {\n oldPropsAnimated.__restoreDefaultValues();\n oldPropsAnimated.__detach();\n }\n }\n\n _setComponentRef: (ref: React.ElementRef) => void = setAndForwardRef({\n getForwardedRef: () => this.props.forwardedRef,\n setLocalRef: ref => {\n this._prevComponent = this._component;\n this._component = ref;\n },\n });\n\n render(): React.Node {\n const animatedProps = this._propsAnimated.__getValue() || {};\n\n const {style = {}, ...props} = animatedProps;\n const {style: passthruStyle = {}, ...passthruProps} =\n this.props.passthroughAnimatedPropExplicitValues || {};\n const mergedStyle = {...style, ...passthruStyle};\n\n // Force `collapsable` to be false so that native view is not flattened.\n // Flattened views cannot be accurately referenced by a native driver.\n return (\n \n );\n }\n\n UNSAFE_componentWillMount() {\n this._waitForUpdate();\n this._attachProps(this.props);\n }\n\n componentDidMount() {\n if (this._invokeAnimatedPropsCallbackOnMount) {\n this._invokeAnimatedPropsCallbackOnMount = false;\n this._animatedPropsCallback();\n }\n\n this._propsAnimated.setNativeView(this._component);\n this._attachNativeEvents();\n this._markUpdateComplete();\n }\n\n UNSAFE_componentWillReceiveProps(newProps: any) {\n this._waitForUpdate();\n this._attachProps(newProps);\n }\n\n componentDidUpdate(prevProps: any) {\n if (this._component !== this._prevComponent) {\n this._propsAnimated.setNativeView(this._component);\n }\n if (this._component !== this._prevComponent || prevProps !== this.props) {\n this._detachNativeEvents();\n this._attachNativeEvents();\n }\n this._markUpdateComplete();\n }\n\n componentWillUnmount() {\n this._propsAnimated && this._propsAnimated.__detach();\n this._detachNativeEvents();\n this._markUpdateComplete();\n this._component = null;\n this._prevComponent = null;\n }\n }\n\n return React.forwardRef(function AnimatedComponentWrapper(props, ref) {\n return (\n \n );\n });\n}\n\n// $FlowIgnore[incompatible-cast] - Will be compatible after refactors.\nexport default (createAnimatedComponentInjection.recordAndRetrieve() ??\n createAnimatedComponent: typeof createAnimatedComponent);\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 * @format\n * @flow\n */\n\n'use strict';\n\nimport type {ElementRef, Ref} from 'react';\n\ntype Args = $ReadOnly<{|\n getForwardedRef: () => ?Ref,\n setLocalRef: (ref: ElementRef) => mixed,\n|}>;\n\n/**\n * This is a helper function for when a component needs to be able to forward a ref\n * to a child component, but still needs to have access to that component as part of\n * its implementation.\n *\n * Its main use case is in wrappers for native components.\n *\n * Usage:\n *\n * class MyView extends React.Component {\n * _nativeRef = null;\n *\n * _setNativeRef = setAndForwardRef({\n * getForwardedRef: () => this.props.forwardedRef,\n * setLocalRef: ref => {\n * this._nativeRef = ref;\n * },\n * });\n *\n * render() {\n * return ;\n * }\n * }\n *\n * const MyViewWithRef = React.forwardRef((props, ref) => (\n * \n * ));\n *\n * module.exports = MyViewWithRef;\n */\n\nfunction setAndForwardRef({\n getForwardedRef,\n setLocalRef,\n}: Args): (ref: ElementRef) => void {\n return function forwardRef(ref: ElementRef) {\n const forwardedRef = getForwardedRef();\n\n setLocalRef(ref);\n\n // Forward to user ref prop (if one has been specified)\n if (typeof forwardedRef === 'function') {\n // Handle function-based refs. String-based refs are handled as functions.\n forwardedRef(ref);\n } else if (typeof forwardedRef === 'object' && forwardedRef != null) {\n // Handle createRef-based refs\n forwardedRef.current = ref;\n }\n };\n}\n\nmodule.exports = setAndForwardRef;\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 * @flow strict-local\n * @format\n */\n\nimport * as React from 'react';\n\ntype createAnimatedComponent = (\n Component: React.AbstractComponent,\n) => React.AbstractComponent;\n\n// This can be undefined, null, or the experimental implementation. If this is\n// null, that means `createAnimatedComponent` has already been initialized and\n// it is too late to call `inject`.\nlet injected: ?createAnimatedComponent;\n\n/**\n * Call during bundle initialization to opt-in to new `createAnimatedComponent`.\n */\nexport function inject(newInjected: createAnimatedComponent): void {\n if (injected !== undefined) {\n if (__DEV__) {\n console.error(\n 'createAnimatedComponentInjection: ' +\n (injected == null\n ? 'Must be called before `createAnimatedComponent`.'\n : 'Cannot be called more than once.'),\n );\n }\n return;\n }\n injected = newInjected;\n}\n\n/**\n * Only called by `createAnimatedComponent.js`.\n */\nexport function recordAndRetrieve(): createAnimatedComponent | null {\n if (injected === undefined) {\n injected = null;\n }\n return injected;\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport type {PlatformConfig} from '../AnimatedPlatformConfig';\n\nimport {findNodeHandle} from '../../ReactNative/RendererProxy';\nimport {AnimatedEvent} from '../AnimatedEvent';\nimport NativeAnimatedHelper from '../NativeAnimatedHelper';\nimport AnimatedNode from './AnimatedNode';\nimport AnimatedStyle from './AnimatedStyle';\nimport invariant from 'invariant';\n\nexport default class AnimatedProps extends AnimatedNode {\n _props: Object;\n _animatedView: any;\n _callback: () => void;\n\n constructor(props: Object, callback: () => void) {\n super();\n if (props.style) {\n props = {\n ...props,\n style: new AnimatedStyle(props.style),\n };\n }\n this._props = props;\n this._callback = callback;\n }\n\n __getValue(): Object {\n const props: {[string]: any | ((...args: any) => void)} = {};\n for (const key in this._props) {\n const value = this._props[key];\n if (value instanceof AnimatedNode) {\n props[key] = value.__getValue();\n } else if (value instanceof AnimatedEvent) {\n props[key] = value.__getHandler();\n } else {\n props[key] = value;\n }\n }\n\n return props;\n }\n\n __getAnimatedValue(): Object {\n const props: {[string]: any} = {};\n for (const key in this._props) {\n const value = this._props[key];\n if (value instanceof AnimatedNode) {\n props[key] = value.__getAnimatedValue();\n }\n }\n return props;\n }\n\n __attach(): void {\n for (const key in this._props) {\n const value = this._props[key];\n if (value instanceof AnimatedNode) {\n value.__addChild(this);\n }\n }\n }\n\n __detach(): void {\n if (this.__isNative && this._animatedView) {\n this.__disconnectAnimatedView();\n }\n for (const key in this._props) {\n const value = this._props[key];\n if (value instanceof AnimatedNode) {\n value.__removeChild(this);\n }\n }\n super.__detach();\n }\n\n update(): void {\n this._callback();\n }\n\n __makeNative(platformConfig: ?PlatformConfig): void {\n if (!this.__isNative) {\n this.__isNative = true;\n for (const key in this._props) {\n const value = this._props[key];\n if (value instanceof AnimatedNode) {\n value.__makeNative(platformConfig);\n }\n }\n\n // Since this does not call the super.__makeNative, we need to store the\n // supplied platformConfig here, before calling __connectAnimatedView\n // where it will be needed to traverse the graph of attached values.\n super.__setPlatformConfig(platformConfig);\n\n if (this._animatedView) {\n this.__connectAnimatedView();\n }\n }\n }\n\n setNativeView(animatedView: any): void {\n if (this._animatedView === animatedView) {\n return;\n }\n this._animatedView = animatedView;\n if (this.__isNative) {\n this.__connectAnimatedView();\n }\n }\n\n __connectAnimatedView(): void {\n invariant(this.__isNative, 'Expected node to be marked as \"native\"');\n const nativeViewTag: ?number = findNodeHandle(this._animatedView);\n invariant(\n nativeViewTag != null,\n 'Unable to locate attached view in the native tree',\n );\n NativeAnimatedHelper.API.connectAnimatedNodeToView(\n this.__getNativeTag(),\n nativeViewTag,\n );\n }\n\n __disconnectAnimatedView(): void {\n invariant(this.__isNative, 'Expected node to be marked as \"native\"');\n const nativeViewTag: ?number = findNodeHandle(this._animatedView);\n invariant(\n nativeViewTag != null,\n 'Unable to locate attached view in the native tree',\n );\n NativeAnimatedHelper.API.disconnectAnimatedNodeFromView(\n this.__getNativeTag(),\n nativeViewTag,\n );\n }\n\n __restoreDefaultValues(): void {\n // When using the native driver, view properties need to be restored to\n // their default values manually since react no longer tracks them. This\n // is needed to handle cases where a prop driven by native animated is removed\n // after having been changed natively by an animation.\n if (this.__isNative) {\n NativeAnimatedHelper.API.restoreDefaultValues(this.__getNativeTag());\n }\n }\n\n __getNativeConfig(): Object {\n const propsConfig: {[string]: number} = {};\n for (const propKey in this._props) {\n const value = this._props[propKey];\n if (value instanceof AnimatedNode) {\n value.__makeNative(this.__getPlatformConfig());\n propsConfig[propKey] = value.__getNativeTag();\n }\n }\n return {\n type: 'props',\n props: propsConfig,\n };\n }\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport type {PlatformConfig} from '../AnimatedPlatformConfig';\n\nimport flattenStyle from '../../StyleSheet/flattenStyle';\nimport NativeAnimatedHelper from '../NativeAnimatedHelper';\nimport AnimatedNode from './AnimatedNode';\nimport AnimatedTransform from './AnimatedTransform';\nimport AnimatedWithChildren from './AnimatedWithChildren';\n\nexport default class AnimatedStyle extends AnimatedWithChildren {\n _style: Object;\n\n constructor(style: any) {\n super();\n style = flattenStyle(style) || ({}: {[string]: any});\n if (style.transform) {\n style = {\n ...style,\n transform: new AnimatedTransform(style.transform),\n };\n }\n this._style = style;\n }\n\n // Recursively get values for nested styles (like iOS's shadowOffset)\n _walkStyleAndGetValues(style: any): {[string]: any | {...}} {\n const updatedStyle: {[string]: any | {...}} = {};\n for (const key in style) {\n const value = style[key];\n if (value instanceof AnimatedNode) {\n updatedStyle[key] = value.__getValue();\n } else if (value && !Array.isArray(value) && typeof value === 'object') {\n // Support animating nested values (for example: shadowOffset.height)\n updatedStyle[key] = this._walkStyleAndGetValues(value);\n } else {\n updatedStyle[key] = value;\n }\n }\n return updatedStyle;\n }\n\n __getValue(): Object {\n return this._walkStyleAndGetValues(this._style);\n }\n\n // Recursively get animated values for nested styles (like iOS's shadowOffset)\n _walkStyleAndGetAnimatedValues(style: any): {[string]: any | {...}} {\n const updatedStyle: {[string]: any | {...}} = {};\n for (const key in style) {\n const value = style[key];\n if (value instanceof AnimatedNode) {\n updatedStyle[key] = value.__getAnimatedValue();\n } else if (value && !Array.isArray(value) && typeof value === 'object') {\n // Support animating nested values (for example: shadowOffset.height)\n updatedStyle[key] = this._walkStyleAndGetAnimatedValues(value);\n }\n }\n return updatedStyle;\n }\n\n __getAnimatedValue(): Object {\n return this._walkStyleAndGetAnimatedValues(this._style);\n }\n\n __attach(): void {\n for (const key in this._style) {\n const value = this._style[key];\n if (value instanceof AnimatedNode) {\n value.__addChild(this);\n }\n }\n }\n\n __detach(): void {\n for (const key in this._style) {\n const value = this._style[key];\n if (value instanceof AnimatedNode) {\n value.__removeChild(this);\n }\n }\n super.__detach();\n }\n\n __makeNative(platformConfig: ?PlatformConfig) {\n for (const key in this._style) {\n const value = this._style[key];\n if (value instanceof AnimatedNode) {\n value.__makeNative(platformConfig);\n }\n }\n super.__makeNative(platformConfig);\n }\n\n __getNativeConfig(): Object {\n const styleConfig: {[string]: ?number} = {};\n for (const styleKey in this._style) {\n if (this._style[styleKey] instanceof AnimatedNode) {\n const style = this._style[styleKey];\n style.__makeNative(this.__getPlatformConfig());\n styleConfig[styleKey] = style.__getNativeTag();\n }\n // Non-animated styles are set using `setNativeProps`, no need\n // to pass those as a part of the node config\n }\n NativeAnimatedHelper.validateStyles(styleConfig);\n return {\n type: 'style',\n style: styleConfig,\n };\n }\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport type {PlatformConfig} from '../AnimatedPlatformConfig';\n\nimport NativeAnimatedHelper from '../NativeAnimatedHelper';\nimport AnimatedNode from './AnimatedNode';\nimport AnimatedWithChildren from './AnimatedWithChildren';\n\nexport default class AnimatedTransform extends AnimatedWithChildren {\n _transforms: $ReadOnlyArray;\n\n constructor(transforms: $ReadOnlyArray) {\n super();\n this._transforms = transforms;\n }\n\n __makeNative(platformConfig: ?PlatformConfig) {\n this._transforms.forEach(transform => {\n for (const key in transform) {\n const value = transform[key];\n if (value instanceof AnimatedNode) {\n value.__makeNative(platformConfig);\n }\n }\n });\n super.__makeNative(platformConfig);\n }\n\n __getValue(): $ReadOnlyArray {\n return this._get(animatedNode => animatedNode.__getValue());\n }\n\n __getAnimatedValue(): $ReadOnlyArray {\n return this._get(animatedNode => animatedNode.__getAnimatedValue());\n }\n\n __attach(): void {\n this._transforms.forEach(transform => {\n for (const key in transform) {\n const value = transform[key];\n if (value instanceof AnimatedNode) {\n value.__addChild(this);\n }\n }\n });\n }\n\n __detach(): void {\n this._transforms.forEach(transform => {\n for (const key in transform) {\n const value = transform[key];\n if (value instanceof AnimatedNode) {\n value.__removeChild(this);\n }\n }\n });\n super.__detach();\n }\n\n __getNativeConfig(): any {\n const transConfigs = [];\n\n this._transforms.forEach(transform => {\n for (const key in transform) {\n const value = transform[key];\n if (value instanceof AnimatedNode) {\n transConfigs.push({\n type: 'animated',\n property: key,\n nodeTag: value.__getNativeTag(),\n });\n } else {\n transConfigs.push({\n type: 'static',\n property: key,\n value: NativeAnimatedHelper.transformDataType(value),\n });\n }\n }\n });\n\n NativeAnimatedHelper.validateTransform(transConfigs);\n return {\n type: 'transform',\n transforms: transConfigs,\n };\n }\n\n _get(getter: AnimatedNode => any): $ReadOnlyArray {\n return this._transforms.map(transform => {\n const result: {[string]: any} = {};\n for (const key in transform) {\n const value = transform[key];\n if (value instanceof AnimatedNode) {\n result[key] = getter(value);\n } else if (Array.isArray(value)) {\n result[key] = value.map(element => {\n if (element instanceof AnimatedNode) {\n return getter(element);\n } else {\n return element;\n }\n });\n } else if (typeof value === 'object') {\n result[key] = {};\n for (const [nestedKey, nestedValue] of Object.entries(value)) {\n if (nestedValue instanceof AnimatedNode) {\n result[key][nestedKey] = getter(nestedValue);\n } else {\n result[key][nestedKey] = nestedValue;\n }\n }\n } else {\n result[key] = value;\n }\n }\n return result;\n });\n }\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport type {PlatformConfig} from './AnimatedPlatformConfig';\n\nimport {findNodeHandle} from '../ReactNative/RendererProxy';\nimport NativeAnimatedHelper from './NativeAnimatedHelper';\nimport AnimatedValue from './nodes/AnimatedValue';\nimport AnimatedValueXY from './nodes/AnimatedValueXY';\nimport invariant from 'invariant';\n\nexport type Mapping =\n | {[key: string]: Mapping, ...}\n | AnimatedValue\n | AnimatedValueXY;\nexport type EventConfig = {\n listener?: ?Function,\n useNativeDriver: boolean,\n platformConfig?: PlatformConfig,\n};\n\nexport function attachNativeEvent(\n viewRef: any,\n eventName: string,\n argMapping: $ReadOnlyArray,\n platformConfig: ?PlatformConfig,\n): {detach: () => void} {\n // Find animated values in `argMapping` and create an array representing their\n // key path inside the `nativeEvent` object. Ex.: ['contentOffset', 'x'].\n const eventMappings = [];\n\n const traverse = (value: mixed, path: Array) => {\n if (value instanceof AnimatedValue) {\n value.__makeNative(platformConfig);\n\n eventMappings.push({\n nativeEventPath: path,\n animatedValueTag: value.__getNativeTag(),\n });\n } else if (value instanceof AnimatedValueXY) {\n traverse(value.x, path.concat('x'));\n traverse(value.y, path.concat('y'));\n } else if (typeof value === 'object') {\n for (const key in value) {\n traverse(value[key], path.concat(key));\n }\n }\n };\n\n invariant(\n argMapping[0] && argMapping[0].nativeEvent,\n 'Native driven events only support animated values contained inside `nativeEvent`.',\n );\n\n // Assume that the event containing `nativeEvent` is always the first argument.\n traverse(argMapping[0].nativeEvent, []);\n\n const viewTag = findNodeHandle(viewRef);\n if (viewTag != null) {\n eventMappings.forEach(mapping => {\n NativeAnimatedHelper.API.addAnimatedEventToView(\n viewTag,\n eventName,\n mapping,\n );\n });\n }\n\n return {\n detach() {\n if (viewTag != null) {\n eventMappings.forEach(mapping => {\n NativeAnimatedHelper.API.removeAnimatedEventFromView(\n viewTag,\n eventName,\n // $FlowFixMe[incompatible-call]\n mapping.animatedValueTag,\n );\n });\n }\n },\n };\n}\n\nfunction validateMapping(argMapping: $ReadOnlyArray, args: any) {\n const validate = (recMapping: ?Mapping, recEvt: any, key: string) => {\n if (recMapping instanceof AnimatedValue) {\n invariant(\n typeof recEvt === 'number',\n 'Bad mapping of event key ' +\n key +\n ', should be number but got ' +\n typeof recEvt,\n );\n return;\n }\n if (recMapping instanceof AnimatedValueXY) {\n invariant(\n typeof recEvt.x === 'number' && typeof recEvt.y === 'number',\n 'Bad mapping of event key ' + key + ', should be XY but got ' + recEvt,\n );\n return;\n }\n if (typeof recEvt === 'number') {\n invariant(\n recMapping instanceof AnimatedValue,\n 'Bad mapping of type ' +\n typeof recMapping +\n ' for key ' +\n key +\n ', event value must map to AnimatedValue',\n );\n return;\n }\n invariant(\n typeof recMapping === 'object',\n 'Bad mapping of type ' + typeof recMapping + ' for key ' + key,\n );\n invariant(\n typeof recEvt === 'object',\n 'Bad event of type ' + typeof recEvt + ' for key ' + key,\n );\n for (const mappingKey in recMapping) {\n validate(recMapping[mappingKey], recEvt[mappingKey], mappingKey);\n }\n };\n\n invariant(\n args.length >= argMapping.length,\n 'Event has less arguments than mapping',\n );\n argMapping.forEach((mapping, idx) => {\n validate(mapping, args[idx], 'arg' + idx);\n });\n}\n\nexport class AnimatedEvent {\n _argMapping: $ReadOnlyArray;\n _listeners: Array = [];\n _attachedEvent: ?{detach: () => void, ...};\n __isNative: boolean;\n __platformConfig: ?PlatformConfig;\n\n constructor(argMapping: $ReadOnlyArray, config: EventConfig) {\n this._argMapping = argMapping;\n\n if (config == null) {\n console.warn('Animated.event now requires a second argument for options');\n config = {useNativeDriver: false};\n }\n\n if (config.listener) {\n this.__addListener(config.listener);\n }\n this._attachedEvent = null;\n this.__isNative = NativeAnimatedHelper.shouldUseNativeDriver(config);\n this.__platformConfig = config.platformConfig;\n }\n\n __addListener(callback: Function): void {\n this._listeners.push(callback);\n }\n\n __removeListener(callback: Function): void {\n this._listeners = this._listeners.filter(listener => listener !== callback);\n }\n\n __attach(viewRef: any, eventName: string): void {\n invariant(\n this.__isNative,\n 'Only native driven events need to be attached.',\n );\n\n this._attachedEvent = attachNativeEvent(\n viewRef,\n eventName,\n this._argMapping,\n this.__platformConfig,\n );\n }\n\n __detach(viewTag: any, eventName: string): void {\n invariant(\n this.__isNative,\n 'Only native driven events need to be detached.',\n );\n\n this._attachedEvent && this._attachedEvent.detach();\n }\n\n __getHandler(): any | ((...args: any) => void) {\n if (this.__isNative) {\n if (__DEV__) {\n let validatedMapping = false;\n return (...args: any) => {\n if (!validatedMapping) {\n validateMapping(this._argMapping, args);\n validatedMapping = true;\n }\n this._callListeners(...args);\n };\n } else {\n return this._callListeners;\n }\n }\n\n let validatedMapping = false;\n return (...args: any) => {\n if (__DEV__ && !validatedMapping) {\n validateMapping(this._argMapping, args);\n validatedMapping = true;\n }\n\n const traverse = (\n recMapping: ?(Mapping | AnimatedValue),\n recEvt: any,\n ) => {\n if (recMapping instanceof AnimatedValue) {\n if (typeof recEvt === 'number') {\n recMapping.setValue(recEvt);\n }\n } else if (recMapping instanceof AnimatedValueXY) {\n if (typeof recEvt === 'object') {\n traverse(recMapping.x, recEvt.x);\n traverse(recMapping.y, recEvt.y);\n }\n } else if (typeof recMapping === 'object') {\n for (const mappingKey in recMapping) {\n /* $FlowFixMe[prop-missing] (>=0.120.0) This comment suppresses an\n * error found when Flow v0.120 was deployed. To see the error,\n * delete this comment and run Flow. */\n traverse(recMapping[mappingKey], recEvt[mappingKey]);\n }\n }\n };\n this._argMapping.forEach((mapping, idx) => {\n traverse(mapping, args[idx]);\n });\n\n this._callListeners(...args);\n };\n }\n\n _callListeners = (...args: any) => {\n this._listeners.forEach(listener => listener(...args));\n };\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport type {PlatformConfig} from '../AnimatedPlatformConfig';\n\nimport AnimatedValue from './AnimatedValue';\nimport AnimatedWithChildren from './AnimatedWithChildren';\nimport invariant from 'invariant';\n\nexport type AnimatedValueXYConfig = $ReadOnly<{\n useNativeDriver: boolean,\n}>;\ntype ValueXYListenerCallback = (value: {\n x: number,\n y: number,\n ...\n}) => mixed;\n\nlet _uniqueId = 1;\n\n/**\n * 2D Value for driving 2D animations, such as pan gestures. Almost identical\n * API to normal `Animated.Value`, but multiplexed.\n *\n * See https://reactnative.dev/docs/animatedvaluexy\n */\nexport default class AnimatedValueXY extends AnimatedWithChildren {\n x: AnimatedValue;\n y: AnimatedValue;\n _listeners: {\n [key: string]: {\n x: string,\n y: string,\n ...\n },\n ...\n };\n\n constructor(\n valueIn?: ?{\n +x: number | AnimatedValue,\n +y: number | AnimatedValue,\n ...\n },\n config?: ?AnimatedValueXYConfig,\n ) {\n super();\n const value: any = valueIn || {x: 0, y: 0}; // @flowfixme: shouldn't need `: any`\n if (typeof value.x === 'number' && typeof value.y === 'number') {\n this.x = new AnimatedValue(value.x);\n this.y = new AnimatedValue(value.y);\n } else {\n invariant(\n value.x instanceof AnimatedValue && value.y instanceof AnimatedValue,\n 'AnimatedValueXY must be initialized with an object of numbers or ' +\n 'AnimatedValues.',\n );\n this.x = value.x;\n this.y = value.y;\n }\n this._listeners = {};\n if (config && config.useNativeDriver) {\n this.__makeNative();\n }\n }\n\n /**\n * Directly set the value. This will stop any animations running on the value\n * and update all the bound properties.\n *\n * See https://reactnative.dev/docs/animatedvaluexy#setvalue\n */\n setValue(value: {x: number, y: number, ...}) {\n this.x.setValue(value.x);\n this.y.setValue(value.y);\n }\n\n /**\n * Sets an offset that is applied on top of whatever value is set, whether\n * via `setValue`, an animation, or `Animated.event`. Useful for compensating\n * things like the start of a pan gesture.\n *\n * See https://reactnative.dev/docs/animatedvaluexy#setoffset\n */\n setOffset(offset: {x: number, y: number, ...}) {\n this.x.setOffset(offset.x);\n this.y.setOffset(offset.y);\n }\n\n /**\n * Merges the offset value into the base value and resets the offset to zero.\n * The final output of the value is unchanged.\n *\n * See https://reactnative.dev/docs/animatedvaluexy#flattenoffset\n */\n flattenOffset(): void {\n this.x.flattenOffset();\n this.y.flattenOffset();\n }\n\n /**\n * Sets the offset value to the base value, and resets the base value to\n * zero. The final output of the value is unchanged.\n *\n * See https://reactnative.dev/docs/animatedvaluexy#extractoffset\n */\n extractOffset(): void {\n this.x.extractOffset();\n this.y.extractOffset();\n }\n\n __getValue(): {\n x: number,\n y: number,\n ...\n } {\n return {\n x: this.x.__getValue(),\n y: this.y.__getValue(),\n };\n }\n\n /**\n * Stops any animation and resets the value to its original.\n *\n * See https://reactnative.dev/docs/animatedvaluexy#resetanimation\n */\n resetAnimation(\n callback?: (value: {\n x: number,\n y: number,\n ...\n }) => void,\n ): void {\n this.x.resetAnimation();\n this.y.resetAnimation();\n callback && callback(this.__getValue());\n }\n\n /**\n * Stops any running animation or tracking. `callback` is invoked with the\n * final value after stopping the animation, which is useful for updating\n * state to match the animation position with layout.\n *\n * See https://reactnative.dev/docs/animatedvaluexy#stopanimation\n */\n stopAnimation(\n callback?: (value: {\n x: number,\n y: number,\n ...\n }) => void,\n ): void {\n this.x.stopAnimation();\n this.y.stopAnimation();\n callback && callback(this.__getValue());\n }\n\n /**\n * Adds an asynchronous listener to the value so you can observe updates from\n * animations. This is useful because there is no way to synchronously read\n * the value because it might be driven natively.\n *\n * Returns a string that serves as an identifier for the listener.\n *\n * See https://reactnative.dev/docs/animatedvaluexy#addlistener\n */\n addListener(callback: ValueXYListenerCallback): string {\n const id = String(_uniqueId++);\n const jointCallback = ({value: number}: any) => {\n callback(this.__getValue());\n };\n this._listeners[id] = {\n x: this.x.addListener(jointCallback),\n y: this.y.addListener(jointCallback),\n };\n return id;\n }\n\n /**\n * Unregister a listener. The `id` param shall match the identifier\n * previously returned by `addListener()`.\n *\n * See https://reactnative.dev/docs/animatedvaluexy#removelistener\n */\n removeListener(id: string): void {\n this.x.removeListener(this._listeners[id].x);\n this.y.removeListener(this._listeners[id].y);\n delete this._listeners[id];\n }\n\n /**\n * Remove all registered listeners.\n *\n * See https://reactnative.dev/docs/animatedvaluexy#removealllisteners\n */\n removeAllListeners(): void {\n this.x.removeAllListeners();\n this.y.removeAllListeners();\n this._listeners = {};\n }\n\n /**\n * Converts `{x, y}` into `{left, top}` for use in style.\n *\n * See https://reactnative.dev/docs/animatedvaluexy#getlayout\n */\n getLayout(): {[key: string]: AnimatedValue, ...} {\n return {\n left: this.x,\n top: this.y,\n };\n }\n\n /**\n * Converts `{x, y}` into a useable translation transform.\n *\n * See https://reactnative.dev/docs/animatedvaluexy#gettranslatetransform\n */\n getTranslateTransform(): Array<{[key: string]: AnimatedValue, ...}> {\n return [{translateX: this.x}, {translateY: this.y}];\n }\n\n __attach(): void {\n this.x.__addChild(this);\n this.y.__addChild(this);\n super.__attach();\n }\n\n __detach(): void {\n this.x.__removeChild(this);\n this.y.__removeChild(this);\n super.__detach();\n }\n\n __makeNative(platformConfig: ?PlatformConfig) {\n this.x.__makeNative(platformConfig);\n this.y.__makeNative(platformConfig);\n super.__makeNative(platformConfig);\n }\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport type {PlatformConfig} from '../AnimatedPlatformConfig';\nimport type {InterpolationConfigType} from './AnimatedInterpolation';\nimport type AnimatedNode from './AnimatedNode';\n\nimport AnimatedInterpolation from './AnimatedInterpolation';\nimport AnimatedValue from './AnimatedValue';\nimport AnimatedWithChildren from './AnimatedWithChildren';\n\nexport default class AnimatedAddition extends AnimatedWithChildren {\n _a: AnimatedNode;\n _b: AnimatedNode;\n\n constructor(a: AnimatedNode | number, b: AnimatedNode | number) {\n super();\n this._a = typeof a === 'number' ? new AnimatedValue(a) : a;\n this._b = typeof b === 'number' ? new AnimatedValue(b) : b;\n }\n\n __makeNative(platformConfig: ?PlatformConfig) {\n this._a.__makeNative(platformConfig);\n this._b.__makeNative(platformConfig);\n super.__makeNative(platformConfig);\n }\n\n __getValue(): number {\n return this._a.__getValue() + this._b.__getValue();\n }\n\n interpolate(\n config: InterpolationConfigType,\n ): AnimatedInterpolation {\n return new AnimatedInterpolation(this, config);\n }\n\n __attach(): void {\n this._a.__addChild(this);\n this._b.__addChild(this);\n }\n\n __detach(): void {\n this._a.__removeChild(this);\n this._b.__removeChild(this);\n super.__detach();\n }\n\n __getNativeConfig(): any {\n return {\n type: 'addition',\n input: [this._a.__getNativeTag(), this._b.__getNativeTag()],\n };\n }\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport type {PlatformConfig} from '../AnimatedPlatformConfig';\nimport type {InterpolationConfigType} from './AnimatedInterpolation';\nimport type AnimatedNode from './AnimatedNode';\n\nimport AnimatedInterpolation from './AnimatedInterpolation';\nimport AnimatedWithChildren from './AnimatedWithChildren';\n\nexport default class AnimatedDiffClamp extends AnimatedWithChildren {\n _a: AnimatedNode;\n _min: number;\n _max: number;\n _value: number;\n _lastValue: number;\n\n constructor(a: AnimatedNode, min: number, max: number) {\n super();\n\n this._a = a;\n this._min = min;\n this._max = max;\n this._value = this._lastValue = this._a.__getValue();\n }\n\n __makeNative(platformConfig: ?PlatformConfig) {\n this._a.__makeNative(platformConfig);\n super.__makeNative(platformConfig);\n }\n\n interpolate(\n config: InterpolationConfigType,\n ): AnimatedInterpolation {\n return new AnimatedInterpolation(this, config);\n }\n\n __getValue(): number {\n const value = this._a.__getValue();\n const diff = value - this._lastValue;\n this._lastValue = value;\n this._value = Math.min(Math.max(this._value + diff, this._min), this._max);\n return this._value;\n }\n\n __attach(): void {\n this._a.__addChild(this);\n }\n\n __detach(): void {\n this._a.__removeChild(this);\n super.__detach();\n }\n\n __getNativeConfig(): any {\n return {\n type: 'diffclamp',\n input: this._a.__getNativeTag(),\n min: this._min,\n max: this._max,\n };\n }\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport type {PlatformConfig} from '../AnimatedPlatformConfig';\nimport type {InterpolationConfigType} from './AnimatedInterpolation';\n\nimport AnimatedInterpolation from './AnimatedInterpolation';\nimport AnimatedNode from './AnimatedNode';\nimport AnimatedValue from './AnimatedValue';\nimport AnimatedWithChildren from './AnimatedWithChildren';\n\nexport default class AnimatedDivision extends AnimatedWithChildren {\n _a: AnimatedNode;\n _b: AnimatedNode;\n _warnedAboutDivideByZero: boolean = false;\n\n constructor(a: AnimatedNode | number, b: AnimatedNode | number) {\n super();\n if (b === 0 || (b instanceof AnimatedNode && b.__getValue() === 0)) {\n console.error('Detected potential division by zero in AnimatedDivision');\n }\n this._a = typeof a === 'number' ? new AnimatedValue(a) : a;\n this._b = typeof b === 'number' ? new AnimatedValue(b) : b;\n }\n\n __makeNative(platformConfig: ?PlatformConfig) {\n this._a.__makeNative(platformConfig);\n this._b.__makeNative(platformConfig);\n super.__makeNative(platformConfig);\n }\n\n __getValue(): number {\n const a = this._a.__getValue();\n const b = this._b.__getValue();\n if (b === 0) {\n // Prevent spamming the console/LogBox\n if (!this._warnedAboutDivideByZero) {\n console.error('Detected division by zero in AnimatedDivision');\n this._warnedAboutDivideByZero = true;\n }\n // Passing infinity/NaN to Fabric will cause a native crash\n return 0;\n }\n this._warnedAboutDivideByZero = false;\n return a / b;\n }\n\n interpolate(\n config: InterpolationConfigType,\n ): AnimatedInterpolation {\n return new AnimatedInterpolation(this, config);\n }\n\n __attach(): void {\n this._a.__addChild(this);\n this._b.__addChild(this);\n }\n\n __detach(): void {\n this._a.__removeChild(this);\n this._b.__removeChild(this);\n super.__detach();\n }\n\n __getNativeConfig(): any {\n return {\n type: 'division',\n input: [this._a.__getNativeTag(), this._b.__getNativeTag()],\n };\n }\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport type {PlatformConfig} from '../AnimatedPlatformConfig';\nimport type {InterpolationConfigType} from './AnimatedInterpolation';\nimport type AnimatedNode from './AnimatedNode';\n\nimport AnimatedInterpolation from './AnimatedInterpolation';\nimport AnimatedWithChildren from './AnimatedWithChildren';\n\nexport default class AnimatedModulo extends AnimatedWithChildren {\n _a: AnimatedNode;\n _modulus: number;\n\n constructor(a: AnimatedNode, modulus: number) {\n super();\n this._a = a;\n this._modulus = modulus;\n }\n\n __makeNative(platformConfig: ?PlatformConfig) {\n this._a.__makeNative(platformConfig);\n super.__makeNative(platformConfig);\n }\n\n __getValue(): number {\n return (\n ((this._a.__getValue() % this._modulus) + this._modulus) % this._modulus\n );\n }\n\n interpolate(\n config: InterpolationConfigType,\n ): AnimatedInterpolation {\n return new AnimatedInterpolation(this, config);\n }\n\n __attach(): void {\n this._a.__addChild(this);\n }\n\n __detach(): void {\n this._a.__removeChild(this);\n super.__detach();\n }\n\n __getNativeConfig(): any {\n return {\n type: 'modulus',\n input: this._a.__getNativeTag(),\n modulus: this._modulus,\n };\n }\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport type {PlatformConfig} from '../AnimatedPlatformConfig';\nimport type {InterpolationConfigType} from './AnimatedInterpolation';\nimport type AnimatedNode from './AnimatedNode';\n\nimport AnimatedInterpolation from './AnimatedInterpolation';\nimport AnimatedValue from './AnimatedValue';\nimport AnimatedWithChildren from './AnimatedWithChildren';\n\nexport default class AnimatedMultiplication extends AnimatedWithChildren {\n _a: AnimatedNode;\n _b: AnimatedNode;\n\n constructor(a: AnimatedNode | number, b: AnimatedNode | number) {\n super();\n this._a = typeof a === 'number' ? new AnimatedValue(a) : a;\n this._b = typeof b === 'number' ? new AnimatedValue(b) : b;\n }\n\n __makeNative(platformConfig: ?PlatformConfig) {\n this._a.__makeNative(platformConfig);\n this._b.__makeNative(platformConfig);\n super.__makeNative(platformConfig);\n }\n\n __getValue(): number {\n return this._a.__getValue() * this._b.__getValue();\n }\n\n interpolate(\n config: InterpolationConfigType,\n ): AnimatedInterpolation {\n return new AnimatedInterpolation(this, config);\n }\n __attach(): void {\n this._a.__addChild(this);\n this._b.__addChild(this);\n }\n\n __detach(): void {\n this._a.__removeChild(this);\n this._b.__removeChild(this);\n super.__detach();\n }\n\n __getNativeConfig(): any {\n return {\n type: 'multiplication',\n input: [this._a.__getNativeTag(), this._b.__getNativeTag()],\n };\n }\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport type {PlatformConfig} from '../AnimatedPlatformConfig';\nimport type {InterpolationConfigType} from './AnimatedInterpolation';\nimport type AnimatedNode from './AnimatedNode';\n\nimport AnimatedInterpolation from './AnimatedInterpolation';\nimport AnimatedValue from './AnimatedValue';\nimport AnimatedWithChildren from './AnimatedWithChildren';\n\nexport default class AnimatedSubtraction extends AnimatedWithChildren {\n _a: AnimatedNode;\n _b: AnimatedNode;\n\n constructor(a: AnimatedNode | number, b: AnimatedNode | number) {\n super();\n this._a = typeof a === 'number' ? new AnimatedValue(a) : a;\n this._b = typeof b === 'number' ? new AnimatedValue(b) : b;\n }\n\n __makeNative(platformConfig: ?PlatformConfig) {\n this._a.__makeNative(platformConfig);\n this._b.__makeNative(platformConfig);\n super.__makeNative(platformConfig);\n }\n\n __getValue(): number {\n return this._a.__getValue() - this._b.__getValue();\n }\n\n interpolate(\n config: InterpolationConfigType,\n ): AnimatedInterpolation {\n return new AnimatedInterpolation(this, config);\n }\n\n __attach(): void {\n this._a.__addChild(this);\n this._b.__addChild(this);\n }\n\n __detach(): void {\n this._a.__removeChild(this);\n this._b.__removeChild(this);\n super.__detach();\n }\n\n __getNativeConfig(): any {\n return {\n type: 'subtraction',\n input: [this._a.__getNativeTag(), this._b.__getNativeTag()],\n };\n }\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport type {PlatformConfig} from '../AnimatedPlatformConfig';\nimport type {EndCallback} from '../animations/Animation';\nimport type AnimatedValue from './AnimatedValue';\n\nimport NativeAnimatedHelper from '../NativeAnimatedHelper';\nimport AnimatedNode from './AnimatedNode';\n\nexport default class AnimatedTracking extends AnimatedNode {\n _value: AnimatedValue;\n _parent: AnimatedNode;\n _callback: ?EndCallback;\n _animationConfig: Object;\n _animationClass: any;\n _useNativeDriver: boolean;\n\n constructor(\n value: AnimatedValue,\n parent: AnimatedNode,\n animationClass: any,\n animationConfig: Object,\n callback?: ?EndCallback,\n ) {\n super();\n this._value = value;\n this._parent = parent;\n this._animationClass = animationClass;\n this._animationConfig = animationConfig;\n this._useNativeDriver =\n NativeAnimatedHelper.shouldUseNativeDriver(animationConfig);\n this._callback = callback;\n this.__attach();\n }\n\n __makeNative(platformConfig: ?PlatformConfig) {\n this.__isNative = true;\n this._parent.__makeNative(platformConfig);\n super.__makeNative(platformConfig);\n this._value.__makeNative(platformConfig);\n }\n\n __getValue(): Object {\n return this._parent.__getValue();\n }\n\n __attach(): void {\n this._parent.__addChild(this);\n if (this._useNativeDriver) {\n // when the tracking starts we need to convert this node to a \"native node\"\n // so that the parent node will be made \"native\" too. This is necessary as\n // if we don't do this `update` method will get called. At that point it\n // may be too late as it would mean the JS driver has already started\n // updating node values\n let {platformConfig} = this._animationConfig;\n this.__makeNative(platformConfig);\n }\n }\n\n __detach(): void {\n this._parent.__removeChild(this);\n super.__detach();\n }\n\n update(): void {\n this._value.animate(\n new this._animationClass({\n ...this._animationConfig,\n toValue: (this._animationConfig.toValue: any).__getValue(),\n }),\n this._callback,\n );\n }\n\n __getNativeConfig(): any {\n const animation = new this._animationClass({\n ...this._animationConfig,\n // remove toValue from the config as it's a ref to Animated.Value\n toValue: undefined,\n });\n const animationConfig = animation.__getNativeAnimationConfig();\n return {\n type: 'tracking',\n animationId: NativeAnimatedHelper.generateNewAnimationId(),\n animationConfig,\n toValue: this._parent.__getNativeTag(),\n value: this._value.__getNativeTag(),\n };\n }\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport type {Numeric as AnimatedNumeric} from './AnimatedImplementation';\nimport type {EndResult} from './animations/Animation';\nimport type {EndCallback} from './animations/Animation';\nimport type {DecayAnimationConfig} from './animations/DecayAnimation';\nimport type {SpringAnimationConfig} from './animations/SpringAnimation';\nimport type {TimingAnimationConfig} from './animations/TimingAnimation';\n\nimport {AnimatedEvent, attachNativeEvent} from './AnimatedEvent';\nimport AnimatedImplementation from './AnimatedImplementation';\nimport createAnimatedComponent from './createAnimatedComponent';\nimport AnimatedColor from './nodes/AnimatedColor';\nimport AnimatedInterpolation from './nodes/AnimatedInterpolation';\nimport AnimatedNode from './nodes/AnimatedNode';\nimport AnimatedValue from './nodes/AnimatedValue';\nimport AnimatedValueXY from './nodes/AnimatedValueXY';\n\n/**\n * Animations are a source of flakiness in snapshot testing. This mock replaces\n * animation functions from AnimatedImplementation with empty animations for\n * predictability in tests. When possible the animation will run immediately\n * to the final state.\n */\n\n// Prevent any callback invocation from recursively triggering another\n// callback, which may trigger another animation\nlet inAnimationCallback = false;\nfunction mockAnimationStart(\n start: (callback?: ?EndCallback) => void,\n): (callback?: ?EndCallback) => void {\n return callback => {\n const guardedCallback =\n callback == null\n ? callback\n : (...args: Array) => {\n if (inAnimationCallback) {\n console.warn(\n 'Ignoring recursive animation callback when running mock animations',\n );\n return;\n }\n inAnimationCallback = true;\n try {\n callback(...args);\n } finally {\n inAnimationCallback = false;\n }\n };\n start(guardedCallback);\n };\n}\n\nexport type CompositeAnimation = {\n start: (callback?: ?EndCallback) => void,\n stop: () => void,\n reset: () => void,\n _startNativeLoop: (iterations?: number) => void,\n _isUsingNativeDriver: () => boolean,\n ...\n};\n\nconst emptyAnimation = {\n start: () => {},\n stop: () => {},\n reset: () => {},\n _startNativeLoop: () => {},\n _isUsingNativeDriver: () => {\n return false;\n },\n};\n\nconst mockCompositeAnimation = (\n animations: Array,\n): CompositeAnimation => ({\n ...emptyAnimation,\n start: mockAnimationStart((callback?: ?EndCallback): void => {\n animations.forEach(animation => animation.start());\n callback?.({finished: true});\n }),\n});\n\nconst spring = function (\n value: AnimatedValue | AnimatedValueXY | AnimatedColor,\n config: SpringAnimationConfig,\n): CompositeAnimation {\n const anyValue: any = value;\n return {\n ...emptyAnimation,\n start: mockAnimationStart((callback?: ?EndCallback): void => {\n anyValue.setValue(config.toValue);\n callback?.({finished: true});\n }),\n };\n};\n\nconst timing = function (\n value: AnimatedValue | AnimatedValueXY | AnimatedColor,\n config: TimingAnimationConfig,\n): CompositeAnimation {\n const anyValue: any = value;\n return {\n ...emptyAnimation,\n start: mockAnimationStart((callback?: ?EndCallback): void => {\n anyValue.setValue(config.toValue);\n callback?.({finished: true});\n }),\n };\n};\n\nconst decay = function (\n value: AnimatedValue | AnimatedValueXY | AnimatedColor,\n config: DecayAnimationConfig,\n): CompositeAnimation {\n return emptyAnimation;\n};\n\nconst sequence = function (\n animations: Array,\n): CompositeAnimation {\n return mockCompositeAnimation(animations);\n};\n\ntype ParallelConfig = {stopTogether?: boolean, ...};\nconst parallel = function (\n animations: Array,\n config?: ?ParallelConfig,\n): CompositeAnimation {\n return mockCompositeAnimation(animations);\n};\n\nconst delay = function (time: number): CompositeAnimation {\n return emptyAnimation;\n};\n\nconst stagger = function (\n time: number,\n animations: Array,\n): CompositeAnimation {\n return mockCompositeAnimation(animations);\n};\n\ntype LoopAnimationConfig = {\n iterations: number,\n resetBeforeIteration?: boolean,\n ...\n};\n\nconst loop = function (\n animation: CompositeAnimation,\n // $FlowFixMe[prop-missing]\n {iterations = -1}: LoopAnimationConfig = {},\n): CompositeAnimation {\n return emptyAnimation;\n};\n\nexport type {AnimatedNumeric as Numeric};\n\nexport default {\n Value: AnimatedValue,\n ValueXY: AnimatedValueXY,\n Color: AnimatedColor,\n Interpolation: AnimatedInterpolation,\n Node: AnimatedNode,\n decay,\n timing,\n spring,\n add: AnimatedImplementation.add,\n subtract: AnimatedImplementation.subtract,\n divide: AnimatedImplementation.divide,\n multiply: AnimatedImplementation.multiply,\n modulo: AnimatedImplementation.modulo,\n diffClamp: AnimatedImplementation.diffClamp,\n delay,\n sequence,\n parallel,\n stagger,\n loop,\n event: AnimatedImplementation.event,\n createAnimatedComponent,\n attachNativeEvent,\n forkEvent: AnimatedImplementation.forkEvent,\n unforkEvent: AnimatedImplementation.unforkEvent,\n Event: AnimatedEvent,\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 * @flow strict-local\n * @format\n */\n\nimport type {AnimatedComponentType} from '../createAnimatedComponent';\n\nimport FlatList from '../../Lists/FlatList';\nimport createAnimatedComponent from '../createAnimatedComponent';\nimport * as React from 'react';\n\n/**\n * @see https://github.com/facebook/react-native/commit/b8c8562\n */\nconst FlatListWithEventThrottle = React.forwardRef((props, ref) => (\n \n));\n\nexport default (createAnimatedComponent(\n FlatListWithEventThrottle,\n): AnimatedComponentType<\n React.ElementConfig,\n React.ElementRef,\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 * @flow\n * @format\n */\n\nimport typeof ScrollViewNativeComponent from '../Components/ScrollView/ScrollViewNativeComponent';\nimport type {ViewStyleProp} from '../StyleSheet/StyleSheet';\nimport type {\n ViewabilityConfigCallbackPair,\n ViewToken,\n} from './ViewabilityHelper';\nimport type {RenderItemProps, RenderItemType} from './VirtualizedList';\n\nimport {type ScrollResponderType} from '../Components/ScrollView/ScrollView';\nimport VirtualizedList from './VirtualizedList';\nimport {keyExtractor as defaultKeyExtractor} from './VirtualizeUtils';\nimport memoizeOne from 'memoize-one';\n\nconst View = require('../Components/View/View');\nconst StyleSheet = require('../StyleSheet/StyleSheet');\nconst deepDiffer = require('../Utilities/differ/deepDiffer');\nconst Platform = require('../Utilities/Platform');\nconst invariant = require('invariant');\nconst React = require('react');\n\ntype RequiredProps = {|\n /**\n * For simplicity, data is just a plain array. If you want to use something else, like an\n * immutable list, use the underlying `VirtualizedList` directly.\n */\n data: ?$ReadOnlyArray,\n|};\ntype OptionalProps = {|\n /**\n * Takes an item from `data` and renders it into the list. Example usage:\n *\n * (\n * \n * )}\n * data={[{title: 'Title Text', key: 'item1'}]}\n * renderItem={({item, separators}) => (\n * this._onPress(item)}\n * onShowUnderlay={separators.highlight}\n * onHideUnderlay={separators.unhighlight}>\n * \n * {item.title}\n * \n * \n * )}\n * />\n *\n * Provides additional metadata like `index` if you need it, as well as a more generic\n * `separators.updateProps` function which let's you set whatever props you want to change the\n * rendering of either the leading separator or trailing separator in case the more common\n * `highlight` and `unhighlight` (which set the `highlighted: boolean` prop) are insufficient for\n * your use-case.\n */\n renderItem?: ?RenderItemType,\n\n /**\n * Optional custom style for multi-item rows generated when numColumns > 1.\n */\n columnWrapperStyle?: ViewStyleProp,\n /**\n * A marker property for telling the list to re-render (since it implements `PureComponent`). If\n * any of your `renderItem`, Header, Footer, etc. functions depend on anything outside of the\n * `data` prop, stick it here and treat it immutably.\n */\n extraData?: any,\n /**\n * `getItemLayout` is an optional optimizations that let us skip measurement of dynamic content if\n * you know the height of items a priori. `getItemLayout` is the most efficient, and is easy to\n * use if you have fixed height items, for example:\n *\n * getItemLayout={(data, index) => (\n * {length: ITEM_HEIGHT, offset: ITEM_HEIGHT * index, index}\n * )}\n *\n * Adding `getItemLayout` can be a great performance boost for lists of several hundred items.\n * Remember to include separator length (height or width) in your offset calculation if you\n * specify `ItemSeparatorComponent`.\n */\n getItemLayout?: (\n data: ?Array,\n index: number,\n ) => {\n length: number,\n offset: number,\n index: number,\n ...\n },\n /**\n * If true, renders items next to each other horizontally instead of stacked vertically.\n */\n horizontal?: ?boolean,\n /**\n * How many items to render in the initial batch. This should be enough to fill the screen but not\n * much more. Note these items will never be unmounted as part of the windowed rendering in order\n * to improve perceived performance of scroll-to-top actions.\n */\n initialNumToRender?: ?number,\n /**\n * Instead of starting at the top with the first item, start at `initialScrollIndex`. This\n * disables the \"scroll to top\" optimization that keeps the first `initialNumToRender` items\n * always rendered and immediately renders the items starting at this initial index. Requires\n * `getItemLayout` to be implemented.\n */\n initialScrollIndex?: ?number,\n /**\n * Reverses the direction of scroll. Uses scale transforms of -1.\n */\n inverted?: ?boolean,\n /**\n * Used to extract a unique key for a given item at the specified index. Key is used for caching\n * and as the react key to track item re-ordering. The default extractor checks `item.key`, then\n * falls back to using the index, like React does.\n */\n keyExtractor?: ?(item: ItemT, index: number) => string,\n /**\n * Multiple columns can only be rendered with `horizontal={false}` and will zig-zag like a\n * `flexWrap` layout. Items should all be the same height - masonry layouts are not supported.\n *\n * The default value is 1.\n */\n numColumns?: number,\n /**\n * Note: may have bugs (missing content) in some circumstances - use at your own risk.\n *\n * This may improve scroll performance for large lists.\n *\n * The default value is true for Android.\n */\n removeClippedSubviews?: boolean,\n /**\n * See `ScrollView` for flow type and further documentation.\n */\n fadingEdgeLength?: ?number,\n /**\n * Enable an optimization to memoize the item renderer to prevent unnecessary rerenders.\n */\n strictMode?: boolean,\n|};\n\n/**\n * Default Props Helper Functions\n * Use the following helper functions for default values\n */\n\n// removeClippedSubviewsOrDefault(this.props.removeClippedSubviews)\nfunction removeClippedSubviewsOrDefault(removeClippedSubviews: ?boolean) {\n return removeClippedSubviews ?? Platform.OS === 'android';\n}\n\n// numColumnsOrDefault(this.props.numColumns)\nfunction numColumnsOrDefault(numColumns: ?number) {\n return numColumns ?? 1;\n}\n\ntype FlatListProps = {|\n ...RequiredProps,\n ...OptionalProps,\n|};\n\ntype VirtualizedListProps = React.ElementConfig;\n\nexport type Props = {\n ...$Diff<\n VirtualizedListProps,\n {\n getItem: $PropertyType,\n getItemCount: $PropertyType,\n getItemLayout: $PropertyType,\n renderItem: $PropertyType,\n keyExtractor: $PropertyType,\n ...\n },\n >,\n ...FlatListProps,\n ...\n};\n\n/**\n * A performant interface for rendering simple, flat lists, supporting the most handy features:\n *\n * - Fully cross-platform.\n * - Optional horizontal mode.\n * - Configurable viewability callbacks.\n * - Header support.\n * - Footer support.\n * - Separator support.\n * - Pull to Refresh.\n * - Scroll loading.\n * - ScrollToIndex support.\n *\n * If you need section support, use [``](docs/sectionlist.html).\n *\n * Minimal Example:\n *\n * {item.key}}\n * />\n *\n * More complex, multi-select example demonstrating `PureComponent` usage for perf optimization and avoiding bugs.\n *\n * - By binding the `onPressItem` handler, the props will remain `===` and `PureComponent` will\n * prevent wasteful re-renders unless the actual `id`, `selected`, or `title` props change, even\n * if the components rendered in `MyListItem` did not have such optimizations.\n * - By passing `extraData={this.state}` to `FlatList` we make sure `FlatList` itself will re-render\n * when the `state.selected` changes. Without setting this prop, `FlatList` would not know it\n * needs to re-render any items because it is also a `PureComponent` and the prop comparison will\n * not show any changes.\n * - `keyExtractor` tells the list to use the `id`s for the react keys instead of the default `key` property.\n *\n *\n * class MyListItem extends React.PureComponent {\n * _onPress = () => {\n * this.props.onPressItem(this.props.id);\n * };\n *\n * render() {\n * const textColor = this.props.selected ? \"red\" : \"black\";\n * return (\n * \n * \n * \n * {this.props.title}\n * \n * \n * \n * );\n * }\n * }\n *\n * class MultiSelectList extends React.PureComponent {\n * state = {selected: (new Map(): Map)};\n *\n * _keyExtractor = (item, index) => item.id;\n *\n * _onPressItem = (id: string) => {\n * // updater functions are preferred for transactional updates\n * this.setState((state) => {\n * // copy the map rather than modifying state.\n * const selected = new Map(state.selected);\n * selected.set(id, !selected.get(id)); // toggle\n * return {selected};\n * });\n * };\n *\n * _renderItem = ({item}) => (\n * \n * );\n *\n * render() {\n * return (\n * \n * );\n * }\n * }\n *\n * This is a convenience wrapper around [``](docs/virtualizedlist.html),\n * and thus inherits its props (as well as those of `ScrollView`) that aren't explicitly listed\n * here, along with the following caveats:\n *\n * - Internal state is not preserved when content scrolls out of the render window. Make sure all\n * your data is captured in the item data or external stores like Flux, Redux, or Relay.\n * - This is a `PureComponent` which means that it will not re-render if `props` remain shallow-\n * equal. Make sure that everything your `renderItem` function depends on is passed as a prop\n * (e.g. `extraData`) that is not `===` after updates, otherwise your UI may not update on\n * changes. This includes the `data` prop and parent component state.\n * - In order to constrain memory and enable smooth scrolling, content is rendered asynchronously\n * offscreen. This means it's possible to scroll faster than the fill rate ands momentarily see\n * blank content. This is a tradeoff that can be adjusted to suit the needs of each application,\n * and we are working on improving it behind the scenes.\n * - By default, the list looks for a `key` prop on each item and uses that for the React key.\n * Alternatively, you can provide a custom `keyExtractor` prop.\n *\n * Also inherits [ScrollView Props](docs/scrollview.html#props), unless it is nested in another FlatList of same orientation.\n */\nclass FlatList extends React.PureComponent, void> {\n props: Props;\n /**\n * Scrolls to the end of the content. May be janky without `getItemLayout` prop.\n */\n scrollToEnd(params?: ?{animated?: ?boolean, ...}) {\n if (this._listRef) {\n this._listRef.scrollToEnd(params);\n }\n }\n\n /**\n * Scrolls to the item at the specified index such that it is positioned in the viewable area\n * such that `viewPosition` 0 places it at the top, 1 at the bottom, and 0.5 centered in the\n * middle. `viewOffset` is a fixed number of pixels to offset the final target position.\n *\n * Note: cannot scroll to locations outside the render window without specifying the\n * `getItemLayout` prop.\n */\n scrollToIndex(params: {\n animated?: ?boolean,\n index: number,\n viewOffset?: number,\n viewPosition?: number,\n ...\n }) {\n if (this._listRef) {\n this._listRef.scrollToIndex(params);\n }\n }\n\n /**\n * Requires linear scan through data - use `scrollToIndex` instead if possible.\n *\n * Note: cannot scroll to locations outside the render window without specifying the\n * `getItemLayout` prop.\n */\n scrollToItem(params: {\n animated?: ?boolean,\n item: ItemT,\n viewOffset?: number,\n viewPosition?: number,\n ...\n }) {\n if (this._listRef) {\n this._listRef.scrollToItem(params);\n }\n }\n\n /**\n * Scroll to a specific content pixel offset in the list.\n *\n * Check out [scrollToOffset](docs/virtualizedlist.html#scrolltooffset) of VirtualizedList\n */\n scrollToOffset(params: {animated?: ?boolean, offset: number, ...}) {\n if (this._listRef) {\n this._listRef.scrollToOffset(params);\n }\n }\n\n /**\n * Tells the list an interaction has occurred, which should trigger viewability calculations, e.g.\n * if `waitForInteractions` is true and the user has not scrolled. This is typically called by\n * taps on items or by navigation actions.\n */\n recordInteraction() {\n if (this._listRef) {\n this._listRef.recordInteraction();\n }\n }\n\n /**\n * Displays the scroll indicators momentarily.\n *\n * @platform ios\n */\n flashScrollIndicators() {\n if (this._listRef) {\n this._listRef.flashScrollIndicators();\n }\n }\n\n /**\n * Provides a handle to the underlying scroll responder.\n */\n getScrollResponder(): ?ScrollResponderType {\n if (this._listRef) {\n return this._listRef.getScrollResponder();\n }\n }\n\n /**\n * Provides a reference to the underlying host component\n */\n getNativeScrollRef():\n | ?React.ElementRef\n | ?React.ElementRef {\n if (this._listRef) {\n /* $FlowFixMe[incompatible-return] Suppresses errors found when fixing\n * TextInput typing */\n return this._listRef.getScrollRef();\n }\n }\n\n getScrollableNode(): any {\n if (this._listRef) {\n return this._listRef.getScrollableNode();\n }\n }\n\n setNativeProps(props: {[string]: mixed, ...}) {\n if (this._listRef) {\n this._listRef.setNativeProps(props);\n }\n }\n\n constructor(props: Props) {\n super(props);\n this._checkProps(this.props);\n if (this.props.viewabilityConfigCallbackPairs) {\n this._virtualizedListPairs =\n this.props.viewabilityConfigCallbackPairs.map(pair => ({\n viewabilityConfig: pair.viewabilityConfig,\n onViewableItemsChanged: this._createOnViewableItemsChanged(\n pair.onViewableItemsChanged,\n ),\n }));\n } else if (this.props.onViewableItemsChanged) {\n this._virtualizedListPairs.push({\n /* $FlowFixMe[incompatible-call] (>=0.63.0 site=react_native_fb) This\n * comment suppresses an error found when Flow v0.63 was deployed. To\n * see the error delete this comment and run Flow. */\n viewabilityConfig: this.props.viewabilityConfig,\n onViewableItemsChanged: this._createOnViewableItemsChanged(\n this.props.onViewableItemsChanged,\n ),\n });\n }\n }\n\n // $FlowFixMe[missing-local-annot]\n componentDidUpdate(prevProps: Props) {\n invariant(\n prevProps.numColumns === this.props.numColumns,\n 'Changing numColumns on the fly is not supported. Change the key prop on FlatList when ' +\n 'changing the number of columns to force a fresh render of the component.',\n );\n invariant(\n prevProps.onViewableItemsChanged === this.props.onViewableItemsChanged,\n 'Changing onViewableItemsChanged on the fly is not supported',\n );\n invariant(\n !deepDiffer(prevProps.viewabilityConfig, this.props.viewabilityConfig),\n 'Changing viewabilityConfig on the fly is not supported',\n );\n invariant(\n prevProps.viewabilityConfigCallbackPairs ===\n this.props.viewabilityConfigCallbackPairs,\n 'Changing viewabilityConfigCallbackPairs on the fly is not supported',\n );\n\n this._checkProps(this.props);\n }\n\n _listRef: ?React.ElementRef;\n _virtualizedListPairs: Array = [];\n\n _captureRef = (ref: ?React.ElementRef) => {\n this._listRef = ref;\n };\n\n // $FlowFixMe[missing-local-annot]\n _checkProps(props: Props) {\n const {\n // $FlowFixMe[prop-missing] this prop doesn't exist, is only used for an invariant\n getItem,\n // $FlowFixMe[prop-missing] this prop doesn't exist, is only used for an invariant\n getItemCount,\n horizontal,\n columnWrapperStyle,\n onViewableItemsChanged,\n viewabilityConfigCallbackPairs,\n } = props;\n const numColumns = numColumnsOrDefault(this.props.numColumns);\n invariant(\n !getItem && !getItemCount,\n 'FlatList does not support custom data formats.',\n );\n if (numColumns > 1) {\n invariant(!horizontal, 'numColumns does not support horizontal.');\n } else {\n invariant(\n !columnWrapperStyle,\n 'columnWrapperStyle not supported for single column lists',\n );\n }\n invariant(\n !(onViewableItemsChanged && viewabilityConfigCallbackPairs),\n 'FlatList does not support setting both onViewableItemsChanged and ' +\n 'viewabilityConfigCallbackPairs.',\n );\n }\n\n // $FlowFixMe[missing-local-annot]\n _getItem = (data: Array, index: number) => {\n const numColumns = numColumnsOrDefault(this.props.numColumns);\n if (numColumns > 1) {\n const ret = [];\n for (let kk = 0; kk < numColumns; kk++) {\n const itemIndex = index * numColumns + kk;\n if (itemIndex < data.length) {\n const item = data[itemIndex];\n ret.push(item);\n }\n }\n return ret;\n } else {\n return data[index];\n }\n };\n\n _getItemCount = (data: ?Array): number => {\n if (Array.isArray(data)) {\n const numColumns = numColumnsOrDefault(this.props.numColumns);\n return numColumns > 1 ? Math.ceil(data.length / numColumns) : data.length;\n } else {\n return 0;\n }\n };\n\n _keyExtractor = (items: ItemT | Array, index: number): string => {\n const numColumns = numColumnsOrDefault(this.props.numColumns);\n const keyExtractor = this.props.keyExtractor ?? defaultKeyExtractor;\n\n if (numColumns > 1) {\n invariant(\n Array.isArray(items),\n 'FlatList: Encountered internal consistency error, expected each item to consist of an ' +\n 'array with 1-%s columns; instead, received a single item.',\n numColumns,\n );\n return items\n .map((item, kk) =>\n keyExtractor(((item: $FlowFixMe): ItemT), index * numColumns + kk),\n )\n .join(':');\n }\n\n // $FlowFixMe[incompatible-call] Can't call keyExtractor with an array\n return keyExtractor(items, index);\n };\n\n _pushMultiColumnViewable(arr: Array, v: ViewToken): void {\n const numColumns = numColumnsOrDefault(this.props.numColumns);\n const keyExtractor = this.props.keyExtractor ?? defaultKeyExtractor;\n v.item.forEach((item, ii) => {\n invariant(v.index != null, 'Missing index!');\n const index = v.index * numColumns + ii;\n arr.push({...v, item, key: keyExtractor(item, index), index});\n });\n }\n\n _createOnViewableItemsChanged(\n onViewableItemsChanged: ?(info: {\n viewableItems: Array,\n changed: Array,\n ...\n }) => void,\n // $FlowFixMe[missing-local-annot]\n ) {\n return (info: {\n viewableItems: Array,\n changed: Array,\n ...\n }) => {\n const numColumns = numColumnsOrDefault(this.props.numColumns);\n if (onViewableItemsChanged) {\n if (numColumns > 1) {\n const changed: Array = [];\n const viewableItems: Array = [];\n info.viewableItems.forEach(v =>\n this._pushMultiColumnViewable(viewableItems, v),\n );\n info.changed.forEach(v => this._pushMultiColumnViewable(changed, v));\n onViewableItemsChanged({viewableItems, changed});\n } else {\n onViewableItemsChanged(info);\n }\n }\n };\n }\n\n _renderer = (\n ListItemComponent: ?(React.ComponentType | React.Element),\n renderItem: ?RenderItemType,\n columnWrapperStyle: ?ViewStyleProp,\n numColumns: ?number,\n extraData: ?any,\n // $FlowFixMe[missing-local-annot]\n ) => {\n const cols = numColumnsOrDefault(numColumns);\n\n const render = (props: RenderItemProps): React.Node => {\n if (ListItemComponent) {\n // $FlowFixMe[not-a-component] Component isn't valid\n // $FlowFixMe[incompatible-type-arg] Component isn't valid\n // $FlowFixMe[incompatible-return] Component isn't valid\n return ;\n } else if (renderItem) {\n // $FlowFixMe[incompatible-call]\n return renderItem(props);\n } else {\n return null;\n }\n };\n\n const renderProp = (info: RenderItemProps) => {\n if (cols > 1) {\n const {item, index} = info;\n invariant(\n Array.isArray(item),\n 'Expected array of items with numColumns > 1',\n );\n return (\n \n {item.map((it, kk) => {\n const element = render({\n // $FlowFixMe[incompatible-call]\n item: it,\n index: index * cols + kk,\n separators: info.separators,\n });\n return element != null ? (\n {element}\n ) : null;\n })}\n \n );\n } else {\n return render(info);\n }\n };\n\n return ListItemComponent\n ? {ListItemComponent: renderProp}\n : {renderItem: renderProp};\n };\n\n // $FlowFixMe[missing-local-annot]\n _memoizedRenderer = memoizeOne(this._renderer);\n\n render(): React.Node {\n const {\n numColumns,\n columnWrapperStyle,\n removeClippedSubviews: _removeClippedSubviews,\n strictMode = false,\n ...restProps\n } = this.props;\n\n const renderer = strictMode ? this._memoizedRenderer : this._renderer;\n\n return (\n // $FlowFixMe[incompatible-exact] - `restProps` (`Props`) is inexact.\n \n );\n }\n}\n\nconst styles = StyleSheet.create({\n row: {flexDirection: 'row'},\n});\n\nmodule.exports = FlatList;\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 * @flow\n * @format\n */\n\nimport type {ScrollResponderType} from '../Components/ScrollView/ScrollView';\nimport type {ViewStyleProp} from '../StyleSheet/StyleSheet';\nimport type {LayoutEvent, ScrollEvent} from '../Types/CoreEventTypes';\nimport type {ViewToken} from './ViewabilityHelper';\nimport type {\n FrameMetricProps,\n Item,\n Props,\n RenderItemProps,\n RenderItemType,\n Separators,\n} from './VirtualizedListProps';\n\nimport RefreshControl from '../Components/RefreshControl/RefreshControl';\nimport ScrollView from '../Components/ScrollView/ScrollView';\nimport View from '../Components/View/View';\nimport Batchinator from '../Interaction/Batchinator';\nimport {findNodeHandle} from '../ReactNative/RendererProxy';\nimport flattenStyle from '../StyleSheet/flattenStyle';\nimport StyleSheet from '../StyleSheet/StyleSheet';\nimport clamp from '../Utilities/clamp';\nimport infoLog from '../Utilities/infoLog';\nimport {CellRenderMask} from './CellRenderMask';\nimport ChildListCollection from './ChildListCollection';\nimport FillRateHelper from './FillRateHelper';\nimport StateSafePureComponent from './StateSafePureComponent';\nimport ViewabilityHelper from './ViewabilityHelper';\nimport CellRenderer from './VirtualizedListCellRenderer';\nimport {\n VirtualizedListCellContextProvider,\n VirtualizedListContext,\n VirtualizedListContextProvider,\n} from './VirtualizedListContext.js';\nimport {\n computeWindowedRenderLimits,\n keyExtractor as defaultKeyExtractor,\n} from './VirtualizeUtils';\nimport invariant from 'invariant';\nimport * as React from 'react';\n\nexport type {RenderItemProps, RenderItemType, Separators};\n\nconst ON_EDGE_REACHED_EPSILON = 0.001;\n\nlet _usedIndexForKey = false;\nlet _keylessItemComponentName: string = '';\n\ntype ViewabilityHelperCallbackTuple = {\n viewabilityHelper: ViewabilityHelper,\n onViewableItemsChanged: (info: {\n viewableItems: Array,\n changed: Array,\n ...\n }) => void,\n ...\n};\n\ntype State = {\n renderMask: CellRenderMask,\n cellsAroundViewport: {first: number, last: number},\n // Used to track items added at the start of the list for maintainVisibleContentPosition.\n firstItemKey: ?string,\n // When using maintainVisibleContentPosition we need to adjust the window to make sure\n // make sure that the visible elements are still rendered.\n maintainVisibleContentPositionAdjustment: ?number,\n};\n\n/**\n * Default Props Helper Functions\n * Use the following helper functions for default values\n */\n\n// horizontalOrDefault(this.props.horizontal)\nfunction horizontalOrDefault(horizontal: ?boolean) {\n return horizontal ?? false;\n}\n\n// initialNumToRenderOrDefault(this.props.initialNumToRenderOrDefault)\nfunction initialNumToRenderOrDefault(initialNumToRender: ?number) {\n return initialNumToRender ?? 10;\n}\n\n// maxToRenderPerBatchOrDefault(this.props.maxToRenderPerBatch)\nfunction maxToRenderPerBatchOrDefault(maxToRenderPerBatch: ?number) {\n return maxToRenderPerBatch ?? 10;\n}\n\n// onStartReachedThresholdOrDefault(this.props.onStartReachedThreshold)\nfunction onStartReachedThresholdOrDefault(onStartReachedThreshold: ?number) {\n return onStartReachedThreshold ?? 2;\n}\n\n// onEndReachedThresholdOrDefault(this.props.onEndReachedThreshold)\nfunction onEndReachedThresholdOrDefault(onEndReachedThreshold: ?number) {\n return onEndReachedThreshold ?? 2;\n}\n\n// getScrollingThreshold(visibleLength, onEndReachedThreshold)\nfunction getScrollingThreshold(threshold: number, visibleLength: number) {\n return (threshold * visibleLength) / 2;\n}\n\n// scrollEventThrottleOrDefault(this.props.scrollEventThrottle)\nfunction scrollEventThrottleOrDefault(scrollEventThrottle: ?number) {\n return scrollEventThrottle ?? 50;\n}\n\n// windowSizeOrDefault(this.props.windowSize)\nfunction windowSizeOrDefault(windowSize: ?number) {\n return windowSize ?? 21;\n}\n\nfunction findLastWhere(\n arr: $ReadOnlyArray,\n predicate: (element: T) => boolean,\n): T | null {\n for (let i = arr.length - 1; i >= 0; i--) {\n if (predicate(arr[i])) {\n return arr[i];\n }\n }\n\n return null;\n}\n\nfunction extractKey(\n props: {\n keyExtractor?: ?(item: Item, index: number) => string,\n ...\n },\n item: Item,\n index: number,\n): string {\n if (props.keyExtractor != null) {\n return props.keyExtractor(item, index);\n }\n\n const key = defaultKeyExtractor(item, index);\n if (key === String(index)) {\n _usedIndexForKey = true;\n if (item.type && item.type.displayName) {\n _keylessItemComponentName = item.type.displayName;\n }\n }\n return key;\n}\n\nfunction findItemIndexWithKey(props: Props, key: string): ?number {\n for (let ii = 0; ii < props.getItemCount(props.data); ii++) {\n const item = props.getItem(props.data, ii);\n const curKey = extractKey(props, item, ii);\n if (curKey === key) {\n return ii;\n }\n }\n return null;\n}\n\nfunction getItemKey(props: Props, index: number): ?string {\n const item = props.getItem(props.data, index);\n if (item == null) {\n return null;\n }\n return extractKey(props, item, 0);\n}\n\n/**\n * Base implementation for the more convenient [``](https://reactnative.dev/docs/flatlist)\n * and [``](https://reactnative.dev/docs/sectionlist) components, which are also better\n * documented. In general, this should only really be used if you need more flexibility than\n * `FlatList` provides, e.g. for use with immutable data instead of plain arrays.\n *\n * Virtualization massively improves memory consumption and performance of large lists by\n * maintaining a finite render window of active items and replacing all items outside of the render\n * window with appropriately sized blank space. The window adapts to scrolling behavior, and items\n * are rendered incrementally with low-pri (after any running interactions) if they are far from the\n * visible area, or with hi-pri otherwise to minimize the potential of seeing blank space.\n *\n * Some caveats:\n *\n * - Internal state is not preserved when content scrolls out of the render window. Make sure all\n * your data is captured in the item data or external stores like Flux, Redux, or Relay.\n * - This is a `PureComponent` which means that it will not re-render if `props` remain shallow-\n * equal. Make sure that everything your `renderItem` function depends on is passed as a prop\n * (e.g. `extraData`) that is not `===` after updates, otherwise your UI may not update on\n * changes. This includes the `data` prop and parent component state.\n * - In order to constrain memory and enable smooth scrolling, content is rendered asynchronously\n * offscreen. This means it's possible to scroll faster than the fill rate ands momentarily see\n * blank content. This is a tradeoff that can be adjusted to suit the needs of each application,\n * and we are working on improving it behind the scenes.\n * - By default, the list looks for a `key` or `id` prop on each item and uses that for the React key.\n * Alternatively, you can provide a custom `keyExtractor` prop.\n * - As an effort to remove defaultProps, use helper functions when referencing certain props\n *\n */\nexport default class VirtualizedList extends StateSafePureComponent<\n Props,\n State,\n> {\n static contextType: typeof VirtualizedListContext = VirtualizedListContext;\n\n // scrollToEnd may be janky without getItemLayout prop\n scrollToEnd(params?: ?{animated?: ?boolean, ...}) {\n const animated = params ? params.animated : true;\n const veryLast = this.props.getItemCount(this.props.data) - 1;\n const frame = this.__getFrameMetricsApprox(veryLast, this.props);\n const offset = Math.max(\n 0,\n frame.offset +\n frame.length +\n this._footerLength -\n this._scrollMetrics.visibleLength,\n );\n\n if (this._scrollRef == null) {\n return;\n }\n\n if (this._scrollRef.scrollTo == null) {\n console.warn(\n 'No scrollTo method provided. This may be because you have two nested ' +\n 'VirtualizedLists with the same orientation, or because you are ' +\n 'using a custom component that does not implement scrollTo.',\n );\n return;\n }\n\n this._scrollRef.scrollTo(\n horizontalOrDefault(this.props.horizontal)\n ? {x: offset, animated}\n : {y: offset, animated},\n );\n }\n\n // scrollToIndex may be janky without getItemLayout prop\n scrollToIndex(params: {\n animated?: ?boolean,\n index: number,\n viewOffset?: number,\n viewPosition?: number,\n ...\n }): $FlowFixMe {\n const {\n data,\n horizontal,\n getItemCount,\n getItemLayout,\n onScrollToIndexFailed,\n } = this.props;\n const {animated, index, viewOffset, viewPosition} = params;\n invariant(\n index >= 0,\n `scrollToIndex out of range: requested index ${index} but minimum is 0`,\n );\n invariant(\n getItemCount(data) >= 1,\n `scrollToIndex out of range: item length ${getItemCount(\n data,\n )} but minimum is 1`,\n );\n invariant(\n index < getItemCount(data),\n `scrollToIndex out of range: requested index ${index} is out of 0 to ${\n getItemCount(data) - 1\n }`,\n );\n if (!getItemLayout && index > this._highestMeasuredFrameIndex) {\n invariant(\n !!onScrollToIndexFailed,\n 'scrollToIndex should be used in conjunction with getItemLayout or onScrollToIndexFailed, ' +\n 'otherwise there is no way to know the location of offscreen indices or handle failures.',\n );\n onScrollToIndexFailed({\n averageItemLength: this._averageCellLength,\n highestMeasuredFrameIndex: this._highestMeasuredFrameIndex,\n index,\n });\n return;\n }\n const frame = this.__getFrameMetricsApprox(Math.floor(index), this.props);\n const offset =\n Math.max(\n 0,\n this._getOffsetApprox(index, this.props) -\n (viewPosition || 0) *\n (this._scrollMetrics.visibleLength - frame.length),\n ) - (viewOffset || 0);\n\n if (this._scrollRef == null) {\n return;\n }\n\n if (this._scrollRef.scrollTo == null) {\n console.warn(\n 'No scrollTo method provided. This may be because you have two nested ' +\n 'VirtualizedLists with the same orientation, or because you are ' +\n 'using a custom component that does not implement scrollTo.',\n );\n return;\n }\n\n this._scrollRef.scrollTo(\n horizontal ? {x: offset, animated} : {y: offset, animated},\n );\n }\n\n // scrollToItem may be janky without getItemLayout prop. Required linear scan through items -\n // use scrollToIndex instead if possible.\n scrollToItem(params: {\n animated?: ?boolean,\n item: Item,\n viewOffset?: number,\n viewPosition?: number,\n ...\n }) {\n const {item} = params;\n const {data, getItem, getItemCount} = this.props;\n const itemCount = getItemCount(data);\n for (let index = 0; index < itemCount; index++) {\n if (getItem(data, index) === item) {\n this.scrollToIndex({...params, index});\n break;\n }\n }\n }\n\n /**\n * Scroll to a specific content pixel offset in the list.\n *\n * Param `offset` expects the offset to scroll to.\n * In case of `horizontal` is true, the offset is the x-value,\n * in any other case the offset is the y-value.\n *\n * Param `animated` (`true` by default) defines whether the list\n * should do an animation while scrolling.\n */\n scrollToOffset(params: {animated?: ?boolean, offset: number, ...}) {\n const {animated, offset} = params;\n\n if (this._scrollRef == null) {\n return;\n }\n\n if (this._scrollRef.scrollTo == null) {\n console.warn(\n 'No scrollTo method provided. This may be because you have two nested ' +\n 'VirtualizedLists with the same orientation, or because you are ' +\n 'using a custom component that does not implement scrollTo.',\n );\n return;\n }\n\n this._scrollRef.scrollTo(\n horizontalOrDefault(this.props.horizontal)\n ? {x: offset, animated}\n : {y: offset, animated},\n );\n }\n\n recordInteraction() {\n this._nestedChildLists.forEach(childList => {\n childList.recordInteraction();\n });\n this._viewabilityTuples.forEach(t => {\n t.viewabilityHelper.recordInteraction();\n });\n this._updateViewableItems(this.props, this.state.cellsAroundViewport);\n }\n\n flashScrollIndicators() {\n if (this._scrollRef == null) {\n return;\n }\n\n this._scrollRef.flashScrollIndicators();\n }\n\n /**\n * Provides a handle to the underlying scroll responder.\n * Note that `this._scrollRef` might not be a `ScrollView`, so we\n * need to check that it responds to `getScrollResponder` before calling it.\n */\n getScrollResponder(): ?ScrollResponderType {\n if (this._scrollRef && this._scrollRef.getScrollResponder) {\n return this._scrollRef.getScrollResponder();\n }\n }\n\n getScrollableNode(): ?number {\n if (this._scrollRef && this._scrollRef.getScrollableNode) {\n return this._scrollRef.getScrollableNode();\n } else {\n return findNodeHandle(this._scrollRef);\n }\n }\n\n getScrollRef():\n | ?React.ElementRef\n | ?React.ElementRef {\n if (this._scrollRef && this._scrollRef.getScrollRef) {\n return this._scrollRef.getScrollRef();\n } else {\n return this._scrollRef;\n }\n }\n\n setNativeProps(props: Object) {\n if (this._scrollRef) {\n this._scrollRef.setNativeProps(props);\n }\n }\n\n _getCellKey(): string {\n return this.context?.cellKey || 'rootList';\n }\n\n // $FlowFixMe[missing-local-annot]\n _getScrollMetrics = () => {\n return this._scrollMetrics;\n };\n\n hasMore(): boolean {\n return this._hasMore;\n }\n\n // $FlowFixMe[missing-local-annot]\n _getOutermostParentListRef = () => {\n if (this._isNestedWithSameOrientation()) {\n return this.context.getOutermostParentListRef();\n } else {\n return this;\n }\n };\n\n _registerAsNestedChild = (childList: {\n cellKey: string,\n ref: React.ElementRef,\n }): void => {\n this._nestedChildLists.add(childList.ref, childList.cellKey);\n if (this._hasInteracted) {\n childList.ref.recordInteraction();\n }\n };\n\n _unregisterAsNestedChild = (childList: {\n ref: React.ElementRef,\n }): void => {\n this._nestedChildLists.remove(childList.ref);\n };\n\n state: State;\n\n constructor(props: Props) {\n super(props);\n invariant(\n // $FlowFixMe[prop-missing]\n !props.onScroll || !props.onScroll.__isNative,\n 'Components based on VirtualizedList must be wrapped with Animated.createAnimatedComponent ' +\n 'to support native onScroll events with useNativeDriver',\n );\n invariant(\n windowSizeOrDefault(props.windowSize) > 0,\n 'VirtualizedList: The windowSize prop must be present and set to a value greater than 0.',\n );\n\n invariant(\n props.getItemCount,\n 'VirtualizedList: The \"getItemCount\" prop must be provided',\n );\n\n this._fillRateHelper = new FillRateHelper(this._getFrameMetrics);\n this._updateCellsToRenderBatcher = new Batchinator(\n this._updateCellsToRender,\n this.props.updateCellsBatchingPeriod ?? 50,\n );\n\n if (this.props.viewabilityConfigCallbackPairs) {\n this._viewabilityTuples = this.props.viewabilityConfigCallbackPairs.map(\n pair => ({\n viewabilityHelper: new ViewabilityHelper(pair.viewabilityConfig),\n onViewableItemsChanged: pair.onViewableItemsChanged,\n }),\n );\n } else {\n const {onViewableItemsChanged, viewabilityConfig} = this.props;\n if (onViewableItemsChanged) {\n this._viewabilityTuples.push({\n viewabilityHelper: new ViewabilityHelper(viewabilityConfig),\n onViewableItemsChanged: onViewableItemsChanged,\n });\n }\n }\n\n invariant(\n !this.context,\n 'Unexpectedly saw VirtualizedListContext available in ctor',\n );\n\n const initialRenderRegion = VirtualizedList._initialRenderRegion(props);\n\n this.state = {\n cellsAroundViewport: initialRenderRegion,\n renderMask: VirtualizedList._createRenderMask(\n props,\n initialRenderRegion,\n null,\n ),\n firstItemKey: getItemKey(this.props, 0),\n maintainVisibleContentPositionAdjustment: null,\n };\n }\n\n static _createRenderMask(\n props: Props,\n cellsAroundViewport: {first: number, last: number},\n maintainVisibleContentPositionAdjustment: ?number,\n additionalRegions?: ?$ReadOnlyArray<{first: number, last: number}>,\n ): CellRenderMask {\n const itemCount = props.getItemCount(props.data);\n\n invariant(\n cellsAroundViewport.first >= 0 &&\n cellsAroundViewport.last >= cellsAroundViewport.first - 1 &&\n cellsAroundViewport.last < itemCount,\n `Invalid cells around viewport \"[${cellsAroundViewport.first}, ${cellsAroundViewport.last}]\" was passed to VirtualizedList._createRenderMask`,\n );\n\n const renderMask = new CellRenderMask(itemCount);\n\n if (itemCount > 0) {\n const allRegions = [cellsAroundViewport, ...(additionalRegions ?? [])];\n for (const region of allRegions) {\n renderMask.addCells(region);\n }\n\n // The initially rendered cells are retained as part of the\n // \"scroll-to-top\" optimization\n if (props.initialScrollIndex == null || props.initialScrollIndex <= 0) {\n const initialRegion = VirtualizedList._initialRenderRegion(props);\n renderMask.addCells(initialRegion);\n }\n\n // The layout coordinates of sticker headers may be off-screen while the\n // actual header is on-screen. Keep the most recent before the viewport\n // rendered, even if its layout coordinates are not in viewport.\n const stickyIndicesSet = new Set(props.stickyHeaderIndices);\n VirtualizedList._ensureClosestStickyHeader(\n props,\n stickyIndicesSet,\n renderMask,\n cellsAroundViewport.first,\n );\n\n if (maintainVisibleContentPositionAdjustment != null) {\n renderMask.addCells({\n first:\n cellsAroundViewport.first +\n maintainVisibleContentPositionAdjustment,\n last:\n cellsAroundViewport.last + maintainVisibleContentPositionAdjustment,\n });\n }\n }\n\n return renderMask;\n }\n\n static _initialRenderRegion(props: Props): {first: number, last: number} {\n const itemCount = props.getItemCount(props.data);\n const scrollIndex = Math.floor(Math.max(0, props.initialScrollIndex ?? 0));\n\n return {\n first: scrollIndex,\n last:\n Math.min(\n itemCount,\n scrollIndex + initialNumToRenderOrDefault(props.initialNumToRender),\n ) - 1,\n };\n }\n\n static _ensureClosestStickyHeader(\n props: Props,\n stickyIndicesSet: Set,\n renderMask: CellRenderMask,\n cellIdx: number,\n ) {\n const stickyOffset = props.ListHeaderComponent ? 1 : 0;\n\n for (let itemIdx = cellIdx - 1; itemIdx >= 0; itemIdx--) {\n if (stickyIndicesSet.has(itemIdx + stickyOffset)) {\n renderMask.addCells({first: itemIdx, last: itemIdx});\n break;\n }\n }\n }\n\n _adjustCellsAroundViewport(\n props: Props,\n cellsAroundViewport: {first: number, last: number},\n ): {first: number, last: number} {\n const {data, getItemCount} = props;\n const onEndReachedThreshold = onEndReachedThresholdOrDefault(\n props.onEndReachedThreshold,\n );\n\n const {contentLength, offset, visibleLength} = this._scrollMetrics;\n const distanceFromEnd = contentLength - visibleLength - offset;\n\n // Wait until the scroll view metrics have been set up. And until then,\n // we will trust the initialNumToRender suggestion\n if (visibleLength <= 0 || contentLength <= 0) {\n return cellsAroundViewport.last >= getItemCount(data)\n ? VirtualizedList._constrainToItemCount(cellsAroundViewport, props)\n : cellsAroundViewport;\n }\n\n let newCellsAroundViewport: {first: number, last: number};\n if (props.disableVirtualization) {\n const renderAhead =\n distanceFromEnd < onEndReachedThreshold * visibleLength\n ? maxToRenderPerBatchOrDefault(props.maxToRenderPerBatch)\n : 0;\n\n newCellsAroundViewport = {\n first: 0,\n last: Math.min(\n cellsAroundViewport.last + renderAhead,\n getItemCount(data) - 1,\n ),\n };\n } else {\n // If we have a non-zero initialScrollIndex and run this before we've scrolled,\n // we'll wipe out the initialNumToRender rendered elements starting at initialScrollIndex.\n // So let's wait until we've scrolled the view to the right place. And until then,\n // we will trust the initialScrollIndex suggestion.\n\n // Thus, we want to recalculate the windowed render limits if any of the following hold:\n // - initialScrollIndex is undefined or is 0\n // - initialScrollIndex > 0 AND scrolling is complete\n // - initialScrollIndex > 0 AND the end of the list is visible (this handles the case\n // where the list is shorter than the visible area)\n if (\n props.initialScrollIndex &&\n !this._scrollMetrics.offset &&\n Math.abs(distanceFromEnd) >= Number.EPSILON\n ) {\n return cellsAroundViewport.last >= getItemCount(data)\n ? VirtualizedList._constrainToItemCount(cellsAroundViewport, props)\n : cellsAroundViewport;\n }\n\n newCellsAroundViewport = computeWindowedRenderLimits(\n props,\n maxToRenderPerBatchOrDefault(props.maxToRenderPerBatch),\n windowSizeOrDefault(props.windowSize),\n cellsAroundViewport,\n this.__getFrameMetricsApprox,\n this._scrollMetrics,\n );\n invariant(\n newCellsAroundViewport.last < getItemCount(data),\n 'computeWindowedRenderLimits() should return range in-bounds',\n );\n }\n\n if (this._nestedChildLists.size() > 0) {\n // If some cell in the new state has a child list in it, we should only render\n // up through that item, so that we give that list a chance to render.\n // Otherwise there's churn from multiple child lists mounting and un-mounting\n // their items.\n\n // Will this prevent rendering if the nested list doesn't realize the end?\n const childIdx = this._findFirstChildWithMore(\n newCellsAroundViewport.first,\n newCellsAroundViewport.last,\n );\n\n newCellsAroundViewport.last = childIdx ?? newCellsAroundViewport.last;\n }\n\n return newCellsAroundViewport;\n }\n\n _findFirstChildWithMore(first: number, last: number): number | null {\n for (let ii = first; ii <= last; ii++) {\n const cellKeyForIndex = this._indicesToKeys.get(ii);\n if (\n cellKeyForIndex != null &&\n this._nestedChildLists.anyInCell(cellKeyForIndex, childList =>\n childList.hasMore(),\n )\n ) {\n return ii;\n }\n }\n\n return null;\n }\n\n componentDidMount() {\n if (this._isNestedWithSameOrientation()) {\n this.context.registerAsNestedChild({\n ref: this,\n cellKey: this.context.cellKey,\n });\n }\n }\n\n componentWillUnmount() {\n if (this._isNestedWithSameOrientation()) {\n this.context.unregisterAsNestedChild({ref: this});\n }\n this._updateCellsToRenderBatcher.dispose({abort: true});\n this._viewabilityTuples.forEach(tuple => {\n tuple.viewabilityHelper.dispose();\n });\n this._fillRateHelper.deactivateAndFlush();\n }\n\n static getDerivedStateFromProps(newProps: Props, prevState: State): State {\n // first and last could be stale (e.g. if a new, shorter items props is passed in), so we make\n // sure we're rendering a reasonable range here.\n const itemCount = newProps.getItemCount(newProps.data);\n if (itemCount === prevState.renderMask.numCells()) {\n return prevState;\n }\n\n let maintainVisibleContentPositionAdjustment =\n prevState.maintainVisibleContentPositionAdjustment;\n const newFirstItemKey = getItemKey(newProps, 0);\n if (\n newProps.maintainVisibleContentPosition != null &&\n maintainVisibleContentPositionAdjustment == null &&\n prevState.firstItemKey != null &&\n newFirstItemKey != null\n ) {\n maintainVisibleContentPositionAdjustment =\n newFirstItemKey !== prevState.firstItemKey\n ? findItemIndexWithKey(newProps, prevState.firstItemKey)\n : null;\n }\n\n const constrainedCells = VirtualizedList._constrainToItemCount(\n prevState.cellsAroundViewport,\n newProps,\n );\n\n return {\n cellsAroundViewport: constrainedCells,\n renderMask: VirtualizedList._createRenderMask(\n newProps,\n constrainedCells,\n maintainVisibleContentPositionAdjustment,\n ),\n firstItemKey: newFirstItemKey,\n maintainVisibleContentPositionAdjustment,\n };\n }\n\n _pushCells(\n cells: Array,\n stickyHeaderIndices: Array,\n stickyIndicesFromProps: Set,\n first: number,\n last: number,\n inversionStyle: ViewStyleProp,\n ) {\n const {\n CellRendererComponent,\n ItemSeparatorComponent,\n ListHeaderComponent,\n ListItemComponent,\n data,\n debug,\n getItem,\n getItemCount,\n getItemLayout,\n horizontal,\n renderItem,\n } = this.props;\n const stickyOffset = ListHeaderComponent ? 1 : 0;\n const end = getItemCount(data) - 1;\n let prevCellKey;\n last = Math.min(end, last);\n for (let ii = first; ii <= last; ii++) {\n const item = getItem(data, ii);\n const key = extractKey(this.props, item, ii);\n this._indicesToKeys.set(ii, key);\n if (stickyIndicesFromProps.has(ii + stickyOffset)) {\n stickyHeaderIndices.push(cells.length);\n }\n cells.push(\n this._onCellFocusCapture(key)}\n onUnmount={this._onCellUnmount}\n ref={ref => {\n this._cellRefs[key] = ref;\n }}\n renderItem={renderItem}\n />,\n );\n prevCellKey = key;\n }\n }\n\n static _constrainToItemCount(\n cells: {first: number, last: number},\n props: Props,\n ): {first: number, last: number} {\n const itemCount = props.getItemCount(props.data);\n const last = Math.min(itemCount - 1, cells.last);\n\n const maxToRenderPerBatch = maxToRenderPerBatchOrDefault(\n props.maxToRenderPerBatch,\n );\n\n return {\n first: clamp(0, itemCount - 1 - maxToRenderPerBatch, cells.first),\n last,\n };\n }\n\n _onUpdateSeparators = (keys: Array, newProps: Object) => {\n keys.forEach(key => {\n const ref = key != null && this._cellRefs[key];\n ref && ref.updateSeparatorProps(newProps);\n });\n };\n\n _isNestedWithSameOrientation(): boolean {\n const nestedContext = this.context;\n return !!(\n nestedContext &&\n !!nestedContext.horizontal === horizontalOrDefault(this.props.horizontal)\n );\n }\n\n _getSpacerKey = (isVertical: boolean): string =>\n isVertical ? 'height' : 'width';\n\n render(): React.Node {\n if (__DEV__) {\n const flatStyles = flattenStyle(this.props.contentContainerStyle);\n if (flatStyles != null && flatStyles.flexWrap === 'wrap') {\n console.warn(\n '`flexWrap: `wrap`` is not supported with the `VirtualizedList` components.' +\n 'Consider using `numColumns` with `FlatList` instead.',\n );\n }\n }\n const {ListEmptyComponent, ListFooterComponent, ListHeaderComponent} =\n this.props;\n const {data, horizontal} = this.props;\n const inversionStyle = this.props.inverted\n ? horizontalOrDefault(this.props.horizontal)\n ? styles.horizontallyInverted\n : styles.verticallyInverted\n : null;\n const cells: Array = [];\n const stickyIndicesFromProps = new Set(this.props.stickyHeaderIndices);\n const stickyHeaderIndices = [];\n\n // 1. Add cell for ListHeaderComponent\n if (ListHeaderComponent) {\n if (stickyIndicesFromProps.has(0)) {\n stickyHeaderIndices.push(0);\n }\n const element = React.isValidElement(ListHeaderComponent) ? (\n ListHeaderComponent\n ) : (\n // $FlowFixMe[not-a-component]\n // $FlowFixMe[incompatible-type-arg]\n \n );\n cells.push(\n \n \n {\n // $FlowFixMe[incompatible-type] - Typing ReactNativeComponent revealed errors\n element\n }\n \n ,\n );\n }\n\n // 2a. Add a cell for ListEmptyComponent if applicable\n const itemCount = this.props.getItemCount(data);\n if (itemCount === 0 && ListEmptyComponent) {\n const element: React.Element = ((React.isValidElement(\n ListEmptyComponent,\n ) ? (\n ListEmptyComponent\n ) : (\n // $FlowFixMe[not-a-component]\n // $FlowFixMe[incompatible-type-arg]\n \n )): any);\n cells.push(\n \n {React.cloneElement(element, {\n onLayout: (event: LayoutEvent) => {\n this._onLayoutEmpty(event);\n if (element.props.onLayout) {\n element.props.onLayout(event);\n }\n },\n style: StyleSheet.compose(inversionStyle, element.props.style),\n })}\n ,\n );\n }\n\n // 2b. Add cells and spacers for each item\n if (itemCount > 0) {\n _usedIndexForKey = false;\n _keylessItemComponentName = '';\n const spacerKey = this._getSpacerKey(!horizontal);\n\n const renderRegions = this.state.renderMask.enumerateRegions();\n const lastSpacer = findLastWhere(renderRegions, r => r.isSpacer);\n\n for (const section of renderRegions) {\n if (section.isSpacer) {\n // Legacy behavior is to avoid spacers when virtualization is\n // disabled (including head spacers on initial render).\n if (this.props.disableVirtualization) {\n continue;\n }\n\n // Without getItemLayout, we limit our tail spacer to the _highestMeasuredFrameIndex to\n // prevent the user for hyperscrolling into un-measured area because otherwise content will\n // likely jump around as it renders in above the viewport.\n const isLastSpacer = section === lastSpacer;\n const constrainToMeasured = isLastSpacer && !this.props.getItemLayout;\n const last = constrainToMeasured\n ? clamp(\n section.first - 1,\n section.last,\n this._highestMeasuredFrameIndex,\n )\n : section.last;\n\n const firstMetrics = this.__getFrameMetricsApprox(\n section.first,\n this.props,\n );\n const lastMetrics = this.__getFrameMetricsApprox(last, this.props);\n const spacerSize =\n lastMetrics.offset + lastMetrics.length - firstMetrics.offset;\n cells.push(\n ,\n );\n } else {\n this._pushCells(\n cells,\n stickyHeaderIndices,\n stickyIndicesFromProps,\n section.first,\n section.last,\n inversionStyle,\n );\n }\n }\n\n if (!this._hasWarned.keys && _usedIndexForKey) {\n console.warn(\n 'VirtualizedList: missing keys for items, make sure to specify a key or id property on each ' +\n 'item or provide a custom keyExtractor.',\n _keylessItemComponentName,\n );\n this._hasWarned.keys = true;\n }\n }\n\n // 3. Add cell for ListFooterComponent\n if (ListFooterComponent) {\n const element = React.isValidElement(ListFooterComponent) ? (\n ListFooterComponent\n ) : (\n // $FlowFixMe[not-a-component]\n // $FlowFixMe[incompatible-type-arg]\n \n );\n cells.push(\n \n \n {\n // $FlowFixMe[incompatible-type] - Typing ReactNativeComponent revealed errors\n element\n }\n \n ,\n );\n }\n\n // 4. Render the ScrollView\n const scrollProps = {\n ...this.props,\n onContentSizeChange: this._onContentSizeChange,\n onLayout: this._onLayout,\n onScroll: this._onScroll,\n onScrollBeginDrag: this._onScrollBeginDrag,\n onScrollEndDrag: this._onScrollEndDrag,\n onMomentumScrollBegin: this._onMomentumScrollBegin,\n onMomentumScrollEnd: this._onMomentumScrollEnd,\n scrollEventThrottle: scrollEventThrottleOrDefault(\n this.props.scrollEventThrottle,\n ), // TODO: Android support\n invertStickyHeaders:\n this.props.invertStickyHeaders !== undefined\n ? this.props.invertStickyHeaders\n : this.props.inverted,\n stickyHeaderIndices,\n style: inversionStyle\n ? [inversionStyle, this.props.style]\n : this.props.style,\n };\n\n this._hasMore = this.state.cellsAroundViewport.last < itemCount - 1;\n\n const innerRet = (\n \n {React.cloneElement(\n (\n this.props.renderScrollComponent ||\n this._defaultRenderScrollComponent\n )(scrollProps),\n {\n ref: this._captureScrollRef,\n },\n cells,\n )}\n \n );\n let ret: React.Node = innerRet;\n if (__DEV__) {\n ret = (\n \n {scrollContext => {\n if (\n scrollContext != null &&\n !scrollContext.horizontal ===\n !horizontalOrDefault(this.props.horizontal) &&\n !this._hasWarned.nesting &&\n this.context == null &&\n this.props.scrollEnabled !== false\n ) {\n // TODO (T46547044): use React.warn once 16.9 is sync'd: https://github.com/facebook/react/pull/15170\n console.error(\n 'VirtualizedLists should never be nested inside plain ScrollViews with the same ' +\n 'orientation because it can break windowing and other functionality - use another ' +\n 'VirtualizedList-backed container instead.',\n );\n this._hasWarned.nesting = true;\n }\n return innerRet;\n }}\n \n );\n }\n if (this.props.debug) {\n return (\n \n {ret}\n {this._renderDebugOverlay()}\n \n );\n } else {\n return ret;\n }\n }\n\n componentDidUpdate(prevProps: Props, prevState: State) {\n const {data, extraData} = this.props;\n if (data !== prevProps.data || extraData !== prevProps.extraData) {\n // clear the viewableIndices cache to also trigger\n // the onViewableItemsChanged callback with the new data\n this._viewabilityTuples.forEach(tuple => {\n tuple.viewabilityHelper.resetViewableIndices();\n });\n }\n // The `this._hiPriInProgress` is guaranteeing a hiPri cell update will only happen\n // once per fiber update. The `_scheduleCellsToRenderUpdate` will set it to true\n // if a hiPri update needs to perform. If `componentDidUpdate` is triggered with\n // `this._hiPriInProgress=true`, means it's triggered by the hiPri update. The\n // `_scheduleCellsToRenderUpdate` will check this condition and not perform\n // another hiPri update.\n const hiPriInProgress = this._hiPriInProgress;\n this._scheduleCellsToRenderUpdate();\n // Make sure setting `this._hiPriInProgress` back to false after `componentDidUpdate`\n // is triggered with `this._hiPriInProgress = true`\n if (hiPriInProgress) {\n this._hiPriInProgress = false;\n }\n\n // Make sure to cancel any pending updates if maintainVisibleContentPositionAdjustment\n // changed since they are now invalid.\n if (\n prevState.maintainVisibleContentPositionAdjustment !==\n this.state.maintainVisibleContentPositionAdjustment\n ) {\n this._updateCellsToRenderBatcher.dispose({abort: true});\n }\n }\n\n _averageCellLength = 0;\n _cellRefs: {[string]: null | CellRenderer} = {};\n _fillRateHelper: FillRateHelper;\n _frames: {\n [string]: {\n inLayout?: boolean,\n index: number,\n length: number,\n offset: number,\n },\n } = {};\n _footerLength = 0;\n // Used for preventing scrollToIndex from being called multiple times for initialScrollIndex\n _hasTriggeredInitialScrollToIndex = false;\n _hasInteracted = false;\n _hasMore = false;\n _hasWarned: {[string]: boolean} = {};\n _headerLength = 0;\n _hiPriInProgress: boolean = false; // flag to prevent infinite hiPri cell limit update\n _highestMeasuredFrameIndex = 0;\n _indicesToKeys: Map = new Map();\n _lastFocusedCellKey: ?string = null;\n _nestedChildLists: ChildListCollection =\n new ChildListCollection();\n _offsetFromParentVirtualizedList: number = 0;\n _prevParentOffset: number = 0;\n // $FlowFixMe[missing-local-annot]\n _scrollMetrics = {\n contentLength: 0,\n dOffset: 0,\n dt: 10,\n offset: 0,\n timestamp: 0,\n velocity: 0,\n visibleLength: 0,\n zoomScale: 1,\n };\n _scrollRef: ?React.ElementRef = null;\n _sentStartForContentLength = 0;\n _sentEndForContentLength = 0;\n _totalCellLength = 0;\n _totalCellsMeasured = 0;\n _updateCellsToRenderBatcher: Batchinator;\n _viewabilityTuples: Array = [];\n\n /* $FlowFixMe[missing-local-annot] The type annotation(s) required by Flow's\n * LTI update could not be added via codemod */\n _captureScrollRef = ref => {\n this._scrollRef = ref;\n };\n\n _computeBlankness() {\n this._fillRateHelper.computeBlankness(\n this.props,\n this.state.cellsAroundViewport,\n this._scrollMetrics,\n );\n }\n\n /* $FlowFixMe[missing-local-annot] The type annotation(s) required by Flow's\n * LTI update could not be added via codemod */\n _defaultRenderScrollComponent = props => {\n const onRefresh = props.onRefresh;\n if (this._isNestedWithSameOrientation()) {\n // $FlowFixMe[prop-missing] - Typing ReactNativeComponent revealed errors\n return ;\n } else if (onRefresh) {\n invariant(\n typeof props.refreshing === 'boolean',\n '`refreshing` prop must be set as a boolean in order to use `onRefresh`, but got `' +\n JSON.stringify(props.refreshing ?? 'undefined') +\n '`',\n );\n return (\n // $FlowFixMe[prop-missing] Invalid prop usage\n // $FlowFixMe[incompatible-use]\n \n ) : (\n props.refreshControl\n )\n }\n />\n );\n } else {\n // $FlowFixMe[prop-missing] Invalid prop usage\n // $FlowFixMe[incompatible-use]\n return ;\n }\n };\n\n _onCellLayout = (e: LayoutEvent, cellKey: string, index: number): void => {\n const layout = e.nativeEvent.layout;\n const next = {\n offset: this._selectOffset(layout),\n length: this._selectLength(layout),\n index,\n inLayout: true,\n };\n const curr = this._frames[cellKey];\n if (\n !curr ||\n next.offset !== curr.offset ||\n next.length !== curr.length ||\n index !== curr.index\n ) {\n this._totalCellLength += next.length - (curr ? curr.length : 0);\n this._totalCellsMeasured += curr ? 0 : 1;\n this._averageCellLength =\n this._totalCellLength / this._totalCellsMeasured;\n this._frames[cellKey] = next;\n this._highestMeasuredFrameIndex = Math.max(\n this._highestMeasuredFrameIndex,\n index,\n );\n this._scheduleCellsToRenderUpdate();\n } else {\n this._frames[cellKey].inLayout = true;\n }\n\n this._triggerRemeasureForChildListsInCell(cellKey);\n\n this._computeBlankness();\n this._updateViewableItems(this.props, this.state.cellsAroundViewport);\n };\n\n _onCellFocusCapture(cellKey: string) {\n this._lastFocusedCellKey = cellKey;\n const renderMask = VirtualizedList._createRenderMask(\n this.props,\n this.state.cellsAroundViewport,\n this.state.maintainVisibleContentPositionAdjustment,\n this._getNonViewportRenderRegions(this.props),\n );\n\n this.setState(state => {\n if (!renderMask.equals(state.renderMask)) {\n return {renderMask};\n }\n return null;\n });\n }\n\n _onCellUnmount = (cellKey: string) => {\n const curr = this._frames[cellKey];\n if (curr) {\n this._frames[cellKey] = {...curr, inLayout: false};\n }\n };\n\n _triggerRemeasureForChildListsInCell(cellKey: string): void {\n this._nestedChildLists.forEachInCell(cellKey, childList => {\n childList.measureLayoutRelativeToContainingList();\n });\n }\n\n measureLayoutRelativeToContainingList(): void {\n // TODO (T35574538): findNodeHandle sometimes crashes with \"Unable to find\n // node on an unmounted component\" during scrolling\n try {\n if (!this._scrollRef) {\n return;\n }\n // We are assuming that getOutermostParentListRef().getScrollRef()\n // is a non-null reference to a ScrollView\n this._scrollRef.measureLayout(\n this.context.getOutermostParentListRef().getScrollRef(),\n (x, y, width, height) => {\n this._offsetFromParentVirtualizedList = this._selectOffset({x, y});\n this._scrollMetrics.contentLength = this._selectLength({\n width,\n height,\n });\n const scrollMetrics = this._convertParentScrollMetrics(\n this.context.getScrollMetrics(),\n );\n\n const metricsChanged =\n this._scrollMetrics.visibleLength !== scrollMetrics.visibleLength ||\n this._scrollMetrics.offset !== scrollMetrics.offset;\n\n if (metricsChanged) {\n this._scrollMetrics.visibleLength = scrollMetrics.visibleLength;\n this._scrollMetrics.offset = scrollMetrics.offset;\n\n // If metrics of the scrollView changed, then we triggered remeasure for child list\n // to ensure VirtualizedList has the right information.\n this._nestedChildLists.forEach(childList => {\n childList.measureLayoutRelativeToContainingList();\n });\n }\n },\n error => {\n console.warn(\n \"VirtualizedList: Encountered an error while measuring a list's\" +\n ' offset from its containing VirtualizedList.',\n );\n },\n );\n } catch (error) {\n console.warn(\n 'measureLayoutRelativeToContainingList threw an error',\n error.stack,\n );\n }\n }\n\n _onLayout = (e: LayoutEvent) => {\n if (this._isNestedWithSameOrientation()) {\n // Need to adjust our scroll metrics to be relative to our containing\n // VirtualizedList before we can make claims about list item viewability\n this.measureLayoutRelativeToContainingList();\n } else {\n this._scrollMetrics.visibleLength = this._selectLength(\n e.nativeEvent.layout,\n );\n }\n this.props.onLayout && this.props.onLayout(e);\n this._scheduleCellsToRenderUpdate();\n this._maybeCallOnEdgeReached();\n };\n\n _onLayoutEmpty = (e: LayoutEvent) => {\n this.props.onLayout && this.props.onLayout(e);\n };\n\n _getFooterCellKey(): string {\n return this._getCellKey() + '-footer';\n }\n\n _onLayoutFooter = (e: LayoutEvent) => {\n this._triggerRemeasureForChildListsInCell(this._getFooterCellKey());\n this._footerLength = this._selectLength(e.nativeEvent.layout);\n };\n\n _onLayoutHeader = (e: LayoutEvent) => {\n this._headerLength = this._selectLength(e.nativeEvent.layout);\n };\n\n // $FlowFixMe[missing-local-annot]\n _renderDebugOverlay() {\n const normalize =\n this._scrollMetrics.visibleLength /\n (this._scrollMetrics.contentLength || 1);\n const framesInLayout = [];\n const itemCount = this.props.getItemCount(this.props.data);\n for (let ii = 0; ii < itemCount; ii++) {\n const frame = this.__getFrameMetricsApprox(ii, this.props);\n /* $FlowFixMe[prop-missing] (>=0.68.0 site=react_native_fb) This comment\n * suppresses an error found when Flow v0.68 was deployed. To see the\n * error delete this comment and run Flow. */\n if (frame.inLayout) {\n framesInLayout.push(frame);\n }\n }\n const windowTop = this.__getFrameMetricsApprox(\n this.state.cellsAroundViewport.first,\n this.props,\n ).offset;\n const frameLast = this.__getFrameMetricsApprox(\n this.state.cellsAroundViewport.last,\n this.props,\n );\n const windowLen = frameLast.offset + frameLast.length - windowTop;\n const visTop = this._scrollMetrics.offset;\n const visLen = this._scrollMetrics.visibleLength;\n\n return (\n \n {framesInLayout.map((f, ii) => (\n \n ))}\n \n \n \n );\n }\n\n _selectLength(\n metrics: $ReadOnly<{\n height: number,\n width: number,\n ...\n }>,\n ): number {\n return !horizontalOrDefault(this.props.horizontal)\n ? metrics.height\n : metrics.width;\n }\n\n _selectOffset(\n metrics: $ReadOnly<{\n x: number,\n y: number,\n ...\n }>,\n ): number {\n return !horizontalOrDefault(this.props.horizontal) ? metrics.y : metrics.x;\n }\n\n _maybeCallOnEdgeReached() {\n const {\n data,\n getItemCount,\n onStartReached,\n onStartReachedThreshold,\n onEndReached,\n onEndReachedThreshold,\n initialScrollIndex,\n } = this.props;\n if (this.state.maintainVisibleContentPositionAdjustment != null) {\n return;\n }\n const {contentLength, visibleLength, offset} = this._scrollMetrics;\n let distanceFromStart = offset;\n let distanceFromEnd = contentLength - visibleLength - offset;\n\n // Especially when oERT is zero it's necessary to 'floor' very small distance values to be 0\n // since debouncing causes us to not fire this event for every single \"pixel\" we scroll and can thus\n // be at the edge of the list with a distance approximating 0 but not quite there.\n if (distanceFromStart < ON_EDGE_REACHED_EPSILON) {\n distanceFromStart = 0;\n }\n if (distanceFromEnd < ON_EDGE_REACHED_EPSILON) {\n distanceFromEnd = 0;\n }\n\n // TODO: T121172172 Look into why we're \"defaulting\" to a threshold of 2 when oERT is not present\n const startThreshold =\n onStartReachedThresholdOrDefault(onStartReachedThreshold) * visibleLength;\n const endThreshold =\n onEndReachedThresholdOrDefault(onEndReachedThreshold) * visibleLength;\n const isWithinStartThreshold = distanceFromStart <= startThreshold;\n const isWithinEndThreshold = distanceFromEnd <= endThreshold;\n\n // First check if the user just scrolled within the end threshold\n // and call onEndReached only once for a given content length,\n // and only if onStartReached is not being executed\n if (\n onEndReached &&\n this.state.cellsAroundViewport.last === getItemCount(data) - 1 &&\n isWithinEndThreshold &&\n this._scrollMetrics.contentLength !== this._sentEndForContentLength\n ) {\n this._sentEndForContentLength = this._scrollMetrics.contentLength;\n onEndReached({distanceFromEnd});\n }\n\n // Next check if the user just scrolled within the start threshold\n // and call onStartReached only once for a given content length,\n // and only if onEndReached is not being executed\n else if (\n onStartReached &&\n this.state.cellsAroundViewport.first === 0 &&\n isWithinStartThreshold &&\n this._scrollMetrics.contentLength !== this._sentStartForContentLength &&\n // On initial mount when using initialScrollIndex the offset will be 0 initially\n // and will trigger an unexpected onStartReached. To avoid this we can use\n // timestamp to differentiate between the initial scroll metrics and when we actually\n // received the first scroll event.\n (!initialScrollIndex || this._scrollMetrics.timestamp !== 0)\n ) {\n this._sentStartForContentLength = this._scrollMetrics.contentLength;\n onStartReached({distanceFromStart});\n }\n\n // If the user scrolls away from the start or end and back again,\n // cause onStartReached or onEndReached to be triggered again\n else {\n this._sentStartForContentLength = isWithinStartThreshold\n ? this._sentStartForContentLength\n : 0;\n this._sentEndForContentLength = isWithinEndThreshold\n ? this._sentEndForContentLength\n : 0;\n }\n }\n\n _onContentSizeChange = (width: number, height: number) => {\n if (\n width > 0 &&\n height > 0 &&\n this.props.initialScrollIndex != null &&\n this.props.initialScrollIndex > 0 &&\n !this._hasTriggeredInitialScrollToIndex\n ) {\n if (this.props.contentOffset == null) {\n this.scrollToIndex({\n animated: false,\n index: this.props.initialScrollIndex,\n });\n }\n this._hasTriggeredInitialScrollToIndex = true;\n }\n if (this.props.onContentSizeChange) {\n this.props.onContentSizeChange(width, height);\n }\n this._scrollMetrics.contentLength = this._selectLength({height, width});\n this._scheduleCellsToRenderUpdate();\n this._maybeCallOnEdgeReached();\n };\n\n /* Translates metrics from a scroll event in a parent VirtualizedList into\n * coordinates relative to the child list.\n */\n _convertParentScrollMetrics = (metrics: {\n visibleLength: number,\n offset: number,\n ...\n }): $FlowFixMe => {\n // Offset of the top of the nested list relative to the top of its parent's viewport\n const offset = metrics.offset - this._offsetFromParentVirtualizedList;\n // Child's visible length is the same as its parent's\n const visibleLength = metrics.visibleLength;\n const dOffset = offset - this._scrollMetrics.offset;\n const contentLength = this._scrollMetrics.contentLength;\n\n return {\n visibleLength,\n contentLength,\n offset,\n dOffset,\n };\n };\n\n _onScroll = (e: Object) => {\n this._nestedChildLists.forEach(childList => {\n childList._onScroll(e);\n });\n if (this.props.onScroll) {\n this.props.onScroll(e);\n }\n const timestamp = e.timeStamp;\n let visibleLength = this._selectLength(e.nativeEvent.layoutMeasurement);\n let contentLength = this._selectLength(e.nativeEvent.contentSize);\n let offset = this._selectOffset(e.nativeEvent.contentOffset);\n let dOffset = offset - this._scrollMetrics.offset;\n\n if (this._isNestedWithSameOrientation()) {\n if (this._scrollMetrics.contentLength === 0) {\n // Ignore scroll events until onLayout has been called and we\n // know our offset from our offset from our parent\n return;\n }\n ({visibleLength, contentLength, offset, dOffset} =\n this._convertParentScrollMetrics({\n visibleLength,\n offset,\n }));\n }\n\n const dt = this._scrollMetrics.timestamp\n ? Math.max(1, timestamp - this._scrollMetrics.timestamp)\n : 1;\n const velocity = dOffset / dt;\n\n if (\n dt > 500 &&\n this._scrollMetrics.dt > 500 &&\n contentLength > 5 * visibleLength &&\n !this._hasWarned.perf\n ) {\n infoLog(\n 'VirtualizedList: You have a large list that is slow to update - make sure your ' +\n 'renderItem function renders components that follow React performance best practices ' +\n 'like PureComponent, shouldComponentUpdate, etc.',\n {dt, prevDt: this._scrollMetrics.dt, contentLength},\n );\n this._hasWarned.perf = true;\n }\n\n // For invalid negative values (w/ RTL), set this to 1.\n const zoomScale = e.nativeEvent.zoomScale < 0 ? 1 : e.nativeEvent.zoomScale;\n this._scrollMetrics = {\n contentLength,\n dt,\n dOffset,\n offset,\n timestamp,\n velocity,\n visibleLength,\n zoomScale,\n };\n if (this.state.maintainVisibleContentPositionAdjustment != null) {\n this.setState({\n maintainVisibleContentPositionAdjustment: null,\n });\n }\n this._updateViewableItems(this.props, this.state.cellsAroundViewport);\n if (!this.props) {\n return;\n }\n this._maybeCallOnEdgeReached();\n if (velocity !== 0) {\n this._fillRateHelper.activate();\n }\n this._computeBlankness();\n this._scheduleCellsToRenderUpdate();\n };\n\n _scheduleCellsToRenderUpdate() {\n if (this.state.maintainVisibleContentPositionAdjustment != null) {\n return;\n }\n const {first, last} = this.state.cellsAroundViewport;\n const {offset, visibleLength, velocity} = this._scrollMetrics;\n const itemCount = this.props.getItemCount(this.props.data);\n let hiPri = false;\n const onStartReachedThreshold = onStartReachedThresholdOrDefault(\n this.props.onStartReachedThreshold,\n );\n const onEndReachedThreshold = onEndReachedThresholdOrDefault(\n this.props.onEndReachedThreshold,\n );\n // Mark as high priority if we're close to the start of the first item\n // But only if there are items before the first rendered item\n if (first > 0) {\n const distTop =\n offset - this.__getFrameMetricsApprox(first, this.props).offset;\n hiPri =\n hiPri ||\n distTop < 0 ||\n (velocity < -2 &&\n distTop <\n getScrollingThreshold(onStartReachedThreshold, visibleLength));\n }\n // Mark as high priority if we're close to the end of the last item\n // But only if there are items after the last rendered item\n if (last >= 0 && last < itemCount - 1) {\n const distBottom =\n this.__getFrameMetricsApprox(last, this.props).offset -\n (offset + visibleLength);\n hiPri =\n hiPri ||\n distBottom < 0 ||\n (velocity > 2 &&\n distBottom <\n getScrollingThreshold(onEndReachedThreshold, visibleLength));\n }\n // Only trigger high-priority updates if we've actually rendered cells,\n // and with that size estimate, accurately compute how many cells we should render.\n // Otherwise, it would just render as many cells as it can (of zero dimension),\n // each time through attempting to render more (limited by maxToRenderPerBatch),\n // starving the renderer from actually laying out the objects and computing _averageCellLength.\n // If this is triggered in an `componentDidUpdate` followed by a hiPri cellToRenderUpdate\n // We shouldn't do another hipri cellToRenderUpdate\n if (\n hiPri &&\n (this._averageCellLength || this.props.getItemLayout) &&\n !this._hiPriInProgress\n ) {\n this._hiPriInProgress = true;\n // Don't worry about interactions when scrolling quickly; focus on filling content as fast\n // as possible.\n this._updateCellsToRenderBatcher.dispose({abort: true});\n this._updateCellsToRender();\n return;\n } else {\n this._updateCellsToRenderBatcher.schedule();\n }\n }\n\n _onScrollBeginDrag = (e: ScrollEvent): void => {\n this._nestedChildLists.forEach(childList => {\n childList._onScrollBeginDrag(e);\n });\n this._viewabilityTuples.forEach(tuple => {\n tuple.viewabilityHelper.recordInteraction();\n });\n this._hasInteracted = true;\n this.props.onScrollBeginDrag && this.props.onScrollBeginDrag(e);\n };\n\n _onScrollEndDrag = (e: ScrollEvent): void => {\n this._nestedChildLists.forEach(childList => {\n childList._onScrollEndDrag(e);\n });\n const {velocity} = e.nativeEvent;\n if (velocity) {\n this._scrollMetrics.velocity = this._selectOffset(velocity);\n }\n this._computeBlankness();\n this.props.onScrollEndDrag && this.props.onScrollEndDrag(e);\n };\n\n _onMomentumScrollBegin = (e: ScrollEvent): void => {\n this._nestedChildLists.forEach(childList => {\n childList._onMomentumScrollBegin(e);\n });\n this.props.onMomentumScrollBegin && this.props.onMomentumScrollBegin(e);\n };\n\n _onMomentumScrollEnd = (e: ScrollEvent): void => {\n this._nestedChildLists.forEach(childList => {\n childList._onMomentumScrollEnd(e);\n });\n this._scrollMetrics.velocity = 0;\n this._computeBlankness();\n this.props.onMomentumScrollEnd && this.props.onMomentumScrollEnd(e);\n };\n\n _updateCellsToRender = () => {\n this._updateViewableItems(this.props, this.state.cellsAroundViewport);\n\n this.setState((state, props) => {\n const cellsAroundViewport = this._adjustCellsAroundViewport(\n props,\n state.cellsAroundViewport,\n );\n const renderMask = VirtualizedList._createRenderMask(\n props,\n cellsAroundViewport,\n state.maintainVisibleContentPositionAdjustment,\n this._getNonViewportRenderRegions(props),\n );\n\n if (\n cellsAroundViewport.first === state.cellsAroundViewport.first &&\n cellsAroundViewport.last === state.cellsAroundViewport.last &&\n renderMask.equals(state.renderMask)\n ) {\n return null;\n }\n\n return {cellsAroundViewport, renderMask};\n });\n };\n\n _createViewToken = (\n index: number,\n isViewable: boolean,\n props: FrameMetricProps,\n // $FlowFixMe[missing-local-annot]\n ) => {\n const {data, getItem} = props;\n const item = getItem(data, index);\n return {\n index,\n item,\n key: extractKey(props, item, index),\n isViewable,\n };\n };\n\n /**\n * Gets an approximate offset to an item at a given index. Supports\n * fractional indices.\n */\n _getOffsetApprox = (index: number, props: FrameMetricProps): number => {\n if (Number.isInteger(index)) {\n return this.__getFrameMetricsApprox(index, props).offset;\n } else {\n const frameMetrics = this.__getFrameMetricsApprox(\n Math.floor(index),\n props,\n );\n const remainder = index - Math.floor(index);\n return frameMetrics.offset + remainder * frameMetrics.length;\n }\n };\n\n __getFrameMetricsApprox: (\n index: number,\n props: FrameMetricProps,\n ) => {\n length: number,\n offset: number,\n ...\n } = (index, props) => {\n const frame = this._getFrameMetrics(index, props);\n if (frame && frame.index === index) {\n // check for invalid frames due to row re-ordering\n return frame;\n } else {\n const {data, getItemCount, getItemLayout} = props;\n invariant(\n index >= 0 && index < getItemCount(data),\n 'Tried to get frame for out of range index ' + index,\n );\n invariant(\n !getItemLayout,\n 'Should not have to estimate frames when a measurement metrics function is provided',\n );\n return {\n length: this._averageCellLength,\n offset: this._averageCellLength * index,\n };\n }\n };\n\n _getFrameMetrics = (\n index: number,\n props: FrameMetricProps,\n ): ?{\n length: number,\n offset: number,\n index: number,\n inLayout?: boolean,\n ...\n } => {\n const {data, getItem, getItemCount, getItemLayout} = props;\n invariant(\n index >= 0 && index < getItemCount(data),\n 'Tried to get frame for out of range index ' + index,\n );\n const item = getItem(data, index);\n const frame =\n item != null ? this._frames[extractKey(props, item, index)] : undefined;\n if (!frame || frame.index !== index) {\n if (getItemLayout) {\n /* $FlowFixMe[prop-missing] (>=0.63.0 site=react_native_fb) This comment\n * suppresses an error found when Flow v0.63 was deployed. To see the error\n * delete this comment and run Flow. */\n return getItemLayout(data, index);\n }\n }\n return frame;\n };\n\n _getNonViewportRenderRegions = (\n props: FrameMetricProps,\n ): $ReadOnlyArray<{\n first: number,\n last: number,\n }> => {\n // Keep a viewport's worth of content around the last focused cell to allow\n // random navigation around it without any blanking. E.g. tabbing from one\n // focused item out of viewport to another.\n if (\n !(this._lastFocusedCellKey && this._cellRefs[this._lastFocusedCellKey])\n ) {\n return [];\n }\n\n const lastFocusedCellRenderer = this._cellRefs[this._lastFocusedCellKey];\n const focusedCellIndex = lastFocusedCellRenderer.props.index;\n const itemCount = props.getItemCount(props.data);\n\n // The cell may have been unmounted and have a stale index\n if (\n focusedCellIndex >= itemCount ||\n this._indicesToKeys.get(focusedCellIndex) !== this._lastFocusedCellKey\n ) {\n return [];\n }\n\n let first = focusedCellIndex;\n let heightOfCellsBeforeFocused = 0;\n for (\n let i = first - 1;\n i >= 0 && heightOfCellsBeforeFocused < this._scrollMetrics.visibleLength;\n i--\n ) {\n first--;\n heightOfCellsBeforeFocused += this.__getFrameMetricsApprox(\n i,\n props,\n ).length;\n }\n\n let last = focusedCellIndex;\n let heightOfCellsAfterFocused = 0;\n for (\n let i = last + 1;\n i < itemCount &&\n heightOfCellsAfterFocused < this._scrollMetrics.visibleLength;\n i++\n ) {\n last++;\n heightOfCellsAfterFocused += this.__getFrameMetricsApprox(\n i,\n props,\n ).length;\n }\n\n return [{first, last}];\n };\n\n _updateViewableItems(\n props: FrameMetricProps,\n cellsAroundViewport: {first: number, last: number},\n ) {\n this._viewabilityTuples.forEach(tuple => {\n tuple.viewabilityHelper.onUpdate(\n props,\n this._scrollMetrics.offset,\n this._scrollMetrics.visibleLength,\n this._getFrameMetrics,\n this._createViewToken,\n tuple.onViewableItemsChanged,\n cellsAroundViewport,\n );\n });\n }\n}\n\nconst styles = StyleSheet.create({\n verticallyInverted: {\n transform: [{scaleY: -1}],\n },\n horizontallyInverted: {\n transform: [{scaleX: -1}],\n },\n debug: {\n flex: 1,\n },\n debugOverlayBase: {\n position: 'absolute',\n top: 0,\n right: 0,\n },\n debugOverlay: {\n bottom: 0,\n width: 20,\n borderColor: 'blue',\n borderWidth: 1,\n },\n debugOverlayFrame: {\n left: 0,\n backgroundColor: 'orange',\n },\n debugOverlayFrameLast: {\n left: 0,\n borderColor: 'green',\n borderWidth: 2,\n },\n debugOverlayFrameVis: {\n left: 0,\n borderColor: 'red',\n borderWidth: 2,\n },\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 * @format\n * @flow\n */\n\nimport type {ColorValue} from '../../StyleSheet/StyleSheet';\nimport type {ViewProps} from '../View/ViewPropTypes';\n\nimport AndroidSwipeRefreshLayoutNativeComponent, {\n Commands as AndroidSwipeRefreshLayoutCommands,\n} from './AndroidSwipeRefreshLayoutNativeComponent';\nimport PullToRefreshViewNativeComponent, {\n Commands as PullToRefreshCommands,\n} from './PullToRefreshViewNativeComponent';\n\nconst Platform = require('../../Utilities/Platform');\nconst React = require('react');\n\ntype IOSProps = $ReadOnly<{|\n /**\n * The color of the refresh indicator.\n */\n tintColor?: ?ColorValue,\n /**\n * Title color.\n */\n titleColor?: ?ColorValue,\n /**\n * The title displayed under the refresh indicator.\n */\n title?: ?string,\n|}>;\n\ntype AndroidProps = $ReadOnly<{|\n /**\n * Whether the pull to refresh functionality is enabled.\n */\n enabled?: ?boolean,\n /**\n * The colors (at least one) that will be used to draw the refresh indicator.\n */\n colors?: ?$ReadOnlyArray,\n /**\n * The background color of the refresh indicator.\n */\n progressBackgroundColor?: ?ColorValue,\n /**\n * Size of the refresh indicator.\n */\n size?: ?('default' | 'large'),\n|}>;\n\nexport type RefreshControlProps = $ReadOnly<{|\n ...ViewProps,\n ...IOSProps,\n ...AndroidProps,\n\n /**\n * Called when the view starts refreshing.\n */\n onRefresh?: ?() => void | Promise,\n\n /**\n * Whether the view should be indicating an active refresh.\n */\n refreshing: boolean,\n\n /**\n * Progress view top offset\n */\n progressViewOffset?: ?number,\n|}>;\n\n/**\n * This component is used inside a ScrollView or ListView to add pull to refresh\n * functionality. When the ScrollView is at `scrollY: 0`, swiping down\n * triggers an `onRefresh` event.\n *\n * ### Usage example\n *\n * ``` js\n * class RefreshableList extends Component {\n * constructor(props) {\n * super(props);\n * this.state = {\n * refreshing: false,\n * };\n * }\n *\n * _onRefresh() {\n * this.setState({refreshing: true});\n * fetchData().then(() => {\n * this.setState({refreshing: false});\n * });\n * }\n *\n * render() {\n * return (\n * \n * }\n * ...\n * >\n * ...\n * \n * );\n * }\n * ...\n * }\n * ```\n *\n * __Note:__ `refreshing` is a controlled prop, this is why it needs to be set to true\n * in the `onRefresh` function otherwise the refresh indicator will stop immediately.\n */\nclass RefreshControl extends React.Component {\n _nativeRef: ?React.ElementRef<\n | typeof PullToRefreshViewNativeComponent\n | typeof AndroidSwipeRefreshLayoutNativeComponent,\n >;\n _lastNativeRefreshing = false;\n\n componentDidMount() {\n this._lastNativeRefreshing = this.props.refreshing;\n }\n\n componentDidUpdate(prevProps: RefreshControlProps) {\n // RefreshControl is a controlled component so if the native refreshing\n // value doesn't match the current js refreshing prop update it to\n // the js value.\n if (this.props.refreshing !== prevProps.refreshing) {\n this._lastNativeRefreshing = this.props.refreshing;\n } else if (\n this.props.refreshing !== this._lastNativeRefreshing &&\n this._nativeRef\n ) {\n if (Platform.OS === 'android') {\n AndroidSwipeRefreshLayoutCommands.setNativeRefreshing(\n this._nativeRef,\n this.props.refreshing,\n );\n } else {\n PullToRefreshCommands.setNativeRefreshing(\n this._nativeRef,\n this.props.refreshing,\n );\n }\n this._lastNativeRefreshing = this.props.refreshing;\n }\n }\n\n render(): React.Node {\n if (Platform.OS === 'ios') {\n const {enabled, colors, progressBackgroundColor, size, ...props} =\n this.props;\n return (\n \n );\n } else {\n const {tintColor, titleColor, title, ...props} = this.props;\n return (\n \n );\n }\n }\n\n _onRefresh = () => {\n this._lastNativeRefreshing = true;\n\n this.props.onRefresh && this.props.onRefresh();\n\n // The native component will start refreshing so force an update to\n // make sure it stays in sync with the js component.\n this.forceUpdate();\n };\n\n _setNativeRef = (\n ref: ?React.ElementRef<\n | typeof PullToRefreshViewNativeComponent\n | typeof AndroidSwipeRefreshLayoutNativeComponent,\n >,\n ) => {\n this._nativeRef = ref;\n };\n}\n\nmodule.exports = RefreshControl;\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 * @format\n * @flow strict-local\n */\n\nimport type {HostComponent} from '../../Renderer/shims/ReactNativeTypes';\nimport type {ColorValue} from '../../StyleSheet/StyleSheet';\nimport type {\n DirectEventHandler,\n Float,\n WithDefault,\n} from '../../Types/CodegenTypes';\nimport type {ViewProps} from '../View/ViewPropTypes';\n\nimport codegenNativeCommands from '../../Utilities/codegenNativeCommands';\nimport codegenNativeComponent from '../../Utilities/codegenNativeComponent';\nimport * as React from 'react';\n\ntype NativeProps = $ReadOnly<{|\n ...ViewProps,\n\n /**\n * Whether the pull to refresh functionality is enabled.\n */\n enabled?: WithDefault,\n /**\n * The colors (at least one) that will be used to draw the refresh indicator.\n */\n colors?: ?$ReadOnlyArray,\n /**\n * The background color of the refresh indicator.\n */\n progressBackgroundColor?: ?ColorValue,\n /**\n * Size of the refresh indicator.\n */\n size?: WithDefault<'default' | 'large', 'default'>,\n /**\n * Progress view top offset\n */\n progressViewOffset?: WithDefault,\n\n /**\n * Called when the view starts refreshing.\n */\n onRefresh?: ?DirectEventHandler,\n\n /**\n * Whether the view should be indicating an active refresh.\n */\n refreshing: boolean,\n|}>;\n\ntype NativeType = HostComponent;\n\ninterface NativeCommands {\n +setNativeRefreshing: (\n viewRef: React.ElementRef,\n value: boolean,\n ) => void;\n}\n\nexport const Commands: NativeCommands = codegenNativeCommands({\n supportedCommands: ['setNativeRefreshing'],\n});\n\nexport default (codegenNativeComponent(\n 'AndroidSwipeRefreshLayout',\n): NativeType);\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 * @format\n * @flow strict-local\n */\n\nimport type {HostComponent} from '../../Renderer/shims/ReactNativeTypes';\nimport type {ColorValue} from '../../StyleSheet/StyleSheet';\nimport type {\n DirectEventHandler,\n Float,\n WithDefault,\n} from '../../Types/CodegenTypes';\nimport type {ViewProps} from '../View/ViewPropTypes';\n\nimport codegenNativeCommands from '../../Utilities/codegenNativeCommands';\nimport codegenNativeComponent from '../../Utilities/codegenNativeComponent';\nimport * as React from 'react';\n\ntype NativeProps = $ReadOnly<{|\n ...ViewProps,\n\n /**\n * The color of the refresh indicator.\n */\n tintColor?: ?ColorValue,\n /**\n * Title color.\n */\n titleColor?: ?ColorValue,\n /**\n * The title displayed under the refresh indicator.\n */\n title?: WithDefault,\n /**\n * Progress view top offset\n */\n progressViewOffset?: WithDefault,\n\n /**\n * Called when the view starts refreshing.\n */\n onRefresh?: ?DirectEventHandler,\n\n /**\n * Whether the view should be indicating an active refresh.\n */\n refreshing: boolean,\n|}>;\n\ntype ComponentType = HostComponent;\n\ninterface NativeCommands {\n +setNativeRefreshing: (\n viewRef: React.ElementRef,\n refreshing: boolean,\n ) => void;\n}\n\nexport const Commands: NativeCommands = codegenNativeCommands({\n supportedCommands: ['setNativeRefreshing'],\n});\n\nexport default (codegenNativeComponent('PullToRefreshView', {\n paperComponentName: 'RCTRefreshControl',\n excludedPlatforms: ['android'],\n}): HostComponent);\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 * @format\n * @flow strict-local\n */\n\nimport type {HostComponent} from '../../Renderer/shims/ReactNativeTypes';\nimport type {EdgeInsetsProp} from '../../StyleSheet/EdgeInsetsPropType';\nimport type {PointProp} from '../../StyleSheet/PointPropType';\nimport type {ViewStyleProp} from '../../StyleSheet/StyleSheet';\nimport type {ColorValue} from '../../StyleSheet/StyleSheet';\nimport type {\n LayoutEvent,\n PressEvent,\n ScrollEvent,\n} from '../../Types/CoreEventTypes';\nimport type {EventSubscription} from '../../vendor/emitter/EventEmitter';\nimport type {KeyboardEvent, KeyboardMetrics} from '../Keyboard/Keyboard';\nimport type {ViewProps} from '../View/ViewPropTypes';\nimport type {Props as ScrollViewStickyHeaderProps} from './ScrollViewStickyHeader';\n\nimport AnimatedImplementation from '../../Animated/AnimatedImplementation';\nimport FrameRateLogger from '../../Interaction/FrameRateLogger';\nimport {findNodeHandle} from '../../ReactNative/RendererProxy';\nimport UIManager from '../../ReactNative/UIManager';\nimport flattenStyle from '../../StyleSheet/flattenStyle';\nimport splitLayoutProps from '../../StyleSheet/splitLayoutProps';\nimport StyleSheet from '../../StyleSheet/StyleSheet';\nimport Dimensions from '../../Utilities/Dimensions';\nimport dismissKeyboard from '../../Utilities/dismissKeyboard';\nimport Platform from '../../Utilities/Platform';\nimport setAndForwardRef from '../../Utilities/setAndForwardRef';\nimport Keyboard from '../Keyboard/Keyboard';\nimport TextInputState from '../TextInput/TextInputState';\nimport View from '../View/View';\nimport AndroidHorizontalScrollContentViewNativeComponent from './AndroidHorizontalScrollContentViewNativeComponent';\nimport AndroidHorizontalScrollViewNativeComponent from './AndroidHorizontalScrollViewNativeComponent';\nimport processDecelerationRate from './processDecelerationRate';\nimport ScrollContentViewNativeComponent from './ScrollContentViewNativeComponent';\nimport Commands from './ScrollViewCommands';\nimport ScrollViewContext, {HORIZONTAL, VERTICAL} from './ScrollViewContext';\nimport ScrollViewNativeComponent from './ScrollViewNativeComponent';\nimport ScrollViewStickyHeader from './ScrollViewStickyHeader';\nimport invariant from 'invariant';\nimport * as React from 'react';\n\nif (Platform.OS === 'ios') {\n require('../../Renderer/shims/ReactNative'); // Force side effects to prevent T55744311\n}\n\nconst {NativeHorizontalScrollViewTuple, NativeVerticalScrollViewTuple} =\n Platform.OS === 'android'\n ? {\n NativeHorizontalScrollViewTuple: [\n AndroidHorizontalScrollViewNativeComponent,\n AndroidHorizontalScrollContentViewNativeComponent,\n ],\n NativeVerticalScrollViewTuple: [ScrollViewNativeComponent, View],\n }\n : {\n NativeHorizontalScrollViewTuple: [\n ScrollViewNativeComponent,\n ScrollContentViewNativeComponent,\n ],\n NativeVerticalScrollViewTuple: [\n ScrollViewNativeComponent,\n ScrollContentViewNativeComponent,\n ],\n };\n\n/*\n * iOS scroll event timing nuances:\n * ===============================\n *\n *\n * Scrolling without bouncing, if you touch down:\n * -------------------------------\n *\n * 1. `onMomentumScrollBegin` (when animation begins after letting up)\n * ... physical touch starts ...\n * 2. `onTouchStartCapture` (when you press down to stop the scroll)\n * 3. `onTouchStart` (same, but bubble phase)\n * 4. `onResponderRelease` (when lifting up - you could pause forever before * lifting)\n * 5. `onMomentumScrollEnd`\n *\n *\n * Scrolling with bouncing, if you touch down:\n * -------------------------------\n *\n * 1. `onMomentumScrollBegin` (when animation begins after letting up)\n * ... bounce begins ...\n * ... some time elapses ...\n * ... physical touch during bounce ...\n * 2. `onMomentumScrollEnd` (Makes no sense why this occurs first during bounce)\n * 3. `onTouchStartCapture` (immediately after `onMomentumScrollEnd`)\n * 4. `onTouchStart` (same, but bubble phase)\n * 5. `onTouchEnd` (You could hold the touch start for a long time)\n * 6. `onMomentumScrollBegin` (When releasing the view starts bouncing back)\n *\n * So when we receive an `onTouchStart`, how can we tell if we are touching\n * *during* an animation (which then causes the animation to stop)? The only way\n * to tell is if the `touchStart` occurred immediately after the\n * `onMomentumScrollEnd`.\n *\n * This is abstracted out for you, so you can just call this.scrollResponderIsAnimating() if\n * necessary\n *\n * `ScrollView` also includes logic for blurring a currently focused input\n * if one is focused while scrolling. This is a natural place\n * to put this logic since it can support not dismissing the keyboard while\n * scrolling, unless a recognized \"tap\"-like gesture has occurred.\n *\n * The public lifecycle API includes events for keyboard interaction, responder\n * interaction, and scrolling (among others). The keyboard callbacks\n * `onKeyboardWill/Did/*` are *global* events, but are invoked on scroll\n * responder's props so that you can guarantee that the scroll responder's\n * internal state has been updated accordingly (and deterministically) by\n * the time the props callbacks are invoke. Otherwise, you would always wonder\n * if the scroll responder is currently in a state where it recognizes new\n * keyboard positions etc. If coordinating scrolling with keyboard movement,\n * *always* use these hooks instead of listening to your own global keyboard\n * events.\n *\n * Public keyboard lifecycle API: (props callbacks)\n *\n * Standard Keyboard Appearance Sequence:\n *\n * this.props.onKeyboardWillShow\n * this.props.onKeyboardDidShow\n *\n * `onScrollResponderKeyboardDismissed` will be invoked if an appropriate\n * tap inside the scroll responder's scrollable region was responsible\n * for the dismissal of the keyboard. There are other reasons why the\n * keyboard could be dismissed.\n *\n * this.props.onScrollResponderKeyboardDismissed\n *\n * Standard Keyboard Hide Sequence:\n *\n * this.props.onKeyboardWillHide\n * this.props.onKeyboardDidHide\n */\n\n// Public methods for ScrollView\nexport type ScrollViewImperativeMethods = $ReadOnly<{|\n getScrollResponder: $PropertyType,\n getScrollableNode: $PropertyType,\n getInnerViewNode: $PropertyType,\n getInnerViewRef: $PropertyType,\n getNativeScrollRef: $PropertyType,\n scrollTo: $PropertyType,\n scrollToEnd: $PropertyType,\n flashScrollIndicators: $PropertyType,\n scrollResponderZoomTo: $PropertyType,\n scrollResponderScrollNativeHandleToKeyboard: $PropertyType<\n ScrollView,\n 'scrollResponderScrollNativeHandleToKeyboard',\n >,\n|}>;\n\nexport type DecelerationRateType = 'fast' | 'normal' | number;\nexport type ScrollResponderType = ScrollViewImperativeMethods;\n\ntype IOSProps = $ReadOnly<{|\n /**\n * Controls whether iOS should automatically adjust the content inset\n * for scroll views that are placed behind a navigation bar or\n * tab bar/ toolbar. The default value is true.\n * @platform ios\n */\n automaticallyAdjustContentInsets?: ?boolean,\n /**\n * Controls whether the ScrollView should automatically adjust its `contentInset`\n * and `scrollViewInsets` when the Keyboard changes its size. The default value is false.\n * @platform ios\n */\n automaticallyAdjustKeyboardInsets?: ?boolean,\n /**\n * Controls whether iOS should automatically adjust the scroll indicator\n * insets. The default value is true. Available on iOS 13 and later.\n * @platform ios\n */\n automaticallyAdjustsScrollIndicatorInsets?: ?boolean,\n /**\n * The amount by which the scroll view content is inset from the edges\n * of the scroll view. Defaults to `{top: 0, left: 0, bottom: 0, right: 0}`.\n * @platform ios\n */\n contentInset?: ?EdgeInsetsProp,\n /**\n * When true, the scroll view bounces when it reaches the end of the\n * content if the content is larger then the scroll view along the axis of\n * the scroll direction. When false, it disables all bouncing even if\n * the `alwaysBounce*` props are true. The default value is true.\n * @platform ios\n */\n bounces?: ?boolean,\n /**\n * By default, ScrollView has an active pan responder that hijacks panresponders\n * deeper in the render tree in order to prevent accidental touches while scrolling.\n * However, in certain occasions (such as when using snapToInterval) in a vertical scrollview\n * You may want to disable this behavior in order to prevent the ScrollView from blocking touches\n */\n disableScrollViewPanResponder?: ?boolean,\n /**\n * When true, gestures can drive zoom past min/max and the zoom will animate\n * to the min/max value at gesture end, otherwise the zoom will not exceed\n * the limits.\n * @platform ios\n */\n bouncesZoom?: ?boolean,\n /**\n * When true, the scroll view bounces horizontally when it reaches the end\n * even if the content is smaller than the scroll view itself. The default\n * value is true when `horizontal={true}` and false otherwise.\n * @platform ios\n */\n alwaysBounceHorizontal?: ?boolean,\n /**\n * When true, the scroll view bounces vertically when it reaches the end\n * even if the content is smaller than the scroll view itself. The default\n * value is false when `horizontal={true}` and true otherwise.\n * @platform ios\n */\n alwaysBounceVertical?: ?boolean,\n /**\n * When true, the scroll view automatically centers the content when the\n * content is smaller than the scroll view bounds; when the content is\n * larger than the scroll view, this property has no effect. The default\n * value is false.\n * @platform ios\n */\n centerContent?: ?boolean,\n /**\n * The style of the scroll indicators.\n *\n * - `'default'` (the default), same as `black`.\n * - `'black'`, scroll indicator is black. This style is good against a light background.\n * - `'white'`, scroll indicator is white. This style is good against a dark background.\n *\n * @platform ios\n */\n indicatorStyle?: ?('default' | 'black' | 'white'),\n /**\n * When true, the ScrollView will try to lock to only vertical or horizontal\n * scrolling while dragging. The default value is false.\n * @platform ios\n */\n directionalLockEnabled?: ?boolean,\n /**\n * When false, once tracking starts, won't try to drag if the touch moves.\n * The default value is true.\n * @platform ios\n */\n canCancelContentTouches?: ?boolean,\n /**\n * When set, the scroll view will adjust the scroll position so that the first child that is\n * currently visible and at or beyond `minIndexForVisible` will not change position. This is\n * useful for lists that are loading content in both directions, e.g. a chat thread, where new\n * messages coming in might otherwise cause the scroll position to jump. A value of 0 is common,\n * but other values such as 1 can be used to skip loading spinners or other content that should\n * not maintain position.\n *\n * The optional `autoscrollToTopThreshold` can be used to make the content automatically scroll\n * to the top after making the adjustment if the user was within the threshold of the top before\n * the adjustment was made. This is also useful for chat-like applications where you want to see\n * new messages scroll into place, but not if the user has scrolled up a ways and it would be\n * disruptive to scroll a bunch.\n *\n * Caveat 1: Reordering elements in the scrollview with this enabled will probably cause\n * jumpiness and jank. It can be fixed, but there are currently no plans to do so. For now,\n * don't re-order the content of any ScrollViews or Lists that use this feature.\n *\n * Caveat 2: This simply uses `contentOffset` and `frame.origin` in native code to compute\n * visibility. Occlusion, transforms, and other complexity won't be taken into account as to\n * whether content is \"visible\" or not.\n */\n maintainVisibleContentPosition?: ?$ReadOnly<{|\n minIndexForVisible: number,\n autoscrollToTopThreshold?: ?number,\n |}>,\n /**\n * The maximum allowed zoom scale. The default value is 1.0.\n * @platform ios\n */\n maximumZoomScale?: ?number,\n /**\n * The minimum allowed zoom scale. The default value is 1.0.\n * @platform ios\n */\n minimumZoomScale?: ?number,\n /**\n * When true, ScrollView allows use of pinch gestures to zoom in and out.\n * The default value is true.\n * @platform ios\n */\n pinchGestureEnabled?: ?boolean,\n /**\n * This controls how often the scroll event will be fired while scrolling\n * (as a time interval in ms). A lower number yields better accuracy for code\n * that is tracking the scroll position, but can lead to scroll performance\n * problems due to the volume of information being send over the bridge.\n *\n * Values between 0 and 17ms indicate 60fps updates are needed and throttling\n * will be disabled.\n *\n * If you do not need precise scroll position tracking, set this value higher\n * to limit the information being sent across the bridge.\n *\n * The default value is zero, which results in the scroll event being sent only\n * once each time the view is scrolled.\n *\n * @platform ios\n */\n scrollEventThrottle?: ?number,\n /**\n * The amount by which the scroll view indicators are inset from the edges\n * of the scroll view. This should normally be set to the same value as\n * the `contentInset`. Defaults to `{0, 0, 0, 0}`.\n * @platform ios\n */\n scrollIndicatorInsets?: ?EdgeInsetsProp,\n /**\n * When true, the scroll view can be programmatically scrolled beyond its\n * content size. The default value is false.\n * @platform ios\n */\n scrollToOverflowEnabled?: ?boolean,\n /**\n * When true, the scroll view scrolls to top when the status bar is tapped.\n * The default value is true.\n * @platform ios\n */\n scrollsToTop?: ?boolean,\n /**\n * Fires when the scroll view scrolls to top after the status bar has been tapped\n * @platform ios\n */\n onScrollToTop?: (event: ScrollEvent) => void,\n /**\n * When true, shows a horizontal scroll indicator.\n * The default value is true.\n */\n showsHorizontalScrollIndicator?: ?boolean,\n /**\n * The current scale of the scroll view content. The default value is 1.0.\n * @platform ios\n */\n zoomScale?: ?number,\n /**\n * This property specifies how the safe area insets are used to modify the\n * content area of the scroll view. The default value of this property is\n * \"never\". Available on iOS 11 and later.\n * @platform ios\n */\n contentInsetAdjustmentBehavior?: ?(\n | 'automatic'\n | 'scrollableAxes'\n | 'never'\n | 'always'\n ),\n|}>;\n\ntype AndroidProps = $ReadOnly<{|\n /**\n * Enables nested scrolling for Android API level 21+.\n * Nested scrolling is supported by default on iOS\n * @platform android\n */\n nestedScrollEnabled?: ?boolean,\n /**\n * Sometimes a scrollview takes up more space than its content fills. When this is\n * the case, this prop will fill the rest of the scrollview with a color to avoid setting\n * a background and creating unnecessary overdraw. This is an advanced optimization\n * that is not needed in the general case.\n * @platform android\n */\n endFillColor?: ?ColorValue,\n /**\n * Tag used to log scroll performance on this scroll view. Will force\n * momentum events to be turned on (see sendMomentumEvents). This doesn't do\n * anything out of the box and you need to implement a custom native\n * FpsListener for it to be useful.\n * @platform android\n */\n scrollPerfTag?: ?string,\n /**\n * Used to override default value of overScroll mode.\n *\n * Possible values:\n *\n * - `'auto'` - Default value, allow a user to over-scroll\n * this view only if the content is large enough to meaningfully scroll.\n * - `'always'` - Always allow a user to over-scroll this view.\n * - `'never'` - Never allow a user to over-scroll this view.\n *\n * @platform android\n */\n overScrollMode?: ?('auto' | 'always' | 'never'),\n /**\n * Causes the scrollbars not to turn transparent when they are not in use.\n * The default value is false.\n *\n * @platform android\n */\n persistentScrollbar?: ?boolean,\n /**\n * Fades out the edges of the scroll content.\n *\n * If the value is greater than 0, the fading edges will be set accordingly\n * to the current scroll direction and position,\n * indicating if there is more content to show.\n *\n * The default value is 0.\n *\n * @platform android\n */\n fadingEdgeLength?: ?number,\n|}>;\n\ntype StickyHeaderComponentType = React.AbstractComponent<\n ScrollViewStickyHeaderProps,\n $ReadOnly void}>,\n>;\n\nexport type Props = $ReadOnly<{|\n ...ViewProps,\n ...IOSProps,\n ...AndroidProps,\n\n /**\n * These styles will be applied to the scroll view content container which\n * wraps all of the child views. Example:\n *\n * ```\n * return (\n * \n * \n * );\n * ...\n * const styles = StyleSheet.create({\n * contentContainer: {\n * paddingVertical: 20\n * }\n * });\n * ```\n */\n contentContainerStyle?: ?ViewStyleProp,\n /**\n * Used to manually set the starting scroll offset.\n * The default value is `{x: 0, y: 0}`.\n */\n contentOffset?: ?PointProp,\n /**\n * When true, the scroll view stops on the next index (in relation to scroll\n * position at release) regardless of how fast the gesture is. This can be\n * used for pagination when the page is less than the width of the\n * horizontal ScrollView or the height of the vertical ScrollView. The default value is false.\n */\n disableIntervalMomentum?: ?boolean,\n /**\n * A floating-point number that determines how quickly the scroll view\n * decelerates after the user lifts their finger. You may also use string\n * shortcuts `\"normal\"` and `\"fast\"` which match the underlying iOS settings\n * for `UIScrollViewDecelerationRateNormal` and\n * `UIScrollViewDecelerationRateFast` respectively.\n *\n * - `'normal'`: 0.998 on iOS, 0.985 on Android (the default)\n * - `'fast'`: 0.99 on iOS, 0.9 on Android\n */\n decelerationRate?: ?DecelerationRateType,\n /**\n * When true, the scroll view's children are arranged horizontally in a row\n * instead of vertically in a column. The default value is false.\n */\n horizontal?: ?boolean,\n /**\n * If sticky headers should stick at the bottom instead of the top of the\n * ScrollView. This is usually used with inverted ScrollViews.\n */\n invertStickyHeaders?: ?boolean,\n /**\n * Determines whether the keyboard gets dismissed in response to a drag.\n *\n * *Cross platform*\n *\n * - `'none'` (the default), drags do not dismiss the keyboard.\n * - `'on-drag'`, the keyboard is dismissed when a drag begins.\n *\n * *iOS Only*\n *\n * - `'interactive'`, the keyboard is dismissed interactively with the drag and moves in\n * synchrony with the touch; dragging upwards cancels the dismissal.\n * On android this is not supported and it will have the same behavior as 'none'.\n */\n keyboardDismissMode?: ?// default\n // cross-platform\n ('none' | 'on-drag' | 'interactive'), // ios only\n /**\n * Determines when the keyboard should stay visible after a tap.\n *\n * - `'never'` (the default), tapping outside of the focused text input when the keyboard\n * is up dismisses the keyboard. When this happens, children won't receive the tap.\n * - `'always'`, the keyboard will not dismiss automatically, and the scroll view will not\n * catch taps, but children of the scroll view can catch taps.\n * - `'handled'`, the keyboard will not dismiss automatically when the tap was handled by\n * a children, (or captured by an ancestor).\n * - `false`, deprecated, use 'never' instead\n * - `true`, deprecated, use 'always' instead\n */\n keyboardShouldPersistTaps?: ?('always' | 'never' | 'handled' | true | false),\n /**\n * Called when the momentum scroll starts (scroll which occurs as the ScrollView glides to a stop).\n */\n onMomentumScrollBegin?: ?(event: ScrollEvent) => void,\n /**\n * Called when the momentum scroll ends (scroll which occurs as the ScrollView glides to a stop).\n */\n onMomentumScrollEnd?: ?(event: ScrollEvent) => void,\n\n /**\n * Fires at most once per frame during scrolling. The frequency of the\n * events can be controlled using the `scrollEventThrottle` prop.\n */\n onScroll?: ?(event: ScrollEvent) => void,\n /**\n * Called when the user begins to drag the scroll view.\n */\n onScrollBeginDrag?: ?(event: ScrollEvent) => void,\n /**\n * Called when the user stops dragging the scroll view and it either stops\n * or begins to glide.\n */\n onScrollEndDrag?: ?(event: ScrollEvent) => void,\n /**\n * Called when scrollable content view of the ScrollView changes.\n *\n * Handler function is passed the content width and content height as parameters:\n * `(contentWidth, contentHeight)`\n *\n * It's implemented using onLayout handler attached to the content container\n * which this ScrollView renders.\n */\n onContentSizeChange?: (contentWidth: number, contentHeight: number) => void,\n onKeyboardDidShow?: (event: KeyboardEvent) => void,\n onKeyboardDidHide?: (event: KeyboardEvent) => void,\n onKeyboardWillShow?: (event: KeyboardEvent) => void,\n onKeyboardWillHide?: (event: KeyboardEvent) => void,\n /**\n * When true, the scroll view stops on multiples of the scroll view's size\n * when scrolling. This can be used for horizontal pagination. The default\n * value is false.\n *\n * Note: Vertical pagination is not supported on Android.\n */\n pagingEnabled?: ?boolean,\n\n /**\n * When false, the view cannot be scrolled via touch interaction.\n * The default value is true.\n *\n * Note that the view can always be scrolled by calling `scrollTo`.\n */\n scrollEnabled?: ?boolean,\n /**\n * When true, shows a vertical scroll indicator.\n * The default value is true.\n */\n showsVerticalScrollIndicator?: ?boolean,\n /**\n * When true, Sticky header is hidden when scrolling down, and dock at the top\n * when scrolling up\n */\n stickyHeaderHiddenOnScroll?: ?boolean,\n /**\n * An array of child indices determining which children get docked to the\n * top of the screen when scrolling. For example, passing\n * `stickyHeaderIndices={[0]}` will cause the first child to be fixed to the\n * top of the scroll view. This property is not supported in conjunction\n * with `horizontal={true}`.\n */\n stickyHeaderIndices?: ?$ReadOnlyArray,\n /**\n * A React Component that will be used to render sticky headers.\n * To be used together with `stickyHeaderIndices` or with `SectionList`, defaults to `ScrollViewStickyHeader`.\n * You may need to set this if your sticky header uses custom transforms (eg. translation),\n * for example when you want your list to have an animated hidable header.\n */\n StickyHeaderComponent?: StickyHeaderComponentType,\n /**\n * When `snapToInterval` is set, `snapToAlignment` will define the relationship\n * of the snapping to the scroll view.\n *\n * - `'start'` (the default) will align the snap at the left (horizontal) or top (vertical)\n * - `'center'` will align the snap in the center\n * - `'end'` will align the snap at the right (horizontal) or bottom (vertical)\n */\n snapToAlignment?: ?('start' | 'center' | 'end'),\n /**\n * When set, causes the scroll view to stop at multiples of the value of\n * `snapToInterval`. This can be used for paginating through children\n * that have lengths smaller than the scroll view. Typically used in\n * combination with `snapToAlignment` and `decelerationRate=\"fast\"`.\n *\n * Overrides less configurable `pagingEnabled` prop.\n */\n snapToInterval?: ?number,\n /**\n * When set, causes the scroll view to stop at the defined offsets.\n * This can be used for paginating through variously sized children\n * that have lengths smaller than the scroll view. Typically used in\n * combination with `decelerationRate=\"fast\"`.\n *\n * Overrides less configurable `pagingEnabled` and `snapToInterval` props.\n */\n snapToOffsets?: ?$ReadOnlyArray,\n /**\n * Use in conjunction with `snapToOffsets`. By default, the beginning\n * of the list counts as a snap offset. Set `snapToStart` to false to disable\n * this behavior and allow the list to scroll freely between its start and\n * the first `snapToOffsets` offset.\n * The default value is true.\n */\n snapToStart?: ?boolean,\n /**\n * Use in conjunction with `snapToOffsets`. By default, the end\n * of the list counts as a snap offset. Set `snapToEnd` to false to disable\n * this behavior and allow the list to scroll freely between its end and\n * the last `snapToOffsets` offset.\n * The default value is true.\n */\n snapToEnd?: ?boolean,\n /**\n * Experimental: When true, offscreen child views (whose `overflow` value is\n * `hidden`) are removed from their native backing superview when offscreen.\n * This can improve scrolling performance on long lists. The default value is\n * true.\n */\n removeClippedSubviews?: ?boolean,\n /**\n * A RefreshControl component, used to provide pull-to-refresh\n * functionality for the ScrollView. Only works for vertical ScrollViews\n * (`horizontal` prop must be `false`).\n *\n * See [RefreshControl](docs/refreshcontrol.html).\n */\n /* $FlowFixMe[unclear-type] - how to handle generic type without existential\n * operator? */\n refreshControl?: ?React.Element,\n children?: React.Node,\n /**\n * A ref to the inner View element of the ScrollView. This should be used\n * instead of calling `getInnerViewRef`.\n */\n innerViewRef?: React.Ref,\n /**\n * A ref to the Native ScrollView component. This ref can be used to call\n * all of ScrollView's public methods, in addition to native methods like\n * measure, measureLayout, etc.\n */\n scrollViewRef?: React.Ref<\n typeof ScrollViewNativeComponent & ScrollViewImperativeMethods,\n >,\n|}>;\n\ntype State = {|\n layoutHeight: ?number,\n|};\n\nconst IS_ANIMATING_TOUCH_START_THRESHOLD_MS = 16;\n\nexport type ScrollViewComponentStatics = $ReadOnly<{|\n Context: typeof ScrollViewContext,\n|}>;\n\n/**\n * Component that wraps platform ScrollView while providing\n * integration with touch locking \"responder\" system.\n *\n * Keep in mind that ScrollViews must have a bounded height in order to work,\n * since they contain unbounded-height children into a bounded container (via\n * a scroll interaction). In order to bound the height of a ScrollView, either\n * set the height of the view directly (discouraged) or make sure all parent\n * views have bounded height. Forgetting to transfer `{flex: 1}` down the\n * view stack can lead to errors here, which the element inspector makes\n * easy to debug.\n *\n * Doesn't yet support other contained responders from blocking this scroll\n * view from becoming the responder.\n *\n *\n * `` vs [``](https://reactnative.dev/docs/flatlist) - which one to use?\n *\n * `ScrollView` simply renders all its react child components at once. That\n * makes it very easy to understand and use.\n *\n * On the other hand, this has a performance downside. Imagine you have a very\n * long list of items you want to display, maybe several screens worth of\n * content. Creating JS components and native views for everything all at once,\n * much of which may not even be shown, will contribute to slow rendering and\n * increased memory usage.\n *\n * This is where `FlatList` comes into play. `FlatList` renders items lazily,\n * just when they are about to appear, and removes items that scroll way off\n * screen to save memory and processing time.\n *\n * `FlatList` is also handy if you want to render separators between your items,\n * multiple columns, infinite scroll loading, or any number of other features it\n * supports out of the box.\n */\nclass ScrollView extends React.Component {\n static Context: typeof ScrollViewContext = ScrollViewContext;\n\n constructor(props: Props) {\n super(props);\n\n this._scrollAnimatedValue = new AnimatedImplementation.Value(\n this.props.contentOffset?.y ?? 0,\n );\n this._scrollAnimatedValue.setOffset(this.props.contentInset?.top ?? 0);\n }\n\n _scrollAnimatedValue: AnimatedImplementation.Value;\n _scrollAnimatedValueAttachment: ?{detach: () => void, ...} = null;\n _stickyHeaderRefs: Map> =\n new Map();\n _headerLayoutYs: Map = new Map();\n\n _keyboardMetrics: ?KeyboardMetrics = null;\n _additionalScrollOffset: number = 0;\n _isTouching: boolean = false;\n _lastMomentumScrollBeginTime: number = 0;\n _lastMomentumScrollEndTime: number = 0;\n\n // Reset to false every time becomes responder. This is used to:\n // - Determine if the scroll view has been scrolled and therefore should\n // refuse to give up its responder lock.\n // - Determine if releasing should dismiss the keyboard when we are in\n // tap-to-dismiss mode (this.props.keyboardShouldPersistTaps !== 'always').\n _observedScrollSinceBecomingResponder: boolean = false;\n _becameResponderWhileAnimating: boolean = false;\n _preventNegativeScrollOffset: ?boolean = null;\n\n _animated = null;\n\n _subscriptionKeyboardWillShow: ?EventSubscription = null;\n _subscriptionKeyboardWillHide: ?EventSubscription = null;\n _subscriptionKeyboardDidShow: ?EventSubscription = null;\n _subscriptionKeyboardDidHide: ?EventSubscription = null;\n\n state: State = {\n layoutHeight: null,\n };\n\n componentDidMount() {\n if (typeof this.props.keyboardShouldPersistTaps === 'boolean') {\n console.warn(\n `'keyboardShouldPersistTaps={${\n this.props.keyboardShouldPersistTaps === true ? 'true' : 'false'\n }}' is deprecated. ` +\n `Use 'keyboardShouldPersistTaps=\"${\n this.props.keyboardShouldPersistTaps ? 'always' : 'never'\n }\"' instead`,\n );\n }\n\n this._keyboardMetrics = Keyboard.metrics();\n this._additionalScrollOffset = 0;\n\n this._subscriptionKeyboardWillShow = Keyboard.addListener(\n 'keyboardWillShow',\n this.scrollResponderKeyboardWillShow,\n );\n this._subscriptionKeyboardWillHide = Keyboard.addListener(\n 'keyboardWillHide',\n this.scrollResponderKeyboardWillHide,\n );\n this._subscriptionKeyboardDidShow = Keyboard.addListener(\n 'keyboardDidShow',\n this.scrollResponderKeyboardDidShow,\n );\n this._subscriptionKeyboardDidHide = Keyboard.addListener(\n 'keyboardDidHide',\n this.scrollResponderKeyboardDidHide,\n );\n\n this._updateAnimatedNodeAttachment();\n }\n\n componentDidUpdate(prevProps: Props) {\n const prevContentInsetTop = prevProps.contentInset\n ? prevProps.contentInset.top\n : 0;\n const newContentInsetTop = this.props.contentInset\n ? this.props.contentInset.top\n : 0;\n if (prevContentInsetTop !== newContentInsetTop) {\n this._scrollAnimatedValue.setOffset(newContentInsetTop || 0);\n }\n\n this._updateAnimatedNodeAttachment();\n }\n\n componentWillUnmount() {\n if (this._subscriptionKeyboardWillShow != null) {\n this._subscriptionKeyboardWillShow.remove();\n }\n if (this._subscriptionKeyboardWillHide != null) {\n this._subscriptionKeyboardWillHide.remove();\n }\n if (this._subscriptionKeyboardDidShow != null) {\n this._subscriptionKeyboardDidShow.remove();\n }\n if (this._subscriptionKeyboardDidHide != null) {\n this._subscriptionKeyboardDidHide.remove();\n }\n\n if (this._scrollAnimatedValueAttachment) {\n this._scrollAnimatedValueAttachment.detach();\n }\n }\n\n _setNativeRef: $FlowFixMe = setAndForwardRef({\n getForwardedRef: () => this.props.scrollViewRef,\n setLocalRef: ref => {\n this._scrollViewRef = ref;\n\n /*\n This is a hack. Ideally we would forwardRef to the underlying\n host component. However, since ScrollView has it's own methods that can be\n called as well, if we used the standard forwardRef then these\n methods wouldn't be accessible and thus be a breaking change.\n\n Therefore we edit ref to include ScrollView's public methods so that\n they are callable from the ref.\n */\n if (ref) {\n ref.getScrollResponder = this.getScrollResponder;\n ref.getScrollableNode = this.getScrollableNode;\n ref.getInnerViewNode = this.getInnerViewNode;\n ref.getInnerViewRef = this.getInnerViewRef;\n ref.getNativeScrollRef = this.getNativeScrollRef;\n ref.scrollTo = this.scrollTo;\n ref.scrollToEnd = this.scrollToEnd;\n ref.flashScrollIndicators = this.flashScrollIndicators;\n ref.scrollResponderZoomTo = this.scrollResponderZoomTo;\n ref.scrollResponderScrollNativeHandleToKeyboard =\n this.scrollResponderScrollNativeHandleToKeyboard;\n }\n },\n });\n\n /**\n * Returns a reference to the underlying scroll responder, which supports\n * operations like `scrollTo`. All ScrollView-like components should\n * implement this method so that they can be composed while providing access\n * to the underlying scroll responder's methods.\n */\n getScrollResponder: () => ScrollResponderType = () => {\n // $FlowFixMe[unclear-type]\n return ((this: any): ScrollResponderType);\n };\n\n getScrollableNode: () => ?number = () => {\n return findNodeHandle(this._scrollViewRef);\n };\n\n getInnerViewNode: () => ?number = () => {\n return findNodeHandle(this._innerViewRef);\n };\n\n getInnerViewRef: () => ?React.ElementRef = () => {\n return this._innerViewRef;\n };\n\n getNativeScrollRef: () => ?React.ElementRef> = () => {\n return this._scrollViewRef;\n };\n\n /**\n * Scrolls to a given x, y offset, either immediately or with a smooth animation.\n *\n * Example:\n *\n * `scrollTo({x: 0, y: 0, animated: true})`\n *\n * Note: The weird function signature is due to the fact that, for historical reasons,\n * the function also accepts separate arguments as an alternative to the options object.\n * This is deprecated due to ambiguity (y before x), and SHOULD NOT BE USED.\n */\n scrollTo: (\n options?:\n | {\n x?: number,\n y?: number,\n animated?: boolean,\n ...\n }\n | number,\n deprecatedX?: number,\n deprecatedAnimated?: boolean,\n ) => void = (\n options?:\n | {\n x?: number,\n y?: number,\n animated?: boolean,\n ...\n }\n | number,\n deprecatedX?: number,\n deprecatedAnimated?: boolean,\n ) => {\n let x, y, animated;\n if (typeof options === 'number') {\n console.warn(\n '`scrollTo(y, x, animated)` is deprecated. Use `scrollTo({x: 5, y: 5, ' +\n 'animated: true})` instead.',\n );\n y = options;\n x = deprecatedX;\n animated = deprecatedAnimated;\n } else if (options) {\n y = options.y;\n x = options.x;\n animated = options.animated;\n }\n if (this._scrollViewRef == null) {\n return;\n }\n Commands.scrollTo(this._scrollViewRef, x || 0, y || 0, animated !== false);\n };\n\n /**\n * If this is a vertical ScrollView scrolls to the bottom.\n * If this is a horizontal ScrollView scrolls to the right.\n *\n * Use `scrollToEnd({animated: true})` for smooth animated scrolling,\n * `scrollToEnd({animated: false})` for immediate scrolling.\n * If no options are passed, `animated` defaults to true.\n */\n scrollToEnd: (options?: ?{animated?: boolean, ...}) => void = (\n options?: ?{animated?: boolean, ...},\n ) => {\n // Default to true\n const animated = (options && options.animated) !== false;\n if (this._scrollViewRef == null) {\n return;\n }\n Commands.scrollToEnd(this._scrollViewRef, animated);\n };\n\n /**\n * Displays the scroll indicators momentarily.\n *\n * @platform ios\n */\n flashScrollIndicators: () => void = () => {\n if (this._scrollViewRef == null) {\n return;\n }\n Commands.flashScrollIndicators(this._scrollViewRef);\n };\n\n /**\n * This method should be used as the callback to onFocus in a TextInputs'\n * parent view. Note that any module using this mixin needs to return\n * the parent view's ref in getScrollViewRef() in order to use this method.\n * @param {number} nodeHandle The TextInput node handle\n * @param {number} additionalOffset The scroll view's bottom \"contentInset\".\n * Default is 0.\n * @param {bool} preventNegativeScrolling Whether to allow pulling the content\n * down to make it meet the keyboard's top. Default is false.\n */\n scrollResponderScrollNativeHandleToKeyboard: (\n nodeHandle: number | React.ElementRef>,\n additionalOffset?: number,\n preventNegativeScrollOffset?: boolean,\n ) => void = (\n nodeHandle: number | React.ElementRef>,\n additionalOffset?: number,\n preventNegativeScrollOffset?: boolean,\n ) => {\n this._additionalScrollOffset = additionalOffset || 0;\n this._preventNegativeScrollOffset = !!preventNegativeScrollOffset;\n\n if (this._innerViewRef == null) {\n return;\n }\n\n if (typeof nodeHandle === 'number') {\n UIManager.measureLayout(\n nodeHandle,\n findNodeHandle(this),\n // $FlowFixMe[method-unbinding] added when improving typing for this parameters\n this._textInputFocusError,\n this._inputMeasureAndScrollToKeyboard,\n );\n } else {\n nodeHandle.measureLayout(\n this._innerViewRef,\n this._inputMeasureAndScrollToKeyboard,\n // $FlowFixMe[method-unbinding] added when improving typing for this parameters\n this._textInputFocusError,\n );\n }\n };\n\n /**\n * A helper function to zoom to a specific rect in the scrollview. The argument has the shape\n * {x: number; y: number; width: number; height: number; animated: boolean = true}\n *\n * @platform ios\n */\n scrollResponderZoomTo: (\n rect: {|\n x: number,\n y: number,\n width: number,\n height: number,\n animated?: boolean,\n |},\n animated?: boolean, // deprecated, put this inside the rect argument instead\n ) => void = (\n rect: {|\n x: number,\n y: number,\n width: number,\n height: number,\n animated?: boolean,\n |},\n animated?: boolean, // deprecated, put this inside the rect argument instead\n ) => {\n invariant(Platform.OS === 'ios', 'zoomToRect is not implemented');\n if ('animated' in rect) {\n this._animated = rect.animated;\n delete rect.animated;\n } else if (typeof animated !== 'undefined') {\n console.warn(\n '`scrollResponderZoomTo` `animated` argument is deprecated. Use `options.animated` instead',\n );\n }\n\n if (this._scrollViewRef == null) {\n return;\n }\n Commands.zoomToRect(this._scrollViewRef, rect, animated !== false);\n };\n\n _textInputFocusError() {\n console.warn('Error measuring text field.');\n }\n\n /**\n * The calculations performed here assume the scroll view takes up the entire\n * screen - even if has some content inset. We then measure the offsets of the\n * keyboard, and compensate both for the scroll view's \"contentInset\".\n *\n * @param {number} left Position of input w.r.t. table view.\n * @param {number} top Position of input w.r.t. table view.\n * @param {number} width Width of the text input.\n * @param {number} height Height of the text input.\n */\n _inputMeasureAndScrollToKeyboard: (\n left: number,\n top: number,\n width: number,\n height: number,\n ) => void = (left: number, top: number, width: number, height: number) => {\n let keyboardScreenY = Dimensions.get('window').height;\n\n const scrollTextInputIntoVisibleRect = () => {\n if (this._keyboardMetrics != null) {\n keyboardScreenY = this._keyboardMetrics.screenY;\n }\n let scrollOffsetY =\n top - keyboardScreenY + height + this._additionalScrollOffset;\n\n // By default, this can scroll with negative offset, pulling the content\n // down so that the target component's bottom meets the keyboard's top.\n // If requested otherwise, cap the offset at 0 minimum to avoid content\n // shifting down.\n if (this._preventNegativeScrollOffset === true) {\n scrollOffsetY = Math.max(0, scrollOffsetY);\n }\n this.scrollTo({x: 0, y: scrollOffsetY, animated: true});\n\n this._additionalScrollOffset = 0;\n this._preventNegativeScrollOffset = false;\n };\n\n if (this._keyboardMetrics == null) {\n // `_keyboardMetrics` is set inside `scrollResponderKeyboardWillShow` which\n // is not guaranteed to be called before `_inputMeasureAndScrollToKeyboard` but native has already scheduled it.\n // In case it was not called before `_inputMeasureAndScrollToKeyboard`, we postpone scrolling to\n // text input.\n setTimeout(() => {\n scrollTextInputIntoVisibleRect();\n }, 0);\n } else {\n scrollTextInputIntoVisibleRect();\n }\n };\n\n _getKeyForIndex(index: $FlowFixMe, childArray: $FlowFixMe): $FlowFixMe {\n const child = childArray[index];\n return child && child.key;\n }\n\n _updateAnimatedNodeAttachment() {\n if (this._scrollAnimatedValueAttachment) {\n this._scrollAnimatedValueAttachment.detach();\n }\n if (\n this.props.stickyHeaderIndices &&\n this.props.stickyHeaderIndices.length > 0\n ) {\n this._scrollAnimatedValueAttachment =\n AnimatedImplementation.attachNativeEvent(\n this._scrollViewRef,\n 'onScroll',\n [{nativeEvent: {contentOffset: {y: this._scrollAnimatedValue}}}],\n );\n }\n }\n\n _setStickyHeaderRef(\n key: string,\n ref: ?React.ElementRef,\n ) {\n if (ref) {\n this._stickyHeaderRefs.set(key, ref);\n } else {\n this._stickyHeaderRefs.delete(key);\n }\n }\n\n _onStickyHeaderLayout(index: $FlowFixMe, event: $FlowFixMe, key: $FlowFixMe) {\n const {stickyHeaderIndices} = this.props;\n if (!stickyHeaderIndices) {\n return;\n }\n const childArray = React.Children.toArray(this.props.children);\n if (key !== this._getKeyForIndex(index, childArray)) {\n // ignore stale layout update\n return;\n }\n\n const layoutY = event.nativeEvent.layout.y;\n this._headerLayoutYs.set(key, layoutY);\n\n const indexOfIndex = stickyHeaderIndices.indexOf(index);\n const previousHeaderIndex = stickyHeaderIndices[indexOfIndex - 1];\n if (previousHeaderIndex != null) {\n const previousHeader = this._stickyHeaderRefs.get(\n this._getKeyForIndex(previousHeaderIndex, childArray),\n );\n previousHeader &&\n previousHeader.setNextHeaderY &&\n previousHeader.setNextHeaderY(layoutY);\n }\n }\n\n _handleScroll = (e: ScrollEvent) => {\n if (__DEV__) {\n if (\n this.props.onScroll &&\n this.props.scrollEventThrottle == null &&\n Platform.OS === 'ios'\n ) {\n console.log(\n 'You specified `onScroll` on a but not ' +\n '`scrollEventThrottle`. You will only receive one event. ' +\n 'Using `16` you get all the events but be aware that it may ' +\n \"cause frame drops, use a bigger number if you don't need as \" +\n 'much precision.',\n );\n }\n }\n this._observedScrollSinceBecomingResponder = true;\n this.props.onScroll && this.props.onScroll(e);\n };\n\n _handleLayout = (e: LayoutEvent) => {\n if (this.props.invertStickyHeaders === true) {\n this.setState({layoutHeight: e.nativeEvent.layout.height});\n }\n if (this.props.onLayout) {\n this.props.onLayout(e);\n }\n };\n\n _handleContentOnLayout = (e: LayoutEvent) => {\n const {width, height} = e.nativeEvent.layout;\n this.props.onContentSizeChange &&\n this.props.onContentSizeChange(width, height);\n };\n\n _scrollViewRef: ?React.ElementRef> = null;\n\n _innerViewRef: ?React.ElementRef = null;\n _setInnerViewRef: $FlowFixMe = setAndForwardRef({\n getForwardedRef: () => this.props.innerViewRef,\n setLocalRef: ref => {\n this._innerViewRef = ref;\n },\n });\n\n /**\n * Warning, this may be called several times for a single keyboard opening.\n * It's best to store the information in this method and then take any action\n * at a later point (either in `keyboardDidShow` or other).\n *\n * Here's the order that events occur in:\n * - focus\n * - willShow {startCoordinates, endCoordinates} several times\n * - didShow several times\n * - blur\n * - willHide {startCoordinates, endCoordinates} several times\n * - didHide several times\n *\n * The `ScrollResponder` module callbacks for each of these events.\n * Even though any user could have easily listened to keyboard events\n * themselves, using these `props` callbacks ensures that ordering of events\n * is consistent - and not dependent on the order that the keyboard events are\n * subscribed to. This matters when telling the scroll view to scroll to where\n * the keyboard is headed - the scroll responder better have been notified of\n * the keyboard destination before being instructed to scroll to where the\n * keyboard will be. Stick to the `ScrollResponder` callbacks, and everything\n * will work.\n *\n * WARNING: These callbacks will fire even if a keyboard is displayed in a\n * different navigation pane. Filter out the events to determine if they are\n * relevant to you. (For example, only if you receive these callbacks after\n * you had explicitly focused a node etc).\n */\n\n scrollResponderKeyboardWillShow: (e: KeyboardEvent) => void = (\n e: KeyboardEvent,\n ) => {\n this._keyboardMetrics = e.endCoordinates;\n this.props.onKeyboardWillShow && this.props.onKeyboardWillShow(e);\n };\n\n scrollResponderKeyboardWillHide: (e: KeyboardEvent) => void = (\n e: KeyboardEvent,\n ) => {\n this._keyboardMetrics = null;\n this.props.onKeyboardWillHide && this.props.onKeyboardWillHide(e);\n };\n\n scrollResponderKeyboardDidShow: (e: KeyboardEvent) => void = (\n e: KeyboardEvent,\n ) => {\n this._keyboardMetrics = e.endCoordinates;\n this.props.onKeyboardDidShow && this.props.onKeyboardDidShow(e);\n };\n\n scrollResponderKeyboardDidHide: (e: KeyboardEvent) => void = (\n e: KeyboardEvent,\n ) => {\n this._keyboardMetrics = null;\n this.props.onKeyboardDidHide && this.props.onKeyboardDidHide(e);\n };\n\n /**\n * Invoke this from an `onMomentumScrollBegin` event.\n */\n _handleMomentumScrollBegin: (e: ScrollEvent) => void = (e: ScrollEvent) => {\n this._lastMomentumScrollBeginTime = global.performance.now();\n this.props.onMomentumScrollBegin && this.props.onMomentumScrollBegin(e);\n };\n\n /**\n * Invoke this from an `onMomentumScrollEnd` event.\n */\n _handleMomentumScrollEnd: (e: ScrollEvent) => void = (e: ScrollEvent) => {\n FrameRateLogger.endScroll();\n this._lastMomentumScrollEndTime = global.performance.now();\n this.props.onMomentumScrollEnd && this.props.onMomentumScrollEnd(e);\n };\n\n /**\n * Unfortunately, `onScrollBeginDrag` also fires when *stopping* the scroll\n * animation, and there's not an easy way to distinguish a drag vs. stopping\n * momentum.\n *\n * Invoke this from an `onScrollBeginDrag` event.\n */\n _handleScrollBeginDrag: (e: ScrollEvent) => void = (e: ScrollEvent) => {\n FrameRateLogger.beginScroll(); // TODO: track all scrolls after implementing onScrollEndAnimation\n\n if (\n Platform.OS === 'android' &&\n this.props.keyboardDismissMode === 'on-drag'\n ) {\n dismissKeyboard();\n }\n\n this.props.onScrollBeginDrag && this.props.onScrollBeginDrag(e);\n };\n\n /**\n * Invoke this from an `onScrollEndDrag` event.\n */\n _handleScrollEndDrag: (e: ScrollEvent) => void = (e: ScrollEvent) => {\n const {velocity} = e.nativeEvent;\n // - If we are animating, then this is a \"drag\" that is stopping the scrollview and momentum end\n // will fire.\n // - If velocity is non-zero, then the interaction will stop when momentum scroll ends or\n // another drag starts and ends.\n // - If we don't get velocity, better to stop the interaction twice than not stop it.\n if (\n !this._isAnimating() &&\n (!velocity || (velocity.x === 0 && velocity.y === 0))\n ) {\n FrameRateLogger.endScroll();\n }\n this.props.onScrollEndDrag && this.props.onScrollEndDrag(e);\n };\n\n /**\n * A helper function for this class that lets us quickly determine if the\n * view is currently animating. This is particularly useful to know when\n * a touch has just started or ended.\n */\n _isAnimating: () => boolean = () => {\n const now = global.performance.now();\n const timeSinceLastMomentumScrollEnd =\n now - this._lastMomentumScrollEndTime;\n const isAnimating =\n timeSinceLastMomentumScrollEnd < IS_ANIMATING_TOUCH_START_THRESHOLD_MS ||\n this._lastMomentumScrollEndTime < this._lastMomentumScrollBeginTime;\n return isAnimating;\n };\n\n /**\n * Invoke this from an `onResponderGrant` event.\n */\n _handleResponderGrant: (e: PressEvent) => void = (e: PressEvent) => {\n this._observedScrollSinceBecomingResponder = false;\n this.props.onResponderGrant && this.props.onResponderGrant(e);\n this._becameResponderWhileAnimating = this._isAnimating();\n };\n\n /**\n * Invoke this from an `onResponderReject` event.\n *\n * Some other element is not yielding its role as responder. Normally, we'd\n * just disable the `UIScrollView`, but a touch has already began on it, the\n * `UIScrollView` will not accept being disabled after that. The easiest\n * solution for now is to accept the limitation of disallowing this\n * altogether. To improve this, find a way to disable the `UIScrollView` after\n * a touch has already started.\n */\n _handleResponderReject: () => void = () => {};\n\n /**\n * Invoke this from an `onResponderRelease` event.\n */\n _handleResponderRelease: (e: PressEvent) => void = (e: PressEvent) => {\n this._isTouching = e.nativeEvent.touches.length !== 0;\n this.props.onResponderRelease && this.props.onResponderRelease(e);\n\n if (typeof e.target === 'number') {\n if (__DEV__) {\n console.error(\n 'Did not expect event target to be a number. Should have been a native component',\n );\n }\n\n return;\n }\n\n // By default scroll views will unfocus a textField\n // if another touch occurs outside of it\n const currentlyFocusedTextInput = TextInputState.currentlyFocusedInput();\n if (\n currentlyFocusedTextInput != null &&\n this.props.keyboardShouldPersistTaps !== true &&\n this.props.keyboardShouldPersistTaps !== 'always' &&\n this._keyboardIsDismissible() &&\n e.target !== currentlyFocusedTextInput &&\n !this._observedScrollSinceBecomingResponder &&\n !this._becameResponderWhileAnimating\n ) {\n TextInputState.blurTextInput(currentlyFocusedTextInput);\n }\n };\n\n /**\n * We will allow the scroll view to give up its lock iff it acquired the lock\n * during an animation. This is a very useful default that happens to satisfy\n * many common user experiences.\n *\n * - Stop a scroll on the left edge, then turn that into an outer view's\n * backswipe.\n * - Stop a scroll mid-bounce at the top, continue pulling to have the outer\n * view dismiss.\n * - However, without catching the scroll view mid-bounce (while it is\n * motionless), if you drag far enough for the scroll view to become\n * responder (and therefore drag the scroll view a bit), any backswipe\n * navigation of a swipe gesture higher in the view hierarchy, should be\n * rejected.\n */\n _handleResponderTerminationRequest: () => boolean = () => {\n return !this._observedScrollSinceBecomingResponder;\n };\n\n /**\n * Invoke this from an `onScroll` event.\n */\n _handleScrollShouldSetResponder: () => boolean = () => {\n // Allow any event touch pass through if the default pan responder is disabled\n if (this.props.disableScrollViewPanResponder === true) {\n return false;\n }\n return this._isTouching;\n };\n\n /**\n * Merely touch starting is not sufficient for a scroll view to become the\n * responder. Being the \"responder\" means that the very next touch move/end\n * event will result in an action/movement.\n *\n * Invoke this from an `onStartShouldSetResponder` event.\n *\n * `onStartShouldSetResponder` is used when the next move/end will trigger\n * some UI movement/action, but when you want to yield priority to views\n * nested inside of the view.\n *\n * There may be some cases where scroll views actually should return `true`\n * from `onStartShouldSetResponder`: Any time we are detecting a standard tap\n * that gives priority to nested views.\n *\n * - If a single tap on the scroll view triggers an action such as\n * recentering a map style view yet wants to give priority to interaction\n * views inside (such as dropped pins or labels), then we would return true\n * from this method when there is a single touch.\n *\n * - Similar to the previous case, if a two finger \"tap\" should trigger a\n * zoom, we would check the `touches` count, and if `>= 2`, we would return\n * true.\n *\n */\n _handleStartShouldSetResponder: (e: PressEvent) => boolean = (\n e: PressEvent,\n ) => {\n // Allow any event touch pass through if the default pan responder is disabled\n if (this.props.disableScrollViewPanResponder === true) {\n return false;\n }\n\n const currentlyFocusedInput = TextInputState.currentlyFocusedInput();\n if (\n this.props.keyboardShouldPersistTaps === 'handled' &&\n this._keyboardIsDismissible() &&\n e.target !== currentlyFocusedInput\n ) {\n return true;\n }\n return false;\n };\n\n /**\n * There are times when the scroll view wants to become the responder\n * (meaning respond to the next immediate `touchStart/touchEnd`), in a way\n * that *doesn't* give priority to nested views (hence the capture phase):\n *\n * - Currently animating.\n * - Tapping anywhere that is not a text input, while the keyboard is\n * up (which should dismiss the keyboard).\n *\n * Invoke this from an `onStartShouldSetResponderCapture` event.\n */\n _handleStartShouldSetResponderCapture: (e: PressEvent) => boolean = (\n e: PressEvent,\n ) => {\n // The scroll view should receive taps instead of its descendants if:\n // * it is already animating/decelerating\n if (this._isAnimating()) {\n return true;\n }\n\n // Allow any event touch pass through if the default pan responder is disabled\n if (this.props.disableScrollViewPanResponder === true) {\n return false;\n }\n\n // * the keyboard is up, keyboardShouldPersistTaps is 'never' (the default),\n // and a new touch starts with a non-textinput target (in which case the\n // first tap should be sent to the scroll view and dismiss the keyboard,\n // then the second tap goes to the actual interior view)\n const {keyboardShouldPersistTaps} = this.props;\n const keyboardNeverPersistTaps =\n !keyboardShouldPersistTaps || keyboardShouldPersistTaps === 'never';\n\n if (typeof e.target === 'number') {\n if (__DEV__) {\n console.error(\n 'Did not expect event target to be a number. Should have been a native component',\n );\n }\n\n return false;\n }\n\n // Let presses through if the soft keyboard is detached from the viewport\n if (this._softKeyboardIsDetached()) {\n return false;\n }\n\n if (\n keyboardNeverPersistTaps &&\n this._keyboardIsDismissible() &&\n e.target != null &&\n // $FlowFixMe[incompatible-call]\n !TextInputState.isTextInput(e.target)\n ) {\n return true;\n }\n\n return false;\n };\n\n /**\n * Do we consider there to be a dismissible soft-keyboard open?\n */\n _keyboardIsDismissible: () => boolean = () => {\n const currentlyFocusedInput = TextInputState.currentlyFocusedInput();\n\n // We cannot dismiss the keyboard without an input to blur, even if a soft\n // keyboard is open (e.g. when keyboard is open due to a native component\n // not participating in TextInputState). It's also possible that the\n // currently focused input isn't a TextInput (such as by calling ref.focus\n // on a non-TextInput).\n const hasFocusedTextInput =\n currentlyFocusedInput != null &&\n TextInputState.isTextInput(currentlyFocusedInput);\n\n // Even if an input is focused, we may not have a keyboard to dismiss. E.g\n // when using a physical keyboard. Ensure we have an event for an opened\n // keyboard.\n const softKeyboardMayBeOpen =\n this._keyboardMetrics != null || this._keyboardEventsAreUnreliable();\n\n return hasFocusedTextInput && softKeyboardMayBeOpen;\n };\n\n /**\n * Whether an open soft keyboard is present which does not overlap the\n * viewport. E.g. for a VR soft-keyboard which is detached from the app\n * viewport.\n */\n _softKeyboardIsDetached: () => boolean = () => {\n return this._keyboardMetrics != null && this._keyboardMetrics.height === 0;\n };\n\n _keyboardEventsAreUnreliable: () => boolean = () => {\n // Android versions prior to API 30 rely on observing layout changes when\n // `android:windowSoftInputMode` is set to `adjustResize` or `adjustPan`.\n return Platform.OS === 'android' && Platform.Version < 30;\n };\n\n /**\n * Invoke this from an `onTouchEnd` event.\n *\n * @param {PressEvent} e Event.\n */\n _handleTouchEnd: (e: PressEvent) => void = (e: PressEvent) => {\n const nativeEvent = e.nativeEvent;\n this._isTouching = nativeEvent.touches.length !== 0;\n\n const {keyboardShouldPersistTaps} = this.props;\n const keyboardNeverPersistsTaps =\n !keyboardShouldPersistTaps || keyboardShouldPersistTaps === 'never';\n\n // Dismiss the keyboard now if we didn't become responder in capture phase\n // to eat presses, but still want to dismiss on interaction.\n // Don't do anything if the target of the touch event is the current input.\n const currentlyFocusedTextInput = TextInputState.currentlyFocusedInput();\n if (\n currentlyFocusedTextInput != null &&\n e.target !== currentlyFocusedTextInput &&\n this._softKeyboardIsDetached() &&\n this._keyboardIsDismissible() &&\n keyboardNeverPersistsTaps\n ) {\n TextInputState.blurTextInput(currentlyFocusedTextInput);\n }\n\n this.props.onTouchEnd && this.props.onTouchEnd(e);\n };\n\n /**\n * Invoke this from an `onTouchCancel` event.\n *\n * @param {PressEvent} e Event.\n */\n _handleTouchCancel: (e: PressEvent) => void = (e: PressEvent) => {\n this._isTouching = false;\n this.props.onTouchCancel && this.props.onTouchCancel(e);\n };\n\n /**\n * Invoke this from an `onTouchStart` event.\n *\n * Since we know that the `SimpleEventPlugin` occurs later in the plugin\n * order, after `ResponderEventPlugin`, we can detect that we were *not*\n * permitted to be the responder (presumably because a contained view became\n * responder). The `onResponderReject` won't fire in that case - it only\n * fires when a *current* responder rejects our request.\n *\n * @param {PressEvent} e Touch Start event.\n */\n _handleTouchStart: (e: PressEvent) => void = (e: PressEvent) => {\n this._isTouching = true;\n this.props.onTouchStart && this.props.onTouchStart(e);\n };\n\n /**\n * Invoke this from an `onTouchMove` event.\n *\n * Since we know that the `SimpleEventPlugin` occurs later in the plugin\n * order, after `ResponderEventPlugin`, we can detect that we were *not*\n * permitted to be the responder (presumably because a contained view became\n * responder). The `onResponderReject` won't fire in that case - it only\n * fires when a *current* responder rejects our request.\n *\n * @param {PressEvent} e Touch Start event.\n */\n _handleTouchMove: (e: PressEvent) => void = (e: PressEvent) => {\n this.props.onTouchMove && this.props.onTouchMove(e);\n };\n\n render(): React.Node | React.Element {\n const [NativeDirectionalScrollView, NativeDirectionalScrollContentView] =\n this.props.horizontal === true\n ? NativeHorizontalScrollViewTuple\n : NativeVerticalScrollViewTuple;\n\n const contentContainerStyle = [\n this.props.horizontal === true && styles.contentContainerHorizontal,\n this.props.contentContainerStyle,\n ];\n if (__DEV__ && this.props.style !== undefined) {\n const style = flattenStyle(this.props.style);\n const childLayoutProps = ['alignItems', 'justifyContent'].filter(\n prop => style && style[prop] !== undefined,\n );\n invariant(\n childLayoutProps.length === 0,\n 'ScrollView child layout (' +\n JSON.stringify(childLayoutProps) +\n ') must be applied through the contentContainerStyle prop.',\n );\n }\n\n const contentSizeChangeProps =\n this.props.onContentSizeChange == null\n ? null\n : {\n onLayout: this._handleContentOnLayout,\n };\n\n const {stickyHeaderIndices} = this.props;\n let children = this.props.children;\n\n if (stickyHeaderIndices != null && stickyHeaderIndices.length > 0) {\n const childArray = React.Children.toArray(this.props.children);\n\n children = childArray.map((child, index) => {\n const indexOfIndex = child ? stickyHeaderIndices.indexOf(index) : -1;\n if (indexOfIndex > -1) {\n const key = child.key;\n const nextIndex = stickyHeaderIndices[indexOfIndex + 1];\n const StickyHeaderComponent =\n this.props.StickyHeaderComponent || ScrollViewStickyHeader;\n return (\n this._setStickyHeaderRef(key, ref)}\n nextHeaderLayoutY={this._headerLayoutYs.get(\n this._getKeyForIndex(nextIndex, childArray),\n )}\n onLayout={event => this._onStickyHeaderLayout(index, event, key)}\n scrollAnimatedValue={this._scrollAnimatedValue}\n inverted={this.props.invertStickyHeaders}\n hiddenOnScroll={this.props.stickyHeaderHiddenOnScroll}\n scrollViewHeight={this.state.layoutHeight}>\n {child}\n \n );\n } else {\n return child;\n }\n });\n }\n children = (\n \n {children}\n \n );\n\n const hasStickyHeaders =\n Array.isArray(stickyHeaderIndices) && stickyHeaderIndices.length > 0;\n\n const contentContainer = (\n \n {children}\n \n );\n\n const alwaysBounceHorizontal =\n this.props.alwaysBounceHorizontal !== undefined\n ? this.props.alwaysBounceHorizontal\n : this.props.horizontal;\n\n const alwaysBounceVertical =\n this.props.alwaysBounceVertical !== undefined\n ? this.props.alwaysBounceVertical\n : !this.props.horizontal;\n\n const baseStyle =\n this.props.horizontal === true\n ? styles.baseHorizontal\n : styles.baseVertical;\n const props = {\n ...this.props,\n alwaysBounceHorizontal,\n alwaysBounceVertical,\n style: StyleSheet.compose(baseStyle, this.props.style),\n // Override the onContentSizeChange from props, since this event can\n // bubble up from TextInputs\n onContentSizeChange: null,\n onLayout: this._handleLayout,\n onMomentumScrollBegin: this._handleMomentumScrollBegin,\n onMomentumScrollEnd: this._handleMomentumScrollEnd,\n onResponderGrant: this._handleResponderGrant,\n onResponderReject: this._handleResponderReject,\n onResponderRelease: this._handleResponderRelease,\n onResponderTerminationRequest: this._handleResponderTerminationRequest,\n onScrollBeginDrag: this._handleScrollBeginDrag,\n onScrollEndDrag: this._handleScrollEndDrag,\n onScrollShouldSetResponder: this._handleScrollShouldSetResponder,\n onStartShouldSetResponder: this._handleStartShouldSetResponder,\n onStartShouldSetResponderCapture:\n this._handleStartShouldSetResponderCapture,\n onTouchEnd: this._handleTouchEnd,\n onTouchMove: this._handleTouchMove,\n onTouchStart: this._handleTouchStart,\n onTouchCancel: this._handleTouchCancel,\n onScroll: this._handleScroll,\n scrollEventThrottle: hasStickyHeaders\n ? 1\n : this.props.scrollEventThrottle,\n sendMomentumEvents:\n this.props.onMomentumScrollBegin || this.props.onMomentumScrollEnd\n ? true\n : false,\n // default to true\n snapToStart: this.props.snapToStart !== false,\n // default to true\n snapToEnd: this.props.snapToEnd !== false,\n // pagingEnabled is overridden by snapToInterval / snapToOffsets\n pagingEnabled: Platform.select({\n // on iOS, pagingEnabled must be set to false to have snapToInterval / snapToOffsets work\n ios:\n this.props.pagingEnabled === true &&\n this.props.snapToInterval == null &&\n this.props.snapToOffsets == null,\n // on Android, pagingEnabled must be set to true to have snapToInterval / snapToOffsets work\n android:\n this.props.pagingEnabled === true ||\n this.props.snapToInterval != null ||\n this.props.snapToOffsets != null,\n }),\n };\n\n const {decelerationRate} = this.props;\n if (decelerationRate != null) {\n props.decelerationRate = processDecelerationRate(decelerationRate);\n }\n\n const refreshControl = this.props.refreshControl;\n\n if (refreshControl) {\n if (Platform.OS === 'ios') {\n // On iOS the RefreshControl is a child of the ScrollView.\n return (\n \n {refreshControl}\n {contentContainer}\n \n );\n } else if (Platform.OS === 'android') {\n // On Android wrap the ScrollView with a AndroidSwipeRefreshLayout.\n // Since the ScrollView is wrapped add the style props to the\n // AndroidSwipeRefreshLayout and use flex: 1 for the ScrollView.\n // Note: we should split props.style on the inner and outer props\n // however, the ScrollView still needs the baseStyle to be scrollable\n const {outer, inner} = splitLayoutProps(flattenStyle(props.style));\n return React.cloneElement(\n refreshControl,\n {style: StyleSheet.compose(baseStyle, outer)},\n \n {contentContainer}\n ,\n );\n }\n }\n return (\n \n {contentContainer}\n \n );\n }\n}\n\nconst styles = StyleSheet.create({\n baseVertical: {\n flexGrow: 1,\n flexShrink: 1,\n flexDirection: 'column',\n overflow: 'scroll',\n },\n baseHorizontal: {\n flexGrow: 1,\n flexShrink: 1,\n flexDirection: 'row',\n overflow: 'scroll',\n },\n contentContainerHorizontal: {\n flexDirection: 'row',\n },\n});\n\n/* $FlowFixMe[missing-local-annot] The type annotation(s) required by Flow's\n * LTI update could not be added via codemod */\nfunction Wrapper(props, ref: (mixed => mixed) | {current: mixed, ...}) {\n return ;\n}\nWrapper.displayName = 'ScrollView';\nconst ForwardedScrollView = React.forwardRef(Wrapper);\n\n// $FlowFixMe[prop-missing] Add static context to ForwardedScrollView\nForwardedScrollView.Context = ScrollViewContext;\n\nForwardedScrollView.displayName = 'ScrollView';\n\nmodule.exports = ((ForwardedScrollView: $FlowFixMe): React.AbstractComponent<\n React.ElementConfig,\n $ReadOnly<{|\n ...$Exact>>,\n ...ScrollViewImperativeMethods,\n |}>,\n> &\n ScrollViewComponentStatics);\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 * @format\n * @flow strict-local\n */\n\nimport NativeFrameRateLogger from './NativeFrameRateLogger';\n\nconst invariant = require('invariant');\n\n/**\n * Flow API for native FrameRateLogger module. If the native module is not installed, function calls\n * are just no-ops.\n *\n * Typical behavior is that `setContext` is called when a new screen is loaded (e.g. via a\n * navigation integration), and then `beginScroll` is called by `ScrollResponder` at which point the\n * native module then begins tracking frame drops. When `ScrollResponder` calls `endScroll`, the\n * native module gathers up all it's frame drop data and reports it via an analytics pipeline for\n * analysis.\n *\n * Note that `beginScroll` may be called multiple times by `ScrollResponder` - unclear if that's a\n * bug, but the native module should be robust to that.\n *\n * In the future we may add support for tracking frame drops in other types of interactions beyond\n * scrolling.\n */\nconst FrameRateLogger = {\n /**\n * Enable `debug` to see local logs of what's going on. `reportStackTraces` will grab stack traces\n * during UI thread stalls and upload them if the native module supports it.\n */\n setGlobalOptions: function (options: {\n debug?: boolean,\n reportStackTraces?: boolean,\n ...\n }) {\n if (options.debug !== undefined) {\n invariant(\n NativeFrameRateLogger,\n 'Trying to debug FrameRateLogger without the native module!',\n );\n }\n if (NativeFrameRateLogger) {\n // Needs to clone the object first to avoid modifying the argument.\n const optionsClone = {\n debug: !!options.debug,\n reportStackTraces: !!options.reportStackTraces,\n };\n NativeFrameRateLogger.setGlobalOptions(optionsClone);\n }\n },\n\n /**\n * Must call `setContext` before any events can be properly tracked, which is done automatically\n * in `AppRegistry`, but navigation is also a common place to hook in.\n */\n setContext: function (context: string) {\n NativeFrameRateLogger && NativeFrameRateLogger.setContext(context);\n },\n\n /**\n * Called in `ScrollResponder` so any component that uses that module will handle this\n * automatically.\n */\n beginScroll() {\n NativeFrameRateLogger && NativeFrameRateLogger.beginScroll();\n },\n\n /**\n * Called in `ScrollResponder` so any component that uses that module will handle this\n * automatically.\n */\n endScroll() {\n NativeFrameRateLogger && NativeFrameRateLogger.endScroll();\n },\n};\n\nmodule.exports = FrameRateLogger;\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 * @format\n * @flow strict\n */\n\nimport type {TurboModule} from '../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../TurboModule/TurboModuleRegistry';\n\nexport interface Spec extends TurboModule {\n +setGlobalOptions: (options: {|\n +debug?: ?boolean,\n +reportStackTraces?: ?boolean,\n |}) => void;\n +setContext: (context: string) => void;\n +beginScroll: () => void;\n +endScroll: () => void;\n}\n\nexport default (TurboModuleRegistry.get('FrameRateLogger'): ?Spec);\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 * @flow strict-local\n * @format\n */\n\nimport type {____ViewStyle_Internal} from './StyleSheetTypes';\n\nexport default function splitLayoutProps(props: ?____ViewStyle_Internal): {\n outer: ?____ViewStyle_Internal,\n inner: ?____ViewStyle_Internal,\n} {\n let outer: ?____ViewStyle_Internal = null;\n let inner: ?____ViewStyle_Internal = null;\n\n if (props != null) {\n // $FlowIgnore[incompatible-exact] Will contain a subset of keys from `props`.\n outer = {};\n // $FlowIgnore[incompatible-exact] Will contain a subset of keys from `props`.\n inner = {};\n\n for (const prop of Object.keys(props)) {\n switch (prop) {\n case 'margin':\n case 'marginHorizontal':\n case 'marginVertical':\n case 'marginBottom':\n case 'marginTop':\n case 'marginLeft':\n case 'marginRight':\n case 'flex':\n case 'flexGrow':\n case 'flexShrink':\n case 'flexBasis':\n case 'alignSelf':\n case 'height':\n case 'minHeight':\n case 'maxHeight':\n case 'width':\n case 'minWidth':\n case 'maxWidth':\n case 'position':\n case 'left':\n case 'right':\n case 'bottom':\n case 'top':\n case 'transform':\n case 'rowGap':\n case 'columnGap':\n case 'gap':\n // $FlowFixMe[cannot-write]\n // $FlowFixMe[incompatible-use]\n // $FlowFixMe[prop-missing]\n outer[prop] = props[prop];\n break;\n default:\n // $FlowFixMe[cannot-write]\n // $FlowFixMe[incompatible-use]\n // $FlowFixMe[prop-missing]\n inner[prop] = props[prop];\n break;\n }\n }\n }\n\n return {outer, inner};\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 * @flow strict-local\n * @format\n */\n\n// This function dismisses the currently-open keyboard, if any.\n\n'use strict';\n\nconst TextInputState = require('../Components/TextInput/TextInputState');\n\nfunction dismissKeyboard() {\n TextInputState.blurTextInput(TextInputState.currentlyFocusedInput());\n}\n\nmodule.exports = dismissKeyboard;\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 * @format\n * @flow strict-local\n */\n\nimport type {EventSubscription} from '../../vendor/emitter/EventEmitter';\n\nimport NativeEventEmitter from '../../EventEmitter/NativeEventEmitter';\nimport LayoutAnimation from '../../LayoutAnimation/LayoutAnimation';\nimport dismissKeyboard from '../../Utilities/dismissKeyboard';\nimport Platform from '../../Utilities/Platform';\nimport NativeKeyboardObserver from './NativeKeyboardObserver';\n\nexport type KeyboardEventName = $Keys;\n\nexport type KeyboardEventEasing =\n | 'easeIn'\n | 'easeInEaseOut'\n | 'easeOut'\n | 'linear'\n | 'keyboard';\n\nexport type KeyboardMetrics = $ReadOnly<{|\n screenX: number,\n screenY: number,\n width: number,\n height: number,\n|}>;\n\nexport type KeyboardEvent = AndroidKeyboardEvent | IOSKeyboardEvent;\n\ntype BaseKeyboardEvent = {|\n duration: number,\n easing: KeyboardEventEasing,\n endCoordinates: KeyboardMetrics,\n|};\n\nexport type AndroidKeyboardEvent = $ReadOnly<{|\n ...BaseKeyboardEvent,\n duration: 0,\n easing: 'keyboard',\n|}>;\n\nexport type IOSKeyboardEvent = $ReadOnly<{|\n ...BaseKeyboardEvent,\n startCoordinates: KeyboardMetrics,\n isEventFromThisApp: boolean,\n|}>;\n\ntype KeyboardEventDefinitions = {\n keyboardWillShow: [KeyboardEvent],\n keyboardDidShow: [KeyboardEvent],\n keyboardWillHide: [KeyboardEvent],\n keyboardDidHide: [KeyboardEvent],\n keyboardWillChangeFrame: [KeyboardEvent],\n keyboardDidChangeFrame: [KeyboardEvent],\n};\n\n/**\n * `Keyboard` module to control keyboard events.\n *\n * ### Usage\n *\n * The Keyboard module allows you to listen for native events and react to them, as\n * well as make changes to the keyboard, like dismissing it.\n *\n *```\n * import React, { Component } from 'react';\n * import { Keyboard, TextInput } from 'react-native';\n *\n * class Example extends Component {\n * componentWillMount () {\n * this.keyboardDidShowListener = Keyboard.addListener('keyboardDidShow', this._keyboardDidShow);\n * this.keyboardDidHideListener = Keyboard.addListener('keyboardDidHide', this._keyboardDidHide);\n * }\n *\n * componentWillUnmount () {\n * this.keyboardDidShowListener.remove();\n * this.keyboardDidHideListener.remove();\n * }\n *\n * _keyboardDidShow () {\n * alert('Keyboard Shown');\n * }\n *\n * _keyboardDidHide () {\n * alert('Keyboard Hidden');\n * }\n *\n * render() {\n * return (\n * \n * );\n * }\n * }\n *```\n */\n\nclass Keyboard {\n _currentlyShowing: ?KeyboardEvent;\n\n _emitter: NativeEventEmitter =\n new NativeEventEmitter(\n // T88715063: NativeEventEmitter only used this parameter on iOS. Now it uses it on all platforms, so this code was modified automatically to preserve its behavior\n // If you want to use the native module on other platforms, please remove this condition and test its behavior\n Platform.OS !== 'ios' ? null : NativeKeyboardObserver,\n );\n\n constructor() {\n this.addListener('keyboardDidShow', ev => {\n this._currentlyShowing = ev;\n });\n this.addListener('keyboardDidHide', _ev => {\n this._currentlyShowing = null;\n });\n }\n\n /**\n * The `addListener` function connects a JavaScript function to an identified native\n * keyboard notification event.\n *\n * This function then returns the reference to the listener.\n *\n * @param {string} eventName The `nativeEvent` is the string that identifies the event you're listening for. This\n *can be any of the following:\n *\n * - `keyboardWillShow`\n * - `keyboardDidShow`\n * - `keyboardWillHide`\n * - `keyboardDidHide`\n * - `keyboardWillChangeFrame`\n * - `keyboardDidChangeFrame`\n *\n * Android versions prior to API 30 rely on observing layout changes when\n * `android:windowSoftInputMode` is set to `adjustResize` or `adjustPan`.\n *\n * `keyboardWillShow` as well as `keyboardWillHide` are not available on Android since there is\n * no native corresponding event.\n *\n * @param {function} callback function to be called when the event fires.\n */\n addListener>(\n eventType: K,\n listener: (...$ElementType) => mixed,\n context?: mixed,\n ): EventSubscription {\n return this._emitter.addListener(eventType, listener);\n }\n\n /**\n * Removes all listeners for a specific event type.\n *\n * @param {string} eventType The native event string listeners are watching which will be removed.\n */\n removeAllListeners>(eventType: ?K): void {\n this._emitter.removeAllListeners(eventType);\n }\n\n /**\n * Dismisses the active keyboard and removes focus.\n */\n dismiss(): void {\n dismissKeyboard();\n }\n\n /**\n * Whether the keyboard is last known to be visible.\n */\n isVisible(): boolean {\n return !!this._currentlyShowing;\n }\n\n /**\n * Return the metrics of the soft-keyboard if visible.\n */\n metrics(): ?KeyboardMetrics {\n return this._currentlyShowing?.endCoordinates;\n }\n\n /**\n * Useful for syncing TextInput (or other keyboard accessory view) size of\n * position changes with keyboard movements.\n */\n scheduleLayoutAnimation(event: KeyboardEvent): void {\n const {duration, easing} = event;\n if (duration != null && duration !== 0) {\n LayoutAnimation.configureNext({\n duration: duration,\n update: {\n duration: duration,\n type: (easing != null && LayoutAnimation.Types[easing]) || 'keyboard',\n },\n });\n }\n }\n}\n\nmodule.exports = (new Keyboard(): Keyboard);\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 * @flow strict-local\n * @format\n */\n\n'use strict';\n\nimport type {Spec as FabricUIManagerSpec} from '../ReactNative/FabricUIManager';\nimport type {\n LayoutAnimationConfig as LayoutAnimationConfig_,\n LayoutAnimationProperty,\n LayoutAnimationType,\n} from '../Renderer/shims/ReactNativeTypes';\n\nimport ReactNativeFeatureFlags from '../ReactNative/ReactNativeFeatureFlags';\nimport Platform from '../Utilities/Platform';\n\nconst UIManager = require('../ReactNative/UIManager');\n\n// Reexport type\nexport type LayoutAnimationConfig = LayoutAnimationConfig_;\n\ntype OnAnimationDidEndCallback = () => void;\ntype OnAnimationDidFailCallback = () => void;\n\nlet isLayoutAnimationEnabled: boolean =\n ReactNativeFeatureFlags.isLayoutAnimationEnabled();\n\nfunction setEnabled(value: boolean) {\n isLayoutAnimationEnabled = isLayoutAnimationEnabled;\n}\n\n/**\n * Configures the next commit to be animated.\n *\n * onAnimationDidEnd is guaranteed to be called when the animation completes.\n * onAnimationDidFail is *never* called in the classic, pre-Fabric renderer,\n * and never has been. In the new renderer (Fabric) it is called only if configuration\n * parsing fails.\n */\nfunction configureNext(\n config: LayoutAnimationConfig,\n onAnimationDidEnd?: OnAnimationDidEndCallback,\n onAnimationDidFail?: OnAnimationDidFailCallback,\n) {\n if (Platform.isTesting) {\n return;\n }\n\n if (!isLayoutAnimationEnabled) {\n return;\n }\n\n // Since LayoutAnimations may possibly be disabled for now on iOS (Fabric),\n // or Android (non-Fabric) we race a setTimeout with animation completion,\n // in case onComplete is never called\n // from native. Once LayoutAnimations+Fabric unconditionally ship everywhere, we can\n // delete this mechanism at least in the Fabric branch.\n let animationCompletionHasRun = false;\n const onAnimationComplete = () => {\n if (animationCompletionHasRun) {\n return;\n }\n animationCompletionHasRun = true;\n clearTimeout(raceWithAnimationId);\n onAnimationDidEnd?.();\n };\n const raceWithAnimationId = setTimeout(\n onAnimationComplete,\n (config.duration ?? 0) + 17 /* one frame + 1ms */,\n );\n\n // In Fabric, LayoutAnimations are unconditionally enabled for Android, and\n // conditionally enabled on iOS (pending fully shipping; this is a temporary state).\n const FabricUIManager: FabricUIManagerSpec = global?.nativeFabricUIManager;\n if (FabricUIManager?.configureNextLayoutAnimation) {\n global?.nativeFabricUIManager?.configureNextLayoutAnimation(\n config,\n onAnimationComplete,\n onAnimationDidFail ??\n function () {} /* this will only be called if configuration parsing fails */,\n );\n return;\n }\n\n // This will only run if Fabric is *not* installed.\n // If you have Fabric + non-Fabric running in the same VM, non-Fabric LayoutAnimations\n // will not work.\n if (UIManager?.configureNextLayoutAnimation) {\n UIManager.configureNextLayoutAnimation(\n config,\n onAnimationComplete ?? function () {},\n onAnimationDidFail ??\n function () {} /* this should never be called in Non-Fabric */,\n );\n }\n}\n\nfunction create(\n duration: number,\n type: LayoutAnimationType,\n property: LayoutAnimationProperty,\n): LayoutAnimationConfig {\n return {\n duration,\n create: {type, property},\n update: {type},\n delete: {type, property},\n };\n}\n\nconst Presets = {\n easeInEaseOut: (create(\n 300,\n 'easeInEaseOut',\n 'opacity',\n ): LayoutAnimationConfig),\n linear: (create(500, 'linear', 'opacity'): LayoutAnimationConfig),\n spring: {\n duration: 700,\n create: {\n type: 'linear',\n property: 'opacity',\n },\n update: {\n type: 'spring',\n springDamping: 0.4,\n },\n delete: {\n type: 'linear',\n property: 'opacity',\n },\n },\n};\n\n/**\n * Automatically animates views to their new positions when the\n * next layout happens.\n *\n * A common way to use this API is to call it before calling `setState`.\n *\n * Note that in order to get this to work on **Android** you need to set the following flags via `UIManager`:\n *\n * UIManager.setLayoutAnimationEnabledExperimental && UIManager.setLayoutAnimationEnabledExperimental(true);\n */\nconst LayoutAnimation = {\n /**\n * Schedules an animation to happen on the next layout.\n *\n * @param config Specifies animation properties:\n *\n * - `duration` in milliseconds\n * - `create`, `AnimationConfig` for animating in new views\n * - `update`, `AnimationConfig` for animating views that have been updated\n *\n * @param onAnimationDidEnd Called when the animation finished.\n * Only supported on iOS.\n * @param onError Called on error. Only supported on iOS.\n */\n configureNext,\n /**\n * Helper for creating a config for `configureNext`.\n */\n create,\n Types: Object.freeze({\n spring: 'spring',\n linear: 'linear',\n easeInEaseOut: 'easeInEaseOut',\n easeIn: 'easeIn',\n easeOut: 'easeOut',\n keyboard: 'keyboard',\n }),\n Properties: Object.freeze({\n opacity: 'opacity',\n scaleX: 'scaleX',\n scaleY: 'scaleY',\n scaleXY: 'scaleXY',\n }),\n checkConfig(...args: Array) {\n console.error('LayoutAnimation.checkConfig(...) has been disabled.');\n },\n Presets,\n easeInEaseOut: (configureNext.bind(null, Presets.easeInEaseOut): (\n onAnimationDidEnd?: OnAnimationDidEndCallback,\n ) => void),\n linear: (configureNext.bind(null, Presets.linear): (\n onAnimationDidEnd?: OnAnimationDidEndCallback,\n ) => void),\n spring: (configureNext.bind(null, Presets.spring): (\n onAnimationDidEnd?: OnAnimationDidEndCallback,\n ) => void),\n setEnabled,\n};\n\nmodule.exports = LayoutAnimation;\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 * @flow strict\n * @format\n */\n\nimport type {TurboModule} from '../../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../../TurboModule/TurboModuleRegistry';\n\nexport interface Spec extends TurboModule {\n +addListener: (eventName: string) => void;\n +removeListeners: (count: number) => void;\n}\n\nexport default (TurboModuleRegistry.get('KeyboardObserver'): ?Spec);\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 * @format\n * @flow strict-local\n */\n\nimport type {HostComponent} from '../../Renderer/shims/ReactNativeTypes';\nimport type {ViewProps} from '../View/ViewPropTypes';\n\nimport codegenNativeComponent from '../../Utilities/codegenNativeComponent';\n\ntype NativeProps = $ReadOnly<{|\n ...ViewProps,\n\n removeClippedSubviews?: ?boolean,\n|}>;\n\ntype NativeType = HostComponent;\n\nexport default (codegenNativeComponent(\n 'AndroidHorizontalScrollContentView',\n): NativeType);\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 * @flow strict-local\n * @format\n */\n\nimport type {\n HostComponent,\n PartialViewConfig,\n} from '../../Renderer/shims/ReactNativeTypes';\nimport type {ScrollViewNativeProps as Props} from './ScrollViewNativeComponentType';\n\nimport * as NativeComponentRegistry from '../../NativeComponent/NativeComponentRegistry';\n\nexport const __INTERNAL_VIEW_CONFIG: PartialViewConfig = {\n uiViewClassName: 'AndroidHorizontalScrollView',\n bubblingEventTypes: {},\n directEventTypes: {},\n validAttributes: {\n decelerationRate: true,\n disableIntervalMomentum: true,\n endFillColor: {process: require('../../StyleSheet/processColor')},\n fadingEdgeLength: true,\n nestedScrollEnabled: true,\n overScrollMode: true,\n pagingEnabled: true,\n persistentScrollbar: true,\n scrollEnabled: true,\n scrollPerfTag: true,\n sendMomentumEvents: true,\n showsHorizontalScrollIndicator: true,\n snapToAlignment: true,\n snapToEnd: true,\n snapToInterval: true,\n snapToStart: true,\n snapToOffsets: true,\n contentOffset: true,\n borderBottomLeftRadius: true,\n borderBottomRightRadius: true,\n borderRadius: true,\n borderStyle: true,\n borderRightColor: {process: require('../../StyleSheet/processColor')},\n borderColor: {process: require('../../StyleSheet/processColor')},\n borderBottomColor: {process: require('../../StyleSheet/processColor')},\n borderTopLeftRadius: true,\n borderTopColor: {process: require('../../StyleSheet/processColor')},\n removeClippedSubviews: true,\n borderTopRightRadius: true,\n borderLeftColor: {process: require('../../StyleSheet/processColor')},\n pointerEvents: true,\n },\n};\n\nconst AndroidHorizontalScrollViewNativeComponent: HostComponent =\n NativeComponentRegistry.get(\n 'AndroidHorizontalScrollView',\n () => __INTERNAL_VIEW_CONFIG,\n );\n\nexport default AndroidHorizontalScrollViewNativeComponent;\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 * @format\n * @flow strict-local\n */\n\nimport Platform from '../../Utilities/Platform';\n\nfunction processDecelerationRate(\n decelerationRate: number | 'normal' | 'fast',\n): number {\n if (decelerationRate === 'normal') {\n return Platform.select({\n ios: 0.998,\n android: 0.985,\n });\n } else if (decelerationRate === 'fast') {\n return Platform.select({\n ios: 0.99,\n android: 0.9,\n });\n }\n return decelerationRate;\n}\n\nmodule.exports = processDecelerationRate;\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 * @format\n * @flow\n */\n\nimport type {\n HostComponent,\n PartialViewConfig,\n} from '../../Renderer/shims/ReactNativeTypes';\nimport type {ViewProps as Props} from '../View/ViewPropTypes';\n\nimport * as NativeComponentRegistry from '../../NativeComponent/NativeComponentRegistry';\n\nexport const __INTERNAL_VIEW_CONFIG: PartialViewConfig = {\n uiViewClassName: 'RCTScrollContentView',\n bubblingEventTypes: {},\n directEventTypes: {},\n validAttributes: {},\n};\n\nconst ScrollContentViewNativeComponent: HostComponent =\n NativeComponentRegistry.get(\n 'RCTScrollContentView',\n () => __INTERNAL_VIEW_CONFIG,\n );\n\nexport default ScrollContentViewNativeComponent;\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 * @format\n * @flow strict-local\n */\n\nimport type {HostComponent} from '../../Renderer/shims/ReactNativeTypes';\nimport type {Double} from '../../Types/CodegenTypes';\n\nimport codegenNativeCommands from '../../Utilities/codegenNativeCommands';\nimport * as React from 'react';\n\ntype ScrollViewNativeComponentType = HostComponent;\ninterface NativeCommands {\n +flashScrollIndicators: (\n viewRef: React.ElementRef,\n ) => void;\n +scrollTo: (\n viewRef: React.ElementRef,\n x: Double,\n y: Double,\n animated: boolean,\n ) => void;\n +scrollToEnd: (\n viewRef: React.ElementRef,\n animated: boolean,\n ) => void;\n +zoomToRect: (\n viewRef: React.ElementRef,\n rect: {|\n x: Double,\n y: Double,\n width: Double,\n height: Double,\n animated?: boolean,\n |},\n animated?: boolean,\n ) => void;\n}\n\nexport default (codegenNativeCommands({\n supportedCommands: [\n 'flashScrollIndicators',\n 'scrollTo',\n 'scrollToEnd',\n 'zoomToRect',\n ],\n}): NativeCommands);\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 * @flow strict\n * @format\n */\n\nimport * as React from 'react';\n\ntype Value = {horizontal: boolean} | null;\n\nconst ScrollViewContext: React.Context = React.createContext(null);\nif (__DEV__) {\n ScrollViewContext.displayName = 'ScrollViewContext';\n}\nexport default ScrollViewContext;\n\nexport const HORIZONTAL: Value = Object.freeze({horizontal: true});\nexport const VERTICAL: Value = Object.freeze({horizontal: false});\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 * @flow strict-local\n * @format\n */\n\nimport type {\n HostComponent,\n PartialViewConfig,\n} from '../../Renderer/shims/ReactNativeTypes';\nimport type {ScrollViewNativeProps as Props} from './ScrollViewNativeComponentType';\n\nimport * as NativeComponentRegistry from '../../NativeComponent/NativeComponentRegistry';\nimport {ConditionallyIgnoredEventHandlers} from '../../NativeComponent/ViewConfigIgnore';\nimport Platform from '../../Utilities/Platform';\n\nexport const __INTERNAL_VIEW_CONFIG: PartialViewConfig =\n Platform.OS === 'android'\n ? {\n uiViewClassName: 'RCTScrollView',\n bubblingEventTypes: {},\n directEventTypes: {\n topMomentumScrollBegin: {\n registrationName: 'onMomentumScrollBegin',\n },\n topMomentumScrollEnd: {\n registrationName: 'onMomentumScrollEnd',\n },\n topScroll: {\n registrationName: 'onScroll',\n },\n topScrollBeginDrag: {\n registrationName: 'onScrollBeginDrag',\n },\n topScrollEndDrag: {\n registrationName: 'onScrollEndDrag',\n },\n },\n validAttributes: {\n contentOffset: {\n diff: require('../../Utilities/differ/pointsDiffer'),\n },\n decelerationRate: true,\n disableIntervalMomentum: true,\n pagingEnabled: true,\n scrollEnabled: true,\n showsVerticalScrollIndicator: true,\n snapToAlignment: true,\n snapToEnd: true,\n snapToInterval: true,\n snapToOffsets: true,\n snapToStart: true,\n borderBottomLeftRadius: true,\n borderBottomRightRadius: true,\n sendMomentumEvents: true,\n borderRadius: true,\n nestedScrollEnabled: true,\n borderStyle: true,\n borderRightColor: {process: require('../../StyleSheet/processColor')},\n borderColor: {process: require('../../StyleSheet/processColor')},\n borderBottomColor: {\n process: require('../../StyleSheet/processColor'),\n },\n persistentScrollbar: true,\n endFillColor: {process: require('../../StyleSheet/processColor')},\n fadingEdgeLength: true,\n overScrollMode: true,\n borderTopLeftRadius: true,\n scrollPerfTag: true,\n borderTopColor: {process: require('../../StyleSheet/processColor')},\n removeClippedSubviews: true,\n borderTopRightRadius: true,\n borderLeftColor: {process: require('../../StyleSheet/processColor')},\n pointerEvents: true,\n },\n }\n : {\n uiViewClassName: 'RCTScrollView',\n bubblingEventTypes: {},\n directEventTypes: {\n topMomentumScrollBegin: {\n registrationName: 'onMomentumScrollBegin',\n },\n topMomentumScrollEnd: {\n registrationName: 'onMomentumScrollEnd',\n },\n topScroll: {\n registrationName: 'onScroll',\n },\n topScrollBeginDrag: {\n registrationName: 'onScrollBeginDrag',\n },\n topScrollEndDrag: {\n registrationName: 'onScrollEndDrag',\n },\n topScrollToTop: {\n registrationName: 'onScrollToTop',\n },\n },\n validAttributes: {\n alwaysBounceHorizontal: true,\n alwaysBounceVertical: true,\n automaticallyAdjustContentInsets: true,\n automaticallyAdjustKeyboardInsets: true,\n automaticallyAdjustsScrollIndicatorInsets: true,\n bounces: true,\n bouncesZoom: true,\n canCancelContentTouches: true,\n centerContent: true,\n contentInset: {\n diff: require('../../Utilities/differ/insetsDiffer'),\n },\n contentOffset: {\n diff: require('../../Utilities/differ/pointsDiffer'),\n },\n contentInsetAdjustmentBehavior: true,\n decelerationRate: true,\n directionalLockEnabled: true,\n disableIntervalMomentum: true,\n indicatorStyle: true,\n inverted: true,\n keyboardDismissMode: true,\n maintainVisibleContentPosition: true,\n maximumZoomScale: true,\n minimumZoomScale: true,\n pagingEnabled: true,\n pinchGestureEnabled: true,\n scrollEnabled: true,\n scrollEventThrottle: true,\n scrollIndicatorInsets: {\n diff: require('../../Utilities/differ/insetsDiffer'),\n },\n scrollToOverflowEnabled: true,\n scrollsToTop: true,\n showsHorizontalScrollIndicator: true,\n showsVerticalScrollIndicator: true,\n snapToAlignment: true,\n snapToEnd: true,\n snapToInterval: true,\n snapToOffsets: true,\n snapToStart: true,\n zoomScale: true,\n ...ConditionallyIgnoredEventHandlers({\n onScrollBeginDrag: true,\n onMomentumScrollEnd: true,\n onScrollEndDrag: true,\n onMomentumScrollBegin: true,\n onScrollToTop: true,\n onScroll: true,\n }),\n },\n };\n\nconst ScrollViewNativeComponent: HostComponent =\n NativeComponentRegistry.get(\n 'RCTScrollView',\n () => __INTERNAL_VIEW_CONFIG,\n );\n\nexport default ScrollViewNativeComponent;\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 * @flow strict-local\n * @format\n */\n\nimport type {LayoutEvent} from '../../Types/CoreEventTypes';\n\nimport Animated from '../../Animated/Animated';\nimport StyleSheet from '../../StyleSheet/StyleSheet';\nimport Platform from '../../Utilities/Platform';\nimport useMergeRefs from '../../Utilities/useMergeRefs';\nimport * as React from 'react';\nimport {useCallback, useEffect, useMemo, useRef, useState} from 'react';\n\nexport type Props = $ReadOnly<{\n children?: React.Element<$FlowFixMe>,\n nextHeaderLayoutY: ?number,\n onLayout: (event: LayoutEvent) => void,\n scrollAnimatedValue: Animated.Value,\n // Will cause sticky headers to stick at the bottom of the ScrollView instead\n // of the top.\n inverted: ?boolean,\n // The height of the parent ScrollView. Currently only set when inverted.\n scrollViewHeight: ?number,\n nativeID?: ?string,\n hiddenOnScroll?: ?boolean,\n}>;\n\ntype Instance = {\n ...React.ElementRef,\n setNextHeaderY: number => void,\n ...\n};\n\nconst ScrollViewStickyHeaderWithForwardedRef: React.AbstractComponent<\n Props,\n Instance,\n> = React.forwardRef(function ScrollViewStickyHeader(props, forwardedRef) {\n const {\n inverted,\n scrollViewHeight,\n hiddenOnScroll,\n scrollAnimatedValue,\n nextHeaderLayoutY: _nextHeaderLayoutY,\n } = props;\n\n const [measured, setMeasured] = useState(false);\n const [layoutY, setLayoutY] = useState(0);\n const [layoutHeight, setLayoutHeight] = useState(0);\n const [translateY, setTranslateY] = useState(null);\n const [nextHeaderLayoutY, setNextHeaderLayoutY] =\n useState(_nextHeaderLayoutY);\n const [isFabric, setIsFabric] = useState(false);\n\n const callbackRef = (ref: Instance | null): void => {\n if (ref == null) {\n return;\n }\n ref.setNextHeaderY = value => {\n setNextHeaderLayoutY(value);\n };\n // Avoid dot notation because at Meta, private properties are obfuscated.\n // $FlowFixMe[prop-missing]\n const _internalInstanceHandler = ref['_internalInstanceHandle']; // eslint-disable-line dot-notation\n setIsFabric(Boolean(_internalInstanceHandler?.stateNode?.canonical));\n };\n const ref: (React.ElementRef | null) => void =\n // $FlowFixMe[incompatible-type] - Ref is mutated by `callbackRef`.\n useMergeRefs(callbackRef, forwardedRef);\n\n const offset = useMemo(\n () =>\n hiddenOnScroll === true\n ? Animated.diffClamp(\n scrollAnimatedValue\n .interpolate({\n extrapolateLeft: 'clamp',\n inputRange: [layoutY, layoutY + 1],\n outputRange: ([0, 1]: Array),\n })\n .interpolate({\n inputRange: [0, 1],\n outputRange: ([0, -1]: Array),\n }),\n -layoutHeight,\n 0,\n )\n : null,\n [scrollAnimatedValue, layoutHeight, layoutY, hiddenOnScroll],\n );\n\n const [animatedTranslateY, setAnimatedTranslateY] = useState(\n () => {\n const inputRange: Array = [-1, 0];\n const outputRange: Array = [0, 0];\n const initialTranslateY = scrollAnimatedValue.interpolate({\n inputRange,\n outputRange,\n });\n\n if (offset != null) {\n return Animated.add(initialTranslateY, offset);\n }\n return initialTranslateY;\n },\n );\n\n const _haveReceivedInitialZeroTranslateY = useRef(true);\n const _timer = useRef(null);\n\n useEffect(() => {\n if (translateY !== 0 && translateY != null) {\n _haveReceivedInitialZeroTranslateY.current = false;\n }\n }, [translateY]);\n\n // This is called whenever the (Interpolated) Animated Value\n // updates, which is several times per frame during scrolling.\n // To ensure that the Fabric ShadowTree has the most recent\n // translate style of this node, we debounce the value and then\n // pass it through to the underlying node during render.\n // This is:\n // 1. Only an issue in Fabric.\n // 2. Worse in Android than iOS. In Android, but not iOS, you\n // can touch and move your finger slightly and still trigger\n // a \"tap\" event. In iOS, moving will cancel the tap in\n // both Fabric and non-Fabric. On Android when you move\n // your finger, the hit-detection moves from the Android\n // platform to JS, so we need the ShadowTree to have knowledge\n // of the current position.\n const animatedValueListener = useCallback(\n ({value}) => {\n const _debounceTimeout: number = Platform.OS === 'android' ? 15 : 64;\n // When the AnimatedInterpolation is recreated, it always initializes\n // to a value of zero and emits a value change of 0 to its listeners.\n if (value === 0 && !_haveReceivedInitialZeroTranslateY.current) {\n _haveReceivedInitialZeroTranslateY.current = true;\n return;\n }\n if (_timer.current != null) {\n clearTimeout(_timer.current);\n }\n _timer.current = setTimeout(() => {\n if (value !== translateY) {\n setTranslateY(value);\n }\n }, _debounceTimeout);\n },\n [translateY],\n );\n\n useEffect(() => {\n const inputRange: Array = [-1, 0];\n const outputRange: Array = [0, 0];\n\n if (measured) {\n if (inverted === true) {\n // The interpolation looks like:\n // - Negative scroll: no translation\n // - `stickStartPoint` is the point at which the header will start sticking.\n // It is calculated using the ScrollView viewport height so it is a the bottom.\n // - Headers that are in the initial viewport will never stick, `stickStartPoint`\n // will be negative.\n // - From 0 to `stickStartPoint` no translation. This will cause the header\n // to scroll normally until it reaches the top of the scroll view.\n // - From `stickStartPoint` to when the next header y hits the bottom edge of the header: translate\n // equally to scroll. This will cause the header to stay at the top of the scroll view.\n // - Past the collision with the next header y: no more translation. This will cause the\n // header to continue scrolling up and make room for the next sticky header.\n // In the case that there is no next header just translate equally to\n // scroll indefinitely.\n if (scrollViewHeight != null) {\n const stickStartPoint = layoutY + layoutHeight - scrollViewHeight;\n if (stickStartPoint > 0) {\n inputRange.push(stickStartPoint);\n outputRange.push(0);\n inputRange.push(stickStartPoint + 1);\n outputRange.push(1);\n // If the next sticky header has not loaded yet (probably windowing) or is the last\n // we can just keep it sticked forever.\n const collisionPoint =\n (nextHeaderLayoutY || 0) - layoutHeight - scrollViewHeight;\n if (collisionPoint > stickStartPoint) {\n inputRange.push(collisionPoint, collisionPoint + 1);\n outputRange.push(\n collisionPoint - stickStartPoint,\n collisionPoint - stickStartPoint,\n );\n }\n }\n }\n } else {\n // The interpolation looks like:\n // - Negative scroll: no translation\n // - From 0 to the y of the header: no translation. This will cause the header\n // to scroll normally until it reaches the top of the scroll view.\n // - From header y to when the next header y hits the bottom edge of the header: translate\n // equally to scroll. This will cause the header to stay at the top of the scroll view.\n // - Past the collision with the next header y: no more translation. This will cause the\n // header to continue scrolling up and make room for the next sticky header.\n // In the case that there is no next header just translate equally to\n // scroll indefinitely.\n inputRange.push(layoutY);\n outputRange.push(0);\n // If the next sticky header has not loaded yet (probably windowing) or is the last\n // we can just keep it sticked forever.\n const collisionPoint = (nextHeaderLayoutY || 0) - layoutHeight;\n if (collisionPoint >= layoutY) {\n inputRange.push(collisionPoint, collisionPoint + 1);\n outputRange.push(collisionPoint - layoutY, collisionPoint - layoutY);\n } else {\n inputRange.push(layoutY + 1);\n outputRange.push(1);\n }\n }\n }\n\n let newAnimatedTranslateY: Animated.Node = scrollAnimatedValue.interpolate({\n inputRange,\n outputRange,\n });\n\n if (offset != null) {\n newAnimatedTranslateY = Animated.add(newAnimatedTranslateY, offset);\n }\n\n // add the event listener\n let animatedListenerId;\n if (isFabric) {\n animatedListenerId = newAnimatedTranslateY.addListener(\n animatedValueListener,\n );\n }\n\n setAnimatedTranslateY(newAnimatedTranslateY);\n\n // clean up the event listener and timer\n return () => {\n if (animatedListenerId) {\n newAnimatedTranslateY.removeListener(animatedListenerId);\n }\n if (_timer.current != null) {\n clearTimeout(_timer.current);\n }\n };\n }, [nextHeaderLayoutY, measured, layoutHeight, layoutY, scrollViewHeight, scrollAnimatedValue, inverted, offset, animatedValueListener, isFabric]);\n\n const _onLayout = (event: LayoutEvent) => {\n setLayoutY(event.nativeEvent.layout.y);\n setLayoutHeight(event.nativeEvent.layout.height);\n setMeasured(true);\n\n props.onLayout(event);\n const child = React.Children.only(props.children);\n if (child.props.onLayout) {\n child.props.onLayout(event);\n }\n };\n\n const child = React.Children.only(props.children);\n\n // TODO T68319535: remove this if NativeAnimated is rewritten for Fabric\n const passthroughAnimatedPropExplicitValues =\n isFabric && translateY != null\n ? {\n style: {transform: [{translateY: translateY}]},\n }\n : null;\n\n return (\n /* $FlowFixMe[prop-missing] passthroughAnimatedPropExplicitValues isn't properly\n included in the Animated.View flow type. */\n \n {React.cloneElement(child, {\n style: styles.fill, // We transfer the child style to the wrapper.\n onLayout: undefined, // we call this manually through our this._onLayout\n })}\n \n );\n});\n\nconst styles = StyleSheet.create({\n header: {\n zIndex: 10,\n position: 'relative',\n },\n fill: {\n flex: 1,\n },\n});\n\nexport default ScrollViewStickyHeaderWithForwardedRef;\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 * @flow strict\n * @format\n */\n\nimport {useCallback} from 'react';\n\ntype CallbackRef = T => mixed;\ntype ObjectRef = {current: T, ...};\n\ntype Ref = CallbackRef | ObjectRef;\n\n/**\n * Constructs a new ref that forwards new values to each of the given refs. The\n * given refs will always be invoked in the order that they are supplied.\n *\n * WARNING: A known problem of merging refs using this approach is that if any\n * of the given refs change, the returned callback ref will also be changed. If\n * the returned callback ref is supplied as a `ref` to a React element, this may\n * lead to problems with the given refs being invoked more times than desired.\n */\nexport default function useMergeRefs(\n ...refs: $ReadOnlyArray>\n): CallbackRef {\n return useCallback(\n (current: T) => {\n for (const ref of refs) {\n if (ref != null) {\n if (typeof ref === 'function') {\n ref(current);\n } else {\n ref.current = current;\n }\n }\n }\n },\n [...refs], // eslint-disable-line react-hooks/exhaustive-deps\n );\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 * @format\n * @flow strict-local\n */\n\n'use strict';\n\nconst InteractionManager = require('./InteractionManager');\n\n/**\n * A simple class for batching up invocations of a low-pri callback. A timeout is set to run the\n * callback once after a delay, no matter how many times it's scheduled. Once the delay is reached,\n * InteractionManager.runAfterInteractions is used to invoke the callback after any hi-pri\n * interactions are done running.\n *\n * Make sure to cleanup with dispose(). Example:\n *\n * class Widget extends React.Component {\n * _batchedSave: new Batchinator(() => this._saveState, 1000);\n * _saveSate() {\n * // save this.state to disk\n * }\n * componentDidUpdate() {\n * this._batchedSave.schedule();\n * }\n * componentWillUnmount() {\n * this._batchedSave.dispose();\n * }\n * ...\n * }\n */\nclass Batchinator {\n _callback: () => void;\n _delay: number;\n _taskHandle: ?{cancel: () => void, ...};\n constructor(callback: () => void, delayMS: number) {\n this._delay = delayMS;\n this._callback = callback;\n }\n /*\n * Cleanup any pending tasks.\n *\n * By default, if there is a pending task the callback is run immediately. Set the option abort to\n * true to not call the callback if it was pending.\n */\n dispose(options: {abort: boolean, ...} = {abort: false}) {\n if (this._taskHandle) {\n this._taskHandle.cancel();\n if (!options.abort) {\n this._callback();\n }\n this._taskHandle = null;\n }\n }\n schedule() {\n if (this._taskHandle) {\n return;\n }\n const timeoutHandle = setTimeout(() => {\n this._taskHandle = InteractionManager.runAfterInteractions(() => {\n // Note that we clear the handle before invoking the callback so that if the callback calls\n // schedule again, it will actually schedule another task.\n this._taskHandle = null;\n this._callback();\n });\n }, this._delay);\n this._taskHandle = {cancel: () => clearTimeout(timeoutHandle)};\n }\n}\n\nmodule.exports = Batchinator;\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 * @format\n * @flow strict\n */\n\n'use strict';\n\nfunction clamp(min: number, value: number, max: number): number {\n if (value < min) {\n return min;\n }\n if (value > max) {\n return max;\n }\n return value;\n}\n\nmodule.exports = clamp;\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 * @flow strict\n * @format\n */\n\nimport invariant from 'invariant';\n\nexport default class ChildListCollection {\n _cellKeyToChildren: Map> = new Map();\n _childrenToCellKey: Map = new Map();\n\n add(list: TList, cellKey: string): void {\n invariant(\n !this._childrenToCellKey.has(list),\n 'Trying to add already present child list',\n );\n\n const cellLists = this._cellKeyToChildren.get(cellKey) ?? new Set();\n cellLists.add(list);\n this._cellKeyToChildren.set(cellKey, cellLists);\n\n this._childrenToCellKey.set(list, cellKey);\n }\n\n remove(list: TList): void {\n const cellKey = this._childrenToCellKey.get(list);\n invariant(cellKey != null, 'Trying to remove non-present child list');\n this._childrenToCellKey.delete(list);\n\n const cellLists = this._cellKeyToChildren.get(cellKey);\n invariant(cellLists, '_cellKeyToChildren should contain cellKey');\n cellLists.delete(list);\n\n if (cellLists.size === 0) {\n this._cellKeyToChildren.delete(cellKey);\n }\n }\n\n forEach(fn: TList => void): void {\n for (const listSet of this._cellKeyToChildren.values()) {\n for (const list of listSet) {\n fn(list);\n }\n }\n }\n\n forEachInCell(cellKey: string, fn: TList => void): void {\n const listSet = this._cellKeyToChildren.get(cellKey) ?? [];\n for (const list of listSet) {\n fn(list);\n }\n }\n\n anyInCell(cellKey: string, fn: TList => boolean): boolean {\n const listSet = this._cellKeyToChildren.get(cellKey) ?? [];\n for (const list of listSet) {\n if (fn(list)) {\n return true;\n }\n }\n return false;\n }\n\n size(): number {\n return this._childrenToCellKey.size;\n }\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport type {FrameMetricProps} from './VirtualizedListProps';\n\nexport type FillRateInfo = Info;\n\nclass Info {\n any_blank_count: number = 0;\n any_blank_ms: number = 0;\n any_blank_speed_sum: number = 0;\n mostly_blank_count: number = 0;\n mostly_blank_ms: number = 0;\n pixels_blank: number = 0;\n pixels_sampled: number = 0;\n pixels_scrolled: number = 0;\n total_time_spent: number = 0;\n sample_count: number = 0;\n}\n\ntype FrameMetrics = {\n inLayout?: boolean,\n length: number,\n offset: number,\n ...\n};\n\nconst DEBUG = false;\n\nlet _listeners: Array<(Info) => void> = [];\nlet _minSampleCount = 10;\nlet _sampleRate = DEBUG ? 1 : null;\n\n/**\n * A helper class for detecting when the maximem fill rate of `VirtualizedList` is exceeded.\n * By default the sampling rate is set to zero and this will do nothing. If you want to collect\n * samples (e.g. to log them), make sure to call `FillRateHelper.setSampleRate(0.0-1.0)`.\n *\n * Listeners and sample rate are global for all `VirtualizedList`s - typical usage will combine with\n * `SceneTracker.getActiveScene` to determine the context of the events.\n */\nclass FillRateHelper {\n _anyBlankStartTime: ?number = null;\n _enabled = false;\n _getFrameMetrics: (index: number, props: FrameMetricProps) => ?FrameMetrics;\n _info: Info = new Info();\n _mostlyBlankStartTime: ?number = null;\n _samplesStartTime: ?number = null;\n\n static addListener(callback: FillRateInfo => void): {\n remove: () => void,\n ...\n } {\n if (_sampleRate === null) {\n console.warn('Call `FillRateHelper.setSampleRate` before `addListener`.');\n }\n _listeners.push(callback);\n return {\n remove: () => {\n _listeners = _listeners.filter(listener => callback !== listener);\n },\n };\n }\n\n static setSampleRate(sampleRate: number) {\n _sampleRate = sampleRate;\n }\n\n static setMinSampleCount(minSampleCount: number) {\n _minSampleCount = minSampleCount;\n }\n\n constructor(\n getFrameMetrics: (index: number, props: FrameMetricProps) => ?FrameMetrics,\n ) {\n this._getFrameMetrics = getFrameMetrics;\n this._enabled = (_sampleRate || 0) > Math.random();\n this._resetData();\n }\n\n activate() {\n if (this._enabled && this._samplesStartTime == null) {\n DEBUG && console.debug('FillRateHelper: activate');\n this._samplesStartTime = global.performance.now();\n }\n }\n\n deactivateAndFlush() {\n if (!this._enabled) {\n return;\n }\n const start = this._samplesStartTime; // const for flow\n if (start == null) {\n DEBUG &&\n console.debug('FillRateHelper: bail on deactivate with no start time');\n return;\n }\n if (this._info.sample_count < _minSampleCount) {\n // Don't bother with under-sampled events.\n this._resetData();\n return;\n }\n const total_time_spent = global.performance.now() - start;\n const info: any = {\n ...this._info,\n total_time_spent,\n };\n if (DEBUG) {\n const derived = {\n avg_blankness: this._info.pixels_blank / this._info.pixels_sampled,\n avg_speed: this._info.pixels_scrolled / (total_time_spent / 1000),\n avg_speed_when_any_blank:\n this._info.any_blank_speed_sum / this._info.any_blank_count,\n any_blank_per_min:\n this._info.any_blank_count / (total_time_spent / 1000 / 60),\n any_blank_time_frac: this._info.any_blank_ms / total_time_spent,\n mostly_blank_per_min:\n this._info.mostly_blank_count / (total_time_spent / 1000 / 60),\n mostly_blank_time_frac: this._info.mostly_blank_ms / total_time_spent,\n };\n for (const key in derived) {\n // $FlowFixMe[prop-missing]\n derived[key] = Math.round(1000 * derived[key]) / 1000;\n }\n console.debug('FillRateHelper deactivateAndFlush: ', {derived, info});\n }\n _listeners.forEach(listener => listener(info));\n this._resetData();\n }\n\n computeBlankness(\n props: {\n ...FrameMetricProps,\n initialNumToRender?: ?number,\n ...\n },\n cellsAroundViewport: {\n first: number,\n last: number,\n ...\n },\n scrollMetrics: {\n dOffset: number,\n offset: number,\n velocity: number,\n visibleLength: number,\n ...\n },\n ): number {\n if (\n !this._enabled ||\n props.getItemCount(props.data) === 0 ||\n cellsAroundViewport.last < cellsAroundViewport.first ||\n this._samplesStartTime == null\n ) {\n return 0;\n }\n const {dOffset, offset, velocity, visibleLength} = scrollMetrics;\n\n // Denominator metrics that we track for all events - most of the time there is no blankness and\n // we want to capture that.\n this._info.sample_count++;\n this._info.pixels_sampled += Math.round(visibleLength);\n this._info.pixels_scrolled += Math.round(Math.abs(dOffset));\n const scrollSpeed = Math.round(Math.abs(velocity) * 1000); // px / sec\n\n // Whether blank now or not, record the elapsed time blank if we were blank last time.\n const now = global.performance.now();\n if (this._anyBlankStartTime != null) {\n this._info.any_blank_ms += now - this._anyBlankStartTime;\n }\n this._anyBlankStartTime = null;\n if (this._mostlyBlankStartTime != null) {\n this._info.mostly_blank_ms += now - this._mostlyBlankStartTime;\n }\n this._mostlyBlankStartTime = null;\n\n let blankTop = 0;\n let first = cellsAroundViewport.first;\n let firstFrame = this._getFrameMetrics(first, props);\n while (\n first <= cellsAroundViewport.last &&\n (!firstFrame || !firstFrame.inLayout)\n ) {\n firstFrame = this._getFrameMetrics(first, props);\n first++;\n }\n // Only count blankTop if we aren't rendering the first item, otherwise we will count the header\n // as blank.\n if (firstFrame && first > 0) {\n blankTop = Math.min(\n visibleLength,\n Math.max(0, firstFrame.offset - offset),\n );\n }\n let blankBottom = 0;\n let last = cellsAroundViewport.last;\n let lastFrame = this._getFrameMetrics(last, props);\n while (\n last >= cellsAroundViewport.first &&\n (!lastFrame || !lastFrame.inLayout)\n ) {\n lastFrame = this._getFrameMetrics(last, props);\n last--;\n }\n // Only count blankBottom if we aren't rendering the last item, otherwise we will count the\n // footer as blank.\n if (lastFrame && last < props.getItemCount(props.data) - 1) {\n const bottomEdge = lastFrame.offset + lastFrame.length;\n blankBottom = Math.min(\n visibleLength,\n Math.max(0, offset + visibleLength - bottomEdge),\n );\n }\n const pixels_blank = Math.round(blankTop + blankBottom);\n const blankness = pixels_blank / visibleLength;\n if (blankness > 0) {\n this._anyBlankStartTime = now;\n this._info.any_blank_speed_sum += scrollSpeed;\n this._info.any_blank_count++;\n this._info.pixels_blank += pixels_blank;\n if (blankness > 0.5) {\n this._mostlyBlankStartTime = now;\n this._info.mostly_blank_count++;\n }\n } else if (scrollSpeed < 0.01 || Math.abs(dOffset) < 1) {\n this.deactivateAndFlush();\n }\n return blankness;\n }\n\n enabled(): boolean {\n return this._enabled;\n }\n\n _resetData() {\n this._anyBlankStartTime = null;\n this._info = new Info();\n this._mostlyBlankStartTime = null;\n this._samplesStartTime = null;\n }\n}\n\nmodule.exports = FillRateHelper;\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 * @flow strict\n * @format\n */\n\nimport invariant from 'invariant';\nimport * as React from 'react';\n\n/**\n * `setState` is called asynchronously, and should not rely on the value of\n * `this.props` or `this.state`:\n * https://reactjs.org/docs/state-and-lifecycle.html#state-updates-may-be-asynchronous\n *\n * SafePureComponent adds runtime enforcement, to catch cases where these\n * variables are read in a state updater function, instead of the ones passed\n * in.\n */\nexport default class StateSafePureComponent<\n Props,\n State: interface {},\n> extends React.PureComponent {\n _inAsyncStateUpdate = false;\n\n constructor(props: Props) {\n super(props);\n this._installSetStateHooks();\n }\n\n setState(\n partialState: ?($Shape | ((State, Props) => ?$Shape)),\n callback?: () => mixed,\n ): void {\n if (typeof partialState === 'function') {\n super.setState((state, props) => {\n this._inAsyncStateUpdate = true;\n let ret;\n try {\n ret = partialState(state, props);\n } catch (err) {\n throw err;\n } finally {\n this._inAsyncStateUpdate = false;\n }\n return ret;\n }, callback);\n } else {\n super.setState(partialState, callback);\n }\n }\n\n _installSetStateHooks() {\n const that = this;\n let {props, state} = this;\n\n Object.defineProperty(this, 'props', {\n get() {\n invariant(\n !that._inAsyncStateUpdate,\n '\"this.props\" should not be accessed during state updates',\n );\n return props;\n },\n set(newProps: Props) {\n props = newProps;\n },\n });\n Object.defineProperty(this, 'state', {\n get() {\n invariant(\n !that._inAsyncStateUpdate,\n '\"this.state\" should not be acceessed during state updates',\n );\n return state;\n },\n set(newState: State) {\n state = newState;\n },\n });\n }\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport type {FrameMetricProps} from './VirtualizedListProps';\n\nconst invariant = require('invariant');\n\nexport type ViewToken = {\n item: any,\n key: string,\n index: ?number,\n isViewable: boolean,\n section?: any,\n ...\n};\n\nexport type ViewabilityConfigCallbackPair = {\n viewabilityConfig: ViewabilityConfig,\n onViewableItemsChanged: (info: {\n viewableItems: Array,\n changed: Array,\n ...\n }) => void,\n ...\n};\n\nexport type ViewabilityConfig = {|\n /**\n * Minimum amount of time (in milliseconds) that an item must be physically viewable before the\n * viewability callback will be fired. A high number means that scrolling through content without\n * stopping will not mark the content as viewable.\n */\n minimumViewTime?: number,\n\n /**\n * Percent of viewport that must be covered for a partially occluded item to count as\n * \"viewable\", 0-100. Fully visible items are always considered viewable. A value of 0 means\n * that a single pixel in the viewport makes the item viewable, and a value of 100 means that\n * an item must be either entirely visible or cover the entire viewport to count as viewable.\n */\n viewAreaCoveragePercentThreshold?: number,\n\n /**\n * Similar to `viewAreaPercentThreshold`, but considers the percent of the item that is visible,\n * rather than the fraction of the viewable area it covers.\n */\n itemVisiblePercentThreshold?: number,\n\n /**\n * Nothing is considered viewable until the user scrolls or `recordInteraction` is called after\n * render.\n */\n waitForInteraction?: boolean,\n|};\n\n/**\n * A Utility class for calculating viewable items based on current metrics like scroll position and\n * layout.\n *\n * An item is said to be in a \"viewable\" state when any of the following\n * is true for longer than `minimumViewTime` milliseconds (after an interaction if `waitForInteraction`\n * is true):\n *\n * - Occupying >= `viewAreaCoveragePercentThreshold` of the view area XOR fraction of the item\n * visible in the view area >= `itemVisiblePercentThreshold`.\n * - Entirely visible on screen\n */\nclass ViewabilityHelper {\n _config: ViewabilityConfig;\n _hasInteracted: boolean = false;\n _timers: Set = new Set();\n _viewableIndices: Array = [];\n _viewableItems: Map = new Map();\n\n constructor(\n config: ViewabilityConfig = {viewAreaCoveragePercentThreshold: 0},\n ) {\n this._config = config;\n }\n\n /**\n * Cleanup, e.g. on unmount. Clears any pending timers.\n */\n dispose() {\n /* $FlowFixMe[incompatible-call] (>=0.63.0 site=react_native_fb) This\n * comment suppresses an error found when Flow v0.63 was deployed. To see\n * the error delete this comment and run Flow. */\n this._timers.forEach(clearTimeout);\n }\n\n /**\n * Determines which items are viewable based on the current metrics and config.\n */\n computeViewableItems(\n props: FrameMetricProps,\n scrollOffset: number,\n viewportHeight: number,\n getFrameMetrics: (\n index: number,\n props: FrameMetricProps,\n ) => ?{\n length: number,\n offset: number,\n ...\n },\n // Optional optimization to reduce the scan size\n renderRange?: {\n first: number,\n last: number,\n ...\n },\n ): Array {\n const itemCount = props.getItemCount(props.data);\n const {itemVisiblePercentThreshold, viewAreaCoveragePercentThreshold} =\n this._config;\n const viewAreaMode = viewAreaCoveragePercentThreshold != null;\n const viewablePercentThreshold = viewAreaMode\n ? viewAreaCoveragePercentThreshold\n : itemVisiblePercentThreshold;\n invariant(\n viewablePercentThreshold != null &&\n (itemVisiblePercentThreshold != null) !==\n (viewAreaCoveragePercentThreshold != null),\n 'Must set exactly one of itemVisiblePercentThreshold or viewAreaCoveragePercentThreshold',\n );\n const viewableIndices = [];\n if (itemCount === 0) {\n return viewableIndices;\n }\n let firstVisible = -1;\n const {first, last} = renderRange || {first: 0, last: itemCount - 1};\n if (last >= itemCount) {\n console.warn(\n 'Invalid render range computing viewability ' +\n JSON.stringify({renderRange, itemCount}),\n );\n return [];\n }\n for (let idx = first; idx <= last; idx++) {\n const metrics = getFrameMetrics(idx, props);\n if (!metrics) {\n continue;\n }\n const top = metrics.offset - scrollOffset;\n const bottom = top + metrics.length;\n if (top < viewportHeight && bottom > 0) {\n firstVisible = idx;\n if (\n _isViewable(\n viewAreaMode,\n viewablePercentThreshold,\n top,\n bottom,\n viewportHeight,\n metrics.length,\n )\n ) {\n viewableIndices.push(idx);\n }\n } else if (firstVisible >= 0) {\n break;\n }\n }\n return viewableIndices;\n }\n\n /**\n * Figures out which items are viewable and how that has changed from before and calls\n * `onViewableItemsChanged` as appropriate.\n */\n onUpdate(\n props: FrameMetricProps,\n scrollOffset: number,\n viewportHeight: number,\n getFrameMetrics: (\n index: number,\n props: FrameMetricProps,\n ) => ?{\n length: number,\n offset: number,\n ...\n },\n createViewToken: (\n index: number,\n isViewable: boolean,\n props: FrameMetricProps,\n ) => ViewToken,\n onViewableItemsChanged: ({\n viewableItems: Array,\n changed: Array,\n ...\n }) => void,\n // Optional optimization to reduce the scan size\n renderRange?: {\n first: number,\n last: number,\n ...\n },\n ): void {\n const itemCount = props.getItemCount(props.data);\n if (\n (this._config.waitForInteraction && !this._hasInteracted) ||\n itemCount === 0 ||\n !getFrameMetrics(0, props)\n ) {\n return;\n }\n let viewableIndices: Array = [];\n if (itemCount) {\n viewableIndices = this.computeViewableItems(\n props,\n scrollOffset,\n viewportHeight,\n getFrameMetrics,\n renderRange,\n );\n }\n if (\n this._viewableIndices.length === viewableIndices.length &&\n this._viewableIndices.every((v, ii) => v === viewableIndices[ii])\n ) {\n // We might get a lot of scroll events where visibility doesn't change and we don't want to do\n // extra work in those cases.\n return;\n }\n this._viewableIndices = viewableIndices;\n if (this._config.minimumViewTime) {\n const handle: TimeoutID = setTimeout(() => {\n /* $FlowFixMe[incompatible-call] (>=0.63.0 site=react_native_fb) This\n * comment suppresses an error found when Flow v0.63 was deployed. To\n * see the error delete this comment and run Flow. */\n this._timers.delete(handle);\n this._onUpdateSync(\n props,\n viewableIndices,\n onViewableItemsChanged,\n createViewToken,\n );\n }, this._config.minimumViewTime);\n /* $FlowFixMe[incompatible-call] (>=0.63.0 site=react_native_fb) This\n * comment suppresses an error found when Flow v0.63 was deployed. To see\n * the error delete this comment and run Flow. */\n this._timers.add(handle);\n } else {\n this._onUpdateSync(\n props,\n viewableIndices,\n onViewableItemsChanged,\n createViewToken,\n );\n }\n }\n\n /**\n * clean-up cached _viewableIndices to evaluate changed items on next update\n */\n resetViewableIndices() {\n this._viewableIndices = [];\n }\n\n /**\n * Records that an interaction has happened even if there has been no scroll.\n */\n recordInteraction() {\n this._hasInteracted = true;\n }\n\n _onUpdateSync(\n props: FrameMetricProps,\n viewableIndicesToCheck: Array,\n onViewableItemsChanged: ({\n changed: Array,\n viewableItems: Array,\n ...\n }) => void,\n createViewToken: (\n index: number,\n isViewable: boolean,\n props: FrameMetricProps,\n ) => ViewToken,\n ) {\n // Filter out indices that have gone out of view since this call was scheduled.\n viewableIndicesToCheck = viewableIndicesToCheck.filter(ii =>\n this._viewableIndices.includes(ii),\n );\n const prevItems = this._viewableItems;\n const nextItems = new Map(\n viewableIndicesToCheck.map(ii => {\n const viewable = createViewToken(ii, true, props);\n return [viewable.key, viewable];\n }),\n );\n\n const changed = [];\n for (const [key, viewable] of nextItems) {\n if (!prevItems.has(key)) {\n changed.push(viewable);\n }\n }\n for (const [key, viewable] of prevItems) {\n if (!nextItems.has(key)) {\n changed.push({...viewable, isViewable: false});\n }\n }\n if (changed.length > 0) {\n this._viewableItems = nextItems;\n onViewableItemsChanged({\n viewableItems: Array.from(nextItems.values()),\n changed,\n viewabilityConfig: this._config,\n });\n }\n }\n}\n\nfunction _isViewable(\n viewAreaMode: boolean,\n viewablePercentThreshold: number,\n top: number,\n bottom: number,\n viewportHeight: number,\n itemLength: number,\n): boolean {\n if (_isEntirelyVisible(top, bottom, viewportHeight)) {\n return true;\n } else {\n const pixels = _getPixelsVisible(top, bottom, viewportHeight);\n const percent =\n 100 * (viewAreaMode ? pixels / viewportHeight : pixels / itemLength);\n return percent >= viewablePercentThreshold;\n }\n}\n\nfunction _getPixelsVisible(\n top: number,\n bottom: number,\n viewportHeight: number,\n): number {\n const visibleHeight = Math.min(bottom, viewportHeight) - Math.max(top, 0);\n return Math.max(0, visibleHeight);\n}\n\nfunction _isEntirelyVisible(\n top: number,\n bottom: number,\n viewportHeight: number,\n): boolean {\n return top >= 0 && bottom <= viewportHeight && bottom > top;\n}\n\nmodule.exports = ViewabilityHelper;\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 * @flow\n * @format\n */\n\nimport type {ViewStyleProp} from '../StyleSheet/StyleSheet';\nimport type {FocusEvent, LayoutEvent} from '../Types/CoreEventTypes';\nimport type FillRateHelper from './FillRateHelper';\nimport type {RenderItemType} from './VirtualizedListProps';\n\nimport View from '../Components/View/View';\nimport StyleSheet from '../StyleSheet/StyleSheet';\nimport {VirtualizedListCellContextProvider} from './VirtualizedListContext.js';\nimport invariant from 'invariant';\nimport * as React from 'react';\n\nexport type Props = {\n CellRendererComponent?: ?React.ComponentType,\n ItemSeparatorComponent: ?React.ComponentType<\n any | {highlighted: boolean, leadingItem: ?ItemT},\n >,\n ListItemComponent?: ?(React.ComponentType | React.Element),\n cellKey: string,\n debug?: ?boolean,\n fillRateHelper: FillRateHelper,\n getItemLayout?: (\n data: any,\n index: number,\n ) => {\n length: number,\n offset: number,\n index: number,\n ...\n },\n horizontal: ?boolean,\n index: number,\n inversionStyle: ViewStyleProp,\n item: ItemT,\n onCellLayout: (event: LayoutEvent, cellKey: string, index: number) => void,\n onCellFocusCapture?: (event: FocusEvent) => void,\n onUnmount: (cellKey: string) => void,\n onUpdateSeparators: (\n cellKeys: Array,\n props: $Shape>,\n ) => void,\n prevCellKey: ?string,\n renderItem?: ?RenderItemType,\n ...\n};\n\ntype SeparatorProps = $ReadOnly<{|\n highlighted: boolean,\n leadingItem: ?ItemT,\n|}>;\n\ntype State = {\n separatorProps: SeparatorProps,\n ...\n};\n\nexport default class CellRenderer extends React.Component<\n Props,\n State,\n> {\n state: State = {\n separatorProps: {\n highlighted: false,\n leadingItem: this.props.item,\n },\n };\n\n static getDerivedStateFromProps(\n props: Props,\n prevState: State,\n ): ?State {\n return {\n separatorProps: {\n ...prevState.separatorProps,\n leadingItem: props.item,\n },\n };\n }\n\n // TODO: consider factoring separator stuff out of VirtualizedList into FlatList since it's not\n // reused by SectionList and we can keep VirtualizedList simpler.\n // $FlowFixMe[missing-local-annot]\n _separators = {\n highlight: () => {\n const {cellKey, prevCellKey} = this.props;\n this.props.onUpdateSeparators([cellKey, prevCellKey], {\n highlighted: true,\n });\n },\n unhighlight: () => {\n const {cellKey, prevCellKey} = this.props;\n this.props.onUpdateSeparators([cellKey, prevCellKey], {\n highlighted: false,\n });\n },\n updateProps: (\n select: 'leading' | 'trailing',\n newProps: SeparatorProps,\n ) => {\n const {cellKey, prevCellKey} = this.props;\n this.props.onUpdateSeparators(\n [select === 'leading' ? prevCellKey : cellKey],\n newProps,\n );\n },\n };\n\n updateSeparatorProps(newProps: SeparatorProps) {\n this.setState(state => ({\n separatorProps: {...state.separatorProps, ...newProps},\n }));\n }\n\n componentWillUnmount() {\n this.props.onUnmount(this.props.cellKey);\n }\n\n _onLayout = (nativeEvent: LayoutEvent): void => {\n this.props.onCellLayout &&\n this.props.onCellLayout(\n nativeEvent,\n this.props.cellKey,\n this.props.index,\n );\n };\n\n _renderElement(\n renderItem: ?RenderItemType,\n ListItemComponent: any,\n item: ItemT,\n index: number,\n ): React.Node {\n if (renderItem && ListItemComponent) {\n console.warn(\n 'VirtualizedList: Both ListItemComponent and renderItem props are present. ListItemComponent will take' +\n ' precedence over renderItem.',\n );\n }\n\n if (ListItemComponent) {\n /* $FlowFixMe[not-a-component] (>=0.108.0 site=react_native_fb) This\n * comment suppresses an error found when Flow v0.108 was deployed. To\n * see the error, delete this comment and run Flow. */\n /* $FlowFixMe[incompatible-type-arg] (>=0.108.0 site=react_native_fb)\n * This comment suppresses an error found when Flow v0.108 was deployed.\n * To see the error, delete this comment and run Flow. */\n return React.createElement(ListItemComponent, {\n item,\n index,\n separators: this._separators,\n });\n }\n\n if (renderItem) {\n return renderItem({\n item,\n index,\n separators: this._separators,\n });\n }\n\n invariant(\n false,\n 'VirtualizedList: Either ListItemComponent or renderItem props are required but none were found.',\n );\n }\n\n render(): React.Node {\n const {\n CellRendererComponent,\n ItemSeparatorComponent,\n ListItemComponent,\n debug,\n fillRateHelper,\n getItemLayout,\n horizontal,\n item,\n index,\n inversionStyle,\n onCellFocusCapture,\n renderItem,\n } = this.props;\n const element = this._renderElement(\n renderItem,\n ListItemComponent,\n item,\n index,\n );\n\n const onLayout =\n (getItemLayout && !debug && !fillRateHelper.enabled()) ||\n !this.props.onCellLayout\n ? undefined\n : this._onLayout;\n // NOTE: that when this is a sticky header, `onLayout` will get automatically extracted and\n // called explicitly by `ScrollViewStickyHeader`.\n const itemSeparator = React.isValidElement(ItemSeparatorComponent)\n ? ItemSeparatorComponent\n : ItemSeparatorComponent && (\n \n );\n const cellStyle = inversionStyle\n ? horizontal\n ? [styles.rowReverse, inversionStyle]\n : [styles.columnReverse, inversionStyle]\n : horizontal\n ? [styles.row, inversionStyle]\n : inversionStyle;\n const result = !CellRendererComponent ? (\n =0.89.0 site=react_native_fb) *\n This comment suppresses an error found when Flow v0.89 was deployed. *\n To see the error, delete this comment and run Flow. */\n >\n {element}\n {itemSeparator}\n \n ) : (\n \n {element}\n {itemSeparator}\n \n );\n\n return (\n \n {result}\n \n );\n }\n}\n\nconst styles = StyleSheet.create({\n row: {\n flexDirection: 'row',\n },\n rowReverse: {\n flexDirection: 'row-reverse',\n },\n columnReverse: {\n flexDirection: 'column-reverse',\n },\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 * @flow strict-local\n * @format\n */\n\nimport typeof VirtualizedList from './VirtualizedList';\n\nimport * as React from 'react';\nimport {useContext, useMemo} from 'react';\n\ntype Context = $ReadOnly<{\n cellKey: ?string,\n getScrollMetrics: () => {\n contentLength: number,\n dOffset: number,\n dt: number,\n offset: number,\n timestamp: number,\n velocity: number,\n visibleLength: number,\n zoomScale: number,\n },\n horizontal: ?boolean,\n getOutermostParentListRef: () => React.ElementRef,\n registerAsNestedChild: ({\n cellKey: string,\n ref: React.ElementRef,\n }) => void,\n unregisterAsNestedChild: ({\n ref: React.ElementRef,\n }) => void,\n}>;\n\nexport const VirtualizedListContext: React.Context =\n React.createContext(null);\nif (__DEV__) {\n VirtualizedListContext.displayName = 'VirtualizedListContext';\n}\n\n/**\n * Resets the context. Intended for use by portal-like components (e.g. Modal).\n */\nexport function VirtualizedListContextResetter({\n children,\n}: {\n children: React.Node,\n}): React.Node {\n return (\n \n {children}\n \n );\n}\n\n/**\n * Sets the context with memoization. Intended to be used by `VirtualizedList`.\n */\nexport function VirtualizedListContextProvider({\n children,\n value,\n}: {\n children: React.Node,\n value: Context,\n}): React.Node {\n // Avoid setting a newly created context object if the values are identical.\n const context = useMemo(\n () => ({\n cellKey: null,\n getScrollMetrics: value.getScrollMetrics,\n horizontal: value.horizontal,\n getOutermostParentListRef: value.getOutermostParentListRef,\n registerAsNestedChild: value.registerAsNestedChild,\n unregisterAsNestedChild: value.unregisterAsNestedChild,\n }),\n [\n value.getScrollMetrics,\n value.horizontal,\n value.getOutermostParentListRef,\n value.registerAsNestedChild,\n value.unregisterAsNestedChild,\n ],\n );\n return (\n \n {children}\n \n );\n}\n\n/**\n * Sets the `cellKey`. Intended to be used by `VirtualizedList` for each cell.\n */\nexport function VirtualizedListCellContextProvider({\n cellKey,\n children,\n}: {\n cellKey: string,\n children: React.Node,\n}): React.Node {\n // Avoid setting a newly created context object if the values are identical.\n const currContext = useContext(VirtualizedListContext);\n const context = useMemo(\n () => (currContext == null ? null : {...currContext, cellKey}),\n [currContext, cellKey],\n );\n return (\n \n {children}\n \n );\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport type {FrameMetricProps} from './VirtualizedListProps';\n\n/**\n * Used to find the indices of the frames that overlap the given offsets. Useful for finding the\n * items that bound different windows of content, such as the visible area or the buffered overscan\n * area.\n */\nexport function elementsThatOverlapOffsets(\n offsets: Array,\n props: FrameMetricProps,\n getFrameMetrics: (\n index: number,\n props: FrameMetricProps,\n ) => {\n length: number,\n offset: number,\n ...\n },\n zoomScale: number = 1,\n): Array {\n const itemCount = props.getItemCount(props.data);\n const result = [];\n for (let offsetIndex = 0; offsetIndex < offsets.length; offsetIndex++) {\n const currentOffset = offsets[offsetIndex];\n let left = 0;\n let right = itemCount - 1;\n\n while (left <= right) {\n // eslint-disable-next-line no-bitwise\n const mid = left + ((right - left) >>> 1);\n const frame = getFrameMetrics(mid, props);\n const scaledOffsetStart = frame.offset * zoomScale;\n const scaledOffsetEnd = (frame.offset + frame.length) * zoomScale;\n\n // We want the first frame that contains the offset, with inclusive bounds. Thus, for the\n // first frame the scaledOffsetStart is inclusive, while for other frames it is exclusive.\n if (\n (mid === 0 && currentOffset < scaledOffsetStart) ||\n (mid !== 0 && currentOffset <= scaledOffsetStart)\n ) {\n right = mid - 1;\n } else if (currentOffset > scaledOffsetEnd) {\n left = mid + 1;\n } else {\n result[offsetIndex] = mid;\n break;\n }\n }\n }\n\n return result;\n}\n\n/**\n * Computes the number of elements in the `next` range that are new compared to the `prev` range.\n * Handy for calculating how many new items will be rendered when the render window changes so we\n * can restrict the number of new items render at once so that content can appear on the screen\n * faster.\n */\nexport function newRangeCount(\n prev: {\n first: number,\n last: number,\n ...\n },\n next: {\n first: number,\n last: number,\n ...\n },\n): number {\n return (\n next.last -\n next.first +\n 1 -\n Math.max(\n 0,\n 1 + Math.min(next.last, prev.last) - Math.max(next.first, prev.first),\n )\n );\n}\n\n/**\n * Custom logic for determining which items should be rendered given the current frame and scroll\n * metrics, as well as the previous render state. The algorithm may evolve over time, but generally\n * prioritizes the visible area first, then expands that with overscan regions ahead and behind,\n * biased in the direction of scroll.\n */\nexport function computeWindowedRenderLimits(\n props: FrameMetricProps,\n maxToRenderPerBatch: number,\n windowSize: number,\n prev: {\n first: number,\n last: number,\n },\n getFrameMetricsApprox: (\n index: number,\n props: FrameMetricProps,\n ) => {\n length: number,\n offset: number,\n ...\n },\n scrollMetrics: {\n dt: number,\n offset: number,\n velocity: number,\n visibleLength: number,\n zoomScale: number,\n ...\n },\n): {\n first: number,\n last: number,\n} {\n const itemCount = props.getItemCount(props.data);\n if (itemCount === 0) {\n return {first: 0, last: -1};\n }\n const {offset, velocity, visibleLength, zoomScale = 1} = scrollMetrics;\n\n // Start with visible area, then compute maximum overscan region by expanding from there, biased\n // in the direction of scroll. Total overscan area is capped, which should cap memory consumption\n // too.\n const visibleBegin = Math.max(0, offset);\n const visibleEnd = visibleBegin + visibleLength;\n const overscanLength = (windowSize - 1) * visibleLength;\n\n // Considering velocity seems to introduce more churn than it's worth.\n const leadFactor = 0.5; // Math.max(0, Math.min(1, velocity / 25 + 0.5));\n\n const fillPreference =\n velocity > 1 ? 'after' : velocity < -1 ? 'before' : 'none';\n\n const overscanBegin = Math.max(\n 0,\n visibleBegin - (1 - leadFactor) * overscanLength,\n );\n const overscanEnd = Math.max(0, visibleEnd + leadFactor * overscanLength);\n\n const lastItemOffset =\n getFrameMetricsApprox(itemCount - 1, props).offset * zoomScale;\n if (lastItemOffset < overscanBegin) {\n // Entire list is before our overscan window\n return {\n first: Math.max(0, itemCount - 1 - maxToRenderPerBatch),\n last: itemCount - 1,\n };\n }\n\n // Find the indices that correspond to the items at the render boundaries we're targeting.\n let [overscanFirst, first, last, overscanLast] = elementsThatOverlapOffsets(\n [overscanBegin, visibleBegin, visibleEnd, overscanEnd],\n props,\n getFrameMetricsApprox,\n zoomScale,\n );\n overscanFirst = overscanFirst == null ? 0 : overscanFirst;\n first = first == null ? Math.max(0, overscanFirst) : first;\n overscanLast = overscanLast == null ? itemCount - 1 : overscanLast;\n last =\n last == null\n ? Math.min(overscanLast, first + maxToRenderPerBatch - 1)\n : last;\n const visible = {first, last};\n\n // We want to limit the number of new cells we're rendering per batch so that we can fill the\n // content on the screen quickly. If we rendered the entire overscan window at once, the user\n // could be staring at white space for a long time waiting for a bunch of offscreen content to\n // render.\n let newCellCount = newRangeCount(prev, visible);\n\n while (true) {\n if (first <= overscanFirst && last >= overscanLast) {\n // If we fill the entire overscan range, we're done.\n break;\n }\n const maxNewCells = newCellCount >= maxToRenderPerBatch;\n const firstWillAddMore = first <= prev.first || first > prev.last;\n const firstShouldIncrement =\n first > overscanFirst && (!maxNewCells || !firstWillAddMore);\n const lastWillAddMore = last >= prev.last || last < prev.first;\n const lastShouldIncrement =\n last < overscanLast && (!maxNewCells || !lastWillAddMore);\n if (maxNewCells && !firstShouldIncrement && !lastShouldIncrement) {\n // We only want to stop if we've hit maxNewCells AND we cannot increment first or last\n // without rendering new items. This let's us preserve as many already rendered items as\n // possible, reducing render churn and keeping the rendered overscan range as large as\n // possible.\n break;\n }\n if (\n firstShouldIncrement &&\n !(fillPreference === 'after' && lastShouldIncrement && lastWillAddMore)\n ) {\n if (firstWillAddMore) {\n newCellCount++;\n }\n first--;\n }\n if (\n lastShouldIncrement &&\n !(fillPreference === 'before' && firstShouldIncrement && firstWillAddMore)\n ) {\n if (lastWillAddMore) {\n newCellCount++;\n }\n last++;\n }\n }\n if (\n !(\n last >= first &&\n first >= 0 &&\n last < itemCount &&\n first >= overscanFirst &&\n last <= overscanLast &&\n first <= visible.first &&\n last >= visible.last\n )\n ) {\n throw new Error(\n 'Bad window calculation ' +\n JSON.stringify({\n first,\n last,\n itemCount,\n overscanFirst,\n overscanLast,\n visible,\n }),\n );\n }\n return {first, last};\n}\n\nexport function keyExtractor(item: any, index: number): string {\n if (typeof item === 'object' && item?.key != null) {\n return item.key;\n }\n if (typeof item === 'object' && item?.id != null) {\n return item.id;\n }\n return String(index);\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 * @flow strict\n * @format\n */\n\nimport invariant from 'invariant';\n\nexport type CellRegion = {\n first: number,\n last: number,\n isSpacer: boolean,\n};\n\nexport class CellRenderMask {\n _numCells: number;\n _regions: Array;\n\n constructor(numCells: number) {\n invariant(\n numCells >= 0,\n 'CellRenderMask must contain a non-negative number os cells',\n );\n\n this._numCells = numCells;\n\n if (numCells === 0) {\n this._regions = [];\n } else {\n this._regions = [\n {\n first: 0,\n last: numCells - 1,\n isSpacer: true,\n },\n ];\n }\n }\n\n enumerateRegions(): $ReadOnlyArray {\n return this._regions;\n }\n\n addCells(cells: {first: number, last: number}): void {\n invariant(\n cells.first >= 0 &&\n cells.first < this._numCells &&\n cells.last >= -1 &&\n cells.last < this._numCells &&\n cells.last >= cells.first - 1,\n 'CellRenderMask.addCells called with invalid cell range',\n );\n\n // VirtualizedList uses inclusive ranges, where zero-count states are\n // possible. E.g. [0, -1] for no cells, starting at 0.\n if (cells.last < cells.first) {\n return;\n }\n\n const [firstIntersect, firstIntersectIdx] = this._findRegion(cells.first);\n const [lastIntersect, lastIntersectIdx] = this._findRegion(cells.last);\n\n // Fast-path if the cells to add are already all present in the mask. We\n // will otherwise need to do some mutation.\n if (firstIntersectIdx === lastIntersectIdx && !firstIntersect.isSpacer) {\n return;\n }\n\n // We need to replace the existing covered regions with 1-3 new regions\n // depending whether we need to split spacers out of overlapping regions.\n const newLeadRegion: Array = [];\n const newTailRegion: Array = [];\n const newMainRegion: CellRegion = {\n ...cells,\n isSpacer: false,\n };\n\n if (firstIntersect.first < newMainRegion.first) {\n if (firstIntersect.isSpacer) {\n newLeadRegion.push({\n first: firstIntersect.first,\n last: newMainRegion.first - 1,\n isSpacer: true,\n });\n } else {\n newMainRegion.first = firstIntersect.first;\n }\n }\n\n if (lastIntersect.last > newMainRegion.last) {\n if (lastIntersect.isSpacer) {\n newTailRegion.push({\n first: newMainRegion.last + 1,\n last: lastIntersect.last,\n isSpacer: true,\n });\n } else {\n newMainRegion.last = lastIntersect.last;\n }\n }\n\n const replacementRegions: Array = [\n ...newLeadRegion,\n newMainRegion,\n ...newTailRegion,\n ];\n const numRegionsToDelete = lastIntersectIdx - firstIntersectIdx + 1;\n this._regions.splice(\n firstIntersectIdx,\n numRegionsToDelete,\n ...replacementRegions,\n );\n }\n\n numCells(): number {\n return this._numCells;\n }\n\n equals(other: CellRenderMask): boolean {\n return (\n this._numCells === other._numCells &&\n this._regions.length === other._regions.length &&\n this._regions.every(\n (region, i) =>\n region.first === other._regions[i].first &&\n region.last === other._regions[i].last &&\n region.isSpacer === other._regions[i].isSpacer,\n )\n );\n }\n\n _findRegion(cellIdx: number): [CellRegion, number] {\n let firstIdx = 0;\n let lastIdx = this._regions.length - 1;\n\n while (firstIdx <= lastIdx) {\n const middleIdx = Math.floor((firstIdx + lastIdx) / 2);\n const middleRegion = this._regions[middleIdx];\n\n if (cellIdx >= middleRegion.first && cellIdx <= middleRegion.last) {\n return [middleRegion, middleIdx];\n } else if (cellIdx < middleRegion.first) {\n lastIdx = middleIdx - 1;\n } else if (cellIdx > middleRegion.last) {\n firstIdx = middleIdx + 1;\n }\n }\n\n invariant(false, `A region was not found containing cellIdx ${cellIdx}`);\n }\n}\n","'use strict';\n\nvar safeIsNaN = Number.isNaN ||\n function ponyfill(value) {\n return typeof value === 'number' && value !== value;\n };\nfunction isEqual(first, second) {\n if (first === second) {\n return true;\n }\n if (safeIsNaN(first) && safeIsNaN(second)) {\n return true;\n }\n return false;\n}\nfunction areInputsEqual(newInputs, lastInputs) {\n if (newInputs.length !== lastInputs.length) {\n return false;\n }\n for (var i = 0; i < newInputs.length; i++) {\n if (!isEqual(newInputs[i], lastInputs[i])) {\n return false;\n }\n }\n return true;\n}\n\nfunction memoizeOne(resultFn, isEqual) {\n if (isEqual === void 0) { isEqual = areInputsEqual; }\n var lastThis;\n var lastArgs = [];\n var lastResult;\n var calledOnce = false;\n function memoized() {\n var newArgs = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n newArgs[_i] = arguments[_i];\n }\n if (calledOnce && lastThis === this && isEqual(newArgs, lastArgs)) {\n return lastResult;\n }\n lastResult = resultFn.apply(this, newArgs);\n calledOnce = true;\n lastThis = this;\n lastArgs = newArgs;\n return lastResult;\n }\n return memoized;\n}\n\nmodule.exports = memoizeOne;\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 * @flow strict-local\n * @format\n */\n\nimport type {AnimatedComponentType} from '../createAnimatedComponent';\n\nimport Image from '../../Image/Image';\nimport createAnimatedComponent from '../createAnimatedComponent';\nimport * as React from 'react';\n\nexport default (createAnimatedComponent(\n (Image: $FlowFixMe),\n): AnimatedComponentType<\n React.ElementConfig,\n React.ElementRef,\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 * @flow\n * @format\n */\n\nimport type {ImageStyleProp} from '../StyleSheet/StyleSheet';\nimport type {RootTag} from '../Types/RootTagTypes';\nimport type {ImageIOS} from './Image.flow';\nimport type {ImageProps as ImagePropsType} from './ImageProps';\n\nimport flattenStyle from '../StyleSheet/flattenStyle';\nimport StyleSheet from '../StyleSheet/StyleSheet';\nimport ImageAnalyticsTagContext from './ImageAnalyticsTagContext';\nimport ImageInjection from './ImageInjection';\nimport {getImageSourcesFromImageProps} from './ImageSourceUtils';\nimport {convertObjectFitToResizeMode} from './ImageUtils';\nimport ImageViewNativeComponent from './ImageViewNativeComponent';\nimport NativeImageLoaderIOS from './NativeImageLoaderIOS';\nimport resolveAssetSource from './resolveAssetSource';\nimport * as React from 'react';\n\nfunction getSize(\n uri: string,\n success: (width: number, height: number) => void,\n failure?: (error: any) => void,\n) {\n NativeImageLoaderIOS.getSize(uri)\n .then(([width, height]) => success(width, height))\n .catch(\n failure ||\n function () {\n console.warn('Failed to get size for image ' + uri);\n },\n );\n}\n\nfunction getSizeWithHeaders(\n uri: string,\n headers: {[string]: string, ...},\n success: (width: number, height: number) => void,\n failure?: (error: any) => void,\n): any {\n return NativeImageLoaderIOS.getSizeWithHeaders(uri, headers)\n .then(function (sizes) {\n success(sizes.width, sizes.height);\n })\n .catch(\n failure ||\n function () {\n console.warn('Failed to get size for image: ' + uri);\n },\n );\n}\n\nfunction prefetchWithMetadata(\n url: string,\n queryRootName: string,\n rootTag?: ?RootTag,\n): any {\n if (NativeImageLoaderIOS.prefetchImageWithMetadata) {\n // number params like rootTag cannot be nullable before TurboModules is available\n return NativeImageLoaderIOS.prefetchImageWithMetadata(\n url,\n queryRootName,\n // NOTE: RootTag type\n // $FlowFixMe[incompatible-call] RootTag: number is incompatible with RootTag\n rootTag ? rootTag : 0,\n );\n } else {\n return NativeImageLoaderIOS.prefetchImage(url);\n }\n}\n\nfunction prefetch(url: string): any {\n return NativeImageLoaderIOS.prefetchImage(url);\n}\n\nasync function queryCache(\n urls: Array,\n): Promise<{[string]: 'memory' | 'disk' | 'disk/memory', ...}> {\n return await NativeImageLoaderIOS.queryCache(urls);\n}\n\nexport type ImageComponentStatics = $ReadOnly<{|\n getSize: typeof getSize,\n getSizeWithHeaders: typeof getSizeWithHeaders,\n prefetch: typeof prefetch,\n prefetchWithMetadata: typeof prefetchWithMetadata,\n queryCache: typeof queryCache,\n resolveAssetSource: typeof resolveAssetSource,\n|}>;\n\n/**\n * A React component for displaying different types of images,\n * including network images, static resources, temporary local images, and\n * images from local disk, such as the camera roll.\n *\n * See https://reactnative.dev/docs/image\n */\n/* $FlowFixMe[missing-local-annot] The type annotation(s) required by Flow's\n * LTI update could not be added via codemod */\nconst BaseImage = (props: ImagePropsType, forwardedRef) => {\n const source = getImageSourcesFromImageProps(props) || {\n uri: undefined,\n width: undefined,\n height: undefined,\n };\n\n let sources;\n let style: ImageStyleProp;\n if (Array.isArray(source)) {\n style = flattenStyle([styles.base, props.style]) || {};\n sources = source;\n } else {\n const {width = props.width, height = props.height, uri} = source;\n style = flattenStyle([{width, height}, styles.base, props.style]) || {};\n sources = [source];\n\n if (uri === '') {\n console.warn('source.uri should not be an empty string');\n }\n }\n\n const objectFit =\n // $FlowFixMe[prop-missing]\n style && style.objectFit\n ? convertObjectFitToResizeMode(style.objectFit)\n : null;\n const resizeMode =\n // $FlowFixMe[prop-missing]\n objectFit || props.resizeMode || (style && style.resizeMode) || 'cover';\n // $FlowFixMe[prop-missing]\n const tintColor = props.tintColor || style.tintColor;\n\n if (props.children != null) {\n throw new Error(\n 'The component cannot contain children. If you want to render content on top of the image, consider using the component or absolute positioning.',\n );\n }\n const {\n 'aria-busy': ariaBusy,\n 'aria-checked': ariaChecked,\n 'aria-disabled': ariaDisabled,\n 'aria-expanded': ariaExpanded,\n 'aria-selected': ariaSelected,\n height,\n src,\n width,\n ...restProps\n } = props;\n\n const _accessibilityState = {\n busy: ariaBusy ?? props.accessibilityState?.busy,\n checked: ariaChecked ?? props.accessibilityState?.checked,\n disabled: ariaDisabled ?? props.accessibilityState?.disabled,\n expanded: ariaExpanded ?? props.accessibilityState?.expanded,\n selected: ariaSelected ?? props.accessibilityState?.selected,\n };\n const accessibilityLabel = props['aria-label'] ?? props.accessibilityLabel;\n\n return (\n \n {analyticTag => {\n return (\n \n );\n }}\n \n );\n};\n\nconst ImageForwardRef = React.forwardRef<\n ImagePropsType,\n React.ElementRef,\n>(BaseImage);\n\nlet Image = ImageForwardRef;\nif (ImageInjection.unstable_createImageComponent != null) {\n Image = ImageInjection.unstable_createImageComponent(Image);\n}\n\nImage.displayName = 'Image';\n\n/**\n * Retrieve the width and height (in pixels) of an image prior to displaying it.\n *\n * See https://reactnative.dev/docs/image#getsize\n */\n/* $FlowFixMe[prop-missing] (>=0.89.0 site=react_native_ios_fb) This comment\n * suppresses an error found when Flow v0.89 was deployed. To see the error,\n * delete this comment and run Flow. */\nImage.getSize = getSize;\n\n/**\n * Retrieve the width and height (in pixels) of an image prior to displaying it\n * with the ability to provide the headers for the request.\n *\n * See https://reactnative.dev/docs/image#getsizewithheaders\n */\n/* $FlowFixMe[prop-missing] (>=0.89.0 site=react_native_ios_fb) This comment\n * suppresses an error found when Flow v0.89 was deployed. To see the error,\n * delete this comment and run Flow. */\nImage.getSizeWithHeaders = getSizeWithHeaders;\n\n/**\n * Prefetches a remote image for later use by downloading it to the disk\n * cache.\n *\n * See https://reactnative.dev/docs/image#prefetch\n */\n/* $FlowFixMe[prop-missing] (>=0.89.0 site=react_native_ios_fb) This comment\n * suppresses an error found when Flow v0.89 was deployed. To see the error,\n * delete this comment and run Flow. */\nImage.prefetch = prefetch;\n\n/**\n * Prefetches a remote image for later use by downloading it to the disk\n * cache, and adds metadata for queryRootName and rootTag.\n *\n * See https://reactnative.dev/docs/image#prefetch\n */\n/* $FlowFixMe[prop-missing] (>=0.89.0 site=react_native_ios_fb) This comment\n * suppresses an error found when Flow v0.89 was deployed. To see the error,\n * delete this comment and run Flow. */\nImage.prefetchWithMetadata = prefetchWithMetadata;\n\n/**\n * Performs cache interrogation.\n *\n * See https://reactnative.dev/docs/image#querycache\n */\n/* $FlowFixMe[prop-missing] (>=0.89.0 site=react_native_ios_fb) This comment\n * suppresses an error found when Flow v0.89 was deployed. To see the error,\n * delete this comment and run Flow. */\nImage.queryCache = queryCache;\n\n/**\n * Resolves an asset reference into an object.\n *\n * See https://reactnative.dev/docs/image#resolveassetsource\n */\n/* $FlowFixMe[prop-missing] (>=0.89.0 site=react_native_ios_fb) This comment\n * suppresses an error found when Flow v0.89 was deployed. To see the error,\n * delete this comment and run Flow. */\nImage.resolveAssetSource = resolveAssetSource;\n\n/**\n * Switch to `deprecated-react-native-prop-types` for compatibility with future\n * releases. This is deprecated and will be removed in the future.\n */\nImage.propTypes = require('deprecated-react-native-prop-types').ImagePropTypes;\n\nconst styles = StyleSheet.create({\n base: {\n overflow: 'hidden',\n },\n});\n\nmodule.exports = ((Image: any): ImageIOS);\n","function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {\n try {\n var info = gen[key](arg);\n var value = info.value;\n } catch (error) {\n reject(error);\n return;\n }\n\n if (info.done) {\n resolve(value);\n } else {\n Promise.resolve(value).then(_next, _throw);\n }\n}\n\nfunction _asyncToGenerator(fn) {\n return function () {\n var self = this,\n args = arguments;\n return new Promise(function (resolve, reject) {\n var gen = fn.apply(self, args);\n\n function _next(value) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value);\n }\n\n function _throw(err) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err);\n }\n\n _next(undefined);\n });\n };\n}\n\nmodule.exports = _asyncToGenerator, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","/**\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 * @flow strict\n * @format\n */\n\nimport * as React from 'react';\n\ntype ContextType = ?string;\n\nconst Context: React.Context =\n React.createContext(null);\n\nif (__DEV__) {\n Context.displayName = 'ImageAnalyticsTagContext';\n}\n\nexport default Context;\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 * @format strict-local\n * @flow\n */\n\nimport type {ImageProps as ImagePropsType} from './ImageProps';\n\nimport ImageViewNativeComponent from './ImageViewNativeComponent';\nimport TextInlineImageNativeComponent from './TextInlineImageNativeComponent';\nimport * as React from 'react';\n\nexport default {\n unstable_createImageComponent: (null: ?(\n Image: React.AbstractComponent<\n ImagePropsType,\n | React.ElementRef\n | React.ElementRef,\n >,\n ) => React.AbstractComponent<\n ImagePropsType,\n | React.ElementRef\n | React.ElementRef,\n >),\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 * @flow strict-local\n * @format\n */\n\nimport type {ViewProps} from '../Components/View/ViewPropTypes';\nimport type {\n HostComponent,\n PartialViewConfig,\n} from '../Renderer/shims/ReactNativeTypes';\nimport type {\n ColorValue,\n DangerouslyImpreciseStyle,\n ImageStyleProp,\n} from '../StyleSheet/StyleSheet';\nimport type {ResolvedAssetSource} from './AssetSourceResolver';\nimport type {ImageProps} from './ImageProps';\n\nimport * as NativeComponentRegistry from '../NativeComponent/NativeComponentRegistry';\nimport {ConditionallyIgnoredEventHandlers} from '../NativeComponent/ViewConfigIgnore';\nimport Platform from '../Utilities/Platform';\n\ntype Props = $ReadOnly<{\n ...ImageProps,\n ...ViewProps,\n\n style?: ImageStyleProp | DangerouslyImpreciseStyle,\n\n // iOS native props\n tintColor?: ColorValue,\n\n // Android native props\n shouldNotifyLoadEvents?: boolean,\n src?:\n | ?ResolvedAssetSource\n | ?$ReadOnlyArray>,\n headers?: ?{[string]: string},\n defaultSrc?: ?string,\n loadingIndicatorSrc?: ?string,\n}>;\n\nexport const __INTERNAL_VIEW_CONFIG: PartialViewConfig =\n Platform.OS === 'android'\n ? {\n uiViewClassName: 'RCTImageView',\n bubblingEventTypes: {},\n directEventTypes: {\n topLoadStart: {\n registrationName: 'onLoadStart',\n },\n topProgress: {\n registrationName: 'onProgress',\n },\n topError: {\n registrationName: 'onError',\n },\n topLoad: {\n registrationName: 'onLoad',\n },\n topLoadEnd: {\n registrationName: 'onLoadEnd',\n },\n },\n validAttributes: {\n blurRadius: true,\n internal_analyticTag: true,\n resizeMode: true,\n tintColor: {\n process: require('../StyleSheet/processColor'),\n },\n borderBottomLeftRadius: true,\n borderTopLeftRadius: true,\n resizeMethod: true,\n src: true,\n borderRadius: true,\n headers: true,\n shouldNotifyLoadEvents: true,\n defaultSrc: true,\n overlayColor: {\n process: require('../StyleSheet/processColor'),\n },\n borderColor: {\n process: require('../StyleSheet/processColor'),\n },\n accessible: true,\n progressiveRenderingEnabled: true,\n fadeDuration: true,\n borderBottomRightRadius: true,\n borderTopRightRadius: true,\n loadingIndicatorSrc: true,\n },\n }\n : {\n uiViewClassName: 'RCTImageView',\n bubblingEventTypes: {},\n directEventTypes: {\n topLoadStart: {\n registrationName: 'onLoadStart',\n },\n topProgress: {\n registrationName: 'onProgress',\n },\n topError: {\n registrationName: 'onError',\n },\n topPartialLoad: {\n registrationName: 'onPartialLoad',\n },\n topLoad: {\n registrationName: 'onLoad',\n },\n topLoadEnd: {\n registrationName: 'onLoadEnd',\n },\n },\n validAttributes: {\n blurRadius: true,\n capInsets: {\n diff: require('../Utilities/differ/insetsDiffer'),\n },\n defaultSource: {\n process: require('./resolveAssetSource'),\n },\n internal_analyticTag: true,\n resizeMode: true,\n source: true,\n tintColor: {\n process: require('../StyleSheet/processColor'),\n },\n ...ConditionallyIgnoredEventHandlers({\n onLoadStart: true,\n onLoad: true,\n onLoadEnd: true,\n onProgress: true,\n onError: true,\n onPartialLoad: true,\n }),\n },\n };\n\nconst ImageViewNativeComponent: HostComponent =\n NativeComponentRegistry.get(\n 'RCTImageView',\n () => __INTERNAL_VIEW_CONFIG,\n );\n\nexport default ImageViewNativeComponent;\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 * @format\n * @flow strict-local\n */\n\n'use strict';\n\nimport type {ViewProps} from '../Components/View/ViewPropTypes';\nimport type {\n HostComponent,\n PartialViewConfig,\n} from '../Renderer/shims/ReactNativeTypes';\nimport type {ColorValue} from '../StyleSheet/StyleSheet';\nimport type {ImageResizeMode} from './ImageResizeMode';\n\nimport * as NativeComponentRegistry from '../NativeComponent/NativeComponentRegistry';\n\ntype NativeProps = $ReadOnly<{\n ...ViewProps,\n resizeMode?: ?ImageResizeMode,\n src?: ?$ReadOnlyArray>,\n tintColor?: ?ColorValue,\n headers?: ?{[string]: string},\n}>;\n\nexport const __INTERNAL_VIEW_CONFIG: PartialViewConfig = {\n uiViewClassName: 'RCTTextInlineImage',\n bubblingEventTypes: {},\n directEventTypes: {},\n validAttributes: {\n resizeMode: true,\n src: true,\n tintColor: {\n process: require('../StyleSheet/processColor'),\n },\n headers: true,\n },\n};\n\nconst TextInlineImage: HostComponent =\n NativeComponentRegistry.get(\n 'RCTTextInlineImage',\n () => __INTERNAL_VIEW_CONFIG,\n );\n\nexport default TextInlineImage;\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 * @flow\n * @format\n */\n\nimport type {RootTag} from '../TurboModule/RCTExport';\nimport type {TurboModule} from '../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../TurboModule/TurboModuleRegistry';\n\nexport interface Spec extends TurboModule {\n +getConstants: () => {||};\n // Return [width, height] of image uri\n +getSize: (uri: string) => Promise<$ReadOnlyArray>;\n +getSizeWithHeaders: (\n uri: string,\n headers: Object,\n ) => Promise<{\n width: number,\n height: number,\n ...\n }>;\n +prefetchImage: (uri: string) => Promise;\n +prefetchImageWithMetadata?: (\n uri: string,\n queryRootName: string,\n rootTag: RootTag,\n ) => Promise;\n +queryCache: (uris: Array) => Promise;\n}\n\nexport default (TurboModuleRegistry.getEnforcing('ImageLoader'): Spec);\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 * @flow strict-local\n * @format\n */\n\n'use strict';\n\nimport type {ResolvedAssetSource} from './AssetSourceResolver';\nimport type {ImageProps} from './ImageProps';\n\nimport resolveAssetSource from './resolveAssetSource';\n\n/**\n * A function which returns the appropriate value for image source\n * by resolving the `source`, `src` and `srcSet` props.\n */\nexport function getImageSourcesFromImageProps(\n imageProps: ImageProps,\n): ?ResolvedAssetSource | $ReadOnlyArray<{uri: string, ...}> {\n let source = resolveAssetSource(imageProps.source);\n\n let sources;\n\n const {crossOrigin, referrerPolicy, src, srcSet, width, height} = imageProps;\n\n const headers: {[string]: string} = {};\n if (crossOrigin === 'use-credentials') {\n headers['Access-Control-Allow-Credentials'] = 'true';\n }\n if (referrerPolicy != null) {\n headers['Referrer-Policy'] = referrerPolicy;\n }\n if (srcSet != null) {\n const sourceList = [];\n const srcSetList = srcSet.split(', ');\n // `src` prop should be used with default scale if `srcSet` does not have 1x scale.\n let shouldUseSrcForDefaultScale = true;\n srcSetList.forEach(imageSrc => {\n const [uri, xScale = '1x'] = imageSrc.split(' ');\n if (!xScale.endsWith('x')) {\n console.warn(\n 'The provided format for scale is not supported yet. Please use scales like 1x, 2x, etc.',\n );\n } else {\n const scale = parseInt(xScale.split('x')[0], 10);\n if (!isNaN(scale)) {\n // 1x scale is provided in `srcSet` prop so ignore the `src` prop if provided.\n shouldUseSrcForDefaultScale =\n scale === 1 ? false : shouldUseSrcForDefaultScale;\n sourceList.push({headers: headers, scale, uri, width, height});\n }\n }\n });\n\n if (shouldUseSrcForDefaultScale && src != null) {\n sourceList.push({\n headers: headers,\n scale: 1,\n uri: src,\n width,\n height,\n });\n }\n if (sourceList.length === 0) {\n console.warn('The provided value for srcSet is not valid.');\n }\n\n sources = sourceList;\n } else if (src != null) {\n sources = [{uri: src, headers: headers, width, height}];\n } else {\n sources = source;\n }\n return sources;\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 * @flow\n * @format\n */\n\ntype ResizeMode = 'cover' | 'contain' | 'stretch' | 'repeat' | 'center';\n\nexport function convertObjectFitToResizeMode(objectFit: string): ResizeMode {\n const objectFitMap = {\n contain: 'contain',\n cover: 'cover',\n fill: 'stretch',\n 'scale-down': 'contain',\n };\n return objectFitMap[objectFit];\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 * @flow strict-local\n * @format\n */\n\nimport type {____ViewStyle_Internal} from '../../StyleSheet/StyleSheetTypes';\nimport type {AnimatedComponentType} from '../createAnimatedComponent';\n\nimport RefreshControl from '../../Components/RefreshControl/RefreshControl';\nimport ScrollView from '../../Components/ScrollView/ScrollView';\nimport flattenStyle from '../../StyleSheet/flattenStyle';\nimport splitLayoutProps from '../../StyleSheet/splitLayoutProps';\nimport StyleSheet from '../../StyleSheet/StyleSheet';\nimport Platform from '../../Utilities/Platform';\nimport useMergeRefs from '../../Utilities/useMergeRefs';\nimport createAnimatedComponent from '../createAnimatedComponent';\nimport useAnimatedProps from '../useAnimatedProps';\nimport * as React from 'react';\nimport {useMemo} from 'react';\n\ntype Props = React.ElementConfig;\ntype Instance = React.ElementRef;\n\n/**\n * @see https://github.com/facebook/react-native/commit/b8c8562\n */\nconst AnimatedScrollView: AnimatedComponentType =\n React.forwardRef((props, forwardedRef) => {\n // (Android only) When a ScrollView has a RefreshControl and\n // any `style` property set with an Animated.Value, the CSS\n // gets incorrectly applied twice. This is because ScrollView\n // swaps the parent/child relationship of itself and the\n // RefreshControl component (see ScrollView.js for more details).\n if (\n Platform.OS === 'android' &&\n props.refreshControl != null &&\n props.style != null\n ) {\n return (\n \n );\n } else {\n return (\n \n );\n }\n });\n\nconst AnimatedScrollViewWithInvertedRefreshControl = React.forwardRef(\n (\n props: {\n ...React.ElementConfig,\n // $FlowFixMe[unclear-type] Same Flow type as `refreshControl` in ScrollView\n refreshControl: React.Element,\n },\n forwardedRef,\n ) => {\n // Split `props` into the animate-able props for the parent (RefreshControl)\n // and child (ScrollView).\n const {intermediatePropsForRefreshControl, intermediatePropsForScrollView} =\n useMemo(() => {\n const {outer, inner} = splitLayoutProps(flattenStyle(props.style));\n return {\n intermediatePropsForRefreshControl: {style: outer},\n intermediatePropsForScrollView: {...props, style: inner},\n };\n }, [props]);\n\n // Handle animated props on `refreshControl`.\n const [refreshControlAnimatedProps, refreshControlRef] = useAnimatedProps<\n {style: ?____ViewStyle_Internal},\n $FlowFixMe,\n >(intermediatePropsForRefreshControl);\n // NOTE: Assumes that refreshControl.ref` and `refreshControl.style` can be\n // safely clobbered.\n const refreshControl: React.Element =\n React.cloneElement(props.refreshControl, {\n ...refreshControlAnimatedProps,\n ref: refreshControlRef,\n });\n\n // Handle animated props on `NativeDirectionalScrollView`.\n const [scrollViewAnimatedProps, scrollViewRef] = useAnimatedProps<\n Props,\n Instance,\n >(intermediatePropsForScrollView);\n const ref = useMergeRefs(scrollViewRef, forwardedRef);\n\n return (\n // $FlowFixMe[incompatible-use] Investigate useAnimatedProps return value\n \n );\n },\n);\n\nconst AnimatedScrollViewWithoutInvertedRefreshControl =\n createAnimatedComponent(ScrollView);\n\nexport default AnimatedScrollView;\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 * @flow strict-local\n * @format\n */\n\n'use strict';\n\nimport useRefEffect from '../Utilities/useRefEffect';\nimport {AnimatedEvent} from './AnimatedEvent';\nimport NativeAnimatedHelper from './NativeAnimatedHelper';\nimport AnimatedProps from './nodes/AnimatedProps';\nimport {\n useCallback,\n useEffect,\n useLayoutEffect,\n useMemo,\n useReducer,\n useRef,\n} from 'react';\n\ntype ReducedProps = {\n ...TProps,\n collapsable: boolean,\n ...\n};\ntype CallbackRef = T => mixed;\n\nexport default function useAnimatedProps(\n props: TProps,\n): [ReducedProps, CallbackRef] {\n const [, scheduleUpdate] = useReducer(count => count + 1, 0);\n const onUpdateRef = useRef void>(null);\n\n // TODO: Only invalidate `node` if animated props or `style` change. In the\n // previous implementation, we permitted `style` to override props with the\n // same name property name as styles, so we can probably continue doing that.\n // The ordering of other props *should* not matter.\n const node = useMemo(\n () => new AnimatedProps(props, () => onUpdateRef.current?.()),\n [props],\n );\n useAnimatedPropsLifecycle(node);\n\n // TODO: This \"effect\" does three things:\n //\n // 1) Call `setNativeView`.\n // 2) Update `onUpdateRef`.\n // 3) Update listeners for `AnimatedEvent` props.\n //\n // Ideally, each of these would be separat \"effects\" so that they are not\n // unnecessarily re-run when irrelevant dependencies change. For example, we\n // should be able to hoist all `AnimatedEvent` props and only do #3 if either\n // the `AnimatedEvent` props change or `instance` changes.\n //\n // But there is no way to transparently compose three separate callback refs,\n // so we just combine them all into one for now.\n const refEffect = useCallback(\n (instance: TInstance) => {\n // NOTE: This may be called more often than necessary (e.g. when `props`\n // changes), but `setNativeView` already optimizes for that.\n node.setNativeView(instance);\n\n // NOTE: This callback is only used by the JavaScript animation driver.\n onUpdateRef.current = () => {\n if (\n process.env.NODE_ENV === 'test' ||\n typeof instance !== 'object' ||\n typeof instance?.setNativeProps !== 'function' ||\n isFabricInstance(instance)\n ) {\n // Schedule an update for this component to update `reducedProps`,\n // but do not compute it immediately. If a parent also updated, we\n // need to merge those new props in before updating.\n scheduleUpdate();\n } else if (!node.__isNative) {\n // $FlowIgnore[not-a-function] - Assume it's still a function.\n // $FlowFixMe[incompatible-use]\n instance.setNativeProps(node.__getAnimatedValue());\n } else {\n throw new Error(\n 'Attempting to run JS driven animation on animated node ' +\n 'that has been moved to \"native\" earlier by starting an ' +\n 'animation with `useNativeDriver: true`',\n );\n }\n };\n\n const target = getEventTarget(instance);\n const events = [];\n\n for (const propName in props) {\n const propValue = props[propName];\n if (propValue instanceof AnimatedEvent && propValue.__isNative) {\n propValue.__attach(target, propName);\n events.push([propName, propValue]);\n }\n }\n\n return () => {\n onUpdateRef.current = null;\n\n for (const [propName, propValue] of events) {\n propValue.__detach(target, propName);\n }\n };\n },\n [props, node],\n );\n const callbackRef = useRefEffect(refEffect);\n\n return [reduceAnimatedProps(node), callbackRef];\n}\n\nfunction reduceAnimatedProps(\n node: AnimatedProps,\n): ReducedProps {\n // Force `collapsable` to be false so that the native view is not flattened.\n // Flattened views cannot be accurately referenced by the native driver.\n return {\n ...node.__getValue(),\n collapsable: false,\n };\n}\n\n/**\n * Manages the lifecycle of the supplied `AnimatedProps` by invoking `__attach`\n * and `__detach`. However, this is more complicated because `AnimatedProps`\n * uses reference counting to determine when to recursively detach its children\n * nodes. So in order to optimize this, we avoid detaching until the next attach\n * unless we are unmounting.\n */\nfunction useAnimatedPropsLifecycle(node: AnimatedProps): void {\n const prevNodeRef = useRef(null);\n const isUnmountingRef = useRef(false);\n\n useEffect(() => {\n // It is ok for multiple components to call `flushQueue` because it noops\n // if the queue is empty. When multiple animated components are mounted at\n // the same time. Only first component flushes the queue and the others will noop.\n NativeAnimatedHelper.API.flushQueue();\n });\n\n useLayoutEffect(() => {\n isUnmountingRef.current = false;\n return () => {\n isUnmountingRef.current = true;\n };\n }, []);\n\n useLayoutEffect(() => {\n node.__attach();\n if (prevNodeRef.current != null) {\n const prevNode = prevNodeRef.current;\n // TODO: Stop restoring default values (unless `reset` is called).\n prevNode.__restoreDefaultValues();\n prevNode.__detach();\n prevNodeRef.current = null;\n }\n return () => {\n if (isUnmountingRef.current) {\n // NOTE: Do not restore default values on unmount, see D18197735.\n node.__detach();\n } else {\n prevNodeRef.current = node;\n }\n };\n }, [node]);\n}\n\nfunction getEventTarget(instance: TInstance): TInstance {\n return typeof instance === 'object' &&\n typeof instance?.getScrollableNode === 'function'\n ? // $FlowFixMe[incompatible-use] - Legacy instance assumptions.\n instance.getScrollableNode()\n : instance;\n}\n\n// $FlowFixMe[unclear-type] - Legacy instance assumptions.\nfunction isFabricInstance(instance: any): boolean {\n return (\n hasFabricHandle(instance) ||\n // Some components have a setNativeProps function but aren't a host component\n // such as lists like FlatList and SectionList. These should also use\n // forceUpdate in Fabric since setNativeProps doesn't exist on the underlying\n // host component. This crazy hack is essentially special casing those lists and\n // ScrollView itself to use forceUpdate in Fabric.\n // If these components end up using forwardRef then these hacks can go away\n // as instance would actually be the underlying host component and the above check\n // would be sufficient.\n hasFabricHandle(instance?.getNativeScrollRef?.()) ||\n hasFabricHandle(instance?.getScrollResponder?.()?.getNativeScrollRef?.())\n );\n}\n\n// $FlowFixMe[unclear-type] - Legacy instance assumptions.\nfunction hasFabricHandle(instance: any): boolean {\n // eslint-disable-next-line dot-notation\n return instance?.['_internalInstanceHandle']?.stateNode?.canonical != null;\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 * @flow strict\n * @format\n */\n\nimport {useCallback, useRef} from 'react';\n\ntype CallbackRef = T => mixed;\n\n/**\n * Constructs a callback ref that provides similar semantics as `useEffect`. The\n * supplied `effect` callback will be called with non-null component instances.\n * The `effect` callback can also optionally return a cleanup function.\n *\n * When a component is updated or unmounted, the cleanup function is called. The\n * `effect` callback will then be called again, if applicable.\n *\n * When a new `effect` callback is supplied, the previously returned cleanup\n * function will be called before the new `effect` callback is called with the\n * same instance.\n *\n * WARNING: The `effect` callback should be stable (e.g. using `useCallback`).\n */\nexport default function useRefEffect(\n effect: TInstance => (() => void) | void,\n): CallbackRef {\n const cleanupRef = useRef<(() => void) | void>(undefined);\n return useCallback(\n (instance: null | TInstance) => {\n if (cleanupRef.current) {\n cleanupRef.current();\n cleanupRef.current = undefined;\n }\n if (instance != null) {\n cleanupRef.current = effect(instance);\n }\n },\n [effect],\n );\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 * @flow strict-local\n * @format\n */\n\nimport type {AnimatedComponentType} from '../createAnimatedComponent';\n\nimport SectionList from '../../Lists/SectionList';\nimport createAnimatedComponent from '../createAnimatedComponent';\nimport * as React from 'react';\n\n/**\n * @see https://github.com/facebook/react-native/commit/b8c8562\n */\nconst SectionListWithEventThrottle = React.forwardRef((props, ref) => (\n \n));\n\nexport default (createAnimatedComponent(\n SectionListWithEventThrottle,\n): AnimatedComponentType<\n React.ElementConfig,\n React.ElementRef,\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport type {ScrollResponderType} from '../Components/ScrollView/ScrollView';\nimport type {\n Props as VirtualizedSectionListProps,\n ScrollToLocationParamsType,\n SectionBase as _SectionBase,\n} from './VirtualizedSectionList';\n\nimport Platform from '../Utilities/Platform';\nimport VirtualizedSectionList from './VirtualizedSectionList';\nimport * as React from 'react';\n\ntype Item = any;\n\nexport type SectionBase = _SectionBase;\n\ntype RequiredProps> = {|\n /**\n * The actual data to render, akin to the `data` prop in [``](https://reactnative.dev/docs/flatlist).\n *\n * General shape:\n *\n * sections: $ReadOnlyArray<{\n * data: $ReadOnlyArray,\n * renderItem?: ({item: SectionItem, ...}) => ?React.Element<*>,\n * ItemSeparatorComponent?: ?ReactClass<{highlighted: boolean, ...}>,\n * }>\n */\n sections: $ReadOnlyArray,\n|};\n\ntype OptionalProps> = {|\n /**\n * Default renderer for every item in every section. Can be over-ridden on a per-section basis.\n */\n renderItem?: (info: {\n item: Item,\n index: number,\n section: SectionT,\n separators: {\n highlight: () => void,\n unhighlight: () => void,\n updateProps: (select: 'leading' | 'trailing', newProps: Object) => void,\n ...\n },\n ...\n }) => null | React.Element,\n /**\n * A marker property for telling the list to re-render (since it implements `PureComponent`). If\n * any of your `renderItem`, Header, Footer, etc. functions depend on anything outside of the\n * `data` prop, stick it here and treat it immutably.\n */\n extraData?: any,\n /**\n * How many items to render in the initial batch. This should be enough to fill the screen but not\n * much more. Note these items will never be unmounted as part of the windowed rendering in order\n * to improve perceived performance of scroll-to-top actions.\n */\n initialNumToRender?: ?number,\n /**\n * Reverses the direction of scroll. Uses scale transforms of -1.\n */\n inverted?: ?boolean,\n /**\n * Used to extract a unique key for a given item at the specified index. Key is used for caching\n * and as the react key to track item re-ordering. The default extractor checks item.key, then\n * falls back to using the index, like react does. Note that this sets keys for each item, but\n * each overall section still needs its own key.\n */\n keyExtractor?: ?(item: Item, index: number) => string,\n /**\n * Called once when the scroll position gets within `onEndReachedThreshold` of the rendered\n * content.\n */\n onEndReached?: ?(info: {distanceFromEnd: number, ...}) => void,\n /**\n * Note: may have bugs (missing content) in some circumstances - use at your own risk.\n *\n * This may improve scroll performance for large lists.\n */\n removeClippedSubviews?: boolean,\n|};\n\nexport type Props = {|\n ...$Diff<\n VirtualizedSectionListProps,\n {\n getItem: $PropertyType, 'getItem'>,\n getItemCount: $PropertyType<\n VirtualizedSectionListProps,\n 'getItemCount',\n >,\n renderItem: $PropertyType<\n VirtualizedSectionListProps,\n 'renderItem',\n >,\n keyExtractor: $PropertyType<\n VirtualizedSectionListProps,\n 'keyExtractor',\n >,\n ...\n },\n >,\n ...RequiredProps,\n ...OptionalProps,\n|};\n\n/**\n * A performant interface for rendering sectioned lists, supporting the most handy features:\n *\n * - Fully cross-platform.\n * - Configurable viewability callbacks.\n * - List header support.\n * - List footer support.\n * - Item separator support.\n * - Section header support.\n * - Section separator support.\n * - Heterogeneous data and item rendering support.\n * - Pull to Refresh.\n * - Scroll loading.\n *\n * If you don't need section support and want a simpler interface, use\n * [``](https://reactnative.dev/docs/flatlist).\n *\n * Simple Examples:\n *\n * }\n * renderSectionHeader={({section}) =>
}\n * sections={[ // homogeneous rendering between sections\n * {data: [...], title: ...},\n * {data: [...], title: ...},\n * {data: [...], title: ...},\n * ]}\n * />\n *\n * \n *\n * This is a convenience wrapper around [``](docs/virtualizedlist),\n * and thus inherits its props (as well as those of `ScrollView`) that aren't explicitly listed\n * here, along with the following caveats:\n *\n * - Internal state is not preserved when content scrolls out of the render window. Make sure all\n * your data is captured in the item data or external stores like Flux, Redux, or Relay.\n * - This is a `PureComponent` which means that it will not re-render if `props` remain shallow-\n * equal. Make sure that everything your `renderItem` function depends on is passed as a prop\n * (e.g. `extraData`) that is not `===` after updates, otherwise your UI may not update on\n * changes. This includes the `data` prop and parent component state.\n * - In order to constrain memory and enable smooth scrolling, content is rendered asynchronously\n * offscreen. This means it's possible to scroll faster than the fill rate and momentarily see\n * blank content. This is a tradeoff that can be adjusted to suit the needs of each application,\n * and we are working on improving it behind the scenes.\n * - By default, the list looks for a `key` prop on each item and uses that for the React key.\n * Alternatively, you can provide a custom `keyExtractor` prop.\n *\n */\nexport default class SectionList<\n SectionT: SectionBase,\n> extends React.PureComponent, void> {\n props: Props;\n\n /**\n * Scrolls to the item at the specified `sectionIndex` and `itemIndex` (within the section)\n * positioned in the viewable area such that `viewPosition` 0 places it at the top (and may be\n * covered by a sticky header), 1 at the bottom, and 0.5 centered in the middle. `viewOffset` is a\n * fixed number of pixels to offset the final target position, e.g. to compensate for sticky\n * headers.\n *\n * Note: cannot scroll to locations outside the render window without specifying the\n * `getItemLayout` prop.\n */\n scrollToLocation(params: ScrollToLocationParamsType) {\n if (this._wrapperListRef != null) {\n this._wrapperListRef.scrollToLocation(params);\n }\n }\n\n /**\n * Tells the list an interaction has occurred, which should trigger viewability calculations, e.g.\n * if `waitForInteractions` is true and the user has not scrolled. This is typically called by\n * taps on items or by navigation actions.\n */\n recordInteraction() {\n const listRef = this._wrapperListRef && this._wrapperListRef.getListRef();\n listRef && listRef.recordInteraction();\n }\n\n /**\n * Displays the scroll indicators momentarily.\n *\n * @platform ios\n */\n flashScrollIndicators() {\n const listRef = this._wrapperListRef && this._wrapperListRef.getListRef();\n listRef && listRef.flashScrollIndicators();\n }\n\n /**\n * Provides a handle to the underlying scroll responder.\n */\n getScrollResponder(): ?ScrollResponderType {\n const listRef = this._wrapperListRef && this._wrapperListRef.getListRef();\n if (listRef) {\n return listRef.getScrollResponder();\n }\n }\n\n getScrollableNode(): any {\n const listRef = this._wrapperListRef && this._wrapperListRef.getListRef();\n if (listRef) {\n return listRef.getScrollableNode();\n }\n }\n\n setNativeProps(props: Object) {\n const listRef = this._wrapperListRef && this._wrapperListRef.getListRef();\n if (listRef) {\n listRef.setNativeProps(props);\n }\n }\n\n render(): React.Node {\n const {\n stickySectionHeadersEnabled: _stickySectionHeadersEnabled,\n ...restProps\n } = this.props;\n const stickySectionHeadersEnabled =\n _stickySectionHeadersEnabled ?? Platform.OS === 'ios';\n return (\n items.length}\n getItem={(items, index) => items[index]}\n />\n );\n }\n\n _wrapperListRef: ?React.ElementRef;\n /* $FlowFixMe[missing-local-annot] The type annotation(s) required by Flow's\n * LTI update could not be added via codemod */\n _captureRef = ref => {\n this._wrapperListRef = ref;\n };\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 * @flow\n * @format\n */\n\nimport type {ViewToken} from './ViewabilityHelper';\n\nimport View from '../Components/View/View';\nimport VirtualizedList from './VirtualizedList';\nimport {keyExtractor as defaultKeyExtractor} from './VirtualizeUtils';\nimport invariant from 'invariant';\nimport * as React from 'react';\n\ntype Item = any;\n\nexport type SectionBase = {\n /**\n * The data for rendering items in this section.\n */\n data: $ReadOnlyArray,\n /**\n * Optional key to keep track of section re-ordering. If you don't plan on re-ordering sections,\n * the array index will be used by default.\n */\n key?: string,\n // Optional props will override list-wide props just for this section.\n renderItem?: ?(info: {\n item: SectionItemT,\n index: number,\n section: SectionBase,\n separators: {\n highlight: () => void,\n unhighlight: () => void,\n updateProps: (select: 'leading' | 'trailing', newProps: Object) => void,\n ...\n },\n ...\n }) => null | React.Element,\n ItemSeparatorComponent?: ?React.ComponentType,\n keyExtractor?: (item: SectionItemT, index?: ?number) => string,\n ...\n};\n\ntype RequiredProps> = {|\n sections: $ReadOnlyArray,\n|};\n\ntype OptionalProps> = {|\n /**\n * Default renderer for every item in every section.\n */\n renderItem?: (info: {\n item: Item,\n index: number,\n section: SectionT,\n separators: {\n highlight: () => void,\n unhighlight: () => void,\n updateProps: (select: 'leading' | 'trailing', newProps: Object) => void,\n ...\n },\n ...\n }) => null | React.Element,\n /**\n * Rendered at the top of each section. These stick to the top of the `ScrollView` by default on\n * iOS. See `stickySectionHeadersEnabled`.\n */\n renderSectionHeader?: ?(info: {\n section: SectionT,\n ...\n }) => null | React.Element,\n /**\n * Rendered at the bottom of each section.\n */\n renderSectionFooter?: ?(info: {\n section: SectionT,\n ...\n }) => null | React.Element,\n /**\n * Rendered at the top and bottom of each section (note this is different from\n * `ItemSeparatorComponent` which is only rendered between items). These are intended to separate\n * sections from the headers above and below and typically have the same highlight response as\n * `ItemSeparatorComponent`. Also receives `highlighted`, `[leading/trailing][Item/Separator]`,\n * and any custom props from `separators.updateProps`.\n */\n SectionSeparatorComponent?: ?React.ComponentType,\n /**\n * Makes section headers stick to the top of the screen until the next one pushes it off. Only\n * enabled by default on iOS because that is the platform standard there.\n */\n stickySectionHeadersEnabled?: boolean,\n onEndReached?: ?({distanceFromEnd: number, ...}) => void,\n|};\n\ntype VirtualizedListProps = React.ElementConfig;\n\nexport type Props = {|\n ...RequiredProps,\n ...OptionalProps,\n ...$Diff<\n VirtualizedListProps,\n {\n renderItem: $PropertyType,\n data: $PropertyType,\n ...\n },\n >,\n|};\nexport type ScrollToLocationParamsType = {|\n animated?: ?boolean,\n itemIndex: number,\n sectionIndex: number,\n viewOffset?: number,\n viewPosition?: number,\n|};\n\ntype State = {childProps: VirtualizedListProps, ...};\n\n/**\n * Right now this just flattens everything into one list and uses VirtualizedList under the\n * hood. The only operation that might not scale well is concatting the data arrays of all the\n * sections when new props are received, which should be plenty fast for up to ~10,000 items.\n */\nclass VirtualizedSectionList<\n SectionT: SectionBase,\n> extends React.PureComponent, State> {\n scrollToLocation(params: ScrollToLocationParamsType) {\n let index = params.itemIndex;\n for (let i = 0; i < params.sectionIndex; i++) {\n index += this.props.getItemCount(this.props.sections[i].data) + 2;\n }\n let viewOffset = params.viewOffset || 0;\n if (this._listRef == null) {\n return;\n }\n if (params.itemIndex > 0 && this.props.stickySectionHeadersEnabled) {\n const frame = this._listRef.__getFrameMetricsApprox(\n index - params.itemIndex,\n this._listRef.props,\n );\n viewOffset += frame.length;\n }\n const toIndexParams = {\n ...params,\n viewOffset,\n index,\n };\n // $FlowFixMe[incompatible-use]\n this._listRef.scrollToIndex(toIndexParams);\n }\n\n getListRef(): ?React.ElementRef {\n return this._listRef;\n }\n\n render(): React.Node {\n const {\n ItemSeparatorComponent, // don't pass through, rendered with renderItem\n SectionSeparatorComponent,\n renderItem: _renderItem,\n renderSectionFooter,\n renderSectionHeader,\n sections: _sections,\n stickySectionHeadersEnabled,\n ...passThroughProps\n } = this.props;\n\n const listHeaderOffset = this.props.ListHeaderComponent ? 1 : 0;\n\n const stickyHeaderIndices = this.props.stickySectionHeadersEnabled\n ? ([]: Array)\n : undefined;\n\n let itemCount = 0;\n for (const section of this.props.sections) {\n // Track the section header indices\n if (stickyHeaderIndices != null) {\n stickyHeaderIndices.push(itemCount + listHeaderOffset);\n }\n\n // Add two for the section header and footer.\n itemCount += 2;\n itemCount += this.props.getItemCount(section.data);\n }\n const renderItem = this._renderItem(itemCount);\n\n return (\n \n this._getItem(this.props, sections, index)\n }\n getItemCount={() => itemCount}\n onViewableItemsChanged={\n this.props.onViewableItemsChanged\n ? this._onViewableItemsChanged\n : undefined\n }\n ref={this._captureRef}\n />\n );\n }\n\n _getItem(\n props: Props,\n sections: ?$ReadOnlyArray,\n index: number,\n ): ?Item {\n if (!sections) {\n return null;\n }\n let itemIdx = index - 1;\n for (let i = 0; i < sections.length; i++) {\n const section = sections[i];\n const sectionData = section.data;\n const itemCount = props.getItemCount(sectionData);\n if (itemIdx === -1 || itemIdx === itemCount) {\n // We intend for there to be overflow by one on both ends of the list.\n // This will be for headers and footers. When returning a header or footer\n // item the section itself is the item.\n return section;\n } else if (itemIdx < itemCount) {\n // If we are in the bounds of the list's data then return the item.\n return props.getItem(sectionData, itemIdx);\n } else {\n itemIdx -= itemCount + 2; // Add two for the header and footer\n }\n }\n return null;\n }\n\n // $FlowFixMe[missing-local-annot]\n _keyExtractor = (item: Item, index: number) => {\n const info = this._subExtractor(index);\n return (info && info.key) || String(index);\n };\n\n _subExtractor(index: number): ?{\n section: SectionT,\n // Key of the section or combined key for section + item\n key: string,\n // Relative index within the section\n index: ?number,\n // True if this is the section header\n header?: ?boolean,\n leadingItem?: ?Item,\n leadingSection?: ?SectionT,\n trailingItem?: ?Item,\n trailingSection?: ?SectionT,\n ...\n } {\n let itemIndex = index;\n const {getItem, getItemCount, keyExtractor, sections} = this.props;\n for (let i = 0; i < sections.length; i++) {\n const section = sections[i];\n const sectionData = section.data;\n const key = section.key || String(i);\n itemIndex -= 1; // The section adds an item for the header\n if (itemIndex >= getItemCount(sectionData) + 1) {\n itemIndex -= getItemCount(sectionData) + 1; // The section adds an item for the footer.\n } else if (itemIndex === -1) {\n return {\n section,\n key: key + ':header',\n index: null,\n header: true,\n trailingSection: sections[i + 1],\n };\n } else if (itemIndex === getItemCount(sectionData)) {\n return {\n section,\n key: key + ':footer',\n index: null,\n header: false,\n trailingSection: sections[i + 1],\n };\n } else {\n const extractor =\n section.keyExtractor || keyExtractor || defaultKeyExtractor;\n return {\n section,\n key:\n key + ':' + extractor(getItem(sectionData, itemIndex), itemIndex),\n index: itemIndex,\n leadingItem: getItem(sectionData, itemIndex - 1),\n leadingSection: sections[i - 1],\n trailingItem: getItem(sectionData, itemIndex + 1),\n trailingSection: sections[i + 1],\n };\n }\n }\n }\n\n _convertViewable = (viewable: ViewToken): ?ViewToken => {\n invariant(viewable.index != null, 'Received a broken ViewToken');\n const info = this._subExtractor(viewable.index);\n if (!info) {\n return null;\n }\n const keyExtractorWithNullableIndex = info.section.keyExtractor;\n const keyExtractorWithNonNullableIndex =\n this.props.keyExtractor || defaultKeyExtractor;\n const key =\n keyExtractorWithNullableIndex != null\n ? keyExtractorWithNullableIndex(viewable.item, info.index)\n : keyExtractorWithNonNullableIndex(viewable.item, info.index ?? 0);\n\n return {\n ...viewable,\n index: info.index,\n key,\n section: info.section,\n };\n };\n\n _onViewableItemsChanged = ({\n viewableItems,\n changed,\n }: {\n viewableItems: Array,\n changed: Array,\n ...\n }) => {\n const onViewableItemsChanged = this.props.onViewableItemsChanged;\n if (onViewableItemsChanged != null) {\n onViewableItemsChanged({\n viewableItems: viewableItems\n .map(this._convertViewable, this)\n .filter(Boolean),\n changed: changed.map(this._convertViewable, this).filter(Boolean),\n });\n }\n };\n\n _renderItem =\n (listItemCount: number): $FlowFixMe =>\n // eslint-disable-next-line react/no-unstable-nested-components\n ({item, index}: {item: Item, index: number, ...}) => {\n const info = this._subExtractor(index);\n if (!info) {\n return null;\n }\n const infoIndex = info.index;\n if (infoIndex == null) {\n const {section} = info;\n if (info.header === true) {\n const {renderSectionHeader} = this.props;\n return renderSectionHeader ? renderSectionHeader({section}) : null;\n } else {\n const {renderSectionFooter} = this.props;\n return renderSectionFooter ? renderSectionFooter({section}) : null;\n }\n } else {\n const renderItem = info.section.renderItem || this.props.renderItem;\n const SeparatorComponent = this._getSeparatorComponent(\n index,\n info,\n listItemCount,\n );\n invariant(renderItem, 'no renderItem!');\n return (\n \n );\n }\n };\n\n _updatePropsFor = (cellKey: string, value: any) => {\n const updateProps = this._updatePropsMap[cellKey];\n if (updateProps != null) {\n updateProps(value);\n }\n };\n\n _updateHighlightFor = (cellKey: string, value: boolean) => {\n const updateHighlight = this._updateHighlightMap[cellKey];\n if (updateHighlight != null) {\n updateHighlight(value);\n }\n };\n\n _setUpdateHighlightFor = (\n cellKey: string,\n updateHighlightFn: ?(boolean) => void,\n ) => {\n if (updateHighlightFn != null) {\n this._updateHighlightMap[cellKey] = updateHighlightFn;\n } else {\n delete this._updateHighlightFor[cellKey];\n }\n };\n\n _setUpdatePropsFor = (cellKey: string, updatePropsFn: ?(boolean) => void) => {\n if (updatePropsFn != null) {\n this._updatePropsMap[cellKey] = updatePropsFn;\n } else {\n delete this._updatePropsMap[cellKey];\n }\n };\n\n _getSeparatorComponent(\n index: number,\n info?: ?Object,\n listItemCount: number,\n ): ?React.ComponentType {\n info = info || this._subExtractor(index);\n if (!info) {\n return null;\n }\n const ItemSeparatorComponent =\n info.section.ItemSeparatorComponent || this.props.ItemSeparatorComponent;\n const {SectionSeparatorComponent} = this.props;\n const isLastItemInList = index === listItemCount - 1;\n const isLastItemInSection =\n info.index === this.props.getItemCount(info.section.data) - 1;\n if (SectionSeparatorComponent && isLastItemInSection) {\n return SectionSeparatorComponent;\n }\n if (ItemSeparatorComponent && !isLastItemInSection && !isLastItemInList) {\n return ItemSeparatorComponent;\n }\n return null;\n }\n\n _updateHighlightMap: {[string]: (boolean) => void} = {};\n _updatePropsMap: {[string]: void | (boolean => void)} = {};\n _listRef: ?React.ElementRef;\n _captureRef = (ref: null | React$ElementRef>) => {\n this._listRef = ref;\n };\n}\n\ntype ItemWithSeparatorCommonProps = $ReadOnly<{|\n leadingItem: ?Item,\n leadingSection: ?Object,\n section: Object,\n trailingItem: ?Item,\n trailingSection: ?Object,\n|}>;\n\ntype ItemWithSeparatorProps = $ReadOnly<{|\n ...ItemWithSeparatorCommonProps,\n LeadingSeparatorComponent: ?React.ComponentType,\n SeparatorComponent: ?React.ComponentType,\n cellKey: string,\n index: number,\n item: Item,\n setSelfHighlightCallback: (\n cellKey: string,\n updateFn: ?(boolean) => void,\n ) => void,\n setSelfUpdatePropsCallback: (\n cellKey: string,\n updateFn: ?(boolean) => void,\n ) => void,\n prevCellKey?: ?string,\n updateHighlightFor: (prevCellKey: string, value: boolean) => void,\n updatePropsFor: (prevCellKey: string, value: Object) => void,\n renderItem: Function,\n inverted: boolean,\n|}>;\n\nfunction ItemWithSeparator(props: ItemWithSeparatorProps): React.Node {\n const {\n LeadingSeparatorComponent,\n // this is the trailing separator and is associated with this item\n SeparatorComponent,\n cellKey,\n prevCellKey,\n setSelfHighlightCallback,\n updateHighlightFor,\n setSelfUpdatePropsCallback,\n updatePropsFor,\n item,\n index,\n section,\n inverted,\n } = props;\n\n const [leadingSeparatorHiglighted, setLeadingSeparatorHighlighted] =\n React.useState(false);\n\n const [separatorHighlighted, setSeparatorHighlighted] = React.useState(false);\n\n const [leadingSeparatorProps, setLeadingSeparatorProps] = React.useState({\n leadingItem: props.leadingItem,\n leadingSection: props.leadingSection,\n section: props.section,\n trailingItem: props.item,\n trailingSection: props.trailingSection,\n });\n const [separatorProps, setSeparatorProps] = React.useState({\n leadingItem: props.item,\n leadingSection: props.leadingSection,\n section: props.section,\n trailingItem: props.trailingItem,\n trailingSection: props.trailingSection,\n });\n\n React.useEffect(() => {\n setSelfHighlightCallback(cellKey, setSeparatorHighlighted);\n setSelfUpdatePropsCallback(cellKey, setSeparatorProps);\n\n return () => {\n setSelfUpdatePropsCallback(cellKey, null);\n setSelfHighlightCallback(cellKey, null);\n };\n }, [\n cellKey,\n setSelfHighlightCallback,\n setSeparatorProps,\n setSelfUpdatePropsCallback,\n ]);\n\n const separators = {\n highlight: () => {\n setLeadingSeparatorHighlighted(true);\n setSeparatorHighlighted(true);\n if (prevCellKey != null) {\n updateHighlightFor(prevCellKey, true);\n }\n },\n unhighlight: () => {\n setLeadingSeparatorHighlighted(false);\n setSeparatorHighlighted(false);\n if (prevCellKey != null) {\n updateHighlightFor(prevCellKey, false);\n }\n },\n updateProps: (\n select: 'leading' | 'trailing',\n newProps: $Shape,\n ) => {\n if (select === 'leading') {\n if (LeadingSeparatorComponent != null) {\n setLeadingSeparatorProps({...leadingSeparatorProps, ...newProps});\n } else if (prevCellKey != null) {\n // update the previous item's separator\n updatePropsFor(prevCellKey, {...leadingSeparatorProps, ...newProps});\n }\n } else if (select === 'trailing' && SeparatorComponent != null) {\n setSeparatorProps({...separatorProps, ...newProps});\n }\n },\n };\n const element = props.renderItem({\n item,\n index,\n section,\n separators,\n });\n const leadingSeparator = LeadingSeparatorComponent != null && (\n \n );\n const separator = SeparatorComponent != null && (\n \n );\n return leadingSeparator || separator ? (\n \n {inverted === false ? leadingSeparator : separator}\n {element}\n {inverted === false ? separator : leadingSeparator}\n \n ) : (\n element\n );\n}\n\n/* $FlowFixMe[class-object-subtyping] added when improving typing for this\n * parameters */\n// $FlowFixMe[method-unbinding]\nmodule.exports = (VirtualizedSectionList: React.AbstractComponent<\n React.ElementConfig,\n $ReadOnly<{\n getListRef: () => ?React.ElementRef,\n scrollToLocation: (params: ScrollToLocationParamsType) => void,\n ...\n }>,\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 * @flow strict-local\n * @format\n */\n\nimport type {AnimatedComponentType} from '../createAnimatedComponent';\n\nimport Text from '../../Text/Text';\nimport createAnimatedComponent from '../createAnimatedComponent';\nimport * as React from 'react';\n\nexport default (createAnimatedComponent(\n (Text: $FlowFixMe),\n): AnimatedComponentType<\n React.ElementConfig,\n React.ElementRef,\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 * @flow strict-local\n * @format\n */\n\nimport type {AnimatedComponentType} from '../createAnimatedComponent';\n\nimport View from '../../Components/View/View';\nimport createAnimatedComponent from '../createAnimatedComponent';\nimport * as React from 'react';\n\nexport default (createAnimatedComponent(View): AnimatedComponentType<\n React.ElementConfig,\n React.ElementRef,\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 * @format\n * @flow strict\n */\n\n'use strict';\n\nconst warnedKeys: {[string]: boolean, ...} = {};\n\n/**\n * A simple function that prints a warning message once per session.\n *\n * @param {string} key - The key used to ensure the message is printed once.\n * This should be unique to the callsite.\n * @param {string} message - The message to print\n */\nfunction warnOnce(key: string, message: string) {\n if (warnedKeys[key]) {\n return;\n }\n\n console.warn(message);\n\n warnedKeys[key] = true;\n}\n\nmodule.exports = warnOnce;\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 * @format\n * @flow strict-local\n */\n\n// This is a controlled component version of RCTDatePickerIOS.\n\nimport type {SyntheticEvent} from '../../Types/CoreEventTypes';\nimport type {ViewProps} from '../View/ViewPropTypes';\nimport type {DatePickerIOSType} from './DatePickerIOS.flow';\n\nimport StyleSheet from '../../StyleSheet/StyleSheet';\nimport View from '../View/View';\nimport RCTDatePickerNativeComponent, {\n Commands as DatePickerCommands,\n} from './RCTDatePickerNativeComponent';\nimport invariant from 'invariant';\nimport * as React from 'react';\n\ntype Event = SyntheticEvent<\n $ReadOnly<{|\n timestamp: number,\n |}>,\n>;\n\ntype Props = $ReadOnly<{|\n ...ViewProps,\n\n /**\n * The currently selected date.\n */\n date?: ?Date,\n\n /**\n * Provides an initial value that will change when the user starts selecting\n * a date. It is useful for simple use-cases where you do not want to deal\n * with listening to events and updating the date prop to keep the\n * controlled state in sync. The controlled state has known bugs which\n * causes it to go out of sync with native. The initialDate prop is intended\n * to allow you to have native be source of truth.\n */\n initialDate?: ?Date,\n\n /**\n * The date picker locale.\n */\n locale?: ?string,\n\n /**\n * Maximum date.\n *\n * Restricts the range of possible date/time values.\n */\n maximumDate?: ?Date,\n\n /**\n * Minimum date.\n *\n * Restricts the range of possible date/time values.\n */\n minimumDate?: ?Date,\n\n /**\n * The interval at which minutes can be selected.\n */\n minuteInterval?: ?(1 | 2 | 3 | 4 | 5 | 6 | 10 | 12 | 15 | 20 | 30),\n\n /**\n * The date picker mode.\n */\n mode?: ?('date' | 'time' | 'datetime'),\n\n /**\n * Date change handler.\n *\n * This is called when the user changes the date or time in the UI.\n * The first and only argument is an Event. For getting the date the picker\n * was changed to, use onDateChange instead.\n */\n onChange?: ?(event: Event) => void,\n\n /**\n * Date change handler.\n *\n * This is called when the user changes the date or time in the UI.\n * The first and only argument is a Date object representing the new\n * date and time.\n */\n onDateChange: (date: Date) => void,\n\n /**\n * Timezone offset in minutes.\n *\n * By default, the date picker will use the device's timezone. With this\n * parameter, it is possible to force a certain timezone offset. For\n * instance, to show times in Pacific Standard Time, pass -7 * 60.\n */\n timeZoneOffsetInMinutes?: ?number,\n\n /**\n * The date picker style\n * This is only available on devices with iOS 14.0 and later.\n * 'spinner' is the default style if this prop isn't set.\n */\n pickerStyle?: ?('compact' | 'spinner' | 'inline'),\n|}>;\n\n/**\n * Use `DatePickerIOS` to render a date/time picker (selector) on iOS. This is\n * a controlled component, so you must hook in to the `onDateChange` callback\n * and update the `date` prop in order for the component to update, otherwise\n * the user's change will be reverted immediately to reflect `props.date` as the\n * source of truth.\n */\nclass DatePickerIOS extends React.Component {\n _picker: ?React.ElementRef = null;\n\n componentDidUpdate() {\n if (this.props.date) {\n const propsTimeStamp = this.props.date.getTime();\n if (this._picker) {\n DatePickerCommands.setNativeDate(this._picker, propsTimeStamp);\n }\n }\n }\n\n _onChange = (event: Event) => {\n const nativeTimeStamp = event.nativeEvent.timestamp;\n this.props.onDateChange &&\n this.props.onDateChange(new Date(nativeTimeStamp));\n this.props.onChange && this.props.onChange(event);\n this.forceUpdate();\n };\n\n render(): React.Node {\n const props = this.props;\n const mode = props.mode ?? 'datetime';\n invariant(\n props.date || props.initialDate,\n 'A selected date or initial date should be specified.',\n );\n return (\n \n {\n this._picker = picker;\n }}\n style={getHeight(props.pickerStyle, mode)}\n date={\n props.date\n ? props.date.getTime()\n : props.initialDate\n ? props.initialDate.getTime()\n : undefined\n }\n locale={\n props.locale != null && props.locale !== ''\n ? props.locale\n : undefined\n }\n maximumDate={\n props.maximumDate ? props.maximumDate.getTime() : undefined\n }\n minimumDate={\n props.minimumDate ? props.minimumDate.getTime() : undefined\n }\n mode={mode}\n minuteInterval={props.minuteInterval}\n timeZoneOffsetInMinutes={props.timeZoneOffsetInMinutes}\n onChange={this._onChange}\n onStartShouldSetResponder={() => true}\n onResponderTerminationRequest={() => false}\n pickerStyle={props.pickerStyle}\n />\n \n );\n }\n}\n\nconst inlineHeightForDatePicker = 318.5;\nconst inlineHeightForTimePicker = 49.5;\nconst compactHeight = 40;\nconst spinnerHeight = 216;\n\nconst styles = StyleSheet.create({\n datePickerIOS: {\n height: spinnerHeight,\n },\n datePickerIOSCompact: {\n height: compactHeight,\n },\n datePickerIOSInline: {\n height: inlineHeightForDatePicker + inlineHeightForTimePicker * 2,\n },\n datePickerIOSInlineDate: {\n height: inlineHeightForDatePicker + inlineHeightForTimePicker,\n },\n datePickerIOSInlineTime: {\n height: inlineHeightForTimePicker,\n },\n});\n\nfunction getHeight(\n pickerStyle: ?(\n | 'compact'\n | 'inline'\n | 'spinner'\n | $TEMPORARY$string<'compact'>\n | $TEMPORARY$string<'inline'>\n | $TEMPORARY$string<'spinner'>\n ),\n mode:\n | 'date'\n | 'datetime'\n | 'time'\n | $TEMPORARY$string<'date'>\n | $TEMPORARY$string<'datetime'>\n | $TEMPORARY$string<'time'>,\n) {\n if (pickerStyle === 'compact') {\n return styles.datePickerIOSCompact;\n }\n if (pickerStyle === 'inline') {\n switch (mode) {\n case 'date':\n return styles.datePickerIOSInlineDate;\n case 'time':\n return styles.datePickerIOSInlineTime;\n default:\n return styles.datePickerIOSInline;\n }\n }\n return styles.datePickerIOS;\n}\n\nmodule.exports = (DatePickerIOS: DatePickerIOSType);\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 * @format\n * @flow strict-local\n */\n\nimport type {HostComponent} from '../../Renderer/shims/ReactNativeTypes';\nimport type {\n BubblingEventHandler,\n Float,\n WithDefault,\n} from '../../Types/CodegenTypes';\nimport type {ViewProps} from '../View/ViewPropTypes';\n\nimport codegenNativeCommands from '../../Utilities/codegenNativeCommands';\nimport codegenNativeComponent from '../../Utilities/codegenNativeComponent';\nimport * as React from 'react';\n\ntype Event = $ReadOnly<{|\n timestamp: Float,\n|}>;\n\ntype NativeProps = $ReadOnly<{|\n ...ViewProps,\n date?: ?Float,\n initialDate?: ?Float,\n locale?: ?string,\n maximumDate?: ?Float,\n minimumDate?: ?Float,\n minuteInterval?: WithDefault<\n 1 | 2 | 3 | 4 | 5 | 6 | 10 | 12 | 15 | 20 | 30,\n 1,\n >,\n mode?: WithDefault<'date' | 'time' | 'datetime', 'date'>,\n onChange?: ?BubblingEventHandler,\n timeZoneOffsetInMinutes?: ?Float,\n pickerStyle?: WithDefault<'compact' | 'spinner' | 'inline', 'spinner'>,\n|}>;\n\ntype ComponentType = HostComponent;\n\ninterface NativeCommands {\n +setNativeDate: (\n viewRef: React.ElementRef,\n date: Float,\n ) => void;\n}\n\nexport const Commands: NativeCommands = codegenNativeCommands({\n supportedCommands: ['setNativeDate'],\n});\n\nexport default (codegenNativeComponent('DatePicker', {\n paperComponentName: 'RCTDatePicker',\n excludedPlatforms: ['android'],\n}): HostComponent);\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 * @format\n */\n\n'use strict';\n\nmodule.exports = require('../UnimplementedViews/UnimplementedView');\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport type {ViewProps} from '../Components/View/ViewPropTypes';\nimport type {HostComponent} from '../Renderer/shims/ReactNativeTypes';\nimport type {ImageBackgroundProps} from './ImageProps';\n\nimport View from '../Components/View/View';\nimport flattenStyle from '../StyleSheet/flattenStyle';\nimport StyleSheet from '../StyleSheet/StyleSheet';\nimport Image from './Image';\nimport * as React from 'react';\n\n/**\n * Very simple drop-in replacement for which supports nesting views.\n *\n * ```ReactNativeWebPlayer\n * import React, { Component } from 'react';\n * import { AppRegistry, View, ImageBackground, Text } from 'react-native';\n *\n * class DisplayAnImageBackground extends Component {\n * render() {\n * return (\n * \n * React\n * \n * );\n * }\n * }\n *\n * // App registration and rendering\n * AppRegistry.registerComponent('DisplayAnImageBackground', () => DisplayAnImageBackground);\n * ```\n */\nclass ImageBackground extends React.Component {\n setNativeProps(props: Object) {\n // Work-around flow\n const viewRef = this._viewRef;\n if (viewRef) {\n viewRef.setNativeProps(props);\n }\n }\n\n _viewRef: ?React.ElementRef = null;\n\n _captureRef = (\n ref: null | React$ElementRef<\n React$AbstractComponent<\n ViewProps,\n React.ElementRef>,\n >,\n >,\n ) => {\n this._viewRef = ref;\n };\n\n render(): React.Node {\n const {\n children,\n style,\n imageStyle,\n imageRef,\n importantForAccessibility,\n ...props\n } = this.props;\n\n const flattenedStyle = flattenStyle(style);\n return (\n \n overwrites width and height styles\n // (which is not quite correct), and these styles conflict with explicitly set styles\n // of and with our internal layout model here.\n // So, we have to proxy/reapply these styles explicitly for actual component.\n // This workaround should be removed after implementing proper support of\n // intrinsic content size of the .\n width: flattenedStyle?.width,\n height: flattenedStyle?.height,\n },\n imageStyle,\n ]}\n ref={imageRef}\n />\n {children}\n \n );\n }\n}\n\nmodule.exports = ImageBackground;\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 * @flow\n * @format\n */\n\nimport StyleSheet, {\n type ColorValue,\n type ViewStyleProp,\n} from '../../StyleSheet/StyleSheet';\nimport Platform from '../../Utilities/Platform';\nimport RCTInputAccessoryViewNativeComponent from './RCTInputAccessoryViewNativeComponent';\nimport * as React from 'react';\n\n/**\n * Note: iOS only\n *\n * A component which enables customization of the keyboard input accessory view.\n * The input accessory view is displayed above the keyboard whenever a TextInput\n * has focus. This component can be used to create custom toolbars.\n *\n * To use this component wrap your custom toolbar with the\n * InputAccessoryView component, and set a nativeID. Then, pass that nativeID\n * as the inputAccessoryViewID of whatever TextInput you desire. A simple\n * example:\n *\n * ```ReactNativeWebPlayer\n * import React, { Component } from 'react';\n * import { AppRegistry, TextInput, InputAccessoryView, Button } from 'react-native';\n *\n * export default class UselessTextInput extends Component {\n * constructor(props) {\n * super(props);\n * this.state = {text: 'Placeholder Text'};\n * }\n *\n * render() {\n * const inputAccessoryViewID = \"uniqueID\";\n * return (\n * \n * \n * this.setState({text})}\n * value={this.state.text}\n * />\n * \n * \n * this.setState({text: 'Placeholder Text'})}\n * title=\"Reset Text\"\n * />\n * \n * \n * );\n * }\n * }\n *\n * // skip this line if using Create React Native App\n * AppRegistry.registerComponent('AwesomeProject', () => UselessTextInput);\n * ```\n *\n * This component can also be used to create sticky text inputs (text inputs\n * which are anchored to the top of the keyboard). To do this, wrap a\n * TextInput with the InputAccessoryView component, and don't set a nativeID.\n * For an example, look at InputAccessoryViewExample.js in RNTester.\n */\n\ntype Props = $ReadOnly<{|\n +children: React.Node,\n /**\n * An ID which is used to associate this `InputAccessoryView` to\n * specified TextInput(s).\n */\n nativeID?: ?string,\n style?: ?ViewStyleProp,\n backgroundColor?: ?ColorValue,\n|}>;\n\nclass InputAccessoryView extends React.Component {\n render(): React.Node {\n if (Platform.OS === 'ios') {\n if (React.Children.count(this.props.children) === 0) {\n return null;\n }\n\n return (\n \n {this.props.children}\n \n );\n } else {\n console.warn(' is only supported on iOS.');\n return null;\n }\n }\n}\n\nconst styles = StyleSheet.create({\n container: {\n position: 'absolute',\n },\n});\n\nmodule.exports = InputAccessoryView;\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 * @flow strict-local\n * @format\n */\n\nimport type {HostComponent} from '../../Renderer/shims/ReactNativeTypes';\nimport type {ColorValue} from '../../StyleSheet/StyleSheet';\nimport type {ViewProps} from '../View/ViewPropTypes';\n\nimport codegenNativeComponent from '../../Utilities/codegenNativeComponent';\n\ntype NativeProps = $ReadOnly<{|\n ...ViewProps,\n backgroundColor?: ?ColorValue,\n|}>;\n\nexport default (codegenNativeComponent('InputAccessory', {\n interfaceOnly: true,\n paperComponentName: 'RCTInputAccessoryView',\n excludedPlatforms: ['android'],\n}): HostComponent);\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 * @format\n * @flow strict-local\n */\n\nimport type {ViewStyleProp} from '../../StyleSheet/StyleSheet';\nimport type {\n ViewLayout,\n ViewLayoutEvent,\n ViewProps,\n} from '../View/ViewPropTypes';\nimport type {KeyboardEvent, KeyboardMetrics} from './Keyboard';\n\nimport LayoutAnimation from '../../LayoutAnimation/LayoutAnimation';\nimport StyleSheet from '../../StyleSheet/StyleSheet';\nimport Platform from '../../Utilities/Platform';\nimport {type EventSubscription} from '../../vendor/emitter/EventEmitter';\nimport AccessibilityInfo from '../AccessibilityInfo/AccessibilityInfo';\nimport View from '../View/View';\nimport Keyboard from './Keyboard';\nimport * as React from 'react';\n\ntype Props = $ReadOnly<{|\n ...ViewProps,\n\n /**\n * Specify how to react to the presence of the keyboard.\n */\n behavior?: ?('height' | 'position' | 'padding'),\n\n /**\n * Style of the content container when `behavior` is 'position'.\n */\n contentContainerStyle?: ?ViewStyleProp,\n\n /**\n * Controls whether this `KeyboardAvoidingView` instance should take effect.\n * This is useful when more than one is on the screen. Defaults to true.\n */\n enabled?: ?boolean,\n\n /**\n * Distance between the top of the user screen and the React Native view. This\n * may be non-zero in some cases. Defaults to 0.\n */\n keyboardVerticalOffset?: number,\n|}>;\n\ntype State = {|\n bottom: number,\n|};\n\n/**\n * View that moves out of the way when the keyboard appears by automatically\n * adjusting its height, position, or bottom padding.\n */\nclass KeyboardAvoidingView extends React.Component {\n _frame: ?ViewLayout = null;\n _keyboardEvent: ?KeyboardEvent = null;\n _subscriptions: Array = [];\n viewRef: {current: React.ElementRef | null, ...};\n _initialFrameHeight: number = 0;\n\n constructor(props: Props) {\n super(props);\n this.state = {bottom: 0};\n this.viewRef = React.createRef();\n }\n\n async _relativeKeyboardHeight(\n keyboardFrame: KeyboardMetrics,\n ): Promise {\n const frame = this._frame;\n if (!frame || !keyboardFrame) {\n return 0;\n }\n\n // On iOS when Prefer Cross-Fade Transitions is enabled, the keyboard position\n // & height is reported differently (0 instead of Y position value matching height of frame)\n if (\n Platform.OS === 'ios' &&\n keyboardFrame.screenY === 0 &&\n (await AccessibilityInfo.prefersCrossFadeTransitions())\n ) {\n return 0;\n }\n\n const keyboardY =\n keyboardFrame.screenY - (this.props.keyboardVerticalOffset ?? 0);\n\n if (this.props.behavior === 'height') {\n return Math.max(\n this.state.bottom + frame.y + frame.height - keyboardY,\n 0,\n );\n }\n\n // Calculate the displacement needed for the view such that it\n // no longer overlaps with the keyboard\n return Math.max(frame.y + frame.height - keyboardY, 0);\n }\n\n _onKeyboardChange = (event: ?KeyboardEvent) => {\n this._keyboardEvent = event;\n this._updateBottomIfNecessary();\n };\n\n _onLayout = async (event: ViewLayoutEvent) => {\n const wasFrameNull = this._frame == null;\n this._frame = event.nativeEvent.layout;\n if (!this._initialFrameHeight) {\n // save the initial frame height, before the keyboard is visible\n this._initialFrameHeight = this._frame.height;\n }\n\n if (wasFrameNull) {\n await this._updateBottomIfNecessary();\n }\n\n if (this.props.onLayout) {\n this.props.onLayout(event);\n }\n };\n\n _updateBottomIfNecessary = async () => {\n if (this._keyboardEvent == null) {\n this.setState({bottom: 0});\n return;\n }\n\n const {duration, easing, endCoordinates} = this._keyboardEvent;\n const height = await this._relativeKeyboardHeight(endCoordinates);\n\n if (this.state.bottom === height) {\n return;\n }\n\n if (duration && easing) {\n LayoutAnimation.configureNext({\n // We have to pass the duration equal to minimal accepted duration defined here: RCTLayoutAnimation.m\n duration: duration > 10 ? duration : 10,\n update: {\n duration: duration > 10 ? duration : 10,\n type: LayoutAnimation.Types[easing] || 'keyboard',\n },\n });\n }\n this.setState({bottom: height});\n };\n\n componentDidMount(): void {\n if (Platform.OS === 'ios') {\n this._subscriptions = [\n Keyboard.addListener('keyboardWillChangeFrame', this._onKeyboardChange),\n ];\n } else {\n this._subscriptions = [\n Keyboard.addListener('keyboardDidHide', this._onKeyboardChange),\n Keyboard.addListener('keyboardDidShow', this._onKeyboardChange),\n ];\n }\n }\n\n componentWillUnmount(): void {\n this._subscriptions.forEach(subscription => {\n subscription.remove();\n });\n }\n\n render(): React.Node {\n const {\n behavior,\n children,\n contentContainerStyle,\n enabled = true,\n // eslint-disable-next-line no-unused-vars\n keyboardVerticalOffset = 0,\n style,\n onLayout,\n ...props\n } = this.props;\n const bottomHeight = enabled === true ? this.state.bottom : 0;\n switch (behavior) {\n case 'height':\n let heightStyle;\n if (this._frame != null && this.state.bottom > 0) {\n // Note that we only apply a height change when there is keyboard present,\n // i.e. this.state.bottom is greater than 0. If we remove that condition,\n // this.frame.height will never go back to its original value.\n // When height changes, we need to disable flex.\n heightStyle = {\n height: this._initialFrameHeight - bottomHeight,\n flex: 0,\n };\n }\n return (\n \n {children}\n \n );\n\n case 'position':\n return (\n \n \n {children}\n \n \n );\n\n case 'padding':\n return (\n \n {children}\n \n );\n\n default:\n return (\n \n {children}\n \n );\n }\n }\n}\n\nexport default KeyboardAvoidingView;\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 * @format\n * @flow strict-local\n */\n\nimport type {ViewProps} from '../Components/View/ViewPropTypes';\nimport type {RootTag} from '../ReactNative/RootTag';\nimport type {DirectEventHandler} from '../Types/CodegenTypes';\n\nimport NativeEventEmitter from '../EventEmitter/NativeEventEmitter';\nimport {VirtualizedListContextResetter} from '../Lists/VirtualizedListContext.js';\nimport {type EventSubscription} from '../vendor/emitter/EventEmitter';\nimport ModalInjection from './ModalInjection';\nimport NativeModalManager from './NativeModalManager';\nimport RCTModalHostView from './RCTModalHostViewNativeComponent';\n\nconst ScrollView = require('../Components/ScrollView/ScrollView');\nconst View = require('../Components/View/View');\nconst AppContainer = require('../ReactNative/AppContainer');\nconst I18nManager = require('../ReactNative/I18nManager');\nconst {RootTagContext} = require('../ReactNative/RootTag');\nconst StyleSheet = require('../StyleSheet/StyleSheet');\nconst Platform = require('../Utilities/Platform');\nconst React = require('react');\n\ntype ModalEventDefinitions = {\n modalDismissed: [{modalID: number}],\n};\n\nconst ModalEventEmitter =\n Platform.OS === 'ios' && NativeModalManager != null\n ? new NativeEventEmitter(\n // T88715063: NativeEventEmitter only used this parameter on iOS. Now it uses it on all platforms, so this code was modified automatically to preserve its behavior\n // If you want to use the native module on other platforms, please remove this condition and test its behavior\n Platform.OS !== 'ios' ? null : NativeModalManager,\n )\n : null;\n\n/**\n * The Modal component is a simple way to present content above an enclosing view.\n *\n * See https://reactnative.dev/docs/modal\n */\n\n// In order to route onDismiss callbacks, we need to uniquely identifier each\n// on screen. There can be different ones, either nested or as siblings.\n// We cannot pass the onDismiss callback to native as the view will be\n// destroyed before the callback is fired.\nlet uniqueModalIdentifier = 0;\n\ntype OrientationChangeEvent = $ReadOnly<{|\n orientation: 'portrait' | 'landscape',\n|}>;\n\nexport type Props = $ReadOnly<{|\n ...ViewProps,\n\n /**\n * The `animationType` prop controls how the modal animates.\n *\n * See https://reactnative.dev/docs/modal#animationtype\n */\n animationType?: ?('none' | 'slide' | 'fade'),\n\n /**\n * The `presentationStyle` prop controls how the modal appears.\n *\n * See https://reactnative.dev/docs/modal#presentationstyle\n */\n presentationStyle?: ?(\n | 'fullScreen'\n | 'pageSheet'\n | 'formSheet'\n | 'overFullScreen'\n ),\n\n /**\n * The `transparent` prop determines whether your modal will fill the\n * entire view.\n *\n * See https://reactnative.dev/docs/modal#transparent\n */\n transparent?: ?boolean,\n\n /**\n * The `statusBarTranslucent` prop determines whether your modal should go under\n * the system statusbar.\n *\n * See https://reactnative.dev/docs/modal#transparent\n */\n statusBarTranslucent?: ?boolean,\n\n /**\n * The `hardwareAccelerated` prop controls whether to force hardware\n * acceleration for the underlying window.\n *\n * This prop works only on Android.\n *\n * See https://reactnative.dev/docs/modal#hardwareaccelerated\n */\n hardwareAccelerated?: ?boolean,\n\n /**\n * The `visible` prop determines whether your modal is visible.\n *\n * See https://reactnative.dev/docs/modal#visible\n */\n visible?: ?boolean,\n\n /**\n * The `onRequestClose` callback is called when the user taps the hardware\n * back button on Android or the menu button on Apple TV.\n *\n * This is required on Apple TV and Android.\n *\n * See https://reactnative.dev/docs/modal#onrequestclose\n */\n onRequestClose?: ?DirectEventHandler,\n\n /**\n * The `onShow` prop allows passing a function that will be called once the\n * modal has been shown.\n *\n * See https://reactnative.dev/docs/modal#onshow\n */\n onShow?: ?DirectEventHandler,\n\n /**\n * The `onDismiss` prop allows passing a function that will be called once\n * the modal has been dismissed.\n *\n * See https://reactnative.dev/docs/modal#ondismiss\n */\n onDismiss?: ?() => mixed,\n\n /**\n * The `supportedOrientations` prop allows the modal to be rotated to any of the specified orientations.\n *\n * See https://reactnative.dev/docs/modal#supportedorientations\n */\n supportedOrientations?: ?$ReadOnlyArray<\n | 'portrait'\n | 'portrait-upside-down'\n | 'landscape'\n | 'landscape-left'\n | 'landscape-right',\n >,\n\n /**\n * The `onOrientationChange` callback is called when the orientation changes while the modal is being displayed.\n *\n * See https://reactnative.dev/docs/modal#onorientationchange\n */\n onOrientationChange?: ?DirectEventHandler,\n|}>;\n\nfunction confirmProps(props: Props) {\n if (__DEV__) {\n if (\n props.presentationStyle &&\n props.presentationStyle !== 'overFullScreen' &&\n props.transparent === true\n ) {\n console.warn(\n `Modal with '${props.presentationStyle}' presentation style and 'transparent' value is not supported.`,\n );\n }\n }\n}\n\nclass Modal extends React.Component {\n static defaultProps: {|hardwareAccelerated: boolean, visible: boolean|} = {\n visible: true,\n hardwareAccelerated: false,\n };\n\n static contextType: React.Context = RootTagContext;\n\n _identifier: number;\n _eventSubscription: ?EventSubscription;\n\n constructor(props: Props) {\n super(props);\n if (__DEV__) {\n confirmProps(props);\n }\n this._identifier = uniqueModalIdentifier++;\n }\n\n componentDidMount() {\n // 'modalDismissed' is for the old renderer in iOS only\n if (ModalEventEmitter) {\n this._eventSubscription = ModalEventEmitter.addListener(\n 'modalDismissed',\n event => {\n if (event.modalID === this._identifier && this.props.onDismiss) {\n this.props.onDismiss();\n }\n },\n );\n }\n }\n\n componentWillUnmount() {\n if (this._eventSubscription) {\n this._eventSubscription.remove();\n }\n }\n\n componentDidUpdate() {\n if (__DEV__) {\n confirmProps(this.props);\n }\n }\n\n render(): React.Node {\n if (this.props.visible !== true) {\n return null;\n }\n\n const containerStyles = {\n backgroundColor:\n this.props.transparent === true ? 'transparent' : 'white',\n };\n\n let animationType = this.props.animationType || 'none';\n\n let presentationStyle = this.props.presentationStyle;\n if (!presentationStyle) {\n presentationStyle = 'fullScreen';\n if (this.props.transparent === true) {\n presentationStyle = 'overFullScreen';\n }\n }\n\n const innerChildren = __DEV__ ? (\n {this.props.children}\n ) : (\n this.props.children\n );\n\n return (\n {\n if (this.props.onDismiss) {\n this.props.onDismiss();\n }\n }}\n visible={this.props.visible}\n statusBarTranslucent={this.props.statusBarTranslucent}\n identifier={this._identifier}\n style={styles.modal}\n // $FlowFixMe[method-unbinding] added when improving typing for this parameters\n onStartShouldSetResponder={this._shouldSetResponder}\n supportedOrientations={this.props.supportedOrientations}\n onOrientationChange={this.props.onOrientationChange}\n testID={this.props.testID}>\n \n \n \n {innerChildren}\n \n \n \n \n );\n }\n\n // We don't want any responder events bubbling out of the modal.\n _shouldSetResponder(): boolean {\n return true;\n }\n}\n\nconst side = I18nManager.getConstants().isRTL ? 'right' : 'left';\nconst styles = StyleSheet.create({\n modal: {\n position: 'absolute',\n },\n container: {\n /* $FlowFixMe[invalid-computed-prop] (>=0.111.0 site=react_native_fb) This\n * comment suppresses an error found when Flow v0.111 was deployed. To see\n * the error, delete this comment and run Flow. */\n [side]: 0,\n top: 0,\n flex: 1,\n },\n});\n\nconst ExportedModal: React.AbstractComponent<\n React.ElementConfig,\n> = ModalInjection.unstable_Modal ?? Modal;\n\nmodule.exports = ExportedModal;\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 * @flow strict-local\n * @format\n */\n\nimport typeof Modal from './Modal';\n\nexport default {\n unstable_Modal: (null: ?Modal),\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 * @flow strict\n * @format\n */\n\nimport type {TurboModule} from '../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../TurboModule/TurboModuleRegistry';\n\nexport interface Spec extends TurboModule {\n // RCTEventEmitter\n +addListener: (eventName: string) => void;\n +removeListeners: (count: number) => void;\n}\n\nexport default (TurboModuleRegistry.get('ModalManager'): ?Spec);\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 * @format\n * @flow strict-local\n */\n\nimport type {ViewProps} from '../Components/View/ViewPropTypes';\nimport type {HostComponent} from '../Renderer/shims/ReactNativeTypes';\nimport type {\n DirectEventHandler,\n Int32,\n WithDefault,\n} from '../Types/CodegenTypes';\n\nimport codegenNativeComponent from '../Utilities/codegenNativeComponent';\n\ntype OrientationChangeEvent = $ReadOnly<{|\n orientation: 'portrait' | 'landscape',\n|}>;\n\ntype NativeProps = $ReadOnly<{|\n ...ViewProps,\n\n /**\n * The `animationType` prop controls how the modal animates.\n *\n * See https://reactnative.dev/docs/modal#animationtype\n */\n animationType?: WithDefault<'none' | 'slide' | 'fade', 'none'>,\n\n /**\n * The `presentationStyle` prop controls how the modal appears.\n *\n * See https://reactnative.dev/docs/modal#presentationstyle\n */\n presentationStyle?: WithDefault<\n 'fullScreen' | 'pageSheet' | 'formSheet' | 'overFullScreen',\n 'fullScreen',\n >,\n\n /**\n * The `transparent` prop determines whether your modal will fill the\n * entire view.\n *\n * See https://reactnative.dev/docs/modal#transparent\n */\n transparent?: WithDefault,\n\n /**\n * The `statusBarTranslucent` prop determines whether your modal should go under\n * the system statusbar.\n *\n * See https://reactnative.dev/docs/modal#statusBarTranslucent\n */\n statusBarTranslucent?: WithDefault,\n\n /**\n * The `hardwareAccelerated` prop controls whether to force hardware\n * acceleration for the underlying window.\n *\n * See https://reactnative.dev/docs/modal#hardwareaccelerated\n */\n hardwareAccelerated?: WithDefault,\n\n /**\n * The `onRequestClose` callback is called when the user taps the hardware\n * back button on Android or the menu button on Apple TV.\n *\n * This is required on Apple TV and Android.\n *\n * See https://reactnative.dev/docs/modal#onrequestclose\n */\n onRequestClose?: ?DirectEventHandler,\n\n /**\n * The `onShow` prop allows passing a function that will be called once the\n * modal has been shown.\n *\n * See https://reactnative.dev/docs/modal#onshow\n */\n onShow?: ?DirectEventHandler,\n\n /**\n * The `onDismiss` prop allows passing a function that will be called once\n * the modal has been dismissed.\n *\n * See https://reactnative.dev/docs/modal#ondismiss\n */\n onDismiss?: ?DirectEventHandler,\n\n /**\n * The `visible` prop determines whether your modal is visible.\n *\n * See https://reactnative.dev/docs/modal#visible\n */\n visible?: WithDefault,\n\n /**\n * Deprecated. Use the `animationType` prop instead.\n */\n animated?: WithDefault,\n\n /**\n * The `supportedOrientations` prop allows the modal to be rotated to any of the specified orientations.\n *\n * See https://reactnative.dev/docs/modal#supportedorientations\n */\n supportedOrientations?: WithDefault<\n $ReadOnlyArray<\n | 'portrait'\n | 'portrait-upside-down'\n | 'landscape'\n | 'landscape-left'\n | 'landscape-right',\n >,\n 'portrait',\n >,\n\n /**\n * The `onOrientationChange` callback is called when the orientation changes while the modal is being displayed.\n *\n * See https://reactnative.dev/docs/modal#onorientationchange\n */\n onOrientationChange?: ?DirectEventHandler,\n\n /**\n * The `identifier` is the unique number for identifying Modal components.\n */\n identifier?: WithDefault,\n|}>;\n\nexport default (codegenNativeComponent('ModalHostView', {\n interfaceOnly: true,\n paperComponentName: 'RCTModalHostView',\n}): HostComponent);\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 * @flow strict-local\n * @format\n */\n\nimport NativeI18nManager from './NativeI18nManager';\n\nconst i18nConstants: {|\n doLeftAndRightSwapInRTL: boolean,\n isRTL: boolean,\n localeIdentifier?: ?string,\n|} = getI18nManagerConstants();\n\nfunction getI18nManagerConstants() {\n if (NativeI18nManager) {\n const {isRTL, doLeftAndRightSwapInRTL, localeIdentifier} =\n NativeI18nManager.getConstants();\n return {isRTL, doLeftAndRightSwapInRTL, localeIdentifier};\n }\n\n return {\n isRTL: false,\n doLeftAndRightSwapInRTL: true,\n };\n}\n\nmodule.exports = {\n getConstants: (): {|\n doLeftAndRightSwapInRTL: boolean,\n isRTL: boolean,\n localeIdentifier: ?string,\n |} => {\n return i18nConstants;\n },\n\n allowRTL: (shouldAllow: boolean) => {\n if (!NativeI18nManager) {\n return;\n }\n\n NativeI18nManager.allowRTL(shouldAllow);\n },\n\n forceRTL: (shouldForce: boolean) => {\n if (!NativeI18nManager) {\n return;\n }\n\n NativeI18nManager.forceRTL(shouldForce);\n },\n\n swapLeftAndRightInRTL: (flipStyles: boolean) => {\n if (!NativeI18nManager) {\n return;\n }\n\n NativeI18nManager.swapLeftAndRightInRTL(flipStyles);\n },\n\n isRTL: i18nConstants.isRTL,\n doLeftAndRightSwapInRTL: i18nConstants.doLeftAndRightSwapInRTL,\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 * @flow strict\n * @format\n */\n\nimport type {TurboModule} from '../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../TurboModule/TurboModuleRegistry';\n\nexport interface Spec extends TurboModule {\n +getConstants: () => {|\n isRTL: boolean,\n doLeftAndRightSwapInRTL: boolean,\n localeIdentifier: ?string,\n |};\n allowRTL: (allowRTL: boolean) => void;\n forceRTL: (forceRTL: boolean) => void;\n swapLeftAndRightInRTL: (flipStyles: boolean) => void;\n}\n\nexport default (TurboModuleRegistry.get('I18nManager'): ?Spec);\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 * @flow strict-local\n * @format\n */\n\nimport type {\n LayoutEvent,\n MouseEvent,\n PressEvent,\n} from '../../Types/CoreEventTypes';\nimport type {\n AccessibilityActionEvent,\n AccessibilityActionInfo,\n AccessibilityRole,\n AccessibilityState,\n AccessibilityValue,\n} from '../View/ViewAccessibility';\n\nimport {PressabilityDebugView} from '../../Pressability/PressabilityDebug';\nimport usePressability from '../../Pressability/usePressability';\nimport {type RectOrSize} from '../../StyleSheet/Rect';\nimport View from '../View/View';\nimport useAndroidRippleForView, {\n type RippleConfig,\n} from './useAndroidRippleForView';\nimport * as React from 'react';\nimport {useImperativeHandle, useMemo, useRef, useState} from 'react';\n\ntype ViewStyleProp = $ElementType, 'style'>;\n\nexport type StateCallbackType = $ReadOnly<{|\n pressed: boolean,\n|}>;\n\ntype Props = $ReadOnly<{|\n /**\n * Accessibility.\n */\n accessibilityActions?: ?$ReadOnlyArray,\n accessibilityElementsHidden?: ?boolean,\n accessibilityHint?: ?Stringish,\n accessibilityLanguage?: ?Stringish,\n accessibilityIgnoresInvertColors?: ?boolean,\n accessibilityLabel?: ?Stringish,\n accessibilityLiveRegion?: ?('none' | 'polite' | 'assertive'),\n accessibilityRole?: ?AccessibilityRole,\n accessibilityState?: ?AccessibilityState,\n accessibilityValue?: ?AccessibilityValue,\n 'aria-valuemax'?: AccessibilityValue['max'],\n 'aria-valuemin'?: AccessibilityValue['min'],\n 'aria-valuenow'?: AccessibilityValue['now'],\n 'aria-valuetext'?: AccessibilityValue['text'],\n accessibilityViewIsModal?: ?boolean,\n 'aria-modal'?: ?boolean,\n accessible?: ?boolean,\n\n /**\n * alias for accessibilityState\n *\n * see https://reactnative.dev/docs/accessibility#accessibilitystate\n */\n 'aria-busy'?: ?boolean,\n 'aria-checked'?: ?boolean | 'mixed',\n 'aria-disabled'?: ?boolean,\n 'aria-expanded'?: ?boolean,\n 'aria-selected'?: ?boolean,\n /**\n * A value indicating whether the accessibility elements contained within\n * this accessibility element are hidden.\n */\n 'aria-hidden'?: ?boolean,\n 'aria-live'?: ?('polite' | 'assertive' | 'off'),\n focusable?: ?boolean,\n importantForAccessibility?: ?('auto' | 'yes' | 'no' | 'no-hide-descendants'),\n onAccessibilityAction?: ?(event: AccessibilityActionEvent) => mixed,\n\n /**\n * Whether a press gesture can be interrupted by a parent gesture such as a\n * scroll event. Defaults to true.\n */\n cancelable?: ?boolean,\n\n /**\n * Either children or a render prop that receives a boolean reflecting whether\n * the component is currently pressed.\n */\n children: React.Node | ((state: StateCallbackType) => React.Node),\n\n /**\n * Duration to wait after hover in before calling `onHoverIn`.\n */\n delayHoverIn?: ?number,\n\n /**\n * Duration to wait after hover out before calling `onHoverOut`.\n */\n delayHoverOut?: ?number,\n\n /**\n * Duration (in milliseconds) from `onPressIn` before `onLongPress` is called.\n */\n delayLongPress?: ?number,\n\n /**\n * Whether the press behavior is disabled.\n */\n disabled?: ?boolean,\n\n /**\n * Additional distance outside of this view in which a press is detected.\n */\n hitSlop?: ?RectOrSize,\n\n /**\n * Additional distance outside of this view in which a touch is considered a\n * press before `onPressOut` is triggered.\n */\n pressRetentionOffset?: ?RectOrSize,\n\n /**\n * Called when this view's layout changes.\n */\n onLayout?: ?(event: LayoutEvent) => mixed,\n\n /**\n * Called when the hover is activated to provide visual feedback.\n */\n onHoverIn?: ?(event: MouseEvent) => mixed,\n\n /**\n * Called when the hover is deactivated to undo visual feedback.\n */\n onHoverOut?: ?(event: MouseEvent) => mixed,\n\n /**\n * Called when a long-tap gesture is detected.\n */\n onLongPress?: ?(event: PressEvent) => mixed,\n\n /**\n * Called when a single tap gesture is detected.\n */\n onPress?: ?(event: PressEvent) => mixed,\n\n /**\n * Called when a touch is engaged before `onPress`.\n */\n onPressIn?: ?(event: PressEvent) => mixed,\n\n /**\n * Called when a touch is released before `onPress`.\n */\n onPressOut?: ?(event: PressEvent) => mixed,\n\n /**\n * Either view styles or a function that receives a boolean reflecting whether\n * the component is currently pressed and returns view styles.\n */\n style?: ViewStyleProp | ((state: StateCallbackType) => ViewStyleProp),\n\n /**\n * Identifier used to find this view in tests.\n */\n testID?: ?string,\n\n /**\n * If true, doesn't play system sound on touch.\n */\n android_disableSound?: ?boolean,\n\n /**\n * Enables the Android ripple effect and configures its color.\n */\n android_ripple?: ?RippleConfig,\n\n /**\n * Used only for documentation or testing (e.g. snapshot testing).\n */\n testOnly_pressed?: ?boolean,\n\n /**\n * Duration to wait after press down before calling `onPressIn`.\n */\n unstable_pressDelay?: ?number,\n /**\n * Web to Native Accessibilty props\n * https://github.com/facebook/react-native/issues/34424\n */\n 'aria-label'?: ?string,\n|}>;\n\n/**\n * Component used to build display components that should respond to whether the\n * component is currently pressed or not.\n */\n/* $FlowFixMe[missing-local-annot] The type annotation(s) required by Flow's\n * LTI update could not be added via codemod */\nfunction Pressable(props: Props, forwardedRef): React.Node {\n const {\n accessible,\n accessibilityState,\n 'aria-live': ariaLive,\n android_disableSound,\n android_ripple,\n 'aria-busy': ariaBusy,\n 'aria-checked': ariaChecked,\n 'aria-disabled': ariaDisabled,\n 'aria-expanded': ariaExpanded,\n 'aria-label': ariaLabel,\n 'aria-selected': ariaSelected,\n cancelable,\n children,\n delayHoverIn,\n delayHoverOut,\n delayLongPress,\n disabled,\n focusable,\n hitSlop,\n onHoverIn,\n onHoverOut,\n onLongPress,\n onPress,\n onPressIn,\n onPressOut,\n pressRetentionOffset,\n style,\n testOnly_pressed,\n unstable_pressDelay,\n ...restProps\n } = props;\n\n const viewRef = useRef | null>(null);\n useImperativeHandle(forwardedRef, () => viewRef.current);\n\n const android_rippleConfig = useAndroidRippleForView(android_ripple, viewRef);\n\n const [pressed, setPressed] = usePressState(testOnly_pressed === true);\n\n let _accessibilityState = {\n busy: ariaBusy ?? accessibilityState?.busy,\n checked: ariaChecked ?? accessibilityState?.checked,\n disabled: ariaDisabled ?? accessibilityState?.disabled,\n expanded: ariaExpanded ?? accessibilityState?.expanded,\n selected: ariaSelected ?? accessibilityState?.selected,\n };\n\n _accessibilityState =\n disabled != null ? {..._accessibilityState, disabled} : _accessibilityState;\n\n const accessibilityValue = {\n max: props['aria-valuemax'] ?? props.accessibilityValue?.max,\n min: props['aria-valuemin'] ?? props.accessibilityValue?.min,\n now: props['aria-valuenow'] ?? props.accessibilityValue?.now,\n text: props['aria-valuetext'] ?? props.accessibilityValue?.text,\n };\n\n const accessibilityLiveRegion =\n ariaLive === 'off' ? 'none' : ariaLive ?? props.accessibilityLiveRegion;\n\n const accessibilityLabel = ariaLabel ?? props.accessibilityLabel;\n const restPropsWithDefaults: React.ElementConfig = {\n ...restProps,\n ...android_rippleConfig?.viewProps,\n accessible: accessible !== false,\n accessibilityViewIsModal:\n restProps['aria-modal'] ?? restProps.accessibilityViewIsModal,\n accessibilityLiveRegion,\n accessibilityLabel,\n accessibilityState: _accessibilityState,\n focusable: focusable !== false,\n accessibilityValue,\n hitSlop,\n };\n\n const config = useMemo(\n () => ({\n cancelable,\n disabled,\n hitSlop,\n pressRectOffset: pressRetentionOffset,\n android_disableSound,\n delayHoverIn,\n delayHoverOut,\n delayLongPress,\n delayPressIn: unstable_pressDelay,\n onHoverIn,\n onHoverOut,\n onLongPress,\n onPress,\n onPressIn(event: PressEvent): void {\n if (android_rippleConfig != null) {\n android_rippleConfig.onPressIn(event);\n }\n setPressed(true);\n if (onPressIn != null) {\n onPressIn(event);\n }\n },\n onPressMove: android_rippleConfig?.onPressMove,\n onPressOut(event: PressEvent): void {\n if (android_rippleConfig != null) {\n android_rippleConfig.onPressOut(event);\n }\n setPressed(false);\n if (onPressOut != null) {\n onPressOut(event);\n }\n },\n }),\n [\n android_disableSound,\n android_rippleConfig,\n cancelable,\n delayHoverIn,\n delayHoverOut,\n delayLongPress,\n disabled,\n hitSlop,\n onHoverIn,\n onHoverOut,\n onLongPress,\n onPress,\n onPressIn,\n onPressOut,\n pressRetentionOffset,\n setPressed,\n unstable_pressDelay,\n ],\n );\n const eventHandlers = usePressability(config);\n\n return (\n \n {typeof children === 'function' ? children({pressed}) : children}\n {__DEV__ ? : null}\n \n );\n}\n\nfunction usePressState(forcePressed: boolean): [boolean, (boolean) => void] {\n const [pressed, setPressed] = useState(false);\n return [pressed || forcePressed, setPressed];\n}\n\nconst MemoedPressable = React.memo(React.forwardRef(Pressable));\nMemoedPressable.displayName = 'Pressable';\n\nexport default (MemoedPressable: React.AbstractComponent<\n Props,\n React.ElementRef,\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 * @flow strict-local\n * @format\n */\n\nimport type {ColorValue} from '../../StyleSheet/StyleSheet';\nimport type {PressEvent} from '../../Types/CoreEventTypes';\n\nimport processColor from '../../StyleSheet/processColor';\nimport Platform from '../../Utilities/Platform';\nimport View from '../View/View';\nimport {Commands} from '../View/ViewNativeComponent';\nimport invariant from 'invariant';\nimport * as React from 'react';\nimport {useMemo} from 'react';\n\ntype NativeBackgroundProp = $ReadOnly<{|\n type: 'RippleAndroid',\n color: ?number,\n borderless: boolean,\n rippleRadius: ?number,\n|}>;\n\nexport type RippleConfig = {|\n color?: ColorValue,\n borderless?: boolean,\n radius?: number,\n foreground?: boolean,\n|};\n\n/**\n * Provides the event handlers and props for configuring the ripple effect on\n * supported versions of Android.\n */\nexport default function useAndroidRippleForView(\n rippleConfig: ?RippleConfig,\n viewRef: {|current: null | React.ElementRef|},\n): ?$ReadOnly<{|\n onPressIn: (event: PressEvent) => void,\n onPressMove: (event: PressEvent) => void,\n onPressOut: (event: PressEvent) => void,\n viewProps:\n | $ReadOnly<{|nativeBackgroundAndroid: NativeBackgroundProp|}>\n | $ReadOnly<{|nativeForegroundAndroid: NativeBackgroundProp|}>,\n|}> {\n const {color, borderless, radius, foreground} = rippleConfig ?? {};\n\n return useMemo(() => {\n if (\n Platform.OS === 'android' &&\n Platform.Version >= 21 &&\n (color != null || borderless != null || radius != null)\n ) {\n const processedColor = processColor(color);\n invariant(\n processedColor == null || typeof processedColor === 'number',\n 'Unexpected color given for Ripple color',\n );\n\n const nativeRippleValue = {\n type: 'RippleAndroid',\n color: processedColor,\n borderless: borderless === true,\n rippleRadius: radius,\n };\n\n return {\n viewProps:\n foreground === true\n ? {nativeForegroundAndroid: nativeRippleValue}\n : {nativeBackgroundAndroid: nativeRippleValue},\n onPressIn(event: PressEvent): void {\n const view = viewRef.current;\n if (view != null) {\n Commands.hotspotUpdate(\n view,\n event.nativeEvent.locationX ?? 0,\n event.nativeEvent.locationY ?? 0,\n );\n Commands.setPressed(view, true);\n }\n },\n onPressMove(event: PressEvent): void {\n const view = viewRef.current;\n if (view != null) {\n Commands.hotspotUpdate(\n view,\n event.nativeEvent.locationX ?? 0,\n event.nativeEvent.locationY ?? 0,\n );\n }\n },\n onPressOut(event: PressEvent): void {\n const view = viewRef.current;\n if (view != null) {\n Commands.setPressed(view, false);\n }\n },\n };\n }\n return null;\n }, [borderless, color, foreground, radius, viewRef]);\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 * @format\n * @flow strict-local\n */\n\nimport type {ImageSource} from '../../Image/ImageSource';\nimport type {ViewProps} from '../View/ViewPropTypes';\n\nimport StyleSheet, {type ColorValue} from '../../StyleSheet/StyleSheet';\nimport RCTProgressViewNativeComponent from './RCTProgressViewNativeComponent';\nimport * as React from 'react';\n\ntype Props = $ReadOnly<{|\n ...ViewProps,\n\n /**\n * The progress bar style.\n */\n progressViewStyle?: ?('default' | 'bar'),\n\n /**\n * The progress value (between 0 and 1).\n */\n progress?: ?number,\n\n /**\n * The tint color of the progress bar itself.\n */\n progressTintColor?: ?ColorValue,\n\n /**\n * The tint color of the progress bar track.\n */\n trackTintColor?: ?ColorValue,\n\n /**\n * A stretchable image to display as the progress bar.\n */\n progressImage?: ?ImageSource,\n\n /**\n * A stretchable image to display behind the progress bar.\n */\n trackImage?: ?ImageSource,\n|}>;\n\n/**\n * Use `ProgressViewIOS` to render a UIProgressView on iOS.\n */\nconst ProgressViewIOS = (\n props: Props,\n forwardedRef?: ?React.Ref,\n) => (\n \n);\n\nconst styles = StyleSheet.create({\n progressView: {\n height: 2,\n },\n});\n\nconst ProgressViewIOSWithRef = React.forwardRef(ProgressViewIOS);\n\nmodule.exports =\n (ProgressViewIOSWithRef: typeof RCTProgressViewNativeComponent);\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 * @flow strict-local\n * @format\n */\n\nimport type {ImageSource} from '../../Image/ImageSource';\nimport type {HostComponent} from '../../Renderer/shims/ReactNativeTypes';\nimport type {ColorValue} from '../../StyleSheet/StyleSheet';\nimport type {Float, WithDefault} from '../../Types/CodegenTypes';\nimport type {ViewProps} from '../View/ViewPropTypes';\n\nimport codegenNativeComponent from '../../Utilities/codegenNativeComponent';\n\ntype NativeProps = $ReadOnly<{|\n ...ViewProps,\n\n // Props\n progressViewStyle?: WithDefault<'default' | 'bar', 'default'>,\n progress?: WithDefault,\n progressTintColor?: ?ColorValue,\n trackTintColor?: ?ColorValue,\n progressImage?: ?ImageSource,\n trackImage?: ?ImageSource,\n|}>;\n\nexport default (codegenNativeComponent(\n 'RCTProgressView',\n): HostComponent);\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 * @flow strict-local\n * @format\n */\n\nimport type {ViewProps} from '../View/ViewPropTypes';\nimport type {SafeAreaViewType} from './SafeAreaView.flow';\n\nimport Platform from '../../Utilities/Platform';\nimport View from '../View/View';\nimport * as React from 'react';\n\nlet exported: React.AbstractComponent>;\n\n/**\n * Renders nested content and automatically applies paddings reflect the portion\n * of the view that is not covered by navigation bars, tab bars, toolbars, and\n * other ancestor views.\n *\n * Moreover, and most importantly, Safe Area's paddings reflect physical\n * limitation of the screen, such as rounded corners or camera notches (aka\n * sensor housing area on iPhone X).\n */\nif (Platform.OS === 'android') {\n exported = View;\n} else {\n exported = require('./RCTSafeAreaViewNativeComponent').default;\n}\n\nexport default (exported: SafeAreaViewType);\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 * @format\n * @flow strict-local\n */\n\nimport type {HostComponent} from '../../Renderer/shims/ReactNativeTypes';\nimport type {ViewProps} from '../View/ViewPropTypes';\n\nimport codegenNativeComponent from '../../Utilities/codegenNativeComponent';\n\ntype NativeProps = $ReadOnly<{|\n ...ViewProps,\n\n // No props\n|}>;\n\nexport default (codegenNativeComponent('SafeAreaView', {\n paperComponentName: 'RCTSafeAreaView',\n interfaceOnly: true,\n}): HostComponent);\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 * @format\n * @flow strict-local\n */\n\nimport type {ImageSource} from '../../Image/ImageSource';\nimport type {SyntheticEvent} from '../../Types/CoreEventTypes';\nimport type {AccessibilityState} from '../View/ViewAccessibility';\nimport type {ViewProps} from '../View/ViewPropTypes';\n\nimport StyleSheet, {\n type ColorValue,\n type ViewStyleProp,\n} from '../../StyleSheet/StyleSheet';\nimport Platform from '../../Utilities/Platform';\nimport SliderNativeComponent from './SliderNativeComponent';\nimport * as React from 'react';\n\ntype Event = SyntheticEvent<\n $ReadOnly<{|\n value: number,\n /**\n * Android Only.\n */\n fromUser?: boolean,\n |}>,\n>;\n\ntype IOSProps = $ReadOnly<{|\n /**\n * Assigns a single image for the track. Only static images are supported.\n * The center pixel of the image will be stretched to fill the track.\n */\n trackImage?: ?ImageSource,\n\n /**\n * Assigns a minimum track image. Only static images are supported. The\n * rightmost pixel of the image will be stretched to fill the track.\n */\n minimumTrackImage?: ?ImageSource,\n\n /**\n * Assigns a maximum track image. Only static images are supported. The\n * leftmost pixel of the image will be stretched to fill the track.\n */\n maximumTrackImage?: ?ImageSource,\n\n /**\n * Sets an image for the thumb. Only static images are supported.\n */\n thumbImage?: ?ImageSource,\n|}>;\n\ntype Props = $ReadOnly<{|\n ...ViewProps,\n ...IOSProps,\n\n /**\n * Used to style and layout the `Slider`. See `StyleSheet.js` and\n * `DeprecatedViewStylePropTypes.js` for more info.\n */\n style?: ?ViewStyleProp,\n\n /**\n * Initial value of the slider. The value should be between minimumValue\n * and maximumValue, which default to 0 and 1 respectively.\n * Default value is 0.\n *\n * *This is not a controlled component*, you don't need to update the\n * value during dragging.\n */\n value?: ?number,\n\n /**\n * Step value of the slider. The value should be\n * between 0 and (maximumValue - minimumValue).\n * Default value is 0.\n */\n step?: ?number,\n\n /**\n * Initial minimum value of the slider. Default value is 0.\n */\n minimumValue?: ?number,\n\n /**\n * Initial maximum value of the slider. Default value is 1.\n */\n maximumValue?: ?number,\n\n /**\n * The color used for the track to the left of the button.\n * Overrides the default blue gradient image on iOS.\n */\n minimumTrackTintColor?: ?ColorValue,\n\n /**\n * The color used for the track to the right of the button.\n * Overrides the default blue gradient image on iOS.\n */\n maximumTrackTintColor?: ?ColorValue,\n /**\n * The color used to tint the default thumb images on iOS, or the\n * color of the foreground switch grip on Android.\n */\n thumbTintColor?: ?ColorValue,\n\n /**\n * If true the user won't be able to move the slider.\n * Default value is false.\n */\n disabled?: ?boolean,\n\n /**\n * Callback continuously called while the user is dragging the slider.\n */\n onValueChange?: ?(value: number) => void,\n\n /**\n * Callback that is called when the user releases the slider,\n * regardless if the value has changed. The current value is passed\n * as an argument to the callback handler.\n */\n onSlidingComplete?: ?(value: number) => void,\n\n /**\n * Used to locate this view in UI automation tests.\n */\n testID?: ?string,\n\n /**\n Indicates to accessibility services that UI Component is in a specific State.\n */\n accessibilityState?: ?AccessibilityState,\n|}>;\n\n/**\n * A component used to select a single value from a range of values.\n *\n * ### Usage\n *\n * The example below shows how to use `Slider` to change\n * a value used by `Text`. The value is stored using\n * the state of the root component (`App`). The same component\n * subscribes to the `onValueChange` of `Slider` and changes\n * the value using `setState`.\n *\n *```\n * import React from 'react';\n * import { StyleSheet, Text, View, Slider } from 'react-native';\n *\n * export default class App extends React.Component {\n * constructor(props) {\n * super(props);\n * this.state = {\n * value: 50\n * }\n * }\n *\n * change(value) {\n * this.setState(() => {\n * return {\n * value: parseFloat(value)\n * };\n * });\n * }\n *\n * render() {\n * const {value} = this.state;\n * return (\n * \n * {String(value)}\n * \n * \n * );\n * }\n * }\n *\n * const styles = StyleSheet.create({\n * container: {\n * flex: 1,\n * flexDirection: 'column',\n * justifyContent: 'center'\n * },\n * text: {\n * fontSize: 50,\n * textAlign: 'center'\n * }\n * });\n *```\n *\n */\nconst Slider = (\n props: Props,\n forwardedRef?: ?React.Ref,\n) => {\n const style = StyleSheet.compose(styles.slider, props.style);\n\n const {\n value = 0.5,\n minimumValue = 0,\n maximumValue = 1,\n step = 0,\n onValueChange,\n onSlidingComplete,\n ...localProps\n } = props;\n\n const onValueChangeEvent = onValueChange\n ? (event: Event) => {\n let userEvent = true;\n if (Platform.OS === 'android') {\n // On Android there's a special flag telling us the user is\n // dragging the slider.\n userEvent =\n event.nativeEvent.fromUser != null && event.nativeEvent.fromUser;\n }\n userEvent && onValueChange(event.nativeEvent.value);\n }\n : null;\n\n const onSlidingCompleteEvent = onSlidingComplete\n ? (event: Event) => {\n onSlidingComplete(event.nativeEvent.value);\n }\n : null;\n\n const disabled =\n props.disabled === true || props.accessibilityState?.disabled === true;\n const accessibilityState = disabled\n ? {...props.accessibilityState, disabled: true}\n : props.accessibilityState;\n\n return (\n false}\n onSlidingComplete={onSlidingCompleteEvent}\n onStartShouldSetResponder={() => true}\n onValueChange={onValueChangeEvent}\n ref={forwardedRef}\n step={step}\n style={style}\n value={value}\n />\n );\n};\n\nconst SliderWithRef: React.AbstractComponent<\n Props,\n React.ElementRef,\n> = React.forwardRef(Slider);\n\nlet styles;\nif (Platform.OS === 'ios') {\n styles = StyleSheet.create({\n slider: {\n height: 40,\n },\n });\n} else {\n styles = StyleSheet.create({\n slider: {},\n });\n}\n\nmodule.exports = SliderWithRef;\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 * @format\n * @flow strict-local\n */\n\nimport type {ImageSource} from '../../Image/ImageSource';\nimport type {HostComponent} from '../../Renderer/shims/ReactNativeTypes';\nimport type {ColorValue} from '../../StyleSheet/StyleSheet';\nimport type {\n BubblingEventHandler,\n DirectEventHandler,\n Double,\n WithDefault,\n} from '../../Types/CodegenTypes';\nimport type {ViewProps} from '../View/ViewPropTypes';\n\nimport codegenNativeComponent from '../../Utilities/codegenNativeComponent';\n\ntype Event = $ReadOnly<{|\n value: Double,\n fromUser?: boolean,\n|}>;\n\ntype NativeProps = $ReadOnly<{|\n ...ViewProps,\n\n // Props\n disabled?: WithDefault,\n enabled?: WithDefault,\n maximumTrackImage?: ?ImageSource,\n maximumTrackTintColor?: ?ColorValue,\n maximumValue?: WithDefault,\n minimumTrackImage?: ?ImageSource,\n minimumTrackTintColor?: ?ColorValue,\n minimumValue?: WithDefault,\n step?: WithDefault,\n testID?: WithDefault,\n thumbImage?: ?ImageSource,\n thumbTintColor?: ?ColorValue,\n trackImage?: ?ImageSource,\n value?: WithDefault,\n\n // Events\n onValueChange?: ?BubblingEventHandler,\n onSlidingComplete?: ?DirectEventHandler,\n|}>;\n\nexport default (codegenNativeComponent('Slider', {\n interfaceOnly: true,\n paperComponentName: 'RCTSlider',\n}): HostComponent);\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 * @format\n * @flow\n */\n\nimport type {ColorValue} from '../../StyleSheet/StyleSheet';\n\nimport processColor from '../../StyleSheet/processColor';\nimport Platform from '../../Utilities/Platform';\nimport NativeStatusBarManagerAndroid from './NativeStatusBarManagerAndroid';\nimport NativeStatusBarManagerIOS from './NativeStatusBarManagerIOS';\nimport invariant from 'invariant';\nimport * as React from 'react';\n\n/**\n * Status bar style\n */\nexport type StatusBarStyle = $Keys<{\n /**\n * Default status bar style (dark for iOS, light for Android)\n */\n default: string,\n /**\n * Dark background, white texts and icons\n */\n 'light-content': string,\n /**\n * Light background, dark texts and icons\n */\n 'dark-content': string,\n ...\n}>;\n\n/**\n * Status bar animation\n */\nexport type StatusBarAnimation = $Keys<{\n /**\n * No animation\n */\n none: string,\n /**\n * Fade animation\n */\n fade: string,\n /**\n * Slide animation\n */\n slide: string,\n ...\n}>;\n\ntype AndroidProps = $ReadOnly<{|\n /**\n * The background color of the status bar.\n * @platform android\n */\n backgroundColor?: ?ColorValue,\n /**\n * If the status bar is translucent.\n * When translucent is set to true, the app will draw under the status bar.\n * This is useful when using a semi transparent status bar color.\n *\n * @platform android\n */\n translucent?: ?boolean,\n|}>;\n\ntype IOSProps = $ReadOnly<{|\n /**\n * If the network activity indicator should be visible.\n *\n * @platform ios\n */\n networkActivityIndicatorVisible?: ?boolean,\n /**\n * The transition effect when showing and hiding the status bar using the `hidden`\n * prop. Defaults to 'fade'.\n *\n * @platform ios\n */\n showHideTransition?: ?('fade' | 'slide' | 'none'),\n|}>;\n\ntype Props = $ReadOnly<{|\n ...AndroidProps,\n ...IOSProps,\n /**\n * If the status bar is hidden.\n */\n hidden?: ?boolean,\n /**\n * If the transition between status bar property changes should be animated.\n * Supported for backgroundColor, barStyle and hidden.\n */\n animated?: ?boolean,\n /**\n * Sets the color of the status bar text.\n */\n barStyle?: ?('default' | 'light-content' | 'dark-content'),\n|}>;\n\n/**\n * Merges the prop stack with the default values.\n */\nfunction mergePropsStack(\n propsStack: Array,\n defaultValues: Object,\n): Object {\n return propsStack.reduce(\n (prev, cur) => {\n for (const prop in cur) {\n if (cur[prop] != null) {\n prev[prop] = cur[prop];\n }\n }\n return prev;\n },\n {...defaultValues},\n );\n}\n\n/**\n * Returns an object to insert in the props stack from the props\n * and the transition/animation info.\n */\nfunction createStackEntry(props: any): any {\n const animated = props.animated ?? false;\n const showHideTransition = props.showHideTransition ?? 'fade';\n return {\n backgroundColor:\n props.backgroundColor != null\n ? {\n value: props.backgroundColor,\n animated,\n }\n : null,\n barStyle:\n props.barStyle != null\n ? {\n value: props.barStyle,\n animated,\n }\n : null,\n translucent: props.translucent,\n hidden:\n props.hidden != null\n ? {\n value: props.hidden,\n animated,\n transition: showHideTransition,\n }\n : null,\n networkActivityIndicatorVisible: props.networkActivityIndicatorVisible,\n };\n}\n\n/**\n * Component to control the app status bar.\n *\n * ### Usage with Navigator\n *\n * It is possible to have multiple `StatusBar` components mounted at the same\n * time. The props will be merged in the order the `StatusBar` components were\n * mounted. One use case is to specify status bar styles per route using `Navigator`.\n *\n * ```\n * \n * \n * \n * \n * \n * }\n * />\n * \n * ```\n *\n * ### Imperative API\n *\n * For cases where using a component is not ideal, there are static methods\n * to manipulate the `StatusBar` display stack. These methods have the same\n * behavior as mounting and unmounting a `StatusBar` component.\n *\n * For example, you can call `StatusBar.pushStackEntry` to update the status bar\n * before launching a third-party native UI component, and then call\n * `StatusBar.popStackEntry` when completed.\n *\n * ```\n * const openThirdPartyBugReporter = async () => {\n * // The bug reporter has a dark background, so we push a new status bar style.\n * const stackEntry = StatusBar.pushStackEntry({barStyle: 'light-content'});\n *\n * // `open` returns a promise that resolves when the UI is dismissed.\n * await BugReporter.open();\n *\n * // Don't forget to call `popStackEntry` when you're done.\n * StatusBar.popStackEntry(stackEntry);\n * };\n * ```\n *\n * There is a legacy imperative API that enables you to manually update the\n * status bar styles. However, the legacy API does not update the internal\n * `StatusBar` display stack, which means that any changes will be overridden\n * whenever a `StatusBar` component is mounted or unmounted.\n *\n * It is strongly advised that you use `pushStackEntry`, `popStackEntry`, or\n * `replaceStackEntry` instead of the static methods beginning with `set`.\n *\n * ### Constants\n *\n * `currentHeight` (Android only) The height of the status bar.\n */\nclass StatusBar extends React.Component {\n static _propsStack: Array = [];\n\n static _defaultProps: any = createStackEntry({\n backgroundColor:\n Platform.OS === 'android'\n ? NativeStatusBarManagerAndroid.getConstants()\n .DEFAULT_BACKGROUND_COLOR ?? 'black'\n : 'black',\n barStyle: 'default',\n translucent: false,\n hidden: false,\n networkActivityIndicatorVisible: false,\n });\n\n // Timer for updating the native module values at the end of the frame.\n static _updateImmediate = null;\n\n // The current merged values from the props stack.\n static _currentValues = null;\n\n // TODO(janic): Provide a real API to deal with status bar height. See the\n // discussion in #6195.\n /**\n * The current height of the status bar on the device.\n *\n * @platform android\n */\n static currentHeight: ?number =\n Platform.OS === 'android'\n ? NativeStatusBarManagerAndroid.getConstants().HEIGHT\n : null;\n\n // Provide an imperative API as static functions of the component.\n // See the corresponding prop for more detail.\n\n /**\n * Show or hide the status bar\n * @param hidden Hide the status bar.\n * @param animation Optional animation when\n * changing the status bar hidden property.\n */\n static setHidden(hidden: boolean, animation?: StatusBarAnimation) {\n animation = animation || 'none';\n StatusBar._defaultProps.hidden.value = hidden;\n if (Platform.OS === 'ios') {\n NativeStatusBarManagerIOS.setHidden(hidden, animation);\n } else if (Platform.OS === 'android') {\n NativeStatusBarManagerAndroid.setHidden(hidden);\n }\n }\n\n /**\n * Set the status bar style\n * @param style Status bar style to set\n * @param animated Animate the style change.\n */\n static setBarStyle(style: StatusBarStyle, animated?: boolean) {\n animated = animated || false;\n StatusBar._defaultProps.barStyle.value = style;\n if (Platform.OS === 'ios') {\n NativeStatusBarManagerIOS.setStyle(style, animated);\n } else if (Platform.OS === 'android') {\n NativeStatusBarManagerAndroid.setStyle(style);\n }\n }\n\n /**\n * Control the visibility of the network activity indicator\n * @param visible Show the indicator.\n */\n static setNetworkActivityIndicatorVisible(visible: boolean) {\n if (Platform.OS !== 'ios') {\n console.warn(\n '`setNetworkActivityIndicatorVisible` is only available on iOS',\n );\n return;\n }\n StatusBar._defaultProps.networkActivityIndicatorVisible = visible;\n NativeStatusBarManagerIOS.setNetworkActivityIndicatorVisible(visible);\n }\n\n /**\n * Set the background color for the status bar\n * @param color Background color.\n * @param animated Animate the style change.\n */\n static setBackgroundColor(color: string, animated?: boolean): void {\n if (Platform.OS !== 'android') {\n console.warn('`setBackgroundColor` is only available on Android');\n return;\n }\n animated = animated || false;\n StatusBar._defaultProps.backgroundColor.value = color;\n\n const processedColor = processColor(color);\n if (processedColor == null) {\n console.warn(\n `\\`StatusBar.setBackgroundColor\\`: Color ${color} parsed to null or undefined`,\n );\n return;\n }\n invariant(\n typeof processedColor === 'number',\n 'Unexpected color given for StatusBar.setBackgroundColor',\n );\n\n NativeStatusBarManagerAndroid.setColor(processedColor, animated);\n }\n\n /**\n * Control the translucency of the status bar\n * @param translucent Set as translucent.\n */\n static setTranslucent(translucent: boolean) {\n if (Platform.OS !== 'android') {\n console.warn('`setTranslucent` is only available on Android');\n return;\n }\n StatusBar._defaultProps.translucent = translucent;\n NativeStatusBarManagerAndroid.setTranslucent(translucent);\n }\n\n /**\n * Push a StatusBar entry onto the stack.\n * The return value should be passed to `popStackEntry` when complete.\n *\n * @param props Object containing the StatusBar props to use in the stack entry.\n */\n static pushStackEntry(props: any): any {\n const entry = createStackEntry(props);\n StatusBar._propsStack.push(entry);\n StatusBar._updatePropsStack();\n return entry;\n }\n\n /**\n * Pop a StatusBar entry from the stack.\n *\n * @param entry Entry returned from `pushStackEntry`.\n */\n static popStackEntry(entry: any) {\n const index = StatusBar._propsStack.indexOf(entry);\n if (index !== -1) {\n StatusBar._propsStack.splice(index, 1);\n }\n StatusBar._updatePropsStack();\n }\n\n /**\n * Replace an existing StatusBar stack entry with new props.\n *\n * @param entry Entry returned from `pushStackEntry` to replace.\n * @param props Object containing the StatusBar props to use in the replacement stack entry.\n */\n static replaceStackEntry(entry: any, props: any): any {\n const newEntry = createStackEntry(props);\n const index = StatusBar._propsStack.indexOf(entry);\n if (index !== -1) {\n StatusBar._propsStack[index] = newEntry;\n }\n StatusBar._updatePropsStack();\n return newEntry;\n }\n\n _stackEntry = null;\n\n componentDidMount() {\n // Every time a StatusBar component is mounted, we push it's prop to a stack\n // and always update the native status bar with the props from the top of then\n // stack. This allows having multiple StatusBar components and the one that is\n // added last or is deeper in the view hierarchy will have priority.\n this._stackEntry = StatusBar.pushStackEntry(this.props);\n }\n\n componentWillUnmount() {\n // When a StatusBar is unmounted, remove itself from the stack and update\n // the native bar with the next props.\n StatusBar.popStackEntry(this._stackEntry);\n }\n\n componentDidUpdate() {\n this._stackEntry = StatusBar.replaceStackEntry(\n this._stackEntry,\n this.props,\n );\n }\n\n /**\n * Updates the native status bar with the props from the stack.\n */\n static _updatePropsStack = () => {\n // Send the update to the native module only once at the end of the frame.\n clearImmediate(StatusBar._updateImmediate);\n StatusBar._updateImmediate = setImmediate(() => {\n const oldProps = StatusBar._currentValues;\n const mergedProps = mergePropsStack(\n StatusBar._propsStack,\n StatusBar._defaultProps,\n );\n\n // Update the props that have changed using the merged values from the props stack.\n if (Platform.OS === 'ios') {\n if (\n !oldProps ||\n oldProps.barStyle.value !== mergedProps.barStyle.value\n ) {\n NativeStatusBarManagerIOS.setStyle(\n mergedProps.barStyle.value,\n mergedProps.barStyle.animated || false,\n );\n }\n if (!oldProps || oldProps.hidden.value !== mergedProps.hidden.value) {\n NativeStatusBarManagerIOS.setHidden(\n mergedProps.hidden.value,\n mergedProps.hidden.animated\n ? mergedProps.hidden.transition\n : 'none',\n );\n }\n\n if (\n !oldProps ||\n oldProps.networkActivityIndicatorVisible !==\n mergedProps.networkActivityIndicatorVisible\n ) {\n NativeStatusBarManagerIOS.setNetworkActivityIndicatorVisible(\n mergedProps.networkActivityIndicatorVisible,\n );\n }\n } else if (Platform.OS === 'android') {\n //todo(T60684787): Add back optimization to only update bar style and\n //background color if the new value is different from the old value.\n NativeStatusBarManagerAndroid.setStyle(mergedProps.barStyle.value);\n const processedColor = processColor(mergedProps.backgroundColor.value);\n if (processedColor == null) {\n console.warn(\n `\\`StatusBar._updatePropsStack\\`: Color ${mergedProps.backgroundColor.value} parsed to null or undefined`,\n );\n } else {\n invariant(\n typeof processedColor === 'number',\n 'Unexpected color given in StatusBar._updatePropsStack',\n );\n NativeStatusBarManagerAndroid.setColor(\n processedColor,\n mergedProps.backgroundColor.animated,\n );\n }\n if (!oldProps || oldProps.hidden.value !== mergedProps.hidden.value) {\n NativeStatusBarManagerAndroid.setHidden(mergedProps.hidden.value);\n }\n // Activities are not translucent by default, so always set if true.\n if (\n !oldProps ||\n oldProps.translucent !== mergedProps.translucent ||\n mergedProps.translucent\n ) {\n NativeStatusBarManagerAndroid.setTranslucent(mergedProps.translucent);\n }\n }\n // Update the current prop values.\n StatusBar._currentValues = mergedProps;\n });\n };\n\n render(): React.Node {\n return null;\n }\n}\n\nmodule.exports = StatusBar;\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 * @flow strict\n * @format\n */\n\nimport type {TurboModule} from '../../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../../TurboModule/TurboModuleRegistry';\n\nexport interface Spec extends TurboModule {\n +getConstants: () => {|\n +HEIGHT: number,\n +DEFAULT_BACKGROUND_COLOR: number,\n |};\n +setColor: (color: number, animated: boolean) => void;\n +setTranslucent: (translucent: boolean) => void;\n\n /**\n * - statusBarStyles can be:\n * - 'default'\n * - 'dark-content'\n */\n +setStyle: (statusBarStyle?: ?string) => void;\n +setHidden: (hidden: boolean) => void;\n}\n\nconst NativeModule = TurboModuleRegistry.getEnforcing('StatusBarManager');\nlet constants = null;\n\nconst NativeStatusBarManager = {\n getConstants(): {|\n +HEIGHT: number,\n +DEFAULT_BACKGROUND_COLOR?: number,\n |} {\n if (constants == null) {\n constants = NativeModule.getConstants();\n }\n return constants;\n },\n\n setColor(color: number, animated: boolean): void {\n NativeModule.setColor(color, animated);\n },\n\n setTranslucent(translucent: boolean): void {\n NativeModule.setTranslucent(translucent);\n },\n\n /**\n * - statusBarStyles can be:\n * - 'default'\n * - 'dark-content'\n */\n setStyle(statusBarStyle?: ?string): void {\n NativeModule.setStyle(statusBarStyle);\n },\n\n setHidden(hidden: boolean): void {\n NativeModule.setHidden(hidden);\n },\n};\n\nexport default NativeStatusBarManager;\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 * @flow strict\n * @format\n */\n\nimport type {TurboModule} from '../../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../../TurboModule/TurboModuleRegistry';\n\nexport interface Spec extends TurboModule {\n +getConstants: () => {|\n +HEIGHT: number,\n +DEFAULT_BACKGROUND_COLOR?: number,\n |};\n\n // TODO(T47754272) Can we remove this method?\n +getHeight: (callback: (result: {|height: number|}) => void) => void;\n +setNetworkActivityIndicatorVisible: (visible: boolean) => void;\n +addListener: (eventType: string) => void;\n +removeListeners: (count: number) => void;\n\n /**\n * - statusBarStyles can be:\n * - 'default'\n * - 'dark-content'\n * - 'light-content'\n */\n +setStyle: (statusBarStyle?: ?string, animated: boolean) => void;\n /**\n * - withAnimation can be: 'none' | 'fade' | 'slide'\n */\n +setHidden: (hidden: boolean, withAnimation: string) => void;\n}\n\nconst NativeModule = TurboModuleRegistry.getEnforcing('StatusBarManager');\nlet constants = null;\n\nconst NativeStatusBarManager = {\n getConstants(): {|\n +HEIGHT: number,\n +DEFAULT_BACKGROUND_COLOR?: number,\n |} {\n if (constants == null) {\n constants = NativeModule.getConstants();\n }\n return constants;\n },\n\n // TODO(T47754272) Can we remove this method?\n getHeight(callback: (result: {|height: number|}) => void): void {\n NativeModule.getHeight(callback);\n },\n\n setNetworkActivityIndicatorVisible(visible: boolean): void {\n NativeModule.setNetworkActivityIndicatorVisible(visible);\n },\n\n addListener(eventType: string): void {\n NativeModule.addListener(eventType);\n },\n\n removeListeners(count: number): void {\n NativeModule.removeListeners(count);\n },\n\n /**\n * - statusBarStyles can be:\n * - 'default'\n * - 'dark-content'\n * - 'light-content'\n */\n setStyle(statusBarStyle?: ?string, animated: boolean): void {\n NativeModule.setStyle(statusBarStyle, animated);\n },\n\n /**\n * - withAnimation can be: 'none' | 'fade' | 'slide'\n */\n setHidden(hidden: boolean, withAnimation: string): void {\n NativeModule.setHidden(hidden, withAnimation);\n },\n};\n\nexport default NativeStatusBarManager;\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 * @flow strict-local\n * @format\n * @generate-docs\n */\n\nimport type {ColorValue} from '../../StyleSheet/StyleSheet';\nimport type {SyntheticEvent} from '../../Types/CoreEventTypes';\nimport type {ViewProps} from '../View/ViewPropTypes';\n\nimport StyleSheet from '../../StyleSheet/StyleSheet';\nimport Platform from '../../Utilities/Platform';\nimport useMergeRefs from '../../Utilities/useMergeRefs';\nimport AndroidSwitchNativeComponent, {\n Commands as AndroidSwitchCommands,\n} from './AndroidSwitchNativeComponent';\nimport SwitchNativeComponent, {\n Commands as SwitchCommands,\n} from './SwitchNativeComponent';\nimport * as React from 'react';\n\ntype SwitchChangeEvent = SyntheticEvent<\n $ReadOnly<{|\n value: boolean,\n target: number,\n |}>,\n>;\n\nexport type Props = $ReadOnly<{|\n ...ViewProps,\n\n /**\n If true the user won't be able to toggle the switch.\n\n @default false\n */\n disabled?: ?boolean,\n\n /**\n The value of the switch. If true the switch will be turned on.\n\n @default false\n */\n value?: ?boolean,\n\n /**\n Color of the foreground switch grip. If this is set on iOS, the switch grip will lose its drop shadow.\n */\n thumbColor?: ?ColorValue,\n\n /**\n Custom colors for the switch track.\n\n _iOS_: When the switch value is false, the track shrinks into the border. If you want to change the\n color of the background exposed by the shrunken track, use\n [`ios_backgroundColor`](https://reactnative.dev/docs/switch#ios_backgroundColor).\n */\n trackColor?: ?$ReadOnly<{|\n false?: ?ColorValue,\n true?: ?ColorValue,\n |}>,\n\n /**\n On iOS, custom color for the background. This background color can be\n seen either when the switch value is false or when the switch is\n disabled (and the switch is translucent).\n */\n ios_backgroundColor?: ?ColorValue,\n\n /**\n Invoked when the user tries to change the value of the switch. Receives\n the change event as an argument. If you want to only receive the new\n value, use `onValueChange` instead.\n */\n onChange?: ?(event: SwitchChangeEvent) => Promise | void,\n\n /**\n Invoked when the user tries to change the value of the switch. Receives\n the new value as an argument. If you want to instead receive an event,\n use `onChange`.\n */\n onValueChange?: ?(value: boolean) => Promise | void,\n|}>;\nconst returnsFalse = () => false;\nconst returnsTrue = () => true;\n\n/**\n Renders a boolean input.\n\n This is a controlled component that requires an `onValueChange`\n callback that updates the `value` prop in order for the component to\n reflect user actions. If the `value` prop is not updated, the\n component will continue to render the supplied `value` prop instead of\n the expected result of any user actions.\n\n ```SnackPlayer name=Switch\n import React, { useState } from \"react\";\n import { View, Switch, StyleSheet } from \"react-native\";\n\n const App = () => {\n const [isEnabled, setIsEnabled] = useState(false);\n const toggleSwitch = () => setIsEnabled(previousState => !previousState);\n\n return (\n \n \n \n );\n }\n\n const styles = StyleSheet.create({\n container: {\n flex: 1,\n alignItems: \"center\",\n justifyContent: \"center\"\n }\n });\n\n export default App;\n ```\n */\n\nconst SwitchWithForwardedRef: React.AbstractComponent<\n Props,\n React.ElementRef<\n typeof SwitchNativeComponent | typeof AndroidSwitchNativeComponent,\n >,\n> = React.forwardRef(function Switch(props, forwardedRef): React.Node {\n const {\n disabled,\n ios_backgroundColor,\n onChange,\n onValueChange,\n style,\n thumbColor,\n trackColor,\n value,\n ...restProps\n } = props;\n const trackColorForFalse = trackColor?.false;\n const trackColorForTrue = trackColor?.true;\n\n const nativeSwitchRef = React.useRef | null>(null);\n\n const ref = useMergeRefs(nativeSwitchRef, forwardedRef);\n\n const [native, setNative] = React.useState({value: null});\n\n const handleChange = (event: SwitchChangeEvent) => {\n onChange?.(event);\n onValueChange?.(event.nativeEvent.value);\n setNative({value: event.nativeEvent.value});\n };\n\n React.useLayoutEffect(() => {\n // This is necessary in case native updates the switch and JS decides\n // that the update should be ignored and we should stick with the value\n // that we have in JS.\n const jsValue = value === true;\n const shouldUpdateNativeSwitch =\n native.value != null && native.value !== jsValue;\n if (\n shouldUpdateNativeSwitch &&\n nativeSwitchRef.current?.setNativeProps != null\n ) {\n if (Platform.OS === 'android') {\n AndroidSwitchCommands.setNativeValue(nativeSwitchRef.current, jsValue);\n } else {\n SwitchCommands.setValue(nativeSwitchRef.current, jsValue);\n }\n }\n }, [value, native]);\n\n if (Platform.OS === 'android') {\n const {accessibilityState} = restProps;\n const _disabled =\n disabled != null ? disabled : accessibilityState?.disabled;\n\n const _accessibilityState =\n _disabled !== accessibilityState?.disabled\n ? {...accessibilityState, disabled: _disabled}\n : accessibilityState;\n\n const platformProps = {\n accessibilityState: _accessibilityState,\n enabled: _disabled !== true,\n on: value === true,\n style,\n thumbTintColor: thumbColor,\n trackColorForFalse: trackColorForFalse,\n trackColorForTrue: trackColorForTrue,\n trackTintColor: value === true ? trackColorForTrue : trackColorForFalse,\n };\n\n return (\n \n );\n } else {\n const platformProps = {\n disabled,\n onTintColor: trackColorForTrue,\n style: StyleSheet.compose(\n {height: 31, width: 51},\n StyleSheet.compose(\n style,\n ios_backgroundColor == null\n ? null\n : {\n backgroundColor: ios_backgroundColor,\n borderRadius: 16,\n },\n ),\n ),\n thumbTintColor: thumbColor,\n tintColor: trackColorForFalse,\n value: value === true,\n };\n\n return (\n \n );\n }\n});\n\nexport default SwitchWithForwardedRef;\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 * @flow strict-local\n * @format\n */\n\nimport type {HostComponent} from '../../Renderer/shims/ReactNativeTypes';\nimport type {ColorValue} from '../../StyleSheet/StyleSheet';\nimport type {\n BubblingEventHandler,\n Int32,\n WithDefault,\n} from '../../Types/CodegenTypes';\nimport type {ViewProps} from '../View/ViewPropTypes';\n\nimport codegenNativeCommands from '../../Utilities/codegenNativeCommands';\nimport codegenNativeComponent from '../../Utilities/codegenNativeComponent';\nimport * as React from 'react';\n\ntype SwitchChangeEvent = $ReadOnly<{|\n value: boolean,\n target: Int32,\n|}>;\n\ntype NativeProps = $ReadOnly<{|\n ...ViewProps,\n\n // Props\n disabled?: WithDefault,\n enabled?: WithDefault,\n thumbColor?: ?ColorValue,\n trackColorForFalse?: ?ColorValue,\n trackColorForTrue?: ?ColorValue,\n value?: WithDefault,\n on?: WithDefault,\n thumbTintColor?: ?ColorValue,\n trackTintColor?: ?ColorValue,\n\n // Events\n onChange?: BubblingEventHandler,\n|}>;\n\ntype NativeType = HostComponent;\n\ninterface NativeCommands {\n +setNativeValue: (\n viewRef: React.ElementRef,\n value: boolean,\n ) => void;\n}\n\nexport const Commands: NativeCommands = codegenNativeCommands({\n supportedCommands: ['setNativeValue'],\n});\n\nexport default (codegenNativeComponent('AndroidSwitch', {\n interfaceOnly: true,\n}): NativeType);\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 * @flow strict-local\n * @format\n */\n\nimport type {HostComponent} from '../../Renderer/shims/ReactNativeTypes';\nimport type {ColorValue} from '../../StyleSheet/StyleSheet';\nimport type {\n BubblingEventHandler,\n Int32,\n WithDefault,\n} from '../../Types/CodegenTypes';\nimport type {ViewProps} from '../View/ViewPropTypes';\n\nimport codegenNativeCommands from '../../Utilities/codegenNativeCommands';\nimport codegenNativeComponent from '../../Utilities/codegenNativeComponent';\nimport * as React from 'react';\n\ntype SwitchChangeEvent = $ReadOnly<{|\n value: boolean,\n target: Int32,\n|}>;\n\ntype NativeProps = $ReadOnly<{|\n ...ViewProps,\n\n // Props\n disabled?: WithDefault,\n value?: WithDefault,\n tintColor?: ?ColorValue,\n onTintColor?: ?ColorValue,\n thumbTintColor?: ?ColorValue,\n\n // Deprecated props\n thumbColor?: ?ColorValue,\n trackColorForFalse?: ?ColorValue,\n trackColorForTrue?: ?ColorValue,\n\n // Events\n onChange?: ?BubblingEventHandler,\n|}>;\n\ntype ComponentType = HostComponent;\n\ninterface NativeCommands {\n +setValue: (viewRef: React.ElementRef, value: boolean) => void;\n}\n\nexport const Commands: NativeCommands = codegenNativeCommands({\n supportedCommands: ['setValue'],\n});\n\nexport default (codegenNativeComponent('Switch', {\n paperComponentName: 'RCTSwitch',\n excludedPlatforms: ['android'],\n}): ComponentType);\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 * @flow strict-local\n * @format\n */\n\nimport type {HostComponent} from '../../Renderer/shims/ReactNativeTypes';\nimport type {\n PressEvent,\n ScrollEvent,\n SyntheticEvent,\n} from '../../Types/CoreEventTypes';\nimport type {ViewProps} from '../View/ViewPropTypes';\nimport type {TextInputType} from './TextInput.flow';\n\nimport usePressability from '../../Pressability/usePressability';\nimport flattenStyle from '../../StyleSheet/flattenStyle';\nimport StyleSheet, {\n type ColorValue,\n type TextStyleProp,\n type ViewStyleProp,\n} from '../../StyleSheet/StyleSheet';\nimport Text from '../../Text/Text';\nimport TextAncestor from '../../Text/TextAncestor';\nimport Platform from '../../Utilities/Platform';\nimport setAndForwardRef from '../../Utilities/setAndForwardRef';\nimport TextInputState from './TextInputState';\nimport invariant from 'invariant';\nimport nullthrows from 'nullthrows';\nimport * as React from 'react';\n\nconst {useLayoutEffect, useRef, useState} = React;\n\ntype ReactRefSetter = {current: null | T, ...} | ((ref: null | T) => mixed);\n\nlet AndroidTextInput;\nlet AndroidTextInputCommands;\nlet RCTSinglelineTextInputView;\nlet RCTSinglelineTextInputNativeCommands;\nlet RCTMultilineTextInputView;\nlet RCTMultilineTextInputNativeCommands;\n\nif (Platform.OS === 'android') {\n AndroidTextInput = require('./AndroidTextInputNativeComponent').default;\n AndroidTextInputCommands =\n require('./AndroidTextInputNativeComponent').Commands;\n} else if (Platform.OS === 'ios') {\n RCTSinglelineTextInputView =\n require('./RCTSingelineTextInputNativeComponent').default;\n RCTSinglelineTextInputNativeCommands =\n require('./RCTSingelineTextInputNativeComponent').Commands;\n RCTMultilineTextInputView =\n require('./RCTMultilineTextInputNativeComponent').default;\n RCTMultilineTextInputNativeCommands =\n require('./RCTMultilineTextInputNativeComponent').Commands;\n}\n\nexport type ChangeEvent = SyntheticEvent<\n $ReadOnly<{|\n eventCount: number,\n target: number,\n text: string,\n |}>,\n>;\n\nexport type TextInputEvent = SyntheticEvent<\n $ReadOnly<{|\n eventCount: number,\n previousText: string,\n range: $ReadOnly<{|\n start: number,\n end: number,\n |}>,\n target: number,\n text: string,\n |}>,\n>;\n\nexport type ContentSizeChangeEvent = SyntheticEvent<\n $ReadOnly<{|\n target: number,\n contentSize: $ReadOnly<{|\n width: number,\n height: number,\n |}>,\n |}>,\n>;\n\ntype TargetEvent = SyntheticEvent<\n $ReadOnly<{|\n target: number,\n |}>,\n>;\n\nexport type BlurEvent = TargetEvent;\nexport type FocusEvent = TargetEvent;\n\ntype Selection = $ReadOnly<{|\n start: number,\n end: number,\n|}>;\n\nexport type SelectionChangeEvent = SyntheticEvent<\n $ReadOnly<{|\n selection: Selection,\n target: number,\n |}>,\n>;\n\nexport type KeyPressEvent = SyntheticEvent<\n $ReadOnly<{|\n key: string,\n target?: ?number,\n eventCount?: ?number,\n |}>,\n>;\n\nexport type EditingEvent = SyntheticEvent<\n $ReadOnly<{|\n eventCount: number,\n text: string,\n target: number,\n |}>,\n>;\n\ntype DataDetectorTypesType =\n | 'phoneNumber'\n | 'link'\n | 'address'\n | 'calendarEvent'\n | 'none'\n | 'all';\n\nexport type KeyboardType =\n // Cross Platform\n | 'default'\n | 'email-address'\n | 'numeric'\n | 'phone-pad'\n | 'number-pad'\n | 'decimal-pad'\n | 'url'\n // iOS-only\n | 'ascii-capable'\n | 'numbers-and-punctuation'\n | 'name-phone-pad'\n | 'twitter'\n | 'web-search'\n // iOS 10+ only\n | 'ascii-capable-number-pad'\n // Android-only\n | 'visible-password';\n\nexport type InputMode =\n | 'none'\n | 'text'\n | 'decimal'\n | 'numeric'\n | 'tel'\n | 'search'\n | 'email'\n | 'url';\n\nexport type ReturnKeyType =\n // Cross Platform\n | 'done'\n | 'go'\n | 'next'\n | 'search'\n | 'send'\n // Android-only\n | 'none'\n | 'previous'\n // iOS-only\n | 'default'\n | 'emergency-call'\n | 'google'\n | 'join'\n | 'route'\n | 'yahoo';\n\nexport type SubmitBehavior = 'submit' | 'blurAndSubmit' | 'newline';\n\nexport type AutoCapitalize = 'none' | 'sentences' | 'words' | 'characters';\n\nexport type TextContentType =\n | 'none'\n | 'URL'\n | 'addressCity'\n | 'addressCityAndState'\n | 'addressState'\n | 'countryName'\n | 'creditCardNumber'\n | 'emailAddress'\n | 'familyName'\n | 'fullStreetAddress'\n | 'givenName'\n | 'jobTitle'\n | 'location'\n | 'middleName'\n | 'name'\n | 'namePrefix'\n | 'nameSuffix'\n | 'nickname'\n | 'organizationName'\n | 'postalCode'\n | 'streetAddressLine1'\n | 'streetAddressLine2'\n | 'sublocality'\n | 'telephoneNumber'\n | 'username'\n | 'password'\n | 'newPassword'\n | 'oneTimeCode';\n\nexport type enterKeyHintType =\n | 'enter'\n | 'done'\n | 'go'\n | 'next'\n | 'previous'\n | 'search'\n | 'send';\n\ntype PasswordRules = string;\n\ntype IOSProps = $ReadOnly<{|\n /**\n * Give the keyboard and the system information about the\n * expected semantic meaning for the content that users enter.\n * @platform ios\n */\n autoComplete?: ?(\n | 'address-line1'\n | 'address-line2'\n | 'cc-number'\n | 'current-password'\n | 'country'\n | 'email'\n | 'name'\n | 'additional-name'\n | 'family-name'\n | 'given-name'\n | 'nickname'\n | 'honorific-prefix'\n | 'honorific-suffix'\n | 'new-password'\n | 'off'\n | 'one-time-code'\n | 'organization'\n | 'organization-title'\n | 'postal-code'\n | 'street-address'\n | 'tel'\n | 'url'\n | 'username'\n ),\n /**\n * When the clear button should appear on the right side of the text view.\n * This property is supported only for single-line TextInput component.\n * @platform ios\n */\n clearButtonMode?: ?('never' | 'while-editing' | 'unless-editing' | 'always'),\n\n /**\n * If `true`, clears the text field automatically when editing begins.\n * @platform ios\n */\n clearTextOnFocus?: ?boolean,\n\n /**\n * Determines the types of data converted to clickable URLs in the text input.\n * Only valid if `multiline={true}` and `editable={false}`.\n * By default no data types are detected.\n *\n * You can provide one type or an array of many types.\n *\n * Possible values for `dataDetectorTypes` are:\n *\n * - `'phoneNumber'`\n * - `'link'`\n * - `'address'`\n * - `'calendarEvent'`\n * - `'none'`\n * - `'all'`\n *\n * @platform ios\n */\n dataDetectorTypes?:\n | ?DataDetectorTypesType\n | $ReadOnlyArray,\n\n /**\n * If `true`, the keyboard disables the return key when there is no text and\n * automatically enables it when there is text. The default value is `false`.\n * @platform ios\n */\n enablesReturnKeyAutomatically?: ?boolean,\n\n /**\n * An optional identifier which links a custom InputAccessoryView to\n * this text input. The InputAccessoryView is rendered above the\n * keyboard when this text input is focused.\n * @platform ios\n */\n inputAccessoryViewID?: ?string,\n\n /**\n * Determines the color of the keyboard.\n * @platform ios\n */\n keyboardAppearance?: ?('default' | 'light' | 'dark'),\n\n /**\n * Provide rules for your password.\n * For example, say you want to require a password with at least eight characters consisting of a mix of uppercase and lowercase letters, at least one number, and at most two consecutive characters.\n * \"required: upper; required: lower; required: digit; max-consecutive: 2; minlength: 8;\"\n * @platform ios\n */\n passwordRules?: ?PasswordRules,\n\n /*\n * If `true`, allows TextInput to pass touch events to the parent component.\n * This allows components to be swipeable from the TextInput on iOS,\n * as is the case on Android by default.\n * If `false`, TextInput always asks to handle the input (except when disabled).\n * @platform ios\n */\n rejectResponderTermination?: ?boolean,\n\n /**\n * If `false`, scrolling of the text view will be disabled.\n * The default value is `true`. Does only work with 'multiline={true}'.\n * @platform ios\n */\n scrollEnabled?: ?boolean,\n\n /**\n * If `false`, disables spell-check style (i.e. red underlines).\n * The default value is inherited from `autoCorrect`.\n * @platform ios\n */\n spellCheck?: ?boolean,\n\n /**\n * Give the keyboard and the system information about the\n * expected semantic meaning for the content that users enter.\n * @platform ios\n */\n textContentType?: ?TextContentType,\n\n /**\n * Set line break strategy on iOS.\n * @platform ios\n */\n lineBreakStrategyIOS?: ?('none' | 'standard' | 'hangul-word' | 'push-out'),\n\n /**\n * If `false`, the iOS system will not insert an extra space after a paste operation\n * neither delete one or two spaces after a cut or delete operation.\n *\n * The default value is `true`.\n *\n * @platform ios\n */\n smartInsertDelete?: ?boolean,\n|}>;\n\ntype AndroidProps = $ReadOnly<{|\n /**\n * Specifies autocomplete hints for the system, so it can provide autofill. On Android, the system will always attempt to offer autofill by using heuristics to identify the type of content.\n * To disable autocomplete, set `autoComplete` to `off`.\n *\n * *Android Only*\n *\n * Possible values for `autoComplete` are:\n *\n * - `birthdate-day`\n * - `birthdate-full`\n * - `birthdate-month`\n * - `birthdate-year`\n * - `cc-csc`\n * - `cc-exp`\n * - `cc-exp-day`\n * - `cc-exp-month`\n * - `cc-exp-year`\n * - `cc-number`\n * - `email`\n * - `gender`\n * - `name`\n * - `name-family`\n * - `name-given`\n * - `name-middle`\n * - `name-middle-initial`\n * - `name-prefix`\n * - `name-suffix`\n * - `password`\n * - `password-new`\n * - `postal-address`\n * - `postal-address-country`\n * - `postal-address-extended`\n * - `postal-address-extended-postal-code`\n * - `postal-address-locality`\n * - `postal-address-region`\n * - `postal-code`\n * - `street-address`\n * - `sms-otp`\n * - `tel`\n * - `tel-country-code`\n * - `tel-national`\n * - `tel-device`\n * - `username`\n * - `username-new`\n * - `off`\n *\n * @platform android\n */\n autoComplete?: ?(\n | 'birthdate-day'\n | 'birthdate-full'\n | 'birthdate-month'\n | 'birthdate-year'\n | 'cc-csc'\n | 'cc-exp'\n | 'cc-exp-day'\n | 'cc-exp-month'\n | 'cc-exp-year'\n | 'cc-number'\n | 'email'\n | 'gender'\n | 'name'\n | 'name-family'\n | 'name-given'\n | 'name-middle'\n | 'name-middle-initial'\n | 'name-prefix'\n | 'name-suffix'\n | 'password'\n | 'password-new'\n | 'postal-address'\n | 'postal-address-country'\n | 'postal-address-extended'\n | 'postal-address-extended-postal-code'\n | 'postal-address-locality'\n | 'postal-address-region'\n | 'postal-code'\n | 'street-address'\n | 'sms-otp'\n | 'tel'\n | 'tel-country-code'\n | 'tel-national'\n | 'tel-device'\n | 'username'\n | 'username-new'\n | 'off'\n // additional HTML autocomplete values\n | 'address-line1'\n | 'address-line2'\n | 'bday'\n | 'bday-day'\n | 'bday-month'\n | 'bday-year'\n | 'country'\n | 'current-password'\n | 'honorific-prefix'\n | 'honorific-suffix'\n | 'additional-name'\n | 'family-name'\n | 'given-name'\n | 'new-password'\n | 'one-time-code'\n | 'sex'\n ),\n\n /**\n * When provided it will set the color of the cursor (or \"caret\") in the component.\n * Unlike the behavior of `selectionColor` the cursor color will be set independently\n * from the color of the text selection box.\n * @platform android\n */\n cursorColor?: ?ColorValue,\n\n /**\n * When `false`, if there is a small amount of space available around a text input\n * (e.g. landscape orientation on a phone), the OS may choose to have the user edit\n * the text inside of a full screen text input mode. When `true`, this feature is\n * disabled and users will always edit the text directly inside of the text input.\n * Defaults to `false`.\n * @platform android\n */\n disableFullscreenUI?: ?boolean,\n\n importantForAutofill?: ?(\n | 'auto'\n | 'no'\n | 'noExcludeDescendants'\n | 'yes'\n | 'yesExcludeDescendants'\n ),\n\n /**\n * If defined, the provided image resource will be rendered on the left.\n * The image resource must be inside `/android/app/src/main/res/drawable` and referenced\n * like\n * ```\n * \n * ```\n * @platform android\n */\n inlineImageLeft?: ?string,\n\n /**\n * Padding between the inline image, if any, and the text input itself.\n * @platform android\n */\n inlineImagePadding?: ?number,\n\n /**\n * Sets the number of lines for a `TextInput`. Use it with multiline set to\n * `true` to be able to fill the lines.\n */\n numberOfLines?: ?number,\n\n /**\n * Sets the return key to the label. Use it instead of `returnKeyType`.\n * @platform android\n */\n returnKeyLabel?: ?string,\n\n /**\n * Sets the number of rows for a `TextInput`. Use it with multiline set to\n * `true` to be able to fill the lines.\n */\n rows?: ?number,\n\n /**\n * Sets the maximum number of lines the TextInput can have.\n */\n maximumNumberOfLines?: ?number,\n\n /**\n * When `false`, it will prevent the soft keyboard from showing when the field is focused.\n * Defaults to `true`.\n */\n showSoftInputOnFocus?: ?boolean,\n\n /**\n * Set text break strategy on Android API Level 23+, possible values are `simple`, `highQuality`, `balanced`\n * The default value is `simple`.\n * @platform android\n */\n textBreakStrategy?: ?('simple' | 'highQuality' | 'balanced'),\n\n /**\n * The color of the `TextInput` underline.\n * @platform android\n */\n underlineColorAndroid?: ?ColorValue,\n|}>;\n\nexport type Props = $ReadOnly<{|\n ...$Diff>,\n ...IOSProps,\n ...AndroidProps,\n\n /**\n * Can tell `TextInput` to automatically capitalize certain characters.\n *\n * - `characters`: all characters.\n * - `words`: first letter of each word.\n * - `sentences`: first letter of each sentence (*default*).\n * - `none`: don't auto capitalize anything.\n */\n autoCapitalize?: ?AutoCapitalize,\n\n /**\n * If `false`, disables auto-correct. The default value is `true`.\n */\n autoCorrect?: ?boolean,\n\n /**\n * If `true`, focuses the input on `componentDidMount`.\n * The default value is `false`.\n */\n autoFocus?: ?boolean,\n\n /**\n * Specifies whether fonts should scale to respect Text Size accessibility settings. The\n * default is `true`.\n */\n allowFontScaling?: ?boolean,\n\n /**\n * If `true`, caret is hidden. The default value is `false`.\n *\n * On Android devices manufactured by Xiaomi with Android Q,\n * when keyboardType equals 'email-address'this will be set\n * in native to 'true' to prevent a system related crash. This\n * will cause cursor to be diabled as a side-effect.\n *\n */\n caretHidden?: ?boolean,\n\n /*\n * If `true`, contextMenuHidden is hidden. The default value is `false`.\n */\n contextMenuHidden?: ?boolean,\n\n /**\n * Provides an initial value that will change when the user starts typing.\n * Useful for simple use-cases where you do not want to deal with listening\n * to events and updating the value prop to keep the controlled state in sync.\n */\n defaultValue?: ?Stringish,\n\n /**\n * If `false`, text is not editable. The default value is `true`.\n */\n editable?: ?boolean,\n\n forwardedRef?: ?ReactRefSetter<\n React.ElementRef> & ImperativeMethods,\n >,\n\n /**\n * `enterKeyHint` defines what action label (or icon) to present for the enter key on virtual keyboards.\n *\n * The following values is supported:\n *\n * - `enter`\n * - `done`\n * - `go`\n * - `next`\n * - `previous`\n * - `search`\n * - `send`\n */\n enterKeyHint?: ?enterKeyHintType,\n\n /**\n * `inputMode` works like the `inputmode` attribute in HTML, it determines which\n * keyboard to open, e.g.`numeric` and has precedence over keyboardType\n *\n * Support the following values:\n *\n * - `none`\n * - `text`\n * - `decimal`\n * - `numeric`\n * - `tel`\n * - `search`\n * - `email`\n * - `url`\n */\n inputMode?: ?InputMode,\n\n /**\n * Determines which keyboard to open, e.g.`numeric`.\n *\n * The following values work across platforms:\n *\n * - `default`\n * - `numeric`\n * - `number-pad`\n * - `decimal-pad`\n * - `email-address`\n * - `phone-pad`\n * - `url`\n *\n * *iOS Only*\n *\n * The following values work on iOS only:\n *\n * - `ascii-capable`\n * - `numbers-and-punctuation`\n * - `name-phone-pad`\n * - `twitter`\n * - `web-search`\n *\n * *Android Only*\n *\n * The following values work on Android only:\n *\n * - `visible-password`\n *\n */\n keyboardType?: ?KeyboardType,\n\n /**\n * Specifies largest possible scale a font can reach when `allowFontScaling` is enabled.\n * Possible values:\n * `null/undefined` (default): inherit from the parent node or the global default (0)\n * `0`: no max, ignore parent/global default\n * `>= 1`: sets the maxFontSizeMultiplier of this node to this value\n */\n maxFontSizeMultiplier?: ?number,\n\n /**\n * Limits the maximum number of characters that can be entered. Use this\n * instead of implementing the logic in JS to avoid flicker.\n */\n maxLength?: ?number,\n\n /**\n * If `true`, the text input can be multiple lines.\n * The default value is `false`.\n */\n multiline?: ?boolean,\n\n /**\n * Callback that is called when the text input is blurred.\n */\n onBlur?: ?(e: BlurEvent) => mixed,\n\n /**\n * Callback that is called when the text input's text changes.\n */\n onChange?: ?(e: ChangeEvent) => mixed,\n\n /**\n * DANGER: this API is not stable and will change in the future.\n *\n * Callback will be called on the main thread and may result in dropped frames.\n * Callback that is called when the text input's text changes.\n *\n * @platform ios\n */\n unstable_onChangeSync?: ?(e: ChangeEvent) => mixed,\n\n /**\n * Callback that is called when the text input's text changes.\n * Changed text is passed as an argument to the callback handler.\n */\n onChangeText?: ?(text: string) => mixed,\n\n /**\n * DANGER: this API is not stable and will change in the future.\n *\n * Callback will be called on the main thread and may result in dropped frames.\n * Callback that is called when the text input's text changes.\n * Changed text is passed as an argument to the callback handler.\n *\n * @platform ios\n */\n unstable_onChangeTextSync?: ?(text: string) => mixed,\n\n /**\n * Callback that is called when the text input's content size changes.\n * This will be called with\n * `{ nativeEvent: { contentSize: { width, height } } }`.\n *\n * Only called for multiline text inputs.\n */\n onContentSizeChange?: ?(e: ContentSizeChangeEvent) => mixed,\n\n /**\n * Callback that is called when text input ends.\n */\n onEndEditing?: ?(e: EditingEvent) => mixed,\n\n /**\n * Callback that is called when the text input is focused.\n */\n onFocus?: ?(e: FocusEvent) => mixed,\n\n /**\n * Callback that is called when a key is pressed.\n * This will be called with `{ nativeEvent: { key: keyValue } }`\n * where `keyValue` is `'Enter'` or `'Backspace'` for respective keys and\n * the typed-in character otherwise including `' '` for space.\n * Fires before `onChange` callbacks.\n */\n onKeyPress?: ?(e: KeyPressEvent) => mixed,\n\n /**\n * DANGER: this API is not stable and will change in the future.\n *\n * Callback will be called on the main thread and may result in dropped frames.\n *\n * Callback that is called when a key is pressed.\n * This will be called with `{ nativeEvent: { key: keyValue } }`\n * where `keyValue` is `'Enter'` or `'Backspace'` for respective keys and\n * the typed-in character otherwise including `' '` for space.\n * Fires before `onChange` callbacks.\n *\n * @platform ios\n */\n unstable_onKeyPressSync?: ?(e: KeyPressEvent) => mixed,\n\n /**\n * Called when a touch is engaged.\n */\n onPressIn?: ?(event: PressEvent) => mixed,\n\n /**\n * Called when a touch is released.\n */\n onPressOut?: ?(event: PressEvent) => mixed,\n\n /**\n * Callback that is called when the text input selection is changed.\n * This will be called with\n * `{ nativeEvent: { selection: { start, end } } }`.\n */\n onSelectionChange?: ?(e: SelectionChangeEvent) => mixed,\n\n /**\n * Callback that is called when the text input's submit button is pressed.\n * Invalid if `multiline={true}` is specified.\n */\n onSubmitEditing?: ?(e: EditingEvent) => mixed,\n\n /**\n * Invoked on content scroll with `{ nativeEvent: { contentOffset: { x, y } } }`.\n * May also contain other properties from ScrollEvent but on Android contentSize\n * is not provided for performance reasons.\n */\n onScroll?: ?(e: ScrollEvent) => mixed,\n\n /**\n * The string that will be rendered before text input has been entered.\n */\n placeholder?: ?Stringish,\n\n /**\n * The text color of the placeholder string.\n */\n placeholderTextColor?: ?ColorValue,\n\n /** `readOnly` works like the `readonly` attribute in HTML.\n * If `true`, text is not editable. The default value is `false`.\n * See https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/readonly\n * for more details.\n */\n readOnly?: ?boolean,\n\n /**\n * Determines how the return key should look. On Android you can also use\n * `returnKeyLabel`.\n *\n * *Cross platform*\n *\n * The following values work across platforms:\n *\n * - `done`\n * - `go`\n * - `next`\n * - `search`\n * - `send`\n *\n * *Android Only*\n *\n * The following values work on Android only:\n *\n * - `none`\n * - `previous`\n *\n * *iOS Only*\n *\n * The following values work on iOS only:\n *\n * - `default`\n * - `emergency-call`\n * - `google`\n * - `join`\n * - `route`\n * - `yahoo`\n */\n returnKeyType?: ?ReturnKeyType,\n\n /**\n * If `true`, the text input obscures the text entered so that sensitive text\n * like passwords stay secure. The default value is `false`. Does not work with 'multiline={true}'.\n */\n secureTextEntry?: ?boolean,\n\n /**\n * The start and end of the text input's selection. Set start and end to\n * the same value to position the cursor.\n */\n selection?: ?$ReadOnly<{|\n start: number,\n end?: ?number,\n |}>,\n\n /**\n * The highlight and cursor color of the text input.\n */\n selectionColor?: ?ColorValue,\n\n /**\n * If `true`, all text will automatically be selected on focus.\n */\n selectTextOnFocus?: ?boolean,\n\n /**\n * If `true`, the text field will blur when submitted.\n * The default value is true for single-line fields and false for\n * multiline fields. Note that for multiline fields, setting `blurOnSubmit`\n * to `true` means that pressing return will blur the field and trigger the\n * `onSubmitEditing` event instead of inserting a newline into the field.\n *\n * @deprecated\n * Note that `submitBehavior` now takes the place of `blurOnSubmit` and will\n * override any behavior defined by `blurOnSubmit`.\n * @see submitBehavior\n */\n blurOnSubmit?: ?boolean,\n\n /**\n * When the return key is pressed,\n *\n * For single line inputs:\n *\n * - `'newline`' defaults to `'blurAndSubmit'`\n * - `undefined` defaults to `'blurAndSubmit'`\n *\n * For multiline inputs:\n *\n * - `'newline'` adds a newline\n * - `undefined` defaults to `'newline'`\n *\n * For both single line and multiline inputs:\n *\n * - `'submit'` will only send a submit event and not blur the input\n * - `'blurAndSubmit`' will both blur the input and send a submit event\n */\n submitBehavior?: ?SubmitBehavior,\n\n /**\n * Note that not all Text styles are supported, an incomplete list of what is not supported includes:\n *\n * - `borderLeftWidth`\n * - `borderTopWidth`\n * - `borderRightWidth`\n * - `borderBottomWidth`\n * - `borderTopLeftRadius`\n * - `borderTopRightRadius`\n * - `borderBottomRightRadius`\n * - `borderBottomLeftRadius`\n *\n * see [Issue#7070](https://github.com/facebook/react-native/issues/7070)\n * for more detail.\n *\n * [Styles](docs/style.html)\n */\n style?: ?TextStyleProp,\n\n /**\n * The value to show for the text input. `TextInput` is a controlled\n * component, which means the native value will be forced to match this\n * value prop if provided. For most uses, this works great, but in some\n * cases this may cause flickering - one common cause is preventing edits\n * by keeping value the same. In addition to simply setting the same value,\n * either set `editable={false}`, or set/update `maxLength` to prevent\n * unwanted edits without flicker.\n */\n value?: ?Stringish,\n|}>;\n\ntype ImperativeMethods = $ReadOnly<{|\n clear: () => void,\n isFocused: () => boolean,\n getNativeRef: () => ?React.ElementRef>,\n setSelection: (start: number, end: number) => void,\n|}>;\n\nconst emptyFunctionThatReturnsTrue = () => true;\n\n/**\n * A foundational component for inputting text into the app via a\n * keyboard. Props provide configurability for several features, such as\n * auto-correction, auto-capitalization, placeholder text, and different keyboard\n * types, such as a numeric keypad.\n *\n * The simplest use case is to plop down a `TextInput` and subscribe to the\n * `onChangeText` events to read the user input. There are also other events,\n * such as `onSubmitEditing` and `onFocus` that can be subscribed to. A simple\n * example:\n *\n * ```ReactNativeWebPlayer\n * import React, { Component } from 'react';\n * import { AppRegistry, TextInput } from 'react-native';\n *\n * export default class UselessTextInput extends Component {\n * constructor(props) {\n * super(props);\n * this.state = { text: 'Useless Placeholder' };\n * }\n *\n * render() {\n * return (\n * this.setState({text})}\n * value={this.state.text}\n * />\n * );\n * }\n * }\n *\n * // skip this line if using Create React Native App\n * AppRegistry.registerComponent('AwesomeProject', () => UselessTextInput);\n * ```\n *\n * Two methods exposed via the native element are .focus() and .blur() that\n * will focus or blur the TextInput programmatically.\n *\n * Note that some props are only available with `multiline={true/false}`.\n * Additionally, border styles that apply to only one side of the element\n * (e.g., `borderBottomColor`, `borderLeftWidth`, etc.) will not be applied if\n * `multiline=false`. To achieve the same effect, you can wrap your `TextInput`\n * in a `View`:\n *\n * ```ReactNativeWebPlayer\n * import React, { Component } from 'react';\n * import { AppRegistry, View, TextInput } from 'react-native';\n *\n * class UselessTextInput extends Component {\n * render() {\n * return (\n * \n * );\n * }\n * }\n *\n * export default class UselessTextInputMultiline extends Component {\n * constructor(props) {\n * super(props);\n * this.state = {\n * text: 'Useless Multiline Placeholder',\n * };\n * }\n *\n * // If you type something in the text box that is a color, the background will change to that\n * // color.\n * render() {\n * return (\n * \n * this.setState({text})}\n * value={this.state.text}\n * />\n * \n * );\n * }\n * }\n *\n * // skip these lines if using Create React Native App\n * AppRegistry.registerComponent(\n * 'AwesomeProject',\n * () => UselessTextInputMultiline\n * );\n * ```\n *\n * `TextInput` has by default a border at the bottom of its view. This border\n * has its padding set by the background image provided by the system, and it\n * cannot be changed. Solutions to avoid this is to either not set height\n * explicitly, case in which the system will take care of displaying the border\n * in the correct position, or to not display the border by setting\n * `underlineColorAndroid` to transparent.\n *\n * Note that on Android performing text selection in input can change\n * app's activity `windowSoftInputMode` param to `adjustResize`.\n * This may cause issues with components that have position: 'absolute'\n * while keyboard is active. To avoid this behavior either specify `windowSoftInputMode`\n * in AndroidManifest.xml ( https://developer.android.com/guide/topics/manifest/activity-element.html )\n * or control this param programmatically with native code.\n *\n */\nfunction InternalTextInput(props: Props): React.Node {\n const {\n rows,\n numberOfLines,\n ...otherProps\n } = props;\n\n const inputRef = useRef>>(null);\n\n // Android sends a \"onTextChanged\" event followed by a \"onSelectionChanged\" event, for\n // the same \"most recent event count\".\n // For controlled selection, that means that immediately after text is updated,\n // a controlled component will pass in the *previous* selection, even if the controlled\n // component didn't mean to modify the selection at all.\n // Therefore, we ignore selections and pass them through until the selection event has\n // been sent.\n // Note that this mitigation is NOT needed for Fabric.\n // discovered when upgrading react-hooks\n // eslint-disable-next-line react-hooks/exhaustive-deps\n let selection: ?Selection =\n props.selection == null\n ? null\n : {\n start: props.selection.start,\n end: props.selection.end ?? props.selection.start,\n };\n\n const [mostRecentEventCount, setMostRecentEventCount] = useState(0);\n\n const [lastNativeText, setLastNativeText] = useState(props.value);\n const [lastNativeSelectionState, setLastNativeSelection] = useState<{|\n selection: ?Selection,\n mostRecentEventCount: number,\n |}>({selection, mostRecentEventCount});\n\n const lastNativeSelection = lastNativeSelectionState.selection;\n const lastNativeSelectionEventCount =\n lastNativeSelectionState.mostRecentEventCount;\n\n if (lastNativeSelectionEventCount < mostRecentEventCount) {\n selection = null;\n }\n\n let viewCommands;\n if (AndroidTextInputCommands) {\n viewCommands = AndroidTextInputCommands;\n } else {\n viewCommands =\n props.multiline === true\n ? RCTMultilineTextInputNativeCommands\n : RCTSinglelineTextInputNativeCommands;\n }\n\n const text =\n typeof props.value === 'string'\n ? props.value\n : typeof props.defaultValue === 'string'\n ? props.defaultValue\n : '';\n\n // This is necessary in case native updates the text and JS decides\n // that the update should be ignored and we should stick with the value\n // that we have in JS.\n useLayoutEffect(() => {\n const nativeUpdate: {text?: string, selection?: Selection} = {};\n\n if (lastNativeText !== props.value && typeof props.value === 'string') {\n nativeUpdate.text = props.value;\n setLastNativeText(props.value);\n }\n\n if (\n selection &&\n lastNativeSelection &&\n (lastNativeSelection.start !== selection.start ||\n lastNativeSelection.end !== selection.end)\n ) {\n nativeUpdate.selection = selection;\n setLastNativeSelection({selection, mostRecentEventCount});\n }\n\n if (Object.keys(nativeUpdate).length === 0) {\n return;\n }\n\n if (inputRef.current != null) {\n viewCommands.setTextAndSelection(\n inputRef.current,\n mostRecentEventCount,\n text,\n selection?.start ?? -1,\n selection?.end ?? -1,\n );\n }\n }, [\n mostRecentEventCount,\n inputRef,\n props.value,\n props.defaultValue,\n lastNativeText,\n selection,\n lastNativeSelection,\n text,\n viewCommands,\n ]);\n\n useLayoutEffect(() => {\n const inputRefValue = inputRef.current;\n\n if (inputRefValue != null) {\n TextInputState.registerInput(inputRefValue);\n\n return () => {\n TextInputState.unregisterInput(inputRefValue);\n\n if (TextInputState.currentlyFocusedInput() === inputRefValue) {\n nullthrows(inputRefValue).blur();\n }\n };\n }\n }, [inputRef]);\n\n function clear(): void {\n if (inputRef.current != null) {\n viewCommands.setTextAndSelection(\n inputRef.current,\n mostRecentEventCount,\n '',\n 0,\n 0,\n );\n }\n }\n\n function setSelection(start: number, end: number): void {\n if (inputRef.current != null) {\n viewCommands.setTextAndSelection(\n inputRef.current,\n mostRecentEventCount,\n null,\n start,\n end,\n );\n }\n }\n\n // TODO: Fix this returning true on null === null, when no input is focused\n function isFocused(): boolean {\n return TextInputState.currentlyFocusedInput() === inputRef.current;\n }\n\n function getNativeRef(): ?React.ElementRef> {\n return inputRef.current;\n }\n\n const _setNativeRef = setAndForwardRef({\n getForwardedRef: () => props.forwardedRef,\n setLocalRef: ref => {\n inputRef.current = ref;\n\n /*\n Hi reader from the future. I'm sorry for this.\n\n This is a hack. Ideally we would forwardRef to the underlying\n host component. However, since TextInput has it's own methods that can be\n called as well, if we used the standard forwardRef then these\n methods wouldn't be accessible and thus be a breaking change.\n\n We have a couple of options of how to handle this:\n - Return a new ref with everything we methods from both. This is problematic\n because we need React to also know it is a host component which requires\n internals of the class implementation of the ref.\n - Break the API and have some other way to call one set of the methods or\n the other. This is our long term approach as we want to eventually\n get the methods on host components off the ref. So instead of calling\n ref.measure() you might call ReactNative.measure(ref). This would hopefully\n let the ref for TextInput then have the methods like `.clear`. Or we do it\n the other way and make it TextInput.clear(textInputRef) which would be fine\n too. Either way though is a breaking change that is longer term.\n - Mutate this ref. :( Gross, but accomplishes what we need in the meantime\n before we can get to the long term breaking change.\n */\n if (ref) {\n ref.clear = clear;\n ref.isFocused = isFocused;\n ref.getNativeRef = getNativeRef;\n ref.setSelection = setSelection;\n }\n },\n });\n\n const _onChange = (event: ChangeEvent) => {\n const currentText = event.nativeEvent.text;\n props.onChange && props.onChange(event);\n props.onChangeText && props.onChangeText(currentText);\n\n if (inputRef.current == null) {\n // calling `props.onChange` or `props.onChangeText`\n // may clean up the input itself. Exits here.\n return;\n }\n\n setLastNativeText(currentText);\n // This must happen last, after we call setLastNativeText.\n // Different ordering can cause bugs when editing AndroidTextInputs\n // with multiple Fragments.\n // We must update this so that controlled input updates work.\n setMostRecentEventCount(event.nativeEvent.eventCount);\n };\n\n const _onChangeSync = (event: ChangeEvent) => {\n const currentText = event.nativeEvent.text;\n props.unstable_onChangeSync && props.unstable_onChangeSync(event);\n props.unstable_onChangeTextSync &&\n props.unstable_onChangeTextSync(currentText);\n\n if (inputRef.current == null) {\n // calling `props.onChange` or `props.onChangeText`\n // may clean up the input itself. Exits here.\n return;\n }\n\n setLastNativeText(currentText);\n // This must happen last, after we call setLastNativeText.\n // Different ordering can cause bugs when editing AndroidTextInputs\n // with multiple Fragments.\n // We must update this so that controlled input updates work.\n setMostRecentEventCount(event.nativeEvent.eventCount);\n };\n\n const _onSelectionChange = (event: SelectionChangeEvent) => {\n props.onSelectionChange && props.onSelectionChange(event);\n\n if (inputRef.current == null) {\n // calling `props.onSelectionChange`\n // may clean up the input itself. Exits here.\n return;\n }\n\n setLastNativeSelection({\n selection: event.nativeEvent.selection,\n mostRecentEventCount,\n });\n };\n\n const _onFocus = (event: FocusEvent) => {\n TextInputState.focusInput(inputRef.current);\n if (props.onFocus) {\n props.onFocus(event);\n }\n };\n\n const _onBlur = (event: BlurEvent) => {\n TextInputState.blurInput(inputRef.current);\n if (props.onBlur) {\n props.onBlur(event);\n }\n };\n\n const _onScroll = (event: ScrollEvent) => {\n props.onScroll && props.onScroll(event);\n };\n\n let textInput = null;\n\n const multiline = props.multiline ?? false;\n\n let submitBehavior: SubmitBehavior;\n if (props.submitBehavior != null) {\n // `submitBehavior` is set explicitly\n if (!multiline && props.submitBehavior === 'newline') {\n // For single line text inputs, `'newline'` is not a valid option\n submitBehavior = 'blurAndSubmit';\n } else {\n submitBehavior = props.submitBehavior;\n }\n } else if (multiline) {\n if (props.blurOnSubmit === true) {\n submitBehavior = 'blurAndSubmit';\n } else {\n submitBehavior = 'newline';\n }\n } else {\n // Single line\n if (props.blurOnSubmit !== false) {\n submitBehavior = 'blurAndSubmit';\n } else {\n submitBehavior = 'submit';\n }\n }\n\n const accessible = props.accessible !== false;\n const focusable = props.focusable !== false;\n\n const config = React.useMemo(\n () => ({\n onPress: (event: PressEvent) => {\n if (props.editable !== false) {\n if (inputRef.current != null) {\n inputRef.current.focus();\n }\n }\n },\n onPressIn: props.onPressIn,\n onPressOut: props.onPressOut,\n cancelable:\n Platform.OS === 'ios' ? !props.rejectResponderTermination : null,\n }),\n [\n props.editable,\n props.onPressIn,\n props.onPressOut,\n props.rejectResponderTermination,\n ],\n );\n\n // Hide caret during test runs due to a flashing caret\n // makes screenshot tests flakey\n let caretHidden = props.caretHidden;\n if (Platform.isTesting) {\n caretHidden = true;\n }\n\n // TextInput handles onBlur and onFocus events\n // so omitting onBlur and onFocus pressability handlers here.\n const {onBlur, onFocus, ...eventHandlers} = usePressability(config) || {};\n\n const _accessibilityState = {\n busy: props['aria-busy'] ?? props.accessibilityState?.busy,\n checked: props['aria-checked'] ?? props.accessibilityState?.checked,\n disabled: props['aria-disabled'] ?? props.accessibilityState?.disabled,\n expanded: props['aria-expanded'] ?? props.accessibilityState?.expanded,\n selected: props['aria-selected'] ?? props.accessibilityState?.selected,\n };\n\n if (Platform.OS === 'ios') {\n const RCTTextInputView =\n props.multiline === true\n ? RCTMultilineTextInputView\n : RCTSinglelineTextInputView;\n\n const style =\n props.multiline === true\n ? StyleSheet.flatten([styles.multilineInput, props.style])\n : props.style;\n\n const useOnChangeSync =\n (props.unstable_onChangeSync || props.unstable_onChangeTextSync) &&\n !(props.onChange || props.onChangeText);\n\n textInput = (\n \n );\n } else if (Platform.OS === 'android') {\n const style = [props.style];\n const autoCapitalize = props.autoCapitalize || 'sentences';\n const _accessibilityLabelledBy =\n props?.['aria-labelledby'] ?? props?.accessibilityLabelledBy;\n const placeholder = props.placeholder ?? '';\n let children = props.children;\n const childCount = React.Children.count(children);\n invariant(\n !(props.value != null && childCount),\n 'Cannot specify both value and children.',\n );\n if (childCount > 1) {\n children = {children};\n }\n\n textInput = (\n /* $FlowFixMe[prop-missing] the types for AndroidTextInput don't match up\n * exactly with the props for TextInput. This will need to get fixed */\n /* $FlowFixMe[incompatible-type] the types for AndroidTextInput don't\n * match up exactly with the props for TextInput. This will need to get\n * fixed */\n /* $FlowFixMe[incompatible-type-arg] the types for AndroidTextInput don't\n * match up exactly with the props for TextInput. This will need to get\n * fixed */\n \n );\n }\n return (\n {textInput}\n );\n}\n\nconst enterKeyHintToReturnTypeMap = {\n enter: 'default',\n done: 'done',\n go: 'go',\n next: 'next',\n previous: 'previous',\n search: 'search',\n send: 'send',\n};\n\nconst inputModeToKeyboardTypeMap = {\n none: 'default',\n text: 'default',\n decimal: 'decimal-pad',\n numeric: 'number-pad',\n tel: 'phone-pad',\n search: Platform.OS === 'ios' ? 'web-search' : 'default',\n email: 'email-address',\n url: 'url',\n};\n\n// Map HTML autocomplete values to Android autoComplete values\nconst autoCompleteWebToAutoCompleteAndroidMap = {\n 'address-line1': 'postal-address-region',\n 'address-line2': 'postal-address-locality',\n bday: 'birthdate-full',\n 'bday-day': 'birthdate-day',\n 'bday-month': 'birthdate-month',\n 'bday-year': 'birthdate-year',\n 'cc-csc': 'cc-csc',\n 'cc-exp': 'cc-exp',\n 'cc-exp-month': 'cc-exp-month',\n 'cc-exp-year': 'cc-exp-year',\n 'cc-number': 'cc-number',\n country: 'postal-address-country',\n 'current-password': 'password',\n email: 'email',\n 'honorific-prefix': 'name-prefix',\n 'honorific-suffix': 'name-suffix',\n name: 'name',\n 'additional-name': 'name-middle',\n 'family-name': 'name-family',\n 'given-name': 'name-given',\n 'new-password': 'password-new',\n off: 'off',\n 'one-time-code': 'sms-otp',\n 'postal-code': 'postal-code',\n sex: 'gender',\n 'street-address': 'street-address',\n tel: 'tel',\n 'tel-country-code': 'tel-country-code',\n 'tel-national': 'tel-national',\n username: 'username',\n};\n\n// Map HTML autocomplete values to iOS textContentType values\nconst autoCompleteWebToTextContentTypeMap = {\n 'address-line1': 'streetAddressLine1',\n 'address-line2': 'streetAddressLine2',\n 'cc-number': 'creditCardNumber',\n 'current-password': 'password',\n country: 'countryName',\n email: 'emailAddress',\n name: 'name',\n 'additional-name': 'middleName',\n 'family-name': 'familyName',\n 'given-name': 'givenName',\n nickname: 'nickname',\n 'honorific-prefix': 'namePrefix',\n 'honorific-suffix': 'nameSuffix',\n 'new-password': 'newPassword',\n off: 'none',\n 'one-time-code': 'oneTimeCode',\n organization: 'organizationName',\n 'organization-title': 'jobTitle',\n 'postal-code': 'postalCode',\n 'street-address': 'fullStreetAddress',\n tel: 'telephoneNumber',\n url: 'URL',\n username: 'username',\n};\n\nconst ExportedForwardRef: React.AbstractComponent<\n React.ElementConfig,\n React.ElementRef> & ImperativeMethods,\n> = React.forwardRef(function TextInput(\n {\n allowFontScaling = true,\n rejectResponderTermination = true,\n underlineColorAndroid = 'transparent',\n autoComplete,\n textContentType,\n readOnly,\n editable,\n enterKeyHint,\n returnKeyType,\n inputMode,\n keyboardType,\n ...restProps\n },\n forwardedRef: ReactRefSetter<\n React.ElementRef> & ImperativeMethods,\n >,\n) {\n const style = flattenStyle(restProps.style);\n\n if (style?.verticalAlign != null) {\n style.textAlignVertical =\n verticalAlignToTextAlignVerticalMap[style.verticalAlign];\n }\n\n return (\n \n );\n});\n\n/**\n * Switch to `deprecated-react-native-prop-types` for compatibility with future\n * releases. This is deprecated and will be removed in the future.\n */\nExportedForwardRef.propTypes =\n require('deprecated-react-native-prop-types').TextInputPropTypes;\n\n// $FlowFixMe[prop-missing]\nExportedForwardRef.State = {\n currentlyFocusedInput: TextInputState.currentlyFocusedInput,\n\n currentlyFocusedField: TextInputState.currentlyFocusedField,\n focusTextInput: TextInputState.focusTextInput,\n blurTextInput: TextInputState.blurTextInput,\n};\n\nexport type TextInputComponentStatics = $ReadOnly<{|\n State: $ReadOnly<{|\n currentlyFocusedInput: typeof TextInputState.currentlyFocusedInput,\n currentlyFocusedField: typeof TextInputState.currentlyFocusedField,\n focusTextInput: typeof TextInputState.focusTextInput,\n blurTextInput: typeof TextInputState.blurTextInput,\n |}>,\n|}>;\n\nconst styles = StyleSheet.create({\n multilineInput: {\n // This default top inset makes RCTMultilineTextInputView seem as close as possible\n // to single-line RCTSinglelineTextInputView defaults, using the system defaults\n // of font size 17 and a height of 31 points.\n paddingTop: 5,\n },\n});\n\nconst verticalAlignToTextAlignVerticalMap = {\n auto: 'auto',\n top: 'top',\n bottom: 'bottom',\n middle: 'center',\n};\n\n// $FlowFixMe[unclear-type] Unclear type. Using `any` type is not safe.\nmodule.exports = ((ExportedForwardRef: any): TextInputType);\n","'use strict';\n\nfunction 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\nmodule.exports = nullthrows;\nmodule.exports.default = nullthrows;\n\nObject.defineProperty(module.exports, '__esModule', {value: true});\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 * @flow strict-local\n * @format\n */\n\nimport type {\n HostComponent,\n PartialViewConfig,\n} from '../../Renderer/shims/ReactNativeTypes';\nimport type {\n ColorValue,\n TextStyleProp,\n ViewStyleProp,\n} from '../../StyleSheet/StyleSheet';\nimport type {\n BubblingEventHandler,\n DirectEventHandler,\n Double,\n Float,\n Int32,\n WithDefault,\n} from '../../Types/CodegenTypes';\nimport type {ViewProps} from '../View/ViewPropTypes';\nimport type {TextInputNativeCommands} from './TextInputNativeCommands';\n\nimport * as NativeComponentRegistry from '../../NativeComponent/NativeComponentRegistry';\nimport codegenNativeCommands from '../../Utilities/codegenNativeCommands';\n\nexport type KeyboardType =\n // Cross Platform\n | 'default'\n | 'email-address'\n | 'numeric'\n | 'phone-pad'\n | 'number-pad'\n | 'decimal-pad'\n | 'url'\n // iOS-only\n | 'ascii-capable'\n | 'numbers-and-punctuation'\n | 'name-phone-pad'\n | 'twitter'\n | 'web-search'\n // Android-only\n | 'visible-password';\n\nexport type ReturnKeyType =\n // Cross Platform\n | 'done'\n | 'go'\n | 'next'\n | 'search'\n | 'send'\n // Android-only\n | 'none'\n | 'previous'\n // iOS-only\n | 'default'\n | 'emergency-call'\n | 'google'\n | 'join'\n | 'route'\n | 'yahoo';\n\nexport type SubmitBehavior = 'submit' | 'blurAndSubmit' | 'newline';\n\nexport type NativeProps = $ReadOnly<{|\n // This allows us to inherit everything from ViewProps except for style (see below)\n // This must be commented for Fabric codegen to work.\n ...$Diff>,\n\n /**\n * Android props after this\n */\n /**\n * Specifies autocomplete hints for the system, so it can provide autofill. On Android, the system will always attempt to offer autofill by using heuristics to identify the type of content.\n * To disable autocomplete, set `autoComplete` to `off`.\n *\n * *Android Only*\n *\n * Possible values for `autoComplete` are:\n *\n * - `birthdate-day`\n * - `birthdate-full`\n * - `birthdate-month`\n * - `birthdate-year`\n * - `cc-csc`\n * - `cc-exp`\n * - `cc-exp-day`\n * - `cc-exp-month`\n * - `cc-exp-year`\n * - `cc-number`\n * - `email`\n * - `gender`\n * - `name`\n * - `name-family`\n * - `name-given`\n * - `name-middle`\n * - `name-middle-initial`\n * - `name-prefix`\n * - `name-suffix`\n * - `password`\n * - `password-new`\n * - `postal-address`\n * - `postal-address-country`\n * - `postal-address-extended`\n * - `postal-address-extended-postal-code`\n * - `postal-address-locality`\n * - `postal-address-region`\n * - `postal-code`\n * - `street-address`\n * - `sms-otp`\n * - `tel`\n * - `tel-country-code`\n * - `tel-national`\n * - `tel-device`\n * - `username`\n * - `username-new`\n * - `off`\n *\n * @platform android\n */\n autoComplete?: WithDefault<\n | 'birthdate-day'\n | 'birthdate-full'\n | 'birthdate-month'\n | 'birthdate-year'\n | 'cc-csc'\n | 'cc-exp'\n | 'cc-exp-day'\n | 'cc-exp-month'\n | 'cc-exp-year'\n | 'cc-number'\n | 'email'\n | 'gender'\n | 'name'\n | 'name-family'\n | 'name-given'\n | 'name-middle'\n | 'name-middle-initial'\n | 'name-prefix'\n | 'name-suffix'\n | 'password'\n | 'password-new'\n | 'postal-address'\n | 'postal-address-country'\n | 'postal-address-extended'\n | 'postal-address-extended-postal-code'\n | 'postal-address-locality'\n | 'postal-address-region'\n | 'postal-code'\n | 'street-address'\n | 'sms-otp'\n | 'tel'\n | 'tel-country-code'\n | 'tel-national'\n | 'tel-device'\n | 'username'\n | 'username-new'\n | 'off',\n 'off',\n >,\n\n /**\n * Sets the return key to the label. Use it instead of `returnKeyType`.\n * @platform android\n */\n returnKeyLabel?: ?string,\n\n /**\n * Sets the number of lines for a `TextInput`. Use it with multiline set to\n * `true` to be able to fill the lines.\n * @platform android\n */\n numberOfLines?: ?Int32,\n\n /**\n * Sets the maximum number of lines for a `TextInput`. Use it with multiline set to\n * `true` to be able to fill the lines.\n * @platform android\n */\n maximumNumberOfLines?: ?Int32,\n\n /**\n * When `false`, if there is a small amount of space available around a text input\n * (e.g. landscape orientation on a phone), the OS may choose to have the user edit\n * the text inside of a full screen text input mode. When `true`, this feature is\n * disabled and users will always edit the text directly inside of the text input.\n * Defaults to `false`.\n * @platform android\n */\n disableFullscreenUI?: ?boolean,\n\n /**\n * Set text break strategy on Android API Level 23+, possible values are `simple`, `highQuality`, `balanced`\n * The default value is `simple`.\n * @platform android\n */\n textBreakStrategy?: WithDefault<\n 'simple' | 'highQuality' | 'balanced',\n 'simple',\n >,\n\n /**\n * The color of the `TextInput` underline.\n * @platform android\n */\n underlineColorAndroid?: ?ColorValue,\n\n /**\n * If defined, the provided image resource will be rendered on the left.\n * The image resource must be inside `/android/app/src/main/res/drawable` and referenced\n * like\n * ```\n * \n * ```\n * @platform android\n */\n inlineImageLeft?: ?string,\n\n /**\n * Padding between the inline image, if any, and the text input itself.\n * @platform android\n */\n inlineImagePadding?: ?Int32,\n\n importantForAutofill?: string /*?(\n | 'auto'\n | 'no'\n | 'noExcludeDescendants'\n | 'yes'\n | 'yesExcludeDescendants'\n ),*/,\n\n /**\n * When `false`, it will prevent the soft keyboard from showing when the field is focused.\n * Defaults to `true`.\n */\n showSoftInputOnFocus?: ?boolean,\n\n /**\n * TextInput props after this\n */\n /**\n * Can tell `TextInput` to automatically capitalize certain characters.\n *\n * - `characters`: all characters.\n * - `words`: first letter of each word.\n * - `sentences`: first letter of each sentence (*default*).\n * - `none`: don't auto capitalize anything.\n */\n autoCapitalize?: WithDefault<\n 'none' | 'sentences' | 'words' | 'characters',\n 'none',\n >,\n\n /**\n * If `false`, disables auto-correct. The default value is `true`.\n */\n autoCorrect?: ?boolean,\n\n /**\n * If `true`, focuses the input on `componentDidMount`.\n * The default value is `false`.\n */\n autoFocus?: ?boolean,\n\n /**\n * Specifies whether fonts should scale to respect Text Size accessibility settings. The\n * default is `true`.\n */\n allowFontScaling?: ?boolean,\n\n /**\n * Specifies largest possible scale a font can reach when `allowFontScaling` is enabled.\n * Possible values:\n * `null/undefined` (default): inherit from the parent node or the global default (0)\n * `0`: no max, ignore parent/global default\n * `>= 1`: sets the maxFontSizeMultiplier of this node to this value\n */\n maxFontSizeMultiplier?: ?Float,\n\n /**\n * If `false`, text is not editable. The default value is `true`.\n */\n editable?: ?boolean,\n\n /**\n * Determines which keyboard to open, e.g.`numeric`.\n *\n * The following values work across platforms:\n *\n * - `default`\n * - `numeric`\n * - `number-pad`\n * - `decimal-pad`\n * - `email-address`\n * - `phone-pad`\n * - `url`\n *\n * *Android Only*\n *\n * The following values work on Android only:\n *\n * - `visible-password`\n */\n keyboardType?: WithDefault,\n\n /**\n * Determines how the return key should look. On Android you can also use\n * `returnKeyLabel`.\n *\n * *Cross platform*\n *\n * The following values work across platforms:\n *\n * - `done`\n * - `go`\n * - `next`\n * - `search`\n * - `send`\n *\n * *Android Only*\n *\n * The following values work on Android only:\n *\n * - `none`\n * - `previous`\n */\n returnKeyType?: WithDefault,\n\n /**\n * Limits the maximum number of characters that can be entered. Use this\n * instead of implementing the logic in JS to avoid flicker.\n */\n maxLength?: ?Int32,\n\n /**\n * If `true`, the text input can be multiple lines.\n * The default value is `false`.\n */\n multiline?: ?boolean,\n\n /**\n * Callback that is called when the text input is blurred.\n * `target` is the reactTag of the element\n */\n onBlur?: ?BubblingEventHandler<$ReadOnly<{|target: Int32|}>>,\n\n /**\n * Callback that is called when the text input is focused.\n * `target` is the reactTag of the element\n */\n onFocus?: ?BubblingEventHandler<$ReadOnly<{|target: Int32|}>>,\n\n /**\n * Callback that is called when the text input's text changes.\n * `target` is the reactTag of the element\n * TODO: differentiate between onChange and onChangeText\n */\n onChange?: ?BubblingEventHandler<\n $ReadOnly<{|target: Int32, eventCount: Int32, text: string|}>,\n >,\n\n /**\n * Callback that is called when the text input's text changes.\n * Changed text is passed as an argument to the callback handler.\n * TODO: differentiate between onChange and onChangeText\n */\n onChangeText?: ?BubblingEventHandler<\n $ReadOnly<{|target: Int32, eventCount: Int32, text: string|}>,\n >,\n\n /**\n * Callback that is called when the text input's content size changes.\n * This will be called with\n * `{ nativeEvent: { contentSize: { width, height } } }`.\n *\n * Only called for multiline text inputs.\n */\n onContentSizeChange?: ?DirectEventHandler<\n $ReadOnly<{|\n target: Int32,\n contentSize: $ReadOnly<{|width: Double, height: Double|}>,\n |}>,\n >,\n\n onTextInput?: ?BubblingEventHandler<\n $ReadOnly<{|\n target: Int32,\n text: string,\n previousText: string,\n range: $ReadOnly<{|start: Double, end: Double|}>,\n |}>,\n >,\n\n /**\n * Callback that is called when text input ends.\n */\n onEndEditing?: ?BubblingEventHandler<\n $ReadOnly<{|target: Int32, text: string|}>,\n >,\n\n /**\n * Callback that is called when the text input selection is changed.\n * This will be called with\n * `{ nativeEvent: { selection: { start, end } } }`.\n */\n onSelectionChange?: ?DirectEventHandler<\n $ReadOnly<{|\n target: Int32,\n selection: $ReadOnly<{|start: Double, end: Double|}>,\n |}>,\n >,\n\n /**\n * Callback that is called when the text input's submit button is pressed.\n * Invalid if `multiline={true}` is specified.\n */\n onSubmitEditing?: ?BubblingEventHandler<\n $ReadOnly<{|target: Int32, text: string|}>,\n >,\n\n /**\n * Callback that is called when a key is pressed.\n * This will be called with `{ nativeEvent: { key: keyValue } }`\n * where `keyValue` is `'Enter'` or `'Backspace'` for respective keys and\n * the typed-in character otherwise including `' '` for space.\n * Fires before `onChange` callbacks.\n */\n onKeyPress?: ?BubblingEventHandler<$ReadOnly<{|target: Int32, key: string|}>>,\n\n /**\n * Invoked on content scroll with `{ nativeEvent: { contentOffset: { x, y } } }`.\n * May also contain other properties from ScrollEvent but on Android contentSize\n * is not provided for performance reasons.\n */\n onScroll?: ?DirectEventHandler<\n $ReadOnly<{|\n target: Int32,\n responderIgnoreScroll: boolean,\n contentInset: $ReadOnly<{|\n top: Double, // always 0 on Android\n bottom: Double, // always 0 on Android\n left: Double, // always 0 on Android\n right: Double, // always 0 on Android\n |}>,\n contentOffset: $ReadOnly<{|\n x: Double,\n y: Double,\n |}>,\n contentSize: $ReadOnly<{|\n width: Double, // always 0 on Android\n height: Double, // always 0 on Android\n |}>,\n layoutMeasurement: $ReadOnly<{|\n width: Double,\n height: Double,\n |}>,\n velocity: $ReadOnly<{|\n x: Double, // always 0 on Android\n y: Double, // always 0 on Android\n |}>,\n |}>,\n >,\n\n /**\n * The string that will be rendered before text input has been entered.\n */\n placeholder?: ?Stringish,\n\n /**\n * The text color of the placeholder string.\n */\n placeholderTextColor?: ?ColorValue,\n\n /**\n * If `true`, the text input obscures the text entered so that sensitive text\n * like passwords stay secure. The default value is `false`. Does not work with 'multiline={true}'.\n */\n secureTextEntry?: ?boolean,\n\n /**\n * The highlight and cursor color of the text input.\n */\n selectionColor?: ?ColorValue,\n\n /**\n * The start and end of the text input's selection. Set start and end to\n * the same value to position the cursor.\n */\n selection?: ?$ReadOnly<{|\n start: Int32,\n end?: ?Int32,\n |}>,\n\n /**\n * The value to show for the text input. `TextInput` is a controlled\n * component, which means the native value will be forced to match this\n * value prop if provided. For most uses, this works great, but in some\n * cases this may cause flickering - one common cause is preventing edits\n * by keeping value the same. In addition to simply setting the same value,\n * either set `editable={false}`, or set/update `maxLength` to prevent\n * unwanted edits without flicker.\n */\n value?: ?string,\n\n /**\n * Provides an initial value that will change when the user starts typing.\n * Useful for simple use-cases where you do not want to deal with listening\n * to events and updating the value prop to keep the controlled state in sync.\n */\n defaultValue?: ?string,\n\n /**\n * If `true`, all text will automatically be selected on focus.\n */\n selectTextOnFocus?: ?boolean,\n\n /**\n * If `true`, the text field will blur when submitted.\n * The default value is true for single-line fields and false for\n * multiline fields. Note that for multiline fields, setting `blurOnSubmit`\n * to `true` means that pressing return will blur the field and trigger the\n * `onSubmitEditing` event instead of inserting a newline into the field.\n *\n * @deprecated\n * Note that `submitBehavior` now takes the place of `blurOnSubmit` and will\n * override any behavior defined by `blurOnSubmit`.\n * @see submitBehavior\n */\n blurOnSubmit?: ?boolean,\n\n /**\n * When the return key is pressed,\n *\n * For single line inputs:\n *\n * - `'newline`' defaults to `'blurAndSubmit'`\n * - `undefined` defaults to `'blurAndSubmit'`\n *\n * For multiline inputs:\n *\n * - `'newline'` adds a newline\n * - `undefined` defaults to `'newline'`\n *\n * For both single line and multiline inputs:\n *\n * - `'submit'` will only send a submit event and not blur the input\n * - `'blurAndSubmit`' will both blur the input and send a submit event\n */\n submitBehavior?: ?SubmitBehavior,\n\n /**\n * Note that not all Text styles are supported, an incomplete list of what is not supported includes:\n *\n * - `borderLeftWidth`\n * - `borderTopWidth`\n * - `borderRightWidth`\n * - `borderBottomWidth`\n * - `borderTopLeftRadius`\n * - `borderTopRightRadius`\n * - `borderBottomRightRadius`\n * - `borderBottomLeftRadius`\n *\n * see [Issue#7070](https://github.com/facebook/react-native/issues/7070)\n * for more detail.\n *\n * [Styles](docs/style.html)\n */\n // TODO: figure out what to do with this style prop for codegen/Fabric purposes\n // This must be commented for Fabric codegen to work; it's currently not possible\n // to override the default View style prop in codegen.\n style?: ?TextStyleProp,\n\n /**\n * If `true`, caret is hidden. The default value is `false`.\n * This property is supported only for single-line TextInput component on iOS.\n */\n caretHidden?: ?boolean,\n\n /*\n * If `true`, contextMenuHidden is hidden. The default value is `false`.\n */\n contextMenuHidden?: ?boolean,\n\n /**\n * The following are props that `BaseTextShadowNode` takes. It is unclear if they\n * are used by TextInput.\n */\n textShadowColor?: ?ColorValue,\n textShadowRadius?: ?Float,\n textDecorationLine?: ?string,\n fontStyle?: ?string,\n textShadowOffset?: ?$ReadOnly<{|width?: ?Double, height?: ?Double|}>,\n lineHeight?: ?Float,\n textTransform?: ?string,\n color?: ?Int32,\n letterSpacing?: ?Float,\n fontSize?: ?Float,\n textAlign?: ?string,\n includeFontPadding?: ?boolean,\n fontWeight?: ?string,\n fontFamily?: ?string,\n\n /**\n * I cannot find where these are defined but JS complains without them.\n */\n textAlignVertical?: ?string,\n cursorColor?: ?ColorValue,\n\n /**\n * \"Private\" fields used by TextInput.js and not users of this component directly\n */\n mostRecentEventCount: Int32,\n text?: ?string,\n|}>;\n\ntype NativeType = HostComponent;\n\ntype NativeCommands = TextInputNativeCommands;\n\nexport const Commands: NativeCommands = codegenNativeCommands({\n supportedCommands: ['focus', 'blur', 'setTextAndSelection'],\n});\n\nexport const __INTERNAL_VIEW_CONFIG: PartialViewConfig = {\n uiViewClassName: 'AndroidTextInput',\n bubblingEventTypes: {\n topBlur: {\n phasedRegistrationNames: {\n bubbled: 'onBlur',\n captured: 'onBlurCapture',\n },\n },\n topEndEditing: {\n phasedRegistrationNames: {\n bubbled: 'onEndEditing',\n captured: 'onEndEditingCapture',\n },\n },\n topFocus: {\n phasedRegistrationNames: {\n bubbled: 'onFocus',\n captured: 'onFocusCapture',\n },\n },\n topKeyPress: {\n phasedRegistrationNames: {\n bubbled: 'onKeyPress',\n captured: 'onKeyPressCapture',\n },\n },\n topSubmitEditing: {\n phasedRegistrationNames: {\n bubbled: 'onSubmitEditing',\n captured: 'onSubmitEditingCapture',\n },\n },\n topTextInput: {\n phasedRegistrationNames: {\n bubbled: 'onTextInput',\n captured: 'onTextInputCapture',\n },\n },\n },\n directEventTypes: {\n topScroll: {\n registrationName: 'onScroll',\n },\n },\n validAttributes: {\n maxFontSizeMultiplier: true,\n adjustsFontSizeToFit: true,\n minimumFontScale: true,\n autoFocus: true,\n placeholder: true,\n inlineImagePadding: true,\n contextMenuHidden: true,\n textShadowColor: {process: require('../../StyleSheet/processColor')},\n maxLength: true,\n selectTextOnFocus: true,\n textShadowRadius: true,\n underlineColorAndroid: {\n process: require('../../StyleSheet/processColor'),\n },\n textDecorationLine: true,\n submitBehavior: true,\n textAlignVertical: true,\n fontStyle: true,\n textShadowOffset: true,\n selectionColor: {process: require('../../StyleSheet/processColor')},\n selection: true,\n placeholderTextColor: {process: require('../../StyleSheet/processColor')},\n importantForAutofill: true,\n lineHeight: true,\n textTransform: true,\n returnKeyType: true,\n keyboardType: true,\n multiline: true,\n color: {process: require('../../StyleSheet/processColor')},\n autoComplete: true,\n numberOfLines: true,\n letterSpacing: true,\n returnKeyLabel: true,\n fontSize: true,\n onKeyPress: true,\n cursorColor: {process: require('../../StyleSheet/processColor')},\n text: true,\n showSoftInputOnFocus: true,\n textAlign: true,\n autoCapitalize: true,\n autoCorrect: true,\n caretHidden: true,\n secureTextEntry: true,\n textBreakStrategy: true,\n onScroll: true,\n onContentSizeChange: true,\n disableFullscreenUI: true,\n includeFontPadding: true,\n fontWeight: true,\n fontFamily: true,\n allowFontScaling: true,\n onSelectionChange: true,\n mostRecentEventCount: true,\n inlineImageLeft: true,\n editable: true,\n fontVariant: true,\n borderBottomRightRadius: true,\n borderBottomColor: {process: require('../../StyleSheet/processColor')},\n borderRadius: true,\n borderRightColor: {process: require('../../StyleSheet/processColor')},\n borderColor: {process: require('../../StyleSheet/processColor')},\n borderTopRightRadius: true,\n borderStyle: true,\n borderBottomLeftRadius: true,\n borderLeftColor: {process: require('../../StyleSheet/processColor')},\n borderTopLeftRadius: true,\n borderTopColor: {process: require('../../StyleSheet/processColor')},\n },\n};\n\nlet AndroidTextInputNativeComponent = NativeComponentRegistry.get(\n 'AndroidTextInput',\n () => __INTERNAL_VIEW_CONFIG,\n);\n\n// flowlint-next-line unclear-type:off\nexport default ((AndroidTextInputNativeComponent: any): HostComponent);\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 * @flow strict-local\n * @format\n */\n\nimport type {\n HostComponent,\n PartialViewConfig,\n} from '../../Renderer/shims/ReactNativeTypes';\nimport type {TextInputNativeCommands} from './TextInputNativeCommands';\n\nimport * as NativeComponentRegistry from '../../NativeComponent/NativeComponentRegistry';\nimport codegenNativeCommands from '../../Utilities/codegenNativeCommands';\nimport RCTTextInputViewConfig from './RCTTextInputViewConfig';\n\ntype NativeType = HostComponent;\n\ntype NativeCommands = TextInputNativeCommands;\n\nexport const Commands: NativeCommands = codegenNativeCommands({\n supportedCommands: ['focus', 'blur', 'setTextAndSelection'],\n});\n\nexport const __INTERNAL_VIEW_CONFIG: PartialViewConfig = {\n uiViewClassName: 'RCTMultilineTextInputView',\n ...RCTTextInputViewConfig,\n validAttributes: {\n ...RCTTextInputViewConfig.validAttributes,\n dataDetectorTypes: true,\n },\n};\n\nconst MultilineTextInputNativeComponent: HostComponent =\n NativeComponentRegistry.get(\n 'RCTMultilineTextInputView',\n () => __INTERNAL_VIEW_CONFIG,\n );\n\n// flowlint-next-line unclear-type:off\nexport default ((MultilineTextInputNativeComponent: any): HostComponent);\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 * @flow\n * @format\n */\n\nimport type {EdgeInsetsProp} from '../../StyleSheet/EdgeInsetsPropType';\nimport type {ColorValue} from '../../StyleSheet/StyleSheet';\nimport type {PressEvent} from '../../Types/CoreEventTypes';\nimport type {TouchableType} from './Touchable.flow';\n\nimport {PressabilityDebugView} from '../../Pressability/PressabilityDebug';\nimport UIManager from '../../ReactNative/UIManager';\nimport Platform from '../../Utilities/Platform';\nimport SoundManager from '../Sound/SoundManager';\nimport BoundingDimensions from './BoundingDimensions';\nimport Position from './Position';\nimport * as React from 'react';\n\nconst extractSingleTouch = (nativeEvent: {\n +changedTouches: $ReadOnlyArray,\n +force?: number,\n +identifier: number,\n +locationX: number,\n +locationY: number,\n +pageX: number,\n +pageY: number,\n +target: ?number,\n +timestamp: number,\n +touches: $ReadOnlyArray,\n}) => {\n const touches = nativeEvent.touches;\n const changedTouches = nativeEvent.changedTouches;\n const hasTouches = touches && touches.length > 0;\n const hasChangedTouches = changedTouches && changedTouches.length > 0;\n\n return !hasTouches && hasChangedTouches\n ? changedTouches[0]\n : hasTouches\n ? touches[0]\n : nativeEvent;\n};\n\n/**\n * `Touchable`: Taps done right.\n *\n * You hook your `ResponderEventPlugin` events into `Touchable`. `Touchable`\n * will measure time/geometry and tells you when to give feedback to the user.\n *\n * ====================== Touchable Tutorial ===============================\n * The `Touchable` mixin helps you handle the \"press\" interaction. It analyzes\n * the geometry of elements, and observes when another responder (scroll view\n * etc) has stolen the touch lock. It notifies your component when it should\n * give feedback to the user. (bouncing/highlighting/unhighlighting).\n *\n * - When a touch was activated (typically you highlight)\n * - When a touch was deactivated (typically you unhighlight)\n * - When a touch was \"pressed\" - a touch ended while still within the geometry\n * of the element, and no other element (like scroller) has \"stolen\" touch\n * lock (\"responder\") (Typically you bounce the element).\n *\n * A good tap interaction isn't as simple as you might think. There should be a\n * slight delay before showing a highlight when starting a touch. If a\n * subsequent touch move exceeds the boundary of the element, it should\n * unhighlight, but if that same touch is brought back within the boundary, it\n * should rehighlight again. A touch can move in and out of that boundary\n * several times, each time toggling highlighting, but a \"press\" is only\n * triggered if that touch ends while within the element's boundary and no\n * scroller (or anything else) has stolen the lock on touches.\n *\n * To create a new type of component that handles interaction using the\n * `Touchable` mixin, do the following:\n *\n * - Initialize the `Touchable` state.\n *\n * getInitialState: function() {\n * return merge(this.touchableGetInitialState(), yourComponentState);\n * }\n *\n * - Choose the rendered component who's touches should start the interactive\n * sequence. On that rendered node, forward all `Touchable` responder\n * handlers. You can choose any rendered node you like. Choose a node whose\n * hit target you'd like to instigate the interaction sequence:\n *\n * // In render function:\n * return (\n * \n * \n * Even though the hit detection/interactions are triggered by the\n * wrapping (typically larger) node, we usually end up implementing\n * custom logic that highlights this inner one.\n * \n * \n * );\n *\n * - You may set up your own handlers for each of these events, so long as you\n * also invoke the `touchable*` handlers inside of your custom handler.\n *\n * - Implement the handlers on your component class in order to provide\n * feedback to the user. See documentation for each of these class methods\n * that you should implement.\n *\n * touchableHandlePress: function() {\n * this.performBounceAnimation(); // or whatever you want to do.\n * },\n * touchableHandleActivePressIn: function() {\n * this.beginHighlighting(...); // Whatever you like to convey activation\n * },\n * touchableHandleActivePressOut: function() {\n * this.endHighlighting(...); // Whatever you like to convey deactivation\n * },\n *\n * - There are more advanced methods you can implement (see documentation below):\n * touchableGetHighlightDelayMS: function() {\n * return 20;\n * }\n * // In practice, *always* use a predeclared constant (conserve memory).\n * touchableGetPressRectOffset: function() {\n * return {top: 20, left: 20, right: 20, bottom: 100};\n * }\n */\n\n/**\n * Touchable states.\n */\n\nconst States = {\n NOT_RESPONDER: 'NOT_RESPONDER', // Not the responder\n RESPONDER_INACTIVE_PRESS_IN: 'RESPONDER_INACTIVE_PRESS_IN', // Responder, inactive, in the `PressRect`\n RESPONDER_INACTIVE_PRESS_OUT: 'RESPONDER_INACTIVE_PRESS_OUT', // Responder, inactive, out of `PressRect`\n RESPONDER_ACTIVE_PRESS_IN: 'RESPONDER_ACTIVE_PRESS_IN', // Responder, active, in the `PressRect`\n RESPONDER_ACTIVE_PRESS_OUT: 'RESPONDER_ACTIVE_PRESS_OUT', // Responder, active, out of `PressRect`\n RESPONDER_ACTIVE_LONG_PRESS_IN: 'RESPONDER_ACTIVE_LONG_PRESS_IN', // Responder, active, in the `PressRect`, after long press threshold\n RESPONDER_ACTIVE_LONG_PRESS_OUT: 'RESPONDER_ACTIVE_LONG_PRESS_OUT', // Responder, active, out of `PressRect`, after long press threshold\n ERROR: 'ERROR',\n};\n\ntype State =\n | typeof States.NOT_RESPONDER\n | typeof States.RESPONDER_INACTIVE_PRESS_IN\n | typeof States.RESPONDER_INACTIVE_PRESS_OUT\n | typeof States.RESPONDER_ACTIVE_PRESS_IN\n | typeof States.RESPONDER_ACTIVE_PRESS_OUT\n | typeof States.RESPONDER_ACTIVE_LONG_PRESS_IN\n | typeof States.RESPONDER_ACTIVE_LONG_PRESS_OUT\n | typeof States.ERROR;\n\n/*\n * Quick lookup map for states that are considered to be \"active\"\n */\n\nconst baseStatesConditions = {\n NOT_RESPONDER: false,\n RESPONDER_INACTIVE_PRESS_IN: false,\n RESPONDER_INACTIVE_PRESS_OUT: false,\n RESPONDER_ACTIVE_PRESS_IN: false,\n RESPONDER_ACTIVE_PRESS_OUT: false,\n RESPONDER_ACTIVE_LONG_PRESS_IN: false,\n RESPONDER_ACTIVE_LONG_PRESS_OUT: false,\n ERROR: false,\n};\n\nconst IsActive = {\n ...baseStatesConditions,\n RESPONDER_ACTIVE_PRESS_OUT: true,\n RESPONDER_ACTIVE_PRESS_IN: true,\n};\n\n/**\n * Quick lookup for states that are considered to be \"pressing\" and are\n * therefore eligible to result in a \"selection\" if the press stops.\n */\nconst IsPressingIn = {\n ...baseStatesConditions,\n RESPONDER_INACTIVE_PRESS_IN: true,\n RESPONDER_ACTIVE_PRESS_IN: true,\n RESPONDER_ACTIVE_LONG_PRESS_IN: true,\n};\n\nconst IsLongPressingIn = {\n ...baseStatesConditions,\n RESPONDER_ACTIVE_LONG_PRESS_IN: true,\n};\n\n/**\n * Inputs to the state machine.\n */\nconst Signals = {\n DELAY: 'DELAY',\n RESPONDER_GRANT: 'RESPONDER_GRANT',\n RESPONDER_RELEASE: 'RESPONDER_RELEASE',\n RESPONDER_TERMINATED: 'RESPONDER_TERMINATED',\n ENTER_PRESS_RECT: 'ENTER_PRESS_RECT',\n LEAVE_PRESS_RECT: 'LEAVE_PRESS_RECT',\n LONG_PRESS_DETECTED: 'LONG_PRESS_DETECTED',\n};\n\ntype Signal =\n | typeof Signals.DELAY\n | typeof Signals.RESPONDER_GRANT\n | typeof Signals.RESPONDER_RELEASE\n | typeof Signals.RESPONDER_TERMINATED\n | typeof Signals.ENTER_PRESS_RECT\n | typeof Signals.LEAVE_PRESS_RECT\n | typeof Signals.LONG_PRESS_DETECTED;\n\n/**\n * Mapping from States x Signals => States\n */\nconst Transitions = {\n NOT_RESPONDER: {\n DELAY: States.ERROR,\n RESPONDER_GRANT: States.RESPONDER_INACTIVE_PRESS_IN,\n RESPONDER_RELEASE: States.ERROR,\n RESPONDER_TERMINATED: States.ERROR,\n ENTER_PRESS_RECT: States.ERROR,\n LEAVE_PRESS_RECT: States.ERROR,\n LONG_PRESS_DETECTED: States.ERROR,\n },\n RESPONDER_INACTIVE_PRESS_IN: {\n DELAY: States.RESPONDER_ACTIVE_PRESS_IN,\n RESPONDER_GRANT: States.ERROR,\n RESPONDER_RELEASE: States.NOT_RESPONDER,\n RESPONDER_TERMINATED: States.NOT_RESPONDER,\n ENTER_PRESS_RECT: States.RESPONDER_INACTIVE_PRESS_IN,\n LEAVE_PRESS_RECT: States.RESPONDER_INACTIVE_PRESS_OUT,\n LONG_PRESS_DETECTED: States.ERROR,\n },\n RESPONDER_INACTIVE_PRESS_OUT: {\n DELAY: States.RESPONDER_ACTIVE_PRESS_OUT,\n RESPONDER_GRANT: States.ERROR,\n RESPONDER_RELEASE: States.NOT_RESPONDER,\n RESPONDER_TERMINATED: States.NOT_RESPONDER,\n ENTER_PRESS_RECT: States.RESPONDER_INACTIVE_PRESS_IN,\n LEAVE_PRESS_RECT: States.RESPONDER_INACTIVE_PRESS_OUT,\n LONG_PRESS_DETECTED: States.ERROR,\n },\n RESPONDER_ACTIVE_PRESS_IN: {\n DELAY: States.ERROR,\n RESPONDER_GRANT: States.ERROR,\n RESPONDER_RELEASE: States.NOT_RESPONDER,\n RESPONDER_TERMINATED: States.NOT_RESPONDER,\n ENTER_PRESS_RECT: States.RESPONDER_ACTIVE_PRESS_IN,\n LEAVE_PRESS_RECT: States.RESPONDER_ACTIVE_PRESS_OUT,\n LONG_PRESS_DETECTED: States.RESPONDER_ACTIVE_LONG_PRESS_IN,\n },\n RESPONDER_ACTIVE_PRESS_OUT: {\n DELAY: States.ERROR,\n RESPONDER_GRANT: States.ERROR,\n RESPONDER_RELEASE: States.NOT_RESPONDER,\n RESPONDER_TERMINATED: States.NOT_RESPONDER,\n ENTER_PRESS_RECT: States.RESPONDER_ACTIVE_PRESS_IN,\n LEAVE_PRESS_RECT: States.RESPONDER_ACTIVE_PRESS_OUT,\n LONG_PRESS_DETECTED: States.ERROR,\n },\n RESPONDER_ACTIVE_LONG_PRESS_IN: {\n DELAY: States.ERROR,\n RESPONDER_GRANT: States.ERROR,\n RESPONDER_RELEASE: States.NOT_RESPONDER,\n RESPONDER_TERMINATED: States.NOT_RESPONDER,\n ENTER_PRESS_RECT: States.RESPONDER_ACTIVE_LONG_PRESS_IN,\n LEAVE_PRESS_RECT: States.RESPONDER_ACTIVE_LONG_PRESS_OUT,\n LONG_PRESS_DETECTED: States.RESPONDER_ACTIVE_LONG_PRESS_IN,\n },\n RESPONDER_ACTIVE_LONG_PRESS_OUT: {\n DELAY: States.ERROR,\n RESPONDER_GRANT: States.ERROR,\n RESPONDER_RELEASE: States.NOT_RESPONDER,\n RESPONDER_TERMINATED: States.NOT_RESPONDER,\n ENTER_PRESS_RECT: States.RESPONDER_ACTIVE_LONG_PRESS_IN,\n LEAVE_PRESS_RECT: States.RESPONDER_ACTIVE_LONG_PRESS_OUT,\n LONG_PRESS_DETECTED: States.ERROR,\n },\n error: {\n DELAY: States.NOT_RESPONDER,\n RESPONDER_GRANT: States.RESPONDER_INACTIVE_PRESS_IN,\n RESPONDER_RELEASE: States.NOT_RESPONDER,\n RESPONDER_TERMINATED: States.NOT_RESPONDER,\n ENTER_PRESS_RECT: States.NOT_RESPONDER,\n LEAVE_PRESS_RECT: States.NOT_RESPONDER,\n LONG_PRESS_DETECTED: States.NOT_RESPONDER,\n },\n};\n\n// ==== Typical Constants for integrating into UI components ====\n// var HIT_EXPAND_PX = 20;\n// var HIT_VERT_OFFSET_PX = 10;\nconst HIGHLIGHT_DELAY_MS = 130;\n\nconst PRESS_EXPAND_PX = 20;\n\nconst LONG_PRESS_THRESHOLD = 500;\n\nconst LONG_PRESS_DELAY_MS = LONG_PRESS_THRESHOLD - HIGHLIGHT_DELAY_MS;\n\nconst LONG_PRESS_ALLOWED_MOVEMENT = 10;\n\n// Default amount \"active\" region protrudes beyond box\n\n/**\n * By convention, methods prefixed with underscores are meant to be @private,\n * and not @protected. Mixers shouldn't access them - not even to provide them\n * as callback handlers.\n *\n *\n * ========== Geometry =========\n * `Touchable` only assumes that there exists a `HitRect` node. The `PressRect`\n * is an abstract box that is extended beyond the `HitRect`.\n *\n * +--------------------------+\n * | | - \"Start\" events in `HitRect` cause `HitRect`\n * | +--------------------+ | to become the responder.\n * | | +--------------+ | | - `HitRect` is typically expanded around\n * | | | | | | the `VisualRect`, but shifted downward.\n * | | | VisualRect | | | - After pressing down, after some delay,\n * | | | | | | and before letting up, the Visual React\n * | | +--------------+ | | will become \"active\". This makes it eligible\n * | | HitRect | | for being highlighted (so long as the\n * | +--------------------+ | press remains in the `PressRect`).\n * | PressRect o |\n * +----------------------|---+\n * Out Region |\n * +-----+ This gap between the `HitRect` and\n * `PressRect` allows a touch to move far away\n * from the original hit rect, and remain\n * highlighted, and eligible for a \"Press\".\n * Customize this via\n * `touchableGetPressRectOffset()`.\n *\n *\n *\n * ======= State Machine =======\n *\n * +-------------+ <---+ RESPONDER_RELEASE\n * |NOT_RESPONDER|\n * +-------------+ <---+ RESPONDER_TERMINATED\n * +\n * | RESPONDER_GRANT (HitRect)\n * v\n * +---------------------------+ DELAY +-------------------------+ T + DELAY +------------------------------+\n * |RESPONDER_INACTIVE_PRESS_IN|+-------->|RESPONDER_ACTIVE_PRESS_IN| +------------> |RESPONDER_ACTIVE_LONG_PRESS_IN|\n * +---------------------------+ +-------------------------+ +------------------------------+\n * + ^ + ^ + ^\n * |LEAVE_ |ENTER_ |LEAVE_ |ENTER_ |LEAVE_ |ENTER_\n * |PRESS_RECT |PRESS_RECT |PRESS_RECT |PRESS_RECT |PRESS_RECT |PRESS_RECT\n * | | | | | |\n * v + v + v +\n * +----------------------------+ DELAY +--------------------------+ +-------------------------------+\n * |RESPONDER_INACTIVE_PRESS_OUT|+------->|RESPONDER_ACTIVE_PRESS_OUT| |RESPONDER_ACTIVE_LONG_PRESS_OUT|\n * +----------------------------+ +--------------------------+ +-------------------------------+\n *\n * T + DELAY => LONG_PRESS_DELAY_MS + DELAY\n *\n * Not drawn are the side effects of each transition. The most important side\n * effect is the `touchableHandlePress` abstract method invocation that occurs\n * when a responder is released while in either of the \"Press\" states.\n *\n * The other important side effects are the highlight abstract method\n * invocations (internal callbacks) to be implemented by the mixer.\n *\n *\n * @lends Touchable.prototype\n */\nconst TouchableMixin = {\n componentDidMount: function () {\n if (!Platform.isTV) {\n return;\n }\n },\n\n /**\n * Clear all timeouts on unmount\n */\n /* $FlowFixMe[missing-this-annot] The 'this' type annotation(s) required by\n * Flow's LTI update could not be added via codemod */\n componentWillUnmount: function () {\n this.touchableDelayTimeout && clearTimeout(this.touchableDelayTimeout);\n this.longPressDelayTimeout && clearTimeout(this.longPressDelayTimeout);\n this.pressOutDelayTimeout && clearTimeout(this.pressOutDelayTimeout);\n },\n\n /**\n * It's prefer that mixins determine state in this way, having the class\n * explicitly mix the state in the one and only `getInitialState` method.\n *\n * @return {object} State object to be placed inside of\n * `this.state.touchable`.\n */\n touchableGetInitialState: function (): $TEMPORARY$object<{|\n touchable: $TEMPORARY$object<{|responderID: null, touchState: void|}>,\n |}> {\n return {\n touchable: {touchState: undefined, responderID: null},\n };\n },\n\n // ==== Hooks to Gesture Responder system ====\n /**\n * Must return true if embedded in a native platform scroll view.\n */\n /* $FlowFixMe[missing-this-annot] The 'this' type annotation(s) required by\n * Flow's LTI update could not be added via codemod */\n touchableHandleResponderTerminationRequest: function (): any {\n return !this.props.rejectResponderTermination;\n },\n\n /**\n * Must return true to start the process of `Touchable`.\n */\n /* $FlowFixMe[missing-this-annot] The 'this' type annotation(s) required by\n * Flow's LTI update could not be added via codemod */\n touchableHandleStartShouldSetResponder: function (): any {\n return !this.props.disabled;\n },\n\n /**\n * Return true to cancel press on long press.\n */\n touchableLongPressCancelsPress: function (): boolean {\n return true;\n },\n\n /**\n * Place as callback for a DOM element's `onResponderGrant` event.\n * @param {SyntheticEvent} e Synthetic event from event system.\n *\n */\n /* $FlowFixMe[missing-this-annot] The 'this' type annotation(s) required by\n * Flow's LTI update could not be added via codemod */\n touchableHandleResponderGrant: function (e: PressEvent) {\n const dispatchID = e.currentTarget;\n // Since e is used in a callback invoked on another event loop\n // (as in setTimeout etc), we need to call e.persist() on the\n // event to make sure it doesn't get reused in the event object pool.\n e.persist();\n\n this.pressOutDelayTimeout && clearTimeout(this.pressOutDelayTimeout);\n this.pressOutDelayTimeout = null;\n\n this.state.touchable.touchState = States.NOT_RESPONDER;\n this.state.touchable.responderID = dispatchID;\n this._receiveSignal(Signals.RESPONDER_GRANT, e);\n let delayMS =\n this.touchableGetHighlightDelayMS !== undefined\n ? Math.max(this.touchableGetHighlightDelayMS(), 0)\n : HIGHLIGHT_DELAY_MS;\n delayMS = isNaN(delayMS) ? HIGHLIGHT_DELAY_MS : delayMS;\n if (delayMS !== 0) {\n this.touchableDelayTimeout = setTimeout(\n this._handleDelay.bind(this, e),\n delayMS,\n );\n } else {\n this._handleDelay(e);\n }\n\n let longDelayMS =\n this.touchableGetLongPressDelayMS !== undefined\n ? Math.max(this.touchableGetLongPressDelayMS(), 10)\n : LONG_PRESS_DELAY_MS;\n longDelayMS = isNaN(longDelayMS) ? LONG_PRESS_DELAY_MS : longDelayMS;\n this.longPressDelayTimeout = setTimeout(\n this._handleLongDelay.bind(this, e),\n longDelayMS + delayMS,\n );\n },\n\n /**\n * Place as callback for a DOM element's `onResponderRelease` event.\n */\n /* $FlowFixMe[missing-this-annot] The 'this' type annotation(s) required by\n * Flow's LTI update could not be added via codemod */\n touchableHandleResponderRelease: function (e: PressEvent) {\n this.pressInLocation = null;\n this._receiveSignal(Signals.RESPONDER_RELEASE, e);\n },\n\n /**\n * Place as callback for a DOM element's `onResponderTerminate` event.\n */\n /* $FlowFixMe[missing-this-annot] The 'this' type annotation(s) required by\n * Flow's LTI update could not be added via codemod */\n touchableHandleResponderTerminate: function (e: PressEvent) {\n this.pressInLocation = null;\n this._receiveSignal(Signals.RESPONDER_TERMINATED, e);\n },\n\n /**\n * Place as callback for a DOM element's `onResponderMove` event.\n */\n /* $FlowFixMe[missing-this-annot] The 'this' type annotation(s) required by\n * Flow's LTI update could not be added via codemod */\n touchableHandleResponderMove: function (e: PressEvent) {\n // Measurement may not have returned yet.\n if (!this.state.touchable.positionOnActivate) {\n return;\n }\n\n const positionOnActivate = this.state.touchable.positionOnActivate;\n const dimensionsOnActivate = this.state.touchable.dimensionsOnActivate;\n const pressRectOffset = this.touchableGetPressRectOffset\n ? this.touchableGetPressRectOffset()\n : {\n left: PRESS_EXPAND_PX,\n right: PRESS_EXPAND_PX,\n top: PRESS_EXPAND_PX,\n bottom: PRESS_EXPAND_PX,\n };\n\n let pressExpandLeft = pressRectOffset.left;\n let pressExpandTop = pressRectOffset.top;\n let pressExpandRight = pressRectOffset.right;\n let pressExpandBottom = pressRectOffset.bottom;\n\n const hitSlop = this.touchableGetHitSlop\n ? this.touchableGetHitSlop()\n : null;\n\n if (hitSlop) {\n pressExpandLeft += hitSlop.left || 0;\n pressExpandTop += hitSlop.top || 0;\n pressExpandRight += hitSlop.right || 0;\n pressExpandBottom += hitSlop.bottom || 0;\n }\n\n const touch = extractSingleTouch(e.nativeEvent);\n const pageX = touch && touch.pageX;\n const pageY = touch && touch.pageY;\n\n if (this.pressInLocation) {\n const movedDistance = this._getDistanceBetweenPoints(\n pageX,\n pageY,\n this.pressInLocation.pageX,\n this.pressInLocation.pageY,\n );\n if (movedDistance > LONG_PRESS_ALLOWED_MOVEMENT) {\n this._cancelLongPressDelayTimeout();\n }\n }\n\n const isTouchWithinActive =\n pageX > positionOnActivate.left - pressExpandLeft &&\n pageY > positionOnActivate.top - pressExpandTop &&\n pageX <\n positionOnActivate.left +\n dimensionsOnActivate.width +\n pressExpandRight &&\n pageY <\n positionOnActivate.top +\n dimensionsOnActivate.height +\n pressExpandBottom;\n if (isTouchWithinActive) {\n const prevState = this.state.touchable.touchState;\n this._receiveSignal(Signals.ENTER_PRESS_RECT, e);\n const curState = this.state.touchable.touchState;\n if (\n curState === States.RESPONDER_INACTIVE_PRESS_IN &&\n prevState !== States.RESPONDER_INACTIVE_PRESS_IN\n ) {\n // fix for t7967420\n this._cancelLongPressDelayTimeout();\n }\n } else {\n this._cancelLongPressDelayTimeout();\n this._receiveSignal(Signals.LEAVE_PRESS_RECT, e);\n }\n },\n\n /**\n * Invoked when the item receives focus. Mixers might override this to\n * visually distinguish the `VisualRect` so that the user knows that it\n * currently has the focus. Most platforms only support a single element being\n * focused at a time, in which case there may have been a previously focused\n * element that was blurred just prior to this. This can be overridden when\n * using `Touchable.Mixin.withoutDefaultFocusAndBlur`.\n */\n /* $FlowFixMe[missing-this-annot] The 'this' type annotation(s) required by\n * Flow's LTI update could not be added via codemod */\n touchableHandleFocus: function (e: Event) {\n this.props.onFocus && this.props.onFocus(e);\n },\n\n /**\n * Invoked when the item loses focus. Mixers might override this to\n * visually distinguish the `VisualRect` so that the user knows that it\n * no longer has focus. Most platforms only support a single element being\n * focused at a time, in which case the focus may have moved to another.\n * This can be overridden when using\n * `Touchable.Mixin.withoutDefaultFocusAndBlur`.\n */\n /* $FlowFixMe[missing-this-annot] The 'this' type annotation(s) required by\n * Flow's LTI update could not be added via codemod */\n touchableHandleBlur: function (e: Event) {\n this.props.onBlur && this.props.onBlur(e);\n },\n\n // ==== Abstract Application Callbacks ====\n\n /**\n * Invoked when the item should be highlighted. Mixers should implement this\n * to visually distinguish the `VisualRect` so that the user knows that\n * releasing a touch will result in a \"selection\" (analog to click).\n *\n * @abstract\n * touchableHandleActivePressIn: function,\n */\n\n /**\n * Invoked when the item is \"active\" (in that it is still eligible to become\n * a \"select\") but the touch has left the `PressRect`. Usually the mixer will\n * want to unhighlight the `VisualRect`. If the user (while pressing) moves\n * back into the `PressRect` `touchableHandleActivePressIn` will be invoked\n * again and the mixer should probably highlight the `VisualRect` again. This\n * event will not fire on an `touchEnd/mouseUp` event, only move events while\n * the user is depressing the mouse/touch.\n *\n * @abstract\n * touchableHandleActivePressOut: function\n */\n\n /**\n * Invoked when the item is \"selected\" - meaning the interaction ended by\n * letting up while the item was either in the state\n * `RESPONDER_ACTIVE_PRESS_IN` or `RESPONDER_INACTIVE_PRESS_IN`.\n *\n * @abstract\n * touchableHandlePress: function\n */\n\n /**\n * Invoked when the item is long pressed - meaning the interaction ended by\n * letting up while the item was in `RESPONDER_ACTIVE_LONG_PRESS_IN`. If\n * `touchableHandleLongPress` is *not* provided, `touchableHandlePress` will\n * be called as it normally is. If `touchableHandleLongPress` is provided, by\n * default any `touchableHandlePress` callback will not be invoked. To\n * override this default behavior, override `touchableLongPressCancelsPress`\n * to return false. As a result, `touchableHandlePress` will be called when\n * lifting up, even if `touchableHandleLongPress` has also been called.\n *\n * @abstract\n * touchableHandleLongPress: function\n */\n\n /**\n * Returns the number of millis to wait before triggering a highlight.\n *\n * @abstract\n * touchableGetHighlightDelayMS: function\n */\n\n /**\n * Returns the amount to extend the `HitRect` into the `PressRect`. Positive\n * numbers mean the size expands outwards.\n *\n * @abstract\n * touchableGetPressRectOffset: function\n */\n\n // ==== Internal Logic ====\n\n /**\n * Measures the `HitRect` node on activation. The Bounding rectangle is with\n * respect to viewport - not page, so adding the `pageXOffset/pageYOffset`\n * should result in points that are in the same coordinate system as an\n * event's `globalX/globalY` data values.\n *\n * - Consider caching this for the lifetime of the component, or possibly\n * being able to share this cache between any `ScrollMap` view.\n *\n * @sideeffects\n * @private\n */\n /* $FlowFixMe[missing-this-annot] The 'this' type annotation(s) required by\n * Flow's LTI update could not be added via codemod */\n _remeasureMetricsOnActivation: function () {\n const responderID = this.state.touchable.responderID;\n if (responderID == null) {\n return;\n }\n\n if (typeof responderID === 'number') {\n UIManager.measure(responderID, this._handleQueryLayout);\n } else {\n responderID.measure(this._handleQueryLayout);\n }\n },\n\n /* $FlowFixMe[missing-this-annot] The 'this' type annotation(s) required by\n * Flow's LTI update could not be added via codemod */\n _handleQueryLayout: function (\n l: number,\n t: number,\n w: number,\n h: number,\n globalX: number,\n globalY: number,\n ) {\n //don't do anything UIManager failed to measure node\n if (!l && !t && !w && !h && !globalX && !globalY) {\n return;\n }\n this.state.touchable.positionOnActivate &&\n Position.release(this.state.touchable.positionOnActivate);\n this.state.touchable.dimensionsOnActivate &&\n BoundingDimensions.release(this.state.touchable.dimensionsOnActivate);\n this.state.touchable.positionOnActivate = Position.getPooled(\n globalX,\n globalY,\n );\n this.state.touchable.dimensionsOnActivate = BoundingDimensions.getPooled(\n w,\n h,\n );\n },\n\n /* $FlowFixMe[missing-this-annot] The 'this' type annotation(s) required by\n * Flow's LTI update could not be added via codemod */\n _handleDelay: function (e: PressEvent) {\n this.touchableDelayTimeout = null;\n this._receiveSignal(Signals.DELAY, e);\n },\n\n /* $FlowFixMe[missing-this-annot] The 'this' type annotation(s) required by\n * Flow's LTI update could not be added via codemod */\n _handleLongDelay: function (e: PressEvent) {\n this.longPressDelayTimeout = null;\n const curState = this.state.touchable.touchState;\n if (\n curState === States.RESPONDER_ACTIVE_PRESS_IN ||\n curState === States.RESPONDER_ACTIVE_LONG_PRESS_IN\n ) {\n this._receiveSignal(Signals.LONG_PRESS_DETECTED, e);\n }\n },\n\n /**\n * Receives a state machine signal, performs side effects of the transition\n * and stores the new state. Validates the transition as well.\n *\n * @param {Signals} signal State machine signal.\n * @throws Error if invalid state transition or unrecognized signal.\n * @sideeffects\n */\n /* $FlowFixMe[missing-this-annot] The 'this' type annotation(s) required by\n * Flow's LTI update could not be added via codemod */\n _receiveSignal: function (signal: Signal, e: PressEvent) {\n const responderID = this.state.touchable.responderID;\n const curState = this.state.touchable.touchState;\n const nextState = Transitions[curState] && Transitions[curState][signal];\n if (!responderID && signal === Signals.RESPONDER_RELEASE) {\n return;\n }\n if (!nextState) {\n throw new Error(\n 'Unrecognized signal `' +\n signal +\n '` or state `' +\n curState +\n '` for Touchable responder `' +\n typeof this.state.touchable.responderID ===\n 'number'\n ? this.state.touchable.responderID\n : 'host component' + '`',\n );\n }\n if (nextState === States.ERROR) {\n throw new Error(\n 'Touchable cannot transition from `' +\n curState +\n '` to `' +\n signal +\n '` for responder `' +\n typeof this.state.touchable.responderID ===\n 'number'\n ? this.state.touchable.responderID\n : '<>' + '`',\n );\n }\n if (curState !== nextState) {\n this._performSideEffectsForTransition(curState, nextState, signal, e);\n this.state.touchable.touchState = nextState;\n }\n },\n\n /* $FlowFixMe[missing-this-annot] The 'this' type annotation(s) required by\n * Flow's LTI update could not be added via codemod */\n _cancelLongPressDelayTimeout: function () {\n this.longPressDelayTimeout && clearTimeout(this.longPressDelayTimeout);\n this.longPressDelayTimeout = null;\n },\n\n _isHighlight: function (state: State): boolean {\n return (\n state === States.RESPONDER_ACTIVE_PRESS_IN ||\n state === States.RESPONDER_ACTIVE_LONG_PRESS_IN\n );\n },\n\n /* $FlowFixMe[missing-this-annot] The 'this' type annotation(s) required by\n * Flow's LTI update could not be added via codemod */\n _savePressInLocation: function (e: PressEvent) {\n const touch = extractSingleTouch(e.nativeEvent);\n const pageX = touch && touch.pageX;\n const pageY = touch && touch.pageY;\n const locationX = touch && touch.locationX;\n const locationY = touch && touch.locationY;\n this.pressInLocation = {pageX, pageY, locationX, locationY};\n },\n\n _getDistanceBetweenPoints: function (\n aX: number,\n aY: number,\n bX: number,\n bY: number,\n ): number {\n const deltaX = aX - bX;\n const deltaY = aY - bY;\n return Math.sqrt(deltaX * deltaX + deltaY * deltaY);\n },\n\n /**\n * Will perform a transition between touchable states, and identify any\n * highlighting or unhighlighting that must be performed for this particular\n * transition.\n *\n * @param {States} curState Current Touchable state.\n * @param {States} nextState Next Touchable state.\n * @param {Signal} signal Signal that triggered the transition.\n * @param {Event} e Native event.\n * @sideeffects\n */\n /* $FlowFixMe[missing-this-annot] The 'this' type annotation(s) required by\n * Flow's LTI update could not be added via codemod */\n _performSideEffectsForTransition: function (\n curState: State,\n nextState: State,\n signal: Signal,\n e: PressEvent,\n ) {\n const curIsHighlight = this._isHighlight(curState);\n const newIsHighlight = this._isHighlight(nextState);\n\n const isFinalSignal =\n signal === Signals.RESPONDER_TERMINATED ||\n signal === Signals.RESPONDER_RELEASE;\n\n if (isFinalSignal) {\n this._cancelLongPressDelayTimeout();\n }\n\n const isInitialTransition =\n curState === States.NOT_RESPONDER &&\n nextState === States.RESPONDER_INACTIVE_PRESS_IN;\n\n const isActiveTransition = !IsActive[curState] && IsActive[nextState];\n if (isInitialTransition || isActiveTransition) {\n this._remeasureMetricsOnActivation();\n }\n\n if (IsPressingIn[curState] && signal === Signals.LONG_PRESS_DETECTED) {\n this.touchableHandleLongPress && this.touchableHandleLongPress(e);\n }\n\n if (newIsHighlight && !curIsHighlight) {\n this._startHighlight(e);\n } else if (!newIsHighlight && curIsHighlight) {\n this._endHighlight(e);\n }\n\n if (IsPressingIn[curState] && signal === Signals.RESPONDER_RELEASE) {\n const hasLongPressHandler = !!this.props.onLongPress;\n const pressIsLongButStillCallOnPress =\n IsLongPressingIn[curState] && // We *are* long pressing.. // But either has no long handler\n (!hasLongPressHandler || !this.touchableLongPressCancelsPress()); // or we're told to ignore it.\n\n const shouldInvokePress =\n !IsLongPressingIn[curState] || pressIsLongButStillCallOnPress;\n if (shouldInvokePress && this.touchableHandlePress) {\n if (!newIsHighlight && !curIsHighlight) {\n // we never highlighted because of delay, but we should highlight now\n this._startHighlight(e);\n this._endHighlight(e);\n }\n if (Platform.OS === 'android' && !this.props.touchSoundDisabled) {\n SoundManager.playTouchSound();\n }\n this.touchableHandlePress(e);\n }\n }\n\n this.touchableDelayTimeout && clearTimeout(this.touchableDelayTimeout);\n this.touchableDelayTimeout = null;\n },\n\n /* $FlowFixMe[missing-this-annot] The 'this' type annotation(s) required by\n * Flow's LTI update could not be added via codemod */\n _startHighlight: function (e: PressEvent) {\n this._savePressInLocation(e);\n this.touchableHandleActivePressIn && this.touchableHandleActivePressIn(e);\n },\n\n /* $FlowFixMe[missing-this-annot] The 'this' type annotation(s) required by\n * Flow's LTI update could not be added via codemod */\n _endHighlight: function (e: PressEvent) {\n if (this.touchableHandleActivePressOut) {\n if (\n this.touchableGetPressOutDelayMS &&\n this.touchableGetPressOutDelayMS()\n ) {\n this.pressOutDelayTimeout = setTimeout(() => {\n this.touchableHandleActivePressOut(e);\n }, this.touchableGetPressOutDelayMS());\n } else {\n this.touchableHandleActivePressOut(e);\n }\n }\n },\n\n withoutDefaultFocusAndBlur: ({}: {...}),\n};\n\n/**\n * Provide an optional version of the mixin where `touchableHandleFocus` and\n * `touchableHandleBlur` can be overridden. This allows appropriate defaults to\n * be set on TV platforms, without breaking existing implementations of\n * `Touchable`.\n */\nconst {\n touchableHandleFocus,\n touchableHandleBlur,\n ...TouchableMixinWithoutDefaultFocusAndBlur\n} = TouchableMixin;\nTouchableMixin.withoutDefaultFocusAndBlur =\n TouchableMixinWithoutDefaultFocusAndBlur;\n\nconst Touchable: TouchableType = {\n Mixin: TouchableMixin,\n /**\n * Renders a debugging overlay to visualize touch target with hitSlop (might not work on Android).\n */\n renderDebugView: ({\n color,\n hitSlop,\n }: {\n color: ColorValue,\n hitSlop: EdgeInsetsProp,\n ...\n }): null | React.Node => {\n if (__DEV__) {\n return ;\n }\n return null;\n },\n};\n\nmodule.exports = Touchable;\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 * @format\n */\n\n'use strict';\nimport PooledClass from './PooledClass';\n\nconst twoArgumentPooler = PooledClass.twoArgumentPooler;\n\n/**\n * PooledClass representing the bounding rectangle of a region.\n *\n * @param {number} width Width of bounding rectangle.\n * @param {number} height Height of bounding rectangle.\n * @constructor BoundingDimensions\n */\nfunction BoundingDimensions(width, height) {\n this.width = width;\n this.height = height;\n}\n\nBoundingDimensions.prototype.destructor = function () {\n this.width = null;\n this.height = null;\n};\n\n/**\n * @param {HTMLElement} element Element to return `BoundingDimensions` for.\n * @return {BoundingDimensions} Bounding dimensions of `element`.\n */\nBoundingDimensions.getPooledFromElement = function (element) {\n return BoundingDimensions.getPooled(\n element.offsetWidth,\n element.offsetHeight,\n );\n};\n\nPooledClass.addPoolingTo(BoundingDimensions, twoArgumentPooler);\n\nmodule.exports = BoundingDimensions;\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 * @format\n * @flow\n */\n\n'use strict';\nimport invariant from 'invariant';\n\n/**\n * Static poolers. Several custom versions for each potential number of\n * arguments. A completely generic pooler is easy to implement, but would\n * require accessing the `arguments` object. In each of these, `this` refers to\n * the Class itself, not an instance. If any others are needed, simply add them\n * here, or in their own files.\n */\n/* $FlowFixMe[missing-this-annot] The 'this' type annotation(s) required by\n * Flow's LTI update could not be added via codemod */\nconst oneArgumentPooler = function (copyFieldsFrom: any) {\n const Klass = this; // eslint-disable-line consistent-this\n if (Klass.instancePool.length) {\n const instance = Klass.instancePool.pop();\n Klass.call(instance, copyFieldsFrom);\n return instance;\n } else {\n return new Klass(copyFieldsFrom);\n }\n};\n\n/* $FlowFixMe[missing-this-annot] The 'this' type annotation(s) required by\n * Flow's LTI update could not be added via codemod */\nconst twoArgumentPooler = function (a1: any, a2: any) {\n const Klass = this; // eslint-disable-line consistent-this\n if (Klass.instancePool.length) {\n const instance = Klass.instancePool.pop();\n Klass.call(instance, a1, a2);\n return instance;\n } else {\n return new Klass(a1, a2);\n }\n};\n\n/* $FlowFixMe[missing-this-annot] The 'this' type annotation(s) required by\n * Flow's LTI update could not be added via codemod */\nconst threeArgumentPooler = function (a1: any, a2: any, a3: any) {\n const Klass = this; // eslint-disable-line consistent-this\n if (Klass.instancePool.length) {\n const instance = Klass.instancePool.pop();\n Klass.call(instance, a1, a2, a3);\n return instance;\n } else {\n return new Klass(a1, a2, a3);\n }\n};\n\n/* $FlowFixMe[missing-this-annot] The 'this' type annotation(s) required by\n * Flow's LTI update could not be added via codemod */\nconst fourArgumentPooler = function (a1: any, a2: any, a3: any, a4: any) {\n const Klass = this; // eslint-disable-line consistent-this\n if (Klass.instancePool.length) {\n const instance = Klass.instancePool.pop();\n Klass.call(instance, a1, a2, a3, a4);\n return instance;\n } else {\n return new Klass(a1, a2, a3, a4);\n }\n};\n\n/* $FlowFixMe[missing-local-annot] The type annotation(s) required by Flow's\n * LTI update could not be added via codemod */\n/* $FlowFixMe[missing-this-annot] The 'this' type annotation(s) required by\n * Flow's LTI update could not be added via codemod */\nconst standardReleaser = function (instance) {\n const Klass = this; // eslint-disable-line consistent-this\n invariant(\n instance instanceof Klass,\n 'Trying to release an instance into a pool of a different type.',\n );\n instance.destructor();\n if (Klass.instancePool.length < Klass.poolSize) {\n Klass.instancePool.push(instance);\n }\n};\n\nconst DEFAULT_POOL_SIZE = 10;\nconst DEFAULT_POOLER = oneArgumentPooler;\n\ntype Pooler = any;\n\n/**\n * Augments `CopyConstructor` to be a poolable class, augmenting only the class\n * itself (statically) not adding any prototypical fields. Any CopyConstructor\n * you give this may have a `poolSize` property, and will look for a\n * prototypical `destructor` on instances.\n *\n * @param {Function} CopyConstructor Constructor that can be used to reset.\n * @param {Function} pooler Customizable pooler.\n */\nconst addPoolingTo = function (\n CopyConstructor: Class,\n pooler: Pooler,\n): Class & {\n getPooled(\n ...args: $ReadOnlyArray\n ): /* arguments of the constructor */ T,\n release(instance: mixed): void,\n ...\n} {\n // Casting as any so that flow ignores the actual implementation and trusts\n // it to match the type we declared\n const NewKlass = (CopyConstructor: any);\n NewKlass.instancePool = [];\n NewKlass.getPooled = pooler || DEFAULT_POOLER;\n if (!NewKlass.poolSize) {\n NewKlass.poolSize = DEFAULT_POOL_SIZE;\n }\n NewKlass.release = standardReleaser;\n return NewKlass;\n};\n\nconst PooledClass = {\n addPoolingTo: addPoolingTo,\n oneArgumentPooler: (oneArgumentPooler: Pooler),\n twoArgumentPooler: (twoArgumentPooler: Pooler),\n threeArgumentPooler: (threeArgumentPooler: Pooler),\n fourArgumentPooler: (fourArgumentPooler: Pooler),\n};\n\nmodule.exports = PooledClass;\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 * @format\n */\n\n'use strict';\nimport PooledClass from './PooledClass';\n\nconst twoArgumentPooler = PooledClass.twoArgumentPooler;\n\n/**\n * Position does not expose methods for construction via an `HTMLDOMElement`,\n * because it isn't meaningful to construct such a thing without first defining\n * a frame of reference.\n *\n * @param {number} windowStartKey Key that window starts at.\n * @param {number} windowEndKey Key that window ends at.\n */\nfunction Position(left, top) {\n this.left = left;\n this.top = top;\n}\n\nPosition.prototype.destructor = function () {\n this.left = null;\n this.top = null;\n};\n\nPooledClass.addPoolingTo(Position, twoArgumentPooler);\n\nmodule.exports = Position;\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 * @flow strict-local\n * @format\n */\n\nimport type {ColorValue} from '../../StyleSheet/StyleSheet';\nimport typeof TouchableWithoutFeedback from './TouchableWithoutFeedback';\n\nimport View from '../../Components/View/View';\nimport Pressability, {\n type PressabilityConfig,\n} from '../../Pressability/Pressability';\nimport {PressabilityDebugView} from '../../Pressability/PressabilityDebug';\nimport StyleSheet, {type ViewStyleProp} from '../../StyleSheet/StyleSheet';\nimport Platform from '../../Utilities/Platform';\nimport * as React from 'react';\n\ntype AndroidProps = $ReadOnly<{|\n nextFocusDown?: ?number,\n nextFocusForward?: ?number,\n nextFocusLeft?: ?number,\n nextFocusRight?: ?number,\n nextFocusUp?: ?number,\n|}>;\n\ntype IOSProps = $ReadOnly<{|\n hasTVPreferredFocus?: ?boolean,\n|}>;\n\ntype Props = $ReadOnly<{|\n ...React.ElementConfig,\n ...AndroidProps,\n ...IOSProps,\n\n activeOpacity?: ?number,\n underlayColor?: ?ColorValue,\n style?: ?ViewStyleProp,\n onShowUnderlay?: ?() => void,\n onHideUnderlay?: ?() => void,\n testOnly_pressed?: ?boolean,\n\n hostRef: React.Ref,\n|}>;\n\ntype ExtraStyles = $ReadOnly<{|\n child: ViewStyleProp,\n underlay: ViewStyleProp,\n|}>;\n\ntype State = $ReadOnly<{|\n pressability: Pressability,\n extraStyles: ?ExtraStyles,\n|}>;\n\n/**\n * A wrapper for making views respond properly to touches.\n * On press down, the opacity of the wrapped view is decreased, which allows\n * the underlay color to show through, darkening or tinting the view.\n *\n * The underlay comes from wrapping the child in a new View, which can affect\n * layout, and sometimes cause unwanted visual artifacts if not used correctly,\n * for example if the backgroundColor of the wrapped view isn't explicitly set\n * to an opaque color.\n *\n * TouchableHighlight must have one child (not zero or more than one).\n * If you wish to have several child components, wrap them in a View.\n *\n * Example:\n *\n * ```\n * renderButton: function() {\n * return (\n * \n * \n * \n * );\n * },\n * ```\n *\n *\n * ### Example\n *\n * ```ReactNativeWebPlayer\n * import React, { Component } from 'react'\n * import {\n * AppRegistry,\n * StyleSheet,\n * TouchableHighlight,\n * Text,\n * View,\n * } from 'react-native'\n *\n * class App extends Component {\n * constructor(props) {\n * super(props)\n * this.state = { count: 0 }\n * }\n *\n * onPress = () => {\n * this.setState({\n * count: this.state.count+1\n * })\n * }\n *\n * render() {\n * return (\n * \n * \n * Touch Here \n * \n * \n * \n * { this.state.count !== 0 ? this.state.count: null}\n * \n * \n * \n * )\n * }\n * }\n *\n * const styles = StyleSheet.create({\n * container: {\n * flex: 1,\n * justifyContent: 'center',\n * paddingHorizontal: 10\n * },\n * button: {\n * alignItems: 'center',\n * backgroundColor: '#DDDDDD',\n * padding: 10\n * },\n * countContainer: {\n * alignItems: 'center',\n * padding: 10\n * },\n * countText: {\n * color: '#FF00FF'\n * }\n * })\n *\n * AppRegistry.registerComponent('App', () => App)\n * ```\n *\n */\nclass TouchableHighlight extends React.Component {\n _hideTimeout: ?TimeoutID;\n _isMounted: boolean = false;\n\n state: State = {\n pressability: new Pressability(this._createPressabilityConfig()),\n extraStyles:\n this.props.testOnly_pressed === true ? this._createExtraStyles() : null,\n };\n\n _createPressabilityConfig(): PressabilityConfig {\n return {\n cancelable: !this.props.rejectResponderTermination,\n disabled:\n this.props.disabled != null\n ? this.props.disabled\n : this.props.accessibilityState?.disabled,\n hitSlop: this.props.hitSlop,\n delayLongPress: this.props.delayLongPress,\n delayPressIn: this.props.delayPressIn,\n delayPressOut: this.props.delayPressOut,\n minPressDuration: 0,\n pressRectOffset: this.props.pressRetentionOffset,\n android_disableSound: this.props.touchSoundDisabled,\n onBlur: event => {\n if (Platform.isTV) {\n this._hideUnderlay();\n }\n if (this.props.onBlur != null) {\n this.props.onBlur(event);\n }\n },\n onFocus: event => {\n if (Platform.isTV) {\n this._showUnderlay();\n }\n if (this.props.onFocus != null) {\n this.props.onFocus(event);\n }\n },\n onLongPress: this.props.onLongPress,\n onPress: event => {\n if (this._hideTimeout != null) {\n clearTimeout(this._hideTimeout);\n }\n if (!Platform.isTV) {\n this._showUnderlay();\n this._hideTimeout = setTimeout(() => {\n this._hideUnderlay();\n }, this.props.delayPressOut ?? 0);\n }\n if (this.props.onPress != null) {\n this.props.onPress(event);\n }\n },\n onPressIn: event => {\n if (this._hideTimeout != null) {\n clearTimeout(this._hideTimeout);\n this._hideTimeout = null;\n }\n this._showUnderlay();\n if (this.props.onPressIn != null) {\n this.props.onPressIn(event);\n }\n },\n onPressOut: event => {\n if (this._hideTimeout == null) {\n this._hideUnderlay();\n }\n if (this.props.onPressOut != null) {\n this.props.onPressOut(event);\n }\n },\n };\n }\n\n _createExtraStyles(): ExtraStyles {\n return {\n child: {opacity: this.props.activeOpacity ?? 0.85},\n underlay: {\n backgroundColor:\n this.props.underlayColor === undefined\n ? 'black'\n : this.props.underlayColor,\n },\n };\n }\n\n _showUnderlay(): void {\n if (!this._isMounted || !this._hasPressHandler()) {\n return;\n }\n this.setState({extraStyles: this._createExtraStyles()});\n if (this.props.onShowUnderlay != null) {\n this.props.onShowUnderlay();\n }\n }\n\n _hideUnderlay(): void {\n if (this._hideTimeout != null) {\n clearTimeout(this._hideTimeout);\n this._hideTimeout = null;\n }\n if (this.props.testOnly_pressed === true) {\n return;\n }\n if (this._hasPressHandler()) {\n this.setState({extraStyles: null});\n if (this.props.onHideUnderlay != null) {\n this.props.onHideUnderlay();\n }\n }\n }\n\n _hasPressHandler(): boolean {\n return (\n this.props.onPress != null ||\n this.props.onPressIn != null ||\n this.props.onPressOut != null ||\n this.props.onLongPress != null\n );\n }\n\n render(): React.Node {\n const child = React.Children.only(this.props.children);\n\n // BACKWARD-COMPATIBILITY: Focus and blur events were never supported before\n // adopting `Pressability`, so preserve that behavior.\n const {onBlur, onFocus, ...eventHandlersWithoutBlurAndFocus} =\n this.state.pressability.getEventHandlers();\n\n const accessibilityState =\n this.props.disabled != null\n ? {\n ...this.props.accessibilityState,\n disabled: this.props.disabled,\n }\n : this.props.accessibilityState;\n\n const accessibilityValue = {\n max: this.props['aria-valuemax'] ?? this.props.accessibilityValue?.max,\n min: this.props['aria-valuemin'] ?? this.props.accessibilityValue?.min,\n now: this.props['aria-valuenow'] ?? this.props.accessibilityValue?.now,\n text: this.props['aria-valuetext'] ?? this.props.accessibilityValue?.text,\n };\n\n const accessibilityLiveRegion =\n this.props['aria-live'] === 'off'\n ? 'none'\n : this.props['aria-live'] ?? this.props.accessibilityLiveRegion;\n\n const accessibilityLabel =\n this.props['aria-label'] ?? this.props.accessibilityLabel;\n return (\n \n {React.cloneElement(child, {\n style: StyleSheet.compose(\n child.props.style,\n this.state.extraStyles?.child,\n ),\n })}\n {__DEV__ ? (\n \n ) : null}\n \n );\n }\n\n componentDidMount(): void {\n this._isMounted = true;\n }\n\n componentDidUpdate(prevProps: Props, prevState: State) {\n this.state.pressability.configure(this._createPressabilityConfig());\n }\n\n componentWillUnmount(): void {\n this._isMounted = false;\n if (this._hideTimeout != null) {\n clearTimeout(this._hideTimeout);\n }\n this.state.pressability.reset();\n }\n}\n\nconst Touchable = (React.forwardRef((props, hostRef) => (\n \n)): React.AbstractComponent<\n $ReadOnly<$Diff|}>>,\n React.ElementRef,\n>);\n\nTouchable.displayName = 'TouchableHighlight';\n\nmodule.exports = Touchable;\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 * @flow strict-local\n * @format\n */\n\nimport type {\n AccessibilityActionEvent,\n AccessibilityActionInfo,\n AccessibilityRole,\n AccessibilityState,\n AccessibilityValue,\n} from '../../Components/View/ViewAccessibility';\nimport type {EdgeInsetsProp} from '../../StyleSheet/EdgeInsetsPropType';\nimport type {\n BlurEvent,\n FocusEvent,\n LayoutEvent,\n PressEvent,\n} from '../../Types/CoreEventTypes';\n\nimport View from '../../Components/View/View';\nimport Pressability, {\n type PressabilityConfig,\n} from '../../Pressability/Pressability';\nimport {PressabilityDebugView} from '../../Pressability/PressabilityDebug';\nimport * as React from 'react';\n\ntype Props = $ReadOnly<{|\n accessibilityActions?: ?$ReadOnlyArray,\n accessibilityElementsHidden?: ?boolean,\n accessibilityHint?: ?Stringish,\n accessibilityLanguage?: ?Stringish,\n accessibilityIgnoresInvertColors?: ?boolean,\n accessibilityLabel?: ?Stringish,\n accessibilityLiveRegion?: ?('none' | 'polite' | 'assertive'),\n accessibilityRole?: ?AccessibilityRole,\n accessibilityState?: ?AccessibilityState,\n accessibilityValue?: ?AccessibilityValue,\n 'aria-valuemax'?: AccessibilityValue['max'],\n 'aria-valuemin'?: AccessibilityValue['min'],\n 'aria-valuenow'?: AccessibilityValue['now'],\n 'aria-valuetext'?: AccessibilityValue['text'],\n accessibilityViewIsModal?: ?boolean,\n 'aria-modal'?: ?boolean,\n accessible?: ?boolean,\n /**\n * alias for accessibilityState\n *\n * see https://reactnative.dev/docs/accessibility#accessibilitystate\n */\n 'aria-busy'?: ?boolean,\n 'aria-checked'?: ?boolean | 'mixed',\n 'aria-disabled'?: ?boolean,\n 'aria-expanded'?: ?boolean,\n 'aria-selected'?: ?boolean,\n 'aria-hidden'?: ?boolean,\n 'aria-live'?: ?('polite' | 'assertive' | 'off'),\n 'aria-label'?: ?Stringish,\n children?: ?React.Node,\n delayLongPress?: ?number,\n delayPressIn?: ?number,\n delayPressOut?: ?number,\n disabled?: ?boolean,\n focusable?: ?boolean,\n hitSlop?: ?EdgeInsetsProp,\n id?: string,\n importantForAccessibility?: ?('auto' | 'yes' | 'no' | 'no-hide-descendants'),\n nativeID?: ?string,\n onAccessibilityAction?: ?(event: AccessibilityActionEvent) => mixed,\n onBlur?: ?(event: BlurEvent) => mixed,\n onFocus?: ?(event: FocusEvent) => mixed,\n onLayout?: ?(event: LayoutEvent) => mixed,\n onLongPress?: ?(event: PressEvent) => mixed,\n onPress?: ?(event: PressEvent) => mixed,\n onPressIn?: ?(event: PressEvent) => mixed,\n onPressOut?: ?(event: PressEvent) => mixed,\n pressRetentionOffset?: ?EdgeInsetsProp,\n rejectResponderTermination?: ?boolean,\n testID?: ?string,\n touchSoundDisabled?: ?boolean,\n|}>;\n\ntype State = $ReadOnly<{|\n pressability: Pressability,\n|}>;\n\nconst PASSTHROUGH_PROPS = [\n 'accessibilityActions',\n 'accessibilityElementsHidden',\n 'accessibilityHint',\n 'accessibilityLanguage',\n 'accessibilityIgnoresInvertColors',\n 'accessibilityLabel',\n 'accessibilityLiveRegion',\n 'accessibilityRole',\n 'accessibilityValue',\n 'aria-valuemax',\n 'aria-valuemin',\n 'aria-valuenow',\n 'aria-valuetext',\n 'accessibilityViewIsModal',\n 'aria-modal',\n 'hitSlop',\n 'importantForAccessibility',\n 'nativeID',\n 'onAccessibilityAction',\n 'onBlur',\n 'onFocus',\n 'onLayout',\n 'testID',\n];\n\nclass TouchableWithoutFeedback extends React.Component {\n state: State = {\n pressability: new Pressability(createPressabilityConfig(this.props)),\n };\n\n render(): React.Node {\n const element = React.Children.only(this.props.children);\n const children = [element.props.children];\n const ariaLive = this.props['aria-live'];\n\n if (__DEV__) {\n if (element.type === View) {\n children.push(\n ,\n );\n }\n }\n\n let _accessibilityState = {\n busy: this.props['aria-busy'] ?? this.props.accessibilityState?.busy,\n checked:\n this.props['aria-checked'] ?? this.props.accessibilityState?.checked,\n disabled:\n this.props['aria-disabled'] ?? this.props.accessibilityState?.disabled,\n expanded:\n this.props['aria-expanded'] ?? this.props.accessibilityState?.expanded,\n selected:\n this.props['aria-selected'] ?? this.props.accessibilityState?.selected,\n };\n\n // BACKWARD-COMPATIBILITY: Focus and blur events were never supported before\n // adopting `Pressability`, so preserve that behavior.\n const {onBlur, onFocus, ...eventHandlersWithoutBlurAndFocus} =\n this.state.pressability.getEventHandlers();\n\n const elementProps: {[string]: mixed, ...} = {\n ...eventHandlersWithoutBlurAndFocus,\n accessible: this.props.accessible !== false,\n accessibilityState:\n this.props.disabled != null\n ? {\n ..._accessibilityState,\n disabled: this.props.disabled,\n }\n : _accessibilityState,\n focusable:\n this.props.focusable !== false && this.props.onPress !== undefined,\n\n accessibilityElementsHidden:\n this.props['aria-hidden'] ?? this.props.accessibilityElementsHidden,\n importantForAccessibility:\n this.props['aria-hidden'] === true\n ? 'no-hide-descendants'\n : this.props.importantForAccessibility,\n accessibilityLiveRegion:\n ariaLive === 'off'\n ? 'none'\n : ariaLive ?? this.props.accessibilityLiveRegion,\n nativeID: this.props.id ?? this.props.nativeID,\n };\n for (const prop of PASSTHROUGH_PROPS) {\n if (this.props[prop] !== undefined) {\n elementProps[prop] = this.props[prop];\n }\n }\n\n return React.cloneElement(element, elementProps, ...children);\n }\n\n componentDidUpdate(): void {\n this.state.pressability.configure(createPressabilityConfig(this.props));\n }\n\n componentWillUnmount(): void {\n this.state.pressability.reset();\n }\n}\n\nfunction createPressabilityConfig({\n 'aria-disabled': ariaDisabled,\n ...props\n}: Props): PressabilityConfig {\n const accessibilityStateDisabled =\n ariaDisabled ?? props.accessibilityState?.disabled;\n return {\n cancelable: !props.rejectResponderTermination,\n disabled:\n props.disabled !== null ? props.disabled : accessibilityStateDisabled,\n hitSlop: props.hitSlop,\n delayLongPress: props.delayLongPress,\n delayPressIn: props.delayPressIn,\n delayPressOut: props.delayPressOut,\n minPressDuration: 0,\n pressRectOffset: props.pressRetentionOffset,\n android_disableSound: props.touchSoundDisabled,\n onBlur: props.onBlur,\n onFocus: props.onFocus,\n onLongPress: props.onLongPress,\n onPress: props.onPress,\n onPressIn: props.onPressIn,\n onPressOut: props.onPressOut,\n };\n}\n\nTouchableWithoutFeedback.displayName = 'TouchableWithoutFeedback';\n\nmodule.exports = TouchableWithoutFeedback;\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 * @flow\n * @format\n */\n\nimport type {ProcessedColorValue} from '../StyleSheet/processColor';\nimport type {ColorValue} from '../StyleSheet/StyleSheet';\n\nimport RCTActionSheetManager from './NativeActionSheetManager';\n\nconst processColor = require('../StyleSheet/processColor');\nconst invariant = require('invariant');\n\n/**\n * Display action sheets and share sheets on iOS.\n *\n * See https://reactnative.dev/docs/actionsheetios\n */\nconst ActionSheetIOS = {\n /**\n * Display an iOS action sheet.\n *\n * The `options` object must contain one or more of:\n *\n * - `options` (array of strings) - a list of button titles (required)\n * - `cancelButtonIndex` (int) - index of cancel button in `options`\n * - `destructiveButtonIndex` (int or array of ints) - index or indices of destructive buttons in `options`\n * - `title` (string) - a title to show above the action sheet\n * - `message` (string) - a message to show below the title\n * - `disabledButtonIndices` (array of numbers) - a list of button indices which should be disabled\n *\n * The 'callback' function takes one parameter, the zero-based index\n * of the selected item.\n *\n * See https://reactnative.dev/docs/actionsheetios#showactionsheetwithoptions\n */\n showActionSheetWithOptions(\n options: {|\n +title?: ?string,\n +message?: ?string,\n +options: Array,\n +destructiveButtonIndex?: ?number | ?Array,\n +cancelButtonIndex?: ?number,\n +anchor?: ?number,\n +tintColor?: ColorValue | ProcessedColorValue,\n +cancelButtonTintColor?: ColorValue | ProcessedColorValue,\n +userInterfaceStyle?: string,\n +disabledButtonIndices?: Array,\n |},\n callback: (buttonIndex: number) => void,\n ) {\n invariant(\n typeof options === 'object' && options !== null,\n 'Options must be a valid object',\n );\n invariant(typeof callback === 'function', 'Must provide a valid callback');\n invariant(RCTActionSheetManager, \"ActionSheetManager doesn't exist\");\n\n const {\n tintColor,\n cancelButtonTintColor,\n destructiveButtonIndex,\n ...remainingOptions\n } = options;\n let destructiveButtonIndices = null;\n\n if (Array.isArray(destructiveButtonIndex)) {\n destructiveButtonIndices = destructiveButtonIndex;\n } else if (typeof destructiveButtonIndex === 'number') {\n destructiveButtonIndices = [destructiveButtonIndex];\n }\n\n const processedTintColor = processColor(tintColor);\n const processedCancelButtonTintColor = processColor(cancelButtonTintColor);\n invariant(\n processedTintColor == null || typeof processedTintColor === 'number',\n 'Unexpected color given for ActionSheetIOS.showActionSheetWithOptions tintColor',\n );\n invariant(\n processedCancelButtonTintColor == null ||\n typeof processedCancelButtonTintColor === 'number',\n 'Unexpected color given for ActionSheetIOS.showActionSheetWithOptions cancelButtonTintColor',\n );\n RCTActionSheetManager.showActionSheetWithOptions(\n {\n ...remainingOptions,\n tintColor: processedTintColor,\n cancelButtonTintColor: processedCancelButtonTintColor,\n destructiveButtonIndices,\n },\n callback,\n );\n },\n\n /**\n * Display the iOS share sheet. The `options` object should contain\n * one or both of `message` and `url` and can additionally have\n * a `subject` or `excludedActivityTypes`:\n *\n * - `url` (string) - a URL to share\n * - `message` (string) - a message to share\n * - `subject` (string) - a subject for the message\n * - `excludedActivityTypes` (array) - the activities to exclude from\n * the ActionSheet\n * - `tintColor` (color) - tint color of the buttons\n *\n * The 'failureCallback' function takes one parameter, an error object.\n * The only property defined on this object is an optional `stack` property\n * of type `string`.\n *\n * The 'successCallback' function takes two parameters:\n *\n * - a boolean value signifying success or failure\n * - a string that, in the case of success, indicates the method of sharing\n *\n * See https://reactnative.dev/docs/actionsheetios#showshareactionsheetwithoptions\n */\n showShareActionSheetWithOptions(\n options: Object,\n failureCallback: Function,\n successCallback: Function,\n ) {\n invariant(\n typeof options === 'object' && options !== null,\n 'Options must be a valid object',\n );\n invariant(\n typeof failureCallback === 'function',\n 'Must provide a valid failureCallback',\n );\n invariant(\n typeof successCallback === 'function',\n 'Must provide a valid successCallback',\n );\n invariant(RCTActionSheetManager, \"ActionSheetManager doesn't exist\");\n RCTActionSheetManager.showShareActionSheetWithOptions(\n {...options, tintColor: processColor(options.tintColor)},\n failureCallback,\n successCallback,\n );\n },\n\n dismissActionSheet: () => {\n invariant(RCTActionSheetManager, \"ActionSheetManager doesn't exist\");\n if (typeof RCTActionSheetManager.dismissActionSheet === 'function') {\n RCTActionSheetManager.dismissActionSheet();\n }\n },\n};\n\nmodule.exports = ActionSheetIOS;\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 * @flow\n * @format\n */\n\nimport type {TurboModule} from '../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../TurboModule/TurboModuleRegistry';\n\nexport interface Spec extends TurboModule {\n +getConstants: () => {||};\n +showActionSheetWithOptions: (\n options: {|\n +title?: ?string,\n +message?: ?string,\n +options: ?Array,\n +destructiveButtonIndices?: ?Array,\n +cancelButtonIndex?: ?number,\n +anchor?: ?number,\n +tintColor?: ?number,\n +cancelButtonTintColor?: ?number,\n +userInterfaceStyle?: ?string,\n +disabledButtonIndices?: Array,\n |},\n callback: (buttonIndex: number) => void,\n ) => void;\n +showShareActionSheetWithOptions: (\n options: {|\n +message?: ?string,\n +url?: ?string,\n +subject?: ?string,\n +anchor?: ?number,\n +tintColor?: ?number,\n +cancelButtonTintColor?: ?number,\n +excludedActivityTypes?: ?Array,\n +userInterfaceStyle?: ?string,\n |},\n failureCallback: (error: {|\n +domain: string,\n +code: string,\n +userInfo?: ?Object,\n +message: string,\n |}) => void,\n successCallback: (completed: boolean, activityType: ?string) => void,\n ) => void;\n +dismissActionSheet?: () => void;\n}\n\nexport default (TurboModuleRegistry.get('ActionSheetManager'): ?Spec);\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 * @format\n * @flow strict-local\n */\n\nimport NativeEventEmitter from '../EventEmitter/NativeEventEmitter';\nimport Platform from '../Utilities/Platform';\nimport EventEmitter, {\n type EventSubscription,\n} from '../vendor/emitter/EventEmitter';\nimport {isAsyncDebugging} from './DebugEnvironment';\nimport NativeAppearance, {\n type AppearancePreferences,\n type ColorSchemeName,\n} from './NativeAppearance';\nimport invariant from 'invariant';\n\ntype AppearanceListener = (preferences: AppearancePreferences) => void;\nconst eventEmitter = new EventEmitter<{\n change: [AppearancePreferences],\n}>();\n\ntype NativeAppearanceEventDefinitions = {\n appearanceChanged: [AppearancePreferences],\n};\n\nif (NativeAppearance) {\n const nativeEventEmitter =\n new NativeEventEmitter(\n // T88715063: NativeEventEmitter only used this parameter on iOS. Now it uses it on all platforms, so this code was modified automatically to preserve its behavior\n // If you want to use the native module on other platforms, please remove this condition and test its behavior\n Platform.OS !== 'ios' ? null : NativeAppearance,\n );\n nativeEventEmitter.addListener(\n 'appearanceChanged',\n (newAppearance: AppearancePreferences) => {\n const {colorScheme} = newAppearance;\n invariant(\n colorScheme === 'dark' ||\n colorScheme === 'light' ||\n colorScheme == null,\n \"Unrecognized color scheme. Did you mean 'dark' or 'light'?\",\n );\n eventEmitter.emit('change', {colorScheme});\n },\n );\n}\n\nmodule.exports = {\n /**\n * Note: Although color scheme is available immediately, it may change at any\n * time. Any rendering logic or styles that depend on this should try to call\n * this function on every render, rather than caching the value (for example,\n * using inline styles rather than setting a value in a `StyleSheet`).\n *\n * Example: `const colorScheme = Appearance.getColorScheme();`\n *\n * @returns {?ColorSchemeName} Value for the color scheme preference.\n */\n getColorScheme(): ?ColorSchemeName {\n if (__DEV__) {\n if (isAsyncDebugging) {\n // Hard code light theme when using the async debugger as\n // sync calls aren't supported\n return 'light';\n }\n }\n\n // TODO: (hramos) T52919652 Use ?ColorSchemeName once codegen supports union\n const nativeColorScheme: ?string =\n NativeAppearance == null\n ? null\n : NativeAppearance.getColorScheme() || null;\n invariant(\n nativeColorScheme === 'dark' ||\n nativeColorScheme === 'light' ||\n nativeColorScheme == null,\n \"Unrecognized color scheme. Did you mean 'dark' or 'light'?\",\n );\n return nativeColorScheme;\n },\n\n /**\n * Add an event handler that is fired when appearance preferences change.\n */\n addChangeListener(listener: AppearanceListener): EventSubscription {\n return eventEmitter.addListener('change', listener);\n },\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 * @flow strict\n * @format\n */\n\nimport type {TurboModule} from '../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../TurboModule/TurboModuleRegistry';\n\nexport type ColorSchemeName = 'light' | 'dark';\n\nexport type AppearancePreferences = {|\n // TODO: (hramos) T52919652 Use ?ColorSchemeName once codegen supports union\n // types.\n /* 'light' | 'dark' */\n colorScheme?: ?string,\n|};\n\nexport interface Spec extends TurboModule {\n // TODO: (hramos) T52919652 Use ?ColorSchemeName once codegen supports union\n // types.\n /* 'light' | 'dark' */\n +getColorScheme: () => ?string;\n\n // RCTEventEmitter\n +addListener: (eventName: string) => void;\n +removeListeners: (count: number) => void;\n}\n\nexport default (TurboModuleRegistry.get('Appearance'): ?Spec);\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 * @flow strict-local\n * @format\n */\n\nimport NativeEventEmitter from '../EventEmitter/NativeEventEmitter';\nimport logError from '../Utilities/logError';\nimport Platform from '../Utilities/Platform';\nimport {type EventSubscription} from '../vendor/emitter/EventEmitter';\nimport NativeAppState from './NativeAppState';\n\nexport type AppStateValues = 'inactive' | 'background' | 'active';\n\ntype AppStateEventDefinitions = {\n change: [AppStateValues],\n memoryWarning: [],\n blur: [],\n focus: [],\n};\n\ntype NativeAppStateEventDefinitions = {\n appStateDidChange: [{app_state: AppStateValues}],\n appStateFocusChange: [boolean],\n memoryWarning: [],\n};\n\n/**\n * `AppState` can tell you if the app is in the foreground or background,\n * and notify you when the state changes.\n *\n * See https://reactnative.dev/docs/appstate\n */\nclass AppState {\n currentState: ?string = null;\n isAvailable: boolean;\n\n _emitter: ?NativeEventEmitter;\n\n constructor() {\n if (NativeAppState == null) {\n this.isAvailable = false;\n } else {\n this.isAvailable = true;\n\n const emitter: NativeEventEmitter =\n new NativeEventEmitter(\n // T88715063: NativeEventEmitter only used this parameter on iOS. Now it uses it on all platforms, so this code was modified automatically to preserve its behavior\n // If you want to use the native module on other platforms, please remove this condition and test its behavior\n Platform.OS !== 'ios' ? null : NativeAppState,\n );\n this._emitter = emitter;\n\n this.currentState = NativeAppState.getConstants().initialAppState;\n\n let eventUpdated = false;\n\n // TODO: this is a terrible solution - in order to ensure `currentState`\n // prop is up to date, we have to register an observer that updates it\n // whenever the state changes, even if nobody cares. We should just\n // deprecate the `currentState` property and get rid of this.\n emitter.addListener('appStateDidChange', appStateData => {\n eventUpdated = true;\n this.currentState = appStateData.app_state;\n });\n\n // TODO: see above - this request just populates the value of `currentState`\n // when the module is first initialized. Would be better to get rid of the\n // prop and expose `getCurrentAppState` method directly.\n // $FlowExpectedError[incompatible-call]\n NativeAppState.getCurrentAppState(appStateData => {\n // It's possible that the state will have changed here & listeners need to be notified\n if (!eventUpdated && this.currentState !== appStateData.app_state) {\n this.currentState = appStateData.app_state;\n // $FlowFixMe[incompatible-call]\n emitter.emit('appStateDidChange', appStateData);\n }\n }, logError);\n }\n }\n\n /**\n * Add a handler to AppState changes by listening to the `change` event type\n * and providing the handler.\n *\n * See https://reactnative.dev/docs/appstate#addeventlistener\n */\n addEventListener>(\n type: K,\n handler: (...$ElementType) => void,\n ): EventSubscription {\n const emitter = this._emitter;\n if (emitter == null) {\n throw new Error('Cannot use AppState when `isAvailable` is false.');\n }\n switch (type) {\n case 'change':\n // $FlowIssue[invalid-tuple-arity] Flow cannot refine handler based on the event type\n const changeHandler: AppStateValues => void = handler;\n return emitter.addListener('appStateDidChange', appStateData => {\n changeHandler(appStateData.app_state);\n });\n case 'memoryWarning':\n // $FlowIssue[invalid-tuple-arity] Flow cannot refine handler based on the event type\n const memoryWarningHandler: () => void = handler;\n return emitter.addListener('memoryWarning', memoryWarningHandler);\n case 'blur':\n case 'focus':\n // $FlowIssue[invalid-tuple-arity] Flow cannot refine handler based on the event type\n const focusOrBlurHandler: () => void = handler;\n return emitter.addListener('appStateFocusChange', hasFocus => {\n if (type === 'blur' && !hasFocus) {\n focusOrBlurHandler();\n }\n if (type === 'focus' && hasFocus) {\n focusOrBlurHandler();\n }\n });\n }\n throw new Error('Trying to subscribe to unknown event: ' + type);\n }\n}\n\nmodule.exports = (new AppState(): AppState);\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 * @format\n * @flow strict\n */\n\n'use strict';\n\n/**\n * Small utility that can be used as an error handler. You cannot just pass\n * `console.error` as a failure callback - it's not properly bound. If passes an\n * `Error` object, it will print the message and stack.\n */\nconst logError = function (...args: $ReadOnlyArray) {\n if (args.length === 1 && args[0] instanceof Error) {\n const err = args[0];\n console.error('Error: \"' + err.message + '\". Stack:\\n' + err.stack);\n } else {\n console.error.apply(console, args);\n }\n};\n\nmodule.exports = logError;\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 * @flow\n * @format\n */\n\nimport type {TurboModule} from '../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../TurboModule/TurboModuleRegistry';\n\nexport interface Spec extends TurboModule {\n +getConstants: () => {|\n initialAppState: string,\n |};\n +getCurrentAppState: (\n success: (appState: {|app_state: string|}) => void,\n error: (error: Object) => void,\n ) => void;\n\n // Events\n +addListener: (eventName: string) => void;\n +removeListeners: (count: number) => void;\n}\n\nexport default (TurboModuleRegistry.getEnforcing('AppState'): Spec);\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 * @format\n * @flow strict\n */\n\nimport NativeClipboard from './NativeClipboard';\n\n/**\n * `Clipboard` gives you an interface for setting and getting content from Clipboard on both iOS and Android\n */\nmodule.exports = {\n /**\n * Get content of string type, this method returns a `Promise`, so you can use following code to get clipboard content\n * ```javascript\n * async _getContent() {\n * var content = await Clipboard.getString();\n * }\n * ```\n */\n getString(): Promise {\n return NativeClipboard.getString();\n },\n /**\n * Set content of string type. You can use following code to set clipboard content\n * ```javascript\n * _setContent() {\n * Clipboard.setString('hello world');\n * }\n * ```\n * @param the content to be stored in the clipboard.\n */\n setString(content: string) {\n NativeClipboard.setString(content);\n },\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 * @flow strict\n * @format\n */\n\nimport type {TurboModule} from '../../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../../TurboModule/TurboModuleRegistry';\n\nexport interface Spec extends TurboModule {\n +getConstants: () => {||};\n +getString: () => Promise;\n +setString: (content: string) => void;\n}\n\nexport default (TurboModuleRegistry.getEnforcing('Clipboard'): Spec);\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 * @format\n * @flow strict-local\n */\n\nimport NativeDeviceInfo from './NativeDeviceInfo';\n\nmodule.exports = NativeDeviceInfo;\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 * @flow strict-local\n * @format\n */\n\nimport type {EventSubscription} from '../vendor/emitter/EventEmitter';\n\nimport NativeEventEmitter from '../EventEmitter/NativeEventEmitter';\nimport NativeDevSettings from '../NativeModules/specs/NativeDevSettings';\nimport Platform from '../Utilities/Platform';\n\nlet DevSettings: {\n addMenuItem(title: string, handler: () => mixed): void,\n reload(reason?: string): void,\n onFastRefresh(): void,\n} = {\n addMenuItem(title: string, handler: () => mixed): void {},\n reload(reason?: string): void {},\n onFastRefresh(): void {},\n};\n\ntype DevSettingsEventDefinitions = {\n didPressMenuItem: [{title: string}],\n};\n\nif (__DEV__) {\n const emitter = new NativeEventEmitter(\n // T88715063: NativeEventEmitter only used this parameter on iOS. Now it uses it on all platforms, so this code was modified automatically to preserve its behavior\n // If you want to use the native module on other platforms, please remove this condition and test its behavior\n Platform.OS !== 'ios' ? null : NativeDevSettings,\n );\n const subscriptions = new Map();\n\n DevSettings = {\n addMenuItem(title: string, handler: () => mixed): void {\n // Make sure items are not added multiple times. This can\n // happen when hot reloading the module that registers the\n // menu items. The title is used as the id which means we\n // don't support multiple items with the same name.\n let subscription = subscriptions.get(title);\n if (subscription != null) {\n subscription.remove();\n } else {\n NativeDevSettings.addMenuItem(title);\n }\n\n subscription = emitter.addListener('didPressMenuItem', event => {\n if (event.title === title) {\n handler();\n }\n });\n subscriptions.set(title, subscription);\n },\n reload(reason?: string): void {\n if (NativeDevSettings.reloadWithReason != null) {\n NativeDevSettings.reloadWithReason(reason ?? 'Uncategorized from JS');\n } else {\n NativeDevSettings.reload();\n }\n },\n onFastRefresh(): void {\n NativeDevSettings.onFastRefresh?.();\n },\n };\n}\n\nmodule.exports = DevSettings;\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 * @flow strict\n * @format\n */\n\nimport type {TurboModule} from '../../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../../TurboModule/TurboModuleRegistry';\n\nexport interface Spec extends TurboModule {\n +reload: () => void;\n +reloadWithReason?: (reason: string) => void;\n +onFastRefresh?: () => void;\n +setHotLoadingEnabled: (isHotLoadingEnabled: boolean) => void;\n +setIsDebuggingRemotely: (isDebuggingRemotelyEnabled: boolean) => void;\n +setProfilingEnabled: (isProfilingEnabled: boolean) => void;\n +toggleElementInspector: () => void;\n +addMenuItem: (title: string) => void;\n\n // Events\n +addListener: (eventName: string) => void;\n +removeListeners: (count: number) => void;\n\n // iOS only.\n +setIsShakeToShowDevMenuEnabled: (enabled: boolean) => void;\n}\n\nexport default (TurboModuleRegistry.getEnforcing('DevSettings'): Spec);\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 * @format\n * @flow strict-local\n */\n\nimport type {EventSubscription} from '../vendor/emitter/EventEmitter';\n\nimport NativeEventEmitter from '../EventEmitter/NativeEventEmitter';\nimport InteractionManager from '../Interaction/InteractionManager';\nimport Platform from '../Utilities/Platform';\nimport NativeIntentAndroid from './NativeIntentAndroid';\nimport NativeLinkingManager from './NativeLinkingManager';\nimport invariant from 'invariant';\nimport nullthrows from 'nullthrows';\n\ntype LinkingEventDefinitions = {\n url: [{url: string}],\n};\n\n/**\n * `Linking` gives you a general interface to interact with both incoming\n * and outgoing app links.\n *\n * See https://reactnative.dev/docs/linking\n */\nclass Linking extends NativeEventEmitter {\n constructor() {\n super(Platform.OS === 'ios' ? nullthrows(NativeLinkingManager) : undefined);\n }\n\n /**\n * Add a handler to Linking changes by listening to the `url` event type\n * and providing the handler\n *\n * See https://reactnative.dev/docs/linking#addeventlistener\n */\n addEventListener>(\n eventType: K,\n listener: (...$ElementType) => mixed,\n context: $FlowFixMe,\n ): EventSubscription {\n return this.addListener(eventType, listener);\n }\n\n /**\n * Try to open the given `url` with any of the installed apps.\n *\n * See https://reactnative.dev/docs/linking#openurl\n */\n openURL(url: string): Promise {\n this._validateURL(url);\n if (Platform.OS === 'android') {\n return nullthrows(NativeIntentAndroid).openURL(url);\n } else {\n return nullthrows(NativeLinkingManager).openURL(url);\n }\n }\n\n /**\n * Determine whether or not an installed app can handle a given URL.\n *\n * See https://reactnative.dev/docs/linking#canopenurl\n */\n canOpenURL(url: string): Promise {\n this._validateURL(url);\n if (Platform.OS === 'android') {\n return nullthrows(NativeIntentAndroid).canOpenURL(url);\n } else {\n return nullthrows(NativeLinkingManager).canOpenURL(url);\n }\n }\n\n /**\n * Open app settings.\n *\n * See https://reactnative.dev/docs/linking#opensettings\n */\n openSettings(): Promise {\n if (Platform.OS === 'android') {\n return nullthrows(NativeIntentAndroid).openSettings();\n } else {\n return nullthrows(NativeLinkingManager).openSettings();\n }\n }\n\n /**\n * If the app launch was triggered by an app link,\n * it will give the link url, otherwise it will give `null`\n *\n * See https://reactnative.dev/docs/linking#getinitialurl\n */\n getInitialURL(): Promise {\n return Platform.OS === 'android'\n ? InteractionManager.runAfterInteractions().then(() =>\n nullthrows(NativeIntentAndroid).getInitialURL(),\n )\n : nullthrows(NativeLinkingManager).getInitialURL();\n }\n\n /*\n * Launch an Android intent with extras (optional)\n *\n * @platform android\n *\n * See https://reactnative.dev/docs/linking#sendintent\n */\n sendIntent(\n action: string,\n extras?: Array<{\n key: string,\n value: string | number | boolean,\n ...\n }>,\n ): Promise {\n if (Platform.OS === 'android') {\n return nullthrows(NativeIntentAndroid).sendIntent(action, extras);\n } else {\n return new Promise((resolve, reject) => reject(new Error('Unsupported')));\n }\n }\n\n _validateURL(url: string): void {\n invariant(\n typeof url === 'string',\n 'Invalid URL: should be a string. Was: ' + url,\n );\n invariant(url, 'Invalid URL: cannot be empty');\n }\n}\n\nmodule.exports = (new Linking(): Linking);\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 * @flow strict\n * @format\n */\n\nimport type {TurboModule} from '../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../TurboModule/TurboModuleRegistry';\n\nexport interface Spec extends TurboModule {\n +getInitialURL: () => Promise;\n +canOpenURL: (url: string) => Promise;\n +openURL: (url: string) => Promise;\n +openSettings: () => Promise;\n +sendIntent: (\n action: string,\n extras: ?Array<{\n key: string,\n value: string | number | boolean, // TODO(T67672788): Union types are not type safe\n ...\n }>,\n ) => Promise;\n}\n\nexport default (TurboModuleRegistry.get('IntentAndroid'): ?Spec);\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 * @flow strict\n * @format\n */\n\nimport type {TurboModule} from '../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../TurboModule/TurboModuleRegistry';\n\nexport interface Spec extends TurboModule {\n // Common interface\n +getInitialURL: () => Promise;\n +canOpenURL: (url: string) => Promise;\n +openURL: (url: string) => Promise;\n +openSettings: () => Promise;\n\n // Events\n +addListener: (eventName: string) => void;\n +removeListeners: (count: number) => void;\n}\n\nexport default (TurboModuleRegistry.get('LinkingManager'): ?Spec);\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 * @flow strict\n * @format\n */\n\nimport type {IgnorePattern, LogData} from './Data/LogBoxData';\nimport type {ExtendedExceptionData} from './Data/parseLogBoxLog';\n\nimport Platform from '../Utilities/Platform';\nimport RCTLog from '../Utilities/RCTLog';\n\nexport type {LogData, ExtendedExceptionData, IgnorePattern};\n\nlet LogBox;\n\ninterface ILogBox {\n install(): void;\n uninstall(): void;\n isInstalled(): boolean;\n ignoreLogs($ReadOnlyArray): void;\n ignoreAllLogs(?boolean): void;\n clearAllLogs(): void;\n addLog(log: LogData): void;\n addException(error: ExtendedExceptionData): void;\n}\n\n/**\n * LogBox displays logs in the app.\n */\nif (__DEV__) {\n const LogBoxData = require('./Data/LogBoxData');\n const {parseLogBoxLog, parseInterpolation} = require('./Data/parseLogBoxLog');\n\n let originalConsoleError;\n let originalConsoleWarn;\n let consoleErrorImpl;\n let consoleWarnImpl: (...args: Array) => void;\n\n let isLogBoxInstalled: boolean = false;\n\n LogBox = {\n install(): void {\n if (isLogBoxInstalled) {\n return;\n }\n\n isLogBoxInstalled = true;\n\n // Trigger lazy initialization of module.\n require('../NativeModules/specs/NativeLogBox');\n\n // IMPORTANT: we only overwrite `console.error` and `console.warn` once.\n // When we uninstall we keep the same reference and only change its\n // internal implementation\n const isFirstInstall = originalConsoleError == null;\n if (isFirstInstall) {\n originalConsoleError = console.error.bind(console);\n originalConsoleWarn = console.warn.bind(console);\n\n // $FlowExpectedError[cannot-write]\n console.error = (...args) => {\n consoleErrorImpl(...args);\n };\n // $FlowExpectedError[cannot-write]\n console.warn = (...args) => {\n consoleWarnImpl(...args);\n };\n }\n\n consoleErrorImpl = registerError;\n consoleWarnImpl = registerWarning;\n\n if (Platform.isTesting) {\n LogBoxData.setDisabled(true);\n }\n\n RCTLog.setWarningHandler((...args) => {\n registerWarning(...args);\n });\n },\n\n uninstall(): void {\n if (!isLogBoxInstalled) {\n return;\n }\n\n isLogBoxInstalled = false;\n\n // IMPORTANT: we don't re-assign to `console` in case the method has been\n // decorated again after installing LogBox. E.g.:\n // Before uninstalling: original > LogBox > OtherErrorHandler\n // After uninstalling: original > LogBox (noop) > OtherErrorHandler\n consoleErrorImpl = originalConsoleError;\n consoleWarnImpl = originalConsoleWarn;\n },\n\n isInstalled(): boolean {\n return isLogBoxInstalled;\n },\n\n ignoreLogs(patterns: $ReadOnlyArray): void {\n LogBoxData.addIgnorePatterns(patterns);\n },\n\n ignoreAllLogs(value?: ?boolean): void {\n LogBoxData.setDisabled(value == null ? true : value);\n },\n\n clearAllLogs(): void {\n LogBoxData.clear();\n },\n\n addLog(log: LogData): void {\n if (isLogBoxInstalled) {\n LogBoxData.addLog(log);\n }\n },\n\n addException(error: ExtendedExceptionData): void {\n if (isLogBoxInstalled) {\n LogBoxData.addException(error);\n }\n },\n };\n\n const isRCTLogAdviceWarning = (...args: Array) => {\n // RCTLogAdvice is a native logging function designed to show users\n // a message in the console, but not show it to them in Logbox.\n return typeof args[0] === 'string' && args[0].startsWith('(ADVICE)');\n };\n\n const isWarningModuleWarning = (...args: Array) => {\n return typeof args[0] === 'string' && args[0].startsWith('Warning: ');\n };\n\n const registerWarning = (...args: Array): void => {\n // Let warnings within LogBox itself fall through.\n if (LogBoxData.isLogBoxErrorMessage(String(args[0]))) {\n originalConsoleError(...args);\n return;\n } else {\n // Be sure to pass LogBox warnings through.\n originalConsoleWarn(...args);\n }\n\n try {\n if (!isRCTLogAdviceWarning(...args)) {\n const {category, message, componentStack} = parseLogBoxLog(args);\n\n if (!LogBoxData.isMessageIgnored(message.content)) {\n LogBoxData.addLog({\n level: 'warn',\n category,\n message,\n componentStack,\n });\n }\n }\n } catch (err) {\n LogBoxData.reportLogBoxError(err);\n }\n };\n\n /* $FlowFixMe[missing-local-annot] The type annotation(s) required by Flow's\n * LTI update could not be added via codemod */\n const registerError = (...args): void => {\n // Let errors within LogBox itself fall through.\n if (LogBoxData.isLogBoxErrorMessage(args[0])) {\n originalConsoleError(...args);\n return;\n }\n\n try {\n if (!isWarningModuleWarning(...args)) {\n // Only show LogBox for the 'warning' module, otherwise pass through.\n // By passing through, this will get picked up by the React console override,\n // potentially adding the component stack. React then passes it back to the\n // React Native ExceptionsManager, which reports it to LogBox as an error.\n //\n // The 'warning' module needs to be handled here because React internally calls\n // `console.error('Warning: ')` with the component stack already included.\n originalConsoleError(...args);\n return;\n }\n\n const format = args[0].replace('Warning: ', '');\n const filterResult = LogBoxData.checkWarningFilter(format);\n if (filterResult.suppressCompletely) {\n return;\n }\n\n let level = 'error';\n if (filterResult.suppressDialog_LEGACY === true) {\n level = 'warn';\n } else if (filterResult.forceDialogImmediately === true) {\n level = 'fatal'; // Do not downgrade. These are real bugs with same severity as throws.\n }\n\n // Unfortunately, we need to add the Warning: prefix back for downstream dependencies.\n args[0] = `Warning: ${filterResult.finalFormat}`;\n const {category, message, componentStack} = parseLogBoxLog(args);\n\n // Interpolate the message so they are formatted for adb and other CLIs.\n // This is different than the message.content above because it includes component stacks.\n const interpolated = parseInterpolation(args);\n originalConsoleError(interpolated.message.content);\n\n if (!LogBoxData.isMessageIgnored(message.content)) {\n LogBoxData.addLog({\n level,\n category,\n message,\n componentStack,\n });\n }\n } catch (err) {\n LogBoxData.reportLogBoxError(err);\n }\n };\n} else {\n LogBox = {\n install(): void {\n // Do nothing.\n },\n\n uninstall(): void {\n // Do nothing.\n },\n\n isInstalled(): boolean {\n return false;\n },\n\n ignoreLogs(patterns: $ReadOnlyArray): void {\n // Do nothing.\n },\n\n ignoreAllLogs(value?: ?boolean): void {\n // Do nothing.\n },\n\n clearAllLogs(): void {\n // Do nothing.\n },\n\n addLog(log: LogData): void {\n // Do nothing.\n },\n\n addException(error: ExtendedExceptionData): void {\n // Do nothing.\n },\n };\n}\n\nmodule.exports = (LogBox: ILogBox);\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport type {PressEvent} from '../Types/CoreEventTypes';\nimport type {PanResponderType} from './PanResponder.flow.js';\n\nconst InteractionManager = require('./InteractionManager');\nconst TouchHistoryMath = require('./TouchHistoryMath');\n\nconst currentCentroidXOfTouchesChangedAfter =\n TouchHistoryMath.currentCentroidXOfTouchesChangedAfter;\nconst currentCentroidYOfTouchesChangedAfter =\n TouchHistoryMath.currentCentroidYOfTouchesChangedAfter;\nconst previousCentroidXOfTouchesChangedAfter =\n TouchHistoryMath.previousCentroidXOfTouchesChangedAfter;\nconst previousCentroidYOfTouchesChangedAfter =\n TouchHistoryMath.previousCentroidYOfTouchesChangedAfter;\nconst currentCentroidX = TouchHistoryMath.currentCentroidX;\nconst currentCentroidY = TouchHistoryMath.currentCentroidY;\n\n/**\n * `PanResponder` reconciles several touches into a single gesture. It makes\n * single-touch gestures resilient to extra touches, and can be used to\n * recognize simple multi-touch gestures.\n *\n * By default, `PanResponder` holds an `InteractionManager` handle to block\n * long-running JS events from interrupting active gestures.\n *\n * It provides a predictable wrapper of the responder handlers provided by the\n * [gesture responder system](docs/gesture-responder-system.html).\n * For each handler, it provides a new `gestureState` object alongside the\n * native event object:\n *\n * ```\n * onPanResponderMove: (event, gestureState) => {}\n * ```\n *\n * A native event is a synthetic touch event with the following form:\n *\n * - `nativeEvent`\n * + `changedTouches` - Array of all touch events that have changed since the last event\n * + `identifier` - The ID of the touch\n * + `locationX` - The X position of the touch, relative to the element\n * + `locationY` - The Y position of the touch, relative to the element\n * + `pageX` - The X position of the touch, relative to the root element\n * + `pageY` - The Y position of the touch, relative to the root element\n * + `target` - The node id of the element receiving the touch event\n * + `timestamp` - A time identifier for the touch, useful for velocity calculation\n * + `touches` - Array of all current touches on the screen\n *\n * A `gestureState` object has the following:\n *\n * - `stateID` - ID of the gestureState- persisted as long as there at least\n * one touch on screen\n * - `moveX` - the latest screen coordinates of the recently-moved touch\n * - `moveY` - the latest screen coordinates of the recently-moved touch\n * - `x0` - the screen coordinates of the responder grant\n * - `y0` - the screen coordinates of the responder grant\n * - `dx` - accumulated distance of the gesture since the touch started\n * - `dy` - accumulated distance of the gesture since the touch started\n * - `vx` - current velocity of the gesture\n * - `vy` - current velocity of the gesture\n * - `numberActiveTouches` - Number of touches currently on screen\n *\n * ### Basic Usage\n *\n * ```\n * componentWillMount: function() {\n * this._panResponder = PanResponder.create({\n * // Ask to be the responder:\n * onStartShouldSetPanResponder: (evt, gestureState) => true,\n * onStartShouldSetPanResponderCapture: (evt, gestureState) => true,\n * onMoveShouldSetPanResponder: (evt, gestureState) => true,\n * onMoveShouldSetPanResponderCapture: (evt, gestureState) => true,\n *\n * onPanResponderGrant: (evt, gestureState) => {\n * // The gesture has started. Show visual feedback so the user knows\n * // what is happening!\n *\n * // gestureState.d{x,y} will be set to zero now\n * },\n * onPanResponderMove: (evt, gestureState) => {\n * // The most recent move distance is gestureState.move{X,Y}\n *\n * // The accumulated gesture distance since becoming responder is\n * // gestureState.d{x,y}\n * },\n * onPanResponderTerminationRequest: (evt, gestureState) => true,\n * onPanResponderRelease: (evt, gestureState) => {\n * // The user has released all touches while this view is the\n * // responder. This typically means a gesture has succeeded\n * },\n * onPanResponderTerminate: (evt, gestureState) => {\n * // Another component has become the responder, so this gesture\n * // should be cancelled\n * },\n * onShouldBlockNativeResponder: (evt, gestureState) => {\n * // Returns whether this component should block native components from becoming the JS\n * // responder. Returns true by default. Is currently only supported on android.\n * return true;\n * },\n * });\n * },\n *\n * render: function() {\n * return (\n * \n * );\n * },\n *\n * ```\n *\n * ### Working Example\n *\n * To see it in action, try the\n * [PanResponder example in RNTester](https://github.com/facebook/react-native/blob/HEAD/packages/rn-tester/js/examples/PanResponder/PanResponderExample.js)\n */\n\nexport type GestureState = {|\n /**\n * ID of the gestureState - persisted as long as there at least one touch on screen\n */\n stateID: number,\n\n /**\n * The latest screen coordinates of the recently-moved touch\n */\n moveX: number,\n\n /**\n * The latest screen coordinates of the recently-moved touch\n */\n moveY: number,\n\n /**\n * The screen coordinates of the responder grant\n */\n x0: number,\n\n /**\n * The screen coordinates of the responder grant\n */\n y0: number,\n\n /**\n * Accumulated distance of the gesture since the touch started\n */\n dx: number,\n\n /**\n * Accumulated distance of the gesture since the touch started\n */\n dy: number,\n\n /**\n * Current velocity of the gesture\n */\n vx: number,\n\n /**\n * Current velocity of the gesture\n */\n vy: number,\n\n /**\n * Number of touches currently on screen\n */\n numberActiveTouches: number,\n\n /**\n * All `gestureState` accounts for timeStamps up until this value\n *\n * @private\n */\n _accountsForMovesUpTo: number,\n|};\n\ntype ActiveCallback = (\n event: PressEvent,\n gestureState: GestureState,\n) => boolean;\n\ntype PassiveCallback = (event: PressEvent, gestureState: GestureState) => mixed;\n\ntype PanHandlers = {|\n onMoveShouldSetResponder: (event: PressEvent) => boolean,\n onMoveShouldSetResponderCapture: (event: PressEvent) => boolean,\n onResponderEnd: (event: PressEvent) => void,\n onResponderGrant: (event: PressEvent) => boolean,\n onResponderMove: (event: PressEvent) => void,\n onResponderReject: (event: PressEvent) => void,\n onResponderRelease: (event: PressEvent) => void,\n onResponderStart: (event: PressEvent) => void,\n onResponderTerminate: (event: PressEvent) => void,\n onResponderTerminationRequest: (event: PressEvent) => boolean,\n onStartShouldSetResponder: (event: PressEvent) => boolean,\n onStartShouldSetResponderCapture: (event: PressEvent) => boolean,\n|};\n\ntype PanResponderConfig = $ReadOnly<{|\n onMoveShouldSetPanResponder?: ?ActiveCallback,\n onMoveShouldSetPanResponderCapture?: ?ActiveCallback,\n onStartShouldSetPanResponder?: ?ActiveCallback,\n onStartShouldSetPanResponderCapture?: ?ActiveCallback,\n /**\n * The body of `onResponderGrant` returns a bool, but the vast majority of\n * callsites return void and this TODO notice is found in it:\n * TODO: t7467124 investigate if this can be removed\n */\n onPanResponderGrant?: ?(PassiveCallback | ActiveCallback),\n onPanResponderReject?: ?PassiveCallback,\n onPanResponderStart?: ?PassiveCallback,\n onPanResponderEnd?: ?PassiveCallback,\n onPanResponderRelease?: ?PassiveCallback,\n onPanResponderMove?: ?PassiveCallback,\n onPanResponderTerminate?: ?PassiveCallback,\n onPanResponderTerminationRequest?: ?ActiveCallback,\n onShouldBlockNativeResponder?: ?ActiveCallback,\n|}>;\n\nconst PanResponder: PanResponderType = {\n /**\n *\n * A graphical explanation of the touch data flow:\n *\n * +----------------------------+ +--------------------------------+\n * | ResponderTouchHistoryStore | |TouchHistoryMath |\n * +----------------------------+ +----------+---------------------+\n * |Global store of touchHistory| |Allocation-less math util |\n * |including activeness, start | |on touch history (centroids |\n * |position, prev/cur position.| |and multitouch movement etc) |\n * | | | |\n * +----^-----------------------+ +----^---------------------------+\n * | |\n * | (records relevant history |\n * | of touches relevant for |\n * | implementing higher level |\n * | gestures) |\n * | |\n * +----+-----------------------+ +----|---------------------------+\n * | ResponderEventPlugin | | | Your App/Component |\n * +----------------------------+ +----|---------------------------+\n * |Negotiates which view gets | Low level | | High level |\n * |onResponderMove events. | events w/ | +-+-------+ events w/ |\n * |Also records history into | touchHistory| | Pan | multitouch + |\n * |ResponderTouchHistoryStore. +---------------->Responder+-----> accumulative|\n * +----------------------------+ attached to | | | distance and |\n * each event | +---------+ velocity. |\n * | |\n * | |\n * +--------------------------------+\n *\n *\n *\n * Gesture that calculates cumulative movement over time in a way that just\n * \"does the right thing\" for multiple touches. The \"right thing\" is very\n * nuanced. When moving two touches in opposite directions, the cumulative\n * distance is zero in each dimension. When two touches move in parallel five\n * pixels in the same direction, the cumulative distance is five, not ten. If\n * two touches start, one moves five in a direction, then stops and the other\n * touch moves fives in the same direction, the cumulative distance is ten.\n *\n * This logic requires a kind of processing of time \"clusters\" of touch events\n * so that two touch moves that essentially occur in parallel but move every\n * other frame respectively, are considered part of the same movement.\n *\n * Explanation of some of the non-obvious fields:\n *\n * - moveX/moveY: If no move event has been observed, then `(moveX, moveY)` is\n * invalid. If a move event has been observed, `(moveX, moveY)` is the\n * centroid of the most recently moved \"cluster\" of active touches.\n * (Currently all move have the same timeStamp, but later we should add some\n * threshold for what is considered to be \"moving\"). If a palm is\n * accidentally counted as a touch, but a finger is moving greatly, the palm\n * will move slightly, but we only want to count the single moving touch.\n * - x0/y0: Centroid location (non-cumulative) at the time of becoming\n * responder.\n * - dx/dy: Cumulative touch distance - not the same thing as sum of each touch\n * distance. Accounts for touch moves that are clustered together in time,\n * moving the same direction. Only valid when currently responder (otherwise,\n * it only represents the drag distance below the threshold).\n * - vx/vy: Velocity.\n */\n\n _initializeGestureState(gestureState: GestureState) {\n gestureState.moveX = 0;\n gestureState.moveY = 0;\n gestureState.x0 = 0;\n gestureState.y0 = 0;\n gestureState.dx = 0;\n gestureState.dy = 0;\n gestureState.vx = 0;\n gestureState.vy = 0;\n gestureState.numberActiveTouches = 0;\n // All `gestureState` accounts for timeStamps up until:\n gestureState._accountsForMovesUpTo = 0;\n },\n\n /**\n * This is nuanced and is necessary. It is incorrect to continuously take all\n * active *and* recently moved touches, find the centroid, and track how that\n * result changes over time. Instead, we must take all recently moved\n * touches, and calculate how the centroid has changed just for those\n * recently moved touches, and append that change to an accumulator. This is\n * to (at least) handle the case where the user is moving three fingers, and\n * then one of the fingers stops but the other two continue.\n *\n * This is very different than taking all of the recently moved touches and\n * storing their centroid as `dx/dy`. For correctness, we must *accumulate\n * changes* in the centroid of recently moved touches.\n *\n * There is also some nuance with how we handle multiple moved touches in a\n * single event. With the way `ReactNativeEventEmitter` dispatches touches as\n * individual events, multiple touches generate two 'move' events, each of\n * them triggering `onResponderMove`. But with the way `PanResponder` works,\n * all of the gesture inference is performed on the first dispatch, since it\n * looks at all of the touches (even the ones for which there hasn't been a\n * native dispatch yet). Therefore, `PanResponder` does not call\n * `onResponderMove` passed the first dispatch. This diverges from the\n * typical responder callback pattern (without using `PanResponder`), but\n * avoids more dispatches than necessary.\n */\n _updateGestureStateOnMove(\n gestureState: GestureState,\n touchHistory: $PropertyType,\n ) {\n gestureState.numberActiveTouches = touchHistory.numberActiveTouches;\n gestureState.moveX = currentCentroidXOfTouchesChangedAfter(\n touchHistory,\n gestureState._accountsForMovesUpTo,\n );\n gestureState.moveY = currentCentroidYOfTouchesChangedAfter(\n touchHistory,\n gestureState._accountsForMovesUpTo,\n );\n const movedAfter = gestureState._accountsForMovesUpTo;\n const prevX = previousCentroidXOfTouchesChangedAfter(\n touchHistory,\n movedAfter,\n );\n const x = currentCentroidXOfTouchesChangedAfter(touchHistory, movedAfter);\n const prevY = previousCentroidYOfTouchesChangedAfter(\n touchHistory,\n movedAfter,\n );\n const y = currentCentroidYOfTouchesChangedAfter(touchHistory, movedAfter);\n const nextDX = gestureState.dx + (x - prevX);\n const nextDY = gestureState.dy + (y - prevY);\n\n // TODO: This must be filtered intelligently.\n const dt =\n touchHistory.mostRecentTimeStamp - gestureState._accountsForMovesUpTo;\n gestureState.vx = (nextDX - gestureState.dx) / dt;\n gestureState.vy = (nextDY - gestureState.dy) / dt;\n\n gestureState.dx = nextDX;\n gestureState.dy = nextDY;\n gestureState._accountsForMovesUpTo = touchHistory.mostRecentTimeStamp;\n },\n\n /**\n * @param {object} config Enhanced versions of all of the responder callbacks\n * that provide not only the typical `ResponderSyntheticEvent`, but also the\n * `PanResponder` gesture state. Simply replace the word `Responder` with\n * `PanResponder` in each of the typical `onResponder*` callbacks. For\n * example, the `config` object would look like:\n *\n * - `onMoveShouldSetPanResponder: (e, gestureState) => {...}`\n * - `onMoveShouldSetPanResponderCapture: (e, gestureState) => {...}`\n * - `onStartShouldSetPanResponder: (e, gestureState) => {...}`\n * - `onStartShouldSetPanResponderCapture: (e, gestureState) => {...}`\n * - `onPanResponderReject: (e, gestureState) => {...}`\n * - `onPanResponderGrant: (e, gestureState) => {...}`\n * - `onPanResponderStart: (e, gestureState) => {...}`\n * - `onPanResponderEnd: (e, gestureState) => {...}`\n * - `onPanResponderRelease: (e, gestureState) => {...}`\n * - `onPanResponderMove: (e, gestureState) => {...}`\n * - `onPanResponderTerminate: (e, gestureState) => {...}`\n * - `onPanResponderTerminationRequest: (e, gestureState) => {...}`\n * - `onShouldBlockNativeResponder: (e, gestureState) => {...}`\n *\n * In general, for events that have capture equivalents, we update the\n * gestureState once in the capture phase and can use it in the bubble phase\n * as well.\n *\n * Be careful with onStartShould* callbacks. They only reflect updated\n * `gestureState` for start/end events that bubble/capture to the Node.\n * Once the node is the responder, you can rely on every start/end event\n * being processed by the gesture and `gestureState` being updated\n * accordingly. (numberActiveTouches) may not be totally accurate unless you\n * are the responder.\n */\n create(config: PanResponderConfig): $TEMPORARY$object<{|\n getInteractionHandle: () => ?number,\n panHandlers: PanHandlers,\n |}> {\n const interactionState = {\n handle: (null: ?number),\n };\n const gestureState: GestureState = {\n // Useful for debugging\n stateID: Math.random(),\n moveX: 0,\n moveY: 0,\n x0: 0,\n y0: 0,\n dx: 0,\n dy: 0,\n vx: 0,\n vy: 0,\n numberActiveTouches: 0,\n _accountsForMovesUpTo: 0,\n };\n const panHandlers = {\n onStartShouldSetResponder(event: PressEvent): boolean {\n return config.onStartShouldSetPanResponder == null\n ? false\n : config.onStartShouldSetPanResponder(event, gestureState);\n },\n onMoveShouldSetResponder(event: PressEvent): boolean {\n return config.onMoveShouldSetPanResponder == null\n ? false\n : config.onMoveShouldSetPanResponder(event, gestureState);\n },\n onStartShouldSetResponderCapture(event: PressEvent): boolean {\n // TODO: Actually, we should reinitialize the state any time\n // touches.length increases from 0 active to > 0 active.\n if (event.nativeEvent.touches.length === 1) {\n PanResponder._initializeGestureState(gestureState);\n }\n gestureState.numberActiveTouches =\n event.touchHistory.numberActiveTouches;\n return config.onStartShouldSetPanResponderCapture != null\n ? config.onStartShouldSetPanResponderCapture(event, gestureState)\n : false;\n },\n\n onMoveShouldSetResponderCapture(event: PressEvent): boolean {\n const touchHistory = event.touchHistory;\n // Responder system incorrectly dispatches should* to current responder\n // Filter out any touch moves past the first one - we would have\n // already processed multi-touch geometry during the first event.\n if (\n gestureState._accountsForMovesUpTo ===\n touchHistory.mostRecentTimeStamp\n ) {\n return false;\n }\n PanResponder._updateGestureStateOnMove(gestureState, touchHistory);\n return config.onMoveShouldSetPanResponderCapture\n ? config.onMoveShouldSetPanResponderCapture(event, gestureState)\n : false;\n },\n\n onResponderGrant(event: PressEvent): boolean {\n if (!interactionState.handle) {\n interactionState.handle =\n InteractionManager.createInteractionHandle();\n }\n gestureState.x0 = currentCentroidX(event.touchHistory);\n gestureState.y0 = currentCentroidY(event.touchHistory);\n gestureState.dx = 0;\n gestureState.dy = 0;\n if (config.onPanResponderGrant) {\n config.onPanResponderGrant(event, gestureState);\n }\n // TODO: t7467124 investigate if this can be removed\n return config.onShouldBlockNativeResponder == null\n ? true\n : config.onShouldBlockNativeResponder(event, gestureState);\n },\n\n onResponderReject(event: PressEvent): void {\n clearInteractionHandle(\n interactionState,\n config.onPanResponderReject,\n event,\n gestureState,\n );\n },\n\n onResponderRelease(event: PressEvent): void {\n clearInteractionHandle(\n interactionState,\n config.onPanResponderRelease,\n event,\n gestureState,\n );\n PanResponder._initializeGestureState(gestureState);\n },\n\n onResponderStart(event: PressEvent): void {\n const touchHistory = event.touchHistory;\n gestureState.numberActiveTouches = touchHistory.numberActiveTouches;\n if (config.onPanResponderStart) {\n config.onPanResponderStart(event, gestureState);\n }\n },\n\n onResponderMove(event: PressEvent): void {\n const touchHistory = event.touchHistory;\n // Guard against the dispatch of two touch moves when there are two\n // simultaneously changed touches.\n if (\n gestureState._accountsForMovesUpTo ===\n touchHistory.mostRecentTimeStamp\n ) {\n return;\n }\n // Filter out any touch moves past the first one - we would have\n // already processed multi-touch geometry during the first event.\n PanResponder._updateGestureStateOnMove(gestureState, touchHistory);\n if (config.onPanResponderMove) {\n config.onPanResponderMove(event, gestureState);\n }\n },\n\n onResponderEnd(event: PressEvent): void {\n const touchHistory = event.touchHistory;\n gestureState.numberActiveTouches = touchHistory.numberActiveTouches;\n clearInteractionHandle(\n interactionState,\n config.onPanResponderEnd,\n event,\n gestureState,\n );\n },\n\n onResponderTerminate(event: PressEvent): void {\n clearInteractionHandle(\n interactionState,\n config.onPanResponderTerminate,\n event,\n gestureState,\n );\n PanResponder._initializeGestureState(gestureState);\n },\n\n onResponderTerminationRequest(event: PressEvent): boolean {\n return config.onPanResponderTerminationRequest == null\n ? true\n : config.onPanResponderTerminationRequest(event, gestureState);\n },\n };\n return {\n panHandlers,\n getInteractionHandle(): ?number {\n return interactionState.handle;\n },\n };\n },\n};\n\nfunction clearInteractionHandle(\n interactionState: {handle: ?number, ...},\n callback: ?(ActiveCallback | PassiveCallback),\n event: PressEvent,\n gestureState: GestureState,\n) {\n if (interactionState.handle) {\n InteractionManager.clearInteractionHandle(interactionState.handle);\n interactionState.handle = null;\n }\n if (callback) {\n callback(event, gestureState);\n }\n}\n\nexport type PanResponderInstance = $Call<\n $PropertyType,\n PanResponderConfig,\n>;\n\nmodule.exports = PanResponder;\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 * @format\n */\n\nconst TouchHistoryMath = {\n /**\n * This code is optimized and not intended to look beautiful. This allows\n * computing of touch centroids that have moved after `touchesChangedAfter`\n * timeStamp. You can compute the current centroid involving all touches\n * moves after `touchesChangedAfter`, or you can compute the previous\n * centroid of all touches that were moved after `touchesChangedAfter`.\n *\n * @param {TouchHistoryMath} touchHistory Standard Responder touch track\n * data.\n * @param {number} touchesChangedAfter timeStamp after which moved touches\n * are considered \"actively moving\" - not just \"active\".\n * @param {boolean} isXAxis Consider `x` dimension vs. `y` dimension.\n * @param {boolean} ofCurrent Compute current centroid for actively moving\n * touches vs. previous centroid of now actively moving touches.\n * @return {number} value of centroid in specified dimension.\n */\n centroidDimension: function (\n touchHistory,\n touchesChangedAfter,\n isXAxis,\n ofCurrent,\n ) {\n const touchBank = touchHistory.touchBank;\n let total = 0;\n let count = 0;\n\n const oneTouchData =\n touchHistory.numberActiveTouches === 1\n ? touchHistory.touchBank[touchHistory.indexOfSingleActiveTouch]\n : null;\n\n if (oneTouchData !== null) {\n if (\n oneTouchData.touchActive &&\n oneTouchData.currentTimeStamp > touchesChangedAfter\n ) {\n total +=\n ofCurrent && isXAxis\n ? oneTouchData.currentPageX\n : ofCurrent && !isXAxis\n ? oneTouchData.currentPageY\n : !ofCurrent && isXAxis\n ? oneTouchData.previousPageX\n : oneTouchData.previousPageY;\n count = 1;\n }\n } else {\n for (let i = 0; i < touchBank.length; i++) {\n const touchTrack = touchBank[i];\n if (\n touchTrack !== null &&\n touchTrack !== undefined &&\n touchTrack.touchActive &&\n touchTrack.currentTimeStamp >= touchesChangedAfter\n ) {\n let toAdd; // Yuck, program temporarily in invalid state.\n if (ofCurrent && isXAxis) {\n toAdd = touchTrack.currentPageX;\n } else if (ofCurrent && !isXAxis) {\n toAdd = touchTrack.currentPageY;\n } else if (!ofCurrent && isXAxis) {\n toAdd = touchTrack.previousPageX;\n } else {\n toAdd = touchTrack.previousPageY;\n }\n total += toAdd;\n count++;\n }\n }\n }\n return count > 0 ? total / count : TouchHistoryMath.noCentroid;\n },\n\n currentCentroidXOfTouchesChangedAfter: function (\n touchHistory,\n touchesChangedAfter,\n ) {\n return TouchHistoryMath.centroidDimension(\n touchHistory,\n touchesChangedAfter,\n true, // isXAxis\n true, // ofCurrent\n );\n },\n\n currentCentroidYOfTouchesChangedAfter: function (\n touchHistory,\n touchesChangedAfter,\n ) {\n return TouchHistoryMath.centroidDimension(\n touchHistory,\n touchesChangedAfter,\n false, // isXAxis\n true, // ofCurrent\n );\n },\n\n previousCentroidXOfTouchesChangedAfter: function (\n touchHistory,\n touchesChangedAfter,\n ) {\n return TouchHistoryMath.centroidDimension(\n touchHistory,\n touchesChangedAfter,\n true, // isXAxis\n false, // ofCurrent\n );\n },\n\n previousCentroidYOfTouchesChangedAfter: function (\n touchHistory,\n touchesChangedAfter,\n ) {\n return TouchHistoryMath.centroidDimension(\n touchHistory,\n touchesChangedAfter,\n false, // isXAxis\n false, // ofCurrent\n );\n },\n\n currentCentroidX: function (touchHistory) {\n return TouchHistoryMath.centroidDimension(\n touchHistory,\n 0, // touchesChangedAfter\n true, // isXAxis\n true, // ofCurrent\n );\n },\n\n currentCentroidY: function (touchHistory) {\n return TouchHistoryMath.centroidDimension(\n touchHistory,\n 0, // touchesChangedAfter\n false, // isXAxis\n true, // ofCurrent\n );\n },\n\n noCentroid: -1,\n};\n\nmodule.exports = TouchHistoryMath;\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 * @format\n * @flow strict\n */\n\nimport type {\n PermissionStatus,\n PermissionType,\n} from './NativePermissionsAndroid';\n\nimport NativeDialogManagerAndroid from '../NativeModules/specs/NativeDialogManagerAndroid';\nimport NativePermissionsAndroid from './NativePermissionsAndroid';\nimport invariant from 'invariant';\n\nconst Platform = require('../Utilities/Platform');\n\nexport type Rationale = {\n title: string,\n message: string,\n buttonPositive?: string,\n buttonNegative?: string,\n buttonNeutral?: string,\n ...\n};\n\nconst PERMISSION_REQUEST_RESULT = Object.freeze({\n GRANTED: 'granted',\n DENIED: 'denied',\n NEVER_ASK_AGAIN: 'never_ask_again',\n});\n\nconst PERMISSIONS = Object.freeze({\n READ_CALENDAR: 'android.permission.READ_CALENDAR',\n WRITE_CALENDAR: 'android.permission.WRITE_CALENDAR',\n CAMERA: 'android.permission.CAMERA',\n READ_CONTACTS: 'android.permission.READ_CONTACTS',\n WRITE_CONTACTS: 'android.permission.WRITE_CONTACTS',\n GET_ACCOUNTS: 'android.permission.GET_ACCOUNTS',\n ACCESS_FINE_LOCATION: 'android.permission.ACCESS_FINE_LOCATION',\n ACCESS_COARSE_LOCATION: 'android.permission.ACCESS_COARSE_LOCATION',\n ACCESS_BACKGROUND_LOCATION: 'android.permission.ACCESS_BACKGROUND_LOCATION',\n RECORD_AUDIO: 'android.permission.RECORD_AUDIO',\n READ_PHONE_STATE: 'android.permission.READ_PHONE_STATE',\n CALL_PHONE: 'android.permission.CALL_PHONE',\n READ_CALL_LOG: 'android.permission.READ_CALL_LOG',\n WRITE_CALL_LOG: 'android.permission.WRITE_CALL_LOG',\n ADD_VOICEMAIL: 'com.android.voicemail.permission.ADD_VOICEMAIL',\n READ_VOICEMAIL: 'com.android.voicemail.permission.READ_VOICEMAIL',\n WRITE_VOICEMAIL: 'com.android.voicemail.permission.WRITE_VOICEMAIL',\n USE_SIP: 'android.permission.USE_SIP',\n PROCESS_OUTGOING_CALLS: 'android.permission.PROCESS_OUTGOING_CALLS',\n BODY_SENSORS: 'android.permission.BODY_SENSORS',\n BODY_SENSORS_BACKGROUND: 'android.permission.BODY_SENSORS_BACKGROUND',\n SEND_SMS: 'android.permission.SEND_SMS',\n RECEIVE_SMS: 'android.permission.RECEIVE_SMS',\n READ_SMS: 'android.permission.READ_SMS',\n RECEIVE_WAP_PUSH: 'android.permission.RECEIVE_WAP_PUSH',\n RECEIVE_MMS: 'android.permission.RECEIVE_MMS',\n READ_EXTERNAL_STORAGE: 'android.permission.READ_EXTERNAL_STORAGE',\n READ_MEDIA_IMAGES: 'android.permission.READ_MEDIA_IMAGES',\n READ_MEDIA_VIDEO: 'android.permission.READ_MEDIA_VIDEO',\n READ_MEDIA_AUDIO: 'android.permission.READ_MEDIA_AUDIO',\n WRITE_EXTERNAL_STORAGE: 'android.permission.WRITE_EXTERNAL_STORAGE',\n BLUETOOTH_CONNECT: 'android.permission.BLUETOOTH_CONNECT',\n BLUETOOTH_SCAN: 'android.permission.BLUETOOTH_SCAN',\n BLUETOOTH_ADVERTISE: 'android.permission.BLUETOOTH_ADVERTISE',\n ACCESS_MEDIA_LOCATION: 'android.permission.ACCESS_MEDIA_LOCATION',\n ACCEPT_HANDOVER: 'android.permission.ACCEPT_HANDOVER',\n ACTIVITY_RECOGNITION: 'android.permission.ACTIVITY_RECOGNITION',\n ANSWER_PHONE_CALLS: 'android.permission.ANSWER_PHONE_CALLS',\n READ_PHONE_NUMBERS: 'android.permission.READ_PHONE_NUMBERS',\n UWB_RANGING: 'android.permission.UWB_RANGING',\n POST_NOTIFICATION: 'android.permission.POST_NOTIFICATIONS', // Remove in 0.72\n POST_NOTIFICATIONS: 'android.permission.POST_NOTIFICATIONS',\n NEARBY_WIFI_DEVICES: 'android.permission.NEARBY_WIFI_DEVICES',\n});\n\n/**\n * `PermissionsAndroid` provides access to Android M's new permissions model.\n *\n * See https://reactnative.dev/docs/permissionsandroid\n */\n\nclass PermissionsAndroid {\n PERMISSIONS: {|\n ACCEPT_HANDOVER: string,\n ACCESS_BACKGROUND_LOCATION: string,\n ACCESS_COARSE_LOCATION: string,\n ACCESS_FINE_LOCATION: string,\n ACCESS_MEDIA_LOCATION: string,\n ACTIVITY_RECOGNITION: string,\n ADD_VOICEMAIL: string,\n READ_VOICEMAIL: string,\n WRITE_VOICEMAIL: string,\n ANSWER_PHONE_CALLS: string,\n BLUETOOTH_ADVERTISE: string,\n BLUETOOTH_CONNECT: string,\n BLUETOOTH_SCAN: string,\n BODY_SENSORS: string,\n BODY_SENSORS_BACKGROUND: string,\n CALL_PHONE: string,\n CAMERA: string,\n GET_ACCOUNTS: string,\n NEARBY_WIFI_DEVICES: string,\n POST_NOTIFICATION: string, // Remove in 0.72\n POST_NOTIFICATIONS: string,\n PROCESS_OUTGOING_CALLS: string,\n READ_CALENDAR: string,\n READ_CALL_LOG: string,\n READ_CONTACTS: string,\n READ_EXTERNAL_STORAGE: string,\n READ_MEDIA_IMAGES: string,\n READ_MEDIA_VIDEO: string,\n READ_MEDIA_AUDIO: string,\n READ_PHONE_NUMBERS: string,\n READ_PHONE_STATE: string,\n READ_SMS: string,\n RECEIVE_MMS: string,\n RECEIVE_SMS: string,\n RECEIVE_WAP_PUSH: string,\n RECORD_AUDIO: string,\n SEND_SMS: string,\n USE_SIP: string,\n UWB_RANGING: string,\n WRITE_CALENDAR: string,\n WRITE_CALL_LOG: string,\n WRITE_CONTACTS: string,\n WRITE_EXTERNAL_STORAGE: string,\n |} = PERMISSIONS;\n RESULTS: {|\n DENIED: $TEMPORARY$string<'denied'>,\n GRANTED: $TEMPORARY$string<'granted'>,\n NEVER_ASK_AGAIN: $TEMPORARY$string<'never_ask_again'>,\n |} = PERMISSION_REQUEST_RESULT;\n\n /**\n * DEPRECATED - use check\n *\n * Returns a promise resolving to a boolean value as to whether the specified\n * permissions has been granted\n *\n * @deprecated\n */\n checkPermission(permission: PermissionType): Promise {\n console.warn(\n '\"PermissionsAndroid.checkPermission\" is deprecated. Use \"PermissionsAndroid.check\" instead',\n );\n if (Platform.OS !== 'android') {\n console.warn(\n '\"PermissionsAndroid\" module works only for Android platform.',\n );\n return Promise.resolve(false);\n }\n\n invariant(\n NativePermissionsAndroid,\n 'PermissionsAndroid is not installed correctly.',\n );\n\n return NativePermissionsAndroid.checkPermission(permission);\n }\n\n /**\n * Returns a promise resolving to a boolean value as to whether the specified\n * permissions has been granted\n *\n * See https://reactnative.dev/docs/permissionsandroid#check\n */\n check(permission: PermissionType): Promise {\n if (Platform.OS !== 'android') {\n console.warn(\n '\"PermissionsAndroid\" module works only for Android platform.',\n );\n return Promise.resolve(false);\n }\n\n invariant(\n NativePermissionsAndroid,\n 'PermissionsAndroid is not installed correctly.',\n );\n\n return NativePermissionsAndroid.checkPermission(permission);\n }\n\n /**\n * DEPRECATED - use request\n *\n * Prompts the user to enable a permission and returns a promise resolving to a\n * boolean value indicating whether the user allowed or denied the request\n *\n * If the optional rationale argument is included (which is an object with a\n * `title` and `message`), this function checks with the OS whether it is\n * necessary to show a dialog explaining why the permission is needed\n * (https://developer.android.com/training/permissions/requesting#explain)\n * and then shows the system permission dialog\n *\n * @deprecated\n */\n async requestPermission(\n permission: PermissionType,\n rationale?: Rationale,\n ): Promise {\n console.warn(\n '\"PermissionsAndroid.requestPermission\" is deprecated. Use \"PermissionsAndroid.request\" instead',\n );\n if (Platform.OS !== 'android') {\n console.warn(\n '\"PermissionsAndroid\" module works only for Android platform.',\n );\n return Promise.resolve(false);\n }\n\n const response = await this.request(permission, rationale);\n return response === this.RESULTS.GRANTED;\n }\n\n /**\n * Prompts the user to enable a permission and returns a promise resolving to a\n * string value indicating whether the user allowed or denied the request\n *\n * See https://reactnative.dev/docs/permissionsandroid#request\n */\n async request(\n permission: PermissionType,\n rationale?: Rationale,\n ): Promise {\n if (Platform.OS !== 'android') {\n console.warn(\n '\"PermissionsAndroid\" module works only for Android platform.',\n );\n return Promise.resolve(this.RESULTS.DENIED);\n }\n\n invariant(\n NativePermissionsAndroid,\n 'PermissionsAndroid is not installed correctly.',\n );\n\n if (rationale) {\n const shouldShowRationale =\n await NativePermissionsAndroid.shouldShowRequestPermissionRationale(\n permission,\n );\n\n if (shouldShowRationale && !!NativeDialogManagerAndroid) {\n return new Promise((resolve, reject) => {\n const options = {\n ...rationale,\n };\n NativeDialogManagerAndroid.showAlert(\n /* $FlowFixMe[incompatible-exact] (>=0.111.0 site=react_native_fb)\n * This comment suppresses an error found when Flow v0.111 was\n * deployed. To see the error, delete this comment and run Flow.\n */\n options,\n () => reject(new Error('Error showing rationale')),\n () =>\n resolve(NativePermissionsAndroid.requestPermission(permission)),\n );\n });\n }\n }\n return NativePermissionsAndroid.requestPermission(permission);\n }\n\n /**\n * Prompts the user to enable multiple permissions in the same dialog and\n * returns an object with the permissions as keys and strings as values\n * indicating whether the user allowed or denied the request\n *\n * See https://reactnative.dev/docs/permissionsandroid#requestmultiple\n */\n requestMultiple(\n permissions: Array,\n ): Promise<{[permission: PermissionType]: PermissionStatus, ...}> {\n if (Platform.OS !== 'android') {\n console.warn(\n '\"PermissionsAndroid\" module works only for Android platform.',\n );\n return Promise.resolve({});\n }\n\n invariant(\n NativePermissionsAndroid,\n 'PermissionsAndroid is not installed correctly.',\n );\n\n return NativePermissionsAndroid.requestMultiplePermissions(permissions);\n }\n}\n\nconst PermissionsAndroidInstance: PermissionsAndroid = new PermissionsAndroid();\n\nmodule.exports = PermissionsAndroidInstance;\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 * @format\n * @flow strict\n */\n\nimport type {TurboModule} from '../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../TurboModule/TurboModuleRegistry';\n\n// TODO: Use proper enum types.\nexport type PermissionStatus = string;\nexport type PermissionType = string;\n/*\nexport type PermissionStatus = 'granted' | 'denied' | 'never_ask_again';\nexport type PermissionType =\n | 'android.permission.READ_CALENDAR'\n | 'android.permission.WRITE_CALENDAR'\n | 'android.permission.CAMERA'\n | 'android.permission.READ_CONTACTS'\n | 'android.permission.WRITE_CONTACTS'\n | 'android.permission.GET_ACCOUNTS'\n | 'android.permission.ACCESS_BACKGROUND_LOCATION'\n | 'android.permission.ACCESS_FINE_LOCATION'\n | 'android.permission.ACCESS_COARSE_LOCATION'\n | 'android.permission.RECORD_AUDIO'\n | 'android.permission.READ_PHONE_STATE'\n | 'android.permission.CALL_PHONE'\n | 'android.permission.READ_CALL_LOG'\n | 'android.permission.WRITE_CALL_LOG'\n | 'com.android.voicemail.permission.ADD_VOICEMAIL'\n | 'com.android.voicemail.permission.READ_VOICEMAIL'\n | 'com.android.voicemail.permission.WRITE_VOICEMAIL'\n | 'android.permission.USE_SIP'\n | 'android.permission.PROCESS_OUTGOING_CALLS'\n | 'android.permission.BODY_SENSORS'\n | 'android.permission.BODY_SENSORS_BACKGROUND'\n | 'android.permission.SEND_SMS'\n | 'android.permission.RECEIVE_SMS'\n | 'android.permission.READ_SMS'\n | 'android.permission.RECEIVE_WAP_PUSH'\n | 'android.permission.RECEIVE_MMS'\n | 'android.permission.READ_EXTERNAL_STORAGE'\n | 'android.permission.READ_MEDIA_IMAGES',\n | 'android.permission.READ_MEDIA_VIDEO',\n | 'android.permission.READ_MEDIA_AUDIO',\n | 'android.permission.WRITE_EXTERNAL_STORAGE'\n | 'android.permission.BLUETOOTH_CONNECT'\n | 'android.permission.BLUETOOTH_SCAN'\n | 'android.permission.BLUETOOTH_ADVERTISE'\n | 'android.permission.ACCESS_MEDIA_LOCATION'\n | 'android.permission.ACCEPT_HANDOVER'\n | 'android.permission.ACTIVITY_RECOGNITION'\n | 'android.permission.ANSWER_PHONE_CALLS'\n | 'android.permission.READ_PHONE_NUMBERS'\n | 'android.permission.UWB_RANGING'\n | 'android.permission.POST_NOTIFICATIONS'\n | 'android.permission.NEARBY_WIFI_DEVICES';\n*/\n\nexport interface Spec extends TurboModule {\n +checkPermission: (permission: PermissionType) => Promise;\n +requestPermission: (permission: PermissionType) => Promise;\n +shouldShowRequestPermissionRationale: (\n permission: string,\n ) => Promise;\n +requestMultiplePermissions: (\n permissions: Array,\n ) => Promise<{[permission: PermissionType]: PermissionStatus, ...}>;\n}\n\nexport default (TurboModuleRegistry.get('PermissionsAndroid'): ?Spec);\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 * @format\n * @flow\n */\n\nimport type {EventSubscription} from '../vendor/emitter/EventEmitter';\n\nimport NativeEventEmitter from '../EventEmitter/NativeEventEmitter';\nimport Platform from '../Utilities/Platform';\nimport NativePushNotificationManagerIOS from './NativePushNotificationManagerIOS';\nimport invariant from 'invariant';\n\ntype NativePushNotificationIOSEventDefinitions = {\n remoteNotificationReceived: [\n {\n notificationId: string,\n remote: boolean,\n ...\n },\n ],\n remoteNotificationsRegistered: [\n {\n deviceToken?: ?string,\n ...\n },\n ],\n remoteNotificationRegistrationError: [\n {\n message: string,\n code: number,\n details: {...},\n },\n ],\n localNotificationReceived: [{...}],\n};\n\nconst PushNotificationEmitter =\n new NativeEventEmitter(\n // T88715063: NativeEventEmitter only used this parameter on iOS. Now it uses it on all platforms, so this code was modified automatically to preserve its behavior\n // If you want to use the native module on other platforms, please remove this condition and test its behavior\n Platform.OS !== 'ios' ? null : NativePushNotificationManagerIOS,\n );\n\nconst _notifHandlers = new Map();\n\nconst DEVICE_NOTIF_EVENT = 'remoteNotificationReceived';\nconst NOTIF_REGISTER_EVENT = 'remoteNotificationsRegistered';\nconst NOTIF_REGISTRATION_ERROR_EVENT = 'remoteNotificationRegistrationError';\nconst DEVICE_LOCAL_NOTIF_EVENT = 'localNotificationReceived';\n\nexport type ContentAvailable = 1 | null | void;\n\nexport type FetchResult = {\n NewData: string,\n NoData: string,\n ResultFailed: string,\n ...\n};\n\n/**\n * An event emitted by PushNotificationIOS.\n */\nexport type PushNotificationEventName = $Keys<{\n /**\n * Fired when a remote notification is received. The handler will be invoked\n * with an instance of `PushNotificationIOS`.\n */\n notification: string,\n /**\n * Fired when a local notification is received. The handler will be invoked\n * with an instance of `PushNotificationIOS`.\n */\n localNotification: string,\n /**\n * Fired when the user registers for remote notifications. The handler will be\n * invoked with a hex string representing the deviceToken.\n */\n register: string,\n /**\n * Fired when the user fails to register for remote notifications. Typically\n * occurs when APNS is having issues, or the device is a simulator. The\n * handler will be invoked with {message: string, code: number, details: any}.\n */\n registrationError: string,\n ...\n}>;\n\n/**\n *\n * Handle push notifications for your app, including permission handling and\n * icon badge number.\n *\n * See https://reactnative.dev/docs/pushnotificationios\n */\nclass PushNotificationIOS {\n _data: Object;\n _alert: string | Object;\n _sound: string;\n _category: string;\n _contentAvailable: ContentAvailable;\n _badgeCount: number;\n _notificationId: string;\n _isRemote: boolean;\n _remoteNotificationCompleteCallbackCalled: boolean;\n _threadID: string;\n\n static FetchResult: FetchResult = {\n NewData: 'UIBackgroundFetchResultNewData',\n NoData: 'UIBackgroundFetchResultNoData',\n ResultFailed: 'UIBackgroundFetchResultFailed',\n };\n\n /**\n * Schedules the localNotification for immediate presentation.\n *\n * See https://reactnative.dev/docs/pushnotificationios#presentlocalnotification\n */\n static presentLocalNotification(details: Object): void {\n invariant(\n NativePushNotificationManagerIOS,\n 'PushNotificationManager is not available.',\n );\n NativePushNotificationManagerIOS.presentLocalNotification(details);\n }\n\n /**\n * Schedules the localNotification for future presentation.\n *\n * See https://reactnative.dev/docs/pushnotificationios#schedulelocalnotification\n */\n static scheduleLocalNotification(details: Object): void {\n invariant(\n NativePushNotificationManagerIOS,\n 'PushNotificationManager is not available.',\n );\n NativePushNotificationManagerIOS.scheduleLocalNotification(details);\n }\n\n /**\n * Cancels all scheduled localNotifications.\n *\n * See https://reactnative.dev/docs/pushnotificationios#cancelalllocalnotifications\n */\n static cancelAllLocalNotifications(): void {\n invariant(\n NativePushNotificationManagerIOS,\n 'PushNotificationManager is not available.',\n );\n NativePushNotificationManagerIOS.cancelAllLocalNotifications();\n }\n\n /**\n * Remove all delivered notifications from Notification Center.\n *\n * See https://reactnative.dev/docs/pushnotificationios#removealldeliverednotifications\n */\n static removeAllDeliveredNotifications(): void {\n invariant(\n NativePushNotificationManagerIOS,\n 'PushNotificationManager is not available.',\n );\n NativePushNotificationManagerIOS.removeAllDeliveredNotifications();\n }\n\n /**\n * Provides you with a list of the app’s notifications that are still displayed in Notification Center.\n *\n * See https://reactnative.dev/docs/pushnotificationios#getdeliverednotifications\n */\n static getDeliveredNotifications(\n callback: (notifications: Array) => void,\n ): void {\n invariant(\n NativePushNotificationManagerIOS,\n 'PushNotificationManager is not available.',\n );\n NativePushNotificationManagerIOS.getDeliveredNotifications(callback);\n }\n\n /**\n * Removes the specified notifications from Notification Center\n *\n * See https://reactnative.dev/docs/pushnotificationios#removedeliverednotifications\n */\n static removeDeliveredNotifications(identifiers: Array): void {\n invariant(\n NativePushNotificationManagerIOS,\n 'PushNotificationManager is not available.',\n );\n NativePushNotificationManagerIOS.removeDeliveredNotifications(identifiers);\n }\n\n /**\n * Sets the badge number for the app icon on the home screen.\n *\n * See https://reactnative.dev/docs/pushnotificationios#setapplicationiconbadgenumber\n */\n static setApplicationIconBadgeNumber(number: number): void {\n invariant(\n NativePushNotificationManagerIOS,\n 'PushNotificationManager is not available.',\n );\n NativePushNotificationManagerIOS.setApplicationIconBadgeNumber(number);\n }\n\n /**\n * Gets the current badge number for the app icon on the home screen.\n *\n * See https://reactnative.dev/docs/pushnotificationios#getapplicationiconbadgenumber\n */\n static getApplicationIconBadgeNumber(callback: Function): void {\n invariant(\n NativePushNotificationManagerIOS,\n 'PushNotificationManager is not available.',\n );\n NativePushNotificationManagerIOS.getApplicationIconBadgeNumber(callback);\n }\n\n /**\n * Cancel local notifications.\n *\n * See https://reactnative.dev/docs/pushnotificationios#cancellocalnotification\n */\n static cancelLocalNotifications(userInfo: Object): void {\n invariant(\n NativePushNotificationManagerIOS,\n 'PushNotificationManager is not available.',\n );\n NativePushNotificationManagerIOS.cancelLocalNotifications(userInfo);\n }\n\n /**\n * Gets the local notifications that are currently scheduled.\n *\n * See https://reactnative.dev/docs/pushnotificationios#getscheduledlocalnotifications\n */\n static getScheduledLocalNotifications(callback: Function): void {\n invariant(\n NativePushNotificationManagerIOS,\n 'PushNotificationManager is not available.',\n );\n NativePushNotificationManagerIOS.getScheduledLocalNotifications(callback);\n }\n\n /**\n * Attaches a listener to remote or local notification events while the app\n * is running in the foreground or the background.\n *\n * See https://reactnative.dev/docs/pushnotificationios#addeventlistener\n */\n static addEventListener(\n type: PushNotificationEventName,\n handler: Function,\n ): void {\n invariant(\n type === 'notification' ||\n type === 'register' ||\n type === 'registrationError' ||\n type === 'localNotification',\n 'PushNotificationIOS only supports `notification`, `register`, `registrationError`, and `localNotification` events',\n );\n let listener;\n if (type === 'notification') {\n listener = PushNotificationEmitter.addListener(\n DEVICE_NOTIF_EVENT,\n notifData => {\n handler(new PushNotificationIOS(notifData));\n },\n );\n } else if (type === 'localNotification') {\n listener = PushNotificationEmitter.addListener(\n DEVICE_LOCAL_NOTIF_EVENT,\n notifData => {\n handler(new PushNotificationIOS(notifData));\n },\n );\n } else if (type === 'register') {\n listener = PushNotificationEmitter.addListener(\n NOTIF_REGISTER_EVENT,\n registrationInfo => {\n handler(registrationInfo.deviceToken);\n },\n );\n } else if (type === 'registrationError') {\n listener = PushNotificationEmitter.addListener(\n NOTIF_REGISTRATION_ERROR_EVENT,\n errorInfo => {\n handler(errorInfo);\n },\n );\n }\n _notifHandlers.set(type, listener);\n }\n\n /**\n * Removes the event listener. Do this in `componentWillUnmount` to prevent\n * memory leaks.\n *\n * See https://reactnative.dev/docs/pushnotificationios#removeeventlistener\n */\n static removeEventListener(\n type: PushNotificationEventName,\n handler: Function,\n ): void {\n invariant(\n type === 'notification' ||\n type === 'register' ||\n type === 'registrationError' ||\n type === 'localNotification',\n 'PushNotificationIOS only supports `notification`, `register`, `registrationError`, and `localNotification` events',\n );\n const listener = _notifHandlers.get(type);\n if (!listener) {\n return;\n }\n listener.remove();\n _notifHandlers.delete(type);\n }\n\n /**\n * Requests notification permissions from iOS, prompting the user's\n * dialog box. By default, it will request all notification permissions, but\n * a subset of these can be requested by passing a map of requested\n * permissions.\n *\n * See https://reactnative.dev/docs/pushnotificationios#requestpermissions\n */\n static requestPermissions(permissions?: {\n alert?: boolean,\n badge?: boolean,\n sound?: boolean,\n ...\n }): Promise<{\n alert: boolean,\n badge: boolean,\n sound: boolean,\n ...\n }> {\n let requestedPermissions = {\n alert: true,\n badge: true,\n sound: true,\n };\n if (permissions) {\n requestedPermissions = {\n alert: !!permissions.alert,\n badge: !!permissions.badge,\n sound: !!permissions.sound,\n };\n }\n invariant(\n NativePushNotificationManagerIOS,\n 'PushNotificationManager is not available.',\n );\n return NativePushNotificationManagerIOS.requestPermissions(\n requestedPermissions,\n );\n }\n\n /**\n * Unregister for all remote notifications received via Apple Push Notification service.\n *\n * See https://reactnative.dev/docs/pushnotificationios#abandonpermissions\n */\n static abandonPermissions(): void {\n invariant(\n NativePushNotificationManagerIOS,\n 'PushNotificationManager is not available.',\n );\n NativePushNotificationManagerIOS.abandonPermissions();\n }\n\n /**\n * See what push permissions are currently enabled. `callback` will be\n * invoked with a `permissions` object.\n *\n * See https://reactnative.dev/docs/pushnotificationios#checkpermissions\n */\n static checkPermissions(callback: Function): void {\n invariant(typeof callback === 'function', 'Must provide a valid callback');\n invariant(\n NativePushNotificationManagerIOS,\n 'PushNotificationManager is not available.',\n );\n NativePushNotificationManagerIOS.checkPermissions(callback);\n }\n\n /**\n * This method returns a promise that resolves to either the notification\n * object if the app was launched by a push notification, or `null` otherwise.\n *\n * See https://reactnative.dev/docs/pushnotificationios#getinitialnotification\n */\n static getInitialNotification(): Promise {\n invariant(\n NativePushNotificationManagerIOS,\n 'PushNotificationManager is not available.',\n );\n return NativePushNotificationManagerIOS.getInitialNotification().then(\n notification => {\n return notification && new PushNotificationIOS(notification);\n },\n );\n }\n\n /**\n * This method returns a promise that resolves to notification authorization status.\n */\n static getAuthorizationStatus(\n callback: (authorizationStatus: number) => void,\n ): void {\n invariant(\n NativePushNotificationManagerIOS,\n 'PushNotificationManager is not available.',\n );\n\n NativePushNotificationManagerIOS.getAuthorizationStatus(callback);\n }\n\n /**\n * You will never need to instantiate `PushNotificationIOS` yourself.\n * Listening to the `notification` event and invoking\n * `getInitialNotification` is sufficient\n *\n */\n constructor(nativeNotif: Object) {\n this._data = {};\n this._remoteNotificationCompleteCallbackCalled = false;\n this._isRemote = nativeNotif.remote;\n if (this._isRemote) {\n this._notificationId = nativeNotif.notificationId;\n }\n\n if (nativeNotif.remote) {\n // Extract data from Apple's `aps` dict as defined:\n // https://developer.apple.com/library/ios/documentation/NetworkingInternet/Conceptual/RemoteNotificationsPG/Chapters/ApplePushService\n Object.keys(nativeNotif).forEach(notifKey => {\n const notifVal = nativeNotif[notifKey];\n if (notifKey === 'aps') {\n this._alert = notifVal.alert;\n this._sound = notifVal.sound;\n this._badgeCount = notifVal.badge;\n this._category = notifVal.category;\n this._contentAvailable = notifVal['content-available'];\n this._threadID = notifVal['thread-id'];\n } else {\n this._data[notifKey] = notifVal;\n }\n });\n } else {\n // Local notifications aren't being sent down with `aps` dict.\n this._badgeCount = nativeNotif.applicationIconBadgeNumber;\n this._sound = nativeNotif.soundName;\n this._alert = nativeNotif.alertBody;\n this._data = nativeNotif.userInfo;\n this._category = nativeNotif.category;\n }\n }\n\n /**\n * This method is available for remote notifications that have been received via:\n * `application:didReceiveRemoteNotification:fetchCompletionHandler:`\n *\n * See https://reactnative.dev/docs/pushnotificationios#finish\n */\n finish(fetchResult: string): void {\n if (\n !this._isRemote ||\n !this._notificationId ||\n this._remoteNotificationCompleteCallbackCalled\n ) {\n return;\n }\n this._remoteNotificationCompleteCallbackCalled = true;\n\n invariant(\n NativePushNotificationManagerIOS,\n 'PushNotificationManager is not available.',\n );\n NativePushNotificationManagerIOS.onFinishRemoteNotification(\n this._notificationId,\n fetchResult,\n );\n }\n\n /**\n * An alias for `getAlert` to get the notification's main message string\n */\n getMessage(): ?string | ?Object {\n // alias because \"alert\" is an ambiguous name\n return this._alert;\n }\n\n /**\n * Gets the sound string from the `aps` object\n *\n * See https://reactnative.dev/docs/pushnotificationios#getsound\n */\n getSound(): ?string {\n return this._sound;\n }\n\n /**\n * Gets the category string from the `aps` object\n *\n * See https://reactnative.dev/docs/pushnotificationios#getcategory\n */\n getCategory(): ?string {\n return this._category;\n }\n\n /**\n * Gets the notification's main message from the `aps` object\n *\n * See https://reactnative.dev/docs/pushnotificationios#getalert\n */\n getAlert(): ?string | ?Object {\n return this._alert;\n }\n\n /**\n * Gets the content-available number from the `aps` object\n *\n * See https://reactnative.dev/docs/pushnotificationios#getcontentavailable\n */\n getContentAvailable(): ContentAvailable {\n return this._contentAvailable;\n }\n\n /**\n * Gets the badge count number from the `aps` object\n *\n * See https://reactnative.dev/docs/pushnotificationios#getbadgecount\n */\n getBadgeCount(): ?number {\n return this._badgeCount;\n }\n\n /**\n * Gets the data object on the notif\n *\n * See https://reactnative.dev/docs/pushnotificationios#getdata\n */\n getData(): ?Object {\n return this._data;\n }\n\n /**\n * Gets the thread ID on the notif\n *\n * See https://reactnative.dev/docs/pushnotificationios#getthreadid\n */\n getThreadID(): ?string {\n return this._threadID;\n }\n}\n\nmodule.exports = PushNotificationIOS;\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 * @format\n * @flow\n */\n\nimport type {TurboModule} from '../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../TurboModule/TurboModuleRegistry';\n\ntype Permissions = {|\n alert: boolean,\n badge: boolean,\n sound: boolean,\n|};\n\ntype Notification = {|\n +alertTitle?: ?string,\n // Actual type: string | number\n +fireDate?: ?number,\n +alertBody?: ?string,\n +alertAction?: ?string,\n +userInfo?: ?Object,\n +category?: ?string,\n // Actual type: 'year' | 'month' | 'week' | 'day' | 'hour' | 'minute'\n +repeatInterval?: ?string,\n +applicationIconBadgeNumber?: ?number,\n +isSilent?: ?boolean,\n +soundName?: ?string,\n|};\n\nexport interface Spec extends TurboModule {\n +getConstants: () => {||};\n +onFinishRemoteNotification: (\n notificationId: string,\n /**\n * Type:\n * 'UIBackgroundFetchResultNewData' |\n * 'UIBackgroundFetchResultNoData' |\n * 'UIBackgroundFetchResultFailed'\n */\n fetchResult: string,\n ) => void;\n +setApplicationIconBadgeNumber: (num: number) => void;\n +getApplicationIconBadgeNumber: (callback: (num: number) => void) => void;\n +requestPermissions: (permission: {|\n +alert: boolean,\n +badge: boolean,\n +sound: boolean,\n |}) => Promise;\n +abandonPermissions: () => void;\n +checkPermissions: (callback: (permissions: Permissions) => void) => void;\n +presentLocalNotification: (notification: Notification) => void;\n +scheduleLocalNotification: (notification: Notification) => void;\n +cancelAllLocalNotifications: () => void;\n +cancelLocalNotifications: (userInfo: Object) => void;\n +getInitialNotification: () => Promise;\n +getScheduledLocalNotifications: (\n callback: (notification: Notification) => void,\n ) => void;\n +removeAllDeliveredNotifications: () => void;\n +removeDeliveredNotifications: (identifiers: Array) => void;\n +getDeliveredNotifications: (\n callback: (notification: Array) => void,\n ) => void;\n +getAuthorizationStatus: (\n callback: (authorizationStatus: number) => void,\n ) => void;\n +addListener: (eventType: string) => void;\n +removeListeners: (count: number) => void;\n}\n\nexport default (TurboModuleRegistry.get(\n 'PushNotificationManager',\n): ?Spec);\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 * @format\n * @flow\n */\n\nimport RCTDeviceEventEmitter from '../EventEmitter/RCTDeviceEventEmitter';\nimport NativeSettingsManager from './NativeSettingsManager';\nimport invariant from 'invariant';\n\nconst subscriptions: Array<{\n keys: Array,\n callback: ?Function,\n ...\n}> = [];\n\nconst Settings = {\n _settings: (NativeSettingsManager &&\n NativeSettingsManager.getConstants().settings: any),\n\n get(key: string): mixed {\n // $FlowFixMe[object-this-reference]\n return this._settings[key];\n },\n\n set(settings: Object) {\n // $FlowFixMe[object-this-reference]\n this._settings = Object.assign(this._settings, settings);\n NativeSettingsManager.setValues(settings);\n },\n\n watchKeys(keys: string | Array, callback: Function): number {\n if (typeof keys === 'string') {\n keys = [keys];\n }\n\n invariant(\n Array.isArray(keys),\n 'keys should be a string or array of strings',\n );\n\n const sid = subscriptions.length;\n subscriptions.push({keys: keys, callback: callback});\n return sid;\n },\n\n clearWatch(watchId: number) {\n if (watchId < subscriptions.length) {\n subscriptions[watchId] = {keys: [], callback: null};\n }\n },\n\n _sendObservations(body: Object) {\n Object.keys(body).forEach(key => {\n const newValue = body[key];\n // $FlowFixMe[object-this-reference]\n const didChange = this._settings[key] !== newValue;\n // $FlowFixMe[object-this-reference]\n this._settings[key] = newValue;\n\n if (didChange) {\n subscriptions.forEach(sub => {\n if (sub.keys.indexOf(key) !== -1 && sub.callback) {\n sub.callback();\n }\n });\n }\n });\n },\n};\n\nRCTDeviceEventEmitter.addListener(\n 'settingsUpdated',\n Settings._sendObservations.bind(Settings),\n);\n\nmodule.exports = Settings;\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 * @flow\n * @format\n */\n\nimport type {TurboModule} from '../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../TurboModule/TurboModuleRegistry';\n\nexport interface Spec extends TurboModule {\n +getConstants: () => {|\n settings: Object,\n |};\n +setValues: (values: Object) => void;\n +deleteValues: (values: Array) => void;\n}\n\nexport default (TurboModuleRegistry.getEnforcing(\n 'SettingsManager',\n): Spec);\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 * @format\n * @flow strict-local\n */\n\nimport NativeActionSheetManager from '../ActionSheetIOS/NativeActionSheetManager';\nimport NativeShareModule from './NativeShareModule';\n\nconst processColor = require('../StyleSheet/processColor');\nconst Platform = require('../Utilities/Platform');\nconst invariant = require('invariant');\n\ntype Content =\n | {\n title?: string,\n message: string,\n ...\n }\n | {\n title?: string,\n url: string,\n ...\n };\ntype Options = {\n dialogTitle?: string,\n excludedActivityTypes?: Array,\n tintColor?: string,\n subject?: string,\n anchor?: number,\n ...\n};\n\nclass Share {\n /**\n * Open a dialog to share text content.\n *\n * In iOS, Returns a Promise which will be invoked an object containing `action`, `activityType`.\n * If the user dismissed the dialog, the Promise will still be resolved with action being `Share.dismissedAction`\n * and all the other keys being undefined.\n *\n * In Android, Returns a Promise which always be resolved with action being `Share.sharedAction`.\n *\n * ### Content\n *\n * - `message` - a message to share\n *\n * #### iOS\n *\n * - `url` - a URL to share\n *\n * At least one of URL and message is required.\n *\n * #### Android\n *\n * - `title` - title of the message\n *\n * ### Options\n *\n * #### iOS\n *\n * - `subject` - a subject to share via email\n * - `excludedActivityTypes`\n * - `tintColor`\n *\n * #### Android\n *\n * - `dialogTitle`\n *\n */\n static share(\n content: Content,\n options: Options = {},\n ): Promise<{action: string, activityType: ?string}> {\n invariant(\n typeof content === 'object' && content !== null,\n 'Content to share must be a valid object',\n );\n invariant(\n typeof content.url === 'string' || typeof content.message === 'string',\n 'At least one of URL and message is required',\n );\n invariant(\n typeof options === 'object' && options !== null,\n 'Options must be a valid object',\n );\n\n if (Platform.OS === 'android') {\n invariant(\n NativeShareModule,\n 'ShareModule should be registered on Android.',\n );\n invariant(\n content.title == null || typeof content.title === 'string',\n 'Invalid title: title should be a string.',\n );\n\n const newContent = {\n title: content.title,\n message:\n typeof content.message === 'string' ? content.message : undefined,\n };\n\n return NativeShareModule.share(newContent, options.dialogTitle).then(\n result => ({\n activityType: null,\n ...result,\n }),\n );\n } else if (Platform.OS === 'ios') {\n return new Promise((resolve, reject) => {\n const tintColor = processColor(options.tintColor);\n\n invariant(\n tintColor == null || typeof tintColor === 'number',\n 'Unexpected color given for options.tintColor',\n );\n\n invariant(\n NativeActionSheetManager,\n 'NativeActionSheetManager is not registered on iOS, but it should be.',\n );\n\n NativeActionSheetManager.showShareActionSheetWithOptions(\n {\n message:\n typeof content.message === 'string' ? content.message : undefined,\n url: typeof content.url === 'string' ? content.url : undefined,\n subject: options.subject,\n tintColor: typeof tintColor === 'number' ? tintColor : undefined,\n anchor:\n typeof options.anchor === 'number' ? options.anchor : undefined,\n excludedActivityTypes: options.excludedActivityTypes,\n },\n error => reject(error),\n (success, activityType) => {\n if (success) {\n resolve({\n action: 'sharedAction',\n activityType: activityType,\n });\n } else {\n resolve({\n action: 'dismissedAction',\n activityType: null,\n });\n }\n },\n );\n });\n } else {\n return Promise.reject(new Error('Unsupported platform'));\n }\n }\n\n /**\n * The content was successfully shared.\n */\n static sharedAction: 'sharedAction' = 'sharedAction';\n\n /**\n * The dialog has been dismissed.\n * @platform ios\n */\n static dismissedAction: 'dismissedAction' = 'dismissedAction';\n}\n\nmodule.exports = Share;\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 * @flow strict\n * @format\n */\n\nimport type {TurboModule} from '../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../TurboModule/TurboModuleRegistry';\n\nexport interface Spec extends TurboModule {\n +getConstants: () => {||};\n +share: (\n content: {|title?: string, message?: string|},\n dialogTitle?: string,\n ) => Promise<{|action: string|}>;\n}\n\nexport default (TurboModuleRegistry.get('ShareModule'): ?Spec);\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 * @format\n * @noflow\n */\n\n'use strict';\n\nconst ToastAndroid = {\n show: function (message: string, duration: number): void {\n console.warn('ToastAndroid is not supported on this platform.');\n },\n\n showWithGravity: function (\n message: string,\n duration: number,\n gravity: number,\n ): void {\n console.warn('ToastAndroid is not supported on this platform.');\n },\n\n showWithGravityAndOffset: function (\n message: string,\n duration: number,\n gravity: number,\n xOffset: number,\n yOffset: number,\n ): void {\n console.warn('ToastAndroid is not supported on this platform.');\n },\n};\n\nmodule.exports = ToastAndroid;\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 * @flow strict-local\n * @format\n */\n\nimport type {AnimatedValueConfig} from './nodes/AnimatedValue';\n\nimport Animated from './Animated';\nimport {useRef} from 'react';\n\nexport default function useAnimatedValue(\n initialValue: number,\n config?: ?AnimatedValueConfig,\n): Animated.Value {\n const ref = useRef(null);\n if (ref.current == null) {\n ref.current = new Animated.Value(initialValue, config);\n }\n return ref.current;\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 * @format\n * @flow strict-local\n */\n\n'use strict';\n\nimport type {ColorSchemeName} from './NativeAppearance';\n\nimport Appearance from './Appearance';\nimport {useSyncExternalStore} from 'use-sync-external-store/shim';\n\nexport default function useColorScheme(): ?ColorSchemeName {\n return useSyncExternalStore(\n callback => {\n const appearanceSubscription = Appearance.addChangeListener(callback);\n return () => appearanceSubscription.remove();\n },\n () => Appearance.getColorScheme(),\n );\n}\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('../cjs/use-sync-external-store-shim.native.production.min.js');\n} else {\n module.exports = require('../cjs/use-sync-external-store-shim.native.development.js');\n}\n","/**\n * @license React\n * use-sync-external-store-shim.native.production.min.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'use strict';var e=require(\"react\");function h(a,b){return a===b&&(0!==a||1/a===1/b)||a!==a&&b!==b}var k=\"function\"===typeof Object.is?Object.is:h,l=e.useState,m=e.useEffect,n=e.useLayoutEffect,p=e.useDebugValue;function q(a,b){var d=b(),f=l({inst:{value:d,getSnapshot:b}}),c=f[0].inst,g=f[1];n(function(){c.value=d;c.getSnapshot=b;r(c)&&g({inst:c})},[a,d,b]);m(function(){r(c)&&g({inst:c});return a(function(){r(c)&&g({inst:c})})},[a]);p(d);return d}\nfunction r(a){var b=a.getSnapshot;a=a.value;try{var d=b();return!k(a,d)}catch(f){return!0}}exports.useSyncExternalStore=void 0!==e.useSyncExternalStore?e.useSyncExternalStore:q;\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 * @format\n * @flow strict-local\n */\n\nimport Dimensions from './Dimensions';\nimport {\n type DisplayMetrics,\n type DisplayMetricsAndroid,\n} from './NativeDeviceInfo';\nimport {useEffect, useState} from 'react';\n\nexport default function useWindowDimensions():\n | DisplayMetrics\n | DisplayMetricsAndroid {\n const [dimensions, setDimensions] = useState(() => Dimensions.get('window'));\n useEffect(() => {\n function handleChange({\n window,\n }:\n | $FlowFixMe\n | $TEMPORARY$object<{window: DisplayMetrics | DisplayMetricsAndroid}>) {\n if (\n dimensions.width !== window.width ||\n dimensions.height !== window.height ||\n dimensions.scale !== window.scale ||\n dimensions.fontScale !== window.fontScale\n ) {\n setDimensions(window);\n }\n }\n const subscription = Dimensions.addEventListener('change', handleChange);\n // We might have missed an update between calling `get` in render and\n // `addEventListener` in this handler, so we set it here. If there was\n // no change, React will filter out this update as a no-op.\n handleChange({window: Dimensions.get('window')});\n return () => {\n subscription.remove();\n };\n }, [dimensions]);\n return dimensions;\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 * @flow strict\n * @format\n */\n\n'use strict';\n\nconst deepFreezeAndThrowOnMutationInDev = require('./Utilities/deepFreezeAndThrowOnMutationInDev');\n\n/**\n * A collection of Unicode sequences for various characters and emoji.\n *\n * - More explicit than using the sequences directly in code.\n * - Source code should be limited to ASCII.\n * - Less chance of typos.\n */\nconst UTFSequence: {|\n BOM: string,\n BULLET: string,\n BULLET_SP: string,\n MDASH: string,\n MDASH_SP: string,\n MIDDOT: string,\n MIDDOT_KATAKANA: string,\n MIDDOT_SP: string,\n NBSP: string,\n NDASH: string,\n NDASH_SP: string,\n PIZZA: string,\n TRIANGLE_LEFT: string,\n TRIANGLE_RIGHT: string,\n|} = deepFreezeAndThrowOnMutationInDev({\n BOM: '\\ufeff', // byte order mark\n BULLET: '\\u2022', // bullet: •\n BULLET_SP: '\\u00A0\\u2022\\u00A0', //  • \n MIDDOT: '\\u00B7', // normal middle dot: ·\n MIDDOT_SP: '\\u00A0\\u00B7\\u00A0', //  · \n MIDDOT_KATAKANA: '\\u30FB', // katakana middle dot\n MDASH: '\\u2014', // em dash: —\n MDASH_SP: '\\u00A0\\u2014\\u00A0', //  — \n NDASH: '\\u2013', // en dash: –\n NDASH_SP: '\\u00A0\\u2013\\u00A0', //  – \n NBSP: '\\u00A0', // non-breaking space:  \n PIZZA: '\\uD83C\\uDF55',\n TRIANGLE_LEFT: '\\u25c0', // black left-pointing triangle\n TRIANGLE_RIGHT: '\\u25b6', // black right-pointing triangle\n});\n\nmodule.exports = UTFSequence;\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 * @format\n * @flow strict\n * @jsdoc\n */\n\nimport NativeVibration from './NativeVibration';\n\nconst Platform = require('../Utilities/Platform');\n\n/**\n * Vibration API\n *\n * See https://reactnative.dev/docs/vibration\n */\n\nlet _vibrating: boolean = false;\nlet _id: number = 0; // _id is necessary to prevent race condition.\nconst _default_vibration_length = 400;\n\nfunction vibrateByPattern(pattern: Array, repeat: boolean = false) {\n if (_vibrating) {\n return;\n }\n _vibrating = true;\n if (pattern[0] === 0) {\n NativeVibration.vibrate(_default_vibration_length);\n // $FlowFixMe[reassign-const]\n pattern = pattern.slice(1);\n }\n if (pattern.length === 0) {\n _vibrating = false;\n return;\n }\n setTimeout(() => vibrateScheduler(++_id, pattern, repeat, 1), pattern[0]);\n}\n\nfunction vibrateScheduler(\n id: number,\n pattern: Array,\n repeat: boolean,\n nextIndex: number,\n) {\n if (!_vibrating || id !== _id) {\n return;\n }\n NativeVibration.vibrate(_default_vibration_length);\n if (nextIndex >= pattern.length) {\n if (repeat) {\n // $FlowFixMe[reassign-const]\n nextIndex = 0;\n } else {\n _vibrating = false;\n return;\n }\n }\n setTimeout(\n () => vibrateScheduler(id, pattern, repeat, nextIndex + 1),\n pattern[nextIndex],\n );\n}\n\nconst Vibration = {\n /**\n * Trigger a vibration with specified `pattern`.\n *\n * See https://reactnative.dev/docs/vibration#vibrate\n */\n vibrate: function (\n pattern: number | Array = _default_vibration_length,\n repeat: boolean = false,\n ) {\n if (Platform.OS === 'android') {\n if (typeof pattern === 'number') {\n NativeVibration.vibrate(pattern);\n } else if (Array.isArray(pattern)) {\n NativeVibration.vibrateByPattern(pattern, repeat ? 0 : -1);\n } else {\n throw new Error('Vibration pattern should be a number or array');\n }\n } else {\n if (_vibrating) {\n return;\n }\n if (typeof pattern === 'number') {\n NativeVibration.vibrate(pattern);\n } else if (Array.isArray(pattern)) {\n vibrateByPattern(pattern, repeat);\n } else {\n throw new Error('Vibration pattern should be a number or array');\n }\n }\n },\n /**\n * Stop vibration\n *\n * See https://reactnative.dev/docs/vibration#cancel\n */\n cancel: function () {\n if (Platform.OS === 'ios') {\n _vibrating = false;\n } else {\n NativeVibration.cancel();\n }\n },\n};\n\nmodule.exports = Vibration;\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 * @flow strict\n * @format\n */\n\nimport type {TurboModule} from '../TurboModule/RCTExport';\n\nimport * as TurboModuleRegistry from '../TurboModule/TurboModuleRegistry';\n\nexport interface Spec extends TurboModule {\n +getConstants: () => {||};\n +vibrate: (pattern: number) => void;\n\n // Android only\n +vibrateByPattern: (pattern: Array, repeat: number) => void;\n +cancel: () => void;\n}\n\nexport default (TurboModuleRegistry.getEnforcing('Vibration'): Spec);\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport type {IgnorePattern} from '../LogBox/Data/LogBoxData';\n\nconst LogBox = require('../LogBox/LogBox');\nconst React = require('react');\n\ntype Props = $ReadOnly<{||}>;\n\nlet YellowBox;\nif (__DEV__) {\n YellowBox = class extends React.Component {\n static ignoreWarnings(patterns: $ReadOnlyArray): void {\n console.warn(\n 'YellowBox has been replaced with LogBox. Please call LogBox.ignoreLogs() instead.',\n );\n\n LogBox.ignoreLogs(patterns);\n }\n\n static install(): void {\n console.warn(\n 'YellowBox has been replaced with LogBox. Please call LogBox.install() instead.',\n );\n LogBox.install();\n }\n\n static uninstall(): void {\n console.warn(\n 'YellowBox has been replaced with LogBox. Please call LogBox.uninstall() instead.',\n );\n LogBox.uninstall();\n }\n\n render(): React.Node {\n return null;\n }\n };\n} else {\n YellowBox = class extends React.Component {\n static ignoreWarnings(patterns: $ReadOnlyArray): void {\n // Do nothing.\n }\n\n static install(): void {\n // Do nothing.\n }\n\n static uninstall(): void {\n // Do nothing.\n }\n\n render(): React.Node {\n return null;\n }\n };\n}\n\n// $FlowFixMe[method-unbinding]\nmodule.exports = (YellowBox: Class> & {\n ignoreWarnings($ReadOnlyArray): void,\n install(): void,\n uninstall(): void,\n ...\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 * @format\n * @flow strict-local\n */\n\nimport type {ColorValue} from './StyleSheet';\n\nimport {DynamicColorIOSPrivate} from './PlatformColorValueTypes';\n\nexport type DynamicColorIOSTuple = {\n light: ColorValue,\n dark: ColorValue,\n highContrastLight?: ColorValue,\n highContrastDark?: ColorValue,\n};\n\nexport const DynamicColorIOS = (tuple: DynamicColorIOSTuple): ColorValue => {\n return DynamicColorIOSPrivate({\n light: tuple.light,\n dark: tuple.dark,\n highContrastLight: tuple.highContrastLight,\n highContrastDark: tuple.highContrastDark,\n });\n};\n","import * as React from 'react';\nimport { useImperativeHandle, useRef } from 'react';\n\nimport {\n NativeViewGestureHandler,\n NativeViewGestureHandlerProps,\n nativeViewProps,\n} from './NativeViewGestureHandler';\n\n/*\n * This array should consist of:\n * - All keys in propTypes from NativeGestureHandler\n * (and all keys in GestureHandlerPropTypes)\n * - 'onGestureHandlerEvent'\n * - 'onGestureHandlerStateChange'\n */\nconst NATIVE_WRAPPER_PROPS_FILTER = [\n ...nativeViewProps,\n 'onGestureHandlerEvent',\n 'onGestureHandlerStateChange',\n] as const;\n\nexport default function createNativeWrapper

(\n Component: React.ComponentType

,\n config: Readonly = {}\n) {\n const ComponentWrapper = React.forwardRef<\n React.ComponentType,\n P & NativeViewGestureHandlerProps\n >((props, ref) => {\n // filter out props that should be passed to gesture handler wrapper\n const gestureHandlerProps = Object.keys(props).reduce(\n (res, key) => {\n // TS being overly protective with it's types, see https://github.com/microsoft/TypeScript/issues/26255#issuecomment-458013731 for more info\n const allowedKeys: readonly string[] = NATIVE_WRAPPER_PROPS_FILTER;\n if (allowedKeys.includes(key)) {\n // @ts-ignore FIXME(TS)\n res[key] = props[key];\n }\n return res;\n },\n { ...config } // watch out not to modify config\n );\n const _ref = useRef>();\n const _gestureHandlerRef = useRef>();\n useImperativeHandle(\n ref,\n // @ts-ignore TODO(TS) decide how nulls work in this context\n () => {\n const node = _gestureHandlerRef.current;\n // add handlerTag for relations config\n if (_ref.current && node) {\n // @ts-ignore FIXME(TS) think about createHandler return type\n _ref.current.handlerTag = node.handlerTag;\n return _ref.current;\n }\n return null;\n },\n [_ref, _gestureHandlerRef]\n );\n return (\n \n \n \n );\n });\n\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n ComponentWrapper.displayName =\n Component?.displayName ||\n // @ts-ignore if render doesn't exist it will return undefined and go further\n Component?.render?.name ||\n (typeof Component === 'string' && Component) ||\n 'ComponentWrapper';\n\n return ComponentWrapper;\n}\n","import createHandler from './createHandler';\nimport {\n BaseGestureHandlerProps,\n baseGestureHandlerProps,\n} from './gestureHandlerCommon';\n\nexport const nativeViewGestureHandlerProps = [\n 'shouldActivateOnStart',\n 'disallowInterruption',\n] as const;\n\nexport interface NativeViewGestureConfig {\n /**\n * Android only.\n *\n * Determines whether the handler should check for an existing touch event on\n * instantiation.\n */\n shouldActivateOnStart?: boolean;\n\n /**\n * When `true`, cancels all other gesture handlers when this\n * `NativeViewGestureHandler` receives an `ACTIVE` state event.\n */\n disallowInterruption?: boolean;\n}\n\nexport interface NativeViewGestureHandlerProps\n extends BaseGestureHandlerProps,\n NativeViewGestureConfig {}\n\nexport type NativeViewGestureHandlerPayload = {\n /**\n * True if gesture was performed inside of containing view, false otherwise.\n */\n pointerInside: boolean;\n};\n\nexport const nativeViewProps = [\n ...baseGestureHandlerProps,\n ...nativeViewGestureHandlerProps,\n] as const;\n\nexport const nativeViewHandlerName = 'NativeViewGestureHandler';\n\nexport type NativeViewGestureHandler = typeof NativeViewGestureHandler;\n// eslint-disable-next-line @typescript-eslint/no-redeclare -- backward compatibility; see description on the top of gestureHandlerCommon.ts file\nexport const NativeViewGestureHandler = createHandler<\n NativeViewGestureHandlerProps,\n NativeViewGestureHandlerPayload\n>({\n name: nativeViewHandlerName,\n allowedProps: nativeViewProps,\n config: {},\n});\n","import * as React from 'react';\nimport {\n Platform,\n UIManager,\n DeviceEventEmitter,\n EmitterSubscription,\n} from 'react-native';\n// @ts-ignore - it isn't typed by TS & don't have definitelyTyped types\nimport deepEqual from 'lodash/isEqual';\nimport RNGestureHandlerModule from '../RNGestureHandlerModule';\nimport type RNGestureHandlerModuleWeb from '../RNGestureHandlerModule.web';\nimport { State } from '../State';\nimport {\n handlerIDToTag,\n getNextHandlerTag,\n registerOldGestureHandler,\n} from './handlersRegistry';\n\nimport {\n BaseGestureHandlerProps,\n filterConfig,\n GestureEvent,\n HandlerStateChangeEvent,\n findNodeHandle,\n scheduleFlushOperations,\n} from './gestureHandlerCommon';\nimport { ValueOf } from '../typeUtils';\nimport { isFabric, isJestEnv, tagMessage } from '../utils';\nimport { ActionType } from '../ActionType';\nimport { PressabilityDebugView } from './PressabilityDebugView';\n\nconst UIManagerAny = UIManager as any;\n\nconst customGHEventsConfigFabricAndroid = {\n topOnGestureHandlerEvent: { registrationName: 'onGestureHandlerEvent' },\n topOnGestureHandlerStateChange: {\n registrationName: 'onGestureHandlerStateChange',\n },\n};\n\nconst customGHEventsConfig = {\n onGestureHandlerEvent: { registrationName: 'onGestureHandlerEvent' },\n onGestureHandlerStateChange: {\n registrationName: 'onGestureHandlerStateChange',\n },\n\n // When using React Native Gesture Handler for Animated.event with useNativeDriver: true\n // on Android with Fabric enabled, the native part still sends the native events to JS\n // but prefixed with \"top\". We cannot simply rename the events above so they are prefixed\n // with \"top\" instead of \"on\" because in such case Animated.events would not be registered.\n // That's why we need to register another pair of event names.\n // The incoming events will be queued but never handled.\n // Without this piece of code below, you'll get the following JS error:\n // Unsupported top level event type \"topOnGestureHandlerEvent\" dispatched\n ...(isFabric() &&\n Platform.OS === 'android' &&\n customGHEventsConfigFabricAndroid),\n};\n\n// Add gesture specific events to genericDirectEventTypes object exported from UIManager\n// native module.\n// Once new event types are registered with react it is possible to dispatch these\n// events to all kind of native views.\nUIManagerAny.genericDirectEventTypes = {\n ...UIManagerAny.genericDirectEventTypes,\n ...customGHEventsConfig,\n};\n// In newer versions of RN the `genericDirectEventTypes` is located in the object\n// returned by UIManager.getViewManagerConfig('getConstants') or in older RN UIManager.getConstants(), we need to add it there as well to make\n// it compatible with RN 61+\nconst UIManagerConstants =\n UIManagerAny.getViewManagerConfig?.('getConstants') ??\n UIManagerAny.getConstants?.();\n\nif (UIManagerConstants) {\n UIManagerConstants.genericDirectEventTypes = {\n ...UIManagerConstants.genericDirectEventTypes,\n ...customGHEventsConfig,\n };\n}\n\n// Wrap JS responder calls and notify gesture handler manager\nconst {\n setJSResponder: oldSetJSResponder = () => {\n //no operation\n },\n clearJSResponder: oldClearJSResponder = () => {\n //no operation\n },\n} = UIManagerAny;\nUIManagerAny.setJSResponder = (tag: number, blockNativeResponder: boolean) => {\n RNGestureHandlerModule.handleSetJSResponder(tag, blockNativeResponder);\n oldSetJSResponder(tag, blockNativeResponder);\n};\nUIManagerAny.clearJSResponder = () => {\n RNGestureHandlerModule.handleClearJSResponder();\n oldClearJSResponder();\n};\n\nlet allowTouches = true;\nconst DEV_ON_ANDROID = __DEV__ && Platform.OS === 'android';\n// Toggled inspector blocks touch events in order to allow inspecting on Android\n// This needs to be a global variable in order to set initial state for `allowTouches` property in Handler component\nif (DEV_ON_ANDROID) {\n DeviceEventEmitter.addListener('toggleElementInspector', () => {\n allowTouches = !allowTouches;\n });\n}\n\ntype HandlerProps> = Readonly<\n React.PropsWithChildren>\n>;\nfunction hasUnresolvedRefs>(\n props: HandlerProps\n) {\n // TODO(TS) - add type for extract arg\n const extract = (refs: any | any[]) => {\n if (!Array.isArray(refs)) {\n return refs && refs.current === null;\n }\n return refs.some((r) => r && r.current === null);\n };\n return extract(props['simultaneousHandlers']) || extract(props['waitFor']);\n}\n\nconst stateToPropMappings = {\n [State.UNDETERMINED]: undefined,\n [State.BEGAN]: 'onBegan',\n [State.FAILED]: 'onFailed',\n [State.CANCELLED]: 'onCancelled',\n [State.ACTIVE]: 'onActivated',\n [State.END]: 'onEnded',\n} as const;\n\ntype CreateHandlerArgs> =\n Readonly<{\n name: string;\n allowedProps: Readonly[]>;\n config: Readonly>;\n transformProps?: (props: HandlerPropsT) => HandlerPropsT;\n customNativeProps?: Readonly;\n }>;\n\n// TODO(TS) fix event types\ntype InternalEventHandlers = {\n onGestureHandlerEvent?: (event: any) => void;\n onGestureHandlerStateChange?: (event: any) => void;\n};\n\nconst UNRESOLVED_REFS_RETRY_LIMIT = 1;\n\n// TODO(TS) - make sure that BaseGestureHandlerProps doesn't need other generic parameter to work with custom properties.\nexport default function createHandler<\n T extends BaseGestureHandlerProps,\n U extends Record\n>({\n name,\n allowedProps = [],\n config = {},\n transformProps,\n customNativeProps = [],\n}: CreateHandlerArgs): React.ComponentType> {\n interface HandlerState {\n allowTouches: boolean;\n }\n class Handler extends React.Component<\n T & InternalEventHandlers,\n HandlerState\n > {\n static displayName = name;\n\n private handlerTag: number;\n private config: Record;\n private propsRef: React.MutableRefObject;\n private viewNode: any;\n private viewTag?: number;\n private updateEnqueued: ReturnType | null = null;\n private inspectorToggleListener?: EmitterSubscription;\n\n constructor(props: T & InternalEventHandlers) {\n super(props);\n this.handlerTag = getNextHandlerTag();\n this.config = {};\n this.propsRef = React.createRef();\n this.state = { allowTouches };\n if (props.id) {\n if (handlerIDToTag[props.id] !== undefined) {\n throw new Error(`Handler with ID \"${props.id}\" already registered`);\n }\n handlerIDToTag[props.id] = this.handlerTag;\n }\n }\n\n componentDidMount() {\n const props: HandlerProps = this.props;\n\n if (DEV_ON_ANDROID) {\n this.inspectorToggleListener = DeviceEventEmitter.addListener(\n 'toggleElementInspector',\n () => {\n this.setState((_) => ({ allowTouches }));\n this.update(UNRESOLVED_REFS_RETRY_LIMIT);\n }\n );\n }\n if (hasUnresolvedRefs(props)) {\n // If there are unresolved refs (e.g. \".current\" has not yet been set)\n // passed as `simultaneousHandlers` or `waitFor`, we enqueue a call to\n // _update method that will try to update native handler props using\n // setImmediate. This makes it so update() function gets called after all\n // react components are mounted and we expect the missing ref object to\n // be resolved by then.\n this.updateEnqueued = setImmediate(() => {\n this.updateEnqueued = null;\n this.update(UNRESOLVED_REFS_RETRY_LIMIT);\n });\n }\n\n this.createGestureHandler(\n filterConfig(\n transformProps ? transformProps(this.props) : this.props,\n [...allowedProps, ...customNativeProps],\n config\n )\n );\n\n this.attachGestureHandler(findNodeHandle(this.viewNode) as number); // TODO(TS) - check if this can be null\n }\n\n componentDidUpdate() {\n const viewTag = findNodeHandle(this.viewNode);\n if (this.viewTag !== viewTag) {\n this.attachGestureHandler(viewTag as number); // TODO(TS) - check interaction between _viewTag & findNodeHandle\n }\n this.update(UNRESOLVED_REFS_RETRY_LIMIT);\n }\n\n componentWillUnmount() {\n this.inspectorToggleListener?.remove();\n RNGestureHandlerModule.dropGestureHandler(this.handlerTag);\n scheduleFlushOperations();\n if (this.updateEnqueued) {\n clearImmediate(this.updateEnqueued);\n }\n // We can't use this.props.id directly due to TS generic type narrowing bug, see https://github.com/microsoft/TypeScript/issues/13995 for more context\n const handlerID: string | undefined = this.props.id;\n if (handlerID) {\n // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n delete handlerIDToTag[handlerID];\n }\n }\n\n private onGestureHandlerEvent = (event: GestureEvent) => {\n if (event.nativeEvent.handlerTag === this.handlerTag) {\n if (typeof this.props.onGestureEvent === 'function') {\n this.props.onGestureEvent?.(event);\n }\n } else {\n this.props.onGestureHandlerEvent?.(event);\n }\n };\n\n // TODO(TS) - make sure this is right type for event\n private onGestureHandlerStateChange = (\n event: HandlerStateChangeEvent\n ) => {\n if (event.nativeEvent.handlerTag === this.handlerTag) {\n if (typeof this.props.onHandlerStateChange === 'function') {\n this.props.onHandlerStateChange?.(event);\n }\n\n const state: ValueOf = event.nativeEvent.state;\n const stateEventName = stateToPropMappings[state];\n const eventHandler = stateEventName && this.props[stateEventName];\n if (eventHandler && typeof eventHandler === 'function') {\n eventHandler(event);\n }\n } else {\n this.props.onGestureHandlerStateChange?.(event);\n }\n };\n\n private refHandler = (node: any) => {\n this.viewNode = node;\n\n const child = React.Children.only(this.props.children);\n // TODO(TS) fix ref type\n const { ref }: any = child;\n if (ref !== null) {\n if (typeof ref === 'function') {\n ref(node);\n } else {\n ref.current = node;\n }\n }\n };\n\n private createGestureHandler = (\n newConfig: Readonly>\n ) => {\n this.config = newConfig;\n\n RNGestureHandlerModule.createGestureHandler(\n name,\n this.handlerTag,\n newConfig\n );\n };\n\n private attachGestureHandler = (newViewTag: number) => {\n this.viewTag = newViewTag;\n\n if (Platform.OS === 'web') {\n // typecast due to dynamic resolution, attachGestureHandler should have web version signature in this branch\n (\n RNGestureHandlerModule.attachGestureHandler as typeof RNGestureHandlerModuleWeb.attachGestureHandler\n )(\n this.handlerTag,\n newViewTag,\n ActionType.JS_FUNCTION_OLD_API, // ignored on web\n this.propsRef\n );\n } else {\n registerOldGestureHandler(this.handlerTag, {\n onGestureEvent: this.onGestureHandlerEvent,\n onGestureStateChange: this.onGestureHandlerStateChange,\n });\n\n const actionType = (() => {\n if (\n this.props?.onGestureEvent &&\n 'current' in this.props.onGestureEvent\n ) {\n // Reanimated worklet\n return ActionType.REANIMATED_WORKLET;\n } else if (\n this.props?.onGestureEvent &&\n '__isNative' in this.props.onGestureEvent\n ) {\n // Animated.event with useNativeDriver: true\n return ActionType.NATIVE_ANIMATED_EVENT;\n } else {\n // JS callback or Animated.event with useNativeDriver: false\n return ActionType.JS_FUNCTION_OLD_API;\n }\n })();\n\n RNGestureHandlerModule.attachGestureHandler(\n this.handlerTag,\n newViewTag,\n actionType\n );\n }\n\n scheduleFlushOperations();\n };\n\n private updateGestureHandler = (\n newConfig: Readonly>\n ) => {\n this.config = newConfig;\n\n RNGestureHandlerModule.updateGestureHandler(this.handlerTag, newConfig);\n scheduleFlushOperations();\n };\n\n private update(remainingTries: number) {\n const props: HandlerProps = this.props;\n\n // When ref is set via a function i.e. `ref={(r) => refObject.current = r}` instead of\n // `ref={refObject}` it's possible that it won't be resolved in time. Seems like trying\n // again is easy enough fix.\n if (hasUnresolvedRefs(props) && remainingTries > 0) {\n this.updateEnqueued = setImmediate(() => {\n this.updateEnqueued = null;\n this.update(remainingTries - 1);\n });\n } else {\n const newConfig = filterConfig(\n transformProps ? transformProps(this.props) : this.props,\n [...allowedProps, ...customNativeProps],\n config\n );\n if (!deepEqual(this.config, newConfig)) {\n this.updateGestureHandler(newConfig);\n }\n }\n }\n\n setNativeProps(updates: any) {\n const mergedProps = { ...this.props, ...updates };\n const newConfig = filterConfig(\n transformProps ? transformProps(mergedProps) : mergedProps,\n [...allowedProps, ...customNativeProps],\n config\n );\n this.updateGestureHandler(newConfig);\n }\n\n render() {\n let gestureEventHandler = this.onGestureHandlerEvent;\n // Another instance of https://github.com/microsoft/TypeScript/issues/13995\n type OnGestureEventHandlers = {\n onGestureEvent?: BaseGestureHandlerProps['onGestureEvent'];\n onGestureHandlerEvent?: InternalEventHandlers['onGestureHandlerEvent'];\n };\n const { onGestureEvent, onGestureHandlerEvent }: OnGestureEventHandlers =\n this.props;\n if (onGestureEvent && typeof onGestureEvent !== 'function') {\n // If it's not a method it should be an native Animated.event\n // object. We set it directly as the handler for the view\n // In this case nested handlers are not going to be supported\n if (onGestureHandlerEvent) {\n throw new Error(\n 'Nesting touch handlers with native animated driver is not supported yet'\n );\n }\n gestureEventHandler = onGestureEvent;\n } else {\n if (\n onGestureHandlerEvent &&\n typeof onGestureHandlerEvent !== 'function'\n ) {\n throw new Error(\n 'Nesting touch handlers with native animated driver is not supported yet'\n );\n }\n }\n\n let gestureStateEventHandler = this.onGestureHandlerStateChange;\n // Another instance of https://github.com/microsoft/TypeScript/issues/13995\n type OnGestureStateChangeHandlers = {\n onHandlerStateChange?: BaseGestureHandlerProps['onHandlerStateChange'];\n onGestureHandlerStateChange?: InternalEventHandlers['onGestureHandlerStateChange'];\n };\n const {\n onHandlerStateChange,\n onGestureHandlerStateChange,\n }: OnGestureStateChangeHandlers = this.props;\n if (onHandlerStateChange && typeof onHandlerStateChange !== 'function') {\n // If it's not a method it should be an native Animated.event\n // object. We set it directly as the handler for the view\n // In this case nested handlers are not going to be supported\n if (onGestureHandlerStateChange) {\n throw new Error(\n 'Nesting touch handlers with native animated driver is not supported yet'\n );\n }\n gestureStateEventHandler = onHandlerStateChange;\n } else {\n if (\n onGestureHandlerStateChange &&\n typeof onGestureHandlerStateChange !== 'function'\n ) {\n throw new Error(\n 'Nesting touch handlers with native animated driver is not supported yet'\n );\n }\n }\n const events = {\n onGestureHandlerEvent: this.state.allowTouches\n ? gestureEventHandler\n : undefined,\n onGestureHandlerStateChange: this.state.allowTouches\n ? gestureStateEventHandler\n : undefined,\n };\n\n this.propsRef.current = events;\n\n let child: any = null;\n try {\n child = React.Children.only(this.props.children);\n } catch (e) {\n throw new Error(\n tagMessage(\n `${name} got more than one view as a child. If you want the gesture to work on multiple views, wrap them with a common parent and attach the gesture to that view.`\n )\n );\n }\n\n let grandChildren = child.props.children;\n if (\n __DEV__ &&\n child.type &&\n (child.type === 'RNGestureHandlerButton' ||\n child.type.name === 'View' ||\n child.type.displayName === 'View')\n ) {\n grandChildren = React.Children.toArray(grandChildren);\n grandChildren.push(\n \n );\n }\n\n return React.cloneElement(\n child,\n {\n ref: this.refHandler,\n collapsable: false,\n ...(isJestEnv()\n ? {\n handlerType: name,\n handlerTag: this.handlerTag,\n }\n : {}),\n testID: this.props.testID ?? child.props.testID,\n ...events,\n },\n grandChildren\n );\n }\n }\n return Handler;\n}\n","var baseIsEqual = require('./_baseIsEqual');\n\n/**\n * Performs a deep comparison between two values to determine if they are\n * equivalent.\n *\n * **Note:** This method supports comparing arrays, array buffers, booleans,\n * date objects, error objects, maps, numbers, `Object` objects, regexes,\n * sets, strings, symbols, and typed arrays. `Object` objects are compared\n * by their own, not inherited, enumerable properties. Functions and DOM\n * nodes are compared by strict equality, i.e. `===`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.isEqual(object, other);\n * // => true\n *\n * object === other;\n * // => false\n */\nfunction isEqual(value, other) {\n return baseIsEqual(value, other);\n}\n\nmodule.exports = isEqual;\n","var baseIsEqualDeep = require('./_baseIsEqualDeep'),\n isObjectLike = require('./isObjectLike');\n\n/**\n * The base implementation of `_.isEqual` which supports partial comparisons\n * and tracks traversed objects.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @param {boolean} bitmask The bitmask flags.\n * 1 - Unordered comparison\n * 2 - Partial comparison\n * @param {Function} [customizer] The function to customize comparisons.\n * @param {Object} [stack] Tracks traversed `value` and `other` objects.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n */\nfunction baseIsEqual(value, other, bitmask, customizer, stack) {\n if (value === other) {\n return true;\n }\n if (value == null || other == null || (!isObjectLike(value) && !isObjectLike(other))) {\n return value !== value && other !== other;\n }\n return baseIsEqualDeep(value, other, bitmask, customizer, baseIsEqual, stack);\n}\n\nmodule.exports = baseIsEqual;\n","/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n return value != null && typeof value == 'object';\n}\n\nmodule.exports = isObjectLike;\n","var Stack = require('./_Stack'),\n equalArrays = require('./_equalArrays'),\n equalByTag = require('./_equalByTag'),\n equalObjects = require('./_equalObjects'),\n getTag = require('./_getTag'),\n isArray = require('./isArray'),\n isBuffer = require('./isBuffer'),\n isTypedArray = require('./isTypedArray');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1;\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n objectTag = '[object Object]';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * A specialized version of `baseIsEqual` for arrays and objects which performs\n * deep comparisons and tracks traversed objects enabling objects with circular\n * references to be compared.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} [stack] Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction baseIsEqualDeep(object, other, bitmask, customizer, equalFunc, stack) {\n var objIsArr = isArray(object),\n othIsArr = isArray(other),\n objTag = objIsArr ? arrayTag : getTag(object),\n othTag = othIsArr ? arrayTag : getTag(other);\n\n objTag = objTag == argsTag ? objectTag : objTag;\n othTag = othTag == argsTag ? objectTag : othTag;\n\n var objIsObj = objTag == objectTag,\n othIsObj = othTag == objectTag,\n isSameTag = objTag == othTag;\n\n if (isSameTag && isBuffer(object)) {\n if (!isBuffer(other)) {\n return false;\n }\n objIsArr = true;\n objIsObj = false;\n }\n if (isSameTag && !objIsObj) {\n stack || (stack = new Stack);\n return (objIsArr || isTypedArray(object))\n ? equalArrays(object, other, bitmask, customizer, equalFunc, stack)\n : equalByTag(object, other, objTag, bitmask, customizer, equalFunc, stack);\n }\n if (!(bitmask & COMPARE_PARTIAL_FLAG)) {\n var objIsWrapped = objIsObj && hasOwnProperty.call(object, '__wrapped__'),\n othIsWrapped = othIsObj && hasOwnProperty.call(other, '__wrapped__');\n\n if (objIsWrapped || othIsWrapped) {\n var objUnwrapped = objIsWrapped ? object.value() : object,\n othUnwrapped = othIsWrapped ? other.value() : other;\n\n stack || (stack = new Stack);\n return equalFunc(objUnwrapped, othUnwrapped, bitmask, customizer, stack);\n }\n }\n if (!isSameTag) {\n return false;\n }\n stack || (stack = new Stack);\n return equalObjects(object, other, bitmask, customizer, equalFunc, stack);\n}\n\nmodule.exports = baseIsEqualDeep;\n","/**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(document.body.children);\n * // => false\n *\n * _.isArray('abc');\n * // => false\n *\n * _.isArray(_.noop);\n * // => false\n */\nvar isArray = Array.isArray;\n\nmodule.exports = isArray;\n","var DataView = require('./_DataView'),\n Map = require('./_Map'),\n Promise = require('./_Promise'),\n Set = require('./_Set'),\n WeakMap = require('./_WeakMap'),\n baseGetTag = require('./_baseGetTag'),\n toSource = require('./_toSource');\n\n/** `Object#toString` result references. */\nvar mapTag = '[object Map]',\n objectTag = '[object Object]',\n promiseTag = '[object Promise]',\n setTag = '[object Set]',\n weakMapTag = '[object WeakMap]';\n\nvar dataViewTag = '[object DataView]';\n\n/** Used to detect maps, sets, and weakmaps. */\nvar dataViewCtorString = toSource(DataView),\n mapCtorString = toSource(Map),\n promiseCtorString = toSource(Promise),\n setCtorString = toSource(Set),\n weakMapCtorString = toSource(WeakMap);\n\n/**\n * Gets the `toStringTag` of `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nvar getTag = baseGetTag;\n\n// Fallback for data views, maps, sets, and weak maps in IE 11 and promises in Node.js < 6.\nif ((DataView && getTag(new DataView(new ArrayBuffer(1))) != dataViewTag) ||\n (Map && getTag(new Map) != mapTag) ||\n (Promise && getTag(Promise.resolve()) != promiseTag) ||\n (Set && getTag(new Set) != setTag) ||\n (WeakMap && getTag(new WeakMap) != weakMapTag)) {\n getTag = function(value) {\n var result = baseGetTag(value),\n Ctor = result == objectTag ? value.constructor : undefined,\n ctorString = Ctor ? toSource(Ctor) : '';\n\n if (ctorString) {\n switch (ctorString) {\n case dataViewCtorString: return dataViewTag;\n case mapCtorString: return mapTag;\n case promiseCtorString: return promiseTag;\n case setCtorString: return setTag;\n case weakMapCtorString: return weakMapTag;\n }\n }\n return result;\n };\n}\n\nmodule.exports = getTag;\n","/** Used for built-in method references. */\nvar funcProto = Function.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/**\n * Converts `func` to its source code.\n *\n * @private\n * @param {Function} func The function to convert.\n * @returns {string} Returns the source code.\n */\nfunction toSource(func) {\n if (func != null) {\n try {\n return funcToString.call(func);\n } catch (e) {}\n try {\n return (func + '');\n } catch (e) {}\n }\n return '';\n}\n\nmodule.exports = toSource;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar DataView = getNative(root, 'DataView');\n\nmodule.exports = DataView;\n","var baseIsNative = require('./_baseIsNative'),\n getValue = require('./_getValue');\n\n/**\n * Gets the native function at `key` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the method to get.\n * @returns {*} Returns the function if it's native, else `undefined`.\n */\nfunction getNative(object, key) {\n var value = getValue(object, key);\n return baseIsNative(value) ? value : undefined;\n}\n\nmodule.exports = getNative;\n","/**\n * Gets the value at `key` of `object`.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\nfunction getValue(object, key) {\n return object == null ? undefined : object[key];\n}\n\nmodule.exports = getValue;\n","var isFunction = require('./isFunction'),\n isMasked = require('./_isMasked'),\n isObject = require('./isObject'),\n toSource = require('./_toSource');\n\n/**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\nvar reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g;\n\n/** Used to detect host constructors (Safari). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Used for built-in method references. */\nvar funcProto = Function.prototype,\n objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to detect if a method is native. */\nvar reIsNative = RegExp('^' +\n funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&')\n .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\n);\n\n/**\n * The base implementation of `_.isNative` without bad shim checks.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function,\n * else `false`.\n */\nfunction baseIsNative(value) {\n if (!isObject(value) || isMasked(value)) {\n return false;\n }\n var pattern = isFunction(value) ? reIsNative : reIsHostCtor;\n return pattern.test(toSource(value));\n}\n\nmodule.exports = baseIsNative;\n","/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n var type = typeof value;\n return value != null && (type == 'object' || type == 'function');\n}\n\nmodule.exports = isObject;\n","var coreJsData = require('./_coreJsData');\n\n/** Used to detect methods masquerading as native. */\nvar maskSrcKey = (function() {\n var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\n return uid ? ('Symbol(src)_1.' + uid) : '';\n}());\n\n/**\n * Checks if `func` has its source masked.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` is masked, else `false`.\n */\nfunction isMasked(func) {\n return !!maskSrcKey && (maskSrcKey in func);\n}\n\nmodule.exports = isMasked;\n","var root = require('./_root');\n\n/** Used to detect overreaching core-js shims. */\nvar coreJsData = root['__core-js_shared__'];\n\nmodule.exports = coreJsData;\n","var freeGlobal = require('./_freeGlobal');\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\nmodule.exports = root;\n","/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\nmodule.exports = freeGlobal;\n","var baseGetTag = require('./_baseGetTag'),\n isObject = require('./isObject');\n\n/** `Object#toString` result references. */\nvar asyncTag = '[object AsyncFunction]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n proxyTag = '[object Proxy]';\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n if (!isObject(value)) {\n return false;\n }\n // The use of `Object#toString` avoids issues with the `typeof` operator\n // in Safari 9 which returns 'object' for typed arrays and other constructors.\n var tag = baseGetTag(value);\n return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;\n}\n\nmodule.exports = isFunction;\n","var Symbol = require('./_Symbol'),\n getRawTag = require('./_getRawTag'),\n objectToString = require('./_objectToString');\n\n/** `Object#toString` result references. */\nvar nullTag = '[object Null]',\n undefinedTag = '[object Undefined]';\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * The base implementation of `getTag` without fallbacks for buggy environments.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n if (value == null) {\n return value === undefined ? undefinedTag : nullTag;\n }\n return (symToStringTag && symToStringTag in Object(value))\n ? getRawTag(value)\n : objectToString(value);\n}\n\nmodule.exports = baseGetTag;\n","var root = require('./_root');\n\n/** Built-in value references. */\nvar Symbol = root.Symbol;\n\nmodule.exports = Symbol;\n","var Symbol = require('./_Symbol');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the raw `toStringTag`.\n */\nfunction getRawTag(value) {\n var isOwn = hasOwnProperty.call(value, symToStringTag),\n tag = value[symToStringTag];\n\n try {\n value[symToStringTag] = undefined;\n var unmasked = true;\n } catch (e) {}\n\n var result = nativeObjectToString.call(value);\n if (unmasked) {\n if (isOwn) {\n value[symToStringTag] = tag;\n } else {\n delete value[symToStringTag];\n }\n }\n return result;\n}\n\nmodule.exports = getRawTag;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/**\n * Converts `value` to a string using `Object.prototype.toString`.\n *\n * @private\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n */\nfunction objectToString(value) {\n return nativeObjectToString.call(value);\n}\n\nmodule.exports = objectToString;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar Map = getNative(root, 'Map');\n\nmodule.exports = Map;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar Promise = getNative(root, 'Promise');\n\nmodule.exports = Promise;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar Set = getNative(root, 'Set');\n\nmodule.exports = Set;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar WeakMap = getNative(root, 'WeakMap');\n\nmodule.exports = WeakMap;\n","var root = require('./_root'),\n stubFalse = require('./stubFalse');\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined;\n\n/**\n * Checks if `value` is a buffer.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.\n * @example\n *\n * _.isBuffer(new Buffer(2));\n * // => true\n *\n * _.isBuffer(new Uint8Array(2));\n * // => false\n */\nvar isBuffer = nativeIsBuffer || stubFalse;\n\nmodule.exports = isBuffer;\n","/**\n * This method returns `false`.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {boolean} Returns `false`.\n * @example\n *\n * _.times(2, _.stubFalse);\n * // => [false, false]\n */\nfunction stubFalse() {\n return false;\n}\n\nmodule.exports = stubFalse;\n","var ListCache = require('./_ListCache'),\n stackClear = require('./_stackClear'),\n stackDelete = require('./_stackDelete'),\n stackGet = require('./_stackGet'),\n stackHas = require('./_stackHas'),\n stackSet = require('./_stackSet');\n\n/**\n * Creates a stack cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Stack(entries) {\n var data = this.__data__ = new ListCache(entries);\n this.size = data.size;\n}\n\n// Add methods to `Stack`.\nStack.prototype.clear = stackClear;\nStack.prototype['delete'] = stackDelete;\nStack.prototype.get = stackGet;\nStack.prototype.has = stackHas;\nStack.prototype.set = stackSet;\n\nmodule.exports = Stack;\n","var listCacheClear = require('./_listCacheClear'),\n listCacheDelete = require('./_listCacheDelete'),\n listCacheGet = require('./_listCacheGet'),\n listCacheHas = require('./_listCacheHas'),\n listCacheSet = require('./_listCacheSet');\n\n/**\n * Creates an list cache object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction ListCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n// Add methods to `ListCache`.\nListCache.prototype.clear = listCacheClear;\nListCache.prototype['delete'] = listCacheDelete;\nListCache.prototype.get = listCacheGet;\nListCache.prototype.has = listCacheHas;\nListCache.prototype.set = listCacheSet;\n\nmodule.exports = ListCache;\n","/**\n * Removes all key-value entries from the list cache.\n *\n * @private\n * @name clear\n * @memberOf ListCache\n */\nfunction listCacheClear() {\n this.__data__ = [];\n this.size = 0;\n}\n\nmodule.exports = listCacheClear;\n","var assocIndexOf = require('./_assocIndexOf');\n\n/** Used for built-in method references. */\nvar arrayProto = Array.prototype;\n\n/** Built-in value references. */\nvar splice = arrayProto.splice;\n\n/**\n * Removes `key` and its value from the list cache.\n *\n * @private\n * @name delete\n * @memberOf ListCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction listCacheDelete(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n return false;\n }\n var lastIndex = data.length - 1;\n if (index == lastIndex) {\n data.pop();\n } else {\n splice.call(data, index, 1);\n }\n --this.size;\n return true;\n}\n\nmodule.exports = listCacheDelete;\n","var eq = require('./eq');\n\n/**\n * Gets the index at which the `key` is found in `array` of key-value pairs.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} key The key to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction assocIndexOf(array, key) {\n var length = array.length;\n while (length--) {\n if (eq(array[length][0], key)) {\n return length;\n }\n }\n return -1;\n}\n\nmodule.exports = assocIndexOf;\n","/**\n * Performs a\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * comparison between two values to determine if they are equivalent.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.eq(object, object);\n * // => true\n *\n * _.eq(object, other);\n * // => false\n *\n * _.eq('a', 'a');\n * // => true\n *\n * _.eq('a', Object('a'));\n * // => false\n *\n * _.eq(NaN, NaN);\n * // => true\n */\nfunction eq(value, other) {\n return value === other || (value !== value && other !== other);\n}\n\nmodule.exports = eq;\n","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Gets the list cache value for `key`.\n *\n * @private\n * @name get\n * @memberOf ListCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction listCacheGet(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n return index < 0 ? undefined : data[index][1];\n}\n\nmodule.exports = listCacheGet;\n","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Checks if a list cache value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf ListCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction listCacheHas(key) {\n return assocIndexOf(this.__data__, key) > -1;\n}\n\nmodule.exports = listCacheHas;\n","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Sets the list cache `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf ListCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the list cache instance.\n */\nfunction listCacheSet(key, value) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n ++this.size;\n data.push([key, value]);\n } else {\n data[index][1] = value;\n }\n return this;\n}\n\nmodule.exports = listCacheSet;\n","var ListCache = require('./_ListCache');\n\n/**\n * Removes all key-value entries from the stack.\n *\n * @private\n * @name clear\n * @memberOf Stack\n */\nfunction stackClear() {\n this.__data__ = new ListCache;\n this.size = 0;\n}\n\nmodule.exports = stackClear;\n","/**\n * Removes `key` and its value from the stack.\n *\n * @private\n * @name delete\n * @memberOf Stack\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction stackDelete(key) {\n var data = this.__data__,\n result = data['delete'](key);\n\n this.size = data.size;\n return result;\n}\n\nmodule.exports = stackDelete;\n","/**\n * Gets the stack value for `key`.\n *\n * @private\n * @name get\n * @memberOf Stack\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction stackGet(key) {\n return this.__data__.get(key);\n}\n\nmodule.exports = stackGet;\n","/**\n * Checks if a stack value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Stack\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction stackHas(key) {\n return this.__data__.has(key);\n}\n\nmodule.exports = stackHas;\n","var ListCache = require('./_ListCache'),\n Map = require('./_Map'),\n MapCache = require('./_MapCache');\n\n/** Used as the size to enable large array optimizations. */\nvar LARGE_ARRAY_SIZE = 200;\n\n/**\n * Sets the stack `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Stack\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the stack cache instance.\n */\nfunction stackSet(key, value) {\n var data = this.__data__;\n if (data instanceof ListCache) {\n var pairs = data.__data__;\n if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) {\n pairs.push([key, value]);\n this.size = ++data.size;\n return this;\n }\n data = this.__data__ = new MapCache(pairs);\n }\n data.set(key, value);\n this.size = data.size;\n return this;\n}\n\nmodule.exports = stackSet;\n","var mapCacheClear = require('./_mapCacheClear'),\n mapCacheDelete = require('./_mapCacheDelete'),\n mapCacheGet = require('./_mapCacheGet'),\n mapCacheHas = require('./_mapCacheHas'),\n mapCacheSet = require('./_mapCacheSet');\n\n/**\n * Creates a map cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction MapCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n// Add methods to `MapCache`.\nMapCache.prototype.clear = mapCacheClear;\nMapCache.prototype['delete'] = mapCacheDelete;\nMapCache.prototype.get = mapCacheGet;\nMapCache.prototype.has = mapCacheHas;\nMapCache.prototype.set = mapCacheSet;\n\nmodule.exports = MapCache;\n","var Hash = require('./_Hash'),\n ListCache = require('./_ListCache'),\n Map = require('./_Map');\n\n/**\n * Removes all key-value entries from the map.\n *\n * @private\n * @name clear\n * @memberOf MapCache\n */\nfunction mapCacheClear() {\n this.size = 0;\n this.__data__ = {\n 'hash': new Hash,\n 'map': new (Map || ListCache),\n 'string': new Hash\n };\n}\n\nmodule.exports = mapCacheClear;\n","var hashClear = require('./_hashClear'),\n hashDelete = require('./_hashDelete'),\n hashGet = require('./_hashGet'),\n hashHas = require('./_hashHas'),\n hashSet = require('./_hashSet');\n\n/**\n * Creates a hash object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Hash(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n// Add methods to `Hash`.\nHash.prototype.clear = hashClear;\nHash.prototype['delete'] = hashDelete;\nHash.prototype.get = hashGet;\nHash.prototype.has = hashHas;\nHash.prototype.set = hashSet;\n\nmodule.exports = Hash;\n","var nativeCreate = require('./_nativeCreate');\n\n/**\n * Removes all key-value entries from the hash.\n *\n * @private\n * @name clear\n * @memberOf Hash\n */\nfunction hashClear() {\n this.__data__ = nativeCreate ? nativeCreate(null) : {};\n this.size = 0;\n}\n\nmodule.exports = hashClear;\n","var getNative = require('./_getNative');\n\n/* Built-in method references that are verified to be native. */\nvar nativeCreate = getNative(Object, 'create');\n\nmodule.exports = nativeCreate;\n","/**\n * Removes `key` and its value from the hash.\n *\n * @private\n * @name delete\n * @memberOf Hash\n * @param {Object} hash The hash to modify.\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction hashDelete(key) {\n var result = this.has(key) && delete this.__data__[key];\n this.size -= result ? 1 : 0;\n return result;\n}\n\nmodule.exports = hashDelete;\n","var nativeCreate = require('./_nativeCreate');\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Gets the hash value for `key`.\n *\n * @private\n * @name get\n * @memberOf Hash\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction hashGet(key) {\n var data = this.__data__;\n if (nativeCreate) {\n var result = data[key];\n return result === HASH_UNDEFINED ? undefined : result;\n }\n return hasOwnProperty.call(data, key) ? data[key] : undefined;\n}\n\nmodule.exports = hashGet;\n","var nativeCreate = require('./_nativeCreate');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Checks if a hash value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Hash\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction hashHas(key) {\n var data = this.__data__;\n return nativeCreate ? (data[key] !== undefined) : hasOwnProperty.call(data, key);\n}\n\nmodule.exports = hashHas;\n","var nativeCreate = require('./_nativeCreate');\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/**\n * Sets the hash `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Hash\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the hash instance.\n */\nfunction hashSet(key, value) {\n var data = this.__data__;\n this.size += this.has(key) ? 0 : 1;\n data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;\n return this;\n}\n\nmodule.exports = hashSet;\n","var getMapData = require('./_getMapData');\n\n/**\n * Removes `key` and its value from the map.\n *\n * @private\n * @name delete\n * @memberOf MapCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction mapCacheDelete(key) {\n var result = getMapData(this, key)['delete'](key);\n this.size -= result ? 1 : 0;\n return result;\n}\n\nmodule.exports = mapCacheDelete;\n","var isKeyable = require('./_isKeyable');\n\n/**\n * Gets the data for `map`.\n *\n * @private\n * @param {Object} map The map to query.\n * @param {string} key The reference key.\n * @returns {*} Returns the map data.\n */\nfunction getMapData(map, key) {\n var data = map.__data__;\n return isKeyable(key)\n ? data[typeof key == 'string' ? 'string' : 'hash']\n : data.map;\n}\n\nmodule.exports = getMapData;\n","/**\n * Checks if `value` is suitable for use as unique object key.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is suitable, else `false`.\n */\nfunction isKeyable(value) {\n var type = typeof value;\n return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean')\n ? (value !== '__proto__')\n : (value === null);\n}\n\nmodule.exports = isKeyable;\n","var getMapData = require('./_getMapData');\n\n/**\n * Gets the map value for `key`.\n *\n * @private\n * @name get\n * @memberOf MapCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction mapCacheGet(key) {\n return getMapData(this, key).get(key);\n}\n\nmodule.exports = mapCacheGet;\n","var getMapData = require('./_getMapData');\n\n/**\n * Checks if a map value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf MapCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction mapCacheHas(key) {\n return getMapData(this, key).has(key);\n}\n\nmodule.exports = mapCacheHas;\n","var getMapData = require('./_getMapData');\n\n/**\n * Sets the map `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf MapCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the map cache instance.\n */\nfunction mapCacheSet(key, value) {\n var data = getMapData(this, key),\n size = data.size;\n\n data.set(key, value);\n this.size += data.size == size ? 0 : 1;\n return this;\n}\n\nmodule.exports = mapCacheSet;\n","var baseIsTypedArray = require('./_baseIsTypedArray'),\n baseUnary = require('./_baseUnary'),\n nodeUtil = require('./_nodeUtil');\n\n/* Node.js helper references. */\nvar nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\n\n/**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\nvar isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;\n\nmodule.exports = isTypedArray;\n","var freeGlobal = require('./_freeGlobal');\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Detect free variable `process` from Node.js. */\nvar freeProcess = moduleExports && freeGlobal.process;\n\n/** Used to access faster Node.js helpers. */\nvar nodeUtil = (function() {\n try {\n // Use `util.types` for Node.js 10+.\n var types = freeModule && freeModule.require && freeModule.require('util').types;\n\n if (types) {\n return types;\n }\n\n // Legacy `process.binding('util')` for Node.js < 10.\n return freeProcess && freeProcess.binding && freeProcess.binding('util');\n } catch (e) {}\n}());\n\nmodule.exports = nodeUtil;\n","/**\n * The base implementation of `_.unary` without support for storing metadata.\n *\n * @private\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n */\nfunction baseUnary(func) {\n return function(value) {\n return func(value);\n };\n}\n\nmodule.exports = baseUnary;\n","var baseGetTag = require('./_baseGetTag'),\n isLength = require('./isLength'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n errorTag = '[object Error]',\n funcTag = '[object Function]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n objectTag = '[object Object]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n/** Used to identify `toStringTag` values of typed arrays. */\nvar typedArrayTags = {};\ntypedArrayTags[float32Tag] = typedArrayTags[float64Tag] =\ntypedArrayTags[int8Tag] = typedArrayTags[int16Tag] =\ntypedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =\ntypedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =\ntypedArrayTags[uint32Tag] = true;\ntypedArrayTags[argsTag] = typedArrayTags[arrayTag] =\ntypedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =\ntypedArrayTags[dataViewTag] = typedArrayTags[dateTag] =\ntypedArrayTags[errorTag] = typedArrayTags[funcTag] =\ntypedArrayTags[mapTag] = typedArrayTags[numberTag] =\ntypedArrayTags[objectTag] = typedArrayTags[regexpTag] =\ntypedArrayTags[setTag] = typedArrayTags[stringTag] =\ntypedArrayTags[weakMapTag] = false;\n\n/**\n * The base implementation of `_.isTypedArray` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n */\nfunction baseIsTypedArray(value) {\n return isObjectLike(value) &&\n isLength(value.length) && !!typedArrayTags[baseGetTag(value)];\n}\n\nmodule.exports = baseIsTypedArray;\n","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This method is loosely based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n * @example\n *\n * _.isLength(3);\n * // => true\n *\n * _.isLength(Number.MIN_VALUE);\n * // => false\n *\n * _.isLength(Infinity);\n * // => false\n *\n * _.isLength('3');\n * // => false\n */\nfunction isLength(value) {\n return typeof value == 'number' &&\n value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n}\n\nmodule.exports = isLength;\n","var SetCache = require('./_SetCache'),\n arraySome = require('./_arraySome'),\n cacheHas = require('./_cacheHas');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n/**\n * A specialized version of `baseIsEqualDeep` for arrays with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Array} array The array to compare.\n * @param {Array} other The other array to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `array` and `other` objects.\n * @returns {boolean} Returns `true` if the arrays are equivalent, else `false`.\n */\nfunction equalArrays(array, other, bitmask, customizer, equalFunc, stack) {\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n arrLength = array.length,\n othLength = other.length;\n\n if (arrLength != othLength && !(isPartial && othLength > arrLength)) {\n return false;\n }\n // Check that cyclic values are equal.\n var arrStacked = stack.get(array);\n var othStacked = stack.get(other);\n if (arrStacked && othStacked) {\n return arrStacked == other && othStacked == array;\n }\n var index = -1,\n result = true,\n seen = (bitmask & COMPARE_UNORDERED_FLAG) ? new SetCache : undefined;\n\n stack.set(array, other);\n stack.set(other, array);\n\n // Ignore non-index properties.\n while (++index < arrLength) {\n var arrValue = array[index],\n othValue = other[index];\n\n if (customizer) {\n var compared = isPartial\n ? customizer(othValue, arrValue, index, other, array, stack)\n : customizer(arrValue, othValue, index, array, other, stack);\n }\n if (compared !== undefined) {\n if (compared) {\n continue;\n }\n result = false;\n break;\n }\n // Recursively compare arrays (susceptible to call stack limits).\n if (seen) {\n if (!arraySome(other, function(othValue, othIndex) {\n if (!cacheHas(seen, othIndex) &&\n (arrValue === othValue || equalFunc(arrValue, othValue, bitmask, customizer, stack))) {\n return seen.push(othIndex);\n }\n })) {\n result = false;\n break;\n }\n } else if (!(\n arrValue === othValue ||\n equalFunc(arrValue, othValue, bitmask, customizer, stack)\n )) {\n result = false;\n break;\n }\n }\n stack['delete'](array);\n stack['delete'](other);\n return result;\n}\n\nmodule.exports = equalArrays;\n","var MapCache = require('./_MapCache'),\n setCacheAdd = require('./_setCacheAdd'),\n setCacheHas = require('./_setCacheHas');\n\n/**\n *\n * Creates an array cache object to store unique values.\n *\n * @private\n * @constructor\n * @param {Array} [values] The values to cache.\n */\nfunction SetCache(values) {\n var index = -1,\n length = values == null ? 0 : values.length;\n\n this.__data__ = new MapCache;\n while (++index < length) {\n this.add(values[index]);\n }\n}\n\n// Add methods to `SetCache`.\nSetCache.prototype.add = SetCache.prototype.push = setCacheAdd;\nSetCache.prototype.has = setCacheHas;\n\nmodule.exports = SetCache;\n","/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/**\n * Adds `value` to the array cache.\n *\n * @private\n * @name add\n * @memberOf SetCache\n * @alias push\n * @param {*} value The value to cache.\n * @returns {Object} Returns the cache instance.\n */\nfunction setCacheAdd(value) {\n this.__data__.set(value, HASH_UNDEFINED);\n return this;\n}\n\nmodule.exports = setCacheAdd;\n","/**\n * Checks if `value` is in the array cache.\n *\n * @private\n * @name has\n * @memberOf SetCache\n * @param {*} value The value to search for.\n * @returns {number} Returns `true` if `value` is found, else `false`.\n */\nfunction setCacheHas(value) {\n return this.__data__.has(value);\n}\n\nmodule.exports = setCacheHas;\n","/**\n * A specialized version of `_.some` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if any element passes the predicate check,\n * else `false`.\n */\nfunction arraySome(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (predicate(array[index], index, array)) {\n return true;\n }\n }\n return false;\n}\n\nmodule.exports = arraySome;\n","/**\n * Checks if a `cache` value for `key` exists.\n *\n * @private\n * @param {Object} cache The cache to query.\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction cacheHas(cache, key) {\n return cache.has(key);\n}\n\nmodule.exports = cacheHas;\n","var Symbol = require('./_Symbol'),\n Uint8Array = require('./_Uint8Array'),\n eq = require('./eq'),\n equalArrays = require('./_equalArrays'),\n mapToArray = require('./_mapToArray'),\n setToArray = require('./_setToArray');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n/** `Object#toString` result references. */\nvar boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n errorTag = '[object Error]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n symbolTag = '[object Symbol]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]';\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;\n\n/**\n * A specialized version of `baseIsEqualDeep` for comparing objects of\n * the same `toStringTag`.\n *\n * **Note:** This function only supports comparing values with tags of\n * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {string} tag The `toStringTag` of the objects to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction equalByTag(object, other, tag, bitmask, customizer, equalFunc, stack) {\n switch (tag) {\n case dataViewTag:\n if ((object.byteLength != other.byteLength) ||\n (object.byteOffset != other.byteOffset)) {\n return false;\n }\n object = object.buffer;\n other = other.buffer;\n\n case arrayBufferTag:\n if ((object.byteLength != other.byteLength) ||\n !equalFunc(new Uint8Array(object), new Uint8Array(other))) {\n return false;\n }\n return true;\n\n case boolTag:\n case dateTag:\n case numberTag:\n // Coerce booleans to `1` or `0` and dates to milliseconds.\n // Invalid dates are coerced to `NaN`.\n return eq(+object, +other);\n\n case errorTag:\n return object.name == other.name && object.message == other.message;\n\n case regexpTag:\n case stringTag:\n // Coerce regexes to strings and treat strings, primitives and objects,\n // as equal. See http://www.ecma-international.org/ecma-262/7.0/#sec-regexp.prototype.tostring\n // for more details.\n return object == (other + '');\n\n case mapTag:\n var convert = mapToArray;\n\n case setTag:\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG;\n convert || (convert = setToArray);\n\n if (object.size != other.size && !isPartial) {\n return false;\n }\n // Assume cyclic values are equal.\n var stacked = stack.get(object);\n if (stacked) {\n return stacked == other;\n }\n bitmask |= COMPARE_UNORDERED_FLAG;\n\n // Recursively compare objects (susceptible to call stack limits).\n stack.set(object, other);\n var result = equalArrays(convert(object), convert(other), bitmask, customizer, equalFunc, stack);\n stack['delete'](object);\n return result;\n\n case symbolTag:\n if (symbolValueOf) {\n return symbolValueOf.call(object) == symbolValueOf.call(other);\n }\n }\n return false;\n}\n\nmodule.exports = equalByTag;\n","var root = require('./_root');\n\n/** Built-in value references. */\nvar Uint8Array = root.Uint8Array;\n\nmodule.exports = Uint8Array;\n","/**\n * Converts `map` to its key-value pairs.\n *\n * @private\n * @param {Object} map The map to convert.\n * @returns {Array} Returns the key-value pairs.\n */\nfunction mapToArray(map) {\n var index = -1,\n result = Array(map.size);\n\n map.forEach(function(value, key) {\n result[++index] = [key, value];\n });\n return result;\n}\n\nmodule.exports = mapToArray;\n","/**\n * Converts `set` to an array of its values.\n *\n * @private\n * @param {Object} set The set to convert.\n * @returns {Array} Returns the values.\n */\nfunction setToArray(set) {\n var index = -1,\n result = Array(set.size);\n\n set.forEach(function(value) {\n result[++index] = value;\n });\n return result;\n}\n\nmodule.exports = setToArray;\n","var getAllKeys = require('./_getAllKeys');\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1;\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * A specialized version of `baseIsEqualDeep` for objects with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction equalObjects(object, other, bitmask, customizer, equalFunc, stack) {\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n objProps = getAllKeys(object),\n objLength = objProps.length,\n othProps = getAllKeys(other),\n othLength = othProps.length;\n\n if (objLength != othLength && !isPartial) {\n return false;\n }\n var index = objLength;\n while (index--) {\n var key = objProps[index];\n if (!(isPartial ? key in other : hasOwnProperty.call(other, key))) {\n return false;\n }\n }\n // Check that cyclic values are equal.\n var objStacked = stack.get(object);\n var othStacked = stack.get(other);\n if (objStacked && othStacked) {\n return objStacked == other && othStacked == object;\n }\n var result = true;\n stack.set(object, other);\n stack.set(other, object);\n\n var skipCtor = isPartial;\n while (++index < objLength) {\n key = objProps[index];\n var objValue = object[key],\n othValue = other[key];\n\n if (customizer) {\n var compared = isPartial\n ? customizer(othValue, objValue, key, other, object, stack)\n : customizer(objValue, othValue, key, object, other, stack);\n }\n // Recursively compare objects (susceptible to call stack limits).\n if (!(compared === undefined\n ? (objValue === othValue || equalFunc(objValue, othValue, bitmask, customizer, stack))\n : compared\n )) {\n result = false;\n break;\n }\n skipCtor || (skipCtor = key == 'constructor');\n }\n if (result && !skipCtor) {\n var objCtor = object.constructor,\n othCtor = other.constructor;\n\n // Non `Object` object instances with different constructors are not equal.\n if (objCtor != othCtor &&\n ('constructor' in object && 'constructor' in other) &&\n !(typeof objCtor == 'function' && objCtor instanceof objCtor &&\n typeof othCtor == 'function' && othCtor instanceof othCtor)) {\n result = false;\n }\n }\n stack['delete'](object);\n stack['delete'](other);\n return result;\n}\n\nmodule.exports = equalObjects;\n","var baseGetAllKeys = require('./_baseGetAllKeys'),\n getSymbols = require('./_getSymbols'),\n keys = require('./keys');\n\n/**\n * Creates an array of own enumerable property names and symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction getAllKeys(object) {\n return baseGetAllKeys(object, keys, getSymbols);\n}\n\nmodule.exports = getAllKeys;\n","var arrayPush = require('./_arrayPush'),\n isArray = require('./isArray');\n\n/**\n * The base implementation of `getAllKeys` and `getAllKeysIn` which uses\n * `keysFunc` and `symbolsFunc` to get the enumerable property names and\n * symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @param {Function} symbolsFunc The function to get the symbols of `object`.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction baseGetAllKeys(object, keysFunc, symbolsFunc) {\n var result = keysFunc(object);\n return isArray(object) ? result : arrayPush(result, symbolsFunc(object));\n}\n\nmodule.exports = baseGetAllKeys;\n","/**\n * Appends the elements of `values` to `array`.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {Array} values The values to append.\n * @returns {Array} Returns `array`.\n */\nfunction arrayPush(array, values) {\n var index = -1,\n length = values.length,\n offset = array.length;\n\n while (++index < length) {\n array[offset + index] = values[index];\n }\n return array;\n}\n\nmodule.exports = arrayPush;\n","var arrayLikeKeys = require('./_arrayLikeKeys'),\n baseKeys = require('./_baseKeys'),\n isArrayLike = require('./isArrayLike');\n\n/**\n * Creates an array of the own enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects. See the\n * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * for more details.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keys(new Foo);\n * // => ['a', 'b'] (iteration order is not guaranteed)\n *\n * _.keys('hi');\n * // => ['0', '1']\n */\nfunction keys(object) {\n return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);\n}\n\nmodule.exports = keys;\n","var isFunction = require('./isFunction'),\n isLength = require('./isLength');\n\n/**\n * Checks if `value` is array-like. A value is considered array-like if it's\n * not a function and has a `value.length` that's an integer greater than or\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n * @example\n *\n * _.isArrayLike([1, 2, 3]);\n * // => true\n *\n * _.isArrayLike(document.body.children);\n * // => true\n *\n * _.isArrayLike('abc');\n * // => true\n *\n * _.isArrayLike(_.noop);\n * // => false\n */\nfunction isArrayLike(value) {\n return value != null && isLength(value.length) && !isFunction(value);\n}\n\nmodule.exports = isArrayLike;\n","var baseTimes = require('./_baseTimes'),\n isArguments = require('./isArguments'),\n isArray = require('./isArray'),\n isBuffer = require('./isBuffer'),\n isIndex = require('./_isIndex'),\n isTypedArray = require('./isTypedArray');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Creates an array of the enumerable property names of the array-like `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @param {boolean} inherited Specify returning inherited property names.\n * @returns {Array} Returns the array of property names.\n */\nfunction arrayLikeKeys(value, inherited) {\n var isArr = isArray(value),\n isArg = !isArr && isArguments(value),\n isBuff = !isArr && !isArg && isBuffer(value),\n isType = !isArr && !isArg && !isBuff && isTypedArray(value),\n skipIndexes = isArr || isArg || isBuff || isType,\n result = skipIndexes ? baseTimes(value.length, String) : [],\n length = result.length;\n\n for (var key in value) {\n if ((inherited || hasOwnProperty.call(value, key)) &&\n !(skipIndexes && (\n // Safari 9 has enumerable `arguments.length` in strict mode.\n key == 'length' ||\n // Node.js 0.10 has enumerable non-index properties on buffers.\n (isBuff && (key == 'offset' || key == 'parent')) ||\n // PhantomJS 2 has enumerable non-index properties on typed arrays.\n (isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset')) ||\n // Skip index properties.\n isIndex(key, length)\n ))) {\n result.push(key);\n }\n }\n return result;\n}\n\nmodule.exports = arrayLikeKeys;\n","var baseIsArguments = require('./_baseIsArguments'),\n isObjectLike = require('./isObjectLike');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Built-in value references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable;\n\n/**\n * Checks if `value` is likely an `arguments` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n * else `false`.\n * @example\n *\n * _.isArguments(function() { return arguments; }());\n * // => true\n *\n * _.isArguments([1, 2, 3]);\n * // => false\n */\nvar isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) {\n return isObjectLike(value) && hasOwnProperty.call(value, 'callee') &&\n !propertyIsEnumerable.call(value, 'callee');\n};\n\nmodule.exports = isArguments;\n","var baseGetTag = require('./_baseGetTag'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]';\n\n/**\n * The base implementation of `_.isArguments`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n */\nfunction baseIsArguments(value) {\n return isObjectLike(value) && baseGetTag(value) == argsTag;\n}\n\nmodule.exports = baseIsArguments;\n","/**\n * The base implementation of `_.times` without support for iteratee shorthands\n * or max array length checks.\n *\n * @private\n * @param {number} n The number of times to invoke `iteratee`.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the array of results.\n */\nfunction baseTimes(n, iteratee) {\n var index = -1,\n result = Array(n);\n\n while (++index < n) {\n result[index] = iteratee(index);\n }\n return result;\n}\n\nmodule.exports = baseTimes;\n","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n/**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\nfunction isIndex(value, length) {\n var type = typeof value;\n length = length == null ? MAX_SAFE_INTEGER : length;\n\n return !!length &&\n (type == 'number' ||\n (type != 'symbol' && reIsUint.test(value))) &&\n (value > -1 && value % 1 == 0 && value < length);\n}\n\nmodule.exports = isIndex;\n","var isPrototype = require('./_isPrototype'),\n nativeKeys = require('./_nativeKeys');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * The base implementation of `_.keys` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction baseKeys(object) {\n if (!isPrototype(object)) {\n return nativeKeys(object);\n }\n var result = [];\n for (var key in Object(object)) {\n if (hasOwnProperty.call(object, key) && key != 'constructor') {\n result.push(key);\n }\n }\n return result;\n}\n\nmodule.exports = baseKeys;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Checks if `value` is likely a prototype object.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\n */\nfunction isPrototype(value) {\n var Ctor = value && value.constructor,\n proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\n\n return value === proto;\n}\n\nmodule.exports = isPrototype;\n","var overArg = require('./_overArg');\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeKeys = overArg(Object.keys, Object);\n\nmodule.exports = nativeKeys;\n","/**\n * Creates a unary function that invokes `func` with its argument transformed.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {Function} transform The argument transform.\n * @returns {Function} Returns the new function.\n */\nfunction overArg(func, transform) {\n return function(arg) {\n return func(transform(arg));\n };\n}\n\nmodule.exports = overArg;\n","var arrayFilter = require('./_arrayFilter'),\n stubArray = require('./stubArray');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Built-in value references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeGetSymbols = Object.getOwnPropertySymbols;\n\n/**\n * Creates an array of the own enumerable symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\nvar getSymbols = !nativeGetSymbols ? stubArray : function(object) {\n if (object == null) {\n return [];\n }\n object = Object(object);\n return arrayFilter(nativeGetSymbols(object), function(symbol) {\n return propertyIsEnumerable.call(object, symbol);\n });\n};\n\nmodule.exports = getSymbols;\n","/**\n * This method returns a new empty array.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {Array} Returns the new empty array.\n * @example\n *\n * var arrays = _.times(2, _.stubArray);\n *\n * console.log(arrays);\n * // => [[], []]\n *\n * console.log(arrays[0] === arrays[1]);\n * // => false\n */\nfunction stubArray() {\n return [];\n}\n\nmodule.exports = stubArray;\n","/**\n * A specialized version of `_.filter` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n */\nfunction arrayFilter(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length,\n resIndex = 0,\n result = [];\n\n while (++index < length) {\n var value = array[index];\n if (predicate(value, index, array)) {\n result[resIndex++] = value;\n }\n }\n return result;\n}\n\nmodule.exports = arrayFilter;\n","import { NativeModules } from 'react-native';\nimport { ActionType } from './ActionType';\nimport { tagMessage } from './utils';\nconst { RNGestureHandlerModule } = NativeModules;\n\nif (RNGestureHandlerModule == null) {\n console.error(\n tagMessage(\n `react-native-gesture-handler module was not found. Make sure you're running your app on the native platform and your code is linked properly (cd ios && pod install && cd ..).\n\n For installation instructions, please refer to https://docs.swmansion.com/react-native-gesture-handler/docs/#installation`\n .split('\\n')\n .map((line) => line.trim())\n .join('\\n')\n )\n );\n}\n\nif (\n RNGestureHandlerModule &&\n RNGestureHandlerModule.flushOperations === undefined\n) {\n RNGestureHandlerModule.flushOperations = () => {\n // NO-OP if not defined\n };\n}\n\nexport type RNGestureHandlerModuleProps = {\n handleSetJSResponder: (tag: number, blockNativeResponder: boolean) => void;\n handleClearJSResponder: () => void;\n createGestureHandler: (\n handlerName: string,\n handlerTag: number,\n config: Readonly>\n ) => void;\n attachGestureHandler: (\n handlerTag: number,\n newView: number,\n actionType: ActionType\n ) => void;\n updateGestureHandler: (\n handlerTag: number,\n newConfig: Readonly>\n ) => void;\n dropGestureHandler: (handlerTag: number) => void;\n install: () => void;\n flushOperations: () => void;\n};\n\nexport default RNGestureHandlerModule as RNGestureHandlerModuleProps;\n","import pack from 'react-native/package.json';\n\nconst [majorStr, minorStr] = pack.version.split('.');\nexport const REACT_NATIVE_VERSION = {\n major: parseInt(majorStr, 10),\n minor: parseInt(minorStr, 10),\n};\n\nexport function toArray(object: T | T[]): T[] {\n if (!Array.isArray(object)) {\n return [object];\n }\n\n return object;\n}\n\nexport type withPrevAndCurrentMapFn = (\n previous: Transformed | null,\n current: T\n) => Transformed;\nexport function withPrevAndCurrent(\n array: T[],\n mapFn: withPrevAndCurrentMapFn\n): Transformed[] {\n const previousArr: (null | Transformed)[] = [null];\n const currentArr = [...array];\n const transformedArr: Transformed[] = [];\n currentArr.forEach((current, i) => {\n const previous = previousArr[i];\n const transformed = mapFn(previous, current);\n previousArr.push(transformed);\n transformedArr.push(transformed);\n });\n return transformedArr;\n}\n\n// eslint-disable-next-line @typescript-eslint/ban-types\nexport function hasProperty(object: object, key: string) {\n return Object.prototype.hasOwnProperty.call(object, key);\n}\n\nexport function isJestEnv(): boolean {\n // @ts-ignore Do not use `@types/node` because it will prioritise Node types over RN types which breaks the types (ex. setTimeout) in React Native projects.\n return hasProperty(global, 'process') && !!process.env.JEST_WORKER_ID;\n}\n\nexport function tagMessage(msg: string) {\n return `[react-native-gesture-handler] ${msg}`;\n}\n\n// helper method to check whether Fabric is enabled, however global.nativeFabricUIManager\n// may not be initialized before the first render\nexport function isFabric(): boolean {\n // @ts-expect-error nativeFabricUIManager is not yet included in the RN types\n return !!global?.nativeFabricUIManager;\n}\n\nexport function shouldUseCodegenNativeComponent(): boolean {\n // use codegenNativeComponent starting with RN 0.68\n return REACT_NATIVE_VERSION.minor >= 68 || REACT_NATIVE_VERSION.major > 0;\n}\n\nexport function isRemoteDebuggingEnabled(): boolean {\n // react-native-reanimated checks if in remote debugging in the same way\n // @ts-ignore global is available but node types are not included\n return !(global as any).nativeCallSyncHook || (global as any).__REMOTEDEV__;\n}\n","{\n \"name\": \"@expensify/react-native\",\n \"version\": \"0.71.2-alpha.3\",\n \"bin\": \"./cli.js\",\n \"description\": \"A framework for building native apps using React\",\n \"license\": \"MIT\",\n \"repository\": \"github:facebook/react-native\",\n \"engines\": {\n \"node\": \">=14\"\n },\n \"types\": \"types\",\n \"jest-junit\": {\n \"outputDirectory\": \"reports/junit\",\n \"outputName\": \"js-test-results.xml\"\n },\n \"files\": [\n \"android\",\n \"cli.js\",\n \"flow\",\n \"flow-typed\",\n \"index.js\",\n \"interface.js\",\n \"jest-preset.js\",\n \"jest\",\n \"!jest/private\",\n \"Libraries\",\n \"LICENSE\",\n \"local-cli\",\n \"React-Core.podspec\",\n \"react-native.config.js\",\n \"react.gradle\",\n \"React.podspec\",\n \"React\",\n \"ReactAndroid\",\n \"ReactCommon\",\n \"README.md\",\n \"rn-get-polyfills.js\",\n \"scripts/compose-source-maps.js\",\n \"scripts/find-node-for-xcode.sh\",\n \"scripts/generate-codegen-artifacts.js\",\n \"scripts/generate-provider-cli.js\",\n \"scripts/generate-specs-cli.js\",\n \"scripts/codegen/codegen-utils.js\",\n \"scripts/codegen/generate-artifacts-executor.js\",\n \"scripts/codegen/generate-specs-cli-executor.js\",\n \"scripts/hermes/hermes-utils.js\",\n \"scripts/hermes/prepare-hermes-for-build.js\",\n \"scripts/ios-configure-glog.sh\",\n \"scripts/xcode/with-environment.sh\",\n \"scripts/launchPackager.bat\",\n \"scripts/launchPackager.command\",\n \"scripts/native_modules.rb\",\n \"scripts/node-binary.sh\",\n \"scripts/packager.sh\",\n \"scripts/packager-reporter.js\",\n \"scripts/react_native_pods_utils/script_phases.rb\",\n \"scripts/react_native_pods_utils/script_phases.sh\",\n \"scripts/react_native_pods.rb\",\n \"scripts/cocoapods\",\n \"scripts/react-native-xcode.sh\",\n \"sdks/.hermesversion\",\n \"sdks/hermes-engine\",\n \"sdks/hermesc\",\n \"template.config.js\",\n \"template\",\n \"!template/node_modules\",\n \"!template/package-lock.json\",\n \"!template/yarn.lock\",\n \"third-party-podspecs\",\n \"types\"\n ],\n \"scripts\": {\n \"start\": \"react-native start\",\n \"test\": \"jest\",\n \"test-ci\": \"jest --maxWorkers=2 --ci --reporters=\\\"default\\\" --reporters=\\\"jest-junit\\\"\",\n \"flow\": \"flow\",\n \"flow-check-ios\": \"flow check\",\n \"flow-check-android\": \"flow check --flowconfig-name .flowconfig.android\",\n \"lint\": \"eslint .\",\n \"lint-ci\": \"./scripts/circleci/analyze_code.sh && yarn shellcheck\",\n \"lint-java\": \"node ./scripts/lint-java.js\",\n \"shellcheck\": \"./scripts/circleci/analyze_scripts.sh\",\n \"clang-format\": \"clang-format -i --glob=*/**/*.{h,cpp,m,mm}\",\n \"format\": \"npm run prettier && npm run clang-format\",\n \"prettier\": \"prettier --write \\\"./**/*.{js,md,yml,ts,tsx}\\\"\",\n \"format-check\": \"prettier --list-different \\\"./**/*.{js,md,yml,ts,tsx}\\\"\",\n \"update-lock\": \"npx yarn-deduplicate\",\n \"docker-setup-android\": \"docker pull reactnativecommunity/react-native-android:6.2\",\n \"docker-build-android\": \"docker build -t reactnativeci/android -f .circleci/Dockerfiles/Dockerfile.android .\",\n \"test-android-run-instrumentation\": \"docker run --cap-add=SYS_ADMIN -it reactnativeci/android bash .circleci/Dockerfiles/scripts/run-android-docker-instrumentation-tests.sh\",\n \"test-android-run-unit\": \"docker run --cap-add=SYS_ADMIN -it reactnativeci/android bash .circleci/Dockerfiles/scripts/run-android-docker-unit-tests.sh\",\n \"test-android-run-e2e\": \"docker run --privileged -it reactnativeci/android bash .circleci/Dockerfiles/scripts/run-ci-e2e-tests.sh --android --js\",\n \"test-android-all\": \"yarn run docker-build-android && yarn run test-android-run-unit && yarn run test-android-run-instrumentation && yarn run test-android-run-e2e\",\n \"test-android-instrumentation\": \"yarn run docker-build-android && yarn run test-android-run-instrumentation\",\n \"test-android-unit\": \"yarn run docker-build-android && yarn run test-android-run-unit\",\n \"test-android-e2e\": \"yarn run docker-build-android && yarn run test-android-run-e2e\",\n \"test-e2e-local\": \"node ./scripts/test-e2e-local.js\",\n \"test-e2e-local-clean\": \"node ./scripts/test-e2e-local-clean.js\",\n \"test-ios\": \"./scripts/objc-test.sh test\",\n \"test-typescript\": \"dtslint types\",\n \"test-typescript-offline\": \"dtslint --localTs node_modules/typescript/lib types\",\n \"bump-all-updated-packages\": \"node ./scripts/monorepo/bump-all-updated-packages\",\n \"align-package-versions\": \"node ./scripts/monorepo/align-package-versions.js\"\n },\n \"peerDependencies\": {\n \"react\": \"18.2.0\"\n },\n \"dependencies\": {\n \"@jest/create-cache-key-function\": \"^29.2.1\",\n \"@react-native-community/cli\": \"10.1.3\",\n \"@react-native-community/cli-platform-android\": \"10.1.3\",\n \"@react-native-community/cli-platform-ios\": \"10.1.1\",\n \"@react-native/assets\": \"1.0.0\",\n \"@react-native/normalize-color\": \"2.1.0\",\n \"@react-native/polyfills\": \"2.0.0\",\n \"abort-controller\": \"^3.0.0\",\n \"anser\": \"^1.4.9\",\n \"base64-js\": \"^1.1.2\",\n \"deprecated-react-native-prop-types\": \"^3.0.1\",\n \"event-target-shim\": \"^5.0.1\",\n \"invariant\": \"^2.2.4\",\n \"jest-environment-node\": \"^29.2.1\",\n \"jsc-android\": \"^250230.2.1\",\n \"memoize-one\": \"^5.0.0\",\n \"metro-react-native-babel-transformer\": \"0.73.7\",\n \"metro-runtime\": \"0.73.7\",\n \"metro-source-map\": \"0.73.7\",\n \"mkdirp\": \"^0.5.1\",\n \"nullthrows\": \"^1.1.1\",\n \"pretty-format\": \"^26.5.2\",\n \"promise\": \"^8.3.0\",\n \"react-devtools-core\": \"^4.26.1\",\n \"react-native-gradle-plugin\": \"^0.71.14\",\n \"react-refresh\": \"^0.4.0\",\n \"react-shallow-renderer\": \"^16.15.0\",\n \"regenerator-runtime\": \"^0.13.2\",\n \"scheduler\": \"^0.23.0\",\n \"stacktrace-parser\": \"^0.1.3\",\n \"use-sync-external-store\": \"^1.0.0\",\n \"whatwg-fetch\": \"^3.0.0\",\n \"ws\": \"^6.2.2\",\n \"react-native-codegen\": \"^0.71.3\"\n },\n \"devDependencies\": {\n \"flow-bin\": \"^0.191.0\",\n \"hermes-eslint\": \"0.8.0\",\n \"react\": \"18.2.0\",\n \"react-test-renderer\": \"18.2.0\",\n \"@babel/core\": \"^7.20.0\",\n \"@babel/eslint-parser\": \"^7.18.2\",\n \"@babel/generator\": \"^7.20.0\",\n \"@babel/plugin-transform-regenerator\": \"^7.0.0\",\n \"@babel/preset-flow\": \"^7.18.0\",\n \"@definitelytyped/dtslint\": \"^0.0.127\",\n \"@react-native-community/eslint-config\": \"*\",\n \"@react-native-community/eslint-plugin\": \"*\",\n \"@react-native/eslint-plugin-specs\": \"^0.71.1\",\n \"@reactions/component\": \"^2.0.2\",\n \"@types/react\": \"^18.0.18\",\n \"@typescript-eslint/parser\": \"^5.30.5\",\n \"async\": \"^3.2.2\",\n \"clang-format\": \"^1.8.0\",\n \"connect\": \"^3.6.5\",\n \"coveralls\": \"^3.1.1\",\n \"eslint\": \"^8.19.0\",\n \"eslint-config-prettier\": \"^8.5.0\",\n \"eslint-plugin-babel\": \"^5.3.1\",\n \"eslint-plugin-eslint-comments\": \"^3.2.0\",\n \"eslint-plugin-ft-flow\": \"^2.0.1\",\n \"eslint-plugin-jest\": \"^26.5.3\",\n \"eslint-plugin-jsx-a11y\": \"^6.6.0\",\n \"eslint-plugin-lint\": \"^1.0.0\",\n \"eslint-plugin-prettier\": \"^4.2.1\",\n \"eslint-plugin-react\": \"^7.30.1\",\n \"eslint-plugin-react-hooks\": \"^4.6.0\",\n \"eslint-plugin-react-native\": \"^4.0.0\",\n \"eslint-plugin-relay\": \"^1.8.3\",\n \"inquirer\": \"^7.1.0\",\n \"jest\": \"^29.2.1\",\n \"jest-junit\": \"^10.0.0\",\n \"jscodeshift\": \"^0.13.1\",\n \"metro-babel-register\": \"0.73.7\",\n \"metro-memory-fs\": \"0.73.7\",\n \"mkdirp\": \"^0.5.1\",\n \"mock-fs\": \"^5.1.4\",\n \"prettier\": \"^2.4.1\",\n \"shelljs\": \"^0.8.5\",\n \"signedsource\": \"^1.0.0\",\n \"typescript\": \"4.1.3\",\n \"ws\": \"^6.2.2\",\n \"yargs\": \"^17.5.1\"\n },\n \"codegenConfig\": {\n \"libraries\": [\n {\n \"name\": \"FBReactNativeSpec\",\n \"type\": \"modules\",\n \"ios\": {},\n \"android\": {},\n \"jsSrcsDir\": \"Libraries\"\n },\n {\n \"name\": \"rncore\",\n \"type\": \"components\",\n \"ios\": {},\n \"android\": {},\n \"jsSrcsDir\": \"Libraries\"\n }\n ]\n }\n}","// TODO use State from RNModule\n\nexport const State = {\n UNDETERMINED: 0,\n FAILED: 1,\n BEGAN: 2,\n CANCELLED: 3,\n ACTIVE: 4,\n END: 5,\n} as const;\n\n// eslint-disable-next-line @typescript-eslint/no-redeclare -- backward compatibility; it can be used as a type and as a value\nexport type State = typeof State[keyof typeof State];\n","export const ActionType = {\n REANIMATED_WORKLET: 1,\n NATIVE_ANIMATED_EVENT: 2,\n JS_FUNCTION_OLD_API: 3,\n JS_FUNCTION_NEW_API: 4,\n} as const;\n\n// eslint-disable-next-line @typescript-eslint/no-redeclare -- backward compatibility; it can be used as a type and as a value\nexport type ActionType = typeof ActionType[keyof typeof ActionType];\n","import { isJestEnv } from '../utils';\nimport { GestureType } from './gestures/gesture';\nimport { GestureEvent, HandlerStateChangeEvent } from './gestureHandlerCommon';\n\nexport const handlerIDToTag: Record = {};\nconst gestures = new Map();\nconst oldHandlers = new Map();\nconst testIDs = new Map();\n\nlet handlerTag = 1;\n\nexport function getNextHandlerTag(): number {\n return handlerTag++;\n}\n\nexport function registerHandler(\n handlerTag: number,\n handler: GestureType,\n testID?: string\n) {\n gestures.set(handlerTag, handler);\n if (isJestEnv() && testID) {\n testIDs.set(testID, handlerTag);\n }\n}\n\nexport function registerOldGestureHandler(\n handlerTag: number,\n handler: GestureHandlerCallbacks\n) {\n oldHandlers.set(handlerTag, handler);\n}\n\nexport function unregisterHandler(handlerTag: number, testID?: string) {\n gestures.delete(handlerTag);\n if (isJestEnv() && testID) {\n testIDs.delete(testID);\n }\n}\n\nexport function findHandler(handlerTag: number) {\n return gestures.get(handlerTag);\n}\n\nexport function findOldGestureHandler(handlerTag: number) {\n return oldHandlers.get(handlerTag);\n}\n\nexport function findHandlerByTestID(testID: string) {\n const handlerTag = testIDs.get(testID);\n if (handlerTag !== undefined) {\n return findHandler(handlerTag) ?? null;\n }\n return null;\n}\n\nexport interface GestureHandlerCallbacks {\n onGestureEvent: (event: GestureEvent) => void;\n onGestureStateChange: (event: HandlerStateChangeEvent) => void;\n}\n","// Previous types exported gesture handlers as classes which creates an interface and variable, both named the same as class.\n// Without those types, we'd introduce breaking change, forcing users to prefix every handler type specification with typeof\n// e.g. React.createRef -> React.createRef.\n// See https://www.typescriptlang.org/docs/handbook/classes.html#constructor-functions for reference.\nimport * as React from 'react';\nimport { Platform, findNodeHandle as findNodeHandleRN } from 'react-native';\n\nimport { State } from '../State';\nimport { TouchEventType } from '../TouchEventType';\nimport { ValueOf } from '../typeUtils';\nimport { handlerIDToTag } from './handlersRegistry';\nimport { toArray } from '../utils';\nimport RNGestureHandlerModule from '../RNGestureHandlerModule';\n\nconst commonProps = [\n 'id',\n 'enabled',\n 'shouldCancelWhenOutside',\n 'hitSlop',\n 'cancelsTouchesInView',\n 'userSelect',\n] as const;\n\nconst componentInteractionProps = ['waitFor', 'simultaneousHandlers'] as const;\n\nexport const baseGestureHandlerProps = [\n ...commonProps,\n ...componentInteractionProps,\n 'onBegan',\n 'onFailed',\n 'onCancelled',\n 'onActivated',\n 'onEnded',\n 'onGestureEvent',\n 'onHandlerStateChange',\n] as const;\n\nexport const baseGestureHandlerWithMonitorProps = [\n ...commonProps,\n 'needsPointerData',\n 'manualActivation',\n];\n\nexport interface GestureEventPayload {\n handlerTag: number;\n numberOfPointers: number;\n state: ValueOf;\n}\nexport interface HandlerStateChangeEventPayload extends GestureEventPayload {\n oldState: ValueOf;\n}\n\nexport type HitSlop =\n | number\n | Partial<\n Record<\n 'left' | 'right' | 'top' | 'bottom' | 'vertical' | 'horizontal',\n number\n >\n >\n | Record<'width' | 'left', number>\n | Record<'width' | 'right', number>\n | Record<'height' | 'top', number>\n | Record<'height' | 'bottom', number>;\n\nexport type UserSelect = 'none' | 'auto' | 'text';\n\n//TODO(TS) events in handlers\n\nexport interface GestureEvent> {\n nativeEvent: Readonly;\n}\nexport interface HandlerStateChangeEvent<\n ExtraEventPayloadT = Record\n> {\n nativeEvent: Readonly;\n}\n\nexport type TouchData = {\n id: number;\n x: number;\n y: number;\n absoluteX: number;\n absoluteY: number;\n};\n\nexport type GestureTouchEvent = {\n handlerTag: number;\n numberOfTouches: number;\n state: ValueOf;\n eventType: TouchEventType;\n allTouches: TouchData[];\n changedTouches: TouchData[];\n};\n\nexport type GestureUpdateEvent> =\n GestureEventPayload & GestureEventPayloadT;\n\nexport type GestureStateChangeEvent<\n GestureStateChangeEventPayloadT = Record\n> = HandlerStateChangeEventPayload & GestureStateChangeEventPayloadT;\n\nexport type CommonGestureConfig = {\n enabled?: boolean;\n shouldCancelWhenOutside?: boolean;\n hitSlop?: HitSlop;\n userSelect?: UserSelect;\n};\n\n// Events payloads are types instead of interfaces due to TS limitation.\n// See https://github.com/microsoft/TypeScript/issues/15300 for more info.\nexport type BaseGestureHandlerProps<\n ExtraEventPayloadT extends Record = Record\n> = CommonGestureConfig & {\n id?: string;\n waitFor?: React.Ref | React.Ref[];\n simultaneousHandlers?: React.Ref | React.Ref[];\n testID?: string;\n cancelsTouchesInView?: boolean;\n // TODO(TS) - fix event types\n onBegan?: (event: HandlerStateChangeEvent) => void;\n onFailed?: (event: HandlerStateChangeEvent) => void;\n onCancelled?: (event: HandlerStateChangeEvent) => void;\n onActivated?: (event: HandlerStateChangeEvent) => void;\n onEnded?: (event: HandlerStateChangeEvent) => void;\n\n //TODO(TS) consider using NativeSyntheticEvent\n onGestureEvent?: (event: GestureEvent) => void;\n onHandlerStateChange?: (\n event: HandlerStateChangeEvent\n ) => void;\n // implicit `children` prop has been removed in @types/react^18.0.0\n children?: React.ReactNode;\n};\n\nfunction isConfigParam(param: unknown, name: string) {\n // param !== Object(param) returns false if `param` is a function\n // or an object and returns true if `param` is null\n return (\n param !== undefined &&\n (param !== Object(param) ||\n !('__isNative' in (param as Record))) &&\n name !== 'onHandlerStateChange' &&\n name !== 'onGestureEvent'\n );\n}\n\nexport function filterConfig(\n props: Record,\n validProps: string[],\n defaults: Record = {}\n) {\n const filteredConfig = { ...defaults };\n for (const key of validProps) {\n let value = props[key];\n if (isConfigParam(value, key)) {\n if (key === 'simultaneousHandlers' || key === 'waitFor') {\n value = transformIntoHandlerTags(props[key]);\n } else if (key === 'hitSlop' && typeof value !== 'object') {\n value = { top: value, left: value, bottom: value, right: value };\n }\n filteredConfig[key] = value;\n }\n }\n return filteredConfig;\n}\n\nfunction transformIntoHandlerTags(handlerIDs: any) {\n handlerIDs = toArray(handlerIDs);\n\n if (Platform.OS === 'web') {\n return handlerIDs\n .map(({ current }: { current: any }) => current)\n .filter((handle: any) => handle);\n }\n // converts handler string IDs into their numeric tags\n return handlerIDs\n .map(\n (handlerID: any) =>\n handlerIDToTag[handlerID] || handlerID.current?.handlerTag || -1\n )\n .filter((handlerTag: number) => handlerTag > 0);\n}\n\nexport function findNodeHandle(\n node: null | number | React.Component | React.ComponentClass\n): null | number | React.Component | React.ComponentClass {\n if (Platform.OS === 'web') {\n return node;\n }\n return findNodeHandleRN(node);\n}\n\nlet scheduledFlushOperationsId: ReturnType<\n typeof requestAnimationFrame\n> | null = null;\n\nexport function scheduleFlushOperations() {\n if (scheduledFlushOperationsId === null) {\n scheduledFlushOperationsId = requestAnimationFrame(() => {\n RNGestureHandlerModule.flushOperations();\n\n scheduledFlushOperationsId = null;\n });\n }\n}\n","/* eslint-disable @typescript-eslint/no-var-requires */\nimport { HostComponent, requireNativeComponent } from 'react-native';\nimport { RawButtonProps } from './GestureButtons';\nimport { shouldUseCodegenNativeComponent } from '../utils';\n\nconst RNGestureHandlerButtonNativeComponent = shouldUseCodegenNativeComponent()\n ? require('../fabric/RNGestureHandlerButtonNativeComponent').default\n : requireNativeComponent('RNGestureHandlerButton');\n\nexport default RNGestureHandlerButtonNativeComponent as HostComponent;\n","import codegenNativeComponent from 'react-native/Libraries/Utilities/codegenNativeComponent';\nimport type {\n Int32,\n WithDefault,\n} from 'react-native/Libraries/Types/CodegenTypes';\nimport type { ViewProps, ColorValue } from 'react-native';\n\ninterface NativeProps extends ViewProps {\n exclusive?: WithDefault;\n foreground?: boolean;\n borderless?: boolean;\n enabled?: WithDefault;\n rippleColor?: ColorValue;\n rippleRadius?: Int32;\n touchSoundDisabled?: WithDefault;\n}\n\nexport default codegenNativeComponent('RNGestureHandlerButton');\n","export const Directions = {\n RIGHT: 1,\n LEFT: 2,\n UP: 4,\n DOWN: 8,\n} as const;\n\n// eslint-disable-next-line @typescript-eslint/no-redeclare -- backward compatibility; it can be used as a type and as a value\nexport type Directions = typeof Directions[keyof typeof Directions];\n","import * as React from 'react';\nimport {\n PropsWithChildren,\n ForwardedRef,\n RefAttributes,\n ReactElement,\n} from 'react';\nimport {\n ScrollView as RNScrollView,\n ScrollViewProps as RNScrollViewProps,\n Switch as RNSwitch,\n SwitchProps as RNSwitchProps,\n TextInput as RNTextInput,\n TextInputProps as RNTextInputProps,\n DrawerLayoutAndroid as RNDrawerLayoutAndroid,\n DrawerLayoutAndroidProps as RNDrawerLayoutAndroidProps,\n FlatList as RNFlatList,\n FlatListProps as RNFlatListProps,\n RefreshControl as RNRefreshControl,\n} from 'react-native';\n\nimport createNativeWrapper from '../handlers/createNativeWrapper';\n\nimport {\n NativeViewGestureHandlerProps,\n nativeViewProps,\n} from '../handlers/NativeViewGestureHandler';\n\nimport { toArray } from '../utils';\n\nexport const RefreshControl = createNativeWrapper(RNRefreshControl, {\n disallowInterruption: true,\n shouldCancelWhenOutside: false,\n});\n// eslint-disable-next-line @typescript-eslint/no-redeclare\nexport type RefreshControl = typeof RefreshControl & RNRefreshControl;\n\nconst GHScrollView = createNativeWrapper>(\n RNScrollView,\n {\n disallowInterruption: true,\n shouldCancelWhenOutside: false,\n }\n);\nexport const ScrollView = React.forwardRef<\n RNScrollView,\n RNScrollViewProps & NativeViewGestureHandlerProps\n>((props, ref) => {\n const refreshControlGestureRef = React.useRef(null);\n const { refreshControl, waitFor, ...rest } = props;\n\n return (\n \n );\n});\n// backward type compatibility with https://github.com/software-mansion/react-native-gesture-handler/blob/db78d3ca7d48e8ba57482d3fe9b0a15aa79d9932/react-native-gesture-handler.d.ts#L440-L457\n// include methods of wrapped components by creating an intersection type with the RN component instead of duplicating them.\n// eslint-disable-next-line @typescript-eslint/no-redeclare\nexport type ScrollView = typeof GHScrollView & RNScrollView;\n\nexport const Switch = createNativeWrapper(RNSwitch, {\n shouldCancelWhenOutside: false,\n shouldActivateOnStart: true,\n disallowInterruption: true,\n});\n// eslint-disable-next-line @typescript-eslint/no-redeclare\nexport type Switch = typeof Switch & RNSwitch;\n\nexport const TextInput = createNativeWrapper(RNTextInput);\n// eslint-disable-next-line @typescript-eslint/no-redeclare\nexport type TextInput = typeof TextInput & RNTextInput;\n\nexport const DrawerLayoutAndroid = createNativeWrapper<\n PropsWithChildren\n>(RNDrawerLayoutAndroid, { disallowInterruption: true });\n// eslint-disable-next-line @typescript-eslint/no-redeclare\nexport type DrawerLayoutAndroid = typeof DrawerLayoutAndroid &\n RNDrawerLayoutAndroid;\n\nexport const FlatList = React.forwardRef((props, ref) => {\n const refreshControlGestureRef = React.useRef(null);\n\n const { waitFor, refreshControl, ...rest } = props;\n\n const flatListProps = {};\n const scrollViewProps = {};\n for (const [propName, value] of Object.entries(rest)) {\n // https://github.com/microsoft/TypeScript/issues/26255\n if ((nativeViewProps as readonly string[]).includes(propName)) {\n // @ts-ignore - this function cannot have generic type so we have to ignore this error\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n scrollViewProps[propName] = value;\n } else {\n // @ts-ignore - this function cannot have generic type so we have to ignore this error\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n flatListProps[propName] = value;\n }\n }\n\n return (\n // @ts-ignore - this function cannot have generic type so we have to ignore this error\n (\n \n )}\n // @ts-ignore we don't pass `refreshing` prop as we only want to override the ref\n refreshControl={\n refreshControl\n ? React.cloneElement(refreshControl, {\n // @ts-ignore for reasons unknown to me, `ref` doesn't exist on the type inferred by TS\n ref: refreshControlGestureRef,\n })\n : undefined\n }\n />\n );\n}) as (\n props: PropsWithChildren<\n RNFlatListProps &\n RefAttributes> &\n NativeViewGestureHandlerProps\n >,\n ref: ForwardedRef>\n) => ReactElement | null;\n// eslint-disable-next-line @typescript-eslint/no-redeclare\nexport type FlatList = typeof FlatList & RNFlatList;\n","import createHandler from './createHandler';\nimport {\n BaseGestureHandlerProps,\n baseGestureHandlerProps,\n} from './gestureHandlerCommon';\n\nexport const flingGestureHandlerProps = [\n 'numberOfPointers',\n 'direction',\n] as const;\n\nexport type FlingGestureHandlerEventPayload = {\n x: number;\n y: number;\n absoluteX: number;\n absoluteY: number;\n};\nexport interface FlingGestureConfig {\n /**\n * Expressed allowed direction of movement. It's possible to pass one or many\n * directions in one parameter:\n *\n * ```js\n * direction={Directions.RIGHT | Directions.LEFT}\n * ```\n *\n * or\n *\n * ```js\n * direction={Directions.DOWN}\n * ```\n */\n direction?: number;\n\n /**\n * Determine exact number of points required to handle the fling gesture.\n */\n numberOfPointers?: number;\n}\n\nexport interface FlingGestureHandlerProps\n extends BaseGestureHandlerProps,\n FlingGestureConfig {}\n\nexport const flingHandlerName = 'FlingGestureHandler';\n\nexport type FlingGestureHandler = typeof FlingGestureHandler;\n// eslint-disable-next-line @typescript-eslint/no-redeclare -- backward compatibility; see description on the top of gestureHandlerCommon.ts file\nexport const FlingGestureHandler = createHandler<\n FlingGestureHandlerProps,\n FlingGestureHandlerEventPayload\n>({\n name: flingHandlerName,\n allowedProps: [\n ...baseGestureHandlerProps,\n ...flingGestureHandlerProps,\n ] as const,\n config: {},\n});\n","import React, { PropsWithChildren } from 'react';\nimport { tagMessage } from '../utils';\nimport PlatformConstants from '../PlatformConstants';\nimport createHandler from './createHandler';\nimport {\n BaseGestureHandlerProps,\n baseGestureHandlerProps,\n} from './gestureHandlerCommon';\n\nexport const forceTouchGestureHandlerProps = [\n 'minForce',\n 'maxForce',\n 'feedbackOnActivation',\n] as const;\n\n// implicit `children` prop has been removed in @types/react^18.0.0\nclass ForceTouchFallback extends React.Component> {\n static forceTouchAvailable = false;\n componentDidMount() {\n console.warn(\n tagMessage(\n 'ForceTouchGestureHandler is not available on this platform. Please use ForceTouchGestureHandler.forceTouchAvailable to conditionally render other components that would provide a fallback behavior specific to your usecase'\n )\n );\n }\n render() {\n return this.props.children;\n }\n}\n\nexport type ForceTouchGestureHandlerEventPayload = {\n x: number;\n y: number;\n absoluteX: number;\n absoluteY: number;\n\n /**\n * The pressure of a touch.\n */\n force: number;\n};\n\nexport interface ForceTouchGestureConfig {\n /**\n *\n * A minimal pressure that is required before handler can activate. Should be a\n * value from range `[0.0, 1.0]`. Default is `0.2`.\n */\n minForce?: number;\n\n /**\n * A maximal pressure that could be applied for handler. If the pressure is\n * greater, handler fails. Should be a value from range `[0.0, 1.0]`.\n */\n maxForce?: number;\n\n /**\n * Boolean value defining if haptic feedback has to be performed on\n * activation.\n */\n feedbackOnActivation?: boolean;\n}\n\nexport interface ForceTouchGestureHandlerProps\n extends BaseGestureHandlerProps,\n ForceTouchGestureConfig {}\n\nexport type ForceTouchGestureHandler = typeof ForceTouchGestureHandler & {\n forceTouchAvailable: boolean;\n};\n\nexport const forceTouchHandlerName = 'ForceTouchGestureHandler';\n\n// eslint-disable-next-line @typescript-eslint/no-redeclare -- backward compatibility; see description on the top of gestureHandlerCommon.ts file\nexport const ForceTouchGestureHandler = PlatformConstants?.forceTouchAvailable\n ? createHandler<\n ForceTouchGestureHandlerProps,\n ForceTouchGestureHandlerEventPayload\n >({\n name: forceTouchHandlerName,\n allowedProps: [\n ...baseGestureHandlerProps,\n ...forceTouchGestureHandlerProps,\n ] as const,\n config: {},\n })\n : ForceTouchFallback;\n\n(ForceTouchGestureHandler as ForceTouchGestureHandler).forceTouchAvailable =\n PlatformConstants?.forceTouchAvailable || false;\n","import { NativeModules, Platform } from 'react-native';\n\ntype PlatformConstants = {\n forceTouchAvailable: boolean;\n};\n\nexport default (NativeModules?.PlatformConstants ??\n Platform.constants) as PlatformConstants;\n","import { FlingGesture } from './flingGesture';\nimport { ForceTouchGesture } from './forceTouchGesture';\nimport { Gesture } from './gesture';\nimport {\n ComposedGesture,\n ExclusiveGesture,\n SimultaneousGesture,\n} from './gestureComposition';\nimport { LongPressGesture } from './longPressGesture';\nimport { PanGesture } from './panGesture';\nimport { PinchGesture } from './pinchGesture';\nimport { RotationGesture } from './rotationGesture';\nimport { TapGesture } from './tapGesture';\nimport { NativeGesture } from './nativeGesture';\nimport { ManualGesture } from './manualGesture';\n\nexport const GestureObjects = {\n Tap: () => {\n return new TapGesture();\n },\n\n Pan: () => {\n return new PanGesture();\n },\n\n Pinch: () => {\n return new PinchGesture();\n },\n\n Rotation: () => {\n return new RotationGesture();\n },\n\n Fling: () => {\n return new FlingGesture();\n },\n\n LongPress: () => {\n return new LongPressGesture();\n },\n\n ForceTouch: () => {\n return new ForceTouchGesture();\n },\n\n Native: () => {\n return new NativeGesture();\n },\n\n Manual: () => {\n return new ManualGesture();\n },\n\n /**\n * Builds a composed gesture consisting of gestures provided as parameters.\n * The first one that becomes active cancels the rest of gestures.\n */\n Race: (...gestures: Gesture[]) => {\n return new ComposedGesture(...gestures);\n },\n\n /**\n * Builds a composed gesture that allows all base gestures to run simultaneously.\n */\n Simultaneous(...gestures: Gesture[]) {\n return new SimultaneousGesture(...gestures);\n },\n\n /**\n * Builds a composed gesture where only one of the provided gestures can become active.\n * Priority is decided through the order of gestures: the first one has higher priority\n * than the second one, second one has higher priority than the third one, and so on.\n * For example, to make a gesture that recognizes both single and double tap you need\n * to call Exclusive(doubleTap, singleTap).\n */\n Exclusive(...gestures: Gesture[]) {\n return new ExclusiveGesture(...gestures);\n },\n};\n","import { BaseGestureConfig, BaseGesture } from './gesture';\nimport {\n TapGestureConfig,\n TapGestureHandlerEventPayload,\n} from '../TapGestureHandler';\n\nexport class TapGesture extends BaseGesture {\n public config: BaseGestureConfig & TapGestureConfig = {};\n\n constructor() {\n super();\n\n this.handlerName = 'TapGestureHandler';\n this.shouldCancelWhenOutside(true);\n }\n\n minPointers(minPointers: number) {\n this.config.minPointers = minPointers;\n return this;\n }\n\n numberOfTaps(count: number) {\n this.config.numberOfTaps = count;\n return this;\n }\n\n maxDistance(maxDist: number) {\n this.config.maxDist = maxDist;\n return this;\n }\n\n maxDuration(duration: number) {\n this.config.maxDurationMs = duration;\n return this;\n }\n\n maxDelay(delay: number) {\n this.config.maxDelayMs = delay;\n return this;\n }\n\n maxDeltaX(delta: number) {\n this.config.maxDeltaX = delta;\n return this;\n }\n\n maxDeltaY(delta: number) {\n this.config.maxDeltaY = delta;\n return this;\n }\n}\n\nexport type TapGestureType = InstanceType;\n","import { FlingGestureHandlerEventPayload } from '../FlingGestureHandler';\nimport { ForceTouchGestureHandlerEventPayload } from '../ForceTouchGestureHandler';\nimport {\n HitSlop,\n CommonGestureConfig,\n GestureTouchEvent,\n GestureStateChangeEvent,\n GestureUpdateEvent,\n} from '../gestureHandlerCommon';\nimport { getNextHandlerTag } from '../handlersRegistry';\nimport { GestureStateManagerType } from './gestureStateManager';\nimport { LongPressGestureHandlerEventPayload } from '../LongPressGestureHandler';\nimport { PanGestureHandlerEventPayload } from '../PanGestureHandler';\nimport { PinchGestureHandlerEventPayload } from '../PinchGestureHandler';\nimport { RotationGestureHandlerEventPayload } from '../RotationGestureHandler';\nimport { TapGestureHandlerEventPayload } from '../TapGestureHandler';\nimport { NativeViewGestureHandlerPayload } from '../NativeViewGestureHandler';\nimport { isRemoteDebuggingEnabled } from '../../utils';\n\nexport type GestureType =\n | BaseGesture>\n | BaseGesture>\n | BaseGesture\n | BaseGesture\n | BaseGesture\n | BaseGesture\n | BaseGesture\n | BaseGesture\n | BaseGesture\n | BaseGesture;\n\nexport type GestureRef =\n | number\n | GestureType\n | React.RefObject\n | React.RefObject; // allow adding a ref to a gesture handler\nexport interface BaseGestureConfig\n extends CommonGestureConfig,\n Record {\n ref?: React.MutableRefObject;\n requireToFail?: GestureRef[];\n simultaneousWith?: GestureRef[];\n needsPointerData?: boolean;\n manualActivation?: boolean;\n runOnJS?: boolean;\n testId?: string;\n cancelsTouchesInView?: boolean;\n}\n\ntype TouchEventHandlerType = (\n event: GestureTouchEvent,\n stateManager: GestureStateManagerType\n) => void;\n\nexport type HandlerCallbacks> = {\n gestureId: number;\n handlerTag: number;\n onBegin?: (event: GestureStateChangeEvent) => void;\n onStart?: (event: GestureStateChangeEvent) => void;\n onEnd?: (\n event: GestureStateChangeEvent,\n success: boolean\n ) => void;\n onFinalize?: (\n event: GestureStateChangeEvent,\n success: boolean\n ) => void;\n onUpdate?: (event: GestureUpdateEvent) => void;\n onChange?: (event: any) => void;\n onTouchesDown?: TouchEventHandlerType;\n onTouchesMove?: TouchEventHandlerType;\n onTouchesUp?: TouchEventHandlerType;\n onTouchesCancelled?: TouchEventHandlerType;\n changeEventCalculator?: (\n current: GestureUpdateEvent>,\n previous?: GestureUpdateEvent>\n ) => GestureUpdateEvent>;\n isWorklet: boolean[];\n};\n\nexport const CALLBACK_TYPE = {\n UNDEFINED: 0,\n BEGAN: 1,\n START: 2,\n UPDATE: 3,\n CHANGE: 4,\n END: 5,\n FINALIZE: 6,\n TOUCHES_DOWN: 7,\n TOUCHES_MOVE: 8,\n TOUCHES_UP: 9,\n TOUCHES_CANCELLED: 10,\n} as const;\n\n// Allow using CALLBACK_TYPE as object and type\n// eslint-disable-next-line @typescript-eslint/no-redeclare\nexport type CALLBACK_TYPE = typeof CALLBACK_TYPE[keyof typeof CALLBACK_TYPE];\n\nexport abstract class Gesture {\n /**\n * Return array of gestures, providing the same interface for creating and updating\n * handlers, no matter which object was used to create gesture instance.\n */\n abstract toGestureArray(): GestureType[];\n\n /**\n * Assign handlerTag to the gesture instance and set ref.current (if a ref is set)\n */\n abstract initialize(): void;\n\n /**\n * Make sure that values of properties defining relations are arrays. Do any necessary\n * preprocessing required to configure relations between handlers. Called just before\n * updating the handler on the native side.\n */\n abstract prepare(): void;\n}\n\nlet nextGestureId = 0;\nexport abstract class BaseGesture<\n EventPayloadT extends Record\n> extends Gesture {\n private gestureId = -1;\n public handlerTag = -1;\n public handlerName = '';\n public config: BaseGestureConfig = {};\n public handlers: HandlerCallbacks = {\n gestureId: -1,\n handlerTag: -1,\n isWorklet: [],\n };\n\n constructor() {\n super();\n\n // Used to check whether the gesture config has been updated when wrapping it\n // with `useMemo`. Since every config will have a unique id, when the dependencies\n // don't change, the config won't be recreated and the id will stay the same.\n // If the id is different, it means that the config has changed and the gesture\n // needs to be updated.\n this.gestureId = nextGestureId++;\n this.handlers.gestureId = this.gestureId;\n }\n\n private addDependency(\n key: 'simultaneousWith' | 'requireToFail',\n gesture: Exclude\n ) {\n const value = this.config[key];\n this.config[key] = value\n ? Array().concat(value, gesture)\n : [gesture];\n }\n\n withRef(ref: React.MutableRefObject) {\n this.config.ref = ref;\n return this;\n }\n\n // eslint-disable-next-line @typescript-eslint/ban-types\n protected isWorklet(callback: Function) {\n //@ts-ignore if callback is a worklet, the property will be available, if not then the check will return false\n return callback.__workletHash !== undefined;\n }\n\n onBegin(callback: (event: GestureStateChangeEvent) => void) {\n this.handlers.onBegin = callback;\n this.handlers.isWorklet[CALLBACK_TYPE.BEGAN] = this.isWorklet(callback);\n return this;\n }\n\n onStart(callback: (event: GestureStateChangeEvent) => void) {\n this.handlers.onStart = callback;\n this.handlers.isWorklet[CALLBACK_TYPE.START] = this.isWorklet(callback);\n return this;\n }\n\n onEnd(\n callback: (\n event: GestureStateChangeEvent,\n success: boolean\n ) => void\n ) {\n this.handlers.onEnd = callback;\n //@ts-ignore if callback is a worklet, the property will be available, if not then the check will return false\n this.handlers.isWorklet[CALLBACK_TYPE.END] = this.isWorklet(callback);\n return this;\n }\n\n onFinalize(\n callback: (\n event: GestureStateChangeEvent,\n success: boolean\n ) => void\n ) {\n this.handlers.onFinalize = callback;\n //@ts-ignore if callback is a worklet, the property will be available, if not then the check will return false\n this.handlers.isWorklet[CALLBACK_TYPE.FINALIZE] = this.isWorklet(callback);\n return this;\n }\n\n onTouchesDown(callback: TouchEventHandlerType) {\n this.config.needsPointerData = true;\n this.handlers.onTouchesDown = callback;\n this.handlers.isWorklet[CALLBACK_TYPE.TOUCHES_DOWN] =\n this.isWorklet(callback);\n\n return this;\n }\n\n onTouchesMove(callback: TouchEventHandlerType) {\n this.config.needsPointerData = true;\n this.handlers.onTouchesMove = callback;\n this.handlers.isWorklet[CALLBACK_TYPE.TOUCHES_MOVE] =\n this.isWorklet(callback);\n\n return this;\n }\n\n onTouchesUp(callback: TouchEventHandlerType) {\n this.config.needsPointerData = true;\n this.handlers.onTouchesUp = callback;\n this.handlers.isWorklet[CALLBACK_TYPE.TOUCHES_UP] =\n this.isWorklet(callback);\n\n return this;\n }\n\n onTouchesCancelled(callback: TouchEventHandlerType) {\n this.config.needsPointerData = true;\n this.handlers.onTouchesCancelled = callback;\n this.handlers.isWorklet[CALLBACK_TYPE.TOUCHES_CANCELLED] =\n this.isWorklet(callback);\n\n return this;\n }\n\n enabled(enabled: boolean) {\n this.config.enabled = enabled;\n return this;\n }\n\n shouldCancelWhenOutside(value: boolean) {\n this.config.shouldCancelWhenOutside = value;\n return this;\n }\n\n hitSlop(hitSlop: HitSlop) {\n this.config.hitSlop = hitSlop;\n return this;\n }\n\n runOnJS(runOnJS: boolean) {\n this.config.runOnJS = runOnJS;\n return this;\n }\n\n simultaneousWithExternalGesture(...gestures: Exclude[]) {\n for (const gesture of gestures) {\n this.addDependency('simultaneousWith', gesture);\n }\n return this;\n }\n\n requireExternalGestureToFail(...gestures: Exclude[]) {\n for (const gesture of gestures) {\n this.addDependency('requireToFail', gesture);\n }\n return this;\n }\n\n withTestId(id: string) {\n this.config.testId = id;\n return this;\n }\n\n cancelsTouchesInView(value: boolean) {\n this.config.cancelsTouchesInView = value;\n return this;\n }\n\n initialize() {\n this.handlerTag = getNextHandlerTag();\n\n this.handlers = { ...this.handlers, handlerTag: this.handlerTag };\n\n if (this.config.ref) {\n this.config.ref.current = this as GestureType;\n }\n }\n\n toGestureArray(): GestureType[] {\n return [this as GestureType];\n }\n\n // eslint-disable-next-line @typescript-eslint/no-empty-function\n prepare() {}\n\n get shouldUseReanimated(): boolean {\n // use Reanimated when runOnJS isn't set explicitly,\n // and all defined callbacks are worklets,\n // and remote debugging is disabled\n return (\n this.config.runOnJS !== true &&\n !this.handlers.isWorklet.includes(false) &&\n !isRemoteDebuggingEnabled()\n );\n }\n}\n\nexport abstract class ContinousBaseGesture<\n EventPayloadT extends Record,\n EventChangePayloadT extends Record\n> extends BaseGesture {\n onUpdate(callback: (event: GestureUpdateEvent) => void) {\n this.handlers.onUpdate = callback;\n this.handlers.isWorklet[CALLBACK_TYPE.UPDATE] = this.isWorklet(callback);\n return this;\n }\n\n onChange(\n callback: (\n event: GestureUpdateEvent\n ) => void\n ) {\n this.handlers.onChange = callback;\n this.handlers.isWorklet[CALLBACK_TYPE.CHANGE] = this.isWorklet(callback);\n return this;\n }\n\n manualActivation(manualActivation: boolean) {\n this.config.manualActivation = manualActivation;\n return this;\n }\n}\n","import { BaseGestureConfig, ContinousBaseGesture } from './gesture';\nimport { GestureUpdateEvent } from '../gestureHandlerCommon';\nimport {\n PanGestureConfig,\n PanGestureHandlerEventPayload,\n} from '../PanGestureHandler';\n\nexport type PanGestureChangeEventPayload = {\n changeX: number;\n changeY: number;\n};\n\nfunction changeEventCalculator(\n current: GestureUpdateEvent,\n previous?: GestureUpdateEvent\n) {\n 'worklet';\n let changePayload: PanGestureChangeEventPayload;\n if (previous === undefined) {\n changePayload = {\n changeX: current.translationX,\n changeY: current.translationY,\n };\n } else {\n changePayload = {\n changeX: current.translationX - previous.translationX,\n changeY: current.translationY - previous.translationY,\n };\n }\n\n return { ...current, ...changePayload };\n}\n\nexport class PanGesture extends ContinousBaseGesture<\n PanGestureHandlerEventPayload,\n PanGestureChangeEventPayload\n> {\n public config: BaseGestureConfig & PanGestureConfig = {};\n\n constructor() {\n super();\n\n this.handlerName = 'PanGestureHandler';\n }\n\n activeOffsetY(offset: number | number[]) {\n if (Array.isArray(offset)) {\n this.config.activeOffsetYStart = offset[0];\n this.config.activeOffsetYEnd = offset[1];\n } else if (offset < 0) {\n this.config.activeOffsetYStart = offset;\n } else {\n this.config.activeOffsetYEnd = offset;\n }\n return this;\n }\n\n activeOffsetX(offset: number | number[]) {\n if (Array.isArray(offset)) {\n this.config.activeOffsetXStart = offset[0];\n this.config.activeOffsetXEnd = offset[1];\n } else if (offset < 0) {\n this.config.activeOffsetXStart = offset;\n } else {\n this.config.activeOffsetXEnd = offset;\n }\n return this;\n }\n\n failOffsetY(offset: number | number[]) {\n if (Array.isArray(offset)) {\n this.config.failOffsetYStart = offset[0];\n this.config.failOffsetYEnd = offset[1];\n } else if (offset < 0) {\n this.config.failOffsetYStart = offset;\n } else {\n this.config.failOffsetYEnd = offset;\n }\n return this;\n }\n\n failOffsetX(offset: number | number[]) {\n if (Array.isArray(offset)) {\n this.config.failOffsetXStart = offset[0];\n this.config.failOffsetXEnd = offset[1];\n } else if (offset < 0) {\n this.config.failOffsetXStart = offset;\n } else {\n this.config.failOffsetXEnd = offset;\n }\n return this;\n }\n\n minPointers(minPointers: number) {\n this.config.minPointers = minPointers;\n return this;\n }\n\n maxPointers(maxPointers: number) {\n this.config.maxPointers = maxPointers;\n return this;\n }\n\n minDistance(distance: number) {\n this.config.minDist = distance;\n return this;\n }\n\n minVelocity(velocity: number) {\n this.config.minVelocity = velocity;\n return this;\n }\n\n minVelocityX(velocity: number) {\n this.config.minVelocityX = velocity;\n return this;\n }\n\n minVelocityY(velocity: number) {\n this.config.minVelocityY = velocity;\n return this;\n }\n\n averageTouches(value: boolean) {\n this.config.avgTouches = value;\n return this;\n }\n\n enableTrackpadTwoFingerGesture(value: boolean) {\n this.config.enableTrackpadTwoFingerGesture = value;\n return this;\n }\n\n activateAfterLongPress(duration: number) {\n this.config.activateAfterLongPress = duration;\n return this;\n }\n\n onChange(\n callback: (\n event: GestureUpdateEvent<\n PanGestureHandlerEventPayload & PanGestureChangeEventPayload\n >\n ) => void\n ) {\n // @ts-ignore TS being overprotective, PanGestureHandlerEventPayload is Record\n this.handlers.changeEventCalculator = changeEventCalculator;\n return super.onChange(callback);\n }\n}\n\nexport type PanGestureType = InstanceType;\n","import { ContinousBaseGesture } from './gesture';\nimport { PinchGestureHandlerEventPayload } from '../PinchGestureHandler';\nimport { GestureUpdateEvent } from '../gestureHandlerCommon';\n\nexport type PinchGestureChangeEventPayload = {\n scaleChange: number;\n};\n\nfunction changeEventCalculator(\n current: GestureUpdateEvent,\n previous?: GestureUpdateEvent\n) {\n 'worklet';\n let changePayload: PinchGestureChangeEventPayload;\n if (previous === undefined) {\n changePayload = {\n scaleChange: current.scale,\n };\n } else {\n changePayload = {\n scaleChange: current.scale / previous.scale,\n };\n }\n\n return { ...current, ...changePayload };\n}\n\nexport class PinchGesture extends ContinousBaseGesture<\n PinchGestureHandlerEventPayload,\n PinchGestureChangeEventPayload\n> {\n constructor() {\n super();\n\n this.handlerName = 'PinchGestureHandler';\n }\n\n onChange(\n callback: (\n event: GestureUpdateEvent<\n PinchGestureHandlerEventPayload & PinchGestureChangeEventPayload\n >\n ) => void\n ) {\n // @ts-ignore TS being overprotective, PinchGestureHandlerEventPayload is Record\n this.handlers.changeEventCalculator = changeEventCalculator;\n return super.onChange(callback);\n }\n}\n\nexport type PinchGestureType = InstanceType;\n","import { ContinousBaseGesture } from './gesture';\nimport { RotationGestureHandlerEventPayload } from '../RotationGestureHandler';\nimport { GestureUpdateEvent } from '../gestureHandlerCommon';\n\ntype RotationGestureChangeEventPayload = {\n rotationChange: number;\n};\n\nfunction changeEventCalculator(\n current: GestureUpdateEvent,\n previous?: GestureUpdateEvent\n) {\n 'worklet';\n let changePayload: RotationGestureChangeEventPayload;\n if (previous === undefined) {\n changePayload = {\n rotationChange: current.rotation,\n };\n } else {\n changePayload = {\n rotationChange: current.rotation - previous.rotation,\n };\n }\n\n return { ...current, ...changePayload };\n}\n\nexport class RotationGesture extends ContinousBaseGesture<\n RotationGestureHandlerEventPayload,\n RotationGestureChangeEventPayload\n> {\n constructor() {\n super();\n\n this.handlerName = 'RotationGestureHandler';\n }\n\n onChange(\n callback: (\n event: GestureUpdateEvent<\n RotationGestureHandlerEventPayload & RotationGestureChangeEventPayload\n >\n ) => void\n ) {\n // @ts-ignore TS being overprotective, RotationGestureHandlerEventPayload is Record\n this.handlers.changeEventCalculator = changeEventCalculator;\n return super.onChange(callback);\n }\n}\n\nexport type RotationGestureType = InstanceType;\n","import { BaseGesture, BaseGestureConfig } from './gesture';\nimport {\n FlingGestureConfig,\n FlingGestureHandlerEventPayload,\n} from '../FlingGestureHandler';\n\nexport class FlingGesture extends BaseGesture {\n public config: BaseGestureConfig & FlingGestureConfig = {};\n\n constructor() {\n super();\n\n this.handlerName = 'FlingGestureHandler';\n }\n\n numberOfPointers(pointers: number) {\n this.config.numberOfPointers = pointers;\n return this;\n }\n\n direction(direction: number) {\n this.config.direction = direction;\n return this;\n }\n}\n\nexport type FlingGestureType = InstanceType;\n","import { BaseGesture, BaseGestureConfig } from './gesture';\nimport {\n LongPressGestureConfig,\n LongPressGestureHandlerEventPayload,\n} from '../LongPressGestureHandler';\n\nexport class LongPressGesture extends BaseGesture {\n public config: BaseGestureConfig & LongPressGestureConfig = {};\n\n constructor() {\n super();\n\n this.handlerName = 'LongPressGestureHandler';\n this.shouldCancelWhenOutside(true);\n }\n\n minDuration(duration: number) {\n this.config.minDurationMs = duration;\n return this;\n }\n\n maxDistance(distance: number) {\n this.config.maxDist = distance;\n return this;\n }\n}\n\nexport type LongPressGestureType = InstanceType;\n","import { BaseGestureConfig, ContinousBaseGesture } from './gesture';\nimport {\n ForceTouchGestureConfig,\n ForceTouchGestureHandlerEventPayload,\n} from '../ForceTouchGestureHandler';\nimport { GestureUpdateEvent } from '../gestureHandlerCommon';\n\nexport type ForceTouchGestureChangeEventPayload = {\n forceChange: number;\n};\n\nfunction changeEventCalculator(\n current: GestureUpdateEvent,\n previous?: GestureUpdateEvent\n) {\n 'worklet';\n let changePayload: ForceTouchGestureChangeEventPayload;\n if (previous === undefined) {\n changePayload = {\n forceChange: current.force,\n };\n } else {\n changePayload = {\n forceChange: current.force - previous.force,\n };\n }\n\n return { ...current, ...changePayload };\n}\n\nexport class ForceTouchGesture extends ContinousBaseGesture<\n ForceTouchGestureHandlerEventPayload,\n ForceTouchGestureChangeEventPayload\n> {\n public config: BaseGestureConfig & ForceTouchGestureConfig = {};\n\n constructor() {\n super();\n\n this.handlerName = 'ForceTouchGestureHandler';\n }\n\n minForce(force: number) {\n this.config.minForce = force;\n return this;\n }\n\n maxForce(force: number) {\n this.config.maxForce = force;\n return this;\n }\n\n feedbackOnActivation(value: boolean) {\n this.config.feedbackOnActivation = value;\n return this;\n }\n\n onChange(\n callback: (\n event: GestureUpdateEvent<\n GestureUpdateEvent<\n ForceTouchGestureHandlerEventPayload &\n ForceTouchGestureChangeEventPayload\n >\n >\n ) => void\n ) {\n // @ts-ignore TS being overprotective, ForceTouchGestureHandlerEventPayload is Record\n this.handlers.changeEventCalculator = changeEventCalculator;\n return super.onChange(callback);\n }\n}\n\nexport type ForceTouchGestureType = InstanceType;\n","import { BaseGestureConfig, BaseGesture } from './gesture';\nimport {\n NativeViewGestureConfig,\n NativeViewGestureHandlerPayload,\n} from '../NativeViewGestureHandler';\n\nexport class NativeGesture extends BaseGesture {\n public config: BaseGestureConfig & NativeViewGestureConfig = {};\n\n constructor() {\n super();\n\n this.handlerName = 'NativeViewGestureHandler';\n }\n\n shouldActivateOnStart(value: boolean) {\n this.config.shouldActivateOnStart = value;\n return this;\n }\n\n disallowInterruption(value: boolean) {\n this.config.disallowInterruption = value;\n return this;\n }\n}\n\nexport type NativeGestureType = InstanceType;\n","import { GestureUpdateEvent } from '../gestureHandlerCommon';\nimport { ContinousBaseGesture } from './gesture';\n\nfunction changeEventCalculator(\n current: GestureUpdateEvent>,\n _previous?: GestureUpdateEvent>\n) {\n 'worklet';\n return current;\n}\n\nexport class ManualGesture extends ContinousBaseGesture<\n Record,\n Record\n> {\n constructor() {\n super();\n\n this.handlerName = 'ManualGestureHandler';\n }\n\n onChange(\n callback: (event: GestureUpdateEvent>) => void\n ) {\n // @ts-ignore TS being overprotective, Record is Record\n this.handlers.changeEventCalculator = changeEventCalculator;\n return super.onChange(callback);\n }\n}\n\nexport type ManualGestureType = InstanceType;\n","import { BaseGesture, Gesture, GestureRef, GestureType } from './gesture';\n\nfunction extendRelation(\n currentRelation: GestureRef[] | undefined,\n extendWith: GestureType[]\n) {\n if (currentRelation === undefined) {\n return [...extendWith];\n } else {\n return [...currentRelation, ...extendWith];\n }\n}\n\nexport class ComposedGesture extends Gesture {\n protected gestures: Gesture[] = [];\n protected simultaneousGestures: GestureType[] = [];\n protected requireGesturesToFail: GestureType[] = [];\n\n constructor(...gestures: Gesture[]) {\n super();\n this.gestures = gestures;\n }\n\n protected prepareSingleGesture(\n gesture: Gesture,\n simultaneousGestures: GestureType[],\n requireGesturesToFail: GestureType[]\n ) {\n if (gesture instanceof BaseGesture) {\n const newConfig = { ...gesture.config };\n\n newConfig.simultaneousWith = extendRelation(\n newConfig.simultaneousWith,\n simultaneousGestures\n );\n newConfig.requireToFail = extendRelation(\n newConfig.requireToFail,\n requireGesturesToFail\n );\n\n gesture.config = newConfig;\n } else if (gesture instanceof ComposedGesture) {\n gesture.simultaneousGestures = simultaneousGestures;\n gesture.requireGesturesToFail = requireGesturesToFail;\n gesture.prepare();\n }\n }\n\n prepare() {\n for (const gesture of this.gestures) {\n this.prepareSingleGesture(\n gesture,\n this.simultaneousGestures,\n this.requireGesturesToFail\n );\n }\n }\n\n initialize() {\n for (const gesture of this.gestures) {\n gesture.initialize();\n }\n }\n\n toGestureArray(): GestureType[] {\n return this.gestures.flatMap((gesture) => gesture.toGestureArray());\n }\n}\n\nexport class SimultaneousGesture extends ComposedGesture {\n prepare() {\n // this piece of magic works something like this:\n // for every gesture in the array\n const simultaneousArrays = this.gestures.map((gesture) =>\n // we take the array it's in\n this.gestures\n // and make a copy without it\n .filter((x) => x !== gesture)\n // then we flatmap the result to get list of raw (not composed) gestures\n // this way we don't make the gestures simultaneous with themselves, which is\n // important when the gesture is `ExclusiveGesture` - we don't want to make\n // exclusive gestures simultaneous\n .flatMap((x) => x.toGestureArray())\n );\n\n for (let i = 0; i < this.gestures.length; i++) {\n this.prepareSingleGesture(\n this.gestures[i],\n simultaneousArrays[i],\n this.requireGesturesToFail\n );\n }\n }\n}\n\nexport class ExclusiveGesture extends ComposedGesture {\n prepare() {\n // transforms the array of gestures into array of grouped raw (not composed) gestures\n // i.e. [gesture1, gesture2, ComposedGesture(gesture3, gesture4)] -> [[gesture1], [gesture2], [gesture3, gesture4]]\n const gestureArrays = this.gestures.map((gesture) =>\n gesture.toGestureArray()\n );\n\n let requireToFail: GestureType[] = [];\n\n for (let i = 0; i < this.gestures.length; i++) {\n this.prepareSingleGesture(\n this.gestures[i],\n this.simultaneousGestures,\n this.requireGesturesToFail.concat(requireToFail)\n );\n\n // every group gets to wait for all groups before it\n requireToFail = requireToFail.concat(gestureArrays[i]);\n }\n }\n}\n\nexport type ComposedGestureType = InstanceType;\nexport type RaceGestureType = ComposedGestureType;\nexport type SimultaneousGestureType = InstanceType;\nexport type ExclusiveGestureType = InstanceType;\n","import React, { useEffect, useRef, useState } from 'react';\nimport {\n GestureType,\n HandlerCallbacks,\n BaseGesture,\n GestureRef,\n CALLBACK_TYPE,\n} from './gesture';\nimport { Reanimated, SharedValue } from './reanimatedWrapper';\nimport { registerHandler, unregisterHandler } from '../handlersRegistry';\nimport RNGestureHandlerModule from '../../RNGestureHandlerModule';\nimport {\n baseGestureHandlerWithMonitorProps,\n filterConfig,\n findNodeHandle,\n GestureTouchEvent,\n GestureUpdateEvent,\n GestureStateChangeEvent,\n HandlerStateChangeEvent,\n scheduleFlushOperations,\n UserSelect,\n} from '../gestureHandlerCommon';\nimport {\n GestureStateManager,\n GestureStateManagerType,\n} from './gestureStateManager';\nimport { flingGestureHandlerProps } from '../FlingGestureHandler';\nimport { forceTouchGestureHandlerProps } from '../ForceTouchGestureHandler';\nimport { longPressGestureHandlerProps } from '../LongPressGestureHandler';\nimport {\n panGestureHandlerProps,\n panGestureHandlerCustomNativeProps,\n} from '../PanGestureHandler';\nimport { tapGestureHandlerProps } from '../TapGestureHandler';\nimport { State } from '../../State';\nimport { TouchEventType } from '../../TouchEventType';\nimport { ComposedGesture } from './gestureComposition';\nimport { ActionType } from '../../ActionType';\nimport { isFabric, REACT_NATIVE_VERSION, tagMessage } from '../../utils';\nimport { getShadowNodeFromRef } from '../../getShadowNodeFromRef';\nimport { Platform } from 'react-native';\nimport type RNGestureHandlerModuleWeb from '../../RNGestureHandlerModule.web';\nimport { onGestureHandlerEvent } from './eventReceiver';\nimport { RNRenderer } from '../../RNRenderer';\nimport { isExperimentalWebImplementationEnabled } from '../../EnableExperimentalWebImplementation';\n\ndeclare const global: {\n isFormsStackingContext: (node: unknown) => boolean | null; // JSI function\n};\n\nconst ALLOWED_PROPS = [\n ...baseGestureHandlerWithMonitorProps,\n ...tapGestureHandlerProps,\n ...panGestureHandlerProps,\n ...panGestureHandlerCustomNativeProps,\n ...longPressGestureHandlerProps,\n ...forceTouchGestureHandlerProps,\n ...flingGestureHandlerProps,\n];\n\nexport type GestureConfigReference = {\n config: GestureType[];\n animatedEventHandler: unknown;\n animatedHandlers: SharedValue<\n HandlerCallbacks>[] | null\n > | null;\n firstExecution: boolean;\n useReanimatedHook: boolean;\n};\n\nfunction convertToHandlerTag(ref: GestureRef): number {\n if (typeof ref === 'number') {\n return ref;\n } else if (ref instanceof BaseGesture) {\n return ref.handlerTag;\n } else {\n // @ts-ignore in this case it should be a ref either to gesture object or\n // a gesture handler component, in both cases handlerTag property exists\n return ref.current?.handlerTag ?? -1;\n }\n}\n\nfunction extractValidHandlerTags(interactionGroup: GestureRef[] | undefined) {\n return (\n interactionGroup?.map(convertToHandlerTag)?.filter((tag) => tag > 0) ?? []\n );\n}\n\nfunction dropHandlers(preparedGesture: GestureConfigReference) {\n for (const handler of preparedGesture.config) {\n RNGestureHandlerModule.dropGestureHandler(handler.handlerTag);\n\n unregisterHandler(handler.handlerTag, handler.config.testId);\n }\n\n scheduleFlushOperations();\n}\n\nfunction checkGestureCallbacksForWorklets(gesture: GestureType) {\n // if a gesture is explicitly marked to run on the JS thread there is no need to check\n // if callbacks are worklets as the user is aware they will be ran on the JS thread\n if (gesture.config.runOnJS) {\n return;\n }\n\n const areSomeNotWorklets = gesture.handlers.isWorklet.includes(false);\n const areSomeWorklets = gesture.handlers.isWorklet.includes(true);\n\n // if some of the callbacks are worklets and some are not, and the gesture is not\n // explicitly marked with `.runOnJS(true)` show an error\n if (areSomeNotWorklets && areSomeWorklets) {\n console.error(\n tagMessage(\n `Some of the callbacks in the gesture are worklets and some are not. Either make sure that all calbacks are marked as 'worklet' if you wish to run them on the UI thread or use '.runOnJS(true)' modifier on the gesture explicitly to run all callbacks on the JS thread.`\n )\n );\n }\n}\n\ninterface WebEventHandler {\n onGestureHandlerEvent: (event: HandlerStateChangeEvent) => void;\n onGestureHandlerStateChange?: (\n event: HandlerStateChangeEvent\n ) => void;\n}\n\ninterface AttachHandlersConfig {\n preparedGesture: GestureConfigReference;\n gestureConfig: ComposedGesture | GestureType;\n gesture: GestureType[];\n viewTag: number;\n webEventHandlersRef: React.RefObject;\n mountedRef: React.RefObject;\n}\n\nfunction attachHandlers({\n preparedGesture,\n gestureConfig,\n gesture,\n viewTag,\n webEventHandlersRef,\n mountedRef,\n}: AttachHandlersConfig) {\n if (!preparedGesture.firstExecution) {\n gestureConfig.initialize();\n } else {\n preparedGesture.firstExecution = false;\n }\n\n // use setImmediate to extract handlerTags, because all refs should be initialized\n // when it's ran\n setImmediate(() => {\n if (!mountedRef.current) {\n return;\n }\n gestureConfig.prepare();\n });\n\n for (const handler of gesture) {\n checkGestureCallbacksForWorklets(handler);\n RNGestureHandlerModule.createGestureHandler(\n handler.handlerName,\n handler.handlerTag,\n filterConfig(handler.config, ALLOWED_PROPS)\n );\n\n registerHandler(handler.handlerTag, handler, handler.config.testId);\n }\n\n // use setImmediate to extract handlerTags, because all refs should be initialized\n // when it's ran\n setImmediate(() => {\n if (!mountedRef.current) {\n return;\n }\n for (const handler of gesture) {\n let requireToFail: number[] = [];\n if (handler.config.requireToFail) {\n requireToFail = extractValidHandlerTags(handler.config.requireToFail);\n }\n\n let simultaneousWith: number[] = [];\n if (handler.config.simultaneousWith) {\n simultaneousWith = extractValidHandlerTags(\n handler.config.simultaneousWith\n );\n }\n\n RNGestureHandlerModule.updateGestureHandler(\n handler.handlerTag,\n filterConfig(handler.config, ALLOWED_PROPS, {\n simultaneousHandlers: simultaneousWith,\n waitFor: requireToFail,\n })\n );\n }\n\n scheduleFlushOperations();\n });\n\n preparedGesture.config = gesture;\n\n for (const gesture of preparedGesture.config) {\n const actionType = gesture.shouldUseReanimated\n ? ActionType.REANIMATED_WORKLET\n : ActionType.JS_FUNCTION_NEW_API;\n\n if (Platform.OS === 'web') {\n (\n RNGestureHandlerModule.attachGestureHandler as typeof RNGestureHandlerModuleWeb.attachGestureHandler\n )(\n gesture.handlerTag,\n viewTag,\n ActionType.JS_FUNCTION_OLD_API, // ignored on web\n webEventHandlersRef\n );\n } else {\n RNGestureHandlerModule.attachGestureHandler(\n gesture.handlerTag,\n viewTag,\n actionType\n );\n }\n }\n\n if (preparedGesture.animatedHandlers) {\n const isAnimatedGesture = (g: GestureType) => g.shouldUseReanimated;\n\n preparedGesture.animatedHandlers.value = gesture\n .filter(isAnimatedGesture)\n .map((g) => g.handlers) as unknown as HandlerCallbacks<\n Record\n >[];\n }\n}\n\nfunction updateHandlers(\n preparedGesture: GestureConfigReference,\n gestureConfig: ComposedGesture | GestureType,\n gesture: GestureType[],\n mountedRef: React.RefObject\n) {\n gestureConfig.prepare();\n\n for (let i = 0; i < gesture.length; i++) {\n const handler = preparedGesture.config[i];\n checkGestureCallbacksForWorklets(handler);\n\n // only update handlerTag when it's actually different, it may be the same\n // if gesture config object is wrapped with useMemo\n if (gesture[i].handlerTag !== handler.handlerTag) {\n gesture[i].handlerTag = handler.handlerTag;\n gesture[i].handlers.handlerTag = handler.handlerTag;\n }\n }\n\n // use setImmediate to extract handlerTags, because when it's ran, all refs should be updated\n // and handlerTags in BaseGesture references should be updated in the loop above (we need to wait\n // in case of external relations)\n setImmediate(() => {\n if (!mountedRef.current) {\n return;\n }\n for (let i = 0; i < gesture.length; i++) {\n const handler = preparedGesture.config[i];\n\n handler.config = gesture[i].config;\n handler.handlers = gesture[i].handlers;\n\n const requireToFail = extractValidHandlerTags(\n handler.config.requireToFail\n );\n\n const simultaneousWith = extractValidHandlerTags(\n handler.config.simultaneousWith\n );\n\n RNGestureHandlerModule.updateGestureHandler(\n handler.handlerTag,\n filterConfig(handler.config, ALLOWED_PROPS, {\n simultaneousHandlers: simultaneousWith,\n waitFor: requireToFail,\n })\n );\n\n registerHandler(handler.handlerTag, handler, handler.config.testId);\n }\n\n if (preparedGesture.animatedHandlers) {\n const previousHandlersValue =\n preparedGesture.animatedHandlers.value ?? [];\n const newHandlersValue = preparedGesture.config\n .filter((g) => g.shouldUseReanimated) // ignore gestures that shouldn't run on UI\n .map((g) => g.handlers) as unknown as HandlerCallbacks<\n Record\n >[];\n\n // if amount of gesture configs changes, we need to update the callbacks in shared value\n let shouldUpdateSharedValue =\n previousHandlersValue.length !== newHandlersValue.length;\n\n if (!shouldUpdateSharedValue) {\n // if the amount is the same, we need to check if any of the configs inside has changed\n for (let i = 0; i < newHandlersValue.length; i++) {\n if (\n // we can use the `gestureId` prop as it's unique for every config instance\n newHandlersValue[i].gestureId !== previousHandlersValue[i].gestureId\n ) {\n shouldUpdateSharedValue = true;\n break;\n }\n }\n }\n\n if (shouldUpdateSharedValue) {\n preparedGesture.animatedHandlers.value = newHandlersValue;\n }\n }\n\n scheduleFlushOperations();\n });\n}\n\nfunction needsToReattach(\n preparedGesture: GestureConfigReference,\n gesture: GestureType[]\n) {\n if (gesture.length !== preparedGesture.config.length) {\n return true;\n }\n for (let i = 0; i < gesture.length; i++) {\n if (\n gesture[i].handlerName !== preparedGesture.config[i].handlerName ||\n gesture[i].shouldUseReanimated !==\n preparedGesture.config[i].shouldUseReanimated\n ) {\n return true;\n }\n }\n\n return false;\n}\n\nfunction isStateChangeEvent(\n event: GestureUpdateEvent | GestureStateChangeEvent | GestureTouchEvent\n): event is GestureStateChangeEvent {\n 'worklet';\n // @ts-ignore Yes, the oldState prop is missing on GestureTouchEvent, that's the point\n return event.oldState != null;\n}\n\nfunction isTouchEvent(\n event: GestureUpdateEvent | GestureStateChangeEvent | GestureTouchEvent\n): event is GestureTouchEvent {\n 'worklet';\n return event.eventType != null;\n}\n\nfunction getHandler(\n type: CALLBACK_TYPE,\n gesture: HandlerCallbacks>\n) {\n 'worklet';\n switch (type) {\n case CALLBACK_TYPE.BEGAN:\n return gesture.onBegin;\n case CALLBACK_TYPE.START:\n return gesture.onStart;\n case CALLBACK_TYPE.UPDATE:\n return gesture.onUpdate;\n case CALLBACK_TYPE.CHANGE:\n return gesture.onChange;\n case CALLBACK_TYPE.END:\n return gesture.onEnd;\n case CALLBACK_TYPE.FINALIZE:\n return gesture.onFinalize;\n case CALLBACK_TYPE.TOUCHES_DOWN:\n return gesture.onTouchesDown;\n case CALLBACK_TYPE.TOUCHES_MOVE:\n return gesture.onTouchesMove;\n case CALLBACK_TYPE.TOUCHES_UP:\n return gesture.onTouchesUp;\n case CALLBACK_TYPE.TOUCHES_CANCELLED:\n return gesture.onTouchesCancelled;\n }\n}\n\nfunction touchEventTypeToCallbackType(\n eventType: TouchEventType\n): CALLBACK_TYPE {\n 'worklet';\n switch (eventType) {\n case TouchEventType.TOUCHES_DOWN:\n return CALLBACK_TYPE.TOUCHES_DOWN;\n case TouchEventType.TOUCHES_MOVE:\n return CALLBACK_TYPE.TOUCHES_MOVE;\n case TouchEventType.TOUCHES_UP:\n return CALLBACK_TYPE.TOUCHES_UP;\n case TouchEventType.TOUCHES_CANCELLED:\n return CALLBACK_TYPE.TOUCHES_CANCELLED;\n }\n return CALLBACK_TYPE.UNDEFINED;\n}\n\nfunction runWorklet(\n type: CALLBACK_TYPE,\n gesture: HandlerCallbacks>,\n event: GestureStateChangeEvent | GestureUpdateEvent | GestureTouchEvent,\n ...args: any[]\n) {\n 'worklet';\n const handler = getHandler(type, gesture);\n if (gesture.isWorklet[type]) {\n // @ts-ignore Logic below makes sure the correct event is send to the\n // correct handler.\n handler?.(event, ...args);\n } else if (handler) {\n console.warn(tagMessage('Animated gesture callback must be a worklet'));\n }\n}\n\nfunction useAnimatedGesture(\n preparedGesture: GestureConfigReference,\n needsRebuild: boolean\n) {\n if (!Reanimated) {\n return;\n }\n\n // Hooks are called conditionally, but the condition is whether the\n // react-native-reanimated is installed, which shouldn't change while running\n // eslint-disable-next-line react-hooks/rules-of-hooks\n const sharedHandlersCallbacks = Reanimated.useSharedValue<\n HandlerCallbacks>[] | null\n >(null);\n\n // eslint-disable-next-line react-hooks/rules-of-hooks\n const lastUpdateEvent = Reanimated.useSharedValue<\n (GestureUpdateEvent | undefined)[]\n >([]);\n\n // not every gesture needs a state controller, init them lazily\n const stateControllers: GestureStateManagerType[] = [];\n\n const callback = (\n event: GestureStateChangeEvent | GestureUpdateEvent | GestureTouchEvent\n ) => {\n 'worklet';\n\n const currentCallback = sharedHandlersCallbacks.value;\n if (!currentCallback) {\n return;\n }\n\n for (let i = 0; i < currentCallback.length; i++) {\n const gesture = currentCallback[i];\n\n if (event.handlerTag === gesture.handlerTag) {\n if (isStateChangeEvent(event)) {\n if (\n event.oldState === State.UNDETERMINED &&\n event.state === State.BEGAN\n ) {\n runWorklet(CALLBACK_TYPE.BEGAN, gesture, event);\n } else if (\n (event.oldState === State.BEGAN ||\n event.oldState === State.UNDETERMINED) &&\n event.state === State.ACTIVE\n ) {\n runWorklet(CALLBACK_TYPE.START, gesture, event);\n lastUpdateEvent.value[gesture.handlerTag] = undefined;\n } else if (\n event.oldState !== event.state &&\n event.state === State.END\n ) {\n if (event.oldState === State.ACTIVE) {\n runWorklet(CALLBACK_TYPE.END, gesture, event, true);\n }\n runWorklet(CALLBACK_TYPE.FINALIZE, gesture, event, true);\n } else if (\n (event.state === State.FAILED || event.state === State.CANCELLED) &&\n event.state !== event.oldState\n ) {\n if (event.oldState === State.ACTIVE) {\n runWorklet(CALLBACK_TYPE.END, gesture, event, false);\n }\n runWorklet(CALLBACK_TYPE.FINALIZE, gesture, event, false);\n }\n } else if (isTouchEvent(event)) {\n if (!stateControllers[i]) {\n stateControllers[i] = GestureStateManager.create(event.handlerTag);\n }\n\n if (event.eventType !== TouchEventType.UNDETERMINED) {\n runWorklet(\n touchEventTypeToCallbackType(event.eventType),\n gesture,\n event,\n stateControllers[i]\n );\n }\n } else {\n runWorklet(CALLBACK_TYPE.UPDATE, gesture, event);\n\n if (gesture.onChange && gesture.changeEventCalculator) {\n runWorklet(\n CALLBACK_TYPE.CHANGE,\n gesture,\n gesture.changeEventCalculator?.(\n event,\n lastUpdateEvent.value[gesture.handlerTag]\n )\n );\n\n lastUpdateEvent.value[gesture.handlerTag] = event;\n }\n }\n }\n }\n };\n\n // eslint-disable-next-line react-hooks/rules-of-hooks\n const event = Reanimated.useEvent(\n callback,\n ['onGestureHandlerStateChange', 'onGestureHandlerEvent'],\n needsRebuild\n );\n\n preparedGesture.animatedEventHandler = event;\n preparedGesture.animatedHandlers = sharedHandlersCallbacks;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction validateDetectorChildren(ref: any) {\n // finds the first native view under the Wrap component and traverses the fiber tree upwards\n // to check whether there is more than one native view as a pseudo-direct child of GestureDetector\n // i.e. this is not ok:\n // Wrap\n // |\n // / \\\n // / \\\n // / \\\n // / \\\n // NativeView NativeView\n //\n // but this is fine:\n // Wrap\n // |\n // NativeView\n // |\n // / \\\n // / \\\n // / \\\n // / \\\n // NativeView NativeView\n if (__DEV__ && Platform.OS !== 'web') {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n const wrapType =\n REACT_NATIVE_VERSION.minor > 63 || REACT_NATIVE_VERSION.major > 0\n ? // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n ref._reactInternals.elementType\n : // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n ref._reactInternalFiber.elementType;\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n let instance =\n RNRenderer.findHostInstance_DEPRECATED(\n ref\n )._internalFiberInstanceHandleDEV;\n\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n while (instance && instance.elementType !== wrapType) {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n if (instance.sibling) {\n throw new Error(\n 'GestureDetector has more than one native view as its children. This can happen if you are using a custom component that renders multiple views, like React.Fragment. You should wrap content of GestureDetector with a or .'\n );\n }\n\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access\n instance = instance.return;\n }\n }\n}\n\nconst applyUserSelectProp = (\n userSelect: UserSelect,\n gesture: ComposedGesture | GestureType\n): void => {\n for (const g of gesture.toGestureArray()) {\n g.config.userSelect = userSelect;\n }\n};\n\ninterface GestureDetectorProps {\n gesture: ComposedGesture | GestureType;\n userSelect?: UserSelect;\n children?: React.ReactNode;\n}\ninterface GestureDetectorState {\n firstRender: boolean;\n viewRef: React.Component | null;\n previousViewTag: number;\n forceReattach: boolean;\n}\nexport const GestureDetector = (props: GestureDetectorProps) => {\n const gestureConfig = props.gesture;\n\n if (props.userSelect) {\n applyUserSelectProp(props.userSelect, gestureConfig);\n }\n\n const gesture = gestureConfig.toGestureArray();\n const useReanimatedHook = gesture.some((g) => g.shouldUseReanimated);\n\n // store state in ref to prevent unnecessary renders\n const state = useRef({\n firstRender: true,\n viewRef: null,\n previousViewTag: -1,\n forceReattach: false,\n }).current;\n const mountedRef = useRef(false);\n const webEventHandlersRef = useRef({\n onGestureHandlerEvent: (e: HandlerStateChangeEvent) => {\n onGestureHandlerEvent(e.nativeEvent);\n },\n onGestureHandlerStateChange: isExperimentalWebImplementationEnabled()\n ? (e: HandlerStateChangeEvent) => {\n onGestureHandlerEvent(e.nativeEvent);\n }\n : undefined,\n });\n\n const [renderState, setRenderState] = useState(false);\n function forceRender() {\n setRenderState(!renderState);\n }\n\n const preparedGesture = React.useRef({\n config: gesture,\n animatedEventHandler: null,\n animatedHandlers: null,\n firstExecution: true,\n useReanimatedHook: useReanimatedHook,\n }).current;\n\n if (useReanimatedHook !== preparedGesture.useReanimatedHook) {\n throw new Error(\n tagMessage(\n 'You cannot change the thread the callbacks are ran on while the app is running'\n )\n );\n }\n\n function onHandlersUpdate(skipConfigUpdate?: boolean) {\n // if the underlying view has changed we need to reattach handlers to the new view\n const viewTag = findNodeHandle(state.viewRef) as number;\n const forceReattach = viewTag !== state.previousViewTag;\n\n if (forceReattach || needsToReattach(preparedGesture, gesture)) {\n validateDetectorChildren(state.viewRef);\n dropHandlers(preparedGesture);\n attachHandlers({\n preparedGesture,\n gestureConfig,\n gesture,\n webEventHandlersRef,\n viewTag,\n mountedRef,\n });\n\n state.previousViewTag = viewTag;\n state.forceReattach = forceReattach;\n if (forceReattach) {\n forceRender();\n }\n } else if (!skipConfigUpdate) {\n updateHandlers(preparedGesture, gestureConfig, gesture, mountedRef);\n }\n }\n\n // Reanimated event should be rebuilt only when gestures are reattached, otherwise\n // config update will be enough as all necessary items are stored in shared values anyway\n const needsToRebuildReanimatedEvent =\n preparedGesture.firstExecution ||\n needsToReattach(preparedGesture, gesture) ||\n state.forceReattach;\n\n state.forceReattach = false;\n\n if (preparedGesture.firstExecution) {\n gestureConfig.initialize();\n }\n\n if (useReanimatedHook) {\n // Whether animatedGesture or gesture is used shouldn't change while the app is running\n // eslint-disable-next-line react-hooks/rules-of-hooks\n useAnimatedGesture(preparedGesture, needsToRebuildReanimatedEvent);\n }\n\n useEffect(() => {\n const viewTag = findNodeHandle(state.viewRef) as number;\n state.firstRender = true;\n mountedRef.current = true;\n\n validateDetectorChildren(state.viewRef);\n\n attachHandlers({\n preparedGesture,\n gestureConfig,\n gesture,\n webEventHandlersRef,\n viewTag,\n mountedRef,\n });\n\n return () => {\n mountedRef.current = false;\n dropHandlers(preparedGesture);\n };\n }, []);\n\n useEffect(() => {\n if (!state.firstRender) {\n onHandlersUpdate();\n } else {\n state.firstRender = false;\n }\n }, [props]);\n\n const refFunction = (ref: unknown) => {\n if (ref !== null) {\n // @ts-ignore Just setting the view ref\n state.viewRef = ref;\n\n // if it's the first render, also set the previousViewTag to prevent reattaching gestures when not needed\n if (state.previousViewTag === -1) {\n state.previousViewTag = findNodeHandle(state.viewRef) as number;\n }\n\n // pass true as `skipConfigUpdate`, here we only want to trigger the eventual reattaching of handlers\n // in case the view has changed, while config update would be handled be the `useEffect` above\n onHandlersUpdate(true);\n\n if (isFabric()) {\n const node = getShadowNodeFromRef(ref);\n if (global.isFormsStackingContext(node) === false) {\n console.error(\n tagMessage(\n 'GestureDetector has received a child that may get view-flattened. ' +\n '\\nTo prevent it from misbehaving you need to wrap the child with a ``.'\n )\n );\n }\n }\n }\n };\n\n if (useReanimatedHook) {\n return (\n \n {props.children}\n \n );\n } else {\n return {props.children};\n }\n};\n\nclass Wrap extends React.Component<{\n onGestureHandlerEvent?: unknown;\n // implicit `children` prop has been removed in @types/react^18.0.0\n children?: React.ReactNode;\n}> {\n render() {\n try {\n // I don't think that fighting with types over such a simple function is worth it\n // The only thing it does is add 'collapsable: false' to the child component\n // to make sure it is in the native view hierarchy so the detector can find\n // correct viewTag to attach to.\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const child: any = React.Children.only(this.props.children);\n return React.cloneElement(\n child,\n { collapsable: false },\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n child.props.children\n );\n } catch (e) {\n throw new Error(\n tagMessage(\n `GestureDetector got more than one view as a child. If you want the gesture to work on multiple views, wrap them with a common parent and attach the gesture to that view.`\n )\n );\n }\n }\n}\n\nconst AnimatedWrap = Reanimated?.default?.createAnimatedComponent(Wrap) ?? Wrap;\n","import createHandler from './createHandler';\nimport {\n BaseGestureHandlerProps,\n baseGestureHandlerProps,\n} from './gestureHandlerCommon';\n\nexport const tapGestureHandlerProps = [\n 'maxDurationMs',\n 'maxDelayMs',\n 'numberOfTaps',\n 'maxDeltaX',\n 'maxDeltaY',\n 'maxDist',\n 'minPointers',\n] as const;\n\nexport type TapGestureHandlerEventPayload = {\n x: number;\n y: number;\n absoluteX: number;\n absoluteY: number;\n};\nexport interface TapGestureConfig {\n /**\n * Minimum number of pointers (fingers) required to be placed before the\n * handler activates. Should be a positive integer.\n * The default value is 1.\n */\n minPointers?: number;\n\n /**\n * Maximum time, expressed in milliseconds, that defines how fast a finger\n * must be released after a touch. The default value is 500.\n */\n maxDurationMs?: number;\n\n /**\n * Maximum time, expressed in milliseconds, that can pass before the next tap\n * if many taps are required. The default value is 500.\n */\n maxDelayMs?: number;\n\n /**\n * Number of tap gestures required to activate the handler. The default value\n * is 1.\n */\n numberOfTaps?: number;\n\n /**\n * Maximum distance, expressed in points, that defines how far the finger is\n * allowed to travel along the X axis during a tap gesture. If the finger\n * travels further than the defined distance along the X axis and the handler\n * hasn't yet activated, it will fail to recognize the gesture.\n */\n maxDeltaX?: number;\n\n /**\n * Maximum distance, expressed in points, that defines how far the finger is\n * allowed to travel along the Y axis during a tap gesture. If the finger\n * travels further than the defined distance along the Y axis and the handler\n * hasn't yet activated, it will fail to recognize the gesture.\n */\n maxDeltaY?: number;\n\n /**\n * Maximum distance, expressed in points, that defines how far the finger is\n * allowed to travel during a tap gesture. If the finger travels further than\n * the defined distance and the handler hasn't yet\n * activated, it will fail to recognize the gesture.\n */\n maxDist?: number;\n}\n\nexport interface TapGestureHandlerProps\n extends BaseGestureHandlerProps,\n TapGestureConfig {}\n\nexport const tapHandlerName = 'TapGestureHandler';\n\nexport type TapGestureHandler = typeof TapGestureHandler;\n// eslint-disable-next-line @typescript-eslint/no-redeclare -- backward compatibility; see description on the top of gestureHandlerCommon.ts file\nexport const TapGestureHandler = createHandler<\n TapGestureHandlerProps,\n TapGestureHandlerEventPayload\n>({\n name: tapHandlerName,\n allowedProps: [\n ...baseGestureHandlerProps,\n ...tapGestureHandlerProps,\n ] as const,\n config: {\n shouldCancelWhenOutside: true,\n },\n});\n","import createHandler from './createHandler';\nimport {\n BaseGestureHandlerProps,\n baseGestureHandlerProps,\n} from './gestureHandlerCommon';\n\nexport const panGestureHandlerProps = [\n 'activeOffsetY',\n 'activeOffsetX',\n 'failOffsetY',\n 'failOffsetX',\n 'minDist',\n 'minVelocity',\n 'minVelocityX',\n 'minVelocityY',\n 'minPointers',\n 'maxPointers',\n 'avgTouches',\n 'enableTrackpadTwoFingerGesture',\n 'activateAfterLongPress',\n] as const;\n\nexport const panGestureHandlerCustomNativeProps = [\n 'activeOffsetYStart',\n 'activeOffsetYEnd',\n 'activeOffsetXStart',\n 'activeOffsetXEnd',\n 'failOffsetYStart',\n 'failOffsetYEnd',\n 'failOffsetXStart',\n 'failOffsetXEnd',\n] as const;\n\nexport type PanGestureHandlerEventPayload = {\n /**\n * X coordinate of the current position of the pointer (finger or a leading\n * pointer when there are multiple fingers placed) relative to the view\n * attached to the handler. Expressed in point units.\n */\n x: number;\n\n /**\n * Y coordinate of the current position of the pointer (finger or a leading\n * pointer when there are multiple fingers placed) relative to the view\n * attached to the handler. Expressed in point units.\n */\n y: number;\n\n /**\n * X coordinate of the current position of the pointer (finger or a leading\n * pointer when there are multiple fingers placed) relative to the window.\n * The value is expressed in point units. It is recommended to use it instead\n * of `x` in cases when the original view can be transformed as an effect of\n * the gesture.\n */\n absoluteX: number;\n\n /**\n * Y coordinate of the current position of the pointer (finger or a leading\n * pointer when there are multiple fingers placed) relative to the window.\n * The value is expressed in point units. It is recommended to use it instead\n * of `y` in cases when the original view can be transformed as an\n * effect of the gesture.\n */\n absoluteY: number;\n\n /**\n * Translation of the pan gesture along X axis accumulated over the time of\n * the gesture. The value is expressed in the point units.\n */\n translationX: number;\n\n /**\n * Translation of the pan gesture along Y axis accumulated over the time of\n * the gesture. The value is expressed in the point units.\n */\n translationY: number;\n\n /**\n * Velocity of the pan gesture along the X axis in the current moment. The\n * value is expressed in point units per second.\n */\n velocityX: number;\n\n /**\n * Velocity of the pan gesture along the Y axis in the current moment. The\n * value is expressed in point units per second.\n */\n velocityY: number;\n};\n\ninterface CommonPanProperties {\n /**\n * Minimum distance the finger (or multiple finger) need to travel before the\n * handler activates. Expressed in points.\n */\n minDist?: number;\n\n /**\n * Android only.\n */\n avgTouches?: boolean;\n\n /**\n * Enables two-finger gestures on supported devices, for example iPads with\n * trackpads. If not enabled the gesture will require click + drag, with\n * enableTrackpadTwoFingerGesture swiping with two fingers will also trigger\n * the gesture.\n */\n enableTrackpadTwoFingerGesture?: boolean;\n\n /**\n * A number of fingers that is required to be placed before handler can\n * activate. Should be a higher or equal to 0 integer.\n */\n minPointers?: number;\n\n /**\n * When the given number of fingers is placed on the screen and handler hasn't\n * yet activated it will fail recognizing the gesture. Should be a higher or\n * equal to 0 integer.\n */\n maxPointers?: number;\n\n minVelocity?: number;\n minVelocityX?: number;\n minVelocityY?: number;\n activateAfterLongPress?: number;\n}\n\nexport interface PanGestureConfig extends CommonPanProperties {\n activeOffsetYStart?: number;\n activeOffsetYEnd?: number;\n activeOffsetXStart?: number;\n activeOffsetXEnd?: number;\n failOffsetYStart?: number;\n failOffsetYEnd?: number;\n failOffsetXStart?: number;\n failOffsetXEnd?: number;\n}\n\nexport interface PanGestureHandlerProps\n extends BaseGestureHandlerProps,\n CommonPanProperties {\n /**\n * Range along X axis (in points) where fingers travels without activation of\n * handler. Moving outside of this range implies activation of handler. Range\n * can be given as an array or a single number. If range is set as an array,\n * first value must be lower or equal to 0, a the second one higher or equal\n * to 0. If only one number `p` is given a range of `(-inf, p)` will be used\n * if `p` is higher or equal to 0 and `(-p, inf)` otherwise.\n */\n activeOffsetY?: number | number[];\n\n /**\n * Range along X axis (in points) where fingers travels without activation of\n * handler. Moving outside of this range implies activation of handler. Range\n * can be given as an array or a single number. If range is set as an array,\n * first value must be lower or equal to 0, a the second one higher or equal\n * to 0. If only one number `p` is given a range of `(-inf, p)` will be used\n * if `p` is higher or equal to 0 and `(-p, inf)` otherwise.\n */\n activeOffsetX?: number | number[];\n\n /**\n * When the finger moves outside this range (in points) along Y axis and\n * handler hasn't yet activated it will fail recognizing the gesture. Range\n * can be given as an array or a single number. If range is set as an array,\n * first value must be lower or equal to 0, a the second one higher or equal\n * to 0. If only one number `p` is given a range of `(-inf, p)` will be used\n * if `p` is higher or equal to 0 and `(-p, inf)` otherwise.\n */\n failOffsetY?: number | number[];\n\n /**\n * When the finger moves outside this range (in points) along X axis and\n * handler hasn't yet activated it will fail recognizing the gesture. Range\n * can be given as an array or a single number. If range is set as an array,\n * first value must be lower or equal to 0, a the second one higher or equal\n * to 0. If only one number `p` is given a range of `(-inf, p)` will be used\n * if `p` is higher or equal to 0 and `(-p, inf)` otherwise.\n */\n failOffsetX?: number | number[];\n}\n\nexport const panHandlerName = 'PanGestureHandler';\n\nexport type PanGestureHandler = typeof PanGestureHandler;\n// eslint-disable-next-line @typescript-eslint/no-redeclare -- backward compatibility; see description on the top of gestureHandlerCommon.ts file\nexport const PanGestureHandler = createHandler<\n PanGestureHandlerProps,\n PanGestureHandlerEventPayload\n>({\n name: panHandlerName,\n allowedProps: [\n ...baseGestureHandlerProps,\n ...panGestureHandlerProps,\n ] as const,\n config: {},\n transformProps: managePanProps,\n customNativeProps: panGestureHandlerCustomNativeProps,\n});\n\nfunction validatePanGestureHandlerProps(props: PanGestureHandlerProps) {\n if (\n Array.isArray(props.activeOffsetX) &&\n (props.activeOffsetX[0] > 0 || props.activeOffsetX[1] < 0)\n ) {\n throw new Error(\n `First element of activeOffsetX should be negative, a the second one should be positive`\n );\n }\n\n if (\n Array.isArray(props.activeOffsetY) &&\n (props.activeOffsetY[0] > 0 || props.activeOffsetY[1] < 0)\n ) {\n throw new Error(\n `First element of activeOffsetY should be negative, a the second one should be positive`\n );\n }\n\n if (\n Array.isArray(props.failOffsetX) &&\n (props.failOffsetX[0] > 0 || props.failOffsetX[1] < 0)\n ) {\n throw new Error(\n `First element of failOffsetX should be negative, a the second one should be positive`\n );\n }\n\n if (\n Array.isArray(props.failOffsetY) &&\n (props.failOffsetY[0] > 0 || props.failOffsetY[1] < 0)\n ) {\n throw new Error(\n `First element of failOffsetY should be negative, a the second one should be positive`\n );\n }\n\n if (props.minDist && (props.failOffsetX || props.failOffsetY)) {\n throw new Error(\n `It is not supported to use minDist with failOffsetX or failOffsetY, use activeOffsetX and activeOffsetY instead`\n );\n }\n\n if (props.minDist && (props.activeOffsetX || props.activeOffsetY)) {\n throw new Error(\n `It is not supported to use minDist with activeOffsetX or activeOffsetY`\n );\n }\n}\n\nfunction transformPanGestureHandlerProps(props: PanGestureHandlerProps) {\n type InternalPanGHKeys =\n | 'activeOffsetXStart'\n | 'activeOffsetXEnd'\n | 'failOffsetXStart'\n | 'failOffsetXEnd'\n | 'activeOffsetYStart'\n | 'activeOffsetYEnd'\n | 'failOffsetYStart'\n | 'failOffsetYEnd';\n type PanGestureHandlerInternalProps = PanGestureHandlerProps &\n Partial>;\n\n const res: PanGestureHandlerInternalProps = { ...props };\n\n if (props.activeOffsetX !== undefined) {\n delete res.activeOffsetX;\n if (Array.isArray(props.activeOffsetX)) {\n res.activeOffsetXStart = props.activeOffsetX[0];\n res.activeOffsetXEnd = props.activeOffsetX[1];\n } else if (props.activeOffsetX < 0) {\n res.activeOffsetXStart = props.activeOffsetX;\n } else {\n res.activeOffsetXEnd = props.activeOffsetX;\n }\n }\n\n if (props.activeOffsetY !== undefined) {\n delete res.activeOffsetY;\n if (Array.isArray(props.activeOffsetY)) {\n res.activeOffsetYStart = props.activeOffsetY[0];\n res.activeOffsetYEnd = props.activeOffsetY[1];\n } else if (props.activeOffsetY < 0) {\n res.activeOffsetYStart = props.activeOffsetY;\n } else {\n res.activeOffsetYEnd = props.activeOffsetY;\n }\n }\n\n if (props.failOffsetX !== undefined) {\n delete res.failOffsetX;\n if (Array.isArray(props.failOffsetX)) {\n res.failOffsetXStart = props.failOffsetX[0];\n res.failOffsetXEnd = props.failOffsetX[1];\n } else if (props.failOffsetX < 0) {\n res.failOffsetXStart = props.failOffsetX;\n } else {\n res.failOffsetXEnd = props.failOffsetX;\n }\n }\n\n if (props.failOffsetY !== undefined) {\n delete res.failOffsetY;\n if (Array.isArray(props.failOffsetY)) {\n res.failOffsetYStart = props.failOffsetY[0];\n res.failOffsetYEnd = props.failOffsetY[1];\n } else if (props.failOffsetY < 0) {\n res.failOffsetYStart = props.failOffsetY;\n } else {\n res.failOffsetYEnd = props.failOffsetY;\n }\n }\n\n return res;\n}\n\nexport function managePanProps(props: PanGestureHandlerProps) {\n if (__DEV__) {\n validatePanGestureHandlerProps(props);\n }\n return transformPanGestureHandlerProps(props);\n}\n","import createHandler from './createHandler';\nimport {\n BaseGestureHandlerProps,\n baseGestureHandlerProps,\n} from './gestureHandlerCommon';\n\nexport const longPressGestureHandlerProps = [\n 'minDurationMs',\n 'maxDist',\n] as const;\n\nexport type LongPressGestureHandlerEventPayload = {\n /**\n * X coordinate, expressed in points, of the current position of the pointer\n * (finger or a leading pointer when there are multiple fingers placed)\n * relative to the view attached to the handler.\n */\n x: number;\n\n /**\n * Y coordinate, expressed in points, of the current position of the pointer\n * (finger or a leading pointer when there are multiple fingers placed)\n * relative to the view attached to the handler.\n */\n y: number;\n\n /**\n * X coordinate, expressed in points, of the current position of the pointer\n * (finger or a leading pointer when there are multiple fingers placed)\n * relative to the window. It is recommended to use `absoluteX` instead of\n * `x` in cases when the view attached to the handler can be transformed as an\n * effect of the gesture.\n */\n absoluteX: number;\n\n /**\n * Y coordinate, expressed in points, of the current position of the pointer\n * (finger or a leading pointer when there are multiple fingers placed)\n * relative to the window. It is recommended to use `absoluteY` instead of\n * `y` in cases when the view attached to the handler can be transformed as an\n * effect of the gesture.\n */\n absoluteY: number;\n\n /**\n * Duration of the long press (time since the start of the event), expressed\n * in milliseconds.\n */\n duration: number;\n};\n\nexport interface LongPressGestureConfig {\n /**\n * Minimum time, expressed in milliseconds, that a finger must remain pressed on\n * the corresponding view. The default value is 500.\n */\n minDurationMs?: number;\n\n /**\n * Maximum distance, expressed in points, that defines how far the finger is\n * allowed to travel during a long press gesture. If the finger travels\n * further than the defined distance and the handler hasn't yet activated, it\n * will fail to recognize the gesture. The default value is 10.\n */\n maxDist?: number;\n}\n\nexport interface LongPressGestureHandlerProps\n extends BaseGestureHandlerProps,\n LongPressGestureConfig {}\n\nexport const longPressHandlerName = 'LongPressGestureHandler';\n\nexport type LongPressGestureHandler = typeof LongPressGestureHandler;\n// eslint-disable-next-line @typescript-eslint/no-redeclare -- backward compatibility; see description on the top of gestureHandlerCommon.ts file\nexport const LongPressGestureHandler = createHandler<\n LongPressGestureHandlerProps,\n LongPressGestureHandlerEventPayload\n>({\n name: longPressHandlerName,\n allowedProps: [\n ...baseGestureHandlerProps,\n ...longPressGestureHandlerProps,\n ] as const,\n config: {\n shouldCancelWhenOutside: true,\n },\n});\n","export const TouchEventType = {\n UNDETERMINED: 0,\n TOUCHES_DOWN: 1,\n TOUCHES_MOVE: 2,\n TOUCHES_UP: 3,\n TOUCHES_CANCELLED: 4,\n} as const;\n\n// eslint-disable-next-line @typescript-eslint/no-redeclare -- backward compatibility; it can be used as a type and as a value\nexport type TouchEventType = typeof TouchEventType[keyof typeof TouchEventType];\n","import { ComponentClass } from 'react';\nimport {\n GestureUpdateEvent,\n GestureStateChangeEvent,\n} from '../gestureHandlerCommon';\nimport { tagMessage } from '../../utils';\n\nexport interface SharedValue {\n value: T;\n}\n\nlet Reanimated: {\n default: {\n // Slightly modified definition copied from 'react-native-reanimated'\n // eslint-disable-next-line @typescript-eslint/ban-types\n createAnimatedComponent

(\n component: ComponentClass

,\n options?: unknown\n ): ComponentClass

;\n };\n useEvent: (\n callback: (event: GestureUpdateEvent | GestureStateChangeEvent) => void,\n events: string[],\n rebuild: boolean\n ) => unknown;\n useSharedValue: (value: T) => SharedValue;\n setGestureState: (handlerTag: number, newState: number) => void;\n};\n\ntry {\n Reanimated = require('react-native-reanimated');\n\n if (!Reanimated.useSharedValue) {\n // @ts-ignore Make sure the loaded module is actually Reanimated, if it's not\n // reset the module to undefined so we can fallback to the default implementation\n Reanimated = undefined;\n throw new Error('react-native-reanimated is not found');\n }\n\n if (!Reanimated.setGestureState) {\n Reanimated.setGestureState = () => {\n 'worklet';\n console.warn(\n tagMessage(\n 'Please use newer version of react-native-reanimated in order to control state of the gestures.'\n )\n );\n };\n }\n // When 'react-native-reanimated' is not available we want to\n // quietly continue\n // eslint-disable-next-line no-empty\n} catch (e) {}\n\nexport { Reanimated };\n","import * as Animated from './Animated';\nimport webGlobalIsInitialized from './reanimated2/js-reanimated/global';\nif (!webGlobalIsInitialized) {\n /* \n `webGlobalIsInitialized` should always be `true`, \n but we need to use `webGlobalIsInitialized` somewhere to ensure function execution, \n in another way, the bundler can remove unused variables. \n */\n console.error('[Reanimated] Unable to initialize global objects for web.');\n}\n\nexport * from './reanimated2';\nexport default Animated;\n","export { default as createAnimatedComponent } from './createAnimatedComponent';\nexport {\n addWhitelistedNativeProps,\n addWhitelistedUIProps,\n} from './ConfigHelper';\n\nexport { default as Text } from './reanimated2/component/Text';\nexport { default as View } from './reanimated2/component/View';\nexport { default as ScrollView } from './reanimated2/component/ScrollView';\nexport { default as Image } from './reanimated2/component/Image';\nexport { default as FlatList } from './reanimated2/component/FlatList';\n","import { configureProps as jsiConfigureProps } from './reanimated2/core';\n\n/**\n * Styles allowed to be direcly updated in UI thread\n */\nlet UI_THREAD_PROPS_WHITELIST: Record = {\n opacity: true,\n transform: true,\n /* colors */\n backgroundColor: true,\n borderRightColor: true,\n borderBottomColor: true,\n borderColor: true,\n borderEndColor: true,\n borderLeftColor: true,\n borderStartColor: true,\n borderTopColor: true,\n /* ios styles */\n shadowOpacity: true,\n shadowRadius: true,\n /* legacy android transform properties */\n scaleX: true,\n scaleY: true,\n translateX: true,\n translateY: true,\n};\n\n/**\n * Whitelist of view props that can be updated in native thread via UIManagerModule\n */\nlet NATIVE_THREAD_PROPS_WHITELIST: Record = {\n borderBottomWidth: true,\n borderEndWidth: true,\n borderLeftWidth: true,\n borderRightWidth: true,\n borderStartWidth: true,\n borderTopWidth: true,\n borderWidth: true,\n bottom: true,\n flex: true,\n flexGrow: true,\n flexShrink: true,\n height: true,\n left: true,\n margin: true,\n marginBottom: true,\n marginEnd: true,\n marginHorizontal: true,\n marginLeft: true,\n marginRight: true,\n marginStart: true,\n marginTop: true,\n marginVertical: true,\n maxHeight: true,\n maxWidth: true,\n minHeight: true,\n minWidth: true,\n padding: true,\n paddingBottom: true,\n paddingEnd: true,\n paddingHorizontal: true,\n paddingLeft: true,\n paddingRight: true,\n paddingStart: true,\n paddingTop: true,\n paddingVertical: true,\n right: true,\n start: true,\n top: true,\n width: true,\n zIndex: true,\n borderBottomEndRadius: true,\n borderBottomLeftRadius: true,\n borderBottomRightRadius: true,\n borderBottomStartRadius: true,\n borderRadius: true,\n borderTopEndRadius: true,\n borderTopLeftRadius: true,\n borderTopRightRadius: true,\n borderTopStartRadius: true,\n elevation: true,\n fontSize: true,\n lineHeight: true,\n textShadowRadius: true,\n letterSpacing: true,\n /* strings */\n display: true,\n backfaceVisibility: true,\n overflow: true,\n resizeMode: true,\n fontStyle: true,\n fontWeight: true,\n textAlign: true,\n textDecorationLine: true,\n fontFamily: true,\n textAlignVertical: true,\n fontVariant: true,\n textDecorationStyle: true,\n textTransform: true,\n writingDirection: true,\n /* text color */\n color: true,\n tintColor: true,\n shadowColor: true,\n placeholderTextColor: true,\n};\n\nfunction configureProps(): void {\n jsiConfigureProps(\n Object.keys(UI_THREAD_PROPS_WHITELIST),\n Object.keys(NATIVE_THREAD_PROPS_WHITELIST)\n );\n}\n\nexport function addWhitelistedNativeProps(\n props: Record\n): void {\n const oldSize = Object.keys(NATIVE_THREAD_PROPS_WHITELIST).length;\n NATIVE_THREAD_PROPS_WHITELIST = {\n ...NATIVE_THREAD_PROPS_WHITELIST,\n ...props,\n };\n if (oldSize !== Object.keys(NATIVE_THREAD_PROPS_WHITELIST).length) {\n configureProps();\n }\n}\n\nexport function addWhitelistedUIProps(props: Record): void {\n const oldSize = Object.keys(UI_THREAD_PROPS_WHITELIST).length;\n UI_THREAD_PROPS_WHITELIST = { ...UI_THREAD_PROPS_WHITELIST, ...props };\n if (oldSize !== Object.keys(UI_THREAD_PROPS_WHITELIST).length) {\n configureProps();\n }\n}\n\nconst PROCESSED_VIEW_NAMES = new Set();\n\ninterface ViewConfig {\n uiViewClassName: string;\n validAttributes: Record;\n}\n/**\n * updates UI props whitelist for given view host instance\n * this will work just once for every view name\n */\n\nexport function adaptViewConfig(viewConfig: ViewConfig): void {\n const viewName = viewConfig.uiViewClassName;\n const props = viewConfig.validAttributes;\n\n // update whitelist of UI props for this view name only once\n if (!PROCESSED_VIEW_NAMES.has(viewName)) {\n const propsToAdd: Record = {};\n Object.keys(props).forEach((key) => {\n // we don't want to add native props as they affect layout\n // we also skip props which repeat here\n if (\n !(key in NATIVE_THREAD_PROPS_WHITELIST) &&\n !(key in UI_THREAD_PROPS_WHITELIST)\n ) {\n propsToAdd[key] = true;\n }\n });\n addWhitelistedUIProps(propsToAdd);\n\n PROCESSED_VIEW_NAMES.add(viewName);\n }\n}\n\nconfigureProps();\n","import NativeReanimatedModule from './NativeReanimated';\nimport { nativeShouldBeMock, shouldBeUseWeb, isWeb } from './PlatformChecker';\nimport { BasicWorkletFunction, Value3D, ValueRotation } from './commonTypes';\nimport {\n makeShareableCloneRecursive,\n makeShareable as makeShareableUnwrapped,\n} from './shareables';\nimport { startMapper as startMapperUnwrapped } from './mappers';\nimport {\n makeMutable as makeMutableUnwrapped,\n makeRemote as makeRemoteUnwrapped,\n} from './mutables';\nimport { LayoutAnimationFunction } from './layoutReanimation';\nimport { initializeUIRuntime } from './initializers';\n\nexport { stopMapper } from './mappers';\nexport { runOnJS, runOnUI } from './threads';\nexport { getTimestamp } from './time';\n\nexport type ReanimatedConsole = Pick<\n Console,\n 'debug' | 'log' | 'warn' | 'info' | 'error'\n>;\n\nconst testWorklet: BasicWorkletFunction = () => {\n 'worklet';\n};\n\nconst throwUninitializedReanimatedException = () => {\n throw new Error(\n \"Failed to initialize react-native-reanimated library, make sure you followed installation steps here: https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/installation/ \\n1) Make sure reanimated's babel plugin is installed in your babel.config.js (you should have 'react-native-reanimated/plugin' listed there - also see the above link for details) \\n2) Make sure you reset build cache after updating the config, run: yarn start --reset-cache\"\n );\n};\n\nexport const checkPluginState: (throwError: boolean) => boolean = (\n throwError = true\n) => {\n if (!testWorklet.__workletHash && !shouldBeUseWeb()) {\n if (throwError) {\n throwUninitializedReanimatedException();\n }\n return false;\n }\n return true;\n};\n\nexport const isConfigured: (throwError?: boolean) => boolean = (\n throwError = false\n) => {\n return checkPluginState(throwError);\n};\n\nexport const isConfiguredCheck: () => void = () => {\n checkPluginState(true);\n};\n\nconst configurationCheckWrapper = __DEV__\n ? , U>(fn: (...args: T) => U) => {\n return (...args: T): U => {\n isConfigured(true);\n return fn(...args);\n };\n }\n : , U>(fn: (...args: T) => U) => fn;\n\nexport const startMapper = __DEV__\n ? configurationCheckWrapper(startMapperUnwrapped)\n : startMapperUnwrapped;\n\nexport const makeShareable = __DEV__\n ? configurationCheckWrapper(makeShareableUnwrapped)\n : makeShareableUnwrapped;\n\nexport const makeMutable = __DEV__\n ? configurationCheckWrapper(makeMutableUnwrapped)\n : makeMutableUnwrapped;\n\nexport const makeRemote = __DEV__\n ? configurationCheckWrapper(makeRemoteUnwrapped)\n : makeRemoteUnwrapped;\n\nglobal._WORKLET = false;\nglobal._log = function (s: string) {\n console.log(s);\n};\n\nexport function getViewProp(viewTag: string, propName: string): Promise {\n if (global._IS_FABRIC) {\n throw new Error(\n '[react-native-reanimated] `getViewProp` is not supported on Fabric yet'\n );\n }\n\n return new Promise((resolve, reject) => {\n return NativeReanimatedModule.getViewProp(\n viewTag,\n propName,\n (result: T) => {\n if (typeof result === 'string' && result.substr(0, 6) === 'error:') {\n reject(result);\n } else {\n resolve(result);\n }\n }\n );\n });\n}\n\nexport function registerEventHandler(\n eventHash: string,\n eventHandler: (event: T) => void\n): string {\n return NativeReanimatedModule.registerEventHandler(\n eventHash,\n makeShareableCloneRecursive(eventHandler)\n );\n}\n\nexport function unregisterEventHandler(id: string): void {\n return NativeReanimatedModule.unregisterEventHandler(id);\n}\n\nexport function subscribeForKeyboardEvents(\n eventHandler: (state: number, height: number) => void\n): number {\n return NativeReanimatedModule.subscribeForKeyboardEvents(\n makeShareableCloneRecursive(eventHandler)\n );\n}\n\nexport function unsubscribeFromKeyboardEvents(listenerId: number): void {\n return NativeReanimatedModule.unsubscribeFromKeyboardEvents(listenerId);\n}\n\nexport function registerSensor(\n sensorType: number,\n interval: number,\n eventHandler: (data: Value3D | ValueRotation) => void\n): number {\n return NativeReanimatedModule.registerSensor(\n sensorType,\n interval,\n makeShareableCloneRecursive(eventHandler)\n );\n}\n\nexport function unregisterSensor(listenerId: number): void {\n return NativeReanimatedModule.unregisterSensor(listenerId);\n}\n\n// initialize UI runtime if applicable\nif (!isWeb() && isConfigured()) {\n initializeUIRuntime();\n}\n\ntype FeaturesConfig = {\n enableLayoutAnimations: boolean;\n setByUser: boolean;\n};\n\nlet featuresConfig: FeaturesConfig = {\n enableLayoutAnimations: false,\n setByUser: false,\n};\n\nexport function enableLayoutAnimations(\n flag: boolean,\n isCallByUser = true\n): void {\n if (isCallByUser) {\n featuresConfig = {\n enableLayoutAnimations: flag,\n setByUser: true,\n };\n NativeReanimatedModule.enableLayoutAnimations(flag);\n } else if (\n !featuresConfig.setByUser &&\n featuresConfig.enableLayoutAnimations !== flag\n ) {\n featuresConfig.enableLayoutAnimations = flag;\n NativeReanimatedModule.enableLayoutAnimations(flag);\n }\n}\n\nexport function configureLayoutAnimations(\n viewTag: number,\n type: string,\n config: LayoutAnimationFunction | Keyframe\n): void {\n NativeReanimatedModule.configureLayoutAnimation(\n viewTag,\n type,\n makeShareableCloneRecursive(config)\n );\n}\n\nexport function configureProps(uiProps: string[], nativeProps: string[]): void {\n if (!nativeShouldBeMock()) {\n NativeReanimatedModule.configureProps(uiProps, nativeProps);\n }\n}\n","import NativeReanimatedModule from './NativeReanimated';\nimport { Platform } from 'react-native';\nimport { nativeShouldBeMock } from './PlatformChecker';\nexport { stopMapper } from './mappers';\n\nlet _getTimestamp: () => number;\nif (nativeShouldBeMock()) {\n _getTimestamp = () => {\n return NativeReanimatedModule.getTimestamp();\n };\n} else {\n _getTimestamp = () => {\n 'worklet';\n if (_frameTimestamp) {\n return _frameTimestamp;\n }\n if (_eventTimestamp) {\n return _eventTimestamp;\n }\n return _getCurrentTime();\n };\n}\n\nexport function getTimestamp(): number {\n 'worklet';\n if (Platform.OS === 'web') {\n return NativeReanimatedModule.getTimestamp();\n }\n return _getTimestamp();\n}\n","import { SharedValue } from './commonTypes';\nimport { runOnUI } from './threads';\n\nexport type Mapper = {\n id: number;\n dirty: boolean;\n worklet: () => void;\n inputs: SharedValue[];\n outputs?: SharedValue[];\n};\n\nexport function createMapperRegistry() {\n 'worklet';\n const mappers = new Map();\n let sortedMappers: Mapper[] = [];\n\n let frameRequested = false;\n\n function updateMappersOrder() {\n // sort mappers topologically\n // the algorithm here takes adventage of a fact that the topological order\n // of a transposed graph is a reverse topological order of the original graph\n // The graph in our case consists of mappers and an edge between two mappers\n // A and B exists if there is a shared value that's on A's output lists and on\n // B's input list.\n //\n // We don't need however to calculate that graph as it is easier to work with\n // the transposed version of it that can be calculated ad-hoc. For the transposed\n // version to be traversed we use \"pre\" map that maps share value to mappers that\n // output that shared value. Then we can infer all the outgoing edges for a given\n // mapper simply by scanning it's input list and checking if any of the shared values\n // from that list exists in the \"pre\" map. If they do, then we have an edge between\n // that mapper and the mappers from the \"pre\" list for the given shared value.\n //\n // For topological sorting we use a dfs-based approach that requires the graph to\n // be traversed in dfs order and each node after being processed lands at the\n // beginning of the topological order list. Since we traverse a transposed graph,\n // instead of reversing that order we can use a normal array and push processed\n // mappers to the end. There is no need to reverse that array after we are done.\n const pre = new Map(); // map from sv -> mapper that outputs that sv\n mappers.forEach((mapper) => {\n if (mapper.outputs) {\n for (const output of mapper.outputs) {\n const preMappers = pre.get(output);\n if (preMappers === undefined) {\n pre.set(output, [mapper]);\n } else {\n preMappers.push(mapper);\n }\n }\n }\n });\n const visited = new Set();\n const newOrder: Mapper[] = [];\n function dfs(mapper: Mapper) {\n visited.add(mapper);\n for (const input of mapper.inputs) {\n const preMappers = pre.get(input);\n if (preMappers) {\n for (const preMapper of preMappers) {\n if (!visited.has(preMapper)) {\n dfs(preMapper);\n }\n }\n }\n }\n newOrder.push(mapper);\n }\n mappers.forEach((mapper) => {\n if (!visited.has(mapper)) {\n dfs(mapper);\n }\n });\n sortedMappers = newOrder;\n }\n\n function mapperFrame() {\n frameRequested = false;\n if (mappers.size !== sortedMappers.length) {\n updateMappersOrder();\n }\n for (const mapper of sortedMappers) {\n if (mapper.dirty) {\n mapper.dirty = false;\n mapper.worklet();\n }\n }\n }\n\n function maybeRequestUpdates() {\n if (!frameRequested) {\n requestAnimationFrame(mapperFrame);\n frameRequested = true;\n }\n }\n\n function extractInputs(\n inputs: any,\n resultArray: SharedValue[]\n ): SharedValue[] {\n if (Array.isArray(inputs)) {\n for (const input of inputs) {\n input && extractInputs(input, resultArray);\n }\n } else if (inputs.addListener) {\n resultArray.push(inputs);\n } else if (typeof inputs === 'object') {\n for (const element of Object.values(inputs)) {\n element && extractInputs(element, resultArray);\n }\n }\n return resultArray;\n }\n\n return {\n start: (\n mapperID: number,\n worklet: () => void,\n inputs: SharedValue[],\n outputs?: SharedValue[]\n ) => {\n const mapper = {\n id: mapperID,\n dirty: true,\n worklet,\n inputs: extractInputs(inputs, []),\n outputs,\n };\n mappers.set(mapper.id, mapper);\n sortedMappers = [];\n for (const sv of mapper.inputs) {\n sv.addListener(mapper.id, () => {\n mapper.dirty = true;\n maybeRequestUpdates();\n });\n }\n maybeRequestUpdates();\n },\n stop: (mapperID: number) => {\n const mapper = mappers.get(mapperID);\n if (mapper) {\n mappers.delete(mapper.id);\n sortedMappers = [];\n for (const sv of mapper.inputs) {\n sv.removeListener(mapper.id);\n }\n }\n },\n };\n}\n\nlet MAPPER_ID = 9999;\n\nexport function startMapper(\n worklet: () => void,\n inputs: any[] = [],\n outputs: any[] = []\n): number {\n const mapperID = (MAPPER_ID += 1);\n\n runOnUI(() => {\n 'worklet';\n let mapperRegistry = global.__mapperRegistry;\n if (mapperRegistry === undefined) {\n mapperRegistry = global.__mapperRegistry = createMapperRegistry();\n }\n mapperRegistry.start(mapperID, worklet, inputs, outputs);\n })();\n\n return mapperID;\n}\n\nexport function stopMapper(mapperID: number): void {\n runOnUI(() => {\n 'worklet';\n const mapperRegistry = global.__mapperRegistry;\n mapperRegistry?.stop(mapperID);\n })();\n}\n","import NativeReanimatedModule from './NativeReanimated';\nimport { ComplexWorkletFunction } from './commonTypes';\nimport {\n makeShareableCloneOnUIRecursive,\n makeShareableCloneRecursive,\n} from './shareables';\n\nexport function runOnUI(\n worklet: ComplexWorkletFunction\n): (...args: A) => void {\n if (__DEV__) {\n if (worklet.__workletHash === undefined) {\n throw new Error('runOnUI() can only be used on worklets');\n }\n }\n return (...args) => {\n NativeReanimatedModule.scheduleOnUI(\n makeShareableCloneRecursive(() => {\n 'worklet';\n return worklet(...args);\n })\n );\n };\n}\n\nif (__DEV__) {\n try {\n runOnUI(() => {\n 'worklet';\n });\n } catch (e) {\n throw new Error(\n 'Failed to create a worklet. Did you forget to add Reanimated Babel plugin in babel.config.js? See installation docs at https://docs.swmansion.com/react-native-reanimated/docs/fundamentals/installation#babel-plugin.'\n );\n }\n}\n\nexport function runOnJS(\n fun: ComplexWorkletFunction\n): (...args: A) => void {\n 'worklet';\n if (fun.__remoteFunction) {\n // in development mode the function provided as `fun` throws an error message\n // such that when someone accidently calls it directly on the UI runtime, they\n // see that they should use `runOnJS` instead. To facilitate that we purt the\n // reference to the original remote function in the `__remoteFunction` property.\n fun = fun.__remoteFunction;\n }\n if (!_WORKLET) {\n return fun;\n }\n return (...args) => {\n _scheduleOnJS(\n fun,\n args.length > 0 ? makeShareableCloneOnUIRecursive(args) : undefined\n );\n };\n}\n","import reanimatedJS from '../js-reanimated';\nimport { shouldBeUseWeb } from '../PlatformChecker';\nimport { NativeReanimated } from './NativeReanimated';\n\nlet exportedModule;\nif (shouldBeUseWeb()) {\n exportedModule = reanimatedJS;\n} else {\n exportedModule = new NativeReanimated();\n}\n\nexport default exportedModule as NativeReanimated;\n","import JSReanimated from './JSReanimated';\nimport { AnimatedStyle, StyleProps } from '../commonTypes';\n\nconst reanimatedJS = new JSReanimated();\n\nglobal._makeShareableClone = (c) => c;\nglobal._scheduleOnJS = setImmediate;\nglobal._getTimestamp = reanimatedJS.getTimestamp.bind(reanimatedJS);\n\ninterface JSReanimatedComponent {\n previousStyle: StyleProps;\n setNativeProps: (style: StyleProps) => void;\n props: Record;\n _touchableNode: {\n setAttribute: (key: string, props: unknown) => void;\n };\n}\n\nexport const _updatePropsJS = (\n updates: StyleProps | AnimatedStyle,\n viewRef: { _component?: JSReanimatedComponent }\n): void => {\n if (viewRef._component) {\n const component = viewRef._component;\n const [rawStyles] = Object.keys(updates).reduce(\n (acc: [StyleProps, AnimatedStyle], key) => {\n const value = updates[key];\n const index = typeof value === 'function' ? 1 : 0;\n acc[index][key] = value;\n return acc;\n },\n [{}, {}]\n );\n\n if (typeof component.setNativeProps === 'function') {\n setNativeProps(component, rawStyles);\n } else if (Object.keys(component.props).length > 0) {\n Object.keys(component.props).forEach((key) => {\n if (!rawStyles[key]) {\n return;\n }\n const dashedKey = key.replace(/[A-Z]/g, (m) => '-' + m.toLowerCase());\n component._touchableNode.setAttribute(dashedKey, rawStyles[key]);\n });\n } else {\n console.warn('It is not possible to manipulate component');\n }\n }\n};\n\nconst setNativeProps = (\n component: JSReanimatedComponent,\n style: StyleProps\n): void => {\n const previousStyle = component.previousStyle ? component.previousStyle : {};\n const currentStyle = { ...previousStyle, ...style };\n component.previousStyle = currentStyle;\n component.setNativeProps({ style: currentStyle });\n};\n\nexport default reanimatedJS;\n","import { NativeReanimated } from '../NativeReanimated/NativeReanimated';\nimport { ShareableRef } from '../commonTypes';\nimport { isJest } from '../PlatformChecker';\n\nexport default class JSReanimated extends NativeReanimated {\n constructor() {\n super(false);\n if (isJest()) {\n // on node < 16 jest have problems mocking performance.now method which\n // results in the tests failing, since date precision isn't that important\n // for tests, we use Date.now instead\n this.getTimestamp = () => Date.now();\n } else {\n this.getTimestamp = () => window.performance.now();\n }\n }\n\n makeShareableClone(value: T): ShareableRef {\n return { __hostObjectShareableJSRef: value };\n }\n\n installCoreFunctions(\n _callGuard: , U>(\n fn: (...args: T) => U,\n ...args: T\n ) => void,\n _valueUnpacker: (value: T) => T\n ): void {\n // noop\n }\n\n scheduleOnUI(worklet: ShareableRef) {\n // @ts-ignore web implementation has still not been updated after the rewrite, this will be addressed once the web implementation updates are ready\n requestAnimationFrame(worklet);\n }\n\n registerEventHandler(\n _eventHash: string,\n _eventHandler: ShareableRef\n ): string {\n // noop\n return '';\n }\n\n unregisterEventHandler(_: string): void {\n // noop\n }\n\n enableLayoutAnimations() {\n console.warn(\n '[Reanimated] enableLayoutAnimations is not available for WEB yet'\n );\n }\n\n registerSensor(): number {\n console.warn('[Reanimated] useAnimatedSensor is not available on web yet.');\n return -1;\n }\n\n unregisterSensor(): void {\n // noop\n }\n\n subscribeForKeyboardEvents(_: ShareableRef): number {\n console.warn(\n '[Reanimated] useAnimatedKeyboard is not available on web yet.'\n );\n return -1;\n }\n\n unsubscribeFromKeyboardEvents(_: number): void {\n // noop\n }\n}\n","import { Platform } from 'react-native';\n\nexport function isJest(): boolean {\n return !!process.env.JEST_WORKER_ID;\n}\n\nexport function isChromeDebugger(): boolean {\n return !(global as any).nativeCallSyncHook || (global as any).__REMOTEDEV__;\n}\n\nexport function isWeb(): boolean {\n return Platform.OS === 'web';\n}\n\nexport function shouldBeUseWeb() {\n return isJest() || isChromeDebugger() || isWeb();\n}\n\nexport function nativeShouldBeMock() {\n return isJest() || isChromeDebugger();\n}\n","import { NativeModules } from 'react-native';\nimport { ShareableRef, ShareableSyncDataHolderRef } from '../commonTypes';\nimport { LayoutAnimationFunction } from '../layoutReanimation';\nimport { checkVersion } from '../platform-specific/checkVersion';\n\nexport class NativeReanimated {\n native: boolean;\n private InnerNativeModule: any;\n\n constructor(native = true) {\n if (global.__reanimatedModuleProxy === undefined && native) {\n const { ReanimatedModule } = NativeModules;\n ReanimatedModule?.installTurboModule();\n }\n this.InnerNativeModule = global.__reanimatedModuleProxy;\n this.native = native;\n if (native) {\n checkVersion();\n }\n }\n\n getTimestamp(): number {\n throw new Error('stub implementation, used on the web only');\n }\n\n installCoreFunctions(\n callGuard: , U>(\n fn: (...args: T) => U,\n ...args: T\n ) => void,\n valueUnpacker: (value: T) => T\n ): void {\n return this.InnerNativeModule.installCoreFunctions(\n callGuard,\n valueUnpacker\n );\n }\n\n makeShareableClone(value: T): ShareableRef {\n return this.InnerNativeModule.makeShareableClone(value);\n }\n\n makeSynchronizedDataHolder(\n valueRef: ShareableRef\n ): ShareableSyncDataHolderRef {\n return this.InnerNativeModule.makeSynchronizedDataHolder(valueRef);\n }\n\n getDataSynchronously(ref: ShareableSyncDataHolderRef): T {\n return this.InnerNativeModule.getDataSynchronously(ref);\n }\n\n updateDataSynchronously(\n ref: ShareableSyncDataHolderRef,\n value: T\n ): void {\n this.InnerNativeModule.updateDataSynchronously(ref, value);\n }\n\n scheduleOnUI(shareable: ShareableRef) {\n return this.InnerNativeModule.scheduleOnUI(shareable);\n }\n\n registerSensor(\n sensorType: number,\n interval: number,\n handler: ShareableRef\n ) {\n return this.InnerNativeModule.registerSensor(sensorType, interval, handler);\n }\n\n unregisterSensor(sensorId: number) {\n return this.InnerNativeModule.unregisterSensor(sensorId);\n }\n\n registerEventHandler(\n eventHash: string,\n eventHandler: ShareableRef\n ): string {\n return this.InnerNativeModule.registerEventHandler(eventHash, eventHandler);\n }\n\n unregisterEventHandler(id: string): void {\n return this.InnerNativeModule.unregisterEventHandler(id);\n }\n\n getViewProp(\n viewTag: string,\n propName: string,\n callback?: (result: T) => void\n ): Promise {\n return this.InnerNativeModule.getViewProp(viewTag, propName, callback);\n }\n\n configureLayoutAnimation(\n viewTag: number,\n type: string,\n config: ShareableRef\n ) {\n this.InnerNativeModule.configureLayoutAnimation(viewTag, type, config);\n }\n\n enableLayoutAnimations(flag: boolean): void {\n this.InnerNativeModule.enableLayoutAnimations(flag);\n }\n\n configureProps(uiProps: string[], nativeProps: string[]): void {\n this.InnerNativeModule.configureProps(uiProps, nativeProps);\n }\n\n subscribeForKeyboardEvents(handler: ShareableRef): number {\n return this.InnerNativeModule.subscribeForKeyboardEvents(handler);\n }\n\n unsubscribeFromKeyboardEvents(listenerId: number): void {\n this.InnerNativeModule.unsubscribeFromKeyboardEvents(listenerId);\n }\n}\n","import { version as jsVersion } from '../../../package.json';\n\n/**\n * Checks that native and js versions of reanimated match.\n */\nexport function checkVersion(): void {\n const cppVersion = global._REANIMATED_VERSION_CPP;\n const ok = (() => {\n if (\n jsVersion.match(/^\\d+\\.\\d+\\.\\d+$/) &&\n cppVersion.match(/^\\d+\\.\\d+\\.\\d+$/)\n ) {\n // x.y.z, compare only major and minor, skip patch\n const [jsMajor, jsMinor] = jsVersion.split('.');\n const [cppMajor, cppMinor] = cppVersion.split('.');\n return jsMajor === cppMajor && jsMinor === cppMinor;\n } else {\n // alpha, beta or rc, compare everything\n return jsVersion === cppVersion;\n }\n })();\n if (!ok) {\n console.error(\n `[Reanimated] Mismatch between JavaScript part and native part of Reanimated (${jsVersion} vs. ${cppVersion}). Did you forget to re-build the app after upgrading react-native-reanimated? If you use Expo Go, you must downgrade to ${cppVersion} which is bundled into Expo SDK.`\n );\n // TODO: detect Expo managed workflow\n }\n}\n","{\n \"name\": \"react-native-reanimated\",\n \"version\": \"3.0.0-rc.10\",\n \"description\": \"More powerful alternative to Animated library for React Native.\",\n \"scripts\": {\n \"test\": \"yarn run format:js && yarn run lint:js && yarn run test:unit\",\n \"test:unit\": \"jest\",\n \"lint\": \"yarn lint:js && yarn lint:cpp && yarn lint:java && yarn lint:ios && yarn lint:docs\",\n \"lint:js\": \"eslint --ext '.js,.ts,.tsx' src/ && yarn prettier --check src/\",\n \"lint:docs\": \"cd docs && yarn lint && cd ..\",\n \"lint:java\": \"./android/gradlew -p android spotlessCheck -q\",\n \"lint:cpp\": \"./scripts/cpplint.sh\",\n \"lint:ios\": \"./scripts/validate-ios.sh && yarn format:ios --dry-run\",\n \"format\": \"yarn format:js && yarn format:java && yarn format:ios && yarn format:android && yarn format:common\",\n \"format:js\": \"prettier --write --list-different './src/'\",\n \"format:java\": \"node ./scripts/format-java.js\",\n \"format:ios\": \"find ios/ -iname *.h -o -iname *.m -o -iname *.mm -o -iname *.cpp | xargs clang-format -i --Werror\",\n \"format:android\": \"find android/src/ -iname *.h -o -iname *.cpp | xargs clang-format -i\",\n \"format:common\": \"find Common/ -iname *.h -o -iname *.cpp | xargs clang-format -i\",\n \"release\": \"npm login && release-it\",\n \"type:check\": \"yarn tsc --noEmit\",\n \"prepare\": \"bob build && husky install\",\n \"circular_dependency_check\": \"yarn madge --extensions js,ts,tsx --circular src lib\",\n \"setup\": \"yarn && cd Example && yarn && cd ios && pod install --verbose && cd ../..\",\n \"clean\": \"rm -rf node_modules && cd Example && rm -rf node_modules && cd ios && pod deintegrate && cd ../..\",\n \"reset\": \"yarn clean && yarn setup\",\n \"clean:deep\": \"cd android && rm -rf .cxx .gradle build && cd ../Example/android && rm -rf .gradle build app/build && cd ../.. && yarn clean\",\n \"reset:deep\": \"yarn clean:deep && yarn setup\"\n },\n \"main\": \"lib/commonjs/index\",\n \"module\": \"lib/module/index\",\n \"react-native\": \"src/index\",\n \"source\": \"src/index\",\n \"types\": \"react-native-reanimated.d.ts\",\n \"files\": [\n \"Common/\",\n \"src/\",\n \"lib/\",\n \"!**/__tests__\",\n \"!**/__fixtures__\",\n \"!**/__mocks__\",\n \"!lib/typescript\",\n \"react-native-reanimated.d.ts\",\n \"android/src/main/AndroidManifest.xml\",\n \"android/src/main/java/\",\n \"android/build.gradle\",\n \"android/\",\n \"ios/\",\n \"!ios/build/\",\n \"!android/build/\",\n \"!android/.cxx/\",\n \"!android/.gradle/\",\n \"RNReanimated.podspec\",\n \"scripts/reanimated_utils.rb\",\n \"README.md\",\n \"mock.js\",\n \"plugin.js\",\n \"!__snapshots__\",\n \"!*.test.js\",\n \"!*.test.js.map\"\n ],\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"git+https://github.com/software-mansion/react-native-reanimated.git\"\n },\n \"author\": {\n \"email\": \"krzys.magiera@gmail.com\",\n \"name\": \"Krzysztof Magiera\"\n },\n \"license\": \"MIT\",\n \"readmeFilename\": \"README.md\",\n \"bugs\": {\n \"url\": \"https://github.com/software-mansion/react-native-reanimated/issues\"\n },\n \"homepage\": \"https://github.com/software-mansion/react-native-reanimated#readme\",\n \"dependencies\": {\n \"@babel/plugin-transform-object-assign\": \"^7.16.7\",\n \"@babel/preset-typescript\": \"^7.16.7\",\n \"convert-source-map\": \"^1.7.0\",\n \"invariant\": \"^2.2.4\",\n \"lodash.isequal\": \"^4.5.0\",\n \"setimmediate\": \"^1.0.5\",\n \"string-hash-64\": \"^1.0.3\"\n },\n \"peerDependencies\": {\n \"@babel/core\": \"^7.0.0-0\",\n \"react\": \"*\",\n \"react-native\": \"*\"\n },\n \"devDependencies\": {\n \"@babel/cli\": \"^7.17.6\",\n \"@babel/core\": \"^7.17.5\",\n \"@babel/plugin-proposal-class-properties\": \"^7.16.7\",\n \"@babel/plugin-proposal-optional-chaining\": \"^7.16.7\",\n \"@babel/preset-env\": \"^7.16.11\",\n \"@react-native-community/eslint-config\": \"^0.0.5\",\n \"@testing-library/jest-native\": \"^4.0.4\",\n \"@testing-library/react-hooks\": \"^8.0.0\",\n \"@testing-library/react-native\": \"^7.1.0\",\n \"@types/babel-types\": \"^7.0.11\",\n \"@types/babel__core\": \"^7.1.18\",\n \"@types/babel__generator\": \"^7.6.4\",\n \"@types/babel__traverse\": \"^7.14.2\",\n \"@types/invariant\": \"^2.2.35\",\n \"@types/jest\": \"^27.4.0\",\n \"@types/react\": \"^18.0.26\",\n \"@typescript-eslint/eslint-plugin\": \"^5.11.0\",\n \"@typescript-eslint/parser\": \"^5.11.0\",\n \"babel-eslint\": \"^10.1.0\",\n \"babel-jest\": \"^27.5.1\",\n \"babel-plugin-module-resolver\": \"^4.1.0\",\n \"clang-format\": \"^1.6.0\",\n \"eslint\": \"^8.8.0\",\n \"eslint-config-prettier\": \"^8.3.0\",\n \"eslint-config-standard\": \"^16.0.3\",\n \"eslint-import-resolver-babel-module\": \"^5.3.1\",\n \"eslint-plugin-import\": \"^2.25.4\",\n \"eslint-plugin-node\": \"^11.1.0\",\n \"eslint-plugin-promise\": \"^6.0.0\",\n \"eslint-plugin-standard\": \"^5.0.0\",\n \"husky\": \"^7.0.4\",\n \"jest\": \"^27.5.1\",\n \"lint-staged\": \"^11.2.0\",\n \"madge\": \"^5.0.1\",\n \"prettier\": \"^2.5.1\",\n \"react\": \"17.0.2\",\n \"react-native\": \"0.71.0-rc.5\",\n \"react-native-builder-bob\": \"^0.18.3\",\n \"react-native-gesture-handler\": \"^2.4.2\",\n \"react-test-renderer\": \"17.0.2\",\n \"release-it\": \"^13.7.2\",\n \"typescript\": \"^4.1.3\"\n },\n \"lint-staged\": {\n \"*.(js|ts|tsx)\": [\n \"eslint --ext '.js,.ts,.tsx' src/ --ignore-pattern src/reanimated1 --ignore-pattern react-native-reanimated.d.ts --ignore-pattern docs\",\n \"prettier --write\"\n ],\n \"**/*.{h,cpp}\": \"yarn lint:cpp\",\n \"android/src/**/*.java\": \"yarn format:java\",\n \"android/src/**/*.{h,cpp}\": \"yarn format:android\",\n \"ios/**/*.{h,m,mm,cpp}\": \"yarn format:ios\",\n \"Common/**/*.{h,cpp}\": \"yarn format:common\",\n \"docs/**/*.{md,mdx}\": \"yarn lint:docs\"\n },\n \"release-it\": {\n \"hooks\": {\n \"before:git:bump\": [\n \"# check if version corresponds to changes in native files \\n if git diff --name-only ${latestVersion} HEAD | egrep '(android/.*)|(ios/.*)' -q ; then egrep '\\\\.0$' -q <<< ${version} ; else true ; fi ;\"\n ]\n }\n },\n \"react-native-builder-bob\": {\n \"source\": \"src\",\n \"output\": \"lib\",\n \"targets\": [\n \"commonjs\",\n \"module\",\n [\n \"typescript\",\n {\n \"project\": \"tsconfig.json\"\n }\n ]\n ]\n },\n \"sideEffects\": [\n \"./lib/reanimated2/core\",\n \"./lib/reanimated2/js-reanimated/global\",\n \"./lib/index\"\n ]\n}\n","import NativeReanimatedModule from './NativeReanimated';\nimport { ShareableRef } from './commonTypes';\nimport { shouldBeUseWeb } from './PlatformChecker';\nimport { registerWorkletStackDetails } from './errors';\n\n// for web/chrome debugger/jest environments this file provides a stub implementation\n// where no shareable references are used. Instead, the objects themselves are used\n// instead of shareable references, because of the fact that we don't have to deal with\n// runnning the code on separate VMs.\nconst USE_STUB_IMPLEMENTATION = shouldBeUseWeb();\n\nconst _shareableCache = new WeakMap<\n Record,\n ShareableRef | symbol\n>();\n// the below symbol is used to represent a mapping from the value to itself\n// this is used to allow for a converted shareable to be passed to makeShareableClone\nconst _shareableFlag = Symbol('shareable flag');\n\nexport function registerShareableMapping(\n shareable: any,\n shareableRef?: ShareableRef\n): void {\n if (USE_STUB_IMPLEMENTATION) {\n return;\n }\n _shareableCache.set(shareable, shareableRef || _shareableFlag);\n}\n\nexport function makeShareableShadowNodeWrapper(shadowNodeWrapper: T): T {\n const adoptedSNW =\n NativeReanimatedModule.makeShareableClone(shadowNodeWrapper);\n registerShareableMapping(shadowNodeWrapper, adoptedSNW);\n return shadowNodeWrapper;\n}\n\nexport function makeShareableCloneRecursive(value: any): ShareableRef {\n if (USE_STUB_IMPLEMENTATION) {\n return value;\n }\n // This one actually may be worth to be moved to c++, we also need similar logic to run on the UI thread\n const type = typeof value;\n if ((type === 'object' || type === 'function') && value !== null) {\n const cached = _shareableCache.get(value);\n if (cached === _shareableFlag) {\n return value;\n } else if (cached !== undefined) {\n return cached as ShareableRef;\n } else {\n let toAdapt: any;\n if (Array.isArray(value)) {\n toAdapt = value.map((element) => makeShareableCloneRecursive(element));\n } else if (type === 'function' && value.__workletHash === undefined) {\n // this is a remote function\n toAdapt = value;\n } else {\n if (__DEV__ && value.__workletHash !== undefined) {\n registerWorkletStackDetails(\n value.__workletHash,\n value.__stackDetails\n );\n }\n toAdapt = {};\n for (const [key, element] of Object.entries(value)) {\n toAdapt[key] = makeShareableCloneRecursive(element);\n }\n }\n if (__DEV__) {\n // we freeze objects that are transformed to shareable. This should help\n // detect issues when someone modifies data after it's been converted to\n // shareable. Meaning that they may be doing a faulty assumption in their\n // code expecting that the updates are going to automatically populate to\n // the object sent to the UI thread. If the user really wants some objects\n // to be mutable they should use share values instead.\n Object.freeze(value);\n }\n const adopted = NativeReanimatedModule.makeShareableClone(toAdapt);\n _shareableCache.set(value, adopted);\n _shareableCache.set(adopted, _shareableFlag);\n return adopted;\n }\n }\n return NativeReanimatedModule.makeShareableClone(value);\n}\n\nexport function makeShareableCloneOnUIRecursive(value: T): ShareableRef {\n 'worklet';\n if (USE_STUB_IMPLEMENTATION) {\n // @ts-ignore web is an interesting place where we don't run a secondary VM on the UI thread\n // see more details in the comment where USE_STUB_IMPLEMENTATION is defined.\n return value;\n }\n function cloneRecursive(value: T): ShareableRef {\n const type = typeof value;\n if ((type === 'object' || type === 'function') && value !== null) {\n let toAdapt: any;\n if (Array.isArray(value)) {\n toAdapt = value.map((element) => cloneRecursive(element));\n } else {\n toAdapt = {};\n for (const [key, element] of Object.entries(value)) {\n toAdapt[key] = cloneRecursive(element);\n }\n }\n if (__DEV__) {\n // See the reasoning behind freezing in the other comment above.\n Object.freeze(value);\n }\n return _makeShareableClone(toAdapt);\n }\n return _makeShareableClone(value);\n }\n return cloneRecursive(value);\n}\n\nexport function makeShareable(value: T): T {\n if (USE_STUB_IMPLEMENTATION) {\n return value;\n }\n const handle = makeShareableCloneRecursive({\n __init: () => {\n 'worklet';\n return value;\n },\n });\n registerShareableMapping(value, handle);\n return value;\n}\n","import NativeReanimatedModule from './NativeReanimated';\nimport { SharedValue, ShareableSyncDataHolderRef } from './commonTypes';\nimport {\n makeShareableCloneOnUIRecursive,\n makeShareableCloneRecursive,\n registerShareableMapping,\n} from './shareables';\nimport { runOnUI } from './threads';\nimport { valueSetter } from './valueSetter';\nexport { stopMapper } from './mappers';\n\nexport function makeUIMutable(\n initial: T,\n syncDataHolder?: ShareableSyncDataHolderRef\n) {\n 'worklet';\n\n const listeners = new Map();\n let value = initial;\n\n const self = {\n set value(newValue) {\n valueSetter(self, newValue);\n },\n get value() {\n return value;\n },\n /**\n * _value prop should only be accessed by the valueSetter implementation\n * which may make the decision about updating the mutable value depending\n * on the provided new value. All other places should only attempt to modify\n * the mutable by assigning to value prop directly.\n */\n set _value(newValue: T) {\n value = newValue;\n if (syncDataHolder) {\n _updateDataSynchronously(\n syncDataHolder,\n makeShareableCloneOnUIRecursive(newValue)\n );\n }\n listeners.forEach((listener) => {\n listener(newValue);\n });\n },\n get _value(): T {\n return value;\n },\n addListener: (id: number, listener: (newValue: T) => void) => {\n listeners.set(id, listener);\n },\n removeListener: (id: number) => {\n listeners.delete(id);\n },\n _animation: null,\n };\n return self;\n}\n\nexport function makeMutable(\n initial: T,\n oneWayReadsOnly = false\n): SharedValue {\n let value: T = initial;\n let syncDataHolder: ShareableSyncDataHolderRef | undefined;\n if (!oneWayReadsOnly && NativeReanimatedModule.native) {\n // updates are always synchronous when running on web or in Jest environment\n syncDataHolder = NativeReanimatedModule.makeSynchronizedDataHolder(\n makeShareableCloneRecursive(value)\n );\n registerShareableMapping(syncDataHolder);\n }\n const handle = makeShareableCloneRecursive({\n __init: () => {\n 'worklet';\n return makeUIMutable(initial, syncDataHolder);\n },\n });\n // listeners can only work on JS thread on Web and jest environments\n const listeners = NativeReanimatedModule.native ? undefined : new Map();\n const mutable = {\n set value(newValue) {\n if (NativeReanimatedModule.native) {\n runOnUI(() => {\n 'worklet';\n mutable.value = newValue;\n })();\n } else {\n valueSetter(mutable, newValue);\n }\n },\n get value() {\n if (syncDataHolder) {\n return NativeReanimatedModule.getDataSynchronously(syncDataHolder);\n }\n return value;\n },\n set _value(newValue: T) {\n if (NativeReanimatedModule.native) {\n throw new Error(\n 'Setting `_value` directly is only possible on the UI runtime'\n );\n }\n value = newValue;\n listeners!.forEach((listener) => {\n listener(newValue);\n });\n },\n get _value(): T {\n if (NativeReanimatedModule.native) {\n throw new Error(\n 'Reading from `_value` directly is only possible on the UI runtime'\n );\n }\n return value;\n },\n modify: (modifier: (value: T) => T) => {\n runOnUI(() => {\n 'worklet';\n mutable.value = modifier(mutable.value);\n })();\n },\n addListener: (id: number, listener: (value: T) => void) => {\n if (NativeReanimatedModule.native) {\n throw new Error('adding listeners is only possible on the UI runtime');\n }\n listeners!.set(id, listener);\n },\n removeListener: (id: number) => {\n if (NativeReanimatedModule.native) {\n throw new Error(\n 'removing listeners is only possible on the UI runtime'\n );\n }\n listeners!.delete(id);\n },\n };\n registerShareableMapping(mutable, handle);\n return mutable;\n}\n\nexport function makeRemote(initial: T = {} as T): T {\n const handle = makeShareableCloneRecursive({\n __init: () => {\n 'worklet';\n return initial;\n },\n });\n registerShareableMapping(initial, handle);\n return initial;\n}\n","import { AnimationObject, AnimatableValue } from './commonTypes';\nimport { Descriptor } from './hook/commonTypes';\nimport { getTimestamp } from './time';\nexport { stopMapper } from './mappers';\n\nexport function valueSetter(sv: any, value: any): void {\n 'worklet';\n const previousAnimation = sv._animation;\n if (previousAnimation) {\n previousAnimation.cancelled = true;\n sv._animation = null;\n }\n if (\n typeof value === 'function' ||\n (value !== null &&\n typeof value === 'object' &&\n (value as AnimationObject).onFrame !== undefined)\n ) {\n const animation: AnimationObject =\n typeof value === 'function'\n ? (value as () => AnimationObject)()\n : (value as AnimationObject);\n // prevent setting again to the same value\n // and triggering the mappers that treat this value as an input\n // this happens when the animation's target value(stored in animation.current until animation.onStart is called) is set to the same value as a current one(this._value)\n // built in animations that are not higher order(withTiming, withSpring) hold target value in .current\n if (sv._value === animation.current && !animation.isHigherOrder) {\n animation.callback && animation.callback(true);\n return;\n }\n // animated set\n const initializeAnimation = (timestamp: number) => {\n animation.onStart(animation, sv.value, timestamp, previousAnimation);\n };\n const currentTimestamp = getTimestamp();\n initializeAnimation(currentTimestamp);\n const step = (timestamp: number) => {\n if (animation.cancelled) {\n animation.callback && animation.callback(false /* finished */);\n return;\n }\n const finished = animation.onFrame(animation, timestamp);\n animation.finished = true;\n animation.timestamp = timestamp;\n sv._value = animation.current;\n if (finished) {\n animation.callback && animation.callback(true /* finished */);\n } else {\n requestAnimationFrame(step);\n }\n };\n\n sv._animation = animation;\n\n step(currentTimestamp);\n } else {\n // prevent setting again to the same value\n // and triggering the mappers that treat this value as an input\n if (sv._value === value) {\n return;\n }\n sv._value = value as Descriptor | AnimatableValue;\n }\n}\n","import { reportFatalErrorOnJS } from './errors';\nimport NativeReanimatedModule from './NativeReanimated';\nimport { isJest } from './PlatformChecker';\nimport { runOnUI, runOnJS } from './threads';\n\n// callGuard is only used with debug builds\nfunction callGuardDEV, U>(\n fn: (...args: T) => U,\n ...args: T\n): void {\n 'worklet';\n try {\n fn(...args);\n } catch (e) {\n if (global.ErrorUtils) {\n global.ErrorUtils.reportFatalError(e as Error);\n } else {\n throw e;\n }\n }\n}\n\nfunction valueUnpacker(objectToUnpack: any, category?: string): any {\n 'worklet';\n let workletsCache = global.__workletsCache;\n let handleCache = global.__handleCache;\n if (workletsCache === undefined) {\n // init\n workletsCache = global.__workletsCache = new Map();\n handleCache = global.__handleCache = new WeakMap();\n }\n if (objectToUnpack.__workletHash) {\n let workletFun = workletsCache.get(objectToUnpack.__workletHash);\n if (workletFun === undefined) {\n if (global.evalWithSourceMap) {\n // if the runtime (hermes only for now) supports loading source maps\n // we want to use the proper filename for the location as it guarantees\n // that debugger understands and loads the source code of the file where\n // the worklet is defined.\n workletFun = global.evalWithSourceMap(\n '(' + objectToUnpack.asString + '\\n)',\n objectToUnpack.__location,\n objectToUnpack.__sourceMap\n ) as (...args: any[]) => any;\n } else if (global.evalWithSourceUrl) {\n // if the runtime doesn't support loading source maps, in dev mode we\n // can pass source url when evaluating the worklet. Now, instead of using\n // the actual file location we use worklet hash, as it the allows us to\n // properly symbolicate traces (see errors.ts for details)\n workletFun = global.evalWithSourceUrl(\n '(' + objectToUnpack.asString + '\\n)',\n `worklet_${objectToUnpack.__workletHash}`\n ) as (...args: any[]) => any;\n } else {\n // in release we use the regular eval to save on JSI calls\n // eslint-disable-next-line no-eval\n workletFun = eval('(' + objectToUnpack.asString + '\\n)') as (\n ...args: any[]\n ) => any;\n }\n workletsCache.set(objectToUnpack.__workletHash, workletFun);\n }\n const functionInstance = workletFun.bind(objectToUnpack);\n objectToUnpack._recur = functionInstance;\n return functionInstance;\n } else if (objectToUnpack.__init) {\n let value = handleCache!.get(objectToUnpack);\n if (value === undefined) {\n value = objectToUnpack.__init();\n handleCache!.set(objectToUnpack, value);\n }\n return value;\n } else if (category === 'RemoteFunction') {\n const fun = () => {\n throw new Error(`Tried to synchronously call a non-worklet function on the UI thread.\n\nPossible solutions are:\n a) If you want to synchronously execute this method, mark it as a worklet\n b) If you want to execute this function on the JS thread, wrap it using \\`runOnJS\\``);\n };\n fun.__remoteFunction = objectToUnpack;\n return fun;\n } else {\n throw new Error('data type not recognized by unpack method');\n }\n}\n\nexport function initializeUIRuntime() {\n NativeReanimatedModule.installCoreFunctions(callGuardDEV, valueUnpacker);\n\n const IS_JEST = isJest();\n\n const capturableConsole = console;\n runOnUI(() => {\n 'worklet';\n // setup error handler\n global.ErrorUtils = {\n reportFatalError: (error: Error) => {\n runOnJS(reportFatalErrorOnJS)({\n message: error.message,\n stack: error.stack,\n });\n },\n };\n\n // setup console\n // @ts-ignore TypeScript doesn't like that there are missing methods in console object, but we don't provide all the methods for the UI runtime console version\n global.console = {\n debug: runOnJS(capturableConsole.debug),\n log: runOnJS(capturableConsole.log),\n warn: runOnJS(capturableConsole.warn),\n error: runOnJS(capturableConsole.error),\n info: runOnJS(capturableConsole.info),\n };\n\n if (!IS_JEST) {\n // Jest mocks requestAnimationFrame API and it does not like if that mock gets overridden\n // so we avoid doing requestAnimationFrame batching in Jest environment.\n const nativeRequestAnimationFrame = global.requestAnimationFrame;\n let callbacks: Array<(time: number) => void> = [];\n global.requestAnimationFrame = (\n callback: (timestamp: number) => void\n ): number => {\n callbacks.push(callback);\n if (callbacks.length === 1) {\n // We schedule native requestAnimationFrame only when the first callback\n // is added and then use it to execute all the enqueued callbacks. Once\n // the callbacks are run, we clear the array.\n nativeRequestAnimationFrame((timestamp) => {\n const currentCallbacks = callbacks;\n callbacks = [];\n currentCallbacks.forEach((f) => f(timestamp));\n });\n }\n // Reanimated currently does not support cancelling calbacks requested with\n // requestAnimationFrame. We return -1 as identifier which isn't in line\n // with the spec but it should give users better clue in case they actually\n // attempt to store the value returned from rAF and use it for cancelling.\n return -1;\n };\n }\n })();\n}\n","type StackDetails = [Error, number, number];\n\nconst _workletStackDetails = new Map();\n\nexport function registerWorkletStackDetails(\n hash: number,\n stackDetails: StackDetails\n) {\n _workletStackDetails.set(hash, stackDetails);\n}\n\nfunction getBundleOffset(error: Error): [string, number, number] {\n const frame = error.stack?.split('\\n')?.[0];\n if (frame) {\n const parsedFrame = /@([^@]+):(\\d+):(\\d+)/.exec(frame);\n if (parsedFrame) {\n const [, file, line, col] = parsedFrame;\n return [file, Number(line), Number(col)];\n }\n }\n return ['unknown', 0, 0];\n}\n\nfunction processStack(stack: string): string {\n const workletStackEntries = stack.match(/worklet_(\\d+):(\\d+):(\\d+)/g);\n let result = stack;\n workletStackEntries?.forEach((match) => {\n const [, hash, origLine, origCol] = match.split(/:|_/).map(Number);\n const errorDetails = _workletStackDetails.get(hash);\n if (!errorDetails) {\n return;\n }\n const [error, lineOffset, colOffset] = errorDetails;\n const [bundleFile, bundleLine, bundleCol] = getBundleOffset(error);\n const line = origLine + bundleLine + lineOffset;\n const col = origCol + bundleCol + colOffset;\n\n result = result.replace(match, `${bundleFile}:${line}:${col}`);\n });\n return result;\n}\n\nexport function reportFatalErrorOnJS({\n message,\n stack,\n}: {\n message: string;\n stack?: string;\n}) {\n const error = new Error();\n error.message = message;\n error.stack = stack ? processStack(stack) : undefined;\n error.name = 'ReanimatedError';\n // @ts-ignore React Native's ErrorUtils implementation extends the Error type with jsEngine field\n error.jsEngine = 'reanimated';\n global.ErrorUtils.reportFatalError(error);\n}\n","import React, { Component, ComponentType, MutableRefObject, Ref } from 'react';\nimport { findNodeHandle, Platform, StyleSheet } from 'react-native';\nimport WorkletEventHandler from './reanimated2/WorkletEventHandler';\nimport setAndForwardRef from './setAndForwardRef';\nimport './reanimated2/layoutReanimation/animationsManager';\nimport invariant from 'invariant';\nimport { adaptViewConfig } from './ConfigHelper';\nimport { RNRenderer } from './reanimated2/platform-specific/RNRenderer';\nimport {\n configureLayoutAnimations,\n enableLayoutAnimations,\n runOnUI,\n} from './reanimated2/core';\nimport {\n isJest,\n isChromeDebugger,\n shouldBeUseWeb,\n} from './reanimated2/PlatformChecker';\nimport { initialUpdaterRun } from './reanimated2/animation';\nimport {\n BaseAnimationBuilder,\n EntryExitAnimationFunction,\n ILayoutAnimationBuilder,\n LayoutAnimationFunction,\n} from './reanimated2/layoutReanimation';\nimport {\n SharedValue,\n StyleProps,\n ShadowNodeWrapper,\n} from './reanimated2/commonTypes';\nimport {\n ViewDescriptorsSet,\n ViewRefSet,\n} from './reanimated2/ViewDescriptorsSet';\nimport { getShadowNodeWrapperFromRef } from './reanimated2/fabricUtils';\nimport { makeShareableShadowNodeWrapper } from './reanimated2/shareables';\n\nfunction dummyListener() {\n // empty listener we use to assign to listener properties for which animated\n // event is used.\n}\n\nfunction maybeBuild(\n layoutAnimationOrBuilder:\n | ILayoutAnimationBuilder\n | LayoutAnimationFunction\n | Keyframe\n): LayoutAnimationFunction | Keyframe {\n const isAnimationBuilder = (\n value: ILayoutAnimationBuilder | LayoutAnimationFunction | Keyframe\n ): value is ILayoutAnimationBuilder =>\n 'build' in layoutAnimationOrBuilder &&\n typeof layoutAnimationOrBuilder.build === 'function';\n\n if (isAnimationBuilder(layoutAnimationOrBuilder)) {\n return layoutAnimationOrBuilder.build();\n } else {\n return layoutAnimationOrBuilder;\n }\n}\n\ntype NestedArray = T | NestedArray[];\nfunction flattenArray(array: NestedArray): T[] {\n if (!Array.isArray(array)) {\n return [array];\n }\n const resultArr: T[] = [];\n\n const _flattenArray = (arr: NestedArray[]): void => {\n arr.forEach((item) => {\n if (Array.isArray(item)) {\n _flattenArray(item);\n } else {\n resultArr.push(item);\n }\n });\n };\n _flattenArray(array);\n return resultArr;\n}\n\nfunction onlyAnimatedStyles(styles: StyleProps[]) {\n return styles.filter((style) => style?.viewDescriptors);\n}\n\nfunction isSameAnimatedStyle(\n style1?: StyleProps,\n style2?: StyleProps\n): boolean {\n // We cannot use equality check to compare useAnimatedStyle outputs directly.\n // Instead, we can compare its viewsRefs.\n return style1?.viewsRef === style2?.viewsRef;\n}\n\nconst isSameAnimatedProps = isSameAnimatedStyle;\n\nconst has = (\n key: K,\n x: unknown\n): x is { [key in K]: unknown } => {\n if (typeof x === 'function' || typeof x === 'object') {\n if (x === null || x === undefined) {\n return false;\n } else {\n return key in x;\n }\n }\n return false;\n};\n\ninterface AnimatedProps extends Record {\n viewDescriptors?: ViewDescriptorsSet;\n viewsRef?: ViewRefSet;\n initial?: SharedValue;\n}\n\nexport type AnimatedComponentProps

> = P & {\n forwardedRef?: Ref;\n style?: NestedArray;\n animatedProps?: Partial>;\n animatedStyle?: StyleProps;\n layout?:\n | BaseAnimationBuilder\n | ILayoutAnimationBuilder\n | typeof BaseAnimationBuilder;\n entering?:\n | BaseAnimationBuilder\n | typeof BaseAnimationBuilder\n | EntryExitAnimationFunction\n | Keyframe;\n exiting?:\n | BaseAnimationBuilder\n | typeof BaseAnimationBuilder\n | EntryExitAnimationFunction\n | Keyframe;\n};\n\ntype Options

= {\n setNativeProps: (ref: ComponentRef, props: P) => void;\n};\n\ninterface ComponentRef extends Component {\n setNativeProps?: (props: Record) => void;\n getScrollableNode?: () => ComponentRef;\n}\n\nexport interface InitialComponentProps extends Record {\n ref?: Ref;\n collapsable?: boolean;\n}\n\nexport default function createAnimatedComponent(\n Component: ComponentType,\n options?: Options\n): ComponentType> {\n invariant(\n typeof Component !== 'function' ||\n (Component.prototype && Component.prototype.isReactComponent),\n '`createAnimatedComponent` does not support stateless functional components; ' +\n 'use a class component instead.'\n );\n\n class AnimatedComponent extends React.Component<\n AnimatedComponentProps\n > {\n _styles: StyleProps[] | null = null;\n _animatedProps?: Partial>;\n _viewTag = -1;\n _isFirstRender = true;\n animatedStyle: { value: StyleProps } = { value: {} };\n initialStyle = {};\n _component: ComponentRef | null = null;\n static displayName: string;\n\n constructor(props: AnimatedComponentProps) {\n super(props);\n if (isJest()) {\n this.animatedStyle = { value: {} };\n }\n }\n\n componentWillUnmount() {\n this._detachNativeEvents();\n this._detachStyles();\n }\n\n componentDidMount() {\n this._attachNativeEvents();\n this._attachAnimatedStyles();\n }\n\n _attachNativeEvents() {\n let viewTag = findNodeHandle(this);\n\n const componentName = Component.displayName || Component.name;\n\n if (componentName?.endsWith('FlashList') && this._component) {\n // @ts-ignore it's FlashList specific: https://github.com/Shopify/flash-list/blob/218f314e63806b4fe926741ef73f8b9cd6ebc7eb/src/FlashList.tsx#L824\n viewTag = findNodeHandle(this._component.recyclerlistview_unsafe);\n }\n\n for (const key in this.props) {\n const prop = this.props[key];\n if (\n has('current', prop) &&\n prop.current instanceof WorkletEventHandler\n ) {\n prop.current.registerForEvents(viewTag as number, key);\n }\n }\n }\n\n _detachNativeEvents() {\n for (const key in this.props) {\n const prop = this.props[key];\n if (\n has('current', prop) &&\n prop.current instanceof WorkletEventHandler\n ) {\n prop.current.unregisterFromEvents();\n }\n }\n }\n\n _detachStyles() {\n if (Platform.OS === 'web' && this._styles !== null) {\n for (const style of this._styles) {\n if (style?.viewsRef) {\n style.viewsRef.remove(this);\n }\n }\n } else if (this._viewTag !== -1 && this._styles !== null) {\n for (const style of this._styles) {\n style.viewDescriptors.remove(this._viewTag);\n }\n if (this.props.animatedProps?.viewDescriptors) {\n this.props.animatedProps.viewDescriptors.remove(this._viewTag);\n }\n if (global._IS_FABRIC) {\n const shadowNodeWrapper = getShadowNodeWrapperFromRef(this);\n runOnUI(() => {\n 'worklet';\n _removeShadowNodeFromRegistry(shadowNodeWrapper);\n })();\n }\n }\n }\n\n _reattachNativeEvents(\n prevProps: AnimatedComponentProps\n ) {\n let viewTag: number | undefined;\n\n for (const key in this.props) {\n const prop = this.props[key];\n if (\n has('current', prop) &&\n prop.current instanceof WorkletEventHandler\n ) {\n if (viewTag === undefined) {\n viewTag = prop.current.viewTag;\n }\n }\n }\n for (const key in prevProps) {\n const prop = this.props[key];\n if (\n has('current', prop) &&\n prop.current instanceof WorkletEventHandler &&\n prop.current.reattachNeeded\n ) {\n prop.current.unregisterFromEvents();\n }\n }\n\n for (const key in this.props) {\n const prop = this.props[key];\n if (\n has('current', prop) &&\n prop.current instanceof WorkletEventHandler &&\n prop.current.reattachNeeded\n ) {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n prop.current.registerForEvents(viewTag!, key);\n prop.current.reattachNeeded = false;\n }\n }\n }\n\n _updateFromNative(props: StyleProps) {\n if (options?.setNativeProps) {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n options.setNativeProps(this._component!, props);\n } else {\n // eslint-disable-next-line no-unused-expressions\n this._component?.setNativeProps?.(props);\n }\n }\n\n _attachAnimatedStyles() {\n const styles = this.props.style\n ? onlyAnimatedStyles(flattenArray(this.props.style))\n : [];\n const prevStyles = this._styles;\n this._styles = styles;\n\n const prevAnimatedProps = this._animatedProps;\n this._animatedProps = this.props.animatedProps;\n\n let viewTag: number | null;\n let viewName: string | null;\n let shadowNodeWrapper: ShadowNodeWrapper | null = null;\n if (Platform.OS === 'web') {\n viewTag = findNodeHandle(this);\n viewName = null;\n shadowNodeWrapper = null;\n } else {\n // hostInstance can be null for a component that doesn't render anything (render function returns null). Example: svg Stop: https://github.com/react-native-svg/react-native-svg/blob/develop/src/elements/Stop.tsx\n const hostInstance = RNRenderer.findHostInstance_DEPRECATED(this);\n if (!hostInstance) {\n throw new Error(\n 'Cannot find host instance for this component. Maybe it renders nothing?'\n );\n }\n // we can access view tag in the same way it's accessed here https://github.com/facebook/react/blob/e3f4eb7272d4ca0ee49f27577156b57eeb07cf73/packages/react-native-renderer/src/ReactFabric.js#L146\n viewTag = hostInstance?._nativeTag;\n /**\n * RN uses viewConfig for components for storing different properties of the component(example: https://github.com/facebook/react-native/blob/master/Libraries/Components/ScrollView/ScrollViewViewConfig.js#L16).\n * The name we're looking for is in the field named uiViewClassName.\n */\n viewName = hostInstance?.viewConfig?.uiViewClassName;\n // update UI props whitelist for this view\n const hasReanimated2Props =\n this.props.animatedProps?.viewDescriptors || styles.length;\n if (hasReanimated2Props && hostInstance?.viewConfig) {\n adaptViewConfig(hostInstance.viewConfig);\n }\n\n if (global._IS_FABRIC) {\n shadowNodeWrapper = makeShareableShadowNodeWrapper(\n getShadowNodeWrapperFromRef(this)\n );\n }\n }\n this._viewTag = viewTag as number;\n\n // remove old styles\n if (prevStyles) {\n // in most of the cases, views have only a single animated style and it remains unchanged\n const hasOneSameStyle =\n styles.length === 1 &&\n prevStyles.length === 1 &&\n isSameAnimatedStyle(styles[0], prevStyles[0]);\n\n if (!hasOneSameStyle) {\n // otherwise, remove each style that is not present in new styles\n for (const prevStyle of prevStyles) {\n const isPresent = styles.some((style) =>\n isSameAnimatedStyle(style, prevStyle)\n );\n if (!isPresent) {\n prevStyle.viewDescriptors.remove(viewTag);\n }\n }\n }\n }\n\n styles.forEach((style) => {\n style.viewDescriptors.add({\n tag: viewTag,\n name: viewName,\n shadowNodeWrapper,\n });\n if (isJest()) {\n /**\n * We need to connect Jest's TestObject instance whose contains just props object\n * with the updateProps() function where we update the properties of the component.\n * We can't update props object directly because TestObject contains a copy of props - look at render function:\n * const props = this._filterNonAnimatedProps(this.props);\n */\n this.animatedStyle.value = {\n ...this.animatedStyle.value,\n ...style.initial.value,\n };\n style.animatedStyle.current = this.animatedStyle;\n }\n });\n\n // detach old animatedProps\n if (\n prevAnimatedProps &&\n !isSameAnimatedProps(prevAnimatedProps, this.props.animatedProps)\n ) {\n prevAnimatedProps.viewDescriptors!.remove(viewTag as number);\n }\n\n // attach animatedProps property\n if (this.props.animatedProps?.viewDescriptors) {\n this.props.animatedProps.viewDescriptors.add({\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n tag: viewTag!,\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n name: viewName!,\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n shadowNodeWrapper: shadowNodeWrapper!,\n });\n }\n }\n\n componentDidUpdate(\n prevProps: AnimatedComponentProps\n ) {\n this._reattachNativeEvents(prevProps);\n this._attachAnimatedStyles();\n }\n\n _setComponentRef = setAndForwardRef({\n getForwardedRef: () =>\n this.props.forwardedRef as MutableRefObject<\n Component, Record, unknown>\n >,\n setLocalRef: (ref) => {\n // TODO update config\n const tag = findNodeHandle(ref);\n const { layout, entering, exiting } = this.props;\n if ((layout || entering || exiting) && tag != null) {\n if (!shouldBeUseWeb()) {\n enableLayoutAnimations(true, false);\n }\n if (layout) {\n configureLayoutAnimations(tag, 'layout', maybeBuild(layout));\n }\n if (entering) {\n configureLayoutAnimations(tag, 'entering', maybeBuild(entering));\n }\n if (exiting) {\n configureLayoutAnimations(tag, 'exiting', maybeBuild(exiting));\n }\n }\n\n if (ref !== this._component) {\n this._component = ref;\n }\n },\n });\n\n _filterNonAnimatedProps(\n inputProps: AnimatedComponentProps\n ): Record {\n const props: Record = {};\n for (const key in inputProps) {\n const value = inputProps[key];\n if (key === 'style') {\n const styleProp = inputProps.style;\n const styles = flattenArray(styleProp ?? []);\n const processedStyle: StyleProps = styles.map((style) => {\n if (style && style.viewDescriptors) {\n // this is how we recognize styles returned by useAnimatedStyle\n style.viewsRef.add(this);\n if (this._isFirstRender) {\n this.initialStyle = {\n ...style.initial.value,\n ...initialUpdaterRun(style.initial.updater),\n };\n }\n return this.initialStyle;\n } else {\n return style;\n }\n });\n props[key] = StyleSheet.flatten(processedStyle);\n } else if (key === 'animatedProps') {\n const animatedProp = inputProps.animatedProps as Partial<\n AnimatedComponentProps\n >;\n if (animatedProp.initial !== undefined) {\n Object.keys(animatedProp.initial.value).forEach((key) => {\n props[key] = animatedProp.initial?.value[key];\n animatedProp.viewsRef?.add(this);\n });\n }\n } else if (\n has('current', value) &&\n value.current instanceof WorkletEventHandler\n ) {\n if (value.current.eventNames.length > 0) {\n value.current.eventNames.forEach((eventName) => {\n props[eventName] = has('listeners', value.current)\n ? (value.current.listeners as Record)[\n eventName\n ]\n : dummyListener;\n });\n } else {\n props[key] = dummyListener;\n }\n } else if (\n key !== 'onGestureHandlerStateChange' ||\n !isChromeDebugger()\n ) {\n props[key] = value;\n }\n }\n return props;\n }\n\n render() {\n const props = this._filterNonAnimatedProps(this.props);\n if (isJest()) {\n props.animatedStyle = this.animatedStyle;\n }\n\n if (this._isFirstRender) {\n this._isFirstRender = false;\n }\n\n const platformProps = Platform.select({\n web: {},\n default: { collapsable: false },\n });\n return (\n \n );\n }\n }\n\n AnimatedComponent.displayName = `AnimatedComponent(${\n Component.displayName || Component.name || 'Component'\n })`;\n\n return React.forwardRef((props, ref) => {\n return (\n \n );\n });\n}\n","import { NativeEvent } from './commonTypes';\nimport NativeReanimatedModule from './NativeReanimated';\nimport { registerEventHandler, unregisterEventHandler } from './core';\n\nfunction jsListener>(\n eventName: string,\n handler: (event: T) => void\n) {\n return (evt: T) => {\n handler({ ...evt.nativeEvent, eventName });\n };\n}\n\nexport default class WorkletEventHandler> {\n worklet: (event: T) => void;\n eventNames: string[];\n reattachNeeded: boolean;\n listeners: Record void>;\n viewTag: number | undefined;\n registrations: string[];\n constructor(worklet: (event: T) => void, eventNames: string[] = []) {\n this.worklet = worklet;\n this.eventNames = eventNames;\n this.reattachNeeded = false;\n this.listeners = {};\n this.viewTag = undefined;\n this.registrations = [];\n\n if (!NativeReanimatedModule.native) {\n this.listeners = eventNames.reduce(\n (acc: Record void>, eventName: string) => {\n acc[eventName] = jsListener(eventName, worklet);\n return acc;\n },\n {}\n );\n }\n }\n\n updateWorklet(newWorklet: (event: T) => void): void {\n this.worklet = newWorklet;\n this.reattachNeeded = true;\n }\n\n registerForEvents(viewTag: number, fallbackEventName?: string): void {\n this.viewTag = viewTag;\n this.registrations = this.eventNames.map((eventName) =>\n registerEventHandler(viewTag + eventName, this.worklet)\n );\n if (this.registrations.length === 0 && fallbackEventName) {\n this.registrations.push(\n registerEventHandler(viewTag + fallbackEventName, this.worklet)\n );\n }\n }\n\n unregisterFromEvents(): void {\n this.registrations.forEach((id) => unregisterEventHandler(id));\n this.registrations = [];\n }\n}\n","/**\n * imported from react-native\n */\n\nimport { MutableRefObject } from 'react';\n\n/**\n * This is a helper function for when a component needs to be able to forward a ref\n * to a child component, but still needs to have access to that component as part of\n * its implementation.\n *\n * Its main use case is in wrappers for native components.\n *\n * Usage:\n *\n * class MyView extends React.Component {\n * _nativeRef = null;\n *\n * _setNativeRef = setAndForwardRef({\n * getForwardedRef: () => this.props.forwardedRef,\n * setLocalRef: ref => {\n * this._nativeRef = ref;\n * },\n * });\n *\n * render() {\n * return ;\n * }\n * }\n *\n * const MyViewWithRef = React.forwardRef((props, ref) => (\n * \n * ));\n *\n * module.exports = MyViewWithRef;\n */\n\nexport type ForwardedRef = () => MutableRefObject | ((ref: T) => void);\n\nfunction setAndForwardRef({\n getForwardedRef,\n setLocalRef,\n}: {\n getForwardedRef: ForwardedRef;\n setLocalRef: (ref: T) => void;\n}): (ref: T) => void {\n return function forwardRef(ref: T) {\n const forwardedRef = getForwardedRef();\n\n setLocalRef(ref);\n\n // Forward to user ref prop (if one has been specified)\n if (typeof forwardedRef === 'function') {\n // Handle function-based refs. String-based refs are handled as functions.\n forwardedRef(ref);\n } else if (typeof forwardedRef === 'object' && forwardedRef != null) {\n // Handle createRef-based refs\n forwardedRef.current = ref;\n }\n };\n}\n\nexport default setAndForwardRef;\n","import { runOnUI } from '../core';\nimport { withStyleAnimation } from '../animation/styleAnimation';\nimport { SharedValue } from '../commonTypes';\nimport { makeUIMutable } from '../mutables';\nimport {\n LayoutAnimationFunction,\n LayoutAnimationsValues,\n} from './animationBuilder';\n\nconst TAG_OFFSET = 1e9;\n\nfunction startObservingProgress(\n tag: number,\n sharedValue: SharedValue\n): void {\n 'worklet';\n sharedValue.addListener(tag + TAG_OFFSET, () => {\n _notifyAboutProgress(tag, sharedValue.value);\n });\n}\n\nfunction stopObservingProgress(\n tag: number,\n sharedValue: SharedValue,\n cancelled: boolean,\n removeView: boolean\n): void {\n 'worklet';\n sharedValue.removeListener(tag + TAG_OFFSET);\n _notifyAboutEnd(tag, cancelled, removeView);\n}\n\nfunction createLayoutAnimationManager() {\n 'worklet';\n const enteringAnimationForTag = new Map();\n const mutableValuesForTag = new Map();\n\n return {\n start(\n tag: number,\n type: string,\n yogaValues: LayoutAnimationsValues,\n config: LayoutAnimationFunction\n ) {\n const style = config(yogaValues);\n let currentAnimation = style.animations;\n\n if (type === 'entering') {\n enteringAnimationForTag.set(tag, currentAnimation);\n } else if (type === 'layout') {\n // When layout animation is requested, but entering is still running, we merge\n // new layout animation targets into the ongoing animation\n const enteringAnimation = enteringAnimationForTag.get(tag);\n if (enteringAnimation) {\n currentAnimation = { ...enteringAnimation, ...style.animations };\n }\n }\n\n let value = mutableValuesForTag.get(tag);\n if (value === undefined) {\n value = makeUIMutable(style.initialValues);\n mutableValuesForTag.set(tag, value);\n } else {\n stopObservingProgress(tag, value, false, false);\n value._value = style.initialValues;\n }\n\n // @ts-ignore The line below started failing because I added types to the method – don't have time to fix it right now\n const animation = withStyleAnimation(currentAnimation);\n\n animation.callback = (finished?: boolean) => {\n if (finished) {\n enteringAnimationForTag.delete(tag);\n mutableValuesForTag.delete(tag);\n const shouldRemoveView = type === 'exiting';\n stopObservingProgress(tag, value, finished, shouldRemoveView);\n }\n style.callback &&\n style.callback(finished === undefined ? false : finished);\n };\n\n startObservingProgress(tag, value);\n value.value = animation;\n },\n };\n}\n\nrunOnUI(() => {\n 'worklet';\n global.LayoutAnimationsManager = createLayoutAnimationManager();\n})();\n","import { defineAnimation } from './util';\nimport {\n Timestamp,\n AnimatableValue,\n AnimationObject,\n Animation,\n AnimatedStyle,\n NestedObject,\n NestedObjectValues,\n} from '../commonTypes';\nimport { StyleLayoutAnimation } from './commonTypes';\nimport { withTiming } from './timing';\nimport { ColorProperties } from '../UpdateProps';\nimport { processColor } from '../Colors';\n\n// resolves path to value for nested objects\n// if path cannot be resolved returns undefined\nexport function resolvePath(\n obj: NestedObject,\n path: AnimatableValue[] | AnimatableValue\n): NestedObjectValues | undefined {\n 'worklet';\n const keys: AnimatableValue[] = Array.isArray(path) ? path : [path];\n return keys.reduce | undefined>((acc, current) => {\n if (Array.isArray(acc) && typeof current === 'number') {\n return acc[current];\n } else if (typeof acc === 'object' && (current as number | string) in acc) {\n return (acc as { [key: string]: NestedObjectValues })[\n current as number | string\n ];\n }\n return undefined;\n }, obj);\n}\n\n// set value at given path\ntype Path = Array | string | number;\nexport function setPath(\n obj: NestedObject,\n path: Path,\n value: NestedObjectValues\n): void {\n 'worklet';\n const keys: Path = Array.isArray(path) ? path : [path];\n let currObj: NestedObjectValues = obj;\n for (let i = 0; i < keys.length - 1; i++) {\n // creates entry if there isn't one\n currObj = currObj as { [key: string]: NestedObjectValues };\n if (!currObj[keys[i]]) {\n // if next key is a number create an array\n if (typeof keys[i + 1] === 'number') {\n currObj[keys[i]] = [];\n } else {\n currObj[keys[i]] = {};\n }\n }\n currObj = currObj[keys[i]];\n }\n\n (currObj as { [key: string]: NestedObjectValues })[keys[keys.length - 1]] =\n value;\n}\n\ninterface NestedObjectEntry {\n value: NestedObjectValues;\n path: (string | number)[];\n}\n\nexport function withStyleAnimation(\n styleAnimations: AnimatedStyle\n): StyleLayoutAnimation {\n 'worklet';\n return defineAnimation({}, () => {\n 'worklet';\n\n const onFrame = (\n animation: StyleLayoutAnimation,\n now: Timestamp\n ): boolean => {\n let stillGoing = false;\n const entriesToCheck: NestedObjectEntry[] = [\n { value: animation.styleAnimations, path: [] },\n ];\n while (entriesToCheck.length > 0) {\n const currentEntry: NestedObjectEntry =\n entriesToCheck.pop() as NestedObjectEntry;\n if (Array.isArray(currentEntry.value)) {\n for (let index = 0; index < currentEntry.value.length; index++) {\n entriesToCheck.push({\n value: currentEntry.value[index],\n path: currentEntry.path.concat(index),\n });\n }\n } else if (\n typeof currentEntry.value === 'object' &&\n currentEntry.value.onFrame === undefined\n ) {\n // nested object\n for (const key of Object.keys(currentEntry.value)) {\n entriesToCheck.push({\n value: currentEntry.value[key],\n path: currentEntry.path.concat(key),\n });\n }\n } else {\n const currentStyleAnimation: AnimationObject =\n currentEntry.value as AnimationObject;\n if (currentStyleAnimation.finished) {\n continue;\n }\n const finished = currentStyleAnimation.onFrame(\n currentStyleAnimation,\n now\n );\n if (finished) {\n currentStyleAnimation.finished = true;\n if (currentStyleAnimation.callback) {\n currentStyleAnimation.callback(true);\n }\n } else {\n stillGoing = true;\n }\n\n if (ColorProperties.includes(currentEntry.path[0] as string)) {\n currentStyleAnimation.current = processColor(\n currentStyleAnimation.current\n ) as number;\n }\n\n setPath(\n animation.current,\n currentEntry.path,\n currentStyleAnimation.current\n );\n }\n }\n return !stillGoing;\n };\n\n const onStart = (\n animation: StyleLayoutAnimation,\n value: AnimatedStyle,\n now: Timestamp,\n previousAnimation: StyleLayoutAnimation\n ): void => {\n const entriesToCheck: NestedObjectEntry<\n AnimationObject | AnimatableValue\n >[] = [{ value: styleAnimations, path: [] }];\n while (entriesToCheck.length > 0) {\n const currentEntry: NestedObjectEntry<\n AnimationObject | AnimatableValue\n > = entriesToCheck.pop() as NestedObjectEntry<\n AnimationObject | AnimatableValue\n >;\n if (Array.isArray(currentEntry.value)) {\n for (let index = 0; index < currentEntry.value.length; index++) {\n entriesToCheck.push({\n value: currentEntry.value[index],\n path: currentEntry.path.concat(index),\n });\n }\n } else if (\n typeof currentEntry.value === 'object' &&\n currentEntry.value.onStart === undefined\n ) {\n for (const key of Object.keys(currentEntry.value)) {\n entriesToCheck.push({\n value: currentEntry.value[key],\n path: currentEntry.path.concat(key),\n });\n }\n } else {\n const prevAnimation = resolvePath(\n previousAnimation?.styleAnimations,\n currentEntry.path\n );\n let prevVal = resolvePath(value, currentEntry.path);\n if (prevAnimation && !prevVal) {\n prevVal = prevAnimation.current;\n }\n setPath(animation.current, currentEntry.path, prevVal);\n let currentAnimation: AnimationObject;\n if (\n typeof currentEntry.value !== 'object' ||\n !currentEntry.value.onStart\n ) {\n currentAnimation = withTiming(\n currentEntry.value as AnimatableValue,\n { duration: 0 }\n );\n setPath(\n animation.styleAnimations,\n currentEntry.path,\n currentAnimation\n );\n } else {\n currentAnimation = currentEntry.value as Animation;\n }\n currentAnimation.onStart(\n currentAnimation,\n prevVal,\n now,\n prevAnimation\n );\n }\n }\n };\n\n const callback = (finished: boolean): void => {\n if (!finished) {\n const animationsToCheck: NestedObjectValues[] = [\n styleAnimations,\n ];\n while (animationsToCheck.length > 0) {\n const currentAnimation: NestedObjectValues =\n animationsToCheck.pop() as NestedObjectValues;\n if (Array.isArray(currentAnimation)) {\n for (const element of currentAnimation) {\n animationsToCheck.push(element);\n }\n } else if (\n typeof currentAnimation === 'object' &&\n currentAnimation.onStart === undefined\n ) {\n for (const value of Object.values(currentAnimation)) {\n animationsToCheck.push(value);\n }\n } else {\n const currentStyleAnimation: AnimationObject =\n currentAnimation as AnimationObject;\n if (\n !currentStyleAnimation.finished &&\n currentStyleAnimation.callback\n ) {\n currentStyleAnimation.callback(false);\n }\n }\n }\n }\n };\n\n return {\n isHigherOrder: true,\n onFrame,\n onStart,\n current: {},\n styleAnimations,\n callback,\n } as StyleLayoutAnimation;\n });\n}\n","import {\n HigherOrderAnimation,\n NextAnimation,\n DelayAnimation,\n RepeatAnimation,\n SequenceAnimation,\n StyleLayoutAnimation,\n} from './commonTypes';\n/* global _WORKLET */\nimport {\n ParsedColorArray,\n isColor,\n convertToRGBA,\n rgbaArrayToRGBAColor,\n toGammaSpace,\n toLinearSpace,\n} from '../Colors';\n\nimport {\n AnimatedStyle,\n SharedValue,\n AnimatableValue,\n Animation,\n AnimationObject,\n Timestamp,\n} from '../commonTypes';\nimport NativeReanimatedModule from '../NativeReanimated';\n\nlet IN_STYLE_UPDATER = false;\n\nexport type UserUpdater = () => AnimatedStyle;\n\nexport function initialUpdaterRun(updater: () => T): T {\n IN_STYLE_UPDATER = true;\n const result = updater();\n IN_STYLE_UPDATER = false;\n return result;\n}\n\ninterface RecognizedPrefixSuffix {\n prefix?: string;\n suffix?: string;\n strippedValue: number;\n}\n\nfunction recognizePrefixSuffix(value: string | number): RecognizedPrefixSuffix {\n 'worklet';\n if (typeof value === 'string') {\n const match = value.match(\n /([A-Za-z]*)(-?\\d*\\.?\\d*)([eE][-+]?[0-9]+)?([A-Za-z%]*)/\n );\n if (!match) {\n throw Error(\n \"Couldn't parse animation value. Check if there isn't any typo.\"\n );\n }\n const prefix = match[1];\n const suffix = match[4];\n // number with scientific notation\n const number = match[2] + (match[3] ?? '');\n return { prefix, suffix, strippedValue: parseFloat(number) };\n } else {\n return { strippedValue: value };\n }\n}\n\nfunction decorateAnimation(\n animation: T\n): void {\n 'worklet';\n if ((animation as HigherOrderAnimation).isHigherOrder) {\n return;\n }\n\n const baseOnStart = (animation as Animation).onStart;\n const baseOnFrame = (animation as Animation).onFrame;\n const animationCopy = Object.assign({}, animation);\n delete animationCopy.callback;\n\n const prefNumberSuffOnStart = (\n animation: Animation,\n value: string | number,\n timestamp: number,\n previousAnimation: Animation\n ) => {\n // recognize prefix, suffix, and updates stripped value on animation start\n const { prefix, suffix, strippedValue } = recognizePrefixSuffix(value);\n animation.__prefix = prefix;\n animation.__suffix = suffix;\n animation.strippedCurrent = strippedValue;\n const { strippedValue: strippedToValue } = recognizePrefixSuffix(\n animation.toValue as string | number\n );\n animation.current = strippedValue;\n animation.startValue = strippedValue;\n animation.toValue = strippedToValue;\n if (previousAnimation && previousAnimation !== animation) {\n const {\n prefix: paPrefix,\n suffix: paSuffix,\n strippedValue: paStrippedValue,\n } = recognizePrefixSuffix(previousAnimation.current as string | number);\n previousAnimation.current = paStrippedValue;\n previousAnimation.__prefix = paPrefix;\n previousAnimation.__suffix = paSuffix;\n }\n\n baseOnStart(animation, strippedValue, timestamp, previousAnimation);\n\n animation.current =\n (animation.__prefix ?? '') +\n animation.current +\n (animation.__suffix ?? '');\n\n if (previousAnimation && previousAnimation !== animation) {\n previousAnimation.current =\n (previousAnimation.__prefix ?? '') +\n previousAnimation.current +\n (previousAnimation.__suffix ?? '');\n }\n };\n const prefNumberSuffOnFrame = (\n animation: Animation,\n timestamp: number\n ) => {\n animation.current = animation.strippedCurrent;\n const res = baseOnFrame(animation, timestamp);\n animation.strippedCurrent = animation.current;\n animation.current =\n (animation.__prefix ?? '') +\n animation.current +\n (animation.__suffix ?? '');\n return res;\n };\n\n const tab = ['R', 'G', 'B', 'A'];\n const colorOnStart = (\n animation: Animation,\n value: string | number,\n timestamp: Timestamp,\n previousAnimation: Animation\n ): void => {\n let RGBAValue: ParsedColorArray;\n let RGBACurrent: ParsedColorArray;\n let RGBAToValue: ParsedColorArray;\n const res: Array = [];\n if (isColor(value)) {\n RGBACurrent = toLinearSpace(convertToRGBA(animation.current));\n RGBAValue = toLinearSpace(convertToRGBA(value));\n if (animation.toValue) {\n RGBAToValue = toLinearSpace(convertToRGBA(animation.toValue));\n }\n }\n tab.forEach((i, index) => {\n animation[i] = Object.assign({}, animationCopy);\n animation[i].current = RGBACurrent[index];\n animation[i].toValue = RGBAToValue ? RGBAToValue[index] : undefined;\n animation[i].onStart(\n animation[i],\n RGBAValue[index],\n timestamp,\n previousAnimation ? previousAnimation[i] : undefined\n );\n res.push(animation[i].current);\n });\n\n animation.current = rgbaArrayToRGBAColor(\n toGammaSpace(res as ParsedColorArray)\n );\n };\n\n const colorOnFrame = (\n animation: Animation,\n timestamp: Timestamp\n ): boolean => {\n const RGBACurrent = toLinearSpace(convertToRGBA(animation.current));\n const res: Array = [];\n let finished = true;\n tab.forEach((i, index) => {\n animation[i].current = RGBACurrent[index];\n // @ts-ignore: disable-next-line\n finished &= animation[i].onFrame(animation[i], timestamp);\n res.push(animation[i].current);\n });\n\n animation.current = rgbaArrayToRGBAColor(\n toGammaSpace(res as ParsedColorArray)\n );\n return finished;\n };\n\n const arrayOnStart = (\n animation: Animation,\n value: Array,\n timestamp: Timestamp,\n previousAnimation: Animation\n ): void => {\n value.forEach((v, i) => {\n animation[i] = Object.assign({}, animationCopy);\n animation[i].current = v;\n animation[i].toValue = (animation.toValue as Array)[i];\n animation[i].onStart(\n animation[i],\n v,\n timestamp,\n previousAnimation ? previousAnimation[i] : undefined\n );\n });\n\n animation.current = value;\n };\n\n const arrayOnFrame = (\n animation: Animation,\n timestamp: Timestamp\n ): boolean => {\n let finished = true;\n (animation.current as Array).forEach((v, i) => {\n // @ts-ignore: disable-next-line\n finished &= animation[i].onFrame(animation[i], timestamp);\n (animation.current as Array)[i] = animation[i].current;\n });\n\n return finished;\n };\n\n animation.onStart = (\n animation: Animation,\n value: number,\n timestamp: Timestamp,\n previousAnimation: Animation\n ) => {\n if (isColor(value)) {\n colorOnStart(animation, value, timestamp, previousAnimation);\n animation.onFrame = colorOnFrame;\n return;\n } else if (Array.isArray(value)) {\n arrayOnStart(animation, value, timestamp, previousAnimation);\n animation.onFrame = arrayOnFrame;\n return;\n } else if (typeof value === 'string') {\n prefNumberSuffOnStart(animation, value, timestamp, previousAnimation);\n animation.onFrame = prefNumberSuffOnFrame;\n return;\n }\n baseOnStart(animation, value, timestamp, previousAnimation);\n };\n}\n\ntype AnimationToDecoration =\n T extends StyleLayoutAnimation\n ? Record\n : T extends DelayAnimation\n ? NextAnimation\n : T extends RepeatAnimation\n ? NextAnimation\n : T extends SequenceAnimation\n ? NextAnimation\n : AnimatableValue | T;\n\nexport function defineAnimation<\n T extends AnimationObject | StyleLayoutAnimation\n>(starting: AnimationToDecoration, factory: () => T): T {\n 'worklet';\n if (IN_STYLE_UPDATER) {\n return starting as T;\n }\n const create = () => {\n 'worklet';\n const animation = factory();\n decorateAnimation(animation);\n return animation;\n };\n\n if (_WORKLET || !NativeReanimatedModule.native) {\n return create();\n }\n // @ts-ignore: eslint-disable-line\n return create;\n}\n\nexport function cancelAnimation(sharedValue: SharedValue): void {\n 'worklet';\n // setting the current value cancels the animation if one is currently running\n sharedValue.value = sharedValue.value; // eslint-disable-line no-self-assign\n}\n\n// TODO it should work only if there was no animation before.\nexport function withStartValue(\n startValue: AnimatableValue,\n animation: NextAnimation\n): Animation {\n 'worklet';\n return defineAnimation(startValue, () => {\n 'worklet';\n if (!_WORKLET && typeof animation === 'function') {\n animation = animation();\n }\n (animation as Animation).current = startValue;\n return animation as Animation;\n });\n}\n","/* global _WORKLET */\n/**\n * Copied from:\n * react-native/Libraries/StyleSheet/normalizeColor.js\n * react-native/Libraries/StyleSheet/processColor.js\n * https://github.com/wcandillon/react-native-redash/blob/master/src/Colors.ts\n */\n\n/* eslint no-bitwise: 0 */\nimport { Platform } from 'react-native';\nimport { makeRemote, makeShareable, isConfigured } from './core';\n\ninterface RGB {\n r: number;\n g: number;\n b: number;\n}\n\ninterface HSV {\n h: number;\n s: number;\n v: number;\n}\n\n// var INTEGER = '[-+]?\\\\d+';\nconst NUMBER = '[-+]?(?:\\\\d+(?:\\\\.\\\\d*)?|\\\\.\\\\d+)';\nconst PERCENTAGE = NUMBER + '%';\n\nfunction call(...args: unknown[]): string {\n 'worklet';\n return '\\\\(\\\\s*(' + args.join(')\\\\s*,\\\\s*(') + ')\\\\s*\\\\)';\n}\n\n// matchers use RegExp objects which needs to be created separately on JS and on\n// the UI thread. We keep separate cache of Regexes for UI and JS using the below\n// objects, then pick the right cache in getMatchers() method.\nconst jsCachedMatchers: Matchers = {};\nconst uiCachedMatchers: Matchers = !isConfigured() ? {} : makeRemote({});\ntype Matchers = {\n rgb?: RegExp;\n rgba?: RegExp;\n hsl?: RegExp;\n hsla?: RegExp;\n hex3?: RegExp;\n hex4?: RegExp;\n hex5?: RegExp;\n hex6?: RegExp;\n hex8?: RegExp;\n};\nfunction getMatchers(): Matchers {\n 'worklet';\n const cachedMatchers: Matchers = _WORKLET\n ? uiCachedMatchers\n : jsCachedMatchers;\n if (cachedMatchers.rgb === undefined) {\n cachedMatchers.rgb = new RegExp('rgb' + call(NUMBER, NUMBER, NUMBER));\n cachedMatchers.rgba = new RegExp(\n 'rgba' + call(NUMBER, NUMBER, NUMBER, NUMBER)\n );\n cachedMatchers.hsl = new RegExp(\n 'hsl' + call(NUMBER, PERCENTAGE, PERCENTAGE)\n );\n cachedMatchers.hsla = new RegExp(\n 'hsla' + call(NUMBER, PERCENTAGE, PERCENTAGE, NUMBER)\n );\n cachedMatchers.hex3 = /^#([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/;\n cachedMatchers.hex4 =\n /^#([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/;\n cachedMatchers.hex6 = /^#([0-9a-fA-F]{6})$/;\n cachedMatchers.hex8 = /^#([0-9a-fA-F]{8})$/;\n }\n return cachedMatchers;\n}\n// cachedMatchers is lazy loaded and it is frozen when worklet is being created,\n// it is possible to call getMatchers() when the object is frozen, then cachedMatchers\n// has no assigned regexes\ngetMatchers();\n\nfunction hue2rgb(p: number, q: number, t: number): number {\n 'worklet';\n if (t < 0) {\n t += 1;\n }\n if (t > 1) {\n t -= 1;\n }\n if (t < 1 / 6) {\n return p + (q - p) * 6 * t;\n }\n if (t < 1 / 2) {\n return q;\n }\n if (t < 2 / 3) {\n return p + (q - p) * (2 / 3 - t) * 6;\n }\n return p;\n}\n\nfunction hslToRgb(h: number, s: number, l: number): number {\n 'worklet';\n const q = l < 0.5 ? l * (1 + s) : l + s - l * s;\n const p = 2 * l - q;\n const r = hue2rgb(p, q, h + 1 / 3);\n const g = hue2rgb(p, q, h);\n const b = hue2rgb(p, q, h - 1 / 3);\n\n return (\n (Math.round(r * 255) << 24) |\n (Math.round(g * 255) << 16) |\n (Math.round(b * 255) << 8)\n );\n}\n\nfunction parse255(str: string): number {\n 'worklet';\n const int = Number.parseInt(str, 10);\n if (int < 0) {\n return 0;\n }\n if (int > 255) {\n return 255;\n }\n return int;\n}\n\nfunction parse360(str: string): number {\n 'worklet';\n const int = Number.parseFloat(str);\n return (((int % 360) + 360) % 360) / 360;\n}\n\nfunction parse1(str: string): number {\n 'worklet';\n const num = Number.parseFloat(str);\n if (num < 0) {\n return 0;\n }\n if (num > 1) {\n return 255;\n }\n return Math.round(num * 255);\n}\n\nfunction parsePercentage(str: string): number {\n 'worklet';\n // parseFloat conveniently ignores the final %\n const int = Number.parseFloat(str);\n if (int < 0) {\n return 0;\n }\n if (int > 100) {\n return 1;\n }\n return int / 100;\n}\n\nconst names: any = !isConfigured()\n ? null\n : makeShareable({\n transparent: 0x00000000,\n\n // http://www.w3.org/TR/css3-color/#svg-color\n aliceblue: 0xf0f8ffff,\n antiquewhite: 0xfaebd7ff,\n aqua: 0x00ffffff,\n aquamarine: 0x7fffd4ff,\n azure: 0xf0ffffff,\n beige: 0xf5f5dcff,\n bisque: 0xffe4c4ff,\n black: 0x000000ff,\n blanchedalmond: 0xffebcdff,\n blue: 0x0000ffff,\n blueviolet: 0x8a2be2ff,\n brown: 0xa52a2aff,\n burlywood: 0xdeb887ff,\n burntsienna: 0xea7e5dff,\n cadetblue: 0x5f9ea0ff,\n chartreuse: 0x7fff00ff,\n chocolate: 0xd2691eff,\n coral: 0xff7f50ff,\n cornflowerblue: 0x6495edff,\n cornsilk: 0xfff8dcff,\n crimson: 0xdc143cff,\n cyan: 0x00ffffff,\n darkblue: 0x00008bff,\n darkcyan: 0x008b8bff,\n darkgoldenrod: 0xb8860bff,\n darkgray: 0xa9a9a9ff,\n darkgreen: 0x006400ff,\n darkgrey: 0xa9a9a9ff,\n darkkhaki: 0xbdb76bff,\n darkmagenta: 0x8b008bff,\n darkolivegreen: 0x556b2fff,\n darkorange: 0xff8c00ff,\n darkorchid: 0x9932ccff,\n darkred: 0x8b0000ff,\n darksalmon: 0xe9967aff,\n darkseagreen: 0x8fbc8fff,\n darkslateblue: 0x483d8bff,\n darkslategray: 0x2f4f4fff,\n darkslategrey: 0x2f4f4fff,\n darkturquoise: 0x00ced1ff,\n darkviolet: 0x9400d3ff,\n deeppink: 0xff1493ff,\n deepskyblue: 0x00bfffff,\n dimgray: 0x696969ff,\n dimgrey: 0x696969ff,\n dodgerblue: 0x1e90ffff,\n firebrick: 0xb22222ff,\n floralwhite: 0xfffaf0ff,\n forestgreen: 0x228b22ff,\n fuchsia: 0xff00ffff,\n gainsboro: 0xdcdcdcff,\n ghostwhite: 0xf8f8ffff,\n gold: 0xffd700ff,\n goldenrod: 0xdaa520ff,\n gray: 0x808080ff,\n green: 0x008000ff,\n greenyellow: 0xadff2fff,\n grey: 0x808080ff,\n honeydew: 0xf0fff0ff,\n hotpink: 0xff69b4ff,\n indianred: 0xcd5c5cff,\n indigo: 0x4b0082ff,\n ivory: 0xfffff0ff,\n khaki: 0xf0e68cff,\n lavender: 0xe6e6faff,\n lavenderblush: 0xfff0f5ff,\n lawngreen: 0x7cfc00ff,\n lemonchiffon: 0xfffacdff,\n lightblue: 0xadd8e6ff,\n lightcoral: 0xf08080ff,\n lightcyan: 0xe0ffffff,\n lightgoldenrodyellow: 0xfafad2ff,\n lightgray: 0xd3d3d3ff,\n lightgreen: 0x90ee90ff,\n lightgrey: 0xd3d3d3ff,\n lightpink: 0xffb6c1ff,\n lightsalmon: 0xffa07aff,\n lightseagreen: 0x20b2aaff,\n lightskyblue: 0x87cefaff,\n lightslategray: 0x778899ff,\n lightslategrey: 0x778899ff,\n lightsteelblue: 0xb0c4deff,\n lightyellow: 0xffffe0ff,\n lime: 0x00ff00ff,\n limegreen: 0x32cd32ff,\n linen: 0xfaf0e6ff,\n magenta: 0xff00ffff,\n maroon: 0x800000ff,\n mediumaquamarine: 0x66cdaaff,\n mediumblue: 0x0000cdff,\n mediumorchid: 0xba55d3ff,\n mediumpurple: 0x9370dbff,\n mediumseagreen: 0x3cb371ff,\n mediumslateblue: 0x7b68eeff,\n mediumspringgreen: 0x00fa9aff,\n mediumturquoise: 0x48d1ccff,\n mediumvioletred: 0xc71585ff,\n midnightblue: 0x191970ff,\n mintcream: 0xf5fffaff,\n mistyrose: 0xffe4e1ff,\n moccasin: 0xffe4b5ff,\n navajowhite: 0xffdeadff,\n navy: 0x000080ff,\n oldlace: 0xfdf5e6ff,\n olive: 0x808000ff,\n olivedrab: 0x6b8e23ff,\n orange: 0xffa500ff,\n orangered: 0xff4500ff,\n orchid: 0xda70d6ff,\n palegoldenrod: 0xeee8aaff,\n palegreen: 0x98fb98ff,\n paleturquoise: 0xafeeeeff,\n palevioletred: 0xdb7093ff,\n papayawhip: 0xffefd5ff,\n peachpuff: 0xffdab9ff,\n peru: 0xcd853fff,\n pink: 0xffc0cbff,\n plum: 0xdda0ddff,\n powderblue: 0xb0e0e6ff,\n purple: 0x800080ff,\n rebeccapurple: 0x663399ff,\n red: 0xff0000ff,\n rosybrown: 0xbc8f8fff,\n royalblue: 0x4169e1ff,\n saddlebrown: 0x8b4513ff,\n salmon: 0xfa8072ff,\n sandybrown: 0xf4a460ff,\n seagreen: 0x2e8b57ff,\n seashell: 0xfff5eeff,\n sienna: 0xa0522dff,\n silver: 0xc0c0c0ff,\n skyblue: 0x87ceebff,\n slateblue: 0x6a5acdff,\n slategray: 0x708090ff,\n slategrey: 0x708090ff,\n snow: 0xfffafaff,\n springgreen: 0x00ff7fff,\n steelblue: 0x4682b4ff,\n tan: 0xd2b48cff,\n teal: 0x008080ff,\n thistle: 0xd8bfd8ff,\n tomato: 0xff6347ff,\n turquoise: 0x40e0d0ff,\n violet: 0xee82eeff,\n wheat: 0xf5deb3ff,\n white: 0xffffffff,\n whitesmoke: 0xf5f5f5ff,\n yellow: 0xffff00ff,\n yellowgreen: 0x9acd32ff,\n });\n\nfunction normalizeColor(color: unknown): number | null {\n 'worklet';\n\n if (typeof color === 'number') {\n if (color >>> 0 === color && color >= 0 && color <= 0xffffffff) {\n return color;\n }\n return null;\n }\n\n if (typeof color !== 'string') {\n return null;\n }\n\n const matchers = getMatchers();\n\n let match: RegExpExecArray | null | undefined;\n\n // Ordered based on occurrences on Facebook codebase\n if ((match = matchers?.hex6?.exec(color))) {\n return Number.parseInt(match[1] + 'ff', 16) >>> 0;\n }\n\n if (names[color] !== undefined) {\n return names[color];\n }\n\n if ((match = matchers?.rgb?.exec(color))) {\n return (\n // b\n ((parse255(match[1]) << 24) | // r\n (parse255(match[2]) << 16) | // g\n (parse255(match[3]) << 8) |\n 0x000000ff) >>> // a\n 0\n );\n }\n\n if ((match = matchers?.rgba?.exec(color))) {\n return (\n // b\n ((parse255(match[1]) << 24) | // r\n (parse255(match[2]) << 16) | // g\n (parse255(match[3]) << 8) |\n parse1(match[4])) >>> // a\n 0\n );\n }\n\n if ((match = matchers?.hex3?.exec(color))) {\n return (\n Number.parseInt(\n match[1] +\n match[1] + // r\n match[2] +\n match[2] + // g\n match[3] +\n match[3] + // b\n 'ff', // a\n 16\n ) >>> 0\n );\n }\n\n // https://drafts.csswg.org/css-color-4/#hex-notation\n if ((match = matchers?.hex8?.exec(color))) {\n return Number.parseInt(match[1], 16) >>> 0;\n }\n\n if ((match = matchers?.hex4?.exec(color))) {\n return (\n Number.parseInt(\n match[1] +\n match[1] + // r\n match[2] +\n match[2] + // g\n match[3] +\n match[3] + // b\n match[4] +\n match[4], // a\n 16\n ) >>> 0\n );\n }\n\n if ((match = matchers?.hsl?.exec(color))) {\n return (\n (hslToRgb(\n parse360(match[1]), // h\n parsePercentage(match[2]), // s\n parsePercentage(match[3]) // l\n ) |\n 0x000000ff) >>> // a\n 0\n );\n }\n\n if ((match = matchers?.hsla?.exec(color))) {\n return (\n (hslToRgb(\n parse360(match[1]), // h\n parsePercentage(match[2]), // s\n parsePercentage(match[3]) // l\n ) |\n parse1(match[4])) >>> // a\n 0\n );\n }\n\n return null;\n}\n\nexport const opacity = (c: number): number => {\n 'worklet';\n return ((c >> 24) & 255) / 255;\n};\n\nexport const red = (c: number): number => {\n 'worklet';\n return (c >> 16) & 255;\n};\n\nexport const green = (c: number): number => {\n 'worklet';\n return (c >> 8) & 255;\n};\n\nexport const blue = (c: number): number => {\n 'worklet';\n return c & 255;\n};\n\nexport const rgbaColor = (\n r: number,\n g: number,\n b: number,\n alpha = 1\n): number | string => {\n 'worklet';\n if (Platform.OS === 'web' || !_WORKLET) {\n return `rgba(${r}, ${g}, ${b}, ${alpha})`;\n }\n\n const c =\n Math.round(alpha * 255) * (1 << 24) +\n Math.round(r) * (1 << 16) +\n Math.round(g) * (1 << 8) +\n Math.round(b);\n if (Platform.OS === 'android') {\n // on Android color is represented as signed 32 bit int\n return c < (1 << 31) >>> 0 ? c : c - 4294967296; // 4294967296 == Math.pow(2, 32);\n }\n return c;\n};\n\n/* accepts parameters\n * r Object = {r:x, g:y, b:z}\n * OR\n * r, g, b\n * 0 <= r, g, b <= 255\n * returns 0 <= h, s, v <= 1\n */\nexport function RGBtoHSV(rgb: RGB): HSV;\nexport function RGBtoHSV(r: number, g: number, b: number): HSV;\nexport function RGBtoHSV(r: any, g?: any, b?: any): HSV {\n 'worklet';\n /* eslint-disable */\n if (arguments.length === 1) {\n g = r.g;\n b = r.b;\n r = r.r;\n }\n const max = Math.max(r, g, b);\n const min = Math.min(r, g, b);\n const d = max - min;\n const s = max === 0 ? 0 : d / max;\n const v = max / 255;\n\n let h;\n\n switch (max) {\n default:\n /* fallthrough */\n case min:\n h = 0;\n break;\n case r:\n h = g - b + d * (g < b ? 6 : 0);\n h /= 6 * d;\n break;\n case g:\n h = b - r + d * 2;\n h /= 6 * d;\n break;\n case b:\n h = r - g + d * 4;\n h /= 6 * d;\n break;\n }\n\n return {\n h: h,\n s: s,\n v: v,\n };\n /* eslint-enable */\n}\n\n/* accepts parameters\n * h Object = {h:x, s:y, v:z}\n * OR\n * h, s, v\n * 0 <= h, s, v <= 1\n * returns 0 <= r, g, b <= 255\n */\nfunction HSVtoRGB(hsv: HSV): RGB;\nfunction HSVtoRGB(h: number, s: number, v: number): RGB;\nfunction HSVtoRGB(h: any, s?: any, v?: any) {\n 'worklet';\n /* eslint-disable */\n var r, g, b, i, f, p, q, t;\n if (arguments.length === 1) {\n s = h.s;\n v = h.v;\n h = h.h;\n }\n i = Math.floor(h * 6);\n f = h * 6 - i;\n p = v * (1 - s);\n q = v * (1 - f * s);\n t = v * (1 - (1 - f) * s);\n switch (i % 6) {\n case 0:\n (r = v), (g = t), (b = p);\n break;\n case 1:\n (r = q), (g = v), (b = p);\n break;\n case 2:\n (r = p), (g = v), (b = t);\n break;\n case 3:\n (r = p), (g = q), (b = v);\n break;\n case 4:\n (r = t), (g = p), (b = v);\n break;\n case 5:\n (r = v), (g = p), (b = q);\n break;\n }\n return {\n r: Math.round(r * 255),\n g: Math.round(g * 255),\n b: Math.round(b * 255),\n };\n /* eslint-enable */\n}\n\nexport const hsvToColor = (\n h: number,\n s: number,\n v: number,\n a: number\n): number | string => {\n 'worklet';\n const { r, g, b } = HSVtoRGB(h, s, v);\n return rgbaColor(r, g, b, a);\n};\n\nexport function processColorInitially(\n color: unknown\n): number | null | undefined {\n 'worklet';\n if (color === null || color === undefined || typeof color === 'number') {\n return color;\n }\n\n let normalizedColor = normalizeColor(color);\n\n if (normalizedColor === null || normalizedColor === undefined) {\n return undefined;\n }\n\n if (typeof normalizedColor !== 'number') {\n return null;\n }\n\n normalizedColor = ((normalizedColor << 24) | (normalizedColor >>> 8)) >>> 0; // argb\n return normalizedColor;\n}\n\nexport function isColor(value: unknown): boolean {\n 'worklet';\n if (typeof value !== 'string') {\n return false;\n }\n return processColorInitially(value) != null;\n}\n\nexport function processColor(color: unknown): number | null | undefined {\n 'worklet';\n let normalizedColor = processColorInitially(color);\n if (normalizedColor === null || normalizedColor === undefined) {\n return undefined;\n }\n\n if (typeof normalizedColor !== 'number') {\n return null;\n }\n\n if (Platform.OS === 'android') {\n // Android use 32 bit *signed* integer to represent the color\n // We utilize the fact that bitwise operations in JS also operates on\n // signed 32 bit integers, so that we can use those to convert from\n // *unsigned* to *signed* 32bit int that way.\n normalizedColor = normalizedColor | 0x0;\n }\n\n return normalizedColor;\n}\n\nexport type ParsedColorArray = [number, number, number, number];\n\nexport function convertToRGBA(color: unknown): ParsedColorArray {\n 'worklet';\n const processedColor = processColorInitially(color)!; // argb;\n const a = (processedColor >>> 24) / 255;\n const r = ((processedColor << 8) >>> 24) / 255;\n const g = ((processedColor << 16) >>> 24) / 255;\n const b = ((processedColor << 24) >>> 24) / 255;\n return [r, g, b, a];\n}\n\nexport function rgbaArrayToRGBAColor(RGBA: ParsedColorArray): string {\n 'worklet';\n return `rgba(${Math.round(RGBA[0] * 255)}, ${Math.round(\n RGBA[1] * 255\n )}, ${Math.round(RGBA[2] * 255)}, ${RGBA[3]})`;\n}\n\nexport function toLinearSpace(\n RGBA: ParsedColorArray,\n gamma = 2.2\n): ParsedColorArray {\n 'worklet';\n const res = [];\n for (let i = 0; i < 3; ++i) {\n res.push(Math.pow(RGBA[i], gamma));\n }\n res.push(RGBA[3]);\n return res as ParsedColorArray;\n}\n\nexport function toGammaSpace(\n RGBA: ParsedColorArray,\n gamma = 2.2\n): ParsedColorArray {\n 'worklet';\n const res = [];\n for (let i = 0; i < 3; ++i) {\n res.push(Math.pow(RGBA[i], 1 / gamma));\n }\n res.push(RGBA[3]);\n return res as ParsedColorArray;\n}\n","/* global _updatePropsPaper _updatePropsFabric */\nimport { MutableRefObject } from 'react';\nimport { processColor } from './Colors';\nimport { AnimatedStyle, SharedValue, StyleProps } from './commonTypes';\nimport { makeShareable, isConfigured } from './core';\nimport { Descriptor } from './hook/commonTypes';\nimport { _updatePropsJS } from './js-reanimated';\nimport { shouldBeUseWeb } from './PlatformChecker';\nimport { ViewRefSet } from './ViewDescriptorsSet';\n\n// copied from react-native/Libraries/Components/View/ReactNativeStyleAttributes\nexport const colorProps = [\n 'backgroundColor',\n 'borderBottomColor',\n 'borderColor',\n 'borderLeftColor',\n 'borderRightColor',\n 'borderTopColor',\n 'borderStartColor',\n 'borderEndColor',\n 'color',\n 'shadowColor',\n 'textDecorationColor',\n 'tintColor',\n 'textShadowColor',\n 'overlayColor',\n];\n\nexport const ColorProperties = !isConfigured() ? [] : makeShareable(colorProps);\n\nlet updatePropsByPlatform;\nif (shouldBeUseWeb()) {\n updatePropsByPlatform = (\n _: SharedValue,\n updates: StyleProps | AnimatedStyle,\n maybeViewRef: ViewRefSet | undefined\n ): void => {\n 'worklet';\n if (maybeViewRef) {\n maybeViewRef.items.forEach((item, _) => {\n _updatePropsJS(updates, item);\n });\n }\n };\n} else {\n if (global._IS_FABRIC) {\n updatePropsByPlatform = (\n viewDescriptors: SharedValue,\n updates: StyleProps | AnimatedStyle,\n _: ViewRefSet | undefined\n ): void => {\n 'worklet';\n\n for (const key in updates) {\n if (ColorProperties.indexOf(key) !== -1) {\n updates[key] = processColor(updates[key]);\n }\n }\n\n viewDescriptors.value.forEach((viewDescriptor) => {\n _updatePropsFabric(viewDescriptor.shadowNodeWrapper, updates);\n });\n };\n } else {\n updatePropsByPlatform = (\n viewDescriptors: SharedValue,\n updates: StyleProps | AnimatedStyle,\n _: ViewRefSet | undefined\n ): void => {\n 'worklet';\n\n for (const key in updates) {\n if (ColorProperties.indexOf(key) !== -1) {\n updates[key] = processColor(updates[key]);\n }\n }\n viewDescriptors.value.forEach((viewDescriptor) => {\n _updatePropsPaper(\n viewDescriptor.tag,\n viewDescriptor.name || 'RCTView',\n updates\n );\n });\n };\n }\n}\n\nexport const updateProps: (\n viewDescriptor: SharedValue,\n updates: StyleProps | AnimatedStyle,\n maybeViewRef: ViewRefSet | undefined\n) => void = updatePropsByPlatform;\n\nexport const updatePropsJestWrapper = (\n viewDescriptors: SharedValue,\n updates: AnimatedStyle,\n maybeViewRef: ViewRefSet | undefined,\n animatedStyle: MutableRefObject,\n adapters: ((updates: AnimatedStyle) => void)[]\n): void => {\n adapters.forEach((adapter) => {\n adapter(updates);\n });\n animatedStyle.current.value = {\n ...animatedStyle.current.value,\n ...updates,\n };\n\n updateProps(viewDescriptors, updates, maybeViewRef);\n};\n\nexport default updateProps;\n","import { Easing, EasingFn, EasingFactoryFn } from '../Easing';\nimport { defineAnimation } from './util';\nimport {\n Animation,\n AnimationCallback,\n Timestamp,\n AnimatableValue,\n} from '../commonTypes';\n\ninterface TimingConfig {\n duration?: number;\n easing?: EasingFn | EasingFactoryFn;\n}\n\nexport interface TimingAnimation extends Animation {\n type: string;\n easing: EasingFn;\n startValue: AnimatableValue;\n startTime: Timestamp;\n progress: number;\n toValue: AnimatableValue;\n current: AnimatableValue;\n}\n\nexport interface InnerTimingAnimation\n extends Omit {\n toValue: number;\n current: number;\n}\n\nexport function withTiming(\n toValue: AnimatableValue,\n userConfig?: TimingConfig,\n callback?: AnimationCallback\n): Animation {\n 'worklet';\n\n return defineAnimation(toValue, () => {\n 'worklet';\n const config: Required = {\n duration: 300,\n easing: Easing.inOut(Easing.quad),\n };\n if (userConfig) {\n Object.keys(userConfig).forEach(\n (key) =>\n ((config as any)[key] = userConfig[key as keyof typeof userConfig])\n );\n }\n\n function timing(animation: InnerTimingAnimation, now: Timestamp): boolean {\n const { toValue, startTime, startValue } = animation;\n const runtime = now - startTime;\n\n if (runtime >= config.duration) {\n // reset startTime to avoid reusing finished animation config in `start` method\n animation.startTime = 0;\n animation.current = toValue;\n return true;\n }\n const progress = animation.easing(runtime / config.duration);\n animation.current =\n (startValue as number) + (toValue - (startValue as number)) * progress;\n return false;\n }\n\n function onStart(\n animation: TimingAnimation,\n value: number,\n now: Timestamp,\n previousAnimation: Animation\n ): void {\n if (\n previousAnimation &&\n (previousAnimation as TimingAnimation).type === 'timing' &&\n (previousAnimation as TimingAnimation).toValue === toValue &&\n (previousAnimation as TimingAnimation).startTime\n ) {\n // to maintain continuity of timing animations we check if we are starting\n // new timing over the old one with the same parameters. If so, we want\n // to copy animation timeline properties\n animation.startTime = (previousAnimation as TimingAnimation).startTime;\n animation.startValue = (\n previousAnimation as TimingAnimation\n ).startValue;\n } else {\n animation.startTime = now;\n animation.startValue = value;\n }\n animation.current = value;\n if (typeof config.easing === 'object') {\n animation.easing = config.easing.factory();\n } else {\n animation.easing = config.easing;\n }\n }\n\n return {\n type: 'timing',\n onFrame: timing,\n onStart: onStart as (animation: TimingAnimation, now: number) => boolean,\n progress: 0,\n toValue,\n startValue: 0,\n startTime: 0,\n easing: () => 0,\n current: toValue,\n callback,\n } as TimingAnimation;\n });\n}\n","import { Bezier } from './Bezier';\n\n/**\n * The `Easing` module implements common easing functions. This module is used\n * by [Animate.timing()](docs/animate.html#timing) to convey physically\n * believable motion in animations.\n *\n * You can find a visualization of some common easing functions at\n * http://easings.net/\n *\n * ### Predefined animations\n *\n * The `Easing` module provides several predefined animations through the\n * following methods:\n *\n * - [`back`](docs/easing.html#back) provides a simple animation where the\n * object goes slightly back before moving forward\n * - [`bounce`](docs/easing.html#bounce) provides a bouncing animation\n * - [`ease`](docs/easing.html#ease) provides a simple inertial animation\n * - [`elastic`](docs/easing.html#elastic) provides a simple spring interaction\n *\n * ### Standard functions\n *\n * Three standard easing functions are provided:\n *\n * - [`linear`](docs/easing.html#linear)\n * - [`quad`](docs/easing.html#quad)\n * - [`cubic`](docs/easing.html#cubic)\n *\n * The [`poly`](docs/easing.html#poly) function can be used to implement\n * quartic, quintic, and other higher power functions.\n *\n * ### Additional functions\n *\n * Additional mathematical functions are provided by the following methods:\n *\n * - [`bezier`](docs/easing.html#bezier) provides a cubic bezier curve\n * - [`circle`](docs/easing.html#circle) provides a circular function\n * - [`sin`](docs/easing.html#sin) provides a sinusoidal function\n * - [`exp`](docs/easing.html#exp) provides an exponential function\n *\n * The following helpers are used to modify other easing functions.\n *\n * - [`in`](docs/easing.html#in) runs an easing function forwards\n * - [`inOut`](docs/easing.html#inout) makes any easing function symmetrical\n * - [`out`](docs/easing.html#out) runs an easing function backwards\n */\n\nexport type EasingFn = (t: number) => number;\n\nexport type EasingFactoryFn = { factory: () => EasingFn };\n/**\n * A linear function, `f(t) = t`. Position correlates to elapsed time one to\n * one.\n *\n * http://cubic-bezier.com/#0,0,1,1\n */\nfunction linear(t: number): number {\n 'worklet';\n return t;\n}\n\n/**\n * A simple inertial interaction, similar to an object slowly accelerating to\n * speed.\n *\n * http://cubic-bezier.com/#.42,0,1,1\n */\nfunction ease(t: number): number {\n 'worklet';\n return Bezier(0.42, 0, 1, 1)(t);\n}\n\n/**\n * A quadratic function, `f(t) = t * t`. Position equals the square of elapsed\n * time.\n *\n * http://easings.net/#easeInQuad\n */\nfunction quad(t: number): number {\n 'worklet';\n return t * t;\n}\n\n/**\n * A cubic function, `f(t) = t * t * t`. Position equals the cube of elapsed\n * time.\n *\n * http://easings.net/#easeInCubic\n */\nfunction cubic(t: number): number {\n 'worklet';\n return t * t * t;\n}\n\n/**\n * A power function. Position is equal to the Nth power of elapsed time.\n *\n * n = 4: http://easings.net/#easeInQuart\n * n = 5: http://easings.net/#easeInQuint\n */\nfunction poly(n: number): EasingFn {\n 'worklet';\n return (t) => {\n 'worklet';\n return Math.pow(t, n);\n };\n}\n\n/**\n * A sinusoidal function.\n *\n * http://easings.net/#easeInSine\n */\nfunction sin(t: number): number {\n 'worklet';\n return 1 - Math.cos((t * Math.PI) / 2);\n}\n\n/**\n * A circular function.\n *\n * http://easings.net/#easeInCirc\n */\nfunction circle(t: number): number {\n 'worklet';\n return 1 - Math.sqrt(1 - t * t);\n}\n\n/**\n * An exponential function.\n *\n * http://easings.net/#easeInExpo\n */\nfunction exp(t: number): number {\n 'worklet';\n return Math.pow(2, 10 * (t - 1));\n}\n\n/**\n * A simple elastic interaction, similar to a spring oscillating back and\n * forth.\n *\n * Default bounciness is 1, which overshoots a little bit once. 0 bounciness\n * doesn't overshoot at all, and bounciness of N > 1 will overshoot about N\n * times.\n *\n * http://easings.net/#easeInElastic\n */\nfunction elastic(bounciness = 1): EasingFn {\n 'worklet';\n const p = bounciness * Math.PI;\n return (t) => {\n 'worklet';\n return 1 - Math.pow(Math.cos((t * Math.PI) / 2), 3) * Math.cos(t * p);\n };\n}\n\n/**\n * Use with `Animated.parallel()` to create a simple effect where the object\n * animates back slightly as the animation starts.\n *\n * Wolfram Plot:\n *\n * - http://tiny.cc/back_default (s = 1.70158, default)\n */\nfunction back(s = 1.70158): (t: number) => number {\n 'worklet';\n return (t) => {\n 'worklet';\n return t * t * ((s + 1) * t - s);\n };\n}\n\n/**\n * Provides a simple bouncing effect.\n *\n * http://easings.net/#easeInBounce\n */\nfunction bounce(t: number): number {\n 'worklet';\n if (t < 1 / 2.75) {\n return 7.5625 * t * t;\n }\n\n if (t < 2 / 2.75) {\n const t2 = t - 1.5 / 2.75;\n return 7.5625 * t2 * t2 + 0.75;\n }\n\n if (t < 2.5 / 2.75) {\n const t2 = t - 2.25 / 2.75;\n return 7.5625 * t2 * t2 + 0.9375;\n }\n\n const t2 = t - 2.625 / 2.75;\n return 7.5625 * t2 * t2 + 0.984375;\n}\n\n/**\n * Provides a cubic bezier curve, equivalent to CSS Transitions'\n * `transition-timing-function`.\n *\n * A useful tool to visualize cubic bezier curves can be found at\n * http://cubic-bezier.com/\n */\nfunction bezier(\n x1: number,\n y1: number,\n x2: number,\n y2: number\n): { factory: () => (x: number) => number } {\n 'worklet';\n return {\n factory: () => {\n 'worklet';\n return Bezier(x1, y1, x2, y2);\n },\n };\n}\n\nfunction bezierFn(\n x1: number,\n y1: number,\n x2: number,\n y2: number\n): (x: number) => number {\n 'worklet';\n return Bezier(x1, y1, x2, y2);\n}\n\n/**\n * Runs an easing function forwards.\n */\nfunction in_(easing: EasingFn): EasingFn {\n 'worklet';\n return easing;\n}\n\n/**\n * Runs an easing function backwards.\n */\nfunction out(easing: EasingFn): EasingFn {\n 'worklet';\n return (t) => {\n 'worklet';\n return 1 - easing(1 - t);\n };\n}\n\n/**\n * Makes any easing function symmetrical. The easing function will run\n * forwards for half of the duration, then backwards for the rest of the\n * duration.\n */\nfunction inOut(easing: EasingFn): EasingFn {\n 'worklet';\n return (t) => {\n 'worklet';\n if (t < 0.5) {\n return easing(t * 2) / 2;\n }\n return 1 - easing((1 - t) * 2) / 2;\n };\n}\n\nconst EasingObject = {\n linear,\n ease,\n quad,\n cubic,\n poly,\n sin,\n circle,\n exp,\n elastic,\n back,\n bounce,\n bezier,\n bezierFn,\n in: in_,\n out,\n inOut,\n};\n\nexport const Easing = EasingObject;\n","/**\n * https://github.com/gre/bezier-easing\n * BezierEasing - use bezier curve for transition easing function\n * by Gaëtan Renaudeau 2014 - 2015 – MIT License\n */\n\n// These values are established by empiricism with tests (tradeoff: performance VS precision)\n\nexport function Bezier(\n mX1: number,\n mY1: number,\n mX2: number,\n mY2: number\n): (x: number) => number {\n 'worklet';\n\n const NEWTON_ITERATIONS = 4;\n const NEWTON_MIN_SLOPE = 0.001;\n const SUBDIVISION_PRECISION = 0.0000001;\n const SUBDIVISION_MAX_ITERATIONS = 10;\n\n const kSplineTableSize = 11;\n const kSampleStepSize = 1.0 / (kSplineTableSize - 1.0);\n\n function A(aA1: number, aA2: number): number {\n 'worklet';\n return 1.0 - 3.0 * aA2 + 3.0 * aA1;\n }\n function B(aA1: number, aA2: number): number {\n 'worklet';\n return 3.0 * aA2 - 6.0 * aA1;\n }\n function C(aA1: number) {\n 'worklet';\n return 3.0 * aA1;\n }\n\n // Returns x(t) given t, x1, and x2, or y(t) given t, y1, and y2.\n function calcBezier(aT: number, aA1: number, aA2: number): number {\n 'worklet';\n return ((A(aA1, aA2) * aT + B(aA1, aA2)) * aT + C(aA1)) * aT;\n }\n\n // Returns dx/dt given t, x1, and x2, or dy/dt given t, y1, and y2.\n function getSlope(aT: number, aA1: number, aA2: number): number {\n 'worklet';\n return 3.0 * A(aA1, aA2) * aT * aT + 2.0 * B(aA1, aA2) * aT + C(aA1);\n }\n\n function binarySubdivide(\n aX: number,\n aA: number,\n aB: number,\n mX1: number,\n mX2: number\n ): number {\n 'worklet';\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 (\n Math.abs(currentX) > SUBDIVISION_PRECISION &&\n ++i < SUBDIVISION_MAX_ITERATIONS\n );\n return currentT;\n }\n\n function newtonRaphsonIterate(\n aX: number,\n aGuessT: number,\n mX1: number,\n mX2: number\n ): number {\n 'worklet';\n for (let i = 0; i < NEWTON_ITERATIONS; ++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\n function LinearEasing(x: number): number {\n 'worklet';\n return x;\n }\n\n if (!(mX1 >= 0 && mX1 <= 1 && mX2 >= 0 && mX2 <= 1)) {\n throw new Error('bezier x values must be in [0, 1] range');\n }\n\n if (mX1 === mY1 && mX2 === mY2) {\n return LinearEasing;\n }\n\n // FIXME: Float32Array is not available in Hermes right now\n //\n // var float32ArraySupported = typeof Float32Array === 'function';\n // const sampleValues = float32ArraySupported\n // ? new Float32Array(kSplineTableSize)\n // : new Array(kSplineTableSize);\n\n // Precompute samples table\n const sampleValues = new Array(kSplineTableSize);\n\n for (let i = 0; i < kSplineTableSize; ++i) {\n sampleValues[i] = calcBezier(i * kSampleStepSize, mX1, mX2);\n }\n\n function getTForX(aX: number): number {\n 'worklet';\n let intervalStart = 0.0;\n let currentSample = 1;\n const lastSample = kSplineTableSize - 1;\n\n for (\n ;\n currentSample !== lastSample && sampleValues[currentSample] <= aX;\n ++currentSample\n ) {\n intervalStart += kSampleStepSize;\n }\n --currentSample;\n\n // Interpolate to provide an initial guess for t\n const dist =\n (aX - sampleValues[currentSample]) /\n (sampleValues[currentSample + 1] - sampleValues[currentSample]);\n const guessForT = intervalStart + dist * kSampleStepSize;\n\n const initialSlope = getSlope(guessForT, mX1, mX2);\n if (initialSlope >= NEWTON_MIN_SLOPE) {\n return newtonRaphsonIterate(aX, guessForT, mX1, mX2);\n } else if (initialSlope === 0.0) {\n return guessForT;\n } else {\n return binarySubdivide(\n aX,\n intervalStart,\n intervalStart + kSampleStepSize,\n mX1,\n mX2\n );\n }\n }\n\n return function BezierEasing(x) {\n 'worklet';\n if (mX1 === mY1 && mX2 === mY2) {\n return x; // linear\n }\n // Because JavaScript number are imprecise, we should guarantee the extremes are right.\n if (x === 0) {\n return 0;\n }\n if (x === 1) {\n return 1;\n }\n return calcBezier(getTForX(x), mY1, mY2);\n };\n}\n","/* eslint-disable camelcase */\n\nimport { ShadowNodeWrapper } from './commonTypes';\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nlet findHostInstance_DEPRECATED = (_ref: React.Component) => null;\n\ntry {\n // eslint-disable-next-line @typescript-eslint/no-var-requires\n findHostInstance_DEPRECATED =\n require('react-native/Libraries/Renderer/shims/ReactFabric').findHostInstance_DEPRECATED;\n} catch (e) {\n // do nothing\n}\n\nexport function getShadowNodeWrapperFromHostInstance(\n hostInstance: unknown\n): ShadowNodeWrapper {\n // @ts-ignore Fabric\n return hostInstance._internalInstanceHandle.stateNode.node;\n}\n\nexport function getShadowNodeWrapperFromRef(\n ref: React.Component\n): ShadowNodeWrapper {\n return getShadowNodeWrapperFromHostInstance(findHostInstance_DEPRECATED(ref));\n}\n","// eslint-disable-next-line @typescript-eslint/ban-ts-comment\n// @ts-nocheck\nexport { default as RNRenderer } from 'react-native/Libraries/Renderer/shims/ReactNative';\n","export type {\n HigherOrderAnimation,\n NextAnimation,\n DelayAnimation,\n RepeatAnimation,\n SequenceAnimation,\n StyleLayoutAnimation,\n} from './commonTypes';\nexport { cancelAnimation, defineAnimation, initialUpdaterRun } from './util';\nexport { withTiming } from './timing';\nexport type { TimingAnimation } from './timing';\nexport { withSpring } from './spring';\nexport type { SpringAnimation } from './spring';\nexport { withDecay } from './decay';\nexport type { DecayAnimation } from './decay';\nexport { withDelay } from './delay';\nexport { withRepeat } from './repeat';\nexport { withSequence } from './sequence';\nexport { withStyleAnimation } from './styleAnimation';\n","import { defineAnimation } from './util';\nimport {\n Animation,\n AnimationCallback,\n AnimationObject,\n AnimatableValue,\n Timestamp,\n} from '../commonTypes';\nimport { Platform } from 'react-native';\n\ninterface DecayConfig {\n deceleration?: number;\n velocityFactor?: number;\n clamp?: number[];\n velocity?: number;\n}\n\ninterface DefaultDecayConfig {\n deceleration: number;\n velocityFactor: number;\n clamp?: number[];\n velocity: number;\n rubberBandEffect?: boolean;\n rubberBandFactor: number;\n}\n\nexport interface DecayAnimation extends Animation {\n lastTimestamp: Timestamp;\n startTimestamp: Timestamp;\n initialVelocity: number;\n velocity: number;\n current: AnimatableValue;\n}\n\nexport interface InnerDecayAnimation\n extends Omit,\n AnimationObject {\n current: number;\n}\n\nexport function withDecay(\n userConfig: DecayConfig,\n callback?: AnimationCallback\n): Animation {\n 'worklet';\n\n return defineAnimation(0, () => {\n 'worklet';\n const config: DefaultDecayConfig = {\n deceleration: 0.998,\n velocityFactor: Platform.OS !== 'web' ? 1 : 1000,\n velocity: 0,\n rubberBandFactor: 0.6,\n };\n if (userConfig) {\n Object.keys(userConfig).forEach(\n (key) =>\n ((config as any)[key] = userConfig[key as keyof typeof userConfig])\n );\n }\n\n const VELOCITY_EPS = Platform.OS !== 'web' ? 1 : 1 / 20;\n const SLOPE_FACTOR = 0.1;\n\n let decay: (animation: InnerDecayAnimation, now: number) => boolean;\n\n if (config.rubberBandEffect) {\n decay = (animation: InnerDecayAnimation, now: number): boolean => {\n const {\n lastTimestamp,\n startTimestamp,\n current,\n initialVelocity,\n velocity,\n } = animation;\n\n const deltaTime = Math.min(now - lastTimestamp, 64);\n const clampIndex = initialVelocity > 0 ? 1 : 0;\n let derivative = 0;\n if (current < config.clamp![0] || current > config.clamp![1]) {\n derivative = current - config.clamp![clampIndex];\n }\n\n if (derivative !== 0) {\n animation.springActive = true;\n } else if (derivative === 0 && animation.springActive) {\n animation.current = config.clamp![clampIndex];\n return true;\n }\n\n const v =\n velocity *\n Math.exp(\n -(1 - config.deceleration) * (now - startTimestamp) * SLOPE_FACTOR\n ) -\n derivative * config.rubberBandFactor;\n\n animation.current =\n current + (v * config.velocityFactor * deltaTime) / 1000;\n animation.velocity = v;\n animation.lastTimestamp = now;\n return false;\n };\n } else {\n decay = (animation: InnerDecayAnimation, now: number): boolean => {\n const {\n lastTimestamp,\n startTimestamp,\n initialVelocity,\n current,\n velocity,\n } = animation;\n\n const deltaTime = Math.min(now - lastTimestamp, 64);\n const v =\n velocity *\n Math.exp(\n -(1 - config.deceleration) * (now - startTimestamp) * SLOPE_FACTOR\n );\n animation.current =\n current + (v * config.velocityFactor * deltaTime) / 1000;\n animation.velocity = v;\n animation.lastTimestamp = now;\n\n if (config.clamp) {\n if (initialVelocity < 0 && animation.current <= config.clamp[0]) {\n animation.current = config.clamp[0];\n return true;\n } else if (\n initialVelocity > 0 &&\n animation.current >= config.clamp[1]\n ) {\n animation.current = config.clamp[1];\n return true;\n }\n }\n\n return Math.abs(v) < VELOCITY_EPS;\n };\n }\n\n function validateConfig(): void {\n if (config.clamp) {\n if (!Array.isArray(config.clamp)) {\n throw Error(\n `config.clamp must be an array but is ${typeof config.clamp}`\n );\n }\n if (config.clamp.length !== 2) {\n throw Error(\n `clamp array must contain 2 items but is given ${config.clamp.length}`\n );\n }\n }\n if (config.velocityFactor <= 0) {\n throw Error(\n `config.velocityFactor must be greather then 0 but is ${config.velocityFactor}`\n );\n }\n if (config.rubberBandEffect && !config.clamp) {\n throw Error(\n 'You need to set `clamp` property when using `rubberBandEffect`.'\n );\n }\n }\n\n function onStart(\n animation: DecayAnimation,\n value: number,\n now: Timestamp\n ): void {\n animation.current = value;\n animation.lastTimestamp = now;\n animation.startTimestamp = now;\n animation.initialVelocity = config.velocity;\n validateConfig();\n }\n\n return {\n onFrame: decay,\n onStart,\n callback,\n velocity: config.velocity ?? 0,\n initialVelocity: 0,\n current: 0,\n lastTimestamp: 0,\n startTimestamp: 0,\n } as DecayAnimation;\n });\n}\n","import { defineAnimation } from './util';\nimport { Animation, Timestamp, AnimatableValue } from '../commonTypes';\nimport { NextAnimation, DelayAnimation } from './commonTypes';\n\nexport function withDelay(\n delayMs: number,\n _nextAnimation: NextAnimation\n): Animation {\n 'worklet';\n return defineAnimation(_nextAnimation, () => {\n 'worklet';\n const nextAnimation =\n typeof _nextAnimation === 'function' ? _nextAnimation() : _nextAnimation;\n\n function delay(animation: DelayAnimation, now: Timestamp): boolean {\n const { startTime, started, previousAnimation } = animation;\n\n if (now - startTime > delayMs) {\n if (!started) {\n nextAnimation.onStart(\n nextAnimation,\n animation.current,\n now,\n previousAnimation as DelayAnimation\n );\n animation.previousAnimation = null;\n animation.started = true;\n }\n const finished = nextAnimation.onFrame(nextAnimation, now);\n animation.current = nextAnimation.current;\n return finished;\n } else if (previousAnimation) {\n const finished =\n previousAnimation.finished ||\n previousAnimation.onFrame(previousAnimation, now);\n animation.current = previousAnimation.current;\n if (finished) {\n animation.previousAnimation = null;\n }\n }\n return false;\n }\n\n function onStart(\n animation: DelayAnimation,\n value: AnimatableValue,\n now: Timestamp,\n previousAnimation: DelayAnimation\n ): void {\n animation.startTime = now;\n animation.started = false;\n animation.current = value;\n if (previousAnimation === animation) {\n animation.previousAnimation = previousAnimation.previousAnimation;\n } else {\n animation.previousAnimation = previousAnimation;\n }\n }\n\n const callback = (finished?: boolean): void => {\n if (nextAnimation.callback) {\n nextAnimation.callback(finished);\n }\n };\n\n return {\n isHigherOrder: true,\n onFrame: delay,\n onStart,\n current: nextAnimation.current,\n callback,\n previousAnimation: null,\n startTime: 0,\n started: false,\n };\n });\n}\n","import { defineAnimation } from './util';\nimport {\n Animation,\n AnimationCallback,\n AnimatableValue,\n Timestamp,\n} from '../commonTypes';\nimport { NextAnimation, RepeatAnimation } from './commonTypes';\n\nexport interface InnerRepeatAnimation\n extends Omit {\n toValue: number;\n startValue: number;\n}\n\nexport function withRepeat(\n _nextAnimation: NextAnimation,\n numberOfReps = 2,\n reverse = false,\n callback?: AnimationCallback\n): Animation {\n 'worklet';\n\n return defineAnimation(_nextAnimation, () => {\n 'worklet';\n\n const nextAnimation: RepeatAnimation =\n typeof _nextAnimation === 'function' ? _nextAnimation() : _nextAnimation;\n\n function repeat(animation: InnerRepeatAnimation, now: Timestamp): boolean {\n const finished = nextAnimation.onFrame(nextAnimation, now);\n animation.current = nextAnimation.current;\n if (finished) {\n animation.reps += 1;\n // call inner animation's callback on every repetition\n // as the second argument the animation's current value is passed\n if (nextAnimation.callback) {\n nextAnimation.callback(true /* finished */, animation.current);\n }\n if (numberOfReps > 0 && animation.reps >= numberOfReps) {\n return true;\n }\n\n const startValue = reverse\n ? (nextAnimation.current as number)\n : animation.startValue;\n if (reverse) {\n nextAnimation.toValue = animation.startValue;\n animation.startValue = startValue;\n }\n nextAnimation.onStart(\n nextAnimation,\n startValue,\n now,\n nextAnimation.previousAnimation as RepeatAnimation\n );\n return false;\n }\n return false;\n }\n\n const repCallback = (finished: boolean): void => {\n if (callback) {\n callback(finished);\n }\n // when cancelled call inner animation's callback\n if (!finished && nextAnimation.callback) {\n nextAnimation.callback(false /* finished */);\n }\n };\n\n function onStart(\n animation: RepeatAnimation,\n value: AnimatableValue,\n now: Timestamp,\n previousAnimation: RepeatAnimation\n ): void {\n animation.startValue = value;\n animation.reps = 0;\n nextAnimation.onStart(nextAnimation, value, now, previousAnimation);\n }\n\n return {\n isHigherOrder: true,\n onFrame: repeat,\n onStart,\n reps: 0,\n current: nextAnimation.current,\n callback: repCallback,\n startValue: 0,\n } as RepeatAnimation;\n });\n}\n","import { defineAnimation } from './util';\nimport { NextAnimation, SequenceAnimation } from './commonTypes';\nimport {\n Animation,\n AnimatableValue,\n AnimationObject,\n Timestamp,\n} from '../commonTypes';\n\nexport function withSequence(\n ..._animations: NextAnimation[]\n): Animation {\n 'worklet';\n return defineAnimation(\n _animations[0] as SequenceAnimation,\n () => {\n 'worklet';\n const animations = _animations.map((a) => {\n const result = typeof a === 'function' ? a() : a;\n result.finished = false;\n return result;\n });\n const firstAnimation = animations[0];\n\n const callback = (finished: boolean): void => {\n if (finished) {\n // we want to call the callback after every single animation\n // not after all of them\n return;\n }\n // this is going to be called only if sequence has been cancelled\n animations.forEach((animation) => {\n if (typeof animation.callback === 'function' && !animation.finished) {\n animation.callback(finished);\n }\n });\n };\n\n function sequence(animation: SequenceAnimation, now: Timestamp): boolean {\n const currentAnim = animations[animation.animationIndex];\n const finished = currentAnim.onFrame(currentAnim, now);\n animation.current = currentAnim.current;\n if (finished) {\n // we want to call the callback after every single animation\n if (currentAnim.callback) {\n currentAnim.callback(true /* finished */);\n }\n currentAnim.finished = true;\n animation.animationIndex += 1;\n if (animation.animationIndex < animations.length) {\n const nextAnim = animations[animation.animationIndex];\n nextAnim.onStart(nextAnim, currentAnim.current, now, currentAnim);\n return false;\n }\n return true;\n }\n return false;\n }\n\n function onStart(\n animation: SequenceAnimation,\n value: AnimatableValue,\n now: Timestamp,\n previousAnimation: SequenceAnimation\n ): void {\n animation.animationIndex = 0;\n if (previousAnimation === undefined) {\n previousAnimation = animations[\n animations.length - 1\n ] as SequenceAnimation;\n }\n firstAnimation.onStart(firstAnimation, value, now, previousAnimation);\n }\n\n return {\n isHigherOrder: true,\n onFrame: sequence,\n onStart,\n animationIndex: 0,\n current: firstAnimation.current,\n callback,\n } as SequenceAnimation;\n }\n );\n}\n","import { defineAnimation } from './util';\nimport {\n Animation,\n AnimationCallback,\n AnimatableValue,\n Timestamp,\n} from '../commonTypes';\n\ninterface SpringConfig {\n mass?: number;\n stiffness?: number;\n overshootClamping?: boolean;\n restDisplacementThreshold?: number;\n restSpeedThreshold?: number;\n velocity?: number;\n damping?: number;\n}\n\nexport interface SpringAnimation extends Animation {\n current: AnimatableValue;\n toValue: AnimatableValue;\n velocity: number;\n lastTimestamp: Timestamp;\n}\n\nexport interface InnerSpringAnimation\n extends Omit {\n toValue: number;\n current: number;\n}\n\nexport function withSpring(\n toValue: AnimatableValue,\n userConfig?: SpringConfig,\n callback?: AnimationCallback\n): Animation {\n 'worklet';\n\n return defineAnimation(toValue, () => {\n 'worklet';\n\n // TODO: figure out why we can't use spread or Object.assign here\n // when user config is \"frozen object\" we can't enumerate it (perhaps\n // something is wrong with the object prototype).\n const config: Required = {\n damping: 10,\n mass: 1,\n stiffness: 100,\n overshootClamping: false,\n restDisplacementThreshold: 0.01,\n restSpeedThreshold: 2,\n velocity: 0,\n };\n if (userConfig) {\n Object.keys(userConfig).forEach(\n (key) =>\n ((config as any)[key] = userConfig[key as keyof typeof userConfig])\n );\n }\n\n function spring(animation: InnerSpringAnimation, now: Timestamp): boolean {\n const { toValue, lastTimestamp, current, velocity } = animation;\n\n const deltaTime = Math.min(now - lastTimestamp, 64);\n animation.lastTimestamp = now;\n\n const c = config.damping;\n const m = config.mass;\n const k = config.stiffness;\n\n const v0 = -velocity;\n const x0 = toValue - current;\n\n const zeta = c / (2 * Math.sqrt(k * m)); // damping ratio\n const omega0 = Math.sqrt(k / m); // undamped angular frequency of the oscillator (rad/ms)\n const omega1 = omega0 * Math.sqrt(1 - zeta ** 2); // exponential decay\n\n const t = deltaTime / 1000;\n\n const sin1 = Math.sin(omega1 * t);\n const cos1 = Math.cos(omega1 * t);\n\n // under damped\n const underDampedEnvelope = Math.exp(-zeta * omega0 * t);\n const underDampedFrag1 =\n underDampedEnvelope *\n (sin1 * ((v0 + zeta * omega0 * x0) / omega1) + x0 * cos1);\n\n const underDampedPosition = toValue - underDampedFrag1;\n // This looks crazy -- it's actually just the derivative of the oscillation function\n const underDampedVelocity =\n zeta * omega0 * underDampedFrag1 -\n underDampedEnvelope *\n (cos1 * (v0 + zeta * omega0 * x0) - omega1 * x0 * sin1);\n\n // critically damped\n const criticallyDampedEnvelope = Math.exp(-omega0 * t);\n const criticallyDampedPosition =\n toValue - criticallyDampedEnvelope * (x0 + (v0 + omega0 * x0) * t);\n\n const criticallyDampedVelocity =\n criticallyDampedEnvelope *\n (v0 * (t * omega0 - 1) + t * x0 * omega0 * omega0);\n\n const isOvershooting = () => {\n if (config.overshootClamping && config.stiffness !== 0) {\n return current < toValue\n ? animation.current > toValue\n : animation.current < toValue;\n } else {\n return false;\n }\n };\n\n const isVelocity = Math.abs(velocity) < config.restSpeedThreshold;\n const isDisplacement =\n config.stiffness === 0 ||\n Math.abs(toValue - current) < config.restDisplacementThreshold;\n\n if (zeta < 1) {\n animation.current = underDampedPosition;\n animation.velocity = underDampedVelocity;\n } else {\n animation.current = criticallyDampedPosition;\n animation.velocity = criticallyDampedVelocity;\n }\n\n if (isOvershooting() || (isVelocity && isDisplacement)) {\n if (config.stiffness !== 0) {\n animation.velocity = 0;\n animation.current = toValue;\n }\n // clear lastTimestamp to avoid using stale value by the next spring animation that starts after this one\n animation.lastTimestamp = 0;\n return true;\n }\n return false;\n }\n\n function onStart(\n animation: SpringAnimation,\n value: number,\n now: Timestamp,\n previousAnimation: SpringAnimation\n ): void {\n animation.current = value;\n if (previousAnimation) {\n animation.velocity =\n previousAnimation.velocity || animation.velocity || 0;\n animation.lastTimestamp = previousAnimation.lastTimestamp || now;\n } else {\n animation.lastTimestamp = now;\n }\n }\n\n return {\n onFrame: spring,\n onStart,\n toValue,\n velocity: config.velocity || 0,\n current: toValue,\n callback,\n lastTimestamp: 0,\n } as SpringAnimation;\n });\n}\n","import { Text } from 'react-native';\nimport createAnimatedComponent from '../../createAnimatedComponent';\n\nconst AnimatedText = createAnimatedComponent(Text as any);\n\nexport default AnimatedText;\n","import { View } from 'react-native';\nimport createAnimatedComponent from '../../createAnimatedComponent';\n\nconst AnimatedView = createAnimatedComponent(View);\n\nexport default AnimatedView;\n","import { ScrollView } from 'react-native';\nimport createAnimatedComponent from '../../createAnimatedComponent';\n\nconst AnimatedScrollView = createAnimatedComponent(ScrollView);\n\nexport default AnimatedScrollView;\n","import { Image } from 'react-native';\nimport createAnimatedComponent from '../../createAnimatedComponent';\n\nconst AnimatedImage = createAnimatedComponent(Image as any);\n\nexport default AnimatedImage;\n","import React, { ForwardedRef, forwardRef } from 'react';\nimport {\n FlatList,\n FlatListProps,\n LayoutChangeEvent,\n StyleSheet,\n} from 'react-native';\nimport ReanimatedView from './View';\nimport createAnimatedComponent from '../../createAnimatedComponent';\nimport { ILayoutAnimationBuilder } from '../layoutReanimation/animationBuilder/commonTypes';\nimport { StyleProps } from '../commonTypes';\n\nconst AnimatedFlatList = createAnimatedComponent(FlatList as any) as any;\n\ninterface AnimatedFlatListProps {\n onLayout: (event: LayoutChangeEvent) => void;\n // implicit `children` prop has been removed in @types/react^18.0.0\n children: React.ReactNode;\n inverted?: boolean;\n horizontal?: boolean;\n}\n\nconst createCellRenderer = (\n itemLayoutAnimation?: ILayoutAnimationBuilder,\n cellStyle?: StyleProps\n) => {\n const cellRenderer = (props: AnimatedFlatListProps) => {\n return (\n \n {props.children}\n \n );\n };\n\n return cellRenderer;\n};\n\nexport interface ReanimatedFlatListProps extends FlatListProps {\n itemLayoutAnimation?: ILayoutAnimationBuilder;\n}\n\ntype ReanimatedFlatListFC = React.FC>;\n\nconst ReanimatedFlatlist: ReanimatedFlatListFC = forwardRef(\n (props: ReanimatedFlatListProps, ref: ForwardedRef) => {\n const { itemLayoutAnimation, ...restProps } = props;\n\n const cellStyle = restProps?.inverted\n ? restProps?.horizontal\n ? styles.horizontallyInverted\n : styles.verticallyInverted\n : undefined;\n\n const cellRenderer = React.useMemo(\n () => createCellRenderer(itemLayoutAnimation, cellStyle),\n [cellStyle]\n );\n\n return (\n \n );\n }\n);\n\nconst styles = StyleSheet.create({\n verticallyInverted: { transform: [{ scaleY: -1 }] },\n horizontallyInverted: { transform: [{ scaleX: -1 }] },\n});\n\nexport default ReanimatedFlatlist;\n","// In order to keep bundle size down, we treat this file as a polyfill for Web.\n\nimport { shouldBeUseWeb } from '../PlatformChecker';\nconst initializeGlobalsForWeb = () => {\n if (shouldBeUseWeb()) {\n global._frameTimestamp = null;\n global._measure = () => {\n console.warn(\n \"[Reanimated] You can't use `measure` with Chrome Debugger or with web version\"\n );\n return {\n x: 0,\n y: 0,\n width: 0,\n height: 0,\n pageX: 0,\n pageY: 0,\n };\n };\n global._scrollTo = () => {\n console.warn(\n \"[Reanimated] You can't use `scrollTo` with Chrome Debugger or with web version\"\n );\n };\n global._dispatchCommand = () => {\n console.warn(\n \"[Reanimated] You can't use `scrollTo` or `dispatchCommand` methods with Chrome Debugger or with web version\"\n );\n };\n global._setGestureState = () => {\n console.warn(\n \"[Reanimated] You can't use `setGestureState` with Chrome Debugger or with web version\"\n );\n };\n }\n return true;\n};\n\n/*\n If a file doesn't export anything, tree shaking doesn't pack\n it into the JS bundle. In effect, the code inside of this file\n will never execute. That is why we wrapped initialization code\n into a function, and we call this one during creating\n the module export object.\n*/\n\nexport default initializeGlobalsForWeb();\n","export * from './core';\nexport * from './hook';\nexport * from './animation';\nexport * from './interpolation';\nexport * from './interpolateColor';\nexport * from './Easing';\nexport * from './NativeMethods';\nexport * from './Colors';\nexport * from './PropAdapters';\nexport * from './layoutReanimation';\nexport * from './utils';\nexport * from './commonTypes';\n","export type { DependencyList } from './commonTypes';\nexport {\n useAnimatedProps,\n useEvent,\n useHandler,\n useWorkletCallback,\n} from './Hooks';\nexport { useSharedValue } from './useSharedValue';\nexport { useAnimatedStyle } from './useAnimatedStyle';\nexport type { AnimatedStyleResult } from './useAnimatedStyle';\nexport { useAnimatedGestureHandler } from './useAnimatedGestureHandler';\nexport type {\n GestureHandlerEvent,\n GestureHandlers,\n} from './useAnimatedGestureHandler';\nexport { useAnimatedReaction } from './useAnimatedReaction';\nexport type { AnimatedReactionWorkletFunction } from './useAnimatedReaction';\nexport { useAnimatedRef } from './useAnimatedRef';\nexport { useAnimatedScrollHandler } from './useAnimatedScrollHandler';\nexport type { ScrollHandler, ScrollHandlers } from './useAnimatedScrollHandler';\nexport { useDerivedValue } from './useDerivedValue';\nexport type { DerivedValue } from './useDerivedValue';\nexport { useAnimatedSensor, SensorType } from './useAnimatedSensor';\nexport { useFrameCallback } from './useFrameCallback';\nexport type { FrameCallback } from './useFrameCallback';\nexport { useAnimatedKeyboard } from './useAnimatedKeyboard';\nexport { useScrollViewOffset } from './useScrollViewOffset';\n","import { useEffect, useRef } from 'react';\nimport { makeMutable, registerSensor, unregisterSensor } from '../core';\nimport { SharedValue, Value3D, ValueRotation } from '../commonTypes';\n\nexport enum SensorType {\n ACCELEROMETER = 1,\n GYROSCOPE = 2,\n GRAVITY = 3,\n MAGNETIC_FIELD = 4,\n ROTATION = 5,\n}\n\nexport type SensorConfig = {\n interval: number | 'auto';\n};\n\nexport type AnimatedSensor = {\n sensor: SharedValue;\n unregister: () => void;\n isAvailable: boolean;\n config: SensorConfig;\n};\n\nfunction initSensorData(\n sensorType: SensorType\n): SharedValue {\n if (sensorType === SensorType.ROTATION) {\n return makeMutable({\n qw: 0,\n qx: 0,\n qy: 0,\n qz: 0,\n yaw: 0,\n pitch: 0,\n roll: 0,\n });\n } else {\n return makeMutable({\n x: 0,\n y: 0,\n z: 0,\n });\n }\n}\n\nexport function useAnimatedSensor(\n sensorType: SensorType,\n userConfig?: SensorConfig\n): AnimatedSensor {\n const ref = useRef({\n sensor: initSensorData(sensorType),\n unregister: () => {\n // NOOP\n },\n isAvailable: false,\n config: {\n interval: 0,\n },\n });\n\n useEffect(() => {\n ref.current.config = { interval: 'auto', ...userConfig };\n const sensorData = ref.current.sensor!;\n const id = registerSensor(\n sensorType,\n ref.current.config.interval === 'auto' ? -1 : ref.current.config.interval,\n (data) => {\n 'worklet';\n sensorData.value = data;\n }\n );\n\n if (id !== -1) {\n // if sensor is available\n ref.current.unregister = () => unregisterSensor(id);\n ref.current.isAvailable = true;\n } else {\n // if sensor is unavailable\n ref.current.unregister = () => {\n // NOOP\n };\n ref.current.isAvailable = false;\n }\n\n return () => {\n ref.current.unregister();\n };\n }, [sensorType, userConfig]);\n\n return ref.current;\n}\n","import { MutableRefObject } from 'react';\nimport { Context, WorkletFunction } from '../commonTypes';\nimport WorkletEventHandler from '../WorkletEventHandler';\nimport { DependencyList } from './commonTypes';\nimport { useEvent, useHandler } from './Hooks';\n\ninterface Handler extends WorkletFunction {\n (event: T, context: TContext, isCanceledOrFailed?: boolean): void;\n}\n\nexport interface GestureHandlers {\n [key: string]: Handler | undefined;\n onStart?: Handler;\n onActive?: Handler;\n onEnd?: Handler;\n onFail?: Handler;\n onCancel?: Handler;\n onFinish?: Handler;\n}\n\nexport enum EventType {\n UNDETERMINED = 0,\n FAILED,\n BEGAN,\n CANCELLED,\n ACTIVE,\n END,\n}\n\nexport interface GestureHandlerStateChangeNativeEvent {\n handlerTag: number;\n numberOfPointers: number;\n state: EventType;\n oldState: EventType;\n}\n\nexport interface GestureHandlerEvent\n extends GestureHandlerStateChangeNativeEvent {\n nativeEvent: T;\n}\n\nexport function useAnimatedGestureHandler<\n T extends GestureHandlerEvent,\n TContext extends Context\n>(\n handlers: GestureHandlers,\n dependencies?: DependencyList\n): MutableRefObject | null> | ((e: T) => void) {\n const { context, doDependenciesDiffer, useWeb } = useHandler(\n handlers,\n dependencies\n );\n\n const handler = (e: T) => {\n 'worklet';\n const event = useWeb ? e.nativeEvent : e;\n\n if (event.state === EventType.BEGAN && handlers.onStart) {\n handlers.onStart(event, context);\n }\n if (event.state === EventType.ACTIVE && handlers.onActive) {\n handlers.onActive(event, context);\n }\n if (\n event.oldState === EventType.ACTIVE &&\n event.state === EventType.END &&\n handlers.onEnd\n ) {\n handlers.onEnd(event, context);\n }\n if (\n event.oldState === EventType.BEGAN &&\n event.state === EventType.FAILED &&\n handlers.onFail\n ) {\n handlers.onFail(event, context);\n }\n if (\n event.oldState === EventType.ACTIVE &&\n event.state === EventType.CANCELLED &&\n handlers.onCancel\n ) {\n handlers.onCancel(event, context);\n }\n if (\n (event.oldState === EventType.BEGAN ||\n event.oldState === EventType.ACTIVE) &&\n event.state !== EventType.BEGAN &&\n event.state !== EventType.ACTIVE &&\n handlers.onFinish\n ) {\n handlers.onFinish(\n event,\n context,\n event.state === EventType.CANCELLED || event.state === EventType.FAILED\n );\n }\n };\n\n if (useWeb) {\n return handler;\n }\n\n return useEvent(\n handler,\n ['onGestureHandlerStateChange', 'onGestureHandlerEvent'],\n doDependenciesDiffer\n );\n}\n","import { useCallback } from 'react';\nimport { DependencyList } from './commonTypes';\nimport { useAnimatedStyle } from './useAnimatedStyle';\n\n// TODO: we should make sure that when useAP is used we are not assigning styles\n// when you need styles to animated you should always use useAS\nexport const useAnimatedProps = useAnimatedStyle;\n\nexport function useWorkletCallback(\n fun: (...args: A) => R,\n deps?: DependencyList\n): (...args: Parameters) => R {\n return useCallback(fun, deps ?? []);\n}\n\nexport { useEvent, useHandler } from './utils';\n","import { MutableRefObject, useEffect, useRef } from 'react';\nimport { processColor } from '../Colors';\nimport {\n AnimatedStyle,\n Context,\n NativeEvent,\n NestedObjectValues,\n StyleProps,\n WorkletFunction,\n AnimationObject,\n} from '../commonTypes';\nimport { makeRemote } from '../core';\nimport { isWeb, isJest } from '../PlatformChecker';\nimport { colorProps } from '../UpdateProps';\nimport WorkletEventHandler from '../WorkletEventHandler';\nimport { ContextWithDependencies, DependencyList } from './commonTypes';\n\ninterface Handler extends WorkletFunction {\n (event: T, context: TContext): void;\n}\n\ninterface Handlers {\n [key: string]: Handler | undefined;\n}\n\nexport interface UseHandlerContext {\n context: TContext;\n doDependenciesDiffer: boolean;\n useWeb: boolean;\n}\n\nexport function useEvent>(\n handler: (event: T) => void,\n eventNames: string[] = [],\n rebuild = false\n): MutableRefObject | null> {\n const initRef = useRef | null>(null);\n if (initRef.current === null) {\n initRef.current = new WorkletEventHandler(handler, eventNames);\n } else if (rebuild) {\n initRef.current.updateWorklet(handler);\n }\n\n return initRef;\n}\n\nexport function useHandler(\n handlers: Handlers,\n dependencies?: DependencyList\n): UseHandlerContext {\n const initRef = useRef | null>(null);\n if (initRef.current === null) {\n initRef.current = {\n context: makeRemote({} as TContext),\n savedDependencies: [],\n };\n }\n\n useEffect(() => {\n return () => {\n initRef.current = null;\n };\n }, []);\n\n const { context, savedDependencies } = initRef.current;\n\n dependencies = buildDependencies(dependencies, handlers);\n\n const doDependenciesDiffer = !areDependenciesEqual(\n dependencies,\n savedDependencies\n );\n initRef.current.savedDependencies = dependencies;\n const useWeb = isWeb() || isJest();\n\n return { context, doDependenciesDiffer, useWeb };\n}\n\n// builds one big hash from multiple worklets' hashes\nexport function buildWorkletsHash(\n handlers: Record | Array\n): string {\n return Object.values(handlers).reduce(\n (acc: string, worklet: WorkletFunction) =>\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n acc + worklet.__workletHash!.toString(),\n ''\n );\n}\n\n// builds dependencies array for gesture handlers\nexport function buildDependencies(\n dependencies: DependencyList,\n handlers: Record\n): Array {\n const handlersList: WorkletFunction[] = Object.values(handlers).filter(\n (handler) => handler !== undefined\n ) as WorkletFunction[];\n if (!dependencies) {\n dependencies = handlersList.map((handler) => {\n return {\n workletHash: handler.__workletHash,\n closure: handler._closure,\n };\n });\n } else {\n dependencies.push(buildWorkletsHash(handlersList));\n }\n return dependencies;\n}\n\n// this is supposed to work as useEffect comparison\nexport function areDependenciesEqual(\n nextDeps: DependencyList,\n prevDeps: DependencyList\n): boolean {\n function is(x: number, y: number) {\n /* eslint-disable no-self-compare */\n return (x === y && (x !== 0 || 1 / x === 1 / y)) || (x !== x && y !== y);\n /* eslint-enable no-self-compare */\n }\n const objectIs: (nextDeps: unknown, prevDeps: unknown) => boolean =\n typeof Object.is === 'function' ? Object.is : is;\n\n function areHookInputsEqual(\n nextDeps: DependencyList,\n prevDeps: DependencyList\n ): boolean {\n if (!nextDeps || !prevDeps || prevDeps.length !== nextDeps.length) {\n return false;\n }\n for (let i = 0; i < prevDeps.length; ++i) {\n if (!objectIs(nextDeps[i], prevDeps[i])) {\n return false;\n }\n }\n return true;\n }\n\n return areHookInputsEqual(nextDeps, prevDeps);\n}\n\nexport function hasColorProps(updates: AnimatedStyle): boolean {\n const colorPropsSet = new Set(colorProps);\n for (const key in updates) {\n if (colorPropsSet.has(key)) {\n return true;\n }\n }\n return false;\n}\n\nexport function parseColors(updates: AnimatedStyle): void {\n 'worklet';\n for (const key in updates) {\n if (colorProps.indexOf(key) !== -1) {\n // value could be an animation in which case processColor will recognize it and will return undefined\n // -> in such a case we don't want to override style of that key\n const processedColor = processColor(updates[key]);\n if (processedColor !== undefined) {\n updates[key] = processedColor;\n }\n }\n }\n}\n\nexport function canApplyOptimalisation(upadterFn: WorkletFunction): number {\n const FUNCTIONLESS_FLAG = 0b00000001;\n const STATEMENTLESS_FLAG = 0b00000010;\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const optimalization = upadterFn.__optimalization!;\n return (\n optimalization & FUNCTIONLESS_FLAG && optimalization & STATEMENTLESS_FLAG\n );\n}\n\nexport function isAnimated(prop: NestedObjectValues): boolean {\n 'worklet';\n const propsToCheck: NestedObjectValues[] = [prop];\n while (propsToCheck.length > 0) {\n const currentProp: NestedObjectValues =\n propsToCheck.pop() as NestedObjectValues;\n if (Array.isArray(currentProp)) {\n for (const item of currentProp) {\n propsToCheck.push(item);\n }\n } else if (currentProp?.onFrame !== undefined) {\n return true;\n } else if (typeof currentProp === 'object') {\n for (const item of Object.values(currentProp)) {\n propsToCheck.push(item);\n }\n }\n // if none of the above, it's not the animated prop, check next one\n }\n\n // when none of the props were animated return false\n return false;\n}\n\nexport function styleDiff(\n oldStyle: AnimatedStyle,\n newStyle: AnimatedStyle\n): Partial {\n 'worklet';\n const diff: any = {};\n for (const key in oldStyle) {\n if (newStyle[key] === undefined) {\n diff[key] = null;\n }\n }\n for (const key in newStyle) {\n const value = newStyle[key];\n const oldValue = oldStyle[key];\n\n if (isAnimated(value)) {\n // do nothing\n continue;\n }\n if (oldValue !== value) {\n diff[key] = value;\n }\n }\n return diff;\n}\n\nexport function getStyleWithoutAnimations(newStyle: AnimatedStyle): StyleProps {\n 'worklet';\n const diff: StyleProps = {};\n\n for (const key in newStyle) {\n const value = newStyle[key];\n if (isAnimated(value)) {\n continue;\n }\n diff[key] = value;\n }\n return diff;\n}\n\nexport const validateAnimatedStyles = (styles: AnimatedStyle): void => {\n 'worklet';\n if (typeof styles !== 'object') {\n throw new Error(\n `useAnimatedStyle has to return an object, found ${typeof styles} instead`\n );\n } else if (Array.isArray(styles)) {\n throw new Error(\n 'useAnimatedStyle has to return an object and cannot return static styles combined with dynamic ones. Please do merging where a component receives props.'\n );\n }\n};\n","/* global _frameTimestamp */\nimport { MutableRefObject, useEffect, useRef } from 'react';\n\nimport { startMapper, stopMapper, makeRemote, getTimestamp } from '../core';\nimport updateProps, { updatePropsJestWrapper } from '../UpdateProps';\nimport { initialUpdaterRun } from '../animation';\nimport NativeReanimatedModule from '../NativeReanimated';\nimport { useSharedValue } from './useSharedValue';\nimport {\n buildWorkletsHash,\n getStyleWithoutAnimations,\n isAnimated,\n styleDiff,\n validateAnimatedStyles,\n} from './utils';\nimport { DependencyList, Descriptor } from './commonTypes';\nimport {\n makeViewDescriptorsSet,\n makeViewsRefSet,\n ViewDescriptorsSet,\n ViewRefSet,\n} from '../ViewDescriptorsSet';\nimport { isJest } from '../PlatformChecker';\nimport {\n AnimationObject,\n Timestamp,\n AdapterWorkletFunction,\n AnimatedStyle,\n BasicWorkletFunction,\n BasicWorkletFunctionOptional,\n NestedObjectValues,\n SharedValue,\n} from '../commonTypes';\nexport interface AnimatedStyleResult {\n viewDescriptors: ViewDescriptorsSet;\n initial: AnimatedStyle;\n viewsRef: ViewRefSet;\n animatedStyle?: MutableRefObject;\n}\n\ninterface AnimatedState {\n last: AnimatedStyle;\n animations: AnimatedStyle;\n isAnimationRunning: boolean;\n isAnimationCancelled: boolean;\n}\n\ninterface AnimationRef {\n initial: {\n value: AnimatedStyle;\n updater: () => AnimatedStyle;\n };\n remoteState: AnimatedState;\n viewDescriptors: ViewDescriptorsSet;\n}\n\nfunction prepareAnimation(\n animatedProp: AnimatedStyle,\n lastAnimation: AnimatedStyle,\n lastValue: AnimatedStyle\n): void {\n 'worklet';\n if (Array.isArray(animatedProp)) {\n animatedProp.forEach((prop, index) => {\n prepareAnimation(\n prop,\n lastAnimation && lastAnimation[index],\n lastValue && lastValue[index]\n );\n });\n // return animatedProp;\n }\n if (typeof animatedProp === 'object' && animatedProp.onFrame) {\n const animation = animatedProp;\n\n let value = animation.current;\n if (lastValue !== undefined) {\n if (typeof lastValue === 'object') {\n if (lastValue.value !== undefined) {\n // previously it was a shared value\n value = lastValue.value;\n } else if (lastValue.onFrame !== undefined) {\n if (lastAnimation?.current !== undefined) {\n // it was an animation before, copy its state\n value = lastAnimation.current;\n } else if (lastValue?.current !== undefined) {\n // it was initialized\n value = lastValue.current;\n }\n }\n } else {\n // previously it was a plain value, just set it as starting point\n value = lastValue;\n }\n }\n\n animation.callStart = (timestamp: Timestamp) => {\n animation.onStart(animation, value, timestamp, lastAnimation);\n };\n animation.callStart(getTimestamp());\n animation.callStart = null;\n } else if (typeof animatedProp === 'object') {\n // it is an object\n Object.keys(animatedProp).forEach((key) =>\n prepareAnimation(\n animatedProp[key],\n lastAnimation && lastAnimation[key],\n lastValue && lastValue[key]\n )\n );\n }\n}\n\nfunction runAnimations(\n animation: AnimatedStyle,\n timestamp: Timestamp,\n key: number | string,\n result: AnimatedStyle,\n animationsActive: SharedValue\n): boolean {\n 'worklet';\n if (!animationsActive.value) {\n return true;\n }\n if (Array.isArray(animation)) {\n result[key] = [];\n let allFinished = true;\n animation.forEach((entry, index) => {\n if (\n !runAnimations(entry, timestamp, index, result[key], animationsActive)\n ) {\n allFinished = false;\n }\n });\n return allFinished;\n } else if (typeof animation === 'object' && animation.onFrame) {\n let finished = true;\n if (!animation.finished) {\n if (animation.callStart) {\n animation.callStart(timestamp);\n animation.callStart = null;\n }\n finished = animation.onFrame(animation, timestamp);\n animation.timestamp = timestamp;\n if (finished) {\n animation.finished = true;\n animation.callback && animation.callback(true /* finished */);\n }\n }\n result[key] = animation.current;\n return finished;\n } else if (typeof animation === 'object') {\n result[key] = {};\n let allFinished = true;\n Object.keys(animation).forEach((k) => {\n if (\n !runAnimations(\n animation[k],\n timestamp,\n k,\n result[key],\n animationsActive\n )\n ) {\n allFinished = false;\n }\n });\n return allFinished;\n } else {\n result[key] = animation;\n return true;\n }\n}\n\nfunction styleUpdater(\n viewDescriptors: SharedValue,\n updater: BasicWorkletFunction,\n state: AnimatedState,\n maybeViewRef: ViewRefSet | undefined,\n animationsActive: SharedValue\n): void {\n 'worklet';\n const animations = state.animations ?? {};\n const newValues = updater() ?? {};\n const oldValues = state.last;\n\n let hasAnimations = false;\n for (const key in newValues) {\n const value = newValues[key];\n if (isAnimated(value)) {\n prepareAnimation(value, animations[key], oldValues[key]);\n animations[key] = value;\n hasAnimations = true;\n } else {\n delete animations[key];\n }\n }\n\n if (hasAnimations) {\n const frame = (_timestamp?: Timestamp) => {\n const { animations, last, isAnimationCancelled } = state;\n const timestamp = _timestamp ?? getTimestamp();\n if (isAnimationCancelled) {\n state.isAnimationRunning = false;\n return;\n }\n\n const updates: AnimatedStyle = {};\n let allFinished = true;\n for (const propName in animations) {\n const finished = runAnimations(\n animations[propName],\n timestamp,\n propName,\n updates,\n animationsActive\n );\n if (finished) {\n last[propName] = updates[propName];\n delete animations[propName];\n } else {\n allFinished = false;\n }\n }\n\n if (updates) {\n updateProps(viewDescriptors, updates, maybeViewRef);\n }\n\n if (!allFinished) {\n requestAnimationFrame(frame);\n } else {\n state.isAnimationRunning = false;\n }\n };\n\n state.animations = animations;\n if (!state.isAnimationRunning) {\n state.isAnimationCancelled = false;\n state.isAnimationRunning = true;\n if (_frameTimestamp) {\n frame(_frameTimestamp);\n } else {\n requestAnimationFrame(frame);\n }\n }\n state.last = Object.assign({}, oldValues, newValues);\n const style = getStyleWithoutAnimations(state.last);\n if (style) {\n updateProps(viewDescriptors, style, maybeViewRef);\n }\n } else {\n state.isAnimationCancelled = true;\n state.animations = [];\n\n const diff = styleDiff(oldValues, newValues);\n state.last = Object.assign({}, oldValues, newValues);\n if (diff) {\n updateProps(viewDescriptors, newValues, maybeViewRef);\n }\n }\n}\n\nfunction jestStyleUpdater(\n viewDescriptors: SharedValue,\n updater: BasicWorkletFunction,\n state: AnimatedState,\n maybeViewRef: ViewRefSet | undefined,\n animationsActive: SharedValue,\n animatedStyle: MutableRefObject,\n adapters: AdapterWorkletFunction[] = []\n): void {\n 'worklet';\n const animations: AnimatedStyle = state.animations ?? {};\n const newValues = updater() ?? {};\n const oldValues = state.last;\n\n // extract animated props\n let hasAnimations = false;\n Object.keys(animations).forEach((key) => {\n const value = newValues[key];\n if (!isAnimated(value)) {\n delete animations[key];\n }\n });\n Object.keys(newValues).forEach((key) => {\n const value = newValues[key];\n if (isAnimated(value)) {\n prepareAnimation(value, animations[key], oldValues[key]);\n animations[key] = value;\n hasAnimations = true;\n }\n });\n\n function frame(_timestamp?: Timestamp) {\n const { animations, last, isAnimationCancelled } = state;\n const timestamp = _timestamp ?? getTimestamp();\n if (isAnimationCancelled) {\n state.isAnimationRunning = false;\n return;\n }\n\n const updates: AnimatedStyle = {};\n let allFinished = true;\n Object.keys(animations).forEach((propName) => {\n const finished = runAnimations(\n animations[propName],\n timestamp,\n propName,\n updates,\n animationsActive\n );\n if (finished) {\n last[propName] = updates[propName];\n delete animations[propName];\n } else {\n allFinished = false;\n }\n });\n\n if (Object.keys(updates).length) {\n updatePropsJestWrapper(\n viewDescriptors,\n updates,\n maybeViewRef,\n animatedStyle,\n adapters\n );\n }\n\n if (!allFinished) {\n requestAnimationFrame(frame);\n } else {\n state.isAnimationRunning = false;\n }\n }\n\n if (hasAnimations) {\n state.animations = animations;\n if (!state.isAnimationRunning) {\n state.isAnimationCancelled = false;\n state.isAnimationRunning = true;\n if (_frameTimestamp) {\n frame(_frameTimestamp);\n } else {\n requestAnimationFrame(frame);\n }\n }\n } else {\n state.isAnimationCancelled = true;\n state.animations = [];\n }\n\n // calculate diff\n const diff = styleDiff(oldValues, newValues);\n state.last = Object.assign({}, oldValues, newValues);\n\n if (Object.keys(diff).length !== 0) {\n updatePropsJestWrapper(\n viewDescriptors,\n diff,\n maybeViewRef,\n animatedStyle,\n adapters\n );\n }\n}\n\n// check for invalid usage of shared values in returned object\nfunction checkSharedValueUsage(\n prop: NestedObjectValues,\n currentKey?: string\n): void {\n if (Array.isArray(prop)) {\n // if it's an array (i.ex. transform) validate all its elements\n for (const element of prop) {\n checkSharedValueUsage(element, currentKey);\n }\n } else if (typeof prop === 'object' && prop.value === undefined) {\n // if it's a nested object, run validation for all its props\n for (const key of Object.keys(prop)) {\n checkSharedValueUsage(prop[key], key);\n }\n } else if (\n currentKey !== undefined &&\n typeof prop === 'object' &&\n prop.value !== undefined\n ) {\n // if shared value is passed insted of its value, throw an error\n throw new Error(\n `invalid value passed to \\`${currentKey}\\`, maybe you forgot to use \\`.value\\`?`\n );\n }\n}\n\nexport function useAnimatedStyle(\n updater: BasicWorkletFunction,\n dependencies?: DependencyList,\n adapters?: AdapterWorkletFunction | AdapterWorkletFunction[]\n): AnimatedStyleResult {\n const viewsRef: ViewRefSet = makeViewsRefSet();\n const initRef = useRef();\n const inputs = Object.values(updater._closure ?? {});\n const adaptersArray: AdapterWorkletFunction[] = adapters\n ? Array.isArray(adapters)\n ? adapters\n : [adapters]\n : [];\n const adaptersHash = adapters ? buildWorkletsHash(adaptersArray) : null;\n const animationsActive = useSharedValue(true);\n const animatedStyle: MutableRefObject = useRef(\n {}\n );\n\n // build dependencies\n if (!dependencies) {\n dependencies = [...inputs, updater.__workletHash];\n } else {\n dependencies.push(updater.__workletHash);\n }\n adaptersHash && dependencies.push(adaptersHash);\n\n if (!initRef.current) {\n const initialStyle: AnimatedStyle = initialUpdaterRun(updater);\n validateAnimatedStyles(initialStyle);\n initRef.current = {\n initial: {\n value: initialStyle,\n updater: updater,\n },\n remoteState: makeRemote({\n last: initialStyle,\n animations: {},\n isAnimationCancelled: false,\n isAnimationRunning: false,\n }),\n viewDescriptors: makeViewDescriptorsSet(),\n };\n }\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const { initial, remoteState, viewDescriptors } = initRef.current!;\n const sharableViewDescriptors = viewDescriptors.sharableViewDescriptors;\n const maybeViewRef = NativeReanimatedModule.native ? undefined : viewsRef;\n\n dependencies.push(sharableViewDescriptors);\n\n useEffect(() => {\n let fun;\n let updaterFn = updater as BasicWorkletFunctionOptional;\n if (adapters) {\n updaterFn = () => {\n 'worklet';\n const newValues = updater();\n adaptersArray.forEach((adapter) => {\n adapter(newValues);\n });\n return newValues;\n };\n }\n\n if (isJest()) {\n fun = () => {\n 'worklet';\n jestStyleUpdater(\n sharableViewDescriptors,\n updater,\n remoteState,\n maybeViewRef,\n animationsActive,\n animatedStyle,\n adaptersArray\n );\n };\n } else {\n fun = () => {\n 'worklet';\n styleUpdater(\n sharableViewDescriptors,\n updaterFn,\n remoteState,\n maybeViewRef,\n animationsActive\n );\n };\n }\n const mapperId = startMapper(fun, inputs);\n return () => {\n stopMapper(mapperId);\n };\n }, dependencies);\n\n useEffect(() => {\n animationsActive.value = true;\n return () => {\n // initRef.current = null;\n // viewsRef = null;\n animationsActive.value = false;\n };\n }, []);\n\n checkSharedValueUsage(initial.value);\n\n if (process.env.JEST_WORKER_ID) {\n return { viewDescriptors, initial: initial, viewsRef, animatedStyle };\n } else {\n return { viewDescriptors, initial: initial, viewsRef };\n }\n}\n","import { useRef } from 'react';\nimport { makeMutable } from './core';\nimport { SharedValue } from './commonTypes';\nimport { Descriptor } from './hook/commonTypes';\n\nexport interface ViewRefSet {\n items: Set;\n add: (item: T) => void;\n remove: (item: T) => void;\n}\n\nexport interface ViewDescriptorsSet {\n sharableViewDescriptors: SharedValue;\n add: (item: Descriptor) => void;\n remove: (viewTag: number) => void;\n}\n\nexport function makeViewDescriptorsSet(): ViewDescriptorsSet {\n const sharableViewDescriptors = makeMutable([]);\n const data: ViewDescriptorsSet = {\n sharableViewDescriptors,\n add: (item: Descriptor) => {\n sharableViewDescriptors.modify((descriptors: Descriptor[]) => {\n 'worklet';\n const index = descriptors.findIndex(\n (descriptor) => descriptor.tag === item.tag\n );\n if (index !== -1) {\n descriptors[index] = item;\n } else {\n descriptors.push(item);\n }\n return descriptors;\n });\n },\n\n remove: (viewTag: number) => {\n sharableViewDescriptors.modify((descriptors: Descriptor[]) => {\n 'worklet';\n const index = descriptors.findIndex(\n (descriptor) => descriptor.tag === viewTag\n );\n if (index !== -1) {\n descriptors.splice(index, 1);\n }\n return descriptors;\n });\n },\n };\n return data;\n}\n\nexport function makeViewsRefSet(): ViewRefSet {\n const ref = useRef | null>(null);\n if (ref.current === null) {\n const data: ViewRefSet = {\n items: new Set(),\n\n add: (item: T) => {\n if (data.items.has(item)) return;\n data.items.add(item);\n },\n\n remove: (item: T) => {\n data.items.delete(item);\n },\n };\n ref.current = data;\n }\n\n return ref.current;\n}\n","import { useEffect, useRef } from 'react';\nimport { cancelAnimation } from '../animation';\nimport { SharedValue } from '../commonTypes';\nimport { makeMutable } from '../core';\n\nexport function useSharedValue(\n init: T,\n oneWayReadsOnly = false\n): SharedValue {\n const ref = useRef>(makeMutable(init, oneWayReadsOnly));\n\n if (ref.current === null) {\n ref.current = makeMutable(init, oneWayReadsOnly);\n }\n\n useEffect(() => {\n return () => {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n cancelAnimation(ref.current!);\n };\n }, []);\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n return ref.current!;\n}\n","import { useEffect, useRef } from 'react';\nimport {\n makeMutable,\n subscribeForKeyboardEvents,\n unsubscribeFromKeyboardEvents,\n} from '../core';\nimport { AnimatedKeyboardInfo, KeyboardState } from '../commonTypes';\n\nexport function useAnimatedKeyboard(): AnimatedKeyboardInfo {\n const ref = useRef(null);\n const listenerId = useRef(-1);\n const isSubscribed = useRef(false);\n\n if (ref.current === null) {\n const keyboardEventData: AnimatedKeyboardInfo = {\n state: makeMutable(KeyboardState.UNKNOWN),\n height: makeMutable(0),\n };\n listenerId.current = subscribeForKeyboardEvents((state, height) => {\n 'worklet';\n keyboardEventData.state.value = state;\n keyboardEventData.height.value = height;\n });\n ref.current = keyboardEventData;\n isSubscribed.current = true;\n }\n useEffect(() => {\n if (isSubscribed.current === false && ref.current !== null) {\n const keyboardEventData = ref.current;\n // subscribe again after Fast Refresh\n listenerId.current = subscribeForKeyboardEvents((state, height) => {\n 'worklet';\n keyboardEventData.state.value = state;\n keyboardEventData.height.value = height;\n });\n isSubscribed.current = true;\n }\n return () => {\n unsubscribeFromKeyboardEvents(listenerId.current);\n isSubscribed.current = false;\n };\n }, []);\n return ref.current;\n}\n","import {\n PerpectiveTransform,\n RotateTransform,\n RotateXTransform,\n RotateYTransform,\n RotateZTransform,\n ScaleTransform,\n ScaleXTransform,\n ScaleYTransform,\n TranslateXTransform,\n TranslateYTransform,\n SkewXTransform,\n SkewYTransform,\n MatrixTransform,\n ViewStyle,\n TextStyle,\n} from 'react-native';\n\nexport type TransformProperty =\n | PerpectiveTransform\n | RotateTransform\n | RotateXTransform\n | RotateYTransform\n | RotateZTransform\n | ScaleTransform\n | ScaleXTransform\n | ScaleYTransform\n | TranslateXTransform\n | TranslateYTransform\n | SkewXTransform\n | SkewYTransform\n | MatrixTransform;\n\nexport interface StyleProps extends ViewStyle, TextStyle {\n originX?: number;\n originY?: number;\n [key: string]: any;\n}\n\nexport interface AnimatedStyle\n extends Record> {\n [key: string]: any;\n transform?: Array>>;\n}\nexport interface SharedValue {\n value: T;\n addListener: (listenerID: number, listener: (value: T) => void) => void;\n removeListener: (listenerID: number) => void;\n modify: (modifier: (value: T) => T) => void;\n}\n\n// The below type is used for HostObjects retured by the JSI API that don't have\n// any accessable fields or methods but can carry data that is accessed from the\n// c++ side. We add a field to the type to make it possible for typescript to recognize\n// which JSI methods accept those types as arguments and to be able to correctly type\n// check other methods that may use them. However, this field is not actually defined\n// nor should be used for anything else as assigning any data to those objects will\n// throw an error.\nexport type ShareableRef = {\n __hostObjectShareableJSRef: T;\n};\n\nexport type ShareableSyncDataHolderRef = {\n __hostObjectShareableJSRefSyncDataHolder: T;\n};\n\nexport type MapperRegistry = {\n start: (\n mapperID: number,\n worklet: () => void,\n inputs: SharedValue[],\n outputs?: SharedValue[]\n ) => void;\n stop: (mapperID: number) => void;\n};\n\nexport type Context = Record;\n\nexport interface WorkletFunction {\n _closure?: Context;\n __workletHash?: number;\n __optimalization?: number;\n}\n\nexport interface BasicWorkletFunction extends WorkletFunction {\n (): T;\n}\n\nexport interface BasicWorkletFunctionOptional extends WorkletFunction {\n (): Partial;\n}\n\nexport interface NativeEvent {\n nativeEvent: T;\n}\nexport interface ComplexWorkletFunction\n extends WorkletFunction {\n (...args: A): R;\n __remoteFunction?: (...args: A) => R;\n}\n\nexport interface NestedObject {\n [key: string]: NestedObjectValues;\n}\n\nexport type NestedObjectValues =\n | T\n | Array>\n | NestedObject;\n\nexport interface AdapterWorkletFunction extends WorkletFunction {\n (value: NestedObject): void;\n}\n\nexport type AnimatableValue = number | string | Array;\n\nexport interface AnimationObject {\n [key: string]: any;\n callback: AnimationCallback;\n current?: AnimatableValue;\n toValue?: AnimationObject['current'];\n startValue?: AnimationObject['current'];\n finished?: boolean;\n strippedCurrent?: number;\n cancelled?: boolean;\n\n __prefix?: string;\n __suffix?: string;\n onFrame: (animation: any, timestamp: Timestamp) => boolean;\n onStart: (\n nextAnimation: any,\n current: any,\n timestamp: Timestamp,\n previousAnimation: any\n ) => void;\n}\n\nexport interface Animation extends AnimationObject {\n onFrame: (animation: T, timestamp: Timestamp) => boolean;\n onStart: (\n nextAnimation: T,\n current: T extends NumericAnimation ? number : AnimatableValue,\n timestamp: Timestamp,\n previousAnimation: T\n ) => void;\n}\n\nexport interface NumericAnimation {\n current?: number;\n}\n\nexport type AnimationCallback = (\n finished?: boolean,\n current?: AnimatableValue\n) => void;\n\nexport type Timestamp = number;\n\nexport type Value3D = {\n x: number;\n y: number;\n z: number;\n};\n\nexport type ValueRotation = {\n qw: number;\n qx: number;\n qy: number;\n qz: number;\n yaw: number;\n pitch: number;\n roll: number;\n};\n\nexport type ShadowNodeWrapper = object;\n\nexport enum KeyboardState {\n UNKNOWN = 0,\n OPENING = 1,\n OPEN = 2,\n CLOSING = 3,\n CLOSED = 4,\n}\n\nexport type AnimatedKeyboardInfo = {\n height: SharedValue;\n state: SharedValue;\n};\n\nexport interface MeasuredDimensions {\n x: number;\n y: number;\n width: number;\n height: number;\n pageX: number;\n pageY: number;\n}\n","import { useEffect } from 'react';\nimport { BasicWorkletFunction, WorkletFunction } from '../commonTypes';\nimport { startMapper, stopMapper } from '../core';\nimport { DependencyList } from './commonTypes';\nimport { useSharedValue } from './useSharedValue';\n\nexport interface AnimatedReactionWorkletFunction extends WorkletFunction {\n (prepared: T, previous: T | null): void;\n}\n/**\n * @param prepare - worklet used for data preparation for the second parameter\n * @param react - worklet which takes data prepared by the one in the first parameter and performs certain actions\n * the first worklet defines the inputs, in other words on which shared values change will it be called.\n * the second one can modify any shared values but those which are mentioned in the first worklet. Beware of that, because this may result in endless loop and high cpu usage.\n */\nexport function useAnimatedReaction(\n prepare: BasicWorkletFunction,\n react: AnimatedReactionWorkletFunction,\n dependencies: DependencyList\n): void {\n const previous = useSharedValue(null);\n if (dependencies === undefined) {\n dependencies = [\n Object.values(prepare._closure ?? {}),\n Object.values(react._closure ?? {}),\n prepare.__workletHash,\n react.__workletHash,\n ];\n } else {\n dependencies.push(prepare.__workletHash, react.__workletHash);\n }\n\n useEffect(() => {\n const fun = () => {\n 'worklet';\n const input = prepare();\n react(input, previous.value);\n previous.value = input;\n };\n const mapperId = startMapper(\n fun,\n Object.values(prepare._closure ?? {}),\n []\n );\n return () => {\n stopMapper(mapperId);\n };\n }, dependencies);\n}\n","import { Component, useRef } from 'react';\nimport { useSharedValue } from './useSharedValue';\nimport { RefObjectFunction } from './commonTypes';\nimport { ShadowNodeWrapper } from '../commonTypes';\nimport { getTag } from '../NativeMethods';\nimport { getShadowNodeWrapperFromHostInstance } from '../fabricUtils';\nimport {\n makeShareableCloneRecursive,\n makeShareableShadowNodeWrapper,\n registerShareableMapping,\n} from '../shareables';\n\nfunction getShareableShadowNodeFromComponent(\n component: Component\n): ShadowNodeWrapper {\n return makeShareableShadowNodeWrapper(\n getShadowNodeWrapperFromHostInstance(component)\n );\n}\n\nconst getTagValueFunction = global._IS_FABRIC\n ? getShareableShadowNodeFromComponent\n : getTag;\n\nexport function useAnimatedRef(): RefObjectFunction {\n const tag = useSharedValue(-1);\n const ref = useRef>();\n\n if (!ref.current) {\n const fun: RefObjectFunction = >((component) => {\n // enters when ref is set by attaching to a component\n if (component) {\n tag.value = getTagValueFunction(component);\n fun.current = component;\n }\n return tag.value;\n });\n\n fun.current = null;\n\n const remoteRef = makeShareableCloneRecursive({\n __init: () => {\n 'worklet';\n return () => tag.value;\n },\n });\n registerShareableMapping(fun, remoteRef);\n\n ref.current = fun;\n }\n\n return ref.current;\n}\n","/* global _WORKLET _measure _scrollTo _dispatchCommand _setGestureState */\nimport { Component } from 'react';\nimport { findNodeHandle } from 'react-native';\nimport { MeasuredDimensions } from './commonTypes';\nimport { RefObjectFunction } from './hook/commonTypes';\nimport { isChromeDebugger, isWeb, shouldBeUseWeb } from './PlatformChecker';\n\nexport function getTag(\n view: null | number | React.Component | React.ComponentClass\n): null | number {\n return findNodeHandle(view);\n}\n\nconst isNative = !shouldBeUseWeb();\n\nexport let measure: (\n animatedRef: RefObjectFunction\n) => MeasuredDimensions | null;\n\nif (isWeb()) {\n measure = (animatedRef: RefObjectFunction) => {\n const element = animatedRef() as unknown as HTMLElement; // TODO: fix typing of animated refs on web\n const viewportOffset = element.getBoundingClientRect();\n return {\n width: element.offsetWidth,\n height: element.offsetHeight,\n x: element.offsetLeft,\n y: element.offsetTop,\n pageX: viewportOffset.left,\n pageY: viewportOffset.top,\n };\n };\n} else if (isChromeDebugger()) {\n measure = (_animatedRef: RefObjectFunction) => {\n console.warn('[Reanimated] measure() cannot be used with Chrome Debugger.');\n return null;\n };\n} else {\n measure = (animatedRef: RefObjectFunction) => {\n 'worklet';\n if (!_WORKLET) {\n console.warn(\n '[Reanimated] measure() was called from the main JS context. Measure is ' +\n 'only available in the UI runtime. This may also happen if measure() ' +\n 'was called by a worklet in the useAnimatedStyle hook, because useAnimatedStyle ' +\n 'calls the given worklet on the JS runtime during render. If you want to ' +\n 'prevent this warning then wrap the call with `if (_WORKLET)`. Then it will ' +\n 'only be called on the UI runtime after the render has been completed.'\n );\n return null;\n }\n\n const viewTag = animatedRef();\n if (viewTag === -1) {\n console.warn(\n `[Reanimated] The view with tag ${viewTag} is not a valid argument for measure(). This may be because the view is not currently rendered, which may not be a bug (e.g. an off-screen FlatList item).`\n );\n return null;\n }\n\n const measured = _measure(viewTag);\n if (measured === null) {\n console.warn(\n `[Reanimated] The view with tag ${viewTag} has some undefined, not-yet-computed or meaningless value of \\`LayoutMetrics\\` type. This may be because the view is not currently rendered, which may not be a bug (e.g. an off-screen FlatList item).`\n );\n return null;\n } else if (measured.x === -1234567) {\n console.warn(\n `[Reanimated] The view with tag ${viewTag} returned an invalid measurement response.`\n );\n return null;\n } else if (isNaN(measured.x)) {\n console.warn(\n `[Reanimated] The view with tag ${viewTag} gets view-flattened on Android. To disable view-flattening, set \\`collapsable={false}\\` on this component.`\n );\n return null;\n } else {\n return measured;\n }\n };\n}\n\nexport function dispatchCommand(\n animatedRef: RefObjectFunction,\n commandName: string,\n args: Array\n): void {\n 'worklet';\n if (!_WORKLET || !isNative) {\n return;\n }\n const shadowNodeWrapper = animatedRef();\n _dispatchCommand(shadowNodeWrapper, commandName, args);\n}\n\nexport let scrollTo: (\n animatedRef: RefObjectFunction,\n x: number,\n y: number,\n animated: boolean\n) => void;\n\nif (isWeb()) {\n scrollTo = (\n animatedRef: RefObjectFunction,\n x: number,\n y: number,\n animated: boolean\n ) => {\n 'worklet';\n const element = animatedRef() as unknown as HTMLElement;\n // @ts-ignore same call as in react-native-web\n element.scrollTo({ x, y, animated });\n };\n} else if (isNative && global._IS_FABRIC) {\n scrollTo = (\n animatedRef: RefObjectFunction,\n x: number,\n y: number,\n animated: boolean\n ) => {\n 'worklet';\n dispatchCommand(animatedRef, 'scrollTo', [x, y, animated]);\n };\n} else if (isNative) {\n scrollTo = (\n animatedRef: RefObjectFunction,\n x: number,\n y: number,\n animated: boolean\n ) => {\n 'worklet';\n if (!_WORKLET) {\n return;\n }\n const viewTag = animatedRef();\n _scrollTo(viewTag, x, y, animated);\n };\n} else {\n scrollTo = (\n _animatedRef: RefObjectFunction,\n _x: number,\n _y: number\n ) => {\n // no-op\n };\n}\n\nexport function setGestureState(handlerTag: number, newState: number): void {\n 'worklet';\n if (!_WORKLET || !isNative) {\n console.warn(\n '[Reanimated] You can not use setGestureState in non-worklet function.'\n );\n return;\n }\n _setGestureState(handlerTag, newState);\n}\n","import { RefObject } from 'react';\nimport { NativeScrollEvent } from 'react-native';\nimport { Context, NativeEvent, WorkletFunction } from '../commonTypes';\nimport WorkletEventHandler from '../WorkletEventHandler';\nimport { DependencyList } from './commonTypes';\nimport { useEvent, useHandler } from './Hooks';\n\nexport interface ScrollHandler\n extends WorkletFunction {\n (event: NativeScrollEvent, context?: TContext): void;\n}\n\nexport interface ScrollEvent\n extends NativeScrollEvent,\n NativeEvent {\n eventName: string;\n}\nexport interface ScrollHandlers {\n [key: string]: ScrollHandler | undefined;\n onScroll?: ScrollHandler;\n onBeginDrag?: ScrollHandler;\n onEndDrag?: ScrollHandler;\n onMomentumBegin?: ScrollHandler;\n onMomentumEnd?: ScrollHandler;\n}\n\nexport function useAnimatedScrollHandler(\n handlers: ScrollHandlers | ScrollHandler,\n dependencies?: DependencyList\n): RefObject> {\n // case when handlers is a function\n const scrollHandlers: ScrollHandlers =\n typeof handlers === 'function' ? { onScroll: handlers } : handlers;\n const { context, doDependenciesDiffer } = useHandler(\n scrollHandlers,\n dependencies\n );\n\n // build event subscription array\n const subscribeForEvents = ['onScroll'];\n if (scrollHandlers.onBeginDrag !== undefined) {\n subscribeForEvents.push('onScrollBeginDrag');\n }\n if (scrollHandlers.onEndDrag !== undefined) {\n subscribeForEvents.push('onScrollEndDrag');\n }\n if (scrollHandlers.onMomentumBegin !== undefined) {\n subscribeForEvents.push('onMomentumScrollBegin');\n }\n if (scrollHandlers.onMomentumEnd !== undefined) {\n subscribeForEvents.push('onMomentumScrollEnd');\n }\n\n return useEvent(\n (event: ScrollEvent) => {\n 'worklet';\n const {\n onScroll,\n onBeginDrag,\n onEndDrag,\n onMomentumBegin,\n onMomentumEnd,\n } = scrollHandlers;\n if (onScroll && event.eventName.endsWith('onScroll')) {\n onScroll(event, context);\n } else if (onBeginDrag && event.eventName.endsWith('onScrollBeginDrag')) {\n onBeginDrag(event, context);\n } else if (onEndDrag && event.eventName.endsWith('onScrollEndDrag')) {\n onEndDrag(event, context);\n } else if (\n onMomentumBegin &&\n event.eventName.endsWith('onMomentumScrollBegin')\n ) {\n onMomentumBegin(event, context);\n } else if (\n onMomentumEnd &&\n event.eventName.endsWith('onMomentumScrollEnd')\n ) {\n onMomentumEnd(event, context);\n }\n },\n subscribeForEvents,\n doDependenciesDiffer\n );\n}\n","import { useEffect, useRef } from 'react';\nimport { initialUpdaterRun } from '../animation';\nimport { BasicWorkletFunction, SharedValue } from '../commonTypes';\nimport { makeMutable, startMapper, stopMapper } from '../core';\nimport { DependencyList } from './commonTypes';\n\nexport type DerivedValue = Readonly>;\n\nexport function useDerivedValue(\n processor: BasicWorkletFunction,\n dependencies: DependencyList\n): DerivedValue {\n const initRef = useRef | null>(null);\n const inputs = Object.values(processor._closure ?? {});\n\n // build dependencies\n if (dependencies === undefined) {\n dependencies = [...inputs, processor.__workletHash];\n } else {\n dependencies.push(processor.__workletHash);\n }\n\n if (initRef.current === null) {\n initRef.current = makeMutable(initialUpdaterRun(processor));\n }\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const sharedValue: SharedValue = initRef.current!;\n\n useEffect(() => {\n const fun = () => {\n 'worklet';\n sharedValue.value = processor();\n };\n const mapperId = startMapper(fun, inputs, [sharedValue]);\n return () => {\n stopMapper(mapperId);\n };\n }, dependencies);\n\n useEffect(() => {\n return () => {\n initRef.current = null;\n };\n }, []);\n\n return sharedValue;\n}\n","import { useEffect, useRef } from 'react';\nimport FrameCallbackRegistryJS from '../frameCallback/FrameCallbackRegistryJS';\nimport { FrameInfo } from '../frameCallback/FrameCallbackRegistryUI';\n\nexport type FrameCallback = {\n setActive: (isActive: boolean) => void;\n isActive: boolean;\n callbackId: number;\n};\nconst frameCallbackRegistry = new FrameCallbackRegistryJS();\n\nexport function useFrameCallback(\n callback: (frameInfo: FrameInfo) => void,\n autostart = true\n): FrameCallback {\n const ref = useRef({\n setActive: (isActive: boolean) => {\n frameCallbackRegistry.manageStateFrameCallback(\n ref.current.callbackId,\n isActive\n );\n ref.current.isActive = isActive;\n },\n isActive: autostart,\n callbackId: -1,\n });\n\n useEffect(() => {\n ref.current.callbackId =\n frameCallbackRegistry.registerFrameCallback(callback);\n ref.current.setActive(ref.current.isActive);\n\n return () => {\n frameCallbackRegistry.unregisterFrameCallback(ref.current.callbackId);\n ref.current.callbackId = -1;\n };\n }, [callback, autostart]);\n\n return ref.current;\n}\n","import { runOnUI } from '../core';\nimport { FrameInfo, prepareUIRegistry } from './FrameCallbackRegistryUI';\n\nexport default class FrameCallbackRegistryJS {\n private nextCallbackId = 0;\n\n constructor() {\n prepareUIRegistry();\n }\n\n registerFrameCallback(callback: (frameInfo: FrameInfo) => void): number {\n if (!callback) {\n return -1;\n }\n\n const callbackId = this.nextCallbackId;\n this.nextCallbackId++;\n\n runOnUI(() => {\n 'worklet';\n global._frameCallbackRegistry.registerFrameCallback(callback, callbackId);\n })();\n\n return callbackId;\n }\n\n unregisterFrameCallback(callbackId: number): void {\n runOnUI(() => {\n 'worklet';\n global._frameCallbackRegistry.unregisterFrameCallback(callbackId);\n })();\n }\n\n manageStateFrameCallback(callbackId: number, state: boolean): void {\n runOnUI(() => {\n 'worklet';\n global._frameCallbackRegistry.manageStateFrameCallback(callbackId, state);\n })();\n }\n}\n","import { runOnUI } from '../core';\n\ntype CallbackDetails = {\n callback: (frameInfo: FrameInfo) => void;\n startTime: number | null;\n};\n\nexport type FrameInfo = {\n timestamp: number;\n timeSincePreviousFrame: number | null;\n timeSinceFirstFrame: number;\n};\n\nexport interface FrameCallbackRegistryUI {\n frameCallbackRegistry: Map;\n activeFrameCallbacks: Set;\n previousFrameTimestamp: number | null;\n runCallbacks: () => void;\n registerFrameCallback: (\n callback: (frameInfo: FrameInfo) => void,\n callbackId: number\n ) => void;\n unregisterFrameCallback: (callbackId: number) => void;\n manageStateFrameCallback: (callbackId: number, state: boolean) => void;\n}\n\nexport const prepareUIRegistry = runOnUI(() => {\n 'worklet';\n\n const frameCallbackRegistry: FrameCallbackRegistryUI = {\n frameCallbackRegistry: new Map(),\n activeFrameCallbacks: new Set(),\n previousFrameTimestamp: null,\n\n runCallbacks() {\n const loop = (timestamp: number) => {\n if (this.previousFrameTimestamp === null) {\n this.previousFrameTimestamp = timestamp;\n }\n\n const delta = timestamp - this.previousFrameTimestamp;\n\n this.activeFrameCallbacks.forEach((callbackId: number) => {\n const callbackDetails = this.frameCallbackRegistry.get(callbackId)!;\n\n const { startTime } = callbackDetails;\n\n if (startTime === null) {\n // First frame\n callbackDetails.startTime = timestamp;\n\n callbackDetails.callback({\n timestamp,\n timeSincePreviousFrame: null,\n timeSinceFirstFrame: 0,\n });\n } else {\n // Next frame\n callbackDetails.callback({\n timestamp,\n timeSincePreviousFrame: delta,\n timeSinceFirstFrame: timestamp - startTime,\n });\n }\n });\n\n if (this.activeFrameCallbacks.size > 0) {\n this.previousFrameTimestamp = timestamp;\n requestAnimationFrame(loop);\n } else {\n this.previousFrameTimestamp = null;\n }\n };\n\n // runCallback() should only be called after registering a callback,\n // so if there is only one active callback, then it means that there were\n // zero previously and the loop isn't running yet.\n if (this.activeFrameCallbacks.size === 1) {\n requestAnimationFrame(loop);\n }\n },\n\n registerFrameCallback(\n callback: (frameInfo: FrameInfo) => void,\n callbackId: number\n ) {\n this.frameCallbackRegistry.set(callbackId, {\n callback: callback,\n startTime: null,\n });\n },\n\n unregisterFrameCallback(callbackId: number) {\n this.manageStateFrameCallback(callbackId, false);\n this.frameCallbackRegistry.delete(callbackId);\n },\n\n manageStateFrameCallback(callbackId: number, state: boolean) {\n if (callbackId === -1) {\n return;\n }\n if (state) {\n this.activeFrameCallbacks.add(callbackId);\n this.runCallbacks();\n } else {\n const callback = this.frameCallbackRegistry.get(callbackId)!;\n callback.startTime = null;\n\n this.activeFrameCallbacks.delete(callbackId);\n }\n },\n };\n\n global._frameCallbackRegistry = frameCallbackRegistry;\n});\n","import { RefObject, useEffect, useRef } from 'react';\n\nimport type Animated from 'react-native-reanimated';\nimport { ScrollEvent } from './useAnimatedScrollHandler';\nimport { SharedValue } from '../commonTypes';\nimport { findNodeHandle } from 'react-native';\nimport { useEvent } from './utils';\nimport { useSharedValue } from './useSharedValue';\n\nconst subscribeForEvents = [\n 'onScroll',\n 'onScrollBeginDrag',\n 'onScrollEndDrag',\n 'onMomentumScrollBegin',\n 'onMomentumScrollEnd',\n];\n\nexport function useScrollViewOffset(\n aref: RefObject\n): SharedValue {\n const offsetRef = useRef(useSharedValue(0));\n\n const event = useEvent((event: ScrollEvent) => {\n 'worklet';\n offsetRef.current.value =\n event.contentOffset.x === 0\n ? event.contentOffset.y\n : event.contentOffset.x;\n }, subscribeForEvents);\n\n useEffect(() => {\n const viewTag = findNodeHandle(aref.current);\n event.current?.registerForEvents(viewTag as number);\n }, [aref.current]);\n\n return offsetRef.current;\n}\n","export enum Extrapolation {\n IDENTITY = 'identity',\n CLAMP = 'clamp',\n EXTEND = 'extend',\n}\n\ninterface InterpolationNarrowedInput {\n leftEdgeInput: number;\n rightEdgeInput: number;\n leftEdgeOutput: number;\n rightEdgeOutput: number;\n}\n\nexport interface ExtrapolationConfig {\n extrapolateLeft?: Extrapolation | string;\n extrapolateRight?: Extrapolation | string;\n}\n\ninterface RequiredExtrapolationConfig {\n extrapolateLeft: Extrapolation;\n extrapolateRight: Extrapolation;\n}\n\nexport type ExtrapolationType =\n | ExtrapolationConfig\n | Extrapolation\n | string\n | undefined;\n\nfunction getVal(\n type: Extrapolation,\n coef: number,\n val: number,\n leftEdgeOutput: number,\n rightEdgeOutput: number,\n x: number\n): number {\n 'worklet';\n\n switch (type) {\n case Extrapolation.IDENTITY:\n return x;\n case Extrapolation.CLAMP:\n if (coef * val < coef * leftEdgeOutput) {\n return leftEdgeOutput;\n }\n return rightEdgeOutput;\n case Extrapolation.EXTEND:\n default:\n return val;\n }\n}\n\nfunction isExtrapolate(value: string): value is Extrapolation {\n 'worklet';\n\n return (\n value === Extrapolation.EXTEND ||\n value === Extrapolation.CLAMP ||\n value === Extrapolation.IDENTITY\n );\n}\n\n// validates extrapolations type\n// if type is correct, converts it to ExtrapolationConfig\nfunction validateType(type: ExtrapolationType): RequiredExtrapolationConfig {\n 'worklet';\n // initialize extrapolationConfig with default extrapolation\n const extrapolationConfig: RequiredExtrapolationConfig = {\n extrapolateLeft: Extrapolation.EXTEND,\n extrapolateRight: Extrapolation.EXTEND,\n };\n\n if (!type) {\n return extrapolationConfig;\n }\n\n if (typeof type === 'string') {\n if (!isExtrapolate(type)) {\n throw new Error(\n `Reanimated: not supported value for \"interpolate\" \\nSupported values: [\"extend\", \"clamp\", \"identity\", Extrapolatation.CLAMP, Extrapolatation.EXTEND, Extrapolatation.IDENTITY]\\n Valid example:\n interpolate(value, [inputRange], [outputRange], \"clamp\")`\n );\n }\n extrapolationConfig.extrapolateLeft = type;\n extrapolationConfig.extrapolateRight = type;\n return extrapolationConfig;\n }\n\n // otherwise type is extrapolation config object\n if (\n (type.extrapolateLeft && !isExtrapolate(type.extrapolateLeft)) ||\n (type.extrapolateRight && !isExtrapolate(type.extrapolateRight))\n ) {\n throw new Error(\n `Reanimated: not supported value for \"interpolate\" \\nSupported values: [\"extend\", \"clamp\", \"identity\", Extrapolatation.CLAMP, Extrapolatation.EXTEND, Extrapolatation.IDENTITY]\\n Valid example:\n interpolate(value, [inputRange], [outputRange], {\n extrapolateLeft: Extrapolation.CLAMP,\n extrapolateRight: Extrapolation.IDENTITY\n }})`\n );\n }\n\n Object.assign(extrapolationConfig, type);\n return extrapolationConfig;\n}\n\nfunction internalInterpolate(\n x: number,\n narrowedInput: InterpolationNarrowedInput,\n extrapolationConfig: RequiredExtrapolationConfig\n) {\n 'worklet';\n const { leftEdgeInput, rightEdgeInput, leftEdgeOutput, rightEdgeOutput } =\n narrowedInput;\n if (rightEdgeInput - leftEdgeInput === 0) return leftEdgeOutput;\n const progress = (x - leftEdgeInput) / (rightEdgeInput - leftEdgeInput);\n const val = leftEdgeOutput + progress * (rightEdgeOutput - leftEdgeOutput);\n const coef = rightEdgeOutput >= leftEdgeOutput ? 1 : -1;\n\n if (coef * val < coef * leftEdgeOutput) {\n return getVal(\n extrapolationConfig.extrapolateLeft,\n coef,\n val,\n leftEdgeOutput,\n rightEdgeOutput,\n x\n );\n } else if (coef * val > coef * rightEdgeOutput) {\n return getVal(\n extrapolationConfig.extrapolateRight,\n coef,\n val,\n leftEdgeOutput,\n rightEdgeOutput,\n x\n );\n }\n\n return val;\n}\n\n// TODO: support default values in worklets:\n// e.g. function interpolate(x, input, output, type = Extrapolatation.CLAMP)\nexport function interpolate(\n x: number,\n input: readonly number[],\n output: readonly number[],\n type?: ExtrapolationType\n): number {\n 'worklet';\n if (input.length < 2 || output.length < 2) {\n throw Error(\n 'Interpolation input and output should contain at least two values.'\n );\n }\n\n const extrapolationConfig = validateType(type);\n const length = input.length;\n const narrowedInput: InterpolationNarrowedInput = {\n leftEdgeInput: input[0],\n rightEdgeInput: input[1],\n leftEdgeOutput: output[0],\n rightEdgeOutput: output[1],\n };\n if (length > 2) {\n if (x > input[length - 1]) {\n narrowedInput.leftEdgeInput = input[length - 2];\n narrowedInput.rightEdgeInput = input[length - 1];\n narrowedInput.leftEdgeOutput = output[length - 2];\n narrowedInput.rightEdgeOutput = output[length - 1];\n } else {\n for (let i = 1; i < length; ++i) {\n if (x <= input[i]) {\n narrowedInput.leftEdgeInput = input[i - 1];\n narrowedInput.rightEdgeInput = input[i];\n narrowedInput.leftEdgeOutput = output[i - 1];\n narrowedInput.rightEdgeOutput = output[i];\n break;\n }\n }\n }\n }\n\n return internalInterpolate(x, narrowedInput, extrapolationConfig);\n}\n","import {\n hsvToColor,\n RGBtoHSV,\n rgbaColor,\n processColor,\n red,\n green,\n blue,\n opacity,\n} from './Colors';\nimport { makeMutable } from './core';\nimport { interpolate } from './interpolation';\nimport { SharedValue } from './commonTypes';\nimport { useSharedValue } from './hook/useSharedValue';\n\nexport const Extrapolate = {\n EXTEND: 'extend',\n CLAMP: 'clamp',\n IDENTITY: 'identity',\n};\n\nexport type InterpolationOptions = {\n gamma?: number;\n useCorrectedHSVInterpolation?: boolean;\n};\n\nconst interpolateColorsHSV = (\n value: number,\n inputRange: readonly number[],\n colors: InterpolateHSV,\n options: InterpolationOptions\n) => {\n 'worklet';\n let h = 0;\n const { useCorrectedHSVInterpolation = true } = options;\n if (useCorrectedHSVInterpolation) {\n // if the difference between hues in a range is > 180 deg\n // then move the hue at the right end of the range +/- 360 deg\n // and add the next point in the original place + 0.00001 with original hue\n // to not break the next range\n const correctedInputRange = [inputRange[0]];\n const originalH = colors.h;\n const correctedH = [originalH[0]];\n\n for (let i = 1; i < originalH.length; ++i) {\n const d = originalH[i] - originalH[i - 1];\n if (originalH[i] > originalH[i - 1] && d > 0.5) {\n correctedInputRange.push(inputRange[i]);\n correctedInputRange.push(inputRange[i] + 0.00001);\n correctedH.push(originalH[i] - 1);\n correctedH.push(originalH[i]);\n } else if (originalH[i] < originalH[i - 1] && d < -0.5) {\n correctedInputRange.push(inputRange[i]);\n correctedInputRange.push(inputRange[i] + 0.00001);\n correctedH.push(originalH[i] + 1);\n correctedH.push(originalH[i]);\n } else {\n correctedInputRange.push(inputRange[i]);\n correctedH.push(originalH[i]);\n }\n }\n h =\n (interpolate(value, correctedInputRange, correctedH, Extrapolate.CLAMP) +\n 1) %\n 1;\n } else {\n h = interpolate(value, inputRange, colors.h, Extrapolate.CLAMP);\n }\n const s = interpolate(value, inputRange, colors.s, Extrapolate.CLAMP);\n const v = interpolate(value, inputRange, colors.v, Extrapolate.CLAMP);\n const a = interpolate(value, inputRange, colors.a, Extrapolate.CLAMP);\n return hsvToColor(h, s, v, a);\n};\n\nconst toLinearSpace = (x: number[], gamma: number): number[] => {\n 'worklet';\n return x.map((v) => Math.pow(v / 255, gamma));\n};\n\nconst toGammaSpace = (x: number, gamma: number): number => {\n 'worklet';\n return Math.round(Math.pow(x, 1 / gamma) * 255);\n};\n\nconst interpolateColorsRGB = (\n value: number,\n inputRange: readonly number[],\n colors: InterpolateRGB,\n options: InterpolationOptions\n) => {\n 'worklet';\n const { gamma = 2.2 } = options;\n let { r: outputR, g: outputG, b: outputB } = colors;\n if (gamma !== 1) {\n outputR = toLinearSpace(outputR, gamma);\n outputG = toLinearSpace(outputG, gamma);\n outputB = toLinearSpace(outputB, gamma);\n }\n const r = interpolate(value, inputRange, outputR, Extrapolate.CLAMP);\n const g = interpolate(value, inputRange, outputG, Extrapolate.CLAMP);\n const b = interpolate(value, inputRange, outputB, Extrapolate.CLAMP);\n const a = interpolate(value, inputRange, colors.a, Extrapolate.CLAMP);\n if (gamma === 1) {\n return rgbaColor(r, g, b, a);\n }\n return rgbaColor(\n toGammaSpace(r, gamma),\n toGammaSpace(g, gamma),\n toGammaSpace(b, gamma),\n a\n );\n};\n\ninterface InterpolateRGB {\n r: number[];\n g: number[];\n b: number[];\n a: number[];\n}\n\nconst getInterpolateRGB = (\n colors: readonly (string | number)[]\n): InterpolateRGB => {\n 'worklet';\n\n const r = [];\n const g = [];\n const b = [];\n const a = [];\n for (let i = 0; i < colors.length; ++i) {\n const color = colors[i];\n const processedColor = processColor(color);\n // explicit check in case if processedColor is 0\n if (processedColor !== null && processedColor !== undefined) {\n r.push(red(processedColor));\n g.push(green(processedColor));\n b.push(blue(processedColor));\n a.push(opacity(processedColor));\n }\n }\n return { r, g, b, a };\n};\n\ninterface InterpolateHSV {\n h: number[];\n s: number[];\n v: number[];\n a: number[];\n}\n\nconst getInterpolateHSV = (\n colors: readonly (string | number)[]\n): InterpolateHSV => {\n 'worklet';\n const h = [];\n const s = [];\n const v = [];\n const a = [];\n for (let i = 0; i < colors.length; ++i) {\n const color = colors[i];\n const processedColor = processColor(color) as any;\n if (typeof processedColor === 'number') {\n const processedHSVColor = RGBtoHSV(\n red(processedColor),\n green(processedColor),\n blue(processedColor)\n );\n\n h.push(processedHSVColor.h);\n s.push(processedHSVColor.s);\n v.push(processedHSVColor.v);\n a.push(opacity(processedColor));\n }\n }\n return { h, s, v, a };\n};\n\nexport const interpolateColor = (\n value: number,\n inputRange: readonly number[],\n outputRange: readonly (string | number)[],\n colorSpace: 'RGB' | 'HSV' = 'RGB',\n options: InterpolationOptions = {}\n): string | number => {\n 'worklet';\n if (colorSpace === 'HSV') {\n return interpolateColorsHSV(\n value,\n inputRange,\n getInterpolateHSV(outputRange),\n options\n );\n } else if (colorSpace === 'RGB') {\n return interpolateColorsRGB(\n value,\n inputRange,\n getInterpolateRGB(outputRange),\n options\n );\n }\n throw new Error(\n `Invalid color space provided: ${colorSpace}. Supported values are: ['RGB', 'HSV']`\n );\n};\n\nexport enum ColorSpace {\n RGB = 0,\n HSV = 1,\n}\n\nexport interface InterpolateConfig {\n inputRange: readonly number[];\n outputRange: readonly (string | number)[];\n colorSpace: ColorSpace;\n cache: SharedValue;\n options: InterpolationOptions;\n}\n\nexport function useInterpolateConfig(\n inputRange: readonly number[],\n outputRange: readonly (string | number)[],\n colorSpace = ColorSpace.RGB,\n options: InterpolationOptions = {}\n): SharedValue {\n return useSharedValue({\n inputRange,\n outputRange,\n colorSpace,\n cache: makeMutable(null),\n options,\n });\n}\n\nexport const interpolateSharableColor = (\n value: number,\n interpolateConfig: SharedValue\n): string | number => {\n 'worklet';\n let colors = interpolateConfig.value.cache.value;\n if (interpolateConfig.value.colorSpace === ColorSpace.RGB) {\n if (!colors) {\n colors = getInterpolateRGB(interpolateConfig.value.outputRange);\n interpolateConfig.value.cache.value = colors;\n }\n return interpolateColorsRGB(\n value,\n interpolateConfig.value.inputRange,\n colors as InterpolateRGB,\n interpolateConfig.value.options\n );\n } else if (interpolateConfig.value.colorSpace === ColorSpace.HSV) {\n if (!colors) {\n colors = getInterpolateHSV(interpolateConfig.value.outputRange);\n interpolateConfig.value.cache.value = colors;\n }\n return interpolateColorsHSV(\n value,\n interpolateConfig.value.inputRange,\n colors as InterpolateHSV,\n interpolateConfig.value.options\n );\n }\n throw new Error(\n `Invalid color space provided: ${interpolateConfig.value.colorSpace}. Supported values are: ['RGB', 'HSV']`\n );\n};\n","import { addWhitelistedNativeProps } from '../ConfigHelper';\nimport { AdapterWorkletFunction } from './commonTypes';\n\nexport function createAnimatedPropAdapter(\n adapter: AdapterWorkletFunction,\n nativeProps?: string[]\n): AdapterWorkletFunction {\n const nativePropsToAdd: { [key: string]: boolean } = {};\n // eslint-disable-next-line no-unused-expressions\n nativeProps?.forEach((prop) => {\n nativePropsToAdd[prop] = true;\n });\n addWhitelistedNativeProps(nativePropsToAdd);\n return adapter;\n}\n\n// ADAPTERS\n\nexport const SVGAdapter: AdapterWorkletFunction = createAnimatedPropAdapter(\n (props) => {\n 'worklet';\n const keys = Object.keys(props);\n // transform\n if (keys.includes('transform')) {\n if (Array.isArray(props.transform)) {\n // case of array with 6 values => https://github.com/react-native-svg/react-native-svg/blob/b2e2c355204ff4b10973d3afce1495f7e4167ff7/src/elements/Shape.tsx#L200\n if (props.transform.length !== 6) {\n throw new Error(\n `invalid transform length of ${props.transform.length}, should be 6`\n );\n }\n const transform: number[] = props.transform as number[];\n const x: number = (props.x as number) ?? 0;\n const y: number = (props.y as number) ?? 0;\n props.transform = [\n { translateX: transform[0] * x + transform[2] * y + transform[4] },\n { translateY: transform[1] * x + transform[3] * y + transform[5] },\n ];\n } else if (typeof props.transform === 'string') {\n // case of string 'translate(translateX translateY)'\n // todo: handle other cases of transform string like here https://github.com/react-native-svg/react-native-svg/blob/b2e2c355204ff4b10973d3afce1495f7e4167ff7/src/lib/extract/extractTransform.ts#L184\n const transform: string = props.transform as string;\n const arr = transform\n .replace('translate(', '')\n .replace(')', '')\n .split(' ');\n props.transform = [\n { translateX: parseFloat(arr[0]) },\n { translateY: parseFloat(arr[1]) },\n ];\n }\n }\n // todo: other props\n }\n);\n\nexport const TextInputAdapter = createAnimatedPropAdapter(\n (props) => {\n 'worklet';\n const keys = Object.keys(props);\n // convert text to value like RN does here: https://github.com/facebook/react-native/blob/f2c6279ca497b34d5a2bfbb6f2d33dc7a7bea02a/Libraries/Components/TextInput/TextInput.js#L878\n if (keys.includes('value')) {\n props.text = props.value;\n delete props.value;\n }\n },\n ['text']\n);\n","import './animationsManager';\nexport * from './animationBuilder';\nexport * from './defaultAnimations';\nexport * from './defaultTransitions';\n","export { BaseAnimationBuilder } from './BaseAnimationBuilder';\nexport { ComplexAnimationBuilder } from './ComplexAnimationBuilder';\nexport { Keyframe } from './Keyframe';\nexport type {\n LayoutAnimation,\n AnimationFunction,\n EntryAnimationsValues,\n ExitAnimationsValues,\n EntryExitAnimationFunction,\n AnimationConfigFunction,\n IEntryAnimationBuilder,\n IExitAnimationBuilder,\n LayoutAnimationsValues,\n LayoutAnimationFunction,\n LayoutAnimationStartFunction,\n ILayoutAnimationBuilder,\n BaseLayoutAnimationConfig,\n BaseBuilderAnimationConfig,\n LayoutAnimationAndConfig,\n IEntryExitAnimationBuilder,\n} from './commonTypes';\n","import { withDelay } from '../../animation';\nimport {\n EntryExitAnimationFunction,\n AnimationFunction,\n LayoutAnimationFunction,\n} from './commonTypes';\n\nexport class BaseAnimationBuilder {\n durationV?: number;\n delayV?: number;\n randomizeDelay = false;\n callbackV?: (finished: boolean) => void;\n\n static createInstance: () => BaseAnimationBuilder;\n build = (): EntryExitAnimationFunction | LayoutAnimationFunction => {\n throw Error('Unimplemented method in child class.');\n };\n\n static duration(durationMs: number): BaseAnimationBuilder {\n const instance = this.createInstance();\n return instance.duration(durationMs);\n }\n\n duration(durationMs: number): BaseAnimationBuilder {\n this.durationV = durationMs;\n return this;\n }\n\n static delay(delayMs: number): BaseAnimationBuilder {\n const instance = this.createInstance();\n return instance.delay(delayMs);\n }\n\n delay(delayMs: number): BaseAnimationBuilder {\n this.delayV = delayMs;\n return this;\n }\n\n static withCallback(\n callback: (finished: boolean) => void\n ): BaseAnimationBuilder {\n const instance = this.createInstance();\n return instance.withCallback(callback);\n }\n\n withCallback(callback: (finsihed: boolean) => void): BaseAnimationBuilder {\n this.callbackV = callback;\n return this;\n }\n\n // 300ms is the default animation duration. If any animation has different default has to override this method.\n static getDuration(): number {\n return 300;\n }\n\n getDuration(): number {\n return this.durationV ?? 300;\n }\n\n static randomDelay(): BaseAnimationBuilder {\n const instance = this.createInstance();\n return instance.randomDelay();\n }\n\n randomDelay(): BaseAnimationBuilder {\n this.randomizeDelay = true;\n return this;\n }\n\n // when randomizeDelay is set to true, randomize delay between 0 and provided value (or 1000ms if delay is not provided)\n getDelay(): number {\n return this.randomizeDelay\n ? Math.random() * (this.delayV ?? 1000)\n : this.delayV ?? 0;\n }\n\n getDelayFunction(): AnimationFunction {\n const isDelayProvided = this.randomizeDelay || this.delayV;\n return isDelayProvided\n ? withDelay\n : (_, animation) => {\n 'worklet';\n return animation;\n };\n }\n\n static build(): EntryExitAnimationFunction | LayoutAnimationFunction {\n const instance = this.createInstance();\n return instance.build();\n }\n}\n","import { withTiming, withSpring } from '../../animation';\nimport {\n AnimationFunction,\n BaseBuilderAnimationConfig,\n LayoutAnimationAndConfig,\n} from './commonTypes';\nimport { EasingFn } from '../../Easing';\nimport { BaseAnimationBuilder } from './BaseAnimationBuilder';\nimport { StyleProps } from '../../commonTypes';\n\nexport class ComplexAnimationBuilder extends BaseAnimationBuilder {\n easingV?: EasingFn;\n rotateV?: string;\n type?: AnimationFunction;\n dampingV?: number;\n massV?: number;\n stiffnessV?: number;\n overshootClampingV?: number;\n restDisplacementThresholdV?: number;\n restSpeedThresholdV?: number;\n initialValues?: StyleProps;\n\n static createInstance: () => ComplexAnimationBuilder;\n\n static easing(easingFunction: EasingFn): ComplexAnimationBuilder {\n const instance = this.createInstance();\n return instance.easing(easingFunction);\n }\n\n easing(easingFunction: EasingFn): ComplexAnimationBuilder {\n this.easingV = easingFunction;\n return this;\n }\n\n static rotate(degree: string): ComplexAnimationBuilder {\n const instance = this.createInstance();\n return instance.rotate(degree);\n }\n\n rotate(degree: string): ComplexAnimationBuilder {\n this.rotateV = degree;\n return this;\n }\n\n static springify(): ComplexAnimationBuilder {\n const instance = this.createInstance();\n return instance.springify();\n }\n\n springify(): ComplexAnimationBuilder {\n this.type = withSpring as AnimationFunction;\n return this;\n }\n\n static damping(damping: number): ComplexAnimationBuilder {\n const instance = this.createInstance();\n return instance.damping(damping);\n }\n\n damping(damping: number): ComplexAnimationBuilder {\n this.dampingV = damping;\n return this;\n }\n\n static mass(mass: number): ComplexAnimationBuilder {\n const instance = this.createInstance();\n return instance.mass(mass);\n }\n\n mass(mass: number): ComplexAnimationBuilder {\n this.massV = mass;\n return this;\n }\n\n static stiffness(stiffness: number): ComplexAnimationBuilder {\n const instance = this.createInstance();\n return instance.stiffness(stiffness);\n }\n\n stiffness(stiffness: number): ComplexAnimationBuilder {\n this.stiffnessV = stiffness;\n return this;\n }\n\n static overshootClamping(overshootClamping: number): ComplexAnimationBuilder {\n const instance = this.createInstance();\n return instance.overshootClamping(overshootClamping);\n }\n\n overshootClamping(overshootClamping: number): ComplexAnimationBuilder {\n this.overshootClampingV = overshootClamping;\n return this;\n }\n\n static restDisplacementThreshold(\n restDisplacementThreshold: number\n ): ComplexAnimationBuilder {\n const instance = this.createInstance();\n return instance.restDisplacementThreshold(restDisplacementThreshold);\n }\n\n restDisplacementThreshold(\n restDisplacementThreshold: number\n ): ComplexAnimationBuilder {\n this.restDisplacementThresholdV = restDisplacementThreshold;\n return this;\n }\n\n static restSpeedThreshold(\n restSpeedThreshold: number\n ): ComplexAnimationBuilder {\n const instance = this.createInstance();\n return instance.restSpeedThreshold(restSpeedThreshold);\n }\n\n restSpeedThreshold(restSpeedThreshold: number): ComplexAnimationBuilder {\n this.restSpeedThresholdV = restSpeedThreshold;\n return this;\n }\n\n static withInitialValues(values: StyleProps): BaseAnimationBuilder {\n const instance = this.createInstance();\n return instance.withInitialValues(values);\n }\n\n withInitialValues(values: StyleProps): BaseAnimationBuilder {\n this.initialValues = values;\n return this;\n }\n\n getAnimationAndConfig(): LayoutAnimationAndConfig {\n const duration = this.durationV;\n const easing = this.easingV;\n const rotate = this.rotateV;\n const type = this.type ? this.type : (withTiming as AnimationFunction);\n const damping = this.dampingV;\n const mass = this.massV;\n const stiffness = this.stiffnessV;\n const overshootClamping = this.overshootClampingV;\n const restDisplacementThreshold = this.restDisplacementThresholdV;\n const restSpeedThreshold = this.restSpeedThresholdV;\n\n const animation = type;\n\n const config: BaseBuilderAnimationConfig = {};\n\n if (type === withTiming) {\n if (easing) {\n config.easing = easing;\n }\n if (duration) {\n config.duration = duration;\n }\n if (rotate) {\n config.rotate = rotate;\n }\n } else {\n if (damping) {\n config.damping = damping;\n }\n if (mass) {\n config.mass = mass;\n }\n if (stiffness) {\n config.stiffness = stiffness;\n }\n if (overshootClamping) {\n config.overshootClamping = overshootClamping;\n }\n if (restDisplacementThreshold) {\n config.restDisplacementThreshold = restDisplacementThreshold;\n }\n if (restSpeedThreshold) {\n config.restSpeedThreshold = restSpeedThreshold;\n }\n if (rotate) {\n config.rotate = rotate;\n }\n }\n return [animation, config];\n }\n}\n","import { Easing, EasingFn } from '../../Easing';\nimport { withDelay, withSequence, withTiming } from '../../animation';\nimport {\n AnimationFunction,\n EntryExitAnimationFunction,\n IEntryExitAnimationBuilder,\n KeyframeProps,\n} from './commonTypes';\nimport { TransformProperty, StyleProps } from '../../commonTypes';\nexport interface KeyframePoint {\n duration: number;\n value: number | string;\n easing?: EasingFn;\n}\nexport interface ParsedKeyframesDefinition {\n initialValues: StyleProps;\n keyframes: Record;\n}\nexport class Keyframe implements IEntryExitAnimationBuilder {\n durationV?: number;\n delayV?: number;\n callbackV?: (finished: boolean) => void;\n definitions: Record;\n\n /*\n Keyframe definition should be passed in the constructor as the map\n which keys are between range 0 - 100 (%) and correspond to the point in the animation progress.\n */\n constructor(definitions: Record) {\n this.definitions = definitions;\n }\n\n private parseDefinitions(): ParsedKeyframesDefinition {\n /* \n Each style property contain an array with all their key points: \n value, duration of transition to that value, and optional easing function (defaults to Linear)\n */\n const parsedKeyframes: Record = {};\n /*\n Parsing keyframes 'from' and 'to'.\n */\n if (this.definitions.from) {\n if (this.definitions['0']) {\n throw Error(\n \"You cannot provide both keyframe 0 and 'from' as they both specified initial values\"\n );\n }\n this.definitions['0'] = this.definitions.from;\n delete this.definitions.from;\n }\n if (this.definitions.to) {\n if (this.definitions['100']) {\n throw Error(\n \"You cannot provide both keyframe 100 and 'to' as they both specified values at the end of the animation.\"\n );\n }\n this.definitions['100'] = this.definitions.to;\n delete this.definitions.to;\n }\n /* \n One of the assumptions is that keyframe 0 is required to properly set initial values.\n Every other keyframe should contain properties from the set provided as initial values.\n */\n if (!this.definitions['0']) {\n throw Error(\n \"Please provide 0, or 'from' keyframe with initial state of your object.\"\n );\n }\n const initialValues: StyleProps = this.definitions['0'] as StyleProps;\n /*\n Initialize parsedKeyframes for properties provided in initial keyframe\n */\n Object.keys(initialValues).forEach((styleProp: string) => {\n if (styleProp === 'transform') {\n initialValues[styleProp]?.forEach((transformStyle, index) => {\n Object.keys(transformStyle).forEach((transformProp: string) => {\n parsedKeyframes[index.toString() + '_transform:' + transformProp] =\n [];\n });\n });\n } else {\n parsedKeyframes[styleProp] = [];\n }\n });\n\n const duration: number = this.durationV ? this.durationV : 500;\n const animationKeyPoints: Array = Array.from(\n Object.keys(this.definitions)\n );\n\n const getAnimationDuration = (\n key: string,\n currentKeyPoint: number\n ): number => {\n const maxDuration = (currentKeyPoint / 100) * duration;\n const currentDuration = parsedKeyframes[key].reduce(\n (acc: number, value: KeyframePoint) => acc + value.duration,\n 0\n );\n return maxDuration - currentDuration;\n };\n\n /* \n Other keyframes can't contain properties that were not specified in initial keyframe.\n */\n const addKeyPoint = ({\n key,\n value,\n currentKeyPoint,\n easing,\n }: {\n key: string;\n value: string | number;\n currentKeyPoint: number;\n easing?: EasingFn;\n }): void => {\n if (!(key in parsedKeyframes)) {\n throw Error(\n \"Keyframe can contain only that set of properties that were provide with initial values (keyframe 0 or 'from')\"\n );\n }\n parsedKeyframes[key].push({\n duration: getAnimationDuration(key, currentKeyPoint),\n value: value,\n easing: easing,\n });\n };\n animationKeyPoints\n .filter((value: string) => parseInt(value) !== 0)\n .sort((a: string, b: string) => parseInt(a) - parseInt(b))\n .forEach((keyPoint: string) => {\n if (parseInt(keyPoint) < 0 || parseInt(keyPoint) > 100) {\n throw Error('Keyframe should be in between range 0 - 100.');\n }\n const keyframe: KeyframeProps = this.definitions[keyPoint];\n const easing = keyframe.easing;\n delete keyframe.easing;\n const addKeyPointWith = (key: string, value: string | number) =>\n addKeyPoint({\n key,\n value,\n currentKeyPoint: parseInt(keyPoint),\n easing,\n });\n Object.keys(keyframe).forEach((key: string) => {\n if (key === 'transform') {\n keyframe[key]?.forEach(\n (transformStyle: { [key: string]: any }, index) => {\n Object.keys(transformStyle).forEach((transformProp: string) => {\n addKeyPointWith(\n index.toString() + '_transform:' + transformProp,\n transformStyle[transformProp]\n );\n });\n }\n );\n } else {\n addKeyPointWith(key, keyframe[key]);\n }\n });\n });\n return { initialValues: initialValues, keyframes: parsedKeyframes };\n }\n\n duration(durationMs: number): Keyframe {\n this.durationV = durationMs;\n return this;\n }\n\n delay(delayMs: number): Keyframe {\n this.delayV = delayMs;\n return this;\n }\n\n withCallback(callback: (finsihed: boolean) => void): Keyframe {\n this.callbackV = callback;\n return this;\n }\n\n private getDelayFunction(): AnimationFunction {\n const delay = this.delayV;\n return delay\n ? withDelay\n : (_, animation) => {\n 'worklet';\n return animation;\n };\n }\n\n build = (): EntryExitAnimationFunction => {\n const delay = this.delayV;\n const delayFunction = this.getDelayFunction();\n const { keyframes, initialValues } = this.parseDefinitions();\n const callback = this.callbackV;\n\n return (_targetValues) => {\n 'worklet';\n const animations: StyleProps = {};\n\n /* \n For each style property, an animations sequence is created that corresponds with its key points.\n Transform style properties require special handling because of their nested structure.\n */\n const addAnimation = (key: string) => {\n const keyframePoints = keyframes[key];\n // in case if property was only passed as initial value\n if (keyframePoints.length === 0) return;\n const animation = delayFunction(\n delay,\n keyframePoints.length === 1\n ? withTiming(keyframePoints[0].value, {\n duration: keyframePoints[0].duration,\n easing: keyframePoints[0].easing\n ? keyframePoints[0].easing\n : Easing.linear,\n })\n : withSequence.apply(\n this,\n keyframePoints.map((keyframePoint: KeyframePoint) =>\n withTiming(keyframePoint.value, {\n duration: keyframePoint.duration,\n easing: keyframePoint.easing\n ? keyframePoint.easing\n : Easing.linear,\n })\n )\n )\n );\n if (key.includes('transform')) {\n if (!('transform' in animations)) {\n animations.transform = [];\n }\n animations.transform?.push({\n [key.split(':')[1]]: animation,\n });\n } else {\n animations[key] = animation;\n }\n };\n Object.keys(initialValues).forEach((key: string) => {\n if (key.includes('transform')) {\n initialValues[key].forEach(\n (transformProp: Record, index: number) => {\n Object.keys(transformProp).forEach((transformPropKey: string) => {\n addAnimation(\n index.toString() + '_transform:' + transformPropKey\n );\n });\n }\n );\n } else {\n addAnimation(key);\n }\n });\n return {\n animations: animations,\n initialValues: initialValues,\n callback: callback,\n };\n };\n };\n}\n","export * from './Flip';\nexport * from './Stretch';\nexport * from './Fade';\nexport * from './Slide';\nexport * from './Zoom';\nexport * from './Bounce';\nexport * from './Lightspeed';\nexport * from './Pinwheel';\nexport * from './Rotate';\nexport * from './Roll';\n","import {\n IEntryExitAnimationBuilder,\n EntryExitAnimationFunction,\n EntryAnimationsValues,\n ExitAnimationsValues,\n AnimationConfigFunction,\n IEntryAnimationBuilder,\n IExitAnimationBuilder,\n} from '../animationBuilder/commonTypes';\nimport { ComplexAnimationBuilder } from '../animationBuilder';\n\nexport class FlipInXUp\n extends ComplexAnimationBuilder\n implements IEntryAnimationBuilder\n{\n static createInstance(): FlipInXUp {\n return new FlipInXUp();\n }\n\n build = (): AnimationConfigFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (targetValues) => {\n 'worklet';\n return {\n initialValues: {\n transform: [\n { perspective: 500 },\n { rotateX: '90deg' },\n { translateY: -targetValues.targetHeight },\n ],\n ...initialValues,\n },\n animations: {\n transform: [\n { perspective: 500 },\n { rotateX: delayFunction(delay, animation('0deg', config)) },\n { translateY: delayFunction(delay, animation(0, config)) },\n ],\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class FlipInYLeft\n extends ComplexAnimationBuilder\n implements IEntryAnimationBuilder\n{\n static createInstance(): FlipInYLeft {\n return new FlipInYLeft();\n }\n\n build = (): AnimationConfigFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (targetValues) => {\n 'worklet';\n return {\n initialValues: {\n transform: [\n { perspective: 500 },\n { rotateY: '-90deg' },\n { translateX: -targetValues.targetWidth },\n ],\n ...initialValues,\n },\n animations: {\n transform: [\n { perspective: delayFunction(delay, animation(500, config)) },\n { rotateY: delayFunction(delay, animation('0deg', config)) },\n { translateX: delayFunction(delay, animation(0, config)) },\n ],\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class FlipInXDown\n extends ComplexAnimationBuilder\n implements IEntryAnimationBuilder\n{\n static createInstance(): FlipInXDown {\n return new FlipInXDown();\n }\n\n build = (): AnimationConfigFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (targetValues) => {\n 'worklet';\n return {\n initialValues: {\n transform: [\n { perspective: 500 },\n { rotateX: '-90deg' },\n { translateY: targetValues.targetHeight },\n ],\n ...initialValues,\n },\n animations: {\n transform: [\n { perspective: delayFunction(delay, animation(500, config)) },\n { rotateX: delayFunction(delay, animation('0deg', config)) },\n { translateY: delayFunction(delay, animation(0, config)) },\n ],\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class FlipInYRight\n extends ComplexAnimationBuilder\n implements IEntryAnimationBuilder\n{\n static createInstance(): FlipInYRight {\n return new FlipInYRight();\n }\n\n build = (): AnimationConfigFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (targetValues) => {\n 'worklet';\n return {\n initialValues: {\n transform: [\n { perspective: 500 },\n { rotateY: '90deg' },\n { translateX: targetValues.targetWidth },\n ],\n ...initialValues,\n },\n animations: {\n transform: [\n { perspective: delayFunction(delay, animation(500, config)) },\n { rotateY: delayFunction(delay, animation('0deg', config)) },\n { translateX: delayFunction(delay, animation(0, config)) },\n ],\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class FlipInEasyX\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): FlipInEasyX {\n return new FlipInEasyX();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return () => {\n 'worklet';\n return {\n initialValues: {\n transform: [{ perspective: 500 }, { rotateX: '90deg' }],\n ...initialValues,\n },\n animations: {\n transform: [\n { perspective: delayFunction(delay, animation(500, config)) },\n { rotateX: delayFunction(delay, animation('0deg', config)) },\n ],\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class FlipInEasyY\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): FlipInEasyY {\n return new FlipInEasyY();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return () => {\n 'worklet';\n return {\n initialValues: {\n transform: [{ perspective: 500 }, { rotateY: '90deg' }],\n ...initialValues,\n },\n animations: {\n transform: [\n { perspective: delayFunction(delay, animation(500, config)) },\n { rotateY: delayFunction(delay, animation('0deg', config)) },\n ],\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class FlipOutXUp\n extends ComplexAnimationBuilder\n implements IExitAnimationBuilder\n{\n static createInstance(): FlipOutXUp {\n return new FlipOutXUp();\n }\n\n build = (): AnimationConfigFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (targetValues) => {\n 'worklet';\n return {\n initialValues: {\n transform: [\n { perspective: 500 },\n { rotateX: '0deg' },\n { translateY: 0 },\n ],\n ...initialValues,\n },\n animations: {\n transform: [\n { perspective: delayFunction(delay, animation(500, config)) },\n { rotateX: delayFunction(delay, animation('90deg', config)) },\n {\n translateY: delayFunction(\n delay,\n animation(-targetValues.currentHeight, config)\n ),\n },\n ],\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class FlipOutYLeft\n extends ComplexAnimationBuilder\n implements IExitAnimationBuilder\n{\n static createInstance(): FlipOutYLeft {\n return new FlipOutYLeft();\n }\n\n build = (): AnimationConfigFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (targetValues) => {\n 'worklet';\n return {\n initialValues: {\n transform: [\n { perspective: 500 },\n { rotateY: '0deg' },\n { translateX: 0 },\n ],\n ...initialValues,\n },\n animations: {\n transform: [\n { perspective: delayFunction(delay, animation(500, config)) },\n { rotateY: delayFunction(delay, animation('-90deg', config)) },\n {\n translateX: delayFunction(\n delay,\n animation(-targetValues.currentWidth, config)\n ),\n },\n ],\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class FlipOutXDown\n extends ComplexAnimationBuilder\n implements IExitAnimationBuilder\n{\n static createInstance(): FlipOutXDown {\n return new FlipOutXDown();\n }\n\n build = (): AnimationConfigFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (targetValues) => {\n 'worklet';\n return {\n initialValues: {\n transform: [\n { perspective: 500 },\n { rotateX: '0deg' },\n { translateY: 0 },\n ],\n ...initialValues,\n },\n animations: {\n transform: [\n { perspective: delayFunction(delay, animation(500, config)) },\n { rotateX: delayFunction(delay, animation('-90deg', config)) },\n {\n translateY: delayFunction(\n delay,\n animation(targetValues.currentHeight, config)\n ),\n },\n ],\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class FlipOutYRight\n extends ComplexAnimationBuilder\n implements IExitAnimationBuilder\n{\n static createInstance(): FlipOutYRight {\n return new FlipOutYRight();\n }\n\n build = (): AnimationConfigFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (targetValues) => {\n 'worklet';\n return {\n initialValues: {\n transform: [\n { perspective: 500 },\n { rotateY: '0deg' },\n { translateX: 0 },\n ],\n ...initialValues,\n },\n animations: {\n transform: [\n { perspective: delayFunction(delay, animation(500, config)) },\n { rotateY: delayFunction(delay, animation('90deg', config)) },\n {\n translateX: delayFunction(\n delay,\n animation(targetValues.currentWidth, config)\n ),\n },\n ],\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class FlipOutEasyX\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): FlipOutEasyX {\n return new FlipOutEasyX();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return () => {\n 'worklet';\n return {\n initialValues: {\n transform: [{ perspective: 500 }, { rotateX: '0deg' }],\n ...initialValues,\n },\n animations: {\n transform: [\n { perspective: delayFunction(delay, animation(500, config)) },\n { rotateX: delayFunction(delay, animation('90deg', config)) },\n ],\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class FlipOutEasyY\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): FlipOutEasyY {\n return new FlipOutEasyY();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return () => {\n 'worklet';\n return {\n initialValues: {\n transform: [{ perspective: 500 }, { rotateY: '0deg' }],\n ...initialValues,\n },\n animations: {\n transform: [\n { perspective: delayFunction(delay, animation(500, config)) },\n { rotateY: delayFunction(delay, animation('90deg', config)) },\n ],\n },\n callback: callback,\n };\n };\n };\n}\n","import {\n IEntryExitAnimationBuilder,\n EntryExitAnimationFunction,\n} from '../animationBuilder/commonTypes';\nimport { ComplexAnimationBuilder } from '../animationBuilder';\n\nexport class StretchInX\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): StretchInX {\n return new StretchInX();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return () => {\n 'worklet';\n return {\n animations: {\n transform: [{ scaleX: delayFunction(delay, animation(1, config)) }],\n },\n initialValues: {\n transform: [{ scaleX: 0 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class StretchInY\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): StretchInY {\n return new StretchInY();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return () => {\n 'worklet';\n return {\n animations: {\n transform: [{ scaleY: delayFunction(delay, animation(1, config)) }],\n },\n initialValues: {\n transform: [{ scaleY: 0 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class StretchOutX\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): StretchOutX {\n return new StretchOutX();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return () => {\n 'worklet';\n return {\n animations: {\n transform: [{ scaleX: delayFunction(delay, animation(0, config)) }],\n },\n initialValues: {\n transform: [{ scaleX: 1 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class StretchOutY\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): StretchOutY {\n return new StretchOutY();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return () => {\n 'worklet';\n return {\n animations: {\n transform: [{ scaleY: delayFunction(delay, animation(0, config)) }],\n },\n initialValues: {\n transform: [{ scaleY: 1 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n","import {\n IEntryExitAnimationBuilder,\n EntryExitAnimationFunction,\n} from '../animationBuilder/commonTypes';\nimport { ComplexAnimationBuilder } from '../animationBuilder';\n\nexport class FadeIn\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): FadeIn {\n return new FadeIn();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n const delay = this.getDelay();\n\n return (_) => {\n 'worklet';\n return {\n animations: {\n opacity: delayFunction(delay, animation(1, config)),\n },\n initialValues: {\n opacity: 0,\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class FadeInRight\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): FadeInRight {\n return new FadeInRight();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n const delay = this.getDelay();\n\n return () => {\n 'worklet';\n return {\n animations: {\n opacity: delayFunction(delay, animation(1, config)),\n transform: [\n { translateX: delayFunction(delay, animation(0, config)) },\n ],\n },\n initialValues: {\n opacity: 0,\n transform: [{ translateX: 25 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class FadeInLeft\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): FadeInLeft {\n return new FadeInLeft();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n const delay = this.getDelay();\n\n return () => {\n 'worklet';\n return {\n animations: {\n opacity: delayFunction(delay, animation(1, config)),\n transform: [\n { translateX: delayFunction(delay, animation(0, config)) },\n ],\n },\n initialValues: {\n opacity: 0,\n transform: [{ translateX: -25 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class FadeInUp\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): FadeInUp {\n return new FadeInUp();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n const delay = this.getDelay();\n\n return () => {\n 'worklet';\n return {\n animations: {\n opacity: delayFunction(delay, animation(1, config)),\n transform: [\n { translateY: delayFunction(delay, animation(0, config)) },\n ],\n },\n initialValues: {\n opacity: 0,\n transform: [{ translateY: -25 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class FadeInDown\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): FadeInDown {\n return new FadeInDown();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n const delay = this.getDelay();\n\n return () => {\n 'worklet';\n return {\n animations: {\n opacity: delayFunction(delay, animation(1, config)),\n transform: [\n { translateY: delayFunction(delay, animation(0, config)) },\n ],\n },\n initialValues: {\n opacity: 0,\n transform: [{ translateY: 25 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class FadeOut\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): FadeOut {\n return new FadeOut();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n const delay = this.getDelay();\n\n return (_) => {\n 'worklet';\n return {\n animations: {\n opacity: delayFunction(delay, animation(0, config)),\n },\n initialValues: {\n opacity: 1,\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class FadeOutRight\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): FadeOutRight {\n return new FadeOutRight();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n const delay = this.getDelay();\n\n return () => {\n 'worklet';\n return {\n animations: {\n opacity: delayFunction(delay, animation(0, config)),\n transform: [\n { translateX: delayFunction(delay, animation(25, config)) },\n ],\n },\n initialValues: {\n opacity: 1,\n transform: [{ translateX: 0 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class FadeOutLeft\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): FadeOutLeft {\n return new FadeOutLeft();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n const delay = this.getDelay();\n\n return () => {\n 'worklet';\n return {\n animations: {\n opacity: delayFunction(delay, animation(0, config)),\n transform: [\n { translateX: delayFunction(delay, animation(-25, config)) },\n ],\n },\n initialValues: {\n opacity: 1,\n transform: [{ translateX: 0 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class FadeOutUp\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): FadeOutUp {\n return new FadeOutUp();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n const delay = this.getDelay();\n\n return () => {\n 'worklet';\n return {\n animations: {\n opacity: delayFunction(delay, animation(0, config)),\n transform: [\n { translateY: delayFunction(delay, animation(-25, config)) },\n ],\n },\n initialValues: {\n opacity: 1,\n transform: [{ translateY: 0 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class FadeOutDown\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): FadeOutDown {\n return new FadeOutDown();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n const delay = this.getDelay();\n\n return () => {\n 'worklet';\n return {\n animations: {\n opacity: delayFunction(delay, animation(0, config)),\n transform: [\n { translateY: delayFunction(delay, animation(25, config)) },\n ],\n },\n initialValues: {\n opacity: 1,\n transform: [{ translateY: 0 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n","import {\n EntryAnimationsValues,\n ExitAnimationsValues,\n AnimationConfigFunction,\n IEntryAnimationBuilder,\n IExitAnimationBuilder,\n} from '../animationBuilder/commonTypes';\nimport { ComplexAnimationBuilder } from '../animationBuilder';\n\nexport class SlideInRight\n extends ComplexAnimationBuilder\n implements IEntryAnimationBuilder\n{\n static createInstance(): SlideInRight {\n return new SlideInRight();\n }\n\n build = (): AnimationConfigFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n originX: delayFunction(\n delay,\n animation(values.targetOriginX, config)\n ),\n },\n initialValues: {\n originX: values.targetOriginX + values.windowWidth,\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class SlideInLeft\n extends ComplexAnimationBuilder\n implements IEntryAnimationBuilder\n{\n static createInstance(): SlideInLeft {\n return new SlideInLeft();\n }\n\n build = (): AnimationConfigFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n originX: delayFunction(\n delay,\n animation(values.targetOriginX, config)\n ),\n },\n initialValues: {\n originX: values.targetOriginX - values.windowWidth,\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class SlideOutRight\n extends ComplexAnimationBuilder\n implements IExitAnimationBuilder\n{\n static createInstance(): SlideOutRight {\n return new SlideOutRight();\n }\n\n build = (): AnimationConfigFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n originX: delayFunction(\n delay,\n animation(\n Math.max(\n values.currentOriginX + values.windowWidth,\n values.windowWidth\n ),\n config\n )\n ),\n },\n initialValues: {\n originX: values.currentOriginX,\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class SlideOutLeft\n extends ComplexAnimationBuilder\n implements IExitAnimationBuilder\n{\n static createInstance(): SlideOutLeft {\n return new SlideOutLeft();\n }\n\n build = (): AnimationConfigFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n originX: delayFunction(\n delay,\n animation(\n Math.min(\n values.currentOriginX - values.windowWidth,\n -values.windowWidth\n ),\n config\n )\n ),\n },\n initialValues: {\n originX: values.currentOriginX,\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class SlideInUp\n extends ComplexAnimationBuilder\n implements IEntryAnimationBuilder\n{\n static createInstance(): SlideInUp {\n return new SlideInUp();\n }\n\n build = (): AnimationConfigFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n originY: delayFunction(\n delay,\n animation(values.targetOriginY, config)\n ),\n },\n initialValues: {\n originY: -values.windowHeight,\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class SlideInDown\n extends ComplexAnimationBuilder\n implements IEntryAnimationBuilder\n{\n static createInstance(): SlideInDown {\n return new SlideInDown();\n }\n\n build = (): AnimationConfigFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n originY: delayFunction(\n delay,\n animation(values.targetOriginY, config)\n ),\n },\n initialValues: {\n originY: values.targetOriginY + values.windowHeight,\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class SlideOutUp\n extends ComplexAnimationBuilder\n implements IExitAnimationBuilder\n{\n static createInstance(): SlideOutUp {\n return new SlideOutUp();\n }\n\n build = (): AnimationConfigFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n originY: delayFunction(\n delay,\n animation(\n Math.min(\n values.currentOriginY - values.windowHeight,\n -values.windowHeight\n ),\n config\n )\n ),\n },\n initialValues: { originY: values.currentOriginY, ...initialValues },\n callback: callback,\n };\n };\n };\n}\n\nexport class SlideOutDown\n extends ComplexAnimationBuilder\n implements IExitAnimationBuilder\n{\n static createInstance(): SlideOutDown {\n return new SlideOutDown();\n }\n\n build = (): AnimationConfigFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n originY: delayFunction(\n delay,\n animation(\n Math.max(\n values.currentOriginY + values.windowHeight,\n values.windowHeight\n ),\n config\n )\n ),\n },\n initialValues: { originY: values.currentOriginY, ...initialValues },\n callback: callback,\n };\n };\n };\n}\n","import {\n IEntryExitAnimationBuilder,\n EntryExitAnimationFunction,\n EntryAnimationsValues,\n ExitAnimationsValues,\n AnimationConfigFunction,\n IEntryAnimationBuilder,\n IExitAnimationBuilder,\n} from '../animationBuilder/commonTypes';\nimport { ComplexAnimationBuilder } from '../animationBuilder';\n\nexport class ZoomIn\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): ZoomIn {\n return new ZoomIn();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return () => {\n 'worklet';\n return {\n animations: {\n transform: [{ scale: delayFunction(delay, animation(1, config)) }],\n },\n initialValues: {\n transform: [{ scale: 0 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class ZoomInRotate\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): ZoomInRotate {\n return new ZoomInRotate();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const rotate = this.rotateV ? this.rotateV : '0.3';\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return () => {\n 'worklet';\n return {\n animations: {\n transform: [\n { scale: delayFunction(delay, animation(1, config)) },\n { rotate: delayFunction(delay, animation(0, config)) },\n ],\n },\n initialValues: {\n transform: [{ scale: 0 }, { rotate: rotate }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class ZoomInLeft\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): ZoomInLeft {\n return new ZoomInLeft();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n transform: [\n { translateX: delayFunction(delay, animation(0, config)) },\n { scale: delayFunction(delay, animation(1, config)) },\n ],\n },\n initialValues: {\n transform: [{ translateX: -values.windowWidth }, { scale: 0 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class ZoomInRight\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): ZoomInRight {\n return new ZoomInRight();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n transform: [\n { translateX: delayFunction(delay, animation(0, config)) },\n { scale: delayFunction(delay, animation(1, config)) },\n ],\n },\n initialValues: {\n transform: [{ translateX: values.windowWidth }, { scale: 0 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class ZoomInUp\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): ZoomInUp {\n return new ZoomInUp();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n transform: [\n { translateY: delayFunction(delay, animation(0, config)) },\n { scale: delayFunction(delay, animation(1, config)) },\n ],\n },\n initialValues: {\n transform: [{ translateY: -values.windowHeight }, { scale: 0 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class ZoomInDown\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): ZoomInDown {\n return new ZoomInDown();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n transform: [\n { translateY: delayFunction(delay, animation(0, config)) },\n { scale: delayFunction(delay, animation(1, config)) },\n ],\n },\n initialValues: {\n transform: [{ translateY: values.windowHeight }, { scale: 0 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class ZoomInEasyUp\n extends ComplexAnimationBuilder\n implements IEntryAnimationBuilder\n{\n static createInstance(): ZoomInEasyUp {\n return new ZoomInEasyUp();\n }\n\n build = (): AnimationConfigFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n transform: [\n { translateY: delayFunction(delay, animation(0, config)) },\n { scale: delayFunction(delay, animation(1, config)) },\n ],\n },\n initialValues: {\n transform: [{ translateY: -values.targetHeight }, { scale: 0 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class ZoomInEasyDown\n extends ComplexAnimationBuilder\n implements IEntryAnimationBuilder\n{\n static createInstance(): ZoomInEasyDown {\n return new ZoomInEasyDown();\n }\n\n build = (): AnimationConfigFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n transform: [\n { translateY: delayFunction(delay, animation(0, config)) },\n { scale: delayFunction(delay, animation(1, config)) },\n ],\n },\n initialValues: {\n transform: [{ translateY: values.targetHeight }, { scale: 0 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class ZoomOut\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): ZoomOut {\n return new ZoomOut();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return () => {\n 'worklet';\n return {\n animations: {\n transform: [{ scale: delayFunction(delay, animation(0, config)) }],\n },\n initialValues: {\n transform: [{ scale: 1 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class ZoomOutRotate\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): ZoomOutRotate {\n return new ZoomOutRotate();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const rotate = this.rotateV ? this.rotateV : '0.3';\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return () => {\n 'worklet';\n return {\n animations: {\n transform: [\n { scale: delayFunction(delay, animation(0, config)) },\n { rotate: delayFunction(delay, animation(rotate, config)) },\n ],\n },\n initialValues: {\n transform: [{ scale: 1 }, { rotate: '0' }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class ZoomOutLeft\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): ZoomOutLeft {\n return new ZoomOutLeft();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n transform: [\n {\n translateX: delayFunction(\n delay,\n animation(-values.windowWidth, config)\n ),\n },\n { scale: delayFunction(delay, animation(0, config)) },\n ],\n },\n initialValues: {\n transform: [{ translateX: 0 }, { scale: 1 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class ZoomOutRight\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): ZoomOutRight {\n return new ZoomOutRight();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n transform: [\n {\n translateX: delayFunction(\n delay,\n animation(values.windowWidth, config)\n ),\n },\n { scale: delayFunction(delay, animation(0, config)) },\n ],\n },\n initialValues: {\n transform: [{ translateX: 0 }, { scale: 1 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class ZoomOutUp\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): ZoomOutUp {\n return new ZoomOutUp();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n transform: [\n {\n translateY: delayFunction(\n delay,\n animation(-values.windowHeight, config)\n ),\n },\n { scale: delayFunction(delay, animation(0, config)) },\n ],\n },\n initialValues: {\n transform: [{ translateY: 0 }, { scale: 1 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class ZoomOutDown\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): ZoomOutDown {\n return new ZoomOutDown();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n transform: [\n {\n translateY: delayFunction(\n delay,\n animation(values.windowHeight, config)\n ),\n },\n { scale: delayFunction(delay, animation(0, config)) },\n ],\n },\n initialValues: {\n transform: [{ translateY: 0 }, { scale: 1 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class ZoomOutEasyUp\n extends ComplexAnimationBuilder\n implements IExitAnimationBuilder\n{\n static createInstance(): ZoomOutEasyUp {\n return new ZoomOutEasyUp();\n }\n\n build = (): AnimationConfigFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n transform: [\n {\n translateY: delayFunction(\n delay,\n animation(-values.currentHeight, config)\n ),\n },\n { scale: delayFunction(delay, animation(0, config)) },\n ],\n },\n initialValues: {\n transform: [{ translateY: 0 }, { scale: 1 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class ZoomOutEasyDown\n extends ComplexAnimationBuilder\n implements IExitAnimationBuilder\n{\n static createInstance(): ZoomOutEasyDown {\n return new ZoomOutEasyDown();\n }\n\n build = (): AnimationConfigFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n transform: [\n {\n translateY: delayFunction(\n delay,\n animation(values.currentHeight, config)\n ),\n },\n { scale: delayFunction(delay, animation(0, config)) },\n ],\n },\n initialValues: {\n transform: [{ translateY: 0 }, { scale: 1 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n","import {\n EntryExitAnimationFunction,\n IEntryExitAnimationBuilder,\n} from '../animationBuilder/commonTypes';\nimport { withSequence, withTiming } from '../../animation';\nimport { ComplexAnimationBuilder } from '../animationBuilder/ComplexAnimationBuilder';\n\nexport class BounceIn\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): BounceIn {\n return new BounceIn();\n }\n\n static getDuration(): number {\n return 600;\n }\n\n getDuration(): number {\n return this.durationV ?? 600;\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const delay = this.getDelay();\n const duration = this.getDuration();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return () => {\n 'worklet';\n return {\n animations: {\n transform: [\n {\n scale: delayFunction(\n delay,\n withSequence(\n withTiming(1.2, { duration: duration * 0.55 }),\n withTiming(0.9, { duration: duration * 0.15 }),\n withTiming(1.1, { duration: duration * 0.15 }),\n withTiming(1, { duration: duration * 0.15 })\n )\n ),\n },\n ],\n },\n initialValues: {\n transform: [{ scale: 0 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class BounceInDown\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): BounceInDown {\n return new BounceInDown();\n }\n\n static getDuration(): number {\n return 600;\n }\n\n getDuration(): number {\n return this.durationV ?? 600;\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const delay = this.getDelay();\n const duration = this.getDuration();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n transform: [\n {\n translateY: delayFunction(\n delay,\n withSequence(\n withTiming(-20, { duration: duration * 0.55 }),\n withTiming(10, { duration: duration * 0.15 }),\n withTiming(-10, { duration: duration * 0.15 }),\n withTiming(0, { duration: duration * 0.15 })\n )\n ),\n },\n ],\n },\n initialValues: {\n transform: [\n {\n translateY: values.windowHeight,\n },\n ],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class BounceInUp\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): BounceInUp {\n return new BounceInUp();\n }\n\n static getDuration(): number {\n return 600;\n }\n\n getDuration(): number {\n return this.durationV ?? 600;\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const delay = this.getDelay();\n const duration = this.getDuration();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n transform: [\n {\n translateY: delayFunction(\n delay,\n withSequence(\n withTiming(20, { duration: duration * 0.55 }),\n withTiming(-10, { duration: duration * 0.15 }),\n withTiming(10, { duration: duration * 0.15 }),\n withTiming(0, { duration: duration * 0.15 })\n )\n ),\n },\n ],\n },\n initialValues: {\n transform: [{ translateY: -values.windowHeight }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class BounceInLeft\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): BounceInLeft {\n return new BounceInLeft();\n }\n\n static getDuration(): number {\n return 600;\n }\n\n getDuration(): number {\n return this.durationV ?? 600;\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const delay = this.getDelay();\n const duration = this.getDuration();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n transform: [\n {\n translateX: delayFunction(\n delay,\n withSequence(\n withTiming(20, { duration: duration * 0.55 }),\n withTiming(-10, { duration: duration * 0.15 }),\n withTiming(10, { duration: duration * 0.15 }),\n withTiming(0, { duration: duration * 0.15 })\n )\n ),\n },\n ],\n },\n initialValues: {\n transform: [{ translateX: -values.windowWidth }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class BounceInRight\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): BounceInRight {\n return new BounceInRight();\n }\n\n static getDuration(): number {\n return 600;\n }\n\n getDuration(): number {\n return this.durationV ?? 600;\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const delay = this.getDelay();\n const duration = this.getDuration();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n transform: [\n {\n translateX: delayFunction(\n delay,\n withSequence(\n withTiming(-20, { duration: duration * 0.55 }),\n withTiming(10, { duration: duration * 0.15 }),\n withTiming(-10, { duration: duration * 0.15 }),\n withTiming(0, { duration: duration * 0.15 })\n )\n ),\n },\n ],\n },\n initialValues: {\n transform: [{ translateX: values.windowWidth }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class BounceOut\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): BounceOut {\n return new BounceOut();\n }\n\n static getDuration(): number {\n return 600;\n }\n\n getDuration(): number {\n return this.durationV ?? 600;\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const delay = this.getDelay();\n const duration = this.getDuration();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return () => {\n 'worklet';\n return {\n animations: {\n transform: [\n {\n scale: delayFunction(\n delay,\n withSequence(\n withTiming(1.1, { duration: duration * 0.15 }),\n withTiming(0.9, { duration: duration * 0.15 }),\n withTiming(1.2, { duration: duration * 0.15 }),\n withTiming(0, { duration: duration * 0.55 })\n )\n ),\n },\n ],\n },\n initialValues: {\n transform: [{ scale: 1 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class BounceOutDown\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): BounceOutDown {\n return new BounceOutDown();\n }\n\n static getDuration(): number {\n return 600;\n }\n\n getDuration(): number {\n return this.durationV ?? 600;\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const delay = this.getDelay();\n const duration = this.getDuration();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n transform: [\n {\n translateY: delayFunction(\n delay,\n withSequence(\n withTiming(-10, { duration: duration * 0.15 }),\n withTiming(10, { duration: duration * 0.15 }),\n withTiming(-20, { duration: duration * 0.15 }),\n withTiming(values.windowHeight, {\n duration: duration * 0.55,\n })\n )\n ),\n },\n ],\n },\n initialValues: {\n transform: [{ translateY: 0 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class BounceOutUp\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): BounceOutUp {\n return new BounceOutUp();\n }\n\n static getDuration(): number {\n return 600;\n }\n\n getDuration(): number {\n return this.durationV ?? 600;\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const delay = this.getDelay();\n const duration = this.getDuration();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n transform: [\n {\n translateY: delayFunction(\n delay,\n withSequence(\n withTiming(10, { duration: duration * 0.15 }),\n withTiming(-10, { duration: duration * 0.15 }),\n withTiming(20, { duration: duration * 0.15 }),\n withTiming(-values.windowHeight, {\n duration: duration * 0.55,\n })\n )\n ),\n },\n ],\n },\n initialValues: {\n transform: [{ translateY: 0 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class BounceOutLeft\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): BounceOutRight {\n return new BounceOutLeft();\n }\n\n static getDuration(): number {\n return 600;\n }\n\n getDuration(): number {\n return this.durationV ?? 600;\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const delay = this.getDelay();\n const duration = this.getDuration();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n transform: [\n {\n translateX: delayFunction(\n delay,\n withSequence(\n withTiming(10, { duration: duration * 0.15 }),\n withTiming(-10, { duration: duration * 0.15 }),\n withTiming(20, { duration: duration * 0.15 }),\n withTiming(-values.windowWidth, {\n duration: duration * 0.55,\n })\n )\n ),\n },\n ],\n },\n initialValues: {\n transform: [{ translateX: 0 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class BounceOutRight\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): BounceOutRight {\n return new BounceOutRight();\n }\n\n static getDuration(): number {\n return 600;\n }\n\n getDuration(): number {\n return this.durationV ?? 600;\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const delay = this.getDelay();\n const duration = this.getDuration();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n transform: [\n {\n translateX: delayFunction(\n delay,\n withSequence(\n withTiming(-10, { duration: duration * 0.15 }),\n withTiming(10, { duration: duration * 0.15 }),\n withTiming(-20, { duration: duration * 0.15 }),\n withTiming(values.windowWidth, {\n duration: duration * 0.55,\n })\n )\n ),\n },\n ],\n },\n initialValues: {\n transform: [{ translateX: 0 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n","import { withSequence, withTiming } from '../../animation';\nimport { ComplexAnimationBuilder } from '../animationBuilder';\nimport {\n EntryExitAnimationFunction,\n IEntryExitAnimationBuilder,\n} from '../animationBuilder/commonTypes';\n\nexport class LightSpeedInRight\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): LightSpeedInRight {\n return new LightSpeedInRight();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const duration = this.getDuration();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n opacity: delayFunction(delay, withTiming(1, { duration: duration })),\n transform: [\n {\n translateX: delayFunction(\n delay,\n animation(0, { ...config, duration: duration * 0.7 })\n ),\n },\n {\n skewX: delayFunction(\n delay,\n withSequence(\n withTiming('10deg', { duration: duration * 0.7 }),\n withTiming('-5deg', { duration: duration * 0.15 }),\n withTiming('0deg', { duration: duration * 0.15 })\n )\n ),\n },\n ],\n },\n initialValues: {\n opacity: 0,\n transform: [{ translateX: values.windowWidth }, { skewX: '-45deg' }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class LightSpeedInLeft\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): LightSpeedInLeft {\n return new LightSpeedInLeft();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const duration = this.getDuration();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n opacity: delayFunction(delay, withTiming(1, { duration: duration })),\n transform: [\n {\n translateX: delayFunction(\n delay,\n animation(0, { ...config, duration: duration * 0.7 })\n ),\n },\n {\n skewX: delayFunction(\n delay,\n withSequence(\n withTiming('-10deg', { duration: duration * 0.7 }),\n withTiming('5deg', { duration: duration * 0.15 }),\n withTiming('0deg', { duration: duration * 0.15 })\n )\n ),\n },\n ],\n },\n initialValues: {\n opacity: 0,\n transform: [{ translateX: -values.windowWidth }, { skewX: '45deg' }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class LightSpeedOutRight\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): LightSpeedOutRight {\n return new LightSpeedOutRight();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n opacity: delayFunction(delay, animation(0, config)),\n transform: [\n {\n translateX: delayFunction(\n delay,\n animation(values.windowWidth, config)\n ),\n },\n {\n skewX: delayFunction(delay, animation('-45deg', config)),\n },\n ],\n },\n initialValues: {\n opacity: 1,\n transform: [{ translateX: 0 }, { skewX: '0deg' }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class LightSpeedOutLeft\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): LightSpeedOutLeft {\n return new LightSpeedOutLeft();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n opacity: delayFunction(delay, animation(0, config)),\n transform: [\n {\n translateX: delayFunction(\n delay,\n animation(-values.windowWidth, config)\n ),\n },\n {\n skewX: delayFunction(delay, animation('45deg', config)),\n },\n ],\n },\n initialValues: {\n opacity: 1,\n transform: [{ translateX: 0 }, { skewX: '0deg' }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n","import { ComplexAnimationBuilder } from '../animationBuilder';\nimport {\n EntryExitAnimationFunction,\n IEntryExitAnimationBuilder,\n} from '../animationBuilder/commonTypes';\n\nexport class PinwheelIn\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): PinwheelIn {\n return new PinwheelIn();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (_values) => {\n 'worklet';\n return {\n animations: {\n opacity: delayFunction(delay, animation(1, config)),\n transform: [\n {\n scale: delayFunction(delay, animation(1, config)),\n },\n {\n rotate: delayFunction(delay, animation('0', config)),\n },\n ],\n },\n initialValues: {\n opacity: 0,\n transform: [\n {\n scale: 0,\n },\n {\n rotate: '5',\n },\n ],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class PinwheelOut\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): PinwheelOut {\n return new PinwheelOut();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (_values) => {\n 'worklet';\n return {\n animations: {\n opacity: delayFunction(delay, animation(0, config)),\n transform: [\n {\n scale: delayFunction(delay, animation(0, config)),\n },\n {\n rotate: delayFunction(delay, animation('5', config)),\n },\n ],\n },\n initialValues: {\n opacity: 1,\n transform: [\n {\n scale: 1,\n },\n {\n rotate: '0',\n },\n ],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n","import { ComplexAnimationBuilder } from '../animationBuilder';\nimport {\n EntryAnimationsValues,\n ExitAnimationsValues,\n AnimationConfigFunction,\n IEntryAnimationBuilder,\n IExitAnimationBuilder,\n} from '../animationBuilder/commonTypes';\n\nexport class RotateInDownLeft\n extends ComplexAnimationBuilder\n implements IEntryAnimationBuilder\n{\n static createInstance(): RotateInDownLeft {\n return new RotateInDownLeft();\n }\n\n build = (): AnimationConfigFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n opacity: delayFunction(delay, animation(1, config)),\n transform: [\n { rotate: delayFunction(delay, animation('0deg', config)) },\n { translateX: delayFunction(delay, animation(0, config)) },\n { translateY: delayFunction(delay, animation(0, config)) },\n ],\n },\n initialValues: {\n opacity: 0,\n transform: [\n { rotate: '-90deg' },\n { translateX: values.targetWidth / 2 - values.targetHeight / 2 },\n { translateY: -(values.targetWidth / 2 - values.targetHeight / 2) },\n ],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class RotateInDownRight\n extends ComplexAnimationBuilder\n implements IEntryAnimationBuilder\n{\n static createInstance(): RotateInDownRight {\n return new RotateInDownRight();\n }\n\n build = (): AnimationConfigFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n opacity: delayFunction(delay, animation(1, config)),\n transform: [\n { rotate: delayFunction(delay, animation('0deg', config)) },\n { translateX: delayFunction(delay, animation(0, config)) },\n { translateY: delayFunction(delay, animation(0, config)) },\n ],\n },\n initialValues: {\n opacity: 0,\n transform: [\n { rotate: '90deg' },\n { translateX: -(values.targetWidth / 2 - values.targetHeight / 2) },\n { translateY: -(values.targetWidth / 2 - values.targetHeight / 2) },\n ],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class RotateInUpLeft\n extends ComplexAnimationBuilder\n implements IEntryAnimationBuilder\n{\n static createInstance(): RotateInUpLeft {\n return new RotateInUpLeft();\n }\n\n build = (): AnimationConfigFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n opacity: delayFunction(delay, animation(1, config)),\n transform: [\n { rotate: delayFunction(delay, animation('0deg', config)) },\n { translateX: delayFunction(delay, animation(0, config)) },\n { translateY: delayFunction(delay, animation(0, config)) },\n ],\n },\n initialValues: {\n opacity: 0,\n transform: [\n { rotate: '90deg' },\n { translateX: values.targetWidth / 2 - values.targetHeight / 2 },\n { translateY: values.targetWidth / 2 - values.targetHeight / 2 },\n ],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class RotateInUpRight\n extends ComplexAnimationBuilder\n implements IEntryAnimationBuilder\n{\n static createInstance(): RotateInUpRight {\n return new RotateInUpRight();\n }\n\n build = (): AnimationConfigFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n opacity: delayFunction(delay, animation(1, config)),\n transform: [\n { rotate: delayFunction(delay, animation('0deg', config)) },\n { translateX: delayFunction(delay, animation(0, config)) },\n { translateY: delayFunction(delay, animation(0, config)) },\n ],\n },\n initialValues: {\n opacity: 0,\n transform: [\n { rotate: '-90deg' },\n { translateX: -(values.targetWidth / 2 - values.targetHeight / 2) },\n { translateY: values.targetWidth / 2 - values.targetHeight / 2 },\n ],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class RotateOutDownLeft\n extends ComplexAnimationBuilder\n implements IExitAnimationBuilder\n{\n static createInstance(): RotateOutDownLeft {\n return new RotateOutDownLeft();\n }\n\n build = (): AnimationConfigFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n opacity: delayFunction(delay, animation(0, config)),\n transform: [\n { rotate: delayFunction(delay, animation('90deg', config)) },\n {\n translateX: delayFunction(\n delay,\n animation(\n values.currentWidth / 2 - values.currentHeight / 2,\n config\n )\n ),\n },\n {\n translateY: delayFunction(\n delay,\n animation(\n values.currentWidth / 2 - values.currentHeight / 2,\n config\n )\n ),\n },\n ],\n },\n initialValues: {\n opacity: 1,\n transform: [{ rotate: '0deg' }, { translateX: 0 }, { translateY: 0 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class RotateOutDownRight\n extends ComplexAnimationBuilder\n implements IExitAnimationBuilder\n{\n static createInstance(): RotateOutDownRight {\n return new RotateOutDownRight();\n }\n\n build = (): AnimationConfigFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n opacity: delayFunction(delay, animation(0, config)),\n transform: [\n { rotate: delayFunction(delay, animation('-90deg', config)) },\n {\n translateX: delayFunction(\n delay,\n animation(\n -(values.currentWidth / 2 - values.currentHeight / 2),\n config\n )\n ),\n },\n {\n translateY: delayFunction(\n delay,\n animation(\n values.currentWidth / 2 - values.currentHeight / 2,\n config\n )\n ),\n },\n ],\n },\n initialValues: {\n opacity: 1,\n transform: [{ rotate: '0deg' }, { translateX: 0 }, { translateY: 0 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class RotateOutUpLeft\n extends ComplexAnimationBuilder\n implements IExitAnimationBuilder\n{\n static createInstance(): RotateOutUpLeft {\n return new RotateOutUpLeft();\n }\n\n build = (): AnimationConfigFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n opacity: delayFunction(delay, animation(0, config)),\n transform: [\n { rotate: delayFunction(delay, animation('-90deg', config)) },\n {\n translateX: delayFunction(\n delay,\n animation(\n values.currentWidth / 2 - values.currentHeight / 2,\n config\n )\n ),\n },\n {\n translateY: delayFunction(\n delay,\n animation(\n -(values.currentWidth / 2 - values.currentHeight / 2),\n config\n )\n ),\n },\n ],\n },\n initialValues: {\n opacity: 1,\n transform: [{ rotate: '0deg' }, { translateX: 0 }, { translateY: 0 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class RotateOutUpRight\n extends ComplexAnimationBuilder\n implements IExitAnimationBuilder\n{\n static createInstance(): RotateOutUpRight {\n return new RotateOutUpRight();\n }\n\n build = (): AnimationConfigFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n opacity: delayFunction(delay, animation(0, config)),\n transform: [\n { rotate: delayFunction(delay, animation('90deg', config)) },\n {\n translateX: delayFunction(\n delay,\n animation(\n -(values.currentWidth / 2 - values.currentHeight / 2),\n config\n )\n ),\n },\n {\n translateY: delayFunction(\n delay,\n animation(\n -(values.currentWidth / 2 - values.currentHeight / 2),\n config\n )\n ),\n },\n ],\n },\n initialValues: {\n opacity: 1,\n transform: [{ rotate: '0deg' }, { translateX: 0 }, { translateY: 0 }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n","import { ComplexAnimationBuilder } from '../animationBuilder';\nimport {\n EntryExitAnimationFunction,\n IEntryExitAnimationBuilder,\n} from '../animationBuilder/commonTypes';\n\nexport class RollInLeft\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): RollInLeft {\n return new RollInLeft();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n transform: [\n { translateX: delayFunction(delay, animation(0), config) },\n { rotate: delayFunction(delay, animation('0deg', config)) },\n ],\n },\n initialValues: {\n transform: [\n { translateX: -values.windowWidth },\n { rotate: '-180deg' },\n ],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class RollInRight\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): RollInRight {\n return new RollInRight();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n transform: [\n { translateX: delayFunction(delay, animation(0, config)) },\n { rotate: delayFunction(delay, animation('0deg', config)) },\n ],\n },\n initialValues: {\n transform: [{ translateX: values.windowWidth }, { rotate: '180deg' }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class RollOutLeft\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): RollOutLeft {\n return new RollOutLeft();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n transform: [\n {\n translateX: delayFunction(\n delay,\n animation(-values.windowWidth, config)\n ),\n },\n { rotate: delayFunction(delay, animation('-180deg', config)) },\n ],\n },\n initialValues: {\n transform: [{ translateX: 0 }, { rotate: '0deg' }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport class RollOutRight\n extends ComplexAnimationBuilder\n implements IEntryExitAnimationBuilder\n{\n static createInstance(): RollOutRight {\n return new RollOutRight();\n }\n\n build = (): EntryExitAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const delay = this.getDelay();\n const callback = this.callbackV;\n const initialValues = this.initialValues;\n\n return (values) => {\n 'worklet';\n return {\n animations: {\n transform: [\n {\n translateX: delayFunction(\n delay,\n animation(values.windowWidth, config)\n ),\n },\n { rotate: delayFunction(delay, animation('180deg', config)) },\n ],\n },\n initialValues: {\n transform: [{ translateX: 0 }, { rotate: '0deg' }],\n ...initialValues,\n },\n callback: callback,\n };\n };\n };\n}\n","export * from './LinearTransition';\nexport * from './FadingTransition';\nexport * from './SequencedTransition';\nexport * from './JumpingTransition';\nexport * from './CurvedTransition';\nexport * from './EntryExitTransition';\n","import { ComplexAnimationBuilder } from '../animationBuilder/ComplexAnimationBuilder';\nimport {\n ILayoutAnimationBuilder,\n LayoutAnimationFunction,\n} from '../animationBuilder/commonTypes';\n\nexport class LinearTransition\n extends ComplexAnimationBuilder\n implements ILayoutAnimationBuilder\n{\n static createInstance(): LinearTransition {\n return new LinearTransition();\n }\n\n build = (): LayoutAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const [animation, config] = this.getAnimationAndConfig();\n const callback = this.callbackV;\n const delay = this.getDelay();\n\n return (values) => {\n 'worklet';\n return {\n initialValues: {\n originX: values.currentOriginX,\n originY: values.currentOriginY,\n width: values.currentWidth,\n height: values.currentHeight,\n },\n animations: {\n originX: delayFunction(\n delay,\n animation(values.targetOriginX, config)\n ),\n originY: delayFunction(\n delay,\n animation(values.targetOriginY, config)\n ),\n width: delayFunction(delay, animation(values.targetWidth, config)),\n height: delayFunction(delay, animation(values.targetHeight, config)),\n },\n callback: callback,\n };\n };\n };\n}\n\nexport const Layout = LinearTransition;\n","import { withSequence, withTiming } from '../../animation';\nimport {\n ILayoutAnimationBuilder,\n LayoutAnimationFunction,\n} from '../animationBuilder/commonTypes';\nimport { BaseAnimationBuilder } from '../animationBuilder';\n\nexport class FadingTransition\n extends BaseAnimationBuilder\n implements ILayoutAnimationBuilder\n{\n static createInstance(): FadingTransition {\n return new FadingTransition();\n }\n\n build = (): LayoutAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const callback = this.callbackV;\n const delay = this.getDelay();\n const duration = this.durationV ?? 500;\n\n return (values) => {\n 'worklet';\n return {\n initialValues: {\n opacity: 1,\n originX: values.currentOriginX,\n originY: values.currentOriginY,\n width: values.currentWidth,\n height: values.currentHeight,\n },\n animations: {\n opacity: delayFunction(\n delay,\n withSequence(\n withTiming(0, { duration: duration }),\n withTiming(1, { duration: duration })\n )\n ),\n originX: delayFunction(\n delay + duration,\n withTiming(values.targetOriginX, { duration: 50 })\n ),\n originY: delayFunction(\n delay + duration,\n withTiming(values.targetOriginY, { duration: 50 })\n ),\n width: delayFunction(\n delay + duration,\n withTiming(values.targetWidth, { duration: 50 })\n ),\n height: delayFunction(\n delay + duration,\n withTiming(values.targetHeight, { duration: 50 })\n ),\n },\n callback: callback,\n };\n };\n };\n}\n","import { withSequence, withTiming } from '../../animation';\nimport {\n ILayoutAnimationBuilder,\n LayoutAnimationFunction,\n} from '../animationBuilder/commonTypes';\nimport { BaseAnimationBuilder } from '../animationBuilder';\n\nexport class SequencedTransition\n extends BaseAnimationBuilder\n implements ILayoutAnimationBuilder\n{\n reversed = false;\n\n static createInstance(): SequencedTransition {\n return new SequencedTransition();\n }\n\n static reverse(): SequencedTransition {\n const instance = SequencedTransition.createInstance();\n return instance.reverse();\n }\n\n reverse(): SequencedTransition {\n this.reversed = !this.reversed;\n return this;\n }\n\n build = (): LayoutAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const callback = this.callbackV;\n const delay = this.getDelay();\n const sequenceDuration = (this.durationV ?? 500) / 2;\n const config = { duration: sequenceDuration };\n const reverse = this.reversed;\n\n return (values) => {\n 'worklet';\n return {\n initialValues: {\n originX: values.currentOriginX,\n originY: values.currentOriginY,\n width: values.currentWidth,\n height: values.currentHeight,\n },\n animations: {\n originX: delayFunction(\n delay,\n withSequence(\n withTiming(\n reverse ? values.currentOriginX : values.targetOriginX,\n config\n ),\n withTiming(values.targetOriginX, config)\n )\n ),\n originY: delayFunction(\n delay,\n withSequence(\n withTiming(\n reverse ? values.targetOriginY : values.currentOriginY,\n config\n ),\n withTiming(values.targetOriginY, config)\n )\n ),\n width: delayFunction(\n delay,\n withSequence(\n withTiming(\n reverse ? values.currentWidth : values.targetWidth,\n config\n ),\n withTiming(values.targetWidth, config)\n )\n ),\n height: delayFunction(\n delay,\n withSequence(\n withTiming(\n reverse ? values.targetHeight : values.currentHeight,\n config\n ),\n withTiming(values.targetHeight, config)\n )\n ),\n },\n callback: callback,\n };\n };\n };\n}\n","import {\n ILayoutAnimationBuilder,\n LayoutAnimationFunction,\n} from '../animationBuilder/commonTypes';\nimport { withSequence, withTiming } from '../../animation';\nimport { Easing } from '../../Easing';\nimport { BaseAnimationBuilder } from '../animationBuilder';\nexport class JumpingTransition\n extends BaseAnimationBuilder\n implements ILayoutAnimationBuilder\n{\n static createInstance(): JumpingTransition {\n return new JumpingTransition();\n }\n\n build = (): LayoutAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const callback = this.callbackV;\n const delay = this.getDelay();\n const duration = (this.durationV ?? 300) / 2;\n const config = { duration: duration * 2 };\n\n return (values) => {\n 'worklet';\n const d = Math.max(\n Math.abs(values.targetOriginX - values.currentOriginX),\n Math.abs(values.targetOriginY - values.currentOriginY)\n );\n return {\n initialValues: {\n originX: values.currentOriginX,\n originY: values.currentOriginY,\n width: values.currentWidth,\n height: values.currentHeight,\n },\n animations: {\n originX: delayFunction(\n delay,\n withTiming(values.targetOriginX, config)\n ),\n originY: delayFunction(\n delay,\n withSequence(\n withTiming(\n Math.min(values.targetOriginY, values.currentOriginY) - d,\n {\n duration,\n easing: Easing.out(Easing.exp),\n }\n ),\n withTiming(values.targetOriginY, {\n ...config,\n duration,\n easing: Easing.bounce,\n })\n )\n ),\n width: delayFunction(delay, withTiming(values.targetWidth, config)),\n height: delayFunction(delay, withTiming(values.targetHeight, config)),\n },\n callback: callback,\n };\n };\n };\n}\n","import {\n ILayoutAnimationBuilder,\n LayoutAnimationFunction,\n} from '../animationBuilder/commonTypes';\nimport { BaseAnimationBuilder } from '../animationBuilder';\nimport { EasingFn, Easing } from '../../Easing';\nimport { withTiming } from '../../animation';\n\nexport class CurvedTransition\n extends BaseAnimationBuilder\n implements ILayoutAnimationBuilder\n{\n easingXV: EasingFn = Easing.in(Easing.ease);\n easingYV: EasingFn = Easing.out(Easing.ease);\n easingWidthV: EasingFn = Easing.in(Easing.exp);\n easingHeightV: EasingFn = Easing.out(Easing.exp);\n static createInstance(): CurvedTransition {\n return new CurvedTransition();\n }\n\n static easingX(easing: EasingFn): CurvedTransition {\n const instance = this.createInstance();\n return instance.easingX(easing);\n }\n\n easingX(easing: EasingFn): CurvedTransition {\n this.easingXV = easing;\n return this;\n }\n\n static easingY(easing: EasingFn): CurvedTransition {\n const instance = this.createInstance();\n return instance.easingY(easing);\n }\n\n easingY(easing: EasingFn): CurvedTransition {\n this.easingYV = easing;\n return this;\n }\n\n static easingWidth(easing: EasingFn): CurvedTransition {\n const instance = this.createInstance();\n return instance.easingWidth(easing);\n }\n\n easingWidth(easing: EasingFn): CurvedTransition {\n this.easingWidthV = easing;\n return this;\n }\n\n static easingHeight(easing: EasingFn): CurvedTransition {\n const instance = this.createInstance();\n return instance.easingHeight(easing);\n }\n\n easingHeight(easing: EasingFn): CurvedTransition {\n this.easingHeightV = easing;\n return this;\n }\n\n build = (): LayoutAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const callback = this.callbackV;\n const delay = this.getDelay();\n const duration = this.durationV ?? 300;\n const easing = {\n easingX: this.easingXV,\n easingY: this.easingYV,\n easingWidth: this.easingWidthV,\n easingHeight: this.easingHeightV,\n };\n\n return (values) => {\n 'worklet';\n\n return {\n initialValues: {\n originX: values.currentOriginX,\n originY: values.currentOriginY,\n width: values.currentWidth,\n height: values.currentHeight,\n },\n animations: {\n originX: delayFunction(\n delay,\n withTiming(values.targetOriginX, {\n duration,\n easing: easing.easingX,\n })\n ),\n originY: delayFunction(\n delay,\n withTiming(values.targetOriginY, {\n duration,\n easing: easing.easingY,\n })\n ),\n width: delayFunction(\n delay,\n withTiming(values.targetWidth, {\n duration,\n easing: easing.easingWidth,\n })\n ),\n height: delayFunction(\n delay,\n withTiming(values.targetHeight, {\n duration,\n easing: easing.easingHeight,\n })\n ),\n },\n callback: callback,\n };\n };\n };\n}\n","import {\n ILayoutAnimationBuilder,\n LayoutAnimationsValues,\n LayoutAnimationFunction,\n} from '../animationBuilder/commonTypes';\nimport { BaseAnimationBuilder } from '../animationBuilder';\nimport { withSequence, withTiming } from '../../animation';\nimport { FadeIn, FadeOut } from '../defaultAnimations/Fade';\nimport {\n StyleProps,\n TransformProperty,\n AnimationObject,\n} from '../../commonTypes';\n\nexport class EntryExitTransition\n extends BaseAnimationBuilder\n implements ILayoutAnimationBuilder\n{\n enteringV: BaseAnimationBuilder | typeof BaseAnimationBuilder = FadeIn;\n\n exitingV: BaseAnimationBuilder | typeof BaseAnimationBuilder = FadeOut;\n\n static createInstance(): EntryExitTransition {\n return new EntryExitTransition();\n }\n\n static entering(\n animation: BaseAnimationBuilder | typeof BaseAnimationBuilder\n ): EntryExitTransition {\n const instance = this.createInstance();\n return instance.entering(animation);\n }\n\n entering(\n animation: BaseAnimationBuilder | typeof BaseAnimationBuilder\n ): EntryExitTransition {\n this.enteringV = animation;\n return this;\n }\n\n static exiting(\n animation: BaseAnimationBuilder | typeof BaseAnimationBuilder\n ): EntryExitTransition {\n const instance = this.createInstance();\n return instance.exiting(animation);\n }\n\n exiting(\n animation: BaseAnimationBuilder | typeof BaseAnimationBuilder\n ): EntryExitTransition {\n this.exitingV = animation;\n return this;\n }\n\n build = (): LayoutAnimationFunction => {\n const delayFunction = this.getDelayFunction();\n const callback = this.callbackV;\n const delay = this.getDelay();\n const enteringAnimation = this.enteringV.build();\n const exitingAnimation = this.exitingV.build();\n const exitingDuration = this.exitingV.getDuration();\n\n return (values) => {\n 'worklet';\n const enteringValues = enteringAnimation(values);\n const exitingValues = exitingAnimation(values);\n const animations: StyleProps = {\n transform: [],\n };\n\n for (const prop of Object.keys(exitingValues.animations)) {\n if (prop === 'transform') {\n exitingValues.animations[prop]?.forEach((value, index) => {\n for (const transformProp of Object.keys(value)) {\n animations.transform?.push({\n [transformProp]: delayFunction(\n delay,\n withSequence(\n value[transformProp as keyof TransformProperty],\n withTiming(\n exitingValues.initialValues.transform\n ? exitingValues.initialValues.transform[index][\n transformProp as keyof TransformProperty\n ]\n : 0,\n { duration: 0 }\n )\n )\n ),\n } as TransformProperty);\n }\n });\n } else {\n const sequence =\n enteringValues.animations[prop] !== undefined\n ? [\n exitingValues.animations[prop],\n withTiming(enteringValues.initialValues[prop], {\n duration: 0,\n }),\n enteringValues.animations[prop],\n ]\n : [\n exitingValues.animations[prop],\n withTiming(\n Object.keys(values).includes(prop)\n ? values[prop as keyof LayoutAnimationsValues]\n : exitingValues.initialValues[prop],\n { duration: 0 }\n ),\n ];\n\n animations[prop] = delayFunction(delay, withSequence(...sequence));\n }\n }\n for (const prop of Object.keys(enteringValues.animations)) {\n if (prop === 'transform') {\n enteringValues.animations[prop]?.forEach((value, index) => {\n for (const transformProp of Object.keys(value)) {\n animations.transform?.push({\n [transformProp]: delayFunction(\n delay + exitingDuration,\n withSequence(\n withTiming(\n enteringValues.initialValues.transform\n ? enteringValues.initialValues.transform[index][\n transformProp as keyof TransformProperty\n ]\n : 0,\n { duration: exitingDuration }\n ),\n value[transformProp as keyof TransformProperty]\n )\n ),\n } as TransformProperty);\n }\n });\n } else if (animations[prop] !== undefined) {\n // it was already added in the previous loop\n continue;\n } else {\n animations[prop] = delayFunction(\n delay,\n withSequence(\n withTiming(enteringValues.initialValues[prop], { duration: 0 }),\n enteringValues.animations[prop]\n )\n );\n }\n }\n\n const mergedTransform = (\n exitingValues.initialValues.transform ?? []\n ).concat(\n (enteringValues.animations.transform ?? []).map((value) => {\n const objectKeys = Object.keys(value);\n if (objectKeys?.length < 1) {\n console.error(\n `[Reanimated]: \\${value} is not a valid Transform object`\n );\n return value;\n }\n const transformProp = objectKeys[0];\n const current = (\n value[transformProp as keyof TransformProperty] as AnimationObject\n ).current;\n if (typeof current === 'string') {\n if (current.includes('deg'))\n return {\n [transformProp]: '0deg',\n } as unknown as TransformProperty;\n else\n return {\n [transformProp]: '0',\n } as unknown as TransformProperty;\n } else if (transformProp.includes('translate')) {\n return { [transformProp]: 0 } as unknown as TransformProperty;\n } else {\n return { [transformProp]: 1 } as unknown as TransformProperty;\n }\n return value;\n })\n );\n\n return {\n initialValues: {\n ...exitingValues.initialValues,\n originX: values.currentOriginX,\n originY: values.currentOriginY,\n width: values.currentWidth,\n height: values.currentHeight,\n transform: mergedTransform,\n },\n animations: {\n originX: delayFunction(\n delay + exitingDuration,\n withTiming(values.targetOriginX, { duration: exitingDuration })\n ),\n originY: delayFunction(\n delay + exitingDuration,\n withTiming(values.targetOriginY, { duration: exitingDuration })\n ),\n width: delayFunction(\n delay + exitingDuration,\n withTiming(values.targetWidth, { duration: exitingDuration })\n ),\n height: delayFunction(\n delay + exitingDuration,\n withTiming(values.targetHeight, { duration: exitingDuration })\n ),\n ...animations,\n },\n callback: callback,\n };\n };\n };\n}\n\nexport function combineTransition(\n exiting: BaseAnimationBuilder | typeof BaseAnimationBuilder,\n entering: BaseAnimationBuilder | typeof BaseAnimationBuilder\n): EntryExitTransition {\n return EntryExitTransition.entering(entering).exiting(exiting);\n}\n","import { Component } from 'react';\nimport { measure } from './NativeMethods';\nimport { RefObjectFunction } from './hook/commonTypes';\n\nexport interface ComponentCoords {\n x: number;\n y: number;\n}\n\n/**\n * Given an absolute position and a component ref, returns the relative\n * position in the component's local coordinate space.\n */\nexport function getRelativeCoords(\n parentRef: RefObjectFunction,\n absoluteX: number,\n absoluteY: number\n): ComponentCoords | null {\n 'worklet';\n const parentCoords = measure(parentRef);\n if (parentCoords === null) {\n return null;\n }\n return {\n x: absoluteX - parentCoords.x,\n y: absoluteY - parentCoords.y,\n };\n}\n","import { Reanimated } from './reanimatedWrapper';\nimport { State } from '../../State';\nimport { tagMessage } from '../../utils';\n\nexport interface GestureStateManagerType {\n begin: () => void;\n activate: () => void;\n fail: () => void;\n end: () => void;\n}\n\nconst warningMessage = tagMessage(\n 'react-native-reanimated is required in order to use synchronous state management'\n);\n\n// check if reanimated module is available, but look for useSharedValue as conditional\n// require of reanimated can sometimes return content of `utils.ts` file (?)\nconst REANIMATED_AVAILABLE = Reanimated?.useSharedValue !== undefined;\nconst setGestureState = Reanimated?.setGestureState;\n\nexport const GestureStateManager = {\n create(handlerTag: number): GestureStateManagerType {\n 'worklet';\n return {\n begin: () => {\n 'worklet';\n if (REANIMATED_AVAILABLE) {\n setGestureState(handlerTag, State.BEGAN);\n } else {\n console.warn(warningMessage);\n }\n },\n\n activate: () => {\n 'worklet';\n if (REANIMATED_AVAILABLE) {\n setGestureState(handlerTag, State.ACTIVE);\n } else {\n console.warn(warningMessage);\n }\n },\n\n fail: () => {\n 'worklet';\n if (REANIMATED_AVAILABLE) {\n setGestureState(handlerTag, State.FAILED);\n } else {\n console.warn(warningMessage);\n }\n },\n\n end: () => {\n 'worklet';\n if (REANIMATED_AVAILABLE) {\n setGestureState(handlerTag, State.END);\n } else {\n console.warn(warningMessage);\n }\n },\n };\n },\n};\n","import { DeviceEventEmitter, EmitterSubscription } from 'react-native';\nimport { State } from '../../State';\nimport { TouchEventType } from '../../TouchEventType';\nimport {\n GestureTouchEvent,\n GestureUpdateEvent,\n GestureStateChangeEvent,\n} from '../gestureHandlerCommon';\nimport { findHandler, findOldGestureHandler } from '../handlersRegistry';\nimport { BaseGesture } from './gesture';\nimport {\n GestureStateManager,\n GestureStateManagerType,\n} from './gestureStateManager';\n\nlet gestureHandlerEventSubscription: EmitterSubscription | null = null;\nlet gestureHandlerStateChangeEventSubscription: EmitterSubscription | null =\n null;\n\nconst gestureStateManagers: Map = new Map<\n number,\n GestureStateManagerType\n>();\n\nconst lastUpdateEvent: (GestureUpdateEvent | undefined)[] = [];\n\nfunction isStateChangeEvent(\n event: GestureUpdateEvent | GestureStateChangeEvent | GestureTouchEvent\n): event is GestureStateChangeEvent {\n // @ts-ignore oldState doesn't exist on GestureTouchEvent and that's the point\n return event.oldState != null;\n}\n\nfunction isTouchEvent(\n event: GestureUpdateEvent | GestureStateChangeEvent | GestureTouchEvent\n): event is GestureTouchEvent {\n return event.eventType != null;\n}\n\nexport function onGestureHandlerEvent(\n event: GestureUpdateEvent | GestureStateChangeEvent | GestureTouchEvent\n) {\n const handler = findHandler(event.handlerTag) as BaseGesture<\n Record\n >;\n\n if (handler) {\n if (isStateChangeEvent(event)) {\n if (\n event.oldState === State.UNDETERMINED &&\n event.state === State.BEGAN\n ) {\n handler.handlers.onBegin?.(event);\n } else if (\n (event.oldState === State.BEGAN ||\n event.oldState === State.UNDETERMINED) &&\n event.state === State.ACTIVE\n ) {\n handler.handlers.onStart?.(event);\n lastUpdateEvent[handler.handlers.handlerTag] = event;\n } else if (event.oldState !== event.state && event.state === State.END) {\n if (event.oldState === State.ACTIVE) {\n handler.handlers.onEnd?.(event, true);\n }\n handler.handlers.onFinalize?.(event, true);\n lastUpdateEvent[handler.handlers.handlerTag] = undefined;\n } else if (\n (event.state === State.FAILED || event.state === State.CANCELLED) &&\n event.oldState !== event.state\n ) {\n if (event.oldState === State.ACTIVE) {\n handler.handlers.onEnd?.(event, false);\n }\n handler.handlers.onFinalize?.(event, false);\n gestureStateManagers.delete(event.handlerTag);\n lastUpdateEvent[handler.handlers.handlerTag] = undefined;\n }\n } else if (isTouchEvent(event)) {\n if (!gestureStateManagers.has(event.handlerTag)) {\n gestureStateManagers.set(\n event.handlerTag,\n GestureStateManager.create(event.handlerTag)\n );\n }\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const manager = gestureStateManagers.get(event.handlerTag)!;\n\n switch (event.eventType) {\n case TouchEventType.TOUCHES_DOWN:\n handler.handlers?.onTouchesDown?.(event, manager);\n break;\n case TouchEventType.TOUCHES_MOVE:\n handler.handlers?.onTouchesMove?.(event, manager);\n break;\n case TouchEventType.TOUCHES_UP:\n handler.handlers?.onTouchesUp?.(event, manager);\n break;\n case TouchEventType.TOUCHES_CANCELLED:\n handler.handlers?.onTouchesCancelled?.(event, manager);\n break;\n }\n } else {\n handler.handlers.onUpdate?.(event);\n\n if (handler.handlers.onChange && handler.handlers.changeEventCalculator) {\n handler.handlers.onChange?.(\n handler.handlers.changeEventCalculator?.(\n event,\n lastUpdateEvent[handler.handlers.handlerTag]\n )\n );\n\n lastUpdateEvent[handler.handlers.handlerTag] = event;\n }\n }\n } else {\n const oldHandler = findOldGestureHandler(event.handlerTag);\n if (oldHandler) {\n const nativeEvent = { nativeEvent: event };\n if (isStateChangeEvent(event)) {\n oldHandler.onGestureStateChange(nativeEvent);\n } else {\n oldHandler.onGestureEvent(nativeEvent);\n }\n return;\n }\n }\n}\n\nexport function startListening() {\n stopListening();\n\n gestureHandlerEventSubscription = DeviceEventEmitter.addListener(\n 'onGestureHandlerEvent',\n onGestureHandlerEvent\n );\n\n gestureHandlerStateChangeEventSubscription = DeviceEventEmitter.addListener(\n 'onGestureHandlerStateChange',\n onGestureHandlerEvent\n );\n}\n\nexport function stopListening() {\n if (gestureHandlerEventSubscription) {\n gestureHandlerEventSubscription.remove();\n gestureHandlerEventSubscription = null;\n }\n\n if (gestureHandlerStateChangeEventSubscription) {\n gestureHandlerStateChangeEventSubscription.remove();\n gestureHandlerStateChangeEventSubscription = null;\n }\n}\n","import { Platform } from 'react-native';\n\nlet EXPERIMENTAL_WEB_IMPLEMENTATION = false;\nlet getWasCalled = false;\n\nexport function enableExperimentalWebImplementation(shouldEnable = true): void {\n if (\n Platform.OS !== 'web' ||\n EXPERIMENTAL_WEB_IMPLEMENTATION === shouldEnable\n ) {\n return;\n }\n\n if (getWasCalled) {\n console.error(\n 'Some parts of this application have already started using old gesture handler implementation. No changes will be applied. You can try enabling new implementation earlier.'\n );\n return;\n }\n\n EXPERIMENTAL_WEB_IMPLEMENTATION = shouldEnable;\n}\n\nexport function isExperimentalWebImplementationEnabled(): boolean {\n getWasCalled = true;\n return EXPERIMENTAL_WEB_IMPLEMENTATION;\n}\n","// Used by GestureDetector (unsupported on web at the moment) to check whether the\n// attached view may get flattened on Fabric. This implementation causes errors\n// on web due to the static resolution of `require` statements by webpack breaking\n// the conditional importing. Solved by making .web file.\nlet findHostInstance_DEPRECATED: (ref: any) => void;\n\nexport function getShadowNodeFromRef(ref: any) {\n // load findHostInstance_DEPRECATED lazily because it may not be available before render\n if (findHostInstance_DEPRECATED === undefined) {\n try {\n findHostInstance_DEPRECATED =\n // eslint-disable-next-line @typescript-eslint/no-var-requires\n require('react-native/Libraries/Renderer/shims/ReactFabric').findHostInstance_DEPRECATED;\n } catch (e) {\n findHostInstance_DEPRECATED = (_ref: any) => null;\n }\n }\n\n // @ts-ignore Fabric\n return findHostInstance_DEPRECATED(ref)._internalInstanceHandle.stateNode\n .node;\n}\n","import createHandler from './createHandler';\nimport {\n BaseGestureHandlerProps,\n baseGestureHandlerProps,\n} from './gestureHandlerCommon';\n\nexport type PinchGestureHandlerEventPayload = {\n /**\n * The scale factor relative to the points of the two touches in screen\n * coordinates.\n */\n scale: number;\n\n /**\n * Position expressed in points along X axis of center anchor point of\n * gesture.\n */\n focalX: number;\n\n /**\n * Position expressed in points along Y axis of center anchor point of\n * gesture.\n */\n focalY: number;\n\n /**\n *\n * Velocity of the pan gesture the current moment. The value is expressed in\n * point units per second.\n */\n velocity: number;\n};\n\nexport interface PinchGestureHandlerProps\n extends BaseGestureHandlerProps {}\n\nexport const pinchHandlerName = 'PinchGestureHandler';\n\nexport type PinchGestureHandler = typeof PinchGestureHandler;\n// eslint-disable-next-line @typescript-eslint/no-redeclare -- backward compatibility; see description on the top of gestureHandlerCommon.ts file\nexport const PinchGestureHandler = createHandler<\n PinchGestureHandlerProps,\n PinchGestureHandlerEventPayload\n>({\n name: pinchHandlerName,\n allowedProps: baseGestureHandlerProps,\n config: {},\n});\n","import createHandler from './createHandler';\nimport {\n BaseGestureHandlerProps,\n baseGestureHandlerProps,\n} from './gestureHandlerCommon';\n\nexport type RotationGestureHandlerEventPayload = {\n /**\n * Amount rotated, expressed in radians, from the gesture's focal point\n * (anchor).\n */\n rotation: number;\n\n /**\n * X coordinate, expressed in points, of the gesture's central focal point\n * (anchor).\n */\n anchorX: number;\n\n /**\n * Y coordinate, expressed in points, of the gesture's central focal point\n * (anchor).\n */\n anchorY: number;\n\n /**\n *\n * Instantaneous velocity, expressed in point units per second, of the\n * gesture.\n */\n velocity: number;\n};\n\nexport interface RotationGestureHandlerProps\n extends BaseGestureHandlerProps {}\n\nexport const rotationHandlerName = 'RotationGestureHandler';\n\nexport type RotationGestureHandler = typeof RotationGestureHandler;\n// eslint-disable-next-line @typescript-eslint/no-redeclare -- backward compatibility; see description on the top of gestureHandlerCommon.ts file\nexport const RotationGestureHandler = createHandler<\n RotationGestureHandlerProps,\n RotationGestureHandlerEventPayload\n>({\n name: rotationHandlerName,\n allowedProps: baseGestureHandlerProps,\n config: {},\n});\n","export { default as TouchableNativeFeedback } from './TouchableNativeFeedback';\nexport { default as TouchableWithoutFeedback } from './TouchableWithoutFeedback';\nexport { default as TouchableOpacity } from './TouchableOpacity';\nexport { default as TouchableHighlight } from './TouchableHighlight';\n","import { TouchableNativeFeedback } from 'react-native';\n\nexport default TouchableNativeFeedback;\n","import * as React from 'react';\nimport { PropsWithChildren } from 'react';\nimport GenericTouchable, { GenericTouchableProps } from './GenericTouchable';\n\nconst TouchableWithoutFeedback = React.forwardRef<\n GenericTouchable,\n PropsWithChildren\n>((props, ref) => );\n\nTouchableWithoutFeedback.defaultProps = GenericTouchable.defaultProps;\n\nexport default TouchableWithoutFeedback;\n","import * as React from 'react';\nimport { Component } from 'react';\nimport {\n Animated,\n Platform,\n StyleProp,\n ViewStyle,\n TouchableWithoutFeedbackProps,\n} from 'react-native';\n\nimport { State } from '../../State';\nimport { BaseButton } from '../GestureButtons';\n\nimport {\n GestureEvent,\n HandlerStateChangeEvent,\n} from '../../handlers/gestureHandlerCommon';\nimport { NativeViewGestureHandlerPayload } from '../../handlers/NativeViewGestureHandler';\nimport { TouchableNativeFeedbackExtraProps } from './TouchableNativeFeedback.android';\n\n/**\n * Each touchable is a states' machine which preforms transitions.\n * On very beginning (and on the very end or recognition) touchable is\n * UNDETERMINED. Then it moves to BEGAN. If touchable recognizes that finger\n * travel outside it transits to special MOVED_OUTSIDE state. Gesture recognition\n * finishes in UNDETERMINED state.\n */\nexport const TOUCHABLE_STATE = {\n UNDETERMINED: 0,\n BEGAN: 1,\n MOVED_OUTSIDE: 2,\n} as const;\n\ntype TouchableState = typeof TOUCHABLE_STATE[keyof typeof TOUCHABLE_STATE];\n\nexport interface GenericTouchableProps extends TouchableWithoutFeedbackProps {\n // Decided to drop not used fields from RN's implementation.\n // e.g. onBlur and onFocus as well as deprecated props. - TODO: this comment may be unuseful in this moment\n\n // TODO: in RN these events get native event parameter, which prolly could be used in our implementation too\n onPress?: () => void;\n onPressIn?: () => void;\n onPressOut?: () => void;\n onLongPress?: () => void;\n\n nativeID?: string;\n shouldActivateOnStart?: boolean;\n disallowInterruption?: boolean;\n\n containerStyle?: StyleProp;\n}\n\ninterface InternalProps {\n extraButtonProps: TouchableNativeFeedbackExtraProps;\n onStateChange?: (oldState: TouchableState, newState: TouchableState) => void;\n}\n\n// TODO: maybe can be better\n// TODO: all clearTimeout have ! added, maybe they shouldn't ?\ntype Timeout = ReturnType | null | undefined;\n\n/**\n * GenericTouchable is not intented to be used as it is.\n * Should be treated as a source for the rest of touchables\n */\n\nexport default class GenericTouchable extends Component<\n GenericTouchableProps & InternalProps\n> {\n static defaultProps = {\n delayLongPress: 600,\n extraButtonProps: {\n rippleColor: 'transparent',\n exclusive: true,\n },\n };\n\n // timeout handlers\n pressInTimeout: Timeout;\n pressOutTimeout: Timeout;\n longPressTimeout: Timeout;\n\n // This flag is required since recognition of longPress implies not-invoking onPress\n longPressDetected = false;\n\n pointerInside = true;\n\n // State of touchable\n STATE: TouchableState = TOUCHABLE_STATE.UNDETERMINED;\n\n // handlePressIn in called on first touch on traveling inside component.\n // Handles state transition with delay.\n handlePressIn() {\n if (this.props.delayPressIn) {\n this.pressInTimeout = setTimeout(() => {\n this.moveToState(TOUCHABLE_STATE.BEGAN);\n this.pressInTimeout = null;\n }, this.props.delayPressIn);\n } else {\n this.moveToState(TOUCHABLE_STATE.BEGAN);\n }\n if (this.props.onLongPress) {\n const time =\n (this.props.delayPressIn || 0) + (this.props.delayLongPress || 0);\n this.longPressTimeout = setTimeout(this.onLongPressDetected, time);\n }\n }\n // handleMoveOutside in called on traveling outside component.\n // Handles state transition with delay.\n handleMoveOutside() {\n if (this.props.delayPressOut) {\n this.pressOutTimeout =\n this.pressOutTimeout ||\n setTimeout(() => {\n this.moveToState(TOUCHABLE_STATE.MOVED_OUTSIDE);\n this.pressOutTimeout = null;\n }, this.props.delayPressOut);\n } else {\n this.moveToState(TOUCHABLE_STATE.MOVED_OUTSIDE);\n }\n }\n\n // handleGoToUndetermined transits to UNDETERMINED state with proper delay\n handleGoToUndetermined() {\n clearTimeout(this.pressOutTimeout!); // TODO: maybe it can be undefined\n if (this.props.delayPressOut) {\n this.pressOutTimeout = setTimeout(() => {\n if (this.STATE === TOUCHABLE_STATE.UNDETERMINED) {\n this.moveToState(TOUCHABLE_STATE.BEGAN);\n }\n this.moveToState(TOUCHABLE_STATE.UNDETERMINED);\n this.pressOutTimeout = null;\n }, this.props.delayPressOut);\n } else {\n if (this.STATE === TOUCHABLE_STATE.UNDETERMINED) {\n this.moveToState(TOUCHABLE_STATE.BEGAN);\n }\n this.moveToState(TOUCHABLE_STATE.UNDETERMINED);\n }\n }\n\n componentDidMount() {\n this.reset();\n }\n // reset timeout to prevent memory leaks.\n reset() {\n this.longPressDetected = false;\n this.pointerInside = true;\n clearTimeout(this.pressInTimeout!);\n clearTimeout(this.pressOutTimeout!);\n clearTimeout(this.longPressTimeout!);\n this.pressOutTimeout = null;\n this.longPressTimeout = null;\n this.pressInTimeout = null;\n }\n\n // All states' transitions are defined here.\n moveToState(newState: TouchableState) {\n if (newState === this.STATE) {\n // Ignore dummy transitions\n return;\n }\n if (newState === TOUCHABLE_STATE.BEGAN) {\n // First touch and moving inside\n this.props.onPressIn?.();\n } else if (newState === TOUCHABLE_STATE.MOVED_OUTSIDE) {\n // Moving outside\n this.props.onPressOut?.();\n } else if (newState === TOUCHABLE_STATE.UNDETERMINED) {\n // Need to reset each time on transition to UNDETERMINED\n this.reset();\n if (this.STATE === TOUCHABLE_STATE.BEGAN) {\n // ... and if it happens inside button.\n this.props.onPressOut?.();\n }\n }\n // Finally call lister (used by subclasses)\n this.props.onStateChange?.(this.STATE, newState);\n // ... and make transition.\n this.STATE = newState;\n }\n\n onGestureEvent = ({\n nativeEvent: { pointerInside },\n }: GestureEvent) => {\n if (this.pointerInside !== pointerInside) {\n if (pointerInside) {\n this.onMoveIn();\n } else {\n this.onMoveOut();\n }\n }\n this.pointerInside = pointerInside;\n };\n\n onHandlerStateChange = ({\n nativeEvent,\n }: HandlerStateChangeEvent) => {\n const { state } = nativeEvent;\n if (state === State.CANCELLED || state === State.FAILED) {\n // Need to handle case with external cancellation (e.g. by ScrollView)\n this.moveToState(TOUCHABLE_STATE.UNDETERMINED);\n } else if (\n // This platform check is an implication of slightly different behavior of handlers on different platform.\n // And Android \"Active\" state is achieving on first move of a finger, not on press in.\n // On iOS event on \"Began\" is not delivered.\n state === (Platform.OS !== 'android' ? State.ACTIVE : State.BEGAN) &&\n this.STATE === TOUCHABLE_STATE.UNDETERMINED\n ) {\n // Moving inside requires\n this.handlePressIn();\n } else if (state === State.END) {\n const shouldCallOnPress =\n !this.longPressDetected &&\n this.STATE !== TOUCHABLE_STATE.MOVED_OUTSIDE &&\n this.pressOutTimeout === null;\n this.handleGoToUndetermined();\n if (shouldCallOnPress) {\n // Calls only inside component whether no long press was called previously\n this.props.onPress?.();\n }\n }\n };\n\n onLongPressDetected = () => {\n this.longPressDetected = true;\n // checked for in the caller of `onLongPressDetected`, but better to check twice\n this.props.onLongPress?.();\n };\n\n componentWillUnmount() {\n // to prevent memory leaks\n this.reset();\n }\n\n onMoveIn() {\n if (this.STATE === TOUCHABLE_STATE.MOVED_OUTSIDE) {\n // This call is not throttled with delays (like in RN's implementation).\n this.moveToState(TOUCHABLE_STATE.BEGAN);\n }\n }\n\n onMoveOut() {\n // long press should no longer be detected\n clearTimeout(this.longPressTimeout!);\n this.longPressTimeout = null;\n if (this.STATE === TOUCHABLE_STATE.BEGAN) {\n this.handleMoveOutside();\n }\n }\n\n render() {\n const coreProps = {\n accessible: this.props.accessible !== false,\n accessibilityLabel: this.props.accessibilityLabel,\n accessibilityHint: this.props.accessibilityHint,\n accessibilityRole: this.props.accessibilityRole,\n // TODO: check if changed to no 's' correctly, also removed 2 props that are no longer available: `accessibilityComponentType` and `accessibilityTraits`,\n // would be good to check if it is ok for sure, see: https://github.com/facebook/react-native/issues/24016\n accessibilityState: this.props.accessibilityState,\n accessibilityActions: this.props.accessibilityActions,\n onAccessibilityAction: this.props.onAccessibilityAction,\n nativeID: this.props.nativeID,\n onLayout: this.props.onLayout,\n hitSlop: this.props.hitSlop,\n };\n\n return (\n \n \n {this.props.children}\n \n \n );\n }\n}\n","import {\n Animated,\n Easing,\n StyleSheet,\n View,\n TouchableOpacityProps,\n} from 'react-native';\nimport GenericTouchable, {\n TOUCHABLE_STATE,\n GenericTouchableProps,\n} from './GenericTouchable';\nimport * as React from 'react';\nimport { Component } from 'react';\n\ninterface GHTouchableOpacityProps {\n useNativeAnimations?: boolean;\n}\n\n/**\n * TouchableOpacity bases on timing animation which has been used in RN's core\n */\nexport default class TouchableOpacity extends Component<\n TouchableOpacityProps & GenericTouchableProps & GHTouchableOpacityProps\n> {\n static defaultProps = {\n ...GenericTouchable.defaultProps,\n activeOpacity: 0.2,\n };\n\n // opacity is 1 one by default but could be overwritten\n getChildStyleOpacityWithDefault = () => {\n const childStyle = StyleSheet.flatten(this.props.style) || {};\n return childStyle.opacity == null ? 1 : childStyle.opacity;\n };\n\n opacity = new Animated.Value(this.getChildStyleOpacityWithDefault());\n\n setOpacityTo = (value: number, duration: number) => {\n Animated.timing(this.opacity, {\n toValue: value,\n duration: duration,\n easing: Easing.inOut(Easing.quad),\n useNativeDriver: this.props.useNativeAnimations ?? true,\n }).start();\n };\n\n onStateChange = (_from: number, to: number) => {\n if (to === TOUCHABLE_STATE.BEGAN) {\n this.setOpacityTo(this.props.activeOpacity!, 0);\n } else if (\n to === TOUCHABLE_STATE.UNDETERMINED ||\n to === TOUCHABLE_STATE.MOVED_OUTSIDE\n ) {\n this.setOpacityTo(this.getChildStyleOpacityWithDefault(), 150);\n }\n };\n\n render() {\n const { style = {}, ...rest } = this.props;\n return (\n \n {this.props.children ? this.props.children : }\n \n );\n }\n}\n","import * as React from 'react';\nimport { Component } from 'react';\nimport GenericTouchable, {\n GenericTouchableProps,\n TOUCHABLE_STATE,\n} from './GenericTouchable';\nimport {\n StyleSheet,\n View,\n TouchableHighlightProps,\n ColorValue,\n ViewProps,\n} from 'react-native';\n\ninterface State {\n extraChildStyle: null | {\n opacity?: number;\n };\n extraUnderlayStyle: null | {\n backgroundColor?: ColorValue;\n };\n}\n\n/**\n * TouchableHighlight follows RN's implementation\n */\nexport default class TouchableHighlight extends Component<\n TouchableHighlightProps & GenericTouchableProps,\n State\n> {\n static defaultProps = {\n ...GenericTouchable.defaultProps,\n activeOpacity: 0.85,\n delayPressOut: 100,\n underlayColor: 'black',\n };\n\n constructor(props: TouchableHighlightProps & GenericTouchableProps) {\n super(props);\n this.state = {\n extraChildStyle: null,\n extraUnderlayStyle: null,\n };\n }\n\n // Copied from RN\n showUnderlay = () => {\n if (!this.hasPressHandler()) {\n return;\n }\n this.setState({\n extraChildStyle: {\n opacity: this.props.activeOpacity,\n },\n extraUnderlayStyle: {\n backgroundColor: this.props.underlayColor,\n },\n });\n this.props.onShowUnderlay?.();\n };\n\n hasPressHandler = () =>\n this.props.onPress ||\n this.props.onPressIn ||\n this.props.onPressOut ||\n this.props.onLongPress;\n\n hideUnderlay = () => {\n this.setState({\n extraChildStyle: null,\n extraUnderlayStyle: null,\n });\n this.props.onHideUnderlay?.();\n };\n\n renderChildren() {\n if (!this.props.children) {\n return ;\n }\n\n const child = React.Children.only(\n this.props.children\n ) as React.ReactElement; // TODO: not sure if OK but fixes error\n return React.cloneElement(child, {\n style: StyleSheet.compose(child.props.style, this.state.extraChildStyle),\n });\n }\n\n onStateChange = (_from: number, to: number) => {\n if (to === TOUCHABLE_STATE.BEGAN) {\n this.showUnderlay();\n } else if (\n to === TOUCHABLE_STATE.UNDETERMINED ||\n to === TOUCHABLE_STATE.MOVED_OUTSIDE\n ) {\n this.hideUnderlay();\n }\n };\n\n render() {\n const { style = {}, ...rest } = this.props;\n const { extraUnderlayStyle } = this.state;\n return (\n \n {this.renderChildren()}\n \n );\n }\n}\n","import * as React from 'react';\nimport { StyleSheet, StyleProp, ViewStyle } from 'react-native';\nimport hoistNonReactStatics from 'hoist-non-react-statics';\nimport GestureHandlerRootView from './GestureHandlerRootView';\n\nexport default function gestureHandlerRootHOC<\n P extends JSX.IntrinsicAttributes\n>(\n Component: React.ComponentType

,\n containerStyles?: StyleProp\n): React.ComponentType

{\n function Wrapper(props: P) {\n return (\n \n \n \n );\n }\n\n Wrapper.displayName = `gestureHandlerRootHOC(${\n Component.displayName || Component.name\n })`;\n\n // @ts-ignore - hoistNonReactStatics uses old version of @types/react\n hoistNonReactStatics(Wrapper, Component);\n\n return Wrapper;\n}\n\nconst styles = StyleSheet.create({\n container: { flex: 1 },\n});\n","'use strict';\n\nvar reactIs = require('react-is');\n\n/**\n * Copyright 2015, Yahoo! Inc.\n * Copyrights licensed under the New BSD License. See the accompanying LICENSE file for terms.\n */\nvar REACT_STATICS = {\n childContextTypes: true,\n contextType: true,\n contextTypes: true,\n defaultProps: true,\n displayName: true,\n getDefaultProps: true,\n getDerivedStateFromError: true,\n getDerivedStateFromProps: true,\n mixins: true,\n propTypes: true,\n type: true\n};\nvar KNOWN_STATICS = {\n name: true,\n length: true,\n prototype: true,\n caller: true,\n callee: true,\n arguments: true,\n arity: true\n};\nvar FORWARD_REF_STATICS = {\n '$$typeof': true,\n render: true,\n defaultProps: true,\n displayName: true,\n propTypes: true\n};\nvar MEMO_STATICS = {\n '$$typeof': true,\n compare: true,\n defaultProps: true,\n displayName: true,\n propTypes: true,\n type: true\n};\nvar TYPE_STATICS = {};\nTYPE_STATICS[reactIs.ForwardRef] = FORWARD_REF_STATICS;\nTYPE_STATICS[reactIs.Memo] = MEMO_STATICS;\n\nfunction getStatics(component) {\n // React v16.11 and below\n if (reactIs.isMemo(component)) {\n return MEMO_STATICS;\n } // React v16.12 and above\n\n\n return TYPE_STATICS[component['$$typeof']] || REACT_STATICS;\n}\n\nvar defineProperty = Object.defineProperty;\nvar getOwnPropertyNames = Object.getOwnPropertyNames;\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\nvar getPrototypeOf = Object.getPrototypeOf;\nvar objectPrototype = Object.prototype;\nfunction hoistNonReactStatics(targetComponent, sourceComponent, blacklist) {\n if (typeof sourceComponent !== 'string') {\n // don't hoist over string (html) components\n if (objectPrototype) {\n var inheritedComponent = getPrototypeOf(sourceComponent);\n\n if (inheritedComponent && inheritedComponent !== objectPrototype) {\n hoistNonReactStatics(targetComponent, inheritedComponent, blacklist);\n }\n }\n\n var keys = getOwnPropertyNames(sourceComponent);\n\n if (getOwnPropertySymbols) {\n keys = keys.concat(getOwnPropertySymbols(sourceComponent));\n }\n\n var targetStatics = getStatics(targetComponent);\n var sourceStatics = getStatics(sourceComponent);\n\n for (var i = 0; i < keys.length; ++i) {\n var key = keys[i];\n\n if (!KNOWN_STATICS[key] && !(blacklist && blacklist[key]) && !(sourceStatics && sourceStatics[key]) && !(targetStatics && targetStatics[key])) {\n var descriptor = getOwnPropertyDescriptor(sourceComponent, key);\n\n try {\n // Avoid failures from read-only properties\n defineProperty(targetComponent, key, descriptor);\n } catch (e) {}\n }\n }\n }\n\n return targetComponent;\n}\n\nmodule.exports = hoistNonReactStatics;\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react-is.production.min.js');\n} else {\n module.exports = require('./cjs/react-is.development.js');\n}\n","/** @license React v16.13.1\n * react-is.production.min.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'use strict';var b=\"function\"===typeof Symbol&&Symbol.for,c=b?Symbol.for(\"react.element\"):60103,d=b?Symbol.for(\"react.portal\"):60106,e=b?Symbol.for(\"react.fragment\"):60107,f=b?Symbol.for(\"react.strict_mode\"):60108,g=b?Symbol.for(\"react.profiler\"):60114,h=b?Symbol.for(\"react.provider\"):60109,k=b?Symbol.for(\"react.context\"):60110,l=b?Symbol.for(\"react.async_mode\"):60111,m=b?Symbol.for(\"react.concurrent_mode\"):60111,n=b?Symbol.for(\"react.forward_ref\"):60112,p=b?Symbol.for(\"react.suspense\"):60113,q=b?\nSymbol.for(\"react.suspense_list\"):60120,r=b?Symbol.for(\"react.memo\"):60115,t=b?Symbol.for(\"react.lazy\"):60116,v=b?Symbol.for(\"react.block\"):60121,w=b?Symbol.for(\"react.fundamental\"):60117,x=b?Symbol.for(\"react.responder\"):60118,y=b?Symbol.for(\"react.scope\"):60119;\nfunction z(a){if(\"object\"===typeof a&&null!==a){var u=a.$$typeof;switch(u){case c:switch(a=a.type,a){case l:case m:case e:case g:case f:case p:return a;default:switch(a=a&&a.$$typeof,a){case k:case n:case t:case r:case h:return a;default:return u}}case d:return u}}}function A(a){return z(a)===m}exports.AsyncMode=l;exports.ConcurrentMode=m;exports.ContextConsumer=k;exports.ContextProvider=h;exports.Element=c;exports.ForwardRef=n;exports.Fragment=e;exports.Lazy=t;exports.Memo=r;exports.Portal=d;\nexports.Profiler=g;exports.StrictMode=f;exports.Suspense=p;exports.isAsyncMode=function(a){return A(a)||z(a)===l};exports.isConcurrentMode=A;exports.isContextConsumer=function(a){return z(a)===k};exports.isContextProvider=function(a){return z(a)===h};exports.isElement=function(a){return\"object\"===typeof a&&null!==a&&a.$$typeof===c};exports.isForwardRef=function(a){return z(a)===n};exports.isFragment=function(a){return z(a)===e};exports.isLazy=function(a){return z(a)===t};\nexports.isMemo=function(a){return z(a)===r};exports.isPortal=function(a){return z(a)===d};exports.isProfiler=function(a){return z(a)===g};exports.isStrictMode=function(a){return z(a)===f};exports.isSuspense=function(a){return z(a)===p};\nexports.isValidElementType=function(a){return\"string\"===typeof a||\"function\"===typeof a||a===e||a===m||a===g||a===f||a===p||a===q||\"object\"===typeof a&&null!==a&&(a.$$typeof===t||a.$$typeof===r||a.$$typeof===h||a.$$typeof===k||a.$$typeof===n||a.$$typeof===w||a.$$typeof===x||a.$$typeof===y||a.$$typeof===v)};exports.typeOf=z;\n","import * as React from 'react';\nimport { PropsWithChildren } from 'react';\nimport { View, ViewProps } from 'react-native';\nimport { maybeInitializeFabric } from './init';\n\nexport interface GestureHandlerRootViewProps\n extends PropsWithChildren {}\n\nexport default function GestureHandlerRootView(\n props: GestureHandlerRootViewProps\n) {\n // try initialize fabric on the first render, at this point we can\n // reliably check if fabric is enabled (the function contains a flag\n // to make sure it's called only once)\n maybeInitializeFabric();\n\n return ;\n}\n","import { startListening } from './handlers/gestures/eventReceiver';\nimport RNGestureHandlerModule from './RNGestureHandlerModule';\nimport { isFabric } from './utils';\n\nlet fabricInitialized = false;\n\nexport function initialize() {\n startListening();\n}\n\n// since isFabric() may give wrong results before the first render, we call this\n// method during render of GestureHandlerRootView\nexport function maybeInitializeFabric() {\n if (isFabric() && !fabricInitialized) {\n RNGestureHandlerModule.install();\n fabricInitialized = true;\n }\n}\n","// Similarily to the DrawerLayout component this deserves to be put in a\n// separate repo. Although, keeping it here for the time being will allow us to\n// move faster and fix possible issues quicker\n\nimport * as React from 'react';\nimport { Component } from 'react';\nimport {\n Animated,\n StyleSheet,\n View,\n I18nManager,\n LayoutChangeEvent,\n StyleProp,\n ViewStyle,\n} from 'react-native';\n\nimport {\n GestureEvent,\n HandlerStateChangeEvent,\n} from '../handlers/gestureHandlerCommon';\nimport {\n PanGestureHandler,\n PanGestureHandlerEventPayload,\n PanGestureHandlerProps,\n} from '../handlers/PanGestureHandler';\nimport {\n TapGestureHandler,\n TapGestureHandlerEventPayload,\n} from '../handlers/TapGestureHandler';\nimport { State } from '../State';\n\nconst DRAG_TOSS = 0.05;\n\ntype SwipeableExcludes = Exclude<\n keyof PanGestureHandlerProps,\n 'onGestureEvent' | 'onHandlerStateChange'\n>;\n\n// Animated.AnimatedInterpolation has been converted to a generic type\n// in @types/react-native 0.70. This way we can maintain compatibility\n// with all versions of @types/react-native\ntype AnimatedInterpolation = ReturnType;\n\nexport interface SwipeableProps\n extends Pick {\n /**\n * Enables two-finger gestures on supported devices, for example iPads with\n * trackpads. If not enabled the gesture will require click + drag, with\n * `enableTrackpadTwoFingerGesture` swiping with two fingers will also trigger\n * the gesture.\n */\n enableTrackpadTwoFingerGesture?: boolean;\n\n /**\n * Specifies how much the visual interaction will be delayed compared to the\n * gesture distance. e.g. value of 1 will indicate that the swipeable panel\n * should exactly follow the gesture, 2 means it is going to be two times\n * \"slower\".\n */\n friction?: number;\n\n /**\n * Distance from the left edge at which released panel will animate to the\n * open state (or the open panel will animate into the closed state). By\n * default it's a half of the panel's width.\n */\n leftThreshold?: number;\n\n /**\n * Distance from the right edge at which released panel will animate to the\n * open state (or the open panel will animate into the closed state). By\n * default it's a half of the panel's width.\n */\n rightThreshold?: number;\n\n /**\n * Value indicating if the swipeable panel can be pulled further than the left\n * actions panel's width. It is set to true by default as long as the left\n * panel render method is present.\n */\n overshootLeft?: boolean;\n\n /**\n * Value indicating if the swipeable panel can be pulled further than the\n * right actions panel's width. It is set to true by default as long as the\n * right panel render method is present.\n */\n overshootRight?: boolean;\n\n /**\n * Specifies how much the visual interaction will be delayed compared to the\n * gesture distance at overshoot. Default value is 1, it mean no friction, for\n * a native feel, try 8 or above.\n */\n overshootFriction?: number;\n\n /**\n * @deprecated Use `direction` argument of onSwipeableOpen()\n *\n * Called when left action panel gets open.\n */\n onSwipeableLeftOpen?: () => void;\n\n /**\n * @deprecated Use `direction` argument of onSwipeableOpen()\n *\n * Called when right action panel gets open.\n */\n onSwipeableRightOpen?: () => void;\n\n /**\n * Called when action panel gets open (either right or left).\n */\n onSwipeableOpen?: (direction: 'left' | 'right', swipeable: Swipeable) => void;\n\n /**\n * Called when action panel is closed.\n */\n onSwipeableClose?: (\n direction: 'left' | 'right',\n swipeable: Swipeable\n ) => void;\n\n /**\n * @deprecated Use `direction` argument of onSwipeableWillOpen()\n *\n * Called when left action panel starts animating on open.\n */\n onSwipeableLeftWillOpen?: () => void;\n\n /**\n * @deprecated Use `direction` argument of onSwipeableWillOpen()\n *\n * Called when right action panel starts animating on open.\n */\n onSwipeableRightWillOpen?: () => void;\n\n /**\n * Called when action panel starts animating on open (either right or left).\n */\n onSwipeableWillOpen?: (direction: 'left' | 'right') => void;\n\n /**\n * Called when action panel starts animating on close.\n */\n onSwipeableWillClose?: (direction: 'left' | 'right') => void;\n\n /**\n *\n * This map describes the values to use as inputRange for extra interpolation:\n * AnimatedValue: [startValue, endValue]\n *\n * progressAnimatedValue: [0, 1] dragAnimatedValue: [0, +]\n *\n * To support `rtl` flexbox layouts use `flexDirection` styling.\n * */\n renderLeftActions?: (\n progressAnimatedValue: AnimatedInterpolation,\n dragAnimatedValue: AnimatedInterpolation\n ) => React.ReactNode;\n /**\n *\n * This map describes the values to use as inputRange for extra interpolation:\n * AnimatedValue: [startValue, endValue]\n *\n * progressAnimatedValue: [0, 1] dragAnimatedValue: [0, -]\n *\n * To support `rtl` flexbox layouts use `flexDirection` styling.\n * */\n renderRightActions?: (\n progressAnimatedValue: AnimatedInterpolation,\n dragAnimatedValue: AnimatedInterpolation,\n swipeable: Swipeable\n ) => React.ReactNode;\n\n useNativeAnimations?: boolean;\n\n animationOptions?: Record;\n\n /**\n * Style object for the container (`Animated.View`), for example to override\n * `overflow: 'hidden'`.\n */\n containerStyle?: StyleProp;\n\n /**\n * Style object for the children container (`Animated.View`), for example to\n * apply `flex: 1`\n */\n childrenContainerStyle?: StyleProp;\n}\n\ntype SwipeableState = {\n dragX: Animated.Value;\n rowTranslation: Animated.Value;\n rowState: number;\n leftWidth?: number;\n rightOffset?: number;\n rowWidth?: number;\n};\n\nexport default class Swipeable extends Component<\n SwipeableProps,\n SwipeableState\n> {\n static defaultProps = {\n friction: 1,\n overshootFriction: 1,\n useNativeAnimations: true,\n };\n\n constructor(props: SwipeableProps) {\n super(props);\n const dragX = new Animated.Value(0);\n this.state = {\n dragX,\n rowTranslation: new Animated.Value(0),\n rowState: 0,\n leftWidth: undefined,\n rightOffset: undefined,\n rowWidth: undefined,\n };\n this.updateAnimatedEvent(props, this.state);\n\n this.onGestureEvent = Animated.event(\n [{ nativeEvent: { translationX: dragX } }],\n { useNativeDriver: props.useNativeAnimations! }\n );\n }\n\n shouldComponentUpdate(props: SwipeableProps, state: SwipeableState) {\n if (\n this.props.friction !== props.friction ||\n this.props.overshootLeft !== props.overshootLeft ||\n this.props.overshootRight !== props.overshootRight ||\n this.props.overshootFriction !== props.overshootFriction ||\n this.state.leftWidth !== state.leftWidth ||\n this.state.rightOffset !== state.rightOffset ||\n this.state.rowWidth !== state.rowWidth\n ) {\n this.updateAnimatedEvent(props, state);\n }\n\n return true;\n }\n\n private onGestureEvent?: (\n event: GestureEvent\n ) => void;\n private transX?: AnimatedInterpolation;\n private showLeftAction?: AnimatedInterpolation | Animated.Value;\n private leftActionTranslate?: AnimatedInterpolation;\n private showRightAction?: AnimatedInterpolation | Animated.Value;\n private rightActionTranslate?: AnimatedInterpolation;\n\n private updateAnimatedEvent = (\n props: SwipeableProps,\n state: SwipeableState\n ) => {\n const { friction, overshootFriction } = props;\n const { dragX, rowTranslation, leftWidth = 0, rowWidth = 0 } = state;\n const { rightOffset = rowWidth } = state;\n const rightWidth = Math.max(0, rowWidth - rightOffset);\n\n const { overshootLeft = leftWidth > 0, overshootRight = rightWidth > 0 } =\n props;\n\n const transX = Animated.add(\n rowTranslation,\n dragX.interpolate({\n inputRange: [0, friction!],\n outputRange: [0, 1],\n })\n ).interpolate({\n inputRange: [-rightWidth - 1, -rightWidth, leftWidth, leftWidth + 1],\n outputRange: [\n -rightWidth - (overshootRight ? 1 / overshootFriction! : 0),\n -rightWidth,\n leftWidth,\n leftWidth + (overshootLeft ? 1 / overshootFriction! : 0),\n ],\n });\n this.transX = transX;\n this.showLeftAction =\n leftWidth > 0\n ? transX.interpolate({\n inputRange: [-1, 0, leftWidth],\n outputRange: [0, 0, 1],\n })\n : new Animated.Value(0);\n this.leftActionTranslate = this.showLeftAction.interpolate({\n inputRange: [0, Number.MIN_VALUE],\n outputRange: [-10000, 0],\n extrapolate: 'clamp',\n });\n this.showRightAction =\n rightWidth > 0\n ? transX.interpolate({\n inputRange: [-rightWidth, 0, 1],\n outputRange: [1, 0, 0],\n })\n : new Animated.Value(0);\n this.rightActionTranslate = this.showRightAction.interpolate({\n inputRange: [0, Number.MIN_VALUE],\n outputRange: [-10000, 0],\n extrapolate: 'clamp',\n });\n };\n\n private onTapHandlerStateChange = ({\n nativeEvent,\n }: HandlerStateChangeEvent) => {\n if (nativeEvent.oldState === State.ACTIVE) {\n this.close();\n }\n };\n\n private onHandlerStateChange = (\n ev: HandlerStateChangeEvent\n ) => {\n if (ev.nativeEvent.oldState === State.ACTIVE) {\n this.handleRelease(ev);\n }\n };\n\n private handleRelease = (\n ev: HandlerStateChangeEvent\n ) => {\n const { velocityX, translationX: dragX } = ev.nativeEvent;\n const { leftWidth = 0, rowWidth = 0, rowState } = this.state;\n const { rightOffset = rowWidth } = this.state;\n const rightWidth = rowWidth - rightOffset;\n const {\n friction,\n leftThreshold = leftWidth / 2,\n rightThreshold = rightWidth / 2,\n } = this.props;\n\n const startOffsetX = this.currentOffset() + dragX / friction!;\n const translationX = (dragX + DRAG_TOSS * velocityX) / friction!;\n\n let toValue = 0;\n if (rowState === 0) {\n if (translationX > leftThreshold) {\n toValue = leftWidth;\n } else if (translationX < -rightThreshold) {\n toValue = -rightWidth;\n }\n } else if (rowState === 1) {\n // swiped to left\n if (translationX > -leftThreshold) {\n toValue = leftWidth;\n }\n } else {\n // swiped to right\n if (translationX < rightThreshold) {\n toValue = -rightWidth;\n }\n }\n\n this.animateRow(startOffsetX, toValue, velocityX / friction!);\n };\n\n private animateRow = (\n fromValue: number,\n toValue: number,\n velocityX?:\n | number\n | {\n x: number;\n y: number;\n }\n ) => {\n const { dragX, rowTranslation } = this.state;\n dragX.setValue(0);\n rowTranslation.setValue(fromValue);\n\n this.setState({ rowState: Math.sign(toValue) });\n Animated.spring(rowTranslation, {\n restSpeedThreshold: 1.7,\n restDisplacementThreshold: 0.4,\n velocity: velocityX,\n bounciness: 0,\n toValue,\n useNativeDriver: this.props.useNativeAnimations!,\n ...this.props.animationOptions,\n }).start(({ finished }) => {\n if (finished) {\n if (toValue > 0) {\n this.props.onSwipeableLeftOpen?.();\n this.props.onSwipeableOpen?.('left', this);\n } else if (toValue < 0) {\n this.props.onSwipeableRightOpen?.();\n this.props.onSwipeableOpen?.('right', this);\n } else {\n const closingDirection = fromValue > 0 ? 'left' : 'right';\n this.props.onSwipeableClose?.(closingDirection, this);\n }\n }\n });\n if (toValue > 0) {\n this.props.onSwipeableLeftWillOpen?.();\n this.props.onSwipeableWillOpen?.('left');\n } else if (toValue < 0) {\n this.props.onSwipeableRightWillOpen?.();\n this.props.onSwipeableWillOpen?.('right');\n } else {\n const closingDirection = fromValue > 0 ? 'left' : 'right';\n this.props.onSwipeableWillClose?.(closingDirection);\n }\n };\n\n private onRowLayout = ({ nativeEvent }: LayoutChangeEvent) => {\n this.setState({ rowWidth: nativeEvent.layout.width });\n };\n\n private currentOffset = () => {\n const { leftWidth = 0, rowWidth = 0, rowState } = this.state;\n const { rightOffset = rowWidth } = this.state;\n const rightWidth = rowWidth - rightOffset;\n if (rowState === 1) {\n return leftWidth;\n } else if (rowState === -1) {\n return -rightWidth;\n }\n return 0;\n };\n\n close = () => {\n this.animateRow(this.currentOffset(), 0);\n };\n\n openLeft = () => {\n const { leftWidth = 0 } = this.state;\n this.animateRow(this.currentOffset(), leftWidth);\n };\n\n openRight = () => {\n const { rowWidth = 0 } = this.state;\n const { rightOffset = rowWidth } = this.state;\n const rightWidth = rowWidth - rightOffset;\n this.animateRow(this.currentOffset(), -rightWidth);\n };\n\n render() {\n const { rowState } = this.state;\n const { children, renderLeftActions, renderRightActions } = this.props;\n\n const left = renderLeftActions && (\n \n {renderLeftActions(this.showLeftAction!, this.transX!)}\n \n this.setState({ leftWidth: nativeEvent.layout.x })\n }\n />\n \n );\n\n const right = renderRightActions && (\n \n {renderRightActions(this.showRightAction!, this.transX!, this)}\n \n this.setState({ rightOffset: nativeEvent.layout.x })\n }\n />\n \n );\n\n return (\n \n \n {left}\n {right}\n \n \n {children}\n \n \n \n \n );\n }\n}\n\nconst styles = StyleSheet.create({\n container: {\n overflow: 'hidden',\n },\n leftActions: {\n ...StyleSheet.absoluteFillObject,\n flexDirection: I18nManager.isRTL ? 'row-reverse' : 'row',\n },\n rightActions: {\n ...StyleSheet.absoluteFillObject,\n flexDirection: I18nManager.isRTL ? 'row' : 'row-reverse',\n },\n});\n","// This component is based on RN's DrawerLayoutAndroid API\n//\n// It perhaps deserves to be put in a separate repo, but since it relies on\n// react-native-gesture-handler library which isn't very popular at the moment I\n// decided to keep it here for the time being. It will allow us to move faster\n// and fix issues that may arise in gesture handler library that could be found\n// when using the drawer component\n\nimport * as React from 'react';\nimport { Component } from 'react';\nimport invariant from 'invariant';\nimport {\n Animated,\n StyleSheet,\n View,\n Keyboard,\n StatusBar,\n I18nManager,\n StatusBarAnimation,\n StyleProp,\n ViewStyle,\n LayoutChangeEvent,\n NativeSyntheticEvent,\n} from 'react-native';\n\nimport {\n GestureEvent,\n HandlerStateChangeEvent,\n UserSelect,\n} from '../handlers/gestureHandlerCommon';\nimport {\n PanGestureHandler,\n PanGestureHandlerEventPayload,\n} from '../handlers/PanGestureHandler';\nimport {\n TapGestureHandler,\n TapGestureHandlerEventPayload,\n} from '../handlers/TapGestureHandler';\nimport { State } from '../State';\n\nconst DRAG_TOSS = 0.05;\n\nconst IDLE: DrawerState = 'Idle';\nconst DRAGGING: DrawerState = 'Dragging';\nconst SETTLING: DrawerState = 'Settling';\n\nexport type DrawerPosition = 'left' | 'right';\n\nexport type DrawerState = 'Idle' | 'Dragging' | 'Settling';\n\nexport type DrawerType = 'front' | 'back' | 'slide';\n\nexport type DrawerLockMode = 'unlocked' | 'locked-closed' | 'locked-open';\n\nexport type DrawerKeyboardDismissMode = 'none' | 'on-drag';\n\n// Animated.AnimatedInterpolation has been converted to a generic type\n// in @types/react-native 0.70. This way we can maintain compatibility\n// with all versions of @types/react-native`\ntype AnimatedInterpolation = ReturnType;\nexport interface DrawerLayoutProps {\n /**\n * This attribute is present in the standard implementation already and is one\n * of the required params. Gesture handler version of DrawerLayout make it\n * possible for the function passed as `renderNavigationView` to take an\n * Animated value as a parameter that indicates the progress of drawer\n * opening/closing animation (progress value is 0 when closed and 1 when\n * opened). This can be used by the drawer component to animated its children\n * while the drawer is opening or closing.\n */\n renderNavigationView: (\n progressAnimatedValue: Animated.Value\n ) => React.ReactNode;\n\n drawerPosition?: DrawerPosition;\n\n drawerWidth?: number;\n\n drawerBackgroundColor?: string;\n\n drawerLockMode?: DrawerLockMode;\n\n keyboardDismissMode?: DrawerKeyboardDismissMode;\n\n /**\n * Called when the drawer is closed.\n */\n onDrawerClose?: () => void;\n\n /**\n * Called when the drawer is opened.\n */\n onDrawerOpen?: () => void;\n\n /**\n * Called when the status of the drawer changes.\n */\n onDrawerStateChanged?: (\n newState: DrawerState,\n drawerWillShow: boolean\n ) => void;\n useNativeAnimations?: boolean;\n\n drawerType?: DrawerType;\n\n /**\n * Defines how far from the edge of the content view the gesture should\n * activate.\n */\n edgeWidth?: number;\n\n minSwipeDistance?: number;\n\n /**\n * When set to true Drawer component will use\n * {@link https://reactnative.dev/docs/statusbar StatusBar} API to hide the OS\n * status bar whenever the drawer is pulled or when its in an \"open\" state.\n */\n hideStatusBar?: boolean;\n\n /**\n * @default 'slide'\n *\n * Can be used when hideStatusBar is set to true and will select the animation\n * used for hiding/showing the status bar. See\n * {@link https://reactnative.dev/docs/statusbar StatusBar} documentation for\n * more details\n */\n statusBarAnimation?: StatusBarAnimation;\n\n /**\n * @default black\n *\n * Color of a semi-transparent overlay to be displayed on top of the content\n * view when drawer gets open. A solid color should be used as the opacity is\n * added by the Drawer itself and the opacity of the overlay is animated (from\n * 0% to 70%).\n */\n overlayColor?: string;\n\n contentContainerStyle?: StyleProp;\n\n drawerContainerStyle?: StyleProp;\n\n /**\n * Enables two-finger gestures on supported devices, for example iPads with\n * trackpads. If not enabled the gesture will require click + drag, with\n * `enableTrackpadTwoFingerGesture` swiping with two fingers will also trigger\n * the gesture.\n */\n enableTrackpadTwoFingerGesture?: boolean;\n\n onDrawerSlide?: (position: number) => void;\n\n onGestureRef?: (ref: PanGestureHandler) => void;\n\n // implicit `children` prop has been removed in @types/react^18.0.0\n children?:\n | React.ReactNode\n | ((openValue?: AnimatedInterpolation) => React.ReactNode);\n\n /**\n * @default 'none'\n * Defines which userSelect property should be used.\n * Values: 'none'|'text'|'auto'\n */\n userSelect?: UserSelect;\n}\n\nexport type DrawerLayoutState = {\n dragX: Animated.Value;\n touchX: Animated.Value;\n drawerTranslation: Animated.Value;\n containerWidth: number;\n drawerState: DrawerState;\n drawerOpened: boolean;\n};\n\nexport type DrawerMovementOption = {\n velocity?: number;\n speed?: number;\n};\nexport default class DrawerLayout extends Component<\n DrawerLayoutProps,\n DrawerLayoutState\n> {\n static defaultProps = {\n drawerWidth: 200,\n drawerPosition: 'left',\n useNativeAnimations: true,\n drawerType: 'front',\n edgeWidth: 20,\n minSwipeDistance: 3,\n overlayColor: 'rgba(0, 0, 0, 0.7)',\n drawerLockMode: 'unlocked',\n enableTrackpadTwoFingerGesture: false,\n };\n\n constructor(props: DrawerLayoutProps) {\n super(props);\n\n const dragX = new Animated.Value(0);\n const touchX = new Animated.Value(0);\n const drawerTranslation = new Animated.Value(0);\n\n this.state = {\n dragX,\n touchX,\n drawerTranslation,\n containerWidth: 0,\n drawerState: IDLE,\n drawerOpened: false,\n };\n\n this.updateAnimatedEvent(props, this.state);\n }\n\n shouldComponentUpdate(props: DrawerLayoutProps, state: DrawerLayoutState) {\n if (\n this.props.drawerPosition !== props.drawerPosition ||\n this.props.drawerWidth !== props.drawerWidth ||\n this.props.drawerType !== props.drawerType ||\n this.state.containerWidth !== state.containerWidth\n ) {\n this.updateAnimatedEvent(props, state);\n }\n\n return true;\n }\n\n private openValue?: AnimatedInterpolation;\n private onGestureEvent?: (\n event: GestureEvent\n ) => void;\n private accessibilityIsModalView = React.createRef();\n private pointerEventsView = React.createRef();\n private panGestureHandler = React.createRef();\n private drawerShown = false;\n\n static positions = {\n Left: 'left',\n Right: 'right',\n };\n\n private updateAnimatedEvent = (\n props: DrawerLayoutProps,\n state: DrawerLayoutState\n ) => {\n // Event definition is based on\n const { drawerPosition, drawerWidth, drawerType } = props;\n const {\n dragX: dragXValue,\n touchX: touchXValue,\n drawerTranslation,\n containerWidth,\n } = state;\n\n let dragX = dragXValue;\n let touchX = touchXValue;\n\n if (drawerPosition !== 'left') {\n // Most of the code is written in a way to handle left-side drawer. In\n // order to handle right-side drawer the only thing we need to do is to\n // reverse events coming from gesture handler in a way they emulate\n // left-side drawer gestures. E.g. dragX is simply -dragX, and touchX is\n // calulcated by subtracing real touchX from the width of the container\n // (such that when touch happens at the right edge the value is simply 0)\n dragX = Animated.multiply(\n new Animated.Value(-1),\n dragXValue\n ) as Animated.Value; // TODO(TS): (for all \"as\" in this file) make sure we can map this\n touchX = Animated.add(\n new Animated.Value(containerWidth),\n Animated.multiply(new Animated.Value(-1), touchXValue)\n ) as Animated.Value; // TODO(TS): make sure we can map this;\n touchXValue.setValue(containerWidth);\n } else {\n touchXValue.setValue(0);\n }\n\n // While closing the drawer when user starts gesture outside of its area (in greyed\n // out part of the window), we want the drawer to follow only once finger reaches the\n // edge of the drawer.\n // E.g. on the diagram below drawer is illustrate by X signs and the greyed out area by\n // dots. The touch gesture starts at '*' and moves left, touch path is indicated by\n // an arrow pointing left\n // 1) +---------------+ 2) +---------------+ 3) +---------------+ 4) +---------------+\n // |XXXXXXXX|......| |XXXXXXXX|......| |XXXXXXXX|......| |XXXXX|.........|\n // |XXXXXXXX|......| |XXXXXXXX|......| |XXXXXXXX|......| |XXXXX|.........|\n // |XXXXXXXX|......| |XXXXXXXX|......| |XXXXXXXX|......| |XXXXX|.........|\n // |XXXXXXXX|......| |XXXXXXXX|.<-*..| |XXXXXXXX|<--*..| |XXXXX|<-----*..|\n // |XXXXXXXX|......| |XXXXXXXX|......| |XXXXXXXX|......| |XXXXX|.........|\n // |XXXXXXXX|......| |XXXXXXXX|......| |XXXXXXXX|......| |XXXXX|.........|\n // |XXXXXXXX|......| |XXXXXXXX|......| |XXXXXXXX|......| |XXXXX|.........|\n // +---------------+ +---------------+ +---------------+ +---------------+\n //\n // For the above to work properly we define animated value that will keep\n // start position of the gesture. Then we use that value to calculate how\n // much we need to subtract from the dragX. If the gesture started on the\n // greyed out area we take the distance from the edge of the drawer to the\n // start position. Otherwise we don't subtract at all and the drawer be\n // pulled back as soon as you start the pan.\n //\n // This is used only when drawerType is \"front\"\n //\n let translationX = dragX;\n if (drawerType === 'front') {\n const startPositionX = Animated.add(\n touchX,\n Animated.multiply(new Animated.Value(-1), dragX)\n );\n\n const dragOffsetFromOnStartPosition = startPositionX.interpolate({\n inputRange: [drawerWidth! - 1, drawerWidth!, drawerWidth! + 1],\n outputRange: [0, 0, 1],\n });\n translationX = Animated.add(\n dragX,\n dragOffsetFromOnStartPosition\n ) as Animated.Value; // TODO: as above\n }\n\n this.openValue = Animated.add(translationX, drawerTranslation).interpolate({\n inputRange: [0, drawerWidth!],\n outputRange: [0, 1],\n extrapolate: 'clamp',\n });\n\n const gestureOptions: {\n useNativeDriver: boolean;\n // TODO: make sure it is correct\n listener?: (\n ev: NativeSyntheticEvent\n ) => void;\n } = {\n useNativeDriver: props.useNativeAnimations!,\n };\n\n if (this.props.onDrawerSlide) {\n gestureOptions.listener = (ev) => {\n const translationX = Math.floor(Math.abs(ev.nativeEvent.translationX));\n const position = translationX / this.state.containerWidth;\n\n this.props.onDrawerSlide?.(position);\n };\n }\n\n this.onGestureEvent = Animated.event(\n [{ nativeEvent: { translationX: dragXValue, x: touchXValue } }],\n gestureOptions\n );\n };\n\n private handleContainerLayout = ({ nativeEvent }: LayoutChangeEvent) => {\n this.setState({ containerWidth: nativeEvent.layout.width });\n };\n\n private emitStateChanged = (\n newState: DrawerState,\n drawerWillShow: boolean\n ) => {\n this.props.onDrawerStateChanged?.(newState, drawerWillShow);\n };\n\n private openingHandlerStateChange = ({\n nativeEvent,\n }: HandlerStateChangeEvent) => {\n if (nativeEvent.oldState === State.ACTIVE) {\n this.handleRelease({ nativeEvent });\n } else if (nativeEvent.state === State.ACTIVE) {\n this.emitStateChanged(DRAGGING, false);\n this.setState({ drawerState: DRAGGING });\n if (this.props.keyboardDismissMode === 'on-drag') {\n Keyboard.dismiss();\n }\n if (this.props.hideStatusBar) {\n StatusBar.setHidden(true, this.props.statusBarAnimation || 'slide');\n }\n }\n };\n\n private onTapHandlerStateChange = ({\n nativeEvent,\n }: HandlerStateChangeEvent) => {\n if (\n this.drawerShown &&\n nativeEvent.oldState === State.ACTIVE &&\n this.props.drawerLockMode !== 'locked-open'\n ) {\n this.closeDrawer();\n }\n };\n\n private handleRelease = ({\n nativeEvent,\n }: HandlerStateChangeEvent) => {\n const { drawerWidth, drawerPosition, drawerType } = this.props;\n const { containerWidth } = this.state;\n let { translationX: dragX, velocityX, x: touchX } = nativeEvent;\n\n if (drawerPosition !== 'left') {\n // See description in _updateAnimatedEvent about why events are flipped\n // for right-side drawer\n dragX = -dragX;\n touchX = containerWidth - touchX;\n velocityX = -velocityX;\n }\n\n const gestureStartX = touchX - dragX;\n let dragOffsetBasedOnStart = 0;\n\n if (drawerType === 'front') {\n dragOffsetBasedOnStart =\n gestureStartX > drawerWidth! ? gestureStartX - drawerWidth! : 0;\n }\n\n const startOffsetX =\n dragX + dragOffsetBasedOnStart + (this.drawerShown ? drawerWidth! : 0);\n const projOffsetX = startOffsetX + DRAG_TOSS * velocityX;\n\n const shouldOpen = projOffsetX > drawerWidth! / 2;\n\n if (shouldOpen) {\n this.animateDrawer(startOffsetX, drawerWidth!, velocityX);\n } else {\n this.animateDrawer(startOffsetX, 0, velocityX);\n }\n };\n\n private updateShowing = (showing: boolean) => {\n this.drawerShown = showing;\n this.accessibilityIsModalView.current?.setNativeProps({\n accessibilityViewIsModal: showing,\n });\n this.pointerEventsView.current?.setNativeProps({\n pointerEvents: showing ? 'auto' : 'none',\n });\n const { drawerPosition, minSwipeDistance, edgeWidth } = this.props;\n const fromLeft = drawerPosition === 'left';\n // gestureOrientation is 1 if the expected gesture is from left to right and\n // -1 otherwise e.g. when drawer is on the left and is closed we expect left\n // to right gesture, thus orientation will be 1.\n const gestureOrientation =\n (fromLeft ? 1 : -1) * (this.drawerShown ? -1 : 1);\n // When drawer is closed we want the hitSlop to be horizontally shorter than\n // the container size by the value of SLOP. This will make it only activate\n // when gesture happens not further than SLOP away from the edge\n const hitSlop = fromLeft\n ? { left: 0, width: showing ? undefined : edgeWidth }\n : { right: 0, width: showing ? undefined : edgeWidth };\n // @ts-ignore internal API, maybe could be fixed in handler types\n this.panGestureHandler.current?.setNativeProps({\n hitSlop,\n activeOffsetX: gestureOrientation * minSwipeDistance!,\n });\n };\n\n private animateDrawer = (\n fromValue: number | null | undefined,\n toValue: number,\n velocity: number,\n speed?: number\n ) => {\n this.state.dragX.setValue(0);\n this.state.touchX.setValue(\n this.props.drawerPosition === 'left' ? 0 : this.state.containerWidth\n );\n\n if (fromValue != null) {\n let nextFramePosition = fromValue;\n if (this.props.useNativeAnimations) {\n // When using native driver, we predict the next position of the\n // animation because it takes one frame of a roundtrip to pass RELEASE\n // event from native driver to JS before we can start animating. Without\n // it, it is more noticable that the frame is dropped.\n if (fromValue < toValue && velocity > 0) {\n nextFramePosition = Math.min(fromValue + velocity / 60.0, toValue);\n } else if (fromValue > toValue && velocity < 0) {\n nextFramePosition = Math.max(fromValue + velocity / 60.0, toValue);\n }\n }\n this.state.drawerTranslation.setValue(nextFramePosition);\n }\n\n const willShow = toValue !== 0;\n this.updateShowing(willShow);\n this.emitStateChanged(SETTLING, willShow);\n this.setState({ drawerState: SETTLING });\n if (this.props.hideStatusBar) {\n StatusBar.setHidden(willShow, this.props.statusBarAnimation || 'slide');\n }\n Animated.spring(this.state.drawerTranslation, {\n velocity,\n bounciness: 0,\n toValue,\n useNativeDriver: this.props.useNativeAnimations!,\n speed: speed ?? undefined,\n }).start(({ finished }) => {\n if (finished) {\n this.emitStateChanged(IDLE, willShow);\n this.setState({ drawerOpened: willShow });\n if (this.state.drawerState !== DRAGGING) {\n // it's possilbe that user started drag while the drawer\n // was settling, don't override state in this case\n this.setState({ drawerState: IDLE });\n }\n if (willShow) {\n this.props.onDrawerOpen?.();\n } else {\n this.props.onDrawerClose?.();\n }\n }\n });\n };\n\n openDrawer = (options: DrawerMovementOption = {}) => {\n this.animateDrawer(\n // TODO: decide if it should be null or undefined is the proper value\n undefined,\n this.props.drawerWidth!,\n options.velocity ? options.velocity : 0,\n options.speed\n );\n\n // We need to force the update, otherwise the overlay is not rerendered and\n // it would not be clickable\n this.forceUpdate();\n };\n\n closeDrawer = (options: DrawerMovementOption = {}) => {\n // TODO: decide if it should be null or undefined is the proper value\n this.animateDrawer(\n undefined,\n 0,\n options.velocity ? options.velocity : 0,\n options.speed\n );\n\n // We need to force the update, otherwise the overlay is not rerendered and\n // it would be still clickable\n this.forceUpdate();\n };\n\n private renderOverlay = () => {\n /* Overlay styles */\n invariant(this.openValue, 'should be set');\n let overlayOpacity;\n\n if (this.state.drawerState !== IDLE) {\n overlayOpacity = this.openValue;\n } else {\n overlayOpacity = this.state.drawerOpened ? 1 : 0;\n }\n\n const dynamicOverlayStyles = {\n opacity: overlayOpacity,\n backgroundColor: this.props.overlayColor,\n };\n\n return (\n \n \n \n );\n };\n\n private renderDrawer = () => {\n const {\n drawerBackgroundColor,\n drawerWidth,\n drawerPosition,\n drawerType,\n drawerContainerStyle,\n contentContainerStyle,\n } = this.props;\n\n const fromLeft = drawerPosition === 'left';\n const drawerSlide = drawerType !== 'back';\n const containerSlide = drawerType !== 'front';\n\n // we rely on row and row-reverse flex directions to position the drawer\n // properly. Apparently for RTL these are flipped which requires us to use\n // the opposite setting for the drawer to appear from left or right\n // according to the drawerPosition prop\n const reverseContentDirection = I18nManager.isRTL ? fromLeft : !fromLeft;\n\n const dynamicDrawerStyles = {\n backgroundColor: drawerBackgroundColor,\n width: drawerWidth,\n };\n const openValue = this.openValue;\n invariant(openValue, 'should be set');\n\n let containerStyles;\n if (containerSlide) {\n const containerTranslateX = openValue.interpolate({\n inputRange: [0, 1],\n outputRange: fromLeft ? [0, drawerWidth!] : [0, -drawerWidth!],\n extrapolate: 'clamp',\n });\n containerStyles = {\n transform: [{ translateX: containerTranslateX }],\n };\n }\n\n let drawerTranslateX: number | AnimatedInterpolation = 0;\n if (drawerSlide) {\n const closedDrawerOffset = fromLeft ? -drawerWidth! : drawerWidth!;\n if (this.state.drawerState !== IDLE) {\n drawerTranslateX = openValue.interpolate({\n inputRange: [0, 1],\n outputRange: [closedDrawerOffset, 0],\n extrapolate: 'clamp',\n });\n } else {\n drawerTranslateX = this.state.drawerOpened ? 0 : closedDrawerOffset;\n }\n }\n const drawerStyles: {\n transform: { translateX: number | AnimatedInterpolation }[];\n flexDirection: 'row-reverse' | 'row';\n } = {\n transform: [{ translateX: drawerTranslateX }],\n flexDirection: reverseContentDirection ? 'row-reverse' : 'row',\n };\n\n return (\n \n \n {typeof this.props.children === 'function'\n ? this.props.children(this.openValue)\n : this.props.children}\n {this.renderOverlay()}\n \n \n \n {this.props.renderNavigationView(this.openValue as Animated.Value)}\n \n \n \n );\n };\n\n private setPanGestureRef = (ref: PanGestureHandler) => {\n // TODO(TS): make sure it is OK taken from\n // https://github.com/DefinitelyTyped/DefinitelyTyped/issues/31065#issuecomment-596081842\n (\n this.panGestureHandler as React.MutableRefObject\n ).current = ref;\n this.props.onGestureRef?.(ref);\n };\n\n render() {\n const { drawerPosition, drawerLockMode, edgeWidth, minSwipeDistance } =\n this.props;\n\n const fromLeft = drawerPosition === 'left';\n\n // gestureOrientation is 1 if the expected gesture is from left to right and\n // -1 otherwise e.g. when drawer is on the left and is closed we expect left\n // to right gesture, thus orientation will be 1.\n const gestureOrientation =\n (fromLeft ? 1 : -1) * (this.drawerShown ? -1 : 1);\n\n // When drawer is closed we want the hitSlop to be horizontally shorter than\n // the container size by the value of SLOP. This will make it only activate\n // when gesture happens not further than SLOP away from the edge\n const hitSlop = fromLeft\n ? { left: 0, width: this.drawerShown ? undefined : edgeWidth }\n : { right: 0, width: this.drawerShown ? undefined : edgeWidth };\n\n return (\n \n {this.renderDrawer()}\n \n );\n }\n}\n\nconst styles = StyleSheet.create({\n drawerContainer: {\n ...StyleSheet.absoluteFillObject,\n zIndex: 1001,\n flexDirection: 'row',\n },\n containerInFront: {\n ...StyleSheet.absoluteFillObject,\n zIndex: 1002,\n },\n containerOnBack: {\n ...StyleSheet.absoluteFillObject,\n },\n main: {\n flex: 1,\n zIndex: 0,\n overflow: 'hidden',\n },\n overlay: {\n ...StyleSheet.absoluteFillObject,\n zIndex: 1000,\n },\n});\n","import '../wdyr';\nimport React from 'react';\nimport {LogBox} from 'react-native';\nimport {GestureHandlerRootView} from 'react-native-gesture-handler';\nimport {SafeAreaProvider} from 'react-native-safe-area-context';\nimport Onyx from 'react-native-onyx';\nimport {PortalProvider} from '@gorhom/portal';\nimport CustomStatusBar from './components/CustomStatusBar';\nimport ErrorBoundary from './components/ErrorBoundary';\nimport Expensify from './Expensify';\nimport {LocaleContextProvider} from './components/withLocalize';\nimport OnyxProvider from './components/OnyxProvider';\nimport HTMLEngineProvider from './components/HTMLEngineProvider';\nimport ComposeProviders from './components/ComposeProviders';\nimport SafeArea from './components/SafeArea';\nimport * as Environment from './libs/Environment/Environment';\nimport {WindowDimensionsProvider} from './components/withWindowDimensions';\nimport {KeyboardStateProvider} from './components/withKeyboardState';\n\n// For easier debugging and development, when we are in web we expose Onyx to the window, so you can more easily set data into Onyx\nif (window && Environment.isDevelopment()) {\n window.Onyx = Onyx;\n}\n\nLogBox.ignoreLogs([\n // Basically it means that if the app goes in the background and back to foreground on Android,\n // the timer is lost. Currently Expensify is using a 30 minutes interval to refresh personal details.\n // More details here: https://git.io/JJYeb\n 'Setting a timer for a long period of time',\n]);\n\nconst fill = {flex: 1};\n\nconst App = () => (\n \n \n \n \n \n \n \n \n);\n\nApp.displayName = 'App';\n\nexport default App;\n","// Implements Why Did You Render (WDYR) in Dev\n\nimport React from 'react';\nimport Config from 'react-native-config';\nimport lodashGet from 'lodash/get';\n\nconst useWDYR = lodashGet(Config, 'USE_WDYR') === 'true';\n\nif (useWDYR) {\n const whyDidYouRender = require('@welldone-software/why-did-you-render');\n whyDidYouRender(React, {\n // Enable tracking in all pure components by default\n trackAllPureComponents: true,\n\n include: [\n // Uncomment to enable tracking in all components. Must also uncomment /^Screen/ in exclude.\n // /.*/,\n\n // Uncomment to enable tracking by displayName, e.g.:\n // /^Avatar/,\n // /^ReportActionItem/,\n // /^ReportActionItemSingle/,\n ],\n\n exclude: [\n // Uncomment to enable tracking in all components\n // /^Screen/\n ],\n });\n}\n","'use strict';\n\n// Bridge to:\n// Android: buildConfigField vars set in build.gradle, and exported via ReactConfig\n// iOS: config vars set in xcconfig and exposed via ReactNativeConfig.m\nimport { NativeModules } from 'react-native';\n\nexport const Config = NativeModules.ReactNativeConfigModule || {}\nexport default Config;\n","var baseGet = require('./_baseGet');\n\n/**\n * Gets the value at `path` of `object`. If the resolved value is\n * `undefined`, the `defaultValue` is returned in its place.\n *\n * @static\n * @memberOf _\n * @since 3.7.0\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the property to get.\n * @param {*} [defaultValue] The value returned for `undefined` resolved values.\n * @returns {*} Returns the resolved value.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }] };\n *\n * _.get(object, 'a[0].b.c');\n * // => 3\n *\n * _.get(object, ['a', '0', 'b', 'c']);\n * // => 3\n *\n * _.get(object, 'a.b.c', 'default');\n * // => 'default'\n */\nfunction get(object, path, defaultValue) {\n var result = object == null ? undefined : baseGet(object, path);\n return result === undefined ? defaultValue : result;\n}\n\nmodule.exports = get;\n","var castPath = require('./_castPath'),\n toKey = require('./_toKey');\n\n/**\n * The base implementation of `_.get` without support for default values.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the property to get.\n * @returns {*} Returns the resolved value.\n */\nfunction baseGet(object, path) {\n path = castPath(path, object);\n\n var index = 0,\n length = path.length;\n\n while (object != null && index < length) {\n object = object[toKey(path[index++])];\n }\n return (index && index == length) ? object : undefined;\n}\n\nmodule.exports = baseGet;\n","var isArray = require('./isArray'),\n isKey = require('./_isKey'),\n stringToPath = require('./_stringToPath'),\n toString = require('./toString');\n\n/**\n * Casts `value` to a path array if it's not one.\n *\n * @private\n * @param {*} value The value to inspect.\n * @param {Object} [object] The object to query keys on.\n * @returns {Array} Returns the cast property path array.\n */\nfunction castPath(value, object) {\n if (isArray(value)) {\n return value;\n }\n return isKey(value, object) ? [value] : stringToPath(toString(value));\n}\n\nmodule.exports = castPath;\n","var isArray = require('./isArray'),\n isSymbol = require('./isSymbol');\n\n/** Used to match property names within property paths. */\nvar reIsDeepProp = /\\.|\\[(?:[^[\\]]*|([\"'])(?:(?!\\1)[^\\\\]|\\\\.)*?\\1)\\]/,\n reIsPlainProp = /^\\w*$/;\n\n/**\n * Checks if `value` is a property name and not a property path.\n *\n * @private\n * @param {*} value The value to check.\n * @param {Object} [object] The object to query keys on.\n * @returns {boolean} Returns `true` if `value` is a property name, else `false`.\n */\nfunction isKey(value, object) {\n if (isArray(value)) {\n return false;\n }\n var type = typeof value;\n if (type == 'number' || type == 'symbol' || type == 'boolean' ||\n value == null || isSymbol(value)) {\n return true;\n }\n return reIsPlainProp.test(value) || !reIsDeepProp.test(value) ||\n (object != null && value in Object(object));\n}\n\nmodule.exports = isKey;\n","var baseGetTag = require('./_baseGetTag'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar symbolTag = '[object Symbol]';\n\n/**\n * Checks if `value` is classified as a `Symbol` primitive or object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.\n * @example\n *\n * _.isSymbol(Symbol.iterator);\n * // => true\n *\n * _.isSymbol('abc');\n * // => false\n */\nfunction isSymbol(value) {\n return typeof value == 'symbol' ||\n (isObjectLike(value) && baseGetTag(value) == symbolTag);\n}\n\nmodule.exports = isSymbol;\n","var memoizeCapped = require('./_memoizeCapped');\n\n/** Used to match property names within property paths. */\nvar rePropName = /[^.[\\]]+|\\[(?:(-?\\d+(?:\\.\\d+)?)|([\"'])((?:(?!\\2)[^\\\\]|\\\\.)*?)\\2)\\]|(?=(?:\\.|\\[\\])(?:\\.|\\[\\]|$))/g;\n\n/** Used to match backslashes in property paths. */\nvar reEscapeChar = /\\\\(\\\\)?/g;\n\n/**\n * Converts `string` to a property path array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the property path array.\n */\nvar stringToPath = memoizeCapped(function(string) {\n var result = [];\n if (string.charCodeAt(0) === 46 /* . */) {\n result.push('');\n }\n string.replace(rePropName, function(match, number, quote, subString) {\n result.push(quote ? subString.replace(reEscapeChar, '$1') : (number || match));\n });\n return result;\n});\n\nmodule.exports = stringToPath;\n","var memoize = require('./memoize');\n\n/** Used as the maximum memoize cache size. */\nvar MAX_MEMOIZE_SIZE = 500;\n\n/**\n * A specialized version of `_.memoize` which clears the memoized function's\n * cache when it exceeds `MAX_MEMOIZE_SIZE`.\n *\n * @private\n * @param {Function} func The function to have its output memoized.\n * @returns {Function} Returns the new memoized function.\n */\nfunction memoizeCapped(func) {\n var result = memoize(func, function(key) {\n if (cache.size === MAX_MEMOIZE_SIZE) {\n cache.clear();\n }\n return key;\n });\n\n var cache = result.cache;\n return result;\n}\n\nmodule.exports = memoizeCapped;\n","var MapCache = require('./_MapCache');\n\n/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/**\n * Creates a function that memoizes the result of `func`. If `resolver` is\n * provided, it determines the cache key for storing the result based on the\n * arguments provided to the memoized function. By default, the first argument\n * provided to the memoized function is used as the map cache key. The `func`\n * is invoked with the `this` binding of the memoized function.\n *\n * **Note:** The cache is exposed as the `cache` property on the memoized\n * function. Its creation may be customized by replacing the `_.memoize.Cache`\n * constructor with one whose instances implement the\n * [`Map`](http://ecma-international.org/ecma-262/7.0/#sec-properties-of-the-map-prototype-object)\n * method interface of `clear`, `delete`, `get`, `has`, and `set`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to have its output memoized.\n * @param {Function} [resolver] The function to resolve the cache key.\n * @returns {Function} Returns the new memoized function.\n * @example\n *\n * var object = { 'a': 1, 'b': 2 };\n * var other = { 'c': 3, 'd': 4 };\n *\n * var values = _.memoize(_.values);\n * values(object);\n * // => [1, 2]\n *\n * values(other);\n * // => [3, 4]\n *\n * object.a = 2;\n * values(object);\n * // => [1, 2]\n *\n * // Modify the result cache.\n * values.cache.set(object, ['a', 'b']);\n * values(object);\n * // => ['a', 'b']\n *\n * // Replace `_.memoize.Cache`.\n * _.memoize.Cache = WeakMap;\n */\nfunction memoize(func, resolver) {\n if (typeof func != 'function' || (resolver != null && typeof resolver != 'function')) {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n var memoized = function() {\n var args = arguments,\n key = resolver ? resolver.apply(this, args) : args[0],\n cache = memoized.cache;\n\n if (cache.has(key)) {\n return cache.get(key);\n }\n var result = func.apply(this, args);\n memoized.cache = cache.set(key, result) || cache;\n return result;\n };\n memoized.cache = new (memoize.Cache || MapCache);\n return memoized;\n}\n\n// Expose `MapCache`.\nmemoize.Cache = MapCache;\n\nmodule.exports = memoize;\n","var baseToString = require('./_baseToString');\n\n/**\n * Converts `value` to a string. An empty string is returned for `null`\n * and `undefined` values. The sign of `-0` is preserved.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n * @example\n *\n * _.toString(null);\n * // => ''\n *\n * _.toString(-0);\n * // => '-0'\n *\n * _.toString([1, 2, 3]);\n * // => '1,2,3'\n */\nfunction toString(value) {\n return value == null ? '' : baseToString(value);\n}\n\nmodule.exports = toString;\n","var Symbol = require('./_Symbol'),\n arrayMap = require('./_arrayMap'),\n isArray = require('./isArray'),\n isSymbol = require('./isSymbol');\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolToString = symbolProto ? symbolProto.toString : undefined;\n\n/**\n * The base implementation of `_.toString` which doesn't convert nullish\n * values to empty strings.\n *\n * @private\n * @param {*} value The value to process.\n * @returns {string} Returns the string.\n */\nfunction baseToString(value) {\n // Exit early for strings to avoid a performance hit in some environments.\n if (typeof value == 'string') {\n return value;\n }\n if (isArray(value)) {\n // Recursively convert values (susceptible to call stack limits).\n return arrayMap(value, baseToString) + '';\n }\n if (isSymbol(value)) {\n return symbolToString ? symbolToString.call(value) : '';\n }\n var result = (value + '');\n return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n}\n\nmodule.exports = baseToString;\n","/**\n * A specialized version of `_.map` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n */\nfunction arrayMap(array, iteratee) {\n var index = -1,\n length = array == null ? 0 : array.length,\n result = Array(length);\n\n while (++index < length) {\n result[index] = iteratee(array[index], index, array);\n }\n return result;\n}\n\nmodule.exports = arrayMap;\n","var isSymbol = require('./isSymbol');\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/**\n * Converts `value` to a string key if it's not a string or symbol.\n *\n * @private\n * @param {*} value The value to inspect.\n * @returns {string|symbol} Returns the key.\n */\nfunction toKey(value) {\n if (typeof value == 'string' || isSymbol(value)) {\n return value;\n }\n var result = (value + '');\n return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n}\n\nmodule.exports = toKey;\n","/**\n * @welldone-software/why-did-you-render 7.0.1\n * MIT Licensed\n * Generated by Vitali Zaidman (https://github.com/vzaidman)\n * Generated at 2022-04-04\n */\n\n(function (global, factory) {\n typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory(require('react'), require('lodash')) :\n typeof define === 'function' && define.amd ? define(['react', 'lodash'], factory) :\n (global = typeof globalThis !== 'undefined' ? globalThis : global || self, global.whyDidYouRender = factory(global.react, global.lodash));\n})(this, (function (React, lodash) { 'use strict';\n\n function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\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 () { return e[k]; }\n });\n }\n });\n }\n n[\"default\"] = e;\n return Object.freeze(n);\n }\n\n var React__default = /*#__PURE__*/_interopDefaultLegacy(React);\n var React__namespace = /*#__PURE__*/_interopNamespace(React);\n\n var wdyrStore = {\n /* The React object we patch */\n React: undefined,\n\n /* Processed user options for WDYR */\n options: undefined,\n\n /* The original React.createElement function */\n origCreateElement: undefined,\n\n /* The original React.createFactory function */\n origCreateFactory: undefined,\n\n /* The original React.cloneElement function */\n origCloneElement: undefined,\n\n /* A weak map of all React elements to their WDYR patched react elements */\n componentsMap: new WeakMap(),\n\n /* A weak map of props to the owner element that passed them */\n ownerDataMap: new WeakMap(),\n\n /* An array of hooks tracked during one render */\n hooksPerRender: []\n };\n\n function ownKeys(object, enumerableOnly) {\n var keys = Object.keys(object);\n\n if (Object.getOwnPropertySymbols) {\n var symbols = Object.getOwnPropertySymbols(object);\n enumerableOnly && (symbols = symbols.filter(function (sym) {\n return Object.getOwnPropertyDescriptor(object, sym).enumerable;\n })), keys.push.apply(keys, symbols);\n }\n\n return keys;\n }\n\n function _objectSpread2(target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = null != arguments[i] ? arguments[i] : {};\n i % 2 ? ownKeys(Object(source), !0).forEach(function (key) {\n _defineProperty(target, key, source[key]);\n }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) {\n Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));\n });\n }\n\n return target;\n }\n\n function _typeof(obj) {\n \"@babel/helpers - typeof\";\n\n return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) {\n return typeof obj;\n } : function (obj) {\n return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n }, _typeof(obj);\n }\n\n function _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n }\n\n function _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n }\n\n function _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n Object.defineProperty(Constructor, \"prototype\", {\n writable: false\n });\n return Constructor;\n }\n\n function _defineProperty(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n\n return obj;\n }\n\n function _inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n writable: true,\n configurable: true\n }\n });\n Object.defineProperty(subClass, \"prototype\", {\n writable: false\n });\n if (superClass) _setPrototypeOf(subClass, superClass);\n }\n\n function _getPrototypeOf(o) {\n _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) {\n return o.__proto__ || Object.getPrototypeOf(o);\n };\n return _getPrototypeOf(o);\n }\n\n function _setPrototypeOf(o, p) {\n _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n };\n\n return _setPrototypeOf(o, p);\n }\n\n function _isNativeReflectConstruct() {\n if (typeof Reflect === \"undefined\" || !Reflect.construct) return false;\n if (Reflect.construct.sham) return false;\n if (typeof Proxy === \"function\") return true;\n\n try {\n Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {}));\n return true;\n } catch (e) {\n return false;\n }\n }\n\n function _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n\n return self;\n }\n\n function _possibleConstructorReturn(self, call) {\n if (call && (typeof call === \"object\" || typeof call === \"function\")) {\n return call;\n } else if (call !== void 0) {\n throw new TypeError(\"Derived constructors may only return object or undefined\");\n }\n\n return _assertThisInitialized(self);\n }\n\n function _createSuper(Derived) {\n var hasNativeReflectConstruct = _isNativeReflectConstruct();\n\n return function _createSuperInternal() {\n var Super = _getPrototypeOf(Derived),\n result;\n\n if (hasNativeReflectConstruct) {\n var NewTarget = _getPrototypeOf(this).constructor;\n\n result = Reflect.construct(Super, arguments, NewTarget);\n } else {\n result = Super.apply(this, arguments);\n }\n\n return _possibleConstructorReturn(this, result);\n };\n }\n\n function _superPropBase(object, property) {\n while (!Object.prototype.hasOwnProperty.call(object, property)) {\n object = _getPrototypeOf(object);\n if (object === null) break;\n }\n\n return object;\n }\n\n function _get() {\n if (typeof Reflect !== \"undefined\" && Reflect.get) {\n _get = Reflect.get;\n } else {\n _get = function _get(target, property, receiver) {\n var base = _superPropBase(target, property);\n\n if (!base) return;\n var desc = Object.getOwnPropertyDescriptor(base, property);\n\n if (desc.get) {\n return desc.get.call(arguments.length < 3 ? target : receiver);\n }\n\n return desc.value;\n };\n }\n\n return _get.apply(this, arguments);\n }\n\n function _slicedToArray(arr, i) {\n return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest();\n }\n\n function _toConsumableArray(arr) {\n return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread();\n }\n\n function _arrayWithoutHoles(arr) {\n if (Array.isArray(arr)) return _arrayLikeToArray(arr);\n }\n\n function _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n }\n\n function _iterableToArray(iter) {\n if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter);\n }\n\n function _iterableToArrayLimit(arr, i) {\n var _i = arr == null ? null : typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"];\n\n if (_i == null) return;\n var _arr = [];\n var _n = true;\n var _d = false;\n\n var _s, _e;\n\n try {\n for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) {\n _arr.push(_s.value);\n\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally {\n try {\n if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n } finally {\n if (_d) throw _e;\n }\n }\n\n return _arr;\n }\n\n function _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return _arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);\n }\n\n function _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n\n for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];\n\n return arr2;\n }\n\n function _nonIterableSpread() {\n throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n }\n\n function _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n }\n\n function _createForOfIteratorHelper(o, allowArrayLike) {\n var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"];\n\n if (!it) {\n if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") {\n if (it) o = it;\n var i = 0;\n\n var F = function () {};\n\n return {\n s: F,\n n: function () {\n if (i >= o.length) return {\n done: true\n };\n return {\n done: false,\n value: o[i++]\n };\n },\n e: function (e) {\n throw e;\n },\n f: F\n };\n }\n\n throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n }\n\n var normalCompletion = true,\n didErr = false,\n err;\n return {\n s: function () {\n it = it.call(o);\n },\n n: function () {\n var step = it.next();\n normalCompletion = step.done;\n return step;\n },\n e: function (e) {\n didErr = true;\n err = e;\n },\n f: function () {\n try {\n if (!normalCompletion && it.return != null) it.return();\n } finally {\n if (didErr) throw err;\n }\n }\n };\n }\n\n var _diffTypesDescription;\n var diffTypes = {\n 'different': 'different',\n 'deepEquals': 'deepEquals',\n 'date': 'date',\n 'regex': 'regex',\n 'reactElement': 'reactElement',\n 'function': 'function',\n 'same': 'same'\n };\n var diffTypesDescriptions = (_diffTypesDescription = {}, _defineProperty(_diffTypesDescription, diffTypes.different, 'different objects'), _defineProperty(_diffTypesDescription, diffTypes.deepEquals, 'different objects that are equal by value'), _defineProperty(_diffTypesDescription, diffTypes.date, 'different date objects with the same value'), _defineProperty(_diffTypesDescription, diffTypes.regex, 'different regular expressions with the same value'), _defineProperty(_diffTypesDescription, diffTypes.reactElement, 'different React elements (remember that the syntax always produces a *NEW* immutable React element so a component that receives as props always re-renders)'), _defineProperty(_diffTypesDescription, diffTypes[\"function\"], 'different functions with the same name'), _defineProperty(_diffTypesDescription, diffTypes.same, 'same objects by ref (===)'), _diffTypesDescription); // copied from packages/shared/ReactSymbols.js in https://github.com/facebook/react\n\n var hasSymbol$1 = typeof Symbol === 'function' && Symbol[\"for\"];\n var REACT_MEMO_TYPE = hasSymbol$1 ? Symbol[\"for\"]('react.memo') : 0xead3;\n var REACT_FORWARD_REF_TYPE = hasSymbol$1 ? Symbol[\"for\"]('react.forward_ref') : 0xead0;\n var REACT_VERSION = Number(React__default[\"default\"].version.split('.')[0]) || 0;\n var REACT_STRICT_MODE = REACT_VERSION >= 18 ? 8 : 1;\n\n var hasElementType = typeof Element !== 'undefined'; // copied from https://github.com/facebook/react/packages/shared/ReactSymbols.js\n\n var hasSymbol = typeof Symbol === 'function' && Symbol[\"for\"];\n var REACT_ELEMENT_TYPE = hasSymbol ? Symbol[\"for\"]('react.element') : 0xeac7;\n\n var isReactElement = function isReactElement(object) {\n return object.$$typeof === REACT_ELEMENT_TYPE;\n }; // end\n\n\n function trackDiff(a, b, diffsAccumulator, pathString, diffType) {\n diffsAccumulator.push({\n diffType: diffType,\n pathString: pathString,\n prevValue: a,\n nextValue: b\n });\n return diffType !== diffTypes.different;\n }\n\n function isGetter(obj, prop) {\n return !!Object.getOwnPropertyDescriptor(obj, prop)['get'];\n }\n\n var dependenciesMap = new WeakMap();\n\n function accumulateDeepEqualDiffs(a, b, diffsAccumulator) {\n var pathString = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : '';\n\n var _ref = arguments.length > 4 ? arguments[4] : undefined,\n detailed = _ref.detailed;\n\n if (a === b) {\n if (detailed) {\n trackDiff(a, b, diffsAccumulator, pathString, diffTypes.same);\n }\n\n return true;\n }\n\n if (!a || !b) {\n return trackDiff(a, b, diffsAccumulator, pathString, diffTypes.different);\n }\n\n if (lodash.isArray(a) && lodash.isArray(b)) {\n var arrayLength = a.length;\n\n if (arrayLength !== b.length) {\n return trackDiff(_toConsumableArray(a), _toConsumableArray(b), diffsAccumulator, pathString, diffTypes.different);\n }\n\n var arrayItemDiffs = [];\n var numberOfDeepEqualsItems = 0;\n\n for (var i = arrayLength; i--; i > 0) {\n var diffEquals = accumulateDeepEqualDiffs(a[i], b[i], arrayItemDiffs, \"\".concat(pathString, \"[\").concat(i, \"]\"), {\n detailed: detailed\n });\n\n if (diffEquals) {\n numberOfDeepEqualsItems++;\n }\n }\n\n if (detailed || numberOfDeepEqualsItems !== arrayLength) {\n diffsAccumulator.push.apply(diffsAccumulator, arrayItemDiffs);\n }\n\n if (numberOfDeepEqualsItems === arrayLength) {\n return trackDiff(_toConsumableArray(a), _toConsumableArray(b), diffsAccumulator, pathString, diffTypes.deepEquals);\n }\n\n return trackDiff(_toConsumableArray(a), _toConsumableArray(b), diffsAccumulator, pathString, diffTypes.different);\n }\n\n if (lodash.isSet(a) && lodash.isSet(b)) {\n if (a.size !== b.size) {\n return trackDiff(new Set(a), new Set(b), diffsAccumulator, pathString, diffTypes.different);\n }\n\n var _iterator = _createForOfIteratorHelper(a),\n _step;\n\n try {\n for (_iterator.s(); !(_step = _iterator.n()).done;) {\n var valA = _step.value;\n\n if (!b.has(valA)) {\n return trackDiff(new Set(a), new Set(b), diffsAccumulator, pathString, diffTypes.different);\n }\n }\n } catch (err) {\n _iterator.e(err);\n } finally {\n _iterator.f();\n }\n\n return trackDiff(new Set(a), new Set(b), diffsAccumulator, pathString, diffTypes.deepEquals);\n }\n\n if (lodash.isDate(a) && lodash.isDate(b)) {\n return a.getTime() === b.getTime() ? trackDiff(new Date(a), new Date(b), diffsAccumulator, pathString, diffTypes.date) : trackDiff(new Date(a), new Date(b), diffsAccumulator, pathString, diffTypes.different);\n }\n\n if (lodash.isRegExp(a) && lodash.isRegExp(b)) {\n return a.toString() === b.toString() ? trackDiff(a, b, diffsAccumulator, pathString, diffTypes.regex) : trackDiff(a, b, diffsAccumulator, pathString, diffTypes.different);\n }\n\n if (hasElementType && a instanceof Element && b instanceof Element) {\n return trackDiff(a, b, diffsAccumulator, pathString, diffTypes.different);\n }\n\n if (isReactElement(a) && isReactElement(b)) {\n if (a.type !== b.type) {\n return trackDiff(a, b, diffsAccumulator, pathString, diffTypes.different);\n }\n\n var reactElementPropsAreDeepEqual = accumulateDeepEqualDiffs(a.props, b.props, [], \"\".concat(pathString, \".props\"), {\n detailed: detailed\n });\n return reactElementPropsAreDeepEqual ? trackDiff(a, b, diffsAccumulator, pathString, diffTypes.reactElement) : trackDiff(a, b, diffsAccumulator, pathString, diffTypes.different);\n }\n\n if (lodash.isFunction(a) && lodash.isFunction(b)) {\n if (a.name !== b.name) {\n return trackDiff(a, b, diffsAccumulator, pathString, diffTypes.different);\n }\n\n var aDependenciesObj = dependenciesMap.get(a);\n var bDependenciesObj = dependenciesMap.get(b);\n\n if (aDependenciesObj && bDependenciesObj) {\n var dependenciesAreDeepEqual = accumulateDeepEqualDiffs(aDependenciesObj.deps, bDependenciesObj.deps, diffsAccumulator, \"\".concat(pathString, \":parent-hook-\").concat(aDependenciesObj.hookName, \"-deps\"), {\n detailed: detailed\n });\n return dependenciesAreDeepEqual ? trackDiff(a, b, diffsAccumulator, pathString, diffTypes[\"function\"]) : trackDiff(a, b, diffsAccumulator, pathString, diffTypes.different);\n }\n\n return trackDiff(a, b, diffsAccumulator, pathString, diffTypes[\"function\"]);\n }\n\n if (_typeof(a) === 'object' && _typeof(b) === 'object' && Object.getPrototypeOf(a) === Object.getPrototypeOf(b)) {\n var aKeys = Object.getOwnPropertyNames(a);\n var bKeys = Object.getOwnPropertyNames(b);\n var allKeys = lodash.uniq([].concat(_toConsumableArray(aKeys), _toConsumableArray(bKeys)));\n var clonedA = lodash.isPlainObject(a) ? _objectSpread2({}, a) : a;\n var clonedB = lodash.isPlainObject(b) ? _objectSpread2({}, b) : b;\n\n if (allKeys.length !== aKeys.length || allKeys.length !== bKeys.length) {\n return trackDiff(clonedA, clonedB, diffsAccumulator, pathString, diffTypes.different);\n }\n\n var relevantKeys = allKeys.filter(function (key) {\n // do not compare the stack as it differ even though the errors are identical.\n if (key === 'stack' && lodash.isError(a)) {\n return false;\n } // getters checking is causing too much problems because of how it's used in js.\n // not only getters can throw errors, they also cause side effects in many cases.\n\n\n if (isGetter(a, key)) {\n return false;\n }\n\n return true;\n });\n var keysLength = relevantKeys.length;\n\n for (var _i = keysLength; _i--; _i > 0) {\n if (!lodash.has(b, relevantKeys[_i])) {\n return trackDiff(clonedA, clonedB, diffsAccumulator, pathString, diffTypes.different);\n }\n }\n\n var objectValuesDiffs = [];\n var numberOfDeepEqualsObjectValues = 0;\n\n for (var _i2 = keysLength; _i2--; _i2 > 0) {\n var key = relevantKeys[_i2];\n var deepEquals = accumulateDeepEqualDiffs(a[key], b[key], objectValuesDiffs, \"\".concat(pathString, \".\").concat(key), {\n detailed: detailed\n });\n\n if (deepEquals) {\n numberOfDeepEqualsObjectValues++;\n }\n }\n\n if (detailed || numberOfDeepEqualsObjectValues !== keysLength) {\n diffsAccumulator.push.apply(diffsAccumulator, objectValuesDiffs);\n }\n\n if (numberOfDeepEqualsObjectValues === keysLength) {\n return trackDiff(clonedA, clonedB, diffsAccumulator, pathString, diffTypes.deepEquals);\n }\n\n return trackDiff(clonedA, clonedB, diffsAccumulator, pathString, diffTypes.different);\n }\n\n return trackDiff(a, b, diffsAccumulator, pathString, diffTypes.different);\n }\n\n function calculateDeepEqualDiffs(a, b, initialPathString) {\n var _ref2 = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {},\n _ref2$detailed = _ref2.detailed,\n detailed = _ref2$detailed === void 0 ? false : _ref2$detailed;\n\n try {\n var diffs = [];\n accumulateDeepEqualDiffs(a, b, diffs, initialPathString, {\n detailed: detailed\n });\n return diffs;\n } catch (error) {\n if (error.message && error.message.match(/stack|recursion/i) || error.number === -2146828260) {\n // warn on circular references, don't crash.\n // browsers throw different errors name and messages:\n // chrome/safari: \"RangeError\", \"Maximum call stack size exceeded\"\n // firefox: \"InternalError\", too much recursion\"\n // edge: \"Error\", \"Out of stack space\"\n // eslint-disable-next-line no-console\n console.warn('Warning: why-did-you-render couldn\\'t handle circular references in props.', error.name, error.message);\n return false;\n }\n\n throw error;\n }\n }\n\n function printDiff(value1, value2, _ref) {\n var pathString = _ref.pathString,\n consoleLog = _ref.consoleLog;\n var diffs = calculateDeepEqualDiffs(value1, value2, pathString, {\n detailed: true\n });\n var keysLength = Math.max.apply(Math, _toConsumableArray(diffs.map(function (diff) {\n return diff.pathString.length;\n }))) + 2;\n Object.entries(lodash.groupBy(lodash.sortBy(diffs, 'pathString'), 'diffType')).forEach(function (_ref2) {\n var _ref3 = _slicedToArray(_ref2, 2),\n diffType = _ref3[0],\n diffs = _ref3[1];\n\n consoleLog(\"%c\".concat(diffTypesDescriptions[diffType], \":\"), 'text-decoration: underline; color: blue;');\n diffs.forEach(function (diff) {\n consoleLog(\"\".concat(diff.pathString, \":\").padEnd(keysLength, ' '), diff.prevValue);\n });\n });\n }\n\n var moreInfoUrl = 'http://bit.ly/wdyr02';\n var moreInfoHooksUrl = 'http://bit.ly/wdyr3';\n var inHotReload = false;\n\n function shouldLog(reason, Component) {\n if (inHotReload) {\n return false;\n }\n\n if (wdyrStore.options.logOnDifferentValues) {\n return true;\n }\n\n if (Component.whyDidYouRender && Component.whyDidYouRender.logOnDifferentValues) {\n return true;\n }\n\n var hasDifferentValues = reason.propsDifferences && reason.propsDifferences.some(function (diff) {\n return diff.diffType === diffTypes.different;\n }) || reason.stateDifferences && reason.stateDifferences.some(function (diff) {\n return diff.diffType === diffTypes.different;\n }) || reason.hookDifferences && reason.hookDifferences.some(function (diff) {\n return diff.diffType === diffTypes.different;\n });\n return !hasDifferentValues;\n }\n\n function logDifference(_ref) {\n var Component = _ref.Component,\n displayName = _ref.displayName,\n hookName = _ref.hookName,\n prefixMessage = _ref.prefixMessage,\n diffObjType = _ref.diffObjType,\n differences = _ref.differences,\n values = _ref.values;\n\n if (differences && differences.length > 0) {\n wdyrStore.options.consoleLog(_defineProperty({}, displayName, Component), \"\".concat(prefixMessage, \" of \").concat(diffObjType, \" changes:\"));\n differences.forEach(function (_ref2) {\n var pathString = _ref2.pathString,\n diffType = _ref2.diffType,\n prevValue = _ref2.prevValue,\n nextValue = _ref2.nextValue;\n\n function diffFn() {\n printDiff(prevValue, nextValue, {\n pathString: pathString,\n consoleLog: wdyrStore.options.consoleLog\n });\n }\n\n wdyrStore.options.consoleGroup(\"%c\".concat(diffObjType === 'hook' ? \"[hook \".concat(hookName, \" result]\") : \"\".concat(diffObjType, \".\"), \"%c\").concat(pathString, \"%c\"), \"color:\".concat(wdyrStore.options.diffNameColor, \";\"), \"color:\".concat(wdyrStore.options.diffPathColor, \";\"), 'color:default;');\n wdyrStore.options.consoleLog(\"\".concat(diffTypesDescriptions[diffType], \". (more info at \").concat(hookName ? moreInfoHooksUrl : moreInfoUrl, \")\"));\n wdyrStore.options.consoleLog(_defineProperty({}, \"prev \".concat(pathString), prevValue), '!==', _defineProperty({}, \"next \".concat(pathString), nextValue));\n\n if (diffType === diffTypes.deepEquals) {\n wdyrStore.options.consoleLog({\n 'For detailed diff, right click the following fn, save as global, and run: ': diffFn\n });\n }\n\n wdyrStore.options.consoleGroupEnd();\n });\n } else if (differences) {\n wdyrStore.options.consoleLog(_defineProperty({}, displayName, Component), \"\".concat(prefixMessage, \" the \").concat(diffObjType, \" object itself changed but its values are all equal.\"), diffObjType === 'props' ? 'This could have been avoided by making the component pure, or by preventing its father from re-rendering.' : 'This usually means this component called setState when no changes in its state actually occurred.', \"More info at \".concat(moreInfoUrl));\n wdyrStore.options.consoleLog(\"prev \".concat(diffObjType, \":\"), values.prev, ' !== ', values.next, \":next \".concat(diffObjType));\n }\n }\n\n function defaultNotifier(updateInfo) {\n var Component = updateInfo.Component,\n displayName = updateInfo.displayName,\n hookName = updateInfo.hookName,\n prevProps = updateInfo.prevProps,\n prevState = updateInfo.prevState,\n prevHook = updateInfo.prevHook,\n nextProps = updateInfo.nextProps,\n nextState = updateInfo.nextState,\n nextHook = updateInfo.nextHook,\n reason = updateInfo.reason;\n\n if (!shouldLog(reason, Component, wdyrStore.options)) {\n return;\n }\n\n wdyrStore.options.consoleGroup(\"%c\".concat(displayName), \"color: \".concat(wdyrStore.options.titleColor, \";\"));\n var prefixMessage = 'Re-rendered because';\n\n if (reason.propsDifferences) {\n logDifference({\n Component: Component,\n displayName: displayName,\n prefixMessage: prefixMessage,\n diffObjType: 'props',\n differences: reason.propsDifferences,\n values: {\n prev: prevProps,\n next: nextProps\n }\n });\n prefixMessage = 'And because';\n }\n\n if (reason.stateDifferences) {\n logDifference({\n Component: Component,\n displayName: displayName,\n prefixMessage: prefixMessage,\n diffObjType: 'state',\n differences: reason.stateDifferences,\n values: {\n prev: prevState,\n next: nextState\n }\n });\n }\n\n if (reason.hookDifferences) {\n logDifference({\n Component: Component,\n displayName: displayName,\n prefixMessage: prefixMessage,\n diffObjType: 'hook',\n differences: reason.hookDifferences,\n values: {\n prev: prevHook,\n next: nextHook\n },\n hookName: hookName\n });\n }\n\n if (reason.propsDifferences && reason.ownerDifferences) {\n var prevOwnerData = wdyrStore.ownerDataMap.get(prevProps);\n var nextOwnerData = wdyrStore.ownerDataMap.get(nextProps);\n wdyrStore.options.consoleGroup(\"Rendered by \".concat(nextOwnerData.displayName));\n var _prefixMessage = 'Re-rendered because';\n\n if (reason.ownerDifferences.propsDifferences) {\n logDifference({\n Component: nextOwnerData.Component,\n displayName: nextOwnerData.displayName,\n prefixMessage: _prefixMessage,\n diffObjType: 'props',\n differences: reason.ownerDifferences.propsDifferences,\n values: {\n prev: prevOwnerData.props,\n next: nextOwnerData.props\n }\n });\n _prefixMessage = 'And because';\n }\n\n if (reason.ownerDifferences.stateDifferences) {\n logDifference({\n Component: nextOwnerData.Component,\n displayName: nextOwnerData.displayName,\n prefixMessage: _prefixMessage,\n diffObjType: 'state',\n differences: reason.ownerDifferences.stateDifferences,\n values: {\n prev: prevOwnerData.state,\n next: nextOwnerData.state\n }\n });\n }\n\n if (reason.ownerDifferences.hookDifferences) {\n reason.ownerDifferences.hookDifferences.forEach(function (_ref3, i) {\n var hookName = _ref3.hookName,\n differences = _ref3.differences;\n return logDifference({\n Component: nextOwnerData.Component,\n displayName: nextOwnerData.displayName,\n prefixMessage: _prefixMessage,\n diffObjType: 'hook',\n differences: differences,\n values: {\n prev: prevOwnerData.hooks[i].result,\n next: nextOwnerData.hooks[i].result\n },\n hookName: hookName\n });\n });\n }\n\n wdyrStore.options.consoleGroupEnd();\n }\n\n if (!reason.propsDifferences && !reason.stateDifferences && !reason.hookDifferences) {\n wdyrStore.options.consoleLog(_defineProperty({}, displayName, Component), 'Re-rendered although props and state objects are the same.', 'This usually means there was a call to this.forceUpdate() inside the component.', \"more info at \".concat(moreInfoUrl));\n }\n\n wdyrStore.options.consoleGroupEnd();\n }\n function createDefaultNotifier(hotReloadBufferMs) {\n if (hotReloadBufferMs) {\n if (typeof module !== 'undefined' && module.hot && module.hot.addStatusHandler) {\n module.hot.addStatusHandler(function (status) {\n if (status === 'idle') {\n inHotReload = true;\n setTimeout(function () {\n inHotReload = false;\n }, hotReloadBufferMs);\n }\n });\n }\n }\n\n return defaultNotifier;\n }\n\n var emptyFn = function emptyFn() {};\n\n function normalizeOptions() {\n var userOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n var consoleGroup = console.group;\n var consoleGroupEnd = console.groupEnd;\n\n if (userOptions.collapseGroups) {\n consoleGroup = console.groupCollapsed;\n } else if (userOptions.onlyLogs) {\n consoleGroup = console.log;\n consoleGroupEnd = emptyFn;\n }\n\n var notifier = userOptions.notifier || createDefaultNotifier('hotReloadBufferMs' in userOptions ? userOptions.hotReloadBufferMs : 500);\n return _objectSpread2({\n include: null,\n exclude: null,\n notifier: notifier,\n onlyLogs: false,\n consoleLog: console.log,\n consoleGroup: consoleGroup,\n consoleGroupEnd: consoleGroupEnd,\n logOnDifferentValues: false,\n logOwnerReasons: true,\n trackHooks: true,\n titleColor: '#058',\n diffNameColor: 'blue',\n diffPathColor: 'red',\n trackExtraHooks: [],\n trackAllPureComponents: false\n }, userOptions);\n }\n\n function getDisplayName(type) {\n return type.displayName || type.name || type.type && getDisplayName(type.type) || type.render && getDisplayName(type.render) || (lodash.isString(type) ? type : 'Unknown');\n }\n\n function getDefaultProps(type) {\n return type.defaultProps || type.type && getDefaultProps(type.type) || type.render && getDefaultProps(type.render) || {};\n }\n\n var emptyObject = {};\n function findObjectsDifferences(userPrevObj, userNextObj) {\n var _ref = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {},\n _ref$shallow = _ref.shallow,\n shallow = _ref$shallow === void 0 ? true : _ref$shallow;\n\n if (userPrevObj === userNextObj) {\n return false;\n }\n\n if (!shallow) {\n return calculateDeepEqualDiffs(userPrevObj, userNextObj);\n }\n\n var prevObj = userPrevObj || emptyObject;\n var nextObj = userNextObj || emptyObject;\n var keysOfBothObjects = Object.keys(_objectSpread2(_objectSpread2({}, prevObj), nextObj));\n return lodash.reduce(keysOfBothObjects, function (result, key) {\n var deepEqualDiffs = calculateDeepEqualDiffs(prevObj[key], nextObj[key], key);\n\n if (deepEqualDiffs) {\n result = [].concat(_toConsumableArray(result), _toConsumableArray(deepEqualDiffs));\n }\n\n return result;\n }, []);\n }\n\n function getOwnerDifferences(_ref) {\n var prevOwnerData = _ref.prevOwnerData,\n nextOwnerData = _ref.nextOwnerData;\n\n if (!prevOwnerData || !nextOwnerData) {\n return false;\n } // in strict mode prevOwnerData might be twice as lengthy because of double renders\n\n\n var prevOwnerDataHooks = prevOwnerData.hooks.length === nextOwnerData.hooks.length * 2 ? prevOwnerData.hooks.slice(prevOwnerData.hooks.length / 2) : prevOwnerData.hooks;\n var hookDifferences = prevOwnerDataHooks.map(function (_ref2, i) {\n var hookName = _ref2.hookName,\n result = _ref2.result;\n return {\n hookName: hookName,\n differences: findObjectsDifferences(result, nextOwnerData.hooks[i].result, {\n shallow: false\n })\n };\n });\n return {\n propsDifferences: findObjectsDifferences(prevOwnerData.props, nextOwnerData.props),\n stateDifferences: findObjectsDifferences(prevOwnerData.state, nextOwnerData.state),\n hookDifferences: hookDifferences.length > 0 ? hookDifferences : false\n };\n }\n\n function getUpdateReason(prevProps, prevState, prevHook, nextProps, nextState, nextHook) {\n var prevOwnerData = wdyrStore.ownerDataMap.get(prevProps);\n var nextOwnerData = wdyrStore.ownerDataMap.get(nextProps);\n return {\n propsDifferences: findObjectsDifferences(prevProps, nextProps),\n stateDifferences: findObjectsDifferences(prevState, nextState),\n hookDifferences: findObjectsDifferences(prevHook, nextHook, {\n shallow: false\n }),\n ownerDifferences: getOwnerDifferences({\n prevOwnerData: prevOwnerData,\n nextOwnerData: nextOwnerData\n })\n };\n }\n\n function getUpdateInfo(_ref3) {\n var Component = _ref3.Component,\n displayName = _ref3.displayName,\n hookName = _ref3.hookName,\n prevProps = _ref3.prevProps,\n prevState = _ref3.prevState,\n prevHook = _ref3.prevHook,\n nextProps = _ref3.nextProps,\n nextState = _ref3.nextState,\n nextHook = _ref3.nextHook;\n return {\n Component: Component,\n displayName: displayName,\n hookName: hookName,\n prevProps: prevProps,\n prevState: prevState,\n prevHook: prevHook,\n nextProps: nextProps,\n nextState: nextState,\n nextHook: nextHook,\n reason: getUpdateReason(prevProps, prevState, prevHook, nextProps, nextState, nextHook)\n };\n }\n\n // copied from https://github.com/facebook/react/blob/master/packages/react-reconciler/src/ReactTypeOfMode.js\n // notice: this is only used for class components. functional components doesn't render twice inside strict mode\n\n function checkIfInsideAStrictModeTree(reactComponentInstance) {\n var reactInternalFiber = reactComponentInstance && (reactComponentInstance._reactInternalFiber || reactComponentInstance._reactInternals);\n\n while (reactInternalFiber) {\n if (reactInternalFiber.mode & REACT_STRICT_MODE) {\n return true;\n }\n\n reactInternalFiber = reactInternalFiber[\"return\"];\n }\n\n return false;\n }\n function isReactClassComponent(Component) {\n return Component.prototype && !!Component.prototype.isReactComponent;\n }\n function isMemoComponent(Component) {\n return Component.$$typeof === REACT_MEMO_TYPE;\n }\n function isForwardRefComponent(Component) {\n return Component.$$typeof === REACT_FORWARD_REF_TYPE;\n }\n\n function shouldInclude(displayName) {\n return wdyrStore.options.include && wdyrStore.options.include.length > 0 && wdyrStore.options.include.some(function (regex) {\n return regex.test(displayName);\n });\n }\n\n function shouldExclude(displayName) {\n return wdyrStore.options.exclude && wdyrStore.options.exclude.length > 0 && wdyrStore.options.exclude.some(function (regex) {\n return regex.test(displayName);\n });\n }\n\n function shouldTrack(Component, _ref) {\n var isHookChange = _ref.isHookChange;\n var displayName = getDisplayName(Component);\n\n if (shouldExclude(displayName)) {\n return false;\n }\n\n if (Component.whyDidYouRender === false) {\n return false;\n }\n\n if (isHookChange && Component.whyDidYouRender && Component.whyDidYouRender.trackHooks === false) {\n return false;\n }\n\n return !!(Component.whyDidYouRender || wdyrStore.options.trackAllPureComponents && (Component && Component.prototype instanceof wdyrStore.React.PureComponent || isMemoComponent(Component)) || shouldInclude(displayName));\n }\n\n function patchClassComponent(ClassComponent, _ref) {\n var displayName = _ref.displayName,\n defaultProps = _ref.defaultProps;\n\n var WDYRPatchedClassComponent = /*#__PURE__*/function (_ClassComponent) {\n _inherits(WDYRPatchedClassComponent, _ClassComponent);\n\n var _super = _createSuper(WDYRPatchedClassComponent);\n\n function WDYRPatchedClassComponent(props, context) {\n var _thisSuper, _this;\n\n _classCallCheck(this, WDYRPatchedClassComponent);\n\n _this = _super.call(this, props, context);\n _this._WDYR = {\n renderNumber: 0\n };\n\n var origRender = _get((_thisSuper = _assertThisInitialized(_this), _getPrototypeOf(WDYRPatchedClassComponent.prototype)), \"render\", _thisSuper) || _this.render; // this probably means that render is an arrow function or this.render.bind(this) was called on the original class\n\n\n var renderIsABindedFunction = origRender !== ClassComponent.prototype.render;\n\n if (renderIsABindedFunction) {\n _this.render = function () {\n WDYRPatchedClassComponent.prototype.render.apply(_assertThisInitialized(_this));\n return origRender();\n };\n }\n\n return _this;\n }\n\n _createClass(WDYRPatchedClassComponent, [{\n key: \"render\",\n value: function render() {\n this._WDYR.renderNumber++;\n\n if (!('isStrictMode' in this._WDYR)) {\n this._WDYR.isStrictMode = checkIfInsideAStrictModeTree(this);\n } // in strict mode- ignore every other render\n\n\n if (!(this._WDYR.isStrictMode && this._WDYR.renderNumber % 2 === 1)) {\n if (this._WDYR.prevProps) {\n var updateInfo = getUpdateInfo({\n Component: ClassComponent,\n displayName: displayName,\n prevProps: this._WDYR.prevProps,\n prevState: this._WDYR.prevState,\n nextProps: this.props,\n nextState: this.state\n });\n wdyrStore.options.notifier(updateInfo);\n }\n\n this._WDYR.prevProps = this.props;\n this._WDYR.prevState = this.state;\n }\n\n return _get(_getPrototypeOf(WDYRPatchedClassComponent.prototype), \"render\", this) ? _get(_getPrototypeOf(WDYRPatchedClassComponent.prototype), \"render\", this).call(this) : null;\n }\n }]);\n\n return WDYRPatchedClassComponent;\n }(ClassComponent);\n\n try {\n WDYRPatchedClassComponent.displayName = displayName;\n } catch (e) {// not crucial if displayName couldn't be set\n }\n\n WDYRPatchedClassComponent.defaultProps = defaultProps;\n lodash.defaults(WDYRPatchedClassComponent, ClassComponent);\n return WDYRPatchedClassComponent;\n }\n\n var getFunctionalComponentFromStringComponent = function getFunctionalComponentFromStringComponent(componentTypeStr) {\n return function (props) {\n return wdyrStore.React.createElement(componentTypeStr, props);\n };\n };\n\n function patchFunctionalOrStrComponent(FunctionalOrStringComponent, _ref) {\n var isPure = _ref.isPure,\n displayName = _ref.displayName,\n defaultProps = _ref.defaultProps;\n var FunctionalComponent = typeof FunctionalOrStringComponent === 'string' ? getFunctionalComponentFromStringComponent(FunctionalOrStringComponent) : FunctionalOrStringComponent;\n\n function WDYRFunctionalComponent() {\n var nextProps = arguments[0];\n var ref = wdyrStore.React.useRef();\n var prevProps = ref.current;\n ref.current = nextProps;\n\n if (prevProps) {\n var updateInfo = getUpdateInfo({\n Component: FunctionalComponent,\n displayName: displayName,\n prevProps: prevProps,\n nextProps: nextProps\n });\n var notifiedByHooks = !updateInfo.reason.propsDifferences || isPure && updateInfo.reason.propsDifferences.length === 0;\n\n if (!notifiedByHooks) {\n wdyrStore.options.notifier(updateInfo);\n }\n }\n\n return FunctionalComponent.apply(void 0, arguments);\n }\n\n try {\n WDYRFunctionalComponent.displayName = displayName;\n } catch (e) {// not crucial if displayName couldn't be set\n }\n\n WDYRFunctionalComponent.defaultProps = defaultProps;\n WDYRFunctionalComponent.ComponentForHooksTracking = FunctionalComponent;\n lodash.defaults(WDYRFunctionalComponent, FunctionalComponent);\n return WDYRFunctionalComponent;\n }\n\n function patchMemoComponent(MemoComponent, _ref) {\n var displayName = _ref.displayName,\n defaultProps = _ref.defaultProps;\n var InnerMemoComponent = MemoComponent.type;\n var isInnerMemoComponentAClassComponent = isReactClassComponent(InnerMemoComponent);\n var isInnerMemoComponentForwardRefs = isForwardRefComponent(InnerMemoComponent);\n var isInnerMemoComponentAnotherMemoComponent = isMemoComponent(InnerMemoComponent);\n var WrappedFunctionalComponent = isInnerMemoComponentForwardRefs ? InnerMemoComponent.render : InnerMemoComponent;\n var PatchedInnerComponent = isInnerMemoComponentAClassComponent ? patchClassComponent(WrappedFunctionalComponent, {\n displayName: displayName,\n defaultProps: defaultProps\n }) : isInnerMemoComponentAnotherMemoComponent ? patchMemoComponent(WrappedFunctionalComponent, {\n displayName: displayName,\n defaultProps: defaultProps\n }) : patchFunctionalOrStrComponent(WrappedFunctionalComponent, {\n displayName: displayName,\n isPure: true\n });\n\n try {\n PatchedInnerComponent.displayName = getDisplayName(WrappedFunctionalComponent);\n } catch (e) {// not crucial if displayName couldn't be set\n }\n\n PatchedInnerComponent.ComponentForHooksTracking = MemoComponent;\n lodash.defaults(PatchedInnerComponent, WrappedFunctionalComponent);\n var WDYRMemoizedFunctionalComponent = wdyrStore.React.memo(isInnerMemoComponentForwardRefs ? wdyrStore.React.forwardRef(PatchedInnerComponent) : PatchedInnerComponent, MemoComponent.compare);\n\n try {\n WDYRMemoizedFunctionalComponent.displayName = displayName;\n } catch (e) {// not crucial if displayName couldn't be set\n }\n\n WDYRMemoizedFunctionalComponent.defaultProps = defaultProps;\n lodash.defaults(WDYRMemoizedFunctionalComponent, MemoComponent);\n return WDYRMemoizedFunctionalComponent;\n }\n\n function patchForwardRefComponent(ForwardRefComponent, _ref) {\n var displayName = _ref.displayName,\n defaultProps = _ref.defaultProps;\n var InnerForwardRefComponent = ForwardRefComponent.render;\n var isInnerComponentMemoized = isMemoComponent(InnerForwardRefComponent);\n var WrappedFunctionalComponent = isInnerComponentMemoized ? InnerForwardRefComponent.type : InnerForwardRefComponent;\n var WDYRWrappedByReactForwardRefFunctionalComponent = patchFunctionalOrStrComponent(WrappedFunctionalComponent, {\n isPure: isInnerComponentMemoized,\n displayName: displayName\n });\n WDYRWrappedByReactForwardRefFunctionalComponent.displayName = getDisplayName(WrappedFunctionalComponent);\n WDYRWrappedByReactForwardRefFunctionalComponent.ComponentForHooksTracking = WrappedFunctionalComponent;\n lodash.defaults(WDYRWrappedByReactForwardRefFunctionalComponent, WrappedFunctionalComponent);\n var WDYRForwardRefFunctionalComponent = wdyrStore.React.forwardRef(isInnerComponentMemoized ? wdyrStore.React.memo(WDYRWrappedByReactForwardRefFunctionalComponent, InnerForwardRefComponent.compare) : WDYRWrappedByReactForwardRefFunctionalComponent);\n\n try {\n WDYRForwardRefFunctionalComponent.displayName = displayName;\n } catch (e) {// not crucial if displayName couldn't be set\n }\n\n WDYRForwardRefFunctionalComponent.defaultProps = defaultProps;\n lodash.defaults(WDYRForwardRefFunctionalComponent, ForwardRefComponent);\n return WDYRForwardRefFunctionalComponent;\n }\n\n var initialHookValue = Symbol('initial-hook-value');\n\n function trackHookChanges(hookName, _ref, hookResult) {\n var hookPath = _ref.path;\n var nextHook = hookPath ? lodash.get(hookResult, hookPath) : hookResult;\n var renderNumberForTheHook = wdyrStore.React.useRef(true); // TODO: improve\n\n var isSecondCycleOfRenders = wdyrStore.hooksPerRender[0] && wdyrStore.hooksPerRender[0].renderNumberForTheHook !== renderNumberForTheHook.current;\n\n if (isSecondCycleOfRenders) {\n wdyrStore.hooksPerRender = [];\n }\n\n wdyrStore.hooksPerRender.push({\n hookName: hookName,\n result: nextHook,\n renderNumberForTheHook: renderNumberForTheHook.current\n });\n renderNumberForTheHook.current++;\n var ComponentHookDispatchedFromInstance = wdyrStore.React.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED && wdyrStore.React.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner.current;\n var prevHookRef = wdyrStore.React.useRef(initialHookValue);\n\n if (!ComponentHookDispatchedFromInstance) {\n return hookResult;\n }\n\n var Component = ComponentHookDispatchedFromInstance.type.ComponentForHooksTracking || ComponentHookDispatchedFromInstance.type;\n var displayName = getDisplayName(Component);\n var isShouldTrack = shouldTrack(Component, {\n isHookChange: true\n });\n\n if (!isShouldTrack) {\n return hookResult;\n }\n\n var newPrevHookRef = prevHookRef.current;\n prevHookRef.current = hookResult;\n\n if (newPrevHookRef !== initialHookValue) {\n var notification = getUpdateInfo({\n Component: Component,\n displayName: displayName,\n hookName: hookName,\n prevHook: hookPath ? lodash.get(newPrevHookRef, hookPath) : newPrevHookRef,\n nextHook: nextHook\n });\n\n if (notification.reason.hookDifferences) {\n wdyrStore.options.notifier(notification);\n }\n }\n\n return hookResult;\n }\n\n function createPatchedComponent(Component, _ref2) {\n var displayName = _ref2.displayName,\n defaultProps = _ref2.defaultProps;\n\n if (isMemoComponent(Component)) {\n return patchMemoComponent(Component, {\n displayName: displayName,\n defaultProps: defaultProps\n });\n }\n\n if (isForwardRefComponent(Component)) {\n return patchForwardRefComponent(Component, {\n displayName: displayName,\n defaultProps: defaultProps\n });\n }\n\n if (isReactClassComponent(Component)) {\n return patchClassComponent(Component, {\n displayName: displayName,\n defaultProps: defaultProps\n });\n }\n\n return patchFunctionalOrStrComponent(Component, {\n displayName: displayName,\n defaultProps: defaultProps,\n isPure: false\n });\n }\n\n function getPatchedComponent(Component, _ref3) {\n var displayName = _ref3.displayName,\n defaultProps = _ref3.defaultProps;\n\n if (wdyrStore.componentsMap.has(Component)) {\n return wdyrStore.componentsMap.get(Component);\n }\n\n var WDYRPatchedComponent = createPatchedComponent(Component, {\n displayName: displayName,\n defaultProps: defaultProps\n });\n wdyrStore.componentsMap.set(Component, WDYRPatchedComponent);\n return WDYRPatchedComponent;\n }\n\n function getIsSupportedComponentType(Comp) {\n if (!Comp) {\n return false;\n }\n\n if (isMemoComponent(Comp)) {\n return getIsSupportedComponentType(Comp.type);\n }\n\n if (isForwardRefComponent(Comp)) {\n return getIsSupportedComponentType(Comp.render);\n }\n\n if (typeof Comp === 'function') {\n return true;\n }\n }\n\n var hooksConfig = {\n useState: {\n path: '0'\n },\n useReducer: {\n path: '0'\n },\n useContext: undefined,\n useMemo: {\n dependenciesPath: '1',\n dontReport: true\n },\n useCallback: {\n dependenciesPath: '1',\n dontReport: true\n }\n };\n function storeOwnerData(element) {\n var OwnerInstance = wdyrStore.React.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner.current;\n\n if (OwnerInstance) {\n var Component = OwnerInstance.type.ComponentForHooksTracking || OwnerInstance.type;\n var displayName = getDisplayName(Component);\n var additionalOwnerData = {};\n\n if (wdyrStore.options.getAdditionalOwnerData) {\n additionalOwnerData = wdyrStore.options.getAdditionalOwnerData(element);\n }\n\n wdyrStore.ownerDataMap.set(element.props, {\n Component: Component,\n displayName: displayName,\n props: OwnerInstance.pendingProps,\n state: OwnerInstance.stateNode ? OwnerInstance.stateNode.state : null,\n hooks: wdyrStore.hooksPerRender,\n additionalOwnerData: additionalOwnerData\n });\n }\n }\n\n function resetHooksPerRenderIfNeeded() {\n // Intercept assignments to ReactCurrentOwner.current to reset hooksPerRender\n var currentOwner = null;\n\n if (wdyrStore.React.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED) {\n Object.defineProperty(wdyrStore.React.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner, 'current', {\n get: function get() {\n return currentOwner;\n },\n set: function set(value) {\n currentOwner = value;\n wdyrStore.hooksPerRender = [];\n }\n });\n }\n }\n\n function trackHooksIfNeeded() {\n var hooksSupported = !!wdyrStore.React.useState;\n\n if (wdyrStore.options.trackHooks && hooksSupported) {\n var nativeHooks = Object.entries(hooksConfig).map(function (_ref4) {\n var _ref5 = _slicedToArray(_ref4, 2),\n hookName = _ref5[0],\n hookTrackingConfig = _ref5[1];\n\n return [wdyrStore.React, hookName, hookTrackingConfig];\n });\n var hooksToTrack = [].concat(_toConsumableArray(nativeHooks), _toConsumableArray(wdyrStore.options.trackExtraHooks));\n hooksToTrack.forEach(function (_ref6) {\n var _ref7 = _slicedToArray(_ref6, 3),\n hookParent = _ref7[0],\n hookName = _ref7[1],\n _ref7$ = _ref7[2],\n hookTrackingConfig = _ref7$ === void 0 ? {} : _ref7$;\n\n var originalHook = hookParent[hookName];\n var newHookName = hookName[0].toUpperCase() + hookName.slice(1);\n\n var newHook = function newHook() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n var hookResult = originalHook.call.apply(originalHook, [this].concat(args));\n var dependenciesPath = hookTrackingConfig.dependenciesPath,\n dontReport = hookTrackingConfig.dontReport;\n\n if (dependenciesPath && lodash.isFunction(hookResult)) {\n dependenciesMap.set(hookResult, {\n hookName: hookName,\n deps: lodash.get(args, dependenciesPath)\n });\n }\n\n if (!dontReport) {\n trackHookChanges(hookName, hookTrackingConfig, hookResult);\n }\n\n return hookResult;\n };\n\n Object.defineProperty(newHook, 'name', {\n value: newHookName,\n writable: false\n });\n Object.assign(newHook, {\n originalHook: originalHook\n });\n hookParent[hookName] = newHook;\n });\n }\n }\n\n function getWDYRType(origType) {\n var isShouldTrack = getIsSupportedComponentType(origType) && shouldTrack(origType, {\n isHookChange: false\n });\n\n if (!isShouldTrack) {\n return null;\n }\n\n var displayName = origType && origType.whyDidYouRender && origType.whyDidYouRender.customName || getDisplayName(origType);\n var defaultProps = getDefaultProps(origType);\n var WDYRPatchedComponent = getPatchedComponent(origType, {\n displayName: displayName,\n defaultProps: defaultProps\n });\n return WDYRPatchedComponent;\n }\n function whyDidYouRender(React, userOptions) {\n if (React.isWDYR) {\n return;\n }\n\n Object.assign(wdyrStore, {\n React: React,\n options: normalizeOptions(userOptions),\n origCreateElement: React.createElement,\n origCreateFactory: React.createFactory,\n origCloneElement: React.cloneElement,\n componentsMap: new WeakMap()\n });\n resetHooksPerRenderIfNeeded();\n\n React.createElement = function (origType) {\n var WDYRType = getWDYRType(origType);\n\n for (var _len2 = arguments.length, rest = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {\n rest[_key2 - 1] = arguments[_key2];\n }\n\n if (WDYRType) {\n try {\n var element = wdyrStore.origCreateElement.apply(React, [WDYRType].concat(rest));\n\n if (wdyrStore.options.logOwnerReasons) {\n storeOwnerData(element);\n }\n\n return element;\n } catch (e) {\n wdyrStore.options.consoleLog('whyDidYouRender error. Please file a bug at https://github.com/welldone-software/why-did-you-render/issues.', {\n errorInfo: {\n error: e,\n componentNameOrComponent: origType,\n rest: rest,\n options: wdyrStore.options\n }\n });\n }\n }\n\n return wdyrStore.origCreateElement.apply(React, [origType].concat(rest));\n };\n\n Object.assign(React.createElement, wdyrStore.origCreateElement);\n\n React.createFactory = function (type) {\n var factory = React.createElement.bind(null, type);\n factory.type = type;\n return factory;\n };\n\n Object.assign(React.createFactory, wdyrStore.origCreateFactory);\n\n React.cloneElement = function () {\n for (var _len3 = arguments.length, args = new Array(_len3), _key3 = 0; _key3 < _len3; _key3++) {\n args[_key3] = arguments[_key3];\n }\n\n var element = wdyrStore.origCloneElement.apply(React, args);\n\n if (wdyrStore.options.logOwnerReasons) {\n storeOwnerData(element);\n }\n\n return element;\n };\n\n Object.assign(React.cloneElement, wdyrStore.origCloneElement);\n trackHooksIfNeeded();\n React.isWDYR = true;\n\n React.__REVERT_WHY_DID_YOU_RENDER__ = function () {\n Object.assign(React, {\n createElement: wdyrStore.origCreateElement,\n createFactory: wdyrStore.origCreateFactory,\n cloneElement: wdyrStore.origCloneElement\n });\n wdyrStore.componentsMap = null;\n var hooksToRevert = [].concat(_toConsumableArray(Object.keys(hooksConfig).map(function (hookName) {\n return [React, hookName];\n })), _toConsumableArray(wdyrStore.options.trackExtraHooks));\n hooksToRevert.forEach(function (_ref8) {\n var _ref9 = _slicedToArray(_ref8, 2),\n hookParent = _ref9[0],\n hookName = _ref9[1];\n\n if (hookParent[hookName].originalHook) {\n hookParent[hookName] = hookParent[hookName].originalHook;\n }\n });\n delete React.__REVERT_WHY_DID_YOU_RENDER__;\n delete React.isWDYR;\n };\n\n return React;\n }\n\n whyDidYouRender.defaultNotifier = defaultNotifier;\n whyDidYouRender.wdyrStore = wdyrStore;\n whyDidYouRender.storeOwnerData = storeOwnerData;\n whyDidYouRender.getWDYRType = getWDYRType;\n Object.assign(whyDidYouRender, React__namespace);\n\n return whyDidYouRender;\n\n}));\n//# sourceMappingURL=whyDidYouRender.js.map\n","/**\n * @license\n * Lodash \n * Copyright OpenJS Foundation and other contributors \n * Released under MIT license \n * Based on Underscore.js 1.8.3 \n * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n */\n;(function() {\n\n /** Used as a safe reference for `undefined` in pre-ES5 environments. */\n var undefined;\n\n /** Used as the semantic version number. */\n var VERSION = '4.17.21';\n\n /** Used as the size to enable large array optimizations. */\n var LARGE_ARRAY_SIZE = 200;\n\n /** Error message constants. */\n var CORE_ERROR_TEXT = 'Unsupported core-js use. Try https://npms.io/search?q=ponyfill.',\n FUNC_ERROR_TEXT = 'Expected a function',\n INVALID_TEMPL_VAR_ERROR_TEXT = 'Invalid `variable` option passed into `_.template`';\n\n /** Used to stand-in for `undefined` hash values. */\n var HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n /** Used as the maximum memoize cache size. */\n var MAX_MEMOIZE_SIZE = 500;\n\n /** Used as the internal argument placeholder. */\n var PLACEHOLDER = '__lodash_placeholder__';\n\n /** Used to compose bitmasks for cloning. */\n var CLONE_DEEP_FLAG = 1,\n CLONE_FLAT_FLAG = 2,\n CLONE_SYMBOLS_FLAG = 4;\n\n /** Used to compose bitmasks for value comparisons. */\n var COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n /** Used to compose bitmasks for function metadata. */\n var WRAP_BIND_FLAG = 1,\n WRAP_BIND_KEY_FLAG = 2,\n WRAP_CURRY_BOUND_FLAG = 4,\n WRAP_CURRY_FLAG = 8,\n WRAP_CURRY_RIGHT_FLAG = 16,\n WRAP_PARTIAL_FLAG = 32,\n WRAP_PARTIAL_RIGHT_FLAG = 64,\n WRAP_ARY_FLAG = 128,\n WRAP_REARG_FLAG = 256,\n WRAP_FLIP_FLAG = 512;\n\n /** Used as default options for `_.truncate`. */\n var DEFAULT_TRUNC_LENGTH = 30,\n DEFAULT_TRUNC_OMISSION = '...';\n\n /** Used to detect hot functions by number of calls within a span of milliseconds. */\n var HOT_COUNT = 800,\n HOT_SPAN = 16;\n\n /** Used to indicate the type of lazy iteratees. */\n var LAZY_FILTER_FLAG = 1,\n LAZY_MAP_FLAG = 2,\n LAZY_WHILE_FLAG = 3;\n\n /** Used as references for various `Number` constants. */\n var INFINITY = 1 / 0,\n MAX_SAFE_INTEGER = 9007199254740991,\n MAX_INTEGER = 1.7976931348623157e+308,\n NAN = 0 / 0;\n\n /** Used as references for the maximum length and index of an array. */\n var MAX_ARRAY_LENGTH = 4294967295,\n MAX_ARRAY_INDEX = MAX_ARRAY_LENGTH - 1,\n HALF_MAX_ARRAY_LENGTH = MAX_ARRAY_LENGTH >>> 1;\n\n /** Used to associate wrap methods with their bit flags. */\n var wrapFlags = [\n ['ary', WRAP_ARY_FLAG],\n ['bind', WRAP_BIND_FLAG],\n ['bindKey', WRAP_BIND_KEY_FLAG],\n ['curry', WRAP_CURRY_FLAG],\n ['curryRight', WRAP_CURRY_RIGHT_FLAG],\n ['flip', WRAP_FLIP_FLAG],\n ['partial', WRAP_PARTIAL_FLAG],\n ['partialRight', WRAP_PARTIAL_RIGHT_FLAG],\n ['rearg', WRAP_REARG_FLAG]\n ];\n\n /** `Object#toString` result references. */\n var argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n asyncTag = '[object AsyncFunction]',\n boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n domExcTag = '[object DOMException]',\n errorTag = '[object Error]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n nullTag = '[object Null]',\n objectTag = '[object Object]',\n promiseTag = '[object Promise]',\n proxyTag = '[object Proxy]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n symbolTag = '[object Symbol]',\n undefinedTag = '[object Undefined]',\n weakMapTag = '[object WeakMap]',\n weakSetTag = '[object WeakSet]';\n\n var arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n /** Used to match empty string literals in compiled template source. */\n var reEmptyStringLeading = /\\b__p \\+= '';/g,\n reEmptyStringMiddle = /\\b(__p \\+=) '' \\+/g,\n reEmptyStringTrailing = /(__e\\(.*?\\)|\\b__t\\)) \\+\\n'';/g;\n\n /** Used to match HTML entities and HTML characters. */\n var reEscapedHtml = /&(?:amp|lt|gt|quot|#39);/g,\n reUnescapedHtml = /[&<>\"']/g,\n reHasEscapedHtml = RegExp(reEscapedHtml.source),\n reHasUnescapedHtml = RegExp(reUnescapedHtml.source);\n\n /** Used to match template delimiters. */\n var reEscape = /<%-([\\s\\S]+?)%>/g,\n reEvaluate = /<%([\\s\\S]+?)%>/g,\n reInterpolate = /<%=([\\s\\S]+?)%>/g;\n\n /** Used to match property names within property paths. */\n var reIsDeepProp = /\\.|\\[(?:[^[\\]]*|([\"'])(?:(?!\\1)[^\\\\]|\\\\.)*?\\1)\\]/,\n reIsPlainProp = /^\\w*$/,\n rePropName = /[^.[\\]]+|\\[(?:(-?\\d+(?:\\.\\d+)?)|([\"'])((?:(?!\\2)[^\\\\]|\\\\.)*?)\\2)\\]|(?=(?:\\.|\\[\\])(?:\\.|\\[\\]|$))/g;\n\n /**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\n var reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g,\n reHasRegExpChar = RegExp(reRegExpChar.source);\n\n /** Used to match leading whitespace. */\n var reTrimStart = /^\\s+/;\n\n /** Used to match a single whitespace character. */\n var reWhitespace = /\\s/;\n\n /** Used to match wrap detail comments. */\n var reWrapComment = /\\{(?:\\n\\/\\* \\[wrapped with .+\\] \\*\\/)?\\n?/,\n reWrapDetails = /\\{\\n\\/\\* \\[wrapped with (.+)\\] \\*/,\n reSplitDetails = /,? & /;\n\n /** Used to match words composed of alphanumeric characters. */\n var reAsciiWord = /[^\\x00-\\x2f\\x3a-\\x40\\x5b-\\x60\\x7b-\\x7f]+/g;\n\n /**\n * Used to validate the `validate` option in `_.template` variable.\n *\n * Forbids characters which could potentially change the meaning of the function argument definition:\n * - \"(),\" (modification of function parameters)\n * - \"=\" (default value)\n * - \"[]{}\" (destructuring of function parameters)\n * - \"/\" (beginning of a comment)\n * - whitespace\n */\n var reForbiddenIdentifierChars = /[()=,{}\\[\\]\\/\\s]/;\n\n /** Used to match backslashes in property paths. */\n var reEscapeChar = /\\\\(\\\\)?/g;\n\n /**\n * Used to match\n * [ES template delimiters](http://ecma-international.org/ecma-262/7.0/#sec-template-literal-lexical-components).\n */\n var reEsTemplate = /\\$\\{([^\\\\}]*(?:\\\\.[^\\\\}]*)*)\\}/g;\n\n /** Used to match `RegExp` flags from their coerced string values. */\n var reFlags = /\\w*$/;\n\n /** Used to detect bad signed hexadecimal string values. */\n var reIsBadHex = /^[-+]0x[0-9a-f]+$/i;\n\n /** Used to detect binary string values. */\n var reIsBinary = /^0b[01]+$/i;\n\n /** Used to detect host constructors (Safari). */\n var reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n /** Used to detect octal string values. */\n var reIsOctal = /^0o[0-7]+$/i;\n\n /** Used to detect unsigned integer values. */\n var reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n /** Used to match Latin Unicode letters (excluding mathematical operators). */\n var reLatin = /[\\xc0-\\xd6\\xd8-\\xf6\\xf8-\\xff\\u0100-\\u017f]/g;\n\n /** Used to ensure capturing order of template delimiters. */\n var reNoMatch = /($^)/;\n\n /** Used to match unescaped characters in compiled string literals. */\n var reUnescapedString = /['\\n\\r\\u2028\\u2029\\\\]/g;\n\n /** Used to compose unicode character classes. */\n var rsAstralRange = '\\\\ud800-\\\\udfff',\n rsComboMarksRange = '\\\\u0300-\\\\u036f',\n reComboHalfMarksRange = '\\\\ufe20-\\\\ufe2f',\n rsComboSymbolsRange = '\\\\u20d0-\\\\u20ff',\n rsComboRange = rsComboMarksRange + reComboHalfMarksRange + rsComboSymbolsRange,\n rsDingbatRange = '\\\\u2700-\\\\u27bf',\n rsLowerRange = 'a-z\\\\xdf-\\\\xf6\\\\xf8-\\\\xff',\n rsMathOpRange = '\\\\xac\\\\xb1\\\\xd7\\\\xf7',\n rsNonCharRange = '\\\\x00-\\\\x2f\\\\x3a-\\\\x40\\\\x5b-\\\\x60\\\\x7b-\\\\xbf',\n rsPunctuationRange = '\\\\u2000-\\\\u206f',\n rsSpaceRange = ' \\\\t\\\\x0b\\\\f\\\\xa0\\\\ufeff\\\\n\\\\r\\\\u2028\\\\u2029\\\\u1680\\\\u180e\\\\u2000\\\\u2001\\\\u2002\\\\u2003\\\\u2004\\\\u2005\\\\u2006\\\\u2007\\\\u2008\\\\u2009\\\\u200a\\\\u202f\\\\u205f\\\\u3000',\n rsUpperRange = 'A-Z\\\\xc0-\\\\xd6\\\\xd8-\\\\xde',\n rsVarRange = '\\\\ufe0e\\\\ufe0f',\n rsBreakRange = rsMathOpRange + rsNonCharRange + rsPunctuationRange + rsSpaceRange;\n\n /** Used to compose unicode capture groups. */\n var rsApos = \"['\\u2019]\",\n rsAstral = '[' + rsAstralRange + ']',\n rsBreak = '[' + rsBreakRange + ']',\n rsCombo = '[' + rsComboRange + ']',\n rsDigits = '\\\\d+',\n rsDingbat = '[' + rsDingbatRange + ']',\n rsLower = '[' + rsLowerRange + ']',\n rsMisc = '[^' + rsAstralRange + rsBreakRange + rsDigits + rsDingbatRange + rsLowerRange + rsUpperRange + ']',\n rsFitz = '\\\\ud83c[\\\\udffb-\\\\udfff]',\n rsModifier = '(?:' + rsCombo + '|' + rsFitz + ')',\n rsNonAstral = '[^' + rsAstralRange + ']',\n rsRegional = '(?:\\\\ud83c[\\\\udde6-\\\\uddff]){2}',\n rsSurrPair = '[\\\\ud800-\\\\udbff][\\\\udc00-\\\\udfff]',\n rsUpper = '[' + rsUpperRange + ']',\n rsZWJ = '\\\\u200d';\n\n /** Used to compose unicode regexes. */\n var rsMiscLower = '(?:' + rsLower + '|' + rsMisc + ')',\n rsMiscUpper = '(?:' + rsUpper + '|' + rsMisc + ')',\n rsOptContrLower = '(?:' + rsApos + '(?:d|ll|m|re|s|t|ve))?',\n rsOptContrUpper = '(?:' + rsApos + '(?:D|LL|M|RE|S|T|VE))?',\n reOptMod = rsModifier + '?',\n rsOptVar = '[' + rsVarRange + ']?',\n rsOptJoin = '(?:' + rsZWJ + '(?:' + [rsNonAstral, rsRegional, rsSurrPair].join('|') + ')' + rsOptVar + reOptMod + ')*',\n rsOrdLower = '\\\\d*(?:1st|2nd|3rd|(?![123])\\\\dth)(?=\\\\b|[A-Z_])',\n rsOrdUpper = '\\\\d*(?:1ST|2ND|3RD|(?![123])\\\\dTH)(?=\\\\b|[a-z_])',\n rsSeq = rsOptVar + reOptMod + rsOptJoin,\n rsEmoji = '(?:' + [rsDingbat, rsRegional, rsSurrPair].join('|') + ')' + rsSeq,\n rsSymbol = '(?:' + [rsNonAstral + rsCombo + '?', rsCombo, rsRegional, rsSurrPair, rsAstral].join('|') + ')';\n\n /** Used to match apostrophes. */\n var reApos = RegExp(rsApos, 'g');\n\n /**\n * Used to match [combining diacritical marks](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks) and\n * [combining diacritical marks for symbols](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks_for_Symbols).\n */\n var reComboMark = RegExp(rsCombo, 'g');\n\n /** Used to match [string symbols](https://mathiasbynens.be/notes/javascript-unicode). */\n var reUnicode = RegExp(rsFitz + '(?=' + rsFitz + ')|' + rsSymbol + rsSeq, 'g');\n\n /** Used to match complex or compound words. */\n var reUnicodeWord = RegExp([\n rsUpper + '?' + rsLower + '+' + rsOptContrLower + '(?=' + [rsBreak, rsUpper, '$'].join('|') + ')',\n rsMiscUpper + '+' + rsOptContrUpper + '(?=' + [rsBreak, rsUpper + rsMiscLower, '$'].join('|') + ')',\n rsUpper + '?' + rsMiscLower + '+' + rsOptContrLower,\n rsUpper + '+' + rsOptContrUpper,\n rsOrdUpper,\n rsOrdLower,\n rsDigits,\n rsEmoji\n ].join('|'), 'g');\n\n /** Used to detect strings with [zero-width joiners or code points from the astral planes](http://eev.ee/blog/2015/09/12/dark-corners-of-unicode/). */\n var reHasUnicode = RegExp('[' + rsZWJ + rsAstralRange + rsComboRange + rsVarRange + ']');\n\n /** Used to detect strings that need a more robust regexp to match words. */\n var reHasUnicodeWord = /[a-z][A-Z]|[A-Z]{2}[a-z]|[0-9][a-zA-Z]|[a-zA-Z][0-9]|[^a-zA-Z0-9 ]/;\n\n /** Used to assign default `context` object properties. */\n var contextProps = [\n 'Array', 'Buffer', 'DataView', 'Date', 'Error', 'Float32Array', 'Float64Array',\n 'Function', 'Int8Array', 'Int16Array', 'Int32Array', 'Map', 'Math', 'Object',\n 'Promise', 'RegExp', 'Set', 'String', 'Symbol', 'TypeError', 'Uint8Array',\n 'Uint8ClampedArray', 'Uint16Array', 'Uint32Array', 'WeakMap',\n '_', 'clearTimeout', 'isFinite', 'parseInt', 'setTimeout'\n ];\n\n /** Used to make template sourceURLs easier to identify. */\n var templateCounter = -1;\n\n /** Used to identify `toStringTag` values of typed arrays. */\n var typedArrayTags = {};\n typedArrayTags[float32Tag] = typedArrayTags[float64Tag] =\n typedArrayTags[int8Tag] = typedArrayTags[int16Tag] =\n typedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =\n typedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =\n typedArrayTags[uint32Tag] = true;\n typedArrayTags[argsTag] = typedArrayTags[arrayTag] =\n typedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =\n typedArrayTags[dataViewTag] = typedArrayTags[dateTag] =\n typedArrayTags[errorTag] = typedArrayTags[funcTag] =\n typedArrayTags[mapTag] = typedArrayTags[numberTag] =\n typedArrayTags[objectTag] = typedArrayTags[regexpTag] =\n typedArrayTags[setTag] = typedArrayTags[stringTag] =\n typedArrayTags[weakMapTag] = false;\n\n /** Used to identify `toStringTag` values supported by `_.clone`. */\n var cloneableTags = {};\n cloneableTags[argsTag] = cloneableTags[arrayTag] =\n cloneableTags[arrayBufferTag] = cloneableTags[dataViewTag] =\n cloneableTags[boolTag] = cloneableTags[dateTag] =\n cloneableTags[float32Tag] = cloneableTags[float64Tag] =\n cloneableTags[int8Tag] = cloneableTags[int16Tag] =\n cloneableTags[int32Tag] = cloneableTags[mapTag] =\n cloneableTags[numberTag] = cloneableTags[objectTag] =\n cloneableTags[regexpTag] = cloneableTags[setTag] =\n cloneableTags[stringTag] = cloneableTags[symbolTag] =\n cloneableTags[uint8Tag] = cloneableTags[uint8ClampedTag] =\n cloneableTags[uint16Tag] = cloneableTags[uint32Tag] = true;\n cloneableTags[errorTag] = cloneableTags[funcTag] =\n cloneableTags[weakMapTag] = false;\n\n /** Used to map Latin Unicode letters to basic Latin letters. */\n var deburredLetters = {\n // Latin-1 Supplement block.\n '\\xc0': 'A', '\\xc1': 'A', '\\xc2': 'A', '\\xc3': 'A', '\\xc4': 'A', '\\xc5': 'A',\n '\\xe0': 'a', '\\xe1': 'a', '\\xe2': 'a', '\\xe3': 'a', '\\xe4': 'a', '\\xe5': 'a',\n '\\xc7': 'C', '\\xe7': 'c',\n '\\xd0': 'D', '\\xf0': 'd',\n '\\xc8': 'E', '\\xc9': 'E', '\\xca': 'E', '\\xcb': 'E',\n '\\xe8': 'e', '\\xe9': 'e', '\\xea': 'e', '\\xeb': 'e',\n '\\xcc': 'I', '\\xcd': 'I', '\\xce': 'I', '\\xcf': 'I',\n '\\xec': 'i', '\\xed': 'i', '\\xee': 'i', '\\xef': 'i',\n '\\xd1': 'N', '\\xf1': 'n',\n '\\xd2': 'O', '\\xd3': 'O', '\\xd4': 'O', '\\xd5': 'O', '\\xd6': 'O', '\\xd8': 'O',\n '\\xf2': 'o', '\\xf3': 'o', '\\xf4': 'o', '\\xf5': 'o', '\\xf6': 'o', '\\xf8': 'o',\n '\\xd9': 'U', '\\xda': 'U', '\\xdb': 'U', '\\xdc': 'U',\n '\\xf9': 'u', '\\xfa': 'u', '\\xfb': 'u', '\\xfc': 'u',\n '\\xdd': 'Y', '\\xfd': 'y', '\\xff': 'y',\n '\\xc6': 'Ae', '\\xe6': 'ae',\n '\\xde': 'Th', '\\xfe': 'th',\n '\\xdf': 'ss',\n // Latin Extended-A block.\n '\\u0100': 'A', '\\u0102': 'A', '\\u0104': 'A',\n '\\u0101': 'a', '\\u0103': 'a', '\\u0105': 'a',\n '\\u0106': 'C', '\\u0108': 'C', '\\u010a': 'C', '\\u010c': 'C',\n '\\u0107': 'c', '\\u0109': 'c', '\\u010b': 'c', '\\u010d': 'c',\n '\\u010e': 'D', '\\u0110': 'D', '\\u010f': 'd', '\\u0111': 'd',\n '\\u0112': 'E', '\\u0114': 'E', '\\u0116': 'E', '\\u0118': 'E', '\\u011a': 'E',\n '\\u0113': 'e', '\\u0115': 'e', '\\u0117': 'e', '\\u0119': 'e', '\\u011b': 'e',\n '\\u011c': 'G', '\\u011e': 'G', '\\u0120': 'G', '\\u0122': 'G',\n '\\u011d': 'g', '\\u011f': 'g', '\\u0121': 'g', '\\u0123': 'g',\n '\\u0124': 'H', '\\u0126': 'H', '\\u0125': 'h', '\\u0127': 'h',\n '\\u0128': 'I', '\\u012a': 'I', '\\u012c': 'I', '\\u012e': 'I', '\\u0130': 'I',\n '\\u0129': 'i', '\\u012b': 'i', '\\u012d': 'i', '\\u012f': 'i', '\\u0131': 'i',\n '\\u0134': 'J', '\\u0135': 'j',\n '\\u0136': 'K', '\\u0137': 'k', '\\u0138': 'k',\n '\\u0139': 'L', '\\u013b': 'L', '\\u013d': 'L', '\\u013f': 'L', '\\u0141': 'L',\n '\\u013a': 'l', '\\u013c': 'l', '\\u013e': 'l', '\\u0140': 'l', '\\u0142': 'l',\n '\\u0143': 'N', '\\u0145': 'N', '\\u0147': 'N', '\\u014a': 'N',\n '\\u0144': 'n', '\\u0146': 'n', '\\u0148': 'n', '\\u014b': 'n',\n '\\u014c': 'O', '\\u014e': 'O', '\\u0150': 'O',\n '\\u014d': 'o', '\\u014f': 'o', '\\u0151': 'o',\n '\\u0154': 'R', '\\u0156': 'R', '\\u0158': 'R',\n '\\u0155': 'r', '\\u0157': 'r', '\\u0159': 'r',\n '\\u015a': 'S', '\\u015c': 'S', '\\u015e': 'S', '\\u0160': 'S',\n '\\u015b': 's', '\\u015d': 's', '\\u015f': 's', '\\u0161': 's',\n '\\u0162': 'T', '\\u0164': 'T', '\\u0166': 'T',\n '\\u0163': 't', '\\u0165': 't', '\\u0167': 't',\n '\\u0168': 'U', '\\u016a': 'U', '\\u016c': 'U', '\\u016e': 'U', '\\u0170': 'U', '\\u0172': 'U',\n '\\u0169': 'u', '\\u016b': 'u', '\\u016d': 'u', '\\u016f': 'u', '\\u0171': 'u', '\\u0173': 'u',\n '\\u0174': 'W', '\\u0175': 'w',\n '\\u0176': 'Y', '\\u0177': 'y', '\\u0178': 'Y',\n '\\u0179': 'Z', '\\u017b': 'Z', '\\u017d': 'Z',\n '\\u017a': 'z', '\\u017c': 'z', '\\u017e': 'z',\n '\\u0132': 'IJ', '\\u0133': 'ij',\n '\\u0152': 'Oe', '\\u0153': 'oe',\n '\\u0149': \"'n\", '\\u017f': 's'\n };\n\n /** Used to map characters to HTML entities. */\n var htmlEscapes = {\n '&': '&',\n '<': '<',\n '>': '>',\n '\"': '"',\n \"'\": '''\n };\n\n /** Used to map HTML entities to characters. */\n var htmlUnescapes = {\n '&': '&',\n '<': '<',\n '>': '>',\n '"': '\"',\n ''': \"'\"\n };\n\n /** Used to escape characters for inclusion in compiled string literals. */\n var stringEscapes = {\n '\\\\': '\\\\',\n \"'\": \"'\",\n '\\n': 'n',\n '\\r': 'r',\n '\\u2028': 'u2028',\n '\\u2029': 'u2029'\n };\n\n /** Built-in method references without a dependency on `root`. */\n var freeParseFloat = parseFloat,\n freeParseInt = parseInt;\n\n /** Detect free variable `global` from Node.js. */\n var freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\n /** Detect free variable `self`. */\n var freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n /** Used as a reference to the global object. */\n var root = freeGlobal || freeSelf || Function('return this')();\n\n /** Detect free variable `exports`. */\n var freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n /** Detect free variable `module`. */\n var freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n /** Detect the popular CommonJS extension `module.exports`. */\n var moduleExports = freeModule && freeModule.exports === freeExports;\n\n /** Detect free variable `process` from Node.js. */\n var freeProcess = moduleExports && freeGlobal.process;\n\n /** Used to access faster Node.js helpers. */\n var nodeUtil = (function() {\n try {\n // Use `util.types` for Node.js 10+.\n var types = freeModule && freeModule.require && freeModule.require('util').types;\n\n if (types) {\n return types;\n }\n\n // Legacy `process.binding('util')` for Node.js < 10.\n return freeProcess && freeProcess.binding && freeProcess.binding('util');\n } catch (e) {}\n }());\n\n /* Node.js helper references. */\n var nodeIsArrayBuffer = nodeUtil && nodeUtil.isArrayBuffer,\n nodeIsDate = nodeUtil && nodeUtil.isDate,\n nodeIsMap = nodeUtil && nodeUtil.isMap,\n nodeIsRegExp = nodeUtil && nodeUtil.isRegExp,\n nodeIsSet = nodeUtil && nodeUtil.isSet,\n nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\n\n /*--------------------------------------------------------------------------*/\n\n /**\n * A faster alternative to `Function#apply`, this function invokes `func`\n * with the `this` binding of `thisArg` and the arguments of `args`.\n *\n * @private\n * @param {Function} func The function to invoke.\n * @param {*} thisArg The `this` binding of `func`.\n * @param {Array} args The arguments to invoke `func` with.\n * @returns {*} Returns the result of `func`.\n */\n function apply(func, thisArg, args) {\n switch (args.length) {\n case 0: return func.call(thisArg);\n case 1: return func.call(thisArg, args[0]);\n case 2: return func.call(thisArg, args[0], args[1]);\n case 3: return func.call(thisArg, args[0], args[1], args[2]);\n }\n return func.apply(thisArg, args);\n }\n\n /**\n * A specialized version of `baseAggregator` for arrays.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} setter The function to set `accumulator` values.\n * @param {Function} iteratee The iteratee to transform keys.\n * @param {Object} accumulator The initial aggregated object.\n * @returns {Function} Returns `accumulator`.\n */\n function arrayAggregator(array, setter, iteratee, accumulator) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n var value = array[index];\n setter(accumulator, value, iteratee(value), array);\n }\n return accumulator;\n }\n\n /**\n * A specialized version of `_.forEach` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns `array`.\n */\n function arrayEach(array, iteratee) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (iteratee(array[index], index, array) === false) {\n break;\n }\n }\n return array;\n }\n\n /**\n * A specialized version of `_.forEachRight` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns `array`.\n */\n function arrayEachRight(array, iteratee) {\n var length = array == null ? 0 : array.length;\n\n while (length--) {\n if (iteratee(array[length], length, array) === false) {\n break;\n }\n }\n return array;\n }\n\n /**\n * A specialized version of `_.every` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if all elements pass the predicate check,\n * else `false`.\n */\n function arrayEvery(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (!predicate(array[index], index, array)) {\n return false;\n }\n }\n return true;\n }\n\n /**\n * A specialized version of `_.filter` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n */\n function arrayFilter(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length,\n resIndex = 0,\n result = [];\n\n while (++index < length) {\n var value = array[index];\n if (predicate(value, index, array)) {\n result[resIndex++] = value;\n }\n }\n return result;\n }\n\n /**\n * A specialized version of `_.includes` for arrays without support for\n * specifying an index to search from.\n *\n * @private\n * @param {Array} [array] The array to inspect.\n * @param {*} target The value to search for.\n * @returns {boolean} Returns `true` if `target` is found, else `false`.\n */\n function arrayIncludes(array, value) {\n var length = array == null ? 0 : array.length;\n return !!length && baseIndexOf(array, value, 0) > -1;\n }\n\n /**\n * This function is like `arrayIncludes` except that it accepts a comparator.\n *\n * @private\n * @param {Array} [array] The array to inspect.\n * @param {*} target The value to search for.\n * @param {Function} comparator The comparator invoked per element.\n * @returns {boolean} Returns `true` if `target` is found, else `false`.\n */\n function arrayIncludesWith(array, value, comparator) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (comparator(value, array[index])) {\n return true;\n }\n }\n return false;\n }\n\n /**\n * A specialized version of `_.map` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n */\n function arrayMap(array, iteratee) {\n var index = -1,\n length = array == null ? 0 : array.length,\n result = Array(length);\n\n while (++index < length) {\n result[index] = iteratee(array[index], index, array);\n }\n return result;\n }\n\n /**\n * Appends the elements of `values` to `array`.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {Array} values The values to append.\n * @returns {Array} Returns `array`.\n */\n function arrayPush(array, values) {\n var index = -1,\n length = values.length,\n offset = array.length;\n\n while (++index < length) {\n array[offset + index] = values[index];\n }\n return array;\n }\n\n /**\n * A specialized version of `_.reduce` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {*} [accumulator] The initial value.\n * @param {boolean} [initAccum] Specify using the first element of `array` as\n * the initial value.\n * @returns {*} Returns the accumulated value.\n */\n function arrayReduce(array, iteratee, accumulator, initAccum) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n if (initAccum && length) {\n accumulator = array[++index];\n }\n while (++index < length) {\n accumulator = iteratee(accumulator, array[index], index, array);\n }\n return accumulator;\n }\n\n /**\n * A specialized version of `_.reduceRight` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {*} [accumulator] The initial value.\n * @param {boolean} [initAccum] Specify using the last element of `array` as\n * the initial value.\n * @returns {*} Returns the accumulated value.\n */\n function arrayReduceRight(array, iteratee, accumulator, initAccum) {\n var length = array == null ? 0 : array.length;\n if (initAccum && length) {\n accumulator = array[--length];\n }\n while (length--) {\n accumulator = iteratee(accumulator, array[length], length, array);\n }\n return accumulator;\n }\n\n /**\n * A specialized version of `_.some` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if any element passes the predicate check,\n * else `false`.\n */\n function arraySome(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (predicate(array[index], index, array)) {\n return true;\n }\n }\n return false;\n }\n\n /**\n * Gets the size of an ASCII `string`.\n *\n * @private\n * @param {string} string The string inspect.\n * @returns {number} Returns the string size.\n */\n var asciiSize = baseProperty('length');\n\n /**\n * Converts an ASCII `string` to an array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the converted array.\n */\n function asciiToArray(string) {\n return string.split('');\n }\n\n /**\n * Splits an ASCII `string` into an array of its words.\n *\n * @private\n * @param {string} The string to inspect.\n * @returns {Array} Returns the words of `string`.\n */\n function asciiWords(string) {\n return string.match(reAsciiWord) || [];\n }\n\n /**\n * The base implementation of methods like `_.findKey` and `_.findLastKey`,\n * without support for iteratee shorthands, which iterates over `collection`\n * using `eachFunc`.\n *\n * @private\n * @param {Array|Object} collection The collection to inspect.\n * @param {Function} predicate The function invoked per iteration.\n * @param {Function} eachFunc The function to iterate over `collection`.\n * @returns {*} Returns the found element or its key, else `undefined`.\n */\n function baseFindKey(collection, predicate, eachFunc) {\n var result;\n eachFunc(collection, function(value, key, collection) {\n if (predicate(value, key, collection)) {\n result = key;\n return false;\n }\n });\n return result;\n }\n\n /**\n * The base implementation of `_.findIndex` and `_.findLastIndex` without\n * support for iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {Function} predicate The function invoked per iteration.\n * @param {number} fromIndex The index to search from.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\n function baseFindIndex(array, predicate, fromIndex, fromRight) {\n var length = array.length,\n index = fromIndex + (fromRight ? 1 : -1);\n\n while ((fromRight ? index-- : ++index < length)) {\n if (predicate(array[index], index, array)) {\n return index;\n }\n }\n return -1;\n }\n\n /**\n * The base implementation of `_.indexOf` without `fromIndex` bounds checks.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} fromIndex The index to search from.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\n function baseIndexOf(array, value, fromIndex) {\n return value === value\n ? strictIndexOf(array, value, fromIndex)\n : baseFindIndex(array, baseIsNaN, fromIndex);\n }\n\n /**\n * This function is like `baseIndexOf` except that it accepts a comparator.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} fromIndex The index to search from.\n * @param {Function} comparator The comparator invoked per element.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\n function baseIndexOfWith(array, value, fromIndex, comparator) {\n var index = fromIndex - 1,\n length = array.length;\n\n while (++index < length) {\n if (comparator(array[index], value)) {\n return index;\n }\n }\n return -1;\n }\n\n /**\n * The base implementation of `_.isNaN` without support for number objects.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is `NaN`, else `false`.\n */\n function baseIsNaN(value) {\n return value !== value;\n }\n\n /**\n * The base implementation of `_.mean` and `_.meanBy` without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {number} Returns the mean.\n */\n function baseMean(array, iteratee) {\n var length = array == null ? 0 : array.length;\n return length ? (baseSum(array, iteratee) / length) : NAN;\n }\n\n /**\n * The base implementation of `_.property` without support for deep paths.\n *\n * @private\n * @param {string} key The key of the property to get.\n * @returns {Function} Returns the new accessor function.\n */\n function baseProperty(key) {\n return function(object) {\n return object == null ? undefined : object[key];\n };\n }\n\n /**\n * The base implementation of `_.propertyOf` without support for deep paths.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Function} Returns the new accessor function.\n */\n function basePropertyOf(object) {\n return function(key) {\n return object == null ? undefined : object[key];\n };\n }\n\n /**\n * The base implementation of `_.reduce` and `_.reduceRight`, without support\n * for iteratee shorthands, which iterates over `collection` using `eachFunc`.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {*} accumulator The initial value.\n * @param {boolean} initAccum Specify using the first or last element of\n * `collection` as the initial value.\n * @param {Function} eachFunc The function to iterate over `collection`.\n * @returns {*} Returns the accumulated value.\n */\n function baseReduce(collection, iteratee, accumulator, initAccum, eachFunc) {\n eachFunc(collection, function(value, index, collection) {\n accumulator = initAccum\n ? (initAccum = false, value)\n : iteratee(accumulator, value, index, collection);\n });\n return accumulator;\n }\n\n /**\n * The base implementation of `_.sortBy` which uses `comparer` to define the\n * sort order of `array` and replaces criteria objects with their corresponding\n * values.\n *\n * @private\n * @param {Array} array The array to sort.\n * @param {Function} comparer The function to define sort order.\n * @returns {Array} Returns `array`.\n */\n function baseSortBy(array, comparer) {\n var length = array.length;\n\n array.sort(comparer);\n while (length--) {\n array[length] = array[length].value;\n }\n return array;\n }\n\n /**\n * The base implementation of `_.sum` and `_.sumBy` without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {number} Returns the sum.\n */\n function baseSum(array, iteratee) {\n var result,\n index = -1,\n length = array.length;\n\n while (++index < length) {\n var current = iteratee(array[index]);\n if (current !== undefined) {\n result = result === undefined ? current : (result + current);\n }\n }\n return result;\n }\n\n /**\n * The base implementation of `_.times` without support for iteratee shorthands\n * or max array length checks.\n *\n * @private\n * @param {number} n The number of times to invoke `iteratee`.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the array of results.\n */\n function baseTimes(n, iteratee) {\n var index = -1,\n result = Array(n);\n\n while (++index < n) {\n result[index] = iteratee(index);\n }\n return result;\n }\n\n /**\n * The base implementation of `_.toPairs` and `_.toPairsIn` which creates an array\n * of key-value pairs for `object` corresponding to the property names of `props`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array} props The property names to get values for.\n * @returns {Object} Returns the key-value pairs.\n */\n function baseToPairs(object, props) {\n return arrayMap(props, function(key) {\n return [key, object[key]];\n });\n }\n\n /**\n * The base implementation of `_.trim`.\n *\n * @private\n * @param {string} string The string to trim.\n * @returns {string} Returns the trimmed string.\n */\n function baseTrim(string) {\n return string\n ? string.slice(0, trimmedEndIndex(string) + 1).replace(reTrimStart, '')\n : string;\n }\n\n /**\n * The base implementation of `_.unary` without support for storing metadata.\n *\n * @private\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n */\n function baseUnary(func) {\n return function(value) {\n return func(value);\n };\n }\n\n /**\n * The base implementation of `_.values` and `_.valuesIn` which creates an\n * array of `object` property values corresponding to the property names\n * of `props`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array} props The property names to get values for.\n * @returns {Object} Returns the array of property values.\n */\n function baseValues(object, props) {\n return arrayMap(props, function(key) {\n return object[key];\n });\n }\n\n /**\n * Checks if a `cache` value for `key` exists.\n *\n * @private\n * @param {Object} cache The cache to query.\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\n function cacheHas(cache, key) {\n return cache.has(key);\n }\n\n /**\n * Used by `_.trim` and `_.trimStart` to get the index of the first string symbol\n * that is not found in the character symbols.\n *\n * @private\n * @param {Array} strSymbols The string symbols to inspect.\n * @param {Array} chrSymbols The character symbols to find.\n * @returns {number} Returns the index of the first unmatched string symbol.\n */\n function charsStartIndex(strSymbols, chrSymbols) {\n var index = -1,\n length = strSymbols.length;\n\n while (++index < length && baseIndexOf(chrSymbols, strSymbols[index], 0) > -1) {}\n return index;\n }\n\n /**\n * Used by `_.trim` and `_.trimEnd` to get the index of the last string symbol\n * that is not found in the character symbols.\n *\n * @private\n * @param {Array} strSymbols The string symbols to inspect.\n * @param {Array} chrSymbols The character symbols to find.\n * @returns {number} Returns the index of the last unmatched string symbol.\n */\n function charsEndIndex(strSymbols, chrSymbols) {\n var index = strSymbols.length;\n\n while (index-- && baseIndexOf(chrSymbols, strSymbols[index], 0) > -1) {}\n return index;\n }\n\n /**\n * Gets the number of `placeholder` occurrences in `array`.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} placeholder The placeholder to search for.\n * @returns {number} Returns the placeholder count.\n */\n function countHolders(array, placeholder) {\n var length = array.length,\n result = 0;\n\n while (length--) {\n if (array[length] === placeholder) {\n ++result;\n }\n }\n return result;\n }\n\n /**\n * Used by `_.deburr` to convert Latin-1 Supplement and Latin Extended-A\n * letters to basic Latin letters.\n *\n * @private\n * @param {string} letter The matched letter to deburr.\n * @returns {string} Returns the deburred letter.\n */\n var deburrLetter = basePropertyOf(deburredLetters);\n\n /**\n * Used by `_.escape` to convert characters to HTML entities.\n *\n * @private\n * @param {string} chr The matched character to escape.\n * @returns {string} Returns the escaped character.\n */\n var escapeHtmlChar = basePropertyOf(htmlEscapes);\n\n /**\n * Used by `_.template` to escape characters for inclusion in compiled string literals.\n *\n * @private\n * @param {string} chr The matched character to escape.\n * @returns {string} Returns the escaped character.\n */\n function escapeStringChar(chr) {\n return '\\\\' + stringEscapes[chr];\n }\n\n /**\n * Gets the value at `key` of `object`.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\n function getValue(object, key) {\n return object == null ? undefined : object[key];\n }\n\n /**\n * Checks if `string` contains Unicode symbols.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {boolean} Returns `true` if a symbol is found, else `false`.\n */\n function hasUnicode(string) {\n return reHasUnicode.test(string);\n }\n\n /**\n * Checks if `string` contains a word composed of Unicode symbols.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {boolean} Returns `true` if a word is found, else `false`.\n */\n function hasUnicodeWord(string) {\n return reHasUnicodeWord.test(string);\n }\n\n /**\n * Converts `iterator` to an array.\n *\n * @private\n * @param {Object} iterator The iterator to convert.\n * @returns {Array} Returns the converted array.\n */\n function iteratorToArray(iterator) {\n var data,\n result = [];\n\n while (!(data = iterator.next()).done) {\n result.push(data.value);\n }\n return result;\n }\n\n /**\n * Converts `map` to its key-value pairs.\n *\n * @private\n * @param {Object} map The map to convert.\n * @returns {Array} Returns the key-value pairs.\n */\n function mapToArray(map) {\n var index = -1,\n result = Array(map.size);\n\n map.forEach(function(value, key) {\n result[++index] = [key, value];\n });\n return result;\n }\n\n /**\n * Creates a unary function that invokes `func` with its argument transformed.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {Function} transform The argument transform.\n * @returns {Function} Returns the new function.\n */\n function overArg(func, transform) {\n return function(arg) {\n return func(transform(arg));\n };\n }\n\n /**\n * Replaces all `placeholder` elements in `array` with an internal placeholder\n * and returns an array of their indexes.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {*} placeholder The placeholder to replace.\n * @returns {Array} Returns the new array of placeholder indexes.\n */\n function replaceHolders(array, placeholder) {\n var index = -1,\n length = array.length,\n resIndex = 0,\n result = [];\n\n while (++index < length) {\n var value = array[index];\n if (value === placeholder || value === PLACEHOLDER) {\n array[index] = PLACEHOLDER;\n result[resIndex++] = index;\n }\n }\n return result;\n }\n\n /**\n * Converts `set` to an array of its values.\n *\n * @private\n * @param {Object} set The set to convert.\n * @returns {Array} Returns the values.\n */\n function setToArray(set) {\n var index = -1,\n result = Array(set.size);\n\n set.forEach(function(value) {\n result[++index] = value;\n });\n return result;\n }\n\n /**\n * Converts `set` to its value-value pairs.\n *\n * @private\n * @param {Object} set The set to convert.\n * @returns {Array} Returns the value-value pairs.\n */\n function setToPairs(set) {\n var index = -1,\n result = Array(set.size);\n\n set.forEach(function(value) {\n result[++index] = [value, value];\n });\n return result;\n }\n\n /**\n * A specialized version of `_.indexOf` which performs strict equality\n * comparisons of values, i.e. `===`.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} fromIndex The index to search from.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\n function strictIndexOf(array, value, fromIndex) {\n var index = fromIndex - 1,\n length = array.length;\n\n while (++index < length) {\n if (array[index] === value) {\n return index;\n }\n }\n return -1;\n }\n\n /**\n * A specialized version of `_.lastIndexOf` which performs strict equality\n * comparisons of values, i.e. `===`.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} fromIndex The index to search from.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\n function strictLastIndexOf(array, value, fromIndex) {\n var index = fromIndex + 1;\n while (index--) {\n if (array[index] === value) {\n return index;\n }\n }\n return index;\n }\n\n /**\n * Gets the number of symbols in `string`.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {number} Returns the string size.\n */\n function stringSize(string) {\n return hasUnicode(string)\n ? unicodeSize(string)\n : asciiSize(string);\n }\n\n /**\n * Converts `string` to an array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the converted array.\n */\n function stringToArray(string) {\n return hasUnicode(string)\n ? unicodeToArray(string)\n : asciiToArray(string);\n }\n\n /**\n * Used by `_.trim` and `_.trimEnd` to get the index of the last non-whitespace\n * character of `string`.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {number} Returns the index of the last non-whitespace character.\n */\n function trimmedEndIndex(string) {\n var index = string.length;\n\n while (index-- && reWhitespace.test(string.charAt(index))) {}\n return index;\n }\n\n /**\n * Used by `_.unescape` to convert HTML entities to characters.\n *\n * @private\n * @param {string} chr The matched character to unescape.\n * @returns {string} Returns the unescaped character.\n */\n var unescapeHtmlChar = basePropertyOf(htmlUnescapes);\n\n /**\n * Gets the size of a Unicode `string`.\n *\n * @private\n * @param {string} string The string inspect.\n * @returns {number} Returns the string size.\n */\n function unicodeSize(string) {\n var result = reUnicode.lastIndex = 0;\n while (reUnicode.test(string)) {\n ++result;\n }\n return result;\n }\n\n /**\n * Converts a Unicode `string` to an array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the converted array.\n */\n function unicodeToArray(string) {\n return string.match(reUnicode) || [];\n }\n\n /**\n * Splits a Unicode `string` into an array of its words.\n *\n * @private\n * @param {string} The string to inspect.\n * @returns {Array} Returns the words of `string`.\n */\n function unicodeWords(string) {\n return string.match(reUnicodeWord) || [];\n }\n\n /*--------------------------------------------------------------------------*/\n\n /**\n * Create a new pristine `lodash` function using the `context` object.\n *\n * @static\n * @memberOf _\n * @since 1.1.0\n * @category Util\n * @param {Object} [context=root] The context object.\n * @returns {Function} Returns a new `lodash` function.\n * @example\n *\n * _.mixin({ 'foo': _.constant('foo') });\n *\n * var lodash = _.runInContext();\n * lodash.mixin({ 'bar': lodash.constant('bar') });\n *\n * _.isFunction(_.foo);\n * // => true\n * _.isFunction(_.bar);\n * // => false\n *\n * lodash.isFunction(lodash.foo);\n * // => false\n * lodash.isFunction(lodash.bar);\n * // => true\n *\n * // Create a suped-up `defer` in Node.js.\n * var defer = _.runInContext({ 'setTimeout': setImmediate }).defer;\n */\n var runInContext = (function runInContext(context) {\n context = context == null ? root : _.defaults(root.Object(), context, _.pick(root, contextProps));\n\n /** Built-in constructor references. */\n var Array = context.Array,\n Date = context.Date,\n Error = context.Error,\n Function = context.Function,\n Math = context.Math,\n Object = context.Object,\n RegExp = context.RegExp,\n String = context.String,\n TypeError = context.TypeError;\n\n /** Used for built-in method references. */\n var arrayProto = Array.prototype,\n funcProto = Function.prototype,\n objectProto = Object.prototype;\n\n /** Used to detect overreaching core-js shims. */\n var coreJsData = context['__core-js_shared__'];\n\n /** Used to resolve the decompiled source of functions. */\n var funcToString = funcProto.toString;\n\n /** Used to check objects for own properties. */\n var hasOwnProperty = objectProto.hasOwnProperty;\n\n /** Used to generate unique IDs. */\n var idCounter = 0;\n\n /** Used to detect methods masquerading as native. */\n var maskSrcKey = (function() {\n var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\n return uid ? ('Symbol(src)_1.' + uid) : '';\n }());\n\n /**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\n var nativeObjectToString = objectProto.toString;\n\n /** Used to infer the `Object` constructor. */\n var objectCtorString = funcToString.call(Object);\n\n /** Used to restore the original `_` reference in `_.noConflict`. */\n var oldDash = root._;\n\n /** Used to detect if a method is native. */\n var reIsNative = RegExp('^' +\n funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&')\n .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\n );\n\n /** Built-in value references. */\n var Buffer = moduleExports ? context.Buffer : undefined,\n Symbol = context.Symbol,\n Uint8Array = context.Uint8Array,\n allocUnsafe = Buffer ? Buffer.allocUnsafe : undefined,\n getPrototype = overArg(Object.getPrototypeOf, Object),\n objectCreate = Object.create,\n propertyIsEnumerable = objectProto.propertyIsEnumerable,\n splice = arrayProto.splice,\n spreadableSymbol = Symbol ? Symbol.isConcatSpreadable : undefined,\n symIterator = Symbol ? Symbol.iterator : undefined,\n symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n var defineProperty = (function() {\n try {\n var func = getNative(Object, 'defineProperty');\n func({}, '', {});\n return func;\n } catch (e) {}\n }());\n\n /** Mocked built-ins. */\n var ctxClearTimeout = context.clearTimeout !== root.clearTimeout && context.clearTimeout,\n ctxNow = Date && Date.now !== root.Date.now && Date.now,\n ctxSetTimeout = context.setTimeout !== root.setTimeout && context.setTimeout;\n\n /* Built-in method references for those with the same name as other `lodash` methods. */\n var nativeCeil = Math.ceil,\n nativeFloor = Math.floor,\n nativeGetSymbols = Object.getOwnPropertySymbols,\n nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined,\n nativeIsFinite = context.isFinite,\n nativeJoin = arrayProto.join,\n nativeKeys = overArg(Object.keys, Object),\n nativeMax = Math.max,\n nativeMin = Math.min,\n nativeNow = Date.now,\n nativeParseInt = context.parseInt,\n nativeRandom = Math.random,\n nativeReverse = arrayProto.reverse;\n\n /* Built-in method references that are verified to be native. */\n var DataView = getNative(context, 'DataView'),\n Map = getNative(context, 'Map'),\n Promise = getNative(context, 'Promise'),\n Set = getNative(context, 'Set'),\n WeakMap = getNative(context, 'WeakMap'),\n nativeCreate = getNative(Object, 'create');\n\n /** Used to store function metadata. */\n var metaMap = WeakMap && new WeakMap;\n\n /** Used to lookup unminified function names. */\n var realNames = {};\n\n /** Used to detect maps, sets, and weakmaps. */\n var dataViewCtorString = toSource(DataView),\n mapCtorString = toSource(Map),\n promiseCtorString = toSource(Promise),\n setCtorString = toSource(Set),\n weakMapCtorString = toSource(WeakMap);\n\n /** Used to convert symbols to primitives and strings. */\n var symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolValueOf = symbolProto ? symbolProto.valueOf : undefined,\n symbolToString = symbolProto ? symbolProto.toString : undefined;\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates a `lodash` object which wraps `value` to enable implicit method\n * chain sequences. Methods that operate on and return arrays, collections,\n * and functions can be chained together. Methods that retrieve a single value\n * or may return a primitive value will automatically end the chain sequence\n * and return the unwrapped value. Otherwise, the value must be unwrapped\n * with `_#value`.\n *\n * Explicit chain sequences, which must be unwrapped with `_#value`, may be\n * enabled using `_.chain`.\n *\n * The execution of chained methods is lazy, that is, it's deferred until\n * `_#value` is implicitly or explicitly called.\n *\n * Lazy evaluation allows several methods to support shortcut fusion.\n * Shortcut fusion is an optimization to merge iteratee calls; this avoids\n * the creation of intermediate arrays and can greatly reduce the number of\n * iteratee executions. Sections of a chain sequence qualify for shortcut\n * fusion if the section is applied to an array and iteratees accept only\n * one argument. The heuristic for whether a section qualifies for shortcut\n * fusion is subject to change.\n *\n * Chaining is supported in custom builds as long as the `_#value` method is\n * directly or indirectly included in the build.\n *\n * In addition to lodash methods, wrappers have `Array` and `String` methods.\n *\n * The wrapper `Array` methods are:\n * `concat`, `join`, `pop`, `push`, `shift`, `sort`, `splice`, and `unshift`\n *\n * The wrapper `String` methods are:\n * `replace` and `split`\n *\n * The wrapper methods that support shortcut fusion are:\n * `at`, `compact`, `drop`, `dropRight`, `dropWhile`, `filter`, `find`,\n * `findLast`, `head`, `initial`, `last`, `map`, `reject`, `reverse`, `slice`,\n * `tail`, `take`, `takeRight`, `takeRightWhile`, `takeWhile`, and `toArray`\n *\n * The chainable wrapper methods are:\n * `after`, `ary`, `assign`, `assignIn`, `assignInWith`, `assignWith`, `at`,\n * `before`, `bind`, `bindAll`, `bindKey`, `castArray`, `chain`, `chunk`,\n * `commit`, `compact`, `concat`, `conforms`, `constant`, `countBy`, `create`,\n * `curry`, `debounce`, `defaults`, `defaultsDeep`, `defer`, `delay`,\n * `difference`, `differenceBy`, `differenceWith`, `drop`, `dropRight`,\n * `dropRightWhile`, `dropWhile`, `extend`, `extendWith`, `fill`, `filter`,\n * `flatMap`, `flatMapDeep`, `flatMapDepth`, `flatten`, `flattenDeep`,\n * `flattenDepth`, `flip`, `flow`, `flowRight`, `fromPairs`, `functions`,\n * `functionsIn`, `groupBy`, `initial`, `intersection`, `intersectionBy`,\n * `intersectionWith`, `invert`, `invertBy`, `invokeMap`, `iteratee`, `keyBy`,\n * `keys`, `keysIn`, `map`, `mapKeys`, `mapValues`, `matches`, `matchesProperty`,\n * `memoize`, `merge`, `mergeWith`, `method`, `methodOf`, `mixin`, `negate`,\n * `nthArg`, `omit`, `omitBy`, `once`, `orderBy`, `over`, `overArgs`,\n * `overEvery`, `overSome`, `partial`, `partialRight`, `partition`, `pick`,\n * `pickBy`, `plant`, `property`, `propertyOf`, `pull`, `pullAll`, `pullAllBy`,\n * `pullAllWith`, `pullAt`, `push`, `range`, `rangeRight`, `rearg`, `reject`,\n * `remove`, `rest`, `reverse`, `sampleSize`, `set`, `setWith`, `shuffle`,\n * `slice`, `sort`, `sortBy`, `splice`, `spread`, `tail`, `take`, `takeRight`,\n * `takeRightWhile`, `takeWhile`, `tap`, `throttle`, `thru`, `toArray`,\n * `toPairs`, `toPairsIn`, `toPath`, `toPlainObject`, `transform`, `unary`,\n * `union`, `unionBy`, `unionWith`, `uniq`, `uniqBy`, `uniqWith`, `unset`,\n * `unshift`, `unzip`, `unzipWith`, `update`, `updateWith`, `values`,\n * `valuesIn`, `without`, `wrap`, `xor`, `xorBy`, `xorWith`, `zip`,\n * `zipObject`, `zipObjectDeep`, and `zipWith`\n *\n * The wrapper methods that are **not** chainable by default are:\n * `add`, `attempt`, `camelCase`, `capitalize`, `ceil`, `clamp`, `clone`,\n * `cloneDeep`, `cloneDeepWith`, `cloneWith`, `conformsTo`, `deburr`,\n * `defaultTo`, `divide`, `each`, `eachRight`, `endsWith`, `eq`, `escape`,\n * `escapeRegExp`, `every`, `find`, `findIndex`, `findKey`, `findLast`,\n * `findLastIndex`, `findLastKey`, `first`, `floor`, `forEach`, `forEachRight`,\n * `forIn`, `forInRight`, `forOwn`, `forOwnRight`, `get`, `gt`, `gte`, `has`,\n * `hasIn`, `head`, `identity`, `includes`, `indexOf`, `inRange`, `invoke`,\n * `isArguments`, `isArray`, `isArrayBuffer`, `isArrayLike`, `isArrayLikeObject`,\n * `isBoolean`, `isBuffer`, `isDate`, `isElement`, `isEmpty`, `isEqual`,\n * `isEqualWith`, `isError`, `isFinite`, `isFunction`, `isInteger`, `isLength`,\n * `isMap`, `isMatch`, `isMatchWith`, `isNaN`, `isNative`, `isNil`, `isNull`,\n * `isNumber`, `isObject`, `isObjectLike`, `isPlainObject`, `isRegExp`,\n * `isSafeInteger`, `isSet`, `isString`, `isUndefined`, `isTypedArray`,\n * `isWeakMap`, `isWeakSet`, `join`, `kebabCase`, `last`, `lastIndexOf`,\n * `lowerCase`, `lowerFirst`, `lt`, `lte`, `max`, `maxBy`, `mean`, `meanBy`,\n * `min`, `minBy`, `multiply`, `noConflict`, `noop`, `now`, `nth`, `pad`,\n * `padEnd`, `padStart`, `parseInt`, `pop`, `random`, `reduce`, `reduceRight`,\n * `repeat`, `result`, `round`, `runInContext`, `sample`, `shift`, `size`,\n * `snakeCase`, `some`, `sortedIndex`, `sortedIndexBy`, `sortedLastIndex`,\n * `sortedLastIndexBy`, `startCase`, `startsWith`, `stubArray`, `stubFalse`,\n * `stubObject`, `stubString`, `stubTrue`, `subtract`, `sum`, `sumBy`,\n * `template`, `times`, `toFinite`, `toInteger`, `toJSON`, `toLength`,\n * `toLower`, `toNumber`, `toSafeInteger`, `toString`, `toUpper`, `trim`,\n * `trimEnd`, `trimStart`, `truncate`, `unescape`, `uniqueId`, `upperCase`,\n * `upperFirst`, `value`, and `words`\n *\n * @name _\n * @constructor\n * @category Seq\n * @param {*} value The value to wrap in a `lodash` instance.\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * function square(n) {\n * return n * n;\n * }\n *\n * var wrapped = _([1, 2, 3]);\n *\n * // Returns an unwrapped value.\n * wrapped.reduce(_.add);\n * // => 6\n *\n * // Returns a wrapped value.\n * var squares = wrapped.map(square);\n *\n * _.isArray(squares);\n * // => false\n *\n * _.isArray(squares.value());\n * // => true\n */\n function lodash(value) {\n if (isObjectLike(value) && !isArray(value) && !(value instanceof LazyWrapper)) {\n if (value instanceof LodashWrapper) {\n return value;\n }\n if (hasOwnProperty.call(value, '__wrapped__')) {\n return wrapperClone(value);\n }\n }\n return new LodashWrapper(value);\n }\n\n /**\n * The base implementation of `_.create` without support for assigning\n * properties to the created object.\n *\n * @private\n * @param {Object} proto The object to inherit from.\n * @returns {Object} Returns the new object.\n */\n var baseCreate = (function() {\n function object() {}\n return function(proto) {\n if (!isObject(proto)) {\n return {};\n }\n if (objectCreate) {\n return objectCreate(proto);\n }\n object.prototype = proto;\n var result = new object;\n object.prototype = undefined;\n return result;\n };\n }());\n\n /**\n * The function whose prototype chain sequence wrappers inherit from.\n *\n * @private\n */\n function baseLodash() {\n // No operation performed.\n }\n\n /**\n * The base constructor for creating `lodash` wrapper objects.\n *\n * @private\n * @param {*} value The value to wrap.\n * @param {boolean} [chainAll] Enable explicit method chain sequences.\n */\n function LodashWrapper(value, chainAll) {\n this.__wrapped__ = value;\n this.__actions__ = [];\n this.__chain__ = !!chainAll;\n this.__index__ = 0;\n this.__values__ = undefined;\n }\n\n /**\n * By default, the template delimiters used by lodash are like those in\n * embedded Ruby (ERB) as well as ES2015 template strings. Change the\n * following template settings to use alternative delimiters.\n *\n * @static\n * @memberOf _\n * @type {Object}\n */\n lodash.templateSettings = {\n\n /**\n * Used to detect `data` property values to be HTML-escaped.\n *\n * @memberOf _.templateSettings\n * @type {RegExp}\n */\n 'escape': reEscape,\n\n /**\n * Used to detect code to be evaluated.\n *\n * @memberOf _.templateSettings\n * @type {RegExp}\n */\n 'evaluate': reEvaluate,\n\n /**\n * Used to detect `data` property values to inject.\n *\n * @memberOf _.templateSettings\n * @type {RegExp}\n */\n 'interpolate': reInterpolate,\n\n /**\n * Used to reference the data object in the template text.\n *\n * @memberOf _.templateSettings\n * @type {string}\n */\n 'variable': '',\n\n /**\n * Used to import variables into the compiled template.\n *\n * @memberOf _.templateSettings\n * @type {Object}\n */\n 'imports': {\n\n /**\n * A reference to the `lodash` function.\n *\n * @memberOf _.templateSettings.imports\n * @type {Function}\n */\n '_': lodash\n }\n };\n\n // Ensure wrappers are instances of `baseLodash`.\n lodash.prototype = baseLodash.prototype;\n lodash.prototype.constructor = lodash;\n\n LodashWrapper.prototype = baseCreate(baseLodash.prototype);\n LodashWrapper.prototype.constructor = LodashWrapper;\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates a lazy wrapper object which wraps `value` to enable lazy evaluation.\n *\n * @private\n * @constructor\n * @param {*} value The value to wrap.\n */\n function LazyWrapper(value) {\n this.__wrapped__ = value;\n this.__actions__ = [];\n this.__dir__ = 1;\n this.__filtered__ = false;\n this.__iteratees__ = [];\n this.__takeCount__ = MAX_ARRAY_LENGTH;\n this.__views__ = [];\n }\n\n /**\n * Creates a clone of the lazy wrapper object.\n *\n * @private\n * @name clone\n * @memberOf LazyWrapper\n * @returns {Object} Returns the cloned `LazyWrapper` object.\n */\n function lazyClone() {\n var result = new LazyWrapper(this.__wrapped__);\n result.__actions__ = copyArray(this.__actions__);\n result.__dir__ = this.__dir__;\n result.__filtered__ = this.__filtered__;\n result.__iteratees__ = copyArray(this.__iteratees__);\n result.__takeCount__ = this.__takeCount__;\n result.__views__ = copyArray(this.__views__);\n return result;\n }\n\n /**\n * Reverses the direction of lazy iteration.\n *\n * @private\n * @name reverse\n * @memberOf LazyWrapper\n * @returns {Object} Returns the new reversed `LazyWrapper` object.\n */\n function lazyReverse() {\n if (this.__filtered__) {\n var result = new LazyWrapper(this);\n result.__dir__ = -1;\n result.__filtered__ = true;\n } else {\n result = this.clone();\n result.__dir__ *= -1;\n }\n return result;\n }\n\n /**\n * Extracts the unwrapped value from its lazy wrapper.\n *\n * @private\n * @name value\n * @memberOf LazyWrapper\n * @returns {*} Returns the unwrapped value.\n */\n function lazyValue() {\n var array = this.__wrapped__.value(),\n dir = this.__dir__,\n isArr = isArray(array),\n isRight = dir < 0,\n arrLength = isArr ? array.length : 0,\n view = getView(0, arrLength, this.__views__),\n start = view.start,\n end = view.end,\n length = end - start,\n index = isRight ? end : (start - 1),\n iteratees = this.__iteratees__,\n iterLength = iteratees.length,\n resIndex = 0,\n takeCount = nativeMin(length, this.__takeCount__);\n\n if (!isArr || (!isRight && arrLength == length && takeCount == length)) {\n return baseWrapperValue(array, this.__actions__);\n }\n var result = [];\n\n outer:\n while (length-- && resIndex < takeCount) {\n index += dir;\n\n var iterIndex = -1,\n value = array[index];\n\n while (++iterIndex < iterLength) {\n var data = iteratees[iterIndex],\n iteratee = data.iteratee,\n type = data.type,\n computed = iteratee(value);\n\n if (type == LAZY_MAP_FLAG) {\n value = computed;\n } else if (!computed) {\n if (type == LAZY_FILTER_FLAG) {\n continue outer;\n } else {\n break outer;\n }\n }\n }\n result[resIndex++] = value;\n }\n return result;\n }\n\n // Ensure `LazyWrapper` is an instance of `baseLodash`.\n LazyWrapper.prototype = baseCreate(baseLodash.prototype);\n LazyWrapper.prototype.constructor = LazyWrapper;\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates a hash object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\n function Hash(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n }\n\n /**\n * Removes all key-value entries from the hash.\n *\n * @private\n * @name clear\n * @memberOf Hash\n */\n function hashClear() {\n this.__data__ = nativeCreate ? nativeCreate(null) : {};\n this.size = 0;\n }\n\n /**\n * Removes `key` and its value from the hash.\n *\n * @private\n * @name delete\n * @memberOf Hash\n * @param {Object} hash The hash to modify.\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\n function hashDelete(key) {\n var result = this.has(key) && delete this.__data__[key];\n this.size -= result ? 1 : 0;\n return result;\n }\n\n /**\n * Gets the hash value for `key`.\n *\n * @private\n * @name get\n * @memberOf Hash\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\n function hashGet(key) {\n var data = this.__data__;\n if (nativeCreate) {\n var result = data[key];\n return result === HASH_UNDEFINED ? undefined : result;\n }\n return hasOwnProperty.call(data, key) ? data[key] : undefined;\n }\n\n /**\n * Checks if a hash value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Hash\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\n function hashHas(key) {\n var data = this.__data__;\n return nativeCreate ? (data[key] !== undefined) : hasOwnProperty.call(data, key);\n }\n\n /**\n * Sets the hash `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Hash\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the hash instance.\n */\n function hashSet(key, value) {\n var data = this.__data__;\n this.size += this.has(key) ? 0 : 1;\n data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;\n return this;\n }\n\n // Add methods to `Hash`.\n Hash.prototype.clear = hashClear;\n Hash.prototype['delete'] = hashDelete;\n Hash.prototype.get = hashGet;\n Hash.prototype.has = hashHas;\n Hash.prototype.set = hashSet;\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates an list cache object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\n function ListCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n }\n\n /**\n * Removes all key-value entries from the list cache.\n *\n * @private\n * @name clear\n * @memberOf ListCache\n */\n function listCacheClear() {\n this.__data__ = [];\n this.size = 0;\n }\n\n /**\n * Removes `key` and its value from the list cache.\n *\n * @private\n * @name delete\n * @memberOf ListCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\n function listCacheDelete(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n return false;\n }\n var lastIndex = data.length - 1;\n if (index == lastIndex) {\n data.pop();\n } else {\n splice.call(data, index, 1);\n }\n --this.size;\n return true;\n }\n\n /**\n * Gets the list cache value for `key`.\n *\n * @private\n * @name get\n * @memberOf ListCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\n function listCacheGet(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n return index < 0 ? undefined : data[index][1];\n }\n\n /**\n * Checks if a list cache value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf ListCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\n function listCacheHas(key) {\n return assocIndexOf(this.__data__, key) > -1;\n }\n\n /**\n * Sets the list cache `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf ListCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the list cache instance.\n */\n function listCacheSet(key, value) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n ++this.size;\n data.push([key, value]);\n } else {\n data[index][1] = value;\n }\n return this;\n }\n\n // Add methods to `ListCache`.\n ListCache.prototype.clear = listCacheClear;\n ListCache.prototype['delete'] = listCacheDelete;\n ListCache.prototype.get = listCacheGet;\n ListCache.prototype.has = listCacheHas;\n ListCache.prototype.set = listCacheSet;\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates a map cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\n function MapCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n }\n\n /**\n * Removes all key-value entries from the map.\n *\n * @private\n * @name clear\n * @memberOf MapCache\n */\n function mapCacheClear() {\n this.size = 0;\n this.__data__ = {\n 'hash': new Hash,\n 'map': new (Map || ListCache),\n 'string': new Hash\n };\n }\n\n /**\n * Removes `key` and its value from the map.\n *\n * @private\n * @name delete\n * @memberOf MapCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\n function mapCacheDelete(key) {\n var result = getMapData(this, key)['delete'](key);\n this.size -= result ? 1 : 0;\n return result;\n }\n\n /**\n * Gets the map value for `key`.\n *\n * @private\n * @name get\n * @memberOf MapCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\n function mapCacheGet(key) {\n return getMapData(this, key).get(key);\n }\n\n /**\n * Checks if a map value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf MapCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\n function mapCacheHas(key) {\n return getMapData(this, key).has(key);\n }\n\n /**\n * Sets the map `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf MapCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the map cache instance.\n */\n function mapCacheSet(key, value) {\n var data = getMapData(this, key),\n size = data.size;\n\n data.set(key, value);\n this.size += data.size == size ? 0 : 1;\n return this;\n }\n\n // Add methods to `MapCache`.\n MapCache.prototype.clear = mapCacheClear;\n MapCache.prototype['delete'] = mapCacheDelete;\n MapCache.prototype.get = mapCacheGet;\n MapCache.prototype.has = mapCacheHas;\n MapCache.prototype.set = mapCacheSet;\n\n /*------------------------------------------------------------------------*/\n\n /**\n *\n * Creates an array cache object to store unique values.\n *\n * @private\n * @constructor\n * @param {Array} [values] The values to cache.\n */\n function SetCache(values) {\n var index = -1,\n length = values == null ? 0 : values.length;\n\n this.__data__ = new MapCache;\n while (++index < length) {\n this.add(values[index]);\n }\n }\n\n /**\n * Adds `value` to the array cache.\n *\n * @private\n * @name add\n * @memberOf SetCache\n * @alias push\n * @param {*} value The value to cache.\n * @returns {Object} Returns the cache instance.\n */\n function setCacheAdd(value) {\n this.__data__.set(value, HASH_UNDEFINED);\n return this;\n }\n\n /**\n * Checks if `value` is in the array cache.\n *\n * @private\n * @name has\n * @memberOf SetCache\n * @param {*} value The value to search for.\n * @returns {number} Returns `true` if `value` is found, else `false`.\n */\n function setCacheHas(value) {\n return this.__data__.has(value);\n }\n\n // Add methods to `SetCache`.\n SetCache.prototype.add = SetCache.prototype.push = setCacheAdd;\n SetCache.prototype.has = setCacheHas;\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates a stack cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\n function Stack(entries) {\n var data = this.__data__ = new ListCache(entries);\n this.size = data.size;\n }\n\n /**\n * Removes all key-value entries from the stack.\n *\n * @private\n * @name clear\n * @memberOf Stack\n */\n function stackClear() {\n this.__data__ = new ListCache;\n this.size = 0;\n }\n\n /**\n * Removes `key` and its value from the stack.\n *\n * @private\n * @name delete\n * @memberOf Stack\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\n function stackDelete(key) {\n var data = this.__data__,\n result = data['delete'](key);\n\n this.size = data.size;\n return result;\n }\n\n /**\n * Gets the stack value for `key`.\n *\n * @private\n * @name get\n * @memberOf Stack\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\n function stackGet(key) {\n return this.__data__.get(key);\n }\n\n /**\n * Checks if a stack value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Stack\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\n function stackHas(key) {\n return this.__data__.has(key);\n }\n\n /**\n * Sets the stack `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Stack\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the stack cache instance.\n */\n function stackSet(key, value) {\n var data = this.__data__;\n if (data instanceof ListCache) {\n var pairs = data.__data__;\n if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) {\n pairs.push([key, value]);\n this.size = ++data.size;\n return this;\n }\n data = this.__data__ = new MapCache(pairs);\n }\n data.set(key, value);\n this.size = data.size;\n return this;\n }\n\n // Add methods to `Stack`.\n Stack.prototype.clear = stackClear;\n Stack.prototype['delete'] = stackDelete;\n Stack.prototype.get = stackGet;\n Stack.prototype.has = stackHas;\n Stack.prototype.set = stackSet;\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates an array of the enumerable property names of the array-like `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @param {boolean} inherited Specify returning inherited property names.\n * @returns {Array} Returns the array of property names.\n */\n function arrayLikeKeys(value, inherited) {\n var isArr = isArray(value),\n isArg = !isArr && isArguments(value),\n isBuff = !isArr && !isArg && isBuffer(value),\n isType = !isArr && !isArg && !isBuff && isTypedArray(value),\n skipIndexes = isArr || isArg || isBuff || isType,\n result = skipIndexes ? baseTimes(value.length, String) : [],\n length = result.length;\n\n for (var key in value) {\n if ((inherited || hasOwnProperty.call(value, key)) &&\n !(skipIndexes && (\n // Safari 9 has enumerable `arguments.length` in strict mode.\n key == 'length' ||\n // Node.js 0.10 has enumerable non-index properties on buffers.\n (isBuff && (key == 'offset' || key == 'parent')) ||\n // PhantomJS 2 has enumerable non-index properties on typed arrays.\n (isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset')) ||\n // Skip index properties.\n isIndex(key, length)\n ))) {\n result.push(key);\n }\n }\n return result;\n }\n\n /**\n * A specialized version of `_.sample` for arrays.\n *\n * @private\n * @param {Array} array The array to sample.\n * @returns {*} Returns the random element.\n */\n function arraySample(array) {\n var length = array.length;\n return length ? array[baseRandom(0, length - 1)] : undefined;\n }\n\n /**\n * A specialized version of `_.sampleSize` for arrays.\n *\n * @private\n * @param {Array} array The array to sample.\n * @param {number} n The number of elements to sample.\n * @returns {Array} Returns the random elements.\n */\n function arraySampleSize(array, n) {\n return shuffleSelf(copyArray(array), baseClamp(n, 0, array.length));\n }\n\n /**\n * A specialized version of `_.shuffle` for arrays.\n *\n * @private\n * @param {Array} array The array to shuffle.\n * @returns {Array} Returns the new shuffled array.\n */\n function arrayShuffle(array) {\n return shuffleSelf(copyArray(array));\n }\n\n /**\n * This function is like `assignValue` except that it doesn't assign\n * `undefined` values.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\n function assignMergeValue(object, key, value) {\n if ((value !== undefined && !eq(object[key], value)) ||\n (value === undefined && !(key in object))) {\n baseAssignValue(object, key, value);\n }\n }\n\n /**\n * Assigns `value` to `key` of `object` if the existing value is not equivalent\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\n function assignValue(object, key, value) {\n var objValue = object[key];\n if (!(hasOwnProperty.call(object, key) && eq(objValue, value)) ||\n (value === undefined && !(key in object))) {\n baseAssignValue(object, key, value);\n }\n }\n\n /**\n * Gets the index at which the `key` is found in `array` of key-value pairs.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} key The key to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\n function assocIndexOf(array, key) {\n var length = array.length;\n while (length--) {\n if (eq(array[length][0], key)) {\n return length;\n }\n }\n return -1;\n }\n\n /**\n * Aggregates elements of `collection` on `accumulator` with keys transformed\n * by `iteratee` and values set by `setter`.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} setter The function to set `accumulator` values.\n * @param {Function} iteratee The iteratee to transform keys.\n * @param {Object} accumulator The initial aggregated object.\n * @returns {Function} Returns `accumulator`.\n */\n function baseAggregator(collection, setter, iteratee, accumulator) {\n baseEach(collection, function(value, key, collection) {\n setter(accumulator, value, iteratee(value), collection);\n });\n return accumulator;\n }\n\n /**\n * The base implementation of `_.assign` without support for multiple sources\n * or `customizer` functions.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @returns {Object} Returns `object`.\n */\n function baseAssign(object, source) {\n return object && copyObject(source, keys(source), object);\n }\n\n /**\n * The base implementation of `_.assignIn` without support for multiple sources\n * or `customizer` functions.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @returns {Object} Returns `object`.\n */\n function baseAssignIn(object, source) {\n return object && copyObject(source, keysIn(source), object);\n }\n\n /**\n * The base implementation of `assignValue` and `assignMergeValue` without\n * value checks.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\n function baseAssignValue(object, key, value) {\n if (key == '__proto__' && defineProperty) {\n defineProperty(object, key, {\n 'configurable': true,\n 'enumerable': true,\n 'value': value,\n 'writable': true\n });\n } else {\n object[key] = value;\n }\n }\n\n /**\n * The base implementation of `_.at` without support for individual paths.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {string[]} paths The property paths to pick.\n * @returns {Array} Returns the picked elements.\n */\n function baseAt(object, paths) {\n var index = -1,\n length = paths.length,\n result = Array(length),\n skip = object == null;\n\n while (++index < length) {\n result[index] = skip ? undefined : get(object, paths[index]);\n }\n return result;\n }\n\n /**\n * The base implementation of `_.clamp` which doesn't coerce arguments.\n *\n * @private\n * @param {number} number The number to clamp.\n * @param {number} [lower] The lower bound.\n * @param {number} upper The upper bound.\n * @returns {number} Returns the clamped number.\n */\n function baseClamp(number, lower, upper) {\n if (number === number) {\n if (upper !== undefined) {\n number = number <= upper ? number : upper;\n }\n if (lower !== undefined) {\n number = number >= lower ? number : lower;\n }\n }\n return number;\n }\n\n /**\n * The base implementation of `_.clone` and `_.cloneDeep` which tracks\n * traversed objects.\n *\n * @private\n * @param {*} value The value to clone.\n * @param {boolean} bitmask The bitmask flags.\n * 1 - Deep clone\n * 2 - Flatten inherited properties\n * 4 - Clone symbols\n * @param {Function} [customizer] The function to customize cloning.\n * @param {string} [key] The key of `value`.\n * @param {Object} [object] The parent object of `value`.\n * @param {Object} [stack] Tracks traversed objects and their clone counterparts.\n * @returns {*} Returns the cloned value.\n */\n function baseClone(value, bitmask, customizer, key, object, stack) {\n var result,\n isDeep = bitmask & CLONE_DEEP_FLAG,\n isFlat = bitmask & CLONE_FLAT_FLAG,\n isFull = bitmask & CLONE_SYMBOLS_FLAG;\n\n if (customizer) {\n result = object ? customizer(value, key, object, stack) : customizer(value);\n }\n if (result !== undefined) {\n return result;\n }\n if (!isObject(value)) {\n return value;\n }\n var isArr = isArray(value);\n if (isArr) {\n result = initCloneArray(value);\n if (!isDeep) {\n return copyArray(value, result);\n }\n } else {\n var tag = getTag(value),\n isFunc = tag == funcTag || tag == genTag;\n\n if (isBuffer(value)) {\n return cloneBuffer(value, isDeep);\n }\n if (tag == objectTag || tag == argsTag || (isFunc && !object)) {\n result = (isFlat || isFunc) ? {} : initCloneObject(value);\n if (!isDeep) {\n return isFlat\n ? copySymbolsIn(value, baseAssignIn(result, value))\n : copySymbols(value, baseAssign(result, value));\n }\n } else {\n if (!cloneableTags[tag]) {\n return object ? value : {};\n }\n result = initCloneByTag(value, tag, isDeep);\n }\n }\n // Check for circular references and return its corresponding clone.\n stack || (stack = new Stack);\n var stacked = stack.get(value);\n if (stacked) {\n return stacked;\n }\n stack.set(value, result);\n\n if (isSet(value)) {\n value.forEach(function(subValue) {\n result.add(baseClone(subValue, bitmask, customizer, subValue, value, stack));\n });\n } else if (isMap(value)) {\n value.forEach(function(subValue, key) {\n result.set(key, baseClone(subValue, bitmask, customizer, key, value, stack));\n });\n }\n\n var keysFunc = isFull\n ? (isFlat ? getAllKeysIn : getAllKeys)\n : (isFlat ? keysIn : keys);\n\n var props = isArr ? undefined : keysFunc(value);\n arrayEach(props || value, function(subValue, key) {\n if (props) {\n key = subValue;\n subValue = value[key];\n }\n // Recursively populate clone (susceptible to call stack limits).\n assignValue(result, key, baseClone(subValue, bitmask, customizer, key, value, stack));\n });\n return result;\n }\n\n /**\n * The base implementation of `_.conforms` which doesn't clone `source`.\n *\n * @private\n * @param {Object} source The object of property predicates to conform to.\n * @returns {Function} Returns the new spec function.\n */\n function baseConforms(source) {\n var props = keys(source);\n return function(object) {\n return baseConformsTo(object, source, props);\n };\n }\n\n /**\n * The base implementation of `_.conformsTo` which accepts `props` to check.\n *\n * @private\n * @param {Object} object The object to inspect.\n * @param {Object} source The object of property predicates to conform to.\n * @returns {boolean} Returns `true` if `object` conforms, else `false`.\n */\n function baseConformsTo(object, source, props) {\n var length = props.length;\n if (object == null) {\n return !length;\n }\n object = Object(object);\n while (length--) {\n var key = props[length],\n predicate = source[key],\n value = object[key];\n\n if ((value === undefined && !(key in object)) || !predicate(value)) {\n return false;\n }\n }\n return true;\n }\n\n /**\n * The base implementation of `_.delay` and `_.defer` which accepts `args`\n * to provide to `func`.\n *\n * @private\n * @param {Function} func The function to delay.\n * @param {number} wait The number of milliseconds to delay invocation.\n * @param {Array} args The arguments to provide to `func`.\n * @returns {number|Object} Returns the timer id or timeout object.\n */\n function baseDelay(func, wait, args) {\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n return setTimeout(function() { func.apply(undefined, args); }, wait);\n }\n\n /**\n * The base implementation of methods like `_.difference` without support\n * for excluding multiple arrays or iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {Array} values The values to exclude.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of filtered values.\n */\n function baseDifference(array, values, iteratee, comparator) {\n var index = -1,\n includes = arrayIncludes,\n isCommon = true,\n length = array.length,\n result = [],\n valuesLength = values.length;\n\n if (!length) {\n return result;\n }\n if (iteratee) {\n values = arrayMap(values, baseUnary(iteratee));\n }\n if (comparator) {\n includes = arrayIncludesWith;\n isCommon = false;\n }\n else if (values.length >= LARGE_ARRAY_SIZE) {\n includes = cacheHas;\n isCommon = false;\n values = new SetCache(values);\n }\n outer:\n while (++index < length) {\n var value = array[index],\n computed = iteratee == null ? value : iteratee(value);\n\n value = (comparator || value !== 0) ? value : 0;\n if (isCommon && computed === computed) {\n var valuesIndex = valuesLength;\n while (valuesIndex--) {\n if (values[valuesIndex] === computed) {\n continue outer;\n }\n }\n result.push(value);\n }\n else if (!includes(values, computed, comparator)) {\n result.push(value);\n }\n }\n return result;\n }\n\n /**\n * The base implementation of `_.forEach` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array|Object} Returns `collection`.\n */\n var baseEach = createBaseEach(baseForOwn);\n\n /**\n * The base implementation of `_.forEachRight` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array|Object} Returns `collection`.\n */\n var baseEachRight = createBaseEach(baseForOwnRight, true);\n\n /**\n * The base implementation of `_.every` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if all elements pass the predicate check,\n * else `false`\n */\n function baseEvery(collection, predicate) {\n var result = true;\n baseEach(collection, function(value, index, collection) {\n result = !!predicate(value, index, collection);\n return result;\n });\n return result;\n }\n\n /**\n * The base implementation of methods like `_.max` and `_.min` which accepts a\n * `comparator` to determine the extremum value.\n *\n * @private\n * @param {Array} array The array to iterate over.\n * @param {Function} iteratee The iteratee invoked per iteration.\n * @param {Function} comparator The comparator used to compare values.\n * @returns {*} Returns the extremum value.\n */\n function baseExtremum(array, iteratee, comparator) {\n var index = -1,\n length = array.length;\n\n while (++index < length) {\n var value = array[index],\n current = iteratee(value);\n\n if (current != null && (computed === undefined\n ? (current === current && !isSymbol(current))\n : comparator(current, computed)\n )) {\n var computed = current,\n result = value;\n }\n }\n return result;\n }\n\n /**\n * The base implementation of `_.fill` without an iteratee call guard.\n *\n * @private\n * @param {Array} array The array to fill.\n * @param {*} value The value to fill `array` with.\n * @param {number} [start=0] The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns `array`.\n */\n function baseFill(array, value, start, end) {\n var length = array.length;\n\n start = toInteger(start);\n if (start < 0) {\n start = -start > length ? 0 : (length + start);\n }\n end = (end === undefined || end > length) ? length : toInteger(end);\n if (end < 0) {\n end += length;\n }\n end = start > end ? 0 : toLength(end);\n while (start < end) {\n array[start++] = value;\n }\n return array;\n }\n\n /**\n * The base implementation of `_.filter` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n */\n function baseFilter(collection, predicate) {\n var result = [];\n baseEach(collection, function(value, index, collection) {\n if (predicate(value, index, collection)) {\n result.push(value);\n }\n });\n return result;\n }\n\n /**\n * The base implementation of `_.flatten` with support for restricting flattening.\n *\n * @private\n * @param {Array} array The array to flatten.\n * @param {number} depth The maximum recursion depth.\n * @param {boolean} [predicate=isFlattenable] The function invoked per iteration.\n * @param {boolean} [isStrict] Restrict to values that pass `predicate` checks.\n * @param {Array} [result=[]] The initial result value.\n * @returns {Array} Returns the new flattened array.\n */\n function baseFlatten(array, depth, predicate, isStrict, result) {\n var index = -1,\n length = array.length;\n\n predicate || (predicate = isFlattenable);\n result || (result = []);\n\n while (++index < length) {\n var value = array[index];\n if (depth > 0 && predicate(value)) {\n if (depth > 1) {\n // Recursively flatten arrays (susceptible to call stack limits).\n baseFlatten(value, depth - 1, predicate, isStrict, result);\n } else {\n arrayPush(result, value);\n }\n } else if (!isStrict) {\n result[result.length] = value;\n }\n }\n return result;\n }\n\n /**\n * The base implementation of `baseForOwn` which iterates over `object`\n * properties returned by `keysFunc` and invokes `iteratee` for each property.\n * Iteratee functions may exit iteration early by explicitly returning `false`.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @returns {Object} Returns `object`.\n */\n var baseFor = createBaseFor();\n\n /**\n * This function is like `baseFor` except that it iterates over properties\n * in the opposite order.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @returns {Object} Returns `object`.\n */\n var baseForRight = createBaseFor(true);\n\n /**\n * The base implementation of `_.forOwn` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Object} Returns `object`.\n */\n function baseForOwn(object, iteratee) {\n return object && baseFor(object, iteratee, keys);\n }\n\n /**\n * The base implementation of `_.forOwnRight` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Object} Returns `object`.\n */\n function baseForOwnRight(object, iteratee) {\n return object && baseForRight(object, iteratee, keys);\n }\n\n /**\n * The base implementation of `_.functions` which creates an array of\n * `object` function property names filtered from `props`.\n *\n * @private\n * @param {Object} object The object to inspect.\n * @param {Array} props The property names to filter.\n * @returns {Array} Returns the function names.\n */\n function baseFunctions(object, props) {\n return arrayFilter(props, function(key) {\n return isFunction(object[key]);\n });\n }\n\n /**\n * The base implementation of `_.get` without support for default values.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the property to get.\n * @returns {*} Returns the resolved value.\n */\n function baseGet(object, path) {\n path = castPath(path, object);\n\n var index = 0,\n length = path.length;\n\n while (object != null && index < length) {\n object = object[toKey(path[index++])];\n }\n return (index && index == length) ? object : undefined;\n }\n\n /**\n * The base implementation of `getAllKeys` and `getAllKeysIn` which uses\n * `keysFunc` and `symbolsFunc` to get the enumerable property names and\n * symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @param {Function} symbolsFunc The function to get the symbols of `object`.\n * @returns {Array} Returns the array of property names and symbols.\n */\n function baseGetAllKeys(object, keysFunc, symbolsFunc) {\n var result = keysFunc(object);\n return isArray(object) ? result : arrayPush(result, symbolsFunc(object));\n }\n\n /**\n * The base implementation of `getTag` without fallbacks for buggy environments.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\n function baseGetTag(value) {\n if (value == null) {\n return value === undefined ? undefinedTag : nullTag;\n }\n return (symToStringTag && symToStringTag in Object(value))\n ? getRawTag(value)\n : objectToString(value);\n }\n\n /**\n * The base implementation of `_.gt` which doesn't coerce arguments.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is greater than `other`,\n * else `false`.\n */\n function baseGt(value, other) {\n return value > other;\n }\n\n /**\n * The base implementation of `_.has` without support for deep paths.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {Array|string} key The key to check.\n * @returns {boolean} Returns `true` if `key` exists, else `false`.\n */\n function baseHas(object, key) {\n return object != null && hasOwnProperty.call(object, key);\n }\n\n /**\n * The base implementation of `_.hasIn` without support for deep paths.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {Array|string} key The key to check.\n * @returns {boolean} Returns `true` if `key` exists, else `false`.\n */\n function baseHasIn(object, key) {\n return object != null && key in Object(object);\n }\n\n /**\n * The base implementation of `_.inRange` which doesn't coerce arguments.\n *\n * @private\n * @param {number} number The number to check.\n * @param {number} start The start of the range.\n * @param {number} end The end of the range.\n * @returns {boolean} Returns `true` if `number` is in the range, else `false`.\n */\n function baseInRange(number, start, end) {\n return number >= nativeMin(start, end) && number < nativeMax(start, end);\n }\n\n /**\n * The base implementation of methods like `_.intersection`, without support\n * for iteratee shorthands, that accepts an array of arrays to inspect.\n *\n * @private\n * @param {Array} arrays The arrays to inspect.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of shared values.\n */\n function baseIntersection(arrays, iteratee, comparator) {\n var includes = comparator ? arrayIncludesWith : arrayIncludes,\n length = arrays[0].length,\n othLength = arrays.length,\n othIndex = othLength,\n caches = Array(othLength),\n maxLength = Infinity,\n result = [];\n\n while (othIndex--) {\n var array = arrays[othIndex];\n if (othIndex && iteratee) {\n array = arrayMap(array, baseUnary(iteratee));\n }\n maxLength = nativeMin(array.length, maxLength);\n caches[othIndex] = !comparator && (iteratee || (length >= 120 && array.length >= 120))\n ? new SetCache(othIndex && array)\n : undefined;\n }\n array = arrays[0];\n\n var index = -1,\n seen = caches[0];\n\n outer:\n while (++index < length && result.length < maxLength) {\n var value = array[index],\n computed = iteratee ? iteratee(value) : value;\n\n value = (comparator || value !== 0) ? value : 0;\n if (!(seen\n ? cacheHas(seen, computed)\n : includes(result, computed, comparator)\n )) {\n othIndex = othLength;\n while (--othIndex) {\n var cache = caches[othIndex];\n if (!(cache\n ? cacheHas(cache, computed)\n : includes(arrays[othIndex], computed, comparator))\n ) {\n continue outer;\n }\n }\n if (seen) {\n seen.push(computed);\n }\n result.push(value);\n }\n }\n return result;\n }\n\n /**\n * The base implementation of `_.invert` and `_.invertBy` which inverts\n * `object` with values transformed by `iteratee` and set by `setter`.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} setter The function to set `accumulator` values.\n * @param {Function} iteratee The iteratee to transform values.\n * @param {Object} accumulator The initial inverted object.\n * @returns {Function} Returns `accumulator`.\n */\n function baseInverter(object, setter, iteratee, accumulator) {\n baseForOwn(object, function(value, key, object) {\n setter(accumulator, iteratee(value), key, object);\n });\n return accumulator;\n }\n\n /**\n * The base implementation of `_.invoke` without support for individual\n * method arguments.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the method to invoke.\n * @param {Array} args The arguments to invoke the method with.\n * @returns {*} Returns the result of the invoked method.\n */\n function baseInvoke(object, path, args) {\n path = castPath(path, object);\n object = parent(object, path);\n var func = object == null ? object : object[toKey(last(path))];\n return func == null ? undefined : apply(func, object, args);\n }\n\n /**\n * The base implementation of `_.isArguments`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n */\n function baseIsArguments(value) {\n return isObjectLike(value) && baseGetTag(value) == argsTag;\n }\n\n /**\n * The base implementation of `_.isArrayBuffer` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array buffer, else `false`.\n */\n function baseIsArrayBuffer(value) {\n return isObjectLike(value) && baseGetTag(value) == arrayBufferTag;\n }\n\n /**\n * The base implementation of `_.isDate` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a date object, else `false`.\n */\n function baseIsDate(value) {\n return isObjectLike(value) && baseGetTag(value) == dateTag;\n }\n\n /**\n * The base implementation of `_.isEqual` which supports partial comparisons\n * and tracks traversed objects.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @param {boolean} bitmask The bitmask flags.\n * 1 - Unordered comparison\n * 2 - Partial comparison\n * @param {Function} [customizer] The function to customize comparisons.\n * @param {Object} [stack] Tracks traversed `value` and `other` objects.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n */\n function baseIsEqual(value, other, bitmask, customizer, stack) {\n if (value === other) {\n return true;\n }\n if (value == null || other == null || (!isObjectLike(value) && !isObjectLike(other))) {\n return value !== value && other !== other;\n }\n return baseIsEqualDeep(value, other, bitmask, customizer, baseIsEqual, stack);\n }\n\n /**\n * A specialized version of `baseIsEqual` for arrays and objects which performs\n * deep comparisons and tracks traversed objects enabling objects with circular\n * references to be compared.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} [stack] Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\n function baseIsEqualDeep(object, other, bitmask, customizer, equalFunc, stack) {\n var objIsArr = isArray(object),\n othIsArr = isArray(other),\n objTag = objIsArr ? arrayTag : getTag(object),\n othTag = othIsArr ? arrayTag : getTag(other);\n\n objTag = objTag == argsTag ? objectTag : objTag;\n othTag = othTag == argsTag ? objectTag : othTag;\n\n var objIsObj = objTag == objectTag,\n othIsObj = othTag == objectTag,\n isSameTag = objTag == othTag;\n\n if (isSameTag && isBuffer(object)) {\n if (!isBuffer(other)) {\n return false;\n }\n objIsArr = true;\n objIsObj = false;\n }\n if (isSameTag && !objIsObj) {\n stack || (stack = new Stack);\n return (objIsArr || isTypedArray(object))\n ? equalArrays(object, other, bitmask, customizer, equalFunc, stack)\n : equalByTag(object, other, objTag, bitmask, customizer, equalFunc, stack);\n }\n if (!(bitmask & COMPARE_PARTIAL_FLAG)) {\n var objIsWrapped = objIsObj && hasOwnProperty.call(object, '__wrapped__'),\n othIsWrapped = othIsObj && hasOwnProperty.call(other, '__wrapped__');\n\n if (objIsWrapped || othIsWrapped) {\n var objUnwrapped = objIsWrapped ? object.value() : object,\n othUnwrapped = othIsWrapped ? other.value() : other;\n\n stack || (stack = new Stack);\n return equalFunc(objUnwrapped, othUnwrapped, bitmask, customizer, stack);\n }\n }\n if (!isSameTag) {\n return false;\n }\n stack || (stack = new Stack);\n return equalObjects(object, other, bitmask, customizer, equalFunc, stack);\n }\n\n /**\n * The base implementation of `_.isMap` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a map, else `false`.\n */\n function baseIsMap(value) {\n return isObjectLike(value) && getTag(value) == mapTag;\n }\n\n /**\n * The base implementation of `_.isMatch` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The object to inspect.\n * @param {Object} source The object of property values to match.\n * @param {Array} matchData The property names, values, and compare flags to match.\n * @param {Function} [customizer] The function to customize comparisons.\n * @returns {boolean} Returns `true` if `object` is a match, else `false`.\n */\n function baseIsMatch(object, source, matchData, customizer) {\n var index = matchData.length,\n length = index,\n noCustomizer = !customizer;\n\n if (object == null) {\n return !length;\n }\n object = Object(object);\n while (index--) {\n var data = matchData[index];\n if ((noCustomizer && data[2])\n ? data[1] !== object[data[0]]\n : !(data[0] in object)\n ) {\n return false;\n }\n }\n while (++index < length) {\n data = matchData[index];\n var key = data[0],\n objValue = object[key],\n srcValue = data[1];\n\n if (noCustomizer && data[2]) {\n if (objValue === undefined && !(key in object)) {\n return false;\n }\n } else {\n var stack = new Stack;\n if (customizer) {\n var result = customizer(objValue, srcValue, key, object, source, stack);\n }\n if (!(result === undefined\n ? baseIsEqual(srcValue, objValue, COMPARE_PARTIAL_FLAG | COMPARE_UNORDERED_FLAG, customizer, stack)\n : result\n )) {\n return false;\n }\n }\n }\n return true;\n }\n\n /**\n * The base implementation of `_.isNative` without bad shim checks.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function,\n * else `false`.\n */\n function baseIsNative(value) {\n if (!isObject(value) || isMasked(value)) {\n return false;\n }\n var pattern = isFunction(value) ? reIsNative : reIsHostCtor;\n return pattern.test(toSource(value));\n }\n\n /**\n * The base implementation of `_.isRegExp` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a regexp, else `false`.\n */\n function baseIsRegExp(value) {\n return isObjectLike(value) && baseGetTag(value) == regexpTag;\n }\n\n /**\n * The base implementation of `_.isSet` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a set, else `false`.\n */\n function baseIsSet(value) {\n return isObjectLike(value) && getTag(value) == setTag;\n }\n\n /**\n * The base implementation of `_.isTypedArray` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n */\n function baseIsTypedArray(value) {\n return isObjectLike(value) &&\n isLength(value.length) && !!typedArrayTags[baseGetTag(value)];\n }\n\n /**\n * The base implementation of `_.iteratee`.\n *\n * @private\n * @param {*} [value=_.identity] The value to convert to an iteratee.\n * @returns {Function} Returns the iteratee.\n */\n function baseIteratee(value) {\n // Don't store the `typeof` result in a variable to avoid a JIT bug in Safari 9.\n // See https://bugs.webkit.org/show_bug.cgi?id=156034 for more details.\n if (typeof value == 'function') {\n return value;\n }\n if (value == null) {\n return identity;\n }\n if (typeof value == 'object') {\n return isArray(value)\n ? baseMatchesProperty(value[0], value[1])\n : baseMatches(value);\n }\n return property(value);\n }\n\n /**\n * The base implementation of `_.keys` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\n function baseKeys(object) {\n if (!isPrototype(object)) {\n return nativeKeys(object);\n }\n var result = [];\n for (var key in Object(object)) {\n if (hasOwnProperty.call(object, key) && key != 'constructor') {\n result.push(key);\n }\n }\n return result;\n }\n\n /**\n * The base implementation of `_.keysIn` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\n function baseKeysIn(object) {\n if (!isObject(object)) {\n return nativeKeysIn(object);\n }\n var isProto = isPrototype(object),\n result = [];\n\n for (var key in object) {\n if (!(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) {\n result.push(key);\n }\n }\n return result;\n }\n\n /**\n * The base implementation of `_.lt` which doesn't coerce arguments.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is less than `other`,\n * else `false`.\n */\n function baseLt(value, other) {\n return value < other;\n }\n\n /**\n * The base implementation of `_.map` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n */\n function baseMap(collection, iteratee) {\n var index = -1,\n result = isArrayLike(collection) ? Array(collection.length) : [];\n\n baseEach(collection, function(value, key, collection) {\n result[++index] = iteratee(value, key, collection);\n });\n return result;\n }\n\n /**\n * The base implementation of `_.matches` which doesn't clone `source`.\n *\n * @private\n * @param {Object} source The object of property values to match.\n * @returns {Function} Returns the new spec function.\n */\n function baseMatches(source) {\n var matchData = getMatchData(source);\n if (matchData.length == 1 && matchData[0][2]) {\n return matchesStrictComparable(matchData[0][0], matchData[0][1]);\n }\n return function(object) {\n return object === source || baseIsMatch(object, source, matchData);\n };\n }\n\n /**\n * The base implementation of `_.matchesProperty` which doesn't clone `srcValue`.\n *\n * @private\n * @param {string} path The path of the property to get.\n * @param {*} srcValue The value to match.\n * @returns {Function} Returns the new spec function.\n */\n function baseMatchesProperty(path, srcValue) {\n if (isKey(path) && isStrictComparable(srcValue)) {\n return matchesStrictComparable(toKey(path), srcValue);\n }\n return function(object) {\n var objValue = get(object, path);\n return (objValue === undefined && objValue === srcValue)\n ? hasIn(object, path)\n : baseIsEqual(srcValue, objValue, COMPARE_PARTIAL_FLAG | COMPARE_UNORDERED_FLAG);\n };\n }\n\n /**\n * The base implementation of `_.merge` without support for multiple sources.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @param {number} srcIndex The index of `source`.\n * @param {Function} [customizer] The function to customize merged values.\n * @param {Object} [stack] Tracks traversed source values and their merged\n * counterparts.\n */\n function baseMerge(object, source, srcIndex, customizer, stack) {\n if (object === source) {\n return;\n }\n baseFor(source, function(srcValue, key) {\n stack || (stack = new Stack);\n if (isObject(srcValue)) {\n baseMergeDeep(object, source, key, srcIndex, baseMerge, customizer, stack);\n }\n else {\n var newValue = customizer\n ? customizer(safeGet(object, key), srcValue, (key + ''), object, source, stack)\n : undefined;\n\n if (newValue === undefined) {\n newValue = srcValue;\n }\n assignMergeValue(object, key, newValue);\n }\n }, keysIn);\n }\n\n /**\n * A specialized version of `baseMerge` for arrays and objects which performs\n * deep merges and tracks traversed objects enabling objects with circular\n * references to be merged.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @param {string} key The key of the value to merge.\n * @param {number} srcIndex The index of `source`.\n * @param {Function} mergeFunc The function to merge values.\n * @param {Function} [customizer] The function to customize assigned values.\n * @param {Object} [stack] Tracks traversed source values and their merged\n * counterparts.\n */\n function baseMergeDeep(object, source, key, srcIndex, mergeFunc, customizer, stack) {\n var objValue = safeGet(object, key),\n srcValue = safeGet(source, key),\n stacked = stack.get(srcValue);\n\n if (stacked) {\n assignMergeValue(object, key, stacked);\n return;\n }\n var newValue = customizer\n ? customizer(objValue, srcValue, (key + ''), object, source, stack)\n : undefined;\n\n var isCommon = newValue === undefined;\n\n if (isCommon) {\n var isArr = isArray(srcValue),\n isBuff = !isArr && isBuffer(srcValue),\n isTyped = !isArr && !isBuff && isTypedArray(srcValue);\n\n newValue = srcValue;\n if (isArr || isBuff || isTyped) {\n if (isArray(objValue)) {\n newValue = objValue;\n }\n else if (isArrayLikeObject(objValue)) {\n newValue = copyArray(objValue);\n }\n else if (isBuff) {\n isCommon = false;\n newValue = cloneBuffer(srcValue, true);\n }\n else if (isTyped) {\n isCommon = false;\n newValue = cloneTypedArray(srcValue, true);\n }\n else {\n newValue = [];\n }\n }\n else if (isPlainObject(srcValue) || isArguments(srcValue)) {\n newValue = objValue;\n if (isArguments(objValue)) {\n newValue = toPlainObject(objValue);\n }\n else if (!isObject(objValue) || isFunction(objValue)) {\n newValue = initCloneObject(srcValue);\n }\n }\n else {\n isCommon = false;\n }\n }\n if (isCommon) {\n // Recursively merge objects and arrays (susceptible to call stack limits).\n stack.set(srcValue, newValue);\n mergeFunc(newValue, srcValue, srcIndex, customizer, stack);\n stack['delete'](srcValue);\n }\n assignMergeValue(object, key, newValue);\n }\n\n /**\n * The base implementation of `_.nth` which doesn't coerce arguments.\n *\n * @private\n * @param {Array} array The array to query.\n * @param {number} n The index of the element to return.\n * @returns {*} Returns the nth element of `array`.\n */\n function baseNth(array, n) {\n var length = array.length;\n if (!length) {\n return;\n }\n n += n < 0 ? length : 0;\n return isIndex(n, length) ? array[n] : undefined;\n }\n\n /**\n * The base implementation of `_.orderBy` without param guards.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function[]|Object[]|string[]} iteratees The iteratees to sort by.\n * @param {string[]} orders The sort orders of `iteratees`.\n * @returns {Array} Returns the new sorted array.\n */\n function baseOrderBy(collection, iteratees, orders) {\n if (iteratees.length) {\n iteratees = arrayMap(iteratees, function(iteratee) {\n if (isArray(iteratee)) {\n return function(value) {\n return baseGet(value, iteratee.length === 1 ? iteratee[0] : iteratee);\n }\n }\n return iteratee;\n });\n } else {\n iteratees = [identity];\n }\n\n var index = -1;\n iteratees = arrayMap(iteratees, baseUnary(getIteratee()));\n\n var result = baseMap(collection, function(value, key, collection) {\n var criteria = arrayMap(iteratees, function(iteratee) {\n return iteratee(value);\n });\n return { 'criteria': criteria, 'index': ++index, 'value': value };\n });\n\n return baseSortBy(result, function(object, other) {\n return compareMultiple(object, other, orders);\n });\n }\n\n /**\n * The base implementation of `_.pick` without support for individual\n * property identifiers.\n *\n * @private\n * @param {Object} object The source object.\n * @param {string[]} paths The property paths to pick.\n * @returns {Object} Returns the new object.\n */\n function basePick(object, paths) {\n return basePickBy(object, paths, function(value, path) {\n return hasIn(object, path);\n });\n }\n\n /**\n * The base implementation of `_.pickBy` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The source object.\n * @param {string[]} paths The property paths to pick.\n * @param {Function} predicate The function invoked per property.\n * @returns {Object} Returns the new object.\n */\n function basePickBy(object, paths, predicate) {\n var index = -1,\n length = paths.length,\n result = {};\n\n while (++index < length) {\n var path = paths[index],\n value = baseGet(object, path);\n\n if (predicate(value, path)) {\n baseSet(result, castPath(path, object), value);\n }\n }\n return result;\n }\n\n /**\n * A specialized version of `baseProperty` which supports deep paths.\n *\n * @private\n * @param {Array|string} path The path of the property to get.\n * @returns {Function} Returns the new accessor function.\n */\n function basePropertyDeep(path) {\n return function(object) {\n return baseGet(object, path);\n };\n }\n\n /**\n * The base implementation of `_.pullAllBy` without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {Array} values The values to remove.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns `array`.\n */\n function basePullAll(array, values, iteratee, comparator) {\n var indexOf = comparator ? baseIndexOfWith : baseIndexOf,\n index = -1,\n length = values.length,\n seen = array;\n\n if (array === values) {\n values = copyArray(values);\n }\n if (iteratee) {\n seen = arrayMap(array, baseUnary(iteratee));\n }\n while (++index < length) {\n var fromIndex = 0,\n value = values[index],\n computed = iteratee ? iteratee(value) : value;\n\n while ((fromIndex = indexOf(seen, computed, fromIndex, comparator)) > -1) {\n if (seen !== array) {\n splice.call(seen, fromIndex, 1);\n }\n splice.call(array, fromIndex, 1);\n }\n }\n return array;\n }\n\n /**\n * The base implementation of `_.pullAt` without support for individual\n * indexes or capturing the removed elements.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {number[]} indexes The indexes of elements to remove.\n * @returns {Array} Returns `array`.\n */\n function basePullAt(array, indexes) {\n var length = array ? indexes.length : 0,\n lastIndex = length - 1;\n\n while (length--) {\n var index = indexes[length];\n if (length == lastIndex || index !== previous) {\n var previous = index;\n if (isIndex(index)) {\n splice.call(array, index, 1);\n } else {\n baseUnset(array, index);\n }\n }\n }\n return array;\n }\n\n /**\n * The base implementation of `_.random` without support for returning\n * floating-point numbers.\n *\n * @private\n * @param {number} lower The lower bound.\n * @param {number} upper The upper bound.\n * @returns {number} Returns the random number.\n */\n function baseRandom(lower, upper) {\n return lower + nativeFloor(nativeRandom() * (upper - lower + 1));\n }\n\n /**\n * The base implementation of `_.range` and `_.rangeRight` which doesn't\n * coerce arguments.\n *\n * @private\n * @param {number} start The start of the range.\n * @param {number} end The end of the range.\n * @param {number} step The value to increment or decrement by.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Array} Returns the range of numbers.\n */\n function baseRange(start, end, step, fromRight) {\n var index = -1,\n length = nativeMax(nativeCeil((end - start) / (step || 1)), 0),\n result = Array(length);\n\n while (length--) {\n result[fromRight ? length : ++index] = start;\n start += step;\n }\n return result;\n }\n\n /**\n * The base implementation of `_.repeat` which doesn't coerce arguments.\n *\n * @private\n * @param {string} string The string to repeat.\n * @param {number} n The number of times to repeat the string.\n * @returns {string} Returns the repeated string.\n */\n function baseRepeat(string, n) {\n var result = '';\n if (!string || n < 1 || n > MAX_SAFE_INTEGER) {\n return result;\n }\n // Leverage the exponentiation by squaring algorithm for a faster repeat.\n // See https://en.wikipedia.org/wiki/Exponentiation_by_squaring for more details.\n do {\n if (n % 2) {\n result += string;\n }\n n = nativeFloor(n / 2);\n if (n) {\n string += string;\n }\n } while (n);\n\n return result;\n }\n\n /**\n * The base implementation of `_.rest` which doesn't validate or coerce arguments.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @param {number} [start=func.length-1] The start position of the rest parameter.\n * @returns {Function} Returns the new function.\n */\n function baseRest(func, start) {\n return setToString(overRest(func, start, identity), func + '');\n }\n\n /**\n * The base implementation of `_.sample`.\n *\n * @private\n * @param {Array|Object} collection The collection to sample.\n * @returns {*} Returns the random element.\n */\n function baseSample(collection) {\n return arraySample(values(collection));\n }\n\n /**\n * The base implementation of `_.sampleSize` without param guards.\n *\n * @private\n * @param {Array|Object} collection The collection to sample.\n * @param {number} n The number of elements to sample.\n * @returns {Array} Returns the random elements.\n */\n function baseSampleSize(collection, n) {\n var array = values(collection);\n return shuffleSelf(array, baseClamp(n, 0, array.length));\n }\n\n /**\n * The base implementation of `_.set`.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {*} value The value to set.\n * @param {Function} [customizer] The function to customize path creation.\n * @returns {Object} Returns `object`.\n */\n function baseSet(object, path, value, customizer) {\n if (!isObject(object)) {\n return object;\n }\n path = castPath(path, object);\n\n var index = -1,\n length = path.length,\n lastIndex = length - 1,\n nested = object;\n\n while (nested != null && ++index < length) {\n var key = toKey(path[index]),\n newValue = value;\n\n if (key === '__proto__' || key === 'constructor' || key === 'prototype') {\n return object;\n }\n\n if (index != lastIndex) {\n var objValue = nested[key];\n newValue = customizer ? customizer(objValue, key, nested) : undefined;\n if (newValue === undefined) {\n newValue = isObject(objValue)\n ? objValue\n : (isIndex(path[index + 1]) ? [] : {});\n }\n }\n assignValue(nested, key, newValue);\n nested = nested[key];\n }\n return object;\n }\n\n /**\n * The base implementation of `setData` without support for hot loop shorting.\n *\n * @private\n * @param {Function} func The function to associate metadata with.\n * @param {*} data The metadata.\n * @returns {Function} Returns `func`.\n */\n var baseSetData = !metaMap ? identity : function(func, data) {\n metaMap.set(func, data);\n return func;\n };\n\n /**\n * The base implementation of `setToString` without support for hot loop shorting.\n *\n * @private\n * @param {Function} func The function to modify.\n * @param {Function} string The `toString` result.\n * @returns {Function} Returns `func`.\n */\n var baseSetToString = !defineProperty ? identity : function(func, string) {\n return defineProperty(func, 'toString', {\n 'configurable': true,\n 'enumerable': false,\n 'value': constant(string),\n 'writable': true\n });\n };\n\n /**\n * The base implementation of `_.shuffle`.\n *\n * @private\n * @param {Array|Object} collection The collection to shuffle.\n * @returns {Array} Returns the new shuffled array.\n */\n function baseShuffle(collection) {\n return shuffleSelf(values(collection));\n }\n\n /**\n * The base implementation of `_.slice` without an iteratee call guard.\n *\n * @private\n * @param {Array} array The array to slice.\n * @param {number} [start=0] The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns the slice of `array`.\n */\n function baseSlice(array, start, end) {\n var index = -1,\n length = array.length;\n\n if (start < 0) {\n start = -start > length ? 0 : (length + start);\n }\n end = end > length ? length : end;\n if (end < 0) {\n end += length;\n }\n length = start > end ? 0 : ((end - start) >>> 0);\n start >>>= 0;\n\n var result = Array(length);\n while (++index < length) {\n result[index] = array[index + start];\n }\n return result;\n }\n\n /**\n * The base implementation of `_.some` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if any element passes the predicate check,\n * else `false`.\n */\n function baseSome(collection, predicate) {\n var result;\n\n baseEach(collection, function(value, index, collection) {\n result = predicate(value, index, collection);\n return !result;\n });\n return !!result;\n }\n\n /**\n * The base implementation of `_.sortedIndex` and `_.sortedLastIndex` which\n * performs a binary search of `array` to determine the index at which `value`\n * should be inserted into `array` in order to maintain its sort order.\n *\n * @private\n * @param {Array} array The sorted array to inspect.\n * @param {*} value The value to evaluate.\n * @param {boolean} [retHighest] Specify returning the highest qualified index.\n * @returns {number} Returns the index at which `value` should be inserted\n * into `array`.\n */\n function baseSortedIndex(array, value, retHighest) {\n var low = 0,\n high = array == null ? low : array.length;\n\n if (typeof value == 'number' && value === value && high <= HALF_MAX_ARRAY_LENGTH) {\n while (low < high) {\n var mid = (low + high) >>> 1,\n computed = array[mid];\n\n if (computed !== null && !isSymbol(computed) &&\n (retHighest ? (computed <= value) : (computed < value))) {\n low = mid + 1;\n } else {\n high = mid;\n }\n }\n return high;\n }\n return baseSortedIndexBy(array, value, identity, retHighest);\n }\n\n /**\n * The base implementation of `_.sortedIndexBy` and `_.sortedLastIndexBy`\n * which invokes `iteratee` for `value` and each element of `array` to compute\n * their sort ranking. The iteratee is invoked with one argument; (value).\n *\n * @private\n * @param {Array} array The sorted array to inspect.\n * @param {*} value The value to evaluate.\n * @param {Function} iteratee The iteratee invoked per element.\n * @param {boolean} [retHighest] Specify returning the highest qualified index.\n * @returns {number} Returns the index at which `value` should be inserted\n * into `array`.\n */\n function baseSortedIndexBy(array, value, iteratee, retHighest) {\n var low = 0,\n high = array == null ? 0 : array.length;\n if (high === 0) {\n return 0;\n }\n\n value = iteratee(value);\n var valIsNaN = value !== value,\n valIsNull = value === null,\n valIsSymbol = isSymbol(value),\n valIsUndefined = value === undefined;\n\n while (low < high) {\n var mid = nativeFloor((low + high) / 2),\n computed = iteratee(array[mid]),\n othIsDefined = computed !== undefined,\n othIsNull = computed === null,\n othIsReflexive = computed === computed,\n othIsSymbol = isSymbol(computed);\n\n if (valIsNaN) {\n var setLow = retHighest || othIsReflexive;\n } else if (valIsUndefined) {\n setLow = othIsReflexive && (retHighest || othIsDefined);\n } else if (valIsNull) {\n setLow = othIsReflexive && othIsDefined && (retHighest || !othIsNull);\n } else if (valIsSymbol) {\n setLow = othIsReflexive && othIsDefined && !othIsNull && (retHighest || !othIsSymbol);\n } else if (othIsNull || othIsSymbol) {\n setLow = false;\n } else {\n setLow = retHighest ? (computed <= value) : (computed < value);\n }\n if (setLow) {\n low = mid + 1;\n } else {\n high = mid;\n }\n }\n return nativeMin(high, MAX_ARRAY_INDEX);\n }\n\n /**\n * The base implementation of `_.sortedUniq` and `_.sortedUniqBy` without\n * support for iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @returns {Array} Returns the new duplicate free array.\n */\n function baseSortedUniq(array, iteratee) {\n var index = -1,\n length = array.length,\n resIndex = 0,\n result = [];\n\n while (++index < length) {\n var value = array[index],\n computed = iteratee ? iteratee(value) : value;\n\n if (!index || !eq(computed, seen)) {\n var seen = computed;\n result[resIndex++] = value === 0 ? 0 : value;\n }\n }\n return result;\n }\n\n /**\n * The base implementation of `_.toNumber` which doesn't ensure correct\n * conversions of binary, hexadecimal, or octal string values.\n *\n * @private\n * @param {*} value The value to process.\n * @returns {number} Returns the number.\n */\n function baseToNumber(value) {\n if (typeof value == 'number') {\n return value;\n }\n if (isSymbol(value)) {\n return NAN;\n }\n return +value;\n }\n\n /**\n * The base implementation of `_.toString` which doesn't convert nullish\n * values to empty strings.\n *\n * @private\n * @param {*} value The value to process.\n * @returns {string} Returns the string.\n */\n function baseToString(value) {\n // Exit early for strings to avoid a performance hit in some environments.\n if (typeof value == 'string') {\n return value;\n }\n if (isArray(value)) {\n // Recursively convert values (susceptible to call stack limits).\n return arrayMap(value, baseToString) + '';\n }\n if (isSymbol(value)) {\n return symbolToString ? symbolToString.call(value) : '';\n }\n var result = (value + '');\n return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n }\n\n /**\n * The base implementation of `_.uniqBy` without support for iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new duplicate free array.\n */\n function baseUniq(array, iteratee, comparator) {\n var index = -1,\n includes = arrayIncludes,\n length = array.length,\n isCommon = true,\n result = [],\n seen = result;\n\n if (comparator) {\n isCommon = false;\n includes = arrayIncludesWith;\n }\n else if (length >= LARGE_ARRAY_SIZE) {\n var set = iteratee ? null : createSet(array);\n if (set) {\n return setToArray(set);\n }\n isCommon = false;\n includes = cacheHas;\n seen = new SetCache;\n }\n else {\n seen = iteratee ? [] : result;\n }\n outer:\n while (++index < length) {\n var value = array[index],\n computed = iteratee ? iteratee(value) : value;\n\n value = (comparator || value !== 0) ? value : 0;\n if (isCommon && computed === computed) {\n var seenIndex = seen.length;\n while (seenIndex--) {\n if (seen[seenIndex] === computed) {\n continue outer;\n }\n }\n if (iteratee) {\n seen.push(computed);\n }\n result.push(value);\n }\n else if (!includes(seen, computed, comparator)) {\n if (seen !== result) {\n seen.push(computed);\n }\n result.push(value);\n }\n }\n return result;\n }\n\n /**\n * The base implementation of `_.unset`.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {Array|string} path The property path to unset.\n * @returns {boolean} Returns `true` if the property is deleted, else `false`.\n */\n function baseUnset(object, path) {\n path = castPath(path, object);\n object = parent(object, path);\n return object == null || delete object[toKey(last(path))];\n }\n\n /**\n * The base implementation of `_.update`.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to update.\n * @param {Function} updater The function to produce the updated value.\n * @param {Function} [customizer] The function to customize path creation.\n * @returns {Object} Returns `object`.\n */\n function baseUpdate(object, path, updater, customizer) {\n return baseSet(object, path, updater(baseGet(object, path)), customizer);\n }\n\n /**\n * The base implementation of methods like `_.dropWhile` and `_.takeWhile`\n * without support for iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to query.\n * @param {Function} predicate The function invoked per iteration.\n * @param {boolean} [isDrop] Specify dropping elements instead of taking them.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Array} Returns the slice of `array`.\n */\n function baseWhile(array, predicate, isDrop, fromRight) {\n var length = array.length,\n index = fromRight ? length : -1;\n\n while ((fromRight ? index-- : ++index < length) &&\n predicate(array[index], index, array)) {}\n\n return isDrop\n ? baseSlice(array, (fromRight ? 0 : index), (fromRight ? index + 1 : length))\n : baseSlice(array, (fromRight ? index + 1 : 0), (fromRight ? length : index));\n }\n\n /**\n * The base implementation of `wrapperValue` which returns the result of\n * performing a sequence of actions on the unwrapped `value`, where each\n * successive action is supplied the return value of the previous.\n *\n * @private\n * @param {*} value The unwrapped value.\n * @param {Array} actions Actions to perform to resolve the unwrapped value.\n * @returns {*} Returns the resolved value.\n */\n function baseWrapperValue(value, actions) {\n var result = value;\n if (result instanceof LazyWrapper) {\n result = result.value();\n }\n return arrayReduce(actions, function(result, action) {\n return action.func.apply(action.thisArg, arrayPush([result], action.args));\n }, result);\n }\n\n /**\n * The base implementation of methods like `_.xor`, without support for\n * iteratee shorthands, that accepts an array of arrays to inspect.\n *\n * @private\n * @param {Array} arrays The arrays to inspect.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of values.\n */\n function baseXor(arrays, iteratee, comparator) {\n var length = arrays.length;\n if (length < 2) {\n return length ? baseUniq(arrays[0]) : [];\n }\n var index = -1,\n result = Array(length);\n\n while (++index < length) {\n var array = arrays[index],\n othIndex = -1;\n\n while (++othIndex < length) {\n if (othIndex != index) {\n result[index] = baseDifference(result[index] || array, arrays[othIndex], iteratee, comparator);\n }\n }\n }\n return baseUniq(baseFlatten(result, 1), iteratee, comparator);\n }\n\n /**\n * This base implementation of `_.zipObject` which assigns values using `assignFunc`.\n *\n * @private\n * @param {Array} props The property identifiers.\n * @param {Array} values The property values.\n * @param {Function} assignFunc The function to assign values.\n * @returns {Object} Returns the new object.\n */\n function baseZipObject(props, values, assignFunc) {\n var index = -1,\n length = props.length,\n valsLength = values.length,\n result = {};\n\n while (++index < length) {\n var value = index < valsLength ? values[index] : undefined;\n assignFunc(result, props[index], value);\n }\n return result;\n }\n\n /**\n * Casts `value` to an empty array if it's not an array like object.\n *\n * @private\n * @param {*} value The value to inspect.\n * @returns {Array|Object} Returns the cast array-like object.\n */\n function castArrayLikeObject(value) {\n return isArrayLikeObject(value) ? value : [];\n }\n\n /**\n * Casts `value` to `identity` if it's not a function.\n *\n * @private\n * @param {*} value The value to inspect.\n * @returns {Function} Returns cast function.\n */\n function castFunction(value) {\n return typeof value == 'function' ? value : identity;\n }\n\n /**\n * Casts `value` to a path array if it's not one.\n *\n * @private\n * @param {*} value The value to inspect.\n * @param {Object} [object] The object to query keys on.\n * @returns {Array} Returns the cast property path array.\n */\n function castPath(value, object) {\n if (isArray(value)) {\n return value;\n }\n return isKey(value, object) ? [value] : stringToPath(toString(value));\n }\n\n /**\n * A `baseRest` alias which can be replaced with `identity` by module\n * replacement plugins.\n *\n * @private\n * @type {Function}\n * @param {Function} func The function to apply a rest parameter to.\n * @returns {Function} Returns the new function.\n */\n var castRest = baseRest;\n\n /**\n * Casts `array` to a slice if it's needed.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {number} start The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns the cast slice.\n */\n function castSlice(array, start, end) {\n var length = array.length;\n end = end === undefined ? length : end;\n return (!start && end >= length) ? array : baseSlice(array, start, end);\n }\n\n /**\n * A simple wrapper around the global [`clearTimeout`](https://mdn.io/clearTimeout).\n *\n * @private\n * @param {number|Object} id The timer id or timeout object of the timer to clear.\n */\n var clearTimeout = ctxClearTimeout || function(id) {\n return root.clearTimeout(id);\n };\n\n /**\n * Creates a clone of `buffer`.\n *\n * @private\n * @param {Buffer} buffer The buffer to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Buffer} Returns the cloned buffer.\n */\n function cloneBuffer(buffer, isDeep) {\n if (isDeep) {\n return buffer.slice();\n }\n var length = buffer.length,\n result = allocUnsafe ? allocUnsafe(length) : new buffer.constructor(length);\n\n buffer.copy(result);\n return result;\n }\n\n /**\n * Creates a clone of `arrayBuffer`.\n *\n * @private\n * @param {ArrayBuffer} arrayBuffer The array buffer to clone.\n * @returns {ArrayBuffer} Returns the cloned array buffer.\n */\n function cloneArrayBuffer(arrayBuffer) {\n var result = new arrayBuffer.constructor(arrayBuffer.byteLength);\n new Uint8Array(result).set(new Uint8Array(arrayBuffer));\n return result;\n }\n\n /**\n * Creates a clone of `dataView`.\n *\n * @private\n * @param {Object} dataView The data view to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned data view.\n */\n function cloneDataView(dataView, isDeep) {\n var buffer = isDeep ? cloneArrayBuffer(dataView.buffer) : dataView.buffer;\n return new dataView.constructor(buffer, dataView.byteOffset, dataView.byteLength);\n }\n\n /**\n * Creates a clone of `regexp`.\n *\n * @private\n * @param {Object} regexp The regexp to clone.\n * @returns {Object} Returns the cloned regexp.\n */\n function cloneRegExp(regexp) {\n var result = new regexp.constructor(regexp.source, reFlags.exec(regexp));\n result.lastIndex = regexp.lastIndex;\n return result;\n }\n\n /**\n * Creates a clone of the `symbol` object.\n *\n * @private\n * @param {Object} symbol The symbol object to clone.\n * @returns {Object} Returns the cloned symbol object.\n */\n function cloneSymbol(symbol) {\n return symbolValueOf ? Object(symbolValueOf.call(symbol)) : {};\n }\n\n /**\n * Creates a clone of `typedArray`.\n *\n * @private\n * @param {Object} typedArray The typed array to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned typed array.\n */\n function cloneTypedArray(typedArray, isDeep) {\n var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer;\n return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length);\n }\n\n /**\n * Compares values to sort them in ascending order.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {number} Returns the sort order indicator for `value`.\n */\n function compareAscending(value, other) {\n if (value !== other) {\n var valIsDefined = value !== undefined,\n valIsNull = value === null,\n valIsReflexive = value === value,\n valIsSymbol = isSymbol(value);\n\n var othIsDefined = other !== undefined,\n othIsNull = other === null,\n othIsReflexive = other === other,\n othIsSymbol = isSymbol(other);\n\n if ((!othIsNull && !othIsSymbol && !valIsSymbol && value > other) ||\n (valIsSymbol && othIsDefined && othIsReflexive && !othIsNull && !othIsSymbol) ||\n (valIsNull && othIsDefined && othIsReflexive) ||\n (!valIsDefined && othIsReflexive) ||\n !valIsReflexive) {\n return 1;\n }\n if ((!valIsNull && !valIsSymbol && !othIsSymbol && value < other) ||\n (othIsSymbol && valIsDefined && valIsReflexive && !valIsNull && !valIsSymbol) ||\n (othIsNull && valIsDefined && valIsReflexive) ||\n (!othIsDefined && valIsReflexive) ||\n !othIsReflexive) {\n return -1;\n }\n }\n return 0;\n }\n\n /**\n * Used by `_.orderBy` to compare multiple properties of a value to another\n * and stable sort them.\n *\n * If `orders` is unspecified, all values are sorted in ascending order. Otherwise,\n * specify an order of \"desc\" for descending or \"asc\" for ascending sort order\n * of corresponding values.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {boolean[]|string[]} orders The order to sort by for each property.\n * @returns {number} Returns the sort order indicator for `object`.\n */\n function compareMultiple(object, other, orders) {\n var index = -1,\n objCriteria = object.criteria,\n othCriteria = other.criteria,\n length = objCriteria.length,\n ordersLength = orders.length;\n\n while (++index < length) {\n var result = compareAscending(objCriteria[index], othCriteria[index]);\n if (result) {\n if (index >= ordersLength) {\n return result;\n }\n var order = orders[index];\n return result * (order == 'desc' ? -1 : 1);\n }\n }\n // Fixes an `Array#sort` bug in the JS engine embedded in Adobe applications\n // that causes it, under certain circumstances, to provide the same value for\n // `object` and `other`. See https://github.com/jashkenas/underscore/pull/1247\n // for more details.\n //\n // This also ensures a stable sort in V8 and other engines.\n // See https://bugs.chromium.org/p/v8/issues/detail?id=90 for more details.\n return object.index - other.index;\n }\n\n /**\n * Creates an array that is the composition of partially applied arguments,\n * placeholders, and provided arguments into a single array of arguments.\n *\n * @private\n * @param {Array} args The provided arguments.\n * @param {Array} partials The arguments to prepend to those provided.\n * @param {Array} holders The `partials` placeholder indexes.\n * @params {boolean} [isCurried] Specify composing for a curried function.\n * @returns {Array} Returns the new array of composed arguments.\n */\n function composeArgs(args, partials, holders, isCurried) {\n var argsIndex = -1,\n argsLength = args.length,\n holdersLength = holders.length,\n leftIndex = -1,\n leftLength = partials.length,\n rangeLength = nativeMax(argsLength - holdersLength, 0),\n result = Array(leftLength + rangeLength),\n isUncurried = !isCurried;\n\n while (++leftIndex < leftLength) {\n result[leftIndex] = partials[leftIndex];\n }\n while (++argsIndex < holdersLength) {\n if (isUncurried || argsIndex < argsLength) {\n result[holders[argsIndex]] = args[argsIndex];\n }\n }\n while (rangeLength--) {\n result[leftIndex++] = args[argsIndex++];\n }\n return result;\n }\n\n /**\n * This function is like `composeArgs` except that the arguments composition\n * is tailored for `_.partialRight`.\n *\n * @private\n * @param {Array} args The provided arguments.\n * @param {Array} partials The arguments to append to those provided.\n * @param {Array} holders The `partials` placeholder indexes.\n * @params {boolean} [isCurried] Specify composing for a curried function.\n * @returns {Array} Returns the new array of composed arguments.\n */\n function composeArgsRight(args, partials, holders, isCurried) {\n var argsIndex = -1,\n argsLength = args.length,\n holdersIndex = -1,\n holdersLength = holders.length,\n rightIndex = -1,\n rightLength = partials.length,\n rangeLength = nativeMax(argsLength - holdersLength, 0),\n result = Array(rangeLength + rightLength),\n isUncurried = !isCurried;\n\n while (++argsIndex < rangeLength) {\n result[argsIndex] = args[argsIndex];\n }\n var offset = argsIndex;\n while (++rightIndex < rightLength) {\n result[offset + rightIndex] = partials[rightIndex];\n }\n while (++holdersIndex < holdersLength) {\n if (isUncurried || argsIndex < argsLength) {\n result[offset + holders[holdersIndex]] = args[argsIndex++];\n }\n }\n return result;\n }\n\n /**\n * Copies the values of `source` to `array`.\n *\n * @private\n * @param {Array} source The array to copy values from.\n * @param {Array} [array=[]] The array to copy values to.\n * @returns {Array} Returns `array`.\n */\n function copyArray(source, array) {\n var index = -1,\n length = source.length;\n\n array || (array = Array(length));\n while (++index < length) {\n array[index] = source[index];\n }\n return array;\n }\n\n /**\n * Copies properties of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy properties from.\n * @param {Array} props The property identifiers to copy.\n * @param {Object} [object={}] The object to copy properties to.\n * @param {Function} [customizer] The function to customize copied values.\n * @returns {Object} Returns `object`.\n */\n function copyObject(source, props, object, customizer) {\n var isNew = !object;\n object || (object = {});\n\n var index = -1,\n length = props.length;\n\n while (++index < length) {\n var key = props[index];\n\n var newValue = customizer\n ? customizer(object[key], source[key], key, object, source)\n : undefined;\n\n if (newValue === undefined) {\n newValue = source[key];\n }\n if (isNew) {\n baseAssignValue(object, key, newValue);\n } else {\n assignValue(object, key, newValue);\n }\n }\n return object;\n }\n\n /**\n * Copies own symbols of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy symbols from.\n * @param {Object} [object={}] The object to copy symbols to.\n * @returns {Object} Returns `object`.\n */\n function copySymbols(source, object) {\n return copyObject(source, getSymbols(source), object);\n }\n\n /**\n * Copies own and inherited symbols of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy symbols from.\n * @param {Object} [object={}] The object to copy symbols to.\n * @returns {Object} Returns `object`.\n */\n function copySymbolsIn(source, object) {\n return copyObject(source, getSymbolsIn(source), object);\n }\n\n /**\n * Creates a function like `_.groupBy`.\n *\n * @private\n * @param {Function} setter The function to set accumulator values.\n * @param {Function} [initializer] The accumulator object initializer.\n * @returns {Function} Returns the new aggregator function.\n */\n function createAggregator(setter, initializer) {\n return function(collection, iteratee) {\n var func = isArray(collection) ? arrayAggregator : baseAggregator,\n accumulator = initializer ? initializer() : {};\n\n return func(collection, setter, getIteratee(iteratee, 2), accumulator);\n };\n }\n\n /**\n * Creates a function like `_.assign`.\n *\n * @private\n * @param {Function} assigner The function to assign values.\n * @returns {Function} Returns the new assigner function.\n */\n function createAssigner(assigner) {\n return baseRest(function(object, sources) {\n var index = -1,\n length = sources.length,\n customizer = length > 1 ? sources[length - 1] : undefined,\n guard = length > 2 ? sources[2] : undefined;\n\n customizer = (assigner.length > 3 && typeof customizer == 'function')\n ? (length--, customizer)\n : undefined;\n\n if (guard && isIterateeCall(sources[0], sources[1], guard)) {\n customizer = length < 3 ? undefined : customizer;\n length = 1;\n }\n object = Object(object);\n while (++index < length) {\n var source = sources[index];\n if (source) {\n assigner(object, source, index, customizer);\n }\n }\n return object;\n });\n }\n\n /**\n * Creates a `baseEach` or `baseEachRight` function.\n *\n * @private\n * @param {Function} eachFunc The function to iterate over a collection.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new base function.\n */\n function createBaseEach(eachFunc, fromRight) {\n return function(collection, iteratee) {\n if (collection == null) {\n return collection;\n }\n if (!isArrayLike(collection)) {\n return eachFunc(collection, iteratee);\n }\n var length = collection.length,\n index = fromRight ? length : -1,\n iterable = Object(collection);\n\n while ((fromRight ? index-- : ++index < length)) {\n if (iteratee(iterable[index], index, iterable) === false) {\n break;\n }\n }\n return collection;\n };\n }\n\n /**\n * Creates a base function for methods like `_.forIn` and `_.forOwn`.\n *\n * @private\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new base function.\n */\n function createBaseFor(fromRight) {\n return function(object, iteratee, keysFunc) {\n var index = -1,\n iterable = Object(object),\n props = keysFunc(object),\n length = props.length;\n\n while (length--) {\n var key = props[fromRight ? length : ++index];\n if (iteratee(iterable[key], key, iterable) === false) {\n break;\n }\n }\n return object;\n };\n }\n\n /**\n * Creates a function that wraps `func` to invoke it with the optional `this`\n * binding of `thisArg`.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @param {*} [thisArg] The `this` binding of `func`.\n * @returns {Function} Returns the new wrapped function.\n */\n function createBind(func, bitmask, thisArg) {\n var isBind = bitmask & WRAP_BIND_FLAG,\n Ctor = createCtor(func);\n\n function wrapper() {\n var fn = (this && this !== root && this instanceof wrapper) ? Ctor : func;\n return fn.apply(isBind ? thisArg : this, arguments);\n }\n return wrapper;\n }\n\n /**\n * Creates a function like `_.lowerFirst`.\n *\n * @private\n * @param {string} methodName The name of the `String` case method to use.\n * @returns {Function} Returns the new case function.\n */\n function createCaseFirst(methodName) {\n return function(string) {\n string = toString(string);\n\n var strSymbols = hasUnicode(string)\n ? stringToArray(string)\n : undefined;\n\n var chr = strSymbols\n ? strSymbols[0]\n : string.charAt(0);\n\n var trailing = strSymbols\n ? castSlice(strSymbols, 1).join('')\n : string.slice(1);\n\n return chr[methodName]() + trailing;\n };\n }\n\n /**\n * Creates a function like `_.camelCase`.\n *\n * @private\n * @param {Function} callback The function to combine each word.\n * @returns {Function} Returns the new compounder function.\n */\n function createCompounder(callback) {\n return function(string) {\n return arrayReduce(words(deburr(string).replace(reApos, '')), callback, '');\n };\n }\n\n /**\n * Creates a function that produces an instance of `Ctor` regardless of\n * whether it was invoked as part of a `new` expression or by `call` or `apply`.\n *\n * @private\n * @param {Function} Ctor The constructor to wrap.\n * @returns {Function} Returns the new wrapped function.\n */\n function createCtor(Ctor) {\n return function() {\n // Use a `switch` statement to work with class constructors. See\n // http://ecma-international.org/ecma-262/7.0/#sec-ecmascript-function-objects-call-thisargument-argumentslist\n // for more details.\n var args = arguments;\n switch (args.length) {\n case 0: return new Ctor;\n case 1: return new Ctor(args[0]);\n case 2: return new Ctor(args[0], args[1]);\n case 3: return new Ctor(args[0], args[1], args[2]);\n case 4: return new Ctor(args[0], args[1], args[2], args[3]);\n case 5: return new Ctor(args[0], args[1], args[2], args[3], args[4]);\n case 6: return new Ctor(args[0], args[1], args[2], args[3], args[4], args[5]);\n case 7: return new Ctor(args[0], args[1], args[2], args[3], args[4], args[5], args[6]);\n }\n var thisBinding = baseCreate(Ctor.prototype),\n result = Ctor.apply(thisBinding, args);\n\n // Mimic the constructor's `return` behavior.\n // See https://es5.github.io/#x13.2.2 for more details.\n return isObject(result) ? result : thisBinding;\n };\n }\n\n /**\n * Creates a function that wraps `func` to enable currying.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @param {number} arity The arity of `func`.\n * @returns {Function} Returns the new wrapped function.\n */\n function createCurry(func, bitmask, arity) {\n var Ctor = createCtor(func);\n\n function wrapper() {\n var length = arguments.length,\n args = Array(length),\n index = length,\n placeholder = getHolder(wrapper);\n\n while (index--) {\n args[index] = arguments[index];\n }\n var holders = (length < 3 && args[0] !== placeholder && args[length - 1] !== placeholder)\n ? []\n : replaceHolders(args, placeholder);\n\n length -= holders.length;\n if (length < arity) {\n return createRecurry(\n func, bitmask, createHybrid, wrapper.placeholder, undefined,\n args, holders, undefined, undefined, arity - length);\n }\n var fn = (this && this !== root && this instanceof wrapper) ? Ctor : func;\n return apply(fn, this, args);\n }\n return wrapper;\n }\n\n /**\n * Creates a `_.find` or `_.findLast` function.\n *\n * @private\n * @param {Function} findIndexFunc The function to find the collection index.\n * @returns {Function} Returns the new find function.\n */\n function createFind(findIndexFunc) {\n return function(collection, predicate, fromIndex) {\n var iterable = Object(collection);\n if (!isArrayLike(collection)) {\n var iteratee = getIteratee(predicate, 3);\n collection = keys(collection);\n predicate = function(key) { return iteratee(iterable[key], key, iterable); };\n }\n var index = findIndexFunc(collection, predicate, fromIndex);\n return index > -1 ? iterable[iteratee ? collection[index] : index] : undefined;\n };\n }\n\n /**\n * Creates a `_.flow` or `_.flowRight` function.\n *\n * @private\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new flow function.\n */\n function createFlow(fromRight) {\n return flatRest(function(funcs) {\n var length = funcs.length,\n index = length,\n prereq = LodashWrapper.prototype.thru;\n\n if (fromRight) {\n funcs.reverse();\n }\n while (index--) {\n var func = funcs[index];\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n if (prereq && !wrapper && getFuncName(func) == 'wrapper') {\n var wrapper = new LodashWrapper([], true);\n }\n }\n index = wrapper ? index : length;\n while (++index < length) {\n func = funcs[index];\n\n var funcName = getFuncName(func),\n data = funcName == 'wrapper' ? getData(func) : undefined;\n\n if (data && isLaziable(data[0]) &&\n data[1] == (WRAP_ARY_FLAG | WRAP_CURRY_FLAG | WRAP_PARTIAL_FLAG | WRAP_REARG_FLAG) &&\n !data[4].length && data[9] == 1\n ) {\n wrapper = wrapper[getFuncName(data[0])].apply(wrapper, data[3]);\n } else {\n wrapper = (func.length == 1 && isLaziable(func))\n ? wrapper[funcName]()\n : wrapper.thru(func);\n }\n }\n return function() {\n var args = arguments,\n value = args[0];\n\n if (wrapper && args.length == 1 && isArray(value)) {\n return wrapper.plant(value).value();\n }\n var index = 0,\n result = length ? funcs[index].apply(this, args) : value;\n\n while (++index < length) {\n result = funcs[index].call(this, result);\n }\n return result;\n };\n });\n }\n\n /**\n * Creates a function that wraps `func` to invoke it with optional `this`\n * binding of `thisArg`, partial application, and currying.\n *\n * @private\n * @param {Function|string} func The function or method name to wrap.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @param {*} [thisArg] The `this` binding of `func`.\n * @param {Array} [partials] The arguments to prepend to those provided to\n * the new function.\n * @param {Array} [holders] The `partials` placeholder indexes.\n * @param {Array} [partialsRight] The arguments to append to those provided\n * to the new function.\n * @param {Array} [holdersRight] The `partialsRight` placeholder indexes.\n * @param {Array} [argPos] The argument positions of the new function.\n * @param {number} [ary] The arity cap of `func`.\n * @param {number} [arity] The arity of `func`.\n * @returns {Function} Returns the new wrapped function.\n */\n function createHybrid(func, bitmask, thisArg, partials, holders, partialsRight, holdersRight, argPos, ary, arity) {\n var isAry = bitmask & WRAP_ARY_FLAG,\n isBind = bitmask & WRAP_BIND_FLAG,\n isBindKey = bitmask & WRAP_BIND_KEY_FLAG,\n isCurried = bitmask & (WRAP_CURRY_FLAG | WRAP_CURRY_RIGHT_FLAG),\n isFlip = bitmask & WRAP_FLIP_FLAG,\n Ctor = isBindKey ? undefined : createCtor(func);\n\n function wrapper() {\n var length = arguments.length,\n args = Array(length),\n index = length;\n\n while (index--) {\n args[index] = arguments[index];\n }\n if (isCurried) {\n var placeholder = getHolder(wrapper),\n holdersCount = countHolders(args, placeholder);\n }\n if (partials) {\n args = composeArgs(args, partials, holders, isCurried);\n }\n if (partialsRight) {\n args = composeArgsRight(args, partialsRight, holdersRight, isCurried);\n }\n length -= holdersCount;\n if (isCurried && length < arity) {\n var newHolders = replaceHolders(args, placeholder);\n return createRecurry(\n func, bitmask, createHybrid, wrapper.placeholder, thisArg,\n args, newHolders, argPos, ary, arity - length\n );\n }\n var thisBinding = isBind ? thisArg : this,\n fn = isBindKey ? thisBinding[func] : func;\n\n length = args.length;\n if (argPos) {\n args = reorder(args, argPos);\n } else if (isFlip && length > 1) {\n args.reverse();\n }\n if (isAry && ary < length) {\n args.length = ary;\n }\n if (this && this !== root && this instanceof wrapper) {\n fn = Ctor || createCtor(fn);\n }\n return fn.apply(thisBinding, args);\n }\n return wrapper;\n }\n\n /**\n * Creates a function like `_.invertBy`.\n *\n * @private\n * @param {Function} setter The function to set accumulator values.\n * @param {Function} toIteratee The function to resolve iteratees.\n * @returns {Function} Returns the new inverter function.\n */\n function createInverter(setter, toIteratee) {\n return function(object, iteratee) {\n return baseInverter(object, setter, toIteratee(iteratee), {});\n };\n }\n\n /**\n * Creates a function that performs a mathematical operation on two values.\n *\n * @private\n * @param {Function} operator The function to perform the operation.\n * @param {number} [defaultValue] The value used for `undefined` arguments.\n * @returns {Function} Returns the new mathematical operation function.\n */\n function createMathOperation(operator, defaultValue) {\n return function(value, other) {\n var result;\n if (value === undefined && other === undefined) {\n return defaultValue;\n }\n if (value !== undefined) {\n result = value;\n }\n if (other !== undefined) {\n if (result === undefined) {\n return other;\n }\n if (typeof value == 'string' || typeof other == 'string') {\n value = baseToString(value);\n other = baseToString(other);\n } else {\n value = baseToNumber(value);\n other = baseToNumber(other);\n }\n result = operator(value, other);\n }\n return result;\n };\n }\n\n /**\n * Creates a function like `_.over`.\n *\n * @private\n * @param {Function} arrayFunc The function to iterate over iteratees.\n * @returns {Function} Returns the new over function.\n */\n function createOver(arrayFunc) {\n return flatRest(function(iteratees) {\n iteratees = arrayMap(iteratees, baseUnary(getIteratee()));\n return baseRest(function(args) {\n var thisArg = this;\n return arrayFunc(iteratees, function(iteratee) {\n return apply(iteratee, thisArg, args);\n });\n });\n });\n }\n\n /**\n * Creates the padding for `string` based on `length`. The `chars` string\n * is truncated if the number of characters exceeds `length`.\n *\n * @private\n * @param {number} length The padding length.\n * @param {string} [chars=' '] The string used as padding.\n * @returns {string} Returns the padding for `string`.\n */\n function createPadding(length, chars) {\n chars = chars === undefined ? ' ' : baseToString(chars);\n\n var charsLength = chars.length;\n if (charsLength < 2) {\n return charsLength ? baseRepeat(chars, length) : chars;\n }\n var result = baseRepeat(chars, nativeCeil(length / stringSize(chars)));\n return hasUnicode(chars)\n ? castSlice(stringToArray(result), 0, length).join('')\n : result.slice(0, length);\n }\n\n /**\n * Creates a function that wraps `func` to invoke it with the `this` binding\n * of `thisArg` and `partials` prepended to the arguments it receives.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @param {*} thisArg The `this` binding of `func`.\n * @param {Array} partials The arguments to prepend to those provided to\n * the new function.\n * @returns {Function} Returns the new wrapped function.\n */\n function createPartial(func, bitmask, thisArg, partials) {\n var isBind = bitmask & WRAP_BIND_FLAG,\n Ctor = createCtor(func);\n\n function wrapper() {\n var argsIndex = -1,\n argsLength = arguments.length,\n leftIndex = -1,\n leftLength = partials.length,\n args = Array(leftLength + argsLength),\n fn = (this && this !== root && this instanceof wrapper) ? Ctor : func;\n\n while (++leftIndex < leftLength) {\n args[leftIndex] = partials[leftIndex];\n }\n while (argsLength--) {\n args[leftIndex++] = arguments[++argsIndex];\n }\n return apply(fn, isBind ? thisArg : this, args);\n }\n return wrapper;\n }\n\n /**\n * Creates a `_.range` or `_.rangeRight` function.\n *\n * @private\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new range function.\n */\n function createRange(fromRight) {\n return function(start, end, step) {\n if (step && typeof step != 'number' && isIterateeCall(start, end, step)) {\n end = step = undefined;\n }\n // Ensure the sign of `-0` is preserved.\n start = toFinite(start);\n if (end === undefined) {\n end = start;\n start = 0;\n } else {\n end = toFinite(end);\n }\n step = step === undefined ? (start < end ? 1 : -1) : toFinite(step);\n return baseRange(start, end, step, fromRight);\n };\n }\n\n /**\n * Creates a function that performs a relational operation on two values.\n *\n * @private\n * @param {Function} operator The function to perform the operation.\n * @returns {Function} Returns the new relational operation function.\n */\n function createRelationalOperation(operator) {\n return function(value, other) {\n if (!(typeof value == 'string' && typeof other == 'string')) {\n value = toNumber(value);\n other = toNumber(other);\n }\n return operator(value, other);\n };\n }\n\n /**\n * Creates a function that wraps `func` to continue currying.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @param {Function} wrapFunc The function to create the `func` wrapper.\n * @param {*} placeholder The placeholder value.\n * @param {*} [thisArg] The `this` binding of `func`.\n * @param {Array} [partials] The arguments to prepend to those provided to\n * the new function.\n * @param {Array} [holders] The `partials` placeholder indexes.\n * @param {Array} [argPos] The argument positions of the new function.\n * @param {number} [ary] The arity cap of `func`.\n * @param {number} [arity] The arity of `func`.\n * @returns {Function} Returns the new wrapped function.\n */\n function createRecurry(func, bitmask, wrapFunc, placeholder, thisArg, partials, holders, argPos, ary, arity) {\n var isCurry = bitmask & WRAP_CURRY_FLAG,\n newHolders = isCurry ? holders : undefined,\n newHoldersRight = isCurry ? undefined : holders,\n newPartials = isCurry ? partials : undefined,\n newPartialsRight = isCurry ? undefined : partials;\n\n bitmask |= (isCurry ? WRAP_PARTIAL_FLAG : WRAP_PARTIAL_RIGHT_FLAG);\n bitmask &= ~(isCurry ? WRAP_PARTIAL_RIGHT_FLAG : WRAP_PARTIAL_FLAG);\n\n if (!(bitmask & WRAP_CURRY_BOUND_FLAG)) {\n bitmask &= ~(WRAP_BIND_FLAG | WRAP_BIND_KEY_FLAG);\n }\n var newData = [\n func, bitmask, thisArg, newPartials, newHolders, newPartialsRight,\n newHoldersRight, argPos, ary, arity\n ];\n\n var result = wrapFunc.apply(undefined, newData);\n if (isLaziable(func)) {\n setData(result, newData);\n }\n result.placeholder = placeholder;\n return setWrapToString(result, func, bitmask);\n }\n\n /**\n * Creates a function like `_.round`.\n *\n * @private\n * @param {string} methodName The name of the `Math` method to use when rounding.\n * @returns {Function} Returns the new round function.\n */\n function createRound(methodName) {\n var func = Math[methodName];\n return function(number, precision) {\n number = toNumber(number);\n precision = precision == null ? 0 : nativeMin(toInteger(precision), 292);\n if (precision && nativeIsFinite(number)) {\n // Shift with exponential notation to avoid floating-point issues.\n // See [MDN](https://mdn.io/round#Examples) for more details.\n var pair = (toString(number) + 'e').split('e'),\n value = func(pair[0] + 'e' + (+pair[1] + precision));\n\n pair = (toString(value) + 'e').split('e');\n return +(pair[0] + 'e' + (+pair[1] - precision));\n }\n return func(number);\n };\n }\n\n /**\n * Creates a set object of `values`.\n *\n * @private\n * @param {Array} values The values to add to the set.\n * @returns {Object} Returns the new set.\n */\n var createSet = !(Set && (1 / setToArray(new Set([,-0]))[1]) == INFINITY) ? noop : function(values) {\n return new Set(values);\n };\n\n /**\n * Creates a `_.toPairs` or `_.toPairsIn` function.\n *\n * @private\n * @param {Function} keysFunc The function to get the keys of a given object.\n * @returns {Function} Returns the new pairs function.\n */\n function createToPairs(keysFunc) {\n return function(object) {\n var tag = getTag(object);\n if (tag == mapTag) {\n return mapToArray(object);\n }\n if (tag == setTag) {\n return setToPairs(object);\n }\n return baseToPairs(object, keysFunc(object));\n };\n }\n\n /**\n * Creates a function that either curries or invokes `func` with optional\n * `this` binding and partially applied arguments.\n *\n * @private\n * @param {Function|string} func The function or method name to wrap.\n * @param {number} bitmask The bitmask flags.\n * 1 - `_.bind`\n * 2 - `_.bindKey`\n * 4 - `_.curry` or `_.curryRight` of a bound function\n * 8 - `_.curry`\n * 16 - `_.curryRight`\n * 32 - `_.partial`\n * 64 - `_.partialRight`\n * 128 - `_.rearg`\n * 256 - `_.ary`\n * 512 - `_.flip`\n * @param {*} [thisArg] The `this` binding of `func`.\n * @param {Array} [partials] The arguments to be partially applied.\n * @param {Array} [holders] The `partials` placeholder indexes.\n * @param {Array} [argPos] The argument positions of the new function.\n * @param {number} [ary] The arity cap of `func`.\n * @param {number} [arity] The arity of `func`.\n * @returns {Function} Returns the new wrapped function.\n */\n function createWrap(func, bitmask, thisArg, partials, holders, argPos, ary, arity) {\n var isBindKey = bitmask & WRAP_BIND_KEY_FLAG;\n if (!isBindKey && typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n var length = partials ? partials.length : 0;\n if (!length) {\n bitmask &= ~(WRAP_PARTIAL_FLAG | WRAP_PARTIAL_RIGHT_FLAG);\n partials = holders = undefined;\n }\n ary = ary === undefined ? ary : nativeMax(toInteger(ary), 0);\n arity = arity === undefined ? arity : toInteger(arity);\n length -= holders ? holders.length : 0;\n\n if (bitmask & WRAP_PARTIAL_RIGHT_FLAG) {\n var partialsRight = partials,\n holdersRight = holders;\n\n partials = holders = undefined;\n }\n var data = isBindKey ? undefined : getData(func);\n\n var newData = [\n func, bitmask, thisArg, partials, holders, partialsRight, holdersRight,\n argPos, ary, arity\n ];\n\n if (data) {\n mergeData(newData, data);\n }\n func = newData[0];\n bitmask = newData[1];\n thisArg = newData[2];\n partials = newData[3];\n holders = newData[4];\n arity = newData[9] = newData[9] === undefined\n ? (isBindKey ? 0 : func.length)\n : nativeMax(newData[9] - length, 0);\n\n if (!arity && bitmask & (WRAP_CURRY_FLAG | WRAP_CURRY_RIGHT_FLAG)) {\n bitmask &= ~(WRAP_CURRY_FLAG | WRAP_CURRY_RIGHT_FLAG);\n }\n if (!bitmask || bitmask == WRAP_BIND_FLAG) {\n var result = createBind(func, bitmask, thisArg);\n } else if (bitmask == WRAP_CURRY_FLAG || bitmask == WRAP_CURRY_RIGHT_FLAG) {\n result = createCurry(func, bitmask, arity);\n } else if ((bitmask == WRAP_PARTIAL_FLAG || bitmask == (WRAP_BIND_FLAG | WRAP_PARTIAL_FLAG)) && !holders.length) {\n result = createPartial(func, bitmask, thisArg, partials);\n } else {\n result = createHybrid.apply(undefined, newData);\n }\n var setter = data ? baseSetData : setData;\n return setWrapToString(setter(result, newData), func, bitmask);\n }\n\n /**\n * Used by `_.defaults` to customize its `_.assignIn` use to assign properties\n * of source objects to the destination object for all destination properties\n * that resolve to `undefined`.\n *\n * @private\n * @param {*} objValue The destination value.\n * @param {*} srcValue The source value.\n * @param {string} key The key of the property to assign.\n * @param {Object} object The parent object of `objValue`.\n * @returns {*} Returns the value to assign.\n */\n function customDefaultsAssignIn(objValue, srcValue, key, object) {\n if (objValue === undefined ||\n (eq(objValue, objectProto[key]) && !hasOwnProperty.call(object, key))) {\n return srcValue;\n }\n return objValue;\n }\n\n /**\n * Used by `_.defaultsDeep` to customize its `_.merge` use to merge source\n * objects into destination objects that are passed thru.\n *\n * @private\n * @param {*} objValue The destination value.\n * @param {*} srcValue The source value.\n * @param {string} key The key of the property to merge.\n * @param {Object} object The parent object of `objValue`.\n * @param {Object} source The parent object of `srcValue`.\n * @param {Object} [stack] Tracks traversed source values and their merged\n * counterparts.\n * @returns {*} Returns the value to assign.\n */\n function customDefaultsMerge(objValue, srcValue, key, object, source, stack) {\n if (isObject(objValue) && isObject(srcValue)) {\n // Recursively merge objects and arrays (susceptible to call stack limits).\n stack.set(srcValue, objValue);\n baseMerge(objValue, srcValue, undefined, customDefaultsMerge, stack);\n stack['delete'](srcValue);\n }\n return objValue;\n }\n\n /**\n * Used by `_.omit` to customize its `_.cloneDeep` use to only clone plain\n * objects.\n *\n * @private\n * @param {*} value The value to inspect.\n * @param {string} key The key of the property to inspect.\n * @returns {*} Returns the uncloned value or `undefined` to defer cloning to `_.cloneDeep`.\n */\n function customOmitClone(value) {\n return isPlainObject(value) ? undefined : value;\n }\n\n /**\n * A specialized version of `baseIsEqualDeep` for arrays with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Array} array The array to compare.\n * @param {Array} other The other array to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `array` and `other` objects.\n * @returns {boolean} Returns `true` if the arrays are equivalent, else `false`.\n */\n function equalArrays(array, other, bitmask, customizer, equalFunc, stack) {\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n arrLength = array.length,\n othLength = other.length;\n\n if (arrLength != othLength && !(isPartial && othLength > arrLength)) {\n return false;\n }\n // Check that cyclic values are equal.\n var arrStacked = stack.get(array);\n var othStacked = stack.get(other);\n if (arrStacked && othStacked) {\n return arrStacked == other && othStacked == array;\n }\n var index = -1,\n result = true,\n seen = (bitmask & COMPARE_UNORDERED_FLAG) ? new SetCache : undefined;\n\n stack.set(array, other);\n stack.set(other, array);\n\n // Ignore non-index properties.\n while (++index < arrLength) {\n var arrValue = array[index],\n othValue = other[index];\n\n if (customizer) {\n var compared = isPartial\n ? customizer(othValue, arrValue, index, other, array, stack)\n : customizer(arrValue, othValue, index, array, other, stack);\n }\n if (compared !== undefined) {\n if (compared) {\n continue;\n }\n result = false;\n break;\n }\n // Recursively compare arrays (susceptible to call stack limits).\n if (seen) {\n if (!arraySome(other, function(othValue, othIndex) {\n if (!cacheHas(seen, othIndex) &&\n (arrValue === othValue || equalFunc(arrValue, othValue, bitmask, customizer, stack))) {\n return seen.push(othIndex);\n }\n })) {\n result = false;\n break;\n }\n } else if (!(\n arrValue === othValue ||\n equalFunc(arrValue, othValue, bitmask, customizer, stack)\n )) {\n result = false;\n break;\n }\n }\n stack['delete'](array);\n stack['delete'](other);\n return result;\n }\n\n /**\n * A specialized version of `baseIsEqualDeep` for comparing objects of\n * the same `toStringTag`.\n *\n * **Note:** This function only supports comparing values with tags of\n * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {string} tag The `toStringTag` of the objects to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\n function equalByTag(object, other, tag, bitmask, customizer, equalFunc, stack) {\n switch (tag) {\n case dataViewTag:\n if ((object.byteLength != other.byteLength) ||\n (object.byteOffset != other.byteOffset)) {\n return false;\n }\n object = object.buffer;\n other = other.buffer;\n\n case arrayBufferTag:\n if ((object.byteLength != other.byteLength) ||\n !equalFunc(new Uint8Array(object), new Uint8Array(other))) {\n return false;\n }\n return true;\n\n case boolTag:\n case dateTag:\n case numberTag:\n // Coerce booleans to `1` or `0` and dates to milliseconds.\n // Invalid dates are coerced to `NaN`.\n return eq(+object, +other);\n\n case errorTag:\n return object.name == other.name && object.message == other.message;\n\n case regexpTag:\n case stringTag:\n // Coerce regexes to strings and treat strings, primitives and objects,\n // as equal. See http://www.ecma-international.org/ecma-262/7.0/#sec-regexp.prototype.tostring\n // for more details.\n return object == (other + '');\n\n case mapTag:\n var convert = mapToArray;\n\n case setTag:\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG;\n convert || (convert = setToArray);\n\n if (object.size != other.size && !isPartial) {\n return false;\n }\n // Assume cyclic values are equal.\n var stacked = stack.get(object);\n if (stacked) {\n return stacked == other;\n }\n bitmask |= COMPARE_UNORDERED_FLAG;\n\n // Recursively compare objects (susceptible to call stack limits).\n stack.set(object, other);\n var result = equalArrays(convert(object), convert(other), bitmask, customizer, equalFunc, stack);\n stack['delete'](object);\n return result;\n\n case symbolTag:\n if (symbolValueOf) {\n return symbolValueOf.call(object) == symbolValueOf.call(other);\n }\n }\n return false;\n }\n\n /**\n * A specialized version of `baseIsEqualDeep` for objects with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\n function equalObjects(object, other, bitmask, customizer, equalFunc, stack) {\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n objProps = getAllKeys(object),\n objLength = objProps.length,\n othProps = getAllKeys(other),\n othLength = othProps.length;\n\n if (objLength != othLength && !isPartial) {\n return false;\n }\n var index = objLength;\n while (index--) {\n var key = objProps[index];\n if (!(isPartial ? key in other : hasOwnProperty.call(other, key))) {\n return false;\n }\n }\n // Check that cyclic values are equal.\n var objStacked = stack.get(object);\n var othStacked = stack.get(other);\n if (objStacked && othStacked) {\n return objStacked == other && othStacked == object;\n }\n var result = true;\n stack.set(object, other);\n stack.set(other, object);\n\n var skipCtor = isPartial;\n while (++index < objLength) {\n key = objProps[index];\n var objValue = object[key],\n othValue = other[key];\n\n if (customizer) {\n var compared = isPartial\n ? customizer(othValue, objValue, key, other, object, stack)\n : customizer(objValue, othValue, key, object, other, stack);\n }\n // Recursively compare objects (susceptible to call stack limits).\n if (!(compared === undefined\n ? (objValue === othValue || equalFunc(objValue, othValue, bitmask, customizer, stack))\n : compared\n )) {\n result = false;\n break;\n }\n skipCtor || (skipCtor = key == 'constructor');\n }\n if (result && !skipCtor) {\n var objCtor = object.constructor,\n othCtor = other.constructor;\n\n // Non `Object` object instances with different constructors are not equal.\n if (objCtor != othCtor &&\n ('constructor' in object && 'constructor' in other) &&\n !(typeof objCtor == 'function' && objCtor instanceof objCtor &&\n typeof othCtor == 'function' && othCtor instanceof othCtor)) {\n result = false;\n }\n }\n stack['delete'](object);\n stack['delete'](other);\n return result;\n }\n\n /**\n * A specialized version of `baseRest` which flattens the rest array.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @returns {Function} Returns the new function.\n */\n function flatRest(func) {\n return setToString(overRest(func, undefined, flatten), func + '');\n }\n\n /**\n * Creates an array of own enumerable property names and symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names and symbols.\n */\n function getAllKeys(object) {\n return baseGetAllKeys(object, keys, getSymbols);\n }\n\n /**\n * Creates an array of own and inherited enumerable property names and\n * symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names and symbols.\n */\n function getAllKeysIn(object) {\n return baseGetAllKeys(object, keysIn, getSymbolsIn);\n }\n\n /**\n * Gets metadata for `func`.\n *\n * @private\n * @param {Function} func The function to query.\n * @returns {*} Returns the metadata for `func`.\n */\n var getData = !metaMap ? noop : function(func) {\n return metaMap.get(func);\n };\n\n /**\n * Gets the name of `func`.\n *\n * @private\n * @param {Function} func The function to query.\n * @returns {string} Returns the function name.\n */\n function getFuncName(func) {\n var result = (func.name + ''),\n array = realNames[result],\n length = hasOwnProperty.call(realNames, result) ? array.length : 0;\n\n while (length--) {\n var data = array[length],\n otherFunc = data.func;\n if (otherFunc == null || otherFunc == func) {\n return data.name;\n }\n }\n return result;\n }\n\n /**\n * Gets the argument placeholder value for `func`.\n *\n * @private\n * @param {Function} func The function to inspect.\n * @returns {*} Returns the placeholder value.\n */\n function getHolder(func) {\n var object = hasOwnProperty.call(lodash, 'placeholder') ? lodash : func;\n return object.placeholder;\n }\n\n /**\n * Gets the appropriate \"iteratee\" function. If `_.iteratee` is customized,\n * this function returns the custom method, otherwise it returns `baseIteratee`.\n * If arguments are provided, the chosen function is invoked with them and\n * its result is returned.\n *\n * @private\n * @param {*} [value] The value to convert to an iteratee.\n * @param {number} [arity] The arity of the created iteratee.\n * @returns {Function} Returns the chosen function or its result.\n */\n function getIteratee() {\n var result = lodash.iteratee || iteratee;\n result = result === iteratee ? baseIteratee : result;\n return arguments.length ? result(arguments[0], arguments[1]) : result;\n }\n\n /**\n * Gets the data for `map`.\n *\n * @private\n * @param {Object} map The map to query.\n * @param {string} key The reference key.\n * @returns {*} Returns the map data.\n */\n function getMapData(map, key) {\n var data = map.__data__;\n return isKeyable(key)\n ? data[typeof key == 'string' ? 'string' : 'hash']\n : data.map;\n }\n\n /**\n * Gets the property names, values, and compare flags of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the match data of `object`.\n */\n function getMatchData(object) {\n var result = keys(object),\n length = result.length;\n\n while (length--) {\n var key = result[length],\n value = object[key];\n\n result[length] = [key, value, isStrictComparable(value)];\n }\n return result;\n }\n\n /**\n * Gets the native function at `key` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the method to get.\n * @returns {*} Returns the function if it's native, else `undefined`.\n */\n function getNative(object, key) {\n var value = getValue(object, key);\n return baseIsNative(value) ? value : undefined;\n }\n\n /**\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the raw `toStringTag`.\n */\n function getRawTag(value) {\n var isOwn = hasOwnProperty.call(value, symToStringTag),\n tag = value[symToStringTag];\n\n try {\n value[symToStringTag] = undefined;\n var unmasked = true;\n } catch (e) {}\n\n var result = nativeObjectToString.call(value);\n if (unmasked) {\n if (isOwn) {\n value[symToStringTag] = tag;\n } else {\n delete value[symToStringTag];\n }\n }\n return result;\n }\n\n /**\n * Creates an array of the own enumerable symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\n var getSymbols = !nativeGetSymbols ? stubArray : function(object) {\n if (object == null) {\n return [];\n }\n object = Object(object);\n return arrayFilter(nativeGetSymbols(object), function(symbol) {\n return propertyIsEnumerable.call(object, symbol);\n });\n };\n\n /**\n * Creates an array of the own and inherited enumerable symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\n var getSymbolsIn = !nativeGetSymbols ? stubArray : function(object) {\n var result = [];\n while (object) {\n arrayPush(result, getSymbols(object));\n object = getPrototype(object);\n }\n return result;\n };\n\n /**\n * Gets the `toStringTag` of `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\n var getTag = baseGetTag;\n\n // Fallback for data views, maps, sets, and weak maps in IE 11 and promises in Node.js < 6.\n if ((DataView && getTag(new DataView(new ArrayBuffer(1))) != dataViewTag) ||\n (Map && getTag(new Map) != mapTag) ||\n (Promise && getTag(Promise.resolve()) != promiseTag) ||\n (Set && getTag(new Set) != setTag) ||\n (WeakMap && getTag(new WeakMap) != weakMapTag)) {\n getTag = function(value) {\n var result = baseGetTag(value),\n Ctor = result == objectTag ? value.constructor : undefined,\n ctorString = Ctor ? toSource(Ctor) : '';\n\n if (ctorString) {\n switch (ctorString) {\n case dataViewCtorString: return dataViewTag;\n case mapCtorString: return mapTag;\n case promiseCtorString: return promiseTag;\n case setCtorString: return setTag;\n case weakMapCtorString: return weakMapTag;\n }\n }\n return result;\n };\n }\n\n /**\n * Gets the view, applying any `transforms` to the `start` and `end` positions.\n *\n * @private\n * @param {number} start The start of the view.\n * @param {number} end The end of the view.\n * @param {Array} transforms The transformations to apply to the view.\n * @returns {Object} Returns an object containing the `start` and `end`\n * positions of the view.\n */\n function getView(start, end, transforms) {\n var index = -1,\n length = transforms.length;\n\n while (++index < length) {\n var data = transforms[index],\n size = data.size;\n\n switch (data.type) {\n case 'drop': start += size; break;\n case 'dropRight': end -= size; break;\n case 'take': end = nativeMin(end, start + size); break;\n case 'takeRight': start = nativeMax(start, end - size); break;\n }\n }\n return { 'start': start, 'end': end };\n }\n\n /**\n * Extracts wrapper details from the `source` body comment.\n *\n * @private\n * @param {string} source The source to inspect.\n * @returns {Array} Returns the wrapper details.\n */\n function getWrapDetails(source) {\n var match = source.match(reWrapDetails);\n return match ? match[1].split(reSplitDetails) : [];\n }\n\n /**\n * Checks if `path` exists on `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @param {Function} hasFunc The function to check properties.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n */\n function hasPath(object, path, hasFunc) {\n path = castPath(path, object);\n\n var index = -1,\n length = path.length,\n result = false;\n\n while (++index < length) {\n var key = toKey(path[index]);\n if (!(result = object != null && hasFunc(object, key))) {\n break;\n }\n object = object[key];\n }\n if (result || ++index != length) {\n return result;\n }\n length = object == null ? 0 : object.length;\n return !!length && isLength(length) && isIndex(key, length) &&\n (isArray(object) || isArguments(object));\n }\n\n /**\n * Initializes an array clone.\n *\n * @private\n * @param {Array} array The array to clone.\n * @returns {Array} Returns the initialized clone.\n */\n function initCloneArray(array) {\n var length = array.length,\n result = new array.constructor(length);\n\n // Add properties assigned by `RegExp#exec`.\n if (length && typeof array[0] == 'string' && hasOwnProperty.call(array, 'index')) {\n result.index = array.index;\n result.input = array.input;\n }\n return result;\n }\n\n /**\n * Initializes an object clone.\n *\n * @private\n * @param {Object} object The object to clone.\n * @returns {Object} Returns the initialized clone.\n */\n function initCloneObject(object) {\n return (typeof object.constructor == 'function' && !isPrototype(object))\n ? baseCreate(getPrototype(object))\n : {};\n }\n\n /**\n * Initializes an object clone based on its `toStringTag`.\n *\n * **Note:** This function only supports cloning values with tags of\n * `Boolean`, `Date`, `Error`, `Map`, `Number`, `RegExp`, `Set`, or `String`.\n *\n * @private\n * @param {Object} object The object to clone.\n * @param {string} tag The `toStringTag` of the object to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the initialized clone.\n */\n function initCloneByTag(object, tag, isDeep) {\n var Ctor = object.constructor;\n switch (tag) {\n case arrayBufferTag:\n return cloneArrayBuffer(object);\n\n case boolTag:\n case dateTag:\n return new Ctor(+object);\n\n case dataViewTag:\n return cloneDataView(object, isDeep);\n\n case float32Tag: case float64Tag:\n case int8Tag: case int16Tag: case int32Tag:\n case uint8Tag: case uint8ClampedTag: case uint16Tag: case uint32Tag:\n return cloneTypedArray(object, isDeep);\n\n case mapTag:\n return new Ctor;\n\n case numberTag:\n case stringTag:\n return new Ctor(object);\n\n case regexpTag:\n return cloneRegExp(object);\n\n case setTag:\n return new Ctor;\n\n case symbolTag:\n return cloneSymbol(object);\n }\n }\n\n /**\n * Inserts wrapper `details` in a comment at the top of the `source` body.\n *\n * @private\n * @param {string} source The source to modify.\n * @returns {Array} details The details to insert.\n * @returns {string} Returns the modified source.\n */\n function insertWrapDetails(source, details) {\n var length = details.length;\n if (!length) {\n return source;\n }\n var lastIndex = length - 1;\n details[lastIndex] = (length > 1 ? '& ' : '') + details[lastIndex];\n details = details.join(length > 2 ? ', ' : ' ');\n return source.replace(reWrapComment, '{\\n/* [wrapped with ' + details + '] */\\n');\n }\n\n /**\n * Checks if `value` is a flattenable `arguments` object or array.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is flattenable, else `false`.\n */\n function isFlattenable(value) {\n return isArray(value) || isArguments(value) ||\n !!(spreadableSymbol && value && value[spreadableSymbol]);\n }\n\n /**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\n function isIndex(value, length) {\n var type = typeof value;\n length = length == null ? MAX_SAFE_INTEGER : length;\n\n return !!length &&\n (type == 'number' ||\n (type != 'symbol' && reIsUint.test(value))) &&\n (value > -1 && value % 1 == 0 && value < length);\n }\n\n /**\n * Checks if the given arguments are from an iteratee call.\n *\n * @private\n * @param {*} value The potential iteratee value argument.\n * @param {*} index The potential iteratee index or key argument.\n * @param {*} object The potential iteratee object argument.\n * @returns {boolean} Returns `true` if the arguments are from an iteratee call,\n * else `false`.\n */\n function isIterateeCall(value, index, object) {\n if (!isObject(object)) {\n return false;\n }\n var type = typeof index;\n if (type == 'number'\n ? (isArrayLike(object) && isIndex(index, object.length))\n : (type == 'string' && index in object)\n ) {\n return eq(object[index], value);\n }\n return false;\n }\n\n /**\n * Checks if `value` is a property name and not a property path.\n *\n * @private\n * @param {*} value The value to check.\n * @param {Object} [object] The object to query keys on.\n * @returns {boolean} Returns `true` if `value` is a property name, else `false`.\n */\n function isKey(value, object) {\n if (isArray(value)) {\n return false;\n }\n var type = typeof value;\n if (type == 'number' || type == 'symbol' || type == 'boolean' ||\n value == null || isSymbol(value)) {\n return true;\n }\n return reIsPlainProp.test(value) || !reIsDeepProp.test(value) ||\n (object != null && value in Object(object));\n }\n\n /**\n * Checks if `value` is suitable for use as unique object key.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is suitable, else `false`.\n */\n function isKeyable(value) {\n var type = typeof value;\n return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean')\n ? (value !== '__proto__')\n : (value === null);\n }\n\n /**\n * Checks if `func` has a lazy counterpart.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` has a lazy counterpart,\n * else `false`.\n */\n function isLaziable(func) {\n var funcName = getFuncName(func),\n other = lodash[funcName];\n\n if (typeof other != 'function' || !(funcName in LazyWrapper.prototype)) {\n return false;\n }\n if (func === other) {\n return true;\n }\n var data = getData(other);\n return !!data && func === data[0];\n }\n\n /**\n * Checks if `func` has its source masked.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` is masked, else `false`.\n */\n function isMasked(func) {\n return !!maskSrcKey && (maskSrcKey in func);\n }\n\n /**\n * Checks if `func` is capable of being masked.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `func` is maskable, else `false`.\n */\n var isMaskable = coreJsData ? isFunction : stubFalse;\n\n /**\n * Checks if `value` is likely a prototype object.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\n */\n function isPrototype(value) {\n var Ctor = value && value.constructor,\n proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\n\n return value === proto;\n }\n\n /**\n * Checks if `value` is suitable for strict equality comparisons, i.e. `===`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` if suitable for strict\n * equality comparisons, else `false`.\n */\n function isStrictComparable(value) {\n return value === value && !isObject(value);\n }\n\n /**\n * A specialized version of `matchesProperty` for source values suitable\n * for strict equality comparisons, i.e. `===`.\n *\n * @private\n * @param {string} key The key of the property to get.\n * @param {*} srcValue The value to match.\n * @returns {Function} Returns the new spec function.\n */\n function matchesStrictComparable(key, srcValue) {\n return function(object) {\n if (object == null) {\n return false;\n }\n return object[key] === srcValue &&\n (srcValue !== undefined || (key in Object(object)));\n };\n }\n\n /**\n * A specialized version of `_.memoize` which clears the memoized function's\n * cache when it exceeds `MAX_MEMOIZE_SIZE`.\n *\n * @private\n * @param {Function} func The function to have its output memoized.\n * @returns {Function} Returns the new memoized function.\n */\n function memoizeCapped(func) {\n var result = memoize(func, function(key) {\n if (cache.size === MAX_MEMOIZE_SIZE) {\n cache.clear();\n }\n return key;\n });\n\n var cache = result.cache;\n return result;\n }\n\n /**\n * Merges the function metadata of `source` into `data`.\n *\n * Merging metadata reduces the number of wrappers used to invoke a function.\n * This is possible because methods like `_.bind`, `_.curry`, and `_.partial`\n * may be applied regardless of execution order. Methods like `_.ary` and\n * `_.rearg` modify function arguments, making the order in which they are\n * executed important, preventing the merging of metadata. However, we make\n * an exception for a safe combined case where curried functions have `_.ary`\n * and or `_.rearg` applied.\n *\n * @private\n * @param {Array} data The destination metadata.\n * @param {Array} source The source metadata.\n * @returns {Array} Returns `data`.\n */\n function mergeData(data, source) {\n var bitmask = data[1],\n srcBitmask = source[1],\n newBitmask = bitmask | srcBitmask,\n isCommon = newBitmask < (WRAP_BIND_FLAG | WRAP_BIND_KEY_FLAG | WRAP_ARY_FLAG);\n\n var isCombo =\n ((srcBitmask == WRAP_ARY_FLAG) && (bitmask == WRAP_CURRY_FLAG)) ||\n ((srcBitmask == WRAP_ARY_FLAG) && (bitmask == WRAP_REARG_FLAG) && (data[7].length <= source[8])) ||\n ((srcBitmask == (WRAP_ARY_FLAG | WRAP_REARG_FLAG)) && (source[7].length <= source[8]) && (bitmask == WRAP_CURRY_FLAG));\n\n // Exit early if metadata can't be merged.\n if (!(isCommon || isCombo)) {\n return data;\n }\n // Use source `thisArg` if available.\n if (srcBitmask & WRAP_BIND_FLAG) {\n data[2] = source[2];\n // Set when currying a bound function.\n newBitmask |= bitmask & WRAP_BIND_FLAG ? 0 : WRAP_CURRY_BOUND_FLAG;\n }\n // Compose partial arguments.\n var value = source[3];\n if (value) {\n var partials = data[3];\n data[3] = partials ? composeArgs(partials, value, source[4]) : value;\n data[4] = partials ? replaceHolders(data[3], PLACEHOLDER) : source[4];\n }\n // Compose partial right arguments.\n value = source[5];\n if (value) {\n partials = data[5];\n data[5] = partials ? composeArgsRight(partials, value, source[6]) : value;\n data[6] = partials ? replaceHolders(data[5], PLACEHOLDER) : source[6];\n }\n // Use source `argPos` if available.\n value = source[7];\n if (value) {\n data[7] = value;\n }\n // Use source `ary` if it's smaller.\n if (srcBitmask & WRAP_ARY_FLAG) {\n data[8] = data[8] == null ? source[8] : nativeMin(data[8], source[8]);\n }\n // Use source `arity` if one is not provided.\n if (data[9] == null) {\n data[9] = source[9];\n }\n // Use source `func` and merge bitmasks.\n data[0] = source[0];\n data[1] = newBitmask;\n\n return data;\n }\n\n /**\n * This function is like\n * [`Object.keys`](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * except that it includes inherited enumerable properties.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\n function nativeKeysIn(object) {\n var result = [];\n if (object != null) {\n for (var key in Object(object)) {\n result.push(key);\n }\n }\n return result;\n }\n\n /**\n * Converts `value` to a string using `Object.prototype.toString`.\n *\n * @private\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n */\n function objectToString(value) {\n return nativeObjectToString.call(value);\n }\n\n /**\n * A specialized version of `baseRest` which transforms the rest array.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @param {number} [start=func.length-1] The start position of the rest parameter.\n * @param {Function} transform The rest array transform.\n * @returns {Function} Returns the new function.\n */\n function overRest(func, start, transform) {\n start = nativeMax(start === undefined ? (func.length - 1) : start, 0);\n return function() {\n var args = arguments,\n index = -1,\n length = nativeMax(args.length - start, 0),\n array = Array(length);\n\n while (++index < length) {\n array[index] = args[start + index];\n }\n index = -1;\n var otherArgs = Array(start + 1);\n while (++index < start) {\n otherArgs[index] = args[index];\n }\n otherArgs[start] = transform(array);\n return apply(func, this, otherArgs);\n };\n }\n\n /**\n * Gets the parent value at `path` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array} path The path to get the parent value of.\n * @returns {*} Returns the parent value.\n */\n function parent(object, path) {\n return path.length < 2 ? object : baseGet(object, baseSlice(path, 0, -1));\n }\n\n /**\n * Reorder `array` according to the specified indexes where the element at\n * the first index is assigned as the first element, the element at\n * the second index is assigned as the second element, and so on.\n *\n * @private\n * @param {Array} array The array to reorder.\n * @param {Array} indexes The arranged array indexes.\n * @returns {Array} Returns `array`.\n */\n function reorder(array, indexes) {\n var arrLength = array.length,\n length = nativeMin(indexes.length, arrLength),\n oldArray = copyArray(array);\n\n while (length--) {\n var index = indexes[length];\n array[length] = isIndex(index, arrLength) ? oldArray[index] : undefined;\n }\n return array;\n }\n\n /**\n * Gets the value at `key`, unless `key` is \"__proto__\" or \"constructor\".\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\n function safeGet(object, key) {\n if (key === 'constructor' && typeof object[key] === 'function') {\n return;\n }\n\n if (key == '__proto__') {\n return;\n }\n\n return object[key];\n }\n\n /**\n * Sets metadata for `func`.\n *\n * **Note:** If this function becomes hot, i.e. is invoked a lot in a short\n * period of time, it will trip its breaker and transition to an identity\n * function to avoid garbage collection pauses in V8. See\n * [V8 issue 2070](https://bugs.chromium.org/p/v8/issues/detail?id=2070)\n * for more details.\n *\n * @private\n * @param {Function} func The function to associate metadata with.\n * @param {*} data The metadata.\n * @returns {Function} Returns `func`.\n */\n var setData = shortOut(baseSetData);\n\n /**\n * A simple wrapper around the global [`setTimeout`](https://mdn.io/setTimeout).\n *\n * @private\n * @param {Function} func The function to delay.\n * @param {number} wait The number of milliseconds to delay invocation.\n * @returns {number|Object} Returns the timer id or timeout object.\n */\n var setTimeout = ctxSetTimeout || function(func, wait) {\n return root.setTimeout(func, wait);\n };\n\n /**\n * Sets the `toString` method of `func` to return `string`.\n *\n * @private\n * @param {Function} func The function to modify.\n * @param {Function} string The `toString` result.\n * @returns {Function} Returns `func`.\n */\n var setToString = shortOut(baseSetToString);\n\n /**\n * Sets the `toString` method of `wrapper` to mimic the source of `reference`\n * with wrapper details in a comment at the top of the source body.\n *\n * @private\n * @param {Function} wrapper The function to modify.\n * @param {Function} reference The reference function.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @returns {Function} Returns `wrapper`.\n */\n function setWrapToString(wrapper, reference, bitmask) {\n var source = (reference + '');\n return setToString(wrapper, insertWrapDetails(source, updateWrapDetails(getWrapDetails(source), bitmask)));\n }\n\n /**\n * Creates a function that'll short out and invoke `identity` instead\n * of `func` when it's called `HOT_COUNT` or more times in `HOT_SPAN`\n * milliseconds.\n *\n * @private\n * @param {Function} func The function to restrict.\n * @returns {Function} Returns the new shortable function.\n */\n function shortOut(func) {\n var count = 0,\n lastCalled = 0;\n\n return function() {\n var stamp = nativeNow(),\n remaining = HOT_SPAN - (stamp - lastCalled);\n\n lastCalled = stamp;\n if (remaining > 0) {\n if (++count >= HOT_COUNT) {\n return arguments[0];\n }\n } else {\n count = 0;\n }\n return func.apply(undefined, arguments);\n };\n }\n\n /**\n * A specialized version of `_.shuffle` which mutates and sets the size of `array`.\n *\n * @private\n * @param {Array} array The array to shuffle.\n * @param {number} [size=array.length] The size of `array`.\n * @returns {Array} Returns `array`.\n */\n function shuffleSelf(array, size) {\n var index = -1,\n length = array.length,\n lastIndex = length - 1;\n\n size = size === undefined ? length : size;\n while (++index < size) {\n var rand = baseRandom(index, lastIndex),\n value = array[rand];\n\n array[rand] = array[index];\n array[index] = value;\n }\n array.length = size;\n return array;\n }\n\n /**\n * Converts `string` to a property path array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the property path array.\n */\n var stringToPath = memoizeCapped(function(string) {\n var result = [];\n if (string.charCodeAt(0) === 46 /* . */) {\n result.push('');\n }\n string.replace(rePropName, function(match, number, quote, subString) {\n result.push(quote ? subString.replace(reEscapeChar, '$1') : (number || match));\n });\n return result;\n });\n\n /**\n * Converts `value` to a string key if it's not a string or symbol.\n *\n * @private\n * @param {*} value The value to inspect.\n * @returns {string|symbol} Returns the key.\n */\n function toKey(value) {\n if (typeof value == 'string' || isSymbol(value)) {\n return value;\n }\n var result = (value + '');\n return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n }\n\n /**\n * Converts `func` to its source code.\n *\n * @private\n * @param {Function} func The function to convert.\n * @returns {string} Returns the source code.\n */\n function toSource(func) {\n if (func != null) {\n try {\n return funcToString.call(func);\n } catch (e) {}\n try {\n return (func + '');\n } catch (e) {}\n }\n return '';\n }\n\n /**\n * Updates wrapper `details` based on `bitmask` flags.\n *\n * @private\n * @returns {Array} details The details to modify.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @returns {Array} Returns `details`.\n */\n function updateWrapDetails(details, bitmask) {\n arrayEach(wrapFlags, function(pair) {\n var value = '_.' + pair[0];\n if ((bitmask & pair[1]) && !arrayIncludes(details, value)) {\n details.push(value);\n }\n });\n return details.sort();\n }\n\n /**\n * Creates a clone of `wrapper`.\n *\n * @private\n * @param {Object} wrapper The wrapper to clone.\n * @returns {Object} Returns the cloned wrapper.\n */\n function wrapperClone(wrapper) {\n if (wrapper instanceof LazyWrapper) {\n return wrapper.clone();\n }\n var result = new LodashWrapper(wrapper.__wrapped__, wrapper.__chain__);\n result.__actions__ = copyArray(wrapper.__actions__);\n result.__index__ = wrapper.__index__;\n result.__values__ = wrapper.__values__;\n return result;\n }\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates an array of elements split into groups the length of `size`.\n * If `array` can't be split evenly, the final chunk will be the remaining\n * elements.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to process.\n * @param {number} [size=1] The length of each chunk\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the new array of chunks.\n * @example\n *\n * _.chunk(['a', 'b', 'c', 'd'], 2);\n * // => [['a', 'b'], ['c', 'd']]\n *\n * _.chunk(['a', 'b', 'c', 'd'], 3);\n * // => [['a', 'b', 'c'], ['d']]\n */\n function chunk(array, size, guard) {\n if ((guard ? isIterateeCall(array, size, guard) : size === undefined)) {\n size = 1;\n } else {\n size = nativeMax(toInteger(size), 0);\n }\n var length = array == null ? 0 : array.length;\n if (!length || size < 1) {\n return [];\n }\n var index = 0,\n resIndex = 0,\n result = Array(nativeCeil(length / size));\n\n while (index < length) {\n result[resIndex++] = baseSlice(array, index, (index += size));\n }\n return result;\n }\n\n /**\n * Creates an array with all falsey values removed. The values `false`, `null`,\n * `0`, `\"\"`, `undefined`, and `NaN` are falsey.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to compact.\n * @returns {Array} Returns the new array of filtered values.\n * @example\n *\n * _.compact([0, 1, false, 2, '', 3]);\n * // => [1, 2, 3]\n */\n function compact(array) {\n var index = -1,\n length = array == null ? 0 : array.length,\n resIndex = 0,\n result = [];\n\n while (++index < length) {\n var value = array[index];\n if (value) {\n result[resIndex++] = value;\n }\n }\n return result;\n }\n\n /**\n * Creates a new array concatenating `array` with any additional arrays\n * and/or values.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to concatenate.\n * @param {...*} [values] The values to concatenate.\n * @returns {Array} Returns the new concatenated array.\n * @example\n *\n * var array = [1];\n * var other = _.concat(array, 2, [3], [[4]]);\n *\n * console.log(other);\n * // => [1, 2, 3, [4]]\n *\n * console.log(array);\n * // => [1]\n */\n function concat() {\n var length = arguments.length;\n if (!length) {\n return [];\n }\n var args = Array(length - 1),\n array = arguments[0],\n index = length;\n\n while (index--) {\n args[index - 1] = arguments[index];\n }\n return arrayPush(isArray(array) ? copyArray(array) : [array], baseFlatten(args, 1));\n }\n\n /**\n * Creates an array of `array` values not included in the other given arrays\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons. The order and references of result values are\n * determined by the first array.\n *\n * **Note:** Unlike `_.pullAll`, this method returns a new array.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {...Array} [values] The values to exclude.\n * @returns {Array} Returns the new array of filtered values.\n * @see _.without, _.xor\n * @example\n *\n * _.difference([2, 1], [2, 3]);\n * // => [1]\n */\n var difference = baseRest(function(array, values) {\n return isArrayLikeObject(array)\n ? baseDifference(array, baseFlatten(values, 1, isArrayLikeObject, true))\n : [];\n });\n\n /**\n * This method is like `_.difference` except that it accepts `iteratee` which\n * is invoked for each element of `array` and `values` to generate the criterion\n * by which they're compared. The order and references of result values are\n * determined by the first array. The iteratee is invoked with one argument:\n * (value).\n *\n * **Note:** Unlike `_.pullAllBy`, this method returns a new array.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {...Array} [values] The values to exclude.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Array} Returns the new array of filtered values.\n * @example\n *\n * _.differenceBy([2.1, 1.2], [2.3, 3.4], Math.floor);\n * // => [1.2]\n *\n * // The `_.property` iteratee shorthand.\n * _.differenceBy([{ 'x': 2 }, { 'x': 1 }], [{ 'x': 1 }], 'x');\n * // => [{ 'x': 2 }]\n */\n var differenceBy = baseRest(function(array, values) {\n var iteratee = last(values);\n if (isArrayLikeObject(iteratee)) {\n iteratee = undefined;\n }\n return isArrayLikeObject(array)\n ? baseDifference(array, baseFlatten(values, 1, isArrayLikeObject, true), getIteratee(iteratee, 2))\n : [];\n });\n\n /**\n * This method is like `_.difference` except that it accepts `comparator`\n * which is invoked to compare elements of `array` to `values`. The order and\n * references of result values are determined by the first array. The comparator\n * is invoked with two arguments: (arrVal, othVal).\n *\n * **Note:** Unlike `_.pullAllWith`, this method returns a new array.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {...Array} [values] The values to exclude.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of filtered values.\n * @example\n *\n * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }];\n *\n * _.differenceWith(objects, [{ 'x': 1, 'y': 2 }], _.isEqual);\n * // => [{ 'x': 2, 'y': 1 }]\n */\n var differenceWith = baseRest(function(array, values) {\n var comparator = last(values);\n if (isArrayLikeObject(comparator)) {\n comparator = undefined;\n }\n return isArrayLikeObject(array)\n ? baseDifference(array, baseFlatten(values, 1, isArrayLikeObject, true), undefined, comparator)\n : [];\n });\n\n /**\n * Creates a slice of `array` with `n` elements dropped from the beginning.\n *\n * @static\n * @memberOf _\n * @since 0.5.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {number} [n=1] The number of elements to drop.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * _.drop([1, 2, 3]);\n * // => [2, 3]\n *\n * _.drop([1, 2, 3], 2);\n * // => [3]\n *\n * _.drop([1, 2, 3], 5);\n * // => []\n *\n * _.drop([1, 2, 3], 0);\n * // => [1, 2, 3]\n */\n function drop(array, n, guard) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return [];\n }\n n = (guard || n === undefined) ? 1 : toInteger(n);\n return baseSlice(array, n < 0 ? 0 : n, length);\n }\n\n /**\n * Creates a slice of `array` with `n` elements dropped from the end.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {number} [n=1] The number of elements to drop.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * _.dropRight([1, 2, 3]);\n * // => [1, 2]\n *\n * _.dropRight([1, 2, 3], 2);\n * // => [1]\n *\n * _.dropRight([1, 2, 3], 5);\n * // => []\n *\n * _.dropRight([1, 2, 3], 0);\n * // => [1, 2, 3]\n */\n function dropRight(array, n, guard) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return [];\n }\n n = (guard || n === undefined) ? 1 : toInteger(n);\n n = length - n;\n return baseSlice(array, 0, n < 0 ? 0 : n);\n }\n\n /**\n * Creates a slice of `array` excluding elements dropped from the end.\n * Elements are dropped until `predicate` returns falsey. The predicate is\n * invoked with three arguments: (value, index, array).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'active': true },\n * { 'user': 'fred', 'active': false },\n * { 'user': 'pebbles', 'active': false }\n * ];\n *\n * _.dropRightWhile(users, function(o) { return !o.active; });\n * // => objects for ['barney']\n *\n * // The `_.matches` iteratee shorthand.\n * _.dropRightWhile(users, { 'user': 'pebbles', 'active': false });\n * // => objects for ['barney', 'fred']\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.dropRightWhile(users, ['active', false]);\n * // => objects for ['barney']\n *\n * // The `_.property` iteratee shorthand.\n * _.dropRightWhile(users, 'active');\n * // => objects for ['barney', 'fred', 'pebbles']\n */\n function dropRightWhile(array, predicate) {\n return (array && array.length)\n ? baseWhile(array, getIteratee(predicate, 3), true, true)\n : [];\n }\n\n /**\n * Creates a slice of `array` excluding elements dropped from the beginning.\n * Elements are dropped until `predicate` returns falsey. The predicate is\n * invoked with three arguments: (value, index, array).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'active': false },\n * { 'user': 'fred', 'active': false },\n * { 'user': 'pebbles', 'active': true }\n * ];\n *\n * _.dropWhile(users, function(o) { return !o.active; });\n * // => objects for ['pebbles']\n *\n * // The `_.matches` iteratee shorthand.\n * _.dropWhile(users, { 'user': 'barney', 'active': false });\n * // => objects for ['fred', 'pebbles']\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.dropWhile(users, ['active', false]);\n * // => objects for ['pebbles']\n *\n * // The `_.property` iteratee shorthand.\n * _.dropWhile(users, 'active');\n * // => objects for ['barney', 'fred', 'pebbles']\n */\n function dropWhile(array, predicate) {\n return (array && array.length)\n ? baseWhile(array, getIteratee(predicate, 3), true)\n : [];\n }\n\n /**\n * Fills elements of `array` with `value` from `start` up to, but not\n * including, `end`.\n *\n * **Note:** This method mutates `array`.\n *\n * @static\n * @memberOf _\n * @since 3.2.0\n * @category Array\n * @param {Array} array The array to fill.\n * @param {*} value The value to fill `array` with.\n * @param {number} [start=0] The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns `array`.\n * @example\n *\n * var array = [1, 2, 3];\n *\n * _.fill(array, 'a');\n * console.log(array);\n * // => ['a', 'a', 'a']\n *\n * _.fill(Array(3), 2);\n * // => [2, 2, 2]\n *\n * _.fill([4, 6, 8, 10], '*', 1, 3);\n * // => [4, '*', '*', 10]\n */\n function fill(array, value, start, end) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return [];\n }\n if (start && typeof start != 'number' && isIterateeCall(array, value, start)) {\n start = 0;\n end = length;\n }\n return baseFill(array, value, start, end);\n }\n\n /**\n * This method is like `_.find` except that it returns the index of the first\n * element `predicate` returns truthy for instead of the element itself.\n *\n * @static\n * @memberOf _\n * @since 1.1.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param {number} [fromIndex=0] The index to search from.\n * @returns {number} Returns the index of the found element, else `-1`.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'active': false },\n * { 'user': 'fred', 'active': false },\n * { 'user': 'pebbles', 'active': true }\n * ];\n *\n * _.findIndex(users, function(o) { return o.user == 'barney'; });\n * // => 0\n *\n * // The `_.matches` iteratee shorthand.\n * _.findIndex(users, { 'user': 'fred', 'active': false });\n * // => 1\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.findIndex(users, ['active', false]);\n * // => 0\n *\n * // The `_.property` iteratee shorthand.\n * _.findIndex(users, 'active');\n * // => 2\n */\n function findIndex(array, predicate, fromIndex) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return -1;\n }\n var index = fromIndex == null ? 0 : toInteger(fromIndex);\n if (index < 0) {\n index = nativeMax(length + index, 0);\n }\n return baseFindIndex(array, getIteratee(predicate, 3), index);\n }\n\n /**\n * This method is like `_.findIndex` except that it iterates over elements\n * of `collection` from right to left.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param {number} [fromIndex=array.length-1] The index to search from.\n * @returns {number} Returns the index of the found element, else `-1`.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'active': true },\n * { 'user': 'fred', 'active': false },\n * { 'user': 'pebbles', 'active': false }\n * ];\n *\n * _.findLastIndex(users, function(o) { return o.user == 'pebbles'; });\n * // => 2\n *\n * // The `_.matches` iteratee shorthand.\n * _.findLastIndex(users, { 'user': 'barney', 'active': true });\n * // => 0\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.findLastIndex(users, ['active', false]);\n * // => 2\n *\n * // The `_.property` iteratee shorthand.\n * _.findLastIndex(users, 'active');\n * // => 0\n */\n function findLastIndex(array, predicate, fromIndex) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return -1;\n }\n var index = length - 1;\n if (fromIndex !== undefined) {\n index = toInteger(fromIndex);\n index = fromIndex < 0\n ? nativeMax(length + index, 0)\n : nativeMin(index, length - 1);\n }\n return baseFindIndex(array, getIteratee(predicate, 3), index, true);\n }\n\n /**\n * Flattens `array` a single level deep.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to flatten.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * _.flatten([1, [2, [3, [4]], 5]]);\n * // => [1, 2, [3, [4]], 5]\n */\n function flatten(array) {\n var length = array == null ? 0 : array.length;\n return length ? baseFlatten(array, 1) : [];\n }\n\n /**\n * Recursively flattens `array`.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to flatten.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * _.flattenDeep([1, [2, [3, [4]], 5]]);\n * // => [1, 2, 3, 4, 5]\n */\n function flattenDeep(array) {\n var length = array == null ? 0 : array.length;\n return length ? baseFlatten(array, INFINITY) : [];\n }\n\n /**\n * Recursively flatten `array` up to `depth` times.\n *\n * @static\n * @memberOf _\n * @since 4.4.0\n * @category Array\n * @param {Array} array The array to flatten.\n * @param {number} [depth=1] The maximum recursion depth.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * var array = [1, [2, [3, [4]], 5]];\n *\n * _.flattenDepth(array, 1);\n * // => [1, 2, [3, [4]], 5]\n *\n * _.flattenDepth(array, 2);\n * // => [1, 2, 3, [4], 5]\n */\n function flattenDepth(array, depth) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return [];\n }\n depth = depth === undefined ? 1 : toInteger(depth);\n return baseFlatten(array, depth);\n }\n\n /**\n * The inverse of `_.toPairs`; this method returns an object composed\n * from key-value `pairs`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} pairs The key-value pairs.\n * @returns {Object} Returns the new object.\n * @example\n *\n * _.fromPairs([['a', 1], ['b', 2]]);\n * // => { 'a': 1, 'b': 2 }\n */\n function fromPairs(pairs) {\n var index = -1,\n length = pairs == null ? 0 : pairs.length,\n result = {};\n\n while (++index < length) {\n var pair = pairs[index];\n result[pair[0]] = pair[1];\n }\n return result;\n }\n\n /**\n * Gets the first element of `array`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @alias first\n * @category Array\n * @param {Array} array The array to query.\n * @returns {*} Returns the first element of `array`.\n * @example\n *\n * _.head([1, 2, 3]);\n * // => 1\n *\n * _.head([]);\n * // => undefined\n */\n function head(array) {\n return (array && array.length) ? array[0] : undefined;\n }\n\n /**\n * Gets the index at which the first occurrence of `value` is found in `array`\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons. If `fromIndex` is negative, it's used as the\n * offset from the end of `array`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} [fromIndex=0] The index to search from.\n * @returns {number} Returns the index of the matched value, else `-1`.\n * @example\n *\n * _.indexOf([1, 2, 1, 2], 2);\n * // => 1\n *\n * // Search from the `fromIndex`.\n * _.indexOf([1, 2, 1, 2], 2, 2);\n * // => 3\n */\n function indexOf(array, value, fromIndex) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return -1;\n }\n var index = fromIndex == null ? 0 : toInteger(fromIndex);\n if (index < 0) {\n index = nativeMax(length + index, 0);\n }\n return baseIndexOf(array, value, index);\n }\n\n /**\n * Gets all but the last element of `array`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to query.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * _.initial([1, 2, 3]);\n * // => [1, 2]\n */\n function initial(array) {\n var length = array == null ? 0 : array.length;\n return length ? baseSlice(array, 0, -1) : [];\n }\n\n /**\n * Creates an array of unique values that are included in all given arrays\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons. The order and references of result values are\n * determined by the first array.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @returns {Array} Returns the new array of intersecting values.\n * @example\n *\n * _.intersection([2, 1], [2, 3]);\n * // => [2]\n */\n var intersection = baseRest(function(arrays) {\n var mapped = arrayMap(arrays, castArrayLikeObject);\n return (mapped.length && mapped[0] === arrays[0])\n ? baseIntersection(mapped)\n : [];\n });\n\n /**\n * This method is like `_.intersection` except that it accepts `iteratee`\n * which is invoked for each element of each `arrays` to generate the criterion\n * by which they're compared. The order and references of result values are\n * determined by the first array. The iteratee is invoked with one argument:\n * (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Array} Returns the new array of intersecting values.\n * @example\n *\n * _.intersectionBy([2.1, 1.2], [2.3, 3.4], Math.floor);\n * // => [2.1]\n *\n * // The `_.property` iteratee shorthand.\n * _.intersectionBy([{ 'x': 1 }], [{ 'x': 2 }, { 'x': 1 }], 'x');\n * // => [{ 'x': 1 }]\n */\n var intersectionBy = baseRest(function(arrays) {\n var iteratee = last(arrays),\n mapped = arrayMap(arrays, castArrayLikeObject);\n\n if (iteratee === last(mapped)) {\n iteratee = undefined;\n } else {\n mapped.pop();\n }\n return (mapped.length && mapped[0] === arrays[0])\n ? baseIntersection(mapped, getIteratee(iteratee, 2))\n : [];\n });\n\n /**\n * This method is like `_.intersection` except that it accepts `comparator`\n * which is invoked to compare elements of `arrays`. The order and references\n * of result values are determined by the first array. The comparator is\n * invoked with two arguments: (arrVal, othVal).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of intersecting values.\n * @example\n *\n * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }];\n * var others = [{ 'x': 1, 'y': 1 }, { 'x': 1, 'y': 2 }];\n *\n * _.intersectionWith(objects, others, _.isEqual);\n * // => [{ 'x': 1, 'y': 2 }]\n */\n var intersectionWith = baseRest(function(arrays) {\n var comparator = last(arrays),\n mapped = arrayMap(arrays, castArrayLikeObject);\n\n comparator = typeof comparator == 'function' ? comparator : undefined;\n if (comparator) {\n mapped.pop();\n }\n return (mapped.length && mapped[0] === arrays[0])\n ? baseIntersection(mapped, undefined, comparator)\n : [];\n });\n\n /**\n * Converts all elements in `array` into a string separated by `separator`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to convert.\n * @param {string} [separator=','] The element separator.\n * @returns {string} Returns the joined string.\n * @example\n *\n * _.join(['a', 'b', 'c'], '~');\n * // => 'a~b~c'\n */\n function join(array, separator) {\n return array == null ? '' : nativeJoin.call(array, separator);\n }\n\n /**\n * Gets the last element of `array`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to query.\n * @returns {*} Returns the last element of `array`.\n * @example\n *\n * _.last([1, 2, 3]);\n * // => 3\n */\n function last(array) {\n var length = array == null ? 0 : array.length;\n return length ? array[length - 1] : undefined;\n }\n\n /**\n * This method is like `_.indexOf` except that it iterates over elements of\n * `array` from right to left.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} [fromIndex=array.length-1] The index to search from.\n * @returns {number} Returns the index of the matched value, else `-1`.\n * @example\n *\n * _.lastIndexOf([1, 2, 1, 2], 2);\n * // => 3\n *\n * // Search from the `fromIndex`.\n * _.lastIndexOf([1, 2, 1, 2], 2, 2);\n * // => 1\n */\n function lastIndexOf(array, value, fromIndex) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return -1;\n }\n var index = length;\n if (fromIndex !== undefined) {\n index = toInteger(fromIndex);\n index = index < 0 ? nativeMax(length + index, 0) : nativeMin(index, length - 1);\n }\n return value === value\n ? strictLastIndexOf(array, value, index)\n : baseFindIndex(array, baseIsNaN, index, true);\n }\n\n /**\n * Gets the element at index `n` of `array`. If `n` is negative, the nth\n * element from the end is returned.\n *\n * @static\n * @memberOf _\n * @since 4.11.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {number} [n=0] The index of the element to return.\n * @returns {*} Returns the nth element of `array`.\n * @example\n *\n * var array = ['a', 'b', 'c', 'd'];\n *\n * _.nth(array, 1);\n * // => 'b'\n *\n * _.nth(array, -2);\n * // => 'c';\n */\n function nth(array, n) {\n return (array && array.length) ? baseNth(array, toInteger(n)) : undefined;\n }\n\n /**\n * Removes all given values from `array` using\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * **Note:** Unlike `_.without`, this method mutates `array`. Use `_.remove`\n * to remove elements from an array by predicate.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Array\n * @param {Array} array The array to modify.\n * @param {...*} [values] The values to remove.\n * @returns {Array} Returns `array`.\n * @example\n *\n * var array = ['a', 'b', 'c', 'a', 'b', 'c'];\n *\n * _.pull(array, 'a', 'c');\n * console.log(array);\n * // => ['b', 'b']\n */\n var pull = baseRest(pullAll);\n\n /**\n * This method is like `_.pull` except that it accepts an array of values to remove.\n *\n * **Note:** Unlike `_.difference`, this method mutates `array`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to modify.\n * @param {Array} values The values to remove.\n * @returns {Array} Returns `array`.\n * @example\n *\n * var array = ['a', 'b', 'c', 'a', 'b', 'c'];\n *\n * _.pullAll(array, ['a', 'c']);\n * console.log(array);\n * // => ['b', 'b']\n */\n function pullAll(array, values) {\n return (array && array.length && values && values.length)\n ? basePullAll(array, values)\n : array;\n }\n\n /**\n * This method is like `_.pullAll` except that it accepts `iteratee` which is\n * invoked for each element of `array` and `values` to generate the criterion\n * by which they're compared. The iteratee is invoked with one argument: (value).\n *\n * **Note:** Unlike `_.differenceBy`, this method mutates `array`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to modify.\n * @param {Array} values The values to remove.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Array} Returns `array`.\n * @example\n *\n * var array = [{ 'x': 1 }, { 'x': 2 }, { 'x': 3 }, { 'x': 1 }];\n *\n * _.pullAllBy(array, [{ 'x': 1 }, { 'x': 3 }], 'x');\n * console.log(array);\n * // => [{ 'x': 2 }]\n */\n function pullAllBy(array, values, iteratee) {\n return (array && array.length && values && values.length)\n ? basePullAll(array, values, getIteratee(iteratee, 2))\n : array;\n }\n\n /**\n * This method is like `_.pullAll` except that it accepts `comparator` which\n * is invoked to compare elements of `array` to `values`. The comparator is\n * invoked with two arguments: (arrVal, othVal).\n *\n * **Note:** Unlike `_.differenceWith`, this method mutates `array`.\n *\n * @static\n * @memberOf _\n * @since 4.6.0\n * @category Array\n * @param {Array} array The array to modify.\n * @param {Array} values The values to remove.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns `array`.\n * @example\n *\n * var array = [{ 'x': 1, 'y': 2 }, { 'x': 3, 'y': 4 }, { 'x': 5, 'y': 6 }];\n *\n * _.pullAllWith(array, [{ 'x': 3, 'y': 4 }], _.isEqual);\n * console.log(array);\n * // => [{ 'x': 1, 'y': 2 }, { 'x': 5, 'y': 6 }]\n */\n function pullAllWith(array, values, comparator) {\n return (array && array.length && values && values.length)\n ? basePullAll(array, values, undefined, comparator)\n : array;\n }\n\n /**\n * Removes elements from `array` corresponding to `indexes` and returns an\n * array of removed elements.\n *\n * **Note:** Unlike `_.at`, this method mutates `array`.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to modify.\n * @param {...(number|number[])} [indexes] The indexes of elements to remove.\n * @returns {Array} Returns the new array of removed elements.\n * @example\n *\n * var array = ['a', 'b', 'c', 'd'];\n * var pulled = _.pullAt(array, [1, 3]);\n *\n * console.log(array);\n * // => ['a', 'c']\n *\n * console.log(pulled);\n * // => ['b', 'd']\n */\n var pullAt = flatRest(function(array, indexes) {\n var length = array == null ? 0 : array.length,\n result = baseAt(array, indexes);\n\n basePullAt(array, arrayMap(indexes, function(index) {\n return isIndex(index, length) ? +index : index;\n }).sort(compareAscending));\n\n return result;\n });\n\n /**\n * Removes all elements from `array` that `predicate` returns truthy for\n * and returns an array of the removed elements. The predicate is invoked\n * with three arguments: (value, index, array).\n *\n * **Note:** Unlike `_.filter`, this method mutates `array`. Use `_.pull`\n * to pull elements from an array by value.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Array\n * @param {Array} array The array to modify.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new array of removed elements.\n * @example\n *\n * var array = [1, 2, 3, 4];\n * var evens = _.remove(array, function(n) {\n * return n % 2 == 0;\n * });\n *\n * console.log(array);\n * // => [1, 3]\n *\n * console.log(evens);\n * // => [2, 4]\n */\n function remove(array, predicate) {\n var result = [];\n if (!(array && array.length)) {\n return result;\n }\n var index = -1,\n indexes = [],\n length = array.length;\n\n predicate = getIteratee(predicate, 3);\n while (++index < length) {\n var value = array[index];\n if (predicate(value, index, array)) {\n result.push(value);\n indexes.push(index);\n }\n }\n basePullAt(array, indexes);\n return result;\n }\n\n /**\n * Reverses `array` so that the first element becomes the last, the second\n * element becomes the second to last, and so on.\n *\n * **Note:** This method mutates `array` and is based on\n * [`Array#reverse`](https://mdn.io/Array/reverse).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to modify.\n * @returns {Array} Returns `array`.\n * @example\n *\n * var array = [1, 2, 3];\n *\n * _.reverse(array);\n * // => [3, 2, 1]\n *\n * console.log(array);\n * // => [3, 2, 1]\n */\n function reverse(array) {\n return array == null ? array : nativeReverse.call(array);\n }\n\n /**\n * Creates a slice of `array` from `start` up to, but not including, `end`.\n *\n * **Note:** This method is used instead of\n * [`Array#slice`](https://mdn.io/Array/slice) to ensure dense arrays are\n * returned.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to slice.\n * @param {number} [start=0] The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns the slice of `array`.\n */\n function slice(array, start, end) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return [];\n }\n if (end && typeof end != 'number' && isIterateeCall(array, start, end)) {\n start = 0;\n end = length;\n }\n else {\n start = start == null ? 0 : toInteger(start);\n end = end === undefined ? length : toInteger(end);\n }\n return baseSlice(array, start, end);\n }\n\n /**\n * Uses a binary search to determine the lowest index at which `value`\n * should be inserted into `array` in order to maintain its sort order.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The sorted array to inspect.\n * @param {*} value The value to evaluate.\n * @returns {number} Returns the index at which `value` should be inserted\n * into `array`.\n * @example\n *\n * _.sortedIndex([30, 50], 40);\n * // => 1\n */\n function sortedIndex(array, value) {\n return baseSortedIndex(array, value);\n }\n\n /**\n * This method is like `_.sortedIndex` except that it accepts `iteratee`\n * which is invoked for `value` and each element of `array` to compute their\n * sort ranking. The iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The sorted array to inspect.\n * @param {*} value The value to evaluate.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {number} Returns the index at which `value` should be inserted\n * into `array`.\n * @example\n *\n * var objects = [{ 'x': 4 }, { 'x': 5 }];\n *\n * _.sortedIndexBy(objects, { 'x': 4 }, function(o) { return o.x; });\n * // => 0\n *\n * // The `_.property` iteratee shorthand.\n * _.sortedIndexBy(objects, { 'x': 4 }, 'x');\n * // => 0\n */\n function sortedIndexBy(array, value, iteratee) {\n return baseSortedIndexBy(array, value, getIteratee(iteratee, 2));\n }\n\n /**\n * This method is like `_.indexOf` except that it performs a binary\n * search on a sorted `array`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n * @example\n *\n * _.sortedIndexOf([4, 5, 5, 5, 6], 5);\n * // => 1\n */\n function sortedIndexOf(array, value) {\n var length = array == null ? 0 : array.length;\n if (length) {\n var index = baseSortedIndex(array, value);\n if (index < length && eq(array[index], value)) {\n return index;\n }\n }\n return -1;\n }\n\n /**\n * This method is like `_.sortedIndex` except that it returns the highest\n * index at which `value` should be inserted into `array` in order to\n * maintain its sort order.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The sorted array to inspect.\n * @param {*} value The value to evaluate.\n * @returns {number} Returns the index at which `value` should be inserted\n * into `array`.\n * @example\n *\n * _.sortedLastIndex([4, 5, 5, 5, 6], 5);\n * // => 4\n */\n function sortedLastIndex(array, value) {\n return baseSortedIndex(array, value, true);\n }\n\n /**\n * This method is like `_.sortedLastIndex` except that it accepts `iteratee`\n * which is invoked for `value` and each element of `array` to compute their\n * sort ranking. The iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The sorted array to inspect.\n * @param {*} value The value to evaluate.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {number} Returns the index at which `value` should be inserted\n * into `array`.\n * @example\n *\n * var objects = [{ 'x': 4 }, { 'x': 5 }];\n *\n * _.sortedLastIndexBy(objects, { 'x': 4 }, function(o) { return o.x; });\n * // => 1\n *\n * // The `_.property` iteratee shorthand.\n * _.sortedLastIndexBy(objects, { 'x': 4 }, 'x');\n * // => 1\n */\n function sortedLastIndexBy(array, value, iteratee) {\n return baseSortedIndexBy(array, value, getIteratee(iteratee, 2), true);\n }\n\n /**\n * This method is like `_.lastIndexOf` except that it performs a binary\n * search on a sorted `array`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n * @example\n *\n * _.sortedLastIndexOf([4, 5, 5, 5, 6], 5);\n * // => 3\n */\n function sortedLastIndexOf(array, value) {\n var length = array == null ? 0 : array.length;\n if (length) {\n var index = baseSortedIndex(array, value, true) - 1;\n if (eq(array[index], value)) {\n return index;\n }\n }\n return -1;\n }\n\n /**\n * This method is like `_.uniq` except that it's designed and optimized\n * for sorted arrays.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @returns {Array} Returns the new duplicate free array.\n * @example\n *\n * _.sortedUniq([1, 1, 2]);\n * // => [1, 2]\n */\n function sortedUniq(array) {\n return (array && array.length)\n ? baseSortedUniq(array)\n : [];\n }\n\n /**\n * This method is like `_.uniqBy` except that it's designed and optimized\n * for sorted arrays.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @returns {Array} Returns the new duplicate free array.\n * @example\n *\n * _.sortedUniqBy([1.1, 1.2, 2.3, 2.4], Math.floor);\n * // => [1.1, 2.3]\n */\n function sortedUniqBy(array, iteratee) {\n return (array && array.length)\n ? baseSortedUniq(array, getIteratee(iteratee, 2))\n : [];\n }\n\n /**\n * Gets all but the first element of `array`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * _.tail([1, 2, 3]);\n * // => [2, 3]\n */\n function tail(array) {\n var length = array == null ? 0 : array.length;\n return length ? baseSlice(array, 1, length) : [];\n }\n\n /**\n * Creates a slice of `array` with `n` elements taken from the beginning.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {number} [n=1] The number of elements to take.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * _.take([1, 2, 3]);\n * // => [1]\n *\n * _.take([1, 2, 3], 2);\n * // => [1, 2]\n *\n * _.take([1, 2, 3], 5);\n * // => [1, 2, 3]\n *\n * _.take([1, 2, 3], 0);\n * // => []\n */\n function take(array, n, guard) {\n if (!(array && array.length)) {\n return [];\n }\n n = (guard || n === undefined) ? 1 : toInteger(n);\n return baseSlice(array, 0, n < 0 ? 0 : n);\n }\n\n /**\n * Creates a slice of `array` with `n` elements taken from the end.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {number} [n=1] The number of elements to take.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * _.takeRight([1, 2, 3]);\n * // => [3]\n *\n * _.takeRight([1, 2, 3], 2);\n * // => [2, 3]\n *\n * _.takeRight([1, 2, 3], 5);\n * // => [1, 2, 3]\n *\n * _.takeRight([1, 2, 3], 0);\n * // => []\n */\n function takeRight(array, n, guard) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return [];\n }\n n = (guard || n === undefined) ? 1 : toInteger(n);\n n = length - n;\n return baseSlice(array, n < 0 ? 0 : n, length);\n }\n\n /**\n * Creates a slice of `array` with elements taken from the end. Elements are\n * taken until `predicate` returns falsey. The predicate is invoked with\n * three arguments: (value, index, array).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'active': true },\n * { 'user': 'fred', 'active': false },\n * { 'user': 'pebbles', 'active': false }\n * ];\n *\n * _.takeRightWhile(users, function(o) { return !o.active; });\n * // => objects for ['fred', 'pebbles']\n *\n * // The `_.matches` iteratee shorthand.\n * _.takeRightWhile(users, { 'user': 'pebbles', 'active': false });\n * // => objects for ['pebbles']\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.takeRightWhile(users, ['active', false]);\n * // => objects for ['fred', 'pebbles']\n *\n * // The `_.property` iteratee shorthand.\n * _.takeRightWhile(users, 'active');\n * // => []\n */\n function takeRightWhile(array, predicate) {\n return (array && array.length)\n ? baseWhile(array, getIteratee(predicate, 3), false, true)\n : [];\n }\n\n /**\n * Creates a slice of `array` with elements taken from the beginning. Elements\n * are taken until `predicate` returns falsey. The predicate is invoked with\n * three arguments: (value, index, array).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'active': false },\n * { 'user': 'fred', 'active': false },\n * { 'user': 'pebbles', 'active': true }\n * ];\n *\n * _.takeWhile(users, function(o) { return !o.active; });\n * // => objects for ['barney', 'fred']\n *\n * // The `_.matches` iteratee shorthand.\n * _.takeWhile(users, { 'user': 'barney', 'active': false });\n * // => objects for ['barney']\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.takeWhile(users, ['active', false]);\n * // => objects for ['barney', 'fred']\n *\n * // The `_.property` iteratee shorthand.\n * _.takeWhile(users, 'active');\n * // => []\n */\n function takeWhile(array, predicate) {\n return (array && array.length)\n ? baseWhile(array, getIteratee(predicate, 3))\n : [];\n }\n\n /**\n * Creates an array of unique values, in order, from all given arrays using\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @returns {Array} Returns the new array of combined values.\n * @example\n *\n * _.union([2], [1, 2]);\n * // => [2, 1]\n */\n var union = baseRest(function(arrays) {\n return baseUniq(baseFlatten(arrays, 1, isArrayLikeObject, true));\n });\n\n /**\n * This method is like `_.union` except that it accepts `iteratee` which is\n * invoked for each element of each `arrays` to generate the criterion by\n * which uniqueness is computed. Result values are chosen from the first\n * array in which the value occurs. The iteratee is invoked with one argument:\n * (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Array} Returns the new array of combined values.\n * @example\n *\n * _.unionBy([2.1], [1.2, 2.3], Math.floor);\n * // => [2.1, 1.2]\n *\n * // The `_.property` iteratee shorthand.\n * _.unionBy([{ 'x': 1 }], [{ 'x': 2 }, { 'x': 1 }], 'x');\n * // => [{ 'x': 1 }, { 'x': 2 }]\n */\n var unionBy = baseRest(function(arrays) {\n var iteratee = last(arrays);\n if (isArrayLikeObject(iteratee)) {\n iteratee = undefined;\n }\n return baseUniq(baseFlatten(arrays, 1, isArrayLikeObject, true), getIteratee(iteratee, 2));\n });\n\n /**\n * This method is like `_.union` except that it accepts `comparator` which\n * is invoked to compare elements of `arrays`. Result values are chosen from\n * the first array in which the value occurs. The comparator is invoked\n * with two arguments: (arrVal, othVal).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of combined values.\n * @example\n *\n * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }];\n * var others = [{ 'x': 1, 'y': 1 }, { 'x': 1, 'y': 2 }];\n *\n * _.unionWith(objects, others, _.isEqual);\n * // => [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }, { 'x': 1, 'y': 1 }]\n */\n var unionWith = baseRest(function(arrays) {\n var comparator = last(arrays);\n comparator = typeof comparator == 'function' ? comparator : undefined;\n return baseUniq(baseFlatten(arrays, 1, isArrayLikeObject, true), undefined, comparator);\n });\n\n /**\n * Creates a duplicate-free version of an array, using\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons, in which only the first occurrence of each element\n * is kept. The order of result values is determined by the order they occur\n * in the array.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @returns {Array} Returns the new duplicate free array.\n * @example\n *\n * _.uniq([2, 1, 2]);\n * // => [2, 1]\n */\n function uniq(array) {\n return (array && array.length) ? baseUniq(array) : [];\n }\n\n /**\n * This method is like `_.uniq` except that it accepts `iteratee` which is\n * invoked for each element in `array` to generate the criterion by which\n * uniqueness is computed. The order of result values is determined by the\n * order they occur in the array. The iteratee is invoked with one argument:\n * (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Array} Returns the new duplicate free array.\n * @example\n *\n * _.uniqBy([2.1, 1.2, 2.3], Math.floor);\n * // => [2.1, 1.2]\n *\n * // The `_.property` iteratee shorthand.\n * _.uniqBy([{ 'x': 1 }, { 'x': 2 }, { 'x': 1 }], 'x');\n * // => [{ 'x': 1 }, { 'x': 2 }]\n */\n function uniqBy(array, iteratee) {\n return (array && array.length) ? baseUniq(array, getIteratee(iteratee, 2)) : [];\n }\n\n /**\n * This method is like `_.uniq` except that it accepts `comparator` which\n * is invoked to compare elements of `array`. The order of result values is\n * determined by the order they occur in the array.The comparator is invoked\n * with two arguments: (arrVal, othVal).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new duplicate free array.\n * @example\n *\n * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }, { 'x': 1, 'y': 2 }];\n *\n * _.uniqWith(objects, _.isEqual);\n * // => [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }]\n */\n function uniqWith(array, comparator) {\n comparator = typeof comparator == 'function' ? comparator : undefined;\n return (array && array.length) ? baseUniq(array, undefined, comparator) : [];\n }\n\n /**\n * This method is like `_.zip` except that it accepts an array of grouped\n * elements and creates an array regrouping the elements to their pre-zip\n * configuration.\n *\n * @static\n * @memberOf _\n * @since 1.2.0\n * @category Array\n * @param {Array} array The array of grouped elements to process.\n * @returns {Array} Returns the new array of regrouped elements.\n * @example\n *\n * var zipped = _.zip(['a', 'b'], [1, 2], [true, false]);\n * // => [['a', 1, true], ['b', 2, false]]\n *\n * _.unzip(zipped);\n * // => [['a', 'b'], [1, 2], [true, false]]\n */\n function unzip(array) {\n if (!(array && array.length)) {\n return [];\n }\n var length = 0;\n array = arrayFilter(array, function(group) {\n if (isArrayLikeObject(group)) {\n length = nativeMax(group.length, length);\n return true;\n }\n });\n return baseTimes(length, function(index) {\n return arrayMap(array, baseProperty(index));\n });\n }\n\n /**\n * This method is like `_.unzip` except that it accepts `iteratee` to specify\n * how regrouped values should be combined. The iteratee is invoked with the\n * elements of each group: (...group).\n *\n * @static\n * @memberOf _\n * @since 3.8.0\n * @category Array\n * @param {Array} array The array of grouped elements to process.\n * @param {Function} [iteratee=_.identity] The function to combine\n * regrouped values.\n * @returns {Array} Returns the new array of regrouped elements.\n * @example\n *\n * var zipped = _.zip([1, 2], [10, 20], [100, 200]);\n * // => [[1, 10, 100], [2, 20, 200]]\n *\n * _.unzipWith(zipped, _.add);\n * // => [3, 30, 300]\n */\n function unzipWith(array, iteratee) {\n if (!(array && array.length)) {\n return [];\n }\n var result = unzip(array);\n if (iteratee == null) {\n return result;\n }\n return arrayMap(result, function(group) {\n return apply(iteratee, undefined, group);\n });\n }\n\n /**\n * Creates an array excluding all given values using\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * **Note:** Unlike `_.pull`, this method returns a new array.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {...*} [values] The values to exclude.\n * @returns {Array} Returns the new array of filtered values.\n * @see _.difference, _.xor\n * @example\n *\n * _.without([2, 1, 2, 3], 1, 2);\n * // => [3]\n */\n var without = baseRest(function(array, values) {\n return isArrayLikeObject(array)\n ? baseDifference(array, values)\n : [];\n });\n\n /**\n * Creates an array of unique values that is the\n * [symmetric difference](https://en.wikipedia.org/wiki/Symmetric_difference)\n * of the given arrays. The order of result values is determined by the order\n * they occur in the arrays.\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @returns {Array} Returns the new array of filtered values.\n * @see _.difference, _.without\n * @example\n *\n * _.xor([2, 1], [2, 3]);\n * // => [1, 3]\n */\n var xor = baseRest(function(arrays) {\n return baseXor(arrayFilter(arrays, isArrayLikeObject));\n });\n\n /**\n * This method is like `_.xor` except that it accepts `iteratee` which is\n * invoked for each element of each `arrays` to generate the criterion by\n * which by which they're compared. The order of result values is determined\n * by the order they occur in the arrays. The iteratee is invoked with one\n * argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Array} Returns the new array of filtered values.\n * @example\n *\n * _.xorBy([2.1, 1.2], [2.3, 3.4], Math.floor);\n * // => [1.2, 3.4]\n *\n * // The `_.property` iteratee shorthand.\n * _.xorBy([{ 'x': 1 }], [{ 'x': 2 }, { 'x': 1 }], 'x');\n * // => [{ 'x': 2 }]\n */\n var xorBy = baseRest(function(arrays) {\n var iteratee = last(arrays);\n if (isArrayLikeObject(iteratee)) {\n iteratee = undefined;\n }\n return baseXor(arrayFilter(arrays, isArrayLikeObject), getIteratee(iteratee, 2));\n });\n\n /**\n * This method is like `_.xor` except that it accepts `comparator` which is\n * invoked to compare elements of `arrays`. The order of result values is\n * determined by the order they occur in the arrays. The comparator is invoked\n * with two arguments: (arrVal, othVal).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of filtered values.\n * @example\n *\n * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }];\n * var others = [{ 'x': 1, 'y': 1 }, { 'x': 1, 'y': 2 }];\n *\n * _.xorWith(objects, others, _.isEqual);\n * // => [{ 'x': 2, 'y': 1 }, { 'x': 1, 'y': 1 }]\n */\n var xorWith = baseRest(function(arrays) {\n var comparator = last(arrays);\n comparator = typeof comparator == 'function' ? comparator : undefined;\n return baseXor(arrayFilter(arrays, isArrayLikeObject), undefined, comparator);\n });\n\n /**\n * Creates an array of grouped elements, the first of which contains the\n * first elements of the given arrays, the second of which contains the\n * second elements of the given arrays, and so on.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {...Array} [arrays] The arrays to process.\n * @returns {Array} Returns the new array of grouped elements.\n * @example\n *\n * _.zip(['a', 'b'], [1, 2], [true, false]);\n * // => [['a', 1, true], ['b', 2, false]]\n */\n var zip = baseRest(unzip);\n\n /**\n * This method is like `_.fromPairs` except that it accepts two arrays,\n * one of property identifiers and one of corresponding values.\n *\n * @static\n * @memberOf _\n * @since 0.4.0\n * @category Array\n * @param {Array} [props=[]] The property identifiers.\n * @param {Array} [values=[]] The property values.\n * @returns {Object} Returns the new object.\n * @example\n *\n * _.zipObject(['a', 'b'], [1, 2]);\n * // => { 'a': 1, 'b': 2 }\n */\n function zipObject(props, values) {\n return baseZipObject(props || [], values || [], assignValue);\n }\n\n /**\n * This method is like `_.zipObject` except that it supports property paths.\n *\n * @static\n * @memberOf _\n * @since 4.1.0\n * @category Array\n * @param {Array} [props=[]] The property identifiers.\n * @param {Array} [values=[]] The property values.\n * @returns {Object} Returns the new object.\n * @example\n *\n * _.zipObjectDeep(['a.b[0].c', 'a.b[1].d'], [1, 2]);\n * // => { 'a': { 'b': [{ 'c': 1 }, { 'd': 2 }] } }\n */\n function zipObjectDeep(props, values) {\n return baseZipObject(props || [], values || [], baseSet);\n }\n\n /**\n * This method is like `_.zip` except that it accepts `iteratee` to specify\n * how grouped values should be combined. The iteratee is invoked with the\n * elements of each group: (...group).\n *\n * @static\n * @memberOf _\n * @since 3.8.0\n * @category Array\n * @param {...Array} [arrays] The arrays to process.\n * @param {Function} [iteratee=_.identity] The function to combine\n * grouped values.\n * @returns {Array} Returns the new array of grouped elements.\n * @example\n *\n * _.zipWith([1, 2], [10, 20], [100, 200], function(a, b, c) {\n * return a + b + c;\n * });\n * // => [111, 222]\n */\n var zipWith = baseRest(function(arrays) {\n var length = arrays.length,\n iteratee = length > 1 ? arrays[length - 1] : undefined;\n\n iteratee = typeof iteratee == 'function' ? (arrays.pop(), iteratee) : undefined;\n return unzipWith(arrays, iteratee);\n });\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates a `lodash` wrapper instance that wraps `value` with explicit method\n * chain sequences enabled. The result of such sequences must be unwrapped\n * with `_#value`.\n *\n * @static\n * @memberOf _\n * @since 1.3.0\n * @category Seq\n * @param {*} value The value to wrap.\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'age': 36 },\n * { 'user': 'fred', 'age': 40 },\n * { 'user': 'pebbles', 'age': 1 }\n * ];\n *\n * var youngest = _\n * .chain(users)\n * .sortBy('age')\n * .map(function(o) {\n * return o.user + ' is ' + o.age;\n * })\n * .head()\n * .value();\n * // => 'pebbles is 1'\n */\n function chain(value) {\n var result = lodash(value);\n result.__chain__ = true;\n return result;\n }\n\n /**\n * This method invokes `interceptor` and returns `value`. The interceptor\n * is invoked with one argument; (value). The purpose of this method is to\n * \"tap into\" a method chain sequence in order to modify intermediate results.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Seq\n * @param {*} value The value to provide to `interceptor`.\n * @param {Function} interceptor The function to invoke.\n * @returns {*} Returns `value`.\n * @example\n *\n * _([1, 2, 3])\n * .tap(function(array) {\n * // Mutate input array.\n * array.pop();\n * })\n * .reverse()\n * .value();\n * // => [2, 1]\n */\n function tap(value, interceptor) {\n interceptor(value);\n return value;\n }\n\n /**\n * This method is like `_.tap` except that it returns the result of `interceptor`.\n * The purpose of this method is to \"pass thru\" values replacing intermediate\n * results in a method chain sequence.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Seq\n * @param {*} value The value to provide to `interceptor`.\n * @param {Function} interceptor The function to invoke.\n * @returns {*} Returns the result of `interceptor`.\n * @example\n *\n * _(' abc ')\n * .chain()\n * .trim()\n * .thru(function(value) {\n * return [value];\n * })\n * .value();\n * // => ['abc']\n */\n function thru(value, interceptor) {\n return interceptor(value);\n }\n\n /**\n * This method is the wrapper version of `_.at`.\n *\n * @name at\n * @memberOf _\n * @since 1.0.0\n * @category Seq\n * @param {...(string|string[])} [paths] The property paths to pick.\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }, 4] };\n *\n * _(object).at(['a[0].b.c', 'a[1]']).value();\n * // => [3, 4]\n */\n var wrapperAt = flatRest(function(paths) {\n var length = paths.length,\n start = length ? paths[0] : 0,\n value = this.__wrapped__,\n interceptor = function(object) { return baseAt(object, paths); };\n\n if (length > 1 || this.__actions__.length ||\n !(value instanceof LazyWrapper) || !isIndex(start)) {\n return this.thru(interceptor);\n }\n value = value.slice(start, +start + (length ? 1 : 0));\n value.__actions__.push({\n 'func': thru,\n 'args': [interceptor],\n 'thisArg': undefined\n });\n return new LodashWrapper(value, this.__chain__).thru(function(array) {\n if (length && !array.length) {\n array.push(undefined);\n }\n return array;\n });\n });\n\n /**\n * Creates a `lodash` wrapper instance with explicit method chain sequences enabled.\n *\n * @name chain\n * @memberOf _\n * @since 0.1.0\n * @category Seq\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'age': 36 },\n * { 'user': 'fred', 'age': 40 }\n * ];\n *\n * // A sequence without explicit chaining.\n * _(users).head();\n * // => { 'user': 'barney', 'age': 36 }\n *\n * // A sequence with explicit chaining.\n * _(users)\n * .chain()\n * .head()\n * .pick('user')\n * .value();\n * // => { 'user': 'barney' }\n */\n function wrapperChain() {\n return chain(this);\n }\n\n /**\n * Executes the chain sequence and returns the wrapped result.\n *\n * @name commit\n * @memberOf _\n * @since 3.2.0\n * @category Seq\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * var array = [1, 2];\n * var wrapped = _(array).push(3);\n *\n * console.log(array);\n * // => [1, 2]\n *\n * wrapped = wrapped.commit();\n * console.log(array);\n * // => [1, 2, 3]\n *\n * wrapped.last();\n * // => 3\n *\n * console.log(array);\n * // => [1, 2, 3]\n */\n function wrapperCommit() {\n return new LodashWrapper(this.value(), this.__chain__);\n }\n\n /**\n * Gets the next value on a wrapped object following the\n * [iterator protocol](https://mdn.io/iteration_protocols#iterator).\n *\n * @name next\n * @memberOf _\n * @since 4.0.0\n * @category Seq\n * @returns {Object} Returns the next iterator value.\n * @example\n *\n * var wrapped = _([1, 2]);\n *\n * wrapped.next();\n * // => { 'done': false, 'value': 1 }\n *\n * wrapped.next();\n * // => { 'done': false, 'value': 2 }\n *\n * wrapped.next();\n * // => { 'done': true, 'value': undefined }\n */\n function wrapperNext() {\n if (this.__values__ === undefined) {\n this.__values__ = toArray(this.value());\n }\n var done = this.__index__ >= this.__values__.length,\n value = done ? undefined : this.__values__[this.__index__++];\n\n return { 'done': done, 'value': value };\n }\n\n /**\n * Enables the wrapper to be iterable.\n *\n * @name Symbol.iterator\n * @memberOf _\n * @since 4.0.0\n * @category Seq\n * @returns {Object} Returns the wrapper object.\n * @example\n *\n * var wrapped = _([1, 2]);\n *\n * wrapped[Symbol.iterator]() === wrapped;\n * // => true\n *\n * Array.from(wrapped);\n * // => [1, 2]\n */\n function wrapperToIterator() {\n return this;\n }\n\n /**\n * Creates a clone of the chain sequence planting `value` as the wrapped value.\n *\n * @name plant\n * @memberOf _\n * @since 3.2.0\n * @category Seq\n * @param {*} value The value to plant.\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * function square(n) {\n * return n * n;\n * }\n *\n * var wrapped = _([1, 2]).map(square);\n * var other = wrapped.plant([3, 4]);\n *\n * other.value();\n * // => [9, 16]\n *\n * wrapped.value();\n * // => [1, 4]\n */\n function wrapperPlant(value) {\n var result,\n parent = this;\n\n while (parent instanceof baseLodash) {\n var clone = wrapperClone(parent);\n clone.__index__ = 0;\n clone.__values__ = undefined;\n if (result) {\n previous.__wrapped__ = clone;\n } else {\n result = clone;\n }\n var previous = clone;\n parent = parent.__wrapped__;\n }\n previous.__wrapped__ = value;\n return result;\n }\n\n /**\n * This method is the wrapper version of `_.reverse`.\n *\n * **Note:** This method mutates the wrapped array.\n *\n * @name reverse\n * @memberOf _\n * @since 0.1.0\n * @category Seq\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * var array = [1, 2, 3];\n *\n * _(array).reverse().value()\n * // => [3, 2, 1]\n *\n * console.log(array);\n * // => [3, 2, 1]\n */\n function wrapperReverse() {\n var value = this.__wrapped__;\n if (value instanceof LazyWrapper) {\n var wrapped = value;\n if (this.__actions__.length) {\n wrapped = new LazyWrapper(this);\n }\n wrapped = wrapped.reverse();\n wrapped.__actions__.push({\n 'func': thru,\n 'args': [reverse],\n 'thisArg': undefined\n });\n return new LodashWrapper(wrapped, this.__chain__);\n }\n return this.thru(reverse);\n }\n\n /**\n * Executes the chain sequence to resolve the unwrapped value.\n *\n * @name value\n * @memberOf _\n * @since 0.1.0\n * @alias toJSON, valueOf\n * @category Seq\n * @returns {*} Returns the resolved unwrapped value.\n * @example\n *\n * _([1, 2, 3]).value();\n * // => [1, 2, 3]\n */\n function wrapperValue() {\n return baseWrapperValue(this.__wrapped__, this.__actions__);\n }\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates an object composed of keys generated from the results of running\n * each element of `collection` thru `iteratee`. The corresponding value of\n * each key is the number of times the key was returned by `iteratee`. The\n * iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 0.5.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The iteratee to transform keys.\n * @returns {Object} Returns the composed aggregate object.\n * @example\n *\n * _.countBy([6.1, 4.2, 6.3], Math.floor);\n * // => { '4': 1, '6': 2 }\n *\n * // The `_.property` iteratee shorthand.\n * _.countBy(['one', 'two', 'three'], 'length');\n * // => { '3': 2, '5': 1 }\n */\n var countBy = createAggregator(function(result, value, key) {\n if (hasOwnProperty.call(result, key)) {\n ++result[key];\n } else {\n baseAssignValue(result, key, 1);\n }\n });\n\n /**\n * Checks if `predicate` returns truthy for **all** elements of `collection`.\n * Iteration is stopped once `predicate` returns falsey. The predicate is\n * invoked with three arguments: (value, index|key, collection).\n *\n * **Note:** This method returns `true` for\n * [empty collections](https://en.wikipedia.org/wiki/Empty_set) because\n * [everything is true](https://en.wikipedia.org/wiki/Vacuous_truth) of\n * elements of empty collections.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {boolean} Returns `true` if all elements pass the predicate check,\n * else `false`.\n * @example\n *\n * _.every([true, 1, null, 'yes'], Boolean);\n * // => false\n *\n * var users = [\n * { 'user': 'barney', 'age': 36, 'active': false },\n * { 'user': 'fred', 'age': 40, 'active': false }\n * ];\n *\n * // The `_.matches` iteratee shorthand.\n * _.every(users, { 'user': 'barney', 'active': false });\n * // => false\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.every(users, ['active', false]);\n * // => true\n *\n * // The `_.property` iteratee shorthand.\n * _.every(users, 'active');\n * // => false\n */\n function every(collection, predicate, guard) {\n var func = isArray(collection) ? arrayEvery : baseEvery;\n if (guard && isIterateeCall(collection, predicate, guard)) {\n predicate = undefined;\n }\n return func(collection, getIteratee(predicate, 3));\n }\n\n /**\n * Iterates over elements of `collection`, returning an array of all elements\n * `predicate` returns truthy for. The predicate is invoked with three\n * arguments: (value, index|key, collection).\n *\n * **Note:** Unlike `_.remove`, this method returns a new array.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n * @see _.reject\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'age': 36, 'active': true },\n * { 'user': 'fred', 'age': 40, 'active': false }\n * ];\n *\n * _.filter(users, function(o) { return !o.active; });\n * // => objects for ['fred']\n *\n * // The `_.matches` iteratee shorthand.\n * _.filter(users, { 'age': 36, 'active': true });\n * // => objects for ['barney']\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.filter(users, ['active', false]);\n * // => objects for ['fred']\n *\n * // The `_.property` iteratee shorthand.\n * _.filter(users, 'active');\n * // => objects for ['barney']\n *\n * // Combining several predicates using `_.overEvery` or `_.overSome`.\n * _.filter(users, _.overSome([{ 'age': 36 }, ['age', 40]]));\n * // => objects for ['fred', 'barney']\n */\n function filter(collection, predicate) {\n var func = isArray(collection) ? arrayFilter : baseFilter;\n return func(collection, getIteratee(predicate, 3));\n }\n\n /**\n * Iterates over elements of `collection`, returning the first element\n * `predicate` returns truthy for. The predicate is invoked with three\n * arguments: (value, index|key, collection).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param {number} [fromIndex=0] The index to search from.\n * @returns {*} Returns the matched element, else `undefined`.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'age': 36, 'active': true },\n * { 'user': 'fred', 'age': 40, 'active': false },\n * { 'user': 'pebbles', 'age': 1, 'active': true }\n * ];\n *\n * _.find(users, function(o) { return o.age < 40; });\n * // => object for 'barney'\n *\n * // The `_.matches` iteratee shorthand.\n * _.find(users, { 'age': 1, 'active': true });\n * // => object for 'pebbles'\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.find(users, ['active', false]);\n * // => object for 'fred'\n *\n * // The `_.property` iteratee shorthand.\n * _.find(users, 'active');\n * // => object for 'barney'\n */\n var find = createFind(findIndex);\n\n /**\n * This method is like `_.find` except that it iterates over elements of\n * `collection` from right to left.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param {number} [fromIndex=collection.length-1] The index to search from.\n * @returns {*} Returns the matched element, else `undefined`.\n * @example\n *\n * _.findLast([1, 2, 3, 4], function(n) {\n * return n % 2 == 1;\n * });\n * // => 3\n */\n var findLast = createFind(findLastIndex);\n\n /**\n * Creates a flattened array of values by running each element in `collection`\n * thru `iteratee` and flattening the mapped results. The iteratee is invoked\n * with three arguments: (value, index|key, collection).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * function duplicate(n) {\n * return [n, n];\n * }\n *\n * _.flatMap([1, 2], duplicate);\n * // => [1, 1, 2, 2]\n */\n function flatMap(collection, iteratee) {\n return baseFlatten(map(collection, iteratee), 1);\n }\n\n /**\n * This method is like `_.flatMap` except that it recursively flattens the\n * mapped results.\n *\n * @static\n * @memberOf _\n * @since 4.7.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * function duplicate(n) {\n * return [[[n, n]]];\n * }\n *\n * _.flatMapDeep([1, 2], duplicate);\n * // => [1, 1, 2, 2]\n */\n function flatMapDeep(collection, iteratee) {\n return baseFlatten(map(collection, iteratee), INFINITY);\n }\n\n /**\n * This method is like `_.flatMap` except that it recursively flattens the\n * mapped results up to `depth` times.\n *\n * @static\n * @memberOf _\n * @since 4.7.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @param {number} [depth=1] The maximum recursion depth.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * function duplicate(n) {\n * return [[[n, n]]];\n * }\n *\n * _.flatMapDepth([1, 2], duplicate, 2);\n * // => [[1, 1], [2, 2]]\n */\n function flatMapDepth(collection, iteratee, depth) {\n depth = depth === undefined ? 1 : toInteger(depth);\n return baseFlatten(map(collection, iteratee), depth);\n }\n\n /**\n * Iterates over elements of `collection` and invokes `iteratee` for each element.\n * The iteratee is invoked with three arguments: (value, index|key, collection).\n * Iteratee functions may exit iteration early by explicitly returning `false`.\n *\n * **Note:** As with other \"Collections\" methods, objects with a \"length\"\n * property are iterated like arrays. To avoid this behavior use `_.forIn`\n * or `_.forOwn` for object iteration.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @alias each\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Array|Object} Returns `collection`.\n * @see _.forEachRight\n * @example\n *\n * _.forEach([1, 2], function(value) {\n * console.log(value);\n * });\n * // => Logs `1` then `2`.\n *\n * _.forEach({ 'a': 1, 'b': 2 }, function(value, key) {\n * console.log(key);\n * });\n * // => Logs 'a' then 'b' (iteration order is not guaranteed).\n */\n function forEach(collection, iteratee) {\n var func = isArray(collection) ? arrayEach : baseEach;\n return func(collection, getIteratee(iteratee, 3));\n }\n\n /**\n * This method is like `_.forEach` except that it iterates over elements of\n * `collection` from right to left.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @alias eachRight\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Array|Object} Returns `collection`.\n * @see _.forEach\n * @example\n *\n * _.forEachRight([1, 2], function(value) {\n * console.log(value);\n * });\n * // => Logs `2` then `1`.\n */\n function forEachRight(collection, iteratee) {\n var func = isArray(collection) ? arrayEachRight : baseEachRight;\n return func(collection, getIteratee(iteratee, 3));\n }\n\n /**\n * Creates an object composed of keys generated from the results of running\n * each element of `collection` thru `iteratee`. The order of grouped values\n * is determined by the order they occur in `collection`. The corresponding\n * value of each key is an array of elements responsible for generating the\n * key. The iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The iteratee to transform keys.\n * @returns {Object} Returns the composed aggregate object.\n * @example\n *\n * _.groupBy([6.1, 4.2, 6.3], Math.floor);\n * // => { '4': [4.2], '6': [6.1, 6.3] }\n *\n * // The `_.property` iteratee shorthand.\n * _.groupBy(['one', 'two', 'three'], 'length');\n * // => { '3': ['one', 'two'], '5': ['three'] }\n */\n var groupBy = createAggregator(function(result, value, key) {\n if (hasOwnProperty.call(result, key)) {\n result[key].push(value);\n } else {\n baseAssignValue(result, key, [value]);\n }\n });\n\n /**\n * Checks if `value` is in `collection`. If `collection` is a string, it's\n * checked for a substring of `value`, otherwise\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * is used for equality comparisons. If `fromIndex` is negative, it's used as\n * the offset from the end of `collection`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object|string} collection The collection to inspect.\n * @param {*} value The value to search for.\n * @param {number} [fromIndex=0] The index to search from.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.reduce`.\n * @returns {boolean} Returns `true` if `value` is found, else `false`.\n * @example\n *\n * _.includes([1, 2, 3], 1);\n * // => true\n *\n * _.includes([1, 2, 3], 1, 2);\n * // => false\n *\n * _.includes({ 'a': 1, 'b': 2 }, 1);\n * // => true\n *\n * _.includes('abcd', 'bc');\n * // => true\n */\n function includes(collection, value, fromIndex, guard) {\n collection = isArrayLike(collection) ? collection : values(collection);\n fromIndex = (fromIndex && !guard) ? toInteger(fromIndex) : 0;\n\n var length = collection.length;\n if (fromIndex < 0) {\n fromIndex = nativeMax(length + fromIndex, 0);\n }\n return isString(collection)\n ? (fromIndex <= length && collection.indexOf(value, fromIndex) > -1)\n : (!!length && baseIndexOf(collection, value, fromIndex) > -1);\n }\n\n /**\n * Invokes the method at `path` of each element in `collection`, returning\n * an array of the results of each invoked method. Any additional arguments\n * are provided to each invoked method. If `path` is a function, it's invoked\n * for, and `this` bound to, each element in `collection`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Array|Function|string} path The path of the method to invoke or\n * the function invoked per iteration.\n * @param {...*} [args] The arguments to invoke each method with.\n * @returns {Array} Returns the array of results.\n * @example\n *\n * _.invokeMap([[5, 1, 7], [3, 2, 1]], 'sort');\n * // => [[1, 5, 7], [1, 2, 3]]\n *\n * _.invokeMap([123, 456], String.prototype.split, '');\n * // => [['1', '2', '3'], ['4', '5', '6']]\n */\n var invokeMap = baseRest(function(collection, path, args) {\n var index = -1,\n isFunc = typeof path == 'function',\n result = isArrayLike(collection) ? Array(collection.length) : [];\n\n baseEach(collection, function(value) {\n result[++index] = isFunc ? apply(path, value, args) : baseInvoke(value, path, args);\n });\n return result;\n });\n\n /**\n * Creates an object composed of keys generated from the results of running\n * each element of `collection` thru `iteratee`. The corresponding value of\n * each key is the last element responsible for generating the key. The\n * iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The iteratee to transform keys.\n * @returns {Object} Returns the composed aggregate object.\n * @example\n *\n * var array = [\n * { 'dir': 'left', 'code': 97 },\n * { 'dir': 'right', 'code': 100 }\n * ];\n *\n * _.keyBy(array, function(o) {\n * return String.fromCharCode(o.code);\n * });\n * // => { 'a': { 'dir': 'left', 'code': 97 }, 'd': { 'dir': 'right', 'code': 100 } }\n *\n * _.keyBy(array, 'dir');\n * // => { 'left': { 'dir': 'left', 'code': 97 }, 'right': { 'dir': 'right', 'code': 100 } }\n */\n var keyBy = createAggregator(function(result, value, key) {\n baseAssignValue(result, key, value);\n });\n\n /**\n * Creates an array of values by running each element in `collection` thru\n * `iteratee`. The iteratee is invoked with three arguments:\n * (value, index|key, collection).\n *\n * Many lodash methods are guarded to work as iteratees for methods like\n * `_.every`, `_.filter`, `_.map`, `_.mapValues`, `_.reject`, and `_.some`.\n *\n * The guarded methods are:\n * `ary`, `chunk`, `curry`, `curryRight`, `drop`, `dropRight`, `every`,\n * `fill`, `invert`, `parseInt`, `random`, `range`, `rangeRight`, `repeat`,\n * `sampleSize`, `slice`, `some`, `sortBy`, `split`, `take`, `takeRight`,\n * `template`, `trim`, `trimEnd`, `trimStart`, and `words`\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n * @example\n *\n * function square(n) {\n * return n * n;\n * }\n *\n * _.map([4, 8], square);\n * // => [16, 64]\n *\n * _.map({ 'a': 4, 'b': 8 }, square);\n * // => [16, 64] (iteration order is not guaranteed)\n *\n * var users = [\n * { 'user': 'barney' },\n * { 'user': 'fred' }\n * ];\n *\n * // The `_.property` iteratee shorthand.\n * _.map(users, 'user');\n * // => ['barney', 'fred']\n */\n function map(collection, iteratee) {\n var func = isArray(collection) ? arrayMap : baseMap;\n return func(collection, getIteratee(iteratee, 3));\n }\n\n /**\n * This method is like `_.sortBy` except that it allows specifying the sort\n * orders of the iteratees to sort by. If `orders` is unspecified, all values\n * are sorted in ascending order. Otherwise, specify an order of \"desc\" for\n * descending or \"asc\" for ascending sort order of corresponding values.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Array[]|Function[]|Object[]|string[]} [iteratees=[_.identity]]\n * The iteratees to sort by.\n * @param {string[]} [orders] The sort orders of `iteratees`.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.reduce`.\n * @returns {Array} Returns the new sorted array.\n * @example\n *\n * var users = [\n * { 'user': 'fred', 'age': 48 },\n * { 'user': 'barney', 'age': 34 },\n * { 'user': 'fred', 'age': 40 },\n * { 'user': 'barney', 'age': 36 }\n * ];\n *\n * // Sort by `user` in ascending order and by `age` in descending order.\n * _.orderBy(users, ['user', 'age'], ['asc', 'desc']);\n * // => objects for [['barney', 36], ['barney', 34], ['fred', 48], ['fred', 40]]\n */\n function orderBy(collection, iteratees, orders, guard) {\n if (collection == null) {\n return [];\n }\n if (!isArray(iteratees)) {\n iteratees = iteratees == null ? [] : [iteratees];\n }\n orders = guard ? undefined : orders;\n if (!isArray(orders)) {\n orders = orders == null ? [] : [orders];\n }\n return baseOrderBy(collection, iteratees, orders);\n }\n\n /**\n * Creates an array of elements split into two groups, the first of which\n * contains elements `predicate` returns truthy for, the second of which\n * contains elements `predicate` returns falsey for. The predicate is\n * invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the array of grouped elements.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'age': 36, 'active': false },\n * { 'user': 'fred', 'age': 40, 'active': true },\n * { 'user': 'pebbles', 'age': 1, 'active': false }\n * ];\n *\n * _.partition(users, function(o) { return o.active; });\n * // => objects for [['fred'], ['barney', 'pebbles']]\n *\n * // The `_.matches` iteratee shorthand.\n * _.partition(users, { 'age': 1, 'active': false });\n * // => objects for [['pebbles'], ['barney', 'fred']]\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.partition(users, ['active', false]);\n * // => objects for [['barney', 'pebbles'], ['fred']]\n *\n * // The `_.property` iteratee shorthand.\n * _.partition(users, 'active');\n * // => objects for [['fred'], ['barney', 'pebbles']]\n */\n var partition = createAggregator(function(result, value, key) {\n result[key ? 0 : 1].push(value);\n }, function() { return [[], []]; });\n\n /**\n * Reduces `collection` to a value which is the accumulated result of running\n * each element in `collection` thru `iteratee`, where each successive\n * invocation is supplied the return value of the previous. If `accumulator`\n * is not given, the first element of `collection` is used as the initial\n * value. The iteratee is invoked with four arguments:\n * (accumulator, value, index|key, collection).\n *\n * Many lodash methods are guarded to work as iteratees for methods like\n * `_.reduce`, `_.reduceRight`, and `_.transform`.\n *\n * The guarded methods are:\n * `assign`, `defaults`, `defaultsDeep`, `includes`, `merge`, `orderBy`,\n * and `sortBy`\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @param {*} [accumulator] The initial value.\n * @returns {*} Returns the accumulated value.\n * @see _.reduceRight\n * @example\n *\n * _.reduce([1, 2], function(sum, n) {\n * return sum + n;\n * }, 0);\n * // => 3\n *\n * _.reduce({ 'a': 1, 'b': 2, 'c': 1 }, function(result, value, key) {\n * (result[value] || (result[value] = [])).push(key);\n * return result;\n * }, {});\n * // => { '1': ['a', 'c'], '2': ['b'] } (iteration order is not guaranteed)\n */\n function reduce(collection, iteratee, accumulator) {\n var func = isArray(collection) ? arrayReduce : baseReduce,\n initAccum = arguments.length < 3;\n\n return func(collection, getIteratee(iteratee, 4), accumulator, initAccum, baseEach);\n }\n\n /**\n * This method is like `_.reduce` except that it iterates over elements of\n * `collection` from right to left.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @param {*} [accumulator] The initial value.\n * @returns {*} Returns the accumulated value.\n * @see _.reduce\n * @example\n *\n * var array = [[0, 1], [2, 3], [4, 5]];\n *\n * _.reduceRight(array, function(flattened, other) {\n * return flattened.concat(other);\n * }, []);\n * // => [4, 5, 2, 3, 0, 1]\n */\n function reduceRight(collection, iteratee, accumulator) {\n var func = isArray(collection) ? arrayReduceRight : baseReduce,\n initAccum = arguments.length < 3;\n\n return func(collection, getIteratee(iteratee, 4), accumulator, initAccum, baseEachRight);\n }\n\n /**\n * The opposite of `_.filter`; this method returns the elements of `collection`\n * that `predicate` does **not** return truthy for.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n * @see _.filter\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'age': 36, 'active': false },\n * { 'user': 'fred', 'age': 40, 'active': true }\n * ];\n *\n * _.reject(users, function(o) { return !o.active; });\n * // => objects for ['fred']\n *\n * // The `_.matches` iteratee shorthand.\n * _.reject(users, { 'age': 40, 'active': true });\n * // => objects for ['barney']\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.reject(users, ['active', false]);\n * // => objects for ['fred']\n *\n * // The `_.property` iteratee shorthand.\n * _.reject(users, 'active');\n * // => objects for ['barney']\n */\n function reject(collection, predicate) {\n var func = isArray(collection) ? arrayFilter : baseFilter;\n return func(collection, negate(getIteratee(predicate, 3)));\n }\n\n /**\n * Gets a random element from `collection`.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to sample.\n * @returns {*} Returns the random element.\n * @example\n *\n * _.sample([1, 2, 3, 4]);\n * // => 2\n */\n function sample(collection) {\n var func = isArray(collection) ? arraySample : baseSample;\n return func(collection);\n }\n\n /**\n * Gets `n` random elements at unique keys from `collection` up to the\n * size of `collection`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to sample.\n * @param {number} [n=1] The number of elements to sample.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the random elements.\n * @example\n *\n * _.sampleSize([1, 2, 3], 2);\n * // => [3, 1]\n *\n * _.sampleSize([1, 2, 3], 4);\n * // => [2, 3, 1]\n */\n function sampleSize(collection, n, guard) {\n if ((guard ? isIterateeCall(collection, n, guard) : n === undefined)) {\n n = 1;\n } else {\n n = toInteger(n);\n }\n var func = isArray(collection) ? arraySampleSize : baseSampleSize;\n return func(collection, n);\n }\n\n /**\n * Creates an array of shuffled values, using a version of the\n * [Fisher-Yates shuffle](https://en.wikipedia.org/wiki/Fisher-Yates_shuffle).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to shuffle.\n * @returns {Array} Returns the new shuffled array.\n * @example\n *\n * _.shuffle([1, 2, 3, 4]);\n * // => [4, 1, 3, 2]\n */\n function shuffle(collection) {\n var func = isArray(collection) ? arrayShuffle : baseShuffle;\n return func(collection);\n }\n\n /**\n * Gets the size of `collection` by returning its length for array-like\n * values or the number of own enumerable string keyed properties for objects.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object|string} collection The collection to inspect.\n * @returns {number} Returns the collection size.\n * @example\n *\n * _.size([1, 2, 3]);\n * // => 3\n *\n * _.size({ 'a': 1, 'b': 2 });\n * // => 2\n *\n * _.size('pebbles');\n * // => 7\n */\n function size(collection) {\n if (collection == null) {\n return 0;\n }\n if (isArrayLike(collection)) {\n return isString(collection) ? stringSize(collection) : collection.length;\n }\n var tag = getTag(collection);\n if (tag == mapTag || tag == setTag) {\n return collection.size;\n }\n return baseKeys(collection).length;\n }\n\n /**\n * Checks if `predicate` returns truthy for **any** element of `collection`.\n * Iteration is stopped once `predicate` returns truthy. The predicate is\n * invoked with three arguments: (value, index|key, collection).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {boolean} Returns `true` if any element passes the predicate check,\n * else `false`.\n * @example\n *\n * _.some([null, 0, 'yes', false], Boolean);\n * // => true\n *\n * var users = [\n * { 'user': 'barney', 'active': true },\n * { 'user': 'fred', 'active': false }\n * ];\n *\n * // The `_.matches` iteratee shorthand.\n * _.some(users, { 'user': 'barney', 'active': false });\n * // => false\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.some(users, ['active', false]);\n * // => true\n *\n * // The `_.property` iteratee shorthand.\n * _.some(users, 'active');\n * // => true\n */\n function some(collection, predicate, guard) {\n var func = isArray(collection) ? arraySome : baseSome;\n if (guard && isIterateeCall(collection, predicate, guard)) {\n predicate = undefined;\n }\n return func(collection, getIteratee(predicate, 3));\n }\n\n /**\n * Creates an array of elements, sorted in ascending order by the results of\n * running each element in a collection thru each iteratee. This method\n * performs a stable sort, that is, it preserves the original sort order of\n * equal elements. The iteratees are invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {...(Function|Function[])} [iteratees=[_.identity]]\n * The iteratees to sort by.\n * @returns {Array} Returns the new sorted array.\n * @example\n *\n * var users = [\n * { 'user': 'fred', 'age': 48 },\n * { 'user': 'barney', 'age': 36 },\n * { 'user': 'fred', 'age': 30 },\n * { 'user': 'barney', 'age': 34 }\n * ];\n *\n * _.sortBy(users, [function(o) { return o.user; }]);\n * // => objects for [['barney', 36], ['barney', 34], ['fred', 48], ['fred', 30]]\n *\n * _.sortBy(users, ['user', 'age']);\n * // => objects for [['barney', 34], ['barney', 36], ['fred', 30], ['fred', 48]]\n */\n var sortBy = baseRest(function(collection, iteratees) {\n if (collection == null) {\n return [];\n }\n var length = iteratees.length;\n if (length > 1 && isIterateeCall(collection, iteratees[0], iteratees[1])) {\n iteratees = [];\n } else if (length > 2 && isIterateeCall(iteratees[0], iteratees[1], iteratees[2])) {\n iteratees = [iteratees[0]];\n }\n return baseOrderBy(collection, baseFlatten(iteratees, 1), []);\n });\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Gets the timestamp of the number of milliseconds that have elapsed since\n * the Unix epoch (1 January 1970 00:00:00 UTC).\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Date\n * @returns {number} Returns the timestamp.\n * @example\n *\n * _.defer(function(stamp) {\n * console.log(_.now() - stamp);\n * }, _.now());\n * // => Logs the number of milliseconds it took for the deferred invocation.\n */\n var now = ctxNow || function() {\n return root.Date.now();\n };\n\n /*------------------------------------------------------------------------*/\n\n /**\n * The opposite of `_.before`; this method creates a function that invokes\n * `func` once it's called `n` or more times.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {number} n The number of calls before `func` is invoked.\n * @param {Function} func The function to restrict.\n * @returns {Function} Returns the new restricted function.\n * @example\n *\n * var saves = ['profile', 'settings'];\n *\n * var done = _.after(saves.length, function() {\n * console.log('done saving!');\n * });\n *\n * _.forEach(saves, function(type) {\n * asyncSave({ 'type': type, 'complete': done });\n * });\n * // => Logs 'done saving!' after the two async saves have completed.\n */\n function after(n, func) {\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n n = toInteger(n);\n return function() {\n if (--n < 1) {\n return func.apply(this, arguments);\n }\n };\n }\n\n /**\n * Creates a function that invokes `func`, with up to `n` arguments,\n * ignoring any additional arguments.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Function\n * @param {Function} func The function to cap arguments for.\n * @param {number} [n=func.length] The arity cap.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Function} Returns the new capped function.\n * @example\n *\n * _.map(['6', '8', '10'], _.ary(parseInt, 1));\n * // => [6, 8, 10]\n */\n function ary(func, n, guard) {\n n = guard ? undefined : n;\n n = (func && n == null) ? func.length : n;\n return createWrap(func, WRAP_ARY_FLAG, undefined, undefined, undefined, undefined, n);\n }\n\n /**\n * Creates a function that invokes `func`, with the `this` binding and arguments\n * of the created function, while it's called less than `n` times. Subsequent\n * calls to the created function return the result of the last `func` invocation.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Function\n * @param {number} n The number of calls at which `func` is no longer invoked.\n * @param {Function} func The function to restrict.\n * @returns {Function} Returns the new restricted function.\n * @example\n *\n * jQuery(element).on('click', _.before(5, addContactToList));\n * // => Allows adding up to 4 contacts to the list.\n */\n function before(n, func) {\n var result;\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n n = toInteger(n);\n return function() {\n if (--n > 0) {\n result = func.apply(this, arguments);\n }\n if (n <= 1) {\n func = undefined;\n }\n return result;\n };\n }\n\n /**\n * Creates a function that invokes `func` with the `this` binding of `thisArg`\n * and `partials` prepended to the arguments it receives.\n *\n * The `_.bind.placeholder` value, which defaults to `_` in monolithic builds,\n * may be used as a placeholder for partially applied arguments.\n *\n * **Note:** Unlike native `Function#bind`, this method doesn't set the \"length\"\n * property of bound functions.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to bind.\n * @param {*} thisArg The `this` binding of `func`.\n * @param {...*} [partials] The arguments to be partially applied.\n * @returns {Function} Returns the new bound function.\n * @example\n *\n * function greet(greeting, punctuation) {\n * return greeting + ' ' + this.user + punctuation;\n * }\n *\n * var object = { 'user': 'fred' };\n *\n * var bound = _.bind(greet, object, 'hi');\n * bound('!');\n * // => 'hi fred!'\n *\n * // Bound with placeholders.\n * var bound = _.bind(greet, object, _, '!');\n * bound('hi');\n * // => 'hi fred!'\n */\n var bind = baseRest(function(func, thisArg, partials) {\n var bitmask = WRAP_BIND_FLAG;\n if (partials.length) {\n var holders = replaceHolders(partials, getHolder(bind));\n bitmask |= WRAP_PARTIAL_FLAG;\n }\n return createWrap(func, bitmask, thisArg, partials, holders);\n });\n\n /**\n * Creates a function that invokes the method at `object[key]` with `partials`\n * prepended to the arguments it receives.\n *\n * This method differs from `_.bind` by allowing bound functions to reference\n * methods that may be redefined or don't yet exist. See\n * [Peter Michaux's article](http://peter.michaux.ca/articles/lazy-function-definition-pattern)\n * for more details.\n *\n * The `_.bindKey.placeholder` value, which defaults to `_` in monolithic\n * builds, may be used as a placeholder for partially applied arguments.\n *\n * @static\n * @memberOf _\n * @since 0.10.0\n * @category Function\n * @param {Object} object The object to invoke the method on.\n * @param {string} key The key of the method.\n * @param {...*} [partials] The arguments to be partially applied.\n * @returns {Function} Returns the new bound function.\n * @example\n *\n * var object = {\n * 'user': 'fred',\n * 'greet': function(greeting, punctuation) {\n * return greeting + ' ' + this.user + punctuation;\n * }\n * };\n *\n * var bound = _.bindKey(object, 'greet', 'hi');\n * bound('!');\n * // => 'hi fred!'\n *\n * object.greet = function(greeting, punctuation) {\n * return greeting + 'ya ' + this.user + punctuation;\n * };\n *\n * bound('!');\n * // => 'hiya fred!'\n *\n * // Bound with placeholders.\n * var bound = _.bindKey(object, 'greet', _, '!');\n * bound('hi');\n * // => 'hiya fred!'\n */\n var bindKey = baseRest(function(object, key, partials) {\n var bitmask = WRAP_BIND_FLAG | WRAP_BIND_KEY_FLAG;\n if (partials.length) {\n var holders = replaceHolders(partials, getHolder(bindKey));\n bitmask |= WRAP_PARTIAL_FLAG;\n }\n return createWrap(key, bitmask, object, partials, holders);\n });\n\n /**\n * Creates a function that accepts arguments of `func` and either invokes\n * `func` returning its result, if at least `arity` number of arguments have\n * been provided, or returns a function that accepts the remaining `func`\n * arguments, and so on. The arity of `func` may be specified if `func.length`\n * is not sufficient.\n *\n * The `_.curry.placeholder` value, which defaults to `_` in monolithic builds,\n * may be used as a placeholder for provided arguments.\n *\n * **Note:** This method doesn't set the \"length\" property of curried functions.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Function\n * @param {Function} func The function to curry.\n * @param {number} [arity=func.length] The arity of `func`.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Function} Returns the new curried function.\n * @example\n *\n * var abc = function(a, b, c) {\n * return [a, b, c];\n * };\n *\n * var curried = _.curry(abc);\n *\n * curried(1)(2)(3);\n * // => [1, 2, 3]\n *\n * curried(1, 2)(3);\n * // => [1, 2, 3]\n *\n * curried(1, 2, 3);\n * // => [1, 2, 3]\n *\n * // Curried with placeholders.\n * curried(1)(_, 3)(2);\n * // => [1, 2, 3]\n */\n function curry(func, arity, guard) {\n arity = guard ? undefined : arity;\n var result = createWrap(func, WRAP_CURRY_FLAG, undefined, undefined, undefined, undefined, undefined, arity);\n result.placeholder = curry.placeholder;\n return result;\n }\n\n /**\n * This method is like `_.curry` except that arguments are applied to `func`\n * in the manner of `_.partialRight` instead of `_.partial`.\n *\n * The `_.curryRight.placeholder` value, which defaults to `_` in monolithic\n * builds, may be used as a placeholder for provided arguments.\n *\n * **Note:** This method doesn't set the \"length\" property of curried functions.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Function\n * @param {Function} func The function to curry.\n * @param {number} [arity=func.length] The arity of `func`.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Function} Returns the new curried function.\n * @example\n *\n * var abc = function(a, b, c) {\n * return [a, b, c];\n * };\n *\n * var curried = _.curryRight(abc);\n *\n * curried(3)(2)(1);\n * // => [1, 2, 3]\n *\n * curried(2, 3)(1);\n * // => [1, 2, 3]\n *\n * curried(1, 2, 3);\n * // => [1, 2, 3]\n *\n * // Curried with placeholders.\n * curried(3)(1, _)(2);\n * // => [1, 2, 3]\n */\n function curryRight(func, arity, guard) {\n arity = guard ? undefined : arity;\n var result = createWrap(func, WRAP_CURRY_RIGHT_FLAG, undefined, undefined, undefined, undefined, undefined, arity);\n result.placeholder = curryRight.placeholder;\n return result;\n }\n\n /**\n * Creates a debounced function that delays invoking `func` until after `wait`\n * milliseconds have elapsed since the last time the debounced function was\n * invoked. The debounced function comes with a `cancel` method to cancel\n * delayed `func` invocations and a `flush` method to immediately invoke them.\n * Provide `options` to indicate whether `func` should be invoked on the\n * leading and/or trailing edge of the `wait` timeout. The `func` is invoked\n * with the last arguments provided to the debounced function. Subsequent\n * calls to the debounced function return the result of the last `func`\n * invocation.\n *\n * **Note:** If `leading` and `trailing` options are `true`, `func` is\n * invoked on the trailing edge of the timeout only if the debounced function\n * is invoked more than once during the `wait` timeout.\n *\n * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred\n * until to the next tick, similar to `setTimeout` with a timeout of `0`.\n *\n * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)\n * for details over the differences between `_.debounce` and `_.throttle`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to debounce.\n * @param {number} [wait=0] The number of milliseconds to delay.\n * @param {Object} [options={}] The options object.\n * @param {boolean} [options.leading=false]\n * Specify invoking on the leading edge of the timeout.\n * @param {number} [options.maxWait]\n * The maximum time `func` is allowed to be delayed before it's invoked.\n * @param {boolean} [options.trailing=true]\n * Specify invoking on the trailing edge of the timeout.\n * @returns {Function} Returns the new debounced function.\n * @example\n *\n * // Avoid costly calculations while the window size is in flux.\n * jQuery(window).on('resize', _.debounce(calculateLayout, 150));\n *\n * // Invoke `sendMail` when clicked, debouncing subsequent calls.\n * jQuery(element).on('click', _.debounce(sendMail, 300, {\n * 'leading': true,\n * 'trailing': false\n * }));\n *\n * // Ensure `batchLog` is invoked once after 1 second of debounced calls.\n * var debounced = _.debounce(batchLog, 250, { 'maxWait': 1000 });\n * var source = new EventSource('/stream');\n * jQuery(source).on('message', debounced);\n *\n * // Cancel the trailing debounced invocation.\n * jQuery(window).on('popstate', debounced.cancel);\n */\n function debounce(func, wait, options) {\n var lastArgs,\n lastThis,\n maxWait,\n result,\n timerId,\n lastCallTime,\n lastInvokeTime = 0,\n leading = false,\n maxing = false,\n trailing = true;\n\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n wait = toNumber(wait) || 0;\n if (isObject(options)) {\n leading = !!options.leading;\n maxing = 'maxWait' in options;\n maxWait = maxing ? nativeMax(toNumber(options.maxWait) || 0, wait) : maxWait;\n trailing = 'trailing' in options ? !!options.trailing : trailing;\n }\n\n function invokeFunc(time) {\n var args = lastArgs,\n thisArg = lastThis;\n\n lastArgs = lastThis = undefined;\n lastInvokeTime = time;\n result = func.apply(thisArg, args);\n return result;\n }\n\n function leadingEdge(time) {\n // Reset any `maxWait` timer.\n lastInvokeTime = time;\n // Start the timer for the trailing edge.\n timerId = setTimeout(timerExpired, wait);\n // Invoke the leading edge.\n return leading ? invokeFunc(time) : result;\n }\n\n function remainingWait(time) {\n var timeSinceLastCall = time - lastCallTime,\n timeSinceLastInvoke = time - lastInvokeTime,\n timeWaiting = wait - timeSinceLastCall;\n\n return maxing\n ? nativeMin(timeWaiting, maxWait - timeSinceLastInvoke)\n : timeWaiting;\n }\n\n function shouldInvoke(time) {\n var timeSinceLastCall = time - lastCallTime,\n timeSinceLastInvoke = time - lastInvokeTime;\n\n // Either this is the first call, activity has stopped and we're at the\n // trailing edge, the system time has gone backwards and we're treating\n // it as the trailing edge, or we've hit the `maxWait` limit.\n return (lastCallTime === undefined || (timeSinceLastCall >= wait) ||\n (timeSinceLastCall < 0) || (maxing && timeSinceLastInvoke >= maxWait));\n }\n\n function timerExpired() {\n var time = now();\n if (shouldInvoke(time)) {\n return trailingEdge(time);\n }\n // Restart the timer.\n timerId = setTimeout(timerExpired, remainingWait(time));\n }\n\n function trailingEdge(time) {\n timerId = undefined;\n\n // Only invoke if we have `lastArgs` which means `func` has been\n // debounced at least once.\n if (trailing && lastArgs) {\n return invokeFunc(time);\n }\n lastArgs = lastThis = undefined;\n return result;\n }\n\n function cancel() {\n if (timerId !== undefined) {\n clearTimeout(timerId);\n }\n lastInvokeTime = 0;\n lastArgs = lastCallTime = lastThis = timerId = undefined;\n }\n\n function flush() {\n return timerId === undefined ? result : trailingEdge(now());\n }\n\n function debounced() {\n var time = now(),\n isInvoking = shouldInvoke(time);\n\n lastArgs = arguments;\n lastThis = this;\n lastCallTime = time;\n\n if (isInvoking) {\n if (timerId === undefined) {\n return leadingEdge(lastCallTime);\n }\n if (maxing) {\n // Handle invocations in a tight loop.\n clearTimeout(timerId);\n timerId = setTimeout(timerExpired, wait);\n return invokeFunc(lastCallTime);\n }\n }\n if (timerId === undefined) {\n timerId = setTimeout(timerExpired, wait);\n }\n return result;\n }\n debounced.cancel = cancel;\n debounced.flush = flush;\n return debounced;\n }\n\n /**\n * Defers invoking the `func` until the current call stack has cleared. Any\n * additional arguments are provided to `func` when it's invoked.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to defer.\n * @param {...*} [args] The arguments to invoke `func` with.\n * @returns {number} Returns the timer id.\n * @example\n *\n * _.defer(function(text) {\n * console.log(text);\n * }, 'deferred');\n * // => Logs 'deferred' after one millisecond.\n */\n var defer = baseRest(function(func, args) {\n return baseDelay(func, 1, args);\n });\n\n /**\n * Invokes `func` after `wait` milliseconds. Any additional arguments are\n * provided to `func` when it's invoked.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to delay.\n * @param {number} wait The number of milliseconds to delay invocation.\n * @param {...*} [args] The arguments to invoke `func` with.\n * @returns {number} Returns the timer id.\n * @example\n *\n * _.delay(function(text) {\n * console.log(text);\n * }, 1000, 'later');\n * // => Logs 'later' after one second.\n */\n var delay = baseRest(function(func, wait, args) {\n return baseDelay(func, toNumber(wait) || 0, args);\n });\n\n /**\n * Creates a function that invokes `func` with arguments reversed.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Function\n * @param {Function} func The function to flip arguments for.\n * @returns {Function} Returns the new flipped function.\n * @example\n *\n * var flipped = _.flip(function() {\n * return _.toArray(arguments);\n * });\n *\n * flipped('a', 'b', 'c', 'd');\n * // => ['d', 'c', 'b', 'a']\n */\n function flip(func) {\n return createWrap(func, WRAP_FLIP_FLAG);\n }\n\n /**\n * Creates a function that memoizes the result of `func`. If `resolver` is\n * provided, it determines the cache key for storing the result based on the\n * arguments provided to the memoized function. By default, the first argument\n * provided to the memoized function is used as the map cache key. The `func`\n * is invoked with the `this` binding of the memoized function.\n *\n * **Note:** The cache is exposed as the `cache` property on the memoized\n * function. Its creation may be customized by replacing the `_.memoize.Cache`\n * constructor with one whose instances implement the\n * [`Map`](http://ecma-international.org/ecma-262/7.0/#sec-properties-of-the-map-prototype-object)\n * method interface of `clear`, `delete`, `get`, `has`, and `set`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to have its output memoized.\n * @param {Function} [resolver] The function to resolve the cache key.\n * @returns {Function} Returns the new memoized function.\n * @example\n *\n * var object = { 'a': 1, 'b': 2 };\n * var other = { 'c': 3, 'd': 4 };\n *\n * var values = _.memoize(_.values);\n * values(object);\n * // => [1, 2]\n *\n * values(other);\n * // => [3, 4]\n *\n * object.a = 2;\n * values(object);\n * // => [1, 2]\n *\n * // Modify the result cache.\n * values.cache.set(object, ['a', 'b']);\n * values(object);\n * // => ['a', 'b']\n *\n * // Replace `_.memoize.Cache`.\n * _.memoize.Cache = WeakMap;\n */\n function memoize(func, resolver) {\n if (typeof func != 'function' || (resolver != null && typeof resolver != 'function')) {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n var memoized = function() {\n var args = arguments,\n key = resolver ? resolver.apply(this, args) : args[0],\n cache = memoized.cache;\n\n if (cache.has(key)) {\n return cache.get(key);\n }\n var result = func.apply(this, args);\n memoized.cache = cache.set(key, result) || cache;\n return result;\n };\n memoized.cache = new (memoize.Cache || MapCache);\n return memoized;\n }\n\n // Expose `MapCache`.\n memoize.Cache = MapCache;\n\n /**\n * Creates a function that negates the result of the predicate `func`. The\n * `func` predicate is invoked with the `this` binding and arguments of the\n * created function.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Function\n * @param {Function} predicate The predicate to negate.\n * @returns {Function} Returns the new negated function.\n * @example\n *\n * function isEven(n) {\n * return n % 2 == 0;\n * }\n *\n * _.filter([1, 2, 3, 4, 5, 6], _.negate(isEven));\n * // => [1, 3, 5]\n */\n function negate(predicate) {\n if (typeof predicate != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n return function() {\n var args = arguments;\n switch (args.length) {\n case 0: return !predicate.call(this);\n case 1: return !predicate.call(this, args[0]);\n case 2: return !predicate.call(this, args[0], args[1]);\n case 3: return !predicate.call(this, args[0], args[1], args[2]);\n }\n return !predicate.apply(this, args);\n };\n }\n\n /**\n * Creates a function that is restricted to invoking `func` once. Repeat calls\n * to the function return the value of the first invocation. The `func` is\n * invoked with the `this` binding and arguments of the created function.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to restrict.\n * @returns {Function} Returns the new restricted function.\n * @example\n *\n * var initialize = _.once(createApplication);\n * initialize();\n * initialize();\n * // => `createApplication` is invoked once\n */\n function once(func) {\n return before(2, func);\n }\n\n /**\n * Creates a function that invokes `func` with its arguments transformed.\n *\n * @static\n * @since 4.0.0\n * @memberOf _\n * @category Function\n * @param {Function} func The function to wrap.\n * @param {...(Function|Function[])} [transforms=[_.identity]]\n * The argument transforms.\n * @returns {Function} Returns the new function.\n * @example\n *\n * function doubled(n) {\n * return n * 2;\n * }\n *\n * function square(n) {\n * return n * n;\n * }\n *\n * var func = _.overArgs(function(x, y) {\n * return [x, y];\n * }, [square, doubled]);\n *\n * func(9, 3);\n * // => [81, 6]\n *\n * func(10, 5);\n * // => [100, 10]\n */\n var overArgs = castRest(function(func, transforms) {\n transforms = (transforms.length == 1 && isArray(transforms[0]))\n ? arrayMap(transforms[0], baseUnary(getIteratee()))\n : arrayMap(baseFlatten(transforms, 1), baseUnary(getIteratee()));\n\n var funcsLength = transforms.length;\n return baseRest(function(args) {\n var index = -1,\n length = nativeMin(args.length, funcsLength);\n\n while (++index < length) {\n args[index] = transforms[index].call(this, args[index]);\n }\n return apply(func, this, args);\n });\n });\n\n /**\n * Creates a function that invokes `func` with `partials` prepended to the\n * arguments it receives. This method is like `_.bind` except it does **not**\n * alter the `this` binding.\n *\n * The `_.partial.placeholder` value, which defaults to `_` in monolithic\n * builds, may be used as a placeholder for partially applied arguments.\n *\n * **Note:** This method doesn't set the \"length\" property of partially\n * applied functions.\n *\n * @static\n * @memberOf _\n * @since 0.2.0\n * @category Function\n * @param {Function} func The function to partially apply arguments to.\n * @param {...*} [partials] The arguments to be partially applied.\n * @returns {Function} Returns the new partially applied function.\n * @example\n *\n * function greet(greeting, name) {\n * return greeting + ' ' + name;\n * }\n *\n * var sayHelloTo = _.partial(greet, 'hello');\n * sayHelloTo('fred');\n * // => 'hello fred'\n *\n * // Partially applied with placeholders.\n * var greetFred = _.partial(greet, _, 'fred');\n * greetFred('hi');\n * // => 'hi fred'\n */\n var partial = baseRest(function(func, partials) {\n var holders = replaceHolders(partials, getHolder(partial));\n return createWrap(func, WRAP_PARTIAL_FLAG, undefined, partials, holders);\n });\n\n /**\n * This method is like `_.partial` except that partially applied arguments\n * are appended to the arguments it receives.\n *\n * The `_.partialRight.placeholder` value, which defaults to `_` in monolithic\n * builds, may be used as a placeholder for partially applied arguments.\n *\n * **Note:** This method doesn't set the \"length\" property of partially\n * applied functions.\n *\n * @static\n * @memberOf _\n * @since 1.0.0\n * @category Function\n * @param {Function} func The function to partially apply arguments to.\n * @param {...*} [partials] The arguments to be partially applied.\n * @returns {Function} Returns the new partially applied function.\n * @example\n *\n * function greet(greeting, name) {\n * return greeting + ' ' + name;\n * }\n *\n * var greetFred = _.partialRight(greet, 'fred');\n * greetFred('hi');\n * // => 'hi fred'\n *\n * // Partially applied with placeholders.\n * var sayHelloTo = _.partialRight(greet, 'hello', _);\n * sayHelloTo('fred');\n * // => 'hello fred'\n */\n var partialRight = baseRest(function(func, partials) {\n var holders = replaceHolders(partials, getHolder(partialRight));\n return createWrap(func, WRAP_PARTIAL_RIGHT_FLAG, undefined, partials, holders);\n });\n\n /**\n * Creates a function that invokes `func` with arguments arranged according\n * to the specified `indexes` where the argument value at the first index is\n * provided as the first argument, the argument value at the second index is\n * provided as the second argument, and so on.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Function\n * @param {Function} func The function to rearrange arguments for.\n * @param {...(number|number[])} indexes The arranged argument indexes.\n * @returns {Function} Returns the new function.\n * @example\n *\n * var rearged = _.rearg(function(a, b, c) {\n * return [a, b, c];\n * }, [2, 0, 1]);\n *\n * rearged('b', 'c', 'a')\n * // => ['a', 'b', 'c']\n */\n var rearg = flatRest(function(func, indexes) {\n return createWrap(func, WRAP_REARG_FLAG, undefined, undefined, undefined, indexes);\n });\n\n /**\n * Creates a function that invokes `func` with the `this` binding of the\n * created function and arguments from `start` and beyond provided as\n * an array.\n *\n * **Note:** This method is based on the\n * [rest parameter](https://mdn.io/rest_parameters).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Function\n * @param {Function} func The function to apply a rest parameter to.\n * @param {number} [start=func.length-1] The start position of the rest parameter.\n * @returns {Function} Returns the new function.\n * @example\n *\n * var say = _.rest(function(what, names) {\n * return what + ' ' + _.initial(names).join(', ') +\n * (_.size(names) > 1 ? ', & ' : '') + _.last(names);\n * });\n *\n * say('hello', 'fred', 'barney', 'pebbles');\n * // => 'hello fred, barney, & pebbles'\n */\n function rest(func, start) {\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n start = start === undefined ? start : toInteger(start);\n return baseRest(func, start);\n }\n\n /**\n * Creates a function that invokes `func` with the `this` binding of the\n * create function and an array of arguments much like\n * [`Function#apply`](http://www.ecma-international.org/ecma-262/7.0/#sec-function.prototype.apply).\n *\n * **Note:** This method is based on the\n * [spread operator](https://mdn.io/spread_operator).\n *\n * @static\n * @memberOf _\n * @since 3.2.0\n * @category Function\n * @param {Function} func The function to spread arguments over.\n * @param {number} [start=0] The start position of the spread.\n * @returns {Function} Returns the new function.\n * @example\n *\n * var say = _.spread(function(who, what) {\n * return who + ' says ' + what;\n * });\n *\n * say(['fred', 'hello']);\n * // => 'fred says hello'\n *\n * var numbers = Promise.all([\n * Promise.resolve(40),\n * Promise.resolve(36)\n * ]);\n *\n * numbers.then(_.spread(function(x, y) {\n * return x + y;\n * }));\n * // => a Promise of 76\n */\n function spread(func, start) {\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n start = start == null ? 0 : nativeMax(toInteger(start), 0);\n return baseRest(function(args) {\n var array = args[start],\n otherArgs = castSlice(args, 0, start);\n\n if (array) {\n arrayPush(otherArgs, array);\n }\n return apply(func, this, otherArgs);\n });\n }\n\n /**\n * Creates a throttled function that only invokes `func` at most once per\n * every `wait` milliseconds. The throttled function comes with a `cancel`\n * method to cancel delayed `func` invocations and a `flush` method to\n * immediately invoke them. Provide `options` to indicate whether `func`\n * should be invoked on the leading and/or trailing edge of the `wait`\n * timeout. The `func` is invoked with the last arguments provided to the\n * throttled function. Subsequent calls to the throttled function return the\n * result of the last `func` invocation.\n *\n * **Note:** If `leading` and `trailing` options are `true`, `func` is\n * invoked on the trailing edge of the timeout only if the throttled function\n * is invoked more than once during the `wait` timeout.\n *\n * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred\n * until to the next tick, similar to `setTimeout` with a timeout of `0`.\n *\n * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)\n * for details over the differences between `_.throttle` and `_.debounce`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to throttle.\n * @param {number} [wait=0] The number of milliseconds to throttle invocations to.\n * @param {Object} [options={}] The options object.\n * @param {boolean} [options.leading=true]\n * Specify invoking on the leading edge of the timeout.\n * @param {boolean} [options.trailing=true]\n * Specify invoking on the trailing edge of the timeout.\n * @returns {Function} Returns the new throttled function.\n * @example\n *\n * // Avoid excessively updating the position while scrolling.\n * jQuery(window).on('scroll', _.throttle(updatePosition, 100));\n *\n * // Invoke `renewToken` when the click event is fired, but not more than once every 5 minutes.\n * var throttled = _.throttle(renewToken, 300000, { 'trailing': false });\n * jQuery(element).on('click', throttled);\n *\n * // Cancel the trailing throttled invocation.\n * jQuery(window).on('popstate', throttled.cancel);\n */\n function throttle(func, wait, options) {\n var leading = true,\n trailing = true;\n\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n if (isObject(options)) {\n leading = 'leading' in options ? !!options.leading : leading;\n trailing = 'trailing' in options ? !!options.trailing : trailing;\n }\n return debounce(func, wait, {\n 'leading': leading,\n 'maxWait': wait,\n 'trailing': trailing\n });\n }\n\n /**\n * Creates a function that accepts up to one argument, ignoring any\n * additional arguments.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Function\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n * @example\n *\n * _.map(['6', '8', '10'], _.unary(parseInt));\n * // => [6, 8, 10]\n */\n function unary(func) {\n return ary(func, 1);\n }\n\n /**\n * Creates a function that provides `value` to `wrapper` as its first\n * argument. Any additional arguments provided to the function are appended\n * to those provided to the `wrapper`. The wrapper is invoked with the `this`\n * binding of the created function.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {*} value The value to wrap.\n * @param {Function} [wrapper=identity] The wrapper function.\n * @returns {Function} Returns the new function.\n * @example\n *\n * var p = _.wrap(_.escape, function(func, text) {\n * return '

' + func(text) + '

';\n * });\n *\n * p('fred, barney, & pebbles');\n * // => '

fred, barney, & pebbles

'\n */\n function wrap(value, wrapper) {\n return partial(castFunction(wrapper), value);\n }\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Casts `value` as an array if it's not one.\n *\n * @static\n * @memberOf _\n * @since 4.4.0\n * @category Lang\n * @param {*} value The value to inspect.\n * @returns {Array} Returns the cast array.\n * @example\n *\n * _.castArray(1);\n * // => [1]\n *\n * _.castArray({ 'a': 1 });\n * // => [{ 'a': 1 }]\n *\n * _.castArray('abc');\n * // => ['abc']\n *\n * _.castArray(null);\n * // => [null]\n *\n * _.castArray(undefined);\n * // => [undefined]\n *\n * _.castArray();\n * // => []\n *\n * var array = [1, 2, 3];\n * console.log(_.castArray(array) === array);\n * // => true\n */\n function castArray() {\n if (!arguments.length) {\n return [];\n }\n var value = arguments[0];\n return isArray(value) ? value : [value];\n }\n\n /**\n * Creates a shallow clone of `value`.\n *\n * **Note:** This method is loosely based on the\n * [structured clone algorithm](https://mdn.io/Structured_clone_algorithm)\n * and supports cloning arrays, array buffers, booleans, date objects, maps,\n * numbers, `Object` objects, regexes, sets, strings, symbols, and typed\n * arrays. The own enumerable properties of `arguments` objects are cloned\n * as plain objects. An empty object is returned for uncloneable values such\n * as error objects, functions, DOM nodes, and WeakMaps.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to clone.\n * @returns {*} Returns the cloned value.\n * @see _.cloneDeep\n * @example\n *\n * var objects = [{ 'a': 1 }, { 'b': 2 }];\n *\n * var shallow = _.clone(objects);\n * console.log(shallow[0] === objects[0]);\n * // => true\n */\n function clone(value) {\n return baseClone(value, CLONE_SYMBOLS_FLAG);\n }\n\n /**\n * This method is like `_.clone` except that it accepts `customizer` which\n * is invoked to produce the cloned value. If `customizer` returns `undefined`,\n * cloning is handled by the method instead. The `customizer` is invoked with\n * up to four arguments; (value [, index|key, object, stack]).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to clone.\n * @param {Function} [customizer] The function to customize cloning.\n * @returns {*} Returns the cloned value.\n * @see _.cloneDeepWith\n * @example\n *\n * function customizer(value) {\n * if (_.isElement(value)) {\n * return value.cloneNode(false);\n * }\n * }\n *\n * var el = _.cloneWith(document.body, customizer);\n *\n * console.log(el === document.body);\n * // => false\n * console.log(el.nodeName);\n * // => 'BODY'\n * console.log(el.childNodes.length);\n * // => 0\n */\n function cloneWith(value, customizer) {\n customizer = typeof customizer == 'function' ? customizer : undefined;\n return baseClone(value, CLONE_SYMBOLS_FLAG, customizer);\n }\n\n /**\n * This method is like `_.clone` except that it recursively clones `value`.\n *\n * @static\n * @memberOf _\n * @since 1.0.0\n * @category Lang\n * @param {*} value The value to recursively clone.\n * @returns {*} Returns the deep cloned value.\n * @see _.clone\n * @example\n *\n * var objects = [{ 'a': 1 }, { 'b': 2 }];\n *\n * var deep = _.cloneDeep(objects);\n * console.log(deep[0] === objects[0]);\n * // => false\n */\n function cloneDeep(value) {\n return baseClone(value, CLONE_DEEP_FLAG | CLONE_SYMBOLS_FLAG);\n }\n\n /**\n * This method is like `_.cloneWith` except that it recursively clones `value`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to recursively clone.\n * @param {Function} [customizer] The function to customize cloning.\n * @returns {*} Returns the deep cloned value.\n * @see _.cloneWith\n * @example\n *\n * function customizer(value) {\n * if (_.isElement(value)) {\n * return value.cloneNode(true);\n * }\n * }\n *\n * var el = _.cloneDeepWith(document.body, customizer);\n *\n * console.log(el === document.body);\n * // => false\n * console.log(el.nodeName);\n * // => 'BODY'\n * console.log(el.childNodes.length);\n * // => 20\n */\n function cloneDeepWith(value, customizer) {\n customizer = typeof customizer == 'function' ? customizer : undefined;\n return baseClone(value, CLONE_DEEP_FLAG | CLONE_SYMBOLS_FLAG, customizer);\n }\n\n /**\n * Checks if `object` conforms to `source` by invoking the predicate\n * properties of `source` with the corresponding property values of `object`.\n *\n * **Note:** This method is equivalent to `_.conforms` when `source` is\n * partially applied.\n *\n * @static\n * @memberOf _\n * @since 4.14.0\n * @category Lang\n * @param {Object} object The object to inspect.\n * @param {Object} source The object of property predicates to conform to.\n * @returns {boolean} Returns `true` if `object` conforms, else `false`.\n * @example\n *\n * var object = { 'a': 1, 'b': 2 };\n *\n * _.conformsTo(object, { 'b': function(n) { return n > 1; } });\n * // => true\n *\n * _.conformsTo(object, { 'b': function(n) { return n > 2; } });\n * // => false\n */\n function conformsTo(object, source) {\n return source == null || baseConformsTo(object, source, keys(source));\n }\n\n /**\n * Performs a\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * comparison between two values to determine if they are equivalent.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.eq(object, object);\n * // => true\n *\n * _.eq(object, other);\n * // => false\n *\n * _.eq('a', 'a');\n * // => true\n *\n * _.eq('a', Object('a'));\n * // => false\n *\n * _.eq(NaN, NaN);\n * // => true\n */\n function eq(value, other) {\n return value === other || (value !== value && other !== other);\n }\n\n /**\n * Checks if `value` is greater than `other`.\n *\n * @static\n * @memberOf _\n * @since 3.9.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is greater than `other`,\n * else `false`.\n * @see _.lt\n * @example\n *\n * _.gt(3, 1);\n * // => true\n *\n * _.gt(3, 3);\n * // => false\n *\n * _.gt(1, 3);\n * // => false\n */\n var gt = createRelationalOperation(baseGt);\n\n /**\n * Checks if `value` is greater than or equal to `other`.\n *\n * @static\n * @memberOf _\n * @since 3.9.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is greater than or equal to\n * `other`, else `false`.\n * @see _.lte\n * @example\n *\n * _.gte(3, 1);\n * // => true\n *\n * _.gte(3, 3);\n * // => true\n *\n * _.gte(1, 3);\n * // => false\n */\n var gte = createRelationalOperation(function(value, other) {\n return value >= other;\n });\n\n /**\n * Checks if `value` is likely an `arguments` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n * else `false`.\n * @example\n *\n * _.isArguments(function() { return arguments; }());\n * // => true\n *\n * _.isArguments([1, 2, 3]);\n * // => false\n */\n var isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) {\n return isObjectLike(value) && hasOwnProperty.call(value, 'callee') &&\n !propertyIsEnumerable.call(value, 'callee');\n };\n\n /**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(document.body.children);\n * // => false\n *\n * _.isArray('abc');\n * // => false\n *\n * _.isArray(_.noop);\n * // => false\n */\n var isArray = Array.isArray;\n\n /**\n * Checks if `value` is classified as an `ArrayBuffer` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array buffer, else `false`.\n * @example\n *\n * _.isArrayBuffer(new ArrayBuffer(2));\n * // => true\n *\n * _.isArrayBuffer(new Array(2));\n * // => false\n */\n var isArrayBuffer = nodeIsArrayBuffer ? baseUnary(nodeIsArrayBuffer) : baseIsArrayBuffer;\n\n /**\n * Checks if `value` is array-like. A value is considered array-like if it's\n * not a function and has a `value.length` that's an integer greater than or\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n * @example\n *\n * _.isArrayLike([1, 2, 3]);\n * // => true\n *\n * _.isArrayLike(document.body.children);\n * // => true\n *\n * _.isArrayLike('abc');\n * // => true\n *\n * _.isArrayLike(_.noop);\n * // => false\n */\n function isArrayLike(value) {\n return value != null && isLength(value.length) && !isFunction(value);\n }\n\n /**\n * This method is like `_.isArrayLike` except that it also checks if `value`\n * is an object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array-like object,\n * else `false`.\n * @example\n *\n * _.isArrayLikeObject([1, 2, 3]);\n * // => true\n *\n * _.isArrayLikeObject(document.body.children);\n * // => true\n *\n * _.isArrayLikeObject('abc');\n * // => false\n *\n * _.isArrayLikeObject(_.noop);\n * // => false\n */\n function isArrayLikeObject(value) {\n return isObjectLike(value) && isArrayLike(value);\n }\n\n /**\n * Checks if `value` is classified as a boolean primitive or object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a boolean, else `false`.\n * @example\n *\n * _.isBoolean(false);\n * // => true\n *\n * _.isBoolean(null);\n * // => false\n */\n function isBoolean(value) {\n return value === true || value === false ||\n (isObjectLike(value) && baseGetTag(value) == boolTag);\n }\n\n /**\n * Checks if `value` is a buffer.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.\n * @example\n *\n * _.isBuffer(new Buffer(2));\n * // => true\n *\n * _.isBuffer(new Uint8Array(2));\n * // => false\n */\n var isBuffer = nativeIsBuffer || stubFalse;\n\n /**\n * Checks if `value` is classified as a `Date` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a date object, else `false`.\n * @example\n *\n * _.isDate(new Date);\n * // => true\n *\n * _.isDate('Mon April 23 2012');\n * // => false\n */\n var isDate = nodeIsDate ? baseUnary(nodeIsDate) : baseIsDate;\n\n /**\n * Checks if `value` is likely a DOM element.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a DOM element, else `false`.\n * @example\n *\n * _.isElement(document.body);\n * // => true\n *\n * _.isElement('');\n * // => false\n */\n function isElement(value) {\n return isObjectLike(value) && value.nodeType === 1 && !isPlainObject(value);\n }\n\n /**\n * Checks if `value` is an empty object, collection, map, or set.\n *\n * Objects are considered empty if they have no own enumerable string keyed\n * properties.\n *\n * Array-like values such as `arguments` objects, arrays, buffers, strings, or\n * jQuery-like collections are considered empty if they have a `length` of `0`.\n * Similarly, maps and sets are considered empty if they have a `size` of `0`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is empty, else `false`.\n * @example\n *\n * _.isEmpty(null);\n * // => true\n *\n * _.isEmpty(true);\n * // => true\n *\n * _.isEmpty(1);\n * // => true\n *\n * _.isEmpty([1, 2, 3]);\n * // => false\n *\n * _.isEmpty({ 'a': 1 });\n * // => false\n */\n function isEmpty(value) {\n if (value == null) {\n return true;\n }\n if (isArrayLike(value) &&\n (isArray(value) || typeof value == 'string' || typeof value.splice == 'function' ||\n isBuffer(value) || isTypedArray(value) || isArguments(value))) {\n return !value.length;\n }\n var tag = getTag(value);\n if (tag == mapTag || tag == setTag) {\n return !value.size;\n }\n if (isPrototype(value)) {\n return !baseKeys(value).length;\n }\n for (var key in value) {\n if (hasOwnProperty.call(value, key)) {\n return false;\n }\n }\n return true;\n }\n\n /**\n * Performs a deep comparison between two values to determine if they are\n * equivalent.\n *\n * **Note:** This method supports comparing arrays, array buffers, booleans,\n * date objects, error objects, maps, numbers, `Object` objects, regexes,\n * sets, strings, symbols, and typed arrays. `Object` objects are compared\n * by their own, not inherited, enumerable properties. Functions and DOM\n * nodes are compared by strict equality, i.e. `===`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.isEqual(object, other);\n * // => true\n *\n * object === other;\n * // => false\n */\n function isEqual(value, other) {\n return baseIsEqual(value, other);\n }\n\n /**\n * This method is like `_.isEqual` except that it accepts `customizer` which\n * is invoked to compare values. If `customizer` returns `undefined`, comparisons\n * are handled by the method instead. The `customizer` is invoked with up to\n * six arguments: (objValue, othValue [, index|key, object, other, stack]).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @param {Function} [customizer] The function to customize comparisons.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * function isGreeting(value) {\n * return /^h(?:i|ello)$/.test(value);\n * }\n *\n * function customizer(objValue, othValue) {\n * if (isGreeting(objValue) && isGreeting(othValue)) {\n * return true;\n * }\n * }\n *\n * var array = ['hello', 'goodbye'];\n * var other = ['hi', 'goodbye'];\n *\n * _.isEqualWith(array, other, customizer);\n * // => true\n */\n function isEqualWith(value, other, customizer) {\n customizer = typeof customizer == 'function' ? customizer : undefined;\n var result = customizer ? customizer(value, other) : undefined;\n return result === undefined ? baseIsEqual(value, other, undefined, customizer) : !!result;\n }\n\n /**\n * Checks if `value` is an `Error`, `EvalError`, `RangeError`, `ReferenceError`,\n * `SyntaxError`, `TypeError`, or `URIError` object.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an error object, else `false`.\n * @example\n *\n * _.isError(new Error);\n * // => true\n *\n * _.isError(Error);\n * // => false\n */\n function isError(value) {\n if (!isObjectLike(value)) {\n return false;\n }\n var tag = baseGetTag(value);\n return tag == errorTag || tag == domExcTag ||\n (typeof value.message == 'string' && typeof value.name == 'string' && !isPlainObject(value));\n }\n\n /**\n * Checks if `value` is a finite primitive number.\n *\n * **Note:** This method is based on\n * [`Number.isFinite`](https://mdn.io/Number/isFinite).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a finite number, else `false`.\n * @example\n *\n * _.isFinite(3);\n * // => true\n *\n * _.isFinite(Number.MIN_VALUE);\n * // => true\n *\n * _.isFinite(Infinity);\n * // => false\n *\n * _.isFinite('3');\n * // => false\n */\n function isFinite(value) {\n return typeof value == 'number' && nativeIsFinite(value);\n }\n\n /**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\n function isFunction(value) {\n if (!isObject(value)) {\n return false;\n }\n // The use of `Object#toString` avoids issues with the `typeof` operator\n // in Safari 9 which returns 'object' for typed arrays and other constructors.\n var tag = baseGetTag(value);\n return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;\n }\n\n /**\n * Checks if `value` is an integer.\n *\n * **Note:** This method is based on\n * [`Number.isInteger`](https://mdn.io/Number/isInteger).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an integer, else `false`.\n * @example\n *\n * _.isInteger(3);\n * // => true\n *\n * _.isInteger(Number.MIN_VALUE);\n * // => false\n *\n * _.isInteger(Infinity);\n * // => false\n *\n * _.isInteger('3');\n * // => false\n */\n function isInteger(value) {\n return typeof value == 'number' && value == toInteger(value);\n }\n\n /**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This method is loosely based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n * @example\n *\n * _.isLength(3);\n * // => true\n *\n * _.isLength(Number.MIN_VALUE);\n * // => false\n *\n * _.isLength(Infinity);\n * // => false\n *\n * _.isLength('3');\n * // => false\n */\n function isLength(value) {\n return typeof value == 'number' &&\n value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n }\n\n /**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\n function isObject(value) {\n var type = typeof value;\n return value != null && (type == 'object' || type == 'function');\n }\n\n /**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\n function isObjectLike(value) {\n return value != null && typeof value == 'object';\n }\n\n /**\n * Checks if `value` is classified as a `Map` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a map, else `false`.\n * @example\n *\n * _.isMap(new Map);\n * // => true\n *\n * _.isMap(new WeakMap);\n * // => false\n */\n var isMap = nodeIsMap ? baseUnary(nodeIsMap) : baseIsMap;\n\n /**\n * Performs a partial deep comparison between `object` and `source` to\n * determine if `object` contains equivalent property values.\n *\n * **Note:** This method is equivalent to `_.matches` when `source` is\n * partially applied.\n *\n * Partial comparisons will match empty array and empty object `source`\n * values against any array or object value, respectively. See `_.isEqual`\n * for a list of supported value comparisons.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {Object} object The object to inspect.\n * @param {Object} source The object of property values to match.\n * @returns {boolean} Returns `true` if `object` is a match, else `false`.\n * @example\n *\n * var object = { 'a': 1, 'b': 2 };\n *\n * _.isMatch(object, { 'b': 2 });\n * // => true\n *\n * _.isMatch(object, { 'b': 1 });\n * // => false\n */\n function isMatch(object, source) {\n return object === source || baseIsMatch(object, source, getMatchData(source));\n }\n\n /**\n * This method is like `_.isMatch` except that it accepts `customizer` which\n * is invoked to compare values. If `customizer` returns `undefined`, comparisons\n * are handled by the method instead. The `customizer` is invoked with five\n * arguments: (objValue, srcValue, index|key, object, source).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {Object} object The object to inspect.\n * @param {Object} source The object of property values to match.\n * @param {Function} [customizer] The function to customize comparisons.\n * @returns {boolean} Returns `true` if `object` is a match, else `false`.\n * @example\n *\n * function isGreeting(value) {\n * return /^h(?:i|ello)$/.test(value);\n * }\n *\n * function customizer(objValue, srcValue) {\n * if (isGreeting(objValue) && isGreeting(srcValue)) {\n * return true;\n * }\n * }\n *\n * var object = { 'greeting': 'hello' };\n * var source = { 'greeting': 'hi' };\n *\n * _.isMatchWith(object, source, customizer);\n * // => true\n */\n function isMatchWith(object, source, customizer) {\n customizer = typeof customizer == 'function' ? customizer : undefined;\n return baseIsMatch(object, source, getMatchData(source), customizer);\n }\n\n /**\n * Checks if `value` is `NaN`.\n *\n * **Note:** This method is based on\n * [`Number.isNaN`](https://mdn.io/Number/isNaN) and is not the same as\n * global [`isNaN`](https://mdn.io/isNaN) which returns `true` for\n * `undefined` and other non-number values.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is `NaN`, else `false`.\n * @example\n *\n * _.isNaN(NaN);\n * // => true\n *\n * _.isNaN(new Number(NaN));\n * // => true\n *\n * isNaN(undefined);\n * // => true\n *\n * _.isNaN(undefined);\n * // => false\n */\n function isNaN(value) {\n // An `NaN` primitive is the only value that is not equal to itself.\n // Perform the `toStringTag` check first to avoid errors with some\n // ActiveX objects in IE.\n return isNumber(value) && value != +value;\n }\n\n /**\n * Checks if `value` is a pristine native function.\n *\n * **Note:** This method can't reliably detect native functions in the presence\n * of the core-js package because core-js circumvents this kind of detection.\n * Despite multiple requests, the core-js maintainer has made it clear: any\n * attempt to fix the detection will be obstructed. As a result, we're left\n * with little choice but to throw an error. Unfortunately, this also affects\n * packages, like [babel-polyfill](https://www.npmjs.com/package/babel-polyfill),\n * which rely on core-js.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function,\n * else `false`.\n * @example\n *\n * _.isNative(Array.prototype.push);\n * // => true\n *\n * _.isNative(_);\n * // => false\n */\n function isNative(value) {\n if (isMaskable(value)) {\n throw new Error(CORE_ERROR_TEXT);\n }\n return baseIsNative(value);\n }\n\n /**\n * Checks if `value` is `null`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is `null`, else `false`.\n * @example\n *\n * _.isNull(null);\n * // => true\n *\n * _.isNull(void 0);\n * // => false\n */\n function isNull(value) {\n return value === null;\n }\n\n /**\n * Checks if `value` is `null` or `undefined`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is nullish, else `false`.\n * @example\n *\n * _.isNil(null);\n * // => true\n *\n * _.isNil(void 0);\n * // => true\n *\n * _.isNil(NaN);\n * // => false\n */\n function isNil(value) {\n return value == null;\n }\n\n /**\n * Checks if `value` is classified as a `Number` primitive or object.\n *\n * **Note:** To exclude `Infinity`, `-Infinity`, and `NaN`, which are\n * classified as numbers, use the `_.isFinite` method.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a number, else `false`.\n * @example\n *\n * _.isNumber(3);\n * // => true\n *\n * _.isNumber(Number.MIN_VALUE);\n * // => true\n *\n * _.isNumber(Infinity);\n * // => true\n *\n * _.isNumber('3');\n * // => false\n */\n function isNumber(value) {\n return typeof value == 'number' ||\n (isObjectLike(value) && baseGetTag(value) == numberTag);\n }\n\n /**\n * Checks if `value` is a plain object, that is, an object created by the\n * `Object` constructor or one with a `[[Prototype]]` of `null`.\n *\n * @static\n * @memberOf _\n * @since 0.8.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a plain object, else `false`.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * }\n *\n * _.isPlainObject(new Foo);\n * // => false\n *\n * _.isPlainObject([1, 2, 3]);\n * // => false\n *\n * _.isPlainObject({ 'x': 0, 'y': 0 });\n * // => true\n *\n * _.isPlainObject(Object.create(null));\n * // => true\n */\n function isPlainObject(value) {\n if (!isObjectLike(value) || baseGetTag(value) != objectTag) {\n return false;\n }\n var proto = getPrototype(value);\n if (proto === null) {\n return true;\n }\n var Ctor = hasOwnProperty.call(proto, 'constructor') && proto.constructor;\n return typeof Ctor == 'function' && Ctor instanceof Ctor &&\n funcToString.call(Ctor) == objectCtorString;\n }\n\n /**\n * Checks if `value` is classified as a `RegExp` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a regexp, else `false`.\n * @example\n *\n * _.isRegExp(/abc/);\n * // => true\n *\n * _.isRegExp('/abc/');\n * // => false\n */\n var isRegExp = nodeIsRegExp ? baseUnary(nodeIsRegExp) : baseIsRegExp;\n\n /**\n * Checks if `value` is a safe integer. An integer is safe if it's an IEEE-754\n * double precision number which isn't the result of a rounded unsafe integer.\n *\n * **Note:** This method is based on\n * [`Number.isSafeInteger`](https://mdn.io/Number/isSafeInteger).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a safe integer, else `false`.\n * @example\n *\n * _.isSafeInteger(3);\n * // => true\n *\n * _.isSafeInteger(Number.MIN_VALUE);\n * // => false\n *\n * _.isSafeInteger(Infinity);\n * // => false\n *\n * _.isSafeInteger('3');\n * // => false\n */\n function isSafeInteger(value) {\n return isInteger(value) && value >= -MAX_SAFE_INTEGER && value <= MAX_SAFE_INTEGER;\n }\n\n /**\n * Checks if `value` is classified as a `Set` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a set, else `false`.\n * @example\n *\n * _.isSet(new Set);\n * // => true\n *\n * _.isSet(new WeakSet);\n * // => false\n */\n var isSet = nodeIsSet ? baseUnary(nodeIsSet) : baseIsSet;\n\n /**\n * Checks if `value` is classified as a `String` primitive or object.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a string, else `false`.\n * @example\n *\n * _.isString('abc');\n * // => true\n *\n * _.isString(1);\n * // => false\n */\n function isString(value) {\n return typeof value == 'string' ||\n (!isArray(value) && isObjectLike(value) && baseGetTag(value) == stringTag);\n }\n\n /**\n * Checks if `value` is classified as a `Symbol` primitive or object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.\n * @example\n *\n * _.isSymbol(Symbol.iterator);\n * // => true\n *\n * _.isSymbol('abc');\n * // => false\n */\n function isSymbol(value) {\n return typeof value == 'symbol' ||\n (isObjectLike(value) && baseGetTag(value) == symbolTag);\n }\n\n /**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\n var isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;\n\n /**\n * Checks if `value` is `undefined`.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is `undefined`, else `false`.\n * @example\n *\n * _.isUndefined(void 0);\n * // => true\n *\n * _.isUndefined(null);\n * // => false\n */\n function isUndefined(value) {\n return value === undefined;\n }\n\n /**\n * Checks if `value` is classified as a `WeakMap` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a weak map, else `false`.\n * @example\n *\n * _.isWeakMap(new WeakMap);\n * // => true\n *\n * _.isWeakMap(new Map);\n * // => false\n */\n function isWeakMap(value) {\n return isObjectLike(value) && getTag(value) == weakMapTag;\n }\n\n /**\n * Checks if `value` is classified as a `WeakSet` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a weak set, else `false`.\n * @example\n *\n * _.isWeakSet(new WeakSet);\n * // => true\n *\n * _.isWeakSet(new Set);\n * // => false\n */\n function isWeakSet(value) {\n return isObjectLike(value) && baseGetTag(value) == weakSetTag;\n }\n\n /**\n * Checks if `value` is less than `other`.\n *\n * @static\n * @memberOf _\n * @since 3.9.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is less than `other`,\n * else `false`.\n * @see _.gt\n * @example\n *\n * _.lt(1, 3);\n * // => true\n *\n * _.lt(3, 3);\n * // => false\n *\n * _.lt(3, 1);\n * // => false\n */\n var lt = createRelationalOperation(baseLt);\n\n /**\n * Checks if `value` is less than or equal to `other`.\n *\n * @static\n * @memberOf _\n * @since 3.9.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is less than or equal to\n * `other`, else `false`.\n * @see _.gte\n * @example\n *\n * _.lte(1, 3);\n * // => true\n *\n * _.lte(3, 3);\n * // => true\n *\n * _.lte(3, 1);\n * // => false\n */\n var lte = createRelationalOperation(function(value, other) {\n return value <= other;\n });\n\n /**\n * Converts `value` to an array.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {Array} Returns the converted array.\n * @example\n *\n * _.toArray({ 'a': 1, 'b': 2 });\n * // => [1, 2]\n *\n * _.toArray('abc');\n * // => ['a', 'b', 'c']\n *\n * _.toArray(1);\n * // => []\n *\n * _.toArray(null);\n * // => []\n */\n function toArray(value) {\n if (!value) {\n return [];\n }\n if (isArrayLike(value)) {\n return isString(value) ? stringToArray(value) : copyArray(value);\n }\n if (symIterator && value[symIterator]) {\n return iteratorToArray(value[symIterator]());\n }\n var tag = getTag(value),\n func = tag == mapTag ? mapToArray : (tag == setTag ? setToArray : values);\n\n return func(value);\n }\n\n /**\n * Converts `value` to a finite number.\n *\n * @static\n * @memberOf _\n * @since 4.12.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted number.\n * @example\n *\n * _.toFinite(3.2);\n * // => 3.2\n *\n * _.toFinite(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toFinite(Infinity);\n * // => 1.7976931348623157e+308\n *\n * _.toFinite('3.2');\n * // => 3.2\n */\n function toFinite(value) {\n if (!value) {\n return value === 0 ? value : 0;\n }\n value = toNumber(value);\n if (value === INFINITY || value === -INFINITY) {\n var sign = (value < 0 ? -1 : 1);\n return sign * MAX_INTEGER;\n }\n return value === value ? value : 0;\n }\n\n /**\n * Converts `value` to an integer.\n *\n * **Note:** This method is loosely based on\n * [`ToInteger`](http://www.ecma-international.org/ecma-262/7.0/#sec-tointeger).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted integer.\n * @example\n *\n * _.toInteger(3.2);\n * // => 3\n *\n * _.toInteger(Number.MIN_VALUE);\n * // => 0\n *\n * _.toInteger(Infinity);\n * // => 1.7976931348623157e+308\n *\n * _.toInteger('3.2');\n * // => 3\n */\n function toInteger(value) {\n var result = toFinite(value),\n remainder = result % 1;\n\n return result === result ? (remainder ? result - remainder : result) : 0;\n }\n\n /**\n * Converts `value` to an integer suitable for use as the length of an\n * array-like object.\n *\n * **Note:** This method is based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted integer.\n * @example\n *\n * _.toLength(3.2);\n * // => 3\n *\n * _.toLength(Number.MIN_VALUE);\n * // => 0\n *\n * _.toLength(Infinity);\n * // => 4294967295\n *\n * _.toLength('3.2');\n * // => 3\n */\n function toLength(value) {\n return value ? baseClamp(toInteger(value), 0, MAX_ARRAY_LENGTH) : 0;\n }\n\n /**\n * Converts `value` to a number.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to process.\n * @returns {number} Returns the number.\n * @example\n *\n * _.toNumber(3.2);\n * // => 3.2\n *\n * _.toNumber(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toNumber(Infinity);\n * // => Infinity\n *\n * _.toNumber('3.2');\n * // => 3.2\n */\n function toNumber(value) {\n if (typeof value == 'number') {\n return value;\n }\n if (isSymbol(value)) {\n return NAN;\n }\n if (isObject(value)) {\n var other = typeof value.valueOf == 'function' ? value.valueOf() : value;\n value = isObject(other) ? (other + '') : other;\n }\n if (typeof value != 'string') {\n return value === 0 ? value : +value;\n }\n value = baseTrim(value);\n var isBinary = reIsBinary.test(value);\n return (isBinary || reIsOctal.test(value))\n ? freeParseInt(value.slice(2), isBinary ? 2 : 8)\n : (reIsBadHex.test(value) ? NAN : +value);\n }\n\n /**\n * Converts `value` to a plain object flattening inherited enumerable string\n * keyed properties of `value` to own properties of the plain object.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {Object} Returns the converted plain object.\n * @example\n *\n * function Foo() {\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.assign({ 'a': 1 }, new Foo);\n * // => { 'a': 1, 'b': 2 }\n *\n * _.assign({ 'a': 1 }, _.toPlainObject(new Foo));\n * // => { 'a': 1, 'b': 2, 'c': 3 }\n */\n function toPlainObject(value) {\n return copyObject(value, keysIn(value));\n }\n\n /**\n * Converts `value` to a safe integer. A safe integer can be compared and\n * represented correctly.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted integer.\n * @example\n *\n * _.toSafeInteger(3.2);\n * // => 3\n *\n * _.toSafeInteger(Number.MIN_VALUE);\n * // => 0\n *\n * _.toSafeInteger(Infinity);\n * // => 9007199254740991\n *\n * _.toSafeInteger('3.2');\n * // => 3\n */\n function toSafeInteger(value) {\n return value\n ? baseClamp(toInteger(value), -MAX_SAFE_INTEGER, MAX_SAFE_INTEGER)\n : (value === 0 ? value : 0);\n }\n\n /**\n * Converts `value` to a string. An empty string is returned for `null`\n * and `undefined` values. The sign of `-0` is preserved.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n * @example\n *\n * _.toString(null);\n * // => ''\n *\n * _.toString(-0);\n * // => '-0'\n *\n * _.toString([1, 2, 3]);\n * // => '1,2,3'\n */\n function toString(value) {\n return value == null ? '' : baseToString(value);\n }\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Assigns own enumerable string keyed properties of source objects to the\n * destination object. Source objects are applied from left to right.\n * Subsequent sources overwrite property assignments of previous sources.\n *\n * **Note:** This method mutates `object` and is loosely based on\n * [`Object.assign`](https://mdn.io/Object/assign).\n *\n * @static\n * @memberOf _\n * @since 0.10.0\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @see _.assignIn\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * }\n *\n * function Bar() {\n * this.c = 3;\n * }\n *\n * Foo.prototype.b = 2;\n * Bar.prototype.d = 4;\n *\n * _.assign({ 'a': 0 }, new Foo, new Bar);\n * // => { 'a': 1, 'c': 3 }\n */\n var assign = createAssigner(function(object, source) {\n if (isPrototype(source) || isArrayLike(source)) {\n copyObject(source, keys(source), object);\n return;\n }\n for (var key in source) {\n if (hasOwnProperty.call(source, key)) {\n assignValue(object, key, source[key]);\n }\n }\n });\n\n /**\n * This method is like `_.assign` except that it iterates over own and\n * inherited source properties.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @alias extend\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @see _.assign\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * }\n *\n * function Bar() {\n * this.c = 3;\n * }\n *\n * Foo.prototype.b = 2;\n * Bar.prototype.d = 4;\n *\n * _.assignIn({ 'a': 0 }, new Foo, new Bar);\n * // => { 'a': 1, 'b': 2, 'c': 3, 'd': 4 }\n */\n var assignIn = createAssigner(function(object, source) {\n copyObject(source, keysIn(source), object);\n });\n\n /**\n * This method is like `_.assignIn` except that it accepts `customizer`\n * which is invoked to produce the assigned values. If `customizer` returns\n * `undefined`, assignment is handled by the method instead. The `customizer`\n * is invoked with five arguments: (objValue, srcValue, key, object, source).\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @alias extendWith\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} sources The source objects.\n * @param {Function} [customizer] The function to customize assigned values.\n * @returns {Object} Returns `object`.\n * @see _.assignWith\n * @example\n *\n * function customizer(objValue, srcValue) {\n * return _.isUndefined(objValue) ? srcValue : objValue;\n * }\n *\n * var defaults = _.partialRight(_.assignInWith, customizer);\n *\n * defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 });\n * // => { 'a': 1, 'b': 2 }\n */\n var assignInWith = createAssigner(function(object, source, srcIndex, customizer) {\n copyObject(source, keysIn(source), object, customizer);\n });\n\n /**\n * This method is like `_.assign` except that it accepts `customizer`\n * which is invoked to produce the assigned values. If `customizer` returns\n * `undefined`, assignment is handled by the method instead. The `customizer`\n * is invoked with five arguments: (objValue, srcValue, key, object, source).\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} sources The source objects.\n * @param {Function} [customizer] The function to customize assigned values.\n * @returns {Object} Returns `object`.\n * @see _.assignInWith\n * @example\n *\n * function customizer(objValue, srcValue) {\n * return _.isUndefined(objValue) ? srcValue : objValue;\n * }\n *\n * var defaults = _.partialRight(_.assignWith, customizer);\n *\n * defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 });\n * // => { 'a': 1, 'b': 2 }\n */\n var assignWith = createAssigner(function(object, source, srcIndex, customizer) {\n copyObject(source, keys(source), object, customizer);\n });\n\n /**\n * Creates an array of values corresponding to `paths` of `object`.\n *\n * @static\n * @memberOf _\n * @since 1.0.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {...(string|string[])} [paths] The property paths to pick.\n * @returns {Array} Returns the picked values.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }, 4] };\n *\n * _.at(object, ['a[0].b.c', 'a[1]']);\n * // => [3, 4]\n */\n var at = flatRest(baseAt);\n\n /**\n * Creates an object that inherits from the `prototype` object. If a\n * `properties` object is given, its own enumerable string keyed properties\n * are assigned to the created object.\n *\n * @static\n * @memberOf _\n * @since 2.3.0\n * @category Object\n * @param {Object} prototype The object to inherit from.\n * @param {Object} [properties] The properties to assign to the object.\n * @returns {Object} Returns the new object.\n * @example\n *\n * function Shape() {\n * this.x = 0;\n * this.y = 0;\n * }\n *\n * function Circle() {\n * Shape.call(this);\n * }\n *\n * Circle.prototype = _.create(Shape.prototype, {\n * 'constructor': Circle\n * });\n *\n * var circle = new Circle;\n * circle instanceof Circle;\n * // => true\n *\n * circle instanceof Shape;\n * // => true\n */\n function create(prototype, properties) {\n var result = baseCreate(prototype);\n return properties == null ? result : baseAssign(result, properties);\n }\n\n /**\n * Assigns own and inherited enumerable string keyed properties of source\n * objects to the destination object for all destination properties that\n * resolve to `undefined`. Source objects are applied from left to right.\n * Once a property is set, additional values of the same property are ignored.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @see _.defaultsDeep\n * @example\n *\n * _.defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 });\n * // => { 'a': 1, 'b': 2 }\n */\n var defaults = baseRest(function(object, sources) {\n object = Object(object);\n\n var index = -1;\n var length = sources.length;\n var guard = length > 2 ? sources[2] : undefined;\n\n if (guard && isIterateeCall(sources[0], sources[1], guard)) {\n length = 1;\n }\n\n while (++index < length) {\n var source = sources[index];\n var props = keysIn(source);\n var propsIndex = -1;\n var propsLength = props.length;\n\n while (++propsIndex < propsLength) {\n var key = props[propsIndex];\n var value = object[key];\n\n if (value === undefined ||\n (eq(value, objectProto[key]) && !hasOwnProperty.call(object, key))) {\n object[key] = source[key];\n }\n }\n }\n\n return object;\n });\n\n /**\n * This method is like `_.defaults` except that it recursively assigns\n * default properties.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 3.10.0\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @see _.defaults\n * @example\n *\n * _.defaultsDeep({ 'a': { 'b': 2 } }, { 'a': { 'b': 1, 'c': 3 } });\n * // => { 'a': { 'b': 2, 'c': 3 } }\n */\n var defaultsDeep = baseRest(function(args) {\n args.push(undefined, customDefaultsMerge);\n return apply(mergeWith, undefined, args);\n });\n\n /**\n * This method is like `_.find` except that it returns the key of the first\n * element `predicate` returns truthy for instead of the element itself.\n *\n * @static\n * @memberOf _\n * @since 1.1.0\n * @category Object\n * @param {Object} object The object to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {string|undefined} Returns the key of the matched element,\n * else `undefined`.\n * @example\n *\n * var users = {\n * 'barney': { 'age': 36, 'active': true },\n * 'fred': { 'age': 40, 'active': false },\n * 'pebbles': { 'age': 1, 'active': true }\n * };\n *\n * _.findKey(users, function(o) { return o.age < 40; });\n * // => 'barney' (iteration order is not guaranteed)\n *\n * // The `_.matches` iteratee shorthand.\n * _.findKey(users, { 'age': 1, 'active': true });\n * // => 'pebbles'\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.findKey(users, ['active', false]);\n * // => 'fred'\n *\n * // The `_.property` iteratee shorthand.\n * _.findKey(users, 'active');\n * // => 'barney'\n */\n function findKey(object, predicate) {\n return baseFindKey(object, getIteratee(predicate, 3), baseForOwn);\n }\n\n /**\n * This method is like `_.findKey` except that it iterates over elements of\n * a collection in the opposite order.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Object\n * @param {Object} object The object to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {string|undefined} Returns the key of the matched element,\n * else `undefined`.\n * @example\n *\n * var users = {\n * 'barney': { 'age': 36, 'active': true },\n * 'fred': { 'age': 40, 'active': false },\n * 'pebbles': { 'age': 1, 'active': true }\n * };\n *\n * _.findLastKey(users, function(o) { return o.age < 40; });\n * // => returns 'pebbles' assuming `_.findKey` returns 'barney'\n *\n * // The `_.matches` iteratee shorthand.\n * _.findLastKey(users, { 'age': 36, 'active': true });\n * // => 'barney'\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.findLastKey(users, ['active', false]);\n * // => 'fred'\n *\n * // The `_.property` iteratee shorthand.\n * _.findLastKey(users, 'active');\n * // => 'pebbles'\n */\n function findLastKey(object, predicate) {\n return baseFindKey(object, getIteratee(predicate, 3), baseForOwnRight);\n }\n\n /**\n * Iterates over own and inherited enumerable string keyed properties of an\n * object and invokes `iteratee` for each property. The iteratee is invoked\n * with three arguments: (value, key, object). Iteratee functions may exit\n * iteration early by explicitly returning `false`.\n *\n * @static\n * @memberOf _\n * @since 0.3.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns `object`.\n * @see _.forInRight\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.forIn(new Foo, function(value, key) {\n * console.log(key);\n * });\n * // => Logs 'a', 'b', then 'c' (iteration order is not guaranteed).\n */\n function forIn(object, iteratee) {\n return object == null\n ? object\n : baseFor(object, getIteratee(iteratee, 3), keysIn);\n }\n\n /**\n * This method is like `_.forIn` except that it iterates over properties of\n * `object` in the opposite order.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns `object`.\n * @see _.forIn\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.forInRight(new Foo, function(value, key) {\n * console.log(key);\n * });\n * // => Logs 'c', 'b', then 'a' assuming `_.forIn` logs 'a', 'b', then 'c'.\n */\n function forInRight(object, iteratee) {\n return object == null\n ? object\n : baseForRight(object, getIteratee(iteratee, 3), keysIn);\n }\n\n /**\n * Iterates over own enumerable string keyed properties of an object and\n * invokes `iteratee` for each property. The iteratee is invoked with three\n * arguments: (value, key, object). Iteratee functions may exit iteration\n * early by explicitly returning `false`.\n *\n * @static\n * @memberOf _\n * @since 0.3.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns `object`.\n * @see _.forOwnRight\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.forOwn(new Foo, function(value, key) {\n * console.log(key);\n * });\n * // => Logs 'a' then 'b' (iteration order is not guaranteed).\n */\n function forOwn(object, iteratee) {\n return object && baseForOwn(object, getIteratee(iteratee, 3));\n }\n\n /**\n * This method is like `_.forOwn` except that it iterates over properties of\n * `object` in the opposite order.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns `object`.\n * @see _.forOwn\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.forOwnRight(new Foo, function(value, key) {\n * console.log(key);\n * });\n * // => Logs 'b' then 'a' assuming `_.forOwn` logs 'a' then 'b'.\n */\n function forOwnRight(object, iteratee) {\n return object && baseForOwnRight(object, getIteratee(iteratee, 3));\n }\n\n /**\n * Creates an array of function property names from own enumerable properties\n * of `object`.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to inspect.\n * @returns {Array} Returns the function names.\n * @see _.functionsIn\n * @example\n *\n * function Foo() {\n * this.a = _.constant('a');\n * this.b = _.constant('b');\n * }\n *\n * Foo.prototype.c = _.constant('c');\n *\n * _.functions(new Foo);\n * // => ['a', 'b']\n */\n function functions(object) {\n return object == null ? [] : baseFunctions(object, keys(object));\n }\n\n /**\n * Creates an array of function property names from own and inherited\n * enumerable properties of `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to inspect.\n * @returns {Array} Returns the function names.\n * @see _.functions\n * @example\n *\n * function Foo() {\n * this.a = _.constant('a');\n * this.b = _.constant('b');\n * }\n *\n * Foo.prototype.c = _.constant('c');\n *\n * _.functionsIn(new Foo);\n * // => ['a', 'b', 'c']\n */\n function functionsIn(object) {\n return object == null ? [] : baseFunctions(object, keysIn(object));\n }\n\n /**\n * Gets the value at `path` of `object`. If the resolved value is\n * `undefined`, the `defaultValue` is returned in its place.\n *\n * @static\n * @memberOf _\n * @since 3.7.0\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the property to get.\n * @param {*} [defaultValue] The value returned for `undefined` resolved values.\n * @returns {*} Returns the resolved value.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }] };\n *\n * _.get(object, 'a[0].b.c');\n * // => 3\n *\n * _.get(object, ['a', '0', 'b', 'c']);\n * // => 3\n *\n * _.get(object, 'a.b.c', 'default');\n * // => 'default'\n */\n function get(object, path, defaultValue) {\n var result = object == null ? undefined : baseGet(object, path);\n return result === undefined ? defaultValue : result;\n }\n\n /**\n * Checks if `path` is a direct property of `object`.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n * @example\n *\n * var object = { 'a': { 'b': 2 } };\n * var other = _.create({ 'a': _.create({ 'b': 2 }) });\n *\n * _.has(object, 'a');\n * // => true\n *\n * _.has(object, 'a.b');\n * // => true\n *\n * _.has(object, ['a', 'b']);\n * // => true\n *\n * _.has(other, 'a');\n * // => false\n */\n function has(object, path) {\n return object != null && hasPath(object, path, baseHas);\n }\n\n /**\n * Checks if `path` is a direct or inherited property of `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n * @example\n *\n * var object = _.create({ 'a': _.create({ 'b': 2 }) });\n *\n * _.hasIn(object, 'a');\n * // => true\n *\n * _.hasIn(object, 'a.b');\n * // => true\n *\n * _.hasIn(object, ['a', 'b']);\n * // => true\n *\n * _.hasIn(object, 'b');\n * // => false\n */\n function hasIn(object, path) {\n return object != null && hasPath(object, path, baseHasIn);\n }\n\n /**\n * Creates an object composed of the inverted keys and values of `object`.\n * If `object` contains duplicate values, subsequent values overwrite\n * property assignments of previous values.\n *\n * @static\n * @memberOf _\n * @since 0.7.0\n * @category Object\n * @param {Object} object The object to invert.\n * @returns {Object} Returns the new inverted object.\n * @example\n *\n * var object = { 'a': 1, 'b': 2, 'c': 1 };\n *\n * _.invert(object);\n * // => { '1': 'c', '2': 'b' }\n */\n var invert = createInverter(function(result, value, key) {\n if (value != null &&\n typeof value.toString != 'function') {\n value = nativeObjectToString.call(value);\n }\n\n result[value] = key;\n }, constant(identity));\n\n /**\n * This method is like `_.invert` except that the inverted object is generated\n * from the results of running each element of `object` thru `iteratee`. The\n * corresponding inverted value of each inverted key is an array of keys\n * responsible for generating the inverted value. The iteratee is invoked\n * with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.1.0\n * @category Object\n * @param {Object} object The object to invert.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Object} Returns the new inverted object.\n * @example\n *\n * var object = { 'a': 1, 'b': 2, 'c': 1 };\n *\n * _.invertBy(object);\n * // => { '1': ['a', 'c'], '2': ['b'] }\n *\n * _.invertBy(object, function(value) {\n * return 'group' + value;\n * });\n * // => { 'group1': ['a', 'c'], 'group2': ['b'] }\n */\n var invertBy = createInverter(function(result, value, key) {\n if (value != null &&\n typeof value.toString != 'function') {\n value = nativeObjectToString.call(value);\n }\n\n if (hasOwnProperty.call(result, value)) {\n result[value].push(key);\n } else {\n result[value] = [key];\n }\n }, getIteratee);\n\n /**\n * Invokes the method at `path` of `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the method to invoke.\n * @param {...*} [args] The arguments to invoke the method with.\n * @returns {*} Returns the result of the invoked method.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': [1, 2, 3, 4] } }] };\n *\n * _.invoke(object, 'a[0].b.c.slice', 1, 3);\n * // => [2, 3]\n */\n var invoke = baseRest(baseInvoke);\n\n /**\n * Creates an array of the own enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects. See the\n * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * for more details.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keys(new Foo);\n * // => ['a', 'b'] (iteration order is not guaranteed)\n *\n * _.keys('hi');\n * // => ['0', '1']\n */\n function keys(object) {\n return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);\n }\n\n /**\n * Creates an array of the own and inherited enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keysIn(new Foo);\n * // => ['a', 'b', 'c'] (iteration order is not guaranteed)\n */\n function keysIn(object) {\n return isArrayLike(object) ? arrayLikeKeys(object, true) : baseKeysIn(object);\n }\n\n /**\n * The opposite of `_.mapValues`; this method creates an object with the\n * same values as `object` and keys generated by running each own enumerable\n * string keyed property of `object` thru `iteratee`. The iteratee is invoked\n * with three arguments: (value, key, object).\n *\n * @static\n * @memberOf _\n * @since 3.8.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns the new mapped object.\n * @see _.mapValues\n * @example\n *\n * _.mapKeys({ 'a': 1, 'b': 2 }, function(value, key) {\n * return key + value;\n * });\n * // => { 'a1': 1, 'b2': 2 }\n */\n function mapKeys(object, iteratee) {\n var result = {};\n iteratee = getIteratee(iteratee, 3);\n\n baseForOwn(object, function(value, key, object) {\n baseAssignValue(result, iteratee(value, key, object), value);\n });\n return result;\n }\n\n /**\n * Creates an object with the same keys as `object` and values generated\n * by running each own enumerable string keyed property of `object` thru\n * `iteratee`. The iteratee is invoked with three arguments:\n * (value, key, object).\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns the new mapped object.\n * @see _.mapKeys\n * @example\n *\n * var users = {\n * 'fred': { 'user': 'fred', 'age': 40 },\n * 'pebbles': { 'user': 'pebbles', 'age': 1 }\n * };\n *\n * _.mapValues(users, function(o) { return o.age; });\n * // => { 'fred': 40, 'pebbles': 1 } (iteration order is not guaranteed)\n *\n * // The `_.property` iteratee shorthand.\n * _.mapValues(users, 'age');\n * // => { 'fred': 40, 'pebbles': 1 } (iteration order is not guaranteed)\n */\n function mapValues(object, iteratee) {\n var result = {};\n iteratee = getIteratee(iteratee, 3);\n\n baseForOwn(object, function(value, key, object) {\n baseAssignValue(result, key, iteratee(value, key, object));\n });\n return result;\n }\n\n /**\n * This method is like `_.assign` except that it recursively merges own and\n * inherited enumerable string keyed properties of source objects into the\n * destination object. Source properties that resolve to `undefined` are\n * skipped if a destination value exists. Array and plain object properties\n * are merged recursively. Other objects and value types are overridden by\n * assignment. Source objects are applied from left to right. Subsequent\n * sources overwrite property assignments of previous sources.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 0.5.0\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = {\n * 'a': [{ 'b': 2 }, { 'd': 4 }]\n * };\n *\n * var other = {\n * 'a': [{ 'c': 3 }, { 'e': 5 }]\n * };\n *\n * _.merge(object, other);\n * // => { 'a': [{ 'b': 2, 'c': 3 }, { 'd': 4, 'e': 5 }] }\n */\n var merge = createAssigner(function(object, source, srcIndex) {\n baseMerge(object, source, srcIndex);\n });\n\n /**\n * This method is like `_.merge` except that it accepts `customizer` which\n * is invoked to produce the merged values of the destination and source\n * properties. If `customizer` returns `undefined`, merging is handled by the\n * method instead. The `customizer` is invoked with six arguments:\n * (objValue, srcValue, key, object, source, stack).\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} sources The source objects.\n * @param {Function} customizer The function to customize assigned values.\n * @returns {Object} Returns `object`.\n * @example\n *\n * function customizer(objValue, srcValue) {\n * if (_.isArray(objValue)) {\n * return objValue.concat(srcValue);\n * }\n * }\n *\n * var object = { 'a': [1], 'b': [2] };\n * var other = { 'a': [3], 'b': [4] };\n *\n * _.mergeWith(object, other, customizer);\n * // => { 'a': [1, 3], 'b': [2, 4] }\n */\n var mergeWith = createAssigner(function(object, source, srcIndex, customizer) {\n baseMerge(object, source, srcIndex, customizer);\n });\n\n /**\n * The opposite of `_.pick`; this method creates an object composed of the\n * own and inherited enumerable property paths of `object` that are not omitted.\n *\n * **Note:** This method is considerably slower than `_.pick`.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The source object.\n * @param {...(string|string[])} [paths] The property paths to omit.\n * @returns {Object} Returns the new object.\n * @example\n *\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\n *\n * _.omit(object, ['a', 'c']);\n * // => { 'b': '2' }\n */\n var omit = flatRest(function(object, paths) {\n var result = {};\n if (object == null) {\n return result;\n }\n var isDeep = false;\n paths = arrayMap(paths, function(path) {\n path = castPath(path, object);\n isDeep || (isDeep = path.length > 1);\n return path;\n });\n copyObject(object, getAllKeysIn(object), result);\n if (isDeep) {\n result = baseClone(result, CLONE_DEEP_FLAG | CLONE_FLAT_FLAG | CLONE_SYMBOLS_FLAG, customOmitClone);\n }\n var length = paths.length;\n while (length--) {\n baseUnset(result, paths[length]);\n }\n return result;\n });\n\n /**\n * The opposite of `_.pickBy`; this method creates an object composed of\n * the own and inherited enumerable string keyed properties of `object` that\n * `predicate` doesn't return truthy for. The predicate is invoked with two\n * arguments: (value, key).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The source object.\n * @param {Function} [predicate=_.identity] The function invoked per property.\n * @returns {Object} Returns the new object.\n * @example\n *\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\n *\n * _.omitBy(object, _.isNumber);\n * // => { 'b': '2' }\n */\n function omitBy(object, predicate) {\n return pickBy(object, negate(getIteratee(predicate)));\n }\n\n /**\n * Creates an object composed of the picked `object` properties.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The source object.\n * @param {...(string|string[])} [paths] The property paths to pick.\n * @returns {Object} Returns the new object.\n * @example\n *\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\n *\n * _.pick(object, ['a', 'c']);\n * // => { 'a': 1, 'c': 3 }\n */\n var pick = flatRest(function(object, paths) {\n return object == null ? {} : basePick(object, paths);\n });\n\n /**\n * Creates an object composed of the `object` properties `predicate` returns\n * truthy for. The predicate is invoked with two arguments: (value, key).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The source object.\n * @param {Function} [predicate=_.identity] The function invoked per property.\n * @returns {Object} Returns the new object.\n * @example\n *\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\n *\n * _.pickBy(object, _.isNumber);\n * // => { 'a': 1, 'c': 3 }\n */\n function pickBy(object, predicate) {\n if (object == null) {\n return {};\n }\n var props = arrayMap(getAllKeysIn(object), function(prop) {\n return [prop];\n });\n predicate = getIteratee(predicate);\n return basePickBy(object, props, function(value, path) {\n return predicate(value, path[0]);\n });\n }\n\n /**\n * This method is like `_.get` except that if the resolved value is a\n * function it's invoked with the `this` binding of its parent object and\n * its result is returned.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the property to resolve.\n * @param {*} [defaultValue] The value returned for `undefined` resolved values.\n * @returns {*} Returns the resolved value.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c1': 3, 'c2': _.constant(4) } }] };\n *\n * _.result(object, 'a[0].b.c1');\n * // => 3\n *\n * _.result(object, 'a[0].b.c2');\n * // => 4\n *\n * _.result(object, 'a[0].b.c3', 'default');\n * // => 'default'\n *\n * _.result(object, 'a[0].b.c3', _.constant('default'));\n * // => 'default'\n */\n function result(object, path, defaultValue) {\n path = castPath(path, object);\n\n var index = -1,\n length = path.length;\n\n // Ensure the loop is entered when path is empty.\n if (!length) {\n length = 1;\n object = undefined;\n }\n while (++index < length) {\n var value = object == null ? undefined : object[toKey(path[index])];\n if (value === undefined) {\n index = length;\n value = defaultValue;\n }\n object = isFunction(value) ? value.call(object) : value;\n }\n return object;\n }\n\n /**\n * Sets the value at `path` of `object`. If a portion of `path` doesn't exist,\n * it's created. Arrays are created for missing index properties while objects\n * are created for all other missing properties. Use `_.setWith` to customize\n * `path` creation.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 3.7.0\n * @category Object\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }] };\n *\n * _.set(object, 'a[0].b.c', 4);\n * console.log(object.a[0].b.c);\n * // => 4\n *\n * _.set(object, ['x', '0', 'y', 'z'], 5);\n * console.log(object.x[0].y.z);\n * // => 5\n */\n function set(object, path, value) {\n return object == null ? object : baseSet(object, path, value);\n }\n\n /**\n * This method is like `_.set` except that it accepts `customizer` which is\n * invoked to produce the objects of `path`. If `customizer` returns `undefined`\n * path creation is handled by the method instead. The `customizer` is invoked\n * with three arguments: (nsValue, key, nsObject).\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {*} value The value to set.\n * @param {Function} [customizer] The function to customize assigned values.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = {};\n *\n * _.setWith(object, '[0][1]', 'a', Object);\n * // => { '0': { '1': 'a' } }\n */\n function setWith(object, path, value, customizer) {\n customizer = typeof customizer == 'function' ? customizer : undefined;\n return object == null ? object : baseSet(object, path, value, customizer);\n }\n\n /**\n * Creates an array of own enumerable string keyed-value pairs for `object`\n * which can be consumed by `_.fromPairs`. If `object` is a map or set, its\n * entries are returned.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @alias entries\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the key-value pairs.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.toPairs(new Foo);\n * // => [['a', 1], ['b', 2]] (iteration order is not guaranteed)\n */\n var toPairs = createToPairs(keys);\n\n /**\n * Creates an array of own and inherited enumerable string keyed-value pairs\n * for `object` which can be consumed by `_.fromPairs`. If `object` is a map\n * or set, its entries are returned.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @alias entriesIn\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the key-value pairs.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.toPairsIn(new Foo);\n * // => [['a', 1], ['b', 2], ['c', 3]] (iteration order is not guaranteed)\n */\n var toPairsIn = createToPairs(keysIn);\n\n /**\n * An alternative to `_.reduce`; this method transforms `object` to a new\n * `accumulator` object which is the result of running each of its own\n * enumerable string keyed properties thru `iteratee`, with each invocation\n * potentially mutating the `accumulator` object. If `accumulator` is not\n * provided, a new object with the same `[[Prototype]]` will be used. The\n * iteratee is invoked with four arguments: (accumulator, value, key, object).\n * Iteratee functions may exit iteration early by explicitly returning `false`.\n *\n * @static\n * @memberOf _\n * @since 1.3.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @param {*} [accumulator] The custom accumulator value.\n * @returns {*} Returns the accumulated value.\n * @example\n *\n * _.transform([2, 3, 4], function(result, n) {\n * result.push(n *= n);\n * return n % 2 == 0;\n * }, []);\n * // => [4, 9]\n *\n * _.transform({ 'a': 1, 'b': 2, 'c': 1 }, function(result, value, key) {\n * (result[value] || (result[value] = [])).push(key);\n * }, {});\n * // => { '1': ['a', 'c'], '2': ['b'] }\n */\n function transform(object, iteratee, accumulator) {\n var isArr = isArray(object),\n isArrLike = isArr || isBuffer(object) || isTypedArray(object);\n\n iteratee = getIteratee(iteratee, 4);\n if (accumulator == null) {\n var Ctor = object && object.constructor;\n if (isArrLike) {\n accumulator = isArr ? new Ctor : [];\n }\n else if (isObject(object)) {\n accumulator = isFunction(Ctor) ? baseCreate(getPrototype(object)) : {};\n }\n else {\n accumulator = {};\n }\n }\n (isArrLike ? arrayEach : baseForOwn)(object, function(value, index, object) {\n return iteratee(accumulator, value, index, object);\n });\n return accumulator;\n }\n\n /**\n * Removes the property at `path` of `object`.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to unset.\n * @returns {boolean} Returns `true` if the property is deleted, else `false`.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 7 } }] };\n * _.unset(object, 'a[0].b.c');\n * // => true\n *\n * console.log(object);\n * // => { 'a': [{ 'b': {} }] };\n *\n * _.unset(object, ['a', '0', 'b', 'c']);\n * // => true\n *\n * console.log(object);\n * // => { 'a': [{ 'b': {} }] };\n */\n function unset(object, path) {\n return object == null ? true : baseUnset(object, path);\n }\n\n /**\n * This method is like `_.set` except that accepts `updater` to produce the\n * value to set. Use `_.updateWith` to customize `path` creation. The `updater`\n * is invoked with one argument: (value).\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.6.0\n * @category Object\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {Function} updater The function to produce the updated value.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }] };\n *\n * _.update(object, 'a[0].b.c', function(n) { return n * n; });\n * console.log(object.a[0].b.c);\n * // => 9\n *\n * _.update(object, 'x[0].y.z', function(n) { return n ? n + 1 : 0; });\n * console.log(object.x[0].y.z);\n * // => 0\n */\n function update(object, path, updater) {\n return object == null ? object : baseUpdate(object, path, castFunction(updater));\n }\n\n /**\n * This method is like `_.update` except that it accepts `customizer` which is\n * invoked to produce the objects of `path`. If `customizer` returns `undefined`\n * path creation is handled by the method instead. The `customizer` is invoked\n * with three arguments: (nsValue, key, nsObject).\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.6.0\n * @category Object\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {Function} updater The function to produce the updated value.\n * @param {Function} [customizer] The function to customize assigned values.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = {};\n *\n * _.updateWith(object, '[0][1]', _.constant('a'), Object);\n * // => { '0': { '1': 'a' } }\n */\n function updateWith(object, path, updater, customizer) {\n customizer = typeof customizer == 'function' ? customizer : undefined;\n return object == null ? object : baseUpdate(object, path, castFunction(updater), customizer);\n }\n\n /**\n * Creates an array of the own enumerable string keyed property values of `object`.\n *\n * **Note:** Non-object values are coerced to objects.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property values.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.values(new Foo);\n * // => [1, 2] (iteration order is not guaranteed)\n *\n * _.values('hi');\n * // => ['h', 'i']\n */\n function values(object) {\n return object == null ? [] : baseValues(object, keys(object));\n }\n\n /**\n * Creates an array of the own and inherited enumerable string keyed property\n * values of `object`.\n *\n * **Note:** Non-object values are coerced to objects.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property values.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.valuesIn(new Foo);\n * // => [1, 2, 3] (iteration order is not guaranteed)\n */\n function valuesIn(object) {\n return object == null ? [] : baseValues(object, keysIn(object));\n }\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Clamps `number` within the inclusive `lower` and `upper` bounds.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Number\n * @param {number} number The number to clamp.\n * @param {number} [lower] The lower bound.\n * @param {number} upper The upper bound.\n * @returns {number} Returns the clamped number.\n * @example\n *\n * _.clamp(-10, -5, 5);\n * // => -5\n *\n * _.clamp(10, -5, 5);\n * // => 5\n */\n function clamp(number, lower, upper) {\n if (upper === undefined) {\n upper = lower;\n lower = undefined;\n }\n if (upper !== undefined) {\n upper = toNumber(upper);\n upper = upper === upper ? upper : 0;\n }\n if (lower !== undefined) {\n lower = toNumber(lower);\n lower = lower === lower ? lower : 0;\n }\n return baseClamp(toNumber(number), lower, upper);\n }\n\n /**\n * Checks if `n` is between `start` and up to, but not including, `end`. If\n * `end` is not specified, it's set to `start` with `start` then set to `0`.\n * If `start` is greater than `end` the params are swapped to support\n * negative ranges.\n *\n * @static\n * @memberOf _\n * @since 3.3.0\n * @category Number\n * @param {number} number The number to check.\n * @param {number} [start=0] The start of the range.\n * @param {number} end The end of the range.\n * @returns {boolean} Returns `true` if `number` is in the range, else `false`.\n * @see _.range, _.rangeRight\n * @example\n *\n * _.inRange(3, 2, 4);\n * // => true\n *\n * _.inRange(4, 8);\n * // => true\n *\n * _.inRange(4, 2);\n * // => false\n *\n * _.inRange(2, 2);\n * // => false\n *\n * _.inRange(1.2, 2);\n * // => true\n *\n * _.inRange(5.2, 4);\n * // => false\n *\n * _.inRange(-3, -2, -6);\n * // => true\n */\n function inRange(number, start, end) {\n start = toFinite(start);\n if (end === undefined) {\n end = start;\n start = 0;\n } else {\n end = toFinite(end);\n }\n number = toNumber(number);\n return baseInRange(number, start, end);\n }\n\n /**\n * Produces a random number between the inclusive `lower` and `upper` bounds.\n * If only one argument is provided a number between `0` and the given number\n * is returned. If `floating` is `true`, or either `lower` or `upper` are\n * floats, a floating-point number is returned instead of an integer.\n *\n * **Note:** JavaScript follows the IEEE-754 standard for resolving\n * floating-point values which can produce unexpected results.\n *\n * @static\n * @memberOf _\n * @since 0.7.0\n * @category Number\n * @param {number} [lower=0] The lower bound.\n * @param {number} [upper=1] The upper bound.\n * @param {boolean} [floating] Specify returning a floating-point number.\n * @returns {number} Returns the random number.\n * @example\n *\n * _.random(0, 5);\n * // => an integer between 0 and 5\n *\n * _.random(5);\n * // => also an integer between 0 and 5\n *\n * _.random(5, true);\n * // => a floating-point number between 0 and 5\n *\n * _.random(1.2, 5.2);\n * // => a floating-point number between 1.2 and 5.2\n */\n function random(lower, upper, floating) {\n if (floating && typeof floating != 'boolean' && isIterateeCall(lower, upper, floating)) {\n upper = floating = undefined;\n }\n if (floating === undefined) {\n if (typeof upper == 'boolean') {\n floating = upper;\n upper = undefined;\n }\n else if (typeof lower == 'boolean') {\n floating = lower;\n lower = undefined;\n }\n }\n if (lower === undefined && upper === undefined) {\n lower = 0;\n upper = 1;\n }\n else {\n lower = toFinite(lower);\n if (upper === undefined) {\n upper = lower;\n lower = 0;\n } else {\n upper = toFinite(upper);\n }\n }\n if (lower > upper) {\n var temp = lower;\n lower = upper;\n upper = temp;\n }\n if (floating || lower % 1 || upper % 1) {\n var rand = nativeRandom();\n return nativeMin(lower + (rand * (upper - lower + freeParseFloat('1e-' + ((rand + '').length - 1)))), upper);\n }\n return baseRandom(lower, upper);\n }\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Converts `string` to [camel case](https://en.wikipedia.org/wiki/CamelCase).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the camel cased string.\n * @example\n *\n * _.camelCase('Foo Bar');\n * // => 'fooBar'\n *\n * _.camelCase('--foo-bar--');\n * // => 'fooBar'\n *\n * _.camelCase('__FOO_BAR__');\n * // => 'fooBar'\n */\n var camelCase = createCompounder(function(result, word, index) {\n word = word.toLowerCase();\n return result + (index ? capitalize(word) : word);\n });\n\n /**\n * Converts the first character of `string` to upper case and the remaining\n * to lower case.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to capitalize.\n * @returns {string} Returns the capitalized string.\n * @example\n *\n * _.capitalize('FRED');\n * // => 'Fred'\n */\n function capitalize(string) {\n return upperFirst(toString(string).toLowerCase());\n }\n\n /**\n * Deburrs `string` by converting\n * [Latin-1 Supplement](https://en.wikipedia.org/wiki/Latin-1_Supplement_(Unicode_block)#Character_table)\n * and [Latin Extended-A](https://en.wikipedia.org/wiki/Latin_Extended-A)\n * letters to basic Latin letters and removing\n * [combining diacritical marks](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to deburr.\n * @returns {string} Returns the deburred string.\n * @example\n *\n * _.deburr('déjà vu');\n * // => 'deja vu'\n */\n function deburr(string) {\n string = toString(string);\n return string && string.replace(reLatin, deburrLetter).replace(reComboMark, '');\n }\n\n /**\n * Checks if `string` ends with the given target string.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to inspect.\n * @param {string} [target] The string to search for.\n * @param {number} [position=string.length] The position to search up to.\n * @returns {boolean} Returns `true` if `string` ends with `target`,\n * else `false`.\n * @example\n *\n * _.endsWith('abc', 'c');\n * // => true\n *\n * _.endsWith('abc', 'b');\n * // => false\n *\n * _.endsWith('abc', 'b', 2);\n * // => true\n */\n function endsWith(string, target, position) {\n string = toString(string);\n target = baseToString(target);\n\n var length = string.length;\n position = position === undefined\n ? length\n : baseClamp(toInteger(position), 0, length);\n\n var end = position;\n position -= target.length;\n return position >= 0 && string.slice(position, end) == target;\n }\n\n /**\n * Converts the characters \"&\", \"<\", \">\", '\"', and \"'\" in `string` to their\n * corresponding HTML entities.\n *\n * **Note:** No other characters are escaped. To escape additional\n * characters use a third-party library like [_he_](https://mths.be/he).\n *\n * Though the \">\" character is escaped for symmetry, characters like\n * \">\" and \"/\" don't need escaping in HTML and have no special meaning\n * unless they're part of a tag or unquoted attribute value. See\n * [Mathias Bynens's article](https://mathiasbynens.be/notes/ambiguous-ampersands)\n * (under \"semi-related fun fact\") for more details.\n *\n * When working with HTML you should always\n * [quote attribute values](http://wonko.com/post/html-escaping) to reduce\n * XSS vectors.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category String\n * @param {string} [string=''] The string to escape.\n * @returns {string} Returns the escaped string.\n * @example\n *\n * _.escape('fred, barney, & pebbles');\n * // => 'fred, barney, & pebbles'\n */\n function escape(string) {\n string = toString(string);\n return (string && reHasUnescapedHtml.test(string))\n ? string.replace(reUnescapedHtml, escapeHtmlChar)\n : string;\n }\n\n /**\n * Escapes the `RegExp` special characters \"^\", \"$\", \"\\\", \".\", \"*\", \"+\",\n * \"?\", \"(\", \")\", \"[\", \"]\", \"{\", \"}\", and \"|\" in `string`.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to escape.\n * @returns {string} Returns the escaped string.\n * @example\n *\n * _.escapeRegExp('[lodash](https://lodash.com/)');\n * // => '\\[lodash\\]\\(https://lodash\\.com/\\)'\n */\n function escapeRegExp(string) {\n string = toString(string);\n return (string && reHasRegExpChar.test(string))\n ? string.replace(reRegExpChar, '\\\\$&')\n : string;\n }\n\n /**\n * Converts `string` to\n * [kebab case](https://en.wikipedia.org/wiki/Letter_case#Special_case_styles).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the kebab cased string.\n * @example\n *\n * _.kebabCase('Foo Bar');\n * // => 'foo-bar'\n *\n * _.kebabCase('fooBar');\n * // => 'foo-bar'\n *\n * _.kebabCase('__FOO_BAR__');\n * // => 'foo-bar'\n */\n var kebabCase = createCompounder(function(result, word, index) {\n return result + (index ? '-' : '') + word.toLowerCase();\n });\n\n /**\n * Converts `string`, as space separated words, to lower case.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the lower cased string.\n * @example\n *\n * _.lowerCase('--Foo-Bar--');\n * // => 'foo bar'\n *\n * _.lowerCase('fooBar');\n * // => 'foo bar'\n *\n * _.lowerCase('__FOO_BAR__');\n * // => 'foo bar'\n */\n var lowerCase = createCompounder(function(result, word, index) {\n return result + (index ? ' ' : '') + word.toLowerCase();\n });\n\n /**\n * Converts the first character of `string` to lower case.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the converted string.\n * @example\n *\n * _.lowerFirst('Fred');\n * // => 'fred'\n *\n * _.lowerFirst('FRED');\n * // => 'fRED'\n */\n var lowerFirst = createCaseFirst('toLowerCase');\n\n /**\n * Pads `string` on the left and right sides if it's shorter than `length`.\n * Padding characters are truncated if they can't be evenly divided by `length`.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to pad.\n * @param {number} [length=0] The padding length.\n * @param {string} [chars=' '] The string used as padding.\n * @returns {string} Returns the padded string.\n * @example\n *\n * _.pad('abc', 8);\n * // => ' abc '\n *\n * _.pad('abc', 8, '_-');\n * // => '_-abc_-_'\n *\n * _.pad('abc', 3);\n * // => 'abc'\n */\n function pad(string, length, chars) {\n string = toString(string);\n length = toInteger(length);\n\n var strLength = length ? stringSize(string) : 0;\n if (!length || strLength >= length) {\n return string;\n }\n var mid = (length - strLength) / 2;\n return (\n createPadding(nativeFloor(mid), chars) +\n string +\n createPadding(nativeCeil(mid), chars)\n );\n }\n\n /**\n * Pads `string` on the right side if it's shorter than `length`. Padding\n * characters are truncated if they exceed `length`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to pad.\n * @param {number} [length=0] The padding length.\n * @param {string} [chars=' '] The string used as padding.\n * @returns {string} Returns the padded string.\n * @example\n *\n * _.padEnd('abc', 6);\n * // => 'abc '\n *\n * _.padEnd('abc', 6, '_-');\n * // => 'abc_-_'\n *\n * _.padEnd('abc', 3);\n * // => 'abc'\n */\n function padEnd(string, length, chars) {\n string = toString(string);\n length = toInteger(length);\n\n var strLength = length ? stringSize(string) : 0;\n return (length && strLength < length)\n ? (string + createPadding(length - strLength, chars))\n : string;\n }\n\n /**\n * Pads `string` on the left side if it's shorter than `length`. Padding\n * characters are truncated if they exceed `length`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to pad.\n * @param {number} [length=0] The padding length.\n * @param {string} [chars=' '] The string used as padding.\n * @returns {string} Returns the padded string.\n * @example\n *\n * _.padStart('abc', 6);\n * // => ' abc'\n *\n * _.padStart('abc', 6, '_-');\n * // => '_-_abc'\n *\n * _.padStart('abc', 3);\n * // => 'abc'\n */\n function padStart(string, length, chars) {\n string = toString(string);\n length = toInteger(length);\n\n var strLength = length ? stringSize(string) : 0;\n return (length && strLength < length)\n ? (createPadding(length - strLength, chars) + string)\n : string;\n }\n\n /**\n * Converts `string` to an integer of the specified radix. If `radix` is\n * `undefined` or `0`, a `radix` of `10` is used unless `value` is a\n * hexadecimal, in which case a `radix` of `16` is used.\n *\n * **Note:** This method aligns with the\n * [ES5 implementation](https://es5.github.io/#x15.1.2.2) of `parseInt`.\n *\n * @static\n * @memberOf _\n * @since 1.1.0\n * @category String\n * @param {string} string The string to convert.\n * @param {number} [radix=10] The radix to interpret `value` by.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {number} Returns the converted integer.\n * @example\n *\n * _.parseInt('08');\n * // => 8\n *\n * _.map(['6', '08', '10'], _.parseInt);\n * // => [6, 8, 10]\n */\n function parseInt(string, radix, guard) {\n if (guard || radix == null) {\n radix = 0;\n } else if (radix) {\n radix = +radix;\n }\n return nativeParseInt(toString(string).replace(reTrimStart, ''), radix || 0);\n }\n\n /**\n * Repeats the given string `n` times.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to repeat.\n * @param {number} [n=1] The number of times to repeat the string.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {string} Returns the repeated string.\n * @example\n *\n * _.repeat('*', 3);\n * // => '***'\n *\n * _.repeat('abc', 2);\n * // => 'abcabc'\n *\n * _.repeat('abc', 0);\n * // => ''\n */\n function repeat(string, n, guard) {\n if ((guard ? isIterateeCall(string, n, guard) : n === undefined)) {\n n = 1;\n } else {\n n = toInteger(n);\n }\n return baseRepeat(toString(string), n);\n }\n\n /**\n * Replaces matches for `pattern` in `string` with `replacement`.\n *\n * **Note:** This method is based on\n * [`String#replace`](https://mdn.io/String/replace).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to modify.\n * @param {RegExp|string} pattern The pattern to replace.\n * @param {Function|string} replacement The match replacement.\n * @returns {string} Returns the modified string.\n * @example\n *\n * _.replace('Hi Fred', 'Fred', 'Barney');\n * // => 'Hi Barney'\n */\n function replace() {\n var args = arguments,\n string = toString(args[0]);\n\n return args.length < 3 ? string : string.replace(args[1], args[2]);\n }\n\n /**\n * Converts `string` to\n * [snake case](https://en.wikipedia.org/wiki/Snake_case).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the snake cased string.\n * @example\n *\n * _.snakeCase('Foo Bar');\n * // => 'foo_bar'\n *\n * _.snakeCase('fooBar');\n * // => 'foo_bar'\n *\n * _.snakeCase('--FOO-BAR--');\n * // => 'foo_bar'\n */\n var snakeCase = createCompounder(function(result, word, index) {\n return result + (index ? '_' : '') + word.toLowerCase();\n });\n\n /**\n * Splits `string` by `separator`.\n *\n * **Note:** This method is based on\n * [`String#split`](https://mdn.io/String/split).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to split.\n * @param {RegExp|string} separator The separator pattern to split by.\n * @param {number} [limit] The length to truncate results to.\n * @returns {Array} Returns the string segments.\n * @example\n *\n * _.split('a-b-c', '-', 2);\n * // => ['a', 'b']\n */\n function split(string, separator, limit) {\n if (limit && typeof limit != 'number' && isIterateeCall(string, separator, limit)) {\n separator = limit = undefined;\n }\n limit = limit === undefined ? MAX_ARRAY_LENGTH : limit >>> 0;\n if (!limit) {\n return [];\n }\n string = toString(string);\n if (string && (\n typeof separator == 'string' ||\n (separator != null && !isRegExp(separator))\n )) {\n separator = baseToString(separator);\n if (!separator && hasUnicode(string)) {\n return castSlice(stringToArray(string), 0, limit);\n }\n }\n return string.split(separator, limit);\n }\n\n /**\n * Converts `string` to\n * [start case](https://en.wikipedia.org/wiki/Letter_case#Stylistic_or_specialised_usage).\n *\n * @static\n * @memberOf _\n * @since 3.1.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the start cased string.\n * @example\n *\n * _.startCase('--foo-bar--');\n * // => 'Foo Bar'\n *\n * _.startCase('fooBar');\n * // => 'Foo Bar'\n *\n * _.startCase('__FOO_BAR__');\n * // => 'FOO BAR'\n */\n var startCase = createCompounder(function(result, word, index) {\n return result + (index ? ' ' : '') + upperFirst(word);\n });\n\n /**\n * Checks if `string` starts with the given target string.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to inspect.\n * @param {string} [target] The string to search for.\n * @param {number} [position=0] The position to search from.\n * @returns {boolean} Returns `true` if `string` starts with `target`,\n * else `false`.\n * @example\n *\n * _.startsWith('abc', 'a');\n * // => true\n *\n * _.startsWith('abc', 'b');\n * // => false\n *\n * _.startsWith('abc', 'b', 1);\n * // => true\n */\n function startsWith(string, target, position) {\n string = toString(string);\n position = position == null\n ? 0\n : baseClamp(toInteger(position), 0, string.length);\n\n target = baseToString(target);\n return string.slice(position, position + target.length) == target;\n }\n\n /**\n * Creates a compiled template function that can interpolate data properties\n * in \"interpolate\" delimiters, HTML-escape interpolated data properties in\n * \"escape\" delimiters, and execute JavaScript in \"evaluate\" delimiters. Data\n * properties may be accessed as free variables in the template. If a setting\n * object is given, it takes precedence over `_.templateSettings` values.\n *\n * **Note:** In the development build `_.template` utilizes\n * [sourceURLs](http://www.html5rocks.com/en/tutorials/developertools/sourcemaps/#toc-sourceurl)\n * for easier debugging.\n *\n * For more information on precompiling templates see\n * [lodash's custom builds documentation](https://lodash.com/custom-builds).\n *\n * For more information on Chrome extension sandboxes see\n * [Chrome's extensions documentation](https://developer.chrome.com/extensions/sandboxingEval).\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category String\n * @param {string} [string=''] The template string.\n * @param {Object} [options={}] The options object.\n * @param {RegExp} [options.escape=_.templateSettings.escape]\n * The HTML \"escape\" delimiter.\n * @param {RegExp} [options.evaluate=_.templateSettings.evaluate]\n * The \"evaluate\" delimiter.\n * @param {Object} [options.imports=_.templateSettings.imports]\n * An object to import into the template as free variables.\n * @param {RegExp} [options.interpolate=_.templateSettings.interpolate]\n * The \"interpolate\" delimiter.\n * @param {string} [options.sourceURL='lodash.templateSources[n]']\n * The sourceURL of the compiled template.\n * @param {string} [options.variable='obj']\n * The data object variable name.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Function} Returns the compiled template function.\n * @example\n *\n * // Use the \"interpolate\" delimiter to create a compiled template.\n * var compiled = _.template('hello <%= user %>!');\n * compiled({ 'user': 'fred' });\n * // => 'hello fred!'\n *\n * // Use the HTML \"escape\" delimiter to escape data property values.\n * var compiled = _.template('<%- value %>');\n * compiled({ 'value': '`.\n this.sequenceIndex = Number(c === 60 /* Lt */);\n }\n };\n Tokenizer.prototype.stateCDATASequence = function (c) {\n if (c === Sequences.Cdata[this.sequenceIndex]) {\n if (++this.sequenceIndex === Sequences.Cdata.length) {\n this._state = 21 /* InCommentLike */;\n this.currentSequence = Sequences.CdataEnd;\n this.sequenceIndex = 0;\n this.sectionStart = this._index + 1;\n }\n }\n else {\n this.sequenceIndex = 0;\n this._state = 16 /* InDeclaration */;\n this.stateInDeclaration(c); // Reconsume the character\n }\n };\n /**\n * When we wait for one specific character, we can speed things up\n * by skipping through the buffer until we find it.\n *\n * @returns Whether the character was found.\n */\n Tokenizer.prototype.fastForwardTo = function (c) {\n while (++this._index < this.buffer.length) {\n if (this.buffer.charCodeAt(this._index) === c) {\n return true;\n }\n }\n /*\n * We increment the index at the end of the `parse` loop,\n * so set it to `buffer.length - 1` here.\n *\n * TODO: Refactor `parse` to increment index before calling states.\n */\n this._index = this.buffer.length - 1;\n return false;\n };\n /**\n * Comments and CDATA end with `-->` and `]]>`.\n *\n * Their common qualities are:\n * - Their end sequences have a distinct character they start with.\n * - That character is then repeated, so we have to check multiple repeats.\n * - All characters but the start character of the sequence can be skipped.\n */\n Tokenizer.prototype.stateInCommentLike = function (c) {\n if (c === this.currentSequence[this.sequenceIndex]) {\n if (++this.sequenceIndex === this.currentSequence.length) {\n // Remove 2 trailing chars\n var section = this.buffer.slice(this.sectionStart, this._index - 2);\n if (this.currentSequence === Sequences.CdataEnd) {\n this.cbs.oncdata(section);\n }\n else {\n this.cbs.oncomment(section);\n }\n this.sequenceIndex = 0;\n this.sectionStart = this._index + 1;\n this._state = 1 /* Text */;\n }\n }\n else if (this.sequenceIndex === 0) {\n // Fast-forward to the first character of the sequence\n if (this.fastForwardTo(this.currentSequence[0])) {\n this.sequenceIndex = 1;\n }\n }\n else if (c !== this.currentSequence[this.sequenceIndex - 1]) {\n // Allow long sequences, eg. --->, ]]]>\n this.sequenceIndex = 0;\n }\n };\n /**\n * HTML only allows ASCII alpha characters (a-z and A-Z) at the beginning of a tag name.\n *\n * XML allows a lot more characters here (@see https://www.w3.org/TR/REC-xml/#NT-NameStartChar).\n * We allow anything that wouldn't end the tag.\n */\n Tokenizer.prototype.isTagStartChar = function (c) {\n return this.xmlMode ? !isEndOfTagSection(c) : isASCIIAlpha(c);\n };\n Tokenizer.prototype.startSpecial = function (sequence, offset) {\n this.isSpecial = true;\n this.currentSequence = sequence;\n this.sequenceIndex = offset;\n this._state = 23 /* SpecialStartSequence */;\n };\n Tokenizer.prototype.stateBeforeTagName = function (c) {\n if (c === 33 /* ExclamationMark */) {\n this._state = 15 /* BeforeDeclaration */;\n this.sectionStart = this._index + 1;\n }\n else if (c === 63 /* Questionmark */) {\n this._state = 17 /* InProcessingInstruction */;\n this.sectionStart = this._index + 1;\n }\n else if (this.isTagStartChar(c)) {\n var lower = c | 0x20;\n this.sectionStart = this._index;\n if (!this.xmlMode && lower === Sequences.TitleEnd[2]) {\n this.startSpecial(Sequences.TitleEnd, 3);\n }\n else {\n this._state =\n !this.xmlMode && lower === Sequences.ScriptEnd[2]\n ? 22 /* BeforeSpecialS */\n : 3 /* InTagName */;\n }\n }\n else if (c === 47 /* Slash */) {\n this._state = 5 /* BeforeClosingTagName */;\n }\n else {\n this._state = 1 /* Text */;\n this.stateText(c);\n }\n };\n Tokenizer.prototype.stateInTagName = function (c) {\n if (isEndOfTagSection(c)) {\n this.cbs.onopentagname(this.getSection());\n this.sectionStart = -1;\n this._state = 8 /* BeforeAttributeName */;\n this.stateBeforeAttributeName(c);\n }\n };\n Tokenizer.prototype.stateBeforeClosingTagName = function (c) {\n if (isWhitespace(c)) {\n // Ignore\n }\n else if (c === 62 /* Gt */) {\n this._state = 1 /* Text */;\n }\n else {\n this._state = this.isTagStartChar(c)\n ? 6 /* InClosingTagName */\n : 20 /* InSpecialComment */;\n this.sectionStart = this._index;\n }\n };\n Tokenizer.prototype.stateInClosingTagName = function (c) {\n if (c === 62 /* Gt */ || isWhitespace(c)) {\n this.cbs.onclosetag(this.getSection());\n this.sectionStart = -1;\n this._state = 7 /* AfterClosingTagName */;\n this.stateAfterClosingTagName(c);\n }\n };\n Tokenizer.prototype.stateAfterClosingTagName = function (c) {\n // Skip everything until \">\"\n if (c === 62 /* Gt */ || this.fastForwardTo(62 /* Gt */)) {\n this._state = 1 /* Text */;\n this.sectionStart = this._index + 1;\n }\n };\n Tokenizer.prototype.stateBeforeAttributeName = function (c) {\n if (c === 62 /* Gt */) {\n this.cbs.onopentagend();\n if (this.isSpecial) {\n this._state = 24 /* InSpecialTag */;\n this.sequenceIndex = 0;\n }\n else {\n this._state = 1 /* Text */;\n }\n this.baseState = this._state;\n this.sectionStart = this._index + 1;\n }\n else if (c === 47 /* Slash */) {\n this._state = 4 /* InSelfClosingTag */;\n }\n else if (!isWhitespace(c)) {\n this._state = 9 /* InAttributeName */;\n this.sectionStart = this._index;\n }\n };\n Tokenizer.prototype.stateInSelfClosingTag = function (c) {\n if (c === 62 /* Gt */) {\n this.cbs.onselfclosingtag();\n this._state = 1 /* Text */;\n this.baseState = 1 /* Text */;\n this.sectionStart = this._index + 1;\n this.isSpecial = false; // Reset special state, in case of self-closing special tags\n }\n else if (!isWhitespace(c)) {\n this._state = 8 /* BeforeAttributeName */;\n this.stateBeforeAttributeName(c);\n }\n };\n Tokenizer.prototype.stateInAttributeName = function (c) {\n if (c === 61 /* Eq */ || isEndOfTagSection(c)) {\n this.cbs.onattribname(this.getSection());\n this.sectionStart = -1;\n this._state = 10 /* AfterAttributeName */;\n this.stateAfterAttributeName(c);\n }\n };\n Tokenizer.prototype.stateAfterAttributeName = function (c) {\n if (c === 61 /* Eq */) {\n this._state = 11 /* BeforeAttributeValue */;\n }\n else if (c === 47 /* Slash */ || c === 62 /* Gt */) {\n this.cbs.onattribend(undefined);\n this._state = 8 /* BeforeAttributeName */;\n this.stateBeforeAttributeName(c);\n }\n else if (!isWhitespace(c)) {\n this.cbs.onattribend(undefined);\n this._state = 9 /* InAttributeName */;\n this.sectionStart = this._index;\n }\n };\n Tokenizer.prototype.stateBeforeAttributeValue = function (c) {\n if (c === 34 /* DoubleQuote */) {\n this._state = 12 /* InAttributeValueDq */;\n this.sectionStart = this._index + 1;\n }\n else if (c === 39 /* SingleQuote */) {\n this._state = 13 /* InAttributeValueSq */;\n this.sectionStart = this._index + 1;\n }\n else if (!isWhitespace(c)) {\n this.sectionStart = this._index;\n this._state = 14 /* InAttributeValueNq */;\n this.stateInAttributeValueNoQuotes(c); // Reconsume token\n }\n };\n Tokenizer.prototype.handleInAttributeValue = function (c, quote) {\n if (c === quote ||\n (!this.decodeEntities && this.fastForwardTo(quote))) {\n this.cbs.onattribdata(this.getSection());\n this.sectionStart = -1;\n this.cbs.onattribend(String.fromCharCode(quote));\n this._state = 8 /* BeforeAttributeName */;\n }\n else if (this.decodeEntities && c === 38 /* Amp */) {\n this.baseState = this._state;\n this._state = 25 /* BeforeEntity */;\n }\n };\n Tokenizer.prototype.stateInAttributeValueDoubleQuotes = function (c) {\n this.handleInAttributeValue(c, 34 /* DoubleQuote */);\n };\n Tokenizer.prototype.stateInAttributeValueSingleQuotes = function (c) {\n this.handleInAttributeValue(c, 39 /* SingleQuote */);\n };\n Tokenizer.prototype.stateInAttributeValueNoQuotes = function (c) {\n if (isWhitespace(c) || c === 62 /* Gt */) {\n this.cbs.onattribdata(this.getSection());\n this.sectionStart = -1;\n this.cbs.onattribend(null);\n this._state = 8 /* BeforeAttributeName */;\n this.stateBeforeAttributeName(c);\n }\n else if (this.decodeEntities && c === 38 /* Amp */) {\n this.baseState = this._state;\n this._state = 25 /* BeforeEntity */;\n }\n };\n Tokenizer.prototype.stateBeforeDeclaration = function (c) {\n if (c === 91 /* OpeningSquareBracket */) {\n this._state = 19 /* CDATASequence */;\n this.sequenceIndex = 0;\n }\n else {\n this._state =\n c === 45 /* Dash */\n ? 18 /* BeforeComment */\n : 16 /* InDeclaration */;\n }\n };\n Tokenizer.prototype.stateInDeclaration = function (c) {\n if (c === 62 /* Gt */ || this.fastForwardTo(62 /* Gt */)) {\n this.cbs.ondeclaration(this.getSection());\n this._state = 1 /* Text */;\n this.sectionStart = this._index + 1;\n }\n };\n Tokenizer.prototype.stateInProcessingInstruction = function (c) {\n if (c === 62 /* Gt */ || this.fastForwardTo(62 /* Gt */)) {\n this.cbs.onprocessinginstruction(this.getSection());\n this._state = 1 /* Text */;\n this.sectionStart = this._index + 1;\n }\n };\n Tokenizer.prototype.stateBeforeComment = function (c) {\n if (c === 45 /* Dash */) {\n this._state = 21 /* InCommentLike */;\n this.currentSequence = Sequences.CommentEnd;\n // Allow short comments (eg. )\n this.sequenceIndex = 2;\n this.sectionStart = this._index + 1;\n }\n else {\n this._state = 16 /* InDeclaration */;\n }\n };\n Tokenizer.prototype.stateInSpecialComment = function (c) {\n if (c === 62 /* Gt */ || this.fastForwardTo(62 /* Gt */)) {\n this.cbs.oncomment(this.getSection());\n this._state = 1 /* Text */;\n this.sectionStart = this._index + 1;\n }\n };\n Tokenizer.prototype.stateBeforeSpecialS = function (c) {\n var lower = c | 0x20;\n if (lower === Sequences.ScriptEnd[3]) {\n this.startSpecial(Sequences.ScriptEnd, 4);\n }\n else if (lower === Sequences.StyleEnd[3]) {\n this.startSpecial(Sequences.StyleEnd, 4);\n }\n else {\n this._state = 3 /* InTagName */;\n this.stateInTagName(c); // Consume the token again\n }\n };\n Tokenizer.prototype.stateBeforeEntity = function (c) {\n // Start excess with 1 to include the '&'\n this.entityExcess = 1;\n if (c === 35 /* Num */) {\n this._state = 26 /* BeforeNumericEntity */;\n }\n else if (c === 38 /* Amp */) {\n // We have two `&` characters in a row. Stay in the current state.\n }\n else {\n this.trieIndex = 0;\n this.trieCurrent = this.entityTrie[0];\n this.trieResult = null;\n this._state = 27 /* InNamedEntity */;\n this.stateInNamedEntity(c);\n }\n };\n Tokenizer.prototype.stateInNamedEntity = function (c) {\n this.entityExcess += 1;\n this.trieIndex = (0, decode_1.determineBranch)(this.entityTrie, this.trieCurrent, this.trieIndex + 1, c);\n if (this.trieIndex < 0) {\n this.emitNamedEntity();\n this._index--;\n return;\n }\n this.trieCurrent = this.entityTrie[this.trieIndex];\n // If the branch is a value, store it and continue\n if (this.trieCurrent & decode_1.BinTrieFlags.HAS_VALUE) {\n // If we have a legacy entity while parsing strictly, just skip the number of bytes\n if (!this.allowLegacyEntity() && c !== 59 /* Semi */) {\n // No need to consider multi-byte values, as the legacy entity is always a single byte\n this.trieIndex += 1;\n }\n else {\n // Add 1 as we have already incremented the excess\n var entityStart = this._index - this.entityExcess + 1;\n if (entityStart > this.sectionStart) {\n this.emitPartial(this.buffer.substring(this.sectionStart, entityStart));\n }\n // If this is a surrogate pair, combine the higher bits from the node with the next byte\n this.trieResult =\n this.trieCurrent & decode_1.BinTrieFlags.MULTI_BYTE\n ? String.fromCharCode(this.entityTrie[++this.trieIndex], this.entityTrie[++this.trieIndex])\n : String.fromCharCode(this.entityTrie[++this.trieIndex]);\n this.entityExcess = 0;\n this.sectionStart = this._index + 1;\n }\n }\n };\n Tokenizer.prototype.emitNamedEntity = function () {\n if (this.trieResult) {\n this.emitPartial(this.trieResult);\n }\n this._state = this.baseState;\n };\n Tokenizer.prototype.stateBeforeNumericEntity = function (c) {\n if ((c | 0x20) === 120 /* LowerX */) {\n this.entityExcess++;\n this._state = 29 /* InHexEntity */;\n }\n else {\n this._state = 28 /* InNumericEntity */;\n this.stateInNumericEntity(c);\n }\n };\n Tokenizer.prototype.decodeNumericEntity = function (base, strict) {\n var entityStart = this._index - this.entityExcess - 1;\n var numberStart = entityStart + 2 + (base >> 4);\n if (numberStart !== this._index) {\n // Emit leading data if any\n if (entityStart > this.sectionStart) {\n this.emitPartial(this.buffer.substring(this.sectionStart, entityStart));\n }\n // Parse entity\n var entity = this.buffer.substring(numberStart, this._index);\n var parsed = parseInt(entity, base);\n this.emitPartial((0, decode_codepoint_1.default)(parsed));\n this.sectionStart = this._index + Number(strict);\n }\n this._state = this.baseState;\n };\n Tokenizer.prototype.stateInNumericEntity = function (c) {\n if (c === 59 /* Semi */) {\n this.decodeNumericEntity(10, true);\n }\n else if (!isNumber(c)) {\n if (this.allowLegacyEntity()) {\n this.decodeNumericEntity(10, false);\n }\n else {\n this._state = this.baseState;\n }\n this._index--;\n }\n else {\n this.entityExcess++;\n }\n };\n Tokenizer.prototype.stateInHexEntity = function (c) {\n if (c === 59 /* Semi */) {\n this.decodeNumericEntity(16, true);\n }\n else if ((c < 97 /* LowerA */ || c > 102 /* LowerF */) &&\n (c < 65 /* UpperA */ || c > 70 /* UpperF */) &&\n !isNumber(c)) {\n if (this.allowLegacyEntity()) {\n this.decodeNumericEntity(16, false);\n }\n else {\n this._state = this.baseState;\n }\n this._index--;\n }\n else {\n this.entityExcess++;\n }\n };\n Tokenizer.prototype.allowLegacyEntity = function () {\n return (!this.xmlMode &&\n (this.baseState === 1 /* Text */ ||\n this.baseState === 24 /* InSpecialTag */));\n };\n /**\n * Remove data that has already been consumed from the buffer.\n */\n Tokenizer.prototype.cleanup = function () {\n // If we are inside of text, emit what we already have.\n if (this.running &&\n this.sectionStart !== this._index &&\n (this._state === 1 /* Text */ ||\n (this._state === 24 /* InSpecialTag */ &&\n this.sequenceIndex === 0))) {\n // TODO: We could emit attribute data here as well.\n this.cbs.ontext(this.buffer.substr(this.sectionStart));\n this.sectionStart = this._index;\n }\n var start = this.sectionStart < 0 ? this._index : this.sectionStart;\n this.buffer =\n start === this.buffer.length ? \"\" : this.buffer.substr(start);\n this._index -= start;\n this.bufferOffset += start;\n if (this.sectionStart > 0) {\n this.sectionStart = 0;\n }\n };\n Tokenizer.prototype.shouldContinue = function () {\n return this._index < this.buffer.length && this.running;\n };\n /**\n * Iterates through the buffer, calling the function corresponding to the current state.\n *\n * States that are more likely to be hit are higher up, as a performance improvement.\n */\n Tokenizer.prototype.parse = function () {\n while (this.shouldContinue()) {\n var c = this.buffer.charCodeAt(this._index);\n if (this._state === 1 /* Text */) {\n this.stateText(c);\n }\n else if (this._state === 23 /* SpecialStartSequence */) {\n this.stateSpecialStartSequence(c);\n }\n else if (this._state === 24 /* InSpecialTag */) {\n this.stateInSpecialTag(c);\n }\n else if (this._state === 19 /* CDATASequence */) {\n this.stateCDATASequence(c);\n }\n else if (this._state === 12 /* InAttributeValueDq */) {\n this.stateInAttributeValueDoubleQuotes(c);\n }\n else if (this._state === 9 /* InAttributeName */) {\n this.stateInAttributeName(c);\n }\n else if (this._state === 21 /* InCommentLike */) {\n this.stateInCommentLike(c);\n }\n else if (this._state === 20 /* InSpecialComment */) {\n this.stateInSpecialComment(c);\n }\n else if (this._state === 8 /* BeforeAttributeName */) {\n this.stateBeforeAttributeName(c);\n }\n else if (this._state === 3 /* InTagName */) {\n this.stateInTagName(c);\n }\n else if (this._state === 6 /* InClosingTagName */) {\n this.stateInClosingTagName(c);\n }\n else if (this._state === 2 /* BeforeTagName */) {\n this.stateBeforeTagName(c);\n }\n else if (this._state === 10 /* AfterAttributeName */) {\n this.stateAfterAttributeName(c);\n }\n else if (this._state === 13 /* InAttributeValueSq */) {\n this.stateInAttributeValueSingleQuotes(c);\n }\n else if (this._state === 11 /* BeforeAttributeValue */) {\n this.stateBeforeAttributeValue(c);\n }\n else if (this._state === 5 /* BeforeClosingTagName */) {\n this.stateBeforeClosingTagName(c);\n }\n else if (this._state === 7 /* AfterClosingTagName */) {\n this.stateAfterClosingTagName(c);\n }\n else if (this._state === 22 /* BeforeSpecialS */) {\n this.stateBeforeSpecialS(c);\n }\n else if (this._state === 14 /* InAttributeValueNq */) {\n this.stateInAttributeValueNoQuotes(c);\n }\n else if (this._state === 4 /* InSelfClosingTag */) {\n this.stateInSelfClosingTag(c);\n }\n else if (this._state === 16 /* InDeclaration */) {\n this.stateInDeclaration(c);\n }\n else if (this._state === 15 /* BeforeDeclaration */) {\n this.stateBeforeDeclaration(c);\n }\n else if (this._state === 18 /* BeforeComment */) {\n this.stateBeforeComment(c);\n }\n else if (this._state === 17 /* InProcessingInstruction */) {\n this.stateInProcessingInstruction(c);\n }\n else if (this._state === 27 /* InNamedEntity */) {\n this.stateInNamedEntity(c);\n }\n else if (this._state === 25 /* BeforeEntity */) {\n this.stateBeforeEntity(c);\n }\n else if (this._state === 29 /* InHexEntity */) {\n this.stateInHexEntity(c);\n }\n else if (this._state === 28 /* InNumericEntity */) {\n this.stateInNumericEntity(c);\n }\n else {\n // `this._state === State.BeforeNumericEntity`\n this.stateBeforeNumericEntity(c);\n }\n this._index++;\n }\n this.cleanup();\n };\n Tokenizer.prototype.finish = function () {\n if (this._state === 27 /* InNamedEntity */) {\n this.emitNamedEntity();\n }\n // If there is remaining data, emit it in a reasonable way\n if (this.sectionStart < this._index) {\n this.handleTrailingData();\n }\n this.cbs.onend();\n };\n /** Handle any trailing data. */\n Tokenizer.prototype.handleTrailingData = function () {\n var data = this.buffer.substr(this.sectionStart);\n if (this._state === 21 /* InCommentLike */) {\n if (this.currentSequence === Sequences.CdataEnd) {\n this.cbs.oncdata(data);\n }\n else {\n this.cbs.oncomment(data);\n }\n }\n else if (this._state === 28 /* InNumericEntity */ &&\n this.allowLegacyEntity()) {\n this.decodeNumericEntity(10, false);\n // All trailing data will have been consumed\n }\n else if (this._state === 29 /* InHexEntity */ &&\n this.allowLegacyEntity()) {\n this.decodeNumericEntity(16, false);\n // All trailing data will have been consumed\n }\n else if (this._state === 3 /* InTagName */ ||\n this._state === 8 /* BeforeAttributeName */ ||\n this._state === 11 /* BeforeAttributeValue */ ||\n this._state === 10 /* AfterAttributeName */ ||\n this._state === 9 /* InAttributeName */ ||\n this._state === 13 /* InAttributeValueSq */ ||\n this._state === 12 /* InAttributeValueDq */ ||\n this._state === 14 /* InAttributeValueNq */ ||\n this._state === 6 /* InClosingTagName */) {\n /*\n * If we are currently in an opening or closing tag, us not calling the\n * respective callback signals that the tag should be ignored.\n */\n }\n else {\n this.cbs.ontext(data);\n }\n };\n Tokenizer.prototype.getSection = function () {\n return this.buffer.substring(this.sectionStart, this._index);\n };\n Tokenizer.prototype.emitPartial = function (value) {\n if (this.baseState !== 1 /* Text */ &&\n this.baseState !== 24 /* InSpecialTag */) {\n this.cbs.onattribdata(value);\n }\n else {\n this.cbs.ontext(value);\n }\n };\n return Tokenizer;\n}());\nexports.default = Tokenizer;\n","\"use strict\";\n// Adapted from https://github.com/mathiasbynens/he/blob/36afe179392226cf1b6ccdb16ebbb7a5a844d93a/src/he.js#L106-L134\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar decodeMap = new Map([\n [0, 65533],\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]);\nvar fromCodePoint = \n// eslint-disable-next-line @typescript-eslint/no-unnecessary-condition, node/no-unsupported-features/es-builtins\nString.fromCodePoint ||\n 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 };\nfunction decodeCodePoint(codePoint) {\n var _a;\n if ((codePoint >= 0xd800 && codePoint <= 0xdfff) || codePoint > 0x10ffff) {\n return \"\\uFFFD\";\n }\n return fromCodePoint((_a = decodeMap.get(codePoint)) !== null && _a !== void 0 ? _a : codePoint);\n}\nexports.default = decodeCodePoint;\n","\"use strict\";\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.decodeXML = exports.decodeHTMLStrict = exports.decodeHTML = exports.determineBranch = exports.JUMP_OFFSET_BASE = exports.BinTrieFlags = exports.xmlDecodeTree = exports.htmlDecodeTree = void 0;\nvar decode_data_html_1 = __importDefault(require(\"./generated/decode-data-html\"));\nexports.htmlDecodeTree = decode_data_html_1.default;\nvar decode_data_xml_1 = __importDefault(require(\"./generated/decode-data-xml\"));\nexports.xmlDecodeTree = decode_data_xml_1.default;\nvar decode_codepoint_1 = __importDefault(require(\"./decode_codepoint\"));\nvar BinTrieFlags;\n(function (BinTrieFlags) {\n BinTrieFlags[BinTrieFlags[\"HAS_VALUE\"] = 32768] = \"HAS_VALUE\";\n BinTrieFlags[BinTrieFlags[\"BRANCH_LENGTH\"] = 32512] = \"BRANCH_LENGTH\";\n BinTrieFlags[BinTrieFlags[\"MULTI_BYTE\"] = 128] = \"MULTI_BYTE\";\n BinTrieFlags[BinTrieFlags[\"JUMP_TABLE\"] = 127] = \"JUMP_TABLE\";\n})(BinTrieFlags = exports.BinTrieFlags || (exports.BinTrieFlags = {}));\nexports.JUMP_OFFSET_BASE = 48 /* ZERO */ - 1;\nfunction getDecoder(decodeTree) {\n return function decodeHTMLBinary(str, strict) {\n var ret = \"\";\n var lastIdx = 0;\n var strIdx = 0;\n while ((strIdx = str.indexOf(\"&\", strIdx)) >= 0) {\n ret += str.slice(lastIdx, strIdx);\n lastIdx = strIdx;\n // Skip the \"&\"\n strIdx += 1;\n // If we have a numeric entity, handle this separately.\n if (str.charCodeAt(strIdx) === 35 /* NUM */) {\n // Skip the leading \"&#\". For hex entities, also skip the leading \"x\".\n var start = strIdx + 1;\n var base = 10;\n var cp = str.charCodeAt(start);\n if ((cp | 32 /* To_LOWER_BIT */) === 120 /* LOWER_X */) {\n base = 16;\n strIdx += 1;\n start += 1;\n }\n while (((cp = str.charCodeAt(++strIdx)) >= 48 /* ZERO */ &&\n cp <= 57 /* NINE */) ||\n (base === 16 &&\n (cp | 32 /* To_LOWER_BIT */) >= 97 /* LOWER_A */ &&\n (cp | 32 /* To_LOWER_BIT */) <= 102 /* LOWER_F */))\n ;\n if (start !== strIdx) {\n var entity = str.substring(start, strIdx);\n var parsed = parseInt(entity, base);\n if (str.charCodeAt(strIdx) === 59 /* SEMI */) {\n strIdx += 1;\n }\n else if (strict) {\n continue;\n }\n ret += decode_codepoint_1.default(parsed);\n lastIdx = strIdx;\n }\n continue;\n }\n var result = null;\n var excess = 1;\n var treeIdx = 0;\n var current = decodeTree[treeIdx];\n for (; strIdx < str.length; strIdx++, excess++) {\n treeIdx = determineBranch(decodeTree, current, treeIdx + 1, str.charCodeAt(strIdx));\n if (treeIdx < 0)\n break;\n current = decodeTree[treeIdx];\n // If the branch is a value, store it and continue\n if (current & BinTrieFlags.HAS_VALUE) {\n // If we have a legacy entity while parsing strictly, just skip the number of bytes\n if (strict && str.charCodeAt(strIdx) !== 59 /* SEMI */) {\n // No need to consider multi-byte values, as the legacy entity is always a single byte\n treeIdx += 1;\n }\n else {\n // If this is a surrogate pair, combine the higher bits from the node with the next byte\n result =\n current & BinTrieFlags.MULTI_BYTE\n ? String.fromCharCode(decodeTree[++treeIdx], decodeTree[++treeIdx])\n : String.fromCharCode(decodeTree[++treeIdx]);\n excess = 0;\n }\n }\n }\n if (result != null) {\n ret += result;\n lastIdx = strIdx - excess + 1;\n }\n }\n return ret + str.slice(lastIdx);\n };\n}\nfunction determineBranch(decodeTree, current, nodeIdx, char) {\n if (current <= 128) {\n return char === current ? nodeIdx : -1;\n }\n var branchCount = (current & BinTrieFlags.BRANCH_LENGTH) >> 8;\n if (branchCount === 0) {\n return -1;\n }\n if (branchCount === 1) {\n return char === decodeTree[nodeIdx] ? nodeIdx + 1 : -1;\n }\n var jumpOffset = current & BinTrieFlags.JUMP_TABLE;\n if (jumpOffset) {\n var value = char - exports.JUMP_OFFSET_BASE - jumpOffset;\n return value < 0 || value > branchCount\n ? -1\n : decodeTree[nodeIdx + value] - 1;\n }\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 }\n else if (midVal > char) {\n hi = mid - 1;\n }\n else {\n return decodeTree[mid + branchCount];\n }\n }\n return -1;\n}\nexports.determineBranch = determineBranch;\nvar htmlDecoder = getDecoder(decode_data_html_1.default);\nvar xmlDecoder = getDecoder(decode_data_xml_1.default);\nfunction decodeHTML(str) {\n return htmlDecoder(str, false);\n}\nexports.decodeHTML = decodeHTML;\nfunction decodeHTMLStrict(str) {\n return htmlDecoder(str, true);\n}\nexports.decodeHTMLStrict = decodeHTMLStrict;\nfunction decodeXML(str) {\n return xmlDecoder(str, true);\n}\nexports.decodeXML = decodeXML;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\n// Generated using scripts/write-decode-map.ts\n// prettier-ignore\nexports.default = new Uint16Array([14866, 60, 237, 340, 721, 1312, 1562, 1654, 1838, 1957, 2183, 2239, 2301, 2958, 3037, 3893, 4123, 4298, 4330, 4801, 5191, 5395, 5752, 5903, 5943, 5972, 6050, 0, 0, 0, 0, 0, 0, 6135, 6565, 7422, 8183, 8738, 9242, 9503, 9938, 10189, 10573, 10637, 10715, 11950, 12246, 13539, 13950, 14445, 14533, 15364, 16514, 16980, 17390, 17763, 17849, 18036, 18125, 4096, 69, 77, 97, 98, 99, 102, 103, 108, 109, 110, 111, 112, 114, 115, 116, 117, 92, 100, 106, 115, 122, 137, 142, 151, 157, 163, 167, 182, 196, 204, 220, 229, 108, 105, 103, 33024, 198, 59, 32768, 198, 80, 33024, 38, 59, 32768, 38, 99, 117, 116, 101, 33024, 193, 59, 32768, 193, 114, 101, 118, 101, 59, 32768, 258, 512, 105, 121, 127, 134, 114, 99, 33024, 194, 59, 32768, 194, 59, 32768, 1040, 114, 59, 32896, 55349, 56580, 114, 97, 118, 101, 33024, 192, 59, 32768, 192, 112, 104, 97, 59, 32768, 913, 97, 99, 114, 59, 32768, 256, 100, 59, 32768, 10835, 512, 103, 112, 172, 177, 111, 110, 59, 32768, 260, 102, 59, 32896, 55349, 56632, 112, 108, 121, 70, 117, 110, 99, 116, 105, 111, 110, 59, 32768, 8289, 105, 110, 103, 33024, 197, 59, 32768, 197, 512, 99, 115, 209, 214, 114, 59, 32896, 55349, 56476, 105, 103, 110, 59, 32768, 8788, 105, 108, 100, 101, 33024, 195, 59, 32768, 195, 109, 108, 33024, 196, 59, 32768, 196, 2048, 97, 99, 101, 102, 111, 114, 115, 117, 253, 278, 282, 310, 315, 321, 327, 332, 512, 99, 114, 258, 267, 107, 115, 108, 97, 115, 104, 59, 32768, 8726, 583, 271, 274, 59, 32768, 10983, 101, 100, 59, 32768, 8966, 121, 59, 32768, 1041, 768, 99, 114, 116, 289, 296, 306, 97, 117, 115, 101, 59, 32768, 8757, 110, 111, 117, 108, 108, 105, 115, 59, 32768, 8492, 97, 59, 32768, 914, 114, 59, 32896, 55349, 56581, 112, 102, 59, 32896, 55349, 56633, 101, 118, 101, 59, 32768, 728, 99, 114, 59, 32768, 8492, 109, 112, 101, 113, 59, 32768, 8782, 3584, 72, 79, 97, 99, 100, 101, 102, 104, 105, 108, 111, 114, 115, 117, 368, 373, 380, 426, 461, 466, 487, 491, 495, 533, 593, 695, 701, 707, 99, 121, 59, 32768, 1063, 80, 89, 33024, 169, 59, 32768, 169, 768, 99, 112, 121, 387, 393, 419, 117, 116, 101, 59, 32768, 262, 512, 59, 105, 398, 400, 32768, 8914, 116, 97, 108, 68, 105, 102, 102, 101, 114, 101, 110, 116, 105, 97, 108, 68, 59, 32768, 8517, 108, 101, 121, 115, 59, 32768, 8493, 1024, 97, 101, 105, 111, 435, 441, 449, 454, 114, 111, 110, 59, 32768, 268, 100, 105, 108, 33024, 199, 59, 32768, 199, 114, 99, 59, 32768, 264, 110, 105, 110, 116, 59, 32768, 8752, 111, 116, 59, 32768, 266, 512, 100, 110, 471, 478, 105, 108, 108, 97, 59, 32768, 184, 116, 101, 114, 68, 111, 116, 59, 32768, 183, 114, 59, 32768, 8493, 105, 59, 32768, 935, 114, 99, 108, 101, 1024, 68, 77, 80, 84, 508, 513, 520, 526, 111, 116, 59, 32768, 8857, 105, 110, 117, 115, 59, 32768, 8854, 108, 117, 115, 59, 32768, 8853, 105, 109, 101, 115, 59, 32768, 8855, 111, 512, 99, 115, 539, 562, 107, 119, 105, 115, 101, 67, 111, 110, 116, 111, 117, 114, 73, 110, 116, 101, 103, 114, 97, 108, 59, 32768, 8754, 101, 67, 117, 114, 108, 121, 512, 68, 81, 573, 586, 111, 117, 98, 108, 101, 81, 117, 111, 116, 101, 59, 32768, 8221, 117, 111, 116, 101, 59, 32768, 8217, 1024, 108, 110, 112, 117, 602, 614, 648, 664, 111, 110, 512, 59, 101, 609, 611, 32768, 8759, 59, 32768, 10868, 768, 103, 105, 116, 621, 629, 634, 114, 117, 101, 110, 116, 59, 32768, 8801, 110, 116, 59, 32768, 8751, 111, 117, 114, 73, 110, 116, 101, 103, 114, 97, 108, 59, 32768, 8750, 512, 102, 114, 653, 656, 59, 32768, 8450, 111, 100, 117, 99, 116, 59, 32768, 8720, 110, 116, 101, 114, 67, 108, 111, 99, 107, 119, 105, 115, 101, 67, 111, 110, 116, 111, 117, 114, 73, 110, 116, 101, 103, 114, 97, 108, 59, 32768, 8755, 111, 115, 115, 59, 32768, 10799, 99, 114, 59, 32896, 55349, 56478, 112, 512, 59, 67, 713, 715, 32768, 8915, 97, 112, 59, 32768, 8781, 2816, 68, 74, 83, 90, 97, 99, 101, 102, 105, 111, 115, 743, 758, 763, 768, 773, 795, 809, 821, 826, 910, 1295, 512, 59, 111, 748, 750, 32768, 8517, 116, 114, 97, 104, 100, 59, 32768, 10513, 99, 121, 59, 32768, 1026, 99, 121, 59, 32768, 1029, 99, 121, 59, 32768, 1039, 768, 103, 114, 115, 780, 786, 790, 103, 101, 114, 59, 32768, 8225, 114, 59, 32768, 8609, 104, 118, 59, 32768, 10980, 512, 97, 121, 800, 806, 114, 111, 110, 59, 32768, 270, 59, 32768, 1044, 108, 512, 59, 116, 815, 817, 32768, 8711, 97, 59, 32768, 916, 114, 59, 32896, 55349, 56583, 512, 97, 102, 831, 897, 512, 99, 109, 836, 891, 114, 105, 116, 105, 99, 97, 108, 1024, 65, 68, 71, 84, 852, 859, 877, 884, 99, 117, 116, 101, 59, 32768, 180, 111, 581, 864, 867, 59, 32768, 729, 98, 108, 101, 65, 99, 117, 116, 101, 59, 32768, 733, 114, 97, 118, 101, 59, 32768, 96, 105, 108, 100, 101, 59, 32768, 732, 111, 110, 100, 59, 32768, 8900, 102, 101, 114, 101, 110, 116, 105, 97, 108, 68, 59, 32768, 8518, 2113, 920, 0, 0, 0, 925, 946, 0, 1139, 102, 59, 32896, 55349, 56635, 768, 59, 68, 69, 931, 933, 938, 32768, 168, 111, 116, 59, 32768, 8412, 113, 117, 97, 108, 59, 32768, 8784, 98, 108, 101, 1536, 67, 68, 76, 82, 85, 86, 961, 978, 996, 1080, 1101, 1125, 111, 110, 116, 111, 117, 114, 73, 110, 116, 101, 103, 114, 97, 108, 59, 32768, 8751, 111, 1093, 985, 0, 0, 988, 59, 32768, 168, 110, 65, 114, 114, 111, 119, 59, 32768, 8659, 512, 101, 111, 1001, 1034, 102, 116, 768, 65, 82, 84, 1010, 1017, 1029, 114, 114, 111, 119, 59, 32768, 8656, 105, 103, 104, 116, 65, 114, 114, 111, 119, 59, 32768, 8660, 101, 101, 59, 32768, 10980, 110, 103, 512, 76, 82, 1041, 1068, 101, 102, 116, 512, 65, 82, 1049, 1056, 114, 114, 111, 119, 59, 32768, 10232, 105, 103, 104, 116, 65, 114, 114, 111, 119, 59, 32768, 10234, 105, 103, 104, 116, 65, 114, 114, 111, 119, 59, 32768, 10233, 105, 103, 104, 116, 512, 65, 84, 1089, 1096, 114, 114, 111, 119, 59, 32768, 8658, 101, 101, 59, 32768, 8872, 112, 1042, 1108, 0, 0, 1115, 114, 114, 111, 119, 59, 32768, 8657, 111, 119, 110, 65, 114, 114, 111, 119, 59, 32768, 8661, 101, 114, 116, 105, 99, 97, 108, 66, 97, 114, 59, 32768, 8741, 110, 1536, 65, 66, 76, 82, 84, 97, 1152, 1179, 1186, 1236, 1272, 1288, 114, 114, 111, 119, 768, 59, 66, 85, 1163, 1165, 1170, 32768, 8595, 97, 114, 59, 32768, 10515, 112, 65, 114, 114, 111, 119, 59, 32768, 8693, 114, 101, 118, 101, 59, 32768, 785, 101, 102, 116, 1315, 1196, 0, 1209, 0, 1220, 105, 103, 104, 116, 86, 101, 99, 116, 111, 114, 59, 32768, 10576, 101, 101, 86, 101, 99, 116, 111, 114, 59, 32768, 10590, 101, 99, 116, 111, 114, 512, 59, 66, 1229, 1231, 32768, 8637, 97, 114, 59, 32768, 10582, 105, 103, 104, 116, 805, 1245, 0, 1256, 101, 101, 86, 101, 99, 116, 111, 114, 59, 32768, 10591, 101, 99, 116, 111, 114, 512, 59, 66, 1265, 1267, 32768, 8641, 97, 114, 59, 32768, 10583, 101, 101, 512, 59, 65, 1279, 1281, 32768, 8868, 114, 114, 111, 119, 59, 32768, 8615, 114, 114, 111, 119, 59, 32768, 8659, 512, 99, 116, 1300, 1305, 114, 59, 32896, 55349, 56479, 114, 111, 107, 59, 32768, 272, 4096, 78, 84, 97, 99, 100, 102, 103, 108, 109, 111, 112, 113, 115, 116, 117, 120, 1344, 1348, 1354, 1363, 1386, 1391, 1396, 1405, 1413, 1460, 1475, 1483, 1514, 1527, 1531, 1538, 71, 59, 32768, 330, 72, 33024, 208, 59, 32768, 208, 99, 117, 116, 101, 33024, 201, 59, 32768, 201, 768, 97, 105, 121, 1370, 1376, 1383, 114, 111, 110, 59, 32768, 282, 114, 99, 33024, 202, 59, 32768, 202, 59, 32768, 1069, 111, 116, 59, 32768, 278, 114, 59, 32896, 55349, 56584, 114, 97, 118, 101, 33024, 200, 59, 32768, 200, 101, 109, 101, 110, 116, 59, 32768, 8712, 512, 97, 112, 1418, 1423, 99, 114, 59, 32768, 274, 116, 121, 1060, 1431, 0, 0, 1444, 109, 97, 108, 108, 83, 113, 117, 97, 114, 101, 59, 32768, 9723, 101, 114, 121, 83, 109, 97, 108, 108, 83, 113, 117, 97, 114, 101, 59, 32768, 9643, 512, 103, 112, 1465, 1470, 111, 110, 59, 32768, 280, 102, 59, 32896, 55349, 56636, 115, 105, 108, 111, 110, 59, 32768, 917, 117, 512, 97, 105, 1489, 1504, 108, 512, 59, 84, 1495, 1497, 32768, 10869, 105, 108, 100, 101, 59, 32768, 8770, 108, 105, 98, 114, 105, 117, 109, 59, 32768, 8652, 512, 99, 105, 1519, 1523, 114, 59, 32768, 8496, 109, 59, 32768, 10867, 97, 59, 32768, 919, 109, 108, 33024, 203, 59, 32768, 203, 512, 105, 112, 1543, 1549, 115, 116, 115, 59, 32768, 8707, 111, 110, 101, 110, 116, 105, 97, 108, 69, 59, 32768, 8519, 1280, 99, 102, 105, 111, 115, 1572, 1576, 1581, 1620, 1648, 121, 59, 32768, 1060, 114, 59, 32896, 55349, 56585, 108, 108, 101, 100, 1060, 1591, 0, 0, 1604, 109, 97, 108, 108, 83, 113, 117, 97, 114, 101, 59, 32768, 9724, 101, 114, 121, 83, 109, 97, 108, 108, 83, 113, 117, 97, 114, 101, 59, 32768, 9642, 1601, 1628, 0, 1633, 0, 0, 1639, 102, 59, 32896, 55349, 56637, 65, 108, 108, 59, 32768, 8704, 114, 105, 101, 114, 116, 114, 102, 59, 32768, 8497, 99, 114, 59, 32768, 8497, 3072, 74, 84, 97, 98, 99, 100, 102, 103, 111, 114, 115, 116, 1678, 1683, 1688, 1701, 1708, 1729, 1734, 1739, 1742, 1748, 1828, 1834, 99, 121, 59, 32768, 1027, 33024, 62, 59, 32768, 62, 109, 109, 97, 512, 59, 100, 1696, 1698, 32768, 915, 59, 32768, 988, 114, 101, 118, 101, 59, 32768, 286, 768, 101, 105, 121, 1715, 1721, 1726, 100, 105, 108, 59, 32768, 290, 114, 99, 59, 32768, 284, 59, 32768, 1043, 111, 116, 59, 32768, 288, 114, 59, 32896, 55349, 56586, 59, 32768, 8921, 112, 102, 59, 32896, 55349, 56638, 101, 97, 116, 101, 114, 1536, 69, 70, 71, 76, 83, 84, 1766, 1783, 1794, 1803, 1809, 1821, 113, 117, 97, 108, 512, 59, 76, 1775, 1777, 32768, 8805, 101, 115, 115, 59, 32768, 8923, 117, 108, 108, 69, 113, 117, 97, 108, 59, 32768, 8807, 114, 101, 97, 116, 101, 114, 59, 32768, 10914, 101, 115, 115, 59, 32768, 8823, 108, 97, 110, 116, 69, 113, 117, 97, 108, 59, 32768, 10878, 105, 108, 100, 101, 59, 32768, 8819, 99, 114, 59, 32896, 55349, 56482, 59, 32768, 8811, 2048, 65, 97, 99, 102, 105, 111, 115, 117, 1854, 1861, 1874, 1880, 1884, 1897, 1919, 1934, 82, 68, 99, 121, 59, 32768, 1066, 512, 99, 116, 1866, 1871, 101, 107, 59, 32768, 711, 59, 32768, 94, 105, 114, 99, 59, 32768, 292, 114, 59, 32768, 8460, 108, 98, 101, 114, 116, 83, 112, 97, 99, 101, 59, 32768, 8459, 833, 1902, 0, 1906, 102, 59, 32768, 8461, 105, 122, 111, 110, 116, 97, 108, 76, 105, 110, 101, 59, 32768, 9472, 512, 99, 116, 1924, 1928, 114, 59, 32768, 8459, 114, 111, 107, 59, 32768, 294, 109, 112, 533, 1940, 1950, 111, 119, 110, 72, 117, 109, 112, 59, 32768, 8782, 113, 117, 97, 108, 59, 32768, 8783, 3584, 69, 74, 79, 97, 99, 100, 102, 103, 109, 110, 111, 115, 116, 117, 1985, 1990, 1996, 2001, 2010, 2025, 2030, 2034, 2043, 2077, 2134, 2155, 2160, 2167, 99, 121, 59, 32768, 1045, 108, 105, 103, 59, 32768, 306, 99, 121, 59, 32768, 1025, 99, 117, 116, 101, 33024, 205, 59, 32768, 205, 512, 105, 121, 2015, 2022, 114, 99, 33024, 206, 59, 32768, 206, 59, 32768, 1048, 111, 116, 59, 32768, 304, 114, 59, 32768, 8465, 114, 97, 118, 101, 33024, 204, 59, 32768, 204, 768, 59, 97, 112, 2050, 2052, 2070, 32768, 8465, 512, 99, 103, 2057, 2061, 114, 59, 32768, 298, 105, 110, 97, 114, 121, 73, 59, 32768, 8520, 108, 105, 101, 115, 59, 32768, 8658, 837, 2082, 0, 2110, 512, 59, 101, 2086, 2088, 32768, 8748, 512, 103, 114, 2093, 2099, 114, 97, 108, 59, 32768, 8747, 115, 101, 99, 116, 105, 111, 110, 59, 32768, 8898, 105, 115, 105, 98, 108, 101, 512, 67, 84, 2120, 2127, 111, 109, 109, 97, 59, 32768, 8291, 105, 109, 101, 115, 59, 32768, 8290, 768, 103, 112, 116, 2141, 2146, 2151, 111, 110, 59, 32768, 302, 102, 59, 32896, 55349, 56640, 97, 59, 32768, 921, 99, 114, 59, 32768, 8464, 105, 108, 100, 101, 59, 32768, 296, 828, 2172, 0, 2177, 99, 121, 59, 32768, 1030, 108, 33024, 207, 59, 32768, 207, 1280, 99, 102, 111, 115, 117, 2193, 2206, 2211, 2217, 2232, 512, 105, 121, 2198, 2203, 114, 99, 59, 32768, 308, 59, 32768, 1049, 114, 59, 32896, 55349, 56589, 112, 102, 59, 32896, 55349, 56641, 820, 2222, 0, 2227, 114, 59, 32896, 55349, 56485, 114, 99, 121, 59, 32768, 1032, 107, 99, 121, 59, 32768, 1028, 1792, 72, 74, 97, 99, 102, 111, 115, 2253, 2258, 2263, 2269, 2283, 2288, 2294, 99, 121, 59, 32768, 1061, 99, 121, 59, 32768, 1036, 112, 112, 97, 59, 32768, 922, 512, 101, 121, 2274, 2280, 100, 105, 108, 59, 32768, 310, 59, 32768, 1050, 114, 59, 32896, 55349, 56590, 112, 102, 59, 32896, 55349, 56642, 99, 114, 59, 32896, 55349, 56486, 2816, 74, 84, 97, 99, 101, 102, 108, 109, 111, 115, 116, 2323, 2328, 2333, 2374, 2396, 2775, 2780, 2797, 2804, 2934, 2954, 99, 121, 59, 32768, 1033, 33024, 60, 59, 32768, 60, 1280, 99, 109, 110, 112, 114, 2344, 2350, 2356, 2360, 2370, 117, 116, 101, 59, 32768, 313, 98, 100, 97, 59, 32768, 923, 103, 59, 32768, 10218, 108, 97, 99, 101, 116, 114, 102, 59, 32768, 8466, 114, 59, 32768, 8606, 768, 97, 101, 121, 2381, 2387, 2393, 114, 111, 110, 59, 32768, 317, 100, 105, 108, 59, 32768, 315, 59, 32768, 1051, 512, 102, 115, 2401, 2702, 116, 2560, 65, 67, 68, 70, 82, 84, 85, 86, 97, 114, 2423, 2470, 2479, 2530, 2537, 2561, 2618, 2666, 2683, 2690, 512, 110, 114, 2428, 2441, 103, 108, 101, 66, 114, 97, 99, 107, 101, 116, 59, 32768, 10216, 114, 111, 119, 768, 59, 66, 82, 2451, 2453, 2458, 32768, 8592, 97, 114, 59, 32768, 8676, 105, 103, 104, 116, 65, 114, 114, 111, 119, 59, 32768, 8646, 101, 105, 108, 105, 110, 103, 59, 32768, 8968, 111, 838, 2485, 0, 2498, 98, 108, 101, 66, 114, 97, 99, 107, 101, 116, 59, 32768, 10214, 110, 805, 2503, 0, 2514, 101, 101, 86, 101, 99, 116, 111, 114, 59, 32768, 10593, 101, 99, 116, 111, 114, 512, 59, 66, 2523, 2525, 32768, 8643, 97, 114, 59, 32768, 10585, 108, 111, 111, 114, 59, 32768, 8970, 105, 103, 104, 116, 512, 65, 86, 2546, 2553, 114, 114, 111, 119, 59, 32768, 8596, 101, 99, 116, 111, 114, 59, 32768, 10574, 512, 101, 114, 2566, 2591, 101, 768, 59, 65, 86, 2574, 2576, 2583, 32768, 8867, 114, 114, 111, 119, 59, 32768, 8612, 101, 99, 116, 111, 114, 59, 32768, 10586, 105, 97, 110, 103, 108, 101, 768, 59, 66, 69, 2604, 2606, 2611, 32768, 8882, 97, 114, 59, 32768, 10703, 113, 117, 97, 108, 59, 32768, 8884, 112, 768, 68, 84, 86, 2626, 2638, 2649, 111, 119, 110, 86, 101, 99, 116, 111, 114, 59, 32768, 10577, 101, 101, 86, 101, 99, 116, 111, 114, 59, 32768, 10592, 101, 99, 116, 111, 114, 512, 59, 66, 2659, 2661, 32768, 8639, 97, 114, 59, 32768, 10584, 101, 99, 116, 111, 114, 512, 59, 66, 2676, 2678, 32768, 8636, 97, 114, 59, 32768, 10578, 114, 114, 111, 119, 59, 32768, 8656, 105, 103, 104, 116, 97, 114, 114, 111, 119, 59, 32768, 8660, 115, 1536, 69, 70, 71, 76, 83, 84, 2716, 2730, 2741, 2750, 2756, 2768, 113, 117, 97, 108, 71, 114, 101, 97, 116, 101, 114, 59, 32768, 8922, 117, 108, 108, 69, 113, 117, 97, 108, 59, 32768, 8806, 114, 101, 97, 116, 101, 114, 59, 32768, 8822, 101, 115, 115, 59, 32768, 10913, 108, 97, 110, 116, 69, 113, 117, 97, 108, 59, 32768, 10877, 105, 108, 100, 101, 59, 32768, 8818, 114, 59, 32896, 55349, 56591, 512, 59, 101, 2785, 2787, 32768, 8920, 102, 116, 97, 114, 114, 111, 119, 59, 32768, 8666, 105, 100, 111, 116, 59, 32768, 319, 768, 110, 112, 119, 2811, 2899, 2904, 103, 1024, 76, 82, 108, 114, 2821, 2848, 2860, 2887, 101, 102, 116, 512, 65, 82, 2829, 2836, 114, 114, 111, 119, 59, 32768, 10229, 105, 103, 104, 116, 65, 114, 114, 111, 119, 59, 32768, 10231, 105, 103, 104, 116, 65, 114, 114, 111, 119, 59, 32768, 10230, 101, 102, 116, 512, 97, 114, 2868, 2875, 114, 114, 111, 119, 59, 32768, 10232, 105, 103, 104, 116, 97, 114, 114, 111, 119, 59, 32768, 10234, 105, 103, 104, 116, 97, 114, 114, 111, 119, 59, 32768, 10233, 102, 59, 32896, 55349, 56643, 101, 114, 512, 76, 82, 2911, 2922, 101, 102, 116, 65, 114, 114, 111, 119, 59, 32768, 8601, 105, 103, 104, 116, 65, 114, 114, 111, 119, 59, 32768, 8600, 768, 99, 104, 116, 2941, 2945, 2948, 114, 59, 32768, 8466, 59, 32768, 8624, 114, 111, 107, 59, 32768, 321, 59, 32768, 8810, 2048, 97, 99, 101, 102, 105, 111, 115, 117, 2974, 2978, 2982, 3007, 3012, 3022, 3028, 3033, 112, 59, 32768, 10501, 121, 59, 32768, 1052, 512, 100, 108, 2987, 2998, 105, 117, 109, 83, 112, 97, 99, 101, 59, 32768, 8287, 108, 105, 110, 116, 114, 102, 59, 32768, 8499, 114, 59, 32896, 55349, 56592, 110, 117, 115, 80, 108, 117, 115, 59, 32768, 8723, 112, 102, 59, 32896, 55349, 56644, 99, 114, 59, 32768, 8499, 59, 32768, 924, 2304, 74, 97, 99, 101, 102, 111, 115, 116, 117, 3055, 3060, 3067, 3089, 3201, 3206, 3874, 3880, 3889, 99, 121, 59, 32768, 1034, 99, 117, 116, 101, 59, 32768, 323, 768, 97, 101, 121, 3074, 3080, 3086, 114, 111, 110, 59, 32768, 327, 100, 105, 108, 59, 32768, 325, 59, 32768, 1053, 768, 103, 115, 119, 3096, 3160, 3194, 97, 116, 105, 118, 101, 768, 77, 84, 86, 3108, 3121, 3145, 101, 100, 105, 117, 109, 83, 112, 97, 99, 101, 59, 32768, 8203, 104, 105, 512, 99, 110, 3128, 3137, 107, 83, 112, 97, 99, 101, 59, 32768, 8203, 83, 112, 97, 99, 101, 59, 32768, 8203, 101, 114, 121, 84, 104, 105, 110, 83, 112, 97, 99, 101, 59, 32768, 8203, 116, 101, 100, 512, 71, 76, 3168, 3184, 114, 101, 97, 116, 101, 114, 71, 114, 101, 97, 116, 101, 114, 59, 32768, 8811, 101, 115, 115, 76, 101, 115, 115, 59, 32768, 8810, 76, 105, 110, 101, 59, 32768, 10, 114, 59, 32896, 55349, 56593, 1024, 66, 110, 112, 116, 3215, 3222, 3238, 3242, 114, 101, 97, 107, 59, 32768, 8288, 66, 114, 101, 97, 107, 105, 110, 103, 83, 112, 97, 99, 101, 59, 32768, 160, 102, 59, 32768, 8469, 3328, 59, 67, 68, 69, 71, 72, 76, 78, 80, 82, 83, 84, 86, 3269, 3271, 3293, 3312, 3352, 3430, 3455, 3551, 3589, 3625, 3678, 3821, 3861, 32768, 10988, 512, 111, 117, 3276, 3286, 110, 103, 114, 117, 101, 110, 116, 59, 32768, 8802, 112, 67, 97, 112, 59, 32768, 8813, 111, 117, 98, 108, 101, 86, 101, 114, 116, 105, 99, 97, 108, 66, 97, 114, 59, 32768, 8742, 768, 108, 113, 120, 3319, 3327, 3345, 101, 109, 101, 110, 116, 59, 32768, 8713, 117, 97, 108, 512, 59, 84, 3335, 3337, 32768, 8800, 105, 108, 100, 101, 59, 32896, 8770, 824, 105, 115, 116, 115, 59, 32768, 8708, 114, 101, 97, 116, 101, 114, 1792, 59, 69, 70, 71, 76, 83, 84, 3373, 3375, 3382, 3394, 3404, 3410, 3423, 32768, 8815, 113, 117, 97, 108, 59, 32768, 8817, 117, 108, 108, 69, 113, 117, 97, 108, 59, 32896, 8807, 824, 114, 101, 97, 116, 101, 114, 59, 32896, 8811, 824, 101, 115, 115, 59, 32768, 8825, 108, 97, 110, 116, 69, 113, 117, 97, 108, 59, 32896, 10878, 824, 105, 108, 100, 101, 59, 32768, 8821, 117, 109, 112, 533, 3437, 3448, 111, 119, 110, 72, 117, 109, 112, 59, 32896, 8782, 824, 113, 117, 97, 108, 59, 32896, 8783, 824, 101, 512, 102, 115, 3461, 3492, 116, 84, 114, 105, 97, 110, 103, 108, 101, 768, 59, 66, 69, 3477, 3479, 3485, 32768, 8938, 97, 114, 59, 32896, 10703, 824, 113, 117, 97, 108, 59, 32768, 8940, 115, 1536, 59, 69, 71, 76, 83, 84, 3506, 3508, 3515, 3524, 3531, 3544, 32768, 8814, 113, 117, 97, 108, 59, 32768, 8816, 114, 101, 97, 116, 101, 114, 59, 32768, 8824, 101, 115, 115, 59, 32896, 8810, 824, 108, 97, 110, 116, 69, 113, 117, 97, 108, 59, 32896, 10877, 824, 105, 108, 100, 101, 59, 32768, 8820, 101, 115, 116, 101, 100, 512, 71, 76, 3561, 3578, 114, 101, 97, 116, 101, 114, 71, 114, 101, 97, 116, 101, 114, 59, 32896, 10914, 824, 101, 115, 115, 76, 101, 115, 115, 59, 32896, 10913, 824, 114, 101, 99, 101, 100, 101, 115, 768, 59, 69, 83, 3603, 3605, 3613, 32768, 8832, 113, 117, 97, 108, 59, 32896, 10927, 824, 108, 97, 110, 116, 69, 113, 117, 97, 108, 59, 32768, 8928, 512, 101, 105, 3630, 3645, 118, 101, 114, 115, 101, 69, 108, 101, 109, 101, 110, 116, 59, 32768, 8716, 103, 104, 116, 84, 114, 105, 97, 110, 103, 108, 101, 768, 59, 66, 69, 3663, 3665, 3671, 32768, 8939, 97, 114, 59, 32896, 10704, 824, 113, 117, 97, 108, 59, 32768, 8941, 512, 113, 117, 3683, 3732, 117, 97, 114, 101, 83, 117, 512, 98, 112, 3694, 3712, 115, 101, 116, 512, 59, 69, 3702, 3705, 32896, 8847, 824, 113, 117, 97, 108, 59, 32768, 8930, 101, 114, 115, 101, 116, 512, 59, 69, 3722, 3725, 32896, 8848, 824, 113, 117, 97, 108, 59, 32768, 8931, 768, 98, 99, 112, 3739, 3757, 3801, 115, 101, 116, 512, 59, 69, 3747, 3750, 32896, 8834, 8402, 113, 117, 97, 108, 59, 32768, 8840, 99, 101, 101, 100, 115, 1024, 59, 69, 83, 84, 3771, 3773, 3781, 3793, 32768, 8833, 113, 117, 97, 108, 59, 32896, 10928, 824, 108, 97, 110, 116, 69, 113, 117, 97, 108, 59, 32768, 8929, 105, 108, 100, 101, 59, 32896, 8831, 824, 101, 114, 115, 101, 116, 512, 59, 69, 3811, 3814, 32896, 8835, 8402, 113, 117, 97, 108, 59, 32768, 8841, 105, 108, 100, 101, 1024, 59, 69, 70, 84, 3834, 3836, 3843, 3854, 32768, 8769, 113, 117, 97, 108, 59, 32768, 8772, 117, 108, 108, 69, 113, 117, 97, 108, 59, 32768, 8775, 105, 108, 100, 101, 59, 32768, 8777, 101, 114, 116, 105, 99, 97, 108, 66, 97, 114, 59, 32768, 8740, 99, 114, 59, 32896, 55349, 56489, 105, 108, 100, 101, 33024, 209, 59, 32768, 209, 59, 32768, 925, 3584, 69, 97, 99, 100, 102, 103, 109, 111, 112, 114, 115, 116, 117, 118, 3921, 3927, 3936, 3951, 3958, 3963, 3972, 3996, 4002, 4034, 4037, 4055, 4071, 4078, 108, 105, 103, 59, 32768, 338, 99, 117, 116, 101, 33024, 211, 59, 32768, 211, 512, 105, 121, 3941, 3948, 114, 99, 33024, 212, 59, 32768, 212, 59, 32768, 1054, 98, 108, 97, 99, 59, 32768, 336, 114, 59, 32896, 55349, 56594, 114, 97, 118, 101, 33024, 210, 59, 32768, 210, 768, 97, 101, 105, 3979, 3984, 3989, 99, 114, 59, 32768, 332, 103, 97, 59, 32768, 937, 99, 114, 111, 110, 59, 32768, 927, 112, 102, 59, 32896, 55349, 56646, 101, 110, 67, 117, 114, 108, 121, 512, 68, 81, 4014, 4027, 111, 117, 98, 108, 101, 81, 117, 111, 116, 101, 59, 32768, 8220, 117, 111, 116, 101, 59, 32768, 8216, 59, 32768, 10836, 512, 99, 108, 4042, 4047, 114, 59, 32896, 55349, 56490, 97, 115, 104, 33024, 216, 59, 32768, 216, 105, 573, 4060, 4067, 100, 101, 33024, 213, 59, 32768, 213, 101, 115, 59, 32768, 10807, 109, 108, 33024, 214, 59, 32768, 214, 101, 114, 512, 66, 80, 4085, 4109, 512, 97, 114, 4090, 4094, 114, 59, 32768, 8254, 97, 99, 512, 101, 107, 4101, 4104, 59, 32768, 9182, 101, 116, 59, 32768, 9140, 97, 114, 101, 110, 116, 104, 101, 115, 105, 115, 59, 32768, 9180, 2304, 97, 99, 102, 104, 105, 108, 111, 114, 115, 4141, 4150, 4154, 4159, 4163, 4166, 4176, 4198, 4284, 114, 116, 105, 97, 108, 68, 59, 32768, 8706, 121, 59, 32768, 1055, 114, 59, 32896, 55349, 56595, 105, 59, 32768, 934, 59, 32768, 928, 117, 115, 77, 105, 110, 117, 115, 59, 32768, 177, 512, 105, 112, 4181, 4194, 110, 99, 97, 114, 101, 112, 108, 97, 110, 101, 59, 32768, 8460, 102, 59, 32768, 8473, 1024, 59, 101, 105, 111, 4207, 4209, 4251, 4256, 32768, 10939, 99, 101, 100, 101, 115, 1024, 59, 69, 83, 84, 4223, 4225, 4232, 4244, 32768, 8826, 113, 117, 97, 108, 59, 32768, 10927, 108, 97, 110, 116, 69, 113, 117, 97, 108, 59, 32768, 8828, 105, 108, 100, 101, 59, 32768, 8830, 109, 101, 59, 32768, 8243, 512, 100, 112, 4261, 4267, 117, 99, 116, 59, 32768, 8719, 111, 114, 116, 105, 111, 110, 512, 59, 97, 4278, 4280, 32768, 8759, 108, 59, 32768, 8733, 512, 99, 105, 4289, 4294, 114, 59, 32896, 55349, 56491, 59, 32768, 936, 1024, 85, 102, 111, 115, 4306, 4313, 4318, 4323, 79, 84, 33024, 34, 59, 32768, 34, 114, 59, 32896, 55349, 56596, 112, 102, 59, 32768, 8474, 99, 114, 59, 32896, 55349, 56492, 3072, 66, 69, 97, 99, 101, 102, 104, 105, 111, 114, 115, 117, 4354, 4360, 4366, 4395, 4417, 4473, 4477, 4481, 4743, 4764, 4776, 4788, 97, 114, 114, 59, 32768, 10512, 71, 33024, 174, 59, 32768, 174, 768, 99, 110, 114, 4373, 4379, 4383, 117, 116, 101, 59, 32768, 340, 103, 59, 32768, 10219, 114, 512, 59, 116, 4389, 4391, 32768, 8608, 108, 59, 32768, 10518, 768, 97, 101, 121, 4402, 4408, 4414, 114, 111, 110, 59, 32768, 344, 100, 105, 108, 59, 32768, 342, 59, 32768, 1056, 512, 59, 118, 4422, 4424, 32768, 8476, 101, 114, 115, 101, 512, 69, 85, 4433, 4458, 512, 108, 113, 4438, 4446, 101, 109, 101, 110, 116, 59, 32768, 8715, 117, 105, 108, 105, 98, 114, 105, 117, 109, 59, 32768, 8651, 112, 69, 113, 117, 105, 108, 105, 98, 114, 105, 117, 109, 59, 32768, 10607, 114, 59, 32768, 8476, 111, 59, 32768, 929, 103, 104, 116, 2048, 65, 67, 68, 70, 84, 85, 86, 97, 4501, 4547, 4556, 4607, 4614, 4671, 4719, 4736, 512, 110, 114, 4506, 4519, 103, 108, 101, 66, 114, 97, 99, 107, 101, 116, 59, 32768, 10217, 114, 111, 119, 768, 59, 66, 76, 4529, 4531, 4536, 32768, 8594, 97, 114, 59, 32768, 8677, 101, 102, 116, 65, 114, 114, 111, 119, 59, 32768, 8644, 101, 105, 108, 105, 110, 103, 59, 32768, 8969, 111, 838, 4562, 0, 4575, 98, 108, 101, 66, 114, 97, 99, 107, 101, 116, 59, 32768, 10215, 110, 805, 4580, 0, 4591, 101, 101, 86, 101, 99, 116, 111, 114, 59, 32768, 10589, 101, 99, 116, 111, 114, 512, 59, 66, 4600, 4602, 32768, 8642, 97, 114, 59, 32768, 10581, 108, 111, 111, 114, 59, 32768, 8971, 512, 101, 114, 4619, 4644, 101, 768, 59, 65, 86, 4627, 4629, 4636, 32768, 8866, 114, 114, 111, 119, 59, 32768, 8614, 101, 99, 116, 111, 114, 59, 32768, 10587, 105, 97, 110, 103, 108, 101, 768, 59, 66, 69, 4657, 4659, 4664, 32768, 8883, 97, 114, 59, 32768, 10704, 113, 117, 97, 108, 59, 32768, 8885, 112, 768, 68, 84, 86, 4679, 4691, 4702, 111, 119, 110, 86, 101, 99, 116, 111, 114, 59, 32768, 10575, 101, 101, 86, 101, 99, 116, 111, 114, 59, 32768, 10588, 101, 99, 116, 111, 114, 512, 59, 66, 4712, 4714, 32768, 8638, 97, 114, 59, 32768, 10580, 101, 99, 116, 111, 114, 512, 59, 66, 4729, 4731, 32768, 8640, 97, 114, 59, 32768, 10579, 114, 114, 111, 119, 59, 32768, 8658, 512, 112, 117, 4748, 4752, 102, 59, 32768, 8477, 110, 100, 73, 109, 112, 108, 105, 101, 115, 59, 32768, 10608, 105, 103, 104, 116, 97, 114, 114, 111, 119, 59, 32768, 8667, 512, 99, 104, 4781, 4785, 114, 59, 32768, 8475, 59, 32768, 8625, 108, 101, 68, 101, 108, 97, 121, 101, 100, 59, 32768, 10740, 3328, 72, 79, 97, 99, 102, 104, 105, 109, 111, 113, 115, 116, 117, 4827, 4842, 4849, 4856, 4889, 4894, 4949, 4955, 4967, 4973, 5059, 5065, 5070, 512, 67, 99, 4832, 4838, 72, 99, 121, 59, 32768, 1065, 121, 59, 32768, 1064, 70, 84, 99, 121, 59, 32768, 1068, 99, 117, 116, 101, 59, 32768, 346, 1280, 59, 97, 101, 105, 121, 4867, 4869, 4875, 4881, 4886, 32768, 10940, 114, 111, 110, 59, 32768, 352, 100, 105, 108, 59, 32768, 350, 114, 99, 59, 32768, 348, 59, 32768, 1057, 114, 59, 32896, 55349, 56598, 111, 114, 116, 1024, 68, 76, 82, 85, 4906, 4917, 4928, 4940, 111, 119, 110, 65, 114, 114, 111, 119, 59, 32768, 8595, 101, 102, 116, 65, 114, 114, 111, 119, 59, 32768, 8592, 105, 103, 104, 116, 65, 114, 114, 111, 119, 59, 32768, 8594, 112, 65, 114, 114, 111, 119, 59, 32768, 8593, 103, 109, 97, 59, 32768, 931, 97, 108, 108, 67, 105, 114, 99, 108, 101, 59, 32768, 8728, 112, 102, 59, 32896, 55349, 56650, 1091, 4979, 0, 0, 4983, 116, 59, 32768, 8730, 97, 114, 101, 1024, 59, 73, 83, 85, 4994, 4996, 5010, 5052, 32768, 9633, 110, 116, 101, 114, 115, 101, 99, 116, 105, 111, 110, 59, 32768, 8851, 117, 512, 98, 112, 5016, 5033, 115, 101, 116, 512, 59, 69, 5024, 5026, 32768, 8847, 113, 117, 97, 108, 59, 32768, 8849, 101, 114, 115, 101, 116, 512, 59, 69, 5043, 5045, 32768, 8848, 113, 117, 97, 108, 59, 32768, 8850, 110, 105, 111, 110, 59, 32768, 8852, 99, 114, 59, 32896, 55349, 56494, 97, 114, 59, 32768, 8902, 1024, 98, 99, 109, 112, 5079, 5102, 5155, 5158, 512, 59, 115, 5084, 5086, 32768, 8912, 101, 116, 512, 59, 69, 5093, 5095, 32768, 8912, 113, 117, 97, 108, 59, 32768, 8838, 512, 99, 104, 5107, 5148, 101, 101, 100, 115, 1024, 59, 69, 83, 84, 5120, 5122, 5129, 5141, 32768, 8827, 113, 117, 97, 108, 59, 32768, 10928, 108, 97, 110, 116, 69, 113, 117, 97, 108, 59, 32768, 8829, 105, 108, 100, 101, 59, 32768, 8831, 84, 104, 97, 116, 59, 32768, 8715, 59, 32768, 8721, 768, 59, 101, 115, 5165, 5167, 5185, 32768, 8913, 114, 115, 101, 116, 512, 59, 69, 5176, 5178, 32768, 8835, 113, 117, 97, 108, 59, 32768, 8839, 101, 116, 59, 32768, 8913, 2816, 72, 82, 83, 97, 99, 102, 104, 105, 111, 114, 115, 5213, 5221, 5227, 5241, 5252, 5274, 5279, 5323, 5362, 5368, 5378, 79, 82, 78, 33024, 222, 59, 32768, 222, 65, 68, 69, 59, 32768, 8482, 512, 72, 99, 5232, 5237, 99, 121, 59, 32768, 1035, 121, 59, 32768, 1062, 512, 98, 117, 5246, 5249, 59, 32768, 9, 59, 32768, 932, 768, 97, 101, 121, 5259, 5265, 5271, 114, 111, 110, 59, 32768, 356, 100, 105, 108, 59, 32768, 354, 59, 32768, 1058, 114, 59, 32896, 55349, 56599, 512, 101, 105, 5284, 5300, 835, 5289, 0, 5297, 101, 102, 111, 114, 101, 59, 32768, 8756, 97, 59, 32768, 920, 512, 99, 110, 5305, 5315, 107, 83, 112, 97, 99, 101, 59, 32896, 8287, 8202, 83, 112, 97, 99, 101, 59, 32768, 8201, 108, 100, 101, 1024, 59, 69, 70, 84, 5335, 5337, 5344, 5355, 32768, 8764, 113, 117, 97, 108, 59, 32768, 8771, 117, 108, 108, 69, 113, 117, 97, 108, 59, 32768, 8773, 105, 108, 100, 101, 59, 32768, 8776, 112, 102, 59, 32896, 55349, 56651, 105, 112, 108, 101, 68, 111, 116, 59, 32768, 8411, 512, 99, 116, 5383, 5388, 114, 59, 32896, 55349, 56495, 114, 111, 107, 59, 32768, 358, 5426, 5417, 5444, 5458, 5473, 0, 5480, 5485, 0, 0, 0, 0, 0, 5494, 5500, 5564, 5579, 0, 5726, 5732, 5738, 5745, 512, 99, 114, 5421, 5429, 117, 116, 101, 33024, 218, 59, 32768, 218, 114, 512, 59, 111, 5435, 5437, 32768, 8607, 99, 105, 114, 59, 32768, 10569, 114, 820, 5449, 0, 5453, 121, 59, 32768, 1038, 118, 101, 59, 32768, 364, 512, 105, 121, 5462, 5469, 114, 99, 33024, 219, 59, 32768, 219, 59, 32768, 1059, 98, 108, 97, 99, 59, 32768, 368, 114, 59, 32896, 55349, 56600, 114, 97, 118, 101, 33024, 217, 59, 32768, 217, 97, 99, 114, 59, 32768, 362, 512, 100, 105, 5504, 5548, 101, 114, 512, 66, 80, 5511, 5535, 512, 97, 114, 5516, 5520, 114, 59, 32768, 95, 97, 99, 512, 101, 107, 5527, 5530, 59, 32768, 9183, 101, 116, 59, 32768, 9141, 97, 114, 101, 110, 116, 104, 101, 115, 105, 115, 59, 32768, 9181, 111, 110, 512, 59, 80, 5555, 5557, 32768, 8899, 108, 117, 115, 59, 32768, 8846, 512, 103, 112, 5568, 5573, 111, 110, 59, 32768, 370, 102, 59, 32896, 55349, 56652, 2048, 65, 68, 69, 84, 97, 100, 112, 115, 5595, 5624, 5635, 5648, 5664, 5671, 5682, 5712, 114, 114, 111, 119, 768, 59, 66, 68, 5606, 5608, 5613, 32768, 8593, 97, 114, 59, 32768, 10514, 111, 119, 110, 65, 114, 114, 111, 119, 59, 32768, 8645, 111, 119, 110, 65, 114, 114, 111, 119, 59, 32768, 8597, 113, 117, 105, 108, 105, 98, 114, 105, 117, 109, 59, 32768, 10606, 101, 101, 512, 59, 65, 5655, 5657, 32768, 8869, 114, 114, 111, 119, 59, 32768, 8613, 114, 114, 111, 119, 59, 32768, 8657, 111, 119, 110, 97, 114, 114, 111, 119, 59, 32768, 8661, 101, 114, 512, 76, 82, 5689, 5700, 101, 102, 116, 65, 114, 114, 111, 119, 59, 32768, 8598, 105, 103, 104, 116, 65, 114, 114, 111, 119, 59, 32768, 8599, 105, 512, 59, 108, 5718, 5720, 32768, 978, 111, 110, 59, 32768, 933, 105, 110, 103, 59, 32768, 366, 99, 114, 59, 32896, 55349, 56496, 105, 108, 100, 101, 59, 32768, 360, 109, 108, 33024, 220, 59, 32768, 220, 2304, 68, 98, 99, 100, 101, 102, 111, 115, 118, 5770, 5776, 5781, 5785, 5798, 5878, 5883, 5889, 5895, 97, 115, 104, 59, 32768, 8875, 97, 114, 59, 32768, 10987, 121, 59, 32768, 1042, 97, 115, 104, 512, 59, 108, 5793, 5795, 32768, 8873, 59, 32768, 10982, 512, 101, 114, 5803, 5806, 59, 32768, 8897, 768, 98, 116, 121, 5813, 5818, 5866, 97, 114, 59, 32768, 8214, 512, 59, 105, 5823, 5825, 32768, 8214, 99, 97, 108, 1024, 66, 76, 83, 84, 5837, 5842, 5848, 5859, 97, 114, 59, 32768, 8739, 105, 110, 101, 59, 32768, 124, 101, 112, 97, 114, 97, 116, 111, 114, 59, 32768, 10072, 105, 108, 100, 101, 59, 32768, 8768, 84, 104, 105, 110, 83, 112, 97, 99, 101, 59, 32768, 8202, 114, 59, 32896, 55349, 56601, 112, 102, 59, 32896, 55349, 56653, 99, 114, 59, 32896, 55349, 56497, 100, 97, 115, 104, 59, 32768, 8874, 1280, 99, 101, 102, 111, 115, 5913, 5919, 5925, 5930, 5936, 105, 114, 99, 59, 32768, 372, 100, 103, 101, 59, 32768, 8896, 114, 59, 32896, 55349, 56602, 112, 102, 59, 32896, 55349, 56654, 99, 114, 59, 32896, 55349, 56498, 1024, 102, 105, 111, 115, 5951, 5956, 5959, 5965, 114, 59, 32896, 55349, 56603, 59, 32768, 926, 112, 102, 59, 32896, 55349, 56655, 99, 114, 59, 32896, 55349, 56499, 2304, 65, 73, 85, 97, 99, 102, 111, 115, 117, 5990, 5995, 6000, 6005, 6014, 6027, 6032, 6038, 6044, 99, 121, 59, 32768, 1071, 99, 121, 59, 32768, 1031, 99, 121, 59, 32768, 1070, 99, 117, 116, 101, 33024, 221, 59, 32768, 221, 512, 105, 121, 6019, 6024, 114, 99, 59, 32768, 374, 59, 32768, 1067, 114, 59, 32896, 55349, 56604, 112, 102, 59, 32896, 55349, 56656, 99, 114, 59, 32896, 55349, 56500, 109, 108, 59, 32768, 376, 2048, 72, 97, 99, 100, 101, 102, 111, 115, 6066, 6071, 6078, 6092, 6097, 6119, 6123, 6128, 99, 121, 59, 32768, 1046, 99, 117, 116, 101, 59, 32768, 377, 512, 97, 121, 6083, 6089, 114, 111, 110, 59, 32768, 381, 59, 32768, 1047, 111, 116, 59, 32768, 379, 835, 6102, 0, 6116, 111, 87, 105, 100, 116, 104, 83, 112, 97, 99, 101, 59, 32768, 8203, 97, 59, 32768, 918, 114, 59, 32768, 8488, 112, 102, 59, 32768, 8484, 99, 114, 59, 32896, 55349, 56501, 5938, 6159, 6168, 6175, 0, 6214, 6222, 6233, 0, 0, 0, 0, 6242, 6267, 6290, 6429, 6444, 0, 6495, 6503, 6531, 6540, 0, 6547, 99, 117, 116, 101, 33024, 225, 59, 32768, 225, 114, 101, 118, 101, 59, 32768, 259, 1536, 59, 69, 100, 105, 117, 121, 6187, 6189, 6193, 6196, 6203, 6210, 32768, 8766, 59, 32896, 8766, 819, 59, 32768, 8767, 114, 99, 33024, 226, 59, 32768, 226, 116, 101, 33024, 180, 59, 32768, 180, 59, 32768, 1072, 108, 105, 103, 33024, 230, 59, 32768, 230, 512, 59, 114, 6226, 6228, 32768, 8289, 59, 32896, 55349, 56606, 114, 97, 118, 101, 33024, 224, 59, 32768, 224, 512, 101, 112, 6246, 6261, 512, 102, 112, 6251, 6257, 115, 121, 109, 59, 32768, 8501, 104, 59, 32768, 8501, 104, 97, 59, 32768, 945, 512, 97, 112, 6271, 6284, 512, 99, 108, 6276, 6280, 114, 59, 32768, 257, 103, 59, 32768, 10815, 33024, 38, 59, 32768, 38, 1077, 6295, 0, 0, 6326, 1280, 59, 97, 100, 115, 118, 6305, 6307, 6312, 6315, 6322, 32768, 8743, 110, 100, 59, 32768, 10837, 59, 32768, 10844, 108, 111, 112, 101, 59, 32768, 10840, 59, 32768, 10842, 1792, 59, 101, 108, 109, 114, 115, 122, 6340, 6342, 6345, 6349, 6391, 6410, 6422, 32768, 8736, 59, 32768, 10660, 101, 59, 32768, 8736, 115, 100, 512, 59, 97, 6356, 6358, 32768, 8737, 2098, 6368, 6371, 6374, 6377, 6380, 6383, 6386, 6389, 59, 32768, 10664, 59, 32768, 10665, 59, 32768, 10666, 59, 32768, 10667, 59, 32768, 10668, 59, 32768, 10669, 59, 32768, 10670, 59, 32768, 10671, 116, 512, 59, 118, 6397, 6399, 32768, 8735, 98, 512, 59, 100, 6405, 6407, 32768, 8894, 59, 32768, 10653, 512, 112, 116, 6415, 6419, 104, 59, 32768, 8738, 59, 32768, 197, 97, 114, 114, 59, 32768, 9084, 512, 103, 112, 6433, 6438, 111, 110, 59, 32768, 261, 102, 59, 32896, 55349, 56658, 1792, 59, 69, 97, 101, 105, 111, 112, 6458, 6460, 6463, 6469, 6472, 6476, 6480, 32768, 8776, 59, 32768, 10864, 99, 105, 114, 59, 32768, 10863, 59, 32768, 8778, 100, 59, 32768, 8779, 115, 59, 32768, 39, 114, 111, 120, 512, 59, 101, 6488, 6490, 32768, 8776, 113, 59, 32768, 8778, 105, 110, 103, 33024, 229, 59, 32768, 229, 768, 99, 116, 121, 6509, 6514, 6517, 114, 59, 32896, 55349, 56502, 59, 32768, 42, 109, 112, 512, 59, 101, 6524, 6526, 32768, 8776, 113, 59, 32768, 8781, 105, 108, 100, 101, 33024, 227, 59, 32768, 227, 109, 108, 33024, 228, 59, 32768, 228, 512, 99, 105, 6551, 6559, 111, 110, 105, 110, 116, 59, 32768, 8755, 110, 116, 59, 32768, 10769, 4096, 78, 97, 98, 99, 100, 101, 102, 105, 107, 108, 110, 111, 112, 114, 115, 117, 6597, 6602, 6673, 6688, 6701, 6707, 6768, 6773, 6891, 6898, 6999, 7023, 7309, 7316, 7334, 7383, 111, 116, 59, 32768, 10989, 512, 99, 114, 6607, 6652, 107, 1024, 99, 101, 112, 115, 6617, 6623, 6632, 6639, 111, 110, 103, 59, 32768, 8780, 112, 115, 105, 108, 111, 110, 59, 32768, 1014, 114, 105, 109, 101, 59, 32768, 8245, 105, 109, 512, 59, 101, 6646, 6648, 32768, 8765, 113, 59, 32768, 8909, 583, 6656, 6661, 101, 101, 59, 32768, 8893, 101, 100, 512, 59, 103, 6667, 6669, 32768, 8965, 101, 59, 32768, 8965, 114, 107, 512, 59, 116, 6680, 6682, 32768, 9141, 98, 114, 107, 59, 32768, 9142, 512, 111, 121, 6693, 6698, 110, 103, 59, 32768, 8780, 59, 32768, 1073, 113, 117, 111, 59, 32768, 8222, 1280, 99, 109, 112, 114, 116, 6718, 6731, 6738, 6743, 6749, 97, 117, 115, 512, 59, 101, 6726, 6728, 32768, 8757, 59, 32768, 8757, 112, 116, 121, 118, 59, 32768, 10672, 115, 105, 59, 32768, 1014, 110, 111, 117, 59, 32768, 8492, 768, 97, 104, 119, 6756, 6759, 6762, 59, 32768, 946, 59, 32768, 8502, 101, 101, 110, 59, 32768, 8812, 114, 59, 32896, 55349, 56607, 103, 1792, 99, 111, 115, 116, 117, 118, 119, 6789, 6809, 6834, 6850, 6872, 6879, 6884, 768, 97, 105, 117, 6796, 6800, 6805, 112, 59, 32768, 8898, 114, 99, 59, 32768, 9711, 112, 59, 32768, 8899, 768, 100, 112, 116, 6816, 6821, 6827, 111, 116, 59, 32768, 10752, 108, 117, 115, 59, 32768, 10753, 105, 109, 101, 115, 59, 32768, 10754, 1090, 6840, 0, 0, 6846, 99, 117, 112, 59, 32768, 10758, 97, 114, 59, 32768, 9733, 114, 105, 97, 110, 103, 108, 101, 512, 100, 117, 6862, 6868, 111, 119, 110, 59, 32768, 9661, 112, 59, 32768, 9651, 112, 108, 117, 115, 59, 32768, 10756, 101, 101, 59, 32768, 8897, 101, 100, 103, 101, 59, 32768, 8896, 97, 114, 111, 119, 59, 32768, 10509, 768, 97, 107, 111, 6905, 6976, 6994, 512, 99, 110, 6910, 6972, 107, 768, 108, 115, 116, 6918, 6927, 6935, 111, 122, 101, 110, 103, 101, 59, 32768, 10731, 113, 117, 97, 114, 101, 59, 32768, 9642, 114, 105, 97, 110, 103, 108, 101, 1024, 59, 100, 108, 114, 6951, 6953, 6959, 6965, 32768, 9652, 111, 119, 110, 59, 32768, 9662, 101, 102, 116, 59, 32768, 9666, 105, 103, 104, 116, 59, 32768, 9656, 107, 59, 32768, 9251, 770, 6981, 0, 6991, 771, 6985, 0, 6988, 59, 32768, 9618, 59, 32768, 9617, 52, 59, 32768, 9619, 99, 107, 59, 32768, 9608, 512, 101, 111, 7004, 7019, 512, 59, 113, 7009, 7012, 32896, 61, 8421, 117, 105, 118, 59, 32896, 8801, 8421, 116, 59, 32768, 8976, 1024, 112, 116, 119, 120, 7032, 7037, 7049, 7055, 102, 59, 32896, 55349, 56659, 512, 59, 116, 7042, 7044, 32768, 8869, 111, 109, 59, 32768, 8869, 116, 105, 101, 59, 32768, 8904, 3072, 68, 72, 85, 86, 98, 100, 104, 109, 112, 116, 117, 118, 7080, 7101, 7126, 7147, 7182, 7187, 7208, 7233, 7240, 7246, 7253, 7274, 1024, 76, 82, 108, 114, 7089, 7092, 7095, 7098, 59, 32768, 9559, 59, 32768, 9556, 59, 32768, 9558, 59, 32768, 9555, 1280, 59, 68, 85, 100, 117, 7112, 7114, 7117, 7120, 7123, 32768, 9552, 59, 32768, 9574, 59, 32768, 9577, 59, 32768, 9572, 59, 32768, 9575, 1024, 76, 82, 108, 114, 7135, 7138, 7141, 7144, 59, 32768, 9565, 59, 32768, 9562, 59, 32768, 9564, 59, 32768, 9561, 1792, 59, 72, 76, 82, 104, 108, 114, 7162, 7164, 7167, 7170, 7173, 7176, 7179, 32768, 9553, 59, 32768, 9580, 59, 32768, 9571, 59, 32768, 9568, 59, 32768, 9579, 59, 32768, 9570, 59, 32768, 9567, 111, 120, 59, 32768, 10697, 1024, 76, 82, 108, 114, 7196, 7199, 7202, 7205, 59, 32768, 9557, 59, 32768, 9554, 59, 32768, 9488, 59, 32768, 9484, 1280, 59, 68, 85, 100, 117, 7219, 7221, 7224, 7227, 7230, 32768, 9472, 59, 32768, 9573, 59, 32768, 9576, 59, 32768, 9516, 59, 32768, 9524, 105, 110, 117, 115, 59, 32768, 8863, 108, 117, 115, 59, 32768, 8862, 105, 109, 101, 115, 59, 32768, 8864, 1024, 76, 82, 108, 114, 7262, 7265, 7268, 7271, 59, 32768, 9563, 59, 32768, 9560, 59, 32768, 9496, 59, 32768, 9492, 1792, 59, 72, 76, 82, 104, 108, 114, 7289, 7291, 7294, 7297, 7300, 7303, 7306, 32768, 9474, 59, 32768, 9578, 59, 32768, 9569, 59, 32768, 9566, 59, 32768, 9532, 59, 32768, 9508, 59, 32768, 9500, 114, 105, 109, 101, 59, 32768, 8245, 512, 101, 118, 7321, 7326, 118, 101, 59, 32768, 728, 98, 97, 114, 33024, 166, 59, 32768, 166, 1024, 99, 101, 105, 111, 7343, 7348, 7353, 7364, 114, 59, 32896, 55349, 56503, 109, 105, 59, 32768, 8271, 109, 512, 59, 101, 7359, 7361, 32768, 8765, 59, 32768, 8909, 108, 768, 59, 98, 104, 7372, 7374, 7377, 32768, 92, 59, 32768, 10693, 115, 117, 98, 59, 32768, 10184, 573, 7387, 7399, 108, 512, 59, 101, 7392, 7394, 32768, 8226, 116, 59, 32768, 8226, 112, 768, 59, 69, 101, 7406, 7408, 7411, 32768, 8782, 59, 32768, 10926, 512, 59, 113, 7416, 7418, 32768, 8783, 59, 32768, 8783, 6450, 7448, 0, 7523, 7571, 7576, 7613, 0, 7618, 7647, 0, 0, 7764, 0, 0, 7779, 0, 0, 7899, 7914, 7949, 7955, 0, 8158, 0, 8176, 768, 99, 112, 114, 7454, 7460, 7509, 117, 116, 101, 59, 32768, 263, 1536, 59, 97, 98, 99, 100, 115, 7473, 7475, 7480, 7487, 7500, 7505, 32768, 8745, 110, 100, 59, 32768, 10820, 114, 99, 117, 112, 59, 32768, 10825, 512, 97, 117, 7492, 7496, 112, 59, 32768, 10827, 112, 59, 32768, 10823, 111, 116, 59, 32768, 10816, 59, 32896, 8745, 65024, 512, 101, 111, 7514, 7518, 116, 59, 32768, 8257, 110, 59, 32768, 711, 1024, 97, 101, 105, 117, 7531, 7544, 7552, 7557, 833, 7536, 0, 7540, 115, 59, 32768, 10829, 111, 110, 59, 32768, 269, 100, 105, 108, 33024, 231, 59, 32768, 231, 114, 99, 59, 32768, 265, 112, 115, 512, 59, 115, 7564, 7566, 32768, 10828, 109, 59, 32768, 10832, 111, 116, 59, 32768, 267, 768, 100, 109, 110, 7582, 7589, 7596, 105, 108, 33024, 184, 59, 32768, 184, 112, 116, 121, 118, 59, 32768, 10674, 116, 33280, 162, 59, 101, 7603, 7605, 32768, 162, 114, 100, 111, 116, 59, 32768, 183, 114, 59, 32896, 55349, 56608, 768, 99, 101, 105, 7624, 7628, 7643, 121, 59, 32768, 1095, 99, 107, 512, 59, 109, 7635, 7637, 32768, 10003, 97, 114, 107, 59, 32768, 10003, 59, 32768, 967, 114, 1792, 59, 69, 99, 101, 102, 109, 115, 7662, 7664, 7667, 7742, 7745, 7752, 7757, 32768, 9675, 59, 32768, 10691, 768, 59, 101, 108, 7674, 7676, 7680, 32768, 710, 113, 59, 32768, 8791, 101, 1074, 7687, 0, 0, 7709, 114, 114, 111, 119, 512, 108, 114, 7695, 7701, 101, 102, 116, 59, 32768, 8634, 105, 103, 104, 116, 59, 32768, 8635, 1280, 82, 83, 97, 99, 100, 7719, 7722, 7725, 7730, 7736, 59, 32768, 174, 59, 32768, 9416, 115, 116, 59, 32768, 8859, 105, 114, 99, 59, 32768, 8858, 97, 115, 104, 59, 32768, 8861, 59, 32768, 8791, 110, 105, 110, 116, 59, 32768, 10768, 105, 100, 59, 32768, 10991, 99, 105, 114, 59, 32768, 10690, 117, 98, 115, 512, 59, 117, 7771, 7773, 32768, 9827, 105, 116, 59, 32768, 9827, 1341, 7785, 7804, 7850, 0, 7871, 111, 110, 512, 59, 101, 7791, 7793, 32768, 58, 512, 59, 113, 7798, 7800, 32768, 8788, 59, 32768, 8788, 1086, 7809, 0, 0, 7820, 97, 512, 59, 116, 7814, 7816, 32768, 44, 59, 32768, 64, 768, 59, 102, 108, 7826, 7828, 7832, 32768, 8705, 110, 59, 32768, 8728, 101, 512, 109, 120, 7838, 7844, 101, 110, 116, 59, 32768, 8705, 101, 115, 59, 32768, 8450, 824, 7854, 0, 7866, 512, 59, 100, 7858, 7860, 32768, 8773, 111, 116, 59, 32768, 10861, 110, 116, 59, 32768, 8750, 768, 102, 114, 121, 7877, 7881, 7886, 59, 32896, 55349, 56660, 111, 100, 59, 32768, 8720, 33280, 169, 59, 115, 7892, 7894, 32768, 169, 114, 59, 32768, 8471, 512, 97, 111, 7903, 7908, 114, 114, 59, 32768, 8629, 115, 115, 59, 32768, 10007, 512, 99, 117, 7918, 7923, 114, 59, 32896, 55349, 56504, 512, 98, 112, 7928, 7938, 512, 59, 101, 7933, 7935, 32768, 10959, 59, 32768, 10961, 512, 59, 101, 7943, 7945, 32768, 10960, 59, 32768, 10962, 100, 111, 116, 59, 32768, 8943, 1792, 100, 101, 108, 112, 114, 118, 119, 7969, 7983, 7996, 8009, 8057, 8147, 8152, 97, 114, 114, 512, 108, 114, 7977, 7980, 59, 32768, 10552, 59, 32768, 10549, 1089, 7989, 0, 0, 7993, 114, 59, 32768, 8926, 99, 59, 32768, 8927, 97, 114, 114, 512, 59, 112, 8004, 8006, 32768, 8630, 59, 32768, 10557, 1536, 59, 98, 99, 100, 111, 115, 8022, 8024, 8031, 8044, 8049, 8053, 32768, 8746, 114, 99, 97, 112, 59, 32768, 10824, 512, 97, 117, 8036, 8040, 112, 59, 32768, 10822, 112, 59, 32768, 10826, 111, 116, 59, 32768, 8845, 114, 59, 32768, 10821, 59, 32896, 8746, 65024, 1024, 97, 108, 114, 118, 8066, 8078, 8116, 8123, 114, 114, 512, 59, 109, 8073, 8075, 32768, 8631, 59, 32768, 10556, 121, 768, 101, 118, 119, 8086, 8104, 8109, 113, 1089, 8093, 0, 0, 8099, 114, 101, 99, 59, 32768, 8926, 117, 99, 99, 59, 32768, 8927, 101, 101, 59, 32768, 8910, 101, 100, 103, 101, 59, 32768, 8911, 101, 110, 33024, 164, 59, 32768, 164, 101, 97, 114, 114, 111, 119, 512, 108, 114, 8134, 8140, 101, 102, 116, 59, 32768, 8630, 105, 103, 104, 116, 59, 32768, 8631, 101, 101, 59, 32768, 8910, 101, 100, 59, 32768, 8911, 512, 99, 105, 8162, 8170, 111, 110, 105, 110, 116, 59, 32768, 8754, 110, 116, 59, 32768, 8753, 108, 99, 116, 121, 59, 32768, 9005, 4864, 65, 72, 97, 98, 99, 100, 101, 102, 104, 105, 106, 108, 111, 114, 115, 116, 117, 119, 122, 8221, 8226, 8231, 8267, 8282, 8296, 8327, 8351, 8366, 8379, 8466, 8471, 8487, 8621, 8647, 8676, 8697, 8712, 8720, 114, 114, 59, 32768, 8659, 97, 114, 59, 32768, 10597, 1024, 103, 108, 114, 115, 8240, 8246, 8252, 8256, 103, 101, 114, 59, 32768, 8224, 101, 116, 104, 59, 32768, 8504, 114, 59, 32768, 8595, 104, 512, 59, 118, 8262, 8264, 32768, 8208, 59, 32768, 8867, 572, 8271, 8278, 97, 114, 111, 119, 59, 32768, 10511, 97, 99, 59, 32768, 733, 512, 97, 121, 8287, 8293, 114, 111, 110, 59, 32768, 271, 59, 32768, 1076, 768, 59, 97, 111, 8303, 8305, 8320, 32768, 8518, 512, 103, 114, 8310, 8316, 103, 101, 114, 59, 32768, 8225, 114, 59, 32768, 8650, 116, 115, 101, 113, 59, 32768, 10871, 768, 103, 108, 109, 8334, 8339, 8344, 33024, 176, 59, 32768, 176, 116, 97, 59, 32768, 948, 112, 116, 121, 118, 59, 32768, 10673, 512, 105, 114, 8356, 8362, 115, 104, 116, 59, 32768, 10623, 59, 32896, 55349, 56609, 97, 114, 512, 108, 114, 8373, 8376, 59, 32768, 8643, 59, 32768, 8642, 1280, 97, 101, 103, 115, 118, 8390, 8418, 8421, 8428, 8433, 109, 768, 59, 111, 115, 8398, 8400, 8415, 32768, 8900, 110, 100, 512, 59, 115, 8407, 8409, 32768, 8900, 117, 105, 116, 59, 32768, 9830, 59, 32768, 9830, 59, 32768, 168, 97, 109, 109, 97, 59, 32768, 989, 105, 110, 59, 32768, 8946, 768, 59, 105, 111, 8440, 8442, 8461, 32768, 247, 100, 101, 33280, 247, 59, 111, 8450, 8452, 32768, 247, 110, 116, 105, 109, 101, 115, 59, 32768, 8903, 110, 120, 59, 32768, 8903, 99, 121, 59, 32768, 1106, 99, 1088, 8478, 0, 0, 8483, 114, 110, 59, 32768, 8990, 111, 112, 59, 32768, 8973, 1280, 108, 112, 116, 117, 119, 8498, 8504, 8509, 8556, 8570, 108, 97, 114, 59, 32768, 36, 102, 59, 32896, 55349, 56661, 1280, 59, 101, 109, 112, 115, 8520, 8522, 8535, 8542, 8548, 32768, 729, 113, 512, 59, 100, 8528, 8530, 32768, 8784, 111, 116, 59, 32768, 8785, 105, 110, 117, 115, 59, 32768, 8760, 108, 117, 115, 59, 32768, 8724, 113, 117, 97, 114, 101, 59, 32768, 8865, 98, 108, 101, 98, 97, 114, 119, 101, 100, 103, 101, 59, 32768, 8966, 110, 768, 97, 100, 104, 8578, 8585, 8597, 114, 114, 111, 119, 59, 32768, 8595, 111, 119, 110, 97, 114, 114, 111, 119, 115, 59, 32768, 8650, 97, 114, 112, 111, 111, 110, 512, 108, 114, 8608, 8614, 101, 102, 116, 59, 32768, 8643, 105, 103, 104, 116, 59, 32768, 8642, 563, 8625, 8633, 107, 97, 114, 111, 119, 59, 32768, 10512, 1088, 8638, 0, 0, 8643, 114, 110, 59, 32768, 8991, 111, 112, 59, 32768, 8972, 768, 99, 111, 116, 8654, 8666, 8670, 512, 114, 121, 8659, 8663, 59, 32896, 55349, 56505, 59, 32768, 1109, 108, 59, 32768, 10742, 114, 111, 107, 59, 32768, 273, 512, 100, 114, 8681, 8686, 111, 116, 59, 32768, 8945, 105, 512, 59, 102, 8692, 8694, 32768, 9663, 59, 32768, 9662, 512, 97, 104, 8702, 8707, 114, 114, 59, 32768, 8693, 97, 114, 59, 32768, 10607, 97, 110, 103, 108, 101, 59, 32768, 10662, 512, 99, 105, 8725, 8729, 121, 59, 32768, 1119, 103, 114, 97, 114, 114, 59, 32768, 10239, 4608, 68, 97, 99, 100, 101, 102, 103, 108, 109, 110, 111, 112, 113, 114, 115, 116, 117, 120, 8774, 8788, 8807, 8844, 8849, 8852, 8866, 8895, 8929, 8977, 8989, 9004, 9046, 9136, 9151, 9171, 9184, 9199, 512, 68, 111, 8779, 8784, 111, 116, 59, 32768, 10871, 116, 59, 32768, 8785, 512, 99, 115, 8793, 8801, 117, 116, 101, 33024, 233, 59, 32768, 233, 116, 101, 114, 59, 32768, 10862, 1024, 97, 105, 111, 121, 8816, 8822, 8835, 8841, 114, 111, 110, 59, 32768, 283, 114, 512, 59, 99, 8828, 8830, 32768, 8790, 33024, 234, 59, 32768, 234, 108, 111, 110, 59, 32768, 8789, 59, 32768, 1101, 111, 116, 59, 32768, 279, 59, 32768, 8519, 512, 68, 114, 8857, 8862, 111, 116, 59, 32768, 8786, 59, 32896, 55349, 56610, 768, 59, 114, 115, 8873, 8875, 8883, 32768, 10906, 97, 118, 101, 33024, 232, 59, 32768, 232, 512, 59, 100, 8888, 8890, 32768, 10902, 111, 116, 59, 32768, 10904, 1024, 59, 105, 108, 115, 8904, 8906, 8914, 8917, 32768, 10905, 110, 116, 101, 114, 115, 59, 32768, 9191, 59, 32768, 8467, 512, 59, 100, 8922, 8924, 32768, 10901, 111, 116, 59, 32768, 10903, 768, 97, 112, 115, 8936, 8941, 8960, 99, 114, 59, 32768, 275, 116, 121, 768, 59, 115, 118, 8950, 8952, 8957, 32768, 8709, 101, 116, 59, 32768, 8709, 59, 32768, 8709, 112, 512, 49, 59, 8966, 8975, 516, 8970, 8973, 59, 32768, 8196, 59, 32768, 8197, 32768, 8195, 512, 103, 115, 8982, 8985, 59, 32768, 331, 112, 59, 32768, 8194, 512, 103, 112, 8994, 8999, 111, 110, 59, 32768, 281, 102, 59, 32896, 55349, 56662, 768, 97, 108, 115, 9011, 9023, 9028, 114, 512, 59, 115, 9017, 9019, 32768, 8917, 108, 59, 32768, 10723, 117, 115, 59, 32768, 10865, 105, 768, 59, 108, 118, 9036, 9038, 9043, 32768, 949, 111, 110, 59, 32768, 949, 59, 32768, 1013, 1024, 99, 115, 117, 118, 9055, 9071, 9099, 9128, 512, 105, 111, 9060, 9065, 114, 99, 59, 32768, 8790, 108, 111, 110, 59, 32768, 8789, 1082, 9077, 0, 0, 9081, 109, 59, 32768, 8770, 97, 110, 116, 512, 103, 108, 9088, 9093, 116, 114, 59, 32768, 10902, 101, 115, 115, 59, 32768, 10901, 768, 97, 101, 105, 9106, 9111, 9116, 108, 115, 59, 32768, 61, 115, 116, 59, 32768, 8799, 118, 512, 59, 68, 9122, 9124, 32768, 8801, 68, 59, 32768, 10872, 112, 97, 114, 115, 108, 59, 32768, 10725, 512, 68, 97, 9141, 9146, 111, 116, 59, 32768, 8787, 114, 114, 59, 32768, 10609, 768, 99, 100, 105, 9158, 9162, 9167, 114, 59, 32768, 8495, 111, 116, 59, 32768, 8784, 109, 59, 32768, 8770, 512, 97, 104, 9176, 9179, 59, 32768, 951, 33024, 240, 59, 32768, 240, 512, 109, 114, 9189, 9195, 108, 33024, 235, 59, 32768, 235, 111, 59, 32768, 8364, 768, 99, 105, 112, 9206, 9210, 9215, 108, 59, 32768, 33, 115, 116, 59, 32768, 8707, 512, 101, 111, 9220, 9230, 99, 116, 97, 116, 105, 111, 110, 59, 32768, 8496, 110, 101, 110, 116, 105, 97, 108, 101, 59, 32768, 8519, 4914, 9262, 0, 9276, 0, 9280, 9287, 0, 0, 9318, 9324, 0, 9331, 0, 9352, 9357, 9386, 0, 9395, 9497, 108, 108, 105, 110, 103, 100, 111, 116, 115, 101, 113, 59, 32768, 8786, 121, 59, 32768, 1092, 109, 97, 108, 101, 59, 32768, 9792, 768, 105, 108, 114, 9293, 9299, 9313, 108, 105, 103, 59, 32768, 64259, 1082, 9305, 0, 0, 9309, 103, 59, 32768, 64256, 105, 103, 59, 32768, 64260, 59, 32896, 55349, 56611, 108, 105, 103, 59, 32768, 64257, 108, 105, 103, 59, 32896, 102, 106, 768, 97, 108, 116, 9337, 9341, 9346, 116, 59, 32768, 9837, 105, 103, 59, 32768, 64258, 110, 115, 59, 32768, 9649, 111, 102, 59, 32768, 402, 833, 9361, 0, 9366, 102, 59, 32896, 55349, 56663, 512, 97, 107, 9370, 9375, 108, 108, 59, 32768, 8704, 512, 59, 118, 9380, 9382, 32768, 8916, 59, 32768, 10969, 97, 114, 116, 105, 110, 116, 59, 32768, 10765, 512, 97, 111, 9399, 9491, 512, 99, 115, 9404, 9487, 1794, 9413, 9443, 9453, 9470, 9474, 0, 9484, 1795, 9421, 9426, 9429, 9434, 9437, 0, 9440, 33024, 189, 59, 32768, 189, 59, 32768, 8531, 33024, 188, 59, 32768, 188, 59, 32768, 8533, 59, 32768, 8537, 59, 32768, 8539, 772, 9447, 0, 9450, 59, 32768, 8532, 59, 32768, 8534, 1285, 9459, 9464, 0, 0, 9467, 33024, 190, 59, 32768, 190, 59, 32768, 8535, 59, 32768, 8540, 53, 59, 32768, 8536, 775, 9478, 0, 9481, 59, 32768, 8538, 59, 32768, 8541, 56, 59, 32768, 8542, 108, 59, 32768, 8260, 119, 110, 59, 32768, 8994, 99, 114, 59, 32896, 55349, 56507, 4352, 69, 97, 98, 99, 100, 101, 102, 103, 105, 106, 108, 110, 111, 114, 115, 116, 118, 9537, 9547, 9575, 9582, 9595, 9600, 9679, 9684, 9694, 9700, 9705, 9725, 9773, 9779, 9785, 9810, 9917, 512, 59, 108, 9542, 9544, 32768, 8807, 59, 32768, 10892, 768, 99, 109, 112, 9554, 9560, 9572, 117, 116, 101, 59, 32768, 501, 109, 97, 512, 59, 100, 9567, 9569, 32768, 947, 59, 32768, 989, 59, 32768, 10886, 114, 101, 118, 101, 59, 32768, 287, 512, 105, 121, 9587, 9592, 114, 99, 59, 32768, 285, 59, 32768, 1075, 111, 116, 59, 32768, 289, 1024, 59, 108, 113, 115, 9609, 9611, 9614, 9633, 32768, 8805, 59, 32768, 8923, 768, 59, 113, 115, 9621, 9623, 9626, 32768, 8805, 59, 32768, 8807, 108, 97, 110, 116, 59, 32768, 10878, 1024, 59, 99, 100, 108, 9642, 9644, 9648, 9667, 32768, 10878, 99, 59, 32768, 10921, 111, 116, 512, 59, 111, 9655, 9657, 32768, 10880, 512, 59, 108, 9662, 9664, 32768, 10882, 59, 32768, 10884, 512, 59, 101, 9672, 9675, 32896, 8923, 65024, 115, 59, 32768, 10900, 114, 59, 32896, 55349, 56612, 512, 59, 103, 9689, 9691, 32768, 8811, 59, 32768, 8921, 109, 101, 108, 59, 32768, 8503, 99, 121, 59, 32768, 1107, 1024, 59, 69, 97, 106, 9714, 9716, 9719, 9722, 32768, 8823, 59, 32768, 10898, 59, 32768, 10917, 59, 32768, 10916, 1024, 69, 97, 101, 115, 9734, 9737, 9751, 9768, 59, 32768, 8809, 112, 512, 59, 112, 9743, 9745, 32768, 10890, 114, 111, 120, 59, 32768, 10890, 512, 59, 113, 9756, 9758, 32768, 10888, 512, 59, 113, 9763, 9765, 32768, 10888, 59, 32768, 8809, 105, 109, 59, 32768, 8935, 112, 102, 59, 32896, 55349, 56664, 97, 118, 101, 59, 32768, 96, 512, 99, 105, 9790, 9794, 114, 59, 32768, 8458, 109, 768, 59, 101, 108, 9802, 9804, 9807, 32768, 8819, 59, 32768, 10894, 59, 32768, 10896, 34304, 62, 59, 99, 100, 108, 113, 114, 9824, 9826, 9838, 9843, 9849, 9856, 32768, 62, 512, 99, 105, 9831, 9834, 59, 32768, 10919, 114, 59, 32768, 10874, 111, 116, 59, 32768, 8919, 80, 97, 114, 59, 32768, 10645, 117, 101, 115, 116, 59, 32768, 10876, 1280, 97, 100, 101, 108, 115, 9867, 9882, 9887, 9906, 9912, 833, 9872, 0, 9879, 112, 114, 111, 120, 59, 32768, 10886, 114, 59, 32768, 10616, 111, 116, 59, 32768, 8919, 113, 512, 108, 113, 9893, 9899, 101, 115, 115, 59, 32768, 8923, 108, 101, 115, 115, 59, 32768, 10892, 101, 115, 115, 59, 32768, 8823, 105, 109, 59, 32768, 8819, 512, 101, 110, 9922, 9932, 114, 116, 110, 101, 113, 113, 59, 32896, 8809, 65024, 69, 59, 32896, 8809, 65024, 2560, 65, 97, 98, 99, 101, 102, 107, 111, 115, 121, 9958, 9963, 10015, 10020, 10026, 10060, 10065, 10085, 10147, 10171, 114, 114, 59, 32768, 8660, 1024, 105, 108, 109, 114, 9972, 9978, 9982, 9988, 114, 115, 112, 59, 32768, 8202, 102, 59, 32768, 189, 105, 108, 116, 59, 32768, 8459, 512, 100, 114, 9993, 9998, 99, 121, 59, 32768, 1098, 768, 59, 99, 119, 10005, 10007, 10012, 32768, 8596, 105, 114, 59, 32768, 10568, 59, 32768, 8621, 97, 114, 59, 32768, 8463, 105, 114, 99, 59, 32768, 293, 768, 97, 108, 114, 10033, 10048, 10054, 114, 116, 115, 512, 59, 117, 10041, 10043, 32768, 9829, 105, 116, 59, 32768, 9829, 108, 105, 112, 59, 32768, 8230, 99, 111, 110, 59, 32768, 8889, 114, 59, 32896, 55349, 56613, 115, 512, 101, 119, 10071, 10078, 97, 114, 111, 119, 59, 32768, 10533, 97, 114, 111, 119, 59, 32768, 10534, 1280, 97, 109, 111, 112, 114, 10096, 10101, 10107, 10136, 10141, 114, 114, 59, 32768, 8703, 116, 104, 116, 59, 32768, 8763, 107, 512, 108, 114, 10113, 10124, 101, 102, 116, 97, 114, 114, 111, 119, 59, 32768, 8617, 105, 103, 104, 116, 97, 114, 114, 111, 119, 59, 32768, 8618, 102, 59, 32896, 55349, 56665, 98, 97, 114, 59, 32768, 8213, 768, 99, 108, 116, 10154, 10159, 10165, 114, 59, 32896, 55349, 56509, 97, 115, 104, 59, 32768, 8463, 114, 111, 107, 59, 32768, 295, 512, 98, 112, 10176, 10182, 117, 108, 108, 59, 32768, 8259, 104, 101, 110, 59, 32768, 8208, 5426, 10211, 0, 10220, 0, 10239, 10255, 10267, 0, 10276, 10312, 0, 0, 10318, 10371, 10458, 10485, 10491, 0, 10500, 10545, 10558, 99, 117, 116, 101, 33024, 237, 59, 32768, 237, 768, 59, 105, 121, 10226, 10228, 10235, 32768, 8291, 114, 99, 33024, 238, 59, 32768, 238, 59, 32768, 1080, 512, 99, 120, 10243, 10247, 121, 59, 32768, 1077, 99, 108, 33024, 161, 59, 32768, 161, 512, 102, 114, 10259, 10262, 59, 32768, 8660, 59, 32896, 55349, 56614, 114, 97, 118, 101, 33024, 236, 59, 32768, 236, 1024, 59, 105, 110, 111, 10284, 10286, 10300, 10306, 32768, 8520, 512, 105, 110, 10291, 10296, 110, 116, 59, 32768, 10764, 116, 59, 32768, 8749, 102, 105, 110, 59, 32768, 10716, 116, 97, 59, 32768, 8489, 108, 105, 103, 59, 32768, 307, 768, 97, 111, 112, 10324, 10361, 10365, 768, 99, 103, 116, 10331, 10335, 10357, 114, 59, 32768, 299, 768, 101, 108, 112, 10342, 10345, 10351, 59, 32768, 8465, 105, 110, 101, 59, 32768, 8464, 97, 114, 116, 59, 32768, 8465, 104, 59, 32768, 305, 102, 59, 32768, 8887, 101, 100, 59, 32768, 437, 1280, 59, 99, 102, 111, 116, 10381, 10383, 10389, 10403, 10409, 32768, 8712, 97, 114, 101, 59, 32768, 8453, 105, 110, 512, 59, 116, 10396, 10398, 32768, 8734, 105, 101, 59, 32768, 10717, 100, 111, 116, 59, 32768, 305, 1280, 59, 99, 101, 108, 112, 10420, 10422, 10427, 10444, 10451, 32768, 8747, 97, 108, 59, 32768, 8890, 512, 103, 114, 10432, 10438, 101, 114, 115, 59, 32768, 8484, 99, 97, 108, 59, 32768, 8890, 97, 114, 104, 107, 59, 32768, 10775, 114, 111, 100, 59, 32768, 10812, 1024, 99, 103, 112, 116, 10466, 10470, 10475, 10480, 121, 59, 32768, 1105, 111, 110, 59, 32768, 303, 102, 59, 32896, 55349, 56666, 97, 59, 32768, 953, 114, 111, 100, 59, 32768, 10812, 117, 101, 115, 116, 33024, 191, 59, 32768, 191, 512, 99, 105, 10504, 10509, 114, 59, 32896, 55349, 56510, 110, 1280, 59, 69, 100, 115, 118, 10521, 10523, 10526, 10531, 10541, 32768, 8712, 59, 32768, 8953, 111, 116, 59, 32768, 8949, 512, 59, 118, 10536, 10538, 32768, 8948, 59, 32768, 8947, 59, 32768, 8712, 512, 59, 105, 10549, 10551, 32768, 8290, 108, 100, 101, 59, 32768, 297, 828, 10562, 0, 10567, 99, 121, 59, 32768, 1110, 108, 33024, 239, 59, 32768, 239, 1536, 99, 102, 109, 111, 115, 117, 10585, 10598, 10603, 10609, 10615, 10630, 512, 105, 121, 10590, 10595, 114, 99, 59, 32768, 309, 59, 32768, 1081, 114, 59, 32896, 55349, 56615, 97, 116, 104, 59, 32768, 567, 112, 102, 59, 32896, 55349, 56667, 820, 10620, 0, 10625, 114, 59, 32896, 55349, 56511, 114, 99, 121, 59, 32768, 1112, 107, 99, 121, 59, 32768, 1108, 2048, 97, 99, 102, 103, 104, 106, 111, 115, 10653, 10666, 10680, 10685, 10692, 10697, 10702, 10708, 112, 112, 97, 512, 59, 118, 10661, 10663, 32768, 954, 59, 32768, 1008, 512, 101, 121, 10671, 10677, 100, 105, 108, 59, 32768, 311, 59, 32768, 1082, 114, 59, 32896, 55349, 56616, 114, 101, 101, 110, 59, 32768, 312, 99, 121, 59, 32768, 1093, 99, 121, 59, 32768, 1116, 112, 102, 59, 32896, 55349, 56668, 99, 114, 59, 32896, 55349, 56512, 5888, 65, 66, 69, 72, 97, 98, 99, 100, 101, 102, 103, 104, 106, 108, 109, 110, 111, 112, 114, 115, 116, 117, 118, 10761, 10783, 10789, 10799, 10804, 10957, 11011, 11047, 11094, 11349, 11372, 11382, 11409, 11414, 11451, 11478, 11526, 11698, 11711, 11755, 11823, 11910, 11929, 768, 97, 114, 116, 10768, 10773, 10777, 114, 114, 59, 32768, 8666, 114, 59, 32768, 8656, 97, 105, 108, 59, 32768, 10523, 97, 114, 114, 59, 32768, 10510, 512, 59, 103, 10794, 10796, 32768, 8806, 59, 32768, 10891, 97, 114, 59, 32768, 10594, 4660, 10824, 0, 10830, 0, 10838, 0, 0, 0, 0, 0, 10844, 10850, 0, 10867, 10870, 10877, 0, 10933, 117, 116, 101, 59, 32768, 314, 109, 112, 116, 121, 118, 59, 32768, 10676, 114, 97, 110, 59, 32768, 8466, 98, 100, 97, 59, 32768, 955, 103, 768, 59, 100, 108, 10857, 10859, 10862, 32768, 10216, 59, 32768, 10641, 101, 59, 32768, 10216, 59, 32768, 10885, 117, 111, 33024, 171, 59, 32768, 171, 114, 2048, 59, 98, 102, 104, 108, 112, 115, 116, 10894, 10896, 10907, 10911, 10915, 10919, 10923, 10928, 32768, 8592, 512, 59, 102, 10901, 10903, 32768, 8676, 115, 59, 32768, 10527, 115, 59, 32768, 10525, 107, 59, 32768, 8617, 112, 59, 32768, 8619, 108, 59, 32768, 10553, 105, 109, 59, 32768, 10611, 108, 59, 32768, 8610, 768, 59, 97, 101, 10939, 10941, 10946, 32768, 10923, 105, 108, 59, 32768, 10521, 512, 59, 115, 10951, 10953, 32768, 10925, 59, 32896, 10925, 65024, 768, 97, 98, 114, 10964, 10969, 10974, 114, 114, 59, 32768, 10508, 114, 107, 59, 32768, 10098, 512, 97, 107, 10979, 10991, 99, 512, 101, 107, 10985, 10988, 59, 32768, 123, 59, 32768, 91, 512, 101, 115, 10996, 10999, 59, 32768, 10635, 108, 512, 100, 117, 11005, 11008, 59, 32768, 10639, 59, 32768, 10637, 1024, 97, 101, 117, 121, 11020, 11026, 11040, 11044, 114, 111, 110, 59, 32768, 318, 512, 100, 105, 11031, 11036, 105, 108, 59, 32768, 316, 108, 59, 32768, 8968, 98, 59, 32768, 123, 59, 32768, 1083, 1024, 99, 113, 114, 115, 11056, 11060, 11072, 11090, 97, 59, 32768, 10550, 117, 111, 512, 59, 114, 11067, 11069, 32768, 8220, 59, 32768, 8222, 512, 100, 117, 11077, 11083, 104, 97, 114, 59, 32768, 10599, 115, 104, 97, 114, 59, 32768, 10571, 104, 59, 32768, 8626, 1280, 59, 102, 103, 113, 115, 11105, 11107, 11228, 11231, 11250, 32768, 8804, 116, 1280, 97, 104, 108, 114, 116, 11119, 11136, 11157, 11169, 11216, 114, 114, 111, 119, 512, 59, 116, 11128, 11130, 32768, 8592, 97, 105, 108, 59, 32768, 8610, 97, 114, 112, 111, 111, 110, 512, 100, 117, 11147, 11153, 111, 119, 110, 59, 32768, 8637, 112, 59, 32768, 8636, 101, 102, 116, 97, 114, 114, 111, 119, 115, 59, 32768, 8647, 105, 103, 104, 116, 768, 97, 104, 115, 11180, 11194, 11204, 114, 114, 111, 119, 512, 59, 115, 11189, 11191, 32768, 8596, 59, 32768, 8646, 97, 114, 112, 111, 111, 110, 115, 59, 32768, 8651, 113, 117, 105, 103, 97, 114, 114, 111, 119, 59, 32768, 8621, 104, 114, 101, 101, 116, 105, 109, 101, 115, 59, 32768, 8907, 59, 32768, 8922, 768, 59, 113, 115, 11238, 11240, 11243, 32768, 8804, 59, 32768, 8806, 108, 97, 110, 116, 59, 32768, 10877, 1280, 59, 99, 100, 103, 115, 11261, 11263, 11267, 11286, 11298, 32768, 10877, 99, 59, 32768, 10920, 111, 116, 512, 59, 111, 11274, 11276, 32768, 10879, 512, 59, 114, 11281, 11283, 32768, 10881, 59, 32768, 10883, 512, 59, 101, 11291, 11294, 32896, 8922, 65024, 115, 59, 32768, 10899, 1280, 97, 100, 101, 103, 115, 11309, 11317, 11322, 11339, 11344, 112, 112, 114, 111, 120, 59, 32768, 10885, 111, 116, 59, 32768, 8918, 113, 512, 103, 113, 11328, 11333, 116, 114, 59, 32768, 8922, 103, 116, 114, 59, 32768, 10891, 116, 114, 59, 32768, 8822, 105, 109, 59, 32768, 8818, 768, 105, 108, 114, 11356, 11362, 11368, 115, 104, 116, 59, 32768, 10620, 111, 111, 114, 59, 32768, 8970, 59, 32896, 55349, 56617, 512, 59, 69, 11377, 11379, 32768, 8822, 59, 32768, 10897, 562, 11386, 11405, 114, 512, 100, 117, 11391, 11394, 59, 32768, 8637, 512, 59, 108, 11399, 11401, 32768, 8636, 59, 32768, 10602, 108, 107, 59, 32768, 9604, 99, 121, 59, 32768, 1113, 1280, 59, 97, 99, 104, 116, 11425, 11427, 11432, 11440, 11446, 32768, 8810, 114, 114, 59, 32768, 8647, 111, 114, 110, 101, 114, 59, 32768, 8990, 97, 114, 100, 59, 32768, 10603, 114, 105, 59, 32768, 9722, 512, 105, 111, 11456, 11462, 100, 111, 116, 59, 32768, 320, 117, 115, 116, 512, 59, 97, 11470, 11472, 32768, 9136, 99, 104, 101, 59, 32768, 9136, 1024, 69, 97, 101, 115, 11487, 11490, 11504, 11521, 59, 32768, 8808, 112, 512, 59, 112, 11496, 11498, 32768, 10889, 114, 111, 120, 59, 32768, 10889, 512, 59, 113, 11509, 11511, 32768, 10887, 512, 59, 113, 11516, 11518, 32768, 10887, 59, 32768, 8808, 105, 109, 59, 32768, 8934, 2048, 97, 98, 110, 111, 112, 116, 119, 122, 11543, 11556, 11561, 11616, 11640, 11660, 11667, 11680, 512, 110, 114, 11548, 11552, 103, 59, 32768, 10220, 114, 59, 32768, 8701, 114, 107, 59, 32768, 10214, 103, 768, 108, 109, 114, 11569, 11596, 11604, 101, 102, 116, 512, 97, 114, 11577, 11584, 114, 114, 111, 119, 59, 32768, 10229, 105, 103, 104, 116, 97, 114, 114, 111, 119, 59, 32768, 10231, 97, 112, 115, 116, 111, 59, 32768, 10236, 105, 103, 104, 116, 97, 114, 114, 111, 119, 59, 32768, 10230, 112, 97, 114, 114, 111, 119, 512, 108, 114, 11627, 11633, 101, 102, 116, 59, 32768, 8619, 105, 103, 104, 116, 59, 32768, 8620, 768, 97, 102, 108, 11647, 11651, 11655, 114, 59, 32768, 10629, 59, 32896, 55349, 56669, 117, 115, 59, 32768, 10797, 105, 109, 101, 115, 59, 32768, 10804, 562, 11671, 11676, 115, 116, 59, 32768, 8727, 97, 114, 59, 32768, 95, 768, 59, 101, 102, 11687, 11689, 11695, 32768, 9674, 110, 103, 101, 59, 32768, 9674, 59, 32768, 10731, 97, 114, 512, 59, 108, 11705, 11707, 32768, 40, 116, 59, 32768, 10643, 1280, 97, 99, 104, 109, 116, 11722, 11727, 11735, 11747, 11750, 114, 114, 59, 32768, 8646, 111, 114, 110, 101, 114, 59, 32768, 8991, 97, 114, 512, 59, 100, 11742, 11744, 32768, 8651, 59, 32768, 10605, 59, 32768, 8206, 114, 105, 59, 32768, 8895, 1536, 97, 99, 104, 105, 113, 116, 11768, 11774, 11779, 11782, 11798, 11817, 113, 117, 111, 59, 32768, 8249, 114, 59, 32896, 55349, 56513, 59, 32768, 8624, 109, 768, 59, 101, 103, 11790, 11792, 11795, 32768, 8818, 59, 32768, 10893, 59, 32768, 10895, 512, 98, 117, 11803, 11806, 59, 32768, 91, 111, 512, 59, 114, 11812, 11814, 32768, 8216, 59, 32768, 8218, 114, 111, 107, 59, 32768, 322, 34816, 60, 59, 99, 100, 104, 105, 108, 113, 114, 11841, 11843, 11855, 11860, 11866, 11872, 11878, 11885, 32768, 60, 512, 99, 105, 11848, 11851, 59, 32768, 10918, 114, 59, 32768, 10873, 111, 116, 59, 32768, 8918, 114, 101, 101, 59, 32768, 8907, 109, 101, 115, 59, 32768, 8905, 97, 114, 114, 59, 32768, 10614, 117, 101, 115, 116, 59, 32768, 10875, 512, 80, 105, 11890, 11895, 97, 114, 59, 32768, 10646, 768, 59, 101, 102, 11902, 11904, 11907, 32768, 9667, 59, 32768, 8884, 59, 32768, 9666, 114, 512, 100, 117, 11916, 11923, 115, 104, 97, 114, 59, 32768, 10570, 104, 97, 114, 59, 32768, 10598, 512, 101, 110, 11934, 11944, 114, 116, 110, 101, 113, 113, 59, 32896, 8808, 65024, 69, 59, 32896, 8808, 65024, 3584, 68, 97, 99, 100, 101, 102, 104, 105, 108, 110, 111, 112, 115, 117, 11978, 11984, 12061, 12075, 12081, 12095, 12100, 12104, 12170, 12181, 12188, 12204, 12207, 12223, 68, 111, 116, 59, 32768, 8762, 1024, 99, 108, 112, 114, 11993, 11999, 12019, 12055, 114, 33024, 175, 59, 32768, 175, 512, 101, 116, 12004, 12007, 59, 32768, 9794, 512, 59, 101, 12012, 12014, 32768, 10016, 115, 101, 59, 32768, 10016, 512, 59, 115, 12024, 12026, 32768, 8614, 116, 111, 1024, 59, 100, 108, 117, 12037, 12039, 12045, 12051, 32768, 8614, 111, 119, 110, 59, 32768, 8615, 101, 102, 116, 59, 32768, 8612, 112, 59, 32768, 8613, 107, 101, 114, 59, 32768, 9646, 512, 111, 121, 12066, 12072, 109, 109, 97, 59, 32768, 10793, 59, 32768, 1084, 97, 115, 104, 59, 32768, 8212, 97, 115, 117, 114, 101, 100, 97, 110, 103, 108, 101, 59, 32768, 8737, 114, 59, 32896, 55349, 56618, 111, 59, 32768, 8487, 768, 99, 100, 110, 12111, 12118, 12146, 114, 111, 33024, 181, 59, 32768, 181, 1024, 59, 97, 99, 100, 12127, 12129, 12134, 12139, 32768, 8739, 115, 116, 59, 32768, 42, 105, 114, 59, 32768, 10992, 111, 116, 33024, 183, 59, 32768, 183, 117, 115, 768, 59, 98, 100, 12155, 12157, 12160, 32768, 8722, 59, 32768, 8863, 512, 59, 117, 12165, 12167, 32768, 8760, 59, 32768, 10794, 564, 12174, 12178, 112, 59, 32768, 10971, 114, 59, 32768, 8230, 112, 108, 117, 115, 59, 32768, 8723, 512, 100, 112, 12193, 12199, 101, 108, 115, 59, 32768, 8871, 102, 59, 32896, 55349, 56670, 59, 32768, 8723, 512, 99, 116, 12212, 12217, 114, 59, 32896, 55349, 56514, 112, 111, 115, 59, 32768, 8766, 768, 59, 108, 109, 12230, 12232, 12240, 32768, 956, 116, 105, 109, 97, 112, 59, 32768, 8888, 97, 112, 59, 32768, 8888, 6144, 71, 76, 82, 86, 97, 98, 99, 100, 101, 102, 103, 104, 105, 106, 108, 109, 111, 112, 114, 115, 116, 117, 118, 119, 12294, 12315, 12364, 12376, 12393, 12472, 12496, 12547, 12553, 12636, 12641, 12703, 12725, 12747, 12752, 12876, 12881, 12957, 13033, 13089, 13294, 13359, 13384, 13499, 512, 103, 116, 12299, 12303, 59, 32896, 8921, 824, 512, 59, 118, 12308, 12311, 32896, 8811, 8402, 59, 32896, 8811, 824, 768, 101, 108, 116, 12322, 12348, 12352, 102, 116, 512, 97, 114, 12329, 12336, 114, 114, 111, 119, 59, 32768, 8653, 105, 103, 104, 116, 97, 114, 114, 111, 119, 59, 32768, 8654, 59, 32896, 8920, 824, 512, 59, 118, 12357, 12360, 32896, 8810, 8402, 59, 32896, 8810, 824, 105, 103, 104, 116, 97, 114, 114, 111, 119, 59, 32768, 8655, 512, 68, 100, 12381, 12387, 97, 115, 104, 59, 32768, 8879, 97, 115, 104, 59, 32768, 8878, 1280, 98, 99, 110, 112, 116, 12404, 12409, 12415, 12420, 12452, 108, 97, 59, 32768, 8711, 117, 116, 101, 59, 32768, 324, 103, 59, 32896, 8736, 8402, 1280, 59, 69, 105, 111, 112, 12431, 12433, 12437, 12442, 12446, 32768, 8777, 59, 32896, 10864, 824, 100, 59, 32896, 8779, 824, 115, 59, 32768, 329, 114, 111, 120, 59, 32768, 8777, 117, 114, 512, 59, 97, 12459, 12461, 32768, 9838, 108, 512, 59, 115, 12467, 12469, 32768, 9838, 59, 32768, 8469, 836, 12477, 0, 12483, 112, 33024, 160, 59, 32768, 160, 109, 112, 512, 59, 101, 12489, 12492, 32896, 8782, 824, 59, 32896, 8783, 824, 1280, 97, 101, 111, 117, 121, 12507, 12519, 12525, 12540, 12544, 833, 12512, 0, 12515, 59, 32768, 10819, 111, 110, 59, 32768, 328, 100, 105, 108, 59, 32768, 326, 110, 103, 512, 59, 100, 12532, 12534, 32768, 8775, 111, 116, 59, 32896, 10861, 824, 112, 59, 32768, 10818, 59, 32768, 1085, 97, 115, 104, 59, 32768, 8211, 1792, 59, 65, 97, 100, 113, 115, 120, 12568, 12570, 12575, 12596, 12602, 12608, 12623, 32768, 8800, 114, 114, 59, 32768, 8663, 114, 512, 104, 114, 12581, 12585, 107, 59, 32768, 10532, 512, 59, 111, 12590, 12592, 32768, 8599, 119, 59, 32768, 8599, 111, 116, 59, 32896, 8784, 824, 117, 105, 118, 59, 32768, 8802, 512, 101, 105, 12613, 12618, 97, 114, 59, 32768, 10536, 109, 59, 32896, 8770, 824, 105, 115, 116, 512, 59, 115, 12631, 12633, 32768, 8708, 59, 32768, 8708, 114, 59, 32896, 55349, 56619, 1024, 69, 101, 115, 116, 12650, 12654, 12688, 12693, 59, 32896, 8807, 824, 768, 59, 113, 115, 12661, 12663, 12684, 32768, 8817, 768, 59, 113, 115, 12670, 12672, 12676, 32768, 8817, 59, 32896, 8807, 824, 108, 97, 110, 116, 59, 32896, 10878, 824, 59, 32896, 10878, 824, 105, 109, 59, 32768, 8821, 512, 59, 114, 12698, 12700, 32768, 8815, 59, 32768, 8815, 768, 65, 97, 112, 12710, 12715, 12720, 114, 114, 59, 32768, 8654, 114, 114, 59, 32768, 8622, 97, 114, 59, 32768, 10994, 768, 59, 115, 118, 12732, 12734, 12744, 32768, 8715, 512, 59, 100, 12739, 12741, 32768, 8956, 59, 32768, 8954, 59, 32768, 8715, 99, 121, 59, 32768, 1114, 1792, 65, 69, 97, 100, 101, 115, 116, 12767, 12772, 12776, 12781, 12785, 12853, 12858, 114, 114, 59, 32768, 8653, 59, 32896, 8806, 824, 114, 114, 59, 32768, 8602, 114, 59, 32768, 8229, 1024, 59, 102, 113, 115, 12794, 12796, 12821, 12842, 32768, 8816, 116, 512, 97, 114, 12802, 12809, 114, 114, 111, 119, 59, 32768, 8602, 105, 103, 104, 116, 97, 114, 114, 111, 119, 59, 32768, 8622, 768, 59, 113, 115, 12828, 12830, 12834, 32768, 8816, 59, 32896, 8806, 824, 108, 97, 110, 116, 59, 32896, 10877, 824, 512, 59, 115, 12847, 12850, 32896, 10877, 824, 59, 32768, 8814, 105, 109, 59, 32768, 8820, 512, 59, 114, 12863, 12865, 32768, 8814, 105, 512, 59, 101, 12871, 12873, 32768, 8938, 59, 32768, 8940, 105, 100, 59, 32768, 8740, 512, 112, 116, 12886, 12891, 102, 59, 32896, 55349, 56671, 33536, 172, 59, 105, 110, 12899, 12901, 12936, 32768, 172, 110, 1024, 59, 69, 100, 118, 12911, 12913, 12917, 12923, 32768, 8713, 59, 32896, 8953, 824, 111, 116, 59, 32896, 8949, 824, 818, 12928, 12931, 12934, 59, 32768, 8713, 59, 32768, 8951, 59, 32768, 8950, 105, 512, 59, 118, 12942, 12944, 32768, 8716, 818, 12949, 12952, 12955, 59, 32768, 8716, 59, 32768, 8958, 59, 32768, 8957, 768, 97, 111, 114, 12964, 12992, 12999, 114, 1024, 59, 97, 115, 116, 12974, 12976, 12983, 12988, 32768, 8742, 108, 108, 101, 108, 59, 32768, 8742, 108, 59, 32896, 11005, 8421, 59, 32896, 8706, 824, 108, 105, 110, 116, 59, 32768, 10772, 768, 59, 99, 101, 13006, 13008, 13013, 32768, 8832, 117, 101, 59, 32768, 8928, 512, 59, 99, 13018, 13021, 32896, 10927, 824, 512, 59, 101, 13026, 13028, 32768, 8832, 113, 59, 32896, 10927, 824, 1024, 65, 97, 105, 116, 13042, 13047, 13066, 13077, 114, 114, 59, 32768, 8655, 114, 114, 768, 59, 99, 119, 13056, 13058, 13062, 32768, 8603, 59, 32896, 10547, 824, 59, 32896, 8605, 824, 103, 104, 116, 97, 114, 114, 111, 119, 59, 32768, 8603, 114, 105, 512, 59, 101, 13084, 13086, 32768, 8939, 59, 32768, 8941, 1792, 99, 104, 105, 109, 112, 113, 117, 13104, 13128, 13151, 13169, 13174, 13179, 13194, 1024, 59, 99, 101, 114, 13113, 13115, 13120, 13124, 32768, 8833, 117, 101, 59, 32768, 8929, 59, 32896, 10928, 824, 59, 32896, 55349, 56515, 111, 114, 116, 1086, 13137, 0, 0, 13142, 105, 100, 59, 32768, 8740, 97, 114, 97, 108, 108, 101, 108, 59, 32768, 8742, 109, 512, 59, 101, 13157, 13159, 32768, 8769, 512, 59, 113, 13164, 13166, 32768, 8772, 59, 32768, 8772, 105, 100, 59, 32768, 8740, 97, 114, 59, 32768, 8742, 115, 117, 512, 98, 112, 13186, 13190, 101, 59, 32768, 8930, 101, 59, 32768, 8931, 768, 98, 99, 112, 13201, 13241, 13254, 1024, 59, 69, 101, 115, 13210, 13212, 13216, 13219, 32768, 8836, 59, 32896, 10949, 824, 59, 32768, 8840, 101, 116, 512, 59, 101, 13226, 13229, 32896, 8834, 8402, 113, 512, 59, 113, 13235, 13237, 32768, 8840, 59, 32896, 10949, 824, 99, 512, 59, 101, 13247, 13249, 32768, 8833, 113, 59, 32896, 10928, 824, 1024, 59, 69, 101, 115, 13263, 13265, 13269, 13272, 32768, 8837, 59, 32896, 10950, 824, 59, 32768, 8841, 101, 116, 512, 59, 101, 13279, 13282, 32896, 8835, 8402, 113, 512, 59, 113, 13288, 13290, 32768, 8841, 59, 32896, 10950, 824, 1024, 103, 105, 108, 114, 13303, 13307, 13315, 13319, 108, 59, 32768, 8825, 108, 100, 101, 33024, 241, 59, 32768, 241, 103, 59, 32768, 8824, 105, 97, 110, 103, 108, 101, 512, 108, 114, 13330, 13344, 101, 102, 116, 512, 59, 101, 13338, 13340, 32768, 8938, 113, 59, 32768, 8940, 105, 103, 104, 116, 512, 59, 101, 13353, 13355, 32768, 8939, 113, 59, 32768, 8941, 512, 59, 109, 13364, 13366, 32768, 957, 768, 59, 101, 115, 13373, 13375, 13380, 32768, 35, 114, 111, 59, 32768, 8470, 112, 59, 32768, 8199, 2304, 68, 72, 97, 100, 103, 105, 108, 114, 115, 13403, 13409, 13415, 13420, 13426, 13439, 13446, 13476, 13493, 97, 115, 104, 59, 32768, 8877, 97, 114, 114, 59, 32768, 10500, 112, 59, 32896, 8781, 8402, 97, 115, 104, 59, 32768, 8876, 512, 101, 116, 13431, 13435, 59, 32896, 8805, 8402, 59, 32896, 62, 8402, 110, 102, 105, 110, 59, 32768, 10718, 768, 65, 101, 116, 13453, 13458, 13462, 114, 114, 59, 32768, 10498, 59, 32896, 8804, 8402, 512, 59, 114, 13467, 13470, 32896, 60, 8402, 105, 101, 59, 32896, 8884, 8402, 512, 65, 116, 13481, 13486, 114, 114, 59, 32768, 10499, 114, 105, 101, 59, 32896, 8885, 8402, 105, 109, 59, 32896, 8764, 8402, 768, 65, 97, 110, 13506, 13511, 13532, 114, 114, 59, 32768, 8662, 114, 512, 104, 114, 13517, 13521, 107, 59, 32768, 10531, 512, 59, 111, 13526, 13528, 32768, 8598, 119, 59, 32768, 8598, 101, 97, 114, 59, 32768, 10535, 9252, 13576, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 13579, 0, 13596, 13617, 13653, 13659, 13673, 13695, 13708, 0, 0, 13713, 13750, 0, 13788, 13794, 0, 13815, 13890, 13913, 13937, 13944, 59, 32768, 9416, 512, 99, 115, 13583, 13591, 117, 116, 101, 33024, 243, 59, 32768, 243, 116, 59, 32768, 8859, 512, 105, 121, 13600, 13613, 114, 512, 59, 99, 13606, 13608, 32768, 8858, 33024, 244, 59, 32768, 244, 59, 32768, 1086, 1280, 97, 98, 105, 111, 115, 13627, 13632, 13638, 13642, 13646, 115, 104, 59, 32768, 8861, 108, 97, 99, 59, 32768, 337, 118, 59, 32768, 10808, 116, 59, 32768, 8857, 111, 108, 100, 59, 32768, 10684, 108, 105, 103, 59, 32768, 339, 512, 99, 114, 13663, 13668, 105, 114, 59, 32768, 10687, 59, 32896, 55349, 56620, 1600, 13680, 0, 0, 13684, 0, 13692, 110, 59, 32768, 731, 97, 118, 101, 33024, 242, 59, 32768, 242, 59, 32768, 10689, 512, 98, 109, 13699, 13704, 97, 114, 59, 32768, 10677, 59, 32768, 937, 110, 116, 59, 32768, 8750, 1024, 97, 99, 105, 116, 13721, 13726, 13741, 13746, 114, 114, 59, 32768, 8634, 512, 105, 114, 13731, 13735, 114, 59, 32768, 10686, 111, 115, 115, 59, 32768, 10683, 110, 101, 59, 32768, 8254, 59, 32768, 10688, 768, 97, 101, 105, 13756, 13761, 13766, 99, 114, 59, 32768, 333, 103, 97, 59, 32768, 969, 768, 99, 100, 110, 13773, 13779, 13782, 114, 111, 110, 59, 32768, 959, 59, 32768, 10678, 117, 115, 59, 32768, 8854, 112, 102, 59, 32896, 55349, 56672, 768, 97, 101, 108, 13800, 13804, 13809, 114, 59, 32768, 10679, 114, 112, 59, 32768, 10681, 117, 115, 59, 32768, 8853, 1792, 59, 97, 100, 105, 111, 115, 118, 13829, 13831, 13836, 13869, 13875, 13879, 13886, 32768, 8744, 114, 114, 59, 32768, 8635, 1024, 59, 101, 102, 109, 13845, 13847, 13859, 13864, 32768, 10845, 114, 512, 59, 111, 13853, 13855, 32768, 8500, 102, 59, 32768, 8500, 33024, 170, 59, 32768, 170, 33024, 186, 59, 32768, 186, 103, 111, 102, 59, 32768, 8886, 114, 59, 32768, 10838, 108, 111, 112, 101, 59, 32768, 10839, 59, 32768, 10843, 768, 99, 108, 111, 13896, 13900, 13908, 114, 59, 32768, 8500, 97, 115, 104, 33024, 248, 59, 32768, 248, 108, 59, 32768, 8856, 105, 573, 13917, 13924, 100, 101, 33024, 245, 59, 32768, 245, 101, 115, 512, 59, 97, 13930, 13932, 32768, 8855, 115, 59, 32768, 10806, 109, 108, 33024, 246, 59, 32768, 246, 98, 97, 114, 59, 32768, 9021, 5426, 13972, 0, 14013, 0, 14017, 14053, 0, 14058, 14086, 0, 0, 14107, 14199, 0, 14202, 0, 0, 14229, 14425, 0, 14438, 114, 1024, 59, 97, 115, 116, 13981, 13983, 13997, 14009, 32768, 8741, 33280, 182, 59, 108, 13989, 13991, 32768, 182, 108, 101, 108, 59, 32768, 8741, 1082, 14003, 0, 0, 14007, 109, 59, 32768, 10995, 59, 32768, 11005, 59, 32768, 8706, 121, 59, 32768, 1087, 114, 1280, 99, 105, 109, 112, 116, 14028, 14033, 14038, 14043, 14046, 110, 116, 59, 32768, 37, 111, 100, 59, 32768, 46, 105, 108, 59, 32768, 8240, 59, 32768, 8869, 101, 110, 107, 59, 32768, 8241, 114, 59, 32896, 55349, 56621, 768, 105, 109, 111, 14064, 14074, 14080, 512, 59, 118, 14069, 14071, 32768, 966, 59, 32768, 981, 109, 97, 116, 59, 32768, 8499, 110, 101, 59, 32768, 9742, 768, 59, 116, 118, 14092, 14094, 14103, 32768, 960, 99, 104, 102, 111, 114, 107, 59, 32768, 8916, 59, 32768, 982, 512, 97, 117, 14111, 14132, 110, 512, 99, 107, 14117, 14128, 107, 512, 59, 104, 14123, 14125, 32768, 8463, 59, 32768, 8462, 118, 59, 32768, 8463, 115, 2304, 59, 97, 98, 99, 100, 101, 109, 115, 116, 14152, 14154, 14160, 14163, 14168, 14179, 14182, 14188, 14193, 32768, 43, 99, 105, 114, 59, 32768, 10787, 59, 32768, 8862, 105, 114, 59, 32768, 10786, 512, 111, 117, 14173, 14176, 59, 32768, 8724, 59, 32768, 10789, 59, 32768, 10866, 110, 33024, 177, 59, 32768, 177, 105, 109, 59, 32768, 10790, 119, 111, 59, 32768, 10791, 59, 32768, 177, 768, 105, 112, 117, 14208, 14216, 14221, 110, 116, 105, 110, 116, 59, 32768, 10773, 102, 59, 32896, 55349, 56673, 110, 100, 33024, 163, 59, 32768, 163, 2560, 59, 69, 97, 99, 101, 105, 110, 111, 115, 117, 14249, 14251, 14254, 14258, 14263, 14336, 14348, 14367, 14413, 14418, 32768, 8826, 59, 32768, 10931, 112, 59, 32768, 10935, 117, 101, 59, 32768, 8828, 512, 59, 99, 14268, 14270, 32768, 10927, 1536, 59, 97, 99, 101, 110, 115, 14283, 14285, 14293, 14302, 14306, 14331, 32768, 8826, 112, 112, 114, 111, 120, 59, 32768, 10935, 117, 114, 108, 121, 101, 113, 59, 32768, 8828, 113, 59, 32768, 10927, 768, 97, 101, 115, 14313, 14321, 14326, 112, 112, 114, 111, 120, 59, 32768, 10937, 113, 113, 59, 32768, 10933, 105, 109, 59, 32768, 8936, 105, 109, 59, 32768, 8830, 109, 101, 512, 59, 115, 14343, 14345, 32768, 8242, 59, 32768, 8473, 768, 69, 97, 115, 14355, 14358, 14362, 59, 32768, 10933, 112, 59, 32768, 10937, 105, 109, 59, 32768, 8936, 768, 100, 102, 112, 14374, 14377, 14402, 59, 32768, 8719, 768, 97, 108, 115, 14384, 14390, 14396, 108, 97, 114, 59, 32768, 9006, 105, 110, 101, 59, 32768, 8978, 117, 114, 102, 59, 32768, 8979, 512, 59, 116, 14407, 14409, 32768, 8733, 111, 59, 32768, 8733, 105, 109, 59, 32768, 8830, 114, 101, 108, 59, 32768, 8880, 512, 99, 105, 14429, 14434, 114, 59, 32896, 55349, 56517, 59, 32768, 968, 110, 99, 115, 112, 59, 32768, 8200, 1536, 102, 105, 111, 112, 115, 117, 14457, 14462, 14467, 14473, 14480, 14486, 114, 59, 32896, 55349, 56622, 110, 116, 59, 32768, 10764, 112, 102, 59, 32896, 55349, 56674, 114, 105, 109, 101, 59, 32768, 8279, 99, 114, 59, 32896, 55349, 56518, 768, 97, 101, 111, 14493, 14513, 14526, 116, 512, 101, 105, 14499, 14508, 114, 110, 105, 111, 110, 115, 59, 32768, 8461, 110, 116, 59, 32768, 10774, 115, 116, 512, 59, 101, 14520, 14522, 32768, 63, 113, 59, 32768, 8799, 116, 33024, 34, 59, 32768, 34, 5376, 65, 66, 72, 97, 98, 99, 100, 101, 102, 104, 105, 108, 109, 110, 111, 112, 114, 115, 116, 117, 120, 14575, 14597, 14603, 14608, 14775, 14829, 14865, 14901, 14943, 14966, 15000, 15139, 15159, 15176, 15182, 15236, 15261, 15267, 15309, 15352, 15360, 768, 97, 114, 116, 14582, 14587, 14591, 114, 114, 59, 32768, 8667, 114, 59, 32768, 8658, 97, 105, 108, 59, 32768, 10524, 97, 114, 114, 59, 32768, 10511, 97, 114, 59, 32768, 10596, 1792, 99, 100, 101, 110, 113, 114, 116, 14623, 14637, 14642, 14650, 14672, 14679, 14751, 512, 101, 117, 14628, 14632, 59, 32896, 8765, 817, 116, 101, 59, 32768, 341, 105, 99, 59, 32768, 8730, 109, 112, 116, 121, 118, 59, 32768, 10675, 103, 1024, 59, 100, 101, 108, 14660, 14662, 14665, 14668, 32768, 10217, 59, 32768, 10642, 59, 32768, 10661, 101, 59, 32768, 10217, 117, 111, 33024, 187, 59, 32768, 187, 114, 2816, 59, 97, 98, 99, 102, 104, 108, 112, 115, 116, 119, 14703, 14705, 14709, 14720, 14723, 14727, 14731, 14735, 14739, 14744, 14748, 32768, 8594, 112, 59, 32768, 10613, 512, 59, 102, 14714, 14716, 32768, 8677, 115, 59, 32768, 10528, 59, 32768, 10547, 115, 59, 32768, 10526, 107, 59, 32768, 8618, 112, 59, 32768, 8620, 108, 59, 32768, 10565, 105, 109, 59, 32768, 10612, 108, 59, 32768, 8611, 59, 32768, 8605, 512, 97, 105, 14756, 14761, 105, 108, 59, 32768, 10522, 111, 512, 59, 110, 14767, 14769, 32768, 8758, 97, 108, 115, 59, 32768, 8474, 768, 97, 98, 114, 14782, 14787, 14792, 114, 114, 59, 32768, 10509, 114, 107, 59, 32768, 10099, 512, 97, 107, 14797, 14809, 99, 512, 101, 107, 14803, 14806, 59, 32768, 125, 59, 32768, 93, 512, 101, 115, 14814, 14817, 59, 32768, 10636, 108, 512, 100, 117, 14823, 14826, 59, 32768, 10638, 59, 32768, 10640, 1024, 97, 101, 117, 121, 14838, 14844, 14858, 14862, 114, 111, 110, 59, 32768, 345, 512, 100, 105, 14849, 14854, 105, 108, 59, 32768, 343, 108, 59, 32768, 8969, 98, 59, 32768, 125, 59, 32768, 1088, 1024, 99, 108, 113, 115, 14874, 14878, 14885, 14897, 97, 59, 32768, 10551, 100, 104, 97, 114, 59, 32768, 10601, 117, 111, 512, 59, 114, 14892, 14894, 32768, 8221, 59, 32768, 8221, 104, 59, 32768, 8627, 768, 97, 99, 103, 14908, 14934, 14938, 108, 1024, 59, 105, 112, 115, 14918, 14920, 14925, 14931, 32768, 8476, 110, 101, 59, 32768, 8475, 97, 114, 116, 59, 32768, 8476, 59, 32768, 8477, 116, 59, 32768, 9645, 33024, 174, 59, 32768, 174, 768, 105, 108, 114, 14950, 14956, 14962, 115, 104, 116, 59, 32768, 10621, 111, 111, 114, 59, 32768, 8971, 59, 32896, 55349, 56623, 512, 97, 111, 14971, 14990, 114, 512, 100, 117, 14977, 14980, 59, 32768, 8641, 512, 59, 108, 14985, 14987, 32768, 8640, 59, 32768, 10604, 512, 59, 118, 14995, 14997, 32768, 961, 59, 32768, 1009, 768, 103, 110, 115, 15007, 15123, 15127, 104, 116, 1536, 97, 104, 108, 114, 115, 116, 15022, 15039, 15060, 15086, 15099, 15111, 114, 114, 111, 119, 512, 59, 116, 15031, 15033, 32768, 8594, 97, 105, 108, 59, 32768, 8611, 97, 114, 112, 111, 111, 110, 512, 100, 117, 15050, 15056, 111, 119, 110, 59, 32768, 8641, 112, 59, 32768, 8640, 101, 102, 116, 512, 97, 104, 15068, 15076, 114, 114, 111, 119, 115, 59, 32768, 8644, 97, 114, 112, 111, 111, 110, 115, 59, 32768, 8652, 105, 103, 104, 116, 97, 114, 114, 111, 119, 115, 59, 32768, 8649, 113, 117, 105, 103, 97, 114, 114, 111, 119, 59, 32768, 8605, 104, 114, 101, 101, 116, 105, 109, 101, 115, 59, 32768, 8908, 103, 59, 32768, 730, 105, 110, 103, 100, 111, 116, 115, 101, 113, 59, 32768, 8787, 768, 97, 104, 109, 15146, 15151, 15156, 114, 114, 59, 32768, 8644, 97, 114, 59, 32768, 8652, 59, 32768, 8207, 111, 117, 115, 116, 512, 59, 97, 15168, 15170, 32768, 9137, 99, 104, 101, 59, 32768, 9137, 109, 105, 100, 59, 32768, 10990, 1024, 97, 98, 112, 116, 15191, 15204, 15209, 15229, 512, 110, 114, 15196, 15200, 103, 59, 32768, 10221, 114, 59, 32768, 8702, 114, 107, 59, 32768, 10215, 768, 97, 102, 108, 15216, 15220, 15224, 114, 59, 32768, 10630, 59, 32896, 55349, 56675, 117, 115, 59, 32768, 10798, 105, 109, 101, 115, 59, 32768, 10805, 512, 97, 112, 15241, 15253, 114, 512, 59, 103, 15247, 15249, 32768, 41, 116, 59, 32768, 10644, 111, 108, 105, 110, 116, 59, 32768, 10770, 97, 114, 114, 59, 32768, 8649, 1024, 97, 99, 104, 113, 15276, 15282, 15287, 15290, 113, 117, 111, 59, 32768, 8250, 114, 59, 32896, 55349, 56519, 59, 32768, 8625, 512, 98, 117, 15295, 15298, 59, 32768, 93, 111, 512, 59, 114, 15304, 15306, 32768, 8217, 59, 32768, 8217, 768, 104, 105, 114, 15316, 15322, 15328, 114, 101, 101, 59, 32768, 8908, 109, 101, 115, 59, 32768, 8906, 105, 1024, 59, 101, 102, 108, 15338, 15340, 15343, 15346, 32768, 9657, 59, 32768, 8885, 59, 32768, 9656, 116, 114, 105, 59, 32768, 10702, 108, 117, 104, 97, 114, 59, 32768, 10600, 59, 32768, 8478, 6706, 15391, 15398, 15404, 15499, 15516, 15592, 0, 15606, 15660, 0, 0, 15752, 15758, 0, 15827, 15863, 15886, 16000, 16006, 16038, 16086, 0, 16467, 0, 0, 16506, 99, 117, 116, 101, 59, 32768, 347, 113, 117, 111, 59, 32768, 8218, 2560, 59, 69, 97, 99, 101, 105, 110, 112, 115, 121, 15424, 15426, 15429, 15441, 15446, 15458, 15463, 15482, 15490, 15495, 32768, 8827, 59, 32768, 10932, 833, 15434, 0, 15437, 59, 32768, 10936, 111, 110, 59, 32768, 353, 117, 101, 59, 32768, 8829, 512, 59, 100, 15451, 15453, 32768, 10928, 105, 108, 59, 32768, 351, 114, 99, 59, 32768, 349, 768, 69, 97, 115, 15470, 15473, 15477, 59, 32768, 10934, 112, 59, 32768, 10938, 105, 109, 59, 32768, 8937, 111, 108, 105, 110, 116, 59, 32768, 10771, 105, 109, 59, 32768, 8831, 59, 32768, 1089, 111, 116, 768, 59, 98, 101, 15507, 15509, 15512, 32768, 8901, 59, 32768, 8865, 59, 32768, 10854, 1792, 65, 97, 99, 109, 115, 116, 120, 15530, 15535, 15556, 15562, 15566, 15572, 15587, 114, 114, 59, 32768, 8664, 114, 512, 104, 114, 15541, 15545, 107, 59, 32768, 10533, 512, 59, 111, 15550, 15552, 32768, 8600, 119, 59, 32768, 8600, 116, 33024, 167, 59, 32768, 167, 105, 59, 32768, 59, 119, 97, 114, 59, 32768, 10537, 109, 512, 105, 110, 15578, 15584, 110, 117, 115, 59, 32768, 8726, 59, 32768, 8726, 116, 59, 32768, 10038, 114, 512, 59, 111, 15597, 15600, 32896, 55349, 56624, 119, 110, 59, 32768, 8994, 1024, 97, 99, 111, 121, 15614, 15619, 15632, 15654, 114, 112, 59, 32768, 9839, 512, 104, 121, 15624, 15629, 99, 121, 59, 32768, 1097, 59, 32768, 1096, 114, 116, 1086, 15640, 0, 0, 15645, 105, 100, 59, 32768, 8739, 97, 114, 97, 108, 108, 101, 108, 59, 32768, 8741, 33024, 173, 59, 32768, 173, 512, 103, 109, 15664, 15681, 109, 97, 768, 59, 102, 118, 15673, 15675, 15678, 32768, 963, 59, 32768, 962, 59, 32768, 962, 2048, 59, 100, 101, 103, 108, 110, 112, 114, 15698, 15700, 15705, 15715, 15725, 15735, 15739, 15745, 32768, 8764, 111, 116, 59, 32768, 10858, 512, 59, 113, 15710, 15712, 32768, 8771, 59, 32768, 8771, 512, 59, 69, 15720, 15722, 32768, 10910, 59, 32768, 10912, 512, 59, 69, 15730, 15732, 32768, 10909, 59, 32768, 10911, 101, 59, 32768, 8774, 108, 117, 115, 59, 32768, 10788, 97, 114, 114, 59, 32768, 10610, 97, 114, 114, 59, 32768, 8592, 1024, 97, 101, 105, 116, 15766, 15788, 15796, 15808, 512, 108, 115, 15771, 15783, 108, 115, 101, 116, 109, 105, 110, 117, 115, 59, 32768, 8726, 104, 112, 59, 32768, 10803, 112, 97, 114, 115, 108, 59, 32768, 10724, 512, 100, 108, 15801, 15804, 59, 32768, 8739, 101, 59, 32768, 8995, 512, 59, 101, 15813, 15815, 32768, 10922, 512, 59, 115, 15820, 15822, 32768, 10924, 59, 32896, 10924, 65024, 768, 102, 108, 112, 15833, 15839, 15857, 116, 99, 121, 59, 32768, 1100, 512, 59, 98, 15844, 15846, 32768, 47, 512, 59, 97, 15851, 15853, 32768, 10692, 114, 59, 32768, 9023, 102, 59, 32896, 55349, 56676, 97, 512, 100, 114, 15868, 15882, 101, 115, 512, 59, 117, 15875, 15877, 32768, 9824, 105, 116, 59, 32768, 9824, 59, 32768, 8741, 768, 99, 115, 117, 15892, 15921, 15977, 512, 97, 117, 15897, 15909, 112, 512, 59, 115, 15903, 15905, 32768, 8851, 59, 32896, 8851, 65024, 112, 512, 59, 115, 15915, 15917, 32768, 8852, 59, 32896, 8852, 65024, 117, 512, 98, 112, 15927, 15952, 768, 59, 101, 115, 15934, 15936, 15939, 32768, 8847, 59, 32768, 8849, 101, 116, 512, 59, 101, 15946, 15948, 32768, 8847, 113, 59, 32768, 8849, 768, 59, 101, 115, 15959, 15961, 15964, 32768, 8848, 59, 32768, 8850, 101, 116, 512, 59, 101, 15971, 15973, 32768, 8848, 113, 59, 32768, 8850, 768, 59, 97, 102, 15984, 15986, 15996, 32768, 9633, 114, 566, 15991, 15994, 59, 32768, 9633, 59, 32768, 9642, 59, 32768, 9642, 97, 114, 114, 59, 32768, 8594, 1024, 99, 101, 109, 116, 16014, 16019, 16025, 16031, 114, 59, 32896, 55349, 56520, 116, 109, 110, 59, 32768, 8726, 105, 108, 101, 59, 32768, 8995, 97, 114, 102, 59, 32768, 8902, 512, 97, 114, 16042, 16053, 114, 512, 59, 102, 16048, 16050, 32768, 9734, 59, 32768, 9733, 512, 97, 110, 16058, 16081, 105, 103, 104, 116, 512, 101, 112, 16067, 16076, 112, 115, 105, 108, 111, 110, 59, 32768, 1013, 104, 105, 59, 32768, 981, 115, 59, 32768, 175, 1280, 98, 99, 109, 110, 112, 16096, 16221, 16288, 16291, 16295, 2304, 59, 69, 100, 101, 109, 110, 112, 114, 115, 16115, 16117, 16120, 16125, 16137, 16143, 16154, 16160, 16166, 32768, 8834, 59, 32768, 10949, 111, 116, 59, 32768, 10941, 512, 59, 100, 16130, 16132, 32768, 8838, 111, 116, 59, 32768, 10947, 117, 108, 116, 59, 32768, 10945, 512, 69, 101, 16148, 16151, 59, 32768, 10955, 59, 32768, 8842, 108, 117, 115, 59, 32768, 10943, 97, 114, 114, 59, 32768, 10617, 768, 101, 105, 117, 16173, 16206, 16210, 116, 768, 59, 101, 110, 16181, 16183, 16194, 32768, 8834, 113, 512, 59, 113, 16189, 16191, 32768, 8838, 59, 32768, 10949, 101, 113, 512, 59, 113, 16201, 16203, 32768, 8842, 59, 32768, 10955, 109, 59, 32768, 10951, 512, 98, 112, 16215, 16218, 59, 32768, 10965, 59, 32768, 10963, 99, 1536, 59, 97, 99, 101, 110, 115, 16235, 16237, 16245, 16254, 16258, 16283, 32768, 8827, 112, 112, 114, 111, 120, 59, 32768, 10936, 117, 114, 108, 121, 101, 113, 59, 32768, 8829, 113, 59, 32768, 10928, 768, 97, 101, 115, 16265, 16273, 16278, 112, 112, 114, 111, 120, 59, 32768, 10938, 113, 113, 59, 32768, 10934, 105, 109, 59, 32768, 8937, 105, 109, 59, 32768, 8831, 59, 32768, 8721, 103, 59, 32768, 9834, 3328, 49, 50, 51, 59, 69, 100, 101, 104, 108, 109, 110, 112, 115, 16322, 16327, 16332, 16337, 16339, 16342, 16356, 16368, 16382, 16388, 16394, 16405, 16411, 33024, 185, 59, 32768, 185, 33024, 178, 59, 32768, 178, 33024, 179, 59, 32768, 179, 32768, 8835, 59, 32768, 10950, 512, 111, 115, 16347, 16351, 116, 59, 32768, 10942, 117, 98, 59, 32768, 10968, 512, 59, 100, 16361, 16363, 32768, 8839, 111, 116, 59, 32768, 10948, 115, 512, 111, 117, 16374, 16378, 108, 59, 32768, 10185, 98, 59, 32768, 10967, 97, 114, 114, 59, 32768, 10619, 117, 108, 116, 59, 32768, 10946, 512, 69, 101, 16399, 16402, 59, 32768, 10956, 59, 32768, 8843, 108, 117, 115, 59, 32768, 10944, 768, 101, 105, 117, 16418, 16451, 16455, 116, 768, 59, 101, 110, 16426, 16428, 16439, 32768, 8835, 113, 512, 59, 113, 16434, 16436, 32768, 8839, 59, 32768, 10950, 101, 113, 512, 59, 113, 16446, 16448, 32768, 8843, 59, 32768, 10956, 109, 59, 32768, 10952, 512, 98, 112, 16460, 16463, 59, 32768, 10964, 59, 32768, 10966, 768, 65, 97, 110, 16473, 16478, 16499, 114, 114, 59, 32768, 8665, 114, 512, 104, 114, 16484, 16488, 107, 59, 32768, 10534, 512, 59, 111, 16493, 16495, 32768, 8601, 119, 59, 32768, 8601, 119, 97, 114, 59, 32768, 10538, 108, 105, 103, 33024, 223, 59, 32768, 223, 5938, 16538, 16552, 16557, 16579, 16584, 16591, 0, 16596, 16692, 0, 0, 0, 0, 0, 16731, 16780, 0, 16787, 16908, 0, 0, 0, 16938, 1091, 16543, 0, 0, 16549, 103, 101, 116, 59, 32768, 8982, 59, 32768, 964, 114, 107, 59, 32768, 9140, 768, 97, 101, 121, 16563, 16569, 16575, 114, 111, 110, 59, 32768, 357, 100, 105, 108, 59, 32768, 355, 59, 32768, 1090, 111, 116, 59, 32768, 8411, 108, 114, 101, 99, 59, 32768, 8981, 114, 59, 32896, 55349, 56625, 1024, 101, 105, 107, 111, 16604, 16641, 16670, 16684, 835, 16609, 0, 16624, 101, 512, 52, 102, 16614, 16617, 59, 32768, 8756, 111, 114, 101, 59, 32768, 8756, 97, 768, 59, 115, 118, 16631, 16633, 16638, 32768, 952, 121, 109, 59, 32768, 977, 59, 32768, 977, 512, 99, 110, 16646, 16665, 107, 512, 97, 115, 16652, 16660, 112, 112, 114, 111, 120, 59, 32768, 8776, 105, 109, 59, 32768, 8764, 115, 112, 59, 32768, 8201, 512, 97, 115, 16675, 16679, 112, 59, 32768, 8776, 105, 109, 59, 32768, 8764, 114, 110, 33024, 254, 59, 32768, 254, 829, 16696, 16701, 16727, 100, 101, 59, 32768, 732, 101, 115, 33536, 215, 59, 98, 100, 16710, 16712, 16723, 32768, 215, 512, 59, 97, 16717, 16719, 32768, 8864, 114, 59, 32768, 10801, 59, 32768, 10800, 116, 59, 32768, 8749, 768, 101, 112, 115, 16737, 16741, 16775, 97, 59, 32768, 10536, 1024, 59, 98, 99, 102, 16750, 16752, 16757, 16762, 32768, 8868, 111, 116, 59, 32768, 9014, 105, 114, 59, 32768, 10993, 512, 59, 111, 16767, 16770, 32896, 55349, 56677, 114, 107, 59, 32768, 10970, 97, 59, 32768, 10537, 114, 105, 109, 101, 59, 32768, 8244, 768, 97, 105, 112, 16793, 16798, 16899, 100, 101, 59, 32768, 8482, 1792, 97, 100, 101, 109, 112, 115, 116, 16813, 16868, 16873, 16876, 16883, 16889, 16893, 110, 103, 108, 101, 1280, 59, 100, 108, 113, 114, 16828, 16830, 16836, 16850, 16853, 32768, 9653, 111, 119, 110, 59, 32768, 9663, 101, 102, 116, 512, 59, 101, 16844, 16846, 32768, 9667, 113, 59, 32768, 8884, 59, 32768, 8796, 105, 103, 104, 116, 512, 59, 101, 16862, 16864, 32768, 9657, 113, 59, 32768, 8885, 111, 116, 59, 32768, 9708, 59, 32768, 8796, 105, 110, 117, 115, 59, 32768, 10810, 108, 117, 115, 59, 32768, 10809, 98, 59, 32768, 10701, 105, 109, 101, 59, 32768, 10811, 101, 122, 105, 117, 109, 59, 32768, 9186, 768, 99, 104, 116, 16914, 16926, 16931, 512, 114, 121, 16919, 16923, 59, 32896, 55349, 56521, 59, 32768, 1094, 99, 121, 59, 32768, 1115, 114, 111, 107, 59, 32768, 359, 512, 105, 111, 16942, 16947, 120, 116, 59, 32768, 8812, 104, 101, 97, 100, 512, 108, 114, 16956, 16967, 101, 102, 116, 97, 114, 114, 111, 119, 59, 32768, 8606, 105, 103, 104, 116, 97, 114, 114, 111, 119, 59, 32768, 8608, 4608, 65, 72, 97, 98, 99, 100, 102, 103, 104, 108, 109, 111, 112, 114, 115, 116, 117, 119, 17016, 17021, 17026, 17043, 17057, 17072, 17095, 17110, 17119, 17139, 17172, 17187, 17202, 17290, 17330, 17336, 17365, 17381, 114, 114, 59, 32768, 8657, 97, 114, 59, 32768, 10595, 512, 99, 114, 17031, 17039, 117, 116, 101, 33024, 250, 59, 32768, 250, 114, 59, 32768, 8593, 114, 820, 17049, 0, 17053, 121, 59, 32768, 1118, 118, 101, 59, 32768, 365, 512, 105, 121, 17062, 17069, 114, 99, 33024, 251, 59, 32768, 251, 59, 32768, 1091, 768, 97, 98, 104, 17079, 17084, 17090, 114, 114, 59, 32768, 8645, 108, 97, 99, 59, 32768, 369, 97, 114, 59, 32768, 10606, 512, 105, 114, 17100, 17106, 115, 104, 116, 59, 32768, 10622, 59, 32896, 55349, 56626, 114, 97, 118, 101, 33024, 249, 59, 32768, 249, 562, 17123, 17135, 114, 512, 108, 114, 17128, 17131, 59, 32768, 8639, 59, 32768, 8638, 108, 107, 59, 32768, 9600, 512, 99, 116, 17144, 17167, 1088, 17150, 0, 0, 17163, 114, 110, 512, 59, 101, 17156, 17158, 32768, 8988, 114, 59, 32768, 8988, 111, 112, 59, 32768, 8975, 114, 105, 59, 32768, 9720, 512, 97, 108, 17177, 17182, 99, 114, 59, 32768, 363, 33024, 168, 59, 32768, 168, 512, 103, 112, 17192, 17197, 111, 110, 59, 32768, 371, 102, 59, 32896, 55349, 56678, 1536, 97, 100, 104, 108, 115, 117, 17215, 17222, 17233, 17257, 17262, 17280, 114, 114, 111, 119, 59, 32768, 8593, 111, 119, 110, 97, 114, 114, 111, 119, 59, 32768, 8597, 97, 114, 112, 111, 111, 110, 512, 108, 114, 17244, 17250, 101, 102, 116, 59, 32768, 8639, 105, 103, 104, 116, 59, 32768, 8638, 117, 115, 59, 32768, 8846, 105, 768, 59, 104, 108, 17270, 17272, 17275, 32768, 965, 59, 32768, 978, 111, 110, 59, 32768, 965, 112, 97, 114, 114, 111, 119, 115, 59, 32768, 8648, 768, 99, 105, 116, 17297, 17320, 17325, 1088, 17303, 0, 0, 17316, 114, 110, 512, 59, 101, 17309, 17311, 32768, 8989, 114, 59, 32768, 8989, 111, 112, 59, 32768, 8974, 110, 103, 59, 32768, 367, 114, 105, 59, 32768, 9721, 99, 114, 59, 32896, 55349, 56522, 768, 100, 105, 114, 17343, 17348, 17354, 111, 116, 59, 32768, 8944, 108, 100, 101, 59, 32768, 361, 105, 512, 59, 102, 17360, 17362, 32768, 9653, 59, 32768, 9652, 512, 97, 109, 17370, 17375, 114, 114, 59, 32768, 8648, 108, 33024, 252, 59, 32768, 252, 97, 110, 103, 108, 101, 59, 32768, 10663, 3840, 65, 66, 68, 97, 99, 100, 101, 102, 108, 110, 111, 112, 114, 115, 122, 17420, 17425, 17437, 17443, 17613, 17617, 17623, 17667, 17672, 17678, 17693, 17699, 17705, 17711, 17754, 114, 114, 59, 32768, 8661, 97, 114, 512, 59, 118, 17432, 17434, 32768, 10984, 59, 32768, 10985, 97, 115, 104, 59, 32768, 8872, 512, 110, 114, 17448, 17454, 103, 114, 116, 59, 32768, 10652, 1792, 101, 107, 110, 112, 114, 115, 116, 17469, 17478, 17485, 17494, 17515, 17526, 17578, 112, 115, 105, 108, 111, 110, 59, 32768, 1013, 97, 112, 112, 97, 59, 32768, 1008, 111, 116, 104, 105, 110, 103, 59, 32768, 8709, 768, 104, 105, 114, 17501, 17505, 17508, 105, 59, 32768, 981, 59, 32768, 982, 111, 112, 116, 111, 59, 32768, 8733, 512, 59, 104, 17520, 17522, 32768, 8597, 111, 59, 32768, 1009, 512, 105, 117, 17531, 17537, 103, 109, 97, 59, 32768, 962, 512, 98, 112, 17542, 17560, 115, 101, 116, 110, 101, 113, 512, 59, 113, 17553, 17556, 32896, 8842, 65024, 59, 32896, 10955, 65024, 115, 101, 116, 110, 101, 113, 512, 59, 113, 17571, 17574, 32896, 8843, 65024, 59, 32896, 10956, 65024, 512, 104, 114, 17583, 17589, 101, 116, 97, 59, 32768, 977, 105, 97, 110, 103, 108, 101, 512, 108, 114, 17600, 17606, 101, 102, 116, 59, 32768, 8882, 105, 103, 104, 116, 59, 32768, 8883, 121, 59, 32768, 1074, 97, 115, 104, 59, 32768, 8866, 768, 101, 108, 114, 17630, 17648, 17654, 768, 59, 98, 101, 17637, 17639, 17644, 32768, 8744, 97, 114, 59, 32768, 8891, 113, 59, 32768, 8794, 108, 105, 112, 59, 32768, 8942, 512, 98, 116, 17659, 17664, 97, 114, 59, 32768, 124, 59, 32768, 124, 114, 59, 32896, 55349, 56627, 116, 114, 105, 59, 32768, 8882, 115, 117, 512, 98, 112, 17685, 17689, 59, 32896, 8834, 8402, 59, 32896, 8835, 8402, 112, 102, 59, 32896, 55349, 56679, 114, 111, 112, 59, 32768, 8733, 116, 114, 105, 59, 32768, 8883, 512, 99, 117, 17716, 17721, 114, 59, 32896, 55349, 56523, 512, 98, 112, 17726, 17740, 110, 512, 69, 101, 17732, 17736, 59, 32896, 10955, 65024, 59, 32896, 8842, 65024, 110, 512, 69, 101, 17746, 17750, 59, 32896, 10956, 65024, 59, 32896, 8843, 65024, 105, 103, 122, 97, 103, 59, 32768, 10650, 1792, 99, 101, 102, 111, 112, 114, 115, 17777, 17783, 17815, 17820, 17826, 17829, 17842, 105, 114, 99, 59, 32768, 373, 512, 100, 105, 17788, 17809, 512, 98, 103, 17793, 17798, 97, 114, 59, 32768, 10847, 101, 512, 59, 113, 17804, 17806, 32768, 8743, 59, 32768, 8793, 101, 114, 112, 59, 32768, 8472, 114, 59, 32896, 55349, 56628, 112, 102, 59, 32896, 55349, 56680, 59, 32768, 8472, 512, 59, 101, 17834, 17836, 32768, 8768, 97, 116, 104, 59, 32768, 8768, 99, 114, 59, 32896, 55349, 56524, 5428, 17871, 17891, 0, 17897, 0, 17902, 17917, 0, 0, 17920, 17935, 17940, 17945, 0, 0, 17977, 17992, 0, 18008, 18024, 18029, 768, 97, 105, 117, 17877, 17881, 17886, 112, 59, 32768, 8898, 114, 99, 59, 32768, 9711, 112, 59, 32768, 8899, 116, 114, 105, 59, 32768, 9661, 114, 59, 32896, 55349, 56629, 512, 65, 97, 17906, 17911, 114, 114, 59, 32768, 10234, 114, 114, 59, 32768, 10231, 59, 32768, 958, 512, 65, 97, 17924, 17929, 114, 114, 59, 32768, 10232, 114, 114, 59, 32768, 10229, 97, 112, 59, 32768, 10236, 105, 115, 59, 32768, 8955, 768, 100, 112, 116, 17951, 17956, 17970, 111, 116, 59, 32768, 10752, 512, 102, 108, 17961, 17965, 59, 32896, 55349, 56681, 117, 115, 59, 32768, 10753, 105, 109, 101, 59, 32768, 10754, 512, 65, 97, 17981, 17986, 114, 114, 59, 32768, 10233, 114, 114, 59, 32768, 10230, 512, 99, 113, 17996, 18001, 114, 59, 32896, 55349, 56525, 99, 117, 112, 59, 32768, 10758, 512, 112, 116, 18012, 18018, 108, 117, 115, 59, 32768, 10756, 114, 105, 59, 32768, 9651, 101, 101, 59, 32768, 8897, 101, 100, 103, 101, 59, 32768, 8896, 2048, 97, 99, 101, 102, 105, 111, 115, 117, 18052, 18068, 18081, 18087, 18092, 18097, 18103, 18109, 99, 512, 117, 121, 18058, 18065, 116, 101, 33024, 253, 59, 32768, 253, 59, 32768, 1103, 512, 105, 121, 18073, 18078, 114, 99, 59, 32768, 375, 59, 32768, 1099, 110, 33024, 165, 59, 32768, 165, 114, 59, 32896, 55349, 56630, 99, 121, 59, 32768, 1111, 112, 102, 59, 32896, 55349, 56682, 99, 114, 59, 32896, 55349, 56526, 512, 99, 109, 18114, 18118, 121, 59, 32768, 1102, 108, 33024, 255, 59, 32768, 255, 2560, 97, 99, 100, 101, 102, 104, 105, 111, 115, 119, 18145, 18152, 18166, 18171, 18186, 18191, 18196, 18204, 18210, 18216, 99, 117, 116, 101, 59, 32768, 378, 512, 97, 121, 18157, 18163, 114, 111, 110, 59, 32768, 382, 59, 32768, 1079, 111, 116, 59, 32768, 380, 512, 101, 116, 18176, 18182, 116, 114, 102, 59, 32768, 8488, 97, 59, 32768, 950, 114, 59, 32896, 55349, 56631, 99, 121, 59, 32768, 1078, 103, 114, 97, 114, 114, 59, 32768, 8669, 112, 102, 59, 32896, 55349, 56683, 99, 114, 59, 32896, 55349, 56527, 512, 106, 110, 18221, 18224, 59, 32768, 8205, 106, 59, 32768, 8204]);\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\n// Generated using scripts/write-decode-map.ts\n// prettier-ignore\nexports.default = new Uint16Array([1024, 97, 103, 108, 113, 9, 23, 27, 31, 1086, 15, 0, 0, 19, 112, 59, 32768, 38, 111, 115, 59, 32768, 39, 116, 59, 32768, 62, 116, 59, 32768, 60, 117, 111, 116, 59, 32768, 34]);\n","\"use strict\";\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.parseFeed = exports.FeedHandler = exports.getFeed = void 0;\nvar domhandler_1 = __importDefault(require(\"domhandler\"));\nvar domutils_1 = require(\"domutils\");\nObject.defineProperty(exports, \"getFeed\", { enumerable: true, get: function () { return domutils_1.getFeed; } });\nvar Parser_1 = require(\"./Parser\");\n/** @deprecated Handler is no longer necessary; use `getFeed` or `parseFeed` instead. */\nvar FeedHandler = /** @class */ (function (_super) {\n __extends(FeedHandler, _super);\n /**\n *\n * @param callback\n * @param options\n */\n function FeedHandler(callback, options) {\n var _this = this;\n if (typeof callback === \"object\") {\n callback = undefined;\n options = callback;\n }\n _this = _super.call(this, callback, options) || this;\n return _this;\n }\n FeedHandler.prototype.onend = function () {\n var feed = (0, domutils_1.getFeed)(this.dom);\n if (feed) {\n this.feed = feed;\n this.handleCallback(null);\n }\n else {\n this.handleCallback(new Error(\"couldn't find root of feed\"));\n }\n };\n return FeedHandler;\n}(domhandler_1.default));\nexports.FeedHandler = FeedHandler;\n/**\n * Parse a feed.\n *\n * @param feed The feed that should be parsed, as a string.\n * @param options Optionally, options for parsing. When using this, you should set `xmlMode` to `true`.\n */\nfunction parseFeed(feed, options) {\n if (options === void 0) { options = { xmlMode: true }; }\n var handler = new domhandler_1.default(null, options);\n new Parser_1.Parser(handler, options).end(feed);\n return (0, domutils_1.getFeed)(handler.dom);\n}\nexports.parseFeed = parseFeed;\n","\"use strict\";\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __exportStar = (this && this.__exportStar) || function(m, exports) {\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.hasChildren = exports.isDocument = exports.isComment = exports.isText = exports.isCDATA = exports.isTag = void 0;\n__exportStar(require(\"./stringify\"), exports);\n__exportStar(require(\"./traversal\"), exports);\n__exportStar(require(\"./manipulation\"), exports);\n__exportStar(require(\"./querying\"), exports);\n__exportStar(require(\"./legacy\"), exports);\n__exportStar(require(\"./helpers\"), exports);\n__exportStar(require(\"./feeds\"), exports);\n/** @deprecated Use these methods from `domhandler` directly. */\nvar domhandler_1 = require(\"domhandler\");\nObject.defineProperty(exports, \"isTag\", { enumerable: true, get: function () { return domhandler_1.isTag; } });\nObject.defineProperty(exports, \"isCDATA\", { enumerable: true, get: function () { return domhandler_1.isCDATA; } });\nObject.defineProperty(exports, \"isText\", { enumerable: true, get: function () { return domhandler_1.isText; } });\nObject.defineProperty(exports, \"isComment\", { enumerable: true, get: function () { return domhandler_1.isComment; } });\nObject.defineProperty(exports, \"isDocument\", { enumerable: true, get: function () { return domhandler_1.isDocument; } });\nObject.defineProperty(exports, \"hasChildren\", { enumerable: true, get: function () { return domhandler_1.hasChildren; } });\n","\"use strict\";\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.innerText = exports.textContent = exports.getText = exports.getInnerHTML = exports.getOuterHTML = void 0;\nvar domhandler_1 = require(\"domhandler\");\nvar dom_serializer_1 = __importDefault(require(\"dom-serializer\"));\nvar domelementtype_1 = require(\"domelementtype\");\n/**\n * @param node Node to get the outer HTML of.\n * @param options Options for serialization.\n * @deprecated Use the `dom-serializer` module directly.\n * @returns `node`'s outer HTML.\n */\nfunction getOuterHTML(node, options) {\n return (0, dom_serializer_1.default)(node, options);\n}\nexports.getOuterHTML = getOuterHTML;\n/**\n * @param node Node to get the inner HTML of.\n * @param options Options for serialization.\n * @deprecated Use the `dom-serializer` module directly.\n * @returns `node`'s inner HTML.\n */\nfunction getInnerHTML(node, options) {\n return (0, domhandler_1.hasChildren)(node)\n ? node.children.map(function (node) { return getOuterHTML(node, options); }).join(\"\")\n : \"\";\n}\nexports.getInnerHTML = getInnerHTML;\n/**\n * Get a node's inner text. Same as `textContent`, but inserts newlines for `
` tags.\n *\n * @deprecated Use `textContent` instead.\n * @param node Node to get the inner text of.\n * @returns `node`'s inner text.\n */\nfunction getText(node) {\n if (Array.isArray(node))\n return node.map(getText).join(\"\");\n if ((0, domhandler_1.isTag)(node))\n return node.name === \"br\" ? \"\\n\" : getText(node.children);\n if ((0, domhandler_1.isCDATA)(node))\n return getText(node.children);\n if ((0, domhandler_1.isText)(node))\n return node.data;\n return \"\";\n}\nexports.getText = getText;\n/**\n * Get a node's text content.\n *\n * @param node Node to get the text content of.\n * @returns `node`'s text content.\n * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/Node/textContent}\n */\nfunction textContent(node) {\n if (Array.isArray(node))\n return node.map(textContent).join(\"\");\n if ((0, domhandler_1.hasChildren)(node) && !(0, domhandler_1.isComment)(node)) {\n return textContent(node.children);\n }\n if ((0, domhandler_1.isText)(node))\n return node.data;\n return \"\";\n}\nexports.textContent = textContent;\n/**\n * Get a node's inner text.\n *\n * @param node Node to get the inner text of.\n * @returns `node`'s inner text.\n * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/Node/innerText}\n */\nfunction innerText(node) {\n if (Array.isArray(node))\n return node.map(innerText).join(\"\");\n if ((0, domhandler_1.hasChildren)(node) && (node.type === domelementtype_1.ElementType.Tag || (0, domhandler_1.isCDATA)(node))) {\n return innerText(node.children);\n }\n if ((0, domhandler_1.isText)(node))\n return node.data;\n return \"\";\n}\nexports.innerText = innerText;\n","\"use strict\";\nvar __assign = (this && this.__assign) || function () {\n __assign = Object.assign || function(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\n/*\n * Module dependencies\n */\nvar ElementType = __importStar(require(\"domelementtype\"));\nvar entities_1 = require(\"entities\");\n/**\n * Mixed-case SVG and MathML tags & attributes\n * recognized by the HTML parser.\n *\n * @see https://html.spec.whatwg.org/multipage/parsing.html#parsing-main-inforeign\n */\nvar foreignNames_1 = require(\"./foreignNames\");\nvar unencodedElements = new Set([\n \"style\",\n \"script\",\n \"xmp\",\n \"iframe\",\n \"noembed\",\n \"noframes\",\n \"plaintext\",\n \"noscript\",\n]);\n/**\n * Format attributes\n */\nfunction formatAttributes(attributes, opts) {\n if (!attributes)\n return;\n return Object.keys(attributes)\n .map(function (key) {\n var _a, _b;\n var value = (_a = attributes[key]) !== null && _a !== void 0 ? _a : \"\";\n if (opts.xmlMode === \"foreign\") {\n /* Fix up mixed-case attribute names */\n key = (_b = foreignNames_1.attributeNames.get(key)) !== null && _b !== void 0 ? _b : key;\n }\n if (!opts.emptyAttrs && !opts.xmlMode && value === \"\") {\n return key;\n }\n return key + \"=\\\"\" + (opts.decodeEntities !== false\n ? entities_1.encodeXML(value)\n : value.replace(/\"/g, \""\")) + \"\\\"\";\n })\n .join(\" \");\n}\n/**\n * Self-enclosing tags\n */\nvar singleTag = new Set([\n \"area\",\n \"base\",\n \"basefont\",\n \"br\",\n \"col\",\n \"command\",\n \"embed\",\n \"frame\",\n \"hr\",\n \"img\",\n \"input\",\n \"isindex\",\n \"keygen\",\n \"link\",\n \"meta\",\n \"param\",\n \"source\",\n \"track\",\n \"wbr\",\n]);\n/**\n * Renders a DOM node or an array of DOM nodes to a string.\n *\n * Can be thought of as the equivalent of the `outerHTML` of the passed node(s).\n *\n * @param node Node to be rendered.\n * @param options Changes serialization behavior\n */\nfunction render(node, options) {\n if (options === void 0) { options = {}; }\n var nodes = \"length\" in node ? node : [node];\n var output = \"\";\n for (var i = 0; i < nodes.length; i++) {\n output += renderNode(nodes[i], options);\n }\n return output;\n}\nexports.default = render;\nfunction renderNode(node, options) {\n switch (node.type) {\n case ElementType.Root:\n return render(node.children, options);\n case ElementType.Directive:\n case ElementType.Doctype:\n return renderDirective(node);\n case ElementType.Comment:\n return renderComment(node);\n case ElementType.CDATA:\n return renderCdata(node);\n case ElementType.Script:\n case ElementType.Style:\n case ElementType.Tag:\n return renderTag(node, options);\n case ElementType.Text:\n return renderText(node, options);\n }\n}\nvar foreignModeIntegrationPoints = new Set([\n \"mi\",\n \"mo\",\n \"mn\",\n \"ms\",\n \"mtext\",\n \"annotation-xml\",\n \"foreignObject\",\n \"desc\",\n \"title\",\n]);\nvar foreignElements = new Set([\"svg\", \"math\"]);\nfunction renderTag(elem, opts) {\n var _a;\n // Handle SVG / MathML in HTML\n if (opts.xmlMode === \"foreign\") {\n /* Fix up mixed-case element names */\n elem.name = (_a = foreignNames_1.elementNames.get(elem.name)) !== null && _a !== void 0 ? _a : elem.name;\n /* Exit foreign mode at integration points */\n if (elem.parent &&\n foreignModeIntegrationPoints.has(elem.parent.name)) {\n opts = __assign(__assign({}, opts), { xmlMode: false });\n }\n }\n if (!opts.xmlMode && foreignElements.has(elem.name)) {\n opts = __assign(__assign({}, opts), { xmlMode: \"foreign\" });\n }\n var tag = \"<\" + elem.name;\n var attribs = formatAttributes(elem.attribs, opts);\n if (attribs) {\n tag += \" \" + attribs;\n }\n if (elem.children.length === 0 &&\n (opts.xmlMode\n ? // In XML mode or foreign mode, and user hasn't explicitly turned off self-closing tags\n opts.selfClosingTags !== false\n : // User explicitly asked for self-closing tags, even in HTML mode\n opts.selfClosingTags && singleTag.has(elem.name))) {\n if (!opts.xmlMode)\n tag += \" \";\n tag += \"/>\";\n }\n else {\n tag += \">\";\n if (elem.children.length > 0) {\n tag += render(elem.children, opts);\n }\n if (opts.xmlMode || !singleTag.has(elem.name)) {\n tag += \"\";\n }\n }\n return tag;\n}\nfunction renderDirective(elem) {\n return \"<\" + elem.data + \">\";\n}\nfunction renderText(elem, opts) {\n var data = elem.data || \"\";\n // If entities weren't decoded, no need to encode them back\n if (opts.decodeEntities !== false &&\n !(!opts.xmlMode &&\n elem.parent &&\n unencodedElements.has(elem.parent.name))) {\n data = entities_1.encodeXML(data);\n }\n return data;\n}\nfunction renderCdata(elem) {\n return \"\";\n}\nfunction renderComment(elem) {\n return \"\";\n}\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.attributeNames = exports.elementNames = void 0;\nexports.elementNames = new Map([\n [\"altglyph\", \"altGlyph\"],\n [\"altglyphdef\", \"altGlyphDef\"],\n [\"altglyphitem\", \"altGlyphItem\"],\n [\"animatecolor\", \"animateColor\"],\n [\"animatemotion\", \"animateMotion\"],\n [\"animatetransform\", \"animateTransform\"],\n [\"clippath\", \"clipPath\"],\n [\"feblend\", \"feBlend\"],\n [\"fecolormatrix\", \"feColorMatrix\"],\n [\"fecomponenttransfer\", \"feComponentTransfer\"],\n [\"fecomposite\", \"feComposite\"],\n [\"feconvolvematrix\", \"feConvolveMatrix\"],\n [\"fediffuselighting\", \"feDiffuseLighting\"],\n [\"fedisplacementmap\", \"feDisplacementMap\"],\n [\"fedistantlight\", \"feDistantLight\"],\n [\"fedropshadow\", \"feDropShadow\"],\n [\"feflood\", \"feFlood\"],\n [\"fefunca\", \"feFuncA\"],\n [\"fefuncb\", \"feFuncB\"],\n [\"fefuncg\", \"feFuncG\"],\n [\"fefuncr\", \"feFuncR\"],\n [\"fegaussianblur\", \"feGaussianBlur\"],\n [\"feimage\", \"feImage\"],\n [\"femerge\", \"feMerge\"],\n [\"femergenode\", \"feMergeNode\"],\n [\"femorphology\", \"feMorphology\"],\n [\"feoffset\", \"feOffset\"],\n [\"fepointlight\", \"fePointLight\"],\n [\"fespecularlighting\", \"feSpecularLighting\"],\n [\"fespotlight\", \"feSpotLight\"],\n [\"fetile\", \"feTile\"],\n [\"feturbulence\", \"feTurbulence\"],\n [\"foreignobject\", \"foreignObject\"],\n [\"glyphref\", \"glyphRef\"],\n [\"lineargradient\", \"linearGradient\"],\n [\"radialgradient\", \"radialGradient\"],\n [\"textpath\", \"textPath\"],\n]);\nexports.attributeNames = new Map([\n [\"definitionurl\", \"definitionURL\"],\n [\"attributename\", \"attributeName\"],\n [\"attributetype\", \"attributeType\"],\n [\"basefrequency\", \"baseFrequency\"],\n [\"baseprofile\", \"baseProfile\"],\n [\"calcmode\", \"calcMode\"],\n [\"clippathunits\", \"clipPathUnits\"],\n [\"diffuseconstant\", \"diffuseConstant\"],\n [\"edgemode\", \"edgeMode\"],\n [\"filterunits\", \"filterUnits\"],\n [\"glyphref\", \"glyphRef\"],\n [\"gradienttransform\", \"gradientTransform\"],\n [\"gradientunits\", \"gradientUnits\"],\n [\"kernelmatrix\", \"kernelMatrix\"],\n [\"kernelunitlength\", \"kernelUnitLength\"],\n [\"keypoints\", \"keyPoints\"],\n [\"keysplines\", \"keySplines\"],\n [\"keytimes\", \"keyTimes\"],\n [\"lengthadjust\", \"lengthAdjust\"],\n [\"limitingconeangle\", \"limitingConeAngle\"],\n [\"markerheight\", \"markerHeight\"],\n [\"markerunits\", \"markerUnits\"],\n [\"markerwidth\", \"markerWidth\"],\n [\"maskcontentunits\", \"maskContentUnits\"],\n [\"maskunits\", \"maskUnits\"],\n [\"numoctaves\", \"numOctaves\"],\n [\"pathlength\", \"pathLength\"],\n [\"patterncontentunits\", \"patternContentUnits\"],\n [\"patterntransform\", \"patternTransform\"],\n [\"patternunits\", \"patternUnits\"],\n [\"pointsatx\", \"pointsAtX\"],\n [\"pointsaty\", \"pointsAtY\"],\n [\"pointsatz\", \"pointsAtZ\"],\n [\"preservealpha\", \"preserveAlpha\"],\n [\"preserveaspectratio\", \"preserveAspectRatio\"],\n [\"primitiveunits\", \"primitiveUnits\"],\n [\"refx\", \"refX\"],\n [\"refy\", \"refY\"],\n [\"repeatcount\", \"repeatCount\"],\n [\"repeatdur\", \"repeatDur\"],\n [\"requiredextensions\", \"requiredExtensions\"],\n [\"requiredfeatures\", \"requiredFeatures\"],\n [\"specularconstant\", \"specularConstant\"],\n [\"specularexponent\", \"specularExponent\"],\n [\"spreadmethod\", \"spreadMethod\"],\n [\"startoffset\", \"startOffset\"],\n [\"stddeviation\", \"stdDeviation\"],\n [\"stitchtiles\", \"stitchTiles\"],\n [\"surfacescale\", \"surfaceScale\"],\n [\"systemlanguage\", \"systemLanguage\"],\n [\"tablevalues\", \"tableValues\"],\n [\"targetx\", \"targetX\"],\n [\"targety\", \"targetY\"],\n [\"textlength\", \"textLength\"],\n [\"viewbox\", \"viewBox\"],\n [\"viewtarget\", \"viewTarget\"],\n [\"xchannelselector\", \"xChannelSelector\"],\n [\"ychannelselector\", \"yChannelSelector\"],\n [\"zoomandpan\", \"zoomAndPan\"],\n]);\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.decodeXMLStrict = exports.decodeHTML5Strict = exports.decodeHTML4Strict = exports.decodeHTML5 = exports.decodeHTML4 = exports.decodeHTMLStrict = exports.decodeHTML = exports.decodeXML = exports.encodeHTML5 = exports.encodeHTML4 = exports.escapeUTF8 = exports.escape = exports.encodeNonAsciiHTML = exports.encodeHTML = exports.encodeXML = exports.encode = exports.decodeStrict = exports.decode = void 0;\nvar decode_1 = require(\"./decode\");\nvar encode_1 = require(\"./encode\");\n/**\n * Decodes a string with entities.\n *\n * @param data String to decode.\n * @param level Optional level to decode at. 0 = XML, 1 = HTML. Default is 0.\n * @deprecated Use `decodeXML` or `decodeHTML` directly.\n */\nfunction decode(data, level) {\n return (!level || level <= 0 ? decode_1.decodeXML : decode_1.decodeHTML)(data);\n}\nexports.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 level Optional level to decode at. 0 = XML, 1 = HTML. Default is 0.\n * @deprecated Use `decodeHTMLStrict` or `decodeXML` directly.\n */\nfunction decodeStrict(data, level) {\n return (!level || level <= 0 ? decode_1.decodeXML : decode_1.decodeHTMLStrict)(data);\n}\nexports.decodeStrict = decodeStrict;\n/**\n * Encodes a string with entities.\n *\n * @param data String to encode.\n * @param level Optional level to encode at. 0 = XML, 1 = HTML. Default is 0.\n * @deprecated Use `encodeHTML`, `encodeXML` or `encodeNonAsciiHTML` directly.\n */\nfunction encode(data, level) {\n return (!level || level <= 0 ? encode_1.encodeXML : encode_1.encodeHTML)(data);\n}\nexports.encode = encode;\nvar encode_2 = require(\"./encode\");\nObject.defineProperty(exports, \"encodeXML\", { enumerable: true, get: function () { return encode_2.encodeXML; } });\nObject.defineProperty(exports, \"encodeHTML\", { enumerable: true, get: function () { return encode_2.encodeHTML; } });\nObject.defineProperty(exports, \"encodeNonAsciiHTML\", { enumerable: true, get: function () { return encode_2.encodeNonAsciiHTML; } });\nObject.defineProperty(exports, \"escape\", { enumerable: true, get: function () { return encode_2.escape; } });\nObject.defineProperty(exports, \"escapeUTF8\", { enumerable: true, get: function () { return encode_2.escapeUTF8; } });\n// Legacy aliases (deprecated)\nObject.defineProperty(exports, \"encodeHTML4\", { enumerable: true, get: function () { return encode_2.encodeHTML; } });\nObject.defineProperty(exports, \"encodeHTML5\", { enumerable: true, get: function () { return encode_2.encodeHTML; } });\nvar decode_2 = require(\"./decode\");\nObject.defineProperty(exports, \"decodeXML\", { enumerable: true, get: function () { return decode_2.decodeXML; } });\nObject.defineProperty(exports, \"decodeHTML\", { enumerable: true, get: function () { return decode_2.decodeHTML; } });\nObject.defineProperty(exports, \"decodeHTMLStrict\", { enumerable: true, get: function () { return decode_2.decodeHTMLStrict; } });\n// Legacy aliases (deprecated)\nObject.defineProperty(exports, \"decodeHTML4\", { enumerable: true, get: function () { return decode_2.decodeHTML; } });\nObject.defineProperty(exports, \"decodeHTML5\", { enumerable: true, get: function () { return decode_2.decodeHTML; } });\nObject.defineProperty(exports, \"decodeHTML4Strict\", { enumerable: true, get: function () { return decode_2.decodeHTMLStrict; } });\nObject.defineProperty(exports, \"decodeHTML5Strict\", { enumerable: true, get: function () { return decode_2.decodeHTMLStrict; } });\nObject.defineProperty(exports, \"decodeXMLStrict\", { enumerable: true, get: function () { return decode_2.decodeXML; } });\n","\"use strict\";\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.decodeHTML = exports.decodeHTMLStrict = exports.decodeXML = void 0;\nvar entities_json_1 = __importDefault(require(\"./maps/entities.json\"));\nvar legacy_json_1 = __importDefault(require(\"./maps/legacy.json\"));\nvar xml_json_1 = __importDefault(require(\"./maps/xml.json\"));\nvar decode_codepoint_1 = __importDefault(require(\"./decode_codepoint\"));\nvar strictEntityRe = /&(?:[a-zA-Z0-9]+|#[xX][\\da-fA-F]+|#\\d+);/g;\nexports.decodeXML = getStrictDecoder(xml_json_1.default);\nexports.decodeHTMLStrict = getStrictDecoder(entities_json_1.default);\nfunction getStrictDecoder(map) {\n var replace = getReplacer(map);\n return function (str) { return String(str).replace(strictEntityRe, replace); };\n}\nvar sorter = function (a, b) { return (a < b ? 1 : -1); };\nexports.decodeHTML = (function () {\n var legacy = Object.keys(legacy_json_1.default).sort(sorter);\n var keys = Object.keys(entities_json_1.default).sort(sorter);\n for (var i = 0, j = 0; i < keys.length; i++) {\n if (legacy[j] === keys[i]) {\n keys[i] += \";?\";\n j++;\n }\n else {\n keys[i] += \";\";\n }\n }\n var re = new RegExp(\"&(?:\" + keys.join(\"|\") + \"|#[xX][\\\\da-fA-F]+;?|#\\\\d+;?)\", \"g\");\n var replace = getReplacer(entities_json_1.default);\n function replacer(str) {\n if (str.substr(-1) !== \";\")\n str += \";\";\n return replace(str);\n }\n // TODO consider creating a merged map\n return function (str) { return String(str).replace(re, replacer); };\n})();\nfunction getReplacer(map) {\n return function replace(str) {\n if (str.charAt(1) === \"#\") {\n var secondChar = str.charAt(2);\n if (secondChar === \"X\" || secondChar === \"x\") {\n return decode_codepoint_1.default(parseInt(str.substr(3), 16));\n }\n return decode_codepoint_1.default(parseInt(str.substr(2), 10));\n }\n // eslint-disable-next-line @typescript-eslint/prefer-nullish-coalescing\n return map[str.slice(1, -1)] || str;\n };\n}\n","{\"Aacute\":\"Á\",\"aacute\":\"á\",\"Abreve\":\"Ă\",\"abreve\":\"ă\",\"ac\":\"∾\",\"acd\":\"∿\",\"acE\":\"∾̳\",\"Acirc\":\"Â\",\"acirc\":\"â\",\"acute\":\"´\",\"Acy\":\"А\",\"acy\":\"а\",\"AElig\":\"Æ\",\"aelig\":\"æ\",\"af\":\"⁡\",\"Afr\":\"𝔄\",\"afr\":\"𝔞\",\"Agrave\":\"À\",\"agrave\":\"à\",\"alefsym\":\"ℵ\",\"aleph\":\"ℵ\",\"Alpha\":\"Α\",\"alpha\":\"α\",\"Amacr\":\"Ā\",\"amacr\":\"ā\",\"amalg\":\"⨿\",\"amp\":\"&\",\"AMP\":\"&\",\"andand\":\"⩕\",\"And\":\"⩓\",\"and\":\"∧\",\"andd\":\"⩜\",\"andslope\":\"⩘\",\"andv\":\"⩚\",\"ang\":\"∠\",\"ange\":\"⦤\",\"angle\":\"∠\",\"angmsdaa\":\"⦨\",\"angmsdab\":\"⦩\",\"angmsdac\":\"⦪\",\"angmsdad\":\"⦫\",\"angmsdae\":\"⦬\",\"angmsdaf\":\"⦭\",\"angmsdag\":\"⦮\",\"angmsdah\":\"⦯\",\"angmsd\":\"∡\",\"angrt\":\"∟\",\"angrtvb\":\"⊾\",\"angrtvbd\":\"⦝\",\"angsph\":\"∢\",\"angst\":\"Å\",\"angzarr\":\"⍼\",\"Aogon\":\"Ą\",\"aogon\":\"ą\",\"Aopf\":\"𝔸\",\"aopf\":\"𝕒\",\"apacir\":\"⩯\",\"ap\":\"≈\",\"apE\":\"⩰\",\"ape\":\"≊\",\"apid\":\"≋\",\"apos\":\"'\",\"ApplyFunction\":\"⁡\",\"approx\":\"≈\",\"approxeq\":\"≊\",\"Aring\":\"Å\",\"aring\":\"å\",\"Ascr\":\"𝒜\",\"ascr\":\"𝒶\",\"Assign\":\"≔\",\"ast\":\"*\",\"asymp\":\"≈\",\"asympeq\":\"≍\",\"Atilde\":\"Ã\",\"atilde\":\"ã\",\"Auml\":\"Ä\",\"auml\":\"ä\",\"awconint\":\"∳\",\"awint\":\"⨑\",\"backcong\":\"≌\",\"backepsilon\":\"϶\",\"backprime\":\"‵\",\"backsim\":\"∽\",\"backsimeq\":\"⋍\",\"Backslash\":\"∖\",\"Barv\":\"⫧\",\"barvee\":\"⊽\",\"barwed\":\"⌅\",\"Barwed\":\"⌆\",\"barwedge\":\"⌅\",\"bbrk\":\"⎵\",\"bbrktbrk\":\"⎶\",\"bcong\":\"≌\",\"Bcy\":\"Б\",\"bcy\":\"б\",\"bdquo\":\"„\",\"becaus\":\"∵\",\"because\":\"∵\",\"Because\":\"∵\",\"bemptyv\":\"⦰\",\"bepsi\":\"϶\",\"bernou\":\"ℬ\",\"Bernoullis\":\"ℬ\",\"Beta\":\"Β\",\"beta\":\"β\",\"beth\":\"ℶ\",\"between\":\"≬\",\"Bfr\":\"𝔅\",\"bfr\":\"𝔟\",\"bigcap\":\"⋂\",\"bigcirc\":\"◯\",\"bigcup\":\"⋃\",\"bigodot\":\"⨀\",\"bigoplus\":\"⨁\",\"bigotimes\":\"⨂\",\"bigsqcup\":\"⨆\",\"bigstar\":\"★\",\"bigtriangledown\":\"▽\",\"bigtriangleup\":\"△\",\"biguplus\":\"⨄\",\"bigvee\":\"⋁\",\"bigwedge\":\"⋀\",\"bkarow\":\"⤍\",\"blacklozenge\":\"⧫\",\"blacksquare\":\"▪\",\"blacktriangle\":\"▴\",\"blacktriangledown\":\"▾\",\"blacktriangleleft\":\"◂\",\"blacktriangleright\":\"▸\",\"blank\":\"␣\",\"blk12\":\"▒\",\"blk14\":\"░\",\"blk34\":\"▓\",\"block\":\"█\",\"bne\":\"=⃥\",\"bnequiv\":\"≡⃥\",\"bNot\":\"⫭\",\"bnot\":\"⌐\",\"Bopf\":\"𝔹\",\"bopf\":\"𝕓\",\"bot\":\"⊥\",\"bottom\":\"⊥\",\"bowtie\":\"⋈\",\"boxbox\":\"⧉\",\"boxdl\":\"┐\",\"boxdL\":\"╕\",\"boxDl\":\"╖\",\"boxDL\":\"╗\",\"boxdr\":\"┌\",\"boxdR\":\"╒\",\"boxDr\":\"╓\",\"boxDR\":\"╔\",\"boxh\":\"─\",\"boxH\":\"═\",\"boxhd\":\"┬\",\"boxHd\":\"╤\",\"boxhD\":\"╥\",\"boxHD\":\"╦\",\"boxhu\":\"┴\",\"boxHu\":\"╧\",\"boxhU\":\"╨\",\"boxHU\":\"╩\",\"boxminus\":\"⊟\",\"boxplus\":\"⊞\",\"boxtimes\":\"⊠\",\"boxul\":\"┘\",\"boxuL\":\"╛\",\"boxUl\":\"╜\",\"boxUL\":\"╝\",\"boxur\":\"└\",\"boxuR\":\"╘\",\"boxUr\":\"╙\",\"boxUR\":\"╚\",\"boxv\":\"│\",\"boxV\":\"║\",\"boxvh\":\"┼\",\"boxvH\":\"╪\",\"boxVh\":\"╫\",\"boxVH\":\"╬\",\"boxvl\":\"┤\",\"boxvL\":\"╡\",\"boxVl\":\"╢\",\"boxVL\":\"╣\",\"boxvr\":\"├\",\"boxvR\":\"╞\",\"boxVr\":\"╟\",\"boxVR\":\"╠\",\"bprime\":\"‵\",\"breve\":\"˘\",\"Breve\":\"˘\",\"brvbar\":\"¦\",\"bscr\":\"𝒷\",\"Bscr\":\"ℬ\",\"bsemi\":\"⁏\",\"bsim\":\"∽\",\"bsime\":\"⋍\",\"bsolb\":\"⧅\",\"bsol\":\"\\\\\",\"bsolhsub\":\"⟈\",\"bull\":\"•\",\"bullet\":\"•\",\"bump\":\"≎\",\"bumpE\":\"⪮\",\"bumpe\":\"≏\",\"Bumpeq\":\"≎\",\"bumpeq\":\"≏\",\"Cacute\":\"Ć\",\"cacute\":\"ć\",\"capand\":\"⩄\",\"capbrcup\":\"⩉\",\"capcap\":\"⩋\",\"cap\":\"∩\",\"Cap\":\"⋒\",\"capcup\":\"⩇\",\"capdot\":\"⩀\",\"CapitalDifferentialD\":\"ⅅ\",\"caps\":\"∩︀\",\"caret\":\"⁁\",\"caron\":\"ˇ\",\"Cayleys\":\"ℭ\",\"ccaps\":\"⩍\",\"Ccaron\":\"Č\",\"ccaron\":\"č\",\"Ccedil\":\"Ç\",\"ccedil\":\"ç\",\"Ccirc\":\"Ĉ\",\"ccirc\":\"ĉ\",\"Cconint\":\"∰\",\"ccups\":\"⩌\",\"ccupssm\":\"⩐\",\"Cdot\":\"Ċ\",\"cdot\":\"ċ\",\"cedil\":\"¸\",\"Cedilla\":\"¸\",\"cemptyv\":\"⦲\",\"cent\":\"¢\",\"centerdot\":\"·\",\"CenterDot\":\"·\",\"cfr\":\"𝔠\",\"Cfr\":\"ℭ\",\"CHcy\":\"Ч\",\"chcy\":\"ч\",\"check\":\"✓\",\"checkmark\":\"✓\",\"Chi\":\"Χ\",\"chi\":\"χ\",\"circ\":\"ˆ\",\"circeq\":\"≗\",\"circlearrowleft\":\"↺\",\"circlearrowright\":\"↻\",\"circledast\":\"⊛\",\"circledcirc\":\"⊚\",\"circleddash\":\"⊝\",\"CircleDot\":\"⊙\",\"circledR\":\"®\",\"circledS\":\"Ⓢ\",\"CircleMinus\":\"⊖\",\"CirclePlus\":\"⊕\",\"CircleTimes\":\"⊗\",\"cir\":\"○\",\"cirE\":\"⧃\",\"cire\":\"≗\",\"cirfnint\":\"⨐\",\"cirmid\":\"⫯\",\"cirscir\":\"⧂\",\"ClockwiseContourIntegral\":\"∲\",\"CloseCurlyDoubleQuote\":\"”\",\"CloseCurlyQuote\":\"’\",\"clubs\":\"♣\",\"clubsuit\":\"♣\",\"colon\":\":\",\"Colon\":\"∷\",\"Colone\":\"⩴\",\"colone\":\"≔\",\"coloneq\":\"≔\",\"comma\":\",\",\"commat\":\"@\",\"comp\":\"∁\",\"compfn\":\"∘\",\"complement\":\"∁\",\"complexes\":\"ℂ\",\"cong\":\"≅\",\"congdot\":\"⩭\",\"Congruent\":\"≡\",\"conint\":\"∮\",\"Conint\":\"∯\",\"ContourIntegral\":\"∮\",\"copf\":\"𝕔\",\"Copf\":\"ℂ\",\"coprod\":\"∐\",\"Coproduct\":\"∐\",\"copy\":\"©\",\"COPY\":\"©\",\"copysr\":\"℗\",\"CounterClockwiseContourIntegral\":\"∳\",\"crarr\":\"↵\",\"cross\":\"✗\",\"Cross\":\"⨯\",\"Cscr\":\"𝒞\",\"cscr\":\"𝒸\",\"csub\":\"⫏\",\"csube\":\"⫑\",\"csup\":\"⫐\",\"csupe\":\"⫒\",\"ctdot\":\"⋯\",\"cudarrl\":\"⤸\",\"cudarrr\":\"⤵\",\"cuepr\":\"⋞\",\"cuesc\":\"⋟\",\"cularr\":\"↶\",\"cularrp\":\"⤽\",\"cupbrcap\":\"⩈\",\"cupcap\":\"⩆\",\"CupCap\":\"≍\",\"cup\":\"∪\",\"Cup\":\"⋓\",\"cupcup\":\"⩊\",\"cupdot\":\"⊍\",\"cupor\":\"⩅\",\"cups\":\"∪︀\",\"curarr\":\"↷\",\"curarrm\":\"⤼\",\"curlyeqprec\":\"⋞\",\"curlyeqsucc\":\"⋟\",\"curlyvee\":\"⋎\",\"curlywedge\":\"⋏\",\"curren\":\"¤\",\"curvearrowleft\":\"↶\",\"curvearrowright\":\"↷\",\"cuvee\":\"⋎\",\"cuwed\":\"⋏\",\"cwconint\":\"∲\",\"cwint\":\"∱\",\"cylcty\":\"⌭\",\"dagger\":\"†\",\"Dagger\":\"‡\",\"daleth\":\"ℸ\",\"darr\":\"↓\",\"Darr\":\"↡\",\"dArr\":\"⇓\",\"dash\":\"‐\",\"Dashv\":\"⫤\",\"dashv\":\"⊣\",\"dbkarow\":\"⤏\",\"dblac\":\"˝\",\"Dcaron\":\"Ď\",\"dcaron\":\"ď\",\"Dcy\":\"Д\",\"dcy\":\"д\",\"ddagger\":\"‡\",\"ddarr\":\"⇊\",\"DD\":\"ⅅ\",\"dd\":\"ⅆ\",\"DDotrahd\":\"⤑\",\"ddotseq\":\"⩷\",\"deg\":\"°\",\"Del\":\"∇\",\"Delta\":\"Δ\",\"delta\":\"δ\",\"demptyv\":\"⦱\",\"dfisht\":\"⥿\",\"Dfr\":\"𝔇\",\"dfr\":\"𝔡\",\"dHar\":\"⥥\",\"dharl\":\"⇃\",\"dharr\":\"⇂\",\"DiacriticalAcute\":\"´\",\"DiacriticalDot\":\"˙\",\"DiacriticalDoubleAcute\":\"˝\",\"DiacriticalGrave\":\"`\",\"DiacriticalTilde\":\"˜\",\"diam\":\"⋄\",\"diamond\":\"⋄\",\"Diamond\":\"⋄\",\"diamondsuit\":\"♦\",\"diams\":\"♦\",\"die\":\"¨\",\"DifferentialD\":\"ⅆ\",\"digamma\":\"ϝ\",\"disin\":\"⋲\",\"div\":\"÷\",\"divide\":\"÷\",\"divideontimes\":\"⋇\",\"divonx\":\"⋇\",\"DJcy\":\"Ђ\",\"djcy\":\"ђ\",\"dlcorn\":\"⌞\",\"dlcrop\":\"⌍\",\"dollar\":\"$\",\"Dopf\":\"𝔻\",\"dopf\":\"𝕕\",\"Dot\":\"¨\",\"dot\":\"˙\",\"DotDot\":\"⃜\",\"doteq\":\"≐\",\"doteqdot\":\"≑\",\"DotEqual\":\"≐\",\"dotminus\":\"∸\",\"dotplus\":\"∔\",\"dotsquare\":\"⊡\",\"doublebarwedge\":\"⌆\",\"DoubleContourIntegral\":\"∯\",\"DoubleDot\":\"¨\",\"DoubleDownArrow\":\"⇓\",\"DoubleLeftArrow\":\"⇐\",\"DoubleLeftRightArrow\":\"⇔\",\"DoubleLeftTee\":\"⫤\",\"DoubleLongLeftArrow\":\"⟸\",\"DoubleLongLeftRightArrow\":\"⟺\",\"DoubleLongRightArrow\":\"⟹\",\"DoubleRightArrow\":\"⇒\",\"DoubleRightTee\":\"⊨\",\"DoubleUpArrow\":\"⇑\",\"DoubleUpDownArrow\":\"⇕\",\"DoubleVerticalBar\":\"∥\",\"DownArrowBar\":\"⤓\",\"downarrow\":\"↓\",\"DownArrow\":\"↓\",\"Downarrow\":\"⇓\",\"DownArrowUpArrow\":\"⇵\",\"DownBreve\":\"̑\",\"downdownarrows\":\"⇊\",\"downharpoonleft\":\"⇃\",\"downharpoonright\":\"⇂\",\"DownLeftRightVector\":\"⥐\",\"DownLeftTeeVector\":\"⥞\",\"DownLeftVectorBar\":\"⥖\",\"DownLeftVector\":\"↽\",\"DownRightTeeVector\":\"⥟\",\"DownRightVectorBar\":\"⥗\",\"DownRightVector\":\"⇁\",\"DownTeeArrow\":\"↧\",\"DownTee\":\"⊤\",\"drbkarow\":\"⤐\",\"drcorn\":\"⌟\",\"drcrop\":\"⌌\",\"Dscr\":\"𝒟\",\"dscr\":\"𝒹\",\"DScy\":\"Ѕ\",\"dscy\":\"ѕ\",\"dsol\":\"⧶\",\"Dstrok\":\"Đ\",\"dstrok\":\"đ\",\"dtdot\":\"⋱\",\"dtri\":\"▿\",\"dtrif\":\"▾\",\"duarr\":\"⇵\",\"duhar\":\"⥯\",\"dwangle\":\"⦦\",\"DZcy\":\"Џ\",\"dzcy\":\"џ\",\"dzigrarr\":\"⟿\",\"Eacute\":\"É\",\"eacute\":\"é\",\"easter\":\"⩮\",\"Ecaron\":\"Ě\",\"ecaron\":\"ě\",\"Ecirc\":\"Ê\",\"ecirc\":\"ê\",\"ecir\":\"≖\",\"ecolon\":\"≕\",\"Ecy\":\"Э\",\"ecy\":\"э\",\"eDDot\":\"⩷\",\"Edot\":\"Ė\",\"edot\":\"ė\",\"eDot\":\"≑\",\"ee\":\"ⅇ\",\"efDot\":\"≒\",\"Efr\":\"𝔈\",\"efr\":\"𝔢\",\"eg\":\"⪚\",\"Egrave\":\"È\",\"egrave\":\"è\",\"egs\":\"⪖\",\"egsdot\":\"⪘\",\"el\":\"⪙\",\"Element\":\"∈\",\"elinters\":\"⏧\",\"ell\":\"ℓ\",\"els\":\"⪕\",\"elsdot\":\"⪗\",\"Emacr\":\"Ē\",\"emacr\":\"ē\",\"empty\":\"∅\",\"emptyset\":\"∅\",\"EmptySmallSquare\":\"◻\",\"emptyv\":\"∅\",\"EmptyVerySmallSquare\":\"▫\",\"emsp13\":\" \",\"emsp14\":\" \",\"emsp\":\" \",\"ENG\":\"Ŋ\",\"eng\":\"ŋ\",\"ensp\":\" \",\"Eogon\":\"Ę\",\"eogon\":\"ę\",\"Eopf\":\"𝔼\",\"eopf\":\"𝕖\",\"epar\":\"⋕\",\"eparsl\":\"⧣\",\"eplus\":\"⩱\",\"epsi\":\"ε\",\"Epsilon\":\"Ε\",\"epsilon\":\"ε\",\"epsiv\":\"ϵ\",\"eqcirc\":\"≖\",\"eqcolon\":\"≕\",\"eqsim\":\"≂\",\"eqslantgtr\":\"⪖\",\"eqslantless\":\"⪕\",\"Equal\":\"⩵\",\"equals\":\"=\",\"EqualTilde\":\"≂\",\"equest\":\"≟\",\"Equilibrium\":\"⇌\",\"equiv\":\"≡\",\"equivDD\":\"⩸\",\"eqvparsl\":\"⧥\",\"erarr\":\"⥱\",\"erDot\":\"≓\",\"escr\":\"ℯ\",\"Escr\":\"ℰ\",\"esdot\":\"≐\",\"Esim\":\"⩳\",\"esim\":\"≂\",\"Eta\":\"Η\",\"eta\":\"η\",\"ETH\":\"Ð\",\"eth\":\"ð\",\"Euml\":\"Ë\",\"euml\":\"ë\",\"euro\":\"€\",\"excl\":\"!\",\"exist\":\"∃\",\"Exists\":\"∃\",\"expectation\":\"ℰ\",\"exponentiale\":\"ⅇ\",\"ExponentialE\":\"ⅇ\",\"fallingdotseq\":\"≒\",\"Fcy\":\"Ф\",\"fcy\":\"ф\",\"female\":\"♀\",\"ffilig\":\"ffi\",\"fflig\":\"ff\",\"ffllig\":\"ffl\",\"Ffr\":\"𝔉\",\"ffr\":\"𝔣\",\"filig\":\"fi\",\"FilledSmallSquare\":\"◼\",\"FilledVerySmallSquare\":\"▪\",\"fjlig\":\"fj\",\"flat\":\"♭\",\"fllig\":\"fl\",\"fltns\":\"▱\",\"fnof\":\"ƒ\",\"Fopf\":\"𝔽\",\"fopf\":\"𝕗\",\"forall\":\"∀\",\"ForAll\":\"∀\",\"fork\":\"⋔\",\"forkv\":\"⫙\",\"Fouriertrf\":\"ℱ\",\"fpartint\":\"⨍\",\"frac12\":\"½\",\"frac13\":\"⅓\",\"frac14\":\"¼\",\"frac15\":\"⅕\",\"frac16\":\"⅙\",\"frac18\":\"⅛\",\"frac23\":\"⅔\",\"frac25\":\"⅖\",\"frac34\":\"¾\",\"frac35\":\"⅗\",\"frac38\":\"⅜\",\"frac45\":\"⅘\",\"frac56\":\"⅚\",\"frac58\":\"⅝\",\"frac78\":\"⅞\",\"frasl\":\"⁄\",\"frown\":\"⌢\",\"fscr\":\"𝒻\",\"Fscr\":\"ℱ\",\"gacute\":\"ǵ\",\"Gamma\":\"Γ\",\"gamma\":\"γ\",\"Gammad\":\"Ϝ\",\"gammad\":\"ϝ\",\"gap\":\"⪆\",\"Gbreve\":\"Ğ\",\"gbreve\":\"ğ\",\"Gcedil\":\"Ģ\",\"Gcirc\":\"Ĝ\",\"gcirc\":\"ĝ\",\"Gcy\":\"Г\",\"gcy\":\"г\",\"Gdot\":\"Ġ\",\"gdot\":\"ġ\",\"ge\":\"≥\",\"gE\":\"≧\",\"gEl\":\"⪌\",\"gel\":\"⋛\",\"geq\":\"≥\",\"geqq\":\"≧\",\"geqslant\":\"⩾\",\"gescc\":\"⪩\",\"ges\":\"⩾\",\"gesdot\":\"⪀\",\"gesdoto\":\"⪂\",\"gesdotol\":\"⪄\",\"gesl\":\"⋛︀\",\"gesles\":\"⪔\",\"Gfr\":\"𝔊\",\"gfr\":\"𝔤\",\"gg\":\"≫\",\"Gg\":\"⋙\",\"ggg\":\"⋙\",\"gimel\":\"ℷ\",\"GJcy\":\"Ѓ\",\"gjcy\":\"ѓ\",\"gla\":\"⪥\",\"gl\":\"≷\",\"glE\":\"⪒\",\"glj\":\"⪤\",\"gnap\":\"⪊\",\"gnapprox\":\"⪊\",\"gne\":\"⪈\",\"gnE\":\"≩\",\"gneq\":\"⪈\",\"gneqq\":\"≩\",\"gnsim\":\"⋧\",\"Gopf\":\"𝔾\",\"gopf\":\"𝕘\",\"grave\":\"`\",\"GreaterEqual\":\"≥\",\"GreaterEqualLess\":\"⋛\",\"GreaterFullEqual\":\"≧\",\"GreaterGreater\":\"⪢\",\"GreaterLess\":\"≷\",\"GreaterSlantEqual\":\"⩾\",\"GreaterTilde\":\"≳\",\"Gscr\":\"𝒢\",\"gscr\":\"ℊ\",\"gsim\":\"≳\",\"gsime\":\"⪎\",\"gsiml\":\"⪐\",\"gtcc\":\"⪧\",\"gtcir\":\"⩺\",\"gt\":\">\",\"GT\":\">\",\"Gt\":\"≫\",\"gtdot\":\"⋗\",\"gtlPar\":\"⦕\",\"gtquest\":\"⩼\",\"gtrapprox\":\"⪆\",\"gtrarr\":\"⥸\",\"gtrdot\":\"⋗\",\"gtreqless\":\"⋛\",\"gtreqqless\":\"⪌\",\"gtrless\":\"≷\",\"gtrsim\":\"≳\",\"gvertneqq\":\"≩︀\",\"gvnE\":\"≩︀\",\"Hacek\":\"ˇ\",\"hairsp\":\" \",\"half\":\"½\",\"hamilt\":\"ℋ\",\"HARDcy\":\"Ъ\",\"hardcy\":\"ъ\",\"harrcir\":\"⥈\",\"harr\":\"↔\",\"hArr\":\"⇔\",\"harrw\":\"↭\",\"Hat\":\"^\",\"hbar\":\"ℏ\",\"Hcirc\":\"Ĥ\",\"hcirc\":\"ĥ\",\"hearts\":\"♥\",\"heartsuit\":\"♥\",\"hellip\":\"…\",\"hercon\":\"⊹\",\"hfr\":\"𝔥\",\"Hfr\":\"ℌ\",\"HilbertSpace\":\"ℋ\",\"hksearow\":\"⤥\",\"hkswarow\":\"⤦\",\"hoarr\":\"⇿\",\"homtht\":\"∻\",\"hookleftarrow\":\"↩\",\"hookrightarrow\":\"↪\",\"hopf\":\"𝕙\",\"Hopf\":\"ℍ\",\"horbar\":\"―\",\"HorizontalLine\":\"─\",\"hscr\":\"𝒽\",\"Hscr\":\"ℋ\",\"hslash\":\"ℏ\",\"Hstrok\":\"Ħ\",\"hstrok\":\"ħ\",\"HumpDownHump\":\"≎\",\"HumpEqual\":\"≏\",\"hybull\":\"⁃\",\"hyphen\":\"‐\",\"Iacute\":\"Í\",\"iacute\":\"í\",\"ic\":\"⁣\",\"Icirc\":\"Î\",\"icirc\":\"î\",\"Icy\":\"И\",\"icy\":\"и\",\"Idot\":\"İ\",\"IEcy\":\"Е\",\"iecy\":\"е\",\"iexcl\":\"¡\",\"iff\":\"⇔\",\"ifr\":\"𝔦\",\"Ifr\":\"ℑ\",\"Igrave\":\"Ì\",\"igrave\":\"ì\",\"ii\":\"ⅈ\",\"iiiint\":\"⨌\",\"iiint\":\"∭\",\"iinfin\":\"⧜\",\"iiota\":\"℩\",\"IJlig\":\"IJ\",\"ijlig\":\"ij\",\"Imacr\":\"Ī\",\"imacr\":\"ī\",\"image\":\"ℑ\",\"ImaginaryI\":\"ⅈ\",\"imagline\":\"ℐ\",\"imagpart\":\"ℑ\",\"imath\":\"ı\",\"Im\":\"ℑ\",\"imof\":\"⊷\",\"imped\":\"Ƶ\",\"Implies\":\"⇒\",\"incare\":\"℅\",\"in\":\"∈\",\"infin\":\"∞\",\"infintie\":\"⧝\",\"inodot\":\"ı\",\"intcal\":\"⊺\",\"int\":\"∫\",\"Int\":\"∬\",\"integers\":\"ℤ\",\"Integral\":\"∫\",\"intercal\":\"⊺\",\"Intersection\":\"⋂\",\"intlarhk\":\"⨗\",\"intprod\":\"⨼\",\"InvisibleComma\":\"⁣\",\"InvisibleTimes\":\"⁢\",\"IOcy\":\"Ё\",\"iocy\":\"ё\",\"Iogon\":\"Į\",\"iogon\":\"į\",\"Iopf\":\"𝕀\",\"iopf\":\"𝕚\",\"Iota\":\"Ι\",\"iota\":\"ι\",\"iprod\":\"⨼\",\"iquest\":\"¿\",\"iscr\":\"𝒾\",\"Iscr\":\"ℐ\",\"isin\":\"∈\",\"isindot\":\"⋵\",\"isinE\":\"⋹\",\"isins\":\"⋴\",\"isinsv\":\"⋳\",\"isinv\":\"∈\",\"it\":\"⁢\",\"Itilde\":\"Ĩ\",\"itilde\":\"ĩ\",\"Iukcy\":\"І\",\"iukcy\":\"і\",\"Iuml\":\"Ï\",\"iuml\":\"ï\",\"Jcirc\":\"Ĵ\",\"jcirc\":\"ĵ\",\"Jcy\":\"Й\",\"jcy\":\"й\",\"Jfr\":\"𝔍\",\"jfr\":\"𝔧\",\"jmath\":\"ȷ\",\"Jopf\":\"𝕁\",\"jopf\":\"𝕛\",\"Jscr\":\"𝒥\",\"jscr\":\"𝒿\",\"Jsercy\":\"Ј\",\"jsercy\":\"ј\",\"Jukcy\":\"Є\",\"jukcy\":\"є\",\"Kappa\":\"Κ\",\"kappa\":\"κ\",\"kappav\":\"ϰ\",\"Kcedil\":\"Ķ\",\"kcedil\":\"ķ\",\"Kcy\":\"К\",\"kcy\":\"к\",\"Kfr\":\"𝔎\",\"kfr\":\"𝔨\",\"kgreen\":\"ĸ\",\"KHcy\":\"Х\",\"khcy\":\"х\",\"KJcy\":\"Ќ\",\"kjcy\":\"ќ\",\"Kopf\":\"𝕂\",\"kopf\":\"𝕜\",\"Kscr\":\"𝒦\",\"kscr\":\"𝓀\",\"lAarr\":\"⇚\",\"Lacute\":\"Ĺ\",\"lacute\":\"ĺ\",\"laemptyv\":\"⦴\",\"lagran\":\"ℒ\",\"Lambda\":\"Λ\",\"lambda\":\"λ\",\"lang\":\"⟨\",\"Lang\":\"⟪\",\"langd\":\"⦑\",\"langle\":\"⟨\",\"lap\":\"⪅\",\"Laplacetrf\":\"ℒ\",\"laquo\":\"«\",\"larrb\":\"⇤\",\"larrbfs\":\"⤟\",\"larr\":\"←\",\"Larr\":\"↞\",\"lArr\":\"⇐\",\"larrfs\":\"⤝\",\"larrhk\":\"↩\",\"larrlp\":\"↫\",\"larrpl\":\"⤹\",\"larrsim\":\"⥳\",\"larrtl\":\"↢\",\"latail\":\"⤙\",\"lAtail\":\"⤛\",\"lat\":\"⪫\",\"late\":\"⪭\",\"lates\":\"⪭︀\",\"lbarr\":\"⤌\",\"lBarr\":\"⤎\",\"lbbrk\":\"❲\",\"lbrace\":\"{\",\"lbrack\":\"[\",\"lbrke\":\"⦋\",\"lbrksld\":\"⦏\",\"lbrkslu\":\"⦍\",\"Lcaron\":\"Ľ\",\"lcaron\":\"ľ\",\"Lcedil\":\"Ļ\",\"lcedil\":\"ļ\",\"lceil\":\"⌈\",\"lcub\":\"{\",\"Lcy\":\"Л\",\"lcy\":\"л\",\"ldca\":\"⤶\",\"ldquo\":\"“\",\"ldquor\":\"„\",\"ldrdhar\":\"⥧\",\"ldrushar\":\"⥋\",\"ldsh\":\"↲\",\"le\":\"≤\",\"lE\":\"≦\",\"LeftAngleBracket\":\"⟨\",\"LeftArrowBar\":\"⇤\",\"leftarrow\":\"←\",\"LeftArrow\":\"←\",\"Leftarrow\":\"⇐\",\"LeftArrowRightArrow\":\"⇆\",\"leftarrowtail\":\"↢\",\"LeftCeiling\":\"⌈\",\"LeftDoubleBracket\":\"⟦\",\"LeftDownTeeVector\":\"⥡\",\"LeftDownVectorBar\":\"⥙\",\"LeftDownVector\":\"⇃\",\"LeftFloor\":\"⌊\",\"leftharpoondown\":\"↽\",\"leftharpoonup\":\"↼\",\"leftleftarrows\":\"⇇\",\"leftrightarrow\":\"↔\",\"LeftRightArrow\":\"↔\",\"Leftrightarrow\":\"⇔\",\"leftrightarrows\":\"⇆\",\"leftrightharpoons\":\"⇋\",\"leftrightsquigarrow\":\"↭\",\"LeftRightVector\":\"⥎\",\"LeftTeeArrow\":\"↤\",\"LeftTee\":\"⊣\",\"LeftTeeVector\":\"⥚\",\"leftthreetimes\":\"⋋\",\"LeftTriangleBar\":\"⧏\",\"LeftTriangle\":\"⊲\",\"LeftTriangleEqual\":\"⊴\",\"LeftUpDownVector\":\"⥑\",\"LeftUpTeeVector\":\"⥠\",\"LeftUpVectorBar\":\"⥘\",\"LeftUpVector\":\"↿\",\"LeftVectorBar\":\"⥒\",\"LeftVector\":\"↼\",\"lEg\":\"⪋\",\"leg\":\"⋚\",\"leq\":\"≤\",\"leqq\":\"≦\",\"leqslant\":\"⩽\",\"lescc\":\"⪨\",\"les\":\"⩽\",\"lesdot\":\"⩿\",\"lesdoto\":\"⪁\",\"lesdotor\":\"⪃\",\"lesg\":\"⋚︀\",\"lesges\":\"⪓\",\"lessapprox\":\"⪅\",\"lessdot\":\"⋖\",\"lesseqgtr\":\"⋚\",\"lesseqqgtr\":\"⪋\",\"LessEqualGreater\":\"⋚\",\"LessFullEqual\":\"≦\",\"LessGreater\":\"≶\",\"lessgtr\":\"≶\",\"LessLess\":\"⪡\",\"lesssim\":\"≲\",\"LessSlantEqual\":\"⩽\",\"LessTilde\":\"≲\",\"lfisht\":\"⥼\",\"lfloor\":\"⌊\",\"Lfr\":\"𝔏\",\"lfr\":\"𝔩\",\"lg\":\"≶\",\"lgE\":\"⪑\",\"lHar\":\"⥢\",\"lhard\":\"↽\",\"lharu\":\"↼\",\"lharul\":\"⥪\",\"lhblk\":\"▄\",\"LJcy\":\"Љ\",\"ljcy\":\"љ\",\"llarr\":\"⇇\",\"ll\":\"≪\",\"Ll\":\"⋘\",\"llcorner\":\"⌞\",\"Lleftarrow\":\"⇚\",\"llhard\":\"⥫\",\"lltri\":\"◺\",\"Lmidot\":\"Ŀ\",\"lmidot\":\"ŀ\",\"lmoustache\":\"⎰\",\"lmoust\":\"⎰\",\"lnap\":\"⪉\",\"lnapprox\":\"⪉\",\"lne\":\"⪇\",\"lnE\":\"≨\",\"lneq\":\"⪇\",\"lneqq\":\"≨\",\"lnsim\":\"⋦\",\"loang\":\"⟬\",\"loarr\":\"⇽\",\"lobrk\":\"⟦\",\"longleftarrow\":\"⟵\",\"LongLeftArrow\":\"⟵\",\"Longleftarrow\":\"⟸\",\"longleftrightarrow\":\"⟷\",\"LongLeftRightArrow\":\"⟷\",\"Longleftrightarrow\":\"⟺\",\"longmapsto\":\"⟼\",\"longrightarrow\":\"⟶\",\"LongRightArrow\":\"⟶\",\"Longrightarrow\":\"⟹\",\"looparrowleft\":\"↫\",\"looparrowright\":\"↬\",\"lopar\":\"⦅\",\"Lopf\":\"𝕃\",\"lopf\":\"𝕝\",\"loplus\":\"⨭\",\"lotimes\":\"⨴\",\"lowast\":\"∗\",\"lowbar\":\"_\",\"LowerLeftArrow\":\"↙\",\"LowerRightArrow\":\"↘\",\"loz\":\"◊\",\"lozenge\":\"◊\",\"lozf\":\"⧫\",\"lpar\":\"(\",\"lparlt\":\"⦓\",\"lrarr\":\"⇆\",\"lrcorner\":\"⌟\",\"lrhar\":\"⇋\",\"lrhard\":\"⥭\",\"lrm\":\"‎\",\"lrtri\":\"⊿\",\"lsaquo\":\"‹\",\"lscr\":\"𝓁\",\"Lscr\":\"ℒ\",\"lsh\":\"↰\",\"Lsh\":\"↰\",\"lsim\":\"≲\",\"lsime\":\"⪍\",\"lsimg\":\"⪏\",\"lsqb\":\"[\",\"lsquo\":\"‘\",\"lsquor\":\"‚\",\"Lstrok\":\"Ł\",\"lstrok\":\"ł\",\"ltcc\":\"⪦\",\"ltcir\":\"⩹\",\"lt\":\"<\",\"LT\":\"<\",\"Lt\":\"≪\",\"ltdot\":\"⋖\",\"lthree\":\"⋋\",\"ltimes\":\"⋉\",\"ltlarr\":\"⥶\",\"ltquest\":\"⩻\",\"ltri\":\"◃\",\"ltrie\":\"⊴\",\"ltrif\":\"◂\",\"ltrPar\":\"⦖\",\"lurdshar\":\"⥊\",\"luruhar\":\"⥦\",\"lvertneqq\":\"≨︀\",\"lvnE\":\"≨︀\",\"macr\":\"¯\",\"male\":\"♂\",\"malt\":\"✠\",\"maltese\":\"✠\",\"Map\":\"⤅\",\"map\":\"↦\",\"mapsto\":\"↦\",\"mapstodown\":\"↧\",\"mapstoleft\":\"↤\",\"mapstoup\":\"↥\",\"marker\":\"▮\",\"mcomma\":\"⨩\",\"Mcy\":\"М\",\"mcy\":\"м\",\"mdash\":\"—\",\"mDDot\":\"∺\",\"measuredangle\":\"∡\",\"MediumSpace\":\" \",\"Mellintrf\":\"ℳ\",\"Mfr\":\"𝔐\",\"mfr\":\"𝔪\",\"mho\":\"℧\",\"micro\":\"µ\",\"midast\":\"*\",\"midcir\":\"⫰\",\"mid\":\"∣\",\"middot\":\"·\",\"minusb\":\"⊟\",\"minus\":\"−\",\"minusd\":\"∸\",\"minusdu\":\"⨪\",\"MinusPlus\":\"∓\",\"mlcp\":\"⫛\",\"mldr\":\"…\",\"mnplus\":\"∓\",\"models\":\"⊧\",\"Mopf\":\"𝕄\",\"mopf\":\"𝕞\",\"mp\":\"∓\",\"mscr\":\"𝓂\",\"Mscr\":\"ℳ\",\"mstpos\":\"∾\",\"Mu\":\"Μ\",\"mu\":\"μ\",\"multimap\":\"⊸\",\"mumap\":\"⊸\",\"nabla\":\"∇\",\"Nacute\":\"Ń\",\"nacute\":\"ń\",\"nang\":\"∠⃒\",\"nap\":\"≉\",\"napE\":\"⩰̸\",\"napid\":\"≋̸\",\"napos\":\"ʼn\",\"napprox\":\"≉\",\"natural\":\"♮\",\"naturals\":\"ℕ\",\"natur\":\"♮\",\"nbsp\":\" \",\"nbump\":\"≎̸\",\"nbumpe\":\"≏̸\",\"ncap\":\"⩃\",\"Ncaron\":\"Ň\",\"ncaron\":\"ň\",\"Ncedil\":\"Ņ\",\"ncedil\":\"ņ\",\"ncong\":\"≇\",\"ncongdot\":\"⩭̸\",\"ncup\":\"⩂\",\"Ncy\":\"Н\",\"ncy\":\"н\",\"ndash\":\"–\",\"nearhk\":\"⤤\",\"nearr\":\"↗\",\"neArr\":\"⇗\",\"nearrow\":\"↗\",\"ne\":\"≠\",\"nedot\":\"≐̸\",\"NegativeMediumSpace\":\"​\",\"NegativeThickSpace\":\"​\",\"NegativeThinSpace\":\"​\",\"NegativeVeryThinSpace\":\"​\",\"nequiv\":\"≢\",\"nesear\":\"⤨\",\"nesim\":\"≂̸\",\"NestedGreaterGreater\":\"≫\",\"NestedLessLess\":\"≪\",\"NewLine\":\"\\n\",\"nexist\":\"∄\",\"nexists\":\"∄\",\"Nfr\":\"𝔑\",\"nfr\":\"𝔫\",\"ngE\":\"≧̸\",\"nge\":\"≱\",\"ngeq\":\"≱\",\"ngeqq\":\"≧̸\",\"ngeqslant\":\"⩾̸\",\"nges\":\"⩾̸\",\"nGg\":\"⋙̸\",\"ngsim\":\"≵\",\"nGt\":\"≫⃒\",\"ngt\":\"≯\",\"ngtr\":\"≯\",\"nGtv\":\"≫̸\",\"nharr\":\"↮\",\"nhArr\":\"⇎\",\"nhpar\":\"⫲\",\"ni\":\"∋\",\"nis\":\"⋼\",\"nisd\":\"⋺\",\"niv\":\"∋\",\"NJcy\":\"Њ\",\"njcy\":\"њ\",\"nlarr\":\"↚\",\"nlArr\":\"⇍\",\"nldr\":\"‥\",\"nlE\":\"≦̸\",\"nle\":\"≰\",\"nleftarrow\":\"↚\",\"nLeftarrow\":\"⇍\",\"nleftrightarrow\":\"↮\",\"nLeftrightarrow\":\"⇎\",\"nleq\":\"≰\",\"nleqq\":\"≦̸\",\"nleqslant\":\"⩽̸\",\"nles\":\"⩽̸\",\"nless\":\"≮\",\"nLl\":\"⋘̸\",\"nlsim\":\"≴\",\"nLt\":\"≪⃒\",\"nlt\":\"≮\",\"nltri\":\"⋪\",\"nltrie\":\"⋬\",\"nLtv\":\"≪̸\",\"nmid\":\"∤\",\"NoBreak\":\"⁠\",\"NonBreakingSpace\":\" \",\"nopf\":\"𝕟\",\"Nopf\":\"ℕ\",\"Not\":\"⫬\",\"not\":\"¬\",\"NotCongruent\":\"≢\",\"NotCupCap\":\"≭\",\"NotDoubleVerticalBar\":\"∦\",\"NotElement\":\"∉\",\"NotEqual\":\"≠\",\"NotEqualTilde\":\"≂̸\",\"NotExists\":\"∄\",\"NotGreater\":\"≯\",\"NotGreaterEqual\":\"≱\",\"NotGreaterFullEqual\":\"≧̸\",\"NotGreaterGreater\":\"≫̸\",\"NotGreaterLess\":\"≹\",\"NotGreaterSlantEqual\":\"⩾̸\",\"NotGreaterTilde\":\"≵\",\"NotHumpDownHump\":\"≎̸\",\"NotHumpEqual\":\"≏̸\",\"notin\":\"∉\",\"notindot\":\"⋵̸\",\"notinE\":\"⋹̸\",\"notinva\":\"∉\",\"notinvb\":\"⋷\",\"notinvc\":\"⋶\",\"NotLeftTriangleBar\":\"⧏̸\",\"NotLeftTriangle\":\"⋪\",\"NotLeftTriangleEqual\":\"⋬\",\"NotLess\":\"≮\",\"NotLessEqual\":\"≰\",\"NotLessGreater\":\"≸\",\"NotLessLess\":\"≪̸\",\"NotLessSlantEqual\":\"⩽̸\",\"NotLessTilde\":\"≴\",\"NotNestedGreaterGreater\":\"⪢̸\",\"NotNestedLessLess\":\"⪡̸\",\"notni\":\"∌\",\"notniva\":\"∌\",\"notnivb\":\"⋾\",\"notnivc\":\"⋽\",\"NotPrecedes\":\"⊀\",\"NotPrecedesEqual\":\"⪯̸\",\"NotPrecedesSlantEqual\":\"⋠\",\"NotReverseElement\":\"∌\",\"NotRightTriangleBar\":\"⧐̸\",\"NotRightTriangle\":\"⋫\",\"NotRightTriangleEqual\":\"⋭\",\"NotSquareSubset\":\"⊏̸\",\"NotSquareSubsetEqual\":\"⋢\",\"NotSquareSuperset\":\"⊐̸\",\"NotSquareSupersetEqual\":\"⋣\",\"NotSubset\":\"⊂⃒\",\"NotSubsetEqual\":\"⊈\",\"NotSucceeds\":\"⊁\",\"NotSucceedsEqual\":\"⪰̸\",\"NotSucceedsSlantEqual\":\"⋡\",\"NotSucceedsTilde\":\"≿̸\",\"NotSuperset\":\"⊃⃒\",\"NotSupersetEqual\":\"⊉\",\"NotTilde\":\"≁\",\"NotTildeEqual\":\"≄\",\"NotTildeFullEqual\":\"≇\",\"NotTildeTilde\":\"≉\",\"NotVerticalBar\":\"∤\",\"nparallel\":\"∦\",\"npar\":\"∦\",\"nparsl\":\"⫽⃥\",\"npart\":\"∂̸\",\"npolint\":\"⨔\",\"npr\":\"⊀\",\"nprcue\":\"⋠\",\"nprec\":\"⊀\",\"npreceq\":\"⪯̸\",\"npre\":\"⪯̸\",\"nrarrc\":\"⤳̸\",\"nrarr\":\"↛\",\"nrArr\":\"⇏\",\"nrarrw\":\"↝̸\",\"nrightarrow\":\"↛\",\"nRightarrow\":\"⇏\",\"nrtri\":\"⋫\",\"nrtrie\":\"⋭\",\"nsc\":\"⊁\",\"nsccue\":\"⋡\",\"nsce\":\"⪰̸\",\"Nscr\":\"𝒩\",\"nscr\":\"𝓃\",\"nshortmid\":\"∤\",\"nshortparallel\":\"∦\",\"nsim\":\"≁\",\"nsime\":\"≄\",\"nsimeq\":\"≄\",\"nsmid\":\"∤\",\"nspar\":\"∦\",\"nsqsube\":\"⋢\",\"nsqsupe\":\"⋣\",\"nsub\":\"⊄\",\"nsubE\":\"⫅̸\",\"nsube\":\"⊈\",\"nsubset\":\"⊂⃒\",\"nsubseteq\":\"⊈\",\"nsubseteqq\":\"⫅̸\",\"nsucc\":\"⊁\",\"nsucceq\":\"⪰̸\",\"nsup\":\"⊅\",\"nsupE\":\"⫆̸\",\"nsupe\":\"⊉\",\"nsupset\":\"⊃⃒\",\"nsupseteq\":\"⊉\",\"nsupseteqq\":\"⫆̸\",\"ntgl\":\"≹\",\"Ntilde\":\"Ñ\",\"ntilde\":\"ñ\",\"ntlg\":\"≸\",\"ntriangleleft\":\"⋪\",\"ntrianglelefteq\":\"⋬\",\"ntriangleright\":\"⋫\",\"ntrianglerighteq\":\"⋭\",\"Nu\":\"Ν\",\"nu\":\"ν\",\"num\":\"#\",\"numero\":\"№\",\"numsp\":\" \",\"nvap\":\"≍⃒\",\"nvdash\":\"⊬\",\"nvDash\":\"⊭\",\"nVdash\":\"⊮\",\"nVDash\":\"⊯\",\"nvge\":\"≥⃒\",\"nvgt\":\">⃒\",\"nvHarr\":\"⤄\",\"nvinfin\":\"⧞\",\"nvlArr\":\"⤂\",\"nvle\":\"≤⃒\",\"nvlt\":\"<⃒\",\"nvltrie\":\"⊴⃒\",\"nvrArr\":\"⤃\",\"nvrtrie\":\"⊵⃒\",\"nvsim\":\"∼⃒\",\"nwarhk\":\"⤣\",\"nwarr\":\"↖\",\"nwArr\":\"⇖\",\"nwarrow\":\"↖\",\"nwnear\":\"⤧\",\"Oacute\":\"Ó\",\"oacute\":\"ó\",\"oast\":\"⊛\",\"Ocirc\":\"Ô\",\"ocirc\":\"ô\",\"ocir\":\"⊚\",\"Ocy\":\"О\",\"ocy\":\"о\",\"odash\":\"⊝\",\"Odblac\":\"Ő\",\"odblac\":\"ő\",\"odiv\":\"⨸\",\"odot\":\"⊙\",\"odsold\":\"⦼\",\"OElig\":\"Œ\",\"oelig\":\"œ\",\"ofcir\":\"⦿\",\"Ofr\":\"𝔒\",\"ofr\":\"𝔬\",\"ogon\":\"˛\",\"Ograve\":\"Ò\",\"ograve\":\"ò\",\"ogt\":\"⧁\",\"ohbar\":\"⦵\",\"ohm\":\"Ω\",\"oint\":\"∮\",\"olarr\":\"↺\",\"olcir\":\"⦾\",\"olcross\":\"⦻\",\"oline\":\"‾\",\"olt\":\"⧀\",\"Omacr\":\"Ō\",\"omacr\":\"ō\",\"Omega\":\"Ω\",\"omega\":\"ω\",\"Omicron\":\"Ο\",\"omicron\":\"ο\",\"omid\":\"⦶\",\"ominus\":\"⊖\",\"Oopf\":\"𝕆\",\"oopf\":\"𝕠\",\"opar\":\"⦷\",\"OpenCurlyDoubleQuote\":\"“\",\"OpenCurlyQuote\":\"‘\",\"operp\":\"⦹\",\"oplus\":\"⊕\",\"orarr\":\"↻\",\"Or\":\"⩔\",\"or\":\"∨\",\"ord\":\"⩝\",\"order\":\"ℴ\",\"orderof\":\"ℴ\",\"ordf\":\"ª\",\"ordm\":\"º\",\"origof\":\"⊶\",\"oror\":\"⩖\",\"orslope\":\"⩗\",\"orv\":\"⩛\",\"oS\":\"Ⓢ\",\"Oscr\":\"𝒪\",\"oscr\":\"ℴ\",\"Oslash\":\"Ø\",\"oslash\":\"ø\",\"osol\":\"⊘\",\"Otilde\":\"Õ\",\"otilde\":\"õ\",\"otimesas\":\"⨶\",\"Otimes\":\"⨷\",\"otimes\":\"⊗\",\"Ouml\":\"Ö\",\"ouml\":\"ö\",\"ovbar\":\"⌽\",\"OverBar\":\"‾\",\"OverBrace\":\"⏞\",\"OverBracket\":\"⎴\",\"OverParenthesis\":\"⏜\",\"para\":\"¶\",\"parallel\":\"∥\",\"par\":\"∥\",\"parsim\":\"⫳\",\"parsl\":\"⫽\",\"part\":\"∂\",\"PartialD\":\"∂\",\"Pcy\":\"П\",\"pcy\":\"п\",\"percnt\":\"%\",\"period\":\".\",\"permil\":\"‰\",\"perp\":\"⊥\",\"pertenk\":\"‱\",\"Pfr\":\"𝔓\",\"pfr\":\"𝔭\",\"Phi\":\"Φ\",\"phi\":\"φ\",\"phiv\":\"ϕ\",\"phmmat\":\"ℳ\",\"phone\":\"☎\",\"Pi\":\"Π\",\"pi\":\"π\",\"pitchfork\":\"⋔\",\"piv\":\"ϖ\",\"planck\":\"ℏ\",\"planckh\":\"ℎ\",\"plankv\":\"ℏ\",\"plusacir\":\"⨣\",\"plusb\":\"⊞\",\"pluscir\":\"⨢\",\"plus\":\"+\",\"plusdo\":\"∔\",\"plusdu\":\"⨥\",\"pluse\":\"⩲\",\"PlusMinus\":\"±\",\"plusmn\":\"±\",\"plussim\":\"⨦\",\"plustwo\":\"⨧\",\"pm\":\"±\",\"Poincareplane\":\"ℌ\",\"pointint\":\"⨕\",\"popf\":\"𝕡\",\"Popf\":\"ℙ\",\"pound\":\"£\",\"prap\":\"⪷\",\"Pr\":\"⪻\",\"pr\":\"≺\",\"prcue\":\"≼\",\"precapprox\":\"⪷\",\"prec\":\"≺\",\"preccurlyeq\":\"≼\",\"Precedes\":\"≺\",\"PrecedesEqual\":\"⪯\",\"PrecedesSlantEqual\":\"≼\",\"PrecedesTilde\":\"≾\",\"preceq\":\"⪯\",\"precnapprox\":\"⪹\",\"precneqq\":\"⪵\",\"precnsim\":\"⋨\",\"pre\":\"⪯\",\"prE\":\"⪳\",\"precsim\":\"≾\",\"prime\":\"′\",\"Prime\":\"″\",\"primes\":\"ℙ\",\"prnap\":\"⪹\",\"prnE\":\"⪵\",\"prnsim\":\"⋨\",\"prod\":\"∏\",\"Product\":\"∏\",\"profalar\":\"⌮\",\"profline\":\"⌒\",\"profsurf\":\"⌓\",\"prop\":\"∝\",\"Proportional\":\"∝\",\"Proportion\":\"∷\",\"propto\":\"∝\",\"prsim\":\"≾\",\"prurel\":\"⊰\",\"Pscr\":\"𝒫\",\"pscr\":\"𝓅\",\"Psi\":\"Ψ\",\"psi\":\"ψ\",\"puncsp\":\" \",\"Qfr\":\"𝔔\",\"qfr\":\"𝔮\",\"qint\":\"⨌\",\"qopf\":\"𝕢\",\"Qopf\":\"ℚ\",\"qprime\":\"⁗\",\"Qscr\":\"𝒬\",\"qscr\":\"𝓆\",\"quaternions\":\"ℍ\",\"quatint\":\"⨖\",\"quest\":\"?\",\"questeq\":\"≟\",\"quot\":\"\\\"\",\"QUOT\":\"\\\"\",\"rAarr\":\"⇛\",\"race\":\"∽̱\",\"Racute\":\"Ŕ\",\"racute\":\"ŕ\",\"radic\":\"√\",\"raemptyv\":\"⦳\",\"rang\":\"⟩\",\"Rang\":\"⟫\",\"rangd\":\"⦒\",\"range\":\"⦥\",\"rangle\":\"⟩\",\"raquo\":\"»\",\"rarrap\":\"⥵\",\"rarrb\":\"⇥\",\"rarrbfs\":\"⤠\",\"rarrc\":\"⤳\",\"rarr\":\"→\",\"Rarr\":\"↠\",\"rArr\":\"⇒\",\"rarrfs\":\"⤞\",\"rarrhk\":\"↪\",\"rarrlp\":\"↬\",\"rarrpl\":\"⥅\",\"rarrsim\":\"⥴\",\"Rarrtl\":\"⤖\",\"rarrtl\":\"↣\",\"rarrw\":\"↝\",\"ratail\":\"⤚\",\"rAtail\":\"⤜\",\"ratio\":\"∶\",\"rationals\":\"ℚ\",\"rbarr\":\"⤍\",\"rBarr\":\"⤏\",\"RBarr\":\"⤐\",\"rbbrk\":\"❳\",\"rbrace\":\"}\",\"rbrack\":\"]\",\"rbrke\":\"⦌\",\"rbrksld\":\"⦎\",\"rbrkslu\":\"⦐\",\"Rcaron\":\"Ř\",\"rcaron\":\"ř\",\"Rcedil\":\"Ŗ\",\"rcedil\":\"ŗ\",\"rceil\":\"⌉\",\"rcub\":\"}\",\"Rcy\":\"Р\",\"rcy\":\"р\",\"rdca\":\"⤷\",\"rdldhar\":\"⥩\",\"rdquo\":\"”\",\"rdquor\":\"”\",\"rdsh\":\"↳\",\"real\":\"ℜ\",\"realine\":\"ℛ\",\"realpart\":\"ℜ\",\"reals\":\"ℝ\",\"Re\":\"ℜ\",\"rect\":\"▭\",\"reg\":\"®\",\"REG\":\"®\",\"ReverseElement\":\"∋\",\"ReverseEquilibrium\":\"⇋\",\"ReverseUpEquilibrium\":\"⥯\",\"rfisht\":\"⥽\",\"rfloor\":\"⌋\",\"rfr\":\"𝔯\",\"Rfr\":\"ℜ\",\"rHar\":\"⥤\",\"rhard\":\"⇁\",\"rharu\":\"⇀\",\"rharul\":\"⥬\",\"Rho\":\"Ρ\",\"rho\":\"ρ\",\"rhov\":\"ϱ\",\"RightAngleBracket\":\"⟩\",\"RightArrowBar\":\"⇥\",\"rightarrow\":\"→\",\"RightArrow\":\"→\",\"Rightarrow\":\"⇒\",\"RightArrowLeftArrow\":\"⇄\",\"rightarrowtail\":\"↣\",\"RightCeiling\":\"⌉\",\"RightDoubleBracket\":\"⟧\",\"RightDownTeeVector\":\"⥝\",\"RightDownVectorBar\":\"⥕\",\"RightDownVector\":\"⇂\",\"RightFloor\":\"⌋\",\"rightharpoondown\":\"⇁\",\"rightharpoonup\":\"⇀\",\"rightleftarrows\":\"⇄\",\"rightleftharpoons\":\"⇌\",\"rightrightarrows\":\"⇉\",\"rightsquigarrow\":\"↝\",\"RightTeeArrow\":\"↦\",\"RightTee\":\"⊢\",\"RightTeeVector\":\"⥛\",\"rightthreetimes\":\"⋌\",\"RightTriangleBar\":\"⧐\",\"RightTriangle\":\"⊳\",\"RightTriangleEqual\":\"⊵\",\"RightUpDownVector\":\"⥏\",\"RightUpTeeVector\":\"⥜\",\"RightUpVectorBar\":\"⥔\",\"RightUpVector\":\"↾\",\"RightVectorBar\":\"⥓\",\"RightVector\":\"⇀\",\"ring\":\"˚\",\"risingdotseq\":\"≓\",\"rlarr\":\"⇄\",\"rlhar\":\"⇌\",\"rlm\":\"‏\",\"rmoustache\":\"⎱\",\"rmoust\":\"⎱\",\"rnmid\":\"⫮\",\"roang\":\"⟭\",\"roarr\":\"⇾\",\"robrk\":\"⟧\",\"ropar\":\"⦆\",\"ropf\":\"𝕣\",\"Ropf\":\"ℝ\",\"roplus\":\"⨮\",\"rotimes\":\"⨵\",\"RoundImplies\":\"⥰\",\"rpar\":\")\",\"rpargt\":\"⦔\",\"rppolint\":\"⨒\",\"rrarr\":\"⇉\",\"Rrightarrow\":\"⇛\",\"rsaquo\":\"›\",\"rscr\":\"𝓇\",\"Rscr\":\"ℛ\",\"rsh\":\"↱\",\"Rsh\":\"↱\",\"rsqb\":\"]\",\"rsquo\":\"’\",\"rsquor\":\"’\",\"rthree\":\"⋌\",\"rtimes\":\"⋊\",\"rtri\":\"▹\",\"rtrie\":\"⊵\",\"rtrif\":\"▸\",\"rtriltri\":\"⧎\",\"RuleDelayed\":\"⧴\",\"ruluhar\":\"⥨\",\"rx\":\"℞\",\"Sacute\":\"Ś\",\"sacute\":\"ś\",\"sbquo\":\"‚\",\"scap\":\"⪸\",\"Scaron\":\"Š\",\"scaron\":\"š\",\"Sc\":\"⪼\",\"sc\":\"≻\",\"sccue\":\"≽\",\"sce\":\"⪰\",\"scE\":\"⪴\",\"Scedil\":\"Ş\",\"scedil\":\"ş\",\"Scirc\":\"Ŝ\",\"scirc\":\"ŝ\",\"scnap\":\"⪺\",\"scnE\":\"⪶\",\"scnsim\":\"⋩\",\"scpolint\":\"⨓\",\"scsim\":\"≿\",\"Scy\":\"С\",\"scy\":\"с\",\"sdotb\":\"⊡\",\"sdot\":\"⋅\",\"sdote\":\"⩦\",\"searhk\":\"⤥\",\"searr\":\"↘\",\"seArr\":\"⇘\",\"searrow\":\"↘\",\"sect\":\"§\",\"semi\":\";\",\"seswar\":\"⤩\",\"setminus\":\"∖\",\"setmn\":\"∖\",\"sext\":\"✶\",\"Sfr\":\"𝔖\",\"sfr\":\"𝔰\",\"sfrown\":\"⌢\",\"sharp\":\"♯\",\"SHCHcy\":\"Щ\",\"shchcy\":\"щ\",\"SHcy\":\"Ш\",\"shcy\":\"ш\",\"ShortDownArrow\":\"↓\",\"ShortLeftArrow\":\"←\",\"shortmid\":\"∣\",\"shortparallel\":\"∥\",\"ShortRightArrow\":\"→\",\"ShortUpArrow\":\"↑\",\"shy\":\"­\",\"Sigma\":\"Σ\",\"sigma\":\"σ\",\"sigmaf\":\"ς\",\"sigmav\":\"ς\",\"sim\":\"∼\",\"simdot\":\"⩪\",\"sime\":\"≃\",\"simeq\":\"≃\",\"simg\":\"⪞\",\"simgE\":\"⪠\",\"siml\":\"⪝\",\"simlE\":\"⪟\",\"simne\":\"≆\",\"simplus\":\"⨤\",\"simrarr\":\"⥲\",\"slarr\":\"←\",\"SmallCircle\":\"∘\",\"smallsetminus\":\"∖\",\"smashp\":\"⨳\",\"smeparsl\":\"⧤\",\"smid\":\"∣\",\"smile\":\"⌣\",\"smt\":\"⪪\",\"smte\":\"⪬\",\"smtes\":\"⪬︀\",\"SOFTcy\":\"Ь\",\"softcy\":\"ь\",\"solbar\":\"⌿\",\"solb\":\"⧄\",\"sol\":\"/\",\"Sopf\":\"𝕊\",\"sopf\":\"𝕤\",\"spades\":\"♠\",\"spadesuit\":\"♠\",\"spar\":\"∥\",\"sqcap\":\"⊓\",\"sqcaps\":\"⊓︀\",\"sqcup\":\"⊔\",\"sqcups\":\"⊔︀\",\"Sqrt\":\"√\",\"sqsub\":\"⊏\",\"sqsube\":\"⊑\",\"sqsubset\":\"⊏\",\"sqsubseteq\":\"⊑\",\"sqsup\":\"⊐\",\"sqsupe\":\"⊒\",\"sqsupset\":\"⊐\",\"sqsupseteq\":\"⊒\",\"square\":\"□\",\"Square\":\"□\",\"SquareIntersection\":\"⊓\",\"SquareSubset\":\"⊏\",\"SquareSubsetEqual\":\"⊑\",\"SquareSuperset\":\"⊐\",\"SquareSupersetEqual\":\"⊒\",\"SquareUnion\":\"⊔\",\"squarf\":\"▪\",\"squ\":\"□\",\"squf\":\"▪\",\"srarr\":\"→\",\"Sscr\":\"𝒮\",\"sscr\":\"𝓈\",\"ssetmn\":\"∖\",\"ssmile\":\"⌣\",\"sstarf\":\"⋆\",\"Star\":\"⋆\",\"star\":\"☆\",\"starf\":\"★\",\"straightepsilon\":\"ϵ\",\"straightphi\":\"ϕ\",\"strns\":\"¯\",\"sub\":\"⊂\",\"Sub\":\"⋐\",\"subdot\":\"⪽\",\"subE\":\"⫅\",\"sube\":\"⊆\",\"subedot\":\"⫃\",\"submult\":\"⫁\",\"subnE\":\"⫋\",\"subne\":\"⊊\",\"subplus\":\"⪿\",\"subrarr\":\"⥹\",\"subset\":\"⊂\",\"Subset\":\"⋐\",\"subseteq\":\"⊆\",\"subseteqq\":\"⫅\",\"SubsetEqual\":\"⊆\",\"subsetneq\":\"⊊\",\"subsetneqq\":\"⫋\",\"subsim\":\"⫇\",\"subsub\":\"⫕\",\"subsup\":\"⫓\",\"succapprox\":\"⪸\",\"succ\":\"≻\",\"succcurlyeq\":\"≽\",\"Succeeds\":\"≻\",\"SucceedsEqual\":\"⪰\",\"SucceedsSlantEqual\":\"≽\",\"SucceedsTilde\":\"≿\",\"succeq\":\"⪰\",\"succnapprox\":\"⪺\",\"succneqq\":\"⪶\",\"succnsim\":\"⋩\",\"succsim\":\"≿\",\"SuchThat\":\"∋\",\"sum\":\"∑\",\"Sum\":\"∑\",\"sung\":\"♪\",\"sup1\":\"¹\",\"sup2\":\"²\",\"sup3\":\"³\",\"sup\":\"⊃\",\"Sup\":\"⋑\",\"supdot\":\"⪾\",\"supdsub\":\"⫘\",\"supE\":\"⫆\",\"supe\":\"⊇\",\"supedot\":\"⫄\",\"Superset\":\"⊃\",\"SupersetEqual\":\"⊇\",\"suphsol\":\"⟉\",\"suphsub\":\"⫗\",\"suplarr\":\"⥻\",\"supmult\":\"⫂\",\"supnE\":\"⫌\",\"supne\":\"⊋\",\"supplus\":\"⫀\",\"supset\":\"⊃\",\"Supset\":\"⋑\",\"supseteq\":\"⊇\",\"supseteqq\":\"⫆\",\"supsetneq\":\"⊋\",\"supsetneqq\":\"⫌\",\"supsim\":\"⫈\",\"supsub\":\"⫔\",\"supsup\":\"⫖\",\"swarhk\":\"⤦\",\"swarr\":\"↙\",\"swArr\":\"⇙\",\"swarrow\":\"↙\",\"swnwar\":\"⤪\",\"szlig\":\"ß\",\"Tab\":\"\\t\",\"target\":\"⌖\",\"Tau\":\"Τ\",\"tau\":\"τ\",\"tbrk\":\"⎴\",\"Tcaron\":\"Ť\",\"tcaron\":\"ť\",\"Tcedil\":\"Ţ\",\"tcedil\":\"ţ\",\"Tcy\":\"Т\",\"tcy\":\"т\",\"tdot\":\"⃛\",\"telrec\":\"⌕\",\"Tfr\":\"𝔗\",\"tfr\":\"𝔱\",\"there4\":\"∴\",\"therefore\":\"∴\",\"Therefore\":\"∴\",\"Theta\":\"Θ\",\"theta\":\"θ\",\"thetasym\":\"ϑ\",\"thetav\":\"ϑ\",\"thickapprox\":\"≈\",\"thicksim\":\"∼\",\"ThickSpace\":\"  \",\"ThinSpace\":\" \",\"thinsp\":\" \",\"thkap\":\"≈\",\"thksim\":\"∼\",\"THORN\":\"Þ\",\"thorn\":\"þ\",\"tilde\":\"˜\",\"Tilde\":\"∼\",\"TildeEqual\":\"≃\",\"TildeFullEqual\":\"≅\",\"TildeTilde\":\"≈\",\"timesbar\":\"⨱\",\"timesb\":\"⊠\",\"times\":\"×\",\"timesd\":\"⨰\",\"tint\":\"∭\",\"toea\":\"⤨\",\"topbot\":\"⌶\",\"topcir\":\"⫱\",\"top\":\"⊤\",\"Topf\":\"𝕋\",\"topf\":\"𝕥\",\"topfork\":\"⫚\",\"tosa\":\"⤩\",\"tprime\":\"‴\",\"trade\":\"™\",\"TRADE\":\"™\",\"triangle\":\"▵\",\"triangledown\":\"▿\",\"triangleleft\":\"◃\",\"trianglelefteq\":\"⊴\",\"triangleq\":\"≜\",\"triangleright\":\"▹\",\"trianglerighteq\":\"⊵\",\"tridot\":\"◬\",\"trie\":\"≜\",\"triminus\":\"⨺\",\"TripleDot\":\"⃛\",\"triplus\":\"⨹\",\"trisb\":\"⧍\",\"tritime\":\"⨻\",\"trpezium\":\"⏢\",\"Tscr\":\"𝒯\",\"tscr\":\"𝓉\",\"TScy\":\"Ц\",\"tscy\":\"ц\",\"TSHcy\":\"Ћ\",\"tshcy\":\"ћ\",\"Tstrok\":\"Ŧ\",\"tstrok\":\"ŧ\",\"twixt\":\"≬\",\"twoheadleftarrow\":\"↞\",\"twoheadrightarrow\":\"↠\",\"Uacute\":\"Ú\",\"uacute\":\"ú\",\"uarr\":\"↑\",\"Uarr\":\"↟\",\"uArr\":\"⇑\",\"Uarrocir\":\"⥉\",\"Ubrcy\":\"Ў\",\"ubrcy\":\"ў\",\"Ubreve\":\"Ŭ\",\"ubreve\":\"ŭ\",\"Ucirc\":\"Û\",\"ucirc\":\"û\",\"Ucy\":\"У\",\"ucy\":\"у\",\"udarr\":\"⇅\",\"Udblac\":\"Ű\",\"udblac\":\"ű\",\"udhar\":\"⥮\",\"ufisht\":\"⥾\",\"Ufr\":\"𝔘\",\"ufr\":\"𝔲\",\"Ugrave\":\"Ù\",\"ugrave\":\"ù\",\"uHar\":\"⥣\",\"uharl\":\"↿\",\"uharr\":\"↾\",\"uhblk\":\"▀\",\"ulcorn\":\"⌜\",\"ulcorner\":\"⌜\",\"ulcrop\":\"⌏\",\"ultri\":\"◸\",\"Umacr\":\"Ū\",\"umacr\":\"ū\",\"uml\":\"¨\",\"UnderBar\":\"_\",\"UnderBrace\":\"⏟\",\"UnderBracket\":\"⎵\",\"UnderParenthesis\":\"⏝\",\"Union\":\"⋃\",\"UnionPlus\":\"⊎\",\"Uogon\":\"Ų\",\"uogon\":\"ų\",\"Uopf\":\"𝕌\",\"uopf\":\"𝕦\",\"UpArrowBar\":\"⤒\",\"uparrow\":\"↑\",\"UpArrow\":\"↑\",\"Uparrow\":\"⇑\",\"UpArrowDownArrow\":\"⇅\",\"updownarrow\":\"↕\",\"UpDownArrow\":\"↕\",\"Updownarrow\":\"⇕\",\"UpEquilibrium\":\"⥮\",\"upharpoonleft\":\"↿\",\"upharpoonright\":\"↾\",\"uplus\":\"⊎\",\"UpperLeftArrow\":\"↖\",\"UpperRightArrow\":\"↗\",\"upsi\":\"υ\",\"Upsi\":\"ϒ\",\"upsih\":\"ϒ\",\"Upsilon\":\"Υ\",\"upsilon\":\"υ\",\"UpTeeArrow\":\"↥\",\"UpTee\":\"⊥\",\"upuparrows\":\"⇈\",\"urcorn\":\"⌝\",\"urcorner\":\"⌝\",\"urcrop\":\"⌎\",\"Uring\":\"Ů\",\"uring\":\"ů\",\"urtri\":\"◹\",\"Uscr\":\"𝒰\",\"uscr\":\"𝓊\",\"utdot\":\"⋰\",\"Utilde\":\"Ũ\",\"utilde\":\"ũ\",\"utri\":\"▵\",\"utrif\":\"▴\",\"uuarr\":\"⇈\",\"Uuml\":\"Ü\",\"uuml\":\"ü\",\"uwangle\":\"⦧\",\"vangrt\":\"⦜\",\"varepsilon\":\"ϵ\",\"varkappa\":\"ϰ\",\"varnothing\":\"∅\",\"varphi\":\"ϕ\",\"varpi\":\"ϖ\",\"varpropto\":\"∝\",\"varr\":\"↕\",\"vArr\":\"⇕\",\"varrho\":\"ϱ\",\"varsigma\":\"ς\",\"varsubsetneq\":\"⊊︀\",\"varsubsetneqq\":\"⫋︀\",\"varsupsetneq\":\"⊋︀\",\"varsupsetneqq\":\"⫌︀\",\"vartheta\":\"ϑ\",\"vartriangleleft\":\"⊲\",\"vartriangleright\":\"⊳\",\"vBar\":\"⫨\",\"Vbar\":\"⫫\",\"vBarv\":\"⫩\",\"Vcy\":\"В\",\"vcy\":\"в\",\"vdash\":\"⊢\",\"vDash\":\"⊨\",\"Vdash\":\"⊩\",\"VDash\":\"⊫\",\"Vdashl\":\"⫦\",\"veebar\":\"⊻\",\"vee\":\"∨\",\"Vee\":\"⋁\",\"veeeq\":\"≚\",\"vellip\":\"⋮\",\"verbar\":\"|\",\"Verbar\":\"‖\",\"vert\":\"|\",\"Vert\":\"‖\",\"VerticalBar\":\"∣\",\"VerticalLine\":\"|\",\"VerticalSeparator\":\"❘\",\"VerticalTilde\":\"≀\",\"VeryThinSpace\":\" \",\"Vfr\":\"𝔙\",\"vfr\":\"𝔳\",\"vltri\":\"⊲\",\"vnsub\":\"⊂⃒\",\"vnsup\":\"⊃⃒\",\"Vopf\":\"𝕍\",\"vopf\":\"𝕧\",\"vprop\":\"∝\",\"vrtri\":\"⊳\",\"Vscr\":\"𝒱\",\"vscr\":\"𝓋\",\"vsubnE\":\"⫋︀\",\"vsubne\":\"⊊︀\",\"vsupnE\":\"⫌︀\",\"vsupne\":\"⊋︀\",\"Vvdash\":\"⊪\",\"vzigzag\":\"⦚\",\"Wcirc\":\"Ŵ\",\"wcirc\":\"ŵ\",\"wedbar\":\"⩟\",\"wedge\":\"∧\",\"Wedge\":\"⋀\",\"wedgeq\":\"≙\",\"weierp\":\"℘\",\"Wfr\":\"𝔚\",\"wfr\":\"𝔴\",\"Wopf\":\"𝕎\",\"wopf\":\"𝕨\",\"wp\":\"℘\",\"wr\":\"≀\",\"wreath\":\"≀\",\"Wscr\":\"𝒲\",\"wscr\":\"𝓌\",\"xcap\":\"⋂\",\"xcirc\":\"◯\",\"xcup\":\"⋃\",\"xdtri\":\"▽\",\"Xfr\":\"𝔛\",\"xfr\":\"𝔵\",\"xharr\":\"⟷\",\"xhArr\":\"⟺\",\"Xi\":\"Ξ\",\"xi\":\"ξ\",\"xlarr\":\"⟵\",\"xlArr\":\"⟸\",\"xmap\":\"⟼\",\"xnis\":\"⋻\",\"xodot\":\"⨀\",\"Xopf\":\"𝕏\",\"xopf\":\"𝕩\",\"xoplus\":\"⨁\",\"xotime\":\"⨂\",\"xrarr\":\"⟶\",\"xrArr\":\"⟹\",\"Xscr\":\"𝒳\",\"xscr\":\"𝓍\",\"xsqcup\":\"⨆\",\"xuplus\":\"⨄\",\"xutri\":\"△\",\"xvee\":\"⋁\",\"xwedge\":\"⋀\",\"Yacute\":\"Ý\",\"yacute\":\"ý\",\"YAcy\":\"Я\",\"yacy\":\"я\",\"Ycirc\":\"Ŷ\",\"ycirc\":\"ŷ\",\"Ycy\":\"Ы\",\"ycy\":\"ы\",\"yen\":\"¥\",\"Yfr\":\"𝔜\",\"yfr\":\"𝔶\",\"YIcy\":\"Ї\",\"yicy\":\"ї\",\"Yopf\":\"𝕐\",\"yopf\":\"𝕪\",\"Yscr\":\"𝒴\",\"yscr\":\"𝓎\",\"YUcy\":\"Ю\",\"yucy\":\"ю\",\"yuml\":\"ÿ\",\"Yuml\":\"Ÿ\",\"Zacute\":\"Ź\",\"zacute\":\"ź\",\"Zcaron\":\"Ž\",\"zcaron\":\"ž\",\"Zcy\":\"З\",\"zcy\":\"з\",\"Zdot\":\"Ż\",\"zdot\":\"ż\",\"zeetrf\":\"ℨ\",\"ZeroWidthSpace\":\"​\",\"Zeta\":\"Ζ\",\"zeta\":\"ζ\",\"zfr\":\"𝔷\",\"Zfr\":\"ℨ\",\"ZHcy\":\"Ж\",\"zhcy\":\"ж\",\"zigrarr\":\"⇝\",\"zopf\":\"𝕫\",\"Zopf\":\"ℤ\",\"Zscr\":\"𝒵\",\"zscr\":\"𝓏\",\"zwj\":\"‍\",\"zwnj\":\"‌\"}\n","{\"Aacute\":\"Á\",\"aacute\":\"á\",\"Acirc\":\"Â\",\"acirc\":\"â\",\"acute\":\"´\",\"AElig\":\"Æ\",\"aelig\":\"æ\",\"Agrave\":\"À\",\"agrave\":\"à\",\"amp\":\"&\",\"AMP\":\"&\",\"Aring\":\"Å\",\"aring\":\"å\",\"Atilde\":\"Ã\",\"atilde\":\"ã\",\"Auml\":\"Ä\",\"auml\":\"ä\",\"brvbar\":\"¦\",\"Ccedil\":\"Ç\",\"ccedil\":\"ç\",\"cedil\":\"¸\",\"cent\":\"¢\",\"copy\":\"©\",\"COPY\":\"©\",\"curren\":\"¤\",\"deg\":\"°\",\"divide\":\"÷\",\"Eacute\":\"É\",\"eacute\":\"é\",\"Ecirc\":\"Ê\",\"ecirc\":\"ê\",\"Egrave\":\"È\",\"egrave\":\"è\",\"ETH\":\"Ð\",\"eth\":\"ð\",\"Euml\":\"Ë\",\"euml\":\"ë\",\"frac12\":\"½\",\"frac14\":\"¼\",\"frac34\":\"¾\",\"gt\":\">\",\"GT\":\">\",\"Iacute\":\"Í\",\"iacute\":\"í\",\"Icirc\":\"Î\",\"icirc\":\"î\",\"iexcl\":\"¡\",\"Igrave\":\"Ì\",\"igrave\":\"ì\",\"iquest\":\"¿\",\"Iuml\":\"Ï\",\"iuml\":\"ï\",\"laquo\":\"«\",\"lt\":\"<\",\"LT\":\"<\",\"macr\":\"¯\",\"micro\":\"µ\",\"middot\":\"·\",\"nbsp\":\" \",\"not\":\"¬\",\"Ntilde\":\"Ñ\",\"ntilde\":\"ñ\",\"Oacute\":\"Ó\",\"oacute\":\"ó\",\"Ocirc\":\"Ô\",\"ocirc\":\"ô\",\"Ograve\":\"Ò\",\"ograve\":\"ò\",\"ordf\":\"ª\",\"ordm\":\"º\",\"Oslash\":\"Ø\",\"oslash\":\"ø\",\"Otilde\":\"Õ\",\"otilde\":\"õ\",\"Ouml\":\"Ö\",\"ouml\":\"ö\",\"para\":\"¶\",\"plusmn\":\"±\",\"pound\":\"£\",\"quot\":\"\\\"\",\"QUOT\":\"\\\"\",\"raquo\":\"»\",\"reg\":\"®\",\"REG\":\"®\",\"sect\":\"§\",\"shy\":\"­\",\"sup1\":\"¹\",\"sup2\":\"²\",\"sup3\":\"³\",\"szlig\":\"ß\",\"THORN\":\"Þ\",\"thorn\":\"þ\",\"times\":\"×\",\"Uacute\":\"Ú\",\"uacute\":\"ú\",\"Ucirc\":\"Û\",\"ucirc\":\"û\",\"Ugrave\":\"Ù\",\"ugrave\":\"ù\",\"uml\":\"¨\",\"Uuml\":\"Ü\",\"uuml\":\"ü\",\"Yacute\":\"Ý\",\"yacute\":\"ý\",\"yen\":\"¥\",\"yuml\":\"ÿ\"}\n","{\"amp\":\"&\",\"apos\":\"'\",\"gt\":\">\",\"lt\":\"<\",\"quot\":\"\\\"\"}\n","\"use strict\";\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar decode_json_1 = __importDefault(require(\"./maps/decode.json\"));\n// Adapted from https://github.com/mathiasbynens/he/blob/master/src/he.js#L94-L119\nvar fromCodePoint = \n// eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\nString.fromCodePoint ||\n 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 };\nfunction decodeCodePoint(codePoint) {\n if ((codePoint >= 0xd800 && codePoint <= 0xdfff) || codePoint > 0x10ffff) {\n return \"\\uFFFD\";\n }\n if (codePoint in decode_json_1.default) {\n codePoint = decode_json_1.default[codePoint];\n }\n return fromCodePoint(codePoint);\n}\nexports.default = decodeCodePoint;\n","{\"0\":65533,\"128\":8364,\"130\":8218,\"131\":402,\"132\":8222,\"133\":8230,\"134\":8224,\"135\":8225,\"136\":710,\"137\":8240,\"138\":352,\"139\":8249,\"140\":338,\"142\":381,\"145\":8216,\"146\":8217,\"147\":8220,\"148\":8221,\"149\":8226,\"150\":8211,\"151\":8212,\"152\":732,\"153\":8482,\"154\":353,\"155\":8250,\"156\":339,\"158\":382,\"159\":376}\n","\"use strict\";\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.escapeUTF8 = exports.escape = exports.encodeNonAsciiHTML = exports.encodeHTML = exports.encodeXML = void 0;\nvar xml_json_1 = __importDefault(require(\"./maps/xml.json\"));\nvar inverseXML = getInverseObj(xml_json_1.default);\nvar xmlReplacer = getInverseReplacer(inverseXML);\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. `ü`) will be used.\n */\nexports.encodeXML = getASCIIEncoder(inverseXML);\nvar entities_json_1 = __importDefault(require(\"./maps/entities.json\"));\nvar inverseHTML = getInverseObj(entities_json_1.default);\nvar htmlReplacer = getInverseReplacer(inverseHTML);\n/**\n * Encodes all entities and non-ASCII characters in the input.\n *\n * This includes characters that are valid ASCII characters in HTML documents.\n * For example `#` will be encoded as `#`. To get a more compact output,\n * consider using the `encodeNonAsciiHTML` function.\n *\n * If a character has no equivalent entity, a\n * numeric hexadecimal reference (eg. `ü`) will be used.\n */\nexports.encodeHTML = getInverse(inverseHTML, htmlReplacer);\n/**\n * Encodes all non-ASCII characters, as well as characters not valid in HTML\n * documents using HTML entities.\n *\n * If a character has no equivalent entity, a\n * numeric hexadecimal reference (eg. `ü`) will be used.\n */\nexports.encodeNonAsciiHTML = getASCIIEncoder(inverseHTML);\nfunction getInverseObj(obj) {\n return Object.keys(obj)\n .sort()\n .reduce(function (inverse, name) {\n inverse[obj[name]] = \"&\" + name + \";\";\n return inverse;\n }, {});\n}\nfunction getInverseReplacer(inverse) {\n var single = [];\n var multiple = [];\n for (var _i = 0, _a = Object.keys(inverse); _i < _a.length; _i++) {\n var k = _a[_i];\n if (k.length === 1) {\n // Add value to single array\n single.push(\"\\\\\" + k);\n }\n else {\n // Add value to multiple array\n multiple.push(k);\n }\n }\n // Add ranges to single characters.\n single.sort();\n for (var start = 0; start < single.length - 1; start++) {\n // Find the end of a run of characters\n var end = start;\n while (end < single.length - 1 &&\n single[end].charCodeAt(1) + 1 === single[end + 1].charCodeAt(1)) {\n end += 1;\n }\n var count = 1 + end - start;\n // We want to replace at least three characters\n if (count < 3)\n continue;\n single.splice(start, count, single[start] + \"-\" + single[end]);\n }\n multiple.unshift(\"[\" + single.join(\"\") + \"]\");\n return new RegExp(multiple.join(\"|\"), \"g\");\n}\n// /[^\\0-\\x7F]/gu\nvar reNonASCII = /(?:[\\x80-\\uD7FF\\uE000-\\uFFFF]|[\\uD800-\\uDBFF][\\uDC00-\\uDFFF]|[\\uD800-\\uDBFF](?![\\uDC00-\\uDFFF])|(?:[^\\uD800-\\uDBFF]|^)[\\uDC00-\\uDFFF])/g;\nvar getCodePoint = \n// eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\nString.prototype.codePointAt != null\n ? // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n function (str) { return str.codePointAt(0); }\n : // http://mathiasbynens.be/notes/javascript-encoding#surrogate-formulae\n function (c) {\n return (c.charCodeAt(0) - 0xd800) * 0x400 +\n c.charCodeAt(1) -\n 0xdc00 +\n 0x10000;\n };\nfunction singleCharReplacer(c) {\n return \"&#x\" + (c.length > 1 ? getCodePoint(c) : c.charCodeAt(0))\n .toString(16)\n .toUpperCase() + \";\";\n}\nfunction getInverse(inverse, re) {\n return function (data) {\n return data\n .replace(re, function (name) { return inverse[name]; })\n .replace(reNonASCII, singleCharReplacer);\n };\n}\nvar reEscapeChars = new RegExp(xmlReplacer.source + \"|\" + reNonASCII.source, \"g\");\n/**\n * Encodes all non-ASCII characters, as well as characters not valid in XML\n * documents using numeric hexadecimal reference (eg. `ü`).\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 */\nfunction escape(data) {\n return data.replace(reEscapeChars, singleCharReplacer);\n}\nexports.escape = escape;\n/**\n * Encodes all characters not valid in XML documents using numeric hexadecimal\n * reference (eg. `ü`).\n *\n * Note that the output will be character-set dependent.\n *\n * @param data String to escape.\n */\nfunction escapeUTF8(data) {\n return data.replace(xmlReplacer, singleCharReplacer);\n}\nexports.escapeUTF8 = escapeUTF8;\nfunction getASCIIEncoder(obj) {\n return function (data) {\n return data.replace(reEscapeChars, function (c) { return obj[c] || singleCharReplacer(c); });\n };\n}\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.prevElementSibling = exports.nextElementSibling = exports.getName = exports.hasAttrib = exports.getAttributeValue = exports.getSiblings = exports.getParent = exports.getChildren = void 0;\nvar domhandler_1 = require(\"domhandler\");\nvar emptyArray = [];\n/**\n * Get a node's children.\n *\n * @param elem Node to get the children of.\n * @returns `elem`'s children, or an empty array.\n */\nfunction getChildren(elem) {\n var _a;\n return (_a = elem.children) !== null && _a !== void 0 ? _a : emptyArray;\n}\nexports.getChildren = getChildren;\n/**\n * Get a node's parent.\n *\n * @param elem Node to get the parent of.\n * @returns `elem`'s parent node.\n */\nfunction getParent(elem) {\n return elem.parent || null;\n}\nexports.getParent = getParent;\n/**\n * Gets an elements siblings, including the element itself.\n *\n * Attempts to get the children through the element's parent first.\n * If we don't have a parent (the element is a root node),\n * we walk the element's `prev` & `next` to get all remaining nodes.\n *\n * @param elem Element to get the siblings of.\n * @returns `elem`'s siblings.\n */\nfunction getSiblings(elem) {\n var _a, _b;\n var parent = getParent(elem);\n if (parent != null)\n return getChildren(parent);\n var siblings = [elem];\n var prev = elem.prev, next = elem.next;\n while (prev != null) {\n siblings.unshift(prev);\n (_a = prev, prev = _a.prev);\n }\n while (next != null) {\n siblings.push(next);\n (_b = next, next = _b.next);\n }\n return siblings;\n}\nexports.getSiblings = getSiblings;\n/**\n * Gets an attribute from an element.\n *\n * @param elem Element to check.\n * @param name Attribute name to retrieve.\n * @returns The element's attribute value, or `undefined`.\n */\nfunction getAttributeValue(elem, name) {\n var _a;\n return (_a = elem.attribs) === null || _a === void 0 ? void 0 : _a[name];\n}\nexports.getAttributeValue = getAttributeValue;\n/**\n * Checks whether an element has an attribute.\n *\n * @param elem Element to check.\n * @param name Attribute name to look for.\n * @returns Returns whether `elem` has the attribute `name`.\n */\nfunction hasAttrib(elem, name) {\n return (elem.attribs != null &&\n Object.prototype.hasOwnProperty.call(elem.attribs, name) &&\n elem.attribs[name] != null);\n}\nexports.hasAttrib = hasAttrib;\n/**\n * Get the tag name of an element.\n *\n * @param elem The element to get the name for.\n * @returns The tag name of `elem`.\n */\nfunction getName(elem) {\n return elem.name;\n}\nexports.getName = getName;\n/**\n * Returns the next element sibling of a node.\n *\n * @param elem The element to get the next sibling of.\n * @returns `elem`'s next sibling that is a tag.\n */\nfunction nextElementSibling(elem) {\n var _a;\n var next = elem.next;\n while (next !== null && !(0, domhandler_1.isTag)(next))\n (_a = next, next = _a.next);\n return next;\n}\nexports.nextElementSibling = nextElementSibling;\n/**\n * Returns the previous element sibling of a node.\n *\n * @param elem The element to get the previous sibling of.\n * @returns `elem`'s previous sibling that is a tag.\n */\nfunction prevElementSibling(elem) {\n var _a;\n var prev = elem.prev;\n while (prev !== null && !(0, domhandler_1.isTag)(prev))\n (_a = prev, prev = _a.prev);\n return prev;\n}\nexports.prevElementSibling = prevElementSibling;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.prepend = exports.prependChild = exports.append = exports.appendChild = exports.replaceElement = exports.removeElement = void 0;\n/**\n * Remove an element from the dom\n *\n * @param elem The element to be removed\n */\nfunction removeElement(elem) {\n if (elem.prev)\n elem.prev.next = elem.next;\n if (elem.next)\n elem.next.prev = elem.prev;\n if (elem.parent) {\n var childs = elem.parent.children;\n childs.splice(childs.lastIndexOf(elem), 1);\n }\n}\nexports.removeElement = removeElement;\n/**\n * Replace an element in the dom\n *\n * @param elem The element to be replaced\n * @param replacement The element to be added\n */\nfunction replaceElement(elem, replacement) {\n var prev = (replacement.prev = elem.prev);\n if (prev) {\n prev.next = replacement;\n }\n var next = (replacement.next = elem.next);\n if (next) {\n next.prev = replacement;\n }\n var parent = (replacement.parent = elem.parent);\n if (parent) {\n var childs = parent.children;\n childs[childs.lastIndexOf(elem)] = replacement;\n }\n}\nexports.replaceElement = replaceElement;\n/**\n * Append a child to an element.\n *\n * @param elem The element to append to.\n * @param child The element to be added as a child.\n */\nfunction appendChild(elem, child) {\n removeElement(child);\n child.next = null;\n child.parent = elem;\n if (elem.children.push(child) > 1) {\n var sibling = elem.children[elem.children.length - 2];\n sibling.next = child;\n child.prev = sibling;\n }\n else {\n child.prev = null;\n }\n}\nexports.appendChild = appendChild;\n/**\n * Append an element after another.\n *\n * @param elem The element to append after.\n * @param next The element be added.\n */\nfunction append(elem, next) {\n removeElement(next);\n var parent = elem.parent;\n var currNext = elem.next;\n next.next = currNext;\n next.prev = elem;\n elem.next = next;\n next.parent = parent;\n if (currNext) {\n currNext.prev = next;\n if (parent) {\n var childs = parent.children;\n childs.splice(childs.lastIndexOf(currNext), 0, next);\n }\n }\n else if (parent) {\n parent.children.push(next);\n }\n}\nexports.append = append;\n/**\n * Prepend a child to an element.\n *\n * @param elem The element to prepend before.\n * @param child The element to be added as a child.\n */\nfunction prependChild(elem, child) {\n removeElement(child);\n child.parent = elem;\n child.prev = null;\n if (elem.children.unshift(child) !== 1) {\n var sibling = elem.children[1];\n sibling.prev = child;\n child.next = sibling;\n }\n else {\n child.next = null;\n }\n}\nexports.prependChild = prependChild;\n/**\n * Prepend an element before another.\n *\n * @param elem The element to prepend before.\n * @param prev The element be added.\n */\nfunction prepend(elem, prev) {\n removeElement(prev);\n var parent = elem.parent;\n if (parent) {\n var childs = parent.children;\n childs.splice(childs.indexOf(elem), 0, prev);\n }\n if (elem.prev) {\n elem.prev.next = prev;\n }\n prev.parent = parent;\n prev.prev = elem.prev;\n prev.next = elem;\n elem.prev = prev;\n}\nexports.prepend = prepend;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.findAll = exports.existsOne = exports.findOne = exports.findOneChild = exports.find = exports.filter = void 0;\nvar domhandler_1 = require(\"domhandler\");\n/**\n * Search a node and its children for nodes passing a test function.\n *\n * @param test Function to test nodes on.\n * @param node Node to search. Will be included in the result set if it matches.\n * @param recurse Also consider child nodes.\n * @param limit Maximum number of nodes to return.\n * @returns All nodes passing `test`.\n */\nfunction filter(test, node, recurse, limit) {\n if (recurse === void 0) { recurse = true; }\n if (limit === void 0) { limit = Infinity; }\n if (!Array.isArray(node))\n node = [node];\n return find(test, node, recurse, limit);\n}\nexports.filter = filter;\n/**\n * Search an array of node and its children for nodes passing a test function.\n *\n * @param test Function to test nodes on.\n * @param nodes Array of nodes to search.\n * @param recurse Also consider child nodes.\n * @param limit Maximum number of nodes to return.\n * @returns All nodes passing `test`.\n */\nfunction find(test, nodes, recurse, limit) {\n var result = [];\n for (var _i = 0, nodes_1 = nodes; _i < nodes_1.length; _i++) {\n var elem = nodes_1[_i];\n if (test(elem)) {\n result.push(elem);\n if (--limit <= 0)\n break;\n }\n if (recurse && (0, domhandler_1.hasChildren)(elem) && elem.children.length > 0) {\n var children = find(test, elem.children, recurse, limit);\n result.push.apply(result, children);\n limit -= children.length;\n if (limit <= 0)\n break;\n }\n }\n return result;\n}\nexports.find = find;\n/**\n * Finds the first element inside of an array that matches a test function.\n *\n * @param test Function to test nodes on.\n * @param nodes Array of nodes to search.\n * @returns The first node in the array that passes `test`.\n */\nfunction findOneChild(test, nodes) {\n return nodes.find(test);\n}\nexports.findOneChild = findOneChild;\n/**\n * Finds one element in a tree that passes a test.\n *\n * @param test Function to test nodes on.\n * @param nodes Array of nodes to search.\n * @param recurse Also consider child nodes.\n * @returns The first child node that passes `test`.\n */\nfunction findOne(test, nodes, recurse) {\n if (recurse === void 0) { recurse = true; }\n var elem = null;\n for (var i = 0; i < nodes.length && !elem; i++) {\n var checked = nodes[i];\n if (!(0, domhandler_1.isTag)(checked)) {\n continue;\n }\n else if (test(checked)) {\n elem = checked;\n }\n else if (recurse && checked.children.length > 0) {\n elem = findOne(test, checked.children);\n }\n }\n return elem;\n}\nexports.findOne = findOne;\n/**\n * @param test Function to test nodes on.\n * @param nodes Array of nodes to search.\n * @returns Whether a tree of nodes contains at least one node passing a test.\n */\nfunction existsOne(test, nodes) {\n return nodes.some(function (checked) {\n return (0, domhandler_1.isTag)(checked) &&\n (test(checked) ||\n (checked.children.length > 0 &&\n existsOne(test, checked.children)));\n });\n}\nexports.existsOne = existsOne;\n/**\n * Search and array of nodes and its children for nodes passing a test function.\n *\n * Same as `find`, only with less options, leading to reduced complexity.\n *\n * @param test Function to test nodes on.\n * @param nodes Array of nodes to search.\n * @returns All nodes passing `test`.\n */\nfunction findAll(test, nodes) {\n var _a;\n var result = [];\n var stack = nodes.filter(domhandler_1.isTag);\n var elem;\n while ((elem = stack.shift())) {\n var children = (_a = elem.children) === null || _a === void 0 ? void 0 : _a.filter(domhandler_1.isTag);\n if (children && children.length > 0) {\n stack.unshift.apply(stack, children);\n }\n if (test(elem))\n result.push(elem);\n }\n return result;\n}\nexports.findAll = findAll;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getElementsByTagType = exports.getElementsByTagName = exports.getElementById = exports.getElements = exports.testElement = void 0;\nvar domhandler_1 = require(\"domhandler\");\nvar querying_1 = require(\"./querying\");\nvar Checks = {\n tag_name: function (name) {\n if (typeof name === \"function\") {\n return function (elem) { return (0, domhandler_1.isTag)(elem) && name(elem.name); };\n }\n else if (name === \"*\") {\n return domhandler_1.isTag;\n }\n return function (elem) { return (0, domhandler_1.isTag)(elem) && elem.name === name; };\n },\n tag_type: function (type) {\n if (typeof type === \"function\") {\n return function (elem) { return type(elem.type); };\n }\n return function (elem) { return elem.type === type; };\n },\n tag_contains: function (data) {\n if (typeof data === \"function\") {\n return function (elem) { return (0, domhandler_1.isText)(elem) && data(elem.data); };\n }\n return function (elem) { return (0, domhandler_1.isText)(elem) && elem.data === data; };\n },\n};\n/**\n * @param attrib Attribute to check.\n * @param value Attribute value to look for.\n * @returns A function to check whether the a node has an attribute with a particular value.\n */\nfunction getAttribCheck(attrib, value) {\n if (typeof value === \"function\") {\n return function (elem) { return (0, domhandler_1.isTag)(elem) && value(elem.attribs[attrib]); };\n }\n return function (elem) { return (0, domhandler_1.isTag)(elem) && elem.attribs[attrib] === value; };\n}\n/**\n * @param a First function to combine.\n * @param b Second function to combine.\n * @returns A function taking a node and returning `true` if either\n * of the input functions returns `true` for the node.\n */\nfunction combineFuncs(a, b) {\n return function (elem) { return a(elem) || b(elem); };\n}\n/**\n * @param options An object describing nodes to look for.\n * @returns A function executing all checks in `options` and returning `true`\n * if any of them match a node.\n */\nfunction compileTest(options) {\n var funcs = Object.keys(options).map(function (key) {\n var value = options[key];\n return Object.prototype.hasOwnProperty.call(Checks, key)\n ? Checks[key](value)\n : getAttribCheck(key, value);\n });\n return funcs.length === 0 ? null : funcs.reduce(combineFuncs);\n}\n/**\n * @param options An object describing nodes to look for.\n * @param node The element to test.\n * @returns Whether the element matches the description in `options`.\n */\nfunction testElement(options, node) {\n var test = compileTest(options);\n return test ? test(node) : true;\n}\nexports.testElement = testElement;\n/**\n * @param options An object describing nodes to look for.\n * @param nodes Nodes to search through.\n * @param recurse Also consider child nodes.\n * @param limit Maximum number of nodes to return.\n * @returns All nodes that match `options`.\n */\nfunction getElements(options, nodes, recurse, limit) {\n if (limit === void 0) { limit = Infinity; }\n var test = compileTest(options);\n return test ? (0, querying_1.filter)(test, nodes, recurse, limit) : [];\n}\nexports.getElements = getElements;\n/**\n * @param id The unique ID attribute value to look for.\n * @param nodes Nodes to search through.\n * @param recurse Also consider child nodes.\n * @returns The node with the supplied ID.\n */\nfunction getElementById(id, nodes, recurse) {\n if (recurse === void 0) { recurse = true; }\n if (!Array.isArray(nodes))\n nodes = [nodes];\n return (0, querying_1.findOne)(getAttribCheck(\"id\", id), nodes, recurse);\n}\nexports.getElementById = getElementById;\n/**\n * @param tagName Tag name to search for.\n * @param nodes Nodes to search through.\n * @param recurse Also consider child nodes.\n * @param limit Maximum number of nodes to return.\n * @returns All nodes with the supplied `tagName`.\n */\nfunction getElementsByTagName(tagName, nodes, recurse, limit) {\n if (recurse === void 0) { recurse = true; }\n if (limit === void 0) { limit = Infinity; }\n return (0, querying_1.filter)(Checks.tag_name(tagName), nodes, recurse, limit);\n}\nexports.getElementsByTagName = getElementsByTagName;\n/**\n * @param type Element type to look for.\n * @param nodes Nodes to search through.\n * @param recurse Also consider child nodes.\n * @param limit Maximum number of nodes to return.\n * @returns All nodes with the supplied `type`.\n */\nfunction getElementsByTagType(type, nodes, recurse, limit) {\n if (recurse === void 0) { recurse = true; }\n if (limit === void 0) { limit = Infinity; }\n return (0, querying_1.filter)(Checks.tag_type(type), nodes, recurse, limit);\n}\nexports.getElementsByTagType = getElementsByTagType;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.uniqueSort = exports.compareDocumentPosition = exports.removeSubsets = void 0;\nvar domhandler_1 = require(\"domhandler\");\n/**\n * Given an array of nodes, remove any member that is contained by another.\n *\n * @param nodes Nodes to filter.\n * @returns Remaining nodes that aren't subtrees of each other.\n */\nfunction removeSubsets(nodes) {\n var idx = nodes.length;\n /*\n * Check if each node (or one of its ancestors) is already contained in the\n * array.\n */\n while (--idx >= 0) {\n var node = nodes[idx];\n /*\n * Remove the node if it is not unique.\n * We are going through the array from the end, so we only\n * have to check nodes that preceed the node under consideration in the array.\n */\n if (idx > 0 && nodes.lastIndexOf(node, idx - 1) >= 0) {\n nodes.splice(idx, 1);\n continue;\n }\n for (var ancestor = node.parent; ancestor; ancestor = ancestor.parent) {\n if (nodes.includes(ancestor)) {\n nodes.splice(idx, 1);\n break;\n }\n }\n }\n return nodes;\n}\nexports.removeSubsets = removeSubsets;\n/**\n * Compare the position of one node against another node in any other document.\n * The return value is a bitmask with the following values:\n *\n * Document order:\n * > There is an ordering, document order, defined on all the nodes in the\n * > document corresponding to the order in which the first character of the\n * > XML representation of each node occurs in the XML representation of the\n * > document after expansion of general entities. Thus, the document element\n * > node will be the first node. Element nodes occur before their children.\n * > Thus, document order orders element nodes in order of the occurrence of\n * > their start-tag in the XML (after expansion of entities). The attribute\n * > nodes of an element occur after the element and before its children. The\n * > relative order of attribute nodes is implementation-dependent./\n *\n * Source:\n * http://www.w3.org/TR/DOM-Level-3-Core/glossary.html#dt-document-order\n *\n * @param nodeA The first node to use in the comparison\n * @param nodeB The second node to use in the comparison\n * @returns A bitmask describing the input nodes' relative position.\n *\n * See http://dom.spec.whatwg.org/#dom-node-comparedocumentposition for\n * a description of these values.\n */\nfunction compareDocumentPosition(nodeA, nodeB) {\n var aParents = [];\n var bParents = [];\n if (nodeA === nodeB) {\n return 0;\n }\n var current = (0, domhandler_1.hasChildren)(nodeA) ? nodeA : nodeA.parent;\n while (current) {\n aParents.unshift(current);\n current = current.parent;\n }\n current = (0, domhandler_1.hasChildren)(nodeB) ? nodeB : nodeB.parent;\n while (current) {\n bParents.unshift(current);\n current = current.parent;\n }\n var maxIdx = Math.min(aParents.length, bParents.length);\n var idx = 0;\n while (idx < maxIdx && aParents[idx] === bParents[idx]) {\n idx++;\n }\n if (idx === 0) {\n return 1 /* DISCONNECTED */;\n }\n var sharedParent = aParents[idx - 1];\n var siblings = sharedParent.children;\n var aSibling = aParents[idx];\n var bSibling = bParents[idx];\n if (siblings.indexOf(aSibling) > siblings.indexOf(bSibling)) {\n if (sharedParent === nodeB) {\n return 4 /* FOLLOWING */ | 16 /* CONTAINED_BY */;\n }\n return 4 /* FOLLOWING */;\n }\n if (sharedParent === nodeA) {\n return 2 /* PRECEDING */ | 8 /* CONTAINS */;\n }\n return 2 /* PRECEDING */;\n}\nexports.compareDocumentPosition = compareDocumentPosition;\n/**\n * Sort an array of nodes based on their relative position in the document and\n * remove any duplicate nodes. If the array contains nodes that do not belong\n * to the same document, sort order is unspecified.\n *\n * @param nodes Array of DOM nodes.\n * @returns Collection of unique nodes, sorted in document order.\n */\nfunction uniqueSort(nodes) {\n nodes = nodes.filter(function (node, i, arr) { return !arr.includes(node, i + 1); });\n nodes.sort(function (a, b) {\n var relative = compareDocumentPosition(a, b);\n if (relative & 2 /* PRECEDING */) {\n return -1;\n }\n else if (relative & 4 /* FOLLOWING */) {\n return 1;\n }\n return 0;\n });\n return nodes;\n}\nexports.uniqueSort = uniqueSort;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getFeed = void 0;\nvar stringify_1 = require(\"./stringify\");\nvar legacy_1 = require(\"./legacy\");\n/**\n * Get the feed object from the root of a DOM tree.\n *\n * @param doc - The DOM to to extract the feed from.\n * @returns The feed.\n */\nfunction getFeed(doc) {\n var feedRoot = getOneElement(isValidFeed, doc);\n return !feedRoot\n ? null\n : feedRoot.name === \"feed\"\n ? getAtomFeed(feedRoot)\n : getRssFeed(feedRoot);\n}\nexports.getFeed = getFeed;\n/**\n * Parse an Atom feed.\n *\n * @param feedRoot The root of the feed.\n * @returns The parsed feed.\n */\nfunction getAtomFeed(feedRoot) {\n var _a;\n var childs = feedRoot.children;\n var feed = {\n type: \"atom\",\n items: (0, legacy_1.getElementsByTagName)(\"entry\", childs).map(function (item) {\n var _a;\n var children = item.children;\n var entry = { media: getMediaElements(children) };\n addConditionally(entry, \"id\", \"id\", children);\n addConditionally(entry, \"title\", \"title\", children);\n var href = (_a = getOneElement(\"link\", children)) === null || _a === void 0 ? void 0 : _a.attribs.href;\n if (href) {\n entry.link = href;\n }\n var description = fetch(\"summary\", children) || fetch(\"content\", children);\n if (description) {\n entry.description = description;\n }\n var pubDate = fetch(\"updated\", children);\n if (pubDate) {\n entry.pubDate = new Date(pubDate);\n }\n return entry;\n }),\n };\n addConditionally(feed, \"id\", \"id\", childs);\n addConditionally(feed, \"title\", \"title\", childs);\n var href = (_a = getOneElement(\"link\", childs)) === null || _a === void 0 ? void 0 : _a.attribs.href;\n if (href) {\n feed.link = href;\n }\n addConditionally(feed, \"description\", \"subtitle\", childs);\n var updated = fetch(\"updated\", childs);\n if (updated) {\n feed.updated = new Date(updated);\n }\n addConditionally(feed, \"author\", \"email\", childs, true);\n return feed;\n}\n/**\n * Parse a RSS feed.\n *\n * @param feedRoot The root of the feed.\n * @returns The parsed feed.\n */\nfunction getRssFeed(feedRoot) {\n var _a, _b;\n var childs = (_b = (_a = getOneElement(\"channel\", feedRoot.children)) === null || _a === void 0 ? void 0 : _a.children) !== null && _b !== void 0 ? _b : [];\n var feed = {\n type: feedRoot.name.substr(0, 3),\n id: \"\",\n items: (0, legacy_1.getElementsByTagName)(\"item\", feedRoot.children).map(function (item) {\n var children = item.children;\n var entry = { media: getMediaElements(children) };\n addConditionally(entry, \"id\", \"guid\", children);\n addConditionally(entry, \"title\", \"title\", children);\n addConditionally(entry, \"link\", \"link\", children);\n addConditionally(entry, \"description\", \"description\", children);\n var pubDate = fetch(\"pubDate\", children);\n if (pubDate)\n entry.pubDate = new Date(pubDate);\n return entry;\n }),\n };\n addConditionally(feed, \"title\", \"title\", childs);\n addConditionally(feed, \"link\", \"link\", childs);\n addConditionally(feed, \"description\", \"description\", childs);\n var updated = fetch(\"lastBuildDate\", childs);\n if (updated) {\n feed.updated = new Date(updated);\n }\n addConditionally(feed, \"author\", \"managingEditor\", childs, true);\n return feed;\n}\nvar MEDIA_KEYS_STRING = [\"url\", \"type\", \"lang\"];\nvar MEDIA_KEYS_INT = [\n \"fileSize\",\n \"bitrate\",\n \"framerate\",\n \"samplingrate\",\n \"channels\",\n \"duration\",\n \"height\",\n \"width\",\n];\n/**\n * Get all media elements of a feed item.\n *\n * @param where Nodes to search in.\n * @returns Media elements.\n */\nfunction getMediaElements(where) {\n return (0, legacy_1.getElementsByTagName)(\"media:content\", where).map(function (elem) {\n var attribs = elem.attribs;\n var media = {\n medium: attribs.medium,\n isDefault: !!attribs.isDefault,\n };\n for (var _i = 0, MEDIA_KEYS_STRING_1 = MEDIA_KEYS_STRING; _i < MEDIA_KEYS_STRING_1.length; _i++) {\n var attrib = MEDIA_KEYS_STRING_1[_i];\n if (attribs[attrib]) {\n media[attrib] = attribs[attrib];\n }\n }\n for (var _a = 0, MEDIA_KEYS_INT_1 = MEDIA_KEYS_INT; _a < MEDIA_KEYS_INT_1.length; _a++) {\n var attrib = MEDIA_KEYS_INT_1[_a];\n if (attribs[attrib]) {\n media[attrib] = parseInt(attribs[attrib], 10);\n }\n }\n if (attribs.expression) {\n media.expression =\n attribs.expression;\n }\n return media;\n });\n}\n/**\n * Get one element by tag name.\n *\n * @param tagName Tag name to look for\n * @param node Node to search in\n * @returns The element or null\n */\nfunction getOneElement(tagName, node) {\n return (0, legacy_1.getElementsByTagName)(tagName, node, true, 1)[0];\n}\n/**\n * Get the text content of an element with a certain tag name.\n *\n * @param tagName Tag name to look for.\n * @param where Node to search in.\n * @param recurse Whether to recurse into child nodes.\n * @returns The text content of the element.\n */\nfunction fetch(tagName, where, recurse) {\n if (recurse === void 0) { recurse = false; }\n return (0, stringify_1.textContent)((0, legacy_1.getElementsByTagName)(tagName, where, recurse, 1)).trim();\n}\n/**\n * Adds a property to an object if it has a value.\n *\n * @param obj Object to be extended\n * @param prop Property name\n * @param tagName Tag name that contains the conditionally added property\n * @param where Element to search for the property\n * @param recurse Whether to recurse into child nodes.\n */\nfunction addConditionally(obj, prop, tagName, where, recurse) {\n if (recurse === void 0) { recurse = false; }\n var val = fetch(tagName, where, recurse);\n if (val)\n obj[prop] = val;\n}\n/**\n * Checks if an element is a feed root node.\n *\n * @param value The name of the element to check.\n * @returns Whether an element is a feed root node.\n */\nfunction isValidFeed(value) {\n return value === \"rss\" || value === \"feed\" || value === \"rdf:RDF\";\n}\n","import internalHTMLElementModels, {\n DefaultHTMLElementModelsStatic\n} from './defaultHTMLElementModels';\nimport HTMLElementModel from './HTMLElementModel';\nimport { HTMLModelRecord, TagName } from './model-types';\n\nexport default class HTMLModelRegistry {\n public readonly modelRecords: HTMLModelRecord =\n internalHTMLElementModels as HTMLModelRecord;\n\n constructor(\n customize?: (\n defaultHTMLElementModels: DefaultHTMLElementModelsStatic\n ) => HTMLModelRecord\n ) {\n if (typeof customize === 'function') {\n this.modelRecords = customize(internalHTMLElementModels);\n }\n }\n\n getElementModelFromTagName(\n tagName: E | TagName\n ): HTMLElementModel | null {\n if (tagName in this.modelRecords) {\n return this.modelRecords[tagName];\n }\n return null;\n }\n}\n","import { MixedStyleDeclaration } from '@native-html/css-processor';\nimport { textContent } from 'domutils';\nimport HTMLContentModel from './HTMLContentModel';\nimport HTMLElementModel from './HTMLElementModel';\nimport {\n AttribTagNames,\n EditsTagNames,\n EmbeddedTagNames,\n GroupingTagNames,\n InteractiveTagNames,\n MetadataTagNames,\n SectioningTagNames,\n TabularTagNames,\n TextLevelTagNames,\n UnsupportedTagNames,\n UntranslatableTagNames,\n HTMLModelRecord,\n ElementModelBase\n} from './model-types';\n\nconst UA_ANCHOR_COL = '#245dc1';\nconst UA_GRAY = '#CCC';\nconst UA_MARGIN_HZ = 30;\n\nconst bigMarginTopBottomStyle: MixedStyleDeclaration = {\n marginTop: '1em',\n marginBottom: '1em'\n};\n\nconst shortMarginTopBottomStyle: MixedStyleDeclaration = {\n marginTop: '.5em',\n marginBottom: '.5em'\n};\n\nconst lineThroughStyle: MixedStyleDeclaration = {\n textDecorationLine: 'line-through'\n};\n\nconst italicStyle: MixedStyleDeclaration = {\n fontStyle: 'italic'\n};\n\nconst monoStyle: MixedStyleDeclaration = {\n fontFamily: 'monospace'\n};\n\nconst boldStyle: MixedStyleDeclaration = {\n fontWeight: 'bold'\n};\n\nconst spacedBlockStyle: MixedStyleDeclaration = {\n ...bigMarginTopBottomStyle,\n marginLeft: UA_MARGIN_HZ,\n marginRight: UA_MARGIN_HZ\n};\n\nconst anchorStyle: MixedStyleDeclaration = {\n color: UA_ANCHOR_COL,\n textDecorationLine: 'underline',\n textDecorationColor: UA_ANCHOR_COL\n};\n\nconst leftBorderQuoteStyle: MixedStyleDeclaration = {\n borderLeftWidth: 2,\n borderLeftColor: UA_GRAY\n};\n\nconst dottedUnderlineStyle: MixedStyleDeclaration = {\n textDecorationLine: 'underline',\n textDecorationStyle: 'dotted'\n};\n\nconst solidUnderlineStyle: MixedStyleDeclaration = {\n textDecorationLine: 'underline',\n textDecorationStyle: 'solid'\n};\n\n// TODO, support directional styles\nconst listStyles: MixedStyleDeclaration = {\n ...bigMarginTopBottomStyle,\n paddingLeft: 30\n};\n\nconst preStyles: MixedStyleDeclaration = {\n whiteSpace: 'pre',\n ...monoStyle,\n ...bigMarginTopBottomStyle\n};\n\nfunction headerStyle(\n fontSize: string,\n marginSize: string\n): MixedStyleDeclaration {\n return {\n fontSize,\n marginTop: marginSize,\n marginBottom: marginSize,\n ...boldStyle\n };\n}\n\nconst getReactNativePropsForHeading: ElementModelBase['getReactNativeProps'] =\n ({ domNode }) => {\n const textLabel = textContent(domNode!);\n return {\n native: {\n accessible: true,\n accessibilityLabel: textLabel,\n accessibilityRole: 'header'\n }\n };\n };\n\nconst getReactNativePropsWithHref: ElementModelBase['getReactNativeProps'] =\n function getReactNativePropsWithHref({ attributes }) {\n if (typeof attributes.href === 'string' && attributes.href.length > 0) {\n return {\n native: {\n accessible: true,\n accessibilityRole: 'link'\n }\n };\n }\n };\n\nconst sectioningModelMap: HTMLModelRecord<\n SectioningTagNames,\n HTMLContentModel.block\n> = {\n address: HTMLElementModel.fromNativeModel({\n category: 'sectioning',\n tagName: 'address',\n mixedUAStyles: italicStyle\n }),\n article: HTMLElementModel.fromNativeModel({\n category: 'sectioning',\n tagName: 'article'\n }),\n aside: HTMLElementModel.fromNativeModel({\n category: 'sectioning',\n tagName: 'aside'\n }),\n body: HTMLElementModel.fromNativeModel({\n category: 'sectioning',\n tagName: 'body'\n }),\n footer: HTMLElementModel.fromNativeModel({\n category: 'sectioning',\n tagName: 'footer'\n }),\n h1: HTMLElementModel.fromNativeModel({\n category: 'sectioning',\n tagName: 'h1',\n mixedUAStyles: headerStyle('2em', '.67em'),\n getReactNativeProps: getReactNativePropsForHeading\n }),\n h2: HTMLElementModel.fromNativeModel({\n category: 'sectioning',\n tagName: 'h2',\n mixedUAStyles: headerStyle('1.5em', '.83em'),\n getReactNativeProps: getReactNativePropsForHeading\n }),\n h3: HTMLElementModel.fromNativeModel({\n category: 'sectioning',\n tagName: 'h3',\n mixedUAStyles: headerStyle('1.17em', '1em'),\n getReactNativeProps: getReactNativePropsForHeading\n }),\n h4: HTMLElementModel.fromNativeModel({\n category: 'sectioning',\n tagName: 'h4',\n mixedUAStyles: headerStyle('1em', '1.33em'),\n getReactNativeProps: getReactNativePropsForHeading\n }),\n h5: HTMLElementModel.fromNativeModel({\n category: 'sectioning',\n tagName: 'h5',\n mixedUAStyles: headerStyle('.83em', '1.67em'),\n getReactNativeProps: getReactNativePropsForHeading\n }),\n h6: HTMLElementModel.fromNativeModel({\n category: 'sectioning',\n tagName: 'h6',\n mixedUAStyles: headerStyle('.67em', '2.33em'),\n getReactNativeProps: getReactNativePropsForHeading\n }),\n header: HTMLElementModel.fromNativeModel({\n category: 'sectioning',\n tagName: 'header'\n }),\n hgroup: HTMLElementModel.fromNativeModel({\n category: 'sectioning',\n tagName: 'hgroup'\n }),\n nav: HTMLElementModel.fromNativeModel({\n category: 'sectioning',\n tagName: 'nav'\n }),\n section: HTMLElementModel.fromNativeModel({\n category: 'sectioning',\n tagName: 'section'\n })\n};\n\nconst unsupportedModelMap: HTMLModelRecord<\n UnsupportedTagNames,\n HTMLContentModel.none\n> = {\n area: HTMLElementModel.fromNativeModel({\n tagName: 'area',\n category: 'untranslatable',\n isVoid: true,\n getReactNativeProps: getReactNativePropsWithHref\n }),\n map: HTMLElementModel.fromNativeModel({\n tagName: 'map',\n category: 'untranslatable'\n })\n};\n\nconst attribsModelMap: HTMLModelRecord =\n {\n accesskey: HTMLElementModel.fromNativeModel({\n tagName: 'accesskey',\n category: 'untranslatable'\n }),\n caption: HTMLElementModel.fromNativeModel({\n tagName: 'caption',\n category: 'untranslatable'\n }),\n col: HTMLElementModel.fromNativeModel({\n tagName: 'col',\n category: 'untranslatable',\n isVoid: true\n }),\n colgroup: HTMLElementModel.fromNativeModel({\n tagName: 'colgroup',\n category: 'untranslatable'\n }),\n datalist: HTMLElementModel.fromNativeModel({\n tagName: 'datalist',\n category: 'untranslatable'\n }),\n source: HTMLElementModel.fromNativeModel({\n tagName: 'source',\n category: 'untranslatable',\n isVoid: true\n }),\n track: HTMLElementModel.fromNativeModel({\n tagName: 'track',\n category: 'untranslatable',\n isVoid: true\n }),\n optgroup: HTMLElementModel.fromNativeModel({\n tagName: 'optgroup',\n category: 'untranslatable'\n }),\n option: HTMLElementModel.fromNativeModel({\n tagName: 'option',\n category: 'untranslatable'\n }),\n param: HTMLElementModel.fromNativeModel({\n tagName: 'param',\n category: 'untranslatable',\n isVoid: true\n })\n };\n\nconst interactiveModelMap: HTMLModelRecord<\n InteractiveTagNames,\n HTMLContentModel.none\n> = {\n button: HTMLElementModel.fromNativeModel({\n tagName: 'button',\n category: 'interactive',\n reactNativeProps: {\n native: {\n accessibilityRole: 'button'\n }\n }\n }),\n fieldset: HTMLElementModel.fromNativeModel({\n tagName: 'fieldset',\n category: 'interactive'\n }),\n form: HTMLElementModel.fromNativeModel({\n tagName: 'form',\n category: 'interactive'\n }),\n input: HTMLElementModel.fromNativeModel({\n tagName: 'input',\n category: 'interactive',\n isVoid: true\n }),\n label: HTMLElementModel.fromNativeModel({\n tagName: 'label',\n category: 'interactive'\n }),\n legend: HTMLElementModel.fromNativeModel({\n tagName: 'legend',\n category: 'interactive'\n }),\n meter: HTMLElementModel.fromNativeModel({\n tagName: 'meter',\n category: 'interactive'\n }),\n progress: HTMLElementModel.fromNativeModel({\n tagName: 'progress',\n category: 'interactive'\n }),\n select: HTMLElementModel.fromNativeModel({\n tagName: 'select',\n category: 'interactive',\n reactNativeProps: {\n native: {\n accessible: true,\n accessibilityRole: 'combobox'\n }\n }\n }),\n details: HTMLElementModel.fromNativeModel({\n tagName: 'details',\n category: 'interactive'\n }),\n dialog: HTMLElementModel.fromNativeModel({\n tagName: 'dialog',\n category: 'interactive'\n }),\n output: HTMLElementModel.fromNativeModel({\n tagName: 'output',\n category: 'interactive'\n }),\n summary: HTMLElementModel.fromNativeModel({\n tagName: 'summary',\n category: 'interactive'\n }),\n textarea: HTMLElementModel.fromNativeModel({\n tagName: 'textarea',\n category: 'interactive'\n })\n};\n\nconst metadataModelMap: HTMLModelRecord<\n MetadataTagNames,\n HTMLContentModel.none\n> = {\n base: HTMLElementModel.fromNativeModel({\n tagName: 'base',\n category: 'untranslatable',\n isVoid: true\n }),\n head: HTMLElementModel.fromNativeModel({\n tagName: 'head',\n category: 'untranslatable',\n isOpaque: true\n }),\n link: HTMLElementModel.fromNativeModel({\n tagName: 'link',\n category: 'untranslatable',\n isVoid: true\n }),\n meta: HTMLElementModel.fromNativeModel({\n tagName: 'meta',\n category: 'untranslatable',\n isVoid: true\n }),\n title: HTMLElementModel.fromNativeModel({\n tagName: 'title',\n category: 'untranslatable'\n })\n};\n\nconst untranslatableModelMap: HTMLModelRecord<\n UntranslatableTagNames,\n HTMLContentModel.none\n> = {\n ...attribsModelMap,\n ...interactiveModelMap,\n ...unsupportedModelMap,\n ...metadataModelMap\n};\n\nconst groupingModelMap: HTMLModelRecord<\n GroupingTagNames,\n HTMLContentModel.block\n> = {\n blockquote: HTMLElementModel.fromNativeModel({\n tagName: 'blockquote',\n category: 'grouping',\n getMixedUAStyles: ({ attributes }) => {\n if (attributes.type === 'cite') {\n return leftBorderQuoteStyle;\n }\n },\n mixedUAStyles: spacedBlockStyle\n }),\n dd: HTMLElementModel.fromNativeModel({\n tagName: 'dd',\n category: 'grouping',\n mixedUAStyles: {\n marginLeft: UA_MARGIN_HZ\n }\n }),\n div: HTMLElementModel.fromNativeModel({\n tagName: 'div',\n category: 'grouping'\n }),\n dl: HTMLElementModel.fromNativeModel({\n tagName: 'dl',\n category: 'grouping',\n mixedUAStyles: bigMarginTopBottomStyle\n }),\n dt: HTMLElementModel.fromNativeModel({\n tagName: 'dt',\n category: 'grouping',\n mixedUAStyles: boldStyle\n }),\n figcaption: HTMLElementModel.fromNativeModel({\n tagName: 'figcaption',\n category: 'grouping',\n mixedUAStyles: {\n ...italicStyle,\n textAlign: 'center'\n }\n }),\n figure: HTMLElementModel.fromNativeModel({\n tagName: 'figure',\n category: 'grouping',\n mixedUAStyles: spacedBlockStyle\n }),\n hr: HTMLElementModel.fromNativeModel({\n tagName: 'hr',\n category: 'grouping',\n mixedUAStyles: {\n marginLeft: 'auto',\n marginRight: 'auto',\n height: 1,\n width: '100%',\n backgroundColor: UA_GRAY,\n ...shortMarginTopBottomStyle\n }\n }),\n li: HTMLElementModel.fromNativeModel({\n tagName: 'li',\n category: 'grouping'\n }),\n main: HTMLElementModel.fromNativeModel({\n tagName: 'main',\n category: 'grouping'\n }),\n menu: HTMLElementModel.fromNativeModel({\n tagName: 'menu',\n category: 'grouping'\n }),\n ol: HTMLElementModel.fromNativeModel({\n tagName: 'ol',\n category: 'grouping',\n mixedUAStyles: listStyles,\n setMarkersForTNode(targetMarkers, parentMarkers) {\n targetMarkers.olNestLevel = parentMarkers.olNestLevel + 1;\n }\n }),\n p: HTMLElementModel.fromNativeModel({\n tagName: 'p',\n category: 'grouping',\n mixedUAStyles: bigMarginTopBottomStyle\n }),\n pre: HTMLElementModel.fromNativeModel({\n tagName: 'pre',\n category: 'grouping',\n mixedUAStyles: preStyles\n }),\n xmp: HTMLElementModel.fromNativeModel({\n tagName: 'xmp',\n category: 'grouping',\n mixedUAStyles: preStyles\n }),\n listing: HTMLElementModel.fromNativeModel({\n tagName: 'listing',\n category: 'grouping',\n mixedUAStyles: preStyles\n }),\n plaintext: HTMLElementModel.fromNativeModel({\n tagName: 'plaintext',\n category: 'grouping',\n mixedUAStyles: preStyles\n }),\n ul: HTMLElementModel.fromNativeModel({\n tagName: 'ul',\n category: 'grouping',\n mixedUAStyles: listStyles,\n setMarkersForTNode(targetMarkers, parentMarkers) {\n targetMarkers.ulNestLevel = parentMarkers.ulNestLevel + 1;\n }\n }),\n dir: HTMLElementModel.fromNativeModel({\n tagName: 'dir',\n category: 'grouping',\n mixedUAStyles: listStyles\n })\n};\n\nconst tabularModelMap: HTMLModelRecord<\n TabularTagNames,\n HTMLContentModel.block\n> = {\n table: HTMLElementModel.fromNativeModel({\n tagName: 'table',\n category: 'tabular'\n }),\n tbody: HTMLElementModel.fromNativeModel({\n tagName: 'tbody',\n category: 'tabular'\n }),\n td: HTMLElementModel.fromNativeModel({\n tagName: 'td',\n category: 'tabular',\n mixedUAStyles: {\n padding: 2,\n flex: 1\n }\n }),\n tfoot: HTMLElementModel.fromNativeModel({\n tagName: 'tfoot',\n category: 'tabular'\n }),\n th: HTMLElementModel.fromNativeModel({\n tagName: 'th',\n category: 'tabular',\n mixedUAStyles: {\n padding: 2,\n flex: 1,\n fontWeight: 'bold'\n }\n }),\n thead: HTMLElementModel.fromNativeModel({\n tagName: 'thead',\n category: 'tabular'\n }),\n tr: HTMLElementModel.fromNativeModel({\n tagName: 'tr',\n category: 'tabular',\n mixedUAStyles: {\n flexDirection: 'row',\n flexWrap: 'nowrap'\n }\n })\n};\n\n// These emnbedded should be rendered by default.\nconst renderedEmbeddedModelMap: HTMLModelRecord<\n Extract,\n HTMLContentModel.block\n> = {\n img: HTMLElementModel.fromNativeModel({\n tagName: 'img',\n category: 'embedded',\n isVoid: true,\n getReactNativeProps({ attributes }, props) {\n // see https://w3c.github.io/html-aria/#el-img\n const label = attributes['aria-label'] || attributes.alt;\n if (label && (!props?.view || props.view.accessibilityRole !== 'none')) {\n return {\n native: {\n accessibilityLabel: label,\n accessibilityRole: 'image'\n }\n };\n }\n return {\n native: {\n accessibilityRole: 'none'\n }\n };\n }\n }).extend({\n contentModel: HTMLContentModel.block\n }),\n picture: HTMLElementModel.fromNativeModel({\n tagName: 'picture',\n category: 'embedded',\n isOpaque: false,\n isVoid: false // allows source and img\n }).extend({\n contentModel: HTMLContentModel.block\n })\n};\n\n// Embedded elements content model is \"none\" by default.\nconst emptyEmbeddedModelMap: HTMLModelRecord<\n Exclude,\n HTMLContentModel.none\n> = {\n audio: HTMLElementModel.fromNativeModel({\n tagName: 'audio',\n category: 'embedded',\n isVoid: false // allows tracks\n }),\n canvas: HTMLElementModel.fromNativeModel({\n tagName: 'canvas',\n category: 'embedded',\n isVoid: false // allows specific content\n }),\n embed: HTMLElementModel.fromNativeModel({\n tagName: 'embed',\n category: 'embedded',\n isVoid: true\n }),\n iframe: HTMLElementModel.fromNativeModel({\n tagName: 'iframe',\n category: 'embedded',\n isVoid: true\n }),\n math: HTMLElementModel.fromNativeModel({\n tagName: 'math',\n category: 'embedded',\n isVoid: false, // allows mathml elems\n isOpaque: true\n }),\n object: HTMLElementModel.fromNativeModel({\n tagName: 'object',\n category: 'embedded',\n isVoid: false // allows params\n }),\n svg: HTMLElementModel.fromNativeModel({\n tagName: 'svg',\n category: 'embedded',\n isVoid: false, // allows svg elems\n isOpaque: true,\n getReactNativeProps({ attributes }) {\n if (attributes['aria-label']) {\n return {\n native: {\n accessibilityLabel: attributes['aria-label'],\n accessibilityRole: 'image'\n }\n };\n }\n return {\n native: {\n accessibilityRole: 'none'\n }\n };\n }\n }),\n video: HTMLElementModel.fromNativeModel({\n tagName: 'video',\n category: 'embedded',\n isVoid: false // allows source, tracks + transparent\n })\n};\n\nconst editsModelMap: HTMLModelRecord = {\n ins: HTMLElementModel.fromNativeModel({\n tagName: 'ins',\n category: 'edits',\n mixedUAStyles: solidUnderlineStyle,\n setMarkersForTNode(targetMarkers) {\n targetMarkers.edits = 'ins';\n }\n }),\n del: HTMLElementModel.fromNativeModel({\n tagName: 'del',\n category: 'edits',\n mixedUAStyles: lineThroughStyle,\n setMarkersForTNode(targetMarkers) {\n targetMarkers.edits = 'del';\n }\n })\n};\n\nconst textLevelModelMap: HTMLModelRecord<\n TextLevelTagNames,\n HTMLContentModel.textual\n> = {\n em: HTMLElementModel.fromNativeModel({\n tagName: 'em',\n category: 'textual',\n mixedUAStyles: italicStyle\n }),\n strong: HTMLElementModel.fromNativeModel({\n tagName: 'strong',\n category: 'textual',\n mixedUAStyles: boldStyle\n }),\n small: HTMLElementModel.fromNativeModel({\n tagName: 'small',\n category: 'textual',\n mixedUAStyles: {\n fontSize: 'smaller'\n }\n }),\n big: HTMLElementModel.fromNativeModel({\n tagName: 'big',\n category: 'textual',\n mixedUAStyles: {\n fontSize: 'larger'\n }\n }),\n s: HTMLElementModel.fromNativeModel({\n tagName: 's',\n category: 'textual',\n mixedUAStyles: lineThroughStyle\n }),\n strike: HTMLElementModel.fromNativeModel({\n tagName: 'strike',\n category: 'textual',\n mixedUAStyles: lineThroughStyle\n }),\n cite: HTMLElementModel.fromNativeModel({\n tagName: 'cite',\n category: 'textual',\n mixedUAStyles: italicStyle\n }),\n q: HTMLElementModel.fromNativeModel({\n tagName: 'q',\n category: 'textual'\n // default style, content: \"open,close-quote\"\n }),\n dfn: HTMLElementModel.fromNativeModel({\n tagName: 'dfn',\n category: 'textual',\n mixedUAStyles: italicStyle\n }),\n abbr: HTMLElementModel.fromNativeModel({\n tagName: 'abbr',\n category: 'textual',\n mixedUAStyles: dottedUnderlineStyle\n }),\n acronym: HTMLElementModel.fromNativeModel({\n tagName: 'acronym',\n category: 'textual',\n mixedUAStyles: dottedUnderlineStyle\n }),\n ruby: HTMLElementModel.fromNativeModel({\n tagName: 'ruby',\n category: 'textual'\n }),\n rt: HTMLElementModel.fromNativeModel({\n tagName: 'rt',\n category: 'textual'\n }),\n rp: HTMLElementModel.fromNativeModel({\n tagName: 'rp',\n category: 'textual'\n }),\n data: HTMLElementModel.fromNativeModel({\n tagName: 'data',\n category: 'textual'\n }),\n time: HTMLElementModel.fromNativeModel({\n tagName: 'time',\n category: 'textual'\n }),\n code: HTMLElementModel.fromNativeModel({\n tagName: 'code',\n category: 'textual',\n mixedUAStyles: monoStyle\n }),\n tt: HTMLElementModel.fromNativeModel({\n tagName: 'tt',\n category: 'textual',\n mixedUAStyles: monoStyle\n }),\n var: HTMLElementModel.fromNativeModel({\n tagName: 'var',\n category: 'textual',\n mixedUAStyles: italicStyle\n }),\n samp: HTMLElementModel.fromNativeModel({\n tagName: 'samp',\n category: 'textual',\n mixedUAStyles: monoStyle\n }),\n kbd: HTMLElementModel.fromNativeModel({\n tagName: 'kbd',\n category: 'textual',\n mixedUAStyles: monoStyle\n }),\n sub: HTMLElementModel.fromNativeModel({\n tagName: 'sub',\n category: 'textual',\n mixedUAStyles: {\n textAlignVertical: 'bottom',\n fontSize: 'smaller'\n }\n }),\n sup: HTMLElementModel.fromNativeModel({\n tagName: 'sup',\n category: 'textual',\n mixedUAStyles: {\n textAlignVertical: 'top',\n fontSize: 'smaller'\n }\n }),\n i: HTMLElementModel.fromNativeModel({\n tagName: 'i',\n category: 'textual',\n mixedUAStyles: italicStyle\n }),\n b: HTMLElementModel.fromNativeModel({\n tagName: 'b',\n category: 'textual',\n mixedUAStyles: boldStyle\n }),\n u: HTMLElementModel.fromNativeModel({\n tagName: 'u',\n category: 'textual',\n mixedUAStyles: solidUnderlineStyle\n }),\n mark: HTMLElementModel.fromNativeModel({\n tagName: 'mark',\n category: 'textual',\n mixedUAStyles: {\n backgroundColor: 'yellow',\n color: 'black'\n }\n }),\n bdi: HTMLElementModel.fromNativeModel({\n tagName: 'bdi',\n category: 'textual'\n // unicode-bidi: isolate;\n }),\n bdo: HTMLElementModel.fromNativeModel({\n tagName: 'bdo',\n category: 'textual'\n // unicode-bidi: isolate-override;\n }),\n span: HTMLElementModel.fromNativeModel({\n tagName: 'span',\n category: 'textual'\n }),\n br: HTMLElementModel.fromNativeModel({\n tagName: 'br',\n category: 'textual',\n isVoid: true\n }),\n wbr: HTMLElementModel.fromNativeModel({\n tagName: 'wbr',\n category: 'textual',\n isVoid: true\n })\n};\n\nconst defaultHTMLElementModels = {\n a: HTMLElementModel.fromNativeModel({\n tagName: 'a',\n category: 'anchor',\n getMixedUAStyles: ({ attributes }) => {\n if (typeof attributes.href === 'string') {\n return anchorStyle;\n }\n },\n getReactNativeProps: getReactNativePropsWithHref,\n setMarkersForTNode(targetMarkers) {\n targetMarkers.anchor = true;\n }\n }),\n ...textLevelModelMap,\n ...editsModelMap,\n ...renderedEmbeddedModelMap,\n ...emptyEmbeddedModelMap,\n ...tabularModelMap,\n ...groupingModelMap,\n ...sectioningModelMap,\n ...interactiveModelMap,\n ...untranslatableModelMap\n};\n\nexport type DefaultHTMLElementModelsStatic = typeof defaultHTMLElementModels;\n\nexport default defaultHTMLElementModels;\n","/**\n * The **content model** associated with a tag determines how this tag should\n * be translated in the Transient Render Tree.\n */\n// eslint-disable-next-line no-shadow\nexport enum HTMLContentModel {\n /**\n * Translatable to TBlock.\n */\n block = 'block',\n /**\n * Translatable to TPhrasing and TText\n */\n textual = 'textual',\n /**\n * Translatable to TBlock, TPhrasing and TText\n */\n mixed = 'mixed',\n /**\n * Translatable to TEmpty\n */\n none = 'none'\n}\n\nexport default HTMLContentModel;\n","/* eslint-disable no-dupe-class-members */\nimport { MixedStyleDeclaration } from '@native-html/css-processor';\nimport { ReactNativePropsDefinitions } from '../helper-types';\nimport { SetMarkersForTNode } from '../tree/tree-types';\nimport HTMLContentModel from './HTMLContentModel';\nimport {\n CustomElementModel,\n ElementCategory,\n ElementModelBase,\n NativeElementModel,\n TagName\n} from './model-types';\n\nconst phrasingCategories: ElementCategory[] = ['textual', 'edits', 'anchor'];\nconst translatableBlockCategories: ElementCategory[] = [\n 'tabular',\n 'grouping',\n 'sectioning'\n];\n\n/**\n * An object to specify custom tags.\n *\n * @typeParam T - The name of the tag to which the model will apply.\n * @typeParam M - The {@link HTMLContentModel} associated with this tag.\n */\nexport interface HTMLElementModelShape<\n T extends string,\n M extends HTMLContentModel\n> extends ElementModelBase {\n /**\n * The {@link HTMLContentModel} attached to this model.\n */\n readonly contentModel: M;\n /**\n * `true` when the associated tag is a {@link https://html.spec.whatwg.org/multipage/syntax.html#void-elements | void element}.\n *\n * @remarks\n *\n * - Void elements cannot have children.\n * - TText-translated void elements will be preserved even though they don't\n * have children.\n */\n readonly isVoid: boolean;\n /**\n * An opaque element translated {@link TNode} will have no translated {@link TNode}\n * children.\n */\n readonly isOpaque: boolean;\n}\n\n/**\n * An object defining engine internals for tags, such as default styles\n * (UAStyles), content model (how this tag is treated during hoisting)... etc.\n *\n * @typeParam T - The name of the tag to which the model will apply.\n * @typeParam M - The {@link HTMLContentModel} associated with this tag.\n */\nexport default class HTMLElementModel<\n T extends string,\n M extends HTMLContentModel\n> implements HTMLElementModelShape\n{\n /**\n * The tag name associated with this model.\n */\n public readonly tagName: T;\n /**\n * The {@link HTMLContentModel} attached to this model.\n */\n public readonly contentModel: M;\n /**\n * An opaque element translated {@link TNode} will have no translated {@link TNode}\n * children.\n */\n public readonly isOpaque: boolean;\n /**\n * `true` when the associated tag is a {@link https://html.spec.whatwg.org/multipage/syntax.html#void-elements | void element}.\n *\n * @remarks\n *\n * - Void elements cannot have children.\n * - TText-translated void elements will be preserved even though they don't\n * have children.\n */\n public readonly isVoid: boolean;\n /**\n * Equivalent of \"user-agent\" styles. The default styles for the element.\n *\n * @remarks These styles will be merged over by `tagsStyles`.\n */\n public readonly mixedUAStyles?: MixedStyleDeclaration;\n /**\n * React Native props grouped by native components. Those props\n * will be passed to the underlying native component at render time.\n *\n * @remarks Some props might be overriden by props derived from the\n * {@link TNode} attributes. For example, if you pass `accessibilityLabel`\n * and there is an `aria-label` attribute attached to one node, the\n * `aria-label` will be used. If you want to be able to override the\n * `aria-label`, use {@link HTMLElementModel.getReactNativeProps} instead.\n *\n * @example\n *\n * ```ts\n * import {HTMLElementModel, HTMLContentModel} from 'react-native-render-html';\n *\n * const customHTMLElementModels = {\n * 'nav-button': HTMLElementModel.fromCustomModel({\n * tagName: 'nav-button',\n * contentModel: HTMLContentModel.block,\n * reactNativeProps: {\n * native: {\n * onPress() {\n * console.info('nav-button pressed');\n * },\n * },\n * },\n * }),\n *};\n * ```\n */\n readonly reactNativeProps?: ReactNativePropsDefinitions;\n /**\n * A function to create conditional \"user-agent\" styles.\n *\n * @deprecated Use {@link HTMLElementModel.getMixedUAStyles} instead.\n */\n public readonly getUADerivedStyleFromAttributes: NativeElementModel['getUADerivedStyleFromAttributes'];\n /**\n * A function to create conditional \"user-agent\" styles.\n *\n * @remarks For example, <a> tags will have underline decoration and be\n * colored blue only when `href` is defined.\n */\n public readonly getMixedUAStyles: NativeElementModel['getMixedUAStyles'];\n /**\n * A function to create React Native props from a {@link TNode} grouped by\n * native components.\n *\n * Those props will be deep-merged over the pre-generated props. You can\n * preserve some of the pre-generated props since you receive them as second\n * argument.\n *\n * **Merge strategy** (latest overrides former):\n *\n * 1. props from `reactNativeProps`,\n * 2. auto-generated props from attributes\n * 3. props returned by this function\n *\n * @param tnode - The {@link TNode} for which to create React Native props.\n * @param preGeneratedProps - The props that were pre-generated for the {@link TNode}\n * based on attributes (e.g. aria-label ...) and\n * {@link ElementModelBase.reactNativeProps}.\n * @returns React Native props grouped by native components (see\n * {@link ReactNativePropsDefinitions}). Those props will be passed to the\n * underlying native component at render time.\n *\n * @example\n *\n * ```ts\n * import { defaultHTMLElementModels } from \"react-native-render-html\";\n *\n * const customHTMLElementModels = {\n * a: defaultHTMLElementModels.a.extend({\n * getReactNativeProps(tnode) {\n * const attributes = tnode.attributes;\n * return {\n * native: {\n * accessibilityHint:\n * attributes['data-scope'] === 'internal'\n * ? 'Open in a new screen.'\n * : 'Open in system web browser.',\n * },\n * };\n * },\n * }),\n * };\n * ```\n */\n public readonly getReactNativeProps: NativeElementModel['getReactNativeProps'];\n\n /**\n * Derive markers for one TNode.\n */\n public readonly setMarkersForTNode?: SetMarkersForTNode;\n\n private constructor({\n tagName,\n contentModel,\n isOpaque,\n mixedUAStyles,\n isVoid,\n getUADerivedStyleFromAttributes,\n getMixedUAStyles,\n setMarkersForTNode,\n getReactNativeProps,\n reactNativeProps\n }: HTMLElementModelShape) {\n this.tagName = tagName;\n this.contentModel = contentModel;\n this.isOpaque = isOpaque || false;\n this.isVoid = isVoid;\n this.mixedUAStyles = mixedUAStyles;\n this.getUADerivedStyleFromAttributes = getUADerivedStyleFromAttributes;\n this.getMixedUAStyles = getMixedUAStyles;\n this.setMarkersForTNode = setMarkersForTNode;\n this.getReactNativeProps = getReactNativeProps;\n this.reactNativeProps = reactNativeProps;\n }\n\n /**\n * Create an {@link HTMLElementModel} from a custom template.\n *\n * @param template - The custom template.\n */\n static fromCustomModel<\n CustomTags extends string,\n ContentModel extends HTMLContentModel\n >(template: CustomElementModel) {\n const {\n contentModel,\n tagName,\n isOpaque = false,\n isVoid = false,\n ...optionalFields\n } = template;\n return new HTMLElementModel({\n tagName,\n contentModel,\n isOpaque,\n isVoid,\n ...optionalFields\n });\n }\n\n /**\n * Create an {@link HTMLElementModel} from a native description.\n *\n * @param nativeElementModel - The native model declaration.\n */\n static fromNativeModel(\n nativeElementModel: NativeElementModel\n ) {\n const {\n category,\n isOpaque,\n isVoid = false,\n ...otherProps\n } = nativeElementModel;\n const isPhrasing = phrasingCategories.indexOf(category) !== -1;\n const isTranslatable =\n isPhrasing || translatableBlockCategories.indexOf(category) !== -1;\n const contentModel =\n category === 'anchor' || category === 'edits'\n ? HTMLContentModel.mixed\n : isPhrasing\n ? HTMLContentModel.textual\n : isTranslatable\n ? HTMLContentModel.block\n : HTMLContentModel.none;\n return new HTMLElementModel<\n TN,\n E extends 'edits' | 'anchor'\n ? HTMLContentModel.mixed\n : E extends 'sectioning' | 'grouping' | 'tabular'\n ? HTMLContentModel.block\n : E extends 'textual'\n ? HTMLContentModel.textual\n : HTMLContentModel.none\n >({\n isVoid,\n contentModel: contentModel as any,\n isOpaque: isOpaque ?? category === 'embedded',\n ...otherProps\n });\n }\n\n isTranslatableBlock(): boolean {\n return this.contentModel === HTMLContentModel.block;\n }\n\n isTranslatableTextual() {\n return (\n this.contentModel === HTMLContentModel.textual ||\n this.contentModel === HTMLContentModel.mixed\n );\n }\n\n /**\n * Create a new {@link HTMLElementModel} by shallow-merging properties into this model.\n *\n * @param merger - A function to generate the new properties to shallow-merge into this model.\n * @typeParam CM - The {@link HTMLContentModel} attached to the new model.\n */\n extend(\n merger: (\n shape: HTMLElementModelShape\n ) => Partial>\n ): HTMLElementModel;\n /**\n * Create a new {@link HTMLElementModel} by shallow-merging properties into this model.\n *\n * @param shape - The {@link HTMLElementModelShape} to shallow-merge into this model.\n * @typeParam CM - The {@link HTMLContentModel} attached to the new model.\n */\n extend(\n shape: Partial>\n ): HTMLElementModel;\n extend(\n arg:\n | ((\n shape: HTMLElementModelShape\n ) => Partial>)\n | Partial>\n ): HTMLElementModel {\n const properties = typeof arg === 'function' ? arg(this) : arg;\n return new HTMLElementModel({\n ...this,\n ...properties\n });\n }\n}\n","import { StylesConfig } from './types';\n\nexport const defaultStylesConfig: Required = {\n classesStyles: {},\n enableCSSInlineProcessing: true,\n enableUserAgentStyles: false,\n idsStyles: {},\n tagsStyles: {},\n baseStyle: {\n fontSize: 14,\n whiteSpace: 'normal'\n }\n};\n","import CSSProcessor, {\n CSSProcessedProps,\n CSSProcessorConfig,\n MixedStyleDeclaration\n} from '@native-html/css-processor';\nimport HTMLModelRegistry from '../model/HTMLModelRegistry';\nimport { TNodeDescriptor } from '../tree/tree-types';\nimport { TStyles } from './TStyles';\nimport { StylesConfig } from './types';\n\nexport const emptyProcessedPropsReg: CSSProcessedProps =\n new CSSProcessedProps();\n\nfunction mapMixedStyleRecordToCSSProcessedPropsReg(\n processor: CSSProcessor,\n styles?: Record\n): Record {\n let regStyles: Record = {};\n for (const key in styles) {\n regStyles[key] = processor.compileStyleDeclaration(styles[key]);\n }\n return regStyles;\n}\n\n// Specificity hierarchy, in descending order:\n// 1. Inline styles\n// 2. ID (idsStyles)\n// 3. Classes (classesStyles)\n// 4. Element name (tagsStyles)\n// 5. Attribute styles (styles derived from attributes)\n// 6. Default element styles\n// 7. Inherited styles (baseFontStyles)\nexport class TStylesMerger {\n private processor: CSSProcessor;\n private tagsStyles: Record;\n private classesStyles: Record;\n private idsStyles: Record;\n private enableCSSInlineProcessing: boolean;\n private enableUserAgentStyles: boolean;\n private modelRegistry: HTMLModelRegistry;\n constructor(\n config: Required,\n modelRegistry: HTMLModelRegistry,\n cssProcessorConfig?: CSSProcessorConfig\n ) {\n this.processor = new CSSProcessor(cssProcessorConfig);\n this.modelRegistry = modelRegistry;\n this.classesStyles = mapMixedStyleRecordToCSSProcessedPropsReg(\n this.processor,\n config.classesStyles\n );\n this.tagsStyles = mapMixedStyleRecordToCSSProcessedPropsReg(\n this.processor,\n config.tagsStyles\n );\n this.idsStyles = mapMixedStyleRecordToCSSProcessedPropsReg(\n this.processor,\n config.idsStyles\n );\n this.enableCSSInlineProcessing = config.enableCSSInlineProcessing;\n this.enableUserAgentStyles = config.enableUserAgentStyles;\n }\n\n compileInlineCSS(inlineCSS: string) {\n return this.processor.compileInlineCSS(inlineCSS);\n }\n\n compileStyleDeclaration(styleDeclaration: MixedStyleDeclaration) {\n return this.processor.compileStyleDeclaration(styleDeclaration);\n }\n\n buildStyles(\n inlineStyle: string,\n parentStyles: TStyles | null,\n descriptor: TNodeDescriptor\n ): TStyles {\n const ownInlinePropsReg =\n this.enableCSSInlineProcessing && inlineStyle\n ? this.compileInlineCSS(inlineStyle)\n : null;\n const model = descriptor.tagName\n ? this.modelRegistry.getElementModelFromTagName(descriptor.tagName)\n : null;\n const userTagOwnProps =\n this.tagsStyles[descriptor.tagName as string] ?? null;\n const userIdOwnProps = this.idsStyles[descriptor.id as string] ?? null;\n const classes = descriptor.classes;\n const userClassesOwnPropsList = classes.map(\n (c) => this.classesStyles[c] || null\n );\n const dynamicPropsFromAttributes = this.enableUserAgentStyles\n ? (model?.getMixedUAStyles?.(descriptor, descriptor.domNode!) || null) ??\n model?.getUADerivedStyleFromAttributes?.(\n descriptor.attributes,\n descriptor.markers\n ) ??\n null\n : null;\n const userAgentTagProps = this.enableUserAgentStyles\n ? model?.mixedUAStyles ?? null\n : null;\n // Latest properties will override former properties.\n const mergedOwnProps = emptyProcessedPropsReg.merge(\n userAgentTagProps &&\n this.processor.compileStyleDeclaration(userAgentTagProps),\n dynamicPropsFromAttributes &&\n this.processor.compileStyleDeclaration(dynamicPropsFromAttributes),\n userTagOwnProps,\n ...userClassesOwnPropsList,\n userIdOwnProps,\n ownInlinePropsReg\n );\n return new TStyles(mergedOwnProps, parentStyles);\n }\n}\n","import { CSSProcessor } from './CSSProcessor';\nexport { CSSProcessedProps } from './CSSProcessedProps';\nexport * from './config';\nexport * from './default';\nexport * from './processor-types';\nexport * from './property-types';\nexport * from './native-types';\nexport { default as mergeProps } from './mergeProps';\nexport { CSSProcessor };\nexport type {\n CSSFlattenProcessedTypes,\n MixedSizeCSSPropertiesKeys,\n MixedStyleDeclaration\n} from './CSSProcessor';\nexport default CSSProcessor;\n","import { CSSProperties } from 'react';\nimport { TextStyle, ViewStyle } from 'react-native';\nimport { MixedStyleDeclaration } from './CSSProcessor';\nimport { emptyProps, isNotEmpty } from './emptyProps';\nimport mergeProps from './mergeProps';\nimport {\n CSSPropertyCompatCategory,\n CSSDisplayRegistry,\n WebTextFlowProperties,\n CSSPropertySpecs,\n CSSPropertyDisplayCategory,\n CSSPropertyPropagationCategory\n} from './processor-types';\nimport {\n CSSLongNativeTranslatableBlockFlowedPropKey,\n CSSLongNativeTranslatableBlockRetainedPropKey,\n CSSLongNativeTranslatableTextFlowedPropKey,\n CSSLongNativeTranslatableTextRetainedPropKey,\n CSSLongNativeUntranslatableBlockFlowedPropKey,\n CSSLongNativeUntranslatableBlockPropKey,\n CSSLongWebTextRetainedPropKey\n} from './property-types';\n\nconst compatCategories: ReadonlyArray = [\n 'native',\n 'web'\n];\nconst displayCategories: ReadonlyArray = [\n 'text',\n 'block'\n];\nconst propagationCategories: ReadonlyArray = [\n 'flow',\n 'retain'\n];\n\n/**\n * An object representing categorized style props. Props are categorized\n * depending on their inheritability (flow, retain), target (block, text)\n * and (react) native support (native, web).\n */\nexport class CSSProcessedProps\n implements Record\n{\n readonly native: {\n text: {\n flow: Partial<\n Pick\n >;\n retain: Partial<\n Pick\n >;\n };\n block: {\n flow: Partial<\n Pick\n >;\n retain: Partial<\n Pick\n >;\n };\n };\n readonly web: {\n text: {\n flow: Partial & CSSProperties;\n retain: Partial> &\n CSSProperties;\n };\n block: {\n flow: Partial<\n Pick\n > &\n CSSProperties;\n retain: Partial<\n Pick\n > &\n CSSProperties;\n };\n };\n\n constructor() {\n this.native = this.newCompatCategory<'native'>();\n this.web = this.newCompatCategory<'web'>();\n }\n\n private newCompatCategory<\n T extends CSSPropertyCompatCategory\n >(): CSSProcessedProps[T] {\n return {\n block: {\n retain: emptyProps,\n flow: emptyProps\n },\n text: {\n retain: emptyProps,\n flow: emptyProps\n }\n };\n }\n\n public withProperty(\n propertyName: K,\n propertyValue: MixedStyleDeclaration[K],\n { compatCategory, displayCategory, propagationCategory }: CSSPropertySpecs\n ) {\n if (propertyValue !== null) {\n const target = this[compatCategory][displayCategory][propagationCategory];\n if (!isNotEmpty(target)) {\n this[compatCategory][displayCategory][propagationCategory] = {};\n }\n //@ts-ignore\n this[compatCategory][displayCategory][propagationCategory][propertyName] =\n propertyValue;\n }\n return this;\n }\n\n /**\n * Create a new processed prop object by merging the 'overriders' parameters\n * into this object.\n *\n * @param overriders - The processed props which will be merged into this\n * processed prop. Rightmost props will override leftmost props.\n */\n public merge(...overriders: Array) {\n const filtered = overriders.filter(isNotEmpty);\n const next = new CSSProcessedProps();\n for (const compat of compatCategories) {\n for (const display of displayCategories) {\n for (const propagation of propagationCategories) {\n next[compat][display][propagation] = mergeProps([\n this[compat][display][propagation],\n ...filtered.map((o) => o[compat][display][propagation])\n ]);\n }\n }\n }\n return next;\n }\n\n static new() {\n return new CSSProcessedProps();\n }\n}\n","import { emptyProps, isNotEmpty } from './emptyProps';\n\nfunction mergeProps>(props: Array): T {\n const filteredProps = props.filter(isNotEmpty);\n if (filteredProps.length) {\n return Object.assign({}, ...filteredProps);\n }\n return emptyProps as unknown as T;\n}\n\nexport default mergeProps;\n","const emptySymbol = Symbol('emptyProps');\n\nexport type EmptyProps = typeof emptyProps;\n\nexport const emptyProps = (function () {\n let obj = {};\n Object.defineProperty(obj, '$$empty', {\n value: emptySymbol,\n enumerable: false\n });\n obj = Object.freeze(obj);\n return obj;\n})() as {\n $$empty: symbol;\n};\n\nexport function isNotEmpty(p: T): p is Exclude {\n //@ts-ignore\n return !!p && p.$$empty !== emptySymbol;\n}\n","import { CSSProcessorConfig } from './config';\nimport { CSSInlineParseRun } from './CSSInlineParseRun';\nimport { CSSNativeParseRun } from './CSSNativeParseRun';\nimport { CSSProcessedProps } from './CSSProcessedProps';\nimport { CSSPropertiesValidationRegistry } from './CSSPropertiesValidationRegistry';\nimport { defaultCSSProcessorConfig } from './default';\nimport {\n ExtraNativeShortStyle,\n ExtraNativeTextStyle,\n ExtraNativeUntranslatedLongStyles,\n ExtraNativeViewStyle\n} from './native-types';\nimport {\n WebBlockRetainProperties,\n WebTextFlowProperties\n} from './processor-types';\n\n// https://www.w3.org/TR/CSS22/\n// https://www.w3.org/TR/css3-cascade/\n// https://www.w3.org/TR/css-cascade-4/\n// https://www.w3.org/TR/css-text-3/\n// https://www.w3.org/TR/css3-values/\n// https://www.w3.org/TR/css-values-4/\n\n/**\n * All those styles that result from processing inline styles.\n */\nexport type CSSFlattenProcessedTypes =\n CSSProcessedProps['native']['text']['flow'] &\n CSSProcessedProps['native']['block']['flow'] &\n CSSProcessedProps['native']['text']['retain'] &\n CSSProcessedProps['native']['block']['retain'];\n\n/**\n * These properties can be set to any of the supoprted CSS sizes, including em,\n * rem units and special values such as large, larger for `fontSize`, thin,\n * medium for `borderWidth`, before passed to {@link CSSProcessor.compileStyleDeclaration}.\n */\nexport type MixedSizeCSSPropertiesKeys =\n | 'fontSize'\n | 'borderWidth'\n | 'letterSpacing'\n | 'bottom'\n | 'left'\n | 'top'\n | 'right'\n | 'width'\n | 'height'\n | 'flexBasis'\n | 'borderRadius'\n | 'borderBottomLeftRadius'\n | 'borderBottomRightRadius'\n | 'borderTopLeftRadius'\n | 'borderTopRightRadius'\n | 'borderWidth'\n | 'borderBottomWidth'\n | 'borderLeftWidth'\n | 'borderRightWidth'\n | 'marginBottom'\n | 'marginLeft'\n | 'marginRight'\n | 'marginTop'\n | 'margin'\n | 'marginHorizontal'\n | 'marginVertical'\n | 'maxWidth'\n | 'maxHeight'\n | 'minWidth'\n | 'minHeight'\n | 'padding'\n | 'paddingBottom'\n | 'paddingLeft'\n | 'paddingRight'\n | 'paddingTop'\n | 'paddingHorizontal'\n | 'paddingVertical';\n\n/**\n * A Style object that can contain mixins of a subset of ViewStyle, TextStyle,\n * and special style entries such as \"whiteSpace\", \"listStyleType\".\n *\n * @remarks Also note that special lengths,\n * such as \"em\", \"rem\" units, and special values, such as \"%\" for fontSize, and\n * keyword values ('larger', 'smaller' for fontSize, 'thick', 'thin', 'medium'\n * for border*Width) will be handled as per CSS specifications on units.\n * Another special use case is fontFamily, which can be a list of font names as\n * per the CSS standard. The translated font will be selected with\n * {@link CSSProcessorConfig.isFontSupported}.\n */\nexport type MixedStyleDeclaration = Omit<\n CSSFlattenProcessedTypes,\n MixedSizeCSSPropertiesKeys\n> &\n WebTextFlowProperties &\n WebBlockRetainProperties &\n ExtraNativeTextStyle &\n ExtraNativeViewStyle &\n ExtraNativeShortStyle &\n ExtraNativeUntranslatedLongStyles &\n {\n [k in MixedSizeCSSPropertiesKeys]?: number | string;\n };\n\nexport class CSSProcessor {\n public readonly registry: CSSPropertiesValidationRegistry;\n constructor(userConfig?: Partial) {\n const config = {\n ...defaultCSSProcessorConfig,\n ...userConfig\n };\n this.registry = new CSSPropertiesValidationRegistry(config);\n }\n\n /**\n *\n * Incoming style declaration:\n * - For native styles: any RN compatible style declaration + special units\n * (font-size: medium) + relative units (smaller, larger, em, rem and perhaps vw)\n *\n * @param declaration\n */\n compileStyleDeclaration(\n declaration: MixedStyleDeclaration\n ): CSSProcessedProps {\n const parseRun = new CSSNativeParseRun(declaration, this.registry);\n return parseRun.exec();\n }\n\n compileInlineCSS(inlineCSS: string): CSSProcessedProps {\n const parseRun = new CSSInlineParseRun(inlineCSS, this.registry);\n return parseRun.exec();\n }\n}\n","import { CSSProcessorConfig } from './config';\n\nconst inchMultiplicator = 96;\nconst cmMultiplicator = inchMultiplicator * 2.54;\nconst mmMultiplicator = cmMultiplicator / 10;\nconst ptMultiplicator = 4 / 3;\nconst pcMultiplicator = 12 * ptMultiplicator;\n\nexport const defaultCSSProcessorConfig: CSSProcessorConfig = {\n absoluteLengthUnitsMultiplicators: {\n cm: cmMultiplicator,\n in: inchMultiplicator,\n mm: mmMultiplicator,\n pc: pcMultiplicator,\n pt: ptMultiplicator\n },\n absoluteBorderWidthsPixelMap: {\n medium: 2.5,\n thick: 5,\n thin: 1\n },\n absoluteFontSizesPixelMap: {\n medium: 14,\n 'xx-small': 8.5,\n 'x-small': 10,\n small: 12,\n large: 17,\n 'x-large': 20,\n 'xx-large': 24\n },\n relativeFontSizesCoefficientMap: {\n larger: 1.2,\n smaller: 0.83\n },\n inlinePropertiesBlacklist: [],\n rootFontSize: 16,\n inlinePropertiesWhitelist: null,\n isFontSupported() {\n return true;\n }\n};\n","import { CSSProcessorConfig, CSSPropertyNameList } from './config';\nimport makepropertiesValidators, {\n ValidatorsType\n} from './makepropertiesValidators';\nimport { GenericCSSPropertyValidator } from './validators/GenericPropertyValidator';\n\nfunction makeRegistry(list: CSSPropertyNameList) {\n const registry = {} as any;\n list.forEach((prop) => {\n registry[prop] = true;\n });\n return registry;\n}\n\nexport class CSSPropertiesValidationRegistry {\n public readonly validators: Readonly;\n public readonly ignoredPropertiesRegistry: Partial>;\n public readonly allowedPropertiesRegistry: Partial<\n Record\n > | null;\n\n constructor(config: CSSProcessorConfig) {\n this.validators = makepropertiesValidators(config);\n this.ignoredPropertiesRegistry = makeRegistry(\n config.inlinePropertiesBlacklist\n );\n this.allowedPropertiesRegistry = config.inlinePropertiesWhitelist\n ? makeRegistry(config.inlinePropertiesWhitelist)\n : null;\n }\n\n private isInlinePropertyAllowed(name: string) {\n if (this.allowedPropertiesRegistry) {\n return !!this.allowedPropertiesRegistry[name];\n }\n return !this.ignoredPropertiesRegistry[name];\n }\n\n shouldRegisterInlineProperty(name: string): name is keyof ValidatorsType {\n return (\n this.isInlinePropertyAllowed(name) &&\n !!this.validators[name as keyof ValidatorsType]\n );\n }\n\n getValidatorForProperty(\n name: T\n ): T extends keyof ValidatorsType ? GenericCSSPropertyValidator : null {\n return (this.validators[name as keyof ValidatorsType] as any) || null;\n }\n}\n","import { CSSProcessorConfig } from './config';\nimport { LongFontFamilyPropertyValidator } from './validators/LongFontFamilyPropertyValidator';\nimport { LongFloatNumberCSSPropertyValidator } from './validators/LongFloatNumberCSSPropertyValidator';\nimport { LongBorderWidthCSSPropertyValidator } from './validators/LongBorderWidthCSSPropertyValidator';\nimport { LongFontSizeCSSValidator } from './validators/LongFontSizeCSSValidator';\nimport { LongSizeCSSPropertyValidator } from './validators/LongSizeCSSPropertyValidator';\nimport { LongAspectRatioPropertyValidator } from './validators/LongAspectRatioPropertyValidator';\nimport { LongEnumerationListCSSPropertyValidator } from './validators/LongEnumerationListCSSPropertyValidator';\nimport { LongBorderStyleCSSPropertyValidator } from './validators/LongBorderStyleCSSPropertyValidator';\nimport { LongEnumerationCSSPropertyValidator } from './validators/LongEnumerationCSSPropertyValidator';\nimport { LongColorCSSPropertyValidator } from './validators/LongColorCSSPropertyValidator';\nimport { ShortFontCSSValidator } from './validators/ShortFontCSSValidator';\nimport { ShortCSSToReactNativeValidator } from './validators/ShortCSSToReactNativeValidator';\nimport { ShortFlexCSSPropertyValidator } from './validators/ShortFlexCSSPropertyValidator';\nimport { LongCSSToReactNativeValidator } from './validators/LongCSSToReactNativeValidator';\nimport { ShortCardinalCSSpropertyValidator } from './validators/ShortCardinalCSSPropertyValidator';\nimport { ShortDualNativepropertyValidator } from './validators/ShortDualNativePropertyValidator';\nimport { LongForgivingCSSPropertyValidator } from './validators/LongForgivingCSSPropertyValidator';\nimport { LongNonPercentSizeCSSPropertyValidator } from './validators/LongNonPercentSizeCSSPropertyValidator';\n\nconst nativeTranslatableBlockFlowModel = {\n inheritable: true,\n native: true,\n translatable: true,\n display: 'block'\n} as const;\n\nconst nativeTranslatableBlockRetainModel = {\n inheritable: false,\n native: true,\n translatable: true,\n display: 'block'\n} as const;\n\nconst nativeUntranslatableBlockRetainModel = {\n inheritable: false,\n native: true,\n translatable: false,\n display: 'block'\n} as const;\n\nconst nativeTranslatableTextFlowModel = {\n inheritable: true,\n native: true,\n translatable: true,\n display: 'text'\n} as const;\n\nconst nativeTranslatableTextRetainModel = {\n inheritable: false,\n native: true,\n translatable: true,\n display: 'text'\n} as const;\n\nconst webTextFlowModel = {\n inheritable: true,\n native: false,\n translatable: false,\n display: 'text'\n} as const;\n\nconst webBlockRetainModel = {\n inheritable: false,\n native: false,\n translatable: false,\n display: 'block'\n} as const;\n\nexport type ValidatorsType = ReturnType;\n\nexport default function makepropertiesValidators(config: CSSProcessorConfig) {\n return {\n background: new ShortCSSToReactNativeValidator({\n config,\n model: nativeTranslatableBlockRetainModel,\n propertyName: 'background'\n }),\n border: new ShortCSSToReactNativeValidator({\n config,\n model: nativeTranslatableBlockRetainModel,\n propertyName: 'border'\n }),\n borderRadius: new ShortCardinalCSSpropertyValidator(\n {\n config,\n model: nativeTranslatableBlockRetainModel,\n propertyName: 'borderRadius'\n },\n {\n top: 'borderTopLeftRadius',\n right: 'borderTopRightRadius',\n bottom: 'borderBottomRightRadius',\n left: 'borderBottomLeftRadius'\n }\n ),\n borderColor: new ShortCardinalCSSpropertyValidator(\n {\n config,\n model: nativeTranslatableBlockRetainModel,\n propertyName: 'borderColor'\n },\n {\n top: 'borderTopColor',\n right: 'borderRightColor',\n bottom: 'borderBottomColor',\n left: 'borderLeftColor'\n }\n ),\n borderStyle: new LongBorderStyleCSSPropertyValidator(\n {\n config,\n model: nativeTranslatableBlockRetainModel,\n propertyName: 'borderStyle'\n },\n ['solid', 'dotted', 'dashed']\n ),\n borderWidth: new ShortCardinalCSSpropertyValidator(\n {\n config,\n propertyName: 'borderWidth',\n model: nativeTranslatableBlockRetainModel\n },\n {\n top: 'borderTopWidth',\n right: 'borderRightWidth',\n bottom: 'borderBottomWidth',\n left: 'borderLeftWidth'\n }\n ),\n flex: new ShortFlexCSSPropertyValidator({\n config,\n propertyName: 'flex',\n model: nativeTranslatableBlockRetainModel\n }),\n flexFlow: new ShortCSSToReactNativeValidator({\n config,\n model: nativeTranslatableBlockRetainModel,\n propertyName: 'flexFlow'\n }),\n font: new ShortFontCSSValidator({\n config,\n model: nativeTranslatableTextFlowModel,\n propertyName: 'font'\n }),\n margin: new ShortCardinalCSSpropertyValidator(\n {\n config,\n model: nativeTranslatableBlockRetainModel,\n propertyName: 'margin'\n },\n {\n top: 'marginTop',\n right: 'marginRight',\n bottom: 'marginBottom',\n left: 'marginLeft'\n }\n ),\n objectFit: new LongEnumerationCSSPropertyValidator(\n {\n config,\n model: webBlockRetainModel,\n propertyName: 'objectFit'\n },\n ['fill', 'contain', 'cover', 'none', 'scale-down']\n ),\n padding: new ShortCardinalCSSpropertyValidator(\n {\n config,\n model: nativeTranslatableBlockRetainModel,\n propertyName: 'padding'\n },\n {\n top: 'paddingTop',\n right: 'paddingRight',\n bottom: 'paddingBottom',\n left: 'paddingLeft'\n }\n ),\n marginHorizontal: new ShortDualNativepropertyValidator(\n {\n config,\n model: nativeTranslatableBlockRetainModel,\n propertyName: 'marginHorizontal'\n },\n ['marginLeft', 'marginRight']\n ),\n marginVertical: new ShortDualNativepropertyValidator(\n {\n config,\n model: nativeTranslatableBlockRetainModel,\n propertyName: 'marginVertical'\n },\n ['marginTop', 'marginBottom']\n ),\n paddingHorizontal: new ShortDualNativepropertyValidator(\n {\n config,\n model: nativeTranslatableBlockRetainModel,\n propertyName: 'paddingHorizontal'\n },\n ['paddingLeft', 'paddingRight']\n ),\n paddingVertical: new ShortDualNativepropertyValidator(\n {\n config,\n model: nativeTranslatableBlockRetainModel,\n propertyName: 'paddingVertical'\n },\n ['paddingTop', 'paddingBottom']\n ),\n textDecoration: new ShortCSSToReactNativeValidator({\n config,\n model: nativeTranslatableTextRetainModel,\n propertyName: 'textDecoration'\n }),\n textDecorationColor: new LongColorCSSPropertyValidator({\n config,\n propertyName: 'textDecorationColor',\n model: nativeTranslatableTextRetainModel\n }),\n textDecorationLine: new LongEnumerationCSSPropertyValidator(\n {\n config,\n model: nativeTranslatableTextRetainModel,\n propertyName: 'textDecorationLine'\n },\n ['none', 'underline', 'line-through', 'underline line-through'] // 'overline' not supported by RN\n ),\n textDecorationStyle: new LongEnumerationCSSPropertyValidator(\n {\n config,\n model: nativeTranslatableTextRetainModel,\n propertyName: 'textDecorationStyle'\n },\n ['solid', 'double', 'dotted', 'dashed'] // 'wavy' unsupported\n ),\n color: new LongColorCSSPropertyValidator({\n config,\n propertyName: 'color',\n model: nativeTranslatableTextFlowModel\n }),\n fontFamily: new LongFontFamilyPropertyValidator({\n config,\n propertyName: 'fontFamily',\n model: nativeTranslatableTextFlowModel\n }),\n fontSize: new LongFontSizeCSSValidator({\n config,\n propertyName: 'fontSize',\n model: nativeTranslatableTextFlowModel\n }),\n fontStyle: new LongEnumerationCSSPropertyValidator(\n {\n config,\n model: nativeTranslatableTextFlowModel,\n propertyName: 'fontStyle'\n },\n ['normal', 'italic'] // 'oblique' not supported\n ),\n fontVariant: new LongEnumerationListCSSPropertyValidator(\n {\n config,\n model: nativeTranslatableTextFlowModel,\n propertyName: 'fontVariant'\n },\n [\n 'small-caps',\n 'oldstyle-nums',\n 'lining-nums',\n 'tabular-nums',\n 'proportional-nums'\n ]\n ),\n fontWeight: new LongEnumerationCSSPropertyValidator(\n {\n config,\n model: nativeTranslatableTextFlowModel,\n propertyName: 'fontWeight'\n },\n [\n 'normal',\n 'bold',\n '100',\n '200',\n '300',\n '400',\n '500',\n '600',\n '700',\n '800',\n '900'\n ]\n ),\n letterSpacing: new LongSizeCSSPropertyValidator({\n config,\n propertyName: 'letterSpacing',\n model: nativeTranslatableTextFlowModel\n }),\n // TODO handle unitless heights\n lineHeight: new LongNonPercentSizeCSSPropertyValidator({\n config,\n propertyName: 'lineHeight',\n model: nativeTranslatableTextFlowModel\n }),\n textAlign: new LongEnumerationCSSPropertyValidator(\n {\n config,\n model: nativeTranslatableTextFlowModel,\n propertyName: 'textAlign'\n },\n ['auto', 'left', 'right', 'center', 'justify']\n ),\n textTransform: new LongEnumerationCSSPropertyValidator(\n {\n config,\n model: nativeTranslatableTextFlowModel,\n propertyName: 'textTransform'\n },\n ['none', 'capitalize', 'uppercase', 'lowercase']\n ),\n whiteSpace: new LongEnumerationCSSPropertyValidator(\n { config, model: webTextFlowModel, propertyName: 'whiteSpace' },\n ['normal', 'pre']\n ),\n listStyleType: new LongForgivingCSSPropertyValidator({\n config,\n model: webTextFlowModel,\n propertyName: 'listStyleType'\n }),\n userSelect: new LongEnumerationCSSPropertyValidator(\n {\n config,\n model: webTextFlowModel,\n propertyName: 'userSelect'\n },\n ['auto', 'text', 'none', 'contain', 'all']\n ),\n alignContent: new LongEnumerationCSSPropertyValidator(\n {\n config,\n model: nativeTranslatableBlockRetainModel,\n propertyName: 'alignContent'\n },\n [\n 'flex-start',\n 'flex-end',\n 'center',\n 'stretch',\n 'space-between',\n 'space-around'\n ]\n ),\n alignItems: new LongEnumerationCSSPropertyValidator(\n {\n config,\n model: nativeTranslatableBlockRetainModel,\n propertyName: 'alignItems'\n },\n ['flex-start', 'flex-end', 'center', 'stretch', 'baseline']\n ),\n alignSelf: new LongEnumerationCSSPropertyValidator(\n {\n config,\n model: nativeTranslatableBlockRetainModel,\n propertyName: 'alignSelf'\n },\n ['auto', 'flex-start', 'flex-end', 'center', 'stretch', 'baseline']\n ),\n aspectRatio: new LongAspectRatioPropertyValidator({\n config,\n model: nativeTranslatableBlockRetainModel,\n propertyName: 'aspectRatio'\n }),\n bottom: new LongSizeCSSPropertyValidator({\n config,\n propertyName: 'bottom',\n model: nativeTranslatableBlockRetainModel\n }),\n display: new LongEnumerationCSSPropertyValidator(\n {\n config,\n model: nativeTranslatableBlockRetainModel,\n propertyName: 'display'\n },\n ['flex', 'none']\n ),\n flexBasis: new LongSizeCSSPropertyValidator({\n config,\n propertyName: 'flexBasis',\n model: nativeTranslatableBlockRetainModel\n }),\n flexDirection: new LongEnumerationCSSPropertyValidator(\n {\n config,\n model: nativeTranslatableBlockRetainModel,\n propertyName: 'flexDirection'\n },\n ['row', 'column', 'row-reverse', 'column-reverse']\n ),\n flexGrow: new LongFloatNumberCSSPropertyValidator({\n config,\n propertyName: 'flexGrow',\n model: nativeTranslatableBlockRetainModel\n }),\n flexShrink: new LongFloatNumberCSSPropertyValidator({\n config,\n propertyName: 'flexShrink',\n model: nativeTranslatableBlockRetainModel\n }),\n flexWrap: new LongEnumerationCSSPropertyValidator(\n {\n config,\n model: nativeTranslatableBlockRetainModel,\n propertyName: 'flexWrap'\n },\n ['wrap', 'nowrap', 'wrap-reverse']\n ),\n justifyContent: new LongEnumerationCSSPropertyValidator(\n {\n config,\n model: nativeTranslatableBlockRetainModel,\n propertyName: 'justifyContent'\n },\n [\n 'flex-start',\n 'flex-end',\n 'center',\n 'space-between',\n 'space-around',\n 'space-evenly'\n ]\n ),\n left: new LongSizeCSSPropertyValidator({\n config,\n propertyName: 'left',\n model: nativeTranslatableBlockRetainModel\n }),\n position: new LongEnumerationCSSPropertyValidator(\n {\n config,\n model: nativeUntranslatableBlockRetainModel,\n propertyName: 'position'\n },\n ['absolute', 'relative']\n ),\n right: new LongSizeCSSPropertyValidator({\n config,\n propertyName: 'right',\n model: nativeTranslatableBlockRetainModel\n }),\n top: new LongSizeCSSPropertyValidator({\n config,\n model: nativeTranslatableBlockRetainModel,\n propertyName: 'top'\n }),\n backfaceVisibility: new LongEnumerationCSSPropertyValidator(\n {\n config,\n model: nativeTranslatableBlockRetainModel,\n propertyName: 'backfaceVisibility'\n },\n ['visible', 'hidden']\n ),\n backgroundColor: new LongColorCSSPropertyValidator({\n config,\n propertyName: 'backgroundColor',\n model: nativeTranslatableBlockRetainModel\n }),\n borderBottomColor: new LongColorCSSPropertyValidator({\n config,\n propertyName: 'borderBottomColor',\n model: nativeTranslatableBlockRetainModel\n }),\n borderBottomLeftRadius: new LongNonPercentSizeCSSPropertyValidator({\n config,\n propertyName: 'borderBottomLeftRadius',\n model: nativeTranslatableBlockRetainModel\n }),\n borderBottomRightRadius: new LongNonPercentSizeCSSPropertyValidator({\n config,\n propertyName: 'borderBottomRightRadius',\n model: nativeTranslatableBlockRetainModel\n }),\n borderBottomWidth: new LongBorderWidthCSSPropertyValidator({\n config,\n propertyName: 'borderBottomWidth',\n model: nativeTranslatableBlockRetainModel\n }),\n borderLeftColor: new LongColorCSSPropertyValidator({\n config,\n propertyName: 'borderLeftColor',\n model: nativeTranslatableBlockRetainModel\n }),\n borderLeftWidth: new LongBorderWidthCSSPropertyValidator({\n config,\n propertyName: 'borderLeftWidth',\n model: nativeTranslatableBlockRetainModel\n }),\n borderRightColor: new LongColorCSSPropertyValidator({\n config,\n propertyName: 'borderRightColor',\n model: nativeTranslatableBlockRetainModel\n }),\n borderRightWidth: new LongBorderWidthCSSPropertyValidator({\n config,\n propertyName: 'borderRightWidth',\n model: nativeTranslatableBlockRetainModel\n }),\n borderTopColor: new LongColorCSSPropertyValidator({\n config,\n propertyName: 'borderTopColor',\n model: nativeTranslatableBlockRetainModel\n }),\n borderTopLeftRadius: new LongNonPercentSizeCSSPropertyValidator({\n config,\n propertyName: 'borderTopLeftRadius',\n model: nativeTranslatableBlockRetainModel\n }),\n borderTopRightRadius: new LongNonPercentSizeCSSPropertyValidator({\n config,\n propertyName: 'borderTopRightRadius',\n model: nativeTranslatableBlockRetainModel\n }),\n borderTopWidth: new LongBorderWidthCSSPropertyValidator({\n config,\n propertyName: 'borderTopWidth',\n model: nativeTranslatableBlockRetainModel\n }),\n height: new LongSizeCSSPropertyValidator({\n config,\n propertyName: 'height',\n model: nativeTranslatableBlockRetainModel\n }),\n marginBottom: new LongSizeCSSPropertyValidator({\n config,\n propertyName: 'marginBottom',\n model: nativeTranslatableBlockRetainModel\n }),\n marginLeft: new LongSizeCSSPropertyValidator({\n config,\n propertyName: 'marginLeft',\n model: nativeTranslatableBlockRetainModel\n }),\n marginRight: new LongSizeCSSPropertyValidator({\n config,\n propertyName: 'marginRight',\n model: nativeTranslatableBlockRetainModel\n }),\n marginTop: new LongSizeCSSPropertyValidator({\n config,\n propertyName: 'marginTop',\n model: nativeTranslatableBlockRetainModel\n }),\n maxHeight: new LongSizeCSSPropertyValidator({\n config,\n propertyName: 'maxHeight',\n model: nativeTranslatableBlockRetainModel\n }),\n maxWidth: new LongSizeCSSPropertyValidator({\n config,\n propertyName: 'maxWidth',\n model: nativeTranslatableBlockRetainModel\n }),\n minHeight: new LongSizeCSSPropertyValidator({\n config,\n propertyName: 'minHeight',\n model: nativeTranslatableBlockRetainModel\n }),\n minWidth: new LongSizeCSSPropertyValidator({\n config,\n propertyName: 'minWidth',\n model: nativeTranslatableBlockRetainModel\n }),\n opacity: new LongFloatNumberCSSPropertyValidator({\n config,\n propertyName: 'opacity',\n model: nativeTranslatableBlockRetainModel\n }),\n paddingBottom: new LongSizeCSSPropertyValidator({\n config,\n propertyName: 'paddingBottom',\n model: nativeTranslatableBlockRetainModel\n }),\n paddingLeft: new LongSizeCSSPropertyValidator({\n config,\n propertyName: 'paddingLeft',\n model: nativeTranslatableBlockRetainModel\n }),\n paddingRight: new LongSizeCSSPropertyValidator({\n config,\n propertyName: 'paddingRight',\n model: nativeTranslatableBlockRetainModel\n }),\n paddingTop: new LongSizeCSSPropertyValidator({\n config,\n propertyName: 'paddingTop',\n model: nativeTranslatableBlockRetainModel\n }),\n transform: new LongCSSToReactNativeValidator({\n config,\n propertyName: 'transform',\n model: nativeTranslatableBlockRetainModel\n }),\n width: new LongSizeCSSPropertyValidator({\n config,\n propertyName: 'width',\n model: nativeTranslatableBlockRetainModel\n }),\n zIndex: new LongFloatNumberCSSPropertyValidator({\n config,\n propertyName: 'zIndex',\n model: nativeTranslatableBlockRetainModel\n }),\n direction: new LongEnumerationCSSPropertyValidator(\n {\n config,\n model: nativeTranslatableBlockFlowModel,\n propertyName: 'direction'\n },\n ['auto', 'ltr', 'rtl']\n )\n };\n}\n","import { ShortCSSPropertyValidator } from './ShortCSSPropertyValidator';\nimport { CSSPropertyModel } from './types';\nimport expandCSSToRN from './expandCSSToRN';\nimport { ShortMergeRequest } from '../ShortMergeRequest';\n\nexport class ShortCSSToReactNativeValidator<\n C extends CSSPropertyModel = any\n> extends ShortCSSPropertyValidator {\n normalizeInlineCSSValue(value: string): ShortMergeRequest | null {\n return new ShortMergeRequest(expandCSSToRN(this.propertyName, value));\n }\n /**\n * Not supported on Native.\n * @param value\n */\n normalizeNativeValue() {\n return null;\n }\n}\n","import { getStylesForProperty } from 'css-to-react-native';\n\nexport default function expandCSSToRN(propertyName: string, value: string) {\n try {\n return getStylesForProperty(propertyName, value);\n } catch (e) {\n // Ignore this rule if parsing failed\n }\n return null;\n}\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', {\n value: true\n});\n\nfunction _interopDefault(ex) {\n return ex && typeof ex === 'object' && 'default' in ex ? ex['default'] : ex;\n}\n\nvar parse = require('postcss-value-parser');\n\nvar parse__default = _interopDefault(parse);\n\nvar camelizeStyleName = _interopDefault(require('camelize'));\n\nvar cssColorKeywords = _interopDefault(require('css-color-keywords'));\n\nvar matchString = function matchString(node) {\n if (node.type !== 'string') return null;\n return node.value.replace(/\\\\([0-9a-f]{1,6})(?:\\s|$)/gi, function (match, charCode) {\n return String.fromCharCode(parseInt(charCode, 16));\n }).replace(/\\\\/g, '');\n};\n\nvar hexColorRe = /^(#(?:[0-9a-f]{3,4}){1,2})$/i;\nvar cssFunctionNameRe = /^(rgba?|hsla?|hwb|lab|lch|gray|color)$/;\n\nvar matchColor = function matchColor(node) {\n if (node.type === 'word' && (hexColorRe.test(node.value) || node.value in cssColorKeywords || node.value === 'transparent')) {\n return node.value;\n } else if (node.type === 'function' && cssFunctionNameRe.test(node.value)) {\n return parse.stringify(node);\n }\n\n return null;\n};\n\nvar noneRe = /^(none)$/i;\nvar autoRe = /^(auto)$/i;\nvar identRe = /(^-?[_a-z][_a-z0-9-]*$)/i; // Note if these are wrong, you'll need to change index.js too\n\nvar numberRe = /^([+-]?(?:\\d*\\.)?\\d+(?:e[+-]?\\d+)?)$/i; // Note lengthRe is sneaky: you can omit units for 0\n\nvar lengthRe = /^(0$|(?:[+-]?(?:\\d*\\.)?\\d+(?:e[+-]?\\d+)?)(?=px$))/i;\nvar unsupportedUnitRe = /^([+-]?(?:\\d*\\.)?\\d+(?:e[+-]?\\d+)?(ch|em|ex|rem|vh|vw|vmin|vmax|cm|mm|in|pc|pt))$/i;\nvar angleRe = /^([+-]?(?:\\d*\\.)?\\d+(?:e[+-]?\\d+)?(?:deg|rad))$/i;\nvar percentRe = /^([+-]?(?:\\d*\\.)?\\d+(?:e[+-]?\\d+)?%)$/i;\n\nvar noopToken = function noopToken(predicate) {\n return function (node) {\n return predicate(node) ? '' : null;\n };\n};\n\nvar valueForTypeToken = function valueForTypeToken(type) {\n return function (node) {\n return node.type === type ? node.value : null;\n };\n};\n\nvar regExpToken = function regExpToken(regExp, transform) {\n if (transform === void 0) {\n transform = String;\n }\n\n return function (node) {\n if (node.type !== 'word') return null;\n var match = node.value.match(regExp);\n if (match === null) return null;\n var value = transform(match[1]);\n return value;\n };\n};\n\nvar SPACE = noopToken(function (node) {\n return node.type === 'space';\n});\nvar SLASH = noopToken(function (node) {\n return node.type === 'div' && node.value === '/';\n});\nvar COMMA = noopToken(function (node) {\n return node.type === 'div' && node.value === ',';\n});\nvar WORD = valueForTypeToken('word');\nvar NONE = regExpToken(noneRe);\nvar AUTO = regExpToken(autoRe);\nvar NUMBER = regExpToken(numberRe, Number);\nvar LENGTH = regExpToken(lengthRe, Number);\nvar UNSUPPORTED_LENGTH_UNIT = regExpToken(unsupportedUnitRe);\nvar ANGLE = regExpToken(angleRe, function (angle) {\n return angle.toLowerCase();\n});\nvar PERCENT = regExpToken(percentRe);\nvar IDENT = regExpToken(identRe);\nvar STRING = matchString;\nvar COLOR = matchColor;\nvar LINE = regExpToken(/^(none|underline|line-through)$/i);\nvar BORDER_STYLE = regExpToken(/^(solid|dashed|dotted)$/);\nvar defaultBorderWidth = 1;\nvar defaultBorderColor = 'black';\nvar defaultBorderStyle = 'solid';\n\nvar border = function border(tokenStream) {\n var borderWidth;\n var borderColor;\n var borderStyle;\n\n if (tokenStream.matches(NONE)) {\n tokenStream.expectEmpty();\n return {\n borderWidth: 0,\n borderColor: 'black',\n borderStyle: 'solid'\n };\n }\n\n var partsParsed = 0;\n\n while (partsParsed < 3 && tokenStream.hasTokens()) {\n if (partsParsed !== 0) tokenStream.expect(SPACE);\n\n if (borderWidth === undefined && tokenStream.matches(LENGTH, UNSUPPORTED_LENGTH_UNIT)) {\n borderWidth = tokenStream.lastValue;\n } else if (borderColor === undefined && tokenStream.matches(COLOR)) {\n borderColor = tokenStream.lastValue;\n } else if (borderStyle === undefined && tokenStream.matches(BORDER_STYLE)) {\n borderStyle = tokenStream.lastValue;\n } else {\n tokenStream[\"throw\"]();\n }\n\n partsParsed += 1;\n }\n\n tokenStream.expectEmpty();\n if (borderWidth === undefined) borderWidth = defaultBorderWidth;\n if (borderColor === undefined) borderColor = defaultBorderColor;\n if (borderStyle === undefined) borderStyle = defaultBorderStyle;\n return {\n borderWidth: borderWidth,\n borderColor: borderColor,\n borderStyle: borderStyle\n };\n};\n\nvar directionFactory = function directionFactory(_ref) {\n var _ref$types = _ref.types,\n types = _ref$types === void 0 ? [LENGTH, UNSUPPORTED_LENGTH_UNIT, PERCENT] : _ref$types,\n _ref$directions = _ref.directions,\n directions = _ref$directions === void 0 ? ['Top', 'Right', 'Bottom', 'Left'] : _ref$directions,\n _ref$prefix = _ref.prefix,\n prefix = _ref$prefix === void 0 ? '' : _ref$prefix,\n _ref$suffix = _ref.suffix,\n suffix = _ref$suffix === void 0 ? '' : _ref$suffix;\n return function (tokenStream) {\n var _ref2;\n\n var values = []; // borderWidth doesn't currently allow a percent value, but may do in the future\n\n values.push(tokenStream.expect.apply(tokenStream, types));\n\n while (values.length < 4 && tokenStream.hasTokens()) {\n tokenStream.expect(SPACE);\n values.push(tokenStream.expect.apply(tokenStream, types));\n }\n\n tokenStream.expectEmpty();\n var top = values[0],\n _values$ = values[1],\n right = _values$ === void 0 ? top : _values$,\n _values$2 = values[2],\n bottom = _values$2 === void 0 ? top : _values$2,\n _values$3 = values[3],\n left = _values$3 === void 0 ? right : _values$3;\n\n var keyFor = function keyFor(n) {\n return \"\" + prefix + directions[n] + suffix;\n };\n\n return _ref2 = {}, _ref2[keyFor(0)] = top, _ref2[keyFor(1)] = right, _ref2[keyFor(2)] = bottom, _ref2[keyFor(3)] = left, _ref2;\n };\n};\n\nvar parseShadowOffset = function parseShadowOffset(tokenStream) {\n var width = tokenStream.expect(LENGTH);\n var height = tokenStream.matches(SPACE) ? tokenStream.expect(LENGTH) : width;\n tokenStream.expectEmpty();\n return {\n width: width,\n height: height\n };\n};\n\nvar parseShadow = function parseShadow(tokenStream) {\n var offsetX;\n var offsetY;\n var radius;\n var color;\n\n if (tokenStream.matches(NONE)) {\n tokenStream.expectEmpty();\n return {\n offset: {\n width: 0,\n height: 0\n },\n radius: 0,\n color: 'black'\n };\n }\n\n var didParseFirst = false;\n\n while (tokenStream.hasTokens()) {\n if (didParseFirst) tokenStream.expect(SPACE);\n\n if (offsetX === undefined && tokenStream.matches(LENGTH, UNSUPPORTED_LENGTH_UNIT)) {\n offsetX = tokenStream.lastValue;\n tokenStream.expect(SPACE);\n offsetY = tokenStream.expect(LENGTH, UNSUPPORTED_LENGTH_UNIT);\n tokenStream.saveRewindPoint();\n\n if (tokenStream.matches(SPACE) && tokenStream.matches(LENGTH, UNSUPPORTED_LENGTH_UNIT)) {\n radius = tokenStream.lastValue;\n } else {\n tokenStream.rewind();\n }\n } else if (color === undefined && tokenStream.matches(COLOR)) {\n color = tokenStream.lastValue;\n } else {\n tokenStream[\"throw\"]();\n }\n\n didParseFirst = true;\n }\n\n if (offsetX === undefined) tokenStream[\"throw\"]();\n return {\n offset: {\n width: offsetX,\n height: offsetY\n },\n radius: radius !== undefined ? radius : 0,\n color: color !== undefined ? color : 'black'\n };\n};\n\nvar boxShadow = function boxShadow(tokenStream) {\n var _parseShadow = parseShadow(tokenStream),\n offset = _parseShadow.offset,\n radius = _parseShadow.radius,\n color = _parseShadow.color;\n\n return {\n shadowOffset: offset,\n shadowRadius: radius,\n shadowColor: color,\n shadowOpacity: 1\n };\n};\n\nvar defaultFlexGrow = 1;\nvar defaultFlexShrink = 1;\nvar defaultFlexBasis = 0;\n\nvar flex = function flex(tokenStream) {\n var flexGrow;\n var flexShrink;\n var flexBasis;\n\n if (tokenStream.matches(NONE)) {\n tokenStream.expectEmpty();\n return {\n flexGrow: 0,\n flexShrink: 0,\n flexBasis: 'auto'\n };\n }\n\n tokenStream.saveRewindPoint();\n\n if (tokenStream.matches(AUTO) && !tokenStream.hasTokens()) {\n return {\n flexGrow: 1,\n flexShrink: 1,\n flexBasis: 'auto'\n };\n }\n\n tokenStream.rewind();\n var partsParsed = 0;\n\n while (partsParsed < 2 && tokenStream.hasTokens()) {\n if (partsParsed !== 0) tokenStream.expect(SPACE);\n\n if (flexGrow === undefined && tokenStream.matches(NUMBER)) {\n flexGrow = tokenStream.lastValue;\n tokenStream.saveRewindPoint();\n\n if (tokenStream.matches(SPACE) && tokenStream.matches(NUMBER)) {\n flexShrink = tokenStream.lastValue;\n } else {\n tokenStream.rewind();\n }\n } else if (flexBasis === undefined && tokenStream.matches(LENGTH, UNSUPPORTED_LENGTH_UNIT, PERCENT)) {\n flexBasis = tokenStream.lastValue;\n } else if (flexBasis === undefined && tokenStream.matches(AUTO)) {\n flexBasis = 'auto';\n } else {\n tokenStream[\"throw\"]();\n }\n\n partsParsed += 1;\n }\n\n tokenStream.expectEmpty();\n if (flexGrow === undefined) flexGrow = defaultFlexGrow;\n if (flexShrink === undefined) flexShrink = defaultFlexShrink;\n if (flexBasis === undefined) flexBasis = defaultFlexBasis;\n return {\n flexGrow: flexGrow,\n flexShrink: flexShrink,\n flexBasis: flexBasis\n };\n};\n\nvar FLEX_WRAP = regExpToken(/(nowrap|wrap|wrap-reverse)/);\nvar FLEX_DIRECTION = regExpToken(/(row|row-reverse|column|column-reverse)/);\nvar defaultFlexWrap = 'nowrap';\nvar defaultFlexDirection = 'row';\n\nvar flexFlow = function flexFlow(tokenStream) {\n var flexWrap;\n var flexDirection;\n var partsParsed = 0;\n\n while (partsParsed < 2 && tokenStream.hasTokens()) {\n if (partsParsed !== 0) tokenStream.expect(SPACE);\n\n if (flexWrap === undefined && tokenStream.matches(FLEX_WRAP)) {\n flexWrap = tokenStream.lastValue;\n } else if (flexDirection === undefined && tokenStream.matches(FLEX_DIRECTION)) {\n flexDirection = tokenStream.lastValue;\n } else {\n tokenStream[\"throw\"]();\n }\n\n partsParsed += 1;\n }\n\n tokenStream.expectEmpty();\n if (flexWrap === undefined) flexWrap = defaultFlexWrap;\n if (flexDirection === undefined) flexDirection = defaultFlexDirection;\n return {\n flexWrap: flexWrap,\n flexDirection: flexDirection\n };\n};\n\nvar fontFamily = function fontFamily(tokenStream) {\n var fontFamily;\n\n if (tokenStream.matches(STRING)) {\n fontFamily = tokenStream.lastValue;\n } else {\n fontFamily = tokenStream.expect(IDENT);\n\n while (tokenStream.hasTokens()) {\n tokenStream.expect(SPACE);\n var nextIdent = tokenStream.expect(IDENT);\n fontFamily += \" \" + nextIdent;\n }\n }\n\n tokenStream.expectEmpty();\n return {\n fontFamily: fontFamily\n };\n};\n\nvar NORMAL = regExpToken(/^(normal)$/);\nvar STYLE = regExpToken(/^(italic)$/);\nvar WEIGHT = regExpToken(/^([1-9]00|bold)$/);\nvar VARIANT = regExpToken(/^(small-caps)$/);\nvar defaultFontStyle = 'normal';\nvar defaultFontWeight = 'normal';\nvar defaultFontVariant = [];\n\nvar font = function font(tokenStream) {\n var fontStyle;\n var fontWeight;\n var fontVariant; // let fontSize;\n\n var lineHeight; // let fontFamily;\n\n var numStyleWeightVariantMatched = 0;\n\n while (numStyleWeightVariantMatched < 3 && tokenStream.hasTokens()) {\n if (tokenStream.matches(NORMAL)) ;else if (fontStyle === undefined && tokenStream.matches(STYLE)) {\n fontStyle = tokenStream.lastValue;\n } else if (fontWeight === undefined && tokenStream.matches(WEIGHT)) {\n fontWeight = tokenStream.lastValue;\n } else if (fontVariant === undefined && tokenStream.matches(VARIANT)) {\n fontVariant = [tokenStream.lastValue];\n } else {\n break;\n }\n tokenStream.expect(SPACE);\n numStyleWeightVariantMatched += 1;\n }\n\n var fontSize = tokenStream.expect(LENGTH, UNSUPPORTED_LENGTH_UNIT);\n\n if (tokenStream.matches(SLASH)) {\n lineHeight = tokenStream.expect(LENGTH, UNSUPPORTED_LENGTH_UNIT);\n }\n\n tokenStream.expect(SPACE);\n\n var _fontFamily = fontFamily(tokenStream),\n fontFamily$1 = _fontFamily.fontFamily;\n\n if (fontStyle === undefined) fontStyle = defaultFontStyle;\n if (fontWeight === undefined) fontWeight = defaultFontWeight;\n if (fontVariant === undefined) fontVariant = defaultFontVariant;\n var out = {\n fontStyle: fontStyle,\n fontWeight: fontWeight,\n fontVariant: fontVariant,\n fontSize: fontSize,\n fontFamily: fontFamily$1\n };\n if (lineHeight !== undefined) out.lineHeight = lineHeight;\n return out;\n};\n\nvar ALIGN_CONTENT = regExpToken(/(flex-(?:start|end)|center|stretch|space-(?:between|around))/);\nvar JUSTIFY_CONTENT = regExpToken(/(flex-(?:start|end)|center|space-(?:between|around|evenly))/);\n\nvar placeContent = function placeContent(tokenStream) {\n var alignContent = tokenStream.expect(ALIGN_CONTENT);\n var justifyContent;\n\n if (tokenStream.hasTokens()) {\n tokenStream.expect(SPACE);\n justifyContent = tokenStream.expect(JUSTIFY_CONTENT);\n } else {\n justifyContent = 'stretch';\n }\n\n tokenStream.expectEmpty();\n return {\n alignContent: alignContent,\n justifyContent: justifyContent\n };\n};\n\nvar STYLE$1 = regExpToken(/^(solid|double|dotted|dashed)$/);\nvar defaultTextDecorationLine = 'none';\nvar defaultTextDecorationStyle = 'solid';\nvar defaultTextDecorationColor = 'black';\n\nvar textDecoration = function textDecoration(tokenStream) {\n var line;\n var style;\n var color;\n var didParseFirst = false;\n\n while (tokenStream.hasTokens()) {\n if (didParseFirst) tokenStream.expect(SPACE);\n\n if (line === undefined && tokenStream.matches(LINE)) {\n var lines = [tokenStream.lastValue.toLowerCase()];\n tokenStream.saveRewindPoint();\n\n if (lines[0] !== 'none' && tokenStream.matches(SPACE) && tokenStream.matches(LINE)) {\n lines.push(tokenStream.lastValue.toLowerCase()); // Underline comes before line-through\n\n lines.sort().reverse();\n } else {\n tokenStream.rewind();\n }\n\n line = lines.join(' ');\n } else if (style === undefined && tokenStream.matches(STYLE$1)) {\n style = tokenStream.lastValue;\n } else if (color === undefined && tokenStream.matches(COLOR)) {\n color = tokenStream.lastValue;\n } else {\n tokenStream[\"throw\"]();\n }\n\n didParseFirst = true;\n }\n\n return {\n textDecorationLine: line !== undefined ? line : defaultTextDecorationLine,\n textDecorationColor: color !== undefined ? color : defaultTextDecorationColor,\n textDecorationStyle: style !== undefined ? style : defaultTextDecorationStyle\n };\n};\n\nvar textDecorationLine = function textDecorationLine(tokenStream) {\n var lines = [];\n var didParseFirst = false;\n\n while (tokenStream.hasTokens()) {\n if (didParseFirst) tokenStream.expect(SPACE);\n lines.push(tokenStream.expect(LINE).toLowerCase());\n didParseFirst = true;\n }\n\n lines.sort().reverse();\n return {\n textDecorationLine: lines.join(' ')\n };\n};\n\nvar textShadow = function textShadow(tokenStream) {\n var _parseShadow2 = parseShadow(tokenStream),\n offset = _parseShadow2.offset,\n radius = _parseShadow2.radius,\n color = _parseShadow2.color;\n\n return {\n textShadowOffset: offset,\n textShadowRadius: radius,\n textShadowColor: color\n };\n};\n\nvar oneOfType = function oneOfType(tokenType) {\n return function (functionStream) {\n var value = functionStream.expect(tokenType);\n functionStream.expectEmpty();\n return value;\n };\n};\n\nvar singleNumber = oneOfType(NUMBER);\nvar singleLength = oneOfType(LENGTH);\nvar singleAngle = oneOfType(ANGLE);\n\nvar xyTransformFactory = function xyTransformFactory(tokenType) {\n return function (key, valueIfOmitted) {\n return function (functionStream) {\n var _ref3, _ref4;\n\n var x = functionStream.expect(tokenType);\n var y;\n\n if (functionStream.hasTokens()) {\n functionStream.expect(COMMA);\n y = functionStream.expect(tokenType);\n } else if (valueIfOmitted !== undefined) {\n y = valueIfOmitted;\n } else {\n // Assumption, if x === y, then we can omit XY\n // I.e. scale(5) => [{ scale: 5 }] rather than [{ scaleX: 5 }, { scaleY: 5 }]\n return x;\n }\n\n functionStream.expectEmpty();\n return [(_ref3 = {}, _ref3[key + \"Y\"] = y, _ref3), (_ref4 = {}, _ref4[key + \"X\"] = x, _ref4)];\n };\n };\n};\n\nvar xyNumber = xyTransformFactory(NUMBER);\nvar xyLength = xyTransformFactory(LENGTH);\nvar xyAngle = xyTransformFactory(ANGLE);\nvar partTransforms = {\n perspective: singleNumber,\n scale: xyNumber('scale'),\n scaleX: singleNumber,\n scaleY: singleNumber,\n translate: xyLength('translate', 0),\n translateX: singleLength,\n translateY: singleLength,\n rotate: singleAngle,\n rotateX: singleAngle,\n rotateY: singleAngle,\n rotateZ: singleAngle,\n skewX: singleAngle,\n skewY: singleAngle,\n skew: xyAngle('skew', '0deg')\n};\n\nvar transform = function transform(tokenStream) {\n var transforms = [];\n var didParseFirst = false;\n\n while (tokenStream.hasTokens()) {\n if (didParseFirst) tokenStream.expect(SPACE);\n var functionStream = tokenStream.expectFunction();\n var functionName = functionStream.functionName;\n var transformedValues = partTransforms[functionName](functionStream);\n\n if (!Array.isArray(transformedValues)) {\n var _ref5;\n\n transformedValues = [(_ref5 = {}, _ref5[functionName] = transformedValues, _ref5)];\n }\n\n transforms = transformedValues.concat(transforms);\n didParseFirst = true;\n }\n\n return {\n transform: transforms\n };\n};\n\nvar background = function background(tokenStream) {\n return {\n backgroundColor: tokenStream.expect(COLOR)\n };\n};\n\nvar borderColor = directionFactory({\n types: [COLOR],\n prefix: 'border',\n suffix: 'Color'\n});\nvar borderRadius = directionFactory({\n directions: ['TopLeft', 'TopRight', 'BottomRight', 'BottomLeft'],\n prefix: 'border',\n suffix: 'Radius'\n});\nvar borderWidth = directionFactory({\n prefix: 'border',\n suffix: 'Width'\n});\nvar margin = directionFactory({\n types: [LENGTH, UNSUPPORTED_LENGTH_UNIT, PERCENT, AUTO],\n prefix: 'margin'\n});\nvar padding = directionFactory({\n prefix: 'padding'\n});\n\nvar fontVariant = function fontVariant(tokenStream) {\n return {\n fontVariant: [tokenStream.expect(IDENT)]\n };\n};\n\nvar fontWeight = function fontWeight(tokenStream) {\n return {\n fontWeight: tokenStream.expect(WORD) // Also match numbers as strings\n\n };\n};\n\nvar shadowOffset = function shadowOffset(tokenStream) {\n return {\n shadowOffset: parseShadowOffset(tokenStream)\n };\n};\n\nvar textShadowOffset = function textShadowOffset(tokenStream) {\n return {\n textShadowOffset: parseShadowOffset(tokenStream)\n };\n};\n\nvar transforms = {\n background: background,\n border: border,\n borderColor: borderColor,\n borderRadius: borderRadius,\n borderWidth: borderWidth,\n boxShadow: boxShadow,\n flex: flex,\n flexFlow: flexFlow,\n font: font,\n fontFamily: fontFamily,\n fontVariant: fontVariant,\n fontWeight: fontWeight,\n margin: margin,\n padding: padding,\n placeContent: placeContent,\n shadowOffset: shadowOffset,\n textShadow: textShadow,\n textShadowOffset: textShadowOffset,\n textDecoration: textDecoration,\n textDecorationLine: textDecorationLine,\n transform: transform\n};\nvar propertiesWithoutUnits;\n\nif (process.env.NODE_ENV !== 'production') {\n propertiesWithoutUnits = ['aspectRatio', 'elevation', 'flexGrow', 'flexShrink', 'opacity', 'shadowOpacity', 'zIndex'];\n}\n\nvar devPropertiesWithUnitsRegExp = propertiesWithoutUnits != null ? new RegExp(propertiesWithoutUnits.join('|')) : null;\nvar SYMBOL_MATCH = 'SYMBOL_MATCH';\n\nvar TokenStream =\n/*#__PURE__*/\nfunction () {\n function TokenStream(nodes, parent) {\n this.index = 0;\n this.nodes = nodes;\n this.functionName = parent != null ? parent.value : null;\n this.lastValue = null;\n this.rewindIndex = -1;\n }\n\n var _proto = TokenStream.prototype;\n\n _proto.hasTokens = function hasTokens() {\n return this.index <= this.nodes.length - 1;\n };\n\n _proto[SYMBOL_MATCH] = function () {\n if (!this.hasTokens()) return null;\n var node = this.nodes[this.index];\n\n for (var i = 0; i < arguments.length; i += 1) {\n var tokenDescriptor = i < 0 || arguments.length <= i ? undefined : arguments[i];\n var value = tokenDescriptor(node);\n\n if (value !== null) {\n this.index += 1;\n this.lastValue = value;\n return value;\n }\n }\n\n return null;\n };\n\n _proto.matches = function matches() {\n return this[SYMBOL_MATCH].apply(this, arguments) !== null;\n };\n\n _proto.expect = function expect() {\n var value = this[SYMBOL_MATCH].apply(this, arguments);\n return value !== null ? value : this[\"throw\"]();\n };\n\n _proto.matchesFunction = function matchesFunction() {\n var node = this.nodes[this.index];\n if (node.type !== 'function') return null;\n var value = new TokenStream(node.nodes, node);\n this.index += 1;\n this.lastValue = null;\n return value;\n };\n\n _proto.expectFunction = function expectFunction() {\n var value = this.matchesFunction();\n return value !== null ? value : this[\"throw\"]();\n };\n\n _proto.expectEmpty = function expectEmpty() {\n if (this.hasTokens()) this[\"throw\"]();\n };\n\n _proto[\"throw\"] = function _throw() {\n throw new Error(\"Unexpected token type: \" + this.nodes[this.index].type);\n };\n\n _proto.saveRewindPoint = function saveRewindPoint() {\n this.rewindIndex = this.index;\n };\n\n _proto.rewind = function rewind() {\n if (this.rewindIndex === -1) throw new Error('Internal error');\n this.index = this.rewindIndex;\n this.lastValue = null;\n };\n\n return TokenStream;\n}();\n/* eslint-disable no-param-reassign */\n// Note if this is wrong, you'll need to change tokenTypes.js too\n\n\nvar numberOrLengthRe = /^([+-]?(?:\\d*\\.)?\\d+(?:e[+-]?\\d+)?)(?:px)?$/i;\nvar numberOnlyRe = /^[+-]?(?:\\d*\\.\\d*|[1-9]\\d*)(?:e[+-]?\\d+)?$/i;\nvar boolRe = /^true|false$/i;\nvar nullRe = /^null$/i;\nvar undefinedRe = /^undefined$/i; // Undocumented export\n\nvar transformRawValue = function transformRawValue(propName, value) {\n if (process.env.NODE_ENV !== 'production') {\n var needsUnit = !devPropertiesWithUnitsRegExp.test(propName);\n var isNumberWithoutUnit = numberOnlyRe.test(value);\n\n if (needsUnit && isNumberWithoutUnit) {\n // eslint-disable-next-line no-console\n console.warn(\"Expected style \\\"\" + propName + \": \" + value + \"\\\" to contain units\");\n }\n\n if (!needsUnit && value !== '0' && !isNumberWithoutUnit) {\n // eslint-disable-next-line no-console\n console.warn(\"Expected style \\\"\" + propName + \": \" + value + \"\\\" to be unitless\");\n }\n }\n\n var numberMatch = value.match(numberOrLengthRe);\n if (numberMatch !== null) return Number(numberMatch[1]);\n var boolMatch = value.match(boolRe);\n if (boolMatch !== null) return boolMatch[0].toLowerCase() === 'true';\n var nullMatch = value.match(nullRe);\n if (nullMatch !== null) return null;\n var undefinedMatch = value.match(undefinedRe);\n if (undefinedMatch !== null) return undefined;\n return value;\n};\n\nvar baseTransformShorthandValue = function baseTransformShorthandValue(propName, value) {\n var ast = parse__default(value);\n var tokenStream = new TokenStream(ast.nodes);\n return transforms[propName](tokenStream);\n};\n\nvar transformShorthandValue = process.env.NODE_ENV === 'production' ? baseTransformShorthandValue : function (propName, value) {\n try {\n return baseTransformShorthandValue(propName, value);\n } catch (e) {\n throw new Error(\"Failed to parse declaration \\\"\" + propName + \": \" + value + \"\\\"\");\n }\n};\n\nvar getStylesForProperty = function getStylesForProperty(propName, inputValue, allowShorthand) {\n var _ref6;\n\n var isRawValue = allowShorthand === false || !(propName in transforms);\n var value = inputValue.trim();\n var propValues = isRawValue ? (_ref6 = {}, _ref6[propName] = transformRawValue(propName, value), _ref6) : transformShorthandValue(propName, value);\n return propValues;\n};\n\nvar getPropertyName = function getPropertyName(propName) {\n var isCustomProp = /^--\\w+/.test(propName);\n\n if (isCustomProp) {\n return propName;\n }\n\n return camelizeStyleName(propName);\n};\n\nvar index = function index(rules, shorthandBlacklist) {\n if (shorthandBlacklist === void 0) {\n shorthandBlacklist = [];\n }\n\n return rules.reduce(function (accum, rule) {\n var propertyName = getPropertyName(rule[0]);\n var value = rule[1];\n var allowShorthand = shorthandBlacklist.indexOf(propertyName) === -1;\n return Object.assign(accum, getStylesForProperty(propertyName, value, allowShorthand));\n }, {});\n};\n\nexports[\"default\"] = index;\nexports.getPropertyName = getPropertyName;\nexports.getStylesForProperty = getStylesForProperty;\nexports.transformRawValue = transformRawValue;\n","var parse = require(\"./parse\");\nvar walk = require(\"./walk\");\nvar stringify = require(\"./stringify\");\n\nfunction ValueParser(value) {\n if (this instanceof ValueParser) {\n this.nodes = parse(value);\n return this;\n }\n return new ValueParser(value);\n}\n\nValueParser.prototype.toString = function() {\n return Array.isArray(this.nodes) ? stringify(this.nodes) : \"\";\n};\n\nValueParser.prototype.walk = function(cb, bubble) {\n walk(this.nodes, cb, bubble);\n return this;\n};\n\nValueParser.unit = require(\"./unit\");\n\nValueParser.walk = walk;\n\nValueParser.stringify = stringify;\n\nmodule.exports = ValueParser;\n","var openParentheses = \"(\".charCodeAt(0);\nvar closeParentheses = \")\".charCodeAt(0);\nvar singleQuote = \"'\".charCodeAt(0);\nvar doubleQuote = '\"'.charCodeAt(0);\nvar backslash = \"\\\\\".charCodeAt(0);\nvar slash = \"/\".charCodeAt(0);\nvar comma = \",\".charCodeAt(0);\nvar colon = \":\".charCodeAt(0);\nvar star = \"*\".charCodeAt(0);\nvar uLower = \"u\".charCodeAt(0);\nvar uUpper = \"U\".charCodeAt(0);\nvar plus = \"+\".charCodeAt(0);\nvar isUnicodeRange = /^[a-f0-9?-]+$/i;\n\nmodule.exports = function(input) {\n var tokens = [];\n var value = input;\n\n var next,\n quote,\n prev,\n token,\n escape,\n escapePos,\n whitespacePos,\n parenthesesOpenPos;\n var pos = 0;\n var code = value.charCodeAt(pos);\n var max = value.length;\n var stack = [{ nodes: tokens }];\n var balanced = 0;\n var parent;\n\n var name = \"\";\n var before = \"\";\n var after = \"\";\n\n while (pos < max) {\n // Whitespaces\n if (code <= 32) {\n next = pos;\n do {\n next += 1;\n code = value.charCodeAt(next);\n } while (code <= 32);\n token = value.slice(pos, next);\n\n prev = tokens[tokens.length - 1];\n if (code === closeParentheses && balanced) {\n after = token;\n } else if (prev && prev.type === \"div\") {\n prev.after = token;\n prev.sourceEndIndex += token.length;\n } else if (\n code === comma ||\n code === colon ||\n (code === slash &&\n value.charCodeAt(next + 1) !== star &&\n (!parent ||\n (parent && parent.type === \"function\" && parent.value !== \"calc\")))\n ) {\n before = token;\n } else {\n tokens.push({\n type: \"space\",\n sourceIndex: pos,\n sourceEndIndex: next,\n value: token\n });\n }\n\n pos = next;\n\n // Quotes\n } else if (code === singleQuote || code === doubleQuote) {\n next = pos;\n quote = code === singleQuote ? \"'\" : '\"';\n token = {\n type: \"string\",\n sourceIndex: pos,\n quote: quote\n };\n do {\n escape = false;\n next = value.indexOf(quote, next + 1);\n if (~next) {\n escapePos = next;\n while (value.charCodeAt(escapePos - 1) === backslash) {\n escapePos -= 1;\n escape = !escape;\n }\n } else {\n value += quote;\n next = value.length - 1;\n token.unclosed = true;\n }\n } while (escape);\n token.value = value.slice(pos + 1, next);\n token.sourceEndIndex = token.unclosed ? next : next + 1;\n tokens.push(token);\n pos = next + 1;\n code = value.charCodeAt(pos);\n\n // Comments\n } else if (code === slash && value.charCodeAt(pos + 1) === star) {\n next = value.indexOf(\"*/\", pos);\n\n token = {\n type: \"comment\",\n sourceIndex: pos,\n sourceEndIndex: next + 2\n };\n\n if (next === -1) {\n token.unclosed = true;\n next = value.length;\n token.sourceEndIndex = next;\n }\n\n token.value = value.slice(pos + 2, next);\n tokens.push(token);\n\n pos = next + 2;\n code = value.charCodeAt(pos);\n\n // Operation within calc\n } else if (\n (code === slash || code === star) &&\n parent &&\n parent.type === \"function\" &&\n parent.value === \"calc\"\n ) {\n token = value[pos];\n tokens.push({\n type: \"word\",\n sourceIndex: pos - before.length,\n sourceEndIndex: pos + token.length,\n value: token\n });\n pos += 1;\n code = value.charCodeAt(pos);\n\n // Dividers\n } else if (code === slash || code === comma || code === colon) {\n token = value[pos];\n\n tokens.push({\n type: \"div\",\n sourceIndex: pos - before.length,\n sourceEndIndex: pos + token.length,\n value: token,\n before: before,\n after: \"\"\n });\n before = \"\";\n\n pos += 1;\n code = value.charCodeAt(pos);\n\n // Open parentheses\n } else if (openParentheses === code) {\n // Whitespaces after open parentheses\n next = pos;\n do {\n next += 1;\n code = value.charCodeAt(next);\n } while (code <= 32);\n parenthesesOpenPos = pos;\n token = {\n type: \"function\",\n sourceIndex: pos - name.length,\n value: name,\n before: value.slice(parenthesesOpenPos + 1, next)\n };\n pos = next;\n\n if (name === \"url\" && code !== singleQuote && code !== doubleQuote) {\n next -= 1;\n do {\n escape = false;\n next = value.indexOf(\")\", next + 1);\n if (~next) {\n escapePos = next;\n while (value.charCodeAt(escapePos - 1) === backslash) {\n escapePos -= 1;\n escape = !escape;\n }\n } else {\n value += \")\";\n next = value.length - 1;\n token.unclosed = true;\n }\n } while (escape);\n // Whitespaces before closed\n whitespacePos = next;\n do {\n whitespacePos -= 1;\n code = value.charCodeAt(whitespacePos);\n } while (code <= 32);\n if (parenthesesOpenPos < whitespacePos) {\n if (pos !== whitespacePos + 1) {\n token.nodes = [\n {\n type: \"word\",\n sourceIndex: pos,\n sourceEndIndex: whitespacePos + 1,\n value: value.slice(pos, whitespacePos + 1)\n }\n ];\n } else {\n token.nodes = [];\n }\n if (token.unclosed && whitespacePos + 1 !== next) {\n token.after = \"\";\n token.nodes.push({\n type: \"space\",\n sourceIndex: whitespacePos + 1,\n sourceEndIndex: next,\n value: value.slice(whitespacePos + 1, next)\n });\n } else {\n token.after = value.slice(whitespacePos + 1, next);\n token.sourceEndIndex = next;\n }\n } else {\n token.after = \"\";\n token.nodes = [];\n }\n pos = next + 1;\n token.sourceEndIndex = token.unclosed ? next : pos;\n code = value.charCodeAt(pos);\n tokens.push(token);\n } else {\n balanced += 1;\n token.after = \"\";\n token.sourceEndIndex = pos + 1;\n tokens.push(token);\n stack.push(token);\n tokens = token.nodes = [];\n parent = token;\n }\n name = \"\";\n\n // Close parentheses\n } else if (closeParentheses === code && balanced) {\n pos += 1;\n code = value.charCodeAt(pos);\n\n parent.after = after;\n parent.sourceEndIndex += after.length;\n after = \"\";\n balanced -= 1;\n stack[stack.length - 1].sourceEndIndex = pos;\n stack.pop();\n parent = stack[balanced];\n tokens = parent.nodes;\n\n // Words\n } else {\n next = pos;\n do {\n if (code === backslash) {\n next += 1;\n }\n next += 1;\n code = value.charCodeAt(next);\n } while (\n next < max &&\n !(\n code <= 32 ||\n code === singleQuote ||\n code === doubleQuote ||\n code === comma ||\n code === colon ||\n code === slash ||\n code === openParentheses ||\n (code === star &&\n parent &&\n parent.type === \"function\" &&\n parent.value === \"calc\") ||\n (code === slash &&\n parent.type === \"function\" &&\n parent.value === \"calc\") ||\n (code === closeParentheses && balanced)\n )\n );\n token = value.slice(pos, next);\n\n if (openParentheses === code) {\n name = token;\n } else if (\n (uLower === token.charCodeAt(0) || uUpper === token.charCodeAt(0)) &&\n plus === token.charCodeAt(1) &&\n isUnicodeRange.test(token.slice(2))\n ) {\n tokens.push({\n type: \"unicode-range\",\n sourceIndex: pos,\n sourceEndIndex: next,\n value: token\n });\n } else {\n tokens.push({\n type: \"word\",\n sourceIndex: pos,\n sourceEndIndex: next,\n value: token\n });\n }\n\n pos = next;\n }\n }\n\n for (pos = stack.length - 1; pos; pos -= 1) {\n stack[pos].unclosed = true;\n stack[pos].sourceEndIndex = value.length;\n }\n\n return stack[0].nodes;\n};\n","function stringifyNode(node, custom) {\n var type = node.type;\n var value = node.value;\n var buf;\n var customResult;\n\n if (custom && (customResult = custom(node)) !== undefined) {\n return customResult;\n } else if (type === \"word\" || type === \"space\") {\n return value;\n } else if (type === \"string\") {\n buf = node.quote || \"\";\n return buf + value + (node.unclosed ? \"\" : buf);\n } else if (type === \"comment\") {\n return \"/*\" + value + (node.unclosed ? \"\" : \"*/\");\n } else if (type === \"div\") {\n return (node.before || \"\") + value + (node.after || \"\");\n } else if (Array.isArray(node.nodes)) {\n buf = stringify(node.nodes, custom);\n if (type !== \"function\") {\n return buf;\n }\n return (\n value +\n \"(\" +\n (node.before || \"\") +\n buf +\n (node.after || \"\") +\n (node.unclosed ? \"\" : \")\")\n );\n }\n return value;\n}\n\nfunction stringify(nodes, custom) {\n var result, i;\n\n if (Array.isArray(nodes)) {\n result = \"\";\n for (i = nodes.length - 1; ~i; i -= 1) {\n result = stringifyNode(nodes[i], custom) + result;\n }\n return result;\n }\n return stringifyNode(nodes, custom);\n}\n\nmodule.exports = stringify;\n","module.exports = function walk(nodes, cb, bubble) {\n var i, max, node, result;\n\n for (i = 0, max = nodes.length; i < max; i += 1) {\n node = nodes[i];\n if (!bubble) {\n result = cb(node, i, nodes);\n }\n\n if (\n result !== false &&\n node.type === \"function\" &&\n Array.isArray(node.nodes)\n ) {\n walk(node.nodes, cb, bubble);\n }\n\n if (bubble) {\n cb(node, i, nodes);\n }\n }\n};\n","var minus = \"-\".charCodeAt(0);\nvar plus = \"+\".charCodeAt(0);\nvar dot = \".\".charCodeAt(0);\nvar exp = \"e\".charCodeAt(0);\nvar EXP = \"E\".charCodeAt(0);\n\n// Check if three code points would start a number\n// https://www.w3.org/TR/css-syntax-3/#starts-with-a-number\nfunction likeNumber(value) {\n var code = value.charCodeAt(0);\n var nextCode;\n\n if (code === plus || code === minus) {\n nextCode = value.charCodeAt(1);\n\n if (nextCode >= 48 && nextCode <= 57) {\n return true;\n }\n\n var nextNextCode = value.charCodeAt(2);\n\n if (nextCode === dot && nextNextCode >= 48 && nextNextCode <= 57) {\n return true;\n }\n\n return false;\n }\n\n if (code === dot) {\n nextCode = value.charCodeAt(1);\n\n if (nextCode >= 48 && nextCode <= 57) {\n return true;\n }\n\n return false;\n }\n\n if (code >= 48 && code <= 57) {\n return true;\n }\n\n return false;\n}\n\n// Consume a number\n// https://www.w3.org/TR/css-syntax-3/#consume-number\nmodule.exports = function(value) {\n var pos = 0;\n var length = value.length;\n var code;\n var nextCode;\n var nextNextCode;\n\n if (length === 0 || !likeNumber(value)) {\n return false;\n }\n\n code = value.charCodeAt(pos);\n\n if (code === plus || code === minus) {\n pos++;\n }\n\n while (pos < length) {\n code = value.charCodeAt(pos);\n\n if (code < 48 || code > 57) {\n break;\n }\n\n pos += 1;\n }\n\n code = value.charCodeAt(pos);\n nextCode = value.charCodeAt(pos + 1);\n\n if (code === dot && nextCode >= 48 && nextCode <= 57) {\n pos += 2;\n\n while (pos < length) {\n code = value.charCodeAt(pos);\n\n if (code < 48 || code > 57) {\n break;\n }\n\n pos += 1;\n }\n }\n\n code = value.charCodeAt(pos);\n nextCode = value.charCodeAt(pos + 1);\n nextNextCode = value.charCodeAt(pos + 2);\n\n if (\n (code === exp || code === EXP) &&\n ((nextCode >= 48 && nextCode <= 57) ||\n ((nextCode === plus || nextCode === minus) &&\n nextNextCode >= 48 &&\n nextNextCode <= 57))\n ) {\n pos += nextCode === plus || nextCode === minus ? 3 : 2;\n\n while (pos < length) {\n code = value.charCodeAt(pos);\n\n if (code < 48 || code > 57) {\n break;\n }\n\n pos += 1;\n }\n }\n\n return {\n number: value.slice(0, pos),\n unit: value.slice(pos)\n };\n};\n","'use strict';\n\nmodule.exports = function (obj) {\n\tif (typeof obj === 'string') { return camelCase(obj); }\n\treturn walk(obj);\n};\n\nfunction walk(obj) {\n\tif (!obj || typeof obj !== 'object') { return obj; }\n\tif (isDate(obj) || isRegex(obj)) { return obj; }\n\tif (isArray(obj)) { return map(obj, walk); }\n\treturn reduce(objectKeys(obj), function (acc, key) {\n\t\tvar camel = camelCase(key);\n\t\tacc[camel] = walk(obj[key]);\n\t\treturn acc;\n\t}, {});\n}\n\nfunction camelCase(str) {\n\treturn str.replace(/[_.-](\\w|$)/g, function (_, x) {\n\t\treturn x.toUpperCase();\n\t});\n}\n\nvar isArray = Array.isArray || function (obj) {\n\treturn Object.prototype.toString.call(obj) === '[object Array]';\n};\n\nvar isDate = function (obj) {\n\treturn Object.prototype.toString.call(obj) === '[object Date]';\n};\n\nvar isRegex = function (obj) {\n\treturn Object.prototype.toString.call(obj) === '[object RegExp]';\n};\n\nvar has = Object.prototype.hasOwnProperty;\nvar objectKeys = Object.keys || function (obj) {\n\tvar keys = [];\n\tfor (var key in obj) {\n\t\tif (has.call(obj, key)) { keys.push(key); }\n\t}\n\treturn keys;\n};\n\nfunction map(xs, f) {\n\tif (xs.map) { return xs.map(f); }\n\tvar res = [];\n\tfor (var i = 0; i < xs.length; i++) {\n\t\tres.push(f(xs[i], i));\n\t}\n\treturn res;\n}\n\nfunction reduce(xs, f, acc) {\n\tif (xs.reduce) { return xs.reduce(f, acc); }\n\tfor (var i = 0; i < xs.length; i++) {\n\t\tacc = f(acc, xs[i], i);\n\t}\n\treturn acc;\n}\n","'use strict'\n\nmodule.exports = require('./colors.json')\n","{\n \"black\": \"#000000\",\n \"silver\": \"#c0c0c0\",\n \"gray\": \"#808080\",\n \"white\": \"#ffffff\",\n \"maroon\": \"#800000\",\n \"red\": \"#ff0000\",\n \"purple\": \"#800080\",\n \"fuchsia\": \"#ff00ff\",\n \"green\": \"#008000\",\n \"lime\": \"#00ff00\",\n \"olive\": \"#808000\",\n \"yellow\": \"#ffff00\",\n \"navy\": \"#000080\",\n \"blue\": \"#0000ff\",\n \"teal\": \"#008080\",\n \"aqua\": \"#00ffff\",\n \"orange\": \"#ffa500\",\n \"aliceblue\": \"#f0f8ff\",\n \"antiquewhite\": \"#faebd7\",\n \"aquamarine\": \"#7fffd4\",\n \"azure\": \"#f0ffff\",\n \"beige\": \"#f5f5dc\",\n \"bisque\": \"#ffe4c4\",\n \"blanchedalmond\": \"#ffebcd\",\n \"blueviolet\": \"#8a2be2\",\n \"brown\": \"#a52a2a\",\n \"burlywood\": \"#deb887\",\n \"cadetblue\": \"#5f9ea0\",\n \"chartreuse\": \"#7fff00\",\n \"chocolate\": \"#d2691e\",\n \"coral\": \"#ff7f50\",\n \"cornflowerblue\": \"#6495ed\",\n \"cornsilk\": \"#fff8dc\",\n \"crimson\": \"#dc143c\",\n \"darkblue\": \"#00008b\",\n \"darkcyan\": \"#008b8b\",\n \"darkgoldenrod\": \"#b8860b\",\n \"darkgray\": \"#a9a9a9\",\n \"darkgreen\": \"#006400\",\n \"darkgrey\": \"#a9a9a9\",\n \"darkkhaki\": \"#bdb76b\",\n \"darkmagenta\": \"#8b008b\",\n \"darkolivegreen\": \"#556b2f\",\n \"darkorange\": \"#ff8c00\",\n \"darkorchid\": \"#9932cc\",\n \"darkred\": \"#8b0000\",\n \"darksalmon\": \"#e9967a\",\n \"darkseagreen\": \"#8fbc8f\",\n \"darkslateblue\": \"#483d8b\",\n \"darkslategray\": \"#2f4f4f\",\n \"darkslategrey\": \"#2f4f4f\",\n \"darkturquoise\": \"#00ced1\",\n \"darkviolet\": \"#9400d3\",\n \"deeppink\": \"#ff1493\",\n \"deepskyblue\": \"#00bfff\",\n \"dimgray\": \"#696969\",\n \"dimgrey\": \"#696969\",\n \"dodgerblue\": \"#1e90ff\",\n \"firebrick\": \"#b22222\",\n \"floralwhite\": \"#fffaf0\",\n \"forestgreen\": \"#228b22\",\n \"gainsboro\": \"#dcdcdc\",\n \"ghostwhite\": \"#f8f8ff\",\n \"gold\": \"#ffd700\",\n \"goldenrod\": \"#daa520\",\n \"greenyellow\": \"#adff2f\",\n \"grey\": \"#808080\",\n \"honeydew\": \"#f0fff0\",\n \"hotpink\": \"#ff69b4\",\n \"indianred\": \"#cd5c5c\",\n \"indigo\": \"#4b0082\",\n \"ivory\": \"#fffff0\",\n \"khaki\": \"#f0e68c\",\n \"lavender\": \"#e6e6fa\",\n \"lavenderblush\": \"#fff0f5\",\n \"lawngreen\": \"#7cfc00\",\n \"lemonchiffon\": \"#fffacd\",\n \"lightblue\": \"#add8e6\",\n \"lightcoral\": \"#f08080\",\n \"lightcyan\": \"#e0ffff\",\n \"lightgoldenrodyellow\": \"#fafad2\",\n \"lightgray\": \"#d3d3d3\",\n \"lightgreen\": \"#90ee90\",\n \"lightgrey\": \"#d3d3d3\",\n \"lightpink\": \"#ffb6c1\",\n \"lightsalmon\": \"#ffa07a\",\n \"lightseagreen\": \"#20b2aa\",\n \"lightskyblue\": \"#87cefa\",\n \"lightslategray\": \"#778899\",\n \"lightslategrey\": \"#778899\",\n \"lightsteelblue\": \"#b0c4de\",\n \"lightyellow\": \"#ffffe0\",\n \"limegreen\": \"#32cd32\",\n \"linen\": \"#faf0e6\",\n \"mediumaquamarine\": \"#66cdaa\",\n \"mediumblue\": \"#0000cd\",\n \"mediumorchid\": \"#ba55d3\",\n \"mediumpurple\": \"#9370db\",\n \"mediumseagreen\": \"#3cb371\",\n \"mediumslateblue\": \"#7b68ee\",\n \"mediumspringgreen\": \"#00fa9a\",\n \"mediumturquoise\": \"#48d1cc\",\n \"mediumvioletred\": \"#c71585\",\n \"midnightblue\": \"#191970\",\n \"mintcream\": \"#f5fffa\",\n \"mistyrose\": \"#ffe4e1\",\n \"moccasin\": \"#ffe4b5\",\n \"navajowhite\": \"#ffdead\",\n \"oldlace\": \"#fdf5e6\",\n \"olivedrab\": \"#6b8e23\",\n \"orangered\": \"#ff4500\",\n \"orchid\": \"#da70d6\",\n \"palegoldenrod\": \"#eee8aa\",\n \"palegreen\": \"#98fb98\",\n \"paleturquoise\": \"#afeeee\",\n \"palevioletred\": \"#db7093\",\n \"papayawhip\": \"#ffefd5\",\n \"peachpuff\": \"#ffdab9\",\n \"peru\": \"#cd853f\",\n \"pink\": \"#ffc0cb\",\n \"plum\": \"#dda0dd\",\n \"powderblue\": \"#b0e0e6\",\n \"rosybrown\": \"#bc8f8f\",\n \"royalblue\": \"#4169e1\",\n \"saddlebrown\": \"#8b4513\",\n \"salmon\": \"#fa8072\",\n \"sandybrown\": \"#f4a460\",\n \"seagreen\": \"#2e8b57\",\n \"seashell\": \"#fff5ee\",\n \"sienna\": \"#a0522d\",\n \"skyblue\": \"#87ceeb\",\n \"slateblue\": \"#6a5acd\",\n \"slategray\": \"#708090\",\n \"slategrey\": \"#708090\",\n \"snow\": \"#fffafa\",\n \"springgreen\": \"#00ff7f\",\n \"steelblue\": \"#4682b4\",\n \"tan\": \"#d2b48c\",\n \"thistle\": \"#d8bfd8\",\n \"tomato\": \"#ff6347\",\n \"turquoise\": \"#40e0d0\",\n \"violet\": \"#ee82ee\",\n \"wheat\": \"#f5deb3\",\n \"whitesmoke\": \"#f5f5f5\",\n \"yellowgreen\": \"#9acd32\",\n \"rebeccapurple\": \"#663399\"\n}\n","import { CSSProperties } from './processor-types';\n\nexport class ShortMergeRequest {\n public readonly properties: CSSProperties | null;\n constructor(properties: CSSProperties | null) {\n this.properties = properties;\n }\n\n forEach(callback: (record: CSSProperties[number]) => void) {\n this.entries().forEach(callback);\n }\n\n map(callback: (record: CSSProperties[number]) => T) {\n return this.entries().map(callback);\n }\n\n entries() {\n if (this.properties == null) {\n return [];\n }\n return Object.entries(this.properties);\n }\n}\n","import { ShortMergeRequest } from '../ShortMergeRequest';\nimport { GenericCSSPropertyValidator } from './GenericPropertyValidator';\nimport { CSSPropertyModel, ShortCSSPropertyValidatorParams } from './types';\n\nexport abstract class ShortCSSPropertyValidator<\n C extends CSSPropertyModel = any,\n N = any\n> extends GenericCSSPropertyValidator {\n constructor(params: ShortCSSPropertyValidatorParams) {\n super(params, true);\n }\n\n /**\n * Expand a CSS shorthand property to its longhand equivalent.\n *\n * @param value\n */\n abstract normalizeInlineCSSValue(value: string): ShortMergeRequest | null;\n\n /**\n * Expand a React Native shorthand property to its longhand equivalent.\n *\n * @param value\n */\n abstract normalizeNativeValue(value: N): ShortMergeRequest | N | null;\n}\n","import { CSSProcessorConfig } from '../config';\nimport { CSSPropertyModel, CSSPropertyValidatorParams } from './types';\nimport {\n CSSPropertyCompatCategory,\n CSSPropertyDisplayCategory,\n CSSPropertyPropagationCategory,\n CSSPropertySpecs\n} from '../processor-types';\nimport { ShortMergeRequest } from '../ShortMergeRequest';\n\nexport abstract class GenericCSSPropertyValidator<\n C extends CSSPropertyModel = any,\n N = any\n> implements CSSPropertySpecs\n{\n protected readonly model: C;\n protected readonly config: CSSProcessorConfig;\n public readonly compatCategory: CSSPropertyCompatCategory;\n public readonly propagationCategory: CSSPropertyPropagationCategory;\n public readonly displayCategory: CSSPropertyDisplayCategory;\n public readonly propertyName: string;\n private readonly _isShorthand: boolean;\n\n constructor(\n { model, config, propertyName }: CSSPropertyValidatorParams,\n isShorthand: boolean\n ) {\n this.model = model;\n this.config = config;\n this.compatCategory = model.translatable ? 'native' : 'web';\n this.propagationCategory = model.inheritable ? 'flow' : 'retain';\n this.displayCategory = model.display;\n this.propertyName = propertyName;\n this._isShorthand = isShorthand;\n }\n\n /**\n * Normalize value from inline styles\n *\n * @param value\n */\n abstract normalizeInlineCSSValue(\n value: string | N\n ): ShortMergeRequest | N | null;\n\n /**\n * Normalize value from native styles.\n *\n * @param value\n */\n abstract normalizeNativeValue(value: N): ShortMergeRequest | N | null;\n\n isShorthand(): boolean {\n return this._isShorthand;\n }\n}\n","import { ShortMergeRequest } from '../ShortMergeRequest';\nimport { ShortCSSPropertyValidator } from './ShortCSSPropertyValidator';\nimport { CSSPropertyModel, ShortCSSPropertyValidatorParams } from './types';\n\nexport type Directions = {\n top: string;\n bottom: string;\n left: string;\n right: string;\n};\n\nconst WHITESPACE_REGEX = /\\s+/;\n\nexport class ShortCardinalCSSpropertyValidator<\n C extends CSSPropertyModel = any\n> extends ShortCSSPropertyValidator {\n public directions: Readonly;\n constructor(\n params: ShortCSSPropertyValidatorParams,\n /**\n * Top, Right, Bottom, Left\n */\n directions: Readonly\n ) {\n super(params);\n this.directions = directions;\n }\n\n normalizeInlineCSSValue(value: string | number) {\n if (typeof value === 'number') {\n return new ShortMergeRequest({\n [this.directions.top]: value,\n [this.directions.right]: value,\n [this.directions.bottom]: value,\n [this.directions.left]: value\n });\n }\n const values = value.split(WHITESPACE_REGEX);\n if (values.length === 4) {\n return new ShortMergeRequest({\n [this.directions.top]: values[0],\n [this.directions.right]: values[1],\n [this.directions.bottom]: values[2],\n [this.directions.left]: values[3]\n });\n }\n if (values.length === 3) {\n return new ShortMergeRequest({\n [this.directions.top]: values[0],\n [this.directions.right]: values[1],\n [this.directions.bottom]: values[2],\n [this.directions.left]: values[1]\n });\n }\n if (values.length === 2) {\n return new ShortMergeRequest({\n [this.directions.top]: values[0],\n [this.directions.right]: values[1],\n [this.directions.bottom]: values[0],\n [this.directions.left]: values[1]\n });\n }\n if (values.length === 1) {\n return new ShortMergeRequest({\n [this.directions.top]: values[0],\n [this.directions.right]: values[0],\n [this.directions.bottom]: values[0],\n [this.directions.left]: values[0]\n });\n }\n return null;\n }\n\n normalizeNativeValue(value: string | number) {\n return this.normalizeInlineCSSValue(value);\n }\n}\n","import { LongEnumerationCSSPropertyValidator } from './LongEnumerationCSSPropertyValidator';\nimport { CSSPropertyModel } from './types';\n\nconst WHITESPACE_REGEX = /\\s+/;\n\nexport class LongBorderStyleCSSPropertyValidator<\n C extends CSSPropertyModel\n> extends LongEnumerationCSSPropertyValidator {\n normalizeRawInlineCSSValue(value: string): string | null {\n const normalizedVal = this.pickFirst(value);\n return normalizedVal\n ? super.normalizeRawInlineCSSValue(normalizedVal)\n : null;\n }\n\n normalizeNativeValue(value: string) {\n return this.pickFirst(value);\n }\n\n pickFirst(value: string) {\n const values = value.split(WHITESPACE_REGEX);\n return values[0] || null;\n }\n}\n","import { LongCSSPropertyValidator } from './LongCSSPropertyValidator';\nimport { CSSPropertyValidatorParams, CSSPropertyModel } from './types';\n\nexport class LongEnumerationCSSPropertyValidator<\n C extends CSSPropertyModel\n> extends LongCSSPropertyValidator {\n public readonly allowedList: ReadonlyArray;\n constructor(params: CSSPropertyValidatorParams, allowedList: string[]) {\n super(params);\n this.allowedList = allowedList;\n }\n\n normalizeRawInlineCSSValue(v: string): string | null {\n if (this.allowedList.indexOf(v) !== -1) {\n return v;\n }\n return null;\n }\n\n normalizeNativeValue(v: string): string | null {\n return this.normalizeInlineCSSValue(v);\n }\n}\n","import { GenericCSSPropertyValidator } from './GenericPropertyValidator';\nimport { CSSPropertyValidatorParams, CSSPropertyModel } from './types';\n\nexport abstract class LongCSSPropertyValidator<\n C extends CSSPropertyModel = any,\n N = any\n> extends GenericCSSPropertyValidator {\n constructor(params: CSSPropertyValidatorParams) {\n super(params, false);\n }\n\n /**\n * Normalize a rule value from inline CSS styles.\n *\n * @param value - The CSS property value to test.\n * @returns The normalized value, or null if normalization failed.\n */\n normalizeInlineCSSValue(value: N | string): N | null {\n if (typeof value !== 'string') {\n return value;\n }\n return this.normalizeRawInlineCSSValue(value);\n }\n\n abstract normalizeRawInlineCSSValue(value: string): N | null;\n\n /**\n * Normalize a mixed value from a @{link MixedStyleDeclaration}.\n *\n * @param value\n */\n normalizeNativeValue(value: N): N | null {\n return value;\n }\n}\n","import { ShortMergeRequest } from '../ShortMergeRequest';\nimport expandCSSToRN from './expandCSSToRN';\nimport { ShortCSSPropertyValidator } from './ShortCSSPropertyValidator';\nimport { CSSPropertyValidatorParams, CSSPropertyModel } from './types';\n\n/**\n * Flex shorthand property in CSS and React Native differ significantly. This\n * validator must therefore expand this shorthand in a way consistent with the\n * specs for both platforms (native and CSS).\n */\nexport class ShortFlexCSSPropertyValidator extends ShortCSSPropertyValidator<\n CSSPropertyModel,\n number\n> {\n constructor(params: CSSPropertyValidatorParams) {\n super({ ...params, propertyName: 'flex' });\n }\n\n normalizeInlineCSSValue(value: string) {\n return new ShortMergeRequest(expandCSSToRN(this.propertyName, value));\n }\n\n /**\n * In React Native, \"flex\" is not a shorthand property, although it looks\n * like one. There is not always a tuple of (flexGrow, flexShrink,\n * flexBasis) that maps exactly to one single \"flex\" value.\n *\n * For this very reason, it is ill-advised to use \"flex\" shorthand property.\n * Use the longhand equivalent when that is possible.\n *\n * @param value\n */\n normalizeNativeValue(value: number) {\n return value;\n }\n}\n","import { ShortCSSToReactNativeValidator } from './ShortCSSToReactNativeValidator';\nimport normalizeFontName from './normalizeFontName';\nimport { CSSPropertyModel } from './types';\nimport { ShortMergeRequest } from '../ShortMergeRequest';\n\nconst WHITESPACE_REGEX = /\\s+/;\n\nexport class ShortFontCSSValidator<\n C extends CSSPropertyModel\n> extends ShortCSSToReactNativeValidator {\n normalizeInlineCSSValue(value: string): ShortMergeRequest | null {\n // A 'font' declaration may end with a list of multiple font families.\n // We must check support for this list before processing.\n const resp = value.split(',');\n let fontFamily = null;\n if (resp.length === 1) {\n return super.normalizeInlineCSSValue(resp[0]);\n }\n const base = resp.splice(0, 1)[0];\n for (const font of resp) {\n const normalizedFont = normalizeFontName(font);\n const isFontSupported = this.config.isFontSupported(normalizedFont);\n if (isFontSupported) {\n fontFamily =\n typeof isFontSupported === 'string'\n ? isFontSupported\n : normalizedFont;\n break;\n }\n }\n return super.normalizeInlineCSSValue(\n base.split(WHITESPACE_REGEX).slice(0, -1).join(' ') +\n ' ' +\n (fontFamily || 'system')\n );\n }\n}\n","export default function normalizeFontName(fontName: string) {\n return fontName.replace(/[\"']/g, '').trim();\n}\n","import { ShortMergeRequest } from '../ShortMergeRequest';\nimport { ShortCSSPropertyValidator } from './ShortCSSPropertyValidator';\nimport { CSSPropertyModel, ShortCSSPropertyValidatorParams } from './types';\n\nexport class ShortDualNativepropertyValidator<\n C extends CSSPropertyModel = any\n> extends ShortCSSPropertyValidator {\n public directions: [string, string];\n constructor(\n params: ShortCSSPropertyValidatorParams,\n /**\n * First direction, second direction.\n */\n directions: [string, string]\n ) {\n super(params);\n this.directions = directions;\n }\n\n // These properties are only available for native styles.\n normalizeInlineCSSValue() {\n return null;\n }\n\n normalizeNativeValue(value: string | number) {\n return new ShortMergeRequest({\n [this.directions[0]]: value,\n [this.directions[1]]: value\n });\n }\n}\n","import { LongForgivingCSSPropertyValidator } from './LongForgivingCSSPropertyValidator';\nimport { CSSPropertyModel } from './types';\n\nconst COLOR_REGEX = /^(rgb|rgba|hsl|hsla)\\([\\d,%. ]+\\)|[#]?\\w+$/;\n\nexport class LongColorCSSPropertyValidator<\n C extends CSSPropertyModel\n> extends LongForgivingCSSPropertyValidator {\n normalizeRawInlineCSSValue(value: string): string | null {\n return value.match(COLOR_REGEX) ? value : null;\n }\n}\n","import { LongCSSPropertyValidator } from './LongCSSPropertyValidator';\nimport { CSSPropertyModel } from './types';\n\nexport class LongForgivingCSSPropertyValidator<\n C extends CSSPropertyModel\n> extends LongCSSPropertyValidator {\n normalizeRawInlineCSSValue(value: string): string | null {\n return value;\n }\n}\n","import { LongCSSPropertyValidator } from './LongCSSPropertyValidator';\nimport normalizeFontName from './normalizeFontName';\nimport { CSSPropertyModel } from './types';\n\nconst SEPARATOR_REGEX = /,\\s*/;\n\nexport class LongFontFamilyPropertyValidator<\n C extends CSSPropertyModel\n> extends LongCSSPropertyValidator {\n normalizeRawInlineCSSValue(value: string): string | null {\n const values = value.split(SEPARATOR_REGEX);\n for (const font of values) {\n const normalizedFont = normalizeFontName(font);\n const isFontSupported =\n normalizedFont.length && this.config.isFontSupported(normalizedFont);\n if (isFontSupported) {\n return typeof isFontSupported === 'string'\n ? isFontSupported\n : normalizedFont;\n }\n }\n return null;\n }\n normalizeNativeValue(value: string) {\n return this.normalizeInlineCSSValue(value);\n }\n}\n","import { CSSLengthUnit } from '../config';\nimport { lookupRecord } from '../helpers';\nimport { LongSizeCSSPropertyValidator } from './LongSizeCSSPropertyValidator';\nimport { CSSPropertyModel } from './types';\n\nexport class LongFontSizeCSSValidator<\n C extends CSSPropertyModel\n> extends LongSizeCSSPropertyValidator {\n protected computeSize(value: number, unit: CSSLengthUnit) {\n if (unit === '%') {\n return this.computeEmSize(value / 100);\n }\n return super.computeSize(value, unit);\n }\n\n normalizeRawInlineCSSValue(value: string) {\n if (lookupRecord(this.config.absoluteFontSizesPixelMap, value)) {\n return this.config.absoluteFontSizesPixelMap[value];\n }\n if (lookupRecord(this.config.relativeFontSizesCoefficientMap, value)) {\n return this.computeEmSize(\n this.config.relativeFontSizesCoefficientMap[value]\n );\n }\n return super.normalizeRawInlineCSSValue(value);\n }\n\n normalizeNativeValue(value: string | number) {\n return this.normalizeInlineCSSValue(value);\n }\n}\n","export function lookupRecord>(\n record: T,\n key: any\n): key is keyof T {\n const value = record[key];\n return !!value;\n}\n","import { CSSLengthUnit } from '../config';\nimport { LongCSSPropertyValidator } from './LongCSSPropertyValidator';\nimport { CSSPropertyModel } from './types';\n\nexport class LongSizeCSSPropertyValidator<\n C extends CSSPropertyModel\n> extends LongCSSPropertyValidator {\n protected computeSize(\n value: number,\n unit: CSSLengthUnit\n ): number | string | null {\n switch (unit) {\n case '%':\n return `${value}%`;\n case 'px':\n return value;\n case 'cm':\n case 'in':\n case 'mm':\n case 'pc':\n case 'pt':\n return value * this.config.absoluteLengthUnitsMultiplicators[unit];\n case 'em':\n return this.computeEmSize(value);\n case 'ex':\n // This is an approximation.\n return this.computeEmSize(value * 0.63);\n case 'rem':\n return this.config.rootFontSize * value;\n }\n return null;\n }\n\n protected computeEmSize(value: number) {\n return this.config.rootFontSize * value;\n }\n\n protected splitValueAndUnit(value: string): [number, CSSLengthUnit] | null {\n const match =\n /^(\\d*\\.?\\d*)\\s*(cm|mm|in|px|pt|pc|em|ex|ch|rem|vw|vh|vmin|vmax|%)$/g.exec(\n value\n );\n if (match === null) {\n return null;\n }\n return [Number(match[1]), match[2] as CSSLengthUnit];\n }\n\n normalizeRawInlineCSSValue(value: string) {\n if (value === '0') {\n return 0;\n }\n if (value === 'auto') {\n return value;\n }\n const split = this.splitValueAndUnit(value);\n if (split) {\n return this.computeSize(split[0], split[1]);\n }\n return null;\n }\n\n normalizeNativeValue(value: string | number) {\n return this.normalizeInlineCSSValue(value);\n }\n}\n","import { LongCSSPropertyValidator } from './LongCSSPropertyValidator';\nimport { CSSPropertyValidatorParams, CSSPropertyModel } from './types';\n\nconst WHITESPACE_REGEX = /\\s+/;\n\nexport class LongEnumerationListCSSPropertyValidator<\n C extends CSSPropertyModel\n> extends LongCSSPropertyValidator {\n public readonly allowedList: ReadonlyArray;\n constructor(params: CSSPropertyValidatorParams, allowedList: string[]) {\n super(params);\n this.allowedList = allowedList;\n }\n\n normalizeRawInlineCSSValue(value: string): string[] | null {\n const input = value.split(WHITESPACE_REGEX);\n const values: string[] = [];\n for (const item of input) {\n if (this.allowedList.indexOf(item) !== -1) {\n values.push(item);\n }\n }\n return values.length > 0 ? values : null;\n }\n}\n","import { CSSLengthUnit } from '../config';\nimport { LongSizeCSSPropertyValidator } from './LongSizeCSSPropertyValidator';\nimport { CSSPropertyModel } from './types';\n\nexport class LongNonPercentSizeCSSPropertyValidator<\n C extends CSSPropertyModel\n> extends LongSizeCSSPropertyValidator {\n protected computeSize(value: number, unit: CSSLengthUnit) {\n if (unit === '%') {\n return null;\n }\n return super.computeSize(value, unit);\n }\n}\n","import { LongCSSPropertyValidator } from './LongCSSPropertyValidator';\nimport { CSSPropertyModel } from './types';\n\nconst ASPECT_RATIO_REGEX = /^(\\d+)\\/(\\d+)$/;\n\nexport class LongAspectRatioPropertyValidator<\n C extends CSSPropertyModel\n> extends LongCSSPropertyValidator {\n normalizeRawInlineCSSValue(value: string): number | null {\n const match = ASPECT_RATIO_REGEX.exec(value);\n if (match) {\n const ratio = Number(match[1]) / Number(match[2]);\n return Number.isFinite(ratio) ? ratio : null;\n }\n const fallback = Number(value);\n return Number.isNaN(fallback) ? null : fallback;\n }\n\n normalizeNativeValue(value: string | number): number | null {\n return typeof value !== 'string'\n ? value\n : this.normalizeRawInlineCSSValue(value);\n }\n}\n","import { LongCSSPropertyValidator } from './LongCSSPropertyValidator';\nimport { CSSPropertyModel } from './types';\n\nexport class LongFloatNumberCSSPropertyValidator<\n C extends CSSPropertyModel\n> extends LongCSSPropertyValidator {\n normalizeRawInlineCSSValue(value: string): number | null {\n const normalizedVal = Number(value);\n if (Number.isNaN(normalizedVal)) {\n return null;\n }\n return normalizedVal;\n }\n\n normalizeNativeValue(v: string | number): number | null {\n return this.normalizeInlineCSSValue(v);\n }\n}\n","import { lookupRecord } from '../helpers';\nimport { LongNonPercentSizeCSSPropertyValidator } from './LongNonPercentSizeCSSPropertyValidator';\nimport { CSSPropertyModel } from './types';\n\nexport class LongBorderWidthCSSPropertyValidator<\n C extends CSSPropertyModel\n> extends LongNonPercentSizeCSSPropertyValidator {\n normalizeRawInlineCSSValue(value: string) {\n if (lookupRecord(this.config.absoluteBorderWidthsPixelMap, value)) {\n return this.config.absoluteBorderWidthsPixelMap[value];\n }\n return super.normalizeRawInlineCSSValue(value);\n }\n\n normalizeNativeValue(value: string | number) {\n return this.normalizeInlineCSSValue(value);\n }\n}\n","import { CSSPropertyModel } from './types';\nimport { LongCSSPropertyValidator } from './LongCSSPropertyValidator';\nimport expandCSSToRN from './expandCSSToRN';\n\nexport class LongCSSToReactNativeValidator<\n C extends CSSPropertyModel = any\n> extends LongCSSPropertyValidator {\n normalizeRawInlineCSSValue(value: string) {\n const expanded = expandCSSToRN(this.propertyName, value);\n if (expanded) {\n return expanded[this.propertyName];\n }\n return null;\n }\n}\n","import { CSSParseRun } from './CSSParseRun';\nimport { MixedStyleDeclaration } from './CSSProcessor';\nimport { CSSPropertiesValidationRegistry } from './CSSPropertiesValidationRegistry';\nimport { lookupRecord } from './helpers';\nimport {\n ExtraNativeTextStyle,\n NativeDirectionalStyleKeys,\n ExtraNativeLongViewStyleKeys\n} from './native-types';\nimport { CSSPropertySpecs } from './processor-types';\nimport { ShortMergeRequest } from './ShortMergeRequest';\n\nconst nativeDirectionalStyleKeys: Record =\n {\n borderBottomEndRadius: 'block',\n borderBottomStartRadius: 'block',\n borderEndColor: 'block',\n borderEndWidth: 'block',\n borderStartColor: 'block',\n borderStartWidth: 'block',\n borderTopEndRadius: 'block',\n borderTopStartRadius: 'block',\n end: 'block',\n marginEnd: 'block',\n marginStart: 'block',\n paddingEnd: 'block',\n paddingStart: 'block',\n start: 'block'\n };\n\nconst extraLongViewStyles: Record = {\n elevation: 'block',\n overflow: 'block',\n overlayColor: 'block',\n resizeMode: 'block',\n rotation: 'block',\n scaleX: 'block',\n scaleY: 'block',\n shadowColor: 'block',\n shadowOffset: 'block',\n shadowOpacity: 'block',\n shadowRadius: 'block',\n testID: 'block',\n tintColor: 'block',\n transformMatrix: 'block',\n translateX: 'block',\n translateY: 'block'\n};\n\nconst extraTextStyles: Record = {\n includeFontPadding: 'text',\n textAlignVertical: 'text',\n textShadowColor: 'text',\n textShadowOffset: 'text',\n textShadowRadius: 'text',\n writingDirection: 'text'\n};\n\nconst extraStylesRegistry = {\n ...extraTextStyles,\n ...extraLongViewStyles\n};\n\nexport class CSSNativeParseRun extends CSSParseRun {\n private declaration: MixedStyleDeclaration;\n\n constructor(\n declaration: MixedStyleDeclaration,\n registry: CSSPropertiesValidationRegistry\n ) {\n super(registry);\n this.declaration = declaration;\n }\n\n private fillProp(\n key: K,\n value: any\n ): void {\n const validator = this.validationMap.getValidatorForProperty(key);\n if (validator) {\n const normalizedValue = validator.normalizeNativeValue(value);\n if (normalizedValue instanceof ShortMergeRequest) {\n normalizedValue.forEach(([innerKey, innerValue]) => {\n this.fillProp(innerKey as any, innerValue);\n });\n } else {\n // assume longhand merge\n this.processedProps.withProperty(\n key,\n normalizedValue,\n validator as CSSPropertySpecs\n );\n }\n } else if (lookupRecord(extraStylesRegistry, key)) {\n this.processedProps.withProperty(key, value, {\n compatCategory: 'native',\n displayCategory: extraStylesRegistry[key],\n propagationCategory: 'retain'\n });\n } else if (lookupRecord(nativeDirectionalStyleKeys, key)) {\n console.warn(\n `Native style property \"${key}\" is a directional style property. These are not yet supported.`\n );\n } else {\n console.warn(\n `Native style property \"${key}\" is not supported and has been ignored.`\n );\n }\n }\n\n protected fillProcessedProps(): void {\n const declaration = this.declaration;\n for (const key of Object.keys(declaration) as Array<\n keyof MixedStyleDeclaration\n >) {\n this.fillProp(key, this.declaration[key]);\n }\n }\n}\n","import { CSSPropertiesValidationRegistry as CSSPropertiesValidationMap } from './CSSPropertiesValidationRegistry';\nimport { CSSProcessedProps } from './CSSProcessedProps';\n\nexport abstract class CSSParseRun {\n protected validationMap: CSSPropertiesValidationMap;\n protected processedProps: CSSProcessedProps;\n\n constructor(validationMap: CSSPropertiesValidationMap) {\n this.validationMap = validationMap;\n this.processedProps = new CSSProcessedProps();\n }\n\n protected abstract fillProcessedProps(): void;\n\n public exec(): CSSProcessedProps {\n this.fillProcessedProps();\n return this.processedProps;\n }\n}\n","import { getPropertyName } from 'css-to-react-native';\nimport { CSSParseRun } from './CSSParseRun';\nimport { MixedStyleDeclaration } from './CSSProcessor';\nimport { CSSPropertiesValidationRegistry } from './CSSPropertiesValidationRegistry';\nimport { ValidatorsType } from './makepropertiesValidators';\nimport { CSSProperties } from './processor-types';\nimport { ShortMergeRequest } from './ShortMergeRequest';\nimport { LongCSSPropertyValidator } from './validators/LongCSSPropertyValidator';\n\ntype CSSRawPropertiesList = [string, any][];\n\nexport class CSSInlineParseRun extends CSSParseRun {\n private rules: CSSRawPropertiesList;\n\n constructor(inlineCSS: string, registry: CSSPropertiesValidationRegistry) {\n super(registry);\n this.rules = this.parseInlineCSS(inlineCSS);\n this.normalizeProp = this.normalizeProp.bind(this);\n this.reduceProps = this.reduceProps.bind(this);\n }\n\n private parseInlineCSS(inlineCSS: string): CSSRawPropertiesList {\n return inlineCSS\n .split(';')\n .map((prop) => prop.split(':'))\n .reduce((acc, prop) => {\n if (prop.length === 2) {\n return [...acc, [prop[0].trim(), prop[1].trim()]];\n }\n return acc;\n }, []);\n }\n\n normalizeProp(\n rule: CSSRawPropertiesList[number],\n strict = false\n ): null | [keyof ValidatorsType, any] {\n const rawName = rule[0];\n const rawValue = rule[1];\n const camelCaseName = getPropertyName(rawName);\n if (!this.validationMap.shouldRegisterInlineProperty(camelCaseName)) {\n return null;\n }\n const validator = this.validationMap.getValidatorForProperty(camelCaseName);\n const normalizedValue = validator.normalizeInlineCSSValue(rawValue);\n if (normalizedValue === null) {\n if (strict) {\n throw new TypeError();\n }\n return null;\n }\n return [camelCaseName, normalizedValue];\n }\n\n reduceProps(\n reg: CSSProperties,\n rule: null | [keyof ValidatorsType, Exclude]\n ): CSSProperties {\n if (!rule) {\n return reg;\n }\n const [camelCaseName, normalizedValue] = rule;\n if (normalizedValue instanceof ShortMergeRequest) {\n try {\n return normalizedValue\n .map((r) => this.normalizeProp(r, true))\n .reduce(this.reduceProps, reg);\n } catch (e) {\n return reg;\n }\n }\n return {\n ...reg,\n [camelCaseName]: normalizedValue\n };\n }\n\n fillProcessedProps() {\n const rawTransformed = this.rules\n .map((r) => this.normalizeProp(r))\n .reduce(this.reduceProps, {});\n (Object.keys(rawTransformed) as Array).forEach(\n (camelCaseName) => {\n const value = rawTransformed[camelCaseName];\n const validator = this.validationMap.getValidatorForProperty(\n camelCaseName\n ) as LongCSSPropertyValidator;\n const normalizedValue = validator.normalizeInlineCSSValue(value);\n this.processedProps.withProperty(\n camelCaseName as keyof MixedStyleDeclaration,\n normalizedValue,\n validator\n );\n }\n );\n }\n}\n","import {\n CSSLongNativeTranslatableBlockPropKey,\n CSSLongNativeTranslatableTextPropKey\n} from './property-types';\n\nexport type CSSLengthUnit =\n | 'cm'\n | 'mm'\n | 'in'\n | 'px'\n | 'pt'\n | 'pc'\n | 'em'\n | 'ex'\n | 'ch'\n | 'rem'\n | 'vw'\n | 'vh'\n | 'vmin'\n | 'vmax'\n | '%';\n\nexport type CSSHardcodedBorderWidth = 'thin' | 'medium' | 'thick';\n\nexport type CSSAbsoluteLengthUnit = Extract<\n CSSLengthUnit,\n 'in' | 'cm' | 'mm' | 'px' | 'pt' | 'pc'\n>;\n\nexport type CSSRelativeHarcodedFontSize = 'smaller' | 'larger';\n\nexport type CSSAbsoluteHardcodedFontSize =\n | 'xx-small'\n | 'x-small'\n | 'small'\n | 'medium'\n | 'large'\n | 'x-large'\n | 'xx-large';\n\nexport type CSSAbsoluteLengthUnitsMultiplicators = Record<\n Exclude,\n number\n>;\n\nexport type CSSPropertyNameList = Array<\n CSSLongNativeTranslatableBlockPropKey | CSSLongNativeTranslatableTextPropKey\n>;\n\nexport interface CSSProcessorConfig {\n readonly absoluteLengthUnitsMultiplicators: CSSAbsoluteLengthUnitsMultiplicators;\n readonly absoluteBorderWidthsPixelMap: Record<\n CSSHardcodedBorderWidth,\n number\n >;\n readonly relativeFontSizesCoefficientMap: Record<\n CSSRelativeHarcodedFontSize,\n number\n >;\n readonly absoluteFontSizesPixelMap: Record<\n CSSAbsoluteHardcodedFontSize,\n number\n >;\n /**\n * Ignore those properties when compiling inline styles. The names should be\n * camelCased.\n *\n * @remarks As of this version, inline styles are considered 100% safe and\n * predictable, thus this property is generally not advised.\n */\n readonly inlinePropertiesBlacklist: CSSPropertyNameList;\n\n /**\n * Allow those properties when compiling inline styles. The names should be\n * camelCased.\n *\n * @remarks When present, inlinePropertiesBlacklist will be ignored.\n */\n readonly inlinePropertiesWhitelist: CSSPropertyNameList | null;\n\n /**\n * Font size used to compute REM.\n */\n readonly rootFontSize: number;\n\n /**\n * Determine is the provided font is supported on running platform.\n *\n * @param fontName - The name of the font to validate. Any quotes have been removed.\n * @returns `true` when the font is supported on current platform, a string\n * when this font should be mapped to another font (such as monospace →\n * Menlo), false otherwise.\n */\n isFontSupported(fontName: string): boolean | string;\n}\n","import { CSSLongWebTextFlowedPropKey } from './property-types';\n\nexport type CSSProperties = Record;\n/**\n * - *flow* CSS properties will be inherited by children TTree nodes;\n * - *retain* CSS properties will only apply to the TTree node to which it is\n * attached.\n */\nexport type CSSPropertyPropagationCategory = 'flow' | 'retain';\n/**\n * - *text* displays will only affect textual nodes\n * - *block* displays will affect all nodes\n */\nexport type CSSPropertyDisplayCategory = 'text' | 'block';\n/**\n * - *native* properties can be injected in React Native components style prop;\n * - *web* properties are solely used in the transient tree render engine.\n */\nexport type CSSPropertyCompatCategory = 'native' | 'web';\n\nexport type CSSPropagationRegistry = Record<\n CSSPropertyPropagationCategory,\n CSSProperties\n>;\n\nexport type CSSDisplayRegistry = Record<\n CSSPropertyDisplayCategory,\n CSSPropagationRegistry\n>;\n\nexport type CSSListStyleTypePropertyBase =\n | 'none'\n | 'disc'\n | 'circle'\n | 'square'\n | 'decimal'\n | 'cjk-decimal'\n | 'decimal-leading-zero'\n | 'lower-roman'\n | 'upper-roman'\n | 'lower-greek'\n | 'lower-alpha'\n | 'lower-latin'\n | 'upper-alpha'\n | 'upper-latin'\n | 'arabic-indic'\n | 'armenian'\n | 'bengali'\n | 'cambodian'\n | 'cjk-earthly-branch'\n | 'cjk-heavenly-stem'\n | 'cjk-ideographic'\n | 'devanagari'\n | 'ethiopic-numeric'\n | 'georgian'\n | 'gujarati'\n | 'gurmukhi'\n | 'hebrew'\n | 'hiragana'\n | 'hiragana-iroha'\n | 'japanese-formal'\n | 'japanese-informal'\n | 'kannada'\n | 'katakana'\n | 'katakana-iroha'\n | 'khmer'\n | 'korean-hangul-formal'\n | 'korean-hanja-formal'\n | 'korean-hanja-informal'\n | 'lao'\n | 'lower-armenian'\n | 'malayalam'\n | 'mongolian'\n | 'myanmar'\n | 'oriya'\n | 'persian'\n | 'simp-chinese-formal'\n | 'simp-chinese-informal'\n | 'tamil'\n | 'telugu'\n | 'thai'\n | 'tibetan'\n | 'trad-chinese-formal'\n | 'trad-chinese-informal'\n | 'upper-armenian'\n | 'disclosure-open'\n | 'disclosure-closed';\n\nexport interface WebTextFlowProperties\n extends Partial> {\n whiteSpace?: 'normal' | 'pre';\n listStyleType?: CSSListStyleTypePropertyBase | string;\n}\n\nexport interface WebBlockRetainProperties {\n objectFit?: 'contain' | 'cover' | 'fill' | 'none' | 'scale-down';\n}\n\nexport interface CSSPropertySpecs<\n C extends CSSPropertyCompatCategory = CSSPropertyCompatCategory,\n D extends CSSPropertyDisplayCategory = CSSPropertyDisplayCategory,\n P extends CSSPropertyPropagationCategory = CSSPropertyPropagationCategory\n> {\n readonly compatCategory: C;\n readonly displayCategory: D;\n readonly propagationCategory: P;\n}\n","import { TextStyle, ViewStyle } from 'react-native';\nimport {\n StandardLonghandProperties,\n StandardShorthandProperties\n} from 'csstype';\n\n// To translate manually\n// borderBottom, borderLeft, borderRight, borderTop\n// borderStyle, overflow, placeItems, placeSelf,\n// textEmphasis\n\n/**\n * React Native style keys which are exclusive to TextStyle.\n */\nexport type NativeTextStyleKey = Exclude;\n\n/**\n * Shorthand properties.\n * These properties will be pre-translated with css-to-react-native.\n * These properties are not considered \"native, web, flow ... etc\" because\n * they won't be translated per-se.\n */\nexport type CSSShortPropsKey = Extract<\n keyof StandardShorthandProperties,\n | 'background'\n | 'border'\n | 'borderColor'\n | 'borderRadius'\n | 'borderWidth'\n | 'flex'\n | 'flexFlow'\n | 'font'\n | 'margin'\n | 'padding'\n | 'textDecoration'\n>;\n\n/**\n * Flowed properties.\n * Such properties propagate recursively to children nodes.\n */\nexport type CSSFlowedPropKey = Extract<\n keyof StandardLonghandProperties,\n | 'borderCollapse'\n | 'borderSpacing'\n | 'captionSide'\n | 'color'\n | 'cursor'\n | 'direction'\n | 'emptyCells'\n | 'fontFamily'\n | 'fontSize'\n | 'fontStyle'\n | 'fontVariant'\n | 'fontWeight'\n | 'font'\n | 'letterSpacing'\n | 'lineHeight'\n | 'listStyleImage'\n | 'listStylePosition'\n | 'listStyleType'\n | 'listStyle'\n | 'orphans'\n | 'quotes'\n | 'textAlign'\n | 'textIndent'\n | 'textTransform'\n | 'visibility'\n | 'whiteSpace'\n | 'listStyleType'\n | 'widows'\n | 'wordSpacing'\n>;\n\n/**\n * Long, Native Text properties\n */\nexport type CSSLongNativeTextPropKey = Extract<\n keyof StandardLonghandProperties,\n NativeTextStyleKey\n>;\n\n/**\n * Long, Native-untranslatable, Text properties\n */\nexport type CSSLongNativeUntranslatableTextPropKey = never;\n\n/**\n * Long, Native-translatable, Text properties\n */\nexport type CSSLongNativeTranslatableTextPropKey = Exclude<\n CSSLongNativeTextPropKey,\n CSSLongNativeUntranslatableTextPropKey\n>;\n\n/**\n * Long, Native-translatable, Text, Flowed properties\n */\nexport type CSSLongNativeTranslatableTextFlowedPropKey = Extract<\n CSSLongNativeTextPropKey,\n CSSFlowedPropKey\n>;\n\n/**\n * Long, Native-translatable, Text, Retained properties\n */\nexport type CSSLongNativeTranslatableTextRetainedPropKey = Exclude<\n CSSLongNativeTextPropKey,\n CSSFlowedPropKey\n>;\n\n/**\n * Long, Native-untranslatable, Text Retained properties\n */\nexport type CSSLongNativeUntranslatableTextRetainedPropKey = Exclude<\n CSSLongNativeUntranslatableTextPropKey,\n CSSFlowedPropKey\n>;\n/**\n * Long, Native-untranslatable, Text Flowed properties\n */\nexport type CSSLongNativeUntranslatableTextFlowedPropKey = Extract<\n CSSLongNativeUntranslatableTextPropKey,\n CSSFlowedPropKey\n>;\n\n/**\n * Long, Web, Text Flowed properties\n */\nexport type CSSLongWebTextFlowedPropKey = Extract<\n keyof StandardLonghandProperties,\n 'whiteSpace' | 'listStyleType' | 'userSelect'\n>;\n\n/**\n * Long, Web, Text Retained properties\n */\nexport type CSSLongWebTextRetainedPropKey = Extract<\n keyof StandardLonghandProperties,\n never\n>;\n\n/**\n * Short, Text properties\n */\nexport type CSSShortTextPropKey = Extract<\n CSSShortPropsKey,\n 'textDecoration' | 'font'\n>;\n\n/**\n * Short, Block properties\n */\nexport type CSSShortBlockPropKey = Exclude<\n CSSShortPropsKey,\n CSSShortTextPropKey\n>;\n\n/**\n * Short, Native-translatable, Block properties\n */\nexport type CSSShortNativeTranslatableBlockPropKey = Exclude<\n CSSShortPropsKey,\n CSSShortTextPropKey\n>;\n\n/**\n * Long, Native, Block properties\n */\nexport type CSSLongNativeBlockPropKey = Extract<\n keyof StandardLonghandProperties | 'borderStyle',\n keyof ViewStyle\n>;\n\n/**\n * Long, Native-translatable, Block properties\n */\nexport type CSSLongNativeTranslatableBlockPropKey = Exclude<\n CSSLongNativeBlockPropKey,\n CSSLongNativeUntranslatableBlockPropKey\n>;\n\n/**\n * Long, Native-untranslatable, Block properties\n */\nexport type CSSLongNativeUntranslatableBlockPropKey = Extract<\n CSSLongNativeBlockPropKey,\n 'position'\n>;\n/**\n * Long, Native-untranslatable, Block, Flowed properties\n */\nexport type CSSLongNativeUntranslatableBlockFlowedPropKey = Extract<\n CSSLongNativeUntranslatableBlockPropKey,\n CSSFlowedPropKey\n>;\n/**\n * Long, Native-untranslatable, Block, Retained properties\n */\nexport type CSSLongNativeUntranslatableBlockRetainedPropKey = Exclude<\n CSSLongNativeUntranslatableBlockPropKey,\n CSSFlowedPropKey\n>;\n\n/**\n * Long, Native-translatable, Block, Flowed properties\n */\nexport type CSSLongNativeTranslatableBlockFlowedPropKey = Extract<\n CSSLongNativeTranslatableBlockPropKey,\n CSSFlowedPropKey\n>;\n\n/**\n * Long, Native-translatable, Block, Retained properties\n */\nexport type CSSLongNativeTranslatableBlockRetainedPropKey = Exclude<\n CSSLongNativeTranslatableBlockPropKey,\n CSSFlowedPropKey\n>;\n\n/**\n * Native properties\n */\nexport type CSSNativePropKey =\n | CSSLongNativeTextPropKey\n | CSSLongNativeBlockPropKey\n | CSSShortPropsKey;\n","import { ImageStyle, TextStyle, ViewStyle } from 'react-native';\nimport {\n CSSLongNativeBlockPropKey,\n CSSLongNativeTextPropKey,\n NativeTextStyleKey,\n CSSShortPropsKey,\n CSSLongNativeUntranslatableBlockPropKey\n} from './property-types';\n\nexport type ExtendedNativeViewStyleKeys = keyof ViewStyle | keyof ImageStyle;\n\nexport type NativeDirectionalStyleKeys = Extract<\n ExtendedNativeViewStyleKeys,\n | 'borderBottomEndRadius'\n | 'borderBottomStartRadius'\n | 'borderTopEndRadius'\n | 'borderTopStartRadius'\n | 'borderEndColor'\n | 'borderEndWidth'\n | 'borderStartColor'\n | 'borderStartWidth'\n | 'marginEnd'\n | 'marginStart'\n | 'paddingEnd'\n | 'paddingStart'\n | 'start'\n | 'end'\n>;\n\nexport type ExtraNativeShortViewStyleKeys = Extract<\n ExtendedNativeViewStyleKeys,\n | 'marginHorizontal'\n | 'marginVertical'\n | 'paddingHorizontal'\n | 'paddingVertical'\n>;\n\nexport type ExtraNativeShortStyle = Pick<\n TextStyle & ViewStyle,\n ExtraNativeShortViewStyleKeys | NativeShortKeys\n>;\n\nexport type ExtraNativeUntranslatedLongStyles = Pick<\n ViewStyle,\n CSSLongNativeUntranslatableBlockPropKey\n>;\n\n/**\n * Extraneous React Native ViewStyle keys.\n */\nexport type ExtraNativeLongViewStyleKeys = Exclude<\n Exclude,\n | CSSLongNativeBlockPropKey\n | NativeDirectionalStyleKeys\n | ExtraNativeShortViewStyleKeys\n>;\n\n/**\n * Native Short keys.\n */\nexport type NativeShortKeys = Extract<\n CSSShortPropsKey,\n NativeTextStyleKey | keyof ViewStyle\n>;\n\n/**\n * Extraneous longhand React Native TextStyle keys.\n */\nexport type ExtraNativeTextStyleKeys = Exclude<\n Exclude,\n CSSLongNativeTextPropKey\n>;\n\nexport type ExtraNativeTextStyle = Partial<\n Pick\n>;\n\nexport type ExtraNativeViewStyle = Partial<\n Pick<\n ViewStyle & ImageStyle,\n ExtraNativeLongViewStyleKeys | ExtraNativeShortViewStyleKeys\n >\n>;\n","import { CSSProperties, CSSProcessedProps } from '@native-html/css-processor';\nimport nil from 'ramda/src/isNil';\nimport not from 'ramda/src/not';\nimport compose from 'ramda/src/compose';\n\nconst notNil = compose(not, nil);\n/**\n * A merge properties from left to right.\n *\n * @param child\n * @param parent\n */\nfunction inheritProperties(\n ...properties: Array\n): CSSProperties {\n const realProperties = properties.filter(notNil) as CSSProperties[];\n if (realProperties.length === 1) {\n return realProperties[0];\n }\n if (Object.keys(realProperties[0]).length === 0) {\n return realProperties[1];\n }\n return realProperties.reduce(\n (prev, curr) => ({ ...prev, ...curr }),\n Object.prototype as CSSProperties\n ) as CSSProperties;\n}\n\n/**\n * A record of styles organized in logical chunks:\n *\n * - wether they are supported in React Native (native) and others (web).\n * - wether they target native Views (block) or Text (text).\n * - wether they are inherited by this node's children (flow) or not (retain).\n *\n * @public\n */\nexport interface TStylesShape {\n readonly nativeTextFlow: CSSProcessedProps['native']['text']['flow'];\n readonly nativeBlockFlow: CSSProcessedProps['native']['block']['flow'];\n readonly nativeTextRet: CSSProcessedProps['native']['text']['retain'];\n readonly nativeBlockRet: CSSProcessedProps['native']['block']['retain'];\n readonly webTextFlow: CSSProcessedProps['web']['text']['flow'];\n readonly webBlockRet: CSSProcessedProps['web']['block']['retain'];\n}\n\nexport class TStyles implements TStylesShape {\n public readonly nativeTextFlow: CSSProcessedProps['native']['text']['flow'];\n public readonly nativeBlockFlow: CSSProcessedProps['native']['block']['flow'];\n public readonly nativeTextRet: CSSProcessedProps['native']['text']['retain'];\n public readonly nativeBlockRet: CSSProcessedProps['native']['block']['retain'];\n public readonly webTextFlow: CSSProcessedProps['web']['text']['flow'];\n public readonly webBlockRet: CSSProcessedProps['web']['block']['retain'];\n\n constructor(\n ownProcessedProps: CSSProcessedProps,\n parentStyles?: TStyles | null\n ) {\n this.nativeTextFlow = inheritProperties(\n parentStyles?.nativeTextFlow,\n ownProcessedProps.native.text.flow\n );\n this.nativeBlockFlow = inheritProperties(\n parentStyles?.nativeBlockFlow,\n ownProcessedProps.native.block.flow\n );\n this.webTextFlow = inheritProperties(\n parentStyles?.webTextFlow,\n ownProcessedProps.web.text.flow\n );\n // In theory, we shouldn't merge those properties. However, these\n // properties being textDecoration*, we actually want children nodes to\n // inherit from them. A cleaner solution would be to to let each TNode\n // handle its merging logic, because only TPhrasing and TText nodes would\n // need to merge these.\n this.nativeTextRet = inheritProperties(\n parentStyles?.nativeTextRet,\n ownProcessedProps.native.text.retain\n );\n this.nativeBlockRet = ownProcessedProps.native.block.retain;\n this.webBlockRet = ownProcessedProps.web.block.retain;\n }\n\n static empty(): TStyles {\n return new TStyles(new CSSProcessedProps());\n }\n}\n","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n/**\n * Checks if the input value is `null` or `undefined`.\n *\n * @func\n * @memberOf R\n * @since v0.9.0\n * @category Type\n * @sig * -> Boolean\n * @param {*} x The value to test.\n * @return {Boolean} `true` if `x` is `undefined` or `null`, otherwise `false`.\n * @example\n *\n * R.isNil(null); //=> true\n * R.isNil(undefined); //=> true\n * R.isNil(0); //=> false\n * R.isNil([]); //=> false\n */\n\n\nvar isNil =\n/*#__PURE__*/\n_curry1(function isNil(x) {\n return x == null;\n});\n\nmodule.exports = isNil;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n/**\n * A function that returns the `!` of its argument. It will return `true` when\n * passed false-y value, and `false` when passed a truth-y one.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Logic\n * @sig * -> Boolean\n * @param {*} a any value\n * @return {Boolean} the logical inverse of passed argument.\n * @see R.complement\n * @example\n *\n * R.not(true); //=> false\n * R.not(false); //=> true\n * R.not(0); //=> true\n * R.not(1); //=> false\n */\n\n\nvar not =\n/*#__PURE__*/\n_curry1(function not(a) {\n return !a;\n});\n\nmodule.exports = not;","var pipe =\n/*#__PURE__*/\nrequire(\"./pipe\");\n\nvar reverse =\n/*#__PURE__*/\nrequire(\"./reverse\");\n/**\n * Performs right-to-left function composition. The last argument may have\n * any arity; the remaining arguments must be unary.\n *\n * **Note:** The result of compose is not automatically curried.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Function\n * @sig ((y -> z), (x -> y), ..., (o -> p), ((a, b, ..., n) -> o)) -> ((a, b, ..., n) -> z)\n * @param {...Function} ...functions The functions to compose\n * @return {Function}\n * @see R.pipe\n * @example\n *\n * const classyGreeting = (firstName, lastName) => \"The name's \" + lastName + \", \" + firstName + \" \" + lastName\n * const yellGreeting = R.compose(R.toUpper, classyGreeting);\n * yellGreeting('James', 'Bond'); //=> \"THE NAME'S BOND, JAMES BOND\"\n *\n * R.compose(Math.abs, R.add(1), R.multiply(2))(-4) //=> 7\n *\n * @symb R.compose(f, g, h)(a, b) = f(g(h(a, b)))\n */\n\n\nfunction compose() {\n if (arguments.length === 0) {\n throw new Error('compose requires at least one argument');\n }\n\n return pipe.apply(this, reverse(arguments));\n}\n\nmodule.exports = compose;","var _arity =\n/*#__PURE__*/\nrequire(\"./internal/_arity\");\n\nvar _pipe =\n/*#__PURE__*/\nrequire(\"./internal/_pipe\");\n\nvar reduce =\n/*#__PURE__*/\nrequire(\"./reduce\");\n\nvar tail =\n/*#__PURE__*/\nrequire(\"./tail\");\n/**\n * Performs left-to-right function composition. The first argument may have\n * any arity; the remaining arguments must be unary.\n *\n * In some libraries this function is named `sequence`.\n *\n * **Note:** The result of pipe is not automatically curried.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Function\n * @sig (((a, b, ..., n) -> o), (o -> p), ..., (x -> y), (y -> z)) -> ((a, b, ..., n) -> z)\n * @param {...Function} functions\n * @return {Function}\n * @see R.compose\n * @example\n *\n * const f = R.pipe(Math.pow, R.negate, R.inc);\n *\n * f(3, 4); // -(3^4) + 1\n * @symb R.pipe(f, g, h)(a, b) = h(g(f(a, b)))\n */\n\n\nfunction pipe() {\n if (arguments.length === 0) {\n throw new Error('pipe requires at least one argument');\n }\n\n return _arity(arguments[0].length, reduce(_pipe, arguments[0], tail(arguments)));\n}\n\nmodule.exports = pipe;","function _arity(n, fn) {\n /* eslint-disable no-unused-vars */\n switch (n) {\n case 0:\n return function () {\n return fn.apply(this, arguments);\n };\n\n case 1:\n return function (a0) {\n return fn.apply(this, arguments);\n };\n\n case 2:\n return function (a0, a1) {\n return fn.apply(this, arguments);\n };\n\n case 3:\n return function (a0, a1, a2) {\n return fn.apply(this, arguments);\n };\n\n case 4:\n return function (a0, a1, a2, a3) {\n return fn.apply(this, arguments);\n };\n\n case 5:\n return function (a0, a1, a2, a3, a4) {\n return fn.apply(this, arguments);\n };\n\n case 6:\n return function (a0, a1, a2, a3, a4, a5) {\n return fn.apply(this, arguments);\n };\n\n case 7:\n return function (a0, a1, a2, a3, a4, a5, a6) {\n return fn.apply(this, arguments);\n };\n\n case 8:\n return function (a0, a1, a2, a3, a4, a5, a6, a7) {\n return fn.apply(this, arguments);\n };\n\n case 9:\n return function (a0, a1, a2, a3, a4, a5, a6, a7, a8) {\n return fn.apply(this, arguments);\n };\n\n case 10:\n return function (a0, a1, a2, a3, a4, a5, a6, a7, a8, a9) {\n return fn.apply(this, arguments);\n };\n\n default:\n throw new Error('First argument to _arity must be a non-negative integer no greater than ten');\n }\n}\n\nmodule.exports = _arity;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n\nvar _reduce =\n/*#__PURE__*/\nrequire(\"./internal/_reduce\");\n/**\n * Returns a single item by iterating through the list, successively calling\n * the iterator function and passing it an accumulator value and the current\n * value from the array, and then passing the result to the next call.\n *\n * The iterator function receives two values: *(acc, value)*. It may use\n * [`R.reduced`](#reduced) to shortcut the iteration.\n *\n * The arguments' order of [`reduceRight`](#reduceRight)'s iterator function\n * is *(value, acc)*.\n *\n * Note: `R.reduce` does not skip deleted or unassigned indices (sparse\n * arrays), unlike the native `Array.prototype.reduce` method. For more details\n * on this behavior, see:\n * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reduce#Description\n *\n * Dispatches to the `reduce` method of the third argument, if present. When\n * doing so, it is up to the user to handle the [`R.reduced`](#reduced)\n * shortcuting, as this is not implemented by `reduce`.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category List\n * @sig ((a, b) -> a) -> a -> [b] -> a\n * @param {Function} fn The iterator function. Receives two values, the accumulator and the\n * current element from the array.\n * @param {*} acc The accumulator value.\n * @param {Array} list The list to iterate over.\n * @return {*} The final, accumulated value.\n * @see R.reduced, R.addIndex, R.reduceRight\n * @example\n *\n * R.reduce(R.subtract, 0, [1, 2, 3, 4]) // => ((((0 - 1) - 2) - 3) - 4) = -10\n * // - -10\n * // / \\ / \\\n * // - 4 -6 4\n * // / \\ / \\\n * // - 3 ==> -3 3\n * // / \\ / \\\n * // - 2 -1 2\n * // / \\ / \\\n * // 0 1 0 1\n *\n * @symb R.reduce(f, a, [b, c, d]) = f(f(f(a, b), c), d)\n */\n\n\nvar reduce =\n/*#__PURE__*/\n_curry3(_reduce);\n\nmodule.exports = reduce;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./_curry1\");\n\nvar _curry2 =\n/*#__PURE__*/\nrequire(\"./_curry2\");\n\nvar _isPlaceholder =\n/*#__PURE__*/\nrequire(\"./_isPlaceholder\");\n/**\n * Optimized internal three-arity curry function.\n *\n * @private\n * @category Function\n * @param {Function} fn The function to curry.\n * @return {Function} The curried function.\n */\n\n\nfunction _curry3(fn) {\n return function f3(a, b, c) {\n switch (arguments.length) {\n case 0:\n return f3;\n\n case 1:\n return _isPlaceholder(a) ? f3 : _curry2(function (_b, _c) {\n return fn(a, _b, _c);\n });\n\n case 2:\n return _isPlaceholder(a) && _isPlaceholder(b) ? f3 : _isPlaceholder(a) ? _curry2(function (_a, _c) {\n return fn(_a, b, _c);\n }) : _isPlaceholder(b) ? _curry2(function (_b, _c) {\n return fn(a, _b, _c);\n }) : _curry1(function (_c) {\n return fn(a, b, _c);\n });\n\n default:\n return _isPlaceholder(a) && _isPlaceholder(b) && _isPlaceholder(c) ? f3 : _isPlaceholder(a) && _isPlaceholder(b) ? _curry2(function (_a, _b) {\n return fn(_a, _b, c);\n }) : _isPlaceholder(a) && _isPlaceholder(c) ? _curry2(function (_a, _c) {\n return fn(_a, b, _c);\n }) : _isPlaceholder(b) && _isPlaceholder(c) ? _curry2(function (_b, _c) {\n return fn(a, _b, _c);\n }) : _isPlaceholder(a) ? _curry1(function (_a) {\n return fn(_a, b, c);\n }) : _isPlaceholder(b) ? _curry1(function (_b) {\n return fn(a, _b, c);\n }) : _isPlaceholder(c) ? _curry1(function (_c) {\n return fn(a, b, _c);\n }) : fn(a, b, c);\n }\n };\n}\n\nmodule.exports = _curry3;","var _isArrayLike =\n/*#__PURE__*/\nrequire(\"./_isArrayLike\");\n\nvar _xwrap =\n/*#__PURE__*/\nrequire(\"./_xwrap\");\n\nvar bind =\n/*#__PURE__*/\nrequire(\"../bind\");\n\nfunction _arrayReduce(xf, acc, list) {\n var idx = 0;\n var len = list.length;\n\n while (idx < len) {\n acc = xf['@@transducer/step'](acc, list[idx]);\n\n if (acc && acc['@@transducer/reduced']) {\n acc = acc['@@transducer/value'];\n break;\n }\n\n idx += 1;\n }\n\n return xf['@@transducer/result'](acc);\n}\n\nfunction _iterableReduce(xf, acc, iter) {\n var step = iter.next();\n\n while (!step.done) {\n acc = xf['@@transducer/step'](acc, step.value);\n\n if (acc && acc['@@transducer/reduced']) {\n acc = acc['@@transducer/value'];\n break;\n }\n\n step = iter.next();\n }\n\n return xf['@@transducer/result'](acc);\n}\n\nfunction _methodReduce(xf, acc, obj, methodName) {\n return xf['@@transducer/result'](obj[methodName](bind(xf['@@transducer/step'], xf), acc));\n}\n\nvar symIterator = typeof Symbol !== 'undefined' ? Symbol.iterator : '@@iterator';\n\nfunction _reduce(fn, acc, list) {\n if (typeof fn === 'function') {\n fn = _xwrap(fn);\n }\n\n if (_isArrayLike(list)) {\n return _arrayReduce(fn, acc, list);\n }\n\n if (typeof list['fantasy-land/reduce'] === 'function') {\n return _methodReduce(fn, acc, list, 'fantasy-land/reduce');\n }\n\n if (list[symIterator] != null) {\n return _iterableReduce(fn, acc, list[symIterator]());\n }\n\n if (typeof list.next === 'function') {\n return _iterableReduce(fn, acc, list);\n }\n\n if (typeof list.reduce === 'function') {\n return _methodReduce(fn, acc, list, 'reduce');\n }\n\n throw new TypeError('reduce: list must be array or iterable');\n}\n\nmodule.exports = _reduce;","var _arity =\n/*#__PURE__*/\nrequire(\"./internal/_arity\");\n\nvar _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Creates a function that is bound to a context.\n * Note: `R.bind` does not provide the additional argument-binding capabilities of\n * [Function.prototype.bind](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Function/bind).\n *\n * @func\n * @memberOf R\n * @since v0.6.0\n * @category Function\n * @category Object\n * @sig (* -> *) -> {*} -> (* -> *)\n * @param {Function} fn The function to bind to context\n * @param {Object} thisObj The context to bind `fn` to\n * @return {Function} A function that will execute in the context of `thisObj`.\n * @see R.partial\n * @example\n *\n * const log = R.bind(console.log, console);\n * R.pipe(R.assoc('a', 2), R.tap(log), R.assoc('a', 3))({a: 1}); //=> {a: 3}\n * // logs {a: 2}\n * @symb R.bind(f, o)(a, b) = f.call(o, a, b)\n */\n\n\nvar bind =\n/*#__PURE__*/\n_curry2(function bind(fn, thisObj) {\n return _arity(fn.length, function () {\n return fn.apply(thisObj, arguments);\n });\n});\n\nmodule.exports = bind;","var XWrap =\n/*#__PURE__*/\nfunction () {\n function XWrap(fn) {\n this.f = fn;\n }\n\n XWrap.prototype['@@transducer/init'] = function () {\n throw new Error('init not implemented on XWrap');\n };\n\n XWrap.prototype['@@transducer/result'] = function (acc) {\n return acc;\n };\n\n XWrap.prototype['@@transducer/step'] = function (acc, x) {\n return this.f(acc, x);\n };\n\n return XWrap;\n}();\n\nfunction _xwrap(fn) {\n return new XWrap(fn);\n}\n\nmodule.exports = _xwrap;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./_curry1\");\n\nvar _isArray =\n/*#__PURE__*/\nrequire(\"./_isArray\");\n\nvar _isString =\n/*#__PURE__*/\nrequire(\"./_isString\");\n/**\n * Tests whether or not an object is similar to an array.\n *\n * @private\n * @category Type\n * @category List\n * @sig * -> Boolean\n * @param {*} x The object to test.\n * @return {Boolean} `true` if `x` has a numeric length property and extreme indices defined; `false` otherwise.\n * @example\n *\n * _isArrayLike([]); //=> true\n * _isArrayLike(true); //=> false\n * _isArrayLike({}); //=> false\n * _isArrayLike({length: 10}); //=> false\n * _isArrayLike({0: 'zero', 9: 'nine', length: 10}); //=> true\n */\n\n\nvar _isArrayLike =\n/*#__PURE__*/\n_curry1(function isArrayLike(x) {\n if (_isArray(x)) {\n return true;\n }\n\n if (!x) {\n return false;\n }\n\n if (typeof x !== 'object') {\n return false;\n }\n\n if (_isString(x)) {\n return false;\n }\n\n if (x.nodeType === 1) {\n return !!x.length;\n }\n\n if (x.length === 0) {\n return true;\n }\n\n if (x.length > 0) {\n return x.hasOwnProperty(0) && x.hasOwnProperty(x.length - 1);\n }\n\n return false;\n});\n\nmodule.exports = _isArrayLike;","/**\n * Tests whether or not an object is an array.\n *\n * @private\n * @param {*} val The object to test.\n * @return {Boolean} `true` if `val` is an array, `false` otherwise.\n * @example\n *\n * _isArray([]); //=> true\n * _isArray(null); //=> false\n * _isArray({}); //=> false\n */\nmodule.exports = Array.isArray || function _isArray(val) {\n return val != null && val.length >= 0 && Object.prototype.toString.call(val) === '[object Array]';\n};","function _isString(x) {\n return Object.prototype.toString.call(x) === '[object String]';\n}\n\nmodule.exports = _isString;","function _pipe(f, g) {\n return function () {\n return g.call(this, f.apply(this, arguments));\n };\n}\n\nmodule.exports = _pipe;","var _checkForMethod =\n/*#__PURE__*/\nrequire(\"./internal/_checkForMethod\");\n\nvar _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar slice =\n/*#__PURE__*/\nrequire(\"./slice\");\n/**\n * Returns all but the first element of the given list or string (or object\n * with a `tail` method).\n *\n * Dispatches to the `slice` method of the first argument, if present.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category List\n * @sig [a] -> [a]\n * @sig String -> String\n * @param {*} list\n * @return {*}\n * @see R.head, R.init, R.last\n * @example\n *\n * R.tail([1, 2, 3]); //=> [2, 3]\n * R.tail([1, 2]); //=> [2]\n * R.tail([1]); //=> []\n * R.tail([]); //=> []\n *\n * R.tail('abc'); //=> 'bc'\n * R.tail('ab'); //=> 'b'\n * R.tail('a'); //=> ''\n * R.tail(''); //=> ''\n */\n\n\nvar tail =\n/*#__PURE__*/\n_curry1(\n/*#__PURE__*/\n_checkForMethod('tail',\n/*#__PURE__*/\nslice(1, Infinity)));\n\nmodule.exports = tail;","var _isArray =\n/*#__PURE__*/\nrequire(\"./_isArray\");\n/**\n * This checks whether a function has a [methodname] function. If it isn't an\n * array it will execute that function otherwise it will default to the ramda\n * implementation.\n *\n * @private\n * @param {Function} fn ramda implemtation\n * @param {String} methodname property to check for a custom implementation\n * @return {Object} Whatever the return value of the method is.\n */\n\n\nfunction _checkForMethod(methodname, fn) {\n return function () {\n var length = arguments.length;\n\n if (length === 0) {\n return fn();\n }\n\n var obj = arguments[length - 1];\n return _isArray(obj) || typeof obj[methodname] !== 'function' ? fn.apply(this, arguments) : obj[methodname].apply(obj, Array.prototype.slice.call(arguments, 0, length - 1));\n };\n}\n\nmodule.exports = _checkForMethod;","var _checkForMethod =\n/*#__PURE__*/\nrequire(\"./internal/_checkForMethod\");\n\nvar _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n/**\n * Returns the elements of the given list or string (or object with a `slice`\n * method) from `fromIndex` (inclusive) to `toIndex` (exclusive).\n *\n * Dispatches to the `slice` method of the third argument, if present.\n *\n * @func\n * @memberOf R\n * @since v0.1.4\n * @category List\n * @sig Number -> Number -> [a] -> [a]\n * @sig Number -> Number -> String -> String\n * @param {Number} fromIndex The start index (inclusive).\n * @param {Number} toIndex The end index (exclusive).\n * @param {*} list\n * @return {*}\n * @example\n *\n * R.slice(1, 3, ['a', 'b', 'c', 'd']); //=> ['b', 'c']\n * R.slice(1, Infinity, ['a', 'b', 'c', 'd']); //=> ['b', 'c', 'd']\n * R.slice(0, -1, ['a', 'b', 'c', 'd']); //=> ['a', 'b', 'c']\n * R.slice(-3, -1, ['a', 'b', 'c', 'd']); //=> ['b', 'c']\n * R.slice(0, 3, 'ramda'); //=> 'ram'\n */\n\n\nvar slice =\n/*#__PURE__*/\n_curry3(\n/*#__PURE__*/\n_checkForMethod('slice', function slice(fromIndex, toIndex, list) {\n return Array.prototype.slice.call(list, fromIndex, toIndex);\n}));\n\nmodule.exports = slice;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar _isString =\n/*#__PURE__*/\nrequire(\"./internal/_isString\");\n/**\n * Returns a new list or string with the elements or characters in reverse\n * order.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category List\n * @sig [a] -> [a]\n * @sig String -> String\n * @param {Array|String} list\n * @return {Array|String}\n * @example\n *\n * R.reverse([1, 2, 3]); //=> [3, 2, 1]\n * R.reverse([1, 2]); //=> [2, 1]\n * R.reverse([1]); //=> [1]\n * R.reverse([]); //=> []\n *\n * R.reverse('abc'); //=> 'cba'\n * R.reverse('ab'); //=> 'ba'\n * R.reverse('a'); //=> 'a'\n * R.reverse(''); //=> ''\n */\n\n\nvar reverse =\n/*#__PURE__*/\n_curry1(function reverse(list) {\n return _isString(list) ? list.split('').reverse().join('') : Array.prototype.slice.call(list, 0).reverse();\n});\n\nmodule.exports = reverse;","import { TNodeImpl, TNodeInit } from '../tree/tree-types';\nimport { Document } from 'domhandler';\nimport { TTextCtor } from '../tree/TTextCtor';\nimport { TPhrasingCtor } from '../tree/TPhrasingCtor';\nimport { TBlockCtor } from '../tree/TBlockCtor';\nimport { TDocumentCtor, TDocumentImpl } from '../tree/TDocumentImpl';\nimport { isDomElement, isDomText, Element, Node, Text } from '../dom/dom-utils';\nimport { TStyles } from '../styles/TStyles';\n\nimport { TEmptyCtor } from '../tree/TEmptyCtor';\nimport { DataFlowParams } from './types';\n\nexport function mapNodeList({\n nodeList,\n parent,\n parentStyles,\n params\n}: {\n nodeList: Node[];\n parentStyles?: TStyles;\n parent: TNodeImpl | null;\n params: DataFlowParams;\n}): TNodeImpl[] {\n const nextMap: TNodeImpl[] = [];\n for (const i in nodeList) {\n const child = nodeList[i];\n const translated = translateNode({\n node: child,\n parentStyles,\n params,\n nodeIndex: Number(i),\n parent\n });\n if (translated) {\n nextMap.push(translated);\n }\n }\n return nextMap;\n}\n\nexport function bindChildren(\n node: TNodeImpl,\n children: Node[],\n params: DataFlowParams\n) {\n if (!node.elementModel || !node.elementModel.isOpaque) {\n node.bindChildren(\n mapNodeList({\n nodeList: children,\n parent: node,\n params\n })\n );\n }\n}\n\nfunction translateElement({\n node,\n nodeIndex,\n params,\n parent,\n parentStyles\n}: TranslateParams): TNodeImpl | null {\n const tagName = node.tagName;\n const sharedProps: Omit = {\n nodeIndex,\n parentStyles,\n context: params,\n domNode: node,\n parent\n };\n const elementModel = params.modelRegistry.getElementModelFromTagName(tagName);\n if (!elementModel) {\n return new TEmptyCtor({\n ...sharedProps,\n isUnregistered: true,\n elementModel,\n domNode: node\n });\n }\n if (elementModel.isTranslatableTextual()) {\n if (node.children.length === 1) {\n const child = node.children[0] as Node;\n if (isDomText(child)) {\n return new TTextCtor({\n ...sharedProps,\n elementModel,\n textNode: child,\n domNode: node\n });\n }\n } else if (node.children.length === 0) {\n return new TTextCtor({\n ...sharedProps,\n elementModel,\n domNode: node,\n textNode: new Text('')\n });\n }\n const phrasing = new TPhrasingCtor({\n ...sharedProps,\n domNode: node,\n elementModel\n });\n bindChildren(phrasing, node.children, params);\n return phrasing;\n }\n if (elementModel.isTranslatableBlock()) {\n const block = new TBlockCtor({\n ...sharedProps,\n elementModel,\n parentStyles,\n domNode: node\n });\n bindChildren(block, node.children, params);\n return block;\n }\n return new TEmptyCtor({\n ...sharedProps,\n isUnregistered: false,\n elementModel,\n domNode: node\n });\n}\n\ninterface TranslateParams {\n node: T;\n params: DataFlowParams;\n parent: TNodeImpl | null;\n parentStyles?: TStyles;\n nodeIndex?: number;\n}\n\nexport function translateNode({\n node,\n parentStyles,\n params,\n nodeIndex,\n parent\n}: TranslateParams): TNodeImpl | null {\n if (isDomText(node)) {\n return new TTextCtor({\n textNode: node,\n context: params,\n parentStyles,\n domNode: null,\n elementModel: null,\n nodeIndex,\n parent\n });\n }\n if (isDomElement(node)) {\n return translateElement({\n node,\n parentStyles,\n params,\n nodeIndex,\n parent\n });\n }\n return null;\n}\n\nexport function translateDocument(\n document: Document,\n params: DataFlowParams\n): TDocumentImpl {\n const tdoc = new TDocumentCtor({\n context: params,\n styles: params.baseStyles,\n domNode: document as any\n });\n bindChildren(tdoc, document.children, params);\n tdoc.parseChildren();\n return tdoc;\n}\n","import HTMLContentModel from '../model/HTMLContentModel';\nimport { Element } from '../dom/dom-utils';\nimport { TNodeImpl, TNodeInit } from './tree-types';\nimport TNodeCtor, { GenericTNodeCtor, Mutable } from './TNodeCtor';\n\nexport interface TEmptyImpl extends TNodeImpl {\n readonly domNode: Element;\n}\n\nexport interface TEmptyInit extends TNodeInit {\n domNode: Element;\n}\n\nconst TEmptyCtor = function TEmpty(\n this: Mutable,\n init: TEmptyInit\n) {\n this.initialize(init);\n} as Function as GenericTNodeCtor;\n\n//@ts-ignore\nTEmptyCtor.prototype = new TNodeCtor('empty', 'TEmpty');\n\nTEmptyCtor.prototype.matchContentModel = function matchContentModel(\n contentModel: HTMLContentModel\n) {\n return contentModel === HTMLContentModel.none;\n};\n\nexport default TEmptyCtor;\n\nexport { TEmptyCtor };\n","import { AccessibilityProps, AccessibilityRole } from 'react-native';\nimport {\n ReactNativePropsSwitch,\n ReactNativePropsDefinitions\n} from '../helper-types';\nimport { TStyles } from '../styles/TStyles';\nimport markersPrototype from './markersPrototype';\nimport tnodeToString from './tnodeSnapshot';\nimport {\n Markers,\n TNodeDescriptor,\n TNodeImpl,\n TNodeInit,\n TNodeType\n} from './tree-types';\n\nexport type GenericTNodeCtor = {\n new (init: Init): Impl;\n prototype: Impl;\n};\n\nexport type Mutable = {\n -readonly [P in keyof T]: T[P];\n};\n\nfunction updateNodeIndexes(node: Mutable, i: number) {\n node.nodeIndex = i;\n}\n\nconst emptyAttrs = Object.freeze({});\nconst emptyClasses = Object.freeze([]);\n\nfunction findNativeRole(ariaRole: string): AccessibilityRole | undefined {\n if (ariaRole === 'img') {\n return 'image';\n }\n if (ariaRole === 'heading') {\n return 'header';\n }\n if (ariaRole === 'dialog') {\n return 'alert';\n }\n if (ariaRole === 'presentation') {\n return 'none';\n }\n if (\n ariaRole === 'button' ||\n ariaRole === 'switch' ||\n ariaRole === 'checkbox' ||\n ariaRole === 'radio' ||\n ariaRole === 'radiogroup' ||\n ariaRole === 'link' ||\n ariaRole === 'search'\n ) {\n return ariaRole;\n }\n}\n\nfunction setMarkersFromAttributes(\n targetMarkers: Markers,\n _parentMarkers: Readonly,\n { attributes }: TNodeDescriptor\n): void {\n if ('dir' in attributes) {\n targetMarkers.direction = attributes.dir as 'rtl';\n }\n if ('lang' in attributes) {\n targetMarkers.lang = attributes.lang;\n }\n}\n\nfunction transformPropsDefinitionsToSwitch(\n definition?: ReactNativePropsDefinitions | null\n): ReactNativePropsSwitch | null {\n if (!definition) {\n return null;\n }\n return {\n text: {\n ...definition.native,\n ...definition.text\n },\n view: {\n ...definition.native,\n ...definition.view\n }\n };\n}\n\nfunction mergeSwitches(\n prev: ReactNativePropsSwitch | null,\n next: ReactNativePropsSwitch | null\n) {\n if (!prev) {\n return next;\n }\n if (!next) {\n return prev;\n }\n return {\n text: {\n ...prev.text,\n ...next.text\n },\n view: {\n ...prev.view,\n ...next.view\n }\n };\n}\n\nconst prototype: Omit = {\n children: Object.freeze([]) as any,\n init: Object.freeze({}) as any,\n classes: Object.freeze([]) as any,\n styles: Object.freeze(TStyles.empty()) as any,\n markers: markersPrototype,\n __nodeIndex: null,\n __trimmedLeft: false,\n __trimmedRight: false,\n __nativeProps: false,\n __nativeStyles: false,\n __webStyles: false,\n __generateNativePropsFromTNode() {\n let ret: ReactNativePropsSwitch | null = null;\n if (this.styles.webTextFlow.userSelect) {\n ret = mergeSwitches(ret, {\n text: {\n selectable: this.styles.webTextFlow.userSelect !== 'none'\n }\n });\n }\n if (this.attributes['aria-label']) {\n const accessibilityProps: AccessibilityProps = {\n accessibilityLabel: this.attributes['aria-label']\n };\n ret = mergeSwitches(ret, {\n view: accessibilityProps,\n text: accessibilityProps\n });\n }\n if (this.attributes.role) {\n const role = this.attributes.role;\n const accessibilityRole = findNativeRole(role);\n if (accessibilityRole) {\n const accessibilityProps: AccessibilityProps = {\n accessibilityRole: accessibilityRole\n };\n ret = mergeSwitches(ret, {\n view: accessibilityProps,\n text: accessibilityProps\n });\n }\n }\n return ret;\n },\n\n __generateDynamicNativePropsFromModel(autoGeneratedProps) {\n const elm = this.elementModel;\n if (!elm || !elm.getReactNativeProps) {\n return null;\n }\n return transformPropsDefinitionsToSwitch(\n elm.getReactNativeProps(this as any, autoGeneratedProps, this.domNode!) ||\n null\n );\n },\n\n get attributes() {\n return this.domNode?.attribs || emptyAttrs;\n },\n\n get hasWhiteSpaceCollapsingEnabled() {\n return typeof this.styles.webTextFlow.whiteSpace === 'string'\n ? this.styles.webTextFlow.whiteSpace === 'normal'\n : true;\n },\n\n get contentModel() {\n return this.elementModel?.contentModel || null;\n },\n\n get parentStyles() {\n return this.init.parentStyles || this.parent?.styles || null;\n },\n\n get id() {\n return this.attributes.id || null;\n },\n\n get domNode() {\n return this.init.domNode || null;\n },\n\n get elementModel() {\n return this.init.elementModel;\n },\n\n get tagName() {\n return this.init.domNode?.name || null;\n },\n\n get parent() {\n return (this.init.parent as any) || null;\n },\n\n get nodeIndex() {\n if (this.__nodeIndex === null) {\n this.__nodeIndex = this.init.nodeIndex || 0;\n }\n return this.__nodeIndex;\n },\n\n get isUnregistered() {\n return this.init.isUnregistered || false;\n },\n\n set nodeIndex(nodeIndex: number) {\n this.__nodeIndex = nodeIndex;\n },\n\n bindChildren(children, shouldUpdateNodeIndexes = false) {\n //@ts-ignore\n this.children = children;\n if (shouldUpdateNodeIndexes) {\n children.forEach(updateNodeIndexes);\n }\n },\n\n cloneInitParams(partial) {\n return Object.assign({}, this.init, partial) as any;\n },\n\n isCollapsibleLeft() {\n if (this.children.length) {\n return (\n this.hasWhiteSpaceCollapsingEnabled &&\n this.children[0].isCollapsibleLeft()\n );\n }\n return false;\n },\n\n isCollapsibleRight() {\n if (this.children.length) {\n return (\n this.hasWhiteSpaceCollapsingEnabled &&\n this.children[this.children.length - 1].isCollapsibleRight()\n );\n }\n return false;\n },\n\n isEmpty() {\n return false;\n },\n\n trimLeft() {\n if (!this.__trimmedLeft && this.children.length) {\n const firstChild = this.children[0];\n firstChild.trimLeft();\n if (firstChild.isEmpty()) {\n //@ts-ignore\n this.children.splice(0, 1);\n }\n this.__trimmedLeft = true;\n }\n },\n\n trimRight() {\n if (!this.__trimmedRight && this.children.length) {\n const lastChild = this.children[this.children.length - 1];\n lastChild.trimRight();\n if (lastChild.isEmpty()) {\n //@ts-ignore\n this.children.splice(-1, 1);\n }\n this.__trimmedRight = true;\n }\n },\n\n matchContentModel() {\n return false;\n },\n\n spliceChildren(indexesToSplice) {\n let offset = 0;\n for (const i of indexesToSplice) {\n //@ts-ignore\n this.children.splice(i - offset, 1);\n offset += 1;\n }\n },\n\n collapse() {\n this.collapseChildren();\n this.bindChildren(this.children, true);\n },\n\n getNativeStyles() {\n if (this.__nativeStyles === false) {\n this.__nativeStyles = {\n ...this.styles.nativeBlockFlow,\n ...this.styles.nativeBlockRet,\n ...this.styles.nativeTextFlow,\n ...this.styles.nativeTextRet\n };\n }\n return this.__nativeStyles;\n },\n\n getWebStyles() {\n if (this.__webStyles === false) {\n this.__webStyles = {\n ...this.styles.webTextFlow,\n ...this.styles.webBlockRet\n } as ReturnType;\n }\n return this.__webStyles;\n },\n\n collapseChildren() {\n return;\n },\n\n snapshot(options = {}) {\n const { withStyles = false, withNodeIndex = false } = options;\n return tnodeToString(this as any, { withStyles, withNodeIndex });\n },\n\n hasClass(className) {\n return this.classes.indexOf(className) > -1;\n },\n\n toString() {\n return this.snapshot();\n },\n\n setMarkers(targetMarkers, parentMarkers) {\n if (this.elementModel?.setMarkersForTNode) {\n this.elementModel.setMarkersForTNode(targetMarkers, parentMarkers, this);\n }\n setMarkersFromAttributes(targetMarkers, parentMarkers, this);\n this.init.context.setMarkersForTNode?.(targetMarkers, parentMarkers, this);\n },\n\n getReactNativeProps() {\n if (this.__nativeProps === false) {\n const staticFromModel = transformPropsDefinitionsToSwitch(\n this.elementModel?.reactNativeProps\n );\n const dynamicFromAttrs = this.__generateNativePropsFromTNode();\n const autoGeneratedProps = mergeSwitches(\n staticFromModel,\n dynamicFromAttrs\n );\n const dynamicFromModel =\n this.__generateDynamicNativePropsFromModel(autoGeneratedProps);\n this.__nativeProps = mergeSwitches(autoGeneratedProps, dynamicFromModel);\n }\n return this.__nativeProps;\n },\n\n initialize = TNodeImpl>(\n this: Mutable,\n init: Impl['init']\n ) {\n this.init = init;\n this.classes = this.attributes.class?.split(/\\s+/) || emptyClasses;\n const parentMarkers = init.parent\n ? init.parent.markers\n : markersPrototype.extend();\n this.markers = parentMarkers.extend();\n this.setMarkers(this.markers, parentMarkers, this);\n // Avoid very long prototype chains by assigning parent to current\n // when current has no own properties\n if (Object.keys(this.markers).length === 0) {\n this.markers = parentMarkers;\n }\n this.styles =\n init.styles ||\n init.context.stylesMerger.buildStyles(\n this.attributes.style,\n this.parentStyles || null,\n this\n );\n }\n};\n\nconst TNodeCtor = function TNode(\n this: Mutable,\n type: TNodeType,\n displayName: string,\n extraAccessors?: {\n [k in Exclude]: {\n get: () => any;\n set?: (val: any) => void;\n };\n }\n) {\n this.type = type;\n this.displayName = displayName;\n extraAccessors && Object.defineProperties(this, extraAccessors);\n};\n\nTNodeCtor.prototype = prototype as any;\n\nexport default TNodeCtor;\n","import { Markers } from './tree-types';\n\nconst markersPrototype: Markers = {\n anchor: false,\n edits: 'none',\n lang: 'en',\n olNestLevel: -1,\n ulNestLevel: -1,\n direction: 'ltr',\n extend(this: Markers) {\n return Object.create(this);\n },\n toString() {\n let print = 'Markers {\\n';\n for (const key in this) {\n //@ts-ignore\n const val = this[key];\n if (typeof val !== 'function') {\n print += ` ${key}: ${JSON.stringify(val)}\\n`;\n }\n }\n return print + '}';\n }\n};\n\nexport default markersPrototype;\n","import { TNode, TNodePrintOptions } from './tree-types';\n\nfunction printTableStyles(styles: Record) {\n const entries = Object.entries(styles);\n return entries.reduce((prev, [name, val]) => {\n return `${prev}${prev ? ',' : ''} ${name}: ${JSON.stringify(val)}`;\n }, '');\n}\n\nfunction tnodePropertiesString(\n tnode: TNode,\n { withNodeIndex, withStyles }: TNodePrintOptions\n) {\n const tagPrint = tnode.tagName ? `tagName=\"${tnode.tagName}\"` : 'anonymous';\n const unregisteredPrint = tnode.isUnregistered ? 'unregistered' : null;\n const indexPrint = withNodeIndex ? `nodeIndex={${tnode.nodeIndex}}` : null;\n const idPrint = tnode.id ? `id=${tnode.id}` : null;\n const classesPrint = tnode.classes?.length\n ? `classes={[${tnode.classes.join(', ')}]}`\n : null;\n const dataPrint =\n tnode.type === 'text' ? `data=${JSON.stringify(tnode.data)}` : null;\n const anchorPrint =\n typeof tnode.attributes.href === 'string'\n ? `href=${JSON.stringify(tnode.attributes.href)}`\n : null;\n const srcPrint =\n typeof tnode.attributes.src === 'string'\n ? `src=${JSON.stringify(tnode.attributes.src)}`\n : null;\n const pstyles = withStyles ? printTableStyles(tnode.getNativeStyles()) : null;\n const nativeStylesPrint = pstyles ? `nativeStyles={{${pstyles} }}` : null;\n const oStyles = withStyles ? printTableStyles(tnode.getWebStyles()) : null;\n const webStylesPrint = oStyles ? `webStyles={{${oStyles}}}` : null;\n const detailsPrint = [\n tagPrint,\n unregisteredPrint,\n indexPrint,\n idPrint,\n classesPrint,\n dataPrint,\n anchorPrint,\n srcPrint,\n nativeStylesPrint,\n webStylesPrint\n ]\n .filter((p) => p !== null)\n .join(' ');\n return `<${tnode.displayName} ${detailsPrint}`;\n}\n\ninterface TNodePrintState {\n parentLeftPrefix: string;\n isChild: boolean;\n isLast: boolean;\n}\n\nexport default function tnodeSnapshot(\n tnode: TNode,\n params: Partial & TNodePrintOptions\n): string {\n const {\n parentLeftPrefix = '',\n isChild = false,\n isLast = true,\n withStyles,\n withNodeIndex\n } = params;\n const prefix = isChild ? ' ' : '';\n const totalPrefixLeft = parentLeftPrefix + prefix;\n const childrenPrint = tnode.children\n .map((c, i) =>\n tnodeSnapshot(c, {\n parentLeftPrefix: parentLeftPrefix + ''.padStart(prefix.length, ' '),\n isChild: true,\n isLast: i === tnode.children.length - 1,\n withStyles,\n withNodeIndex\n })\n )\n .join('');\n return `${totalPrefixLeft}${tnodePropertiesString(tnode, {\n withStyles,\n withNodeIndex\n })}${\n childrenPrint\n ? `>\\n${childrenPrint}\\n${totalPrefixLeft}`\n : ' />'\n }${isLast ? '' : '\\n'}`;\n}\n","import { Text } from '../dom/dom-utils';\nimport HTMLContentModel from '../model/HTMLContentModel';\n\nimport compose from 'ramda/src/compose';\nimport { TNodeInit, TNodeImpl } from './tree-types';\nimport {\n normalizeWhitespaces,\n normalizeZeroWidthWhitespaces,\n removeCollapsibleAroundSegmentBreak,\n removeConsecutiveSegmentBreaks,\n removeLineBreaksAroundEastAsianDiscardSet,\n replaceSegmentBreaks\n} from '../flow/text-transforms';\nimport TNodeCtor, { GenericTNodeCtor, Mutable } from './TNodeCtor';\n\nexport interface TTextInit extends TNodeInit {\n readonly textNode: Text;\n}\n\nexport interface TTextImpl extends TNodeImpl {\n readonly data: string;\n /**\n * True when tagName is defined and should be substituted with text when\n * rendering. E.g.
tags.\n */\n readonly isVoid: boolean;\n}\n\nconst collapseWhiteSpaces = compose(\n normalizeWhitespaces,\n replaceSegmentBreaks,\n normalizeZeroWidthWhitespaces,\n removeConsecutiveSegmentBreaks,\n removeCollapsibleAroundSegmentBreak\n);\n\nconst collapseWhiteSpacesWithEastAsianCharset = compose(\n normalizeWhitespaces,\n replaceSegmentBreaks,\n removeLineBreaksAroundEastAsianDiscardSet,\n normalizeZeroWidthWhitespaces,\n removeConsecutiveSegmentBreaks,\n removeCollapsibleAroundSegmentBreak\n);\n\nconst TTextCtor = function TText(this: Mutable, init: TTextInit) {\n this.initialize(init);\n this.isVoid = this.elementModel ? this.elementModel.isVoid : false;\n} as Function as GenericTNodeCtor;\n\n//@ts-ignore\nTTextCtor.prototype = new TNodeCtor('text', 'TText', {\n data: {\n get(this: TTextImpl) {\n return this.init.textNode.data;\n },\n set(this: TTextImpl, data: string) {\n this.init.textNode.data = data;\n }\n }\n});\n\nTTextCtor.prototype.matchContentModel = function matchContentModel(\n contentModel: HTMLContentModel\n) {\n return (\n contentModel === HTMLContentModel.textual ||\n contentModel === HTMLContentModel.mixed\n );\n};\n\nTTextCtor.prototype.isCollapsibleLeft = function isCollapsibleLeft(\n this: TTextImpl\n) {\n return (\n this.hasWhiteSpaceCollapsingEnabled &&\n !this.isEmpty() &&\n this.data[0] === ' '\n );\n};\n\nTTextCtor.prototype.isCollapsibleRight = function isCollapsibleRight(\n this: TTextImpl\n) {\n return (\n this.hasWhiteSpaceCollapsingEnabled &&\n !this.isEmpty() &&\n (this.isVoid || this.data[this.data.length - 1] === ' ')\n );\n};\n\nTTextCtor.prototype.isEmpty = function isEmpty(this: TTextImpl) {\n // Only anonymous text nodes can be considered \"empty\"\n return this.tagName === null && !this.data.length;\n};\n\nTTextCtor.prototype.trimLeft = function trimLeft(this: Mutable) {\n if (this.isCollapsibleLeft()) {\n this.data = this.data.slice(1);\n }\n};\n\nTTextCtor.prototype.trimRight = function trimRight(this: Mutable) {\n if (this.isCollapsibleRight()) {\n this.data = this.data.substr(0, this.data.length - 1);\n }\n};\n\nTTextCtor.prototype.collapseChildren = function collapseChildren(\n this: Mutable\n) {\n if (this.hasWhiteSpaceCollapsingEnabled) {\n if (this.init.context.removeLineBreaksAroundEastAsianDiscardSet) {\n this.data = collapseWhiteSpacesWithEastAsianCharset(this.data);\n } else {\n this.data = collapseWhiteSpaces(this.data);\n }\n }\n return null;\n};\n\nexport default TTextCtor;\n\nexport { TTextCtor };\n","// TODO, when React Native supports unicode regexes,\n// we should use `p{Zs}` instead of [ \\t] to comply\n// with the CSS3 Text Module standard. https://www.w3.org/TR/css-text-3/#spaces\nconst COLLAPSIBLE_AROUND_SEGMENT_BREAK_REGEX = /[ \\t]*[\\r\\n\\f]+[ \\t]*/g;\nconst CONSECUTIVE_SEGMENT_BREAKS_REGEX = /[\\r\\n\\f]+/g;\nconst ZERO_WIDTH_SPACES_AROUND_SEGMENT_BREAKS_REGEX =\n /(\\u200b\\n\\u200b?|\\u200b?\\n\\u200b)/g;\nconst SPACE_DISCARDING_CHARSET_REGEX =\n /([\\u2E80-\\u2EFF\\u2F00-\\u2FDF\\u2FF0-\\u2FFF\\u3000-\\u303F\\u3040-\\u309F\\u30A0-\\u30FF\\u3130-\\u318F\\u3190-\\u319F\\u31C0-\\u31EF\\u31F0-\\u31FF\\u3300-\\u33FF\\u3400-\\u4DBF\\u4E00-\\u9FFF\\uA000-\\uA48F\\uA490-\\uA4CF\\uF900-\\uFAFF\\uFE10-\\uFE1F\\uFE30-\\uFE4F\\uFE50-\\uFE6F\\uFF00-\\uFFEF])\\n([\\u2E80-\\u2EFF\\u2F00-\\u2FDF\\u2FF0-\\u2FFF\\u3000-\\u303F\\u3040-\\u309F\\u30A0-\\u30FF\\u3130-\\u318F\\u3190-\\u319F\\u31C0-\\u31EF\\u31F0-\\u31FF\\u3300-\\u33FF\\u3400-\\u4DBF\\u4E00-\\u9FFF\\uA000-\\uA48F\\uA490-\\uA4CF\\uF900-\\uFAFF\\uFE10-\\uFE1F\\uFE30-\\uFE4F\\uFE50-\\uFE6F\\uFF00-\\uFFEF])/g;\nconst SEGMENT_BREAK_REGEX = /\\n/g;\nconst SUBSEQUENT_WHITESPACE_REGEX = /[ \\t]+/g;\n\n// Implementation of\n// https://www.w3.org/TR/2020/WD-css-text-3-20201119/#white-space-phase-1\nexport function removeCollapsibleAroundSegmentBreak(data: string): string {\n return data.replace(COLLAPSIBLE_AROUND_SEGMENT_BREAK_REGEX, '\\n');\n}\n\n// Implementation of\n// https://www.w3.org/TR/2020/WD-css-text-3-20201119/#line-break-transform\nexport function removeConsecutiveSegmentBreaks(data: string): string {\n return data.replace(CONSECUTIVE_SEGMENT_BREAKS_REGEX, '\\n');\n}\n\n// Implementation of\n// https://www.w3.org/TR/2020/WD-css-text-3-20200429/#line-break-transform\n// In the latest version (https://www.w3.org/TR/2020/WD-css-text-3-20201119/),\n// the behavior is considered at UA discretion.\nexport function normalizeZeroWidthWhitespaces(data: string): string {\n return data.replace(ZERO_WIDTH_SPACES_AROUND_SEGMENT_BREAKS_REGEX, '\\u200b');\n}\n\n// Partial implementation of\n// https://www.w3.org/TR/2020/WD-css-text-3-20200429/#line-break-transform\n//\n// Because RN Javascript runtime doesn't support String.fromCharCode, we don't support space discarding\n// for character ranges above U+FFFF\n//\n// In the latest version (https://www.w3.org/TR/2020/WD-css-text-3-20201119/),\n// the behavior is considered at UA discretion.\nexport function removeLineBreaksAroundEastAsianDiscardSet(\n data: string\n): string {\n return data.replace(SPACE_DISCARDING_CHARSET_REGEX, '$1$2');\n}\n\n// Implementation of\n// https://www.w3.org/TR/2020/WD-css-text-3-20201119/#white-space-phase-2\n// (A.1)\nexport function replaceSegmentBreaks(data: string): string {\n return data.replace(SEGMENT_BREAK_REGEX, ' ');\n}\n\n// Implementation of\n// https://www.w3.org/TR/2020/WD-css-text-3-20201119/#white-space-phase-2\n// (A.4)\nexport function normalizeWhitespaces(data: string): string {\n return data.replace(SUBSEQUENT_WHITESPACE_REGEX, ' ');\n}\n","import HTMLContentModel from '../model/HTMLContentModel';\nimport TNodeCtor, { GenericTNodeCtor, Mutable } from './TNodeCtor';\nimport { TNodeImpl, TNodeInit } from './tree-types';\n\nexport interface TPhrasingImpl extends TNodeImpl {}\n\nfunction isChildEmpty(c: TNodeImpl) {\n return c.isEmpty();\n}\n\nconst TPhrasingCtor = function TPhrasing(\n this: Mutable,\n init: TNodeInit\n) {\n this.initialize(init);\n} as Function as GenericTNodeCtor;\n\n//@ts-ignore\nTPhrasingCtor.prototype = new TNodeCtor('phrasing', 'TPhrasing');\n\nTPhrasingCtor.prototype.matchContentModel = function matchContentModel(\n contentModel\n) {\n return (\n contentModel === HTMLContentModel.textual ||\n contentModel === HTMLContentModel.mixed\n );\n};\n\nTPhrasingCtor.prototype.isEmpty = function isEmpty() {\n // Only anonymous phrasing nodes with every children empty can be considered \"empty\"\n return this.tagName === null && this.children.every(isChildEmpty);\n};\n\nTPhrasingCtor.prototype.collapseChildren = function collapseChildren() {\n let previous: TNodeImpl | null = null;\n this.children.forEach((childK, k) => {\n const j = k - 1;\n childK.collapse();\n if (\n j > -1 &&\n childK.isCollapsibleLeft() &&\n (previous as TNodeImpl).isCollapsibleRight()\n ) {\n // We must trim left from current to support trimming\n // after
and tags.\n childK.trimLeft();\n }\n previous = childK;\n });\n this.trimLeft();\n this.trimRight();\n return null;\n};\n\nexport default TPhrasingCtor;\n\nexport { TPhrasingCtor };\n","import HTMLContentModel from '../model/HTMLContentModel';\nimport TNodeCtor, { GenericTNodeCtor, Mutable } from './TNodeCtor';\nimport { TNodeImpl, TNodeInit } from './tree-types';\n\nexport interface TBlockImpl extends TNodeImpl {}\n\nconst TBlockCtor = function TBlock(this: Mutable, init: TNodeInit) {\n this.initialize(init);\n} as Function as GenericTNodeCtor;\n\n//@ts-ignore\nTBlockCtor.prototype = new TNodeCtor('block', 'TBlock');\n\nTBlockCtor.prototype.matchContentModel = function matchContentModel(\n contentModel\n) {\n return (\n contentModel === HTMLContentModel.block ||\n contentModel === HTMLContentModel.mixed\n );\n};\n\nTBlockCtor.prototype.collapseChildren = function collapseChildren() {\n let indexesToSplice: number[] = [];\n this.children.forEach((child, i) => {\n child.collapse();\n if (child.isEmpty()) {\n indexesToSplice.push(i);\n }\n });\n this.spliceChildren(indexesToSplice);\n};\n\nTBlockCtor.prototype.getNativeStyles = function getNativeStyles(\n this: TNodeImpl\n) {\n if (this.__nativeStyles === false) {\n this.__nativeStyles = {\n ...this.styles.nativeBlockFlow,\n ...this.styles.nativeBlockRet\n };\n }\n return this.__nativeStyles;\n};\n\nexport default TBlockCtor;\n\nexport { TBlockCtor };\n","import { GenericTNodeCtor, Mutable } from './TNodeCtor';\nimport HTMLElementModel from '../model/HTMLElementModel';\nimport { isDomElement, isDomText } from '../dom/dom-utils';\nimport { TEmptyImpl } from './TEmptyCtor';\nimport { TNodeInit, TNodeImpl, DocumentContext } from './tree-types';\nimport TBlockImpl from './TBlockCtor';\n\nexport type TDocumentInit = Omit;\n\nexport interface TDocumentImpl extends TNodeImpl {\n readonly context: Readonly;\n /**\n * Iterate over children and extract meta-information into context field.\n * Replace children with a single-element array containing the body.\n */\n parseChildren(): void;\n}\n\nconst defaultContextBase: DocumentContext = Object.freeze({\n baseHref: 'about:blank',\n baseTarget: '_self',\n charset: 'utf-8',\n title: '',\n lang: 'en',\n dir: 'ltr',\n links: [],\n meta: []\n});\n\nfunction getDefaultDocumentContext(): DocumentContext {\n return Object.assign({}, defaultContextBase, { links: [], meta: [] });\n}\n\nfunction extractContextFromHead(head: TEmptyImpl, lang?: string, dir?: string) {\n const context = getDefaultDocumentContext();\n if (lang) {\n context.lang = lang;\n }\n if (dir) {\n context.dir = 'rtl';\n }\n const domNode = head.domNode;\n const children = domNode.children;\n children.filter(isDomElement).forEach((child) => {\n if (child.tagName === 'meta') {\n if (child.attribs.name) {\n context.meta.push(child.attribs as any);\n } else if (child.attribs.charset) {\n context.charset = child.attribs.charset.toLowerCase();\n }\n } else if (child.tagName === 'link') {\n context.links.push(child.attribs);\n } else if (child.tagName === 'title') {\n for (const titleChild of child.children.filter(isDomText)) {\n context.title = titleChild.data.trim();\n break;\n }\n } else if (child.tagName === 'base') {\n context.baseHref = child.attribs.href || context.baseHref;\n context.baseTarget = (child.attribs.target as any) || context.baseTarget;\n }\n });\n return context;\n}\n\nconst htmlModel = HTMLElementModel.fromNativeModel({\n tagName: 'html' as any,\n category: 'grouping'\n});\n\nconst TDocumentCtor = function TDocument(\n this: Mutable,\n init: TDocumentInit\n) {\n this.initialize(init as TNodeInit);\n} as Function as GenericTNodeCtor;\n\nTDocumentCtor.prototype = Object.create(TBlockImpl.prototype);\n\nObject.defineProperty(TDocumentCtor.prototype, 'tagName', {\n value: 'html',\n writable: false\n});\n\nObject.defineProperty(TDocumentCtor.prototype, 'type', {\n value: 'document',\n writable: false\n});\n\nObject.defineProperty(TDocumentCtor.prototype, 'displayName', {\n value: 'TDocument',\n writable: false\n});\n\nObject.defineProperty(TDocumentCtor.prototype, 'elementModel', {\n value: htmlModel,\n writable: false\n});\n\nTDocumentCtor.prototype.parseChildren = function parseChildren(\n this: Mutable\n) {\n let head: TEmptyImpl | undefined;\n for (const child of this.children) {\n if (child.tagName === 'head') {\n head = child as unknown as TEmptyImpl;\n break;\n }\n }\n this.context = Object.freeze(\n head\n ? extractContextFromHead(\n head,\n this.attributes!.lang,\n this.attributes!.dir\n )\n : {\n ...getDefaultDocumentContext(),\n lang: this.attributes!.lang,\n dir: this.attributes!.dir as any\n }\n );\n};\n\nexport { TDocumentCtor };\n\nexport default TDocumentCtor;\n","import TBlockCtor, { TBlockImpl } from '../tree/TBlockCtor';\nimport { TNodeImpl } from '../tree/tree-types';\nimport { TPhrasingCtor } from '../tree/TPhrasingCtor';\nimport { TTextCtor } from '../tree/TTextCtor';\n\n/**\n * Wrap text nodes around TPhrasing nodes.\n * @param tnode The parent node of all elements to group.\n */\nfunction groupText(tnode: TBlockImpl): TNodeImpl {\n let newChildren: TNodeImpl[] = [];\n const wrapperInit = {\n elementModel: null,\n context: tnode.init.context,\n // We need to merge styles here to make sure\n // some React Native styles working only for the uppermost Text element\n // such as \"textAlign\" are preserved.\n parentStyles: tnode.styles,\n parent: null\n };\n let wrapper = new TPhrasingCtor(wrapperInit);\n let wrapperChildren: TNodeImpl[] = [];\n for (const child of tnode.children) {\n if (child instanceof TTextCtor || child instanceof TPhrasingCtor) {\n wrapperChildren.push(child);\n } else {\n if (wrapperChildren.length) {\n newChildren.push(wrapper);\n wrapper.bindChildren(wrapperChildren);\n wrapper = new TPhrasingCtor(wrapperInit);\n wrapperChildren = [];\n }\n newChildren.push(child);\n }\n }\n if (wrapperChildren.length) {\n wrapper.bindChildren(wrapperChildren);\n newChildren.push(wrapper);\n }\n tnode.bindChildren(newChildren);\n return tnode;\n}\n\nfunction hoistNode(tnode: TNodeImpl): TNodeImpl {\n if (tnode instanceof TTextCtor) {\n return tnode;\n }\n tnode.bindChildren(tnode.children.map(hoistNode));\n if (tnode instanceof TPhrasingCtor) {\n for (const cnode of tnode.children) {\n if (cnode instanceof TBlockCtor) {\n const newNode = new TBlockCtor(tnode.cloneInitParams());\n newNode.bindChildren(tnode.children);\n const output = groupText(newNode);\n return output;\n }\n }\n } else if (tnode instanceof TBlockCtor) {\n if (tnode.children.length > 0) {\n const output = groupText(tnode);\n return output;\n }\n }\n return tnode;\n}\n\nexport function hoist(tree: TNodeImpl): TNodeImpl {\n return hoistNode(tree);\n}\n","import { TNodeImpl } from '../tree/tree-types';\n\nexport function collapse(root: TNodeImpl): TNodeImpl {\n root.collapse();\n root.trimLeft();\n root.trimRight();\n return root;\n}\n","import { MixedStyleDeclaration } from '@native-html/css-processor';\nimport { Element } from 'domhandler';\nimport {\n ReactNativePropsDefinitions,\n ReactNativePropsSwitch\n} from '../helper-types';\nimport {\n ExtractTNodeFromType,\n Markers,\n SetMarkersForTNode,\n TNodeDescriptor,\n TNodeType\n} from '../tree/tree-types';\nimport HTMLContentModel from './HTMLContentModel';\nimport HTMLElementModel from './HTMLElementModel';\n\nexport type ElementCategory =\n | 'anchor'\n | 'textual'\n | 'tabular'\n | 'edits'\n | 'embedded'\n | 'sectioning'\n | 'grouping'\n | 'interactive'\n | 'untranslatable';\n\nexport type TagName =\n | AnchorTagName\n | TextLevelTagNames\n | EditsTagNames\n | EmbeddedTagNames\n | TabularTagNames\n | GroupingTagNames\n | SectioningTagNames\n | InteractiveTagNames\n | UntranslatableTagNames;\n\nexport type AnchorTagName = 'a';\n\nexport type TabularTagNames =\n | 'table'\n | 'tbody'\n | 'thead'\n | 'tfoot'\n | 'tr'\n | 'td'\n | 'th';\n\nexport type GroupingTagNames =\n | 'p'\n | 'hr'\n | 'pre'\n | 'blockquote'\n | 'ol'\n | 'ul'\n | 'dir'\n | 'menu'\n | 'li'\n | 'dl'\n | 'dt'\n | 'dd'\n | 'figure'\n | 'figcaption'\n | 'main'\n | 'div'\n | 'xmp' // deprecated, behaves like pre\n | 'listing' // deprecated, behaves like pre\n | 'plaintext'; // deprecated, behaves like pre\n\nexport type AttribTagNames =\n | 'accesskey' // Attribute for fieldset\n | 'datalist' // Attribute for input by id\n | 'source' // Attribute for pictures / videos / audio\n | 'track' // Attribute for videos\n | 'caption' // Attribute for table\n | 'colgroup' // Attribute for table\n | 'col' // Attribute for colgroup\n | 'option' // Attribute for optgroup, select\n | 'optgroup' // Attribute for select\n | 'param'; // Attribute for object\n\nexport type MetadataTagNames = 'head' | 'title' | 'base' | 'link' | 'meta';\n\nexport type InteractiveTagNames =\n | 'form'\n | 'label'\n | 'input'\n | 'button'\n | 'select'\n | 'progress'\n | 'meter'\n | 'fieldset'\n | 'legend'\n | 'textarea'\n | 'output'\n | 'details'\n | 'summary'\n | 'dialog';\n\nexport type UnsupportedTagNames = 'area' | 'map';\nexport type UntranslatableTagNames =\n | AttribTagNames\n | UnsupportedTagNames\n | MetadataTagNames;\n\nexport type EmbeddedTagNames =\n | 'audio'\n | 'canvas'\n | 'embed'\n | 'iframe'\n | 'img'\n | 'math'\n | 'object'\n | 'picture'\n | 'svg'\n | 'video';\n\nexport type EditsTagNames = 'ins' | 'del';\n\nexport type SectioningTagNames =\n | 'body'\n | 'article'\n | 'section'\n | 'nav'\n | 'aside'\n | 'h1'\n | 'h2'\n | 'h3'\n | 'h4'\n | 'h5'\n | 'h6'\n | 'hgroup'\n | 'header'\n | 'footer'\n | 'address';\n\nexport type TextLevelTagNames =\n | 'em'\n | 'strong'\n | 'strike'\n | 'small'\n | 'big'\n | 's'\n | 'cite'\n | 'q'\n | 'dfn'\n | 'abbr'\n | 'acronym'\n | 'ruby'\n | 'rt'\n | 'rp'\n | 'data'\n | 'time'\n | 'tt'\n | 'code'\n | 'var'\n | 'samp'\n | 'kbd'\n | 'sup'\n | 'sub'\n | 'i'\n | 'b'\n | 'u'\n | 'mark'\n | 'bdi'\n | 'bdo'\n | 'span'\n | 'br'\n | 'wbr';\n\n/**\n * @public\n */\nexport type HTMLModelRecord<\n T extends string = TagName,\n M extends HTMLContentModel = HTMLContentModel\n> = {\n [k in T]: HTMLElementModel;\n};\n\n/**\n * @typeParam T - The name of the tag to which the model will apply.\n */\nexport interface ElementModelBase {\n /**\n * The tag name associated with this model.\n */\n readonly tagName: T;\n\n /**\n * An opaque element translated {@link TNode} will have no translated {@link TNode}\n * children.\n */\n readonly isOpaque?: boolean;\n\n /**\n * Equivalent of \"user-agent\" styles. The default styles for the element.\n *\n * @remarks These styles will be merged over by `tagsStyles`.\n */\n readonly mixedUAStyles?: MixedStyleDeclaration;\n\n /**\n * React Native props grouped by native components. Those props\n * will be passed to the underlying native component at render time.\n *\n * @remarks Some props might be overriden by props derived from the\n * {@link TNode} attributes. For example, if you pass `accessibilityLabel`\n * and there is an `aria-label` attribute attached to one node, the\n * `aria-label` will be used. If you want to be able to override the\n * `aria-label`, use {@link ElementModelBase.getReactNativeProps} instead.\n *\n * @example\n *\n * ```ts\n * import {HTMLElementModel, HTMLContentModel} from 'react-native-render-html';\n *\n * const customHTMLElementModels = {\n * 'nav-button': HTMLElementModel.fromCustomModel({\n * tagName: 'nav-button',\n * contentModel: HTMLContentModel.block,\n * reactNativeProps: {\n * native: {\n * onPress() {\n * console.info('nav-button pressed');\n * },\n * },\n * },\n * }),\n *};\n * ```\n */\n readonly reactNativeProps?: ReactNativePropsDefinitions;\n\n /**\n * `true` when the associated tag is a {@link https://html.spec.whatwg.org/multipage/syntax.html#void-elements | void element}.\n *\n * @remarks\n *\n * - Void elements cannot have children.\n * - TText-translated void elements will be preserved even though they don't\n * have children.\n */\n readonly isVoid?: boolean;\n\n /**\n * Derive markers for one TNode.\n */\n setMarkersForTNode?: SetMarkersForTNode;\n\n /**\n * A function to create conditional \"user-agent\" styles.\n *\n * @deprecated Use {@link ElementModelBase.getMixedUAStyles} instead.\n */\n getUADerivedStyleFromAttributes?: (\n attributes: Record,\n markers: Markers\n ) => MixedStyleDeclaration | null;\n\n /**\n * A function to create conditional \"user-agent\" styles.\n *\n * @remarks For example, <a> tags will have underline decoration and be\n * colored blue only when `href` is defined.\n */\n getMixedUAStyles?: (\n tnode: TNodeDescriptor,\n element: Element\n ) => MixedStyleDeclaration | null | undefined | void;\n\n /**\n * A function to create React Native props from a {@link TNode} grouped by\n * native components.\n *\n * Those props will be deep-merged over the pre-generated props. You can\n * preserve some of the pre-generated props since you receive them as second\n * argument.\n *\n * **Merge strategy** (latest overrides former):\n *\n * 1. props from `reactNativeProps`,\n * 2. auto-generated props from attributes\n * 3. props returned by this function\n *\n * @param tnode - The {@link TNode} for which to create React Native props.\n * @param preGeneratedProps - The props that were pre-generated for the {@link TNode}\n * based on attributes (e.g. aria-label ...) and\n * {@link ElementModelBase.reactNativeProps}.\n * @returns React Native props grouped by native components (see\n * {@link ReactNativePropsDefinitions}). Those props will be passed to the\n * underlying native component at render time.\n *\n * @example\n *\n * ```ts\n * import { defaultHTMLElementModels } from \"react-native-render-html\";\n *\n * const customHTMLElementModels = {\n * a: defaultHTMLElementModels.a.extend({\n * getReactNativeProps(tnode) {\n * const attributes = tnode.attributes;\n * return {\n * native: {\n * accessibilityHint:\n * attributes['data-scope'] === 'internal'\n * ? 'Open in a new screen.'\n * : 'Open in system web browser.',\n * },\n * };\n * },\n * }),\n * };\n * ```\n */\n getReactNativeProps?: (\n tnode: ExtractTNodeFromType,\n preGeneratedProps: ReactNativePropsSwitch | null,\n element: Element\n ) => ReactNativePropsDefinitions | null | undefined | void;\n}\n\n/**\n * An object to specify custom tags.\n *\n * @typeParam T - The name of the tag to which the model will apply.\n * @typeParam M - The {@link HTMLContentModel} associated with this tag.\n */\nexport interface CustomElementModel<\n T extends string,\n M extends HTMLContentModel\n> extends ElementModelBase {\n /**\n * The {@link HTMLContentModel} attached to this model.\n */\n readonly contentModel: M;\n /**\n * The tag name associated with this model.\n */\n readonly tagName: T;\n}\n\n/**\n * An object to specify tags parts of the HTML4 and HTML5 standards.\n *\n * @typeParam T - The name of the tag to which the model will apply.\n * @typeParam C - The {@link ElementCategory} associated with this tag.\n */\nexport interface NativeElementModel<\n T extends string = TagName,\n C = ElementCategory\n> extends ElementModelBase {\n /**\n * The category of this element as per HTML5 standard.\n */\n readonly category: C;\n}\n","import {\n ViewProps,\n TextProps,\n ViewStyle,\n TextStyle,\n StyleProp\n} from 'react-native';\n\n/**\n * Props available on both React Native `Text` and `View` components.\n */\nexport type ReactNativeProps = Pick<\n ViewProps,\n Extract>\n> &\n Pick<\n TextProps,\n Extract>\n > & {\n style?: StyleProp<\n Pick>\n >;\n };\n\n/**\n * React Native `Text` props, minus the `style` prop.\n */\nexport type StylessReactNativeTextProps = Omit;\n\n/**\n * React Native `View` props, minus the `style` prop.\n */\nexport type StylessReactNativeViewProps = Omit & {\n onPress?: () => void;\n};\n\n/**\n * An intersection between React Native `View` and `Text` props, minus the\n * `style` prop.\n */\nexport type StylessReactNativeProps = Omit & {\n onPress?: () => void;\n};\n\n/**\n * An object containing props targetting either `Text`, `View`, or both.\n */\nexport type ReactNativePropsDefinitions = {\n /**\n * Props that will only apply to `Text`-backed renderers.\n */\n text?: StylessReactNativeTextProps;\n /**\n * Props that will only apply to `View`-backed renderers.\n */\n view?: StylessReactNativeViewProps;\n /**\n * Props that will apply to both `View` and `Text`-backed renderers.\n */\n native?: StylessReactNativeProps;\n};\n\n/**\n * An object containing props targetting either `Text` or `View`.\n */\nexport type ReactNativePropsSwitch = {\n /**\n * Props that will only apply to `Text`-wrapped renderers.\n */\n text?: StylessReactNativeTextProps;\n /**\n * Props that will only apply to `View`-wrapped renderers.\n */\n view?: StylessReactNativeViewProps;\n};\n","import React, { PropsWithChildren, useCallback, useMemo } from 'react';\nimport defaultListStyleSpecs from '../elements/defaultListStyleSpecs';\nimport selectSharedProps from '../helpers/selectSharedProps';\nimport { RenderHTMLSharedProps, RendererBaseProps } from '../shared-types';\nimport defaultSharedProps from './defaultSharedProps';\n\nconst SharedPropsContext = React.createContext(defaultSharedProps);\n\n/**\n * Use shared props. See {@link RenderHTMLSharedProps}.\n *\n * @public\n */\nexport function useSharedProps() {\n return React.useContext(SharedPropsContext);\n}\n\n/**\n * @internal\n */\nexport function useDefaultContainerProps(): Pick<\n RendererBaseProps,\n 'viewProps' | 'textProps'\n> {\n const sharedProps = useSharedProps();\n return {\n viewProps: {\n ...defaultSharedProps.defaultViewProps,\n ...sharedProps.defaultViewProps\n },\n textProps: {\n ...defaultSharedProps.defaultTextProps,\n ...sharedProps.defaultTextProps\n }\n };\n}\n\n/**\n * Compute max width for a given tag. Uses\n * {@link RenderHTMLProps.computeEmbeddedMaxWidth}\n * and {@link RenderHTMLProps.contentWidth} under the hood.\n *\n * @param tagName - The tag to target.\n *\n * @public\n */\nexport function useComputeMaxWidthForTag(tagName: string) {\n const { computeEmbeddedMaxWidth } = useSharedProps();\n return useCallback(\n (cw: number) => {\n return computeEmbeddedMaxWidth(cw, tagName);\n },\n [computeEmbeddedMaxWidth, tagName]\n );\n}\n\n/**\n * @internal\n */\nexport default function SharedPropsProvider(\n props: PropsWithChildren\n) {\n const memoizedSharedProps = useMemo(\n () => ({\n ...selectSharedProps(props),\n customListStyleSpecs: {\n ...defaultListStyleSpecs,\n ...props.customListStyleSpecs\n }\n }),\n // eslint-disable-next-line react-hooks/exhaustive-deps\n Object.values(selectSharedProps(props))\n );\n return React.createElement(\n SharedPropsContext.Provider,\n { value: memoizedSharedProps },\n props.children\n );\n}\n","import CounterStyle from '@jsamr/counter-style';\nimport decimal from '@jsamr/counter-style/presets/decimal';\nimport decimalLeadingZero from '@jsamr/counter-style/presets/decimalLeadingZero';\nimport lowerRoman from '@jsamr/counter-style/presets/lowerRoman';\nimport lowerAlpha from '@jsamr/counter-style/presets/lowerAlpha';\nimport lowerGreek from '@jsamr/counter-style/presets/lowerGreek';\nimport upperAlpha from '@jsamr/counter-style/presets/upperAlpha';\nimport upperRoman from '@jsamr/counter-style/presets/upperRoman';\nimport DisclosureClosedSymbolRenderer from './symbolic/DisclosureClosedSymbolRenderer';\nimport DisclosureOpenSymbolRenderer from './symbolic/DisclosureOpenSymbolRenderer';\nimport CircleSymbolRenderer from './symbolic/CircleSymbolRenderer';\nimport DiscSymbolRenderer from './symbolic/DiscSymbolRenderer';\nimport SquareSymbolRenderer from './symbolic/SquareSymbolRenderer';\nimport type {\n DefaultSupportedListStyleType,\n ListStyleSpec\n} from '../shared-types';\n\nconst unitaryRenderer = CounterStyle.cyclic('*').withSuffix(' ');\n\nconst lowerAlphaSpec = {\n type: 'textual',\n counterStyleRenderer: lowerAlpha\n} as const;\n\nconst upperAlphaSpec = {\n type: 'textual',\n counterStyleRenderer: upperAlpha\n} as const;\n\n/**\n * Default list style specs supported by this library.\n *\n * @public\n */\nconst defaultListStyleSpecs: Record<\n DefaultSupportedListStyleType,\n ListStyleSpec\n> = {\n 'decimal-leading-zero': {\n type: 'textual',\n counterStyleRenderer: decimalLeadingZero\n },\n 'disclosure-closed': {\n counterStyleRenderer: unitaryRenderer,\n type: 'unitary',\n Component: DisclosureClosedSymbolRenderer\n },\n 'disclosure-open': {\n counterStyleRenderer: unitaryRenderer,\n type: 'unitary',\n Component: DisclosureOpenSymbolRenderer\n },\n 'lower-alpha': lowerAlphaSpec,\n 'lower-greek': {\n type: 'textual',\n counterStyleRenderer: lowerGreek\n },\n 'lower-latin': lowerAlphaSpec,\n 'lower-roman': {\n type: 'textual',\n counterStyleRenderer: lowerRoman\n },\n 'upper-alpha': upperAlphaSpec,\n 'upper-latin': upperAlphaSpec,\n 'upper-roman': {\n type: 'textual',\n counterStyleRenderer: upperRoman\n },\n circle: {\n counterStyleRenderer: unitaryRenderer,\n type: 'unitary',\n Component: CircleSymbolRenderer\n },\n decimal: {\n type: 'textual',\n counterStyleRenderer: decimal\n },\n disc: {\n counterStyleRenderer: unitaryRenderer,\n type: 'unitary',\n Component: DiscSymbolRenderer\n },\n none: {\n counterStyleRenderer: CounterStyle.symbolic('').withSuffix(null),\n type: 'unitary',\n Component: () => null\n },\n square: {\n counterStyleRenderer: unitaryRenderer,\n type: 'unitary',\n Component: SquareSymbolRenderer\n }\n};\n\nexport default defaultListStyleSpecs;\n","import CounterStyle from './CounterStyle';\nexport * from './CounterStyle';\nexport * from './public-types';\nexport default CounterStyle;\n//# sourceMappingURL=index.js.map","import getAlphanumFromUnicodeRange from './getAlphanumFromUnicodeRange';\nimport makeAlphanumMaxlenComputer from './makeAlphanumMaxlenComputer';\nimport makeCSEngine from './makeCSEngine';\nimport makeCSRenderer from './makeCSRenderer';\nimport codepointLength from './utils/codepointLength';\nconst mod = (value, divisor) => ((value % divisor) + divisor) % divisor;\nfunction makeCSRendererFromFormatter(formatter) {\n return makeCSRenderer(makeCSEngine(formatter));\n}\nfunction getMaxLenInSymbols(lens, from = 0, to) {\n to = typeof to === 'number' ? to : lens.length;\n return lens.slice(from, to + 1).reduce((p, c) => Math.max(p, c), 0);\n}\nfunction numeric(renderer, length) {\n return renderer\n .withMaxLengthComputer(makeAlphanumMaxlenComputer(length, false))\n .withNegative('-');\n}\nfunction alphabetic(renderer, length) {\n return renderer\n .withMaxLengthComputer(makeAlphanumMaxlenComputer(length, true))\n .withRange(1, Infinity);\n}\n/**\n * A static object to build counter style renderers.\n * See {@link CounterStyleStatic}.\n *\n * @public\n */\nconst CounterStyle = Object.freeze({\n raw: (formatter) => {\n return makeCSRendererFromFormatter(formatter);\n },\n cyclic: (...symbols) => {\n const symbolLenghts = symbols.map(codepointLength);\n const maxLen = getMaxLenInSymbols(symbolLenghts);\n const renderer = symbols.length === 1\n ? makeCSRendererFromFormatter(() => symbols[0])\n : makeCSRendererFromFormatter((index) => symbols[mod(index - 1, symbols.length)]);\n return renderer.withMaxLengthComputer((min, max) => {\n return maxLen === 1 || max - min + 1 >= symbols.length\n ? maxLen\n : getMaxLenInSymbols(symbolLenghts, min - 1, max - 1);\n });\n },\n fixed: (...symbols) => {\n const symbolLenghts = symbols.map(codepointLength);\n const maxLen = getMaxLenInSymbols(symbolLenghts);\n return makeCSRendererFromFormatter((index) => symbols[index - 1])\n .withRange(1, symbols.length)\n .withMaxLengthComputer((min, max) => {\n return maxLen === 1\n ? maxLen\n : getMaxLenInSymbols(symbolLenghts, min - 1, max - 1);\n });\n },\n symbolic: (...symbols) => makeCSRendererFromFormatter((index) => symbols[mod(index - 1, symbols.length)].repeat(Math.ceil(index / symbols.length)))\n .withRange(1, Infinity)\n .withMaxLengthComputer((min, max, defaultCmp) => {\n // Just iterate over the last n elements until max, with n the number\n // of symbols.\n return defaultCmp(max < symbols.length ? min : max - symbols.length, max);\n }),\n alphabetic: (...symbols) => {\n return alphabetic(makeCSRendererFromFormatter((index) => {\n let result = '';\n while (index > 0) {\n index--;\n result = symbols[mod(index, symbols.length)] + result;\n index = Math.floor(index / symbols.length);\n }\n return result;\n }), symbols.length);\n },\n numeric: (...symbols) => {\n return numeric(makeCSRendererFromFormatter((index) => {\n if (index === 0) {\n return symbols[0];\n }\n else {\n let result = '';\n while (index > 0) {\n result = symbols[mod(index, symbols.length)] + result;\n index = Math.floor(index / symbols.length);\n }\n return result;\n }\n }), symbols.length);\n },\n numericFromUnicodeRange: (originUnicode, base) => {\n return numeric(makeCSRendererFromFormatter((index) => getAlphanumFromUnicodeRange(index, originUnicode, base, false)), base);\n },\n alphabeticFromUnicodeRange: (originUnicode, alphabetLen) => {\n return alphabetic(makeCSRendererFromFormatter((index) => {\n return getAlphanumFromUnicodeRange(index, originUnicode, alphabetLen, true);\n }), alphabetLen);\n },\n additive: (symbols) => {\n const values = Object.keys(symbols)\n .map((value) => parseInt(value, 10))\n .sort((a, b) => b - a);\n return makeCSRendererFromFormatter((index) => {\n if (index === 0) {\n return symbols[0];\n }\n let result = '';\n for (const value of values) {\n if (index >= value && value > 0) {\n const repeat = Math.floor(index / value);\n result += symbols[value].repeat(repeat);\n index -= repeat * value;\n }\n }\n return index === 0 ? result : undefined;\n }).withRange(values.length ? values[values.length - 1] : 0, 0 in symbols && values.length === 1 ? 0 : values.length ? Infinity : -1);\n }\n});\nexport default CounterStyle;\n//# sourceMappingURL=CounterStyle.js.map","/**\n * Create an alphabetic initial counter representation from an UTF-16 unicode\n * and a range.\n *\n * @param index - The index to render.\n * @param baseCharcode - The original UTF-16 unicode.\n * @param modulo - The number of symbols in the set.\n * @param alpha - In alpha mode, index starts at 1 instead of 0.\n * @returns\n */\nfunction getAlphanumFromUnicodeRange(index, baseCharcode, modulo, alpha) {\n const reindex = index - Number(alpha);\n if (reindex < 0) {\n return undefined;\n }\n if (reindex < modulo) {\n return String.fromCharCode(baseCharcode + reindex);\n }\n const rest = reindex % modulo;\n const next = (reindex - rest - modulo) / modulo + 1;\n return (getAlphanumFromUnicodeRange(next, baseCharcode, modulo, alpha) +\n String.fromCharCode(baseCharcode + rest));\n}\nexport default getAlphanumFromUnicodeRange;\n//# sourceMappingURL=getAlphanumFromUnicodeRange.js.map","export default function makeAlphanumMaxlenComputer(base, alpha) {\n return function alphanumericMaxLenComputer(_min, max) {\n let remax = max - Number(alpha);\n let digits = 1;\n while (remax >= base) {\n remax /= base;\n digits++;\n }\n return digits;\n };\n}\n//# sourceMappingURL=makeAlphanumMaxlenComputer.js.map","import codepointLength from './utils/codepointLength';\nimport { DEFAULT_SUFFIX } from './constants';\nconst DEFAULT_SPECS = {\n suffix: DEFAULT_SUFFIX,\n prefix: null,\n reversedMarker: false,\n reversedCounter: false,\n fallback: {\n renderCounter: (index) => index.toString(),\n maxCounterLenInRange(min, max) {\n return Math.max(this.renderCounter(min).length, this.renderCounter(max).length);\n }\n },\n negative: null,\n range: {\n min: -Infinity,\n max: Infinity\n },\n padding: null\n};\nconst styleEngineProto = {\n // Cost-inefficient since it requires iterating over the whole range.\n maxLengthInRange(min, max) {\n let len = 0;\n for (let i = Math.max(0, min); i <= max; i++) {\n const val = this.formatter(i);\n len = Math.max(codepointLength(val), len);\n }\n return len;\n },\n withSpecs(spToMerge) {\n const next = Object.create(this);\n next.specs = Object.assign({}, this.specs, spToMerge);\n return next;\n },\n withMaxLengthInRange(cp) {\n const next = Object.create(this);\n next.maxLengthInRange = cp;\n return next;\n }\n};\nexport default function makeCSEngine(formatter, specs = DEFAULT_SPECS) {\n const eng = Object.create(styleEngineProto);\n eng.specs = specs;\n eng.formatter = formatter;\n return eng;\n}\n//# sourceMappingURL=makeCSEngine.js.map","export default function codepointLength(source) {\n // get codepoints length instead of UTF16 code units with the string Iterator.\n return (source && [...source].length) || 0;\n}\n//# sourceMappingURL=codepointLength.js.map","/**\n * See https://www.w3.org/TR/css-counter-styles-3/#counter-style-suffix\n *\n * @remarks We are using non-breaking space, otherwise iOS text elements get trimmed.\n */\nexport const DEFAULT_SUFFIX = '\\u002E\\u00A0';\nexport const CJK_SUFFIX = '\\u3001';\n//# sourceMappingURL=constants.js.map","import codepointLength from './utils/codepointLength';\nimport codeunitLength from './utils/codeunitLength';\nimport reverseString from './utils/reverseString';\nconst defaultRtlOptions = {\n reverseCounter: false,\n reversePrefix: true,\n reverseSuffix: true\n};\nconst stylePrototype = {\n getAbsoluteMaxLenInRange(normMin, normMax, negative) {\n var _a;\n const specs = this.engine.specs;\n const supportedRange = specs.range;\n const supportedMin = Math.max(normMin, supportedRange.min);\n const supportedMax = Math.min(normMax, supportedRange.max);\n const lenMiddle = Math.max(this.engine.maxLengthInRange(negative ? Math.abs(supportedMax) : supportedMin, negative ? Math.abs(supportedMin) : supportedMax) +\n (negative && specs.negative\n ? codeunitLength(specs.negative.prefix) +\n codeunitLength(specs.negative.suffix)\n : 0), ((_a = specs === null || specs === void 0 ? void 0 : specs.padding) === null || _a === void 0 ? void 0 : _a.length) || 0);\n const lenLeft = supportedMin > normMin\n ? specs.fallback.maxCounterLenInRange(normMin, supportedMin - 1)\n : 0;\n const lenRight = supportedMax < normMax\n ? specs.fallback.maxCounterLenInRange(supportedMax + 1, normMax)\n : 0;\n return Math.max(lenLeft, lenMiddle, lenRight);\n },\n maxCounterLenInRange(min, max) {\n if (max < min) {\n return 0;\n }\n if (min >= 0) {\n return this.getAbsoluteMaxLenInRange(min, max, false);\n }\n if (max <= 0) {\n return this.getAbsoluteMaxLenInRange(min, max, true);\n }\n return Math.max(this.getAbsoluteMaxLenInRange(min, -1, true), this.getAbsoluteMaxLenInRange(0, max, false));\n },\n maxMarkerLenInRange(min, max) {\n if (max < min) {\n return 0;\n }\n return (this.maxCounterLenInRange(min, max) +\n codeunitLength(this.engine.specs.suffix) +\n codeunitLength(this.engine.specs.prefix));\n },\n renderCounter(index) {\n const formatter = this.engine.formatter;\n const sp = this.engine.specs;\n const negative = sp.negative;\n let res;\n if (index < sp.range.min || index > sp.range.max) {\n return sp.fallback.renderCounter(index);\n }\n const decoratorL = negative && index < 0\n ? codeunitLength(negative.prefix) + codeunitLength(negative.suffix)\n : 0;\n res = formatter(Math.sign(index) * index);\n if (typeof res === 'undefined') {\n return sp.fallback.renderCounter(index);\n }\n if (sp.padding) {\n const lenWithDecorator = codepointLength(res) + decoratorL;\n if (lenWithDecorator < sp.padding.length) {\n const padChar = sp.padding.char.repeat(sp.padding.length - lenWithDecorator);\n res = sp.padding.right ? res + padChar : padChar + res;\n }\n }\n if (index < 0 && negative) {\n res = negative.prefix + res + negative.suffix;\n }\n return sp.reversedCounter ? reverseString(res) : res;\n },\n renderMarker(index) {\n const sp = this.engine.specs;\n const elements = [\n sp.prefix || '',\n this.renderCounter(index),\n sp.suffix || ''\n ];\n return sp.reversedMarker ? elements.reverse().join('') : elements.join('');\n },\n renderPrefix() {\n return this.engine.specs.prefix || '';\n },\n renderSuffix() {\n return this.engine.specs.suffix || '';\n },\n withFallback(fallback) {\n return makeCSRenderer(this.engine.withSpecs({ fallback }));\n },\n withRange(min, max, fallback) {\n const result = makeCSRenderer(this.engine.withSpecs({\n range: {\n min,\n max\n }\n }));\n return fallback ? result.withFallback(fallback) : result;\n },\n withNegative(prefix, suffix = '') {\n return makeCSRenderer(this.engine.withSpecs({\n negative: {\n prefix,\n suffix\n }\n }));\n },\n withPadLeft(length, pad) {\n return makeCSRenderer(this.engine.withSpecs({\n padding: {\n right: false,\n char: pad,\n length\n }\n }));\n },\n withPadRight(length, pad) {\n return makeCSRenderer(this.engine.withSpecs({\n padding: {\n right: true,\n char: pad,\n length\n }\n }));\n },\n withSuffix(suffix) {\n return makeCSRenderer(this.engine.withSpecs({\n suffix\n }));\n },\n withPrefix(prefix) {\n return makeCSRenderer(this.engine.withSpecs({\n prefix\n }));\n },\n withRtl(options) {\n const synthOptions = Object.assign({}, defaultRtlOptions, options);\n const sp = this.engine.specs;\n return makeCSRenderer(this.engine.withSpecs({\n reversedMarker: true,\n reversedCounter: synthOptions.reverseCounter,\n suffix: synthOptions.reverseSuffix && sp.suffix\n ? reverseString(sp.suffix)\n : sp.suffix,\n prefix: synthOptions.reversePrefix && sp.prefix\n ? reverseString(sp.prefix)\n : sp.prefix\n }));\n },\n withMaxLengthComputer(computer) {\n return makeCSRenderer(this.engine.withMaxLengthInRange((min, max) => computer(min, max, this.engine.maxLengthInRange.bind(this.engine))));\n }\n};\nexport default function makeCSRenderer(engine) {\n const target = Object.create(stylePrototype);\n target.engine = engine;\n return Object.freeze(target);\n}\n//# sourceMappingURL=makeCSRenderer.js.map","export default function codeunitLength(source) {\n return (source && source.length) || 0;\n}\n//# sourceMappingURL=codeunitLength.js.map","export default function reverseString(source) {\n return Array.from(source).reverse().join('');\n}\n//# sourceMappingURL=reverseString.js.map","export {};\n//# sourceMappingURL=public-types.js.map","import CounterStyle from '../CounterStyle';\nimport makeAlphanumMaxlenComputer from '../makeAlphanumMaxlenComputer';\n// Default implementation is faster than invoking CounterStyle.numeric\nconst decimal = CounterStyle.raw((index) => index.toString())\n .withMaxLengthComputer(makeAlphanumMaxlenComputer(10, false))\n .withNegative('-');\nexport default decimal;\n//# sourceMappingURL=decimal.js.map","import decimal from './decimal';\nconst decimalLeadingZero = decimal.withPadLeft(2, '0');\nexport default decimalLeadingZero;\n//# sourceMappingURL=decimalLeadingZero.js.map","import CounterStyle from '../CounterStyle';\nconst lowerRoman = CounterStyle.additive({\n 1000: 'm',\n 900: 'cm',\n 500: 'd',\n 400: 'cd',\n 100: 'c',\n 90: 'xc',\n 50: 'l',\n 40: 'xl',\n 10: 'x',\n 9: 'ix',\n 5: 'v',\n 4: 'iv',\n 1: 'i'\n}).withRange(1, 3999);\nexport default lowerRoman;\n//# sourceMappingURL=lowerRoman.js.map","import CounterStyle from '../CounterStyle';\nconst lowerAlpha = CounterStyle.alphabeticFromUnicodeRange(97, 26);\nexport default lowerAlpha;\n//# sourceMappingURL=lowerAlpha.js.map","import CounterStyle from '../CounterStyle';\nconst lowerGreek = CounterStyle.alphabeticFromUnicodeRange(\n/* α β γ δ ε ζ η θ ι κ λ μ ν ξ ο π ρ σ τ υ φ χ ψ ω */\n0x3b1, 24);\nexport default lowerGreek;\n//# sourceMappingURL=lowerGreek.js.map","import CounterStyle from '../CounterStyle';\nexport const upperAlpha = CounterStyle.alphabeticFromUnicodeRange(65, 26);\nexport default upperAlpha;\n//# sourceMappingURL=upperAlpha.js.map","import CounterStyle from '../CounterStyle';\nconst upperRoman = CounterStyle.additive({\n 1000: 'M',\n 900: 'CM',\n 500: 'D',\n 400: 'CD',\n 100: 'C',\n 90: 'XC',\n 50: 'L',\n 40: 'XL',\n 10: 'X',\n 9: 'IX',\n 5: 'V',\n 4: 'IV',\n 1: 'I'\n}).withRange(1, 3999);\nexport default upperRoman;\n//# sourceMappingURL=upperRoman.js.map","import React from 'react';\nimport { View } from 'react-native';\nimport { UnitaryCounterRendererProps } from '../../shared-types';\nimport useSymbolicMarkerRendererProps from './useSymbolicMarkerRendererStyles';\n\nexport default function DisclosureClosedSymbolRenderer(\n props: UnitaryCounterRendererProps\n) {\n const {\n prefixStyle: { top },\n prefixSize\n } = useSymbolicMarkerRendererProps(props, 1);\n return React.createElement(View, {\n style: {\n top,\n width: 0,\n height: 0,\n borderStyle: 'solid',\n borderLeftWidth: prefixSize,\n borderLeftColor: props.color,\n borderTopWidth: prefixSize / 2,\n borderTopColor: 'transparent',\n borderBottomWidth: prefixSize / 2,\n borderBottomColor: 'transparent'\n }\n });\n}\n","import { UnitaryCounterRendererProps } from '../../shared-types';\n\nexport default function useSymbolicMarkerRendererProps(\n props: UnitaryCounterRendererProps,\n shrinkFactor = 1\n) {\n const prefixSize = props.fontSize / (shrinkFactor * 2.8);\n return {\n prefixSize,\n prefixStyle: {\n width: prefixSize,\n height: prefixSize,\n // center the item vertically, relative to line height\n top: (props.lineHeight - prefixSize) / 2\n }\n };\n}\n","import React from 'react';\nimport { View } from 'react-native';\nimport { UnitaryCounterRendererProps } from '../../shared-types';\nimport useSymbolicMarkerRendererProps from './useSymbolicMarkerRendererStyles';\n\nexport default function DisclosureOpenSymbolRenderer(\n props: UnitaryCounterRendererProps\n) {\n const {\n prefixStyle: { top },\n prefixSize\n } = useSymbolicMarkerRendererProps(props, 1);\n return React.createElement(View, {\n style: {\n top,\n width: 0,\n height: 0,\n borderStyle: 'solid',\n borderTopWidth: prefixSize,\n borderTopColor: props.color,\n borderLeftWidth: prefixSize / 2,\n borderLeftColor: 'transparent',\n borderRightWidth: prefixSize / 2,\n borderRightColor: 'transparent'\n }\n });\n}\n","import React from 'react';\nimport { View } from 'react-native';\nimport { UnitaryCounterRendererProps } from '../../shared-types';\nimport useSymbolicMarkerRendererProps from './useSymbolicMarkerRendererStyles';\n\nexport default function CircleSymbolRenderer(\n props: UnitaryCounterRendererProps\n) {\n const { prefixSize, prefixStyle } = useSymbolicMarkerRendererProps(props);\n const style = {\n borderColor: props.color,\n borderWidth: prefixSize / 10,\n borderRadius: prefixSize,\n ...prefixStyle\n };\n return ;\n}\n","import React from 'react';\nimport { View } from 'react-native';\nimport { UnitaryCounterRendererProps } from '../../shared-types';\nimport useSymbolicMarkerRendererProps from './useSymbolicMarkerRendererStyles';\n\nexport default function DiscSymbolRenderer(props: UnitaryCounterRendererProps) {\n const { prefixSize, prefixStyle } = useSymbolicMarkerRendererProps(props);\n const style = {\n borderRadius: prefixSize,\n backgroundColor: props.color,\n ...prefixStyle\n };\n return ;\n}\n","import React from 'react';\nimport { View } from 'react-native';\nimport { UnitaryCounterRendererProps } from '../../shared-types';\nimport useSymbolicMarkerRendererProps from './useSymbolicMarkerRendererStyles';\n\nexport default function SquareSymbolRenderer(\n props: UnitaryCounterRendererProps\n) {\n const { prefixStyle } = useSymbolicMarkerRendererProps(props, 1.2);\n return React.createElement(View, {\n style: {\n backgroundColor: props.color,\n ...prefixStyle\n }\n });\n}\n","import pickBy from 'ramda/src/pickBy';\nimport pick from 'ramda/src/pick';\nimport pipe from 'ramda/src/pipe';\nimport mergeRight from 'ramda/src/mergeRight';\nimport { RenderHTMLProps, RenderHTMLAmbiantSharedProps } from '../shared-types';\nimport defaultSharedProps from '../context/defaultSharedProps';\n\nconst selectSharedProps: (\n props: Partial\n) => RenderHTMLAmbiantSharedProps = pipe(\n pick(Object.keys(defaultSharedProps)),\n pickBy((val) => val != null),\n mergeRight(defaultSharedProps) as any\n);\n\nexport default selectSharedProps;\n","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Returns a partial copy of an object containing only the keys that satisfy\n * the supplied predicate.\n *\n * @func\n * @memberOf R\n * @since v0.8.0\n * @category Object\n * @sig ((v, k) -> Boolean) -> {k: v} -> {k: v}\n * @param {Function} pred A predicate to determine whether or not a key\n * should be included on the output object.\n * @param {Object} obj The object to copy from\n * @return {Object} A new object with only properties that satisfy `pred`\n * on it.\n * @see R.pick, R.filter\n * @example\n *\n * const isUpperCase = (val, key) => key.toUpperCase() === key;\n * R.pickBy(isUpperCase, {a: 1, b: 2, A: 3, B: 4}); //=> {A: 3, B: 4}\n */\n\n\nvar pickBy =\n/*#__PURE__*/\n_curry2(function pickBy(test, obj) {\n var result = {};\n\n for (var prop in obj) {\n if (test(obj[prop], prop, obj)) {\n result[prop] = obj[prop];\n }\n }\n\n return result;\n});\n\nmodule.exports = pickBy;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Returns a partial copy of an object containing only the keys specified. If\n * the key does not exist, the property is ignored.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Object\n * @sig [k] -> {k: v} -> {k: v}\n * @param {Array} names an array of String property names to copy onto a new object\n * @param {Object} obj The object to copy from\n * @return {Object} A new object with only properties from `names` on it.\n * @see R.omit, R.props\n * @example\n *\n * R.pick(['a', 'd'], {a: 1, b: 2, c: 3, d: 4}); //=> {a: 1, d: 4}\n * R.pick(['a', 'e', 'f'], {a: 1, b: 2, c: 3, d: 4}); //=> {a: 1}\n */\n\n\nvar pick =\n/*#__PURE__*/\n_curry2(function pick(names, obj) {\n var result = {};\n var idx = 0;\n\n while (idx < names.length) {\n if (names[idx] in obj) {\n result[names[idx]] = obj[names[idx]];\n }\n\n idx += 1;\n }\n\n return result;\n});\n\nmodule.exports = pick;","var _objectAssign =\n/*#__PURE__*/\nrequire(\"./internal/_objectAssign\");\n\nvar _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Create a new object with the own properties of the first object merged with\n * the own properties of the second object. If a key exists in both objects,\n * the value from the second object will be used.\n *\n * @func\n * @memberOf R\n * @since v0.26.0\n * @category Object\n * @sig {k: v} -> {k: v} -> {k: v}\n * @param {Object} l\n * @param {Object} r\n * @return {Object}\n * @see R.mergeLeft, R.mergeDeepRight, R.mergeWith, R.mergeWithKey\n * @example\n *\n * R.mergeRight({ 'name': 'fred', 'age': 10 }, { 'age': 40 });\n * //=> { 'name': 'fred', 'age': 40 }\n *\n * const withDefaults = R.mergeRight({x: 0, y: 0});\n * withDefaults({y: 2}); //=> {x: 0, y: 2}\n * @symb R.mergeRight(a, b) = {...a, ...b}\n */\n\n\nvar mergeRight =\n/*#__PURE__*/\n_curry2(function mergeRight(l, r) {\n return _objectAssign({}, l, r);\n});\n\nmodule.exports = mergeRight;","var _has =\n/*#__PURE__*/\nrequire(\"./_has\"); // Based on https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/Object/assign\n\n\nfunction _objectAssign(target) {\n if (target == null) {\n throw new TypeError('Cannot convert undefined or null to object');\n }\n\n var output = Object(target);\n var idx = 1;\n var length = arguments.length;\n\n while (idx < length) {\n var source = arguments[idx];\n\n if (source != null) {\n for (var nextKey in source) {\n if (_has(nextKey, source)) {\n output[nextKey] = source[nextKey];\n }\n }\n }\n\n idx += 1;\n }\n\n return output;\n}\n\nmodule.exports = typeof Object.assign === 'function' ? Object.assign : _objectAssign;","function _has(prop, obj) {\n return Object.prototype.hasOwnProperty.call(obj, prop);\n}\n\nmodule.exports = _has;","import { DEFAULT_PRESSABLE_RIPPLE_COLOR } from '../constants';\nimport { RenderHTMLAmbiantSharedProps } from '../shared-types';\n\nfunction WebViewPlaceholder() {\n /* istanbul ignore else */\n if (typeof __DEV__ === 'boolean' && __DEV__) {\n console.warn(\n 'One of your renderers is attempting to use WebView component, which has not been ' +\n \"provided as a prop to the RenderHtml component. As a consequence, the element won't be rendered.\"\n );\n }\n return null;\n}\n\nconst defaultSharedProps: RenderHTMLAmbiantSharedProps = {\n bypassAnonymousTPhrasingNodes: true,\n debug: false,\n defaultTextProps: {\n selectable: false,\n allowFontScaling: true\n },\n defaultViewProps: {},\n enableExperimentalBRCollapsing: false,\n enableExperimentalGhostLinesPrevention: false,\n enableExperimentalMarginCollapsing: false,\n computeEmbeddedMaxWidth: (contentWidth) => contentWidth,\n WebView: WebViewPlaceholder,\n defaultWebViewProps: {},\n pressableHightlightColor: DEFAULT_PRESSABLE_RIPPLE_COLOR,\n provideEmbeddedHeaders: undefined,\n GenericPressable: undefined,\n customListStyleSpecs: undefined\n};\n\nexport default defaultSharedProps;\n","const DEFAULT_TEXT_COLOR = 'black';\nconst DEFAULT_PRESSABLE_RIPPLE_COLOR = 'rgba(38, 132, 240, 0.2)';\n\nconst constants = {\n DEFAULT_PRESSABLE_RIPPLE_COLOR,\n DEFAULT_TEXT_COLOR\n};\n\nexport { DEFAULT_TEXT_COLOR, DEFAULT_PRESSABLE_RIPPLE_COLOR };\n\nexport default constants;\n","import React, { useContext } from 'react';\nimport { DocumentMetadata } from '../shared-types';\n\nconst DocumentMetadataContext = React.createContext({\n baseUrl: '',\n baseTarget: '_self',\n lang: 'en',\n links: [],\n meta: [],\n title: '',\n dir: 'ltr'\n});\n\nconst DocumentMetadataProvider = DocumentMetadataContext.Provider;\n\n/**\n * Get access to the parsed HTML metadata anywhere in the render tree.\n */\nexport function useDocumentMetadata() {\n return useContext(DocumentMetadataContext);\n}\n\nexport default DocumentMetadataProvider;\n","import React, { useMemo } from 'react';\nimport { TBlock } from '@native-html/transient-render-engine';\nimport IMGElement, { IMGElementProps } from '../elements/IMGElement';\nimport { InternalBlockRenderer } from '../render/render-types';\nimport { useComputeMaxWidthForTag } from '../context/SharedPropsProvider';\nimport { ImageStyle, StyleSheet } from 'react-native';\nimport { InternalRendererProps } from '../shared-types';\nimport useNormalizedUrl from '../hooks/useNormalizedUrl';\nimport { useRendererProps } from '../context/RenderersPropsProvider';\nimport useContentWidth from '../hooks/useContentWidth';\nimport getNativePropsForTNode from '../helpers/getNativePropsForTNode';\n\n/**\n * A hook to produce props consumable by {@link IMGElement} component\n * from custom renderer props.\n */\nexport function useIMGElementProps(\n props: InternalRendererProps\n): IMGElementProps {\n const { tnode } = props;\n\n const contentWidth = useContentWidth();\n const { initialDimensions, enableExperimentalPercentWidth } =\n useRendererProps('img');\n const computeImagesMaxWidth = useComputeMaxWidthForTag('img');\n const src = tnode.attributes.src || '';\n const source = { uri: useNormalizedUrl(src) };\n const { style: rawStyle, ...containerProps } = getNativePropsForTNode(props);\n const style = useMemo(\n () => (rawStyle ? (StyleSheet.flatten(rawStyle) as ImageStyle) : {}),\n [rawStyle]\n );\n return {\n contentWidth,\n containerProps,\n enableExperimentalPercentWidth,\n initialDimensions,\n source,\n style,\n testID: 'img',\n computeMaxWidth: computeImagesMaxWidth,\n alt: tnode.attributes.alt,\n altColor: tnode.styles.nativeTextFlow.color as string,\n width: tnode.attributes.width,\n height: tnode.attributes.height,\n objectFit: tnode.styles.webBlockRet.objectFit\n };\n}\n\nconst IMGRenderer: InternalBlockRenderer = (props) => {\n return React.createElement(IMGElement, useIMGElementProps(props));\n};\n\nexport default IMGRenderer;\n","import React, { ReactElement, ReactNode } from 'react';\nimport PropTypes from 'prop-types';\nimport useIMGElementState from './useIMGElementState';\nimport IMGElementContentSuccess from './IMGElementContentSuccess';\nimport IMGElementContainer from './IMGElementContainer';\nimport IMGElementContentLoading from './IMGElementContentLoading';\nimport IMGElementContentError from './IMGElementContentError';\nimport type { IMGElementProps } from './img-types';\nimport defaultImageInitialDimensions from './defaultInitialImageDimensions';\n\nexport type { IMGElementProps } from './img-types';\n\nfunction identity(arg: any) {\n return arg;\n}\n\n/**\n * A component to render images based on an internal loading state.\n *\n * @remarks This component will attempt to draw a box of paint dimensions\n * before retrieving the physical dimensions of the image to avoid layout\n * shifts. See also {@link useIMGElementState}, {@link IMGElementContainer},\n * {@link IMGElementContentSuccess}, {@link IMGElementContentLoading}\n * and {@link IMGElementContentError} for customization.\n */\nfunction IMGElement(props: IMGElementProps): ReactElement {\n const state = useIMGElementState(props);\n let content: ReactNode;\n if (state.type === 'success') {\n content = React.createElement(IMGElementContentSuccess, state);\n } else if (state.type === 'loading') {\n content = React.createElement(IMGElementContentLoading, state);\n } else {\n content = React.createElement(IMGElementContentError, state);\n }\n return (\n \n {content}\n \n );\n}\n\nconst imgDimensionsType = PropTypes.shape({\n width: PropTypes.number,\n height: PropTypes.number\n});\n\nconst propTypes: Record = {\n source: PropTypes.object.isRequired,\n alt: PropTypes.string,\n altColor: PropTypes.string,\n height: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n width: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n style: PropTypes.oneOfType([PropTypes.object, PropTypes.array]),\n computeMaxWidth: PropTypes.func.isRequired,\n contentWidth: PropTypes.number,\n enableExperimentalPercentWidth: PropTypes.bool,\n initialDimensions: imgDimensionsType,\n onPress: PropTypes.func,\n testID: PropTypes.string,\n objectFit: PropTypes.string,\n cachedNaturalDimensions: imgDimensionsType,\n containerProps: PropTypes.object\n};\n\n/**\n * @ignore\n */\nIMGElement.propTypes = propTypes;\n\n/**\n * @ignore\n */\nIMGElement.defaultProps = {\n enableExperimentalPercentWidth: false,\n computeMaxWidth: identity,\n imagesInitialDimensions: defaultImageInitialDimensions,\n style: {}\n};\n\nexport default IMGElement;\n","import { useEffect, useState } from 'react';\nimport { Image, ImageURISource } from 'react-native';\nimport {\n UseIMGElementStateProps,\n IMGElementState,\n IncompleteImageDimensions\n} from './img-types';\nimport defaultImageInitialDimensions from './defaultInitialImageDimensions';\nimport useIMGNormalizedSource from './useIMGNormalizedSource';\nimport { ImageDimensions } from '../shared-types';\nimport useImageConcreteDimensions from './useImageConcreteDimensions';\nimport { getIMGState } from './getIMGState';\nimport useImageSpecifiedDimensions from './useImageSpecifiedDimensions';\n\nfunction getImageSizeAsync({\n uri,\n headers\n}: {\n headers: any;\n uri: string;\n}): Promise {\n return new Promise((onsuccess, onerror) => {\n const onImageDimensionsSuccess = (width: number, height: number) =>\n onsuccess({ width, height });\n if (headers) {\n Image.getSizeWithHeaders(uri, headers, onImageDimensionsSuccess, onerror);\n } else {\n Image.getSize(uri, onImageDimensionsSuccess, onerror);\n }\n });\n}\n\nfunction useImageNaturalDimensions

(props: {\n cachedNaturalDimensions?: ImageDimensions;\n source: ImageURISource;\n specifiedDimensions: IncompleteImageDimensions;\n}) {\n const { source, cachedNaturalDimensions } = props;\n const [naturalDimensions, setNaturalDimensions] = useState<\n P['cachedNaturalDimensions'] extends ImageDimensions\n ? ImageDimensions\n : ImageDimensions | null\n >((cachedNaturalDimensions as any) || null);\n const { width: cachedNaturalWidth, height: cachedNaturalHeight } =\n cachedNaturalDimensions || {};\n const [error, setError] = useState(null);\n useEffect(\n function resetOnURIChange() {\n setNaturalDimensions(\n (cachedNaturalWidth != null && cachedNaturalHeight != null\n ? { width: cachedNaturalWidth, height: cachedNaturalHeight }\n : null) as any\n );\n setError(null);\n },\n [cachedNaturalHeight, cachedNaturalWidth, source.uri]\n );\n return {\n onNaturalDimensions: setNaturalDimensions,\n onError: setError,\n naturalDimensions,\n error\n };\n}\n\nfunction useFetchedNaturalDimensions(props: {\n cachedNaturalDimensions?: ImageDimensions;\n source: ImageURISource;\n specifiedDimensions: IncompleteImageDimensions;\n}) {\n const { source, cachedNaturalDimensions } = props;\n const { error, naturalDimensions, onError, onNaturalDimensions } =\n useImageNaturalDimensions(props);\n const hasCachedDimensions = !!cachedNaturalDimensions;\n useEffect(\n function fetchPhysicalDimensions() {\n let cancelled = false;\n if (source.uri && !hasCachedDimensions) {\n getImageSizeAsync({ uri: source.uri, headers: source.headers })\n .then((dimensions) => !cancelled && onNaturalDimensions(dimensions))\n .catch((e) => !cancelled && onError(e || {}));\n return () => {\n cancelled = true;\n };\n }\n },\n [\n source.uri,\n source.headers,\n onNaturalDimensions,\n onError,\n hasCachedDimensions\n ]\n );\n return {\n naturalDimensions,\n error,\n onError,\n onNaturalDimensions\n };\n}\n\n/**\n * This hook will compute concrete dimensions from image natural dimensions and\n * constraints. It will fetch the image and get its dimensions.\n *\n * @remarks If you know the dimensions beforehand, use\n * {@link useIMGElementStateWithCache} instead to save a network request and\n * prevent a layout shift.\n */\nexport default function useIMGElementState(\n props: UseIMGElementStateProps\n): IMGElementState {\n const {\n alt,\n altColor,\n source,\n contentWidth,\n computeMaxWidth,\n objectFit,\n initialDimensions = defaultImageInitialDimensions,\n cachedNaturalDimensions\n } = props;\n const { flatStyle, specifiedDimensions } = useImageSpecifiedDimensions(props);\n const nomalizedSource = useIMGNormalizedSource({\n specifiedDimensions,\n source\n });\n const { naturalDimensions, onError, error } = useFetchedNaturalDimensions({\n source: nomalizedSource,\n specifiedDimensions,\n cachedNaturalDimensions\n });\n const concreteDimensions = useImageConcreteDimensions({\n flatStyle,\n naturalDimensions,\n specifiedDimensions,\n computeMaxWidth,\n contentWidth\n });\n\n return getIMGState({\n error,\n alt,\n altColor,\n concreteDimensions,\n containerStyle: flatStyle,\n initialDimensions,\n objectFit,\n onError,\n source: nomalizedSource\n });\n}\n","import { ImageDimensions } from '../shared-types';\n\nconst defaultImageInitialDimensions: ImageDimensions = {\n width: 100,\n height: 100\n};\n\nexport default defaultImageInitialDimensions;\n","import { useMemo, useRef } from 'react';\nimport { useSharedProps } from '../context/SharedPropsProvider';\nimport {\n IncompleteImageDimensions,\n UseIMGElementStateProps\n} from './img-types';\n\nexport default function useIMGNormalizedSource({\n source,\n specifiedDimensions\n}: Pick & {\n specifiedDimensions: IncompleteImageDimensions;\n}) {\n const cachedDimensions = useRef(specifiedDimensions);\n const { provideEmbeddedHeaders } = useSharedProps();\n return useMemo(() => {\n if (source.uri && typeof provideEmbeddedHeaders === 'function') {\n const headers = provideEmbeddedHeaders(source.uri, 'img', {\n printWidth: cachedDimensions.current?.width || undefined,\n printHeight: cachedDimensions.current?.height || undefined\n });\n if (headers) {\n return {\n headers,\n ...source\n };\n }\n }\n return source;\n }, [provideEmbeddedHeaders, source]);\n}\n","import { useMemo } from 'react';\nimport { ImageStyle } from 'react-native';\nimport { ImageDimensions } from '../shared-types';\nimport {\n IncompleteImageDimensions,\n UseIMGElementStateProps\n} from './img-types';\n\nexport type ConcreteDimensionsProps = {\n flatStyle: ImageStyle;\n naturalDimensions: ImageDimensions | null;\n specifiedDimensions: IncompleteImageDimensions;\n} & Pick;\n\nfunction extractHorizontalSpace({\n marginHorizontal,\n leftMargin,\n rightMargin,\n margin\n}: any) {\n const realLeftMargin = leftMargin || marginHorizontal || margin || 0;\n const realRightMargin = rightMargin || marginHorizontal || margin || 0;\n return realLeftMargin + realRightMargin;\n}\n\nfunction scaleUp(\n minDimensions: ImageDimensions,\n desiredDimensions: ImageDimensions\n): ImageDimensions {\n const aspectRatio = desiredDimensions.width / desiredDimensions.height;\n if (desiredDimensions.width < minDimensions.width) {\n return scaleUp(minDimensions, {\n width: minDimensions.width,\n height: minDimensions.width / aspectRatio\n });\n }\n if (desiredDimensions.height < minDimensions.height) {\n return scaleUp(minDimensions, {\n height: minDimensions.height,\n width: minDimensions.height * aspectRatio\n });\n }\n return desiredDimensions;\n}\n\nfunction scaleDown(\n maxDimensions: ImageDimensions,\n desiredDimensions: ImageDimensions\n): ImageDimensions {\n const aspectRatio = desiredDimensions.width / desiredDimensions.height;\n if (desiredDimensions.width > maxDimensions.width) {\n return scaleDown(maxDimensions, {\n width: maxDimensions.width,\n height: maxDimensions.width / aspectRatio\n });\n }\n if (desiredDimensions.height > maxDimensions.height) {\n return scaleDown(maxDimensions, {\n height: maxDimensions.height,\n width: maxDimensions.height * aspectRatio\n });\n }\n return desiredDimensions;\n}\n\nfunction scale(\n { minBox, maxBox }: { maxBox: ImageDimensions; minBox: ImageDimensions },\n originalBox: ImageDimensions\n) {\n return scaleDown(maxBox, scaleUp(minBox, originalBox));\n}\n\nfunction computeConcreteDimensions(params: any) {\n const {\n computeMaxWidth,\n contentWidth,\n flattenStyles,\n naturalWidth,\n naturalHeight,\n specifiedWidth,\n specifiedHeight\n } = params;\n const horizontalSpace = extractHorizontalSpace(flattenStyles);\n const {\n maxWidth = Infinity,\n maxHeight = Infinity,\n minWidth = 0,\n minHeight = 0\n } = flattenStyles;\n const imagesMaxWidth =\n typeof contentWidth === 'number' ? computeMaxWidth(contentWidth) : Infinity;\n const minBox = {\n width: minWidth,\n height: minHeight\n };\n const maxBox = {\n width:\n Math.min(\n imagesMaxWidth,\n maxWidth,\n typeof specifiedWidth === 'number' ? specifiedWidth : Infinity\n ) - horizontalSpace,\n height: Math.min(\n typeof specifiedHeight === 'number' ? specifiedHeight : Infinity,\n maxHeight\n )\n };\n if (\n typeof specifiedWidth === 'number' &&\n typeof specifiedHeight === 'number'\n ) {\n return scale(\n { minBox, maxBox },\n {\n width: specifiedWidth,\n height: specifiedHeight\n }\n );\n }\n if (naturalWidth != null && naturalHeight != null) {\n return scale(\n { minBox, maxBox },\n {\n width: naturalWidth,\n height: naturalHeight\n }\n );\n }\n return null;\n}\n\nexport default function useImageConcreteDimensions<\n P extends ConcreteDimensionsProps\n>({\n flatStyle,\n naturalDimensions,\n specifiedDimensions,\n computeMaxWidth,\n contentWidth\n}: P): P['naturalDimensions'] extends ImageDimensions\n ? ImageDimensions\n : ImageDimensions | null {\n return useMemo(() => {\n return computeConcreteDimensions({\n flattenStyles: flatStyle,\n computeMaxWidth,\n contentWidth,\n naturalWidth: naturalDimensions?.width,\n naturalHeight: naturalDimensions?.height,\n specifiedWidth: specifiedDimensions.width,\n specifiedHeight: specifiedDimensions.height\n }) as any;\n }, [\n computeMaxWidth,\n contentWidth,\n flatStyle,\n naturalDimensions,\n specifiedDimensions.height,\n specifiedDimensions.width\n ]);\n}\n","import { useMemo } from 'react';\nimport {\n UseIMGElementStateProps,\n IncompleteImageDimensions\n} from './img-types';\nimport getDimensionsWithAspectRatio from './getDimensionsWithAspectRatio';\nimport { StyleSheet } from 'react-native';\n\nfunction normalizeSize(\n dimension: string | number | null | undefined,\n options: Partial<{\n containerDimension: number | null;\n enablePercentWidth: boolean;\n }>\n) {\n const containerDimension = options.containerDimension || null;\n const enablePercentWidth = options.enablePercentWidth || false;\n if (\n dimension === null ||\n dimension === undefined ||\n Number.isNaN(dimension)\n ) {\n return null;\n }\n if (typeof dimension === 'number') {\n return dimension;\n }\n if (\n dimension.search('%') !== -1 &&\n enablePercentWidth &&\n typeof containerDimension === 'number'\n ) {\n return (parseFloat(dimension) * containerDimension) / 100;\n } else if (dimension.trim().match(/^[\\d.]+$/)) {\n return parseFloat(dimension);\n }\n return null;\n}\n\n/**\n * Extract specified dimensions from props.\n */\nfunction deriveSpecifiedDimensionsFromProps({\n width,\n height,\n contentWidth,\n flatStyle,\n enableExperimentalPercentWidth: enablePercentWidth\n}: Pick<\n UseIMGElementStateProps,\n 'width' | 'height' | 'contentWidth' | 'enableExperimentalPercentWidth'\n> & { flatStyle: Record }): IncompleteImageDimensions {\n const normalizeOptionsWidth = {\n enablePercentWidth,\n containerDimension: contentWidth\n };\n const normalizeOptionsHeight = {\n enablePercentWidth: false\n };\n const widthProp = normalizeSize(width, normalizeOptionsWidth);\n const heightProp = normalizeSize(height, normalizeOptionsHeight);\n const styleWidth = normalizeSize(flatStyle.width, normalizeOptionsWidth);\n const styleHeight = normalizeSize(flatStyle.height, normalizeOptionsHeight);\n return getDimensionsWithAspectRatio(\n styleWidth ?? widthProp,\n styleHeight ?? heightProp,\n flatStyle.aspectRatio\n );\n}\n\nexport default function useImageSpecifiedDimensions(\n props: UseIMGElementStateProps\n) {\n const { contentWidth, enableExperimentalPercentWidth, style, width, height } =\n props;\n const flatStyle = useMemo(() => StyleSheet.flatten(style) || {}, [style]);\n const specifiedDimensions = useMemo(\n () =>\n deriveSpecifiedDimensionsFromProps({\n contentWidth,\n enableExperimentalPercentWidth,\n width,\n height,\n flatStyle\n }),\n [contentWidth, enableExperimentalPercentWidth, flatStyle, height, width]\n );\n return { flatStyle, specifiedDimensions };\n}\n","export default function getDimensionsWithAspectRatio(\n width: number | null,\n height: number | null,\n aspectRatio: number | undefined\n) {\n return {\n width: width ?? (aspectRatio && height ? height * aspectRatio : null),\n height: height ?? (aspectRatio && width ? width / aspectRatio : null)\n };\n}\n","import type {\n UseIMGElementStateProps,\n IMGElementState,\n IMGElementStateBase,\n IMGElementStateError,\n IMGElementStateSuccess,\n IMGElementStateLoading\n} from './img-types';\nimport extractImageStyleProps from './extractImageStyleProps';\nimport { ImageDimensions } from '../shared-types';\n\ninterface GetStateProps extends Omit {\n concreteDimensions: C;\n error: Error | null;\n initialDimensions: ImageDimensions;\n objectFit: UseIMGElementStateProps['objectFit'];\n onError?: (e: Error) => void;\n}\n\nexport function getIMGState(\n props: GetStateProps\n): IMGElementStateError | IMGElementStateSuccess;\nexport function getIMGState(\n props: GetStateProps\n): IMGElementState;\nexport function getIMGState({\n error,\n alt,\n altColor,\n source,\n containerStyle,\n concreteDimensions,\n initialDimensions,\n objectFit,\n onError\n}: GetStateProps): IMGElementState {\n if (error) {\n return {\n type: 'error',\n alt,\n altColor,\n source,\n error,\n containerStyle,\n dimensions: concreteDimensions ?? initialDimensions\n };\n }\n if (concreteDimensions != null) {\n return {\n type: 'success',\n alt,\n altColor,\n source,\n onError,\n containerStyle,\n imageStyle: extractImageStyleProps(containerStyle, objectFit),\n dimensions: concreteDimensions\n } as IMGElementStateSuccess;\n }\n return {\n type: 'loading',\n alt,\n altColor,\n source,\n containerStyle,\n dimensions: initialDimensions\n } as IMGElementStateLoading;\n}\n","import { ImageStyle } from 'react-native';\nimport { WebBlockStyles } from '@native-html/transient-render-engine';\n\nimport pick from 'ramda/src/pick';\n\nconst extractProps = pick([\n 'resizeMode',\n 'tintColor',\n 'overlayColor'\n]);\n\nfunction mapObjectFit(objectFit: WebBlockStyles['objectFit']) {\n let resizeMode: ImageStyle['resizeMode'];\n switch (objectFit) {\n case 'contain':\n case 'cover':\n resizeMode = objectFit;\n break;\n case 'fill':\n resizeMode = 'stretch';\n break;\n case 'scale-down':\n resizeMode = 'contain';\n break;\n default:\n return null;\n }\n return { resizeMode };\n}\n\nfunction extractImageStyleProps(\n style: any,\n objectFit?: WebBlockStyles['objectFit']\n) {\n const resizeModeFromFit = objectFit ? mapObjectFit(objectFit) : null;\n return {\n ...extractProps(style),\n ...resizeModeFromFit\n };\n}\n\nexport default extractImageStyleProps;\n","import React, { ReactElement, useCallback } from 'react';\nimport {\n Image,\n ImageErrorEventData,\n ImageStyle,\n NativeSyntheticEvent\n} from 'react-native';\nimport { IMGElementStateSuccess } from './img-types';\n\nconst defaultImageStyle: ImageStyle = { resizeMode: 'cover' };\n\n/**\n * Default success \"image\" view for the {@link IMGElement} component.\n */\nexport default function IMGElementContentSuccess({\n source,\n imageStyle,\n dimensions,\n onError\n}: IMGElementStateSuccess): ReactElement {\n const onImageError = useCallback(\n ({ nativeEvent: { error } }: NativeSyntheticEvent) =>\n onError(error),\n [onError]\n );\n return (\n \n );\n}\n","import React, {\n ComponentType,\n PropsWithChildren,\n ReactElement,\n useMemo\n} from 'react';\nimport { View, StyleSheet, ViewStyle, ViewProps } from 'react-native';\nimport GenericPressable from '../GenericPressable';\nimport { IMGElementProps } from './img-types';\n\nconst styles = StyleSheet.create({\n container: {\n flexDirection: 'row',\n alignSelf: 'stretch',\n justifyContent: 'center'\n }\n});\n\n/**\n * Container for the {@link IMGElement} component.\n */\nexport default function IMGElementContainer({\n style,\n onPress,\n testID,\n children,\n ...otherProps\n}: PropsWithChildren<\n Pick &\n Omit & { style: ViewStyle }\n>): ReactElement {\n const containerStyle = useMemo(() => {\n const { width, height, ...remainingStyle } = style;\n return [styles.container, remainingStyle];\n }, [style]);\n const Container: ComponentType =\n typeof onPress === 'function' ? GenericPressable : View;\n return React.createElement(\n Container,\n { ...otherProps, style: containerStyle, onPress, testID },\n children\n );\n}\n","import React, { PropsWithChildren } from 'react';\nimport {\n Platform,\n TouchableHighlight,\n TouchableNativeFeedback,\n View\n} from 'react-native';\nimport { useSharedProps } from './context/SharedPropsProvider';\nimport { GenericPressableProps } from './shared-types';\n\nexport default function GenericPressable({\n style,\n children,\n borderless = false,\n ...otherProps\n}: PropsWithChildren) {\n const { pressableHightlightColor, GenericPressable: UserProvidedPressable } =\n useSharedProps();\n if (UserProvidedPressable) {\n return (\n \n {children}\n \n );\n }\n if (Platform.OS === 'android') {\n // TouchableNativeFeedback does not support a\n // style prop. So we must wrap it inside a View.\n return (\n \n \n {children}\n \n \n );\n }\n return (\n \n {children}\n \n );\n}\n","import React, { PropsWithChildren, ReactElement } from 'react';\nimport { View } from 'react-native';\nimport { IMGElementStateLoading } from './img-types';\n\n/**\n * Default loading view for the {@link IMGElement} component.\n */\nexport default function IMGElementContentLoading({\n dimensions,\n children\n}: PropsWithChildren): ReactElement {\n return (\n \n {children}\n \n );\n}\n","import React, { ReactElement } from 'react';\nimport { IMGElementStateError } from './img-types';\nimport IMGElementContentAlt from './IMGElementContentAlt';\n\n/**\n * Default error view for the {@link IMGElement} component.\n */\nexport default function IMGElementContentError(\n props: IMGElementStateError\n): ReactElement {\n return ;\n}\n","import React, { PropsWithChildren, ReactElement } from 'react';\nimport { StyleSheet, Text, View } from 'react-native';\nimport { IMGElementStateBase } from './img-types';\n\nconst styles = StyleSheet.create({\n altBox: {\n borderWidth: StyleSheet.hairlineWidth,\n overflow: 'hidden',\n justifyContent: 'center'\n },\n altText: { textAlign: 'center', fontStyle: 'italic' }\n});\n\n/**\n * Alt view for the {@link IMGElement} component.\n */\nexport default function IMGElementContentAlt({\n dimensions,\n alt,\n altColor,\n testID,\n children\n}: PropsWithChildren): ReactElement {\n return (\n \n {alt}\n {children}\n \n );\n}\n","import { useDocumentMetadata } from '../context/DocumentMetadataProvider';\nimport normalizeResourceLocator from '../helpers/normalizeResourceLocator';\n\n/**\n * This hook transforms relative and protocol-relative URLs to absolute URLs as\n * per {@link https://tools.ietf.org/html/rfc1808 | RFC1808}. The base URL is\n * determined by the `` element, `source.uri` or `source.baseUrl`.\n *\n * @remarks\n * - If there is no `baseUrl` and the initial URL is relative, this hook will\n * return the initial URL.\n * - If the initial URL is absolute, this hook will return this initial URL.\n *\n * @param initialUrl - The URL before normalization.\n *\n * @public\n */\nexport default function useNormalizedUrl(initialUrl: string) {\n const { baseUrl } = useDocumentMetadata();\n return normalizeResourceLocator(initialUrl, baseUrl);\n}\n","import URI from 'urijs';\n\n/**\n * This function normalize relative and protocol-relative URLs to absolute\n * URLs as per {@link https://tools.ietf.org/html/rfc1808 | RFC1808}.\n *\n * @param url - The URL to normalize.\n * @param baseUrl - The base URL to resolve relative and protocol-relative URLs.\n */\nexport default function normalizeResourceLocator(\n url: string,\n baseUrl?: string\n) {\n try {\n return baseUrl ? URI(url).absoluteTo(URI(baseUrl)).href() : URI(url).href();\n } catch (e) {\n return url;\n }\n}\n","/*!\n * URI.js - Mutating URLs\n *\n * Version: 1.19.11\n *\n * Author: Rodney Rehm\n * Web: http://medialize.github.io/URI.js/\n *\n * Licensed under\n * MIT License http://www.opensource.org/licenses/mit-license\n *\n */\n(function (root, factory) {\n 'use strict';\n // https://github.com/umdjs/umd/blob/master/returnExports.js\n if (typeof module === 'object' && module.exports) {\n // Node\n module.exports = factory(require('./punycode'), require('./IPv6'), require('./SecondLevelDomains'));\n } else if (typeof define === 'function' && define.amd) {\n // AMD. Register as an anonymous module.\n define(['./punycode', './IPv6', './SecondLevelDomains'], factory);\n } else {\n // Browser globals (root is window)\n root.URI = factory(root.punycode, root.IPv6, root.SecondLevelDomains, root);\n }\n}(this, function (punycode, IPv6, SLD, root) {\n 'use strict';\n /*global location, escape, unescape */\n // FIXME: v2.0.0 renamce non-camelCase properties to uppercase\n /*jshint camelcase: false */\n\n // save current URI variable, if any\n var _URI = root && root.URI;\n\n function URI(url, base) {\n var _urlSupplied = arguments.length >= 1;\n var _baseSupplied = arguments.length >= 2;\n\n // Allow instantiation without the 'new' keyword\n if (!(this instanceof URI)) {\n if (_urlSupplied) {\n if (_baseSupplied) {\n return new URI(url, base);\n }\n\n return new URI(url);\n }\n\n return new URI();\n }\n\n if (url === undefined) {\n if (_urlSupplied) {\n throw new TypeError('undefined is not a valid argument for URI');\n }\n\n if (typeof location !== 'undefined') {\n url = location.href + '';\n } else {\n url = '';\n }\n }\n\n if (url === null) {\n if (_urlSupplied) {\n throw new TypeError('null is not a valid argument for URI');\n }\n }\n\n this.href(url);\n\n // resolve to base according to http://dvcs.w3.org/hg/url/raw-file/tip/Overview.html#constructor\n if (base !== undefined) {\n return this.absoluteTo(base);\n }\n\n return this;\n }\n\n function isInteger(value) {\n return /^[0-9]+$/.test(value);\n }\n\n URI.version = '1.19.11';\n\n var p = URI.prototype;\n var hasOwn = Object.prototype.hasOwnProperty;\n\n function escapeRegEx(string) {\n // https://github.com/medialize/URI.js/commit/85ac21783c11f8ccab06106dba9735a31a86924d#commitcomment-821963\n return string.replace(/([.*+?^=!:${}()|[\\]\\/\\\\])/g, '\\\\$1');\n }\n\n function getType(value) {\n // IE8 doesn't return [Object Undefined] but [Object Object] for undefined value\n if (value === undefined) {\n return 'Undefined';\n }\n\n return String(Object.prototype.toString.call(value)).slice(8, -1);\n }\n\n function isArray(obj) {\n return getType(obj) === 'Array';\n }\n\n function filterArrayValues(data, value) {\n var lookup = {};\n var i, length;\n\n if (getType(value) === 'RegExp') {\n lookup = null;\n } else if (isArray(value)) {\n for (i = 0, length = value.length; i < length; i++) {\n lookup[value[i]] = true;\n }\n } else {\n lookup[value] = true;\n }\n\n for (i = 0, length = data.length; i < length; i++) {\n /*jshint laxbreak: true */\n var _match = lookup && lookup[data[i]] !== undefined\n || !lookup && value.test(data[i]);\n /*jshint laxbreak: false */\n if (_match) {\n data.splice(i, 1);\n length--;\n i--;\n }\n }\n\n return data;\n }\n\n function arrayContains(list, value) {\n var i, length;\n\n // value may be string, number, array, regexp\n if (isArray(value)) {\n // Note: this can be optimized to O(n) (instead of current O(m * n))\n for (i = 0, length = value.length; i < length; i++) {\n if (!arrayContains(list, value[i])) {\n return false;\n }\n }\n\n return true;\n }\n\n var _type = getType(value);\n for (i = 0, length = list.length; i < length; i++) {\n if (_type === 'RegExp') {\n if (typeof list[i] === 'string' && list[i].match(value)) {\n return true;\n }\n } else if (list[i] === value) {\n return true;\n }\n }\n\n return false;\n }\n\n function arraysEqual(one, two) {\n if (!isArray(one) || !isArray(two)) {\n return false;\n }\n\n // arrays can't be equal if they have different amount of content\n if (one.length !== two.length) {\n return false;\n }\n\n one.sort();\n two.sort();\n\n for (var i = 0, l = one.length; i < l; i++) {\n if (one[i] !== two[i]) {\n return false;\n }\n }\n\n return true;\n }\n\n function trimSlashes(text) {\n var trim_expression = /^\\/+|\\/+$/g;\n return text.replace(trim_expression, '');\n }\n\n URI._parts = function() {\n return {\n protocol: null,\n username: null,\n password: null,\n hostname: null,\n urn: null,\n port: null,\n path: null,\n query: null,\n fragment: null,\n // state\n preventInvalidHostname: URI.preventInvalidHostname,\n duplicateQueryParameters: URI.duplicateQueryParameters,\n escapeQuerySpace: URI.escapeQuerySpace\n };\n };\n // state: throw on invalid hostname\n // see https://github.com/medialize/URI.js/pull/345\n // and https://github.com/medialize/URI.js/issues/354\n URI.preventInvalidHostname = false;\n // state: allow duplicate query parameters (a=1&a=1)\n URI.duplicateQueryParameters = false;\n // state: replaces + with %20 (space in query strings)\n URI.escapeQuerySpace = true;\n // static properties\n URI.protocol_expression = /^[a-z][a-z0-9.+-]*$/i;\n URI.idn_expression = /[^a-z0-9\\._-]/i;\n URI.punycode_expression = /(xn--)/i;\n // well, 333.444.555.666 matches, but it sure ain't no IPv4 - do we care?\n URI.ip4_expression = /^\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}$/;\n // credits to Rich Brown\n // source: http://forums.intermapper.com/viewtopic.php?p=1096#1096\n // specification: http://www.ietf.org/rfc/rfc4291.txt\n URI.ip6_expression = /^\\s*((([0-9A-Fa-f]{1,4}:){7}([0-9A-Fa-f]{1,4}|:))|(([0-9A-Fa-f]{1,4}:){6}(:[0-9A-Fa-f]{1,4}|((25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)(\\.(25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)){3})|:))|(([0-9A-Fa-f]{1,4}:){5}(((:[0-9A-Fa-f]{1,4}){1,2})|:((25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)(\\.(25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)){3})|:))|(([0-9A-Fa-f]{1,4}:){4}(((:[0-9A-Fa-f]{1,4}){1,3})|((:[0-9A-Fa-f]{1,4})?:((25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)(\\.(25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)){3}))|:))|(([0-9A-Fa-f]{1,4}:){3}(((:[0-9A-Fa-f]{1,4}){1,4})|((:[0-9A-Fa-f]{1,4}){0,2}:((25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)(\\.(25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)){3}))|:))|(([0-9A-Fa-f]{1,4}:){2}(((:[0-9A-Fa-f]{1,4}){1,5})|((:[0-9A-Fa-f]{1,4}){0,3}:((25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)(\\.(25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)){3}))|:))|(([0-9A-Fa-f]{1,4}:){1}(((:[0-9A-Fa-f]{1,4}){1,6})|((:[0-9A-Fa-f]{1,4}){0,4}:((25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)(\\.(25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)){3}))|:))|(:(((:[0-9A-Fa-f]{1,4}){1,7})|((:[0-9A-Fa-f]{1,4}){0,5}:((25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)(\\.(25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]?\\d)){3}))|:)))(%.+)?\\s*$/;\n // expression used is \"gruber revised\" (@gruber v2) determined to be the\n // best solution in a regex-golf we did a couple of ages ago at\n // * http://mathiasbynens.be/demo/url-regex\n // * http://rodneyrehm.de/t/url-regex.html\n URI.find_uri_expression = /\\b((?:[a-z][\\w-]+:(?:\\/{1,3}|[a-z0-9%])|www\\d{0,3}[.]|[a-z0-9.\\-]+[.][a-z]{2,4}\\/)(?:[^\\s()<>]+|\\(([^\\s()<>]+|(\\([^\\s()<>]+\\)))*\\))+(?:\\(([^\\s()<>]+|(\\([^\\s()<>]+\\)))*\\)|[^\\s`!()\\[\\]{};:'\".,<>?«»“”‘’]))/ig;\n URI.findUri = {\n // valid \"scheme://\" or \"www.\"\n start: /\\b(?:([a-z][a-z0-9.+-]*:\\/\\/)|www\\.)/gi,\n // everything up to the next whitespace\n end: /[\\s\\r\\n]|$/,\n // trim trailing punctuation captured by end RegExp\n trim: /[`!()\\[\\]{};:'\".,<>?«»“”„‘’]+$/,\n // balanced parens inclusion (), [], {}, <>\n parens: /(\\([^\\)]*\\)|\\[[^\\]]*\\]|\\{[^}]*\\}|<[^>]*>)/g,\n };\n URI.leading_whitespace_expression = /^[\\x00-\\x20\\u00a0\\u1680\\u2000-\\u200a\\u2028\\u2029\\u202f\\u205f\\u3000\\ufeff]+/\n // https://infra.spec.whatwg.org/#ascii-tab-or-newline\n URI.ascii_tab_whitespace = /[\\u0009\\u000A\\u000D]+/g\n // http://www.iana.org/assignments/uri-schemes.html\n // http://en.wikipedia.org/wiki/List_of_TCP_and_UDP_port_numbers#Well-known_ports\n URI.defaultPorts = {\n http: '80',\n https: '443',\n ftp: '21',\n gopher: '70',\n ws: '80',\n wss: '443'\n };\n // list of protocols which always require a hostname\n URI.hostProtocols = [\n 'http',\n 'https'\n ];\n\n // allowed hostname characters according to RFC 3986\n // ALPHA DIGIT \"-\" \".\" \"_\" \"~\" \"!\" \"$\" \"&\" \"'\" \"(\" \")\" \"*\" \"+\" \",\" \";\" \"=\" %encoded\n // I've never seen a (non-IDN) hostname other than: ALPHA DIGIT . - _\n URI.invalid_hostname_characters = /[^a-zA-Z0-9\\.\\-:_]/;\n // map DOM Elements to their URI attribute\n URI.domAttributes = {\n 'a': 'href',\n 'blockquote': 'cite',\n 'link': 'href',\n 'base': 'href',\n 'script': 'src',\n 'form': 'action',\n 'img': 'src',\n 'area': 'href',\n 'iframe': 'src',\n 'embed': 'src',\n 'source': 'src',\n 'track': 'src',\n 'input': 'src', // but only if type=\"image\"\n 'audio': 'src',\n 'video': 'src'\n };\n URI.getDomAttribute = function(node) {\n if (!node || !node.nodeName) {\n return undefined;\n }\n\n var nodeName = node.nodeName.toLowerCase();\n // should only expose src for type=\"image\"\n if (nodeName === 'input' && node.type !== 'image') {\n return undefined;\n }\n\n return URI.domAttributes[nodeName];\n };\n\n function escapeForDumbFirefox36(value) {\n // https://github.com/medialize/URI.js/issues/91\n return escape(value);\n }\n\n // encoding / decoding according to RFC3986\n function strictEncodeURIComponent(string) {\n // see https://developer.mozilla.org/en-US/docs/JavaScript/Reference/Global_Objects/encodeURIComponent\n return encodeURIComponent(string)\n .replace(/[!'()*]/g, escapeForDumbFirefox36)\n .replace(/\\*/g, '%2A');\n }\n URI.encode = strictEncodeURIComponent;\n URI.decode = decodeURIComponent;\n URI.iso8859 = function() {\n URI.encode = escape;\n URI.decode = unescape;\n };\n URI.unicode = function() {\n URI.encode = strictEncodeURIComponent;\n URI.decode = decodeURIComponent;\n };\n URI.characters = {\n pathname: {\n encode: {\n // RFC3986 2.1: For consistency, URI producers and normalizers should\n // use uppercase hexadecimal digits for all percent-encodings.\n expression: /%(24|26|2B|2C|3B|3D|3A|40)/ig,\n map: {\n // -._~!'()*\n '%24': '$',\n '%26': '&',\n '%2B': '+',\n '%2C': ',',\n '%3B': ';',\n '%3D': '=',\n '%3A': ':',\n '%40': '@'\n }\n },\n decode: {\n expression: /[\\/\\?#]/g,\n map: {\n '/': '%2F',\n '?': '%3F',\n '#': '%23'\n }\n }\n },\n reserved: {\n encode: {\n // RFC3986 2.1: For consistency, URI producers and normalizers should\n // use uppercase hexadecimal digits for all percent-encodings.\n expression: /%(21|23|24|26|27|28|29|2A|2B|2C|2F|3A|3B|3D|3F|40|5B|5D)/ig,\n map: {\n // gen-delims\n '%3A': ':',\n '%2F': '/',\n '%3F': '?',\n '%23': '#',\n '%5B': '[',\n '%5D': ']',\n '%40': '@',\n // sub-delims\n '%21': '!',\n '%24': '$',\n '%26': '&',\n '%27': '\\'',\n '%28': '(',\n '%29': ')',\n '%2A': '*',\n '%2B': '+',\n '%2C': ',',\n '%3B': ';',\n '%3D': '='\n }\n }\n },\n urnpath: {\n // The characters under `encode` are the characters called out by RFC 2141 as being acceptable\n // for usage in a URN. RFC2141 also calls out \"-\", \".\", and \"_\" as acceptable characters, but\n // these aren't encoded by encodeURIComponent, so we don't have to call them out here. Also\n // note that the colon character is not featured in the encoding map; this is because URI.js\n // gives the colons in URNs semantic meaning as the delimiters of path segements, and so it\n // should not appear unencoded in a segment itself.\n // See also the note above about RFC3986 and capitalalized hex digits.\n encode: {\n expression: /%(21|24|27|28|29|2A|2B|2C|3B|3D|40)/ig,\n map: {\n '%21': '!',\n '%24': '$',\n '%27': '\\'',\n '%28': '(',\n '%29': ')',\n '%2A': '*',\n '%2B': '+',\n '%2C': ',',\n '%3B': ';',\n '%3D': '=',\n '%40': '@'\n }\n },\n // These characters are the characters called out by RFC2141 as \"reserved\" characters that\n // should never appear in a URN, plus the colon character (see note above).\n decode: {\n expression: /[\\/\\?#:]/g,\n map: {\n '/': '%2F',\n '?': '%3F',\n '#': '%23',\n ':': '%3A'\n }\n }\n }\n };\n URI.encodeQuery = function(string, escapeQuerySpace) {\n var escaped = URI.encode(string + '');\n if (escapeQuerySpace === undefined) {\n escapeQuerySpace = URI.escapeQuerySpace;\n }\n\n return escapeQuerySpace ? escaped.replace(/%20/g, '+') : escaped;\n };\n URI.decodeQuery = function(string, escapeQuerySpace) {\n string += '';\n if (escapeQuerySpace === undefined) {\n escapeQuerySpace = URI.escapeQuerySpace;\n }\n\n try {\n return URI.decode(escapeQuerySpace ? string.replace(/\\+/g, '%20') : string);\n } catch(e) {\n // we're not going to mess with weird encodings,\n // give up and return the undecoded original string\n // see https://github.com/medialize/URI.js/issues/87\n // see https://github.com/medialize/URI.js/issues/92\n return string;\n }\n };\n // generate encode/decode path functions\n var _parts = {'encode':'encode', 'decode':'decode'};\n var _part;\n var generateAccessor = function(_group, _part) {\n return function(string) {\n try {\n return URI[_part](string + '').replace(URI.characters[_group][_part].expression, function(c) {\n return URI.characters[_group][_part].map[c];\n });\n } catch (e) {\n // we're not going to mess with weird encodings,\n // give up and return the undecoded original string\n // see https://github.com/medialize/URI.js/issues/87\n // see https://github.com/medialize/URI.js/issues/92\n return string;\n }\n };\n };\n\n for (_part in _parts) {\n URI[_part + 'PathSegment'] = generateAccessor('pathname', _parts[_part]);\n URI[_part + 'UrnPathSegment'] = generateAccessor('urnpath', _parts[_part]);\n }\n\n var generateSegmentedPathFunction = function(_sep, _codingFuncName, _innerCodingFuncName) {\n return function(string) {\n // Why pass in names of functions, rather than the function objects themselves? The\n // definitions of some functions (but in particular, URI.decode) will occasionally change due\n // to URI.js having ISO8859 and Unicode modes. Passing in the name and getting it will ensure\n // that the functions we use here are \"fresh\".\n var actualCodingFunc;\n if (!_innerCodingFuncName) {\n actualCodingFunc = URI[_codingFuncName];\n } else {\n actualCodingFunc = function(string) {\n return URI[_codingFuncName](URI[_innerCodingFuncName](string));\n };\n }\n\n var segments = (string + '').split(_sep);\n\n for (var i = 0, length = segments.length; i < length; i++) {\n segments[i] = actualCodingFunc(segments[i]);\n }\n\n return segments.join(_sep);\n };\n };\n\n // This takes place outside the above loop because we don't want, e.g., encodeUrnPath functions.\n URI.decodePath = generateSegmentedPathFunction('/', 'decodePathSegment');\n URI.decodeUrnPath = generateSegmentedPathFunction(':', 'decodeUrnPathSegment');\n URI.recodePath = generateSegmentedPathFunction('/', 'encodePathSegment', 'decode');\n URI.recodeUrnPath = generateSegmentedPathFunction(':', 'encodeUrnPathSegment', 'decode');\n\n URI.encodeReserved = generateAccessor('reserved', 'encode');\n\n URI.parse = function(string, parts) {\n var pos;\n if (!parts) {\n parts = {\n preventInvalidHostname: URI.preventInvalidHostname\n };\n }\n\n string = string.replace(URI.leading_whitespace_expression, '')\n // https://infra.spec.whatwg.org/#ascii-tab-or-newline\n string = string.replace(URI.ascii_tab_whitespace, '')\n\n // [protocol\"://\"[username[\":\"password]\"@\"]hostname[\":\"port]\"/\"?][path][\"?\"querystring][\"#\"fragment]\n\n // extract fragment\n pos = string.indexOf('#');\n if (pos > -1) {\n // escaping?\n parts.fragment = string.substring(pos + 1) || null;\n string = string.substring(0, pos);\n }\n\n // extract query\n pos = string.indexOf('?');\n if (pos > -1) {\n // escaping?\n parts.query = string.substring(pos + 1) || null;\n string = string.substring(0, pos);\n }\n\n // slashes and backslashes have lost all meaning for the web protocols (https, http, wss, ws)\n string = string.replace(/^(https?|ftp|wss?)?:+[/\\\\]*/i, '$1://');\n // slashes and backslashes have lost all meaning for scheme relative URLs\n string = string.replace(/^[/\\\\]{2,}/i, '//');\n\n // extract protocol\n if (string.substring(0, 2) === '//') {\n // relative-scheme\n parts.protocol = null;\n string = string.substring(2);\n // extract \"user:pass@host:port\"\n string = URI.parseAuthority(string, parts);\n } else {\n pos = string.indexOf(':');\n if (pos > -1) {\n parts.protocol = string.substring(0, pos) || null;\n if (parts.protocol && !parts.protocol.match(URI.protocol_expression)) {\n // : may be within the path\n parts.protocol = undefined;\n } else if (string.substring(pos + 1, pos + 3).replace(/\\\\/g, '/') === '//') {\n string = string.substring(pos + 3);\n\n // extract \"user:pass@host:port\"\n string = URI.parseAuthority(string, parts);\n } else {\n string = string.substring(pos + 1);\n parts.urn = true;\n }\n }\n }\n\n // what's left must be the path\n parts.path = string;\n\n // and we're done\n return parts;\n };\n URI.parseHost = function(string, parts) {\n if (!string) {\n string = '';\n }\n\n // Copy chrome, IE, opera backslash-handling behavior.\n // Back slashes before the query string get converted to forward slashes\n // See: https://github.com/joyent/node/blob/386fd24f49b0e9d1a8a076592a404168faeecc34/lib/url.js#L115-L124\n // See: https://code.google.com/p/chromium/issues/detail?id=25916\n // https://github.com/medialize/URI.js/pull/233\n string = string.replace(/\\\\/g, '/');\n\n // extract host:port\n var pos = string.indexOf('/');\n var bracketPos;\n var t;\n\n if (pos === -1) {\n pos = string.length;\n }\n\n if (string.charAt(0) === '[') {\n // IPv6 host - http://tools.ietf.org/html/draft-ietf-6man-text-addr-representation-04#section-6\n // I claim most client software breaks on IPv6 anyways. To simplify things, URI only accepts\n // IPv6+port in the format [2001:db8::1]:80 (for the time being)\n bracketPos = string.indexOf(']');\n parts.hostname = string.substring(1, bracketPos) || null;\n parts.port = string.substring(bracketPos + 2, pos) || null;\n if (parts.port === '/') {\n parts.port = null;\n }\n } else {\n var firstColon = string.indexOf(':');\n var firstSlash = string.indexOf('/');\n var nextColon = string.indexOf(':', firstColon + 1);\n if (nextColon !== -1 && (firstSlash === -1 || nextColon < firstSlash)) {\n // IPv6 host contains multiple colons - but no port\n // this notation is actually not allowed by RFC 3986, but we're a liberal parser\n parts.hostname = string.substring(0, pos) || null;\n parts.port = null;\n } else {\n t = string.substring(0, pos).split(':');\n parts.hostname = t[0] || null;\n parts.port = t[1] || null;\n }\n }\n\n if (parts.hostname && string.substring(pos).charAt(0) !== '/') {\n pos++;\n string = '/' + string;\n }\n\n if (parts.preventInvalidHostname) {\n URI.ensureValidHostname(parts.hostname, parts.protocol);\n }\n\n if (parts.port) {\n URI.ensureValidPort(parts.port);\n }\n\n return string.substring(pos) || '/';\n };\n URI.parseAuthority = function(string, parts) {\n string = URI.parseUserinfo(string, parts);\n return URI.parseHost(string, parts);\n };\n URI.parseUserinfo = function(string, parts) {\n // extract username:password\n var _string = string\n var firstBackSlash = string.indexOf('\\\\');\n if (firstBackSlash !== -1) {\n string = string.replace(/\\\\/g, '/')\n }\n var firstSlash = string.indexOf('/');\n var pos = string.lastIndexOf('@', firstSlash > -1 ? firstSlash : string.length - 1);\n var t;\n\n // authority@ must come before /path or \\path\n if (pos > -1 && (firstSlash === -1 || pos < firstSlash)) {\n t = string.substring(0, pos).split(':');\n parts.username = t[0] ? URI.decode(t[0]) : null;\n t.shift();\n parts.password = t[0] ? URI.decode(t.join(':')) : null;\n string = _string.substring(pos + 1);\n } else {\n parts.username = null;\n parts.password = null;\n }\n\n return string;\n };\n URI.parseQuery = function(string, escapeQuerySpace) {\n if (!string) {\n return {};\n }\n\n // throw out the funky business - \"?\"[name\"=\"value\"&\"]+\n string = string.replace(/&+/g, '&').replace(/^\\?*&*|&+$/g, '');\n\n if (!string) {\n return {};\n }\n\n var items = {};\n var splits = string.split('&');\n var length = splits.length;\n var v, name, value;\n\n for (var i = 0; i < length; i++) {\n v = splits[i].split('=');\n name = URI.decodeQuery(v.shift(), escapeQuerySpace);\n // no \"=\" is null according to http://dvcs.w3.org/hg/url/raw-file/tip/Overview.html#collect-url-parameters\n value = v.length ? URI.decodeQuery(v.join('='), escapeQuerySpace) : null;\n\n if (name === '__proto__') {\n // ignore attempt at exploiting JavaScript internals\n continue;\n } else if (hasOwn.call(items, name)) {\n if (typeof items[name] === 'string' || items[name] === null) {\n items[name] = [items[name]];\n }\n\n items[name].push(value);\n } else {\n items[name] = value;\n }\n }\n\n return items;\n };\n\n URI.build = function(parts) {\n var t = '';\n var requireAbsolutePath = false\n\n if (parts.protocol) {\n t += parts.protocol + ':';\n }\n\n if (!parts.urn && (t || parts.hostname)) {\n t += '//';\n requireAbsolutePath = true\n }\n\n t += (URI.buildAuthority(parts) || '');\n\n if (typeof parts.path === 'string') {\n if (parts.path.charAt(0) !== '/' && requireAbsolutePath) {\n t += '/';\n }\n\n t += parts.path;\n }\n\n if (typeof parts.query === 'string' && parts.query) {\n t += '?' + parts.query;\n }\n\n if (typeof parts.fragment === 'string' && parts.fragment) {\n t += '#' + parts.fragment;\n }\n return t;\n };\n URI.buildHost = function(parts) {\n var t = '';\n\n if (!parts.hostname) {\n return '';\n } else if (URI.ip6_expression.test(parts.hostname)) {\n t += '[' + parts.hostname + ']';\n } else {\n t += parts.hostname;\n }\n\n if (parts.port) {\n t += ':' + parts.port;\n }\n\n return t;\n };\n URI.buildAuthority = function(parts) {\n return URI.buildUserinfo(parts) + URI.buildHost(parts);\n };\n URI.buildUserinfo = function(parts) {\n var t = '';\n\n if (parts.username) {\n t += URI.encode(parts.username);\n }\n\n if (parts.password) {\n t += ':' + URI.encode(parts.password);\n }\n\n if (t) {\n t += '@';\n }\n\n return t;\n };\n URI.buildQuery = function(data, duplicateQueryParameters, escapeQuerySpace) {\n // according to http://tools.ietf.org/html/rfc3986 or http://labs.apache.org/webarch/uri/rfc/rfc3986.html\n // being »-._~!$&'()*+,;=:@/?« %HEX and alnum are allowed\n // the RFC explicitly states ?/foo being a valid use case, no mention of parameter syntax!\n // URI.js treats the query string as being application/x-www-form-urlencoded\n // see http://www.w3.org/TR/REC-html40/interact/forms.html#form-content-type\n\n var t = '';\n var unique, key, i, length;\n for (key in data) {\n if (key === '__proto__') {\n // ignore attempt at exploiting JavaScript internals\n continue;\n } else if (hasOwn.call(data, key)) {\n if (isArray(data[key])) {\n unique = {};\n for (i = 0, length = data[key].length; i < length; i++) {\n if (data[key][i] !== undefined && unique[data[key][i] + ''] === undefined) {\n t += '&' + URI.buildQueryParameter(key, data[key][i], escapeQuerySpace);\n if (duplicateQueryParameters !== true) {\n unique[data[key][i] + ''] = true;\n }\n }\n }\n } else if (data[key] !== undefined) {\n t += '&' + URI.buildQueryParameter(key, data[key], escapeQuerySpace);\n }\n }\n }\n\n return t.substring(1);\n };\n URI.buildQueryParameter = function(name, value, escapeQuerySpace) {\n // http://www.w3.org/TR/REC-html40/interact/forms.html#form-content-type -- application/x-www-form-urlencoded\n // don't append \"=\" for null values, according to http://dvcs.w3.org/hg/url/raw-file/tip/Overview.html#url-parameter-serialization\n return URI.encodeQuery(name, escapeQuerySpace) + (value !== null ? '=' + URI.encodeQuery(value, escapeQuerySpace) : '');\n };\n\n URI.addQuery = function(data, name, value) {\n if (typeof name === 'object') {\n for (var key in name) {\n if (hasOwn.call(name, key)) {\n URI.addQuery(data, key, name[key]);\n }\n }\n } else if (typeof name === 'string') {\n if (data[name] === undefined) {\n data[name] = value;\n return;\n } else if (typeof data[name] === 'string') {\n data[name] = [data[name]];\n }\n\n if (!isArray(value)) {\n value = [value];\n }\n\n data[name] = (data[name] || []).concat(value);\n } else {\n throw new TypeError('URI.addQuery() accepts an object, string as the name parameter');\n }\n };\n\n URI.setQuery = function(data, name, value) {\n if (typeof name === 'object') {\n for (var key in name) {\n if (hasOwn.call(name, key)) {\n URI.setQuery(data, key, name[key]);\n }\n }\n } else if (typeof name === 'string') {\n data[name] = value === undefined ? null : value;\n } else {\n throw new TypeError('URI.setQuery() accepts an object, string as the name parameter');\n }\n };\n\n URI.removeQuery = function(data, name, value) {\n var i, length, key;\n\n if (isArray(name)) {\n for (i = 0, length = name.length; i < length; i++) {\n data[name[i]] = undefined;\n }\n } else if (getType(name) === 'RegExp') {\n for (key in data) {\n if (name.test(key)) {\n data[key] = undefined;\n }\n }\n } else if (typeof name === 'object') {\n for (key in name) {\n if (hasOwn.call(name, key)) {\n URI.removeQuery(data, key, name[key]);\n }\n }\n } else if (typeof name === 'string') {\n if (value !== undefined) {\n if (getType(value) === 'RegExp') {\n if (!isArray(data[name]) && value.test(data[name])) {\n data[name] = undefined;\n } else {\n data[name] = filterArrayValues(data[name], value);\n }\n } else if (data[name] === String(value) && (!isArray(value) || value.length === 1)) {\n data[name] = undefined;\n } else if (isArray(data[name])) {\n data[name] = filterArrayValues(data[name], value);\n }\n } else {\n data[name] = undefined;\n }\n } else {\n throw new TypeError('URI.removeQuery() accepts an object, string, RegExp as the first parameter');\n }\n };\n URI.hasQuery = function(data, name, value, withinArray) {\n switch (getType(name)) {\n case 'String':\n // Nothing to do here\n break;\n\n case 'RegExp':\n for (var key in data) {\n if (hasOwn.call(data, key)) {\n if (name.test(key) && (value === undefined || URI.hasQuery(data, key, value))) {\n return true;\n }\n }\n }\n\n return false;\n\n case 'Object':\n for (var _key in name) {\n if (hasOwn.call(name, _key)) {\n if (!URI.hasQuery(data, _key, name[_key])) {\n return false;\n }\n }\n }\n\n return true;\n\n default:\n throw new TypeError('URI.hasQuery() accepts a string, regular expression or object as the name parameter');\n }\n\n switch (getType(value)) {\n case 'Undefined':\n // true if exists (but may be empty)\n return name in data; // data[name] !== undefined;\n\n case 'Boolean':\n // true if exists and non-empty\n var _booly = Boolean(isArray(data[name]) ? data[name].length : data[name]);\n return value === _booly;\n\n case 'Function':\n // allow complex comparison\n return !!value(data[name], name, data);\n\n case 'Array':\n if (!isArray(data[name])) {\n return false;\n }\n\n var op = withinArray ? arrayContains : arraysEqual;\n return op(data[name], value);\n\n case 'RegExp':\n if (!isArray(data[name])) {\n return Boolean(data[name] && data[name].match(value));\n }\n\n if (!withinArray) {\n return false;\n }\n\n return arrayContains(data[name], value);\n\n case 'Number':\n value = String(value);\n /* falls through */\n case 'String':\n if (!isArray(data[name])) {\n return data[name] === value;\n }\n\n if (!withinArray) {\n return false;\n }\n\n return arrayContains(data[name], value);\n\n default:\n throw new TypeError('URI.hasQuery() accepts undefined, boolean, string, number, RegExp, Function as the value parameter');\n }\n };\n\n\n URI.joinPaths = function() {\n var input = [];\n var segments = [];\n var nonEmptySegments = 0;\n\n for (var i = 0; i < arguments.length; i++) {\n var url = new URI(arguments[i]);\n input.push(url);\n var _segments = url.segment();\n for (var s = 0; s < _segments.length; s++) {\n if (typeof _segments[s] === 'string') {\n segments.push(_segments[s]);\n }\n\n if (_segments[s]) {\n nonEmptySegments++;\n }\n }\n }\n\n if (!segments.length || !nonEmptySegments) {\n return new URI('');\n }\n\n var uri = new URI('').segment(segments);\n\n if (input[0].path() === '' || input[0].path().slice(0, 1) === '/') {\n uri.path('/' + uri.path());\n }\n\n return uri.normalize();\n };\n\n URI.commonPath = function(one, two) {\n var length = Math.min(one.length, two.length);\n var pos;\n\n // find first non-matching character\n for (pos = 0; pos < length; pos++) {\n if (one.charAt(pos) !== two.charAt(pos)) {\n pos--;\n break;\n }\n }\n\n if (pos < 1) {\n return one.charAt(0) === two.charAt(0) && one.charAt(0) === '/' ? '/' : '';\n }\n\n // revert to last /\n if (one.charAt(pos) !== '/' || two.charAt(pos) !== '/') {\n pos = one.substring(0, pos).lastIndexOf('/');\n }\n\n return one.substring(0, pos + 1);\n };\n\n URI.withinString = function(string, callback, options) {\n options || (options = {});\n var _start = options.start || URI.findUri.start;\n var _end = options.end || URI.findUri.end;\n var _trim = options.trim || URI.findUri.trim;\n var _parens = options.parens || URI.findUri.parens;\n var _attributeOpen = /[a-z0-9-]=[\"']?$/i;\n\n _start.lastIndex = 0;\n while (true) {\n var match = _start.exec(string);\n if (!match) {\n break;\n }\n\n var start = match.index;\n if (options.ignoreHtml) {\n // attribut(e=[\"']?$)\n var attributeOpen = string.slice(Math.max(start - 3, 0), start);\n if (attributeOpen && _attributeOpen.test(attributeOpen)) {\n continue;\n }\n }\n\n var end = start + string.slice(start).search(_end);\n var slice = string.slice(start, end);\n // make sure we include well balanced parens\n var parensEnd = -1;\n while (true) {\n var parensMatch = _parens.exec(slice);\n if (!parensMatch) {\n break;\n }\n\n var parensMatchEnd = parensMatch.index + parensMatch[0].length;\n parensEnd = Math.max(parensEnd, parensMatchEnd);\n }\n\n if (parensEnd > -1) {\n slice = slice.slice(0, parensEnd) + slice.slice(parensEnd).replace(_trim, '');\n } else {\n slice = slice.replace(_trim, '');\n }\n\n if (slice.length <= match[0].length) {\n // the extract only contains the starting marker of a URI,\n // e.g. \"www\" or \"http://\"\n continue;\n }\n\n if (options.ignore && options.ignore.test(slice)) {\n continue;\n }\n\n end = start + slice.length;\n var result = callback(slice, start, end, string);\n if (result === undefined) {\n _start.lastIndex = end;\n continue;\n }\n\n result = String(result);\n string = string.slice(0, start) + result + string.slice(end);\n _start.lastIndex = start + result.length;\n }\n\n _start.lastIndex = 0;\n return string;\n };\n\n URI.ensureValidHostname = function(v, protocol) {\n // Theoretically URIs allow percent-encoding in Hostnames (according to RFC 3986)\n // they are not part of DNS and therefore ignored by URI.js\n\n var hasHostname = !!v; // not null and not an empty string\n var hasProtocol = !!protocol;\n var rejectEmptyHostname = false;\n\n if (hasProtocol) {\n rejectEmptyHostname = arrayContains(URI.hostProtocols, protocol);\n }\n\n if (rejectEmptyHostname && !hasHostname) {\n throw new TypeError('Hostname cannot be empty, if protocol is ' + protocol);\n } else if (v && v.match(URI.invalid_hostname_characters)) {\n // test punycode\n if (!punycode) {\n throw new TypeError('Hostname \"' + v + '\" contains characters other than [A-Z0-9.-:_] and Punycode.js is not available');\n }\n if (punycode.toASCII(v).match(URI.invalid_hostname_characters)) {\n throw new TypeError('Hostname \"' + v + '\" contains characters other than [A-Z0-9.-:_]');\n }\n }\n };\n\n URI.ensureValidPort = function (v) {\n if (!v) {\n return;\n }\n\n var port = Number(v);\n if (isInteger(port) && (port > 0) && (port < 65536)) {\n return;\n }\n\n throw new TypeError('Port \"' + v + '\" is not a valid port');\n };\n\n // noConflict\n URI.noConflict = function(removeAll) {\n if (removeAll) {\n var unconflicted = {\n URI: this.noConflict()\n };\n\n if (root.URITemplate && typeof root.URITemplate.noConflict === 'function') {\n unconflicted.URITemplate = root.URITemplate.noConflict();\n }\n\n if (root.IPv6 && typeof root.IPv6.noConflict === 'function') {\n unconflicted.IPv6 = root.IPv6.noConflict();\n }\n\n if (root.SecondLevelDomains && typeof root.SecondLevelDomains.noConflict === 'function') {\n unconflicted.SecondLevelDomains = root.SecondLevelDomains.noConflict();\n }\n\n return unconflicted;\n } else if (root.URI === this) {\n root.URI = _URI;\n }\n\n return this;\n };\n\n p.build = function(deferBuild) {\n if (deferBuild === true) {\n this._deferred_build = true;\n } else if (deferBuild === undefined || this._deferred_build) {\n this._string = URI.build(this._parts);\n this._deferred_build = false;\n }\n\n return this;\n };\n\n p.clone = function() {\n return new URI(this);\n };\n\n p.valueOf = p.toString = function() {\n return this.build(false)._string;\n };\n\n\n function generateSimpleAccessor(_part){\n return function(v, build) {\n if (v === undefined) {\n return this._parts[_part] || '';\n } else {\n this._parts[_part] = v || null;\n this.build(!build);\n return this;\n }\n };\n }\n\n function generatePrefixAccessor(_part, _key){\n return function(v, build) {\n if (v === undefined) {\n return this._parts[_part] || '';\n } else {\n if (v !== null) {\n v = v + '';\n if (v.charAt(0) === _key) {\n v = v.substring(1);\n }\n }\n\n this._parts[_part] = v;\n this.build(!build);\n return this;\n }\n };\n }\n\n p.protocol = generateSimpleAccessor('protocol');\n p.username = generateSimpleAccessor('username');\n p.password = generateSimpleAccessor('password');\n p.hostname = generateSimpleAccessor('hostname');\n p.port = generateSimpleAccessor('port');\n p.query = generatePrefixAccessor('query', '?');\n p.fragment = generatePrefixAccessor('fragment', '#');\n\n p.search = function(v, build) {\n var t = this.query(v, build);\n return typeof t === 'string' && t.length ? ('?' + t) : t;\n };\n p.hash = function(v, build) {\n var t = this.fragment(v, build);\n return typeof t === 'string' && t.length ? ('#' + t) : t;\n };\n\n p.pathname = function(v, build) {\n if (v === undefined || v === true) {\n var res = this._parts.path || (this._parts.hostname ? '/' : '');\n return v ? (this._parts.urn ? URI.decodeUrnPath : URI.decodePath)(res) : res;\n } else {\n if (this._parts.urn) {\n this._parts.path = v ? URI.recodeUrnPath(v) : '';\n } else {\n this._parts.path = v ? URI.recodePath(v) : '/';\n }\n this.build(!build);\n return this;\n }\n };\n p.path = p.pathname;\n p.href = function(href, build) {\n var key;\n\n if (href === undefined) {\n return this.toString();\n }\n\n this._string = '';\n this._parts = URI._parts();\n\n var _URI = href instanceof URI;\n var _object = typeof href === 'object' && (href.hostname || href.path || href.pathname);\n if (href.nodeName) {\n var attribute = URI.getDomAttribute(href);\n href = href[attribute] || '';\n _object = false;\n }\n\n // window.location is reported to be an object, but it's not the sort\n // of object we're looking for:\n // * location.protocol ends with a colon\n // * location.query != object.search\n // * location.hash != object.fragment\n // simply serializing the unknown object should do the trick\n // (for location, not for everything...)\n if (!_URI && _object && href.pathname !== undefined) {\n href = href.toString();\n }\n\n if (typeof href === 'string' || href instanceof String) {\n this._parts = URI.parse(String(href), this._parts);\n } else if (_URI || _object) {\n var src = _URI ? href._parts : href;\n for (key in src) {\n if (key === 'query') { continue; }\n if (hasOwn.call(this._parts, key)) {\n this._parts[key] = src[key];\n }\n }\n if (src.query) {\n this.query(src.query, false);\n }\n } else {\n throw new TypeError('invalid input');\n }\n\n this.build(!build);\n return this;\n };\n\n // identification accessors\n p.is = function(what) {\n var ip = false;\n var ip4 = false;\n var ip6 = false;\n var name = false;\n var sld = false;\n var idn = false;\n var punycode = false;\n var relative = !this._parts.urn;\n\n if (this._parts.hostname) {\n relative = false;\n ip4 = URI.ip4_expression.test(this._parts.hostname);\n ip6 = URI.ip6_expression.test(this._parts.hostname);\n ip = ip4 || ip6;\n name = !ip;\n sld = name && SLD && SLD.has(this._parts.hostname);\n idn = name && URI.idn_expression.test(this._parts.hostname);\n punycode = name && URI.punycode_expression.test(this._parts.hostname);\n }\n\n switch (what.toLowerCase()) {\n case 'relative':\n return relative;\n\n case 'absolute':\n return !relative;\n\n // hostname identification\n case 'domain':\n case 'name':\n return name;\n\n case 'sld':\n return sld;\n\n case 'ip':\n return ip;\n\n case 'ip4':\n case 'ipv4':\n case 'inet4':\n return ip4;\n\n case 'ip6':\n case 'ipv6':\n case 'inet6':\n return ip6;\n\n case 'idn':\n return idn;\n\n case 'url':\n return !this._parts.urn;\n\n case 'urn':\n return !!this._parts.urn;\n\n case 'punycode':\n return punycode;\n }\n\n return null;\n };\n\n // component specific input validation\n var _protocol = p.protocol;\n var _port = p.port;\n var _hostname = p.hostname;\n\n p.protocol = function(v, build) {\n if (v) {\n // accept trailing ://\n v = v.replace(/:(\\/\\/)?$/, '');\n\n if (!v.match(URI.protocol_expression)) {\n throw new TypeError('Protocol \"' + v + '\" contains characters other than [A-Z0-9.+-] or doesn\\'t start with [A-Z]');\n }\n }\n\n return _protocol.call(this, v, build);\n };\n p.scheme = p.protocol;\n p.port = function(v, build) {\n if (this._parts.urn) {\n return v === undefined ? '' : this;\n }\n\n if (v !== undefined) {\n if (v === 0) {\n v = null;\n }\n\n if (v) {\n v += '';\n if (v.charAt(0) === ':') {\n v = v.substring(1);\n }\n\n URI.ensureValidPort(v);\n }\n }\n return _port.call(this, v, build);\n };\n p.hostname = function(v, build) {\n if (this._parts.urn) {\n return v === undefined ? '' : this;\n }\n\n if (v !== undefined) {\n var x = { preventInvalidHostname: this._parts.preventInvalidHostname };\n var res = URI.parseHost(v, x);\n if (res !== '/') {\n throw new TypeError('Hostname \"' + v + '\" contains characters other than [A-Z0-9.-]');\n }\n\n v = x.hostname;\n if (this._parts.preventInvalidHostname) {\n URI.ensureValidHostname(v, this._parts.protocol);\n }\n }\n\n return _hostname.call(this, v, build);\n };\n\n // compound accessors\n p.origin = function(v, build) {\n if (this._parts.urn) {\n return v === undefined ? '' : this;\n }\n\n if (v === undefined) {\n var protocol = this.protocol();\n var authority = this.authority();\n if (!authority) {\n return '';\n }\n\n return (protocol ? protocol + '://' : '') + this.authority();\n } else {\n var origin = URI(v);\n this\n .protocol(origin.protocol())\n .authority(origin.authority())\n .build(!build);\n return this;\n }\n };\n p.host = function(v, build) {\n if (this._parts.urn) {\n return v === undefined ? '' : this;\n }\n\n if (v === undefined) {\n return this._parts.hostname ? URI.buildHost(this._parts) : '';\n } else {\n var res = URI.parseHost(v, this._parts);\n if (res !== '/') {\n throw new TypeError('Hostname \"' + v + '\" contains characters other than [A-Z0-9.-]');\n }\n\n this.build(!build);\n return this;\n }\n };\n p.authority = function(v, build) {\n if (this._parts.urn) {\n return v === undefined ? '' : this;\n }\n\n if (v === undefined) {\n return this._parts.hostname ? URI.buildAuthority(this._parts) : '';\n } else {\n var res = URI.parseAuthority(v, this._parts);\n if (res !== '/') {\n throw new TypeError('Hostname \"' + v + '\" contains characters other than [A-Z0-9.-]');\n }\n\n this.build(!build);\n return this;\n }\n };\n p.userinfo = function(v, build) {\n if (this._parts.urn) {\n return v === undefined ? '' : this;\n }\n\n if (v === undefined) {\n var t = URI.buildUserinfo(this._parts);\n return t ? t.substring(0, t.length -1) : t;\n } else {\n if (v[v.length-1] !== '@') {\n v += '@';\n }\n\n URI.parseUserinfo(v, this._parts);\n this.build(!build);\n return this;\n }\n };\n p.resource = function(v, build) {\n var parts;\n\n if (v === undefined) {\n return this.path() + this.search() + this.hash();\n }\n\n parts = URI.parse(v);\n this._parts.path = parts.path;\n this._parts.query = parts.query;\n this._parts.fragment = parts.fragment;\n this.build(!build);\n return this;\n };\n\n // fraction accessors\n p.subdomain = function(v, build) {\n if (this._parts.urn) {\n return v === undefined ? '' : this;\n }\n\n // convenience, return \"www\" from \"www.example.org\"\n if (v === undefined) {\n if (!this._parts.hostname || this.is('IP')) {\n return '';\n }\n\n // grab domain and add another segment\n var end = this._parts.hostname.length - this.domain().length - 1;\n return this._parts.hostname.substring(0, end) || '';\n } else {\n var e = this._parts.hostname.length - this.domain().length;\n var sub = this._parts.hostname.substring(0, e);\n var replace = new RegExp('^' + escapeRegEx(sub));\n\n if (v && v.charAt(v.length - 1) !== '.') {\n v += '.';\n }\n\n if (v.indexOf(':') !== -1) {\n throw new TypeError('Domains cannot contain colons');\n }\n\n if (v) {\n URI.ensureValidHostname(v, this._parts.protocol);\n }\n\n this._parts.hostname = this._parts.hostname.replace(replace, v);\n this.build(!build);\n return this;\n }\n };\n p.domain = function(v, build) {\n if (this._parts.urn) {\n return v === undefined ? '' : this;\n }\n\n if (typeof v === 'boolean') {\n build = v;\n v = undefined;\n }\n\n // convenience, return \"example.org\" from \"www.example.org\"\n if (v === undefined) {\n if (!this._parts.hostname || this.is('IP')) {\n return '';\n }\n\n // if hostname consists of 1 or 2 segments, it must be the domain\n var t = this._parts.hostname.match(/\\./g);\n if (t && t.length < 2) {\n return this._parts.hostname;\n }\n\n // grab tld and add another segment\n var end = this._parts.hostname.length - this.tld(build).length - 1;\n end = this._parts.hostname.lastIndexOf('.', end -1) + 1;\n return this._parts.hostname.substring(end) || '';\n } else {\n if (!v) {\n throw new TypeError('cannot set domain empty');\n }\n\n if (v.indexOf(':') !== -1) {\n throw new TypeError('Domains cannot contain colons');\n }\n\n URI.ensureValidHostname(v, this._parts.protocol);\n\n if (!this._parts.hostname || this.is('IP')) {\n this._parts.hostname = v;\n } else {\n var replace = new RegExp(escapeRegEx(this.domain()) + '$');\n this._parts.hostname = this._parts.hostname.replace(replace, v);\n }\n\n this.build(!build);\n return this;\n }\n };\n p.tld = function(v, build) {\n if (this._parts.urn) {\n return v === undefined ? '' : this;\n }\n\n if (typeof v === 'boolean') {\n build = v;\n v = undefined;\n }\n\n // return \"org\" from \"www.example.org\"\n if (v === undefined) {\n if (!this._parts.hostname || this.is('IP')) {\n return '';\n }\n\n var pos = this._parts.hostname.lastIndexOf('.');\n var tld = this._parts.hostname.substring(pos + 1);\n\n if (build !== true && SLD && SLD.list[tld.toLowerCase()]) {\n return SLD.get(this._parts.hostname) || tld;\n }\n\n return tld;\n } else {\n var replace;\n\n if (!v) {\n throw new TypeError('cannot set TLD empty');\n } else if (v.match(/[^a-zA-Z0-9-]/)) {\n if (SLD && SLD.is(v)) {\n replace = new RegExp(escapeRegEx(this.tld()) + '$');\n this._parts.hostname = this._parts.hostname.replace(replace, v);\n } else {\n throw new TypeError('TLD \"' + v + '\" contains characters other than [A-Z0-9]');\n }\n } else if (!this._parts.hostname || this.is('IP')) {\n throw new ReferenceError('cannot set TLD on non-domain host');\n } else {\n replace = new RegExp(escapeRegEx(this.tld()) + '$');\n this._parts.hostname = this._parts.hostname.replace(replace, v);\n }\n\n this.build(!build);\n return this;\n }\n };\n p.directory = function(v, build) {\n if (this._parts.urn) {\n return v === undefined ? '' : this;\n }\n\n if (v === undefined || v === true) {\n if (!this._parts.path && !this._parts.hostname) {\n return '';\n }\n\n if (this._parts.path === '/') {\n return '/';\n }\n\n var end = this._parts.path.length - this.filename().length - 1;\n var res = this._parts.path.substring(0, end) || (this._parts.hostname ? '/' : '');\n\n return v ? URI.decodePath(res) : res;\n\n } else {\n var e = this._parts.path.length - this.filename().length;\n var directory = this._parts.path.substring(0, e);\n var replace = new RegExp('^' + escapeRegEx(directory));\n\n // fully qualifier directories begin with a slash\n if (!this.is('relative')) {\n if (!v) {\n v = '/';\n }\n\n if (v.charAt(0) !== '/') {\n v = '/' + v;\n }\n }\n\n // directories always end with a slash\n if (v && v.charAt(v.length - 1) !== '/') {\n v += '/';\n }\n\n v = URI.recodePath(v);\n this._parts.path = this._parts.path.replace(replace, v);\n this.build(!build);\n return this;\n }\n };\n p.filename = function(v, build) {\n if (this._parts.urn) {\n return v === undefined ? '' : this;\n }\n\n if (typeof v !== 'string') {\n if (!this._parts.path || this._parts.path === '/') {\n return '';\n }\n\n var pos = this._parts.path.lastIndexOf('/');\n var res = this._parts.path.substring(pos+1);\n\n return v ? URI.decodePathSegment(res) : res;\n } else {\n var mutatedDirectory = false;\n\n if (v.charAt(0) === '/') {\n v = v.substring(1);\n }\n\n if (v.match(/\\.?\\//)) {\n mutatedDirectory = true;\n }\n\n var replace = new RegExp(escapeRegEx(this.filename()) + '$');\n v = URI.recodePath(v);\n this._parts.path = this._parts.path.replace(replace, v);\n\n if (mutatedDirectory) {\n this.normalizePath(build);\n } else {\n this.build(!build);\n }\n\n return this;\n }\n };\n p.suffix = function(v, build) {\n if (this._parts.urn) {\n return v === undefined ? '' : this;\n }\n\n if (v === undefined || v === true) {\n if (!this._parts.path || this._parts.path === '/') {\n return '';\n }\n\n var filename = this.filename();\n var pos = filename.lastIndexOf('.');\n var s, res;\n\n if (pos === -1) {\n return '';\n }\n\n // suffix may only contain alnum characters (yup, I made this up.)\n s = filename.substring(pos+1);\n res = (/^[a-z0-9%]+$/i).test(s) ? s : '';\n return v ? URI.decodePathSegment(res) : res;\n } else {\n if (v.charAt(0) === '.') {\n v = v.substring(1);\n }\n\n var suffix = this.suffix();\n var replace;\n\n if (!suffix) {\n if (!v) {\n return this;\n }\n\n this._parts.path += '.' + URI.recodePath(v);\n } else if (!v) {\n replace = new RegExp(escapeRegEx('.' + suffix) + '$');\n } else {\n replace = new RegExp(escapeRegEx(suffix) + '$');\n }\n\n if (replace) {\n v = URI.recodePath(v);\n this._parts.path = this._parts.path.replace(replace, v);\n }\n\n this.build(!build);\n return this;\n }\n };\n p.segment = function(segment, v, build) {\n var separator = this._parts.urn ? ':' : '/';\n var path = this.path();\n var absolute = path.substring(0, 1) === '/';\n var segments = path.split(separator);\n\n if (segment !== undefined && typeof segment !== 'number') {\n build = v;\n v = segment;\n segment = undefined;\n }\n\n if (segment !== undefined && typeof segment !== 'number') {\n throw new Error('Bad segment \"' + segment + '\", must be 0-based integer');\n }\n\n if (absolute) {\n segments.shift();\n }\n\n if (segment < 0) {\n // allow negative indexes to address from the end\n segment = Math.max(segments.length + segment, 0);\n }\n\n if (v === undefined) {\n /*jshint laxbreak: true */\n return segment === undefined\n ? segments\n : segments[segment];\n /*jshint laxbreak: false */\n } else if (segment === null || segments[segment] === undefined) {\n if (isArray(v)) {\n segments = [];\n // collapse empty elements within array\n for (var i=0, l=v.length; i < l; i++) {\n if (!v[i].length && (!segments.length || !segments[segments.length -1].length)) {\n continue;\n }\n\n if (segments.length && !segments[segments.length -1].length) {\n segments.pop();\n }\n\n segments.push(trimSlashes(v[i]));\n }\n } else if (v || typeof v === 'string') {\n v = trimSlashes(v);\n if (segments[segments.length -1] === '') {\n // empty trailing elements have to be overwritten\n // to prevent results such as /foo//bar\n segments[segments.length -1] = v;\n } else {\n segments.push(v);\n }\n }\n } else {\n if (v) {\n segments[segment] = trimSlashes(v);\n } else {\n segments.splice(segment, 1);\n }\n }\n\n if (absolute) {\n segments.unshift('');\n }\n\n return this.path(segments.join(separator), build);\n };\n p.segmentCoded = function(segment, v, build) {\n var segments, i, l;\n\n if (typeof segment !== 'number') {\n build = v;\n v = segment;\n segment = undefined;\n }\n\n if (v === undefined) {\n segments = this.segment(segment, v, build);\n if (!isArray(segments)) {\n segments = segments !== undefined ? URI.decode(segments) : undefined;\n } else {\n for (i = 0, l = segments.length; i < l; i++) {\n segments[i] = URI.decode(segments[i]);\n }\n }\n\n return segments;\n }\n\n if (!isArray(v)) {\n v = (typeof v === 'string' || v instanceof String) ? URI.encode(v) : v;\n } else {\n for (i = 0, l = v.length; i < l; i++) {\n v[i] = URI.encode(v[i]);\n }\n }\n\n return this.segment(segment, v, build);\n };\n\n // mutating query string\n var q = p.query;\n p.query = function(v, build) {\n if (v === true) {\n return URI.parseQuery(this._parts.query, this._parts.escapeQuerySpace);\n } else if (typeof v === 'function') {\n var data = URI.parseQuery(this._parts.query, this._parts.escapeQuerySpace);\n var result = v.call(this, data);\n this._parts.query = URI.buildQuery(result || data, this._parts.duplicateQueryParameters, this._parts.escapeQuerySpace);\n this.build(!build);\n return this;\n } else if (v !== undefined && typeof v !== 'string') {\n this._parts.query = URI.buildQuery(v, this._parts.duplicateQueryParameters, this._parts.escapeQuerySpace);\n this.build(!build);\n return this;\n } else {\n return q.call(this, v, build);\n }\n };\n p.setQuery = function(name, value, build) {\n var data = URI.parseQuery(this._parts.query, this._parts.escapeQuerySpace);\n\n if (typeof name === 'string' || name instanceof String) {\n data[name] = value !== undefined ? value : null;\n } else if (typeof name === 'object') {\n for (var key in name) {\n if (hasOwn.call(name, key)) {\n data[key] = name[key];\n }\n }\n } else {\n throw new TypeError('URI.addQuery() accepts an object, string as the name parameter');\n }\n\n this._parts.query = URI.buildQuery(data, this._parts.duplicateQueryParameters, this._parts.escapeQuerySpace);\n if (typeof name !== 'string') {\n build = value;\n }\n\n this.build(!build);\n return this;\n };\n p.addQuery = function(name, value, build) {\n var data = URI.parseQuery(this._parts.query, this._parts.escapeQuerySpace);\n URI.addQuery(data, name, value === undefined ? null : value);\n this._parts.query = URI.buildQuery(data, this._parts.duplicateQueryParameters, this._parts.escapeQuerySpace);\n if (typeof name !== 'string') {\n build = value;\n }\n\n this.build(!build);\n return this;\n };\n p.removeQuery = function(name, value, build) {\n var data = URI.parseQuery(this._parts.query, this._parts.escapeQuerySpace);\n URI.removeQuery(data, name, value);\n this._parts.query = URI.buildQuery(data, this._parts.duplicateQueryParameters, this._parts.escapeQuerySpace);\n if (typeof name !== 'string') {\n build = value;\n }\n\n this.build(!build);\n return this;\n };\n p.hasQuery = function(name, value, withinArray) {\n var data = URI.parseQuery(this._parts.query, this._parts.escapeQuerySpace);\n return URI.hasQuery(data, name, value, withinArray);\n };\n p.setSearch = p.setQuery;\n p.addSearch = p.addQuery;\n p.removeSearch = p.removeQuery;\n p.hasSearch = p.hasQuery;\n\n // sanitizing URLs\n p.normalize = function() {\n if (this._parts.urn) {\n return this\n .normalizeProtocol(false)\n .normalizePath(false)\n .normalizeQuery(false)\n .normalizeFragment(false)\n .build();\n }\n\n return this\n .normalizeProtocol(false)\n .normalizeHostname(false)\n .normalizePort(false)\n .normalizePath(false)\n .normalizeQuery(false)\n .normalizeFragment(false)\n .build();\n };\n p.normalizeProtocol = function(build) {\n if (typeof this._parts.protocol === 'string') {\n this._parts.protocol = this._parts.protocol.toLowerCase();\n this.build(!build);\n }\n\n return this;\n };\n p.normalizeHostname = function(build) {\n if (this._parts.hostname) {\n if (this.is('IDN') && punycode) {\n this._parts.hostname = punycode.toASCII(this._parts.hostname);\n } else if (this.is('IPv6') && IPv6) {\n this._parts.hostname = IPv6.best(this._parts.hostname);\n }\n\n this._parts.hostname = this._parts.hostname.toLowerCase();\n this.build(!build);\n }\n\n return this;\n };\n p.normalizePort = function(build) {\n // remove port of it's the protocol's default\n if (typeof this._parts.protocol === 'string' && this._parts.port === URI.defaultPorts[this._parts.protocol]) {\n this._parts.port = null;\n this.build(!build);\n }\n\n return this;\n };\n p.normalizePath = function(build) {\n var _path = this._parts.path;\n if (!_path) {\n return this;\n }\n\n if (this._parts.urn) {\n this._parts.path = URI.recodeUrnPath(this._parts.path);\n this.build(!build);\n return this;\n }\n\n if (this._parts.path === '/') {\n return this;\n }\n\n _path = URI.recodePath(_path);\n\n var _was_relative;\n var _leadingParents = '';\n var _parent, _pos;\n\n // handle relative paths\n if (_path.charAt(0) !== '/') {\n _was_relative = true;\n _path = '/' + _path;\n }\n\n // handle relative files (as opposed to directories)\n if (_path.slice(-3) === '/..' || _path.slice(-2) === '/.') {\n _path += '/';\n }\n\n // resolve simples\n _path = _path\n .replace(/(\\/(\\.\\/)+)|(\\/\\.$)/g, '/')\n .replace(/\\/{2,}/g, '/');\n\n // remember leading parents\n if (_was_relative) {\n _leadingParents = _path.substring(1).match(/^(\\.\\.\\/)+/) || '';\n if (_leadingParents) {\n _leadingParents = _leadingParents[0];\n }\n }\n\n // resolve parents\n while (true) {\n _parent = _path.search(/\\/\\.\\.(\\/|$)/);\n if (_parent === -1) {\n // no more ../ to resolve\n break;\n } else if (_parent === 0) {\n // top level cannot be relative, skip it\n _path = _path.substring(3);\n continue;\n }\n\n _pos = _path.substring(0, _parent).lastIndexOf('/');\n if (_pos === -1) {\n _pos = _parent;\n }\n _path = _path.substring(0, _pos) + _path.substring(_parent + 3);\n }\n\n // revert to relative\n if (_was_relative && this.is('relative')) {\n _path = _leadingParents + _path.substring(1);\n }\n\n this._parts.path = _path;\n this.build(!build);\n return this;\n };\n p.normalizePathname = p.normalizePath;\n p.normalizeQuery = function(build) {\n if (typeof this._parts.query === 'string') {\n if (!this._parts.query.length) {\n this._parts.query = null;\n } else {\n this.query(URI.parseQuery(this._parts.query, this._parts.escapeQuerySpace));\n }\n\n this.build(!build);\n }\n\n return this;\n };\n p.normalizeFragment = function(build) {\n if (!this._parts.fragment) {\n this._parts.fragment = null;\n this.build(!build);\n }\n\n return this;\n };\n p.normalizeSearch = p.normalizeQuery;\n p.normalizeHash = p.normalizeFragment;\n\n p.iso8859 = function() {\n // expect unicode input, iso8859 output\n var e = URI.encode;\n var d = URI.decode;\n\n URI.encode = escape;\n URI.decode = decodeURIComponent;\n try {\n this.normalize();\n } finally {\n URI.encode = e;\n URI.decode = d;\n }\n return this;\n };\n\n p.unicode = function() {\n // expect iso8859 input, unicode output\n var e = URI.encode;\n var d = URI.decode;\n\n URI.encode = strictEncodeURIComponent;\n URI.decode = unescape;\n try {\n this.normalize();\n } finally {\n URI.encode = e;\n URI.decode = d;\n }\n return this;\n };\n\n p.readable = function() {\n var uri = this.clone();\n // removing username, password, because they shouldn't be displayed according to RFC 3986\n uri.username('').password('').normalize();\n var t = '';\n if (uri._parts.protocol) {\n t += uri._parts.protocol + '://';\n }\n\n if (uri._parts.hostname) {\n if (uri.is('punycode') && punycode) {\n t += punycode.toUnicode(uri._parts.hostname);\n if (uri._parts.port) {\n t += ':' + uri._parts.port;\n }\n } else {\n t += uri.host();\n }\n }\n\n if (uri._parts.hostname && uri._parts.path && uri._parts.path.charAt(0) !== '/') {\n t += '/';\n }\n\n t += uri.path(true);\n if (uri._parts.query) {\n var q = '';\n for (var i = 0, qp = uri._parts.query.split('&'), l = qp.length; i < l; i++) {\n var kv = (qp[i] || '').split('=');\n q += '&' + URI.decodeQuery(kv[0], this._parts.escapeQuerySpace)\n .replace(/&/g, '%26');\n\n if (kv[1] !== undefined) {\n q += '=' + URI.decodeQuery(kv[1], this._parts.escapeQuerySpace)\n .replace(/&/g, '%26');\n }\n }\n t += '?' + q.substring(1);\n }\n\n t += URI.decodeQuery(uri.hash(), true);\n return t;\n };\n\n // resolving relative and absolute URLs\n p.absoluteTo = function(base) {\n var resolved = this.clone();\n var properties = ['protocol', 'username', 'password', 'hostname', 'port'];\n var basedir, i, p;\n\n if (this._parts.urn) {\n throw new Error('URNs do not have any generally defined hierarchical components');\n }\n\n if (!(base instanceof URI)) {\n base = new URI(base);\n }\n\n if (resolved._parts.protocol) {\n // Directly returns even if this._parts.hostname is empty.\n return resolved;\n } else {\n resolved._parts.protocol = base._parts.protocol;\n }\n\n if (this._parts.hostname) {\n return resolved;\n }\n\n for (i = 0; (p = properties[i]); i++) {\n resolved._parts[p] = base._parts[p];\n }\n\n if (!resolved._parts.path) {\n resolved._parts.path = base._parts.path;\n if (!resolved._parts.query) {\n resolved._parts.query = base._parts.query;\n }\n } else {\n if (resolved._parts.path.substring(-2) === '..') {\n resolved._parts.path += '/';\n }\n\n if (resolved.path().charAt(0) !== '/') {\n basedir = base.directory();\n basedir = basedir ? basedir : base.path().indexOf('/') === 0 ? '/' : '';\n resolved._parts.path = (basedir ? (basedir + '/') : '') + resolved._parts.path;\n resolved.normalizePath();\n }\n }\n\n resolved.build();\n return resolved;\n };\n p.relativeTo = function(base) {\n var relative = this.clone().normalize();\n var relativeParts, baseParts, common, relativePath, basePath;\n\n if (relative._parts.urn) {\n throw new Error('URNs do not have any generally defined hierarchical components');\n }\n\n base = new URI(base).normalize();\n relativeParts = relative._parts;\n baseParts = base._parts;\n relativePath = relative.path();\n basePath = base.path();\n\n if (relativePath.charAt(0) !== '/') {\n throw new Error('URI is already relative');\n }\n\n if (basePath.charAt(0) !== '/') {\n throw new Error('Cannot calculate a URI relative to another relative URI');\n }\n\n if (relativeParts.protocol === baseParts.protocol) {\n relativeParts.protocol = null;\n }\n\n if (relativeParts.username !== baseParts.username || relativeParts.password !== baseParts.password) {\n return relative.build();\n }\n\n if (relativeParts.protocol !== null || relativeParts.username !== null || relativeParts.password !== null) {\n return relative.build();\n }\n\n if (relativeParts.hostname === baseParts.hostname && relativeParts.port === baseParts.port) {\n relativeParts.hostname = null;\n relativeParts.port = null;\n } else {\n return relative.build();\n }\n\n if (relativePath === basePath) {\n relativeParts.path = '';\n return relative.build();\n }\n\n // determine common sub path\n common = URI.commonPath(relativePath, basePath);\n\n // If the paths have nothing in common, return a relative URL with the absolute path.\n if (!common) {\n return relative.build();\n }\n\n var parents = baseParts.path\n .substring(common.length)\n .replace(/[^\\/]*$/, '')\n .replace(/.*?\\//g, '../');\n\n relativeParts.path = (parents + relativeParts.path.substring(common.length)) || './';\n\n return relative.build();\n };\n\n // comparing URIs\n p.equals = function(uri) {\n var one = this.clone();\n var two = new URI(uri);\n var one_map = {};\n var two_map = {};\n var checked = {};\n var one_query, two_query, key;\n\n one.normalize();\n two.normalize();\n\n // exact match\n if (one.toString() === two.toString()) {\n return true;\n }\n\n // extract query string\n one_query = one.query();\n two_query = two.query();\n one.query('');\n two.query('');\n\n // definitely not equal if not even non-query parts match\n if (one.toString() !== two.toString()) {\n return false;\n }\n\n // query parameters have the same length, even if they're permuted\n if (one_query.length !== two_query.length) {\n return false;\n }\n\n one_map = URI.parseQuery(one_query, this._parts.escapeQuerySpace);\n two_map = URI.parseQuery(two_query, this._parts.escapeQuerySpace);\n\n for (key in one_map) {\n if (hasOwn.call(one_map, key)) {\n if (!isArray(one_map[key])) {\n if (one_map[key] !== two_map[key]) {\n return false;\n }\n } else if (!arraysEqual(one_map[key], two_map[key])) {\n return false;\n }\n\n checked[key] = true;\n }\n }\n\n for (key in two_map) {\n if (hasOwn.call(two_map, key)) {\n if (!checked[key]) {\n // two contains a parameter not present in one\n return false;\n }\n }\n }\n\n return true;\n };\n\n // state\n p.preventInvalidHostname = function(v) {\n this._parts.preventInvalidHostname = !!v;\n return this;\n };\n\n p.duplicateQueryParameters = function(v) {\n this._parts.duplicateQueryParameters = !!v;\n return this;\n };\n\n p.escapeQuerySpace = function(v) {\n this._parts.escapeQuerySpace = !!v;\n return this;\n };\n\n return URI;\n}));\n","/*! https://mths.be/punycode v1.4.0 by @mathias */\n;(function(root) {\n\n\t/** Detect free variables */\n\tvar freeExports = typeof exports == 'object' && exports &&\n\t\t!exports.nodeType && exports;\n\tvar freeModule = typeof module == 'object' && module &&\n\t\t!module.nodeType && module;\n\tvar freeGlobal = typeof global == 'object' && global;\n\tif (\n\t\tfreeGlobal.global === freeGlobal ||\n\t\tfreeGlobal.window === freeGlobal ||\n\t\tfreeGlobal.self === freeGlobal\n\t) {\n\t\troot = freeGlobal;\n\t}\n\n\t/**\n\t * The `punycode` object.\n\t * @name punycode\n\t * @type Object\n\t */\n\tvar punycode,\n\n\t/** Highest positive signed 32-bit float value */\n\tmaxInt = 2147483647, // aka. 0x7FFFFFFF or 2^31-1\n\n\t/** Bootstring parameters */\n\tbase = 36,\n\ttMin = 1,\n\ttMax = 26,\n\tskew = 38,\n\tdamp = 700,\n\tinitialBias = 72,\n\tinitialN = 128, // 0x80\n\tdelimiter = '-', // '\\x2D'\n\n\t/** Regular expressions */\n\tregexPunycode = /^xn--/,\n\tregexNonASCII = /[^\\x20-\\x7E]/, // unprintable ASCII chars + non-ASCII chars\n\tregexSeparators = /[\\x2E\\u3002\\uFF0E\\uFF61]/g, // RFC 3490 separators\n\n\t/** Error messages */\n\terrors = {\n\t\t'overflow': 'Overflow: input needs wider integers to process',\n\t\t'not-basic': 'Illegal input >= 0x80 (not a basic code point)',\n\t\t'invalid-input': 'Invalid input'\n\t},\n\n\t/** Convenience shortcuts */\n\tbaseMinusTMin = base - tMin,\n\tfloor = Math.floor,\n\tstringFromCharCode = String.fromCharCode,\n\n\t/** Temporary variable */\n\tkey;\n\n\t/*--------------------------------------------------------------------------*/\n\n\t/**\n\t * A generic error utility function.\n\t * @private\n\t * @param {String} type The error type.\n\t * @returns {Error} Throws a `RangeError` with the applicable error message.\n\t */\n\tfunction error(type) {\n\t\tthrow new RangeError(errors[type]);\n\t}\n\n\t/**\n\t * A generic `Array#map` utility function.\n\t * @private\n\t * @param {Array} array The array to iterate over.\n\t * @param {Function} callback The function that gets called for every array\n\t * item.\n\t * @returns {Array} A new array of values returned by the callback function.\n\t */\n\tfunction map(array, fn) {\n\t\tvar length = array.length;\n\t\tvar result = [];\n\t\twhile (length--) {\n\t\t\tresult[length] = fn(array[length]);\n\t\t}\n\t\treturn result;\n\t}\n\n\t/**\n\t * A simple `Array#map`-like wrapper to work with domain name strings or email\n\t * addresses.\n\t * @private\n\t * @param {String} domain The domain name or email address.\n\t * @param {Function} callback The function that gets called for every\n\t * character.\n\t * @returns {Array} A new string of characters returned by the callback\n\t * function.\n\t */\n\tfunction mapDomain(string, fn) {\n\t\tvar parts = string.split('@');\n\t\tvar result = '';\n\t\tif (parts.length > 1) {\n\t\t\t// In email addresses, only the domain name should be punycoded. Leave\n\t\t\t// the local part (i.e. everything up to `@`) intact.\n\t\t\tresult = parts[0] + '@';\n\t\t\tstring = parts[1];\n\t\t}\n\t\t// Avoid `split(regex)` for IE8 compatibility. See #17.\n\t\tstring = string.replace(regexSeparators, '\\x2E');\n\t\tvar labels = string.split('.');\n\t\tvar encoded = map(labels, fn).join('.');\n\t\treturn result + encoded;\n\t}\n\n\t/**\n\t * Creates an array containing the numeric code points of each Unicode\n\t * character in the string. While JavaScript uses UCS-2 internally,\n\t * this function will convert a pair of surrogate halves (each of which\n\t * UCS-2 exposes as separate characters) into a single code point,\n\t * matching UTF-16.\n\t * @see `punycode.ucs2.encode`\n\t * @see \n\t * @memberOf punycode.ucs2\n\t * @name decode\n\t * @param {String} string The Unicode input string (UCS-2).\n\t * @returns {Array} The new array of code points.\n\t */\n\tfunction ucs2decode(string) {\n\t\tvar output = [],\n\t\t counter = 0,\n\t\t length = string.length,\n\t\t value,\n\t\t extra;\n\t\twhile (counter < length) {\n\t\t\tvalue = string.charCodeAt(counter++);\n\t\t\tif (value >= 0xD800 && value <= 0xDBFF && counter < length) {\n\t\t\t\t// high surrogate, and there is a next character\n\t\t\t\textra = string.charCodeAt(counter++);\n\t\t\t\tif ((extra & 0xFC00) == 0xDC00) { // low surrogate\n\t\t\t\t\toutput.push(((value & 0x3FF) << 10) + (extra & 0x3FF) + 0x10000);\n\t\t\t\t} else {\n\t\t\t\t\t// unmatched surrogate; only append this code unit, in case the next\n\t\t\t\t\t// code unit is the high surrogate of a surrogate pair\n\t\t\t\t\toutput.push(value);\n\t\t\t\t\tcounter--;\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\toutput.push(value);\n\t\t\t}\n\t\t}\n\t\treturn output;\n\t}\n\n\t/**\n\t * Creates a string based on an array of numeric code points.\n\t * @see `punycode.ucs2.decode`\n\t * @memberOf punycode.ucs2\n\t * @name encode\n\t * @param {Array} codePoints The array of numeric code points.\n\t * @returns {String} The new Unicode string (UCS-2).\n\t */\n\tfunction ucs2encode(array) {\n\t\treturn map(array, function(value) {\n\t\t\tvar output = '';\n\t\t\tif (value > 0xFFFF) {\n\t\t\t\tvalue -= 0x10000;\n\t\t\t\toutput += stringFromCharCode(value >>> 10 & 0x3FF | 0xD800);\n\t\t\t\tvalue = 0xDC00 | value & 0x3FF;\n\t\t\t}\n\t\t\toutput += stringFromCharCode(value);\n\t\t\treturn output;\n\t\t}).join('');\n\t}\n\n\t/**\n\t * Converts a basic code point into a digit/integer.\n\t * @see `digitToBasic()`\n\t * @private\n\t * @param {Number} codePoint The basic numeric code point value.\n\t * @returns {Number} The numeric value of a basic code point (for use in\n\t * representing integers) in the range `0` to `base - 1`, or `base` if\n\t * the code point does not represent a value.\n\t */\n\tfunction basicToDigit(codePoint) {\n\t\tif (codePoint - 48 < 10) {\n\t\t\treturn codePoint - 22;\n\t\t}\n\t\tif (codePoint - 65 < 26) {\n\t\t\treturn codePoint - 65;\n\t\t}\n\t\tif (codePoint - 97 < 26) {\n\t\t\treturn codePoint - 97;\n\t\t}\n\t\treturn base;\n\t}\n\n\t/**\n\t * Converts a digit/integer into a basic code point.\n\t * @see `basicToDigit()`\n\t * @private\n\t * @param {Number} digit The numeric value of a basic code point.\n\t * @returns {Number} The basic code point whose value (when used for\n\t * representing integers) is `digit`, which needs to be in the range\n\t * `0` to `base - 1`. If `flag` is non-zero, the uppercase form is\n\t * used; else, the lowercase form is used. The behavior is undefined\n\t * if `flag` is non-zero and `digit` has no uppercase form.\n\t */\n\tfunction digitToBasic(digit, flag) {\n\t\t// 0..25 map to ASCII a..z or A..Z\n\t\t// 26..35 map to ASCII 0..9\n\t\treturn digit + 22 + 75 * (digit < 26) - ((flag != 0) << 5);\n\t}\n\n\t/**\n\t * Bias adaptation function as per section 3.4 of RFC 3492.\n\t * https://tools.ietf.org/html/rfc3492#section-3.4\n\t * @private\n\t */\n\tfunction adapt(delta, numPoints, firstTime) {\n\t\tvar k = 0;\n\t\tdelta = firstTime ? floor(delta / damp) : delta >> 1;\n\t\tdelta += floor(delta / numPoints);\n\t\tfor (/* no initialization */; delta > baseMinusTMin * tMax >> 1; k += base) {\n\t\t\tdelta = floor(delta / baseMinusTMin);\n\t\t}\n\t\treturn floor(k + (baseMinusTMin + 1) * delta / (delta + skew));\n\t}\n\n\t/**\n\t * Converts a Punycode string of ASCII-only symbols to a string of Unicode\n\t * symbols.\n\t * @memberOf punycode\n\t * @param {String} input The Punycode string of ASCII-only symbols.\n\t * @returns {String} The resulting string of Unicode symbols.\n\t */\n\tfunction decode(input) {\n\t\t// Don't use UCS-2\n\t\tvar output = [],\n\t\t inputLength = input.length,\n\t\t out,\n\t\t i = 0,\n\t\t n = initialN,\n\t\t bias = initialBias,\n\t\t basic,\n\t\t j,\n\t\t index,\n\t\t oldi,\n\t\t w,\n\t\t k,\n\t\t digit,\n\t\t t,\n\t\t /** Cached calculation results */\n\t\t baseMinusT;\n\n\t\t// Handle the basic code points: let `basic` be the number of input code\n\t\t// points before the last delimiter, or `0` if there is none, then copy\n\t\t// the first basic code points to the output.\n\n\t\tbasic = input.lastIndexOf(delimiter);\n\t\tif (basic < 0) {\n\t\t\tbasic = 0;\n\t\t}\n\n\t\tfor (j = 0; j < basic; ++j) {\n\t\t\t// if it's not a basic code point\n\t\t\tif (input.charCodeAt(j) >= 0x80) {\n\t\t\t\terror('not-basic');\n\t\t\t}\n\t\t\toutput.push(input.charCodeAt(j));\n\t\t}\n\n\t\t// Main decoding loop: start just after the last delimiter if any basic code\n\t\t// points were copied; start at the beginning otherwise.\n\n\t\tfor (index = basic > 0 ? basic + 1 : 0; index < inputLength; /* no final expression */) {\n\n\t\t\t// `index` is the index of the next character to be consumed.\n\t\t\t// Decode a generalized variable-length integer into `delta`,\n\t\t\t// which gets added to `i`. The overflow checking is easier\n\t\t\t// if we increase `i` as we go, then subtract off its starting\n\t\t\t// value at the end to obtain `delta`.\n\t\t\tfor (oldi = i, w = 1, k = base; /* no condition */; k += base) {\n\n\t\t\t\tif (index >= inputLength) {\n\t\t\t\t\terror('invalid-input');\n\t\t\t\t}\n\n\t\t\t\tdigit = basicToDigit(input.charCodeAt(index++));\n\n\t\t\t\tif (digit >= base || digit > floor((maxInt - i) / w)) {\n\t\t\t\t\terror('overflow');\n\t\t\t\t}\n\n\t\t\t\ti += digit * w;\n\t\t\t\tt = k <= bias ? tMin : (k >= bias + tMax ? tMax : k - bias);\n\n\t\t\t\tif (digit < t) {\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\n\t\t\t\tbaseMinusT = base - t;\n\t\t\t\tif (w > floor(maxInt / baseMinusT)) {\n\t\t\t\t\terror('overflow');\n\t\t\t\t}\n\n\t\t\t\tw *= baseMinusT;\n\n\t\t\t}\n\n\t\t\tout = output.length + 1;\n\t\t\tbias = adapt(i - oldi, out, oldi == 0);\n\n\t\t\t// `i` was supposed to wrap around from `out` to `0`,\n\t\t\t// incrementing `n` each time, so we'll fix that now:\n\t\t\tif (floor(i / out) > maxInt - n) {\n\t\t\t\terror('overflow');\n\t\t\t}\n\n\t\t\tn += floor(i / out);\n\t\t\ti %= out;\n\n\t\t\t// Insert `n` at position `i` of the output\n\t\t\toutput.splice(i++, 0, n);\n\n\t\t}\n\n\t\treturn ucs2encode(output);\n\t}\n\n\t/**\n\t * Converts a string of Unicode symbols (e.g. a domain name label) to a\n\t * Punycode string of ASCII-only symbols.\n\t * @memberOf punycode\n\t * @param {String} input The string of Unicode symbols.\n\t * @returns {String} The resulting Punycode string of ASCII-only symbols.\n\t */\n\tfunction encode(input) {\n\t\tvar n,\n\t\t delta,\n\t\t handledCPCount,\n\t\t basicLength,\n\t\t bias,\n\t\t j,\n\t\t m,\n\t\t q,\n\t\t k,\n\t\t t,\n\t\t currentValue,\n\t\t output = [],\n\t\t /** `inputLength` will hold the number of code points in `input`. */\n\t\t inputLength,\n\t\t /** Cached calculation results */\n\t\t handledCPCountPlusOne,\n\t\t baseMinusT,\n\t\t qMinusT;\n\n\t\t// Convert the input in UCS-2 to Unicode\n\t\tinput = ucs2decode(input);\n\n\t\t// Cache the length\n\t\tinputLength = input.length;\n\n\t\t// Initialize the state\n\t\tn = initialN;\n\t\tdelta = 0;\n\t\tbias = initialBias;\n\n\t\t// Handle the basic code points\n\t\tfor (j = 0; j < inputLength; ++j) {\n\t\t\tcurrentValue = input[j];\n\t\t\tif (currentValue < 0x80) {\n\t\t\t\toutput.push(stringFromCharCode(currentValue));\n\t\t\t}\n\t\t}\n\n\t\thandledCPCount = basicLength = output.length;\n\n\t\t// `handledCPCount` is the number of code points that have been handled;\n\t\t// `basicLength` is the number of basic code points.\n\n\t\t// Finish the basic string - if it is not empty - with a delimiter\n\t\tif (basicLength) {\n\t\t\toutput.push(delimiter);\n\t\t}\n\n\t\t// Main encoding loop:\n\t\twhile (handledCPCount < inputLength) {\n\n\t\t\t// All non-basic code points < n have been handled already. Find the next\n\t\t\t// larger one:\n\t\t\tfor (m = maxInt, j = 0; j < inputLength; ++j) {\n\t\t\t\tcurrentValue = input[j];\n\t\t\t\tif (currentValue >= n && currentValue < m) {\n\t\t\t\t\tm = currentValue;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Increase `delta` enough to advance the decoder's state to ,\n\t\t\t// but guard against overflow\n\t\t\thandledCPCountPlusOne = handledCPCount + 1;\n\t\t\tif (m - n > floor((maxInt - delta) / handledCPCountPlusOne)) {\n\t\t\t\terror('overflow');\n\t\t\t}\n\n\t\t\tdelta += (m - n) * handledCPCountPlusOne;\n\t\t\tn = m;\n\n\t\t\tfor (j = 0; j < inputLength; ++j) {\n\t\t\t\tcurrentValue = input[j];\n\n\t\t\t\tif (currentValue < n && ++delta > maxInt) {\n\t\t\t\t\terror('overflow');\n\t\t\t\t}\n\n\t\t\t\tif (currentValue == n) {\n\t\t\t\t\t// Represent delta as a generalized variable-length integer\n\t\t\t\t\tfor (q = delta, k = base; /* no condition */; k += base) {\n\t\t\t\t\t\tt = k <= bias ? tMin : (k >= bias + tMax ? tMax : k - bias);\n\t\t\t\t\t\tif (q < t) {\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tqMinusT = q - t;\n\t\t\t\t\t\tbaseMinusT = base - t;\n\t\t\t\t\t\toutput.push(\n\t\t\t\t\t\t\tstringFromCharCode(digitToBasic(t + qMinusT % baseMinusT, 0))\n\t\t\t\t\t\t);\n\t\t\t\t\t\tq = floor(qMinusT / baseMinusT);\n\t\t\t\t\t}\n\n\t\t\t\t\toutput.push(stringFromCharCode(digitToBasic(q, 0)));\n\t\t\t\t\tbias = adapt(delta, handledCPCountPlusOne, handledCPCount == basicLength);\n\t\t\t\t\tdelta = 0;\n\t\t\t\t\t++handledCPCount;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t++delta;\n\t\t\t++n;\n\n\t\t}\n\t\treturn output.join('');\n\t}\n\n\t/**\n\t * Converts a Punycode string representing a domain name or an email address\n\t * to Unicode. Only the Punycoded parts of the input will be converted, i.e.\n\t * it doesn't matter if you call it on a string that has already been\n\t * converted to Unicode.\n\t * @memberOf punycode\n\t * @param {String} input The Punycoded domain name or email address to\n\t * convert to Unicode.\n\t * @returns {String} The Unicode representation of the given Punycode\n\t * string.\n\t */\n\tfunction toUnicode(input) {\n\t\treturn mapDomain(input, function(string) {\n\t\t\treturn regexPunycode.test(string)\n\t\t\t\t? decode(string.slice(4).toLowerCase())\n\t\t\t\t: string;\n\t\t});\n\t}\n\n\t/**\n\t * Converts a Unicode string representing a domain name or an email address to\n\t * Punycode. Only the non-ASCII parts of the domain name will be converted,\n\t * i.e. it doesn't matter if you call it with a domain that's already in\n\t * ASCII.\n\t * @memberOf punycode\n\t * @param {String} input The domain name or email address to convert, as a\n\t * Unicode string.\n\t * @returns {String} The Punycode representation of the given domain name or\n\t * email address.\n\t */\n\tfunction toASCII(input) {\n\t\treturn mapDomain(input, function(string) {\n\t\t\treturn regexNonASCII.test(string)\n\t\t\t\t? 'xn--' + encode(string)\n\t\t\t\t: string;\n\t\t});\n\t}\n\n\t/*--------------------------------------------------------------------------*/\n\n\t/** Define the public API */\n\tpunycode = {\n\t\t/**\n\t\t * A string representing the current Punycode.js version number.\n\t\t * @memberOf punycode\n\t\t * @type String\n\t\t */\n\t\t'version': '1.3.2',\n\t\t/**\n\t\t * An object of methods to convert from JavaScript's internal character\n\t\t * representation (UCS-2) to Unicode code points, and back.\n\t\t * @see \n\t\t * @memberOf punycode\n\t\t * @type Object\n\t\t */\n\t\t'ucs2': {\n\t\t\t'decode': ucs2decode,\n\t\t\t'encode': ucs2encode\n\t\t},\n\t\t'decode': decode,\n\t\t'encode': encode,\n\t\t'toASCII': toASCII,\n\t\t'toUnicode': toUnicode\n\t};\n\n\t/** Expose `punycode` */\n\t// Some AMD build optimizers, like r.js, check for specific condition patterns\n\t// like the following:\n\tif (\n\t\ttypeof define == 'function' &&\n\t\ttypeof define.amd == 'object' &&\n\t\tdefine.amd\n\t) {\n\t\tdefine('punycode', function() {\n\t\t\treturn punycode;\n\t\t});\n\t} else if (freeExports && freeModule) {\n\t\tif (module.exports == freeExports) {\n\t\t\t// in Node.js, io.js, or RingoJS v0.8.0+\n\t\t\tfreeModule.exports = punycode;\n\t\t} else {\n\t\t\t// in Narwhal or RingoJS v0.7.0-\n\t\t\tfor (key in punycode) {\n\t\t\t\tpunycode.hasOwnProperty(key) && (freeExports[key] = punycode[key]);\n\t\t\t}\n\t\t}\n\t} else {\n\t\t// in Rhino or a web browser\n\t\troot.punycode = punycode;\n\t}\n\n}(this));\n","/*!\n * URI.js - Mutating URLs\n * IPv6 Support\n *\n * Version: 1.19.11\n *\n * Author: Rodney Rehm\n * Web: http://medialize.github.io/URI.js/\n *\n * Licensed under\n * MIT License http://www.opensource.org/licenses/mit-license\n *\n */\n\n(function (root, factory) {\n 'use strict';\n // https://github.com/umdjs/umd/blob/master/returnExports.js\n if (typeof module === 'object' && module.exports) {\n // Node\n module.exports = factory();\n } else if (typeof define === 'function' && define.amd) {\n // AMD. Register as an anonymous module.\n define(factory);\n } else {\n // Browser globals (root is window)\n root.IPv6 = factory(root);\n }\n}(this, function (root) {\n 'use strict';\n\n /*\n var _in = \"fe80:0000:0000:0000:0204:61ff:fe9d:f156\";\n var _out = IPv6.best(_in);\n var _expected = \"fe80::204:61ff:fe9d:f156\";\n\n console.log(_in, _out, _expected, _out === _expected);\n */\n\n // save current IPv6 variable, if any\n var _IPv6 = root && root.IPv6;\n\n function bestPresentation(address) {\n // based on:\n // Javascript to test an IPv6 address for proper format, and to\n // present the \"best text representation\" according to IETF Draft RFC at\n // http://tools.ietf.org/html/draft-ietf-6man-text-addr-representation-04\n // 8 Feb 2010 Rich Brown, Dartware, LLC\n // Please feel free to use this code as long as you provide a link to\n // http://www.intermapper.com\n // http://intermapper.com/support/tools/IPV6-Validator.aspx\n // http://download.dartware.com/thirdparty/ipv6validator.js\n\n var _address = address.toLowerCase();\n var segments = _address.split(':');\n var length = segments.length;\n var total = 8;\n\n // trim colons (:: or ::a:b:c… or …a:b:c::)\n if (segments[0] === '' && segments[1] === '' && segments[2] === '') {\n // must have been ::\n // remove first two items\n segments.shift();\n segments.shift();\n } else if (segments[0] === '' && segments[1] === '') {\n // must have been ::xxxx\n // remove the first item\n segments.shift();\n } else if (segments[length - 1] === '' && segments[length - 2] === '') {\n // must have been xxxx::\n segments.pop();\n }\n\n length = segments.length;\n\n // adjust total segments for IPv4 trailer\n if (segments[length - 1].indexOf('.') !== -1) {\n // found a \".\" which means IPv4\n total = 7;\n }\n\n // fill empty segments them with \"0000\"\n var pos;\n for (pos = 0; pos < length; pos++) {\n if (segments[pos] === '') {\n break;\n }\n }\n\n if (pos < total) {\n segments.splice(pos, 1, '0000');\n while (segments.length < total) {\n segments.splice(pos, 0, '0000');\n }\n }\n\n // strip leading zeros\n var _segments;\n for (var i = 0; i < total; i++) {\n _segments = segments[i].split('');\n for (var j = 0; j < 3 ; j++) {\n if (_segments[0] === '0' && _segments.length > 1) {\n _segments.splice(0,1);\n } else {\n break;\n }\n }\n\n segments[i] = _segments.join('');\n }\n\n // find longest sequence of zeroes and coalesce them into one segment\n var best = -1;\n var _best = 0;\n var _current = 0;\n var current = -1;\n var inzeroes = false;\n // i; already declared\n\n for (i = 0; i < total; i++) {\n if (inzeroes) {\n if (segments[i] === '0') {\n _current += 1;\n } else {\n inzeroes = false;\n if (_current > _best) {\n best = current;\n _best = _current;\n }\n }\n } else {\n if (segments[i] === '0') {\n inzeroes = true;\n current = i;\n _current = 1;\n }\n }\n }\n\n if (_current > _best) {\n best = current;\n _best = _current;\n }\n\n if (_best > 1) {\n segments.splice(best, _best, '');\n }\n\n length = segments.length;\n\n // assemble remaining segments\n var result = '';\n if (segments[0] === '') {\n result = ':';\n }\n\n for (i = 0; i < length; i++) {\n result += segments[i];\n if (i === length - 1) {\n break;\n }\n\n result += ':';\n }\n\n if (segments[length - 1] === '') {\n result += ':';\n }\n\n return result;\n }\n\n function noConflict() {\n /*jshint validthis: true */\n if (root.IPv6 === this) {\n root.IPv6 = _IPv6;\n }\n\n return this;\n }\n\n return {\n best: bestPresentation,\n noConflict: noConflict\n };\n}));\n","/*!\n * URI.js - Mutating URLs\n * Second Level Domain (SLD) Support\n *\n * Version: 1.19.11\n *\n * Author: Rodney Rehm\n * Web: http://medialize.github.io/URI.js/\n *\n * Licensed under\n * MIT License http://www.opensource.org/licenses/mit-license\n *\n */\n\n(function (root, factory) {\n 'use strict';\n // https://github.com/umdjs/umd/blob/master/returnExports.js\n if (typeof module === 'object' && module.exports) {\n // Node\n module.exports = factory();\n } else if (typeof define === 'function' && define.amd) {\n // AMD. Register as an anonymous module.\n define(factory);\n } else {\n // Browser globals (root is window)\n root.SecondLevelDomains = factory(root);\n }\n}(this, function (root) {\n 'use strict';\n\n // save current SecondLevelDomains variable, if any\n var _SecondLevelDomains = root && root.SecondLevelDomains;\n\n var SLD = {\n // list of known Second Level Domains\n // converted list of SLDs from https://github.com/gavingmiller/second-level-domains\n // ----\n // publicsuffix.org is more current and actually used by a couple of browsers internally.\n // downside is it also contains domains like \"dyndns.org\" - which is fine for the security\n // issues browser have to deal with (SOP for cookies, etc) - but is way overboard for URI.js\n // ----\n list: {\n 'ac':' com gov mil net org ',\n 'ae':' ac co gov mil name net org pro sch ',\n 'af':' com edu gov net org ',\n 'al':' com edu gov mil net org ',\n 'ao':' co ed gv it og pb ',\n 'ar':' com edu gob gov int mil net org tur ',\n 'at':' ac co gv or ',\n 'au':' asn com csiro edu gov id net org ',\n 'ba':' co com edu gov mil net org rs unbi unmo unsa untz unze ',\n 'bb':' biz co com edu gov info net org store tv ',\n 'bh':' biz cc com edu gov info net org ',\n 'bn':' com edu gov net org ',\n 'bo':' com edu gob gov int mil net org tv ',\n 'br':' adm adv agr am arq art ato b bio blog bmd cim cng cnt com coop ecn edu eng esp etc eti far flog fm fnd fot fst g12 ggf gov imb ind inf jor jus lel mat med mil mus net nom not ntr odo org ppg pro psc psi qsl rec slg srv tmp trd tur tv vet vlog wiki zlg ',\n 'bs':' com edu gov net org ',\n 'bz':' du et om ov rg ',\n 'ca':' ab bc mb nb nf nl ns nt nu on pe qc sk yk ',\n 'ck':' biz co edu gen gov info net org ',\n 'cn':' ac ah bj com cq edu fj gd gov gs gx gz ha hb he hi hl hn jl js jx ln mil net nm nx org qh sc sd sh sn sx tj tw xj xz yn zj ',\n 'co':' com edu gov mil net nom org ',\n 'cr':' ac c co ed fi go or sa ',\n 'cy':' ac biz com ekloges gov ltd name net org parliament press pro tm ',\n 'do':' art com edu gob gov mil net org sld web ',\n 'dz':' art asso com edu gov net org pol ',\n 'ec':' com edu fin gov info med mil net org pro ',\n 'eg':' com edu eun gov mil name net org sci ',\n 'er':' com edu gov ind mil net org rochest w ',\n 'es':' com edu gob nom org ',\n 'et':' biz com edu gov info name net org ',\n 'fj':' ac biz com info mil name net org pro ',\n 'fk':' ac co gov net nom org ',\n 'fr':' asso com f gouv nom prd presse tm ',\n 'gg':' co net org ',\n 'gh':' com edu gov mil org ',\n 'gn':' ac com gov net org ',\n 'gr':' com edu gov mil net org ',\n 'gt':' com edu gob ind mil net org ',\n 'gu':' com edu gov net org ',\n 'hk':' com edu gov idv net org ',\n 'hu':' 2000 agrar bolt casino city co erotica erotika film forum games hotel info ingatlan jogasz konyvelo lakas media news org priv reklam sex shop sport suli szex tm tozsde utazas video ',\n 'id':' ac co go mil net or sch web ',\n 'il':' ac co gov idf k12 muni net org ',\n 'in':' ac co edu ernet firm gen gov i ind mil net nic org res ',\n 'iq':' com edu gov i mil net org ',\n 'ir':' ac co dnssec gov i id net org sch ',\n 'it':' edu gov ',\n 'je':' co net org ',\n 'jo':' com edu gov mil name net org sch ',\n 'jp':' ac ad co ed go gr lg ne or ',\n 'ke':' ac co go info me mobi ne or sc ',\n 'kh':' com edu gov mil net org per ',\n 'ki':' biz com de edu gov info mob net org tel ',\n 'km':' asso com coop edu gouv k medecin mil nom notaires pharmaciens presse tm veterinaire ',\n 'kn':' edu gov net org ',\n 'kr':' ac busan chungbuk chungnam co daegu daejeon es gangwon go gwangju gyeongbuk gyeonggi gyeongnam hs incheon jeju jeonbuk jeonnam k kg mil ms ne or pe re sc seoul ulsan ',\n 'kw':' com edu gov net org ',\n 'ky':' com edu gov net org ',\n 'kz':' com edu gov mil net org ',\n 'lb':' com edu gov net org ',\n 'lk':' assn com edu gov grp hotel int ltd net ngo org sch soc web ',\n 'lr':' com edu gov net org ',\n 'lv':' asn com conf edu gov id mil net org ',\n 'ly':' com edu gov id med net org plc sch ',\n 'ma':' ac co gov m net org press ',\n 'mc':' asso tm ',\n 'me':' ac co edu gov its net org priv ',\n 'mg':' com edu gov mil nom org prd tm ',\n 'mk':' com edu gov inf name net org pro ',\n 'ml':' com edu gov net org presse ',\n 'mn':' edu gov org ',\n 'mo':' com edu gov net org ',\n 'mt':' com edu gov net org ',\n 'mv':' aero biz com coop edu gov info int mil museum name net org pro ',\n 'mw':' ac co com coop edu gov int museum net org ',\n 'mx':' com edu gob net org ',\n 'my':' com edu gov mil name net org sch ',\n 'nf':' arts com firm info net other per rec store web ',\n 'ng':' biz com edu gov mil mobi name net org sch ',\n 'ni':' ac co com edu gob mil net nom org ',\n 'np':' com edu gov mil net org ',\n 'nr':' biz com edu gov info net org ',\n 'om':' ac biz co com edu gov med mil museum net org pro sch ',\n 'pe':' com edu gob mil net nom org sld ',\n 'ph':' com edu gov i mil net ngo org ',\n 'pk':' biz com edu fam gob gok gon gop gos gov net org web ',\n 'pl':' art bialystok biz com edu gda gdansk gorzow gov info katowice krakow lodz lublin mil net ngo olsztyn org poznan pwr radom slupsk szczecin torun warszawa waw wroc wroclaw zgora ',\n 'pr':' ac biz com edu est gov info isla name net org pro prof ',\n 'ps':' com edu gov net org plo sec ',\n 'pw':' belau co ed go ne or ',\n 'ro':' arts com firm info nom nt org rec store tm www ',\n 'rs':' ac co edu gov in org ',\n 'sb':' com edu gov net org ',\n 'sc':' com edu gov net org ',\n 'sh':' co com edu gov net nom org ',\n 'sl':' com edu gov net org ',\n 'st':' co com consulado edu embaixada gov mil net org principe saotome store ',\n 'sv':' com edu gob org red ',\n 'sz':' ac co org ',\n 'tr':' av bbs bel biz com dr edu gen gov info k12 name net org pol tel tsk tv web ',\n 'tt':' aero biz cat co com coop edu gov info int jobs mil mobi museum name net org pro tel travel ',\n 'tw':' club com ebiz edu game gov idv mil net org ',\n 'mu':' ac co com gov net or org ',\n 'mz':' ac co edu gov org ',\n 'na':' co com ',\n 'nz':' ac co cri geek gen govt health iwi maori mil net org parliament school ',\n 'pa':' abo ac com edu gob ing med net nom org sld ',\n 'pt':' com edu gov int net nome org publ ',\n 'py':' com edu gov mil net org ',\n 'qa':' com edu gov mil net org ',\n 're':' asso com nom ',\n 'ru':' ac adygeya altai amur arkhangelsk astrakhan bashkiria belgorod bir bryansk buryatia cbg chel chelyabinsk chita chukotka chuvashia com dagestan e-burg edu gov grozny int irkutsk ivanovo izhevsk jar joshkar-ola kalmykia kaluga kamchatka karelia kazan kchr kemerovo khabarovsk khakassia khv kirov koenig komi kostroma kranoyarsk kuban kurgan kursk lipetsk magadan mari mari-el marine mil mordovia mosreg msk murmansk nalchik net nnov nov novosibirsk nsk omsk orenburg org oryol penza perm pp pskov ptz rnd ryazan sakhalin samara saratov simbirsk smolensk spb stavropol stv surgut tambov tatarstan tom tomsk tsaritsyn tsk tula tuva tver tyumen udm udmurtia ulan-ude vladikavkaz vladimir vladivostok volgograd vologda voronezh vrn vyatka yakutia yamal yekaterinburg yuzhno-sakhalinsk ',\n 'rw':' ac co com edu gouv gov int mil net ',\n 'sa':' com edu gov med net org pub sch ',\n 'sd':' com edu gov info med net org tv ',\n 'se':' a ac b bd c d e f g h i k l m n o org p parti pp press r s t tm u w x y z ',\n 'sg':' com edu gov idn net org per ',\n 'sn':' art com edu gouv org perso univ ',\n 'sy':' com edu gov mil net news org ',\n 'th':' ac co go in mi net or ',\n 'tj':' ac biz co com edu go gov info int mil name net nic org test web ',\n 'tn':' agrinet com defense edunet ens fin gov ind info intl mincom nat net org perso rnrt rns rnu tourism ',\n 'tz':' ac co go ne or ',\n 'ua':' biz cherkassy chernigov chernovtsy ck cn co com crimea cv dn dnepropetrovsk donetsk dp edu gov if in ivano-frankivsk kh kharkov kherson khmelnitskiy kiev kirovograd km kr ks kv lg lugansk lutsk lviv me mk net nikolaev od odessa org pl poltava pp rovno rv sebastopol sumy te ternopil uzhgorod vinnica vn zaporizhzhe zhitomir zp zt ',\n 'ug':' ac co go ne or org sc ',\n 'uk':' ac bl british-library co cym gov govt icnet jet lea ltd me mil mod national-library-scotland nel net nhs nic nls org orgn parliament plc police sch scot soc ',\n 'us':' dni fed isa kids nsn ',\n 'uy':' com edu gub mil net org ',\n 've':' co com edu gob info mil net org web ',\n 'vi':' co com k12 net org ',\n 'vn':' ac biz com edu gov health info int name net org pro ',\n 'ye':' co com gov ltd me net org plc ',\n 'yu':' ac co edu gov org ',\n 'za':' ac agric alt bourse city co cybernet db edu gov grondar iaccess imt inca landesign law mil net ngo nis nom olivetti org pix school tm web ',\n 'zm':' ac co com edu gov net org sch ',\n // https://en.wikipedia.org/wiki/CentralNic#Second-level_domains\n 'com': 'ar br cn de eu gb gr hu jpn kr no qc ru sa se uk us uy za ',\n 'net': 'gb jp se uk ',\n 'org': 'ae',\n 'de': 'com '\n },\n // gorhill 2013-10-25: Using indexOf() instead Regexp(). Significant boost\n // in both performance and memory footprint. No initialization required.\n // http://jsperf.com/uri-js-sld-regex-vs-binary-search/4\n // Following methods use lastIndexOf() rather than array.split() in order\n // to avoid any memory allocations.\n has: function(domain) {\n var tldOffset = domain.lastIndexOf('.');\n if (tldOffset <= 0 || tldOffset >= (domain.length-1)) {\n return false;\n }\n var sldOffset = domain.lastIndexOf('.', tldOffset-1);\n if (sldOffset <= 0 || sldOffset >= (tldOffset-1)) {\n return false;\n }\n var sldList = SLD.list[domain.slice(tldOffset+1)];\n if (!sldList) {\n return false;\n }\n return sldList.indexOf(' ' + domain.slice(sldOffset+1, tldOffset) + ' ') >= 0;\n },\n is: function(domain) {\n var tldOffset = domain.lastIndexOf('.');\n if (tldOffset <= 0 || tldOffset >= (domain.length-1)) {\n return false;\n }\n var sldOffset = domain.lastIndexOf('.', tldOffset-1);\n if (sldOffset >= 0) {\n return false;\n }\n var sldList = SLD.list[domain.slice(tldOffset+1)];\n if (!sldList) {\n return false;\n }\n return sldList.indexOf(' ' + domain.slice(0, tldOffset) + ' ') >= 0;\n },\n get: function(domain) {\n var tldOffset = domain.lastIndexOf('.');\n if (tldOffset <= 0 || tldOffset >= (domain.length-1)) {\n return null;\n }\n var sldOffset = domain.lastIndexOf('.', tldOffset-1);\n if (sldOffset <= 0 || sldOffset >= (tldOffset-1)) {\n return null;\n }\n var sldList = SLD.list[domain.slice(tldOffset+1)];\n if (!sldList) {\n return null;\n }\n if (sldList.indexOf(' ' + domain.slice(sldOffset+1, tldOffset) + ' ') < 0) {\n return null;\n }\n return domain.slice(sldOffset+1);\n },\n noConflict: function(){\n if (root.SecondLevelDomains === this) {\n root.SecondLevelDomains = _SecondLevelDomains;\n }\n return this;\n }\n };\n\n return SLD;\n}));\n","import { useContext } from 'react';\nimport contentWidthContext from '../context/contentWidthContext';\n\n/**\n * A hook to get access to the ambient `contentWidth`.\n *\n * @returns The contentWidth available in context.\n *\n * @public\n */\nexport default function useContentWidth() {\n return useContext(contentWidthContext);\n}\n","import React from 'react';\nimport { Dimensions } from 'react-native';\n\nconst contentWidthContext = React.createContext(Dimensions.get('window').width);\n\nexport default contentWidthContext;\n","import { TBlock, TPhrasing, TText } from '@native-html/transient-render-engine';\nimport React from 'react';\nimport { TextProps, ViewProps } from 'react-native';\nimport { TDefaultRendererProps } from '../shared-types';\n\nconst empty: any = {};\n\n/**\n * Extract React Native props for a given {@link TNode}, such as those which\n * would be passed to `Text`, `View` or `GenericPressable` by `TDefaultRenderer`.\n *\n * This helper function is peculiarly useful when one wants a custom renderer\n * which uses a different native component, for example `Animated.Text` instead\n * of default `Text`.\n *\n * @public\n *\n * @example\n *\n * ```tsx\n * import React from 'react';\n * import { Animated } from 'react-native';\n * import { CustomTextualRenderer, getNativePropsForTNode } from 'react-native-render-html';\n *\n * const AnimatedSpanRenderer: CustomTextualRenderer = (props) => {\n * const nativeProps = getNativePropsForTNode(props);\n * // This is equivalent to a TDefaultRenderer which `Text` is replaced\n * // with Animated.Text\n * return ;\n * }\n * ```\n */\nexport default function getNativePropsForTNode<\n T extends TPhrasing | TText | TBlock\n>(\n props: TDefaultRendererProps\n): T extends TBlock ? ViewProps & { onPress?: () => void } : TextProps {\n const {\n tnode,\n style,\n type,\n nativeProps: passedNativeProps,\n onPress,\n children: overridenChildren,\n propsForChildren,\n viewProps,\n textProps,\n TNodeChildrenRenderer\n } = props;\n const children =\n overridenChildren ||\n (tnode.type === 'text'\n ? (tnode as TText).data\n : React.createElement(TNodeChildrenRenderer, {\n tnode,\n propsForChildren\n }));\n const switchProp = type === 'block' ? viewProps : textProps;\n const propsFromModel =\n tnode.getReactNativeProps()?.[type === 'block' ? 'view' : 'text'] || empty;\n const syntheticOnPress =\n onPress ?? passedNativeProps?.onPress ?? propsFromModel.onPress;\n const nativeProps: TextProps | ViewProps = {\n ...(typeof syntheticOnPress === 'function'\n ? ({ accessibilityRole: type === 'block' ? 'button' : 'link' } as const)\n : null),\n ...propsFromModel,\n ...passedNativeProps,\n ...switchProp,\n children,\n onPress: syntheticOnPress,\n style: [style, passedNativeProps?.style, switchProp.style],\n testID: tnode.tagName || undefined\n };\n return nativeProps as any;\n}\n","import React, { PropsWithChildren, useMemo } from 'react';\nimport mergeDeepRight from 'ramda/src/mergeDeepRight';\n\nimport { RenderersProps, RenderHTMLPassedProps } from '../shared-types';\nimport defaultRendererProps from './defaultRendererProps';\nimport useProfiler from '../hooks/useProfiler';\n\nconst RenderersPropsContext =\n React.createContext>(defaultRendererProps);\n\n/**\n * Consume props from {@link RenderHTMLProps.renderersProps}.\n *\n * @param tagName - The name of the element.\n * @typeParam K - The type literal corresponding to the element name.\n * @returns props for this renderer.\n *\n * @public\n */\nexport function useRendererProps<\n RendererProps extends RenderersProps = RenderersProps,\n K extends keyof RendererProps = keyof RendererProps\n>(tagName: K) {\n const userProps = React.useContext(RenderersPropsContext) as RendererProps;\n return userProps[tagName];\n}\n\n/**\n * @internal\n */\nexport default function RenderersPropsProvider(\n props: PropsWithChildren\n) {\n const profile = useProfiler({ prop: 'renderersProps' });\n const mergedRenderersProps = useMemo(() => {\n typeof __DEV__ === 'boolean' && __DEV__ && profile();\n return mergeDeepRight(defaultRendererProps, props.renderersProps || {});\n }, [props.renderersProps, profile]);\n return React.createElement(\n RenderersPropsContext.Provider,\n { value: mergedRenderersProps as Required },\n props.children\n );\n}\n","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar mergeDeepWithKey =\n/*#__PURE__*/\nrequire(\"./mergeDeepWithKey\");\n/**\n * Creates a new object with the own properties of the first object merged with\n * the own properties of the second object. If a key exists in both objects:\n * - and both values are objects, the two values will be recursively merged\n * - otherwise the value from the second object will be used.\n *\n * @func\n * @memberOf R\n * @since v0.24.0\n * @category Object\n * @sig {a} -> {a} -> {a}\n * @param {Object} lObj\n * @param {Object} rObj\n * @return {Object}\n * @see R.merge, R.mergeDeepLeft, R.mergeDeepWith, R.mergeDeepWithKey\n * @example\n *\n * R.mergeDeepRight({ name: 'fred', age: 10, contact: { email: 'moo@example.com' }},\n * { age: 40, contact: { email: 'baa@example.com' }});\n * //=> { name: 'fred', age: 40, contact: { email: 'baa@example.com' }}\n */\n\n\nvar mergeDeepRight =\n/*#__PURE__*/\n_curry2(function mergeDeepRight(lObj, rObj) {\n return mergeDeepWithKey(function (k, lVal, rVal) {\n return rVal;\n }, lObj, rObj);\n});\n\nmodule.exports = mergeDeepRight;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n\nvar _isObject =\n/*#__PURE__*/\nrequire(\"./internal/_isObject\");\n\nvar mergeWithKey =\n/*#__PURE__*/\nrequire(\"./mergeWithKey\");\n/**\n * Creates a new object with the own properties of the two provided objects.\n * If a key exists in both objects:\n * - and both associated values are also objects then the values will be\n * recursively merged.\n * - otherwise the provided function is applied to the key and associated values\n * using the resulting value as the new value associated with the key.\n * If a key only exists in one object, the value will be associated with the key\n * of the resulting object.\n *\n * @func\n * @memberOf R\n * @since v0.24.0\n * @category Object\n * @sig ((String, a, a) -> a) -> {a} -> {a} -> {a}\n * @param {Function} fn\n * @param {Object} lObj\n * @param {Object} rObj\n * @return {Object}\n * @see R.mergeWithKey, R.mergeDeepWith\n * @example\n *\n * let concatValues = (k, l, r) => k == 'values' ? R.concat(l, r) : r\n * R.mergeDeepWithKey(concatValues,\n * { a: true, c: { thing: 'foo', values: [10, 20] }},\n * { b: true, c: { thing: 'bar', values: [15, 35] }});\n * //=> { a: true, b: true, c: { thing: 'bar', values: [10, 20, 15, 35] }}\n */\n\n\nvar mergeDeepWithKey =\n/*#__PURE__*/\n_curry3(function mergeDeepWithKey(fn, lObj, rObj) {\n return mergeWithKey(function (k, lVal, rVal) {\n if (_isObject(lVal) && _isObject(rVal)) {\n return mergeDeepWithKey(fn, lVal, rVal);\n } else {\n return fn(k, lVal, rVal);\n }\n }, lObj, rObj);\n});\n\nmodule.exports = mergeDeepWithKey;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n\nvar _has =\n/*#__PURE__*/\nrequire(\"./internal/_has\");\n/**\n * Creates a new object with the own properties of the two provided objects. If\n * a key exists in both objects, the provided function is applied to the key\n * and the values associated with the key in each object, with the result being\n * used as the value associated with the key in the returned object.\n *\n * @func\n * @memberOf R\n * @since v0.19.0\n * @category Object\n * @sig ((String, a, a) -> a) -> {a} -> {a} -> {a}\n * @param {Function} fn\n * @param {Object} l\n * @param {Object} r\n * @return {Object}\n * @see R.mergeDeepWithKey, R.merge, R.mergeWith\n * @example\n *\n * let concatValues = (k, l, r) => k == 'values' ? R.concat(l, r) : r\n * R.mergeWithKey(concatValues,\n * { a: true, thing: 'foo', values: [10, 20] },\n * { b: true, thing: 'bar', values: [15, 35] });\n * //=> { a: true, b: true, thing: 'bar', values: [10, 20, 15, 35] }\n * @symb R.mergeWithKey(f, { x: 1, y: 2 }, { y: 5, z: 3 }) = { x: 1, y: f('y', 2, 5), z: 3 }\n */\n\n\nvar mergeWithKey =\n/*#__PURE__*/\n_curry3(function mergeWithKey(fn, l, r) {\n var result = {};\n var k;\n\n for (k in l) {\n if (_has(k, l)) {\n result[k] = _has(k, r) ? fn(k, l[k], r[k]) : l[k];\n }\n }\n\n for (k in r) {\n if (_has(k, r) && !_has(k, result)) {\n result[k] = r[k];\n }\n }\n\n return result;\n});\n\nmodule.exports = mergeWithKey;","function _isObject(x) {\n return Object.prototype.toString.call(x) === '[object Object]';\n}\n\nmodule.exports = _isObject;","import { Linking } from 'react-native';\nimport { RenderersProps } from '../shared-types';\n\nexport async function defaultAOnPress(_e: any, href: string): Promise {\n if (await Linking.canOpenURL(href)) {\n return Linking.openURL(href);\n }\n}\n\nconst defaultRendererProps: Required = {\n img: {\n initialDimensions: {\n height: 50,\n width: 50\n },\n enableExperimentalPercentWidth: false\n },\n a: {\n onPress: defaultAOnPress\n },\n ol: {},\n ul: {}\n};\n\nexport default defaultRendererProps;\n","import { useCallback, useRef } from 'react';\nimport identity from 'ramda/src/identity';\n\ndeclare const performance: { now: () => number };\n\nconst useProfiler =\n typeof __DEV__ === 'boolean' && __DEV__ && typeof performance === 'object'\n ? function useProfiler({ name, prop }: { name?: string; prop?: string }) {\n const lastUpdate = useRef(0);\n const profile = useCallback(\n function onUpdate() {\n const now = performance.now();\n const diff = now - lastUpdate.current;\n if (diff < 60) {\n console.warn(\n `You seem to update ${\n prop ? `the ${prop} prop(s)` : 'props'\n } of the \"${\n name ? name : 'RenderHTML'\n }\" component in short periods of time, causing costly tree rerenders (last update was ${diff.toFixed(\n 2\n )}ms ago). See https://stackoverflow.com/q/68966120/2779871`\n );\n }\n lastUpdate.current = now;\n },\n [name, prop]\n );\n return profile;\n }\n : /* istanbul ignore next */\n function useProfiler() {\n return identity as () => void;\n };\n\nexport default useProfiler;\n","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar _identity =\n/*#__PURE__*/\nrequire(\"./internal/_identity\");\n/**\n * A function that does nothing but return the parameter supplied to it. Good\n * as a default or placeholder function.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Function\n * @sig a -> a\n * @param {*} x The value to return.\n * @return {*} The input value, `x`.\n * @example\n *\n * R.identity(1); //=> 1\n *\n * const obj = {};\n * R.identity(obj) === obj; //=> true\n * @symb R.identity(a) = a\n */\n\n\nvar identity =\n/*#__PURE__*/\n_curry1(_identity);\n\nmodule.exports = identity;","function _identity(x) {\n return x;\n}\n\nmodule.exports = _identity;","import React, { ReactElement } from 'react';\nimport { RenderHTMLProps } from './shared-types';\nimport RenderHTMLDebug from './RenderHTMLDebug';\nimport TRenderEngineProvider from './TRenderEngineProvider';\nimport RenderHTMLConfigProvider from './RenderHTMLConfigProvider';\nimport RenderHTMLSource from './RenderHTMLSource';\n\n/**\n * Render HTML text in native views!\n *\n * @remarks If your application uses many instances of this component, you\n * should share the render engine across those instances via the\n * {@link TRenderEngineProvider} and {@link RenderHTMLConfigProvider}\n * components, and render the HTML with {@link RenderHTMLSource} instead. That\n * should significantly increase performance.\n *\n * @warning It should never be a child of a React Native `Text` element, as the\n * layout will break.\n *\n * @public\n */\nexport default function RenderHTML(props: RenderHTMLProps): ReactElement {\n const {\n source,\n onHTMLLoaded,\n onTTreeChange,\n onDocumentMetadataLoaded,\n contentWidth,\n ...otherProps\n } = props;\n return (\n \n \n \n {React.createElement(RenderHTMLSource, {\n source,\n onHTMLLoaded,\n onTTreeChange,\n onDocumentMetadataLoaded,\n contentWidth\n })}\n \n \n \n );\n}\n","import React, { Fragment, PropsWithChildren } from 'react';\nimport debugMessage from './debugMessages';\nimport { RenderHTMLProps } from './shared-types';\n\nconst RenderHTMLDebug = function RenderHTMLDebug(\n props: PropsWithChildren\n) {\n if (typeof __DEV__ === 'boolean' && __DEV__) {\n if (typeof props.contentWidth !== 'number') {\n console.warn(debugMessage.contentWidth);\n }\n if ('html' in props) {\n console.warn(debugMessage.outdatedHtmlProp);\n }\n if ('uri' in props) {\n console.warn(debugMessage.outdatedUriProp);\n }\n if ('listsPrefixesRenderers' in props) {\n console.warn(debugMessage.outdatedListPrefixRenderersProps);\n }\n if ('imagesInitialDimensions' in props) {\n console.warn(debugMessage.outdatedImagesDimensions);\n }\n if ('onLinkPress' in props) {\n console.warn(debugMessage.outdatedOnLinkPressProp);\n }\n if ('enableExperimentalPercentWidth' in props) {\n console.warn(debugMessage.outdatedEnableExperimentalPercentWidth);\n }\n if ('ignoreNodesFunction' in props) {\n console.warn(debugMessage.outdatedIgnoreNodesFunction);\n }\n if ('alterNode' in props) {\n console.warn(debugMessage.outdatedAlterNode);\n }\n if ('alterChildren' in props) {\n console.warn(debugMessage.outdatedAlterChildren);\n }\n if ('alterData' in props) {\n console.warn(debugMessage.outdatedAlterData);\n }\n if ('computeImagesMaxWidth' in props) {\n console.warn(debugMessage.outdatedComputeImagesMaxWidth);\n }\n if ('triggerTREInvalidationPropNames' in props) {\n console.warn(debugMessage.outdatedTriggerTREInvalidation);\n }\n if (Array.isArray(props.allowedStyles)) {\n props.allowedStyles.forEach((s) => {\n if (s.indexOf('-') > -1) {\n console.warn(\n `Style property '${s}' of 'allowedStyles' prop array must be camelCased.`\n );\n }\n });\n }\n if (Array.isArray(props.ignoredStyles)) {\n props.ignoredStyles.forEach((s) => {\n if (s.indexOf('-') > -1) {\n console.warn(\n `Style property '${s}' of 'ignoredStyles' prop array must be camelCased.`\n );\n }\n });\n }\n }\n return {props.children};\n};\n\nexport default RenderHTMLDebug;\n","export type DebugType =\n | 'noSource'\n | 'contentWidth'\n | 'outdatedUriProp'\n | 'outdatedHtmlProp'\n | 'outdatedListPrefixRenderersProps'\n | 'outdatedImagesDimensions'\n | 'outdatedOnLinkPressProp'\n | 'outdatedEnableExperimentalPercentWidth'\n | 'outdatedIgnoreNodesFunction'\n | 'outdatedAlterNode'\n | 'outdatedAlterChildren'\n | 'outdatedAlterData'\n | 'outdatedComputeImagesMaxWidth'\n | 'outdatedTriggerTREInvalidation';\n\nlet debugMessage: Record;\n\nexport type DebugMessages = typeof debugMessage;\n/* istanbul ignore next */\nif (typeof __DEV__ === 'boolean' && __DEV__) {\n debugMessage = {\n outdatedComputeImagesMaxWidth:\n \"You're attempting to use an outdated prop, 'computeImagesMaxWidth'. This prop has been replaced in version 6 with 'computeEmbeddedMaxWidth'.\",\n outdatedAlterChildren:\n \"You're attempting to use an outdated prop, 'alterChildren'. This prop has been discontinued in version 6. \" +\n \"Use 'domVisitors={{ onElement }}' instead, and tamper the children manually from here. Use 'domutils' package for easy DOM manipulation.\",\n outdatedAlterData:\n \"You're attempting to use an outdated prop, 'alterData'. This prop has been discontinued in version 6. \" +\n \"Use 'domVisitors={{ onText }}' instead, and tamper the node data field manually from here.\",\n outdatedAlterNode:\n \"You're attempting to use an outdated prop, 'alterNode'. This prop has been discontinued in version 6. \" +\n \"Use 'domVisitors={{ onElement }}' instead, and tamper the node manually from here. Use 'domutils' package for easy DOM manipulation.\",\n outdatedIgnoreNodesFunction:\n \"You're attempting to use an outdated prop, 'ignoreNodesFunction'. This prop has been replaced in version 6 with 'ignoreDomNode'.\",\n outdatedUriProp:\n \"You're attempting to use an outdated prop, 'uri'. This prop has been discontinued in version 6. \" +\n \"Use 'source={{ uri }}' instead.\",\n outdatedHtmlProp:\n \"You're attempting to use an outdated prop, 'html'. This prop has been discontinued in version 6. \" +\n \"Use 'source={{ html }}' instead.\",\n outdatedListPrefixRenderersProps:\n \"You're attempting to use an outdated prop, 'listPrefixRenderers'. This prop has been discontinued in version 6. \" +\n \"Use 'customListStyleSpecs' instead.\",\n outdatedImagesDimensions:\n \"You're attempting to use an outdated prop, 'imagesInitialDimensions'. This prop has been discontinued in version 6. \" +\n \"Use 'renderersProps={{ img: { initialDimensions } }}' instead.\",\n outdatedOnLinkPressProp:\n \"You're attempting to use an outdated prop, 'onLinkPress'. This prop has been discontinued in version 6. \" +\n \"Use 'renderersProps={{ a: { onPress } }}' instead.\",\n outdatedEnableExperimentalPercentWidth:\n \"You're attempting to use an outdated prop, 'enableExperimentalPercentWidth'. This prop has been discontinued in version 6. \" +\n \"Use 'renderersProps={{ img: { enableExperimentalPercentWidth } }}' instead.\",\n outdatedTriggerTREInvalidation:\n \"You're attempting to use an outdated prop, 'triggerTREInvalidationPropsNames'. This prop has been discontinued in v6.0.0-beta.3. \" +\n 'From now-on, every prop sent to the TRenderEngineProvider is hot by default.',\n noSource: 'No source prop was provided. Nothing will be rendered',\n contentWidth:\n 'You should always pass contentWidth prop to properly handle screen rotations ' +\n 'and have a seamless support for images scaling. ' +\n 'In the meantime, HTML will fallback to Dimensions.window().width, but its ' +\n 'layout will become inconsistent after screen rotations. ' +\n 'You are encouraged to use useWindowDimensions hook, see: ' +\n 'https://reactnative.dev/docs/usewindowdimensions'\n };\n} else {\n debugMessage = null as any;\n}\n\nexport default debugMessage;\n","import TRenderEngine from '@native-html/transient-render-engine';\nimport React, { PropsWithChildren, ReactElement } from 'react';\nimport { Platform } from 'react-native';\nimport PropTypes from 'prop-types';\nimport useTRenderEngine from './hooks/useTRenderEngine';\nimport { TRenderEngineConfig } from './shared-types';\nimport defaultSystemFonts from './defaultSystemFonts';\n\nconst defaultTRenderEngine = {} as any;\n\nconst TRenderEngineContext =\n React.createContext(defaultTRenderEngine);\n\nexport const tRenderEngineProviderPropTypes: Record<\n keyof TRenderEngineConfig,\n any\n> = {\n customHTMLElementModels: PropTypes.object.isRequired,\n enableCSSInlineProcessing: PropTypes.bool,\n enableUserAgentStyles: PropTypes.bool,\n idsStyles: PropTypes.object,\n ignoredDomTags: PropTypes.array,\n ignoreDomNode: PropTypes.func,\n domVisitors: PropTypes.object,\n ignoredStyles: PropTypes.array.isRequired,\n allowedStyles: PropTypes.array,\n htmlParserOptions: PropTypes.object,\n tagsStyles: PropTypes.object,\n classesStyles: PropTypes.object,\n emSize: PropTypes.number.isRequired,\n baseStyle: PropTypes.object,\n systemFonts: PropTypes.arrayOf(PropTypes.string),\n fallbackFonts: PropTypes.shape({\n serif: PropTypes.string,\n 'sans-serif': PropTypes.string,\n monospace: PropTypes.string\n }),\n setMarkersForTNode: PropTypes.func,\n dangerouslyDisableHoisting: PropTypes.bool,\n dangerouslyDisableWhitespaceCollapsing: PropTypes.bool,\n selectDomRoot: PropTypes.func\n};\n\n/**\n * Default fallback font for special keys such as 'sans-serif', 'monospace',\n * 'serif', based on current platform.\n */\nexport const defaultFallbackFonts = {\n 'sans-serif': Platform.select({ ios: 'system', default: 'sans-serif' }),\n monospace: Platform.select({ ios: 'Menlo', default: 'monospace' }),\n serif: Platform.select({ ios: 'Times New Roman', default: 'serif' })\n};\n\nexport const defaultTRenderEngineProviderProps: TRenderEngineConfig = {\n htmlParserOptions: {\n decodeEntities: true\n },\n emSize: 14,\n ignoredDomTags: [],\n ignoredStyles: [],\n baseStyle: { fontSize: 14 },\n tagsStyles: {},\n classesStyles: {},\n enableUserAgentStyles: true,\n enableCSSInlineProcessing: true,\n customHTMLElementModels: {},\n fallbackFonts: defaultFallbackFonts,\n systemFonts: defaultSystemFonts\n};\n\n/**\n * Use the ambient transient render engine.\n *\n * @returns The ambient transient render engine.\n *\n * @public\n */\nexport function useAmbientTRenderEngine() {\n const engine = React.useContext(TRenderEngineContext);\n if (\n typeof __DEV__ === 'boolean' &&\n __DEV__ &&\n engine === defaultTRenderEngine\n ) {\n console.error('TRenderEngineProvider is missing in the render tree.');\n }\n return engine;\n}\n\n/**\n * A react component to share a {@link TRenderEngine} instance across different\n * rendered contents via {@link RenderHTMLSource}. This can significantly enhance\n * performance in applications with potentially dozens or hundreds of distinct\n * rendered snippets such as chat apps.\n *\n * @param props - Pass engine config here.\n */\nexport default function TRenderEngineProvider({\n children,\n ...config\n}: PropsWithChildren): ReactElement {\n const engine = useTRenderEngine(config);\n return (\n \n {children}\n \n );\n}\n\n/**\n * @ignore\n */\nTRenderEngineProvider.defaultProps = defaultTRenderEngineProviderProps;\n\n/**\n * @ignore\n */\nTRenderEngineProvider.propTypes = tRenderEngineProviderPropTypes;\n","import { useMemo } from 'react';\nimport { TRenderEngineConfig } from '../shared-types';\nimport buildTREFromConfig from '../helpers/buildTREFromConfig';\nimport useProfiler from './useProfiler';\n\n/**\n * @internal\n */\nexport default function useTRenderEngine({\n allowedStyles,\n baseStyle,\n classesStyles,\n customHTMLElementModels,\n dangerouslyDisableHoisting,\n dangerouslyDisableWhitespaceCollapsing,\n domVisitors,\n emSize,\n enableCSSInlineProcessing,\n enableUserAgentStyles,\n fallbackFonts,\n htmlParserOptions,\n idsStyles,\n ignoreDomNode,\n ignoredDomTags,\n ignoredStyles,\n selectDomRoot,\n setMarkersForTNode,\n systemFonts,\n tagsStyles\n}: TRenderEngineConfig) {\n const profile = useProfiler({ name: 'TRenderEngineProvider' });\n return useMemo(() => {\n typeof __DEV__ === 'boolean' && __DEV__ && profile();\n return buildTREFromConfig({\n allowedStyles,\n baseStyle,\n classesStyles,\n customHTMLElementModels,\n dangerouslyDisableHoisting,\n dangerouslyDisableWhitespaceCollapsing,\n domVisitors,\n emSize,\n enableCSSInlineProcessing,\n enableUserAgentStyles,\n fallbackFonts,\n htmlParserOptions,\n idsStyles,\n ignoreDomNode,\n ignoredDomTags,\n ignoredStyles,\n selectDomRoot,\n setMarkersForTNode,\n systemFonts,\n tagsStyles\n });\n }, [\n profile,\n allowedStyles,\n baseStyle,\n classesStyles,\n customHTMLElementModels,\n dangerouslyDisableHoisting,\n dangerouslyDisableWhitespaceCollapsing,\n domVisitors,\n emSize,\n enableCSSInlineProcessing,\n enableUserAgentStyles,\n fallbackFonts,\n htmlParserOptions,\n idsStyles,\n ignoreDomNode,\n ignoredDomTags,\n ignoredStyles,\n selectDomRoot,\n setMarkersForTNode,\n systemFonts,\n tagsStyles\n ]);\n}\n","import { TRenderEngineConfig } from '../shared-types';\nimport TRenderEngine, {\n HTMLModelRecord,\n TagName\n} from '@native-html/transient-render-engine';\n\n/**\n * Build a {@link TRenderEngine} instance from a configuration object.\n *\n * @remarks This utility can be useful to test and debug the TRE layer of your\n * application.\n *\n * @param props - The configuration from which a TRE should be built.\n */\nexport default function buildTREFromConfig(props: TRenderEngineConfig) {\n const {\n allowedStyles,\n // TODO fix upstream\n ignoredStyles = [],\n ignoredDomTags,\n ignoreDomNode,\n domVisitors,\n htmlParserOptions,\n baseStyle,\n classesStyles,\n tagsStyles,\n idsStyles,\n enableCSSInlineProcessing,\n enableUserAgentStyles,\n systemFonts = [],\n fallbackFonts = {},\n customHTMLElementModels = {},\n emSize,\n setMarkersForTNode,\n selectDomRoot,\n dangerouslyDisableHoisting,\n dangerouslyDisableWhitespaceCollapsing\n } = props;\n const customizeHTMLModels = Object.keys(customHTMLElementModels).length\n ? (defaultModels: HTMLModelRecord): HTMLModelRecord => {\n return { ...defaultModels, ...customHTMLElementModels };\n }\n : undefined;\n const fontMap = {} as Record;\n systemFonts.forEach((font) => {\n fontMap[font] = true;\n });\n const isFontSupported = (fontFamily: string) => {\n if (fallbackFonts[fontFamily as keyof typeof fallbackFonts]) {\n return fallbackFonts[fontFamily as keyof typeof fallbackFonts];\n }\n /* istanbul ignore next */\n return fontMap[fontFamily] || false;\n };\n return new TRenderEngine({\n customizeHTMLModels,\n cssProcessorConfig: {\n isFontSupported,\n inlinePropertiesBlacklist: ignoredStyles,\n inlinePropertiesWhitelist: allowedStyles,\n rootFontSize: emSize\n },\n htmlParserOptions: {\n decodeEntities: true,\n ...htmlParserOptions\n },\n stylesConfig: {\n baseStyle,\n enableCSSInlineProcessing,\n enableUserAgentStyles,\n classesStyles,\n idsStyles,\n tagsStyles\n },\n ignoredDomTags,\n ignoreDomNode,\n domVisitors,\n setMarkersForTNode,\n selectDomRoot,\n dangerouslyDisableHoisting,\n dangerouslyDisableWhitespaceCollapsing\n });\n}\n","const defaultSystemFonts = [\n 'San Francisco',\n 'Arial',\n 'ArialHebrew',\n 'Avenir',\n 'Baskerville',\n 'Bodoni 72',\n 'Bradley Hand',\n 'Chalkboard SE',\n 'Cochin',\n 'Copperplate',\n 'Courier',\n 'Courier New',\n 'Damascus',\n 'Didot',\n 'Futura',\n 'Geeza Pro',\n 'Georgia',\n 'Gill Sans',\n 'Helvetica',\n 'Helvetica Neue',\n 'Hiragino Sans',\n 'Hoefler Text',\n 'Iowan Old Style',\n 'Kailasa',\n 'Khmer Sangam MN',\n 'Marker Felt',\n 'Menlo',\n 'Mishafi',\n 'Noteworthy',\n 'Optima',\n 'Palatino',\n 'Papyrus',\n 'Savoye LET',\n 'Symbol',\n 'Thonburi',\n 'Times New Roman',\n 'Trebuchet MS',\n 'Verdana',\n 'Zapf Dingbats',\n 'Zapfino'\n];\n\nexport default defaultSystemFonts;\n","import React, { PropsWithChildren, ReactElement, useMemo } from 'react';\nimport PropTypes from 'prop-types';\nimport RenderersPropsProvider from './context/RenderersPropsProvider';\nimport SharedPropsProvider from './context/SharedPropsProvider';\nimport TChildrenRenderersContext from './context/TChildrenRendererContext';\nimport { RenderHTMLConfig } from './shared-types';\nimport TNodeChildrenRenderer from './TNodeChildrenRenderer';\nimport TChildrenRenderer from './TChildrenRenderer';\nimport sourceLoaderContext, {\n defaultRenderError,\n defaultRenderLoading\n} from './context/sourceLoaderContext';\nimport RenderRegistryProvider from './context/RenderRegistryProvider';\nimport { useAmbientTRenderEngine } from './TRenderEngineProvider';\nimport useProfiler from './hooks/useProfiler';\nimport ListStyleSpecsProvider from './context/ListStyleSpecsProvider';\n\nconst childrenRendererContext = {\n TChildrenRenderer,\n TNodeChildrenRenderer\n};\n\nexport type RenderHTMLConfigPropTypes = Record;\n\nexport const renderHTMLConfigPropTypes: RenderHTMLConfigPropTypes = {\n bypassAnonymousTPhrasingNodes: PropTypes.bool,\n defaultTextProps: PropTypes.object,\n defaultViewProps: PropTypes.object,\n enableExperimentalBRCollapsing: PropTypes.bool,\n enableExperimentalGhostLinesPrevention: PropTypes.bool,\n enableExperimentalMarginCollapsing: PropTypes.bool,\n remoteErrorView: PropTypes.func,\n remoteLoadingView: PropTypes.func,\n debug: PropTypes.bool,\n computeEmbeddedMaxWidth: PropTypes.func,\n renderersProps: PropTypes.object,\n WebView: PropTypes.any,\n GenericPressable: PropTypes.any,\n defaultWebViewProps: PropTypes.object,\n pressableHightlightColor: PropTypes.string,\n customListStyleSpecs: PropTypes.object,\n renderers: PropTypes.object,\n provideEmbeddedHeaders: PropTypes.func\n};\n\n/**\n * A component to provide configuration for {@link RenderHTMLSource}\n * descendants, to be used in conjunction with {@link TRenderEngineProvider}.\n */\nexport default function RenderHTMLConfigProvider(\n props: PropsWithChildren\n): ReactElement {\n const {\n remoteErrorView,\n remoteLoadingView,\n renderersProps,\n children,\n renderers,\n ...sharedProps\n } = props;\n const engine = useAmbientTRenderEngine();\n const profile = useProfiler({ prop: 'remoteErrorView or remoteLoadingView' });\n const sourceLoaderConfig = useMemo(() => {\n typeof __DEV__ === 'boolean' && __DEV__ && profile();\n return {\n remoteErrorView: remoteErrorView || defaultRenderError,\n remoteLoadingView: remoteLoadingView || defaultRenderLoading\n };\n }, [remoteErrorView, remoteLoadingView, profile]);\n return (\n \n \n \n \n \n \n {children}\n \n \n \n \n \n \n );\n}\n\n/**\n * @ignore\n */\nRenderHTMLConfigProvider.propTypes = renderHTMLConfigPropTypes;\n","import React from 'react';\nimport type TNodeChildrenRenderer from '../TNodeChildrenRenderer';\nimport type TChildrenRenderer from '../TChildrenRenderer';\n\n/**\n * This context allows dependency injection to avoid circular dependencies.\n */\nconst TChildrenRenderersContext = React.createContext<{\n TChildrenRenderer: typeof TChildrenRenderer;\n TNodeChildrenRenderer: typeof TNodeChildrenRenderer;\n}>({\n TChildrenRenderer: null as any,\n TNodeChildrenRenderer: null as any\n});\n\nexport function useTNodeChildrenRenderer() {\n return React.useContext(TChildrenRenderersContext).TNodeChildrenRenderer;\n}\n\nexport function useTChildrenRenderer() {\n return React.useContext(TChildrenRenderersContext).TChildrenRenderer;\n}\n\nexport default TChildrenRenderersContext;\n","import { ReactElement } from 'react';\nimport { TNode } from '@native-html/transient-render-engine';\nimport { useSharedProps } from './context/SharedPropsProvider';\nimport { tchildrenRendererDefaultProps } from './TChildrenRenderer';\nimport {\n TChildrenRendererProps,\n TNodeChildrenRendererProps\n} from './shared-types';\nimport renderChildren from './renderChildren';\n\nfunction isCollapsible(tnode: TNode) {\n return tnode.type === 'block' || tnode.type === 'phrasing';\n}\n\n/**\n * A hook especially useful when one need to tamper with children in a custom\n * renderer. Should be used with {@link TChildrenRenderer}.\n *\n * @example\n * For example, a custom renderer which inserts ads in an article:\n *\n * ```tsx\n * function ArticleRenderer(props) {\n * const { tnode, TDefaultRenderer, ...defaultRendererProps } = props;\n * const tchildrenProps = useTNodeChildrenProps(props);\n * const firstChildrenChunk = tnode.children.slice(0, 2);\n * const secondChildrenChunk = tnode.children.slice(2, 4);\n * const thirdChildrenChunk = tnode.children.slice(4, 5);\n * return (\n * \n * \n * {firstChildrenChunk.length === 2 ? : null}\n * \n * {secondChildrenChunk.length === 2 ? : null}\n * \n * \n * );\n * };\n * ```\n */\nexport function useTNodeChildrenProps({\n tnode,\n propsForChildren,\n disableMarginCollapsing = false,\n renderChild\n}: TNodeChildrenRendererProps): TChildrenRendererProps {\n const { enableExperimentalMarginCollapsing } = useSharedProps();\n const shouldCollapseChildren =\n enableExperimentalMarginCollapsing &&\n !disableMarginCollapsing &&\n isCollapsible(tnode);\n return {\n propsForChildren,\n disableMarginCollapsing: !shouldCollapseChildren,\n tchildren: tnode.children,\n renderChild\n };\n}\n\n/**\n * A component to render all children of a {@link TNode}.\n */\nfunction TNodeChildrenRenderer(\n props: TNodeChildrenRendererProps\n): ReactElement {\n if (props.tnode.type === 'text') {\n // see https://github.com/DefinitelyTyped/DefinitelyTyped/issues/20544\n return props.tnode.data as unknown as ReactElement;\n }\n // A tnode type will never change. We can safely\n // ignore the non-conditional rule of hooks.\n // eslint-disable-next-line react-hooks/rules-of-hooks\n return renderChildren(useTNodeChildrenProps(props));\n}\n\n/**\n * @ignore\n */\nTNodeChildrenRenderer.defaultProps = tchildrenRendererDefaultProps;\n\nexport default TNodeChildrenRenderer;\n","import React, { ReactElement } from 'react';\nimport { TNode } from '@native-html/transient-render-engine';\nimport TNodeRenderer from './TNodeRenderer';\nimport { TChildrenRendererProps } from './shared-types';\nimport collapseTopMarginForChild from './helpers/collapseTopMarginForChild';\n\nconst empty = {};\n\nconst mapCollapsibleChildren = (\n propsForChildren: TChildrenRendererProps['propsForChildren'],\n renderChild: TChildrenRendererProps['renderChild'],\n disableMarginCollapsing: boolean | undefined,\n childTnode: TNode,\n n: number,\n tchildren: readonly TNode[]\n) => {\n const collapsedMarginTop = disableMarginCollapsing\n ? null\n : collapseTopMarginForChild(n, tchildren);\n const propsFromParent = { ...propsForChildren, collapsedMarginTop };\n const key = childTnode.nodeIndex;\n const childElement = React.createElement(TNodeRenderer, {\n propsFromParent,\n tnode: childTnode,\n key,\n renderIndex: n,\n renderLength: tchildren.length\n });\n return typeof renderChild === 'function'\n ? renderChild({\n key,\n childElement,\n index: n,\n childTnode,\n propsFromParent\n })\n : childElement;\n};\n\nexport default function renderChildren({\n tchildren,\n propsForChildren = empty,\n disableMarginCollapsing,\n renderChild\n}: TChildrenRendererProps): ReactElement {\n const elements = tchildren.map(\n mapCollapsibleChildren.bind(\n null,\n propsForChildren,\n renderChild,\n disableMarginCollapsing\n )\n );\n return <>{elements};\n}\n","import React, { memo, ReactElement } from 'react';\nimport { TDefaultRenderer, TNodeRendererProps } from './shared-types';\nimport { useSharedProps } from './context/SharedPropsProvider';\nimport {\n TText,\n TBlock,\n TNode,\n TPhrasing\n} from '@native-html/transient-render-engine';\nimport useAssembledCommonProps from './hooks/useAssembledCommonProps';\nimport { useTNodeChildrenRenderer } from './context/TChildrenRendererContext';\nimport renderTextualContent from './renderTextualContent';\nimport { useRendererRegistry } from './context/RenderRegistryProvider';\nimport renderBlockContent from './renderBlockContent';\nimport renderEmptyContent from './renderEmptyContent';\n\nexport type { TNodeRendererProps } from './shared-types';\n\nconst TDefaultBlockRenderer: TDefaultRenderer =\n renderBlockContent.bind(null);\n\nTDefaultBlockRenderer.displayName = 'TDefaultBlockRenderer';\n\nconst TDefaultPhrasingRenderer: TDefaultRenderer =\n renderTextualContent.bind(null);\n\nTDefaultPhrasingRenderer.displayName = 'TDefaultPhrasingRenderer';\n\nconst TDefaultTextRenderer: TDefaultRenderer =\n renderTextualContent.bind(null);\n\nTDefaultTextRenderer.displayName = 'TDefaultTextRenderer';\n\nfunction isGhostTNode(tnode: TNode) {\n return (\n (tnode.type === 'text' && (tnode.data === '' || tnode.data === ' ')) ||\n tnode.type === 'empty'\n );\n}\n\n/**\n * A component to render any {@link TNode}.\n */\nconst TNodeRenderer = memo(function MemoizedTNodeRenderer(\n props: TNodeRendererProps\n): ReactElement | null {\n const { tnode } = props;\n const sharedProps = useSharedProps();\n const renderRegistry = useRendererRegistry();\n const TNodeChildrenRenderer = useTNodeChildrenRenderer();\n const tnodeProps = {\n ...props,\n TNodeChildrenRenderer,\n sharedProps\n };\n const renderer =\n tnode.type === 'block' || tnode.type === 'document'\n ? TDefaultBlockRenderer\n : tnode.type === 'text'\n ? TDefaultTextRenderer\n : tnode.type === 'phrasing'\n ? TDefaultPhrasingRenderer\n : renderEmptyContent;\n\n const { assembledProps, Renderer } = useAssembledCommonProps(\n tnodeProps,\n renderer as any\n );\n switch (tnode.type) {\n case 'empty':\n return renderEmptyContent(assembledProps);\n case 'text':\n const InternalTextRenderer = renderRegistry.getInternalTextRenderer(\n props.tnode.tagName\n );\n\n if (InternalTextRenderer) {\n return React.createElement(InternalTextRenderer, tnodeProps);\n }\n // If ghost line prevention is enabled and the text data is empty, render\n // nothing to avoid React Native painting a 20px height line.\n // See also https://git.io/JErwX\n if (\n tnodeProps.tnode.data === '' &&\n tnodeProps.sharedProps.enableExperimentalGhostLinesPrevention\n ) {\n return null;\n }\n break;\n case 'phrasing':\n // When a TPhrasing node is anonymous and has only one child, its\n // rendering amounts to rendering its only child.\n if (\n tnodeProps.sharedProps.bypassAnonymousTPhrasingNodes &&\n tnodeProps.tnode.tagName == null &&\n tnodeProps.tnode.children.length <= 1\n ) {\n return React.createElement(TNodeChildrenRenderer, {\n tnode: props.tnode\n });\n }\n // If ghost line prevention is enabled and the tnode is an anonymous empty\n // phrasing node, render nothing to avoid React Native painting a 20px\n // height line. See also https://git.io/JErwX\n if (\n tnodeProps.sharedProps.enableExperimentalGhostLinesPrevention &&\n tnodeProps.tnode.tagName == null &&\n tnodeProps.tnode.children.every(isGhostTNode)\n ) {\n return null;\n }\n break;\n }\n const renderFn =\n tnode.type === 'block' || tnode.type === 'document'\n ? renderBlockContent\n : renderTextualContent;\n return Renderer === null\n ? renderFn(assembledProps)\n : React.createElement(Renderer as any, assembledProps);\n});\n\nconst defaultProps: Required, 'propsFromParent'>> =\n {\n propsFromParent: {\n collapsedMarginTop: null\n }\n };\n\n// @ts-expect-error default props must be defined\nTNodeRenderer.defaultProps = defaultProps;\n\nexport {\n TDefaultBlockRenderer,\n TDefaultPhrasingRenderer,\n TDefaultTextRenderer\n};\n\nexport default TNodeRenderer;\n","import { TNode } from '@native-html/transient-render-engine';\nimport {\n CustomRenderer,\n CustomRendererProps,\n InternalRenderer,\n InternalRendererProps,\n TDefaultRenderer,\n TDefaultRendererProps\n} from '../shared-types';\nimport { TNodeSubRendererProps } from '../internal-types';\nimport mergeCollapsedMargins from '../helpers/mergeCollapsedMargins';\nimport { useRendererConfig } from '../context/RenderRegistryProvider';\nimport { useDefaultContainerProps } from '../context/SharedPropsProvider';\n\n/**\n * @internal\n */\nexport default function useAssembledCommonProps(\n {\n tnode,\n propsFromParent,\n sharedProps,\n renderIndex,\n renderLength,\n TNodeChildrenRenderer\n }: TNodeSubRendererProps,\n TDefault: TDefaultRenderer | null\n): {\n Renderer: CustomRenderer | InternalRenderer | null;\n assembledProps: CustomRendererProps &\n TDefaultRendererProps &\n InternalRendererProps;\n} {\n const { Default, Custom } = useRendererConfig(tnode);\n const containerProps = useDefaultContainerProps();\n const assembledProps: CustomRendererProps & TDefaultRendererProps = {\n tnode,\n propsFromParent,\n sharedProps,\n TDefaultRenderer: TDefault as TDefaultRenderer,\n TNodeChildrenRenderer,\n style: mergeCollapsedMargins(\n propsFromParent?.collapsedMarginTop,\n tnode.getNativeStyles()\n ) as any,\n type: tnode.type === 'text' || tnode.type === 'phrasing' ? 'text' : 'block',\n propsForChildren: tnode.tagName ? {} : propsFromParent,\n InternalRenderer: Default || (TDefault as any),\n renderIndex,\n renderLength,\n ...containerProps\n };\n return {\n assembledProps,\n Renderer: Custom || Default || null\n };\n}\n","import { TNodeShape, TNodeType } from '@native-html/transient-render-engine';\n\nexport default function mergeCollapsedMargins(\n collapsedMarginTop: number | null | undefined,\n nativeStyle: ReturnType['getNativeStyles']>\n): ReturnType['getNativeStyles']> {\n if (typeof collapsedMarginTop !== 'number') {\n return nativeStyle;\n }\n return {\n ...nativeStyle,\n marginTop: collapsedMarginTop\n };\n}\n","import { TNode, TText } from '@native-html/transient-render-engine';\nimport React, { PropsWithChildren, useMemo } from 'react';\nimport useProfiler from '../hooks/useProfiler';\nimport { CustomTagRendererRecord } from '../render/render-types';\nimport RenderRegistry from '../render/RenderRegistry';\nimport { HTMLElementModelRecord } from '../shared-types';\n\nexport const RenderRegistryContext = React.createContext(\n null as any\n);\n\nexport function useRendererRegistry() {\n return React.useContext(RenderRegistryContext);\n}\n\nexport function useRendererConfig(tnode: T) {\n return React.useContext(RenderRegistryContext).getRendererConfigForTNode(\n tnode\n );\n}\n\nexport function useInternalTextRenderer(tnode: TText) {\n return React.useContext(RenderRegistryContext).getInternalTextRenderer(\n tnode.tagName\n );\n}\n\nexport default function RenderRegistryProvider({\n children,\n elementModels,\n renderers\n}: PropsWithChildren<{\n elementModels: HTMLElementModelRecord;\n renderers?: CustomTagRendererRecord;\n}>) {\n const profile = useProfiler({ prop: 'renderers' });\n const registry = useMemo(() => {\n typeof __DEV__ === 'boolean' && __DEV__ && profile();\n return new RenderRegistry(renderers, elementModels);\n }, [renderers, elementModels, profile]);\n return (\n \n {children}\n \n );\n}\n","import { TNode } from '@native-html/transient-render-engine';\nimport { ComponentType } from 'react';\nimport { CustomRendererProps } from '..';\nimport lookupRecord from '../helpers/lookupRecord';\nimport BRRenderer from '../renderers/BRRenderer';\nimport WBRRenderer from '../renderers/WBRRenderer';\nimport {\n CustomRenderer,\n HTMLElementModelRecord,\n InternalRenderer\n} from '../shared-types';\nimport internalRenderers from './internalRenderers';\nimport {\n CustomTagRendererRecord,\n InternalTextContentRenderer\n} from './render-types';\n\nconst internalTextRenderers: Record = {\n br: BRRenderer,\n wbr: WBRRenderer\n};\n\nexport interface RendererConfig {\n Custom: CustomRenderer | null;\n Default: InternalRenderer | null;\n}\n\nexport default class RenderRegistry {\n constructor(\n customRenderers: CustomTagRendererRecord = {},\n elementModels: HTMLElementModelRecord\n ) {\n this.customRenderers = customRenderers;\n this.elementModels = elementModels;\n }\n\n private readonly customRenderers: CustomTagRendererRecord = {};\n private readonly elementModels: HTMLElementModelRecord;\n\n private getCustomRendererForTNode(\n tnode: T\n ): ComponentType> | null {\n if (tnode.tagName! in this.customRenderers) {\n const renderer = this.customRenderers[tnode.tagName!];\n /* istanbul ignore next */\n if (typeof __DEV__ === 'boolean' && __DEV__) {\n // In DEV, check for discrepancies.\n const elementModel = this.elementModels[tnode.tagName!];\n if (!elementModel) {\n console.warn(\n `You are attempting to render a ${tnode.tagName!} tag but you didn't provide an HTMLElementModel. Make sure you register a model for this tag in \"customHTMLElementModels\" prop. `\n );\n } else if (!tnode.matchContentModel(elementModel.contentModel)) {\n console.warn(\n `You are attempting to render \"${tnode.tagName}\" of type \"${tnode.displayName}\", but the registered renderer is of content model type ${elementModel?.contentModel} which is incompatible with \"${tnode.displayName}\".`\n );\n }\n }\n return renderer as any;\n }\n return null;\n }\n\n private getDefaultRendererForTNode(\n tnode: T\n ): InternalRenderer | null {\n if (tnode.tagName! in internalRenderers) {\n //@ts-expect-error we know that the tagName is in the map\n return internalRenderers[tnode.tagName!];\n }\n return null;\n }\n\n getInternalTextRenderer(tagName: string | null) {\n if (lookupRecord(internalTextRenderers, tagName)) {\n return internalTextRenderers[tagName];\n }\n return null;\n }\n\n getRendererConfigForTNode(tnode: T): RendererConfig {\n return {\n Custom: this.getCustomRendererForTNode(tnode),\n Default: this.getDefaultRendererForTNode(tnode)\n };\n }\n}\n","export default function lookupRecord>(\n record: T,\n key: any\n): key is keyof T {\n const value = record[key];\n return !!value;\n}\n","import { TNode } from '@native-html/transient-render-engine';\nimport React from 'react';\nimport { Platform, Text, View } from 'react-native';\nimport { InternalTextContentRenderer } from '../render/render-types';\n\nconst emptyProps = {\n testID: 'br'\n};\n\nconst isWeb = Platform.OS === 'web';\n\nfunction renderEmptyLineBreak(tnode: TNode) {\n const lineHeight =\n tnode.styles.nativeTextFlow.lineHeight ||\n tnode.styles.nativeTextFlow.fontSize! * 1.4;\n return ;\n}\n\nconst BRRenderer: InternalTextContentRenderer = function BRRenderer({\n renderIndex,\n renderLength,\n sharedProps,\n tnode\n}) {\n // If it is the last child and BR collapsing is enabled, render an empty\n // string to prevent inserting an undesired space to follow HTML specs,\n // unless the platform is web and it is also the first child.\n //\n // Note that we are taking advantage of the Ghost Line oddity in React\n // Native, where an empty element displays a line, since a\n // line break opening **and** closing an inline formatting context\n // should be printed as a one line-height item.\n const isFirst = renderIndex === 0;\n const isLast = renderIndex === renderLength - 1;\n const isLonelyBreak = isFirst && isLast;\n const shouldCollapse =\n sharedProps.enableExperimentalBRCollapsing &&\n (isFirst ? isLast && !isWeb : isLast);\n return isLonelyBreak && shouldCollapse\n ? renderEmptyLineBreak(tnode)\n : React.createElement(Text, emptyProps, shouldCollapse ? '' : '\\n');\n};\n\nBRRenderer.isNativeInternalTextRenderer = true;\n\nexport default BRRenderer;\n","import React from 'react';\nimport { Text } from 'react-native';\nimport { InternalTextContentRenderer } from '../render/render-types';\n\nconst emptyProps = {};\n\nconst WBRRenderer: InternalTextContentRenderer = function WordBreakRenderer() {\n return React.createElement(Text, emptyProps, '\\u200b');\n};\n\nWBRRenderer.isNativeInternalTextRenderer = true;\n\nexport default WBRRenderer;\n","import ARenderer from '../renderers/ARenderer';\nimport IMGRenderer from '../renderers/IMGRenderer';\nimport OLRenderer from '../renderers/OLRenderer';\nimport ULRenderer from '../renderers/ULRenderer';\n\nconst internalRenderers = {\n img: IMGRenderer,\n ul: ULRenderer,\n ol: OLRenderer,\n a: ARenderer\n};\n\nexport default internalRenderers;\n","import React from 'react';\nimport { InternalMixedRenderer } from '../render/render-types';\nimport { TNode, DocumentContext } from '@native-html/transient-render-engine';\nimport { InternalRendererProps, RenderersProps } from '../shared-types';\nimport { GestureResponderEvent } from 'react-native';\nimport useNormalizedUrl from '../hooks/useNormalizedUrl';\nimport { useDocumentMetadata } from '../context/DocumentMetadataProvider';\nimport { useRendererProps } from '../context/RenderersPropsProvider';\n\nfunction useAnchorOnLinkPress(\n tnode: TNode,\n onPress: RenderersProps['a']['onPress']\n) {\n const href: string = tnode.attributes.href;\n const normalizedHref = useNormalizedUrl(href);\n const { baseTarget } = useDocumentMetadata();\n const shouldHandleLinkPress =\n tnode.tagName === 'a' &&\n typeof normalizedHref === 'string' &&\n href.length > 0 &&\n typeof onPress === 'function';\n return shouldHandleLinkPress\n ? (e: GestureResponderEvent) =>\n onPress!(\n e,\n normalizedHref,\n tnode.attributes,\n (tnode.attributes.target as DocumentContext['baseTarget']) ||\n baseTarget\n )\n : undefined;\n}\n\nexport function useAElementProps(\n props: InternalRendererProps\n): InternalRendererProps {\n const { tnode } = props;\n const { onPress } = useRendererProps('a');\n const syntheticAnchorOnLinkPress = useAnchorOnLinkPress(tnode, onPress);\n if (typeof syntheticAnchorOnLinkPress !== 'function') {\n return props;\n }\n return {\n ...props,\n onPress: syntheticAnchorOnLinkPress\n };\n}\n\nconst ARenderer: InternalMixedRenderer = (props) => {\n return React.createElement(props.TDefaultRenderer, useAElementProps(props));\n};\n\nexport default ARenderer;\n","import React from 'react';\nimport { TBlock } from '@native-html/transient-render-engine';\nimport { InternalBlockRenderer } from '../render/render-types';\nimport {\n InternalRendererProps,\n DefaultSupportedListStyleType\n} from '../shared-types';\nimport OLElement, { OLElementProps } from '../elements/OLElement';\nimport { useRendererProps } from '../context/RenderersPropsProvider';\n\nfunction getFallbackListStyleTypeFromNestLevel(\n nestLevel: number\n): DefaultSupportedListStyleType {\n switch (nestLevel % 3) {\n case 0:\n return 'decimal';\n\n /* istanbul ignore next */\n case 1:\n return 'upper-alpha';\n\n /* istanbul ignore next */\n default:\n return 'lower-alpha';\n }\n}\n\nexport function useOLElementProps(\n props: InternalRendererProps\n): OLElementProps {\n const config = useRendererProps('ol');\n return {\n ...props,\n getFallbackListStyleTypeFromNestLevel,\n ...config\n };\n}\n\nconst OLRenderer: InternalBlockRenderer = (props) => {\n return React.createElement(OLElement, useOLElementProps(props));\n};\n\nexport default OLRenderer;\n","import React from 'react';\nimport ListElement, { ListElementProps } from './ListElement';\n\nexport type OLElementProps = Omit, 'listType'>;\nexport default function OLElement(props: OLElementProps) {\n return React.createElement(ListElement, { ...props, listType: 'ol' });\n}\n","import { StyleSheet, View } from 'react-native';\nimport React from 'react';\nimport { TBlock, TNode } from '@native-html/transient-render-engine';\nimport { MarkedListItem, useMarkedList } from '@jsamr/react-native-li';\nimport type {\n DefaultSupportedListStyleType,\n InternalRendererProps,\n ListElementConfig,\n TChildProps\n} from '../shared-types';\nimport { useTChildrenRenderer } from '../context/TChildrenRendererContext';\nimport { DEFAULT_TEXT_COLOR } from '../constants';\nimport pick from 'ramda/src/pick';\nimport { useListStyleSpecs } from '../context/ListStyleSpecsProvider';\n\nexport interface ListElementProps\n extends InternalRendererProps,\n ListElementConfig {\n listType: T;\n}\n\nfunction getStartIndex(tnode: TNode) {\n const parsedIndex = tnode.attributes.start\n ? Number(tnode.attributes.start)\n : Number.NaN;\n return Number.isNaN(parsedIndex) ? 1 : parsedIndex;\n}\n\nconst pickMarkerTextStyles = pick([\n 'fontStyle',\n 'fontSize',\n 'fontWeight',\n 'fontFamily',\n 'fontVariant',\n 'color',\n 'lineHeight'\n]);\n\nfunction extractMarkerTextStyle(tnode: TNode) {\n return Object.assign(\n {\n lineHeight: 14 * 1.3,\n fontSize: 14,\n color: DEFAULT_TEXT_COLOR\n },\n pickMarkerTextStyles(tnode.styles.nativeTextFlow)\n );\n}\n\nexport function getMarkerBoxStyle(\n markerWidth: number | false,\n paddingValue: string | number | undefined\n) {\n const markerBoxWidth =\n typeof markerWidth === 'number'\n ? typeof paddingValue === 'number'\n ? Math.max(paddingValue, markerWidth)\n : markerWidth\n : paddingValue;\n return { width: markerBoxWidth };\n}\n\nconst listStyleTypeFallbackRecord: Record<\n 'ol' | 'ul',\n DefaultSupportedListStyleType\n> = {\n ol: 'decimal',\n ul: 'disc'\n};\n\nexport default function ListElement({\n tnode,\n TDefaultRenderer,\n listType,\n style,\n getFallbackListStyleTypeFromNestLevel,\n markerBoxStyle,\n markerTextStyle: providedMarkerTextStyle,\n enableExperimentalRtl = false,\n enableRemoveTopMarginIfNested = true,\n enableRemoveBottomMarginIfNested = true,\n enableDynamicMarkerBoxWidth = false,\n ...props\n}: ListElementProps<'ol' | 'ul'>) {\n const listStyleSpecs = useListStyleSpecs();\n const markers = tnode.markers;\n const nestLevel =\n listType === 'ol' ? markers.olNestLevel : markers.ulNestLevel;\n const TChildrenRenderer = useTChildrenRenderer();\n const rtl =\n enableExperimentalRtl &&\n (style.direction === 'rtl' || markers.direction === 'rtl');\n const removeTopMarginStyle =\n enableRemoveTopMarginIfNested &&\n tnode.parent?.tagName === 'li' &&\n tnode.nodeIndex === 0\n ? styles.zeroMarginTop\n : null;\n const removeBottomMarginStyle =\n enableRemoveBottomMarginIfNested &&\n tnode.parent?.tagName === 'li' &&\n tnode.nodeIndex === tnode.parent?.children.length - 1\n ? styles.zeroMarginBottom\n : null;\n const ownListType = tnode.styles.webTextFlow.listStyleType as\n | DefaultSupportedListStyleType\n | undefined;\n const selectedListType =\n getFallbackListStyleTypeFromNestLevel!(nestLevel) ||\n ownListType ||\n listStyleTypeFallbackRecord[listType];\n const listStyleType = ownListType || selectedListType;\n if (\n typeof __DEV__ === 'boolean' &&\n __DEV__ &&\n !(listStyleType in listStyleSpecs)\n ) {\n if (listStyleType.match(/^(\"|')/)) {\n console.warn(\n \"This library doesn't support strings for list-style-type CSS properties.\"\n );\n } else {\n console.warn(\n `list-style-type \"${listStyleType}\" is not handled by react-native-render-html. ` +\n 'You can easily provide support for this style via \"customListStyleSpecs\" prop.'\n );\n }\n }\n const spec =\n listStyleType in listStyleSpecs\n ? listStyleSpecs[listStyleType]\n : listStyleSpecs[selectedListType];\n const counterRenderer = spec.counterStyleRenderer;\n const startIndex = getStartIndex(tnode);\n const markerTextStyle =\n typeof providedMarkerTextStyle === 'object' && providedMarkerTextStyle\n ? { ...extractMarkerTextStyle(tnode), ...providedMarkerTextStyle }\n : extractMarkerTextStyle(tnode);\n const itemProps = useMarkedList({\n counterRenderer,\n startIndex,\n markerTextStyle,\n markerBoxStyle,\n rtlLineReversed: rtl,\n rtlMarkerReversed: rtl,\n length: tnode.children.length,\n dynamicMarkerBoxWidth: enableDynamicMarkerBoxWidth,\n renderMarker: spec.renderMarker\n });\n const markerWidth = itemProps.markerTextWidth;\n const fixedPaddingRule = rtl\n ? ('paddingRight' as const)\n : ('paddingLeft' as const);\n // Fallback to padding-left value on RTL mode\n const paddingValue = style[fixedPaddingRule] ?? style.paddingLeft;\n const markerBoxWidthStyle = getMarkerBoxStyle(markerWidth, paddingValue);\n const renderChild = ({ childElement, key, index }: TChildProps) => (\n \n {childElement}\n \n );\n\n const dynamicPaddingStyle = {\n position: 'relative' as const,\n [fixedPaddingRule]: 0\n };\n return (\n \n \n \n );\n}\n\nconst styles = StyleSheet.create({\n zeroMarginTop: { marginTop: 0 },\n zeroMarginBottom: { marginBottom: 0 },\n shrink: { flexShrink: 1 }\n});\n","/* eslint-disable react-native/no-inline-styles */\nimport { MarkerBoxProps } from '@jsamr/react-native-li';\nimport { mapObjIndexed } from 'ramda';\nimport React, {\n createContext,\n PropsWithChildren,\n useContext,\n useMemo\n} from 'react';\nimport { Text, View } from 'react-native';\nimport defaultListStyleSpecs from '../elements/defaultListStyleSpecs';\nimport { ListStyleSpec, UnitaryListStyleSpec } from '../shared-types';\nimport { useSharedProps } from './SharedPropsProvider';\n\nconst listStyleSpecsContext = createContext<\n Record<\n string,\n ListStyleSpec & { renderMarker?: (props: MarkerBoxProps) => any }\n >\n>(defaultListStyleSpecs);\n\nexport function useListStyleSpecs() {\n return useContext(listStyleSpecsContext);\n}\n\nfunction createSymbolicMarkerRenderer({\n Component,\n counterStyleRenderer\n}: UnitaryListStyleSpec) {\n const prefix = counterStyleRenderer.renderPrefix();\n const suffix = counterStyleRenderer.renderSuffix();\n return ({\n style,\n markerTextStyle,\n counterIndex,\n rtlMarkerReversed\n }: MarkerBoxProps) => {\n return (\n \n {!!prefix && {prefix}}\n {React.createElement(Component, {\n ...(markerTextStyle as any),\n index: counterIndex\n })}\n {!!suffix && {suffix}}\n \n );\n };\n}\n\nconst makeMarkerRenderers = mapObjIndexed((value: ListStyleSpec) => {\n if (value.type === 'unitary') {\n return {\n ...value,\n renderMarker: createSymbolicMarkerRenderer(value)\n };\n }\n return value;\n});\n\nexport default function ListStyleSpecsProvider({\n children\n}: PropsWithChildren<{}>) {\n const { customListStyleSpecs } = useSharedProps();\n const mergedListStyleSpecs = useMemo(() => {\n return makeMarkerRenderers(\n customListStyleSpecs != null\n ? { ...defaultListStyleSpecs, ...customListStyleSpecs }\n : defaultListStyleSpecs\n );\n }, [customListStyleSpecs]);\n return (\n \n {children}\n \n );\n}\n","module.exports = {};\nmodule.exports.F =\n/*#__PURE__*/\nrequire(\"./F\");\nmodule.exports.T =\n/*#__PURE__*/\nrequire(\"./T\");\nmodule.exports.__ =\n/*#__PURE__*/\nrequire(\"./__\");\nmodule.exports.add =\n/*#__PURE__*/\nrequire(\"./add\");\nmodule.exports.addIndex =\n/*#__PURE__*/\nrequire(\"./addIndex\");\nmodule.exports.adjust =\n/*#__PURE__*/\nrequire(\"./adjust\");\nmodule.exports.all =\n/*#__PURE__*/\nrequire(\"./all\");\nmodule.exports.allPass =\n/*#__PURE__*/\nrequire(\"./allPass\");\nmodule.exports.always =\n/*#__PURE__*/\nrequire(\"./always\");\nmodule.exports.and =\n/*#__PURE__*/\nrequire(\"./and\");\nmodule.exports.any =\n/*#__PURE__*/\nrequire(\"./any\");\nmodule.exports.anyPass =\n/*#__PURE__*/\nrequire(\"./anyPass\");\nmodule.exports.ap =\n/*#__PURE__*/\nrequire(\"./ap\");\nmodule.exports.aperture =\n/*#__PURE__*/\nrequire(\"./aperture\");\nmodule.exports.append =\n/*#__PURE__*/\nrequire(\"./append\");\nmodule.exports.apply =\n/*#__PURE__*/\nrequire(\"./apply\");\nmodule.exports.applySpec =\n/*#__PURE__*/\nrequire(\"./applySpec\");\nmodule.exports.applyTo =\n/*#__PURE__*/\nrequire(\"./applyTo\");\nmodule.exports.ascend =\n/*#__PURE__*/\nrequire(\"./ascend\");\nmodule.exports.assoc =\n/*#__PURE__*/\nrequire(\"./assoc\");\nmodule.exports.assocPath =\n/*#__PURE__*/\nrequire(\"./assocPath\");\nmodule.exports.binary =\n/*#__PURE__*/\nrequire(\"./binary\");\nmodule.exports.bind =\n/*#__PURE__*/\nrequire(\"./bind\");\nmodule.exports.both =\n/*#__PURE__*/\nrequire(\"./both\");\nmodule.exports.call =\n/*#__PURE__*/\nrequire(\"./call\");\nmodule.exports.chain =\n/*#__PURE__*/\nrequire(\"./chain\");\nmodule.exports.clamp =\n/*#__PURE__*/\nrequire(\"./clamp\");\nmodule.exports.clone =\n/*#__PURE__*/\nrequire(\"./clone\");\nmodule.exports.comparator =\n/*#__PURE__*/\nrequire(\"./comparator\");\nmodule.exports.complement =\n/*#__PURE__*/\nrequire(\"./complement\");\nmodule.exports.compose =\n/*#__PURE__*/\nrequire(\"./compose\");\nmodule.exports.composeK =\n/*#__PURE__*/\nrequire(\"./composeK\");\nmodule.exports.composeP =\n/*#__PURE__*/\nrequire(\"./composeP\");\nmodule.exports.composeWith =\n/*#__PURE__*/\nrequire(\"./composeWith\");\nmodule.exports.concat =\n/*#__PURE__*/\nrequire(\"./concat\");\nmodule.exports.cond =\n/*#__PURE__*/\nrequire(\"./cond\");\nmodule.exports.construct =\n/*#__PURE__*/\nrequire(\"./construct\");\nmodule.exports.constructN =\n/*#__PURE__*/\nrequire(\"./constructN\");\nmodule.exports.contains =\n/*#__PURE__*/\nrequire(\"./contains\");\nmodule.exports.converge =\n/*#__PURE__*/\nrequire(\"./converge\");\nmodule.exports.countBy =\n/*#__PURE__*/\nrequire(\"./countBy\");\nmodule.exports.curry =\n/*#__PURE__*/\nrequire(\"./curry\");\nmodule.exports.curryN =\n/*#__PURE__*/\nrequire(\"./curryN\");\nmodule.exports.dec =\n/*#__PURE__*/\nrequire(\"./dec\");\nmodule.exports.defaultTo =\n/*#__PURE__*/\nrequire(\"./defaultTo\");\nmodule.exports.descend =\n/*#__PURE__*/\nrequire(\"./descend\");\nmodule.exports.difference =\n/*#__PURE__*/\nrequire(\"./difference\");\nmodule.exports.differenceWith =\n/*#__PURE__*/\nrequire(\"./differenceWith\");\nmodule.exports.dissoc =\n/*#__PURE__*/\nrequire(\"./dissoc\");\nmodule.exports.dissocPath =\n/*#__PURE__*/\nrequire(\"./dissocPath\");\nmodule.exports.divide =\n/*#__PURE__*/\nrequire(\"./divide\");\nmodule.exports.drop =\n/*#__PURE__*/\nrequire(\"./drop\");\nmodule.exports.dropLast =\n/*#__PURE__*/\nrequire(\"./dropLast\");\nmodule.exports.dropLastWhile =\n/*#__PURE__*/\nrequire(\"./dropLastWhile\");\nmodule.exports.dropRepeats =\n/*#__PURE__*/\nrequire(\"./dropRepeats\");\nmodule.exports.dropRepeatsWith =\n/*#__PURE__*/\nrequire(\"./dropRepeatsWith\");\nmodule.exports.dropWhile =\n/*#__PURE__*/\nrequire(\"./dropWhile\");\nmodule.exports.either =\n/*#__PURE__*/\nrequire(\"./either\");\nmodule.exports.empty =\n/*#__PURE__*/\nrequire(\"./empty\");\nmodule.exports.endsWith =\n/*#__PURE__*/\nrequire(\"./endsWith\");\nmodule.exports.eqBy =\n/*#__PURE__*/\nrequire(\"./eqBy\");\nmodule.exports.eqProps =\n/*#__PURE__*/\nrequire(\"./eqProps\");\nmodule.exports.equals =\n/*#__PURE__*/\nrequire(\"./equals\");\nmodule.exports.evolve =\n/*#__PURE__*/\nrequire(\"./evolve\");\nmodule.exports.filter =\n/*#__PURE__*/\nrequire(\"./filter\");\nmodule.exports.find =\n/*#__PURE__*/\nrequire(\"./find\");\nmodule.exports.findIndex =\n/*#__PURE__*/\nrequire(\"./findIndex\");\nmodule.exports.findLast =\n/*#__PURE__*/\nrequire(\"./findLast\");\nmodule.exports.findLastIndex =\n/*#__PURE__*/\nrequire(\"./findLastIndex\");\nmodule.exports.flatten =\n/*#__PURE__*/\nrequire(\"./flatten\");\nmodule.exports.flip =\n/*#__PURE__*/\nrequire(\"./flip\");\nmodule.exports.forEach =\n/*#__PURE__*/\nrequire(\"./forEach\");\nmodule.exports.forEachObjIndexed =\n/*#__PURE__*/\nrequire(\"./forEachObjIndexed\");\nmodule.exports.fromPairs =\n/*#__PURE__*/\nrequire(\"./fromPairs\");\nmodule.exports.groupBy =\n/*#__PURE__*/\nrequire(\"./groupBy\");\nmodule.exports.groupWith =\n/*#__PURE__*/\nrequire(\"./groupWith\");\nmodule.exports.gt =\n/*#__PURE__*/\nrequire(\"./gt\");\nmodule.exports.gte =\n/*#__PURE__*/\nrequire(\"./gte\");\nmodule.exports.has =\n/*#__PURE__*/\nrequire(\"./has\");\nmodule.exports.hasIn =\n/*#__PURE__*/\nrequire(\"./hasIn\");\nmodule.exports.hasPath =\n/*#__PURE__*/\nrequire(\"./hasPath\");\nmodule.exports.head =\n/*#__PURE__*/\nrequire(\"./head\");\nmodule.exports.identical =\n/*#__PURE__*/\nrequire(\"./identical\");\nmodule.exports.identity =\n/*#__PURE__*/\nrequire(\"./identity\");\nmodule.exports.ifElse =\n/*#__PURE__*/\nrequire(\"./ifElse\");\nmodule.exports.inc =\n/*#__PURE__*/\nrequire(\"./inc\");\nmodule.exports.includes =\n/*#__PURE__*/\nrequire(\"./includes\");\nmodule.exports.indexBy =\n/*#__PURE__*/\nrequire(\"./indexBy\");\nmodule.exports.indexOf =\n/*#__PURE__*/\nrequire(\"./indexOf\");\nmodule.exports.init =\n/*#__PURE__*/\nrequire(\"./init\");\nmodule.exports.innerJoin =\n/*#__PURE__*/\nrequire(\"./innerJoin\");\nmodule.exports.insert =\n/*#__PURE__*/\nrequire(\"./insert\");\nmodule.exports.insertAll =\n/*#__PURE__*/\nrequire(\"./insertAll\");\nmodule.exports.intersection =\n/*#__PURE__*/\nrequire(\"./intersection\");\nmodule.exports.intersperse =\n/*#__PURE__*/\nrequire(\"./intersperse\");\nmodule.exports.into =\n/*#__PURE__*/\nrequire(\"./into\");\nmodule.exports.invert =\n/*#__PURE__*/\nrequire(\"./invert\");\nmodule.exports.invertObj =\n/*#__PURE__*/\nrequire(\"./invertObj\");\nmodule.exports.invoker =\n/*#__PURE__*/\nrequire(\"./invoker\");\nmodule.exports.is =\n/*#__PURE__*/\nrequire(\"./is\");\nmodule.exports.isEmpty =\n/*#__PURE__*/\nrequire(\"./isEmpty\");\nmodule.exports.isNil =\n/*#__PURE__*/\nrequire(\"./isNil\");\nmodule.exports.join =\n/*#__PURE__*/\nrequire(\"./join\");\nmodule.exports.juxt =\n/*#__PURE__*/\nrequire(\"./juxt\");\nmodule.exports.keys =\n/*#__PURE__*/\nrequire(\"./keys\");\nmodule.exports.keysIn =\n/*#__PURE__*/\nrequire(\"./keysIn\");\nmodule.exports.last =\n/*#__PURE__*/\nrequire(\"./last\");\nmodule.exports.lastIndexOf =\n/*#__PURE__*/\nrequire(\"./lastIndexOf\");\nmodule.exports.length =\n/*#__PURE__*/\nrequire(\"./length\");\nmodule.exports.lens =\n/*#__PURE__*/\nrequire(\"./lens\");\nmodule.exports.lensIndex =\n/*#__PURE__*/\nrequire(\"./lensIndex\");\nmodule.exports.lensPath =\n/*#__PURE__*/\nrequire(\"./lensPath\");\nmodule.exports.lensProp =\n/*#__PURE__*/\nrequire(\"./lensProp\");\nmodule.exports.lift =\n/*#__PURE__*/\nrequire(\"./lift\");\nmodule.exports.liftN =\n/*#__PURE__*/\nrequire(\"./liftN\");\nmodule.exports.lt =\n/*#__PURE__*/\nrequire(\"./lt\");\nmodule.exports.lte =\n/*#__PURE__*/\nrequire(\"./lte\");\nmodule.exports.map =\n/*#__PURE__*/\nrequire(\"./map\");\nmodule.exports.mapAccum =\n/*#__PURE__*/\nrequire(\"./mapAccum\");\nmodule.exports.mapAccumRight =\n/*#__PURE__*/\nrequire(\"./mapAccumRight\");\nmodule.exports.mapObjIndexed =\n/*#__PURE__*/\nrequire(\"./mapObjIndexed\");\nmodule.exports.match =\n/*#__PURE__*/\nrequire(\"./match\");\nmodule.exports.mathMod =\n/*#__PURE__*/\nrequire(\"./mathMod\");\nmodule.exports.max =\n/*#__PURE__*/\nrequire(\"./max\");\nmodule.exports.maxBy =\n/*#__PURE__*/\nrequire(\"./maxBy\");\nmodule.exports.mean =\n/*#__PURE__*/\nrequire(\"./mean\");\nmodule.exports.median =\n/*#__PURE__*/\nrequire(\"./median\");\nmodule.exports.memoizeWith =\n/*#__PURE__*/\nrequire(\"./memoizeWith\");\nmodule.exports.merge =\n/*#__PURE__*/\nrequire(\"./merge\");\nmodule.exports.mergeAll =\n/*#__PURE__*/\nrequire(\"./mergeAll\");\nmodule.exports.mergeDeepLeft =\n/*#__PURE__*/\nrequire(\"./mergeDeepLeft\");\nmodule.exports.mergeDeepRight =\n/*#__PURE__*/\nrequire(\"./mergeDeepRight\");\nmodule.exports.mergeDeepWith =\n/*#__PURE__*/\nrequire(\"./mergeDeepWith\");\nmodule.exports.mergeDeepWithKey =\n/*#__PURE__*/\nrequire(\"./mergeDeepWithKey\");\nmodule.exports.mergeLeft =\n/*#__PURE__*/\nrequire(\"./mergeLeft\");\nmodule.exports.mergeRight =\n/*#__PURE__*/\nrequire(\"./mergeRight\");\nmodule.exports.mergeWith =\n/*#__PURE__*/\nrequire(\"./mergeWith\");\nmodule.exports.mergeWithKey =\n/*#__PURE__*/\nrequire(\"./mergeWithKey\");\nmodule.exports.min =\n/*#__PURE__*/\nrequire(\"./min\");\nmodule.exports.minBy =\n/*#__PURE__*/\nrequire(\"./minBy\");\nmodule.exports.modulo =\n/*#__PURE__*/\nrequire(\"./modulo\");\nmodule.exports.move =\n/*#__PURE__*/\nrequire(\"./move\");\nmodule.exports.multiply =\n/*#__PURE__*/\nrequire(\"./multiply\");\nmodule.exports.nAry =\n/*#__PURE__*/\nrequire(\"./nAry\");\nmodule.exports.negate =\n/*#__PURE__*/\nrequire(\"./negate\");\nmodule.exports.none =\n/*#__PURE__*/\nrequire(\"./none\");\nmodule.exports.not =\n/*#__PURE__*/\nrequire(\"./not\");\nmodule.exports.nth =\n/*#__PURE__*/\nrequire(\"./nth\");\nmodule.exports.nthArg =\n/*#__PURE__*/\nrequire(\"./nthArg\");\nmodule.exports.o =\n/*#__PURE__*/\nrequire(\"./o\");\nmodule.exports.objOf =\n/*#__PURE__*/\nrequire(\"./objOf\");\nmodule.exports.of =\n/*#__PURE__*/\nrequire(\"./of\");\nmodule.exports.omit =\n/*#__PURE__*/\nrequire(\"./omit\");\nmodule.exports.once =\n/*#__PURE__*/\nrequire(\"./once\");\nmodule.exports.or =\n/*#__PURE__*/\nrequire(\"./or\");\nmodule.exports.otherwise =\n/*#__PURE__*/\nrequire(\"./otherwise\");\nmodule.exports.over =\n/*#__PURE__*/\nrequire(\"./over\");\nmodule.exports.pair =\n/*#__PURE__*/\nrequire(\"./pair\");\nmodule.exports.partial =\n/*#__PURE__*/\nrequire(\"./partial\");\nmodule.exports.partialRight =\n/*#__PURE__*/\nrequire(\"./partialRight\");\nmodule.exports.partition =\n/*#__PURE__*/\nrequire(\"./partition\");\nmodule.exports.path =\n/*#__PURE__*/\nrequire(\"./path\");\nmodule.exports.paths =\n/*#__PURE__*/\nrequire(\"./paths\");\nmodule.exports.pathEq =\n/*#__PURE__*/\nrequire(\"./pathEq\");\nmodule.exports.pathOr =\n/*#__PURE__*/\nrequire(\"./pathOr\");\nmodule.exports.pathSatisfies =\n/*#__PURE__*/\nrequire(\"./pathSatisfies\");\nmodule.exports.pick =\n/*#__PURE__*/\nrequire(\"./pick\");\nmodule.exports.pickAll =\n/*#__PURE__*/\nrequire(\"./pickAll\");\nmodule.exports.pickBy =\n/*#__PURE__*/\nrequire(\"./pickBy\");\nmodule.exports.pipe =\n/*#__PURE__*/\nrequire(\"./pipe\");\nmodule.exports.pipeK =\n/*#__PURE__*/\nrequire(\"./pipeK\");\nmodule.exports.pipeP =\n/*#__PURE__*/\nrequire(\"./pipeP\");\nmodule.exports.pipeWith =\n/*#__PURE__*/\nrequire(\"./pipeWith\");\nmodule.exports.pluck =\n/*#__PURE__*/\nrequire(\"./pluck\");\nmodule.exports.prepend =\n/*#__PURE__*/\nrequire(\"./prepend\");\nmodule.exports.product =\n/*#__PURE__*/\nrequire(\"./product\");\nmodule.exports.project =\n/*#__PURE__*/\nrequire(\"./project\");\nmodule.exports.prop =\n/*#__PURE__*/\nrequire(\"./prop\");\nmodule.exports.propEq =\n/*#__PURE__*/\nrequire(\"./propEq\");\nmodule.exports.propIs =\n/*#__PURE__*/\nrequire(\"./propIs\");\nmodule.exports.propOr =\n/*#__PURE__*/\nrequire(\"./propOr\");\nmodule.exports.propSatisfies =\n/*#__PURE__*/\nrequire(\"./propSatisfies\");\nmodule.exports.props =\n/*#__PURE__*/\nrequire(\"./props\");\nmodule.exports.range =\n/*#__PURE__*/\nrequire(\"./range\");\nmodule.exports.reduce =\n/*#__PURE__*/\nrequire(\"./reduce\");\nmodule.exports.reduceBy =\n/*#__PURE__*/\nrequire(\"./reduceBy\");\nmodule.exports.reduceRight =\n/*#__PURE__*/\nrequire(\"./reduceRight\");\nmodule.exports.reduceWhile =\n/*#__PURE__*/\nrequire(\"./reduceWhile\");\nmodule.exports.reduced =\n/*#__PURE__*/\nrequire(\"./reduced\");\nmodule.exports.reject =\n/*#__PURE__*/\nrequire(\"./reject\");\nmodule.exports.remove =\n/*#__PURE__*/\nrequire(\"./remove\");\nmodule.exports.repeat =\n/*#__PURE__*/\nrequire(\"./repeat\");\nmodule.exports.replace =\n/*#__PURE__*/\nrequire(\"./replace\");\nmodule.exports.reverse =\n/*#__PURE__*/\nrequire(\"./reverse\");\nmodule.exports.scan =\n/*#__PURE__*/\nrequire(\"./scan\");\nmodule.exports.sequence =\n/*#__PURE__*/\nrequire(\"./sequence\");\nmodule.exports.set =\n/*#__PURE__*/\nrequire(\"./set\");\nmodule.exports.slice =\n/*#__PURE__*/\nrequire(\"./slice\");\nmodule.exports.sort =\n/*#__PURE__*/\nrequire(\"./sort\");\nmodule.exports.sortBy =\n/*#__PURE__*/\nrequire(\"./sortBy\");\nmodule.exports.sortWith =\n/*#__PURE__*/\nrequire(\"./sortWith\");\nmodule.exports.split =\n/*#__PURE__*/\nrequire(\"./split\");\nmodule.exports.splitAt =\n/*#__PURE__*/\nrequire(\"./splitAt\");\nmodule.exports.splitEvery =\n/*#__PURE__*/\nrequire(\"./splitEvery\");\nmodule.exports.splitWhen =\n/*#__PURE__*/\nrequire(\"./splitWhen\");\nmodule.exports.startsWith =\n/*#__PURE__*/\nrequire(\"./startsWith\");\nmodule.exports.subtract =\n/*#__PURE__*/\nrequire(\"./subtract\");\nmodule.exports.sum =\n/*#__PURE__*/\nrequire(\"./sum\");\nmodule.exports.symmetricDifference =\n/*#__PURE__*/\nrequire(\"./symmetricDifference\");\nmodule.exports.symmetricDifferenceWith =\n/*#__PURE__*/\nrequire(\"./symmetricDifferenceWith\");\nmodule.exports.tail =\n/*#__PURE__*/\nrequire(\"./tail\");\nmodule.exports.take =\n/*#__PURE__*/\nrequire(\"./take\");\nmodule.exports.takeLast =\n/*#__PURE__*/\nrequire(\"./takeLast\");\nmodule.exports.takeLastWhile =\n/*#__PURE__*/\nrequire(\"./takeLastWhile\");\nmodule.exports.takeWhile =\n/*#__PURE__*/\nrequire(\"./takeWhile\");\nmodule.exports.tap =\n/*#__PURE__*/\nrequire(\"./tap\");\nmodule.exports.test =\n/*#__PURE__*/\nrequire(\"./test\");\nmodule.exports.andThen =\n/*#__PURE__*/\nrequire(\"./andThen\");\nmodule.exports.times =\n/*#__PURE__*/\nrequire(\"./times\");\nmodule.exports.toLower =\n/*#__PURE__*/\nrequire(\"./toLower\");\nmodule.exports.toPairs =\n/*#__PURE__*/\nrequire(\"./toPairs\");\nmodule.exports.toPairsIn =\n/*#__PURE__*/\nrequire(\"./toPairsIn\");\nmodule.exports.toString =\n/*#__PURE__*/\nrequire(\"./toString\");\nmodule.exports.toUpper =\n/*#__PURE__*/\nrequire(\"./toUpper\");\nmodule.exports.transduce =\n/*#__PURE__*/\nrequire(\"./transduce\");\nmodule.exports.transpose =\n/*#__PURE__*/\nrequire(\"./transpose\");\nmodule.exports.traverse =\n/*#__PURE__*/\nrequire(\"./traverse\");\nmodule.exports.trim =\n/*#__PURE__*/\nrequire(\"./trim\");\nmodule.exports.tryCatch =\n/*#__PURE__*/\nrequire(\"./tryCatch\");\nmodule.exports.type =\n/*#__PURE__*/\nrequire(\"./type\");\nmodule.exports.unapply =\n/*#__PURE__*/\nrequire(\"./unapply\");\nmodule.exports.unary =\n/*#__PURE__*/\nrequire(\"./unary\");\nmodule.exports.uncurryN =\n/*#__PURE__*/\nrequire(\"./uncurryN\");\nmodule.exports.unfold =\n/*#__PURE__*/\nrequire(\"./unfold\");\nmodule.exports.union =\n/*#__PURE__*/\nrequire(\"./union\");\nmodule.exports.unionWith =\n/*#__PURE__*/\nrequire(\"./unionWith\");\nmodule.exports.uniq =\n/*#__PURE__*/\nrequire(\"./uniq\");\nmodule.exports.uniqBy =\n/*#__PURE__*/\nrequire(\"./uniqBy\");\nmodule.exports.uniqWith =\n/*#__PURE__*/\nrequire(\"./uniqWith\");\nmodule.exports.unless =\n/*#__PURE__*/\nrequire(\"./unless\");\nmodule.exports.unnest =\n/*#__PURE__*/\nrequire(\"./unnest\");\nmodule.exports.until =\n/*#__PURE__*/\nrequire(\"./until\");\nmodule.exports.update =\n/*#__PURE__*/\nrequire(\"./update\");\nmodule.exports.useWith =\n/*#__PURE__*/\nrequire(\"./useWith\");\nmodule.exports.values =\n/*#__PURE__*/\nrequire(\"./values\");\nmodule.exports.valuesIn =\n/*#__PURE__*/\nrequire(\"./valuesIn\");\nmodule.exports.view =\n/*#__PURE__*/\nrequire(\"./view\");\nmodule.exports.when =\n/*#__PURE__*/\nrequire(\"./when\");\nmodule.exports.where =\n/*#__PURE__*/\nrequire(\"./where\");\nmodule.exports.whereEq =\n/*#__PURE__*/\nrequire(\"./whereEq\");\nmodule.exports.without =\n/*#__PURE__*/\nrequire(\"./without\");\nmodule.exports.xor =\n/*#__PURE__*/\nrequire(\"./xor\");\nmodule.exports.xprod =\n/*#__PURE__*/\nrequire(\"./xprod\");\nmodule.exports.zip =\n/*#__PURE__*/\nrequire(\"./zip\");\nmodule.exports.zipObj =\n/*#__PURE__*/\nrequire(\"./zipObj\");\nmodule.exports.zipWith =\n/*#__PURE__*/\nrequire(\"./zipWith\");\nmodule.exports.thunkify =\n/*#__PURE__*/\nrequire(\"./thunkify\");","/**\n * A function that always returns `false`. Any passed in parameters are ignored.\n *\n * @func\n * @memberOf R\n * @since v0.9.0\n * @category Function\n * @sig * -> Boolean\n * @param {*}\n * @return {Boolean}\n * @see R.T\n * @example\n *\n * R.F(); //=> false\n */\nvar F = function () {\n return false;\n};\n\nmodule.exports = F;","/**\n * A function that always returns `true`. Any passed in parameters are ignored.\n *\n * @func\n * @memberOf R\n * @since v0.9.0\n * @category Function\n * @sig * -> Boolean\n * @param {*}\n * @return {Boolean}\n * @see R.F\n * @example\n *\n * R.T(); //=> true\n */\nvar T = function () {\n return true;\n};\n\nmodule.exports = T;","/**\n * A special placeholder value used to specify \"gaps\" within curried functions,\n * allowing partial application of any combination of arguments, regardless of\n * their positions.\n *\n * If `g` is a curried ternary function and `_` is `R.__`, the following are\n * equivalent:\n *\n * - `g(1, 2, 3)`\n * - `g(_, 2, 3)(1)`\n * - `g(_, _, 3)(1)(2)`\n * - `g(_, _, 3)(1, 2)`\n * - `g(_, 2, _)(1, 3)`\n * - `g(_, 2)(1)(3)`\n * - `g(_, 2)(1, 3)`\n * - `g(_, 2)(_, 3)(1)`\n *\n * @name __\n * @constant\n * @memberOf R\n * @since v0.6.0\n * @category Function\n * @example\n *\n * const greet = R.replace('{name}', R.__, 'Hello, {name}!');\n * greet('Alice'); //=> 'Hello, Alice!'\n */\nmodule.exports = {\n '@@functional/placeholder': true\n};","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Adds two values.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Math\n * @sig Number -> Number -> Number\n * @param {Number} a\n * @param {Number} b\n * @return {Number}\n * @see R.subtract\n * @example\n *\n * R.add(2, 3); //=> 5\n * R.add(7)(10); //=> 17\n */\n\n\nvar add =\n/*#__PURE__*/\n_curry2(function add(a, b) {\n return Number(a) + Number(b);\n});\n\nmodule.exports = add;","var _concat =\n/*#__PURE__*/\nrequire(\"./internal/_concat\");\n\nvar _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar curryN =\n/*#__PURE__*/\nrequire(\"./curryN\");\n/**\n * Creates a new list iteration function from an existing one by adding two new\n * parameters to its callback function: the current index, and the entire list.\n *\n * This would turn, for instance, [`R.map`](#map) function into one that\n * more closely resembles `Array.prototype.map`. Note that this will only work\n * for functions in which the iteration callback function is the first\n * parameter, and where the list is the last parameter. (This latter might be\n * unimportant if the list parameter is not used.)\n *\n * @func\n * @memberOf R\n * @since v0.15.0\n * @category Function\n * @category List\n * @sig ((a ... -> b) ... -> [a] -> *) -> ((a ..., Int, [a] -> b) ... -> [a] -> *)\n * @param {Function} fn A list iteration function that does not pass index or list to its callback\n * @return {Function} An altered list iteration function that passes (item, index, list) to its callback\n * @example\n *\n * const mapIndexed = R.addIndex(R.map);\n * mapIndexed((val, idx) => idx + '-' + val, ['f', 'o', 'o', 'b', 'a', 'r']);\n * //=> ['0-f', '1-o', '2-o', '3-b', '4-a', '5-r']\n */\n\n\nvar addIndex =\n/*#__PURE__*/\n_curry1(function addIndex(fn) {\n return curryN(fn.length, function () {\n var idx = 0;\n var origFn = arguments[0];\n var list = arguments[arguments.length - 1];\n var args = Array.prototype.slice.call(arguments, 0);\n\n args[0] = function () {\n var result = origFn.apply(this, _concat(arguments, [idx, list]));\n idx += 1;\n return result;\n };\n\n return fn.apply(this, args);\n });\n});\n\nmodule.exports = addIndex;","var _arity =\n/*#__PURE__*/\nrequire(\"./internal/_arity\");\n\nvar _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _curryN =\n/*#__PURE__*/\nrequire(\"./internal/_curryN\");\n/**\n * Returns a curried equivalent of the provided function, with the specified\n * arity. The curried function has two unusual capabilities. First, its\n * arguments needn't be provided one at a time. If `g` is `R.curryN(3, f)`, the\n * following are equivalent:\n *\n * - `g(1)(2)(3)`\n * - `g(1)(2, 3)`\n * - `g(1, 2)(3)`\n * - `g(1, 2, 3)`\n *\n * Secondly, the special placeholder value [`R.__`](#__) may be used to specify\n * \"gaps\", allowing partial application of any combination of arguments,\n * regardless of their positions. If `g` is as above and `_` is [`R.__`](#__),\n * the following are equivalent:\n *\n * - `g(1, 2, 3)`\n * - `g(_, 2, 3)(1)`\n * - `g(_, _, 3)(1)(2)`\n * - `g(_, _, 3)(1, 2)`\n * - `g(_, 2)(1)(3)`\n * - `g(_, 2)(1, 3)`\n * - `g(_, 2)(_, 3)(1)`\n *\n * @func\n * @memberOf R\n * @since v0.5.0\n * @category Function\n * @sig Number -> (* -> a) -> (* -> a)\n * @param {Number} length The arity for the returned function.\n * @param {Function} fn The function to curry.\n * @return {Function} A new, curried function.\n * @see R.curry\n * @example\n *\n * const sumArgs = (...args) => R.sum(args);\n *\n * const curriedAddFourNumbers = R.curryN(4, sumArgs);\n * const f = curriedAddFourNumbers(1, 2);\n * const g = f(3);\n * g(4); //=> 10\n */\n\n\nvar curryN =\n/*#__PURE__*/\n_curry2(function curryN(length, fn) {\n if (length === 1) {\n return _curry1(fn);\n }\n\n return _arity(length, _curryN(length, [], fn));\n});\n\nmodule.exports = curryN;","var _arity =\n/*#__PURE__*/\nrequire(\"./_arity\");\n\nvar _isPlaceholder =\n/*#__PURE__*/\nrequire(\"./_isPlaceholder\");\n/**\n * Internal curryN function.\n *\n * @private\n * @category Function\n * @param {Number} length The arity of the curried function.\n * @param {Array} received An array of arguments received thus far.\n * @param {Function} fn The function to curry.\n * @return {Function} The curried function.\n */\n\n\nfunction _curryN(length, received, fn) {\n return function () {\n var combined = [];\n var argsIdx = 0;\n var left = length;\n var combinedIdx = 0;\n\n while (combinedIdx < received.length || argsIdx < arguments.length) {\n var result;\n\n if (combinedIdx < received.length && (!_isPlaceholder(received[combinedIdx]) || argsIdx >= arguments.length)) {\n result = received[combinedIdx];\n } else {\n result = arguments[argsIdx];\n argsIdx += 1;\n }\n\n combined[combinedIdx] = result;\n\n if (!_isPlaceholder(result)) {\n left -= 1;\n }\n\n combinedIdx += 1;\n }\n\n return left <= 0 ? fn.apply(this, combined) : _arity(left, _curryN(length, combined, fn));\n };\n}\n\nmodule.exports = _curryN;","/**\n * Private `concat` function to merge two array-like objects.\n *\n * @private\n * @param {Array|Arguments} [set1=[]] An array-like object.\n * @param {Array|Arguments} [set2=[]] An array-like object.\n * @return {Array} A new, merged array.\n * @example\n *\n * _concat([4, 5, 6], [1, 2, 3]); //=> [4, 5, 6, 1, 2, 3]\n */\nfunction _concat(set1, set2) {\n set1 = set1 || [];\n set2 = set2 || [];\n var idx;\n var len1 = set1.length;\n var len2 = set2.length;\n var result = [];\n idx = 0;\n\n while (idx < len1) {\n result[result.length] = set1[idx];\n idx += 1;\n }\n\n idx = 0;\n\n while (idx < len2) {\n result[result.length] = set2[idx];\n idx += 1;\n }\n\n return result;\n}\n\nmodule.exports = _concat;","var _concat =\n/*#__PURE__*/\nrequire(\"./internal/_concat\");\n\nvar _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n/**\n * Applies a function to the value at the given index of an array, returning a\n * new copy of the array with the element at the given index replaced with the\n * result of the function application.\n *\n * @func\n * @memberOf R\n * @since v0.14.0\n * @category List\n * @sig Number -> (a -> a) -> [a] -> [a]\n * @param {Number} idx The index.\n * @param {Function} fn The function to apply.\n * @param {Array|Arguments} list An array-like object whose value\n * at the supplied index will be replaced.\n * @return {Array} A copy of the supplied array-like object with\n * the element at index `idx` replaced with the value\n * returned by applying `fn` to the existing element.\n * @see R.update\n * @example\n *\n * R.adjust(1, R.toUpper, ['a', 'b', 'c', 'd']); //=> ['a', 'B', 'c', 'd']\n * R.adjust(-1, R.toUpper, ['a', 'b', 'c', 'd']); //=> ['a', 'b', 'c', 'D']\n * @symb R.adjust(-1, f, [a, b]) = [a, f(b)]\n * @symb R.adjust(0, f, [a, b]) = [f(a), b]\n */\n\n\nvar adjust =\n/*#__PURE__*/\n_curry3(function adjust(idx, fn, list) {\n if (idx >= list.length || idx < -list.length) {\n return list;\n }\n\n var start = idx < 0 ? list.length : 0;\n\n var _idx = start + idx;\n\n var _list = _concat(list);\n\n _list[_idx] = fn(list[_idx]);\n return _list;\n});\n\nmodule.exports = adjust;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _dispatchable =\n/*#__PURE__*/\nrequire(\"./internal/_dispatchable\");\n\nvar _xall =\n/*#__PURE__*/\nrequire(\"./internal/_xall\");\n/**\n * Returns `true` if all elements of the list match the predicate, `false` if\n * there are any that don't.\n *\n * Dispatches to the `all` method of the second argument, if present.\n *\n * Acts as a transducer if a transformer is given in list position.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category List\n * @sig (a -> Boolean) -> [a] -> Boolean\n * @param {Function} fn The predicate function.\n * @param {Array} list The array to consider.\n * @return {Boolean} `true` if the predicate is satisfied by every element, `false`\n * otherwise.\n * @see R.any, R.none, R.transduce\n * @example\n *\n * const equals3 = R.equals(3);\n * R.all(equals3)([3, 3, 3, 3]); //=> true\n * R.all(equals3)([3, 3, 1, 3]); //=> false\n */\n\n\nvar all =\n/*#__PURE__*/\n_curry2(\n/*#__PURE__*/\n_dispatchable(['all'], _xall, function all(fn, list) {\n var idx = 0;\n\n while (idx < list.length) {\n if (!fn(list[idx])) {\n return false;\n }\n\n idx += 1;\n }\n\n return true;\n}));\n\nmodule.exports = all;","var _isArray =\n/*#__PURE__*/\nrequire(\"./_isArray\");\n\nvar _isTransformer =\n/*#__PURE__*/\nrequire(\"./_isTransformer\");\n/**\n * Returns a function that dispatches with different strategies based on the\n * object in list position (last argument). If it is an array, executes [fn].\n * Otherwise, if it has a function with one of the given method names, it will\n * execute that function (functor case). Otherwise, if it is a transformer,\n * uses transducer [xf] to return a new transformer (transducer case).\n * Otherwise, it will default to executing [fn].\n *\n * @private\n * @param {Array} methodNames properties to check for a custom implementation\n * @param {Function} xf transducer to initialize if object is transformer\n * @param {Function} fn default ramda implementation\n * @return {Function} A function that dispatches on object in list position\n */\n\n\nfunction _dispatchable(methodNames, xf, fn) {\n return function () {\n if (arguments.length === 0) {\n return fn();\n }\n\n var args = Array.prototype.slice.call(arguments, 0);\n var obj = args.pop();\n\n if (!_isArray(obj)) {\n var idx = 0;\n\n while (idx < methodNames.length) {\n if (typeof obj[methodNames[idx]] === 'function') {\n return obj[methodNames[idx]].apply(obj, args);\n }\n\n idx += 1;\n }\n\n if (_isTransformer(obj)) {\n var transducer = xf.apply(null, args);\n return transducer(obj);\n }\n }\n\n return fn.apply(this, arguments);\n };\n}\n\nmodule.exports = _dispatchable;","function _isTransformer(obj) {\n return obj != null && typeof obj['@@transducer/step'] === 'function';\n}\n\nmodule.exports = _isTransformer;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./_curry2\");\n\nvar _reduced =\n/*#__PURE__*/\nrequire(\"./_reduced\");\n\nvar _xfBase =\n/*#__PURE__*/\nrequire(\"./_xfBase\");\n\nvar XAll =\n/*#__PURE__*/\nfunction () {\n function XAll(f, xf) {\n this.xf = xf;\n this.f = f;\n this.all = true;\n }\n\n XAll.prototype['@@transducer/init'] = _xfBase.init;\n\n XAll.prototype['@@transducer/result'] = function (result) {\n if (this.all) {\n result = this.xf['@@transducer/step'](result, true);\n }\n\n return this.xf['@@transducer/result'](result);\n };\n\n XAll.prototype['@@transducer/step'] = function (result, input) {\n if (!this.f(input)) {\n this.all = false;\n result = _reduced(this.xf['@@transducer/step'](result, false));\n }\n\n return result;\n };\n\n return XAll;\n}();\n\nvar _xall =\n/*#__PURE__*/\n_curry2(function _xall(f, xf) {\n return new XAll(f, xf);\n});\n\nmodule.exports = _xall;","module.exports = {\n init: function () {\n return this.xf['@@transducer/init']();\n },\n result: function (result) {\n return this.xf['@@transducer/result'](result);\n }\n};","function _reduced(x) {\n return x && x['@@transducer/reduced'] ? x : {\n '@@transducer/value': x,\n '@@transducer/reduced': true\n };\n}\n\nmodule.exports = _reduced;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar curryN =\n/*#__PURE__*/\nrequire(\"./curryN\");\n\nvar max =\n/*#__PURE__*/\nrequire(\"./max\");\n\nvar pluck =\n/*#__PURE__*/\nrequire(\"./pluck\");\n\nvar reduce =\n/*#__PURE__*/\nrequire(\"./reduce\");\n/**\n * Takes a list of predicates and returns a predicate that returns true for a\n * given list of arguments if every one of the provided predicates is satisfied\n * by those arguments.\n *\n * The function returned is a curried function whose arity matches that of the\n * highest-arity predicate.\n *\n * @func\n * @memberOf R\n * @since v0.9.0\n * @category Logic\n * @sig [(*... -> Boolean)] -> (*... -> Boolean)\n * @param {Array} predicates An array of predicates to check\n * @return {Function} The combined predicate\n * @see R.anyPass\n * @example\n *\n * const isQueen = R.propEq('rank', 'Q');\n * const isSpade = R.propEq('suit', '♠︎');\n * const isQueenOfSpades = R.allPass([isQueen, isSpade]);\n *\n * isQueenOfSpades({rank: 'Q', suit: '♣︎'}); //=> false\n * isQueenOfSpades({rank: 'Q', suit: '♠︎'}); //=> true\n */\n\n\nvar allPass =\n/*#__PURE__*/\n_curry1(function allPass(preds) {\n return curryN(reduce(max, 0, pluck('length', preds)), function () {\n var idx = 0;\n var len = preds.length;\n\n while (idx < len) {\n if (!preds[idx].apply(this, arguments)) {\n return false;\n }\n\n idx += 1;\n }\n\n return true;\n });\n});\n\nmodule.exports = allPass;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Returns the larger of its two arguments.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Relation\n * @sig Ord a => a -> a -> a\n * @param {*} a\n * @param {*} b\n * @return {*}\n * @see R.maxBy, R.min\n * @example\n *\n * R.max(789, 123); //=> 789\n * R.max('a', 'b'); //=> 'b'\n */\n\n\nvar max =\n/*#__PURE__*/\n_curry2(function max(a, b) {\n return b > a ? b : a;\n});\n\nmodule.exports = max;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar map =\n/*#__PURE__*/\nrequire(\"./map\");\n\nvar prop =\n/*#__PURE__*/\nrequire(\"./prop\");\n/**\n * Returns a new list by plucking the same named property off all objects in\n * the list supplied.\n *\n * `pluck` will work on\n * any [functor](https://github.com/fantasyland/fantasy-land#functor) in\n * addition to arrays, as it is equivalent to `R.map(R.prop(k), f)`.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category List\n * @sig Functor f => k -> f {k: v} -> f v\n * @param {Number|String} key The key name to pluck off of each object.\n * @param {Array} f The array or functor to consider.\n * @return {Array} The list of values for the given key.\n * @see R.props\n * @example\n *\n * var getAges = R.pluck('age');\n * getAges([{name: 'fred', age: 29}, {name: 'wilma', age: 27}]); //=> [29, 27]\n *\n * R.pluck(0, [[1, 2], [3, 4]]); //=> [1, 3]\n * R.pluck('val', {a: {val: 3}, b: {val: 5}}); //=> {a: 3, b: 5}\n * @symb R.pluck('x', [{x: 1, y: 2}, {x: 3, y: 4}, {x: 5, y: 6}]) = [1, 3, 5]\n * @symb R.pluck(0, [[1, 2], [3, 4], [5, 6]]) = [1, 3, 5]\n */\n\n\nvar pluck =\n/*#__PURE__*/\n_curry2(function pluck(p, list) {\n return map(prop(p), list);\n});\n\nmodule.exports = pluck;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _dispatchable =\n/*#__PURE__*/\nrequire(\"./internal/_dispatchable\");\n\nvar _map =\n/*#__PURE__*/\nrequire(\"./internal/_map\");\n\nvar _reduce =\n/*#__PURE__*/\nrequire(\"./internal/_reduce\");\n\nvar _xmap =\n/*#__PURE__*/\nrequire(\"./internal/_xmap\");\n\nvar curryN =\n/*#__PURE__*/\nrequire(\"./curryN\");\n\nvar keys =\n/*#__PURE__*/\nrequire(\"./keys\");\n/**\n * Takes a function and\n * a [functor](https://github.com/fantasyland/fantasy-land#functor),\n * applies the function to each of the functor's values, and returns\n * a functor of the same shape.\n *\n * Ramda provides suitable `map` implementations for `Array` and `Object`,\n * so this function may be applied to `[1, 2, 3]` or `{x: 1, y: 2, z: 3}`.\n *\n * Dispatches to the `map` method of the second argument, if present.\n *\n * Acts as a transducer if a transformer is given in list position.\n *\n * Also treats functions as functors and will compose them together.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category List\n * @sig Functor f => (a -> b) -> f a -> f b\n * @param {Function} fn The function to be called on every element of the input `list`.\n * @param {Array} list The list to be iterated over.\n * @return {Array} The new list.\n * @see R.transduce, R.addIndex\n * @example\n *\n * const double = x => x * 2;\n *\n * R.map(double, [1, 2, 3]); //=> [2, 4, 6]\n *\n * R.map(double, {x: 1, y: 2, z: 3}); //=> {x: 2, y: 4, z: 6}\n * @symb R.map(f, [a, b]) = [f(a), f(b)]\n * @symb R.map(f, { x: a, y: b }) = { x: f(a), y: f(b) }\n * @symb R.map(f, functor_o) = functor_o.map(f)\n */\n\n\nvar map =\n/*#__PURE__*/\n_curry2(\n/*#__PURE__*/\n_dispatchable(['fantasy-land/map', 'map'], _xmap, function map(fn, functor) {\n switch (Object.prototype.toString.call(functor)) {\n case '[object Function]':\n return curryN(functor.length, function () {\n return fn.call(this, functor.apply(this, arguments));\n });\n\n case '[object Object]':\n return _reduce(function (acc, key) {\n acc[key] = fn(functor[key]);\n return acc;\n }, {}, keys(functor));\n\n default:\n return _map(fn, functor);\n }\n}));\n\nmodule.exports = map;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./_curry2\");\n\nvar _xfBase =\n/*#__PURE__*/\nrequire(\"./_xfBase\");\n\nvar XMap =\n/*#__PURE__*/\nfunction () {\n function XMap(f, xf) {\n this.xf = xf;\n this.f = f;\n }\n\n XMap.prototype['@@transducer/init'] = _xfBase.init;\n XMap.prototype['@@transducer/result'] = _xfBase.result;\n\n XMap.prototype['@@transducer/step'] = function (result, input) {\n return this.xf['@@transducer/step'](result, this.f(input));\n };\n\n return XMap;\n}();\n\nvar _xmap =\n/*#__PURE__*/\n_curry2(function _xmap(f, xf) {\n return new XMap(f, xf);\n});\n\nmodule.exports = _xmap;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar _has =\n/*#__PURE__*/\nrequire(\"./internal/_has\");\n\nvar _isArguments =\n/*#__PURE__*/\nrequire(\"./internal/_isArguments\"); // cover IE < 9 keys issues\n\n\nvar hasEnumBug = !\n/*#__PURE__*/\n{\n toString: null\n}.propertyIsEnumerable('toString');\nvar nonEnumerableProps = ['constructor', 'valueOf', 'isPrototypeOf', 'toString', 'propertyIsEnumerable', 'hasOwnProperty', 'toLocaleString']; // Safari bug\n\nvar hasArgsEnumBug =\n/*#__PURE__*/\nfunction () {\n 'use strict';\n\n return arguments.propertyIsEnumerable('length');\n}();\n\nvar contains = function contains(list, item) {\n var idx = 0;\n\n while (idx < list.length) {\n if (list[idx] === item) {\n return true;\n }\n\n idx += 1;\n }\n\n return false;\n};\n/**\n * Returns a list containing the names of all the enumerable own properties of\n * the supplied object.\n * Note that the order of the output array is not guaranteed to be consistent\n * across different JS platforms.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Object\n * @sig {k: v} -> [k]\n * @param {Object} obj The object to extract properties from\n * @return {Array} An array of the object's own properties.\n * @see R.keysIn, R.values\n * @example\n *\n * R.keys({a: 1, b: 2, c: 3}); //=> ['a', 'b', 'c']\n */\n\n\nvar keys = typeof Object.keys === 'function' && !hasArgsEnumBug ?\n/*#__PURE__*/\n_curry1(function keys(obj) {\n return Object(obj) !== obj ? [] : Object.keys(obj);\n}) :\n/*#__PURE__*/\n_curry1(function keys(obj) {\n if (Object(obj) !== obj) {\n return [];\n }\n\n var prop, nIdx;\n var ks = [];\n\n var checkArgsLength = hasArgsEnumBug && _isArguments(obj);\n\n for (prop in obj) {\n if (_has(prop, obj) && (!checkArgsLength || prop !== 'length')) {\n ks[ks.length] = prop;\n }\n }\n\n if (hasEnumBug) {\n nIdx = nonEnumerableProps.length - 1;\n\n while (nIdx >= 0) {\n prop = nonEnumerableProps[nIdx];\n\n if (_has(prop, obj) && !contains(ks, prop)) {\n ks[ks.length] = prop;\n }\n\n nIdx -= 1;\n }\n }\n\n return ks;\n});\nmodule.exports = keys;","var _has =\n/*#__PURE__*/\nrequire(\"./_has\");\n\nvar toString = Object.prototype.toString;\n\nvar _isArguments =\n/*#__PURE__*/\nfunction () {\n return toString.call(arguments) === '[object Arguments]' ? function _isArguments(x) {\n return toString.call(x) === '[object Arguments]';\n } : function _isArguments(x) {\n return _has('callee', x);\n };\n}();\n\nmodule.exports = _isArguments;","function _map(fn, functor) {\n var idx = 0;\n var len = functor.length;\n var result = Array(len);\n\n while (idx < len) {\n result[idx] = fn(functor[idx]);\n idx += 1;\n }\n\n return result;\n}\n\nmodule.exports = _map;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar path =\n/*#__PURE__*/\nrequire(\"./path\");\n/**\n * Returns a function that when supplied an object returns the indicated\n * property of that object, if it exists.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Object\n * @typedefn Idx = String | Int\n * @sig Idx -> {s: a} -> a | Undefined\n * @param {String|Number} p The property name or array index\n * @param {Object} obj The object to query\n * @return {*} The value at `obj.p`.\n * @see R.path, R.nth\n * @example\n *\n * R.prop('x', {x: 100}); //=> 100\n * R.prop('x', {}); //=> undefined\n * R.prop(0, [100]); //=> 100\n * R.compose(R.inc, R.prop('x'))({ x: 3 }) //=> 4\n */\n\n\nvar prop =\n/*#__PURE__*/\n_curry2(function prop(p, obj) {\n return path([p], obj);\n});\n\nmodule.exports = prop;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar paths =\n/*#__PURE__*/\nrequire(\"./paths\");\n/**\n * Retrieve the value at a given path.\n *\n * @func\n * @memberOf R\n * @since v0.2.0\n * @category Object\n * @typedefn Idx = String | Int\n * @sig [Idx] -> {a} -> a | Undefined\n * @param {Array} path The path to use.\n * @param {Object} obj The object to retrieve the nested property from.\n * @return {*} The data at `path`.\n * @see R.prop, R.nth\n * @example\n *\n * R.path(['a', 'b'], {a: {b: 2}}); //=> 2\n * R.path(['a', 'b'], {c: {b: 2}}); //=> undefined\n * R.path(['a', 'b', 0], {a: {b: [1, 2, 3]}}); //=> 1\n * R.path(['a', 'b', -2], {a: {b: [1, 2, 3]}}); //=> 2\n */\n\n\nvar path =\n/*#__PURE__*/\n_curry2(function path(pathAr, obj) {\n return paths([pathAr], obj)[0];\n});\n\nmodule.exports = path;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _isInteger =\n/*#__PURE__*/\nrequire(\"./internal/_isInteger\");\n\nvar nth =\n/*#__PURE__*/\nrequire(\"./nth\");\n/**\n * Retrieves the values at given paths of an object.\n *\n * @func\n * @memberOf R\n * @since v0.27.1\n * @category Object\n * @typedefn Idx = [String | Int]\n * @sig [Idx] -> {a} -> [a | Undefined]\n * @param {Array} pathsArray The array of paths to be fetched.\n * @param {Object} obj The object to retrieve the nested properties from.\n * @return {Array} A list consisting of values at paths specified by \"pathsArray\".\n * @see R.path\n * @example\n *\n * R.paths([['a', 'b'], ['p', 0, 'q']], {a: {b: 2}, p: [{q: 3}]}); //=> [2, 3]\n * R.paths([['a', 'b'], ['p', 'r']], {a: {b: 2}, p: [{q: 3}]}); //=> [2, undefined]\n */\n\n\nvar paths =\n/*#__PURE__*/\n_curry2(function paths(pathsArray, obj) {\n return pathsArray.map(function (paths) {\n var val = obj;\n var idx = 0;\n var p;\n\n while (idx < paths.length) {\n if (val == null) {\n return;\n }\n\n p = paths[idx];\n val = _isInteger(p) ? nth(p, val) : val[p];\n idx += 1;\n }\n\n return val;\n });\n});\n\nmodule.exports = paths;","/**\n * Determine if the passed argument is an integer.\n *\n * @private\n * @param {*} n\n * @category Type\n * @return {Boolean}\n */\nmodule.exports = Number.isInteger || function _isInteger(n) {\n return n << 0 === n;\n};","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _isString =\n/*#__PURE__*/\nrequire(\"./internal/_isString\");\n/**\n * Returns the nth element of the given list or string. If n is negative the\n * element at index length + n is returned.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category List\n * @sig Number -> [a] -> a | Undefined\n * @sig Number -> String -> String\n * @param {Number} offset\n * @param {*} list\n * @return {*}\n * @example\n *\n * const list = ['foo', 'bar', 'baz', 'quux'];\n * R.nth(1, list); //=> 'bar'\n * R.nth(-1, list); //=> 'quux'\n * R.nth(-99, list); //=> undefined\n *\n * R.nth(2, 'abc'); //=> 'c'\n * R.nth(3, 'abc'); //=> ''\n * @symb R.nth(-1, [a, b, c]) = c\n * @symb R.nth(0, [a, b, c]) = a\n * @symb R.nth(1, [a, b, c]) = b\n */\n\n\nvar nth =\n/*#__PURE__*/\n_curry2(function nth(offset, list) {\n var idx = offset < 0 ? list.length + offset : offset;\n return _isString(list) ? list.charAt(idx) : list[idx];\n});\n\nmodule.exports = nth;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n/**\n * Returns a function that always returns the given value. Note that for\n * non-primitives the value returned is a reference to the original value.\n *\n * This function is known as `const`, `constant`, or `K` (for K combinator) in\n * other languages and libraries.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Function\n * @sig a -> (* -> a)\n * @param {*} val The value to wrap in a function\n * @return {Function} A Function :: * -> val.\n * @example\n *\n * const t = R.always('Tee');\n * t(); //=> 'Tee'\n */\n\n\nvar always =\n/*#__PURE__*/\n_curry1(function always(val) {\n return function () {\n return val;\n };\n});\n\nmodule.exports = always;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Returns `true` if both arguments are `true`; `false` otherwise.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Logic\n * @sig a -> b -> a | b\n * @param {Any} a\n * @param {Any} b\n * @return {Any} the first argument if it is falsy, otherwise the second argument.\n * @see R.both, R.xor\n * @example\n *\n * R.and(true, true); //=> true\n * R.and(true, false); //=> false\n * R.and(false, true); //=> false\n * R.and(false, false); //=> false\n */\n\n\nvar and =\n/*#__PURE__*/\n_curry2(function and(a, b) {\n return a && b;\n});\n\nmodule.exports = and;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _dispatchable =\n/*#__PURE__*/\nrequire(\"./internal/_dispatchable\");\n\nvar _xany =\n/*#__PURE__*/\nrequire(\"./internal/_xany\");\n/**\n * Returns `true` if at least one of the elements of the list match the predicate,\n * `false` otherwise.\n *\n * Dispatches to the `any` method of the second argument, if present.\n *\n * Acts as a transducer if a transformer is given in list position.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category List\n * @sig (a -> Boolean) -> [a] -> Boolean\n * @param {Function} fn The predicate function.\n * @param {Array} list The array to consider.\n * @return {Boolean} `true` if the predicate is satisfied by at least one element, `false`\n * otherwise.\n * @see R.all, R.none, R.transduce\n * @example\n *\n * const lessThan0 = R.flip(R.lt)(0);\n * const lessThan2 = R.flip(R.lt)(2);\n * R.any(lessThan0)([1, 2]); //=> false\n * R.any(lessThan2)([1, 2]); //=> true\n */\n\n\nvar any =\n/*#__PURE__*/\n_curry2(\n/*#__PURE__*/\n_dispatchable(['any'], _xany, function any(fn, list) {\n var idx = 0;\n\n while (idx < list.length) {\n if (fn(list[idx])) {\n return true;\n }\n\n idx += 1;\n }\n\n return false;\n}));\n\nmodule.exports = any;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./_curry2\");\n\nvar _reduced =\n/*#__PURE__*/\nrequire(\"./_reduced\");\n\nvar _xfBase =\n/*#__PURE__*/\nrequire(\"./_xfBase\");\n\nvar XAny =\n/*#__PURE__*/\nfunction () {\n function XAny(f, xf) {\n this.xf = xf;\n this.f = f;\n this.any = false;\n }\n\n XAny.prototype['@@transducer/init'] = _xfBase.init;\n\n XAny.prototype['@@transducer/result'] = function (result) {\n if (!this.any) {\n result = this.xf['@@transducer/step'](result, false);\n }\n\n return this.xf['@@transducer/result'](result);\n };\n\n XAny.prototype['@@transducer/step'] = function (result, input) {\n if (this.f(input)) {\n this.any = true;\n result = _reduced(this.xf['@@transducer/step'](result, true));\n }\n\n return result;\n };\n\n return XAny;\n}();\n\nvar _xany =\n/*#__PURE__*/\n_curry2(function _xany(f, xf) {\n return new XAny(f, xf);\n});\n\nmodule.exports = _xany;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar curryN =\n/*#__PURE__*/\nrequire(\"./curryN\");\n\nvar max =\n/*#__PURE__*/\nrequire(\"./max\");\n\nvar pluck =\n/*#__PURE__*/\nrequire(\"./pluck\");\n\nvar reduce =\n/*#__PURE__*/\nrequire(\"./reduce\");\n/**\n * Takes a list of predicates and returns a predicate that returns true for a\n * given list of arguments if at least one of the provided predicates is\n * satisfied by those arguments.\n *\n * The function returned is a curried function whose arity matches that of the\n * highest-arity predicate.\n *\n * @func\n * @memberOf R\n * @since v0.9.0\n * @category Logic\n * @sig [(*... -> Boolean)] -> (*... -> Boolean)\n * @param {Array} predicates An array of predicates to check\n * @return {Function} The combined predicate\n * @see R.allPass\n * @example\n *\n * const isClub = R.propEq('suit', '♣');\n * const isSpade = R.propEq('suit', '♠');\n * const isBlackCard = R.anyPass([isClub, isSpade]);\n *\n * isBlackCard({rank: '10', suit: '♣'}); //=> true\n * isBlackCard({rank: 'Q', suit: '♠'}); //=> true\n * isBlackCard({rank: 'Q', suit: '♦'}); //=> false\n */\n\n\nvar anyPass =\n/*#__PURE__*/\n_curry1(function anyPass(preds) {\n return curryN(reduce(max, 0, pluck('length', preds)), function () {\n var idx = 0;\n var len = preds.length;\n\n while (idx < len) {\n if (preds[idx].apply(this, arguments)) {\n return true;\n }\n\n idx += 1;\n }\n\n return false;\n });\n});\n\nmodule.exports = anyPass;","var _concat =\n/*#__PURE__*/\nrequire(\"./internal/_concat\");\n\nvar _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _reduce =\n/*#__PURE__*/\nrequire(\"./internal/_reduce\");\n\nvar map =\n/*#__PURE__*/\nrequire(\"./map\");\n/**\n * ap applies a list of functions to a list of values.\n *\n * Dispatches to the `ap` method of the second argument, if present. Also\n * treats curried functions as applicatives.\n *\n * @func\n * @memberOf R\n * @since v0.3.0\n * @category Function\n * @sig [a -> b] -> [a] -> [b]\n * @sig Apply f => f (a -> b) -> f a -> f b\n * @sig (r -> a -> b) -> (r -> a) -> (r -> b)\n * @param {*} applyF\n * @param {*} applyX\n * @return {*}\n * @example\n *\n * R.ap([R.multiply(2), R.add(3)], [1,2,3]); //=> [2, 4, 6, 4, 5, 6]\n * R.ap([R.concat('tasty '), R.toUpper], ['pizza', 'salad']); //=> [\"tasty pizza\", \"tasty salad\", \"PIZZA\", \"SALAD\"]\n *\n * // R.ap can also be used as S combinator\n * // when only two functions are passed\n * R.ap(R.concat, R.toUpper)('Ramda') //=> 'RamdaRAMDA'\n * @symb R.ap([f, g], [a, b]) = [f(a), f(b), g(a), g(b)]\n */\n\n\nvar ap =\n/*#__PURE__*/\n_curry2(function ap(applyF, applyX) {\n return typeof applyX['fantasy-land/ap'] === 'function' ? applyX['fantasy-land/ap'](applyF) : typeof applyF.ap === 'function' ? applyF.ap(applyX) : typeof applyF === 'function' ? function (x) {\n return applyF(x)(applyX(x));\n } : _reduce(function (acc, f) {\n return _concat(acc, map(f, applyX));\n }, [], applyF);\n});\n\nmodule.exports = ap;","var _aperture =\n/*#__PURE__*/\nrequire(\"./internal/_aperture\");\n\nvar _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _dispatchable =\n/*#__PURE__*/\nrequire(\"./internal/_dispatchable\");\n\nvar _xaperture =\n/*#__PURE__*/\nrequire(\"./internal/_xaperture\");\n/**\n * Returns a new list, composed of n-tuples of consecutive elements. If `n` is\n * greater than the length of the list, an empty list is returned.\n *\n * Acts as a transducer if a transformer is given in list position.\n *\n * @func\n * @memberOf R\n * @since v0.12.0\n * @category List\n * @sig Number -> [a] -> [[a]]\n * @param {Number} n The size of the tuples to create\n * @param {Array} list The list to split into `n`-length tuples\n * @return {Array} The resulting list of `n`-length tuples\n * @see R.transduce\n * @example\n *\n * R.aperture(2, [1, 2, 3, 4, 5]); //=> [[1, 2], [2, 3], [3, 4], [4, 5]]\n * R.aperture(3, [1, 2, 3, 4, 5]); //=> [[1, 2, 3], [2, 3, 4], [3, 4, 5]]\n * R.aperture(7, [1, 2, 3, 4, 5]); //=> []\n */\n\n\nvar aperture =\n/*#__PURE__*/\n_curry2(\n/*#__PURE__*/\n_dispatchable([], _xaperture, _aperture));\n\nmodule.exports = aperture;","var _concat =\n/*#__PURE__*/\nrequire(\"./_concat\");\n\nvar _curry2 =\n/*#__PURE__*/\nrequire(\"./_curry2\");\n\nvar _xfBase =\n/*#__PURE__*/\nrequire(\"./_xfBase\");\n\nvar XAperture =\n/*#__PURE__*/\nfunction () {\n function XAperture(n, xf) {\n this.xf = xf;\n this.pos = 0;\n this.full = false;\n this.acc = new Array(n);\n }\n\n XAperture.prototype['@@transducer/init'] = _xfBase.init;\n\n XAperture.prototype['@@transducer/result'] = function (result) {\n this.acc = null;\n return this.xf['@@transducer/result'](result);\n };\n\n XAperture.prototype['@@transducer/step'] = function (result, input) {\n this.store(input);\n return this.full ? this.xf['@@transducer/step'](result, this.getCopy()) : result;\n };\n\n XAperture.prototype.store = function (input) {\n this.acc[this.pos] = input;\n this.pos += 1;\n\n if (this.pos === this.acc.length) {\n this.pos = 0;\n this.full = true;\n }\n };\n\n XAperture.prototype.getCopy = function () {\n return _concat(Array.prototype.slice.call(this.acc, this.pos), Array.prototype.slice.call(this.acc, 0, this.pos));\n };\n\n return XAperture;\n}();\n\nvar _xaperture =\n/*#__PURE__*/\n_curry2(function _xaperture(n, xf) {\n return new XAperture(n, xf);\n});\n\nmodule.exports = _xaperture;","function _aperture(n, list) {\n var idx = 0;\n var limit = list.length - (n - 1);\n var acc = new Array(limit >= 0 ? limit : 0);\n\n while (idx < limit) {\n acc[idx] = Array.prototype.slice.call(list, idx, idx + n);\n idx += 1;\n }\n\n return acc;\n}\n\nmodule.exports = _aperture;","var _concat =\n/*#__PURE__*/\nrequire(\"./internal/_concat\");\n\nvar _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Returns a new list containing the contents of the given list, followed by\n * the given element.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category List\n * @sig a -> [a] -> [a]\n * @param {*} el The element to add to the end of the new list.\n * @param {Array} list The list of elements to add a new item to.\n * list.\n * @return {Array} A new list containing the elements of the old list followed by `el`.\n * @see R.prepend\n * @example\n *\n * R.append('tests', ['write', 'more']); //=> ['write', 'more', 'tests']\n * R.append('tests', []); //=> ['tests']\n * R.append(['tests'], ['write', 'more']); //=> ['write', 'more', ['tests']]\n */\n\n\nvar append =\n/*#__PURE__*/\n_curry2(function append(el, list) {\n return _concat(list, [el]);\n});\n\nmodule.exports = append;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Applies function `fn` to the argument list `args`. This is useful for\n * creating a fixed-arity function from a variadic function. `fn` should be a\n * bound function if context is significant.\n *\n * @func\n * @memberOf R\n * @since v0.7.0\n * @category Function\n * @sig (*... -> a) -> [*] -> a\n * @param {Function} fn The function which will be called with `args`\n * @param {Array} args The arguments to call `fn` with\n * @return {*} result The result, equivalent to `fn(...args)`\n * @see R.call, R.unapply\n * @example\n *\n * const nums = [1, 2, 3, -99, 42, 6, 7];\n * R.apply(Math.max, nums); //=> 42\n * @symb R.apply(f, [a, b, c]) = f(a, b, c)\n */\n\n\nvar apply =\n/*#__PURE__*/\n_curry2(function apply(fn, args) {\n return fn.apply(this, args);\n});\n\nmodule.exports = apply;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar apply =\n/*#__PURE__*/\nrequire(\"./apply\");\n\nvar curryN =\n/*#__PURE__*/\nrequire(\"./curryN\");\n\nvar max =\n/*#__PURE__*/\nrequire(\"./max\");\n\nvar pluck =\n/*#__PURE__*/\nrequire(\"./pluck\");\n\nvar reduce =\n/*#__PURE__*/\nrequire(\"./reduce\");\n\nvar keys =\n/*#__PURE__*/\nrequire(\"./keys\");\n\nvar values =\n/*#__PURE__*/\nrequire(\"./values\"); // Use custom mapValues function to avoid issues with specs that include a \"map\" key and R.map\n// delegating calls to .map\n\n\nfunction mapValues(fn, obj) {\n return keys(obj).reduce(function (acc, key) {\n acc[key] = fn(obj[key]);\n return acc;\n }, {});\n}\n/**\n * Given a spec object recursively mapping properties to functions, creates a\n * function producing an object of the same structure, by mapping each property\n * to the result of calling its associated function with the supplied arguments.\n *\n * @func\n * @memberOf R\n * @since v0.20.0\n * @category Function\n * @sig {k: ((a, b, ..., m) -> v)} -> ((a, b, ..., m) -> {k: v})\n * @param {Object} spec an object recursively mapping properties to functions for\n * producing the values for these properties.\n * @return {Function} A function that returns an object of the same structure\n * as `spec', with each property set to the value returned by calling its\n * associated function with the supplied arguments.\n * @see R.converge, R.juxt\n * @example\n *\n * const getMetrics = R.applySpec({\n * sum: R.add,\n * nested: { mul: R.multiply }\n * });\n * getMetrics(2, 4); // => { sum: 6, nested: { mul: 8 } }\n * @symb R.applySpec({ x: f, y: { z: g } })(a, b) = { x: f(a, b), y: { z: g(a, b) } }\n */\n\n\nvar applySpec =\n/*#__PURE__*/\n_curry1(function applySpec(spec) {\n spec = mapValues(function (v) {\n return typeof v == 'function' ? v : applySpec(v);\n }, spec);\n return curryN(reduce(max, 0, pluck('length', values(spec))), function () {\n var args = arguments;\n return mapValues(function (f) {\n return apply(f, args);\n }, spec);\n });\n});\n\nmodule.exports = applySpec;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar keys =\n/*#__PURE__*/\nrequire(\"./keys\");\n/**\n * Returns a list of all the enumerable own properties of the supplied object.\n * Note that the order of the output array is not guaranteed across different\n * JS platforms.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Object\n * @sig {k: v} -> [v]\n * @param {Object} obj The object to extract values from\n * @return {Array} An array of the values of the object's own properties.\n * @see R.valuesIn, R.keys\n * @example\n *\n * R.values({a: 1, b: 2, c: 3}); //=> [1, 2, 3]\n */\n\n\nvar values =\n/*#__PURE__*/\n_curry1(function values(obj) {\n var props = keys(obj);\n var len = props.length;\n var vals = [];\n var idx = 0;\n\n while (idx < len) {\n vals[idx] = obj[props[idx]];\n idx += 1;\n }\n\n return vals;\n});\n\nmodule.exports = values;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Takes a value and applies a function to it.\n *\n * This function is also known as the `thrush` combinator.\n *\n * @func\n * @memberOf R\n * @since v0.25.0\n * @category Function\n * @sig a -> (a -> b) -> b\n * @param {*} x The value\n * @param {Function} f The function to apply\n * @return {*} The result of applying `f` to `x`\n * @example\n *\n * const t42 = R.applyTo(42);\n * t42(R.identity); //=> 42\n * t42(R.add(1)); //=> 43\n */\n\n\nvar applyTo =\n/*#__PURE__*/\n_curry2(function applyTo(x, f) {\n return f(x);\n});\n\nmodule.exports = applyTo;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n/**\n * Makes an ascending comparator function out of a function that returns a value\n * that can be compared with `<` and `>`.\n *\n * @func\n * @memberOf R\n * @since v0.23.0\n * @category Function\n * @sig Ord b => (a -> b) -> a -> a -> Number\n * @param {Function} fn A function of arity one that returns a value that can be compared\n * @param {*} a The first item to be compared.\n * @param {*} b The second item to be compared.\n * @return {Number} `-1` if fn(a) < fn(b), `1` if fn(b) < fn(a), otherwise `0`\n * @see R.descend\n * @example\n *\n * const byAge = R.ascend(R.prop('age'));\n * const people = [\n * { name: 'Emma', age: 70 },\n * { name: 'Peter', age: 78 },\n * { name: 'Mikhail', age: 62 },\n * ];\n * const peopleByYoungestFirst = R.sort(byAge, people);\n * //=> [{ name: 'Mikhail', age: 62 },{ name: 'Emma', age: 70 }, { name: 'Peter', age: 78 }]\n */\n\n\nvar ascend =\n/*#__PURE__*/\n_curry3(function ascend(fn, a, b) {\n var aa = fn(a);\n var bb = fn(b);\n return aa < bb ? -1 : aa > bb ? 1 : 0;\n});\n\nmodule.exports = ascend;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n/**\n * Makes a shallow clone of an object, setting or overriding the specified\n * property with the given value. Note that this copies and flattens prototype\n * properties onto the new object as well. All non-primitive properties are\n * copied by reference.\n *\n * @func\n * @memberOf R\n * @since v0.8.0\n * @category Object\n * @sig String -> a -> {k: v} -> {k: v}\n * @param {String} prop The property name to set\n * @param {*} val The new value\n * @param {Object} obj The object to clone\n * @return {Object} A new object equivalent to the original except for the changed property.\n * @see R.dissoc, R.pick\n * @example\n *\n * R.assoc('c', 3, {a: 1, b: 2}); //=> {a: 1, b: 2, c: 3}\n */\n\n\nvar assoc =\n/*#__PURE__*/\n_curry3(function assoc(prop, val, obj) {\n var result = {};\n\n for (var p in obj) {\n result[p] = obj[p];\n }\n\n result[prop] = val;\n return result;\n});\n\nmodule.exports = assoc;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n\nvar _has =\n/*#__PURE__*/\nrequire(\"./internal/_has\");\n\nvar _isArray =\n/*#__PURE__*/\nrequire(\"./internal/_isArray\");\n\nvar _isInteger =\n/*#__PURE__*/\nrequire(\"./internal/_isInteger\");\n\nvar assoc =\n/*#__PURE__*/\nrequire(\"./assoc\");\n\nvar isNil =\n/*#__PURE__*/\nrequire(\"./isNil\");\n/**\n * Makes a shallow clone of an object, setting or overriding the nodes required\n * to create the given path, and placing the specific value at the tail end of\n * that path. Note that this copies and flattens prototype properties onto the\n * new object as well. All non-primitive properties are copied by reference.\n *\n * @func\n * @memberOf R\n * @since v0.8.0\n * @category Object\n * @typedefn Idx = String | Int\n * @sig [Idx] -> a -> {a} -> {a}\n * @param {Array} path the path to set\n * @param {*} val The new value\n * @param {Object} obj The object to clone\n * @return {Object} A new object equivalent to the original except along the specified path.\n * @see R.dissocPath\n * @example\n *\n * R.assocPath(['a', 'b', 'c'], 42, {a: {b: {c: 0}}}); //=> {a: {b: {c: 42}}}\n *\n * // Any missing or non-object keys in path will be overridden\n * R.assocPath(['a', 'b', 'c'], 42, {a: 5}); //=> {a: {b: {c: 42}}}\n */\n\n\nvar assocPath =\n/*#__PURE__*/\n_curry3(function assocPath(path, val, obj) {\n if (path.length === 0) {\n return val;\n }\n\n var idx = path[0];\n\n if (path.length > 1) {\n var nextObj = !isNil(obj) && _has(idx, obj) ? obj[idx] : _isInteger(path[1]) ? [] : {};\n val = assocPath(Array.prototype.slice.call(path, 1), val, nextObj);\n }\n\n if (_isInteger(idx) && _isArray(obj)) {\n var arr = [].concat(obj);\n arr[idx] = val;\n return arr;\n } else {\n return assoc(idx, val, obj);\n }\n});\n\nmodule.exports = assocPath;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar nAry =\n/*#__PURE__*/\nrequire(\"./nAry\");\n/**\n * Wraps a function of any arity (including nullary) in a function that accepts\n * exactly 2 parameters. Any extraneous parameters will not be passed to the\n * supplied function.\n *\n * @func\n * @memberOf R\n * @since v0.2.0\n * @category Function\n * @sig (* -> c) -> (a, b -> c)\n * @param {Function} fn The function to wrap.\n * @return {Function} A new function wrapping `fn`. The new function is guaranteed to be of\n * arity 2.\n * @see R.nAry, R.unary\n * @example\n *\n * const takesThreeArgs = function(a, b, c) {\n * return [a, b, c];\n * };\n * takesThreeArgs.length; //=> 3\n * takesThreeArgs(1, 2, 3); //=> [1, 2, 3]\n *\n * const takesTwoArgs = R.binary(takesThreeArgs);\n * takesTwoArgs.length; //=> 2\n * // Only 2 arguments are passed to the wrapped function\n * takesTwoArgs(1, 2, 3); //=> [1, 2, undefined]\n * @symb R.binary(f)(a, b, c) = f(a, b)\n */\n\n\nvar binary =\n/*#__PURE__*/\n_curry1(function binary(fn) {\n return nAry(2, fn);\n});\n\nmodule.exports = binary;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Wraps a function of any arity (including nullary) in a function that accepts\n * exactly `n` parameters. Any extraneous parameters will not be passed to the\n * supplied function.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Function\n * @sig Number -> (* -> a) -> (* -> a)\n * @param {Number} n The desired arity of the new function.\n * @param {Function} fn The function to wrap.\n * @return {Function} A new function wrapping `fn`. The new function is guaranteed to be of\n * arity `n`.\n * @see R.binary, R.unary\n * @example\n *\n * const takesTwoArgs = (a, b) => [a, b];\n *\n * takesTwoArgs.length; //=> 2\n * takesTwoArgs(1, 2); //=> [1, 2]\n *\n * const takesOneArg = R.nAry(1, takesTwoArgs);\n * takesOneArg.length; //=> 1\n * // Only `n` arguments are passed to the wrapped function\n * takesOneArg(1, 2); //=> [1, undefined]\n * @symb R.nAry(0, f)(a, b) = f()\n * @symb R.nAry(1, f)(a, b) = f(a)\n * @symb R.nAry(2, f)(a, b) = f(a, b)\n */\n\n\nvar nAry =\n/*#__PURE__*/\n_curry2(function nAry(n, fn) {\n switch (n) {\n case 0:\n return function () {\n return fn.call(this);\n };\n\n case 1:\n return function (a0) {\n return fn.call(this, a0);\n };\n\n case 2:\n return function (a0, a1) {\n return fn.call(this, a0, a1);\n };\n\n case 3:\n return function (a0, a1, a2) {\n return fn.call(this, a0, a1, a2);\n };\n\n case 4:\n return function (a0, a1, a2, a3) {\n return fn.call(this, a0, a1, a2, a3);\n };\n\n case 5:\n return function (a0, a1, a2, a3, a4) {\n return fn.call(this, a0, a1, a2, a3, a4);\n };\n\n case 6:\n return function (a0, a1, a2, a3, a4, a5) {\n return fn.call(this, a0, a1, a2, a3, a4, a5);\n };\n\n case 7:\n return function (a0, a1, a2, a3, a4, a5, a6) {\n return fn.call(this, a0, a1, a2, a3, a4, a5, a6);\n };\n\n case 8:\n return function (a0, a1, a2, a3, a4, a5, a6, a7) {\n return fn.call(this, a0, a1, a2, a3, a4, a5, a6, a7);\n };\n\n case 9:\n return function (a0, a1, a2, a3, a4, a5, a6, a7, a8) {\n return fn.call(this, a0, a1, a2, a3, a4, a5, a6, a7, a8);\n };\n\n case 10:\n return function (a0, a1, a2, a3, a4, a5, a6, a7, a8, a9) {\n return fn.call(this, a0, a1, a2, a3, a4, a5, a6, a7, a8, a9);\n };\n\n default:\n throw new Error('First argument to nAry must be a non-negative integer no greater than ten');\n }\n});\n\nmodule.exports = nAry;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _isFunction =\n/*#__PURE__*/\nrequire(\"./internal/_isFunction\");\n\nvar and =\n/*#__PURE__*/\nrequire(\"./and\");\n\nvar lift =\n/*#__PURE__*/\nrequire(\"./lift\");\n/**\n * A function which calls the two provided functions and returns the `&&`\n * of the results.\n * It returns the result of the first function if it is false-y and the result\n * of the second function otherwise. Note that this is short-circuited,\n * meaning that the second function will not be invoked if the first returns a\n * false-y value.\n *\n * In addition to functions, `R.both` also accepts any fantasy-land compatible\n * applicative functor.\n *\n * @func\n * @memberOf R\n * @since v0.12.0\n * @category Logic\n * @sig (*... -> Boolean) -> (*... -> Boolean) -> (*... -> Boolean)\n * @param {Function} f A predicate\n * @param {Function} g Another predicate\n * @return {Function} a function that applies its arguments to `f` and `g` and `&&`s their outputs together.\n * @see R.and\n * @example\n *\n * const gt10 = R.gt(R.__, 10)\n * const lt20 = R.lt(R.__, 20)\n * const f = R.both(gt10, lt20);\n * f(15); //=> true\n * f(30); //=> false\n *\n * R.both(Maybe.Just(false), Maybe.Just(55)); // => Maybe.Just(false)\n * R.both([false, false, 'a'], [11]); //=> [false, false, 11]\n */\n\n\nvar both =\n/*#__PURE__*/\n_curry2(function both(f, g) {\n return _isFunction(f) ? function _both() {\n return f.apply(this, arguments) && g.apply(this, arguments);\n } : lift(and)(f, g);\n});\n\nmodule.exports = both;","function _isFunction(x) {\n var type = Object.prototype.toString.call(x);\n return type === '[object Function]' || type === '[object AsyncFunction]' || type === '[object GeneratorFunction]' || type === '[object AsyncGeneratorFunction]';\n}\n\nmodule.exports = _isFunction;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar liftN =\n/*#__PURE__*/\nrequire(\"./liftN\");\n/**\n * \"lifts\" a function of arity > 1 so that it may \"map over\" a list, Function or other\n * object that satisfies the [FantasyLand Apply spec](https://github.com/fantasyland/fantasy-land#apply).\n *\n * @func\n * @memberOf R\n * @since v0.7.0\n * @category Function\n * @sig (*... -> *) -> ([*]... -> [*])\n * @param {Function} fn The function to lift into higher context\n * @return {Function} The lifted function.\n * @see R.liftN\n * @example\n *\n * const madd3 = R.lift((a, b, c) => a + b + c);\n *\n * madd3([1,2,3], [1,2,3], [1]); //=> [3, 4, 5, 4, 5, 6, 5, 6, 7]\n *\n * const madd5 = R.lift((a, b, c, d, e) => a + b + c + d + e);\n *\n * madd5([1,2], [3], [4, 5], [6], [7, 8]); //=> [21, 22, 22, 23, 22, 23, 23, 24]\n */\n\n\nvar lift =\n/*#__PURE__*/\n_curry1(function lift(fn) {\n return liftN(fn.length, fn);\n});\n\nmodule.exports = lift;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _reduce =\n/*#__PURE__*/\nrequire(\"./internal/_reduce\");\n\nvar ap =\n/*#__PURE__*/\nrequire(\"./ap\");\n\nvar curryN =\n/*#__PURE__*/\nrequire(\"./curryN\");\n\nvar map =\n/*#__PURE__*/\nrequire(\"./map\");\n/**\n * \"lifts\" a function to be the specified arity, so that it may \"map over\" that\n * many lists, Functions or other objects that satisfy the [FantasyLand Apply spec](https://github.com/fantasyland/fantasy-land#apply).\n *\n * @func\n * @memberOf R\n * @since v0.7.0\n * @category Function\n * @sig Number -> (*... -> *) -> ([*]... -> [*])\n * @param {Function} fn The function to lift into higher context\n * @return {Function} The lifted function.\n * @see R.lift, R.ap\n * @example\n *\n * const madd3 = R.liftN(3, (...args) => R.sum(args));\n * madd3([1,2,3], [1,2,3], [1]); //=> [3, 4, 5, 4, 5, 6, 5, 6, 7]\n */\n\n\nvar liftN =\n/*#__PURE__*/\n_curry2(function liftN(arity, fn) {\n var lifted = curryN(arity, fn);\n return curryN(arity, function () {\n return _reduce(ap, map(lifted, arguments[0]), Array.prototype.slice.call(arguments, 1));\n });\n});\n\nmodule.exports = liftN;","var curry =\n/*#__PURE__*/\nrequire(\"./curry\");\n/**\n * Returns the result of calling its first argument with the remaining\n * arguments. This is occasionally useful as a converging function for\n * [`R.converge`](#converge): the first branch can produce a function while the\n * remaining branches produce values to be passed to that function as its\n * arguments.\n *\n * @func\n * @memberOf R\n * @since v0.9.0\n * @category Function\n * @sig (*... -> a),*... -> a\n * @param {Function} fn The function to apply to the remaining arguments.\n * @param {...*} args Any number of positional arguments.\n * @return {*}\n * @see R.apply\n * @example\n *\n * R.call(R.add, 1, 2); //=> 3\n *\n * const indentN = R.pipe(R.repeat(' '),\n * R.join(''),\n * R.replace(/^(?!$)/gm));\n *\n * const format = R.converge(R.call, [\n * R.pipe(R.prop('indent'), indentN),\n * R.prop('value')\n * ]);\n *\n * format({indent: 2, value: 'foo\\nbar\\nbaz\\n'}); //=> ' foo\\n bar\\n baz\\n'\n * @symb R.call(f, a, b) = f(a, b)\n */\n\n\nvar call =\n/*#__PURE__*/\ncurry(function call(fn) {\n return fn.apply(this, Array.prototype.slice.call(arguments, 1));\n});\nmodule.exports = call;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar curryN =\n/*#__PURE__*/\nrequire(\"./curryN\");\n/**\n * Returns a curried equivalent of the provided function. The curried function\n * has two unusual capabilities. First, its arguments needn't be provided one\n * at a time. If `f` is a ternary function and `g` is `R.curry(f)`, the\n * following are equivalent:\n *\n * - `g(1)(2)(3)`\n * - `g(1)(2, 3)`\n * - `g(1, 2)(3)`\n * - `g(1, 2, 3)`\n *\n * Secondly, the special placeholder value [`R.__`](#__) may be used to specify\n * \"gaps\", allowing partial application of any combination of arguments,\n * regardless of their positions. If `g` is as above and `_` is [`R.__`](#__),\n * the following are equivalent:\n *\n * - `g(1, 2, 3)`\n * - `g(_, 2, 3)(1)`\n * - `g(_, _, 3)(1)(2)`\n * - `g(_, _, 3)(1, 2)`\n * - `g(_, 2)(1)(3)`\n * - `g(_, 2)(1, 3)`\n * - `g(_, 2)(_, 3)(1)`\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Function\n * @sig (* -> a) -> (* -> a)\n * @param {Function} fn The function to curry.\n * @return {Function} A new, curried function.\n * @see R.curryN, R.partial\n * @example\n *\n * const addFourNumbers = (a, b, c, d) => a + b + c + d;\n *\n * const curriedAddFourNumbers = R.curry(addFourNumbers);\n * const f = curriedAddFourNumbers(1, 2);\n * const g = f(3);\n * g(4); //=> 10\n */\n\n\nvar curry =\n/*#__PURE__*/\n_curry1(function curry(fn) {\n return curryN(fn.length, fn);\n});\n\nmodule.exports = curry;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _dispatchable =\n/*#__PURE__*/\nrequire(\"./internal/_dispatchable\");\n\nvar _makeFlat =\n/*#__PURE__*/\nrequire(\"./internal/_makeFlat\");\n\nvar _xchain =\n/*#__PURE__*/\nrequire(\"./internal/_xchain\");\n\nvar map =\n/*#__PURE__*/\nrequire(\"./map\");\n/**\n * `chain` maps a function over a list and concatenates the results. `chain`\n * is also known as `flatMap` in some libraries.\n *\n * Dispatches to the `chain` method of the second argument, if present,\n * according to the [FantasyLand Chain spec](https://github.com/fantasyland/fantasy-land#chain).\n *\n * If second argument is a function, `chain(f, g)(x)` is equivalent to `f(g(x), x)`.\n *\n * Acts as a transducer if a transformer is given in list position.\n *\n * @func\n * @memberOf R\n * @since v0.3.0\n * @category List\n * @sig Chain m => (a -> m b) -> m a -> m b\n * @param {Function} fn The function to map with\n * @param {Array} list The list to map over\n * @return {Array} The result of flat-mapping `list` with `fn`\n * @example\n *\n * const duplicate = n => [n, n];\n * R.chain(duplicate, [1, 2, 3]); //=> [1, 1, 2, 2, 3, 3]\n *\n * R.chain(R.append, R.head)([1, 2, 3]); //=> [1, 2, 3, 1]\n */\n\n\nvar chain =\n/*#__PURE__*/\n_curry2(\n/*#__PURE__*/\n_dispatchable(['fantasy-land/chain', 'chain'], _xchain, function chain(fn, monad) {\n if (typeof monad === 'function') {\n return function (x) {\n return fn(monad(x))(x);\n };\n }\n\n return _makeFlat(false)(map(fn, monad));\n}));\n\nmodule.exports = chain;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./_curry2\");\n\nvar _flatCat =\n/*#__PURE__*/\nrequire(\"./_flatCat\");\n\nvar map =\n/*#__PURE__*/\nrequire(\"../map\");\n\nvar _xchain =\n/*#__PURE__*/\n_curry2(function _xchain(f, xf) {\n return map(f, _flatCat(xf));\n});\n\nmodule.exports = _xchain;","var _forceReduced =\n/*#__PURE__*/\nrequire(\"./_forceReduced\");\n\nvar _isArrayLike =\n/*#__PURE__*/\nrequire(\"./_isArrayLike\");\n\nvar _reduce =\n/*#__PURE__*/\nrequire(\"./_reduce\");\n\nvar _xfBase =\n/*#__PURE__*/\nrequire(\"./_xfBase\");\n\nvar preservingReduced = function (xf) {\n return {\n '@@transducer/init': _xfBase.init,\n '@@transducer/result': function (result) {\n return xf['@@transducer/result'](result);\n },\n '@@transducer/step': function (result, input) {\n var ret = xf['@@transducer/step'](result, input);\n return ret['@@transducer/reduced'] ? _forceReduced(ret) : ret;\n }\n };\n};\n\nvar _flatCat = function _xcat(xf) {\n var rxf = preservingReduced(xf);\n return {\n '@@transducer/init': _xfBase.init,\n '@@transducer/result': function (result) {\n return rxf['@@transducer/result'](result);\n },\n '@@transducer/step': function (result, input) {\n return !_isArrayLike(input) ? _reduce(rxf, result, [input]) : _reduce(rxf, result, input);\n }\n };\n};\n\nmodule.exports = _flatCat;","function _forceReduced(x) {\n return {\n '@@transducer/value': x,\n '@@transducer/reduced': true\n };\n}\n\nmodule.exports = _forceReduced;","var _isArrayLike =\n/*#__PURE__*/\nrequire(\"./_isArrayLike\");\n/**\n * `_makeFlat` is a helper function that returns a one-level or fully recursive\n * function based on the flag passed in.\n *\n * @private\n */\n\n\nfunction _makeFlat(recursive) {\n return function flatt(list) {\n var value, jlen, j;\n var result = [];\n var idx = 0;\n var ilen = list.length;\n\n while (idx < ilen) {\n if (_isArrayLike(list[idx])) {\n value = recursive ? flatt(list[idx]) : list[idx];\n j = 0;\n jlen = value.length;\n\n while (j < jlen) {\n result[result.length] = value[j];\n j += 1;\n }\n } else {\n result[result.length] = list[idx];\n }\n\n idx += 1;\n }\n\n return result;\n };\n}\n\nmodule.exports = _makeFlat;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n/**\n * Restricts a number to be within a range.\n *\n * Also works for other ordered types such as Strings and Dates.\n *\n * @func\n * @memberOf R\n * @since v0.20.0\n * @category Relation\n * @sig Ord a => a -> a -> a -> a\n * @param {Number} minimum The lower limit of the clamp (inclusive)\n * @param {Number} maximum The upper limit of the clamp (inclusive)\n * @param {Number} value Value to be clamped\n * @return {Number} Returns `minimum` when `val < minimum`, `maximum` when `val > maximum`, returns `val` otherwise\n * @example\n *\n * R.clamp(1, 10, -5) // => 1\n * R.clamp(1, 10, 15) // => 10\n * R.clamp(1, 10, 4) // => 4\n */\n\n\nvar clamp =\n/*#__PURE__*/\n_curry3(function clamp(min, max, value) {\n if (min > max) {\n throw new Error('min must not be greater than max in clamp(min, max, value)');\n }\n\n return value < min ? min : value > max ? max : value;\n});\n\nmodule.exports = clamp;","var _clone =\n/*#__PURE__*/\nrequire(\"./internal/_clone\");\n\nvar _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n/**\n * Creates a deep copy of the value which may contain (nested) `Array`s and\n * `Object`s, `Number`s, `String`s, `Boolean`s and `Date`s. `Function`s are\n * assigned by reference rather than copied\n *\n * Dispatches to a `clone` method if present.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Object\n * @sig {*} -> {*}\n * @param {*} value The object or array to clone\n * @return {*} A deeply cloned copy of `val`\n * @example\n *\n * const objects = [{}, {}, {}];\n * const objectsClone = R.clone(objects);\n * objects === objectsClone; //=> false\n * objects[0] === objectsClone[0]; //=> false\n */\n\n\nvar clone =\n/*#__PURE__*/\n_curry1(function clone(value) {\n return value != null && typeof value.clone === 'function' ? value.clone() : _clone(value, [], [], true);\n});\n\nmodule.exports = clone;","var _cloneRegExp =\n/*#__PURE__*/\nrequire(\"./_cloneRegExp\");\n\nvar type =\n/*#__PURE__*/\nrequire(\"../type\");\n/**\n * Copies an object.\n *\n * @private\n * @param {*} value The value to be copied\n * @param {Array} refFrom Array containing the source references\n * @param {Array} refTo Array containing the copied source references\n * @param {Boolean} deep Whether or not to perform deep cloning.\n * @return {*} The copied value.\n */\n\n\nfunction _clone(value, refFrom, refTo, deep) {\n var copy = function copy(copiedValue) {\n var len = refFrom.length;\n var idx = 0;\n\n while (idx < len) {\n if (value === refFrom[idx]) {\n return refTo[idx];\n }\n\n idx += 1;\n }\n\n refFrom[idx + 1] = value;\n refTo[idx + 1] = copiedValue;\n\n for (var key in value) {\n copiedValue[key] = deep ? _clone(value[key], refFrom, refTo, true) : value[key];\n }\n\n return copiedValue;\n };\n\n switch (type(value)) {\n case 'Object':\n return copy({});\n\n case 'Array':\n return copy([]);\n\n case 'Date':\n return new Date(value.valueOf());\n\n case 'RegExp':\n return _cloneRegExp(value);\n\n default:\n return value;\n }\n}\n\nmodule.exports = _clone;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n/**\n * Gives a single-word string description of the (native) type of a value,\n * returning such answers as 'Object', 'Number', 'Array', or 'Null'. Does not\n * attempt to distinguish user Object types any further, reporting them all as\n * 'Object'.\n *\n * @func\n * @memberOf R\n * @since v0.8.0\n * @category Type\n * @sig (* -> {*}) -> String\n * @param {*} val The value to test\n * @return {String}\n * @example\n *\n * R.type({}); //=> \"Object\"\n * R.type(1); //=> \"Number\"\n * R.type(false); //=> \"Boolean\"\n * R.type('s'); //=> \"String\"\n * R.type(null); //=> \"Null\"\n * R.type([]); //=> \"Array\"\n * R.type(/[A-z]/); //=> \"RegExp\"\n * R.type(() => {}); //=> \"Function\"\n * R.type(undefined); //=> \"Undefined\"\n */\n\n\nvar type =\n/*#__PURE__*/\n_curry1(function type(val) {\n return val === null ? 'Null' : val === undefined ? 'Undefined' : Object.prototype.toString.call(val).slice(8, -1);\n});\n\nmodule.exports = type;","function _cloneRegExp(pattern) {\n return new RegExp(pattern.source, (pattern.global ? 'g' : '') + (pattern.ignoreCase ? 'i' : '') + (pattern.multiline ? 'm' : '') + (pattern.sticky ? 'y' : '') + (pattern.unicode ? 'u' : ''));\n}\n\nmodule.exports = _cloneRegExp;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n/**\n * Makes a comparator function out of a function that reports whether the first\n * element is less than the second.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Function\n * @sig ((a, b) -> Boolean) -> ((a, b) -> Number)\n * @param {Function} pred A predicate function of arity two which will return `true` if the first argument\n * is less than the second, `false` otherwise\n * @return {Function} A Function :: a -> b -> Int that returns `-1` if a < b, `1` if b < a, otherwise `0`\n * @example\n *\n * const byAge = R.comparator((a, b) => a.age < b.age);\n * const people = [\n * { name: 'Emma', age: 70 },\n * { name: 'Peter', age: 78 },\n * { name: 'Mikhail', age: 62 },\n * ];\n * const peopleByIncreasingAge = R.sort(byAge, people);\n * //=> [{ name: 'Mikhail', age: 62 },{ name: 'Emma', age: 70 }, { name: 'Peter', age: 78 }]\n */\n\n\nvar comparator =\n/*#__PURE__*/\n_curry1(function comparator(pred) {\n return function (a, b) {\n return pred(a, b) ? -1 : pred(b, a) ? 1 : 0;\n };\n});\n\nmodule.exports = comparator;","var lift =\n/*#__PURE__*/\nrequire(\"./lift\");\n\nvar not =\n/*#__PURE__*/\nrequire(\"./not\");\n/**\n * Takes a function `f` and returns a function `g` such that if called with the same arguments\n * when `f` returns a \"truthy\" value, `g` returns `false` and when `f` returns a \"falsy\" value `g` returns `true`.\n *\n * `R.complement` may be applied to any functor\n *\n * @func\n * @memberOf R\n * @since v0.12.0\n * @category Logic\n * @sig (*... -> *) -> (*... -> Boolean)\n * @param {Function} f\n * @return {Function}\n * @see R.not\n * @example\n *\n * const isNotNil = R.complement(R.isNil);\n * isNil(null); //=> true\n * isNotNil(null); //=> false\n * isNil(7); //=> false\n * isNotNil(7); //=> true\n */\n\n\nvar complement =\n/*#__PURE__*/\nlift(not);\nmodule.exports = complement;","var chain =\n/*#__PURE__*/\nrequire(\"./chain\");\n\nvar compose =\n/*#__PURE__*/\nrequire(\"./compose\");\n\nvar map =\n/*#__PURE__*/\nrequire(\"./map\");\n/**\n * Returns the right-to-left Kleisli composition of the provided functions,\n * each of which must return a value of a type supported by [`chain`](#chain).\n *\n * `R.composeK(h, g, f)` is equivalent to `R.compose(R.chain(h), R.chain(g), f)`.\n *\n * @func\n * @memberOf R\n * @since v0.16.0\n * @category Function\n * @sig Chain m => ((y -> m z), (x -> m y), ..., (a -> m b)) -> (a -> m z)\n * @param {...Function} ...functions The functions to compose\n * @return {Function}\n * @see R.pipeK\n * @deprecated since v0.26.0\n * @example\n *\n * // get :: String -> Object -> Maybe *\n * const get = R.curry((propName, obj) => Maybe(obj[propName]))\n *\n * // getStateCode :: Maybe String -> Maybe String\n * const getStateCode = R.composeK(\n * R.compose(Maybe.of, R.toUpper),\n * get('state'),\n * get('address'),\n * get('user'),\n * );\n * getStateCode({\"user\":{\"address\":{\"state\":\"ny\"}}}); //=> Maybe.Just(\"NY\")\n * getStateCode({}); //=> Maybe.Nothing()\n * @symb R.composeK(f, g, h)(a) = R.chain(f, R.chain(g, h(a)))\n */\n\n\nfunction composeK() {\n if (arguments.length === 0) {\n throw new Error('composeK requires at least one argument');\n }\n\n var init = Array.prototype.slice.call(arguments);\n var last = init.pop();\n return compose(compose.apply(this, map(chain, init)), last);\n}\n\nmodule.exports = composeK;","var pipeP =\n/*#__PURE__*/\nrequire(\"./pipeP\");\n\nvar reverse =\n/*#__PURE__*/\nrequire(\"./reverse\");\n/**\n * Performs right-to-left composition of one or more Promise-returning\n * functions. The last arguments may have any arity; the remaining\n * arguments must be unary.\n *\n * @func\n * @memberOf R\n * @since v0.10.0\n * @category Function\n * @sig ((y -> Promise z), (x -> Promise y), ..., (a -> Promise b)) -> (a -> Promise z)\n * @param {...Function} functions The functions to compose\n * @return {Function}\n * @see R.pipeP\n * @deprecated since v0.26.0\n * @example\n *\n * const db = {\n * users: {\n * JOE: {\n * name: 'Joe',\n * followers: ['STEVE', 'SUZY']\n * }\n * }\n * }\n *\n * // We'll pretend to do a db lookup which returns a promise\n * const lookupUser = (userId) => Promise.resolve(db.users[userId])\n * const lookupFollowers = (user) => Promise.resolve(user.followers)\n * lookupUser('JOE').then(lookupFollowers)\n *\n * // followersForUser :: String -> Promise [UserId]\n * const followersForUser = R.composeP(lookupFollowers, lookupUser);\n * followersForUser('JOE').then(followers => console.log('Followers:', followers))\n * // Followers: [\"STEVE\",\"SUZY\"]\n */\n\n\nfunction composeP() {\n if (arguments.length === 0) {\n throw new Error('composeP requires at least one argument');\n }\n\n return pipeP.apply(this, reverse(arguments));\n}\n\nmodule.exports = composeP;","var _arity =\n/*#__PURE__*/\nrequire(\"./internal/_arity\");\n\nvar _pipeP =\n/*#__PURE__*/\nrequire(\"./internal/_pipeP\");\n\nvar reduce =\n/*#__PURE__*/\nrequire(\"./reduce\");\n\nvar tail =\n/*#__PURE__*/\nrequire(\"./tail\");\n/**\n * Performs left-to-right composition of one or more Promise-returning\n * functions. The first argument may have any arity; the remaining arguments\n * must be unary.\n *\n * @func\n * @memberOf R\n * @since v0.10.0\n * @category Function\n * @sig ((a -> Promise b), (b -> Promise c), ..., (y -> Promise z)) -> (a -> Promise z)\n * @param {...Function} functions\n * @return {Function}\n * @see R.composeP\n * @deprecated since v0.26.0\n * @example\n *\n * // followersForUser :: String -> Promise [User]\n * const followersForUser = R.pipeP(db.getUserById, db.getFollowers);\n */\n\n\nfunction pipeP() {\n if (arguments.length === 0) {\n throw new Error('pipeP requires at least one argument');\n }\n\n return _arity(arguments[0].length, reduce(_pipeP, arguments[0], tail(arguments)));\n}\n\nmodule.exports = pipeP;","function _pipeP(f, g) {\n return function () {\n var ctx = this;\n return f.apply(ctx, arguments).then(function (x) {\n return g.call(ctx, x);\n });\n };\n}\n\nmodule.exports = _pipeP;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar pipeWith =\n/*#__PURE__*/\nrequire(\"./pipeWith\");\n\nvar reverse =\n/*#__PURE__*/\nrequire(\"./reverse\");\n/**\n * Performs right-to-left function composition using transforming function. The last argument may have\n * any arity; the remaining arguments must be unary.\n *\n * **Note:** The result of compose is not automatically curried. Transforming function is not used on the\n * last argument.\n *\n * @func\n * @memberOf R\n * @since v0.26.0\n * @category Function\n * @sig ((* -> *), [(y -> z), (x -> y), ..., (o -> p), ((a, b, ..., n) -> o)]) -> ((a, b, ..., n) -> z)\n * @param {...Function} ...functions The functions to compose\n * @return {Function}\n * @see R.compose, R.pipeWith\n * @example\n *\n * const composeWhileNotNil = R.composeWith((f, res) => R.isNil(res) ? res : f(res));\n *\n * composeWhileNotNil([R.inc, R.prop('age')])({age: 1}) //=> 2\n * composeWhileNotNil([R.inc, R.prop('age')])({}) //=> undefined\n *\n * @symb R.composeWith(f)([g, h, i])(...args) = f(g, f(h, i(...args)))\n */\n\n\nvar composeWith =\n/*#__PURE__*/\n_curry2(function composeWith(xf, list) {\n return pipeWith.apply(this, [xf, reverse(list)]);\n});\n\nmodule.exports = composeWith;","var _arity =\n/*#__PURE__*/\nrequire(\"./internal/_arity\");\n\nvar _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar head =\n/*#__PURE__*/\nrequire(\"./head\");\n\nvar _reduce =\n/*#__PURE__*/\nrequire(\"./internal/_reduce\");\n\nvar tail =\n/*#__PURE__*/\nrequire(\"./tail\");\n\nvar identity =\n/*#__PURE__*/\nrequire(\"./identity\");\n/**\n * Performs left-to-right function composition using transforming function. The first argument may have\n * any arity; the remaining arguments must be unary.\n *\n * **Note:** The result of pipeWith is not automatically curried. Transforming function is not used on the\n * first argument.\n *\n * @func\n * @memberOf R\n * @since v0.26.0\n * @category Function\n * @sig ((* -> *), [((a, b, ..., n) -> o), (o -> p), ..., (x -> y), (y -> z)]) -> ((a, b, ..., n) -> z)\n * @param {...Function} functions\n * @return {Function}\n * @see R.composeWith, R.pipe\n * @example\n *\n * const pipeWhileNotNil = R.pipeWith((f, res) => R.isNil(res) ? res : f(res));\n * const f = pipeWhileNotNil([Math.pow, R.negate, R.inc])\n *\n * f(3, 4); // -(3^4) + 1\n * @symb R.pipeWith(f)([g, h, i])(...args) = f(i, f(h, g(...args)))\n */\n\n\nvar pipeWith =\n/*#__PURE__*/\n_curry2(function pipeWith(xf, list) {\n if (list.length <= 0) {\n return identity;\n }\n\n var headList = head(list);\n var tailList = tail(list);\n return _arity(headList.length, function () {\n return _reduce(function (result, f) {\n return xf.call(this, f, result);\n }, headList.apply(this, arguments), tailList);\n });\n});\n\nmodule.exports = pipeWith;","var nth =\n/*#__PURE__*/\nrequire(\"./nth\");\n/**\n * Returns the first element of the given list or string. In some libraries\n * this function is named `first`.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category List\n * @sig [a] -> a | Undefined\n * @sig String -> String\n * @param {Array|String} list\n * @return {*}\n * @see R.tail, R.init, R.last\n * @example\n *\n * R.head(['fi', 'fo', 'fum']); //=> 'fi'\n * R.head([]); //=> undefined\n *\n * R.head('abc'); //=> 'a'\n * R.head(''); //=> ''\n */\n\n\nvar head =\n/*#__PURE__*/\nnth(0);\nmodule.exports = head;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _isArray =\n/*#__PURE__*/\nrequire(\"./internal/_isArray\");\n\nvar _isFunction =\n/*#__PURE__*/\nrequire(\"./internal/_isFunction\");\n\nvar _isString =\n/*#__PURE__*/\nrequire(\"./internal/_isString\");\n\nvar toString =\n/*#__PURE__*/\nrequire(\"./toString\");\n/**\n * Returns the result of concatenating the given lists or strings.\n *\n * Note: `R.concat` expects both arguments to be of the same type,\n * unlike the native `Array.prototype.concat` method. It will throw\n * an error if you `concat` an Array with a non-Array value.\n *\n * Dispatches to the `concat` method of the first argument, if present.\n * Can also concatenate two members of a [fantasy-land\n * compatible semigroup](https://github.com/fantasyland/fantasy-land#semigroup).\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category List\n * @sig [a] -> [a] -> [a]\n * @sig String -> String -> String\n * @param {Array|String} firstList The first list\n * @param {Array|String} secondList The second list\n * @return {Array|String} A list consisting of the elements of `firstList` followed by the elements of\n * `secondList`.\n *\n * @example\n *\n * R.concat('ABC', 'DEF'); // 'ABCDEF'\n * R.concat([4, 5, 6], [1, 2, 3]); //=> [4, 5, 6, 1, 2, 3]\n * R.concat([], []); //=> []\n */\n\n\nvar concat =\n/*#__PURE__*/\n_curry2(function concat(a, b) {\n if (_isArray(a)) {\n if (_isArray(b)) {\n return a.concat(b);\n }\n\n throw new TypeError(toString(b) + ' is not an array');\n }\n\n if (_isString(a)) {\n if (_isString(b)) {\n return a + b;\n }\n\n throw new TypeError(toString(b) + ' is not a string');\n }\n\n if (a != null && _isFunction(a['fantasy-land/concat'])) {\n return a['fantasy-land/concat'](b);\n }\n\n if (a != null && _isFunction(a.concat)) {\n return a.concat(b);\n }\n\n throw new TypeError(toString(a) + ' does not have a method named \"concat\" or \"fantasy-land/concat\"');\n});\n\nmodule.exports = concat;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar _toString =\n/*#__PURE__*/\nrequire(\"./internal/_toString\");\n/**\n * Returns the string representation of the given value. `eval`'ing the output\n * should result in a value equivalent to the input value. Many of the built-in\n * `toString` methods do not satisfy this requirement.\n *\n * If the given value is an `[object Object]` with a `toString` method other\n * than `Object.prototype.toString`, this method is invoked with no arguments\n * to produce the return value. This means user-defined constructor functions\n * can provide a suitable `toString` method. For example:\n *\n * function Point(x, y) {\n * this.x = x;\n * this.y = y;\n * }\n *\n * Point.prototype.toString = function() {\n * return 'new Point(' + this.x + ', ' + this.y + ')';\n * };\n *\n * R.toString(new Point(1, 2)); //=> 'new Point(1, 2)'\n *\n * @func\n * @memberOf R\n * @since v0.14.0\n * @category String\n * @sig * -> String\n * @param {*} val\n * @return {String}\n * @example\n *\n * R.toString(42); //=> '42'\n * R.toString('abc'); //=> '\"abc\"'\n * R.toString([1, 2, 3]); //=> '[1, 2, 3]'\n * R.toString({foo: 1, bar: 2, baz: 3}); //=> '{\"bar\": 2, \"baz\": 3, \"foo\": 1}'\n * R.toString(new Date('2001-02-03T04:05:06Z')); //=> 'new Date(\"2001-02-03T04:05:06.000Z\")'\n */\n\n\nvar toString =\n/*#__PURE__*/\n_curry1(function toString(val) {\n return _toString(val, []);\n});\n\nmodule.exports = toString;","var _includes =\n/*#__PURE__*/\nrequire(\"./_includes\");\n\nvar _map =\n/*#__PURE__*/\nrequire(\"./_map\");\n\nvar _quote =\n/*#__PURE__*/\nrequire(\"./_quote\");\n\nvar _toISOString =\n/*#__PURE__*/\nrequire(\"./_toISOString\");\n\nvar keys =\n/*#__PURE__*/\nrequire(\"../keys\");\n\nvar reject =\n/*#__PURE__*/\nrequire(\"../reject\");\n\nfunction _toString(x, seen) {\n var recur = function recur(y) {\n var xs = seen.concat([x]);\n return _includes(y, xs) ? '' : _toString(y, xs);\n }; // mapPairs :: (Object, [String]) -> [String]\n\n\n var mapPairs = function (obj, keys) {\n return _map(function (k) {\n return _quote(k) + ': ' + recur(obj[k]);\n }, keys.slice().sort());\n };\n\n switch (Object.prototype.toString.call(x)) {\n case '[object Arguments]':\n return '(function() { return arguments; }(' + _map(recur, x).join(', ') + '))';\n\n case '[object Array]':\n return '[' + _map(recur, x).concat(mapPairs(x, reject(function (k) {\n return /^\\d+$/.test(k);\n }, keys(x)))).join(', ') + ']';\n\n case '[object Boolean]':\n return typeof x === 'object' ? 'new Boolean(' + recur(x.valueOf()) + ')' : x.toString();\n\n case '[object Date]':\n return 'new Date(' + (isNaN(x.valueOf()) ? recur(NaN) : _quote(_toISOString(x))) + ')';\n\n case '[object Null]':\n return 'null';\n\n case '[object Number]':\n return typeof x === 'object' ? 'new Number(' + recur(x.valueOf()) + ')' : 1 / x === -Infinity ? '-0' : x.toString(10);\n\n case '[object String]':\n return typeof x === 'object' ? 'new String(' + recur(x.valueOf()) + ')' : _quote(x);\n\n case '[object Undefined]':\n return 'undefined';\n\n default:\n if (typeof x.toString === 'function') {\n var repr = x.toString();\n\n if (repr !== '[object Object]') {\n return repr;\n }\n }\n\n return '{' + mapPairs(x, keys(x)).join(', ') + '}';\n }\n}\n\nmodule.exports = _toString;","var _indexOf =\n/*#__PURE__*/\nrequire(\"./_indexOf\");\n\nfunction _includes(a, list) {\n return _indexOf(list, a, 0) >= 0;\n}\n\nmodule.exports = _includes;","var equals =\n/*#__PURE__*/\nrequire(\"../equals\");\n\nfunction _indexOf(list, a, idx) {\n var inf, item; // Array.prototype.indexOf doesn't exist below IE9\n\n if (typeof list.indexOf === 'function') {\n switch (typeof a) {\n case 'number':\n if (a === 0) {\n // manually crawl the list to distinguish between +0 and -0\n inf = 1 / a;\n\n while (idx < list.length) {\n item = list[idx];\n\n if (item === 0 && 1 / item === inf) {\n return idx;\n }\n\n idx += 1;\n }\n\n return -1;\n } else if (a !== a) {\n // NaN\n while (idx < list.length) {\n item = list[idx];\n\n if (typeof item === 'number' && item !== item) {\n return idx;\n }\n\n idx += 1;\n }\n\n return -1;\n } // non-zero numbers can utilise Set\n\n\n return list.indexOf(a, idx);\n // all these types can utilise Set\n\n case 'string':\n case 'boolean':\n case 'function':\n case 'undefined':\n return list.indexOf(a, idx);\n\n case 'object':\n if (a === null) {\n // null can utilise Set\n return list.indexOf(a, idx);\n }\n\n }\n } // anything else not covered above, defer to R.equals\n\n\n while (idx < list.length) {\n if (equals(list[idx], a)) {\n return idx;\n }\n\n idx += 1;\n }\n\n return -1;\n}\n\nmodule.exports = _indexOf;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _equals =\n/*#__PURE__*/\nrequire(\"./internal/_equals\");\n/**\n * Returns `true` if its arguments are equivalent, `false` otherwise. Handles\n * cyclical data structures.\n *\n * Dispatches symmetrically to the `equals` methods of both arguments, if\n * present.\n *\n * @func\n * @memberOf R\n * @since v0.15.0\n * @category Relation\n * @sig a -> b -> Boolean\n * @param {*} a\n * @param {*} b\n * @return {Boolean}\n * @example\n *\n * R.equals(1, 1); //=> true\n * R.equals(1, '1'); //=> false\n * R.equals([1, 2, 3], [1, 2, 3]); //=> true\n *\n * const a = {}; a.v = a;\n * const b = {}; b.v = b;\n * R.equals(a, b); //=> true\n */\n\n\nvar equals =\n/*#__PURE__*/\n_curry2(function equals(a, b) {\n return _equals(a, b, [], []);\n});\n\nmodule.exports = equals;","var _arrayFromIterator =\n/*#__PURE__*/\nrequire(\"./_arrayFromIterator\");\n\nvar _includesWith =\n/*#__PURE__*/\nrequire(\"./_includesWith\");\n\nvar _functionName =\n/*#__PURE__*/\nrequire(\"./_functionName\");\n\nvar _has =\n/*#__PURE__*/\nrequire(\"./_has\");\n\nvar _objectIs =\n/*#__PURE__*/\nrequire(\"./_objectIs\");\n\nvar keys =\n/*#__PURE__*/\nrequire(\"../keys\");\n\nvar type =\n/*#__PURE__*/\nrequire(\"../type\");\n/**\n * private _uniqContentEquals function.\n * That function is checking equality of 2 iterator contents with 2 assumptions\n * - iterators lengths are the same\n * - iterators values are unique\n *\n * false-positive result will be returned for comparision of, e.g.\n * - [1,2,3] and [1,2,3,4]\n * - [1,1,1] and [1,2,3]\n * */\n\n\nfunction _uniqContentEquals(aIterator, bIterator, stackA, stackB) {\n var a = _arrayFromIterator(aIterator);\n\n var b = _arrayFromIterator(bIterator);\n\n function eq(_a, _b) {\n return _equals(_a, _b, stackA.slice(), stackB.slice());\n } // if *a* array contains any element that is not included in *b*\n\n\n return !_includesWith(function (b, aItem) {\n return !_includesWith(eq, aItem, b);\n }, b, a);\n}\n\nfunction _equals(a, b, stackA, stackB) {\n if (_objectIs(a, b)) {\n return true;\n }\n\n var typeA = type(a);\n\n if (typeA !== type(b)) {\n return false;\n }\n\n if (a == null || b == null) {\n return false;\n }\n\n if (typeof a['fantasy-land/equals'] === 'function' || typeof b['fantasy-land/equals'] === 'function') {\n return typeof a['fantasy-land/equals'] === 'function' && a['fantasy-land/equals'](b) && typeof b['fantasy-land/equals'] === 'function' && b['fantasy-land/equals'](a);\n }\n\n if (typeof a.equals === 'function' || typeof b.equals === 'function') {\n return typeof a.equals === 'function' && a.equals(b) && typeof b.equals === 'function' && b.equals(a);\n }\n\n switch (typeA) {\n case 'Arguments':\n case 'Array':\n case 'Object':\n if (typeof a.constructor === 'function' && _functionName(a.constructor) === 'Promise') {\n return a === b;\n }\n\n break;\n\n case 'Boolean':\n case 'Number':\n case 'String':\n if (!(typeof a === typeof b && _objectIs(a.valueOf(), b.valueOf()))) {\n return false;\n }\n\n break;\n\n case 'Date':\n if (!_objectIs(a.valueOf(), b.valueOf())) {\n return false;\n }\n\n break;\n\n case 'Error':\n return a.name === b.name && a.message === b.message;\n\n case 'RegExp':\n if (!(a.source === b.source && a.global === b.global && a.ignoreCase === b.ignoreCase && a.multiline === b.multiline && a.sticky === b.sticky && a.unicode === b.unicode)) {\n return false;\n }\n\n break;\n }\n\n var idx = stackA.length - 1;\n\n while (idx >= 0) {\n if (stackA[idx] === a) {\n return stackB[idx] === b;\n }\n\n idx -= 1;\n }\n\n switch (typeA) {\n case 'Map':\n if (a.size !== b.size) {\n return false;\n }\n\n return _uniqContentEquals(a.entries(), b.entries(), stackA.concat([a]), stackB.concat([b]));\n\n case 'Set':\n if (a.size !== b.size) {\n return false;\n }\n\n return _uniqContentEquals(a.values(), b.values(), stackA.concat([a]), stackB.concat([b]));\n\n case 'Arguments':\n case 'Array':\n case 'Object':\n case 'Boolean':\n case 'Number':\n case 'String':\n case 'Date':\n case 'Error':\n case 'RegExp':\n case 'Int8Array':\n case 'Uint8Array':\n case 'Uint8ClampedArray':\n case 'Int16Array':\n case 'Uint16Array':\n case 'Int32Array':\n case 'Uint32Array':\n case 'Float32Array':\n case 'Float64Array':\n case 'ArrayBuffer':\n break;\n\n default:\n // Values of other types are only equal if identical.\n return false;\n }\n\n var keysA = keys(a);\n\n if (keysA.length !== keys(b).length) {\n return false;\n }\n\n var extendedStackA = stackA.concat([a]);\n var extendedStackB = stackB.concat([b]);\n idx = keysA.length - 1;\n\n while (idx >= 0) {\n var key = keysA[idx];\n\n if (!(_has(key, b) && _equals(b[key], a[key], extendedStackA, extendedStackB))) {\n return false;\n }\n\n idx -= 1;\n }\n\n return true;\n}\n\nmodule.exports = _equals;","function _arrayFromIterator(iter) {\n var list = [];\n var next;\n\n while (!(next = iter.next()).done) {\n list.push(next.value);\n }\n\n return list;\n}\n\nmodule.exports = _arrayFromIterator;","function _includesWith(pred, x, list) {\n var idx = 0;\n var len = list.length;\n\n while (idx < len) {\n if (pred(x, list[idx])) {\n return true;\n }\n\n idx += 1;\n }\n\n return false;\n}\n\nmodule.exports = _includesWith;","// Based on https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is\nfunction _objectIs(a, b) {\n // SameValue algorithm\n if (a === b) {\n // Steps 1-5, 7-10\n // Steps 6.b-6.e: +0 != -0\n return a !== 0 || 1 / a === 1 / b;\n } else {\n // Step 6.a: NaN == NaN\n return a !== a && b !== b;\n }\n}\n\nmodule.exports = typeof Object.is === 'function' ? Object.is : _objectIs;","function _functionName(f) {\n // String(x => x) evaluates to \"x => x\", so the pattern may not match.\n var match = String(f).match(/^function (\\w*)/);\n return match == null ? '' : match[1];\n}\n\nmodule.exports = _functionName;","function _quote(s) {\n var escaped = s.replace(/\\\\/g, '\\\\\\\\').replace(/[\\b]/g, '\\\\b') // \\b matches word boundary; [\\b] matches backspace\n .replace(/\\f/g, '\\\\f').replace(/\\n/g, '\\\\n').replace(/\\r/g, '\\\\r').replace(/\\t/g, '\\\\t').replace(/\\v/g, '\\\\v').replace(/\\0/g, '\\\\0');\n return '\"' + escaped.replace(/\"/g, '\\\\\"') + '\"';\n}\n\nmodule.exports = _quote;","var _complement =\n/*#__PURE__*/\nrequire(\"./internal/_complement\");\n\nvar _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar filter =\n/*#__PURE__*/\nrequire(\"./filter\");\n/**\n * The complement of [`filter`](#filter).\n *\n * Acts as a transducer if a transformer is given in list position. Filterable\n * objects include plain objects or any object that has a filter method such\n * as `Array`.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category List\n * @sig Filterable f => (a -> Boolean) -> f a -> f a\n * @param {Function} pred\n * @param {Array} filterable\n * @return {Array}\n * @see R.filter, R.transduce, R.addIndex\n * @example\n *\n * const isOdd = (n) => n % 2 === 1;\n *\n * R.reject(isOdd, [1, 2, 3, 4]); //=> [2, 4]\n *\n * R.reject(isOdd, {a: 1, b: 2, c: 3, d: 4}); //=> {b: 2, d: 4}\n */\n\n\nvar reject =\n/*#__PURE__*/\n_curry2(function reject(pred, filterable) {\n return filter(_complement(pred), filterable);\n});\n\nmodule.exports = reject;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _dispatchable =\n/*#__PURE__*/\nrequire(\"./internal/_dispatchable\");\n\nvar _filter =\n/*#__PURE__*/\nrequire(\"./internal/_filter\");\n\nvar _isObject =\n/*#__PURE__*/\nrequire(\"./internal/_isObject\");\n\nvar _reduce =\n/*#__PURE__*/\nrequire(\"./internal/_reduce\");\n\nvar _xfilter =\n/*#__PURE__*/\nrequire(\"./internal/_xfilter\");\n\nvar keys =\n/*#__PURE__*/\nrequire(\"./keys\");\n/**\n * Takes a predicate and a `Filterable`, and returns a new filterable of the\n * same type containing the members of the given filterable which satisfy the\n * given predicate. Filterable objects include plain objects or any object\n * that has a filter method such as `Array`.\n *\n * Dispatches to the `filter` method of the second argument, if present.\n *\n * Acts as a transducer if a transformer is given in list position.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category List\n * @sig Filterable f => (a -> Boolean) -> f a -> f a\n * @param {Function} pred\n * @param {Array} filterable\n * @return {Array} Filterable\n * @see R.reject, R.transduce, R.addIndex\n * @example\n *\n * const isEven = n => n % 2 === 0;\n *\n * R.filter(isEven, [1, 2, 3, 4]); //=> [2, 4]\n *\n * R.filter(isEven, {a: 1, b: 2, c: 3, d: 4}); //=> {b: 2, d: 4}\n */\n\n\nvar filter =\n/*#__PURE__*/\n_curry2(\n/*#__PURE__*/\n_dispatchable(['filter'], _xfilter, function (pred, filterable) {\n return _isObject(filterable) ? _reduce(function (acc, key) {\n if (pred(filterable[key])) {\n acc[key] = filterable[key];\n }\n\n return acc;\n }, {}, keys(filterable)) : // else\n _filter(pred, filterable);\n}));\n\nmodule.exports = filter;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./_curry2\");\n\nvar _xfBase =\n/*#__PURE__*/\nrequire(\"./_xfBase\");\n\nvar XFilter =\n/*#__PURE__*/\nfunction () {\n function XFilter(f, xf) {\n this.xf = xf;\n this.f = f;\n }\n\n XFilter.prototype['@@transducer/init'] = _xfBase.init;\n XFilter.prototype['@@transducer/result'] = _xfBase.result;\n\n XFilter.prototype['@@transducer/step'] = function (result, input) {\n return this.f(input) ? this.xf['@@transducer/step'](result, input) : result;\n };\n\n return XFilter;\n}();\n\nvar _xfilter =\n/*#__PURE__*/\n_curry2(function _xfilter(f, xf) {\n return new XFilter(f, xf);\n});\n\nmodule.exports = _xfilter;","function _filter(fn, list) {\n var idx = 0;\n var len = list.length;\n var result = [];\n\n while (idx < len) {\n if (fn(list[idx])) {\n result[result.length] = list[idx];\n }\n\n idx += 1;\n }\n\n return result;\n}\n\nmodule.exports = _filter;","function _complement(f) {\n return function () {\n return !f.apply(this, arguments);\n };\n}\n\nmodule.exports = _complement;","/**\n * Polyfill from .\n */\nvar pad = function pad(n) {\n return (n < 10 ? '0' : '') + n;\n};\n\nvar _toISOString = typeof Date.prototype.toISOString === 'function' ? function _toISOString(d) {\n return d.toISOString();\n} : function _toISOString(d) {\n return d.getUTCFullYear() + '-' + pad(d.getUTCMonth() + 1) + '-' + pad(d.getUTCDate()) + 'T' + pad(d.getUTCHours()) + ':' + pad(d.getUTCMinutes()) + ':' + pad(d.getUTCSeconds()) + '.' + (d.getUTCMilliseconds() / 1000).toFixed(3).slice(2, 5) + 'Z';\n};\n\nmodule.exports = _toISOString;","var _arity =\n/*#__PURE__*/\nrequire(\"./internal/_arity\");\n\nvar _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar map =\n/*#__PURE__*/\nrequire(\"./map\");\n\nvar max =\n/*#__PURE__*/\nrequire(\"./max\");\n\nvar reduce =\n/*#__PURE__*/\nrequire(\"./reduce\");\n/**\n * Returns a function, `fn`, which encapsulates `if/else, if/else, ...` logic.\n * `R.cond` takes a list of [predicate, transformer] pairs. All of the arguments\n * to `fn` are applied to each of the predicates in turn until one returns a\n * \"truthy\" value, at which point `fn` returns the result of applying its\n * arguments to the corresponding transformer. If none of the predicates\n * matches, `fn` returns undefined.\n *\n * @func\n * @memberOf R\n * @since v0.6.0\n * @category Logic\n * @sig [[(*... -> Boolean),(*... -> *)]] -> (*... -> *)\n * @param {Array} pairs A list of [predicate, transformer]\n * @return {Function}\n * @see R.ifElse, R.unless, R.when\n * @example\n *\n * const fn = R.cond([\n * [R.equals(0), R.always('water freezes at 0°C')],\n * [R.equals(100), R.always('water boils at 100°C')],\n * [R.T, temp => 'nothing special happens at ' + temp + '°C']\n * ]);\n * fn(0); //=> 'water freezes at 0°C'\n * fn(50); //=> 'nothing special happens at 50°C'\n * fn(100); //=> 'water boils at 100°C'\n */\n\n\nvar cond =\n/*#__PURE__*/\n_curry1(function cond(pairs) {\n var arity = reduce(max, 0, map(function (pair) {\n return pair[0].length;\n }, pairs));\n return _arity(arity, function () {\n var idx = 0;\n\n while (idx < pairs.length) {\n if (pairs[idx][0].apply(this, arguments)) {\n return pairs[idx][1].apply(this, arguments);\n }\n\n idx += 1;\n }\n });\n});\n\nmodule.exports = cond;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar constructN =\n/*#__PURE__*/\nrequire(\"./constructN\");\n/**\n * Wraps a constructor function inside a curried function that can be called\n * with the same arguments and returns the same type.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Function\n * @sig (* -> {*}) -> (* -> {*})\n * @param {Function} fn The constructor function to wrap.\n * @return {Function} A wrapped, curried constructor function.\n * @see R.invoker\n * @example\n *\n * // Constructor function\n * function Animal(kind) {\n * this.kind = kind;\n * };\n * Animal.prototype.sighting = function() {\n * return \"It's a \" + this.kind + \"!\";\n * }\n *\n * const AnimalConstructor = R.construct(Animal)\n *\n * // Notice we no longer need the 'new' keyword:\n * AnimalConstructor('Pig'); //=> {\"kind\": \"Pig\", \"sighting\": function (){...}};\n *\n * const animalTypes = [\"Lion\", \"Tiger\", \"Bear\"];\n * const animalSighting = R.invoker(0, 'sighting');\n * const sightNewAnimal = R.compose(animalSighting, AnimalConstructor);\n * R.map(sightNewAnimal, animalTypes); //=> [\"It's a Lion!\", \"It's a Tiger!\", \"It's a Bear!\"]\n */\n\n\nvar construct =\n/*#__PURE__*/\n_curry1(function construct(Fn) {\n return constructN(Fn.length, Fn);\n});\n\nmodule.exports = construct;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar curry =\n/*#__PURE__*/\nrequire(\"./curry\");\n\nvar nAry =\n/*#__PURE__*/\nrequire(\"./nAry\");\n/**\n * Wraps a constructor function inside a curried function that can be called\n * with the same arguments and returns the same type. The arity of the function\n * returned is specified to allow using variadic constructor functions.\n *\n * @func\n * @memberOf R\n * @since v0.4.0\n * @category Function\n * @sig Number -> (* -> {*}) -> (* -> {*})\n * @param {Number} n The arity of the constructor function.\n * @param {Function} Fn The constructor function to wrap.\n * @return {Function} A wrapped, curried constructor function.\n * @example\n *\n * // Variadic Constructor function\n * function Salad() {\n * this.ingredients = arguments;\n * }\n *\n * Salad.prototype.recipe = function() {\n * const instructions = R.map(ingredient => 'Add a dollop of ' + ingredient, this.ingredients);\n * return R.join('\\n', instructions);\n * };\n *\n * const ThreeLayerSalad = R.constructN(3, Salad);\n *\n * // Notice we no longer need the 'new' keyword, and the constructor is curried for 3 arguments.\n * const salad = ThreeLayerSalad('Mayonnaise')('Potato Chips')('Ketchup');\n *\n * console.log(salad.recipe());\n * // Add a dollop of Mayonnaise\n * // Add a dollop of Potato Chips\n * // Add a dollop of Ketchup\n */\n\n\nvar constructN =\n/*#__PURE__*/\n_curry2(function constructN(n, Fn) {\n if (n > 10) {\n throw new Error('Constructor with greater than ten arguments');\n }\n\n if (n === 0) {\n return function () {\n return new Fn();\n };\n }\n\n return curry(nAry(n, function ($0, $1, $2, $3, $4, $5, $6, $7, $8, $9) {\n switch (arguments.length) {\n case 1:\n return new Fn($0);\n\n case 2:\n return new Fn($0, $1);\n\n case 3:\n return new Fn($0, $1, $2);\n\n case 4:\n return new Fn($0, $1, $2, $3);\n\n case 5:\n return new Fn($0, $1, $2, $3, $4);\n\n case 6:\n return new Fn($0, $1, $2, $3, $4, $5);\n\n case 7:\n return new Fn($0, $1, $2, $3, $4, $5, $6);\n\n case 8:\n return new Fn($0, $1, $2, $3, $4, $5, $6, $7);\n\n case 9:\n return new Fn($0, $1, $2, $3, $4, $5, $6, $7, $8);\n\n case 10:\n return new Fn($0, $1, $2, $3, $4, $5, $6, $7, $8, $9);\n }\n }));\n});\n\nmodule.exports = constructN;","var _includes =\n/*#__PURE__*/\nrequire(\"./internal/_includes\");\n\nvar _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Returns `true` if the specified value is equal, in [`R.equals`](#equals)\n * terms, to at least one element of the given list; `false` otherwise.\n * Works also with strings.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category List\n * @sig a -> [a] -> Boolean\n * @param {Object} a The item to compare against.\n * @param {Array} list The array to consider.\n * @return {Boolean} `true` if an equivalent item is in the list, `false` otherwise.\n * @see R.includes\n * @deprecated since v0.26.0\n * @example\n *\n * R.contains(3, [1, 2, 3]); //=> true\n * R.contains(4, [1, 2, 3]); //=> false\n * R.contains({ name: 'Fred' }, [{ name: 'Fred' }]); //=> true\n * R.contains([42], [[42]]); //=> true\n * R.contains('ba', 'banana'); //=>true\n */\n\n\nvar contains =\n/*#__PURE__*/\n_curry2(_includes);\n\nmodule.exports = contains;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _map =\n/*#__PURE__*/\nrequire(\"./internal/_map\");\n\nvar curryN =\n/*#__PURE__*/\nrequire(\"./curryN\");\n\nvar max =\n/*#__PURE__*/\nrequire(\"./max\");\n\nvar pluck =\n/*#__PURE__*/\nrequire(\"./pluck\");\n\nvar reduce =\n/*#__PURE__*/\nrequire(\"./reduce\");\n/**\n * Accepts a converging function and a list of branching functions and returns\n * a new function. The arity of the new function is the same as the arity of\n * the longest branching function. When invoked, this new function is applied\n * to some arguments, and each branching function is applied to those same\n * arguments. The results of each branching function are passed as arguments\n * to the converging function to produce the return value.\n *\n * @func\n * @memberOf R\n * @since v0.4.2\n * @category Function\n * @sig ((x1, x2, ...) -> z) -> [((a, b, ...) -> x1), ((a, b, ...) -> x2), ...] -> (a -> b -> ... -> z)\n * @param {Function} after A function. `after` will be invoked with the return values of\n * `fn1` and `fn2` as its arguments.\n * @param {Array} functions A list of functions.\n * @return {Function} A new function.\n * @see R.useWith\n * @example\n *\n * const average = R.converge(R.divide, [R.sum, R.length])\n * average([1, 2, 3, 4, 5, 6, 7]) //=> 4\n *\n * const strangeConcat = R.converge(R.concat, [R.toUpper, R.toLower])\n * strangeConcat(\"Yodel\") //=> \"YODELyodel\"\n *\n * @symb R.converge(f, [g, h])(a, b) = f(g(a, b), h(a, b))\n */\n\n\nvar converge =\n/*#__PURE__*/\n_curry2(function converge(after, fns) {\n return curryN(reduce(max, 0, pluck('length', fns)), function () {\n var args = arguments;\n var context = this;\n return after.apply(context, _map(function (fn) {\n return fn.apply(context, args);\n }, fns));\n });\n});\n\nmodule.exports = converge;","var reduceBy =\n/*#__PURE__*/\nrequire(\"./reduceBy\");\n/**\n * Counts the elements of a list according to how many match each value of a\n * key generated by the supplied function. Returns an object mapping the keys\n * produced by `fn` to the number of occurrences in the list. Note that all\n * keys are coerced to strings because of how JavaScript objects work.\n *\n * Acts as a transducer if a transformer is given in list position.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Relation\n * @sig (a -> String) -> [a] -> {*}\n * @param {Function} fn The function used to map values to keys.\n * @param {Array} list The list to count elements from.\n * @return {Object} An object mapping keys to number of occurrences in the list.\n * @example\n *\n * const numbers = [1.0, 1.1, 1.2, 2.0, 3.0, 2.2];\n * R.countBy(Math.floor)(numbers); //=> {'1': 3, '2': 2, '3': 1}\n *\n * const letters = ['a', 'b', 'A', 'a', 'B', 'c'];\n * R.countBy(R.toLower)(letters); //=> {'a': 3, 'b': 2, 'c': 1}\n */\n\n\nvar countBy =\n/*#__PURE__*/\nreduceBy(function (acc, elem) {\n return acc + 1;\n}, 0);\nmodule.exports = countBy;","var _clone =\n/*#__PURE__*/\nrequire(\"./internal/_clone\");\n\nvar _curryN =\n/*#__PURE__*/\nrequire(\"./internal/_curryN\");\n\nvar _dispatchable =\n/*#__PURE__*/\nrequire(\"./internal/_dispatchable\");\n\nvar _has =\n/*#__PURE__*/\nrequire(\"./internal/_has\");\n\nvar _reduce =\n/*#__PURE__*/\nrequire(\"./internal/_reduce\");\n\nvar _xreduceBy =\n/*#__PURE__*/\nrequire(\"./internal/_xreduceBy\");\n/**\n * Groups the elements of the list according to the result of calling\n * the String-returning function `keyFn` on each element and reduces the elements\n * of each group to a single value via the reducer function `valueFn`.\n *\n * This function is basically a more general [`groupBy`](#groupBy) function.\n *\n * Acts as a transducer if a transformer is given in list position.\n *\n * @func\n * @memberOf R\n * @since v0.20.0\n * @category List\n * @sig ((a, b) -> a) -> a -> (b -> String) -> [b] -> {String: a}\n * @param {Function} valueFn The function that reduces the elements of each group to a single\n * value. Receives two values, accumulator for a particular group and the current element.\n * @param {*} acc The (initial) accumulator value for each group.\n * @param {Function} keyFn The function that maps the list's element into a key.\n * @param {Array} list The array to group.\n * @return {Object} An object with the output of `keyFn` for keys, mapped to the output of\n * `valueFn` for elements which produced that key when passed to `keyFn`.\n * @see R.groupBy, R.reduce\n * @example\n *\n * const groupNames = (acc, {name}) => acc.concat(name)\n * const toGrade = ({score}) =>\n * score < 65 ? 'F' :\n * score < 70 ? 'D' :\n * score < 80 ? 'C' :\n * score < 90 ? 'B' : 'A'\n *\n * var students = [\n * {name: 'Abby', score: 83},\n * {name: 'Bart', score: 62},\n * {name: 'Curt', score: 88},\n * {name: 'Dora', score: 92},\n * ]\n *\n * reduceBy(groupNames, [], toGrade, students)\n * //=> {\"A\": [\"Dora\"], \"B\": [\"Abby\", \"Curt\"], \"F\": [\"Bart\"]}\n */\n\n\nvar reduceBy =\n/*#__PURE__*/\n_curryN(4, [],\n/*#__PURE__*/\n_dispatchable([], _xreduceBy, function reduceBy(valueFn, valueAcc, keyFn, list) {\n return _reduce(function (acc, elt) {\n var key = keyFn(elt);\n acc[key] = valueFn(_has(key, acc) ? acc[key] : _clone(valueAcc, [], [], false), elt);\n return acc;\n }, {}, list);\n}));\n\nmodule.exports = reduceBy;","var _curryN =\n/*#__PURE__*/\nrequire(\"./_curryN\");\n\nvar _has =\n/*#__PURE__*/\nrequire(\"./_has\");\n\nvar _xfBase =\n/*#__PURE__*/\nrequire(\"./_xfBase\");\n\nvar XReduceBy =\n/*#__PURE__*/\nfunction () {\n function XReduceBy(valueFn, valueAcc, keyFn, xf) {\n this.valueFn = valueFn;\n this.valueAcc = valueAcc;\n this.keyFn = keyFn;\n this.xf = xf;\n this.inputs = {};\n }\n\n XReduceBy.prototype['@@transducer/init'] = _xfBase.init;\n\n XReduceBy.prototype['@@transducer/result'] = function (result) {\n var key;\n\n for (key in this.inputs) {\n if (_has(key, this.inputs)) {\n result = this.xf['@@transducer/step'](result, this.inputs[key]);\n\n if (result['@@transducer/reduced']) {\n result = result['@@transducer/value'];\n break;\n }\n }\n }\n\n this.inputs = null;\n return this.xf['@@transducer/result'](result);\n };\n\n XReduceBy.prototype['@@transducer/step'] = function (result, input) {\n var key = this.keyFn(input);\n this.inputs[key] = this.inputs[key] || [key, this.valueAcc];\n this.inputs[key][1] = this.valueFn(this.inputs[key][1], input);\n return result;\n };\n\n return XReduceBy;\n}();\n\nvar _xreduceBy =\n/*#__PURE__*/\n_curryN(4, [], function _xreduceBy(valueFn, valueAcc, keyFn, xf) {\n return new XReduceBy(valueFn, valueAcc, keyFn, xf);\n});\n\nmodule.exports = _xreduceBy;","var add =\n/*#__PURE__*/\nrequire(\"./add\");\n/**\n * Decrements its argument.\n *\n * @func\n * @memberOf R\n * @since v0.9.0\n * @category Math\n * @sig Number -> Number\n * @param {Number} n\n * @return {Number} n - 1\n * @see R.inc\n * @example\n *\n * R.dec(42); //=> 41\n */\n\n\nvar dec =\n/*#__PURE__*/\nadd(-1);\nmodule.exports = dec;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Returns the second argument if it is not `null`, `undefined` or `NaN`;\n * otherwise the first argument is returned.\n *\n * @func\n * @memberOf R\n * @since v0.10.0\n * @category Logic\n * @sig a -> b -> a | b\n * @param {a} default The default value.\n * @param {b} val `val` will be returned instead of `default` unless `val` is `null`, `undefined` or `NaN`.\n * @return {*} The second value if it is not `null`, `undefined` or `NaN`, otherwise the default value\n * @example\n *\n * const defaultTo42 = R.defaultTo(42);\n *\n * defaultTo42(null); //=> 42\n * defaultTo42(undefined); //=> 42\n * defaultTo42(false); //=> false\n * defaultTo42('Ramda'); //=> 'Ramda'\n * // parseInt('string') results in NaN\n * defaultTo42(parseInt('string')); //=> 42\n */\n\n\nvar defaultTo =\n/*#__PURE__*/\n_curry2(function defaultTo(d, v) {\n return v == null || v !== v ? d : v;\n});\n\nmodule.exports = defaultTo;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n/**\n * Makes a descending comparator function out of a function that returns a value\n * that can be compared with `<` and `>`.\n *\n * @func\n * @memberOf R\n * @since v0.23.0\n * @category Function\n * @sig Ord b => (a -> b) -> a -> a -> Number\n * @param {Function} fn A function of arity one that returns a value that can be compared\n * @param {*} a The first item to be compared.\n * @param {*} b The second item to be compared.\n * @return {Number} `-1` if fn(a) > fn(b), `1` if fn(b) > fn(a), otherwise `0`\n * @see R.ascend\n * @example\n *\n * const byAge = R.descend(R.prop('age'));\n * const people = [\n * { name: 'Emma', age: 70 },\n * { name: 'Peter', age: 78 },\n * { name: 'Mikhail', age: 62 },\n * ];\n * const peopleByOldestFirst = R.sort(byAge, people);\n * //=> [{ name: 'Peter', age: 78 }, { name: 'Emma', age: 70 }, { name: 'Mikhail', age: 62 }]\n */\n\n\nvar descend =\n/*#__PURE__*/\n_curry3(function descend(fn, a, b) {\n var aa = fn(a);\n var bb = fn(b);\n return aa > bb ? -1 : aa < bb ? 1 : 0;\n});\n\nmodule.exports = descend;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _Set =\n/*#__PURE__*/\nrequire(\"./internal/_Set\");\n/**\n * Finds the set (i.e. no duplicates) of all elements in the first list not\n * contained in the second list. Objects and Arrays are compared in terms of\n * value equality, not reference equality.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Relation\n * @sig [*] -> [*] -> [*]\n * @param {Array} list1 The first list.\n * @param {Array} list2 The second list.\n * @return {Array} The elements in `list1` that are not in `list2`.\n * @see R.differenceWith, R.symmetricDifference, R.symmetricDifferenceWith, R.without\n * @example\n *\n * R.difference([1,2,3,4], [7,6,5,4,3]); //=> [1,2]\n * R.difference([7,6,5,4,3], [1,2,3,4]); //=> [7,6,5]\n * R.difference([{a: 1}, {b: 2}], [{a: 1}, {c: 3}]) //=> [{b: 2}]\n */\n\n\nvar difference =\n/*#__PURE__*/\n_curry2(function difference(first, second) {\n var out = [];\n var idx = 0;\n var firstLen = first.length;\n var secondLen = second.length;\n var toFilterOut = new _Set();\n\n for (var i = 0; i < secondLen; i += 1) {\n toFilterOut.add(second[i]);\n }\n\n while (idx < firstLen) {\n if (toFilterOut.add(first[idx])) {\n out[out.length] = first[idx];\n }\n\n idx += 1;\n }\n\n return out;\n});\n\nmodule.exports = difference;","var _includes =\n/*#__PURE__*/\nrequire(\"./_includes\");\n\nvar _Set =\n/*#__PURE__*/\nfunction () {\n function _Set() {\n /* globals Set */\n this._nativeSet = typeof Set === 'function' ? new Set() : null;\n this._items = {};\n }\n\n // until we figure out why jsdoc chokes on this\n // @param item The item to add to the Set\n // @returns {boolean} true if the item did not exist prior, otherwise false\n //\n _Set.prototype.add = function (item) {\n return !hasOrAdd(item, true, this);\n }; //\n // @param item The item to check for existence in the Set\n // @returns {boolean} true if the item exists in the Set, otherwise false\n //\n\n\n _Set.prototype.has = function (item) {\n return hasOrAdd(item, false, this);\n }; //\n // Combines the logic for checking whether an item is a member of the set and\n // for adding a new item to the set.\n //\n // @param item The item to check or add to the Set instance.\n // @param shouldAdd If true, the item will be added to the set if it doesn't\n // already exist.\n // @param set The set instance to check or add to.\n // @return {boolean} true if the item already existed, otherwise false.\n //\n\n\n return _Set;\n}();\n\nfunction hasOrAdd(item, shouldAdd, set) {\n var type = typeof item;\n var prevSize, newSize;\n\n switch (type) {\n case 'string':\n case 'number':\n // distinguish between +0 and -0\n if (item === 0 && 1 / item === -Infinity) {\n if (set._items['-0']) {\n return true;\n } else {\n if (shouldAdd) {\n set._items['-0'] = true;\n }\n\n return false;\n }\n } // these types can all utilise the native Set\n\n\n if (set._nativeSet !== null) {\n if (shouldAdd) {\n prevSize = set._nativeSet.size;\n\n set._nativeSet.add(item);\n\n newSize = set._nativeSet.size;\n return newSize === prevSize;\n } else {\n return set._nativeSet.has(item);\n }\n } else {\n if (!(type in set._items)) {\n if (shouldAdd) {\n set._items[type] = {};\n set._items[type][item] = true;\n }\n\n return false;\n } else if (item in set._items[type]) {\n return true;\n } else {\n if (shouldAdd) {\n set._items[type][item] = true;\n }\n\n return false;\n }\n }\n\n case 'boolean':\n // set._items['boolean'] holds a two element array\n // representing [ falseExists, trueExists ]\n if (type in set._items) {\n var bIdx = item ? 1 : 0;\n\n if (set._items[type][bIdx]) {\n return true;\n } else {\n if (shouldAdd) {\n set._items[type][bIdx] = true;\n }\n\n return false;\n }\n } else {\n if (shouldAdd) {\n set._items[type] = item ? [false, true] : [true, false];\n }\n\n return false;\n }\n\n case 'function':\n // compare functions for reference equality\n if (set._nativeSet !== null) {\n if (shouldAdd) {\n prevSize = set._nativeSet.size;\n\n set._nativeSet.add(item);\n\n newSize = set._nativeSet.size;\n return newSize === prevSize;\n } else {\n return set._nativeSet.has(item);\n }\n } else {\n if (!(type in set._items)) {\n if (shouldAdd) {\n set._items[type] = [item];\n }\n\n return false;\n }\n\n if (!_includes(item, set._items[type])) {\n if (shouldAdd) {\n set._items[type].push(item);\n }\n\n return false;\n }\n\n return true;\n }\n\n case 'undefined':\n if (set._items[type]) {\n return true;\n } else {\n if (shouldAdd) {\n set._items[type] = true;\n }\n\n return false;\n }\n\n case 'object':\n if (item === null) {\n if (!set._items['null']) {\n if (shouldAdd) {\n set._items['null'] = true;\n }\n\n return false;\n }\n\n return true;\n }\n\n /* falls through */\n\n default:\n // reduce the search size of heterogeneous sets by creating buckets\n // for each type.\n type = Object.prototype.toString.call(item);\n\n if (!(type in set._items)) {\n if (shouldAdd) {\n set._items[type] = [item];\n }\n\n return false;\n } // scan through all previously applied items\n\n\n if (!_includes(item, set._items[type])) {\n if (shouldAdd) {\n set._items[type].push(item);\n }\n\n return false;\n }\n\n return true;\n }\n} // A simple Set type that honours R.equals semantics\n\n\nmodule.exports = _Set;","var _includesWith =\n/*#__PURE__*/\nrequire(\"./internal/_includesWith\");\n\nvar _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n/**\n * Finds the set (i.e. no duplicates) of all elements in the first list not\n * contained in the second list. Duplication is determined according to the\n * value returned by applying the supplied predicate to two list elements.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Relation\n * @sig ((a, a) -> Boolean) -> [a] -> [a] -> [a]\n * @param {Function} pred A predicate used to test whether two items are equal.\n * @param {Array} list1 The first list.\n * @param {Array} list2 The second list.\n * @return {Array} The elements in `list1` that are not in `list2`.\n * @see R.difference, R.symmetricDifference, R.symmetricDifferenceWith\n * @example\n *\n * const cmp = (x, y) => x.a === y.a;\n * const l1 = [{a: 1}, {a: 2}, {a: 3}];\n * const l2 = [{a: 3}, {a: 4}];\n * R.differenceWith(cmp, l1, l2); //=> [{a: 1}, {a: 2}]\n */\n\n\nvar differenceWith =\n/*#__PURE__*/\n_curry3(function differenceWith(pred, first, second) {\n var out = [];\n var idx = 0;\n var firstLen = first.length;\n\n while (idx < firstLen) {\n if (!_includesWith(pred, first[idx], second) && !_includesWith(pred, first[idx], out)) {\n out.push(first[idx]);\n }\n\n idx += 1;\n }\n\n return out;\n});\n\nmodule.exports = differenceWith;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Returns a new object that does not contain a `prop` property.\n *\n * @func\n * @memberOf R\n * @since v0.10.0\n * @category Object\n * @sig String -> {k: v} -> {k: v}\n * @param {String} prop The name of the property to dissociate\n * @param {Object} obj The object to clone\n * @return {Object} A new object equivalent to the original but without the specified property\n * @see R.assoc, R.omit\n * @example\n *\n * R.dissoc('b', {a: 1, b: 2, c: 3}); //=> {a: 1, c: 3}\n */\n\n\nvar dissoc =\n/*#__PURE__*/\n_curry2(function dissoc(prop, obj) {\n var result = {};\n\n for (var p in obj) {\n result[p] = obj[p];\n }\n\n delete result[prop];\n return result;\n});\n\nmodule.exports = dissoc;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _isInteger =\n/*#__PURE__*/\nrequire(\"./internal/_isInteger\");\n\nvar _isArray =\n/*#__PURE__*/\nrequire(\"./internal/_isArray\");\n\nvar assoc =\n/*#__PURE__*/\nrequire(\"./assoc\");\n\nvar dissoc =\n/*#__PURE__*/\nrequire(\"./dissoc\");\n\nvar remove =\n/*#__PURE__*/\nrequire(\"./remove\");\n\nvar update =\n/*#__PURE__*/\nrequire(\"./update\");\n/**\n * Makes a shallow clone of an object, omitting the property at the given path.\n * Note that this copies and flattens prototype properties onto the new object\n * as well. All non-primitive properties are copied by reference.\n *\n * @func\n * @memberOf R\n * @since v0.11.0\n * @category Object\n * @typedefn Idx = String | Int\n * @sig [Idx] -> {k: v} -> {k: v}\n * @param {Array} path The path to the value to omit\n * @param {Object} obj The object to clone\n * @return {Object} A new object without the property at path\n * @see R.assocPath\n * @example\n *\n * R.dissocPath(['a', 'b', 'c'], {a: {b: {c: 42}}}); //=> {a: {b: {}}}\n */\n\n\nvar dissocPath =\n/*#__PURE__*/\n_curry2(function dissocPath(path, obj) {\n switch (path.length) {\n case 0:\n return obj;\n\n case 1:\n return _isInteger(path[0]) && _isArray(obj) ? remove(path[0], 1, obj) : dissoc(path[0], obj);\n\n default:\n var head = path[0];\n var tail = Array.prototype.slice.call(path, 1);\n\n if (obj[head] == null) {\n return obj;\n } else if (_isInteger(head) && _isArray(obj)) {\n return update(head, dissocPath(tail, obj[head]), obj);\n } else {\n return assoc(head, dissocPath(tail, obj[head]), obj);\n }\n\n }\n});\n\nmodule.exports = dissocPath;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n/**\n * Removes the sub-list of `list` starting at index `start` and containing\n * `count` elements. _Note that this is not destructive_: it returns a copy of\n * the list with the changes.\n * No lists have been harmed in the application of this function.\n *\n * @func\n * @memberOf R\n * @since v0.2.2\n * @category List\n * @sig Number -> Number -> [a] -> [a]\n * @param {Number} start The position to start removing elements\n * @param {Number} count The number of elements to remove\n * @param {Array} list The list to remove from\n * @return {Array} A new Array with `count` elements from `start` removed.\n * @see R.without\n * @example\n *\n * R.remove(2, 3, [1,2,3,4,5,6,7,8]); //=> [1,2,6,7,8]\n */\n\n\nvar remove =\n/*#__PURE__*/\n_curry3(function remove(start, count, list) {\n var result = Array.prototype.slice.call(list, 0);\n result.splice(start, count);\n return result;\n});\n\nmodule.exports = remove;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n\nvar adjust =\n/*#__PURE__*/\nrequire(\"./adjust\");\n\nvar always =\n/*#__PURE__*/\nrequire(\"./always\");\n/**\n * Returns a new copy of the array with the element at the provided index\n * replaced with the given value.\n *\n * @func\n * @memberOf R\n * @since v0.14.0\n * @category List\n * @sig Number -> a -> [a] -> [a]\n * @param {Number} idx The index to update.\n * @param {*} x The value to exist at the given index of the returned array.\n * @param {Array|Arguments} list The source array-like object to be updated.\n * @return {Array} A copy of `list` with the value at index `idx` replaced with `x`.\n * @see R.adjust\n * @example\n *\n * R.update(1, '_', ['a', 'b', 'c']); //=> ['a', '_', 'c']\n * R.update(-1, '_', ['a', 'b', 'c']); //=> ['a', 'b', '_']\n * @symb R.update(-1, a, [b, c]) = [b, a]\n * @symb R.update(0, a, [b, c]) = [a, c]\n * @symb R.update(1, a, [b, c]) = [b, a]\n */\n\n\nvar update =\n/*#__PURE__*/\n_curry3(function update(idx, x, list) {\n return adjust(idx, always(x), list);\n});\n\nmodule.exports = update;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Divides two numbers. Equivalent to `a / b`.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Math\n * @sig Number -> Number -> Number\n * @param {Number} a The first value.\n * @param {Number} b The second value.\n * @return {Number} The result of `a / b`.\n * @see R.multiply\n * @example\n *\n * R.divide(71, 100); //=> 0.71\n *\n * const half = R.divide(R.__, 2);\n * half(42); //=> 21\n *\n * const reciprocal = R.divide(1);\n * reciprocal(4); //=> 0.25\n */\n\n\nvar divide =\n/*#__PURE__*/\n_curry2(function divide(a, b) {\n return a / b;\n});\n\nmodule.exports = divide;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _dispatchable =\n/*#__PURE__*/\nrequire(\"./internal/_dispatchable\");\n\nvar _xdrop =\n/*#__PURE__*/\nrequire(\"./internal/_xdrop\");\n\nvar slice =\n/*#__PURE__*/\nrequire(\"./slice\");\n/**\n * Returns all but the first `n` elements of the given list, string, or\n * transducer/transformer (or object with a `drop` method).\n *\n * Dispatches to the `drop` method of the second argument, if present.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category List\n * @sig Number -> [a] -> [a]\n * @sig Number -> String -> String\n * @param {Number} n\n * @param {*} list\n * @return {*} A copy of list without the first `n` elements\n * @see R.take, R.transduce, R.dropLast, R.dropWhile\n * @example\n *\n * R.drop(1, ['foo', 'bar', 'baz']); //=> ['bar', 'baz']\n * R.drop(2, ['foo', 'bar', 'baz']); //=> ['baz']\n * R.drop(3, ['foo', 'bar', 'baz']); //=> []\n * R.drop(4, ['foo', 'bar', 'baz']); //=> []\n * R.drop(3, 'ramda'); //=> 'da'\n */\n\n\nvar drop =\n/*#__PURE__*/\n_curry2(\n/*#__PURE__*/\n_dispatchable(['drop'], _xdrop, function drop(n, xs) {\n return slice(Math.max(0, n), Infinity, xs);\n}));\n\nmodule.exports = drop;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./_curry2\");\n\nvar _xfBase =\n/*#__PURE__*/\nrequire(\"./_xfBase\");\n\nvar XDrop =\n/*#__PURE__*/\nfunction () {\n function XDrop(n, xf) {\n this.xf = xf;\n this.n = n;\n }\n\n XDrop.prototype['@@transducer/init'] = _xfBase.init;\n XDrop.prototype['@@transducer/result'] = _xfBase.result;\n\n XDrop.prototype['@@transducer/step'] = function (result, input) {\n if (this.n > 0) {\n this.n -= 1;\n return result;\n }\n\n return this.xf['@@transducer/step'](result, input);\n };\n\n return XDrop;\n}();\n\nvar _xdrop =\n/*#__PURE__*/\n_curry2(function _xdrop(n, xf) {\n return new XDrop(n, xf);\n});\n\nmodule.exports = _xdrop;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _dispatchable =\n/*#__PURE__*/\nrequire(\"./internal/_dispatchable\");\n\nvar _dropLast =\n/*#__PURE__*/\nrequire(\"./internal/_dropLast\");\n\nvar _xdropLast =\n/*#__PURE__*/\nrequire(\"./internal/_xdropLast\");\n/**\n * Returns a list containing all but the last `n` elements of the given `list`.\n *\n * Acts as a transducer if a transformer is given in list position.\n *\n * @func\n * @memberOf R\n * @since v0.16.0\n * @category List\n * @sig Number -> [a] -> [a]\n * @sig Number -> String -> String\n * @param {Number} n The number of elements of `list` to skip.\n * @param {Array} list The list of elements to consider.\n * @return {Array} A copy of the list with only the first `list.length - n` elements\n * @see R.takeLast, R.drop, R.dropWhile, R.dropLastWhile\n * @example\n *\n * R.dropLast(1, ['foo', 'bar', 'baz']); //=> ['foo', 'bar']\n * R.dropLast(2, ['foo', 'bar', 'baz']); //=> ['foo']\n * R.dropLast(3, ['foo', 'bar', 'baz']); //=> []\n * R.dropLast(4, ['foo', 'bar', 'baz']); //=> []\n * R.dropLast(3, 'ramda'); //=> 'ra'\n */\n\n\nvar dropLast =\n/*#__PURE__*/\n_curry2(\n/*#__PURE__*/\n_dispatchable([], _xdropLast, _dropLast));\n\nmodule.exports = dropLast;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./_curry2\");\n\nvar _xfBase =\n/*#__PURE__*/\nrequire(\"./_xfBase\");\n\nvar XDropLast =\n/*#__PURE__*/\nfunction () {\n function XDropLast(n, xf) {\n this.xf = xf;\n this.pos = 0;\n this.full = false;\n this.acc = new Array(n);\n }\n\n XDropLast.prototype['@@transducer/init'] = _xfBase.init;\n\n XDropLast.prototype['@@transducer/result'] = function (result) {\n this.acc = null;\n return this.xf['@@transducer/result'](result);\n };\n\n XDropLast.prototype['@@transducer/step'] = function (result, input) {\n if (this.full) {\n result = this.xf['@@transducer/step'](result, this.acc[this.pos]);\n }\n\n this.store(input);\n return result;\n };\n\n XDropLast.prototype.store = function (input) {\n this.acc[this.pos] = input;\n this.pos += 1;\n\n if (this.pos === this.acc.length) {\n this.pos = 0;\n this.full = true;\n }\n };\n\n return XDropLast;\n}();\n\nvar _xdropLast =\n/*#__PURE__*/\n_curry2(function _xdropLast(n, xf) {\n return new XDropLast(n, xf);\n});\n\nmodule.exports = _xdropLast;","var take =\n/*#__PURE__*/\nrequire(\"../take\");\n\nfunction dropLast(n, xs) {\n return take(n < xs.length ? xs.length - n : 0, xs);\n}\n\nmodule.exports = dropLast;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _dispatchable =\n/*#__PURE__*/\nrequire(\"./internal/_dispatchable\");\n\nvar _xtake =\n/*#__PURE__*/\nrequire(\"./internal/_xtake\");\n\nvar slice =\n/*#__PURE__*/\nrequire(\"./slice\");\n/**\n * Returns the first `n` elements of the given list, string, or\n * transducer/transformer (or object with a `take` method).\n *\n * Dispatches to the `take` method of the second argument, if present.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category List\n * @sig Number -> [a] -> [a]\n * @sig Number -> String -> String\n * @param {Number} n\n * @param {*} list\n * @return {*}\n * @see R.drop\n * @example\n *\n * R.take(1, ['foo', 'bar', 'baz']); //=> ['foo']\n * R.take(2, ['foo', 'bar', 'baz']); //=> ['foo', 'bar']\n * R.take(3, ['foo', 'bar', 'baz']); //=> ['foo', 'bar', 'baz']\n * R.take(4, ['foo', 'bar', 'baz']); //=> ['foo', 'bar', 'baz']\n * R.take(3, 'ramda'); //=> 'ram'\n *\n * const personnel = [\n * 'Dave Brubeck',\n * 'Paul Desmond',\n * 'Eugene Wright',\n * 'Joe Morello',\n * 'Gerry Mulligan',\n * 'Bob Bates',\n * 'Joe Dodge',\n * 'Ron Crotty'\n * ];\n *\n * const takeFive = R.take(5);\n * takeFive(personnel);\n * //=> ['Dave Brubeck', 'Paul Desmond', 'Eugene Wright', 'Joe Morello', 'Gerry Mulligan']\n * @symb R.take(-1, [a, b]) = [a, b]\n * @symb R.take(0, [a, b]) = []\n * @symb R.take(1, [a, b]) = [a]\n * @symb R.take(2, [a, b]) = [a, b]\n */\n\n\nvar take =\n/*#__PURE__*/\n_curry2(\n/*#__PURE__*/\n_dispatchable(['take'], _xtake, function take(n, xs) {\n return slice(0, n < 0 ? Infinity : n, xs);\n}));\n\nmodule.exports = take;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./_curry2\");\n\nvar _reduced =\n/*#__PURE__*/\nrequire(\"./_reduced\");\n\nvar _xfBase =\n/*#__PURE__*/\nrequire(\"./_xfBase\");\n\nvar XTake =\n/*#__PURE__*/\nfunction () {\n function XTake(n, xf) {\n this.xf = xf;\n this.n = n;\n this.i = 0;\n }\n\n XTake.prototype['@@transducer/init'] = _xfBase.init;\n XTake.prototype['@@transducer/result'] = _xfBase.result;\n\n XTake.prototype['@@transducer/step'] = function (result, input) {\n this.i += 1;\n var ret = this.n === 0 ? result : this.xf['@@transducer/step'](result, input);\n return this.n >= 0 && this.i >= this.n ? _reduced(ret) : ret;\n };\n\n return XTake;\n}();\n\nvar _xtake =\n/*#__PURE__*/\n_curry2(function _xtake(n, xf) {\n return new XTake(n, xf);\n});\n\nmodule.exports = _xtake;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _dispatchable =\n/*#__PURE__*/\nrequire(\"./internal/_dispatchable\");\n\nvar _dropLastWhile =\n/*#__PURE__*/\nrequire(\"./internal/_dropLastWhile\");\n\nvar _xdropLastWhile =\n/*#__PURE__*/\nrequire(\"./internal/_xdropLastWhile\");\n/**\n * Returns a new list excluding all the tailing elements of a given list which\n * satisfy the supplied predicate function. It passes each value from the right\n * to the supplied predicate function, skipping elements until the predicate\n * function returns a `falsy` value. The predicate function is applied to one argument:\n * *(value)*.\n *\n * Acts as a transducer if a transformer is given in list position.\n *\n * @func\n * @memberOf R\n * @since v0.16.0\n * @category List\n * @sig (a -> Boolean) -> [a] -> [a]\n * @sig (a -> Boolean) -> String -> String\n * @param {Function} predicate The function to be called on each element\n * @param {Array} xs The collection to iterate over.\n * @return {Array} A new array without any trailing elements that return `falsy` values from the `predicate`.\n * @see R.takeLastWhile, R.addIndex, R.drop, R.dropWhile\n * @example\n *\n * const lteThree = x => x <= 3;\n *\n * R.dropLastWhile(lteThree, [1, 2, 3, 4, 3, 2, 1]); //=> [1, 2, 3, 4]\n *\n * R.dropLastWhile(x => x !== 'd' , 'Ramda'); //=> 'Ramd'\n */\n\n\nvar dropLastWhile =\n/*#__PURE__*/\n_curry2(\n/*#__PURE__*/\n_dispatchable([], _xdropLastWhile, _dropLastWhile));\n\nmodule.exports = dropLastWhile;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./_curry2\");\n\nvar _reduce =\n/*#__PURE__*/\nrequire(\"./_reduce\");\n\nvar _xfBase =\n/*#__PURE__*/\nrequire(\"./_xfBase\");\n\nvar XDropLastWhile =\n/*#__PURE__*/\nfunction () {\n function XDropLastWhile(fn, xf) {\n this.f = fn;\n this.retained = [];\n this.xf = xf;\n }\n\n XDropLastWhile.prototype['@@transducer/init'] = _xfBase.init;\n\n XDropLastWhile.prototype['@@transducer/result'] = function (result) {\n this.retained = null;\n return this.xf['@@transducer/result'](result);\n };\n\n XDropLastWhile.prototype['@@transducer/step'] = function (result, input) {\n return this.f(input) ? this.retain(result, input) : this.flush(result, input);\n };\n\n XDropLastWhile.prototype.flush = function (result, input) {\n result = _reduce(this.xf['@@transducer/step'], result, this.retained);\n this.retained = [];\n return this.xf['@@transducer/step'](result, input);\n };\n\n XDropLastWhile.prototype.retain = function (result, input) {\n this.retained.push(input);\n return result;\n };\n\n return XDropLastWhile;\n}();\n\nvar _xdropLastWhile =\n/*#__PURE__*/\n_curry2(function _xdropLastWhile(fn, xf) {\n return new XDropLastWhile(fn, xf);\n});\n\nmodule.exports = _xdropLastWhile;","var slice =\n/*#__PURE__*/\nrequire(\"../slice\");\n\nfunction dropLastWhile(pred, xs) {\n var idx = xs.length - 1;\n\n while (idx >= 0 && pred(xs[idx])) {\n idx -= 1;\n }\n\n return slice(0, idx + 1, xs);\n}\n\nmodule.exports = dropLastWhile;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar _dispatchable =\n/*#__PURE__*/\nrequire(\"./internal/_dispatchable\");\n\nvar _xdropRepeatsWith =\n/*#__PURE__*/\nrequire(\"./internal/_xdropRepeatsWith\");\n\nvar dropRepeatsWith =\n/*#__PURE__*/\nrequire(\"./dropRepeatsWith\");\n\nvar equals =\n/*#__PURE__*/\nrequire(\"./equals\");\n/**\n * Returns a new list without any consecutively repeating elements.\n * [`R.equals`](#equals) is used to determine equality.\n *\n * Acts as a transducer if a transformer is given in list position.\n *\n * @func\n * @memberOf R\n * @since v0.14.0\n * @category List\n * @sig [a] -> [a]\n * @param {Array} list The array to consider.\n * @return {Array} `list` without repeating elements.\n * @see R.transduce\n * @example\n *\n * R.dropRepeats([1, 1, 1, 2, 3, 4, 4, 2, 2]); //=> [1, 2, 3, 4, 2]\n */\n\n\nvar dropRepeats =\n/*#__PURE__*/\n_curry1(\n/*#__PURE__*/\n_dispatchable([],\n/*#__PURE__*/\n_xdropRepeatsWith(equals),\n/*#__PURE__*/\ndropRepeatsWith(equals)));\n\nmodule.exports = dropRepeats;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./_curry2\");\n\nvar _xfBase =\n/*#__PURE__*/\nrequire(\"./_xfBase\");\n\nvar XDropRepeatsWith =\n/*#__PURE__*/\nfunction () {\n function XDropRepeatsWith(pred, xf) {\n this.xf = xf;\n this.pred = pred;\n this.lastValue = undefined;\n this.seenFirstValue = false;\n }\n\n XDropRepeatsWith.prototype['@@transducer/init'] = _xfBase.init;\n XDropRepeatsWith.prototype['@@transducer/result'] = _xfBase.result;\n\n XDropRepeatsWith.prototype['@@transducer/step'] = function (result, input) {\n var sameAsLast = false;\n\n if (!this.seenFirstValue) {\n this.seenFirstValue = true;\n } else if (this.pred(this.lastValue, input)) {\n sameAsLast = true;\n }\n\n this.lastValue = input;\n return sameAsLast ? result : this.xf['@@transducer/step'](result, input);\n };\n\n return XDropRepeatsWith;\n}();\n\nvar _xdropRepeatsWith =\n/*#__PURE__*/\n_curry2(function _xdropRepeatsWith(pred, xf) {\n return new XDropRepeatsWith(pred, xf);\n});\n\nmodule.exports = _xdropRepeatsWith;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _dispatchable =\n/*#__PURE__*/\nrequire(\"./internal/_dispatchable\");\n\nvar _xdropRepeatsWith =\n/*#__PURE__*/\nrequire(\"./internal/_xdropRepeatsWith\");\n\nvar last =\n/*#__PURE__*/\nrequire(\"./last\");\n/**\n * Returns a new list without any consecutively repeating elements. Equality is\n * determined by applying the supplied predicate to each pair of consecutive elements. The\n * first element in a series of equal elements will be preserved.\n *\n * Acts as a transducer if a transformer is given in list position.\n *\n * @func\n * @memberOf R\n * @since v0.14.0\n * @category List\n * @sig ((a, a) -> Boolean) -> [a] -> [a]\n * @param {Function} pred A predicate used to test whether two items are equal.\n * @param {Array} list The array to consider.\n * @return {Array} `list` without repeating elements.\n * @see R.transduce\n * @example\n *\n * const l = [1, -1, 1, 3, 4, -4, -4, -5, 5, 3, 3];\n * R.dropRepeatsWith(R.eqBy(Math.abs), l); //=> [1, 3, 4, -5, 3]\n */\n\n\nvar dropRepeatsWith =\n/*#__PURE__*/\n_curry2(\n/*#__PURE__*/\n_dispatchable([], _xdropRepeatsWith, function dropRepeatsWith(pred, list) {\n var result = [];\n var idx = 1;\n var len = list.length;\n\n if (len !== 0) {\n result[0] = list[0];\n\n while (idx < len) {\n if (!pred(last(result), list[idx])) {\n result[result.length] = list[idx];\n }\n\n idx += 1;\n }\n }\n\n return result;\n}));\n\nmodule.exports = dropRepeatsWith;","var nth =\n/*#__PURE__*/\nrequire(\"./nth\");\n/**\n * Returns the last element of the given list or string.\n *\n * @func\n * @memberOf R\n * @since v0.1.4\n * @category List\n * @sig [a] -> a | Undefined\n * @sig String -> String\n * @param {*} list\n * @return {*}\n * @see R.init, R.head, R.tail\n * @example\n *\n * R.last(['fi', 'fo', 'fum']); //=> 'fum'\n * R.last([]); //=> undefined\n *\n * R.last('abc'); //=> 'c'\n * R.last(''); //=> ''\n */\n\n\nvar last =\n/*#__PURE__*/\nnth(-1);\nmodule.exports = last;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _dispatchable =\n/*#__PURE__*/\nrequire(\"./internal/_dispatchable\");\n\nvar _xdropWhile =\n/*#__PURE__*/\nrequire(\"./internal/_xdropWhile\");\n\nvar slice =\n/*#__PURE__*/\nrequire(\"./slice\");\n/**\n * Returns a new list excluding the leading elements of a given list which\n * satisfy the supplied predicate function. It passes each value to the supplied\n * predicate function, skipping elements while the predicate function returns\n * `true`. The predicate function is applied to one argument: *(value)*.\n *\n * Dispatches to the `dropWhile` method of the second argument, if present.\n *\n * Acts as a transducer if a transformer is given in list position.\n *\n * @func\n * @memberOf R\n * @since v0.9.0\n * @category List\n * @sig (a -> Boolean) -> [a] -> [a]\n * @sig (a -> Boolean) -> String -> String\n * @param {Function} fn The function called per iteration.\n * @param {Array} xs The collection to iterate over.\n * @return {Array} A new array.\n * @see R.takeWhile, R.transduce, R.addIndex\n * @example\n *\n * const lteTwo = x => x <= 2;\n *\n * R.dropWhile(lteTwo, [1, 2, 3, 4, 3, 2, 1]); //=> [3, 4, 3, 2, 1]\n *\n * R.dropWhile(x => x !== 'd' , 'Ramda'); //=> 'da'\n */\n\n\nvar dropWhile =\n/*#__PURE__*/\n_curry2(\n/*#__PURE__*/\n_dispatchable(['dropWhile'], _xdropWhile, function dropWhile(pred, xs) {\n var idx = 0;\n var len = xs.length;\n\n while (idx < len && pred(xs[idx])) {\n idx += 1;\n }\n\n return slice(idx, Infinity, xs);\n}));\n\nmodule.exports = dropWhile;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./_curry2\");\n\nvar _xfBase =\n/*#__PURE__*/\nrequire(\"./_xfBase\");\n\nvar XDropWhile =\n/*#__PURE__*/\nfunction () {\n function XDropWhile(f, xf) {\n this.xf = xf;\n this.f = f;\n }\n\n XDropWhile.prototype['@@transducer/init'] = _xfBase.init;\n XDropWhile.prototype['@@transducer/result'] = _xfBase.result;\n\n XDropWhile.prototype['@@transducer/step'] = function (result, input) {\n if (this.f) {\n if (this.f(input)) {\n return result;\n }\n\n this.f = null;\n }\n\n return this.xf['@@transducer/step'](result, input);\n };\n\n return XDropWhile;\n}();\n\nvar _xdropWhile =\n/*#__PURE__*/\n_curry2(function _xdropWhile(f, xf) {\n return new XDropWhile(f, xf);\n});\n\nmodule.exports = _xdropWhile;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _isFunction =\n/*#__PURE__*/\nrequire(\"./internal/_isFunction\");\n\nvar lift =\n/*#__PURE__*/\nrequire(\"./lift\");\n\nvar or =\n/*#__PURE__*/\nrequire(\"./or\");\n/**\n * A function wrapping calls to the two functions in an `||` operation,\n * returning the result of the first function if it is truth-y and the result\n * of the second function otherwise. Note that this is short-circuited,\n * meaning that the second function will not be invoked if the first returns a\n * truth-y value.\n *\n * In addition to functions, `R.either` also accepts any fantasy-land compatible\n * applicative functor.\n *\n * @func\n * @memberOf R\n * @since v0.12.0\n * @category Logic\n * @sig (*... -> Boolean) -> (*... -> Boolean) -> (*... -> Boolean)\n * @param {Function} f a predicate\n * @param {Function} g another predicate\n * @return {Function} a function that applies its arguments to `f` and `g` and `||`s their outputs together.\n * @see R.or\n * @example\n *\n * const gt10 = x => x > 10;\n * const even = x => x % 2 === 0;\n * const f = R.either(gt10, even);\n * f(101); //=> true\n * f(8); //=> true\n *\n * R.either(Maybe.Just(false), Maybe.Just(55)); // => Maybe.Just(55)\n * R.either([false, false, 'a'], [11]) // => [11, 11, \"a\"]\n */\n\n\nvar either =\n/*#__PURE__*/\n_curry2(function either(f, g) {\n return _isFunction(f) ? function _either() {\n return f.apply(this, arguments) || g.apply(this, arguments);\n } : lift(or)(f, g);\n});\n\nmodule.exports = either;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Returns `true` if one or both of its arguments are `true`. Returns `false`\n * if both arguments are `false`.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Logic\n * @sig a -> b -> a | b\n * @param {Any} a\n * @param {Any} b\n * @return {Any} the first argument if truthy, otherwise the second argument.\n * @see R.either, R.xor\n * @example\n *\n * R.or(true, true); //=> true\n * R.or(true, false); //=> true\n * R.or(false, true); //=> true\n * R.or(false, false); //=> false\n */\n\n\nvar or =\n/*#__PURE__*/\n_curry2(function or(a, b) {\n return a || b;\n});\n\nmodule.exports = or;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar _isArguments =\n/*#__PURE__*/\nrequire(\"./internal/_isArguments\");\n\nvar _isArray =\n/*#__PURE__*/\nrequire(\"./internal/_isArray\");\n\nvar _isObject =\n/*#__PURE__*/\nrequire(\"./internal/_isObject\");\n\nvar _isString =\n/*#__PURE__*/\nrequire(\"./internal/_isString\");\n/**\n * Returns the empty value of its argument's type. Ramda defines the empty\n * value of Array (`[]`), Object (`{}`), String (`''`), and Arguments. Other\n * types are supported if they define `.empty`,\n * `.prototype.empty` or implement the\n * [FantasyLand Monoid spec](https://github.com/fantasyland/fantasy-land#monoid).\n *\n * Dispatches to the `empty` method of the first argument, if present.\n *\n * @func\n * @memberOf R\n * @since v0.3.0\n * @category Function\n * @sig a -> a\n * @param {*} x\n * @return {*}\n * @example\n *\n * R.empty(Just(42)); //=> Nothing()\n * R.empty([1, 2, 3]); //=> []\n * R.empty('unicorns'); //=> ''\n * R.empty({x: 1, y: 2}); //=> {}\n */\n\n\nvar empty =\n/*#__PURE__*/\n_curry1(function empty(x) {\n return x != null && typeof x['fantasy-land/empty'] === 'function' ? x['fantasy-land/empty']() : x != null && x.constructor != null && typeof x.constructor['fantasy-land/empty'] === 'function' ? x.constructor['fantasy-land/empty']() : x != null && typeof x.empty === 'function' ? x.empty() : x != null && x.constructor != null && typeof x.constructor.empty === 'function' ? x.constructor.empty() : _isArray(x) ? [] : _isString(x) ? '' : _isObject(x) ? {} : _isArguments(x) ? function () {\n return arguments;\n }() : void 0 // else\n ;\n});\n\nmodule.exports = empty;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar equals =\n/*#__PURE__*/\nrequire(\"./equals\");\n\nvar takeLast =\n/*#__PURE__*/\nrequire(\"./takeLast\");\n/**\n * Checks if a list ends with the provided sublist.\n *\n * Similarly, checks if a string ends with the provided substring.\n *\n * @func\n * @memberOf R\n * @since v0.24.0\n * @category List\n * @sig [a] -> [a] -> Boolean\n * @sig String -> String -> Boolean\n * @param {*} suffix\n * @param {*} list\n * @return {Boolean}\n * @see R.startsWith\n * @example\n *\n * R.endsWith('c', 'abc') //=> true\n * R.endsWith('b', 'abc') //=> false\n * R.endsWith(['c'], ['a', 'b', 'c']) //=> true\n * R.endsWith(['b'], ['a', 'b', 'c']) //=> false\n */\n\n\nvar endsWith =\n/*#__PURE__*/\n_curry2(function (suffix, list) {\n return equals(takeLast(suffix.length, list), suffix);\n});\n\nmodule.exports = endsWith;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar drop =\n/*#__PURE__*/\nrequire(\"./drop\");\n/**\n * Returns a new list containing the last `n` elements of the given list.\n * If `n > list.length`, returns a list of `list.length` elements.\n *\n * @func\n * @memberOf R\n * @since v0.16.0\n * @category List\n * @sig Number -> [a] -> [a]\n * @sig Number -> String -> String\n * @param {Number} n The number of elements to return.\n * @param {Array} xs The collection to consider.\n * @return {Array}\n * @see R.dropLast\n * @example\n *\n * R.takeLast(1, ['foo', 'bar', 'baz']); //=> ['baz']\n * R.takeLast(2, ['foo', 'bar', 'baz']); //=> ['bar', 'baz']\n * R.takeLast(3, ['foo', 'bar', 'baz']); //=> ['foo', 'bar', 'baz']\n * R.takeLast(4, ['foo', 'bar', 'baz']); //=> ['foo', 'bar', 'baz']\n * R.takeLast(3, 'ramda'); //=> 'mda'\n */\n\n\nvar takeLast =\n/*#__PURE__*/\n_curry2(function takeLast(n, xs) {\n return drop(n >= 0 ? xs.length - n : 0, xs);\n});\n\nmodule.exports = takeLast;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n\nvar equals =\n/*#__PURE__*/\nrequire(\"./equals\");\n/**\n * Takes a function and two values in its domain and returns `true` if the\n * values map to the same value in the codomain; `false` otherwise.\n *\n * @func\n * @memberOf R\n * @since v0.18.0\n * @category Relation\n * @sig (a -> b) -> a -> a -> Boolean\n * @param {Function} f\n * @param {*} x\n * @param {*} y\n * @return {Boolean}\n * @example\n *\n * R.eqBy(Math.abs, 5, -5); //=> true\n */\n\n\nvar eqBy =\n/*#__PURE__*/\n_curry3(function eqBy(f, x, y) {\n return equals(f(x), f(y));\n});\n\nmodule.exports = eqBy;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n\nvar equals =\n/*#__PURE__*/\nrequire(\"./equals\");\n/**\n * Reports whether two objects have the same value, in [`R.equals`](#equals)\n * terms, for the specified property. Useful as a curried predicate.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Object\n * @sig k -> {k: v} -> {k: v} -> Boolean\n * @param {String} prop The name of the property to compare\n * @param {Object} obj1\n * @param {Object} obj2\n * @return {Boolean}\n *\n * @example\n *\n * const o1 = { a: 1, b: 2, c: 3, d: 4 };\n * const o2 = { a: 10, b: 20, c: 3, d: 40 };\n * R.eqProps('a', o1, o2); //=> false\n * R.eqProps('c', o1, o2); //=> true\n */\n\n\nvar eqProps =\n/*#__PURE__*/\n_curry3(function eqProps(prop, obj1, obj2) {\n return equals(obj1[prop], obj2[prop]);\n});\n\nmodule.exports = eqProps;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Creates a new object by recursively evolving a shallow copy of `object`,\n * according to the `transformation` functions. All non-primitive properties\n * are copied by reference.\n *\n * A `transformation` function will not be invoked if its corresponding key\n * does not exist in the evolved object.\n *\n * @func\n * @memberOf R\n * @since v0.9.0\n * @category Object\n * @sig {k: (v -> v)} -> {k: v} -> {k: v}\n * @param {Object} transformations The object specifying transformation functions to apply\n * to the object.\n * @param {Object} object The object to be transformed.\n * @return {Object} The transformed object.\n * @example\n *\n * const tomato = {firstName: ' Tomato ', data: {elapsed: 100, remaining: 1400}, id:123};\n * const transformations = {\n * firstName: R.trim,\n * lastName: R.trim, // Will not get invoked.\n * data: {elapsed: R.add(1), remaining: R.add(-1)}\n * };\n * R.evolve(transformations, tomato); //=> {firstName: 'Tomato', data: {elapsed: 101, remaining: 1399}, id:123}\n */\n\n\nvar evolve =\n/*#__PURE__*/\n_curry2(function evolve(transformations, object) {\n var result = object instanceof Array ? [] : {};\n var transformation, key, type;\n\n for (key in object) {\n transformation = transformations[key];\n type = typeof transformation;\n result[key] = type === 'function' ? transformation(object[key]) : transformation && type === 'object' ? evolve(transformation, object[key]) : object[key];\n }\n\n return result;\n});\n\nmodule.exports = evolve;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _dispatchable =\n/*#__PURE__*/\nrequire(\"./internal/_dispatchable\");\n\nvar _xfind =\n/*#__PURE__*/\nrequire(\"./internal/_xfind\");\n/**\n * Returns the first element of the list which matches the predicate, or\n * `undefined` if no element matches.\n *\n * Dispatches to the `find` method of the second argument, if present.\n *\n * Acts as a transducer if a transformer is given in list position.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category List\n * @sig (a -> Boolean) -> [a] -> a | undefined\n * @param {Function} fn The predicate function used to determine if the element is the\n * desired one.\n * @param {Array} list The array to consider.\n * @return {Object} The element found, or `undefined`.\n * @see R.transduce\n * @example\n *\n * const xs = [{a: 1}, {a: 2}, {a: 3}];\n * R.find(R.propEq('a', 2))(xs); //=> {a: 2}\n * R.find(R.propEq('a', 4))(xs); //=> undefined\n */\n\n\nvar find =\n/*#__PURE__*/\n_curry2(\n/*#__PURE__*/\n_dispatchable(['find'], _xfind, function find(fn, list) {\n var idx = 0;\n var len = list.length;\n\n while (idx < len) {\n if (fn(list[idx])) {\n return list[idx];\n }\n\n idx += 1;\n }\n}));\n\nmodule.exports = find;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./_curry2\");\n\nvar _reduced =\n/*#__PURE__*/\nrequire(\"./_reduced\");\n\nvar _xfBase =\n/*#__PURE__*/\nrequire(\"./_xfBase\");\n\nvar XFind =\n/*#__PURE__*/\nfunction () {\n function XFind(f, xf) {\n this.xf = xf;\n this.f = f;\n this.found = false;\n }\n\n XFind.prototype['@@transducer/init'] = _xfBase.init;\n\n XFind.prototype['@@transducer/result'] = function (result) {\n if (!this.found) {\n result = this.xf['@@transducer/step'](result, void 0);\n }\n\n return this.xf['@@transducer/result'](result);\n };\n\n XFind.prototype['@@transducer/step'] = function (result, input) {\n if (this.f(input)) {\n this.found = true;\n result = _reduced(this.xf['@@transducer/step'](result, input));\n }\n\n return result;\n };\n\n return XFind;\n}();\n\nvar _xfind =\n/*#__PURE__*/\n_curry2(function _xfind(f, xf) {\n return new XFind(f, xf);\n});\n\nmodule.exports = _xfind;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _dispatchable =\n/*#__PURE__*/\nrequire(\"./internal/_dispatchable\");\n\nvar _xfindIndex =\n/*#__PURE__*/\nrequire(\"./internal/_xfindIndex\");\n/**\n * Returns the index of the first element of the list which matches the\n * predicate, or `-1` if no element matches.\n *\n * Acts as a transducer if a transformer is given in list position.\n *\n * @func\n * @memberOf R\n * @since v0.1.1\n * @category List\n * @sig (a -> Boolean) -> [a] -> Number\n * @param {Function} fn The predicate function used to determine if the element is the\n * desired one.\n * @param {Array} list The array to consider.\n * @return {Number} The index of the element found, or `-1`.\n * @see R.transduce\n * @example\n *\n * const xs = [{a: 1}, {a: 2}, {a: 3}];\n * R.findIndex(R.propEq('a', 2))(xs); //=> 1\n * R.findIndex(R.propEq('a', 4))(xs); //=> -1\n */\n\n\nvar findIndex =\n/*#__PURE__*/\n_curry2(\n/*#__PURE__*/\n_dispatchable([], _xfindIndex, function findIndex(fn, list) {\n var idx = 0;\n var len = list.length;\n\n while (idx < len) {\n if (fn(list[idx])) {\n return idx;\n }\n\n idx += 1;\n }\n\n return -1;\n}));\n\nmodule.exports = findIndex;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./_curry2\");\n\nvar _reduced =\n/*#__PURE__*/\nrequire(\"./_reduced\");\n\nvar _xfBase =\n/*#__PURE__*/\nrequire(\"./_xfBase\");\n\nvar XFindIndex =\n/*#__PURE__*/\nfunction () {\n function XFindIndex(f, xf) {\n this.xf = xf;\n this.f = f;\n this.idx = -1;\n this.found = false;\n }\n\n XFindIndex.prototype['@@transducer/init'] = _xfBase.init;\n\n XFindIndex.prototype['@@transducer/result'] = function (result) {\n if (!this.found) {\n result = this.xf['@@transducer/step'](result, -1);\n }\n\n return this.xf['@@transducer/result'](result);\n };\n\n XFindIndex.prototype['@@transducer/step'] = function (result, input) {\n this.idx += 1;\n\n if (this.f(input)) {\n this.found = true;\n result = _reduced(this.xf['@@transducer/step'](result, this.idx));\n }\n\n return result;\n };\n\n return XFindIndex;\n}();\n\nvar _xfindIndex =\n/*#__PURE__*/\n_curry2(function _xfindIndex(f, xf) {\n return new XFindIndex(f, xf);\n});\n\nmodule.exports = _xfindIndex;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _dispatchable =\n/*#__PURE__*/\nrequire(\"./internal/_dispatchable\");\n\nvar _xfindLast =\n/*#__PURE__*/\nrequire(\"./internal/_xfindLast\");\n/**\n * Returns the last element of the list which matches the predicate, or\n * `undefined` if no element matches.\n *\n * Acts as a transducer if a transformer is given in list position.\n *\n * @func\n * @memberOf R\n * @since v0.1.1\n * @category List\n * @sig (a -> Boolean) -> [a] -> a | undefined\n * @param {Function} fn The predicate function used to determine if the element is the\n * desired one.\n * @param {Array} list The array to consider.\n * @return {Object} The element found, or `undefined`.\n * @see R.transduce\n * @example\n *\n * const xs = [{a: 1, b: 0}, {a:1, b: 1}];\n * R.findLast(R.propEq('a', 1))(xs); //=> {a: 1, b: 1}\n * R.findLast(R.propEq('a', 4))(xs); //=> undefined\n */\n\n\nvar findLast =\n/*#__PURE__*/\n_curry2(\n/*#__PURE__*/\n_dispatchable([], _xfindLast, function findLast(fn, list) {\n var idx = list.length - 1;\n\n while (idx >= 0) {\n if (fn(list[idx])) {\n return list[idx];\n }\n\n idx -= 1;\n }\n}));\n\nmodule.exports = findLast;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./_curry2\");\n\nvar _xfBase =\n/*#__PURE__*/\nrequire(\"./_xfBase\");\n\nvar XFindLast =\n/*#__PURE__*/\nfunction () {\n function XFindLast(f, xf) {\n this.xf = xf;\n this.f = f;\n }\n\n XFindLast.prototype['@@transducer/init'] = _xfBase.init;\n\n XFindLast.prototype['@@transducer/result'] = function (result) {\n return this.xf['@@transducer/result'](this.xf['@@transducer/step'](result, this.last));\n };\n\n XFindLast.prototype['@@transducer/step'] = function (result, input) {\n if (this.f(input)) {\n this.last = input;\n }\n\n return result;\n };\n\n return XFindLast;\n}();\n\nvar _xfindLast =\n/*#__PURE__*/\n_curry2(function _xfindLast(f, xf) {\n return new XFindLast(f, xf);\n});\n\nmodule.exports = _xfindLast;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _dispatchable =\n/*#__PURE__*/\nrequire(\"./internal/_dispatchable\");\n\nvar _xfindLastIndex =\n/*#__PURE__*/\nrequire(\"./internal/_xfindLastIndex\");\n/**\n * Returns the index of the last element of the list which matches the\n * predicate, or `-1` if no element matches.\n *\n * Acts as a transducer if a transformer is given in list position.\n *\n * @func\n * @memberOf R\n * @since v0.1.1\n * @category List\n * @sig (a -> Boolean) -> [a] -> Number\n * @param {Function} fn The predicate function used to determine if the element is the\n * desired one.\n * @param {Array} list The array to consider.\n * @return {Number} The index of the element found, or `-1`.\n * @see R.transduce\n * @example\n *\n * const xs = [{a: 1, b: 0}, {a:1, b: 1}];\n * R.findLastIndex(R.propEq('a', 1))(xs); //=> 1\n * R.findLastIndex(R.propEq('a', 4))(xs); //=> -1\n */\n\n\nvar findLastIndex =\n/*#__PURE__*/\n_curry2(\n/*#__PURE__*/\n_dispatchable([], _xfindLastIndex, function findLastIndex(fn, list) {\n var idx = list.length - 1;\n\n while (idx >= 0) {\n if (fn(list[idx])) {\n return idx;\n }\n\n idx -= 1;\n }\n\n return -1;\n}));\n\nmodule.exports = findLastIndex;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./_curry2\");\n\nvar _xfBase =\n/*#__PURE__*/\nrequire(\"./_xfBase\");\n\nvar XFindLastIndex =\n/*#__PURE__*/\nfunction () {\n function XFindLastIndex(f, xf) {\n this.xf = xf;\n this.f = f;\n this.idx = -1;\n this.lastIdx = -1;\n }\n\n XFindLastIndex.prototype['@@transducer/init'] = _xfBase.init;\n\n XFindLastIndex.prototype['@@transducer/result'] = function (result) {\n return this.xf['@@transducer/result'](this.xf['@@transducer/step'](result, this.lastIdx));\n };\n\n XFindLastIndex.prototype['@@transducer/step'] = function (result, input) {\n this.idx += 1;\n\n if (this.f(input)) {\n this.lastIdx = this.idx;\n }\n\n return result;\n };\n\n return XFindLastIndex;\n}();\n\nvar _xfindLastIndex =\n/*#__PURE__*/\n_curry2(function _xfindLastIndex(f, xf) {\n return new XFindLastIndex(f, xf);\n});\n\nmodule.exports = _xfindLastIndex;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar _makeFlat =\n/*#__PURE__*/\nrequire(\"./internal/_makeFlat\");\n/**\n * Returns a new list by pulling every item out of it (and all its sub-arrays)\n * and putting them in a new array, depth-first.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category List\n * @sig [a] -> [b]\n * @param {Array} list The array to consider.\n * @return {Array} The flattened list.\n * @see R.unnest\n * @example\n *\n * R.flatten([1, 2, [3, 4], 5, [6, [7, 8, [9, [10, 11], 12]]]]);\n * //=> [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]\n */\n\n\nvar flatten =\n/*#__PURE__*/\n_curry1(\n/*#__PURE__*/\n_makeFlat(true));\n\nmodule.exports = flatten;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar curryN =\n/*#__PURE__*/\nrequire(\"./curryN\");\n/**\n * Returns a new function much like the supplied one, except that the first two\n * arguments' order is reversed.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Function\n * @sig ((a, b, c, ...) -> z) -> (b -> a -> c -> ... -> z)\n * @param {Function} fn The function to invoke with its first two parameters reversed.\n * @return {*} The result of invoking `fn` with its first two parameters' order reversed.\n * @example\n *\n * const mergeThree = (a, b, c) => [].concat(a, b, c);\n *\n * mergeThree(1, 2, 3); //=> [1, 2, 3]\n *\n * R.flip(mergeThree)(1, 2, 3); //=> [2, 1, 3]\n * @symb R.flip(f)(a, b, c) = f(b, a, c)\n */\n\n\nvar flip =\n/*#__PURE__*/\n_curry1(function flip(fn) {\n return curryN(fn.length, function (a, b) {\n var args = Array.prototype.slice.call(arguments, 0);\n args[0] = b;\n args[1] = a;\n return fn.apply(this, args);\n });\n});\n\nmodule.exports = flip;","var _checkForMethod =\n/*#__PURE__*/\nrequire(\"./internal/_checkForMethod\");\n\nvar _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Iterate over an input `list`, calling a provided function `fn` for each\n * element in the list.\n *\n * `fn` receives one argument: *(value)*.\n *\n * Note: `R.forEach` does not skip deleted or unassigned indices (sparse\n * arrays), unlike the native `Array.prototype.forEach` method. For more\n * details on this behavior, see:\n * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/forEach#Description\n *\n * Also note that, unlike `Array.prototype.forEach`, Ramda's `forEach` returns\n * the original array. In some libraries this function is named `each`.\n *\n * Dispatches to the `forEach` method of the second argument, if present.\n *\n * @func\n * @memberOf R\n * @since v0.1.1\n * @category List\n * @sig (a -> *) -> [a] -> [a]\n * @param {Function} fn The function to invoke. Receives one argument, `value`.\n * @param {Array} list The list to iterate over.\n * @return {Array} The original list.\n * @see R.addIndex\n * @example\n *\n * const printXPlusFive = x => console.log(x + 5);\n * R.forEach(printXPlusFive, [1, 2, 3]); //=> [1, 2, 3]\n * // logs 6\n * // logs 7\n * // logs 8\n * @symb R.forEach(f, [a, b, c]) = [a, b, c]\n */\n\n\nvar forEach =\n/*#__PURE__*/\n_curry2(\n/*#__PURE__*/\n_checkForMethod('forEach', function forEach(fn, list) {\n var len = list.length;\n var idx = 0;\n\n while (idx < len) {\n fn(list[idx]);\n idx += 1;\n }\n\n return list;\n}));\n\nmodule.exports = forEach;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar keys =\n/*#__PURE__*/\nrequire(\"./keys\");\n/**\n * Iterate over an input `object`, calling a provided function `fn` for each\n * key and value in the object.\n *\n * `fn` receives three argument: *(value, key, obj)*.\n *\n * @func\n * @memberOf R\n * @since v0.23.0\n * @category Object\n * @sig ((a, String, StrMap a) -> Any) -> StrMap a -> StrMap a\n * @param {Function} fn The function to invoke. Receives three argument, `value`, `key`, `obj`.\n * @param {Object} obj The object to iterate over.\n * @return {Object} The original object.\n * @example\n *\n * const printKeyConcatValue = (value, key) => console.log(key + ':' + value);\n * R.forEachObjIndexed(printKeyConcatValue, {x: 1, y: 2}); //=> {x: 1, y: 2}\n * // logs x:1\n * // logs y:2\n * @symb R.forEachObjIndexed(f, {x: a, y: b}) = {x: a, y: b}\n */\n\n\nvar forEachObjIndexed =\n/*#__PURE__*/\n_curry2(function forEachObjIndexed(fn, obj) {\n var keyList = keys(obj);\n var idx = 0;\n\n while (idx < keyList.length) {\n var key = keyList[idx];\n fn(obj[key], key, obj);\n idx += 1;\n }\n\n return obj;\n});\n\nmodule.exports = forEachObjIndexed;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n/**\n * Creates a new object from a list key-value pairs. If a key appears in\n * multiple pairs, the rightmost pair is included in the object.\n *\n * @func\n * @memberOf R\n * @since v0.3.0\n * @category List\n * @sig [[k,v]] -> {k: v}\n * @param {Array} pairs An array of two-element arrays that will be the keys and values of the output object.\n * @return {Object} The object made by pairing up `keys` and `values`.\n * @see R.toPairs, R.pair\n * @example\n *\n * R.fromPairs([['a', 1], ['b', 2], ['c', 3]]); //=> {a: 1, b: 2, c: 3}\n */\n\n\nvar fromPairs =\n/*#__PURE__*/\n_curry1(function fromPairs(pairs) {\n var result = {};\n var idx = 0;\n\n while (idx < pairs.length) {\n result[pairs[idx][0]] = pairs[idx][1];\n idx += 1;\n }\n\n return result;\n});\n\nmodule.exports = fromPairs;","var _checkForMethod =\n/*#__PURE__*/\nrequire(\"./internal/_checkForMethod\");\n\nvar _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar reduceBy =\n/*#__PURE__*/\nrequire(\"./reduceBy\");\n/**\n * Splits a list into sub-lists stored in an object, based on the result of\n * calling a String-returning function on each element, and grouping the\n * results according to values returned.\n *\n * Dispatches to the `groupBy` method of the second argument, if present.\n *\n * Acts as a transducer if a transformer is given in list position.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category List\n * @sig (a -> String) -> [a] -> {String: [a]}\n * @param {Function} fn Function :: a -> String\n * @param {Array} list The array to group\n * @return {Object} An object with the output of `fn` for keys, mapped to arrays of elements\n * that produced that key when passed to `fn`.\n * @see R.reduceBy, R.transduce\n * @example\n *\n * const byGrade = R.groupBy(function(student) {\n * const score = student.score;\n * return score < 65 ? 'F' :\n * score < 70 ? 'D' :\n * score < 80 ? 'C' :\n * score < 90 ? 'B' : 'A';\n * });\n * const students = [{name: 'Abby', score: 84},\n * {name: 'Eddy', score: 58},\n * // ...\n * {name: 'Jack', score: 69}];\n * byGrade(students);\n * // {\n * // 'A': [{name: 'Dianne', score: 99}],\n * // 'B': [{name: 'Abby', score: 84}]\n * // // ...,\n * // 'F': [{name: 'Eddy', score: 58}]\n * // }\n */\n\n\nvar groupBy =\n/*#__PURE__*/\n_curry2(\n/*#__PURE__*/\n_checkForMethod('groupBy',\n/*#__PURE__*/\nreduceBy(function (acc, item) {\n if (acc == null) {\n acc = [];\n }\n\n acc.push(item);\n return acc;\n}, null)));\n\nmodule.exports = groupBy;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Takes a list and returns a list of lists where each sublist's elements are\n * all satisfied pairwise comparison according to the provided function.\n * Only adjacent elements are passed to the comparison function.\n *\n * @func\n * @memberOf R\n * @since v0.21.0\n * @category List\n * @sig ((a, a) → Boolean) → [a] → [[a]]\n * @param {Function} fn Function for determining whether two given (adjacent)\n * elements should be in the same group\n * @param {Array} list The array to group. Also accepts a string, which will be\n * treated as a list of characters.\n * @return {List} A list that contains sublists of elements,\n * whose concatenations are equal to the original list.\n * @example\n *\n * R.groupWith(R.equals, [0, 1, 1, 2, 3, 5, 8, 13, 21])\n * //=> [[0], [1, 1], [2], [3], [5], [8], [13], [21]]\n *\n * R.groupWith((a, b) => a + 1 === b, [0, 1, 1, 2, 3, 5, 8, 13, 21])\n * //=> [[0, 1], [1, 2, 3], [5], [8], [13], [21]]\n *\n * R.groupWith((a, b) => a % 2 === b % 2, [0, 1, 1, 2, 3, 5, 8, 13, 21])\n * //=> [[0], [1, 1], [2], [3, 5], [8], [13, 21]]\n *\n * R.groupWith(R.eqBy(isVowel), 'aestiou')\n * //=> ['ae', 'st', 'iou']\n */\n\n\nvar groupWith =\n/*#__PURE__*/\n_curry2(function (fn, list) {\n var res = [];\n var idx = 0;\n var len = list.length;\n\n while (idx < len) {\n var nextidx = idx + 1;\n\n while (nextidx < len && fn(list[nextidx - 1], list[nextidx])) {\n nextidx += 1;\n }\n\n res.push(list.slice(idx, nextidx));\n idx = nextidx;\n }\n\n return res;\n});\n\nmodule.exports = groupWith;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Returns `true` if the first argument is greater than the second; `false`\n * otherwise.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Relation\n * @sig Ord a => a -> a -> Boolean\n * @param {*} a\n * @param {*} b\n * @return {Boolean}\n * @see R.lt\n * @example\n *\n * R.gt(2, 1); //=> true\n * R.gt(2, 2); //=> false\n * R.gt(2, 3); //=> false\n * R.gt('a', 'z'); //=> false\n * R.gt('z', 'a'); //=> true\n */\n\n\nvar gt =\n/*#__PURE__*/\n_curry2(function gt(a, b) {\n return a > b;\n});\n\nmodule.exports = gt;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Returns `true` if the first argument is greater than or equal to the second;\n * `false` otherwise.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Relation\n * @sig Ord a => a -> a -> Boolean\n * @param {Number} a\n * @param {Number} b\n * @return {Boolean}\n * @see R.lte\n * @example\n *\n * R.gte(2, 1); //=> true\n * R.gte(2, 2); //=> true\n * R.gte(2, 3); //=> false\n * R.gte('a', 'z'); //=> false\n * R.gte('z', 'a'); //=> true\n */\n\n\nvar gte =\n/*#__PURE__*/\n_curry2(function gte(a, b) {\n return a >= b;\n});\n\nmodule.exports = gte;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar hasPath =\n/*#__PURE__*/\nrequire(\"./hasPath\");\n/**\n * Returns whether or not an object has an own property with the specified name\n *\n * @func\n * @memberOf R\n * @since v0.7.0\n * @category Object\n * @sig s -> {s: x} -> Boolean\n * @param {String} prop The name of the property to check for.\n * @param {Object} obj The object to query.\n * @return {Boolean} Whether the property exists.\n * @example\n *\n * const hasName = R.has('name');\n * hasName({name: 'alice'}); //=> true\n * hasName({name: 'bob'}); //=> true\n * hasName({}); //=> false\n *\n * const point = {x: 0, y: 0};\n * const pointHas = R.has(R.__, point);\n * pointHas('x'); //=> true\n * pointHas('y'); //=> true\n * pointHas('z'); //=> false\n */\n\n\nvar has =\n/*#__PURE__*/\n_curry2(function has(prop, obj) {\n return hasPath([prop], obj);\n});\n\nmodule.exports = has;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _has =\n/*#__PURE__*/\nrequire(\"./internal/_has\");\n\nvar isNil =\n/*#__PURE__*/\nrequire(\"./isNil\");\n/**\n * Returns whether or not a path exists in an object. Only the object's\n * own properties are checked.\n *\n * @func\n * @memberOf R\n * @since v0.26.0\n * @category Object\n * @typedefn Idx = String | Int\n * @sig [Idx] -> {a} -> Boolean\n * @param {Array} path The path to use.\n * @param {Object} obj The object to check the path in.\n * @return {Boolean} Whether the path exists.\n * @see R.has\n * @example\n *\n * R.hasPath(['a', 'b'], {a: {b: 2}}); // => true\n * R.hasPath(['a', 'b'], {a: {b: undefined}}); // => true\n * R.hasPath(['a', 'b'], {a: {c: 2}}); // => false\n * R.hasPath(['a', 'b'], {}); // => false\n */\n\n\nvar hasPath =\n/*#__PURE__*/\n_curry2(function hasPath(_path, obj) {\n if (_path.length === 0 || isNil(obj)) {\n return false;\n }\n\n var val = obj;\n var idx = 0;\n\n while (idx < _path.length) {\n if (!isNil(val) && _has(_path[idx], val)) {\n val = val[_path[idx]];\n idx += 1;\n } else {\n return false;\n }\n }\n\n return true;\n});\n\nmodule.exports = hasPath;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Returns whether or not an object or its prototype chain has a property with\n * the specified name\n *\n * @func\n * @memberOf R\n * @since v0.7.0\n * @category Object\n * @sig s -> {s: x} -> Boolean\n * @param {String} prop The name of the property to check for.\n * @param {Object} obj The object to query.\n * @return {Boolean} Whether the property exists.\n * @example\n *\n * function Rectangle(width, height) {\n * this.width = width;\n * this.height = height;\n * }\n * Rectangle.prototype.area = function() {\n * return this.width * this.height;\n * };\n *\n * const square = new Rectangle(2, 2);\n * R.hasIn('width', square); //=> true\n * R.hasIn('area', square); //=> true\n */\n\n\nvar hasIn =\n/*#__PURE__*/\n_curry2(function hasIn(prop, obj) {\n return prop in obj;\n});\n\nmodule.exports = hasIn;","var _objectIs =\n/*#__PURE__*/\nrequire(\"./internal/_objectIs\");\n\nvar _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Returns true if its arguments are identical, false otherwise. Values are\n * identical if they reference the same memory. `NaN` is identical to `NaN`;\n * `0` and `-0` are not identical.\n *\n * Note this is merely a curried version of ES6 `Object.is`.\n *\n * @func\n * @memberOf R\n * @since v0.15.0\n * @category Relation\n * @sig a -> a -> Boolean\n * @param {*} a\n * @param {*} b\n * @return {Boolean}\n * @example\n *\n * const o = {};\n * R.identical(o, o); //=> true\n * R.identical(1, 1); //=> true\n * R.identical(1, '1'); //=> false\n * R.identical([], []); //=> false\n * R.identical(0, -0); //=> false\n * R.identical(NaN, NaN); //=> true\n */\n\n\nvar identical =\n/*#__PURE__*/\n_curry2(_objectIs);\n\nmodule.exports = identical;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n\nvar curryN =\n/*#__PURE__*/\nrequire(\"./curryN\");\n/**\n * Creates a function that will process either the `onTrue` or the `onFalse`\n * function depending upon the result of the `condition` predicate.\n *\n * @func\n * @memberOf R\n * @since v0.8.0\n * @category Logic\n * @sig (*... -> Boolean) -> (*... -> *) -> (*... -> *) -> (*... -> *)\n * @param {Function} condition A predicate function\n * @param {Function} onTrue A function to invoke when the `condition` evaluates to a truthy value.\n * @param {Function} onFalse A function to invoke when the `condition` evaluates to a falsy value.\n * @return {Function} A new function that will process either the `onTrue` or the `onFalse`\n * function depending upon the result of the `condition` predicate.\n * @see R.unless, R.when, R.cond\n * @example\n *\n * const incCount = R.ifElse(\n * R.has('count'),\n * R.over(R.lensProp('count'), R.inc),\n * R.assoc('count', 1)\n * );\n * incCount({}); //=> { count: 1 }\n * incCount({ count: 1 }); //=> { count: 2 }\n */\n\n\nvar ifElse =\n/*#__PURE__*/\n_curry3(function ifElse(condition, onTrue, onFalse) {\n return curryN(Math.max(condition.length, onTrue.length, onFalse.length), function _ifElse() {\n return condition.apply(this, arguments) ? onTrue.apply(this, arguments) : onFalse.apply(this, arguments);\n });\n});\n\nmodule.exports = ifElse;","var add =\n/*#__PURE__*/\nrequire(\"./add\");\n/**\n * Increments its argument.\n *\n * @func\n * @memberOf R\n * @since v0.9.0\n * @category Math\n * @sig Number -> Number\n * @param {Number} n\n * @return {Number} n + 1\n * @see R.dec\n * @example\n *\n * R.inc(42); //=> 43\n */\n\n\nvar inc =\n/*#__PURE__*/\nadd(1);\nmodule.exports = inc;","var _includes =\n/*#__PURE__*/\nrequire(\"./internal/_includes\");\n\nvar _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Returns `true` if the specified value is equal, in [`R.equals`](#equals)\n * terms, to at least one element of the given list; `false` otherwise.\n * Works also with strings.\n *\n * @func\n * @memberOf R\n * @since v0.26.0\n * @category List\n * @sig a -> [a] -> Boolean\n * @param {Object} a The item to compare against.\n * @param {Array} list The array to consider.\n * @return {Boolean} `true` if an equivalent item is in the list, `false` otherwise.\n * @see R.any\n * @example\n *\n * R.includes(3, [1, 2, 3]); //=> true\n * R.includes(4, [1, 2, 3]); //=> false\n * R.includes({ name: 'Fred' }, [{ name: 'Fred' }]); //=> true\n * R.includes([42], [[42]]); //=> true\n * R.includes('ba', 'banana'); //=>true\n */\n\n\nvar includes =\n/*#__PURE__*/\n_curry2(_includes);\n\nmodule.exports = includes;","var reduceBy =\n/*#__PURE__*/\nrequire(\"./reduceBy\");\n/**\n * Given a function that generates a key, turns a list of objects into an\n * object indexing the objects by the given key. Note that if multiple\n * objects generate the same value for the indexing key only the last value\n * will be included in the generated object.\n *\n * Acts as a transducer if a transformer is given in list position.\n *\n * @func\n * @memberOf R\n * @since v0.19.0\n * @category List\n * @sig (a -> String) -> [{k: v}] -> {k: {k: v}}\n * @param {Function} fn Function :: a -> String\n * @param {Array} array The array of objects to index\n * @return {Object} An object indexing each array element by the given property.\n * @example\n *\n * const list = [{id: 'xyz', title: 'A'}, {id: 'abc', title: 'B'}];\n * R.indexBy(R.prop('id'), list);\n * //=> {abc: {id: 'abc', title: 'B'}, xyz: {id: 'xyz', title: 'A'}}\n */\n\n\nvar indexBy =\n/*#__PURE__*/\nreduceBy(function (acc, elem) {\n return elem;\n}, null);\nmodule.exports = indexBy;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _indexOf =\n/*#__PURE__*/\nrequire(\"./internal/_indexOf\");\n\nvar _isArray =\n/*#__PURE__*/\nrequire(\"./internal/_isArray\");\n/**\n * Returns the position of the first occurrence of an item in an array, or -1\n * if the item is not included in the array. [`R.equals`](#equals) is used to\n * determine equality.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category List\n * @sig a -> [a] -> Number\n * @param {*} target The item to find.\n * @param {Array} xs The array to search in.\n * @return {Number} the index of the target, or -1 if the target is not found.\n * @see R.lastIndexOf\n * @example\n *\n * R.indexOf(3, [1,2,3,4]); //=> 2\n * R.indexOf(10, [1,2,3,4]); //=> -1\n */\n\n\nvar indexOf =\n/*#__PURE__*/\n_curry2(function indexOf(target, xs) {\n return typeof xs.indexOf === 'function' && !_isArray(xs) ? xs.indexOf(target) : _indexOf(xs, target, 0);\n});\n\nmodule.exports = indexOf;","var slice =\n/*#__PURE__*/\nrequire(\"./slice\");\n/**\n * Returns all but the last element of the given list or string.\n *\n * @func\n * @memberOf R\n * @since v0.9.0\n * @category List\n * @sig [a] -> [a]\n * @sig String -> String\n * @param {*} list\n * @return {*}\n * @see R.last, R.head, R.tail\n * @example\n *\n * R.init([1, 2, 3]); //=> [1, 2]\n * R.init([1, 2]); //=> [1]\n * R.init([1]); //=> []\n * R.init([]); //=> []\n *\n * R.init('abc'); //=> 'ab'\n * R.init('ab'); //=> 'a'\n * R.init('a'); //=> ''\n * R.init(''); //=> ''\n */\n\n\nvar init =\n/*#__PURE__*/\nslice(0, -1);\nmodule.exports = init;","var _includesWith =\n/*#__PURE__*/\nrequire(\"./internal/_includesWith\");\n\nvar _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n\nvar _filter =\n/*#__PURE__*/\nrequire(\"./internal/_filter\");\n/**\n * Takes a predicate `pred`, a list `xs`, and a list `ys`, and returns a list\n * `xs'` comprising each of the elements of `xs` which is equal to one or more\n * elements of `ys` according to `pred`.\n *\n * `pred` must be a binary function expecting an element from each list.\n *\n * `xs`, `ys`, and `xs'` are treated as sets, semantically, so ordering should\n * not be significant, but since `xs'` is ordered the implementation guarantees\n * that its values are in the same order as they appear in `xs`. Duplicates are\n * not removed, so `xs'` may contain duplicates if `xs` contains duplicates.\n *\n * @func\n * @memberOf R\n * @since v0.24.0\n * @category Relation\n * @sig ((a, b) -> Boolean) -> [a] -> [b] -> [a]\n * @param {Function} pred\n * @param {Array} xs\n * @param {Array} ys\n * @return {Array}\n * @see R.intersection\n * @example\n *\n * R.innerJoin(\n * (record, id) => record.id === id,\n * [{id: 824, name: 'Richie Furay'},\n * {id: 956, name: 'Dewey Martin'},\n * {id: 313, name: 'Bruce Palmer'},\n * {id: 456, name: 'Stephen Stills'},\n * {id: 177, name: 'Neil Young'}],\n * [177, 456, 999]\n * );\n * //=> [{id: 456, name: 'Stephen Stills'}, {id: 177, name: 'Neil Young'}]\n */\n\n\nvar innerJoin =\n/*#__PURE__*/\n_curry3(function innerJoin(pred, xs, ys) {\n return _filter(function (x) {\n return _includesWith(pred, x, ys);\n }, xs);\n});\n\nmodule.exports = innerJoin;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n/**\n * Inserts the supplied element into the list, at the specified `index`. _Note that\n\n * this is not destructive_: it returns a copy of the list with the changes.\n * No lists have been harmed in the application of this function.\n *\n * @func\n * @memberOf R\n * @since v0.2.2\n * @category List\n * @sig Number -> a -> [a] -> [a]\n * @param {Number} index The position to insert the element\n * @param {*} elt The element to insert into the Array\n * @param {Array} list The list to insert into\n * @return {Array} A new Array with `elt` inserted at `index`.\n * @example\n *\n * R.insert(2, 'x', [1,2,3,4]); //=> [1,2,'x',3,4]\n */\n\n\nvar insert =\n/*#__PURE__*/\n_curry3(function insert(idx, elt, list) {\n idx = idx < list.length && idx >= 0 ? idx : list.length;\n var result = Array.prototype.slice.call(list, 0);\n result.splice(idx, 0, elt);\n return result;\n});\n\nmodule.exports = insert;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n/**\n * Inserts the sub-list into the list, at the specified `index`. _Note that this is not\n * destructive_: it returns a copy of the list with the changes.\n * No lists have been harmed in the application of this function.\n *\n * @func\n * @memberOf R\n * @since v0.9.0\n * @category List\n * @sig Number -> [a] -> [a] -> [a]\n * @param {Number} index The position to insert the sub-list\n * @param {Array} elts The sub-list to insert into the Array\n * @param {Array} list The list to insert the sub-list into\n * @return {Array} A new Array with `elts` inserted starting at `index`.\n * @example\n *\n * R.insertAll(2, ['x','y','z'], [1,2,3,4]); //=> [1,2,'x','y','z',3,4]\n */\n\n\nvar insertAll =\n/*#__PURE__*/\n_curry3(function insertAll(idx, elts, list) {\n idx = idx < list.length && idx >= 0 ? idx : list.length;\n return [].concat(Array.prototype.slice.call(list, 0, idx), elts, Array.prototype.slice.call(list, idx));\n});\n\nmodule.exports = insertAll;","var _includes =\n/*#__PURE__*/\nrequire(\"./internal/_includes\");\n\nvar _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _filter =\n/*#__PURE__*/\nrequire(\"./internal/_filter\");\n\nvar flip =\n/*#__PURE__*/\nrequire(\"./flip\");\n\nvar uniq =\n/*#__PURE__*/\nrequire(\"./uniq\");\n/**\n * Combines two lists into a set (i.e. no duplicates) composed of those\n * elements common to both lists.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Relation\n * @sig [*] -> [*] -> [*]\n * @param {Array} list1 The first list.\n * @param {Array} list2 The second list.\n * @return {Array} The list of elements found in both `list1` and `list2`.\n * @see R.innerJoin\n * @example\n *\n * R.intersection([1,2,3,4], [7,6,5,4,3]); //=> [4, 3]\n */\n\n\nvar intersection =\n/*#__PURE__*/\n_curry2(function intersection(list1, list2) {\n var lookupList, filteredList;\n\n if (list1.length > list2.length) {\n lookupList = list1;\n filteredList = list2;\n } else {\n lookupList = list2;\n filteredList = list1;\n }\n\n return uniq(_filter(flip(_includes)(lookupList), filteredList));\n});\n\nmodule.exports = intersection;","var identity =\n/*#__PURE__*/\nrequire(\"./identity\");\n\nvar uniqBy =\n/*#__PURE__*/\nrequire(\"./uniqBy\");\n/**\n * Returns a new list containing only one copy of each element in the original\n * list. [`R.equals`](#equals) is used to determine equality.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category List\n * @sig [a] -> [a]\n * @param {Array} list The array to consider.\n * @return {Array} The list of unique items.\n * @example\n *\n * R.uniq([1, 1, 2, 1]); //=> [1, 2]\n * R.uniq([1, '1']); //=> [1, '1']\n * R.uniq([[42], [42]]); //=> [[42]]\n */\n\n\nvar uniq =\n/*#__PURE__*/\nuniqBy(identity);\nmodule.exports = uniq;","var _Set =\n/*#__PURE__*/\nrequire(\"./internal/_Set\");\n\nvar _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Returns a new list containing only one copy of each element in the original\n * list, based upon the value returned by applying the supplied function to\n * each list element. Prefers the first item if the supplied function produces\n * the same value on two items. [`R.equals`](#equals) is used for comparison.\n *\n * @func\n * @memberOf R\n * @since v0.16.0\n * @category List\n * @sig (a -> b) -> [a] -> [a]\n * @param {Function} fn A function used to produce a value to use during comparisons.\n * @param {Array} list The array to consider.\n * @return {Array} The list of unique items.\n * @example\n *\n * R.uniqBy(Math.abs, [-1, -5, 2, 10, 1, 2]); //=> [-1, -5, 2, 10]\n */\n\n\nvar uniqBy =\n/*#__PURE__*/\n_curry2(function uniqBy(fn, list) {\n var set = new _Set();\n var result = [];\n var idx = 0;\n var appliedItem, item;\n\n while (idx < list.length) {\n item = list[idx];\n appliedItem = fn(item);\n\n if (set.add(appliedItem)) {\n result.push(item);\n }\n\n idx += 1;\n }\n\n return result;\n});\n\nmodule.exports = uniqBy;","var _checkForMethod =\n/*#__PURE__*/\nrequire(\"./internal/_checkForMethod\");\n\nvar _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Creates a new list with the separator interposed between elements.\n *\n * Dispatches to the `intersperse` method of the second argument, if present.\n *\n * @func\n * @memberOf R\n * @since v0.14.0\n * @category List\n * @sig a -> [a] -> [a]\n * @param {*} separator The element to add to the list.\n * @param {Array} list The list to be interposed.\n * @return {Array} The new list.\n * @example\n *\n * R.intersperse('a', ['b', 'n', 'n', 's']); //=> ['b', 'a', 'n', 'a', 'n', 'a', 's']\n */\n\n\nvar intersperse =\n/*#__PURE__*/\n_curry2(\n/*#__PURE__*/\n_checkForMethod('intersperse', function intersperse(separator, list) {\n var out = [];\n var idx = 0;\n var length = list.length;\n\n while (idx < length) {\n if (idx === length - 1) {\n out.push(list[idx]);\n } else {\n out.push(list[idx], separator);\n }\n\n idx += 1;\n }\n\n return out;\n}));\n\nmodule.exports = intersperse;","var _clone =\n/*#__PURE__*/\nrequire(\"./internal/_clone\");\n\nvar _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n\nvar _isTransformer =\n/*#__PURE__*/\nrequire(\"./internal/_isTransformer\");\n\nvar _reduce =\n/*#__PURE__*/\nrequire(\"./internal/_reduce\");\n\nvar _stepCat =\n/*#__PURE__*/\nrequire(\"./internal/_stepCat\");\n/**\n * Transforms the items of the list with the transducer and appends the\n * transformed items to the accumulator using an appropriate iterator function\n * based on the accumulator type.\n *\n * The accumulator can be an array, string, object or a transformer. Iterated\n * items will be appended to arrays and concatenated to strings. Objects will\n * be merged directly or 2-item arrays will be merged as key, value pairs.\n *\n * The accumulator can also be a transformer object that provides a 2-arity\n * reducing iterator function, step, 0-arity initial value function, init, and\n * 1-arity result extraction function result. The step function is used as the\n * iterator function in reduce. The result function is used to convert the\n * final accumulator into the return type and in most cases is R.identity. The\n * init function is used to provide the initial accumulator.\n *\n * The iteration is performed with [`R.reduce`](#reduce) after initializing the\n * transducer.\n *\n * @func\n * @memberOf R\n * @since v0.12.0\n * @category List\n * @sig a -> (b -> b) -> [c] -> a\n * @param {*} acc The initial accumulator value.\n * @param {Function} xf The transducer function. Receives a transformer and returns a transformer.\n * @param {Array} list The list to iterate over.\n * @return {*} The final, accumulated value.\n * @see R.transduce\n * @example\n *\n * const numbers = [1, 2, 3, 4];\n * const transducer = R.compose(R.map(R.add(1)), R.take(2));\n *\n * R.into([], transducer, numbers); //=> [2, 3]\n *\n * const intoArray = R.into([]);\n * intoArray(transducer, numbers); //=> [2, 3]\n */\n\n\nvar into =\n/*#__PURE__*/\n_curry3(function into(acc, xf, list) {\n return _isTransformer(acc) ? _reduce(xf(acc), acc['@@transducer/init'](), list) : _reduce(xf(_stepCat(acc)), _clone(acc, [], [], false), list);\n});\n\nmodule.exports = into;","var _objectAssign =\n/*#__PURE__*/\nrequire(\"./_objectAssign\");\n\nvar _identity =\n/*#__PURE__*/\nrequire(\"./_identity\");\n\nvar _isArrayLike =\n/*#__PURE__*/\nrequire(\"./_isArrayLike\");\n\nvar _isTransformer =\n/*#__PURE__*/\nrequire(\"./_isTransformer\");\n\nvar objOf =\n/*#__PURE__*/\nrequire(\"../objOf\");\n\nvar _stepCatArray = {\n '@@transducer/init': Array,\n '@@transducer/step': function (xs, x) {\n xs.push(x);\n return xs;\n },\n '@@transducer/result': _identity\n};\nvar _stepCatString = {\n '@@transducer/init': String,\n '@@transducer/step': function (a, b) {\n return a + b;\n },\n '@@transducer/result': _identity\n};\nvar _stepCatObject = {\n '@@transducer/init': Object,\n '@@transducer/step': function (result, input) {\n return _objectAssign(result, _isArrayLike(input) ? objOf(input[0], input[1]) : input);\n },\n '@@transducer/result': _identity\n};\n\nfunction _stepCat(obj) {\n if (_isTransformer(obj)) {\n return obj;\n }\n\n if (_isArrayLike(obj)) {\n return _stepCatArray;\n }\n\n if (typeof obj === 'string') {\n return _stepCatString;\n }\n\n if (typeof obj === 'object') {\n return _stepCatObject;\n }\n\n throw new Error('Cannot create transformer for ' + obj);\n}\n\nmodule.exports = _stepCat;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Creates an object containing a single key:value pair.\n *\n * @func\n * @memberOf R\n * @since v0.18.0\n * @category Object\n * @sig String -> a -> {String:a}\n * @param {String} key\n * @param {*} val\n * @return {Object}\n * @see R.pair\n * @example\n *\n * const matchPhrases = R.compose(\n * R.objOf('must'),\n * R.map(R.objOf('match_phrase'))\n * );\n * matchPhrases(['foo', 'bar', 'baz']); //=> {must: [{match_phrase: 'foo'}, {match_phrase: 'bar'}, {match_phrase: 'baz'}]}\n */\n\n\nvar objOf =\n/*#__PURE__*/\n_curry2(function objOf(key, val) {\n var obj = {};\n obj[key] = val;\n return obj;\n});\n\nmodule.exports = objOf;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar _has =\n/*#__PURE__*/\nrequire(\"./internal/_has\");\n\nvar keys =\n/*#__PURE__*/\nrequire(\"./keys\");\n/**\n * Same as [`R.invertObj`](#invertObj), however this accounts for objects with\n * duplicate values by putting the values into an array.\n *\n * @func\n * @memberOf R\n * @since v0.9.0\n * @category Object\n * @sig {s: x} -> {x: [ s, ... ]}\n * @param {Object} obj The object or array to invert\n * @return {Object} out A new object with keys in an array.\n * @see R.invertObj\n * @example\n *\n * const raceResultsByFirstName = {\n * first: 'alice',\n * second: 'jake',\n * third: 'alice',\n * };\n * R.invert(raceResultsByFirstName);\n * //=> { 'alice': ['first', 'third'], 'jake':['second'] }\n */\n\n\nvar invert =\n/*#__PURE__*/\n_curry1(function invert(obj) {\n var props = keys(obj);\n var len = props.length;\n var idx = 0;\n var out = {};\n\n while (idx < len) {\n var key = props[idx];\n var val = obj[key];\n var list = _has(val, out) ? out[val] : out[val] = [];\n list[list.length] = key;\n idx += 1;\n }\n\n return out;\n});\n\nmodule.exports = invert;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar keys =\n/*#__PURE__*/\nrequire(\"./keys\");\n/**\n * Returns a new object with the keys of the given object as values, and the\n * values of the given object, which are coerced to strings, as keys. Note\n * that the last key found is preferred when handling the same value.\n *\n * @func\n * @memberOf R\n * @since v0.9.0\n * @category Object\n * @sig {s: x} -> {x: s}\n * @param {Object} obj The object or array to invert\n * @return {Object} out A new object\n * @see R.invert\n * @example\n *\n * const raceResults = {\n * first: 'alice',\n * second: 'jake'\n * };\n * R.invertObj(raceResults);\n * //=> { 'alice': 'first', 'jake':'second' }\n *\n * // Alternatively:\n * const raceResults = ['alice', 'jake'];\n * R.invertObj(raceResults);\n * //=> { 'alice': '0', 'jake':'1' }\n */\n\n\nvar invertObj =\n/*#__PURE__*/\n_curry1(function invertObj(obj) {\n var props = keys(obj);\n var len = props.length;\n var idx = 0;\n var out = {};\n\n while (idx < len) {\n var key = props[idx];\n out[obj[key]] = key;\n idx += 1;\n }\n\n return out;\n});\n\nmodule.exports = invertObj;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _isFunction =\n/*#__PURE__*/\nrequire(\"./internal/_isFunction\");\n\nvar curryN =\n/*#__PURE__*/\nrequire(\"./curryN\");\n\nvar toString =\n/*#__PURE__*/\nrequire(\"./toString\");\n/**\n * Turns a named method with a specified arity into a function that can be\n * called directly supplied with arguments and a target object.\n *\n * The returned function is curried and accepts `arity + 1` parameters where\n * the final parameter is the target object.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Function\n * @sig Number -> String -> (a -> b -> ... -> n -> Object -> *)\n * @param {Number} arity Number of arguments the returned function should take\n * before the target object.\n * @param {String} method Name of any of the target object's methods to call.\n * @return {Function} A new curried function.\n * @see R.construct\n * @example\n *\n * const sliceFrom = R.invoker(1, 'slice');\n * sliceFrom(6, 'abcdefghijklm'); //=> 'ghijklm'\n * const sliceFrom6 = R.invoker(2, 'slice')(6);\n * sliceFrom6(8, 'abcdefghijklm'); //=> 'gh'\n *\n * const dog = {\n * speak: async () => 'Woof!'\n * };\n * const speak = R.invoker(0, 'speak');\n * speak(dog).then(console.log) //~> 'Woof!'\n *\n * @symb R.invoker(0, 'method')(o) = o['method']()\n * @symb R.invoker(1, 'method')(a, o) = o['method'](a)\n * @symb R.invoker(2, 'method')(a, b, o) = o['method'](a, b)\n */\n\n\nvar invoker =\n/*#__PURE__*/\n_curry2(function invoker(arity, method) {\n return curryN(arity + 1, function () {\n var target = arguments[arity];\n\n if (target != null && _isFunction(target[method])) {\n return target[method].apply(target, Array.prototype.slice.call(arguments, 0, arity));\n }\n\n throw new TypeError(toString(target) + ' does not have a method named \"' + method + '\"');\n });\n});\n\nmodule.exports = invoker;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * See if an object (`val`) is an instance of the supplied constructor. This\n * function will check up the inheritance chain, if any.\n *\n * @func\n * @memberOf R\n * @since v0.3.0\n * @category Type\n * @sig (* -> {*}) -> a -> Boolean\n * @param {Object} ctor A constructor\n * @param {*} val The value to test\n * @return {Boolean}\n * @example\n *\n * R.is(Object, {}); //=> true\n * R.is(Number, 1); //=> true\n * R.is(Object, 1); //=> false\n * R.is(String, 's'); //=> true\n * R.is(String, new String('')); //=> true\n * R.is(Object, new String('')); //=> true\n * R.is(Object, 's'); //=> false\n * R.is(Number, {}); //=> false\n */\n\n\nvar is =\n/*#__PURE__*/\n_curry2(function is(Ctor, val) {\n return val != null && val.constructor === Ctor || val instanceof Ctor;\n});\n\nmodule.exports = is;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar empty =\n/*#__PURE__*/\nrequire(\"./empty\");\n\nvar equals =\n/*#__PURE__*/\nrequire(\"./equals\");\n/**\n * Returns `true` if the given value is its type's empty value; `false`\n * otherwise.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Logic\n * @sig a -> Boolean\n * @param {*} x\n * @return {Boolean}\n * @see R.empty\n * @example\n *\n * R.isEmpty([1, 2, 3]); //=> false\n * R.isEmpty([]); //=> true\n * R.isEmpty(''); //=> true\n * R.isEmpty(null); //=> false\n * R.isEmpty({}); //=> true\n * R.isEmpty({length: 0}); //=> false\n */\n\n\nvar isEmpty =\n/*#__PURE__*/\n_curry1(function isEmpty(x) {\n return x != null && equals(x, empty(x));\n});\n\nmodule.exports = isEmpty;","var invoker =\n/*#__PURE__*/\nrequire(\"./invoker\");\n/**\n * Returns a string made by inserting the `separator` between each element and\n * concatenating all the elements into a single string.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category List\n * @sig String -> [a] -> String\n * @param {Number|String} separator The string used to separate the elements.\n * @param {Array} xs The elements to join into a string.\n * @return {String} str The string made by concatenating `xs` with `separator`.\n * @see R.split\n * @example\n *\n * const spacer = R.join(' ');\n * spacer(['a', 2, 3.4]); //=> 'a 2 3.4'\n * R.join('|', [1, 2, 3]); //=> '1|2|3'\n */\n\n\nvar join =\n/*#__PURE__*/\ninvoker(1, 'join');\nmodule.exports = join;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar converge =\n/*#__PURE__*/\nrequire(\"./converge\");\n/**\n * juxt applies a list of functions to a list of values.\n *\n * @func\n * @memberOf R\n * @since v0.19.0\n * @category Function\n * @sig [(a, b, ..., m) -> n] -> ((a, b, ..., m) -> [n])\n * @param {Array} fns An array of functions\n * @return {Function} A function that returns a list of values after applying each of the original `fns` to its parameters.\n * @see R.applySpec\n * @example\n *\n * const getRange = R.juxt([Math.min, Math.max]);\n * getRange(3, 4, 9, -3); //=> [-3, 9]\n * @symb R.juxt([f, g, h])(a, b) = [f(a, b), g(a, b), h(a, b)]\n */\n\n\nvar juxt =\n/*#__PURE__*/\n_curry1(function juxt(fns) {\n return converge(function () {\n return Array.prototype.slice.call(arguments, 0);\n }, fns);\n});\n\nmodule.exports = juxt;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n/**\n * Returns a list containing the names of all the properties of the supplied\n * object, including prototype properties.\n * Note that the order of the output array is not guaranteed to be consistent\n * across different JS platforms.\n *\n * @func\n * @memberOf R\n * @since v0.2.0\n * @category Object\n * @sig {k: v} -> [k]\n * @param {Object} obj The object to extract properties from\n * @return {Array} An array of the object's own and prototype properties.\n * @see R.keys, R.valuesIn\n * @example\n *\n * const F = function() { this.x = 'X'; };\n * F.prototype.y = 'Y';\n * const f = new F();\n * R.keysIn(f); //=> ['x', 'y']\n */\n\n\nvar keysIn =\n/*#__PURE__*/\n_curry1(function keysIn(obj) {\n var prop;\n var ks = [];\n\n for (prop in obj) {\n ks[ks.length] = prop;\n }\n\n return ks;\n});\n\nmodule.exports = keysIn;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _isArray =\n/*#__PURE__*/\nrequire(\"./internal/_isArray\");\n\nvar equals =\n/*#__PURE__*/\nrequire(\"./equals\");\n/**\n * Returns the position of the last occurrence of an item in an array, or -1 if\n * the item is not included in the array. [`R.equals`](#equals) is used to\n * determine equality.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category List\n * @sig a -> [a] -> Number\n * @param {*} target The item to find.\n * @param {Array} xs The array to search in.\n * @return {Number} the index of the target, or -1 if the target is not found.\n * @see R.indexOf\n * @example\n *\n * R.lastIndexOf(3, [-1,3,3,0,1,2,3,4]); //=> 6\n * R.lastIndexOf(10, [1,2,3,4]); //=> -1\n */\n\n\nvar lastIndexOf =\n/*#__PURE__*/\n_curry2(function lastIndexOf(target, xs) {\n if (typeof xs.lastIndexOf === 'function' && !_isArray(xs)) {\n return xs.lastIndexOf(target);\n } else {\n var idx = xs.length - 1;\n\n while (idx >= 0) {\n if (equals(xs[idx], target)) {\n return idx;\n }\n\n idx -= 1;\n }\n\n return -1;\n }\n});\n\nmodule.exports = lastIndexOf;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar _isNumber =\n/*#__PURE__*/\nrequire(\"./internal/_isNumber\");\n/**\n * Returns the number of elements in the array by returning `list.length`.\n *\n * @func\n * @memberOf R\n * @since v0.3.0\n * @category List\n * @sig [a] -> Number\n * @param {Array} list The array to inspect.\n * @return {Number} The length of the array.\n * @example\n *\n * R.length([]); //=> 0\n * R.length([1, 2, 3]); //=> 3\n */\n\n\nvar length =\n/*#__PURE__*/\n_curry1(function length(list) {\n return list != null && _isNumber(list.length) ? list.length : NaN;\n});\n\nmodule.exports = length;","function _isNumber(x) {\n return Object.prototype.toString.call(x) === '[object Number]';\n}\n\nmodule.exports = _isNumber;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar map =\n/*#__PURE__*/\nrequire(\"./map\");\n/**\n * Returns a lens for the given getter and setter functions. The getter \"gets\"\n * the value of the focus; the setter \"sets\" the value of the focus. The setter\n * should not mutate the data structure.\n *\n * @func\n * @memberOf R\n * @since v0.8.0\n * @category Object\n * @typedefn Lens s a = Functor f => (a -> f a) -> s -> f s\n * @sig (s -> a) -> ((a, s) -> s) -> Lens s a\n * @param {Function} getter\n * @param {Function} setter\n * @return {Lens}\n * @see R.view, R.set, R.over, R.lensIndex, R.lensProp\n * @example\n *\n * const xLens = R.lens(R.prop('x'), R.assoc('x'));\n *\n * R.view(xLens, {x: 1, y: 2}); //=> 1\n * R.set(xLens, 4, {x: 1, y: 2}); //=> {x: 4, y: 2}\n * R.over(xLens, R.negate, {x: 1, y: 2}); //=> {x: -1, y: 2}\n */\n\n\nvar lens =\n/*#__PURE__*/\n_curry2(function lens(getter, setter) {\n return function (toFunctorFn) {\n return function (target) {\n return map(function (focus) {\n return setter(focus, target);\n }, toFunctorFn(getter(target)));\n };\n };\n});\n\nmodule.exports = lens;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar lens =\n/*#__PURE__*/\nrequire(\"./lens\");\n\nvar nth =\n/*#__PURE__*/\nrequire(\"./nth\");\n\nvar update =\n/*#__PURE__*/\nrequire(\"./update\");\n/**\n * Returns a lens whose focus is the specified index.\n *\n * @func\n * @memberOf R\n * @since v0.14.0\n * @category Object\n * @typedefn Lens s a = Functor f => (a -> f a) -> s -> f s\n * @sig Number -> Lens s a\n * @param {Number} n\n * @return {Lens}\n * @see R.view, R.set, R.over, R.nth\n * @example\n *\n * const headLens = R.lensIndex(0);\n *\n * R.view(headLens, ['a', 'b', 'c']); //=> 'a'\n * R.set(headLens, 'x', ['a', 'b', 'c']); //=> ['x', 'b', 'c']\n * R.over(headLens, R.toUpper, ['a', 'b', 'c']); //=> ['A', 'b', 'c']\n */\n\n\nvar lensIndex =\n/*#__PURE__*/\n_curry1(function lensIndex(n) {\n return lens(nth(n), update(n));\n});\n\nmodule.exports = lensIndex;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar assocPath =\n/*#__PURE__*/\nrequire(\"./assocPath\");\n\nvar lens =\n/*#__PURE__*/\nrequire(\"./lens\");\n\nvar path =\n/*#__PURE__*/\nrequire(\"./path\");\n/**\n * Returns a lens whose focus is the specified path.\n *\n * @func\n * @memberOf R\n * @since v0.19.0\n * @category Object\n * @typedefn Idx = String | Int\n * @typedefn Lens s a = Functor f => (a -> f a) -> s -> f s\n * @sig [Idx] -> Lens s a\n * @param {Array} path The path to use.\n * @return {Lens}\n * @see R.view, R.set, R.over\n * @example\n *\n * const xHeadYLens = R.lensPath(['x', 0, 'y']);\n *\n * R.view(xHeadYLens, {x: [{y: 2, z: 3}, {y: 4, z: 5}]});\n * //=> 2\n * R.set(xHeadYLens, 1, {x: [{y: 2, z: 3}, {y: 4, z: 5}]});\n * //=> {x: [{y: 1, z: 3}, {y: 4, z: 5}]}\n * R.over(xHeadYLens, R.negate, {x: [{y: 2, z: 3}, {y: 4, z: 5}]});\n * //=> {x: [{y: -2, z: 3}, {y: 4, z: 5}]}\n */\n\n\nvar lensPath =\n/*#__PURE__*/\n_curry1(function lensPath(p) {\n return lens(path(p), assocPath(p));\n});\n\nmodule.exports = lensPath;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar assoc =\n/*#__PURE__*/\nrequire(\"./assoc\");\n\nvar lens =\n/*#__PURE__*/\nrequire(\"./lens\");\n\nvar prop =\n/*#__PURE__*/\nrequire(\"./prop\");\n/**\n * Returns a lens whose focus is the specified property.\n *\n * @func\n * @memberOf R\n * @since v0.14.0\n * @category Object\n * @typedefn Lens s a = Functor f => (a -> f a) -> s -> f s\n * @sig String -> Lens s a\n * @param {String} k\n * @return {Lens}\n * @see R.view, R.set, R.over\n * @example\n *\n * const xLens = R.lensProp('x');\n *\n * R.view(xLens, {x: 1, y: 2}); //=> 1\n * R.set(xLens, 4, {x: 1, y: 2}); //=> {x: 4, y: 2}\n * R.over(xLens, R.negate, {x: 1, y: 2}); //=> {x: -1, y: 2}\n */\n\n\nvar lensProp =\n/*#__PURE__*/\n_curry1(function lensProp(k) {\n return lens(prop(k), assoc(k));\n});\n\nmodule.exports = lensProp;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Returns `true` if the first argument is less than the second; `false`\n * otherwise.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Relation\n * @sig Ord a => a -> a -> Boolean\n * @param {*} a\n * @param {*} b\n * @return {Boolean}\n * @see R.gt\n * @example\n *\n * R.lt(2, 1); //=> false\n * R.lt(2, 2); //=> false\n * R.lt(2, 3); //=> true\n * R.lt('a', 'z'); //=> true\n * R.lt('z', 'a'); //=> false\n */\n\n\nvar lt =\n/*#__PURE__*/\n_curry2(function lt(a, b) {\n return a < b;\n});\n\nmodule.exports = lt;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Returns `true` if the first argument is less than or equal to the second;\n * `false` otherwise.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Relation\n * @sig Ord a => a -> a -> Boolean\n * @param {Number} a\n * @param {Number} b\n * @return {Boolean}\n * @see R.gte\n * @example\n *\n * R.lte(2, 1); //=> false\n * R.lte(2, 2); //=> true\n * R.lte(2, 3); //=> true\n * R.lte('a', 'z'); //=> true\n * R.lte('z', 'a'); //=> false\n */\n\n\nvar lte =\n/*#__PURE__*/\n_curry2(function lte(a, b) {\n return a <= b;\n});\n\nmodule.exports = lte;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n/**\n * The `mapAccum` function behaves like a combination of map and reduce; it\n * applies a function to each element of a list, passing an accumulating\n * parameter from left to right, and returning a final value of this\n * accumulator together with the new list.\n *\n * The iterator function receives two arguments, *acc* and *value*, and should\n * return a tuple *[acc, value]*.\n *\n * @func\n * @memberOf R\n * @since v0.10.0\n * @category List\n * @sig ((acc, x) -> (acc, y)) -> acc -> [x] -> (acc, [y])\n * @param {Function} fn The function to be called on every element of the input `list`.\n * @param {*} acc The accumulator value.\n * @param {Array} list The list to iterate over.\n * @return {*} The final, accumulated value.\n * @see R.scan, R.addIndex, R.mapAccumRight\n * @example\n *\n * const digits = ['1', '2', '3', '4'];\n * const appender = (a, b) => [a + b, a + b];\n *\n * R.mapAccum(appender, 0, digits); //=> ['01234', ['01', '012', '0123', '01234']]\n * @symb R.mapAccum(f, a, [b, c, d]) = [\n * f(f(f(a, b)[0], c)[0], d)[0],\n * [\n * f(a, b)[1],\n * f(f(a, b)[0], c)[1],\n * f(f(f(a, b)[0], c)[0], d)[1]\n * ]\n * ]\n */\n\n\nvar mapAccum =\n/*#__PURE__*/\n_curry3(function mapAccum(fn, acc, list) {\n var idx = 0;\n var len = list.length;\n var result = [];\n var tuple = [acc];\n\n while (idx < len) {\n tuple = fn(tuple[0], list[idx]);\n result[idx] = tuple[1];\n idx += 1;\n }\n\n return [tuple[0], result];\n});\n\nmodule.exports = mapAccum;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n/**\n * The `mapAccumRight` function behaves like a combination of map and reduce; it\n * applies a function to each element of a list, passing an accumulating\n * parameter from right to left, and returning a final value of this\n * accumulator together with the new list.\n *\n * Similar to [`mapAccum`](#mapAccum), except moves through the input list from\n * the right to the left.\n *\n * The iterator function receives two arguments, *acc* and *value*, and should\n * return a tuple *[acc, value]*.\n *\n * @func\n * @memberOf R\n * @since v0.10.0\n * @category List\n * @sig ((acc, x) -> (acc, y)) -> acc -> [x] -> (acc, [y])\n * @param {Function} fn The function to be called on every element of the input `list`.\n * @param {*} acc The accumulator value.\n * @param {Array} list The list to iterate over.\n * @return {*} The final, accumulated value.\n * @see R.addIndex, R.mapAccum\n * @example\n *\n * const digits = ['1', '2', '3', '4'];\n * const appender = (a, b) => [b + a, b + a];\n *\n * R.mapAccumRight(appender, 5, digits); //=> ['12345', ['12345', '2345', '345', '45']]\n * @symb R.mapAccumRight(f, a, [b, c, d]) = [\n * f(f(f(a, d)[0], c)[0], b)[0],\n * [\n * f(a, d)[1],\n * f(f(a, d)[0], c)[1],\n * f(f(f(a, d)[0], c)[0], b)[1]\n * ]\n * ]\n */\n\n\nvar mapAccumRight =\n/*#__PURE__*/\n_curry3(function mapAccumRight(fn, acc, list) {\n var idx = list.length - 1;\n var result = [];\n var tuple = [acc];\n\n while (idx >= 0) {\n tuple = fn(tuple[0], list[idx]);\n result[idx] = tuple[1];\n idx -= 1;\n }\n\n return [tuple[0], result];\n});\n\nmodule.exports = mapAccumRight;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _reduce =\n/*#__PURE__*/\nrequire(\"./internal/_reduce\");\n\nvar keys =\n/*#__PURE__*/\nrequire(\"./keys\");\n/**\n * An Object-specific version of [`map`](#map). The function is applied to three\n * arguments: *(value, key, obj)*. If only the value is significant, use\n * [`map`](#map) instead.\n *\n * @func\n * @memberOf R\n * @since v0.9.0\n * @category Object\n * @sig ((*, String, Object) -> *) -> Object -> Object\n * @param {Function} fn\n * @param {Object} obj\n * @return {Object}\n * @see R.map\n * @example\n *\n * const xyz = { x: 1, y: 2, z: 3 };\n * const prependKeyAndDouble = (num, key, obj) => key + (num * 2);\n *\n * R.mapObjIndexed(prependKeyAndDouble, xyz); //=> { x: 'x2', y: 'y4', z: 'z6' }\n */\n\n\nvar mapObjIndexed =\n/*#__PURE__*/\n_curry2(function mapObjIndexed(fn, obj) {\n return _reduce(function (acc, key) {\n acc[key] = fn(obj[key], key, obj);\n return acc;\n }, {}, keys(obj));\n});\n\nmodule.exports = mapObjIndexed;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Tests a regular expression against a String. Note that this function will\n * return an empty array when there are no matches. This differs from\n * [`String.prototype.match`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/match)\n * which returns `null` when there are no matches.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category String\n * @sig RegExp -> String -> [String | Undefined]\n * @param {RegExp} rx A regular expression.\n * @param {String} str The string to match against\n * @return {Array} The list of matches or empty array.\n * @see R.test\n * @example\n *\n * R.match(/([a-z]a)/g, 'bananas'); //=> ['ba', 'na', 'na']\n * R.match(/a/, 'b'); //=> []\n * R.match(/a/, null); //=> TypeError: null does not have a method named \"match\"\n */\n\n\nvar match =\n/*#__PURE__*/\n_curry2(function match(rx, str) {\n return str.match(rx) || [];\n});\n\nmodule.exports = match;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _isInteger =\n/*#__PURE__*/\nrequire(\"./internal/_isInteger\");\n/**\n * `mathMod` behaves like the modulo operator should mathematically, unlike the\n * `%` operator (and by extension, [`R.modulo`](#modulo)). So while\n * `-17 % 5` is `-2`, `mathMod(-17, 5)` is `3`. `mathMod` requires Integer\n * arguments, and returns NaN when the modulus is zero or negative.\n *\n * @func\n * @memberOf R\n * @since v0.3.0\n * @category Math\n * @sig Number -> Number -> Number\n * @param {Number} m The dividend.\n * @param {Number} p the modulus.\n * @return {Number} The result of `b mod a`.\n * @see R.modulo\n * @example\n *\n * R.mathMod(-17, 5); //=> 3\n * R.mathMod(17, 5); //=> 2\n * R.mathMod(17, -5); //=> NaN\n * R.mathMod(17, 0); //=> NaN\n * R.mathMod(17.2, 5); //=> NaN\n * R.mathMod(17, 5.3); //=> NaN\n *\n * const clock = R.mathMod(R.__, 12);\n * clock(15); //=> 3\n * clock(24); //=> 0\n *\n * const seventeenMod = R.mathMod(17);\n * seventeenMod(3); //=> 2\n * seventeenMod(4); //=> 1\n * seventeenMod(10); //=> 7\n */\n\n\nvar mathMod =\n/*#__PURE__*/\n_curry2(function mathMod(m, p) {\n if (!_isInteger(m)) {\n return NaN;\n }\n\n if (!_isInteger(p) || p < 1) {\n return NaN;\n }\n\n return (m % p + p) % p;\n});\n\nmodule.exports = mathMod;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n/**\n * Takes a function and two values, and returns whichever value produces the\n * larger result when passed to the provided function.\n *\n * @func\n * @memberOf R\n * @since v0.8.0\n * @category Relation\n * @sig Ord b => (a -> b) -> a -> a -> a\n * @param {Function} f\n * @param {*} a\n * @param {*} b\n * @return {*}\n * @see R.max, R.minBy\n * @example\n *\n * // square :: Number -> Number\n * const square = n => n * n;\n *\n * R.maxBy(square, -3, 2); //=> -3\n *\n * R.reduce(R.maxBy(square), 0, [3, -5, 4, 1, -2]); //=> -5\n * R.reduce(R.maxBy(square), 0, []); //=> 0\n */\n\n\nvar maxBy =\n/*#__PURE__*/\n_curry3(function maxBy(f, a, b) {\n return f(b) > f(a) ? b : a;\n});\n\nmodule.exports = maxBy;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar sum =\n/*#__PURE__*/\nrequire(\"./sum\");\n/**\n * Returns the mean of the given list of numbers.\n *\n * @func\n * @memberOf R\n * @since v0.14.0\n * @category Math\n * @sig [Number] -> Number\n * @param {Array} list\n * @return {Number}\n * @see R.median\n * @example\n *\n * R.mean([2, 7, 9]); //=> 6\n * R.mean([]); //=> NaN\n */\n\n\nvar mean =\n/*#__PURE__*/\n_curry1(function mean(list) {\n return sum(list) / list.length;\n});\n\nmodule.exports = mean;","var add =\n/*#__PURE__*/\nrequire(\"./add\");\n\nvar reduce =\n/*#__PURE__*/\nrequire(\"./reduce\");\n/**\n * Adds together all the elements of a list.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Math\n * @sig [Number] -> Number\n * @param {Array} list An array of numbers\n * @return {Number} The sum of all the numbers in the list.\n * @see R.reduce\n * @example\n *\n * R.sum([2,4,6,8,100,1]); //=> 121\n */\n\n\nvar sum =\n/*#__PURE__*/\nreduce(add, 0);\nmodule.exports = sum;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar mean =\n/*#__PURE__*/\nrequire(\"./mean\");\n/**\n * Returns the median of the given list of numbers.\n *\n * @func\n * @memberOf R\n * @since v0.14.0\n * @category Math\n * @sig [Number] -> Number\n * @param {Array} list\n * @return {Number}\n * @see R.mean\n * @example\n *\n * R.median([2, 9, 7]); //=> 7\n * R.median([7, 2, 10, 9]); //=> 8\n * R.median([]); //=> NaN\n */\n\n\nvar median =\n/*#__PURE__*/\n_curry1(function median(list) {\n var len = list.length;\n\n if (len === 0) {\n return NaN;\n }\n\n var width = 2 - len % 2;\n var idx = (len - width) / 2;\n return mean(Array.prototype.slice.call(list, 0).sort(function (a, b) {\n return a < b ? -1 : a > b ? 1 : 0;\n }).slice(idx, idx + width));\n});\n\nmodule.exports = median;","var _arity =\n/*#__PURE__*/\nrequire(\"./internal/_arity\");\n\nvar _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _has =\n/*#__PURE__*/\nrequire(\"./internal/_has\");\n/**\n * Creates a new function that, when invoked, caches the result of calling `fn`\n * for a given argument set and returns the result. Subsequent calls to the\n * memoized `fn` with the same argument set will not result in an additional\n * call to `fn`; instead, the cached result for that set of arguments will be\n * returned.\n *\n *\n * @func\n * @memberOf R\n * @since v0.24.0\n * @category Function\n * @sig (*... -> String) -> (*... -> a) -> (*... -> a)\n * @param {Function} fn The function to generate the cache key.\n * @param {Function} fn The function to memoize.\n * @return {Function} Memoized version of `fn`.\n * @example\n *\n * let count = 0;\n * const factorial = R.memoizeWith(R.identity, n => {\n * count += 1;\n * return R.product(R.range(1, n + 1));\n * });\n * factorial(5); //=> 120\n * factorial(5); //=> 120\n * factorial(5); //=> 120\n * count; //=> 1\n */\n\n\nvar memoizeWith =\n/*#__PURE__*/\n_curry2(function memoizeWith(mFn, fn) {\n var cache = {};\n return _arity(fn.length, function () {\n var key = mFn.apply(this, arguments);\n\n if (!_has(key, cache)) {\n cache[key] = fn.apply(this, arguments);\n }\n\n return cache[key];\n });\n});\n\nmodule.exports = memoizeWith;","var _objectAssign =\n/*#__PURE__*/\nrequire(\"./internal/_objectAssign\");\n\nvar _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Create a new object with the own properties of the first object merged with\n * the own properties of the second object. If a key exists in both objects,\n * the value from the second object will be used.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Object\n * @sig {k: v} -> {k: v} -> {k: v}\n * @param {Object} l\n * @param {Object} r\n * @return {Object}\n * @see R.mergeRight, R.mergeDeepRight, R.mergeWith, R.mergeWithKey\n * @deprecated since v0.26.0\n * @example\n *\n * R.merge({ 'name': 'fred', 'age': 10 }, { 'age': 40 });\n * //=> { 'name': 'fred', 'age': 40 }\n *\n * const withDefaults = R.merge({x: 0, y: 0});\n * withDefaults({y: 2}); //=> {x: 0, y: 2}\n * @symb R.merge(a, b) = {...a, ...b}\n */\n\n\nvar merge =\n/*#__PURE__*/\n_curry2(function merge(l, r) {\n return _objectAssign({}, l, r);\n});\n\nmodule.exports = merge;","var _objectAssign =\n/*#__PURE__*/\nrequire(\"./internal/_objectAssign\");\n\nvar _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n/**\n * Merges a list of objects together into one object.\n *\n * @func\n * @memberOf R\n * @since v0.10.0\n * @category List\n * @sig [{k: v}] -> {k: v}\n * @param {Array} list An array of objects\n * @return {Object} A merged object.\n * @see R.reduce\n * @example\n *\n * R.mergeAll([{foo:1},{bar:2},{baz:3}]); //=> {foo:1,bar:2,baz:3}\n * R.mergeAll([{foo:1},{foo:2},{bar:2}]); //=> {foo:2,bar:2}\n * @symb R.mergeAll([{ x: 1 }, { y: 2 }, { z: 3 }]) = { x: 1, y: 2, z: 3 }\n */\n\n\nvar mergeAll =\n/*#__PURE__*/\n_curry1(function mergeAll(list) {\n return _objectAssign.apply(null, [{}].concat(list));\n});\n\nmodule.exports = mergeAll;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar mergeDeepWithKey =\n/*#__PURE__*/\nrequire(\"./mergeDeepWithKey\");\n/**\n * Creates a new object with the own properties of the first object merged with\n * the own properties of the second object. If a key exists in both objects:\n * - and both values are objects, the two values will be recursively merged\n * - otherwise the value from the first object will be used.\n *\n * @func\n * @memberOf R\n * @since v0.24.0\n * @category Object\n * @sig {a} -> {a} -> {a}\n * @param {Object} lObj\n * @param {Object} rObj\n * @return {Object}\n * @see R.merge, R.mergeDeepRight, R.mergeDeepWith, R.mergeDeepWithKey\n * @example\n *\n * R.mergeDeepLeft({ name: 'fred', age: 10, contact: { email: 'moo@example.com' }},\n * { age: 40, contact: { email: 'baa@example.com' }});\n * //=> { name: 'fred', age: 10, contact: { email: 'moo@example.com' }}\n */\n\n\nvar mergeDeepLeft =\n/*#__PURE__*/\n_curry2(function mergeDeepLeft(lObj, rObj) {\n return mergeDeepWithKey(function (k, lVal, rVal) {\n return lVal;\n }, lObj, rObj);\n});\n\nmodule.exports = mergeDeepLeft;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n\nvar mergeDeepWithKey =\n/*#__PURE__*/\nrequire(\"./mergeDeepWithKey\");\n/**\n * Creates a new object with the own properties of the two provided objects.\n * If a key exists in both objects:\n * - and both associated values are also objects then the values will be\n * recursively merged.\n * - otherwise the provided function is applied to associated values using the\n * resulting value as the new value associated with the key.\n * If a key only exists in one object, the value will be associated with the key\n * of the resulting object.\n *\n * @func\n * @memberOf R\n * @since v0.24.0\n * @category Object\n * @sig ((a, a) -> a) -> {a} -> {a} -> {a}\n * @param {Function} fn\n * @param {Object} lObj\n * @param {Object} rObj\n * @return {Object}\n * @see R.mergeWith, R.mergeDeepWithKey\n * @example\n *\n * R.mergeDeepWith(R.concat,\n * { a: true, c: { values: [10, 20] }},\n * { b: true, c: { values: [15, 35] }});\n * //=> { a: true, b: true, c: { values: [10, 20, 15, 35] }}\n */\n\n\nvar mergeDeepWith =\n/*#__PURE__*/\n_curry3(function mergeDeepWith(fn, lObj, rObj) {\n return mergeDeepWithKey(function (k, lVal, rVal) {\n return fn(lVal, rVal);\n }, lObj, rObj);\n});\n\nmodule.exports = mergeDeepWith;","var _objectAssign =\n/*#__PURE__*/\nrequire(\"./internal/_objectAssign\");\n\nvar _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Create a new object with the own properties of the first object merged with\n * the own properties of the second object. If a key exists in both objects,\n * the value from the first object will be used.\n *\n * @func\n * @memberOf R\n * @since v0.26.0\n * @category Object\n * @sig {k: v} -> {k: v} -> {k: v}\n * @param {Object} l\n * @param {Object} r\n * @return {Object}\n * @see R.mergeRight, R.mergeDeepLeft, R.mergeWith, R.mergeWithKey\n * @example\n *\n * R.mergeLeft({ 'age': 40 }, { 'name': 'fred', 'age': 10 });\n * //=> { 'name': 'fred', 'age': 40 }\n *\n * const resetToDefault = R.mergeLeft({x: 0});\n * resetToDefault({x: 5, y: 2}); //=> {x: 0, y: 2}\n * @symb R.mergeLeft(a, b) = {...b, ...a}\n */\n\n\nvar mergeLeft =\n/*#__PURE__*/\n_curry2(function mergeLeft(l, r) {\n return _objectAssign({}, r, l);\n});\n\nmodule.exports = mergeLeft;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n\nvar mergeWithKey =\n/*#__PURE__*/\nrequire(\"./mergeWithKey\");\n/**\n * Creates a new object with the own properties of the two provided objects. If\n * a key exists in both objects, the provided function is applied to the values\n * associated with the key in each object, with the result being used as the\n * value associated with the key in the returned object.\n *\n * @func\n * @memberOf R\n * @since v0.19.0\n * @category Object\n * @sig ((a, a) -> a) -> {a} -> {a} -> {a}\n * @param {Function} fn\n * @param {Object} l\n * @param {Object} r\n * @return {Object}\n * @see R.mergeDeepWith, R.merge, R.mergeWithKey\n * @example\n *\n * R.mergeWith(R.concat,\n * { a: true, values: [10, 20] },\n * { b: true, values: [15, 35] });\n * //=> { a: true, b: true, values: [10, 20, 15, 35] }\n */\n\n\nvar mergeWith =\n/*#__PURE__*/\n_curry3(function mergeWith(fn, l, r) {\n return mergeWithKey(function (_, _l, _r) {\n return fn(_l, _r);\n }, l, r);\n});\n\nmodule.exports = mergeWith;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Returns the smaller of its two arguments.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Relation\n * @sig Ord a => a -> a -> a\n * @param {*} a\n * @param {*} b\n * @return {*}\n * @see R.minBy, R.max\n * @example\n *\n * R.min(789, 123); //=> 123\n * R.min('a', 'b'); //=> 'a'\n */\n\n\nvar min =\n/*#__PURE__*/\n_curry2(function min(a, b) {\n return b < a ? b : a;\n});\n\nmodule.exports = min;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n/**\n * Takes a function and two values, and returns whichever value produces the\n * smaller result when passed to the provided function.\n *\n * @func\n * @memberOf R\n * @since v0.8.0\n * @category Relation\n * @sig Ord b => (a -> b) -> a -> a -> a\n * @param {Function} f\n * @param {*} a\n * @param {*} b\n * @return {*}\n * @see R.min, R.maxBy\n * @example\n *\n * // square :: Number -> Number\n * const square = n => n * n;\n *\n * R.minBy(square, -3, 2); //=> 2\n *\n * R.reduce(R.minBy(square), Infinity, [3, -5, 4, 1, -2]); //=> 1\n * R.reduce(R.minBy(square), Infinity, []); //=> Infinity\n */\n\n\nvar minBy =\n/*#__PURE__*/\n_curry3(function minBy(f, a, b) {\n return f(b) < f(a) ? b : a;\n});\n\nmodule.exports = minBy;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Divides the first parameter by the second and returns the remainder. Note\n * that this function preserves the JavaScript-style behavior for modulo. For\n * mathematical modulo see [`mathMod`](#mathMod).\n *\n * @func\n * @memberOf R\n * @since v0.1.1\n * @category Math\n * @sig Number -> Number -> Number\n * @param {Number} a The value to the divide.\n * @param {Number} b The pseudo-modulus\n * @return {Number} The result of `b % a`.\n * @see R.mathMod\n * @example\n *\n * R.modulo(17, 3); //=> 2\n * // JS behavior:\n * R.modulo(-17, 3); //=> -2\n * R.modulo(17, -3); //=> 2\n *\n * const isOdd = R.modulo(R.__, 2);\n * isOdd(42); //=> 0\n * isOdd(21); //=> 1\n */\n\n\nvar modulo =\n/*#__PURE__*/\n_curry2(function modulo(a, b) {\n return a % b;\n});\n\nmodule.exports = modulo;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n/**\n * Move an item, at index `from`, to index `to`, in a list of elements.\n * A new list will be created containing the new elements order.\n *\n * @func\n * @memberOf R\n * @since v0.27.1\n * @category List\n * @sig Number -> Number -> [a] -> [a]\n * @param {Number} from The source index\n * @param {Number} to The destination index\n * @param {Array} list The list which will serve to realise the move\n * @return {Array} The new list reordered\n * @example\n *\n * R.move(0, 2, ['a', 'b', 'c', 'd', 'e', 'f']); //=> ['b', 'c', 'a', 'd', 'e', 'f']\n * R.move(-1, 0, ['a', 'b', 'c', 'd', 'e', 'f']); //=> ['f', 'a', 'b', 'c', 'd', 'e'] list rotation\n */\n\n\nvar move =\n/*#__PURE__*/\n_curry3(function (from, to, list) {\n var length = list.length;\n var result = list.slice();\n var positiveFrom = from < 0 ? length + from : from;\n var positiveTo = to < 0 ? length + to : to;\n var item = result.splice(positiveFrom, 1);\n return positiveFrom < 0 || positiveFrom >= list.length || positiveTo < 0 || positiveTo >= list.length ? list : [].concat(result.slice(0, positiveTo)).concat(item).concat(result.slice(positiveTo, list.length));\n});\n\nmodule.exports = move;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Multiplies two numbers. Equivalent to `a * b` but curried.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Math\n * @sig Number -> Number -> Number\n * @param {Number} a The first value.\n * @param {Number} b The second value.\n * @return {Number} The result of `a * b`.\n * @see R.divide\n * @example\n *\n * const double = R.multiply(2);\n * const triple = R.multiply(3);\n * double(3); //=> 6\n * triple(4); //=> 12\n * R.multiply(2, 5); //=> 10\n */\n\n\nvar multiply =\n/*#__PURE__*/\n_curry2(function multiply(a, b) {\n return a * b;\n});\n\nmodule.exports = multiply;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n/**\n * Negates its argument.\n *\n * @func\n * @memberOf R\n * @since v0.9.0\n * @category Math\n * @sig Number -> Number\n * @param {Number} n\n * @return {Number}\n * @example\n *\n * R.negate(42); //=> -42\n */\n\n\nvar negate =\n/*#__PURE__*/\n_curry1(function negate(n) {\n return -n;\n});\n\nmodule.exports = negate;","var _complement =\n/*#__PURE__*/\nrequire(\"./internal/_complement\");\n\nvar _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar all =\n/*#__PURE__*/\nrequire(\"./all\");\n/**\n * Returns `true` if no elements of the list match the predicate, `false`\n * otherwise.\n *\n * Dispatches to the `all` method of the second argument, if present.\n *\n * Acts as a transducer if a transformer is given in list position.\n *\n * @func\n * @memberOf R\n * @since v0.12.0\n * @category List\n * @sig (a -> Boolean) -> [a] -> Boolean\n * @param {Function} fn The predicate function.\n * @param {Array} list The array to consider.\n * @return {Boolean} `true` if the predicate is not satisfied by every element, `false` otherwise.\n * @see R.all, R.any\n * @example\n *\n * const isEven = n => n % 2 === 0;\n * const isOdd = n => n % 2 === 1;\n *\n * R.none(isEven, [1, 3, 5, 7, 9, 11]); //=> true\n * R.none(isOdd, [1, 3, 5, 7, 8, 11]); //=> false\n */\n\n\nvar none =\n/*#__PURE__*/\n_curry2(function none(fn, input) {\n return all(_complement(fn), input);\n});\n\nmodule.exports = none;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar curryN =\n/*#__PURE__*/\nrequire(\"./curryN\");\n\nvar nth =\n/*#__PURE__*/\nrequire(\"./nth\");\n/**\n * Returns a function which returns its nth argument.\n *\n * @func\n * @memberOf R\n * @since v0.9.0\n * @category Function\n * @sig Number -> *... -> *\n * @param {Number} n\n * @return {Function}\n * @example\n *\n * R.nthArg(1)('a', 'b', 'c'); //=> 'b'\n * R.nthArg(-1)('a', 'b', 'c'); //=> 'c'\n * @symb R.nthArg(-1)(a, b, c) = c\n * @symb R.nthArg(0)(a, b, c) = a\n * @symb R.nthArg(1)(a, b, c) = b\n */\n\n\nvar nthArg =\n/*#__PURE__*/\n_curry1(function nthArg(n) {\n var arity = n < 0 ? 1 : n + 1;\n return curryN(arity, function () {\n return nth(n, arguments);\n });\n});\n\nmodule.exports = nthArg;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n/**\n * `o` is a curried composition function that returns a unary function.\n * Like [`compose`](#compose), `o` performs right-to-left function composition.\n * Unlike [`compose`](#compose), the rightmost function passed to `o` will be\n * invoked with only one argument. Also, unlike [`compose`](#compose), `o` is\n * limited to accepting only 2 unary functions. The name o was chosen because\n * of its similarity to the mathematical composition operator ∘.\n *\n * @func\n * @memberOf R\n * @since v0.24.0\n * @category Function\n * @sig (b -> c) -> (a -> b) -> a -> c\n * @param {Function} f\n * @param {Function} g\n * @return {Function}\n * @see R.compose, R.pipe\n * @example\n *\n * const classyGreeting = name => \"The name's \" + name.last + \", \" + name.first + \" \" + name.last\n * const yellGreeting = R.o(R.toUpper, classyGreeting);\n * yellGreeting({first: 'James', last: 'Bond'}); //=> \"THE NAME'S BOND, JAMES BOND\"\n *\n * R.o(R.multiply(10), R.add(10))(-4) //=> 60\n *\n * @symb R.o(f, g, x) = f(g(x))\n */\n\n\nvar o =\n/*#__PURE__*/\n_curry3(function o(f, g, x) {\n return f(g(x));\n});\n\nmodule.exports = o;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar _of =\n/*#__PURE__*/\nrequire(\"./internal/_of\");\n/**\n * Returns a singleton array containing the value provided.\n *\n * Note this `of` is different from the ES6 `of`; See\n * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/of\n *\n * @func\n * @memberOf R\n * @since v0.3.0\n * @category Function\n * @sig a -> [a]\n * @param {*} x any value\n * @return {Array} An array wrapping `x`.\n * @example\n *\n * R.of(null); //=> [null]\n * R.of([42]); //=> [[42]]\n */\n\n\nvar of =\n/*#__PURE__*/\n_curry1(_of);\n\nmodule.exports = of;","function _of(x) {\n return [x];\n}\n\nmodule.exports = _of;","var _arity =\n/*#__PURE__*/\nrequire(\"./internal/_arity\");\n\nvar _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n/**\n * Accepts a function `fn` and returns a function that guards invocation of\n * `fn` such that `fn` can only ever be called once, no matter how many times\n * the returned function is invoked. The first value calculated is returned in\n * subsequent invocations.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Function\n * @sig (a... -> b) -> (a... -> b)\n * @param {Function} fn The function to wrap in a call-only-once wrapper.\n * @return {Function} The wrapped function.\n * @example\n *\n * const addOneOnce = R.once(x => x + 1);\n * addOneOnce(10); //=> 11\n * addOneOnce(addOneOnce(50)); //=> 11\n */\n\n\nvar once =\n/*#__PURE__*/\n_curry1(function once(fn) {\n var called = false;\n var result;\n return _arity(fn.length, function () {\n if (called) {\n return result;\n }\n\n called = true;\n result = fn.apply(this, arguments);\n return result;\n });\n});\n\nmodule.exports = once;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _assertPromise =\n/*#__PURE__*/\nrequire(\"./internal/_assertPromise\");\n/**\n * Returns the result of applying the onFailure function to the value inside\n * a failed promise. This is useful for handling rejected promises\n * inside function compositions.\n *\n * @func\n * @memberOf R\n * @since v0.26.0\n * @category Function\n * @sig (e -> b) -> (Promise e a) -> (Promise e b)\n * @sig (e -> (Promise f b)) -> (Promise e a) -> (Promise f b)\n * @param {Function} onFailure The function to apply. Can return a value or a promise of a value.\n * @param {Promise} p\n * @return {Promise} The result of calling `p.then(null, onFailure)`\n * @see R.then\n * @example\n *\n * var failedFetch = (id) => Promise.reject('bad ID');\n * var useDefault = () => ({ firstName: 'Bob', lastName: 'Loblaw' })\n *\n * //recoverFromFailure :: String -> Promise ({firstName, lastName})\n * var recoverFromFailure = R.pipe(\n * failedFetch,\n * R.otherwise(useDefault),\n * R.then(R.pick(['firstName', 'lastName'])),\n * );\n * recoverFromFailure(12345).then(console.log)\n */\n\n\nvar otherwise =\n/*#__PURE__*/\n_curry2(function otherwise(f, p) {\n _assertPromise('otherwise', p);\n\n return p.then(null, f);\n});\n\nmodule.exports = otherwise;","var _isFunction =\n/*#__PURE__*/\nrequire(\"./_isFunction\");\n\nvar _toString =\n/*#__PURE__*/\nrequire(\"./_toString\");\n\nfunction _assertPromise(name, p) {\n if (p == null || !_isFunction(p.then)) {\n throw new TypeError('`' + name + '` expected a Promise, received ' + _toString(p, []));\n }\n}\n\nmodule.exports = _assertPromise;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\"); // `Identity` is a functor that holds a single value, where `map` simply\n// transforms the held value with the provided function.\n\n\nvar Identity = function (x) {\n return {\n value: x,\n map: function (f) {\n return Identity(f(x));\n }\n };\n};\n/**\n * Returns the result of \"setting\" the portion of the given data structure\n * focused by the given lens to the result of applying the given function to\n * the focused value.\n *\n * @func\n * @memberOf R\n * @since v0.16.0\n * @category Object\n * @typedefn Lens s a = Functor f => (a -> f a) -> s -> f s\n * @sig Lens s a -> (a -> a) -> s -> s\n * @param {Lens} lens\n * @param {*} v\n * @param {*} x\n * @return {*}\n * @see R.prop, R.lensIndex, R.lensProp\n * @example\n *\n * const headLens = R.lensIndex(0);\n *\n * R.over(headLens, R.toUpper, ['foo', 'bar', 'baz']); //=> ['FOO', 'bar', 'baz']\n */\n\n\nvar over =\n/*#__PURE__*/\n_curry3(function over(lens, f, x) {\n // The value returned by the getter function is first transformed with `f`,\n // then set as the value of an `Identity`. This is then mapped over with the\n // setter function of the lens.\n return lens(function (y) {\n return Identity(f(y));\n })(x).value;\n});\n\nmodule.exports = over;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Takes two arguments, `fst` and `snd`, and returns `[fst, snd]`.\n *\n * @func\n * @memberOf R\n * @since v0.18.0\n * @category List\n * @sig a -> b -> (a,b)\n * @param {*} fst\n * @param {*} snd\n * @return {Array}\n * @see R.objOf, R.of\n * @example\n *\n * R.pair('foo', 'bar'); //=> ['foo', 'bar']\n */\n\n\nvar pair =\n/*#__PURE__*/\n_curry2(function pair(fst, snd) {\n return [fst, snd];\n});\n\nmodule.exports = pair;","var _concat =\n/*#__PURE__*/\nrequire(\"./internal/_concat\");\n\nvar _createPartialApplicator =\n/*#__PURE__*/\nrequire(\"./internal/_createPartialApplicator\");\n/**\n * Takes a function `f` and a list of arguments, and returns a function `g`.\n * When applied, `g` returns the result of applying `f` to the arguments\n * provided initially followed by the arguments provided to `g`.\n *\n * @func\n * @memberOf R\n * @since v0.10.0\n * @category Function\n * @sig ((a, b, c, ..., n) -> x) -> [a, b, c, ...] -> ((d, e, f, ..., n) -> x)\n * @param {Function} f\n * @param {Array} args\n * @return {Function}\n * @see R.partialRight, R.curry\n * @example\n *\n * const multiply2 = (a, b) => a * b;\n * const double = R.partial(multiply2, [2]);\n * double(2); //=> 4\n *\n * const greet = (salutation, title, firstName, lastName) =>\n * salutation + ', ' + title + ' ' + firstName + ' ' + lastName + '!';\n *\n * const sayHello = R.partial(greet, ['Hello']);\n * const sayHelloToMs = R.partial(sayHello, ['Ms.']);\n * sayHelloToMs('Jane', 'Jones'); //=> 'Hello, Ms. Jane Jones!'\n * @symb R.partial(f, [a, b])(c, d) = f(a, b, c, d)\n */\n\n\nvar partial =\n/*#__PURE__*/\n_createPartialApplicator(_concat);\n\nmodule.exports = partial;","var _arity =\n/*#__PURE__*/\nrequire(\"./_arity\");\n\nvar _curry2 =\n/*#__PURE__*/\nrequire(\"./_curry2\");\n\nfunction _createPartialApplicator(concat) {\n return _curry2(function (fn, args) {\n return _arity(Math.max(0, fn.length - args.length), function () {\n return fn.apply(this, concat(args, arguments));\n });\n });\n}\n\nmodule.exports = _createPartialApplicator;","var _concat =\n/*#__PURE__*/\nrequire(\"./internal/_concat\");\n\nvar _createPartialApplicator =\n/*#__PURE__*/\nrequire(\"./internal/_createPartialApplicator\");\n\nvar flip =\n/*#__PURE__*/\nrequire(\"./flip\");\n/**\n * Takes a function `f` and a list of arguments, and returns a function `g`.\n * When applied, `g` returns the result of applying `f` to the arguments\n * provided to `g` followed by the arguments provided initially.\n *\n * @func\n * @memberOf R\n * @since v0.10.0\n * @category Function\n * @sig ((a, b, c, ..., n) -> x) -> [d, e, f, ..., n] -> ((a, b, c, ...) -> x)\n * @param {Function} f\n * @param {Array} args\n * @return {Function}\n * @see R.partial\n * @example\n *\n * const greet = (salutation, title, firstName, lastName) =>\n * salutation + ', ' + title + ' ' + firstName + ' ' + lastName + '!';\n *\n * const greetMsJaneJones = R.partialRight(greet, ['Ms.', 'Jane', 'Jones']);\n *\n * greetMsJaneJones('Hello'); //=> 'Hello, Ms. Jane Jones!'\n * @symb R.partialRight(f, [a, b])(c, d) = f(c, d, a, b)\n */\n\n\nvar partialRight =\n/*#__PURE__*/\n_createPartialApplicator(\n/*#__PURE__*/\nflip(_concat));\n\nmodule.exports = partialRight;","var filter =\n/*#__PURE__*/\nrequire(\"./filter\");\n\nvar juxt =\n/*#__PURE__*/\nrequire(\"./juxt\");\n\nvar reject =\n/*#__PURE__*/\nrequire(\"./reject\");\n/**\n * Takes a predicate and a list or other `Filterable` object and returns the\n * pair of filterable objects of the same type of elements which do and do not\n * satisfy, the predicate, respectively. Filterable objects include plain objects or any object\n * that has a filter method such as `Array`.\n *\n * @func\n * @memberOf R\n * @since v0.1.4\n * @category List\n * @sig Filterable f => (a -> Boolean) -> f a -> [f a, f a]\n * @param {Function} pred A predicate to determine which side the element belongs to.\n * @param {Array} filterable the list (or other filterable) to partition.\n * @return {Array} An array, containing first the subset of elements that satisfy the\n * predicate, and second the subset of elements that do not satisfy.\n * @see R.filter, R.reject\n * @example\n *\n * R.partition(R.includes('s'), ['sss', 'ttt', 'foo', 'bars']);\n * // => [ [ 'sss', 'bars' ], [ 'ttt', 'foo' ] ]\n *\n * R.partition(R.includes('s'), { a: 'sss', b: 'ttt', foo: 'bars' });\n * // => [ { a: 'sss', foo: 'bars' }, { b: 'ttt' } ]\n */\n\n\nvar partition =\n/*#__PURE__*/\njuxt([filter, reject]);\nmodule.exports = partition;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n\nvar equals =\n/*#__PURE__*/\nrequire(\"./equals\");\n\nvar path =\n/*#__PURE__*/\nrequire(\"./path\");\n/**\n * Determines whether a nested path on an object has a specific value, in\n * [`R.equals`](#equals) terms. Most likely used to filter a list.\n *\n * @func\n * @memberOf R\n * @since v0.7.0\n * @category Relation\n * @typedefn Idx = String | Int\n * @sig [Idx] -> a -> {a} -> Boolean\n * @param {Array} path The path of the nested property to use\n * @param {*} val The value to compare the nested property with\n * @param {Object} obj The object to check the nested property in\n * @return {Boolean} `true` if the value equals the nested object property,\n * `false` otherwise.\n * @example\n *\n * const user1 = { address: { zipCode: 90210 } };\n * const user2 = { address: { zipCode: 55555 } };\n * const user3 = { name: 'Bob' };\n * const users = [ user1, user2, user3 ];\n * const isFamous = R.pathEq(['address', 'zipCode'], 90210);\n * R.filter(isFamous, users); //=> [ user1 ]\n */\n\n\nvar pathEq =\n/*#__PURE__*/\n_curry3(function pathEq(_path, val, obj) {\n return equals(path(_path, obj), val);\n});\n\nmodule.exports = pathEq;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n\nvar defaultTo =\n/*#__PURE__*/\nrequire(\"./defaultTo\");\n\nvar path =\n/*#__PURE__*/\nrequire(\"./path\");\n/**\n * If the given, non-null object has a value at the given path, returns the\n * value at that path. Otherwise returns the provided default value.\n *\n * @func\n * @memberOf R\n * @since v0.18.0\n * @category Object\n * @typedefn Idx = String | Int\n * @sig a -> [Idx] -> {a} -> a\n * @param {*} d The default value.\n * @param {Array} p The path to use.\n * @param {Object} obj The object to retrieve the nested property from.\n * @return {*} The data at `path` of the supplied object or the default value.\n * @example\n *\n * R.pathOr('N/A', ['a', 'b'], {a: {b: 2}}); //=> 2\n * R.pathOr('N/A', ['a', 'b'], {c: {b: 2}}); //=> \"N/A\"\n */\n\n\nvar pathOr =\n/*#__PURE__*/\n_curry3(function pathOr(d, p, obj) {\n return defaultTo(d, path(p, obj));\n});\n\nmodule.exports = pathOr;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n\nvar path =\n/*#__PURE__*/\nrequire(\"./path\");\n/**\n * Returns `true` if the specified object property at given path satisfies the\n * given predicate; `false` otherwise.\n *\n * @func\n * @memberOf R\n * @since v0.19.0\n * @category Logic\n * @typedefn Idx = String | Int\n * @sig (a -> Boolean) -> [Idx] -> {a} -> Boolean\n * @param {Function} pred\n * @param {Array} propPath\n * @param {*} obj\n * @return {Boolean}\n * @see R.propSatisfies, R.path\n * @example\n *\n * R.pathSatisfies(y => y > 0, ['x', 'y'], {x: {y: 2}}); //=> true\n * R.pathSatisfies(R.is(Object), [], {x: {y: 2}}); //=> true\n */\n\n\nvar pathSatisfies =\n/*#__PURE__*/\n_curry3(function pathSatisfies(pred, propPath, obj) {\n return pred(path(propPath, obj));\n});\n\nmodule.exports = pathSatisfies;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Similar to `pick` except that this one includes a `key: undefined` pair for\n * properties that don't exist.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Object\n * @sig [k] -> {k: v} -> {k: v}\n * @param {Array} names an array of String property names to copy onto a new object\n * @param {Object} obj The object to copy from\n * @return {Object} A new object with only properties from `names` on it.\n * @see R.pick\n * @example\n *\n * R.pickAll(['a', 'd'], {a: 1, b: 2, c: 3, d: 4}); //=> {a: 1, d: 4}\n * R.pickAll(['a', 'e', 'f'], {a: 1, b: 2, c: 3, d: 4}); //=> {a: 1, e: undefined, f: undefined}\n */\n\n\nvar pickAll =\n/*#__PURE__*/\n_curry2(function pickAll(names, obj) {\n var result = {};\n var idx = 0;\n var len = names.length;\n\n while (idx < len) {\n var name = names[idx];\n result[name] = obj[name];\n idx += 1;\n }\n\n return result;\n});\n\nmodule.exports = pickAll;","var composeK =\n/*#__PURE__*/\nrequire(\"./composeK\");\n\nvar reverse =\n/*#__PURE__*/\nrequire(\"./reverse\");\n/**\n * Returns the left-to-right Kleisli composition of the provided functions,\n * each of which must return a value of a type supported by [`chain`](#chain).\n *\n * `R.pipeK(f, g, h)` is equivalent to `R.pipe(f, R.chain(g), R.chain(h))`.\n *\n * @func\n * @memberOf R\n * @since v0.16.0\n * @category Function\n * @sig Chain m => ((a -> m b), (b -> m c), ..., (y -> m z)) -> (a -> m z)\n * @param {...Function}\n * @return {Function}\n * @see R.composeK\n * @deprecated since v0.26.0\n * @example\n *\n * // parseJson :: String -> Maybe *\n * // get :: String -> Object -> Maybe *\n *\n * // getStateCode :: Maybe String -> Maybe String\n * const getStateCode = R.pipeK(\n * parseJson,\n * get('user'),\n * get('address'),\n * get('state'),\n * R.compose(Maybe.of, R.toUpper)\n * );\n *\n * getStateCode('{\"user\":{\"address\":{\"state\":\"ny\"}}}');\n * //=> Just('NY')\n * getStateCode('[Invalid JSON]');\n * //=> Nothing()\n * @symb R.pipeK(f, g, h)(a) = R.chain(h, R.chain(g, f(a)))\n */\n\n\nfunction pipeK() {\n if (arguments.length === 0) {\n throw new Error('pipeK requires at least one argument');\n }\n\n return composeK.apply(this, reverse(arguments));\n}\n\nmodule.exports = pipeK;","var _concat =\n/*#__PURE__*/\nrequire(\"./internal/_concat\");\n\nvar _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Returns a new list with the given element at the front, followed by the\n * contents of the list.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category List\n * @sig a -> [a] -> [a]\n * @param {*} el The item to add to the head of the output list.\n * @param {Array} list The array to add to the tail of the output list.\n * @return {Array} A new array.\n * @see R.append\n * @example\n *\n * R.prepend('fee', ['fi', 'fo', 'fum']); //=> ['fee', 'fi', 'fo', 'fum']\n */\n\n\nvar prepend =\n/*#__PURE__*/\n_curry2(function prepend(el, list) {\n return _concat([el], list);\n});\n\nmodule.exports = prepend;","var multiply =\n/*#__PURE__*/\nrequire(\"./multiply\");\n\nvar reduce =\n/*#__PURE__*/\nrequire(\"./reduce\");\n/**\n * Multiplies together all the elements of a list.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Math\n * @sig [Number] -> Number\n * @param {Array} list An array of numbers\n * @return {Number} The product of all the numbers in the list.\n * @see R.reduce\n * @example\n *\n * R.product([2,4,6,8,100,1]); //=> 38400\n */\n\n\nvar product =\n/*#__PURE__*/\nreduce(multiply, 1);\nmodule.exports = product;","var _map =\n/*#__PURE__*/\nrequire(\"./internal/_map\");\n\nvar identity =\n/*#__PURE__*/\nrequire(\"./identity\");\n\nvar pickAll =\n/*#__PURE__*/\nrequire(\"./pickAll\");\n\nvar useWith =\n/*#__PURE__*/\nrequire(\"./useWith\");\n/**\n * Reasonable analog to SQL `select` statement.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Object\n * @category Relation\n * @sig [k] -> [{k: v}] -> [{k: v}]\n * @param {Array} props The property names to project\n * @param {Array} objs The objects to query\n * @return {Array} An array of objects with just the `props` properties.\n * @example\n *\n * const abby = {name: 'Abby', age: 7, hair: 'blond', grade: 2};\n * const fred = {name: 'Fred', age: 12, hair: 'brown', grade: 7};\n * const kids = [abby, fred];\n * R.project(['name', 'grade'], kids); //=> [{name: 'Abby', grade: 2}, {name: 'Fred', grade: 7}]\n */\n\n\nvar project =\n/*#__PURE__*/\nuseWith(_map, [pickAll, identity]); // passing `identity` gives correct arity\n\nmodule.exports = project;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar curryN =\n/*#__PURE__*/\nrequire(\"./curryN\");\n/**\n * Accepts a function `fn` and a list of transformer functions and returns a\n * new curried function. When the new function is invoked, it calls the\n * function `fn` with parameters consisting of the result of calling each\n * supplied handler on successive arguments to the new function.\n *\n * If more arguments are passed to the returned function than transformer\n * functions, those arguments are passed directly to `fn` as additional\n * parameters. If you expect additional arguments that don't need to be\n * transformed, although you can ignore them, it's best to pass an identity\n * function so that the new function reports the correct arity.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Function\n * @sig ((x1, x2, ...) -> z) -> [(a -> x1), (b -> x2), ...] -> (a -> b -> ... -> z)\n * @param {Function} fn The function to wrap.\n * @param {Array} transformers A list of transformer functions\n * @return {Function} The wrapped function.\n * @see R.converge\n * @example\n *\n * R.useWith(Math.pow, [R.identity, R.identity])(3, 4); //=> 81\n * R.useWith(Math.pow, [R.identity, R.identity])(3)(4); //=> 81\n * R.useWith(Math.pow, [R.dec, R.inc])(3, 4); //=> 32\n * R.useWith(Math.pow, [R.dec, R.inc])(3)(4); //=> 32\n * @symb R.useWith(f, [g, h])(a, b) = f(g(a), h(b))\n */\n\n\nvar useWith =\n/*#__PURE__*/\n_curry2(function useWith(fn, transformers) {\n return curryN(transformers.length, function () {\n var args = [];\n var idx = 0;\n\n while (idx < transformers.length) {\n args.push(transformers[idx].call(this, arguments[idx]));\n idx += 1;\n }\n\n return fn.apply(this, args.concat(Array.prototype.slice.call(arguments, transformers.length)));\n });\n});\n\nmodule.exports = useWith;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n\nvar equals =\n/*#__PURE__*/\nrequire(\"./equals\");\n/**\n * Returns `true` if the specified object property is equal, in\n * [`R.equals`](#equals) terms, to the given value; `false` otherwise.\n * You can test multiple properties with [`R.whereEq`](#whereEq).\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Relation\n * @sig String -> a -> Object -> Boolean\n * @param {String} name\n * @param {*} val\n * @param {*} obj\n * @return {Boolean}\n * @see R.whereEq, R.propSatisfies, R.equals\n * @example\n *\n * const abby = {name: 'Abby', age: 7, hair: 'blond'};\n * const fred = {name: 'Fred', age: 12, hair: 'brown'};\n * const rusty = {name: 'Rusty', age: 10, hair: 'brown'};\n * const alois = {name: 'Alois', age: 15, disposition: 'surly'};\n * const kids = [abby, fred, rusty, alois];\n * const hasBrownHair = R.propEq('hair', 'brown');\n * R.filter(hasBrownHair, kids); //=> [fred, rusty]\n */\n\n\nvar propEq =\n/*#__PURE__*/\n_curry3(function propEq(name, val, obj) {\n return equals(val, obj[name]);\n});\n\nmodule.exports = propEq;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n\nvar is =\n/*#__PURE__*/\nrequire(\"./is\");\n/**\n * Returns `true` if the specified object property is of the given type;\n * `false` otherwise.\n *\n * @func\n * @memberOf R\n * @since v0.16.0\n * @category Type\n * @sig Type -> String -> Object -> Boolean\n * @param {Function} type\n * @param {String} name\n * @param {*} obj\n * @return {Boolean}\n * @see R.is, R.propSatisfies\n * @example\n *\n * R.propIs(Number, 'x', {x: 1, y: 2}); //=> true\n * R.propIs(Number, 'x', {x: 'foo'}); //=> false\n * R.propIs(Number, 'x', {}); //=> false\n */\n\n\nvar propIs =\n/*#__PURE__*/\n_curry3(function propIs(type, name, obj) {\n return is(type, obj[name]);\n});\n\nmodule.exports = propIs;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n\nvar pathOr =\n/*#__PURE__*/\nrequire(\"./pathOr\");\n/**\n * If the given, non-null object has an own property with the specified name,\n * returns the value of that property. Otherwise returns the provided default\n * value.\n *\n * @func\n * @memberOf R\n * @since v0.6.0\n * @category Object\n * @sig a -> String -> Object -> a\n * @param {*} val The default value.\n * @param {String} p The name of the property to return.\n * @param {Object} obj The object to query.\n * @return {*} The value of given property of the supplied object or the default value.\n * @example\n *\n * const alice = {\n * name: 'ALICE',\n * age: 101\n * };\n * const favorite = R.prop('favoriteLibrary');\n * const favoriteWithDefault = R.propOr('Ramda', 'favoriteLibrary');\n *\n * favorite(alice); //=> undefined\n * favoriteWithDefault(alice); //=> 'Ramda'\n */\n\n\nvar propOr =\n/*#__PURE__*/\n_curry3(function propOr(val, p, obj) {\n return pathOr(val, [p], obj);\n});\n\nmodule.exports = propOr;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n/**\n * Returns `true` if the specified object property satisfies the given\n * predicate; `false` otherwise. You can test multiple properties with\n * [`R.where`](#where).\n *\n * @func\n * @memberOf R\n * @since v0.16.0\n * @category Logic\n * @sig (a -> Boolean) -> String -> {String: a} -> Boolean\n * @param {Function} pred\n * @param {String} name\n * @param {*} obj\n * @return {Boolean}\n * @see R.where, R.propEq, R.propIs\n * @example\n *\n * R.propSatisfies(x => x > 0, 'x', {x: 1, y: 2}); //=> true\n */\n\n\nvar propSatisfies =\n/*#__PURE__*/\n_curry3(function propSatisfies(pred, name, obj) {\n return pred(obj[name]);\n});\n\nmodule.exports = propSatisfies;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar path =\n/*#__PURE__*/\nrequire(\"./path\");\n/**\n * Acts as multiple `prop`: array of keys in, array of values out. Preserves\n * order.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Object\n * @sig [k] -> {k: v} -> [v]\n * @param {Array} ps The property names to fetch\n * @param {Object} obj The object to query\n * @return {Array} The corresponding values or partially applied function.\n * @example\n *\n * R.props(['x', 'y'], {x: 1, y: 2}); //=> [1, 2]\n * R.props(['c', 'a', 'b'], {b: 2, a: 1}); //=> [undefined, 1, 2]\n *\n * const fullName = R.compose(R.join(' '), R.props(['first', 'last']));\n * fullName({last: 'Bullet-Tooth', age: 33, first: 'Tony'}); //=> 'Tony Bullet-Tooth'\n */\n\n\nvar props =\n/*#__PURE__*/\n_curry2(function props(ps, obj) {\n return ps.map(function (p) {\n return path([p], obj);\n });\n});\n\nmodule.exports = props;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _isNumber =\n/*#__PURE__*/\nrequire(\"./internal/_isNumber\");\n/**\n * Returns a list of numbers from `from` (inclusive) to `to` (exclusive).\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category List\n * @sig Number -> Number -> [Number]\n * @param {Number} from The first number in the list.\n * @param {Number} to One more than the last number in the list.\n * @return {Array} The list of numbers in the set `[a, b)`.\n * @example\n *\n * R.range(1, 5); //=> [1, 2, 3, 4]\n * R.range(50, 53); //=> [50, 51, 52]\n */\n\n\nvar range =\n/*#__PURE__*/\n_curry2(function range(from, to) {\n if (!(_isNumber(from) && _isNumber(to))) {\n throw new TypeError('Both arguments to range must be numbers');\n }\n\n var result = [];\n var n = from;\n\n while (n < to) {\n result.push(n);\n n += 1;\n }\n\n return result;\n});\n\nmodule.exports = range;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n/**\n * Returns a single item by iterating through the list, successively calling\n * the iterator function and passing it an accumulator value and the current\n * value from the array, and then passing the result to the next call.\n *\n * Similar to [`reduce`](#reduce), except moves through the input list from the\n * right to the left.\n *\n * The iterator function receives two values: *(value, acc)*, while the arguments'\n * order of `reduce`'s iterator function is *(acc, value)*.\n *\n * Note: `R.reduceRight` does not skip deleted or unassigned indices (sparse\n * arrays), unlike the native `Array.prototype.reduceRight` method. For more details\n * on this behavior, see:\n * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reduceRight#Description\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category List\n * @sig ((a, b) -> b) -> b -> [a] -> b\n * @param {Function} fn The iterator function. Receives two values, the current element from the array\n * and the accumulator.\n * @param {*} acc The accumulator value.\n * @param {Array} list The list to iterate over.\n * @return {*} The final, accumulated value.\n * @see R.reduce, R.addIndex\n * @example\n *\n * R.reduceRight(R.subtract, 0, [1, 2, 3, 4]) // => (1 - (2 - (3 - (4 - 0)))) = -2\n * // - -2\n * // / \\ / \\\n * // 1 - 1 3\n * // / \\ / \\\n * // 2 - ==> 2 -1\n * // / \\ / \\\n * // 3 - 3 4\n * // / \\ / \\\n * // 4 0 4 0\n *\n * @symb R.reduceRight(f, a, [b, c, d]) = f(b, f(c, f(d, a)))\n */\n\n\nvar reduceRight =\n/*#__PURE__*/\n_curry3(function reduceRight(fn, acc, list) {\n var idx = list.length - 1;\n\n while (idx >= 0) {\n acc = fn(list[idx], acc);\n idx -= 1;\n }\n\n return acc;\n});\n\nmodule.exports = reduceRight;","var _curryN =\n/*#__PURE__*/\nrequire(\"./internal/_curryN\");\n\nvar _reduce =\n/*#__PURE__*/\nrequire(\"./internal/_reduce\");\n\nvar _reduced =\n/*#__PURE__*/\nrequire(\"./internal/_reduced\");\n/**\n * Like [`reduce`](#reduce), `reduceWhile` returns a single item by iterating\n * through the list, successively calling the iterator function. `reduceWhile`\n * also takes a predicate that is evaluated before each step. If the predicate\n * returns `false`, it \"short-circuits\" the iteration and returns the current\n * value of the accumulator.\n *\n * @func\n * @memberOf R\n * @since v0.22.0\n * @category List\n * @sig ((a, b) -> Boolean) -> ((a, b) -> a) -> a -> [b] -> a\n * @param {Function} pred The predicate. It is passed the accumulator and the\n * current element.\n * @param {Function} fn The iterator function. Receives two values, the\n * accumulator and the current element.\n * @param {*} a The accumulator value.\n * @param {Array} list The list to iterate over.\n * @return {*} The final, accumulated value.\n * @see R.reduce, R.reduced\n * @example\n *\n * const isOdd = (acc, x) => x % 2 === 1;\n * const xs = [1, 3, 5, 60, 777, 800];\n * R.reduceWhile(isOdd, R.add, 0, xs); //=> 9\n *\n * const ys = [2, 4, 6]\n * R.reduceWhile(isOdd, R.add, 111, ys); //=> 111\n */\n\n\nvar reduceWhile =\n/*#__PURE__*/\n_curryN(4, [], function _reduceWhile(pred, fn, a, list) {\n return _reduce(function (acc, x) {\n return pred(acc, x) ? fn(acc, x) : _reduced(acc);\n }, a, list);\n});\n\nmodule.exports = reduceWhile;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar _reduced =\n/*#__PURE__*/\nrequire(\"./internal/_reduced\");\n/**\n * Returns a value wrapped to indicate that it is the final value of the reduce\n * and transduce functions. The returned value should be considered a black\n * box: the internal structure is not guaranteed to be stable.\n *\n * Note: this optimization is only available to the below functions:\n * - [`reduce`](#reduce)\n * - [`reduceWhile`](#reduceWhile)\n * - [`transduce`](#transduce)\n *\n * @func\n * @memberOf R\n * @since v0.15.0\n * @category List\n * @sig a -> *\n * @param {*} x The final value of the reduce.\n * @return {*} The wrapped value.\n * @see R.reduce, R.reduceWhile, R.transduce\n * @example\n *\n * R.reduce(\n * (acc, item) => item > 3 ? R.reduced(acc) : acc.concat(item),\n * [],\n * [1, 2, 3, 4, 5]) // [1, 2, 3]\n */\n\n\nvar reduced =\n/*#__PURE__*/\n_curry1(_reduced);\n\nmodule.exports = reduced;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar always =\n/*#__PURE__*/\nrequire(\"./always\");\n\nvar times =\n/*#__PURE__*/\nrequire(\"./times\");\n/**\n * Returns a fixed list of size `n` containing a specified identical value.\n *\n * @func\n * @memberOf R\n * @since v0.1.1\n * @category List\n * @sig a -> n -> [a]\n * @param {*} value The value to repeat.\n * @param {Number} n The desired size of the output list.\n * @return {Array} A new array containing `n` `value`s.\n * @see R.times\n * @example\n *\n * R.repeat('hi', 5); //=> ['hi', 'hi', 'hi', 'hi', 'hi']\n *\n * const obj = {};\n * const repeatedObjs = R.repeat(obj, 5); //=> [{}, {}, {}, {}, {}]\n * repeatedObjs[0] === repeatedObjs[1]; //=> true\n * @symb R.repeat(a, 0) = []\n * @symb R.repeat(a, 1) = [a]\n * @symb R.repeat(a, 2) = [a, a]\n */\n\n\nvar repeat =\n/*#__PURE__*/\n_curry2(function repeat(value, n) {\n return times(always(value), n);\n});\n\nmodule.exports = repeat;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Calls an input function `n` times, returning an array containing the results\n * of those function calls.\n *\n * `fn` is passed one argument: The current value of `n`, which begins at `0`\n * and is gradually incremented to `n - 1`.\n *\n * @func\n * @memberOf R\n * @since v0.2.3\n * @category List\n * @sig (Number -> a) -> Number -> [a]\n * @param {Function} fn The function to invoke. Passed one argument, the current value of `n`.\n * @param {Number} n A value between `0` and `n - 1`. Increments after each function call.\n * @return {Array} An array containing the return values of all calls to `fn`.\n * @see R.repeat\n * @example\n *\n * R.times(R.identity, 5); //=> [0, 1, 2, 3, 4]\n * @symb R.times(f, 0) = []\n * @symb R.times(f, 1) = [f(0)]\n * @symb R.times(f, 2) = [f(0), f(1)]\n */\n\n\nvar times =\n/*#__PURE__*/\n_curry2(function times(fn, n) {\n var len = Number(n);\n var idx = 0;\n var list;\n\n if (len < 0 || isNaN(len)) {\n throw new RangeError('n must be a non-negative number');\n }\n\n list = new Array(len);\n\n while (idx < len) {\n list[idx] = fn(idx);\n idx += 1;\n }\n\n return list;\n});\n\nmodule.exports = times;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n/**\n * Replace a substring or regex match in a string with a replacement.\n *\n * The first two parameters correspond to the parameters of the\n * `String.prototype.replace()` function, so the second parameter can also be a\n * function.\n *\n * @func\n * @memberOf R\n * @since v0.7.0\n * @category String\n * @sig RegExp|String -> String -> String -> String\n * @param {RegExp|String} pattern A regular expression or a substring to match.\n * @param {String} replacement The string to replace the matches with.\n * @param {String} str The String to do the search and replacement in.\n * @return {String} The result.\n * @example\n *\n * R.replace('foo', 'bar', 'foo foo foo'); //=> 'bar foo foo'\n * R.replace(/foo/, 'bar', 'foo foo foo'); //=> 'bar foo foo'\n *\n * // Use the \"g\" (global) flag to replace all occurrences:\n * R.replace(/foo/g, 'bar', 'foo foo foo'); //=> 'bar bar bar'\n */\n\n\nvar replace =\n/*#__PURE__*/\n_curry3(function replace(regex, replacement, str) {\n return str.replace(regex, replacement);\n});\n\nmodule.exports = replace;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n/**\n * Scan is similar to [`reduce`](#reduce), but returns a list of successively\n * reduced values from the left\n *\n * @func\n * @memberOf R\n * @since v0.10.0\n * @category List\n * @sig ((a, b) -> a) -> a -> [b] -> [a]\n * @param {Function} fn The iterator function. Receives two values, the accumulator and the\n * current element from the array\n * @param {*} acc The accumulator value.\n * @param {Array} list The list to iterate over.\n * @return {Array} A list of all intermediately reduced values.\n * @see R.reduce, R.mapAccum\n * @example\n *\n * const numbers = [1, 2, 3, 4];\n * const factorials = R.scan(R.multiply, 1, numbers); //=> [1, 1, 2, 6, 24]\n * @symb R.scan(f, a, [b, c]) = [a, f(a, b), f(f(a, b), c)]\n */\n\n\nvar scan =\n/*#__PURE__*/\n_curry3(function scan(fn, acc, list) {\n var idx = 0;\n var len = list.length;\n var result = [acc];\n\n while (idx < len) {\n acc = fn(acc, list[idx]);\n result[idx + 1] = acc;\n idx += 1;\n }\n\n return result;\n});\n\nmodule.exports = scan;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar ap =\n/*#__PURE__*/\nrequire(\"./ap\");\n\nvar map =\n/*#__PURE__*/\nrequire(\"./map\");\n\nvar prepend =\n/*#__PURE__*/\nrequire(\"./prepend\");\n\nvar reduceRight =\n/*#__PURE__*/\nrequire(\"./reduceRight\");\n/**\n * Transforms a [Traversable](https://github.com/fantasyland/fantasy-land#traversable)\n * of [Applicative](https://github.com/fantasyland/fantasy-land#applicative) into an\n * Applicative of Traversable.\n *\n * Dispatches to the `sequence` method of the second argument, if present.\n *\n * @func\n * @memberOf R\n * @since v0.19.0\n * @category List\n * @sig (Applicative f, Traversable t) => (a -> f a) -> t (f a) -> f (t a)\n * @param {Function} of\n * @param {*} traversable\n * @return {*}\n * @see R.traverse\n * @example\n *\n * R.sequence(Maybe.of, [Just(1), Just(2), Just(3)]); //=> Just([1, 2, 3])\n * R.sequence(Maybe.of, [Just(1), Just(2), Nothing()]); //=> Nothing()\n *\n * R.sequence(R.of, Just([1, 2, 3])); //=> [Just(1), Just(2), Just(3)]\n * R.sequence(R.of, Nothing()); //=> [Nothing()]\n */\n\n\nvar sequence =\n/*#__PURE__*/\n_curry2(function sequence(of, traversable) {\n return typeof traversable.sequence === 'function' ? traversable.sequence(of) : reduceRight(function (x, acc) {\n return ap(map(prepend, x), acc);\n }, of([]), traversable);\n});\n\nmodule.exports = sequence;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n\nvar always =\n/*#__PURE__*/\nrequire(\"./always\");\n\nvar over =\n/*#__PURE__*/\nrequire(\"./over\");\n/**\n * Returns the result of \"setting\" the portion of the given data structure\n * focused by the given lens to the given value.\n *\n * @func\n * @memberOf R\n * @since v0.16.0\n * @category Object\n * @typedefn Lens s a = Functor f => (a -> f a) -> s -> f s\n * @sig Lens s a -> a -> s -> s\n * @param {Lens} lens\n * @param {*} v\n * @param {*} x\n * @return {*}\n * @see R.prop, R.lensIndex, R.lensProp\n * @example\n *\n * const xLens = R.lensProp('x');\n *\n * R.set(xLens, 4, {x: 1, y: 2}); //=> {x: 4, y: 2}\n * R.set(xLens, 8, {x: 1, y: 2}); //=> {x: 8, y: 2}\n */\n\n\nvar set =\n/*#__PURE__*/\n_curry3(function set(lens, v, x) {\n return over(lens, always(v), x);\n});\n\nmodule.exports = set;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Returns a copy of the list, sorted according to the comparator function,\n * which should accept two values at a time and return a negative number if the\n * first value is smaller, a positive number if it's larger, and zero if they\n * are equal. Please note that this is a **copy** of the list. It does not\n * modify the original.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category List\n * @sig ((a, a) -> Number) -> [a] -> [a]\n * @param {Function} comparator A sorting function :: a -> b -> Int\n * @param {Array} list The list to sort\n * @return {Array} a new array with its elements sorted by the comparator function.\n * @example\n *\n * const diff = function(a, b) { return a - b; };\n * R.sort(diff, [4,2,7,5]); //=> [2, 4, 5, 7]\n */\n\n\nvar sort =\n/*#__PURE__*/\n_curry2(function sort(comparator, list) {\n return Array.prototype.slice.call(list, 0).sort(comparator);\n});\n\nmodule.exports = sort;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Sorts the list according to the supplied function.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Relation\n * @sig Ord b => (a -> b) -> [a] -> [a]\n * @param {Function} fn\n * @param {Array} list The list to sort.\n * @return {Array} A new list sorted by the keys generated by `fn`.\n * @example\n *\n * const sortByFirstItem = R.sortBy(R.prop(0));\n * const pairs = [[-1, 1], [-2, 2], [-3, 3]];\n * sortByFirstItem(pairs); //=> [[-3, 3], [-2, 2], [-1, 1]]\n *\n * const sortByNameCaseInsensitive = R.sortBy(R.compose(R.toLower, R.prop('name')));\n * const alice = {\n * name: 'ALICE',\n * age: 101\n * };\n * const bob = {\n * name: 'Bob',\n * age: -10\n * };\n * const clara = {\n * name: 'clara',\n * age: 314.159\n * };\n * const people = [clara, bob, alice];\n * sortByNameCaseInsensitive(people); //=> [alice, bob, clara]\n */\n\n\nvar sortBy =\n/*#__PURE__*/\n_curry2(function sortBy(fn, list) {\n return Array.prototype.slice.call(list, 0).sort(function (a, b) {\n var aa = fn(a);\n var bb = fn(b);\n return aa < bb ? -1 : aa > bb ? 1 : 0;\n });\n});\n\nmodule.exports = sortBy;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Sorts a list according to a list of comparators.\n *\n * @func\n * @memberOf R\n * @since v0.23.0\n * @category Relation\n * @sig [(a, a) -> Number] -> [a] -> [a]\n * @param {Array} functions A list of comparator functions.\n * @param {Array} list The list to sort.\n * @return {Array} A new list sorted according to the comarator functions.\n * @example\n *\n * const alice = {\n * name: 'alice',\n * age: 40\n * };\n * const bob = {\n * name: 'bob',\n * age: 30\n * };\n * const clara = {\n * name: 'clara',\n * age: 40\n * };\n * const people = [clara, bob, alice];\n * const ageNameSort = R.sortWith([\n * R.descend(R.prop('age')),\n * R.ascend(R.prop('name'))\n * ]);\n * ageNameSort(people); //=> [alice, clara, bob]\n */\n\n\nvar sortWith =\n/*#__PURE__*/\n_curry2(function sortWith(fns, list) {\n return Array.prototype.slice.call(list, 0).sort(function (a, b) {\n var result = 0;\n var i = 0;\n\n while (result === 0 && i < fns.length) {\n result = fns[i](a, b);\n i += 1;\n }\n\n return result;\n });\n});\n\nmodule.exports = sortWith;","var invoker =\n/*#__PURE__*/\nrequire(\"./invoker\");\n/**\n * Splits a string into an array of strings based on the given\n * separator.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category String\n * @sig (String | RegExp) -> String -> [String]\n * @param {String|RegExp} sep The pattern.\n * @param {String} str The string to separate into an array.\n * @return {Array} The array of strings from `str` separated by `sep`.\n * @see R.join\n * @example\n *\n * const pathComponents = R.split('/');\n * R.tail(pathComponents('/usr/local/bin/node')); //=> ['usr', 'local', 'bin', 'node']\n *\n * R.split('.', 'a.b.c.xyz.d'); //=> ['a', 'b', 'c', 'xyz', 'd']\n */\n\n\nvar split =\n/*#__PURE__*/\ninvoker(1, 'split');\nmodule.exports = split;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar length =\n/*#__PURE__*/\nrequire(\"./length\");\n\nvar slice =\n/*#__PURE__*/\nrequire(\"./slice\");\n/**\n * Splits a given list or string at a given index.\n *\n * @func\n * @memberOf R\n * @since v0.19.0\n * @category List\n * @sig Number -> [a] -> [[a], [a]]\n * @sig Number -> String -> [String, String]\n * @param {Number} index The index where the array/string is split.\n * @param {Array|String} array The array/string to be split.\n * @return {Array}\n * @example\n *\n * R.splitAt(1, [1, 2, 3]); //=> [[1], [2, 3]]\n * R.splitAt(5, 'hello world'); //=> ['hello', ' world']\n * R.splitAt(-1, 'foobar'); //=> ['fooba', 'r']\n */\n\n\nvar splitAt =\n/*#__PURE__*/\n_curry2(function splitAt(index, array) {\n return [slice(0, index, array), slice(index, length(array), array)];\n});\n\nmodule.exports = splitAt;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar slice =\n/*#__PURE__*/\nrequire(\"./slice\");\n/**\n * Splits a collection into slices of the specified length.\n *\n * @func\n * @memberOf R\n * @since v0.16.0\n * @category List\n * @sig Number -> [a] -> [[a]]\n * @sig Number -> String -> [String]\n * @param {Number} n\n * @param {Array} list\n * @return {Array}\n * @example\n *\n * R.splitEvery(3, [1, 2, 3, 4, 5, 6, 7]); //=> [[1, 2, 3], [4, 5, 6], [7]]\n * R.splitEvery(3, 'foobarbaz'); //=> ['foo', 'bar', 'baz']\n */\n\n\nvar splitEvery =\n/*#__PURE__*/\n_curry2(function splitEvery(n, list) {\n if (n <= 0) {\n throw new Error('First argument to splitEvery must be a positive integer');\n }\n\n var result = [];\n var idx = 0;\n\n while (idx < list.length) {\n result.push(slice(idx, idx += n, list));\n }\n\n return result;\n});\n\nmodule.exports = splitEvery;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Takes a list and a predicate and returns a pair of lists with the following properties:\n *\n * - the result of concatenating the two output lists is equivalent to the input list;\n * - none of the elements of the first output list satisfies the predicate; and\n * - if the second output list is non-empty, its first element satisfies the predicate.\n *\n * @func\n * @memberOf R\n * @since v0.19.0\n * @category List\n * @sig (a -> Boolean) -> [a] -> [[a], [a]]\n * @param {Function} pred The predicate that determines where the array is split.\n * @param {Array} list The array to be split.\n * @return {Array}\n * @example\n *\n * R.splitWhen(R.equals(2), [1, 2, 3, 1, 2, 3]); //=> [[1], [2, 3, 1, 2, 3]]\n */\n\n\nvar splitWhen =\n/*#__PURE__*/\n_curry2(function splitWhen(pred, list) {\n var idx = 0;\n var len = list.length;\n var prefix = [];\n\n while (idx < len && !pred(list[idx])) {\n prefix.push(list[idx]);\n idx += 1;\n }\n\n return [prefix, Array.prototype.slice.call(list, idx)];\n});\n\nmodule.exports = splitWhen;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar equals =\n/*#__PURE__*/\nrequire(\"./equals\");\n\nvar take =\n/*#__PURE__*/\nrequire(\"./take\");\n/**\n * Checks if a list starts with the provided sublist.\n *\n * Similarly, checks if a string starts with the provided substring.\n *\n * @func\n * @memberOf R\n * @since v0.24.0\n * @category List\n * @sig [a] -> [a] -> Boolean\n * @sig String -> String -> Boolean\n * @param {*} prefix\n * @param {*} list\n * @return {Boolean}\n * @see R.endsWith\n * @example\n *\n * R.startsWith('a', 'abc') //=> true\n * R.startsWith('b', 'abc') //=> false\n * R.startsWith(['a'], ['a', 'b', 'c']) //=> true\n * R.startsWith(['b'], ['a', 'b', 'c']) //=> false\n */\n\n\nvar startsWith =\n/*#__PURE__*/\n_curry2(function (prefix, list) {\n return equals(take(prefix.length, list), prefix);\n});\n\nmodule.exports = startsWith;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Subtracts its second argument from its first argument.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Math\n * @sig Number -> Number -> Number\n * @param {Number} a The first value.\n * @param {Number} b The second value.\n * @return {Number} The result of `a - b`.\n * @see R.add\n * @example\n *\n * R.subtract(10, 8); //=> 2\n *\n * const minus5 = R.subtract(R.__, 5);\n * minus5(17); //=> 12\n *\n * const complementaryAngle = R.subtract(90);\n * complementaryAngle(30); //=> 60\n * complementaryAngle(72); //=> 18\n */\n\n\nvar subtract =\n/*#__PURE__*/\n_curry2(function subtract(a, b) {\n return Number(a) - Number(b);\n});\n\nmodule.exports = subtract;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar concat =\n/*#__PURE__*/\nrequire(\"./concat\");\n\nvar difference =\n/*#__PURE__*/\nrequire(\"./difference\");\n/**\n * Finds the set (i.e. no duplicates) of all elements contained in the first or\n * second list, but not both.\n *\n * @func\n * @memberOf R\n * @since v0.19.0\n * @category Relation\n * @sig [*] -> [*] -> [*]\n * @param {Array} list1 The first list.\n * @param {Array} list2 The second list.\n * @return {Array} The elements in `list1` or `list2`, but not both.\n * @see R.symmetricDifferenceWith, R.difference, R.differenceWith\n * @example\n *\n * R.symmetricDifference([1,2,3,4], [7,6,5,4,3]); //=> [1,2,7,6,5]\n * R.symmetricDifference([7,6,5,4,3], [1,2,3,4]); //=> [7,6,5,1,2]\n */\n\n\nvar symmetricDifference =\n/*#__PURE__*/\n_curry2(function symmetricDifference(list1, list2) {\n return concat(difference(list1, list2), difference(list2, list1));\n});\n\nmodule.exports = symmetricDifference;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n\nvar concat =\n/*#__PURE__*/\nrequire(\"./concat\");\n\nvar differenceWith =\n/*#__PURE__*/\nrequire(\"./differenceWith\");\n/**\n * Finds the set (i.e. no duplicates) of all elements contained in the first or\n * second list, but not both. Duplication is determined according to the value\n * returned by applying the supplied predicate to two list elements.\n *\n * @func\n * @memberOf R\n * @since v0.19.0\n * @category Relation\n * @sig ((a, a) -> Boolean) -> [a] -> [a] -> [a]\n * @param {Function} pred A predicate used to test whether two items are equal.\n * @param {Array} list1 The first list.\n * @param {Array} list2 The second list.\n * @return {Array} The elements in `list1` or `list2`, but not both.\n * @see R.symmetricDifference, R.difference, R.differenceWith\n * @example\n *\n * const eqA = R.eqBy(R.prop('a'));\n * const l1 = [{a: 1}, {a: 2}, {a: 3}, {a: 4}];\n * const l2 = [{a: 3}, {a: 4}, {a: 5}, {a: 6}];\n * R.symmetricDifferenceWith(eqA, l1, l2); //=> [{a: 1}, {a: 2}, {a: 5}, {a: 6}]\n */\n\n\nvar symmetricDifferenceWith =\n/*#__PURE__*/\n_curry3(function symmetricDifferenceWith(pred, list1, list2) {\n return concat(differenceWith(pred, list1, list2), differenceWith(pred, list2, list1));\n});\n\nmodule.exports = symmetricDifferenceWith;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar slice =\n/*#__PURE__*/\nrequire(\"./slice\");\n/**\n * Returns a new list containing the last `n` elements of a given list, passing\n * each value to the supplied predicate function, and terminating when the\n * predicate function returns `false`. Excludes the element that caused the\n * predicate function to fail. The predicate function is passed one argument:\n * *(value)*.\n *\n * @func\n * @memberOf R\n * @since v0.16.0\n * @category List\n * @sig (a -> Boolean) -> [a] -> [a]\n * @sig (a -> Boolean) -> String -> String\n * @param {Function} fn The function called per iteration.\n * @param {Array} xs The collection to iterate over.\n * @return {Array} A new array.\n * @see R.dropLastWhile, R.addIndex\n * @example\n *\n * const isNotOne = x => x !== 1;\n *\n * R.takeLastWhile(isNotOne, [1, 2, 3, 4]); //=> [2, 3, 4]\n *\n * R.takeLastWhile(x => x !== 'R' , 'Ramda'); //=> 'amda'\n */\n\n\nvar takeLastWhile =\n/*#__PURE__*/\n_curry2(function takeLastWhile(fn, xs) {\n var idx = xs.length - 1;\n\n while (idx >= 0 && fn(xs[idx])) {\n idx -= 1;\n }\n\n return slice(idx + 1, Infinity, xs);\n});\n\nmodule.exports = takeLastWhile;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _dispatchable =\n/*#__PURE__*/\nrequire(\"./internal/_dispatchable\");\n\nvar _xtakeWhile =\n/*#__PURE__*/\nrequire(\"./internal/_xtakeWhile\");\n\nvar slice =\n/*#__PURE__*/\nrequire(\"./slice\");\n/**\n * Returns a new list containing the first `n` elements of a given list,\n * passing each value to the supplied predicate function, and terminating when\n * the predicate function returns `false`. Excludes the element that caused the\n * predicate function to fail. The predicate function is passed one argument:\n * *(value)*.\n *\n * Dispatches to the `takeWhile` method of the second argument, if present.\n *\n * Acts as a transducer if a transformer is given in list position.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category List\n * @sig (a -> Boolean) -> [a] -> [a]\n * @sig (a -> Boolean) -> String -> String\n * @param {Function} fn The function called per iteration.\n * @param {Array} xs The collection to iterate over.\n * @return {Array} A new array.\n * @see R.dropWhile, R.transduce, R.addIndex\n * @example\n *\n * const isNotFour = x => x !== 4;\n *\n * R.takeWhile(isNotFour, [1, 2, 3, 4, 3, 2, 1]); //=> [1, 2, 3]\n *\n * R.takeWhile(x => x !== 'd' , 'Ramda'); //=> 'Ram'\n */\n\n\nvar takeWhile =\n/*#__PURE__*/\n_curry2(\n/*#__PURE__*/\n_dispatchable(['takeWhile'], _xtakeWhile, function takeWhile(fn, xs) {\n var idx = 0;\n var len = xs.length;\n\n while (idx < len && fn(xs[idx])) {\n idx += 1;\n }\n\n return slice(0, idx, xs);\n}));\n\nmodule.exports = takeWhile;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./_curry2\");\n\nvar _reduced =\n/*#__PURE__*/\nrequire(\"./_reduced\");\n\nvar _xfBase =\n/*#__PURE__*/\nrequire(\"./_xfBase\");\n\nvar XTakeWhile =\n/*#__PURE__*/\nfunction () {\n function XTakeWhile(f, xf) {\n this.xf = xf;\n this.f = f;\n }\n\n XTakeWhile.prototype['@@transducer/init'] = _xfBase.init;\n XTakeWhile.prototype['@@transducer/result'] = _xfBase.result;\n\n XTakeWhile.prototype['@@transducer/step'] = function (result, input) {\n return this.f(input) ? this.xf['@@transducer/step'](result, input) : _reduced(result);\n };\n\n return XTakeWhile;\n}();\n\nvar _xtakeWhile =\n/*#__PURE__*/\n_curry2(function _xtakeWhile(f, xf) {\n return new XTakeWhile(f, xf);\n});\n\nmodule.exports = _xtakeWhile;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _dispatchable =\n/*#__PURE__*/\nrequire(\"./internal/_dispatchable\");\n\nvar _xtap =\n/*#__PURE__*/\nrequire(\"./internal/_xtap\");\n/**\n * Runs the given function with the supplied object, then returns the object.\n *\n * Acts as a transducer if a transformer is given as second parameter.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Function\n * @sig (a -> *) -> a -> a\n * @param {Function} fn The function to call with `x`. The return value of `fn` will be thrown away.\n * @param {*} x\n * @return {*} `x`.\n * @example\n *\n * const sayX = x => console.log('x is ' + x);\n * R.tap(sayX, 100); //=> 100\n * // logs 'x is 100'\n * @symb R.tap(f, a) = a\n */\n\n\nvar tap =\n/*#__PURE__*/\n_curry2(\n/*#__PURE__*/\n_dispatchable([], _xtap, function tap(fn, x) {\n fn(x);\n return x;\n}));\n\nmodule.exports = tap;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./_curry2\");\n\nvar _xfBase =\n/*#__PURE__*/\nrequire(\"./_xfBase\");\n\nvar XTap =\n/*#__PURE__*/\nfunction () {\n function XTap(f, xf) {\n this.xf = xf;\n this.f = f;\n }\n\n XTap.prototype['@@transducer/init'] = _xfBase.init;\n XTap.prototype['@@transducer/result'] = _xfBase.result;\n\n XTap.prototype['@@transducer/step'] = function (result, input) {\n this.f(input);\n return this.xf['@@transducer/step'](result, input);\n };\n\n return XTap;\n}();\n\nvar _xtap =\n/*#__PURE__*/\n_curry2(function _xtap(f, xf) {\n return new XTap(f, xf);\n});\n\nmodule.exports = _xtap;","var _cloneRegExp =\n/*#__PURE__*/\nrequire(\"./internal/_cloneRegExp\");\n\nvar _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _isRegExp =\n/*#__PURE__*/\nrequire(\"./internal/_isRegExp\");\n\nvar toString =\n/*#__PURE__*/\nrequire(\"./toString\");\n/**\n * Determines whether a given string matches a given regular expression.\n *\n * @func\n * @memberOf R\n * @since v0.12.0\n * @category String\n * @sig RegExp -> String -> Boolean\n * @param {RegExp} pattern\n * @param {String} str\n * @return {Boolean}\n * @see R.match\n * @example\n *\n * R.test(/^x/, 'xyz'); //=> true\n * R.test(/^y/, 'xyz'); //=> false\n */\n\n\nvar test =\n/*#__PURE__*/\n_curry2(function test(pattern, str) {\n if (!_isRegExp(pattern)) {\n throw new TypeError('‘test’ requires a value of type RegExp as its first argument; received ' + toString(pattern));\n }\n\n return _cloneRegExp(pattern).test(str);\n});\n\nmodule.exports = test;","function _isRegExp(x) {\n return Object.prototype.toString.call(x) === '[object RegExp]';\n}\n\nmodule.exports = _isRegExp;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _assertPromise =\n/*#__PURE__*/\nrequire(\"./internal/_assertPromise\");\n/**\n * Returns the result of applying the onSuccess function to the value inside\n * a successfully resolved promise. This is useful for working with promises\n * inside function compositions.\n *\n * @func\n * @memberOf R\n * @since v0.27.1\n * @category Function\n * @sig (a -> b) -> (Promise e a) -> (Promise e b)\n * @sig (a -> (Promise e b)) -> (Promise e a) -> (Promise e b)\n * @param {Function} onSuccess The function to apply. Can return a value or a promise of a value.\n * @param {Promise} p\n * @return {Promise} The result of calling `p.then(onSuccess)`\n * @see R.otherwise\n * @example\n *\n * var makeQuery = (email) => ({ query: { email }});\n *\n * //getMemberName :: String -> Promise ({firstName, lastName})\n * var getMemberName = R.pipe(\n * makeQuery,\n * fetchMember,\n * R.andThen(R.pick(['firstName', 'lastName']))\n * );\n */\n\n\nvar andThen =\n/*#__PURE__*/\n_curry2(function andThen(f, p) {\n _assertPromise('andThen', p);\n\n return p.then(f);\n});\n\nmodule.exports = andThen;","var invoker =\n/*#__PURE__*/\nrequire(\"./invoker\");\n/**\n * The lower case version of a string.\n *\n * @func\n * @memberOf R\n * @since v0.9.0\n * @category String\n * @sig String -> String\n * @param {String} str The string to lower case.\n * @return {String} The lower case version of `str`.\n * @see R.toUpper\n * @example\n *\n * R.toLower('XYZ'); //=> 'xyz'\n */\n\n\nvar toLower =\n/*#__PURE__*/\ninvoker(0, 'toLowerCase');\nmodule.exports = toLower;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar _has =\n/*#__PURE__*/\nrequire(\"./internal/_has\");\n/**\n * Converts an object into an array of key, value arrays. Only the object's\n * own properties are used.\n * Note that the order of the output array is not guaranteed to be consistent\n * across different JS platforms.\n *\n * @func\n * @memberOf R\n * @since v0.4.0\n * @category Object\n * @sig {String: *} -> [[String,*]]\n * @param {Object} obj The object to extract from\n * @return {Array} An array of key, value arrays from the object's own properties.\n * @see R.fromPairs\n * @example\n *\n * R.toPairs({a: 1, b: 2, c: 3}); //=> [['a', 1], ['b', 2], ['c', 3]]\n */\n\n\nvar toPairs =\n/*#__PURE__*/\n_curry1(function toPairs(obj) {\n var pairs = [];\n\n for (var prop in obj) {\n if (_has(prop, obj)) {\n pairs[pairs.length] = [prop, obj[prop]];\n }\n }\n\n return pairs;\n});\n\nmodule.exports = toPairs;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n/**\n * Converts an object into an array of key, value arrays. The object's own\n * properties and prototype properties are used. Note that the order of the\n * output array is not guaranteed to be consistent across different JS\n * platforms.\n *\n * @func\n * @memberOf R\n * @since v0.4.0\n * @category Object\n * @sig {String: *} -> [[String,*]]\n * @param {Object} obj The object to extract from\n * @return {Array} An array of key, value arrays from the object's own\n * and prototype properties.\n * @example\n *\n * const F = function() { this.x = 'X'; };\n * F.prototype.y = 'Y';\n * const f = new F();\n * R.toPairsIn(f); //=> [['x','X'], ['y','Y']]\n */\n\n\nvar toPairsIn =\n/*#__PURE__*/\n_curry1(function toPairsIn(obj) {\n var pairs = [];\n\n for (var prop in obj) {\n pairs[pairs.length] = [prop, obj[prop]];\n }\n\n return pairs;\n});\n\nmodule.exports = toPairsIn;","var invoker =\n/*#__PURE__*/\nrequire(\"./invoker\");\n/**\n * The upper case version of a string.\n *\n * @func\n * @memberOf R\n * @since v0.9.0\n * @category String\n * @sig String -> String\n * @param {String} str The string to upper case.\n * @return {String} The upper case version of `str`.\n * @see R.toLower\n * @example\n *\n * R.toUpper('abc'); //=> 'ABC'\n */\n\n\nvar toUpper =\n/*#__PURE__*/\ninvoker(0, 'toUpperCase');\nmodule.exports = toUpper;","var _reduce =\n/*#__PURE__*/\nrequire(\"./internal/_reduce\");\n\nvar _xwrap =\n/*#__PURE__*/\nrequire(\"./internal/_xwrap\");\n\nvar curryN =\n/*#__PURE__*/\nrequire(\"./curryN\");\n/**\n * Initializes a transducer using supplied iterator function. Returns a single\n * item by iterating through the list, successively calling the transformed\n * iterator function and passing it an accumulator value and the current value\n * from the array, and then passing the result to the next call.\n *\n * The iterator function receives two values: *(acc, value)*. It will be\n * wrapped as a transformer to initialize the transducer. A transformer can be\n * passed directly in place of an iterator function. In both cases, iteration\n * may be stopped early with the [`R.reduced`](#reduced) function.\n *\n * A transducer is a function that accepts a transformer and returns a\n * transformer and can be composed directly.\n *\n * A transformer is an an object that provides a 2-arity reducing iterator\n * function, step, 0-arity initial value function, init, and 1-arity result\n * extraction function, result. The step function is used as the iterator\n * function in reduce. The result function is used to convert the final\n * accumulator into the return type and in most cases is\n * [`R.identity`](#identity). The init function can be used to provide an\n * initial accumulator, but is ignored by transduce.\n *\n * The iteration is performed with [`R.reduce`](#reduce) after initializing the transducer.\n *\n * @func\n * @memberOf R\n * @since v0.12.0\n * @category List\n * @sig (c -> c) -> ((a, b) -> a) -> a -> [b] -> a\n * @param {Function} xf The transducer function. Receives a transformer and returns a transformer.\n * @param {Function} fn The iterator function. Receives two values, the accumulator and the\n * current element from the array. Wrapped as transformer, if necessary, and used to\n * initialize the transducer\n * @param {*} acc The initial accumulator value.\n * @param {Array} list The list to iterate over.\n * @return {*} The final, accumulated value.\n * @see R.reduce, R.reduced, R.into\n * @example\n *\n * const numbers = [1, 2, 3, 4];\n * const transducer = R.compose(R.map(R.add(1)), R.take(2));\n * R.transduce(transducer, R.flip(R.append), [], numbers); //=> [2, 3]\n *\n * const isOdd = (x) => x % 2 === 1;\n * const firstOddTransducer = R.compose(R.filter(isOdd), R.take(1));\n * R.transduce(firstOddTransducer, R.flip(R.append), [], R.range(0, 100)); //=> [1]\n */\n\n\nvar transduce =\n/*#__PURE__*/\ncurryN(4, function transduce(xf, fn, acc, list) {\n return _reduce(xf(typeof fn === 'function' ? _xwrap(fn) : fn), acc, list);\n});\nmodule.exports = transduce;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n/**\n * Transposes the rows and columns of a 2D list.\n * When passed a list of `n` lists of length `x`,\n * returns a list of `x` lists of length `n`.\n *\n *\n * @func\n * @memberOf R\n * @since v0.19.0\n * @category List\n * @sig [[a]] -> [[a]]\n * @param {Array} list A 2D list\n * @return {Array} A 2D list\n * @example\n *\n * R.transpose([[1, 'a'], [2, 'b'], [3, 'c']]) //=> [[1, 2, 3], ['a', 'b', 'c']]\n * R.transpose([[1, 2, 3], ['a', 'b', 'c']]) //=> [[1, 'a'], [2, 'b'], [3, 'c']]\n *\n * // If some of the rows are shorter than the following rows, their elements are skipped:\n * R.transpose([[10, 11], [20], [], [30, 31, 32]]) //=> [[10, 20, 30], [11, 31], [32]]\n * @symb R.transpose([[a], [b], [c]]) = [a, b, c]\n * @symb R.transpose([[a, b], [c, d]]) = [[a, c], [b, d]]\n * @symb R.transpose([[a, b], [c]]) = [[a, c], [b]]\n */\n\n\nvar transpose =\n/*#__PURE__*/\n_curry1(function transpose(outerlist) {\n var i = 0;\n var result = [];\n\n while (i < outerlist.length) {\n var innerlist = outerlist[i];\n var j = 0;\n\n while (j < innerlist.length) {\n if (typeof result[j] === 'undefined') {\n result[j] = [];\n }\n\n result[j].push(innerlist[j]);\n j += 1;\n }\n\n i += 1;\n }\n\n return result;\n});\n\nmodule.exports = transpose;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n\nvar map =\n/*#__PURE__*/\nrequire(\"./map\");\n\nvar sequence =\n/*#__PURE__*/\nrequire(\"./sequence\");\n/**\n * Maps an [Applicative](https://github.com/fantasyland/fantasy-land#applicative)-returning\n * function over a [Traversable](https://github.com/fantasyland/fantasy-land#traversable),\n * then uses [`sequence`](#sequence) to transform the resulting Traversable of Applicative\n * into an Applicative of Traversable.\n *\n * Dispatches to the `traverse` method of the third argument, if present.\n *\n * @func\n * @memberOf R\n * @since v0.19.0\n * @category List\n * @sig (Applicative f, Traversable t) => (a -> f a) -> (a -> f b) -> t a -> f (t b)\n * @param {Function} of\n * @param {Function} f\n * @param {*} traversable\n * @return {*}\n * @see R.sequence\n * @example\n *\n * // Returns `Maybe.Nothing` if the given divisor is `0`\n * const safeDiv = n => d => d === 0 ? Maybe.Nothing() : Maybe.Just(n / d)\n *\n * R.traverse(Maybe.of, safeDiv(10), [2, 4, 5]); //=> Maybe.Just([5, 2.5, 2])\n * R.traverse(Maybe.of, safeDiv(10), [2, 0, 5]); //=> Maybe.Nothing\n */\n\n\nvar traverse =\n/*#__PURE__*/\n_curry3(function traverse(of, f, traversable) {\n return typeof traversable['fantasy-land/traverse'] === 'function' ? traversable['fantasy-land/traverse'](f, of) : sequence(of, map(f, traversable));\n});\n\nmodule.exports = traverse;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar ws = '\\x09\\x0A\\x0B\\x0C\\x0D\\x20\\xA0\\u1680\\u2000\\u2001\\u2002\\u2003' + '\\u2004\\u2005\\u2006\\u2007\\u2008\\u2009\\u200A\\u202F\\u205F\\u3000\\u2028' + '\\u2029\\uFEFF';\nvar zeroWidth = '\\u200b';\nvar hasProtoTrim = typeof String.prototype.trim === 'function';\n/**\n * Removes (strips) whitespace from both ends of the string.\n *\n * @func\n * @memberOf R\n * @since v0.6.0\n * @category String\n * @sig String -> String\n * @param {String} str The string to trim.\n * @return {String} Trimmed version of `str`.\n * @example\n *\n * R.trim(' xyz '); //=> 'xyz'\n * R.map(R.trim, R.split(',', 'x, y, z')); //=> ['x', 'y', 'z']\n */\n\nvar trim = !hasProtoTrim ||\n/*#__PURE__*/\nws.trim() || !\n/*#__PURE__*/\nzeroWidth.trim() ?\n/*#__PURE__*/\n_curry1(function trim(str) {\n var beginRx = new RegExp('^[' + ws + '][' + ws + ']*');\n var endRx = new RegExp('[' + ws + '][' + ws + ']*$');\n return str.replace(beginRx, '').replace(endRx, '');\n}) :\n/*#__PURE__*/\n_curry1(function trim(str) {\n return str.trim();\n});\nmodule.exports = trim;","var _arity =\n/*#__PURE__*/\nrequire(\"./internal/_arity\");\n\nvar _concat =\n/*#__PURE__*/\nrequire(\"./internal/_concat\");\n\nvar _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * `tryCatch` takes two functions, a `tryer` and a `catcher`. The returned\n * function evaluates the `tryer`; if it does not throw, it simply returns the\n * result. If the `tryer` *does* throw, the returned function evaluates the\n * `catcher` function and returns its result. Note that for effective\n * composition with this function, both the `tryer` and `catcher` functions\n * must return the same type of results.\n *\n * @func\n * @memberOf R\n * @since v0.20.0\n * @category Function\n * @sig (...x -> a) -> ((e, ...x) -> a) -> (...x -> a)\n * @param {Function} tryer The function that may throw.\n * @param {Function} catcher The function that will be evaluated if `tryer` throws.\n * @return {Function} A new function that will catch exceptions and send then to the catcher.\n * @example\n *\n * R.tryCatch(R.prop('x'), R.F)({x: true}); //=> true\n * R.tryCatch(() => { throw 'foo'}, R.always('catched'))('bar') // => 'catched'\n * R.tryCatch(R.times(R.identity), R.always([]))('s') // => []\n * R.tryCatch(() => { throw 'this is not a valid value'}, (err, value)=>({error : err, value }))('bar') // => {'error': 'this is not a valid value', 'value': 'bar'}\n */\n\n\nvar tryCatch =\n/*#__PURE__*/\n_curry2(function _tryCatch(tryer, catcher) {\n return _arity(tryer.length, function () {\n try {\n return tryer.apply(this, arguments);\n } catch (e) {\n return catcher.apply(this, _concat([e], arguments));\n }\n });\n});\n\nmodule.exports = tryCatch;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n/**\n * Takes a function `fn`, which takes a single array argument, and returns a\n * function which:\n *\n * - takes any number of positional arguments;\n * - passes these arguments to `fn` as an array; and\n * - returns the result.\n *\n * In other words, `R.unapply` derives a variadic function from a function which\n * takes an array. `R.unapply` is the inverse of [`R.apply`](#apply).\n *\n * @func\n * @memberOf R\n * @since v0.8.0\n * @category Function\n * @sig ([*...] -> a) -> (*... -> a)\n * @param {Function} fn\n * @return {Function}\n * @see R.apply\n * @example\n *\n * R.unapply(JSON.stringify)(1, 2, 3); //=> '[1,2,3]'\n * @symb R.unapply(f)(a, b) = f([a, b])\n */\n\n\nvar unapply =\n/*#__PURE__*/\n_curry1(function unapply(fn) {\n return function () {\n return fn(Array.prototype.slice.call(arguments, 0));\n };\n});\n\nmodule.exports = unapply;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n\nvar nAry =\n/*#__PURE__*/\nrequire(\"./nAry\");\n/**\n * Wraps a function of any arity (including nullary) in a function that accepts\n * exactly 1 parameter. Any extraneous parameters will not be passed to the\n * supplied function.\n *\n * @func\n * @memberOf R\n * @since v0.2.0\n * @category Function\n * @sig (* -> b) -> (a -> b)\n * @param {Function} fn The function to wrap.\n * @return {Function} A new function wrapping `fn`. The new function is guaranteed to be of\n * arity 1.\n * @see R.binary, R.nAry\n * @example\n *\n * const takesTwoArgs = function(a, b) {\n * return [a, b];\n * };\n * takesTwoArgs.length; //=> 2\n * takesTwoArgs(1, 2); //=> [1, 2]\n *\n * const takesOneArg = R.unary(takesTwoArgs);\n * takesOneArg.length; //=> 1\n * // Only 1 argument is passed to the wrapped function\n * takesOneArg(1, 2); //=> [1, undefined]\n * @symb R.unary(f)(a, b, c) = f(a)\n */\n\n\nvar unary =\n/*#__PURE__*/\n_curry1(function unary(fn) {\n return nAry(1, fn);\n});\n\nmodule.exports = unary;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar curryN =\n/*#__PURE__*/\nrequire(\"./curryN\");\n/**\n * Returns a function of arity `n` from a (manually) curried function.\n *\n * @func\n * @memberOf R\n * @since v0.14.0\n * @category Function\n * @sig Number -> (a -> b) -> (a -> c)\n * @param {Number} length The arity for the returned function.\n * @param {Function} fn The function to uncurry.\n * @return {Function} A new function.\n * @see R.curry\n * @example\n *\n * const addFour = a => b => c => d => a + b + c + d;\n *\n * const uncurriedAddFour = R.uncurryN(4, addFour);\n * uncurriedAddFour(1, 2, 3, 4); //=> 10\n */\n\n\nvar uncurryN =\n/*#__PURE__*/\n_curry2(function uncurryN(depth, fn) {\n return curryN(depth, function () {\n var currentDepth = 1;\n var value = fn;\n var idx = 0;\n var endIdx;\n\n while (currentDepth <= depth && typeof value === 'function') {\n endIdx = currentDepth === depth ? arguments.length : idx + value.length;\n value = value.apply(this, Array.prototype.slice.call(arguments, idx, endIdx));\n currentDepth += 1;\n idx = endIdx;\n }\n\n return value;\n });\n});\n\nmodule.exports = uncurryN;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Builds a list from a seed value. Accepts an iterator function, which returns\n * either false to stop iteration or an array of length 2 containing the value\n * to add to the resulting list and the seed to be used in the next call to the\n * iterator function.\n *\n * The iterator function receives one argument: *(seed)*.\n *\n * @func\n * @memberOf R\n * @since v0.10.0\n * @category List\n * @sig (a -> [b]) -> * -> [b]\n * @param {Function} fn The iterator function. receives one argument, `seed`, and returns\n * either false to quit iteration or an array of length two to proceed. The element\n * at index 0 of this array will be added to the resulting array, and the element\n * at index 1 will be passed to the next call to `fn`.\n * @param {*} seed The seed value.\n * @return {Array} The final list.\n * @example\n *\n * const f = n => n > 50 ? false : [-n, n + 10];\n * R.unfold(f, 10); //=> [-10, -20, -30, -40, -50]\n * @symb R.unfold(f, x) = [f(x)[0], f(f(x)[1])[0], f(f(f(x)[1])[1])[0], ...]\n */\n\n\nvar unfold =\n/*#__PURE__*/\n_curry2(function unfold(fn, seed) {\n var pair = fn(seed);\n var result = [];\n\n while (pair && pair.length) {\n result[result.length] = pair[0];\n pair = fn(pair[1]);\n }\n\n return result;\n});\n\nmodule.exports = unfold;","var _concat =\n/*#__PURE__*/\nrequire(\"./internal/_concat\");\n\nvar _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar compose =\n/*#__PURE__*/\nrequire(\"./compose\");\n\nvar uniq =\n/*#__PURE__*/\nrequire(\"./uniq\");\n/**\n * Combines two lists into a set (i.e. no duplicates) composed of the elements\n * of each list.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Relation\n * @sig [*] -> [*] -> [*]\n * @param {Array} as The first list.\n * @param {Array} bs The second list.\n * @return {Array} The first and second lists concatenated, with\n * duplicates removed.\n * @example\n *\n * R.union([1, 2, 3], [2, 3, 4]); //=> [1, 2, 3, 4]\n */\n\n\nvar union =\n/*#__PURE__*/\n_curry2(\n/*#__PURE__*/\ncompose(uniq, _concat));\n\nmodule.exports = union;","var _concat =\n/*#__PURE__*/\nrequire(\"./internal/_concat\");\n\nvar _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n\nvar uniqWith =\n/*#__PURE__*/\nrequire(\"./uniqWith\");\n/**\n * Combines two lists into a set (i.e. no duplicates) composed of the elements\n * of each list. Duplication is determined according to the value returned by\n * applying the supplied predicate to two list elements.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category Relation\n * @sig ((a, a) -> Boolean) -> [*] -> [*] -> [*]\n * @param {Function} pred A predicate used to test whether two items are equal.\n * @param {Array} list1 The first list.\n * @param {Array} list2 The second list.\n * @return {Array} The first and second lists concatenated, with\n * duplicates removed.\n * @see R.union\n * @example\n *\n * const l1 = [{a: 1}, {a: 2}];\n * const l2 = [{a: 1}, {a: 4}];\n * R.unionWith(R.eqBy(R.prop('a')), l1, l2); //=> [{a: 1}, {a: 2}, {a: 4}]\n */\n\n\nvar unionWith =\n/*#__PURE__*/\n_curry3(function unionWith(pred, list1, list2) {\n return uniqWith(pred, _concat(list1, list2));\n});\n\nmodule.exports = unionWith;","var _includesWith =\n/*#__PURE__*/\nrequire(\"./internal/_includesWith\");\n\nvar _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Returns a new list containing only one copy of each element in the original\n * list, based upon the value returned by applying the supplied predicate to\n * two list elements. Prefers the first item if two items compare equal based\n * on the predicate.\n *\n * @func\n * @memberOf R\n * @since v0.2.0\n * @category List\n * @sig ((a, a) -> Boolean) -> [a] -> [a]\n * @param {Function} pred A predicate used to test whether two items are equal.\n * @param {Array} list The array to consider.\n * @return {Array} The list of unique items.\n * @example\n *\n * const strEq = R.eqBy(String);\n * R.uniqWith(strEq)([1, '1', 2, 1]); //=> [1, 2]\n * R.uniqWith(strEq)([{}, {}]); //=> [{}]\n * R.uniqWith(strEq)([1, '1', 1]); //=> [1]\n * R.uniqWith(strEq)(['1', 1, 1]); //=> ['1']\n */\n\n\nvar uniqWith =\n/*#__PURE__*/\n_curry2(function uniqWith(pred, list) {\n var idx = 0;\n var len = list.length;\n var result = [];\n var item;\n\n while (idx < len) {\n item = list[idx];\n\n if (!_includesWith(pred, item, result)) {\n result[result.length] = item;\n }\n\n idx += 1;\n }\n\n return result;\n});\n\nmodule.exports = uniqWith;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n/**\n * Tests the final argument by passing it to the given predicate function. If\n * the predicate is not satisfied, the function will return the result of\n * calling the `whenFalseFn` function with the same argument. If the predicate\n * is satisfied, the argument is returned as is.\n *\n * @func\n * @memberOf R\n * @since v0.18.0\n * @category Logic\n * @sig (a -> Boolean) -> (a -> a) -> a -> a\n * @param {Function} pred A predicate function\n * @param {Function} whenFalseFn A function to invoke when the `pred` evaluates\n * to a falsy value.\n * @param {*} x An object to test with the `pred` function and\n * pass to `whenFalseFn` if necessary.\n * @return {*} Either `x` or the result of applying `x` to `whenFalseFn`.\n * @see R.ifElse, R.when, R.cond\n * @example\n *\n * let safeInc = R.unless(R.isNil, R.inc);\n * safeInc(null); //=> null\n * safeInc(1); //=> 2\n */\n\n\nvar unless =\n/*#__PURE__*/\n_curry3(function unless(pred, whenFalseFn, x) {\n return pred(x) ? x : whenFalseFn(x);\n});\n\nmodule.exports = unless;","var _identity =\n/*#__PURE__*/\nrequire(\"./internal/_identity\");\n\nvar chain =\n/*#__PURE__*/\nrequire(\"./chain\");\n/**\n * Shorthand for `R.chain(R.identity)`, which removes one level of nesting from\n * any [Chain](https://github.com/fantasyland/fantasy-land#chain).\n *\n * @func\n * @memberOf R\n * @since v0.3.0\n * @category List\n * @sig Chain c => c (c a) -> c a\n * @param {*} list\n * @return {*}\n * @see R.flatten, R.chain\n * @example\n *\n * R.unnest([1, [2], [[3]]]); //=> [1, 2, [3]]\n * R.unnest([[1, 2], [3, 4], [5, 6]]); //=> [1, 2, 3, 4, 5, 6]\n */\n\n\nvar unnest =\n/*#__PURE__*/\nchain(_identity);\nmodule.exports = unnest;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n/**\n * Takes a predicate, a transformation function, and an initial value,\n * and returns a value of the same type as the initial value.\n * It does so by applying the transformation until the predicate is satisfied,\n * at which point it returns the satisfactory value.\n *\n * @func\n * @memberOf R\n * @since v0.20.0\n * @category Logic\n * @sig (a -> Boolean) -> (a -> a) -> a -> a\n * @param {Function} pred A predicate function\n * @param {Function} fn The iterator function\n * @param {*} init Initial value\n * @return {*} Final value that satisfies predicate\n * @example\n *\n * R.until(R.gt(R.__, 100), R.multiply(2))(1) // => 128\n */\n\n\nvar until =\n/*#__PURE__*/\n_curry3(function until(pred, fn, init) {\n var val = init;\n\n while (!pred(val)) {\n val = fn(val);\n }\n\n return val;\n});\n\nmodule.exports = until;","var _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n/**\n * Returns a list of all the properties, including prototype properties, of the\n * supplied object.\n * Note that the order of the output array is not guaranteed to be consistent\n * across different JS platforms.\n *\n * @func\n * @memberOf R\n * @since v0.2.0\n * @category Object\n * @sig {k: v} -> [v]\n * @param {Object} obj The object to extract values from\n * @return {Array} An array of the values of the object's own and prototype properties.\n * @see R.values, R.keysIn\n * @example\n *\n * const F = function() { this.x = 'X'; };\n * F.prototype.y = 'Y';\n * const f = new F();\n * R.valuesIn(f); //=> ['X', 'Y']\n */\n\n\nvar valuesIn =\n/*#__PURE__*/\n_curry1(function valuesIn(obj) {\n var prop;\n var vs = [];\n\n for (prop in obj) {\n vs[vs.length] = obj[prop];\n }\n\n return vs;\n});\n\nmodule.exports = valuesIn;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\"); // `Const` is a functor that effectively ignores the function given to `map`.\n\n\nvar Const = function (x) {\n return {\n value: x,\n 'fantasy-land/map': function () {\n return this;\n }\n };\n};\n/**\n * Returns a \"view\" of the given data structure, determined by the given lens.\n * The lens's focus determines which portion of the data structure is visible.\n *\n * @func\n * @memberOf R\n * @since v0.16.0\n * @category Object\n * @typedefn Lens s a = Functor f => (a -> f a) -> s -> f s\n * @sig Lens s a -> s -> a\n * @param {Lens} lens\n * @param {*} x\n * @return {*}\n * @see R.prop, R.lensIndex, R.lensProp\n * @example\n *\n * const xLens = R.lensProp('x');\n *\n * R.view(xLens, {x: 1, y: 2}); //=> 1\n * R.view(xLens, {x: 4, y: 2}); //=> 4\n */\n\n\nvar view =\n/*#__PURE__*/\n_curry2(function view(lens, x) {\n // Using `Const` effectively ignores the setter function of the `lens`,\n // leaving the value returned by the getter function unmodified.\n return lens(Const)(x).value;\n});\n\nmodule.exports = view;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n/**\n * Tests the final argument by passing it to the given predicate function. If\n * the predicate is satisfied, the function will return the result of calling\n * the `whenTrueFn` function with the same argument. If the predicate is not\n * satisfied, the argument is returned as is.\n *\n * @func\n * @memberOf R\n * @since v0.18.0\n * @category Logic\n * @sig (a -> Boolean) -> (a -> a) -> a -> a\n * @param {Function} pred A predicate function\n * @param {Function} whenTrueFn A function to invoke when the `condition`\n * evaluates to a truthy value.\n * @param {*} x An object to test with the `pred` function and\n * pass to `whenTrueFn` if necessary.\n * @return {*} Either `x` or the result of applying `x` to `whenTrueFn`.\n * @see R.ifElse, R.unless, R.cond\n * @example\n *\n * // truncate :: String -> String\n * const truncate = R.when(\n * R.propSatisfies(R.gt(R.__, 10), 'length'),\n * R.pipe(R.take(10), R.append('…'), R.join(''))\n * );\n * truncate('12345'); //=> '12345'\n * truncate('0123456789ABC'); //=> '0123456789…'\n */\n\n\nvar when =\n/*#__PURE__*/\n_curry3(function when(pred, whenTrueFn, x) {\n return pred(x) ? whenTrueFn(x) : x;\n});\n\nmodule.exports = when;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar _has =\n/*#__PURE__*/\nrequire(\"./internal/_has\");\n/**\n * Takes a spec object and a test object; returns true if the test satisfies\n * the spec. Each of the spec's own properties must be a predicate function.\n * Each predicate is applied to the value of the corresponding property of the\n * test object. `where` returns true if all the predicates return true, false\n * otherwise.\n *\n * `where` is well suited to declaratively expressing constraints for other\n * functions such as [`filter`](#filter) and [`find`](#find).\n *\n * @func\n * @memberOf R\n * @since v0.1.1\n * @category Object\n * @sig {String: (* -> Boolean)} -> {String: *} -> Boolean\n * @param {Object} spec\n * @param {Object} testObj\n * @return {Boolean}\n * @see R.propSatisfies, R.whereEq\n * @example\n *\n * // pred :: Object -> Boolean\n * const pred = R.where({\n * a: R.equals('foo'),\n * b: R.complement(R.equals('bar')),\n * x: R.gt(R.__, 10),\n * y: R.lt(R.__, 20)\n * });\n *\n * pred({a: 'foo', b: 'xxx', x: 11, y: 19}); //=> true\n * pred({a: 'xxx', b: 'xxx', x: 11, y: 19}); //=> false\n * pred({a: 'foo', b: 'bar', x: 11, y: 19}); //=> false\n * pred({a: 'foo', b: 'xxx', x: 10, y: 19}); //=> false\n * pred({a: 'foo', b: 'xxx', x: 11, y: 20}); //=> false\n */\n\n\nvar where =\n/*#__PURE__*/\n_curry2(function where(spec, testObj) {\n for (var prop in spec) {\n if (_has(prop, spec) && !spec[prop](testObj[prop])) {\n return false;\n }\n }\n\n return true;\n});\n\nmodule.exports = where;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar equals =\n/*#__PURE__*/\nrequire(\"./equals\");\n\nvar map =\n/*#__PURE__*/\nrequire(\"./map\");\n\nvar where =\n/*#__PURE__*/\nrequire(\"./where\");\n/**\n * Takes a spec object and a test object; returns true if the test satisfies\n * the spec, false otherwise. An object satisfies the spec if, for each of the\n * spec's own properties, accessing that property of the object gives the same\n * value (in [`R.equals`](#equals) terms) as accessing that property of the\n * spec.\n *\n * `whereEq` is a specialization of [`where`](#where).\n *\n * @func\n * @memberOf R\n * @since v0.14.0\n * @category Object\n * @sig {String: *} -> {String: *} -> Boolean\n * @param {Object} spec\n * @param {Object} testObj\n * @return {Boolean}\n * @see R.propEq, R.where\n * @example\n *\n * // pred :: Object -> Boolean\n * const pred = R.whereEq({a: 1, b: 2});\n *\n * pred({a: 1}); //=> false\n * pred({a: 1, b: 2}); //=> true\n * pred({a: 1, b: 2, c: 3}); //=> true\n * pred({a: 1, b: 1}); //=> false\n */\n\n\nvar whereEq =\n/*#__PURE__*/\n_curry2(function whereEq(spec, testObj) {\n return where(map(equals, spec), testObj);\n});\n\nmodule.exports = whereEq;","var _includes =\n/*#__PURE__*/\nrequire(\"./internal/_includes\");\n\nvar _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n\nvar flip =\n/*#__PURE__*/\nrequire(\"./flip\");\n\nvar reject =\n/*#__PURE__*/\nrequire(\"./reject\");\n/**\n * Returns a new list without values in the first argument.\n * [`R.equals`](#equals) is used to determine equality.\n *\n * Acts as a transducer if a transformer is given in list position.\n *\n * @func\n * @memberOf R\n * @since v0.19.0\n * @category List\n * @sig [a] -> [a] -> [a]\n * @param {Array} list1 The values to be removed from `list2`.\n * @param {Array} list2 The array to remove values from.\n * @return {Array} The new array without values in `list1`.\n * @see R.transduce, R.difference, R.remove\n * @example\n *\n * R.without([1, 2], [1, 2, 1, 3, 4]); //=> [3, 4]\n */\n\n\nvar without =\n/*#__PURE__*/\n_curry2(function (xs, list) {\n return reject(flip(_includes)(xs), list);\n});\n\nmodule.exports = without;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Exclusive disjunction logical operation.\n * Returns `true` if one of the arguments is truthy and the other is falsy.\n * Otherwise, it returns `false`.\n *\n * @func\n * @memberOf R\n * @since v0.27.1\n * @category Logic\n * @sig a -> b -> Boolean\n * @param {Any} a\n * @param {Any} b\n * @return {Boolean} true if one of the arguments is truthy and the other is falsy\n * @see R.or, R.and\n * @example\n *\n * R.xor(true, true); //=> false\n * R.xor(true, false); //=> true\n * R.xor(false, true); //=> true\n * R.xor(false, false); //=> false\n */\n\n\nvar xor =\n/*#__PURE__*/\n_curry2(function xor(a, b) {\n return Boolean(!a ^ !b);\n});\n\nmodule.exports = xor;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Creates a new list out of the two supplied by creating each possible pair\n * from the lists.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category List\n * @sig [a] -> [b] -> [[a,b]]\n * @param {Array} as The first list.\n * @param {Array} bs The second list.\n * @return {Array} The list made by combining each possible pair from\n * `as` and `bs` into pairs (`[a, b]`).\n * @example\n *\n * R.xprod([1, 2], ['a', 'b']); //=> [[1, 'a'], [1, 'b'], [2, 'a'], [2, 'b']]\n * @symb R.xprod([a, b], [c, d]) = [[a, c], [a, d], [b, c], [b, d]]\n */\n\n\nvar xprod =\n/*#__PURE__*/\n_curry2(function xprod(a, b) {\n // = xprodWith(prepend); (takes about 3 times as long...)\n var idx = 0;\n var ilen = a.length;\n var j;\n var jlen = b.length;\n var result = [];\n\n while (idx < ilen) {\n j = 0;\n\n while (j < jlen) {\n result[result.length] = [a[idx], b[j]];\n j += 1;\n }\n\n idx += 1;\n }\n\n return result;\n});\n\nmodule.exports = xprod;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Creates a new list out of the two supplied by pairing up equally-positioned\n * items from both lists. The returned list is truncated to the length of the\n * shorter of the two input lists.\n * Note: `zip` is equivalent to `zipWith(function(a, b) { return [a, b] })`.\n *\n * @func\n * @memberOf R\n * @since v0.1.0\n * @category List\n * @sig [a] -> [b] -> [[a,b]]\n * @param {Array} list1 The first array to consider.\n * @param {Array} list2 The second array to consider.\n * @return {Array} The list made by pairing up same-indexed elements of `list1` and `list2`.\n * @example\n *\n * R.zip([1, 2, 3], ['a', 'b', 'c']); //=> [[1, 'a'], [2, 'b'], [3, 'c']]\n * @symb R.zip([a, b, c], [d, e, f]) = [[a, d], [b, e], [c, f]]\n */\n\n\nvar zip =\n/*#__PURE__*/\n_curry2(function zip(a, b) {\n var rv = [];\n var idx = 0;\n var len = Math.min(a.length, b.length);\n\n while (idx < len) {\n rv[idx] = [a[idx], b[idx]];\n idx += 1;\n }\n\n return rv;\n});\n\nmodule.exports = zip;","var _curry2 =\n/*#__PURE__*/\nrequire(\"./internal/_curry2\");\n/**\n * Creates a new object out of a list of keys and a list of values.\n * Key/value pairing is truncated to the length of the shorter of the two lists.\n * Note: `zipObj` is equivalent to `pipe(zip, fromPairs)`.\n *\n * @func\n * @memberOf R\n * @since v0.3.0\n * @category List\n * @sig [String] -> [*] -> {String: *}\n * @param {Array} keys The array that will be properties on the output object.\n * @param {Array} values The list of values on the output object.\n * @return {Object} The object made by pairing up same-indexed elements of `keys` and `values`.\n * @example\n *\n * R.zipObj(['a', 'b', 'c'], [1, 2, 3]); //=> {a: 1, b: 2, c: 3}\n */\n\n\nvar zipObj =\n/*#__PURE__*/\n_curry2(function zipObj(keys, values) {\n var idx = 0;\n var len = Math.min(keys.length, values.length);\n var out = {};\n\n while (idx < len) {\n out[keys[idx]] = values[idx];\n idx += 1;\n }\n\n return out;\n});\n\nmodule.exports = zipObj;","var _curry3 =\n/*#__PURE__*/\nrequire(\"./internal/_curry3\");\n/**\n * Creates a new list out of the two supplied by applying the function to each\n * equally-positioned pair in the lists. The returned list is truncated to the\n * length of the shorter of the two input lists.\n *\n * @function\n * @memberOf R\n * @since v0.1.0\n * @category List\n * @sig ((a, b) -> c) -> [a] -> [b] -> [c]\n * @param {Function} fn The function used to combine the two elements into one value.\n * @param {Array} list1 The first array to consider.\n * @param {Array} list2 The second array to consider.\n * @return {Array} The list made by combining same-indexed elements of `list1` and `list2`\n * using `fn`.\n * @example\n *\n * const f = (x, y) => {\n * // ...\n * };\n * R.zipWith(f, [1, 2, 3], ['a', 'b', 'c']);\n * //=> [f(1, 'a'), f(2, 'b'), f(3, 'c')]\n * @symb R.zipWith(fn, [a, b, c], [d, e, f]) = [fn(a, d), fn(b, e), fn(c, f)]\n */\n\n\nvar zipWith =\n/*#__PURE__*/\n_curry3(function zipWith(fn, a, b) {\n var rv = [];\n var idx = 0;\n var len = Math.min(a.length, b.length);\n\n while (idx < len) {\n rv[idx] = fn(a[idx], b[idx]);\n idx += 1;\n }\n\n return rv;\n});\n\nmodule.exports = zipWith;","var curryN =\n/*#__PURE__*/\nrequire(\"./curryN\");\n\nvar _curry1 =\n/*#__PURE__*/\nrequire(\"./internal/_curry1\");\n/**\n * Creates a thunk out of a function. A thunk delays a calculation until\n * its result is needed, providing lazy evaluation of arguments.\n *\n * @func\n * @memberOf R\n * @since v0.26.0\n * @category Function\n * @sig ((a, b, ..., j) -> k) -> (a, b, ..., j) -> (() -> k)\n * @param {Function} fn A function to wrap in a thunk\n * @return {Function} Expects arguments for `fn` and returns a new function\n * that, when called, applies those arguments to `fn`.\n * @see R.partial, R.partialRight\n * @example\n *\n * R.thunkify(R.identity)(42)(); //=> 42\n * R.thunkify((a, b) => a + b)(25, 17)(); //=> 42\n */\n\n\nvar thunkify =\n/*#__PURE__*/\n_curry1(function thunkify(fn) {\n return curryN(fn.length, function createThunk() {\n var fnArgs = arguments;\n return function invokeThunk() {\n return fn.apply(this, fnArgs);\n };\n });\n});\n\nmodule.exports = thunkify;","import MarkedList from './MarkedList';\n\nexport * from './shared-types';\nexport * from './MarkerBox';\nexport * from './MarkedList';\nexport * from './MarkedListItem';\nexport { default as MarkerBox } from './MarkerBox';\nexport { default as MarkedListItem } from './MarkedListItem';\nexport { default as useMarkedList } from './useMarkedList';\nexport { MarkedList };\nexport default MarkedList;\n","import React, { Children, Fragment, PropsWithChildren } from 'react';\nimport MarkedListItem from './MarkedListItem';\nimport { MarkedListProps } from './shared-types';\nimport useMarkedList from './useMarkedList';\n\n/**\n * A component which given a counter style, wraps each of its children with a\n * {@link MarkedListItem}. The latter prepends the child with a marker\n * box containing a marker string representation for this child index.\n *\n * See {@link https://www.w3.org/TR/css-lists-3/#markers | CSS Lists and Counters Module Level 3, Markers}.\n *\n * @public\n */\nexport default function MarkedList({\n children,\n Container = Fragment,\n ...props\n}: PropsWithChildren) {\n const normalChildren = Children.toArray(children);\n const listProps = useMarkedList({ ...props, length: normalChildren.length });\n return React.createElement(\n Container,\n {},\n normalChildren.map((child, index) => {\n return (\n \n {child}\n \n );\n })\n );\n}\n","import React, { PropsWithChildren } from 'react';\nimport { StyleProp, StyleSheet, View, ViewStyle } from 'react-native';\nimport { MarkedListProps } from './shared-types';\n\n/**\n * Props for the {@link MarkedListItem} component.\n *\n * @public\n */\nexport type MarkedListItemProps = Required<\n Pick<\n MarkedListProps,\n | 'counterRenderer'\n | 'renderMarker'\n | 'markerTextStyle'\n | 'markerBoxStyle'\n | 'rtlLineReversed'\n | 'rtlMarkerReversed'\n | 'startIndex'\n >\n> & {\n index: number;\n markerTextWidth: number | false;\n maxNumOfCodepoints: number;\n enableMarkerClipping: boolean;\n style: StyleProp;\n};\n\n/**\n * A component which reproduces CSS3 `display: list-item;` behavior. It\n * prepends its child with a marker box containing a marker string\n * representation for this child index.\n *\n * See {@link https://www.w3.org/TR/css-lists-3/#markers | CSS Lists and Counters Module Level 3, Markers}.\n *\n * @public\n */\nexport default function MarkedListItem({\n counterRenderer,\n index,\n startIndex,\n rtlLineReversed,\n rtlMarkerReversed,\n markerTextStyle,\n markerBoxStyle,\n maxNumOfCodepoints,\n markerTextWidth,\n style,\n renderMarker,\n enableMarkerClipping,\n children\n}: PropsWithChildren) {\n return (\n \n {renderMarker({\n counterRenderer,\n rtlMarkerReversed:\n typeof rtlMarkerReversed === 'boolean' ? rtlMarkerReversed : true,\n counterIndex: index + startIndex,\n maxNumOfCodepoints,\n style: markerBoxStyle,\n markerTextStyle,\n markerTextWidth,\n enableMarkerClipping\n })}\n {children}\n \n );\n}\n\nconst styles = StyleSheet.create({\n lineLtr: { flexWrap: 'nowrap', alignSelf: 'stretch', flexDirection: 'row' },\n lineRtl: {\n flexWrap: 'nowrap',\n alignSelf: 'stretch',\n flexDirection: 'row-reverse'\n }\n});\n","import React, { useMemo } from 'react';\nimport { I18nManager } from 'react-native';\nimport MarkerBox from './MarkerBox';\nimport { MarkedListItemProps } from './MarkedListItem';\nimport { MarkedListProps } from './shared-types';\n\nconst defaultRenderMarker: NonNullable = (\n props\n) => React.createElement(MarkerBox, props);\n\nconst defaultComputeMarkerBoxWidth: NonNullable<\n MarkedListProps['computeMarkerBoxWidth']\n> = (maxNumOfCodepoints, fontSize) => maxNumOfCodepoints * fontSize * 0.6;\n\nconst DEFAULT_FONT_SIZE = 14;\n\n/**\n * A hook to reuse MarkedList logic to render custom lists components in\n * combination with {@link MarkedListItem}.\n *\n * @public\n */\nexport default function useMarkedList({\n counterRenderer,\n startIndex = 1,\n lineStyle,\n rtlLineReversed = false,\n rtlMarkerReversed = false,\n markerTextStyle,\n markerBoxStyle,\n dynamicMarkerBoxWidth = true,\n length = 0,\n renderMarker = defaultRenderMarker,\n enableMarkerClipping = false,\n computeMarkerBoxWidth = defaultComputeMarkerBoxWidth\n}: MarkedListProps & { length: number }): Omit {\n const maxNumOfCodepoints = useMemo(\n () =>\n counterRenderer.maxMarkerLenInRange(startIndex, startIndex + length - 1),\n [counterRenderer, length, startIndex]\n );\n const syntheticRtlLineReversed = !I18nManager.isRTL && rtlLineReversed;\n const markerTextWidth = useMemo(\n () =>\n dynamicMarkerBoxWidth &&\n computeMarkerBoxWidth(\n maxNumOfCodepoints,\n markerTextStyle?.fontSize ?? DEFAULT_FONT_SIZE\n ),\n [\n computeMarkerBoxWidth,\n markerTextStyle?.fontSize,\n maxNumOfCodepoints,\n dynamicMarkerBoxWidth\n ]\n );\n const renderer = useMemo(\n () =>\n rtlMarkerReversed\n ? counterRenderer.withRtl(\n rtlMarkerReversed === true ? undefined : rtlMarkerReversed\n )\n : counterRenderer,\n [counterRenderer, rtlMarkerReversed]\n );\n const syntheticMarkerTextStyle = useMemo(\n () =>\n ({\n flexGrow: 0,\n flexShrink: 0,\n fontSize: DEFAULT_FONT_SIZE,\n textAlign: syntheticRtlLineReversed ? 'left' : 'right',\n alignSelf: syntheticRtlLineReversed ? 'flex-start' : 'flex-end',\n ...markerTextStyle\n } as const),\n [markerTextStyle, syntheticRtlLineReversed]\n );\n return {\n maxNumOfCodepoints,\n rtlMarkerReversed,\n markerTextWidth,\n renderMarker,\n startIndex,\n rtlLineReversed: syntheticRtlLineReversed,\n markerTextStyle: syntheticMarkerTextStyle,\n markerBoxStyle: markerBoxStyle as any,\n counterRenderer: renderer,\n style: lineStyle,\n enableMarkerClipping\n };\n}\n","import React from 'react';\nimport { Text, TextProps, View } from 'react-native';\nimport { MarkerBoxProps } from './shared-types';\n\nconst markerClipConfig: Partial = {\n numberOfLines: 1,\n ellipsizeMode: 'clip'\n};\n\n/**\n * Default component to render the list marker.\n *\n * See {@link https://www.w3.org/TR/css-lists-3/#marker-pseudo | CSS Lists and Counters Module Level 3, Markers}\n *\n * @public\n */\nexport default function MarkerBox({\n style,\n counterRenderer,\n counterIndex,\n markerTextStyle,\n markerTextWidth,\n enableMarkerClipping\n}: MarkerBoxProps) {\n const markerStyle =\n typeof markerTextWidth === 'number'\n ? [markerTextStyle, { width: markerTextWidth }]\n : markerTextStyle;\n return (\n \n \n {counterRenderer.renderMarker(counterIndex)}\n \n \n );\n}\n","import type { CounterStyleRenderer, RtlOptions } from '@jsamr/counter-style';\nimport type { ComponentType, ReactNode } from 'react';\nimport type { StyleProp, ViewStyle, TextStyle } from 'react-native';\n\n/**\n * Props for the {@link MarkerBox} component.\n *\n * @public\n */\nexport interface MarkerBoxProps {\n /**\n * Style for the container `Text` element.\n */\n style: StyleProp;\n /**\n * Style for any text element. Should not contain CSS box model properties.\n */\n markerTextStyle: TextStyle;\n /**\n * The width for the marker text element.\n */\n markerTextWidth: number | false;\n /**\n * The renderer to generate the marker string.\n */\n counterRenderer: CounterStyleRenderer;\n /**\n * The index to render.\n */\n counterIndex: number;\n /**\n * The maximum length of the `markerString` in range.\n */\n maxNumOfCodepoints: number;\n /**\n * Whether to reverse or not the order of elements in marker (prefix,\n * counter, suffix).\n */\n rtlMarkerReversed: boolean;\n /**\n * Clip the marker text when it overflows the marker box.\n */\n enableMarkerClipping: boolean;\n}\n\n/**\n * Props for the {@link MarkedList} component.\n *\n * @public\n */\nexport interface MarkedListProps {\n /**\n * The counter renderer for this list.\n */\n counterRenderer: CounterStyleRenderer;\n /**\n * Set the line layout in `flexDirection: 'row-reverse'` and left-align the\n * marker box.\n *\n * @remarks Will be ignored if `I18nManager.isRTL` is `true`.\n *\n * @defaultValue false\n */\n rtlLineReversed?: boolean;\n /**\n * Should the marker string be rendered in reverse order?\n *\n * @remarks Fine-grained options are available when you provide an option\n * object. See `@jsamr/counter-style` documentation.\n *\n * @defaultValue false\n */\n rtlMarkerReversed?: true | false | RtlOptions;\n /**\n * Should the width of the marker box be computed dynamically, e.g. depend on\n * the longest marker in the list?\n *\n * @defaultValue true\n */\n dynamicMarkerBoxWidth?: boolean;\n /**\n * The index for the first item in the list. Negative indexes are supported.\n *\n * @defaultValue 1\n */\n startIndex?: number;\n /**\n * Style for the line wrapper.\n */\n lineStyle?: StyleProp;\n /**\n * A plain JavaScript object text style for the marker string. It is\n * advised to pass the same `fontSize` and `lineHeight` as the list content\n * for perfect horizontal alignment.\n *\n * @remarks It should not contain CSS box model properties and it should be a\n * plain JavaScript object. **Do not** use StyleSheet or array styles.\n */\n markerTextStyle?: TextStyle;\n /**\n * Style for the marker box container.\n *\n * @remarks It is discouraged to set\n * `(min,max)width` when {@link MarkedListProps.dynamicMarkerBoxWidth} is set\n * to `true`. In that case, use {@link MarkedListProps.computeMarkerBoxWidth}\n * instead.\n */\n markerBoxStyle?: StyleProp;\n /**\n * A function to compute marker box width depending on the maximum length of\n * the marker string in range.\n *\n * @remarks\n * - Font size is derived from `markerStyle` prop.\n * - Will be ignored when {@link MarkedListProps.dynamicMarkerBoxWidth} is\n * set to `false`.\n */\n computeMarkerBoxWidth?: (\n maxCodepointsLengthInRange: number,\n fontSize: number\n ) => number;\n /**\n * A custom Marker render function.\n *\n * @remarks You are advised to use {@link MarkerBox} component.\n */\n renderMarker?: (props: MarkerBoxProps) => ReactNode;\n /**\n * The component used to wrap list elements.\n *\n * @defaultValue Fragment\n */\n Container?: ComponentType;\n /**\n * Clip the marker text when it overflows the marker box.\n *\n * @defaultValue false\n */\n enableMarkerClipping?: boolean;\n}\n","import React from 'react';\nimport { InternalBlockRenderer } from '../render/render-types';\nimport {\n InternalRendererProps,\n DefaultSupportedListStyleType\n} from '../shared-types';\nimport { TBlock } from '@native-html/transient-render-engine';\nimport ULElement, { ULElementProps } from '../elements/ULElement';\nimport { useRendererProps } from '../context/RenderersPropsProvider';\n\nfunction getFallbackListStyleTypeFromNestLevel(\n nestLevel: number\n): DefaultSupportedListStyleType {\n switch (nestLevel % 3) {\n case 0:\n return 'disc';\n\n /* istanbul ignore next */\n case 1:\n return 'circle';\n\n /* istanbul ignore next */\n default:\n return 'square';\n }\n}\n\nexport function useULElementProps(\n props: InternalRendererProps\n): ULElementProps {\n const config = useRendererProps('ul');\n return {\n ...props,\n getFallbackListStyleTypeFromNestLevel,\n ...config\n };\n}\n\nconst ULRenderer: InternalBlockRenderer = (props) => {\n return React.createElement(ULElement, useULElementProps(props));\n};\n\nexport default ULRenderer;\n","import React from 'react';\nimport ListElement, { ListElementProps } from './ListElement';\n\nexport type ULElementProps = Omit, 'listType'>;\n\nexport default function ULElement(props: ULElementProps) {\n return React.createElement(ListElement, {\n ...props,\n listType: 'ul'\n });\n}\n","import React from 'react';\nimport { Text } from 'react-native';\nimport { TPhrasing, TText } from '@native-html/transient-render-engine';\nimport { TDefaultRendererProps } from './shared-types';\nimport getNativePropsForTNode from './helpers/getNativePropsForTNode';\n\nconst renderTextualContent = (\n props: TDefaultRendererProps\n) => {\n return React.createElement(Text, getNativePropsForTNode(props));\n};\n\nexport default renderTextualContent;\n","import React from 'react';\nimport { TDefaultRendererProps } from './shared-types';\nimport GenericPressable from './GenericPressable';\nimport getNativePropsForTNode from './helpers/getNativePropsForTNode';\nimport { View } from 'react-native';\nimport { TBlock } from '@native-html/transient-render-engine';\n\nfunction renderBlockContent(props: TDefaultRendererProps) {\n const nativeProps = getNativePropsForTNode(props);\n return React.createElement(\n typeof nativeProps.onPress === 'function' ? GenericPressable : View,\n nativeProps\n );\n}\nexport default renderBlockContent;\n","import { TNode } from '@native-html/transient-render-engine';\nimport { TNodeSubRendererProps } from './internal-types';\n\nfunction renderEmptyContent({ tnode }: TNodeSubRendererProps) {\n if (typeof __DEV__ !== 'undefined' && __DEV__) {\n if (tnode.isUnregistered) {\n console.warn(\n `There is no custom renderer registered for tag \"${tnode.tagName}\" which is not part of the HTML5 standard. The tag will not be rendered.` +\n ' If you don\\'t want this tag to be rendered, add it to \"ignoredDomTags\" prop array. If you do, register an HTMLElementModel for this tag with \"customHTMLElementModels\" prop.'\n );\n } else if (tnode.tagName !== 'head') {\n console.warn(\n `The \"${tnode.tagName}\" tag is a valid HTML element but is not handled by this library. You must extend the default HTMLElementModel for this tag with \"customHTMLElementModels\" prop and make sure its content model is not set to \"none\".` +\n ' If you don\\'t want this tag to be rendered, add it to \"ignoredDomTags\" prop array.'\n );\n }\n }\n return null;\n}\n\nexport default renderEmptyContent;\n","import { TNode } from '@native-html/transient-render-engine';\nimport getCollapsedMarginTop from './getCollapsedMarginTop';\n\nfunction isCollapsible(tnode: TNode) {\n return tnode.type === 'block' || tnode.type === 'phrasing';\n}\n\n/**\n * Compute top collapsed margin for the nth {@link TNode}-child of a list of\n * TNodes.\n *\n * @param n - The index for which the top margin should be collapsed.\n * @param tchildren - The list of {@link TNode} children.\n * @returns `null` when no margin collapsing should apply, a number otherwise.\n * @public\n */\nexport default function collapseTopMarginForChild(\n n: number,\n tchildren: readonly TNode[]\n): number | null {\n const childTnode = tchildren[n];\n if (isCollapsible(childTnode) && n > 0 && isCollapsible(tchildren[n - 1])) {\n return getCollapsedMarginTop(tchildren[n - 1], childTnode);\n }\n return null;\n}\n","import { TNode } from '@native-html/transient-render-engine';\n\n/**\n * Compute a TNode top margin to satisfy requirements expressed in CSS\n * standard regarding margin collapsing.\n *\n * See https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Box_Model/Mastering_margin_collapsing\n * for a reference.\n *\n * @param precedent - The node above the one for which we need to compute top margin.\n * @param current - The node for which a margin top might collapse.\n */\nexport default function getCollapsedMarginTop(\n precedent: TNode,\n current: TNode\n): null | number {\n const topMostMarginBottom =\n typeof precedent.styles.nativeBlockRet.marginBottom === 'number'\n ? precedent.styles.nativeBlockRet.marginBottom\n : null;\n const bottomMostMarginTop =\n typeof current.styles.nativeBlockRet.marginTop === 'number'\n ? current.styles.nativeBlockRet.marginTop\n : null;\n if (topMostMarginBottom == null || bottomMostMarginTop == null) {\n return null;\n }\n if (topMostMarginBottom < 0 && bottomMostMarginTop < 0) {\n return (\n Math.min(topMostMarginBottom, bottomMostMarginTop) - topMostMarginBottom\n );\n }\n if (topMostMarginBottom < 0 || bottomMostMarginTop < 0) {\n return topMostMarginBottom + bottomMostMarginTop - topMostMarginBottom;\n }\n if (topMostMarginBottom > bottomMostMarginTop) {\n return 0;\n }\n return bottomMostMarginTop - topMostMarginBottom;\n}\n","import { FunctionComponent } from 'react';\nimport { TChildrenRendererProps } from './shared-types';\nimport renderChildren from './renderChildren';\n\n/**\n * A component to render collections of tnodes.\n * Especially useful when used with {@link useTNodeChildrenProps}.\n */\nconst TChildrenRenderer: FunctionComponent =\n renderChildren.bind(null);\n\nexport const tchildrenRendererDefaultProps: Pick<\n TChildrenRendererProps,\n 'propsForChildren'\n> = {\n propsForChildren: {}\n};\n\n/**\n * @ignore\n */\nTChildrenRenderer.defaultProps = tchildrenRendererDefaultProps;\n\nexport default TChildrenRenderer;\n","import React from 'react';\nimport { ActivityIndicator, StyleSheet, Text, View } from 'react-native';\nimport { RenderHTMLConfig, HTMLSourceUri } from '../shared-types';\n\nconst styles = StyleSheet.create({\n alignCenter: {\n flex: 1,\n alignItems: 'center',\n justifyContent: 'center'\n },\n errorText: {\n fontStyle: 'italic',\n fontSize: 16\n }\n});\n\nexport function defaultRenderError(source: HTMLSourceUri) {\n return (\n \n \n Failed to load HTML from {source.uri}\n \n \n );\n}\n\nexport function defaultRenderLoading() {\n return (\n \n \n \n );\n}\n\nconst sourceLoaderContext = React.createContext<\n Pick, 'remoteErrorView' | 'remoteLoadingView'>\n>({\n remoteErrorView: defaultRenderError,\n remoteLoadingView: defaultRenderLoading\n});\n\nexport default sourceLoaderContext;\n","import equals from 'ramda/src/equals';\nimport React, { memo, ReactElement, useMemo } from 'react';\nimport { Dimensions } from 'react-native';\nimport PropTypes from 'prop-types';\nimport ttreeEventsContext from './context/ttreeEventsContext';\nimport isUriSource from './helpers/isUriSource';\nimport { SourceLoaderProps, TTreeEvents } from './internal-types';\nimport {\n HTMLSourceDom,\n HTMLSourceInline,\n RenderHTMLSourceProps,\n HTMLSourceUri,\n HTMLSource\n} from './shared-types';\nimport SourceLoaderUri from './SourceLoaderUri';\nimport SourceLoaderInline from './SourceLoaderInline';\nimport SourceLoaderDom from './SourceLoaderDom';\nimport debugMessage from './debugMessages';\nimport contentWidthContext from './context/contentWidthContext';\nimport isDomSource from './helpers/isDomSource';\nimport useProfiler from './hooks/useProfiler';\n\nexport type RenderHTMLSourcePropTypes = Record<\n keyof RenderHTMLSourceProps,\n any\n>;\n\nexport const renderSourcePropTypes: RenderHTMLSourcePropTypes = {\n source: PropTypes.oneOfType([\n PropTypes.shape({\n html: PropTypes.string.isRequired,\n baseUrl: PropTypes.string\n }),\n PropTypes.shape({\n dom: PropTypes.object.isRequired,\n baseUrl: PropTypes.string\n }),\n PropTypes.shape({\n uri: PropTypes.string.isRequired,\n method: PropTypes.string,\n body: PropTypes.any,\n headers: PropTypes.object\n })\n ]),\n onTTreeChange: PropTypes.func,\n onHTMLLoaded: PropTypes.func,\n onDocumentMetadataLoaded: PropTypes.func,\n contentWidth: PropTypes.number\n};\n\nfunction isEmptySource(source: undefined | HTMLSource) {\n return (\n !source ||\n (typeof (source as HTMLSourceUri).uri !== 'string' &&\n typeof (source as HTMLSourceInline).html !== 'string' &&\n !(source as HTMLSourceDom).dom)\n );\n}\n\nfunction RawSourceLoader({\n source,\n ...props\n}: SourceLoaderProps): ReactElement | null {\n if (isEmptySource(source)) {\n /* istanbul ignore next */\n if (typeof __DEV__ === 'boolean' && __DEV__) {\n console.warn(debugMessage.noSource);\n }\n return null;\n }\n if (isUriSource(source)) {\n return React.createElement(SourceLoaderUri, { source, ...props });\n }\n if (isDomSource(source)) {\n return React.createElement(SourceLoaderDom, { source, ...props });\n }\n return React.createElement(SourceLoaderInline, { source, ...props });\n}\n\n// check if for each key of two objects, the values are equal\nfunction shallowEqual(prop1: any, prop2: any) {\n if (!equals(Object.keys(prop1), Object.keys(prop2))) {\n return false;\n }\n for (const key in prop1) {\n if (prop1[key] !== prop2[key]) {\n return false;\n }\n }\n return true;\n}\n\n/**\n * A React component to render HTML snippets.\n *\n * @remarks This component is useful when you have to load dozens of HTML\n * snippets with the same config. Performance is expected to improve in such\n * scenarios.\n *\n * @warning This component requires to have {@link TRenderEngineProvider}\n * and {@link RenderHTMLConfigProvider} as parents.\n */\nconst RenderHTMLSource = memo(\n function RenderHtmlSource({\n onDocumentMetadataLoaded,\n onTTreeChange,\n contentWidth,\n ...props\n }: RenderHTMLSourceProps) {\n const profile = useProfiler({\n prop: 'onDocumentMetadataLoaded or onTTreeChange'\n });\n const ttreeEvents: TTreeEvents = useMemo(() => {\n typeof __DEV__ === 'boolean' && __DEV__ && profile();\n return {\n onDocumentMetadataLoaded,\n onTTreeChange\n };\n }, [onDocumentMetadataLoaded, onTTreeChange, profile]);\n if (typeof __DEV__ === 'boolean' && __DEV__) {\n if (!(typeof contentWidth === 'number')) {\n console.warn(debugMessage.contentWidth);\n }\n }\n return (\n \n \n {React.createElement(RawSourceLoader, props)}\n \n \n );\n },\n ({ source: prevSource, ...prev }, { source: currSource, ...curr }) => {\n return shallowEqual(prevSource, currSource) && shallowEqual(prev, curr);\n }\n);\n\n/**\n * @ignore\n */\n(RenderHTMLSource as any).propTypes = renderSourcePropTypes;\n\nexport default RenderHTMLSource;\n","import { createContext } from 'react';\nimport { TTreeEvents } from '../internal-types';\n\nconst ttreeEventsContext = createContext({});\n\nexport default ttreeEventsContext;\n","import { HTMLSource, HTMLSourceUri } from '../shared-types';\n\nexport default function isUriSource(\n source: HTMLSource\n): source is HTMLSourceUri {\n return 'uri' in source && typeof source.uri === 'string';\n}\n","import React, { useContext, useEffect, useState } from 'react';\nimport { HTMLSourceUri } from './shared-types';\nimport { SourceLoaderProps } from './internal-types';\nimport RenderTTree from './RenderTTree';\nimport sourceLoaderContext from './context/sourceLoaderContext';\n\ninterface LoaderInternalState {\n error: boolean;\n resolvedHTML: string | null;\n}\n\nconst ERROR_STATE = {\n error: true,\n resolvedHTML: null\n};\n\nasync function loadHTMLResource(\n uri: string,\n { body, headers, method }: Omit\n): Promise {\n const response = await fetch(uri, {\n body,\n headers,\n method\n });\n if (response.ok) {\n const html = await response.text();\n return {\n resolvedHTML: html,\n error: false\n };\n }\n return ERROR_STATE;\n}\n\nexport type UriSourceLoaderProps = {\n source: HTMLSourceUri;\n} & SourceLoaderProps;\n\nfunction useUriSourceLoader({ source, onHTMLLoaded }: UriSourceLoaderProps) {\n const [loadState, setState] = useState({\n error: false,\n resolvedHTML: null\n });\n const { error } = loadState;\n\n // Effect to reload on uri changes\n useEffect(() => {\n let cancelled = false;\n if (!error) {\n setState({ error: false, resolvedHTML: null });\n loadHTMLResource(source.uri, {\n body: source.body,\n headers: source.headers,\n method: source.method\n })\n .then((state) => {\n !cancelled && setState(state);\n })\n .catch(() => {\n !cancelled && setState(ERROR_STATE);\n });\n }\n return () => {\n cancelled = true;\n };\n }, [error, source.uri, source.body, source.headers, source.method]);\n useEffect(() => {\n loadState.resolvedHTML && onHTMLLoaded?.call(null, loadState.resolvedHTML);\n }, [loadState.resolvedHTML, onHTMLLoaded]);\n return loadState;\n}\n\nexport default function SourceLoaderUri(props: UriSourceLoaderProps) {\n const { remoteErrorView, remoteLoadingView } =\n useContext(sourceLoaderContext);\n const { resolvedHTML, error } = useUriSourceLoader(props);\n if (error) {\n return remoteErrorView.call(null, props.source);\n }\n if (resolvedHTML === null) {\n return remoteLoadingView.call(null, props.source);\n }\n return React.createElement(RenderTTree, {\n document: resolvedHTML!,\n baseUrl: props.source.uri\n });\n}\n","import React, { useContext } from 'react';\nimport ttreeEventsContext from './context/ttreeEventsContext';\nimport useTTree from './hooks/useTTree';\nimport { RenderTTreeProps } from './internal-types';\nimport TDocumentRenderer from './TDocumentRenderer';\n\nexport default function RenderTTree(props: RenderTTreeProps) {\n const ttree = useTTree(props);\n const { onDocumentMetadataLoaded } = useContext(ttreeEventsContext);\n return (\n \n );\n}\n","import { useMemo, useEffect, useRef, useContext } from 'react';\nimport ttreeEventsContext from '../context/ttreeEventsContext';\nimport { useSharedProps } from '../context/SharedPropsProvider';\nimport { RenderTTreeProps } from '../internal-types';\nimport { useAmbientTRenderEngine } from '../TRenderEngineProvider';\nimport { TDocument } from '@native-html/transient-render-engine';\n\nfunction useTTreeChangeEffect(ttree: TDocument) {\n const { onTTreeChange } = useContext(ttreeEventsContext);\n const { debug } = useSharedProps();\n const updateNumber = useRef(0);\n useEffect(() => {\n onTTreeChange?.call(null, ttree);\n if (debug && typeof __DEV__ === 'boolean' && __DEV__) {\n console.info(\n `Transient Render Tree update ${++updateNumber.current}:\\n${ttree.snapshot(\n {\n withNodeIndex: false,\n withStyles: false\n }\n )}`\n );\n }\n }, [ttree, onTTreeChange, debug]);\n}\n\n/**\n * @internal\n */\nexport default function useTTree(props: RenderTTreeProps) {\n const { document } = props;\n const trenderEngine = useAmbientTRenderEngine();\n const ttree = useMemo(\n () =>\n typeof document === 'string'\n ? trenderEngine.buildTTree(document)\n : trenderEngine.buildTTreeFromDoc(document),\n [document, trenderEngine]\n );\n useTTreeChangeEffect(ttree);\n return ttree;\n}\n","import React, { memo, useEffect, useMemo } from 'react';\nimport { TDocument } from '@native-html/transient-render-engine';\nimport { DocumentMetadata, RenderHTMLSourceProps } from './shared-types';\nimport DocumentMetadataProvider from './context/DocumentMetadataProvider';\nimport TNodeRenderer from './TNodeRenderer';\n\nconst TDocumentRenderer = memo(\n ({\n tdoc,\n baseUrl,\n onDocumentMetadataLoaded\n }: {\n baseUrl?: string;\n onDocumentMetadataLoaded?: RenderHTMLSourceProps['onDocumentMetadataLoaded'];\n tdoc: TDocument;\n }) => {\n const metadata: DocumentMetadata = useMemo(() => {\n const { baseHref, baseTarget, lang, links, meta, title, dir } =\n tdoc.context;\n return {\n baseTarget,\n baseUrl: baseUrl ?? baseHref,\n lang,\n dir,\n links,\n meta,\n title\n };\n }, [tdoc.context, baseUrl]);\n useEffect(() => {\n onDocumentMetadataLoaded?.call(null, metadata);\n }, [onDocumentMetadataLoaded, metadata]);\n return (\n \n \n \n );\n }\n);\nexport default TDocumentRenderer;\n","import React, { useEffect } from 'react';\nimport { SourceLoaderProps } from './internal-types';\nimport RenderTTree from './RenderTTree';\nimport { HTMLSourceInline } from './shared-types';\n\nexport type InlineSourceLoaderProps = {\n source: HTMLSourceInline;\n} & SourceLoaderProps;\n\nfunction useInlineSourceLoader({\n source,\n onHTMLLoaded\n}: InlineSourceLoaderProps) {\n const html = source.html;\n useEffect(() => {\n html && onHTMLLoaded?.call(null, html);\n }, [html, onHTMLLoaded]);\n return source;\n}\n\nexport default function SourceLoaderInline(props: InlineSourceLoaderProps) {\n const { html } = useInlineSourceLoader(props);\n return React.createElement(RenderTTree, {\n document: html,\n baseUrl: props.source.baseUrl\n });\n}\n","import React from 'react';\nimport { SourceLoaderProps } from './internal-types';\nimport RenderTTree from './RenderTTree';\nimport { HTMLSourceDom } from './shared-types';\n\nexport type DomSourceLoaderProps = {\n source: HTMLSourceDom;\n} & SourceLoaderProps;\n\nexport default function SourceLoaderDom(props: DomSourceLoaderProps) {\n return React.createElement(RenderTTree, {\n document: props.source.dom,\n baseUrl: props.source.baseUrl\n });\n}\n","import { HTMLSource, HTMLSourceDom } from '../shared-types';\n\nexport default function isDomSource(\n source: HTMLSource\n): source is HTMLSourceDom {\n return 'dom' in source && typeof source.dom === 'object' && !!source.dom;\n}\n","import type {\n AccessibilityProps,\n GestureResponderEvent,\n StyleProp,\n TextProps,\n TextStyle,\n TouchableHighlightProps,\n ViewProps,\n ViewStyle\n} from 'react-native';\nimport type {\n CSSPropertyNameList,\n Document,\n DocumentContext as TREDocumentContext,\n DomVisitorCallbacks,\n Element,\n EmbeddedTagNames,\n HTMLContentModel,\n HTMLElementModel,\n MixedStyleDeclaration,\n MixedStyleRecord,\n NativeBlockStyles,\n NativeTextStyles,\n Node,\n NodeWithChildren,\n SetMarkersForTNode,\n StylessReactNativeProps,\n TDocument,\n TNode,\n TPhrasing,\n TRenderEngineOptions,\n TText\n} from '@native-html/transient-render-engine';\nimport type { CounterStyleRenderer } from '@jsamr/counter-style';\nimport type { ComponentType, ReactElement, ReactNode } from 'react';\nimport type { CustomTagRendererRecord } from './render/render-types';\nimport type { ParserOptions as HtmlParserOptions } from 'htmlparser2';\n\n/**\n * A record of HTMLElementModels.\n *\n * @public\n */\nexport type HTMLElementModelRecord = Record<\n string,\n HTMLElementModel\n>;\n\n/**\n * @public\n */\nexport interface ImageDimensions {\n height: number;\n width: number;\n}\n\n/**\n * Props for custom Pressable components.\n *\n * @public\n */\nexport interface GenericPressableProps extends AccessibilityProps {\n borderless?: boolean;\n onPress?: TouchableHighlightProps['onPress'];\n style?: StyleProp;\n}\n\n/**\n * Configuration for ol and ul.\n *\n * @public\n */\nexport interface ListElementConfig {\n /**\n * When `true`, the width of the marker box will be adapted depending on\n * `fontSize` and the highest number of characters in the printed range.\n *\n * If this length is superior than the left (or right in ltr mode) padding,\n * a supplemental space will be added before every list child.\n *\n * When `false`, the left (or right in ltr mode) padding will be invariable.\n *\n * @defaultValue false\n */\n enableDynamicMarkerBoxWidth?: boolean;\n /**\n * If `true` and the direction is set to `'rtl'` (either via `dir` attribute\n * or `direction` CSS property):\n *\n * - lists markers will be flushed to the right when `I18nManager.isRtl` is `false`.\n * - list markers prefixes and suffixes print order will be reversed.\n *\n * @remarks Beware that left and right padding of li elements *will not*\n * be switched.\n *\n * @defaultValue false\n */\n enableExperimentalRtl?: boolean;\n /**\n * Remove bottom margin if this element parent is an `li` element and it\n * is its last child.\n *\n * @defaultValue true\n */\n enableRemoveBottomMarginIfNested?: boolean;\n /**\n * Remove top margin if this element parent is an `li` element and it\n * is its first child.\n *\n * @defaultValue true\n */\n enableRemoveTopMarginIfNested?: boolean;\n /**\n * Get default list-style-type given the number of nest level for this list.\n *\n * @remarks This function will not be used when a list element has its own\n * `list-style-type` CSS property, or has inherited this property from\n * parents.\n *\n * @param nestLevel - The number of parents elements with the same tag name.\n */\n getFallbackListStyleTypeFromNestLevel?: (\n nestLevel: number\n ) => DefaultSupportedListStyleType;\n /**\n * Customize the marker box appearance (the `View` containing the marker,\n * e.g. the symbol prefixing list elements).\n *\n * @remarks This is useful to set some right padding or a different background for example.\n *\n * @warning **Do not**:\n * - Use margin (since the width will match the `

    ` / `
      ` padding left)\n * - Set width constraints (since the width will match the `
        ` / `
          ` padding left)\n */\n markerBoxStyle?: StyleProp;\n /**\n * Customize the marker text appearance (the `Text` component in which the marker,\n * e.g. the symbol prefixing list elements).\n *\n * @remarks Useful to set the color, fontFamily, fontSize of the marker.\n * Avoid using padding here, take advantage of `markerBoxStyle` instead.\n *\n * @warning This style must be a style object! Arrays, and `Stylesheet` styles will not work.\n */\n markerTextStyle?: TextStyle;\n}\n\n/**\n * Props for custom renderers. The convention is to declare a field per tag name.\n * In doing so, you can benefit from `useRendererProps('tagname')` in custom renderers.\n *\n * @remarks **Typescript users**: If you need to add fields to the {@link RenderersProps} interface,\n * you should use {@link https://www.typescriptlang.org/docs/handbook/declaration-merging.html#module-augmentation | module augmentation}:\n *\n * ```ts\n * declare module 'react-native-render-html' {\n * interface RenderersProps {\n * div?: {\n * customProp: boolean;\n * };\n * }\n * }\n * @public\n */\nexport interface RenderersProps extends Record {\n a: {\n /**\n * A callback to handle anchors presses.\n *\n * @remarks The `href` argument has been normalized, see {@link useNormalizedUrl}.\n *\n * @defaultValue A function using React Native `Linking.onpenUrl`.\n * @param event - The {@link GestureResponderEvent} event.\n * @param href - The normalized href, see {@link useNormalizedUrl}.\n * @param htmlAttribs - The attributes of the underlying {@link Element}.\n * @param target - The normalized `target` for this hyperlink.\n */\n onPress?: (\n event: GestureResponderEvent,\n href: string,\n htmlAttribs: Record,\n target: '_blank' | '_self' | '_parent' | '_top'\n ) => void;\n };\n img: {\n /**\n * Support for relative percent-widths.\n *\n * @defaultValue false\n */\n enableExperimentalPercentWidth?: boolean;\n /**\n * Default width and height to display while image's dimensions are being retrieved.\n *\n * @remarks Changes to this prop will cause a react tree update. Always\n * memoize it.\n */\n initialDimensions?: ImageDimensions;\n };\n ol: ListElementConfig;\n ul: ListElementConfig;\n}\n\n/**\n * Props passed to internal and custom renderers.\n *\n * @public\n */\nexport interface RenderHTMLPassedProps {\n /**\n * Props to use in custom renderers with `useRendererProps`.\n *\n * @remarks\n * - When you use the hook, you'll get this object deep-merged with default renderers props.\n * - **Typescript users**: If you need to add fields to the {@link RenderersProps} interface,\n * you should use {@link https://www.typescriptlang.org/docs/handbook/declaration-merging.html#module-augmentation | module augmentation}:\n *\n * ```ts\n * declare module 'react-native-render-html' {\n * interface RenderersProps {\n * div?: {\n * customProp: boolean;\n * };\n * }\n * }\n * ```\n */\n renderersProps?: Partial;\n}\n\n/**\n * A map which defines the type of parameters passed as third argument\n * of {@link EmbeddedHeadersProvider}.\n */\nexport interface EmbeddedWithHeadersParamsMap\n extends Record> {\n img: {\n /**\n * The print height of the image in DPI, if it can be determined beforehand\n * (for example, with a _height_ attribute set or an inline style).\n */\n printHeight?: number;\n /**\n * The print width of the image in DPI, if it can be determined beforehand\n * (for example, with a _width_ attribute set or an inline style).\n */\n printWidth?: number;\n };\n}\n\n/**\n * Tag names eligible for headers provision.\n */\nexport type EmbeddedWithHeadersTagName = Exclude<\n EmbeddedTagNames,\n 'svg' | 'canvas' | 'math'\n>;\n\n/**\n * A function to provide headers to a peculiar embedded element.\n */\nexport type EmbeddedHeadersProvider = (\n uri: string,\n tagName: T,\n params: EmbeddedWithHeadersParamsMap[T]\n) => Record | null | void;\n\n/**\n * Props shared across renderers.\n *\n * @warning Shared props changes will cause all the React tree to invalidate. You should\n * always memoize these.\n *\n * @public\n */\nexport interface RenderHTMLSharedProps {\n /**\n * A component used to wrap pressable elements (e.g. when provided `onPress`).\n * Note that textual elements will not be wrapped; `TextProps.onPress` will\n * be used instead.\n *\n * @defaultValue A `TouchableNativeFeedback` based component on Android, `TouchableHighlight` based component on other platforms.\n */\n GenericPressable?: ComponentType;\n\n /**\n * The WebView component used by plugins (iframe, table)...\n * See {@link https://github.com/native-html/plugins | @native-html/plugins}.\n *\n * @defaultValue `() => null`\n */\n WebView?: ComponentType;\n\n /**\n * When `true` (default), anonymous {@link TPhrasing} nodes parents of a\n * lonely {@link TText} node are not translated as React Native `Text`\n * elements. Instead, their child is directly rendered, e.g. with no `Text`\n * wrapper.\n *\n * @example **With `true`:**\n *\n * ```xml\n * \n * Hello\n * \n * ```\n *\n * is translated to\n *\n * ```xml\n * Hello\n * ```\n *\n * **With `false`:**\n *\n * ```xml\n * \n * Hello\n * \n * ```\n *\n * is translated to\n *\n * ```xml\n * Hello\n * ```\n *\n * @warning Unless strictly necessary, this should be left to `true` because\n * some styles don't apply to nested React Native `Text` elements\n * (`borderRadius`, `padding`...).\n *\n * @defaultValue true\n */\n bypassAnonymousTPhrasingNodes?: boolean;\n\n /**\n * A function which takes contentWidth and tagName as arguments and returns a\n * new width. Can return Infinity to denote unconstrained widths.\n *\n * @param contentWidth - The available width in this {@link RenderHTML} component.\n * @param tagName - The tagName of this element to render, e.g. \"img\".\n *\n * @remarks\n * - Take advantage of {@link useComputeMaxWidthForTag} hook inside custom\n * renderers to get the maximum width for this tag.\n * - Changes to this prop will cause a react tree update. Always\n * memoize it.\n *\n * @defaultValue `(c) => c`\n */\n computeEmbeddedMaxWidth?: (contentWidth: number, tagName: string) => number;\n\n /**\n * Provide support for list style types which are not supported by this\n * library.\n *\n * @remarks Check the numerous presets provided by\n * {@link https://github.com/jsamr/react-native-li/tree/master/packages/counter-style#readme | @jsamr/counter-style}\n * as they require zero-effort!\n *\n * @example\n *\n * ```js\n * import hebrew from '@jsamr/counter-style/presets/hebrew';\n *\n * const customListStyleSpecs = {\n * hebrew: {\n * type: 'textual',\n * counterStyleRenderer: hebrew\n * }\n * };\n * ```\n */\n customListStyleSpecs?: Record;\n\n /**\n * Log to the console a snapshot of the rendered {@link TDocument} after each\n * transient render tree invalidation.\n *\n * @defaultValue `false`\n */\n debug?: boolean;\n\n /**\n * Default props for Text elements in the render tree.\n *\n * @remarks \"style\" will be merged into the tnode own styles.\n */\n defaultTextProps?: TextProps;\n\n /**\n * Default props for View elements in the render tree.\n *\n * @remarks \"style\" will be merged into the tnode own styles.\n */\n defaultViewProps?: ViewProps;\n\n /**\n * Default props for WebView elements in the render tree used by plugins.\n */\n defaultWebViewProps?: any;\n\n /**\n * Follow closely the HTML standard and ignore `
          ` tags closing an\n * inline formatting context.\n *\n * @example\n *\n * ```html\n *

          \n * Hello
          \n *

          \n * ```\n *\n * When this flag is set to `true`, one line is printed instead of two on\n * native platforms, which is the HTML-compliant behavior.\n *\n * @defaultValue false\n *\n * @remarks Recommended value is `true` on non-web platforms. Also note that\n * this is an experimental feature, thus subject to behavioral instability.\n */\n enableExperimentalBRCollapsing?: boolean;\n\n /**\n * React Native doesn't handle lines like we would expect on a web browser.\n * For example:\n * ```jsx\n * \n * \n * \n * ```\n * will span 20 dpi in height. Setting this prop to `true` will make\n * the renderer take those React Native oddities into account.\n * See also this ticket: https://git.io/JErwX\n *\n * @remarks This is an experimental feature, thus subject to behavioral\n * instability.\n *\n * @defaultValue false\n */\n enableExperimentalGhostLinesPrevention?: boolean;\n\n /**\n * Enable or disable margin collapsing CSS behavior (experimental!).\n * See {@link https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Box_Model/Mastering_margin_collapsing | MDN docs}.\n *\n * @remarks Limitations:\n * - Only adjacent siblings collapsing is implemented.\n * - If one of the margins height is in percent, no collapsing will occur.\n * - Will apply indiscriminately to all `display` properties (including\n * flex), which is not standard.\n * - Might not work well with {@link TPhrasing} nodes having only one child.\n *\n * This is an experimental feature, thus subject to behavioral instability.\n *\n * @defaultValue false\n */\n enableExperimentalMarginCollapsing?: boolean;\n\n /**\n * Color used for pressable items, either for the ripple effect (Android), or\n * highlight (other platforms).\n *\n * @defaultValue rgba(38, 132, 240, 0.2)\n */\n pressableHightlightColor?: string;\n\n /**\n * Provide headers for specific embedded elements, such as images, iframes...\n *\n * @example\n *\n * ```js\n * function provideEmbeddedHeaders(uri, tagName, params) {\n * if (tagName === \"img\" &&\n * uri.startsWith(\"https://example.com\")) {\n * return {\n * Authorization: \"Bearer daem6QuaeloopheiD7Oh\"\n * }\n * }\n *\n * // ...\n *\n * \n * ```\n */\n provideEmbeddedHeaders?: EmbeddedHeadersProvider;\n}\n\ntype SharedPropsWithoutFallback = Exclude<\n keyof RenderHTMLSharedProps,\n 'provideEmbeddedHeaders' | 'GenericPressable' | 'customListStyleSpecs'\n>;\n\n/**\n * Shared props available with {@link useSharedProps} hook or `sharedProp`\n * custom renderers prop.\n */\nexport type RenderHTMLAmbiantSharedProps = Required<\n Pick\n> &\n Omit;\n\n/**\n * Configuration for the {@link TRenderEngineProvider} component.\n *\n * @warning When one of these props changes, it will cause the\n * {@link TRenderEngine} to be rebuilt, and all transient trees to be\n * re-assembled. Beware!\n *\n * @public\n */\nexport interface TRenderEngineConfig {\n /**\n * Whitelist specific inline CSS style properties and ignore the others.\n *\n * @warning Property names must be camelCased: for example, `background-color`\n * should be written `backgroundColor`.\n */\n allowedStyles?: CSSPropertyNameList;\n\n /**\n * The default style for the document (root). Inheritable styles will be\n * transferred to children. That works also for textual styles.\n *\n * @warning **Do NOT** use the `StyleSheet` API to create those styles.\n *\n * @remarks Any `fontFamily` used in those styles must be registered with\n * {@link TRenderEngineConfig.systemFonts} prop.\n */\n baseStyle?: MixedStyleDeclaration;\n\n /**\n * Provide mixed styles to target elements selected by CSS classes.\n *\n * @warning **Do NOT** use the `StyleSheet` API to create those styles.\n *\n * @remarks Any `fontFamily` used in those styles must be registered with\n * {@link TRenderEngineConfig.systemFonts} prop.\n */\n classesStyles?: MixedStyleRecord;\n\n /**\n * Customize element models for target tags.\n */\n customHTMLElementModels?: HTMLElementModelRecord;\n\n /**\n * **Experimental**\n *\n * Disable hoisting. Especially useful for rendering with react-native-web.\n * Note that your layout might break in native!\n *\n * @defaultValue false\n */\n dangerouslyDisableHoisting?: boolean;\n\n /**\n * **Experimental**\n *\n * Disable whitespace collapsing. Especially useful if your html is\n * being pre-processed server-side with a minifier.\n *\n * @defaultValue false\n */\n dangerouslyDisableWhitespaceCollapsing?: boolean;\n\n /**\n * An object which callbacks will be invoked when a DOM element or text node\n * has been parsed and its children attached. This is great to tamper the dom,\n * remove children, insert nodes, change text nodes data... etc.\n *\n * @remark Each callback is applied during DOM parsing, thus with very little\n * overhead. However, it means that one node next siblings won't be available\n * since it has not yet been parsed. If you need some siblings logic, apply\n * this logic to the children of this node.\n */\n domVisitors?: DomVisitorCallbacks;\n\n /**\n * The default value in pixels for 1em.\n */\n emSize?: number;\n\n /**\n * Enable or disable inline CSS processing of inline styles.\n *\n * @remarks If you want to allow or disallow specific properties, use\n * `allowedStyles` or `ignoredStyles` props.\n *\n * @defaultValue true\n */\n enableCSSInlineProcessing?: boolean;\n\n /**\n * Enable or disable fallback styles for each tag. For example, `pre` tags\n * will have `whiteSpace` set to 'pre' by default.\n *\n * @defaultValue true\n */\n enableUserAgentStyles?: boolean;\n\n /**\n * A record for specific CSS fonts.\n *\n * @remarks Use `Plaform.select({ ios: ..., android: ..., default: ...})`.\n */\n fallbackFonts?: FallbackFontsDefinitions;\n\n /**\n * ParserOptions for {@link https://github.com/fb55/htmlparser2/wiki/Parser-options | htmlparser2}.\n *\n * @defaultValue `{ decodeEntities: true }`\n */\n htmlParserOptions?: HtmlParserOptions;\n /**\n * Provide mixed styles to target elements identified by the `id` attribute.\n *\n * @warning **Do NOT** use the `StyleSheet` API to create those styles.\n *\n * @remarks Any `fontFamily` used in those styles must be registered with\n * {@link TRenderEngineConfig.systemFonts} prop.\n */\n idsStyles?: MixedStyleRecord;\n\n /**\n * Ignore specific DOM nodes.\n *\n * @warning When this function is invoked, the node has not yet been attached\n * to its parent or siblings. Use the second argument (`parent`) if you\n * need to perform logic based on parent.\n *\n * @remarks\n * - The function is applied during DOM parsing, thus with very little\n * overhead. However, it means that one node next siblings won't be\n * available since it has not yet been parsed.\n * - Use `ignoredDomTags` if you just need to target specific tag names.\n *\n * @returns `true` if this node should not be included in the DOM, anything\n * else otherwise.\n *\n * @param node - The node to check. Beware the parent node is not accessible. Use the second argument.\n * @param parent - The parent node.\n */\n ignoreDomNode?: (\n node: Node,\n parent: NodeWithChildren\n ) => boolean | void | unknown;\n\n /**\n * A list of **lowercase tags** which should not be included in the DOM.\n *\n * @remark The filtering is happening during parsing, thus with very little\n * overhead.\n */\n ignoredDomTags?: string[];\n\n /**\n * Blacklist specific inline CSS style properties and allow the others.\n *\n * @warning Property names must be camelCased: for example, `background-color`\n * should be written `backgroundColor`.\n *\n * @remarks Note that if you don't want inline style processing at all, you\n * should set `enableCSSInlineProcessing` prop to `false`.\n */\n ignoredStyles?: CSSPropertyNameList;\n\n /**\n * Select the DOM root before TTree generation. For example, you could\n * iterate over children until you reach an article element and return this\n * element.\n *\n * @remarks Applied after DOM parsing, before normalization and TTree\n * construction. Before normalization implies that a body will be added in\n * the tree **after** selecting root.\n */\n selectDomRoot?: TRenderEngineOptions['selectDomRoot'];\n\n /**\n * Set custom markers from a {@link TNode} and all its descendants. {@link Markers} will be\n * accessible in custom renderers via `tnode.markers` prop.\n *\n * @param targetMarkers - The markers to modify.\n * @param parentMarkers - {@link Markers} from the parent {@link TNode}.\n * @param tnode - The {@link TNode} to inspect.\n *\n * @defaultValue `() => null`\n */\n setMarkersForTNode?: SetMarkersForTNode;\n\n /**\n * A list of fonts available in the current platform. These fonts will be used\n * to select the first match in CSS `fontFamily` property, which supports a\n * comma-separated list of fonts. By default, a handful of fonts are selected\n * per platform.\n *\n * @remarks\n * - You need to specify any font family you wish to use via `*styles` props\n * here, otherwise those styles will be ignored.\n * - If you are using expo, you should use or extend `Constants.systemFonts`.\n *\n * @example\n * ```tsx\n * import RenderHTML, {defaultSystemFonts} from 'react-native-render-html'\n * // Replace defaultSystemFonts with Constants.systemFonts if you're using expo\n * const systemFonts = [...defaultSystemFonts, 'Mysuperfont']\n * // ...\n * \n * ```\n */\n systemFonts?: string[];\n\n /**\n * Provide mixed styles to target HTML tag names.\n *\n * @warning **Do NOT** use the `StyleSheet` API to create those styles.\n *\n * @remarks Any `fontFamily` used in those styles must be registered with\n * {@link TRenderEngineConfig.systemFonts} prop.\n */\n tagsStyles?: MixedStyleRecord;\n}\n\n/**\n * A source represented by a URI.\n *\n * @public\n */\nexport interface HTMLSourceUri {\n /**\n * The HTTP body to send with the request. This must be a valid\n * UTF-8 string, and will be sent exactly as specified, with no\n * additional encoding (e.g. URL-escaping or base64) applied.\n */\n body?: string;\n\n /**\n * Additional HTTP headers to send with the request.\n */\n headers?: Record;\n\n /**\n * The HTTP Method to use. Defaults to GET if not specified.\n */\n method?: string;\n\n /**\n * The URI to load in the `HTML` component. Can be a local or remote file.\n */\n uri: string;\n}\n\n/**\n * A source which content is provided in-place.\n *\n * @public\n */\nexport interface HTMLSourceInline {\n /**\n * The base URL to resolve relative URLs in the HTML code.\n * See {@link useNormalizedUrl}.\n */\n baseUrl?: string;\n\n /**\n * A static HTML page to display in the HTML component.\n */\n html: string;\n}\n\n/**\n * A source which content is a DOM tree created by the transient render\n * engine `parseDocument` method.\n *\n * See {@link useAmbientTRenderEngine}.\n *\n * @remarks When you use a DOM source, the `onHTMLLoaded` callback will never\n * be invoked for this source, since the source loader hasn't access to the\n * HTML source of the DOM.\n *\n * @public\n */\nexport interface HTMLSourceDom {\n /**\n * The base URL to resolve relative URLs in the HTML code.\n * See {@link useNormalizedUrl}.\n */\n baseUrl?: string;\n\n /**\n * A DOM object. This object **must** have been created with\n * the transient render engine `parseDocument` method.\n */\n dom: Element | Document;\n}\n\n/**\n * The source to render.\n *\n * @public\n */\nexport type HTMLSource = HTMLSourceInline | HTMLSourceDom | HTMLSourceUri;\n\n/**\n *\n * Props for the {@link RenderHTMLConfigProvider} component.\n *\n * @public\n */\nexport interface RenderHTMLConfig\n extends RenderHTMLSharedProps,\n RenderHTMLPassedProps {\n /**\n * Replace the default error if a remote website's content could not be fetched.\n */\n remoteErrorView?: (source: HTMLSourceUri) => ReactElement;\n\n /**\n * Replace the default loader while fetching a remote website's content.\n */\n remoteLoadingView?: (source: HTMLSourceUri) => ReactElement;\n\n /**\n * Your custom renderers.\n *\n * @remarks\n *\n * **TypeScript users**: To have intellisense for custom renderers, explicitly\n * set your custom renderer type to one of {@link CustomBlockRenderer},\n * {@link CustomTextualRenderer} or {@link CustomMixedRenderer} depending\n * on the {@link HTMLContentModel} defined for this tag (see example below).\n *\n * @example\n *\n * A custom renderer for `
          ` tags which trigger an alert on press.\n *\n * ```tsx\n * import React from 'react';\n * import RenderHTML, { CustomBlockRenderer } from 'react-native-render-html';\n * import { Alert } from 'react-native';\n *\n * const onPress = () => Alert.alert(\"I pressed a div!\");\n *\n * // (TypeScript) Notice the type for intellisense\n * const DivRenderer: CustomBlockRenderer = function DivRenderer({ TDefaultRenderer, ...props }) {\n * return ;\n * }\n *\n * const renderers = { div: DivRenderer }\n *\n * //\n *\n * return \n * ```\n */\n renderers?: CustomTagRendererRecord;\n}\n\n/**\n * Props for the {@link RenderHTMLSource} component.\n *\n * @public\n */\nexport interface RenderHTMLSourceProps {\n /**\n * The width of the HTML content to display. The recommended practice is to pass\n * `useWindowDimensions().width` minus any padding or margins.\n *\n * @defaultValue `Dimensions.get('window').width`\n */\n contentWidth?: number;\n\n /**\n * Handler invoked when the document metadata is available. It will\n * re-trigger on HTML content changes.\n */\n onDocumentMetadataLoaded?: (documentMetadata: DocumentMetadata) => void;\n\n /**\n * Triggered when HTML is available to the RenderHTML component.\n */\n onHTMLLoaded?: (html: string) => void;\n\n /**\n * Triggered when the transient render tree changes. Useful for debugging.\n */\n onTTreeChange?: (ttree: TDocument) => void;\n\n /**\n * The object source to render (either `{ uri }`, `{ html }` or `{ dom }`).\n */\n source: HTMLSource;\n}\n\n/**\n * Props for the {@link RenderHTML} component.\n *\n * @public\n */\nexport interface RenderHTMLProps\n extends RenderHTMLConfig,\n RenderHTMLSourceProps,\n TRenderEngineConfig {}\n\n/**\n * An object which keys are keyword font names, and values system fonts.\n *\n * @public\n */\nexport interface FallbackFontsDefinitions {\n monospace: string;\n 'sans-serif': string;\n serif: string;\n}\n\n/**\n * Props passed from parents to children.\n *\n *\n * @remarks Anonymous nodes will pass those props from their parents to\n * children.\n *\n */\nexport interface PropsFromParent extends Record {\n collapsedMarginTop: number | null;\n}\n\n/**\n * Props to render a child.\n *\n * @public\n */\nexport interface TChildProps {\n /**\n * The child element.\n */\n childElement: ReactElement;\n\n /**\n * The child associated {@link TNode}.\n */\n childTnode: TNode;\n\n /**\n * The position relative to parent.\n */\n index: number;\n\n /**\n * The React `key`.\n */\n key: string | number;\n\n /**\n * Props that have been set via\n * {@link TChildrenRendererProps.propsForChildren}.\n */\n propsFromParent: PropsFromParent;\n}\n\n/**\n * Common props for TChildren rendering logic.\n *\n * @public\n */\nexport interface TChildrenBaseProps {\n /**\n * When {@link RenderHTMLProps.enableExperimentalMarginCollapsing} is\n * enabled, this prop will be true by default. But you can opt-out when\n * rendering children.\n */\n disableMarginCollapsing?: boolean;\n\n /**\n * Props that will be passed to children renderers via\n * {@link CustomRendererProps.propsFromParent}.\n */\n propsForChildren?: Partial;\n\n /**\n * A React render function to render and wrap individual children.\n */\n renderChild?: (props: TChildProps) => ReactNode;\n}\n\n/**\n * Props for {@link TChildrenRenderer}.\n *\n * @public\n */\nexport interface TChildrenRendererProps extends TChildrenBaseProps {\n /**\n * An array of {@link TNode} to render.\n */\n tchildren: ReadonlyArray;\n}\n\n/**\n * Props for {@link TNodeChildrenRenderer}.\n *\n * @public\n */\nexport interface TNodeChildrenRendererProps extends TChildrenBaseProps {\n /**\n * The {@link TNode} from which children will be rendered.\n */\n tnode: TNode;\n}\n\n/**\n * Props for {@link TNodeRenderer} component.\n *\n * @typeParam T - The concrete type of {@link TNode}.\n */\nexport interface TNodeRendererProps {\n /**\n * Props passed by direct parents.\n */\n propsFromParent?: PropsFromParent;\n\n /**\n * The position of this React element relative to the parent React element,\n * starting at 0.\n *\n * @remarks Not to be confused with {@link TNodeShape.index}, which is\n * the position of the *TNode* before hoisting. The latter is much closer\n * to an intuitive understanding of the position of a DOM node in the DOM\n * tree.\n */\n renderIndex: number;\n\n /**\n * The total number of elements children of this React element parent.\n */\n renderLength: number;\n\n /**\n * The {@link TNode} to render.\n */\n tnode: T;\n}\n\n/**\n * Abstract interface for renderers.\n *\n * @typeParam T - The concrete type of {@link TNode}.\n */\nexport interface RendererBaseProps\n extends TNodeRendererProps {\n /**\n * Props passed to the underlying React Native element, either `Text` or\n * `View`. See also {@link RendererBaseProps.textProps} and\n * {@link RendererBaseProps.viewProps}.\n *\n * @remarks The `prop.style` property will have a greater specificity\n * than computed styles for this {@link TNode}. E.g. `style={[computedStyle,\n * nativeProps.style, viewProps.style]}`.\n *\n */\n nativeProps?: StylessReactNativeProps & { style?: StyleProp };\n\n /**\n * Any default renderer should be able to handle press.\n */\n onPress?: (e: GestureResponderEvent) => void;\n\n /**\n * Props passed to the underlying `Text` element (`type` must be 'text'). See\n * also {@link RendererBaseProps.nativeProps} and\n * {@link RendererBaseProps.viewProps}.\n *\n * @remarks The `textProps.style` property will have a greater specificity than\n * computed styles for this {@link TNode}. E.g. `style={[computedStyle,\n * nativeProps.style, textProps.style]}`.\n */\n textProps: TextProps;\n\n /**\n * Is the underlying component `Text` or `View`?\n */\n type: 'text' | 'block';\n\n /**\n * Props passed to the underlying `View` element (`type` must be 'view'). See\n * also {@link RendererBaseProps.nativeProps} and\n * {@link RendererBaseProps.textProps}.\n *\n * @remarks The `viewProps.style` property will have a greater specificity than\n * computed styles for this {@link TNode}. E.g. `style={[computedStyle,\n * nativeProps.style, viewProps.style]}`.\n */\n viewProps: ViewProps;\n}\n\n/**\n * Props for {@link TDefaultRenderer}.\n *\n * @typeParam T - The concrete type of {@link TNode}.\n * @public\n */\nexport interface TDefaultRendererProps\n extends RendererBaseProps {\n /**\n * A component to render children of a `tnode`.\n */\n TNodeChildrenRenderer: ComponentType;\n\n /**\n * When children is present, renderChildren will not be invoked.\n */\n children?: ReactNode;\n\n /**\n * Props passed to children nodes. Those props are accessible from children\n * renderers as `propsFromParent`\n */\n propsForChildren?: Partial;\n\n /**\n * The style for this renderer will depend on the type of {@link TNode}.\n * You can check if a node is textual with `props.type === 'text'`.\n */\n style: T extends TText | TPhrasing\n ? StyleProp\n : StyleProp;\n}\n\n/**\n * Props for {@link InternalRenderer} components.\n *\n * @typeParam T - The concrete type of {@link TNode}.\n * @public\n */\nexport interface InternalRendererProps\n extends RendererBaseProps {\n /**\n * Default renderer for this {@link TNode}.\n */\n TDefaultRenderer: TDefaultRenderer;\n\n /**\n * A component to render children of a `tnode`.\n */\n TNodeChildrenRenderer: ComponentType;\n\n /**\n * Props shared across the whole render tree.\n */\n sharedProps: RenderHTMLAmbiantSharedProps;\n\n /**\n * Styles extracted with {@link TNode.getNativeStyles}.\n */\n style: T extends TText | TPhrasing ? NativeTextStyles : NativeBlockStyles;\n}\n\n/**\n * Props for custom renderers, such as provided in the `renderers` prop.\n *\n * @typeParam T - The concrete type of {@link TNode}.\n * @public\n */\nexport interface CustomRendererProps\n extends InternalRendererProps {\n /**\n * Internal renderer for this _tagName_, not to be confused with\n * {@link TDefaultRenderer}, which is the fallback renderer for any {@link TNode}.\n *\n * @remarks For example, when rendering `img` tags, `TDefaultRenderer` and\n * `InternalRenderer` won't be equal.\n *\n * When there is no internal renderer for this tag, this prop will fallback\n * to `TDefaultRenderer`.\n */\n InternalRenderer: InternalRenderer;\n}\n\n/**\n * Default renderer for any {@link TNode}. The renderer behavior will only\n * change given the {@link TNodeType | type} of the {@link TNode}.\n *\n * @typeParam T - The concrete type of {@link TNode}.\n * @public\n */\nexport type TDefaultRenderer = ComponentType<\n TDefaultRendererProps\n>;\n\n/**\n * An \"internal renderer\" is an internal custom renderer, adding specific\n * features to the fallback `TDefaultRenderer`. For example, `` tags will\n * be rendered via an internal renderer, while `
          ` will fallback to a\n * {@link TDefaultRenderer}.\n *\n * @public\n *\n * @typeParam T - The concrete type of {@link TNode}.\n */\nexport type InternalRenderer = ComponentType<\n InternalRendererProps\n>;\n\n/**\n * A custom renderer, such as provided in the {@link RenderHTMLProps.renderers} prop.\n *\n * @typeParam T - The concrete type of {@link TNode}.\n * @public\n */\nexport type CustomRenderer = ComponentType<\n CustomRendererProps\n>;\n\n/**\n * An object containing meta-data extracted from resource URL and HTML\n * `` element.\n *\n * @public\n */\nexport interface DocumentMetadata {\n /**\n * How anchors should be actioned on press?\n *\n * @remarks By default, `renderersProps.a.onPress` will always open the\n * system browser, equivalent to `_blank` target. However, you can customize\n * the behavior by providing your own implementation.\n */\n baseTarget: TREDocumentContext['baseTarget'];\n\n /**\n * The base URL of this resource. It will influence how relative URLs are\n * resolved such as `href` and `src` element properties. By order of\n * precedence:\n *\n * 1. `baseUrl` from `` html element;\n * 2. `baseUrl` from `source.baseUrl` prop;\n * 3. `baseUrl` as origin of `source.uri` prop.\n */\n baseUrl: string;\n\n /**\n * The writing direction of this document, extracted from the `dir` attribute\n * of `` element.\n */\n dir: 'ltr' | 'rtl';\n\n /**\n * The language of this document, extracted from the `lang` attribute of the\n * `` element;\n */\n lang: string;\n\n /**\n * A data array comprised of attributes from <link> elements.\n */\n links: TREDocumentContext['links'];\n\n /**\n * A data array comprised of attributes from <meta> elements.\n */\n meta: TREDocumentContext['meta'];\n\n /**\n * The content of the <title> element.\n */\n title: string;\n}\n\n/**\n * Props for unitary counter renderers.\n *\n * @public\n */\nexport type UnitaryCounterRendererProps = {\n color: string;\n fontSize: number;\n index: number;\n lineHeight: number;\n} & Pick<\n MixedStyleDeclaration,\n 'fontFamily' | 'fontStyle' | 'fontWeight' | 'fontVariant'\n>;\n\n/**\n * List style types supported internally.\n *\n * See {@link https://www.w3.org/TR/css-counter-styles-3 | CSS Counter Styles Level 3}.\n *\n * @public\n */\nexport type DefaultSupportedListStyleType =\n | 'none'\n | 'disc'\n | 'circle'\n | 'square'\n | 'decimal'\n | 'decimal-leading-zero'\n | 'lower-roman'\n | 'upper-roman'\n | 'lower-greek'\n | 'lower-alpha'\n | 'lower-latin'\n | 'upper-alpha'\n | 'upper-latin'\n | 'disclosure-open'\n | 'disclosure-closed';\n\n/**\n * Specs for a list item marker renderer backed by a `CounterStyleRenderer`\n * from `@jsamr/counter-style`.\n *\n * @public\n */\nexport interface TextualListStyleSpec {\n counterStyleRenderer: CounterStyleRenderer;\n type: 'textual';\n}\n\n/**\n * Specs for a list item marker renderer with only one representation. The\n * \"Component\" should render this representation, minus prefix and suffix. The\n * rendered component should have a maximum width of `0.6 * fontSize`, and a height of\n * `lineHeight`.\n *\n * @public\n */\nexport interface UnitaryListStyleSpec {\n Component: ComponentType;\n counterStyleRenderer: CounterStyleRenderer;\n type: 'unitary';\n}\n\n/**\n * An object to specify how to render list markers.\n *\n * @public\n */\nexport type ListStyleSpec = TextualListStyleSpec | UnitaryListStyleSpec;\n","import { TBlock, TPhrasing, TText } from '@native-html/transient-render-engine';\nimport { ComponentType } from 'react';\nimport { TNodeSubRendererProps } from '../internal-types';\nimport { CustomRenderer, InternalRenderer } from '../shared-types';\n\n/**\n * Special internal renderers for non-printable text (wbr, br).\n */\nexport type InternalTextContentRenderer = ComponentType<\n TNodeSubRendererProps\n> & {\n isNativeInternalTextRenderer: true;\n};\n\n/**\n * Internal renderer for tags with a **block** content model.\n */\nexport type InternalBlockRenderer = InternalRenderer;\n\n/**\n * Internal renderer for tags with a **mixed** content model.\n */\nexport type InternalMixedRenderer = InternalRenderer<\n TBlock | TPhrasing | TText\n>;\n\n/**\n * Internal renderer for tags with a **textual** content model.\n */\nexport type InternalTextualRenderer = InternalRenderer;\n\n/**\n * Block renderers can only render tnodes of type TBlock.\n */\nexport type CustomBlockRenderer = CustomRenderer;\n\n/**\n * Textual renderers can render tnodes of type TText or TPhrasing.\n */\nexport type CustomTextualRenderer = CustomRenderer;\n\n/**\n * Mixed renderers can can render tnodes of type TText, TPhrasing or TBlock.\n */\nexport type CustomMixedRenderer = CustomRenderer;\n\n/**\n * A record of custom renderers.\n */\nexport type CustomTagRendererRecord = Record<\n string,\n CustomBlockRenderer | CustomTextualRenderer | CustomMixedRenderer\n>;\n","import { TagName } from '@native-html/transient-render-engine';\nimport { ComponentType } from 'react';\nimport IMGElement from '../elements/IMGElement';\nimport OLElement from '../elements/OLElement';\nimport ULElement from '../elements/ULElement';\nimport { useAElementProps } from '../renderers/ARenderer';\nimport { useIMGElementProps } from '../renderers/IMGRenderer';\nimport { useOLElementProps } from '../renderers/OLRenderer';\nimport { useULElementProps } from '../renderers/ULRenderer';\nimport { InternalRendererProps, TDefaultRendererProps } from '../shared-types';\n\nconst specialRenderersConfig = {\n img: {\n hook: useIMGElementProps,\n Element: IMGElement\n },\n ol: {\n hook: useOLElementProps,\n Element: OLElement\n },\n ul: {\n hook: useULElementProps,\n Element: ULElement\n },\n a: {\n hook: useAElementProps,\n Element: undefined\n }\n};\n\nexport type InternalSpecialRenderedTag = keyof typeof specialRenderersConfig;\n\nfunction hasSpecialInternalRenderer(\n tagName: TagName\n): tagName is keyof typeof specialRenderersConfig {\n return tagName in specialRenderersConfig;\n}\n\nexport interface InternalRendererConfig

          {\n Renderer: ComponentType

          ;\n rendererProps: P;\n}\n/**\n * Resuse internal renderers logic for infinite customization!\n *\n * @remarks `tagName` must be invariant, i.e. it cannot change. You would\n * otherwise break the rules of hooks.\n *\n * @param tagName - **Invariant** The tag name to extend.\n * @param props - The props passed to the custom renderer.\n * @typeParam T - The name of the tag to target.\n * @returns An object with two fields: `Renderer` (the internal react\n * component) and `rendererProps`, the internal component props.\n *\n * @public\n */\nexport default function useInternalRenderer(\n tagName: T,\n props: InternalRendererProps\n): T extends InternalSpecialRenderedTag\n ? InternalRendererConfig>\n : InternalRendererConfig> {\n const { TDefaultRenderer, ...rendererProps } = props;\n if (hasSpecialInternalRenderer(tagName)) {\n return {\n Renderer: specialRenderersConfig[tagName].Element || TDefaultRenderer,\n rendererProps: specialRenderersConfig[tagName].hook(props as any)\n } as any;\n }\n return {\n Renderer: TDefaultRenderer,\n rendererProps\n } as any;\n}\n","import pick from 'ramda/src/pick';\nimport omit from 'ramda/src/omit';\nimport { TNodeShape, TNodeType } from '@native-html/transient-render-engine';\n\nconst borderBoxProps = [\n 'backgroundColor',\n 'borderBottomColor',\n 'borderBottomLeftRadius',\n 'borderBottomRightRadius',\n 'borderBottomWidth',\n 'borderLeftColor',\n 'borderLeftWidth',\n 'borderRightColor',\n 'borderRightWidth',\n 'borderStyle',\n 'borderTopColor',\n 'borderTopLeftRadius',\n 'borderTopRightRadius',\n 'borderTopWidth',\n 'paddingBottom',\n 'paddingLeft',\n 'paddingRight',\n 'paddingTop',\n 'marginBottom',\n 'marginLeft',\n 'marginRight',\n 'marginTop'\n];\n\nconst pickBorderBox = pick(borderBoxProps);\nconst omitBorderBox = omit(borderBoxProps);\n\n/**\n * A utility to separate box model styles and other styles. Useful when one wants\n * to wrap a text element in a view to benefit from padding vertical,\n * borders... etc.\n *\n * @param styles - The native styles to split.\n */\nexport default function splitBoxModelStyle(\n style: ReturnType['getNativeStyles']>\n) {\n return {\n boxModelStyle: pickBorderBox(style),\n otherStyle: omitBorderBox(style)\n };\n}\n","import strigifyEntities from 'stringify-entities';\nimport {\n Node,\n isDomText,\n isDomElement\n} from '@native-html/transient-render-engine';\n\nfunction renderOpeningTag(tag: string, attributes: Record) {\n const strAttributes: string[] = [];\n Object.keys(attributes).forEach((key) => {\n strAttributes.push(`${key}=\"${strigifyEntities(`${attributes[key]}`)}\"`);\n });\n return `<${tag}${strAttributes.length ? ' ' : ''}${strAttributes.join(' ')}>`;\n}\n\n/**\n * Convert a DOM node to its HTML representation.\n *\n * @param root - The root to stringify.\n * @param reporter - An optional function which will receive every\n * parsed node as 1st argument, the depth as 2d argument and the converted html\n * as 3d argument.\n */\nexport default function domNodeToHTMLString(\n root: Node | null,\n reporter?: DomNodeToHtmlReporter,\n depth = 0\n) {\n let html = '';\n if (isDomElement(root)) {\n const strChildren = root.children.reduce((prev, curr) => {\n const convertedNode = domNodeToHTMLString(curr, reporter, depth + 1);\n return `${prev}${convertedNode}`;\n }, '');\n html = `${renderOpeningTag(root.tagName, root.attribs)}${strChildren}`;\n } else if (isDomText(root)) {\n const text = strigifyEntities(root.data);\n html = text;\n }\n typeof reporter === 'function' && reporter(root, depth, html);\n return html;\n}\n\n/**\n * @public\n */\nexport interface DomNodeToHtmlReporter {\n /**\n * @param node - The node being parsed.\n * @param depth - How many parents this node have.\n * @param html - The HTML representation of this node and its children.\n */\n (node: Node | null, depth: number, html: string): void;\n}\n","'use strict'\n\nmodule.exports = require('./lib')\n","'use strict'\n\nvar encode = require('./encode')\nvar escape = require('./escape')\n\nmodule.exports = encode\nencode.escape = escape\n","'use strict'\n\nvar xtend = require('xtend')\nvar core = require('./core')\nvar smart = require('./util/format-smart')\n\nmodule.exports = encode\n\n// Encode special characters in `value`.\nfunction encode(value, options) {\n // Note: Switch to `Object.assign` next major.\n return core(value, xtend(options, {format: smart}))\n}\n","'use strict'\n\nmodule.exports = encode\n\n// Encode special characters in `value`.\nfunction encode(value, options) {\n value = value.replace(\n options.subset ? charactersToExpression(options.subset) : /[\"&'<>`]/g,\n basic\n )\n\n if (options.subset || options.escapeOnly) {\n return value\n }\n\n return (\n value\n // Surrogate pairs.\n .replace(/[\\uD800-\\uDBFF][\\uDC00-\\uDFFF]/g, surrogate)\n // BMP control characters (C0 except for LF, CR, SP; DEL; and some more\n // non-ASCII ones).\n .replace(\n // eslint-disable-next-line no-control-regex, unicorn/no-hex-escape\n /[\\x01-\\t\\v\\f\\x0E-\\x1F\\x7F\\x81\\x8D\\x8F\\x90\\x9D\\xA0-\\uFFFF]/g,\n basic\n )\n )\n\n function surrogate(pair, index, all) {\n return options.format(\n (pair.charCodeAt(0) - 0xd800) * 0x400 +\n pair.charCodeAt(1) -\n 0xdc00 +\n 0x10000,\n all.charCodeAt(index + 2),\n options\n )\n }\n\n function basic(character, index, all) {\n return options.format(\n character.charCodeAt(0),\n all.charCodeAt(index + 1),\n options\n )\n }\n}\n\nfunction charactersToExpression(subset) {\n var groups = []\n var index = -1\n\n while (++index < subset.length) {\n groups.push(subset[index].replace(/[|\\\\{}()[\\]^$+*?.]/g, '\\\\$&'))\n }\n\n return new RegExp('(?:' + groups.join('|') + ')', 'g')\n}\n","module.exports = extend\n\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\n\nfunction extend() {\n var target = {}\n\n for (var i = 0; i < arguments.length; i++) {\n var source = arguments[i]\n\n for (var key in source) {\n if (hasOwnProperty.call(source, key)) {\n target[key] = source[key]\n }\n }\n }\n\n return target\n}\n","module.exports = formatPretty\n\nvar toHexadecimal = require('./to-hexadecimal')\nvar toDecimal = require('./to-decimal')\nvar toNamed = require('./to-named')\n\n// Encode `character` according to `options`.\nfunction formatPretty(code, next, options) {\n var named\n var numeric\n var decimal\n\n if (options.useNamedReferences || options.useShortestReferences) {\n named = toNamed(\n code,\n next,\n options.omitOptionalSemicolons,\n options.attribute\n )\n }\n\n if (options.useShortestReferences || !named) {\n numeric = toHexadecimal(code, next, options.omitOptionalSemicolons)\n\n // Use the shortest numeric reference when requested.\n // A simple algorithm would use decimal for all code points under 100, as\n // those are shorter than hexadecimal:\n //\n // * `c` vs `c` (decimal shorter)\n // * `d` vs `d` (equal)\n //\n // However, because we take `next` into consideration when `omit` is used,\n // And it would be possible that decimals are shorter on bigger values as\n // well if `next` is hexadecimal but not decimal, we instead compare both.\n if (options.useShortestReferences) {\n decimal = toDecimal(code, next, options.omitOptionalSemicolons)\n\n if (decimal.length < numeric.length) {\n numeric = decimal\n }\n }\n }\n\n return named &&\n (!options.useShortestReferences || named.length < numeric.length)\n ? named\n : numeric\n}\n","module.exports = toNamed\n\nvar legacy = require('character-entities-legacy')\nvar characters = require('../constant/characters')\nvar fromCharCode = require('../constant/from-char-code')\nvar own = require('../constant/has-own-property')\nvar dangerous = require('../constant/dangerous.json')\n\n// Transform `code` into a named character reference.\nfunction toNamed(code, next, omit, attribute) {\n var character = fromCharCode(code)\n var name\n var value\n\n if (own.call(characters, character)) {\n name = characters[character]\n value = '&' + name\n\n if (\n omit &&\n own.call(legacy, name) &&\n dangerous.indexOf(name) === -1 &&\n (!attribute ||\n (next && next !== 61 /* `=` */ && /[^\\da-z]/i.test(fromCharCode(next))))\n ) {\n return value\n }\n\n return value + ';'\n }\n\n return ''\n}\n","module.exports = String.fromCharCode\n","module.exports = {}.hasOwnProperty\n","var entities = require('character-entities-html4')\n\nvar characters = {}\nvar name\n\nmodule.exports = characters\n\nfor (name in entities) {\n characters[entities[name]] = name\n}\n","{\n \"nbsp\": \" \",\n \"iexcl\": \"¡\",\n \"cent\": \"¢\",\n \"pound\": \"£\",\n \"curren\": \"¤\",\n \"yen\": \"¥\",\n \"brvbar\": \"¦\",\n \"sect\": \"§\",\n \"uml\": \"¨\",\n \"copy\": \"©\",\n \"ordf\": \"ª\",\n \"laquo\": \"«\",\n \"not\": \"¬\",\n \"shy\": \"­\",\n \"reg\": \"®\",\n \"macr\": \"¯\",\n \"deg\": \"°\",\n \"plusmn\": \"±\",\n \"sup2\": \"²\",\n \"sup3\": \"³\",\n \"acute\": \"´\",\n \"micro\": \"µ\",\n \"para\": \"¶\",\n \"middot\": \"·\",\n \"cedil\": \"¸\",\n \"sup1\": \"¹\",\n \"ordm\": \"º\",\n \"raquo\": \"»\",\n \"frac14\": \"¼\",\n \"frac12\": \"½\",\n \"frac34\": \"¾\",\n \"iquest\": \"¿\",\n \"Agrave\": \"À\",\n \"Aacute\": \"Á\",\n \"Acirc\": \"Â\",\n \"Atilde\": \"Ã\",\n \"Auml\": \"Ä\",\n \"Aring\": \"Å\",\n \"AElig\": \"Æ\",\n \"Ccedil\": \"Ç\",\n \"Egrave\": \"È\",\n \"Eacute\": \"É\",\n \"Ecirc\": \"Ê\",\n \"Euml\": \"Ë\",\n \"Igrave\": \"Ì\",\n \"Iacute\": \"Í\",\n \"Icirc\": \"Î\",\n \"Iuml\": \"Ï\",\n \"ETH\": \"Ð\",\n \"Ntilde\": \"Ñ\",\n \"Ograve\": \"Ò\",\n \"Oacute\": \"Ó\",\n \"Ocirc\": \"Ô\",\n \"Otilde\": \"Õ\",\n \"Ouml\": \"Ö\",\n \"times\": \"×\",\n \"Oslash\": \"Ø\",\n \"Ugrave\": \"Ù\",\n \"Uacute\": \"Ú\",\n \"Ucirc\": \"Û\",\n \"Uuml\": \"Ü\",\n \"Yacute\": \"Ý\",\n \"THORN\": \"Þ\",\n \"szlig\": \"ß\",\n \"agrave\": \"à\",\n \"aacute\": \"á\",\n \"acirc\": \"â\",\n \"atilde\": \"ã\",\n \"auml\": \"ä\",\n \"aring\": \"å\",\n \"aelig\": \"æ\",\n \"ccedil\": \"ç\",\n \"egrave\": \"è\",\n \"eacute\": \"é\",\n \"ecirc\": \"ê\",\n \"euml\": \"ë\",\n \"igrave\": \"ì\",\n \"iacute\": \"í\",\n \"icirc\": \"î\",\n \"iuml\": \"ï\",\n \"eth\": \"ð\",\n \"ntilde\": \"ñ\",\n \"ograve\": \"ò\",\n \"oacute\": \"ó\",\n \"ocirc\": \"ô\",\n \"otilde\": \"õ\",\n \"ouml\": \"ö\",\n \"divide\": \"÷\",\n \"oslash\": \"ø\",\n \"ugrave\": \"ù\",\n \"uacute\": \"ú\",\n \"ucirc\": \"û\",\n \"uuml\": \"ü\",\n \"yacute\": \"ý\",\n \"thorn\": \"þ\",\n \"yuml\": \"ÿ\",\n \"fnof\": \"ƒ\",\n \"Alpha\": \"Α\",\n \"Beta\": \"Β\",\n \"Gamma\": \"Γ\",\n \"Delta\": \"Δ\",\n \"Epsilon\": \"Ε\",\n \"Zeta\": \"Ζ\",\n \"Eta\": \"Η\",\n \"Theta\": \"Θ\",\n \"Iota\": \"Ι\",\n \"Kappa\": \"Κ\",\n \"Lambda\": \"Λ\",\n \"Mu\": \"Μ\",\n \"Nu\": \"Ν\",\n \"Xi\": \"Ξ\",\n \"Omicron\": \"Ο\",\n \"Pi\": \"Π\",\n \"Rho\": \"Ρ\",\n \"Sigma\": \"Σ\",\n \"Tau\": \"Τ\",\n \"Upsilon\": \"Υ\",\n \"Phi\": \"Φ\",\n \"Chi\": \"Χ\",\n \"Psi\": \"Ψ\",\n \"Omega\": \"Ω\",\n \"alpha\": \"α\",\n \"beta\": \"β\",\n \"gamma\": \"γ\",\n \"delta\": \"δ\",\n \"epsilon\": \"ε\",\n \"zeta\": \"ζ\",\n \"eta\": \"η\",\n \"theta\": \"θ\",\n \"iota\": \"ι\",\n \"kappa\": \"κ\",\n \"lambda\": \"λ\",\n \"mu\": \"μ\",\n \"nu\": \"ν\",\n \"xi\": \"ξ\",\n \"omicron\": \"ο\",\n \"pi\": \"π\",\n \"rho\": \"ρ\",\n \"sigmaf\": \"ς\",\n \"sigma\": \"σ\",\n \"tau\": \"τ\",\n \"upsilon\": \"υ\",\n \"phi\": \"φ\",\n \"chi\": \"χ\",\n \"psi\": \"ψ\",\n \"omega\": \"ω\",\n \"thetasym\": \"ϑ\",\n \"upsih\": \"ϒ\",\n \"piv\": \"ϖ\",\n \"bull\": \"•\",\n \"hellip\": \"…\",\n \"prime\": \"′\",\n \"Prime\": \"″\",\n \"oline\": \"‾\",\n \"frasl\": \"⁄\",\n \"weierp\": \"℘\",\n \"image\": \"ℑ\",\n \"real\": \"ℜ\",\n \"trade\": \"™\",\n \"alefsym\": \"ℵ\",\n \"larr\": \"←\",\n \"uarr\": \"↑\",\n \"rarr\": \"→\",\n \"darr\": \"↓\",\n \"harr\": \"↔\",\n \"crarr\": \"↵\",\n \"lArr\": \"⇐\",\n \"uArr\": \"⇑\",\n \"rArr\": \"⇒\",\n \"dArr\": \"⇓\",\n \"hArr\": \"⇔\",\n \"forall\": \"∀\",\n \"part\": \"∂\",\n \"exist\": \"∃\",\n \"empty\": \"∅\",\n \"nabla\": \"∇\",\n \"isin\": \"∈\",\n \"notin\": \"∉\",\n \"ni\": \"∋\",\n \"prod\": \"∏\",\n \"sum\": \"∑\",\n \"minus\": \"−\",\n \"lowast\": \"∗\",\n \"radic\": \"√\",\n \"prop\": \"∝\",\n \"infin\": \"∞\",\n \"ang\": \"∠\",\n \"and\": \"∧\",\n \"or\": \"∨\",\n \"cap\": \"∩\",\n \"cup\": \"∪\",\n \"int\": \"∫\",\n \"there4\": \"∴\",\n \"sim\": \"∼\",\n \"cong\": \"≅\",\n \"asymp\": \"≈\",\n \"ne\": \"≠\",\n \"equiv\": \"≡\",\n \"le\": \"≤\",\n \"ge\": \"≥\",\n \"sub\": \"⊂\",\n \"sup\": \"⊃\",\n \"nsub\": \"⊄\",\n \"sube\": \"⊆\",\n \"supe\": \"⊇\",\n \"oplus\": \"⊕\",\n \"otimes\": \"⊗\",\n \"perp\": \"⊥\",\n \"sdot\": \"⋅\",\n \"lceil\": \"⌈\",\n \"rceil\": \"⌉\",\n \"lfloor\": \"⌊\",\n \"rfloor\": \"⌋\",\n \"lang\": \"〈\",\n \"rang\": \"〉\",\n \"loz\": \"◊\",\n \"spades\": \"♠\",\n \"clubs\": \"♣\",\n \"hearts\": \"♥\",\n \"diams\": \"♦\",\n \"quot\": \"\\\"\",\n \"amp\": \"&\",\n \"lt\": \"<\",\n \"gt\": \">\",\n \"OElig\": \"Œ\",\n \"oelig\": \"œ\",\n \"Scaron\": \"Š\",\n \"scaron\": \"š\",\n \"Yuml\": \"Ÿ\",\n \"circ\": \"ˆ\",\n \"tilde\": \"˜\",\n \"ensp\": \" \",\n \"emsp\": \" \",\n \"thinsp\": \" \",\n \"zwnj\": \"‌\",\n \"zwj\": \"‍\",\n \"lrm\": \"‎\",\n \"rlm\": \"‏\",\n \"ndash\": \"–\",\n \"mdash\": \"—\",\n \"lsquo\": \"‘\",\n \"rsquo\": \"’\",\n \"sbquo\": \"‚\",\n \"ldquo\": \"“\",\n \"rdquo\": \"”\",\n \"bdquo\": \"„\",\n \"dagger\": \"†\",\n \"Dagger\": \"‡\",\n \"permil\": \"‰\",\n \"lsaquo\": \"‹\",\n \"rsaquo\": \"›\",\n \"euro\": \"€\"\n}\n","{\n \"AElig\": \"Æ\",\n \"AMP\": \"&\",\n \"Aacute\": \"Á\",\n \"Acirc\": \"Â\",\n \"Agrave\": \"À\",\n \"Aring\": \"Å\",\n \"Atilde\": \"Ã\",\n \"Auml\": \"Ä\",\n \"COPY\": \"©\",\n \"Ccedil\": \"Ç\",\n \"ETH\": \"Ð\",\n \"Eacute\": \"É\",\n \"Ecirc\": \"Ê\",\n \"Egrave\": \"È\",\n \"Euml\": \"Ë\",\n \"GT\": \">\",\n \"Iacute\": \"Í\",\n \"Icirc\": \"Î\",\n \"Igrave\": \"Ì\",\n \"Iuml\": \"Ï\",\n \"LT\": \"<\",\n \"Ntilde\": \"Ñ\",\n \"Oacute\": \"Ó\",\n \"Ocirc\": \"Ô\",\n \"Ograve\": \"Ò\",\n \"Oslash\": \"Ø\",\n \"Otilde\": \"Õ\",\n \"Ouml\": \"Ö\",\n \"QUOT\": \"\\\"\",\n \"REG\": \"®\",\n \"THORN\": \"Þ\",\n \"Uacute\": \"Ú\",\n \"Ucirc\": \"Û\",\n \"Ugrave\": \"Ù\",\n \"Uuml\": \"Ü\",\n \"Yacute\": \"Ý\",\n \"aacute\": \"á\",\n \"acirc\": \"â\",\n \"acute\": \"´\",\n \"aelig\": \"æ\",\n \"agrave\": \"à\",\n \"amp\": \"&\",\n \"aring\": \"å\",\n \"atilde\": \"ã\",\n \"auml\": \"ä\",\n \"brvbar\": \"¦\",\n \"ccedil\": \"ç\",\n \"cedil\": \"¸\",\n \"cent\": \"¢\",\n \"copy\": \"©\",\n \"curren\": \"¤\",\n \"deg\": \"°\",\n \"divide\": \"÷\",\n \"eacute\": \"é\",\n \"ecirc\": \"ê\",\n \"egrave\": \"è\",\n \"eth\": \"ð\",\n \"euml\": \"ë\",\n \"frac12\": \"½\",\n \"frac14\": \"¼\",\n \"frac34\": \"¾\",\n \"gt\": \">\",\n \"iacute\": \"í\",\n \"icirc\": \"î\",\n \"iexcl\": \"¡\",\n \"igrave\": \"ì\",\n \"iquest\": \"¿\",\n \"iuml\": \"ï\",\n \"laquo\": \"«\",\n \"lt\": \"<\",\n \"macr\": \"¯\",\n \"micro\": \"µ\",\n \"middot\": \"·\",\n \"nbsp\": \" \",\n \"not\": \"¬\",\n \"ntilde\": \"ñ\",\n \"oacute\": \"ó\",\n \"ocirc\": \"ô\",\n \"ograve\": \"ò\",\n \"ordf\": \"ª\",\n \"ordm\": \"º\",\n \"oslash\": \"ø\",\n \"otilde\": \"õ\",\n \"ouml\": \"ö\",\n \"para\": \"¶\",\n \"plusmn\": \"±\",\n \"pound\": \"£\",\n \"quot\": \"\\\"\",\n \"raquo\": \"»\",\n \"reg\": \"®\",\n \"sect\": \"§\",\n \"shy\": \"­\",\n \"sup1\": \"¹\",\n \"sup2\": \"²\",\n \"sup3\": \"³\",\n \"szlig\": \"ß\",\n \"thorn\": \"þ\",\n \"times\": \"×\",\n \"uacute\": \"ú\",\n \"ucirc\": \"û\",\n \"ugrave\": \"ù\",\n \"uml\": \"¨\",\n \"uuml\": \"ü\",\n \"yacute\": \"ý\",\n \"yen\": \"¥\",\n \"yuml\": \"ÿ\"\n}\n","[\n \"cent\",\n \"copy\",\n \"divide\",\n \"gt\",\n \"lt\",\n \"not\",\n \"para\",\n \"times\"\n]\n","module.exports = toHexReference\n\nvar fromCharCode = require('../constant/from-char-code')\n\n// Transform `code` into a hexadecimal character reference.\nfunction toHexReference(code, next, omit) {\n var value = '&#x' + code.toString(16).toUpperCase()\n return omit && next && !/[\\dA-Fa-f]/.test(fromCharCode(next))\n ? value\n : value + ';'\n}\n","module.exports = toDecimalReference\n\nvar fromCharCode = require('../constant/from-char-code')\n\n// Transform `code` into a decimal character reference.\nfunction toDecimalReference(code, next, omit) {\n var value = '&#' + String(code)\n return omit && next && !/\\d/.test(fromCharCode(next)) ? value : value + ';'\n}\n","'use strict'\n\nvar core = require('./core')\nvar smart = require('./util/format-smart')\n\nmodule.exports = escape\n\n// Shortcut to escape special characters in HTML.\nfunction escape(value) {\n return core(value, {\n escapeOnly: true,\n useNamedReferences: true,\n format: smart\n })\n}\n","import defaultImageInitialDimensions from './defaultInitialImageDimensions';\nimport { getIMGState } from './getIMGState';\nimport type {\n UseIMGElementStateWithCacheProps,\n IMGElementStateError,\n IMGElementStateSuccess\n} from './img-types';\nimport useImageConcreteDimensions from './useImageConcreteDimensions';\nimport useImageSpecifiedDimensions from './useImageSpecifiedDimensions';\nimport useIMGNormalizedSource from './useIMGNormalizedSource';\n\n/**\n * This hook is useful when one has access to image natural dimensions prior to\n * loading. The `cachedNaturalDimensions` prop must be passed to immediately\n * compute concrete dimensions.\n */\nexport default function useIMGElementStateWithCache(\n props: UseIMGElementStateWithCacheProps\n): IMGElementStateError | IMGElementStateSuccess {\n const {\n alt,\n altColor,\n source,\n contentWidth,\n computeMaxWidth,\n objectFit,\n initialDimensions = defaultImageInitialDimensions,\n cachedNaturalDimensions\n } = props;\n const { flatStyle, specifiedDimensions } = useImageSpecifiedDimensions(props);\n const nomalizedSource = useIMGNormalizedSource({\n specifiedDimensions,\n source\n });\n const concreteDimensions = useImageConcreteDimensions({\n flatStyle,\n naturalDimensions: cachedNaturalDimensions,\n specifiedDimensions,\n computeMaxWidth,\n contentWidth\n });\n\n return getIMGState({\n error: null,\n concreteDimensions,\n containerStyle: flatStyle,\n initialDimensions,\n objectFit,\n source: nomalizedSource,\n alt,\n altColor\n });\n}\n","import {\n ImageStyle,\n ImageURISource,\n PressableProps,\n StyleProp,\n ViewProps,\n ViewStyle\n} from 'react-native';\nimport { ImageDimensions } from '../shared-types';\nimport { WebBlockStyles } from '@native-html/transient-render-engine';\n\n/**\n * Props for {@link useIMGElementStateWithCache} hook.\n */\nexport type UseIMGElementStateWithCacheProps = UseIMGElementStateProps &\n Required>;\n\n/**\n * Props for {@link useIMGElementState} hook.\n */\nexport interface UseIMGElementStateProps {\n /**\n * Alt text extract from `alt` attribute.\n */\n alt?: string;\n /**\n * Alt color, defaults to `color` for this {@link TNode}.\n */\n altColor?: string;\n /**\n * When the natural (\"physical\") dimensions for this image are accessible *a\n * priori*, these should be passed. It will save some API calls and filesytem\n * access via React Native Image.getSize.\n */\n cachedNaturalDimensions?: ImageDimensions;\n /**\n * When provided, the print image will have a max width depending on the\n * `contentWidth` prop.\n */\n computeMaxWidth?: (contentWidth: number) => number;\n /**\n * The `contentWidth` from the {@link RenderHTMLProps}.\n */\n contentWidth?: number;\n /**\n * Allow experimental percent width for the print dimensions computation.\n * The percent will be relative to `contentWidth`\n */\n enableExperimentalPercentWidth?: boolean;\n /**\n * The value of the `height` attribute.\n */\n height?: string | number;\n /**\n * Rendered dimensions prior to retrieving natural dimensions of the image.\n */\n initialDimensions?: ImageDimensions;\n /**\n * The value of the `object-fit` CSS property.\n */\n objectFit?: WebBlockStyles['objectFit'];\n /**\n * The source to paint.\n */\n source: ImageURISource;\n /**\n * The style for this image.\n */\n style?: StyleProp;\n /**\n * The value of the `width` attribute.\n */\n width?: string | number;\n}\n\n/**\n * Props for the {@link IMGElement} component.\n */\nexport interface IMGElementProps extends UseIMGElementStateProps {\n containerProps?: Omit;\n /**\n * A callback triggered on press.\n */\n onPress?: PressableProps['onPress'];\n testID?: string;\n}\n\n/**\n * The internal state used by {@link IMGElement}.\n */\nexport type IMGElementState =\n | IMGElementStateError\n | IMGElementStateSuccess\n | IMGElementStateLoading;\n\n/**\n * Base fields for all {@link IMGElementState}.\n */\nexport interface IMGElementStateBase {\n /**\n * Alt text extract from `alt` attribute.\n */\n alt?: string;\n /**\n * Alt color, defaults to `color` for this {@link TNode}.\n */\n altColor?: string;\n /**\n * Styles of the container.\n */\n containerStyle: ViewStyle;\n /**\n * Physical dimensions of the image\n */\n dimensions: ImageDimensions;\n /**\n * The source to paint.\n */\n source: ImageURISource;\n}\n\n/**\n * State when the image has been successfully loaded.\n */\nexport interface IMGElementStateSuccess extends IMGElementStateBase {\n /**\n * Image-only style extracted from `IMGElement.style` prop.\n */\n imageStyle: ImageStyle;\n /**\n * This callback should be passed down to the underlying image component.\n *\n * @remarks Quite often, the image won't be pre-fetched\n * because its print dimensions can be determined immediately. For\n * example, when both width and height are provide as attributes. So the\n * first state s0 of this state machine can be \"success\", and the second\n * state s1 be \"error\".\n */\n onError: (error: Error) => void;\n type: 'success';\n}\n\n/**\n * State when the image is loading.\n */\nexport interface IMGElementStateLoading extends IMGElementStateBase {\n type: 'loading';\n}\n\n/**\n * State when the image could not be loaded.\n */\nexport interface IMGElementStateError extends IMGElementStateBase {\n error: Error;\n type: 'error';\n}\n\n/**\n * Partial image dimensions.\n */\nexport interface IncompleteImageDimensions {\n height: number | null;\n width: number | null;\n}\n","import React from 'react';\nimport {View} from 'react-native';\nimport * as formSubmitPropTypes from './formSubmitPropTypes';\n\nconst FormSubmit = React.forwardRef((props, ref) => (\n {props.children}\n));\n\nFormSubmit.propTypes = formSubmitPropTypes.propTypes;\nFormSubmit.defaultProps = formSubmitPropTypes.defaultProps;\nFormSubmit.displayName = 'FormSubmit';\n\nexport default FormSubmit;\n","import PropTypes from 'prop-types';\nimport stylePropTypes from '../../styles/stylePropTypes';\n\nconst propTypes = {\n /** A reference forwarded to the inner View */\n innerRef: PropTypes.oneOfType([\n PropTypes.func,\n // eslint-disable-next-line react/forbid-prop-types\n PropTypes.shape({current: PropTypes.any}),\n ]),\n\n /* A function to execute when form is submitted with ENTER */\n onSubmit: PropTypes.func.isRequired,\n\n /** Children to wrap with FormSubmit. */\n children: PropTypes.node.isRequired,\n\n /** Container styles */\n style: stylePropTypes,\n};\n\nconst defaultProps = {\n innerRef: undefined,\n style: [],\n};\n\nexport {propTypes, defaultProps};\n","import React from 'react';\nimport {ScrollView} from 'react-native';\n\nconst MIN_SMOOTH_SCROLL_EVENT_THROTTLE = 16;\n\nconst ScrollContext = React.createContext();\n\n// eslint-disable-next-line react/forbid-foreign-prop-types\nconst propTypes = ScrollView.propTypes;\n\n/*\n* is a wrapper around that provides a ref to the .\n* can be used as a direct replacement for \n* if it contains one or more / components.\n* Using this wrapper will automatically handle scrolling to the picker's \n* when the picker modal is opened\n*/\nclass ScrollViewWithContext extends React.Component {\n constructor(props) {\n super(props);\n\n this.state = {\n contentOffsetY: 0,\n };\n this.scrollViewRef = this.props.innerRef || React.createRef(null);\n\n this.setContextScrollPosition = this.setContextScrollPosition.bind(this);\n }\n\n setContextScrollPosition(event) {\n if (this.props.onScroll) {\n this.props.onScroll(event);\n }\n this.setState({contentOffsetY: event.nativeEvent.contentOffset.y});\n }\n\n render() {\n return (\n \n \n {this.props.children}\n \n \n );\n }\n}\nScrollViewWithContext.propTypes = propTypes;\n\nexport default React.forwardRef((props, ref) => (\n // eslint-disable-next-line react/jsx-props-no-spreading\n \n));\n\nexport {\n ScrollContext,\n};\n","import React from 'react';\nimport CONST from '../../CONST';\nimport MoneyRequestModal from './MoneyRequestModal';\n\n// eslint-disable-next-line react/jsx-props-no-spreading\nconst IOUSendPage = props => ;\nIOUSendPage.displayName = 'IOUSendPage';\nexport default IOUSendPage;\n","import _ from 'underscore';\nimport React from 'react';\nimport {withOnyx} from 'react-native-onyx';\nimport lodashGet from 'lodash/get';\nimport PropTypes from 'prop-types';\nimport HeaderWithCloseButton from '../components/HeaderWithCloseButton';\nimport ScreenWrapper from '../components/ScreenWrapper';\nimport Navigation from '../libs/Navigation/Navigation';\nimport * as BankAccounts from '../libs/actions/BankAccounts';\nimport withLocalize, {withLocalizePropTypes} from '../components/withLocalize';\nimport AddPlaidBankAccount from '../components/AddPlaidBankAccount';\nimport getPlaidOAuthReceivedRedirectURI from '../libs/getPlaidOAuthReceivedRedirectURI';\nimport compose from '../libs/compose';\nimport ONYXKEYS from '../ONYXKEYS';\nimport styles from '../styles/styles';\nimport Form from '../components/Form';\nimport ROUTES from '../ROUTES';\nimport * as PlaidDataProps from './ReimbursementAccount/plaidDataPropTypes';\nimport ConfirmationPage from '../components/ConfirmationPage';\n\nconst propTypes = {\n ...withLocalizePropTypes,\n\n /** Contains plaid data */\n plaidData: PlaidDataProps.plaidDataPropTypes,\n\n /** The details about the Personal bank account we are adding saved in Onyx */\n personalBankAccount: PropTypes.shape({\n /** An error message to display to the user */\n error: PropTypes.string,\n\n /** Whether we should show the view that the bank account was successfully added */\n shouldShowSuccess: PropTypes.bool,\n\n /** Whether the form is loading */\n isLoading: PropTypes.bool,\n\n /** The account ID of the selected bank account from Plaid */\n plaidAccountID: PropTypes.string,\n }),\n};\n\nconst defaultProps = {\n plaidData: PlaidDataProps.plaidDataDefaultProps,\n personalBankAccount: {\n error: '',\n shouldShowSuccess: false,\n isLoading: false,\n plaidAccountID: '',\n },\n};\n\nclass AddPersonalBankAccountPage extends React.Component {\n constructor(props) {\n super(props);\n\n this.validate = this.validate.bind(this);\n this.submit = this.submit.bind(this);\n\n this.state = {\n selectedPlaidAccountID: '',\n };\n }\n\n componentWillUnmount() {\n BankAccounts.clearPersonalBankAccount();\n }\n\n /**\n * @returns {Object}\n */\n validate() {\n return {};\n }\n\n submit() {\n const selectedPlaidBankAccount = _.findWhere(lodashGet(this.props.plaidData, 'bankAccounts', []), {\n plaidAccountID: this.state.selectedPlaidAccountID,\n });\n\n BankAccounts.addPersonalBankAccount(selectedPlaidBankAccount);\n }\n\n render() {\n const shouldShowSuccess = lodashGet(this.props, 'personalBankAccount.shouldShowSuccess', false);\n\n return (\n \n \n {shouldShowSuccess ? (\n {\n Navigation.navigate(ROUTES.SETTINGS_PAYMENTS);\n }}\n />\n ) : (\n \n <>\n {\n this.setState({selectedPlaidAccountID});\n }}\n plaidData={this.props.plaidData}\n onExitPlaid={Navigation.goBack}\n receivedRedirectURI={getPlaidOAuthReceivedRedirectURI()}\n selectedPlaidAccountID={this.state.selectedPlaidAccountID}\n />\n \n \n )}\n \n );\n }\n}\n\nAddPersonalBankAccountPage.propTypes = propTypes;\nAddPersonalBankAccountPage.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withOnyx({\n personalBankAccount: {\n key: ONYXKEYS.PERSONAL_BANK_ACCOUNT,\n },\n plaidData: {\n key: ONYXKEYS.PLAID_DATA,\n },\n }),\n)(AddPersonalBankAccountPage);\n","import Onyx from 'react-native-onyx';\nimport CONST from '../../CONST';\nimport * as API from '../API';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport * as Localize from '../Localize';\nimport DateUtils from '../DateUtils';\nimport * as PlaidDataProps from '../../pages/ReimbursementAccount/plaidDataPropTypes';\nimport Navigation from '../Navigation/Navigation';\nimport ROUTES from '../../ROUTES';\nimport * as ReimbursementAccount from './ReimbursementAccount';\n\nexport {\n goToWithdrawalAccountSetupStep,\n setBankAccountFormValidationErrors,\n resetReimbursementAccount,\n resetFreePlanBankAccount,\n hideBankAccountErrors,\n setWorkspaceIDForReimbursementAccount,\n setBankAccountSubStep,\n updateReimbursementAccountDraft,\n requestResetFreePlanBankAccount,\n cancelResetFreePlanBankAccount,\n} from './ReimbursementAccount';\nexport {\n openPlaidBankAccountSelector,\n openPlaidBankLogin,\n} from './Plaid';\nexport {\n openOnfidoFlow,\n answerQuestionsForWallet,\n verifyIdentity,\n acceptWalletTerms,\n} from './Wallet';\n\nfunction clearPlaid() {\n Onyx.set(ONYXKEYS.PLAID_LINK_TOKEN, '');\n\n return Onyx.set(ONYXKEYS.PLAID_DATA, PlaidDataProps.plaidDataDefaultProps);\n}\n\nfunction openPlaidView() {\n clearPlaid().then(() => ReimbursementAccount.setBankAccountSubStep(CONST.BANK_ACCOUNT.SETUP_TYPE.PLAID));\n}\n\nfunction openPersonalBankAccountSetupView() {\n clearPlaid().then(() => Navigation.navigate(ROUTES.SETTINGS_ADD_BANK_ACCOUNT));\n}\n\nfunction clearPersonalBankAccount() {\n clearPlaid();\n Onyx.set(ONYXKEYS.PERSONAL_BANK_ACCOUNT, {});\n}\n\nfunction clearOnfidoToken() {\n Onyx.merge(ONYXKEYS.ONFIDO_TOKEN, '');\n}\n\n/**\n * Helper method to build the Onyx data required during setup of a Verified Business Bank Account\n *\n * @returns {Object}\n */\nfunction getVBBADataForOnyx() {\n return {\n optimisticData: [\n {\n onyxMethod: CONST.ONYX.METHOD.MERGE,\n key: ONYXKEYS.REIMBURSEMENT_ACCOUNT,\n value: {\n isLoading: true,\n errors: null,\n },\n },\n ],\n successData: [\n {\n onyxMethod: CONST.ONYX.METHOD.MERGE,\n key: ONYXKEYS.REIMBURSEMENT_ACCOUNT,\n value: {\n isLoading: false,\n errors: null,\n },\n },\n ],\n failureData: [\n {\n onyxMethod: CONST.ONYX.METHOD.MERGE,\n key: ONYXKEYS.REIMBURSEMENT_ACCOUNT,\n value: {\n isLoading: false,\n errors: {\n [DateUtils.getMicroseconds()]: Localize.translateLocal('paymentsPage.addBankAccountFailure'),\n },\n },\n },\n ],\n };\n}\n\n/**\n * Submit Bank Account step with Plaid data so php can perform some checks.\n *\n * @param {Number} bankAccountID\n * @param {Object} selectedPlaidBankAccount\n */\nfunction connectBankAccountWithPlaid(bankAccountID, selectedPlaidBankAccount) {\n const commandName = 'ConnectBankAccountWithPlaid';\n\n const parameters = {\n bankAccountID,\n routingNumber: selectedPlaidBankAccount.routingNumber,\n accountNumber: selectedPlaidBankAccount.accountNumber,\n bank: selectedPlaidBankAccount.bankName,\n plaidAccountID: selectedPlaidBankAccount.plaidAccountID,\n plaidAccessToken: selectedPlaidBankAccount.plaidAccessToken,\n };\n\n API.write(commandName, parameters, getVBBADataForOnyx());\n}\n\n/**\n * Adds a bank account via Plaid\n *\n * @param {Object} account\n * @TODO offline pattern for this command will have to be added later once the pattern B design doc is complete\n */\nfunction addPersonalBankAccount(account) {\n const commandName = 'AddPersonalBankAccount';\n\n const parameters = {\n addressName: account.addressName,\n routingNumber: account.routingNumber,\n accountNumber: account.accountNumber,\n isSavings: account.isSavings,\n setupType: 'plaid',\n bank: account.bankName,\n plaidAccountID: account.plaidAccountID,\n plaidAccessToken: account.plaidAccessToken,\n };\n\n const onyxData = {\n optimisticData: [\n {\n onyxMethod: CONST.ONYX.METHOD.MERGE,\n key: ONYXKEYS.PERSONAL_BANK_ACCOUNT,\n value: {\n isLoading: true,\n errors: null,\n plaidAccountID: account.plaidAccountID,\n },\n },\n ],\n successData: [\n {\n onyxMethod: CONST.ONYX.METHOD.MERGE,\n key: ONYXKEYS.PERSONAL_BANK_ACCOUNT,\n value: {\n isLoading: false,\n errors: null,\n shouldShowSuccess: true,\n },\n },\n ],\n failureData: [\n {\n onyxMethod: CONST.ONYX.METHOD.MERGE,\n key: ONYXKEYS.PERSONAL_BANK_ACCOUNT,\n value: {\n isLoading: false,\n errors: {\n [DateUtils.getMicroseconds()]: Localize.translateLocal('paymentsPage.addBankAccountFailure'),\n },\n },\n },\n ],\n };\n\n API.write(commandName, parameters, onyxData);\n}\n\nfunction deletePaymentBankAccount(bankAccountID) {\n API.write('DeletePaymentBankAccount', {\n bankAccountID,\n }, {\n optimisticData: [\n {\n onyxMethod: CONST.ONYX.METHOD.MERGE,\n key: `${ONYXKEYS.BANK_ACCOUNT_LIST}`,\n value: {[bankAccountID]: {pendingAction: CONST.RED_BRICK_ROAD_PENDING_ACTION.DELETE}},\n },\n ],\n\n // Sometimes pusher updates aren't received when we close the App while still offline,\n // so we are setting the bankAccount to null here to ensure that it gets cleared out once we come back online.\n successData: [\n {\n onyxMethod: CONST.ONYX.METHOD.MERGE,\n key: `${ONYXKEYS.BANK_ACCOUNT_LIST}`,\n value: {[bankAccountID]: null},\n },\n ],\n });\n}\n\n/**\n* Update the user's personal information on the bank account in database.\n*\n* This action is called by the requestor step in the Verified Bank Account flow\n*\n* @param {Object} params\n*\n* @param {String} [params.dob]\n* @param {String} [params.firstName]\n* @param {String} [params.lastName]\n* @param {String} [params.requestorAddressStreet]\n* @param {String} [params.requestorAddressCity]\n* @param {String} [params.requestorAddressState]\n* @param {String} [params.requestorAddressZipCode]\n* @param {String} [params.ssnLast4]\n* @param {String} [params.isControllingOfficer]\n* @param {Object} [params.onfidoData]\n* @param {Boolean} [params.isOnfidoSetupComplete]\n*/\nfunction updatePersonalInformationForBankAccount(params) {\n API.write('UpdatePersonalInformationForBankAccount', params, getVBBADataForOnyx());\n}\n\n/**\n * @param {Number} bankAccountID\n * @param {String} validateCode\n */\nfunction validateBankAccount(bankAccountID, validateCode) {\n API.write('ValidateBankAccountWithTransactions', {\n bankAccountID,\n validateCode,\n }, {\n optimisticData: [{\n onyxMethod: CONST.ONYX.METHOD.MERGE,\n key: ONYXKEYS.REIMBURSEMENT_ACCOUNT,\n value: {\n isLoading: true,\n errors: null,\n },\n }],\n successData: [{\n onyxMethod: CONST.ONYX.METHOD.MERGE,\n key: ONYXKEYS.REIMBURSEMENT_ACCOUNT,\n value: {\n isLoading: false,\n },\n }],\n failureData: [{\n onyxMethod: CONST.ONYX.METHOD.MERGE,\n key: ONYXKEYS.REIMBURSEMENT_ACCOUNT,\n value: {\n isLoading: false,\n },\n }],\n });\n}\n\nfunction openReimbursementAccountPage(stepToOpen, subStep, localCurrentStep) {\n const onyxData = {\n optimisticData: [\n {\n onyxMethod: CONST.ONYX.METHOD.MERGE,\n key: ONYXKEYS.REIMBURSEMENT_ACCOUNT,\n value: {\n errors: null,\n isLoading: true,\n },\n },\n ],\n successData: [\n {\n onyxMethod: CONST.ONYX.METHOD.MERGE,\n key: ONYXKEYS.REIMBURSEMENT_ACCOUNT,\n value: {\n isLoading: false,\n },\n },\n ],\n failureData: [\n {\n onyxMethod: CONST.ONYX.METHOD.MERGE,\n key: ONYXKEYS.REIMBURSEMENT_ACCOUNT,\n value: {\n isLoading: false,\n },\n },\n ],\n };\n\n const param = {\n stepToOpen,\n subStep,\n localCurrentStep,\n };\n\n return API.read('OpenReimbursementAccountPage', param, onyxData);\n}\n\n/**\n * Updates the bank account in the database with the company step data\n *\n * @param {Object} bankAccount\n * @param {Number} [bankAccount.bankAccountID]\n *\n * Fields from BankAccount step\n * @param {String} [bankAccount.routingNumber]\n * @param {String} [bankAccount.accountNumber]\n * @param {String} [bankAccount.bankName]\n * @param {String} [bankAccount.plaidAccountID]\n * @param {String} [bankAccount.plaidAccessToken]\n * @param {Boolean} [bankAccount.isSavings]\n *\n * Fields from Company step\n * @param {String} [bankAccount.companyName]\n * @param {String} [bankAccount.addressStreet]\n * @param {String} [bankAccount.addressCity]\n * @param {String} [bankAccount.addressState]\n * @param {String} [bankAccount.addressZipCode]\n * @param {String} [bankAccount.companyPhone]\n * @param {String} [bankAccount.website]\n * @param {String} [bankAccount.companyTaxID]\n * @param {String} [bankAccount.incorporationType]\n * @param {String} [bankAccount.incorporationState]\n * @param {String} [bankAccount.incorporationDate]\n * @param {Boolean} [bankAccount.hasNoConnectionToCannabis]\n */\nfunction updateCompanyInformationForBankAccount(bankAccount) {\n API.write('UpdateCompanyInformationForBankAccount', bankAccount, getVBBADataForOnyx());\n}\n\n/**\n * Add beneficial owners for the bank account, accept the ACH terms and conditions and verify the accuracy of the information provided\n *\n * @param {Object} params\n *\n * // ACH Contract Step\n * @param {Boolean} [params.ownsMoreThan25Percent]\n * @param {Boolean} [params.hasOtherBeneficialOwners]\n * @param {Boolean} [params.acceptTermsAndConditions]\n * @param {Boolean} [params.certifyTrueInformation]\n * @param {String} [params.beneficialOwners]\n */\nfunction updateBeneficialOwnersForBankAccount(params) {\n API.write('UpdateBeneficialOwnersForBankAccount', {...params}, getVBBADataForOnyx());\n}\n\n/**\n * Create the bank account with manually entered data.\n *\n * @param {number} [bankAccountID]\n * @param {String} [accountNumber]\n * @param {String} [routingNumber]\n * @param {String} [plaidMask]\n *\n */\nfunction connectBankAccountManually(bankAccountID, accountNumber, routingNumber, plaidMask) {\n API.write('ConnectBankAccountManually', {\n bankAccountID,\n accountNumber,\n routingNumber,\n plaidMask,\n }, getVBBADataForOnyx());\n}\n\n/**\n * Verify the user's identity via Onfido\n *\n * @param {Number} bankAccountID\n * @param {Object} onfidoData\n */\nfunction verifyIdentityForBankAccount(bankAccountID, onfidoData) {\n API.write('VerifyIdentityForBankAccount', {\n bankAccountID,\n onfidoData: JSON.stringify(onfidoData),\n }, getVBBADataForOnyx());\n}\n\nfunction openWorkspaceView() {\n API.read('OpenWorkspaceView');\n}\n\n/**\n * Set the reimbursement account loading so that it happens right away, instead of when the API command is processed.\n *\n * @param {Boolean} isLoading\n */\nfunction setReimbursementAccountLoading(isLoading) {\n Onyx.merge(ONYXKEYS.REIMBURSEMENT_ACCOUNT, {isLoading});\n}\n\nexport {\n addPersonalBankAccount,\n clearOnfidoToken,\n clearPersonalBankAccount,\n clearPlaid,\n openPlaidView,\n connectBankAccountManually,\n connectBankAccountWithPlaid,\n deletePaymentBankAccount,\n openPersonalBankAccountSetupView,\n openReimbursementAccountPage,\n updateBeneficialOwnersForBankAccount,\n updateCompanyInformationForBankAccount,\n updatePersonalInformationForBankAccount,\n openWorkspaceView,\n validateBankAccount,\n verifyIdentityForBankAccount,\n setReimbursementAccountLoading,\n};\n","import getPlaidLinkTokenParameters from '../getPlaidLinkTokenParameters';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport * as API from '../API';\nimport CONST from '../../CONST';\nimport * as PlaidDataProps from '../../pages/ReimbursementAccount/plaidDataPropTypes';\n\n/**\n * Gets the Plaid Link token used to initialize the Plaid SDK\n * @param {Boolean} allowDebit\n * @param {Number} bankAccountID\n */\nfunction openPlaidBankLogin(allowDebit, bankAccountID) {\n const params = getPlaidLinkTokenParameters();\n params.allowDebit = allowDebit;\n params.bankAccountID = bankAccountID;\n const optimisticData = [{\n onyxMethod: CONST.ONYX.METHOD.SET,\n key: ONYXKEYS.PLAID_DATA,\n value: {...PlaidDataProps.plaidDataDefaultProps, isLoading: true},\n }, {\n onyxMethod: CONST.ONYX.METHOD.SET,\n key: ONYXKEYS.PLAID_LINK_TOKEN,\n value: '',\n }, {\n onyxMethod: CONST.ONYX.METHOD.MERGE,\n key: ONYXKEYS.REIMBURSEMENT_ACCOUNT_DRAFT,\n value: {\n plaidAccountID: '',\n },\n }];\n\n API.read('OpenPlaidBankLogin', params, {optimisticData});\n}\n\n/**\n * @param {String} publicToken\n * @param {String} bankName\n * @param {Boolean} allowDebit\n */\nfunction openPlaidBankAccountSelector(publicToken, bankName, allowDebit) {\n API.read('OpenPlaidBankAccountSelector', {\n publicToken,\n allowDebit,\n bank: bankName,\n }, {\n optimisticData: [{\n onyxMethod: CONST.ONYX.METHOD.MERGE,\n key: ONYXKEYS.PLAID_DATA,\n value: {\n isLoading: true,\n errors: null,\n bankName,\n },\n }],\n successData: [{\n onyxMethod: CONST.ONYX.METHOD.MERGE,\n key: ONYXKEYS.PLAID_DATA,\n value: {\n isLoading: false,\n errors: null,\n },\n }],\n failureData: [{\n onyxMethod: CONST.ONYX.METHOD.MERGE,\n key: ONYXKEYS.PLAID_DATA,\n value: {\n isLoading: false,\n },\n }],\n });\n}\n\nexport {\n openPlaidBankAccountSelector,\n openPlaidBankLogin,\n};\n","import CONFIG from '../../CONFIG';\n\nexport default () => ({redirect_uri: `${CONFIG.EXPENSIFY.NEW_EXPENSIFY_URL}partners/plaid/oauth_ios`});\n","import PropTypes from 'prop-types';\n\nconst plaidDataPropTypes = PropTypes.shape({\n /** Whether we are fetching the bank accounts from the API */\n isLoading: PropTypes.bool,\n\n /** Any additional error message to show */\n errors: PropTypes.objectOf(PropTypes.string),\n\n /** Name of the bank */\n bankName: PropTypes.string,\n\n /** Access token returned by Plaid once the user has logged into their bank. This token can be used along with internal credentials to query for Plaid Balance or Assets */\n plaidAccessToken: PropTypes.string,\n\n /** List of plaid bank accounts */\n bankAccounts: PropTypes.arrayOf(PropTypes.shape({\n /** Masked account number */\n accountNumber: PropTypes.string,\n\n /** Name of account */\n addressName: PropTypes.string,\n\n /** Is the account a savings account? */\n isSavings: PropTypes.bool,\n\n /** Unique identifier for this account in Plaid */\n plaidAccountID: PropTypes.string,\n\n /** Routing number for the account */\n routingNumber: PropTypes.string,\n\n /** last 4 digits of the account number */\n mask: PropTypes.string,\n\n /** Plaid access token, used to then retrieve Assets and Balances */\n plaidAccessToken: PropTypes.string,\n })),\n});\n\nconst plaidDataDefaultProps = {\n bankName: '',\n plaidAccessToken: '',\n bankAccounts: [],\n isLoading: false,\n error: '',\n errors: {},\n};\n\nexport {plaidDataPropTypes, plaidDataDefaultProps};\n","import Onyx from 'react-native-onyx';\nimport ONYXKEYS from '../../../ONYXKEYS';\nimport resetFreePlanBankAccount from './resetFreePlanBankAccount';\nimport deleteFromBankAccountList from './deleteFromBankAccountList';\n\nexport {goToWithdrawalAccountSetupStep, navigateToBankAccountRoute} from './navigation';\nexport {\n setBankAccountFormValidationErrors,\n setPersonalBankAccountFormValidationErrorFields,\n resetReimbursementAccount,\n showBankAccountFormValidationError,\n} from './errors';\n\n/**\n * Set the current sub step in first step of adding withdrawal bank account:\n * - `null` if we want to go back to the view where the user selects between connecting via Plaid or connecting manually\n * - CONST.BANK_ACCOUNT.SETUP_TYPE.MANUAL to ask them to enter their accountNumber and routingNumber\n * - CONST.BANK_ACCOUNT.SETUP_TYPE.PLAID to ask them to login to their bank via Plaid\n *\n * @param {String} subStep\n */\nfunction setBankAccountSubStep(subStep) {\n Onyx.merge(ONYXKEYS.REIMBURSEMENT_ACCOUNT, {achData: {subStep}});\n}\n\nfunction hideBankAccountErrors() {\n Onyx.merge(ONYXKEYS.REIMBURSEMENT_ACCOUNT, {error: '', errors: null});\n}\n\nfunction setWorkspaceIDForReimbursementAccount(workspaceID) {\n Onyx.merge(ONYXKEYS.REIMBURSEMENT_ACCOUNT_WORKSPACE_ID, workspaceID);\n}\n\n/**\n * @param {Object} bankAccountData\n */\nfunction updateReimbursementAccountDraft(bankAccountData) {\n Onyx.merge(ONYXKEYS.REIMBURSEMENT_ACCOUNT_DRAFT, bankAccountData);\n}\n\n/**\n * Triggers a modal to open allowing the user to reset their bank account\n */\nfunction requestResetFreePlanBankAccount() {\n Onyx.merge(ONYXKEYS.REIMBURSEMENT_ACCOUNT, {shouldShowResetModal: true});\n}\n\n/**\n * Hides modal allowing the user to reset their bank account\n */\nfunction cancelResetFreePlanBankAccount() {\n Onyx.merge(ONYXKEYS.REIMBURSEMENT_ACCOUNT, {shouldShowResetModal: false});\n}\n\nexport {\n resetFreePlanBankAccount,\n setBankAccountSubStep,\n hideBankAccountErrors,\n setWorkspaceIDForReimbursementAccount,\n updateReimbursementAccountDraft,\n requestResetFreePlanBankAccount,\n cancelResetFreePlanBankAccount,\n deleteFromBankAccountList,\n};\n","import Onyx from 'react-native-onyx';\nimport ONYXKEYS from '../../../ONYXKEYS';\nimport ROUTES from '../../../ROUTES';\nimport Navigation from '../../Navigation/Navigation';\n\n/**\n * Navigate to a specific step in the VBA flow\n *\n * @param {String} stepID\n * @param {Object} newAchData\n */\nfunction goToWithdrawalAccountSetupStep(stepID, newAchData) {\n Onyx.merge(ONYXKEYS.REIMBURSEMENT_ACCOUNT, {achData: {...newAchData, currentStep: stepID}});\n}\n\n/**\n * Navigate to the correct bank account route based on the bank account state and type\n *\n * @param {String} policyId\n */\nfunction navigateToBankAccountRoute(policyId) {\n Navigation.navigate(ROUTES.getBankAccountRoute('', policyId));\n}\n\nexport {\n goToWithdrawalAccountSetupStep,\n navigateToBankAccountRoute,\n};\n","import Onyx from 'react-native-onyx';\nimport ONYXKEYS from '../../../ONYXKEYS';\nimport DateUtils from '../../DateUtils';\n\n/**\n * Set the current fields with errors.\n * @param {Object} errorFields\n */\nfunction setPersonalBankAccountFormValidationErrorFields(errorFields) {\n // We set 'errorFields' to null first because we don't have a way yet to replace a specific property without merging it\n Onyx.merge(ONYXKEYS.PERSONAL_BANK_ACCOUNT, {errorFields: null});\n Onyx.merge(ONYXKEYS.PERSONAL_BANK_ACCOUNT, {errorFields});\n}\n\n/**\n * Set the current fields with errors.\n *\n * @param {Object} errorFields\n */\nfunction setBankAccountFormValidationErrors(errorFields) {\n Onyx.merge(ONYXKEYS.REIMBURSEMENT_ACCOUNT, {errorFields: null});\n Onyx.merge(ONYXKEYS.REIMBURSEMENT_ACCOUNT, {errorFields});\n}\n\n/**\n * Clear validation messages from reimbursement account\n */\nfunction resetReimbursementAccount() {\n setBankAccountFormValidationErrors({});\n Onyx.merge(ONYXKEYS.REIMBURSEMENT_ACCOUNT, {errors: null});\n}\n\n/**\n * Set the current error message.\n *\n * @param {String} error\n */\nfunction showBankAccountFormValidationError(error) {\n Onyx.merge(ONYXKEYS.REIMBURSEMENT_ACCOUNT, {\n // eslint-disable-next-line rulesdir/prefer-localization\n errors: {\n [DateUtils.getMicroseconds()]: error,\n },\n });\n}\n\nexport {\n setBankAccountFormValidationErrors,\n setPersonalBankAccountFormValidationErrorFields,\n showBankAccountFormValidationError,\n resetReimbursementAccount,\n};\n","import CONST from '../../../CONST';\nimport ONYXKEYS from '../../../ONYXKEYS';\nimport * as store from './store';\nimport * as API from '../../API';\nimport * as PlaidDataProps from '../../../pages/ReimbursementAccount/plaidDataPropTypes';\nimport * as ReimbursementAccountProps from '../../../pages/ReimbursementAccount/reimbursementAccountPropTypes';\n\n/**\n * Reset user's reimbursement account. This will delete the bank account.\n * @param {number} bankAccountID\n */\nfunction resetFreePlanBankAccount(bankAccountID) {\n if (!bankAccountID) {\n throw new Error('Missing bankAccountID when attempting to reset free plan bank account');\n }\n if (!store.getCredentials() || !store.getCredentials().login) {\n throw new Error('Missing credentials when attempting to reset free plan bank account');\n }\n\n API.write('RestartBankAccountSetup',\n {\n bankAccountID,\n ownerEmail: store.getCredentials().login,\n },\n {\n optimisticData: [\n {\n onyxMethod: CONST.ONYX.METHOD.SET,\n key: ONYXKEYS.ONFIDO_TOKEN,\n value: '',\n },\n {\n onyxMethod: CONST.ONYX.METHOD.SET,\n key: ONYXKEYS.PLAID_DATA,\n value: PlaidDataProps.plaidDataDefaultProps,\n },\n {\n onyxMethod: CONST.ONYX.METHOD.SET,\n key: ONYXKEYS.PLAID_LINK_TOKEN,\n value: '',\n },\n {\n onyxMethod: CONST.ONYX.METHOD.SET,\n key: ONYXKEYS.REIMBURSEMENT_ACCOUNT,\n value: ReimbursementAccountProps.reimbursementAccountDefaultProps,\n },\n {\n onyxMethod: CONST.ONYX.METHOD.MERGE,\n key: ONYXKEYS.REIMBURSEMENT_ACCOUNT,\n value: {isLoading: true},\n },\n {\n onyxMethod: CONST.ONYX.METHOD.SET,\n key: ONYXKEYS.REIMBURSEMENT_ACCOUNT_DRAFT,\n value: {},\n },\n ],\n successData: [\n {\n onyxMethod: CONST.ONYX.METHOD.MERGE,\n key: ONYXKEYS.REIMBURSEMENT_ACCOUNT,\n value: {isLoading: false},\n },\n ],\n failureData: [\n {\n onyxMethod: CONST.ONYX.METHOD.MERGE,\n key: ONYXKEYS.REIMBURSEMENT_ACCOUNT,\n value: {isLoading: false},\n },\n ],\n });\n}\n\nexport default resetFreePlanBankAccount;\n","import Onyx from 'react-native-onyx';\nimport lodashGet from 'lodash/get';\nimport ONYXKEYS from '../../../ONYXKEYS';\n\n/** Reimbursement account actively being set up */\nlet reimbursementAccountInSetup = {};\nOnyx.connect({\n key: ONYXKEYS.REIMBURSEMENT_ACCOUNT,\n callback: (val) => {\n reimbursementAccountInSetup = lodashGet(val, 'achData', {});\n },\n});\n\nlet reimbursementAccountWorkspaceID = null;\nOnyx.connect({\n key: ONYXKEYS.REIMBURSEMENT_ACCOUNT_WORKSPACE_ID,\n callback: (val) => {\n reimbursementAccountWorkspaceID = val;\n },\n});\n\nlet bankAccountList = null;\nOnyx.connect({\n key: ONYXKEYS.BANK_ACCOUNT_LIST,\n callback: (val) => {\n bankAccountList = val;\n },\n});\n\nlet credentials;\nOnyx.connect({\n key: ONYXKEYS.CREDENTIALS,\n callback: (val) => {\n credentials = val || {};\n },\n});\n\nfunction getReimbursementAccountInSetup() {\n return reimbursementAccountInSetup;\n}\n\nfunction getBankAccountList() {\n return bankAccountList;\n}\n\nfunction getCredentials() {\n return credentials;\n}\n\nfunction getReimbursementAccountWorkspaceID() {\n return reimbursementAccountWorkspaceID;\n}\n\nexport {\n getReimbursementAccountInSetup,\n getBankAccountList,\n getCredentials,\n getReimbursementAccountWorkspaceID,\n};\n","import PropTypes from 'prop-types';\nimport BankAccount from '../../libs/models/BankAccount';\n\nconst reimbursementAccountPropTypes = PropTypes.shape({\n /** Whether we are loading the data via the API */\n isLoading: PropTypes.bool,\n\n /** A date that indicates the user has been throttled */\n throttledDate: PropTypes.string,\n\n /** Additional data for the account in setup */\n achData: PropTypes.shape({\n\n /** Step of the setup flow that we are on. Determines which view is presented. */\n currentStep: PropTypes.string,\n\n /** Bank account state */\n state: PropTypes.string,\n\n /** Bank account ID of the VBA that we are validating is required */\n bankAccountID: PropTypes.number,\n\n }),\n\n /** Disable validation button if max attempts exceeded */\n maxAttemptsReached: PropTypes.bool,\n\n /** Alert message to display above submit button */\n error: PropTypes.string,\n\n /** Which field needs attention? */\n errorFields: PropTypes.objectOf(PropTypes.oneOfType([PropTypes.bool, PropTypes.array])),\n\n /** Any additional error message to show */\n errors: PropTypes.objectOf(PropTypes.string),\n});\n\nconst reimbursementAccountDefaultProps = {\n achData: {\n state: BankAccount.STATE.SETUP,\n },\n isLoading: false,\n errorFields: {},\n errors: {},\n maxAttemptsReached: false,\n shouldShowResetModal: false,\n};\n\nexport {reimbursementAccountPropTypes, reimbursementAccountDefaultProps};\n","import Onyx from 'react-native-onyx';\nimport ONYXKEYS from '../../../ONYXKEYS';\nimport * as store from './store';\n\n/**\n * Deletes a bank account from bankAccountList\n *\n * @param {Number} bankAccountID\n */\nfunction deleteFromBankAccountList(bankAccountID) {\n // We should delete the bankAccountID key from the bankAccountList object before setting it in Onyx\n const bankAccountList = store.getBankAccountList();\n delete bankAccountList[bankAccountID];\n\n Onyx.merge(ONYXKEYS.BANK_ACCOUNT_LIST, bankAccountList);\n}\n\nexport default deleteFromBankAccountList;\n","import _ from 'underscore';\nimport React from 'react';\nimport {\n ActivityIndicator,\n View,\n} from 'react-native';\nimport PropTypes from 'prop-types';\nimport {withOnyx} from 'react-native-onyx';\nimport lodashGet from 'lodash/get';\nimport Log from '../libs/Log';\nimport PlaidLink from './PlaidLink';\nimport * as BankAccounts from '../libs/actions/BankAccounts';\nimport ONYXKEYS from '../ONYXKEYS';\nimport styles from '../styles/styles';\nimport themeColors from '../styles/themes/default';\nimport compose from '../libs/compose';\nimport withLocalize, {withLocalizePropTypes} from './withLocalize';\nimport Picker from './Picker';\nimport {plaidDataPropTypes} from '../pages/ReimbursementAccount/plaidDataPropTypes';\nimport Text from './Text';\nimport getBankIcon from './Icon/BankIcons';\nimport Icon from './Icon';\nimport FullPageOfflineBlockingView from './BlockingViews/FullPageOfflineBlockingView';\nimport {withNetwork} from './OnyxProvider';\n\nconst propTypes = {\n /** Contains plaid data */\n plaidData: plaidDataPropTypes.isRequired,\n\n /** Selected account ID from the Picker associated with the end of the Plaid flow */\n selectedPlaidAccountID: PropTypes.string,\n\n /** Plaid SDK token to use to initialize the widget */\n plaidLinkToken: PropTypes.string,\n\n /** Fired when the user exits the Plaid flow */\n onExitPlaid: PropTypes.func,\n\n /** Fired when the user selects an account */\n onSelect: PropTypes.func,\n\n /** Additional text to display */\n text: PropTypes.string,\n\n /** The OAuth URI + stateID needed to re-initialize the PlaidLink after the user logs into their bank */\n receivedRedirectURI: PropTypes.string,\n\n /** During the OAuth flow we need to use the plaidLink token that we initially connected with */\n plaidLinkOAuthToken: PropTypes.string,\n\n /** If we're updating an existing bank account, what's its bank account ID? */\n bankAccountID: PropTypes.number,\n\n /** Are we adding a withdrawal account? */\n allowDebit: PropTypes.bool,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n selectedPlaidAccountID: '',\n plaidLinkToken: '',\n onExitPlaid: () => {},\n onSelect: () => {},\n text: '',\n receivedRedirectURI: null,\n plaidLinkOAuthToken: '',\n allowDebit: false,\n bankAccountID: 0,\n};\n\nclass AddPlaidBankAccount extends React.Component {\n constructor(props) {\n super(props);\n\n this.getPlaidLinkToken = this.getPlaidLinkToken.bind(this);\n }\n\n componentDidMount() {\n // If we're coming from Plaid OAuth flow then we need to reuse the existing plaidLinkToken\n if (this.isAuthenticatedWithPlaid()) {\n return;\n }\n\n BankAccounts.openPlaidBankLogin(this.props.allowDebit, this.props.bankAccountID);\n }\n\n componentDidUpdate(prevProps) {\n if (!prevProps.network.isOffline || this.props.network.isOffline || this.isAuthenticatedWithPlaid()) {\n return;\n }\n\n // If we are coming back from offline and we haven't authenticated with Plaid yet, we need to re-run our call to kick off Plaid\n BankAccounts.openPlaidBankLogin(this.props.allowDebit, this.props.bankAccountID);\n }\n\n /**\n * @returns {String}\n */\n getPlaidLinkToken() {\n if (this.props.plaidLinkToken) {\n return this.props.plaidLinkToken;\n }\n\n if (this.props.receivedRedirectURI && this.props.plaidLinkOAuthToken) {\n return this.props.plaidLinkOAuthToken;\n }\n }\n\n /**\n * @returns {Boolean}\n */\n isAuthenticatedWithPlaid() {\n return ((this.props.receivedRedirectURI && this.props.plaidLinkOAuthToken)\n || !_.isEmpty(lodashGet(this.props.plaidData, 'bankAccounts'))\n || !_.isEmpty(lodashGet(this.props.plaidData, 'errors')));\n }\n\n render() {\n const plaidBankAccounts = lodashGet(this.props.plaidData, 'bankAccounts') || [];\n const token = this.getPlaidLinkToken();\n const options = _.map(plaidBankAccounts, account => ({\n value: account.plaidAccountID,\n label: `${account.addressName} ${account.mask}`,\n }));\n const {icon, iconSize} = getBankIcon();\n const plaidErrors = lodashGet(this.props.plaidData, 'errors');\n const plaidDataErrorMessage = !_.isEmpty(plaidErrors) ? _.chain(plaidErrors).values().first().value() : '';\n const bankName = lodashGet(this.props.plaidData, 'bankName');\n\n // Plaid Link view\n if (!plaidBankAccounts.length) {\n return (\n \n {lodashGet(this.props.plaidData, 'isLoading') && (\n \n \n \n )}\n {Boolean(plaidDataErrorMessage) && (\n \n {plaidDataErrorMessage}\n \n )}\n {Boolean(token) && !bankName && (\n {\n Log.info('[PlaidLink] Success!');\n BankAccounts.openPlaidBankAccountSelector(publicToken, metadata.institution.name, this.props.allowDebit);\n }}\n onError={(error) => {\n Log.hmmm('[PlaidLink] Error: ', error.message);\n }}\n\n // User prematurely exited the Plaid flow\n // eslint-disable-next-line react/jsx-props-no-multi-spaces\n onExit={this.props.onExitPlaid}\n receivedRedirectURI={this.props.receivedRedirectURI}\n />\n )}\n \n );\n }\n\n // Plaid bank accounts view\n return (\n \n {!_.isEmpty(this.props.text) && (\n {this.props.text}\n )}\n \n \n {bankName}\n \n \n \n \n \n );\n }\n}\n\nAddPlaidBankAccount.propTypes = propTypes;\nAddPlaidBankAccount.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withNetwork(),\n withOnyx({\n plaidLinkToken: {\n key: ONYXKEYS.PLAID_LINK_TOKEN,\n initWithStoredValues: false,\n },\n }),\n)(AddPlaidBankAccount);\n","import {useEffect} from 'react';\nimport {openLink, useDeepLinkRedirector, usePlaidEmitter} from 'react-native-plaid-link-sdk';\nimport Log from '../../libs/Log';\nimport CONST from '../../CONST';\nimport {plaidLinkPropTypes, plaidLinkDefaultProps} from './plaidLinkPropTypes';\n\nconst PlaidLink = (props) => {\n useDeepLinkRedirector();\n usePlaidEmitter((event) => {\n Log.info('[PlaidLink] Handled Plaid Event: ', false, event);\n if (event.eventName === CONST.PLAID.EVENT.ERROR) {\n props.onError(event.metadata);\n }\n });\n useEffect(() => {\n openLink({\n tokenConfig: {\n token: props.token,\n },\n onSuccess: ({publicToken, metadata}) => {\n props.onSuccess({publicToken, metadata});\n },\n onExit: (exitError, metadata) => {\n Log.info('[PlaidLink] Exit: ', false, {exitError, metadata});\n props.onExit();\n },\n });\n\n // We generally do not need to include the token as a dependency here as it is only provided once via props and should not change\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n return null;\n};\n\nPlaidLink.propTypes = plaidLinkPropTypes;\nPlaidLink.defaultProps = plaidLinkDefaultProps;\nPlaidLink.displayName = 'PlaidLink';\n\nexport default PlaidLink;\n","import { openLink, dismissLink, useDeepLinkRedirector, usePlaidEmitter, PlaidLink, } from './PlaidLink';\nexport * from './Types';\nexport default PlaidLink;\nexport { PlaidLink, openLink, dismissLink, useDeepLinkRedirector, usePlaidEmitter, };\n","var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nimport React, { useEffect } from 'react';\nimport { Linking, NativeEventEmitter, NativeModules, Platform, TouchableOpacity, } from 'react-native';\n/**\n * A hook that registers a listener on the Plaid emitter for the 'onEvent' type.\n * The listener is cleaned up when this view is unmounted\n *\n * @param LinkEventListener the listener to call\n */\nexport const usePlaidEmitter = (LinkEventListener) => {\n useEffect(() => {\n const emitter = new NativeEventEmitter(Platform.OS === 'ios'\n ? NativeModules.RNLinksdk\n : NativeModules.PlaidAndroid);\n const listener = emitter.addListener('onEvent', LinkEventListener);\n // Clean up after this effect:\n return function cleanup() {\n listener.remove();\n };\n }, []);\n};\nexport const openLink = (props) => __awaiter(void 0, void 0, void 0, function* () {\n if (props.tokenConfig == null) {\n console.log('The public_key is being deprecated. Learn how to upgrade to link_tokens at https://plaid.com/docs/link-token-migration-guide/');\n }\n let config = props.tokenConfig ? props.tokenConfig : props.publicKeyConfig;\n if (Platform.OS === 'android') {\n NativeModules.PlaidAndroid.startLinkActivityForResult(JSON.stringify(config), (result) => {\n if (props.onSuccess != null) {\n props.onSuccess(result);\n }\n }, (result) => {\n if (props.onExit != null) {\n if (result.error != null && result.error.displayMessage != null) {\n //TODO(RNSDK-118): Remove errorDisplayMessage field in next major update.\n result.error.errorDisplayMessage = result.error.displayMessage;\n }\n props.onExit(result);\n }\n });\n }\n else {\n NativeModules.RNLinksdk.create(config);\n NativeModules.RNLinksdk.open((result) => {\n if (props.onSuccess != null) {\n props.onSuccess(result);\n }\n }, (error, result) => {\n if (props.onExit != null) {\n if (error) {\n var data = result || {};\n data.error = error;\n props.onExit(data);\n }\n else {\n props.onExit(result);\n }\n }\n });\n }\n});\nexport const dismissLink = () => {\n if (Platform.OS === 'ios') {\n NativeModules.RNLinksdk.dismiss();\n }\n};\nexport const useDeepLinkRedirector = () => {\n const _handleListenerChange = (event) => {\n if (event.url !== null && Platform.OS === 'ios') {\n NativeModules.RNLinksdk.continueFromRedirectUriString(event.url);\n }\n };\n useEffect(() => {\n const listener = Linking.addEventListener('url', _handleListenerChange);\n return function cleanup() {\n listener.remove();\n };\n }, []);\n};\nexport const PlaidLink = (props) => {\n function onPress() {\n var _a;\n (_a = props.onPress) === null || _a === void 0 ? void 0 : _a.call(props);\n openLink(props);\n }\n useDeepLinkRedirector();\n return {props.children};\n};\n","export var LinkLogLevel;\n(function (LinkLogLevel) {\n LinkLogLevel[\"DEBUG\"] = \"debug\";\n LinkLogLevel[\"INFO\"] = \"info\";\n LinkLogLevel[\"WARN\"] = \"warn\";\n LinkLogLevel[\"ERROR\"] = \"error\";\n})(LinkLogLevel || (LinkLogLevel = {}));\nexport var PlaidEnvironment;\n(function (PlaidEnvironment) {\n PlaidEnvironment[\"PRODUCTION\"] = \"production\";\n PlaidEnvironment[\"DEVELOPMENT\"] = \"development\";\n PlaidEnvironment[\"SANDBOX\"] = \"sandbox\";\n})(PlaidEnvironment || (PlaidEnvironment = {}));\nexport var PlaidProduct;\n(function (PlaidProduct) {\n PlaidProduct[\"ASSETS\"] = \"assets\";\n PlaidProduct[\"AUTH\"] = \"auth\";\n PlaidProduct[\"DEPOSIT_SWITCH\"] = \"deposit_switch\";\n PlaidProduct[\"IDENTITY\"] = \"identity\";\n PlaidProduct[\"INCOME\"] = \"income\";\n PlaidProduct[\"INVESTMENTS\"] = \"investments\";\n PlaidProduct[\"LIABILITIES\"] = \"liabilities\";\n PlaidProduct[\"LIABILITIES_REPORT\"] = \"liabilities_report\";\n PlaidProduct[\"PAYMENT_INITIATION\"] = \"payment_initiation\";\n PlaidProduct[\"TRANSACTIONS\"] = \"transactions\";\n})(PlaidProduct || (PlaidProduct = {}));\nvar LinkAccountType;\n(function (LinkAccountType) {\n LinkAccountType[\"CREDIT\"] = \"credit\";\n LinkAccountType[\"DEPOSITORY\"] = \"depository\";\n LinkAccountType[\"INVESTMENT\"] = \"investment\";\n LinkAccountType[\"LOAN\"] = \"loan\";\n LinkAccountType[\"OTHER\"] = \"other\";\n})(LinkAccountType || (LinkAccountType = {}));\nvar LinkAccountSubtypes;\n(function (LinkAccountSubtypes) {\n LinkAccountSubtypes[\"ALL\"] = \"all\";\n LinkAccountSubtypes[\"CREDIT_CARD\"] = \"credit card\";\n LinkAccountSubtypes[\"PAYPAL\"] = \"paypal\";\n LinkAccountSubtypes[\"AUTO\"] = \"auto\";\n LinkAccountSubtypes[\"BUSINESS\"] = \"business\";\n LinkAccountSubtypes[\"COMMERCIAL\"] = \"commercial\";\n LinkAccountSubtypes[\"CONSTRUCTION\"] = \"construction\";\n LinkAccountSubtypes[\"CONSUMER\"] = \"consumer\";\n LinkAccountSubtypes[\"HOME_EQUITY\"] = \"home equity\";\n LinkAccountSubtypes[\"LINE_OF_CREDIT\"] = \"line of credit\";\n LinkAccountSubtypes[\"LOAN\"] = \"loan\";\n LinkAccountSubtypes[\"MORTGAGE\"] = \"mortgage\";\n LinkAccountSubtypes[\"OVERDRAFT\"] = \"overdraft\";\n LinkAccountSubtypes[\"STUDENT\"] = \"student\";\n LinkAccountSubtypes[\"CASH_MANAGEMENT\"] = \"cash management\";\n LinkAccountSubtypes[\"CD\"] = \"cd\";\n LinkAccountSubtypes[\"CHECKING\"] = \"checking\";\n LinkAccountSubtypes[\"EBT\"] = \"ebt\";\n LinkAccountSubtypes[\"HSA\"] = \"hsa\";\n LinkAccountSubtypes[\"MONEY_MARKET\"] = \"money market\";\n LinkAccountSubtypes[\"PREPAID\"] = \"prepaid\";\n LinkAccountSubtypes[\"SAVINGS\"] = \"savings\";\n LinkAccountSubtypes[\"FOUR_0_1_A\"] = \"401a\";\n LinkAccountSubtypes[\"FOUR_0_1_K\"] = \"401k\";\n LinkAccountSubtypes[\"FOUR_0_3_B\"] = \"403B\";\n LinkAccountSubtypes[\"FOUR_5_7_B\"] = \"457b\";\n LinkAccountSubtypes[\"FIVE_2_9\"] = \"529\";\n LinkAccountSubtypes[\"BROKERAGE\"] = \"brokerage\";\n LinkAccountSubtypes[\"CASH_ISA\"] = \"cash isa\";\n LinkAccountSubtypes[\"EDUCATION_SAVINGS_ACCOUNT\"] = \"education savings account\";\n LinkAccountSubtypes[\"FIXED_ANNUNITY\"] = \"fixed annuity\";\n LinkAccountSubtypes[\"GIC\"] = \"gic\";\n LinkAccountSubtypes[\"HEALTH_REIMBURSEMENT_ARRANGEMENT\"] = \"health reimbursement arrangement\";\n LinkAccountSubtypes[\"IRA\"] = \"ira\";\n LinkAccountSubtypes[\"ISA\"] = \"isa\";\n LinkAccountSubtypes[\"KEOGH\"] = \"keogh\";\n LinkAccountSubtypes[\"LIF\"] = \"lif\";\n LinkAccountSubtypes[\"LIRA\"] = \"lira\";\n LinkAccountSubtypes[\"LRIF\"] = \"lrif\";\n LinkAccountSubtypes[\"LRSP\"] = \"lrsp\";\n LinkAccountSubtypes[\"MUTUAL_FUND\"] = \"mutual fund\";\n LinkAccountSubtypes[\"NON_TAXABLE_BROKERAGE_ACCOUNT\"] = \"non-taxable brokerage account\";\n LinkAccountSubtypes[\"PENSION\"] = \"pension\";\n LinkAccountSubtypes[\"PLAN\"] = \"plan\";\n LinkAccountSubtypes[\"PRIF\"] = \"prif\";\n LinkAccountSubtypes[\"PROFIT_SHARING_PLAN\"] = \"profit sharing plan\";\n LinkAccountSubtypes[\"RDSP\"] = \"rdsp\";\n LinkAccountSubtypes[\"RESP\"] = \"resp\";\n LinkAccountSubtypes[\"RETIREMENT\"] = \"retirement\";\n LinkAccountSubtypes[\"RLIF\"] = \"rlif\";\n LinkAccountSubtypes[\"ROTH_401K\"] = \"roth 401k\";\n LinkAccountSubtypes[\"ROTH\"] = \"roth\";\n LinkAccountSubtypes[\"RRIF\"] = \"rrif\";\n LinkAccountSubtypes[\"RRSP\"] = \"rrsp\";\n LinkAccountSubtypes[\"SARSEP\"] = \"sarsep\";\n LinkAccountSubtypes[\"SEP_IRA\"] = \"sep ira\";\n LinkAccountSubtypes[\"SIMPLE_IRA\"] = \"simple ira\";\n LinkAccountSubtypes[\"SIPP\"] = \"sipp\";\n LinkAccountSubtypes[\"STOCK_PLAN\"] = \"stock plan\";\n LinkAccountSubtypes[\"TFSA\"] = \"tfsa\";\n LinkAccountSubtypes[\"THRIFT_SAVINGS_PLAN\"] = \"thrift savings plan\";\n LinkAccountSubtypes[\"TRUST\"] = \"trust\";\n LinkAccountSubtypes[\"UGMA\"] = \"ugma\";\n LinkAccountSubtypes[\"UTMA\"] = \"utma\";\n LinkAccountSubtypes[\"VARIABLE_ANNUITY\"] = \"variable annuity\";\n})(LinkAccountSubtypes || (LinkAccountSubtypes = {}));\nexport class LinkAccountSubtypeCredit {\n constructor(type, subtype) {\n this.type = type;\n this.subtype = subtype;\n }\n}\nLinkAccountSubtypeCredit.ALL = new LinkAccountSubtypeCredit(LinkAccountType.CREDIT, LinkAccountSubtypes.ALL);\nLinkAccountSubtypeCredit.CREDIT_CARD = new LinkAccountSubtypeCredit(LinkAccountType.CREDIT, LinkAccountSubtypes.CREDIT_CARD);\nLinkAccountSubtypeCredit.PAYPAL = new LinkAccountSubtypeCredit(LinkAccountType.CREDIT, LinkAccountSubtypes.PAYPAL);\nexport class LinkAccountSubtypeDepository {\n constructor(type, subtype) {\n this.type = type;\n this.subtype = subtype;\n }\n}\nLinkAccountSubtypeDepository.ALL = new LinkAccountSubtypeDepository(LinkAccountType.DEPOSITORY, LinkAccountSubtypes.ALL);\nLinkAccountSubtypeDepository.CASH_MANAGEMENT = new LinkAccountSubtypeDepository(LinkAccountType.DEPOSITORY, LinkAccountSubtypes.CASH_MANAGEMENT);\nLinkAccountSubtypeDepository.CD = new LinkAccountSubtypeDepository(LinkAccountType.DEPOSITORY, LinkAccountSubtypes.CD);\nLinkAccountSubtypeDepository.CHECKING = new LinkAccountSubtypeDepository(LinkAccountType.DEPOSITORY, LinkAccountSubtypes.CHECKING);\nLinkAccountSubtypeDepository.EBT = new LinkAccountSubtypeDepository(LinkAccountType.DEPOSITORY, LinkAccountSubtypes.EBT);\nLinkAccountSubtypeDepository.HSA = new LinkAccountSubtypeDepository(LinkAccountType.DEPOSITORY, LinkAccountSubtypes.HSA);\nLinkAccountSubtypeDepository.MONEY_MARKET = new LinkAccountSubtypeDepository(LinkAccountType.DEPOSITORY, LinkAccountSubtypes.MONEY_MARKET);\nLinkAccountSubtypeDepository.PAYPAL = new LinkAccountSubtypeDepository(LinkAccountType.DEPOSITORY, LinkAccountSubtypes.PAYPAL);\nLinkAccountSubtypeDepository.PREPAID = new LinkAccountSubtypeDepository(LinkAccountType.DEPOSITORY, LinkAccountSubtypes.PREPAID);\nLinkAccountSubtypeDepository.SAVINGS = new LinkAccountSubtypeDepository(LinkAccountType.DEPOSITORY, LinkAccountSubtypes.SAVINGS);\nexport class LinkAccountSubtypeInvestment {\n constructor(type, subtype) {\n this.type = type;\n this.subtype = subtype;\n }\n}\nLinkAccountSubtypeInvestment.ALL = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.ALL);\nLinkAccountSubtypeInvestment.BROKERAGE = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.BROKERAGE);\nLinkAccountSubtypeInvestment.CASH_ISA = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.CASH_ISA);\nLinkAccountSubtypeInvestment.EDUCATION_SAVINGS_ACCOUNT = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.EDUCATION_SAVINGS_ACCOUNT);\nLinkAccountSubtypeInvestment.FIXED_ANNUNITY = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.FIXED_ANNUNITY);\nLinkAccountSubtypeInvestment.GIC = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.GIC);\nLinkAccountSubtypeInvestment.HEALTH_REIMBURSEMENT_ARRANGEMENT = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.HEALTH_REIMBURSEMENT_ARRANGEMENT);\nLinkAccountSubtypeInvestment.HSA = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.HSA);\nLinkAccountSubtypeInvestment.INVESTMENT_401A = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.FOUR_0_1_A);\nLinkAccountSubtypeInvestment.INVESTMENT_401K = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.FOUR_0_1_K);\nLinkAccountSubtypeInvestment.INVESTMENT_403B = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.FOUR_0_3_B);\nLinkAccountSubtypeInvestment.INVESTMENT_457B = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.FOUR_5_7_B);\nLinkAccountSubtypeInvestment.INVESTMENT_529 = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.FIVE_2_9);\nLinkAccountSubtypeInvestment.IRA = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.IRA);\nLinkAccountSubtypeInvestment.ISA = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.ISA);\nLinkAccountSubtypeInvestment.KEOGH = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.KEOGH);\nLinkAccountSubtypeInvestment.LIF = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.LIF);\nLinkAccountSubtypeInvestment.LIRA = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.LIRA);\nLinkAccountSubtypeInvestment.LRIF = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.LRIF);\nLinkAccountSubtypeInvestment.LRSP = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.LRSP);\nLinkAccountSubtypeInvestment.MUTUAL_FUND = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.MUTUAL_FUND);\nLinkAccountSubtypeInvestment.NON_TAXABLE_BROKERAGE_ACCOUNT = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.NON_TAXABLE_BROKERAGE_ACCOUNT);\nLinkAccountSubtypeInvestment.PENSION = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.PENSION);\nLinkAccountSubtypeInvestment.PLAN = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.PLAN);\nLinkAccountSubtypeInvestment.PRIF = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.PRIF);\nLinkAccountSubtypeInvestment.PROFIT_SHARING_PLAN = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.PROFIT_SHARING_PLAN);\nLinkAccountSubtypeInvestment.RDSP = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.RDSP);\nLinkAccountSubtypeInvestment.RESP = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.RESP);\nLinkAccountSubtypeInvestment.RETIREMENT = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.RETIREMENT);\nLinkAccountSubtypeInvestment.RLIF = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.RLIF);\nLinkAccountSubtypeInvestment.ROTH = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.ROTH);\nLinkAccountSubtypeInvestment.ROTH_401K = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.ROTH_401K);\nLinkAccountSubtypeInvestment.RRIF = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.RRIF);\nLinkAccountSubtypeInvestment.RRSP = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.RRSP);\nLinkAccountSubtypeInvestment.SARSEP = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.SARSEP);\nLinkAccountSubtypeInvestment.SEP_IRA = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.SEP_IRA);\nLinkAccountSubtypeInvestment.SIMPLE_IRA = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.SIMPLE_IRA);\nLinkAccountSubtypeInvestment.SIIP = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.SIPP);\nLinkAccountSubtypeInvestment.STOCK_PLAN = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.STOCK_PLAN);\nLinkAccountSubtypeInvestment.TFSA = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.TFSA);\nLinkAccountSubtypeInvestment.THRIFT_SAVINGS_PLAN = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.THRIFT_SAVINGS_PLAN);\nLinkAccountSubtypeInvestment.TRUST = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.TRUST);\nLinkAccountSubtypeInvestment.UGMA = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.UGMA);\nLinkAccountSubtypeInvestment.UTMA = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.UTMA);\nLinkAccountSubtypeInvestment.VARIABLE_ANNUITY = new LinkAccountSubtypeInvestment(LinkAccountType.INVESTMENT, LinkAccountSubtypes.VARIABLE_ANNUITY);\nexport class LinkAccountSubtypeLoan {\n constructor(type, subtype) {\n this.type = type;\n this.subtype = subtype;\n }\n}\nLinkAccountSubtypeLoan.ALL = new LinkAccountSubtypeLoan(LinkAccountType.CREDIT, LinkAccountSubtypes.ALL);\nLinkAccountSubtypeLoan.AUTO = new LinkAccountSubtypeLoan(LinkAccountType.CREDIT, LinkAccountSubtypes.AUTO);\nLinkAccountSubtypeLoan.BUSINESS = new LinkAccountSubtypeLoan(LinkAccountType.CREDIT, LinkAccountSubtypes.BUSINESS);\nLinkAccountSubtypeLoan.COMMERCIAL = new LinkAccountSubtypeLoan(LinkAccountType.CREDIT, LinkAccountSubtypes.COMMERCIAL);\nLinkAccountSubtypeLoan.CONSTRUCTION = new LinkAccountSubtypeLoan(LinkAccountType.CREDIT, LinkAccountSubtypes.CONSTRUCTION);\nLinkAccountSubtypeLoan.CONSUMER = new LinkAccountSubtypeLoan(LinkAccountType.CREDIT, LinkAccountSubtypes.CONSUMER);\nLinkAccountSubtypeLoan.HOME_EQUITY = new LinkAccountSubtypeLoan(LinkAccountType.CREDIT, LinkAccountSubtypes.HOME_EQUITY);\nLinkAccountSubtypeLoan.LINE_OF_CREDIT = new LinkAccountSubtypeLoan(LinkAccountType.CREDIT, LinkAccountSubtypes.LINE_OF_CREDIT);\nLinkAccountSubtypeLoan.LOAN = new LinkAccountSubtypeLoan(LinkAccountType.CREDIT, LinkAccountSubtypes.LOAN);\nLinkAccountSubtypeLoan.MORTGAGE = new LinkAccountSubtypeLoan(LinkAccountType.CREDIT, LinkAccountSubtypes.MORTGAGE);\nLinkAccountSubtypeLoan.OVERDRAFT = new LinkAccountSubtypeLoan(LinkAccountType.CREDIT, LinkAccountSubtypes.OVERDRAFT);\nLinkAccountSubtypeLoan.STUDENT = new LinkAccountSubtypeLoan(LinkAccountType.CREDIT, LinkAccountSubtypes.STUDENT);\nexport class LinkAccountSubtypeUnknown {\n constructor(type, subtype) {\n this.type = type;\n this.subtype = subtype;\n }\n}\nexport var LinkAccountVerificationStatus;\n(function (LinkAccountVerificationStatus) {\n LinkAccountVerificationStatus[\"PENDING_AUTOMATIC_VERIFICATION\"] = \"pending_automatic_verification\";\n LinkAccountVerificationStatus[\"PENDING_MANUAL_VERIFICATION\"] = \"pending_manual_verification\";\n LinkAccountVerificationStatus[\"MANUALLY_VERIFIED\"] = \"manually_verified\";\n})(LinkAccountVerificationStatus || (LinkAccountVerificationStatus = {}));\nexport var LinkExitMetadataStatus;\n(function (LinkExitMetadataStatus) {\n LinkExitMetadataStatus[\"CONNECTED\"] = \"connected\";\n LinkExitMetadataStatus[\"CHOOSE_DEVICE\"] = \"choose_device\";\n LinkExitMetadataStatus[\"REQUIRES_ACCOUNT_SELECTION\"] = \"requires_account_selection\";\n LinkExitMetadataStatus[\"REQUIRES_CODE\"] = \"requires_code\";\n LinkExitMetadataStatus[\"REQUIRES_CREDENTIALS\"] = \"requires_credentials\";\n LinkExitMetadataStatus[\"REQUIRES_EXTERNAL_ACTION\"] = \"requires_external_action\";\n LinkExitMetadataStatus[\"REQUIRES_OAUTH\"] = \"requires_oauth\";\n LinkExitMetadataStatus[\"REQUIRES_QUESTIONS\"] = \"requires_questions\";\n LinkExitMetadataStatus[\"REQUIRES_RECAPTCHA\"] = \"requires_recaptcha\";\n LinkExitMetadataStatus[\"REQUIRES_SELECTIONS\"] = \"requires_selections\";\n LinkExitMetadataStatus[\"REQUIRES_DEPOSIT_SWITCH_ALLOCATION_CONFIGURATION\"] = \"requires_deposit_switch_allocation_configuration\";\n LinkExitMetadataStatus[\"REQUIRES_DEPOSIT_SWITCH_ALLOCATION_SELECTION\"] = \"requires_deposit_switch_allocation_selection\";\n})(LinkExitMetadataStatus || (LinkExitMetadataStatus = {}));\nexport var LinkErrorCode;\n(function (LinkErrorCode) {\n // ITEM_ERROR\n LinkErrorCode[\"INVALID_CREDENTIALS\"] = \"INVALID_CREDENTIALS\";\n LinkErrorCode[\"INVALID_MFA\"] = \"INVALID_MFA\";\n LinkErrorCode[\"ITEM_LOGIN_REQUIRED\"] = \"ITEM_LOGIN_REQUIRED\";\n LinkErrorCode[\"INSUFFICIENT_CREDENTIALS\"] = \"INSUFFICIENT_CREDENTIALS\";\n LinkErrorCode[\"ITEM_LOCKED\"] = \"ITEM_LOCKED\";\n LinkErrorCode[\"USER_SETUP_REQUIRED\"] = \"USER_SETUP_REQUIRED\";\n LinkErrorCode[\"MFA_NOT_SUPPORTED\"] = \"MFA_NOT_SUPPORTED\";\n LinkErrorCode[\"INVALID_SEND_METHOD\"] = \"INVALID_SEND_METHOD\";\n LinkErrorCode[\"NO_ACCOUNTS\"] = \"NO_ACCOUNTS\";\n LinkErrorCode[\"ITEM_NOT_SUPPORTED\"] = \"ITEM_NOT_SUPPORTED\";\n LinkErrorCode[\"TOO_MANY_VERIFICATION_ATTEMPTS\"] = \"TOO_MANY_VERIFICATION_ATTEMPTS\";\n LinkErrorCode[\"INVALD_UPDATED_USERNAME\"] = \"INVALD_UPDATED_USERNAME\";\n LinkErrorCode[\"INVALID_UPDATED_USERNAME\"] = \"INVALID_UPDATED_USERNAME\";\n LinkErrorCode[\"ITEM_NO_ERROR\"] = \"ITEM_NO_ERROR\";\n LinkErrorCode[\"item_no_error\"] = \"item-no-error\";\n LinkErrorCode[\"NO_AUTH_ACCOUNTS\"] = \"NO_AUTH_ACCOUNTS\";\n LinkErrorCode[\"NO_INVESTMENT_ACCOUNTS\"] = \"NO_INVESTMENT_ACCOUNTS\";\n LinkErrorCode[\"NO_INVESTMENT_AUTH_ACCOUNTS\"] = \"NO_INVESTMENT_AUTH_ACCOUNTS\";\n LinkErrorCode[\"NO_LIABILITY_ACCOUNTS\"] = \"NO_LIABILITY_ACCOUNTS\";\n LinkErrorCode[\"PRODUCTS_NOT_SUPPORTED\"] = \"PRODUCTS_NOT_SUPPORTED\";\n LinkErrorCode[\"ITEM_NOT_FOUND\"] = \"ITEM_NOT_FOUND\";\n LinkErrorCode[\"ITEM_PRODUCT_NOT_READY\"] = \"ITEM_PRODUCT_NOT_READY\";\n // INSTITUTION_ERROR\n LinkErrorCode[\"INSTITUTION_DOWN\"] = \"INSTITUTION_DOWN\";\n LinkErrorCode[\"INSTITUTION_NOT_RESPONDING\"] = \"INSTITUTION_NOT_RESPONDING\";\n LinkErrorCode[\"INSTITUTION_NOT_AVAILABLE\"] = \"INSTITUTION_NOT_AVAILABLE\";\n LinkErrorCode[\"INSTITUTION_NO_LONGER_SUPPORTED\"] = \"INSTITUTION_NO_LONGER_SUPPORTED\";\n // API_ERROR\n LinkErrorCode[\"INTERNAL_SERVER_ERROR\"] = \"INTERNAL_SERVER_ERROR\";\n LinkErrorCode[\"PLANNED_MAINTENANCE\"] = \"PLANNED_MAINTENANCE\";\n // ASSET_REPORT_ERROR\n LinkErrorCode[\"PRODUCT_NOT_ENABLED\"] = \"PRODUCT_NOT_ENABLED\";\n LinkErrorCode[\"DATA_UNAVAILABLE\"] = \"DATA_UNAVAILABLE\";\n LinkErrorCode[\"ASSET_PRODUCT_NOT_READY\"] = \"ASSET_PRODUCT_NOT_READY\";\n LinkErrorCode[\"ASSET_REPORT_GENERATION_FAILED\"] = \"ASSET_REPORT_GENERATION_FAILED\";\n LinkErrorCode[\"INVALID_PARENT\"] = \"INVALID_PARENT\";\n LinkErrorCode[\"INSIGHTS_NOT_ENABLED\"] = \"INSIGHTS_NOT_ENABLED\";\n LinkErrorCode[\"INSIGHTS_PREVIOUSLY_NOT_ENABLED\"] = \"INSIGHTS_PREVIOUSLY_NOT_ENABLED\";\n // BANK_TRANSFER_ERROR\n LinkErrorCode[\"BANK_TRANSFER_LIMIT_EXCEEDED\"] = \"BANK_TRANSFER_LIMIT_EXCEEDED\";\n LinkErrorCode[\"BANK_TRANSFER_MISSING_ORIGINATION_ACCOUNT\"] = \"BANK_TRANSFER_MISSING_ORIGINATION_ACCOUNT\";\n LinkErrorCode[\"BANK_TRANSFER_INVALID_ORIGINATION_ACCOUNT\"] = \"BANK_TRANSFER_INVALID_ORIGINATION_ACCOUNT\";\n LinkErrorCode[\"BANK_TRANSFER_ACCOUNT_BLOCKED\"] = \"BANK_TRANSFER_ACCOUNT_BLOCKED\";\n LinkErrorCode[\"BANK_TRANSFER_INSUFFICIENT_FUNDS\"] = \"BANK_TRANSFER_INSUFFICIENT_FUNDS\";\n LinkErrorCode[\"BANK_TRANSFER_NOT_CANCELLABLE\"] = \"BANK_TRANSFER_NOT_CANCELLABLE\";\n LinkErrorCode[\"BANK_TRANSFER_UNSUPPORTED_ACCOUNT_TYPE\"] = \"BANK_TRANSFER_UNSUPPORTED_ACCOUNT_TYPE\";\n LinkErrorCode[\"BANK_TRANSFER_UNSUPPORTED_ENVIRONMENT\"] = \"BANK_TRANSFER_UNSUPPORTED_ENVIRONMENT\";\n // SANDBOX_ERROR\n LinkErrorCode[\"SANDBOX_PRODUCT_NOT_ENABLED\"] = \"SANDBOX_PRODUCT_NOT_ENABLED\";\n LinkErrorCode[\"SANDBOX_WEBHOOK_INVALID\"] = \"SANDBOX_WEBHOOK_INVALID\";\n LinkErrorCode[\"SANDBOX_BANK_TRANSFER_EVENT_TRANSITION_INVALID\"] = \"SANDBOX_BANK_TRANSFER_EVENT_TRANSITION_INVALID\";\n // INVALID_REQUEST\n LinkErrorCode[\"MISSING_FIELDS\"] = \"MISSING_FIELDS\";\n LinkErrorCode[\"UNKNOWN_FIELDS\"] = \"UNKNOWN_FIELDS\";\n LinkErrorCode[\"INVALID_FIELD\"] = \"INVALID_FIELD\";\n LinkErrorCode[\"INCOMPATIBLE_API_VERSION\"] = \"INCOMPATIBLE_API_VERSION\";\n LinkErrorCode[\"INVALID_BODY\"] = \"INVALID_BODY\";\n LinkErrorCode[\"INVALID_HEADERS\"] = \"INVALID_HEADERS\";\n LinkErrorCode[\"NOT_FOUND\"] = \"NOT_FOUND\";\n LinkErrorCode[\"NO_LONGER_AVAILABLE\"] = \"NO_LONGER_AVAILABLE\";\n LinkErrorCode[\"SANDBOX_ONLY\"] = \"SANDBOX_ONLY\";\n LinkErrorCode[\"INVALID_ACCOUNT_NUMBER\"] = \"INVALID_ACCOUNT_NUMBER\";\n // INVALID_INPUT\n // From above ITEM_LOGIN_REQUIRED = \"INVALID_CREDENTIALS\",\n LinkErrorCode[\"INCORRECT_DEPOSIT_AMOUNTS\"] = \"INCORRECT_DEPOSIT_AMOUNTS\";\n LinkErrorCode[\"UNAUTHORIZED_ENVIRONMENT\"] = \"UNAUTHORIZED_ENVIRONMENT\";\n LinkErrorCode[\"INVALID_PRODUCT\"] = \"INVALID_PRODUCT\";\n LinkErrorCode[\"UNAUTHORIZED_ROUTE_ACCESS\"] = \"UNAUTHORIZED_ROUTE_ACCESS\";\n LinkErrorCode[\"DIRECT_INTEGRATION_NOT_ENABLED\"] = \"DIRECT_INTEGRATION_NOT_ENABLED\";\n LinkErrorCode[\"INVALID_API_KEYS\"] = \"INVALID_API_KEYS\";\n LinkErrorCode[\"INVALID_ACCESS_TOKEN\"] = \"INVALID_ACCESS_TOKEN\";\n LinkErrorCode[\"INVALID_PUBLIC_TOKEN\"] = \"INVALID_PUBLIC_TOKEN\";\n LinkErrorCode[\"INVALID_LINK_TOKEN\"] = \"INVALID_LINK_TOKEN\";\n LinkErrorCode[\"INVALID_PROCESSOR_TOKEN\"] = \"INVALID_PROCESSOR_TOKEN\";\n LinkErrorCode[\"INVALID_AUDIT_COPY_TOKEN\"] = \"INVALID_AUDIT_COPY_TOKEN\";\n LinkErrorCode[\"INVALID_ACCOUNT_ID\"] = \"INVALID_ACCOUNT_ID\";\n LinkErrorCode[\"MICRODEPOSITS_ALREADY_VERIFIED\"] = \"MICRODEPOSITS_ALREADY_VERIFIED\";\n // INVALID_RESULT\n LinkErrorCode[\"PLAID_DIRECT_ITEM_IMPORT_RETURNED_INVALID_MFA\"] = \"PLAID_DIRECT_ITEM_IMPORT_RETURNED_INVALID_MFA\";\n // RATE_LIMIT_EXCEEDED\n LinkErrorCode[\"ACCOUNTS_LIMIT\"] = \"ACCOUNTS_LIMIT\";\n LinkErrorCode[\"ADDITION_LIMIT\"] = \"ADDITION_LIMIT\";\n LinkErrorCode[\"AUTH_LIMIT\"] = \"AUTH_LIMIT\";\n LinkErrorCode[\"BALANCE_LIMIT\"] = \"BALANCE_LIMIT\";\n LinkErrorCode[\"IDENTITY_LIMIT\"] = \"IDENTITY_LIMIT\";\n LinkErrorCode[\"ITEM_GET_LIMIT\"] = \"ITEM_GET_LIMIT\";\n LinkErrorCode[\"RATE_LIMIT\"] = \"RATE_LIMIT\";\n LinkErrorCode[\"TRANSACTIONS_LIMIT\"] = \"TRANSACTIONS_LIMIT\";\n // RECAPTCHA_ERROR\n LinkErrorCode[\"RECAPTCHA_REQUIRED\"] = \"RECAPTCHA_REQUIRED\";\n LinkErrorCode[\"RECAPTCHA_BAD\"] = \"RECAPTCHA_BAD\";\n // OAUTH_ERROR\n LinkErrorCode[\"INCORRECT_OAUTH_NONCE\"] = \"INCORRECT_OAUTH_NONCE\";\n LinkErrorCode[\"OAUTH_STATE_ID_ALREADY_PROCESSED\"] = \"OAUTH_STATE_ID_ALREADY_PROCESSED\";\n})(LinkErrorCode || (LinkErrorCode = {}));\nexport var LinkErrorType;\n(function (LinkErrorType) {\n LinkErrorType[\"BANK_TRANSFER\"] = \"BANK_TRANSFER_ERROR\";\n LinkErrorType[\"INVALID_REQUEST\"] = \"INVALID_REQUEST\";\n LinkErrorType[\"INVALID_RESULT\"] = \"INVALID_RESULT\";\n LinkErrorType[\"INVALID_INPUT\"] = \"INVALID_INPUT\";\n LinkErrorType[\"INSTITUTION_ERROR\"] = \"INSTITUTION_ERROR\";\n LinkErrorType[\"RATE_LIMIT_EXCEEDED\"] = \"RATE_LIMIT_EXCEEDED\";\n LinkErrorType[\"API_ERROR\"] = \"API_ERROR\";\n LinkErrorType[\"ITEM_ERROR\"] = \"ITEM_ERROR\";\n LinkErrorType[\"AUTH_ERROR\"] = \"AUTH_ERROR\";\n LinkErrorType[\"ASSET_REPORT_ERROR\"] = \"ASSET_REPORT_ERROR\";\n LinkErrorType[\"SANDBOX_ERROR\"] = \"SANDBOX_ERROR\";\n LinkErrorType[\"RECAPTCHA_ERROR\"] = \"RECAPTCHA_ERROR\";\n LinkErrorType[\"OAUTH_ERROR\"] = \"OAUTH_ERROR\";\n})(LinkErrorType || (LinkErrorType = {}));\nexport var LinkEventName;\n(function (LinkEventName) {\n LinkEventName[\"BANK_INCOME_INSIGHTS_COMPLETED\"] = \"BANK_INCOME_INSIGHTS_COMPLETED\";\n LinkEventName[\"CLOSE_OAUTH\"] = \"CLOSE_OAUTH\";\n LinkEventName[\"ERROR\"] = \"ERROR\";\n LinkEventName[\"EXIT\"] = \"EXIT\";\n LinkEventName[\"FAIL_OAUTH\"] = \"FAIL_OAUTH\";\n LinkEventName[\"HANDOFF\"] = \"HANDOFF\";\n LinkEventName[\"IDENTITY_VERIFICATION_START_STEP\"] = \"IDENTITY_VERIFICATION_START_STEP\";\n LinkEventName[\"IDENTITY_VERIFICATION_PASS_STEP\"] = \"IDENTITY_VERIFICATION_PASS_STEP\";\n LinkEventName[\"IDENTITY_VERIFICATION_FAIL_STEP\"] = \"IDENTITY_VERIFICATION_FAIL_STEP\";\n LinkEventName[\"IDENTITY_VERIFICATION_PENDING_REVIEW_STEP\"] = \"IDENTITY_VERIFICATION_PENDING_REVIEW_STEP\";\n LinkEventName[\"IDENTITY_VERIFICATION_CREATE_SESSION\"] = \"IDENTITY_VERIFICATION_CREATE_SESSION\";\n LinkEventName[\"IDENTITY_VERIFICATION_RESUME_SESSION\"] = \"IDENTITY_VERIFICATION_RESUME_SESSION\";\n LinkEventName[\"IDENTITY_VERIFICATION_PASS_SESSION\"] = \"IDENTITY_VERIFICATION_PASS_SESSION\";\n LinkEventName[\"IDENTITY_VERIFICATION_FAIL_SESSION\"] = \"IDENTITY_VERIFICATION_FAIL_SESSION\";\n LinkEventName[\"IDENTITY_VERIFICATION_OPEN_UI\"] = \"IDENTITY_VERIFICATION_OPEN_UI\";\n LinkEventName[\"IDENTITY_VERIFICATION_RESUME_UI\"] = \"IDENTITY_VERIFICATION_RESUME_UI\";\n LinkEventName[\"IDENTITY_VERIFICATION_CLOSE_UI\"] = \"IDENTITY_VERIFICATION_CLOSE_UI\";\n LinkEventName[\"MATCHED_CONSENT\"] = \"MATCHED_CONSENT\";\n LinkEventName[\"MATCHED_SELECT_INSTITUTION\"] = \"MATCHED_SELECT_INSTITUTION\";\n LinkEventName[\"MATCHED_SELECT_VERIFY_METHOD\"] = \"MATCHED_SELECT_VERIFY_METHOD\";\n LinkEventName[\"OPEN\"] = \"OPEN\";\n LinkEventName[\"OPEN_MY_PLAID\"] = \"OPEN_MY_PLAID\";\n LinkEventName[\"OPEN_OAUTH\"] = \"OPEN_OAUTH\";\n LinkEventName[\"SEARCH_INSTITUTION\"] = \"SEARCH_INSTITUTION\";\n LinkEventName[\"SELECT_DEGRADED_INSTITUTION\"] = \"SELECT_DEGRADED_INSTITUTION\";\n LinkEventName[\"SELECT_DOWN_INSTITUTION\"] = \"SELECT_DOWN_INSTITUTION\";\n LinkEventName[\"SELECT_INSTITUTION\"] = \"SELECT_INSTITUTION\";\n LinkEventName[\"SUBMIT_CREDENTIALS\"] = \"SUBMIT_CREDENTIALS\";\n LinkEventName[\"SUBMIT_MFA\"] = \"SUBMIT_MFA\";\n LinkEventName[\"TRANSITION_VIEW\"] = \"TRANSITION_VIEW\";\n})(LinkEventName || (LinkEventName = {}));\nexport var LinkEventViewName;\n(function (LinkEventViewName) {\n LinkEventViewName[\"ACCEPT_TOS\"] = \"ACCEPT_TOS\";\n LinkEventViewName[\"CONNECTED\"] = \"CONNECTED\";\n LinkEventViewName[\"CONSENT\"] = \"CONSENT\";\n LinkEventViewName[\"CREDENTIAL\"] = \"CREDENTIAL\";\n LinkEventViewName[\"DOCUMENTARY_VERIFICATION\"] = \"DOCUMENTARY_VERIFICATION\";\n LinkEventViewName[\"ERROR\"] = \"ERROR\";\n LinkEventViewName[\"EXIT\"] = \"EXIT\";\n LinkEventViewName[\"KYC_CHECK\"] = \"KYC_CHECK\";\n LinkEventViewName[\"SELFIE_CHECK\"] = \"SELFIE_CHECK\";\n LinkEventViewName[\"LOADING\"] = \"LOADING\";\n LinkEventViewName[\"MATCHED_CONSENT\"] = \"MATCHED_CONSENT\";\n LinkEventViewName[\"MATCHED_CREDENTIAL\"] = \"MATCHED_CREDENTIAL\";\n LinkEventViewName[\"MATCHED_MFA\"] = \"MATCHED_MFA\";\n LinkEventViewName[\"MFA\"] = \"MFA\";\n LinkEventViewName[\"NUMBERS\"] = \"NUMBERS\";\n LinkEventViewName[\"OAUTH\"] = \"OAUTH\";\n LinkEventViewName[\"RECAPTCHA\"] = \"RECAPTCHA\";\n LinkEventViewName[\"RISK_CHECK\"] = \"RISK_CHECK\";\n LinkEventViewName[\"SCREENING\"] = \"SCREENING\";\n LinkEventViewName[\"SELECT_ACCOUNT\"] = \"SELECT_ACCOUNT\";\n LinkEventViewName[\"SELECT_INSTITUTION\"] = \"SELECT_INSTITUTION\";\n LinkEventViewName[\"VERIFY_SMS\"] = \"VERIFY_SMS\";\n})(LinkEventViewName || (LinkEventViewName = {}));\n","import PropTypes from 'prop-types';\n\nconst plaidLinkPropTypes = {\n // Plaid Link SDK public token used to initialize the Plaid SDK\n token: PropTypes.string.isRequired,\n\n // Callback to execute once the user taps continue after successfully entering their account information\n onSuccess: PropTypes.func,\n\n // Callback to execute when there is an error event emitted by the Plaid SDK\n onError: PropTypes.func,\n\n // Callback to execute when the user leaves the Plaid widget flow without entering any information\n onExit: PropTypes.func,\n\n // The redirect URI with an OAuth state ID. Needed to re-initialize the PlaidLink after directing the\n // user to their respective bank platform\n receivedRedirectURI: PropTypes.string,\n};\n\nconst plaidLinkDefaultProps = {\n onSuccess: () => {},\n onError: () => {},\n onExit: () => {},\n receivedRedirectURI: null,\n};\n\nexport {\n plaidLinkPropTypes,\n plaidLinkDefaultProps,\n};\n","import React, {forwardRef} from 'react';\nimport BasePicker from './BasePicker';\n\nexport default forwardRef((props, ref) => (\n // eslint-disable-next-line react/jsx-props-no-spreading\n \n));\n","import _ from 'underscore';\nimport React, {PureComponent} from 'react';\nimport {View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport RNPickerSelect from 'react-native-picker-select';\nimport Icon from '../Icon';\nimport * as Expensicons from '../Icon/Expensicons';\nimport FormHelpMessage from '../FormHelpMessage';\nimport Text from '../Text';\nimport styles from '../../styles/styles';\nimport themeColors from '../../styles/themes/default';\nimport {ScrollContext} from '../ScrollViewWithContext';\n\nconst propTypes = {\n /** BasePicker label */\n label: PropTypes.string,\n\n /** Should the picker appear disabled? */\n isDisabled: PropTypes.bool,\n\n /** Input value */\n value: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n\n /** The items to display in the list of selections */\n items: PropTypes.arrayOf(PropTypes.shape({\n /** The value of the item that is being selected */\n value: PropTypes.oneOfType([PropTypes.string, PropTypes.number]).isRequired,\n\n /** The text to display for the item */\n label: PropTypes.string.isRequired,\n })).isRequired,\n\n /** Something to show as the placeholder before something is selected */\n placeholder: PropTypes.shape({\n /** The value of the placeholder item, usually an empty string */\n value: PropTypes.string,\n\n /** The text to be displayed as the placeholder */\n label: PropTypes.string,\n }),\n\n /** Error text to display */\n errorText: PropTypes.string,\n\n /** Customize the BasePicker container */\n // eslint-disable-next-line react/forbid-prop-types\n containerStyles: PropTypes.arrayOf(PropTypes.object),\n\n /** Customize the BasePicker background color */\n backgroundColor: PropTypes.string,\n\n /** The ID used to uniquely identify the input in a Form */\n inputID: PropTypes.string,\n\n /** Saves a draft of the input value when used in a form */\n // eslint-disable-next-line react/no-unused-prop-types\n shouldSaveDraft: PropTypes.bool,\n\n /** A callback method that is called when the value changes and it receives the selected value as an argument */\n onInputChange: PropTypes.func.isRequired,\n\n /** Size of a picker component */\n size: PropTypes.oneOf(['normal', 'small']),\n\n /** An icon to display with the picker */\n icon: PropTypes.func,\n\n /** Whether we should forward the focus/blur calls to the inner picker * */\n shouldFocusPicker: PropTypes.bool,\n\n /** Callback called when click or tap out of BasePicker */\n onBlur: PropTypes.func,\n\n /** Additional events passed to the core BasePicker for specific platforms such as web */\n additionalPickerEvents: PropTypes.func,\n\n /** Hint text that appears below the picker */\n hintText: PropTypes.string,\n};\n\nconst defaultProps = {\n label: '',\n isDisabled: false,\n errorText: '',\n hintText: '',\n containerStyles: [],\n backgroundColor: undefined,\n inputID: undefined,\n shouldSaveDraft: false,\n value: undefined,\n placeholder: {},\n size: 'normal',\n icon: size => (\n \n ),\n shouldFocusPicker: false,\n onBlur: () => {},\n additionalPickerEvents: () => {},\n};\n\n/**\n * @property {View} root - a reference to the root View\n * @property {Object} picker - a reference to @react-native-picker/picker\n */\nclass BasePicker extends PureComponent {\n constructor(props) {\n super(props);\n this.state = {\n isHighlighted: false,\n };\n\n this.onInputChange = this.onInputChange.bind(this);\n this.enableHighlight = this.enableHighlight.bind(this);\n this.disableHighlight = this.disableHighlight.bind(this);\n this.focus = this.focus.bind(this);\n this.measureLayout = this.measureLayout.bind(this);\n\n // Windows will reuse the text color of the select for each one of the options\n // so we might need to color accordingly so it doesn't blend with the background.\n this.placeholder = _.isEmpty(this.props.placeholder) ? {} : {\n ...this.props.placeholder,\n color: themeColors.pickerOptionsTextColor,\n };\n }\n\n componentDidMount() {\n this.setDefaultValue();\n }\n\n componentDidUpdate(prevProps) {\n if (prevProps.items === this.props.items) {\n return;\n }\n this.setDefaultValue();\n }\n\n /**\n * Forms use inputID to set values. But BasePicker passes an index as the second parameter to onInputChange\n * We are overriding this behavior to make BasePicker work with Form\n * @param {String} value\n * @param {Number} index\n */\n onInputChange(value, index) {\n if (this.props.inputID) {\n this.props.onInputChange(value);\n return;\n }\n\n this.props.onInputChange(value, index);\n }\n\n setDefaultValue() {\n // When there is only 1 element in the selector, we do the user a favor and automatically select it for them\n // so they don't have to spend extra time selecting the only possible value.\n if (this.props.value || !this.props.items || this.props.items.length !== 1 || !this.props.onInputChange) {\n return;\n }\n this.props.onInputChange(this.props.items[0].value, 0);\n }\n\n enableHighlight() {\n this.setState({\n isHighlighted: true,\n });\n }\n\n disableHighlight() {\n this.setState({\n isHighlighted: false,\n });\n }\n\n /**\n * Focuses the picker (if configured to do so)\n *\n * This method is used by Form\n */\n focus() {\n if (!this.props.shouldFocusPicker) {\n return;\n }\n\n // Defer the focusing to work around a bug on Mobile Safari, where focusing the `select` element in the same\n // task when we scrolled to it left that element in a glitched state, where the dropdown list can't be opened\n // until the element gets re-focused\n _.defer(() => {\n this.picker.focus();\n });\n }\n\n /**\n * Like measure(), but measures the view relative to an ancestor\n *\n * This method is used by Form when scrolling to the input\n *\n * @param {Object} relativeToNativeComponentRef - reference to an ancestor\n * @param {function(x: number, y: number, width: number, height: number): void} onSuccess - callback called on success\n * @param {function(): void} onFail - callback called on failure\n */\n measureLayout(relativeToNativeComponentRef, onSuccess, onFail) {\n if (!this.root) {\n return;\n }\n\n this.root.measureLayout(relativeToNativeComponentRef, onSuccess, onFail);\n }\n\n render() {\n const hasError = !_.isEmpty(this.props.errorText);\n\n if (this.props.isDisabled) {\n return (\n \n {Boolean(this.props.label) && (\n \n {this.props.label}\n \n )}\n \n {this.props.value}\n \n {Boolean(this.props.hintText)\n && (\n \n {this.props.hintText}\n \n )}\n \n );\n }\n\n return (\n <>\n this.root = el}\n style={[\n styles.pickerContainer,\n this.props.isDisabled && styles.inputDisabled,\n ...this.props.containerStyles,\n this.state.isHighlighted && styles.borderColorFocus,\n hasError && styles.borderColorDanger,\n ]}\n >\n {this.props.label && (\n \n {this.props.label}\n \n )}\n ({...item, color: themeColors.pickerOptionsTextColor}))}\n style={this.props.size === 'normal'\n ? styles.picker(this.props.isDisabled, this.props.backgroundColor)\n : styles.pickerSmall(this.props.backgroundColor)}\n useNativeAndroidPickerStyle={false}\n placeholder={this.placeholder}\n value={this.props.value}\n Icon={() => this.props.icon(this.props.size)}\n disabled={this.props.isDisabled}\n fixAndroidTouchableBug\n onOpen={this.enableHighlight}\n onClose={this.disableHighlight}\n textInputProps={{\n allowFontScaling: false,\n }}\n pickerProps={{\n ref: el => this.picker = el,\n onFocus: this.enableHighlight,\n onBlur: () => {\n this.disableHighlight();\n this.props.onBlur();\n },\n ...this.props.additionalPickerEvents(\n this.enableHighlight,\n (value, index) => {\n this.onInputChange(value, index);\n this.disableHighlight();\n },\n ),\n }}\n scrollViewRef={this.context && this.context.scrollViewRef}\n scrollViewContentOffsetY={this.context && this.context.contentOffsetY}\n />\n \n \n {Boolean(this.props.hintText)\n && (\n \n {this.props.hintText}\n \n )}\n \n );\n }\n}\n\nBasePicker.propTypes = propTypes;\nBasePicker.defaultProps = defaultProps;\nBasePicker.contextType = ScrollContext;\n\nexport default React.forwardRef((props, ref) => (\n \n));\n","import React, { PureComponent } from 'react';\nimport { Keyboard, Modal, Platform, Text, TextInput, TouchableOpacity, View } from 'react-native';\nimport PropTypes from 'prop-types';\nimport isEqual from 'lodash.isequal';\nimport { Picker } from '@react-native-picker/picker';\nimport { defaultStyles } from './styles';\nimport { Dimensions } from 'react-native';\n\n// Measuring the modal before rendering is not working reliably, so we need to hardcode the height\n// This height was tested thoroughly on several iPhone Models (from iPhone 8 to 14 Pro)\nconst IOS_MODAL_HEIGHT = 262;\n\nexport default class RNPickerSelect extends PureComponent {\n static propTypes = {\n onValueChange: PropTypes.func.isRequired,\n items: PropTypes.arrayOf(\n PropTypes.shape({\n label: PropTypes.string.isRequired,\n value: PropTypes.any.isRequired,\n inputLabel: PropTypes.string,\n key: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n color: PropTypes.string,\n })\n ).isRequired,\n value: PropTypes.any, // eslint-disable-line react/forbid-prop-types\n placeholder: PropTypes.shape({\n label: PropTypes.string,\n value: PropTypes.any,\n key: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n color: PropTypes.string,\n }),\n disabled: PropTypes.bool,\n itemKey: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n style: PropTypes.shape({}),\n children: PropTypes.any, // eslint-disable-line react/forbid-prop-types\n onOpen: PropTypes.func,\n useNativeAndroidPickerStyle: PropTypes.bool,\n fixAndroidTouchableBug: PropTypes.bool,\n scrollViewRef: PropTypes.any,\n scrollViewContentOffsetY: PropTypes.number,\n\n // Custom Modal props (iOS only)\n doneText: PropTypes.string,\n onDonePress: PropTypes.func,\n onUpArrow: PropTypes.func,\n onDownArrow: PropTypes.func,\n onClose: PropTypes.func,\n\n // Modal props (iOS only)\n modalProps: PropTypes.shape({}),\n\n // TextInput props\n textInputProps: PropTypes.shape({}),\n\n // Picker props\n pickerProps: PropTypes.shape({}),\n\n // Touchable Done props (iOS only)\n touchableDoneProps: PropTypes.shape({}),\n\n // Touchable wrapper props\n touchableWrapperProps: PropTypes.shape({}),\n\n // Custom Icon\n Icon: PropTypes.func,\n InputAccessoryView: PropTypes.func,\n };\n\n static defaultProps = {\n value: undefined,\n placeholder: {\n label: 'Select an item...',\n value: null,\n color: '#9EA0A4',\n },\n disabled: false,\n itemKey: null,\n style: {},\n children: null,\n useNativeAndroidPickerStyle: true,\n fixAndroidTouchableBug: false,\n doneText: 'Done',\n onDonePress: null,\n onUpArrow: null,\n onDownArrow: null,\n onOpen: null,\n onClose: null,\n modalProps: {},\n textInputProps: {},\n pickerProps: {},\n touchableDoneProps: {},\n touchableWrapperProps: {},\n Icon: null,\n InputAccessoryView: null,\n };\n\n static handlePlaceholder({ placeholder }) {\n if (isEqual(placeholder, {})) {\n return [];\n }\n return [placeholder];\n }\n\n static getSelectedItem({ items, key, value }) {\n let idx = items.findIndex((item) => {\n if (item.key && key) {\n return isEqual(item.key, key);\n }\n return isEqual(item.value, value);\n });\n if (idx === -1) {\n idx = 0;\n }\n return {\n selectedItem: items[idx] || {},\n idx,\n };\n }\n\n constructor(props) {\n super(props);\n\n const items = RNPickerSelect.handlePlaceholder({\n placeholder: props.placeholder,\n }).concat(props.items);\n\n const { selectedItem } = RNPickerSelect.getSelectedItem({\n items,\n key: props.itemKey,\n value: props.value,\n });\n\n this.state = {\n items,\n selectedItem,\n showPicker: false,\n animationType: undefined,\n orientation: 'portrait',\n doneDepressed: false,\n };\n\n this.onUpArrow = this.onUpArrow.bind(this);\n this.onDownArrow = this.onDownArrow.bind(this);\n this.onValueChange = this.onValueChange.bind(this);\n this.onOrientationChange = this.onOrientationChange.bind(this);\n this.setInputRef = this.setInputRef.bind(this);\n this.scrollToInput = this.scrollToInput.bind(this);\n this.togglePicker = this.togglePicker.bind(this);\n this.renderInputAccessoryView = this.renderInputAccessoryView.bind(this);\n }\n\n componentDidUpdate = (prevProps, prevState) => {\n // update items if items or placeholder prop changes\n const items = RNPickerSelect.handlePlaceholder({\n placeholder: this.props.placeholder,\n }).concat(this.props.items);\n const itemsChanged = !isEqual(prevState.items, items);\n\n // update selectedItem if value prop is defined and differs from currently selected item\n const { selectedItem, idx } = RNPickerSelect.getSelectedItem({\n items,\n key: this.props.itemKey,\n value: this.props.value,\n });\n const selectedItemChanged =\n !isEqual(this.props.value, undefined) && !isEqual(prevState.selectedItem, selectedItem);\n\n if (itemsChanged || selectedItemChanged) {\n this.props.onValueChange(selectedItem.value, idx);\n\n this.setState({\n ...(itemsChanged ? { items } : {}),\n ...(selectedItemChanged ? { selectedItem } : {}),\n });\n }\n };\n\n onUpArrow() {\n const { onUpArrow } = this.props;\n\n this.togglePicker(false, onUpArrow);\n }\n\n onDownArrow() {\n const { onDownArrow } = this.props;\n\n this.togglePicker(false, onDownArrow);\n }\n\n onValueChange(value, index) {\n const { onValueChange } = this.props;\n\n onValueChange(value, index);\n\n this.setState((prevState) => {\n return {\n selectedItem: prevState.items[index],\n };\n });\n }\n\n onOrientationChange({ nativeEvent }) {\n this.setState({\n orientation: nativeEvent.orientation,\n });\n }\n\n setInputRef(ref) {\n this.inputRef = ref;\n }\n\n getPlaceholderStyle() {\n const { placeholder, style } = this.props;\n const { selectedItem } = this.state;\n\n if (!isEqual(placeholder, {}) && selectedItem.label === placeholder.label) {\n return {\n ...defaultStyles.placeholder,\n ...style.placeholder,\n };\n }\n return {};\n }\n\n scrollToInput() {\n if (\n this.props.scrollViewRef == null ||\n this.props.scrollViewContentOffsetY == null ||\n this.inputRef == null\n ) {\n return;\n }\n\n this.inputRef.measureInWindow((_x, y, _width, height) => {\n // Bottom y-position of TextInput on screen\n const textInputBottomY = y + height;\n // Top y-position of picker modal on screen\n const modalY = Dimensions.get('window').height - IOS_MODAL_HEIGHT;\n\n // If TextInput is below picker modal, scroll up\n if (textInputBottomY > modalY) {\n this.props.scrollViewRef.current.scrollTo({\n y: textInputBottomY - modalY + this.props.scrollViewContentOffsetY,\n });\n }\n });\n }\n\n triggerOpenCloseCallbacks() {\n const { onOpen, onClose } = this.props;\n const { showPicker } = this.state;\n\n if (!showPicker && onOpen) {\n onOpen();\n this.scrollToInput();\n }\n\n if (showPicker && onClose) {\n onClose();\n }\n }\n\n togglePicker(animate = false, postToggleCallback) {\n const { modalProps, disabled } = this.props;\n const { showPicker } = this.state;\n\n if (disabled) {\n return;\n }\n\n if (!showPicker) {\n Keyboard.dismiss();\n }\n\n const animationType =\n modalProps && modalProps.animationType ? modalProps.animationType : 'slide';\n\n this.triggerOpenCloseCallbacks();\n\n this.setState(\n (prevState) => {\n return {\n animationType: animate ? animationType : undefined,\n showPicker: !prevState.showPicker,\n };\n },\n () => {\n if (postToggleCallback) {\n postToggleCallback();\n }\n }\n );\n }\n\n renderPickerItems() {\n const { items } = this.state;\n\n return items.map((item) => {\n return (\n \n );\n });\n }\n\n renderInputAccessoryView() {\n const {\n InputAccessoryView,\n doneText,\n onUpArrow,\n onDownArrow,\n onDonePress,\n style,\n touchableDoneProps,\n } = this.props;\n\n const { doneDepressed } = this.state;\n\n if (InputAccessoryView) {\n return ;\n }\n\n return (\n \n \n \n \n \n \n \n \n \n {\n this.togglePicker(true, onDonePress);\n }}\n onPressIn={() => {\n this.setState({ doneDepressed: true });\n }}\n onPressOut={() => {\n this.setState({ doneDepressed: false });\n }}\n hitSlop={{ top: 4, right: 4, bottom: 4, left: 4 }}\n {...touchableDoneProps}\n >\n \n \n {doneText}\n \n \n \n \n );\n }\n\n renderIcon() {\n const { style, Icon } = this.props;\n\n if (!Icon) {\n return null;\n }\n\n return (\n \n \n \n );\n }\n\n renderTextInputOrChildren() {\n const { children, style, textInputProps } = this.props;\n const { selectedItem } = this.state;\n\n const containerStyle =\n Platform.OS === 'ios' ? style.inputIOSContainer : style.inputAndroidContainer;\n\n if (children) {\n return (\n \n {children}\n \n );\n }\n\n return (\n \n \n {this.renderIcon()}\n \n );\n }\n\n renderIOS() {\n const { style, modalProps, pickerProps, touchableWrapperProps } = this.props;\n const { animationType, orientation, selectedItem, showPicker } = this.state;\n\n return (\n \n {\n this.togglePicker(true);\n }}\n activeOpacity={1}\n {...touchableWrapperProps}\n >\n {this.renderTextInputOrChildren()}\n \n \n {\n this.togglePicker(true);\n }}\n />\n {this.renderInputAccessoryView()}\n \n \n {this.renderPickerItems()}\n \n \n \n \n );\n }\n\n renderAndroidHeadless() {\n const {\n disabled,\n Icon,\n style,\n pickerProps,\n onOpen,\n touchableWrapperProps,\n fixAndroidTouchableBug,\n } = this.props;\n const { selectedItem } = this.state;\n\n const Component = fixAndroidTouchableBug ? View : TouchableOpacity;\n return (\n \n \n {this.renderTextInputOrChildren()}\n {\n Keyboard.dismiss();\n if (pickerProps.onFocus) {\n pickerProps.onFocus();\n }\n }}\n >\n {this.renderPickerItems()}\n \n \n \n );\n }\n\n renderAndroidNativePickerStyle() {\n const { disabled, Icon, style, pickerProps } = this.props;\n const { selectedItem } = this.state;\n\n return (\n \n {\n Keyboard.dismiss();\n if (pickerProps.onFocus) {\n pickerProps.onFocus();\n }\n }}\n >\n {this.renderPickerItems()}\n \n {this.renderIcon()}\n \n );\n }\n\n renderWeb() {\n const { disabled, style, pickerProps } = this.props;\n const { selectedItem } = this.state;\n\n return (\n \n \n {this.renderPickerItems()}\n \n {this.renderIcon()}\n \n );\n }\n\n render() {\n const { children, useNativeAndroidPickerStyle } = this.props;\n\n if (Platform.OS === 'ios') {\n return this.renderIOS();\n }\n\n if (Platform.OS === 'web') {\n return this.renderWeb();\n }\n\n if (children || !useNativeAndroidPickerStyle) {\n return this.renderAndroidHeadless();\n }\n\n return this.renderAndroidNativePickerStyle();\n }\n}\n\nexport { defaultStyles };\n","/**\n * Lodash (Custom Build) \n * Build: `lodash modularize exports=\"npm\" -o ./`\n * Copyright JS Foundation and other contributors \n * Released under MIT license \n * Based on Underscore.js 1.8.3 \n * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n */\n\n/** Used as the size to enable large array optimizations. */\nvar LARGE_ARRAY_SIZE = 200;\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n asyncTag = '[object AsyncFunction]',\n boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n errorTag = '[object Error]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n nullTag = '[object Null]',\n objectTag = '[object Object]',\n promiseTag = '[object Promise]',\n proxyTag = '[object Proxy]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n symbolTag = '[object Symbol]',\n undefinedTag = '[object Undefined]',\n weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n/**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\nvar reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g;\n\n/** Used to detect host constructors (Safari). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n/** Used to identify `toStringTag` values of typed arrays. */\nvar typedArrayTags = {};\ntypedArrayTags[float32Tag] = typedArrayTags[float64Tag] =\ntypedArrayTags[int8Tag] = typedArrayTags[int16Tag] =\ntypedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =\ntypedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =\ntypedArrayTags[uint32Tag] = true;\ntypedArrayTags[argsTag] = typedArrayTags[arrayTag] =\ntypedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =\ntypedArrayTags[dataViewTag] = typedArrayTags[dateTag] =\ntypedArrayTags[errorTag] = typedArrayTags[funcTag] =\ntypedArrayTags[mapTag] = typedArrayTags[numberTag] =\ntypedArrayTags[objectTag] = typedArrayTags[regexpTag] =\ntypedArrayTags[setTag] = typedArrayTags[stringTag] =\ntypedArrayTags[weakMapTag] = false;\n\n/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Detect free variable `process` from Node.js. */\nvar freeProcess = moduleExports && freeGlobal.process;\n\n/** Used to access faster Node.js helpers. */\nvar nodeUtil = (function() {\n try {\n return freeProcess && freeProcess.binding && freeProcess.binding('util');\n } catch (e) {}\n}());\n\n/* Node.js helper references. */\nvar nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\n\n/**\n * A specialized version of `_.filter` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n */\nfunction arrayFilter(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length,\n resIndex = 0,\n result = [];\n\n while (++index < length) {\n var value = array[index];\n if (predicate(value, index, array)) {\n result[resIndex++] = value;\n }\n }\n return result;\n}\n\n/**\n * Appends the elements of `values` to `array`.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {Array} values The values to append.\n * @returns {Array} Returns `array`.\n */\nfunction arrayPush(array, values) {\n var index = -1,\n length = values.length,\n offset = array.length;\n\n while (++index < length) {\n array[offset + index] = values[index];\n }\n return array;\n}\n\n/**\n * A specialized version of `_.some` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if any element passes the predicate check,\n * else `false`.\n */\nfunction arraySome(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (predicate(array[index], index, array)) {\n return true;\n }\n }\n return false;\n}\n\n/**\n * The base implementation of `_.times` without support for iteratee shorthands\n * or max array length checks.\n *\n * @private\n * @param {number} n The number of times to invoke `iteratee`.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the array of results.\n */\nfunction baseTimes(n, iteratee) {\n var index = -1,\n result = Array(n);\n\n while (++index < n) {\n result[index] = iteratee(index);\n }\n return result;\n}\n\n/**\n * The base implementation of `_.unary` without support for storing metadata.\n *\n * @private\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n */\nfunction baseUnary(func) {\n return function(value) {\n return func(value);\n };\n}\n\n/**\n * Checks if a `cache` value for `key` exists.\n *\n * @private\n * @param {Object} cache The cache to query.\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction cacheHas(cache, key) {\n return cache.has(key);\n}\n\n/**\n * Gets the value at `key` of `object`.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\nfunction getValue(object, key) {\n return object == null ? undefined : object[key];\n}\n\n/**\n * Converts `map` to its key-value pairs.\n *\n * @private\n * @param {Object} map The map to convert.\n * @returns {Array} Returns the key-value pairs.\n */\nfunction mapToArray(map) {\n var index = -1,\n result = Array(map.size);\n\n map.forEach(function(value, key) {\n result[++index] = [key, value];\n });\n return result;\n}\n\n/**\n * Creates a unary function that invokes `func` with its argument transformed.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {Function} transform The argument transform.\n * @returns {Function} Returns the new function.\n */\nfunction overArg(func, transform) {\n return function(arg) {\n return func(transform(arg));\n };\n}\n\n/**\n * Converts `set` to an array of its values.\n *\n * @private\n * @param {Object} set The set to convert.\n * @returns {Array} Returns the values.\n */\nfunction setToArray(set) {\n var index = -1,\n result = Array(set.size);\n\n set.forEach(function(value) {\n result[++index] = value;\n });\n return result;\n}\n\n/** Used for built-in method references. */\nvar arrayProto = Array.prototype,\n funcProto = Function.prototype,\n objectProto = Object.prototype;\n\n/** Used to detect overreaching core-js shims. */\nvar coreJsData = root['__core-js_shared__'];\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to detect methods masquerading as native. */\nvar maskSrcKey = (function() {\n var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\n return uid ? ('Symbol(src)_1.' + uid) : '';\n}());\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/** Used to detect if a method is native. */\nvar reIsNative = RegExp('^' +\n funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&')\n .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\n);\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined,\n Symbol = root.Symbol,\n Uint8Array = root.Uint8Array,\n propertyIsEnumerable = objectProto.propertyIsEnumerable,\n splice = arrayProto.splice,\n symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeGetSymbols = Object.getOwnPropertySymbols,\n nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined,\n nativeKeys = overArg(Object.keys, Object);\n\n/* Built-in method references that are verified to be native. */\nvar DataView = getNative(root, 'DataView'),\n Map = getNative(root, 'Map'),\n Promise = getNative(root, 'Promise'),\n Set = getNative(root, 'Set'),\n WeakMap = getNative(root, 'WeakMap'),\n nativeCreate = getNative(Object, 'create');\n\n/** Used to detect maps, sets, and weakmaps. */\nvar dataViewCtorString = toSource(DataView),\n mapCtorString = toSource(Map),\n promiseCtorString = toSource(Promise),\n setCtorString = toSource(Set),\n weakMapCtorString = toSource(WeakMap);\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;\n\n/**\n * Creates a hash object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Hash(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n/**\n * Removes all key-value entries from the hash.\n *\n * @private\n * @name clear\n * @memberOf Hash\n */\nfunction hashClear() {\n this.__data__ = nativeCreate ? nativeCreate(null) : {};\n this.size = 0;\n}\n\n/**\n * Removes `key` and its value from the hash.\n *\n * @private\n * @name delete\n * @memberOf Hash\n * @param {Object} hash The hash to modify.\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction hashDelete(key) {\n var result = this.has(key) && delete this.__data__[key];\n this.size -= result ? 1 : 0;\n return result;\n}\n\n/**\n * Gets the hash value for `key`.\n *\n * @private\n * @name get\n * @memberOf Hash\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction hashGet(key) {\n var data = this.__data__;\n if (nativeCreate) {\n var result = data[key];\n return result === HASH_UNDEFINED ? undefined : result;\n }\n return hasOwnProperty.call(data, key) ? data[key] : undefined;\n}\n\n/**\n * Checks if a hash value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Hash\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction hashHas(key) {\n var data = this.__data__;\n return nativeCreate ? (data[key] !== undefined) : hasOwnProperty.call(data, key);\n}\n\n/**\n * Sets the hash `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Hash\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the hash instance.\n */\nfunction hashSet(key, value) {\n var data = this.__data__;\n this.size += this.has(key) ? 0 : 1;\n data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;\n return this;\n}\n\n// Add methods to `Hash`.\nHash.prototype.clear = hashClear;\nHash.prototype['delete'] = hashDelete;\nHash.prototype.get = hashGet;\nHash.prototype.has = hashHas;\nHash.prototype.set = hashSet;\n\n/**\n * Creates an list cache object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction ListCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n/**\n * Removes all key-value entries from the list cache.\n *\n * @private\n * @name clear\n * @memberOf ListCache\n */\nfunction listCacheClear() {\n this.__data__ = [];\n this.size = 0;\n}\n\n/**\n * Removes `key` and its value from the list cache.\n *\n * @private\n * @name delete\n * @memberOf ListCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction listCacheDelete(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n return false;\n }\n var lastIndex = data.length - 1;\n if (index == lastIndex) {\n data.pop();\n } else {\n splice.call(data, index, 1);\n }\n --this.size;\n return true;\n}\n\n/**\n * Gets the list cache value for `key`.\n *\n * @private\n * @name get\n * @memberOf ListCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction listCacheGet(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n return index < 0 ? undefined : data[index][1];\n}\n\n/**\n * Checks if a list cache value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf ListCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction listCacheHas(key) {\n return assocIndexOf(this.__data__, key) > -1;\n}\n\n/**\n * Sets the list cache `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf ListCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the list cache instance.\n */\nfunction listCacheSet(key, value) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n ++this.size;\n data.push([key, value]);\n } else {\n data[index][1] = value;\n }\n return this;\n}\n\n// Add methods to `ListCache`.\nListCache.prototype.clear = listCacheClear;\nListCache.prototype['delete'] = listCacheDelete;\nListCache.prototype.get = listCacheGet;\nListCache.prototype.has = listCacheHas;\nListCache.prototype.set = listCacheSet;\n\n/**\n * Creates a map cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction MapCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n/**\n * Removes all key-value entries from the map.\n *\n * @private\n * @name clear\n * @memberOf MapCache\n */\nfunction mapCacheClear() {\n this.size = 0;\n this.__data__ = {\n 'hash': new Hash,\n 'map': new (Map || ListCache),\n 'string': new Hash\n };\n}\n\n/**\n * Removes `key` and its value from the map.\n *\n * @private\n * @name delete\n * @memberOf MapCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction mapCacheDelete(key) {\n var result = getMapData(this, key)['delete'](key);\n this.size -= result ? 1 : 0;\n return result;\n}\n\n/**\n * Gets the map value for `key`.\n *\n * @private\n * @name get\n * @memberOf MapCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction mapCacheGet(key) {\n return getMapData(this, key).get(key);\n}\n\n/**\n * Checks if a map value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf MapCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction mapCacheHas(key) {\n return getMapData(this, key).has(key);\n}\n\n/**\n * Sets the map `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf MapCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the map cache instance.\n */\nfunction mapCacheSet(key, value) {\n var data = getMapData(this, key),\n size = data.size;\n\n data.set(key, value);\n this.size += data.size == size ? 0 : 1;\n return this;\n}\n\n// Add methods to `MapCache`.\nMapCache.prototype.clear = mapCacheClear;\nMapCache.prototype['delete'] = mapCacheDelete;\nMapCache.prototype.get = mapCacheGet;\nMapCache.prototype.has = mapCacheHas;\nMapCache.prototype.set = mapCacheSet;\n\n/**\n *\n * Creates an array cache object to store unique values.\n *\n * @private\n * @constructor\n * @param {Array} [values] The values to cache.\n */\nfunction SetCache(values) {\n var index = -1,\n length = values == null ? 0 : values.length;\n\n this.__data__ = new MapCache;\n while (++index < length) {\n this.add(values[index]);\n }\n}\n\n/**\n * Adds `value` to the array cache.\n *\n * @private\n * @name add\n * @memberOf SetCache\n * @alias push\n * @param {*} value The value to cache.\n * @returns {Object} Returns the cache instance.\n */\nfunction setCacheAdd(value) {\n this.__data__.set(value, HASH_UNDEFINED);\n return this;\n}\n\n/**\n * Checks if `value` is in the array cache.\n *\n * @private\n * @name has\n * @memberOf SetCache\n * @param {*} value The value to search for.\n * @returns {number} Returns `true` if `value` is found, else `false`.\n */\nfunction setCacheHas(value) {\n return this.__data__.has(value);\n}\n\n// Add methods to `SetCache`.\nSetCache.prototype.add = SetCache.prototype.push = setCacheAdd;\nSetCache.prototype.has = setCacheHas;\n\n/**\n * Creates a stack cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Stack(entries) {\n var data = this.__data__ = new ListCache(entries);\n this.size = data.size;\n}\n\n/**\n * Removes all key-value entries from the stack.\n *\n * @private\n * @name clear\n * @memberOf Stack\n */\nfunction stackClear() {\n this.__data__ = new ListCache;\n this.size = 0;\n}\n\n/**\n * Removes `key` and its value from the stack.\n *\n * @private\n * @name delete\n * @memberOf Stack\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction stackDelete(key) {\n var data = this.__data__,\n result = data['delete'](key);\n\n this.size = data.size;\n return result;\n}\n\n/**\n * Gets the stack value for `key`.\n *\n * @private\n * @name get\n * @memberOf Stack\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction stackGet(key) {\n return this.__data__.get(key);\n}\n\n/**\n * Checks if a stack value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Stack\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction stackHas(key) {\n return this.__data__.has(key);\n}\n\n/**\n * Sets the stack `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Stack\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the stack cache instance.\n */\nfunction stackSet(key, value) {\n var data = this.__data__;\n if (data instanceof ListCache) {\n var pairs = data.__data__;\n if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) {\n pairs.push([key, value]);\n this.size = ++data.size;\n return this;\n }\n data = this.__data__ = new MapCache(pairs);\n }\n data.set(key, value);\n this.size = data.size;\n return this;\n}\n\n// Add methods to `Stack`.\nStack.prototype.clear = stackClear;\nStack.prototype['delete'] = stackDelete;\nStack.prototype.get = stackGet;\nStack.prototype.has = stackHas;\nStack.prototype.set = stackSet;\n\n/**\n * Creates an array of the enumerable property names of the array-like `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @param {boolean} inherited Specify returning inherited property names.\n * @returns {Array} Returns the array of property names.\n */\nfunction arrayLikeKeys(value, inherited) {\n var isArr = isArray(value),\n isArg = !isArr && isArguments(value),\n isBuff = !isArr && !isArg && isBuffer(value),\n isType = !isArr && !isArg && !isBuff && isTypedArray(value),\n skipIndexes = isArr || isArg || isBuff || isType,\n result = skipIndexes ? baseTimes(value.length, String) : [],\n length = result.length;\n\n for (var key in value) {\n if ((inherited || hasOwnProperty.call(value, key)) &&\n !(skipIndexes && (\n // Safari 9 has enumerable `arguments.length` in strict mode.\n key == 'length' ||\n // Node.js 0.10 has enumerable non-index properties on buffers.\n (isBuff && (key == 'offset' || key == 'parent')) ||\n // PhantomJS 2 has enumerable non-index properties on typed arrays.\n (isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset')) ||\n // Skip index properties.\n isIndex(key, length)\n ))) {\n result.push(key);\n }\n }\n return result;\n}\n\n/**\n * Gets the index at which the `key` is found in `array` of key-value pairs.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} key The key to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction assocIndexOf(array, key) {\n var length = array.length;\n while (length--) {\n if (eq(array[length][0], key)) {\n return length;\n }\n }\n return -1;\n}\n\n/**\n * The base implementation of `getAllKeys` and `getAllKeysIn` which uses\n * `keysFunc` and `symbolsFunc` to get the enumerable property names and\n * symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @param {Function} symbolsFunc The function to get the symbols of `object`.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction baseGetAllKeys(object, keysFunc, symbolsFunc) {\n var result = keysFunc(object);\n return isArray(object) ? result : arrayPush(result, symbolsFunc(object));\n}\n\n/**\n * The base implementation of `getTag` without fallbacks for buggy environments.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n if (value == null) {\n return value === undefined ? undefinedTag : nullTag;\n }\n return (symToStringTag && symToStringTag in Object(value))\n ? getRawTag(value)\n : objectToString(value);\n}\n\n/**\n * The base implementation of `_.isArguments`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n */\nfunction baseIsArguments(value) {\n return isObjectLike(value) && baseGetTag(value) == argsTag;\n}\n\n/**\n * The base implementation of `_.isEqual` which supports partial comparisons\n * and tracks traversed objects.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @param {boolean} bitmask The bitmask flags.\n * 1 - Unordered comparison\n * 2 - Partial comparison\n * @param {Function} [customizer] The function to customize comparisons.\n * @param {Object} [stack] Tracks traversed `value` and `other` objects.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n */\nfunction baseIsEqual(value, other, bitmask, customizer, stack) {\n if (value === other) {\n return true;\n }\n if (value == null || other == null || (!isObjectLike(value) && !isObjectLike(other))) {\n return value !== value && other !== other;\n }\n return baseIsEqualDeep(value, other, bitmask, customizer, baseIsEqual, stack);\n}\n\n/**\n * A specialized version of `baseIsEqual` for arrays and objects which performs\n * deep comparisons and tracks traversed objects enabling objects with circular\n * references to be compared.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} [stack] Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction baseIsEqualDeep(object, other, bitmask, customizer, equalFunc, stack) {\n var objIsArr = isArray(object),\n othIsArr = isArray(other),\n objTag = objIsArr ? arrayTag : getTag(object),\n othTag = othIsArr ? arrayTag : getTag(other);\n\n objTag = objTag == argsTag ? objectTag : objTag;\n othTag = othTag == argsTag ? objectTag : othTag;\n\n var objIsObj = objTag == objectTag,\n othIsObj = othTag == objectTag,\n isSameTag = objTag == othTag;\n\n if (isSameTag && isBuffer(object)) {\n if (!isBuffer(other)) {\n return false;\n }\n objIsArr = true;\n objIsObj = false;\n }\n if (isSameTag && !objIsObj) {\n stack || (stack = new Stack);\n return (objIsArr || isTypedArray(object))\n ? equalArrays(object, other, bitmask, customizer, equalFunc, stack)\n : equalByTag(object, other, objTag, bitmask, customizer, equalFunc, stack);\n }\n if (!(bitmask & COMPARE_PARTIAL_FLAG)) {\n var objIsWrapped = objIsObj && hasOwnProperty.call(object, '__wrapped__'),\n othIsWrapped = othIsObj && hasOwnProperty.call(other, '__wrapped__');\n\n if (objIsWrapped || othIsWrapped) {\n var objUnwrapped = objIsWrapped ? object.value() : object,\n othUnwrapped = othIsWrapped ? other.value() : other;\n\n stack || (stack = new Stack);\n return equalFunc(objUnwrapped, othUnwrapped, bitmask, customizer, stack);\n }\n }\n if (!isSameTag) {\n return false;\n }\n stack || (stack = new Stack);\n return equalObjects(object, other, bitmask, customizer, equalFunc, stack);\n}\n\n/**\n * The base implementation of `_.isNative` without bad shim checks.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function,\n * else `false`.\n */\nfunction baseIsNative(value) {\n if (!isObject(value) || isMasked(value)) {\n return false;\n }\n var pattern = isFunction(value) ? reIsNative : reIsHostCtor;\n return pattern.test(toSource(value));\n}\n\n/**\n * The base implementation of `_.isTypedArray` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n */\nfunction baseIsTypedArray(value) {\n return isObjectLike(value) &&\n isLength(value.length) && !!typedArrayTags[baseGetTag(value)];\n}\n\n/**\n * The base implementation of `_.keys` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction baseKeys(object) {\n if (!isPrototype(object)) {\n return nativeKeys(object);\n }\n var result = [];\n for (var key in Object(object)) {\n if (hasOwnProperty.call(object, key) && key != 'constructor') {\n result.push(key);\n }\n }\n return result;\n}\n\n/**\n * A specialized version of `baseIsEqualDeep` for arrays with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Array} array The array to compare.\n * @param {Array} other The other array to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `array` and `other` objects.\n * @returns {boolean} Returns `true` if the arrays are equivalent, else `false`.\n */\nfunction equalArrays(array, other, bitmask, customizer, equalFunc, stack) {\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n arrLength = array.length,\n othLength = other.length;\n\n if (arrLength != othLength && !(isPartial && othLength > arrLength)) {\n return false;\n }\n // Assume cyclic values are equal.\n var stacked = stack.get(array);\n if (stacked && stack.get(other)) {\n return stacked == other;\n }\n var index = -1,\n result = true,\n seen = (bitmask & COMPARE_UNORDERED_FLAG) ? new SetCache : undefined;\n\n stack.set(array, other);\n stack.set(other, array);\n\n // Ignore non-index properties.\n while (++index < arrLength) {\n var arrValue = array[index],\n othValue = other[index];\n\n if (customizer) {\n var compared = isPartial\n ? customizer(othValue, arrValue, index, other, array, stack)\n : customizer(arrValue, othValue, index, array, other, stack);\n }\n if (compared !== undefined) {\n if (compared) {\n continue;\n }\n result = false;\n break;\n }\n // Recursively compare arrays (susceptible to call stack limits).\n if (seen) {\n if (!arraySome(other, function(othValue, othIndex) {\n if (!cacheHas(seen, othIndex) &&\n (arrValue === othValue || equalFunc(arrValue, othValue, bitmask, customizer, stack))) {\n return seen.push(othIndex);\n }\n })) {\n result = false;\n break;\n }\n } else if (!(\n arrValue === othValue ||\n equalFunc(arrValue, othValue, bitmask, customizer, stack)\n )) {\n result = false;\n break;\n }\n }\n stack['delete'](array);\n stack['delete'](other);\n return result;\n}\n\n/**\n * A specialized version of `baseIsEqualDeep` for comparing objects of\n * the same `toStringTag`.\n *\n * **Note:** This function only supports comparing values with tags of\n * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {string} tag The `toStringTag` of the objects to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction equalByTag(object, other, tag, bitmask, customizer, equalFunc, stack) {\n switch (tag) {\n case dataViewTag:\n if ((object.byteLength != other.byteLength) ||\n (object.byteOffset != other.byteOffset)) {\n return false;\n }\n object = object.buffer;\n other = other.buffer;\n\n case arrayBufferTag:\n if ((object.byteLength != other.byteLength) ||\n !equalFunc(new Uint8Array(object), new Uint8Array(other))) {\n return false;\n }\n return true;\n\n case boolTag:\n case dateTag:\n case numberTag:\n // Coerce booleans to `1` or `0` and dates to milliseconds.\n // Invalid dates are coerced to `NaN`.\n return eq(+object, +other);\n\n case errorTag:\n return object.name == other.name && object.message == other.message;\n\n case regexpTag:\n case stringTag:\n // Coerce regexes to strings and treat strings, primitives and objects,\n // as equal. See http://www.ecma-international.org/ecma-262/7.0/#sec-regexp.prototype.tostring\n // for more details.\n return object == (other + '');\n\n case mapTag:\n var convert = mapToArray;\n\n case setTag:\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG;\n convert || (convert = setToArray);\n\n if (object.size != other.size && !isPartial) {\n return false;\n }\n // Assume cyclic values are equal.\n var stacked = stack.get(object);\n if (stacked) {\n return stacked == other;\n }\n bitmask |= COMPARE_UNORDERED_FLAG;\n\n // Recursively compare objects (susceptible to call stack limits).\n stack.set(object, other);\n var result = equalArrays(convert(object), convert(other), bitmask, customizer, equalFunc, stack);\n stack['delete'](object);\n return result;\n\n case symbolTag:\n if (symbolValueOf) {\n return symbolValueOf.call(object) == symbolValueOf.call(other);\n }\n }\n return false;\n}\n\n/**\n * A specialized version of `baseIsEqualDeep` for objects with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction equalObjects(object, other, bitmask, customizer, equalFunc, stack) {\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n objProps = getAllKeys(object),\n objLength = objProps.length,\n othProps = getAllKeys(other),\n othLength = othProps.length;\n\n if (objLength != othLength && !isPartial) {\n return false;\n }\n var index = objLength;\n while (index--) {\n var key = objProps[index];\n if (!(isPartial ? key in other : hasOwnProperty.call(other, key))) {\n return false;\n }\n }\n // Assume cyclic values are equal.\n var stacked = stack.get(object);\n if (stacked && stack.get(other)) {\n return stacked == other;\n }\n var result = true;\n stack.set(object, other);\n stack.set(other, object);\n\n var skipCtor = isPartial;\n while (++index < objLength) {\n key = objProps[index];\n var objValue = object[key],\n othValue = other[key];\n\n if (customizer) {\n var compared = isPartial\n ? customizer(othValue, objValue, key, other, object, stack)\n : customizer(objValue, othValue, key, object, other, stack);\n }\n // Recursively compare objects (susceptible to call stack limits).\n if (!(compared === undefined\n ? (objValue === othValue || equalFunc(objValue, othValue, bitmask, customizer, stack))\n : compared\n )) {\n result = false;\n break;\n }\n skipCtor || (skipCtor = key == 'constructor');\n }\n if (result && !skipCtor) {\n var objCtor = object.constructor,\n othCtor = other.constructor;\n\n // Non `Object` object instances with different constructors are not equal.\n if (objCtor != othCtor &&\n ('constructor' in object && 'constructor' in other) &&\n !(typeof objCtor == 'function' && objCtor instanceof objCtor &&\n typeof othCtor == 'function' && othCtor instanceof othCtor)) {\n result = false;\n }\n }\n stack['delete'](object);\n stack['delete'](other);\n return result;\n}\n\n/**\n * Creates an array of own enumerable property names and symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction getAllKeys(object) {\n return baseGetAllKeys(object, keys, getSymbols);\n}\n\n/**\n * Gets the data for `map`.\n *\n * @private\n * @param {Object} map The map to query.\n * @param {string} key The reference key.\n * @returns {*} Returns the map data.\n */\nfunction getMapData(map, key) {\n var data = map.__data__;\n return isKeyable(key)\n ? data[typeof key == 'string' ? 'string' : 'hash']\n : data.map;\n}\n\n/**\n * Gets the native function at `key` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the method to get.\n * @returns {*} Returns the function if it's native, else `undefined`.\n */\nfunction getNative(object, key) {\n var value = getValue(object, key);\n return baseIsNative(value) ? value : undefined;\n}\n\n/**\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the raw `toStringTag`.\n */\nfunction getRawTag(value) {\n var isOwn = hasOwnProperty.call(value, symToStringTag),\n tag = value[symToStringTag];\n\n try {\n value[symToStringTag] = undefined;\n var unmasked = true;\n } catch (e) {}\n\n var result = nativeObjectToString.call(value);\n if (unmasked) {\n if (isOwn) {\n value[symToStringTag] = tag;\n } else {\n delete value[symToStringTag];\n }\n }\n return result;\n}\n\n/**\n * Creates an array of the own enumerable symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\nvar getSymbols = !nativeGetSymbols ? stubArray : function(object) {\n if (object == null) {\n return [];\n }\n object = Object(object);\n return arrayFilter(nativeGetSymbols(object), function(symbol) {\n return propertyIsEnumerable.call(object, symbol);\n });\n};\n\n/**\n * Gets the `toStringTag` of `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nvar getTag = baseGetTag;\n\n// Fallback for data views, maps, sets, and weak maps in IE 11 and promises in Node.js < 6.\nif ((DataView && getTag(new DataView(new ArrayBuffer(1))) != dataViewTag) ||\n (Map && getTag(new Map) != mapTag) ||\n (Promise && getTag(Promise.resolve()) != promiseTag) ||\n (Set && getTag(new Set) != setTag) ||\n (WeakMap && getTag(new WeakMap) != weakMapTag)) {\n getTag = function(value) {\n var result = baseGetTag(value),\n Ctor = result == objectTag ? value.constructor : undefined,\n ctorString = Ctor ? toSource(Ctor) : '';\n\n if (ctorString) {\n switch (ctorString) {\n case dataViewCtorString: return dataViewTag;\n case mapCtorString: return mapTag;\n case promiseCtorString: return promiseTag;\n case setCtorString: return setTag;\n case weakMapCtorString: return weakMapTag;\n }\n }\n return result;\n };\n}\n\n/**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\nfunction isIndex(value, length) {\n length = length == null ? MAX_SAFE_INTEGER : length;\n return !!length &&\n (typeof value == 'number' || reIsUint.test(value)) &&\n (value > -1 && value % 1 == 0 && value < length);\n}\n\n/**\n * Checks if `value` is suitable for use as unique object key.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is suitable, else `false`.\n */\nfunction isKeyable(value) {\n var type = typeof value;\n return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean')\n ? (value !== '__proto__')\n : (value === null);\n}\n\n/**\n * Checks if `func` has its source masked.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` is masked, else `false`.\n */\nfunction isMasked(func) {\n return !!maskSrcKey && (maskSrcKey in func);\n}\n\n/**\n * Checks if `value` is likely a prototype object.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\n */\nfunction isPrototype(value) {\n var Ctor = value && value.constructor,\n proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\n\n return value === proto;\n}\n\n/**\n * Converts `value` to a string using `Object.prototype.toString`.\n *\n * @private\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n */\nfunction objectToString(value) {\n return nativeObjectToString.call(value);\n}\n\n/**\n * Converts `func` to its source code.\n *\n * @private\n * @param {Function} func The function to convert.\n * @returns {string} Returns the source code.\n */\nfunction toSource(func) {\n if (func != null) {\n try {\n return funcToString.call(func);\n } catch (e) {}\n try {\n return (func + '');\n } catch (e) {}\n }\n return '';\n}\n\n/**\n * Performs a\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * comparison between two values to determine if they are equivalent.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.eq(object, object);\n * // => true\n *\n * _.eq(object, other);\n * // => false\n *\n * _.eq('a', 'a');\n * // => true\n *\n * _.eq('a', Object('a'));\n * // => false\n *\n * _.eq(NaN, NaN);\n * // => true\n */\nfunction eq(value, other) {\n return value === other || (value !== value && other !== other);\n}\n\n/**\n * Checks if `value` is likely an `arguments` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n * else `false`.\n * @example\n *\n * _.isArguments(function() { return arguments; }());\n * // => true\n *\n * _.isArguments([1, 2, 3]);\n * // => false\n */\nvar isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) {\n return isObjectLike(value) && hasOwnProperty.call(value, 'callee') &&\n !propertyIsEnumerable.call(value, 'callee');\n};\n\n/**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(document.body.children);\n * // => false\n *\n * _.isArray('abc');\n * // => false\n *\n * _.isArray(_.noop);\n * // => false\n */\nvar isArray = Array.isArray;\n\n/**\n * Checks if `value` is array-like. A value is considered array-like if it's\n * not a function and has a `value.length` that's an integer greater than or\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n * @example\n *\n * _.isArrayLike([1, 2, 3]);\n * // => true\n *\n * _.isArrayLike(document.body.children);\n * // => true\n *\n * _.isArrayLike('abc');\n * // => true\n *\n * _.isArrayLike(_.noop);\n * // => false\n */\nfunction isArrayLike(value) {\n return value != null && isLength(value.length) && !isFunction(value);\n}\n\n/**\n * Checks if `value` is a buffer.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.\n * @example\n *\n * _.isBuffer(new Buffer(2));\n * // => true\n *\n * _.isBuffer(new Uint8Array(2));\n * // => false\n */\nvar isBuffer = nativeIsBuffer || stubFalse;\n\n/**\n * Performs a deep comparison between two values to determine if they are\n * equivalent.\n *\n * **Note:** This method supports comparing arrays, array buffers, booleans,\n * date objects, error objects, maps, numbers, `Object` objects, regexes,\n * sets, strings, symbols, and typed arrays. `Object` objects are compared\n * by their own, not inherited, enumerable properties. Functions and DOM\n * nodes are compared by strict equality, i.e. `===`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.isEqual(object, other);\n * // => true\n *\n * object === other;\n * // => false\n */\nfunction isEqual(value, other) {\n return baseIsEqual(value, other);\n}\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n if (!isObject(value)) {\n return false;\n }\n // The use of `Object#toString` avoids issues with the `typeof` operator\n // in Safari 9 which returns 'object' for typed arrays and other constructors.\n var tag = baseGetTag(value);\n return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;\n}\n\n/**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This method is loosely based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n * @example\n *\n * _.isLength(3);\n * // => true\n *\n * _.isLength(Number.MIN_VALUE);\n * // => false\n *\n * _.isLength(Infinity);\n * // => false\n *\n * _.isLength('3');\n * // => false\n */\nfunction isLength(value) {\n return typeof value == 'number' &&\n value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n}\n\n/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n var type = typeof value;\n return value != null && (type == 'object' || type == 'function');\n}\n\n/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n return value != null && typeof value == 'object';\n}\n\n/**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\nvar isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;\n\n/**\n * Creates an array of the own enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects. See the\n * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * for more details.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keys(new Foo);\n * // => ['a', 'b'] (iteration order is not guaranteed)\n *\n * _.keys('hi');\n * // => ['0', '1']\n */\nfunction keys(object) {\n return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);\n}\n\n/**\n * This method returns a new empty array.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {Array} Returns the new empty array.\n * @example\n *\n * var arrays = _.times(2, _.stubArray);\n *\n * console.log(arrays);\n * // => [[], []]\n *\n * console.log(arrays[0] === arrays[1]);\n * // => false\n */\nfunction stubArray() {\n return [];\n}\n\n/**\n * This method returns `false`.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {boolean} Returns `false`.\n * @example\n *\n * _.times(2, _.stubFalse);\n * // => [false, false]\n */\nfunction stubFalse() {\n return false;\n}\n\nmodule.exports = isEqual;\n","/**\n * @flow\n */\n\nexport {default as Picker} from './Picker';\nexport {default as PickerIOS} from './PickerIOS';\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 * @format\n * @flow\n */\n\n'use strict';\n\nimport * as React from 'react';\nimport {Platform} from 'react-native';\n\nimport PickerAndroid from './PickerAndroid';\nimport PickerIOS from './PickerIOS';\nimport PickerWindows from './PickerWindows';\nimport PickerMacOS from './PickerMacOS';\n\nimport type {TextStyleProp} from 'react-native/Libraries/StyleSheet/StyleSheet';\nimport type {ColorValue} from 'react-native/Libraries/StyleSheet/StyleSheet';\nimport type {Node} from 'react';\n\nconst MODE_DIALOG = 'dialog';\nconst MODE_DROPDOWN = 'dropdown';\n\ntype PickerItemProps = $ReadOnly<{|\n /**\n * Text to display for this item.\n */\n label: string,\n\n /**\n * The value to be passed to picker's `onValueChange` callback when\n * this item is selected. Can be a string or an integer.\n */\n value?: ?(number | string),\n\n /**\n * Color of this item's text.\n * @platform android\n */\n color?: ColorValue,\n\n /**\n * Used to locate the item in end-to-end tests.\n */\n testID?: string,\n|}>;\n\n/**\n * Individual selectable item in a Picker.\n */\nclass PickerItem extends React.Component {\n render() {\n // The items are not rendered directly\n throw null;\n }\n}\n\ntype PickerProps = $ReadOnly<{|\n children?: Node,\n style?: ?TextStyleProp,\n\n /**\n * Value matching value of one of the items. Can be a string or an integer.\n */\n selectedValue?: ?(number | string),\n\n /**\n * Callback for when an item is selected. This is called with the following parameters:\n * - `itemValue`: the `value` prop of the item that was selected\n * - `itemIndex`: the index of the selected item in this picker\n */\n onValueChange?: ?(itemValue: string | number, itemIndex: number) => mixed,\n\n /**\n * If set to false, the picker will be disabled, i.e. the user will not be able to make a\n * selection.\n * @platform android\n */\n enabled?: ?boolean,\n\n /**\n * On Android, specifies how to display the selection items when the user taps on the picker:\n *\n * - 'dialog': Show a modal dialog. This is the default.\n * - 'dropdown': Shows a dropdown anchored to the picker view\n *\n * @platform android\n */\n mode?: ?('dialog' | 'dropdown'),\n\n /**\n * Style to apply to each of the item labels.\n * @platform ios\n */\n itemStyle?: ?TextStyleProp,\n\n /**\n * Prompt string for this picker, used on Android in dialog mode as the title of the dialog.\n * @platform android\n */\n prompt?: ?string,\n\n /**\n * Placeholder string for this picker, used on Windows if no item has been selected.\n * @platform windows\n */\n placeholder?: ?string,\n\n /**\n * Used to locate this view in end-to-end tests.\n */\n testID?: ?string,\n\n /**\n * On Android, used to truncate the text with an ellipsis after computing the text layout, including line wrapping,\n * such that the total number of lines does not exceed this number. Default is '1'\n * @platform android\n */\n numberOfLines?: ?number,\n\n /**\n * The string used for the accessibility label. Will be read once focused on the picker but not on change.\n */\n accessibilityLabel?: ?string,\n|}>;\n\n/**\n * Renders the native picker component on iOS and Android. Example:\n *\n * this.setState({language: itemValue})}>\n * \n * \n * \n */\nclass Picker extends React.Component {\n pickerRef: React.ElementRef = React.createRef();\n /**\n * On Android, display the options in a dialog.\n */\n static MODE_DIALOG: typeof MODE_DIALOG = MODE_DIALOG;\n\n /**\n * On Android, display the options in a dropdown (this is the default).\n */\n static MODE_DROPDOWN: typeof MODE_DROPDOWN = MODE_DROPDOWN;\n\n static Item: typeof PickerItem = PickerItem;\n\n static defaultProps: PickerProps = {\n mode: MODE_DIALOG,\n };\n\n blur: () => void = () => {\n this.pickerRef.current?.blur();\n };\n\n focus: () => void = () => {\n this.pickerRef.current?.focus();\n };\n\n render(): React.Node {\n if (Platform.OS === 'ios') {\n /* $FlowFixMe(>=0.81.0 site=react_native_ios_fb) This suppression was\n * added when renaming suppression sites. */\n return {this.props.children};\n } else if (Platform.OS === 'macos') {\n /* $FlowFixMe(>=0.81.0 site=react_native_ios_fb) This suppression was\n * added when renaming suppression sites. */\n return {this.props.children};\n } else if (Platform.OS === 'android') {\n return (\n /* $FlowFixMe(>=0.81.0 site=react_native_android_fb) This suppression\n * was added when renaming suppression sites. */\n \n {this.props.children}\n \n );\n } else if (Platform.OS === 'windows') {\n return (\n {this.props.children}\n );\n } else {\n return null;\n }\n }\n}\n\nexport default Picker;\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 * @flow\n */\n\nimport UnimplementedView from './UnimplementedView';\n\n/**\n * Fallback for non-android platforms\n */\nexport default UnimplementedView;\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 * @flow\n * @format\n */\n\n'use strict';\n\nimport * as React from 'react';\nimport {View, StyleSheet} from 'react-native';\ndeclare var __DEV__: boolean;\n/**\n * Common implementation for a simple stubbed view. Simply applies the view's styles to the inner\n * View component and renders its children.\n */\nconst UnimplementedView = (props: $FlowFixMeProps): React.Node => {\n return (\n \n {props.children}\n \n );\n};\n\nconst styles = StyleSheet.create({\n unimplementedView: __DEV__\n ? {\n alignSelf: 'flex-start',\n borderColor: 'red',\n borderWidth: 1,\n }\n : {},\n});\n\nexport default UnimplementedView;\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 * This is a controlled component version of RNCPickerIOS\n *\n * @format\n * @flow\n */\n\n'use strict';\n\nimport * as React from 'react';\nimport {processColor, StyleSheet, View} from 'react-native';\nimport RNCPickerNativeComponent from './RNCPickerNativeComponent';\nimport type {RNCPickerIOSType} from './RNCPickerNativeComponent';\nimport type {ProcessedColorValue} from 'react-native/Libraries/StyleSheet/processColor';\nimport type {ColorValue} from 'react-native/Libraries/StyleSheet/StyleSheet';\nimport type {ViewProps} from 'react-native/Libraries/Components/View/ViewPropTypes';\nimport type {TextStyleProp} from 'react-native/Libraries/StyleSheet/StyleSheet';\nimport type {SyntheticEvent} from 'react-native/Libraries/Types/CoreEventTypes';\nimport type {Element, ElementRef, ChildrenArray} from 'react';\n\ntype PickerIOSChangeEvent = SyntheticEvent<\n $ReadOnly<{|\n newValue: number | string,\n newIndex: number,\n |}>,\n>;\n\ntype RNCPickerIOSItemType = $ReadOnly<{|\n label: ?Label,\n value: ?(number | string),\n textColor: ?ProcessedColorValue,\n testID: ?string,\n|}>;\n\ntype Label = Stringish | number;\n\ntype Props = $ReadOnly<{|\n ...ViewProps,\n children: ChildrenArray>,\n itemStyle?: ?TextStyleProp,\n onChange?: ?(event: PickerIOSChangeEvent) => mixed,\n onValueChange?: ?(itemValue: string | number, itemIndex: number) => mixed,\n selectedValue: ?(number | string),\n numberOfLines: ?number,\n themeVariant: ?string,\n|}>;\n\ntype State = {|\n selectedIndex: number,\n items: $ReadOnlyArray,\n|};\n\ntype ItemProps = $ReadOnly<{|\n label: ?Label,\n value?: ?(number | string),\n color?: ?ColorValue,\n testID?: ?string,\n|}>;\n\nconst PickerIOSItem = (props: ItemProps): null => {\n return null;\n};\n\nclass PickerIOS extends React.Component {\n _picker: ?ElementRef = null;\n\n state: State = {\n selectedIndex: 0,\n items: [],\n };\n\n static Item: typeof PickerIOSItem = PickerIOSItem;\n\n static getDerivedStateFromProps(props: Props): State {\n let selectedIndex = 0;\n const items = [];\n React.Children.toArray(props.children).forEach(function (child, index) {\n if (child.props.value === props.selectedValue) {\n selectedIndex = index;\n }\n items.push({\n value: child.props.value,\n label: child.props.label,\n textColor: processColor(child.props.color),\n testID: child.props.testID,\n });\n });\n return {selectedIndex, items};\n }\n\n render(): React.Node {\n let numberOfLines = Math.round(this.props.numberOfLines ?? 1);\n if (numberOfLines < 1) {\n numberOfLines = 1;\n }\n return (\n \n {\n this._picker = picker;\n }}\n themeVariant={this.props.themeVariant}\n testID={this.props.testID}\n style={[styles.pickerIOS, this.props.itemStyle]}\n items={this.state.items}\n selectedIndex={this.state.selectedIndex}\n onChange={this._onChange}\n numberOfLines={numberOfLines}\n />\n \n );\n }\n\n _onChange = (event) => {\n if (this.props.onChange) {\n this.props.onChange(event);\n }\n if (this.props.onValueChange) {\n this.props.onValueChange(\n event.nativeEvent.newValue,\n event.nativeEvent.newIndex,\n );\n }\n\n // The picker is a controlled component. This means we expect the\n // on*Change handlers to be in charge of updating our\n // `selectedValue` prop. That way they can also\n // disallow/undo/mutate the selection of certain values. In other\n // words, the embedder of this component should be the source of\n // truth, not the native component.\n if (\n this._picker &&\n this.state.selectedIndex !== event.nativeEvent.newIndex\n ) {\n this._picker.setNativeProps({\n selectedIndex: this.state.selectedIndex,\n });\n }\n };\n}\n\nconst styles = StyleSheet.create({\n pickerIOS: {\n // The picker will conform to whatever width is given, but we do\n // have to set the component's height explicitly on the\n // surrounding view to ensure it gets rendered.\n height: 216,\n },\n});\n\nexport default PickerIOS;\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 * @flow\n * @format\n */\n'use strict';\n\nimport {requireNativeComponent} from 'react-native';\n\nimport type {SyntheticEvent} from 'react-native/Libraries/Types/CoreEventTypes';\nimport type {ProcessedColorValue} from 'react-native/Libraries/StyleSheet/processColor';\nimport type {TextStyleProp} from 'react-native/Libraries/StyleSheet/StyleSheet';\nimport type {HostComponent} from 'react-native/Libraries/Renderer/shims/ReactNativeTypes';\n\ntype PickerIOSChangeEvent = SyntheticEvent<\n $ReadOnly<{|\n newValue: number | string,\n newIndex: number,\n |}>,\n>;\n\ntype RNCPickerIOSTypeItemType = $ReadOnly<{|\n label: ?Label,\n value: ?(number | string),\n textColor: ?ProcessedColorValue,\n testID: ?string,\n|}>;\n\ntype Label = Stringish | number;\n\nexport type RNCPickerIOSType = HostComponent<\n $ReadOnly<{|\n items: $ReadOnlyArray,\n onChange: (event: PickerIOSChangeEvent) => void,\n selectedIndex: number,\n style?: ?TextStyleProp,\n testID?: ?string,\n numberOfLines?: ?number,\n themeVariant?: ?string,\n |}>,\n>;\n\nmodule.exports = ((requireNativeComponent('RNCPicker'): any): RNCPickerIOSType);\n","/**\n * Copyright (c) Microsoft Corporation. All rights reserved.\n * Licensed under the MIT License.\n *\n * @flow\n */\n\n'use strict';\n\nimport UnimplementedView from './UnimplementedView';\n\nexport default UnimplementedView;\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 * @flow\n */\n\nimport * as React from 'react';\nimport UnimplementedView from './UnimplementedView';\nclass PickerMacOS extends React.Component<{}> {\n static Item: typeof UnimplementedView = UnimplementedView;\n render(): React.Node {\n return ;\n }\n}\n\n/**\n * Fallback for non-MacOS platforms\n */\nexport default PickerMacOS;\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport networkPropTypes from '../networkPropTypes';\nimport {withNetwork} from '../OnyxProvider';\nimport withLocalize, {withLocalizePropTypes} from '../withLocalize';\nimport * as Expensicons from '../Icon/Expensicons';\nimport compose from '../../libs/compose';\nimport BlockingView from './BlockingView';\n\nconst propTypes = {\n /** Child elements */\n children: PropTypes.node.isRequired,\n\n /** Props to fetch translation features */\n ...withLocalizePropTypes,\n\n /** Props to detect online status */\n network: networkPropTypes.isRequired,\n};\n\nconst FullPageOfflineBlockingView = (props) => {\n if (props.network.isOffline) {\n return (\n \n );\n }\n\n return props.children;\n};\n\nFullPageOfflineBlockingView.propTypes = propTypes;\nFullPageOfflineBlockingView.displayName = 'FullPageOfflineBlockingView';\n\nexport default compose(\n withLocalize,\n withNetwork(),\n)(FullPageOfflineBlockingView);\n","export default () => null;\n","import React from 'react';\nimport {View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport Lottie from 'lottie-react-native';\nimport FireworksAnimation from '../../assets/animations/Fireworks.json';\nimport Text from './Text';\nimport styles from '../styles/styles';\nimport Button from './Button';\nimport FixedFooter from './FixedFooter';\n\nconst propTypes = {\n /** The asset to render */\n animation: PropTypes.string,\n\n /** Heading of the confirmation page */\n heading: PropTypes.string,\n\n /** Description of the confirmation page */\n description: PropTypes.string,\n\n /** The text for the button label */\n buttonText: PropTypes.string,\n\n /** A function that is called when the button is clicked on */\n onButtonPress: PropTypes.func,\n\n /** Whether we should show a confirmation button */\n shouldShowButton: PropTypes.bool,\n};\n\nconst defaultProps = {\n animation: FireworksAnimation,\n heading: '',\n description: '',\n buttonText: '',\n onButtonPress: () => {},\n shouldShowButton: false,\n};\n\nconst ConfirmationPage = props => (\n <>\n \n \n \n {props.heading}\n \n \n {props.description}\n \n \n {props.shouldShowButton && (\n \n \n \n )}\n \n);\n\nConfirmationPage.propTypes = propTypes;\nConfirmationPage.defaultProps = defaultProps;\nConfirmationPage.displayName = 'ConfirmationPage';\n\nexport default ConfirmationPage;\n","module.exports=require(\"./LottieView\");","var _interopRequireDefault=require(\"@babel/runtime/helpers/interopRequireDefault\");var _extends2=_interopRequireDefault(require(\"@babel/runtime/helpers/extends\"));var _objectWithoutProperties2=_interopRequireDefault(require(\"@babel/runtime/helpers/objectWithoutProperties\"));var _toConsumableArray2=_interopRequireDefault(require(\"@babel/runtime/helpers/toConsumableArray\"));var _classCallCheck2=_interopRequireDefault(require(\"@babel/runtime/helpers/classCallCheck\"));var _createClass2=_interopRequireDefault(require(\"@babel/runtime/helpers/createClass\"));var _inherits2=_interopRequireDefault(require(\"@babel/runtime/helpers/inherits\"));var _possibleConstructorReturn2=_interopRequireDefault(require(\"@babel/runtime/helpers/possibleConstructorReturn\"));var _getPrototypeOf2=_interopRequireDefault(require(\"@babel/runtime/helpers/getPrototypeOf\"));var _react=_interopRequireDefault(require(\"react\"));var _reactNative=require(\"react-native\");var _reactNativeSafeModules=_interopRequireDefault(require(\"react-native-safe-modules\"));var _jsxFileName=\"/Users/emiliorodriguez/Work/lottie-react-native/src/js/LottieView.js\";var _excluded=[\"style\",\"source\",\"autoSize\",\"autoPlay\"];function _createSuper(Derived){var hasNativeReflectConstruct=_isNativeReflectConstruct();return function _createSuperInternal(){var Super=(0,_getPrototypeOf2.default)(Derived),result;if(hasNativeReflectConstruct){var NewTarget=(0,_getPrototypeOf2.default)(this).constructor;result=Reflect.construct(Super,arguments,NewTarget);}else{result=Super.apply(this,arguments);}return(0,_possibleConstructorReturn2.default)(this,result);};}function _isNativeReflectConstruct(){if(typeof Reflect===\"undefined\"||!Reflect.construct)return false;if(Reflect.construct.sham)return false;if(typeof Proxy===\"function\")return true;try{Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],function(){}));return true;}catch(e){return false;}}var getNativeLottieViewForDesktop=function getNativeLottieViewForDesktop(){return(0,_reactNative.requireNativeComponent)('LottieAnimationView');};var NativeLottieView=_reactNative.Platform.OS==='macos'||_reactNative.Platform.OS==='windows'?getNativeLottieViewForDesktop():_reactNativeSafeModules.default.component({viewName:'LottieAnimationView',mockComponent:_reactNative.View});var AnimatedNativeLottieView=_reactNative.Animated.createAnimatedComponent(NativeLottieView);var LottieViewManager=_reactNative.Platform.select({macos:_reactNative.NativeModules.LottieAnimationView,windows:_reactNative.NativeModules.LottieAnimationView,default:_reactNativeSafeModules.default.module({moduleName:'LottieAnimationView',mock:{play:function play(){},reset:function reset(){},pause:function pause(){},resume:function resume(){},getConstants:function getConstants(){}}})});var defaultProps={progress:0,speed:1,loop:true,autoPlay:false,autoSize:false,enableMergePathsAndroidForKitKatAndAbove:false,cacheComposition:true,useNativeLooping:false,resizeMode:'contain',colorFilters:[],textFiltersAndroid:[],textFiltersIOS:[]};var viewConfig={uiViewClassName:'LottieAnimationView',validAttributes:{progress:true}};var safeGetViewManagerConfig=function safeGetViewManagerConfig(moduleName){if(_reactNative.UIManager.getViewManagerConfig){return _reactNative.UIManager.getViewManagerConfig(moduleName);}return _reactNative.UIManager[moduleName];};var LottieView=function(_React$PureComponent){(0,_inherits2.default)(LottieView,_React$PureComponent);var _super=_createSuper(LottieView);function LottieView(props){var _this;(0,_classCallCheck2.default)(this,LottieView);_this=_super.call(this,props);_this.refRoot=function(root){_this.root=root;if(_this.props.autoPlay){_this.play();}};_this.onAnimationFinish=function(evt){if(_this.props.onAnimationFinish){_this.props.onAnimationFinish(evt.nativeEvent.isCancelled);}};_this.viewConfig=viewConfig;return _this;}(0,_createClass2.default)(LottieView,[{key:\"componentDidUpdate\",value:function componentDidUpdate(prevProps){if(this.props.autoPlay&&this.props.source!==prevProps.source&&!!this.props.source){this.play();}}},{key:\"setNativeProps\",value:function setNativeProps(props){_reactNative.UIManager.updateView(this.getHandle(),this.viewConfig.uiViewClassName,{progress:props.progress});}},{key:\"play\",value:function play(){var startFrame=arguments.length>0&&arguments[0]!==undefined?arguments[0]:-1;var endFrame=arguments.length>1&&arguments[1]!==undefined?arguments[1]:-1;this.runCommand('play',[startFrame,endFrame]);}},{key:\"reset\",value:function reset(){this.runCommand('reset');}},{key:\"pause\",value:function pause(){this.runCommand('pause');}},{key:\"resume\",value:function resume(){this.runCommand('resume');}},{key:\"runCommand\",value:function runCommand(name){var _this2=this;var args=arguments.length>1&&arguments[1]!==undefined?arguments[1]:[];var handle=this.getHandle();if(!handle){return null;}return _reactNative.Platform.select({android:function android(){return _reactNative.UIManager.dispatchViewManagerCommand(handle,safeGetViewManagerConfig('LottieAnimationView').Commands[name],args);},windows:function windows(){return _reactNative.UIManager.dispatchViewManagerCommand(handle,safeGetViewManagerConfig('LottieAnimationView').Commands[name],args);},ios:function ios(){return LottieViewManager[name].apply(LottieViewManager,[_this2.getHandle()].concat((0,_toConsumableArray2.default)(args)));},macos:function macos(){return LottieViewManager[name].apply(LottieViewManager,[_this2.getHandle()].concat((0,_toConsumableArray2.default)(args)));}})();}},{key:\"getHandle\",value:function getHandle(){return(0,_reactNative.findNodeHandle)(this.root);}},{key:\"render\",value:function render(){var _this$props=this.props,style=_this$props.style,source=_this$props.source,autoSize=_this$props.autoSize,autoPlay=_this$props.autoPlay,rest=(0,_objectWithoutProperties2.default)(_this$props,_excluded);var sourceName=typeof source==='string'?source:undefined;var sourceJson=typeof source==='object'&&!source.uri?JSON.stringify(source):undefined;var sourceURL=typeof source==='object'&&source.uri?source.uri:undefined;var aspectRatioStyle=sourceJson?{aspectRatio:source.w/source.h}:undefined;var styleObject=_reactNative.StyleSheet.flatten(style);var sizeStyle;if(!styleObject||styleObject.width===undefined&&styleObject.height===undefined){sizeStyle=autoSize&&sourceJson?{width:source.w}:_reactNative.StyleSheet.absoluteFill;}var speed=this.props.duration&&sourceJson&&this.props.source.fr?Math.round(this.props.source.op/this.props.source.fr*1000/this.props.duration):this.props.speed;var colorFilters=Array.isArray(this.props.colorFilters)?this.props.colorFilters.map(function(_ref){var keypath=_ref.keypath,color=_ref.color;return{keypath:keypath,color:(0,_reactNative.processColor)(color)};}):undefined;return _react.default.createElement(_reactNative.View,{style:[aspectRatioStyle,sizeStyle,style],__self:this,__source:{fileName:_jsxFileName,lineNumber:177,columnNumber:7}},_react.default.createElement(AnimatedNativeLottieView,(0,_extends2.default)({ref:this.refRoot},rest,{colorFilters:colorFilters,speed:speed,style:[aspectRatioStyle,sizeStyle||{width:'100%',height:'100%'},style],sourceName:sourceName,sourceJson:sourceJson,sourceURL:sourceURL,onAnimationFinish:this.onAnimationFinish,__self:this,__source:{fileName:_jsxFileName,lineNumber:178,columnNumber:9}})));}}]);return LottieView;}(_react.default.PureComponent);LottieView.defaultProps=defaultProps;module.exports=LottieView;","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\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n\n return target;\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n return _extends.apply(this, arguments);\n}\n\nmodule.exports = _extends, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","\nmodule.exports={\ncreate:require('./SafeModule'),\nmodule:require('./SafeModule'),\ncomponent:require('./SafeComponent')};","module.exports=require('./NativeSafeModule');","var _extends=Object.assign||function(target){for(var i=1;i 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n values[_key - 1] = arguments[_key];\n }\n\n for (var i = 0; i < raw.length; i++) {\n result += raw[i].\n // join lines when there is a suppressed newline\n replace(/\\\\\\n[ \\t]*/g, \"\").\n\n // handle escaped backticks\n replace(/\\\\`/g, \"`\");\n\n if (i < values.length) {\n result += values[i];\n }\n }\n\n // dedent eats leading and trailing whitespace too\n result = result.trim();\n\n // now strip indentation\n var lines = result.split(\"\\n\");\n var mindent = null;\n lines.forEach(function (l) {\n var m = l.match(/^ +/);\n if (m) {\n var indent = m[0].length;\n if (!mindent) {\n // this is the first indented line\n mindent = indent;\n } else {\n mindent = Math.min(mindent, indent);\n }\n }\n });\n\n if (mindent !== null) {\n result = lines.map(function (l) {\n return l[0] === \" \" ? l.slice(mindent) : l;\n }).join(\"\\n\");\n }\n\n // handle escaped newlines at the end to ensure they don't get stripped too\n return result.replace(/\\\\n/g, \"\\n\");\n}\n\nif (typeof module !== \"undefined\") {\n module.exports = dedent;\n}","module.exports=require('./NativeSafeComponent');","var _extends=Object.assign||function(target){for(var i=1;i2?_len-2:0),_key=2;_key<_len;_key++){args[_key-2]=arguments[_key];}\nvar native=function native(){return _reactNative.UIManager.dispatchViewManagerCommand(\n(0,_reactNative.findNodeHandle)(instance),\ngetViewManagerConfig(realViewName).Commands[name],\nargs);};\n\nreturn _reactNative.Platform.select({\nandroid:native,\nios:function ios(){return nativeModule[name].apply(nativeModule,[(0,_reactNative.findNodeHandle)(instance)].concat(args));},\nwindows:native,\ndefault:function _default(){}})();\n\n};\n\nresult.updateView=function(instance,props){\nvar native=function native(){return _reactNative.UIManager.updateView((0,_reactNative.findNodeHandle)(instance),realViewName,props);};\n_reactNative.Platform.select({\nios:native,\nandroid:native,\nwindows:native,\ndefault:function _default(){}})();\n\n};\n\nif(componentOverrides){\nvar _overrides=componentOverrides[version];\nif(_overrides){\nif(__DEV__){\nif(typeof _overrides!=='function'){\nconsole.error((0,_dedent2.default)(_templateObject2,\nPRIMARY_VIEW_NAME,\nversion,\ntypeof _overrides));\n\n}\n}\n\nresult=_overrides(nativeComponent,nativeModule);\n\nif(__DEV__){\nif(typeof result!=='function'){\nconsole.error((0,_dedent2.default)(_templateObject3,\nPRIMARY_VIEW_NAME,\nversion,\ntypeof result));\n\n}\n}\n}\n}\n\nreturn result;\n}\n\nmodule.exports=SafeComponentCreate;","{\"v\":\"5.9.6\",\"fr\":24,\"ip\":0,\"op\":109,\"w\":360,\"h\":360,\"nm\":\"Comp 1\",\"ddd\":0,\"assets\":[{\"id\":\"comp_0\",\"nm\":\"Expensify-Fireworks-120722-kjs-1\",\"fr\":24,\"layers\":[{\"ddd\":0,\"ind\":4,\"ty\":3,\"nm\":\"pyramid all\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.333,\"y\":0},\"t\":83,\"s\":[970,372.5,0],\"to\":[0,23.333,0],\"ti\":[0,-23.333,0]},{\"t\":108,\"s\":[970,512.5,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[51,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":5,\"ty\":3,\"nm\":\"1\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[42,35,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[42,-103.341,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.169},\"t\":99,\"s\":[42,-134.114,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[39,-152,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":6,\"ty\":3,\"nm\":\"2\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[57.5,55,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[80.693,-53.232,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.136},\"t\":99,\"s\":[85.851,-77.307,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[89,-95,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":7,\"ty\":3,\"nm\":\"3\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[56,67.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[71.462,-25.677,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.134},\"t\":99,\"s\":[74.901,-46.406,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[76,-62,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":8,\"ty\":3,\"nm\":\"4\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[69,73,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[110.502,-7.564,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.131},\"t\":99,\"s\":[119.735,-25.486,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[127,-39,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":9,\"ty\":3,\"nm\":\"5\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[80,91,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[141.033,30.781,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.151},\"t\":99,\"s\":[154.611,17.384,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[163,8,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":10,\"ty\":3,\"nm\":\"6\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[1.5,92.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[-43.664,8.274,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.13},\"t\":99,\"s\":[-53.709,-10.458,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[-64,-23,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":11,\"ty\":3,\"nm\":\"7\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[-19,123,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[-102.819,94.518,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.164},\"t\":99,\"s\":[-121.468,88.181,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[-133,85,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":12,\"ty\":3,\"nm\":\"8\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[-43,157,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[-151.232,182.227,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.139},\"t\":99,\"s\":[-175.314,187.84,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[-193,189,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":13,\"ty\":3,\"nm\":\"9\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[-27.5,175,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[-123.932,214.875,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.152},\"t\":99,\"s\":[-145.389,223.747,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[-160,228,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":14,\"ty\":3,\"nm\":\"10\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[-6,174,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[-70.288,214.689,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.134},\"t\":99,\"s\":[-84.592,223.742,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[-96,229,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":15,\"ty\":3,\"nm\":\"11\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[17.5,155.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[-10.575,179.506,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.148},\"t\":99,\"s\":[-16.82,184.846,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[-22,183,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":16,\"ty\":3,\"nm\":\"12\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[35,174.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[21.166,216.409,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.255},\"t\":99,\"s\":[18.088,225.733,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[15,228,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":17,\"ty\":3,\"nm\":\"13\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[51.5,150,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[61.672,162.207,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.328},\"t\":99,\"s\":[63.933,164.919,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[65,165,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":18,\"ty\":3,\"nm\":\"14\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[65,149,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[99.992,153.883,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.351},\"t\":99,\"s\":[107.774,154.968,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[110,155,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":19,\"ty\":3,\"nm\":\"15\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[69,162.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[94.227,187.32,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.256},\"t\":99,\"s\":[99.837,192.84,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[102,195,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":20,\"ty\":3,\"nm\":\"16\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[81.5,131.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[146.195,118.073,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.173},\"t\":99,\"s\":[160.59,115.085,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[168,111,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":21,\"ty\":3,\"nm\":\"17\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[89.5,176,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[158.264,215.875,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.186},\"t\":99,\"s\":[173.564,224.747,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[182,229,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":22,\"ty\":3,\"nm\":\"18\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[141,185,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[259.811,238.709,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.173},\"t\":99,\"s\":[286.239,250.656,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[302,256,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":23,\"ty\":3,\"nm\":\"19\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[141,233,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[276.086,368.086,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.201},\"t\":99,\"s\":[306.143,398.143,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[321,413,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":24,\"ty\":3,\"nm\":\"20\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[82,233.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[139.778,370.621,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.196},\"t\":99,\"s\":[152.63,401.122,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[158,417,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":25,\"ty\":3,\"nm\":\"21\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[62,234,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[102.689,373.155,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.198},\"t\":99,\"s\":[111.739,404.109,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[115,420,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":26,\"ty\":3,\"nm\":\"22\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[-26,234,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[-90.288,372.341,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.172},\"t\":99,\"s\":[-104.592,403.123,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[-116,419,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":27,\"ty\":3,\"nm\":\"23\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[-86,232,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[-240.617,366.273,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.163},\"t\":99,\"s\":[-275.02,396.149,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[-299,410,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":28,\"ty\":3,\"nm\":\"24\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[23,64,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[-8.737,-43.418,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.132},\"t\":99,\"s\":[-15.799,-67.319,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[-22,-85,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":29,\"ty\":3,\"nm\":\"25\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[-50,175,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[-178.576,235.219,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.155},\"t\":99,\"s\":[-207.176,248.614,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[-226,256,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":30,\"ty\":3,\"nm\":\"26\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[-1,135.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[-61.219,122.073,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.133},\"t\":99,\"s\":[-74.618,119.085,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[-84,115,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":31,\"ty\":3,\"nm\":\"27\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[12,173,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[-21.365,213.689,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.11},\"t\":99,\"s\":[-28.787,222.741,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[-38,228,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":32,\"ty\":3,\"nm\":\"28\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[-48,233,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[-139.143,367.273,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.156},\"t\":99,\"s\":[-159.422,397.149,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[-175,414,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":33,\"ty\":3,\"nm\":\"29\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[111,141,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[196.446,139.372,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.163},\"t\":99,\"s\":[215.458,139.01,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[227,138,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":34,\"ty\":3,\"nm\":\"30\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[12,237,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[4.676,376.155,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.175},\"t\":99,\"s\":[3.047,407.109,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[-2,424,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":35,\"ty\":3,\"nm\":\"32\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[100.5,234.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[184.726,366.738,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.179},\"t\":99,\"s\":[203.466,396.162,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[213,413,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":36,\"ty\":3,\"nm\":\"33\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[159,215,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[294.9,297.191,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.166},\"t\":99,\"s\":[325.138,315.479,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[344,325,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":37,\"ty\":3,\"nm\":\"34\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[40.5,67.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[28.7,-37.07,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.137},\"t\":99,\"s\":[26.075,-60.337,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[23,-77,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":38,\"ty\":3,\"nm\":\"35\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[14.5,84.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[-20.899,-11.932,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.188},\"t\":99,\"s\":[-28.776,-33.389,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[-32,-45,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":39,\"ty\":3,\"nm\":\"36\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[-10.5,113,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[-71.94,47.898,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.132},\"t\":99,\"s\":[-85.61,33.413,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[-98,25,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":40,\"ty\":3,\"nm\":\"37\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[93,117,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[162.171,78.753,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.168},\"t\":99,\"s\":[177.561,70.243,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[185,63,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":41,\"ty\":3,\"nm\":\"38\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[26.5,149.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[13.073,161.3,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.277},\"t\":99,\"s\":[10.088,163.923,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[9,163,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":42,\"ty\":3,\"nm\":\"39\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[-32,145,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[-127.212,140.117,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.127},\"t\":99,\"s\":[-148.387,139.031,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[-165,138,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":43,\"ty\":3,\"nm\":\"40\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[53.5,175.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[70.182,217.409,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.221},\"t\":99,\"s\":[73.894,226.733,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[77,230,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":44,\"ty\":3,\"nm\":\"41\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[71.5,176,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[116.664,218.316,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.254},\"t\":99,\"s\":[126.712,227.73,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[130,232,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":45,\"ty\":3,\"nm\":\"42\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[108,177,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[201.584,218.502,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.151},\"t\":99,\"s\":[222.401,227.734,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[237,231,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":46,\"ty\":3,\"nm\":\"43\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[131,170,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[234.349,193.599,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.194},\"t\":99,\"s\":[257.345,198.85,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[269,202,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":47,\"ty\":3,\"nm\":\"44\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[-70,203,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[-207.528,298.212,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.152},\"t\":99,\"s\":[-238.128,319.396,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[-260,330,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":48,\"ty\":3,\"nm\":\"45\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[-70,234,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[-191.252,371.528,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.169},\"t\":99,\"s\":[-218.231,402.128,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[-237,417,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":49,\"ty\":3,\"nm\":\"46\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[-8,235,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[-50.316,373.341,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.17},\"t\":99,\"s\":[-59.732,404.123,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[-68,421,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":50,\"ty\":3,\"nm\":\"47\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[39,237,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[56.089,374.528,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.18},\"t\":99,\"s\":[59.891,405.119,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[62,422,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":51,\"ty\":3,\"nm\":\"48\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[120.5,234.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[232.394,369.993,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.203},\"t\":99,\"s\":[257.291,400.141,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[268,416,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":52,\"ty\":3,\"nm\":\"49\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[168,232,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[323.431,361.39,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.167},\"t\":99,\"s\":[358.014,390.18,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[377,409,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":53,\"ty\":3,\"nm\":\"50\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[36,108.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[24.607,60.08,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.099},\"t\":99,\"s\":[22.073,49.311,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[18,39,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":54,\"ty\":3,\"nm\":\"51\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[28.5,104.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[0.425,51.198,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.125},\"t\":99,\"s\":[-5.822,39.338,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[-11,30,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":55,\"ty\":3,\"nm\":\"52\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[31.5,190.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[2.611,251.126,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.199},\"t\":99,\"s\":[-3.816,264.613,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[-9,270,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":56,\"ty\":3,\"nm\":\"53\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[55,128,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[76.158,107.656,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.117},\"t\":99,\"s\":[80.863,103.131,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[83,98,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":57,\"ty\":3,\"nm\":\"54\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[37,129.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[28.048,116.073,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.082},\"t\":99,\"s\":[26.059,113.089,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[23,110,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":58,\"ty\":3,\"nm\":\"55\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[7.5,191.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[-63.705,252.94,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.182},\"t\":99,\"s\":[-79.542,266.605,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[-89,273,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":59,\"ty\":3,\"nm\":\"56\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[27,221,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[-4.737,327.604,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.158},\"t\":99,\"s\":[-11.799,351.324,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[-17,366,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":60,\"ty\":3,\"nm\":\"57\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[57,206,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[70.834,291.446,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.166},\"t\":99,\"s\":[73.912,310.455,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[74,322,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":61,\"ty\":3,\"nm\":\"58\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[63,190.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[87.413,248.685,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.207},\"t\":99,\"s\":[92.844,261.629,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[95,268,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":62,\"ty\":3,\"nm\":\"59\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[82,190,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[140.592,248.592,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.241},\"t\":99,\"s\":[153.626,261.626,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[159,267,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":63,\"ty\":3,\"nm\":\"60\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[12.5,207.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[-50.567,295.794,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.143},\"t\":99,\"s\":[-64.596,315.434,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[-73,330,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":64,\"ty\":3,\"nm\":\"61\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[31.5,209,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[1.797,299.329,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.16},\"t\":99,\"s\":[-4.809,319.419,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[-11,331,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":65,\"ty\":3,\"nm\":\"62\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[75.5,209,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[122.292,298.515,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.174},\"t\":99,\"s\":[132.7,318.427,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[140,329,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":66,\"ty\":3,\"nm\":\"63\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[47.5,223.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[46.279,334.58,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.177},\"t\":99,\"s\":[46.008,359.288,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[44,373,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":67,\"ty\":3,\"nm\":\"64\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[45.5,111,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[47.534,67.87,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.092},\"t\":99,\"s\":[47.987,58.277,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[47,48,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":68,\"ty\":3,\"nm\":\"65\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[50.5,92.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[61.486,14.785,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.139},\"t\":99,\"s\":[63.93,-2.507,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[64,-15,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":69,\"ty\":3,\"nm\":\"66\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[33.5,94,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[18.445,19.947,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.119},\"t\":99,\"s\":[15.096,3.47,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[11,-10,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":70,\"ty\":3,\"nm\":\"67\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[36,119,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[22.98,86.449,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.118},\"t\":99,\"s\":[20.084,79.209,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[18,73,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":71,\"ty\":3,\"nm\":\"68\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[50.5,135,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[54.976,127.676,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.133},\"t\":99,\"s\":[55.97,126.048,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[55,125,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":72,\"ty\":3,\"nm\":\"69\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[29,125,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[5.401,103.028,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.122},\"t\":99,\"s\":[0.153,98.142,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[-4,94,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":73,\"ty\":3,\"nm\":\"70\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[41,91.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[36.931,9.716,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.132},\"t\":99,\"s\":[36.026,-8.481,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[34,-22,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":74,\"ty\":3,\"nm\":\"71\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[62.5,104,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[94.644,49.477,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.146},\"t\":99,\"s\":[101.795,37.348,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[104,28,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":75,\"ty\":3,\"nm\":\"72\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[62,115.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[94.551,80.915,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.123},\"t\":99,\"s\":[101.792,73.221,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[104,65,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":76,\"ty\":3,\"nm\":\"73\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[59,97.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[84.227,27.922,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.156},\"t\":99,\"s\":[89.84,12.441,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[91,2,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":77,\"ty\":3,\"nm\":\"74\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[56,196,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[69.834,264.357,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.347},\"t\":99,\"s\":[72.912,279.564,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[73,284,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":78,\"ty\":3,\"nm\":\"75\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[72,190,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[113.502,247.778,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.185},\"t\":99,\"s\":[122.735,260.632,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[127,268,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":79,\"ty\":3,\"nm\":\"76\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[49.5,189.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[53.976,245.243,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.167},\"t\":99,\"s\":[54.971,257.645,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[54,265,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":80,\"ty\":3,\"nm\":\"77\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[55.5,222,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[72.182,331.859,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.177},\"t\":99,\"s\":[75.893,356.296,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[78,370,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":81,\"ty\":3,\"nm\":\"78\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[62.5,218,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[89.761,323.79,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.176},\"t\":99,\"s\":[95.825,347.322,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[97,361,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":82,\"ty\":3,\"nm\":\"79\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[69.5,214.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[104.899,313.373,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.196},\"t\":99,\"s\":[112.773,335.367,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[115,347,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":83,\"ty\":3,\"nm\":\"80\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[67.5,204.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[98.016,290.353,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.19},\"t\":99,\"s\":[104.805,309.453,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[106,320,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":84,\"ty\":3,\"nm\":\"81\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[81,198.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[138.778,272.96,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.191},\"t\":99,\"s\":[151.632,289.525,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[157,299,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":85,\"ty\":3,\"nm\":\"82\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[37.5,224,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[20.004,332.232,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.188},\"t\":99,\"s\":[16.112,356.307,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[14,369,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":86,\"ty\":3,\"nm\":\"83\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[19,216,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[-30.64,311.212,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.149},\"t\":99,\"s\":[-41.682,332.39,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[-50,346,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":87,\"ty\":3,\"nm\":\"84\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[23,208,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[-20.13,297.515,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.174},\"t\":99,\"s\":[-29.724,317.427,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[-38,327,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":88,\"ty\":3,\"nm\":\"85\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[47,208,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[46.186,298.329,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.172},\"t\":99,\"s\":[46.005,318.427,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[45,330,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":89,\"ty\":3,\"nm\":\"86\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[39.5,207.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[24.445,298.236,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.184},\"t\":99,\"s\":[21.096,318.421,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[18,329,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":90,\"ty\":3,\"nm\":\"87\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[30.5,199.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[3.239,275.588,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.18},\"t\":99,\"s\":[-2.827,292.517,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[-8,301,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":91,\"ty\":3,\"nm\":\"88\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[8,201,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[-59.543,275.053,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.157},\"t\":99,\"s\":[-74.567,291.526,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[-85,301,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":92,\"ty\":3,\"nm\":\"89\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[40,189.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.698},\"t\":92,\"s\":[28.607,247.685,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.194},\"t\":99,\"s\":[26.073,260.627,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[22,266,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":93,\"ty\":3,\"nm\":\"90\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.593,\"y\":0.764},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":83,\"s\":[20,189,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.686,\"y\":0.929},\"o\":{\"x\":0.344,\"y\":0.697},\"t\":92,\"s\":[-27.199,249.219,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.343,\"y\":0.224},\"t\":99,\"s\":[-37.701,262.618,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":108,\"s\":[-43,268,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[52,52,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.635,0.635,0.635],\"y\":[0.853,0.853,-6.148]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.153,0.153,7.449]},\"t\":83,\"s\":[50,50,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.347,0.347,0.347],\"y\":[-0.052,-0.052,3.817]},\"t\":99,\"s\":[98.683,98.683,100]},{\"t\":108,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":109,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":94,\"ty\":4,\"nm\":\"pyramid blast 1 Outlines\",\"parent\":5,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[50.55,51.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[535.875,162.388,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-20.579,-16.196],[16.196,-20.579],[20.579,16.196],[-16.196,20.58]],\"o\":[[-23.549,-11.457],[11.458,-23.549],[23.549,11.457],[-11.458,23.549]],\"v\":[[26.354,16.515],[-16.516,26.355],[-26.355,-16.514],[16.515,-26.355]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[537.633,163.497],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":95,\"ty\":4,\"nm\":\"pyramid blast 2 Outlines\",\"parent\":6,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[50.55,50.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[593.018,235.115,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.23,-1.273],[0,0],[-0.365,-0.361],[0,0],[1.282,-0.175],[0,0],[0.231,-0.458],[0,0],[0.563,1.166],[0,0],[0.508,0.079],[0,0],[-0.934,0.896],[0,0],[0.082,0.507],[0,0],[-1.14,-0.612],[0,0],[-0.457,0.235],[0,0]],\"o\":[[0,0],[-0.092,0.505],[0,0],[0.918,0.911],[0,0],[-0.509,0.069],[0,0],[-0.583,1.155],[0,0],[-0.224,-0.462],[0,0],[-1.279,-0.197],[0,0],[0.371,-0.356],[0,0],[-0.208,-1.277],[0,0],[0.453,0.243],[0,0],[1.151,-0.593]],\"v\":[[12.356,-15.902],[10.511,-5.681],[10.948,-4.296],[18.323,3.019],[17.433,5.673],[7.143,7.079],[5.961,7.922],[1.284,17.196],[-1.516,17.171],[-6.031,7.818],[-7.2,6.954],[-17.464,5.371],[-18.307,2.701],[-10.807,-4.483],[-10.346,-5.861],[-12.013,-16.113],[-9.734,-17.738],[-0.583,-12.827],[0.87,-12.814],[10.104,-17.566]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[595.618,238.838],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":96,\"ty\":4,\"nm\":\"pyramid blast 3 Outlines\",\"parent\":7,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[52.55,53.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[581.329,279.271,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-5.686],[5.686,0],[0,5.686],[-5.686,0]],\"o\":[[0,5.686],[-5.686,0],[0,-5.686],[5.686,0]],\"v\":[[10.296,0],[0,10.296],[-10.296,0],[0,-10.296]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[580.777,278.24],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":97,\"ty\":4,\"nm\":\"pyramid blast 4 Outlines\",\"parent\":8,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[52.55,53.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[639.771,306.544,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-5.686],[5.686,0],[0,5.686],[-5.686,0]],\"o\":[[0,5.686],[-5.686,0],[0,-5.686],[5.686,0]],\"v\":[[10.296,0],[0,10.296],[-10.296,0],[0,-10.296]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[639.716,305.739],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":98,\"ty\":4,\"nm\":\"pyramid blast 5 Outlines\",\"parent\":9,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[52.55,52.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[685.225,361.089,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-5.686],[5.686,0],[0,5.686],[-5.686,0]],\"o\":[[0,5.686],[-5.686,0],[0,-5.686],[5.686,0]],\"v\":[[10.296,0],[0,10.296],[-10.296,0],[0,-10.296]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[684.777,361.022],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":99,\"ty\":4,\"nm\":\"pyramid blast 6 Outlines\",\"parent\":10,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[52.55,54.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[413.797,327.323,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-5.686],[5.686,0],[0,5.686],[-5.686,0]],\"o\":[[0,5.686],[-5.686,0],[0,-5.686],[5.686,0]],\"v\":[[10.296,0],[0,10.296],[-10.296,0],[0,-10.296]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[412.648,324.617],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":100,\"ty\":4,\"nm\":\"pyramid blast 7 Outlines\",\"parent\":11,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,52.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[324.186,453.297,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-5.686],[5.686,0],[0,5.686],[-5.686,0]],\"o\":[[0,5.686],[-5.686,0],[0,-5.686],[5.686,0]],\"v\":[[10.296,0],[0,10.296],[-10.296,0],[0,-10.296]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[325.652,453.161],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":101,\"ty\":4,\"nm\":\"pyramid blast 8 Outlines\",\"parent\":12,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,52.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[254.056,583.167,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-5.686],[5.686,0],[0,5.686],[-5.686,0]],\"o\":[[0,5.686],[-5.686,0],[0,-5.686],[5.686,0]],\"v\":[[10.296,0],[0,10.296],[-10.296,0],[0,-10.296]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[255.37,582.165],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":102,\"ty\":4,\"nm\":\"pyramid blast 9 Outlines\",\"parent\":13,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[52.55,53.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[294.316,631.219,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-5.686],[5.686,0],[0,5.686],[-5.686,0]],\"o\":[[0,5.686],[-5.686,0],[0,-5.686],[5.686,0]],\"v\":[[10.296,0],[0,10.296],[-10.296,0],[0,-10.296]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[293.939,628.866],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":103,\"ty\":4,\"nm\":\"pyramid blast 10 Outlines\",\"parent\":14,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[53.55,53.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[374.836,631.219,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-5.686],[5.686,0],[0,5.686],[-5.686,0]],\"o\":[[0,5.686],[-5.686,0],[0,-5.686],[5.686,0]],\"v\":[[10.296,0],[0,10.296],[-10.296,0],[0,-10.296]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[373.169,629.122],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":104,\"ty\":4,\"nm\":\"pyramid blast 11 Outlines\",\"parent\":15,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[52.55,53.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[461.849,580.57,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-5.686],[5.686,0],[0,5.686],[-5.686,0]],\"o\":[[0,5.686],[-5.686,0],[0,-5.686],[5.686,0]],\"v\":[[10.296,0],[0,10.296],[-10.296,0],[0,-10.296]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[461.439,577.89],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":105,\"ty\":4,\"nm\":\"pyramid blast 12 Outlines\",\"parent\":16,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,53.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[506.005,633.816,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-5.686],[5.686,0],[0,5.686],[-5.686,0]],\"o\":[[0,5.686],[-5.686,0],[0,-5.686],[5.686,0]],\"v\":[[10.296,0],[0,10.296],[-10.296,0],[0,-10.296]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[507.357,631.438],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":106,\"ty\":4,\"nm\":\"pyramid blast 13 Outlines\",\"parent\":17,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,52.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[565.745,553.297,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-5.686],[5.686,0],[0,5.686],[-5.686,0]],\"o\":[[0,5.686],[-5.686,0],[0,-5.686],[5.686,0]],\"v\":[[10.296,0],[0,10.296],[-10.296,0],[0,-10.296]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[566.497,553.87],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":107,\"ty\":4,\"nm\":\"pyramid blast 14 Outlines\",\"parent\":18,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,53.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[622.888,541.609,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-5.686],[5.686,0],[0,5.686],[-5.686,0]],\"o\":[[0,5.686],[-5.686,0],[0,-5.686],[5.686,0]],\"v\":[[10.296,0],[0,10.296],[-10.296,0],[0,-10.296]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[623.066,538.871],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":108,\"ty\":4,\"nm\":\"pyramid blast 15 Outlines\",\"parent\":19,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[53.55,55.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[615.095,593.557,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-5.686],[5.686,0],[0,5.686],[-5.686,0]],\"o\":[[0,5.686],[-5.686,0],[0,-5.686],[5.686,0]],\"v\":[[10.296,0],[0,10.296],[-10.296,0],[0,-10.296]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[613.344,590.297],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":109,\"ty\":4,\"nm\":\"pyramid blast 16 Outlines\",\"parent\":20,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[52.55,52.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[693.018,488.362,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-5.686],[5.686,0],[0,5.686],[-5.686,0]],\"o\":[[0,5.686],[-5.686,0],[0,-5.686],[5.686,0]],\"v\":[[10.296,0],[0,10.296],[-10.296,0],[0,-10.296]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[692.491,487.873],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":110,\"ty\":4,\"nm\":\"pyramid blast 17 Outlines\",\"parent\":21,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,54.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[708.602,633.816,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-5.686],[5.686,0],[0,5.686],[-5.686,0]],\"o\":[[0,5.686],[-5.686,0],[0,-5.686],[5.686,0]],\"v\":[[10.296,0],[0,10.296],[-10.296,0],[0,-10.296]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[709.205,631.438],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":111,\"ty\":4,\"nm\":\"pyramid blast 18 Outlines\",\"parent\":22,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[52.55,52.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[856.654,664.985,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-5.686],[5.686,0],[0,5.686],[-5.686,0]],\"o\":[[0,5.686],[-5.686,0],[0,-5.686],[5.686,0]],\"v\":[[10.296,0],[0,10.296],[-10.296,0],[0,-10.296]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[857.055,665.293],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":112,\"ty\":4,\"nm\":\"pyramid blast 19 Outlines\",\"parent\":23,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[52.55,53.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[882.628,858.492,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-5.686],[5.686,0],[0,5.686],[-5.686,0]],\"o\":[[0,5.686],[-5.686,0],[0,-5.686],[5.686,0]],\"v\":[[10.296,0],[0,10.296],[-10.296,0],[0,-10.296]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[881.482,856.427],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":113,\"ty\":4,\"nm\":\"pyramid blast 20 Outlines\",\"parent\":24,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[53.55,54.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[683.927,863.687,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-5.686],[5.686,0],[0,5.686],[-5.686,0]],\"o\":[[0,5.686],[-5.686,0],[0,-5.686],[5.686,0]],\"v\":[[10.296,0],[0,10.296],[-10.296,0],[0,-10.296]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[682.132,860.712],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":114,\"ty\":4,\"nm\":\"pyramid blast 21 Outlines\",\"parent\":25,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,52.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[628.082,864.985,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-5.686],[5.686,0],[0,5.686],[-5.686,0]],\"o\":[[0,5.686],[-5.686,0],[0,-5.686],[5.686,0]],\"v\":[[10.296,0],[0,10.296],[-10.296,0],[0,-10.296]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[628.209,863.283],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":115,\"ty\":4,\"nm\":\"pyramid blast 22 Outlines\",\"parent\":26,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[50.55,52.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[344.966,863.687,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-5.686],[5.686,0],[0,5.686],[-5.686,0]],\"o\":[[0,5.686],[-5.686,0],[0,-5.686],[5.686,0]],\"v\":[[10.296,0],[0,10.296],[-10.296,0],[0,-10.296]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[346.651,863.539],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":116,\"ty\":4,\"nm\":\"pyramid blast 23 Outlines\",\"parent\":27,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,53.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[124.186,855.894,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-5.686],[5.686,0],[0,5.686],[-5.686,0]],\"o\":[[0,5.686],[-5.686,0],[0,-5.686],[5.686,0]],\"v\":[[10.296,0],[0,10.296],[-10.296,0],[0,-10.296]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[124.233,853.754],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":117,\"ty\":4,\"nm\":\"pyramid blast 24 Outlines\",\"parent\":28,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,53.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[461.849,251.998,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-20.579,-16.196],[16.196,-20.579],[20.579,16.196],[-16.196,20.58]],\"o\":[[-23.549,-11.457],[11.458,-23.549],[23.549,11.457],[-11.458,23.549]],\"v\":[[26.355,16.515],[-16.516,26.355],[-26.354,-16.514],[16.516,-26.355]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[463.893,251.314],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":118,\"ty\":4,\"nm\":\"pyramid blast 25 Outlines\",\"parent\":29,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[50.55,52.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[211.199,662.388,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-20.579,-16.196],[16.196,-20.579],[20.579,16.196],[-16.196,20.58]],\"o\":[[-23.549,-11.457],[11.458,-23.549],[23.549,11.457],[-11.458,23.549]],\"v\":[[26.355,16.516],[-16.516,26.355],[-26.354,-16.514],[16.516,-26.354]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[213.915,661.109],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":119,\"ty\":4,\"nm\":\"pyramid blast 26 Outlines\",\"parent\":30,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,52.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[385.225,493.557,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-20.579,-16.196],[16.196,-20.579],[20.579,16.196],[-16.196,20.58]],\"o\":[[-23.549,-11.457],[11.458,-23.549],[23.549,11.457],[-11.458,23.549]],\"v\":[[26.355,16.515],[-16.516,26.355],[-26.354,-16.514],[16.516,-26.355]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[386.397,493.266],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":120,\"ty\":4,\"nm\":\"pyramid blast 27 Outlines\",\"parent\":31,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[50.55,52.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[443.667,628.622,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-20.579,-16.196],[16.196,-20.579],[20.579,16.196],[-16.196,20.58]],\"o\":[[-23.549,-11.457],[11.458,-23.549],[23.549,11.457],[-11.458,23.549]],\"v\":[[26.355,16.515],[-16.516,26.354],[-26.354,-16.515],[16.516,-26.355]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[446.262,629.072],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":121,\"ty\":4,\"nm\":\"pyramid blast 28 Outlines\",\"parent\":32,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[52.55,53.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[276.134,857.193,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-20.579,-16.196],[16.196,-20.579],[20.579,16.196],[-16.196,20.58]],\"o\":[[-23.549,-11.457],[11.458,-23.549],[23.549,11.457],[-11.458,23.549]],\"v\":[[26.354,16.516],[-16.516,26.354],[-26.355,-16.515],[16.515,-26.354]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[277.432,857.888],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":122,\"ty\":4,\"nm\":\"pyramid blast 29 Outlines\",\"parent\":33,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,52.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[763.147,519.531,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-20.579,-16.196],[16.196,-20.579],[20.579,16.196],[-16.196,20.58]],\"o\":[[-23.549,-11.457],[11.458,-23.549],[23.549,11.457],[-11.458,23.549]],\"v\":[[26.354,16.515],[-16.516,26.354],[-26.355,-16.515],[16.515,-26.355]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[765.424,519.398],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":123,\"ty\":4,\"nm\":\"pyramid blast 30 Outlines\",\"parent\":34,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[52.55,52.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[487.823,868.881,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-20.579,-16.196],[16.196,-20.579],[20.579,16.196],[-16.196,20.58]],\"o\":[[-23.549,-11.457],[11.458,-23.549],[23.549,11.457],[-11.458,23.549]],\"v\":[[26.354,16.516],[-16.516,26.354],[-26.355,-16.515],[16.515,-26.354]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[487.15,867.849],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":124,\"ty\":4,\"nm\":\"pyramid blast 32 Outlines\",\"parent\":35,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,52.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[747.563,854.596,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-20.579,-16.196],[16.196,-20.579],[20.579,16.196],[-16.196,20.58]],\"o\":[[-23.549,-11.457],[11.458,-23.549],[23.549,11.457],[-11.458,23.549]],\"v\":[[26.354,16.516],[-16.516,26.354],[-26.355,-16.515],[16.515,-26.354]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[749.793,854.215],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":125,\"ty\":4,\"nm\":\"pyramid blast 33 Outlines\",\"parent\":36,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[50.55,51.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[904.706,748.102,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-20.579,-16.196],[16.196,-20.579],[20.579,16.196],[-16.196,20.58]],\"o\":[[-23.549,-11.457],[11.458,-23.549],[23.549,11.457],[-11.458,23.549]],\"v\":[[26.355,16.516],[-16.516,26.354],[-26.354,-16.515],[16.516,-26.354]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[906.926,748.336],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":126,\"ty\":4,\"nm\":\"pyramid blast 34 Outlines\",\"parent\":37,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[52.55,53.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[517.693,261.089,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.23,-1.273],[0,0],[-0.365,-0.361],[0,0],[1.282,-0.175],[0,0],[0.231,-0.458],[0,0],[0.563,1.166],[0,0],[0.508,0.079],[0,0],[-0.934,0.896],[0,0],[0.082,0.507],[0,0],[-1.14,-0.612],[0,0],[-0.457,0.235],[0,0]],\"o\":[[0,0],[-0.092,0.505],[0,0],[0.918,0.911],[0,0],[-0.509,0.069],[0,0],[-0.583,1.155],[0,0],[-0.224,-0.462],[0,0],[-1.279,-0.197],[0,0],[0.371,-0.356],[0,0],[-0.208,-1.277],[0,0],[0.453,0.243],[0,0],[1.151,-0.593]],\"v\":[[12.356,-15.902],[10.511,-5.681],[10.948,-4.296],[18.323,3.019],[17.433,5.673],[7.143,7.079],[5.961,7.922],[1.284,17.196],[-1.516,17.171],[-6.031,7.818],[-7.199,6.954],[-17.464,5.371],[-18.306,2.701],[-10.806,-4.483],[-10.345,-5.861],[-12.012,-16.113],[-9.733,-17.738],[-0.583,-12.827],[0.87,-12.814],[10.104,-17.566]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[517.633,260.345],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":127,\"ty\":4,\"nm\":\"pyramid blast 35 Outlines\",\"parent\":38,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[52.55,54.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[446.264,297.453,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.23,-1.273],[0,0],[-0.365,-0.361],[0,0],[1.282,-0.175],[0,0],[0.231,-0.458],[0,0],[0.563,1.166],[0,0],[0.508,0.079],[0,0],[-0.934,0.896],[0,0],[0.082,0.507],[0,0],[-1.14,-0.612],[0,0],[-0.457,0.235],[0,0]],\"o\":[[0,0],[-0.092,0.505],[0,0],[0.918,0.911],[0,0],[-0.509,0.069],[0,0],[-0.583,1.155],[0,0],[-0.224,-0.462],[0,0],[-1.279,-0.197],[0,0],[0.371,-0.356],[0,0],[-0.208,-1.277],[0,0],[0.453,0.243],[0,0],[1.151,-0.593]],\"v\":[[12.356,-15.902],[10.512,-5.681],[10.949,-4.296],[18.323,3.019],[17.434,5.673],[7.144,7.079],[5.961,7.922],[1.284,17.196],[-1.516,17.171],[-6.031,7.818],[-7.199,6.954],[-17.464,5.371],[-18.306,2.701],[-10.806,-4.483],[-10.345,-5.861],[-12.012,-16.113],[-9.733,-17.738],[-0.582,-12.827],[0.871,-12.814],[10.105,-17.566]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[447.242,297.962],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":128,\"ty\":4,\"nm\":\"pyramid blast 36 Outlines\",\"parent\":39,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[52.55,53.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[372.238,383.167,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.23,-1.273],[0,0],[-0.365,-0.361],[0,0],[1.282,-0.175],[0,0],[0.231,-0.458],[0,0],[0.563,1.165],[0,0],[0.508,0.079],[0,0],[-0.934,0.896],[0,0],[0.082,0.507],[0,0],[-1.14,-0.612],[0,0],[-0.457,0.235],[0,0]],\"o\":[[0,0],[-0.092,0.505],[0,0],[0.918,0.911],[0,0],[-0.509,0.069],[0,0],[-0.583,1.156],[0,0],[-0.224,-0.462],[0,0],[-1.279,-0.197],[0,0],[0.371,-0.356],[0,0],[-0.208,-1.277],[0,0],[0.453,0.243],[0,0],[1.151,-0.593]],\"v\":[[12.356,-15.902],[10.512,-5.681],[10.949,-4.296],[18.323,3.019],[17.434,5.673],[7.144,7.079],[5.961,7.922],[1.284,17.194],[-1.516,17.171],[-6.031,7.818],[-7.199,6.954],[-17.464,5.371],[-18.306,2.701],[-10.806,-4.483],[-10.345,-5.861],[-12.012,-16.113],[-9.733,-17.738],[-0.582,-12.827],[0.871,-12.814],[10.105,-17.566]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[373.148,383.664],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":129,\"ty\":4,\"nm\":\"pyramid blast 37 Outlines\",\"parent\":40,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,53.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[713.797,431.219,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.23,-1.273],[0,0],[-0.365,-0.361],[0,0],[1.282,-0.175],[0,0],[0.231,-0.458],[0,0],[0.563,1.166],[0,0],[0.508,0.079],[0,0],[-0.934,0.896],[0,0],[0.082,0.507],[0,0],[-1.14,-0.612],[0,0],[-0.457,0.235],[0,0]],\"o\":[[0,0],[-0.092,0.505],[0,0],[0.918,0.911],[0,0],[-0.509,0.069],[0,0],[-0.583,1.155],[0,0],[-0.224,-0.462],[0,0],[-1.279,-0.197],[0,0],[0.371,-0.356],[0,0],[-0.208,-1.277],[0,0],[0.453,0.243],[0,0],[1.151,-0.593]],\"v\":[[12.356,-15.902],[10.511,-5.681],[10.948,-4.296],[18.323,3.019],[17.433,5.673],[7.143,7.079],[5.961,7.922],[1.284,17.196],[-1.516,17.171],[-6.031,7.818],[-7.2,6.954],[-17.464,5.371],[-18.307,2.701],[-10.807,-4.483],[-10.346,-5.861],[-12.013,-16.113],[-9.734,-17.738],[-0.583,-12.827],[0.87,-12.814],[10.104,-17.566]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[714.198,430.837],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":130,\"ty\":4,\"nm\":\"pyramid blast 38 Outlines\",\"parent\":41,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[52.55,52.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[496.914,551.998,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.23,-1.273],[0,0],[-0.365,-0.361],[0,0],[1.282,-0.175],[0,0],[0.231,-0.458],[0,0],[0.563,1.166],[0,0],[0.508,0.079],[0,0],[-0.934,0.896],[0,0],[0.082,0.507],[0,0],[-1.14,-0.612],[0,0],[-0.457,0.235],[0,0]],\"o\":[[0,0],[-0.092,0.505],[0,0],[0.918,0.911],[0,0],[-0.509,0.069],[0,0],[-0.583,1.155],[0,0],[-0.224,-0.462],[0,0],[-1.279,-0.197],[0,0],[0.371,-0.356],[0,0],[-0.208,-1.277],[0,0],[0.453,0.243],[0,0],[1.151,-0.593]],\"v\":[[12.356,-15.902],[10.512,-5.681],[10.949,-4.296],[18.323,3.018],[17.433,5.673],[7.144,7.078],[5.961,7.922],[1.284,17.195],[-1.516,17.17],[-6.031,7.818],[-7.199,6.953],[-17.464,5.371],[-18.306,2.701],[-10.806,-4.484],[-10.345,-5.862],[-12.012,-16.113],[-9.733,-17.739],[-0.582,-12.827],[0.871,-12.814],[10.105,-17.567]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[497.679,553.878],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":131,\"ty\":4,\"nm\":\"pyramid blast 39 Outlines\",\"parent\":42,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,51.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[289.121,518.232,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.23,-1.273],[0,0],[-0.365,-0.361],[0,0],[1.282,-0.175],[0,0],[0.231,-0.458],[0,0],[0.563,1.166],[0,0],[0.508,0.079],[0,0],[-0.934,0.896],[0,0],[0.082,0.507],[0,0],[-1.14,-0.612],[0,0],[-0.457,0.235],[0,0]],\"o\":[[0,0],[-0.092,0.505],[0,0],[0.918,0.911],[0,0],[-0.509,0.069],[0,0],[-0.583,1.155],[0,0],[-0.224,-0.462],[0,0],[-1.279,-0.197],[0,0],[0.371,-0.356],[0,0],[-0.208,-1.277],[0,0],[0.453,0.243],[0,0],[1.151,-0.593]],\"v\":[[12.355,-15.901],[10.511,-5.68],[10.948,-4.295],[18.322,3.019],[17.433,5.674],[7.143,7.079],[5.96,7.922],[1.283,17.196],[-1.517,17.171],[-6.032,7.818],[-7.2,6.954],[-17.465,5.372],[-18.307,2.701],[-10.807,-4.483],[-10.346,-5.861],[-12.013,-16.112],[-9.734,-17.738],[-0.583,-12.826],[0.87,-12.813],[10.104,-17.566]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[290.309,519.406],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":132,\"ty\":4,\"nm\":\"pyramid blast 40 Outlines\",\"parent\":43,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[52.55,54.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[580.031,636.414,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.23,-1.273],[0,0],[-0.365,-0.361],[0,0],[1.282,-0.175],[0,0],[0.231,-0.458],[0,0],[0.563,1.166],[0,0],[0.508,0.079],[0,0],[-0.934,0.896],[0,0],[0.082,0.507],[0,0],[-1.14,-0.612],[0,0],[-0.457,0.235],[0,0]],\"o\":[[0,0],[-0.092,0.505],[0,0],[0.918,0.911],[0,0],[-0.509,0.069],[0,0],[-0.583,1.155],[0,0],[-0.224,-0.462],[0,0],[-1.279,-0.197],[0,0],[0.371,-0.356],[0,0],[-0.208,-1.277],[0,0],[0.453,0.243],[0,0],[1.151,-0.593]],\"v\":[[12.356,-15.902],[10.511,-5.68],[10.948,-4.295],[18.323,3.018],[17.433,5.674],[7.143,7.078],[5.961,7.922],[1.284,17.195],[-1.516,17.17],[-6.031,7.818],[-7.2,6.953],[-17.464,5.372],[-18.307,2.701],[-10.807,-4.483],[-10.346,-5.862],[-12.013,-16.112],[-9.734,-17.738],[-0.583,-12.826],[0.87,-12.814],[10.104,-17.566]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[580.757,635.779],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":133,\"ty\":4,\"nm\":\"pyramid blast 41 Outlines\",\"parent\":44,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[52.55,54.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[648.862,637.713,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.23,-1.273],[0,0],[-0.365,-0.361],[0,0],[1.282,-0.175],[0,0],[0.231,-0.458],[0,0],[0.563,1.166],[0,0],[0.508,0.079],[0,0],[-0.934,0.896],[0,0],[0.082,0.507],[0,0],[-1.14,-0.612],[0,0],[-0.457,0.235],[0,0]],\"o\":[[0,0],[-0.092,0.505],[0,0],[0.918,0.911],[0,0],[-0.509,0.069],[0,0],[-0.583,1.155],[0,0],[-0.224,-0.462],[0,0],[-1.279,-0.197],[0,0],[0.371,-0.356],[0,0],[-0.208,-1.277],[0,0],[0.453,0.243],[0,0],[1.151,-0.593]],\"v\":[[12.356,-15.902],[10.511,-5.68],[10.948,-4.295],[18.323,3.018],[17.433,5.674],[7.143,7.078],[5.961,7.922],[1.284,17.195],[-1.516,17.17],[-6.031,7.818],[-7.2,6.953],[-17.464,5.372],[-18.307,2.701],[-10.807,-4.483],[-10.346,-5.862],[-12.013,-16.112],[-9.734,-17.738],[-0.583,-12.826],[0.87,-12.814],[10.104,-17.566]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[648.419,635.779],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":134,\"ty\":4,\"nm\":\"pyramid blast 42 Outlines\",\"parent\":45,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,52.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[772.238,635.115,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.23,-1.273],[0,0],[-0.365,-0.361],[0,0],[1.282,-0.175],[0,0],[0.231,-0.458],[0,0],[0.563,1.166],[0,0],[0.508,0.079],[0,0],[-0.934,0.896],[0,0],[0.082,0.507],[0,0],[-1.14,-0.612],[0,0],[-0.457,0.235],[0,0]],\"o\":[[0,0],[-0.092,0.505],[0,0],[0.918,0.911],[0,0],[-0.509,0.069],[0,0],[-0.583,1.155],[0,0],[-0.224,-0.462],[0,0],[-1.279,-0.197],[0,0],[0.371,-0.356],[0,0],[-0.208,-1.277],[0,0],[0.453,0.243],[0,0],[1.151,-0.593]],\"v\":[[12.356,-15.902],[10.511,-5.68],[10.948,-4.295],[18.323,3.018],[17.433,5.674],[7.143,7.078],[5.961,7.922],[1.284,17.195],[-1.516,17.17],[-6.031,7.818],[-7.2,6.953],[-17.464,5.372],[-18.307,2.701],[-10.807,-4.483],[-10.346,-5.862],[-12.013,-16.112],[-9.734,-17.738],[-0.583,-12.826],[0.87,-12.814],[10.104,-17.566]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[773.927,635.779],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":135,\"ty\":4,\"nm\":\"pyramid blast 43 Outlines\",\"parent\":46,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,55.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[817.693,601.349,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.23,-1.273],[0,0],[-0.365,-0.361],[0,0],[1.282,-0.175],[0,0],[0.231,-0.458],[0,0],[0.563,1.166],[0,0],[0.508,0.079],[0,0],[-0.934,0.896],[0,0],[0.082,0.507],[0,0],[-1.14,-0.612],[0,0],[-0.457,0.235],[0,0]],\"o\":[[0,0],[-0.092,0.505],[0,0],[0.918,0.911],[0,0],[-0.509,0.069],[0,0],[-0.583,1.155],[0,0],[-0.224,-0.462],[0,0],[-1.279,-0.197],[0,0],[0.371,-0.356],[0,0],[-0.208,-1.277],[0,0],[0.453,0.243],[0,0],[1.151,-0.593]],\"v\":[[12.356,-15.902],[10.511,-5.68],[10.948,-4.295],[18.323,3.018],[17.433,5.674],[7.143,7.078],[5.961,7.922],[1.284,17.195],[-1.516,17.17],[-6.031,7.818],[-7.2,6.953],[-17.464,5.372],[-18.307,2.701],[-10.807,-4.483],[-10.346,-5.862],[-12.013,-16.112],[-9.734,-17.738],[-0.583,-12.826],[0.87,-12.814],[10.104,-17.566]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[818.479,600.601],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":136,\"ty\":4,\"nm\":\"pyramid blast 44 Outlines\",\"parent\":47,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,52.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[172.238,754.596,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.23,-1.273],[0,0],[-0.365,-0.361],[0,0],[1.282,-0.175],[0,0],[0.231,-0.458],[0,0],[0.563,1.166],[0,0],[0.508,0.079],[0,0],[-0.934,0.896],[0,0],[0.082,0.507],[0,0],[-1.14,-0.612],[0,0],[-0.457,0.235],[0,0]],\"o\":[[0,0],[-0.092,0.505],[0,0],[0.918,0.911],[0,0],[-0.509,0.069],[0,0],[-0.583,1.155],[0,0],[-0.224,-0.462],[0,0],[-1.279,-0.197],[0,0],[0.371,-0.356],[0,0],[-0.208,-1.277],[0,0],[0.453,0.243],[0,0],[1.151,-0.593]],\"v\":[[12.355,-15.901],[10.511,-5.68],[10.948,-4.295],[18.322,3.019],[17.433,5.674],[7.143,7.078],[5.96,7.922],[1.283,17.196],[-1.517,17.171],[-6.032,7.818],[-7.2,6.953],[-17.465,5.372],[-18.307,2.701],[-10.807,-4.483],[-10.346,-5.861],[-12.013,-16.112],[-9.734,-17.738],[-0.583,-12.826],[0.87,-12.813],[10.104,-17.566]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[172.378,755.112],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":137,\"ty\":4,\"nm\":\"pyramid blast 45 Outlines\",\"parent\":48,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,53.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[198.212,863.687,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.23,-1.273],[0,0],[-0.365,-0.361],[0,0],[1.282,-0.175],[0,0],[0.231,-0.458],[0,0],[0.563,1.166],[0,0],[0.508,0.079],[0,0],[-0.934,0.896],[0,0],[0.082,0.507],[0,0],[-1.14,-0.612],[0,0],[-0.457,0.235],[0,0]],\"o\":[[0,0],[-0.092,0.505],[0,0],[0.918,0.911],[0,0],[-0.509,0.069],[0,0],[-0.583,1.155],[0,0],[-0.224,-0.462],[0,0],[-1.279,-0.197],[0,0],[0.371,-0.356],[0,0],[-0.208,-1.277],[0,0],[0.453,0.243],[0,0],[1.151,-0.593]],\"v\":[[12.356,-15.901],[10.512,-5.68],[10.949,-4.295],[18.323,3.019],[17.434,5.674],[7.144,7.078],[5.961,7.922],[1.284,17.195],[-1.516,17.171],[-6.031,7.818],[-7.199,6.953],[-17.464,5.372],[-18.306,2.701],[-10.806,-4.483],[-10.345,-5.861],[-12.012,-16.112],[-9.733,-17.738],[-0.582,-12.826],[0.871,-12.813],[10.105,-17.566]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[199.332,863.291],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":138,\"ty\":4,\"nm\":\"pyramid blast 46 Outlines\",\"parent\":49,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[50.55,53.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[403.407,866.284,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.23,-1.273],[0,0],[-0.365,-0.361],[0,0],[1.282,-0.175],[0,0],[0.231,-0.458],[0,0],[0.563,1.166],[0,0],[0.508,0.079],[0,0],[-0.934,0.896],[0,0],[0.082,0.507],[0,0],[-1.14,-0.612],[0,0],[-0.457,0.235],[0,0]],\"o\":[[0,0],[-0.092,0.505],[0,0],[0.918,0.911],[0,0],[-0.509,0.069],[0,0],[-0.583,1.155],[0,0],[-0.224,-0.462],[0,0],[-1.279,-0.197],[0,0],[0.371,-0.356],[0,0],[-0.208,-1.277],[0,0],[0.453,0.243],[0,0],[1.151,-0.593]],\"v\":[[12.355,-15.901],[10.511,-5.68],[10.948,-4.295],[18.322,3.019],[17.433,5.674],[7.143,7.079],[5.96,7.922],[1.283,17.196],[-1.517,17.171],[-6.032,7.818],[-7.2,6.954],[-17.465,5.372],[-18.307,2.701],[-10.807,-4.483],[-10.346,-5.861],[-12.013,-16.112],[-9.734,-17.738],[-0.583,-12.826],[0.87,-12.813],[10.104,-17.566]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[404.462,866.73],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":139,\"ty\":4,\"nm\":\"pyramid blast 47 Outlines\",\"parent\":50,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,54.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[560.55,868.881,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.23,-1.273],[0,0],[-0.365,-0.361],[0,0],[1.282,-0.175],[0,0],[0.231,-0.458],[0,0],[0.563,1.166],[0,0],[0.508,0.079],[0,0],[-0.934,0.896],[0,0],[0.082,0.507],[0,0],[-1.14,-0.612],[0,0],[-0.457,0.235],[0,0]],\"o\":[[0,0],[-0.092,0.505],[0,0],[0.918,0.911],[0,0],[-0.509,0.069],[0,0],[-0.583,1.155],[0,0],[-0.224,-0.462],[0,0],[-1.279,-0.197],[0,0],[0.371,-0.356],[0,0],[-0.208,-1.277],[0,0],[0.453,0.243],[0,0],[1.151,-0.593]],\"v\":[[12.356,-15.901],[10.511,-5.68],[10.948,-4.295],[18.323,3.019],[17.433,5.674],[7.143,7.078],[5.961,7.922],[1.284,17.195],[-1.516,17.171],[-6.031,7.818],[-7.2,6.953],[-17.464,5.372],[-18.307,2.701],[-10.807,-4.483],[-10.346,-5.861],[-12.013,-16.112],[-9.734,-17.738],[-0.583,-12.826],[0.87,-12.813],[10.104,-17.566]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[561.948,868.918],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":140,\"ty\":4,\"nm\":\"pyramid blast 48 Outlines\",\"parent\":51,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[52.55,52.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[818.992,859.791,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.23,-1.273],[0,0],[-0.365,-0.361],[0,0],[1.282,-0.175],[0,0],[0.231,-0.458],[0,0],[0.563,1.166],[0,0],[0.508,0.079],[0,0],[-0.934,0.896],[0,0],[0.082,0.507],[0,0],[-1.14,-0.612],[0,0],[-0.457,0.235],[0,0]],\"o\":[[0,0],[-0.092,0.505],[0,0],[0.918,0.911],[0,0],[-0.509,0.069],[0,0],[-0.583,1.155],[0,0],[-0.224,-0.462],[0,0],[-1.279,-0.197],[0,0],[0.371,-0.356],[0,0],[-0.208,-1.277],[0,0],[0.453,0.243],[0,0],[1.151,-0.593]],\"v\":[[12.356,-15.901],[10.511,-5.68],[10.948,-4.295],[18.323,3.018],[17.433,5.674],[7.143,7.078],[5.961,7.922],[1.284,17.195],[-1.516,17.17],[-6.031,7.818],[-7.2,6.953],[-17.464,5.372],[-18.307,2.701],[-10.807,-4.483],[-10.346,-5.862],[-12.013,-16.112],[-9.734,-17.738],[-0.583,-12.826],[0.87,-12.813],[10.104,-17.566]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[818.457,860.975],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":141,\"ty\":4,\"nm\":\"pyramid blast 49 Outlines\",\"parent\":52,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[53.55,54.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[951.459,849.401,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.23,-1.273],[0,0],[-0.365,-0.361],[0,0],[1.282,-0.175],[0,0],[0.231,-0.458],[0,0],[0.563,1.166],[0,0],[0.508,0.079],[0,0],[-0.934,0.896],[0,0],[0.082,0.507],[0,0],[-1.14,-0.612],[0,0],[-0.457,0.235],[0,0]],\"o\":[[0,0],[-0.092,0.505],[0,0],[0.918,0.911],[0,0],[-0.509,0.069],[0,0],[-0.583,1.155],[0,0],[-0.224,-0.462],[0,0],[-1.279,-0.197],[0,0],[0.371,-0.356],[0,0],[-0.208,-1.277],[0,0],[0.453,0.243],[0,0],[1.151,-0.593]],\"v\":[[12.356,-15.901],[10.511,-5.68],[10.948,-4.295],[18.323,3.019],[17.433,5.674],[7.143,7.078],[5.961,7.922],[1.284,17.195],[-1.516,17.171],[-6.031,7.818],[-7.2,6.953],[-17.464,5.372],[-18.307,2.701],[-10.807,-4.483],[-10.346,-5.861],[-12.013,-16.112],[-9.734,-17.738],[-0.583,-12.826],[0.87,-12.813],[10.104,-17.566]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[950.079,848.572],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":142,\"ty\":4,\"nm\":\"pyramid blast 50 Outlines\",\"parent\":53,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[50.55,51.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[509.901,401.349,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-4.33],[4.329,0],[0,4.33],[-4.33,0]],\"o\":[[0,4.33],[-4.33,0],[0,-4.33],[4.329,0]],\"v\":[[7.84,0],[0,7.839],[-7.84,0],[0,-7.839]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.945098099054,0.341176470588,0.18431372549,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[511.612,400.358],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":143,\"ty\":4,\"nm\":\"pyramid blast 51 Outlines\",\"parent\":54,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[50.55,53.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[473.537,390.959,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-17.907,-14.093],[14.093,-17.907],[17.908,14.093],[-14.093,17.907]],\"o\":[[-20.491,-9.969],[9.97,-20.492],[20.492,9.969],[-9.969,20.491]],\"v\":[[22.932,14.37],[-14.371,22.932],[-22.933,-14.37],[14.37,-22.932]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.945098099054,0.341176470588,0.18431372549,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[475.951,388.546],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":144,\"ty\":4,\"nm\":\"pyramid blast 52 Outlines\",\"parent\":55,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[52.55,52.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[478.732,683.167,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.187,-1.034],[0,0],[-0.297,-0.293],[0,0],[1.041,-0.142],[0,0],[0.188,-0.373],[0,0],[0.456,0.946],[0,0],[0.412,0.063],[0,0],[-0.758,0.726],[0,0],[0.067,0.412],[0,0],[-0.925,-0.497],[0,0],[-0.371,0.191],[0,0]],\"o\":[[0,0],[-0.074,0.41],[0,0],[0.746,0.74],[0,0],[-0.413,0.056],[0,0],[-0.473,0.938],[0,0],[-0.181,-0.375],[0,0],[-1.038,-0.16],[0,0],[0.301,-0.288],[0,0],[-0.168,-1.036],[0,0],[0.368,0.198],[0,0],[0.934,-0.481]],\"v\":[[10.03,-12.908],[8.533,-4.611],[8.887,-3.487],[14.872,2.45],[14.151,4.606],[5.798,5.746],[4.839,6.431],[1.042,13.958],[-1.23,13.938],[-4.897,6.346],[-5.845,5.645],[-14.177,4.36],[-14.861,2.193],[-8.772,-3.64],[-8.398,-4.758],[-9.751,-13.08],[-7.901,-14.399],[-0.474,-10.412],[0.706,-10.402],[8.202,-14.26]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[478.381,682.623],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":145,\"ty\":4,\"nm\":\"pyramid blast 53 Outlines\",\"parent\":56,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,53.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[587.823,474.076,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-17.907,-14.093],[14.093,-17.907],[17.908,14.093],[-14.093,17.907]],\"o\":[[-20.491,-9.969],[9.97,-20.492],[20.492,9.969],[-9.969,20.491]],\"v\":[[22.933,14.37],[-14.37,22.932],[-22.932,-14.37],[14.371,-22.932]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.945098099054,0.341176470588,0.18431372549,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[589.846,471.107],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":146,\"ty\":4,\"nm\":\"pyramid blast 54 Outlines\",\"parent\":57,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[53.55,52.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[518.992,485.765,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-17.907,-14.093],[14.093,-17.907],[17.907,14.093],[-14.093,17.907]],\"o\":[[-20.491,-9.969],[9.97,-20.492],[20.492,9.969],[-9.969,20.491]],\"v\":[[22.932,14.37],[-14.371,22.932],[-22.933,-14.37],[14.37,-22.932]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.945098099054,0.341176470588,0.18431372549,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[518.715,485.871],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":147,\"ty\":4,\"nm\":\"pyramid blast 55 Outlines\",\"parent\":58,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[52.55,52.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[380.031,685.765,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-17.907,-14.093],[14.093,-17.907],[17.907,14.093],[-14.093,17.907]],\"o\":[[-20.491,-9.969],[9.97,-20.492],[20.492,9.969],[-9.969,20.491]],\"v\":[[22.933,14.37],[-14.37,22.932],[-22.932,-14.371],[14.371,-22.932]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[379.715,683.871],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":148,\"ty\":4,\"nm\":\"pyramid blast 56 Outlines\",\"parent\":59,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[50.55,52.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[465.745,796.154,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-17.907,-14.093],[14.093,-17.907],[17.907,14.093],[-14.093,17.907]],\"o\":[[-20.491,-9.969],[9.97,-20.491],[20.492,9.969],[-9.969,20.491]],\"v\":[[22.933,14.37],[-14.37,22.932],[-22.932,-14.37],[14.371,-22.932]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.945098099054,0.341176470588,0.18431372549,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[467.422,795.311],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":149,\"ty\":4,\"nm\":\"pyramid blast 57 Outlines\",\"parent\":60,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,52.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[578.732,742.907,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-17.907,-14.093],[14.093,-17.907],[17.907,14.093],[-14.093,17.907]],\"o\":[[-20.491,-9.969],[9.97,-20.492],[20.492,9.969],[-9.969,20.491]],\"v\":[[22.932,14.37],[-14.371,22.932],[-22.933,-14.37],[14.37,-22.932]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[579.647,742.363],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":150,\"ty\":4,\"nm\":\"pyramid blast 58 Outlines\",\"parent\":61,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[50.55,52.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[602.108,679.271,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.187,-1.034],[0,0],[-0.297,-0.294],[0,0],[1.041,-0.142],[0,0],[0.188,-0.373],[0,0],[0.456,0.946],[0,0],[0.412,0.063],[0,0],[-0.758,0.726],[0,0],[0.067,0.412],[0,0],[-0.926,-0.497],[0,0],[-0.371,0.191],[0,0]],\"o\":[[0,0],[-0.074,0.41],[0,0],[0.746,0.74],[0,0],[-0.413,0.056],[0,0],[-0.473,0.938],[0,0],[-0.181,-0.375],[0,0],[-1.038,-0.16],[0,0],[0.301,-0.288],[0,0],[-0.168,-1.037],[0,0],[0.368,0.198],[0,0],[0.934,-0.481]],\"v\":[[10.03,-12.908],[8.533,-4.611],[8.888,-3.486],[14.872,2.45],[14.151,4.606],[5.799,5.746],[4.839,6.431],[1.042,13.958],[-1.23,13.938],[-4.896,6.346],[-5.844,5.645],[-14.177,4.36],[-14.86,2.193],[-8.772,-3.64],[-8.398,-4.758],[-9.751,-13.079],[-7.901,-14.399],[-0.474,-10.412],[0.706,-10.402],[8.203,-14.26]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[603.032,679.2],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":151,\"ty\":4,\"nm\":\"pyramid blast 59 Outlines\",\"parent\":62,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[50.55,51.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[681.329,677.972,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.187,-1.034],[0,0],[-0.297,-0.294],[0,0],[1.041,-0.142],[0,0],[0.188,-0.373],[0,0],[0.456,0.946],[0,0],[0.412,0.063],[0,0],[-0.758,0.726],[0,0],[0.067,0.412],[0,0],[-0.925,-0.497],[0,0],[-0.371,0.191],[0,0]],\"o\":[[0,0],[-0.074,0.41],[0,0],[0.746,0.74],[0,0],[-0.413,0.056],[0,0],[-0.473,0.938],[0,0],[-0.181,-0.375],[0,0],[-1.038,-0.16],[0,0],[0.301,-0.288],[0,0],[-0.168,-1.037],[0,0],[0.368,0.198],[0,0],[0.934,-0.481]],\"v\":[[10.03,-12.908],[8.533,-4.611],[8.888,-3.486],[14.872,2.45],[14.151,4.606],[5.799,5.746],[4.839,6.431],[1.042,13.958],[-1.23,13.938],[-4.896,6.346],[-5.844,5.645],[-14.177,4.36],[-14.86,2.193],[-8.772,-3.64],[-8.398,-4.758],[-9.751,-13.079],[-7.901,-14.399],[-0.474,-10.412],[0.706,-10.402],[8.203,-14.26]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[682.116,679.2],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":152,\"ty\":4,\"nm\":\"pyramid blast 60 Outlines\",\"parent\":63,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[52.55,52.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[399.511,749.401,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.187,-1.034],[0,0],[-0.297,-0.294],[0,0],[1.041,-0.142],[0,0],[0.188,-0.373],[0,0],[0.456,0.946],[0,0],[0.412,0.063],[0,0],[-0.758,0.726],[0,0],[0.067,0.412],[0,0],[-0.925,-0.497],[0,0],[-0.371,0.191],[0,0]],\"o\":[[0,0],[-0.074,0.41],[0,0],[0.746,0.74],[0,0],[-0.413,0.056],[0,0],[-0.473,0.938],[0,0],[-0.181,-0.375],[0,0],[-1.038,-0.16],[0,0],[0.301,-0.288],[0,0],[-0.168,-1.037],[0,0],[0.368,0.198],[0,0],[0.934,-0.481]],\"v\":[[10.03,-12.908],[8.533,-4.611],[8.887,-3.486],[14.872,2.45],[14.151,4.606],[5.798,5.746],[4.839,6.431],[1.042,13.958],[-1.23,13.938],[-4.897,6.346],[-5.845,5.645],[-14.177,4.36],[-14.861,2.193],[-8.772,-3.64],[-8.398,-4.758],[-9.751,-13.079],[-7.901,-14.399],[-0.474,-10.412],[0.706,-10.402],[8.202,-14.26]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[400.336,750.343],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":153,\"ty\":4,\"nm\":\"pyramid blast 61 Outlines\",\"parent\":64,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,50.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[476.134,751.998,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.187,-1.034],[0,0],[-0.297,-0.293],[0,0],[1.041,-0.142],[0,0],[0.188,-0.373],[0,0],[0.456,0.946],[0,0],[0.412,0.063],[0,0],[-0.758,0.726],[0,0],[0.067,0.412],[0,0],[-0.925,-0.497],[0,0],[-0.371,0.191],[0,0]],\"o\":[[0,0],[-0.074,0.41],[0,0],[0.746,0.74],[0,0],[-0.413,0.056],[0,0],[-0.473,0.938],[0,0],[-0.181,-0.375],[0,0],[-1.038,-0.16],[0,0],[0.301,-0.288],[0,0],[-0.168,-1.036],[0,0],[0.368,0.198],[0,0],[0.934,-0.481]],\"v\":[[10.03,-12.908],[8.533,-4.611],[8.887,-3.487],[14.872,2.45],[14.151,4.606],[5.798,5.746],[4.839,6.431],[1.042,13.958],[-1.23,13.938],[-4.897,6.346],[-5.845,5.645],[-14.177,4.36],[-14.861,2.193],[-8.772,-3.64],[-8.398,-4.758],[-9.751,-13.08],[-7.901,-14.399],[-0.474,-10.412],[0.706,-10.402],[8.202,-14.26]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[476.717,753.82],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":154,\"ty\":4,\"nm\":\"pyramid blast 62 Outlines\",\"parent\":65,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,52.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[655.355,753.297,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.187,-1.034],[0,0],[-0.297,-0.293],[0,0],[1.041,-0.142],[0,0],[0.188,-0.373],[0,0],[0.456,0.946],[0,0],[0.412,0.063],[0,0],[-0.758,0.726],[0,0],[0.067,0.412],[0,0],[-0.926,-0.497],[0,0],[-0.371,0.191],[0,0]],\"o\":[[0,0],[-0.074,0.41],[0,0],[0.746,0.74],[0,0],[-0.413,0.056],[0,0],[-0.473,0.938],[0,0],[-0.181,-0.375],[0,0],[-1.038,-0.16],[0,0],[0.301,-0.288],[0,0],[-0.168,-1.036],[0,0],[0.368,0.198],[0,0],[0.934,-0.481]],\"v\":[[10.029,-12.908],[8.532,-4.611],[8.887,-3.487],[14.872,2.45],[14.151,4.606],[5.798,5.746],[4.838,6.431],[1.041,13.958],[-1.231,13.938],[-4.897,6.346],[-5.845,5.645],[-14.177,4.36],[-14.861,2.193],[-8.773,-3.64],[-8.399,-4.758],[-9.752,-13.08],[-7.901,-14.399],[-0.474,-10.412],[0.706,-10.402],[8.202,-14.26]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[656.717,753.82],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":155,\"ty\":4,\"nm\":\"pyramid blast 63 Outlines\",\"parent\":66,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[50.55,53.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[541.069,807.842,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.187,-1.034],[0,0],[-0.297,-0.293],[0,0],[1.041,-0.142],[0,0],[0.188,-0.373],[0,0],[0.456,0.946],[0,0],[0.412,0.063],[0,0],[-0.758,0.726],[0,0],[0.067,0.412],[0,0],[-0.926,-0.497],[0,0],[-0.371,0.191],[0,0]],\"o\":[[0,0],[-0.074,0.41],[0,0],[0.746,0.74],[0,0],[-0.413,0.056],[0,0],[-0.473,0.938],[0,0],[-0.181,-0.375],[0,0],[-1.038,-0.16],[0,0],[0.301,-0.288],[0,0],[-0.168,-1.036],[0,0],[0.368,0.198],[0,0],[0.934,-0.481]],\"v\":[[10.029,-12.908],[8.532,-4.611],[8.887,-3.487],[14.872,2.45],[14.151,4.606],[5.798,5.746],[4.838,6.431],[1.041,13.958],[-1.231,13.938],[-4.897,6.346],[-5.845,5.645],[-14.177,4.36],[-14.861,2.193],[-8.773,-3.64],[-8.399,-4.758],[-9.752,-13.08],[-7.901,-14.399],[-0.474,-10.412],[0.706,-10.402],[8.202,-14.26]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.945098099054,0.341176470588,0.18431372549,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[542.717,806.82],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":156,\"ty\":4,\"nm\":\"pyramid blast 64 Outlines\",\"parent\":67,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[50.55,51.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[543.667,413.037,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.187,-1.034],[0,0],[-0.297,-0.294],[0,0],[1.041,-0.142],[0,0],[0.188,-0.373],[0,0],[0.456,0.946],[0,0],[0.412,0.063],[0,0],[-0.758,0.726],[0,0],[0.067,0.412],[0,0],[-0.926,-0.497],[0,0],[-0.371,0.191],[0,0]],\"o\":[[0,0],[-0.074,0.41],[0,0],[0.746,0.74],[0,0],[-0.413,0.056],[0,0],[-0.473,0.938],[0,0],[-0.181,-0.375],[0,0],[-1.038,-0.16],[0,0],[0.301,-0.288],[0,0],[-0.168,-1.036],[0,0],[0.368,0.198],[0,0],[0.934,-0.481]],\"v\":[[10.029,-12.908],[8.532,-4.611],[8.887,-3.486],[14.872,2.45],[14.151,4.606],[5.798,5.746],[4.838,6.431],[1.041,13.958],[-1.231,13.938],[-4.897,6.346],[-5.845,5.645],[-14.177,4.36],[-14.861,2.193],[-8.773,-3.64],[-8.399,-4.758],[-9.752,-13.08],[-7.901,-14.399],[-0.474,-10.412],[0.706,-10.402],[8.202,-14.26]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.945098099054,0.341176470588,0.18431372549,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[546.717,412.82],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":157,\"ty\":4,\"nm\":\"pyramid blast 65 Outlines\",\"parent\":68,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[52.55,50.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[567.043,332.518,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.187,-1.034],[0,0],[-0.297,-0.294],[0,0],[1.041,-0.142],[0,0],[0.188,-0.373],[0,0],[0.456,0.946],[0,0],[0.412,0.063],[0,0],[-0.758,0.726],[0,0],[0.067,0.412],[0,0],[-0.926,-0.497],[0,0],[-0.371,0.191],[0,0]],\"o\":[[0,0],[-0.074,0.41],[0,0],[0.746,0.74],[0,0],[-0.413,0.056],[0,0],[-0.473,0.938],[0,0],[-0.181,-0.375],[0,0],[-1.038,-0.16],[0,0],[0.301,-0.288],[0,0],[-0.168,-1.036],[0,0],[0.368,0.198],[0,0],[0.934,-0.481]],\"v\":[[10.029,-12.908],[8.532,-4.611],[8.887,-3.486],[14.872,2.45],[14.151,4.606],[5.798,5.746],[4.838,6.431],[1.041,13.958],[-1.231,13.938],[-4.897,6.346],[-5.845,5.645],[-14.177,4.36],[-14.861,2.193],[-8.773,-3.64],[-8.399,-4.758],[-9.752,-13.08],[-7.901,-14.399],[-0.474,-10.412],[0.706,-10.402],[8.202,-14.26]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.945098099054,0.341176470588,0.18431372549,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[567.717,334.82],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":158,\"ty\":4,\"nm\":\"pyramid blast 66 Outlines\",\"parent\":69,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[50.55,52.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[500.81,342.907,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.187,-1.034],[0,0],[-0.297,-0.294],[0,0],[1.041,-0.142],[0,0],[0.188,-0.373],[0,0],[0.456,0.946],[0,0],[0.412,0.063],[0,0],[-0.758,0.726],[0,0],[0.067,0.412],[0,0],[-0.925,-0.497],[0,0],[-0.371,0.191],[0,0]],\"o\":[[0,0],[-0.074,0.41],[0,0],[0.746,0.74],[0,0],[-0.413,0.056],[0,0],[-0.473,0.938],[0,0],[-0.181,-0.375],[0,0],[-1.038,-0.16],[0,0],[0.301,-0.288],[0,0],[-0.168,-1.036],[0,0],[0.368,0.198],[0,0],[0.934,-0.481]],\"v\":[[10.03,-12.908],[8.533,-4.611],[8.887,-3.486],[14.872,2.45],[14.151,4.606],[5.798,5.746],[4.839,6.431],[1.042,13.958],[-1.23,13.938],[-4.897,6.346],[-5.845,5.645],[-14.177,4.36],[-14.861,2.193],[-8.772,-3.64],[-8.398,-4.758],[-9.751,-13.08],[-7.901,-14.399],[-0.474,-10.412],[0.706,-10.402],[8.202,-14.26]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.945098099054,0.341176470588,0.18431372549,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[502.717,343.82],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":159,\"ty\":4,\"nm\":\"pyramid blast 67 Outlines\",\"parent\":70,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[52.55,53.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[509.901,442.907,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-4.33],[4.329,0],[0,4.33],[-4.33,0]],\"o\":[[0,4.33],[-4.33,0],[0,-4.33],[4.329,0]],\"v\":[[7.84,0],[0,7.839],[-7.84,0],[0,-7.839]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.945098099054,0.341176470588,0.18431372549,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[509.715,440.871],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":160,\"ty\":4,\"nm\":\"pyramid blast 68 Outlines\",\"parent\":71,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,53.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[555.355,503.946,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-4.33],[4.329,0],[0,4.33],[-4.33,0]],\"o\":[[0,4.33],[-4.33,0],[0,-4.33],[4.329,0]],\"v\":[[7.84,0],[0,7.839],[-7.839,0],[0,-7.839]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.945098099054,0.341176470588,0.18431372549,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[554.715,501.871],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":161,\"ty\":4,\"nm\":\"pyramid blast 69 Outlines\",\"parent\":72,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[52.55,52.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[483.927,466.284,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-4.33],[4.329,0],[0,4.33],[-4.33,0]],\"o\":[[0,4.33],[-4.33,0],[0,-4.33],[4.329,0]],\"v\":[[7.84,0],[0,7.839],[-7.84,0],[0,-7.839]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.945098099054,0.341176470588,0.18431372549,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[483.715,465.871],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":162,\"ty\":4,\"nm\":\"pyramid blast 70 Outlines\",\"parent\":73,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,53.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[529.381,328.622,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-4.33],[4.329,0],[0,4.33],[-4.33,0]],\"o\":[[0,4.33],[-4.33,0],[0,-4.33],[4.329,0]],\"v\":[[7.84,0],[0,7.839],[-7.839,0],[0,-7.839]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.945098099054,0.341176470588,0.18431372549,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[530.715,326.871],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":163,\"ty\":4,\"nm\":\"pyramid blast 71 Outlines\",\"parent\":74,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,52.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[615.095,387.063,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-4.33],[4.329,0],[0,4.33],[-4.33,0]],\"o\":[[0,4.33],[-4.33,0],[0,-4.33],[4.329,0]],\"v\":[[7.84,0],[0,7.839],[-7.839,0],[0,-7.839]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.945098099054,0.341176470588,0.18431372549,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[615.715,387.871],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":164,\"ty\":4,\"nm\":\"pyramid blast 72 Outlines\",\"parent\":75,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,52.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[615.095,433.816,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-4.33],[4.329,0],[0,4.33],[-4.33,0]],\"o\":[[0,4.33],[-4.33,0],[0,-4.33],[4.329,0]],\"v\":[[7.84,0],[0,7.839],[-7.839,0],[0,-7.839]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.945098099054,0.341176470588,0.18431372549,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[616.715,432.871],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":165,\"ty\":4,\"nm\":\"pyramid blast 73 Outlines\",\"parent\":76,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[52.55,53.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[600.81,355.894,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-4.33],[4.329,0],[0,4.33],[-4.33,0]],\"o\":[[0,4.33],[-4.33,0],[0,-4.33],[4.329,0]],\"v\":[[7.84,0],[0,7.839],[-7.839,0],[0,-7.839]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.945098099054,0.341176470588,0.18431372549,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[599.715,354.871],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":166,\"ty\":4,\"nm\":\"pyramid blast 74 Outlines\",\"parent\":77,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,54.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[577.433,705.245,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-4.33],[4.329,0],[0,4.33],[-4.33,0]],\"o\":[[0,4.33],[-4.33,0],[0,-4.33],[4.329,0]],\"v\":[[7.84,0],[0,7.839],[-7.839,0],[0,-7.839]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[577.715,702.871],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":167,\"ty\":4,\"nm\":\"pyramid blast 75 Outlines\",\"parent\":78,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[52.55,53.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[643.667,679.271,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-4.33],[4.329,0],[0,4.33],[-4.33,0]],\"o\":[[0,4.33],[-4.33,0],[0,-4.33],[4.329,0]],\"v\":[[7.84,0],[0,7.839],[-7.839,0],[0,-7.839]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[643.715,677.871],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":168,\"ty\":4,\"nm\":\"pyramid blast 76 Outlines\",\"parent\":79,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[53.55,54.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[556.654,676.674,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-4.33],[4.329,0],[0,4.33],[-4.33,0]],\"o\":[[0,4.33],[-4.33,0],[0,-4.33],[4.329,0]],\"v\":[[7.84,0],[0,7.839],[-7.839,0],[0,-7.839]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[554.715,673.871],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":169,\"ty\":4,\"nm\":\"pyramid blast 77 Outlines\",\"parent\":80,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[53.55,53.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[583.927,803.946,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-4.33],[4.329,0],[0,4.33],[-4.33,0]],\"o\":[[0,4.33],[-4.33,0],[0,-4.33],[4.329,0]],\"v\":[[7.84,0],[0,7.839],[-7.839,0],[0,-7.839]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.945098099054,0.341176470588,0.18431372549,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[582.715,802.126],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":170,\"ty\":4,\"nm\":\"pyramid blast 78 Outlines\",\"parent\":81,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[52.55,54.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[608.602,793.557,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-4.33],[4.329,0],[0,4.33],[-4.33,0]],\"o\":[[0,4.33],[-4.33,0],[0,-4.33],[4.329,0]],\"v\":[[7.84,0],[0,7.839],[-7.839,0],[0,-7.839]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.945098099054,0.341176470588,0.18431372549,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[606.715,791.126],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":171,\"ty\":4,\"nm\":\"pyramid blast 79 Outlines\",\"parent\":82,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[52.55,53.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[630.68,776.674,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-4.33],[4.329,0],[0,4.33],[-4.33,0]],\"o\":[[0,4.33],[-4.33,0],[0,-4.33],[4.329,0]],\"v\":[[7.84,0],[0,7.839],[-7.839,0],[0,-7.839]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.945098099054,0.341176470588,0.18431372549,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[630.715,774.126],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":172,\"ty\":4,\"nm\":\"pyramid blast 80 Outlines\",\"parent\":83,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,53.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[618.992,742.907,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-4.33],[4.329,0],[0,4.33],[-4.33,0]],\"o\":[[0,4.33],[-4.33,0],[0,-4.33],[4.329,0]],\"v\":[[7.84,0],[0,7.839],[-7.839,0],[0,-7.839]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[618.715,741.126],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":173,\"ty\":4,\"nm\":\"pyramid blast 81 Outlines\",\"parent\":84,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[53.55,52.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[682.628,715.635,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-4.33],[4.329,0],[0,4.33],[-4.33,0]],\"o\":[[0,4.33],[-4.33,0],[0,-4.33],[4.329,0]],\"v\":[[7.84,0],[0,7.839],[-7.839,0],[0,-7.839]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[680.715,715.126],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":174,\"ty\":4,\"nm\":\"pyramid blast 82 Outlines\",\"parent\":85,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[53.55,51.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[506.005,801.349,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-4.33],[4.329,0],[0,4.33],[-4.33,0]],\"o\":[[0,4.33],[-4.33,0],[0,-4.33],[4.329,0]],\"v\":[[7.84,0],[0,7.839],[-7.84,0],[0,-7.839]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.945098099054,0.341176470588,0.18431372549,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[505.715,802.126],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":175,\"ty\":4,\"nm\":\"pyramid blast 83 Outlines\",\"parent\":86,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,53.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[428.082,772.778,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-4.33],[4.329,0],[0,4.33],[-4.33,0]],\"o\":[[0,4.33],[-4.33,0],[0,-4.33],[4.329,0]],\"v\":[[7.84,0],[0,7.839],[-7.84,0],[0,-7.839]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.945098099054,0.341176470588,0.18431372549,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[429.715,772.126],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":176,\"ty\":4,\"nm\":\"pyramid blast 84 Outlines\",\"parent\":87,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,52.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[443.667,751.998,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-4.33],[4.329,0],[0,4.33],[-4.33,0]],\"o\":[[0,4.33],[-4.33,0],[0,-4.33],[4.329,0]],\"v\":[[7.84,0],[0,7.839],[-7.84,0],[0,-7.839]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[443.715,751.126],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":177,\"ty\":4,\"nm\":\"pyramid blast 85 Outlines\",\"parent\":88,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,53.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[542.368,754.596,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-4.33],[4.329,0],[0,4.33],[-4.33,0]],\"o\":[[0,4.33],[-4.33,0],[0,-4.33],[4.329,0]],\"v\":[[7.84,0],[0,7.839],[-7.839,0],[0,-7.839]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[543.715,754.126],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":178,\"ty\":4,\"nm\":\"pyramid blast 86 Outlines\",\"parent\":89,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[50.55,53.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[508.602,754.596,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-4.33],[4.329,0],[0,4.33],[-4.33,0]],\"o\":[[0,4.33],[-4.33,0],[0,-4.33],[4.329,0]],\"v\":[[7.84,0],[0,7.839],[-7.84,0],[0,-7.839]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[508.715,754.126],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":179,\"ty\":4,\"nm\":\"pyramid blast 87 Outlines\",\"parent\":90,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,54.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[478.732,722.128,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-4.33],[4.329,0],[0,4.33],[-4.33,0]],\"o\":[[0,4.33],[-4.33,0],[0,-4.33],[4.329,0]],\"v\":[[7.84,0],[0,7.839],[-7.84,0],[0,-7.839]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[478.715,719.126],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":180,\"ty\":4,\"nm\":\"pyramid blast 88 Outlines\",\"parent\":91,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[52.55,53.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[386.524,719.531,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-4.33],[4.329,0],[0,4.33],[-4.33,0]],\"o\":[[0,4.33],[-4.33,0],[0,-4.33],[4.329,0]],\"v\":[[7.84,0],[0,7.839],[-7.84,0],[0,-7.839]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[385.715,718.126],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":181,\"ty\":4,\"nm\":\"pyramid blast 89 Outlines\",\"parent\":92,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51.55,52.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[516.394,677.972,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-4.33],[4.329,0],[0,4.33],[-4.33,0]],\"o\":[[0,4.33],[-4.33,0],[0,-4.33],[4.329,0]],\"v\":[[7.84,0],[0,7.839],[-7.839,0],[0,-7.839]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[516.715,677.126],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":182,\"ty\":4,\"nm\":\"pyramid blast 90 Outlines\",\"parent\":93,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[53.55,53.81,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[435.875,681.868,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":83,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":89,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":95,\"s\":[77,77,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":101,\"s\":[100,100,100]},{\"t\":107,\"s\":[77,77,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-4.33],[4.329,0],[0,4.33],[-4.33,0]],\"o\":[[0,4.33],[-4.33,0],[0,-4.33],[4.329,0]],\"v\":[[7.84,0],[0,7.839],[-7.84,0],[0,-7.839]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[435.715,680.126],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":83,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":183,\"ty\":4,\"nm\":\"rocket1 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.581],\"y\":[0.026]},\"o\":{\"x\":[0.18],\"y\":[0.385]},\"t\":0,\"s\":[-36]},{\"i\":{\"x\":[0.702],\"y\":[1]},\"o\":{\"x\":[0.346],\"y\":[0.286]},\"t\":6,\"s\":[-16.465]},{\"t\":16,\"s\":[75]}],\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.581,\"y\":0.758},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":0,\"s\":[718.55,954.31,0],\"to\":[53.006,-290.17,0],\"ti\":[-58.282,72.885,0]},{\"i\":{\"x\":0.702,\"y\":1},\"o\":{\"x\":0.346,\"y\":0.806},\"t\":6,\"s\":[892.496,441.56,0],\"to\":[100.826,-126.088,0],\"ti\":[-1.999,-4.051,0]},{\"t\":16,\"s\":[1083.05,423.31,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1440.55,792.31,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.632,0.632,0.632],\"y\":[0.839,0.839,0.66]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.152,0.152,0.321]},\"t\":0,\"s\":[88,88,100]},{\"i\":{\"x\":[0.683,0.683,0.683],\"y\":[1,1,1]},\"o\":{\"x\":[0.348,0.348,0.348],\"y\":[0.152,0.152,0.046]},\"t\":14,\"s\":[32.867,32.867,100]},{\"t\":16,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0.511,6.383]],\"o\":[[0,0],[0,0]],\"v\":[[3.009,5.081],[-3.009,-5.081]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1136.096,1010.555],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-0.705,5.243]],\"o\":[[0,0],[0,0]],\"v\":[[2.698,5.331],[-1.993,-5.331]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1144.541,1006.503],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-3.609,6.459]],\"o\":[[0,0],[0,0]],\"v\":[[2.472,5.806],[1.137,-5.806]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1153.944,1004.176],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 3\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":3,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-4.435,4.757]],\"o\":[[0,0],[0,0]],\"v\":[[2.464,5.954],[1.971,-5.954]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1165.065,1003.13],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 4\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":4,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-1.846,6.46]],\"o\":[[0,0],[0,0]],\"v\":[[1.942,5.83],[-0.096,-5.829]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1178.213,1002.575],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 5\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":5,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-2.204,6.553]],\"o\":[[0,0],[0,0]],\"v\":[[3.065,5.776],[-0.861,-5.776]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1189.997,1001.263],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 6\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":6,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-0.754,7.709]],\"o\":[[0,0],[0,0]],\"v\":[[3.284,5.721],[-2.53,-5.721]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1202.702,997.954],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 7\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":7,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[2.789,7.477]],\"o\":[[0,0],[0,0]],\"v\":[[4.133,4.981],[-4.132,-4.981]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1213.796,992.444],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 8\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":8,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[12.273,41.27]],\"o\":[[0,0],[0,0]],\"v\":[[22.271,25.483],[-22.271,-25.483]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1264.622,948.246],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 9\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":9,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[-8.261,-9.453],[-21.084,-12.594],[-12.24,-2.797],[-24.457,2.201],[-11.548,4.937],[-18.489,16.158],[-6.438,10.783],[-5.456,23.942],[1.133,12.505],[9.657,22.581],[8.262,9.453],[21.085,12.594],[12.24,2.797],[24.457,-2.2],[11.549,-4.937],[18.489,-16.158],[6.439,-10.783],[5.456,-23.942],[-1.132,-12.504],[-9.656,-22.581]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1118.845,1033.643],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 10\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":10,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[29.549,-36.105]],\"o\":[[-32.097,29.7],[0,0]],\"v\":[[47.752,-17.414],[-47.752,18.052]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1168.295,999.118],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 11\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":11,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[23.197,-27.911]],\"o\":[[-33.083,30.381],[0,0]],\"v\":[[47.974,-16.368],[-47.974,16.368]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1177.252,1008.444],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 12\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":12,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[10.491,12.005],[-4.968,4.341],[0,0]],\"o\":[[0,0],[-4.968,4.341],[-10.491,-12.004],[0,0],[0,0]],\"v\":[[93.763,-18.048],[-50.804,85.943],[-78.794,72.068],[-88.795,42.473],[30.666,-90.284]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1299.957,915.153],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 13\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":13,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-10.445,-11.952],[-9.636,-5.011]],\"o\":[[3.795,10.066],[10.747,12.297],[0,0]],\"v\":[[-26.901,-30.531],[-5.016,3.809],[26.9,30.53]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1314.874,902.92],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 14\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":14,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0.369,-0.424],[-19.482,-22.293],[-8.672,5.692],[-0.177,0.54],[0,0],[1.866,-0.361]],\"o\":[[-0.552,0.107],[-6.815,7.823],[19.476,22.285],[0.475,-0.312],[0,0],[0.594,-1.806],[0,0]],\"v\":[[-48.568,-34.764],[-49.99,-33.945],[-27.581,19.753],[22.623,49.157],[23.63,47.839],[56.21,-51.266],[53.371,-54.489]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1382.41,847.677],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 15\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":15,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-0.114,-0.579],[-24.901,4.907],[2.179,11.057],[0.28,0.634]],\"o\":[[0.003,0.588],[2.179,11.057],[24.901,-4.907],[-0.134,-0.681],[0,0]],\"v\":[[-46.263,0.099],[-46.089,1.851],[2.943,12.986],[44.084,-15.92],[43.462,-17.893]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[1,0.84313731474,0.686274509804,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1385.212,812.377],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 16\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":16,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[-13.77,-16.092],[-4.812,-13.106],[-0.83,-22.728],[2.82,-12.442],[11.446,-18.746],[10.451,-10.12],[21.4,-9.124],[13.769,-1.493],[21.732,4.811],[11.446,7.466],[15.428,17.088],[4.811,12.443],[2.156,22.728],[-2.821,13.106],[-11.447,19.41],[-10.452,7.466],[-18.415,7.797],[-12.775,0.83],[-21.733,-6.138],[-10.452,-6.802]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1118.773,1033.618],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 17\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":17,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-3.65,4.313],[0,0],[14.599,-2.655],[17.917,-16.258],[1.991,3.318],[0,0],[-17.253,2.655],[-7.906,2.4]],\"o\":[[0,0],[0,0],[-14.599,2.654],[0,0],[-1.991,-3.318],[0,0],[17.253,-2.654],[7.905,-2.399]],\"v\":[[43.963,-23.226],[52.922,-12.609],[26.046,1.659],[-42.636,18.249],[-50.931,19.908],[-51.926,12.276],[-19.41,-7.3],[20.406,-10.618]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.811764765721,0.501960784314,0,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1171.861,1005.25],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 18\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":18,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[9.843,2.765],[20.463,30.38],[-3.982,5.309],[0,0],[0.332,-2.986]],\"o\":[[0,0],[-9.843,-2.765],[-14.931,-20.903],[0,0],[0,0],[-0.331,2.987]],\"v\":[[22.894,49.327],[10.507,51.097],[-40.147,6.193],[-50.101,-32.959],[52.424,-52.535],[54.746,-50.876]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.945098099054,0.341176470588,0.18431372549,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1383.381,845.766],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 19\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":19,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[14.267,38.82],[0,0],[-27.871,-3.65]],\"o\":[[0,0],[0,0],[0,0],[0,0]],\"v\":[[49.936,10.783],[-4.147,-50.599],[-49.936,0.166],[-4.479,50.599]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.945098099054,0.341176470588,0.18431372549,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1292.303,922.799],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 20\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":20,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-3.097,-38.046],[0,0],[0,0],[10.617,16.368],[-3.54,3.982],[0,0]],\"o\":[[0,0],[0,0],[0,0],[-10.618,-16.369],[3.539,-3.981],[0,0]],\"v\":[[93.346,-16.59],[83.613,-9.512],[-53.088,88.7],[-82.727,70.12],[-88.479,43.133],[29.641,-88.7]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[1,0.976470648074,0.937254961799,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1300.542,913.453],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 21\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":21,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":0,\"op\":17,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":184,\"ty\":4,\"nm\":\"rocket2 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.582],\"y\":[0.349]},\"o\":{\"x\":[0.18],\"y\":[0.259]},\"t\":36,\"s\":[65]},{\"i\":{\"x\":[0.702],\"y\":[1]},\"o\":{\"x\":[0.347],\"y\":[0.32]},\"t\":41,\"s\":[36.521]},{\"t\":50,\"s\":[-50]}],\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.582,\"y\":0.775},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":36,\"s\":[1198.55,908.31,0],\"to\":[-68.757,-245.849,0],\"ti\":[53.561,51.278,0]},{\"i\":{\"x\":0.702,\"y\":1},\"o\":{\"x\":0.347,\"y\":0.851},\"t\":41,\"s\":[1012.332,493.279,0],\"to\":[-84.556,-80.953,0],\"ti\":[11.44,-9.885,0]},{\"t\":50,\"s\":[857.55,507.31,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1502.55,940.31,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.627,0.627,0.627],\"y\":[0.822,0.822,0.159]},\"o\":{\"x\":[0.168,0.168,0.168],\"y\":[0.15,0.15,0.709]},\"t\":36,\"s\":[67,67,100]},{\"i\":{\"x\":[0.685,0.685,0.685],\"y\":[1,1,1]},\"o\":{\"x\":[0.349,0.349,0.349],\"y\":[0.151,0.151,0.131]},\"t\":48,\"s\":[31.549,31.549,100]},{\"t\":50,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[2.176,6.023]],\"o\":[[0,0],[0,0]],\"v\":[[-1.724,5.872],[-0.452,-5.871]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1867.801,1011.427],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[2.812,4.482]],\"o\":[[0,0],[0,0]],\"v\":[[-1.265,5.824],[-1.406,-5.824]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1858.364,1011.378],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[5.958,4.387]],\"o\":[[0,0],[0,0]],\"v\":[[0.61,5.562],[-2.979,-5.562]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1847.367,1013.752],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 3\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":3,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[6.006,2.496]],\"o\":[[0,0],[0,0]],\"v\":[[1.476,5.522],[-3.003,-5.523]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1836.013,1017.571],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 4\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":4,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[4.353,5.117]],\"o\":[[0,0],[0,0]],\"v\":[[0.793,5.728],[-2.177,-5.728]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1824.921,1021.971],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 5\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":5,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[4.718,5.054]],\"o\":[[0,0],[0,0]],\"v\":[[-1.154,6.07],[-2.359,-6.07]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1814.552,1025.727],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 6\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":6,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[3.876,6.706]],\"o\":[[0,0],[0,0]],\"v\":[[-2.217,6.411],[-1.658,-6.411]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1802.458,1027.671],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 7\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":7,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0.555,7.961]],\"o\":[[0,0],[0,0]],\"v\":[[-1.979,6.245],[1.424,-6.245]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1788.76,1027.089],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 8\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":8,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[5.903,42.65]],\"o\":[[0,0],[0,0]],\"v\":[[-12.682,32.414],[6.779,-32.414]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1726.876,1007.881],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 9\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":9,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[7.06,-23.517],[7.153,-10.323],[19.539,-14.873],[11.852,-4.142],[24.553,-0.552],[12.024,3.609],[20.189,13.984],[7.611,9.985],[8.116,23.176],[0.284,12.557],[-7.06,23.517],[-7.153,10.323],[-19.539,14.874],[-11.852,4.142],[-24.553,0.552],[-12.024,-3.609],[-20.189,-13.984],[-7.611,-9.986],[-8.116,-23.175],[-0.284,-12.556]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1891.971,1025.309],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 10\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":10,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-41.84,-20.644]],\"o\":[[41.509,13.758],[0,0]],\"v\":[[-50.81,7.056],[50.81,-0.171]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1832.799,1011.185],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 11\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":11,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-32.667,-15.812]],\"o\":[[42.689,13.97],[0,0]],\"v\":[[-50.447,5.869],[50.447,-4.027]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1828.373,1025.614],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 12\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":12,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[-4.584,15.269],[6.318,1.897],[0,0]],\"o\":[[0,0],[6.318,1.897],[4.584,-15.269],[0,0],[0,0]],\"v\":[[-99.482,27.558],[75.158,62.415],[94.898,38.202],[91.758,7.12],[-71.927,-64.312]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1684.717,987.179],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 13\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":13,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[4.564,-15.203],[6.7,-8.549]],\"o\":[[0.71,10.734],[-4.695,15.642],[0,0]],\"v\":[[11.503,-38.925],[5.787,1.393],[-12.213,38.925]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1659.776,987.409],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 14\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":14,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-0.511,-0.233],[8.513,-28.356],[10.25,1.594],[0.385,0.419],[0,0],[-1.849,0.443]],\"o\":[[0.546,-0.131],[9.441,4.303],[-8.51,28.347],[-0.561,-0.087],[0,0],[-1.287,-1.399],[0,0]],\"v\":[[45.771,-53.659],[47.403,-53.503],[49.22,4.655],[15.681,52.197],[14.219,51.413],[-56.447,-25.329],[-55.195,-29.438]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1559.142,966.975],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 15\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":15,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-0.149,-0.571],[24.559,-6.402],[2.843,10.905],[0.023,0.692]],\"o\":[[0.253,0.531],[2.843,10.905],[-24.559,6.402],[-0.175,-0.671],[0,0]],\"v\":[[42.59,-19.697],[43.194,-18.043],[3.874,13.295],[-45.741,5.142],[-46.037,3.095]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.690196078431,0.945098099054,0.835294177485,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1557.75,933.194],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 16\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":16,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[5.656,1.076],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[-4.233,-1.555],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[7.343,-22.528],[-0.433,-12.088],[-7.81,-22.681],[-7.201,-9.994],[-19.417,-13.252],[-11.917,-3.566],[-24.369,0.611],[-11.917,4.468],[-18.99,14.577],[-7.179,10.365],[-6.717,22.11],[0.687,12.427],[8.281,22.681],[7.892,9.954],[19.531,13.125],[12.636,3.691],[24.368,-0.285],[12.394,-4.234],[19.167,-14.248],[7.387,-10.255]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1891.734,1025.301],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 17\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":17,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[5.091,2.45],[0,0],[-14.412,3.529],[-23.993,-9.111],[-0.465,3.841],[0,0],[19.958,-2.177],[17.501,-3.377]],\"o\":[[0,0],[0,0],[17.539,-3.857],[0,0],[0.465,-3.842],[0,0],[-11.007,0.982],[-8.197,1.032]],\"v\":[[-51.677,-2.251],[-55.528,11.096],[-23.472,13.106],[44.307,0.312],[55.064,0.951],[52.612,-8.411],[19.467,-14.458],[-25.818,0.449]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.811764765721,0.501960784314,0,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1832.651,1020.226],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 18\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":18,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-7.86,6.538],[-5.165,26.827],[4.622,0.355],[0,0],[-1.521,-2.591]],\"o\":[[0,0],[7.861,-6.538],[5.165,-26.827],[0,0],[0,0],[1.52,2.591]],\"v\":[[14.026,51.113],[26.058,47.678],[53.432,-14.547],[46.697,-54.217],[-54.469,-29.858],[-57.077,-26.232]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.360784313725,0.882353001015,0.662745098039,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1559.26,967.79],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 19\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":19,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[2.8,41.264],[0,0],[27.537,-28.432]],\"o\":[[0,0],[0,0],[0,0],[0,0]],\"v\":[[-47.305,32.938],[-22.948,-45.906],[38.932,-18.771],[19.769,45.906]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.360784313725,0.882353001015,0.662745098039,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1694.425,994.39],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 20\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":20,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-3.022,19.275],[7.954,3.019],[0,0],[-12.684,-36.003]],\"o\":[[0,0],[3.021,-19.276],[-4.855,-2.193],[0,0],[0,0]],\"v\":[[84.925,63.516],[103.104,37.281],[96.935,6.969],[-64.672,-63.516],[-93.441,29.044]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.972549079446,0.705882352941,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1677.101,986.247],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 21\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":21,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":35,\"op\":51,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":185,\"ty\":4,\"nm\":\"rocket3 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.627,\"y\":0.854},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":69,\"s\":[960.55,945.31,0],\"to\":[0.027,-13.605,0],\"ti\":[-0.251,129.51,0]},{\"i\":{\"x\":0.71,\"y\":1},\"o\":{\"x\":0.238,\"y\":1},\"t\":73,\"s\":[961.446,483.222,0],\"to\":[0.064,-33.099,0],\"ti\":[0,0.089,0]},{\"t\":78,\"s\":[961.55,429.31,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1760.55,451.31,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.611,0.611,0.611],\"y\":[0.86,0.86,1.015]},\"o\":{\"x\":[0.17,0.17,0.17],\"y\":[0.083,0.083,-0.009]},\"t\":69,\"s\":[41,41,100]},{\"i\":{\"x\":[0.692,0.692,0.692],\"y\":[1,1,1]},\"o\":{\"x\":[0.352,0.352,0.352],\"y\":[0.02,0.02,-0.017]},\"t\":73,\"s\":[39.185,39.185,100]},{\"t\":78,\"s\":[25,25,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-4.845,2.285]],\"o\":[[5.399,2.25],[0,0]],\"v\":[[-7.705,-1.301],[7.705,-0.984]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1774.25,878.815],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-4.343,2.124]],\"o\":[[5.189,1.777],[0,0]],\"v\":[[-7.205,-1.062],[7.205,-1.062]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1773.916,860.814],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[4.719,1.504]],\"o\":[[-4.991,1.217],[0,0]],\"v\":[[7.288,-0.45],[-7.289,-0.767]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1773.833,839.269],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 3\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":3,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-4.995,2.139]],\"o\":[[5.118,1.997],[0,0]],\"v\":[[-7.588,-1.069],[7.587,-1.069]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1773.526,821.122],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 4\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":4,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-5.061,1.081]],\"o\":[[5.061,1.081],[0,0]],\"v\":[[-7.591,-0.541],[7.592,-0.541]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1773.53,802.885],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 5\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":5,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-0.138,33.25]],\"o\":[[-0.839,-34.333],[0,0]],\"v\":[[0.903,53.454],[-0.766,-53.453]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1781.892,844.085],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 6\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":6,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,39.687]],\"o\":[[0,-32.271],[0,0]],\"v\":[[0.606,52.031],[-0.605,-52.031]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1765.938,842.743],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 7\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":7,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[16.158,-18.489],[10.783,-6.439],[23.942,-5.456],[12.505,1.132],[22.581,9.656],[9.453,8.261],[12.594,21.084],[2.797,12.24],[-2.2,24.457],[-4.936,11.548],[-16.158,18.489],[-10.783,6.439],[-23.942,5.456],[-12.504,-1.133],[-22.581,-9.657],[-9.453,-8.262],[-12.594,-21.085],[-2.797,-12.24],[2.201,-24.457],[4.937,-11.549]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1774.875,912.14],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 8\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":8,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-41.456,9.66]],\"o\":[[0,0],[0,0]],\"v\":[[-40.248,-4.83],[40.249,-4.83]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1762.813,505.14],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 9\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":9,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-71.24,25.357]],\"o\":[[10.867,6.037],[0,0]],\"v\":[[-81.906,-12.679],[81.905,-12.679]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1763.417,567.726],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 10\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":10,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[21.35,12.106],[14.131,8.311],[-10.596,21.31],[-5.873,-6.223],[-21.35,-21.31]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1827.166,644.234],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 11\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":11,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[-4.785,32.013],[-2.134,16.555],[-22.138,-2.945],[5.507,-6.961],[17.87,-32.013],[22.138,-23.365]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1819.804,752.264],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 12\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":12,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[-24.01,-16.969],[-15.999,-33.202],[-3.635,-8.151],[24.009,-4.134],[4.005,15.365],[7.065,33.202]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1716.023,752.246],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 13\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":13,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[22.128,-22.998],[3.187,-4.535],[7.909,22.998],[-16.817,9.999],[-22.128,12.791]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1706.781,646.571],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 14\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":14,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[0,-38.05],[12.363,-12.999],[40.008,-8.982],[20.004,10.517],[24.726,38.05],[0,25.05],[-24.726,38.05],[-20.004,10.517],[-40.008,-8.982],[-12.363,-12.999]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1767.643,689.477],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 15\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":15,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0]],\"v\":[[-112.889,72.919],[-2.378,-72.919],[112.888,72.26]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1763.983,520.101],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 16\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":16,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,-1.932],[63.018,0],[0,15.453],[-0.645,1.204]],\"o\":[[1.52,1.821],[0,15.453],[-63.018,0],[0,-1.247],[0,0]],\"v\":[[111.786,-16.81],[114.104,-11.17],[0,16.81],[-114.104,-11.17],[-113.127,-14.848]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1764.222,607.868],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 17\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":17,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[40.345,0],[0,12.337]],\"o\":[[0,12.337],[-40.345,0],[0,0]],\"v\":[[73.051,-11.169],[0,11.169],[-73.051,-11.169]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1766.636,778.929],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 18\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":18,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-12.075,63.995]],\"o\":[[0,0],[0,0]],\"v\":[[-7.848,76.371],[7.849,-76.371]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1847.536,691.087],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 19\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":19,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[12.075,63.995]],\"o\":[[0,0],[0,0]],\"v\":[[7.849,76.371],[-7.849,-76.371]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1685.737,691.389],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 20\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":20,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-1.206,-0.912],[24.676,-32.654],[19.298,14.583],[0.887,0.897]],\"o\":[[1.327,0.686],[19.298,14.583],[-24.676,32.653],[-1.018,-0.769],[0,0]],\"v\":[[32.657,-67.614],[36.46,-65.219],[26.723,20.312],[-52.899,53.031],[-55.757,50.528]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.894117706897,0.976470648074,0.992156922583,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1714.706,532.332],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 21\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":21,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[23.02,-5.315],[11.089,-6.347],[15.545,-18.065],[4.815,-11.496],[1.74,-24.044],[-3.273,-12.524],[-12.471,-20.347],[-9.868,-8.305],[-22.174,-9.47],[-13.12,-1.269],[-23.02,5.307],[-11.218,6.56],[-15.584,17.662],[-5.295,11.921],[-2.273,24.044],[2.443,12.448],[12.027,20.89],[9.356,8.697],[21.7,9.721],[11.955,1.155]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1775.201,912.12],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 22\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":22,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0]],\"v\":[[7.197,-56.703],[-8.596,-56.42],[-7.269,56.343],[8.597,56.703]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.945098099054,0.341176470588,0.18431372549,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1773.93,846.483],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 23\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":23,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-50.765,0],[0,0],[0,0],[37.162,9.954]],\"o\":[[0,0],[50.765,0],[0,0],[0,0],[0,0]],\"v\":[[-83.115,21.235],[-0.166,33.843],[83.115,20.571],[39.65,-33.511],[-41.309,-33.843]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.792156922583,0.964705942191,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1763.392,533.877],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 24\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":24,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-1.328,-3.539],[-98.989,-0.223],[1.327,10.618],[0,0],[0,0]],\"o\":[[0,0],[1.327,3.539],[90.691,-3.097],[0,0],[0,0],[0,0]],\"v\":[[-113.253,56.099],[-113.695,63.705],[4.424,88.922],[113.696,59.281],[109.714,53.088],[-3.097,-88.921]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1764.664,535.979],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 25\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":25,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-3.385,9.75],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[1.429,-12.945],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[-5.029,31.792],[18.86,18.078],[21.957,-23.471],[17.47,-31.792],[5.201,-7.084],[-21.957,-2.923],[-2.455,16.751]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1820.126,752.37],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 26\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":26,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-21.235,-3.982],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[-22.783,16.811],[6.635,33.18],[3.54,15.484],[23.89,-4.866],[-3.097,-7.963],[-16.369,-33.18],[-23.89,-17.253]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1716,752.31],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 27\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":27,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[-24.332,37.094],[-0.443,24.708],[24.023,37.671],[19.443,9.995],[38.931,-9.799],[11.502,-13.781],[-0.443,-37.671],[-12.83,-13.781],[-38.931,-9.358],[-21.235,9.666]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1768.203,689.999],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 28\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":28,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[12.829,0.442],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[-24.99,-15.8],[-9.516,-0.995],[-13.498,25.548],[10.391,14.046],[17.912,17.585],[24.99,-25.548]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1830.807,638.725],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 29\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":29,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.442,-5.751],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[-19.797,16.59],[-14.488,13.936],[10.728,27.207],[7.189,-0.663],[26.212,-18.802],[-26.212,-27.207]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1703.502,642.375],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 30\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":30,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[1.168,-45.555],[-61.051,-2.655],[-2.654,7.3],[-9.29,20.572]],\"o\":[[0.74,-2.578],[0,0],[64.206,0.275],[0,0],[0,0]],\"v\":[[-89.253,-86.443],[-73.327,67.511],[-8.958,88.746],[73.327,66.847],[89.253,-88.434]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.003921568627,0.517647058824,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1766.544,701.61],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 31\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":31,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":69,\"op\":79,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":186,\"ty\":4,\"nm\":\"spiky blast Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[1064.55,423.31,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1316.55,193.31,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.167,0.167,0.167],\"y\":[0.167,0.167,-10.833]},\"t\":17,\"s\":[100,100,100]},{\"t\":20,\"s\":[35,35,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[61.681,23.494],[31.162,25.106],[36.084,55.271],[10.443,38.621],[-3.287,65.936],[-14.24,37.384],[-41.412,51.415],[-33.491,21.886],[-63.712,17.258],[-39.969,-1.988],[-61.682,-23.494],[-31.164,-25.106],[-36.086,-55.271],[-10.444,-38.62],[3.286,-65.936],[14.239,-37.384],[41.411,-51.414],[33.49,-21.886],[63.711,-17.258],[39.969,1.988]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1319.813,190.894],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[163.401,0],[92.175,24.721],[141.513,81.736],[67.458,67.459],[81.735,141.514],[24.721,92.175],[0,163.401],[-24.722,92.175],[-81.737,141.513],[-67.458,67.458],[-141.514,81.736],[-92.176,24.721],[-163.401,0],[-92.176,-24.721],[-141.514,-81.736],[-67.458,-67.459],[-81.736,-141.514],[-24.722,-92.175],[0,-163.401],[24.721,-92.175],[81.735,-141.513],[67.458,-67.458],[141.513,-81.736],[92.175,-24.721]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1316.922,190.004],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[-41.696,52.383],[-13.769,37.396],[-3.484,64.935],[10.12,39.388],[35.668,54.651],[31.355,24.789],[61.401,23.794],[39.866,2.674],[63.539,-17.018],[33.346,-21.995],[40.645,-50.862],[13.438,-37.589],[2.92,-64.935],[-10.545,-38.693],[-36,-54.51],[-32.018,-25.312],[-61.866,-23.321],[-39.981,-1.423],[-63.539,17.82],[-33.677,22.797]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.745098039216,0.188235309077,0.074509803922,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1319.979,190.658],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 3\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":3,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[-67.244,68.128],[-81.401,140.682],[-23.889,92.903],[0,162.802],[24.774,93.346],[81.401,141.567],[67.687,68.128],[140.682,81.843],[93.346,24.773],[161.917,0.885],[92.903,-24.774],[139.797,-80.516],[67.244,-67.687],[81.843,-140.24],[25.217,-92.461],[0,-162.802],[-24.332,-92.018],[-81.401,-139.797],[-67.686,-67.245],[-140.239,-80.958],[-92.018,-24.774],[-161.917,0],[-92.461,24.331],[-139.797,80.958]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1316.716,189.567],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 4\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":4,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":17,\"op\":21,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":187,\"ty\":4,\"nm\":\"spiky blast Outlines 2\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[872.55,512.31,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1316.55,192.31,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.167,0.167,0.167],\"y\":[0.167,0.167,-10.833]},\"t\":51,\"s\":[100,100,100]},{\"t\":54,\"s\":[35,35,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[61.681,23.494],[31.162,25.106],[36.084,55.271],[10.443,38.621],[-3.287,65.936],[-14.24,37.384],[-41.412,51.415],[-33.491,21.886],[-63.712,17.258],[-39.969,-1.988],[-61.682,-23.494],[-31.164,-25.106],[-36.086,-55.271],[-10.444,-38.62],[3.286,-65.936],[14.239,-37.384],[41.411,-51.414],[33.49,-21.886],[63.711,-17.258],[39.969,1.988]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1319.813,190.894],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[163.401,0],[92.175,24.721],[141.513,81.736],[67.458,67.459],[81.735,141.514],[24.721,92.175],[0,163.401],[-24.722,92.175],[-81.737,141.513],[-67.458,67.458],[-141.514,81.736],[-92.176,24.721],[-163.401,0],[-92.176,-24.721],[-141.514,-81.736],[-67.458,-67.459],[-81.736,-141.514],[-24.722,-92.175],[0,-163.401],[24.721,-92.175],[81.735,-141.513],[67.458,-67.458],[141.513,-81.736],[92.175,-24.721]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1316.922,190.004],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[-41.696,52.383],[-13.769,37.396],[-3.484,64.935],[10.12,39.388],[35.668,54.651],[31.355,24.789],[61.401,23.794],[39.866,2.674],[63.539,-17.018],[33.346,-21.995],[40.645,-50.862],[13.438,-37.589],[2.92,-64.935],[-10.545,-38.693],[-36,-54.51],[-32.018,-25.312],[-61.866,-23.321],[-39.981,-1.423],[-63.539,17.82],[-33.677,22.797]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.745098039216,0.188235309077,0.074509803922,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1319.979,190.658],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 3\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":3,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[-67.244,68.128],[-81.401,140.682],[-23.889,92.903],[0,162.802],[24.774,93.346],[81.401,141.567],[67.687,68.128],[140.682,81.843],[93.346,24.773],[161.917,0.885],[92.903,-24.774],[139.797,-80.516],[67.244,-67.687],[81.843,-140.24],[25.217,-92.461],[0,-162.802],[-24.332,-92.018],[-81.401,-139.797],[-67.686,-67.245],[-140.239,-80.958],[-92.018,-24.774],[-161.917,0],[-92.461,24.331],[-139.797,80.958]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1316.716,189.567],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 4\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":4,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":51,\"op\":55,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":188,\"ty\":4,\"nm\":\"spiky blast Outlines 3\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[960.55,486.31,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1312.55,194.31,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.167,0.167,0.167],\"y\":[0,0,0]},\"t\":55,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.167,0.167,0.167],\"y\":[0.167,0.167,-10.833]},\"t\":79,\"s\":[100,100,100]},{\"t\":82,\"s\":[35,35,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[61.681,23.494],[31.162,25.106],[36.084,55.271],[10.443,38.621],[-3.287,65.936],[-14.24,37.384],[-41.412,51.415],[-33.491,21.886],[-63.712,17.258],[-39.969,-1.988],[-61.682,-23.494],[-31.164,-25.106],[-36.086,-55.271],[-10.444,-38.62],[3.286,-65.936],[14.239,-37.384],[41.411,-51.414],[33.49,-21.886],[63.711,-17.258],[39.969,1.988]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1319.813,190.894],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[163.401,0],[92.175,24.721],[141.513,81.736],[67.458,67.459],[81.735,141.514],[24.721,92.175],[0,163.401],[-24.722,92.175],[-81.737,141.513],[-67.458,67.458],[-141.514,81.736],[-92.176,24.721],[-163.401,0],[-92.176,-24.721],[-141.514,-81.736],[-67.458,-67.459],[-81.736,-141.514],[-24.722,-92.175],[0,-163.401],[24.721,-92.175],[81.735,-141.513],[67.458,-67.458],[141.513,-81.736],[92.175,-24.721]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1316.922,190.004],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[-41.696,52.383],[-13.769,37.396],[-3.484,64.935],[10.12,39.388],[35.668,54.651],[31.355,24.789],[61.401,23.794],[39.866,2.674],[63.539,-17.018],[33.346,-21.995],[40.645,-50.862],[13.438,-37.589],[2.92,-64.935],[-10.545,-38.693],[-36,-54.51],[-32.018,-25.312],[-61.866,-23.321],[-39.981,-1.423],[-63.539,17.82],[-33.677,22.797]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.745098039216,0.188235309077,0.074509803922,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1319.979,190.658],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 3\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":3,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[-67.244,68.128],[-81.401,140.682],[-23.889,92.903],[0,162.802],[24.774,93.346],[81.401,141.567],[67.687,68.128],[140.682,81.843],[93.346,24.773],[161.917,0.885],[92.903,-24.774],[139.797,-80.516],[67.244,-67.687],[81.843,-140.24],[25.217,-92.461],[0,-162.802],[-24.332,-92.018],[-81.401,-139.797],[-67.686,-67.245],[-140.239,-80.958],[-92.018,-24.774],[-161.917,0],[-92.461,24.331],[-139.797,80.958]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1316.716,189.567],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 4\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":4,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":79,\"op\":83,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":189,\"ty\":4,\"nm\":\"blast 2 1 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.585,\"y\":0.73},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":55,\"s\":[890.55,523.31,0],\"to\":[4.275,4.703,0],\"ti\":[-10.385,-11.423,0]},{\"i\":{\"x\":0.684,\"y\":0.887},\"o\":{\"x\":0.341,\"y\":0.595},\"t\":62,\"s\":[920.451,556.201,0],\"to\":[4.567,5.023,0],\"ti\":[-1.343,-1.477,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.346,\"y\":0.32},\"t\":68,\"s\":[929.988,566.692,0],\"to\":[0.366,0.402,0],\"ti\":[0,0,0]},{\"t\":72,\"s\":[932.55,569.31,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1472.008,596.56,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.585,0.585,0.585],\"y\":[0.73,0.73,15.726]},\"o\":{\"x\":[0.178,0.178,0.178],\"y\":[0.111,0.111,-6.062]},\"t\":55,\"s\":[96,96,100]},{\"i\":{\"x\":[0.684,0.684,0.684],\"y\":[0.887,0.887,2.97]},\"o\":{\"x\":[0.341,0.341,0.341],\"y\":[0.595,0.595,-10.349]},\"t\":62,\"s\":[42.926,42.926,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.178]},\"o\":{\"x\":[0.346,0.346,0.346],\"y\":[0.078,0.078,-1.436]},\"t\":68,\"s\":[25.997,25.997,100]},{\"t\":72,\"s\":[8,8,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[2.704,-2.474],[-2.473,-2.704],[-2.704,2.474],[2.474,2.704]],\"o\":[[-2.704,2.473],[2.474,2.705],[2.705,-2.473],[-2.473,-2.704]],\"v\":[[-4.479,-4.897],[-4.897,4.478],[4.478,4.896],[4.896,-4.479]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1472.49,595.429],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-0.106,-3.904],[3.913,-0.106],[0.106,3.904],[-3.914,0.106]],\"o\":[[0.106,3.904],[-3.914,0.106],[-0.106,-3.904],[3.913,-0.106]],\"v\":[[7.087,-0.193],[0.193,7.069],[-7.087,0.193],[-0.192,-7.068]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.023529413635,0.827451040231,0.486274539723,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1472.49,595.43],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":55,\"op\":73,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":190,\"ty\":4,\"nm\":\"blast 2 2 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.585,\"y\":0.73},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":55,\"s\":[858.55,524.31,0],\"to\":[-5.558,5.023,0],\"ti\":[13.5,-12.202,0]},{\"i\":{\"x\":0.684,\"y\":0.887},\"o\":{\"x\":0.341,\"y\":0.595},\"t\":62,\"s\":[819.679,559.443,0],\"to\":[-5.93,5.36,0],\"ti\":[1.751,-1.583,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.346,\"y\":0.673},\"t\":68,\"s\":[807.287,570.644,0],\"to\":[-0.479,0.433,0],\"ti\":[0,0,0]},{\"t\":72,\"s\":[805.8,572.06,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1438.675,597.602,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.585,0.585,0.585],\"y\":[0.73,0.73,15.726]},\"o\":{\"x\":[0.178,0.178,0.178],\"y\":[0.111,0.111,-6.062]},\"t\":55,\"s\":[96,96,100]},{\"i\":{\"x\":[0.684,0.684,0.684],\"y\":[0.887,0.887,2.97]},\"o\":{\"x\":[0.341,0.341,0.341],\"y\":[0.595,0.595,-10.349]},\"t\":62,\"s\":[42.926,42.926,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.178]},\"o\":{\"x\":[0.346,0.346,0.346],\"y\":[0.078,0.078,-1.436]},\"t\":68,\"s\":[25.997,25.997,100]},{\"t\":72,\"s\":[8,8,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[2.704,-2.474],[-2.473,-2.704],[-2.704,2.474],[2.474,2.704]],\"o\":[[-2.704,2.473],[2.474,2.705],[2.705,-2.473],[-2.473,-2.704]],\"v\":[[-4.479,-4.897],[-4.897,4.478],[4.478,4.896],[4.896,-4.479]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1438.868,595.429],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-0.106,-3.904],[3.913,-0.106],[0.106,3.904],[-3.914,0.106]],\"o\":[[0.106,3.904],[-3.914,0.106],[-0.106,-3.904],[3.913,-0.106]],\"v\":[[7.087,-0.193],[0.193,7.069],[-7.087,0.193],[-0.192,-7.068]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.023529413635,0.827451040231,0.486274539723,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1438.868,595.43],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":55,\"op\":73,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":191,\"ty\":4,\"nm\":\"blast 2 3 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.585,\"y\":0.73},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":55,\"s\":[891.55,492.31,0],\"to\":[4.275,-5.344,0],\"ti\":[-10.385,12.981,0]},{\"i\":{\"x\":0.684,\"y\":0.887},\"o\":{\"x\":0.341,\"y\":0.595},\"t\":62,\"s\":[921.451,454.934,0],\"to\":[4.567,-5.708,0],\"ti\":[-1.343,1.679,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.346,\"y\":0.355},\"t\":68,\"s\":[930.988,443.012,0],\"to\":[0.366,-0.457,0],\"ti\":[0,0,0]},{\"t\":72,\"s\":[933.3,440.31,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1473.05,564.268,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.585,0.585,0.585],\"y\":[0.73,0.73,15.726]},\"o\":{\"x\":[0.178,0.178,0.178],\"y\":[0.111,0.111,-6.062]},\"t\":55,\"s\":[96,96,100]},{\"i\":{\"x\":[0.684,0.684,0.684],\"y\":[0.887,0.887,2.97]},\"o\":{\"x\":[0.341,0.341,0.341],\"y\":[0.595,0.595,-10.349]},\"t\":62,\"s\":[42.926,42.926,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.178]},\"o\":{\"x\":[0.346,0.346,0.346],\"y\":[0.078,0.078,-1.436]},\"t\":68,\"s\":[25.997,25.997,100]},{\"t\":72,\"s\":[8,8,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[2.704,-2.474],[-2.473,-2.704],[-2.704,2.474],[2.474,2.704]],\"o\":[[-2.704,2.474],[2.474,2.705],[2.705,-2.473],[-2.473,-2.704]],\"v\":[[-4.479,-4.897],[-4.897,4.478],[4.478,4.896],[4.896,-4.479]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1473.038,562.335],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-0.106,-3.904],[3.913,-0.106],[0.106,3.904],[-3.914,0.106]],\"o\":[[0.106,3.904],[-3.914,0.107],[-0.106,-3.904],[3.913,-0.106]],\"v\":[[7.087,-0.193],[0.193,7.068],[-7.087,0.192],[-0.192,-7.069]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.023529413635,0.827451040231,0.486274539723,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1473.038,562.335],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":55,\"op\":73,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":192,\"ty\":4,\"nm\":\"blast 2 4 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.585,\"y\":0.73},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":55,\"s\":[856.55,491.31,0],\"to\":[-5.344,-5.718,0],\"ti\":[12.981,13.89,0]},{\"i\":{\"x\":0.684,\"y\":0.887},\"o\":{\"x\":0.341,\"y\":0.595},\"t\":62,\"s\":[819.174,451.318,0],\"to\":[-5.702,-6.101,0],\"ti\":[1.684,1.801,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.346,\"y\":0.514},\"t\":68,\"s\":[807.258,438.568,0],\"to\":[-0.461,-0.493,0],\"ti\":[0,0,0]},{\"t\":72,\"s\":[805.3,436.56,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1436.592,563.227,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.585,0.585,0.585],\"y\":[0.73,0.73,15.726]},\"o\":{\"x\":[0.178,0.178,0.178],\"y\":[0.111,0.111,-6.062]},\"t\":55,\"s\":[96,96,100]},{\"i\":{\"x\":[0.684,0.684,0.684],\"y\":[0.887,0.887,2.97]},\"o\":{\"x\":[0.341,0.341,0.341],\"y\":[0.595,0.595,-10.349]},\"t\":62,\"s\":[42.926,42.926,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.178]},\"o\":{\"x\":[0.346,0.346,0.346],\"y\":[0.078,0.078,-1.436]},\"t\":68,\"s\":[25.997,25.997,100]},{\"t\":72,\"s\":[8,8,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[2.704,-2.474],[2.473,2.704],[-2.705,2.473],[-2.474,-2.705]],\"o\":[[-2.704,2.473],[-2.474,-2.704],[2.704,-2.474],[2.473,2.704]],\"v\":[[4.479,4.897],[-4.896,4.479],[-4.478,-4.896],[4.897,-4.478]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1437.098,562.028],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-0.099,-3.661],[3.67,-0.1],[0.099,3.661],[-3.671,0.1]],\"o\":[[0.099,3.661],[-3.671,0.1],[-0.1,-3.661],[3.67,-0.1]],\"v\":[[6.647,-0.181],[0.181,6.63],[-6.646,0.18],[-0.179,-6.63]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.023529413635,0.827451040231,0.486274539723,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1437.554,561.731],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":55,\"op\":73,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":193,\"ty\":4,\"nm\":\"blast 2 5 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.585,\"y\":0.73},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":55,\"s\":[827.55,418.31,0],\"to\":[-7.481,-13.894,0],\"ti\":[18.173,33.751,0]},{\"i\":{\"x\":0.684,\"y\":0.887},\"o\":{\"x\":0.341,\"y\":0.595},\"t\":62,\"s\":[775.224,321.133,0],\"to\":[-7.992,-14.841,0],\"ti\":[2.351,4.365,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.346,\"y\":0.451},\"t\":68,\"s\":[758.533,290.136,0],\"to\":[-0.64,-1.188,0],\"ti\":[0,0,0]},{\"t\":72,\"s\":[755.3,284.56,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1406.383,487.185,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.585,0.585,0.585],\"y\":[0.73,0.73,15.726]},\"o\":{\"x\":[0.178,0.178,0.178],\"y\":[0.111,0.111,-6.062]},\"t\":55,\"s\":[96,96,100]},{\"i\":{\"x\":[0.684,0.684,0.684],\"y\":[0.887,0.887,2.97]},\"o\":{\"x\":[0.341,0.341,0.341],\"y\":[0.595,0.595,-10.349]},\"t\":62,\"s\":[42.926,42.926,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.178]},\"o\":{\"x\":[0.346,0.346,0.346],\"y\":[0.078,0.078,-1.436]},\"t\":68,\"s\":[25.997,25.997,100]},{\"t\":72,\"s\":[8,8,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-13.562,12.591]],\"o\":[[0,0],[16.963,-9.971]],\"v\":[[21.899,38.156],[-8.337,-28.185]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1414.193,507.89],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.233,1.874],[3.006,6.37],[10.549,-3.778],[-3.765,-7.918]],\"o\":[[0,0],[-3.005,-6.371],[-7.147,2.416],[5.357,11.266]],\"v\":[[18.284,33.761],[8.597,-6.751],[-11.37,-31.857],[-5.823,-2.135]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.960784373564,0.549019607843,0.992156922583,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1417.226,511.562],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":55,\"op\":73,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":194,\"ty\":4,\"nm\":\"blast 2 6 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.585,\"y\":0.73},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":55,\"s\":[825.55,369.31,0],\"to\":[-1.176,-9.94,0],\"ti\":[2.856,24.145,0]},{\"i\":{\"x\":0.684,\"y\":0.887},\"o\":{\"x\":0.341,\"y\":0.595},\"t\":62,\"s\":[817.327,299.791,0],\"to\":[-1.256,-10.617,0],\"ti\":[0.369,3.123,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.346,\"y\":0.515},\"t\":68,\"s\":[814.705,277.616,0],\"to\":[-0.101,-0.85,0],\"ti\":[0,0,0]},{\"t\":72,\"s\":[814.3,274.06,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1404.3,436.143,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.585,0.585,0.585],\"y\":[0.73,0.73,15.726]},\"o\":{\"x\":[0.178,0.178,0.178],\"y\":[0.111,0.111,-6.062]},\"t\":55,\"s\":[96,96,100]},{\"i\":{\"x\":[0.684,0.684,0.684],\"y\":[0.887,0.887,2.97]},\"o\":{\"x\":[0.341,0.341,0.341],\"y\":[0.595,0.595,-10.349]},\"t\":62,\"s\":[42.926,42.926,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.178]},\"o\":{\"x\":[0.346,0.346,0.346],\"y\":[0.078,0.078,-1.436]},\"t\":68,\"s\":[25.997,25.997,100]},{\"t\":72,\"s\":[8,8,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[5.409,-4.947],[4.947,5.409],[-5.408,4.947],[-4.947,-5.408]],\"o\":[[-5.409,4.947],[-4.947,-5.409],[5.409,-4.947],[4.947,5.409]],\"v\":[[8.958,9.793],[-9.794,8.957],[-8.958,-9.793],[9.793,-8.957]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1405.213,436.34],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-0.192,-7.052],[7.052,-0.191],[0.192,7.052],[-7.053,0.192]],\"o\":[[0.192,7.052],[-7.053,0.192],[-0.191,-7.053],[7.052,-0.191]],\"v\":[[12.769,-0.347],[0.347,12.769],[-12.77,0.347],[-0.347,-12.77]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1404.854,436.454],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":55,\"op\":73,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":195,\"ty\":4,\"nm\":\"blast 2 7 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.585,\"y\":0.73},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":55,\"s\":[769.55,394.31,0],\"to\":[-7.481,-6.092,0],\"ti\":[18.173,14.798,0]},{\"i\":{\"x\":0.684,\"y\":0.887},\"o\":{\"x\":0.341,\"y\":0.595},\"t\":62,\"s\":[717.224,351.701,0],\"to\":[-7.992,-6.507,0],\"ti\":[2.351,1.914,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.346,\"y\":0.384},\"t\":68,\"s\":[700.533,338.111,0],\"to\":[-0.64,-0.521,0],\"ti\":[0,0,0]},{\"t\":72,\"s\":[697.05,335.06,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1345.967,462.185,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.585,0.585,0.585],\"y\":[0.73,0.73,15.726]},\"o\":{\"x\":[0.178,0.178,0.178],\"y\":[0.111,0.111,-6.062]},\"t\":55,\"s\":[96,96,100]},{\"i\":{\"x\":[0.684,0.684,0.684],\"y\":[0.887,0.887,2.97]},\"o\":{\"x\":[0.341,0.341,0.341],\"y\":[0.595,0.595,-10.349]},\"t\":62,\"s\":[42.926,42.926,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.178]},\"o\":{\"x\":[0.346,0.346,0.346],\"y\":[0.078,0.078,-1.436]},\"t\":68,\"s\":[25.997,25.997,100]},{\"t\":72,\"s\":[8,8,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-3.76,4.676],[0,0],[0.683,2.282],[0,0],[-5.609,-2.131],[0,0],[-1.959,1.355],[0,0],[0.293,-5.993],[0,0],[-1.894,-1.445],[0,0],[5.79,-1.574],[0,0],[0.789,-2.249],[0,0],[3.286,5.021],[0,0],[2.382,0.055],[0,0]],\"o\":[[0,0],[1.492,-1.857],[0,0],[-1.72,-5.748],[0,0],[2.227,0.846],[0,0],[4.935,-3.413],[0,0],[-0.116,2.38],[0,0],[4.771,3.639],[0,0],[-2.299,0.624],[0,0],[-1.987,5.662],[0,0],[-1.305,-1.994],[0,0],[-5.999,-0.14]],\"v\":[[-33.732,6.479],[-26.068,-3.053],[-24.775,-9.665],[-28.283,-21.382],[-18.777,-30.226],[-7.343,-25.883],[-0.655,-26.696],[9.405,-33.653],[20.753,-27.345],[20.156,-15.129],[22.996,-9.019],[32.721,-1.602],[30.229,11.141],[18.426,14.348],[13.493,18.937],[9.444,30.478],[-3.445,32.045],[-10.142,21.811],[-16.031,18.538],[-28.258,18.253]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1345.567,460.847],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-5.326,1.887],[0,0],[-3.732,1.425],[-2.4,4.839],[2.968,1.904],[0.804,8.748],[6.022,1.712],[4.4,-0.179],[8.145,-4.083],[2.803,-7.027],[-0.88,-4.236],[-4.236,0.88],[-3.019,-3.272]],\"o\":[[0,0],[5.327,-1.886],[0,0],[3.733,-1.425],[2.399,-4.838],[-2.969,-1.904],[-0.803,-8.748],[-6.022,-1.712],[-4.4,0.179],[-8.144,4.083],[-2.803,7.028],[0.88,4.235],[4.235,-0.88],[3.019,3.272]],\"v\":[[-6.509,28.677],[3.445,34.432],[11.163,25.293],[16.55,14.064],[33.754,6.668],[29.16,-4.436],[19.45,-18.897],[15.251,-34.608],[-3.454,-26.434],[-26.25,-28.821],[-26.489,-4.574],[-35.274,12.82],[-25.277,17.527],[-10.726,21.262]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.023529413635,0.827451040231,0.486274539723,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1346.077,461.219],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":55,\"op\":73,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":196,\"ty\":4,\"nm\":\"blast 2 8 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.585,\"y\":0.73},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":55,\"s\":[783.55,457.31,0],\"to\":[-12.932,-6.733,0],\"ti\":[31.414,16.356,0]},{\"i\":{\"x\":0.684,\"y\":0.887},\"o\":{\"x\":0.341,\"y\":0.595},\"t\":62,\"s\":[693.1,410.216,0],\"to\":[-13.814,-7.192,0],\"ti\":[4.063,2.115,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.346,\"y\":0.47},\"t\":68,\"s\":[664.25,395.195,0],\"to\":[-1.106,-0.576,0],\"ti\":[0,0,0]},{\"t\":72,\"s\":[659.05,392.81,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1360.55,527.81,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.585,0.585,0.585],\"y\":[0.73,0.73,15.726]},\"o\":{\"x\":[0.178,0.178,0.178],\"y\":[0.111,0.111,-6.062]},\"t\":55,\"s\":[96,96,100]},{\"i\":{\"x\":[0.684,0.684,0.684],\"y\":[0.887,0.887,2.97]},\"o\":{\"x\":[0.341,0.341,0.341],\"y\":[0.595,0.595,-10.349]},\"t\":62,\"s\":[42.926,42.926,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.178]},\"o\":{\"x\":[0.346,0.346,0.346],\"y\":[0.078,0.078,-1.436]},\"t\":68,\"s\":[25.997,25.997,100]},{\"t\":72,\"s\":[8,8,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-3.188,18.229]],\"o\":[[0,0],[7.481,-18.2]],\"v\":[[33.693,26.378],[-30.505,-8.178]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1385.5,532.992],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[6.246,3.257],[6.117,-9.388],[-8.284,-2.869]],\"o\":[[0,0],[-6.246,-3.256],[-4.232,6.246],[10.787,4.659]],\"v\":[[34.215,21.972],[-0.293,-5.805],[-29.982,-12.584],[-7.594,7.734]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.960784373564,0.549019607843,0.992156922583,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1384.978,537.398],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":55,\"op\":73,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":197,\"ty\":4,\"nm\":\"blast 2 9 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.585,\"y\":0.73},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":55,\"s\":[743.55,451.31,0],\"to\":[-11.222,-0.641,0],\"ti\":[27.26,1.558,0]},{\"i\":{\"x\":0.684,\"y\":0.887},\"o\":{\"x\":0.341,\"y\":0.595},\"t\":62,\"s\":[665.061,446.825,0],\"to\":[-11.987,-0.685,0],\"ti\":[3.526,0.201,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.346,\"y\":0.515},\"t\":68,\"s\":[640.025,445.394,0],\"to\":[-0.96,-0.055,0],\"ti\":[0,0,0]},{\"t\":72,\"s\":[636.05,444.81,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1318.883,521.56,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.585,0.585,0.585],\"y\":[0.73,0.73,15.726]},\"o\":{\"x\":[0.178,0.178,0.178],\"y\":[0.111,0.111,-6.062]},\"t\":55,\"s\":[96,96,100]},{\"i\":{\"x\":[0.684,0.684,0.684],\"y\":[0.887,0.887,2.97]},\"o\":{\"x\":[0.341,0.341,0.341],\"y\":[0.595,0.595,-10.349]},\"t\":62,\"s\":[42.926,42.926,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.178]},\"o\":{\"x\":[0.346,0.346,0.346],\"y\":[0.078,0.078,-1.436]},\"t\":68,\"s\":[25.997,25.997,100]},{\"t\":72,\"s\":[8,8,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-5.409,4.947],[4.947,5.409],[5.409,-4.947],[-4.947,-5.409]],\"o\":[[5.409,-4.947],[-4.947,-5.408],[-5.408,4.947],[4.947,5.409]],\"v\":[[8.958,9.793],[9.794,-8.958],[-8.957,-9.794],[-9.793,8.957]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1320.305,521.328],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-0.192,-7.052],[7.052,-0.191],[0.192,7.052],[-7.053,0.192]],\"o\":[[0.192,7.052],[-7.053,0.192],[-0.191,-7.053],[7.052,-0.191]],\"v\":[[12.769,-0.347],[0.347,12.769],[-12.77,0.347],[-0.347,-12.77]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1320.306,521.328],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":55,\"op\":73,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":198,\"ty\":4,\"nm\":\"blast 2 10 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.585,\"y\":0.73},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":55,\"s\":[704.55,506.31,0],\"to\":[-10.474,0,0],\"ti\":[25.443,0,0]},{\"i\":{\"x\":0.684,\"y\":0.887},\"o\":{\"x\":0.341,\"y\":0.595},\"t\":62,\"s\":[631.293,506.31,0],\"to\":[-11.188,0,0],\"ti\":[3.291,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.346,\"y\":0.441},\"t\":68,\"s\":[607.927,506.31,0],\"to\":[-0.896,0,0],\"ti\":[0,0,0]},{\"t\":72,\"s\":[603.55,506.31,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1278.258,578.852,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.585,0.585,0.585],\"y\":[0.73,0.73,15.726]},\"o\":{\"x\":[0.178,0.178,0.178],\"y\":[0.111,0.111,-6.062]},\"t\":55,\"s\":[96,96,100]},{\"i\":{\"x\":[0.684,0.684,0.684],\"y\":[0.887,0.887,2.97]},\"o\":{\"x\":[0.341,0.341,0.341],\"y\":[0.595,0.595,-10.349]},\"t\":62,\"s\":[42.926,42.926,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.178]},\"o\":{\"x\":[0.346,0.346,0.346],\"y\":[0.078,0.078,-1.436]},\"t\":68,\"s\":[25.997,25.997,100]},{\"t\":72,\"s\":[8,8,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-2.931,-28.71]],\"o\":[[0,0],[2.378,26.368]],\"v\":[[87.926,1.659],[-84.995,1.171]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1352.926,577.611],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[35.313,-1.122],[0,0],[-13.648,-1.489],[-27.388,-0.256]],\"o\":[[0,0],[-56.986,-4.48],[0,0],[13.648,1.489],[27.388,0.256]],\"v\":[[88.769,2.97],[-31.783,-9.628],[-82.888,2.946],[-66.261,12.231],[-19.944,13.852]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.807843197093,0.298039215686,0.847058883368,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1351.123,576.443],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":55,\"op\":73,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":199,\"ty\":4,\"nm\":\"blast 2 11 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.585,\"y\":0.73},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":55,\"s\":[737.55,556.31,0],\"to\":[-10.581,1.069,0],\"ti\":[25.702,-2.596,0]},{\"i\":{\"x\":0.684,\"y\":0.887},\"o\":{\"x\":0.341,\"y\":0.595},\"t\":62,\"s\":[663.546,563.785,0],\"to\":[-11.302,1.142,0],\"ti\":[3.324,-0.336,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.346,\"y\":0.568},\"t\":68,\"s\":[639.941,566.17,0],\"to\":[-0.905,0.091,0],\"ti\":[0,0,0]},{\"t\":72,\"s\":[636.55,566.81,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1312.633,630.935,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.585,0.585,0.585],\"y\":[0.73,0.73,15.726]},\"o\":{\"x\":[0.178,0.178,0.178],\"y\":[0.111,0.111,-6.062]},\"t\":55,\"s\":[96,96,100]},{\"i\":{\"x\":[0.684,0.684,0.684],\"y\":[0.887,0.887,2.97]},\"o\":{\"x\":[0.341,0.341,0.341],\"y\":[0.595,0.595,-10.349]},\"t\":62,\"s\":[42.926,42.926,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.178]},\"o\":{\"x\":[0.346,0.346,0.346],\"y\":[0.078,0.078,-1.436]},\"t\":68,\"s\":[25.997,25.997,100]},{\"t\":72,\"s\":[8,8,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-5.409,4.947],[4.947,5.409],[5.409,-4.947],[-4.947,-5.409]],\"o\":[[5.409,-4.947],[-4.947,-5.408],[-5.408,4.947],[4.947,5.409]],\"v\":[[8.958,9.794],[9.793,-8.957],[-8.958,-9.794],[-9.794,8.957]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1313.831,629.936],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-0.192,-7.052],[7.053,-0.191],[0.192,7.052],[-7.053,0.192]],\"o\":[[0.192,7.052],[-7.052,0.192],[-0.191,-7.053],[7.052,-0.191]],\"v\":[[12.769,-0.347],[0.346,12.769],[-12.77,0.347],[-0.347,-12.77]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1313.831,629.937],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":55,\"op\":73,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":200,\"ty\":4,\"nm\":\"blast 2 12 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.585,\"y\":0.73},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":55,\"s\":[782.55,555.31,0],\"to\":[-10.581,4.809,0],\"ti\":[25.702,-11.683,0]},{\"i\":{\"x\":0.684,\"y\":0.887},\"o\":{\"x\":0.341,\"y\":0.595},\"t\":62,\"s\":[708.546,588.948,0],\"to\":[-11.302,5.137,0],\"ti\":[3.324,-1.511,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.346,\"y\":0.369},\"t\":68,\"s\":[684.941,599.678,0],\"to\":[-0.905,0.411,0],\"ti\":[0,0,0]},{\"t\":72,\"s\":[679.55,601.81,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1359.508,629.893,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.585,0.585,0.585],\"y\":[0.73,0.73,15.726]},\"o\":{\"x\":[0.178,0.178,0.178],\"y\":[0.111,0.111,-6.062]},\"t\":55,\"s\":[96,96,100]},{\"i\":{\"x\":[0.684,0.684,0.684],\"y\":[0.887,0.887,2.97]},\"o\":{\"x\":[0.341,0.341,0.341],\"y\":[0.595,0.595,-10.349]},\"t\":62,\"s\":[42.926,42.926,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.178]},\"o\":{\"x\":[0.346,0.346,0.346],\"y\":[0.078,0.078,-1.436]},\"t\":68,\"s\":[25.997,25.997,100]},{\"t\":72,\"s\":[8,8,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-3.188,-18.229]],\"o\":[[0,0],[7.481,18.2]],\"v\":[[33.693,-26.378],[-30.505,8.178]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1380.634,627.286],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[6.246,-3.257],[6.117,9.388],[-8.284,2.869]],\"o\":[[0,0],[-6.246,3.256],[-4.232,-6.246],[13.033,-7.555]],\"v\":[[34.214,-21.972],[-2.356,7.445],[-29.983,12.584],[-7.594,-7.734]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.960784373564,0.549019607843,0.992156922583,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1380.112,622.88],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":55,\"op\":73,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":201,\"ty\":4,\"nm\":\"blast 2 13 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.585,\"y\":0.73},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":55,\"s\":[763.55,614.31,0],\"to\":[-6.199,6.52,0],\"ti\":[15.058,-15.837,0]},{\"i\":{\"x\":0.684,\"y\":0.887},\"o\":{\"x\":0.341,\"y\":0.595},\"t\":62,\"s\":[720.194,659.909,0],\"to\":[-6.622,6.964,0],\"ti\":[1.948,-2.048,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.346,\"y\":0.502},\"t\":68,\"s\":[706.365,674.453,0],\"to\":[-0.53,0.557,0],\"ti\":[0,0,0]},{\"t\":72,\"s\":[704.05,676.81,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1339.717,691.352,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.585,0.585,0.585],\"y\":[0.73,0.73,15.726]},\"o\":{\"x\":[0.178,0.178,0.178],\"y\":[0.111,0.111,-6.062]},\"t\":55,\"s\":[96,96,100]},{\"i\":{\"x\":[0.684,0.684,0.684],\"y\":[0.887,0.887,2.97]},\"o\":{\"x\":[0.341,0.341,0.341],\"y\":[0.595,0.595,-10.349]},\"t\":62,\"s\":[42.926,42.926,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.178]},\"o\":{\"x\":[0.346,0.346,0.346],\"y\":[0.078,0.078,-1.436]},\"t\":68,\"s\":[25.997,25.997,100]},{\"t\":72,\"s\":[8,8,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[4.591,3.864],[0,0],[2.297,-0.632],[0,0],[-2.256,5.56],[0,0],[1.311,1.99],[0,0],[-5.985,-0.428],[0,0],[-1.488,1.862],[0,0],[-1.443,-5.824],[0,0],[-2.23,-0.84],[0,0],[5.093,-3.172],[0,0],[0.109,-2.381],[0,0]],\"o\":[[0,0],[-1.823,-1.534],[0,0],[-5.785,1.592],[0,0],[0.896,-2.208],[0,0],[-3.301,-5.011],[0,0],[2.376,0.17],[0,0],[3.746,-4.688],[0,0],[0.573,2.313],[0,0],[5.616,2.113],[0,0],[-2.023,1.26],[0,0],[-0.275,5.994]],\"v\":[[5.561,33.721],[-3.796,25.845],[-10.378,24.404],[-22.171,27.647],[-30.799,17.945],[-26.2,6.612],[-26.863,-0.093],[-33.592,-10.306],[-27.031,-21.51],[-14.831,-20.639],[-8.659,-23.341],[-1.026,-32.897],[11.658,-30.119],[14.599,-18.247],[19.076,-13.212],[30.523,-8.905],[31.801,4.016],[21.419,10.481],[18.014,16.296],[17.455,28.513]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1343.514,691.035],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[1.717,5.383],[0,0],[1.307,3.776],[5.588,4.256],[1.997,-2.907],[8.769,-0.528],[1.9,-5.965],[-0.04,-4.403],[-3.824,-8.269],[-6.936,-3.023],[-4.726,2.564],[0.746,4.262],[-3.365,2.914]],\"o\":[[0,0],[-1.718,-5.383],[0,0],[-1.307,-3.775],[-5.589,-4.256],[-1.997,2.907],[-8.769,0.528],[-1.901,5.964],[0.04,4.404],[3.825,8.269],[6.936,3.022],[4.726,-2.563],[-0.746,-4.261],[3.365,-2.915]],\"v\":[[28.514,6.348],[34.58,-3.902],[25.687,-9.898],[14.633,-15.637],[7.784,-34.43],[-4.449,-27.833],[-16.63,-20.5],[-34.396,-16.819],[-26.474,3.082],[-29.577,25.792],[-5.349,24.753],[11.759,36.122],[17.771,25.286],[20.97,11.853]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.023529413635,0.827451040231,0.486274539723,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1343.733,690.662],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":55,\"op\":73,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":202,\"ty\":4,\"nm\":\"blast 2 14 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.585,\"y\":0.73},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":55,\"s\":[824.55,595.31,0],\"to\":[-5.664,11.008,0],\"ti\":[13.76,-26.741,0]},{\"i\":{\"x\":0.684,\"y\":0.887},\"o\":{\"x\":0.341,\"y\":0.595},\"t\":62,\"s\":[784.931,672.304,0],\"to\":[-6.051,11.759,0],\"ti\":[1.78,-3.459,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.346,\"y\":0.551},\"t\":68,\"s\":[772.295,696.863,0],\"to\":[-0.484,0.941,0],\"ti\":[0,0,0]},{\"t\":72,\"s\":[771.05,700.81,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1403.258,671.56,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.585,0.585,0.585],\"y\":[0.73,0.73,15.726]},\"o\":{\"x\":[0.178,0.178,0.178],\"y\":[0.111,0.111,-6.062]},\"t\":55,\"s\":[96,96,100]},{\"i\":{\"x\":[0.684,0.684,0.684],\"y\":[0.887,0.887,2.97]},\"o\":{\"x\":[0.341,0.341,0.341],\"y\":[0.595,0.595,-10.349]},\"t\":62,\"s\":[42.926,42.926,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.178]},\"o\":{\"x\":[0.346,0.346,0.346],\"y\":[0.078,0.078,-1.436]},\"t\":68,\"s\":[25.997,25.997,100]},{\"t\":72,\"s\":[8,8,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-13.562,-12.591]],\"o\":[[0,0],[16.963,9.971]],\"v\":[[21.899,-38.157],[-8.337,28.185]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1409.327,652.388],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[3.005,-6.37],[10.548,3.778],[-4.863,7.295]],\"o\":[[0,0],[-3.006,6.37],[-7.147,-2.416],[6.049,-10.666]],\"v\":[[18.691,-35.06],[7.876,9.18],[-11.544,31.282],[-5.998,1.56]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.960784373564,0.549019607843,0.992156922583,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1412.534,649.291],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":55,\"op\":73,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":203,\"ty\":4,\"nm\":\"blast 2 15 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.585,\"y\":0.73},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":55,\"s\":[824.55,659.31,0],\"to\":[-1.496,8.55,0],\"ti\":[3.635,-20.77,0]},{\"i\":{\"x\":0.684,\"y\":0.887},\"o\":{\"x\":0.341,\"y\":0.595},\"t\":62,\"s\":[814.085,719.112,0],\"to\":[-1.598,9.133,0],\"ti\":[0.47,-2.686,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.346,\"y\":0.434},\"t\":68,\"s\":[810.747,738.186,0],\"to\":[-0.128,0.731,0],\"ti\":[0,0,0]},{\"t\":72,\"s\":[810.05,741.81,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1403.258,738.227,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.585,0.585,0.585],\"y\":[0.73,0.73,15.726]},\"o\":{\"x\":[0.178,0.178,0.178],\"y\":[0.111,0.111,-6.062]},\"t\":55,\"s\":[96,96,100]},{\"i\":{\"x\":[0.684,0.684,0.684],\"y\":[0.887,0.887,2.97]},\"o\":{\"x\":[0.341,0.341,0.341],\"y\":[0.595,0.595,-10.349]},\"t\":62,\"s\":[42.926,42.926,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.178]},\"o\":{\"x\":[0.346,0.346,0.346],\"y\":[0.078,0.078,-1.436]},\"t\":68,\"s\":[25.997,25.997,100]},{\"t\":72,\"s\":[8,8,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-5.409,4.947],[4.947,5.409],[5.409,-4.947],[-4.947,-5.409]],\"o\":[[5.409,-4.947],[-4.947,-5.408],[-5.408,4.947],[4.947,5.409]],\"v\":[[8.958,9.794],[9.794,-8.957],[-8.957,-9.794],[-9.793,8.957]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1404.582,736.996],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-0.192,-7.052],[7.053,-0.191],[0.192,7.052],[-7.053,0.192]],\"o\":[[0.192,7.052],[-7.052,0.192],[-0.192,-7.053],[7.052,-0.191]],\"v\":[[12.77,-0.347],[0.346,12.769],[-12.77,0.347],[-0.347,-12.77]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1404.582,736.996],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":55,\"op\":73,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":204,\"ty\":4,\"nm\":\"blast 2 16 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.585,\"y\":0.73},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":55,\"s\":[872.55,677.31,0],\"to\":[-0.107,9.726,0],\"ti\":[0.26,-23.625,0]},{\"i\":{\"x\":0.684,\"y\":0.887},\"o\":{\"x\":0.341,\"y\":0.595},\"t\":62,\"s\":[871.802,745.334,0],\"to\":[-0.114,10.389,0],\"ti\":[0.034,-3.056,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.346,\"y\":0.419},\"t\":68,\"s\":[871.564,767.032,0],\"to\":[-0.009,0.832,0],\"ti\":[0,0,0]},{\"t\":72,\"s\":[871.55,771.31,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1453.258,756.977,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.585,0.585,0.585],\"y\":[0.73,0.73,15.726]},\"o\":{\"x\":[0.178,0.178,0.178],\"y\":[0.111,0.111,-6.062]},\"t\":55,\"s\":[96,96,100]},{\"i\":{\"x\":[0.684,0.684,0.684],\"y\":[0.887,0.887,2.97]},\"o\":{\"x\":[0.341,0.341,0.341],\"y\":[0.595,0.595,-10.349]},\"t\":62,\"s\":[42.926,42.926,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.178]},\"o\":{\"x\":[0.346,0.346,0.346],\"y\":[0.078,0.078,-1.436]},\"t\":68,\"s\":[25.997,25.997,100]},{\"t\":72,\"s\":[8,8,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-28.71,2.931]],\"o\":[[0,0],[26.368,-2.378]],\"v\":[[1.659,-87.926],[1.171,84.995]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1454.02,684.24],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-1.122,-35.313],[0,0],[-2.886,16.639],[-0.256,27.388]],\"o\":[[0,0],[-3.333,55.614],[0,0],[1.489,-13.648],[0.256,-27.387]],\"v\":[[1.771,-88.563],[-10.201,32.949],[1.765,84.054],[11.658,67.427],[13.279,21.11]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.807843197093,0.298039215686,0.847058883368,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1453.426,684.877],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":55,\"op\":73,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":205,\"ty\":4,\"nm\":\"blast 2 17 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.585,\"y\":0.73},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":55,\"s\":[922.55,657.31,0],\"to\":[1.176,8.764,0],\"ti\":[-2.856,-21.289,0]},{\"i\":{\"x\":0.684,\"y\":0.887},\"o\":{\"x\":0.341,\"y\":0.595},\"t\":62,\"s\":[930.773,718.607,0],\"to\":[1.256,9.362,0],\"ti\":[-0.369,-2.753,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.346,\"y\":0.439},\"t\":68,\"s\":[933.395,738.158,0],\"to\":[0.101,0.749,0],\"ti\":[0,0,0]},{\"t\":72,\"s\":[934.05,741.81,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1505.342,736.143,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.585,0.585,0.585],\"y\":[0.73,0.73,15.726]},\"o\":{\"x\":[0.178,0.178,0.178],\"y\":[0.111,0.111,-6.062]},\"t\":55,\"s\":[96,96,100]},{\"i\":{\"x\":[0.684,0.684,0.684],\"y\":[0.887,0.887,2.97]},\"o\":{\"x\":[0.341,0.341,0.341],\"y\":[0.595,0.595,-10.349]},\"t\":62,\"s\":[42.926,42.926,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.178]},\"o\":{\"x\":[0.346,0.346,0.346],\"y\":[0.078,0.078,-1.436]},\"t\":68,\"s\":[25.997,25.997,100]},{\"t\":72,\"s\":[8,8,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-5.409,4.947],[4.947,5.409],[5.409,-4.947],[-4.947,-5.409]],\"o\":[[5.409,-4.947],[-4.947,-5.408],[-5.408,4.947],[4.947,5.409]],\"v\":[[8.958,9.794],[9.794,-8.957],[-8.957,-9.793],[-9.793,8.958]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1505.89,736.111],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-0.192,-7.052],[7.052,-0.191],[0.192,7.052],[-7.053,0.192]],\"o\":[[0.192,7.052],[-7.053,0.192],[-0.191,-7.053],[7.052,-0.191]],\"v\":[[12.769,-0.347],[0.347,12.769],[-12.77,0.347],[-0.347,-12.77]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1505.891,736.111],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":55,\"op\":73,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":206,\"ty\":4,\"nm\":\"blast 2 18 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.585,\"y\":0.73},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":55,\"s\":[918.55,598.31,0],\"to\":[4.596,10.688,0],\"ti\":[-11.164,-25.962,0]},{\"i\":{\"x\":0.684,\"y\":0.887},\"o\":{\"x\":0.341,\"y\":0.595},\"t\":62,\"s\":[950.693,673.062,0],\"to\":[4.909,11.417,0],\"ti\":[-1.444,-3.358,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.346,\"y\":0.535},\"t\":68,\"s\":[960.946,696.905,0],\"to\":[0.393,0.914,0],\"ti\":[0,0,0]},{\"t\":72,\"s\":[963.05,700.31,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1501.175,674.685,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.585,0.585,0.585],\"y\":[0.73,0.73,15.726]},\"o\":{\"x\":[0.178,0.178,0.178],\"y\":[0.111,0.111,-6.062]},\"t\":55,\"s\":[96,96,100]},{\"i\":{\"x\":[0.684,0.684,0.684],\"y\":[0.887,0.887,2.97]},\"o\":{\"x\":[0.341,0.341,0.341],\"y\":[0.595,0.595,-10.349]},\"t\":62,\"s\":[42.926,42.926,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.178]},\"o\":{\"x\":[0.346,0.346,0.346],\"y\":[0.078,0.078,-1.436]},\"t\":68,\"s\":[25.997,25.997,100]},{\"t\":72,\"s\":[8,8,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[13.562,-12.591]],\"o\":[[0,0],[-16.963,9.971]],\"v\":[[-21.899,-38.156],[8.336,28.186]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1498.37,655.927],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-3.005,-6.37],[-10.549,3.778],[4.863,7.294]],\"o\":[[0,0],[3.006,6.37],[7.147,-2.415],[-4.971,-12.05]],\"v\":[[-18.392,-34.688],[-9.232,5.486],[11.245,30.91],[5.699,1.189]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.960784373564,0.549019607843,0.992156922583,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1495.461,653.202],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":55,\"op\":73,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":207,\"ty\":4,\"nm\":\"blast 2 19 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.585,\"y\":0.73},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":55,\"s\":[981.55,623.31,0],\"to\":[5.237,6.52,0],\"ti\":[-12.721,-15.837,0]},{\"i\":{\"x\":0.684,\"y\":0.887},\"o\":{\"x\":0.341,\"y\":0.595},\"t\":62,\"s\":[1018.178,668.909,0],\"to\":[5.594,6.964,0],\"ti\":[-1.645,-2.048,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.346,\"y\":0.479},\"t\":68,\"s\":[1029.862,683.453,0],\"to\":[0.448,0.557,0],\"ti\":[0,0,0]},{\"t\":72,\"s\":[1032.05,685.81,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1566.8,700.727,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.585,0.585,0.585],\"y\":[0.73,0.73,15.726]},\"o\":{\"x\":[0.178,0.178,0.178],\"y\":[0.111,0.111,-6.062]},\"t\":55,\"s\":[96,96,100]},{\"i\":{\"x\":[0.684,0.684,0.684],\"y\":[0.887,0.887,2.97]},\"o\":{\"x\":[0.341,0.341,0.341],\"y\":[0.595,0.595,-10.349]},\"t\":62,\"s\":[42.926,42.926,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.178]},\"o\":{\"x\":[0.346,0.346,0.346],\"y\":[0.078,0.078,-1.436]},\"t\":68,\"s\":[25.997,25.997,100]},{\"t\":72,\"s\":[8,8,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-3.656,-4.758],[0,0],[-2.38,0.125],[0,0],[3.395,-4.947],[0,0],[-0.854,-2.224],[0,0],[5.754,1.7],[0,0],[1.852,-1.5],[0,0],[0.161,5.998],[0,0],[1.998,1.298],[0,0],[-5.655,2.007],[0,0],[-0.617,2.301],[0,0]],\"o\":[[0,0],[1.452,1.889],[0,0],[5.993,-0.314],[0,0],[-1.348,1.965],[0,0],[2.151,5.602],[0,0],[-2.285,-0.675],[0,0],[-4.663,3.777],[0,0],[-0.064,-2.382],[0,0],[-5.032,-3.268],[0,0],[2.245,-0.797],[0,0],[1.553,-5.796]],\"v\":[[1.511,-32.75],[8.963,-23.052],[15.083,-20.233],[27.296,-20.874],[33.645,-9.548],[26.724,0.536],[25.934,7.227],[30.318,18.645],[21.508,28.183],[9.779,24.717],[3.171,26.034],[-6.333,33.731],[-18.126,28.3],[-18.455,16.074],[-21.749,10.196],[-32.007,3.536],[-30.485,-9.359],[-18.959,-13.449],[-14.387,-18.398],[-11.223,-30.212]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1565.249,697.915],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-5.501,-1.29],[0,0],[-3.911,-0.817],[-4.633,2.775],[1.469,3.207],[-4.049,7.796],[4.142,4.694],[3.799,2.227],[9.059,0.963],[6.155,-4.4],[1.548,-4.04],[-4.039,-1.548],[-0.774,-4.384]],\"o\":[[0,0],[5.501,1.29],[0,0],[3.911,0.817],[4.634,-2.776],[-1.47,-3.206],[6.465,-9.184],[-4.143,-4.694],[-3.8,-2.226],[-9.06,-0.964],[-6.155,4.4],[-1.547,4.04],[4.04,1.547],[0.773,4.384]],\"v\":[[-19.47,23.75],[-14.202,34.974],[-2.769,30.448],[7.83,23.908],[26.301,26.979],[28.435,15.151],[26.56,-0.748],[32.517,-18.825],[10.649,-21.64],[-5.022,-35.3],[-18.322,-15.025],[-35.111,-6.267],[-29.423,5.233],[-19.013,15.232]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.023529413635,0.827451040231,0.486274539723,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1565.869,698.298],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":55,\"op\":73,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":208,\"ty\":4,\"nm\":\"blast 2 20 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.585,\"y\":0.73},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":55,\"s\":[1005.55,566.31,0],\"to\":[9.405,0,0],\"ti\":[-22.847,0,0]},{\"i\":{\"x\":0.684,\"y\":0.887},\"o\":{\"x\":0.341,\"y\":0.595},\"t\":62,\"s\":[1071.332,566.31,0],\"to\":[10.047,0,0],\"ti\":[-2.955,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.346,\"y\":0.536},\"t\":68,\"s\":[1092.314,566.31,0],\"to\":[0.804,0,0],\"ti\":[0,0,0]},{\"t\":72,\"s\":[1095.55,566.31,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1591.8,641.352,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.585,0.585,0.585],\"y\":[0.73,0.73,15.726]},\"o\":{\"x\":[0.178,0.178,0.178],\"y\":[0.111,0.111,-6.062]},\"t\":55,\"s\":[96,96,100]},{\"i\":{\"x\":[0.684,0.684,0.684],\"y\":[0.887,0.887,2.97]},\"o\":{\"x\":[0.341,0.341,0.341],\"y\":[0.595,0.595,-10.349]},\"t\":62,\"s\":[42.926,42.926,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.178]},\"o\":{\"x\":[0.346,0.346,0.346],\"y\":[0.078,0.078,-1.436]},\"t\":68,\"s\":[25.997,25.997,100]},{\"t\":72,\"s\":[8,8,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[5.409,-4.947],[-4.947,-5.409],[-5.409,4.947],[4.947,5.409]],\"o\":[[-5.409,4.947],[4.947,5.408],[5.408,-4.947],[-4.947,-5.409]],\"v\":[[-8.958,-9.794],[-9.794,8.958],[8.957,9.793],[9.793,-8.958]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1592.422,641.021],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-0.192,-7.052],[7.053,-0.191],[0.192,7.052],[-7.053,0.192]],\"o\":[[0.192,7.052],[-7.052,0.192],[-0.192,-7.053],[7.052,-0.191]],\"v\":[[12.77,-0.347],[0.347,12.769],[-12.769,0.347],[-0.346,-12.77]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1592.095,640.425],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":55,\"op\":73,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":209,\"ty\":4,\"nm\":\"blast 2 21 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.585,\"y\":0.73},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":55,\"s\":[963.55,561.31,0],\"to\":[10.046,5.451,0],\"ti\":[-24.404,-13.241,0]},{\"i\":{\"x\":0.684,\"y\":0.887},\"o\":{\"x\":0.341,\"y\":0.595},\"t\":62,\"s\":[1033.817,599.433,0],\"to\":[10.732,5.822,0],\"ti\":[-3.156,-1.713,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.346,\"y\":0.477},\"t\":68,\"s\":[1056.229,611.594,0],\"to\":[0.859,0.466,0],\"ti\":[0,0,0]},{\"t\":72,\"s\":[1060.05,613.81,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1548.05,636.143,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.585,0.585,0.585],\"y\":[0.73,0.73,15.726]},\"o\":{\"x\":[0.178,0.178,0.178],\"y\":[0.111,0.111,-6.062]},\"t\":55,\"s\":[96,96,100]},{\"i\":{\"x\":[0.684,0.684,0.684],\"y\":[0.887,0.887,2.97]},\"o\":{\"x\":[0.341,0.341,0.341],\"y\":[0.595,0.595,-10.349]},\"t\":62,\"s\":[42.926,42.926,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.178]},\"o\":{\"x\":[0.346,0.346,0.346],\"y\":[0.078,0.078,-1.436]},\"t\":68,\"s\":[25.997,25.997,100]},{\"t\":72,\"s\":[8,8,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[3.188,-18.229]],\"o\":[[0,0],[-7.481,18.2]],\"v\":[[-33.692,-26.378],[30.505,8.178]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1527.063,630.825],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-6.246,-3.257],[-6.117,9.388],[8.284,2.869]],\"o\":[[0,0],[6.246,3.256],[4.232,-6.246],[-10.242,-4.454]],\"v\":[[-34.214,-21.972],[0,5.66],[29.982,12.584],[7.594,-7.734]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.960784373564,0.549019607843,0.992156922583,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1527.585,626.419],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":55,\"op\":73,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":210,\"ty\":4,\"nm\":\"blast 2 22 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.585,\"y\":0.73},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":55,\"s\":[1044.55,509.31,0],\"to\":[9.298,0,0],\"ti\":[-22.587,0,0]},{\"i\":{\"x\":0.684,\"y\":0.887},\"o\":{\"x\":0.341,\"y\":0.595},\"t\":62,\"s\":[1109.584,509.31,0],\"to\":[9.932,0,0],\"ti\":[-2.921,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.346,\"y\":0.328},\"t\":68,\"s\":[1130.328,509.31,0],\"to\":[0.795,0,0],\"ti\":[0,0,0]},{\"t\":72,\"s\":[1135.55,509.31,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1632.425,581.977,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.585,0.585,0.585],\"y\":[0.73,0.73,15.726]},\"o\":{\"x\":[0.178,0.178,0.178],\"y\":[0.111,0.111,-6.062]},\"t\":55,\"s\":[96,96,100]},{\"i\":{\"x\":[0.684,0.684,0.684],\"y\":[0.887,0.887,2.97]},\"o\":{\"x\":[0.341,0.341,0.341],\"y\":[0.595,0.595,-10.349]},\"t\":62,\"s\":[42.926,42.926,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.178]},\"o\":{\"x\":[0.346,0.346,0.346],\"y\":[0.078,0.078,-1.436]},\"t\":68,\"s\":[25.997,25.997,100]},{\"t\":72,\"s\":[8,8,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[2.931,28.71]],\"o\":[[0,0],[-2.378,-26.368]],\"v\":[[-87.926,-1.659],[84.995,-1.171]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1556.225,581.377],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-35.313,1.123],[1.452,3.162],[13.648,1.49],[27.388,0.256]],\"o\":[[0,0],[53.234,2.808],[-1.452,-3.163],[-13.648,-1.489],[-27.387,-0.256]],\"v\":[[-87.373,-1.508],[34.139,10.464],[85.244,-2.11],[68.617,-11.395],[22.3,-13.016]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.807843197093,0.298039215686,0.847058883368,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1555.672,581.708],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":55,\"op\":73,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":211,\"ty\":4,\"nm\":\"blast 2 23 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.585,\"y\":0.73},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":55,\"s\":[1005.55,468.31,0],\"to\":[9.405,-2.779,0],\"ti\":[-22.847,6.75,0]},{\"i\":{\"x\":0.684,\"y\":0.887},\"o\":{\"x\":0.341,\"y\":0.595},\"t\":62,\"s\":[1071.332,448.875,0],\"to\":[10.047,-2.968,0],\"ti\":[-2.955,0.873,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.346,\"y\":0.454},\"t\":68,\"s\":[1092.314,442.675,0],\"to\":[0.804,-0.238,0],\"ti\":[0,0,0]},{\"t\":72,\"s\":[1096.05,441.31,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1591.8,539.268,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.585,0.585,0.585],\"y\":[0.73,0.73,15.726]},\"o\":{\"x\":[0.178,0.178,0.178],\"y\":[0.111,0.111,-6.062]},\"t\":55,\"s\":[96,96,100]},{\"i\":{\"x\":[0.684,0.684,0.684],\"y\":[0.887,0.887,2.97]},\"o\":{\"x\":[0.341,0.341,0.341],\"y\":[0.595,0.595,-10.349]},\"t\":62,\"s\":[42.926,42.926,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.178]},\"o\":{\"x\":[0.346,0.346,0.346],\"y\":[0.078,0.078,-1.436]},\"t\":68,\"s\":[25.997,25.997,100]},{\"t\":72,\"s\":[8,8,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[5.409,-4.947],[4.947,5.409],[-5.408,4.947],[-4.947,-5.408]],\"o\":[[-5.409,4.947],[-4.947,-5.409],[5.409,-4.947],[4.947,5.409]],\"v\":[[8.958,9.793],[-9.793,8.957],[-8.957,-9.794],[9.794,-8.958]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1592.3,538.803],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-0.192,-7.052],[7.052,-0.191],[0.192,7.052],[-7.053,0.192]],\"o\":[[0.192,7.052],[-7.053,0.192],[-0.191,-7.053],[7.052,-0.191]],\"v\":[[12.769,-0.347],[0.347,12.769],[-12.77,0.347],[-0.347,-12.77]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1591.94,538.916],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":55,\"op\":73,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":212,\"ty\":4,\"nm\":\"blast 2 24 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.585,\"y\":0.73},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":55,\"s\":[968.55,460.31,0],\"to\":[9.085,-4.809,0],\"ti\":[-22.068,11.683,0]},{\"i\":{\"x\":0.684,\"y\":0.887},\"o\":{\"x\":0.341,\"y\":0.595},\"t\":62,\"s\":[1032.089,426.672,0],\"to\":[9.704,-5.137,0],\"ti\":[-2.854,1.511,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.346,\"y\":0.296},\"t\":68,\"s\":[1052.356,415.942,0],\"to\":[0.777,-0.411,0],\"ti\":[0,0,0]},{\"t\":72,\"s\":[1058.55,414.31,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1553.258,530.935,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.585,0.585,0.585],\"y\":[0.73,0.73,15.726]},\"o\":{\"x\":[0.178,0.178,0.178],\"y\":[0.111,0.111,-6.062]},\"t\":55,\"s\":[96,96,100]},{\"i\":{\"x\":[0.684,0.684,0.684],\"y\":[0.887,0.887,2.97]},\"o\":{\"x\":[0.341,0.341,0.341],\"y\":[0.595,0.595,-10.349]},\"t\":62,\"s\":[42.926,42.926,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.178]},\"o\":{\"x\":[0.346,0.346,0.346],\"y\":[0.078,0.078,-1.436]},\"t\":68,\"s\":[25.997,25.997,100]},{\"t\":72,\"s\":[8,8,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[3.188,18.229]],\"o\":[[0,0],[-7.481,-18.2]],\"v\":[[-33.693,26.378],[30.504,-8.178]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1531.929,536.531],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-6.246,3.257],[-6.117,-9.388],[8.283,-2.869]],\"o\":[[0,0],[6.246,-3.256],[4.232,6.245],[-11.68,4.991]],\"v\":[[-33.81,21.601],[-0.724,-5.508],[29.578,-12.212],[7.19,8.106]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.960784373564,0.549019607843,0.992156922583,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1532.855,540.566],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":55,\"op\":73,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":213,\"ty\":4,\"nm\":\"blast 2 25 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.585,\"y\":0.73},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":55,\"s\":[989.55,408.31,0],\"to\":[4.916,-6.306,0],\"ti\":[-11.943,15.318,0]},{\"i\":{\"x\":0.684,\"y\":0.887},\"o\":{\"x\":0.341,\"y\":0.595},\"t\":62,\"s\":[1023.936,364.206,0],\"to\":[5.246,-6.728,0],\"ti\":[-1.549,1.987,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.346,\"y\":0.321},\"t\":68,\"s\":[1034.898,350.146,0],\"to\":[0.424,-0.544,0],\"ti\":[0,0,0]},{\"t\":72,\"s\":[1038.05,346.81,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1575.133,476.768,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.585,0.585,0.585],\"y\":[0.73,0.73,15.726]},\"o\":{\"x\":[0.178,0.178,0.178],\"y\":[0.111,0.111,-6.062]},\"t\":55,\"s\":[96,96,100]},{\"i\":{\"x\":[0.684,0.684,0.684],\"y\":[0.887,0.887,2.97]},\"o\":{\"x\":[0.341,0.341,0.341],\"y\":[0.595,0.595,-10.349]},\"t\":62,\"s\":[42.926,42.926,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.178]},\"o\":{\"x\":[0.346,0.346,0.346],\"y\":[0.078,0.078,-1.436]},\"t\":68,\"s\":[25.997,25.997,100]},{\"t\":72,\"s\":[8,8,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-5.197,3],[0,0],[-0.189,2.375],[0,0],[-4.459,-4.015],[0,0],[-2.318,0.555],[0,0],[2.441,-5.481],[0,0],[-1.243,-2.032],[0,0],[5.968,0.628],[0,0],[1.549,-1.811],[0,0],[1.247,5.869],[0,0],[2.201,0.913],[0,0]],\"o\":[[0,0],[2.064,-1.192],[0,0],[0.475,-5.982],[0,0],[1.77,1.594],[0,0],[5.836,-1.397],[0,0],[-0.969,2.176],[0,0],[3.132,5.118],[0,0],[-2.37,-0.249],[0,0],[-3.9,4.56],[0,0],[-0.496,-2.331],[0,0],[-5.542,-2.3]],\"v\":[[-31.406,-4.863],[-20.814,-10.977],[-17.216,-16.674],[-16.248,-28.866],[-4.186,-33.673],[4.902,-25.488],[11.432,-23.827],[23.326,-26.674],[31.625,-16.688],[26.649,-5.515],[27.087,1.208],[33.47,11.641],[26.537,22.619],[14.374,21.339],[8.115,23.834],[0.165,33.128],[-12.418,29.927],[-14.959,17.964],[-19.266,12.782],[-30.562,8.093]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1573.373,476.227],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-5.643,-0.289],[0,0],[-3.994,-0.107],[-4.064,3.557],[4.804,9.306],[-2.595,8.393],[4.913,3.88],[6.798,-0.375],[9.087,-0.667],[6.827,-4.113],[0.803,-4.251],[-4.251,-0.803],[-1.542,-4.176]],\"o\":[[0,0],[5.643,0.289],[0,0],[3.994,0.107],[4.064,-3.557],[-4.804,-7.62],[2.595,-8.393],[-4.913,-3.881],[-6.798,0.375],[-9.086,0.666],[-6.827,4.112],[-0.802,4.251],[4.251,0.803],[1.542,4.176]],\"v\":[[-13.503,26.488],[-7.528,35.606],[3.093,30.102],[12.357,21.777],[31.08,21.506],[31.071,7.802],[27.613,-7.584],[29.693,-24.673],[9.317,-23.289],[-10.844,-35.228],[-20.316,-11.87],[-35.073,0.855],[-26.373,10.226],[-15.603,18.025]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.023529413635,0.827451040231,0.486274539723,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1573.565,475.913],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":55,\"op\":73,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":214,\"ty\":4,\"nm\":\"blast 2 26 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.585,\"y\":0.73},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":55,\"s\":[922.55,421.31,0],\"to\":[4.168,-11.756,0],\"ti\":[-10.125,28.558,0]},{\"i\":{\"x\":0.684,\"y\":0.887},\"o\":{\"x\":0.341,\"y\":0.595},\"t\":62,\"s\":[951.703,339.083,0],\"to\":[4.452,-12.558,0],\"ti\":[-1.31,3.694,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.346,\"y\":0.377},\"t\":68,\"s\":[961.002,312.855,0],\"to\":[0.356,-1.005,0],\"ti\":[0,0,0]},{\"t\":72,\"s\":[963.55,307.31,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1505.342,490.31,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.585,0.585,0.585],\"y\":[0.73,0.73,15.726]},\"o\":{\"x\":[0.178,0.178,0.178],\"y\":[0.111,0.111,-6.062]},\"t\":55,\"s\":[96,96,100]},{\"i\":{\"x\":[0.684,0.684,0.684],\"y\":[0.887,0.887,2.97]},\"o\":{\"x\":[0.341,0.341,0.341],\"y\":[0.595,0.595,-10.349]},\"t\":62,\"s\":[42.926,42.926,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.178]},\"o\":{\"x\":[0.346,0.346,0.346],\"y\":[0.078,0.078,-1.436]},\"t\":68,\"s\":[25.997,25.997,100]},{\"t\":72,\"s\":[8,8,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[13.562,12.591]],\"o\":[[0,0],[-16.963,-9.971]],\"v\":[[-21.898,38.156],[8.337,-28.185]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1503.236,511.429],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-3.006,6.37],[-10.548,-3.778],[4.863,-7.295]],\"o\":[[0,0],[3.006,-6.371],[7.147,2.416],[-5.995,10.581]],\"v\":[[-18.691,35.06],[-8.602,-7.398],[11.544,-31.282],[5.998,-1.56]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.960784373564,0.549019607843,0.992156922583,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1500.029,514.526],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":55,\"op\":73,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":215,\"ty\":4,\"nm\":\"blast 2 27 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.585,\"y\":0.73},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":55,\"s\":[920.55,368.31,0],\"to\":[0.534,-9.833,0],\"ti\":[-1.298,23.885,0]},{\"i\":{\"x\":0.684,\"y\":0.887},\"o\":{\"x\":0.341,\"y\":0.595},\"t\":62,\"s\":[924.288,299.538,0],\"to\":[0.571,-10.503,0],\"ti\":[-0.168,3.089,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.346,\"y\":0.341},\"t\":68,\"s\":[925.48,277.602,0],\"to\":[0.046,-0.841,0],\"ti\":[0,0,0]},{\"t\":72,\"s\":[926.05,272.31,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1503.258,435.102,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.585,0.585,0.585],\"y\":[0.73,0.73,15.726]},\"o\":{\"x\":[0.178,0.178,0.178],\"y\":[0.111,0.111,-6.062]},\"t\":55,\"s\":[96,96,100]},{\"i\":{\"x\":[0.684,0.684,0.684],\"y\":[0.887,0.887,2.97]},\"o\":{\"x\":[0.341,0.341,0.341],\"y\":[0.595,0.595,-10.349]},\"t\":62,\"s\":[42.926,42.926,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,3.844]},\"o\":{\"x\":[0.346,0.346,0.346],\"y\":[0.078,0.078,-1.436]},\"t\":68,\"s\":[25.997,25.997,100]},{\"t\":72,\"s\":[8,8,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[5.409,-4.947],[4.947,5.409],[-5.408,4.947],[-4.947,-5.408]],\"o\":[[-5.409,4.947],[-4.947,-5.409],[5.409,-4.947],[4.947,5.409]],\"v\":[[8.958,9.793],[-9.794,8.957],[-8.958,-9.793],[9.793,-8.957]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1504.121,435.725],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-0.192,-7.052],[7.053,-0.191],[0.192,7.052],[-7.053,0.192]],\"o\":[[0.192,7.052],[-7.052,0.192],[-0.192,-7.053],[7.052,-0.191]],\"v\":[[12.77,-0.347],[0.346,12.769],[-12.77,0.347],[-0.347,-12.77]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.992156922583,0.835294177485,0.01568627451,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1503.761,435.838],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":55,\"op\":73,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":216,\"ty\":4,\"nm\":\"blast 2 28 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.585,\"y\":0.73},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":55,\"s\":[875.55,345.31,0],\"to\":[-0.16,-10.314,0],\"ti\":[0.389,25.053,0]},{\"i\":{\"x\":0.684,\"y\":0.887},\"o\":{\"x\":0.341,\"y\":0.595},\"t\":62,\"s\":[874.429,273.174,0],\"to\":[-0.171,-11.017,0],\"ti\":[0.05,3.24,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.346,\"y\":0.242},\"t\":68,\"s\":[874.071,250.166,0],\"to\":[-0.014,-0.882,0],\"ti\":[0,0,0]},{\"t\":72,\"s\":[874.05,242.31,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1456.383,411.143,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.585,0.585,0.585],\"y\":[0.73,0.73,-0.05]},\"o\":{\"x\":[0.178,0.178,0.178],\"y\":[0.111,0.111,0.432]},\"t\":55,\"s\":[96,96,100]},{\"i\":{\"x\":[0.684,0.684,0.684],\"y\":[0.887,0.887,0.86]},\"o\":{\"x\":[0.341,0.341,0.341],\"y\":[0.595,0.595,0.738]},\"t\":62,\"s\":[42.926,42.926,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,5.016]},\"o\":{\"x\":[0.346,0.346,0.346],\"y\":[0.078,0.078,0.102]},\"t\":68,\"s\":[25.997,25.997,100]},{\"t\":72,\"s\":[8,8,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[28.71,-2.931]],\"o\":[[0,0],[-26.368,2.378]],\"v\":[[-1.659,87.926],[-1.171,-84.995]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1456.901,483.595],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[1.122,35.313],[0,0],[1.489,-13.648],[0.256,-27.387]],\"o\":[[0,0],[2.808,-53.235],[0,0],[-1.489,13.648],[-0.256,27.388]],\"v\":[[-1.508,85.881],[10.464,-32.646],[-2.11,-83.751],[-11.395,-67.124],[-13.016,-20.808]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.807843197093,0.298039215686,0.847058883368,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1457.233,482.655],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":55,\"op\":73,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":217,\"ty\":4,\"nm\":\"blast 1 1 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.582,\"y\":0.82},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":21,\"s\":[1030.55,421.31,0],\"to\":[-4.409,-0.396,0],\"ti\":[10.181,0.914,0]},{\"i\":{\"x\":0.676,\"y\":0.877},\"o\":{\"x\":0.336,\"y\":0.604},\"t\":25,\"s\":[1002.579,418.8,0],\"to\":[-4.15,-0.372,0],\"ti\":[2.263,0.203,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.262,\"y\":1},\"t\":31,\"s\":[992.547,417.899,0],\"to\":[-0.37,-0.033,0],\"ti\":[0.166,0.015,0]},{\"t\":37,\"s\":[991.55,417.81,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1667.043,209.141,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.582,0.582,0.582],\"y\":[0.82,0.82,9.89]},\"o\":{\"x\":[0.18,0.18,0.18],\"y\":[0.072,0.072,-3.541]},\"t\":21,\"s\":[77,77,100]},{\"i\":{\"x\":[0.676,0.676,0.676],\"y\":[0.877,0.877,3.181]},\"o\":{\"x\":[0.336,0.336,0.336],\"y\":[0.604,0.604,-10.699]},\"t\":25,\"s\":[37.554,37.554,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,-1.52]},\"o\":{\"x\":[0.35,0.35,0.35],\"y\":[0.14,0.14,-2.359]},\"t\":31,\"s\":[23.405,23.405,100]},{\"t\":37,\"s\":[10,10,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-3.665],[3.665,0],[0,3.665],[-3.665,0]],\"o\":[[0,3.665],[-3.665,0],[0,-3.665],[3.665,0]],\"v\":[[6.636,0],[0,6.636],[-6.636,0],[0,-6.636]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1666.157,207.808],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-2.938,-2.573],[2.58,-2.945],[2.937,2.573],[-2.58,2.945]],\"o\":[[2.938,2.573],[-2.58,2.945],[-2.938,-2.574],[2.58,-2.945]],\"v\":[[4.671,-5.333],[5.319,4.659],[-4.671,5.333],[-5.319,-4.659]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.549019607843,0.780392216701,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1665.945,207.535],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":21,\"op\":38,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":218,\"ty\":4,\"nm\":\"blast 1 2 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.582,\"y\":0.82},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":21,\"s\":[1061.55,459.31,0],\"to\":[-0.226,3.9,0],\"ti\":[0.522,-9.006,0]},{\"i\":{\"x\":0.676,\"y\":0.877},\"o\":{\"x\":0.336,\"y\":0.604},\"t\":25,\"s\":[1060.116,484.052,0],\"to\":[-0.213,3.672,0],\"ti\":[0.116,-2.002,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.262,\"y\":1},\"t\":31,\"s\":[1059.601,492.927,0],\"to\":[-0.019,0.327,0],\"ti\":[0.009,-0.147,0]},{\"t\":37,\"s\":[1059.55,493.81,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1707.303,258.492,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.582,0.582,0.582],\"y\":[0.82,0.82,9.89]},\"o\":{\"x\":[0.18,0.18,0.18],\"y\":[0.072,0.072,-3.541]},\"t\":21,\"s\":[77,77,100]},{\"i\":{\"x\":[0.676,0.676,0.676],\"y\":[0.877,0.877,3.181]},\"o\":{\"x\":[0.336,0.336,0.336],\"y\":[0.604,0.604,-10.699]},\"t\":25,\"s\":[37.554,37.554,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,-1.52]},\"o\":{\"x\":[0.35,0.35,0.35],\"y\":[0.14,0.14,-2.359]},\"t\":31,\"s\":[23.405,23.405,100]},{\"t\":37,\"s\":[10,10,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,4.764],[-4.765,0],[0,-4.764],[4.764,0]],\"o\":[[0,-4.764],[4.764,0],[0,4.764],[-4.765,0]],\"v\":[[-8.626,0],[0,-8.627],[8.626,0],[0,8.627]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1707.3,258.241],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-3.446,-3.019],[3.018,-3.446],[3.446,3.018],[-3.019,3.446]],\"o\":[[3.446,3.019],[-3.019,3.446],[-3.446,-3.019],[3.018,-3.446]],\"v\":[[5.466,-6.239],[6.24,5.466],[-5.466,6.24],[-6.239,-5.465]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.549019607843,0.780392216701,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1707.3,258.24],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":21,\"op\":38,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":219,\"ty\":4,\"nm\":\"blast 1 3 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.582,\"y\":0.82},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":21,\"s\":[1094.55,421.31,0],\"to\":[3.504,-0.339,0],\"ti\":[-8.093,0.783,0]},{\"i\":{\"x\":0.676,\"y\":0.877},\"o\":{\"x\":0.336,\"y\":0.604},\"t\":25,\"s\":[1116.782,419.158,0],\"to\":[3.299,-0.319,0],\"ti\":[-1.799,0.174,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.262,\"y\":1},\"t\":31,\"s\":[1124.757,418.387,0],\"to\":[0.294,-0.028,0],\"ti\":[-0.132,0.013,0]},{\"t\":37,\"s\":[1125.55,418.31,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1750.16,209.141,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.582,0.582,0.582],\"y\":[0.82,0.82,9.89]},\"o\":{\"x\":[0.18,0.18,0.18],\"y\":[0.072,0.072,-3.541]},\"t\":21,\"s\":[77,77,100]},{\"i\":{\"x\":[0.676,0.676,0.676],\"y\":[0.877,0.877,3.181]},\"o\":{\"x\":[0.336,0.336,0.336],\"y\":[0.604,0.604,-10.699]},\"t\":25,\"s\":[37.554,37.554,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,-1.52]},\"o\":{\"x\":[0.35,0.35,0.35],\"y\":[0.14,0.14,-2.359]},\"t\":31,\"s\":[23.405,23.405,100]},{\"t\":37,\"s\":[10,10,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-3.665],[-3.665,0],[0,3.665],[3.665,0]],\"o\":[[0,3.665],[3.665,0],[0,-3.665],[-3.665,0]],\"v\":[[-6.636,0],[0,6.636],[6.636,0],[0,-6.636]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1749.77,207.808],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-2.654,-2.325],[2.331,-2.661],[2.654,2.325],[-2.331,2.661]],\"o\":[[2.654,2.325],[-2.331,2.661],[-2.655,-2.325],[2.331,-2.661]],\"v\":[[4.221,-4.818],[4.806,4.21],[-4.22,4.818],[-4.806,-4.21]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.549019607843,0.780392216701,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1749.807,207.527],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":21,\"op\":38,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":220,\"ty\":4,\"nm\":\"blast 1 4 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.582,\"y\":0.82},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":21,\"s\":[1061.55,383.31,0],\"to\":[-0.17,-8.026,0],\"ti\":[0.392,18.535,0]},{\"i\":{\"x\":0.676,\"y\":0.877},\"o\":{\"x\":0.336,\"y\":0.604},\"t\":25,\"s\":[1060.474,332.389,0],\"to\":[-0.16,-7.556,0],\"ti\":[0.087,4.119,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.262,\"y\":1},\"t\":31,\"s\":[1060.088,314.125,0],\"to\":[-0.014,-0.673,0],\"ti\":[0.006,0.303,0]},{\"t\":37,\"s\":[1060.05,312.31,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1707.303,159.791,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.582,0.582,0.582],\"y\":[0.82,0.82,9.89]},\"o\":{\"x\":[0.18,0.18,0.18],\"y\":[0.072,0.072,-3.541]},\"t\":21,\"s\":[77,77,100]},{\"i\":{\"x\":[0.676,0.676,0.676],\"y\":[0.877,0.877,3.181]},\"o\":{\"x\":[0.336,0.336,0.336],\"y\":[0.604,0.604,-10.699]},\"t\":25,\"s\":[37.554,37.554,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,-1.52]},\"o\":{\"x\":[0.35,0.35,0.35],\"y\":[0.14,0.14,-2.359]},\"t\":31,\"s\":[23.405,23.405,100]},{\"t\":37,\"s\":[10,10,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-4.764],[4.765,0],[0,4.764],[-4.764,0]],\"o\":[[0,4.764],[-4.764,0],[0,-4.764],[4.765,0]],\"v\":[[8.626,0],[-0.001,8.627],[-8.627,0],[-0.001,-8.627]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1707.964,158.038],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-3.619,-3.17],[3.171,-3.62],[3.619,3.17],[-3.17,3.62]],\"o\":[[3.619,3.17],[-3.17,3.619],[-3.619,-3.17],[3.171,-3.619]],\"v\":[[5.741,-6.553],[6.552,5.741],[-5.74,6.553],[-6.553,-5.741]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.549019607843,0.780392216701,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1707.878,158.213],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":21,\"op\":38,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":221,\"ty\":4,\"nm\":\"blast 1 5 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.582,\"y\":0.82},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":21,\"s\":[979.55,389.31,0],\"to\":[-4.708,-2.95,0],\"ti\":[10.853,6.799,0]},{\"i\":{\"x\":0.676,\"y\":0.877},\"o\":{\"x\":0.336,\"y\":0.604},\"t\":25,\"s\":[949.784,370.666,0],\"to\":[-4.39,-2.75,0],\"ti\":[2.442,1.532,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.35,\"y\":0.549},\"t\":31,\"s\":[939.11,363.975,0],\"to\":[-0.39,-0.245,0],\"ti\":[0.427,0.278,0]},{\"t\":37,\"s\":[936.55,362.31,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1600.81,167.583,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.582,0.582,0.582],\"y\":[0.82,0.82,9.89]},\"o\":{\"x\":[0.18,0.18,0.18],\"y\":[0.072,0.072,-3.541]},\"t\":21,\"s\":[77,77,100]},{\"i\":{\"x\":[0.676,0.676,0.676],\"y\":[0.877,0.877,3.181]},\"o\":{\"x\":[0.336,0.336,0.336],\"y\":[0.604,0.604,-10.699]},\"t\":25,\"s\":[37.554,37.554,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,-1.52]},\"o\":{\"x\":[0.35,0.35,0.35],\"y\":[0.14,0.14,-2.359]},\"t\":31,\"s\":[23.405,23.405,100]},{\"t\":37,\"s\":[10,10,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-32.411,-34.067],[0.407,13.43]],\"o\":[[0,0],[-0.408,-13.431]],\"v\":[[34.565,19.673],[-34.157,-6.242]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1629.819,173.77],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-7.741,0.276],[21.168,6.165],[1.844,-4.119],[-10.204,-3.771]],\"o\":[[0,0],[-17.258,-4.973],[-1.844,4.119],[3.651,1.875]],\"v\":[[35.052,17.316],[-9.789,-12.619],[-33.209,-11.335],[-19.234,2.862]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1629.331,176.126],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":21,\"op\":38,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":222,\"ty\":4,\"nm\":\"blast 1 6 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.582,\"y\":0.82},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":21,\"s\":[955.55,378.31,0],\"to\":[-7.97,-4.805,0],\"ti\":[18.405,11.095,0]},{\"i\":{\"x\":0.676,\"y\":0.877},\"o\":{\"x\":0.336,\"y\":0.604},\"t\":25,\"s\":[904.988,347.829,0],\"to\":[-7.503,-4.523,0],\"ti\":[4.09,2.466,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.262,\"y\":1},\"t\":31,\"s\":[886.853,336.897,0],\"to\":[-0.669,-0.403,0],\"ti\":[0.3,0.181,0]},{\"t\":37,\"s\":[885.05,335.81,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1569.641,153.297,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.582,0.582,0.582],\"y\":[0.82,0.82,9.89]},\"o\":{\"x\":[0.18,0.18,0.18],\"y\":[0.072,0.072,-3.541]},\"t\":21,\"s\":[77,77,100]},{\"i\":{\"x\":[0.676,0.676,0.676],\"y\":[0.877,0.877,3.181]},\"o\":{\"x\":[0.336,0.336,0.336],\"y\":[0.604,0.604,-10.699]},\"t\":25,\"s\":[37.554,37.554,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,-1.52]},\"o\":{\"x\":[0.35,0.35,0.35],\"y\":[0.14,0.14,-2.359]},\"t\":31,\"s\":[23.405,23.405,100]},{\"t\":37,\"s\":[10,10,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-7.33],[7.33,0],[0,7.33],[-7.33,0]],\"o\":[[0,7.33],[-7.33,0],[0,-7.33],[7.33,0]],\"v\":[[13.272,0],[0,13.272],[-13.272,0],[0,-13.272]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1569.272,150.739],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-5.43,-4.756],[4.756,-5.429],[5.429,4.757],[-4.757,5.429]],\"o\":[[5.43,4.756],[-4.756,5.43],[-5.43,-4.756],[4.756,-5.43]],\"v\":[[8.613,-9.832],[9.832,8.612],[-8.612,9.831],[-9.831,-8.612]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.549019607843,0.780392216701,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1569.219,150.537],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":21,\"op\":38,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":223,\"ty\":4,\"nm\":\"blast 1 7 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.582,\"y\":0.82},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":21,\"s\":[932.55,417.31,0],\"to\":[-7.082,-0.057,0],\"ti\":[16.334,0.131,0]},{\"i\":{\"x\":0.676,\"y\":0.877},\"o\":{\"x\":0.336,\"y\":0.604},\"t\":25,\"s\":[887.725,416.951,0],\"to\":[-6.626,-0.053,0],\"ti\":[3.661,0.029,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.35,\"y\":0.691},\"t\":31,\"s\":[871.648,416.823,0],\"to\":[-0.59,-0.005,0],\"ti\":[0.516,0.002,0]},{\"t\":37,\"s\":[868.55,416.81,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1544.771,203.946,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.582,0.582,0.582],\"y\":[0.82,0.82,9.89]},\"o\":{\"x\":[0.18,0.18,0.18],\"y\":[0.072,0.072,-3.541]},\"t\":21,\"s\":[77,77,100]},{\"i\":{\"x\":[0.676,0.676,0.676],\"y\":[0.877,0.877,3.181]},\"o\":{\"x\":[0.336,0.336,0.336],\"y\":[0.604,0.604,-10.699]},\"t\":25,\"s\":[37.554,37.554,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,-1.52]},\"o\":{\"x\":[0.35,0.35,0.35],\"y\":[0.14,0.14,-2.359]},\"t\":31,\"s\":[23.405,23.405,100]},{\"t\":37,\"s\":[10,10,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-0.609,5.969],[0,0],[1.816,1.543],[0,0],[-5.865,1.266],[0,0],[-0.906,2.204],[0,0],[-3.016,-5.187],[0,0],[-2.376,-0.181],[0,0],[4.001,-4.471],[0,0],[-0.562,-2.315],[0,0],[5.489,2.423],[0,0],[2.029,-1.25],[0,0]],\"o\":[[0,0],[0.242,-2.371],[0,0],[-4.572,-3.885],[0,0],[2.329,-0.503],[0,0],[2.282,-5.549],[0,0],[1.198,2.06],[0,0],[5.983,0.456],[0,0],[-1.589,1.776],[0,0],[1.415,5.831],[0,0],[-2.179,-0.963],[0,0],[-5.109,3.148]],\"v\":[[-22.515,26.585],[-21.274,14.418],[-23.788,8.168],[-33.108,0.246],[-29.947,-12.346],[-17.991,-14.926],[-12.823,-19.249],[-8.17,-30.559],[4.783,-31.444],[10.931,-20.871],[16.639,-17.293],[28.834,-16.363],[33.679,-4.316],[25.523,4.798],[23.883,11.332],[26.767,23.219],[16.808,31.548],[5.619,26.608],[-1.103,27.068],[-11.515,33.483]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1541.178,203.17],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-3.467,4.461],[0,0],[-2.374,3.213],[0.59,5.369],[3.527,0.002],[4.455,6.905],[5.994,-1.807],[3.609,-2.525],[4.655,-7.831],[-1.432,-7.43],[-4.964,-4.964],[-3.091,3.025],[-4.307,-1.126]],\"o\":[[0,0],[3.468,-4.462],[0,0],[2.374,-3.214],[-0.59,-5.369],[-3.527,-0.002],[-5.634,-8.615],[-5.994,1.807],[-3.608,2.525],[-4.655,7.832],[1.431,7.429],[3.026,3.092],[3.092,-3.026],[4.306,1.126]],\"v\":[[14.839,30.787],[27.277,30.126],[27.893,18.403],[26.371,6.042],[36.867,-9.465],[27.008,-16.337],[12.241,-21.392],[-0.98,-34.238],[-13.943,-15.642],[-32.801,-6.977],[-19.922,13.569],[-17.936,32.953],[-5.299,31.524],[7.288,26.819]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.792156922583,0.964705942191,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1539.305,202.473],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":21,\"op\":38,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":224,\"ty\":4,\"nm\":\"blast 1 8 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.582,\"y\":0.82},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":21,\"s\":[954.55,466.31,0],\"to\":[-7.97,3.618,0],\"ti\":[18.405,-8.354,0]},{\"i\":{\"x\":0.676,\"y\":0.877},\"o\":{\"x\":0.336,\"y\":0.604},\"t\":25,\"s\":[903.988,489.26,0],\"to\":[-7.503,3.406,0],\"ti\":[4.09,-1.857,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.262,\"y\":1},\"t\":31,\"s\":[885.853,497.492,0],\"to\":[-0.669,0.303,0],\"ti\":[0.3,-0.136,0]},{\"t\":37,\"s\":[884.05,498.31,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1568.342,267.583,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.582,0.582,0.582],\"y\":[0.82,0.82,9.89]},\"o\":{\"x\":[0.18,0.18,0.18],\"y\":[0.072,0.072,-3.541]},\"t\":21,\"s\":[77,77,100]},{\"i\":{\"x\":[0.676,0.676,0.676],\"y\":[0.877,0.877,3.181]},\"o\":{\"x\":[0.336,0.336,0.336],\"y\":[0.604,0.604,-10.699]},\"t\":25,\"s\":[37.554,37.554,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,-1.52]},\"o\":{\"x\":[0.35,0.35,0.35],\"y\":[0.14,0.14,-2.359]},\"t\":31,\"s\":[23.405,23.405,100]},{\"t\":37,\"s\":[10,10,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,7.33],[7.33,0],[0,-7.33],[-7.33,0]],\"o\":[[0,-7.33],[-7.33,0],[0,7.33],[7.33,0]],\"v\":[[13.272,0],[0,-13.272],[-13.272,0],[0,13.272]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1568.609,265.54],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-5.495,-4.814],[4.814,-5.495],[5.495,4.814],[-4.814,5.495]],\"o\":[[5.495,4.814],[-4.814,5.495],[-5.496,-4.814],[4.814,-5.496]],\"v\":[[8.717,-9.951],[9.95,8.717],[-8.717,9.95],[-9.951,-8.717]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.549019607843,0.780392216701,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1568.893,265.497],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":21,\"op\":38,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":225,\"ty\":4,\"nm\":\"blast 1 9 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.582,\"y\":0.82},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":21,\"s\":[979.55,452.31,0],\"to\":[-3.844,1.752,0],\"ti\":[8.876,-4.046,0]},{\"i\":{\"x\":0.676,\"y\":0.877},\"o\":{\"x\":0.336,\"y\":0.604},\"t\":25,\"s\":[955.166,463.426,0],\"to\":[-3.619,1.65,0],\"ti\":[1.973,-0.899,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.262,\"y\":1},\"t\":31,\"s\":[946.42,467.413,0],\"to\":[-0.323,0.147,0],\"ti\":[0.145,-0.066,0]},{\"t\":37,\"s\":[945.55,467.81,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1600.81,249.401,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.582,0.582,0.582],\"y\":[0.82,0.82,9.89]},\"o\":{\"x\":[0.18,0.18,0.18],\"y\":[0.072,0.072,-3.541]},\"t\":21,\"s\":[77,77,100]},{\"i\":{\"x\":[0.676,0.676,0.676],\"y\":[0.877,0.877,3.181]},\"o\":{\"x\":[0.336,0.336,0.336],\"y\":[0.604,0.604,-10.699]},\"t\":25,\"s\":[37.554,37.554,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,-1.52]},\"o\":{\"x\":[0.35,0.35,0.35],\"y\":[0.14,0.14,-2.359]},\"t\":31,\"s\":[23.405,23.405,100]},{\"t\":37,\"s\":[10,10,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-32.411,34.067],[0.407,-13.43]],\"o\":[[0,0],[-0.408,13.431]],\"v\":[[34.565,-19.673],[-34.157,6.242]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1629.155,242.51],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-12.805,16.368],[6.65,-2.556],[-4.215,-7.32],[-1.842,0.592]],\"o\":[[0,0],[-6.649,2.556],[1.089,5.806],[1.841,-0.591]],\"v\":[[36.128,-17.359],[-15.498,-3.906],[-31.913,11.553],[-11.205,13.599]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1627.592,240.196],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":21,\"op\":38,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":226,\"ty\":4,\"nm\":\"blast 1 10 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.582,\"y\":0.82},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":21,\"s\":[955.55,517.31,0],\"to\":[-8.608,8.268,0],\"ti\":[19.859,-19.075,0]},{\"i\":{\"x\":0.676,\"y\":0.877},\"o\":{\"x\":0.336,\"y\":0.604},\"t\":25,\"s\":[901.041,569.663,0],\"to\":[-8.062,7.744,0],\"ti\":[4.444,-4.271,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.35,\"y\":0.749},\"t\":31,\"s\":[881.492,588.443,0],\"to\":[-0.717,0.689,0],\"ti\":[0.574,-0.561,0]},{\"t\":37,\"s\":[878.05,591.81,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1569.641,333.816,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.582,0.582,0.582],\"y\":[0.82,0.82,9.89]},\"o\":{\"x\":[0.18,0.18,0.18],\"y\":[0.072,0.072,-3.541]},\"t\":21,\"s\":[77,77,100]},{\"i\":{\"x\":[0.676,0.676,0.676],\"y\":[0.877,0.877,3.181]},\"o\":{\"x\":[0.336,0.336,0.336],\"y\":[0.604,0.604,-10.699]},\"t\":25,\"s\":[37.554,37.554,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,-1.52]},\"o\":{\"x\":[0.35,0.35,0.35],\"y\":[0.14,0.14,-2.359]},\"t\":31,\"s\":[23.405,23.405,100]},{\"t\":37,\"s\":[10,10,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-75.65,79.631],[11.944,18.58]],\"o\":[[-19.908,58.396],[-11.945,-18.581]],\"v\":[[68.35,-69.014],[-56.405,50.434]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1622.36,288.102],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[26.605,-19.628],[-6.433,-13.532],[-21.166,18.219],[-13.686,28.394]],\"o\":[[0,0],[-31.079,24.212],[5.113,10.948],[17.292,-14.884],[4.484,-9.875]],\"v\":[[65.511,-63.855],[-4.708,-1.473],[-59.079,52.908],[-8.473,31.157],[58.868,-48.913]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.003921568627,0.517647058824,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1624.588,284.469],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":21,\"op\":38,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":227,\"ty\":4,\"nm\":\"blast 1 11 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.582,\"y\":0.82},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":21,\"s\":[1019.55,511.31,0],\"to\":[-2.729,4.662,0],\"ti\":[6.284,-10.735,0]},{\"i\":{\"x\":0.676,\"y\":0.877},\"o\":{\"x\":0.336,\"y\":0.604},\"t\":25,\"s\":[1002.339,540.717,0],\"to\":[-2.529,4.32,0],\"ti\":[1.428,-2.437,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.35,\"y\":0.394},\"t\":31,\"s\":[996.164,551.262,0],\"to\":[-0.225,0.384,0],\"ti\":[0.352,-0.591,0]},{\"t\":37,\"s\":[994.05,554.81,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1652.758,326.024,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.582,0.582,0.582],\"y\":[0.82,0.82,9.89]},\"o\":{\"x\":[0.18,0.18,0.18],\"y\":[0.072,0.072,-3.541]},\"t\":21,\"s\":[77,77,100]},{\"i\":{\"x\":[0.676,0.676,0.676],\"y\":[0.877,0.877,3.181]},\"o\":{\"x\":[0.336,0.336,0.336],\"y\":[0.604,0.604,-10.699]},\"t\":25,\"s\":[37.554,37.554,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,-1.52]},\"o\":{\"x\":[0.35,0.35,0.35],\"y\":[0.14,0.14,-2.359]},\"t\":31,\"s\":[23.405,23.405,100]},{\"t\":37,\"s\":[10,10,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-7.299,46.451],[-7.3,-11.281]],\"o\":[[0,0],[7.299,11.281]],\"v\":[[24.553,-35.834],[-17.253,24.553]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1664.166,307.347],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.286,7.213],[3.187,-5.149],[-5.709,-4.56],[-6.654,9.609]],\"o\":[[0,0],[-3.187,5.148],[5.71,4.561],[6.653,-9.61]],\"v\":[[22.834,-33.184],[-10.534,5.405],[-17.411,28.623],[5.913,12.657]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1665.885,304.697],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":21,\"op\":38,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":228,\"ty\":4,\"nm\":\"blast 1 12 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.582,\"y\":0.82},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":21,\"s\":[1007.55,534.31,0],\"to\":[-4.531,8.156,0],\"ti\":[10.453,-18.815,0]},{\"i\":{\"x\":0.676,\"y\":0.877},\"o\":{\"x\":0.336,\"y\":0.604},\"t\":25,\"s\":[978.871,585.954,0],\"to\":[-4.242,7.635,0],\"ti\":[2.346,-4.211,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.35,\"y\":0.722},\"t\":31,\"s\":[968.575,604.471,0],\"to\":[-0.378,0.679,0],\"ti\":[0.338,-0.557,0]},{\"t\":37,\"s\":[966.55,607.81,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1637.173,355.894,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.582,0.582,0.582],\"y\":[0.82,0.82,9.89]},\"o\":{\"x\":[0.18,0.18,0.18],\"y\":[0.072,0.072,-3.541]},\"t\":21,\"s\":[77,77,100]},{\"i\":{\"x\":[0.676,0.676,0.676],\"y\":[0.877,0.877,3.181]},\"o\":{\"x\":[0.336,0.336,0.336],\"y\":[0.604,0.604,-10.699]},\"t\":25,\"s\":[37.554,37.554,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,-1.52]},\"o\":{\"x\":[0.35,0.35,0.35],\"y\":[0.14,0.14,-2.359]},\"t\":31,\"s\":[23.405,23.405,100]},{\"t\":37,\"s\":[10,10,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,5.497],[5.498,0],[0,-5.497],[-5.497,0]],\"o\":[[0,-5.497],[-5.497,0],[0,5.497],[5.498,0]],\"v\":[[9.954,0],[0,-9.954],[-9.954,0],[0,9.954]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1636.959,353.798],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-3.88,-3.399],[3.4,-3.881],[3.881,3.399],[-3.399,3.881]],\"o\":[[3.881,3.399],[-3.399,3.88],[-3.88,-3.4],[3.4,-3.88]],\"v\":[[6.155,-7.027],[7.026,6.155],[-6.156,7.027],[-7.027,-6.155]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.549019607843,0.780392216701,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1636.859,353.935],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":21,\"op\":38,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":229,\"ty\":4,\"nm\":\"blast 1 13 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.582,\"y\":0.82},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":21,\"s\":[1061.55,539.31,0],\"to\":[-0.113,7.318,0],\"ti\":[0.26,-16.869,0]},{\"i\":{\"x\":0.676,\"y\":0.877},\"o\":{\"x\":0.336,\"y\":0.604},\"t\":25,\"s\":[1060.793,585.569,0],\"to\":[-0.105,6.821,0],\"ti\":[0.038,-3.8,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.35,\"y\":0.529},\"t\":31,\"s\":[1060.565,602.161,0],\"to\":[-0.006,0.607,0],\"ti\":[-0.081,-0.691,0]},{\"t\":37,\"s\":[1061.05,606.31,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1707.303,362.388,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.582,0.582,0.582],\"y\":[0.82,0.82,9.89]},\"o\":{\"x\":[0.18,0.18,0.18],\"y\":[0.072,0.072,-3.541]},\"t\":21,\"s\":[77,77,100]},{\"i\":{\"x\":[0.676,0.676,0.676],\"y\":[0.877,0.877,3.181]},\"o\":{\"x\":[0.336,0.336,0.336],\"y\":[0.604,0.604,-10.699]},\"t\":25,\"s\":[37.554,37.554,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,-1.52]},\"o\":{\"x\":[0.35,0.35,0.35],\"y\":[0.14,0.14,-2.359]},\"t\":31,\"s\":[23.405,23.405,100]},{\"t\":37,\"s\":[10,10,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-0.761,5.952],[0,0],[1.775,1.589],[0,0],[-5.896,1.116],[0,0],[-0.962,2.18],[0,0],[-2.883,-5.263],[0,0],[-2.371,-0.241],[0,0],[4.114,-4.368],[0,0],[-0.502,-2.329],[0,0],[5.426,2.563],[0,0],[2.06,-1.197],[0,0]],\"o\":[[0,0],[0.302,-2.363],[0,0],[-4.471,-4.002],[0,0],[2.341,-0.443],[0,0],[2.423,-5.489],[0,0],[1.145,2.09],[0,0],[5.969,0.608],[0,0],[-1.634,1.734],[0,0],[1.266,5.865],[0,0],[-2.155,-1.018],[0,0],[-5.187,3.016]],\"v\":[[-23.345,26.192],[-21.795,14.06],[-24.147,7.747],[-33.263,-0.408],[-29.781,-12.917],[-17.764,-15.19],[-12.487,-19.38],[-7.547,-30.568],[5.426,-31.122],[11.302,-20.396],[16.917,-16.672],[29.083,-15.431],[33.62,-3.265],[25.234,5.638],[23.427,12.129],[26.006,24.084],[15.838,32.157],[4.78,26.933],[-1.953,27.22],[-12.526,33.369]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1708.928,361.084],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-3.619,4.339],[0,0],[-4.328,4.328],[0.404,5.386],[3.525,0.124],[5.153,7.115],[6.053,-1.599],[3.694,-2.398],[4.923,-7.666],[-1.173,-7.474],[-2.917,-3.195],[-3.195,2.918],[-4.265,-1.274]],\"o\":[[0,0],[3.619,-4.339],[0,0],[2.483,-3.13],[-0.404,-5.386],[-3.524,-0.124],[-5.943,-11.373],[-6.053,1.599],[-3.694,2.398],[-4.923,7.666],[0,8.102],[2.917,3.194],[3.195,-2.917],[4.266,1.274]],\"v\":[[14.363,30.859],[25.86,30.733],[26.501,18.934],[26.742,6.527],[37.768,-8.608],[26.286,-15.816],[12.424,-20.717],[-1.326,-34.673],[-13.344,-15.879],[-33.25,-8.527],[-19.784,12.45],[-19.654,33.079],[-6.51,30.842],[6.953,26.632]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.792156922583,0.964705942191,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1707.15,360.975],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":21,\"op\":38,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":230,\"ty\":4,\"nm\":\"blast 1 14 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.582,\"y\":0.82},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":21,\"s\":[1116.55,534.31,0],\"to\":[3.286,7.309,0],\"ti\":[-7.58,-16.858,0]},{\"i\":{\"x\":0.676,\"y\":0.877},\"o\":{\"x\":0.336,\"y\":0.604},\"t\":25,\"s\":[1137.329,580.578,0],\"to\":[3.074,6.836,0],\"ti\":[-1.71,-3.775,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.35,\"y\":0.673},\"t\":31,\"s\":[1144.803,597.164,0],\"to\":[0.275,0.608,0],\"ti\":[-0.291,-0.524,0]},{\"t\":37,\"s\":[1146.55,600.31,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1778.732,355.894,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.582,0.582,0.582],\"y\":[0.82,0.82,9.89]},\"o\":{\"x\":[0.18,0.18,0.18],\"y\":[0.072,0.072,-3.541]},\"t\":21,\"s\":[77,77,100]},{\"i\":{\"x\":[0.676,0.676,0.676],\"y\":[0.877,0.877,3.181]},\"o\":{\"x\":[0.336,0.336,0.336],\"y\":[0.604,0.604,-10.699]},\"t\":25,\"s\":[37.554,37.554,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,-1.52]},\"o\":{\"x\":[0.35,0.35,0.35],\"y\":[0.14,0.14,-2.359]},\"t\":31,\"s\":[23.405,23.405,100]},{\"t\":37,\"s\":[10,10,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,5.497],[-5.498,0],[0,-5.497],[5.497,0]],\"o\":[[0,-5.497],[5.497,0],[0,5.497],[-5.498,0]],\"v\":[[-9.954,0],[0,-9.954],[9.954,0],[0,9.954]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1777.641,353.798],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-4.127,-3.615],[3.615,-4.127],[4.127,3.615],[-3.615,4.127]],\"o\":[[4.127,3.615],[-3.616,4.127],[-4.127,-3.615],[3.616,-4.127]],\"v\":[[6.546,-7.473],[7.473,6.547],[-6.546,7.472],[-7.473,-6.547]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.549019607843,0.780392216701,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1777.651,353.868],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":21,\"op\":38,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":231,\"ty\":4,\"nm\":\"blast 1 15 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.582,\"y\":0.82},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":21,\"s\":[1102.55,514.31,0],\"to\":[1.696,3.787,0],\"ti\":[-3.916,-8.745,0]},{\"i\":{\"x\":0.676,\"y\":0.877},\"o\":{\"x\":0.336,\"y\":0.604},\"t\":25,\"s\":[1113.307,538.335,0],\"to\":[1.596,3.565,0],\"ti\":[-0.87,-1.944,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.262,\"y\":1},\"t\":31,\"s\":[1117.166,546.953,0],\"to\":[0.142,0.318,0],\"ti\":[-0.064,-0.143,0]},{\"t\":37,\"s\":[1117.55,547.81,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1760.55,329.92,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.582,0.582,0.582],\"y\":[0.82,0.82,9.89]},\"o\":{\"x\":[0.18,0.18,0.18],\"y\":[0.072,0.072,-3.541]},\"t\":21,\"s\":[77,77,100]},{\"i\":{\"x\":[0.676,0.676,0.676],\"y\":[0.877,0.877,3.181]},\"o\":{\"x\":[0.336,0.336,0.336],\"y\":[0.604,0.604,-10.699]},\"t\":25,\"s\":[37.554,37.554,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,-1.52]},\"o\":{\"x\":[0.35,0.35,0.35],\"y\":[0.14,0.14,-2.359]},\"t\":31,\"s\":[23.405,23.405,100]},{\"t\":37,\"s\":[10,10,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[7.3,46.451],[7.3,-11.281]],\"o\":[[0,0],[-7.299,11.281]],\"v\":[[-24.553,-35.834],[17.253,24.553]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1750.434,307.347],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[7.394,5.154],[-15.222,-16.864],[0,0],[2.244,5.495]],\"o\":[[0,0],[15.222,16.863],[0,0],[-2.244,-5.495]],\"v\":[[-21.593,-34.461],[-0.784,17.598],[18.906,27.346],[19.349,16.267]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1747.474,305.973],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":21,\"op\":38,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":232,\"ty\":4,\"nm\":\"blast 1 16 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.582,\"y\":0.82},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":21,\"s\":[1163.55,516.31,0],\"to\":[8.603,8.489,0],\"ti\":[-19.854,-19.59,0]},{\"i\":{\"x\":0.676,\"y\":0.877},\"o\":{\"x\":0.336,\"y\":0.604},\"t\":25,\"s\":[1218.021,570.137,0],\"to\":[8.071,7.964,0],\"ti\":[-4.451,-4.355,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.35,\"y\":0.868},\"t\":31,\"s\":[1237.597,589.403,0],\"to\":[0.722,0.706,0],\"ti\":[-0.575,-0.401,0]},{\"t\":37,\"s\":[1241.05,591.81,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1839.771,332.518,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.582,0.582,0.582],\"y\":[0.82,0.82,9.89]},\"o\":{\"x\":[0.18,0.18,0.18],\"y\":[0.072,0.072,-3.541]},\"t\":21,\"s\":[77,77,100]},{\"i\":{\"x\":[0.676,0.676,0.676],\"y\":[0.877,0.877,3.181]},\"o\":{\"x\":[0.336,0.336,0.336],\"y\":[0.604,0.604,-10.699]},\"t\":25,\"s\":[37.554,37.554,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,-1.52]},\"o\":{\"x\":[0.35,0.35,0.35],\"y\":[0.14,0.14,-2.359]},\"t\":31,\"s\":[23.405,23.405,100]},{\"t\":37,\"s\":[10,10,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[75.65,79.631],[-11.945,18.58]],\"o\":[[19.908,58.396],[11.944,-18.581]],\"v\":[[-68.35,-69.014],[56.406,50.434]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1792.24,288.102],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[8.982,12.574],[-46.668,-46.763],[-3.707,5.574],[3.66,3.206],[2.953,1.999]],\"o\":[[0,0],[44.699,42.754],[3.707,-5.575],[-3.661,-3.207],[-19.334,-12.347]],\"v\":[[-64.152,-62.511],[-5.913,19.491],[60.445,56.936],[55.867,40.027],[20.186,11.184]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.003921568627,0.517647058824,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1788.042,281.599],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":21,\"op\":38,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":233,\"ty\":4,\"nm\":\"blast 1 17 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.582,\"y\":0.82},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":21,\"s\":[1168.55,465.31,0],\"to\":[6.733,3.734,0],\"ti\":[-15.54,-8.619,0]},{\"i\":{\"x\":0.676,\"y\":0.877},\"o\":{\"x\":0.336,\"y\":0.604},\"t\":25,\"s\":[1211.23,488.965,0],\"to\":[6.322,3.506,0],\"ti\":[-3.462,-1.929,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.35,\"y\":0.96},\"t\":31,\"s\":[1226.531,497.463,0],\"to\":[0.562,0.313,0],\"ti\":[-0.337,-0.225,0]},{\"t\":37,\"s\":[1228.55,498.81,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1846.264,266.284,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.582,0.582,0.582],\"y\":[0.82,0.82,9.89]},\"o\":{\"x\":[0.18,0.18,0.18],\"y\":[0.072,0.072,-3.541]},\"t\":21,\"s\":[77,77,100]},{\"i\":{\"x\":[0.676,0.676,0.676],\"y\":[0.877,0.877,3.181]},\"o\":{\"x\":[0.336,0.336,0.336],\"y\":[0.604,0.604,-10.699]},\"t\":25,\"s\":[37.554,37.554,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,-1.52]},\"o\":{\"x\":[0.35,0.35,0.35],\"y\":[0.14,0.14,-2.359]},\"t\":31,\"s\":[23.405,23.405,100]},{\"t\":37,\"s\":[10,10,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,7.33],[-7.33,0],[0,-7.33],[7.33,0]],\"o\":[[0,-7.33],[7.33,0],[0,7.33],[-7.33,0]],\"v\":[[-13.272,0],[0,-13.272],[13.272,0],[0,13.272]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1845.991,265.54],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-5.307,-4.649],[4.649,-5.307],[5.307,4.649],[-4.649,5.307]],\"o\":[[5.307,4.649],[-4.648,5.307],[-5.306,-4.648],[4.649,-5.306]],\"v\":[[8.418,-9.609],[9.609,8.417],[-8.417,9.609],[-9.608,-8.417]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.549019607843,0.780392216701,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1845.991,265.54],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":21,\"op\":38,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":234,\"ty\":4,\"nm\":\"blast 1 18 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.582,\"y\":0.82},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":21,\"s\":[1141.55,455.31,0],\"to\":[5.094,2.32,0],\"ti\":[-11.755,-5.356,0]},{\"i\":{\"x\":0.676,\"y\":0.877},\"o\":{\"x\":0.336,\"y\":0.604},\"t\":25,\"s\":[1173.832,469.996,0],\"to\":[4.779,2.177,0],\"ti\":[-2.621,-1.204,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.35,\"y\":0.871},\"t\":31,\"s\":[1185.402,475.281,0],\"to\":[0.425,0.195,0],\"ti\":[-0.275,-0.171,0]},{\"t\":37,\"s\":[1187.05,476.31,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1811.199,253.297,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.582,0.582,0.582],\"y\":[0.82,0.82,9.89]},\"o\":{\"x\":[0.18,0.18,0.18],\"y\":[0.072,0.072,-3.541]},\"t\":21,\"s\":[77,77,100]},{\"i\":{\"x\":[0.676,0.676,0.676],\"y\":[0.877,0.877,3.181]},\"o\":{\"x\":[0.336,0.336,0.336],\"y\":[0.604,0.604,-10.699]},\"t\":25,\"s\":[37.554,37.554,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,-1.52]},\"o\":{\"x\":[0.35,0.35,0.35],\"y\":[0.14,0.14,-2.359]},\"t\":31,\"s\":[23.405,23.405,100]},{\"t\":37,\"s\":[10,10,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[32.411,34.067],[-0.407,-13.43]],\"o\":[[0,0],[0.408,13.431]],\"v\":[[-34.565,-19.673],[34.157,6.242]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1785.445,242.51],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-19.021,-5.752],[-3.5,7.521],[10.435,3.831]],\"o\":[[0,0],[12.264,4.127],[3.5,-7.52],[-13.593,-3.668]],\"v\":[[-35.482,-17.451],[3.797,10.382],[31.983,9.93],[3.117,-8.747]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1786.85,240.534],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":21,\"op\":38,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":235,\"ty\":4,\"nm\":\"blast 1 19 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.582,\"y\":0.82},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":21,\"s\":[1188.55,422.31,0],\"to\":[6.912,-0.227,0],\"ti\":[-15.943,0.523,0]},{\"i\":{\"x\":0.676,\"y\":0.877},\"o\":{\"x\":0.336,\"y\":0.604},\"t\":25,\"s\":[1232.299,420.872,0],\"to\":[6.466,-0.212,0],\"ti\":[-3.574,0.115,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.35,\"y\":0.683},\"t\":31,\"s\":[1247.991,420.36,0],\"to\":[0.575,-0.019,0],\"ti\":[-0.51,0.008,0]},{\"t\":37,\"s\":[1251.05,420.31,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1872.238,210.44,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.582,0.582,0.582],\"y\":[0.82,0.82,9.89]},\"o\":{\"x\":[0.18,0.18,0.18],\"y\":[0.072,0.072,-3.541]},\"t\":21,\"s\":[77,77,100]},{\"i\":{\"x\":[0.676,0.676,0.676],\"y\":[0.877,0.877,3.181]},\"o\":{\"x\":[0.336,0.336,0.336],\"y\":[0.604,0.604,-10.699]},\"t\":25,\"s\":[37.554,37.554,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,-1.52]},\"o\":{\"x\":[0.35,0.35,0.35],\"y\":[0.14,0.14,-2.359]},\"t\":31,\"s\":[23.405,23.405,100]},{\"t\":37,\"s\":[10,10,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-5.958,0.712],[0,0],[-1.108,2.109],[0,0],[-2.519,-5.446],[0,0],[-2.348,-0.402],[0,0],[4.401,-4.078],[0,0],[-0.343,-2.358],[0,0],[5.239,2.925],[0,0],[2.137,-1.055],[0,0],[-1.163,5.886],[0,0],[1.664,1.706],[0,0]],\"o\":[[0,0],[2.366,-0.283],[0,0],[2.791,-5.312],[0,0],[1,2.163],[0,0],[5.914,1.013],[0,0],[-1.747,1.62],[0,0],[0.864,5.938],[0,0],[-2.08,-1.161],[0,0],[-5.38,2.657],[0,0],[0.462,-2.337],[0,0],[-4.19,-4.296]],\"v\":[[-29.243,-14.791],[-17.099,-16.243],[-11.55,-20.064],[-5.861,-30.891],[7.119,-30.563],[12.252,-19.462],[17.601,-15.365],[29.656,-13.301],[33.355,-0.855],[24.383,7.458],[22.14,13.811],[23.902,25.914],[13.208,33.278],[2.53,27.314],[-4.206,27.144],[-15.172,32.56],[-25.48,24.665],[-23.108,12.666],[-25.027,6.208],[-33.566,-2.548]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1873.589,208.841],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-3.942,4.048],[0,0],[-2.717,2.929],[-0.012,5.401],[3.505,0.394],[3.885,7.05],[6.158,-1.129],[6.528,-3.212],[5.382,-5.383],[-0.595,-7.542],[-2.663,-3.409],[-3.409,2.663],[-4.155,-1.599]],\"o\":[[0,0],[3.943,-4.047],[0,0],[2.717,-2.93],[0.012,-5.401],[-3.505,-0.395],[-3.885,-7.049],[-6.158,1.128],[-3.867,2.107],[-5.499,7.264],[0.596,7.543],[2.663,3.41],[3.41,-2.663],[4.154,1.598]],\"v\":[[11.127,31.352],[23.558,32.111],[25.479,20.5],[25.342,8.046],[37.5,-6.196],[28.467,-14.123],[13.847,-21.266],[1.117,-35.029],[-12.964,-16.974],[-32.012,-11.48],[-21.501,10.37],[-21.685,29.856],[-10.638,30.909],[4.065,26.568]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.792156922583,0.964705942191,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1871.488,209.035],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":21,\"op\":38,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":236,\"ty\":4,\"nm\":\"blast 1 20 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.582,\"y\":0.82},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":21,\"s\":[1141.55,390.31,0],\"to\":[4.522,-3.109,0],\"ti\":[-10.442,7.179,0]},{\"i\":{\"x\":0.676,\"y\":0.877},\"o\":{\"x\":0.336,\"y\":0.604},\"t\":25,\"s\":[1170.237,370.588,0],\"to\":[4.257,-2.927,0],\"ti\":[-2.321,1.596,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.262,\"y\":1},\"t\":31,\"s\":[1180.527,363.514,0],\"to\":[0.38,-0.261,0],\"ti\":[-0.171,0.117,0]},{\"t\":37,\"s\":[1181.55,362.81,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1811.199,168.881,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.582,0.582,0.582],\"y\":[0.82,0.82,9.89]},\"o\":{\"x\":[0.18,0.18,0.18],\"y\":[0.072,0.072,-3.541]},\"t\":21,\"s\":[77,77,100]},{\"i\":{\"x\":[0.676,0.676,0.676],\"y\":[0.877,0.877,3.181]},\"o\":{\"x\":[0.336,0.336,0.336],\"y\":[0.604,0.604,-10.699]},\"t\":25,\"s\":[37.554,37.554,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,-1.52]},\"o\":{\"x\":[0.35,0.35,0.35],\"y\":[0.14,0.14,-2.359]},\"t\":31,\"s\":[23.405,23.405,100]},{\"t\":37,\"s\":[10,10,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[32.411,-34.067],[-0.407,13.43]],\"o\":[[0,0],[0.408,-13.431]],\"v\":[[-34.565,19.673],[34.157,-6.242]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1786.109,173.77],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-1.693,13.514],[19.482,-9.675],[4.717,-6.895]],\"o\":[[0,0],[1.634,-6.822],[-19.483,9.674],[0,0]],\"v\":[[-33.455,17.703],[33.632,-8.005],[1.925,-9.088],[-35.266,18.763]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1786.634,175.533],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":21,\"op\":38,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":237,\"ty\":4,\"nm\":\"blast 1 21 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.582,\"y\":0.82},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":21,\"s\":[1169.55,377.31,0],\"to\":[6.563,-4.866,0],\"ti\":[-15.148,11.231,0]},{\"i\":{\"x\":0.676,\"y\":0.877},\"o\":{\"x\":0.336,\"y\":0.604},\"t\":25,\"s\":[1211.152,346.477,0],\"to\":[6.163,-4.569,0],\"ti\":[-3.376,2.508,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.35,\"y\":0.97},\"t\":31,\"s\":[1226.068,335.411,0],\"to\":[0.548,-0.407,0],\"ti\":[-0.33,0.267,0]},{\"t\":37,\"s\":[1228.05,333.81,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1847.563,151.998,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.582,0.582,0.582],\"y\":[0.82,0.82,9.89]},\"o\":{\"x\":[0.18,0.18,0.18],\"y\":[0.072,0.072,-3.541]},\"t\":21,\"s\":[77,77,100]},{\"i\":{\"x\":[0.676,0.676,0.676],\"y\":[0.877,0.877,3.181]},\"o\":{\"x\":[0.336,0.336,0.336],\"y\":[0.604,0.604,-10.699]},\"t\":25,\"s\":[37.554,37.554,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,-1.52]},\"o\":{\"x\":[0.35,0.35,0.35],\"y\":[0.14,0.14,-2.359]},\"t\":31,\"s\":[23.405,23.405,100]},{\"t\":37,\"s\":[10,10,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-7.33],[-7.33,0],[0,7.33],[7.33,0]],\"o\":[[0,7.33],[7.33,0],[0,-7.33],[-7.33,0]],\"v\":[[-13.272,0],[0,13.272],[13.272,0],[0,-13.272]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1846.655,150.739],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-5.534,-4.848],[4.848,-5.534],[5.533,4.847],[-4.847,5.534]],\"o\":[[5.534,4.848],[-4.847,5.533],[-5.534,-4.848],[4.848,-5.533]],\"v\":[[8.777,-10.019],[10.019,8.778],[-8.777,10.02],[-10.02,-8.777]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.549019607843,0.780392216701,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1847.061,150.69],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":21,\"op\":38,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":238,\"ty\":4,\"nm\":\"blast 1 22 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.582,\"y\":0.82},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":21,\"s\":[1166.55,323.31,0],\"to\":[8.422,-8.422,0],\"ti\":[-19.449,19.449,0]},{\"i\":{\"x\":0.676,\"y\":0.877},\"o\":{\"x\":0.336,\"y\":0.604},\"t\":25,\"s\":[1219.981,269.879,0],\"to\":[7.929,-7.929,0],\"ti\":[-4.322,4.322,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.262,\"y\":1},\"t\":31,\"s\":[1239.145,250.715,0],\"to\":[0.707,-0.707,0],\"ti\":[-0.318,0.318,0]},{\"t\":37,\"s\":[1241.05,248.81,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1843.667,81.868,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.582,0.582,0.582],\"y\":[0.82,0.82,9.89]},\"o\":{\"x\":[0.18,0.18,0.18],\"y\":[0.072,0.072,-3.541]},\"t\":21,\"s\":[77,77,100]},{\"i\":{\"x\":[0.676,0.676,0.676],\"y\":[0.877,0.877,3.181]},\"o\":{\"x\":[0.336,0.336,0.336],\"y\":[0.604,0.604,-10.699]},\"t\":25,\"s\":[37.554,37.554,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,-1.52]},\"o\":{\"x\":[0.35,0.35,0.35],\"y\":[0.14,0.14,-2.359]},\"t\":31,\"s\":[23.405,23.405,100]},{\"t\":37,\"s\":[10,10,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[75.65,-79.631],[-11.944,-18.58]],\"o\":[[19.908,-58.396],[11.945,18.581]],\"v\":[[-68.35,69.013],[56.405,-50.433]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1792.903,128.177],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[3.759,-23.761],[-42.519,29.64],[4.541,8.725],[33.018,-26.949]],\"o\":[[0,0],[20.983,-14.554],[-3.094,-5.404],[-33.018,26.949]],\"v\":[[-65.072,64.341],[21.244,-11.75],[60.53,-53.487],[16.195,-37.392]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.003921568627,0.517647058824,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1789.625,132.849],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":21,\"op\":38,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":239,\"ty\":4,\"nm\":\"blast 1 23 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.582,\"y\":0.82},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":21,\"s\":[1103.55,328.31,0],\"to\":[2.604,-6.681,0],\"ti\":[-6.01,15.415,0]},{\"i\":{\"x\":0.676,\"y\":0.877},\"o\":{\"x\":0.336,\"y\":0.604},\"t\":25,\"s\":[1120.039,285.992,0],\"to\":[2.441,-6.261,0],\"ti\":[-1.347,3.446,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.35,\"y\":0.793},\"t\":31,\"s\":[1125.96,270.818,0],\"to\":[0.218,-0.557,0],\"ti\":[-0.182,0.418,0]},{\"t\":37,\"s\":[1127.05,268.31,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1761.849,88.362,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.582,0.582,0.582],\"y\":[0.82,0.82,9.89]},\"o\":{\"x\":[0.18,0.18,0.18],\"y\":[0.072,0.072,-3.541]},\"t\":21,\"s\":[77,77,100]},{\"i\":{\"x\":[0.676,0.676,0.676],\"y\":[0.877,0.877,3.181]},\"o\":{\"x\":[0.336,0.336,0.336],\"y\":[0.604,0.604,-10.699]},\"t\":25,\"s\":[37.554,37.554,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,-1.52]},\"o\":{\"x\":[0.35,0.35,0.35],\"y\":[0.14,0.14,-2.359]},\"t\":31,\"s\":[23.405,23.405,100]},{\"t\":37,\"s\":[10,10,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[7.3,-46.452],[7.3,11.281]],\"o\":[[0,0],[-7.299,-11.281]],\"v\":[[-24.553,35.834],[17.253,-24.553]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1751.097,108.932],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.565,-5.68],[-5.874,10.734],[5.945,4.654],[7.935,-11.576]],\"o\":[[0,0],[5.874,-10.734],[-5.944,-4.653],[-7.934,11.575]],\"v\":[[-22.957,33.113],[12.287,-7.456],[17.012,-28.46],[-7.469,-11.088]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1749.339,111.491],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":21,\"op\":38,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":240,\"ty\":4,\"nm\":\"blast 1 24 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.582,\"y\":0.82},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":21,\"s\":[1116.55,309.31,0],\"to\":[4.239,-9.383,0],\"ti\":[-9.79,21.668,0]},{\"i\":{\"x\":0.676,\"y\":0.877},\"o\":{\"x\":0.336,\"y\":0.604},\"t\":25,\"s\":[1143.445,249.783,0],\"to\":[3.991,-8.833,0],\"ti\":[-2.176,4.815,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.262,\"y\":1},\"t\":31,\"s\":[1153.091,228.432,0],\"to\":[0.356,-0.787,0],\"ti\":[-0.16,0.354,0]},{\"t\":37,\"s\":[1154.05,226.31,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1778.732,63.687,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.582,0.582,0.582],\"y\":[0.82,0.82,9.89]},\"o\":{\"x\":[0.18,0.18,0.18],\"y\":[0.072,0.072,-3.541]},\"t\":21,\"s\":[77,77,100]},{\"i\":{\"x\":[0.676,0.676,0.676],\"y\":[0.877,0.877,3.181]},\"o\":{\"x\":[0.336,0.336,0.336],\"y\":[0.604,0.604,-10.699]},\"t\":25,\"s\":[37.554,37.554,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,-1.52]},\"o\":{\"x\":[0.35,0.35,0.35],\"y\":[0.14,0.14,-2.359]},\"t\":31,\"s\":[23.405,23.405,100]},{\"t\":37,\"s\":[10,10,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-5.497],[-5.497,0],[0,5.497],[5.497,0]],\"o\":[[0,5.497],[5.497,0],[0,-5.497],[-5.497,0]],\"v\":[[-9.954,0],[0,9.954],[9.954,0],[0,-9.954]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1778.305,62.481],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-4.107,-3.598],[3.598,-4.107],[4.107,3.598],[-3.598,4.107]],\"o\":[[4.107,3.598],[-3.598,4.107],[-4.107,-3.598],[3.598,-4.107]],\"v\":[[6.515,-7.437],[7.437,6.514],[-6.515,7.436],[-7.437,-6.514]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.549019607843,0.780392216701,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1778.237,62.68],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":21,\"op\":38,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":241,\"ty\":4,\"nm\":\"blast 1 25 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.582,\"y\":0.82},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":21,\"s\":[1064.55,299.31,0],\"to\":[0,-6.974,0],\"ti\":[0,16.08,0]},{\"i\":{\"x\":0.676,\"y\":0.877},\"o\":{\"x\":0.336,\"y\":0.604},\"t\":25,\"s\":[1064.55,255.202,0],\"to\":[0,-6.51,0],\"ti\":[0,3.615,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.35,\"y\":0.59},\"t\":31,\"s\":[1064.55,239.382,0],\"to\":[0,-0.579,0],\"ti\":[0,0.595,0]},{\"t\":37,\"s\":[1064.55,235.81,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1711.199,50.7,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.582,0.582,0.582],\"y\":[0.82,0.82,9.89]},\"o\":{\"x\":[0.18,0.18,0.18],\"y\":[0.072,0.072,-3.541]},\"t\":21,\"s\":[77,77,100]},{\"i\":{\"x\":[0.676,0.676,0.676],\"y\":[0.877,0.877,3.181]},\"o\":{\"x\":[0.336,0.336,0.336],\"y\":[0.604,0.604,-10.699]},\"t\":25,\"s\":[37.554,37.554,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,-1.52]},\"o\":{\"x\":[0.35,0.35,0.35],\"y\":[0.14,0.14,-2.359]},\"t\":31,\"s\":[23.405,23.405,100]},{\"t\":37,\"s\":[10,10,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-1.294,5.859],[0,0],[1.625,1.742],[0,0],[-5.972,0.58],[0,0],[-1.155,2.084],[0,0],[-2.397,-5.501],[0,0],[-2.34,-0.454],[0,0],[4.491,-3.979],[0,0],[-0.291,-2.365],[0,0],[5.173,3.041],[0,0],[2.159,-1.007],[0,0]],\"o\":[[0,0],[0.514,-2.326],[0,0],[-4.093,-4.388],[0,0],[2.372,-0.23],[0,0],[2.908,-5.249],[0,0],[0.952,2.184],[0,0],[5.89,1.143],[0,0],[-1.783,1.581],[0,0],[0.732,5.956],[0,0],[-2.054,-1.208],[0,0],[-5.437,2.537]],\"v\":[[-26.15,23.923],[-23.513,11.98],[-25.288,5.481],[-33.632,-3.462],[-29.038,-15.606],[-16.865,-16.789],[-11.232,-20.486],[-5.305,-31.184],[7.664,-30.568],[12.551,-19.356],[17.807,-15.142],[29.814,-12.81],[33.234,-0.286],[24.082,7.826],[21.698,14.128],[23.192,26.267],[12.337,33.392],[1.794,27.193],[-4.936,26.873],[-16.021,32.045]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1713.564,49.543],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-4.044,3.945],[0,0],[-2.791,2.859],[-0.149,5.399],[3.494,0.484],[4.398,7.604],[6.184,-0.971],[3.405,-4.567],[-0.098,-7.19],[-0.403,-7.556],[-2.575,-3.476],[-3.476,2.575],[-4.112,-1.704]],\"o\":[[0,0],[4.044,-3.946],[0,0],[2.791,-2.859],[0.149,-5.399],[-3.494,-0.484],[-4.398,-7.605],[-6.185,0.971],[-3.919,2.008],[-1.19,10.828],[0.403,7.555],[2.575,3.477],[3.476,-2.575],[4.113,1.704]],\"v\":[[11.438,32.569],[21.407,32.174],[23.135,22.084],[23.315,9.631],[35.832,-6.456],[25.945,-13.509],[12.124,-21.507],[0.583,-35.149],[-11.829,-18.743],[-34.791,-11.419],[-23.572,8.216],[-24.252,30.237],[-13.203,30.318],[2.282,26.897]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.792156922583,0.964705942191,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1713.115,49.879],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":21,\"op\":38,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":242,\"ty\":4,\"nm\":\"blast 1 26 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.582,\"y\":0.82},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":21,\"s\":[1017.55,329.31,0],\"to\":[-2.77,-6.726,0],\"ti\":[6.396,15.533,0]},{\"i\":{\"x\":0.676,\"y\":0.877},\"o\":{\"x\":0.336,\"y\":0.604},\"t\":25,\"s\":[999.979,286.637,0],\"to\":[-2.607,-6.332,0],\"ti\":[1.421,3.452,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.262,\"y\":1},\"t\":31,\"s\":[993.676,271.331,0],\"to\":[-0.232,-0.564,0],\"ti\":[0.104,0.254,0]},{\"t\":37,\"s\":[993.05,269.81,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1650.16,89.661,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.582,0.582,0.582],\"y\":[0.82,0.82,9.89]},\"o\":{\"x\":[0.18,0.18,0.18],\"y\":[0.072,0.072,-3.541]},\"t\":21,\"s\":[77,77,100]},{\"i\":{\"x\":[0.676,0.676,0.676],\"y\":[0.877,0.877,3.181]},\"o\":{\"x\":[0.336,0.336,0.336],\"y\":[0.604,0.604,-10.699]},\"t\":25,\"s\":[37.554,37.554,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,-1.52]},\"o\":{\"x\":[0.35,0.35,0.35],\"y\":[0.14,0.14,-2.359]},\"t\":31,\"s\":[23.405,23.405,100]},{\"t\":37,\"s\":[10,10,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-7.299,-46.452],[-7.3,11.281]],\"o\":[[0,0],[7.299,-11.281]],\"v\":[[24.553,35.834],[-17.253,-24.553]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1664.83,108.932],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[10.029,15.55],[5.091,-4.804],[-1.528,-1.78],[-6.51,-4.401]],\"o\":[[0,0],[-4.987,-11.426],[-5.09,4.804],[1.529,1.78],[0,0]],\"v\":[[21.986,31.878],[8.525,-8.145],[-17.526,-28.76],[-15.322,-12.014],[22.616,33.564]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.317647058824,0.929411824544,0.964705942191,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1666.767,111.536],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":21,\"op\":38,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":243,\"ty\":4,\"nm\":\"blast 1 27 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.582,\"y\":0.82},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":21,\"s\":[1007.55,309.31,0],\"to\":[-4.635,-9.327,0],\"ti\":[10.703,21.537,0]},{\"i\":{\"x\":0.676,\"y\":0.877},\"o\":{\"x\":0.336,\"y\":0.604},\"t\":25,\"s\":[978.145,250.141,0],\"to\":[-4.363,-8.78,0],\"ti\":[2.379,4.786,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.262,\"y\":1},\"t\":31,\"s\":[967.598,228.92,0],\"to\":[-0.389,-0.782,0],\"ti\":[0.175,0.352,0]},{\"t\":37,\"s\":[966.55,226.81,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1637.173,63.687,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.582,0.582,0.582],\"y\":[0.82,0.82,9.89]},\"o\":{\"x\":[0.18,0.18,0.18],\"y\":[0.072,0.072,-3.541]},\"t\":21,\"s\":[77,77,100]},{\"i\":{\"x\":[0.676,0.676,0.676],\"y\":[0.877,0.877,3.181]},\"o\":{\"x\":[0.336,0.336,0.336],\"y\":[0.604,0.604,-10.699]},\"t\":25,\"s\":[37.554,37.554,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,-1.52]},\"o\":{\"x\":[0.35,0.35,0.35],\"y\":[0.14,0.14,-2.359]},\"t\":31,\"s\":[23.405,23.405,100]},{\"t\":37,\"s\":[10,10,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-5.497],[5.497,0],[0,5.497],[-5.497,0]],\"o\":[[0,5.497],[-5.497,0],[0,-5.497],[5.497,0]],\"v\":[[9.954,0],[0,9.954],[-9.954,0],[0,-9.954]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1637.623,62.481],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-4.11,-3.6],[3.6,-4.11],[4.111,3.601],[-3.601,4.11]],\"o\":[[4.11,3.601],[-3.601,4.11],[-4.11,-3.6],[3.6,-4.11]],\"v\":[[6.52,-7.443],[7.443,6.519],[-6.52,7.441],[-7.442,-6.519]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.549019607843,0.780392216701,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1637.941,62.542],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":21,\"op\":38,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":244,\"ty\":4,\"nm\":\"blast 1 28 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.582,\"y\":0.82},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":21,\"s\":[954.55,322.31,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.676,\"y\":0.877},\"o\":{\"x\":0.336,\"y\":0.604},\"t\":25,\"s\":[901.126,269.603,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.35,\"y\":0.577},\"t\":31,\"s\":[881.956,250.691,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":37,\"s\":[877.55,246.31,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[1568.342,80.57,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.582,0.582,0.582],\"y\":[0.82,0.82,0.059]},\"o\":{\"x\":[0.18,0.18,0.18],\"y\":[0.072,0.072,0.375]},\"t\":21,\"s\":[77,77,100]},{\"i\":{\"x\":[0.676,0.676,0.676],\"y\":[0.877,0.877,0.769]},\"o\":{\"x\":[0.336,0.336,0.336],\"y\":[0.604,0.604,1.133]},\"t\":25,\"s\":[37.554,37.554,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,10.854]},\"o\":{\"x\":[0.35,0.35,0.35],\"y\":[0.14,0.14,0.25]},\"t\":31,\"s\":[23.405,23.405,100]},{\"t\":37,\"s\":[10,10,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-75.65,-79.631],[11.944,-18.58]],\"o\":[[-19.908,-58.396],[-11.945,18.581]],\"v\":[[68.35,69.013],[-56.405,-50.433]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1623.024,128.177],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-18.581,-24.955],[55.181,45.726],[2.124,-3.432],[-6.926,-5.186]],\"o\":[[0,0],[-44.486,-39.853],[-4.25,10.778],[6.926,5.185]],\"v\":[[64.844,66.217],[-5.238,-26.364],[-60.594,-52.802],[-43.203,-26.299]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.003921568627,0.517647058824,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1626.53,130.973],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":21,\"op\":38,\"st\":0,\"ct\":1,\"bm\":0}]}],\"layers\":[{\"ddd\":0,\"ind\":1,\"ty\":0,\"nm\":\"Expensify-Fireworks-120722-kjs-1\",\"refId\":\"comp_0\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[180,180,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[961,540.5,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[40,40,100],\"ix\":6,\"l\":2}},\"ao\":0,\"w\":1922,\"h\":1081,\"ip\":0,\"op\":109,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":3,\"ty\":1,\"nm\":\"Dark Green Solid 1\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[180,180,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[180,180,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"sw\":360,\"sh\":360,\"sc\":\"#061b09\",\"ip\":0,\"op\":109,\"st\":0,\"bm\":0}],\"markers\":[]}","import React, {Component} from 'react';\nimport {View} from 'react-native';\nimport _ from 'underscore';\nimport {withOnyx} from 'react-native-onyx';\nimport PropTypes from 'prop-types';\nimport compose from '../../../libs/compose';\nimport HeaderWithCloseButton from '../../../components/HeaderWithCloseButton';\nimport Navigation from '../../../libs/Navigation/Navigation';\nimport ScreenWrapper from '../../../components/ScreenWrapper';\nimport styles from '../../../styles/styles';\nimport Text from '../../../components/Text';\nimport TextLink from '../../../components/TextLink';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport * as PaymentMethods from '../../../libs/actions/PaymentMethods';\nimport * as ValidationUtils from '../../../libs/ValidationUtils';\nimport CheckboxWithLabel from '../../../components/CheckboxWithLabel';\nimport StatePicker from '../../../components/StatePicker';\nimport TextInput from '../../../components/TextInput';\nimport CONST from '../../../CONST';\nimport ONYXKEYS from '../../../ONYXKEYS';\nimport AddressSearch from '../../../components/AddressSearch';\nimport * as ComponentUtils from '../../../libs/ComponentUtils';\nimport Form from '../../../components/Form';\nimport Permissions from '../../../libs/Permissions';\n\nconst propTypes = {\n /* Onyx Props */\n formData: PropTypes.shape({\n setupComplete: PropTypes.bool,\n }),\n\n /** List of betas available to current user */\n betas: PropTypes.arrayOf(PropTypes.string),\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n formData: {\n setupComplete: false,\n },\n betas: [],\n};\n\nclass DebitCardPage extends Component {\n constructor(props) {\n super(props);\n\n this.validate = this.validate.bind(this);\n PaymentMethods.clearDebitCardFormErrorAndSubmit();\n }\n\n componentDidUpdate(prevProps) {\n if (prevProps.formData.setupComplete || !this.props.formData.setupComplete) {\n return;\n }\n\n PaymentMethods.continueSetup();\n }\n\n /**\n * Make sure we reset the onyx values so old errors don't show if this form is displayed later\n */\n componentWillUnmount() {\n PaymentMethods.clearDebitCardFormErrorAndSubmit();\n }\n\n /**\n * @param {Object} values - form input values passed by the Form component\n * @returns {Boolean}\n */\n validate(values) {\n const errors = {};\n\n if (!values.nameOnCard || !ValidationUtils.isValidCardName(values.nameOnCard)) {\n errors.nameOnCard = this.props.translate('addDebitCardPage.error.invalidName');\n }\n\n if (!values.cardNumber || !ValidationUtils.isValidDebitCard(values.cardNumber.replace(/ /g, ''))) {\n errors.cardNumber = this.props.translate('addDebitCardPage.error.debitCardNumber');\n }\n\n if (!values.expirationDate || !ValidationUtils.isValidExpirationDate(values.expirationDate)) {\n errors.expirationDate = this.props.translate('addDebitCardPage.error.expirationDate');\n }\n\n if (!values.securityCode || !ValidationUtils.isValidSecurityCode(values.securityCode)) {\n errors.securityCode = this.props.translate('addDebitCardPage.error.securityCode');\n }\n\n if (!values.addressStreet || !ValidationUtils.isValidAddress(values.addressStreet)) {\n errors.addressStreet = this.props.translate('addDebitCardPage.error.addressStreet');\n }\n\n if (!values.addressZipCode || !ValidationUtils.isValidZipCode(values.addressZipCode)) {\n errors.addressZipCode = this.props.translate('addDebitCardPage.error.addressZipCode');\n }\n\n if (!values.addressState || !values.addressState) {\n errors.addressState = this.props.translate('addDebitCardPage.error.addressState');\n }\n\n if (!Permissions.canUsePasswordlessLogins(this.props.betas) && (!values.password || _.isEmpty(values.password.trim()))) {\n errors.password = this.props.translate('addDebitCardPage.error.password');\n }\n\n if (!values.acceptTerms) {\n errors.acceptTerms = this.props.translate('common.error.acceptTerms');\n }\n\n return errors;\n }\n\n render() {\n return (\n \n Navigation.goBack()}\n onCloseButtonPress={() => Navigation.dismissModal(true)}\n />\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n {!Permissions.canUsePasswordlessLogins(this.props.betas) && (\n \n \n \n )}\n (\n \n {`${this.props.translate('common.iAcceptThe')}`}\n \n {`${this.props.translate('common.expensifyTermsOfService')}`}\n \n \n )}\n style={[styles.mt4]}\n />\n \n \n );\n }\n}\n\nDebitCardPage.propTypes = propTypes;\nDebitCardPage.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withOnyx({\n formData: {\n key: ONYXKEYS.FORMS.ADD_DEBIT_CARD_FORM,\n },\n betas: {\n key: ONYXKEYS.BETAS,\n },\n }),\n)(DebitCardPage);\n","import moment from 'moment';\nimport _ from 'underscore';\nimport CONST from '../CONST';\nimport * as CardUtils from './CardUtils';\nimport * as LoginUtils from './LoginUtils';\nimport * as Localize from './Localize';\n\n/**\n * Implements the Luhn Algorithm, a checksum formula used to validate credit card\n * numbers.\n *\n * @param {String} val\n * @returns {Boolean}\n */\nfunction validateCardNumber(val) {\n let sum = 0;\n for (let i = 0; i < val.length; i++) {\n let intVal = parseInt(val.substr(i, 1), 10);\n if (i % 2 === 0) {\n intVal *= 2;\n if (intVal > 9) {\n intVal = 1 + (intVal % 10);\n }\n }\n sum += intVal;\n }\n return (sum % 10) === 0;\n}\n\n/**\n * Validating that this is a valid address (PO boxes are not allowed)\n *\n * @param {String} value\n * @returns {Boolean}\n */\nfunction isValidAddress(value) {\n if (!CONST.REGEX.ANY_VALUE.test(value)) {\n return false;\n }\n\n return !CONST.REGEX.PO_BOX.test(value);\n}\n\n/**\n * Validate date fields\n *\n * @param {String|Date} date\n * @returns {Boolean} true if valid\n */\nfunction isValidDate(date) {\n if (!date) {\n return false;\n }\n\n const pastDate = moment().subtract(1000, 'years');\n const futureDate = moment().add(1000, 'years');\n const testDate = moment(date);\n return testDate.isValid() && testDate.isBetween(pastDate, futureDate);\n}\n\n/**\n * Validate that date entered isn't a future date.\n *\n * @param {String|Date} date\n * @returns {Boolean} true if valid\n */\nfunction isValidPastDate(date) {\n if (!date) {\n return false;\n }\n\n const pastDate = moment().subtract(1000, 'years');\n const currentDate = moment();\n const testDate = moment(date).startOf('day');\n return testDate.isValid() && testDate.isBetween(pastDate, currentDate);\n}\n\n/**\n * Used to validate a value that is \"required\".\n *\n * @param {*} value\n * @returns {Boolean}\n */\nfunction isRequiredFulfilled(value) {\n if (_.isString(value)) {\n return !_.isEmpty(value.trim());\n }\n if (_.isDate(value)) {\n return isValidDate(value);\n }\n if (_.isArray(value) || _.isObject(value)) {\n return !_.isEmpty(value);\n }\n return Boolean(value);\n}\n\n/**\n * Validates that this is a valid expiration date. Supports the following formats:\n * 1. MM/YY\n * 2. MM/YYYY\n * 3. MMYY\n * 4. MMYYYY\n *\n * @param {String} string\n * @returns {Boolean}\n */\nfunction isValidExpirationDate(string) {\n if (!CONST.REGEX.CARD_EXPIRATION_DATE.test(string)) {\n return false;\n }\n\n // Use the last of the month to check if the expiration date is in the future or not\n const expirationDate = `${CardUtils.getYearFromExpirationDateString(string)}-${CardUtils.getMonthFromExpirationDateString(string)}-01`;\n return moment(expirationDate).endOf('month').isAfter(moment());\n}\n\n/**\n * Validates that this is a valid security code\n * in the XXX or XXXX format.\n *\n * @param {String} string\n * @returns {Boolean}\n */\nfunction isValidSecurityCode(string) {\n return CONST.REGEX.CARD_SECURITY_CODE.test(string);\n}\n\n/**\n * Validates a debit card number (15 or 16 digits).\n *\n * @param {String} string\n * @returns {Boolean}\n */\nfunction isValidDebitCard(string) {\n if (!CONST.REGEX.CARD_NUMBER.test(string)) {\n return false;\n }\n\n return validateCardNumber(string);\n}\n\n/**\n *\n * @param {String} nameOnCard\n * @returns {Boolean}\n */\nfunction isValidCardName(nameOnCard) {\n if (!CONST.REGEX.ALPHABETIC_CHARS.test(nameOnCard)) {\n return false;\n }\n\n return !_.isEmpty(nameOnCard.trim());\n}\n\n/**\n * @param {String} code\n * @returns {Boolean}\n */\nfunction isValidIndustryCode(code) {\n return CONST.REGEX.INDUSTRY_CODE.test(code);\n}\n\n/**\n * @param {String} zipCode\n * @returns {Boolean}\n */\nfunction isValidZipCode(zipCode) {\n return CONST.REGEX.ZIP_CODE.test(zipCode);\n}\n\n/**\n * @param {String} ssnLast4\n * @returns {Boolean}\n */\nfunction isValidSSNLastFour(ssnLast4) {\n return CONST.REGEX.SSN_LAST_FOUR.test(ssnLast4);\n}\n\n/**\n * @param {String} ssnFull9\n * @returns {Boolean}\n */\nfunction isValidSSNFullNine(ssnFull9) {\n return CONST.REGEX.SSN_FULL_NINE.test(ssnFull9);\n}\n\n/**\n *\n * @param {String} paypalUsername\n * @returns {Boolean}\n */\nfunction isValidPaypalUsername(paypalUsername) {\n return Boolean(paypalUsername) && CONST.REGEX.PAYPAL_ME_USERNAME.test(paypalUsername);\n}\n\n/**\n * Validate that \"date\" is between 18 and 150 years in the past\n *\n * @param {String} date\n * @returns {Boolean}\n */\nfunction meetsAgeRequirements(date) {\n const eighteenYearsAgo = moment().subtract(18, 'years');\n const oneHundredFiftyYearsAgo = moment().subtract(150, 'years');\n const testDate = moment(date);\n return testDate.isValid() && testDate.isBetween(oneHundredFiftyYearsAgo, eighteenYearsAgo);\n}\n\n/**\n * Validate that given date is in a specified range of years before now.\n *\n * @param {String} date\n * @param {Number} minimumAge\n * @param {Number} maximumAge\n * @returns {String}\n */\nfunction getAgeRequirementError(date, minimumAge, maximumAge) {\n const recentDate = moment().startOf('day').subtract(minimumAge, 'years');\n const longAgoDate = moment().startOf('day').subtract(maximumAge, 'years');\n const testDate = moment(date);\n if (!testDate.isValid()) {\n return Localize.translateLocal('common.error.dateInvalid');\n }\n if (testDate.isBetween(longAgoDate, recentDate, undefined, [])) {\n return '';\n }\n if (testDate.isSameOrAfter(recentDate)) {\n return Localize.translateLocal('privatePersonalDetails.error.dateShouldBeBefore', {dateString: recentDate.format(CONST.DATE.MOMENT_FORMAT_STRING)});\n }\n return Localize.translateLocal('privatePersonalDetails.error.dateShouldBeAfter', {dateString: longAgoDate.format(CONST.DATE.MOMENT_FORMAT_STRING)});\n}\n\n/**\n * Similar to backend, checks whether a website has a valid URL or not.\n * http/https/ftp URL scheme required.\n *\n * @param {String} url\n * @returns {Boolean}\n */\nfunction isValidWebsite(url) {\n return CONST.REGEX.WEBSITE.test(url);\n}\n\n/**\n * @param {Object} identity\n * @returns {Object}\n */\nfunction validateIdentity(identity) {\n const requiredFields = ['firstName', 'lastName', 'street', 'city', 'zipCode', 'state', 'ssnLast4', 'dob'];\n const errors = {};\n\n // Check that all required fields are filled\n _.each(requiredFields, (fieldName) => {\n if (isRequiredFulfilled(identity[fieldName])) {\n return;\n }\n errors[fieldName] = true;\n });\n\n if (!isValidAddress(identity.street)) {\n errors.street = true;\n }\n\n if (!isValidZipCode(identity.zipCode)) {\n errors.zipCode = true;\n }\n\n // dob field has multiple validations/errors, we are handling it temporarily like this.\n if (!isValidDate(identity.dob)) {\n errors.dob = true;\n } else if (!meetsAgeRequirements(identity.dob)) {\n errors.dobAge = true;\n }\n\n if (!isValidSSNLastFour(identity.ssnLast4)) {\n errors.ssnLast4 = true;\n }\n\n return errors;\n}\n\n/**\n * @param {String} phoneNumber\n * @param {Boolean} [isCountryCodeOptional]\n * @returns {Boolean}\n */\nfunction isValidUSPhone(phoneNumber = '', isCountryCodeOptional) {\n // Remove non alphanumeric characters from the phone number\n const sanitizedPhone = (phoneNumber || '').replace(CONST.REGEX.NON_ALPHA_NUMERIC, '');\n const isUsPhone = isCountryCodeOptional\n ? CONST.REGEX.US_PHONE_WITH_OPTIONAL_COUNTRY_CODE.test(sanitizedPhone) : CONST.REGEX.US_PHONE.test(sanitizedPhone);\n\n return CONST.REGEX.PHONE_E164_PLUS.test(sanitizedPhone) && isUsPhone;\n}\n\n/**\n * @param {String} password\n * @returns {Boolean}\n */\nfunction isValidPassword(password) {\n return password.match(CONST.PASSWORD_COMPLEXITY_REGEX_STRING);\n}\n\n/**\n * @param {string} validateCode\n * @returns {Boolean}\n */\nfunction isValidValidateCode(validateCode) {\n return validateCode.match(CONST.VALIDATE_CODE_REGEX_STRING);\n}\n\n/**\n * @param {String} code\n * @returns {Boolean}\n */\nfunction isValidTwoFactorCode(code) {\n return Boolean(code.match(CONST.REGEX.CODE_2FA));\n}\n\n/**\n * Checks whether a value is a numeric string including `(`, `)`, `-` and optional leading `+`\n * @param {String} input\n * @returns {Boolean}\n */\nfunction isNumericWithSpecialChars(input) {\n return /^\\+?\\d*$/.test(LoginUtils.getPhoneNumberWithoutSpecialChars(input));\n}\n\n/**\n * Checks the given number is a valid US Routing Number\n * using ABA routingNumber checksum algorithm: http://www.brainjar.com/js/validation/\n * @param {String} number\n * @returns {Boolean}\n */\nfunction isValidRoutingNumber(number) {\n let n = 0;\n for (let i = 0; i < number.length; i += 3) {\n n += (parseInt(number.charAt(i), 10) * 3)\n + (parseInt(number.charAt(i + 1), 10) * 7)\n + parseInt(number.charAt(i + 2), 10);\n }\n\n // If the resulting sum is an even multiple of ten (but not zero),\n // the ABA routing number is valid.\n if (n !== 0 && n % 10 === 0) {\n return true;\n }\n return false;\n}\n\n/**\n * Checks that the provided name doesn't contain any commas or semicolons\n *\n * @param {String} name\n * @returns {Boolean}\n */\nfunction isValidDisplayName(name) {\n return !name.includes(',') && !name.includes(';');\n}\n\n/**\n * Checks that the provided legal name doesn't contain special characters\n *\n * @param {String} name\n * @returns {Boolean}\n */\nfunction isValidLegalName(name) {\n return CONST.REGEX.ALPHABETIC_CHARS_WITH_NUMBER.test(name);\n}\n\n/**\n * Checks if the provided string includes any of the provided reserved words\n *\n * @param {String} value\n * @param {String[]} reservedWords\n * @returns {Boolean}\n */\nfunction doesContainReservedWord(value, reservedWords) {\n const valueToCheck = value.trim().toLowerCase();\n return _.some(reservedWords, reservedWord => valueToCheck.includes(reservedWord.toLowerCase()));\n}\n\n/**\n * Checks if is one of the certain names which are reserved for default rooms\n * and should not be used for policy rooms.\n *\n * @param {String} roomName\n * @returns {Boolean}\n */\nfunction isReservedRoomName(roomName) {\n return _.contains(CONST.REPORT.RESERVED_ROOM_NAMES, roomName);\n}\n\n/**\n * Checks if the room name already exists.\n *\n * @param {String} roomName\n * @param {Object} reports\n * @param {String} policyID\n * @returns {Boolean}\n */\nfunction isExistingRoomName(roomName, reports, policyID) {\n return _.some(\n reports,\n report => report && report.policyID === policyID\n && report.reportName === roomName,\n );\n}\n\n/**\n * Checks if a room name is valid by checking that:\n * - It starts with a hash '#'\n * - After the first character, it contains only lowercase letters, numbers, and dashes\n * - It's between 1 and MAX_ROOM_NAME_LENGTH characters long\n *\n * @param {String} roomName\n * @returns {Boolean}\n */\nfunction isValidRoomName(roomName) {\n return CONST.REGEX.ROOM_NAME.test(roomName);\n}\n\n/**\n * Checks if tax ID consists of 9 digits\n *\n * @param {String} taxID\n * @returns {Boolean}\n */\nfunction isValidTaxID(taxID) {\n return taxID && CONST.REGEX.TAX_ID.test(taxID.replace(CONST.REGEX.NON_NUMERIC, ''));\n}\n\nexport {\n meetsAgeRequirements,\n getAgeRequirementError,\n isValidAddress,\n isValidDate,\n isValidCardName,\n isValidPastDate,\n isValidSecurityCode,\n isValidExpirationDate,\n isValidDebitCard,\n isValidIndustryCode,\n isValidZipCode,\n isRequiredFulfilled,\n isValidUSPhone,\n isValidWebsite,\n validateIdentity,\n isValidPassword,\n isValidTwoFactorCode,\n isNumericWithSpecialChars,\n isValidPaypalUsername,\n isValidRoutingNumber,\n isValidSSNLastFour,\n isValidSSNFullNine,\n isReservedRoomName,\n isExistingRoomName,\n isValidRoomName,\n isValidTaxID,\n isValidValidateCode,\n isValidDisplayName,\n isValidLegalName,\n doesContainReservedWord,\n};\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport {View, TouchableOpacity} from 'react-native';\nimport styles from '../styles/styles';\nimport Checkbox from './Checkbox';\nimport Text from './Text';\nimport FormHelpMessage from './FormHelpMessage';\nimport variables from '../styles/variables';\n\nconst requiredPropsCheck = (props) => {\n if (!props.label && !props.LabelComponent) {\n return new Error('One of \"label\" or \"LabelComponent\" must be provided');\n }\n\n if (props.label && typeof props.label !== 'string') {\n return new Error('Prop \"label\" must be a string');\n }\n\n if (props.LabelComponent && typeof props.LabelComponent !== 'function') {\n return new Error('Prop \"LabelComponent\" must be a function');\n }\n};\n\nconst propTypes = {\n /** Whether the checkbox is checked */\n isChecked: PropTypes.bool,\n\n /** Called when the checkbox or label is pressed */\n onInputChange: PropTypes.func.isRequired,\n\n /** Container styles */\n style: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.object), PropTypes.object]),\n\n /** Text that appears next to check box */\n label: requiredPropsCheck,\n\n /** Component to display for label */\n LabelComponent: requiredPropsCheck,\n\n /** Error text to display */\n errorText: PropTypes.string,\n\n /** Value for checkbox. This prop is intended to be set by Form.js only */\n value: PropTypes.bool,\n\n /** The default value for the checkbox */\n defaultValue: PropTypes.bool,\n\n /** React ref being forwarded to the Checkbox input */\n forwardedRef: PropTypes.func,\n\n /** The ID used to uniquely identify the input in a Form */\n /* eslint-disable-next-line react/no-unused-prop-types */\n inputID: PropTypes.string,\n\n /** Saves a draft of the input value when used in a form */\n /* eslint-disable-next-line react/no-unused-prop-types */\n shouldSaveDraft: PropTypes.bool,\n};\n\nconst defaultProps = {\n inputID: undefined,\n style: [],\n label: undefined,\n LabelComponent: undefined,\n errorText: '',\n shouldSaveDraft: false,\n isChecked: false,\n value: false,\n defaultValue: false,\n forwardedRef: () => {},\n};\n\nclass CheckboxWithLabel extends React.Component {\n constructor(props) {\n super(props);\n\n this.isChecked = props.value || props.defaultValue || props.isChecked;\n this.LabelComponent = props.LabelComponent;\n\n this.toggleCheckbox = this.toggleCheckbox.bind(this);\n }\n\n toggleCheckbox() {\n this.props.onInputChange(!this.isChecked);\n this.isChecked = !this.isChecked;\n }\n\n render() {\n return (\n \n \n \n \n {this.props.label && (\n \n {this.props.label}\n \n )}\n {this.LabelComponent && ()}\n \n \n \n \n );\n }\n}\n\nCheckboxWithLabel.propTypes = propTypes;\nCheckboxWithLabel.defaultProps = defaultProps;\n\nexport default React.forwardRef((props, ref) => (\n // eslint-disable-next-line react/jsx-props-no-spreading\n \n));\n","import _ from 'underscore';\nimport React, {forwardRef} from 'react';\nimport PropTypes from 'prop-types';\nimport Picker from './Picker';\nimport withLocalize, {withLocalizePropTypes} from './withLocalize';\n\nconst propTypes = {\n /** The label for the field */\n label: PropTypes.string,\n\n /** A callback method that is called when the value changes and it receives the selected value as an argument. */\n onInputChange: PropTypes.func.isRequired,\n\n /** The value that needs to be selected */\n value: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n\n /** The ID used to uniquely identify the input in a Form */\n inputID: PropTypes.string,\n\n /** Saves a draft of the input value when used in a form */\n shouldSaveDraft: PropTypes.bool,\n\n /** Callback that is called when the text input is blurred */\n onBlur: PropTypes.func,\n\n /** Error text to display */\n errorText: PropTypes.string,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n label: '',\n value: undefined,\n errorText: '',\n shouldSaveDraft: false,\n inputID: undefined,\n onBlur: () => {},\n};\n\nconst StatePicker = forwardRef((props, ref) => {\n const STATES = _.chain(props.translate('allStates'))\n .sortBy(state => state.stateName.toLowerCase())\n .map(state => ({value: state.stateISO, label: state.stateName}))\n .value();\n\n return (\n \n );\n});\n\nStatePicker.propTypes = propTypes;\nStatePicker.defaultProps = defaultProps;\nStatePicker.displayName = 'StatePicker';\n\nexport default withLocalize(StatePicker);\n","import _ from 'underscore';\nimport React, {useState} from 'react';\nimport PropTypes from 'prop-types';\nimport {LogBox, ScrollView, View} from 'react-native';\nimport {GooglePlacesAutocomplete} from 'react-native-google-places-autocomplete';\nimport lodashGet from 'lodash/get';\nimport withLocalize, {withLocalizePropTypes} from './withLocalize';\nimport styles from '../styles/styles';\nimport themeColors from '../styles/themes/default';\nimport TextInput from './TextInput';\nimport * as ApiUtils from '../libs/ApiUtils';\nimport * as GooglePlacesUtils from '../libs/GooglePlacesUtils';\nimport CONST from '../CONST';\nimport * as StyleUtils from '../styles/StyleUtils';\n\n// The error that's being thrown below will be ignored until we fork the\n// react-native-google-places-autocomplete repo and replace the\n// VirtualizedList component with a VirtualizedList-backed instead\nLogBox.ignoreLogs(['VirtualizedLists should never be nested']);\n\nconst propTypes = {\n /** The ID used to uniquely identify the input in a Form */\n inputID: PropTypes.string,\n\n /** Saves a draft of the input value when used in a form */\n shouldSaveDraft: PropTypes.bool,\n\n /** Callback that is called when the text input is blurred */\n onBlur: PropTypes.func,\n\n /** Error text to display */\n errorText: PropTypes.string,\n\n /** Hint text to display */\n hint: PropTypes.string,\n\n /** The label to display for the field */\n label: PropTypes.string.isRequired,\n\n /** The value to set the field to initially */\n value: PropTypes.string,\n\n /** The value to set the field to initially */\n defaultValue: PropTypes.string,\n\n /** A callback function when the value of this field has changed */\n onInputChange: PropTypes.func.isRequired,\n\n /** Customize the TextInput container */\n // eslint-disable-next-line react/forbid-prop-types\n containerStyles: PropTypes.arrayOf(PropTypes.object),\n\n /** Should address search be limited to results in the USA */\n isLimitedToUSA: PropTypes.bool,\n\n /** A map of inputID key names */\n renamedInputKeys: PropTypes.shape({\n street: PropTypes.string,\n city: PropTypes.string,\n state: PropTypes.string,\n zipCode: PropTypes.string,\n }),\n\n /** Maximum number of characters allowed in search input */\n maxInputLength: PropTypes.number,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n inputID: undefined,\n shouldSaveDraft: false,\n onBlur: () => {},\n errorText: '',\n hint: '',\n value: undefined,\n defaultValue: undefined,\n containerStyles: [],\n isLimitedToUSA: true,\n renamedInputKeys: {\n street: 'addressStreet',\n city: 'addressCity',\n state: 'addressState',\n zipCode: 'addressZipCode',\n },\n maxInputLength: undefined,\n};\n\n// Do not convert to class component! It's been tried before and presents more challenges than it's worth.\n// Relevant thread: https://expensify.slack.com/archives/C03TQ48KC/p1634088400387400\n// Reference: https://github.com/FaridSafi/react-native-google-places-autocomplete/issues/609#issuecomment-886133839\nconst AddressSearch = (props) => {\n const [displayListViewBorder, setDisplayListViewBorder] = useState(false);\n const query = {language: props.preferredLocale, types: 'address'};\n if (props.isLimitedToUSA) {\n query.components = 'country:us';\n }\n\n const saveLocationDetails = (autocompleteData, details) => {\n const addressComponents = details.address_components;\n if (!addressComponents) {\n return;\n }\n\n // Gather the values from the Google details\n const {\n street_number: streetNumber,\n route: streetName,\n subpremise,\n locality,\n sublocality,\n postal_town: postalTown,\n postal_code: zipCode,\n administrative_area_level_1: state,\n country,\n } = GooglePlacesUtils.getAddressComponents(addressComponents, {\n street_number: 'long_name',\n route: 'long_name',\n subpremise: 'long_name',\n locality: 'long_name',\n sublocality: 'long_name',\n postal_town: 'long_name',\n postal_code: 'long_name',\n administrative_area_level_1: 'short_name',\n country: 'short_name',\n });\n\n // The state's iso code (short_name) is needed for the StatePicker component but we also\n // need the state's full name (long_name) when we render the state in a TextInput.\n const {\n administrative_area_level_1: longStateName,\n } = GooglePlacesUtils.getAddressComponents(addressComponents, {\n administrative_area_level_1: 'long_name',\n });\n\n // Make sure that the order of keys remains such that the country is always set above the state.\n // Refer to https://github.com/Expensify/App/issues/15633 for more information.\n const {\n state: stateAutoCompleteFallback = '',\n city: cityAutocompleteFallback = '',\n } = GooglePlacesUtils.getPlaceAutocompleteTerms(autocompleteData.terms);\n\n const values = {\n street: `${streetNumber} ${streetName}`.trim(),\n\n // Autocomplete returns any additional valid address fragments (e.g. Apt #) as subpremise.\n street2: subpremise,\n\n // When locality is not returned, many countries return the city as postalTown (e.g. 5 New Street\n // Square, London), otherwise as sublocality (e.g. 384 Court Street Brooklyn). If postalTown is\n // returned, the sublocality will be a city subdivision so shouldn't take precedence (e.g.\n // Salagatan, Upssala, Sweden).\n city: locality || postalTown || sublocality || cityAutocompleteFallback,\n zipCode,\n country: '',\n state: state || stateAutoCompleteFallback,\n };\n\n // If the address is not in the US, use the full length state name since we're displaying the address's\n // state / province in a TextInput instead of in a picker.\n if (country !== CONST.COUNTRY.US) {\n values.state = longStateName;\n }\n\n // Not all pages define the Address Line 2 field, so in that case we append any additional address details\n // (e.g. Apt #) to Address Line 1\n if (subpremise && typeof props.renamedInputKeys.street2 === 'undefined') {\n values.street += `, ${subpremise}`;\n }\n\n const isValidCountryCode = lodashGet(CONST.ALL_COUNTRIES, country);\n if (isValidCountryCode) {\n values.country = country;\n }\n\n if (props.inputID) {\n _.each(values, (value, key) => {\n const inputKey = lodashGet(props.renamedInputKeys, key, key);\n props.onInputChange(value, inputKey);\n });\n } else {\n props.onInputChange(values);\n }\n };\n\n return (\n\n /*\n * The GooglePlacesAutocomplete component uses a VirtualizedList internally,\n * and VirtualizedLists cannot be directly nested within other VirtualizedLists of the same orientation.\n * To work around this, we wrap the GooglePlacesAutocomplete component with a horizontal ScrollView\n * that has scrolling disabled and would otherwise not be needed\n */\n \n \n {\n saveLocationDetails(data, details);\n\n // After we select an option, we set displayListViewBorder to false to prevent UI flickering\n setDisplayListViewBorder(false);\n }}\n query={query}\n requestUrl={{\n useOnPlatform: 'all',\n url: ApiUtils.getCommandURL({command: 'Proxy_GooglePlaces&proxyUrl='}),\n }}\n textInputProps={{\n InputComp: TextInput,\n ref: (node) => {\n if (!props.innerRef) {\n return;\n }\n\n if (_.isFunction(props.innerRef)) {\n props.innerRef(node);\n return;\n }\n\n // eslint-disable-next-line no-param-reassign\n props.innerRef.current = node;\n },\n label: props.label,\n containerStyles: props.containerStyles,\n errorText: props.errorText,\n hint: displayListViewBorder ? undefined : props.hint,\n value: props.value,\n defaultValue: props.defaultValue,\n inputID: props.inputID,\n shouldSaveDraft: props.shouldSaveDraft,\n onBlur: props.onBlur,\n autoComplete: 'off',\n onInputChange: (text) => {\n if (props.inputID) {\n props.onInputChange(text);\n } else {\n props.onInputChange({street: text});\n }\n\n // If the text is empty, we set displayListViewBorder to false to prevent UI flickering\n if (_.isEmpty(text)) {\n setDisplayListViewBorder(false);\n }\n },\n maxLength: props.maxInputLength,\n }}\n styles={{\n textInputContainer: [styles.flexColumn],\n listView: [\n StyleUtils.getGoolgeListViewStyle(displayListViewBorder),\n styles.overflowAuto,\n styles.borderLeft,\n styles.borderRight,\n ],\n row: [\n styles.pv4,\n styles.ph3,\n styles.overflowAuto,\n ],\n description: [styles.googleSearchText],\n separator: [styles.googleSearchSeparator],\n }}\n listHoverColor={themeColors.border}\n listUnderlayColor={themeColors.buttonPressedBG}\n onLayout={(event) => {\n // We use the height of the element to determine if we should hide the border of the listView dropdown\n // to prevent a lingering border when there are no address suggestions.\n // The height of the empty element is 2px (1px height for each top and bottom borders)\n setDisplayListViewBorder(event.nativeEvent.layout.height > 2);\n }}\n />\n \n \n );\n};\n\nAddressSearch.propTypes = propTypes;\nAddressSearch.defaultProps = defaultProps;\nAddressSearch.displayName = 'AddressSearch';\n\nexport default withLocalize(React.forwardRef((props, ref) => (\n // eslint-disable-next-line react/jsx-props-no-spreading\n \n)));\n","import _ from 'underscore';\n\n/**\n * Finds an address component by type, and returns the value associated to key. Each address component object\n * inside the addressComponents array has the following structure:\n * [{\n * long_name: \"New York\",\n * short_name: \"New York\",\n * types: [ \"locality\", \"political\" ]\n * }]\n *\n * @param {Array} addressComponents\n * @param {Object} fieldsToExtract – has shape: {addressType: 'keyToUse'}\n * @returns {Object}\n */\nfunction getAddressComponents(addressComponents, fieldsToExtract) {\n const result = _.mapObject(fieldsToExtract, () => '');\n _.each(addressComponents, (addressComponent) => {\n _.each(addressComponent.types, (addressType) => {\n if (!_.has(fieldsToExtract, addressType) || !_.isEmpty(result[addressType])) {\n return;\n }\n const value = addressComponent[fieldsToExtract[addressType]] ? addressComponent[fieldsToExtract[addressType]] : '';\n result[addressType] = value;\n });\n });\n return result;\n}\n\n/**\n * Finds an address term by type, and returns the value associated to key. Note that each term in the address must\n * conform to the following ORDER: \n *\n * @param {Array} addressTerms\n * @returns {Object}\n */\nfunction getPlaceAutocompleteTerms(addressTerms) {\n const fieldsToExtract = ['country', 'state', 'city', 'street'];\n const result = {};\n _.each(fieldsToExtract, (fieldToExtract, index) => {\n const fieldTermIndex = addressTerms.length - (index + 1);\n result[fieldToExtract] = fieldTermIndex >= 0 ? addressTerms[fieldTermIndex].value : '';\n });\n return result;\n}\n\nexport {\n // eslint-disable-next-line import/prefer-default-export\n getAddressComponents,\n getPlaceAutocompleteTerms,\n};\n","/* eslint-disable react-native/no-inline-styles */\nimport debounce from 'lodash.debounce';\nimport PropTypes from 'prop-types';\nimport Qs from 'qs';\nimport React, {\n forwardRef,\n useMemo,\n useEffect,\n useImperativeHandle,\n useRef,\n useState,\n} from 'react';\nimport {\n ActivityIndicator,\n FlatList,\n Image,\n Keyboard,\n Platform,\n Pressable,\n ScrollView,\n Text,\n TextInput,\n View,\n} from 'react-native';\n\nconst defaultStyles = {\n container: {\n flex: 1,\n },\n textInputContainer: {\n flexDirection: 'row',\n },\n textInput: {\n backgroundColor: '#FFFFFF',\n height: 44,\n borderRadius: 5,\n paddingVertical: 5,\n paddingHorizontal: 10,\n fontSize: 15,\n flex: 1,\n marginBottom: 5,\n },\n listView: {},\n row: {\n backgroundColor: '#FFFFFF',\n padding: 13,\n minHeight: 44,\n flexDirection: 'row',\n },\n loader: {\n flexDirection: 'row',\n justifyContent: 'flex-end',\n height: 20,\n },\n description: {},\n separator: {\n height: 0.5,\n backgroundColor: '#c8c7cc',\n },\n poweredContainer: {\n justifyContent: 'flex-end',\n alignItems: 'center',\n borderBottomRightRadius: 5,\n borderBottomLeftRadius: 5,\n borderColor: '#c8c7cc',\n borderTopWidth: 0.5,\n },\n powered: {},\n};\n\nexport const GooglePlacesAutocomplete = forwardRef((props, ref) => {\n let _results = [];\n let _requests = [];\n\n const hasNavigator = () => {\n if (navigator?.geolocation) {\n return true;\n } else {\n console.warn(\n 'If you are using React Native v0.60.0+ you must follow these instructions to enable currentLocation: https://git.io/Jf4AR',\n );\n return false;\n }\n };\n\n const buildRowsFromResults = (results) => {\n let res = [];\n\n if (results.length === 0 || props.predefinedPlacesAlwaysVisible === true) {\n res = [\n ...props.predefinedPlaces.filter((place) => place?.description.length),\n ];\n\n if (props.currentLocation === true && hasNavigator()) {\n res.unshift({\n description: props.currentLocationLabel,\n isCurrentLocation: true,\n });\n }\n }\n\n res = res.map((place) => ({\n ...place,\n isPredefinedPlace: true,\n }));\n\n return [...res, ...results];\n };\n\n const getRequestUrl = (requestUrl) => {\n if (requestUrl) {\n if (requestUrl.useOnPlatform === 'all') {\n return requestUrl.url;\n }\n if (requestUrl.useOnPlatform === 'web') {\n return Platform.select({\n web: requestUrl.url,\n default: 'https://maps.googleapis.com/maps/api',\n });\n }\n } else {\n return 'https://maps.googleapis.com/maps/api';\n }\n };\n\n const getRequestHeaders = (requestUrl) => {\n return requestUrl?.headers || {};\n };\n\n const setRequestHeaders = (request, headers) => {\n Object.keys(headers).map((headerKey) =>\n request.setRequestHeader(headerKey, headers[headerKey]),\n );\n };\n\n const [stateText, setStateText] = useState('');\n const [dataSource, setDataSource] = useState(buildRowsFromResults([]));\n const [listViewDisplayed, setListViewDisplayed] = useState(\n props.listViewDisplayed === 'auto' ? false : props.listViewDisplayed,\n );\n const [url] = useState(getRequestUrl(props.requestUrl));\n\n const inputRef = useRef();\n const containerRef = useRef();\n\n useEffect(() => {\n if (Platform.OS !== 'web' || !listViewDisplayed) {\n return;\n }\n\n // This will close search results list when user clicks outside the container\n const outsideClickHandler = (e) => {\n if (containerRef.current?.contains(e.target)) {\n return;\n }\n setListViewDisplayed(false);\n };\n\n document.addEventListener('mousedown', outsideClickHandler);\n\n return () => document.removeEventListener('mousedown', outsideClickHandler);\n }, [listViewDisplayed]);\n\n useEffect(() => {\n // This will load the default value's search results after the view has\n // been rendered\n _handleChangeText(stateText);\n return () => {\n _abortRequests();\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n useEffect(() => {\n // Update dataSource if props.predefinedPlaces changed\n setDataSource(buildRowsFromResults([]));\n }, [props.predefinedPlaces]);\n\n useImperativeHandle(ref, () => ({\n setAddressText: (address) => {\n setStateText(address);\n },\n getAddressText: () => stateText,\n blur: () => inputRef.current.blur(),\n focus: () => inputRef.current.focus(),\n isFocused: () => inputRef.current.isFocused(),\n clear: () => inputRef.current.clear(),\n getCurrentLocation,\n }));\n\n const requestShouldUseWithCredentials = () =>\n url === 'https://maps.googleapis.com/maps/api';\n\n const _abortRequests = () => {\n _requests.map((i) => i.abort());\n _requests = [];\n };\n\n const supportedPlatform = () => {\n if (Platform.OS === 'web' && !props.requestUrl) {\n console.warn(\n 'This library cannot be used for the web unless you specify the requestUrl prop. See https://git.io/JflFv for more for details.',\n );\n return false;\n } else {\n return true;\n }\n };\n\n const getCurrentLocation = () => {\n let options = {\n enableHighAccuracy: false,\n timeout: 20000,\n maximumAge: 1000,\n };\n\n if (props.enableHighAccuracyLocation && Platform.OS === 'android') {\n options = {\n enableHighAccuracy: true,\n timeout: 20000,\n };\n }\n const getCurrentPosition =\n navigator.geolocation.getCurrentPosition ||\n navigator.geolocation.default.getCurrentPosition;\n\n getCurrentPosition &&\n getCurrentPosition(\n (position) => {\n if (props.nearbyPlacesAPI === 'None') {\n let currentLocation = {\n description: props.currentLocationLabel,\n geometry: {\n location: {\n lat: position.coords.latitude,\n lng: position.coords.longitude,\n },\n },\n };\n\n _disableRowLoaders();\n props.onPress(currentLocation, currentLocation);\n } else {\n _requestNearby(position.coords.latitude, position.coords.longitude);\n }\n },\n (error) => {\n _disableRowLoaders();\n console.error(error.message);\n },\n options,\n );\n };\n\n const _onPress = (rowData) => {\n if (rowData.isPredefinedPlace !== true && props.fetchDetails === true) {\n if (rowData.isLoading === true) {\n // already requesting\n return;\n }\n\n Keyboard.dismiss();\n\n _abortRequests();\n\n // display loader\n _enableRowLoader(rowData);\n\n // fetch details\n const request = new XMLHttpRequest();\n _requests.push(request);\n request.timeout = props.timeout;\n request.ontimeout = props.onTimeout;\n request.onreadystatechange = () => {\n if (request.readyState !== 4) return;\n\n if (request.status === 200) {\n const responseJSON = JSON.parse(request.responseText);\n\n if (responseJSON.status === 'OK') {\n // if (_isMounted === true) {\n const details = responseJSON.result;\n _disableRowLoaders();\n _onBlur();\n\n setStateText(_renderDescription(rowData));\n\n delete rowData.isLoading;\n props.onPress(rowData, details);\n // }\n } else {\n _disableRowLoaders();\n\n if (props.autoFillOnNotFound) {\n setStateText(_renderDescription(rowData));\n delete rowData.isLoading;\n }\n\n if (!props.onNotFound) {\n console.warn(\n 'google places autocomplete: ' + responseJSON.status,\n );\n } else {\n props.onNotFound(responseJSON);\n }\n }\n } else {\n _disableRowLoaders();\n\n if (!props.onFail) {\n console.warn(\n 'google places autocomplete: request could not be completed or has been aborted',\n );\n } else {\n props.onFail('request could not be completed or has been aborted');\n }\n }\n };\n\n request.open(\n 'GET',\n `${url}/place/details/json?` +\n Qs.stringify({\n key: props.query.key,\n placeid: rowData.place_id,\n language: props.query.language,\n ...props.GooglePlacesDetailsQuery,\n }),\n );\n\n request.withCredentials = requestShouldUseWithCredentials();\n setRequestHeaders(request, getRequestHeaders(props.requestUrl));\n\n request.send();\n } else if (rowData.isCurrentLocation === true) {\n // display loader\n _enableRowLoader(rowData);\n\n setStateText(_renderDescription(rowData));\n\n delete rowData.isLoading;\n getCurrentLocation();\n } else {\n setStateText(_renderDescription(rowData));\n\n _onBlur();\n delete rowData.isLoading;\n let predefinedPlace = _getPredefinedPlace(rowData);\n\n // sending predefinedPlace as details for predefined places\n props.onPress(predefinedPlace, predefinedPlace);\n }\n };\n\n const _enableRowLoader = (rowData) => {\n let rows = buildRowsFromResults(_results);\n for (let i = 0; i < rows.length; i++) {\n if (\n rows[i].place_id === rowData.place_id ||\n (rows[i].isCurrentLocation === true &&\n rowData.isCurrentLocation === true)\n ) {\n rows[i].isLoading = true;\n setDataSource(rows);\n break;\n }\n }\n };\n\n const _disableRowLoaders = () => {\n // if (_isMounted === true) {\n for (let i = 0; i < _results.length; i++) {\n if (_results[i].isLoading === true) {\n _results[i].isLoading = false;\n }\n }\n\n setDataSource(buildRowsFromResults(_results));\n // }\n };\n\n const _getPredefinedPlace = (rowData) => {\n if (rowData.isPredefinedPlace !== true) {\n return rowData;\n }\n\n for (let i = 0; i < props.predefinedPlaces.length; i++) {\n if (props.predefinedPlaces[i].description === rowData.description) {\n return props.predefinedPlaces[i];\n }\n }\n\n return rowData;\n };\n\n const _filterResultsByTypes = (unfilteredResults, types) => {\n if (types.length === 0) return unfilteredResults;\n\n const results = [];\n for (let i = 0; i < unfilteredResults.length; i++) {\n let found = false;\n\n for (let j = 0; j < types.length; j++) {\n if (unfilteredResults[i].types.indexOf(types[j]) !== -1) {\n found = true;\n break;\n }\n }\n\n if (found === true) {\n results.push(unfilteredResults[i]);\n }\n }\n return results;\n };\n\n const _requestNearby = (latitude, longitude) => {\n _abortRequests();\n\n if (\n latitude !== undefined &&\n longitude !== undefined &&\n latitude !== null &&\n longitude !== null\n ) {\n const request = new XMLHttpRequest();\n _requests.push(request);\n request.timeout = props.timeout;\n request.ontimeout = props.onTimeout;\n request.onreadystatechange = () => {\n if (request.readyState !== 4) {\n return;\n }\n\n if (request.status === 200) {\n const responseJSON = JSON.parse(request.responseText);\n\n _disableRowLoaders();\n\n if (typeof responseJSON.results !== 'undefined') {\n // if (_isMounted === true) {\n var results = [];\n if (props.nearbyPlacesAPI === 'GoogleReverseGeocoding') {\n results = _filterResultsByTypes(\n responseJSON.results,\n props.filterReverseGeocodingByTypes,\n );\n } else {\n results = responseJSON.results;\n }\n\n setDataSource(buildRowsFromResults(results));\n // }\n }\n if (typeof responseJSON.error_message !== 'undefined') {\n if (!props.onFail)\n console.warn(\n 'google places autocomplete: ' + responseJSON.error_message,\n );\n else {\n props.onFail(responseJSON.error_message);\n }\n }\n } else {\n // console.warn(\"google places autocomplete: request could not be completed or has been aborted\");\n }\n };\n\n let requestUrl = '';\n if (props.nearbyPlacesAPI === 'GoogleReverseGeocoding') {\n // your key must be allowed to use Google Maps Geocoding API\n requestUrl =\n `${url}/geocode/json?` +\n Qs.stringify({\n latlng: latitude + ',' + longitude,\n key: props.query.key,\n ...props.GoogleReverseGeocodingQuery,\n });\n } else {\n requestUrl =\n `${url}/place/nearbysearch/json?` +\n Qs.stringify({\n location: latitude + ',' + longitude,\n key: props.query.key,\n ...props.GooglePlacesSearchQuery,\n });\n }\n\n request.open('GET', requestUrl);\n\n request.withCredentials = requestShouldUseWithCredentials();\n setRequestHeaders(request, getRequestHeaders(props.requestUrl));\n\n request.send();\n } else {\n _results = [];\n setDataSource(buildRowsFromResults([]));\n }\n };\n\n const _request = (text) => {\n _abortRequests();\n if (supportedPlatform() && text && text.length >= props.minLength) {\n const request = new XMLHttpRequest();\n _requests.push(request);\n request.timeout = props.timeout;\n request.ontimeout = props.onTimeout;\n request.onreadystatechange = () => {\n if (request.readyState !== 4) {\n return;\n }\n\n if (request.status === 200) {\n const responseJSON = JSON.parse(request.responseText);\n if (typeof responseJSON.predictions !== 'undefined') {\n // if (_isMounted === true) {\n const results =\n props.nearbyPlacesAPI === 'GoogleReverseGeocoding'\n ? _filterResultsByTypes(\n responseJSON.predictions,\n props.filterReverseGeocodingByTypes,\n )\n : responseJSON.predictions;\n\n _results = results;\n setDataSource(buildRowsFromResults(results));\n // }\n }\n if (typeof responseJSON.error_message !== 'undefined') {\n if (!props.onFail)\n console.warn(\n 'google places autocomplete: ' + responseJSON.error_message,\n );\n else {\n props.onFail(responseJSON.error_message);\n }\n }\n } else {\n // console.warn(\"google places autocomplete: request could not be completed or has been aborted\");\n }\n };\n\n if (props.preProcess) {\n setStateText(props.preProcess(text));\n }\n\n request.open(\n 'GET',\n `${url}/place/autocomplete/json?input=` +\n encodeURIComponent(text) +\n '&' +\n Qs.stringify(props.query),\n );\n\n request.withCredentials = requestShouldUseWithCredentials();\n setRequestHeaders(request, getRequestHeaders(props.requestUrl));\n\n request.send();\n } else {\n _results = [];\n setDataSource(buildRowsFromResults([]));\n }\n };\n\n // eslint-disable-next-line react-hooks/exhaustive-deps\n const debounceData = useMemo(() => debounce(_request, props.debounce), [\n props.query,\n ]);\n\n const _onChangeText = (text) => {\n setStateText(text);\n debounceData(text);\n };\n\n const _handleChangeText = (text) => {\n _onChangeText(text);\n\n const onChangeText = props?.textInputProps?.onChangeText;\n\n if (onChangeText) {\n onChangeText(text);\n }\n };\n\n const _getRowLoader = () => {\n return ;\n };\n\n const _renderRowData = (rowData, index) => {\n if (props.renderRow) {\n return props.renderRow(rowData, index);\n }\n\n return (\n \n {_renderDescription(rowData)}\n \n );\n };\n\n const _renderDescription = (rowData) => {\n if (props.renderDescription) {\n return props.renderDescription(rowData);\n }\n\n return rowData.description || rowData.formatted_address || rowData.name;\n };\n\n const _renderLoader = (rowData) => {\n if (rowData.isLoading === true) {\n return (\n \n {_getRowLoader()}\n \n );\n }\n\n return null;\n };\n\n const _renderRow = (rowData = {}, index) => {\n return (\n \n [\n props.isRowScrollable ? { minWidth: '100%' } : { width: '100%' },\n {\n backgroundColor: pressed\n ? props.listUnderlayColor\n : hovered\n ? props.listHoverColor\n : undefined,\n },\n ]}\n onPress={() => _onPress(rowData)}\n onBlur={_onBlur}\n >\n \n {_renderLoader(rowData)}\n {_renderRowData(rowData, index)}\n \n \n \n );\n };\n\n const _renderSeparator = (sectionID, rowID) => {\n if (rowID === dataSource.length - 1) {\n return null;\n }\n\n return (\n \n );\n };\n\n const isNewFocusInAutocompleteResultList = ({\n relatedTarget,\n currentTarget,\n }) => {\n if (!relatedTarget) return false;\n\n var node = relatedTarget.parentNode;\n\n while (node) {\n if (node.id === 'result-list-id') return true;\n node = node.parentNode;\n }\n\n return false;\n };\n\n const _onBlur = (e) => {\n if (e && isNewFocusInAutocompleteResultList(e)) return;\n\n if (!props.keepResultsAfterBlur) {\n setListViewDisplayed(false);\n }\n inputRef?.current?.blur();\n };\n\n const _onFocus = () => setListViewDisplayed(true);\n\n const _renderPoweredLogo = () => {\n if (!_shouldShowPoweredLogo()) {\n return null;\n }\n\n return (\n \n \n \n );\n };\n\n const _shouldShowPoweredLogo = () => {\n if (!props.enablePoweredByContainer || dataSource.length === 0) {\n return false;\n }\n\n for (let i = 0; i < dataSource.length; i++) {\n let row = dataSource[i];\n\n if (\n !row.hasOwnProperty('isCurrentLocation') &&\n !row.hasOwnProperty('isPredefinedPlace')\n ) {\n return true;\n }\n }\n\n return false;\n };\n\n const _renderLeftButton = () => {\n if (props.renderLeftButton) {\n return props.renderLeftButton();\n }\n };\n\n const _renderRightButton = () => {\n if (props.renderRightButton) {\n return props.renderRightButton();\n }\n };\n\n const _getFlatList = () => {\n const keyGenerator = () => Math.random().toString(36).substr(2, 10);\n\n if (\n supportedPlatform() &&\n (stateText !== '' ||\n props.predefinedPlaces.length > 0 ||\n props.currentLocation === true) &&\n listViewDisplayed === true\n ) {\n return (\n _renderRow(item, index)}\n ListEmptyComponent={\n stateText.length > props.minLength && props.listEmptyComponent\n }\n ListHeaderComponent={\n props.renderHeaderComponent &&\n props.renderHeaderComponent(stateText)\n }\n ListFooterComponent={_renderPoweredLogo}\n {...props}\n />\n );\n }\n\n return null;\n };\n\n let {\n onFocus,\n onBlur,\n onChangeText, // destructuring here stops this being set after onChangeText={_handleChangeText}\n clearButtonMode,\n InputComp,\n ...userProps\n } = props.textInputProps;\n const TextInputComp = InputComp || TextInput;\n return (\n \n {!props.textInputHide && (\n \n {_renderLeftButton()}\n {\n _onFocus();\n onFocus();\n }\n : _onFocus\n }\n onBlur={\n onBlur\n ? (e) => {\n _onBlur(e);\n onBlur();\n }\n : _onBlur\n }\n clearButtonMode={clearButtonMode || 'while-editing'}\n onChangeText={_handleChangeText}\n {...userProps}\n />\n {_renderRightButton()}\n \n )}\n {_getFlatList()}\n {props.children}\n \n );\n});\n\nGooglePlacesAutocomplete.propTypes = {\n autoFillOnNotFound: PropTypes.bool,\n currentLocation: PropTypes.bool,\n currentLocationLabel: PropTypes.string,\n debounce: PropTypes.number,\n disableScroll: PropTypes.bool,\n enableHighAccuracyLocation: PropTypes.bool,\n enablePoweredByContainer: PropTypes.bool,\n fetchDetails: PropTypes.bool,\n filterReverseGeocodingByTypes: PropTypes.array,\n GooglePlacesDetailsQuery: PropTypes.object,\n GooglePlacesSearchQuery: PropTypes.object,\n GoogleReverseGeocodingQuery: PropTypes.object,\n isRowScrollable: PropTypes.bool,\n keyboardShouldPersistTaps: PropTypes.oneOf(['never', 'always', 'handled']),\n listEmptyComponent: PropTypes.func,\n listHoverColor: PropTypes.string,\n listUnderlayColor: PropTypes.string,\n // Must write it this way: https://stackoverflow.com/a/54290946/7180620\n listViewDisplayed: PropTypes.oneOfType([\n PropTypes.bool,\n PropTypes.oneOf(['auto']),\n ]),\n keepResultsAfterBlur: PropTypes.bool,\n minLength: PropTypes.number,\n nearbyPlacesAPI: PropTypes.string,\n numberOfLines: PropTypes.number,\n onFail: PropTypes.func,\n onNotFound: PropTypes.func,\n onPress: PropTypes.func,\n onTimeout: PropTypes.func,\n placeholder: PropTypes.string,\n predefinedPlaces: PropTypes.array,\n predefinedPlacesAlwaysVisible: PropTypes.bool,\n preProcess: PropTypes.func,\n query: PropTypes.object,\n renderDescription: PropTypes.func,\n renderHeaderComponent: PropTypes.func,\n renderLeftButton: PropTypes.func,\n renderRightButton: PropTypes.func,\n renderRow: PropTypes.func,\n requestUrl: PropTypes.shape({\n url: PropTypes.string,\n useOnPlatform: PropTypes.oneOf(['web', 'all']),\n headers: PropTypes.objectOf(PropTypes.string),\n }),\n styles: PropTypes.object,\n suppressDefaultStyles: PropTypes.bool,\n textInputHide: PropTypes.bool,\n textInputProps: PropTypes.object,\n timeout: PropTypes.number,\n};\n\nGooglePlacesAutocomplete.defaultProps = {\n autoFillOnNotFound: false,\n currentLocation: false,\n currentLocationLabel: 'Current location',\n debounce: 0,\n disableScroll: false,\n enableHighAccuracyLocation: true,\n enablePoweredByContainer: true,\n fetchDetails: false,\n filterReverseGeocodingByTypes: [],\n GooglePlacesDetailsQuery: {},\n GooglePlacesSearchQuery: {\n rankby: 'distance',\n type: 'restaurant',\n },\n GoogleReverseGeocodingQuery: {},\n isRowScrollable: true,\n keyboardShouldPersistTaps: 'always',\n listHoverColor: '#ececec',\n listUnderlayColor: '#c8c7cc',\n listViewDisplayed: 'auto',\n keepResultsAfterBlur: false,\n minLength: 0,\n nearbyPlacesAPI: 'GooglePlacesSearch',\n numberOfLines: 1,\n onFail: () => {},\n onNotFound: () => {},\n onPress: () => {},\n onTimeout: () => console.warn('google places autocomplete: request timeout'),\n placeholder: '',\n predefinedPlaces: [],\n predefinedPlacesAlwaysVisible: false,\n query: {\n key: 'missing api key',\n language: 'en',\n types: 'geocode',\n },\n styles: {},\n suppressDefaultStyles: false,\n textInputHide: false,\n textInputProps: {},\n timeout: 20000,\n};\n\nexport default { GooglePlacesAutocomplete };\n","/**\n * lodash (Custom Build) \n * Build: `lodash modularize exports=\"npm\" -o ./`\n * Copyright jQuery Foundation and other contributors \n * Released under MIT license \n * Based on Underscore.js 1.8.3 \n * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n */\n\n/** Used as the `TypeError` message for \"Functions\" methods. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/** Used as references for various `Number` constants. */\nvar NAN = 0 / 0;\n\n/** `Object#toString` result references. */\nvar symbolTag = '[object Symbol]';\n\n/** Used to match leading and trailing whitespace. */\nvar reTrim = /^\\s+|\\s+$/g;\n\n/** Used to detect bad signed hexadecimal string values. */\nvar reIsBadHex = /^[-+]0x[0-9a-f]+$/i;\n\n/** Used to detect binary string values. */\nvar reIsBinary = /^0b[01]+$/i;\n\n/** Used to detect octal string values. */\nvar reIsOctal = /^0o[0-7]+$/i;\n\n/** Built-in method references without a dependency on `root`. */\nvar freeParseInt = parseInt;\n\n/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objectToString = objectProto.toString;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max,\n nativeMin = Math.min;\n\n/**\n * Gets the timestamp of the number of milliseconds that have elapsed since\n * the Unix epoch (1 January 1970 00:00:00 UTC).\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Date\n * @returns {number} Returns the timestamp.\n * @example\n *\n * _.defer(function(stamp) {\n * console.log(_.now() - stamp);\n * }, _.now());\n * // => Logs the number of milliseconds it took for the deferred invocation.\n */\nvar now = function() {\n return root.Date.now();\n};\n\n/**\n * Creates a debounced function that delays invoking `func` until after `wait`\n * milliseconds have elapsed since the last time the debounced function was\n * invoked. The debounced function comes with a `cancel` method to cancel\n * delayed `func` invocations and a `flush` method to immediately invoke them.\n * Provide `options` to indicate whether `func` should be invoked on the\n * leading and/or trailing edge of the `wait` timeout. The `func` is invoked\n * with the last arguments provided to the debounced function. Subsequent\n * calls to the debounced function return the result of the last `func`\n * invocation.\n *\n * **Note:** If `leading` and `trailing` options are `true`, `func` is\n * invoked on the trailing edge of the timeout only if the debounced function\n * is invoked more than once during the `wait` timeout.\n *\n * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred\n * until to the next tick, similar to `setTimeout` with a timeout of `0`.\n *\n * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)\n * for details over the differences between `_.debounce` and `_.throttle`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to debounce.\n * @param {number} [wait=0] The number of milliseconds to delay.\n * @param {Object} [options={}] The options object.\n * @param {boolean} [options.leading=false]\n * Specify invoking on the leading edge of the timeout.\n * @param {number} [options.maxWait]\n * The maximum time `func` is allowed to be delayed before it's invoked.\n * @param {boolean} [options.trailing=true]\n * Specify invoking on the trailing edge of the timeout.\n * @returns {Function} Returns the new debounced function.\n * @example\n *\n * // Avoid costly calculations while the window size is in flux.\n * jQuery(window).on('resize', _.debounce(calculateLayout, 150));\n *\n * // Invoke `sendMail` when clicked, debouncing subsequent calls.\n * jQuery(element).on('click', _.debounce(sendMail, 300, {\n * 'leading': true,\n * 'trailing': false\n * }));\n *\n * // Ensure `batchLog` is invoked once after 1 second of debounced calls.\n * var debounced = _.debounce(batchLog, 250, { 'maxWait': 1000 });\n * var source = new EventSource('/stream');\n * jQuery(source).on('message', debounced);\n *\n * // Cancel the trailing debounced invocation.\n * jQuery(window).on('popstate', debounced.cancel);\n */\nfunction debounce(func, wait, options) {\n var lastArgs,\n lastThis,\n maxWait,\n result,\n timerId,\n lastCallTime,\n lastInvokeTime = 0,\n leading = false,\n maxing = false,\n trailing = true;\n\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n wait = toNumber(wait) || 0;\n if (isObject(options)) {\n leading = !!options.leading;\n maxing = 'maxWait' in options;\n maxWait = maxing ? nativeMax(toNumber(options.maxWait) || 0, wait) : maxWait;\n trailing = 'trailing' in options ? !!options.trailing : trailing;\n }\n\n function invokeFunc(time) {\n var args = lastArgs,\n thisArg = lastThis;\n\n lastArgs = lastThis = undefined;\n lastInvokeTime = time;\n result = func.apply(thisArg, args);\n return result;\n }\n\n function leadingEdge(time) {\n // Reset any `maxWait` timer.\n lastInvokeTime = time;\n // Start the timer for the trailing edge.\n timerId = setTimeout(timerExpired, wait);\n // Invoke the leading edge.\n return leading ? invokeFunc(time) : result;\n }\n\n function remainingWait(time) {\n var timeSinceLastCall = time - lastCallTime,\n timeSinceLastInvoke = time - lastInvokeTime,\n result = wait - timeSinceLastCall;\n\n return maxing ? nativeMin(result, maxWait - timeSinceLastInvoke) : result;\n }\n\n function shouldInvoke(time) {\n var timeSinceLastCall = time - lastCallTime,\n timeSinceLastInvoke = time - lastInvokeTime;\n\n // Either this is the first call, activity has stopped and we're at the\n // trailing edge, the system time has gone backwards and we're treating\n // it as the trailing edge, or we've hit the `maxWait` limit.\n return (lastCallTime === undefined || (timeSinceLastCall >= wait) ||\n (timeSinceLastCall < 0) || (maxing && timeSinceLastInvoke >= maxWait));\n }\n\n function timerExpired() {\n var time = now();\n if (shouldInvoke(time)) {\n return trailingEdge(time);\n }\n // Restart the timer.\n timerId = setTimeout(timerExpired, remainingWait(time));\n }\n\n function trailingEdge(time) {\n timerId = undefined;\n\n // Only invoke if we have `lastArgs` which means `func` has been\n // debounced at least once.\n if (trailing && lastArgs) {\n return invokeFunc(time);\n }\n lastArgs = lastThis = undefined;\n return result;\n }\n\n function cancel() {\n if (timerId !== undefined) {\n clearTimeout(timerId);\n }\n lastInvokeTime = 0;\n lastArgs = lastCallTime = lastThis = timerId = undefined;\n }\n\n function flush() {\n return timerId === undefined ? result : trailingEdge(now());\n }\n\n function debounced() {\n var time = now(),\n isInvoking = shouldInvoke(time);\n\n lastArgs = arguments;\n lastThis = this;\n lastCallTime = time;\n\n if (isInvoking) {\n if (timerId === undefined) {\n return leadingEdge(lastCallTime);\n }\n if (maxing) {\n // Handle invocations in a tight loop.\n timerId = setTimeout(timerExpired, wait);\n return invokeFunc(lastCallTime);\n }\n }\n if (timerId === undefined) {\n timerId = setTimeout(timerExpired, wait);\n }\n return result;\n }\n debounced.cancel = cancel;\n debounced.flush = flush;\n return debounced;\n}\n\n/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n var type = typeof value;\n return !!value && (type == 'object' || type == 'function');\n}\n\n/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n return !!value && typeof value == 'object';\n}\n\n/**\n * Checks if `value` is classified as a `Symbol` primitive or object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.\n * @example\n *\n * _.isSymbol(Symbol.iterator);\n * // => true\n *\n * _.isSymbol('abc');\n * // => false\n */\nfunction isSymbol(value) {\n return typeof value == 'symbol' ||\n (isObjectLike(value) && objectToString.call(value) == symbolTag);\n}\n\n/**\n * Converts `value` to a number.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to process.\n * @returns {number} Returns the number.\n * @example\n *\n * _.toNumber(3.2);\n * // => 3.2\n *\n * _.toNumber(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toNumber(Infinity);\n * // => Infinity\n *\n * _.toNumber('3.2');\n * // => 3.2\n */\nfunction toNumber(value) {\n if (typeof value == 'number') {\n return value;\n }\n if (isSymbol(value)) {\n return NAN;\n }\n if (isObject(value)) {\n var other = typeof value.valueOf == 'function' ? value.valueOf() : value;\n value = isObject(other) ? (other + '') : other;\n }\n if (typeof value != 'string') {\n return value === 0 ? value : +value;\n }\n value = value.replace(reTrim, '');\n var isBinary = reIsBinary.test(value);\n return (isBinary || reIsOctal.test(value))\n ? freeParseInt(value.slice(2), isBinary ? 2 : 8)\n : (reIsBadHex.test(value) ? NAN : +value);\n}\n\nmodule.exports = debounce;\n","'use strict';\n\nvar stringify = require('./stringify');\nvar parse = require('./parse');\nvar formats = require('./formats');\n\nmodule.exports = {\n formats: formats,\n parse: parse,\n stringify: stringify\n};\n","'use strict';\n\nvar replace = String.prototype.replace;\nvar percentTwenties = /%20/g;\n\nvar Format = {\n RFC1738: 'RFC1738',\n RFC3986: 'RFC3986'\n};\n\nmodule.exports = {\n 'default': Format.RFC3986,\n formatters: {\n RFC1738: function (value) {\n return replace.call(value, percentTwenties, '+');\n },\n RFC3986: function (value) {\n return String(value);\n }\n },\n RFC1738: Format.RFC1738,\n RFC3986: Format.RFC3986\n};\n","'use strict';\n\nvar utils = require('./utils');\n\nvar has = Object.prototype.hasOwnProperty;\nvar isArray = Array.isArray;\n\nvar defaults = {\n allowDots: false,\n allowPrototypes: false,\n arrayLimit: 20,\n charset: 'utf-8',\n charsetSentinel: false,\n comma: false,\n decoder: utils.decode,\n delimiter: '&',\n depth: 5,\n ignoreQueryPrefix: false,\n interpretNumericEntities: false,\n parameterLimit: 1000,\n parseArrays: true,\n plainObjects: false,\n strictNullHandling: false\n};\n\nvar interpretNumericEntities = function (str) {\n return str.replace(/&#(\\d+);/g, function ($0, numberStr) {\n return String.fromCharCode(parseInt(numberStr, 10));\n });\n};\n\nvar parseArrayValue = function (val, options) {\n if (val && typeof val === 'string' && options.comma && val.indexOf(',') > -1) {\n return val.split(',');\n }\n\n return val;\n};\n\n// This is what browsers will submit when the ✓ character occurs in an\n// application/x-www-form-urlencoded body and the encoding of the page containing\n// the form is iso-8859-1, or when the submitted form has an accept-charset\n// attribute of iso-8859-1. Presumably also with other charsets that do not contain\n// the ✓ character, such as us-ascii.\nvar isoSentinel = 'utf8=%26%2310003%3B'; // encodeURIComponent('✓')\n\n// These are the percent-encoded utf-8 octets representing a checkmark, indicating that the request actually is utf-8 encoded.\nvar charsetSentinel = 'utf8=%E2%9C%93'; // encodeURIComponent('✓')\n\nvar parseValues = function parseQueryStringValues(str, options) {\n var obj = {};\n var cleanStr = options.ignoreQueryPrefix ? str.replace(/^\\?/, '') : str;\n var limit = options.parameterLimit === Infinity ? undefined : options.parameterLimit;\n var parts = cleanStr.split(options.delimiter, limit);\n var skipIndex = -1; // Keep track of where the utf8 sentinel was found\n var i;\n\n var charset = options.charset;\n if (options.charsetSentinel) {\n for (i = 0; i < parts.length; ++i) {\n if (parts[i].indexOf('utf8=') === 0) {\n if (parts[i] === charsetSentinel) {\n charset = 'utf-8';\n } else if (parts[i] === isoSentinel) {\n charset = 'iso-8859-1';\n }\n skipIndex = i;\n i = parts.length; // The eslint settings do not allow break;\n }\n }\n }\n\n for (i = 0; i < parts.length; ++i) {\n if (i === skipIndex) {\n continue;\n }\n var part = parts[i];\n\n var bracketEqualsPos = part.indexOf(']=');\n var pos = bracketEqualsPos === -1 ? part.indexOf('=') : bracketEqualsPos + 1;\n\n var key, val;\n if (pos === -1) {\n key = options.decoder(part, defaults.decoder, charset, 'key');\n val = options.strictNullHandling ? null : '';\n } else {\n key = options.decoder(part.slice(0, pos), defaults.decoder, charset, 'key');\n val = utils.maybeMap(\n parseArrayValue(part.slice(pos + 1), options),\n function (encodedVal) {\n return options.decoder(encodedVal, defaults.decoder, charset, 'value');\n }\n );\n }\n\n if (val && options.interpretNumericEntities && charset === 'iso-8859-1') {\n val = interpretNumericEntities(val);\n }\n\n if (part.indexOf('[]=') > -1) {\n val = isArray(val) ? [val] : val;\n }\n\n if (has.call(obj, key)) {\n obj[key] = utils.combine(obj[key], val);\n } else {\n obj[key] = val;\n }\n }\n\n return obj;\n};\n\nvar parseObject = function (chain, val, options, valuesParsed) {\n var leaf = valuesParsed ? val : parseArrayValue(val, options);\n\n for (var i = chain.length - 1; i >= 0; --i) {\n var obj;\n var root = chain[i];\n\n if (root === '[]' && options.parseArrays) {\n obj = [].concat(leaf);\n } else {\n obj = options.plainObjects ? Object.create(null) : {};\n var cleanRoot = root.charAt(0) === '[' && root.charAt(root.length - 1) === ']' ? root.slice(1, -1) : root;\n var index = parseInt(cleanRoot, 10);\n if (!options.parseArrays && cleanRoot === '') {\n obj = { 0: leaf };\n } else if (\n !isNaN(index)\n && root !== cleanRoot\n && String(index) === cleanRoot\n && index >= 0\n && (options.parseArrays && index <= options.arrayLimit)\n ) {\n obj = [];\n obj[index] = leaf;\n } else if (cleanRoot !== '__proto__') {\n obj[cleanRoot] = leaf;\n }\n }\n\n leaf = obj;\n }\n\n return leaf;\n};\n\nvar parseKeys = function parseQueryStringKeys(givenKey, val, options, valuesParsed) {\n if (!givenKey) {\n return;\n }\n\n // Transform dot notation to bracket notation\n var key = options.allowDots ? givenKey.replace(/\\.([^.[]+)/g, '[$1]') : givenKey;\n\n // The regex chunks\n\n var brackets = /(\\[[^[\\]]*])/;\n var child = /(\\[[^[\\]]*])/g;\n\n // Get the parent\n\n var segment = options.depth > 0 && brackets.exec(key);\n var parent = segment ? key.slice(0, segment.index) : key;\n\n // Stash the parent if it exists\n\n var keys = [];\n if (parent) {\n // If we aren't using plain objects, optionally prefix keys that would overwrite object prototype properties\n if (!options.plainObjects && has.call(Object.prototype, parent)) {\n if (!options.allowPrototypes) {\n return;\n }\n }\n\n keys.push(parent);\n }\n\n // Loop through children appending to the array until we hit depth\n\n var i = 0;\n while (options.depth > 0 && (segment = child.exec(key)) !== null && i < options.depth) {\n i += 1;\n if (!options.plainObjects && has.call(Object.prototype, segment[1].slice(1, -1))) {\n if (!options.allowPrototypes) {\n return;\n }\n }\n keys.push(segment[1]);\n }\n\n // If there's a remainder, just add whatever is left\n\n if (segment) {\n keys.push('[' + key.slice(segment.index) + ']');\n }\n\n return parseObject(keys, val, options, valuesParsed);\n};\n\nvar normalizeParseOptions = function normalizeParseOptions(opts) {\n if (!opts) {\n return defaults;\n }\n\n if (opts.decoder !== null && opts.decoder !== undefined && typeof opts.decoder !== 'function') {\n throw new TypeError('Decoder has to be a function.');\n }\n\n if (typeof opts.charset !== 'undefined' && opts.charset !== 'utf-8' && opts.charset !== 'iso-8859-1') {\n throw new TypeError('The charset option must be either utf-8, iso-8859-1, or undefined');\n }\n var charset = typeof opts.charset === 'undefined' ? defaults.charset : opts.charset;\n\n return {\n allowDots: typeof opts.allowDots === 'undefined' ? defaults.allowDots : !!opts.allowDots,\n allowPrototypes: typeof opts.allowPrototypes === 'boolean' ? opts.allowPrototypes : defaults.allowPrototypes,\n arrayLimit: typeof opts.arrayLimit === 'number' ? opts.arrayLimit : defaults.arrayLimit,\n charset: charset,\n charsetSentinel: typeof opts.charsetSentinel === 'boolean' ? opts.charsetSentinel : defaults.charsetSentinel,\n comma: typeof opts.comma === 'boolean' ? opts.comma : defaults.comma,\n decoder: typeof opts.decoder === 'function' ? opts.decoder : defaults.decoder,\n delimiter: typeof opts.delimiter === 'string' || utils.isRegExp(opts.delimiter) ? opts.delimiter : defaults.delimiter,\n // eslint-disable-next-line no-implicit-coercion, no-extra-parens\n depth: (typeof opts.depth === 'number' || opts.depth === false) ? +opts.depth : defaults.depth,\n ignoreQueryPrefix: opts.ignoreQueryPrefix === true,\n interpretNumericEntities: typeof opts.interpretNumericEntities === 'boolean' ? opts.interpretNumericEntities : defaults.interpretNumericEntities,\n parameterLimit: typeof opts.parameterLimit === 'number' ? opts.parameterLimit : defaults.parameterLimit,\n parseArrays: opts.parseArrays !== false,\n plainObjects: typeof opts.plainObjects === 'boolean' ? opts.plainObjects : defaults.plainObjects,\n strictNullHandling: typeof opts.strictNullHandling === 'boolean' ? opts.strictNullHandling : defaults.strictNullHandling\n };\n};\n\nmodule.exports = function (str, opts) {\n var options = normalizeParseOptions(opts);\n\n if (str === '' || str === null || typeof str === 'undefined') {\n return options.plainObjects ? Object.create(null) : {};\n }\n\n var tempObj = typeof str === 'string' ? parseValues(str, options) : str;\n var obj = options.plainObjects ? Object.create(null) : {};\n\n // Iterate over the keys and setup the new object\n\n var keys = Object.keys(tempObj);\n for (var i = 0; i < keys.length; ++i) {\n var key = keys[i];\n var newObj = parseKeys(key, tempObj[key], options, typeof str === 'string');\n obj = utils.merge(obj, newObj, options);\n }\n\n return utils.compact(obj);\n};\n","'use strict';\n\nvar formats = require('./formats');\n\nvar has = Object.prototype.hasOwnProperty;\nvar isArray = Array.isArray;\n\nvar hexTable = (function () {\n var array = [];\n for (var i = 0; i < 256; ++i) {\n array.push('%' + ((i < 16 ? '0' : '') + i.toString(16)).toUpperCase());\n }\n\n return array;\n}());\n\nvar compactQueue = function compactQueue(queue) {\n while (queue.length > 1) {\n var item = queue.pop();\n var obj = item.obj[item.prop];\n\n if (isArray(obj)) {\n var compacted = [];\n\n for (var j = 0; j < obj.length; ++j) {\n if (typeof obj[j] !== 'undefined') {\n compacted.push(obj[j]);\n }\n }\n\n item.obj[item.prop] = compacted;\n }\n }\n};\n\nvar arrayToObject = function arrayToObject(source, options) {\n var obj = options && options.plainObjects ? Object.create(null) : {};\n for (var i = 0; i < source.length; ++i) {\n if (typeof source[i] !== 'undefined') {\n obj[i] = source[i];\n }\n }\n\n return obj;\n};\n\nvar merge = function merge(target, source, options) {\n /* eslint no-param-reassign: 0 */\n if (!source) {\n return target;\n }\n\n if (typeof source !== 'object') {\n if (isArray(target)) {\n target.push(source);\n } else if (target && typeof target === 'object') {\n if ((options && (options.plainObjects || options.allowPrototypes)) || !has.call(Object.prototype, source)) {\n target[source] = true;\n }\n } else {\n return [target, source];\n }\n\n return target;\n }\n\n if (!target || typeof target !== 'object') {\n return [target].concat(source);\n }\n\n var mergeTarget = target;\n if (isArray(target) && !isArray(source)) {\n mergeTarget = arrayToObject(target, options);\n }\n\n if (isArray(target) && isArray(source)) {\n source.forEach(function (item, i) {\n if (has.call(target, i)) {\n var targetItem = target[i];\n if (targetItem && typeof targetItem === 'object' && item && typeof item === 'object') {\n target[i] = merge(targetItem, item, options);\n } else {\n target.push(item);\n }\n } else {\n target[i] = item;\n }\n });\n return target;\n }\n\n return Object.keys(source).reduce(function (acc, key) {\n var value = source[key];\n\n if (has.call(acc, key)) {\n acc[key] = merge(acc[key], value, options);\n } else {\n acc[key] = value;\n }\n return acc;\n }, mergeTarget);\n};\n\nvar assign = function assignSingleSource(target, source) {\n return Object.keys(source).reduce(function (acc, key) {\n acc[key] = source[key];\n return acc;\n }, target);\n};\n\nvar decode = function (str, decoder, charset) {\n var strWithoutPlus = str.replace(/\\+/g, ' ');\n if (charset === 'iso-8859-1') {\n // unescape never throws, no try...catch needed:\n return strWithoutPlus.replace(/%[0-9a-f]{2}/gi, unescape);\n }\n // utf-8\n try {\n return decodeURIComponent(strWithoutPlus);\n } catch (e) {\n return strWithoutPlus;\n }\n};\n\nvar encode = function encode(str, defaultEncoder, charset, kind, format) {\n // This code was originally written by Brian White (mscdex) for the io.js core querystring library.\n // It has been adapted here for stricter adherence to RFC 3986\n if (str.length === 0) {\n return str;\n }\n\n var string = str;\n if (typeof str === 'symbol') {\n string = Symbol.prototype.toString.call(str);\n } else if (typeof str !== 'string') {\n string = String(str);\n }\n\n if (charset === 'iso-8859-1') {\n return escape(string).replace(/%u[0-9a-f]{4}/gi, function ($0) {\n return '%26%23' + parseInt($0.slice(2), 16) + '%3B';\n });\n }\n\n var out = '';\n for (var i = 0; i < string.length; ++i) {\n var c = string.charCodeAt(i);\n\n if (\n c === 0x2D // -\n || c === 0x2E // .\n || c === 0x5F // _\n || c === 0x7E // ~\n || (c >= 0x30 && c <= 0x39) // 0-9\n || (c >= 0x41 && c <= 0x5A) // a-z\n || (c >= 0x61 && c <= 0x7A) // A-Z\n || (format === formats.RFC1738 && (c === 0x28 || c === 0x29)) // ( )\n ) {\n out += string.charAt(i);\n continue;\n }\n\n if (c < 0x80) {\n out = out + hexTable[c];\n continue;\n }\n\n if (c < 0x800) {\n out = out + (hexTable[0xC0 | (c >> 6)] + hexTable[0x80 | (c & 0x3F)]);\n continue;\n }\n\n if (c < 0xD800 || c >= 0xE000) {\n out = out + (hexTable[0xE0 | (c >> 12)] + hexTable[0x80 | ((c >> 6) & 0x3F)] + hexTable[0x80 | (c & 0x3F)]);\n continue;\n }\n\n i += 1;\n c = 0x10000 + (((c & 0x3FF) << 10) | (string.charCodeAt(i) & 0x3FF));\n /* eslint operator-linebreak: [2, \"before\"] */\n out += hexTable[0xF0 | (c >> 18)]\n + hexTable[0x80 | ((c >> 12) & 0x3F)]\n + hexTable[0x80 | ((c >> 6) & 0x3F)]\n + hexTable[0x80 | (c & 0x3F)];\n }\n\n return out;\n};\n\nvar compact = function compact(value) {\n var queue = [{ obj: { o: value }, prop: 'o' }];\n var refs = [];\n\n for (var i = 0; i < queue.length; ++i) {\n var item = queue[i];\n var obj = item.obj[item.prop];\n\n var keys = Object.keys(obj);\n for (var j = 0; j < keys.length; ++j) {\n var key = keys[j];\n var val = obj[key];\n if (typeof val === 'object' && val !== null && refs.indexOf(val) === -1) {\n queue.push({ obj: obj, prop: key });\n refs.push(val);\n }\n }\n }\n\n compactQueue(queue);\n\n return value;\n};\n\nvar isRegExp = function isRegExp(obj) {\n return Object.prototype.toString.call(obj) === '[object RegExp]';\n};\n\nvar isBuffer = function isBuffer(obj) {\n if (!obj || typeof obj !== 'object') {\n return false;\n }\n\n return !!(obj.constructor && obj.constructor.isBuffer && obj.constructor.isBuffer(obj));\n};\n\nvar combine = function combine(a, b) {\n return [].concat(a, b);\n};\n\nvar maybeMap = function maybeMap(val, fn) {\n if (isArray(val)) {\n var mapped = [];\n for (var i = 0; i < val.length; i += 1) {\n mapped.push(fn(val[i]));\n }\n return mapped;\n }\n return fn(val);\n};\n\nmodule.exports = {\n arrayToObject: arrayToObject,\n assign: assign,\n combine: combine,\n compact: compact,\n decode: decode,\n encode: encode,\n isBuffer: isBuffer,\n isRegExp: isRegExp,\n maybeMap: maybeMap,\n merge: merge\n};\n","'use strict';\n\nvar utils = require('./utils');\nvar formats = require('./formats');\nvar has = Object.prototype.hasOwnProperty;\n\nvar arrayPrefixGenerators = {\n brackets: function brackets(prefix) {\n return prefix + '[]';\n },\n comma: 'comma',\n indices: function indices(prefix, key) {\n return prefix + '[' + key + ']';\n },\n repeat: function repeat(prefix) {\n return prefix;\n }\n};\n\nvar isArray = Array.isArray;\nvar split = String.prototype.split;\nvar push = Array.prototype.push;\nvar pushToArray = function (arr, valueOrArray) {\n push.apply(arr, isArray(valueOrArray) ? valueOrArray : [valueOrArray]);\n};\n\nvar toISO = Date.prototype.toISOString;\n\nvar defaultFormat = formats['default'];\nvar defaults = {\n addQueryPrefix: false,\n allowDots: false,\n charset: 'utf-8',\n charsetSentinel: false,\n delimiter: '&',\n encode: true,\n encoder: utils.encode,\n encodeValuesOnly: false,\n format: defaultFormat,\n formatter: formats.formatters[defaultFormat],\n // deprecated\n indices: false,\n serializeDate: function serializeDate(date) {\n return toISO.call(date);\n },\n skipNulls: false,\n strictNullHandling: false\n};\n\nvar isNonNullishPrimitive = function isNonNullishPrimitive(v) {\n return typeof v === 'string'\n || typeof v === 'number'\n || typeof v === 'boolean'\n || typeof v === 'symbol'\n || typeof v === 'bigint';\n};\n\nvar stringify = function stringify(\n object,\n prefix,\n generateArrayPrefix,\n strictNullHandling,\n skipNulls,\n encoder,\n filter,\n sort,\n allowDots,\n serializeDate,\n format,\n formatter,\n encodeValuesOnly,\n charset\n) {\n var obj = object;\n if (typeof filter === 'function') {\n obj = filter(prefix, obj);\n } else if (obj instanceof Date) {\n obj = serializeDate(obj);\n } else if (generateArrayPrefix === 'comma' && isArray(obj)) {\n obj = utils.maybeMap(obj, function (value) {\n if (value instanceof Date) {\n return serializeDate(value);\n }\n return value;\n });\n }\n\n if (obj === null) {\n if (strictNullHandling) {\n return encoder && !encodeValuesOnly ? encoder(prefix, defaults.encoder, charset, 'key', format) : prefix;\n }\n\n obj = '';\n }\n\n if (isNonNullishPrimitive(obj) || utils.isBuffer(obj)) {\n if (encoder) {\n var keyValue = encodeValuesOnly ? prefix : encoder(prefix, defaults.encoder, charset, 'key', format);\n if (generateArrayPrefix === 'comma' && encodeValuesOnly) {\n var valuesArray = split.call(String(obj), ',');\n var valuesJoined = '';\n for (var i = 0; i < valuesArray.length; ++i) {\n valuesJoined += (i === 0 ? '' : ',') + formatter(encoder(valuesArray[i], defaults.encoder, charset, 'value', format));\n }\n return [formatter(keyValue) + '=' + valuesJoined];\n }\n return [formatter(keyValue) + '=' + formatter(encoder(obj, defaults.encoder, charset, 'value', format))];\n }\n return [formatter(prefix) + '=' + formatter(String(obj))];\n }\n\n var values = [];\n\n if (typeof obj === 'undefined') {\n return values;\n }\n\n var objKeys;\n if (generateArrayPrefix === 'comma' && isArray(obj)) {\n // we need to join elements in\n objKeys = [{ value: obj.length > 0 ? obj.join(',') || null : void undefined }];\n } else if (isArray(filter)) {\n objKeys = filter;\n } else {\n var keys = Object.keys(obj);\n objKeys = sort ? keys.sort(sort) : keys;\n }\n\n for (var j = 0; j < objKeys.length; ++j) {\n var key = objKeys[j];\n var value = typeof key === 'object' && typeof key.value !== 'undefined' ? key.value : obj[key];\n\n if (skipNulls && value === null) {\n continue;\n }\n\n var keyPrefix = isArray(obj)\n ? typeof generateArrayPrefix === 'function' ? generateArrayPrefix(prefix, key) : prefix\n : prefix + (allowDots ? '.' + key : '[' + key + ']');\n\n pushToArray(values, stringify(\n value,\n keyPrefix,\n generateArrayPrefix,\n strictNullHandling,\n skipNulls,\n encoder,\n filter,\n sort,\n allowDots,\n serializeDate,\n format,\n formatter,\n encodeValuesOnly,\n charset\n ));\n }\n\n return values;\n};\n\nvar normalizeStringifyOptions = function normalizeStringifyOptions(opts) {\n if (!opts) {\n return defaults;\n }\n\n if (opts.encoder !== null && typeof opts.encoder !== 'undefined' && typeof opts.encoder !== 'function') {\n throw new TypeError('Encoder has to be a function.');\n }\n\n var charset = opts.charset || defaults.charset;\n if (typeof opts.charset !== 'undefined' && opts.charset !== 'utf-8' && opts.charset !== 'iso-8859-1') {\n throw new TypeError('The charset option must be either utf-8, iso-8859-1, or undefined');\n }\n\n var format = formats['default'];\n if (typeof opts.format !== 'undefined') {\n if (!has.call(formats.formatters, opts.format)) {\n throw new TypeError('Unknown format option provided.');\n }\n format = opts.format;\n }\n var formatter = formats.formatters[format];\n\n var filter = defaults.filter;\n if (typeof opts.filter === 'function' || isArray(opts.filter)) {\n filter = opts.filter;\n }\n\n return {\n addQueryPrefix: typeof opts.addQueryPrefix === 'boolean' ? opts.addQueryPrefix : defaults.addQueryPrefix,\n allowDots: typeof opts.allowDots === 'undefined' ? defaults.allowDots : !!opts.allowDots,\n charset: charset,\n charsetSentinel: typeof opts.charsetSentinel === 'boolean' ? opts.charsetSentinel : defaults.charsetSentinel,\n delimiter: typeof opts.delimiter === 'undefined' ? defaults.delimiter : opts.delimiter,\n encode: typeof opts.encode === 'boolean' ? opts.encode : defaults.encode,\n encoder: typeof opts.encoder === 'function' ? opts.encoder : defaults.encoder,\n encodeValuesOnly: typeof opts.encodeValuesOnly === 'boolean' ? opts.encodeValuesOnly : defaults.encodeValuesOnly,\n filter: filter,\n format: format,\n formatter: formatter,\n serializeDate: typeof opts.serializeDate === 'function' ? opts.serializeDate : defaults.serializeDate,\n skipNulls: typeof opts.skipNulls === 'boolean' ? opts.skipNulls : defaults.skipNulls,\n sort: typeof opts.sort === 'function' ? opts.sort : null,\n strictNullHandling: typeof opts.strictNullHandling === 'boolean' ? opts.strictNullHandling : defaults.strictNullHandling\n };\n};\n\nmodule.exports = function (object, opts) {\n var obj = object;\n var options = normalizeStringifyOptions(opts);\n\n var objKeys;\n var filter;\n\n if (typeof options.filter === 'function') {\n filter = options.filter;\n obj = filter('', obj);\n } else if (isArray(options.filter)) {\n filter = options.filter;\n objKeys = filter;\n }\n\n var keys = [];\n\n if (typeof obj !== 'object' || obj === null) {\n return '';\n }\n\n var arrayFormat;\n if (opts && opts.arrayFormat in arrayPrefixGenerators) {\n arrayFormat = opts.arrayFormat;\n } else if (opts && 'indices' in opts) {\n arrayFormat = opts.indices ? 'indices' : 'repeat';\n } else {\n arrayFormat = 'indices';\n }\n\n var generateArrayPrefix = arrayPrefixGenerators[arrayFormat];\n\n if (!objKeys) {\n objKeys = Object.keys(obj);\n }\n\n if (options.sort) {\n objKeys.sort(options.sort);\n }\n\n for (var i = 0; i < objKeys.length; ++i) {\n var key = objKeys[i];\n\n if (options.skipNulls && obj[key] === null) {\n continue;\n }\n pushToArray(keys, stringify(\n obj[key],\n key,\n generateArrayPrefix,\n options.strictNullHandling,\n options.skipNulls,\n options.encode ? options.encoder : null,\n options.filter,\n options.sort,\n options.allowDots,\n options.serializeDate,\n options.format,\n options.formatter,\n options.encodeValuesOnly,\n options.charset\n ));\n }\n\n var joined = keys.join(options.delimiter);\n var prefix = options.addQueryPrefix === true ? '?' : '';\n\n if (options.charsetSentinel) {\n if (options.charset === 'iso-8859-1') {\n // encodeURIComponent('✓'), the \"numeric entity\" representation of a checkmark\n prefix += 'utf8=%26%2310003%3B&';\n } else {\n // encodeURIComponent('✓')\n prefix += 'utf8=%E2%9C%93&';\n }\n }\n\n return joined.length > 0 ? prefix + joined : '';\n};\n","","const PASSWORD_AUTOCOMPLETE_TYPE = 'password';\nconst NEW_PASSWORD_AUTOCOMPLETE_TYPE = 'password-new';\nconst ACCESSIBILITY_ROLE_FORM = 'none';\n\nexport {\n PASSWORD_AUTOCOMPLETE_TYPE,\n ACCESSIBILITY_ROLE_FORM,\n NEW_PASSWORD_AUTOCOMPLETE_TYPE,\n};\n","import _ from 'underscore';\nimport React from 'react';\nimport {withOnyx} from 'react-native-onyx';\nimport ScreenWrapper from '../../components/ScreenWrapper';\nimport * as Wallet from '../../libs/actions/Wallet';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport FullScreenLoadingIndicator from '../../components/FullscreenLoadingIndicator';\nimport CONST from '../../CONST';\nimport userWalletPropTypes from './userWalletPropTypes';\nimport {withNetwork} from '../../components/OnyxProvider';\nimport networkPropTypes from '../../components/networkPropTypes';\n\n// Steps\nimport OnfidoStep from './OnfidoStep';\nimport AdditionalDetailsStep from './AdditionalDetailsStep';\nimport TermsStep from './TermsStep';\nimport ActivateStep from './ActivateStep';\nimport HeaderWithCloseButton from '../../components/HeaderWithCloseButton';\nimport Navigation from '../../libs/Navigation/Navigation';\nimport FailedKYC from './FailedKYC';\nimport compose from '../../libs/compose';\nimport withLocalize, {withLocalizePropTypes} from '../../components/withLocalize';\n\nconst propTypes = {\n /** Information about the network from Onyx */\n network: networkPropTypes.isRequired,\n\n /** The user's wallet */\n userWallet: userWalletPropTypes,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n userWallet: {},\n};\n\nclass EnablePaymentsPage extends React.Component {\n componentDidMount() {\n Wallet.openEnablePaymentsPage();\n }\n\n componentDidUpdate(prevProps) {\n if (!prevProps.network.isOffline || this.props.network.isOffline) {\n return;\n }\n\n Wallet.openEnablePaymentsPage();\n }\n\n render() {\n if (_.isEmpty(this.props.userWallet)) {\n return ;\n }\n\n return (\n \n {() => {\n if (this.props.userWallet.errorCode === CONST.WALLET.ERROR.KYC) {\n return (\n <>\n Navigation.dismissModal()}\n />\n \n \n );\n }\n\n if (this.props.userWallet.shouldShowWalletActivationSuccess) {\n return (\n \n );\n }\n\n const currentStep = this.props.userWallet.currentStep || CONST.WALLET.STEP.ADDITIONAL_DETAILS;\n\n return (\n <>\n {(currentStep === CONST.WALLET.STEP.ADDITIONAL_DETAILS || currentStep === CONST.WALLET.STEP.ADDITIONAL_DETAILS_KBA)\n && }\n {currentStep === CONST.WALLET.STEP.ONFIDO && }\n {currentStep === CONST.WALLET.STEP.TERMS && }\n {currentStep === CONST.WALLET.STEP.ACTIVATE && }\n \n );\n }}\n \n );\n }\n}\n\nEnablePaymentsPage.propTypes = propTypes;\nEnablePaymentsPage.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withOnyx({\n userWallet: {\n key: ONYXKEYS.USER_WALLET,\n\n // We want to refresh the wallet each time the user attempts to activate the wallet so we won't use the\n // stored values here.\n initWithStoredValues: false,\n },\n }),\n withNetwork(),\n)(EnablePaymentsPage);\n","import React from 'react';\nimport {withOnyx} from 'react-native-onyx';\nimport Onfido from '../../components/Onfido';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport * as BankAccounts from '../../libs/actions/BankAccounts';\nimport Navigation from '../../libs/Navigation/Navigation';\nimport CONST from '../../CONST';\nimport HeaderWithCloseButton from '../../components/HeaderWithCloseButton';\nimport * as Wallet from '../../libs/actions/Wallet';\nimport withLocalize, {withLocalizePropTypes} from '../../components/withLocalize';\nimport compose from '../../libs/compose';\nimport Growl from '../../libs/Growl';\nimport OnfidoPrivacy from './OnfidoPrivacy';\nimport walletOnfidoDataPropTypes from './walletOnfidoDataPropTypes';\nimport FullPageOfflineBlockingView from '../../components/BlockingViews/FullPageOfflineBlockingView';\n\nconst propTypes = {\n /** Stores various information used to build the UI and call any APIs */\n walletOnfidoData: walletOnfidoDataPropTypes,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n walletOnfidoData: {\n loading: false,\n hasAcceptedPrivacyPolicy: false,\n },\n};\n\nclass OnfidoStep extends React.Component {\n /**\n * @returns {boolean|*}\n */\n canShowOnfido() {\n return this.props.walletOnfidoData.hasAcceptedPrivacyPolicy\n && !this.props.walletOnfidoData.isLoading\n && !this.props.walletOnfidoData.error\n && this.props.walletOnfidoData.sdkToken;\n }\n\n render() {\n return (\n <>\n Navigation.dismissModal()}\n shouldShowBackButton\n onBackButtonPress={() => Wallet.updateCurrentStep(CONST.WALLET.STEP.ADDITIONAL_DETAILS)}\n />\n \n {\n this.canShowOnfido() ? (\n {\n Growl.error(this.props.translate('onfidoStep.genericError'), 10000);\n }}\n onUserExit={() => {\n Navigation.goBack();\n }}\n onSuccess={(data) => {\n BankAccounts.verifyIdentity({\n onfidoData: JSON.stringify({\n ...data,\n applicantID: this.props.walletOnfidoData.applicantID,\n }),\n });\n }}\n />\n ) : (\n \n )\n }\n \n\n \n );\n }\n}\n\nOnfidoStep.propTypes = propTypes;\nOnfidoStep.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withOnyx({\n walletOnfidoData: {\n key: ONYXKEYS.WALLET_ONFIDO,\n\n // Let's get a new onfido token each time the user hits this flow (as it should only be once)\n initWithStoredValues: false,\n },\n }),\n)(OnfidoStep);\n","import _ from 'underscore';\nimport lodashGet from 'lodash/get';\nimport React from 'react';\nimport {Alert, Linking} from 'react-native';\nimport {\n Onfido as OnfidoSDK,\n OnfidoCaptureType,\n OnfidoDocumentType,\n OnfidoCountryCode,\n} from '@onfido/react-native-sdk';\nimport onfidoPropTypes from './onfidoPropTypes';\nimport CONST from '../../CONST';\nimport withLocalize, {withLocalizePropTypes} from '../withLocalize';\nimport Log from '../../libs/Log';\n\nconst propTypes = {\n ...withLocalizePropTypes,\n ...onfidoPropTypes,\n};\n\nclass Onfido extends React.Component {\n componentDidMount() {\n OnfidoSDK.start({\n sdkToken: this.props.sdkToken,\n flowSteps: {\n welcome: true,\n captureFace: {\n type: OnfidoCaptureType.VIDEO,\n },\n captureDocument: {\n docType: OnfidoDocumentType.GENERIC,\n countryCode: OnfidoCountryCode.USA,\n },\n },\n })\n .then(this.props.onSuccess)\n .catch((error) => {\n const errorMessage = lodashGet(error, 'message', CONST.ERROR.UNKNOWN_ERROR);\n const errorType = lodashGet(error, 'type');\n Log.hmmm('Onfido error on native', {errorType, errorMessage});\n\n // If the user cancels the Onfido flow we won't log this error as it's normal. In the React Native SDK the user exiting the flow will trigger this error which we can use as\n // our \"user exited the flow\" callback. On web, this event has it's own callback passed as a config so we don't need to bother with this there.\n if (_.contains(\n [\n CONST.ONFIDO.ERROR.USER_CANCELLED,\n CONST.ONFIDO.ERROR.USER_TAPPED_BACK,\n CONST.ONFIDO.ERROR.USER_EXITED,\n ],\n errorMessage,\n )) {\n this.props.onUserExit();\n return;\n }\n\n // Handle user camera permission on iOS and Android\n if (_.contains(\n [\n CONST.ONFIDO.ERROR.USER_CAMERA_PERMISSION,\n CONST.ONFIDO.ERROR.USER_CAMERA_DENINED,\n CONST.ONFIDO.ERROR.USER_CAMERA_CONSENT_DENIED,\n ],\n errorMessage,\n )) {\n Alert.alert(\n this.props.translate('onfidoStep.cameraPermissionsNotGranted'),\n this.props.translate('onfidoStep.cameraRequestMessage'),\n [\n {\n text: this.props.translate('common.cancel'),\n onPress: () => this.props.onUserExit(),\n },\n {\n text: this.props.translate('common.settings'),\n onPress: () => {\n this.props.onUserExit();\n Linking.openSettings();\n },\n },\n ],\n {cancelable: false},\n );\n return;\n }\n\n this.props.onError(errorMessage);\n });\n }\n\n render() {\n return null;\n }\n}\n\nOnfido.propTypes = propTypes;\nexport default withLocalize(Onfido);\n","import PropTypes from 'prop-types';\n\nexport default {\n /** Token used to initialize the Onfido SDK */\n sdkToken: PropTypes.string.isRequired,\n\n /** Called when the user intentionally exits the flow without completing it */\n onUserExit: PropTypes.func.isRequired,\n\n /** Called when the user is totally done with Onfido */\n onSuccess: PropTypes.func.isRequired,\n\n /** Called when Onfido throws an error */\n onError: PropTypes.func.isRequired,\n};\n","import Onfido from \"./js/Onfido\";\nexport * from './js/config_constants';\n\nexport { Onfido };\nexport default Onfido;\n","import { NativeModules, Platform } from 'react-native';\nimport { \n OnfidoDocumentType, \n OnfidoCaptureType, \n OnfidoCountryCode,\n OnfidoAlpha2CountryCode, \n OnfidoConfig,\n OnfidoError,\n OnfidoResult\n} from \"./config_constants\";\n\nconst { OnfidoSdk } = NativeModules;\n\nconst Onfido = {\n start(config: OnfidoConfig): Promise {\n\n if (!config) {\n return configError(\"config is missing\");\n }\n\n if (!config.sdkToken) {\n return configError(\"sdkToken is missing\");\n }\n\n if (!config.sdkToken.match(/^[A-Za-z0-9-_=]+\\.[A-Za-z0-9-_=]+\\.?[A-Za-z0-9-_.+/=]*$/)) {\n return configError(\"sdkToken is not a valid jwt\");\n }\n\n if (config.workflowRunId === undefined) { \n if (!config.flowSteps) {\n return configError(\"flowSteps configuration is missing\");\n }\n \n if (config.flowSteps.captureDocument) {\n if (config.flowSteps.captureDocument.docType && !config.flowSteps.captureDocument.countryCode) {\n return configError(\"countryCode needs to be a ISO 3166-1 3 letter code if docType is specified\");\n }\n \n if (!config.flowSteps.captureDocument.docType && config.flowSteps.captureDocument.countryCode) {\n return configError(\"docType needs to be provided if countryCode is specified\");\n }\n \n if (config.flowSteps.captureDocument.docType && !(config.flowSteps.captureDocument.docType in OnfidoDocumentType)) {\n return configError(\"docType is invalid\");\n }\n \n \n if (config.flowSteps.captureDocument.countryCode) {\n if (!(config.flowSteps.captureDocument.countryCode in OnfidoCountryCode)) {\n return configError(\"countryCode is not a ISO 3166-1 3 letter code\");\n }\n \n if (Platform.OS === \"android\") {\n config.flowSteps.captureDocument.alpha2CountryCode = OnfidoAlpha2CountryCode[config.flowSteps.captureDocument.countryCode];\n }\n }\n }\n \n if (!config.flowSteps.captureDocument && !config.flowSteps.captureFace) {\n return configError(\"flowSteps doesn't include either valid captureDocument options or valid captureFace options\");\n }\n \n if (config.flowSteps.captureFace && !(config.flowSteps.captureFace.type in OnfidoCaptureType)) {\n return configError(\"Capture Face type is invalid\");\n }\n }\n\n return OnfidoSdk.start(config).catch((error: any) => {\n console.log(error);\n throw error;\n });\n }\n};\n\nconst configError = (message: string): Promise => {\n const error: OnfidoError = new Error(message);\n error.code = \"config_error\";\n console.log(error);\n return Promise.reject(error);\n};\n\nexport default Onfido\n","export type OnfidoFlowSteps = {\n welcome?: boolean;\n captureDocument?: {\n countryCode?: OnfidoCountryCode;\n alpha2CountryCode?: OnfidoAlpha2CountryCode;\n docType?: OnfidoDocumentType;\n };\n captureFace?: {\n type: OnfidoCaptureType;\n };\n};\n\nexport type OnfidoResult = {\n document?: {\n front: {\n id: string;\n };\n back?: {\n id: string;\n };\n };\n face?: {\n id: string;\n variant: OnfidoCaptureType;\n };\n};\n\nexport type OnfidoConfig = {\n sdkToken: string;\n workflowRunId?: string;\n flowSteps: OnfidoFlowSteps;\n hideLogo?: boolean;\n logoCoBrand?: boolean;\n enableNFC?: boolean;\n localisation?: {\n ios_strings_file_name?: string;\n };\n};\n\nexport interface OnfidoError extends Error {\n code?: string;\n}\n\n\nexport enum OnfidoDocumentType {\n PASSPORT = \"PASSPORT\",\n DRIVING_LICENCE = \"DRIVING_LICENCE\",\n NATIONAL_IDENTITY_CARD = \"NATIONAL_IDENTITY_CARD\",\n RESIDENCE_PERMIT = \"RESIDENCE_PERMIT\",\n VISA = \"VISA\",\n WORK_PERMIT = \"WORK_PERMIT\",\n GENERIC = \"GENERIC\"\n}\n\nexport enum OnfidoCaptureType {\n PHOTO = \"PHOTO\",\n VIDEO = \"VIDEO\",\n MOTION = \"MOTION\"\n}\n\nexport enum OnfidoCountryCode {\n ABW = \"ABW\",\n AFG = \"AFG\",\n AGO = \"AGO\",\n AIA = \"AIA\",\n ALA = \"ALA\",\n ALB = \"ALB\",\n AND = \"AND\",\n ARE = \"ARE\",\n ARG = \"ARG\",\n ARM = \"ARM\",\n ASM = \"ASM\",\n ATA = \"ATA\",\n ATF = \"ATF\",\n ATG = \"ATG\",\n AUS = \"AUS\",\n AUT = \"AUT\",\n AZE = \"AZE\",\n BDI = \"BDI\",\n BEL = \"BEL\",\n BEN = \"BEN\",\n BES = \"BES\",\n BFA = \"BFA\",\n BGD = \"BGD\",\n BGR = \"BGR\",\n BHR = \"BHR\",\n BHS = \"BHS\",\n BIH = \"BIH\",\n BLM = \"BLM\",\n BLR = \"BLR\",\n BLZ = \"BLZ\",\n BMU = \"BMU\",\n BOL = \"BOL\",\n BRA = \"BRA\",\n BRB = \"BRB\",\n BRN = \"BRN\",\n BTN = \"BTN\",\n BVT = \"BVT\",\n BWA = \"BWA\",\n CAF = \"CAF\",\n CAN = \"CAN\",\n CCK = \"CCK\",\n CHE = \"CHE\",\n CHL = \"CHL\",\n CHN = \"CHN\",\n CIV = \"CIV\",\n CMR = \"CMR\",\n COD = \"COD\",\n COG = \"COG\",\n COK = \"COK\",\n COL = \"COL\",\n COM = \"COM\",\n CPV = \"CPV\",\n CRI = \"CRI\",\n CUB = \"CUB\",\n CUW = \"CUW\",\n CXR = \"CXR\",\n CYM = \"CYM\",\n CYP = \"CYP\",\n CZE = \"CZE\",\n DEU = \"DEU\",\n DJI = \"DJI\",\n DMA = \"DMA\",\n DNK = \"DNK\",\n DOM = \"DOM\",\n DZA = \"DZA\",\n ECU = \"ECU\",\n EGY = \"EGY\",\n ERI = \"ERI\",\n ESH = \"ESH\",\n ESP = \"ESP\",\n EST = \"EST\",\n ETH = \"ETH\",\n FIN = \"FIN\",\n FJI = \"FJI\",\n FLK = \"FLK\",\n FRA = \"FRA\",\n FRO = \"FRO\",\n FSM = \"FSM\",\n GAB = \"GAB\",\n GBR = \"GBR\",\n GEO = \"GEO\",\n GGY = \"GGY\",\n GHA = \"GHA\",\n GIB = \"GIB\",\n GIN = \"GIN\",\n GLP = \"GLP\",\n GMB = \"GMB\",\n GNB = \"GNB\",\n GNQ = \"GNQ\",\n GRC = \"GRC\",\n GRD = \"GRD\",\n GRL = \"GRL\",\n GTM = \"GTM\",\n GUF = \"GUF\",\n GUM = \"GUM\",\n GUY = \"GUY\",\n HKG = \"HKG\",\n HMD = \"HMD\",\n HND = \"HND\",\n HRV = \"HRV\",\n HTI = \"HTI\",\n HUN = \"HUN\",\n IDN = \"IDN\",\n IMN = \"IMN\",\n IND = \"IND\",\n IOT = \"IOT\",\n IRL = \"IRL\",\n IRN = \"IRN\",\n IRQ = \"IRQ\",\n ISL = \"ISL\",\n ISR = \"ISR\",\n ITA = \"ITA\",\n JAM = \"JAM\",\n JEY = \"JEY\",\n JOR = \"JOR\",\n JPN = \"JPN\",\n KAZ = \"KAZ\",\n KEN = \"KEN\",\n KGZ = \"KGZ\",\n KHM = \"KHM\",\n KIR = \"KIR\",\n KNA = \"KNA\",\n KOR = \"KOR\",\n KWT = \"KWT\",\n LAO = \"LAO\",\n LBN = \"LBN\",\n LBR = \"LBR\",\n LBY = \"LBY\",\n LCA = \"LCA\",\n LIE = \"LIE\",\n LKA = \"LKA\",\n LSO = \"LSO\",\n LTU = \"LTU\",\n LUX = \"LUX\",\n LVA = \"LVA\",\n MAC = \"MAC\",\n MAF = \"MAF\",\n MAR = \"MAR\",\n MCO = \"MCO\",\n MDA = \"MDA\",\n MDG = \"MDG\",\n MDV = \"MDV\",\n MEX = \"MEX\",\n MHL = \"MHL\",\n MKD = \"MKD\",\n MLI = \"MLI\",\n MLT = \"MLT\",\n MMR = \"MMR\",\n MNE = \"MNE\",\n MNG = \"MNG\",\n MNP = \"MNP\",\n MOZ = \"MOZ\",\n MSR = \"MSR\",\n MTQ = \"MTQ\",\n MUS = \"MUS\",\n MWI = \"MWI\",\n MYS = \"MYS\",\n MYT = \"MYT\",\n NAM = \"NAM\",\n NCL = \"NCL\",\n NER = \"NER\",\n NFK = \"NFK\",\n NGA = \"NGA\",\n NIC = \"NIC\",\n NIU = \"NIU\",\n NLD = \"NLD\",\n NOR = \"NOR\",\n NPL = \"NPL\",\n NRU = \"NRU\",\n NZL = \"NZL\",\n OMN = \"OMN\",\n PAK = \"PAK\",\n PAN = \"PAN\",\n PCN = \"PCN\",\n PER = \"PER\",\n PHL = \"PHL\",\n PLW = \"PLW\",\n PNG = \"PNG\",\n POL = \"POL\",\n PRI = \"PRI\",\n PRK = \"PRK\",\n PRT = \"PRT\",\n PRY = \"PRY\",\n PSE = \"PSE\",\n PYF = \"PYF\",\n QAT = \"QAT\",\n REU = \"REU\",\n RKS = \"RKS\",\n ROU = \"ROU\",\n RUS = \"RUS\",\n RWA = \"RWA\",\n SAU = \"SAU\",\n SDN = \"SDN\",\n SEN = \"SEN\",\n SGP = \"SGP\",\n SGS = \"SGS\",\n SHN = \"SHN\",\n SJM = \"SJM\",\n SLB = \"SLB\",\n SLE = \"SLE\",\n SLV = \"SLV\",\n SMR = \"SMR\",\n SOM = \"SOM\",\n SPM = \"SPM\",\n SRB = \"SRB\",\n SSD = \"SSD\",\n STP = \"STP\",\n SUR = \"SUR\",\n SVK = \"SVK\",\n SVN = \"SVN\",\n SWE = \"SWE\",\n SWZ = \"SWZ\",\n SXM = \"SXM\",\n SYC = \"SYC\",\n SYR = \"SYR\",\n TCA = \"TCA\",\n TCD = \"TCD\",\n TGO = \"TGO\",\n THA = \"THA\",\n TJK = \"TJK\",\n TKL = \"TKL\",\n TKM = \"TKM\",\n TLS = \"TLS\",\n TON = \"TON\",\n TTO = \"TTO\",\n TUN = \"TUN\",\n TUR = \"TUR\",\n TUV = \"TUV\",\n TWN = \"TWN\",\n TZA = \"TZA\",\n UGA = \"UGA\",\n UKR = \"UKR\",\n UMI = \"UMI\",\n URY = \"URY\",\n USA = \"USA\",\n UZB = \"UZB\",\n VAT = \"VAT\",\n VCT = \"VCT\",\n VEN = \"VEN\",\n VGB = \"VGB\",\n VIR = \"VIR\",\n VNM = \"VNM\",\n VUT = \"VUT\",\n WLF = \"WLF\",\n WSM = \"WSM\",\n XKX = \"XKX\",\n YEM = \"YEM\",\n ZAF = \"ZAF\",\n ZMB = \"ZMB\",\n ZWE = \"ZWE\",\n}\n\nexport enum OnfidoAlpha2CountryCode {\n ABW = \"AW\",\n AFG = \"AF\",\n AGO = \"AO\",\n AIA = \"AI\",\n ALA = \"AX\",\n ALB = \"AL\",\n AND = \"AD\",\n ARE = \"AE\",\n ARG = \"AR\",\n ARM = \"AM\",\n ASM = \"AS\",\n ATA = \"AQ\",\n ATF = \"TF\",\n ATG = \"AG\",\n AUS = \"AU\",\n AUT = \"AT\",\n AZE = \"AZ\",\n BDI = \"BI\",\n BEL = \"BE\",\n BEN = \"BJ\",\n BES = \"BQ\",\n BFA = \"BF\",\n BGD = \"BD\",\n BGR = \"BG\",\n BHR = \"BH\",\n BHS = \"BS\",\n BIH = \"BA\",\n BLM = \"BL\",\n BLR = \"BY\",\n BLZ = \"BZ\",\n BMU = \"BM\",\n BOL = \"BO\",\n BRA = \"BR\",\n BRB = \"BB\",\n BRN = \"BN\",\n BTN = \"BT\",\n BVT = \"BV\",\n BWA = \"BW\",\n CAF = \"CF\",\n CAN = \"CA\",\n CCK = \"CC\",\n CHE = \"CH\",\n CHL = \"CL\",\n CHN = \"CN\",\n CIV = \"CI\",\n CMR = \"CM\",\n COD = \"CD\",\n COG = \"CG\",\n COK = \"CK\",\n COL = \"CO\",\n COM = \"KM\",\n CPV = \"CV\",\n CRI = \"CR\",\n CUB = \"CU\",\n CUW = \"CW\",\n CXR = \"CX\",\n CYM = \"KY\",\n CYP = \"CY\",\n CZE = \"CZ\",\n DEU = \"DE\",\n DJI = \"DJ\",\n DMA = \"DM\",\n DNK = \"DK\",\n DOM = \"DO\",\n DZA = \"DZ\",\n ECU = \"EC\",\n EGY = \"EG\",\n ERI = \"ER\",\n ESH = \"EH\",\n ESP = \"ES\",\n EST = \"EE\",\n ETH = \"ET\",\n FIN = \"FI\",\n FJI = \"FJ\",\n FLK = \"FK\",\n FRA = \"FR\",\n FRO = \"FO\",\n FSM = \"FM\",\n GAB = \"GA\",\n GBR = \"GB\",\n GEO = \"GE\",\n GGY = \"GG\",\n GHA = \"GH\",\n GIB = \"GI\",\n GIN = \"GN\",\n GLP = \"GP\",\n GMB = \"GM\",\n GNB = \"GW\",\n GNQ = \"GQ\",\n GRC = \"GR\",\n GRD = \"GD\",\n GRL = \"GL\",\n GTM = \"GT\",\n GUF = \"GF\",\n GUM = \"GU\",\n GUY = \"GY\",\n HKG = \"HK\",\n HMD = \"HM\",\n HND = \"HN\",\n HRV = \"HR\",\n HTI = \"HT\",\n HUN = \"HU\",\n IDN = \"ID\",\n IMN = \"IM\",\n IND = \"IN\",\n IOT = \"IO\",\n IRL = \"IE\",\n IRN = \"IR\",\n IRQ = \"IQ\",\n ISL = \"IS\",\n ISR = \"IL\",\n ITA = \"IT\",\n JAM = \"JM\",\n JEY = \"JE\",\n JOR = \"JO\",\n JPN = \"JP\",\n KAZ = \"KZ\",\n KEN = \"KE\",\n KGZ = \"KG\",\n KHM = \"KH\",\n KIR = \"KI\",\n KNA = \"KN\",\n KOR = \"KR\",\n KWT = \"KW\",\n LAO = \"LA\",\n LBN = \"LB\",\n LBR = \"LR\",\n LBY = \"LY\",\n LCA = \"LC\",\n LIE = \"LI\",\n LKA = \"LK\",\n LSO = \"LS\",\n LTU = \"LT\",\n LUX = \"LU\",\n LVA = \"LV\",\n MAC = \"MO\",\n MAF = \"MF\",\n MAR = \"MA\",\n MCO = \"MC\",\n MDA = \"MD\",\n MDG = \"MG\",\n MDV = \"MV\",\n MEX = \"MX\",\n MHL = \"MH\",\n MKD = \"MK\",\n MLI = \"ML\",\n MLT = \"MT\",\n MMR = \"MM\",\n MNE = \"ME\",\n MNG = \"MN\",\n MNP = \"MP\",\n MOZ = \"MZ\",\n MSR = \"MS\",\n MTQ = \"MQ\",\n MUS = \"MU\",\n MWI = \"MW\",\n MYS = \"MY\",\n MYT = \"YT\",\n NAM = \"NA\",\n NCL = \"NC\",\n NER = \"NE\",\n NFK = \"NF\",\n NGA = \"NG\",\n NIC = \"NI\",\n NIU = \"NU\",\n NLD = \"NL\",\n NOR = \"NO\",\n NPL = \"NP\",\n NRU = \"NR\",\n NZL = \"NZ\",\n OMN = \"OM\",\n PAK = \"PK\",\n PAN = \"PA\",\n PCN = \"PN\",\n PER = \"PE\",\n PHL = \"PH\",\n PLW = \"PW\",\n PNG = \"PG\",\n POL = \"PL\",\n PRI = \"PR\",\n PRK = \"KP\",\n PRT = \"PT\",\n PRY = \"PY\",\n PSE = \"PS\",\n PYF = \"PF\",\n QAT = \"QA\",\n REU = \"RE\",\n RKS = \"XK\",\n ROU = \"RO\",\n RUS = \"RU\",\n RWA = \"RW\",\n SAU = \"SA\",\n SDN = \"SD\",\n SEN = \"SN\",\n SGP = \"SG\",\n SGS = \"GS\",\n SHN = \"SH\",\n SJM = \"SJ\",\n SLB = \"SB\",\n SLE = \"SL\",\n SLV = \"SV\",\n SMR = \"SM\",\n SOM = \"SO\",\n SPM = \"PM\",\n SRB = \"RS\",\n SSD = \"SS\",\n STP = \"ST\",\n SUR = \"SR\",\n SVK = \"SK\",\n SVN = \"SI\",\n SWE = \"SE\",\n SWZ = \"SZ\",\n SXM = \"SX\",\n SYC = \"SC\",\n SYR = \"SY\",\n TCA = \"TC\",\n TCD = \"TD\",\n TGO = \"TG\",\n THA = \"TH\",\n TJK = \"TJ\",\n TKL = \"TK\",\n TKM = \"TM\",\n TLS = \"TL\",\n TON = \"TO\",\n TTO = \"TT\",\n TUN = \"TN\",\n TUR = \"TR\",\n TUV = \"TV\",\n TWN = \"TW\",\n TZA = \"TZ\",\n UGA = \"UG\",\n UKR = \"UA\",\n UMI = \"UM\",\n URY = \"UY\",\n USA = \"US\",\n UZB = \"UZ\",\n VAT = \"VA\",\n VCT = \"VC\",\n VEN = \"VE\",\n VGB = \"VG\",\n VIR = \"VI\",\n VNM = \"VN\",\n VUT = \"VU\",\n WLF = \"WF\",\n WSM = \"WS\",\n XKX = \"XK\",\n YEM = \"YE\",\n ZAF = \"ZA\",\n ZMB = \"ZM\",\n ZWE = \"ZW\",\n}\n","import React from 'react';\nimport {View} from 'react-native';\nimport lodashGet from 'lodash/get';\nimport _ from 'underscore';\nimport {withOnyx} from 'react-native-onyx';\nimport FullscreenLoadingIndicator from '../../components/FullscreenLoadingIndicator';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport * as BankAccounts from '../../libs/actions/BankAccounts';\nimport styles from '../../styles/styles';\nimport TextLink from '../../components/TextLink';\nimport withLocalize, {withLocalizePropTypes} from '../../components/withLocalize';\nimport compose from '../../libs/compose';\nimport Text from '../../components/Text';\nimport FormAlertWithSubmitButton from '../../components/FormAlertWithSubmitButton';\nimport FormScrollView from '../../components/FormScrollView';\nimport walletOnfidoDataPropTypes from './walletOnfidoDataPropTypes';\nimport * as ErrorUtils from '../../libs/ErrorUtils';\nimport FixedFooter from '../../components/FixedFooter';\n\nconst propTypes = {\n /** Stores various information used to build the UI and call any APIs */\n walletOnfidoData: walletOnfidoDataPropTypes,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n walletOnfidoData: {\n applicantID: '',\n sdkToken: '',\n loading: false,\n errors: {},\n fixableErrors: [],\n hasAcceptedPrivacyPolicy: false,\n },\n};\n\nclass OnfidoPrivacy extends React.Component {\n constructor(props) {\n super(props);\n\n this.openOnfidoFlow = this.openOnfidoFlow.bind(this);\n }\n\n openOnfidoFlow() {\n BankAccounts.openOnfidoFlow();\n }\n\n render() {\n let onfidoError = ErrorUtils.getLatestErrorMessage(this.props.walletOnfidoData) || '';\n const onfidoFixableErrors = lodashGet(this.props, 'walletOnfidoData.fixableErrors', []);\n onfidoError += !_.isEmpty(onfidoFixableErrors) ? `\\n${onfidoFixableErrors.join('\\n')}` : '';\n\n return (\n \n {!this.props.walletOnfidoData.hasAcceptedPrivacyPolicy ? (\n <>\n this.form = el}>\n \n \n {this.props.translate('onfidoStep.acceptTerms')}\n \n {this.props.translate('onfidoStep.facialScan')}\n \n {', '}\n \n {this.props.translate('common.privacy')}\n \n {` ${this.props.translate('common.and')} `}\n \n {this.props.translate('common.termsOfService')}\n \n .\n \n \n \n \n {\n this.form.scrollTo({y: 0, animated: true});\n }}\n message={onfidoError}\n isLoading={this.props.walletOnfidoData.isLoading}\n buttonText={onfidoError ? this.props.translate('onfidoStep.tryAgain') : this.props.translate('common.continue')}\n containerStyles={[styles.mh0, styles.mv0, styles.mb0]}\n />\n \n \n ) : null}\n {this.props.walletOnfidoData.hasAcceptedPrivacyPolicy && this.props.walletOnfidoData.isLoading ? : null}\n \n );\n }\n}\n\nOnfidoPrivacy.propTypes = propTypes;\nOnfidoPrivacy.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withOnyx({\n walletOnfidoData: {\n key: ONYXKEYS.WALLET_ONFIDO,\n\n // Let's get a new onfido token each time the user hits this flow (as it should only be once)\n initWithStoredValues: false,\n },\n }),\n)(OnfidoPrivacy);\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport {ScrollView} from 'react-native';\nimport styles from '../styles/styles';\n\nconst propTypes = {\n /** Form elements */\n children: PropTypes.node.isRequired,\n};\n\nconst FormScrollView = React.forwardRef((props, ref) => (\n \n {props.children}\n \n));\n\nFormScrollView.propTypes = propTypes;\nexport default FormScrollView;\n","import PropTypes from 'prop-types';\n\nexport default PropTypes.shape({\n /** Unique identifier returned from openOnfidoFlow then re-sent to ActivateWallet with Onfido response data */\n applicantID: PropTypes.string,\n\n /** Token used to initialize the Onfido SDK token */\n sdkToken: PropTypes.string,\n\n /** Loading state to provide feedback when we are waiting for a request to finish */\n loading: PropTypes.bool,\n\n /** Error message to inform the user of any problem that might occur */\n error: PropTypes.string,\n\n /** A list of Onfido errors that the user can fix in order to attempt the Onfido flow again */\n fixableErrors: PropTypes.arrayOf(PropTypes.string),\n\n /** Whether the user has accepted the privacy policy of Onfido or not */\n hasAcceptedPrivacyPolicy: PropTypes.bool,\n});\n","import _ from 'underscore';\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport {withOnyx} from 'react-native-onyx';\nimport {View} from 'react-native';\nimport moment from 'moment/moment';\nimport IdologyQuestions from './IdologyQuestions';\nimport ScreenWrapper from '../../components/ScreenWrapper';\nimport HeaderWithCloseButton from '../../components/HeaderWithCloseButton';\nimport withLocalize, {withLocalizePropTypes} from '../../components/withLocalize';\nimport Navigation from '../../libs/Navigation/Navigation';\nimport styles from '../../styles/styles';\nimport Text from '../../components/Text';\nimport CONST from '../../CONST';\nimport compose from '../../libs/compose';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport TextLink from '../../components/TextLink';\nimport TextInput from '../../components/TextInput';\nimport * as Wallet from '../../libs/actions/Wallet';\nimport * as ValidationUtils from '../../libs/ValidationUtils';\nimport * as LoginUtils from '../../libs/LoginUtils';\nimport * as ErrorUtils from '../../libs/ErrorUtils';\nimport AddressForm from '../ReimbursementAccount/AddressForm';\nimport DatePicker from '../../components/DatePicker';\nimport Form from '../../components/Form';\nimport withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsPropTypes, withCurrentUserPersonalDetailsDefaultProps} from '../../components/withCurrentUserPersonalDetails';\nimport * as PersonalDetails from '../../libs/actions/PersonalDetails';\nimport OfflineIndicator from '../../components/OfflineIndicator';\n\nconst propTypes = {\n ...withLocalizePropTypes,\n ...withCurrentUserPersonalDetailsPropTypes,\n\n /** Stores additional information about the additional details step e.g. loading state and errors with fields */\n walletAdditionalDetails: PropTypes.shape({\n /** Are we waiting for a response? */\n isLoading: PropTypes.bool,\n\n /** Which field needs attention? */\n errorFields: PropTypes.objectOf(PropTypes.bool),\n\n /** Any additional error message to show */\n errors: PropTypes.objectOf(PropTypes.string),\n\n /** Questions returned by Idology */\n questions: PropTypes.arrayOf(PropTypes.shape({\n prompt: PropTypes.string,\n type: PropTypes.string,\n answer: PropTypes.arrayOf(PropTypes.string),\n })),\n\n /** ExpectID ID number related to those questions */\n idNumber: PropTypes.string,\n\n /** Error code to determine additional behavior */\n errorCode: PropTypes.string,\n }),\n};\n\nconst defaultProps = {\n walletAdditionalDetails: {\n errorFields: {},\n isLoading: false,\n errors: {},\n questions: [],\n idNumber: '',\n errorCode: '',\n },\n ...withCurrentUserPersonalDetailsDefaultProps,\n};\n\nconst INPUT_IDS = {\n LEGAL_FIRST_NAME: 'legalFirstName',\n LEGAL_LAST_NAME: 'legalLastName',\n PHONE_NUMBER: 'phoneNumber',\n DOB: 'dob',\n SSN: 'ssn',\n ADDRESS: {\n street: 'addressStreet',\n city: 'addressCity',\n state: 'addressState',\n zipCode: 'addressZip',\n },\n};\n\nclass AdditionalDetailsStep extends React.Component {\n constructor(props) {\n super(props);\n\n this.activateWallet = this.activateWallet.bind(this);\n this.validate = this.validate.bind(this);\n\n this.errorTranslationKeys = {\n legalFirstName: 'bankAccount.error.firstName',\n legalLastName: 'bankAccount.error.lastName',\n phoneNumber: 'bankAccount.error.phoneNumber',\n dob: 'bankAccount.error.dob',\n age: 'bankAccount.error.age',\n ssn: 'bankAccount.error.ssnLast4',\n ssnFull9: 'additionalDetailsStep.ssnFull9Error',\n };\n\n this.fieldNameTranslationKeys = {\n legalFirstName: 'additionalDetailsStep.legalFirstNameLabel',\n legalLastName: 'additionalDetailsStep.legalLastNameLabel',\n addressStreet: 'common.personalAddress',\n phoneNumber: 'common.phoneNumber',\n dob: 'common.dob',\n ssn: 'common.ssnLast4',\n ssnFull9: 'common.ssnFull9',\n };\n\n this.minDate = moment().subtract(CONST.DATE_BIRTH.MAX_AGE, 'Y').toDate();\n this.maxDate = moment().subtract(CONST.DATE_BIRTH.MIN_AGE_FOR_PAYMENT, 'Y').toDate();\n }\n\n /**\n * @param {Object} values The values object is passed from Form.js and contains info for each form element that has an inputID\n * @returns {Object}\n */\n validate(values) {\n const errors = {};\n\n if (_.isEmpty(values[INPUT_IDS.LEGAL_FIRST_NAME])) {\n errors[INPUT_IDS.LEGAL_FIRST_NAME] = this.props.translate(this.errorTranslationKeys.legalFirstName);\n }\n\n if (_.isEmpty(values[INPUT_IDS.LEGAL_LAST_NAME])) {\n errors[INPUT_IDS.LEGAL_LAST_NAME] = this.props.translate(this.errorTranslationKeys.legalLastName);\n }\n\n if (!ValidationUtils.isValidPastDate(values[INPUT_IDS.DOB])) {\n ErrorUtils.addErrorMessage(errors, INPUT_IDS.DOB, this.props.translate(this.errorTranslationKeys.dob));\n } else if (!ValidationUtils.meetsAgeRequirements(values[INPUT_IDS.DOB])) {\n ErrorUtils.addErrorMessage(errors, INPUT_IDS.DOB, this.props.translate(this.errorTranslationKeys.age));\n }\n\n if (!ValidationUtils.isValidAddress(values[INPUT_IDS.ADDRESS.street]) || _.isEmpty(values[INPUT_IDS.ADDRESS.street])) {\n errors[INPUT_IDS.ADDRESS.street] = this.props.translate('bankAccount.error.addressStreet');\n }\n\n if (_.isEmpty(values[INPUT_IDS.ADDRESS.city])) {\n errors[INPUT_IDS.ADDRESS.city] = this.props.translate('bankAccount.error.addressCity');\n }\n\n if (_.isEmpty(values[INPUT_IDS.ADDRESS.state])) {\n errors[INPUT_IDS.ADDRESS.state] = this.props.translate('bankAccount.error.addressState');\n }\n\n if (!ValidationUtils.isValidZipCode(values[INPUT_IDS.ADDRESS.zipCode])) {\n errors[INPUT_IDS.ADDRESS.zipCode] = this.props.translate('bankAccount.error.zipCode');\n }\n\n if (!ValidationUtils.isValidUSPhone(values[INPUT_IDS.PHONE_NUMBER], true)) {\n errors[INPUT_IDS.PHONE_NUMBER] = this.props.translate(this.errorTranslationKeys.phoneNumber);\n }\n\n // this.props.walletAdditionalDetails stores errors returned by the server. If the server returns an SSN error\n // then the user needs to provide the full 9 digit SSN.\n if (this.props.walletAdditionalDetails.errorCode === CONST.WALLET.ERROR.SSN) {\n if (!ValidationUtils.isValidSSNFullNine(values[INPUT_IDS.SSN])) {\n errors[INPUT_IDS.SSN] = this.props.translate(this.errorTranslationKeys.ssnFull9);\n }\n } else if (!ValidationUtils.isValidSSNLastFour(values[INPUT_IDS.SSN])) {\n errors[INPUT_IDS.SSN] = this.props.translate(this.errorTranslationKeys.ssn);\n }\n\n return errors;\n }\n\n /**\n * @param {Object} values The values object is passed from Form.js and contains info for each form element that has an inputID\n */\n activateWallet(values) {\n const personalDetails = {\n phoneNumber: LoginUtils.getPhoneNumberWithoutUSCountryCodeAndSpecialChars(values[INPUT_IDS.PHONE_NUMBER]),\n legalFirstName: values[INPUT_IDS.LEGAL_FIRST_NAME],\n legalLastName: values[INPUT_IDS.LEGAL_LAST_NAME],\n addressStreet: values[INPUT_IDS.ADDRESS.street],\n addressCity: values[INPUT_IDS.ADDRESS.city],\n addressState: values[INPUT_IDS.ADDRESS.state],\n addressZip: values[INPUT_IDS.ADDRESS.zipCode],\n dob: values[INPUT_IDS.DOB],\n ssn: values[INPUT_IDS.SSN],\n };\n\n // Attempt to set the personal details\n Wallet.updatePersonalDetails(personalDetails);\n }\n\n render() {\n if (!_.isEmpty(this.props.walletAdditionalDetails.questions)) {\n return (\n \n Navigation.dismissModal()}\n shouldShowBackButton\n onBackButtonPress={() => Wallet.setAdditionalDetailsQuestions(null)}\n />\n \n \n );\n }\n const shouldAskForFullSSN = this.props.walletAdditionalDetails.errorCode === CONST.WALLET.ERROR.SSN;\n\n return (\n <>\n Navigation.dismissModal()}\n />\n \n \n {this.props.translate('additionalDetailsStep.helpText')}\n \n {this.props.translate('additionalDetailsStep.helpLink')}\n \n \n \n \n \n \n \n \n \n \n \n \n \n );\n }\n}\n\nAdditionalDetailsStep.propTypes = propTypes;\nAdditionalDetailsStep.defaultProps = defaultProps;\nexport default compose(\n withLocalize,\n withCurrentUserPersonalDetails,\n withOnyx({\n walletAdditionalDetails: {\n key: ONYXKEYS.WALLET_ADDITIONAL_DETAILS,\n },\n }),\n)(AdditionalDetailsStep);\n","import _ from 'underscore';\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport {\n View,\n} from 'react-native';\nimport {withOnyx} from 'react-native-onyx';\nimport RadioButtons from '../../components/RadioButtons';\nimport withLocalize, {withLocalizePropTypes} from '../../components/withLocalize';\nimport styles from '../../styles/styles';\nimport * as BankAccounts from '../../libs/actions/BankAccounts';\nimport Text from '../../components/Text';\nimport TextLink from '../../components/TextLink';\nimport FormScrollView from '../../components/FormScrollView';\nimport FormAlertWithSubmitButton from '../../components/FormAlertWithSubmitButton';\nimport compose from '../../libs/compose';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport OfflineIndicator from '../../components/OfflineIndicator';\nimport * as ErrorUtils from '../../libs/ErrorUtils';\nimport FixedFooter from '../../components/FixedFooter';\n\nconst MAX_SKIP = 1;\nconst SKIP_QUESTION_TEXT = 'Skip Question';\n\nconst propTypes = {\n ...withLocalizePropTypes,\n\n /** Questions returned by Idology */\n /** example: [{\"answer\":[\"1251\",\"6253\",\"113\",\"None of the above\",\"Skip Question\"],\"prompt\":\"Which number goes with your address on MASONIC AVE?\",\"type\":\"street.number.b\"}, ...] */\n questions: PropTypes.arrayOf(PropTypes.shape({\n prompt: PropTypes.string,\n type: PropTypes.string,\n answer: PropTypes.arrayOf(PropTypes.string),\n })),\n\n /** ID from Idology, referencing those questions */\n idNumber: PropTypes.string,\n\n walletAdditionalDetails: PropTypes.shape({\n /** Are we waiting for a response? */\n isLoading: PropTypes.bool,\n\n /** Any additional error message to show */\n errors: PropTypes.objectOf(PropTypes.string),\n\n /** What error do we need to handle */\n errorCode: PropTypes.string,\n }),\n};\n\nconst defaultProps = {\n questions: [],\n idNumber: '',\n walletAdditionalDetails: {},\n};\n\nclass IdologyQuestions extends React.Component {\n constructor(props) {\n super(props);\n this.submitAnswers = this.submitAnswers.bind(this);\n\n this.state = {\n /** Current question index to display. */\n questionNumber: 0,\n\n /** Should we hide the \"Skip question\" answer? Yes if the user already skipped MAX_SKIP questions. */\n hideSkip: false,\n\n /** Answers from the user */\n answers: [],\n\n /** Any error message */\n errorMessage: '',\n };\n }\n\n /**\n * Put question answer in the state.\n * @param {Number} questionIndex\n * @param {String} answer\n */\n chooseAnswer(questionIndex, answer) {\n this.setState((prevState) => {\n const answers = prevState.answers;\n const question = this.props.questions[questionIndex];\n answers[questionIndex] = {question: question.type, answer};\n return {\n answers,\n errorMessage: '',\n };\n });\n }\n\n /**\n * Show next question or send all answers for Idology verifications when we've answered enough\n */\n submitAnswers() {\n this.setState((prevState) => {\n // User must pick an answer\n if (!prevState.answers[prevState.questionNumber]) {\n return {\n errorMessage: this.props.translate('additionalDetailsStep.selectAnswer'),\n };\n }\n\n // Get the number of questions that were skipped by the user.\n const skippedQuestionsCount = _.filter(prevState.answers, answer => answer.answer === SKIP_QUESTION_TEXT).length;\n\n // We have enough answers, let's call expectID KBA to verify them\n if ((prevState.answers.length - skippedQuestionsCount) >= (this.props.questions.length - MAX_SKIP)) {\n const answers = prevState.answers;\n\n // Auto skip any remaining questions\n if (answers.length < this.props.questions.length) {\n for (let i = answers.length; i < this.props.questions.length; i++) {\n answers[i] = {question: this.props.questions[i].type, answer: SKIP_QUESTION_TEXT};\n }\n }\n\n BankAccounts.answerQuestionsForWallet(answers, this.props.idNumber);\n return {answers};\n }\n\n // Else, show next question\n return {\n questionNumber: prevState.questionNumber + 1,\n hideSkip: skippedQuestionsCount >= MAX_SKIP,\n };\n });\n }\n\n render() {\n const questionIndex = this.state.questionNumber;\n const question = this.props.questions[questionIndex] || {};\n const possibleAnswers = _.filter(_.map(question.answer, (answer) => {\n if (this.state.hideSkip && answer === SKIP_QUESTION_TEXT) {\n return;\n }\n\n return {\n label: answer,\n value: answer,\n };\n }));\n\n const errorMessage = ErrorUtils.getLatestErrorMessage(this.props.walletAdditionalDetails) || this.state.errorMessage;\n\n return (\n \n \n {this.props.translate('additionalDetailsStep.helpTextIdologyQuestions')}\n \n {this.props.translate('additionalDetailsStep.helpLink')}\n \n \n this.form = el}>\n \n {question.prompt}\n this.chooseAnswer(questionIndex, answer)}\n />\n \n \n \n {\n this.form.scrollTo({y: 0, animated: true});\n }}\n message={errorMessage}\n isLoading={this.props.walletAdditionalDetails.isLoading}\n buttonText={this.props.translate('common.saveAndContinue')}\n containerStyles={[styles.mh0, styles.mv0, styles.mb0]}\n />\n \n \n \n );\n }\n}\n\nIdologyQuestions.propTypes = propTypes;\nIdologyQuestions.defaultProps = defaultProps;\nexport default compose(\n withLocalize,\n withOnyx({\n walletAdditionalDetails: {\n key: ONYXKEYS.WALLET_ADDITIONAL_DETAILS,\n },\n }),\n)(IdologyQuestions);\n","import React from 'react';\nimport {View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport _ from 'underscore';\nimport RadioButtonWithLabel from './RadioButtonWithLabel';\nimport styles from '../styles/styles';\n\nconst propTypes = {\n /** List of choices to display via radio buttons */\n items: PropTypes.arrayOf(PropTypes.shape({\n label: PropTypes.string.isRequired,\n value: PropTypes.string.isRequired,\n })).isRequired,\n\n /** Callback to fire when selecting a radio button */\n onPress: PropTypes.func.isRequired,\n};\n\nclass RadioButtons extends React.Component {\n constructor(props) {\n super(props);\n\n this.state = {\n checkedValue: '',\n };\n }\n\n render() {\n return (\n \n {_.map(this.props.items, item => (\n {\n this.setState({checkedValue: item.value});\n return this.props.onPress(item.value);\n }}\n label={item.label}\n />\n ))}\n \n );\n }\n}\n\nRadioButtons.propTypes = propTypes;\n\nexport default RadioButtons;\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport {View, TouchableOpacity} from 'react-native';\nimport _ from 'underscore';\nimport styles from '../styles/styles';\nimport RadioButton from './RadioButton';\nimport Text from './Text';\nimport FormHelpMessage from './FormHelpMessage';\n\nconst propTypes = {\n /** Whether the radioButton is checked */\n isChecked: PropTypes.bool.isRequired,\n\n /** Called when the radioButton or label is pressed */\n onPress: PropTypes.func.isRequired,\n\n /** Container styles */\n style: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.object), PropTypes.object]),\n\n /** Text that appears next to check box */\n label: PropTypes.string,\n\n /** Component to display for label */\n LabelComponent: PropTypes.func,\n\n /** Should the input be styled for errors */\n hasError: PropTypes.bool,\n\n /** Error text to display */\n errorText: PropTypes.string,\n};\n\nconst defaultProps = {\n style: [],\n label: undefined,\n LabelComponent: undefined,\n hasError: false,\n errorText: '',\n};\n\nconst RadioButtonWithLabel = (props) => {\n const LabelComponent = props.LabelComponent;\n const defaultStyles = [styles.flexRow, styles.alignItemsCenter];\n const wrapperStyles = _.isArray(props.style) ? [...defaultStyles, ...props.style] : [...defaultStyles, props.style];\n\n if (!props.label && !LabelComponent) {\n throw new Error('Must provide at least label or LabelComponent prop');\n }\n return (\n <>\n \n \n props.onPress()}\n style={[\n styles.ml3,\n styles.pr2,\n styles.w100,\n styles.flexRow,\n styles.flexWrap,\n styles.flexShrink1,\n styles.alignItemsCenter,\n ]}\n >\n {Boolean(props.label) && (\n \n {props.label}\n \n )}\n {Boolean(LabelComponent) && ()}\n \n \n \n \n );\n};\n\nRadioButtonWithLabel.propTypes = propTypes;\nRadioButtonWithLabel.defaultProps = defaultProps;\nRadioButtonWithLabel.displayName = 'RadioButtonWithLabel';\n\nexport default RadioButtonWithLabel;\n","import React from 'react';\nimport {View, Pressable} from 'react-native';\nimport PropTypes from 'prop-types';\nimport styles from '../styles/styles';\nimport Icon from './Icon';\nimport * as Expensicons from './Icon/Expensicons';\n\nconst propTypes = {\n /** Whether radioButton is checked */\n isChecked: PropTypes.bool.isRequired,\n\n /** A function that is called when the box/label is pressed */\n onPress: PropTypes.func.isRequired,\n\n /** Should the input be styled for errors */\n hasError: PropTypes.bool,\n\n /** Should the input be disabled */\n disabled: PropTypes.bool,\n};\n\nconst defaultProps = {\n hasError: false,\n disabled: false,\n};\n\nconst RadioButton = props => (\n \n \n \n \n \n);\n\nRadioButton.propTypes = propTypes;\nRadioButton.defaultProps = defaultProps;\nRadioButton.displayName = 'RadioButton';\n\nexport default RadioButton;\n","import React from 'react';\nimport {View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport TextInput from '../../components/TextInput';\nimport AddressSearch from '../../components/AddressSearch';\nimport styles from '../../styles/styles';\nimport CONST from '../../CONST';\nimport StatePicker from '../../components/StatePicker';\n\nconst propTypes = {\n\n /** Translate key for Street name */\n streetTranslationKey: PropTypes.string.isRequired,\n\n /** Callback fired when a field changes. Passes args as {[fieldName]: val} */\n onFieldChange: PropTypes.func,\n\n /** Default values */\n defaultValues: PropTypes.shape({\n /** Address street field */\n street: PropTypes.string,\n\n /** Address city field */\n city: PropTypes.string,\n\n /** Address state field */\n state: PropTypes.string,\n\n /** Address zip code field */\n zipCode: PropTypes.string,\n }),\n\n /** Form values */\n values: PropTypes.shape({\n /** Address street field */\n street: PropTypes.string,\n\n /** Address city field */\n city: PropTypes.string,\n\n /** Address state field */\n state: PropTypes.string,\n\n /** Address zip code field */\n zipCode: PropTypes.string,\n }),\n\n /** Any errors that can arise from form validation */\n errors: PropTypes.shape({\n street: PropTypes.bool,\n city: PropTypes.bool,\n state: PropTypes.bool,\n zipCode: PropTypes.bool,\n }),\n\n /** The map for inputID of the inputs */\n inputKeys: PropTypes.shape({\n street: PropTypes.string,\n city: PropTypes.string,\n state: PropTypes.string,\n zipCode: PropTypes.string,\n }),\n\n /** Saves a draft of the input value when used in a form */\n shouldSaveDraft: PropTypes.bool,\n\n /** Returns translated string for given locale and phrase */\n translate: PropTypes.func.isRequired,\n};\n\nconst defaultProps = {\n values: {\n street: undefined,\n city: undefined,\n state: undefined,\n zipCode: undefined,\n },\n defaultValues: {\n street: undefined,\n city: undefined,\n state: undefined,\n zipCode: undefined,\n },\n errors: {},\n inputKeys: {\n street: '',\n city: '',\n state: '',\n zipCode: '',\n },\n shouldSaveDraft: false,\n onFieldChange: () => {},\n};\n\nconst AddressForm = props => (\n <>\n \n \n \n props.onFieldChange({city: value})}\n errorText={props.errors.city ? props.translate('bankAccount.error.addressCity') : ''}\n containerStyles={[styles.mt4]}\n />\n \n props.onFieldChange({state: value})}\n errorText={props.errors.state ? props.translate('bankAccount.error.addressState') : ''}\n />\n \n props.onFieldChange({zipCode: value})}\n errorText={props.errors.zipCode ? props.translate('bankAccount.error.zipCode') : ''}\n maxLength={CONST.BANK_ACCOUNT.MAX_LENGTH.ZIP_CODE}\n hint={props.translate('common.zipCodeExampleFormat', {zipSampleFormat: CONST.COUNTRY_ZIP_REGEX_DATA.US.samples})}\n />\n \n);\n\nAddressForm.propTypes = propTypes;\nAddressForm.defaultProps = defaultProps;\nAddressForm.displayName = 'AddressForm';\nexport default AddressForm;\n","import React from 'react';\n// eslint-disable-next-line no-restricted-imports\nimport {Button, View, Keyboard} from 'react-native';\nimport RNDatePicker from '@react-native-community/datetimepicker';\nimport moment from 'moment';\nimport _ from 'underscore';\nimport compose from '../../libs/compose';\nimport TextInput from '../TextInput';\nimport withLocalize, {withLocalizePropTypes} from '../withLocalize';\nimport Popover from '../Popover';\nimport CONST from '../../CONST';\nimport styles from '../../styles/styles';\nimport themeColors from '../../styles/themes/default';\nimport {propTypes, defaultProps} from './datepickerPropTypes';\nimport withKeyboardState, {keyboardStatePropTypes} from '../withKeyboardState';\n\nconst datepickerPropTypes = {\n ...propTypes,\n ...withLocalizePropTypes,\n ...keyboardStatePropTypes,\n};\n\nclass DatePicker extends React.Component {\n constructor(props) {\n super(props);\n\n this.state = {\n isPickerVisible: false,\n selectedDate: props.value || props.defaultValue ? moment(props.value || props.defaultValue).toDate() : new Date(),\n };\n\n this.showPicker = this.showPicker.bind(this);\n this.reset = this.reset.bind(this);\n this.selectDate = this.selectDate.bind(this);\n this.updateLocalDate = this.updateLocalDate.bind(this);\n }\n\n showPicker() {\n this.initialValue = this.state.selectedDate;\n\n // Opens the popover only after the keyboard is hidden to avoid a \"blinking\" effect where the keyboard was on iOS\n // See https://github.com/Expensify/App/issues/14084 for more context\n if (!this.props.isKeyboardShown) {\n this.setState({isPickerVisible: true});\n return;\n }\n const listener = Keyboard.addListener('keyboardDidHide', () => {\n this.setState({isPickerVisible: true});\n listener.remove();\n });\n Keyboard.dismiss();\n }\n\n /**\n * Reset the date spinner to the initial value\n */\n reset() {\n this.setState({selectedDate: this.initialValue});\n }\n\n /**\n * Accept the current spinner changes, close the spinner and propagate the change\n * to the parent component (props.onInputChange)\n */\n selectDate() {\n this.setState({isPickerVisible: false});\n const asMoment = moment(this.state.selectedDate, true);\n this.props.onInputChange(asMoment.format(CONST.DATE.MOMENT_FORMAT_STRING));\n }\n\n /**\n * @param {Event} event\n * @param {Date} selectedDate\n */\n updateLocalDate(event, selectedDate) {\n this.setState({selectedDate});\n }\n\n render() {\n const dateAsText = this.props.value || this.props.defaultValue ? moment(this.props.value || this.props.defaultValue).format(CONST.DATE.MOMENT_FORMAT_STRING) : '';\n return (\n <>\n {\n if (!_.isFunction(this.props.innerRef)) {\n return;\n }\n if (el && el.focus && typeof el.focus === 'function') {\n let inputRef = {...el};\n inputRef = {...inputRef, focus: this.showPicker};\n this.props.innerRef(inputRef);\n return;\n }\n\n this.props.innerRef(el);\n }}\n />\n \n \n \n \n \n \n \n \n );\n }\n}\n\nDatePicker.propTypes = datepickerPropTypes;\nDatePicker.defaultProps = defaultProps;\n\n/**\n * We're applying localization here because we present a modal (with buttons) ourselves\n * Furthermore we're passing the locale down so that the modal and the date spinner are in the same\n * locale. Otherwise the spinner would be present in the system locale and it would be weird if it happens\n * that the modal buttons are in one locale (app) while the (spinner) month names are another (system)\n */\nexport default compose(\n withLocalize,\n withKeyboardState,\n)(React.forwardRef((props, ref) => (\n /* eslint-disable-next-line react/jsx-props-no-spreading */\n \n)));\n","import RNDateTimePicker from './datetimepicker';\n\nexport default RNDateTimePicker;\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 * This is a controlled component version of RNDateTimePicker\n *\n * @format\n * @flow strict-local\n */\nimport RNDateTimePicker from './picker';\nimport {toMilliseconds} from './utils';\nimport {IOS_DISPLAY, MODE_DATE} from './constants';\nimport invariant from 'invariant';\nimport React, {useEffect, useState} from 'react';\nimport {getPickerHeightStyle} from './layoutUtilsIOS';\nimport {Platform, StyleSheet} from 'react-native';\n\nimport type {\n Event,\n NativeRef,\n IOSNativeProps,\n DatePickerOptions,\n IOSDisplay,\n} from './types';\n\nconst getDisplaySafe = (display: IOSDisplay) => {\n const majorVersionIOS = parseInt(Platform.Version, 10);\n if (display === IOS_DISPLAY.inline && majorVersionIOS < 14) {\n // inline is available since 14.0\n return IOS_DISPLAY.spinner;\n }\n if (majorVersionIOS < 14) {\n // NOTE this should compare against 13.4, not 14 according to https://developer.apple.com/documentation/uikit/uidatepickerstyle/uidatepickerstylecompact?changes=latest_minor&language=objc\n // but UIDatePickerStyleCompact does not seem to work prior to 14\n // only the spinner display (UIDatePickerStyleWheels) is thus available below 14\n return IOS_DISPLAY.spinner;\n }\n\n return display;\n};\n\nexport default function Picker({\n value,\n locale,\n maximumDate,\n minimumDate,\n style,\n testID,\n mode,\n minuteInterval,\n timeZoneOffsetInMinutes,\n textColor,\n themeVariant,\n onChange,\n disabled = false,\n ...otherProps\n}: IOSNativeProps) {\n const [heightStyle, setHeightStyle] = useState(undefined);\n const _picker: NativeRef = React.useRef();\n const display = getDisplaySafe(otherProps.display);\n\n useEffect(\n function ensureNativeIsInSyncWithJS() {\n const {current} = _picker;\n\n if (value && onChange && current) {\n const timestamp = value.getTime();\n current.setNativeProps({\n date: timestamp,\n });\n }\n },\n [onChange, value],\n );\n\n useEffect(\n function ensureCorrectHeight() {\n const height = getPickerHeightStyle(display, mode);\n if (height instanceof Promise) {\n height.then((measuredStyle) => setHeightStyle(measuredStyle));\n } else {\n setHeightStyle(height);\n }\n },\n [display, mode],\n );\n\n const _onChange = (event: Event) => {\n const timestamp = event.nativeEvent.timestamp;\n let date;\n\n if (timestamp) {\n date = new Date(timestamp);\n }\n\n onChange && onChange(event, date);\n };\n\n invariant(value, 'A date or time should be specified as `value`.');\n\n if (!heightStyle) {\n // wait for height to be available in state\n return null;\n }\n\n const dates: DatePickerOptions = {value, maximumDate, minimumDate};\n toMilliseconds(dates, 'value', 'minimumDate', 'maximumDate');\n\n return (\n true}\n onResponderTerminationRequest={() => false}\n displayIOS={display}\n disabled={disabled === true}\n />\n );\n}\n\nPicker.defaultProps = {\n mode: MODE_DATE,\n display: IOS_DISPLAY.default,\n};\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 * @format\n * @flow strict-local\n */\nimport {requireNativeComponent} from 'react-native';\n\nimport type {RCTDateTimePickerNative} from './types';\n\nexport default ((requireNativeComponent(\n 'RNDateTimePicker',\n): any): RCTDateTimePickerNative);\n","/**\n * @format\n * @flow strict-local\n */\nexport const MODE_DATE = 'date';\nexport const MODE_TIME = 'time';\nexport const MODE_DATETIME = 'datetime';\n\nexport const DISPLAY_DEFAULT = 'default';\nexport const DISPLAY_SPINNER = 'spinner';\nexport const DISPLAY_CLOCK = 'clock';\nexport const DISPLAY_CALENDAR = 'calendar';\nexport const MIN_MS = 60000;\n\n// TODO vonovak potentially replace the above string consts with this object\nexport const ANDROID_DISPLAY = Object.freeze({\n default: 'default',\n spinner: 'spinner',\n clock: 'clock',\n calendar: 'calendar',\n});\n\nexport const ANDROID_MODE = Object.freeze({\n date: 'date',\n time: 'time',\n});\n\nexport const IOS_MODE = Object.freeze({\n date: 'date',\n time: 'time',\n datetime: 'datetime',\n countdown: 'countdown',\n});\n\nexport const IOS_DISPLAY = Object.freeze({\n default: 'default',\n spinner: 'spinner',\n compact: 'compact',\n inline: 'inline',\n});\n\nexport const DAY_OF_WEEK = Object.freeze({\n Sunday: 0,\n Monday: 1,\n Tuesday: 2,\n Wednesday: 3,\n Thursday: 4,\n Friday: 5,\n Saturday: 6,\n});\n\nexport const DATE_SET_ACTION = 'dateSetAction';\nexport const TIME_SET_ACTION = 'timeSetAction';\nexport const DISMISS_ACTION = 'dismissedAction';\n\nexport const NEUTRAL_BUTTON_LABEL = 'neutralButtonLabel';\nexport const NEUTRAL_BUTTON_ACTION = 'neutralButtonAction';\n","import {NativeModules, StyleSheet} from 'react-native';\nimport {IOS_DISPLAY, IOS_MODE} from './constants';\nimport type {IOSDisplay, IOSMode} from './types';\n\nconst inlineHeightForDatePicker = 318.5;\nconst inlineHeightForTimePicker = 49.5;\nconst compactHeight = 34.5;\n\n// NOTE these styles are only supported from ios 14\n// the numbers may not be 100% accurate but were measured by calling `layoutIfNeeded`\n// while the proper mode and preferredDatePickerStyle were set in the native module\nconst styles = StyleSheet.create({\n [`${IOS_DISPLAY.inline}_${IOS_MODE.date}`]: {\n height: inlineHeightForDatePicker + inlineHeightForTimePicker,\n },\n [`${IOS_DISPLAY.inline}_${IOS_MODE.time}`]: {\n height: inlineHeightForTimePicker,\n },\n [`${IOS_DISPLAY.inline}_${IOS_MODE.datetime}`]: {\n height: inlineHeightForDatePicker + inlineHeightForTimePicker * 2,\n },\n compact: {\n height: compactHeight,\n },\n default: {\n // this is for spinner style (UIDatePickerStyleWheels) or countdown mode\n height: 216,\n },\n});\n\nfunction getHeightStyleFromKnowValues(display, mode) {\n if (display === IOS_DISPLAY.compact) {\n return styles.compact;\n }\n const key = `${display}_${mode}`;\n const maybeKnownStyle = styles[key];\n return maybeKnownStyle || styles.default;\n}\n\nexport function getPickerHeightStyle(\n display: IOSDisplay,\n mode: IOSMode,\n): {|height: number|} | Promise<{|height: number|}> {\n if (display === IOS_DISPLAY.default && mode !== IOS_MODE.countdown) {\n // when display is UIDatePickerStyleAutomatic, ios will \"Automatically pick the best style available for the current platform & mode.\"\n // because we don't know what that is going to be, we need to ask native for it\n // TODO vonovak this value could be cached\n return NativeModules.RNDateTimePickerManager.getDefaultDisplayValue({\n mode,\n }).then(({determinedDisplayValue}) => {\n return getHeightStyleFromKnowValues(determinedDisplayValue, mode);\n });\n }\n return getHeightStyleFromKnowValues(display, mode);\n}\n","/**\n * @format\n * @flow strict-local\n */\nimport type {DatePickerOptions, TimePickerOptions} from './types';\n\n/**\n * Convert a Date to a timestamp.\n */\nexport function toMilliseconds(\n options: DatePickerOptions | TimePickerOptions,\n ...keys: Array\n) {\n keys.forEach(function each(key) {\n const value = options[key];\n\n // Is it a Date object?\n if (Object.prototype.toString.call(value) === '[object Date]') {\n options[key] = value.getTime();\n }\n });\n}\n","import PropTypes from 'prop-types';\nimport {\n propTypes as fieldPropTypes,\n defaultProps as defaultFieldPropTypes,\n} from '../TextInput/baseTextInputPropTypes';\nimport CONST from '../../CONST';\n\nconst propTypes = {\n ...fieldPropTypes,\n\n /**\n * The datepicker supports any value that `moment` can parse.\n * `onInputChange` would always be called with a Date (or null)\n */\n value: PropTypes.oneOfType([PropTypes.instanceOf(Date), PropTypes.string]),\n\n /**\n * The datepicker supports any defaultValue that `moment` can parse.\n * `onInputChange` would always be called with a Date (or null)\n */\n defaultValue: PropTypes.oneOfType([PropTypes.instanceOf(Date), PropTypes.string]),\n\n /** The earliest date allowed to select */\n minDate: PropTypes.instanceOf(Date),\n\n /** The latest date allowed to select */\n maxDate: PropTypes.instanceOf(Date),\n};\n\nconst defaultProps = {\n ...defaultFieldPropTypes,\n value: undefined,\n minDate: new Date(CONST.DATE.MIN_DATE),\n maxDate: new Date(CONST.DATE.MAX_DATE),\n};\n\nexport {propTypes, defaultProps};\n","import React from 'react';\nimport {ScrollView} from 'react-native';\nimport {withOnyx} from 'react-native-onyx';\nimport HeaderWithCloseButton from '../../components/HeaderWithCloseButton';\nimport Navigation from '../../libs/Navigation/Navigation';\nimport withLocalize, {withLocalizePropTypes} from '../../components/withLocalize';\nimport styles from '../../styles/styles';\nimport * as BankAccounts from '../../libs/actions/BankAccounts';\nimport TextLink from '../../components/TextLink';\nimport compose from '../../libs/compose';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport CheckboxWithLabel from '../../components/CheckboxWithLabel';\nimport Text from '../../components/Text';\nimport ShortTermsForm from './TermsPage/ShortTermsForm';\nimport LongTermsForm from './TermsPage/LongTermsForm';\nimport FormAlertWithSubmitButton from '../../components/FormAlertWithSubmitButton';\nimport walletTermsPropTypes from './walletTermsPropTypes';\nimport * as ErrorUtils from '../../libs/ErrorUtils';\n\nconst propTypes = {\n /** Comes from Onyx. Information about the terms for the wallet */\n walletTerms: walletTermsPropTypes,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n walletTerms: {},\n};\n\nclass TermsStep extends React.Component {\n constructor(props) {\n super(props);\n\n this.toggleDisclosure = this.toggleDisclosure.bind(this);\n this.togglePrivacyPolicy = this.togglePrivacyPolicy.bind(this);\n this.state = {\n hasAcceptedDisclosure: false,\n hasAcceptedPrivacyPolicyAndWalletAgreement: false,\n error: false,\n };\n }\n\n clearError() {\n if (!this.state.hasAcceptedDisclosure || !this.state.hasAcceptedPrivacyPolicyAndWalletAgreement) {\n return;\n }\n\n this.setState({error: false});\n }\n\n toggleDisclosure() {\n this.setState(prevState => ({hasAcceptedDisclosure: !prevState.hasAcceptedDisclosure}), () => this.clearError());\n }\n\n togglePrivacyPolicy() {\n this.setState(prevState => ({\n hasAcceptedPrivacyPolicyAndWalletAgreement: !prevState.hasAcceptedPrivacyPolicyAndWalletAgreement,\n }), () => this.clearError());\n }\n\n render() {\n const errorMessage = this.state.error ? this.props.translate('common.error.acceptTerms') : (ErrorUtils.getLatestErrorMessage(this.props.walletTerms) || '');\n return (\n <>\n Navigation.dismissModal()}\n />\n \n \n \n (\n \n {`${this.props.translate('termsStep.haveReadAndAgree')}`}\n \n {`${this.props.translate('termsStep.electronicDisclosures')}.`}\n \n \n )}\n />\n (\n \n {`${this.props.translate('termsStep.agreeToThe')} `}\n\n \n {`${this.props.translate('common.privacy')} `}\n \n\n {`${this.props.translate('common.and')} `}\n\n \n {`${this.props.translate('termsStep.walletAgreement')}.`}\n \n \n )}\n />\n {\n if (!this.state.hasAcceptedDisclosure\n || !this.state.hasAcceptedPrivacyPolicyAndWalletAgreement) {\n this.setState({error: true});\n return;\n }\n\n this.setState({error: false});\n BankAccounts.acceptWalletTerms({\n hasAcceptedTerms: this.state.hasAcceptedDisclosure\n && this.state.hasAcceptedPrivacyPolicyAndWalletAgreement,\n chatReportID: this.props.walletTerms.chatReportID,\n });\n }}\n message={errorMessage}\n isAlertVisible={this.state.error || Boolean(errorMessage)}\n containerStyles={[styles.mh0, styles.mv4]}\n />\n \n \n );\n }\n}\n\nTermsStep.propTypes = propTypes;\nTermsStep.defaultProps = defaultProps;\nexport default compose(\n withLocalize,\n withOnyx({\n walletTerms: {\n key: ONYXKEYS.WALLET_TERMS,\n },\n }),\n)(TermsStep);\n","import React from 'react';\nimport {View} from 'react-native';\nimport styles from '../../../styles/styles';\nimport Text from '../../../components/Text';\nimport * as Localize from '../../../libs/Localize';\nimport CONST from '../../../CONST';\nimport TextLink from '../../../components/TextLink';\n\nconst ShortTermsForm = () => (\n <>\n \n {Localize.translateLocal('termsStep.shortTermsForm.expensifyPaymentsAccount')}\n \n\n \n \n \n \n {Localize.translateLocal('termsStep.monthlyFee')}\n \n \n {Localize.translateLocal('termsStep.feeAmountZero')}\n \n \n \n \n \n {Localize.translateLocal('termsStep.shortTermsForm.perPurchase')}\n \n \n {Localize.translateLocal('termsStep.feeAmountZero')}\n \n \n \n \n\n \n \n \n {Localize.translateLocal('termsStep.shortTermsForm.atmWithdrawal')}\n \n \n {Localize.translateLocal('common.na')}\n \n \n \n {Localize.translateLocal('termsStep.shortTermsForm.inNetwork')}\n \n \n \n {Localize.translateLocal('common.na')}\n \n \n \n {Localize.translateLocal('termsStep.shortTermsForm.outOfNetwork')}\n \n \n \n \n \n \n {Localize.translateLocal('termsStep.shortTermsForm.cashReload')}\n \n \n {Localize.translateLocal('common.na')}\n \n \n \n \n\n \n \n \n \n {Localize.translateLocal('termsStep.shortTermsForm.atmBalanceInquiry')}\n {' '}\n {Localize.translateLocal('termsStep.shortTermsForm.inOrOutOfNetwork')}\n \n \n \n \n {Localize.translateLocal('common.na')}\n \n \n \n\n \n \n \n \n {Localize.translateLocal('termsStep.shortTermsForm.customerService')}\n {' '}\n {Localize.translateLocal('termsStep.shortTermsForm.automatedOrLive')}\n \n \n \n \n {Localize.translateLocal('termsStep.feeAmountZero')}\n \n \n \n\n \n \n \n \n {Localize.translateLocal('termsStep.inactivity')}\n {' '}\n {Localize.translateLocal('termsStep.shortTermsForm.afterTwelveMonths')}\n \n \n \n \n {Localize.translateLocal('termsStep.feeAmountZero')}\n \n \n \n\n \n \n \n {Localize.translateLocal('termsStep.shortTermsForm.weChargeOneFee')}\n \n \n\n \n \n \n \n {Localize.translateLocal('termsStep.electronicFundsWithdrawal')}\n {' '}\n {Localize.translateLocal('termsStep.shortTermsForm.instant')}\n \n \n \n \n {Localize.translateLocal('termsStep.electronicFundsInstantFee')}\n {' '}\n \n \n {Localize.translateLocal('termsStep.shortTermsForm.electronicFundsInstantFeeMin')}\n \n \n \n \n \n {Localize.translateLocal('termsStep.noOverdraftOrCredit')}\n \n \n {Localize.translateLocal('termsStep.shortTermsForm.fdicInsurance')}\n \n \n {Localize.translateLocal('termsStep.shortTermsForm.generalInfo')}\n {' '}\n \n {CONST.TERMS.CFPB_PREPAID}\n \n .\n \n \n {Localize.translateLocal('termsStep.shortTermsForm.conditionsDetails')}\n {' '}\n \n {CONST.TERMS.USE_EXPENSIFY_FEES}\n \n {' '}\n {Localize.translateLocal('termsStep.shortTermsForm.conditionsPhone')}\n \n \n \n \n);\n\nShortTermsForm.displayName = 'ShortTermsForm';\n\nexport default ShortTermsForm;\n","import _ from 'underscore';\nimport React from 'react';\nimport {View} from 'react-native';\nimport styles from '../../../styles/styles';\nimport Text from '../../../components/Text';\nimport CollapsibleSection from '../../../components/CollapsibleSection';\nimport * as Localize from '../../../libs/Localize';\nimport CONST from '../../../CONST';\nimport Icon from '../../../components/Icon';\nimport * as Expensicons from '../../../components/Icon/Expensicons';\nimport TextLink from '../../../components/TextLink';\n\nconst termsData = [\n {\n title: Localize.translateLocal('termsStep.longTermsForm.openingAccountTitle'),\n rightText: Localize.translateLocal('termsStep.feeAmountZero'),\n details: Localize.translateLocal('termsStep.longTermsForm.openingAccountDetails'),\n },\n {\n title: Localize.translateLocal('termsStep.monthlyFee'),\n rightText: Localize.translateLocal('termsStep.feeAmountZero'),\n details: Localize.translateLocal('termsStep.longTermsForm.monthlyFeeDetails'),\n },\n {\n title: Localize.translateLocal('termsStep.longTermsForm.customerServiceTitle'),\n subTitle: Localize.translateLocal('termsStep.longTermsForm.automated'),\n rightText: Localize.translateLocal('termsStep.feeAmountZero'),\n details: Localize.translateLocal('termsStep.longTermsForm.customerServiceDetails'),\n },\n {\n title: Localize.translateLocal('termsStep.longTermsForm.customerServiceTitle'),\n subTitle: Localize.translateLocal('termsStep.longTermsForm.liveAgent'),\n rightText: Localize.translateLocal('termsStep.feeAmountZero'),\n details: Localize.translateLocal('termsStep.longTermsForm.customerServiceDetails'),\n },\n {\n title: Localize.translateLocal('termsStep.inactivity'),\n rightText: Localize.translateLocal('termsStep.feeAmountZero'),\n details: Localize.translateLocal('termsStep.longTermsForm.inactivityDetails'),\n },\n {\n title: Localize.translateLocal('termsStep.longTermsForm.sendingFundsTitle'),\n rightText: Localize.translateLocal('termsStep.feeAmountZero'),\n details: Localize.translateLocal('termsStep.longTermsForm.sendingFundsDetails'),\n },\n {\n title: Localize.translateLocal('termsStep.electronicFundsWithdrawal'),\n subTitle: Localize.translateLocal('termsStep.standard'),\n rightText: Localize.translateLocal('termsStep.feeAmountZero'),\n details: Localize.translateLocal('termsStep.longTermsForm.electronicFundsStandardDetails'),\n },\n {\n title: Localize.translateLocal('termsStep.electronicFundsWithdrawal'),\n subTitle: Localize.translateLocal('termsStep.longTermsForm.instant'),\n rightText: Localize.translateLocal('termsStep.electronicFundsInstantFee'),\n subRightText: Localize.translateLocal('termsStep.longTermsForm.electronicFundsInstantFeeMin'),\n details: Localize.translateLocal('termsStep.longTermsForm.electronicFundsInstantDetails'),\n },\n];\n\nconst getLongTermsSections = () => _.map(termsData, (section, index) => (\n // eslint-disable-next-line react/no-array-index-key\n \n \n \n {section.title}\n {\n Boolean(section.subTitle)\n && (\n \n {section.subTitle}\n \n )\n }\n \n \n \n {section.rightText}\n \n {\n Boolean(section.subRightText)\n && (\n \n {section.subRightText}\n \n )\n }\n \n \n \n {section.details}\n \n \n));\n\nconst LongTermsForm = () => (\n <>\n \n {getLongTermsSections()}\n \n\n \n {Localize.translateLocal('termsStep.longTermsForm.fdicInsuranceBancorp')}\n {' '}\n {CONST.TERMS.FDIC_PREPAID}\n {' '}\n {Localize.translateLocal('termsStep.longTermsForm.fdicInsuranceBancorp2')}\n \n \n {Localize.translateLocal('termsStep.noOverdraftOrCredit')}\n \n \n {Localize.translateLocal('termsStep.longTermsForm.contactExpensifyPayments')}\n {' '}\n {CONST.EMAIL.CONCIERGE}\n {' '}\n {Localize.translateLocal('termsStep.longTermsForm.contactExpensifyPayments2')}\n {' '}\n {CONST.NEW_EXPENSIFY_URL}\n .\n \n \n {Localize.translateLocal('termsStep.longTermsForm.generalInformation')}\n {' '}\n {CONST.TERMS.CFPB_PREPAID}\n {'. '}\n {Localize.translateLocal('termsStep.longTermsForm.generalInformation2')}\n {' '}\n {CONST.TERMS.CFPB_COMPLAINT}\n .\n \n\n \n \n \n {Localize.translateLocal('termsStep.longTermsForm.printerFriendlyView')}\n \n \n \n);\n\nLongTermsForm.displayName = 'LongTermsForm';\nexport default LongTermsForm;\n","import React from 'react';\nimport {View, TouchableOpacity} from 'react-native';\nimport PropTypes from 'prop-types';\nimport Collapsible from './Collapsible';\nimport Text from '../Text';\nimport styles from '../../styles/styles';\nimport Icon from '../Icon';\nimport * as Expensicons from '../Icon/Expensicons';\n\nconst propTypes = {\n /** Title of the Collapsible section */\n title: PropTypes.string.isRequired,\n\n /** Children to display inside the Collapsible component */\n children: PropTypes.node.isRequired,\n};\n\nclass CollapsibleSection extends React.Component {\n constructor(props) {\n super(props);\n this.toggleSection = this.toggleSection.bind(this);\n this.state = {\n isExpanded: false,\n };\n }\n\n /**\n * Expands/collapses the section\n */\n toggleSection() {\n this.setState(prevState => ({\n isExpanded: !prevState.isExpanded,\n }));\n }\n\n render() {\n const src = this.state.isExpanded ? Expensicons.UpArrow : Expensicons.DownArrow;\n\n return (\n \n \n \n {this.props.title}\n \n \n \n \n\n \n \n {this.props.children}\n \n \n \n );\n }\n}\n\nCollapsibleSection.propTypes = propTypes;\nexport default CollapsibleSection;\n","import CollapsibleRN from 'react-native-collapsible';\nimport PropTypes from 'prop-types';\nimport React from 'react';\n\nconst propTypes = {\n /** Whether the section should start expanded. False by default */\n isOpened: PropTypes.bool,\n\n /** Children to display inside the Collapsible component */\n children: PropTypes.node.isRequired,\n};\n\nconst defaultProps = {\n isOpened: false,\n};\n\nconst Collapsible = props => (\n \n {props.children}\n \n);\n\nCollapsible.displayName = 'Collapsible';\nCollapsible.propTypes = propTypes;\nCollapsible.defaultProps = defaultProps;\nexport default Collapsible;\n","import React, { Component } from 'react';\nimport { Animated, Easing } from 'react-native';\n\nconst ANIMATED_EASING_PREFIXES = ['easeInOut', 'easeOut', 'easeIn'];\n\nexport default class Collapsible extends Component {\n static defaultProps = {\n align: 'top',\n collapsed: true,\n collapsedHeight: 0,\n enablePointerEvents: false,\n duration: 300,\n easing: 'easeOutCubic',\n onAnimationEnd: () => null,\n renderChildrenCollapsed: true,\n };\n\n constructor(props) {\n super(props);\n this.state = {\n measuring: false,\n measured: false,\n height: new Animated.Value(props.collapsedHeight),\n contentHeight: 0,\n animating: false,\n };\n }\n\n componentDidUpdate(prevProps) {\n if (prevProps.collapsed !== this.props.collapsed) {\n this.setState({ measured: false }, () =>\n this._componentDidUpdate(prevProps)\n );\n } else {\n this._componentDidUpdate(prevProps);\n }\n }\n\n componentWillUnmount() {\n this.unmounted = true;\n }\n\n _componentDidUpdate(prevProps) {\n if (prevProps.collapsed !== this.props.collapsed) {\n this._toggleCollapsed(this.props.collapsed);\n } else if (\n this.props.collapsed &&\n prevProps.collapsedHeight !== this.props.collapsedHeight\n ) {\n this.state.height.setValue(this.props.collapsedHeight);\n }\n }\n\n contentHandle = null;\n\n _handleRef = (ref) => {\n this.contentHandle = ref;\n };\n\n _measureContent(callback) {\n this.setState(\n {\n measuring: true,\n },\n () => {\n requestAnimationFrame(() => {\n if (!this.contentHandle) {\n this.setState(\n {\n measuring: false,\n },\n () => callback(this.props.collapsedHeight)\n );\n } else {\n let ref;\n if (typeof this.contentHandle.measure === 'function') {\n ref = this.contentHandle;\n } else {\n ref = this.contentHandle.getNode();\n }\n ref.measure((x, y, width, height) => {\n this.setState(\n {\n measuring: false,\n measured: true,\n contentHeight: height,\n },\n () => callback(height)\n );\n });\n }\n });\n }\n );\n }\n\n _toggleCollapsed(collapsed) {\n if (collapsed) {\n this._transitionToHeight(this.props.collapsedHeight);\n } else if (!this.contentHandle) {\n if (this.state.measured) {\n this._transitionToHeight(this.state.contentHeight);\n }\n return;\n } else {\n this._measureContent((contentHeight) => {\n this._transitionToHeight(contentHeight);\n });\n }\n }\n\n _transitionToHeight(height) {\n const { duration } = this.props;\n let easing = this.props.easing;\n if (typeof easing === 'string') {\n let prefix;\n let found = false;\n for (let i = 0; i < ANIMATED_EASING_PREFIXES.length; i++) {\n prefix = ANIMATED_EASING_PREFIXES[i];\n if (easing.substr(0, prefix.length) === prefix) {\n easing =\n easing.substr(prefix.length, 1).toLowerCase() +\n easing.substr(prefix.length + 1);\n prefix = prefix.substr(4, 1).toLowerCase() + prefix.substr(5);\n easing = Easing[prefix](Easing[easing || 'ease']);\n found = true;\n break;\n }\n }\n if (!found) {\n easing = Easing[easing];\n }\n if (!easing) {\n throw new Error('Invalid easing type \"' + this.props.easing + '\"');\n }\n }\n\n if (this._animation) {\n this._animation.stop();\n }\n this.setState({ animating: true });\n this._animation = Animated.timing(this.state.height, {\n useNativeDriver: false,\n toValue: height ? height : 0,\n duration,\n easing,\n }).start(() => {\n if (this.unmounted) {\n return;\n }\n this.setState({ animating: false }, () => {\n if (this.unmounted) {\n return;\n }\n this.props.onAnimationEnd();\n });\n });\n }\n\n _handleLayoutChange = (event) => {\n const contentHeight = event.nativeEvent.layout.height;\n if (\n this.state.animating ||\n this.props.collapsed ||\n this.state.measuring ||\n this.state.contentHeight === contentHeight\n ) {\n return;\n }\n\n this.state.height.setValue(contentHeight);\n this.setState({ contentHeight });\n };\n\n render() {\n const {\n collapsed,\n enablePointerEvents,\n renderChildrenCollapsed,\n } = this.props;\n const {\n height,\n contentHeight,\n measuring,\n measured,\n animating,\n } = this.state;\n const hasKnownHeight = !measuring && (measured || collapsed);\n const style = hasKnownHeight && {\n overflow: 'hidden',\n height: height,\n };\n const contentStyle = {};\n if (measuring) {\n contentStyle.position = 'absolute';\n contentStyle.opacity = 0;\n } else if (this.props.align === 'center') {\n contentStyle.transform = [\n {\n translateY: height.interpolate({\n inputRange: [0, contentHeight],\n outputRange: [contentHeight / -2, 0],\n }),\n },\n ];\n } else if (this.props.align === 'bottom') {\n contentStyle.transform = [\n {\n translateY: height.interpolate({\n inputRange: [0, contentHeight],\n outputRange: [-contentHeight, 0],\n }),\n },\n ];\n }\n if (animating) {\n contentStyle.height = contentHeight;\n }\n const shouldRenderChildren =\n renderChildrenCollapsed ||\n ((!collapsed || (collapsed && animating)) &&\n (animating || measuring || measured));\n\n return (\n \n \n {shouldRenderChildren && this.props.children}\n \n \n );\n }\n}\n","import PropTypes from 'prop-types';\n\n/** Prop types related to the Terms step of KYC flow */\nexport default PropTypes.shape({\n /** Any error message to show */\n errors: PropTypes.objectOf(PropTypes.string),\n\n /** When the user accepts the Wallet's terms in order to pay an IOU, this is the ID of the chatReport the IOU is linked to */\n chatReportID: PropTypes.string,\n});\n","import React from 'react';\nimport {withOnyx} from 'react-native-onyx';\nimport FireworksAnimation from '../../../assets/animations/Fireworks.json';\nimport ReviewingBankInfoAnimation from '../../../assets/animations/ReviewingBankInfo.json';\nimport HeaderWithCloseButton from '../../components/HeaderWithCloseButton';\nimport Navigation from '../../libs/Navigation/Navigation';\nimport withLocalize, {withLocalizePropTypes} from '../../components/withLocalize';\nimport userWalletPropTypes from './userWalletPropTypes';\nimport CONST from '../../CONST';\nimport * as PaymentMethods from '../../libs/actions/PaymentMethods';\nimport compose from '../../libs/compose';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport walletTermsPropTypes from './walletTermsPropTypes';\nimport ConfirmationPage from '../../components/ConfirmationPage';\n\nconst propTypes = {\n ...withLocalizePropTypes,\n\n /** The user's wallet */\n userWallet: userWalletPropTypes,\n\n /** Information about the user accepting the terms for payments */\n walletTerms: walletTermsPropTypes,\n};\n\nconst defaultProps = {\n userWallet: {},\n walletTerms: {\n chatReportID: 0,\n },\n};\n\nconst ActivateStep = (props) => {\n const isGoldWallet = props.userWallet.tierName === CONST.WALLET.TIER_NAME.GOLD;\n const animation = isGoldWallet ? FireworksAnimation : ReviewingBankInfoAnimation;\n const continueButtonText = props.walletTerms.chatReportID ? props.translate('activateStep.continueToPayment') : props.translate('activateStep.continueToTransfer');\n\n return (\n <>\n Navigation.dismissModal()}\n shouldShowBackButton\n onBackButtonPress={() => Navigation.goBack()}\n />\n \n \n );\n};\n\nActivateStep.propTypes = propTypes;\nActivateStep.defaultProps = defaultProps;\nActivateStep.displayName = 'ActivateStep';\n\nexport default compose(\n withLocalize,\n withOnyx({\n walletTerms: {\n key: ONYXKEYS.WALLET_TERMS,\n },\n }),\n)(ActivateStep);\n","{\"v\":\"5.9.6\",\"fr\":24,\"ip\":0,\"op\":128,\"w\":280,\"h\":280,\"nm\":\"Comp 1\",\"ddd\":0,\"assets\":[{\"id\":\"comp_0\",\"nm\":\"Expensify-Reviewing-120522-kjs-1\",\"fr\":24,\"layers\":[{\"ddd\":0,\"ind\":2,\"ty\":3,\"nm\":\"magnifying glass ol peg\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.899,\"y\":0},\"o\":{\"x\":0.333,\"y\":0},\"t\":0,\"s\":[934.5,523,0],\"to\":[0.157,0,0],\"ti\":[-0.171,0,0]},{\"i\":{\"x\":0.667,\"y\":0.952},\"o\":{\"x\":0.333,\"y\":0.048},\"t\":10,\"s\":[934.993,523,0],\"to\":[10.919,0,0],\"ti\":[-10.92,0,0]},{\"i\":{\"x\":0.667,\"y\":1},\"o\":{\"x\":0.101,\"y\":1},\"t\":28,\"s\":[996.007,523,0],\"to\":[0.171,0,0],\"ti\":[-0.157,0,0]},{\"i\":{\"x\":0.667,\"y\":0.667},\"o\":{\"x\":0.333,\"y\":0.333},\"t\":38,\"s\":[996.5,523,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.888,\"y\":0},\"o\":{\"x\":0.333,\"y\":0},\"t\":41,\"s\":[996.5,523,0],\"to\":[-0.101,0.188,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.667,\"y\":0.95},\"o\":{\"x\":0.333,\"y\":0.05},\"t\":50,\"s\":[996.181,523.593,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.667,\"y\":1},\"o\":{\"x\":0.101,\"y\":1},\"t\":67,\"s\":[960.819,589.407,0],\"to\":[0,0,0],\"ti\":[0.1,-0.185,0]},{\"i\":{\"x\":0.667,\"y\":0.667},\"o\":{\"x\":0.333,\"y\":0.333},\"t\":77,\"s\":[960.5,590,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.889,\"y\":0},\"o\":{\"x\":0.333,\"y\":0},\"t\":80,\"s\":[960.5,590,0],\"to\":[-0.048,-0.123,0],\"ti\":[0.051,0.131,0]},{\"i\":{\"x\":0.667,\"y\":0.95},\"o\":{\"x\":0.333,\"y\":0.05},\"t\":89,\"s\":[960.352,589.619,0],\"to\":[-4.515,-11.634,0],\"ti\":[4.515,11.634,0]},{\"i\":{\"x\":0.667,\"y\":1},\"o\":{\"x\":0.1,\"y\":1},\"t\":115,\"s\":[934.648,523.381,0],\"to\":[-0.051,-0.131,0],\"ti\":[0.048,0.123,0]},{\"t\":125,\"s\":[934.5,523,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[50.5,49,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":128,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":3,\"ty\":3,\"nm\":\"mag glass handle peg\",\"parent\":2,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667],\"y\":[-2.273]},\"o\":{\"x\":[0.333],\"y\":[0]},\"t\":0,\"s\":[0]},{\"i\":{\"x\":[0.667],\"y\":[0.952]},\"o\":{\"x\":[0.333],\"y\":[0.048]},\"t\":10,\"s\":[-0.866]},{\"i\":{\"x\":[0.667],\"y\":[1]},\"o\":{\"x\":[0.333],\"y\":[3.273]},\"t\":28,\"s\":[-107.134]},{\"i\":{\"x\":[0.667],\"y\":[1]},\"o\":{\"x\":[0.333],\"y\":[0]},\"t\":38,\"s\":[-108]},{\"i\":{\"x\":[0.667],\"y\":[-1.942]},\"o\":{\"x\":[0.333],\"y\":[0]},\"t\":41,\"s\":[-108]},{\"i\":{\"x\":[0.667],\"y\":[0.95]},\"o\":{\"x\":[0.333],\"y\":[0.05]},\"t\":50,\"s\":[-107.204]},{\"i\":{\"x\":[0.667],\"y\":[1]},\"o\":{\"x\":[0.333],\"y\":[3.269]},\"t\":67,\"s\":[-19.51]},{\"i\":{\"x\":[0.667],\"y\":[1]},\"o\":{\"x\":[0.333],\"y\":[0]},\"t\":77,\"s\":[-18.714]},{\"i\":{\"x\":[0.667],\"y\":[-1.954]},\"o\":{\"x\":[0.333],\"y\":[0]},\"t\":80,\"s\":[-18.714]},{\"i\":{\"x\":[0.667],\"y\":[0.95]},\"o\":{\"x\":[0.333],\"y\":[0.05]},\"t\":89,\"s\":[-18.607]},{\"i\":{\"x\":[0.667],\"y\":[1]},\"o\":{\"x\":[0.333],\"y\":[3.282]},\"t\":115,\"s\":[-0.108]},{\"t\":125,\"s\":[0]}],\"ix\":10},\"p\":{\"a\":0,\"k\":[50.5,49,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[50.5,49,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":128,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":4,\"ty\":3,\"nm\":\"magnifying glass shine peg\",\"parent\":2,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[50.5,49,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[50.5,49,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":128,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":5,\"ty\":3,\"nm\":\"magnifying glass ul peg 2\",\"parent\":2,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[-2.463,49,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[50.5,49,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":128,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":6,\"ty\":4,\"nm\":\"magnifying glass ol Outlines 2\",\"parent\":2,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[288,105,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[960,540,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[2.841,-20.339],[20.339,2.841],[-2.841,20.339],[-20.339,-2.841]],\"o\":[[-2.841,20.339],[-20.339,-2.841],[2.841,-20.34],[20.34,2.841]],\"v\":[[36.828,5.144],[-5.144,36.828],[-36.828,-5.144],[5.144,-36.828]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[722.446,485.643],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[3.486,-24.958],[24.958,3.486],[-3.486,24.958],[-24.958,-3.486]],\"o\":[[-3.486,24.958],[-24.958,-3.486],[3.486,-24.958],[24.958,3.487]],\"v\":[[45.191,6.312],[-6.312,45.191],[-45.19,-6.313],[6.312,-45.191]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[722.446,485.643],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[7.071,-12.993],[15.178,-0.264],[5.535,14.426],[-13.988,9.919],[-12.417,-10.82]],\"o\":[[-5.553,13.91],[-15.764,0.274],[-6.247,-16.281],[13.537,-9.599],[10.449,9.106]],\"v\":[[34.266,13.544],[-0.348,37.053],[-34.648,12.721],[-20.793,-30.413],[23.884,-27.934]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ind\":1,\"ty\":\"sh\",\"ix\":2,\"ks\":{\"a\":0,\"k\":{\"i\":[[25.257,3.528],[3.527,-25.256],[-25.256,-3.527],[-3.528,25.256]],\"o\":[[-25.256,-3.528],[-3.528,25.257],[25.256,3.528],[3.528,-25.256]],\"v\":[[6.387,-45.73],[-45.73,-6.388],[-6.388,45.73],[45.73,6.388]],\"c\":true},\"ix\":2},\"nm\":\"Path 2\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"mm\",\"mm\":1,\"nm\":\"Merge Paths 1\",\"mn\":\"ADBE Vector Filter - Merge\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[1,0.901960844152,0.533333333333,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[722.61,485.504],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 3\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":3,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":0,\"op\":1512,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":7,\"ty\":4,\"nm\":\"mag glass handle Outlines\",\"parent\":3,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[288,105,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[960,540,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[-3.292,-4.361],[-4.36,3.292],[0,0]],\"o\":[[0,0],[-4.361,3.292],[3.291,4.36],[0,0],[0,0]],\"v\":[[14.736,-23.474],[-22.461,4.391],[-24.396,18.247],[-10.542,20.182],[27.688,-8.76]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[670.18,528.677],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[1.996,5.78],[0,0],[-4.675,-6.524],[-0.778,0.881]],\"o\":[[-6.007,-4.393],[0,0],[0,0],[3.157,5.13],[0.778,-0.88]],\"v\":[[28.38,-8.572],[15.149,-23.565],[-23.552,5.787],[-23.705,18.435],[-10.627,21.25]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.788235353956,0.501960784314,0,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[669.488,528.489],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":0,\"op\":1512,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":8,\"ty\":4,\"nm\":\"magnifying glass shine Outlines\",\"parent\":4,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[288,105,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[960,540,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[16.954,-13.615],[-3.426,0.413],[-3.406,0.546],[-3.484,0.387],[-0.767,3.42]],\"o\":[[-2.69,2.16],[3.425,-0.413],[3.461,-0.555],[3.483,-0.387],[0,0]],\"v\":[[-17.046,4.363],[-8.758,8.839],[1.229,6.186],[11.728,5.897],[19.737,0.175]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.870588295133,0.952941236309,0.968627510819,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[717.709,451.654],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":0,\"op\":128,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":9,\"ty\":4,\"nm\":\"magnifying glass ul Outlines 3\",\"parent\":2,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":50,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[288,105,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[960,540,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[2.862,-20.493],[20.493,2.863],[-2.863,20.493],[-20.493,-2.863]],\"o\":[[-2.862,20.493],[-20.493,-2.862],[2.862,-20.492],[20.492,2.862]],\"v\":[[37.105,5.183],[-5.183,37.105],[-37.105,-5.183],[5.183,-37.105]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.572549019608,0.941176530427,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[723.272,485.671],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":0,\"op\":128,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":10,\"ty\":4,\"nm\":\"magnifying glass ul Outlines 2\",\"parent\":2,\"td\":1,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[288,105,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[960,540,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[2.862,-20.493],[20.493,2.863],[-2.863,20.493],[-20.493,-2.863]],\"o\":[[-2.862,20.493],[-20.493,-2.862],[2.862,-20.492],[20.492,2.862]],\"v\":[[37.105,5.183],[-5.183,37.105],[-37.105,-5.183],[5.183,-37.105]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.572549019608,0.941176530427,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[723.272,485.671],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":0,\"op\":128,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":11,\"ty\":0,\"nm\":\"items\",\"tt\":1,\"refId\":\"comp_1\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[960,540,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[960,540,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[156.3,156.3,100],\"ix\":6,\"l\":2}},\"ao\":0,\"w\":1920,\"h\":1080,\"ip\":0,\"op\":128,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":12,\"ty\":0,\"nm\":\"items\",\"refId\":\"comp_1\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[960,540,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[960,540,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"w\":1920,\"h\":1080,\"ip\":0,\"op\":128,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":13,\"ty\":4,\"nm\":\"magnifying glass ul Outlines\",\"parent\":2,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[288,105,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[960,540,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[2.862,-20.493],[20.493,2.863],[-2.863,20.493],[-20.493,-2.863]],\"o\":[[-2.862,20.493],[-20.493,-2.862],[2.862,-20.492],[20.492,2.862]],\"v\":[[37.105,5.183],[-5.183,37.105],[-37.105,-5.183],[5.183,-37.105]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.572549019608,0.941176530427,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[723.272,485.671],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":0,\"op\":128,\"st\":0,\"ct\":1,\"bm\":0}]},{\"id\":\"comp_1\",\"nm\":\"items\",\"fr\":24,\"layers\":[{\"ddd\":0,\"ind\":1,\"ty\":3,\"nm\":\"bank2 peg\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[878.5,629,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[50.5,49,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.167,0.167,0.167],\"y\":[0.167,0.167,-16.667]},\"t\":0,\"s\":[10,10,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.833]},\"o\":{\"x\":[0.167,0.167,0.167],\"y\":[0.167,0.167,0.167]},\"t\":5,\"s\":[100,100,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,16]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":37,\"s\":[100,100,100]},{\"t\":42,\"s\":[10,10,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":43,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":2,\"ty\":3,\"nm\":\"bank5 peg\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[959.5,630,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[50.5,49,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.167,0.167,0.167],\"y\":[0.167,0.167,15]},\"t\":0,\"s\":[10,10,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.833]},\"o\":{\"x\":[0.167,0.167,0.167],\"y\":[0.167,0.167,0.167]},\"t\":5,\"s\":[100,100,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,16]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":37,\"s\":[100,100,100]},{\"t\":42,\"s\":[10,10,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":43,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":3,\"ty\":3,\"nm\":\"bank4 peg\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[1040.5,630,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[50.5,49,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.167,0.167,0.167],\"y\":[0.167,0.167,15]},\"t\":0,\"s\":[10,10,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.833]},\"o\":{\"x\":[0.167,0.167,0.167],\"y\":[0.167,0.167,0.167]},\"t\":5,\"s\":[100,100,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,16]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":37,\"s\":[100,100,100]},{\"t\":42,\"s\":[10,10,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":43,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":4,\"ty\":3,\"nm\":\"bank5 peg\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.667,\"y\":1},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":5,\"s\":[961.5,621,0],\"to\":[-6.917,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":10,\"s\":[920,621,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.333,\"y\":0},\"t\":32,\"s\":[920,621,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":37,\"s\":[961.5,621,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[50.5,49,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.167,0.167,0.167],\"y\":[0.167,0.167,-0.175]},\"t\":5,\"s\":[96,96,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.833]},\"o\":{\"x\":[0.167,0.167,0.167],\"y\":[0.167,0.167,0.167]},\"t\":10,\"s\":[100,100,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.825]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":32,\"s\":[100,100,100]},{\"t\":37,\"s\":[96,96,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":5,\"op\":38,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":5,\"ty\":3,\"nm\":\"bank6 peg\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.667,\"y\":1},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":5,\"s\":[959,622,0],\"to\":[6.667,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":10,\"s\":[999,622,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.333,\"y\":0},\"t\":32,\"s\":[999,622,0],\"to\":[0,0,0],\"ti\":[6.667,0,0]},{\"t\":37,\"s\":[959,622,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[50.5,49,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.167,0.167,0.167],\"y\":[0.167,0.167,-0.175]},\"t\":5,\"s\":[96,96,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.833]},\"o\":{\"x\":[0.167,0.167,0.167],\"y\":[0.167,0.167,0.167]},\"t\":10,\"s\":[100,100,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":32,\"s\":[100,100,100]},{\"t\":37,\"s\":[96,96,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":5,\"op\":38,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":6,\"ty\":3,\"nm\":\"bank1 peg\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.667,\"y\":1},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":7,\"s\":[959.5,518,0],\"to\":[0,-3,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":13,\"s\":[959.5,500,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.333,\"y\":0},\"t\":29,\"s\":[959.5,500,0],\"to\":[0,0,0],\"ti\":[0,-3,0]},{\"t\":35,\"s\":[959.5,518,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[50.5,49,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.167,0.167,0.167],\"y\":[0.167,0.167,0.278]},\"t\":7,\"s\":[59,59,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.833]},\"o\":{\"x\":[0.167,0.167,0.167],\"y\":[0.167,0.167,0.167]},\"t\":13,\"s\":[100,100,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":29,\"s\":[100,100,100]},{\"t\":35,\"s\":[59,59,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":7,\"op\":36,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":7,\"ty\":3,\"nm\":\"card1 peg\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667],\"y\":[1]},\"o\":{\"x\":[0.167],\"y\":[0.167]},\"t\":43,\"s\":[0]},{\"i\":{\"x\":[0.667],\"y\":[1]},\"o\":{\"x\":[0.333],\"y\":[0]},\"t\":48,\"s\":[-7]},{\"i\":{\"x\":[0.833],\"y\":[1]},\"o\":{\"x\":[0.333],\"y\":[0]},\"t\":54,\"s\":[0]},{\"i\":{\"x\":[0.652],\"y\":[1]},\"o\":{\"x\":[0.317],\"y\":[0]},\"t\":78,\"s\":[0]},{\"i\":{\"x\":[0.832],\"y\":[1]},\"o\":{\"x\":[0.368],\"y\":[0]},\"t\":81,\"s\":[0]},{\"t\":86,\"s\":[0]}],\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.667,\"y\":1},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":43,\"s\":[902.5,625,0],\"to\":[0.5,-2.333,0],\"ti\":[-0.5,1.167,0]},{\"i\":{\"x\":0.667,\"y\":1},\"o\":{\"x\":0.333,\"y\":0},\"t\":48,\"s\":[905.5,611,0],\"to\":[0.5,-1.167,0],\"ti\":[0,-1.167,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.333,\"y\":0.333},\"t\":54,\"s\":[905.5,618,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.819,\"y\":0},\"o\":{\"x\":0.317,\"y\":0},\"t\":78,\"s\":[905.5,618,0],\"to\":[-0.028,0.066,0],\"ti\":[0.037,-0.087,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.368,\"y\":0.115},\"t\":81,\"s\":[905.402,618.23,0],\"to\":[-0.622,1.452,0],\"ti\":[0.472,-1.101,0]},{\"t\":86,\"s\":[902.5,625,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[50.5,49,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.167,0.167,0.167],\"y\":[0.167,0.167,0]},\"t\":43,\"s\":[103,12,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":48,\"s\":[100,100,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":54,\"s\":[100,100,100]},{\"i\":{\"x\":[0.652,0.652,0.652],\"y\":[-0.923,-0.923,1]},\"o\":{\"x\":[0.317,0.317,0.317],\"y\":[0,0,0]},\"t\":78,\"s\":[100,100,100]},{\"i\":{\"x\":[0.832,0.832,0.832],\"y\":[0.892,0.892,1]},\"o\":{\"x\":[0.368,0.368,0.368],\"y\":[0.115,0.115,0]},\"t\":81,\"s\":[100.098,97.117,100]},{\"t\":86,\"s\":[103,12,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":43,\"op\":87,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":8,\"ty\":3,\"nm\":\"card2 peg\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667],\"y\":[1]},\"o\":{\"x\":[0.167],\"y\":[0.167]},\"t\":41,\"s\":[0]},{\"i\":{\"x\":[0.667],\"y\":[1]},\"o\":{\"x\":[0.333],\"y\":[0]},\"t\":47,\"s\":[-7]},{\"i\":{\"x\":[0.833],\"y\":[1]},\"o\":{\"x\":[0.333],\"y\":[0]},\"t\":52,\"s\":[0]},{\"i\":{\"x\":[0.652],\"y\":[1]},\"o\":{\"x\":[0.317],\"y\":[0]},\"t\":76,\"s\":[0]},{\"i\":{\"x\":[0.832],\"y\":[1]},\"o\":{\"x\":[0.368],\"y\":[0]},\"t\":79,\"s\":[0]},{\"t\":84,\"s\":[0]}],\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.667,\"y\":1},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":41,\"s\":[846.5,573,0],\"to\":[0.5,-3.667,0],\"ti\":[-0.5,2.667,0]},{\"i\":{\"x\":0.667,\"y\":1},\"o\":{\"x\":0.333,\"y\":0},\"t\":47,\"s\":[849.5,551,0],\"to\":[0.5,-2.667,0],\"ti\":[0,-1,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.333,\"y\":0.333},\"t\":52,\"s\":[849.5,557,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.82,\"y\":0},\"o\":{\"x\":0.317,\"y\":0},\"t\":76,\"s\":[849.5,557,0],\"to\":[-0.028,0.15,0],\"ti\":[0.037,-0.197,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.368,\"y\":0.115},\"t\":79,\"s\":[849.402,557.521,0],\"to\":[-0.622,3.316,0],\"ti\":[0.472,-2.517,0]},{\"t\":84,\"s\":[846.5,573,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[50.5,49,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.167,0.167,0.167],\"y\":[0.167,0.167,0]},\"t\":41,\"s\":[103,10,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":47,\"s\":[100,100,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":52,\"s\":[100,100,100]},{\"i\":{\"x\":[0.652,0.652,0.652],\"y\":[-0.923,-0.923,1]},\"o\":{\"x\":[0.317,0.317,0.317],\"y\":[0,0,0]},\"t\":76,\"s\":[100,100,100]},{\"i\":{\"x\":[0.832,0.832,0.832],\"y\":[0.892,0.892,1]},\"o\":{\"x\":[0.368,0.368,0.368],\"y\":[0.115,0.115,0]},\"t\":79,\"s\":[100.098,97.052,100]},{\"t\":84,\"s\":[103,10,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":41,\"op\":85,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":9,\"ty\":3,\"nm\":\"receipt roll peg\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":87,\"s\":[940.5,413,0],\"to\":[-14.167,3,0],\"ti\":[0.697,-25.63,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":92,\"s\":[861.5,452,0],\"to\":[-0.667,24.5,0],\"ti\":[0,-15.5,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":95,\"s\":[861.5,545,0],\"to\":[0,0,0],\"ti\":[0,15.583,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":120,\"s\":[861.5,614.5,0],\"to\":[0,-15.583,0],\"ti\":[-13.167,33.583,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":125,\"s\":[861.5,451.5,0],\"to\":[13.167,-33.583,0],\"ti\":[14.365,-3.042,0]},{\"t\":127,\"s\":[940.5,413,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[50.5,49,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.833]},\"o\":{\"x\":[0.167,0.167,0.167],\"y\":[0.167,0.167,0.167]},\"t\":87,\"s\":[22,22,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.833]},\"o\":{\"x\":[0.167,0.167,0.167],\"y\":[0.167,0.167,0.167]},\"t\":92,\"s\":[100,100,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.833]},\"o\":{\"x\":[0.167,0.167,0.167],\"y\":[0.167,0.167,0.167]},\"t\":95,\"s\":[100,100,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.833]},\"o\":{\"x\":[0.167,0.167,0.167],\"y\":[0.167,0.167,0.167]},\"t\":120,\"s\":[100,100,100]},{\"i\":{\"x\":[0.833,0.833,0.833],\"y\":[0.833,0.833,0.833]},\"o\":{\"x\":[0.167,0.167,0.167],\"y\":[0.167,0.167,0.167]},\"t\":125,\"s\":[100,100,100]},{\"t\":127,\"s\":[22,22,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":87,\"op\":128,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":10,\"ty\":3,\"nm\":\"receipt peg\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.667,\"y\":0.667},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":95,\"s\":[958.5,445,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.667,\"y\":0.667},\"o\":{\"x\":0.333,\"y\":0.333},\"t\":96,\"s\":[958.5,445,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":101,\"s\":[958.5,445,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[50.5,49,0],\"ix\":1,\"l\":2},\"s\":{\"a\":1,\"k\":[{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.167,0.167,0.167],\"y\":[0.167,0.167,0]},\"t\":95,\"s\":[100,100,100]},{\"i\":{\"x\":[0.667,0.667,0.667],\"y\":[1,1,1]},\"o\":{\"x\":[0.333,0.333,0.333],\"y\":[0,0,0]},\"t\":96,\"s\":[97,105,100]},{\"t\":101,\"s\":[100,100,100]}],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":92,\"op\":126,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":11,\"ty\":4,\"nm\":\"bank2 Outlines\",\"parent\":1,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[338,-183,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[960,540,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[654.22,642.81],[690.97,642.81]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[15.545,-7.38],[20.125,-7.38],[20.125,7.38],[-20.125,7.38],[-20.125,-7.38],[-15.885,-7.38],[0.345,-7.38]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[672.765,765.47],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[673.11,663.73],[673.11,757.88]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 3\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":3,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[688.31,663.61],[688.31,758.02]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 4\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":4,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[656.88,663.61],[656.88,757.88]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 5\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":5,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,-9.29],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,-9.29],[0,0]],\"v\":[[-18.375,-10.4],[-15.715,10.4],[0.515,10.4],[15.715,10.4],[18.375,-10.4]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[672.595,653.21],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 6\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":6,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,-9.29],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,-9.29]],\"v\":[[-18.375,-10.4],[18.375,-10.4],[15.715,10.4],[0.515,10.4],[-15.715,10.4]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.666666666667,0.827451040231,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[672.595,653.21],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 7\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":7,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[20.125,-7.38],[20.125,7.38],[-20.125,7.38],[-20.125,-7.38],[-15.885,-7.38],[0.345,-7.38],[15.545,-7.38]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.666666666667,0.827451040231,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[672.765,765.47],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 8\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":8,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[7.6,47.17],[7.6,47.24],[-7.6,47.24],[-7.6,47.03],[-7.6,-47.12],[-7.6,-47.24],[7.6,-47.24]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.87450986376,0.956862804936,0.972549079446,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[680.71,710.85],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 9\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":9,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[8.115,47.03],[8.115,47.24],[-8.115,47.24],[-8.115,47.03],[-8.115,-47.24],[8.115,-47.24],[8.115,-47.12]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.87450986376,0.956862804936,0.972549079446,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[664.995,710.85],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 10\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":10,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":0,\"op\":43,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":12,\"ty\":4,\"nm\":\"bank3 Outlines\",\"parent\":2,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[257,-184,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[960,540,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[735.46,642.81],[772.21,642.81]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[15.555,-7.38],[20.125,-7.38],[20.125,7.38],[-20.125,7.38],[-20.125,-7.38],[-15.885,-7.38],[0.355,-7.38]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[754.005,765.47],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0]],\"v\":[[754.36,663.29],[754.36,663.61],[754.36,758.09],[754.36,758.17]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 3\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":3,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[769.56,663.61],[769.56,758.02]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 4\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":4,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0]],\"v\":[[738.12,663.61],[738.12,758.09],[738.12,758.17]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 5\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":5,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,-9.29],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,-9.29],[0,0]],\"v\":[[-18.375,-10.4],[-15.715,10.4],[0.525,10.4],[15.725,10.4],[18.375,-10.4]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[753.835,653.21],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 6\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":6,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[-15.885,-7.38],[0.355,-7.38],[15.555,-7.38],[20.125,-7.38],[20.125,7.38],[-20.125,7.38],[-20.125,-7.38]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.666666666667,0.827451040231,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[754.005,765.47],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 7\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":7,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,-9.29]],\"o\":[[0,0],[0,-9.29],[0,0],[0,0],[0,0]],\"v\":[[0.525,10.4],[-15.715,10.4],[-18.375,-10.4],[18.375,-10.4],[15.725,10.4]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.666666666667,0.827451040231,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[753.835,653.21],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 8\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":8,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0]],\"v\":[[8.12,47.24],[-8.12,47.24],[-8.12,-47.24],[8.12,-47.24]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.87450986376,0.956862804936,0.972549079446,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[746.24,710.85],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 9\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":9,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[7.6,47.17],[7.6,47.24],[-7.6,47.24],[-7.6,-47.24],[7.6,-47.24]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.87450986376,0.956862804936,0.972549079446,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[761.96,710.85],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 10\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":10,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":0,\"op\":43,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":13,\"ty\":4,\"nm\":\"bank4 Outlines\",\"parent\":3,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[176,-184,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[960,540,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[816.27,642.81],[853.01,642.81]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":1,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[15.555,-7.38],[20.125,-7.38],[20.125,7.38],[-20.125,7.38],[-20.125,-7.38],[-15.885,-7.38],[0.355,-7.38]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[834.805,765.47],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[835.16,663.87],[835.16,757.74]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 3\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":3,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[850.36,663.61],[850.36,757.59]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 4\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":4,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[818.92,663.61],[818.92,757.88]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 5\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":5,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,-9.29],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,-9.29],[0,0]],\"v\":[[-18.37,-10.4],[-15.72,10.4],[0.52,10.4],[15.72,10.4],[18.37,-10.4]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[834.64,653.21],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 6\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":6,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,-9.29],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,-9.29]],\"v\":[[-18.37,-10.4],[18.37,-10.4],[15.72,10.4],[0.52,10.4],[-15.72,10.4]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.666666666667,0.827451040231,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[834.64,653.21],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 7\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":7,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[20.125,-7.38],[20.125,7.38],[-20.125,7.38],[-20.125,-7.38],[-15.885,-7.38],[0.355,-7.38],[15.555,-7.38]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.666666666667,0.827451040231,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[834.805,765.47],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 8\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":8,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[7.6,46.74],[7.6,47.24],[-7.6,47.24],[-7.6,46.89],[-7.6,-46.98],[-7.6,-47.24],[7.6,-47.24]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.87450986376,0.956862804936,0.972549079446,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[842.76,710.85],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 9\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":9,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[8.12,46.89],[8.12,47.24],[-8.12,47.24],[-8.12,47.03],[-8.12,-47.24],[8.12,-47.24],[8.12,-46.98]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.87450986376,0.956862804936,0.972549079446,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[827.04,710.85],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 10\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":10,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":0,\"op\":43,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":14,\"ty\":4,\"nm\":\"Shape Layer 2\",\"td\":1,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[960,540,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[0,0,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ty\":\"rc\",\"d\":1,\"s\":{\"a\":0,\"k\":[83.5,152],\"ix\":2},\"p\":{\"a\":0,\"k\":[0,0],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":4},\"nm\":\"Rectangle Path 1\",\"mn\":\"ADBE Vector Shape - Rect\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[1,1,1,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":1,\"lj\":1,\"ml\":4,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[1,0,0,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[-42.75,28],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Rectangle 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":5,\"op\":38,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":15,\"ty\":4,\"nm\":\"bank5 Outlines\",\"parent\":4,\"tt\":1,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[296,-175,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[960,540,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0]],\"v\":[[674.05,764.78],[674.05,744.64],[674.05,724.71],[674.05,642.81]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0]],\"v\":[[752.16,764.78],[752.16,744.64],[752.16,724.71],[752.16,642.81]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[752.16,642.81],[674.05,642.81]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 3\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":3,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[6.48,0],[2.12,-2.12],[0,-3.24],[0,0]],\"o\":[[0,0],[0,-6.48],[-3.24,0],[-2.13,2.12],[0,0],[0,0]],\"v\":[[11.73,24.795],[11.73,-13.055],[0,-24.795],[-8.29,-21.355],[-11.73,-13.055],[-11.73,24.355]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[713.77,699.475],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 4\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":4,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0]],\"v\":[[674.05,724.71],[702.04,724.71],[725.5,724.71],[752.16,724.71]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 5\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":5,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[674.05,744.64],[752.16,744.64]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 6\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":6,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[674.05,764.78],[752.16,764.78]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 7\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":7,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0]],\"v\":[[39.055,10.07],[-39.055,10.07],[-39.055,-10.07],[39.055,-10.07]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.666666666667,0.827451040231,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[713.105,754.71],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 8\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":8,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[39.055,-9.965],[39.055,9.965],[-39.055,9.965],[-39.055,-9.965],[-11.065,-9.965],[12.395,-9.965]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.666666666667,0.827451040231,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[713.105,734.675],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 9\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":9,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[-2.13,2.12],[-3.24,0],[0,-6.48]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,-3.24],[2.12,-2.12],[6.48,0],[0,0]],\"v\":[[11.73,24.575],[11.73,25.015],[-11.73,25.015],[-11.73,24.135],[-11.73,-13.275],[-8.29,-21.575],[0,-25.015],[11.73,-13.275]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[713.77,699.695],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 10\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":10,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[6.48,0],[2.12,-2.12],[0,-3.24],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,-6.48],[-3.24,0],[-2.13,2.12],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[39.055,-40.95],[39.055,40.95],[12.395,40.95],[12.395,40.51],[12.395,2.66],[0.665,-9.08],[-7.625,-5.64],[-11.065,2.66],[-11.065,40.07],[-11.065,40.95],[-39.055,40.95],[-39.055,-40.95]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.349019607843,0.662745098039,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[713.105,683.76],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 11\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":11,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":5,\"op\":38,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":16,\"ty\":4,\"nm\":\"Shape Layer 1\",\"td\":1,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[960,540,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[0,0,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ty\":\"rc\",\"d\":1,\"s\":{\"a\":0,\"k\":[82,146.5],\"ix\":2},\"p\":{\"a\":0,\"k\":[0,0],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":4},\"nm\":\"Rectangle Path 1\",\"mn\":\"ADBE Vector Shape - Rect\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[1,1,1,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":1,\"lj\":1,\"ml\":4,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[1,0,0,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[41.5,25.25],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Rectangle 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":5,\"op\":38,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":17,\"ty\":4,\"nm\":\"bank6 Outlines\",\"parent\":5,\"tt\":1,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[217,-176,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[960,540,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0]],\"v\":[[833.24,764.78],[833.24,744.64],[833.24,724.71],[833.24,642.81]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0]],\"v\":[[756.21,764.78],[756.21,744.64],[756.21,724.71],[756.21,642.81]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[756.21,642.81],[833.24,642.81]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 3\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":3,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[-6.48,0],[-2.12,-2.12],[0,-3.24],[0,0]],\"o\":[[0,0],[0,-6.48],[3.24,0],[2.13,2.12],[0,0],[0,0]],\"v\":[[-11.735,24.355],[-11.735,-13.055],[0.005,-24.795],[8.295,-21.355],[11.735,-13.055],[11.735,24.795]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[793.905,699.475],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 4\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":4,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0]],\"v\":[[756.21,724.71],[782.17,724.71],[805.64,724.71],[833.24,724.71]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 5\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":5,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[756.21,744.64],[833.24,744.64]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 6\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":6,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[756.21,764.78],[833.24,764.78]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 7\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":7,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0]],\"v\":[[38.515,10.07],[-38.515,10.07],[-38.515,-10.07],[38.515,-10.07]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.666666666667,0.827451040231,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[794.725,754.71],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 8\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":8,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[38.515,-9.965],[38.515,9.965],[-38.515,9.965],[-38.515,-9.965],[-12.555,-9.965],[10.915,-9.965]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.666666666667,0.827451040231,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[794.725,734.675],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 9\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":9,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[-6.48,0],[-2.12,-2.12],[0,-3.24]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,-6.48],[3.24,0],[2.13,2.12],[0,0]],\"v\":[[11.735,24.575],[11.735,25.015],[-11.735,25.015],[-11.735,24.135],[-11.735,-13.275],[0.005,-25.015],[8.295,-21.575],[11.735,-13.275]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[793.905,699.695],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 10\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":10,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0],[0,0],[2.13,2.12],[3.24,0],[0,-6.48],[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0],[0,-3.24],[-2.12,-2.12],[-6.48,0],[0,0],[0,0],[0,0],[0,0],[0,0]],\"v\":[[38.515,-40.95],[38.515,40.95],[10.915,40.95],[10.915,40.51],[10.915,2.66],[7.475,-5.64],[-0.815,-9.08],[-12.555,2.66],[-12.555,40.07],[-12.555,40.95],[-38.515,40.95],[-38.515,-40.95]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.349019607843,0.662745098039,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[794.725,683.76],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 11\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":11,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":5,\"op\":38,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":18,\"ty\":0,\"nm\":\"bank-top-comp\",\"parent\":6,\"refId\":\"comp_2\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[51,89,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[960,540,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"w\":1920,\"h\":1080,\"ip\":0,\"op\":128,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":19,\"ty\":4,\"nm\":\"card1 Outlines\",\"parent\":7,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[111,-83,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[960,540,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[4.072,0.006],[0,0],[-0.005,4.072],[0,0],[-4.072,-0.006],[0,0],[0.006,-4.071],[0,0]],\"o\":[[0,0],[-4.072,-0.006],[0,0],[0.006,-4.073],[0,0],[4.071,0.005],[0,0],[-0.005,4.072]],\"v\":[[27.908,11.434],[-27.94,11.354],[-35.303,3.971],[-35.292,-4.071],[-27.909,-11.434],[27.94,-11.354],[35.302,-3.972],[35.291,4.071]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1014.446,617.26],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-0.001,0.979],[0,0],[0.949,0.001],[0,0],[0.326,-0.432],[0,0],[0,-0.395],[0,0],[-0.2,-0.298],[0,0],[-0.565,0.002],[0,0]],\"o\":[[0,0],[0.002,-0.982],[0,0],[-0.529,-0.001],[0,0],[-0.235,0.311],[0,0],[0,0.362],[0,0],[0.322,0.481],[0,0],[0.945,-0.003]],\"v\":[[5.883,9.434],[5.908,-9.441],[4.193,-11.221],[-2.044,-11.23],[-3.4,-10.546],[-5.529,-7.72],[-5.892,-6.63],[-5.911,7.078],[-5.605,8.093],[-4.017,10.464],[-2.601,11.229],[4.171,11.209]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.960784373564,0.835294177485,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[928.435,618.478],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.963,0.001],[0,0],[-0.001,0.963],[0,0],[-0.964,-0.002],[0,0],[0.001,-0.963],[0,0]],\"o\":[[0,0],[-0.963,-0.001],[0,0],[0.002,-0.963],[0,0],[0.963,0.001],[0,0],[-0.001,0.963]],\"v\":[[2.023,5.807],[-2.038,5.801],[-3.779,4.055],[-3.768,-4.065],[-2.021,-5.806],[2.039,-5.8],[3.779,-4.054],[3.768,4.066]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.960784373564,0.835294177485,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[949.355,613.329],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 3\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":3,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.963,0.001],[0,0],[-0.001,0.963],[0,0],[-0.963,-0.002],[0,0],[0.001,-0.963],[0,0]],\"o\":[[0,0],[-0.963,-0.001],[0,0],[0.001,-0.963],[0,0],[0.963,0.002],[0,0],[-0.001,0.963]],\"v\":[[2.024,4.622],[-2.036,4.616],[-3.778,2.87],[-3.77,-2.88],[-2.024,-4.622],[2.037,-4.617],[3.778,-2.87],[3.77,2.881]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.960784373564,0.835294177485,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[949.587,625.096],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 4\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":4,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.963,0.001],[0,0],[-0.001,0.963],[0,0],[-0.963,-0.002],[0,0],[0.001,-0.963],[0,0]],\"o\":[[0,0],[-0.963,-0.001],[0,0],[0.001,-0.963],[0,0],[0.963,0.002],[0,0],[-0.001,0.963]],\"v\":[[2.024,4.622],[-2.036,4.617],[-3.778,2.871],[-3.77,-2.88],[-2.024,-4.622],[2.037,-4.617],[3.778,-2.869],[3.77,2.882]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.960784373564,0.835294177485,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[940.021,612.131],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 5\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":5,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.963,0.001],[0,0],[-0.001,0.963],[0,0],[-0.963,-0.001],[0,0],[0.002,-0.963],[0,0]],\"o\":[[0,0],[-0.963,-0.001],[0,0],[0.001,-0.963],[0,0],[0.963,0.001],[0,0],[-0.001,0.963]],\"v\":[[2.023,5.568],[-2.038,5.562],[-3.779,3.816],[-3.768,-3.826],[-2.023,-5.568],[2.037,-5.562],[3.779,-3.816],[3.768,3.827]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.960784373564,0.835294177485,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[939.906,624.24],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 6\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":6,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[-11.183,-0.016],[11.183,0.016]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[960.134,656.4],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 7\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":7,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[-11.183,-0.016],[11.183,0.016]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[927.517,656.354],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 8\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":8,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[4.967,0.007],[0,0],[-0.007,4.966],[0,0],[-4.967,-0.008],[0,0],[0.006,-4.966],[0,0]],\"o\":[[0,0],[-4.966,-0.007],[0,0],[0.006,-4.967],[0,0],[4.966,0.007],[0,0],[-0.007,4.966]],\"v\":[[73.65,50.24],[-73.784,50.029],[-82.763,41.025],[-82.654,-41.26],[-73.648,-50.24],[73.786,-50.029],[82.765,-41.025],[82.654,41.26]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[983.473,622.645],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 9\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":9,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[4.156,0.006],[0,0],[-0.006,4.156],[0,0],[-4.156,-0.006],[0,0],[0.006,-4.156],[0,0]],\"o\":[[0,0],[-4.155,-0.006],[0,0],[0.005,-4.156],[0,0],[4.156,0.006],[0,0],[-0.005,4.156]],\"v\":[[75.018,49.896],[-73.782,49.783],[-82.629,40.911],[-82.673,-41.528],[-74.284,-49.897],[75.153,-49.682],[82.667,-42.148],[82.553,43.12]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[1,0.443137284821,0.007843137255,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[983.339,622.759],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 10\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":10,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":43,\"op\":87,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":20,\"ty\":4,\"nm\":\"card2 Outlines\",\"parent\":8,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[190,35,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[960,540,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0]],\"v\":[[820.25,483.81],[820.95,483.81],[985.43,483.81],[985.67,483.81]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0]],\"v\":[[985.67,475.39],[985.43,475.39],[820.95,475.39],[820.25,475.39]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.16,-0.68],[4.24,0],[0,0],[1.49,2.87],[0,1.5],[0,0],[0,0],[0,0],[-4.96,0],[0,0],[-1.32,-0.77],[-0.7,-2.06],[0,-1.02],[0,0],[0,0],[0,0]],\"o\":[[-0.94,3.96],[0,0],[-3.46,0],[-0.66,-1.25],[0,0],[0,0],[0,0],[0,-4.97],[0,0],[1.64,0],[1.85,1.07],[0.33,0.92],[0,0],[0,0],[0,0],[0,0.72]],\"v\":[[82.46,43.245],[73.72,50.135],[-73.72,50.135],[-81.68,45.305],[-82.71,41.145],[-82.71,-22.045],[-82.71,-30.465],[-82.71,-41.135],[-73.72,-50.135],[73.72,-50.135],[78.22,-48.925],[82.21,-44.065],[82.71,-41.135],[82.71,-30.465],[82.71,-22.045],[82.71,41.145]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[902.96,505.855],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 3\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":3,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-0.94,3.96],[4.12,0],[0,0],[0.92,3.09],[-3.46,0]],\"o\":[[4.24,0],[-0.06,4.1],[0,0],[-3.39,0],[1.49,2.87],[0,0]],\"v\":[[73.33,3.19],[82.07,-3.7],[73.69,2.83],[-74.88,3.7],[-82.07,-1.64],[-74.11,3.19]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.866666726505,0.709803921569,0.023529413635,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[903.35,552.8],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 4\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":4,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[1.85,1.07],[-0.55,-2.15]],\"o\":[[1.96,0.94],[-0.7,-2.06]],\"v\":[[-1.995,-2.43],[1.995,2.43]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.866666726505,0.709803921569,0.023529413635,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[983.175,459.36],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 5\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":5,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,-0.66],[0,0],[0,0],[0,0],[-4.15,0],[0,0],[-0.99,-0.48],[-0.7,-2.06]],\"o\":[[0,0],[0,0],[0,0],[0,-4.16],[0,0],[1.17,0],[1.85,1.07],[0.17,0.61]],\"v\":[[82.668,-2.075],[82.668,9.605],[-82.512,9.605],[-82.667,-1.22],[-74.292,-9.605],[75.148,-9.605],[78.418,-8.855],[82.408,-3.995]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.866666726505,0.709803921569,0.023529413635,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[902.762,465.785],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 6\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":6,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[0,0]],\"v\":[[82.59,4.21],[-82.59,4.21],[-82.59,-4.21],[82.59,-4.21]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[902.84,479.6],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 7\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":7,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0.01,-0.04],[4.24,0],[0,0],[1.49,2.87],[0,0.76],[0,0]],\"o\":[[0,0],[0,0.04],[-0.94,3.96],[0,0],[-3.46,0],[-0.22,-0.69],[0,0],[0,0]],\"v\":[[82.59,-36.09],[82.59,29.08],[82.58,29.2],[73.84,36.09],[-73.6,36.09],[-81.56,31.26],[-82.59,28.198],[-82.59,-36.09]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.866666726505,0.709803921569,0.023529413635,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[902.84,519.9],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 8\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":8,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":41,\"op\":85,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":21,\"ty\":4,\"nm\":\"receipt roll Outlines 3\",\"parent\":9,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[-70,107,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[960,540,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0]],\"v\":[[1089.61,485.54],[1089.7,485.54],[1096.98,485.54]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0,0,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0]],\"v\":[[-2.96,0.065],[2.66,-0.055],[2.96,-0.065]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0,0,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1094.39,477.605],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[1091.04,493.93],[1101.69,493.93]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0,0,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 3\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":3,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0]],\"v\":[[1091.17,469.14],[1101.03,469.14],[1101.04,469.14]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0,0,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 4\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":4,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0.01,-0.02],[-4.46,0],[-0.67,4.61],[0.06,1.56],[0.14,1.08],[3.54,0],[-0.13,-3.15],[-2.09,-0.13]],\"o\":[[0,0.02],[-2.05,15.55],[3.37,0],[0.22,-1.48],[-0.05,-1.18],[-0.65,-4.82],[-4.33,0],[0.13,3.15],[0,0]],\"v\":[[-6.685,-10.915],[-6.695,-10.865],[2.395,12.395],[8.455,4.025],[8.685,-0.585],[8.405,-3.985],[2.525,-12.395],[-2.065,-3.865],[0.965,4.005]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0,0,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1088.645,481.535],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 5\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":5,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[1.16,3.49]],\"o\":[[2.02,0],[0,0]],\"v\":[[-1.445,3.935],[0.285,-3.935]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0,0,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1091.145,481.605],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 6\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":6,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-1.85,-4.42],[0,-3.75],[1.27,-3.96],[4.48,0],[0,0]],\"o\":[[3.75,0],[1.63,3.88],[0,3.97],[-1.68,5.25],[0,0],[0,0]],\"v\":[[-5.48,-21],[2.99,-13.16],[5.48,-0.89],[3.65,11.63],[-5.42,21],[-5.48,21]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0,0,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1098.04,482.3],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 7\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":7,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[-0.2,14.05],[0,0],[0,0],[2.07,-7.21],[-0.04,-4.35],[-6.56,0]],\"o\":[[0,0],[5.99,-1.75],[0.21,-14.06],[0,0],[-4.12,-0.11],[-0.8,2.75],[0.16,15.71],[0,0]],\"v\":[[-89.375,21.055],[91.185,21.055],[101.075,-1.425],[91.185,-20.945],[-89.435,-20.945],[-100.045,-11.575],[-101.245,-0.995],[-89.435,21.055]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0,0,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1181.995,482.245],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 8\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":8,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[1.63,3.88],[3.75,0],[0,0],[0.21,-14.06],[5.99,-1.75],[0,0],[-1.68,5.25],[0,3.97]],\"o\":[[-1.85,-4.42],[0,0],[0,0],[-0.2,14.05],[0,0],[4.48,0],[1.27,-3.96],[0,-3.75]],\"v\":[[-86.89,-13.16],[-95.36,-21],[85.26,-21],[95.15,-1.48],[85.26,21],[-95.3,21],[-86.23,11.63],[-84.4,-0.89]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.956862804936,0.772549079446,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1187.92,482.3],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 9\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":9,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-0.8,2.75],[-4.46,0],[0,0],[4.48,0],[0,0],[0.16,15.71]],\"o\":[[-2.05,15.55],[0,0],[-1.68,5.25],[0,0],[-6.56,0],[-0.04,-4.35]],\"v\":[[-8.845,-16.315],[0.245,6.945],[10.895,6.945],[1.825,16.315],[1.765,16.315],[-10.045,-5.735]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.956862804936,0.772549079446,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1090.795,486.985],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 10\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":10,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-4.12,-0.11],[-1.85,-4.42],[0,0],[-0.13,-3.15],[-2.09,-0.13],[0,0],[0,0],[0,0],[3.37,0],[-2.05,15.55]],\"o\":[[3.75,0],[0,0],[-4.33,0],[0.13,3.15],[0,0],[0,0],[0,0],[-0.67,4.61],[-4.46,0],[2.07,-7.21]],\"v\":[[2.095,-16.26],[10.565,-8.42],[0.705,-8.42],[-3.885,0.11],[-0.855,7.98],[-0.765,7.98],[6.515,7.98],[6.635,8],[0.575,16.37],[-8.515,-6.89]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.956862804936,0.772549079446,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1090.465,477.56],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 11\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":11,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-0.65,-4.82],[0,0],[2.02,0],[0,0],[0.13,3.15],[-4.33,0]],\"o\":[[0,0],[1.16,3.49],[0,0],[-2.09,-0.13],[-0.13,-3.15],[3.54,0]],\"v\":[[5.3,0.21],[-0.32,0.33],[-2.05,8.2],[-2.14,8.2],[-5.17,0.33],[-0.58,-8.2]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.956862804936,0.772549079446,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1091.75,477.34],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 12\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":12,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-0.05,-1.18],[0.22,-1.48],[0,0],[0,0],[1.16,3.49],[0,0]],\"o\":[[0.06,1.56],[0,0],[0,0],[2.02,0],[0,0],[0.14,1.08]],\"v\":[[3.785,-0.605],[3.555,4.005],[3.435,3.985],[-3.845,3.985],[-2.115,-3.885],[3.505,-4.005]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.956862804936,0.772549079446,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1093.545,481.555],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 13\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":13,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.14,1.08],[3.54,0],[0,0],[0,-3.75],[1.27,-3.96],[0,0],[-0.67,4.61],[0.06,1.56]],\"o\":[[-0.65,-4.82],[0,0],[1.63,3.88],[0,3.97],[0,0],[3.37,0],[0.22,-1.48],[-0.05,-1.18]],\"v\":[[-0.23,-3.985],[-6.11,-12.395],[3.75,-12.395],[6.24,-0.125],[4.41,12.395],[-6.24,12.395],[-0.18,4.025],[0.05,-0.585]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.956862804936,0.772549079446,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1097.28,481.535],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 14\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":14,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":87,\"op\":96,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":22,\"ty\":4,\"nm\":\"receipt roll Outlines\",\"parent\":9,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[-70,107,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[960,540,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0]],\"v\":[[1089.61,485.54],[1089.7,485.54],[1096.98,485.54]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0,0,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0]],\"v\":[[-2.96,0.065],[2.66,-0.055],[2.96,-0.065]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0,0,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1094.39,477.605],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[1091.04,493.93],[1101.69,493.93]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0,0,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 3\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":3,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0]],\"v\":[[1091.17,469.14],[1101.03,469.14],[1101.04,469.14]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0,0,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 4\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":4,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0.01,-0.02],[-4.46,0],[-0.67,4.61],[0.06,1.56],[0.14,1.08],[3.54,0],[-0.13,-3.15],[-2.09,-0.13]],\"o\":[[0,0.02],[-2.05,15.55],[3.37,0],[0.22,-1.48],[-0.05,-1.18],[-0.65,-4.82],[-4.33,0],[0.13,3.15],[0,0]],\"v\":[[-6.685,-10.915],[-6.695,-10.865],[2.395,12.395],[8.455,4.025],[8.685,-0.585],[8.405,-3.985],[2.525,-12.395],[-2.065,-3.865],[0.965,4.005]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0,0,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1088.645,481.535],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 5\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":5,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[1.16,3.49]],\"o\":[[2.02,0],[0,0]],\"v\":[[-1.445,3.935],[0.285,-3.935]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0,0,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1091.145,481.605],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 6\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":6,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-1.85,-4.42],[0,-3.75],[1.27,-3.96],[4.48,0],[0,0]],\"o\":[[3.75,0],[1.63,3.88],[0,3.97],[-1.68,5.25],[0,0],[0,0]],\"v\":[[-5.48,-21],[2.99,-13.16],[5.48,-0.89],[3.65,11.63],[-5.42,21],[-5.48,21]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0,0,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1098.04,482.3],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 7\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":7,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[-0.2,14.05],[0,0],[0,0],[2.07,-7.21],[-0.04,-4.35],[-6.56,0]],\"o\":[[0,0],[5.99,-1.75],[0.21,-14.06],[0,0],[-4.12,-0.11],[-0.8,2.75],[0.16,15.71],[0,0]],\"v\":[[-89.375,21.055],[91.185,21.055],[101.075,-1.425],[91.185,-20.945],[-89.435,-20.945],[-100.045,-11.575],[-101.245,-0.995],[-89.435,21.055]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0,0,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1181.995,482.245],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 8\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":8,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[1.63,3.88],[3.75,0],[0,0],[0.21,-14.06],[5.99,-1.75],[0,0],[-1.68,5.25],[0,3.97]],\"o\":[[-1.85,-4.42],[0,0],[0,0],[-0.2,14.05],[0,0],[4.48,0],[1.27,-3.96],[0,-3.75]],\"v\":[[-86.89,-13.16],[-95.36,-21],[85.26,-21],[95.15,-1.48],[85.26,21],[-95.3,21],[-86.23,11.63],[-84.4,-0.89]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.956862804936,0.772549079446,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1187.92,482.3],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 9\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":9,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-0.8,2.75],[-4.46,0],[0,0],[4.48,0],[0,0],[0.16,15.71]],\"o\":[[-2.05,15.55],[0,0],[-1.68,5.25],[0,0],[-6.56,0],[-0.04,-4.35]],\"v\":[[-8.845,-16.315],[0.245,6.945],[10.895,6.945],[1.825,16.315],[1.765,16.315],[-10.045,-5.735]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.956862804936,0.772549079446,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1090.795,486.985],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 10\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":10,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-4.12,-0.11],[-1.85,-4.42],[0,0],[-0.13,-3.15],[-2.09,-0.13],[0,0],[0,0],[0,0],[3.37,0],[-2.05,15.55]],\"o\":[[3.75,0],[0,0],[-4.33,0],[0.13,3.15],[0,0],[0,0],[0,0],[-0.67,4.61],[-4.46,0],[2.07,-7.21]],\"v\":[[2.095,-16.26],[10.565,-8.42],[0.705,-8.42],[-3.885,0.11],[-0.855,7.98],[-0.765,7.98],[6.515,7.98],[6.635,8],[0.575,16.37],[-8.515,-6.89]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.956862804936,0.772549079446,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1090.465,477.56],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 11\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":11,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-0.65,-4.82],[0,0],[2.02,0],[0,0],[0.13,3.15],[-4.33,0]],\"o\":[[0,0],[1.16,3.49],[0,0],[-2.09,-0.13],[-0.13,-3.15],[3.54,0]],\"v\":[[5.3,0.21],[-0.32,0.33],[-2.05,8.2],[-2.14,8.2],[-5.17,0.33],[-0.58,-8.2]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.956862804936,0.772549079446,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1091.75,477.34],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 12\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":12,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-0.05,-1.18],[0.22,-1.48],[0,0],[0,0],[1.16,3.49],[0,0]],\"o\":[[0.06,1.56],[0,0],[0,0],[2.02,0],[0,0],[0.14,1.08]],\"v\":[[3.785,-0.605],[3.555,4.005],[3.435,3.985],[-3.845,3.985],[-2.115,-3.885],[3.505,-4.005]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.956862804936,0.772549079446,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1093.545,481.555],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 13\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":13,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0.14,1.08],[3.54,0],[0,0],[0,-3.75],[1.27,-3.96],[0,0],[-0.67,4.61],[0.06,1.56]],\"o\":[[-0.65,-4.82],[0,0],[1.63,3.88],[0,3.97],[0,0],[3.37,0],[0.22,-1.48],[-0.05,-1.18]],\"v\":[[-0.23,-3.985],[-6.11,-12.395],[3.75,-12.395],[6.24,-0.125],[4.41,12.395],[-6.24,12.395],[-0.18,4.025],[0.05,-0.585]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.956862804936,0.772549079446,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1097.28,481.535],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 14\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":14,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":120,\"op\":128,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":23,\"ty\":4,\"nm\":\"Shape Layer 3\",\"td\":1,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":92,\"s\":[960,339,0],\"to\":[0,23.688,0],\"ti\":[0,-53.124,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":95,\"s\":[960,430.749,0],\"to\":[0,22.005,0],\"ti\":[0,-9.812,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":96,\"s\":[960,540,0],\"to\":[0,33.5,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":119,\"s\":[960,540,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":120,\"s\":[960,501,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":124,\"s\":[960,371,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"t\":125,\"s\":[960,339,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[0,0,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ty\":\"rc\",\"d\":1,\"s\":{\"a\":0,\"k\":[214,233],\"ix\":2},\"p\":{\"a\":0,\"k\":[0,0],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":4},\"nm\":\"Rectangle Path 1\",\"mn\":\"ADBE Vector Shape - Rect\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[1,1,1,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":1,\"lj\":1,\"ml\":4,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[1,0,0,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[-4,1.5],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Rectangle 1\",\"np\":3,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":92,\"op\":126,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":24,\"ty\":4,\"nm\":\"receipt Outlines\",\"parent\":10,\"tt\":1,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[-167,44,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[960,540,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[-9.19,0.24],[9.19,-0.24]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1246.99,601.22],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[-9.19,0.245],[9.19,-0.245]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1212.87,601.195],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[-9.195,0.24],[9.195,-0.24]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1177.775,601.17],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 3\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":3,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[-9.195,0.24],[9.195,-0.24]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1144.625,601.15],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 4\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":4,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[-9.195,0.245],[9.195,-0.245]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1112.455,601.125],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 5\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":5,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[-9.19,0.24],[9.19,-0.24]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1246.99,682.22],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 6\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":6,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[-9.19,0.245],[9.19,-0.245]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1212.87,682.195],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 7\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":7,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[-9.195,0.24],[9.195,-0.24]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1177.775,682.17],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 8\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":8,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[-9.195,0.24],[9.195,-0.24]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1144.625,682.15],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 9\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":9,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[-9.195,0.245],[9.195,-0.245]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1112.455,682.125],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 10\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":10,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[1103.26,573.08],[1256.13,573.08]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 11\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":11,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[1103.26,627.08],[1256.13,627.08]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 12\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":12,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[1103.26,654.08],[1256.13,654.08]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 13\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":13,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-4.6,5.75],[-3.79,-4.02],[-4.22,7.05],[-4.83,-8.28],[-6.67,7.56],[-4.14,-4.59],[-5.74,7.36],[-5.06,-5.74],[-5.98,6.44],[-5.97,-8.04],[-4.37,5.06],[-6.44,-8.5],[0,10.35],[0,0],[0,0]],\"o\":[[0.07,7.62],[4.6,-5.75],[7.56,9.23],[10.35,-16.99],[4.37,5.29],[10.58,-14.23],[4.14,4.6],[9.96,-10.78],[5.06,5.75],[11.73,-11.73],[8.28,10.58],[10.11,-11.67],[4.37,5.06],[0,0],[0,0],[0,0]],\"v\":[[-96.805,88.48],[-83.315,79.2],[-74.925,77.47],[-59.975,86.9],[-41.825,79.3],[-27.785,88.48],[-12.835,77.01],[2.105,85.52],[17.055,76.55],[33.615,86.9],[51.315,75.86],[66.265,85.75],[83.515,76.09],[96.805,85.29],[96.805,-95.57],[-96.805,-96.1]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1178.505,640.57],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 14\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":14,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[4.37,5.06],[10.11,-11.67],[8.28,10.58],[11.73,-11.73],[5.06,5.75],[9.96,-10.78],[4.14,4.6],[10.58,-14.23],[4.37,5.29],[10.35,-16.99],[7.56,9.23],[4.6,-5.75],[0.07,7.62],[0,0]],\"o\":[[0,0],[0,10.35],[-6.44,-8.5],[-4.37,5.06],[-5.97,-8.04],[-5.98,6.44],[-5.06,-5.74],[-5.74,7.36],[-4.14,-4.59],[-6.67,7.56],[-4.83,-8.28],[-4.22,7.05],[-3.79,-4.02],[-4.6,5.75],[0,0],[0,0]],\"v\":[[96.805,-95.57],[96.805,85.29],[83.515,76.09],[66.265,85.75],[51.315,75.86],[33.615,86.9],[17.055,76.55],[2.105,85.52],[-12.835,77.01],[-27.785,88.48],[-41.825,79.3],[-59.975,86.9],[-74.925,77.47],[-83.315,79.2],[-96.805,88.48],[-96.805,-96.1]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.956862804936,0.772549079446,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[1178.505,640.57],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 15\",\"np\":4,\"cix\":2,\"bm\":0,\"ix\":15,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":92,\"op\":126,\"st\":0,\"ct\":1,\"bm\":0}]},{\"id\":\"comp_2\",\"nm\":\"bank-top-comp\",\"fr\":24,\"layers\":[{\"ddd\":0,\"ind\":1,\"ty\":3,\"nm\":\"toplid peg\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.667,\"y\":0.667},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":0,\"s\":[958,421.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.667,\"y\":1},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":19,\"s\":[958,421.5,0],\"to\":[0,5.583,0],\"ti\":[0,-5.583,0]},{\"i\":{\"x\":0.667,\"y\":0.667},\"o\":{\"x\":0.333,\"y\":0.333},\"t\":22,\"s\":[958,455,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.333,\"y\":0},\"t\":25,\"s\":[958,455,0],\"to\":[0,-5.583,0],\"ti\":[0,5.583,0]},{\"t\":29,\"s\":[958,421.5,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[50,50,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":128,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":2,\"ty\":3,\"nm\":\"bottomlid peg\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.667,\"y\":0.667},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":0,\"s\":[958,525,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.667,\"y\":1},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":19,\"s\":[958,525,0],\"to\":[0,-5.833,0],\"ti\":[0,5.833,0]},{\"i\":{\"x\":0.667,\"y\":0.667},\"o\":{\"x\":0.333,\"y\":0.333},\"t\":22,\"s\":[958,490,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.833,\"y\":0.833},\"o\":{\"x\":0.333,\"y\":0},\"t\":25,\"s\":[958,490,0],\"to\":[0,5.833,0],\"ti\":[0,-5.833,0]},{\"t\":29,\"s\":[958,525,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[50,50,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":128,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":3,\"ty\":3,\"nm\":\"pupil peg\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":0,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":1,\"k\":[{\"i\":{\"x\":0.667,\"y\":0.667},\"o\":{\"x\":0.167,\"y\":0.167},\"t\":7,\"s\":[959.5,470.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.667,\"y\":1},\"o\":{\"x\":0.333,\"y\":0},\"t\":9,\"s\":[959.5,470.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.667,\"y\":0.667},\"o\":{\"x\":0.333,\"y\":0.333},\"t\":13,\"s\":[974.5,470.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.667,\"y\":1},\"o\":{\"x\":0.333,\"y\":0},\"t\":16,\"s\":[974.5,470.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.667,\"y\":0.667},\"o\":{\"x\":0.333,\"y\":0.333},\"t\":20,\"s\":[944.5,470.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.667,\"y\":1},\"o\":{\"x\":0.333,\"y\":0},\"t\":23,\"s\":[944.5,470.5,0],\"to\":[0,0,0],\"ti\":[0,0,0]},{\"i\":{\"x\":0.667,\"y\":1},\"o\":{\"x\":0.333,\"y\":0},\"t\":25,\"s\":[949.5,470.5,0],\"to\":[0,0,0],\"ti\":[-1.667,0,0]},{\"t\":29,\"s\":[959.5,470.5,0]}],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[50,50,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"ip\":0,\"op\":128,\"st\":0,\"bm\":0},{\"ddd\":0,\"ind\":4,\"ty\":4,\"nm\":\"eye outline Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[1165.5,397,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[960,540,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[-39.93,0],[0,0]],\"o\":[[0,0],[39.94,0],[0,0]],\"v\":[[-38.785,-15.06],[-0.005,16.07],[36.675,-16.07]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[754.595,620.98],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[36.35,-34.81]],\"o\":[[0,0],[0,0]],\"v\":[[37.73,16.395],[-37.73,17.405]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[753.54,588.515],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":7,\"op\":36,\"st\":-115,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":5,\"ty\":4,\"nm\":\"eye color Outlines 3\",\"td\":1,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[1165.5,397,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[960,540,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[39.94,0],[0,0]],\"o\":[[0,0],[-39.93,0],[36.35,-34.81]],\"v\":[[36.675,0.83],[-0.005,32.97],[-38.785,1.84]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.87450986376,0.956862804936,0.972549079446,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[754.595,604.08],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":7,\"op\":36,\"st\":-115,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":6,\"ty\":4,\"nm\":\"toplid Outlines\",\"parent\":1,\"tt\":1,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[257.5,-8,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[960,540,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[-39.925,0.445],[39.925,-0.445]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":1,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[753.135,575.725],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[793.06,604.4],[793.06,575.28]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[713.21,604.58],[713.21,576.17]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 3\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":3,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[25,20.29]],\"o\":[[-20.85,19.77],[0,0]],\"v\":[[39.925,-10.235],[-39.925,-10.055]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[753.135,614.635],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 4\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":4,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[25,20.29],[0,0]],\"o\":[[0,0],[-20.85,19.77],[0,0],[0,0]],\"v\":[[39.925,-24.795],[39.925,4.325],[-39.925,4.505],[-39.925,-23.905]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.666666666667,0.827451040231,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[753.135,600.075],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 5\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":5,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":7,\"op\":36,\"st\":-115,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":7,\"ty\":4,\"nm\":\"eye color Outlines 2\",\"td\":1,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[1165.5,397,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[960,540,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[39.94,0],[0,0]],\"o\":[[0,0],[-39.93,0],[36.35,-34.81]],\"v\":[[36.675,0.83],[-0.005,32.97],[-38.785,1.84]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.87450986376,0.956862804936,0.972549079446,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[754.595,604.08],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":7,\"op\":36,\"st\":-115,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":8,\"ty\":4,\"nm\":\"bottomlid Outlines\",\"parent\":2,\"tt\":1,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[257.5,-43,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[960,540,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[713.21,647.46],[793.06,647.46]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[793.06,604.4],[793.06,647.46]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0]],\"o\":[[0,0],[0,0]],\"v\":[[713.21,604.58],[713.21,647.46]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[0,0],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 3\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":3,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[25,20.29]],\"o\":[[-20.85,19.77],[0,0]],\"v\":[[39.925,-10.235],[-39.925,-10.055]],\"c\":false},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[753.135,614.635],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 4\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":4,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[-20.85,19.77],[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0],[25,20.29]],\"v\":[[39.925,-21.53],[39.925,21.53],[-39.925,21.53],[-39.925,-21.35]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.666666666667,0.827451040231,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[753.135,625.93],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 5\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":5,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":7,\"op\":36,\"st\":-115,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":9,\"ty\":4,\"nm\":\"pupil Outlines\",\"parent\":3,\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[256,-23.5,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[960,540,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[7.65,0],[0,8.99],[-8.99,0],[-2.7,-5.28]],\"o\":[[0,0],[-1.74,7.11],[-8.99,0],[0,-8.99],[6.33,0],[0,0]],\"v\":[[4.165,1.69],[16.035,3.89],[0.245,16.28],[-16.035,0],[0.245,-16.28],[14.745,-7.38]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[754.245,613.35],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":7,\"op\":36,\"st\":-115,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":10,\"ty\":4,\"nm\":\"eye color Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[1165.5,397,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[960,540,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[39.94,0],[0,0]],\"o\":[[0,0],[-39.93,0],[36.35,-34.81]],\"v\":[[36.675,0.83],[-0.005,32.97],[-38.785,1.84]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.87450986376,0.956862804936,0.972549079446,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[754.595,604.08],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":7,\"op\":36,\"st\":-115,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":11,\"ty\":4,\"nm\":\"bank1 Outlines\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[1165.5,397,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[960,540,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"shapes\":[{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0]],\"v\":[[-99.62,37.855],[99.62,37.855],[0,-37.855]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"st\",\"c\":{\"a\":0,\"k\":[0,0.129411764706,0.250980392157,1],\"ix\":3},\"o\":{\"a\":0,\"k\":100,\"ix\":4},\"w\":{\"a\":0,\"k\":2,\"ix\":5},\"lc\":2,\"lj\":2,\"bm\":0,\"nm\":\"Stroke 1\",\"mn\":\"ADBE Vector Graphic - Stroke\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[753.84,604.955],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 1\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":1,\"mn\":\"ADBE Vector Group\",\"hd\":false},{\"ty\":\"gr\",\"it\":[{\"ind\":0,\"ty\":\"sh\",\"ix\":1,\"ks\":{\"a\":0,\"k\":{\"i\":[[0,0],[0,0],[0,0]],\"o\":[[0,0],[0,0],[0,0]],\"v\":[[99.62,37.855],[-99.62,37.855],[0,-37.855]],\"c\":true},\"ix\":2},\"nm\":\"Path 1\",\"mn\":\"ADBE Vector Shape - Group\",\"hd\":false},{\"ty\":\"fl\",\"c\":{\"a\":0,\"k\":[0.666666666667,0.827451040231,1,1],\"ix\":4},\"o\":{\"a\":0,\"k\":100,\"ix\":5},\"r\":1,\"bm\":0,\"nm\":\"Fill 1\",\"mn\":\"ADBE Vector Graphic - Fill\",\"hd\":false},{\"ty\":\"tr\",\"p\":{\"a\":0,\"k\":[753.84,604.955],\"ix\":2},\"a\":{\"a\":0,\"k\":[0,0],\"ix\":1},\"s\":{\"a\":0,\"k\":[100,100],\"ix\":3},\"r\":{\"a\":0,\"k\":0,\"ix\":6},\"o\":{\"a\":0,\"k\":100,\"ix\":7},\"sk\":{\"a\":0,\"k\":0,\"ix\":4},\"sa\":{\"a\":0,\"k\":0,\"ix\":5},\"nm\":\"Transform\"}],\"nm\":\"Group 2\",\"np\":2,\"cix\":2,\"bm\":0,\"ix\":2,\"mn\":\"ADBE Vector Group\",\"hd\":false}],\"ip\":7,\"op\":36,\"st\":-115,\"ct\":1,\"bm\":0}]}],\"layers\":[{\"ddd\":0,\"ind\":1,\"ty\":0,\"nm\":\"Expensify-Reviewing-120522-kjs-1\",\"refId\":\"comp_0\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[140,140,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[960,540,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[75,75,100],\"ix\":6,\"l\":2}},\"ao\":0,\"w\":1920,\"h\":1080,\"ip\":0,\"op\":128,\"st\":0,\"ct\":1,\"bm\":0},{\"ddd\":0,\"ind\":2,\"ty\":1,\"nm\":\"Dark Green Solid 1\",\"sr\":1,\"ks\":{\"o\":{\"a\":0,\"k\":100,\"ix\":11},\"r\":{\"a\":0,\"k\":0,\"ix\":10},\"p\":{\"a\":0,\"k\":[140,140,0],\"ix\":2,\"l\":2},\"a\":{\"a\":0,\"k\":[140,140,0],\"ix\":1,\"l\":2},\"s\":{\"a\":0,\"k\":[100,100,100],\"ix\":6,\"l\":2}},\"ao\":0,\"sw\":280,\"sh\":280,\"sc\":\"#061b09\",\"ip\":0,\"op\":128,\"st\":0,\"bm\":0}],\"markers\":[]}","import React from 'react';\nimport {\n View,\n} from 'react-native';\nimport CONST from '../../CONST';\nimport Text from '../../components/Text';\nimport TextLink from '../../components/TextLink';\nimport withLocalize, {withLocalizePropTypes} from '../../components/withLocalize';\nimport styles from '../../styles/styles';\n\nconst propTypes = {\n ...withLocalizePropTypes,\n};\n\nconst FailedKYC = props => (\n \n \n \n {props.translate('additionalDetailsStep.failedKYCTextBefore')}\n \n {CONST.EMAIL.CONCIERGE}\n \n {props.translate('additionalDetailsStep.failedKYCTextAfter')}\n \n \n \n);\n\nFailedKYC.propTypes = propTypes;\nFailedKYC.displayName = 'FailedKYC';\n\nexport default withLocalize(FailedKYC);\n","import React, {Component} from 'react';\nimport {View, ScrollView} from 'react-native';\nimport PropTypes from 'prop-types';\nimport {withOnyx} from 'react-native-onyx';\nimport lodashGet from 'lodash/get';\nimport _ from 'underscore';\nimport styles from '../../styles/styles';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport {withNetwork} from '../../components/OnyxProvider';\nimport HeaderWithCloseButton from '../../components/HeaderWithCloseButton';\nimport Navigation from '../../libs/Navigation/Navigation';\nimport ScreenWrapper from '../../components/ScreenWrapper';\nimport * as IOU from '../../libs/actions/IOU';\nimport * as Report from '../../libs/actions/Report';\nimport IOUPreview from '../../components/ReportActionItem/IOUPreview';\nimport IOUTransactions from './IOUTransactions';\nimport withLocalize, {withLocalizePropTypes} from '../../components/withLocalize';\nimport compose from '../../libs/compose';\nimport CONST from '../../CONST';\nimport SettlementButton from '../../components/SettlementButton';\nimport ROUTES from '../../ROUTES';\nimport FixedFooter from '../../components/FixedFooter';\nimport networkPropTypes from '../../components/networkPropTypes';\nimport reportActionPropTypes from '../home/report/reportActionPropTypes';\nimport FullPageNotFoundView from '../../components/BlockingViews/FullPageNotFoundView';\nimport FullScreenLoadingIndicator from '../../components/FullscreenLoadingIndicator';\n\nconst propTypes = {\n /** URL Route params */\n route: PropTypes.shape({\n /** Params from the URL path */\n params: PropTypes.shape({\n /** chatReportID passed via route: /iou/details/:chatReportID/:iouReportID */\n chatReportID: PropTypes.string,\n\n /** iouReportID passed via route: /iou/details/:chatReportID/:iouReportID */\n iouReportID: PropTypes.string,\n }),\n }).isRequired,\n\n /* Onyx Props */\n /** Holds data related to IOU view state, rather than the underlying IOU data. */\n iou: PropTypes.shape({\n /** Is the IOU Report currently being loaded? */\n loading: PropTypes.bool,\n\n /** Error message, empty represents no error */\n error: PropTypes.bool,\n }),\n\n /** IOU Report data object */\n iouReport: PropTypes.shape({\n /** ID for the chatReport that this IOU is linked to */\n chatReportID: PropTypes.string,\n\n /** Manager is the person who currently owes money */\n managerEmail: PropTypes.string,\n\n /** Owner is the person who is owed money */\n ownerEmail: PropTypes.string,\n\n /** Does the iouReport have an outstanding IOU? */\n hasOutstandingIOU: PropTypes.bool,\n }),\n\n /** Session info for the currently logged in user. */\n session: PropTypes.shape({\n /** Currently logged in user email */\n email: PropTypes.string,\n }),\n\n /** Actions from the ChatReport */\n reportActions: PropTypes.shape(reportActionPropTypes),\n\n /** Information about the network */\n network: networkPropTypes.isRequired,\n\n /** chatReport associated with iouReport */\n chatReport: PropTypes.shape({\n /** Report ID associated with the transaction */\n reportID: PropTypes.string,\n\n /** The participants of this report */\n participants: PropTypes.arrayOf(PropTypes.string),\n\n /** Whether the chat report has an outstanding IOU */\n hasOutstandingIOU: PropTypes.bool.isRequired,\n }),\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n iou: {},\n reportActions: {},\n iouReport: undefined,\n session: {\n email: null,\n },\n chatReport: {\n participants: [],\n },\n};\n\nclass IOUDetailsModal extends Component {\n componentDidMount() {\n if (this.props.network.isOffline) {\n return;\n }\n\n this.fetchData();\n }\n\n componentDidUpdate(prevProps) {\n if (!prevProps.network.isOffline || this.props.network.isOffline) {\n return;\n }\n\n this.fetchData();\n }\n\n fetchData() {\n Report.openPaymentDetailsPage(this.props.route.params.chatReportID, this.props.route.params.iouReportID);\n }\n\n /**\n * @param {String} paymentMethodType\n */\n payMoneyRequest(paymentMethodType) {\n const recipient = {\n login: this.props.iouReport.ownerEmail,\n payPalMeAddress: this.props.iouReport.submitterPayPalMeAddress,\n };\n\n if (paymentMethodType === CONST.IOU.PAYMENT_TYPE.ELSEWHERE) {\n IOU.payMoneyRequestElsewhere(\n this.props.chatReport,\n this.props.iouReport,\n recipient,\n );\n return;\n }\n\n if (paymentMethodType === CONST.IOU.PAYMENT_TYPE.PAYPAL_ME) {\n IOU.payMoneyRequestViaPaypal(\n this.props.chatReport,\n this.props.iouReport,\n recipient,\n );\n return;\n }\n\n if (paymentMethodType === CONST.IOU.PAYMENT_TYPE.EXPENSIFY) {\n IOU.payMoneyRequestWithWallet(\n this.props.chatReport,\n this.props.iouReport,\n recipient,\n );\n Navigation.navigate(ROUTES.getReportRoute(this.props.route.params.chatReportID));\n }\n }\n\n // Finds if there is a reportAction pending for this IOU\n findPendingAction() {\n const reportActionWithPendingAction = _.find(this.props.reportActions, reportAction => reportAction.originalMessage\n && Number(reportAction.originalMessage.IOUReportID) === Number(this.props.route.params.iouReportID)\n && !_.isEmpty(reportAction.pendingAction));\n return reportActionWithPendingAction ? reportActionWithPendingAction.pendingAction : undefined;\n }\n\n render() {\n const sessionEmail = lodashGet(this.props.session, 'email', null);\n const pendingAction = this.findPendingAction();\n const iouReportStateNum = lodashGet(this.props.iouReport, 'stateNum');\n const hasOutstandingIOU = lodashGet(this.props.iouReport, 'hasOutstandingIOU');\n const hasFixedFooter = hasOutstandingIOU && this.props.iouReport.managerEmail === sessionEmail;\n return (\n \n {({safeAreaPaddingBottomStyle}) => (\n \n \n {this.props.iou.loading ? : (\n \n \n \n \n \n {(hasOutstandingIOU && this.props.iouReport.managerEmail === sessionEmail && (\n \n this.payMoneyRequest(paymentMethodType)}\n shouldShowPaypal={Boolean(lodashGet(this.props, 'iouReport.submitterPayPalMeAddress'))}\n currency={lodashGet(this.props, 'iouReport.currency')}\n enablePaymentsRoute={ROUTES.IOU_DETAILS_ENABLE_PAYMENTS}\n addBankAccountRoute={ROUTES.IOU_DETAILS_ADD_BANK_ACCOUNT}\n addDebitCardRoute={ROUTES.IOU_DETAILS_ADD_DEBIT_CARD}\n chatReportID={this.props.route.params.chatReportID}\n />\n \n ))}\n \n )}\n \n )}\n \n );\n }\n}\n\nIOUDetailsModal.propTypes = propTypes;\nIOUDetailsModal.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withNetwork(),\n withOnyx({\n iou: {\n key: ONYXKEYS.IOU,\n },\n chatReport: {\n key: ({route}) => `${ONYXKEYS.COLLECTION.REPORT}${route.params.chatReportID}`,\n },\n iouReport: {\n key: ({route}) => `${ONYXKEYS.COLLECTION.REPORT}${route.params.iouReportID}`,\n },\n session: {\n key: ONYXKEYS.SESSION,\n },\n reportActions: {\n key: ({route}) => `${ONYXKEYS.COLLECTION.REPORT_ACTIONS}${route.params.chatReportID}`,\n canEvict: false,\n },\n }),\n)(IOUDetailsModal);\n","import React from 'react';\nimport {\n View,\n TouchableWithoutFeedback,\n} from 'react-native';\nimport PropTypes from 'prop-types';\nimport Str from 'expensify-common/lib/str';\nimport {withOnyx} from 'react-native-onyx';\nimport lodashGet from 'lodash/get';\nimport _ from 'underscore';\nimport compose from '../../libs/compose';\nimport styles from '../../styles/styles';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport MultipleAvatars from '../MultipleAvatars';\nimport withLocalize, {withLocalizePropTypes} from '../withLocalize';\nimport * as Report from '../../libs/actions/Report';\nimport themeColors from '../../styles/themes/default';\nimport Icon from '../Icon';\nimport CONST from '../../CONST';\nimport * as Expensicons from '../Icon/Expensicons';\nimport Text from '../Text';\nimport * as PaymentMethods from '../../libs/actions/PaymentMethods';\nimport OfflineWithFeedback from '../OfflineWithFeedback';\nimport walletTermsPropTypes from '../../pages/EnablePayments/walletTermsPropTypes';\nimport ControlSelection from '../../libs/ControlSelection';\nimport * as DeviceCapabilities from '../../libs/DeviceCapabilities';\nimport reportActionPropTypes from '../../pages/home/report/reportActionPropTypes';\nimport {showContextMenuForReport} from '../ShowContextMenuContext';\nimport * as ReportUtils from '../../libs/ReportUtils';\nimport Button from '../Button';\n\nconst propTypes = {\n /** Additional logic for displaying the pay button */\n shouldHidePayButton: PropTypes.bool,\n\n /** Callback for the Pay/Settle button */\n onPayButtonPressed: PropTypes.func,\n\n /** The active IOUReport, used for Onyx subscription */\n // eslint-disable-next-line react/no-unused-prop-types\n iouReportID: PropTypes.string.isRequired,\n\n /** The associated chatReport */\n chatReportID: PropTypes.string.isRequired,\n\n /** Callback for the preview pressed */\n onPreviewPressed: PropTypes.func,\n\n /** All the data of the action, used for showing context menu */\n action: PropTypes.shape(reportActionPropTypes),\n\n /** Popover context menu anchor, used for showing context menu */\n contextMenuAnchor: PropTypes.shape({current: PropTypes.elementType}),\n\n /** Callback for updating context menu active state, used for showing context menu */\n checkIfContextMenuActive: PropTypes.func,\n\n /** Extra styles to pass to View wrapper */\n // eslint-disable-next-line react/forbid-prop-types\n containerStyles: PropTypes.arrayOf(PropTypes.object),\n\n /* Onyx Props */\n\n /** Active IOU Report for current report */\n iouReport: PropTypes.shape({\n /** Email address of the manager in this iou report */\n managerEmail: PropTypes.string,\n\n /** Email address of the creator of this iou report */\n ownerEmail: PropTypes.string,\n\n /** Outstanding amount in cents of this transaction */\n total: PropTypes.number,\n\n /** Currency of outstanding amount of this transaction */\n currency: PropTypes.string,\n\n /** Does the iouReport have an outstanding IOU? */\n hasOutstandingIOU: PropTypes.bool,\n }),\n\n /** True if the IOU Preview card is hovered */\n isHovered: PropTypes.bool,\n\n /** All of the personal details for everyone */\n personalDetails: PropTypes.objectOf(PropTypes.shape({\n\n /** This is either the user's full name, or their login if full name is an empty string */\n displayName: PropTypes.string.isRequired,\n })),\n\n /** Session info for the currently logged in user. */\n session: PropTypes.shape({\n /** Currently logged in user email */\n email: PropTypes.string,\n }),\n\n /** Information about the user accepting the terms for payments */\n walletTerms: walletTermsPropTypes,\n\n /** Pending action, if any */\n pendingAction: PropTypes.oneOf(_.values(CONST.RED_BRICK_ROAD_PENDING_ACTION)),\n\n /** Whether or not an IOU report contains money requests in a different currency\n * that are either created or cancelled offline, and thus haven't been converted to the report's currency yet\n */\n shouldShowPendingConversionMessage: PropTypes.bool,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n iouReport: {},\n shouldHidePayButton: false,\n onPayButtonPressed: null,\n onPreviewPressed: () => {},\n action: undefined,\n contextMenuAnchor: undefined,\n checkIfContextMenuActive: () => {},\n containerStyles: [],\n walletTerms: {},\n pendingAction: null,\n isHovered: false,\n personalDetails: {},\n session: {\n email: null,\n },\n shouldShowPendingConversionMessage: false,\n};\n\nconst IOUPreview = (props) => {\n // Usually the parent determines whether the IOU Preview is displayed. But as the iouReport total cannot be known\n // until it is stored locally, we need to make this check within the Component after retrieving it. This allows us\n // to handle the loading UI from within this Component instead of needing to declare it within each parent, which\n // would duplicate and complicate the logic\n if (props.iouReport.total === 0) {\n return null;\n }\n\n const sessionEmail = lodashGet(props.session, 'email', null);\n const managerEmail = props.iouReport.managerEmail || '';\n const ownerEmail = props.iouReport.ownerEmail || '';\n\n // Pay button should only be visible to the manager of the report.\n const isCurrentUserManager = managerEmail === sessionEmail;\n\n const managerName = ReportUtils.getDisplayNameForParticipant(managerEmail, true);\n const ownerName = ReportUtils.getDisplayNameForParticipant(ownerEmail, true);\n const managerAvatar = {\n source: ReportUtils.getAvatar(lodashGet(props.personalDetails, [managerEmail, 'avatar']), managerEmail),\n type: CONST.ICON_TYPE_AVATAR,\n name: managerEmail,\n };\n const ownerAvatar = {\n source: ReportUtils.getAvatar(lodashGet(props.personalDetails, [ownerEmail, 'avatar']), ownerEmail),\n type: CONST.ICON_TYPE_AVATAR,\n name: ownerEmail,\n };\n const cachedTotal = props.iouReport.total && props.iouReport.currency\n ? props.numberFormat(\n Math.abs(props.iouReport.total) / 100,\n {style: 'currency', currency: props.iouReport.currency},\n ) : '';\n const avatarTooltip = [Str.removeSMSDomain(managerEmail), Str.removeSMSDomain(ownerEmail)];\n\n const showContextMenu = (event) => {\n // Use action and shouldHidePayButton props to check if we are in IOUDetailsModal,\n // if it's true, do nothing when user long press, otherwise show context menu.\n if (!props.action && props.shouldHidePayButton) {\n return;\n }\n\n showContextMenuForReport(\n event,\n props.contextMenuAnchor,\n props.chatReportID,\n props.action,\n props.checkIfContextMenuActive,\n );\n };\n\n return (\n DeviceCapabilities.canUseTouchScreen() && ControlSelection.block()}\n onPressOut={() => ControlSelection.unblock()}\n onLongPress={showContextMenu}\n >\n \n {\n PaymentMethods.clearWalletTermsError();\n Report.clearIOUError(props.chatReportID);\n }}\n errorRowStyles={[styles.mbn1]}\n needsOffscreenAlphaCompositing\n >\n \n \n \n \n {cachedTotal}\n \n {!props.iouReport.hasOutstandingIOU && (\n \n \n \n )}\n \n \n \n \n \n {isCurrentUserManager\n ? (\n \n {props.iouReport.hasOutstandingIOU\n ? props.translate('iou.youowe', {owner: ownerName})\n : props.translate('iou.youpaid', {owner: ownerName})}\n \n )\n : (\n <>\n \n {props.iouReport.hasOutstandingIOU\n ? props.translate('iou.owesyou', {manager: managerName})\n : props.translate('iou.paidyou', {manager: managerName})}\n \n {props.shouldShowPendingConversionMessage && (\n \n {props.translate('iou.pendingConversionMessage')}\n \n )}\n \n )}\n {(isCurrentUserManager\n && !props.shouldHidePayButton\n && props.iouReport.stateNum === CONST.REPORT.STATE_NUM.PROCESSING && (\n DeviceCapabilities.canUseTouchScreen() && ControlSelection.block()}\n onPressOut={() => ControlSelection.unblock()}\n onLongPress={showContextMenu}\n text={props.translate('iou.pay')}\n success\n medium\n />\n ))}\n \n \n \n \n );\n};\n\nIOUPreview.propTypes = propTypes;\nIOUPreview.defaultProps = defaultProps;\nIOUPreview.displayName = 'IOUPreview';\n\nexport default compose(\n withLocalize,\n withOnyx({\n personalDetails: {\n key: ONYXKEYS.PERSONAL_DETAILS,\n },\n iouReport: {\n key: ({iouReportID}) => `${ONYXKEYS.COLLECTION.REPORT}${iouReportID}`,\n },\n session: {\n key: ONYXKEYS.SESSION,\n },\n walletTerms: {\n key: ONYXKEYS.WALLET_TERMS,\n },\n }),\n)(IOUPreview);\n","import PropTypes from 'prop-types';\n\nimport reportActionFragmentPropTypes from './reportActionFragmentPropTypes';\n\nexport default {\n /** The ID of the reportAction. It is the string representation of the a 64-bit integer. */\n reportActionID: PropTypes.string,\n\n /** Name of the action e.g. ADDCOMMENT */\n actionName: PropTypes.string,\n\n /** Person who created the action */\n person: PropTypes.arrayOf(reportActionFragmentPropTypes),\n\n /** ISO-formatted datetime */\n created: PropTypes.string,\n\n /** report action message */\n message: PropTypes.arrayOf(reportActionFragmentPropTypes),\n\n /** Original message associated with this action */\n originalMessage: PropTypes.shape({\n // The ID of the iou transaction\n IOUTransactionID: PropTypes.string,\n }),\n\n /** Whether we have received a response back from the server */\n isLoading: PropTypes.bool,\n\n /** Error message that's come back from the server. */\n error: PropTypes.string,\n};\n","import PropTypes from 'prop-types';\n\nexport default PropTypes.shape({\n /** The type of the action item fragment. Used to render a corresponding component */\n type: PropTypes.string.isRequired,\n\n /** The text content of the fragment. */\n text: PropTypes.string.isRequired,\n\n /** Used to apply additional styling. Style refers to a predetermined constant and not a class name. e.g. 'normal'\n * or 'strong'\n */\n style: PropTypes.string,\n\n /** ID of a report */\n reportID: PropTypes.string,\n\n /** ID of a policy */\n policyID: PropTypes.string,\n\n /** The target of a link fragment e.g. '_blank' */\n target: PropTypes.string,\n\n /** The destination of a link fragment e.g. 'https://www.expensify.com' */\n href: PropTypes.string,\n\n /** An additional avatar url - not the main avatar url but used within a message. */\n iconUrl: PropTypes.string,\n\n /** Fragment edited flag */\n isEdited: PropTypes.bool,\n});\n","import React from 'react';\nimport * as ReportActionContextMenu from '../pages/home/report/ContextMenu/ReportActionContextMenu';\nimport * as ContextMenuActions from '../pages/home/report/ContextMenu/ContextMenuActions';\n\nconst ShowContextMenuContext = React.createContext({\n anchor: null,\n reportID: null,\n action: undefined,\n checkIfContextMenuActive: () => {},\n});\n\nShowContextMenuContext.displayName = 'ShowContextMenuContext';\n\n/**\n * Show the report action context menu.\n *\n * @param {Object} event - Press event object\n * @param {Element} anchor - Context menu anchor\n * @param {String} reportID - Active Report ID\n * @param {Object} action - ReportAction for ContextMenu\n * @param {Function} checkIfContextMenuActive Callback to update context menu active state\n */\nfunction showContextMenuForReport(event, anchor, reportID, action, checkIfContextMenuActive) {\n ReportActionContextMenu.showContextMenu(\n ContextMenuActions.CONTEXT_MENU_TYPES.REPORT_ACTION,\n event,\n '',\n anchor,\n reportID,\n action,\n '',\n checkIfContextMenuActive,\n checkIfContextMenuActive,\n );\n}\n\nexport {\n ShowContextMenuContext,\n showContextMenuForReport,\n};\n","import React from 'react';\n\nconst contextMenuRef = React.createRef();\n\n/**\n * Show the ReportActionContextMenu modal popover.\n *\n * @param {string} type - the context menu type to display [EMAIL, LINK, REPORT_ACTION]\n * @param {Object} [event] - A press event.\n * @param {String} [selection] - Copied content.\n * @param {Element} contextMenuAnchor - popoverAnchor\n * @param {String} reportID - Active Report Id\n * @param {Object} reportAction - ReportAction for ContextMenu\n * @param {String} draftMessage - ReportAction Draftmessage\n * @param {Function} [onShow=() => {}] - Run a callback when Menu is shown\n * @param {Function} [onHide=() => {}] - Run a callback when Menu is hidden\n * @param {Boolean} isArchivedRoom - Whether the provided report is an archived room\n * @param {Boolean} isChronosReport - Flag to check if the chat participant is Chronos\n */\nfunction showContextMenu(\n type,\n event,\n selection,\n contextMenuAnchor,\n reportID = '0',\n reportAction = {},\n draftMessage = '',\n onShow = () => {},\n onHide = () => {},\n isArchivedRoom = false,\n isChronosReport = false,\n) {\n if (!contextMenuRef.current) {\n return;\n }\n contextMenuRef.current.showContextMenu(\n type,\n event,\n selection,\n contextMenuAnchor,\n reportID,\n reportAction,\n draftMessage,\n onShow,\n onHide,\n isArchivedRoom,\n isChronosReport,\n );\n}\n\n/**\n * Hide the ReportActionContextMenu modal popover.\n * Hides the popover menu with an optional delay\n * @param {Boolean} shouldDelay - whether the menu should close after a delay\n * @param {Function} [onHideCallback=() => {}] - Callback to be called after Context Menu is completely hidden\n */\nfunction hideContextMenu(shouldDelay, onHideCallback = () => {}) {\n if (!contextMenuRef.current) {\n return;\n }\n if (!shouldDelay) {\n contextMenuRef.current.hideContextMenu(onHideCallback);\n\n return;\n }\n\n // Save the active instanceID for which hide action was called.\n // If menu is being closed with a delay, check that whether the same instance exists or a new was created.\n // If instance is not same, cancel the hide action\n const instanceID = contextMenuRef.current.instanceID;\n setTimeout(() => {\n if (contextMenuRef.current.instanceID !== instanceID) {\n return;\n }\n\n contextMenuRef.current.hideContextMenu(onHideCallback);\n }, 800);\n}\n\nfunction hideDeleteModal() {\n if (!contextMenuRef.current) {\n return;\n }\n contextMenuRef.current.hideDeleteModal();\n}\n\n/**\n * Opens the Confirm delete action modal\n * @param {String} reportID\n * @param {Object} reportAction\n * @param {Boolean} [shouldSetModalVisibility]\n * @param {Function} [onConfirm]\n * @param {Function} [onCancel]\n */\nfunction showDeleteModal(reportID, reportAction, shouldSetModalVisibility, onConfirm, onCancel) {\n if (!contextMenuRef.current) {\n return;\n }\n contextMenuRef.current.showDeleteModal(reportID, reportAction, shouldSetModalVisibility, onConfirm, onCancel);\n}\n\n/**\n * Whether Context Menu is active for the Report Action.\n *\n * @param {Number|String} actionID\n * @return {Boolean}\n */\nfunction isActiveReportAction(actionID) {\n if (!contextMenuRef.current) {\n return;\n }\n return contextMenuRef.current.isActiveReportAction(actionID);\n}\n\nexport {\n contextMenuRef,\n showContextMenu,\n hideContextMenu,\n isActiveReportAction,\n showDeleteModal,\n hideDeleteModal,\n};\n","import React from 'react';\nimport _ from 'underscore';\nimport ExpensiMark from 'expensify-common/lib/ExpensiMark';\nimport Str from 'expensify-common/lib/str';\nimport lodashGet from 'lodash/get';\nimport * as Expensicons from '../../../../components/Icon/Expensicons';\nimport * as Report from '../../../../libs/actions/Report';\nimport * as Download from '../../../../libs/actions/Download';\nimport Clipboard from '../../../../libs/Clipboard';\nimport * as ReportUtils from '../../../../libs/ReportUtils';\nimport ReportActionComposeFocusManager from '../../../../libs/ReportActionComposeFocusManager';\nimport {hideContextMenu, showDeleteModal} from './ReportActionContextMenu';\nimport CONST from '../../../../CONST';\nimport getAttachmentDetails from '../../../../libs/fileDownload/getAttachmentDetails';\nimport fileDownload from '../../../../libs/fileDownload';\nimport addEncryptedAuthTokenToURL from '../../../../libs/addEncryptedAuthTokenToURL';\nimport * as Environment from '../../../../libs/Environment/Environment';\nimport Permissions from '../../../../libs/Permissions';\nimport QuickEmojiReactions from '../../../../components/Reactions/QuickEmojiReactions';\nimport MiniQuickEmojiReactions from '../../../../components/Reactions/MiniQuickEmojiReactions';\n\n/**\n * Gets the HTML version of the message in an action.\n * @param {Object} reportAction\n * @return {String}\n */\nfunction getActionText(reportAction) {\n const message = _.last(lodashGet(reportAction, 'message', null));\n return lodashGet(message, 'html', '');\n}\n\nconst CONTEXT_MENU_TYPES = {\n LINK: 'LINK',\n REPORT_ACTION: 'REPORT_ACTION',\n EMAIL: 'EMAIL',\n};\n\n// A list of all the context actions in this menu.\nexport default [\n {\n shouldKeepOpen: true,\n shouldShow: (type, reportAction) => type === CONTEXT_MENU_TYPES.REPORT_ACTION && _.has(reportAction, 'message'),\n renderContent: (closePopover, {\n reportID, reportAction, close: closeManually, openContextMenu,\n }) => {\n const isMini = !closePopover;\n\n const closeContextMenu = (onHideCallback) => {\n if (isMini) {\n closeManually();\n if (onHideCallback) {\n onHideCallback();\n }\n } else {\n hideContextMenu(false, onHideCallback);\n }\n };\n\n const onEmojiSelected = (emoji) => {\n Report.toggleEmojiReaction(reportID, reportAction, emoji);\n closeContextMenu();\n };\n\n if (isMini) {\n return (\n \n );\n }\n\n return (\n \n );\n },\n },\n {\n textTranslateKey: 'common.download',\n icon: Expensicons.Download,\n successTextTranslateKey: 'common.download',\n successIcon: Expensicons.Download,\n shouldShow: (type, reportAction) => {\n const message = _.last(lodashGet(reportAction, 'message', [{}]));\n const isAttachment = _.has(reportAction, 'isAttachment')\n ? reportAction.isAttachment\n : ReportUtils.isReportMessageAttachment(message);\n return isAttachment && reportAction.reportActionID;\n },\n onPress: (closePopover, {reportAction}) => {\n const message = _.last(lodashGet(reportAction, 'message', [{}]));\n const html = lodashGet(message, 'html', '');\n const attachmentDetails = getAttachmentDetails(html);\n const {originalFileName, sourceURL} = attachmentDetails;\n const sourceURLWithAuth = addEncryptedAuthTokenToURL(sourceURL);\n const sourceID = (sourceURL.match(CONST.REGEX.ATTACHMENT_ID) || [])[1];\n Download.setDownload(sourceID, true);\n fileDownload(sourceURLWithAuth, originalFileName).then(() => Download.setDownload(sourceID, false));\n if (closePopover) {\n hideContextMenu(true, ReportActionComposeFocusManager.focus);\n }\n },\n getDescription: () => {},\n },\n {\n textTranslateKey: 'reportActionContextMenu.copyURLToClipboard',\n icon: Expensicons.Copy,\n successTextTranslateKey: 'reportActionContextMenu.copied',\n successIcon: Expensicons.Checkmark,\n shouldShow: type => type === CONTEXT_MENU_TYPES.LINK,\n onPress: (closePopover, {selection}) => {\n Clipboard.setString(selection);\n hideContextMenu(true, ReportActionComposeFocusManager.focus);\n },\n getDescription: selection => selection,\n },\n {\n textTranslateKey: 'reportActionContextMenu.copyEmailToClipboard',\n icon: Expensicons.Copy,\n successTextTranslateKey: 'reportActionContextMenu.copied',\n successIcon: Expensicons.Checkmark,\n shouldShow: type => type === CONTEXT_MENU_TYPES.EMAIL,\n onPress: (closePopover, {selection}) => {\n Clipboard.setString(selection.replace('mailto:', ''));\n hideContextMenu(true, ReportActionComposeFocusManager.focus);\n },\n getDescription: () => {},\n },\n {\n textTranslateKey: 'reportActionContextMenu.copyToClipboard',\n icon: Expensicons.Copy,\n successTextTranslateKey: 'reportActionContextMenu.copied',\n successIcon: Expensicons.Checkmark,\n shouldShow: (type, reportAction) => (type === CONTEXT_MENU_TYPES.REPORT_ACTION\n && reportAction.actionName !== CONST.REPORT.ACTIONS.TYPE.IOU\n && !ReportUtils.isReportMessageAttachment(_.last(lodashGet(reportAction, ['message'], [{}])))),\n\n // If return value is true, we switch the `text` and `icon` on\n // `ContextMenuItem` with `successText` and `successIcon` which will fallback to\n // the `text` and `icon`\n onPress: (closePopover, {reportAction, selection}) => {\n const message = _.last(lodashGet(reportAction, 'message', [{}]));\n const messageHtml = lodashGet(message, 'html', '');\n\n const isAttachment = _.has(reportAction, 'isAttachment')\n ? reportAction.isAttachment\n : ReportUtils.isReportMessageAttachment(message);\n if (!isAttachment) {\n const content = selection || messageHtml;\n if (content) {\n const parser = new ExpensiMark();\n if (!Clipboard.canSetHtml()) {\n Clipboard.setString(parser.htmlToMarkdown(content));\n } else {\n const plainText = Str.htmlDecode(parser.htmlToText(content));\n Clipboard.setHtml(content, plainText);\n }\n }\n } else {\n Clipboard.setString(messageHtml);\n }\n if (closePopover) {\n hideContextMenu(true, ReportActionComposeFocusManager.focus);\n }\n },\n getDescription: () => {},\n },\n\n {\n textTranslateKey: 'reportActionContextMenu.copyLink',\n icon: Expensicons.LinkCopy,\n successIcon: Expensicons.Checkmark,\n successTextTranslateKey: 'reportActionContextMenu.copied',\n shouldShow: (type, reportAction, isArchivedRoom, betas, menuTarget) => {\n const isAttachment = ReportUtils.isReportMessageAttachment(_.last(lodashGet(reportAction, ['message'], [{}])));\n\n // Only hide the copylink menu item when context menu is opened over img element.\n const isAttachmentTarget = lodashGet(menuTarget, 'tagName') === 'IMG' && isAttachment;\n return Permissions.canUseCommentLinking(betas) && type === CONTEXT_MENU_TYPES.REPORT_ACTION && !isAttachmentTarget;\n },\n onPress: (closePopover, {reportAction, reportID}) => {\n Environment.getEnvironmentURL()\n .then((environmentURL) => {\n const reportActionID = parseInt(lodashGet(reportAction, 'reportActionID'), 10);\n Clipboard.setString(`${environmentURL}/r/${reportID}/${reportActionID}`);\n });\n hideContextMenu(true, ReportActionComposeFocusManager.focus);\n },\n getDescription: () => {},\n },\n\n {\n textTranslateKey: 'reportActionContextMenu.markAsUnread',\n icon: Expensicons.Mail,\n successIcon: Expensicons.Checkmark,\n shouldShow: type => type === CONTEXT_MENU_TYPES.REPORT_ACTION,\n onPress: (closePopover, {reportAction, reportID}) => {\n Report.markCommentAsUnread(reportID, reportAction.created);\n if (closePopover) {\n hideContextMenu(true, ReportActionComposeFocusManager.focus);\n }\n },\n getDescription: () => {},\n },\n\n {\n textTranslateKey: 'reportActionContextMenu.editComment',\n icon: Expensicons.Pencil,\n shouldShow: (type, reportAction, isArchivedRoom, betas, menuTarget, isChronosReport) => (\n type === CONTEXT_MENU_TYPES.REPORT_ACTION && ReportUtils.canEditReportAction(reportAction) && !isArchivedRoom && !isChronosReport\n ),\n onPress: (closePopover, {reportID, reportAction, draftMessage}) => {\n const editAction = () => Report.saveReportActionDraft(\n reportID,\n reportAction.reportActionID,\n _.isEmpty(draftMessage) ? getActionText(reportAction) : '',\n );\n\n if (closePopover) {\n // Hide popover, then call editAction\n hideContextMenu(false, editAction);\n return;\n }\n\n // No popover to hide, call editAction immediately\n editAction();\n },\n getDescription: () => {},\n },\n {\n textTranslateKey: 'reportActionContextMenu.deleteComment',\n icon: Expensicons.Trashcan,\n shouldShow: (type, reportAction, isArchivedRoom, betas, menuTarget, isChronosReport) => type === CONTEXT_MENU_TYPES.REPORT_ACTION\n && ReportUtils.canDeleteReportAction(reportAction) && !isArchivedRoom && !isChronosReport,\n onPress: (closePopover, {reportID, reportAction}) => {\n if (closePopover) {\n // Hide popover, then call showDeleteConfirmModal\n hideContextMenu(\n false,\n () => showDeleteModal(reportID, reportAction),\n );\n return;\n }\n\n // No popover to hide, call showDeleteConfirmModal immediately\n showDeleteModal(reportID, reportAction);\n },\n getDescription: () => {},\n },\n];\n\nexport {\n CONTEXT_MENU_TYPES,\n};\n","import _ from 'underscore';\nimport Onyx from 'react-native-onyx';\nimport ONYXKEYS from '../../ONYXKEYS';\n\n/**\n * Set whether an attachment is being downloaded so that a spinner can be shown.\n *\n * @param {String} sourceID\n * @param {Boolean} isDownloading\n * @returns {Promise}\n */\nfunction setDownload(sourceID, isDownloading) {\n return Onyx.merge(`${ONYXKEYS.COLLECTION.DOWNLOAD}${sourceID}`, {isDownloading});\n}\n\nfunction clearDownloads() {\n const connectionID = Onyx.connect({\n key: ONYXKEYS.COLLECTION.DOWNLOAD,\n waitForCollectionCallback: true,\n callback: (records) => {\n Onyx.disconnect(connectionID);\n const downloadsToDelete = {};\n _.each(_.keys(records), recordKey => downloadsToDelete[recordKey] = null);\n if (!_.isEmpty(downloadsToDelete)) {\n Onyx.multiSet(downloadsToDelete);\n }\n },\n });\n}\n\nexport {\n setDownload,\n clearDownloads,\n};\n","import Clipboard from '@react-native-community/clipboard';\n\n/**\n * Sets a string on the Clipboard object via @react-native-community/clipboard\n *\n * @param {String} text\n */\nconst setString = (text) => {\n Clipboard.setString(text);\n};\n\nexport default {\n setString,\n\n // We don't want to set HTML on native platforms so noop them.\n canSetHtml: () => false,\n setHtml: () => {},\n};\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar Clipboard_1 = require(\"./Clipboard\");\nvar useClipboard_1 = require(\"./useClipboard\");\nObject.defineProperty(exports, \"useClipboard\", { enumerable: true, get: function () { return useClipboard_1.useClipboard; } });\nexports.default = Clipboard_1.Clipboard;\n","\"use strict\";\n/**\n * useClipboard.ts\n * This code is inspired from the @react-native-community/hooks package\n * All credit goes to author of the useClipboard custom hooks.\n * https://github.com/react-native-community/hooks\n */\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.useClipboard = void 0;\nvar react_1 = require(\"react\");\nvar Clipboard_1 = require(\"./Clipboard\");\nvar listeners = new Set();\nfunction setString(content) {\n Clipboard_1.Clipboard.setString(content);\n listeners.forEach(function (listener) { return listener(content); });\n}\nexports.useClipboard = function () {\n var _a = react_1.useState(''), data = _a[0], updateClipboardData = _a[1];\n react_1.useEffect(function () {\n Clipboard_1.Clipboard.getString().then(updateClipboardData);\n }, []);\n react_1.useEffect(function () {\n listeners.add(updateClipboardData);\n return function () {\n listeners.delete(updateClipboardData);\n };\n }, []);\n return [data, setString];\n};\n","\"use strict\";\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Clipboard = void 0;\nvar NativeClipboard_1 = __importDefault(require(\"./NativeClipboard\"));\n/**\n * `Clipboard` gives you an interface for setting and getting content from Clipboard on both iOS and Android\n */\nexports.Clipboard = {\n /**\n * Get content of string type, this method returns a `Promise`, so you can use following code to get clipboard content\n * ```javascript\n * async _getContent() {\n * var content = await Clipboard.getString();\n * }\n * ```\n */\n getString: function () {\n return NativeClipboard_1.default.getString();\n },\n /**\n * Set content of string type. You can use following code to set clipboard content\n * ```javascript\n * _setContent() {\n * Clipboard.setString('hello world');\n * }\n * ```\n * @param the content to be stored in the clipboard.\n */\n setString: function (content) {\n NativeClipboard_1.default.setString(content);\n },\n /**\n * Returns whether the clipboard has content or is empty.\n * This method returns a `Promise`, so you can use following code to get clipboard content\n * ```javascript\n * async _hasContent() {\n * var hasContent = await Clipboard.hasString();\n * }\n * ```\n */\n hasString: function () {\n return NativeClipboard_1.default.hasString();\n },\n /**\n * (IOS Only)\n * Returns whether the clipboard has content or is empty.\n * This method returns a `Promise`, so you can use following code to get clipboard content\n * ```javascript\n * async _hasContent() {\n * var hasContent = await Clipboard.hasString();\n * }\n * ```\n */\n hasURL: function () {\n return NativeClipboard_1.default.hasURL();\n },\n};\n","'use strict';\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar react_native_1 = require(\"react-native\");\n// Separated file for Native Clipboard to be ready to switch to Turbo Module when it becomes public\n// TODO: uncomment when Turbo module is available\n// export interface Spec extends TurboModule {\n// +getConstants: () => {||};\n// +getString: () => Promise;\n// +setString: (content: string) => void;\n// +hasString: () => Promise;\n// }\nexports.default = react_native_1.NativeModules.RNCClipboard;\n","import _ from 'underscore';\nimport React from 'react';\n\nconst composerRef = React.createRef();\nlet focusCallback = null;\n\n/**\n * Register a callback to be called when focus is requested.\n * Typical uses of this would be call the focus on the ReportActionComposer.\n *\n * @param {Function} callback callback to register\n */\nfunction onComposerFocus(callback) {\n focusCallback = callback;\n}\n\n/**\n * Request focus on the ReportActionComposer\n *\n */\nfunction focus() {\n if (!_.isFunction(focusCallback)) {\n return;\n }\n\n focusCallback();\n}\n\n/**\n * Clear the registered focus callback\n *\n */\nfunction clear() {\n focusCallback = null;\n}\n\n/**\n * Exposes the current focus state of the report action composer.\n * @return {Boolean} isFocused\n */\nfunction isFocused() {\n return composerRef.current && composerRef.current.isFocused();\n}\n\nexport default {\n composerRef,\n onComposerFocus,\n focus,\n clear,\n isFocused,\n};\n","import CONST from '../../CONST';\nimport tryResolveUrlFromApiRoot from '../tryResolveUrlFromApiRoot';\n\n/**\n * Extract the thumbnail URL, source URL and the original filename from the HTML.\n * @param {String} html\n * @returns {Object}\n */\nexport default function getAttachmentName(html) {\n // Files can be rendered either as anchor tag or as an image so based on that we have to form regex.\n const IS_IMAGE_TAG = //i.test(html);\n const PREVIEW_SOURCE_REGEX = new RegExp(`${CONST.ATTACHMENT_PREVIEW_ATTRIBUTE}*=*\"(.+?)\"`, 'i');\n const SOURCE_REGEX = new RegExp(`${CONST.ATTACHMENT_SOURCE_ATTRIBUTE}*=*\"(.+?)\"`, 'i');\n const ORIGINAL_FILENAME_REGEX = IS_IMAGE_TAG ? new RegExp(`${CONST.ATTACHMENT_ORIGINAL_FILENAME_ATTRIBUTE}*=*\"(.+?)\"`, 'i') : new RegExp(']*>([^<]+)', 'i');\n if (!html) {\n return {\n previewSourceURL: null,\n sourceURL: null,\n originalFileName: null,\n };\n }\n\n // Files created/uploaded/hosted by App should resolve from API ROOT. Other URLs aren't modified\n const sourceURL = tryResolveUrlFromApiRoot(html.match(SOURCE_REGEX)[1]);\n const imageURL = IS_IMAGE_TAG && tryResolveUrlFromApiRoot(html.match(PREVIEW_SOURCE_REGEX)[1]);\n const previewSourceURL = IS_IMAGE_TAG ? imageURL : sourceURL;\n const originalFileName = html.match(ORIGINAL_FILENAME_REGEX)[1];\n\n // Update the image URL so the images can be accessed depending on the config environment\n return {\n previewSourceURL,\n sourceURL,\n originalFileName,\n };\n}\n","import Config from '../CONFIG';\nimport * as ApiUtils from './ApiUtils';\n\n// Absolute URLs (`/` or `//`) should be resolved from API ROOT\n// Legacy attachments can come from either staging or prod, depending on the env they were uploaded by\n// Both should be replaced and loaded from API ROOT of the current environment\nconst ORIGINS_TO_REPLACE = [\n '/+',\n Config.EXPENSIFY.EXPENSIFY_URL,\n Config.EXPENSIFY.STAGING_API_ROOT,\n Config.EXPENSIFY.DEFAULT_API_ROOT,\n];\n\n// Anything starting with a match from ORIGINS_TO_REPLACE\nconst ORIGIN_PATTERN = new RegExp(`^(${ORIGINS_TO_REPLACE.join('|')})`);\n\n/**\n * When possible this function resolve URLs relative to API ROOT\n * - Absolute URLs like `/{path}`, become: `https://{API_ROOT}/{path}`\n * - Similarly for prod or staging URLs we replace the `https://www.expensify`\n * or `https://staging.expensify` part, with `https://{API_ROOT}`\n * - Unmatched URLs (non expensify) are returned with no modifications\n *\n * @param {String} url\n * @returns {String}\n */\nexport default function tryResolveUrlFromApiRoot(url) {\n const apiRoot = ApiUtils.getApiRoot({shouldUseSecure: false});\n return url.replace(ORIGIN_PATTERN, apiRoot);\n}\n","import RNFetchBlob from 'react-native-blob-util';\nimport {CameraRoll} from '@react-native-camera-roll/camera-roll';\nimport lodashGet from 'lodash/get';\nimport * as FileUtils from './FileUtils';\nimport CONST from '../../CONST';\n\n/**\n * Downloads the file to Documents section in iOS\n * @param {String} fileUrl\n * @param {String} fileName\n * @returns {Promise}\n */\nfunction downloadFile(fileUrl, fileName) {\n const dirs = RNFetchBlob.fs.dirs;\n\n // The iOS files will download to documents directory\n const path = dirs.DocumentDir;\n\n // Fetching the attachment\n const fetchedAttachment = RNFetchBlob.config({\n fileCache: true,\n path: `${path}/${fileName}`,\n addAndroidDownloads: {\n useDownloadManager: true,\n notification: true,\n path: `${path}/Expensify/${fileName}`,\n },\n }).fetch('GET', fileUrl);\n return fetchedAttachment;\n}\n\n/**\n * Download the image to photo lib in iOS\n * @param {String} fileUrl\n * @param {String} fileName\n * @returns {String} URI\n */\nfunction downloadImage(fileUrl) {\n return CameraRoll.save(fileUrl);\n}\n\n/**\n * Download the video to photo lib in iOS\n * @param {String} fileUrl\n * @param {String} fileName\n * @returns {String} URI\n */\nfunction downloadVideo(fileUrl, fileName) {\n return new Promise((resolve, reject) => {\n let documentPathUri = null;\n let cameraRollUri = null;\n\n // Because CameraRoll doesn't allow direct downloads of video with remote URIs, we first download as documents, then copy to photo lib and unlink the original file.\n downloadFile(fileUrl, fileName).then((attachment) => {\n documentPathUri = lodashGet(attachment, 'data');\n return CameraRoll.save(documentPathUri);\n }).then((attachment) => {\n cameraRollUri = attachment;\n return RNFetchBlob.fs.unlink(documentPathUri);\n }).then(() => resolve(cameraRollUri))\n .catch(err => reject(err));\n });\n}\n\n/**\n * Download the file based on type(image, video, other file types)for iOS\n * @param {String} fileUrl\n * @param {String} fileName\n * @returns {Promise}\n */\nexport default function fileDownload(fileUrl, fileName) {\n return new Promise((resolve) => {\n let fileDownloadPromise = null;\n const fileType = FileUtils.getFileType(fileUrl);\n const attachmentName = fileName || FileUtils.getAttachmentName(fileUrl);\n\n switch (fileType) {\n case CONST.ATTACHMENT_FILE_TYPE.IMAGE:\n fileDownloadPromise = downloadImage(fileUrl, attachmentName);\n break;\n case CONST.ATTACHMENT_FILE_TYPE.VIDEO:\n fileDownloadPromise = downloadVideo(fileUrl, attachmentName);\n break;\n default:\n fileDownloadPromise = downloadFile(fileUrl, attachmentName);\n break;\n }\n\n fileDownloadPromise.then((attachment) => {\n if (!attachment) {\n return;\n }\n\n FileUtils.showSuccessAlert();\n }).catch((err) => {\n // iOS shows permission popup only once. Subsequent request will only throw an error.\n // We catch the error and show a redirection link to the settings screen\n if (err.message === CONST.IOS_CAMERAROLL_ACCESS_ERROR) {\n FileUtils.showPermissionErrorAlert();\n } else {\n FileUtils.showGeneralErrorAlert();\n }\n }).finally(() => resolve());\n });\n}\n","// Copyright 2016 wkh237@github. All rights reserved.\r\n// Use of this source code is governed by a MIT-style license that can be\r\n// found in the LICENSE file.\r\n\r\nimport {AppState, DeviceEventEmitter, NativeModules, Platform,} from 'react-native';\r\n\r\n//import StatefulPromise from './class/StatefulPromise.js'\r\nimport fs from './fs';\r\nimport MediaCollection from './mediacollection';\r\nimport base64 from 'base-64';\r\nimport polyfill from './polyfill';\r\nimport android from './android';\r\nimport ios from './ios';\r\nimport JSONStream from './json-stream';\r\nimport {config, fetch} from './fetch';\r\nimport URIUtil from \"./utils/uri\";\r\n\r\nconst {\r\n ReactNativeBlobUtilSession,\r\n readStream,\r\n createFile,\r\n unlink,\r\n exists,\r\n mkdir,\r\n session,\r\n writeStream,\r\n readFile,\r\n ls,\r\n isDir,\r\n mv,\r\n cp\r\n} = fs;\r\n\r\nconst Blob = polyfill.Blob;\r\nconst emitter = DeviceEventEmitter;\r\nconst ReactNativeBlobUtil = NativeModules.ReactNativeBlobUtil;\r\nconst wrap = URIUtil.wrap;\r\n\r\n// when app resumes, check if there's any expired network task and trigger\r\n// their .expire event\r\nif (Platform.OS === 'ios') {\r\n AppState.addEventListener('change', (e) => {\r\n if (e === 'active')\r\n ReactNativeBlobUtil.emitExpiredEvent(() => {\r\n });\r\n });\r\n}\r\n\r\n// Show warning if native module not detected\r\nif (!ReactNativeBlobUtil || !ReactNativeBlobUtil.fetchBlobForm || !ReactNativeBlobUtil.fetchBlob) {\r\n console.warn(\r\n 'react-native-blob-util could not find valid native module.',\r\n 'please make sure you have linked native modules using `rnpm link`,',\r\n 'and restart RN packager or manually compile IOS/Android project.'\r\n );\r\n}\r\n\r\nexport {ReactNativeBlobUtilConfig, ReactNativeBlobUtilResponseInfo, ReactNativeBlobUtilStream} from './types';\r\nexport { URIUtil } from './utils/uri';\r\nexport {FetchBlobResponse} from './class/ReactNativeBlobUtilBlobResponse';\r\nexport { getUUID } from './utils/uuid';\r\nexport default {\r\n fetch,\r\n base64,\r\n android,\r\n ios,\r\n config,\r\n session,\r\n fs,\r\n wrap,\r\n polyfill,\r\n JSONStream,\r\n MediaCollection\r\n};\r\n","import {ReactNativeBlobUtilResponseInfo, ReactNativeBlobUtilStream} from \"../types\";\r\nimport fs from \"../fs\";\r\nimport Blob from \"../polyfill/Blob\";\r\nimport ReactNativeBlobUtilSession from \"./ReactNativeBlobUtilSession\";\r\nimport URIUtil from \"../utils/uri\";\r\nimport base64 from \"base-64\";\r\n/**\r\n * ReactNativeBlobUtil response object class.\r\n */\r\nexport class FetchBlobResponse {\r\n\r\n taskId: string;\r\n path: () => string | null;\r\n type: 'base64' | 'path' | 'utf8';\r\n data: any;\r\n blob: (contentType: string, sliceSize: number) => Promise;\r\n text: () => string | Promise;\r\n json: () => any;\r\n base64: () => any;\r\n flush: () => void;\r\n respInfo: ReactNativeBlobUtilResponseInfo;\r\n session: (name: string) => ReactNativeBlobUtilSession | null;\r\n readFile: (encode: 'base64' | 'utf8' | 'ascii') => ?Promise;\r\n readStream: (\r\n encode: 'utf8' | 'ascii' | 'base64',\r\n ) => ReactNativeBlobUtilStream | null;\r\n\r\n constructor(taskId: string, info: ReactNativeBlobUtilResponseInfo, data: any) {\r\n this.data = data;\r\n this.taskId = taskId;\r\n this.type = info.rnfbEncode;\r\n this.respInfo = info;\r\n\r\n this.info = (): ReactNativeBlobUtilResponseInfo => {\r\n return this.respInfo;\r\n };\r\n\r\n this.array = (): Promise => {\r\n let cType = info.headers['Content-Type'] || info.headers['content-type'];\r\n return new Promise((resolve, reject) => {\r\n switch (this.type) {\r\n case 'base64':\r\n // TODO : base64 to array buffer\r\n break;\r\n case 'path':\r\n fs.readFile(this.data, 'ascii').then(resolve);\r\n break;\r\n default:\r\n // TODO : text to array buffer\r\n break;\r\n }\r\n });\r\n };\r\n\r\n /**\r\n * Convert result to javascript ReactNativeBlobUtil object.\r\n * @return {Promise} Return a promise resolves Blob object.\r\n */\r\n this.blob = (): Promise => {\r\n let cType = info.headers['Content-Type'] || info.headers['content-type'];\r\n return new Promise((resolve, reject) => {\r\n switch (this.type) {\r\n case 'base64':\r\n Blob.build(this.data, {type: cType + ';BASE64'}).then(resolve);\r\n break;\r\n case 'path':\r\n Blob.build(URIUtil.wrap(this.data), {type: cType}).then(resolve);\r\n break;\r\n default:\r\n Blob.build(this.data, {type: 'text/plain'}).then(resolve);\r\n break;\r\n }\r\n });\r\n };\r\n /**\r\n * Convert result to text.\r\n * @return {string} Decoded base64 string.\r\n */\r\n this.text = (): string | Promise => {\r\n switch (this.type) {\r\n case 'base64':\r\n return base64.decode(this.data);\r\n case 'path':\r\n return fs.readFile(this.data, 'base64').then((b64) => Promise.resolve(base64.decode(b64)));\r\n default:\r\n return this.data;\r\n }\r\n };\r\n /**\r\n * Convert result to JSON object.\r\n * @return {object} Parsed javascript object.\r\n */\r\n this.json = (): any => {\r\n switch (this.type) {\r\n case 'base64':\r\n return JSON.parse(base64.decode(this.data));\r\n case 'path':\r\n return fs.readFile(this.data, 'utf8')\r\n .then((text) => Promise.resolve(JSON.parse(text)));\r\n default:\r\n return JSON.parse(this.data);\r\n }\r\n };\r\n /**\r\n * Return BASE64 string directly.\r\n * @return {string} BASE64 string of response body.\r\n */\r\n this.base64 = (): string | Promise => {\r\n switch (this.type) {\r\n case 'base64':\r\n return this.data;\r\n case 'path':\r\n return fs.readFile(this.data, 'base64');\r\n default:\r\n return base64.encode(this.data);\r\n }\r\n };\r\n /**\r\n * Remove cahced file\r\n * @return {Promise}\r\n */\r\n this.flush = () => {\r\n let path = this.path();\r\n if (!path || this.type !== 'path')\r\n return;\r\n return fs.unlink(path);\r\n };\r\n /**\r\n * get path of response temp file\r\n * @return {string} File path of temp file.\r\n */\r\n this.path = () => {\r\n if (this.type === 'path')\r\n return this.data;\r\n return null;\r\n };\r\n\r\n this.session = (name: string): ReactNativeBlobUtilSession | null => {\r\n if (this.type === 'path')\r\n return fs.session(name).add(this.data);\r\n else {\r\n console.warn('only file paths can be add into session.');\r\n return null;\r\n }\r\n };\r\n /**\r\n * Start read stream from cached file\r\n * @param {String} encoding Encode type, should be one of `base64`, `ascii`, `utf8`.\r\n * @return {void}\r\n */\r\n this.readStream = (encoding: 'base64' | 'utf8' | 'ascii'): ReactNativeBlobUtilStream | null => {\r\n if (this.type === 'path') {\r\n return fs.readStream(this.data, encoding);\r\n }\r\n else {\r\n console.warn('ReactNativeBlobUtil', 'this response data does not contains any available stream');\r\n return null;\r\n }\r\n };\r\n /**\r\n * Read file content with given encoding, if the response does not contains\r\n * a file path, show warning message\r\n * @param {String} encoding Encode type, should be one of `base64`, `ascrii`, `utf8`.\r\n * @return {String}\r\n */\r\n this.readFile = (encoding: 'base64' | 'utf8' | 'ascii') => {\r\n if (this.type === 'path') {\r\n return fs.readFile(this.data, encoding);\r\n }\r\n else {\r\n console.warn('ReactNativeBlobUtil', 'this response does not contains a readable file');\r\n return null;\r\n }\r\n };\r\n }\r\n\r\n}","// Copyright 2016 wkh237@github. All rights reserved.\r\n// Use of this source code is governed by a MIT-style license that can be\r\n// found in the LICENSE file.\r\n\r\n// import type {ReactNativeBlobUtilConfig, ReactNativeBlobUtilNative, ReactNativeBlobUtilStream} from './types'\r\n\r\nimport {NativeModules, Platform} from 'react-native';\r\nimport ReactNativeBlobUtilSession from './class/ReactNativeBlobUtilSession';\r\nimport ReactNativeBlobUtilWriteStream from './class/ReactNativeBlobUtilWriteStream';\r\nimport ReactNativeBlobUtilReadStream from './class/ReactNativeBlobUtilReadStream';\r\nimport ReactNativeBlobUtilFile from './class/ReactNativeBlobUtilFile';\r\n\r\nconst ReactNativeBlobUtil: ReactNativeBlobUtilNative = NativeModules.ReactNativeBlobUtil;\r\n\r\nconst dirs = {\r\n DocumentDir: ReactNativeBlobUtil.DocumentDir,\r\n CacheDir: ReactNativeBlobUtil.CacheDir,\r\n PictureDir: ReactNativeBlobUtil.PictureDir,\r\n MusicDir: ReactNativeBlobUtil.MusicDir,\r\n MovieDir: ReactNativeBlobUtil.MovieDir,\r\n DownloadDir: ReactNativeBlobUtil.DownloadDir,\r\n DCIMDir: ReactNativeBlobUtil.DCIMDir,\r\n SDCardDir: ReactNativeBlobUtil.SDCardDir, // Depracated\r\n SDCardApplicationDir: ReactNativeBlobUtil.SDCardApplicationDir, // Deprecated\r\n MainBundleDir: ReactNativeBlobUtil.MainBundleDir,\r\n LibraryDir: ReactNativeBlobUtil.LibraryDir,\r\n ApplicationSupportDir: ReactNativeBlobUtil.ApplicationSupportDir\r\n};\r\n\r\nfunction addCode(code: string, error: Error): Error {\r\n error.code = code;\r\n return error;\r\n}\r\n\r\n/**\r\n * Get a file cache session\r\n * @param {string} name Stream ID\r\n * @return {ReactNativeBlobUtilSession}\r\n */\r\nfunction session(name: string): ReactNativeBlobUtilSession {\r\n let s = ReactNativeBlobUtilSession.getSession(name);\r\n if (s)\r\n return new ReactNativeBlobUtilSession(name);\r\n else {\r\n ReactNativeBlobUtilSession.setSession(name, []);\r\n return new ReactNativeBlobUtilSession(name, []);\r\n }\r\n}\r\n\r\nfunction asset(path: string): string {\r\n if (Platform.OS === 'ios') {\r\n // path from camera roll\r\n if (/^assets-library\\:\\/\\//.test(path))\r\n return path;\r\n }\r\n return 'bundle-assets://' + path;\r\n}\r\n\r\nfunction createFile(path: string, data: string, encoding: 'base64' | 'ascii' | 'utf8' = 'utf8'): Promise {\r\n if (encoding.toLowerCase() === 'ascii') {\r\n return Array.isArray(data) ?\r\n ReactNativeBlobUtil.createFileASCII(path, data) :\r\n Promise.reject(addCode('EINVAL', new TypeError('`data` of ASCII file must be an array with 0..255 numbers')));\r\n }\r\n else {\r\n return ReactNativeBlobUtil.createFile(path, data, encoding);\r\n }\r\n}\r\n\r\n/**\r\n * Create write stream to a file.\r\n * @param {string} path Target path of file stream.\r\n * @param {string} encoding Encoding of input data.\r\n * @param {boolean} [append] A flag represent if data append to existing ones.\r\n * @return {Promise} A promise resolves a `WriteStream` object.\r\n */\r\nfunction writeStream(\r\n path: string,\r\n encoding?: 'utf8' | 'ascii' | 'base64' = 'utf8',\r\n append?: boolean = false,\r\n): Promise {\r\n if (typeof path !== 'string') {\r\n return Promise.reject(addCode('EINVAL', new TypeError('Missing argument \"path\" ')));\r\n }\r\n return new Promise((resolve, reject) => {\r\n ReactNativeBlobUtil.writeStream(path, encoding, append, (errCode, errMsg, streamId: string) => {\r\n if (errMsg) {\r\n const err = new Error(errMsg);\r\n err.code = errCode;\r\n reject(err);\r\n }\r\n else\r\n resolve(new ReactNativeBlobUtilWriteStream(streamId, encoding));\r\n });\r\n });\r\n}\r\n\r\n/**\r\n * Create file stream from file at `path`.\r\n * @param {string} path The file path.\r\n * @param {string} encoding Data encoding, should be one of `base64`, `utf8`, `ascii`\r\n * @param {boolean} bufferSize Size of stream buffer.\r\n * @param {number} [tick=10] Interval in milliseconds between reading chunks of data\r\n * @return {ReactNativeBlobUtilStream} ReactNativeBlobUtilStream stream instance.\r\n */\r\nfunction readStream(\r\n path: string,\r\n encoding: 'utf8' | 'ascii' | 'base64' = 'utf8',\r\n bufferSize?: number,\r\n tick?: number = 10\r\n): Promise {\r\n if (typeof path !== 'string') {\r\n return Promise.reject(addCode('EINVAL', new TypeError('Missing argument \"path\" ')));\r\n }\r\n return Promise.resolve(new ReactNativeBlobUtilReadStream(path, encoding, bufferSize, tick));\r\n}\r\n\r\n/**\r\n * Create a directory.\r\n * @param {string} path Path of directory to be created\r\n * @return {Promise}\r\n */\r\nfunction mkdir(path: string): Promise {\r\n if (typeof path !== 'string') {\r\n return Promise.reject(addCode('EINVAL', new TypeError('Missing argument \"path\" ')));\r\n }\r\n return ReactNativeBlobUtil.mkdir(path);\r\n}\r\n\r\n/**\r\n * Returns the path for the app group.\r\n * @param {string} groupName Name of app group\r\n * @return {Promise}\r\n */\r\nfunction pathForAppGroup(groupName: string): Promise {\r\n return ReactNativeBlobUtil.pathForAppGroup(groupName);\r\n}\r\n\r\n/**\r\n * Returns the path for the app group synchronous.\r\n * @param {string} groupName Name of app group\r\n * @return {string} Path of App Group dir\r\n */\r\nfunction syncPathAppGroup(groupName: string): string {\r\n if (Platform.OS === 'ios') {\r\n return ReactNativeBlobUtil.syncPathAppGroup(groupName);\r\n }\r\n else {\r\n return '';\r\n }\r\n}\r\n\r\n/**\r\n * Wrapper method of readStream.\r\n * @param {string} path Path of the file.\r\n * @param {'base64' | 'utf8' | 'ascii'} encoding Encoding of read stream.\r\n * @return {Promise | string>}\r\n */\r\nfunction readFile(path: string, encoding: string = 'utf8'): Promise {\r\n if (typeof path !== 'string') {\r\n return Promise.reject(addCode('EINVAL', new TypeError('Missing argument \"path\" ')));\r\n }\r\n return ReactNativeBlobUtil.readFile(path, encoding, false);\r\n}\r\n\r\n/**\r\n * Reads the file, then transforms it before returning the content\r\n * @param {string} path Path of the file.\r\n * @param {'base64' | 'utf8' | 'ascii'} encoding Encoding of read stream.\r\n * @return {Promise | string>}\r\n */\r\nfunction readFileWithTransform(path: string, encoding: string = 'utf8'): Promise {\r\n if (typeof path !== 'string') {\r\n return Promise.reject(addCode('EINVAL', new TypeError('Missing argument \"path\" ')))\r\n }\r\n return ReactNativeBlobUtil.readFile(path, encoding, true);\r\n}\r\n\r\n/**\r\n * Write data to file.\r\n * @param {string} path Path of the file.\r\n * @param {string | number[]} data Data to write to the file.\r\n * @param {string} encoding Encoding of data (Optional).\r\n * @return {Promise}\r\n */\r\nfunction writeFile(path: string, data: string | Array, encoding: ?string = 'utf8'): Promise {\r\n if (typeof path !== 'string') {\r\n return Promise.reject(addCode('EINVAL', new TypeError('Missing argument \"path\" ')));\r\n }\r\n if (encoding.toLocaleLowerCase() === 'ascii') {\r\n if (!Array.isArray(data)) {\r\n return Promise.reject(addCode('EINVAL', new TypeError('\"data\" must be an Array when encoding is \"ascii\"')));\r\n }\r\n else\r\n return ReactNativeBlobUtil.writeFileArray(path, data, false);\r\n }\r\n else {\r\n if (typeof data !== 'string') {\r\n return Promise.reject(addCode('EINVAL', new TypeError(`\"data\" must be a String when encoding is \"utf8\" or \"base64\", but it is \"${typeof data}\"`)));\r\n }\r\n else\r\n return ReactNativeBlobUtil.writeFile(path, encoding, data, false, false);\r\n }\r\n}\r\n\r\n/**\r\n * Transforms the data and then writes to the file.\r\n * @param {string} path Path of the file.\r\n * @param {string | number[]} data Data to write to the file.\r\n * @param {string} encoding Encoding of data (Optional).\r\n * @return {Promise}\r\n */\r\nfunction writeFileWithTransform(path: string, data: string | Array, encoding: ?string = 'utf8'): Promise {\r\n if (typeof path !== 'string') {\r\n return Promise.reject(addCode('EINVAL', new TypeError('Missing argument \"path\" ')))\r\n }\r\n if (encoding.toLocaleLowerCase() === 'ascii') {\r\n return Promise.reject(addCode('EINVAL', new TypeError('ascii is not supported for converted files')))\r\n }\r\n else {\r\n if (typeof data !== 'string') {\r\n return Promise.reject(addCode('EINVAL', new TypeError(`\"data\" must be a String when encoding is \"utf8\" or \"base64\", but it is \"${typeof data}\"`)))\r\n }\r\n\r\n else\r\n return ReactNativeBlobUtil.writeFile(path, encoding, data, true, false)\r\n }\r\n}\r\n\r\nfunction appendFile(path: string, data: string | Array, encoding?: string = 'utf8'): Promise {\r\n if (typeof path !== 'string') {\r\n return Promise.reject(addCode('EINVAL', new TypeError('Missing argument \"path\" ')));\r\n }\r\n if (encoding.toLocaleLowerCase() === 'ascii') {\r\n if (!Array.isArray(data)) {\r\n return Promise.reject(addCode('EINVAL', new TypeError('`data` of ASCII file must be an array with 0..255 numbers')));\r\n }\r\n else\r\n return ReactNativeBlobUtil.writeFileArray(path, data, true);\r\n }\r\n else {\r\n if (typeof data !== 'string') {\r\n return Promise.reject(addCode('EINVAL'), new TypeError(`\"data\" must be a String when encoding is \"utf8\" or \"base64\", but it is \"${typeof data}\"`));\r\n }\r\n else\r\n return ReactNativeBlobUtil.writeFile(path, encoding, data, false, true);\r\n }\r\n}\r\n\r\n/**\r\n * Show statistic data of a path.\r\n * @param {string} path Target path\r\n * @return {ReactNativeBlobUtilFile}\r\n */\r\nfunction stat(path: string): Promise {\r\n return new Promise((resolve, reject) => {\r\n if (typeof path !== 'string') {\r\n return reject(addCode('EINVAL', new TypeError('Missing argument \"path\" ')));\r\n }\r\n ReactNativeBlobUtil.stat(path, (err, stat) => {\r\n if (err)\r\n reject(new Error(err));\r\n else {\r\n if (stat) {\r\n stat.size = parseInt(stat.size);\r\n stat.lastModified = parseInt(stat.lastModified);\r\n }\r\n resolve(stat);\r\n }\r\n });\r\n });\r\n}\r\n\r\n/**\r\n * Android only method, request media scanner to scan the file.\r\n * @param {Array>} pairs Array contains Key value pairs with key `path` and `mime`.\r\n * @return {Promise}\r\n */\r\nfunction scanFile(pairs: any): Promise {\r\n return new Promise((resolve, reject) => {\r\n if (pairs === undefined) {\r\n return reject(addCode('EINVAL', new TypeError('Missing argument')));\r\n }\r\n ReactNativeBlobUtil.scanFile(pairs, (err) => {\r\n if (err)\r\n reject(addCode('EUNSPECIFIED', new Error(err)));\r\n else\r\n resolve();\r\n });\r\n });\r\n}\r\n\r\nfunction hash(path: string, algorithm: string): Promise {\r\n if (typeof path !== 'string' || typeof algorithm !== 'string') {\r\n return Promise.reject(addCode('EINVAL', new TypeError('Missing argument \"path\" and/or \"algorithm\"')));\r\n }\r\n return ReactNativeBlobUtil.hash(path, algorithm);\r\n}\r\n\r\nfunction cp(path: string, dest: string): Promise {\r\n return new Promise((resolve, reject) => {\r\n if (typeof path !== 'string' || typeof dest !== 'string') {\r\n return reject(addCode('EINVAL', new TypeError('Missing argument \"path\" and/or \"destination\"')));\r\n }\r\n ReactNativeBlobUtil.cp(path, dest, (err, res) => {\r\n if (err)\r\n reject(addCode('EUNSPECIFIED', new Error(err)));\r\n else\r\n resolve(res);\r\n });\r\n });\r\n}\r\n\r\nfunction mv(path: string, dest: string): Promise {\r\n return new Promise((resolve, reject) => {\r\n if (typeof path !== 'string' || typeof dest !== 'string') {\r\n return reject(addCode('EINVAL', new TypeError('Missing argument \"path\" and/or \"destination\"')));\r\n }\r\n ReactNativeBlobUtil.mv(path, dest, (err, res) => {\r\n if (err)\r\n reject(addCode('EUNSPECIFIED', new Error(err)));\r\n else\r\n resolve(res);\r\n });\r\n });\r\n}\r\n\r\nfunction lstat(path: string): Promise> {\r\n return new Promise((resolve, reject) => {\r\n if (typeof path !== 'string') {\r\n return reject(addCode('EINVAL', new TypeError('Missing argument \"path\" ')));\r\n }\r\n ReactNativeBlobUtil.lstat(path, (err, stat) => {\r\n if (err)\r\n reject(addCode('EUNSPECIFIED', new Error(err)));\r\n else\r\n resolve(stat);\r\n });\r\n });\r\n}\r\n\r\nfunction ls(path: string): Promise> {\r\n if (typeof path !== 'string') {\r\n return Promise.reject(addCode('EINVAL', new TypeError('Missing argument \"path\" ')));\r\n }\r\n return ReactNativeBlobUtil.ls(path);\r\n}\r\n\r\n/**\r\n * Remove file at path.\r\n * @param {string} path:string Path of target file.\r\n * @return {Promise}\r\n */\r\nfunction unlink(path: string): Promise {\r\n return new Promise((resolve, reject) => {\r\n if (typeof path !== 'string') {\r\n return reject(addCode('EINVAL', new TypeError('Missing argument \"path\" ')));\r\n }\r\n ReactNativeBlobUtil.unlink(path, (err) => {\r\n if (err) {\r\n reject(addCode('EUNSPECIFIED', new Error(err)));\r\n }\r\n else\r\n resolve();\r\n });\r\n });\r\n}\r\n\r\n/**\r\n * Check if file exists and if it is a folder.\r\n * @param {string} path Path to check\r\n * @return {Promise}\r\n */\r\nfunction exists(path: string): Promise {\r\n return new Promise((resolve, reject) => {\r\n if (typeof path !== 'string') {\r\n return reject(addCode('EINVAL', new TypeError('Missing argument \"path\" ')));\r\n }\r\n try {\r\n ReactNativeBlobUtil.exists(path, (exist) => {\r\n resolve(exist);\r\n });\r\n } catch (err) {\r\n reject(addCode('EUNSPECIFIED', new Error(err)));\r\n }\r\n });\r\n\r\n}\r\n\r\nfunction slice(src: string, dest: string, start: number, end: number): Promise {\r\n if (typeof src !== 'string' || typeof dest !== 'string') {\r\n return reject(addCode('EINVAL', new TypeError('Missing argument \"src\" and/or \"destination\"')));\r\n }\r\n\r\n let p = Promise.resolve();\r\n let size = 0;\r\n\r\n function normalize(num, size) {\r\n if (num < 0)\r\n return Math.max(0, size + num);\r\n if (!num && num !== 0)\r\n return size;\r\n return num;\r\n }\r\n\r\n if (start < 0 || end < 0 || !start || !end) {\r\n p = p.then(() => stat(src))\r\n .then((stat) => {\r\n size = Math.floor(stat.size);\r\n start = normalize(start || 0, size);\r\n end = normalize(end, size);\r\n });\r\n }\r\n return p.then(() => ReactNativeBlobUtil.slice(src, dest, start, end));\r\n}\r\n\r\nfunction isDir(path: string): Promise {\r\n return new Promise((resolve, reject) => {\r\n if (typeof path !== 'string') {\r\n return reject(addCode('EINVAL', new TypeError('Missing argument \"path\" ')));\r\n }\r\n try {\r\n ReactNativeBlobUtil.exists(path, (exist, isDir) => {\r\n resolve(isDir);\r\n });\r\n } catch (err) {\r\n reject(addCode('EUNSPECIFIED', new Error(err)));\r\n }\r\n });\r\n\r\n}\r\n\r\nfunction df(): Promise<{ free: number, total: number }> {\r\n return new Promise((resolve, reject) => {\r\n ReactNativeBlobUtil.df((err, stat) => {\r\n if (err)\r\n reject(addCode('EUNSPECIFIED', new Error(err)));\r\n else\r\n resolve(stat);\r\n });\r\n });\r\n}\r\n\r\nexport default {\r\n ReactNativeBlobUtilSession,\r\n unlink,\r\n mkdir,\r\n session,\r\n ls,\r\n readStream,\r\n mv,\r\n cp,\r\n writeStream,\r\n writeFile,\r\n writeFileWithTransform,\r\n readFileWithTransform,\r\n appendFile,\r\n pathForAppGroup,\r\n syncPathAppGroup,\r\n readFile,\r\n hash,\r\n exists,\r\n createFile,\r\n isDir,\r\n stat,\r\n lstat,\r\n scanFile,\r\n dirs,\r\n slice,\r\n asset,\r\n df\r\n};\r\n","// Copyright 2016 wkh237@github. All rights reserved.\r\n// Use of this source code is governed by a MIT-style license that can be\r\n// found in the LICENSE file.\r\n\r\nimport {\r\n NativeModules,\r\n DeviceEventEmitter,\r\n NativeAppEventEmitter,\r\n} from 'react-native';\r\n\r\nconst ReactNativeBlobUtil = NativeModules.ReactNativeBlobUtil;\r\n\r\nlet sessions = {};\r\n\r\nexport default class ReactNativeBlobUtilSession {\r\n\r\n name : string;\r\n\r\n static getSession(name:string):any {\r\n return sessions[name];\r\n }\r\n\r\n static setSession(name:string, val:any) {\r\n sessions[name] = val;\r\n }\r\n\r\n static removeSession(name:string) {\r\n delete sessions[name];\r\n }\r\n\r\n constructor(name:string, list:Array) {\r\n this.name = name;\r\n if(!sessions[name]) {\r\n if(Array.isArray(list))\r\n sessions[name] = list;\r\n else\r\n sessions[name] = [];\r\n }\r\n }\r\n\r\n add(path:string):ReactNativeBlobUtilSession {\r\n sessions[this.name].push(path);\r\n return this;\r\n }\r\n\r\n remove(path:string):ReactNativeBlobUtilSession {\r\n let list = sessions[this.name];\r\n for(let i of list) {\r\n if(list[i] === path) {\r\n sessions[this.name].splice(i, 1);\r\n break;\r\n }\r\n }\r\n return this;\r\n }\r\n\r\n list():Array {\r\n return sessions[this.name];\r\n }\r\n\r\n dispose():Promise {\r\n return new Promise((resolve, reject) => {\r\n ReactNativeBlobUtil.removeSession(sessions[this.name], (err) => {\r\n if(err)\r\n reject(new Error(err));\r\n else {\r\n delete sessions[this.name];\r\n resolve();\r\n }\r\n });\r\n });\r\n }\r\n\r\n}\r\n","// Copyright 2016 wkh237@github. All rights reserved.\r\n// Use of this source code is governed by a MIT-style license that can be\r\n// found in the LICENSE file.\r\n\r\nimport {\r\n NativeModules,\r\n DeviceEventEmitter,\r\n NativeAppEventEmitter,\r\n} from 'react-native';\r\n\r\nconst ReactNativeBlobUtil = NativeModules.ReactNativeBlobUtil;\r\n\r\nexport default class ReactNativeBlobUtilWriteStream {\r\n\r\n id : string;\r\n encoding : string;\r\n append : boolean;\r\n\r\n constructor(streamId:string, encoding:string, append:boolean) {\r\n this.id = streamId;\r\n this.encoding = encoding;\r\n this.append = append;\r\n }\r\n\r\n write(data:string): Promise {\r\n return new Promise((resolve, reject) => {\r\n try {\r\n let method = this.encoding === 'ascii' ? 'writeArrayChunk' : 'writeChunk';\r\n if(this.encoding.toLocaleLowerCase() === 'ascii' && !Array.isArray(data)) {\r\n reject(new Error('ascii input data must be an Array'));\r\n return;\r\n }\r\n ReactNativeBlobUtil[method](this.id, data, (error) => {\r\n if(error)\r\n reject(new Error(error));\r\n else\r\n resolve(this);\r\n });\r\n } catch(err) {\r\n reject(new Error(err));\r\n }\r\n });\r\n }\r\n\r\n close() {\r\n return new Promise((resolve, reject) => {\r\n try {\r\n ReactNativeBlobUtil.closeStream(this.id, () => {\r\n resolve();\r\n });\r\n } catch (err) {\r\n reject(new Error(err));\r\n }\r\n });\r\n }\r\n\r\n}\r\n","// Copyright 2016 wkh237@github. All rights reserved.\r\n// Use of this source code is governed by a MIT-style license that can be\r\n// found in the LICENSE file.\r\n\r\nimport {\r\n NativeModules,\r\n DeviceEventEmitter,\r\n NativeAppEventEmitter,\r\n} from 'react-native';\r\nimport UUID from '../utils/uuid';\r\n\r\nconst ReactNativeBlobUtil = NativeModules.ReactNativeBlobUtil;\r\nconst emitter = DeviceEventEmitter;\r\n\r\nexport default class ReactNativeBlobUtilReadStream {\r\n\r\n path : string;\r\n encoding : 'utf8' | 'ascii' | 'base64';\r\n bufferSize : ?number;\r\n closed : boolean;\r\n tick : number = 10;\r\n\r\n constructor(path:string, encoding:string, bufferSize?:?number, tick:number) {\r\n if(!path)\r\n throw Error('ReactNativeBlobUtil could not open file stream with empty `path`');\r\n this.encoding = encoding || 'utf8';\r\n this.bufferSize = bufferSize;\r\n this.path = path;\r\n this.closed = false;\r\n this.tick = tick;\r\n this._onData = () => {};\r\n this._onEnd = () => {};\r\n this._onError = () => {};\r\n this.streamId = 'RNFBRS'+ UUID();\r\n\r\n // register for file stream event\r\n let subscription = emitter.addListener(this.streamId, (e) => {\r\n let {event, code, detail} = e;\r\n if(this._onData && event === 'data') {\r\n this._onData(detail);\r\n return;\r\n }\r\n else if (this._onEnd && event === 'end') {\r\n this._onEnd(detail);\r\n }\r\n else {\r\n const err = new Error(detail);\r\n err.code = code || 'EUNSPECIFIED';\r\n if(this._onError)\r\n this._onError(err);\r\n else\r\n throw err;\r\n }\r\n // when stream closed or error, remove event handler\r\n if (event === 'error' || event === 'end') {\r\n subscription.remove();\r\n this.closed = true;\r\n }\r\n });\r\n\r\n }\r\n\r\n open() {\r\n if(!this.closed)\r\n ReactNativeBlobUtil.readStream(this.path, this.encoding, this.bufferSize || 10240 , this.tick || -1, this.streamId);\r\n else\r\n throw new Error('Stream closed');\r\n }\r\n\r\n onData(fn:() => void) {\r\n this._onData = fn;\r\n }\r\n\r\n onError(fn) {\r\n this._onError = fn;\r\n }\r\n\r\n onEnd (fn) {\r\n this._onEnd = fn;\r\n }\r\n\r\n}\r\n","export default function getUUID() {\r\n return Math.random().toString(36).substring(2, 15) +\r\n Math.random().toString(36).substring(2, 15);\r\n}\r\n","// Copyright 2016 wkh237@github. All rights reserved.\r\n// Use of this source code is governed by a MIT-style license that can be\r\n// found in the LICENSE file.\r\n\r\n\r\nimport {\r\n NativeModules,\r\n DeviceEventEmitter,\r\n NativeAppEventEmitter,\r\n} from 'react-native';\r\n\r\nconst ReactNativeBlobUtil = NativeModules.ReactNativeBlobUtil;\r\nconst emitter = DeviceEventEmitter;\r\n\r\nexport default class ReactNativeBlobUtilFile {\r\n\r\n}\r\n","// Copyright 2016 wkh237@github. All rights reserved.\r\n// Use of this source code is governed by a MIT-style license that can be\r\n// found in the LICENSE file.\r\n\r\nimport fs from '../fs.js';\r\nimport getUUID from '../utils/uuid';\r\nimport Log from '../utils/log.js';\r\nimport URIUtil from \"../utils/uri\";\r\nimport EventTarget from './EventTarget';\r\n\r\nconst log = new Log('Blob');\r\nconst blobCacheDir = fs.dirs.DocumentDir + '/ReactNativeBlobUtil-blobs/';\r\n\r\nlog.disable();\r\n// log.level(3)\r\n\r\n/**\r\n * A ReactNativeBlobUtil style Blob polyfill class, this is a Blob which compatible to\r\n * Response object attain fron ReactNativeBlobUtil.fetch.\r\n */\r\nexport default class Blob extends EventTarget {\r\n\r\n cacheName: string;\r\n type: string;\r\n size: number;\r\n isReactNativeBlobUtilPolyfill: boolean = true;\r\n multipartBoundary: string = null;\r\n\r\n _ref: string = null;\r\n _blobCreated: boolean = false;\r\n _onCreated: Array = [];\r\n _closed: boolean = false;\r\n\r\n /**\r\n * Static method that remove all files in Blob cache folder.\r\n * @nonstandard\r\n * @return {Promise}\r\n */\r\n static clearCache() {\r\n return fs.unlink(blobCacheDir).then(() => fs.mkdir(blobCacheDir));\r\n }\r\n\r\n static build(data: any, cType: any): Promise {\r\n return new Promise((resolve, reject) => {\r\n new Blob(data, cType).onCreated(resolve);\r\n });\r\n }\r\n\r\n get blobPath() {\r\n return this._ref;\r\n }\r\n\r\n static setLog(level: number) {\r\n if (level === -1)\r\n log.disable();\r\n else\r\n log.level(level);\r\n }\r\n\r\n /**\r\n * ReactNativeBlobUtil Blob polyfill, create a Blob directly from file path, BASE64\r\n * encoded data, and string. The conversion is done implicitly according to\r\n * given `mime`. However, the blob creation is asynchronously, to register\r\n * event `onCreated` is need to ensure the Blob is creadted.\r\n * @param {any} data Content of Blob object\r\n * @param {any} mime Content type settings of Blob object, `text/plain`\r\n * by default\r\n * @param {boolean} defer When this argument set to `true`, blob constructor\r\n * will not invoke blob created event automatically.\r\n */\r\n constructor(data: any, cType: any, defer: boolean) {\r\n super();\r\n cType = cType || {};\r\n this.cacheName = getBlobName();\r\n this.isReactNativeBlobUtilPolyfill = true;\r\n this.isDerived = defer;\r\n this.type = cType.type || 'text/plain';\r\n log.verbose('Blob constructor called', 'mime', this.type, 'type', typeof data, 'length', data ? data.length : 0);\r\n this._ref = blobCacheDir + this.cacheName;\r\n let p = null;\r\n if (!data)\r\n data = '';\r\n if (data.isReactNativeBlobUtilPolyfill) {\r\n log.verbose('create Blob cache file from Blob object');\r\n let size = 0;\r\n this._ref = String(data.getReactNativeBlobUtilRef());\r\n let orgPath = this._ref;\r\n\r\n p = fs.exists(orgPath)\r\n .then((exist) => {\r\n if (exist)\r\n return fs.writeFile(orgPath, data, 'uri')\r\n .then((size) => Promise.resolve(size))\r\n .catch((err) => {\r\n throw `ReactNativeBlobUtil Blob file creation error, ${err}`;\r\n });\r\n else\r\n throw `could not create Blob from path ${orgPath}, file not exists`;\r\n });\r\n }\r\n // process FormData\r\n else if (data instanceof FormData) {\r\n log.verbose('create Blob cache file from FormData', data);\r\n let boundary = `ReactNativeBlobUtil-${this.cacheName}-${Date.now()}`;\r\n this.multipartBoundary = boundary;\r\n let parts = data.getParts();\r\n let formArray = [];\r\n if (!parts) {\r\n p = fs.writeFile(this._ref, '', 'utf8');\r\n }\r\n else {\r\n for (let i in parts) {\r\n formArray.push('\\r\\n--' + boundary + '\\r\\n');\r\n let part = parts[i];\r\n for (let j in part.headers) {\r\n formArray.push(j + ': ' + part.headers[j] + '\\r\\n');\r\n }\r\n formArray.push('\\r\\n');\r\n if (part.isReactNativeBlobUtilPolyfill)\r\n formArray.push(part);\r\n else\r\n formArray.push(part.string);\r\n }\r\n log.verbose('FormData array', formArray);\r\n formArray.push('\\r\\n--' + boundary + '--\\r\\n');\r\n p = createMixedBlobData(this._ref, formArray);\r\n }\r\n }\r\n // if the data is a string starts with `ReactNativeBlobUtil-file://`, append the\r\n // Blob data from file path\r\n else if (typeof data === 'string' && data.startsWith('ReactNativeBlobUtil-file://')) {\r\n log.verbose('create Blob cache file from file path', data);\r\n // set this flag so that we know this blob is a wrapper of an existing file\r\n this._isReference = true;\r\n this._ref = String(data).replace('ReactNativeBlobUtil-file://', '');\r\n let orgPath = this._ref;\r\n if (defer)\r\n return;\r\n else {\r\n p = fs.stat(orgPath)\r\n .then((stat) => {\r\n return Promise.resolve(stat.size);\r\n });\r\n }\r\n }\r\n // content from variable need create file\r\n else if (typeof data === 'string') {\r\n let encoding = 'utf8';\r\n let mime = String(this.type);\r\n // when content type contains application/octet* or *;base64, ReactNativeBlobUtil\r\n // fs will treat it as BASE64 encoded string binary data\r\n if (/(application\\/octet|\\;base64)/i.test(mime))\r\n encoding = 'base64';\r\n else\r\n data = data.toString();\r\n // create cache file\r\n this.type = String(this.type).replace(/;base64/ig, '');\r\n log.verbose('create Blob cache file from string', 'encode', encoding);\r\n p = fs.writeFile(this._ref, data, encoding)\r\n .then((size) => {\r\n return Promise.resolve(size);\r\n });\r\n\r\n }\r\n // TODO : ArrayBuffer support\r\n // else if (data instanceof ArrayBuffer ) {\r\n //\r\n // }\r\n // when input is an array of mixed data types, create a file cache\r\n else if (Array.isArray(data)) {\r\n log.verbose('create Blob cache file from mixed array', data);\r\n p = createMixedBlobData(this._ref, data);\r\n }\r\n else {\r\n data = data.toString();\r\n p = fs.writeFile(this._ref, data, 'utf8')\r\n .then((size) => Promise.resolve(size));\r\n }\r\n p && p.then((size) => {\r\n this.size = size;\r\n this._invokeOnCreateEvent();\r\n })\r\n .catch((err) => {\r\n log.error('ReactNativeBlobUtil could not create Blob : ' + this._ref, err);\r\n });\r\n\r\n }\r\n\r\n /**\r\n * Since Blob content will asynchronously write to a file during creation,\r\n * use this method to register an event handler for Blob initialized event.\r\n * @nonstandard\r\n * @param {(b:Blob) => void} An event handler invoked when Blob created\r\n * @return {Blob} The Blob object instance itself\r\n */\r\n onCreated(fn: () => void): Blob {\r\n log.verbose('#register blob onCreated', this._blobCreated);\r\n if (!this._blobCreated)\r\n this._onCreated.push(fn);\r\n else {\r\n fn(this);\r\n }\r\n return this;\r\n }\r\n\r\n markAsDerived() {\r\n this._isDerived = true;\r\n }\r\n\r\n get isDerived() {\r\n return this._isDerived || false;\r\n }\r\n\r\n /**\r\n * Get file reference of the Blob object.\r\n * @nonstandard\r\n * @return {string} Blob file reference which can be consumed by ReactNativeBlobUtil fs\r\n */\r\n getReactNativeBlobUtilRef() {\r\n return this._ref;\r\n }\r\n\r\n /**\r\n * Create a Blob object which is sliced from current object\r\n * @param {number} start Start byte number\r\n * @param {number} end End byte number\r\n * @param {string} contentType Optional, content type of new Blob object\r\n * @return {Blob}\r\n */\r\n slice(start: ?number, end: ?number, contentType: ?string = ''): Blob {\r\n if (this._closed)\r\n throw 'Blob has been released.';\r\n log.verbose('slice called', start, end, contentType);\r\n\r\n\r\n let resPath = blobCacheDir + getBlobName();\r\n let pass = false;\r\n log.debug('fs.slice new blob will at', resPath);\r\n let result = new Blob(URIUtil.wrap(resPath), {type: contentType}, true);\r\n fs.exists(blobCacheDir)\r\n .then((exist) => {\r\n if (exist)\r\n return Promise.resolve();\r\n return fs.mkdir(blobCacheDir);\r\n })\r\n .then(() => fs.slice(this._ref, resPath, start, end))\r\n .then((dest) => {\r\n log.debug('fs.slice done', dest);\r\n result._invokeOnCreateEvent();\r\n pass = true;\r\n })\r\n .catch((err) => {\r\n console.warn('Blob.slice failed:', err);\r\n pass = true;\r\n });\r\n log.debug('slice returning new Blob');\r\n\r\n return result;\r\n }\r\n\r\n /**\r\n * Read data of the Blob object, this is not standard method.\r\n * @nonstandard\r\n * @param {string} encoding Read data with encoding\r\n * @return {Promise}\r\n */\r\n readBlob(encoding: string): Promise {\r\n if (this._closed)\r\n throw 'Blob has been released.';\r\n return fs.readFile(this._ref, encoding || 'utf8');\r\n }\r\n\r\n /**\r\n * Release the resource of the Blob object.\r\n * @nonstandard\r\n * @return {Promise}\r\n */\r\n close() {\r\n if (this._closed)\r\n return Promise.reject('Blob has been released.');\r\n this._closed = true;\r\n return fs.unlink(this._ref).catch((err) => {\r\n console.warn(err);\r\n });\r\n }\r\n\r\n safeClose() {\r\n if (this._closed)\r\n return Promise.reject('Blob has been released.');\r\n this._closed = true;\r\n if (!this._isReference) {\r\n return fs.unlink(this._ref).catch((err) => {\r\n console.warn(err);\r\n });\r\n }\r\n else {\r\n return Promise.resolve();\r\n }\r\n }\r\n\r\n _invokeOnCreateEvent() {\r\n log.verbose('invoke create event', this._onCreated);\r\n this._blobCreated = true;\r\n let fns = this._onCreated;\r\n for (let i in fns) {\r\n if (typeof fns[i] === 'function') {\r\n fns[i](this);\r\n }\r\n }\r\n delete this._onCreated;\r\n }\r\n\r\n}\r\n\r\n/**\r\n * Get a temp filename for Blob object\r\n * @return {string} Temporary filename\r\n */\r\nfunction getBlobName() {\r\n return 'blob-' + getUUID();\r\n}\r\n\r\n/**\r\n * Create a file according to given array. The element in array can be a number,\r\n * Blob, String, Array.\r\n * @param {string} ref File path reference\r\n * @param {Array} dataArray An array contains different types of data.\r\n * @return {Promise}\r\n */\r\nfunction createMixedBlobData(ref, dataArray) {\r\n // create an empty file for store blob data\r\n let p = fs.writeFile(ref, '');\r\n let args = [];\r\n let size = 0;\r\n for (let i in dataArray) {\r\n let part = dataArray[i];\r\n if (!part)\r\n continue;\r\n if (part.isReactNativeBlobUtilPolyfill) {\r\n args.push([ref, part._ref, 'uri']);\r\n }\r\n else if (typeof part === 'string')\r\n args.push([ref, part, 'utf8']);\r\n // TODO : ArrayBuffer\r\n // else if (part instanceof ArrayBuffer) {\r\n //\r\n // }\r\n else if (Array.isArray(part))\r\n args.push([ref, part, 'ascii']);\r\n }\r\n // start write blob data\r\n for (let i in args) {\r\n p = p.then(function (written) {\r\n let arg = this;\r\n if (written)\r\n size += written;\r\n log.verbose('mixed blob write', args[i], written);\r\n return fs.appendFile(...arg);\r\n }.bind(args[i]));\r\n }\r\n return p.then(() => Promise.resolve(size));\r\n}\r\n","export default class Log {\r\n\r\n _name:string;\r\n _isEnable:boolean = true\r\n _level:number = 0\r\n\r\n constructor(name:string) {\r\n this._name = name;\r\n }\r\n\r\n level(val:number) {\r\n this._isEnable = true;\r\n this._level = val;\r\n }\r\n\r\n enable() {\r\n this._isEnable = true;\r\n }\r\n\r\n disable() {\r\n this._isEnable = false;\r\n }\r\n\r\n verbose(...args) {\r\n this._isEnable && this._level > 2 && console.log(this._name, 'verbose:', ...args);\r\n }\r\n\r\n debug(...args) {\r\n this._isEnable && this._level > 1 && console.log(this._name, 'debug:', ...args);\r\n }\r\n\r\n info(...args) {\r\n this._isEnable && this._level > 0 && console.log(this._name, 'info:', ...args);\r\n }\r\n\r\n error(...args) {\r\n this._isEnable && this._level > -1 && console.warn(this._name, 'error:', ...args);\r\n }\r\n\r\n}\r\n","export default {\r\n\r\n isFileURI: (uri: string): boolean => {\r\n if (typeof uri !== 'string')\r\n return false;\r\n return /^ReactNativeBlobUtil-file\\:\\/\\//.test(uri);\r\n },\r\n\r\n isJSONStreamURI: (uri: string): boolean => {\r\n if (typeof uri !== 'string')\r\n return false;\r\n return /^JSONStream\\:\\/\\//.test(uri);\r\n },\r\n\r\n removeURIScheme: (uri: string, iterations: number): string => {\r\n iterations = iterations || 1;\r\n let result = uri;\r\n for (let i = 0; i < iterations; i++) {\r\n result = String(result).replace(/^[^\\:]+\\:\\/\\//, '');\r\n }\r\n return String(result);\r\n },\r\n\r\n unwrapFileURI: (uri: string): string => {\r\n return String(uri).replace(/^ReactNativeBlobUtil-file\\:\\/\\//, '');\r\n },\r\n\r\n wrap: (path: string): string => {\r\n const prefix = path.startsWith('content://') ? 'ReactNativeBlobUtil-content://' : 'ReactNativeBlobUtil-file://';\r\n return prefix + path;\r\n }\r\n\r\n};\r\n","// Copyright 2016 wkh237@github. All rights reserved.\r\n// Use of this source code is governed by a MIT-style license that can be\r\n// found in the LICENSE file.\r\n\r\nimport Log from '../utils/log.js';\r\n\r\nconst log = new Log('EventTarget');\r\n\r\nlog.disable();\r\n\r\nexport default class EventTarget {\r\n\r\n listeners: any;\r\n\r\n constructor() {\r\n log.info('constructor called');\r\n this.listeners = {};\r\n }\r\n\r\n /**\r\n * Add an event listener to given event type\r\n * @param {string} type Event type string\r\n * @param {(Event) => void} cb Event handler function\r\n */\r\n addEventListener(type: string, cb: () => void) {\r\n log.info('add event listener', type, cb);\r\n if (!(type in this.listeners)) {\r\n this.listeners[type] = [];\r\n }\r\n this.listeners[type].push(cb);\r\n }\r\n\r\n /**\r\n * Remove an event listener\r\n * @param {string} type Type of the event listener\r\n * @param {()=>void} cb Event listener function.\r\n * @return {[type]} [description]\r\n */\r\n removeEventListener(type: string, cb: () => void) {\r\n log.info('remove event listener', type, cb);\r\n if (!(type in this.listeners))\r\n return;\r\n let handlers = this.listeners[type];\r\n for (let i in handlers) {\r\n if (cb === handlers[i]) {\r\n handlers.splice(i, 1);\r\n return this.removeEventListener(type, cb);\r\n }\r\n }\r\n }\r\n\r\n /**\r\n * Dispatch an event\r\n * @param {string} type Event type.\r\n * @param {Event} event Event data payload.\r\n */\r\n dispatchEvent(type: string, event: Event) {\r\n log.info('dispatch event', event);\r\n if (!(type in this.listeners))\r\n return;\r\n let handlers = this.listeners[type];\r\n for (let i in handlers) {\r\n handlers[i].call(this, event);\r\n }\r\n\r\n }\r\n\r\n /**\r\n * Remove all registered listeners from this object.\r\n * @nonstandard\r\n * @return {[type]} [description]\r\n */\r\n clearEventListeners() {\r\n for (let i in this.listeners) {\r\n delete this.listeners[i];\r\n }\r\n }\r\n\r\n}","/*! http://mths.be/base64 v0.1.0 by @mathias | MIT license */\n;(function(root) {\n\n\t// Detect free variables `exports`.\n\tvar freeExports = typeof exports == 'object' && exports;\n\n\t// Detect free variable `module`.\n\tvar freeModule = typeof module == 'object' && module &&\n\t\tmodule.exports == freeExports && module;\n\n\t// Detect free variable `global`, from Node.js or Browserified code, and use\n\t// it as `root`.\n\tvar freeGlobal = typeof global == 'object' && global;\n\tif (freeGlobal.global === freeGlobal || freeGlobal.window === freeGlobal) {\n\t\troot = freeGlobal;\n\t}\n\n\t/*--------------------------------------------------------------------------*/\n\n\tvar InvalidCharacterError = function(message) {\n\t\tthis.message = message;\n\t};\n\tInvalidCharacterError.prototype = new Error;\n\tInvalidCharacterError.prototype.name = 'InvalidCharacterError';\n\n\tvar error = function(message) {\n\t\t// Note: the error messages used throughout this file match those used by\n\t\t// the native `atob`/`btoa` implementation in Chromium.\n\t\tthrow new InvalidCharacterError(message);\n\t};\n\n\tvar TABLE = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/';\n\t// http://whatwg.org/html/common-microsyntaxes.html#space-character\n\tvar REGEX_SPACE_CHARACTERS = /[\\t\\n\\f\\r ]/g;\n\n\t// `decode` is designed to be fully compatible with `atob` as described in the\n\t// HTML Standard. http://whatwg.org/html/webappapis.html#dom-windowbase64-atob\n\t// The optimized base64-decoding algorithm used is based on @atk’s excellent\n\t// implementation. https://gist.github.com/atk/1020396\n\tvar decode = function(input) {\n\t\tinput = String(input)\n\t\t\t.replace(REGEX_SPACE_CHARACTERS, '');\n\t\tvar length = input.length;\n\t\tif (length % 4 == 0) {\n\t\t\tinput = input.replace(/==?$/, '');\n\t\t\tlength = input.length;\n\t\t}\n\t\tif (\n\t\t\tlength % 4 == 1 ||\n\t\t\t// http://whatwg.org/C#alphanumeric-ascii-characters\n\t\t\t/[^+a-zA-Z0-9/]/.test(input)\n\t\t) {\n\t\t\terror(\n\t\t\t\t'Invalid character: the string to be decoded is not correctly encoded.'\n\t\t\t);\n\t\t}\n\t\tvar bitCounter = 0;\n\t\tvar bitStorage;\n\t\tvar buffer;\n\t\tvar output = '';\n\t\tvar position = -1;\n\t\twhile (++position < length) {\n\t\t\tbuffer = TABLE.indexOf(input.charAt(position));\n\t\t\tbitStorage = bitCounter % 4 ? bitStorage * 64 + buffer : buffer;\n\t\t\t// Unless this is the first of a group of 4 characters…\n\t\t\tif (bitCounter++ % 4) {\n\t\t\t\t// …convert the first 8 bits to a single ASCII character.\n\t\t\t\toutput += String.fromCharCode(\n\t\t\t\t\t0xFF & bitStorage >> (-2 * bitCounter & 6)\n\t\t\t\t);\n\t\t\t}\n\t\t}\n\t\treturn output;\n\t};\n\n\t// `encode` is designed to be fully compatible with `btoa` as described in the\n\t// HTML Standard: http://whatwg.org/html/webappapis.html#dom-windowbase64-btoa\n\tvar encode = function(input) {\n\t\tinput = String(input);\n\t\tif (/[^\\0-\\xFF]/.test(input)) {\n\t\t\t// Note: no need to special-case astral symbols here, as surrogates are\n\t\t\t// matched, and the input is supposed to only contain ASCII anyway.\n\t\t\terror(\n\t\t\t\t'The string to be encoded contains characters outside of the ' +\n\t\t\t\t'Latin1 range.'\n\t\t\t);\n\t\t}\n\t\tvar padding = input.length % 3;\n\t\tvar output = '';\n\t\tvar position = -1;\n\t\tvar a;\n\t\tvar b;\n\t\tvar c;\n\t\tvar d;\n\t\tvar buffer;\n\t\t// Make sure any padding is handled outside of the loop.\n\t\tvar length = input.length - padding;\n\n\t\twhile (++position < length) {\n\t\t\t// Read three bytes, i.e. 24 bits.\n\t\t\ta = input.charCodeAt(position) << 16;\n\t\t\tb = input.charCodeAt(++position) << 8;\n\t\t\tc = input.charCodeAt(++position);\n\t\t\tbuffer = a + b + c;\n\t\t\t// Turn the 24 bits into four chunks of 6 bits each, and append the\n\t\t\t// matching character for each of them to the output.\n\t\t\toutput += (\n\t\t\t\tTABLE.charAt(buffer >> 18 & 0x3F) +\n\t\t\t\tTABLE.charAt(buffer >> 12 & 0x3F) +\n\t\t\t\tTABLE.charAt(buffer >> 6 & 0x3F) +\n\t\t\t\tTABLE.charAt(buffer & 0x3F)\n\t\t\t);\n\t\t}\n\n\t\tif (padding == 2) {\n\t\t\ta = input.charCodeAt(position) << 8;\n\t\t\tb = input.charCodeAt(++position);\n\t\t\tbuffer = a + b;\n\t\t\toutput += (\n\t\t\t\tTABLE.charAt(buffer >> 10) +\n\t\t\t\tTABLE.charAt((buffer >> 4) & 0x3F) +\n\t\t\t\tTABLE.charAt((buffer << 2) & 0x3F) +\n\t\t\t\t'='\n\t\t\t);\n\t\t} else if (padding == 1) {\n\t\t\tbuffer = input.charCodeAt(position);\n\t\t\toutput += (\n\t\t\t\tTABLE.charAt(buffer >> 2) +\n\t\t\t\tTABLE.charAt((buffer << 4) & 0x3F) +\n\t\t\t\t'=='\n\t\t\t);\n\t\t}\n\n\t\treturn output;\n\t};\n\n\tvar base64 = {\n\t\t'encode': encode,\n\t\t'decode': decode,\n\t\t'version': '0.1.0'\n\t};\n\n\t// Some AMD build optimizers, like r.js, check for specific condition patterns\n\t// like the following:\n\tif (\n\t\ttypeof define == 'function' &&\n\t\ttypeof define.amd == 'object' &&\n\t\tdefine.amd\n\t) {\n\t\tdefine(function() {\n\t\t\treturn base64;\n\t\t});\n\t}\telse if (freeExports && !freeExports.nodeType) {\n\t\tif (freeModule) { // in Node.js or RingoJS v0.8.0+\n\t\t\tfreeModule.exports = base64;\n\t\t} else { // in Narwhal or RingoJS v0.7.0-\n\t\t\tfor (var key in base64) {\n\t\t\t\tbase64.hasOwnProperty(key) && (freeExports[key] = base64[key]);\n\t\t\t}\n\t\t}\n\t} else { // in Rhino or a web browser\n\t\troot.base64 = base64;\n\t}\n\n}(this));\n","\r\nexport type ReactNativeBlobUtilConfig = {\r\n Progress: any,\r\n UploadProgress: any,\r\n fileCache : bool,\r\n transformFile: boolean;\r\n path : string,\r\n appendExt : string,\r\n session : string,\r\n addAndroidDownloads : any,\r\n indicator : bool,\r\n followRedirect : bool,\r\n trusty : bool,\r\n wifiOnly : bool\r\n};\r\n\r\nexport type ReactNativeBlobUtilNative = {\r\n // API for fetch octet-stream data\r\n fetchBlob : (\r\n options:fetchConfig,\r\n taskId:string,\r\n method:string,\r\n url:string,\r\n headers:any,\r\n body:any,\r\n callback:(err:any, ...data:any) => void\r\n ) => void,\r\n // API for fetch form data\r\n fetchBlobForm : (\r\n options:fetchConfig,\r\n taskId:string,\r\n method:string,\r\n url:string,\r\n headers:any,\r\n form:Array,\r\n callback:(err:any, ...data:any) => void\r\n ) => void,\r\n // open file stream\r\n readStream : (\r\n path:string,\r\n encode:'utf8' | 'ascii' | 'base64'\r\n ) => void,\r\n // get system folders\r\n getEnvironmentDirs : (dirs:any) => void,\r\n // unlink file by path\r\n unlink : (path:string, callback: (err:any) => void) => void,\r\n removeSession : (paths:Array, callback: (err:any) => void) => void,\r\n ls : (path:string, callback: (err:any) => void) => void,\r\n};\r\n\r\nexport type ReactNativeBlobUtilResponseInfo = {\r\n taskId : string,\r\n state : number,\r\n headers : any,\r\n status : number,\r\n respType : 'text' | 'blob' | '' | 'json',\r\n rnfbEncode : 'path' | 'base64' | 'ascii' | 'utf8'\r\n}\r\n\r\nexport type ReactNativeBlobUtilStream = {\r\n onData : () => void,\r\n onError : () => void,\r\n onEnd : () => void,\r\n _onData : () => void,\r\n _onEnd : () => void,\r\n _onError : () => void,\r\n}\r\n\r\n\r\nexport type filedescriptor = { path: string, parentFolder: string, mimeType: string }","import {NativeModules} from 'react-native';\r\nimport type {ReactNativeBlobUtilNative, filedescriptor} from \"types\";\r\n\r\nconst ReactNativeBlobUtil: ReactNativeBlobUtilNative = NativeModules.ReactNativeBlobUtil;\r\n\r\nfunction createMediafile(fd: filedescriptor, mediatype: string): Promise {\r\n if ((!'parentFolder' in fd)) fd['parentFolder'] = '';\r\n return ReactNativeBlobUtil.createMediaFile(fd, mediatype);\r\n}\r\n\r\nfunction writeToMediafile(uri: string, path: string) {\r\n return ReactNativeBlobUtil.writeToMediaFile(uri, path, false);\r\n}\r\n\r\nfunction writeToMediafileWithTransform(uri: string, path: string) {\r\n return ReactNativeBlobUtil.writeToMediaFile(uri, path, true);\r\n}\r\n\r\nfunction copyToInternal(contenturi: string, destpath: string) {\r\n return ReactNativeBlobUtil.copyToInternal(contenturi, destpath);\r\n}\r\n\r\nfunction getBlob(contenturi: string, encoding: string) {\r\n return ReactNativeBlobUtil.getBlob(contenturi, encoding);\r\n}\r\n\r\nfunction copyToMediaStore(fd: filedescriptor, mediatype: string, path: string) {\r\n return ReactNativeBlobUtil.copyToMediaStore(fd, mediatype, path);\r\n}\r\n\r\nexport default {\r\n createMediafile,\r\n writeToMediafile,\r\n writeToMediafileWithTransform,\r\n copyToInternal,\r\n getBlob,\r\n copyToMediaStore\r\n};","import Blob from './Blob.js';\r\nimport File from './File.js';\r\nimport XMLHttpRequest from './XMLHttpRequest.js';\r\nimport ProgressEvent from './ProgressEvent';\r\nimport Event from './Event';\r\nimport FileReader from './FileReader';\r\nimport Fetch from './Fetch';\r\n\r\nexport default {\r\n Blob, File, XMLHttpRequest, ProgressEvent, Event, FileReader, Fetch\r\n};\r\n","// Copyright 2016 wkh237@github. All rights reserved.\r\n// Use of this source code is governed by a MIT-style license that can be\r\n// found in the LICENSE file.\r\n\r\nimport Blob from './Blob.js';\r\n\r\nexport default class File extends Blob {\r\n\r\n name: string = '';\r\n\r\n static build(name: string, data: any, cType: string): Promise {\r\n return new Promise((resolve, reject) => {\r\n if (data === undefined) {\r\n reject(new TypeError('data is undefined'));\r\n }\r\n new File(data, cType).onCreated((f) => {\r\n f.name = name;\r\n resolve(f);\r\n });\r\n });\r\n }\r\n\r\n constructor(data: any, cType: string) {\r\n super(data, cType);\r\n }\r\n\r\n}\r\n","// Copyright 2016 wkh237@github. All rights reserved.\r\n// Use of this source code is governed by a MIT-style license that can be\r\n// found in the LICENSE file.\r\n\r\nimport XMLHttpRequestEventTarget from './XMLHttpRequestEventTarget.js';\r\nimport Log from '../utils/log.js';\r\nimport Blob from './Blob.js';\r\nimport ProgressEvent from './ProgressEvent.js';\r\nimport URIUtil from \"../utils/uri\";\r\nimport {config} from \"../fetch\";\r\n\r\nconst log = new Log('XMLHttpRequest');\r\n\r\n\r\nlog.disable();\r\n// log.level(3)\r\n\r\nconst UNSENT = 0;\r\nconst OPENED = 1;\r\nconst HEADERS_RECEIVED = 2;\r\nconst LOADING = 3;\r\nconst DONE = 4;\r\n\r\nexport default class XMLHttpRequest extends XMLHttpRequestEventTarget {\r\n\r\n _onreadystatechange: () => void;\r\n\r\n upload: XMLHttpRequestEventTarget = new XMLHttpRequestEventTarget();\r\n static binaryContentTypes: Array = [\r\n 'image/', 'video/', 'audio/'\r\n ];\r\n\r\n // readonly\r\n _readyState: number = UNSENT;\r\n _uriType: 'net' | 'file' = 'net';\r\n _response: any = '';\r\n _responseText: any = '';\r\n _responseHeaders: any = {};\r\n _responseType: '' | 'arraybuffer' | 'blob' | 'json' | 'text' = '';\r\n // TODO : not suppoted ATM\r\n _responseURL: null = '';\r\n _responseXML: null = '';\r\n _status: number = 0;\r\n _statusText: string = '';\r\n _timeout: number = 60000;\r\n _sendFlag: boolean = false;\r\n _uploadStarted: boolean = false;\r\n _increment: boolean = false;\r\n\r\n // ReactNativeBlobUtil compatible data structure\r\n _config: ReactNativeBlobUtilConfig = {};\r\n _url: any;\r\n _method: string;\r\n _headers: any = {\r\n 'Content-Type': 'text/plain'\r\n };\r\n _cleanUp: () => void = null;\r\n _body: any;\r\n\r\n // ReactNativeBlobUtil promise object, which has `progress`, `uploadProgress`, and\r\n // `cancel` methods.\r\n _task: any;\r\n\r\n // constants\r\n get UNSENT() {\r\n return UNSENT;\r\n }\r\n\r\n get OPENED() {\r\n return OPENED;\r\n }\r\n\r\n get HEADERS_RECEIVED() {\r\n return HEADERS_RECEIVED;\r\n }\r\n\r\n get LOADING() {\r\n return LOADING;\r\n }\r\n\r\n get DONE() {\r\n return DONE;\r\n }\r\n\r\n static get UNSENT() {\r\n return UNSENT;\r\n }\r\n\r\n static get OPENED() {\r\n return OPENED;\r\n }\r\n\r\n static get HEADERS_RECEIVED() {\r\n return HEADERS_RECEIVED;\r\n }\r\n\r\n static get LOADING() {\r\n return LOADING;\r\n }\r\n\r\n static get DONE() {\r\n return DONE;\r\n }\r\n\r\n static setLog(level: number) {\r\n if (level === -1)\r\n log.disable();\r\n else\r\n log.level(level);\r\n }\r\n\r\n static addBinaryContentType(substr: string) {\r\n for (let i in XMLHttpRequest.binaryContentTypes) {\r\n if (new RegExp(substr, 'i').test(XMLHttpRequest.binaryContentTypes[i])) {\r\n return;\r\n }\r\n }\r\n XMLHttpRequest.binaryContentTypes.push(substr);\r\n\r\n }\r\n\r\n static removeBinaryContentType(val) {\r\n for (let i in XMLHttpRequest.binaryContentTypes) {\r\n if (new RegExp(substr, 'i').test(XMLHttpRequest.binaryContentTypes[i])) {\r\n XMLHttpRequest.binaryContentTypes.splice(i, 1);\r\n return;\r\n }\r\n }\r\n }\r\n\r\n constructor() {\r\n log.verbose('XMLHttpRequest constructor called');\r\n super();\r\n }\r\n\r\n\r\n /**\r\n * XMLHttpRequest.open, always async, user and password not supported. When\r\n * this method invoked, headers should becomes empty again.\r\n * @param {string} method Request method\r\n * @param {string} url Request URL\r\n * @param {true} async Always async\r\n * @param {any} user NOT SUPPORTED\r\n * @param {any} password NOT SUPPORTED\r\n */\r\n open(method: string, url: string, async: true, user: any, password: any) {\r\n log.verbose('XMLHttpRequest open ', method, url, async, user, password);\r\n this._method = method;\r\n this._url = url;\r\n this._headers = {};\r\n this._increment = URIUtil.isJSONStreamURI(this._url);\r\n this._url = this._url.replace(/^JSONStream\\:\\/\\//, '');\r\n this._dispatchReadStateChange(XMLHttpRequest.OPENED);\r\n }\r\n\r\n /**\r\n * Invoke this function to send HTTP request, and set body.\r\n * @param {any} body Body in ReactNativeBlobUtil flavor\r\n */\r\n send(body) {\r\n\r\n this._body = body;\r\n\r\n if (this._readyState !== XMLHttpRequest.OPENED)\r\n throw 'InvalidStateError : XMLHttpRequest is not opened yet.';\r\n let promise = Promise.resolve();\r\n this._sendFlag = true;\r\n log.verbose('XMLHttpRequest send ', body);\r\n let {_method, _url, _headers} = this;\r\n log.verbose('sending request with args', _method, _url, _headers, body);\r\n log.verbose(typeof body, body instanceof FormData);\r\n\r\n if (body instanceof FormData) {\r\n log.debug('creating blob and setting header from FormData instance');\r\n body = new Blob(body);\r\n this._headers['Content-Type'] = `multipart/form-data; boundary=${body.multipartBoundary}`;\r\n }\r\n\r\n if (body instanceof Blob) {\r\n log.debug('sending blob body', body._blobCreated);\r\n promise = new Promise((resolve, reject) => {\r\n body.onCreated((blob) => {\r\n // when the blob is derived (not created by RN developer), the blob\r\n // will be released after XMLHttpRequest sent\r\n if (blob.isDerived) {\r\n this._cleanUp = () => {\r\n blob.close();\r\n };\r\n }\r\n log.debug('body created send request');\r\n body = URIUtil.wrap(blob.getReactNativeBlobUtilRef());\r\n resolve();\r\n });\r\n });\r\n }\r\n else if (typeof body === 'object') {\r\n body = JSON.stringify(body);\r\n promise = Promise.resolve();\r\n }\r\n else {\r\n body = body ? body.toString() : body;\r\n promise = Promise.resolve();\r\n }\r\n\r\n promise.then(() => {\r\n log.debug('send request invoke', body);\r\n for (let h in _headers) {\r\n _headers[h] = _headers[h].toString();\r\n }\r\n\r\n this._task = config({\r\n auto: true,\r\n timeout: this._timeout,\r\n increment: this._increment,\r\n binaryContentTypes: XMLHttpRequest.binaryContentTypes\r\n })\r\n .fetch(_method, _url, _headers, body);\r\n this._task\r\n .stateChange(this._headerReceived)\r\n .uploadProgress(this._uploadProgressEvent)\r\n .progress(this._progressEvent)\r\n .catch(this._onError)\r\n .then(this._onDone);\r\n\r\n });\r\n }\r\n\r\n overrideMimeType(mime: string) {\r\n log.verbose('XMLHttpRequest overrideMimeType', mime);\r\n this._headers['Content-Type'] = mime;\r\n }\r\n\r\n setRequestHeader(name, value) {\r\n log.verbose('XMLHttpRequest set header', name, value);\r\n if (this._readyState !== OPENED || this._sendFlag) {\r\n throw `InvalidStateError : Calling setRequestHeader in wrong state ${this._readyState}`;\r\n }\r\n // UNICODE SHOULD NOT PASS\r\n if (typeof name !== 'string' || /[^\\u0000-\\u00ff]/.test(name)) {\r\n throw 'TypeError : header field name should be a string';\r\n }\r\n //\r\n let invalidPatterns = [\r\n /[\\(\\)\\>\\<\\@\\,\\:\\\\\\/\\[\\]\\?\\=\\}\\{\\s\\ \\u007f\\;\\t\\0\\v\\r]/,\r\n /tt/\r\n ];\r\n for (let pattern of invalidPatterns) {\r\n if (pattern.test(name) || typeof name !== 'string') {\r\n throw `SyntaxError : Invalid header field name ${name}`;\r\n }\r\n }\r\n this._headers[name] = value;\r\n }\r\n\r\n abort() {\r\n log.verbose('XMLHttpRequest abort ');\r\n if (!this._task)\r\n return;\r\n this._task.cancel((err) => {\r\n let e = {\r\n timeStamp: Date.now(),\r\n };\r\n if (this.onabort)\r\n this.onabort();\r\n if (err) {\r\n e.detail = err;\r\n e.type = 'error';\r\n this.dispatchEvent('error', e);\r\n }\r\n else {\r\n e.type = 'abort';\r\n this.dispatchEvent('abort', e);\r\n }\r\n });\r\n }\r\n\r\n getResponseHeader(field: string): string | null {\r\n log.verbose('XMLHttpRequest get header', field, this._responseHeaders);\r\n if (!this._responseHeaders)\r\n return null;\r\n return this._responseHeaders[field] || this._responseHeaders[field.toLowerCase()] || null;\r\n\r\n }\r\n\r\n getAllResponseHeaders(): string | null {\r\n log.verbose('XMLHttpRequest get all headers', this._responseHeaders);\r\n if (!this._responseHeaders)\r\n return '';\r\n let result = '';\r\n let respHeaders = this.responseHeaders;\r\n for (let i in respHeaders) {\r\n result += `${i}: ${respHeaders[i]}${String.fromCharCode(0x0D, 0x0A)}`;\r\n }\r\n return result.substr(0, result.length - 2);\r\n }\r\n\r\n _headerReceived = (e) => {\r\n log.debug('header received ', this._task.taskId, e);\r\n this.responseURL = this._url;\r\n if (e.state === \"2\" && e.taskId === this._task.taskId) {\r\n this._responseHeaders = e.headers;\r\n this._statusText = e.status;\r\n this._status = Math.floor(e.status);\r\n this._dispatchReadStateChange(XMLHttpRequest.HEADERS_RECEIVED);\r\n }\r\n }\r\n\r\n _uploadProgressEvent = (send: number, total: number) => {\r\n if (!this._uploadStarted) {\r\n this.upload.dispatchEvent('loadstart');\r\n this._uploadStarted = true;\r\n }\r\n if (send >= total)\r\n this.upload.dispatchEvent('load');\r\n this.upload.dispatchEvent('progress', new ProgressEvent(true, send, total));\r\n }\r\n\r\n _progressEvent = (send: number, total: number, chunk: string) => {\r\n log.verbose(this.readyState);\r\n if (this._readyState === XMLHttpRequest.HEADERS_RECEIVED)\r\n this._dispatchReadStateChange(XMLHttpRequest.LOADING);\r\n let lengthComputable = false;\r\n if (total && total >= 0)\r\n lengthComputable = true;\r\n let e = new ProgressEvent(lengthComputable, send, total);\r\n\r\n if (this._increment) {\r\n this._responseText += chunk;\r\n }\r\n this.dispatchEvent('progress', e);\r\n }\r\n\r\n _onError = (err) => {\r\n let statusCode = Math.floor(this.status);\r\n if (statusCode >= 100 && statusCode !== 408) {\r\n return;\r\n }\r\n log.debug('XMLHttpRequest error', err);\r\n this._statusText = err;\r\n this._status = String(err).match(/\\d+/);\r\n this._status = this._status ? Math.floor(this.status) : 404;\r\n this._dispatchReadStateChange(XMLHttpRequest.DONE);\r\n if (err && String(err.message).match(/(timed\\sout|timedout)/) || this._status == 408) {\r\n this.dispatchEvent('timeout');\r\n }\r\n this.dispatchEvent('loadend');\r\n this.dispatchEvent('error', {\r\n type: 'error',\r\n detail: err\r\n });\r\n this.clearEventListeners();\r\n }\r\n\r\n _onDone = (resp) => {\r\n log.debug('XMLHttpRequest done', this._url, resp, this);\r\n this._statusText = this._status;\r\n let responseDataReady = () => {\r\n log.debug('request done state = 4');\r\n this.dispatchEvent('load');\r\n this.dispatchEvent('loadend');\r\n this._dispatchReadStateChange(XMLHttpRequest.DONE);\r\n this.clearEventListeners();\r\n };\r\n if (resp) {\r\n let info = resp.respInfo || {};\r\n log.debug(this._url, info, info.respType);\r\n switch (this._responseType) {\r\n case 'blob' :\r\n resp.blob().then((b) => {\r\n this._responseText = resp.text();\r\n this._response = b;\r\n responseDataReady();\r\n });\r\n break;\r\n case 'arraybuffer':\r\n // TODO : to array buffer\r\n break;\r\n case 'json':\r\n this._response = resp.json();\r\n this._responseText = resp.text();\r\n break;\r\n default :\r\n this._responseText = resp.text();\r\n this._response = this.responseText;\r\n responseDataReady();\r\n break;\r\n }\r\n }\r\n\r\n }\r\n\r\n _dispatchReadStateChange(state) {\r\n this._readyState = state;\r\n if (typeof this._onreadystatechange === 'function')\r\n this._onreadystatechange();\r\n }\r\n\r\n set onreadystatechange(fn: () => void) {\r\n log.verbose('XMLHttpRequest set onreadystatechange', fn);\r\n this._onreadystatechange = fn;\r\n }\r\n\r\n get onreadystatechange() {\r\n return this._onreadystatechange;\r\n }\r\n\r\n get readyState() {\r\n log.verbose('get readyState', this._readyState);\r\n return this._readyState;\r\n }\r\n\r\n get status() {\r\n log.verbose('get status', this._status);\r\n return this._status;\r\n }\r\n\r\n get statusText() {\r\n log.verbose('get statusText', this._statusText);\r\n return this._statusText;\r\n }\r\n\r\n get response() {\r\n log.verbose('get response', this._response);\r\n return this._response;\r\n }\r\n\r\n get responseText() {\r\n log.verbose('get responseText', this._responseText);\r\n return this._responseText;\r\n }\r\n\r\n get responseURL() {\r\n log.verbose('get responseURL', this._responseURL);\r\n return this._responseURL;\r\n }\r\n\r\n get responseHeaders() {\r\n log.verbose('get responseHeaders', this._responseHeaders);\r\n return this._responseHeaders;\r\n }\r\n\r\n set timeout(val) {\r\n this._timeout = val * 1000;\r\n log.verbose('set timeout', this._timeout);\r\n }\r\n\r\n get timeout() {\r\n log.verbose('get timeout', this._timeout);\r\n return this._timeout;\r\n }\r\n\r\n set responseType(val) {\r\n log.verbose('set response type', this._responseType);\r\n this._responseType = val;\r\n }\r\n\r\n get responseType() {\r\n log.verbose('get response type', this._responseType);\r\n return this._responseType;\r\n }\r\n\r\n static get isRNFBPolyfill() {\r\n return true;\r\n }\r\n\r\n}\r\n","// Copyright 2016 wkh237@github. All rights reserved.\r\n// Use of this source code is governed by a MIT-style license that can be\r\n// found in the LICENSE file.\r\n\r\nimport EventTarget from './EventTarget.js';\r\nimport Log from '../utils/log.js';\r\n\r\nconst log = new Log('XMLHttpRequestEventTarget');\r\n\r\nlog.disable();\r\n// log.level(3)\r\n\r\nexport default class XMLHttpRequestEventTarget extends EventTarget {\r\n\r\n _onabort: (e: Event) => void = () => {\r\n };\r\n _onerror: (e: Event) => void = () => {\r\n };\r\n _onload: (e: Event) => void = () => {\r\n };\r\n _onloadstart: (e: Event) => void = () => {\r\n };\r\n _onprogress: (e: Event) => void = () => {\r\n };\r\n _ontimeout: (e: Event) => void = () => {\r\n };\r\n _onloadend: (e: Event) => void = () => {\r\n };\r\n\r\n constructor() {\r\n super();\r\n log.info('constructor called');\r\n }\r\n\r\n dispatchEvent(event: string, e: Event) {\r\n log.debug('dispatch event', event, e);\r\n super.dispatchEvent(event, e);\r\n switch (event) {\r\n case 'abort' :\r\n this._onabort(e);\r\n break;\r\n case 'error' :\r\n this._onerror(e);\r\n break;\r\n case 'load' :\r\n this._onload(e);\r\n break;\r\n case 'loadstart' :\r\n this._onloadstart(e);\r\n break;\r\n case 'loadend' :\r\n this._onloadend(e);\r\n break;\r\n case 'progress' :\r\n this._onprogress(e);\r\n break;\r\n case 'timeout' :\r\n this._ontimeout(e);\r\n break;\r\n }\r\n }\r\n\r\n set onabort(fn: (e: Event) => void) {\r\n log.info('set onabort');\r\n this._onabort = fn;\r\n }\r\n\r\n get onabort() {\r\n return this._onabort;\r\n }\r\n\r\n set onerror(fn: (e: Event) => void) {\r\n log.info('set onerror');\r\n this._onerror = fn;\r\n }\r\n\r\n get onerror() {\r\n return this._onerror;\r\n }\r\n\r\n set onload(fn: (e: Event) => void) {\r\n log.info('set onload', fn);\r\n this._onload = fn;\r\n }\r\n\r\n get onload() {\r\n return this._onload;\r\n }\r\n\r\n set onloadstart(fn: (e: Event) => void) {\r\n log.info('set onloadstart');\r\n this._onloadstart = fn;\r\n }\r\n\r\n get onloadstart() {\r\n return this._onloadstart;\r\n }\r\n\r\n set onprogress(fn: (e: Event) => void) {\r\n log.info('set onprogress');\r\n this._onprogress = fn;\r\n }\r\n\r\n get onprogress() {\r\n return this._onprogress;\r\n }\r\n\r\n set ontimeout(fn: (e: Event) => void) {\r\n log.info('set ontimeout');\r\n this._ontimeout = fn;\r\n }\r\n\r\n get ontimeout() {\r\n return this._ontimeout;\r\n }\r\n\r\n set onloadend(fn: (e: Event) => void) {\r\n log.info('set onloadend');\r\n this._onloadend = fn;\r\n }\r\n\r\n get onloadend() {\r\n return this._onloadend;\r\n }\r\n\r\n}\r\n","// Copyright 2016 wkh237@github. All rights reserved.\r\n// Use of this source code is governed by a MIT-style license that can be\r\n// found in the LICENSE file.\r\n\r\nimport Event from './Event';\r\n\r\nexport default class ProgressEvent extends Event {\r\n\r\n _lengthComputable: boolean = false;\r\n _loaded: number = -1;\r\n _total: numver = -1;\r\n\r\n constructor(lengthComputable, loaded, total) {\r\n super();\r\n this._lengthComputable = lengthComputable;\r\n this._loaded = loaded;\r\n this._total = total;\r\n }\r\n\r\n get lengthComputable() {\r\n return this._lengthComputable;\r\n }\r\n\r\n get loaded() {\r\n return this._loaded;\r\n }\r\n\r\n get total() {\r\n return this._total;\r\n }\r\n\r\n}\r\n","// Copyright 2016 wkh237@github. All rights reserved.\r\n// Use of this source code is governed by a MIT-style license that can be\r\n// found in the LICENSE file.\r\n\r\nexport default class Event {\r\n\r\n constructor() {\r\n\r\n }\r\n\r\n}\r\n","import {ReactNativeBlobUtilConfig} from \"./types\";\r\nimport URIUtil from \"./utils/uri\";\r\nimport fs from \"./fs\";\r\nimport getUUID from \"./utils/uuid\";\r\nimport {DeviceEventEmitter, NativeModules} from \"react-native\";\r\nimport {FetchBlobResponse} from \"./class/ReactNativeBlobUtilBlobResponse\";\r\n\r\nconst emitter = DeviceEventEmitter;\r\nconst ReactNativeBlobUtil = NativeModules.ReactNativeBlobUtil;\r\n\r\n// register message channel event handler.\r\nemitter.addListener(\"ReactNativeBlobUtilMessage\", (e) => {\r\n\r\n if (e.event === 'warn') {\r\n console.warn(e.detail);\r\n }\r\n else if (e.event === 'error') {\r\n throw e.detail;\r\n }\r\n else {\r\n console.log(\"ReactNativeBlobUtil native message\", e.detail);\r\n }\r\n});\r\n\r\n/**\r\n * Calling this method will inject configurations into followed `fetch` method.\r\n * @param {ReactNativeBlobUtilConfig} options\r\n * Fetch API configurations, contains the following options :\r\n * @property {boolean} fileCache\r\n * When fileCache is `true`, response data will be saved in\r\n * storage with a random generated file name, rather than\r\n * a BASE64 encoded string.\r\n * @property {string} appendExt\r\n * Set this property to change file extension of random-\r\n * generated file name.\r\n * @property {string} path\r\n * If this property has a valid string format, resonse data\r\n * will be saved to specific file path. Default string format\r\n * is : `ReactNativeBlobUtil-file://path-to-file`\r\n * @property {string} key\r\n * If this property is set, it will be converted to md5, to\r\n * check if a file with this name exists.\r\n * If it exists, the absolute path is returned (no network\r\n * activity takes place )\r\n * If it doesn't exist, the file is downloaded as usual\r\n * @property {number} timeout\r\n * Request timeout in millionseconds, by default it's 60000ms.\r\n * @property {boolean} followRedirect\r\n * Follow redirects automatically, default true\r\n * @property {boolean} trusty\r\n * Trust all certificates\r\n * @property {boolean} wifiOnly\r\n * Only do requests through WiFi. Android SDK 21 or above only.\r\n *\r\n * @return {function} This method returns a `fetch` method instance.\r\n */\r\nexport function config(options: ReactNativeBlobUtilConfig) {\r\n return {fetch: fetch.bind(options)};\r\n}\r\n\r\n/**\r\n * Fetch from file system, use the same interface as RNFB.fetch\r\n * @param {ReactNativeBlobUtilConfig} [options={}] Fetch configurations\r\n * @param {string} method Should be one of `get`, `post`, `put`\r\n * @param {string} url A file URI string\r\n * @param {string} headers Arguments of file system API\r\n * @param {any} body Data to put or post to file systen.\r\n * @return {Promise}\r\n */\r\nfunction fetchFile(options = {}, method, url, headers = {}, body): Promise {\r\n\r\n if (!URIUtil.isFileURI(url)) {\r\n throw `could not fetch file from an invalid URI : ${url}`;\r\n }\r\n\r\n url = URIUtil.unwrapFileURI(url);\r\n\r\n let promise = null,\r\n cursor = 0,\r\n total = -1,\r\n cacheData = '',\r\n info = null,\r\n _progress, _uploadProgress, _stateChange;\r\n\r\n switch (method.toLowerCase()) {\r\n\r\n case 'post':\r\n break;\r\n\r\n case 'put':\r\n break;\r\n\r\n // read data from file system\r\n default:\r\n promise = fs.stat(url)\r\n .then((stat) => {\r\n total = stat.size;\r\n return fs.readStream(url,\r\n headers.encoding || 'utf8',\r\n Math.floor(headers.bufferSize) || 409600,\r\n Math.floor(headers.interval) || 100\r\n );\r\n })\r\n .then((stream) => new Promise((resolve, reject) => {\r\n stream.open();\r\n info = {\r\n state: \"2\",\r\n headers: {'source': 'system-fs'},\r\n status: 200,\r\n respType: 'text',\r\n rnfbEncode: headers.encoding || 'utf8'\r\n };\r\n _stateChange(info);\r\n stream.onData((chunk) => {\r\n _progress && _progress(cursor, total, chunk);\r\n if (headers.noCache)\r\n return;\r\n cacheData += chunk;\r\n });\r\n stream.onError((err) => {\r\n reject(err);\r\n });\r\n stream.onEnd(() => {\r\n resolve(new FetchBlobResponse(null, info, cacheData));\r\n });\r\n }));\r\n break;\r\n }\r\n\r\n promise.progress = (fn) => {\r\n _progress = fn;\r\n return promise;\r\n };\r\n promise.stateChange = (fn) => {\r\n _stateChange = fn;\r\n return promise;\r\n };\r\n promise.uploadProgress = (fn) => {\r\n _uploadProgress = fn;\r\n return promise;\r\n };\r\n\r\n return promise;\r\n}\r\n\r\n/**\r\n * Create a HTTP request by settings, the `this` context is a `ReactNativeBlobUtilConfig` object.\r\n * @param {string} method HTTP method, should be `GET`, `POST`, `PUT`, `DELETE`\r\n * @param {string} url Request target url string.\r\n * @param {object} headers HTTP request headers.\r\n * @param {string} body\r\n * Request body, can be either a BASE64 encoded data string,\r\n * or a file path with prefix `ReactNativeBlobUtil-file://` (can be changed)\r\n * @return {Promise}\r\n * This promise instance also contains a Customized method `progress`for\r\n * register progress event handler.\r\n */\r\nexport function fetch(...args: any): Promise {\r\n\r\n // create task ID for receiving progress event\r\n let taskId = getUUID();\r\n let options = this || {};\r\n let subscription, subscriptionUpload, stateEvent, partEvent;\r\n let respInfo = {};\r\n let [method, url, headers, body] = [...args];\r\n\r\n // # 241 normalize null or undefined headers, in case nil or null string\r\n // pass to native context\r\n headers = headers && Object.keys(headers).reduce((result, key) => {\r\n result[key] = headers[key] || '';\r\n return result;\r\n }, {});\r\n\r\n // fetch from file system\r\n if (URIUtil.isFileURI(url)) {\r\n return fetchFile(options, method, url, headers, body);\r\n }\r\n\r\n let promiseResolve;\r\n let promiseReject;\r\n\r\n // from remote HTTP(S)\r\n let promise = new Promise((resolve, reject) => {\r\n promiseResolve = resolve;\r\n promiseReject = reject;\r\n\r\n let nativeMethodName = Array.isArray(body) ? 'fetchBlobForm' : 'fetchBlob';\r\n\r\n // on progress event listener\r\n subscription = emitter.addListener('ReactNativeBlobUtilProgress', (e) => {\r\n if (e.taskId === taskId && promise.onProgress) {\r\n promise.onProgress(e.written, e.total, e.chunk);\r\n }\r\n });\r\n\r\n subscriptionUpload = emitter.addListener('ReactNativeBlobUtilProgress-upload', (e) => {\r\n if (e.taskId === taskId && promise.onUploadProgress) {\r\n promise.onUploadProgress(e.written, e.total);\r\n }\r\n });\r\n\r\n stateEvent = emitter.addListener('ReactNativeBlobUtilState', (e) => {\r\n if (e.taskId === taskId)\r\n respInfo = e;\r\n promise.onStateChange && promise.onStateChange(e);\r\n });\r\n\r\n subscription = emitter.addListener('ReactNativeBlobUtilExpire', (e) => {\r\n if (e.taskId === taskId && promise.onExpire) {\r\n promise.onExpire(e);\r\n }\r\n });\r\n\r\n partEvent = emitter.addListener('ReactNativeBlobUtilServerPush', (e) => {\r\n if (e.taskId === taskId && promise.onPartData) {\r\n promise.onPartData(e.chunk);\r\n }\r\n });\r\n\r\n // When the request body comes from Blob polyfill, we should use special its ref\r\n // as the request body\r\n if (body instanceof Blob && body.isReactNativeBlobUtilPolyfill) {\r\n body = body.getReactNativeBlobUtilRef();\r\n }\r\n\r\n let req = ReactNativeBlobUtil[nativeMethodName];\r\n\r\n /**\r\n * Send request via native module, the response callback accepts three arguments\r\n * @callback\r\n * @param err {any} Error message or object, when the request success, this\r\n * parameter should be `null`.\r\n * @param rawType { 'utf8' | 'base64' | 'path'} RNFB request will be stored\r\n * as UTF8 string, BASE64 string, or a file path reference\r\n * in JS context, and this parameter indicates which one\r\n * dose the response data presents.\r\n * @param data {string} Response data or its reference.\r\n */\r\n req(options, taskId, method, url, headers || {}, body, (err, rawType, data) => {\r\n\r\n // task done, remove event listeners\r\n subscription.remove();\r\n subscriptionUpload.remove();\r\n stateEvent.remove();\r\n partEvent.remove();\r\n delete promise['progress'];\r\n delete promise['uploadProgress'];\r\n delete promise['stateChange'];\r\n delete promise['part'];\r\n delete promise['cancel'];\r\n // delete promise['expire']\r\n promise.cancel = () => {\r\n };\r\n\r\n if (err)\r\n reject(new Error(err, respInfo));\r\n else {\r\n // response data is saved to storage, create a session for it\r\n if (options.path || options.fileCache || options.addAndroidDownloads\r\n || options.key || options.auto && respInfo.respType === 'blob') {\r\n if (options.session)\r\n fs.session(options.session).add(data);\r\n }\r\n respInfo.rnfbEncode = rawType;\r\n resolve(new FetchBlobResponse(taskId, respInfo, data));\r\n }\r\n\r\n });\r\n\r\n });\r\n\r\n // extend Promise object, add `progress`, `uploadProgress`, and `cancel`\r\n // method for register progress event handler and cancel request.\r\n // Add second parameter for performance purpose #140\r\n // When there's only one argument pass to this method, use default `interval`\r\n // and `count`, otherwise use the given on.\r\n // TODO : code refactor, move `uploadProgress` and `progress` to StatefulPromise\r\n promise.progress = (...args) => {\r\n let interval = 250;\r\n let count = -1;\r\n let fn = () => {\r\n };\r\n if (args.length === 2) {\r\n interval = args[0].interval || interval;\r\n count = args[0].count || count;\r\n fn = args[1];\r\n }\r\n else {\r\n fn = args[0];\r\n }\r\n promise.onProgress = fn;\r\n ReactNativeBlobUtil.enableProgressReport(taskId, interval, count);\r\n return promise;\r\n };\r\n promise.uploadProgress = (...args) => {\r\n let interval = 250;\r\n let count = -1;\r\n let fn = () => {\r\n };\r\n if (args.length === 2) {\r\n interval = args[0].interval || interval;\r\n count = args[0].count || count;\r\n fn = args[1];\r\n }\r\n else {\r\n fn = args[0];\r\n }\r\n promise.onUploadProgress = fn;\r\n ReactNativeBlobUtil.enableUploadProgressReport(taskId, interval, count);\r\n return promise;\r\n };\r\n promise.part = (fn) => {\r\n promise.onPartData = fn;\r\n return promise;\r\n };\r\n promise.stateChange = (fn) => {\r\n promise.onStateChange = fn;\r\n return promise;\r\n };\r\n promise.expire = (fn) => {\r\n promise.onExpire = fn;\r\n return promise;\r\n };\r\n promise.cancel = (fn) => {\r\n fn = fn || function () {\r\n };\r\n subscription.remove();\r\n subscriptionUpload.remove();\r\n stateEvent.remove();\r\n ReactNativeBlobUtil.cancelRequest(taskId, fn);\r\n promiseReject(new Error(\"canceled\"));\r\n };\r\n promise.taskId = taskId;\r\n\r\n return promise;\r\n\r\n}\r\n","// Copyright 2016 wkh237@github. All rights reserved.\r\n// Use of this source code is governed by a MIT-style license that can be\r\n// found in the LICENSE file.\r\n\r\nimport EventTarget from './EventTarget';\r\nimport Blob from './Blob';\r\nimport Log from '../utils/log.js';\r\n\r\nconst log = new Log('FileReader');\r\n\r\nlog.level(3);\r\n\r\nexport default class FileReader extends EventTarget {\r\n\r\n static get EMPTY() {\r\n return 0;\r\n }\r\n\r\n static get LOADING() {\r\n return 1;\r\n }\r\n\r\n static get DONE() {\r\n return 2;\r\n }\r\n\r\n // properties\r\n _readState: number = 0;\r\n _result: any;\r\n _error: any;\r\n\r\n get isRNFBPolyFill() {\r\n return true;\r\n }\r\n\r\n // event handlers\r\n onloadstart: (e: Event) => void;\r\n onprogress: (e: Event) => void;\r\n onload: (e: Event) => void;\r\n onabort: (e: Event) => void;\r\n onerror: (e: Event) => void;\r\n onloadend: (e: Event) => void;\r\n\r\n constructor() {\r\n super();\r\n log.verbose('file reader const');\r\n this._result = null;\r\n }\r\n\r\n abort() {\r\n log.verbose('abort');\r\n }\r\n\r\n readAsArrayBuffer(b: Blob) {\r\n log.verbose('readAsArrayBuffer', b);\r\n }\r\n\r\n readAsBinaryString(b: Blob) {\r\n log.verbose('readAsBinaryString', b);\r\n }\r\n\r\n readAsText(b: Blob, label: ?string) {\r\n log.verbose('readAsText', b, label);\r\n }\r\n\r\n readAsDataURL(b: Blob) {\r\n log.verbose('readAsDataURL', b);\r\n }\r\n\r\n dispatchEvent(event, e) {\r\n log.verbose('dispatch event', event, e);\r\n super.dispatchEvent(event, e);\r\n if (typeof this[`on${event}`] === 'function') {\r\n this[`on${event}`](e);\r\n }\r\n }\r\n\r\n // private methods\r\n\r\n // getters and setters\r\n\r\n get readyState() {\r\n return this._readyState;\r\n }\r\n\r\n get result() {\r\n return this._result;\r\n }\r\n\r\n\r\n}\r\n","import Log from '../utils/log.js';\r\nimport Blob from './Blob';\r\nimport {config as RNconfig} from \"../fetch\";\r\nimport type {ReactNativeBlobUtilConfig} from \"../types\";\r\nimport URIUtil from \"../utils/uri\";\r\nimport {FetchBlobResponse} from \"../class/ReactNativeBlobUtilBlobResponse\";\r\n\r\nconst log = new Log('FetchPolyfill');\r\n\r\nlog.disable();\r\n// log.level(3)\r\n\r\nexport default class Fetch {\r\n\r\n constructor(config: ReactNativeBlobUtilConfig) {\r\n Object.assign(this, new ReactNativeBlobUtilFetchPolyfill(config));\r\n }\r\n\r\n}\r\n\r\nclass ReactNativeBlobUtilFetchPolyfill {\r\n\r\n constructor(config: ReactNativeBlobUtilConfig) {\r\n this.build = () => (url, options = {}) => {\r\n\r\n let body = options.body;\r\n let promise = Promise.resolve();\r\n let blobCache = null;\r\n\r\n options.headers = options.headers || {};\r\n let ctype = options['Content-Type'] || options['content-type'];\r\n let ctypeH = options.headers['Content-Type'] || options.headers['content-type'];\r\n options.headers['Content-Type'] = ctype || ctypeH;\r\n options.headers['content-type'] = ctype || ctypeH;\r\n options.method = options.method || 'GET';\r\n if (body) {\r\n // When the request body is an instance of FormData, create a Blob cache\r\n // to upload the body.\r\n if (body instanceof FormData) {\r\n log.verbose('convert FormData to blob body');\r\n promise = Blob.build(body).then((b) => {\r\n blobCache = b;\r\n options.headers['Content-Type'] = 'multipart/form-data;boundary=' + b.multipartBoundary;\r\n return Promise.resolve(URIUtil.wrap(b._ref));\r\n });\r\n }\r\n // When request body is a Blob, use file URI of the Blob as request body.\r\n else if (body.isReactNativeBlobUtilPolyfill)\r\n promise = Promise.resolve(URIUtil.wrap(body.blobPath));\r\n else if (typeof body !== 'object' && options.headers['Content-Type'] !== 'application/json')\r\n promise = Promise.resolve(JSON.stringify(body));\r\n else if (typeof body !== 'string')\r\n promise = Promise.resolve(body.toString());\r\n // send it as-is, leave the native module decide how to send the body.\r\n else\r\n promise = Promise.resolve(body);\r\n }\r\n // task is a progress reportable and cancellable Promise, however,\r\n // task.then is not, so we have to extend task.then with progress and\r\n // cancel function\r\n let progressHandler, uploadHandler, cancelHandler;\r\n let scopedTask = null;\r\n let statefulPromise = promise\r\n .then((body) => {\r\n let task = RNconfig(config)\r\n .fetch(options.method, url, options.headers, body);\r\n scopedTask = task;\r\n if (progressHandler)\r\n task.progress(progressHandler);\r\n if (uploadHandler)\r\n task.uploadProgress(uploadHandler);\r\n if (cancelHandler)\r\n task.cancel();\r\n return task.then((resp) => {\r\n log.verbose('response', resp);\r\n // release blob cache created when sending request\r\n if (blobCache !== null && blobCache instanceof Blob)\r\n blobCache.close();\r\n return Promise.resolve(new ReactNativeBlobUtilFetchResponse(resp));\r\n });\r\n });\r\n\r\n // extend task.then progress with report and cancelling functions\r\n statefulPromise.progress = (fn) => {\r\n progressHandler = fn;\r\n };\r\n statefulPromise.uploadProgress = (fn) => {\r\n uploadHandler = fn;\r\n };\r\n statefulPromise.cancel = () => {\r\n cancelHandler = true;\r\n if (scopedTask && scopedTask.cancel)\r\n scopedTask.cancel();\r\n };\r\n\r\n return statefulPromise;\r\n\r\n };\r\n }\r\n\r\n}\r\n\r\nclass ReactNativeBlobUtilFetchResponse {\r\n\r\n constructor(resp: FetchBlobResponse) {\r\n let info = resp.info();\r\n this.headers = info.headers;\r\n this.ok = info.status >= 200 && info.status <= 299,\r\n this.status = info.status;\r\n this.type = 'basic';\r\n this.bodyUsed = false;\r\n this.resp = resp;\r\n this.rnfbRespInfo = info;\r\n this.rnfbResp = resp;\r\n }\r\n\r\n rawResp() {\r\n return Promise.resolve(this.rnfbResp);\r\n }\r\n\r\n arrayBuffer() {\r\n log.verbose('to arrayBuffer', this.rnfbRespInfo);\r\n this.bodyUsed = true;\r\n return readArrayBuffer(this.rnfbResp, this.rnfbRespInfo);\r\n }\r\n\r\n text() {\r\n log.verbose('to text', this.rnfbResp, this.rnfbRespInfo);\r\n this.bodyUsed = true;\r\n return readText(this.rnfbResp, this.rnfbRespInfo);\r\n }\r\n\r\n json() {\r\n log.verbose('to json', this.rnfbResp, this.rnfbRespInfo);\r\n this.bodyUsed = true;\r\n return readJSON(this.rnfbResp, this.rnfbRespInfo);\r\n }\r\n\r\n blob() {\r\n log.verbose('to blob', this.rnfbResp, this.rnfbRespInfo);\r\n this.bodyUsed = true;\r\n return readBlob(this.rnfbResp, this.rnfbRespInfo);\r\n }\r\n}\r\n\r\n/**\r\n * Get response data as array.\r\n * @param {FetchBlobResponse} resp Response data object from RNFB fetch call.\r\n * @param {ReactNativeBlobUtilResponseInfo} info Response informations.\r\n * @return {Promise}\r\n */\r\nfunction readArrayBuffer(resp, info): Promise {\r\n switch (info.rnfbEncode) {\r\n case 'path':\r\n return resp.readFile('ascii');\r\n break;\r\n default:\r\n let buffer = [];\r\n let str = resp.text();\r\n for (let i in str) {\r\n buffer[i] = str.charCodeAt(i);\r\n }\r\n return Promise.resolve(buffer);\r\n break;\r\n }\r\n}\r\n\r\n/**\r\n * Get response data as string.\r\n * @param {FetchBlobResponse} resp Response data object from RNFB fetch call.\r\n * @param {ReactNativeBlobUtilResponseInfo} info Response informations.\r\n * @return {Promise}\r\n */\r\nfunction readText(resp, info): Promise {\r\n switch (info.rnfbEncode) {\r\n case 'base64':\r\n return Promise.resolve(resp.text());\r\n break;\r\n case 'path':\r\n return resp.text();\r\n break;\r\n default:\r\n return Promise.resolve(resp.text());\r\n break;\r\n }\r\n}\r\n\r\n\r\n/**\r\n * Get response data as ReactNativeBlobUtil Blob polyfill object.\r\n * @param {FetchBlobResponse} resp Response data object from RNFB fetch call.\r\n * @param {ReactNativeBlobUtilResponseInfo} info Response informations.\r\n * @return {Promise}\r\n */\r\nfunction readBlob(resp, info): Promise {\r\n log.verbose('readBlob', resp, info);\r\n return resp.blob();\r\n}\r\n\r\n/**\r\n * Get response data as JSON object.\r\n * @param {FetchBlobResponse} resp Response data object from RNFB fetch call.\r\n * @param {ReactNativeBlobUtilResponseInfo} info Response informations.\r\n * @return {Promise}\r\n */\r\nfunction readJSON(resp, info): Promise {\r\n log.verbose('readJSON', resp, info);\r\n switch (info.rnfbEncode) {\r\n case 'base64':\r\n return Promise.resolve(resp.json());\r\n case 'path':\r\n return resp.json();\r\n default:\r\n return Promise.resolve(resp.json());\r\n }\r\n}\r\n","// Copyright 2016 wkh237@github. All rights reserved.\r\n// Use of this source code is governed by a MIT-style license that can be\r\n// found in the LICENSE file.\r\n\r\nimport { NativeModules, Platform } from 'react-native';\r\n\r\nconst ReactNativeBlobUtil = NativeModules.ReactNativeBlobUtil;\r\n\r\n/**\r\n * Send an intent to open the file.\r\n * @param {string} path Path of the file to be open.\r\n * @param {string} mime MIME type string\r\n * @param {string} chooserTitle for chooser, if not set the chooser won't be displayed (see https://developer.android.com/reference/android/content/Intent.html#createChooser(android.content.Intent,%20java.lang.CharSequence))\r\n * @return {Promise}\r\n */\r\nfunction actionViewIntent(path, mime, chooserTitle) {\r\n if(typeof chooserTitle === 'undefined') chooserTitle = null;\r\n if(Platform.OS === 'android')\r\n return ReactNativeBlobUtil.actionViewIntent(path, mime, chooserTitle);\r\n else\r\n return Promise.reject('ReactNativeBlobUtil.android.actionViewIntent only supports Android.');\r\n}\r\n\r\nfunction getContentIntent(mime) {\r\n if(Platform.OS === 'android')\r\n return ReactNativeBlobUtil.getContentIntent(mime);\r\n else\r\n return Promise.reject('ReactNativeBlobUtil.android.getContentIntent only supports Android.');\r\n}\r\n\r\nfunction addCompleteDownload(config) {\r\n if(Platform.OS === 'android')\r\n return ReactNativeBlobUtil.addCompleteDownload(config);\r\n else\r\n return Promise.reject('ReactNativeBlobUtil.android.addCompleteDownload only supports Android.');\r\n}\r\n\r\nfunction getSDCardDir() {\r\n if(Platform.OS === 'android')\r\n return ReactNativeBlobUtil.getSDCardDir();\r\n else\r\n return Promise.reject('ReactNativeBlobUtil.android.getSDCardDir only supports Android.');\r\n}\r\n\r\nfunction getSDCardApplicationDir() {\r\n if(Platform.OS === 'android')\r\n return ReactNativeBlobUtil.getSDCardApplicationDir();\r\n else\r\n return Promise.reject('ReactNativeBlobUtil.android.getSDCardApplicationDir only supports Android.');\r\n}\r\n\r\n\r\nexport default {\r\n actionViewIntent,\r\n getContentIntent,\r\n addCompleteDownload,\r\n getSDCardDir,\r\n getSDCardApplicationDir,\r\n};\r\n","// Copyright 2016 wkh237@github. All rights reserved.\r\n// Use of this source code is governed by a MIT-style license that can be\r\n// found in the LICENSE file.\r\n\r\nimport { NativeModules, Platform } from \"react-native\";\r\n\r\nconst ReactNativeBlobUtil: ReactNativeBlobUtilNative = NativeModules.ReactNativeBlobUtil;\r\n\r\n/**\r\n * Displays an options menu using UIDocumentInteractionController.presentOptionsMenu\r\n * @param {string} path Path of the file to be open.\r\n * @param {string} scheme URI scheme that needs to support, optional\r\n * @return {Promise}\r\n */\r\nfunction presentOptionsMenu(path: string, scheme: string) {\r\n if (Platform.OS === \"ios\")\r\n return ReactNativeBlobUtil.presentOptionsMenu(\"file://\" + path, scheme);\r\n else return Promise.reject(\"ReactNativeBlobUtil.openDocument only supports IOS.\");\r\n}\r\n\r\n/**\r\n * Displays a menu for opening the document using UIDocumentInteractionController.presentOpenInMenu\r\n * @param {string} path Path of the file to be open.\r\n * @param {string} scheme URI scheme that needs to support, optional\r\n * @return {Promise}\r\n */\r\nfunction presentOpenInMenu(path: string, scheme: string) {\r\n if (Platform.OS === \"ios\")\r\n return ReactNativeBlobUtil.presentOpenInMenu(\"file://\" + path, scheme);\r\n else return Promise.reject(\"ReactNativeBlobUtil.openDocument only supports IOS.\");\r\n}\r\n\r\n/**\r\n * Displays a full-screen preview of the target document using UIDocumentInteractionController.presentPreview\r\n * @param {string} path Path of the file to be open.\r\n * @param {string} scheme URI scheme that needs to support, optional\r\n * @return {Promise}\r\n */\r\nfunction presentPreview(path: string, scheme: string) {\r\n if (Platform.OS === \"ios\")\r\n return ReactNativeBlobUtil.presentPreview(\"file://\" + path, scheme);\r\n else return Promise.reject(\"ReactNativeBlobUtil.previewDocument only supports IOS.\");\r\n}\r\n\r\n/**\r\n * Set excludeFromBackupKey to a URL to prevent the resource to be backuped to\r\n * iCloud.\r\n * @param {string} url URL of the resource, only file URL is supported\r\n * @return {Promise}\r\n */\r\nfunction excludeFromBackupKey(path: string) {\r\n return ReactNativeBlobUtil.excludeFromBackupKey(\"file://\" + path);\r\n}\r\n\r\nexport default {\r\n presentPreview,\r\n openDocument: presentPreview, // legacy alias\r\n presentOptionsMenu,\r\n previewDocument: presentOptionsMenu, // legacy alias\r\n presentOpenInMenu,\r\n excludeFromBackupKey\r\n};\r\n","import Oboe from './lib/oboe-browser.min.js';\r\nimport XMLHttpRequest from './polyfill/XMLHttpRequest';\r\nimport URIUtil from './utils/uri';\r\n\r\nconst OboeExtended = (arg: string | Object) => {\r\n\r\n\r\n window.location = '';\r\n\r\n if (!window.XMLHttpRequest.isRNFBPolyfill) {\r\n window.XMLHttpRequest = XMLHttpRequest;\r\n console.warn(\r\n 'Use JSONStream will automatically replace window.XMLHttpRequest with ReactNativeBlobUtil.polyfill.XMLHttpRequest. ' +\r\n 'You are seeing this warning because you did not replace it manually.'\r\n );\r\n }\r\n\r\n if (typeof arg === 'string') {\r\n if (URIUtil.isFileURI(arg)) {\r\n arg = {\r\n url: 'JSONStream://' + arg,\r\n headers: {noCache: true}\r\n };\r\n }\r\n else\r\n arg = 'JSONStream://' + arg;\r\n\r\n }\r\n else if (typeof arg === 'object') {\r\n let headers = arg.headers || {};\r\n if (URIUtil.isFileURI(arg.url)) {\r\n headers.noCache = true;\r\n }\r\n arg = Object.assign(arg, {\r\n url: 'JSONStream://' + arg.url,\r\n headers\r\n });\r\n }\r\n return Oboe(arg);\r\n};\r\n\r\nexport default OboeExtended;\r\n","!function(a,b,c,d,e,f){function g(a,b){return function(){return a.call(this,b.apply(this,arguments));};}function h(a){return function(b){return b[a];};}function i(a,b){return b.apply(f,a);}function j(a){var b=a.length-1,d=c.prototype.slice; if(0==b)return function(){return a.call(this,d.call(arguments));}; if(1==b)return function(){return a.call(this,arguments[0],d.call(arguments,1));}; var e=c(a.length); return function(){for(var c=0; b>c; c++)e[c]=arguments[c]; return e[b]=d.call(arguments,b),a.apply(this,e);};}function k(a){return function(b,c){return a(c,b);};}function l(a,b){return function(c){return a(c)&&b(c);};}function m(){}function n(){return!0;}function o(a){return function(){return a;};}function p(a,b){return b&&b.constructor===a;}function q(a){return a!==f;}function r(a,c){return c instanceof b&&y(function(a){return a in c;},a);}function s(a,b){return[a,b];}function t(a){return A(a.reduce(k(s),X));}function u(a){return w(function(a,b){return a.unshift(b),a;},[],a);}function v(a,b){return b?s(a(Y(b)),v(a,Z(b))):X;}function w(a,b,c){return c?a(w(a,b,Z(c)),Y(c)):b;}function x(a,b,c){function d(a,c){return a?b(Y(a))?(c(Y(a)),Z(a)):s(Y(a),d(Z(a),c)):X;}return d(a,c||m);}function y(a,b){return!b||a(Y(b))&&y(a,Z(b));}function z(a,b){a&&(Y(a).apply(null,b),z(Z(a),b));}function A(a){function b(a,c){return a?b(Z(a),s(Y(a),c)):c;}return b(a,X);}function B(a,b){return b&&(a(Y(b))?Y(b):B(a,Z(b)));}function C(a){\"use strict\"; function b(){var a=0; P.length>p&&(c(\"Max buffer length exceeded: textNode\"),a=Math.max(a,P.length)),Q.length>p&&(c(\"Max buffer length exceeded: numberNode\"),a=Math.max(a,Q.length)),O=p-a+Y;}function c(a){P&&(m(P),n(),P=\"\"),i=d(a+\"\\nLn: \"+$+\"\\nCol: \"+Z+\"\\nChr: \"+j),o(N(f,f,i));}function e(){return T==s?(m({}),n(),void(S=!0)):((T!==t||0!==X)&&c(\"Unexpected end\"),P&&(m(P),n(),P=\"\"),void(S=!0));}function g(a){return\"\\r\"==a||\"\\n\"==a||\" \"==a||\"\t\"==a;}function h(a){if(!i){if(S)return c(\"Cannot write after close\"); var d=0; for(j=a[0]; j&&(k=j,j=a[d++]);)switch(Y++,\"\\n\"==j?($++,Z=0):Z++,T){case s:if(\"{\"===j)T=u; else if(\"[\"===j)T=w; else if(!g(j))return c(\"Non-whitespace before {[.\"); continue; case z:case u:if(g(j))continue; if(T===z)U.push(A); else{if(\"}\"===j){m({}),n(),T=U.pop()||t; continue;}U.push(v);}if('\"'!==j)return c('Malformed object key should start with \" '); T=y; continue; case A:case v:if(g(j))continue; if(\":\"===j)T===v?(U.push(v),P&&(m({}),l(P),P=\"\"),X++):P&&(l(P),P=\"\"),T=t; else if(\"}\"===j)P&&(m(P),n(),P=\"\"),n(),X--,T=U.pop()||t; else{if(\",\"!==j)return c(\"Bad object\"); T===v&&U.push(v),P&&(m(P),n(),P=\"\"),T=z;}continue; case w:case t:if(g(j))continue; if(T===w){if(m([]),X++,T=t,\"]\"===j){n(),X--,T=U.pop()||t; continue;}U.push(x);}if('\"'===j)T=y; else if(\"{\"===j)T=u; else if(\"[\"===j)T=w; else if(\"t\"===j)T=B; else if(\"f\"===j)T=E; else if(\"n\"===j)T=I; else if(\"-\"===j)Q+=j; else if(\"0\"===j)Q+=j,T=M; else{if(-1===\"123456789\".indexOf(j))return c(\"Bad value\"); Q+=j,T=M;}continue; case x:if(\",\"===j)U.push(x),P&&(m(P),n(),P=\"\"),T=t; else{if(\"]\"!==j){if(g(j))continue; return c(\"Bad array\");}P&&(m(P),n(),P=\"\"),n(),X--,T=U.pop()||t;}continue; case y:var e=d-1; a:for(;;){for(;W>0;)if(V+=j,j=a.charAt(d++),4===W?(P+=String.fromCharCode(parseInt(V,16)),W=0,e=d-1):W++,!j)break a; if('\"'===j&&!R){T=U.pop()||t,P+=a.substring(e,d-1),P||(m(\"\"),n()); break;}if(\"\\\\\"===j&&!R&&(R=!0,P+=a.substring(e,d-1),j=a.charAt(d++),!j))break; if(R){if(R=!1,\"n\"===j?P+=\"\\n\":\"r\"===j?P+=\"\\r\":\"t\"===j?P+=\"\t\":\"f\"===j?P+=\"\\f\":\"b\"===j?P+=\"\\b\":\"u\"===j?(W=1,V=\"\"):P+=j,j=a.charAt(d++),e=d-1,j)continue; break;}q.lastIndex=d; var f=q.exec(a); if(!f){d=a.length+1,P+=a.substring(e,d-1); break;}if(d=f.index+1,j=a.charAt(f.index),!j){P+=a.substring(e,d-1); break;}}continue; case B:if(!j)continue; if(\"r\"!==j)return c(\"Invalid true started with t\"+j); T=C; continue; case C:if(!j)continue; if(\"u\"!==j)return c(\"Invalid true started with tr\"+j); T=D; continue; case D:if(!j)continue; if(\"e\"!==j)return c(\"Invalid true started with tru\"+j); m(!0),n(),T=U.pop()||t; continue; case E:if(!j)continue; if(\"a\"!==j)return c(\"Invalid false started with f\"+j); T=F; continue; case F:if(!j)continue; if(\"l\"!==j)return c(\"Invalid false started with fa\"+j); T=G; continue; case G:if(!j)continue; if(\"s\"!==j)return c(\"Invalid false started with fal\"+j); T=H; continue; case H:if(!j)continue; if(\"e\"!==j)return c(\"Invalid false started with fals\"+j); m(!1),n(),T=U.pop()||t; continue; case I:if(!j)continue; if(\"u\"!==j)return c(\"Invalid null started with n\"+j); T=J; continue; case J:if(!j)continue; if(\"l\"!==j)return c(\"Invalid null started with nu\"+j); T=K; continue; case K:if(!j)continue; if(\"l\"!==j)return c(\"Invalid null started with nul\"+j); m(null),n(),T=U.pop()||t; continue; case L:if(\".\"!==j)return c(\"Leading zero not followed by .\"); Q+=j,T=M; continue; case M:if(-1!==\"0123456789\".indexOf(j))Q+=j; else if(\".\"===j){if(-1!==Q.indexOf(\".\"))return c(\"Invalid number has two dots\"); Q+=j;}else if(\"e\"===j||\"E\"===j){if(-1!==Q.indexOf(\"e\")||-1!==Q.indexOf(\"E\"))return c(\"Invalid number has two exponential\"); Q+=j;}else if(\"+\"===j||\"-\"===j){if(\"e\"!==k&&\"E\"!==k)return c(\"Invalid symbol in number\"); Q+=j;}else Q&&(m(parseFloat(Q)),n(),Q=\"\"),d--,T=U.pop()||t; continue; default:return c(\"Unknown state: \"+T);}Y>=O&&b();}}var i,j,k,l=a(qb).emit,m=a(rb).emit,n=a(sb).emit,o=a(jb).emit,p=65536,q=/[\\\\\"\\n]/g,r=0,s=r++,t=r++,u=r++,v=r++,w=r++,x=r++,y=r++,z=r++,A=r++,B=r++,C=r++,D=r++,E=r++,F=r++,G=r++,H=r++,I=r++,J=r++,K=r++,L=r++,M=r,O=p,P=\"\",Q=\"\",R=!1,S=!1,T=s,U=[],V=null,W=0,X=0,Y=0,Z=0,$=1; a(nb).on(h),a(ob).on(e);}function D(a,b){\"use strict\"; function c(a){return function(b){d=a(d,b);};}var d,e={}; for(var f in b)a(f).on(c(b[f]),e); a(hb).on(function(a){var b,c=Y(d),e=ab(c),f=Z(d); f&&(b=bb(Y(f)),b[e]=a);}),a(ib).on(function(){var a,b=Y(d),c=ab(b),e=Z(d); e&&(a=bb(Y(e)),delete a[c]);}),a(pb).on(function(){for(var c in b)a(c).un(e);});}function E(a){var b={}; return a&&a.split(\"\\r\\n\").forEach(function(a){var c=a.indexOf(\": \"); b[a.substring(0,c)]=a.substring(c+2);}),b;}function F(a,b){function c(a){return{\"http:\":80,\"https:\":443}[a];}function d(b){return b.port||c(b.protocol||a.protocol);}return!!(b.protocol&&b.protocol!=a.protocol||b.host&&b.host!=a.host||b.host&&d(b)!=d(a));}function G(a){var b=/(\\w+:)?(?:\\/\\/)([\\w.-]+)?(?::(\\d+))?\\/?/,c=b.exec(a)||[]; return{protocol:c[1]||\"\",host:c[2]||\"\",port:c[3]||\"\"};}function H(){return new XMLHttpRequest;}function I(b,c,d,e,g,h,i){\"use strict\"; function j(){var a=c.responseText,b=a.substr(m); b&&k(b),m=V(a);}var k=b(nb).emit,l=b(jb).emit,m=0,n=!0; b(pb).on(function(){c.onreadystatechange=null,c.abort();}),\"onprogress\"in c&&(c.onprogress=j),c.onreadystatechange=function(){function a(){try{n&&b(mb).emit(c.status,E(c.getAllResponseHeaders())),n=!1;}catch(a){}}switch(c.readyState){case 2:case 3:return a(); case 4:a(); var d=2==String(c.status)[0]; d?(j(),b(ob).emit()):l(N(c.status,c.responseText));}}; try{c.open(d,e,!0); for(var o in h)c.setRequestHeader(o,h[o]); F(a.location,G(e))||c.setRequestHeader(\"X-Requested-With\",\"XMLHttpRequest\"),c.withCredentials=i,c.send(g);}catch(p){a.setTimeout(T(l,N(f,f,p)),0);}}function J(a,b){return{key:a,node:b};}function K(a){function b(a,b){var d=bb(Y(a)); return p(c,d)?f(a,V(d),b):a;}function d(a,c){if(!a)return j(c),f(a,cb,c); var d=b(a,c),g=Z(d),h=ab(Y(d)); return e(g,h,c),s(J(h,c),g);}function e(a,b,c){bb(Y(a))[b]=c;}function f(a,b,c){a&&e(a,b,c); var d=s(J(b,c),a); return h(d),d;}function g(a){return i(a),Z(a)||k(bb(Y(a)));}var h=a(fb).emit,i=a(gb).emit,j=a(lb).emit,k=a(kb).emit,l={}; return l[rb]=d,l[sb]=g,l[qb]=f,l;}function L(a,b,c){function d(a){return function(b){return b.id==a;};}var e,f; return{on:function(c,d){var g={listener:c,id:d||c}; return b&&b.emit(a,c,g.id),e=s(g,e),f=s(c,f),this;},emit:function(){z(f,arguments);},un:function(b){var g; e=x(e,d(b),function(a){g=a;}),g&&(f=x(f,function(a){return a==g.listener;}),c&&c.emit(a,g.listener,g.id));},listeners:function(){return f;},hasListener:function(a){var b=a?d(a):n; return q(B(b,e));}};}function M(){function a(a){return c[a]=L(a,d,e);}function b(b){return c[b]||a(b);}var c={},d=a(\"newListener\"),e=a(\"removeListener\"); return[\"emit\",\"on\",\"un\"].forEach(function(a){b[a]=j(function(c,d){i(d,b(c)[a]);});}),b;}function N(a,b,c){try{var d=e.parse(b);}catch(f){}return{statusCode:a,body:b,jsonBody:d,thrown:c};}function O(a,b){function c(a,b,c){var d=A(c); a(b,u(Z(v(ab,d))),u(v(bb,d)));}function d(b,d,e){var f=a(b).emit; d.on(function(a){var b=e(a); b!==!1&&c(f,bb(b),a);},b),a(\"removeListener\").on(function(c){c==b&&(a(c).listeners()||d.un(b));});}var e={node:a(gb),path:a(fb)}; a(\"newListener\").on(function(a){var c=/(node|path):(.*)/.exec(a); if(c){var f=e[c[1]]; f.hasListener(a)||d(a,f,b(c[2]));}});}function P(a,b){function c(b,c){return a(b).on(e(c),c),p;}function d(a,b,c){c=c||b; var d=e(b); return a.on(function(){var b=!1; p.forget=function(){b=!0;},i(arguments,d),delete p.forget,b&&a.un(c);},c),p;}function e(b){return function(){try{return b.apply(p,arguments);}catch(c){a(jb).emit(N(f,f,c));}};}function g(b,c){return a(b+\":\"+c);}function h(a){return function(){var b=a.apply(this,arguments); q(b)&&(b==S.drop?t():u(b));};}function k(a,b,c){var e; e=\"node\"==a?h(c):c,d(g(a,b),e,c);}function l(a,b){for(var c in b)k(a,c,b[c]);}function n(a,b,c){return W(b)?k(a,b,c):l(a,b),p;}var p,r=/^(node|path):./,s=a(kb),t=a(ib).emit,u=a(hb).emit,v=j(function(b,c){if(p[b])i(c,p[b]); else{var e=a(b),f=c[0]; r.test(b)?d(e,f):e.on(f);}return p;}),w=function(b,c,d){if(\"done\"==b)s.un(c); else if(\"node\"==b||\"path\"==b)a.un(b+\":\"+c,d); else{var e=c; a(b).un(e);}return p;}; return a(lb).on(function(a){p.root=o(a);}),a(mb).on(function(a,b){p.header=function(a){return a?b[a]:b;};}),p={on:v,addListener:v,removeListener:w,emit:a.emit,node:T(n,\"node\"),path:T(n,\"path\"),done:T(d,s),start:T(c,mb),fail:a(jb).on,abort:a(pb).emit,header:m,root:m,source:b};}function Q(a,b,c,d,e){var f=M(); return b&&I(f,H(),a,b,c,d,e),C(f),D(f,K(f)),O(f,db),P(f,b);}function R(a,b,c,d,f,g,h){function i(a,b){return b===!1&&(a+=-1==a.indexOf(\"?\")?\"?\":\"&\",a+=\"_=\"+(new Date).getTime()),a;}return f=f?e.parse(e.stringify(f)):{},d?W(d)||(d=e.stringify(d),f[\"Content-Type\"]=f[\"Content-Type\"]||\"application/json\"):d=null,a(c||\"GET\",i(b,h),d,f,g||!1);}function S(a){var b=$(\"resume\",\"pause\",\"pipe\"),c=T(r,b); return a?c(a)||W(a)?R(Q,a):R(Q,a.url,a.method,a.body,a.headers,a.withCredentials,a.cached):Q();}var T=j(function(a,b){var c=b.length; return j(function(d){for(var e=0; e Linking.openSettings(),\n },\n ],\n );\n}\n\n/**\n * Generate a random file name with timestamp and file extension\n * @param {String} url\n * @returns {String}\n */\nfunction getAttachmentName(url) {\n if (!url) {\n return '';\n }\n return `${moment().format('DDMMYYYYHHmmss')}.${url.split(/[#?]/)[0].split('.').pop().trim()}`;\n}\n\n/**\n * @param {String} fileName\n * @returns {Boolean}\n */\nfunction isImage(fileName) {\n return CONST.FILE_TYPE_REGEX.IMAGE.test(fileName);\n}\n\n/**\n * @param {String} fileName\n * @returns {Boolean}\n */\nfunction isVideo(fileName) {\n return CONST.FILE_TYPE_REGEX.VIDEO.test(fileName);\n}\n\n/**\n * Returns file type based on the uri\n * @param {String} fileUrl\n * @returns {String}\n */\nfunction getFileType(fileUrl) {\n if (!fileUrl) {\n return;\n }\n const fileName = fileUrl.split('/').pop().split('?')[0].split('#')[0];\n if (isImage(fileName)) {\n return CONST.ATTACHMENT_FILE_TYPE.IMAGE;\n }\n if (isVideo(fileName)) {\n return CONST.ATTACHMENT_FILE_TYPE.VIDEO;\n }\n return CONST.ATTACHMENT_FILE_TYPE.FILE;\n}\n\n/**\n * Returns the filename split into fileName and fileExtension\n *\n * @param {String} fullFileName\n * @returns {Object}\n */\nfunction splitExtensionFromFileName(fullFileName) {\n const fileName = fullFileName.trim();\n const splitFileName = fileName.split('.');\n const fileExtension = splitFileName.pop();\n return {fileName: splitFileName.join('.'), fileExtension};\n}\n\n/**\n * Returns the filename replacing special characters with underscore\n *\n * @param {String} fileName\n * @returns {String}\n */\nfunction cleanFileName(fileName) {\n return fileName.replace(/[^a-zA-Z0-9\\-._]/g, '_');\n}\n\nexport {\n showGeneralErrorAlert,\n showSuccessAlert,\n showPermissionErrorAlert,\n splitExtensionFromFileName,\n getAttachmentName,\n getFileType,\n cleanFileName,\n};\n","export * from './useCameraRoll';\nexport * from './CameraRoll';\nexport * from './CameraRollIOSPermission';\n","import {useState} from 'react';\nimport type {\n GetPhotosParams,\n PhotoIdentifiersPage,\n SaveToCameraRollOptions,\n} from './CameraRoll';\nimport {CameraRoll} from './CameraRoll';\n\nconst initialState: PhotoIdentifiersPage = {\n edges: [],\n page_info: {\n end_cursor: '',\n has_next_page: false,\n start_cursor: '',\n },\n};\n\nconst defaultConfig: GetPhotosParams = {\n first: 20,\n groupTypes: 'All',\n};\n\ntype UseCameraRollResult = [\n PhotoIdentifiersPage,\n (config?: GetPhotosParams) => Promise,\n (tag: string, options?: SaveToCameraRollOptions) => Promise,\n];\n\nexport function useCameraRoll(): UseCameraRollResult {\n const [photos, setPhotos] = useState(initialState);\n\n async function getPhotos(\n config: GetPhotosParams = defaultConfig,\n ): Promise {\n try {\n const result = await CameraRoll.getPhotos(config);\n setPhotos(result);\n } catch (error) {\n if (__DEV__) console.log('[useCameraRoll] Error getting photos: ', error);\n }\n }\n\n async function save(\n ...args: Parameters\n ): Promise {\n try {\n await CameraRoll.save(...args);\n } catch (error) {\n if (__DEV__)\n console.log('[useCameraRoll] Error saving to camera roll: ', error);\n }\n }\n\n return [photos, getPhotos, save];\n}\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 */\nimport {Platform} from 'react-native';\nimport RNCCameraRoll from './NativeCameraRollModule';\n\nconst GROUP_TYPES_OPTIONS = {\n Album: 'Album',\n All: 'All', // default\n Event: 'Event',\n Faces: 'Faces',\n Library: 'Library',\n PhotoStream: 'PhotoStream',\n SavedPhotos: 'SavedPhotos',\n};\n\nconst ASSET_TYPE_OPTIONS = {\n All: 'All',\n Videos: 'Videos',\n Photos: 'Photos',\n};\n\nexport type GroupTypes =\n | 'Album'\n | 'All'\n | 'Event'\n | 'Faces'\n | 'Library'\n | 'PhotoStream'\n | 'SavedPhotos';\n\nexport type Include =\n | 'filename'\n | 'fileSize'\n | 'fileExtension'\n | 'location'\n | 'imageSize'\n | 'playableDuration'\n | 'orientation';\n\nexport type AssetType = 'All' | 'Videos' | 'Photos';\n\n/**\n * Shape of the param arg for the `getPhotos` function.\n */\nexport type GetPhotosParams = {\n /**\n * The number of photos wanted in reverse order of the photo application\n * (i.e. most recent first).\n */\n first: number;\n\n /**\n * A cursor that matches `page_info { end_cursor }` returned from a previous\n * call to `getPhotos`\n */\n after?: string;\n\n /**\n * Specifies which group types to filter the results to.\n */\n groupTypes?: GroupTypes;\n\n /**\n * Specifies filter on group names, like 'Recent Photos' or custom album\n * titles.\n */\n groupName?: string;\n\n /**\n * Specifies filter on asset type\n */\n assetType?: AssetType;\n\n /**\n * Earliest time to get photos from. A timestamp in milliseconds. Exclusive.\n */\n fromTime?: number;\n\n /**\n * Latest time to get photos from. A timestamp in milliseconds. Inclusive.\n */\n toTime?: number;\n\n /**\n * Filter by mimetype (e.g. image/jpeg).\n */\n mimeTypes?: Array;\n\n /**\n * Specific fields in the output that we want to include, even though they\n * might have some performance impact.\n */\n include?: Include[];\n};\n\nexport type PhotoIdentifier = {\n node: {\n type: string;\n group_name: string;\n image: {\n filename: string | null;\n filepath: string | null;\n extension: string | null;\n uri: string;\n height: number;\n width: number;\n fileSize: number | null;\n playableDuration: number;\n orientation: number | null;\n };\n timestamp: number;\n location: {\n latitude?: number;\n longitude?: number;\n altitude?: number;\n heading?: number;\n speed?: number;\n } | null;\n };\n};\n\nexport type PhotoConvertionOptions = {\n convertHeicImages: boolean;\n};\n\nexport type PhotoIdentifiersPage = {\n edges: Array;\n page_info: {\n has_next_page: boolean;\n start_cursor?: string;\n end_cursor?: string;\n };\n limited?: boolean;\n};\n\nexport type SaveToCameraRollOptions = {\n type?: 'photo' | 'video' | 'auto';\n album?: string;\n};\n\nexport type GetAlbumsParams = {\n assetType?: AssetType;\n};\n\nexport type Album = {\n title: string;\n count: number;\n};\n\n/**\n * `CameraRoll` provides access to the local camera roll or photo library.\n *\n * See https://facebook.github.io/react-native/docs/cameraroll.html\n */\nexport class CameraRoll {\n static GroupTypesOptions = GROUP_TYPES_OPTIONS;\n static AssetTypeOptions = ASSET_TYPE_OPTIONS;\n\n /**\n * On iOS: requests deletion of a set of photos from the camera roll.\n * On Android: Deletes a set of photos from the camera roll.\n *\n */\n static deletePhotos(photoUris: Array): Promise {\n return RNCCameraRoll.deletePhotos(photoUris);\n }\n\n /**\n * Saves the photo or video to the camera roll or photo library.\n *\n */\n static save(\n tag: string,\n options: SaveToCameraRollOptions = {},\n ): Promise {\n let {type = 'auto'} = options;\n const {album = ''} = options;\n if (tag === '') throw new Error('tag must be a valid string');\n\n if (type === 'auto') {\n const fileExtension = tag.split('.').slice(-1)[0] ?? '';\n if (['mov', 'mp4'].indexOf(fileExtension.toLowerCase()) >= 0)\n type = 'video';\n else type = 'photo';\n }\n return RNCCameraRoll.saveToCameraRoll(tag, {type, album});\n }\n\n static saveToCameraRoll(\n tag: string,\n type?: 'photo' | 'video' | 'auto',\n ): Promise {\n console.warn(\n 'CameraRoll.saveToCameraRoll(tag, type) is deprecated. Use the save function instead',\n );\n return CameraRoll.save(tag, {type});\n }\n\n static getAlbums(\n params: GetAlbumsParams = {assetType: 'All'},\n ): Promise {\n return RNCCameraRoll.getAlbums(params);\n }\n\n static getParamsWithDefaults(params: GetPhotosParams): GetPhotosParams {\n const newParams = {...params};\n if (newParams.assetType === undefined) newParams.assetType = 'All';\n\n if (newParams.groupTypes === undefined && Platform.OS !== 'android')\n newParams.groupTypes = 'All';\n\n return newParams;\n }\n\n /**\n * Returns a Promise with photo identifier objects from the local camera\n * roll of the device matching shape defined by `getPhotosReturnChecker`.\n *\n * See https://facebook.github.io/react-native/docs/cameraroll.html#getphotos\n */\n static getPhotos(params: GetPhotosParams): Promise {\n params = CameraRoll.getParamsWithDefaults(params);\n return RNCCameraRoll.getPhotos(params);\n }\n\n /**\n * Returns a Promise with photo internal path.\n * if conversion is requested from HEIC then temporary file is created.\n *\n * @param internalID - PH photo internal ID.\n * @param convertHeicImages - whether to convert or not heic images to JPEG.\n * @returns Promise\n */\n static iosGetImageDataById(\n internalID: string,\n convertHeicImages = false,\n ): Promise {\n const conversionOption: PhotoConvertionOptions = {\n convertHeicImages: convertHeicImages,\n };\n return RNCCameraRoll.getPhotoByInternalID(internalID, conversionOption);\n }\n}\n","/* eslint-disable @typescript-eslint/ban-types */\n// we use Object type because methods on the native side use NSDictionary and ReadableMap\n// and we want to stay compatible with those\nimport {TurboModuleRegistry, TurboModule} from 'react-native';\n\ntype Album = {\n title: string;\n count: number;\n};\n\ntype PhotoIdentifier = {\n node: {\n type: string;\n group_name: string;\n image: {\n filename: string | null;\n filepath: string | null;\n extension: string | null;\n uri: string;\n height: number;\n width: number;\n fileSize: number | null;\n playableDuration: number;\n orientation: number | null;\n };\n timestamp: number;\n location: {\n latitude?: number;\n longitude?: number;\n altitude?: number;\n heading?: number;\n speed?: number;\n } | null;\n };\n};\n\ntype PhotoIdentifiersPage = {\n edges: Array;\n page_info: {\n has_next_page: boolean;\n start_cursor?: string;\n end_cursor?: string;\n };\n limited?: boolean;\n};\n\nexport interface Spec extends TurboModule {\n saveToCameraRoll(uri: string, options: Object): Promise;\n getPhotos(params: Object): Promise;\n getAlbums(params: Object): Promise;\n deletePhotos(photoUris: Array): Promise;\n getPhotoByInternalID(\n internalID: string,\n options: Object,\n ): Promise;\n}\n\nexport default TurboModuleRegistry.getEnforcing('RNCCameraRoll');\n","import {NativeEventEmitter, Platform} from 'react-native';\nimport CameraRollPermissionModule from './NativeCameraRollPermissionModule';\n\n/** Defines ios permission access levels for gallery */\nexport type AccessLevel = 'addOnly' | 'readWrite';\n\nexport type CameraRollAuthorizationStatus =\n | 'granted'\n | 'limited'\n | 'denied'\n | 'unavailable'\n | 'blocked'\n | 'not-determined';\n\nconst isIOS = Platform.OS === 'ios';\n// eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\nif (isIOS && CameraRollPermissionModule == null) {\n console.error(\n \"photoLibraryPermissionModule: Native Module 'photoLibraryPermissionModule' was null! Did you run pod install?\",\n );\n}\nexport const cameraRollEventEmitter = new NativeEventEmitter(\n isIOS ? CameraRollPermissionModule : undefined,\n);\n\nexport const iosReadGalleryPermission = (\n accessLevel: AccessLevel,\n): Promise => {\n if (!isIOS) throw new Error('this module is available only for ios');\n\n return CameraRollPermissionModule.checkPermission(accessLevel);\n};\n\nexport const iosRequestReadWriteGalleryPermission =\n (): Promise => {\n if (!isIOS) throw new Error('this module is available only for ios');\n\n return CameraRollPermissionModule.requestReadWritePermission();\n };\n\nexport const iosRequestAddOnlyGalleryPermission =\n (): Promise => {\n if (!isIOS) throw new Error('this module is available only for ios');\n\n return CameraRollPermissionModule.requestAddOnlyPermission();\n };\n\nexport const iosRefreshGallerySelection = (): Promise => {\n if (!isIOS) throw new Error('this module is available only for ios');\n\n return CameraRollPermissionModule.refreshPhotoSelection();\n};\n","import {TurboModuleRegistry, TurboModule} from 'react-native';\nimport type {Int32} from 'react-native/Libraries/Types/CodegenTypes';\n\ntype CameraRollAuthorizationStatus =\n | 'granted'\n | 'limited'\n | 'denied'\n | 'unavailable'\n | 'blocked'\n | 'not-determined';\n\nexport interface Spec extends TurboModule {\n checkPermission(content: string): Promise;\n requestReadWritePermission(): Promise;\n requestAddOnlyPermission(): Promise;\n refreshPhotoSelection(): Promise;\n addListener(eventName: string): void;\n removeListeners(count: Int32): void;\n}\n\n// we call get here since on Android this module does not exist and it would throw\n// eslint-disable-next-line @typescript-eslint/no-non-null-assertion\nexport default TurboModuleRegistry.get('RNCCameraRollPermission')!;\n","import lodashGet from 'lodash/get';\nimport Onyx from 'react-native-onyx';\nimport ONYXKEYS from '../ONYXKEYS';\n\nlet encryptedAuthToken = '';\nOnyx.connect({\n key: ONYXKEYS.SESSION,\n callback: session => encryptedAuthToken = lodashGet(session, 'encryptedAuthToken', ''),\n});\n\n/**\n * Add encryptedAuthToken to this attachment URL\n *\n * @param {String} url\n * @returns {String}\n */\nexport default function (url) {\n return `${url}?encryptedAuthToken=${encodeURIComponent(encryptedAuthToken)}`;\n}\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport BaseQuickEmojiReactions, {baseQuickEmojiReactionsPropTypes} from './BaseQuickEmojiReactions';\nimport ReportActionComposeFocusManager from '../../../libs/ReportActionComposeFocusManager';\n\nconst propTypes = {\n ...baseQuickEmojiReactionsPropTypes,\n\n /**\n * Function that can be called to close the\n * context menu in which this component is\n * rendered.\n */\n closeContextMenu: PropTypes.func.isRequired,\n};\n\nconst QuickEmojiReactions = (props) => {\n const onPressOpenPicker = (openPicker) => {\n // We first need to close the menu as it's a popover.\n // The picker is a popover as well and on mobile there can only\n // be one active popover at a time.\n props.closeContextMenu(() => {\n // As the menu which includes the button to open the emoji picker\n // gets closed, before the picker actually opens, we pass the composer\n // ref as anchor for the emoji picker popover.\n openPicker(ReportActionComposeFocusManager.composerRef.current);\n });\n };\n\n return (\n // eslint-disable-next-line react/jsx-props-no-spreading\n \n );\n};\n\nQuickEmojiReactions.displayName = 'QuickEmojiReactions';\nQuickEmojiReactions.propTypes = propTypes;\nexport default QuickEmojiReactions;\n","import React from 'react';\nimport {View} from 'react-native';\nimport _ from 'underscore';\nimport PropTypes from 'prop-types';\nimport {withOnyx} from 'react-native-onyx';\nimport EmojiReactionBubble from '../EmojiReactionBubble';\nimport AddReactionBubble from '../AddReactionBubble';\nimport CONST from '../../../CONST';\nimport styles from '../../../styles/styles';\nimport ONYXKEYS from '../../../ONYXKEYS';\nimport getPreferredEmojiCode from '../getPreferredEmojiCode';\nimport Tooltip from '../../Tooltip';\n\nconst baseQuickEmojiReactionsPropTypes = {\n /**\n * Callback to fire when an emoji is selected.\n */\n onEmojiSelected: PropTypes.func.isRequired,\n\n /**\n * Will be called when the emoji picker is about to show.\n */\n onWillShowPicker: PropTypes.func,\n\n /**\n * Callback to fire when the \"open emoji picker\" button is pressed.\n * The function receives an argument which can be called\n * to actually open the emoji picker.\n */\n onPressOpenPicker: PropTypes.func,\n};\n\nconst baseQuickEmojiReactionsDefaultProps = {\n onWillShowPicker: () => {},\n onPressOpenPicker: () => {},\n};\n\nconst propTypes = {\n ...baseQuickEmojiReactionsPropTypes,\n preferredSkinTone: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n};\n\nconst defaultProps = {\n ...baseQuickEmojiReactionsDefaultProps,\n preferredSkinTone: CONST.EMOJI_DEFAULT_SKIN_TONE,\n};\n\nconst BaseQuickEmojiReactions = props => (\n \n {_.map(CONST.QUICK_REACTIONS, emoji => (\n\n // Note: focus is handled by the Pressable component in EmojiReactionBubble\n \n {\n props.onEmojiSelected(emoji);\n }}\n />\n \n ))}\n \n \n);\n\nBaseQuickEmojiReactions.displayName = 'BaseQuickEmojiReactions';\nBaseQuickEmojiReactions.propTypes = propTypes;\nBaseQuickEmojiReactions.defaultProps = defaultProps;\nexport default withOnyx({\n preferredSkinTone: {\n key: ONYXKEYS.PREFERRED_EMOJI_SKIN_TONE,\n },\n})(BaseQuickEmojiReactions);\n\nexport {\n baseQuickEmojiReactionsPropTypes,\n};\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport {Pressable} from 'react-native';\nimport styles from '../../styles/styles';\nimport Text from '../Text';\nimport * as StyleUtils from '../../styles/StyleUtils';\nimport withCurrentUserPersonalDetails, {\n withCurrentUserPersonalDetailsDefaultProps,\n withCurrentUserPersonalDetailsPropTypes,\n} from '../withCurrentUserPersonalDetails';\nimport * as Report from '../../libs/actions/Report';\n\nconst propTypes = {\n /**\n * The emoji codes to display in the bubble.\n */\n emojiCodes: PropTypes.arrayOf(PropTypes.string).isRequired,\n\n /**\n * Called when the user presses on the reaction bubble.\n */\n onPress: PropTypes.func.isRequired,\n\n /**\n * Called when the user long presses or right clicks\n * on the reaction bubble.\n */\n onReactionListOpen: PropTypes.func,\n\n /**\n * The number of reactions to display in the bubble.\n */\n count: PropTypes.number,\n\n /**\n * The account ids of the users who reacted.\n */\n reactionUsers: PropTypes.arrayOf(PropTypes.string),\n\n /** Whether it is for context menu so we can modify its style */\n isContextMenu: PropTypes.bool,\n\n ...withCurrentUserPersonalDetailsPropTypes,\n};\n\nconst defaultProps = {\n count: 0,\n onReactionListOpen: () => {},\n reactionUsers: [],\n isContextMenu: false,\n\n ...withCurrentUserPersonalDetailsDefaultProps,\n};\n\nconst EmojiReactionBubble = (props) => {\n const hasUserReacted = Report.hasAccountIDReacted(props.currentUserPersonalDetails.accountID, props.reactionUsers);\n return (\n [\n styles.emojiReactionBubble,\n StyleUtils.getEmojiReactionBubbleStyle(hovered || pressed, hasUserReacted, props.isContextMenu),\n ]}\n onPress={props.onPress}\n onLongPress={props.onReactionListOpen}\n\n // Prevent text input blur when emoji reaction is clicked\n onMouseDown={e => e.preventDefault()}\n >\n \n {props.emojiCodes.join('')}\n \n {props.count > 0 && (\n \n {props.count}\n \n )}\n \n );\n};\n\nEmojiReactionBubble.propTypes = propTypes;\nEmojiReactionBubble.defaultProps = defaultProps;\nEmojiReactionBubble.displayName = 'EmojiReactionBubble';\n\nexport default withCurrentUserPersonalDetails(EmojiReactionBubble);\n","import React, {useRef} from 'react';\nimport {Pressable, View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport Tooltip from '../Tooltip';\nimport styles from '../../styles/styles';\nimport * as StyleUtils from '../../styles/StyleUtils';\nimport Icon from '../Icon';\nimport * as Expensicons from '../Icon/Expensicons';\nimport Text from '../Text';\nimport getButtonState from '../../libs/getButtonState';\nimport * as EmojiPickerAction from '../../libs/actions/EmojiPickerAction';\nimport variables from '../../styles/variables';\nimport withLocalize, {withLocalizePropTypes} from '../withLocalize';\n\nconst propTypes = {\n /** Whether it is for context menu so we can modify its style */\n isContextMenu: PropTypes.bool,\n\n /**\n * Called when the user presses on the icon button.\n * Will have a function as parameter which you can call\n * to open the picker.\n */\n onPressOpenPicker: PropTypes.func,\n\n /**\n * Will get called the moment before the picker opens.\n */\n onWillShowPicker: PropTypes.func,\n\n /**\n * Called when the user selects an emoji.\n */\n onSelectEmoji: PropTypes.func.isRequired,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n isContextMenu: false,\n onWillShowPicker: () => {},\n onPressOpenPicker: undefined,\n};\n\nconst AddReactionBubble = (props) => {\n const ref = useRef();\n\n const onPress = () => {\n const openPicker = (refParam, anchorOrigin) => {\n EmojiPickerAction.showEmojiPicker(\n () => {},\n (emojiCode, emojiObject) => {\n props.onSelectEmoji(emojiObject);\n },\n refParam || ref.current,\n anchorOrigin,\n props.onWillShowPicker,\n );\n };\n\n if (props.onPressOpenPicker) {\n props.onPressOpenPicker(openPicker);\n } else {\n openPicker();\n }\n };\n\n return (\n \n [\n styles.emojiReactionBubble,\n StyleUtils.getEmojiReactionBubbleStyle(hovered || pressed, false, props.isContextMenu),\n ]}\n onPress={onPress}\n\n // Prevent text input blur when Add reaction is clicked\n onMouseDown={e => e.preventDefault()}\n >\n {({\n hovered,\n pressed,\n }) => (\n <>\n {/* This (invisible) text will make the view have the same size as a regular\n emoji reaction. We make the text invisible and put the\n icon on top of it. */}\n \n {'\\u2800\\u2800'}\n \n \n \n \n \n )}\n \n\n \n );\n};\n\nAddReactionBubble.propTypes = propTypes;\nAddReactionBubble.defaultProps = defaultProps;\nAddReactionBubble.displayName = 'AddReactionBubble';\n\nexport default withLocalize(AddReactionBubble);\n","import React from 'react';\n\nconst emojiPickerRef = React.createRef();\n\n/**\n * Show the ReportActionContextMenu modal popover.\n *\n * @param {Function} [onModalHide=() => {}] - Run a callback when Modal hides.\n * @param {Function} [onEmojiSelected=() => {}] - Run a callback when Emoji selected.\n * @param {Element} emojiPopoverAnchor - Element on which EmojiPicker is anchored\n * @param {Object} [anchorOrigin] - Anchor origin for Popover\n * @param {Function} [onWillShow=() => {}] - Run a callback when Popover will show\n */\nfunction showEmojiPicker(\n onModalHide = () => {},\n onEmojiSelected = () => {},\n emojiPopoverAnchor,\n anchorOrigin = undefined,\n onWillShow = () => {},\n) {\n if (!emojiPickerRef.current) {\n return;\n }\n\n emojiPickerRef.current.showEmojiPicker(\n onModalHide,\n onEmojiSelected,\n emojiPopoverAnchor,\n anchorOrigin,\n onWillShow,\n );\n}\n\nexport {\n emojiPickerRef,\n showEmojiPicker,\n};\n","/**\n * Given an emoji object it returns the correct emoji code\n * based on the users preferred skin tone.\n * @param {Object} emoji\n * @param {String | Number} preferredSkinTone\n * @returns {String}\n */\nexport default function getPreferredEmojiCode(emoji, preferredSkinTone) {\n if (emoji.types) {\n const emojiCodeWithSkinTone = emoji.types[preferredSkinTone];\n\n // Note: it can happen that preferredSkinTone has a outdated format,\n // so it makes sense to check if we actually got a valid emoji code back\n if (emojiCodeWithSkinTone) {\n return emojiCodeWithSkinTone;\n }\n }\n\n return emoji.code;\n}\n","import React, {useRef} from 'react';\nimport {View} from 'react-native';\nimport _ from 'underscore';\nimport {withOnyx} from 'react-native-onyx';\nimport PropTypes from 'prop-types';\nimport CONST from '../../CONST';\nimport styles from '../../styles/styles';\nimport Text from '../Text';\nimport * as StyleUtils from '../../styles/StyleUtils';\nimport BaseMiniContextMenuItem from '../BaseMiniContextMenuItem';\nimport Icon from '../Icon';\nimport * as Expensicons from '../Icon/Expensicons';\nimport getButtonState from '../../libs/getButtonState';\nimport * as EmojiPickerAction from '../../libs/actions/EmojiPickerAction';\nimport {\n baseQuickEmojiReactionsPropTypes,\n} from './QuickEmojiReactions/BaseQuickEmojiReactions';\nimport withLocalize, {withLocalizePropTypes} from '../withLocalize';\nimport compose from '../../libs/compose';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport getPreferredEmojiCode from './getPreferredEmojiCode';\n\nconst propTypes = {\n ...baseQuickEmojiReactionsPropTypes,\n\n /**\n * Will be called when the user closed the emoji picker\n * without selecting an emoji.\n */\n onEmojiPickerClosed: PropTypes.func,\n\n ...withLocalizePropTypes,\n preferredSkinTone: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n\n};\n\nconst defaultProps = {\n onEmojiPickerClosed: () => {},\n preferredSkinTone: CONST.EMOJI_DEFAULT_SKIN_TONE,\n};\n\n/**\n * Shows the four common quick reactions and a\n * emoji picker icon button. This is used for the mini\n * context menu which we just show on web, when hovering\n * a message.\n * @param {Props} props\n * @returns {JSX.Element}\n */\nconst MiniQuickEmojiReactions = (props) => {\n const ref = useRef();\n\n const openEmojiPicker = () => {\n props.onPressOpenPicker();\n EmojiPickerAction.showEmojiPicker(\n props.onEmojiPickerClosed,\n (emojiCode, emojiObject) => {\n props.onEmojiSelected(emojiObject);\n },\n ref.current,\n );\n };\n\n return (\n \n {_.map(CONST.QUICK_REACTIONS, emoji => (\n props.onEmojiSelected(emoji)}\n >\n \n {getPreferredEmojiCode(emoji, props.preferredSkinTone)}\n \n \n ))}\n \n {({hovered, pressed}) => (\n \n )}\n \n \n );\n};\n\nMiniQuickEmojiReactions.displayName = 'MiniQuickEmojiReactions';\nMiniQuickEmojiReactions.propTypes = propTypes;\nMiniQuickEmojiReactions.defaultProps = defaultProps;\nexport default compose(\n withLocalize,\n withOnyx({\n preferredSkinTone: {\n key: ONYXKEYS.PREFERRED_EMOJI_SKIN_TONE,\n },\n }),\n)(MiniQuickEmojiReactions);\n","import {Pressable, View} from 'react-native';\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport _ from 'underscore';\nimport styles from '../styles/styles';\nimport * as StyleUtils from '../styles/StyleUtils';\nimport getButtonState from '../libs/getButtonState';\nimport variables from '../styles/variables';\nimport Tooltip from './Tooltip';\n\nconst propTypes = {\n /**\n * Text to display when hovering the menu item\n */\n tooltipText: PropTypes.string.isRequired,\n\n /**\n * Callback to fire on press\n */\n onPress: PropTypes.func.isRequired,\n\n /**\n * The children to display within the menu item\n */\n children: PropTypes.oneOfType([PropTypes.func, PropTypes.node]).isRequired,\n\n /**\n * Whether the button should be in the active state\n */\n isDelayButtonStateComplete: PropTypes.bool,\n\n /**\n * A ref to forward to the Pressable\n */\n innerRef: PropTypes.oneOfType([PropTypes.func, PropTypes.object]),\n};\n\nconst defaultProps = {\n isDelayButtonStateComplete: true,\n innerRef: () => {},\n};\n\n/**\n * Component that renders a mini context menu item with a\n * pressable. Also renders a tooltip when hovering the item.\n * @param {Object} props\n * @returns {JSX.Element}\n */\nconst BaseMiniContextMenuItem = props => (\n \n [\n styles.reportActionContextMenuMiniButton,\n StyleUtils.getButtonBackgroundColorStyle(getButtonState(hovered, pressed, props.isDelayButtonStateComplete)),\n ]\n }\n >\n {pressableState => (\n \n {_.isFunction(props.children) ? props.children(pressableState) : props.children}\n \n )}\n \n \n);\n\nBaseMiniContextMenuItem.propTypes = propTypes;\nBaseMiniContextMenuItem.defaultProps = defaultProps;\nBaseMiniContextMenuItem.displayName = 'BaseMiniContextMenuItem';\n\n// eslint-disable-next-line react/jsx-props-no-spreading\nexport default React.forwardRef((props, ref) => );\n","import React, {Component} from 'react';\nimport {View} from 'react-native';\nimport {withOnyx} from 'react-native-onyx';\nimport _ from 'underscore';\nimport PropTypes from 'prop-types';\nimport lodashGet from 'lodash/get';\nimport styles from '../../styles/styles';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport * as ReportActionsUtils from '../../libs/ReportActionsUtils';\nimport reportActionPropTypes from '../home/report/reportActionPropTypes';\nimport ReportTransaction from '../../components/ReportTransaction';\nimport CONST from '../../CONST';\n\nconst propTypes = {\n /** Actions from the ChatReport */\n reportActions: PropTypes.shape(reportActionPropTypes),\n\n /** ReportID for the associated chat report */\n chatReportID: PropTypes.string.isRequired,\n\n /** ReportID for the associated IOU report */\n iouReportID: PropTypes.string.isRequired,\n\n /** Email for the authenticated user */\n userEmail: PropTypes.string.isRequired,\n\n /** Is the associated IOU settled? */\n isIOUSettled: PropTypes.bool,\n};\n\nconst defaultProps = {\n reportActions: {},\n isIOUSettled: false,\n};\n\nclass IOUTransactions extends Component {\n constructor(props) {\n super(props);\n\n this.getRejectableTransactions = this.getRejectableTransactions.bind(this);\n }\n\n /**\n * Builds and returns the rejectableTransactionIDs array. A transaction must meet multiple requirements in order\n * to be rejectable. We must exclude transactions not associated with the iouReportID, actions which have already\n * been rejected, and those which are not of type 'create'.\n *\n * @returns {Array}\n */\n getRejectableTransactions() {\n if (this.props.isIOUSettled) {\n return [];\n }\n\n // iouReportIDs should be strings, but we still have places that send them as ints so we convert them both to Numbers for comparison\n const actionsForIOUReport = _.filter(this.props.reportActions, action => action.originalMessage\n && action.originalMessage.type && Number(action.originalMessage.IOUReportID) === Number(this.props.iouReportID));\n\n const rejectedTransactionIDs = _.chain(actionsForIOUReport)\n .filter(action => _.contains(['cancel', 'decline'], action.originalMessage.type))\n .map(rejectedAction => lodashGet(rejectedAction, 'originalMessage.IOUTransactionID', ''))\n .compact()\n .value();\n\n return _.chain(actionsForIOUReport)\n .filter(action => action.originalMessage.type === 'create')\n .filter(action => !_.contains(rejectedTransactionIDs, action.originalMessage.IOUTransactionID))\n .map(action => lodashGet(action, 'originalMessage.IOUTransactionID', ''))\n .compact()\n .value();\n }\n\n render() {\n const sortedReportActions = ReportActionsUtils.getSortedReportActionsForDisplay(this.props.reportActions);\n return (\n \n {_.map(sortedReportActions, (reportAction) => {\n // iouReportIDs should be strings, but we still have places that send them as ints so we convert them both to Numbers for comparison\n if (!reportAction.originalMessage || Number(reportAction.originalMessage.IOUReportID) !== Number(this.props.iouReportID)) {\n return;\n }\n\n const rejectableTransactions = this.getRejectableTransactions();\n const canBeRejected = _.contains(rejectableTransactions,\n reportAction.originalMessage.IOUTransactionID);\n const isCurrentUserTransactionCreator = this.props.userEmail === reportAction.actorEmail;\n return (\n \n );\n })}\n \n );\n }\n}\n\nIOUTransactions.defaultProps = defaultProps;\nIOUTransactions.propTypes = propTypes;\nexport default withOnyx({\n reportActions: {\n key: ({chatReportID}) => `${ONYXKEYS.COLLECTION.REPORT_ACTIONS}${chatReportID}`,\n canEvict: false,\n },\n})(IOUTransactions);\n","import React, {Component} from 'react';\nimport PropTypes from 'prop-types';\nimport {View} from 'react-native';\nimport styles from '../styles/styles';\nimport CONST from '../CONST';\nimport * as IOU from '../libs/actions/IOU';\nimport * as ReportActions from '../libs/actions/ReportActions';\nimport reportActionPropTypes from '../pages/home/report/reportActionPropTypes';\nimport ReportActionItemSingle from '../pages/home/report/ReportActionItemSingle';\nimport withLocalize, {withLocalizePropTypes} from './withLocalize';\nimport OfflineWithFeedback from './OfflineWithFeedback';\nimport Text from './Text';\nimport Button from './Button';\n\nconst propTypes = {\n /** The chatReport which the transaction is associated with */\n /* eslint-disable-next-line react/no-unused-prop-types */\n chatReportID: PropTypes.string.isRequired,\n\n /** ID for the IOU report */\n /* eslint-disable-next-line react/no-unused-prop-types */\n iouReportID: PropTypes.string.isRequired,\n\n /** The report action which we are displaying */\n action: PropTypes.shape(reportActionPropTypes).isRequired,\n\n /** Can this transaction be rejected? */\n canBeRejected: PropTypes.bool,\n\n /** Type of the reject transaction button */\n rejectButtonType: PropTypes.oneOf([CONST.IOU.REPORT_ACTION_TYPE.DECLINE, CONST.IOU.REPORT_ACTION_TYPE.CANCEL]).isRequired,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n canBeRejected: false,\n};\n\nclass ReportTransaction extends Component {\n constructor(props) {\n super(props);\n\n this.cancelMoneyRequest = this.cancelMoneyRequest.bind(this);\n }\n\n cancelMoneyRequest() {\n IOU.cancelMoneyRequest(\n this.props.chatReportID,\n this.props.iouReportID,\n this.props.rejectButtonType,\n this.props.action,\n );\n }\n\n render() {\n return (\n {\n if (this.props.action.actionName === CONST.REPORT.ACTIONS.TYPE.IOU) {\n ReportActions.clearSendMoneyErrors(this.props.chatReportID, this.props.action.reportActionID);\n }\n if (this.props.action.pendingAction === CONST.RED_BRICK_ROAD_PENDING_ACTION.ADD) {\n ReportActions.deleteOptimisticReportAction(this.props.chatReportID, this.props.action.reportActionID);\n } else {\n ReportActions.clearReportActionErrors(this.props.chatReportID, this.props.action.reportActionID);\n }\n }}\n pendingAction={this.props.action.pendingAction}\n errors={this.props.action.errors}\n errorRowStyles={[styles.ml10, styles.mr2]}\n >\n \n \n \n {this.props.action.message[0].text}\n \n \n {this.props.canBeRejected && (\n \n \n \n )}\n \n \n );\n }\n}\n\nReportTransaction.defaultProps = defaultProps;\nReportTransaction.propTypes = propTypes;\nexport default withLocalize(ReportTransaction);\n","import Onyx from 'react-native-onyx';\nimport ONYXKEYS from '../../ONYXKEYS';\n\n/**\n * @param {String} reportID\n * @param {String} reportActionID\n */\nfunction deleteOptimisticReportAction(reportID, reportActionID) {\n Onyx.merge(`${ONYXKEYS.COLLECTION.REPORT_ACTIONS}${reportID}`, {\n [reportActionID]: null,\n });\n}\n\n/**\n * @param {String} reportID\n * @param {String} reportActionID\n */\nfunction clearReportActionErrors(reportID, reportActionID) {\n Onyx.merge(`${ONYXKEYS.COLLECTION.REPORT_ACTIONS}${reportID}`, {\n [reportActionID]: {\n errors: null,\n },\n });\n}\n\n/**\n * This method clears the errors for a chat where send money action was done\n * @param {String} chatReportID\n * @param {String} reportActionID\n */\nfunction clearSendMoneyErrors(chatReportID, reportActionID) {\n Onyx.merge(`${ONYXKEYS.COLLECTION.REPORT_ACTIONS}${chatReportID}`, {\n [reportActionID]: {\n errors: null,\n },\n });\n}\n\nexport {\n clearReportActionErrors,\n deleteOptimisticReportAction,\n clearSendMoneyErrors,\n};\n","import lodashGet from 'lodash/get';\nimport React from 'react';\nimport {View, Pressable} from 'react-native';\nimport PropTypes from 'prop-types';\nimport _ from 'underscore';\nimport Str from 'expensify-common/lib/str';\nimport reportActionPropTypes from './reportActionPropTypes';\nimport ReportActionItemFragment from './ReportActionItemFragment';\nimport styles from '../../../styles/styles';\nimport ReportActionItemDate from './ReportActionItemDate';\nimport Avatar from '../../../components/Avatar';\nimport personalDetailsPropType from '../../personalDetailsPropType';\nimport compose from '../../../libs/compose';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport Navigation from '../../../libs/Navigation/Navigation';\nimport ROUTES from '../../../ROUTES';\nimport {withPersonalDetails} from '../../../components/OnyxProvider';\nimport Tooltip from '../../../components/Tooltip';\nimport ControlSelection from '../../../libs/ControlSelection';\nimport * as ReportUtils from '../../../libs/ReportUtils';\nimport OfflineWithFeedback from '../../../components/OfflineWithFeedback';\nimport CONST from '../../../CONST';\n\nconst propTypes = {\n /** All the data of the action */\n action: PropTypes.shape(reportActionPropTypes).isRequired,\n\n /** All of the personalDetails */\n personalDetails: PropTypes.objectOf(personalDetailsPropType),\n\n /** Styles for the outermost View */\n // eslint-disable-next-line react/forbid-prop-types\n wrapperStyles: PropTypes.arrayOf(PropTypes.object),\n\n /** Children view component for this action item */\n children: PropTypes.node.isRequired,\n\n /** Show header for action */\n showHeader: PropTypes.bool,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n personalDetails: {},\n wrapperStyles: [styles.chatItem],\n showHeader: true,\n};\n\nconst showUserDetails = (email) => {\n Navigation.navigate(ROUTES.getDetailsRoute(email));\n};\n\nconst ReportActionItemSingle = (props) => {\n const actorEmail = props.action.actorEmail.replace(CONST.REGEX.MERGED_ACCOUNT_PREFIX, '');\n const {\n avatar,\n displayName,\n login,\n pendingFields,\n } = props.personalDetails[actorEmail] || {};\n const avatarSource = ReportUtils.getAvatar(avatar, actorEmail);\n\n // Since the display name for a report action message is delivered with the report history as an array of fragments\n // we'll need to take the displayName from personal details and have it be in the same format for now. Eventually,\n // we should stop referring to the report history items entirely for this information.\n const personArray = displayName\n ? [{type: 'TEXT', text: Str.isSMSLogin(login) ? props.toLocalPhone(displayName) : displayName}]\n : props.action.person;\n\n return (\n \n showUserDetails(actorEmail)}\n >\n \n \n \n \n \n \n \n {props.showHeader ? (\n \n showUserDetails(actorEmail)}\n >\n {_.map(personArray, (fragment, index) => (\n \n ))}\n \n \n \n ) : null}\n {props.children}\n \n \n );\n};\n\nReportActionItemSingle.propTypes = propTypes;\nReportActionItemSingle.defaultProps = defaultProps;\nReportActionItemSingle.displayName = 'ReportActionItemSingle';\n\nexport default compose(\n withLocalize,\n withPersonalDetails(),\n)(ReportActionItemSingle);\n","import React, {memo} from 'react';\nimport {ActivityIndicator, View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport Str from 'expensify-common/lib/str';\nimport reportActionFragmentPropTypes from './reportActionFragmentPropTypes';\nimport styles from '../../../styles/styles';\nimport variables from '../../../styles/variables';\nimport themeColors from '../../../styles/themes/default';\nimport RenderHTML from '../../../components/RenderHTML';\nimport Text from '../../../components/Text';\nimport Tooltip from '../../../components/Tooltip';\nimport * as EmojiUtils from '../../../libs/EmojiUtils';\nimport withWindowDimensions, {windowDimensionsPropTypes} from '../../../components/withWindowDimensions';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport * as DeviceCapabilities from '../../../libs/DeviceCapabilities';\nimport compose from '../../../libs/compose';\nimport * as StyleUtils from '../../../styles/StyleUtils';\nimport {withNetwork} from '../../../components/OnyxProvider';\nimport CONST from '../../../CONST';\nimport applyStrikethrough from '../../../components/HTMLEngineProvider/applyStrikethrough';\n\nconst propTypes = {\n /** The message fragment needing to be displayed */\n fragment: reportActionFragmentPropTypes.isRequired,\n\n /** Text to be shown for tooltip When Fragment is report Actor */\n tooltipText: PropTypes.string,\n\n /** Is this fragment an attachment? */\n isAttachment: PropTypes.bool,\n\n /** If this fragment is attachment than has info? */\n attachmentInfo: PropTypes.shape({\n\n /** The file name of attachment */\n name: PropTypes.string,\n\n /** The file size of the attachment in bytes. */\n size: PropTypes.number,\n\n /** The MIME type of the attachment. */\n type: PropTypes.string,\n\n /** Attachment's URL represents the specified File object or Blob object */\n source: PropTypes.string,\n }),\n\n /** Does this fragment belong to a reportAction that has not yet loaded? */\n loading: PropTypes.bool,\n\n /** The reportAction's source */\n source: PropTypes.oneOf(['Chronos', 'email', 'ios', 'android', 'web', 'email', '']),\n\n /** Should this fragment be contained in a single line? */\n isSingleLine: PropTypes.bool,\n\n // Additional styles to add after local styles\n style: PropTypes.oneOfType([\n PropTypes.arrayOf(PropTypes.object),\n PropTypes.object,\n ]),\n\n ...windowDimensionsPropTypes,\n\n /** localization props */\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n isAttachment: false,\n attachmentInfo: {\n name: '',\n size: 0,\n type: '',\n source: '',\n },\n loading: false,\n isSingleLine: false,\n tooltipText: '',\n source: '',\n style: [],\n};\n\nconst ReportActionItemFragment = (props) => {\n switch (props.fragment.type) {\n case 'COMMENT': {\n // If this is an attachment placeholder, return the placeholder component\n if (props.isAttachment && props.loading) {\n return (\n Str.isImage(props.attachmentInfo.name)\n ? (\n `} />\n ) : (\n \n \n \n )\n );\n }\n const {html, text} = props.fragment;\n\n // If the only difference between fragment.text and fragment.html is
          tags\n // we render it as text, not as html.\n // This is done to render emojis with line breaks between them as text.\n const differByLineBreaksOnly = Str.replaceAll(html, '
          ', '\\n') === text;\n\n // Only render HTML if we have html in the fragment\n if (!differByLineBreaksOnly) {\n const isPendingDelete = props.pendingAction === CONST.RED_BRICK_ROAD_PENDING_ACTION.DELETE && props.network.isOffline;\n const editedTag = props.fragment.isEdited ? '' : '';\n const htmlContent = applyStrikethrough(html + editedTag, isPendingDelete);\n\n return (\n ${htmlContent}`\n : `${htmlContent}`}\n />\n );\n }\n return (\n \n {StyleUtils.convertToLTR(Str.htmlDecode(text))}\n {Boolean(props.fragment.isEdited) && (\n \n {` ${props.translate('reportActionCompose.edited')}`}\n \n )}\n \n );\n }\n case 'TEXT':\n return (\n \n \n {props.fragment.text}\n \n \n );\n case 'LINK':\n return LINK;\n case 'INTEGRATION_COMMENT':\n return REPORT_LINK;\n case 'REPORT_LINK':\n return REPORT_LINK;\n case 'POLICY_LINK':\n return POLICY_LINK;\n\n // If we have a message fragment type of OLD_MESSAGE this means we have not yet converted this over to the\n // new data structure. So we simply set this message as inner html and render it like we did before.\n // This wil allow us to convert messages over to the new structure without needing to do it all at once.\n case 'OLD_MESSAGE':\n return OLD_MESSAGE;\n default:\n return fragment.text;\n }\n};\n\nReportActionItemFragment.propTypes = propTypes;\nReportActionItemFragment.defaultProps = defaultProps;\nReportActionItemFragment.displayName = 'ReportActionItemFragment';\n\nexport default compose(\n withWindowDimensions,\n withLocalize,\n withNetwork(),\n)(memo(ReportActionItemFragment));\n","import _ from 'underscore';\nimport lodashOrderBy from 'lodash/orderBy';\nimport moment from 'moment';\nimport Str from 'expensify-common/lib/str';\nimport CONST from '../CONST';\nimport * as User from './actions/User';\nimport emojisTrie from './EmojiTrie';\nimport FrequentlyUsed from '../../assets/images/history.svg';\n\n/**\n * Get the unicode code of an emoji in base 16.\n * @param {String} input\n * @returns {String}\n */\nconst getEmojiUnicode = _.memoize((input) => {\n if (input.length === 0) {\n return '';\n }\n\n if (input.length === 1) {\n return _.map(input.charCodeAt(0).toString().split(' '), val => parseInt(val, 10).toString(16)).join(' ');\n }\n\n const pairs = [];\n\n // Some Emojis in UTF-16 are stored as pair of 2 Unicode characters (eg Flags)\n // The first char is generally between the range U+D800 to U+DBFF called High surrogate\n // & the second char between the range U+DC00 to U+DFFF called low surrogate\n // More info in the following links:\n // 1. https://docs.microsoft.com/en-us/windows/win32/intl/surrogates-and-supplementary-characters\n // 2. https://thekevinscott.com/emojis-in-javascript/\n for (let i = 0; i < input.length; i++) {\n if (input.charCodeAt(i) >= 0xd800 && input.charCodeAt(i) <= 0xdbff) { // high surrogate\n if (input.charCodeAt(i + 1) >= 0xdc00 && input.charCodeAt(i + 1) <= 0xdfff) { // low surrogate\n pairs.push(\n ((input.charCodeAt(i) - 0xd800) * 0x400)\n + (input.charCodeAt(i + 1) - 0xdc00) + 0x10000,\n );\n }\n } else if (input.charCodeAt(i) < 0xd800 || input.charCodeAt(i) > 0xdfff) {\n // modifiers and joiners\n pairs.push(input.charCodeAt(i));\n }\n }\n return _.map(pairs, val => parseInt(val, 10).toString(16)).join(' ');\n});\n\n/**\n * Function to remove Skin Tone and utf16 surrogates from Emoji\n * @param {String} emojiCode\n * @returns {String}\n */\nfunction trimEmojiUnicode(emojiCode) {\n return emojiCode.replace(/(fe0f|1f3fb|1f3fc|1f3fd|1f3fe|1f3ff)$/, '').trim();\n}\n\n/**\n * Validates that this message contains only emojis\n *\n * @param {String} message\n * @returns {Boolean}\n */\nfunction containsOnlyEmojis(message) {\n const trimmedMessage = Str.replaceAll(message.replace(/ /g, ''), '\\n', '');\n const match = trimmedMessage.match(CONST.REGEX.EMOJIS);\n\n if (!match) {\n return false;\n }\n\n const codes = [];\n _.map(match, emoji => _.map(getEmojiUnicode(emoji).split(' '), (code) => {\n if (!CONST.INVISIBLE_CODEPOINTS.includes(code)) {\n codes.push(code);\n }\n return code;\n }));\n\n // Emojis are stored as multiple characters, so we're using spread operator\n // to iterate over the actual emojis, not just characters that compose them\n const messageCodes = _.filter(_.map([...trimmedMessage], char => getEmojiUnicode(char)), string => string.length > 0 && !CONST.INVISIBLE_CODEPOINTS.includes(string));\n return codes.length === messageCodes.length;\n}\n\n/**\n * Get the header emojis with their code, icon and index\n * @param {Object[]} emojis\n * @returns {Object[]}\n */\nfunction getHeaderEmojis(emojis) {\n const headerIndices = [];\n _.each(emojis, (emoji, index) => {\n if (!emoji.header) {\n return;\n }\n headerIndices.push({code: emoji.code, index, icon: emoji.icon});\n });\n return headerIndices;\n}\n\n/**\n * Get number of empty spaces to be filled to get equal emojis for every row\n * @param {Number} emojiCount\n * @param {Number} suffix\n * @returns {Object[]}\n */\nfunction getDynamicSpacing(emojiCount, suffix) {\n const spacerEmojis = [];\n let modLength = CONST.EMOJI_NUM_PER_ROW - (emojiCount % CONST.EMOJI_NUM_PER_ROW);\n\n // Empty spaces is pushed if the given row has less than eight emojis\n while (modLength > 0 && modLength < CONST.EMOJI_NUM_PER_ROW) {\n spacerEmojis.push({\n code: `${CONST.EMOJI_SPACER}_${suffix}_${modLength}`,\n spacer: true,\n });\n modLength -= 1;\n }\n return spacerEmojis;\n}\n\n/**\n * Add dynamic spaces to emoji categories\n * @param {Object[]} emojis\n * @returns {Object[]}\n */\nfunction addSpacesToEmojiCategories(emojis) {\n let updatedEmojis = [];\n _.each(emojis, (emoji, index) => {\n if (emoji.header) {\n updatedEmojis = updatedEmojis.concat(getDynamicSpacing(updatedEmojis.length, index), [emoji], getDynamicSpacing(1, index));\n return;\n }\n updatedEmojis.push(emoji);\n });\n return updatedEmojis;\n}\n\n/**\n * Get a merged array with frequently used emojis\n * @param {Object[]} emojis\n * @param {Object[]} frequentlyUsedEmojis\n * @returns {Object[]}\n */\nfunction mergeEmojisWithFrequentlyUsedEmojis(emojis, frequentlyUsedEmojis = []) {\n if (frequentlyUsedEmojis.length === 0) {\n return addSpacesToEmojiCategories(emojis);\n }\n\n let allEmojis = [{\n header: true,\n code: 'frequentlyUsed',\n icon: FrequentlyUsed,\n }];\n\n allEmojis = allEmojis.concat(frequentlyUsedEmojis, emojis);\n return addSpacesToEmojiCategories(allEmojis);\n}\n\n/**\n * Update the frequently used emojis list by usage and sync with API\n * @param {Object[]} frequentlyUsedEmojis\n * @param {Object} newEmoji\n */\nfunction addToFrequentlyUsedEmojis(frequentlyUsedEmojis, newEmoji) {\n let frequentEmojiList = frequentlyUsedEmojis;\n let currentEmojiCount = 1;\n const currentTimestamp = moment().unix();\n const emojiIndex = _.findIndex(frequentEmojiList, e => e.code === newEmoji.code);\n if (emojiIndex >= 0) {\n currentEmojiCount = frequentEmojiList[emojiIndex].count + 1;\n frequentEmojiList.splice(emojiIndex, 1);\n }\n const updatedEmoji = {...newEmoji, ...{count: currentEmojiCount, lastUpdatedAt: currentTimestamp}};\n const maxFrequentEmojiCount = (CONST.EMOJI_FREQUENT_ROW_COUNT * CONST.EMOJI_NUM_PER_ROW) - 1;\n\n // We want to make sure the current emoji is added to the list\n // Hence, we take one less than the current high frequent used emojis and if same then sorted by lastUpdatedAt\n frequentEmojiList = lodashOrderBy(frequentEmojiList, ['count', 'lastUpdatedAt'], ['desc', 'desc']);\n frequentEmojiList = frequentEmojiList.slice(0, maxFrequentEmojiCount);\n frequentEmojiList.push(updatedEmoji);\n\n // Second sorting is required so that new emoji is properly placed at sort-ordered location\n frequentEmojiList = lodashOrderBy(frequentEmojiList, ['count', 'lastUpdatedAt'], ['desc', 'desc']);\n User.updateFrequentlyUsedEmojis(frequentEmojiList);\n}\n\n/**\n * Given an emoji item object, return an emoji code based on its type.\n *\n * @param {Object} item\n * @param {Number} preferredSkinToneIndex\n * @returns {String}\n */\nconst getEmojiCodeWithSkinColor = (item, preferredSkinToneIndex) => {\n const {code, types} = item;\n if (types && types[preferredSkinToneIndex]) {\n return types[preferredSkinToneIndex];\n }\n\n return code;\n};\n\n/**\n * Replace any emoji name in a text with the emoji icon.\n * If we're on mobile, we also add a space after the emoji granted there's no text after it.\n * @param {String} text\n * @param {Boolean} isSmallScreenWidth\n * @param {Number} preferredSkinTone\n * @returns {String}\n */\nfunction replaceEmojis(text, isSmallScreenWidth = false, preferredSkinTone = CONST.EMOJI_DEFAULT_SKIN_TONE) {\n let newText = text;\n const emojiData = text.match(CONST.REGEX.EMOJI_NAME);\n if (!emojiData || emojiData.length === 0) {\n return text;\n }\n for (let i = 0; i < emojiData.length; i++) {\n const checkEmoji = emojisTrie.search(emojiData[i].slice(1, -1));\n if (checkEmoji && checkEmoji.metaData.code) {\n let emojiReplacement = getEmojiCodeWithSkinColor(checkEmoji.metaData, preferredSkinTone);\n\n // If this is the last emoji in the message and it's the end of the message so far,\n // add a space after it so the user can keep typing easily.\n if (isSmallScreenWidth && i === emojiData.length - 1 && text.endsWith(emojiData[i])) {\n emojiReplacement += ' ';\n }\n newText = newText.replace(emojiData[i], emojiReplacement);\n }\n }\n return newText;\n}\n\n/**\n * Suggest emojis when typing emojis prefix after colon\n * @param {String} text\n * @param {Number} [limit] - matching emojis limit\n * @returns {Array}\n */\nfunction suggestEmojis(text, limit = 5) {\n const emojiData = text.match(CONST.REGEX.EMOJI_SUGGESTIONS);\n if (emojiData) {\n const matching = [];\n const nodes = emojisTrie.getAllMatchingWords(emojiData[0].toLowerCase().slice(1), limit);\n for (let j = 0; j < nodes.length; j++) {\n if (nodes[j].metaData.code && !_.find(matching, obj => obj.name === nodes[j].name)) {\n if (matching.length === limit) {\n return matching;\n }\n matching.push({code: nodes[j].metaData.code, name: nodes[j].name, types: nodes[j].metaData.types});\n }\n const suggestions = nodes[j].metaData.suggestions;\n for (let i = 0; i < suggestions.length; i++) {\n if (matching.length === limit) {\n return matching;\n }\n if (!_.find(matching, obj => obj.name === suggestions[i].name)) {\n matching.push(suggestions[i]);\n }\n }\n }\n return matching;\n }\n return [];\n}\n\nexport {\n getHeaderEmojis,\n mergeEmojisWithFrequentlyUsedEmojis,\n addToFrequentlyUsedEmojis,\n containsOnlyEmojis,\n replaceEmojis,\n suggestEmojis,\n trimEmojiUnicode,\n getEmojiCodeWithSkinColor,\n};\n","import emojis from '../../assets/emojis';\nimport Trie from './Trie';\nimport Timing from './actions/Timing';\nimport CONST from '../CONST';\n\nTiming.start(CONST.TIMING.TRIE_INITIALIZATION);\n\nconst emojisTrie = new Trie();\n\n// Inserting all emojis into the Trie object\nfor (let i = 0; i < emojis.length; i++) {\n if (emojis[i].name) {\n const node = emojisTrie.search(emojis[i].name);\n if (!node) {\n emojisTrie.add(emojis[i].name, {code: emojis[i].code, types: emojis[i].types, suggestions: []});\n } else {\n emojisTrie.update(emojis[i].name, {code: emojis[i].code, types: emojis[i].types, suggestions: node.metaData.suggestions});\n }\n\n if (emojis[i].keywords) {\n for (let j = 0; j < emojis[i].keywords.length; j++) {\n const keywordNode = emojisTrie.search(emojis[i].keywords[j]);\n if (!keywordNode) {\n emojisTrie.add(emojis[i].keywords[j], {suggestions: [{code: emojis[i].code, types: emojis[i].types, name: emojis[i].name}]});\n } else {\n emojisTrie.update(emojis[i].keywords[j],\n {...keywordNode.metaData, suggestions: [...keywordNode.metaData.suggestions, {code: emojis[i].code, types: emojis[i].types, name: emojis[i].name}]});\n }\n }\n }\n }\n}\nTiming.end(CONST.TIMING.TRIE_INITIALIZATION);\n\nexport default emojisTrie;\n","import Smiley from './images/emoji.svg';\nimport AnimalsAndNature from './images/emojiCategoryIcons/plant.svg';\nimport FoodAndDrink from './images/emojiCategoryIcons/hamburger.svg';\nimport TravelAndPlaces from './images/emojiCategoryIcons/plane.svg';\nimport Activities from './images/emojiCategoryIcons/soccer-ball.svg';\nimport Objects from './images/emojiCategoryIcons/light-bulb.svg';\nimport Symbols from './images/emojiCategoryIcons/peace-sign.svg';\nimport Flags from './images/emojiCategoryIcons/flag.svg';\n\n/*\n * This list is generated from the code here https://github.com/github/gemoji/blob/master/db/emoji.json\n * Each code is then converted to hex by replacing the \"U+\" with \"0x\"\n * Each hex is then converted to a string using this function (each section is defined as \"emojis\" in this function)\n * const emojiData = require('./gemoji.json');\n * const { getEmojiUnicode } = require('./EmojiUtils');\n * const emojisGroupedByCategory = _.groupBy(emojiData, 'category');\n * const skinTones = ['1f3fb', '1f3fc', '1f3fd', '1f3fe', '1f3ff'];\n * const emojisList = []\n * for(let category in emojisGroupedByCategory) {\n * let categoryName = category.replace(' & ', 'And');\n * categoryName = categoryName.charAt(0).toLowerCase() + categoryName.slice(1);\n * emojisList.push({\n * code: categoryName,\n * header: true\n * });\n *\n * const emojisPerCategory = emojisGroupedByCategory[category];\n * for(let i = 0; i < emojisPerCategory.length; i++) {\n * const emoji = emojisPerCategory[i];\n * let keywords = [...emoji.tags , ...emoji.aliases];\n * if(oldEmojiMap[emoji.emoji]) { // old Emoji Map is old assets/emojis.js data\n * keywords = keywords.concat(oldEmojiMap[emoji.emoji].keywords);\n * }\n * const emojiRow = {\n * code: emoji.emoji,\n * keywords: _.uniq(keywords)\n * };\n *\n * if (emoji.skin_tones) {\n * emojiRow.types = skinTones.map(skinTone => {\n * const emojiUnicode = trimEmojiUnicode(getEmojiUnicode(emoji.emoji)).split(' ').map(p => parseInt(p, 16));\n * if(emojiUnicode.length > 0) {\n * emojiUnicode.splice(1, 0, parseInt(skinTone, 16));\n * } else {\n * emojiUnicode.push(parseInt(skinTone, 16));\n * }\n * return String.fromCodePoint(...emojiUnicode);\n * });\n * }\n * emojisList.push(emojiRow);\n * }\n * };\n */\n\n// BEFORE YOU EDIT THIS, PLEASE SEE WARNINGS IN EmojiPickerMenu.js\nconst skinTones = [{\n code: '🖐',\n skinTone: -1,\n}, {\n code: '🖐🏻',\n skinTone: 4,\n}, {\n code: '🖐🏼',\n skinTone: 3,\n}, {\n code: '🖐🏽',\n skinTone: 2,\n}, {\n code: '🖐🏾',\n skinTone: 1,\n}, {\n code: '🖐🏿',\n skinTone: 0,\n}];\n\nconst emojis = [\n {\n code: 'smileysAndEmotion',\n header: true,\n icon: Smiley,\n },\n {\n name: 'grinning',\n code: '😀',\n keywords: [\n 'smile',\n 'happy',\n 'grinning',\n 'face',\n 'grin',\n ],\n },\n {\n name: 'smiley',\n code: '😃',\n keywords: [\n 'happy',\n 'joy',\n 'haha',\n 'smiley',\n 'face',\n 'mouth',\n 'open',\n 'smile',\n ],\n },\n {\n name: 'smile',\n code: '😄',\n keywords: [\n 'happy',\n 'joy',\n 'laugh',\n 'pleased',\n 'smile',\n 'eye',\n 'face',\n 'mouth',\n 'open',\n ],\n },\n {\n name: 'grin',\n code: '😁',\n keywords: [\n 'grin',\n 'eye',\n 'face',\n 'smile',\n ],\n },\n {\n name: 'laughing',\n code: '😆',\n keywords: [\n 'happy',\n 'haha',\n 'laughing',\n 'satisfied',\n 'face',\n 'laugh',\n 'mouth',\n 'open',\n 'smile',\n ],\n },\n {\n name: 'sweat_smile',\n code: '😅',\n keywords: [\n 'hot',\n 'sweat_smile',\n 'cold',\n 'face',\n 'open',\n 'smile',\n 'sweat',\n ],\n },\n {\n name: 'rofl',\n code: '🤣',\n keywords: [\n 'lol',\n 'laughing',\n 'rofl',\n 'face',\n 'floor',\n 'laugh',\n 'rolling',\n ],\n },\n {\n name: 'joy',\n code: '😂',\n keywords: [\n 'tears',\n 'joy',\n 'face',\n 'laugh',\n 'tear',\n ],\n },\n {\n name: 'slightly_smiling_face',\n code: '🙂',\n keywords: [\n 'slightly_smiling_face',\n 'face',\n 'smile',\n ],\n },\n {\n name: 'upside_down_face',\n code: '🙃',\n keywords: [\n 'upside_down_face',\n 'face',\n 'upside-down',\n ],\n },\n {\n name: 'wink',\n code: '😉',\n keywords: [\n 'flirt',\n 'wink',\n 'face',\n ],\n },\n {\n name: 'blush',\n code: '😊',\n keywords: [\n 'proud',\n 'blush',\n 'eye',\n 'face',\n 'smile',\n ],\n },\n {\n name: 'innocent',\n code: '😇',\n keywords: [\n 'angel',\n 'innocent',\n 'face',\n 'fairy tale',\n 'fantasy',\n 'halo',\n 'smile',\n ],\n },\n {\n name: 'smiling_face_with_three_hearts',\n code: '🥰',\n keywords: [\n 'love',\n 'smiling_face_with_three_hearts',\n ],\n },\n {\n name: 'heart_eyes',\n code: '😍',\n keywords: [\n 'love',\n 'crush',\n 'heart_eyes',\n 'eye',\n 'face',\n 'heart',\n 'smile',\n ],\n },\n {\n name: 'star_struck',\n code: '🤩',\n keywords: [\n 'eyes',\n 'star_struck',\n ],\n },\n {\n name: 'kissing_heart',\n code: '😘',\n keywords: [\n 'flirt',\n 'kissing_heart',\n 'face',\n 'heart',\n 'kiss',\n ],\n },\n {\n name: 'kissing',\n code: '😗',\n keywords: [\n 'kissing',\n 'face',\n 'kiss',\n ],\n },\n {\n name: 'relaxed',\n code: '☺️',\n keywords: [\n 'blush',\n 'pleased',\n 'relaxed',\n ],\n },\n {\n name: 'kissing_closed_eyes',\n code: '😚',\n keywords: [\n 'kissing_closed_eyes',\n 'closed',\n 'eye',\n 'face',\n 'kiss',\n ],\n },\n {\n name: 'kissing_smiling_eyes',\n code: '😙',\n keywords: [\n 'kissing_smiling_eyes',\n 'eye',\n 'face',\n 'kiss',\n 'smile',\n ],\n },\n {\n name: 'smiling_face_with_tear',\n code: '🥲',\n keywords: [\n 'smiling_face_with_tear',\n ],\n },\n {\n name: 'yum',\n code: '😋',\n keywords: [\n 'tongue',\n 'lick',\n 'yum',\n 'delicious',\n 'face',\n 'savouring',\n 'smile',\n 'um',\n ],\n },\n {\n name: 'stuck_out_tongue',\n code: '😛',\n keywords: [\n 'stuck_out_tongue',\n 'face',\n 'tongue',\n ],\n },\n {\n name: 'stuck_out_tongue_winking_eye',\n code: '😜',\n keywords: [\n 'prank',\n 'silly',\n 'stuck_out_tongue_winking_eye',\n 'eye',\n 'face',\n 'joke',\n 'tongue',\n 'wink',\n ],\n },\n {\n name: 'zany_face',\n code: '🤪',\n keywords: [\n 'goofy',\n 'wacky',\n 'zany_face',\n ],\n },\n {\n name: 'stuck_out_tongue_closed_eyes',\n code: '😝',\n keywords: [\n 'prank',\n 'stuck_out_tongue_closed_eyes',\n 'eye',\n 'face',\n 'horrible',\n 'taste',\n 'tongue',\n ],\n },\n {\n name: 'money_mouth_face',\n code: '🤑',\n keywords: [\n 'rich',\n 'money_mouth_face',\n 'face',\n 'money',\n 'mouth',\n ],\n },\n {\n name: 'hugs',\n code: '🤗',\n keywords: [\n 'hugs',\n 'face',\n 'hug',\n 'hugging',\n ],\n },\n {\n name: 'hand_over_mouth',\n code: '🤭',\n keywords: [\n 'quiet',\n 'whoops',\n 'hand_over_mouth',\n ],\n },\n {\n name: 'shushing_face',\n code: '🤫',\n keywords: [\n 'silence',\n 'quiet',\n 'shushing_face',\n ],\n },\n {\n name: 'thinking',\n code: '🤔',\n keywords: [\n 'thinking',\n 'face',\n ],\n },\n {\n name: 'zipper_mouth_face',\n code: '🤐',\n keywords: [\n 'silence',\n 'hush',\n 'zipper_mouth_face',\n 'face',\n 'mouth',\n 'zipper',\n ],\n },\n {\n name: 'raised_eyebrow',\n code: '🤨',\n keywords: [\n 'suspicious',\n 'raised_eyebrow',\n ],\n },\n {\n name: 'neutral_face',\n code: '😐',\n keywords: [\n 'meh',\n 'neutral_face',\n 'deadpan',\n 'face',\n 'neutral',\n ],\n },\n {\n name: 'expressionless',\n code: '😑',\n keywords: [\n 'expressionless',\n 'face',\n 'inexpressive',\n 'unexpressive',\n ],\n },\n {\n name: 'no_mouth',\n code: '😶',\n keywords: [\n 'mute',\n 'silence',\n 'no_mouth',\n 'face',\n 'mouth',\n 'quiet',\n 'silent',\n ],\n },\n {\n name: 'face_in_clouds',\n code: '😶‍🌫️',\n keywords: [\n 'face_in_clouds',\n ],\n },\n {\n name: 'smirk',\n code: '😏',\n keywords: [\n 'smug',\n 'smirk',\n 'face',\n ],\n },\n {\n name: 'unamused',\n code: '😒',\n keywords: [\n 'meh',\n 'unamused',\n 'face',\n 'unhappy',\n ],\n },\n {\n name: 'roll_eyes',\n code: '🙄',\n keywords: [\n 'roll_eyes',\n 'eyes',\n 'face',\n 'rolling',\n ],\n },\n {\n name: 'grimacing',\n code: '😬',\n keywords: [\n 'grimacing',\n 'face',\n 'grimace',\n ],\n },\n {\n name: 'face_exhaling',\n code: '😮‍💨',\n keywords: [\n 'face_exhaling',\n ],\n },\n {\n name: 'lying_face',\n code: '🤥',\n keywords: [\n 'liar',\n 'lying_face',\n 'face',\n 'lie',\n 'pinocchio',\n ],\n },\n {\n name: 'relieved',\n code: '😌',\n keywords: [\n 'whew',\n 'relieved',\n 'face',\n ],\n },\n {\n name: 'pensive',\n code: '😔',\n keywords: [\n 'pensive',\n 'dejected',\n 'face',\n ],\n },\n {\n name: 'sleepy',\n code: '😪',\n keywords: [\n 'tired',\n 'sleepy',\n 'face',\n 'sleep',\n ],\n },\n {\n name: 'drooling_face',\n code: '🤤',\n keywords: [\n 'drooling_face',\n 'drooling',\n 'face',\n ],\n },\n {\n name: 'sleeping',\n code: '😴',\n keywords: [\n 'zzz',\n 'sleeping',\n 'face',\n 'sleep',\n ],\n },\n {\n name: 'mask',\n code: '😷',\n keywords: [\n 'sick',\n 'ill',\n 'mask',\n 'cold',\n 'doctor',\n 'face',\n 'medicine',\n ],\n },\n {\n name: 'face_with_thermometer',\n code: '🤒',\n keywords: [\n 'sick',\n 'face_with_thermometer',\n 'face',\n 'ill',\n 'thermometer',\n ],\n },\n {\n name: 'face_with_head_bandage',\n code: '🤕',\n keywords: [\n 'hurt',\n 'face_with_head_bandage',\n 'bandage',\n 'face',\n 'injury',\n ],\n },\n {\n name: 'nauseated_face',\n code: '🤢',\n keywords: [\n 'sick',\n 'barf',\n 'disgusted',\n 'nauseated_face',\n 'face',\n 'nauseated',\n 'vomit',\n ],\n },\n {\n name: 'vomiting_face',\n code: '🤮',\n keywords: [\n 'barf',\n 'sick',\n 'vomiting_face',\n ],\n },\n {\n name: 'sneezing_face',\n code: '🤧',\n keywords: [\n 'achoo',\n 'sick',\n 'sneezing_face',\n 'face',\n 'gesundheit',\n 'sneeze',\n ],\n },\n {\n name: 'hot_face',\n code: '🥵',\n keywords: [\n 'heat',\n 'sweating',\n 'hot_face',\n ],\n },\n {\n name: 'cold_face',\n code: '🥶',\n keywords: [\n 'freezing',\n 'ice',\n 'cold_face',\n ],\n },\n {\n name: 'woozy_face',\n code: '🥴',\n keywords: [\n 'groggy',\n 'woozy_face',\n ],\n },\n {\n name: 'dizzy_face',\n code: '😵',\n keywords: [\n 'dizzy_face',\n 'dizzy',\n 'face',\n ],\n },\n {\n name: 'face_with_spiral_eyes',\n code: '😵‍💫',\n keywords: [\n 'face_with_spiral_eyes',\n ],\n },\n {\n name: 'exploding_head',\n code: '🤯',\n keywords: [\n 'mind',\n 'blown',\n 'exploding_head',\n ],\n },\n {\n name: 'cowboy_hat_face',\n code: '🤠',\n keywords: [\n 'cowboy_hat_face',\n 'cowboy',\n 'cowgirl',\n 'face',\n 'hat',\n ],\n },\n {\n name: 'partying_face',\n code: '🥳',\n keywords: [\n 'celebration',\n 'birthday',\n 'partying_face',\n ],\n },\n {\n name: 'disguised_face',\n code: '🥸',\n keywords: [\n 'disguised_face',\n ],\n },\n {\n name: 'sunglasses',\n code: '😎',\n keywords: [\n 'cool',\n 'sunglasses',\n 'bright',\n 'eye',\n 'eyewear',\n 'face',\n 'glasses',\n 'smile',\n 'sun',\n 'weather',\n ],\n },\n {\n name: 'nerd_face',\n code: '🤓',\n keywords: [\n 'geek',\n 'glasses',\n 'nerd_face',\n 'face',\n 'nerd',\n ],\n },\n {\n name: 'monocle_face',\n code: '🧐',\n keywords: [\n 'monocle_face',\n ],\n },\n {\n name: 'confused',\n code: '😕',\n keywords: [\n 'confused',\n 'face',\n ],\n },\n {\n name: 'worried',\n code: '😟',\n keywords: [\n 'nervous',\n 'worried',\n 'face',\n ],\n },\n {\n name: 'slightly_frowning_face',\n code: '🙁',\n keywords: [\n 'slightly_frowning_face',\n 'face',\n 'frown',\n ],\n },\n {\n name: 'frowning_face',\n code: '☹️',\n keywords: [\n 'frowning_face',\n ],\n },\n {\n name: 'open_mouth',\n code: '😮',\n keywords: [\n 'surprise',\n 'impressed',\n 'wow',\n 'open_mouth',\n 'face',\n 'mouth',\n 'open',\n 'sympathy',\n ],\n },\n {\n name: 'hushed',\n code: '😯',\n keywords: [\n 'silence',\n 'speechless',\n 'hushed',\n 'face',\n 'stunned',\n 'surprised',\n ],\n },\n {\n name: 'astonished',\n code: '😲',\n keywords: [\n 'amazed',\n 'gasp',\n 'astonished',\n 'face',\n 'shocked',\n 'totally',\n ],\n },\n {\n name: 'flushed',\n code: '😳',\n keywords: [\n 'flushed',\n 'dazed',\n 'face',\n ],\n },\n {\n name: 'pleading_face',\n code: '🥺',\n keywords: [\n 'puppy',\n 'eyes',\n 'pleading_face',\n ],\n },\n {\n name: 'frowning',\n code: '😦',\n keywords: [\n 'frowning',\n 'face',\n 'frown',\n 'mouth',\n 'open',\n ],\n },\n {\n name: 'anguished',\n code: '😧',\n keywords: [\n 'stunned',\n 'anguished',\n 'face',\n ],\n },\n {\n name: 'fearful',\n code: '😨',\n keywords: [\n 'scared',\n 'shocked',\n 'oops',\n 'fearful',\n 'face',\n 'fear',\n ],\n },\n {\n name: 'cold_sweat',\n code: '😰',\n keywords: [\n 'nervous',\n 'cold_sweat',\n 'blue',\n 'cold',\n 'face',\n 'mouth',\n 'open',\n 'rushed',\n 'sweat',\n ],\n },\n {\n name: 'disappointed_relieved',\n code: '😥',\n keywords: [\n 'phew',\n 'sweat',\n 'nervous',\n 'disappointed_relieved',\n 'disappointed',\n 'face',\n 'relieved',\n 'whew',\n ],\n },\n {\n name: 'cry',\n code: '😢',\n keywords: [\n 'sad',\n 'tear',\n 'cry',\n 'face',\n ],\n },\n {\n name: 'sob',\n code: '😭',\n keywords: [\n 'sad',\n 'cry',\n 'bawling',\n 'sob',\n 'face',\n 'tear',\n ],\n },\n {\n name: 'scream',\n code: '😱',\n keywords: [\n 'horror',\n 'shocked',\n 'scream',\n 'face',\n 'fear',\n 'fearful',\n 'munch',\n 'scared',\n ],\n },\n {\n name: 'confounded',\n code: '😖',\n keywords: [\n 'confounded',\n 'face',\n ],\n },\n {\n name: 'persevere',\n code: '😣',\n keywords: [\n 'struggling',\n 'persevere',\n 'face',\n ],\n },\n {\n name: 'disappointed',\n code: '😞',\n keywords: [\n 'sad',\n 'disappointed',\n 'face',\n ],\n },\n {\n name: 'sweat',\n code: '😓',\n keywords: [\n 'sweat',\n 'cold',\n 'face',\n ],\n },\n {\n name: 'weary',\n code: '😩',\n keywords: [\n 'tired',\n 'weary',\n 'face',\n ],\n },\n {\n name: 'tired_face',\n code: '😫',\n keywords: [\n 'upset',\n 'whine',\n 'tired_face',\n 'face',\n 'tired',\n ],\n },\n {\n name: 'yawning_face',\n code: '🥱',\n keywords: [\n 'yawning_face',\n ],\n },\n {\n name: 'triumph',\n code: '😤',\n keywords: [\n 'smug',\n 'triumph',\n 'face',\n 'won',\n ],\n },\n {\n name: 'rage',\n code: '😡',\n keywords: [\n 'angry',\n 'rage',\n 'pout',\n 'face',\n 'mad',\n 'pouting',\n 'red',\n ],\n },\n {\n name: 'angry',\n code: '😠',\n keywords: [\n 'mad',\n 'annoyed',\n 'angry',\n 'face',\n ],\n },\n {\n name: 'cursing_face',\n code: '🤬',\n keywords: [\n 'foul',\n 'cursing_face',\n ],\n },\n {\n name: 'smiling_imp',\n code: '😈',\n keywords: [\n 'devil',\n 'evil',\n 'horns',\n 'smiling_imp',\n 'face',\n 'fairy tale',\n 'fantasy',\n 'smile',\n ],\n },\n {\n name: 'imp',\n code: '👿',\n keywords: [\n 'angry',\n 'devil',\n 'evil',\n 'horns',\n 'imp',\n 'demon',\n 'face',\n 'fairy tale',\n 'fantasy',\n ],\n },\n {\n name: 'skull',\n code: '💀',\n keywords: [\n 'dead',\n 'danger',\n 'poison',\n 'skull',\n 'body',\n 'death',\n 'face',\n 'fairy tale',\n 'monster',\n ],\n },\n {\n name: 'skull_and_crossbones',\n code: '☠️',\n keywords: [\n 'danger',\n 'pirate',\n 'skull_and_crossbones',\n 'body',\n 'crossbones',\n 'death',\n 'face',\n 'monster',\n 'skull',\n ],\n },\n {\n name: 'hankey',\n code: '💩',\n keywords: [\n 'crap',\n 'hankey',\n 'poop',\n 'shit',\n 'comic',\n 'dung',\n 'face',\n 'monster',\n 'poo',\n ],\n },\n {\n name: 'clown_face',\n code: '🤡',\n keywords: [\n 'clown_face',\n 'clown',\n 'face',\n ],\n },\n {\n name: 'japanese_ogre',\n code: '👹',\n keywords: [\n 'monster',\n 'japanese_ogre',\n 'creature',\n 'face',\n 'fairy tale',\n 'fantasy',\n 'japanese',\n 'ogre',\n ],\n },\n {\n name: 'japanese_goblin',\n code: '👺',\n keywords: [\n 'japanese_goblin',\n 'creature',\n 'face',\n 'fairy tale',\n 'fantasy',\n 'goblin',\n 'japanese',\n 'monster',\n ],\n },\n {\n name: 'ghost',\n code: '👻',\n keywords: [\n 'halloween',\n 'ghost',\n 'creature',\n 'face',\n 'fairy tale',\n 'fantasy',\n 'monster',\n ],\n },\n {\n name: 'alien',\n code: '👽',\n keywords: [\n 'ufo',\n 'alien',\n 'creature',\n 'extraterrestrial',\n 'face',\n 'fairy tale',\n 'fantasy',\n 'monster',\n 'space',\n ],\n },\n {\n name: 'space_invader',\n code: '👾',\n keywords: [\n 'game',\n 'retro',\n 'space_invader',\n 'alien',\n 'creature',\n 'extraterrestrial',\n 'face',\n 'fairy tale',\n 'fantasy',\n 'monster',\n 'space',\n 'ufo',\n ],\n },\n {\n name: 'robot',\n code: '🤖',\n keywords: [\n 'robot',\n 'face',\n 'monster',\n ],\n },\n {\n name: 'smiley_cat',\n code: '😺',\n keywords: [\n 'smiley_cat',\n 'cat',\n 'face',\n 'mouth',\n 'open',\n 'smile',\n ],\n },\n {\n name: 'smile_cat',\n code: '😸',\n keywords: [\n 'smile_cat',\n 'cat',\n 'eye',\n 'face',\n 'grin',\n 'smile',\n ],\n },\n {\n name: 'joy_cat',\n code: '😹',\n keywords: [\n 'joy_cat',\n 'cat',\n 'face',\n 'joy',\n 'tear',\n ],\n },\n {\n name: 'heart_eyes_cat',\n code: '😻',\n keywords: [\n 'heart_eyes_cat',\n 'cat',\n 'eye',\n 'face',\n 'heart',\n 'love',\n 'smile',\n ],\n },\n {\n name: 'smirk_cat',\n code: '😼',\n keywords: [\n 'smirk_cat',\n 'cat',\n 'face',\n 'ironic',\n 'smile',\n 'wry',\n ],\n },\n {\n name: 'kissing_cat',\n code: '😽',\n keywords: [\n 'kissing_cat',\n 'cat',\n 'eye',\n 'face',\n 'kiss',\n ],\n },\n {\n name: 'scream_cat',\n code: '🙀',\n keywords: [\n 'horror',\n 'scream_cat',\n 'cat',\n 'face',\n 'oh',\n 'surprised',\n 'weary',\n ],\n },\n {\n name: 'crying_cat_face',\n code: '😿',\n keywords: [\n 'sad',\n 'tear',\n 'crying_cat_face',\n 'cat',\n 'cry',\n 'face',\n ],\n },\n {\n name: 'pouting_cat',\n code: '😾',\n keywords: [\n 'pouting_cat',\n 'cat',\n 'face',\n 'pouting',\n ],\n },\n {\n name: 'see_no_evil',\n code: '🙈',\n keywords: [\n 'monkey',\n 'blind',\n 'ignore',\n 'see_no_evil',\n 'evil',\n 'face',\n 'forbidden',\n 'gesture',\n 'no',\n 'not',\n 'prohibited',\n 'see',\n ],\n },\n {\n name: 'hear_no_evil',\n code: '🙉',\n keywords: [\n 'monkey',\n 'deaf',\n 'hear_no_evil',\n 'evil',\n 'face',\n 'forbidden',\n 'gesture',\n 'hear',\n 'no',\n 'not',\n 'prohibited',\n ],\n },\n {\n name: 'speak_no_evil',\n code: '🙊',\n keywords: [\n 'monkey',\n 'mute',\n 'hush',\n 'speak_no_evil',\n 'evil',\n 'face',\n 'forbidden',\n 'gesture',\n 'no',\n 'not',\n 'prohibited',\n 'speak',\n ],\n },\n {\n name: 'kiss',\n code: '💋',\n keywords: [\n 'lipstick',\n 'kiss',\n 'heart',\n 'lips',\n 'mark',\n 'romance',\n ],\n },\n {\n name: 'love_letter',\n code: '💌',\n keywords: [\n 'email',\n 'envelope',\n 'love_letter',\n 'heart',\n 'letter',\n 'love',\n 'mail',\n 'romance',\n ],\n },\n {\n name: 'cupid',\n code: '💘',\n keywords: [\n 'love',\n 'heart',\n 'cupid',\n 'arrow',\n 'romance',\n ],\n },\n {\n name: 'gift_heart',\n code: '💝',\n keywords: [\n 'chocolates',\n 'gift_heart',\n 'heart',\n 'ribbon',\n 'valentine',\n ],\n },\n {\n name: 'sparkling_heart',\n code: '💖',\n keywords: [\n 'sparkling_heart',\n 'excited',\n 'heart',\n 'sparkle',\n ],\n },\n {\n name: 'heartpulse',\n code: '💗',\n keywords: [\n 'heartpulse',\n 'excited',\n 'growing',\n 'heart',\n 'nervous',\n ],\n },\n {\n name: 'heartbeat',\n code: '💓',\n keywords: [\n 'heartbeat',\n 'beating',\n 'heart',\n 'pulsating',\n ],\n },\n {\n name: 'revolving_hearts',\n code: '💞',\n keywords: [\n 'revolving_hearts',\n 'heart',\n 'revolving',\n ],\n },\n {\n name: 'two_hearts',\n code: '💕',\n keywords: [\n 'two_hearts',\n 'heart',\n 'love',\n ],\n },\n {\n name: 'heart_decoration',\n code: '💟',\n keywords: [\n 'heart_decoration',\n 'heart',\n ],\n },\n {\n name: 'heavy_heart_exclamation',\n code: '❣️',\n keywords: [\n 'heavy_heart_exclamation',\n 'exclamation',\n 'heart',\n 'mark',\n 'punctuation',\n ],\n },\n {\n name: 'broken_heart',\n code: '💔',\n keywords: [\n 'broken_heart',\n 'break',\n 'broken',\n 'heart',\n ],\n },\n {\n name: 'heart_on_fire',\n code: '❤️‍🔥',\n keywords: [\n 'heart_on_fire',\n ],\n },\n {\n name: 'mending_heart',\n code: '❤️‍🩹',\n keywords: [\n 'mending_heart',\n ],\n },\n {\n name: 'heart',\n code: '❤️',\n keywords: [\n 'love',\n 'heart',\n ],\n },\n {\n name: 'orange_heart',\n code: '🧡',\n keywords: [\n 'orange_heart',\n ],\n },\n {\n name: 'yellow_heart',\n code: '💛',\n keywords: [\n 'yellow_heart',\n 'heart',\n 'yellow',\n ],\n },\n {\n name: 'green_heart',\n code: '💚',\n keywords: [\n 'green_heart',\n 'green',\n 'heart',\n ],\n },\n {\n name: 'blue_heart',\n code: '💙',\n keywords: [\n 'blue_heart',\n 'blue',\n 'heart',\n ],\n },\n {\n name: 'purple_heart',\n code: '💜',\n keywords: [\n 'purple_heart',\n 'heart',\n 'purple',\n ],\n },\n {\n name: 'brown_heart',\n code: '🤎',\n keywords: [\n 'brown_heart',\n ],\n },\n {\n name: 'black_heart',\n code: '🖤',\n keywords: [\n 'black_heart',\n 'black',\n 'evil',\n 'heart',\n 'wicked',\n ],\n },\n {\n name: 'white_heart',\n code: '🤍',\n keywords: [\n 'white_heart',\n ],\n },\n {\n name: '100',\n code: '💯',\n keywords: [\n 'score',\n 'perfect',\n '100',\n 'full',\n 'hundred',\n ],\n },\n {\n name: 'anger',\n code: '💢',\n keywords: [\n 'angry',\n 'anger',\n 'comic',\n 'mad',\n ],\n },\n {\n name: 'boom',\n code: '💥',\n keywords: [\n 'explode',\n 'boom',\n 'collision',\n 'comic',\n ],\n },\n {\n name: 'dizzy',\n code: '💫',\n keywords: [\n 'star',\n 'dizzy',\n 'comic',\n ],\n },\n {\n name: 'sweat_drops',\n code: '💦',\n keywords: [\n 'water',\n 'workout',\n 'sweat_drops',\n 'comic',\n 'splashing',\n 'sweat',\n ],\n },\n {\n name: 'dash',\n code: '💨',\n keywords: [\n 'wind',\n 'blow',\n 'fast',\n 'dash',\n 'comic',\n 'running',\n ],\n },\n {\n name: 'hole',\n code: '🕳️',\n keywords: [\n 'hole',\n ],\n },\n {\n name: 'bomb',\n code: '💣',\n keywords: [\n 'boom',\n 'bomb',\n 'comic',\n ],\n },\n {\n name: 'speech_balloon',\n code: '💬',\n keywords: [\n 'comment',\n 'speech_balloon',\n 'balloon',\n 'bubble',\n 'comic',\n 'dialog',\n 'speech',\n ],\n },\n {\n name: 'eye_speech_bubble',\n code: '👁️‍🗨️',\n keywords: [\n 'eye_speech_bubble',\n ],\n },\n {\n name: 'left_speech_bubble',\n code: '🗨️',\n keywords: [\n 'left_speech_bubble',\n ],\n },\n {\n name: 'right_anger_bubble',\n code: '🗯️',\n keywords: [\n 'right_anger_bubble',\n ],\n },\n {\n name: 'thought_balloon',\n code: '💭',\n keywords: [\n 'thinking',\n 'thought_balloon',\n 'balloon',\n 'bubble',\n 'comic',\n 'thought',\n ],\n },\n {\n name: 'zzz',\n code: '💤',\n keywords: [\n 'sleeping',\n 'zzz',\n 'comic',\n 'sleep',\n ],\n },\n {\n name: 'wave',\n code: '👋',\n keywords: [\n 'goodbye',\n 'wave',\n 'body',\n 'hand',\n 'waving',\n ],\n types: [\n '👋🏿',\n '👋🏾',\n '👋🏽',\n '👋🏼',\n '👋🏻',\n ],\n },\n {\n name: 'raised_back_of_hand',\n code: '🤚',\n keywords: [\n 'raised_back_of_hand',\n 'backhand',\n 'raised',\n ],\n types: [\n '🤚🏿',\n '🤚🏾',\n '🤚🏽',\n '🤚🏼',\n '🤚🏻',\n ],\n },\n {\n name: 'raised_hand_with_fingers_splayed',\n code: '🖐️',\n keywords: [\n 'raised_hand_with_fingers_splayed',\n ],\n types: [\n '🖐🏿',\n '🖐🏾',\n '🖐🏽',\n '🖐🏼',\n '🖐🏻',\n ],\n },\n {\n name: 'hand',\n code: '✋',\n keywords: [\n 'highfive',\n 'stop',\n 'hand',\n 'raised_hand',\n 'body',\n ],\n types: [\n '✋🏿',\n '✋🏾',\n '✋🏽',\n '✋🏼',\n '✋🏻',\n ],\n },\n {\n name: 'vulcan_salute',\n code: '🖖',\n keywords: [\n 'prosper',\n 'spock',\n 'vulcan_salute',\n 'body',\n 'finger',\n 'hand',\n 'vulcan',\n ],\n types: [\n '🖖🏿',\n '🖖🏾',\n '🖖🏽',\n '🖖🏼',\n '🖖🏻',\n ],\n },\n {\n name: 'ok_hand',\n code: '👌',\n keywords: [\n 'ok_hand',\n 'body',\n 'hand',\n 'ok',\n ],\n types: [\n '👌🏿',\n '👌🏾',\n '👌🏽',\n '👌🏼',\n '👌🏻',\n ],\n },\n {\n name: 'pinched_fingers',\n code: '🤌',\n keywords: [\n 'pinched_fingers',\n ],\n types: [\n '🤌🏿',\n '🤌🏾',\n '🤌🏽',\n '🤌🏼',\n '🤌🏻',\n ],\n },\n {\n name: 'pinching_hand',\n code: '🤏',\n keywords: [\n 'pinching_hand',\n ],\n types: [\n '🤏🏿',\n '🤏🏾',\n '🤏🏽',\n '🤏🏼',\n '🤏🏻',\n ],\n },\n {\n name: 'v',\n code: '✌️',\n keywords: [\n 'victory',\n 'peace',\n 'v',\n ],\n types: [\n '✌🏿',\n '✌🏾',\n '✌🏽',\n '✌🏼',\n '✌🏻',\n ],\n },\n {\n name: 'crossed_fingers',\n code: '🤞',\n keywords: [\n 'luck',\n 'hopeful',\n 'crossed_fingers',\n 'cross',\n 'finger',\n 'hand',\n ],\n types: [\n '🤞🏿',\n '🤞🏾',\n '🤞🏽',\n '🤞🏼',\n '🤞🏻',\n ],\n },\n {\n name: 'love_you_gesture',\n code: '🤟',\n keywords: [\n 'love_you_gesture',\n ],\n types: [\n '🤟🏿',\n '🤟🏾',\n '🤟🏽',\n '🤟🏼',\n '🤟🏻',\n ],\n },\n {\n name: 'metal',\n code: '🤘',\n keywords: [\n 'metal',\n 'body',\n 'finger',\n 'hand',\n 'horns',\n 'rock-on',\n ],\n types: [\n '🤘🏿',\n '🤘🏾',\n '🤘🏽',\n '🤘🏼',\n '🤘🏻',\n ],\n },\n {\n name: 'call_me_hand',\n code: '🤙',\n keywords: [\n 'call_me_hand',\n 'call',\n 'hand',\n 'shaka',\n ],\n types: [\n '🤙🏿',\n '🤙🏾',\n '🤙🏽',\n '🤙🏼',\n '🤙🏻',\n ],\n },\n {\n name: 'point_left',\n code: '👈',\n keywords: [\n 'point_left',\n 'backhand',\n 'body',\n 'finger',\n 'hand',\n 'index',\n 'point',\n ],\n types: [\n '👈🏿',\n '👈🏾',\n '👈🏽',\n '👈🏼',\n '👈🏻',\n ],\n },\n {\n name: 'point_right',\n code: '👉',\n keywords: [\n 'point_right',\n 'backhand',\n 'body',\n 'finger',\n 'hand',\n 'index',\n 'point',\n ],\n types: [\n '👉🏿',\n '👉🏾',\n '👉🏽',\n '👉🏼',\n '👉🏻',\n ],\n },\n {\n name: 'point_up_2',\n code: '👆',\n keywords: [\n 'point_up_2',\n 'backhand',\n 'body',\n 'finger',\n 'hand',\n 'index',\n 'point',\n 'up',\n ],\n types: [\n '👆🏿',\n '👆🏾',\n '👆🏽',\n '👆🏼',\n '👆🏻',\n ],\n },\n {\n name: 'middle_finger',\n code: '🖕',\n keywords: [\n 'middle_finger',\n 'fu',\n 'body',\n 'finger',\n 'hand',\n 'middle finger',\n ],\n types: [\n '🖕🏿',\n '🖕🏾',\n '🖕🏽',\n '🖕🏼',\n '🖕🏻',\n ],\n },\n {\n name: 'point_down',\n code: '👇',\n keywords: [\n 'point_down',\n 'backhand',\n 'body',\n 'down',\n 'finger',\n 'hand',\n 'index',\n 'point',\n ],\n types: [\n '👇🏿',\n '👇🏾',\n '👇🏽',\n '👇🏼',\n '👇🏻',\n ],\n },\n {\n name: 'point_up',\n code: '☝️',\n keywords: [\n 'point_up',\n ],\n types: [\n '☝🏿',\n '☝🏾',\n '☝🏽',\n '☝🏼',\n '☝🏻',\n ],\n },\n {\n name: '+1',\n code: '👍',\n keywords: [\n 'approve',\n 'ok',\n '+1',\n 'thumbsup',\n 'body',\n 'hand',\n 'thumb',\n 'thumbs up',\n 'up',\n ],\n types: [\n '👍🏿',\n '👍🏾',\n '👍🏽',\n '👍🏼',\n '👍🏻',\n ],\n },\n {\n name: '-1',\n code: '👎',\n keywords: [\n 'disapprove',\n 'bury',\n '-1',\n 'thumbsdown',\n 'body',\n 'down',\n 'hand',\n 'thumb',\n 'thumbs down',\n ],\n types: [\n '👎🏿',\n '👎🏾',\n '👎🏽',\n '👎🏼',\n '👎🏻',\n ],\n },\n {\n name: 'fist_raised',\n code: '✊',\n keywords: [\n 'power',\n 'fist_raised',\n 'fist',\n 'body',\n 'clenched',\n 'hand',\n 'punch',\n ],\n types: [\n '✊🏿',\n '✊🏾',\n '✊🏽',\n '✊🏼',\n '✊🏻',\n ],\n },\n {\n name: 'fist_oncoming',\n code: '👊',\n keywords: [\n 'attack',\n 'fist_oncoming',\n 'facepunch',\n 'punch',\n 'body',\n 'clenched',\n 'fist',\n 'hand',\n ],\n types: [\n '👊🏿',\n '👊🏾',\n '👊🏽',\n '👊🏼',\n '👊🏻',\n ],\n },\n {\n name: 'fist_left',\n code: '🤛',\n keywords: [\n 'fist_left',\n 'fist',\n 'leftwards',\n ],\n types: [\n '🤛🏿',\n '🤛🏾',\n '🤛🏽',\n '🤛🏼',\n '🤛🏻',\n ],\n },\n {\n name: 'fist_right',\n code: '🤜',\n keywords: [\n 'fist_right',\n 'fist',\n 'rightwards',\n ],\n types: [\n '🤜🏿',\n '🤜🏾',\n '🤜🏽',\n '🤜🏼',\n '🤜🏻',\n ],\n },\n {\n name: 'clap',\n code: '👏',\n keywords: [\n 'praise',\n 'applause',\n 'clap',\n 'body',\n 'hand',\n ],\n types: [\n '👏🏿',\n '👏🏾',\n '👏🏽',\n '👏🏼',\n '👏🏻',\n ],\n },\n {\n name: 'raised_hands',\n code: '🙌',\n keywords: [\n 'hooray',\n 'raised_hands',\n 'body',\n 'celebration',\n 'gesture',\n 'hand',\n 'raised',\n ],\n types: [\n '🙌🏿',\n '🙌🏾',\n '🙌🏽',\n '🙌🏼',\n '🙌🏻',\n ],\n },\n {\n name: 'open_hands',\n code: '👐',\n keywords: [\n 'open_hands',\n 'body',\n 'hand',\n 'open',\n ],\n types: [\n '👐🏿',\n '👐🏾',\n '👐🏽',\n '👐🏼',\n '👐🏻',\n ],\n },\n {\n name: 'palms_up_together',\n code: '🤲',\n keywords: [\n 'palms_up_together',\n ],\n types: [\n '🤲🏿',\n '🤲🏾',\n '🤲🏽',\n '🤲🏼',\n '🤲🏻',\n ],\n },\n {\n name: 'handshake',\n code: '🤝',\n keywords: [\n 'deal',\n 'handshake',\n 'agreement',\n 'hand',\n 'meeting',\n 'shake',\n ],\n types: [\n '🤝🏿',\n '🤝🏾',\n '🤝🏽',\n '🤝🏼',\n '🤝🏻',\n ],\n },\n {\n name: 'pray',\n code: '🙏',\n keywords: [\n 'please',\n 'hope',\n 'wish',\n 'pray',\n 'ask',\n 'body',\n 'bow',\n 'folded',\n 'gesture',\n 'hand',\n 'thanks',\n ],\n types: [\n '🙏🏿',\n '🙏🏾',\n '🙏🏽',\n '🙏🏼',\n '🙏🏻',\n ],\n },\n {\n name: 'writing_hand',\n code: '✍️',\n keywords: [\n 'writing_hand',\n ],\n types: [\n '✍🏿',\n '✍🏾',\n '✍🏽',\n '✍🏼',\n '✍🏻',\n ],\n },\n {\n name: 'nail_care',\n code: '💅',\n keywords: [\n 'beauty',\n 'manicure',\n 'nail_care',\n 'body',\n 'care',\n 'cosmetics',\n 'nail',\n 'polish',\n ],\n types: [\n '💅🏿',\n '💅🏾',\n '💅🏽',\n '💅🏼',\n '💅🏻',\n ],\n },\n {\n name: 'selfie',\n code: '🤳',\n keywords: [\n 'selfie',\n 'camera',\n 'phone',\n ],\n types: [\n '🤳🏿',\n '🤳🏾',\n '🤳🏽',\n '🤳🏼',\n '🤳🏻',\n ],\n },\n {\n name: 'muscle',\n code: '💪',\n keywords: [\n 'flex',\n 'bicep',\n 'strong',\n 'workout',\n 'muscle',\n 'biceps',\n 'body',\n 'comic',\n ],\n types: [\n '💪🏿',\n '💪🏾',\n '💪🏽',\n '💪🏼',\n '💪🏻',\n ],\n },\n {\n name: 'mechanical_arm',\n code: '🦾',\n keywords: [\n 'mechanical_arm',\n ],\n },\n {\n name: 'mechanical_leg',\n code: '🦿',\n keywords: [\n 'mechanical_leg',\n ],\n },\n {\n name: 'leg',\n code: '🦵',\n keywords: [\n 'leg',\n ],\n types: [\n '🦵🏿',\n '🦵🏾',\n '🦵🏽',\n '🦵🏼',\n '🦵🏻',\n ],\n },\n {\n name: 'foot',\n code: '🦶',\n keywords: [\n 'foot',\n ],\n types: [\n '🦶🏿',\n '🦶🏾',\n '🦶🏽',\n '🦶🏼',\n '🦶🏻',\n ],\n },\n {\n name: 'ear',\n code: '👂',\n keywords: [\n 'hear',\n 'sound',\n 'listen',\n 'ear',\n 'body',\n ],\n types: [\n '👂🏿',\n '👂🏾',\n '👂🏽',\n '👂🏼',\n '👂🏻',\n ],\n },\n {\n name: 'ear_with_hearing_aid',\n code: '🦻',\n keywords: [\n 'ear_with_hearing_aid',\n ],\n types: [\n '🦻🏿',\n '🦻🏾',\n '🦻🏽',\n '🦻🏼',\n '🦻🏻',\n ],\n },\n {\n name: 'nose',\n code: '👃',\n keywords: [\n 'smell',\n 'nose',\n 'body',\n ],\n types: [\n '👃🏿',\n '👃🏾',\n '👃🏽',\n '👃🏼',\n '👃🏻',\n ],\n },\n {\n name: 'brain',\n code: '🧠',\n keywords: [\n 'brain',\n ],\n },\n {\n name: 'anatomical_heart',\n code: '🫀',\n keywords: [\n 'anatomical_heart',\n ],\n },\n {\n name: 'lungs',\n code: '🫁',\n keywords: [\n 'lungs',\n ],\n },\n {\n name: 'tooth',\n code: '🦷',\n keywords: [\n 'tooth',\n ],\n },\n {\n name: 'bone',\n code: '🦴',\n keywords: [\n 'bone',\n ],\n },\n {\n name: 'eyes',\n code: '👀',\n keywords: [\n 'look',\n 'see',\n 'watch',\n 'eyes',\n 'body',\n 'eye',\n 'face',\n ],\n },\n {\n name: 'eye',\n code: '👁️',\n keywords: [\n 'eye',\n ],\n },\n {\n name: 'tongue',\n code: '👅',\n keywords: [\n 'taste',\n 'tongue',\n 'body',\n ],\n },\n {\n name: 'lips',\n code: '👄',\n keywords: [\n 'kiss',\n 'lips',\n 'body',\n 'mouth',\n ],\n },\n {\n name: 'baby',\n code: '👶',\n keywords: [\n 'child',\n 'newborn',\n 'baby',\n ],\n types: [\n '👶🏿',\n '👶🏾',\n '👶🏽',\n '👶🏼',\n '👶🏻',\n ],\n },\n {\n name: 'child',\n code: '🧒',\n keywords: [\n 'child',\n ],\n types: [\n '🧒🏿',\n '🧒🏾',\n '🧒🏽',\n '🧒🏼',\n '🧒🏻',\n ],\n },\n {\n name: 'boy',\n code: '👦',\n keywords: [\n 'child',\n 'boy',\n ],\n types: [\n '👦🏿',\n '👦🏾',\n '👦🏽',\n '👦🏼',\n '👦🏻',\n ],\n },\n {\n name: 'girl',\n code: '👧',\n keywords: [\n 'child',\n 'girl',\n 'maiden',\n 'virgin',\n 'virgo',\n 'zodiac',\n ],\n types: [\n '👧🏿',\n '👧🏾',\n '👧🏽',\n '👧🏼',\n '👧🏻',\n ],\n },\n {\n name: 'adult',\n code: '🧑',\n keywords: [\n 'adult',\n ],\n types: [\n '🧑🏿',\n '🧑🏾',\n '🧑🏽',\n '🧑🏼',\n '🧑🏻',\n ],\n },\n {\n name: 'blond_haired_person',\n code: '👱',\n keywords: [\n 'blond_haired_person',\n 'blond',\n ],\n types: [\n '👱🏿',\n '👱🏾',\n '👱🏽',\n '👱🏼',\n '👱🏻',\n ],\n },\n {\n name: 'man',\n code: '👨',\n keywords: [\n 'mustache',\n 'father',\n 'dad',\n 'man',\n ],\n types: [\n '👨🏿',\n '👨🏾',\n '👨🏽',\n '👨🏼',\n '👨🏻',\n ],\n },\n {\n name: 'bearded_person',\n code: '🧔',\n keywords: [\n 'bearded_person',\n ],\n types: [\n '🧔🏿',\n '🧔🏾',\n '🧔🏽',\n '🧔🏼',\n '🧔🏻',\n ],\n },\n {\n name: 'man_beard',\n code: '🧔‍♂️',\n keywords: [\n 'man_beard',\n ],\n types: [\n '🧔🏿‍♂️',\n '🧔🏾‍♂️',\n '🧔🏽‍♂️',\n '🧔🏼‍♂️',\n '🧔🏻‍♂️',\n ],\n },\n {\n name: 'woman_beard',\n code: '🧔‍♀️',\n keywords: [\n 'woman_beard',\n ],\n types: [\n '🧔🏿‍♀️',\n '🧔🏾‍♀️',\n '🧔🏽‍♀️',\n '🧔🏼‍♀️',\n '🧔🏻‍♀️',\n ],\n },\n {\n name: 'red_haired_man',\n code: '👨‍🦰',\n keywords: [\n 'red_haired_man',\n ],\n types: [\n '👨🏿‍🦰',\n '👨🏾‍🦰',\n '👨🏽‍🦰',\n '👨🏼‍🦰',\n '👨🏻‍🦰',\n ],\n },\n {\n name: 'curly_haired_man',\n code: '👨‍🦱',\n keywords: [\n 'curly_haired_man',\n ],\n types: [\n '👨🏿‍🦱',\n '👨🏾‍🦱',\n '👨🏽‍🦱',\n '👨🏼‍🦱',\n '👨🏻‍🦱',\n ],\n },\n {\n name: 'white_haired_man',\n code: '👨‍🦳',\n keywords: [\n 'white_haired_man',\n ],\n types: [\n '👨🏿‍🦳',\n '👨🏾‍🦳',\n '👨🏽‍🦳',\n '👨🏼‍🦳',\n '👨🏻‍🦳',\n ],\n },\n {\n name: 'bald_man',\n code: '👨‍🦲',\n keywords: [\n 'bald_man',\n ],\n types: [\n '👨🏿‍🦲',\n '👨🏾‍🦲',\n '👨🏽‍🦲',\n '👨🏼‍🦲',\n '👨🏻‍🦲',\n ],\n },\n {\n name: 'woman',\n code: '👩',\n keywords: [\n 'girls',\n 'woman',\n ],\n types: [\n '👩🏿',\n '👩🏾',\n '👩🏽',\n '👩🏼',\n '👩🏻',\n ],\n },\n {\n name: 'red_haired_woman',\n code: '👩‍🦰',\n keywords: [\n 'red_haired_woman',\n ],\n types: [\n '👩🏿‍🦰',\n '👩🏾‍🦰',\n '👩🏽‍🦰',\n '👩🏼‍🦰',\n '👩🏻‍🦰',\n ],\n },\n {\n name: 'person_red_hair',\n code: '🧑‍🦰',\n keywords: [\n 'person_red_hair',\n ],\n types: [\n '🧑🏿‍🦰',\n '🧑🏾‍🦰',\n '🧑🏽‍🦰',\n '🧑🏼‍🦰',\n '🧑🏻‍🦰',\n ],\n },\n {\n name: 'curly_haired_woman',\n code: '👩‍🦱',\n keywords: [\n 'curly_haired_woman',\n ],\n types: [\n '👩🏿‍🦱',\n '👩🏾‍🦱',\n '👩🏽‍🦱',\n '👩🏼‍🦱',\n '👩🏻‍🦱',\n ],\n },\n {\n name: 'person_curly_hair',\n code: '🧑‍🦱',\n keywords: [\n 'person_curly_hair',\n ],\n types: [\n '🧑🏿‍🦱',\n '🧑🏾‍🦱',\n '🧑🏽‍🦱',\n '🧑🏼‍🦱',\n '🧑🏻‍🦱',\n ],\n },\n {\n name: 'white_haired_woman',\n code: '👩‍🦳',\n keywords: [\n 'white_haired_woman',\n ],\n types: [\n '👩🏿‍🦳',\n '👩🏾‍🦳',\n '👩🏽‍🦳',\n '👩🏼‍🦳',\n '👩🏻‍🦳',\n ],\n },\n {\n name: 'person_white_hair',\n code: '🧑‍🦳',\n keywords: [\n 'person_white_hair',\n ],\n types: [\n '🧑🏿‍🦳',\n '🧑🏾‍🦳',\n '🧑🏽‍🦳',\n '🧑🏼‍🦳',\n '🧑🏻‍🦳',\n ],\n },\n {\n name: 'bald_woman',\n code: '👩‍🦲',\n keywords: [\n 'bald_woman',\n ],\n types: [\n '👩🏿‍🦲',\n '👩🏾‍🦲',\n '👩🏽‍🦲',\n '👩🏼‍🦲',\n '👩🏻‍🦲',\n ],\n },\n {\n name: 'person_bald',\n code: '🧑‍🦲',\n keywords: [\n 'person_bald',\n ],\n types: [\n '🧑🏿‍🦲',\n '🧑🏾‍🦲',\n '🧑🏽‍🦲',\n '🧑🏼‍🦲',\n '🧑🏻‍🦲',\n ],\n },\n {\n name: 'blond_haired_woman',\n code: '👱‍♀️',\n keywords: [\n 'blond_haired_woman',\n 'blonde_woman',\n ],\n types: [\n '👱🏿‍♀️',\n '👱🏾‍♀️',\n '👱🏽‍♀️',\n '👱🏼‍♀️',\n '👱🏻‍♀️',\n ],\n },\n {\n name: 'blond_haired_man',\n code: '👱‍♂️',\n keywords: [\n 'blond_haired_man',\n ],\n types: [\n '👱🏿‍♂️',\n '👱🏾‍♂️',\n '👱🏽‍♂️',\n '👱🏼‍♂️',\n '👱🏻‍♂️',\n ],\n },\n {\n name: 'older_adult',\n code: '🧓',\n keywords: [\n 'older_adult',\n ],\n types: [\n '🧓🏿',\n '🧓🏾',\n '🧓🏽',\n '🧓🏼',\n '🧓🏻',\n ],\n },\n {\n name: 'older_man',\n code: '👴',\n keywords: [\n 'older_man',\n 'man',\n 'old',\n ],\n types: [\n '👴🏿',\n '👴🏾',\n '👴🏽',\n '👴🏼',\n '👴🏻',\n ],\n },\n {\n name: 'older_woman',\n code: '👵',\n keywords: [\n 'older_woman',\n 'old',\n 'woman',\n ],\n types: [\n '👵🏿',\n '👵🏾',\n '👵🏽',\n '👵🏼',\n '👵🏻',\n ],\n },\n {\n name: 'frowning_person',\n code: '🙍',\n keywords: [\n 'frowning_person',\n 'frown',\n 'gesture',\n ],\n types: [\n '🙍🏿',\n '🙍🏾',\n '🙍🏽',\n '🙍🏼',\n '🙍🏻',\n ],\n },\n {\n name: 'frowning_man',\n code: '🙍‍♂️',\n keywords: [\n 'frowning_man',\n ],\n types: [\n '🙍🏿‍♂️',\n '🙍🏾‍♂️',\n '🙍🏽‍♂️',\n '🙍🏼‍♂️',\n '🙍🏻‍♂️',\n ],\n },\n {\n name: 'frowning_woman',\n code: '🙍‍♀️',\n keywords: [\n 'frowning_woman',\n ],\n types: [\n '🙍🏿‍♀️',\n '🙍🏾‍♀️',\n '🙍🏽‍♀️',\n '🙍🏼‍♀️',\n '🙍🏻‍♀️',\n ],\n },\n {\n name: 'pouting_face',\n code: '🙎',\n keywords: [\n 'pouting_face',\n 'gesture',\n 'pouting',\n ],\n types: [\n '🙎🏿',\n '🙎🏾',\n '🙎🏽',\n '🙎🏼',\n '🙎🏻',\n ],\n },\n {\n name: 'pouting_man',\n code: '🙎‍♂️',\n keywords: [\n 'pouting_man',\n ],\n types: [\n '🙎🏿‍♂️',\n '🙎🏾‍♂️',\n '🙎🏽‍♂️',\n '🙎🏼‍♂️',\n '🙎🏻‍♂️',\n ],\n },\n {\n name: 'pouting_woman',\n code: '🙎‍♀️',\n keywords: [\n 'pouting_woman',\n ],\n types: [\n '🙎🏿‍♀️',\n '🙎🏾‍♀️',\n '🙎🏽‍♀️',\n '🙎🏼‍♀️',\n '🙎🏻‍♀️',\n ],\n },\n {\n name: 'no_good',\n code: '🙅',\n keywords: [\n 'stop',\n 'halt',\n 'denied',\n 'no_good',\n 'forbidden',\n 'gesture',\n 'hand',\n 'no',\n 'not',\n 'prohibited',\n ],\n types: [\n '🙅🏿',\n '🙅🏾',\n '🙅🏽',\n '🙅🏼',\n '🙅🏻',\n ],\n },\n {\n name: 'no_good_man',\n code: '🙅‍♂️',\n keywords: [\n 'stop',\n 'halt',\n 'denied',\n 'no_good_man',\n 'ng_man',\n ],\n types: [\n '🙅🏿‍♂️',\n '🙅🏾‍♂️',\n '🙅🏽‍♂️',\n '🙅🏼‍♂️',\n '🙅🏻‍♂️',\n ],\n },\n {\n name: 'no_good_woman',\n code: '🙅‍♀️',\n keywords: [\n 'stop',\n 'halt',\n 'denied',\n 'no_good_woman',\n 'ng_woman',\n ],\n types: [\n '🙅🏿‍♀️',\n '🙅🏾‍♀️',\n '🙅🏽‍♀️',\n '🙅🏼‍♀️',\n '🙅🏻‍♀️',\n ],\n },\n {\n name: 'ok_person',\n code: '🙆',\n keywords: [\n 'ok_person',\n 'gesture',\n 'hand',\n 'ok',\n ],\n types: [\n '🙆🏿',\n '🙆🏾',\n '🙆🏽',\n '🙆🏼',\n '🙆🏻',\n ],\n },\n {\n name: 'ok_man',\n code: '🙆‍♂️',\n keywords: [\n 'ok_man',\n ],\n types: [\n '🙆🏿‍♂️',\n '🙆🏾‍♂️',\n '🙆🏽‍♂️',\n '🙆🏼‍♂️',\n '🙆🏻‍♂️',\n ],\n },\n {\n name: 'ok_woman',\n code: '🙆‍♀️',\n keywords: [\n 'ok_woman',\n ],\n types: [\n '🙆🏿‍♀️',\n '🙆🏾‍♀️',\n '🙆🏽‍♀️',\n '🙆🏼‍♀️',\n '🙆🏻‍♀️',\n ],\n },\n {\n name: 'tipping_hand_person',\n code: '💁',\n keywords: [\n 'tipping_hand_person',\n 'information_desk_person',\n 'hand',\n 'help',\n 'information',\n 'sassy',\n ],\n types: [\n '💁🏿',\n '💁🏾',\n '💁🏽',\n '💁🏼',\n '💁🏻',\n ],\n },\n {\n name: 'tipping_hand_man',\n code: '💁‍♂️',\n keywords: [\n 'information',\n 'tipping_hand_man',\n 'sassy_man',\n ],\n types: [\n '💁🏿‍♂️',\n '💁🏾‍♂️',\n '💁🏽‍♂️',\n '💁🏼‍♂️',\n '💁🏻‍♂️',\n ],\n },\n {\n name: 'tipping_hand_woman',\n code: '💁‍♀️',\n keywords: [\n 'information',\n 'tipping_hand_woman',\n 'sassy_woman',\n ],\n types: [\n '💁🏿‍♀️',\n '💁🏾‍♀️',\n '💁🏽‍♀️',\n '💁🏼‍♀️',\n '💁🏻‍♀️',\n ],\n },\n {\n name: 'raising_hand',\n code: '🙋',\n keywords: [\n 'raising_hand',\n 'gesture',\n 'hand',\n 'happy',\n 'raised',\n ],\n types: [\n '🙋🏿',\n '🙋🏾',\n '🙋🏽',\n '🙋🏼',\n '🙋🏻',\n ],\n },\n {\n name: 'raising_hand_man',\n code: '🙋‍♂️',\n keywords: [\n 'raising_hand_man',\n ],\n types: [\n '🙋🏿‍♂️',\n '🙋🏾‍♂️',\n '🙋🏽‍♂️',\n '🙋🏼‍♂️',\n '🙋🏻‍♂️',\n ],\n },\n {\n name: 'raising_hand_woman',\n code: '🙋‍♀️',\n keywords: [\n 'raising_hand_woman',\n ],\n types: [\n '🙋🏿‍♀️',\n '🙋🏾‍♀️',\n '🙋🏽‍♀️',\n '🙋🏼‍♀️',\n '🙋🏻‍♀️',\n ],\n },\n {\n name: 'deaf_person',\n code: '🧏',\n keywords: [\n 'deaf_person',\n ],\n types: [\n '🧏🏿',\n '🧏🏾',\n '🧏🏽',\n '🧏🏼',\n '🧏🏻',\n ],\n },\n {\n name: 'deaf_man',\n code: '🧏‍♂️',\n keywords: [\n 'deaf_man',\n ],\n types: [\n '🧏🏿‍♂️',\n '🧏🏾‍♂️',\n '🧏🏽‍♂️',\n '🧏🏼‍♂️',\n '🧏🏻‍♂️',\n ],\n },\n {\n name: 'deaf_woman',\n code: '🧏‍♀️',\n keywords: [\n 'deaf_woman',\n ],\n types: [\n '🧏🏿‍♀️',\n '🧏🏾‍♀️',\n '🧏🏽‍♀️',\n '🧏🏼‍♀️',\n '🧏🏻‍♀️',\n ],\n },\n {\n name: 'bow',\n code: '🙇',\n keywords: [\n 'respect',\n 'thanks',\n 'bow',\n 'apology',\n 'gesture',\n 'sorry',\n ],\n types: [\n '🙇🏿',\n '🙇🏾',\n '🙇🏽',\n '🙇🏼',\n '🙇🏻',\n ],\n },\n {\n name: 'bowing_man',\n code: '🙇‍♂️',\n keywords: [\n 'respect',\n 'thanks',\n 'bowing_man',\n ],\n types: [\n '🙇🏿‍♂️',\n '🙇🏾‍♂️',\n '🙇🏽‍♂️',\n '🙇🏼‍♂️',\n '🙇🏻‍♂️',\n ],\n },\n {\n name: 'bowing_woman',\n code: '🙇‍♀️',\n keywords: [\n 'respect',\n 'thanks',\n 'bowing_woman',\n ],\n types: [\n '🙇🏿‍♀️',\n '🙇🏾‍♀️',\n '🙇🏽‍♀️',\n '🙇🏼‍♀️',\n '🙇🏻‍♀️',\n ],\n },\n {\n name: 'facepalm',\n code: '🤦',\n keywords: [\n 'facepalm',\n 'disbelief',\n 'exasperation',\n 'face',\n 'palm',\n ],\n types: [\n '🤦🏿',\n '🤦🏾',\n '🤦🏽',\n '🤦🏼',\n '🤦🏻',\n ],\n },\n {\n name: 'man_facepalming',\n code: '🤦‍♂️',\n keywords: [\n 'man_facepalming',\n ],\n types: [\n '🤦🏿‍♂️',\n '🤦🏾‍♂️',\n '🤦🏽‍♂️',\n '🤦🏼‍♂️',\n '🤦🏻‍♂️',\n ],\n },\n {\n name: 'woman_facepalming',\n code: '🤦‍♀️',\n keywords: [\n 'woman_facepalming',\n ],\n types: [\n '🤦🏿‍♀️',\n '🤦🏾‍♀️',\n '🤦🏽‍♀️',\n '🤦🏼‍♀️',\n '🤦🏻‍♀️',\n ],\n },\n {\n name: 'shrug',\n code: '🤷',\n keywords: [\n 'shrug',\n 'doubt',\n 'ignorance',\n 'indifference',\n ],\n types: [\n '🤷🏿',\n '🤷🏾',\n '🤷🏽',\n '🤷🏼',\n '🤷🏻',\n ],\n },\n {\n name: 'man_shrugging',\n code: '🤷‍♂️',\n keywords: [\n 'man_shrugging',\n ],\n types: [\n '🤷🏿‍♂️',\n '🤷🏾‍♂️',\n '🤷🏽‍♂️',\n '🤷🏼‍♂️',\n '🤷🏻‍♂️',\n ],\n },\n {\n name: 'woman_shrugging',\n code: '🤷‍♀️',\n keywords: [\n 'woman_shrugging',\n ],\n types: [\n '🤷🏿‍♀️',\n '🤷🏾‍♀️',\n '🤷🏽‍♀️',\n '🤷🏼‍♀️',\n '🤷🏻‍♀️',\n ],\n },\n {\n name: 'health_worker',\n code: '🧑‍⚕️',\n keywords: [\n 'health_worker',\n ],\n types: [\n '🧑🏿‍⚕️',\n '🧑🏾‍⚕️',\n '🧑🏽‍⚕️',\n '🧑🏼‍⚕️',\n '🧑🏻‍⚕️',\n ],\n },\n {\n name: 'man_health_worker',\n code: '👨‍⚕️',\n keywords: [\n 'doctor',\n 'nurse',\n 'man_health_worker',\n ],\n types: [\n '👨🏿‍⚕️',\n '👨🏾‍⚕️',\n '👨🏽‍⚕️',\n '👨🏼‍⚕️',\n '👨🏻‍⚕️',\n ],\n },\n {\n name: 'woman_health_worker',\n code: '👩‍⚕️',\n keywords: [\n 'doctor',\n 'nurse',\n 'woman_health_worker',\n ],\n types: [\n '👩🏿‍⚕️',\n '👩🏾‍⚕️',\n '👩🏽‍⚕️',\n '👩🏼‍⚕️',\n '👩🏻‍⚕️',\n ],\n },\n {\n name: 'student',\n code: '🧑‍🎓',\n keywords: [\n 'student',\n ],\n types: [\n '🧑🏿‍🎓',\n '🧑🏾‍🎓',\n '🧑🏽‍🎓',\n '🧑🏼‍🎓',\n '🧑🏻‍🎓',\n ],\n },\n {\n name: 'man_student',\n code: '👨‍🎓',\n keywords: [\n 'graduation',\n 'man_student',\n ],\n types: [\n '👨🏿‍🎓',\n '👨🏾‍🎓',\n '👨🏽‍🎓',\n '👨🏼‍🎓',\n '👨🏻‍🎓',\n ],\n },\n {\n name: 'woman_student',\n code: '👩‍🎓',\n keywords: [\n 'graduation',\n 'woman_student',\n ],\n types: [\n '👩🏿‍🎓',\n '👩🏾‍🎓',\n '👩🏽‍🎓',\n '👩🏼‍🎓',\n '👩🏻‍🎓',\n ],\n },\n {\n name: 'teacher',\n code: '🧑‍🏫',\n keywords: [\n 'teacher',\n ],\n types: [\n '🧑🏿‍🏫',\n '🧑🏾‍🏫',\n '🧑🏽‍🏫',\n '🧑🏼‍🏫',\n '🧑🏻‍🏫',\n ],\n },\n {\n name: 'man_teacher',\n code: '👨‍🏫',\n keywords: [\n 'school',\n 'professor',\n 'man_teacher',\n ],\n types: [\n '👨🏿‍🏫',\n '👨🏾‍🏫',\n '👨🏽‍🏫',\n '👨🏼‍🏫',\n '👨🏻‍🏫',\n ],\n },\n {\n name: 'woman_teacher',\n code: '👩‍🏫',\n keywords: [\n 'school',\n 'professor',\n 'woman_teacher',\n ],\n types: [\n '👩🏿‍🏫',\n '👩🏾‍🏫',\n '👩🏽‍🏫',\n '👩🏼‍🏫',\n '👩🏻‍🏫',\n ],\n },\n {\n name: 'judge',\n code: '🧑‍⚖️',\n keywords: [\n 'judge',\n ],\n types: [\n '🧑🏿‍⚖️',\n '🧑🏾‍⚖️',\n '🧑🏽‍⚖️',\n '🧑🏼‍⚖️',\n '🧑🏻‍⚖️',\n ],\n },\n {\n name: 'man_judge',\n code: '👨‍⚖️',\n keywords: [\n 'justice',\n 'man_judge',\n ],\n types: [\n '👨🏿‍⚖️',\n '👨🏾‍⚖️',\n '👨🏽‍⚖️',\n '👨🏼‍⚖️',\n '👨🏻‍⚖️',\n ],\n },\n {\n name: 'woman_judge',\n code: '👩‍⚖️',\n keywords: [\n 'justice',\n 'woman_judge',\n ],\n types: [\n '👩🏿‍⚖️',\n '👩🏾‍⚖️',\n '👩🏽‍⚖️',\n '👩🏼‍⚖️',\n '👩🏻‍⚖️',\n ],\n },\n {\n name: 'farmer',\n code: '🧑‍🌾',\n keywords: [\n 'farmer',\n ],\n types: [\n '🧑🏿‍🌾',\n '🧑🏾‍🌾',\n '🧑🏽‍🌾',\n '🧑🏼‍🌾',\n '🧑🏻‍🌾',\n ],\n },\n {\n name: 'man_farmer',\n code: '👨‍🌾',\n keywords: [\n 'man_farmer',\n ],\n types: [\n '👨🏿‍🌾',\n '👨🏾‍🌾',\n '👨🏽‍🌾',\n '👨🏼‍🌾',\n '👨🏻‍🌾',\n ],\n },\n {\n name: 'woman_farmer',\n code: '👩‍🌾',\n keywords: [\n 'woman_farmer',\n ],\n types: [\n '👩🏿‍🌾',\n '👩🏾‍🌾',\n '👩🏽‍🌾',\n '👩🏼‍🌾',\n '👩🏻‍🌾',\n ],\n },\n {\n name: 'cook',\n code: '🧑‍🍳',\n keywords: [\n 'cook',\n ],\n types: [\n '🧑🏿‍🍳',\n '🧑🏾‍🍳',\n '🧑🏽‍🍳',\n '🧑🏼‍🍳',\n '🧑🏻‍🍳',\n ],\n },\n {\n name: 'man_cook',\n code: '👨‍🍳',\n keywords: [\n 'chef',\n 'man_cook',\n ],\n types: [\n '👨🏿‍🍳',\n '👨🏾‍🍳',\n '👨🏽‍🍳',\n '👨🏼‍🍳',\n '👨🏻‍🍳',\n ],\n },\n {\n name: 'woman_cook',\n code: '👩‍🍳',\n keywords: [\n 'chef',\n 'woman_cook',\n ],\n types: [\n '👩🏿‍🍳',\n '👩🏾‍🍳',\n '👩🏽‍🍳',\n '👩🏼‍🍳',\n '👩🏻‍🍳',\n ],\n },\n {\n name: 'mechanic',\n code: '🧑‍🔧',\n keywords: [\n 'mechanic',\n ],\n types: [\n '🧑🏿‍🔧',\n '🧑🏾‍🔧',\n '🧑🏽‍🔧',\n '🧑🏼‍🔧',\n '🧑🏻‍🔧',\n ],\n },\n {\n name: 'man_mechanic',\n code: '👨‍🔧',\n keywords: [\n 'man_mechanic',\n ],\n types: [\n '👨🏿‍🔧',\n '👨🏾‍🔧',\n '👨🏽‍🔧',\n '👨🏼‍🔧',\n '👨🏻‍🔧',\n ],\n },\n {\n name: 'woman_mechanic',\n code: '👩‍🔧',\n keywords: [\n 'woman_mechanic',\n ],\n types: [\n '👩🏿‍🔧',\n '👩🏾‍🔧',\n '👩🏽‍🔧',\n '👩🏼‍🔧',\n '👩🏻‍🔧',\n ],\n },\n {\n name: 'factory_worker',\n code: '🧑‍🏭',\n keywords: [\n 'factory_worker',\n ],\n types: [\n '🧑🏿‍🏭',\n '🧑🏾‍🏭',\n '🧑🏽‍🏭',\n '🧑🏼‍🏭',\n '🧑🏻‍🏭',\n ],\n },\n {\n name: 'man_factory_worker',\n code: '👨‍🏭',\n keywords: [\n 'man_factory_worker',\n ],\n types: [\n '👨🏿‍🏭',\n '👨🏾‍🏭',\n '👨🏽‍🏭',\n '👨🏼‍🏭',\n '👨🏻‍🏭',\n ],\n },\n {\n name: 'woman_factory_worker',\n code: '👩‍🏭',\n keywords: [\n 'woman_factory_worker',\n ],\n types: [\n '👩🏿‍🏭',\n '👩🏾‍🏭',\n '👩🏽‍🏭',\n '👩🏼‍🏭',\n '👩🏻‍🏭',\n ],\n },\n {\n name: 'office_worker',\n code: '🧑‍💼',\n keywords: [\n 'office_worker',\n ],\n types: [\n '🧑🏿‍💼',\n '🧑🏾‍💼',\n '🧑🏽‍💼',\n '🧑🏼‍💼',\n '🧑🏻‍💼',\n ],\n },\n {\n name: 'man_office_worker',\n code: '👨‍💼',\n keywords: [\n 'business',\n 'man_office_worker',\n ],\n types: [\n '👨🏿‍💼',\n '👨🏾‍💼',\n '👨🏽‍💼',\n '👨🏼‍💼',\n '👨🏻‍💼',\n ],\n },\n {\n name: 'woman_office_worker',\n code: '👩‍💼',\n keywords: [\n 'business',\n 'woman_office_worker',\n ],\n types: [\n '👩🏿‍💼',\n '👩🏾‍💼',\n '👩🏽‍💼',\n '👩🏼‍💼',\n '👩🏻‍💼',\n ],\n },\n {\n name: 'scientist',\n code: '🧑‍🔬',\n keywords: [\n 'scientist',\n ],\n types: [\n '🧑🏿‍🔬',\n '🧑🏾‍🔬',\n '🧑🏽‍🔬',\n '🧑🏼‍🔬',\n '🧑🏻‍🔬',\n ],\n },\n {\n name: 'man_scientist',\n code: '👨‍🔬',\n keywords: [\n 'research',\n 'man_scientist',\n ],\n types: [\n '👨🏿‍🔬',\n '👨🏾‍🔬',\n '👨🏽‍🔬',\n '👨🏼‍🔬',\n '👨🏻‍🔬',\n ],\n },\n {\n name: 'woman_scientist',\n code: '👩‍🔬',\n keywords: [\n 'research',\n 'woman_scientist',\n ],\n types: [\n '👩🏿‍🔬',\n '👩🏾‍🔬',\n '👩🏽‍🔬',\n '👩🏼‍🔬',\n '👩🏻‍🔬',\n ],\n },\n {\n name: 'technologist',\n code: '🧑‍💻',\n keywords: [\n 'technologist',\n ],\n types: [\n '🧑🏿‍💻',\n '🧑🏾‍💻',\n '🧑🏽‍💻',\n '🧑🏼‍💻',\n '🧑🏻‍💻',\n ],\n },\n {\n name: 'man_technologist',\n code: '👨‍💻',\n keywords: [\n 'coder',\n 'man_technologist',\n ],\n types: [\n '👨🏿‍💻',\n '👨🏾‍💻',\n '👨🏽‍💻',\n '👨🏼‍💻',\n '👨🏻‍💻',\n ],\n },\n {\n name: 'woman_technologist',\n code: '👩‍💻',\n keywords: [\n 'coder',\n 'woman_technologist',\n ],\n types: [\n '👩🏿‍💻',\n '👩🏾‍💻',\n '👩🏽‍💻',\n '👩🏼‍💻',\n '👩🏻‍💻',\n ],\n },\n {\n name: 'singer',\n code: '🧑‍🎤',\n keywords: [\n 'singer',\n ],\n types: [\n '🧑🏿‍🎤',\n '🧑🏾‍🎤',\n '🧑🏽‍🎤',\n '🧑🏼‍🎤',\n '🧑🏻‍🎤',\n ],\n },\n {\n name: 'man_singer',\n code: '👨‍🎤',\n keywords: [\n 'rockstar',\n 'man_singer',\n ],\n types: [\n '👨🏿‍🎤',\n '👨🏾‍🎤',\n '👨🏽‍🎤',\n '👨🏼‍🎤',\n '👨🏻‍🎤',\n ],\n },\n {\n name: 'woman_singer',\n code: '👩‍🎤',\n keywords: [\n 'rockstar',\n 'woman_singer',\n ],\n types: [\n '👩🏿‍🎤',\n '👩🏾‍🎤',\n '👩🏽‍🎤',\n '👩🏼‍🎤',\n '👩🏻‍🎤',\n ],\n },\n {\n name: 'artist',\n code: '🧑‍🎨',\n keywords: [\n 'artist',\n ],\n types: [\n '🧑🏿‍🎨',\n '🧑🏾‍🎨',\n '🧑🏽‍🎨',\n '🧑🏼‍🎨',\n '🧑🏻‍🎨',\n ],\n },\n {\n name: 'man_artist',\n code: '👨‍🎨',\n keywords: [\n 'painter',\n 'man_artist',\n ],\n types: [\n '👨🏿‍🎨',\n '👨🏾‍🎨',\n '👨🏽‍🎨',\n '👨🏼‍🎨',\n '👨🏻‍🎨',\n ],\n },\n {\n name: 'woman_artist',\n code: '👩‍🎨',\n keywords: [\n 'painter',\n 'woman_artist',\n ],\n types: [\n '👩🏿‍🎨',\n '👩🏾‍🎨',\n '👩🏽‍🎨',\n '👩🏼‍🎨',\n '👩🏻‍🎨',\n ],\n },\n {\n name: 'pilot',\n code: '🧑‍✈️',\n keywords: [\n 'pilot',\n ],\n types: [\n '🧑🏿‍✈️',\n '🧑🏾‍✈️',\n '🧑🏽‍✈️',\n '🧑🏼‍✈️',\n '🧑🏻‍✈️',\n ],\n },\n {\n name: 'man_pilot',\n code: '👨‍✈️',\n keywords: [\n 'man_pilot',\n ],\n types: [\n '👨🏿‍✈️',\n '👨🏾‍✈️',\n '👨🏽‍✈️',\n '👨🏼‍✈️',\n '👨🏻‍✈️',\n ],\n },\n {\n name: 'woman_pilot',\n code: '👩‍✈️',\n keywords: [\n 'woman_pilot',\n ],\n types: [\n '👩🏿‍✈️',\n '👩🏾‍✈️',\n '👩🏽‍✈️',\n '👩🏼‍✈️',\n '👩🏻‍✈️',\n ],\n },\n {\n name: 'astronaut',\n code: '🧑‍🚀',\n keywords: [\n 'astronaut',\n ],\n types: [\n '🧑🏿‍🚀',\n '🧑🏾‍🚀',\n '🧑🏽‍🚀',\n '🧑🏼‍🚀',\n '🧑🏻‍🚀',\n ],\n },\n {\n name: 'man_astronaut',\n code: '👨‍🚀',\n keywords: [\n 'space',\n 'man_astronaut',\n ],\n types: [\n '👨🏿‍🚀',\n '👨🏾‍🚀',\n '👨🏽‍🚀',\n '👨🏼‍🚀',\n '👨🏻‍🚀',\n ],\n },\n {\n name: 'woman_astronaut',\n code: '👩‍🚀',\n keywords: [\n 'space',\n 'woman_astronaut',\n ],\n types: [\n '👩🏿‍🚀',\n '👩🏾‍🚀',\n '👩🏽‍🚀',\n '👩🏼‍🚀',\n '👩🏻‍🚀',\n ],\n },\n {\n name: 'firefighter',\n code: '🧑‍🚒',\n keywords: [\n 'firefighter',\n ],\n types: [\n '🧑🏿‍🚒',\n '🧑🏾‍🚒',\n '🧑🏽‍🚒',\n '🧑🏼‍🚒',\n '🧑🏻‍🚒',\n ],\n },\n {\n name: 'man_firefighter',\n code: '👨‍🚒',\n keywords: [\n 'man_firefighter',\n ],\n types: [\n '👨🏿‍🚒',\n '👨🏾‍🚒',\n '👨🏽‍🚒',\n '👨🏼‍🚒',\n '👨🏻‍🚒',\n ],\n },\n {\n name: 'woman_firefighter',\n code: '👩‍🚒',\n keywords: [\n 'woman_firefighter',\n ],\n types: [\n '👩🏿‍🚒',\n '👩🏾‍🚒',\n '👩🏽‍🚒',\n '👩🏼‍🚒',\n '👩🏻‍🚒',\n ],\n },\n {\n name: 'police_officer',\n code: '👮',\n keywords: [\n 'law',\n 'police_officer',\n 'cop',\n 'officer',\n 'police',\n ],\n types: [\n '👮🏿',\n '👮🏾',\n '👮🏽',\n '👮🏼',\n '👮🏻',\n ],\n },\n {\n name: 'policeman',\n code: '👮‍♂️',\n keywords: [\n 'law',\n 'cop',\n 'policeman',\n ],\n types: [\n '👮🏿‍♂️',\n '👮🏾‍♂️',\n '👮🏽‍♂️',\n '👮🏼‍♂️',\n '👮🏻‍♂️',\n ],\n },\n {\n name: 'policewoman',\n code: '👮‍♀️',\n keywords: [\n 'law',\n 'cop',\n 'policewoman',\n ],\n types: [\n '👮🏿‍♀️',\n '👮🏾‍♀️',\n '👮🏽‍♀️',\n '👮🏼‍♀️',\n '👮🏻‍♀️',\n ],\n },\n {\n name: 'detective',\n code: '🕵️',\n keywords: [\n 'sleuth',\n 'detective',\n ],\n types: [\n '🕵🏿',\n '🕵🏾',\n '🕵🏽',\n '🕵🏼',\n '🕵🏻',\n ],\n },\n {\n name: 'male_detective',\n code: '🕵️‍♂️',\n keywords: [\n 'sleuth',\n 'male_detective',\n ],\n types: [\n '🕵🏿‍♂️',\n '🕵🏾‍♂️',\n '🕵🏽‍♂️',\n '🕵🏼‍♂️',\n '🕵🏻‍♂️',\n ],\n },\n {\n name: 'female_detective',\n code: '🕵️‍♀️',\n keywords: [\n 'sleuth',\n 'female_detective',\n ],\n types: [\n '🕵🏿‍♀️',\n '🕵🏾‍♀️',\n '🕵🏽‍♀️',\n '🕵🏼‍♀️',\n '🕵🏻‍♀️',\n ],\n },\n {\n name: 'guard',\n code: '💂',\n keywords: [\n 'guard',\n 'guardsman',\n ],\n types: [\n '💂🏿',\n '💂🏾',\n '💂🏽',\n '💂🏼',\n '💂🏻',\n ],\n },\n {\n name: 'guardsman',\n code: '💂‍♂️',\n keywords: [\n 'guardsman',\n ],\n types: [\n '💂🏿‍♂️',\n '💂🏾‍♂️',\n '💂🏽‍♂️',\n '💂🏼‍♂️',\n '💂🏻‍♂️',\n ],\n },\n {\n name: 'guardswoman',\n code: '💂‍♀️',\n keywords: [\n 'guardswoman',\n ],\n types: [\n '💂🏿‍♀️',\n '💂🏾‍♀️',\n '💂🏽‍♀️',\n '💂🏼‍♀️',\n '💂🏻‍♀️',\n ],\n },\n {\n name: 'ninja',\n code: '🥷',\n keywords: [\n 'ninja',\n ],\n types: [\n '🥷🏿',\n '🥷🏾',\n '🥷🏽',\n '🥷🏼',\n '🥷🏻',\n ],\n },\n {\n name: 'construction_worker',\n code: '👷',\n keywords: [\n 'helmet',\n 'construction_worker',\n 'construction',\n 'hat',\n 'worker',\n ],\n types: [\n '👷🏿',\n '👷🏾',\n '👷🏽',\n '👷🏼',\n '👷🏻',\n ],\n },\n {\n name: 'construction_worker_man',\n code: '👷‍♂️',\n keywords: [\n 'helmet',\n 'construction_worker_man',\n ],\n types: [\n '👷🏿‍♂️',\n '👷🏾‍♂️',\n '👷🏽‍♂️',\n '👷🏼‍♂️',\n '👷🏻‍♂️',\n ],\n },\n {\n name: 'construction_worker_woman',\n code: '👷‍♀️',\n keywords: [\n 'helmet',\n 'construction_worker_woman',\n ],\n types: [\n '👷🏿‍♀️',\n '👷🏾‍♀️',\n '👷🏽‍♀️',\n '👷🏼‍♀️',\n '👷🏻‍♀️',\n ],\n },\n {\n name: 'prince',\n code: '🤴',\n keywords: [\n 'crown',\n 'royal',\n 'prince',\n ],\n types: [\n '🤴🏿',\n '🤴🏾',\n '🤴🏽',\n '🤴🏼',\n '🤴🏻',\n ],\n },\n {\n name: 'princess',\n code: '👸',\n keywords: [\n 'crown',\n 'royal',\n 'princess',\n 'fairy tale',\n 'fantasy',\n ],\n types: [\n '👸🏿',\n '👸🏾',\n '👸🏽',\n '👸🏼',\n '👸🏻',\n ],\n },\n {\n name: 'person_with_turban',\n code: '👳',\n keywords: [\n 'person_with_turban',\n 'man',\n 'turban',\n ],\n types: [\n '👳🏿',\n '👳🏾',\n '👳🏽',\n '👳🏼',\n '👳🏻',\n ],\n },\n {\n name: 'man_with_turban',\n code: '👳‍♂️',\n keywords: [\n 'man_with_turban',\n ],\n types: [\n '👳🏿‍♂️',\n '👳🏾‍♂️',\n '👳🏽‍♂️',\n '👳🏼‍♂️',\n '👳🏻‍♂️',\n ],\n },\n {\n name: 'woman_with_turban',\n code: '👳‍♀️',\n keywords: [\n 'woman_with_turban',\n ],\n types: [\n '👳🏿‍♀️',\n '👳🏾‍♀️',\n '👳🏽‍♀️',\n '👳🏼‍♀️',\n '👳🏻‍♀️',\n ],\n },\n {\n name: 'man_with_gua_pi_mao',\n code: '👲',\n keywords: [\n 'man_with_gua_pi_mao',\n 'gua pi mao',\n 'hat',\n 'man',\n ],\n types: [\n '👲🏿',\n '👲🏾',\n '👲🏽',\n '👲🏼',\n '👲🏻',\n ],\n },\n {\n name: 'woman_with_headscarf',\n code: '🧕',\n keywords: [\n 'hijab',\n 'woman_with_headscarf',\n ],\n types: [\n '🧕🏿',\n '🧕🏾',\n '🧕🏽',\n '🧕🏼',\n '🧕🏻',\n ],\n },\n {\n name: 'person_in_tuxedo',\n code: '🤵',\n keywords: [\n 'groom',\n 'marriage',\n 'wedding',\n 'person_in_tuxedo',\n 'man',\n 'tuxedo',\n ],\n types: [\n '🤵🏿',\n '🤵🏾',\n '🤵🏽',\n '🤵🏼',\n '🤵🏻',\n ],\n },\n {\n name: 'man_in_tuxedo',\n code: '🤵‍♂️',\n keywords: [\n 'man_in_tuxedo',\n ],\n types: [\n '🤵🏿‍♂️',\n '🤵🏾‍♂️',\n '🤵🏽‍♂️',\n '🤵🏼‍♂️',\n '🤵🏻‍♂️',\n ],\n },\n {\n name: 'woman_in_tuxedo',\n code: '🤵‍♀️',\n keywords: [\n 'woman_in_tuxedo',\n ],\n types: [\n '🤵🏿‍♀️',\n '🤵🏾‍♀️',\n '🤵🏽‍♀️',\n '🤵🏼‍♀️',\n '🤵🏻‍♀️',\n ],\n },\n {\n name: 'person_with_veil',\n code: '👰',\n keywords: [\n 'marriage',\n 'wedding',\n 'person_with_veil',\n 'bride',\n 'veil',\n ],\n types: [\n '👰🏿',\n '👰🏾',\n '👰🏽',\n '👰🏼',\n '👰🏻',\n ],\n },\n {\n name: 'man_with_veil',\n code: '👰‍♂️',\n keywords: [\n 'man_with_veil',\n ],\n types: [\n '👰🏿‍♂️',\n '👰🏾‍♂️',\n '👰🏽‍♂️',\n '👰🏼‍♂️',\n '👰🏻‍♂️',\n ],\n },\n {\n name: 'woman_with_veil',\n code: '👰‍♀️',\n keywords: [\n 'woman_with_veil',\n 'bride_with_veil',\n ],\n types: [\n '👰🏿‍♀️',\n '👰🏾‍♀️',\n '👰🏽‍♀️',\n '👰🏼‍♀️',\n '👰🏻‍♀️',\n ],\n },\n {\n name: 'pregnant_woman',\n code: '🤰',\n keywords: [\n 'pregnant_woman',\n 'pregnant',\n 'woman',\n ],\n types: [\n '🤰🏿',\n '🤰🏾',\n '🤰🏽',\n '🤰🏼',\n '🤰🏻',\n ],\n },\n {\n name: 'breast_feeding',\n code: '🤱',\n keywords: [\n 'nursing',\n 'breast_feeding',\n ],\n types: [\n '🤱🏿',\n '🤱🏾',\n '🤱🏽',\n '🤱🏼',\n '🤱🏻',\n ],\n },\n {\n name: 'woman_feeding_baby',\n code: '👩‍🍼',\n keywords: [\n 'woman_feeding_baby',\n ],\n types: [\n '👩🏿‍🍼',\n '👩🏾‍🍼',\n '👩🏽‍🍼',\n '👩🏼‍🍼',\n '👩🏻‍🍼',\n ],\n },\n {\n name: 'man_feeding_baby',\n code: '👨‍🍼',\n keywords: [\n 'man_feeding_baby',\n ],\n types: [\n '👨🏿‍🍼',\n '👨🏾‍🍼',\n '👨🏽‍🍼',\n '👨🏼‍🍼',\n '👨🏻‍🍼',\n ],\n },\n {\n name: 'person_feeding_baby',\n code: '🧑‍🍼',\n keywords: [\n 'person_feeding_baby',\n ],\n types: [\n '🧑🏿‍🍼',\n '🧑🏾‍🍼',\n '🧑🏽‍🍼',\n '🧑🏼‍🍼',\n '🧑🏻‍🍼',\n ],\n },\n {\n name: 'angel',\n code: '👼',\n keywords: [\n 'angel',\n 'baby',\n 'face',\n 'fairy tale',\n 'fantasy',\n ],\n types: [\n '👼🏿',\n '👼🏾',\n '👼🏽',\n '👼🏼',\n '👼🏻',\n ],\n },\n {\n name: 'santa',\n code: '🎅',\n keywords: [\n 'christmas',\n 'santa',\n 'activity',\n 'celebration',\n 'fairy tale',\n 'fantasy',\n 'father',\n ],\n types: [\n '🎅🏿',\n '🎅🏾',\n '🎅🏽',\n '🎅🏼',\n '🎅🏻',\n ],\n },\n {\n name: 'mrs_claus',\n code: '🤶',\n keywords: [\n 'santa',\n 'mrs_claus',\n 'christmas',\n 'mother',\n 'mrs. claus',\n ],\n types: [\n '🤶🏿',\n '🤶🏾',\n '🤶🏽',\n '🤶🏼',\n '🤶🏻',\n ],\n },\n {\n name: 'mx_claus',\n code: '🧑‍🎄',\n keywords: [\n 'mx_claus',\n ],\n types: [\n '🧑🏿‍🎄',\n '🧑🏾‍🎄',\n '🧑🏽‍🎄',\n '🧑🏼‍🎄',\n '🧑🏻‍🎄',\n ],\n },\n {\n name: 'superhero',\n code: '🦸',\n keywords: [\n 'superhero',\n ],\n types: [\n '🦸🏿',\n '🦸🏾',\n '🦸🏽',\n '🦸🏼',\n '🦸🏻',\n ],\n },\n {\n name: 'superhero_man',\n code: '🦸‍♂️',\n keywords: [\n 'superhero_man',\n ],\n types: [\n '🦸🏿‍♂️',\n '🦸🏾‍♂️',\n '🦸🏽‍♂️',\n '🦸🏼‍♂️',\n '🦸🏻‍♂️',\n ],\n },\n {\n name: 'superhero_woman',\n code: '🦸‍♀️',\n keywords: [\n 'superhero_woman',\n ],\n types: [\n '🦸🏿‍♀️',\n '🦸🏾‍♀️',\n '🦸🏽‍♀️',\n '🦸🏼‍♀️',\n '🦸🏻‍♀️',\n ],\n },\n {\n name: 'supervillain',\n code: '🦹',\n keywords: [\n 'supervillain',\n ],\n types: [\n '🦹🏿',\n '🦹🏾',\n '🦹🏽',\n '🦹🏼',\n '🦹🏻',\n ],\n },\n {\n name: 'supervillain_man',\n code: '🦹‍♂️',\n keywords: [\n 'supervillain_man',\n ],\n types: [\n '🦹🏿‍♂️',\n '🦹🏾‍♂️',\n '🦹🏽‍♂️',\n '🦹🏼‍♂️',\n '🦹🏻‍♂️',\n ],\n },\n {\n name: 'supervillain_woman',\n code: '🦹‍♀️',\n keywords: [\n 'supervillain_woman',\n ],\n types: [\n '🦹🏿‍♀️',\n '🦹🏾‍♀️',\n '🦹🏽‍♀️',\n '🦹🏼‍♀️',\n '🦹🏻‍♀️',\n ],\n },\n {\n name: 'mage',\n code: '🧙',\n keywords: [\n 'wizard',\n 'mage',\n ],\n types: [\n '🧙🏿',\n '🧙🏾',\n '🧙🏽',\n '🧙🏼',\n '🧙🏻',\n ],\n },\n {\n name: 'mage_man',\n code: '🧙‍♂️',\n keywords: [\n 'wizard',\n 'mage_man',\n ],\n types: [\n '🧙🏿‍♂️',\n '🧙🏾‍♂️',\n '🧙🏽‍♂️',\n '🧙🏼‍♂️',\n '🧙🏻‍♂️',\n ],\n },\n {\n name: 'mage_woman',\n code: '🧙‍♀️',\n keywords: [\n 'wizard',\n 'mage_woman',\n ],\n types: [\n '🧙🏿‍♀️',\n '🧙🏾‍♀️',\n '🧙🏽‍♀️',\n '🧙🏼‍♀️',\n '🧙🏻‍♀️',\n ],\n },\n {\n name: 'fairy',\n code: '🧚',\n keywords: [\n 'fairy',\n ],\n types: [\n '🧚🏿',\n '🧚🏾',\n '🧚🏽',\n '🧚🏼',\n '🧚🏻',\n ],\n },\n {\n name: 'fairy_man',\n code: '🧚‍♂️',\n keywords: [\n 'fairy_man',\n ],\n types: [\n '🧚🏿‍♂️',\n '🧚🏾‍♂️',\n '🧚🏽‍♂️',\n '🧚🏼‍♂️',\n '🧚🏻‍♂️',\n ],\n },\n {\n name: 'fairy_woman',\n code: '🧚‍♀️',\n keywords: [\n 'fairy_woman',\n ],\n types: [\n '🧚🏿‍♀️',\n '🧚🏾‍♀️',\n '🧚🏽‍♀️',\n '🧚🏼‍♀️',\n '🧚🏻‍♀️',\n ],\n },\n {\n name: 'vampire',\n code: '🧛',\n keywords: [\n 'vampire',\n ],\n types: [\n '🧛🏿',\n '🧛🏾',\n '🧛🏽',\n '🧛🏼',\n '🧛🏻',\n ],\n },\n {\n name: 'vampire_man',\n code: '🧛‍♂️',\n keywords: [\n 'vampire_man',\n ],\n types: [\n '🧛🏿‍♂️',\n '🧛🏾‍♂️',\n '🧛🏽‍♂️',\n '🧛🏼‍♂️',\n '🧛🏻‍♂️',\n ],\n },\n {\n name: 'vampire_woman',\n code: '🧛‍♀️',\n keywords: [\n 'vampire_woman',\n ],\n types: [\n '🧛🏿‍♀️',\n '🧛🏾‍♀️',\n '🧛🏽‍♀️',\n '🧛🏼‍♀️',\n '🧛🏻‍♀️',\n ],\n },\n {\n name: 'merperson',\n code: '🧜',\n keywords: [\n 'merperson',\n ],\n types: [\n '🧜🏿',\n '🧜🏾',\n '🧜🏽',\n '🧜🏼',\n '🧜🏻',\n ],\n },\n {\n name: 'merman',\n code: '🧜‍♂️',\n keywords: [\n 'merman',\n ],\n types: [\n '🧜🏿‍♂️',\n '🧜🏾‍♂️',\n '🧜🏽‍♂️',\n '🧜🏼‍♂️',\n '🧜🏻‍♂️',\n ],\n },\n {\n name: 'mermaid',\n code: '🧜‍♀️',\n keywords: [\n 'mermaid',\n ],\n types: [\n '🧜🏿‍♀️',\n '🧜🏾‍♀️',\n '🧜🏽‍♀️',\n '🧜🏼‍♀️',\n '🧜🏻‍♀️',\n ],\n },\n {\n name: 'elf',\n code: '🧝',\n keywords: [\n 'elf',\n ],\n types: [\n '🧝🏿',\n '🧝🏾',\n '🧝🏽',\n '🧝🏼',\n '🧝🏻',\n ],\n },\n {\n name: 'elf_man',\n code: '🧝‍♂️',\n keywords: [\n 'elf_man',\n ],\n types: [\n '🧝🏿‍♂️',\n '🧝🏾‍♂️',\n '🧝🏽‍♂️',\n '🧝🏼‍♂️',\n '🧝🏻‍♂️',\n ],\n },\n {\n name: 'elf_woman',\n code: '🧝‍♀️',\n keywords: [\n 'elf_woman',\n ],\n types: [\n '🧝🏿‍♀️',\n '🧝🏾‍♀️',\n '🧝🏽‍♀️',\n '🧝🏼‍♀️',\n '🧝🏻‍♀️',\n ],\n },\n {\n name: 'genie',\n code: '🧞',\n keywords: [\n 'genie',\n ],\n },\n {\n name: 'genie_man',\n code: '🧞‍♂️',\n keywords: [\n 'genie_man',\n ],\n },\n {\n name: 'genie_woman',\n code: '🧞‍♀️',\n keywords: [\n 'genie_woman',\n ],\n },\n {\n name: 'zombie',\n code: '🧟',\n keywords: [\n 'zombie',\n ],\n },\n {\n name: 'zombie_man',\n code: '🧟‍♂️',\n keywords: [\n 'zombie_man',\n ],\n },\n {\n name: 'zombie_woman',\n code: '🧟‍♀️',\n keywords: [\n 'zombie_woman',\n ],\n },\n {\n name: 'massage',\n code: '💆',\n keywords: [\n 'spa',\n 'massage',\n 'salon',\n ],\n types: [\n '💆🏿',\n '💆🏾',\n '💆🏽',\n '💆🏼',\n '💆🏻',\n ],\n },\n {\n name: 'massage_man',\n code: '💆‍♂️',\n keywords: [\n 'spa',\n 'massage_man',\n ],\n types: [\n '💆🏿‍♂️',\n '💆🏾‍♂️',\n '💆🏽‍♂️',\n '💆🏼‍♂️',\n '💆🏻‍♂️',\n ],\n },\n {\n name: 'massage_woman',\n code: '💆‍♀️',\n keywords: [\n 'spa',\n 'massage_woman',\n ],\n types: [\n '💆🏿‍♀️',\n '💆🏾‍♀️',\n '💆🏽‍♀️',\n '💆🏼‍♀️',\n '💆🏻‍♀️',\n ],\n },\n {\n name: 'haircut',\n code: '💇',\n keywords: [\n 'beauty',\n 'haircut',\n 'barber',\n 'parlor',\n ],\n types: [\n '💇🏿',\n '💇🏾',\n '💇🏽',\n '💇🏼',\n '💇🏻',\n ],\n },\n {\n name: 'haircut_man',\n code: '💇‍♂️',\n keywords: [\n 'haircut_man',\n ],\n types: [\n '💇🏿‍♂️',\n '💇🏾‍♂️',\n '💇🏽‍♂️',\n '💇🏼‍♂️',\n '💇🏻‍♂️',\n ],\n },\n {\n name: 'haircut_woman',\n code: '💇‍♀️',\n keywords: [\n 'haircut_woman',\n ],\n types: [\n '💇🏿‍♀️',\n '💇🏾‍♀️',\n '💇🏽‍♀️',\n '💇🏼‍♀️',\n '💇🏻‍♀️',\n ],\n },\n {\n name: 'walking',\n code: '🚶',\n keywords: [\n 'walking',\n 'hike',\n 'pedestrian',\n 'walk',\n ],\n types: [\n '🚶🏿',\n '🚶🏾',\n '🚶🏽',\n '🚶🏼',\n '🚶🏻',\n ],\n },\n {\n name: 'walking_man',\n code: '🚶‍♂️',\n keywords: [\n 'walking_man',\n ],\n types: [\n '🚶🏿‍♂️',\n '🚶🏾‍♂️',\n '🚶🏽‍♂️',\n '🚶🏼‍♂️',\n '🚶🏻‍♂️',\n ],\n },\n {\n name: 'walking_woman',\n code: '🚶‍♀️',\n keywords: [\n 'walking_woman',\n ],\n types: [\n '🚶🏿‍♀️',\n '🚶🏾‍♀️',\n '🚶🏽‍♀️',\n '🚶🏼‍♀️',\n '🚶🏻‍♀️',\n ],\n },\n {\n name: 'standing_person',\n code: '🧍',\n keywords: [\n 'standing_person',\n ],\n types: [\n '🧍🏿',\n '🧍🏾',\n '🧍🏽',\n '🧍🏼',\n '🧍🏻',\n ],\n },\n {\n name: 'standing_man',\n code: '🧍‍♂️',\n keywords: [\n 'standing_man',\n ],\n types: [\n '🧍🏿‍♂️',\n '🧍🏾‍♂️',\n '🧍🏽‍♂️',\n '🧍🏼‍♂️',\n '🧍🏻‍♂️',\n ],\n },\n {\n name: 'standing_woman',\n code: '🧍‍♀️',\n keywords: [\n 'standing_woman',\n ],\n types: [\n '🧍🏿‍♀️',\n '🧍🏾‍♀️',\n '🧍🏽‍♀️',\n '🧍🏼‍♀️',\n '🧍🏻‍♀️',\n ],\n },\n {\n name: 'kneeling_person',\n code: '🧎',\n keywords: [\n 'kneeling_person',\n ],\n types: [\n '🧎🏿',\n '🧎🏾',\n '🧎🏽',\n '🧎🏼',\n '🧎🏻',\n ],\n },\n {\n name: 'kneeling_man',\n code: '🧎‍♂️',\n keywords: [\n 'kneeling_man',\n ],\n types: [\n '🧎🏿‍♂️',\n '🧎🏾‍♂️',\n '🧎🏽‍♂️',\n '🧎🏼‍♂️',\n '🧎🏻‍♂️',\n ],\n },\n {\n name: 'kneeling_woman',\n code: '🧎‍♀️',\n keywords: [\n 'kneeling_woman',\n ],\n types: [\n '🧎🏿‍♀️',\n '🧎🏾‍♀️',\n '🧎🏽‍♀️',\n '🧎🏼‍♀️',\n '🧎🏻‍♀️',\n ],\n },\n {\n name: 'person_with_probing_cane',\n code: '🧑‍🦯',\n keywords: [\n 'person_with_probing_cane',\n ],\n types: [\n '🧑🏿‍🦯',\n '🧑🏾‍🦯',\n '🧑🏽‍🦯',\n '🧑🏼‍🦯',\n '🧑🏻‍🦯',\n ],\n },\n {\n name: 'man_with_probing_cane',\n code: '👨‍🦯',\n keywords: [\n 'man_with_probing_cane',\n ],\n types: [\n '👨🏿‍🦯',\n '👨🏾‍🦯',\n '👨🏽‍🦯',\n '👨🏼‍🦯',\n '👨🏻‍🦯',\n ],\n },\n {\n name: 'woman_with_probing_cane',\n code: '👩‍🦯',\n keywords: [\n 'woman_with_probing_cane',\n ],\n types: [\n '👩🏿‍🦯',\n '👩🏾‍🦯',\n '👩🏽‍🦯',\n '👩🏼‍🦯',\n '👩🏻‍🦯',\n ],\n },\n {\n name: 'person_in_motorized_wheelchair',\n code: '🧑‍🦼',\n keywords: [\n 'person_in_motorized_wheelchair',\n ],\n types: [\n '🧑🏿‍🦼',\n '🧑🏾‍🦼',\n '🧑🏽‍🦼',\n '🧑🏼‍🦼',\n '🧑🏻‍🦼',\n ],\n },\n {\n name: 'man_in_motorized_wheelchair',\n code: '👨‍🦼',\n keywords: [\n 'man_in_motorized_wheelchair',\n ],\n types: [\n '👨🏿‍🦼',\n '👨🏾‍🦼',\n '👨🏽‍🦼',\n '👨🏼‍🦼',\n '👨🏻‍🦼',\n ],\n },\n {\n name: 'woman_in_motorized_wheelchair',\n code: '👩‍🦼',\n keywords: [\n 'woman_in_motorized_wheelchair',\n ],\n types: [\n '👩🏿‍🦼',\n '👩🏾‍🦼',\n '👩🏽‍🦼',\n '👩🏼‍🦼',\n '👩🏻‍🦼',\n ],\n },\n {\n name: 'person_in_manual_wheelchair',\n code: '🧑‍🦽',\n keywords: [\n 'person_in_manual_wheelchair',\n ],\n types: [\n '🧑🏿‍🦽',\n '🧑🏾‍🦽',\n '🧑🏽‍🦽',\n '🧑🏼‍🦽',\n '🧑🏻‍🦽',\n ],\n },\n {\n name: 'man_in_manual_wheelchair',\n code: '👨‍🦽',\n keywords: [\n 'man_in_manual_wheelchair',\n ],\n types: [\n '👨🏿‍🦽',\n '👨🏾‍🦽',\n '👨🏽‍🦽',\n '👨🏼‍🦽',\n '👨🏻‍🦽',\n ],\n },\n {\n name: 'woman_in_manual_wheelchair',\n code: '👩‍🦽',\n keywords: [\n 'woman_in_manual_wheelchair',\n ],\n types: [\n '👩🏿‍🦽',\n '👩🏾‍🦽',\n '👩🏽‍🦽',\n '👩🏼‍🦽',\n '👩🏻‍🦽',\n ],\n },\n {\n name: 'runner',\n code: '🏃',\n keywords: [\n 'exercise',\n 'workout',\n 'marathon',\n 'runner',\n 'running',\n ],\n types: [\n '🏃🏿',\n '🏃🏾',\n '🏃🏽',\n '🏃🏼',\n '🏃🏻',\n ],\n },\n {\n name: 'running_man',\n code: '🏃‍♂️',\n keywords: [\n 'exercise',\n 'workout',\n 'marathon',\n 'running_man',\n ],\n types: [\n '🏃🏿‍♂️',\n '🏃🏾‍♂️',\n '🏃🏽‍♂️',\n '🏃🏼‍♂️',\n '🏃🏻‍♂️',\n ],\n },\n {\n name: 'running_woman',\n code: '🏃‍♀️',\n keywords: [\n 'exercise',\n 'workout',\n 'marathon',\n 'running_woman',\n ],\n types: [\n '🏃🏿‍♀️',\n '🏃🏾‍♀️',\n '🏃🏽‍♀️',\n '🏃🏼‍♀️',\n '🏃🏻‍♀️',\n ],\n },\n {\n name: 'woman_dancing',\n code: '💃',\n keywords: [\n 'dress',\n 'woman_dancing',\n 'dancer',\n ],\n types: [\n '💃🏿',\n '💃🏾',\n '💃🏽',\n '💃🏼',\n '💃🏻',\n ],\n },\n {\n name: 'man_dancing',\n code: '🕺',\n keywords: [\n 'dancer',\n 'man_dancing',\n 'dance',\n 'man',\n ],\n types: [\n '🕺🏿',\n '🕺🏾',\n '🕺🏽',\n '🕺🏼',\n '🕺🏻',\n ],\n },\n {\n name: 'business_suit_levitating',\n code: '🕴️',\n keywords: [\n 'business_suit_levitating',\n ],\n types: [\n '🕴🏿',\n '🕴🏾',\n '🕴🏽',\n '🕴🏼',\n '🕴🏻',\n ],\n },\n {\n name: 'dancers',\n code: '👯',\n keywords: [\n 'bunny',\n 'dancers',\n 'dancer',\n 'ear',\n 'girl',\n 'woman',\n ],\n },\n {\n name: 'dancing_men',\n code: '👯‍♂️',\n keywords: [\n 'bunny',\n 'dancing_men',\n ],\n },\n {\n name: 'dancing_women',\n code: '👯‍♀️',\n keywords: [\n 'bunny',\n 'dancing_women',\n ],\n },\n {\n name: 'sauna_person',\n code: '🧖',\n keywords: [\n 'steamy',\n 'sauna_person',\n ],\n types: [\n '🧖🏿',\n '🧖🏾',\n '🧖🏽',\n '🧖🏼',\n '🧖🏻',\n ],\n },\n {\n name: 'sauna_man',\n code: '🧖‍♂️',\n keywords: [\n 'steamy',\n 'sauna_man',\n ],\n types: [\n '🧖🏿‍♂️',\n '🧖🏾‍♂️',\n '🧖🏽‍♂️',\n '🧖🏼‍♂️',\n '🧖🏻‍♂️',\n ],\n },\n {\n name: 'sauna_woman',\n code: '🧖‍♀️',\n keywords: [\n 'steamy',\n 'sauna_woman',\n ],\n types: [\n '🧖🏿‍♀️',\n '🧖🏾‍♀️',\n '🧖🏽‍♀️',\n '🧖🏼‍♀️',\n '🧖🏻‍♀️',\n ],\n },\n {\n name: 'climbing',\n code: '🧗',\n keywords: [\n 'bouldering',\n 'climbing',\n ],\n types: [\n '🧗🏿',\n '🧗🏾',\n '🧗🏽',\n '🧗🏼',\n '🧗🏻',\n ],\n },\n {\n name: 'climbing_man',\n code: '🧗‍♂️',\n keywords: [\n 'bouldering',\n 'climbing_man',\n ],\n types: [\n '🧗🏿‍♂️',\n '🧗🏾‍♂️',\n '🧗🏽‍♂️',\n '🧗🏼‍♂️',\n '🧗🏻‍♂️',\n ],\n },\n {\n name: 'climbing_woman',\n code: '🧗‍♀️',\n keywords: [\n 'bouldering',\n 'climbing_woman',\n ],\n types: [\n '🧗🏿‍♀️',\n '🧗🏾‍♀️',\n '🧗🏽‍♀️',\n '🧗🏼‍♀️',\n '🧗🏻‍♀️',\n ],\n },\n {\n name: 'person_fencing',\n code: '🤺',\n keywords: [\n 'person_fencing',\n 'fencer',\n 'fencing',\n 'sword',\n ],\n },\n {\n name: 'horse_racing',\n code: '🏇',\n keywords: [\n 'horse_racing',\n 'horse',\n 'jockey',\n 'racehorse',\n 'racing',\n ],\n types: [\n '🏇🏿',\n '🏇🏾',\n '🏇🏽',\n '🏇🏼',\n '🏇🏻',\n ],\n },\n {\n name: 'skier',\n code: '⛷️',\n keywords: [\n 'skier',\n ],\n },\n {\n name: 'snowboarder',\n code: '🏂',\n keywords: [\n 'snowboarder',\n 'ski',\n 'snow',\n 'snowboard',\n ],\n types: [\n '🏂🏿',\n '🏂🏾',\n '🏂🏽',\n '🏂🏼',\n '🏂🏻',\n ],\n },\n {\n name: 'golfing',\n code: '🏌️',\n keywords: [\n 'golfing',\n ],\n types: [\n '🏌🏿',\n '🏌🏾',\n '🏌🏽',\n '🏌🏼',\n '🏌🏻',\n ],\n },\n {\n name: 'golfing_man',\n code: '🏌️‍♂️',\n keywords: [\n 'golfing_man',\n ],\n types: [\n '🏌🏿‍♂️',\n '🏌🏾‍♂️',\n '🏌🏽‍♂️',\n '🏌🏼‍♂️',\n '🏌🏻‍♂️',\n ],\n },\n {\n name: 'golfing_woman',\n code: '🏌️‍♀️',\n keywords: [\n 'golfing_woman',\n ],\n types: [\n '🏌🏿‍♀️',\n '🏌🏾‍♀️',\n '🏌🏽‍♀️',\n '🏌🏼‍♀️',\n '🏌🏻‍♀️',\n ],\n },\n {\n name: 'surfer',\n code: '🏄',\n keywords: [\n 'surfer',\n 'surfing',\n ],\n types: [\n '🏄🏿',\n '🏄🏾',\n '🏄🏽',\n '🏄🏼',\n '🏄🏻',\n ],\n },\n {\n name: 'surfing_man',\n code: '🏄‍♂️',\n keywords: [\n 'surfing_man',\n ],\n types: [\n '🏄🏿‍♂️',\n '🏄🏾‍♂️',\n '🏄🏽‍♂️',\n '🏄🏼‍♂️',\n '🏄🏻‍♂️',\n ],\n },\n {\n name: 'surfing_woman',\n code: '🏄‍♀️',\n keywords: [\n 'surfing_woman',\n ],\n types: [\n '🏄🏿‍♀️',\n '🏄🏾‍♀️',\n '🏄🏽‍♀️',\n '🏄🏼‍♀️',\n '🏄🏻‍♀️',\n ],\n },\n {\n name: 'rowboat',\n code: '🚣',\n keywords: [\n 'rowboat',\n 'boat',\n 'vehicle',\n ],\n types: [\n '🚣🏿',\n '🚣🏾',\n '🚣🏽',\n '🚣🏼',\n '🚣🏻',\n ],\n },\n {\n name: 'rowing_man',\n code: '🚣‍♂️',\n keywords: [\n 'rowing_man',\n ],\n types: [\n '🚣🏿‍♂️',\n '🚣🏾‍♂️',\n '🚣🏽‍♂️',\n '🚣🏼‍♂️',\n '🚣🏻‍♂️',\n ],\n },\n {\n name: 'rowing_woman',\n code: '🚣‍♀️',\n keywords: [\n 'rowing_woman',\n ],\n types: [\n '🚣🏿‍♀️',\n '🚣🏾‍♀️',\n '🚣🏽‍♀️',\n '🚣🏼‍♀️',\n '🚣🏻‍♀️',\n ],\n },\n {\n name: 'swimmer',\n code: '🏊',\n keywords: [\n 'swimmer',\n 'swim',\n ],\n types: [\n '🏊🏿',\n '🏊🏾',\n '🏊🏽',\n '🏊🏼',\n '🏊🏻',\n ],\n },\n {\n name: 'swimming_man',\n code: '🏊‍♂️',\n keywords: [\n 'swimming_man',\n ],\n types: [\n '🏊🏿‍♂️',\n '🏊🏾‍♂️',\n '🏊🏽‍♂️',\n '🏊🏼‍♂️',\n '🏊🏻‍♂️',\n ],\n },\n {\n name: 'swimming_woman',\n code: '🏊‍♀️',\n keywords: [\n 'swimming_woman',\n ],\n types: [\n '🏊🏿‍♀️',\n '🏊🏾‍♀️',\n '🏊🏽‍♀️',\n '🏊🏼‍♀️',\n '🏊🏻‍♀️',\n ],\n },\n {\n name: 'bouncing_ball_person',\n code: '⛹️',\n keywords: [\n 'basketball',\n 'bouncing_ball_person',\n ],\n types: [\n '⛹🏿',\n '⛹🏾',\n '⛹🏽',\n '⛹🏼',\n '⛹🏻',\n ],\n },\n {\n name: 'bouncing_ball_man',\n code: '⛹️‍♂️',\n keywords: [\n 'bouncing_ball_man',\n 'basketball_man',\n ],\n types: [\n '⛹🏿‍♂️',\n '⛹🏾‍♂️',\n '⛹🏽‍♂️',\n '⛹🏼‍♂️',\n '⛹🏻‍♂️',\n ],\n },\n {\n name: 'bouncing_ball_woman',\n code: '⛹️‍♀️',\n keywords: [\n 'bouncing_ball_woman',\n 'basketball_woman',\n ],\n types: [\n '⛹🏿‍♀️',\n '⛹🏾‍♀️',\n '⛹🏽‍♀️',\n '⛹🏼‍♀️',\n '⛹🏻‍♀️',\n ],\n },\n {\n name: 'weight_lifting',\n code: '🏋️',\n keywords: [\n 'gym',\n 'workout',\n 'weight_lifting',\n ],\n types: [\n '🏋🏿',\n '🏋🏾',\n '🏋🏽',\n '🏋🏼',\n '🏋🏻',\n ],\n },\n {\n name: 'weight_lifting_man',\n code: '🏋️‍♂️',\n keywords: [\n 'gym',\n 'workout',\n 'weight_lifting_man',\n ],\n types: [\n '🏋🏿‍♂️',\n '🏋🏾‍♂️',\n '🏋🏽‍♂️',\n '🏋🏼‍♂️',\n '🏋🏻‍♂️',\n ],\n },\n {\n name: 'weight_lifting_woman',\n code: '🏋️‍♀️',\n keywords: [\n 'gym',\n 'workout',\n 'weight_lifting_woman',\n ],\n types: [\n '🏋🏿‍♀️',\n '🏋🏾‍♀️',\n '🏋🏽‍♀️',\n '🏋🏼‍♀️',\n '🏋🏻‍♀️',\n ],\n },\n {\n name: 'bicyclist',\n code: '🚴',\n keywords: [\n 'bicyclist',\n 'bicycle',\n 'bike',\n 'cyclist',\n ],\n types: [\n '🚴🏿',\n '🚴🏾',\n '🚴🏽',\n '🚴🏼',\n '🚴🏻',\n ],\n },\n {\n name: 'biking_man',\n code: '🚴‍♂️',\n keywords: [\n 'biking_man',\n ],\n types: [\n '🚴🏿‍♂️',\n '🚴🏾‍♂️',\n '🚴🏽‍♂️',\n '🚴🏼‍♂️',\n '🚴🏻‍♂️',\n ],\n },\n {\n name: 'biking_woman',\n code: '🚴‍♀️',\n keywords: [\n 'biking_woman',\n ],\n types: [\n '🚴🏿‍♀️',\n '🚴🏾‍♀️',\n '🚴🏽‍♀️',\n '🚴🏼‍♀️',\n '🚴🏻‍♀️',\n ],\n },\n {\n name: 'mountain_bicyclist',\n code: '🚵',\n keywords: [\n 'mountain_bicyclist',\n 'bicycle',\n 'bicyclist',\n 'bike',\n 'cyclist',\n 'mountain',\n ],\n types: [\n '🚵🏿',\n '🚵🏾',\n '🚵🏽',\n '🚵🏼',\n '🚵🏻',\n ],\n },\n {\n name: 'mountain_biking_man',\n code: '🚵‍♂️',\n keywords: [\n 'mountain_biking_man',\n ],\n types: [\n '🚵🏿‍♂️',\n '🚵🏾‍♂️',\n '🚵🏽‍♂️',\n '🚵🏼‍♂️',\n '🚵🏻‍♂️',\n ],\n },\n {\n name: 'mountain_biking_woman',\n code: '🚵‍♀️',\n keywords: [\n 'mountain_biking_woman',\n ],\n types: [\n '🚵🏿‍♀️',\n '🚵🏾‍♀️',\n '🚵🏽‍♀️',\n '🚵🏼‍♀️',\n '🚵🏻‍♀️',\n ],\n },\n {\n name: 'cartwheeling',\n code: '🤸',\n keywords: [\n 'cartwheeling',\n 'cartwheel',\n 'gymnastics',\n ],\n types: [\n '🤸🏿',\n '🤸🏾',\n '🤸🏽',\n '🤸🏼',\n '🤸🏻',\n ],\n },\n {\n name: 'man_cartwheeling',\n code: '🤸‍♂️',\n keywords: [\n 'man_cartwheeling',\n ],\n types: [\n '🤸🏿‍♂️',\n '🤸🏾‍♂️',\n '🤸🏽‍♂️',\n '🤸🏼‍♂️',\n '🤸🏻‍♂️',\n ],\n },\n {\n name: 'woman_cartwheeling',\n code: '🤸‍♀️',\n keywords: [\n 'woman_cartwheeling',\n ],\n types: [\n '🤸🏿‍♀️',\n '🤸🏾‍♀️',\n '🤸🏽‍♀️',\n '🤸🏼‍♀️',\n '🤸🏻‍♀️',\n ],\n },\n {\n name: 'wrestling',\n code: '🤼',\n keywords: [\n 'wrestling',\n 'wrestle',\n 'wrestler',\n ],\n },\n {\n name: 'men_wrestling',\n code: '🤼‍♂️',\n keywords: [\n 'men_wrestling',\n ],\n },\n {\n name: 'women_wrestling',\n code: '🤼‍♀️',\n keywords: [\n 'women_wrestling',\n ],\n },\n {\n name: 'water_polo',\n code: '🤽',\n keywords: [\n 'water_polo',\n 'polo',\n 'water',\n ],\n types: [\n '🤽🏿',\n '🤽🏾',\n '🤽🏽',\n '🤽🏼',\n '🤽🏻',\n ],\n },\n {\n name: 'man_playing_water_polo',\n code: '🤽‍♂️',\n keywords: [\n 'man_playing_water_polo',\n ],\n types: [\n '🤽🏿‍♂️',\n '🤽🏾‍♂️',\n '🤽🏽‍♂️',\n '🤽🏼‍♂️',\n '🤽🏻‍♂️',\n ],\n },\n {\n name: 'woman_playing_water_polo',\n code: '🤽‍♀️',\n keywords: [\n 'woman_playing_water_polo',\n ],\n types: [\n '🤽🏿‍♀️',\n '🤽🏾‍♀️',\n '🤽🏽‍♀️',\n '🤽🏼‍♀️',\n '🤽🏻‍♀️',\n ],\n },\n {\n name: 'handball_person',\n code: '🤾',\n keywords: [\n 'handball_person',\n 'ball',\n 'handball',\n ],\n types: [\n '🤾🏿',\n '🤾🏾',\n '🤾🏽',\n '🤾🏼',\n '🤾🏻',\n ],\n },\n {\n name: 'man_playing_handball',\n code: '🤾‍♂️',\n keywords: [\n 'man_playing_handball',\n ],\n types: [\n '🤾🏿‍♂️',\n '🤾🏾‍♂️',\n '🤾🏽‍♂️',\n '🤾🏼‍♂️',\n '🤾🏻‍♂️',\n ],\n },\n {\n name: 'woman_playing_handball',\n code: '🤾‍♀️',\n keywords: [\n 'woman_playing_handball',\n ],\n types: [\n '🤾🏿‍♀️',\n '🤾🏾‍♀️',\n '🤾🏽‍♀️',\n '🤾🏼‍♀️',\n '🤾🏻‍♀️',\n ],\n },\n {\n name: 'juggling_person',\n code: '🤹',\n keywords: [\n 'juggling_person',\n 'balance',\n 'juggle',\n 'multitask',\n 'skill',\n ],\n types: [\n '🤹🏿',\n '🤹🏾',\n '🤹🏽',\n '🤹🏼',\n '🤹🏻',\n ],\n },\n {\n name: 'man_juggling',\n code: '🤹‍♂️',\n keywords: [\n 'man_juggling',\n ],\n types: [\n '🤹🏿‍♂️',\n '🤹🏾‍♂️',\n '🤹🏽‍♂️',\n '🤹🏼‍♂️',\n '🤹🏻‍♂️',\n ],\n },\n {\n name: 'woman_juggling',\n code: '🤹‍♀️',\n keywords: [\n 'woman_juggling',\n ],\n types: [\n '🤹🏿‍♀️',\n '🤹🏾‍♀️',\n '🤹🏽‍♀️',\n '🤹🏼‍♀️',\n '🤹🏻‍♀️',\n ],\n },\n {\n name: 'lotus_position',\n code: '🧘',\n keywords: [\n 'meditation',\n 'lotus_position',\n ],\n types: [\n '🧘🏿',\n '🧘🏾',\n '🧘🏽',\n '🧘🏼',\n '🧘🏻',\n ],\n },\n {\n name: 'lotus_position_man',\n code: '🧘‍♂️',\n keywords: [\n 'meditation',\n 'lotus_position_man',\n ],\n types: [\n '🧘🏿‍♂️',\n '🧘🏾‍♂️',\n '🧘🏽‍♂️',\n '🧘🏼‍♂️',\n '🧘🏻‍♂️',\n ],\n },\n {\n name: 'lotus_position_woman',\n code: '🧘‍♀️',\n keywords: [\n 'meditation',\n 'lotus_position_woman',\n ],\n types: [\n '🧘🏿‍♀️',\n '🧘🏾‍♀️',\n '🧘🏽‍♀️',\n '🧘🏼‍♀️',\n '🧘🏻‍♀️',\n ],\n },\n {\n name: 'bath',\n code: '🛀',\n keywords: [\n 'shower',\n 'bath',\n 'bathtub',\n ],\n types: [\n '🛀🏿',\n '🛀🏾',\n '🛀🏽',\n '🛀🏼',\n '🛀🏻',\n ],\n },\n {\n name: 'sleeping_bed',\n code: '🛌',\n keywords: [\n 'sleeping_bed',\n 'hotel',\n 'sleep',\n ],\n types: [\n '🛌🏿',\n '🛌🏾',\n '🛌🏽',\n '🛌🏼',\n '🛌🏻',\n ],\n },\n {\n name: 'people_holding_hands',\n code: '🧑‍🤝‍🧑',\n keywords: [\n 'couple',\n 'date',\n 'people_holding_hands',\n ],\n types: [\n '🧑🏿‍🤝‍🧑🏿',\n '🧑🏿‍🤝‍🧑🏾',\n '🧑🏿‍🤝‍🧑🏽',\n '🧑🏿‍🤝‍🧑🏼',\n '🧑🏿‍🤝‍🧑🏻',\n '🧑🏾‍🤝‍🧑🏿',\n '🧑🏾‍🤝‍🧑🏾',\n '🧑🏾‍🤝‍🧑🏽',\n '🧑🏾‍🤝‍🧑🏼',\n '🧑🏾‍🤝‍🧑🏻',\n '🧑🏽‍🤝‍🧑🏿',\n '🧑🏽‍🤝‍🧑🏾',\n '🧑🏽‍🤝‍🧑🏽',\n '🧑🏽‍🤝‍🧑🏼',\n '🧑🏽‍🤝‍🧑🏻',\n '🧑🏼‍🤝‍🧑🏿',\n '🧑🏼‍🤝‍🧑🏾',\n '🧑🏼‍🤝‍🧑🏽',\n '🧑🏼‍🤝‍🧑🏼',\n '🧑🏼‍🤝‍🧑🏻',\n '🧑🏻‍🤝‍🧑🏿',\n '🧑🏻‍🤝‍🧑🏾',\n '🧑🏻‍🤝‍🧑🏽',\n '🧑🏻‍🤝‍🧑🏼',\n '🧑🏻‍🤝‍🧑🏻',\n ],\n },\n {\n name: 'two_women_holding_hands',\n code: '👭',\n keywords: [\n 'couple',\n 'date',\n 'two_women_holding_hands',\n 'hand',\n 'hold',\n 'woman',\n ],\n types: [\n '👩🏿‍🤝‍👩🏾',\n '👩🏿‍🤝‍👩🏽',\n '👩🏿‍🤝‍👩🏼',\n '👩🏿‍🤝‍👩🏻',\n '👩🏾‍🤝‍👩🏿',\n '👩🏾‍🤝‍👩🏽',\n '👩🏾‍🤝‍👩🏼',\n '👩🏾‍🤝‍👩🏻',\n '👩🏽‍🤝‍👩🏿',\n '👩🏽‍🤝‍👩🏾',\n '👩🏽‍🤝‍👩🏼',\n '👩🏽‍🤝‍👩🏻',\n '👩🏼‍🤝‍👩🏿',\n '👩🏼‍🤝‍👩🏾',\n '👩🏼‍🤝‍👩🏽',\n '👩🏼‍🤝‍👩🏻',\n '👩🏻‍🤝‍👩🏿',\n '👩🏻‍🤝‍👩🏾',\n '👩🏻‍🤝‍👩🏽',\n '👩🏻‍🤝‍👩🏼',\n '👭🏿',\n '👭🏾',\n '👭🏽',\n '👭🏼',\n '👭🏻',\n ],\n },\n {\n name: 'couple',\n code: '👫',\n keywords: [\n 'date',\n 'couple',\n 'hand',\n 'hold',\n 'man',\n 'woman',\n ],\n types: [\n '👩🏿‍🤝‍👨🏾',\n '👩🏿‍🤝‍👨🏽',\n '👩🏿‍🤝‍👨🏼',\n '👩🏿‍🤝‍👨🏻',\n '👩🏾‍🤝‍👨🏿',\n '👩🏾‍🤝‍👨🏽',\n '👩🏾‍🤝‍👨🏼',\n '👩🏾‍🤝‍👨🏻',\n '👩🏽‍🤝‍👨🏿',\n '👩🏽‍🤝‍👨🏾',\n '👩🏽‍🤝‍👨🏼',\n '👩🏽‍🤝‍👨🏻',\n '👩🏼‍🤝‍👨🏿',\n '👩🏼‍🤝‍👨🏾',\n '👩🏼‍🤝‍👨🏽',\n '👩🏼‍🤝‍👨🏻',\n '👩🏻‍🤝‍👨🏿',\n '👩🏻‍🤝‍👨🏾',\n '👩🏻‍🤝‍👨🏽',\n '👩🏻‍🤝‍👨🏼',\n '👫🏿',\n '👫🏾',\n '👫🏽',\n '👫🏼',\n '👫🏻',\n ],\n },\n {\n name: 'two_men_holding_hands',\n code: '👬',\n keywords: [\n 'couple',\n 'date',\n 'two_men_holding_hands',\n 'gemini',\n 'hand',\n 'hold',\n 'man',\n 'twins',\n 'zodiac',\n ],\n types: [\n '👨🏿‍🤝‍👨🏾',\n '👨🏿‍🤝‍👨🏽',\n '👨🏿‍🤝‍👨🏼',\n '👨🏿‍🤝‍👨🏻',\n '👨🏾‍🤝‍👨🏿',\n '👨🏾‍🤝‍👨🏽',\n '👨🏾‍🤝‍👨🏼',\n '👨🏾‍🤝‍👨🏻',\n '👨🏽‍🤝‍👨🏿',\n '👨🏽‍🤝‍👨🏾',\n '👨🏽‍🤝‍👨🏼',\n '👨🏽‍🤝‍👨🏻',\n '👨🏼‍🤝‍👨🏿',\n '👨🏼‍🤝‍👨🏾',\n '👨🏼‍🤝‍👨🏽',\n '👨🏼‍🤝‍👨🏻',\n '👨🏻‍🤝‍👨🏿',\n '👨🏻‍🤝‍👨🏾',\n '👨🏻‍🤝‍👨🏽',\n '👨🏻‍🤝‍👨🏼',\n '👬🏿',\n '👬🏾',\n '👬🏽',\n '👬🏼',\n '👬🏻',\n ],\n },\n {\n name: 'couplekiss',\n code: '💏',\n keywords: [\n 'couplekiss',\n 'couple',\n 'kiss',\n 'romance',\n ],\n types: [\n '🧑🏿‍❤️‍💋‍🧑🏾',\n '🧑🏿‍❤️‍💋‍🧑🏽',\n '🧑🏿‍❤️‍💋‍🧑🏼',\n '🧑🏿‍❤️‍💋‍🧑🏻',\n '🧑🏾‍❤️‍💋‍🧑🏿',\n '🧑🏾‍❤️‍💋‍🧑🏽',\n '🧑🏾‍❤️‍💋‍🧑🏼',\n '🧑🏾‍❤️‍💋‍🧑🏻',\n '🧑🏽‍❤️‍💋‍🧑🏿',\n '🧑🏽‍❤️‍💋‍🧑🏾',\n '🧑🏽‍❤️‍💋‍🧑🏼',\n '🧑🏽‍❤️‍💋‍🧑🏻',\n '🧑🏼‍❤️‍💋‍🧑🏿',\n '🧑🏼‍❤️‍💋‍🧑🏾',\n '🧑🏼‍❤️‍💋‍🧑🏽',\n '🧑🏼‍❤️‍💋‍🧑🏻',\n '🧑🏻‍❤️‍💋‍🧑🏿',\n '🧑🏻‍❤️‍💋‍🧑🏾',\n '🧑🏻‍❤️‍💋‍🧑🏽',\n '🧑🏻‍❤️‍💋‍🧑🏼',\n '💏🏿',\n '💏🏾',\n '💏🏽',\n '💏🏼',\n '💏🏻',\n ],\n },\n {\n name: 'couplekiss_man_woman',\n code: '👩‍❤️‍💋‍👨',\n keywords: [\n 'couplekiss_man_woman',\n ],\n types: [\n '👩🏿‍❤️‍💋‍👨🏿',\n '👩🏿‍❤️‍💋‍👨🏾',\n '👩🏿‍❤️‍💋‍👨🏽',\n '👩🏿‍❤️‍💋‍👨🏼',\n '👩🏿‍❤️‍💋‍👨🏻',\n '👩🏾‍❤️‍💋‍👨🏿',\n '👩🏾‍❤️‍💋‍👨🏾',\n '👩🏾‍❤️‍💋‍👨🏽',\n '👩🏾‍❤️‍💋‍👨🏼',\n '👩🏾‍❤️‍💋‍👨🏻',\n '👩🏽‍❤️‍💋‍👨🏿',\n '👩🏽‍❤️‍💋‍👨🏾',\n '👩🏽‍❤️‍💋‍👨🏽',\n '👩🏽‍❤️‍💋‍👨🏼',\n '👩🏽‍❤️‍💋‍👨🏻',\n '👩🏼‍❤️‍💋‍👨🏿',\n '👩🏼‍❤️‍💋‍👨🏾',\n '👩🏼‍❤️‍💋‍👨🏽',\n '👩🏼‍❤️‍💋‍👨🏼',\n '👩🏼‍❤️‍💋‍👨🏻',\n '👩🏻‍❤️‍💋‍👨🏿',\n '👩🏻‍❤️‍💋‍👨🏾',\n '👩🏻‍❤️‍💋‍👨🏽',\n '👩🏻‍❤️‍💋‍👨🏼',\n '👩🏻‍❤️‍💋‍👨🏻',\n ],\n },\n {\n name: 'couplekiss_man_man',\n code: '👨‍❤️‍💋‍👨',\n keywords: [\n 'couplekiss_man_man',\n ],\n types: [\n '👨🏿‍❤️‍💋‍👨🏿',\n '👨🏿‍❤️‍💋‍👨🏾',\n '👨🏿‍❤️‍💋‍👨🏽',\n '👨🏿‍❤️‍💋‍👨🏼',\n '👨🏿‍❤️‍💋‍👨🏻',\n '👨🏾‍❤️‍💋‍👨🏿',\n '👨🏾‍❤️‍💋‍👨🏾',\n '👨🏾‍❤️‍💋‍👨🏽',\n '👨🏾‍❤️‍💋‍👨🏼',\n '👨🏾‍❤️‍💋‍👨🏻',\n '👨🏽‍❤️‍💋‍👨🏿',\n '👨🏽‍❤️‍💋‍👨🏾',\n '👨🏽‍❤️‍💋‍👨🏽',\n '👨🏽‍❤️‍💋‍👨🏼',\n '👨🏽‍❤️‍💋‍👨🏻',\n '👨🏼‍❤️‍💋‍👨🏿',\n '👨🏼‍❤️‍💋‍👨🏾',\n '👨🏼‍❤️‍💋‍👨🏽',\n '👨🏼‍❤️‍💋‍👨🏼',\n '👨🏼‍❤️‍💋‍👨🏻',\n '👨🏻‍❤️‍💋‍👨🏿',\n '👨🏻‍❤️‍💋‍👨🏾',\n '👨🏻‍❤️‍💋‍👨🏽',\n '👨🏻‍❤️‍💋‍👨🏼',\n '👨🏻‍❤️‍💋‍👨🏻',\n ],\n },\n {\n name: 'couplekiss_woman_woman',\n code: '👩‍❤️‍💋‍👩',\n keywords: [\n 'couplekiss_woman_woman',\n ],\n types: [\n '👩🏿‍❤️‍💋‍👩🏿',\n '👩🏿‍❤️‍💋‍👩🏾',\n '👩🏿‍❤️‍💋‍👩🏽',\n '👩🏿‍❤️‍💋‍👩🏼',\n '👩🏿‍❤️‍💋‍👩🏻',\n '👩🏾‍❤️‍💋‍👩🏿',\n '👩🏾‍❤️‍💋‍👩🏾',\n '👩🏾‍❤️‍💋‍👩🏽',\n '👩🏾‍❤️‍💋‍👩🏼',\n '👩🏾‍❤️‍💋‍👩🏻',\n '👩🏽‍❤️‍💋‍👩🏿',\n '👩🏽‍❤️‍💋‍👩🏾',\n '👩🏽‍❤️‍💋‍👩🏽',\n '👩🏽‍❤️‍💋‍👩🏼',\n '👩🏽‍❤️‍💋‍👩🏻',\n '👩🏼‍❤️‍💋‍👩🏿',\n '👩🏼‍❤️‍💋‍👩🏾',\n '👩🏼‍❤️‍💋‍👩🏽',\n '👩🏼‍❤️‍💋‍👩🏼',\n '👩🏼‍❤️‍💋‍👩🏻',\n '👩🏻‍❤️‍💋‍👩🏿',\n '👩🏻‍❤️‍💋‍👩🏾',\n '👩🏻‍❤️‍💋‍👩🏽',\n '👩🏻‍❤️‍💋‍👩🏼',\n '👩🏻‍❤️‍💋‍👩🏻',\n ],\n },\n {\n name: 'couple_with_heart',\n code: '💑',\n keywords: [\n 'couple_with_heart',\n 'couple',\n 'heart',\n 'love',\n 'romance',\n ],\n types: [\n '🧑🏿‍❤️‍🧑🏾',\n '🧑🏿‍❤️‍🧑🏽',\n '🧑🏿‍❤️‍🧑🏼',\n '🧑🏿‍❤️‍🧑🏻',\n '🧑🏾‍❤️‍🧑🏿',\n '🧑🏾‍❤️‍🧑🏽',\n '🧑🏾‍❤️‍🧑🏼',\n '🧑🏾‍❤️‍🧑🏻',\n '🧑🏽‍❤️‍🧑🏿',\n '🧑🏽‍❤️‍🧑🏾',\n '🧑🏽‍❤️‍🧑🏼',\n '🧑🏽‍❤️‍🧑🏻',\n '🧑🏼‍❤️‍🧑🏿',\n '🧑🏼‍❤️‍🧑🏾',\n '🧑🏼‍❤️‍🧑🏽',\n '🧑🏼‍❤️‍🧑🏻',\n '🧑🏻‍❤️‍🧑🏿',\n '🧑🏻‍❤️‍🧑🏾',\n '🧑🏻‍❤️‍🧑🏽',\n '🧑🏻‍❤️‍🧑🏼',\n '💑🏿',\n '💑🏾',\n '💑🏽',\n '💑🏼',\n '💑🏻',\n ],\n },\n {\n name: 'couple_with_heart_woman_man',\n code: '👩‍❤️‍👨',\n keywords: [\n 'couple_with_heart_woman_man',\n ],\n types: [\n '👩🏿‍❤️‍👨🏿',\n '👩🏿‍❤️‍👨🏾',\n '👩🏿‍❤️‍👨🏽',\n '👩🏿‍❤️‍👨🏼',\n '👩🏿‍❤️‍👨🏻',\n '👩🏾‍❤️‍👨🏿',\n '👩🏾‍❤️‍👨🏾',\n '👩🏾‍❤️‍👨🏽',\n '👩🏾‍❤️‍👨🏼',\n '👩🏾‍❤️‍👨🏻',\n '👩🏽‍❤️‍👨🏿',\n '👩🏽‍❤️‍👨🏾',\n '👩🏽‍❤️‍👨🏽',\n '👩🏽‍❤️‍👨🏼',\n '👩🏽‍❤️‍👨🏻',\n '👩🏼‍❤️‍👨🏿',\n '👩🏼‍❤️‍👨🏾',\n '👩🏼‍❤️‍👨🏽',\n '👩🏼‍❤️‍👨🏼',\n '👩🏼‍❤️‍👨🏻',\n '👩🏻‍❤️‍👨🏿',\n '👩🏻‍❤️‍👨🏾',\n '👩🏻‍❤️‍👨🏽',\n '👩🏻‍❤️‍👨🏼',\n '👩🏻‍❤️‍👨🏻',\n ],\n },\n {\n name: 'couple_with_heart_man_man',\n code: '👨‍❤️‍👨',\n keywords: [\n 'couple_with_heart_man_man',\n ],\n types: [\n '👨🏿‍❤️‍👨🏿',\n '👨🏿‍❤️‍👨🏾',\n '👨🏿‍❤️‍👨🏽',\n '👨🏿‍❤️‍👨🏼',\n '👨🏿‍❤️‍👨🏻',\n '👨🏾‍❤️‍👨🏿',\n '👨🏾‍❤️‍👨🏾',\n '👨🏾‍❤️‍👨🏽',\n '👨🏾‍❤️‍👨🏼',\n '👨🏾‍❤️‍👨🏻',\n '👨🏽‍❤️‍👨🏿',\n '👨🏽‍❤️‍👨🏾',\n '👨🏽‍❤️‍👨🏽',\n '👨🏽‍❤️‍👨🏼',\n '👨🏽‍❤️‍👨🏻',\n '👨🏼‍❤️‍👨🏿',\n '👨🏼‍❤️‍👨🏾',\n '👨🏼‍❤️‍👨🏽',\n '👨🏼‍❤️‍👨🏼',\n '👨🏼‍❤️‍👨🏻',\n '👨🏻‍❤️‍👨🏿',\n '👨🏻‍❤️‍👨🏾',\n '👨🏻‍❤️‍👨🏽',\n '👨🏻‍❤️‍👨🏼',\n '👨🏻‍❤️‍👨🏻',\n ],\n },\n {\n name: 'couple_with_heart_woman_woman',\n code: '👩‍❤️‍👩',\n keywords: [\n 'couple_with_heart_woman_woman',\n ],\n types: [\n '👩🏿‍❤️‍👩🏿',\n '👩🏿‍❤️‍👩🏾',\n '👩🏿‍❤️‍👩🏽',\n '👩🏿‍❤️‍👩🏼',\n '👩🏿‍❤️‍👩🏻',\n '👩🏾‍❤️‍👩🏿',\n '👩🏾‍❤️‍👩🏾',\n '👩🏾‍❤️‍👩🏽',\n '👩🏾‍❤️‍👩🏼',\n '👩🏾‍❤️‍👩🏻',\n '👩🏽‍❤️‍👩🏿',\n '👩🏽‍❤️‍👩🏾',\n '👩🏽‍❤️‍👩🏽',\n '👩🏽‍❤️‍👩🏼',\n '👩🏽‍❤️‍👩🏻',\n '👩🏼‍❤️‍👩🏿',\n '👩🏼‍❤️‍👩🏾',\n '👩🏼‍❤️‍👩🏽',\n '👩🏼‍❤️‍👩🏼',\n '👩🏼‍❤️‍👩🏻',\n '👩🏻‍❤️‍👩🏿',\n '👩🏻‍❤️‍👩🏾',\n '👩🏻‍❤️‍👩🏽',\n '👩🏻‍❤️‍👩🏼',\n '👩🏻‍❤️‍👩🏻',\n ],\n },\n {\n name: 'family',\n code: '👪',\n keywords: [\n 'home',\n 'parents',\n 'child',\n 'family',\n 'father',\n 'mother',\n ],\n },\n {\n name: 'family_man_woman_boy',\n code: '👨‍👩‍👦',\n keywords: [\n 'family_man_woman_boy',\n 'boy',\n 'family',\n 'man',\n 'woman',\n ],\n },\n {\n name: 'family_man_woman_girl',\n code: '👨‍👩‍👧',\n keywords: [\n 'family_man_woman_girl',\n 'family',\n 'girl',\n 'man',\n 'woman',\n ],\n },\n {\n name: 'family_man_woman_girl_boy',\n code: '👨‍👩‍👧‍👦',\n keywords: [\n 'family_man_woman_girl_boy',\n 'boy',\n 'family',\n 'girl',\n 'man',\n 'woman',\n ],\n },\n {\n name: 'family_man_woman_boy_boy',\n code: '👨‍👩‍👦‍👦',\n keywords: [\n 'family_man_woman_boy_boy',\n 'boy',\n 'family',\n 'man',\n 'woman',\n ],\n },\n {\n name: 'family_man_woman_girl_girl',\n code: '👨‍👩‍👧‍👧',\n keywords: [\n 'family_man_woman_girl_girl',\n 'family',\n 'girl',\n 'man',\n 'woman',\n ],\n },\n {\n name: 'family_man_man_boy',\n code: '👨‍👨‍👦',\n keywords: [\n 'family_man_man_boy',\n 'boy',\n 'family',\n 'man',\n ],\n },\n {\n name: 'family_man_man_girl',\n code: '👨‍👨‍👧',\n keywords: [\n 'family_man_man_girl',\n 'family',\n 'girl',\n 'man',\n ],\n },\n {\n name: 'family_man_man_girl_boy',\n code: '👨‍👨‍👧‍👦',\n keywords: [\n 'family_man_man_girl_boy',\n 'boy',\n 'family',\n 'girl',\n 'man',\n ],\n },\n {\n name: 'family_man_man_boy_boy',\n code: '👨‍👨‍👦‍👦',\n keywords: [\n 'family_man_man_boy_boy',\n 'boy',\n 'family',\n 'man',\n ],\n },\n {\n name: 'family_man_man_girl_girl',\n code: '👨‍👨‍👧‍👧',\n keywords: [\n 'family_man_man_girl_girl',\n 'family',\n 'girl',\n 'man',\n ],\n },\n {\n name: 'family_woman_woman_boy',\n code: '👩‍👩‍👦',\n keywords: [\n 'family_woman_woman_boy',\n 'boy',\n 'family',\n 'woman',\n ],\n },\n {\n name: 'family_woman_woman_girl',\n code: '👩‍👩‍👧',\n keywords: [\n 'family_woman_woman_girl',\n 'family',\n 'girl',\n 'woman',\n ],\n },\n {\n name: 'family_woman_woman_girl_boy',\n code: '👩‍👩‍👧‍👦',\n keywords: [\n 'family_woman_woman_girl_boy',\n 'boy',\n 'family',\n 'girl',\n 'woman',\n ],\n },\n {\n name: 'family_woman_woman_boy_boy',\n code: '👩‍👩‍👦‍👦',\n keywords: [\n 'family_woman_woman_boy_boy',\n 'boy',\n 'family',\n 'woman',\n ],\n },\n {\n name: 'family_woman_woman_girl_girl',\n code: '👩‍👩‍👧‍👧',\n keywords: [\n 'family_woman_woman_girl_girl',\n 'family',\n 'girl',\n 'woman',\n ],\n },\n {\n name: 'family_man_boy',\n code: '👨‍👦',\n keywords: [\n 'family_man_boy',\n ],\n },\n {\n name: 'family_man_boy_boy',\n code: '👨‍👦‍👦',\n keywords: [\n 'family_man_boy_boy',\n ],\n },\n {\n name: 'family_man_girl',\n code: '👨‍👧',\n keywords: [\n 'family_man_girl',\n ],\n },\n {\n name: 'family_man_girl_boy',\n code: '👨‍👧‍👦',\n keywords: [\n 'family_man_girl_boy',\n ],\n },\n {\n name: 'family_man_girl_girl',\n code: '👨‍👧‍👧',\n keywords: [\n 'family_man_girl_girl',\n ],\n },\n {\n name: 'family_woman_boy',\n code: '👩‍👦',\n keywords: [\n 'family_woman_boy',\n ],\n },\n {\n name: 'family_woman_boy_boy',\n code: '👩‍👦‍👦',\n keywords: [\n 'family_woman_boy_boy',\n ],\n },\n {\n name: 'family_woman_girl',\n code: '👩‍👧',\n keywords: [\n 'family_woman_girl',\n ],\n },\n {\n name: 'family_woman_girl_boy',\n code: '👩‍👧‍👦',\n keywords: [\n 'family_woman_girl_boy',\n ],\n },\n {\n name: 'family_woman_girl_girl',\n code: '👩‍👧‍👧',\n keywords: [\n 'family_woman_girl_girl',\n ],\n },\n {\n name: 'speaking_head',\n code: '🗣️',\n keywords: [\n 'speaking_head',\n ],\n },\n {\n name: 'bust_in_silhouette',\n code: '👤',\n keywords: [\n 'user',\n 'bust_in_silhouette',\n 'bust',\n 'silhouette',\n ],\n },\n {\n name: 'busts_in_silhouette',\n code: '👥',\n keywords: [\n 'users',\n 'group',\n 'team',\n 'busts_in_silhouette',\n 'bust',\n 'silhouette',\n ],\n },\n {\n name: 'people_hugging',\n code: '🫂',\n keywords: [\n 'people_hugging',\n ],\n },\n {\n name: 'footprints',\n code: '👣',\n keywords: [\n 'feet',\n 'tracks',\n 'footprints',\n 'body',\n 'clothing',\n 'footprint',\n 'print',\n ],\n },\n {\n code: 'animalsAndNature',\n header: true,\n icon: AnimalsAndNature,\n },\n {\n name: 'monkey_face',\n code: '🐵',\n keywords: [\n 'monkey_face',\n 'face',\n 'monkey',\n ],\n },\n {\n name: 'monkey',\n code: '🐒',\n keywords: [\n 'monkey',\n ],\n },\n {\n name: 'gorilla',\n code: '🦍',\n keywords: [\n 'gorilla',\n ],\n },\n {\n name: 'orangutan',\n code: '🦧',\n keywords: [\n 'orangutan',\n ],\n },\n {\n name: 'dog',\n code: '🐶',\n keywords: [\n 'pet',\n 'dog',\n 'face',\n ],\n },\n {\n name: 'dog2',\n code: '🐕',\n keywords: [\n 'dog2',\n 'dog',\n 'pet',\n ],\n },\n {\n name: 'guide_dog',\n code: '🦮',\n keywords: [\n 'guide_dog',\n ],\n },\n {\n name: 'service_dog',\n code: '🐕‍🦺',\n keywords: [\n 'service_dog',\n ],\n },\n {\n name: 'poodle',\n code: '🐩',\n keywords: [\n 'dog',\n 'poodle',\n ],\n },\n {\n name: 'wolf',\n code: '🐺',\n keywords: [\n 'wolf',\n 'face',\n ],\n },\n {\n name: 'fox_face',\n code: '🦊',\n keywords: [\n 'fox_face',\n 'face',\n 'fox',\n ],\n },\n {\n name: 'raccoon',\n code: '🦝',\n keywords: [\n 'raccoon',\n ],\n },\n {\n name: 'cat',\n code: '🐱',\n keywords: [\n 'pet',\n 'cat',\n 'face',\n ],\n },\n {\n name: 'cat2',\n code: '🐈',\n keywords: [\n 'cat2',\n 'cat',\n 'pet',\n ],\n },\n {\n name: 'black_cat',\n code: '🐈‍⬛',\n keywords: [\n 'black_cat',\n ],\n },\n {\n name: 'lion',\n code: '🦁',\n keywords: [\n 'lion',\n 'face',\n 'leo',\n 'zodiac',\n ],\n },\n {\n name: 'tiger',\n code: '🐯',\n keywords: [\n 'tiger',\n 'face',\n ],\n },\n {\n name: 'tiger2',\n code: '🐅',\n keywords: [\n 'tiger2',\n 'tiger',\n ],\n },\n {\n name: 'leopard',\n code: '🐆',\n keywords: [\n 'leopard',\n ],\n },\n {\n name: 'horse',\n code: '🐴',\n keywords: [\n 'horse',\n 'face',\n ],\n },\n {\n name: 'racehorse',\n code: '🐎',\n keywords: [\n 'speed',\n 'racehorse',\n 'horse',\n 'racing',\n ],\n },\n {\n name: 'unicorn',\n code: '🦄',\n keywords: [\n 'unicorn',\n 'face',\n ],\n },\n {\n name: 'zebra',\n code: '🦓',\n keywords: [\n 'zebra',\n ],\n },\n {\n name: 'deer',\n code: '🦌',\n keywords: [\n 'deer',\n ],\n },\n {\n name: 'bison',\n code: '🦬',\n keywords: [\n 'bison',\n ],\n },\n {\n name: 'cow',\n code: '🐮',\n keywords: [\n 'cow',\n 'face',\n ],\n },\n {\n name: 'ox',\n code: '🐂',\n keywords: [\n 'ox',\n 'bull',\n 'taurus',\n 'zodiac',\n ],\n },\n {\n name: 'water_buffalo',\n code: '🐃',\n keywords: [\n 'water_buffalo',\n 'buffalo',\n 'water',\n ],\n },\n {\n name: 'cow2',\n code: '🐄',\n keywords: [\n 'cow2',\n 'cow',\n ],\n },\n {\n name: 'pig',\n code: '🐷',\n keywords: [\n 'pig',\n 'face',\n ],\n },\n {\n name: 'pig2',\n code: '🐖',\n keywords: [\n 'pig2',\n 'pig',\n 'sow',\n ],\n },\n {\n name: 'boar',\n code: '🐗',\n keywords: [\n 'boar',\n 'pig',\n ],\n },\n {\n name: 'pig_nose',\n code: '🐽',\n keywords: [\n 'pig_nose',\n 'face',\n 'nose',\n 'pig',\n ],\n },\n {\n name: 'ram',\n code: '🐏',\n keywords: [\n 'ram',\n 'aries',\n 'sheep',\n 'zodiac',\n ],\n },\n {\n name: 'sheep',\n code: '🐑',\n keywords: [\n 'sheep',\n 'ewe',\n ],\n },\n {\n name: 'goat',\n code: '🐐',\n keywords: [\n 'goat',\n 'capricorn',\n 'zodiac',\n ],\n },\n {\n name: 'dromedary_camel',\n code: '🐪',\n keywords: [\n 'desert',\n 'dromedary_camel',\n 'camel',\n 'dromedary',\n 'hump',\n ],\n },\n {\n name: 'camel',\n code: '🐫',\n keywords: [\n 'camel',\n 'bactrian',\n 'hump',\n ],\n },\n {\n name: 'llama',\n code: '🦙',\n keywords: [\n 'llama',\n ],\n },\n {\n name: 'giraffe',\n code: '🦒',\n keywords: [\n 'giraffe',\n ],\n },\n {\n name: 'elephant',\n code: '🐘',\n keywords: [\n 'elephant',\n ],\n },\n {\n name: 'mammoth',\n code: '🦣',\n keywords: [\n 'mammoth',\n ],\n },\n {\n name: 'rhinoceros',\n code: '🦏',\n keywords: [\n 'rhinoceros',\n ],\n },\n {\n name: 'hippopotamus',\n code: '🦛',\n keywords: [\n 'hippopotamus',\n ],\n },\n {\n name: 'mouse',\n code: '🐭',\n keywords: [\n 'mouse',\n 'face',\n ],\n },\n {\n name: 'mouse2',\n code: '🐁',\n keywords: [\n 'mouse2',\n 'mouse',\n ],\n },\n {\n name: 'rat',\n code: '🐀',\n keywords: [\n 'rat',\n ],\n },\n {\n name: 'hamster',\n code: '🐹',\n keywords: [\n 'pet',\n 'hamster',\n 'face',\n ],\n },\n {\n name: 'rabbit',\n code: '🐰',\n keywords: [\n 'bunny',\n 'rabbit',\n 'face',\n 'pet',\n ],\n },\n {\n name: 'rabbit2',\n code: '🐇',\n keywords: [\n 'rabbit2',\n 'bunny',\n 'pet',\n 'rabbit',\n ],\n },\n {\n name: 'chipmunk',\n code: '🐿️',\n keywords: [\n 'chipmunk',\n ],\n },\n {\n name: 'beaver',\n code: '🦫',\n keywords: [\n 'beaver',\n ],\n },\n {\n name: 'hedgehog',\n code: '🦔',\n keywords: [\n 'hedgehog',\n ],\n },\n {\n name: 'bat',\n code: '🦇',\n keywords: [\n 'bat',\n 'vampire',\n ],\n },\n {\n name: 'bear',\n code: '🐻',\n keywords: [\n 'bear',\n 'face',\n ],\n },\n {\n name: 'polar_bear',\n code: '🐻‍❄️',\n keywords: [\n 'polar_bear',\n ],\n },\n {\n name: 'koala',\n code: '🐨',\n keywords: [\n 'koala',\n 'bear',\n ],\n },\n {\n name: 'panda_face',\n code: '🐼',\n keywords: [\n 'panda_face',\n 'face',\n 'panda',\n ],\n },\n {\n name: 'sloth',\n code: '🦥',\n keywords: [\n 'sloth',\n ],\n },\n {\n name: 'otter',\n code: '🦦',\n keywords: [\n 'otter',\n ],\n },\n {\n name: 'skunk',\n code: '🦨',\n keywords: [\n 'skunk',\n ],\n },\n {\n name: 'kangaroo',\n code: '🦘',\n keywords: [\n 'kangaroo',\n ],\n },\n {\n name: 'badger',\n code: '🦡',\n keywords: [\n 'badger',\n ],\n },\n {\n name: 'feet',\n code: '🐾',\n keywords: [\n 'feet',\n 'paw_prints',\n 'paw',\n 'print',\n ],\n },\n {\n name: 'turkey',\n code: '🦃',\n keywords: [\n 'thanksgiving',\n 'turkey',\n ],\n },\n {\n name: 'chicken',\n code: '🐔',\n keywords: [\n 'chicken',\n ],\n },\n {\n name: 'rooster',\n code: '🐓',\n keywords: [\n 'rooster',\n ],\n },\n {\n name: 'hatching_chick',\n code: '🐣',\n keywords: [\n 'hatching_chick',\n 'baby',\n 'chick',\n 'hatching',\n ],\n },\n {\n name: 'baby_chick',\n code: '🐤',\n keywords: [\n 'baby_chick',\n 'baby',\n 'chick',\n ],\n },\n {\n name: 'hatched_chick',\n code: '🐥',\n keywords: [\n 'hatched_chick',\n 'baby',\n 'chick',\n ],\n },\n {\n name: 'bird',\n code: '🐦',\n keywords: [\n 'bird',\n ],\n },\n {\n name: 'penguin',\n code: '🐧',\n keywords: [\n 'penguin',\n ],\n },\n {\n name: 'dove',\n code: '🕊️',\n keywords: [\n 'peace',\n 'dove',\n ],\n },\n {\n name: 'eagle',\n code: '🦅',\n keywords: [\n 'eagle',\n 'bird',\n ],\n },\n {\n name: 'duck',\n code: '🦆',\n keywords: [\n 'duck',\n 'bird',\n ],\n },\n {\n name: 'swan',\n code: '🦢',\n keywords: [\n 'swan',\n ],\n },\n {\n name: 'owl',\n code: '🦉',\n keywords: [\n 'owl',\n 'bird',\n 'wise',\n ],\n },\n {\n name: 'dodo',\n code: '🦤',\n keywords: [\n 'dodo',\n ],\n },\n {\n name: 'feather',\n code: '🪶',\n keywords: [\n 'feather',\n ],\n },\n {\n name: 'flamingo',\n code: '🦩',\n keywords: [\n 'flamingo',\n ],\n },\n {\n name: 'peacock',\n code: '🦚',\n keywords: [\n 'peacock',\n ],\n },\n {\n name: 'parrot',\n code: '🦜',\n keywords: [\n 'parrot',\n ],\n },\n {\n name: 'frog',\n code: '🐸',\n keywords: [\n 'frog',\n 'face',\n ],\n },\n {\n name: 'crocodile',\n code: '🐊',\n keywords: [\n 'crocodile',\n ],\n },\n {\n name: 'turtle',\n code: '🐢',\n keywords: [\n 'slow',\n 'turtle',\n ],\n },\n {\n name: 'lizard',\n code: '🦎',\n keywords: [\n 'lizard',\n 'reptile',\n ],\n },\n {\n name: 'snake',\n code: '🐍',\n keywords: [\n 'snake',\n 'bearer',\n 'ophiuchus',\n 'serpent',\n 'zodiac',\n ],\n },\n {\n name: 'dragon_face',\n code: '🐲',\n keywords: [\n 'dragon_face',\n 'dragon',\n 'face',\n 'fairy tale',\n ],\n },\n {\n name: 'dragon',\n code: '🐉',\n keywords: [\n 'dragon',\n 'fairy tale',\n ],\n },\n {\n name: 'sauropod',\n code: '🦕',\n keywords: [\n 'dinosaur',\n 'sauropod',\n ],\n },\n {\n name: 't-rex',\n code: '🦖',\n keywords: [\n 'dinosaur',\n 't-rex',\n ],\n },\n {\n name: 'whale',\n code: '🐳',\n keywords: [\n 'sea',\n 'whale',\n 'face',\n 'spouting',\n ],\n },\n {\n name: 'whale2',\n code: '🐋',\n keywords: [\n 'whale2',\n 'whale',\n ],\n },\n {\n name: 'dolphin',\n code: '🐬',\n keywords: [\n 'dolphin',\n 'flipper',\n ],\n },\n {\n name: 'seal',\n code: '🦭',\n keywords: [\n 'seal',\n ],\n },\n {\n name: 'fish',\n code: '🐟',\n keywords: [\n 'fish',\n 'pisces',\n 'zodiac',\n ],\n },\n {\n name: 'tropical_fish',\n code: '🐠',\n keywords: [\n 'tropical_fish',\n 'fish',\n 'tropical',\n ],\n },\n {\n name: 'blowfish',\n code: '🐡',\n keywords: [\n 'blowfish',\n 'fish',\n ],\n },\n {\n name: 'shark',\n code: '🦈',\n keywords: [\n 'shark',\n 'fish',\n ],\n },\n {\n name: 'octopus',\n code: '🐙',\n keywords: [\n 'octopus',\n ],\n },\n {\n name: 'shell',\n code: '🐚',\n keywords: [\n 'sea',\n 'beach',\n 'shell',\n 'spiral',\n ],\n },\n {\n name: 'snail',\n code: '🐌',\n keywords: [\n 'slow',\n 'snail',\n ],\n },\n {\n name: 'butterfly',\n code: '🦋',\n keywords: [\n 'butterfly',\n 'insect',\n 'pretty',\n ],\n },\n {\n name: 'bug',\n code: '🐛',\n keywords: [\n 'bug',\n 'insect',\n ],\n },\n {\n name: 'ant',\n code: '🐜',\n keywords: [\n 'ant',\n 'insect',\n ],\n },\n {\n name: 'bee',\n code: '🐝',\n keywords: [\n 'bee',\n 'honeybee',\n 'insect',\n ],\n },\n {\n name: 'beetle',\n code: '🪲',\n keywords: [\n 'beetle',\n ],\n },\n {\n name: 'lady_beetle',\n code: '🐞',\n keywords: [\n 'bug',\n 'lady_beetle',\n 'beetle',\n 'insect',\n 'lady beetle',\n 'ladybird',\n 'ladybug',\n ],\n },\n {\n name: 'cricket',\n code: '🦗',\n keywords: [\n 'cricket',\n ],\n },\n {\n name: 'cockroach',\n code: '🪳',\n keywords: [\n 'cockroach',\n ],\n },\n {\n name: 'spider',\n code: '🕷️',\n keywords: [\n 'spider',\n ],\n },\n {\n name: 'spider_web',\n code: '🕸️',\n keywords: [\n 'spider_web',\n ],\n },\n {\n name: 'scorpion',\n code: '🦂',\n keywords: [\n 'scorpion',\n 'scorpio',\n 'scorpius',\n 'zodiac',\n ],\n },\n {\n name: 'mosquito',\n code: '🦟',\n keywords: [\n 'mosquito',\n ],\n },\n {\n name: 'fly',\n code: '🪰',\n keywords: [\n 'fly',\n ],\n },\n {\n name: 'worm',\n code: '🪱',\n keywords: [\n 'worm',\n ],\n },\n {\n name: 'microbe',\n code: '🦠',\n keywords: [\n 'germ',\n 'microbe',\n ],\n },\n {\n name: 'bouquet',\n code: '💐',\n keywords: [\n 'flowers',\n 'bouquet',\n 'flower',\n 'plant',\n 'romance',\n ],\n },\n {\n name: 'cherry_blossom',\n code: '🌸',\n keywords: [\n 'flower',\n 'spring',\n 'cherry_blossom',\n 'blossom',\n 'cherry',\n 'plant',\n ],\n },\n {\n name: 'white_flower',\n code: '💮',\n keywords: [\n 'white_flower',\n 'flower',\n ],\n },\n {\n name: 'rosette',\n code: '🏵️',\n keywords: [\n 'rosette',\n ],\n },\n {\n name: 'rose',\n code: '🌹',\n keywords: [\n 'flower',\n 'rose',\n 'plant',\n ],\n },\n {\n name: 'wilted_flower',\n code: '🥀',\n keywords: [\n 'wilted_flower',\n 'flower',\n 'wilted',\n ],\n },\n {\n name: 'hibiscus',\n code: '🌺',\n keywords: [\n 'hibiscus',\n 'flower',\n 'plant',\n ],\n },\n {\n name: 'sunflower',\n code: '🌻',\n keywords: [\n 'sunflower',\n 'flower',\n 'plant',\n 'sun',\n ],\n },\n {\n name: 'blossom',\n code: '🌼',\n keywords: [\n 'blossom',\n 'flower',\n 'plant',\n ],\n },\n {\n name: 'tulip',\n code: '🌷',\n keywords: [\n 'flower',\n 'tulip',\n 'plant',\n ],\n },\n {\n name: 'seedling',\n code: '🌱',\n keywords: [\n 'plant',\n 'seedling',\n 'young',\n ],\n },\n {\n name: 'potted_plant',\n code: '🪴',\n keywords: [\n 'potted_plant',\n ],\n },\n {\n name: 'evergreen_tree',\n code: '🌲',\n keywords: [\n 'wood',\n 'evergreen_tree',\n 'evergreen',\n 'plant',\n 'tree',\n ],\n },\n {\n name: 'deciduous_tree',\n code: '🌳',\n keywords: [\n 'wood',\n 'deciduous_tree',\n 'deciduous',\n 'plant',\n 'shedding',\n 'tree',\n ],\n },\n {\n name: 'palm_tree',\n code: '🌴',\n keywords: [\n 'palm_tree',\n 'palm',\n 'plant',\n 'tree',\n ],\n },\n {\n name: 'cactus',\n code: '🌵',\n keywords: [\n 'cactus',\n 'plant',\n ],\n },\n {\n name: 'ear_of_rice',\n code: '🌾',\n keywords: [\n 'ear_of_rice',\n 'ear',\n 'plant',\n 'rice',\n ],\n },\n {\n name: 'herb',\n code: '🌿',\n keywords: [\n 'herb',\n 'leaf',\n 'plant',\n ],\n },\n {\n name: 'shamrock',\n code: '☘️',\n keywords: [\n 'shamrock',\n 'plant',\n ],\n },\n {\n name: 'four_leaf_clover',\n code: '🍀',\n keywords: [\n 'luck',\n 'four_leaf_clover',\n '4',\n 'clover',\n 'four',\n 'leaf',\n 'plant',\n ],\n },\n {\n name: 'maple_leaf',\n code: '🍁',\n keywords: [\n 'canada',\n 'maple_leaf',\n 'falling',\n 'leaf',\n 'maple',\n 'plant',\n ],\n },\n {\n name: 'fallen_leaf',\n code: '🍂',\n keywords: [\n 'autumn',\n 'fallen_leaf',\n 'falling',\n 'leaf',\n 'plant',\n ],\n },\n {\n name: 'leaves',\n code: '🍃',\n keywords: [\n 'leaf',\n 'leaves',\n 'blow',\n 'flutter',\n 'plant',\n 'wind',\n ],\n },\n {\n code: 'foodAndDrink',\n header: true,\n icon: FoodAndDrink,\n },\n {\n name: 'grapes',\n code: '🍇',\n keywords: [\n 'grapes',\n 'fruit',\n 'grape',\n 'plant',\n ],\n },\n {\n name: 'melon',\n code: '🍈',\n keywords: [\n 'melon',\n 'fruit',\n 'plant',\n ],\n },\n {\n name: 'watermelon',\n code: '🍉',\n keywords: [\n 'watermelon',\n 'fruit',\n 'plant',\n ],\n },\n {\n name: 'tangerine',\n code: '🍊',\n keywords: [\n 'tangerine',\n 'orange',\n 'mandarin',\n 'fruit',\n 'plant',\n ],\n },\n {\n name: 'lemon',\n code: '🍋',\n keywords: [\n 'lemon',\n 'citrus',\n 'fruit',\n 'plant',\n ],\n },\n {\n name: 'banana',\n code: '🍌',\n keywords: [\n 'fruit',\n 'banana',\n 'plant',\n ],\n },\n {\n name: 'pineapple',\n code: '🍍',\n keywords: [\n 'pineapple',\n 'fruit',\n 'plant',\n ],\n },\n {\n name: 'mango',\n code: '🥭',\n keywords: [\n 'mango',\n ],\n },\n {\n name: 'apple',\n code: '🍎',\n keywords: [\n 'apple',\n 'fruit',\n 'plant',\n 'red',\n ],\n },\n {\n name: 'green_apple',\n code: '🍏',\n keywords: [\n 'fruit',\n 'green_apple',\n 'apple',\n 'green',\n 'plant',\n ],\n },\n {\n name: 'pear',\n code: '🍐',\n keywords: [\n 'pear',\n 'fruit',\n 'plant',\n ],\n },\n {\n name: 'peach',\n code: '🍑',\n keywords: [\n 'peach',\n 'fruit',\n 'plant',\n ],\n },\n {\n name: 'cherries',\n code: '🍒',\n keywords: [\n 'fruit',\n 'cherries',\n 'cherry',\n 'plant',\n ],\n },\n {\n name: 'strawberry',\n code: '🍓',\n keywords: [\n 'fruit',\n 'strawberry',\n 'berry',\n 'plant',\n ],\n },\n {\n name: 'blueberries',\n code: '🫐',\n keywords: [\n 'blueberries',\n ],\n },\n {\n name: 'kiwi_fruit',\n code: '🥝',\n keywords: [\n 'kiwi_fruit',\n 'fruit',\n 'kiwi',\n ],\n },\n {\n name: 'tomato',\n code: '🍅',\n keywords: [\n 'tomato',\n 'plant',\n 'vegetable',\n ],\n },\n {\n name: 'olive',\n code: '🫒',\n keywords: [\n 'olive',\n ],\n },\n {\n name: 'coconut',\n code: '🥥',\n keywords: [\n 'coconut',\n ],\n },\n {\n name: 'avocado',\n code: '🥑',\n keywords: [\n 'avocado',\n 'fruit',\n ],\n },\n {\n name: 'eggplant',\n code: '🍆',\n keywords: [\n 'aubergine',\n 'eggplant',\n 'plant',\n 'vegetable',\n ],\n },\n {\n name: 'potato',\n code: '🥔',\n keywords: [\n 'potato',\n 'vegetable',\n ],\n },\n {\n name: 'carrot',\n code: '🥕',\n keywords: [\n 'carrot',\n 'vegetable',\n ],\n },\n {\n name: 'corn',\n code: '🌽',\n keywords: [\n 'corn',\n 'ear',\n 'maize',\n 'maze',\n 'plant',\n ],\n },\n {\n name: 'hot_pepper',\n code: '🌶️',\n keywords: [\n 'spicy',\n 'hot_pepper',\n ],\n },\n {\n name: 'bell_pepper',\n code: '🫑',\n keywords: [\n 'bell_pepper',\n ],\n },\n {\n name: 'cucumber',\n code: '🥒',\n keywords: [\n 'cucumber',\n 'pickle',\n 'vegetable',\n ],\n },\n {\n name: 'leafy_green',\n code: '🥬',\n keywords: [\n 'leafy_green',\n ],\n },\n {\n name: 'broccoli',\n code: '🥦',\n keywords: [\n 'broccoli',\n ],\n },\n {\n name: 'garlic',\n code: '🧄',\n keywords: [\n 'garlic',\n ],\n },\n {\n name: 'onion',\n code: '🧅',\n keywords: [\n 'onion',\n ],\n },\n {\n name: 'mushroom',\n code: '🍄',\n keywords: [\n 'mushroom',\n 'plant',\n ],\n },\n {\n name: 'peanuts',\n code: '🥜',\n keywords: [\n 'peanuts',\n 'nut',\n 'peanut',\n 'vegetable',\n ],\n },\n {\n name: 'chestnut',\n code: '🌰',\n keywords: [\n 'chestnut',\n 'plant',\n ],\n },\n {\n name: 'bread',\n code: '🍞',\n keywords: [\n 'toast',\n 'bread',\n 'loaf',\n ],\n },\n {\n name: 'croissant',\n code: '🥐',\n keywords: [\n 'croissant',\n 'bread',\n 'crescent roll',\n 'french',\n ],\n },\n {\n name: 'baguette_bread',\n code: '🥖',\n keywords: [\n 'baguette_bread',\n 'baguette',\n 'bread',\n 'french',\n ],\n },\n {\n name: 'flatbread',\n code: '🫓',\n keywords: [\n 'flatbread',\n ],\n },\n {\n name: 'pretzel',\n code: '🥨',\n keywords: [\n 'pretzel',\n ],\n },\n {\n name: 'bagel',\n code: '🥯',\n keywords: [\n 'bagel',\n ],\n },\n {\n name: 'pancakes',\n code: '🥞',\n keywords: [\n 'pancakes',\n 'crêpe',\n 'hotcake',\n 'pancake',\n ],\n },\n {\n name: 'waffle',\n code: '🧇',\n keywords: [\n 'waffle',\n ],\n },\n {\n name: 'cheese',\n code: '🧀',\n keywords: [\n 'cheese',\n ],\n },\n {\n name: 'meat_on_bone',\n code: '🍖',\n keywords: [\n 'meat_on_bone',\n 'bone',\n 'meat',\n ],\n },\n {\n name: 'poultry_leg',\n code: '🍗',\n keywords: [\n 'meat',\n 'chicken',\n 'poultry_leg',\n 'bone',\n 'leg',\n 'poultry',\n ],\n },\n {\n name: 'cut_of_meat',\n code: '🥩',\n keywords: [\n 'cut_of_meat',\n ],\n },\n {\n name: 'bacon',\n code: '🥓',\n keywords: [\n 'bacon',\n 'meat',\n ],\n },\n {\n name: 'hamburger',\n code: '🍔',\n keywords: [\n 'burger',\n 'hamburger',\n ],\n },\n {\n name: 'fries',\n code: '🍟',\n keywords: [\n 'fries',\n 'french',\n ],\n },\n {\n name: 'pizza',\n code: '🍕',\n keywords: [\n 'pizza',\n 'cheese',\n 'slice',\n ],\n },\n {\n name: 'hotdog',\n code: '🌭',\n keywords: [\n 'hotdog',\n 'frankfurter',\n 'hot dog',\n 'sausage',\n ],\n },\n {\n name: 'sandwich',\n code: '🥪',\n keywords: [\n 'sandwich',\n ],\n },\n {\n name: 'taco',\n code: '🌮',\n keywords: [\n 'taco',\n 'mexican',\n ],\n },\n {\n name: 'burrito',\n code: '🌯',\n keywords: [\n 'burrito',\n 'mexican',\n ],\n },\n {\n name: 'tamale',\n code: '🫔',\n keywords: [\n 'tamale',\n ],\n },\n {\n name: 'stuffed_flatbread',\n code: '🥙',\n keywords: [\n 'stuffed_flatbread',\n 'falafel',\n 'flatbread',\n 'gyro',\n 'kebab',\n 'stuffed',\n ],\n },\n {\n name: 'falafel',\n code: '🧆',\n keywords: [\n 'falafel',\n ],\n },\n {\n name: 'egg',\n code: '🥚',\n keywords: [\n 'egg',\n ],\n },\n {\n name: 'fried_egg',\n code: '🍳',\n keywords: [\n 'breakfast',\n 'fried_egg',\n 'cooking',\n 'egg',\n 'frying',\n 'pan',\n ],\n },\n {\n name: 'shallow_pan_of_food',\n code: '🥘',\n keywords: [\n 'paella',\n 'curry',\n 'shallow_pan_of_food',\n 'casserole',\n 'pan',\n 'shallow',\n ],\n },\n {\n name: 'stew',\n code: '🍲',\n keywords: [\n 'stew',\n 'pot',\n ],\n },\n {\n name: 'fondue',\n code: '🫕',\n keywords: [\n 'fondue',\n ],\n },\n {\n name: 'bowl_with_spoon',\n code: '🥣',\n keywords: [\n 'bowl_with_spoon',\n ],\n },\n {\n name: 'green_salad',\n code: '🥗',\n keywords: [\n 'green_salad',\n 'green',\n 'salad',\n ],\n },\n {\n name: 'popcorn',\n code: '🍿',\n keywords: [\n 'popcorn',\n ],\n },\n {\n name: 'butter',\n code: '🧈',\n keywords: [\n 'butter',\n ],\n },\n {\n name: 'salt',\n code: '🧂',\n keywords: [\n 'salt',\n ],\n },\n {\n name: 'canned_food',\n code: '🥫',\n keywords: [\n 'canned_food',\n ],\n },\n {\n name: 'bento',\n code: '🍱',\n keywords: [\n 'bento',\n 'box',\n ],\n },\n {\n name: 'rice_cracker',\n code: '🍘',\n keywords: [\n 'rice_cracker',\n 'cracker',\n 'rice',\n ],\n },\n {\n name: 'rice_ball',\n code: '🍙',\n keywords: [\n 'rice_ball',\n 'ball',\n 'japanese',\n 'rice',\n ],\n },\n {\n name: 'rice',\n code: '🍚',\n keywords: [\n 'rice',\n 'cooked',\n ],\n },\n {\n name: 'curry',\n code: '🍛',\n keywords: [\n 'curry',\n 'rice',\n ],\n },\n {\n name: 'ramen',\n code: '🍜',\n keywords: [\n 'noodle',\n 'ramen',\n 'bowl',\n 'steaming',\n ],\n },\n {\n name: 'spaghetti',\n code: '🍝',\n keywords: [\n 'pasta',\n 'spaghetti',\n ],\n },\n {\n name: 'sweet_potato',\n code: '🍠',\n keywords: [\n 'sweet_potato',\n 'potato',\n 'roasted',\n 'sweet',\n ],\n },\n {\n name: 'oden',\n code: '🍢',\n keywords: [\n 'oden',\n 'kebab',\n 'seafood',\n 'skewer',\n 'stick',\n ],\n },\n {\n name: 'sushi',\n code: '🍣',\n keywords: [\n 'sushi',\n ],\n },\n {\n name: 'fried_shrimp',\n code: '🍤',\n keywords: [\n 'tempura',\n 'fried_shrimp',\n 'fried',\n 'prawn',\n 'shrimp',\n ],\n },\n {\n name: 'fish_cake',\n code: '🍥',\n keywords: [\n 'fish_cake',\n 'cake',\n 'fish',\n 'pastry',\n 'swirl',\n ],\n },\n {\n name: 'moon_cake',\n code: '🥮',\n keywords: [\n 'moon_cake',\n ],\n },\n {\n name: 'dango',\n code: '🍡',\n keywords: [\n 'dango',\n 'dessert',\n 'japanese',\n 'skewer',\n 'stick',\n 'sweet',\n ],\n },\n {\n name: 'dumpling',\n code: '🥟',\n keywords: [\n 'dumpling',\n ],\n },\n {\n name: 'fortune_cookie',\n code: '🥠',\n keywords: [\n 'fortune_cookie',\n ],\n },\n {\n name: 'takeout_box',\n code: '🥡',\n keywords: [\n 'takeout_box',\n ],\n },\n {\n name: 'crab',\n code: '🦀',\n keywords: [\n 'crab',\n 'cancer',\n 'zodiac',\n ],\n },\n {\n name: 'lobster',\n code: '🦞',\n keywords: [\n 'lobster',\n ],\n },\n {\n name: 'shrimp',\n code: '🦐',\n keywords: [\n 'shrimp',\n 'shellfish',\n 'small',\n ],\n },\n {\n name: 'squid',\n code: '🦑',\n keywords: [\n 'squid',\n 'molusc',\n ],\n },\n {\n name: 'oyster',\n code: '🦪',\n keywords: [\n 'oyster',\n ],\n },\n {\n name: 'icecream',\n code: '🍦',\n keywords: [\n 'icecream',\n 'cream',\n 'dessert',\n 'ice',\n 'soft',\n 'sweet',\n ],\n },\n {\n name: 'shaved_ice',\n code: '🍧',\n keywords: [\n 'shaved_ice',\n 'dessert',\n 'ice',\n 'shaved',\n 'sweet',\n ],\n },\n {\n name: 'ice_cream',\n code: '🍨',\n keywords: [\n 'ice_cream',\n 'cream',\n 'dessert',\n 'ice',\n 'sweet',\n ],\n },\n {\n name: 'doughnut',\n code: '🍩',\n keywords: [\n 'doughnut',\n 'dessert',\n 'donut',\n 'sweet',\n ],\n },\n {\n name: 'cookie',\n code: '🍪',\n keywords: [\n 'cookie',\n 'dessert',\n 'sweet',\n ],\n },\n {\n name: 'birthday',\n code: '🎂',\n keywords: [\n 'party',\n 'birthday',\n 'cake',\n 'celebration',\n 'dessert',\n 'pastry',\n 'sweet',\n ],\n },\n {\n name: 'cake',\n code: '🍰',\n keywords: [\n 'dessert',\n 'cake',\n 'pastry',\n 'shortcake',\n 'slice',\n 'sweet',\n ],\n },\n {\n name: 'cupcake',\n code: '🧁',\n keywords: [\n 'cupcake',\n ],\n },\n {\n name: 'pie',\n code: '🥧',\n keywords: [\n 'pie',\n ],\n },\n {\n name: 'chocolate_bar',\n code: '🍫',\n keywords: [\n 'chocolate_bar',\n 'bar',\n 'chocolate',\n 'dessert',\n 'sweet',\n ],\n },\n {\n name: 'candy',\n code: '🍬',\n keywords: [\n 'sweet',\n 'candy',\n 'dessert',\n ],\n },\n {\n name: 'lollipop',\n code: '🍭',\n keywords: [\n 'lollipop',\n 'candy',\n 'dessert',\n 'sweet',\n ],\n },\n {\n name: 'custard',\n code: '🍮',\n keywords: [\n 'custard',\n 'dessert',\n 'pudding',\n 'sweet',\n ],\n },\n {\n name: 'honey_pot',\n code: '🍯',\n keywords: [\n 'honey_pot',\n 'honey',\n 'honeypot',\n 'pot',\n 'sweet',\n ],\n },\n {\n name: 'baby_bottle',\n code: '🍼',\n keywords: [\n 'milk',\n 'baby_bottle',\n 'baby',\n 'bottle',\n 'drink',\n ],\n },\n {\n name: 'milk_glass',\n code: '🥛',\n keywords: [\n 'milk_glass',\n 'drink',\n 'glass',\n 'milk',\n ],\n },\n {\n name: 'coffee',\n code: '☕',\n keywords: [\n 'cafe',\n 'espresso',\n 'coffee',\n 'beverage',\n 'drink',\n 'hot',\n 'steaming',\n 'tea',\n ],\n },\n {\n name: 'teapot',\n code: '🫖',\n keywords: [\n 'teapot',\n ],\n },\n {\n name: 'tea',\n code: '🍵',\n keywords: [\n 'green',\n 'breakfast',\n 'tea',\n 'beverage',\n 'cup',\n 'drink',\n 'teacup',\n ],\n },\n {\n name: 'sake',\n code: '🍶',\n keywords: [\n 'sake',\n 'bar',\n 'beverage',\n 'bottle',\n 'cup',\n 'drink',\n ],\n },\n {\n name: 'champagne',\n code: '🍾',\n keywords: [\n 'bottle',\n 'bubbly',\n 'celebration',\n 'champagne',\n 'bar',\n 'cork',\n 'drink',\n 'popping',\n ],\n },\n {\n name: 'wine_glass',\n code: '🍷',\n keywords: [\n 'wine_glass',\n 'bar',\n 'beverage',\n 'drink',\n 'glass',\n 'wine',\n ],\n },\n {\n name: 'cocktail',\n code: '🍸',\n keywords: [\n 'drink',\n 'cocktail',\n 'bar',\n 'glass',\n ],\n },\n {\n name: 'tropical_drink',\n code: '🍹',\n keywords: [\n 'summer',\n 'vacation',\n 'tropical_drink',\n 'bar',\n 'drink',\n 'tropical',\n ],\n },\n {\n name: 'beer',\n code: '🍺',\n keywords: [\n 'drink',\n 'beer',\n 'bar',\n 'mug',\n ],\n },\n {\n name: 'beers',\n code: '🍻',\n keywords: [\n 'drinks',\n 'beers',\n 'bar',\n 'beer',\n 'clink',\n 'drink',\n 'mug',\n ],\n },\n {\n name: 'clinking_glasses',\n code: '🥂',\n keywords: [\n 'cheers',\n 'toast',\n 'clinking_glasses',\n 'celebrate',\n 'clink',\n 'drink',\n 'glass',\n ],\n },\n {\n name: 'tumbler_glass',\n code: '🥃',\n keywords: [\n 'whisky',\n 'tumbler_glass',\n 'glass',\n 'liquor',\n 'shot',\n 'tumbler',\n ],\n },\n {\n name: 'cup_with_straw',\n code: '🥤',\n keywords: [\n 'cup_with_straw',\n ],\n },\n {\n name: 'bubble_tea',\n code: '🧋',\n keywords: [\n 'bubble_tea',\n ],\n },\n {\n name: 'beverage_box',\n code: '🧃',\n keywords: [\n 'beverage_box',\n ],\n },\n {\n name: 'mate',\n code: '🧉',\n keywords: [\n 'mate',\n ],\n },\n {\n name: 'ice_cube',\n code: '🧊',\n keywords: [\n 'ice_cube',\n ],\n },\n {\n name: 'chopsticks',\n code: '🥢',\n keywords: [\n 'chopsticks',\n ],\n },\n {\n name: 'plate_with_cutlery',\n code: '🍽️',\n keywords: [\n 'dining',\n 'dinner',\n 'plate_with_cutlery',\n ],\n },\n {\n name: 'fork_and_knife',\n code: '🍴',\n keywords: [\n 'cutlery',\n 'fork_and_knife',\n 'cooking',\n 'fork',\n 'knife',\n ],\n },\n {\n name: 'spoon',\n code: '🥄',\n keywords: [\n 'spoon',\n 'tableware',\n ],\n },\n {\n name: 'hocho',\n code: '🔪',\n keywords: [\n 'cut',\n 'chop',\n 'hocho',\n 'knife',\n 'cooking',\n 'tool',\n 'weapon',\n ],\n },\n {\n name: 'amphora',\n code: '🏺',\n keywords: [\n 'amphora',\n 'aquarius',\n 'cooking',\n 'drink',\n 'jug',\n 'tool',\n 'weapon',\n 'zodiac',\n ],\n },\n {\n code: 'travelAndPlaces',\n header: true,\n icon: TravelAndPlaces,\n },\n {\n name: 'earth_africa',\n code: '🌍',\n keywords: [\n 'globe',\n 'world',\n 'international',\n 'earth_africa',\n 'africa',\n 'earth',\n 'europe',\n ],\n },\n {\n name: 'earth_americas',\n code: '🌎',\n keywords: [\n 'globe',\n 'world',\n 'international',\n 'earth_americas',\n 'americas',\n 'earth',\n ],\n },\n {\n name: 'earth_asia',\n code: '🌏',\n keywords: [\n 'globe',\n 'world',\n 'international',\n 'earth_asia',\n 'asia',\n 'australia',\n 'earth',\n ],\n },\n {\n name: 'globe_with_meridians',\n code: '🌐',\n keywords: [\n 'world',\n 'global',\n 'international',\n 'globe_with_meridians',\n 'earth',\n 'globe',\n 'meridians',\n ],\n },\n {\n name: 'world_map',\n code: '🗺️',\n keywords: [\n 'travel',\n 'world_map',\n ],\n },\n {\n name: 'japan',\n code: '🗾',\n keywords: [\n 'japan',\n 'map',\n ],\n },\n {\n name: 'compass',\n code: '🧭',\n keywords: [\n 'compass',\n ],\n },\n {\n name: 'mountain_snow',\n code: '🏔️',\n keywords: [\n 'mountain_snow',\n ],\n },\n {\n name: 'mountain',\n code: '⛰️',\n keywords: [\n 'mountain',\n ],\n },\n {\n name: 'volcano',\n code: '🌋',\n keywords: [\n 'volcano',\n 'eruption',\n 'mountain',\n 'weather',\n ],\n },\n {\n name: 'mount_fuji',\n code: '🗻',\n keywords: [\n 'mount_fuji',\n 'fuji',\n 'mountain',\n ],\n },\n {\n name: 'camping',\n code: '🏕️',\n keywords: [\n 'camping',\n ],\n },\n {\n name: 'beach_umbrella',\n code: '🏖️',\n keywords: [\n 'beach_umbrella',\n ],\n },\n {\n name: 'desert',\n code: '🏜️',\n keywords: [\n 'desert',\n ],\n },\n {\n name: 'desert_island',\n code: '🏝️',\n keywords: [\n 'desert_island',\n ],\n },\n {\n name: 'national_park',\n code: '🏞️',\n keywords: [\n 'national_park',\n ],\n },\n {\n name: 'stadium',\n code: '🏟️',\n keywords: [\n 'stadium',\n ],\n },\n {\n name: 'classical_building',\n code: '🏛️',\n keywords: [\n 'classical_building',\n ],\n },\n {\n name: 'building_construction',\n code: '🏗️',\n keywords: [\n 'building_construction',\n ],\n },\n {\n name: 'bricks',\n code: '🧱',\n keywords: [\n 'bricks',\n ],\n },\n {\n name: 'rock',\n code: '🪨',\n keywords: [\n 'rock',\n ],\n },\n {\n name: 'wood',\n code: '🪵',\n keywords: [\n 'wood',\n ],\n },\n {\n name: 'hut',\n code: '🛖',\n keywords: [\n 'hut',\n ],\n },\n {\n name: 'houses',\n code: '🏘️',\n keywords: [\n 'houses',\n ],\n },\n {\n name: 'derelict_house',\n code: '🏚️',\n keywords: [\n 'derelict_house',\n ],\n },\n {\n name: 'house',\n code: '🏠',\n keywords: [\n 'house',\n 'building',\n 'home',\n ],\n },\n {\n name: 'house_with_garden',\n code: '🏡',\n keywords: [\n 'house_with_garden',\n 'building',\n 'garden',\n 'home',\n 'house',\n ],\n },\n {\n name: 'office',\n code: '🏢',\n keywords: [\n 'office',\n 'building',\n ],\n },\n {\n name: 'post_office',\n code: '🏣',\n keywords: [\n 'post_office',\n 'building',\n 'japanese',\n 'post',\n ],\n },\n {\n name: 'european_post_office',\n code: '🏤',\n keywords: [\n 'european_post_office',\n 'building',\n 'european',\n 'post',\n ],\n },\n {\n name: 'hospital',\n code: '🏥',\n keywords: [\n 'hospital',\n 'building',\n 'doctor',\n 'medicine',\n ],\n },\n {\n name: 'bank',\n code: '🏦',\n keywords: [\n 'bank',\n 'building',\n ],\n },\n {\n name: 'hotel',\n code: '🏨',\n keywords: [\n 'hotel',\n 'building',\n ],\n },\n {\n name: 'love_hotel',\n code: '🏩',\n keywords: [\n 'love_hotel',\n 'building',\n 'hotel',\n 'love',\n ],\n },\n {\n name: 'convenience_store',\n code: '🏪',\n keywords: [\n 'convenience_store',\n 'building',\n 'convenience',\n 'store',\n ],\n },\n {\n name: 'school',\n code: '🏫',\n keywords: [\n 'school',\n 'building',\n ],\n },\n {\n name: 'department_store',\n code: '🏬',\n keywords: [\n 'department_store',\n 'building',\n 'department',\n 'store',\n ],\n },\n {\n name: 'factory',\n code: '🏭',\n keywords: [\n 'factory',\n 'building',\n ],\n },\n {\n name: 'japanese_castle',\n code: '🏯',\n keywords: [\n 'japanese_castle',\n 'building',\n 'castle',\n 'japanese',\n ],\n },\n {\n name: 'european_castle',\n code: '🏰',\n keywords: [\n 'european_castle',\n 'building',\n 'castle',\n 'european',\n ],\n },\n {\n name: 'wedding',\n code: '💒',\n keywords: [\n 'marriage',\n 'wedding',\n 'activity',\n 'chapel',\n 'romance',\n ],\n },\n {\n name: 'tokyo_tower',\n code: '🗼',\n keywords: [\n 'tokyo_tower',\n 'tokyo',\n 'tower',\n ],\n },\n {\n name: 'statue_of_liberty',\n code: '🗽',\n keywords: [\n 'statue_of_liberty',\n 'liberty',\n 'statue',\n ],\n },\n {\n name: 'church',\n code: '⛪',\n keywords: [\n 'church',\n 'building',\n 'christian',\n 'cross',\n 'religion',\n ],\n },\n {\n name: 'mosque',\n code: '🕌',\n keywords: [\n 'mosque',\n 'islam',\n 'muslim',\n 'religion',\n ],\n },\n {\n name: 'hindu_temple',\n code: '🛕',\n keywords: [\n 'hindu_temple',\n ],\n },\n {\n name: 'synagogue',\n code: '🕍',\n keywords: [\n 'synagogue',\n 'jew',\n 'jewish',\n 'religion',\n 'temple',\n ],\n },\n {\n name: 'shinto_shrine',\n code: '⛩️',\n keywords: [\n 'shinto_shrine',\n ],\n },\n {\n name: 'kaaba',\n code: '🕋',\n keywords: [\n 'kaaba',\n 'islam',\n 'muslim',\n 'religion',\n ],\n },\n {\n name: 'fountain',\n code: '⛲',\n keywords: [\n 'fountain',\n ],\n },\n {\n name: 'tent',\n code: '⛺',\n keywords: [\n 'camping',\n 'tent',\n ],\n },\n {\n name: 'foggy',\n code: '🌁',\n keywords: [\n 'karl',\n 'foggy',\n 'fog',\n 'weather',\n ],\n },\n {\n name: 'night_with_stars',\n code: '🌃',\n keywords: [\n 'night_with_stars',\n 'night',\n 'star',\n 'weather',\n ],\n },\n {\n name: 'cityscape',\n code: '🏙️',\n keywords: [\n 'skyline',\n 'cityscape',\n ],\n },\n {\n name: 'sunrise_over_mountains',\n code: '🌄',\n keywords: [\n 'sunrise_over_mountains',\n 'morning',\n 'mountain',\n 'sun',\n 'sunrise',\n 'weather',\n ],\n },\n {\n name: 'sunrise',\n code: '🌅',\n keywords: [\n 'sunrise',\n 'morning',\n 'sun',\n 'weather',\n ],\n },\n {\n name: 'city_sunset',\n code: '🌆',\n keywords: [\n 'city_sunset',\n 'building',\n 'city',\n 'dusk',\n 'evening',\n 'landscape',\n 'sun',\n 'sunset',\n 'weather',\n ],\n },\n {\n name: 'city_sunrise',\n code: '🌇',\n keywords: [\n 'city_sunrise',\n 'building',\n 'dusk',\n 'sun',\n 'sunset',\n 'weather',\n ],\n },\n {\n name: 'bridge_at_night',\n code: '🌉',\n keywords: [\n 'bridge_at_night',\n 'bridge',\n 'night',\n 'weather',\n ],\n },\n {\n name: 'hotsprings',\n code: '♨️',\n keywords: [\n 'hotsprings',\n 'hot',\n 'springs',\n 'steaming',\n ],\n },\n {\n name: 'carousel_horse',\n code: '🎠',\n keywords: [\n 'carousel_horse',\n 'activity',\n 'carousel',\n 'entertainment',\n 'horse',\n ],\n },\n {\n name: 'ferris_wheel',\n code: '🎡',\n keywords: [\n 'ferris_wheel',\n 'activity',\n 'amusement park',\n 'entertainment',\n 'ferris',\n 'wheel',\n ],\n },\n {\n name: 'roller_coaster',\n code: '🎢',\n keywords: [\n 'roller_coaster',\n 'activity',\n 'amusement park',\n 'coaster',\n 'entertainment',\n 'roller',\n ],\n },\n {\n name: 'barber',\n code: '💈',\n keywords: [\n 'barber',\n 'haircut',\n 'pole',\n ],\n },\n {\n name: 'circus_tent',\n code: '🎪',\n keywords: [\n 'circus_tent',\n 'activity',\n 'circus',\n 'entertainment',\n 'tent',\n ],\n },\n {\n name: 'steam_locomotive',\n code: '🚂',\n keywords: [\n 'train',\n 'steam_locomotive',\n 'engine',\n 'locomotive',\n 'railway',\n 'steam',\n 'vehicle',\n ],\n },\n {\n name: 'railway_car',\n code: '🚃',\n keywords: [\n 'railway_car',\n 'car',\n 'electric',\n 'railway',\n 'train',\n 'tram',\n 'trolleybus',\n 'vehicle',\n ],\n },\n {\n name: 'bullettrain_side',\n code: '🚄',\n keywords: [\n 'train',\n 'bullettrain_side',\n 'railway',\n 'shinkansen',\n 'speed',\n 'vehicle',\n ],\n },\n {\n name: 'bullettrain_front',\n code: '🚅',\n keywords: [\n 'train',\n 'bullettrain_front',\n 'bullet',\n 'railway',\n 'shinkansen',\n 'speed',\n 'vehicle',\n ],\n },\n {\n name: 'train2',\n code: '🚆',\n keywords: [\n 'train2',\n 'railway',\n 'train',\n 'vehicle',\n ],\n },\n {\n name: 'metro',\n code: '🚇',\n keywords: [\n 'metro',\n 'subway',\n 'vehicle',\n ],\n },\n {\n name: 'light_rail',\n code: '🚈',\n keywords: [\n 'light_rail',\n 'railway',\n 'vehicle',\n ],\n },\n {\n name: 'station',\n code: '🚉',\n keywords: [\n 'station',\n 'railway',\n 'train',\n 'vehicle',\n ],\n },\n {\n name: 'tram',\n code: '🚊',\n keywords: [\n 'tram',\n 'trolleybus',\n 'vehicle',\n ],\n },\n {\n name: 'monorail',\n code: '🚝',\n keywords: [\n 'monorail',\n 'vehicle',\n ],\n },\n {\n name: 'mountain_railway',\n code: '🚞',\n keywords: [\n 'mountain_railway',\n 'car',\n 'mountain',\n 'railway',\n 'vehicle',\n ],\n },\n {\n name: 'train',\n code: '🚋',\n keywords: [\n 'train',\n 'car',\n 'tram',\n 'trolleybus',\n 'vehicle',\n ],\n },\n {\n name: 'bus',\n code: '🚌',\n keywords: [\n 'bus',\n 'vehicle',\n ],\n },\n {\n name: 'oncoming_bus',\n code: '🚍',\n keywords: [\n 'oncoming_bus',\n 'bus',\n 'oncoming',\n 'vehicle',\n ],\n },\n {\n name: 'trolleybus',\n code: '🚎',\n keywords: [\n 'trolleybus',\n 'bus',\n 'tram',\n 'trolley',\n 'vehicle',\n ],\n },\n {\n name: 'minibus',\n code: '🚐',\n keywords: [\n 'minibus',\n 'bus',\n 'vehicle',\n ],\n },\n {\n name: 'ambulance',\n code: '🚑',\n keywords: [\n 'ambulance',\n 'vehicle',\n ],\n },\n {\n name: 'fire_engine',\n code: '🚒',\n keywords: [\n 'fire_engine',\n 'engine',\n 'fire',\n 'truck',\n 'vehicle',\n ],\n },\n {\n name: 'police_car',\n code: '🚓',\n keywords: [\n 'police_car',\n 'car',\n 'patrol',\n 'police',\n 'vehicle',\n ],\n },\n {\n name: 'oncoming_police_car',\n code: '🚔',\n keywords: [\n 'oncoming_police_car',\n 'car',\n 'oncoming',\n 'police',\n 'vehicle',\n ],\n },\n {\n name: 'taxi',\n code: '🚕',\n keywords: [\n 'taxi',\n 'vehicle',\n ],\n },\n {\n name: 'oncoming_taxi',\n code: '🚖',\n keywords: [\n 'oncoming_taxi',\n 'oncoming',\n 'taxi',\n 'vehicle',\n ],\n },\n {\n name: 'car',\n code: '🚗',\n keywords: [\n 'car',\n 'red_car',\n 'automobile',\n 'vehicle',\n ],\n },\n {\n name: 'oncoming_automobile',\n code: '🚘',\n keywords: [\n 'oncoming_automobile',\n 'automobile',\n 'car',\n 'oncoming',\n 'vehicle',\n ],\n },\n {\n name: 'blue_car',\n code: '🚙',\n keywords: [\n 'blue_car',\n 'recreational',\n 'rv',\n 'vehicle',\n ],\n },\n {\n name: 'pickup_truck',\n code: '🛻',\n keywords: [\n 'pickup_truck',\n ],\n },\n {\n name: 'truck',\n code: '🚚',\n keywords: [\n 'truck',\n 'delivery',\n 'vehicle',\n ],\n },\n {\n name: 'articulated_lorry',\n code: '🚛',\n keywords: [\n 'articulated_lorry',\n 'lorry',\n 'semi',\n 'truck',\n 'vehicle',\n ],\n },\n {\n name: 'tractor',\n code: '🚜',\n keywords: [\n 'tractor',\n 'vehicle',\n ],\n },\n {\n name: 'racing_car',\n code: '🏎️',\n keywords: [\n 'racing_car',\n ],\n },\n {\n name: 'motorcycle',\n code: '🏍️',\n keywords: [\n 'motorcycle',\n ],\n },\n {\n name: 'motor_scooter',\n code: '🛵',\n keywords: [\n 'motor_scooter',\n 'motor',\n 'scooter',\n ],\n },\n {\n name: 'manual_wheelchair',\n code: '🦽',\n keywords: [\n 'manual_wheelchair',\n ],\n },\n {\n name: 'motorized_wheelchair',\n code: '🦼',\n keywords: [\n 'motorized_wheelchair',\n ],\n },\n {\n name: 'auto_rickshaw',\n code: '🛺',\n keywords: [\n 'auto_rickshaw',\n ],\n },\n {\n name: 'bike',\n code: '🚲',\n keywords: [\n 'bicycle',\n 'bike',\n 'vehicle',\n ],\n },\n {\n name: 'kick_scooter',\n code: '🛴',\n keywords: [\n 'kick_scooter',\n 'kick',\n 'scooter',\n ],\n },\n {\n name: 'skateboard',\n code: '🛹',\n keywords: [\n 'skateboard',\n ],\n },\n {\n name: 'roller_skate',\n code: '🛼',\n keywords: [\n 'roller_skate',\n ],\n },\n {\n name: 'busstop',\n code: '🚏',\n keywords: [\n 'busstop',\n 'bus',\n 'stop',\n ],\n },\n {\n name: 'motorway',\n code: '🛣️',\n keywords: [\n 'motorway',\n ],\n },\n {\n name: 'railway_track',\n code: '🛤️',\n keywords: [\n 'railway_track',\n ],\n },\n {\n name: 'oil_drum',\n code: '🛢️',\n keywords: [\n 'oil_drum',\n ],\n },\n {\n name: 'fuelpump',\n code: '⛽',\n keywords: [\n 'fuelpump',\n 'fuel',\n 'gas',\n 'pump',\n 'station',\n ],\n },\n {\n name: 'rotating_light',\n code: '🚨',\n keywords: [\n '911',\n 'emergency',\n 'rotating_light',\n 'beacon',\n 'car',\n 'light',\n 'police',\n 'revolving',\n 'vehicle',\n ],\n },\n {\n name: 'traffic_light',\n code: '🚥',\n keywords: [\n 'traffic_light',\n 'light',\n 'signal',\n 'traffic',\n ],\n },\n {\n name: 'vertical_traffic_light',\n code: '🚦',\n keywords: [\n 'semaphore',\n 'vertical_traffic_light',\n 'light',\n 'signal',\n 'traffic',\n ],\n },\n {\n name: 'stop_sign',\n code: '🛑',\n keywords: [\n 'stop_sign',\n 'octagonal',\n 'stop',\n ],\n },\n {\n name: 'construction',\n code: '🚧',\n keywords: [\n 'wip',\n 'construction',\n 'barrier',\n ],\n },\n {\n name: 'anchor',\n code: '⚓',\n keywords: [\n 'ship',\n 'anchor',\n 'tool',\n ],\n },\n {\n name: 'boat',\n code: '⛵',\n keywords: [\n 'boat',\n 'sailboat',\n 'resort',\n 'sea',\n 'vehicle',\n 'yacht',\n ],\n },\n {\n name: 'canoe',\n code: '🛶',\n keywords: [\n 'canoe',\n 'boat',\n ],\n },\n {\n name: 'speedboat',\n code: '🚤',\n keywords: [\n 'ship',\n 'speedboat',\n 'boat',\n 'vehicle',\n ],\n },\n {\n name: 'passenger_ship',\n code: '🛳️',\n keywords: [\n 'cruise',\n 'passenger_ship',\n ],\n },\n {\n name: 'ferry',\n code: '⛴️',\n keywords: [\n 'ferry',\n ],\n },\n {\n name: 'motor_boat',\n code: '🛥️',\n keywords: [\n 'motor_boat',\n ],\n },\n {\n name: 'ship',\n code: '🚢',\n keywords: [\n 'ship',\n 'vehicle',\n ],\n },\n {\n name: 'airplane',\n code: '✈️',\n keywords: [\n 'flight',\n 'airplane',\n 'vehicle',\n ],\n },\n {\n name: 'small_airplane',\n code: '🛩️',\n keywords: [\n 'flight',\n 'small_airplane',\n ],\n },\n {\n name: 'flight_departure',\n code: '🛫',\n keywords: [\n 'flight_departure',\n 'airplane',\n 'check-in',\n 'departure',\n 'departures',\n 'vehicle',\n ],\n },\n {\n name: 'flight_arrival',\n code: '🛬',\n keywords: [\n 'flight_arrival',\n 'airplane',\n 'arrivals',\n 'arriving',\n 'landing',\n 'vehicle',\n ],\n },\n {\n name: 'parachute',\n code: '🪂',\n keywords: [\n 'parachute',\n ],\n },\n {\n name: 'seat',\n code: '💺',\n keywords: [\n 'seat',\n 'chair',\n ],\n },\n {\n name: 'helicopter',\n code: '🚁',\n keywords: [\n 'helicopter',\n 'vehicle',\n ],\n },\n {\n name: 'suspension_railway',\n code: '🚟',\n keywords: [\n 'suspension_railway',\n 'railway',\n 'suspension',\n 'vehicle',\n ],\n },\n {\n name: 'mountain_cableway',\n code: '🚠',\n keywords: [\n 'mountain_cableway',\n 'cable',\n 'gondola',\n 'mountain',\n 'vehicle',\n ],\n },\n {\n name: 'aerial_tramway',\n code: '🚡',\n keywords: [\n 'aerial_tramway',\n 'aerial',\n 'cable',\n 'car',\n 'gondola',\n 'ropeway',\n 'tramway',\n 'vehicle',\n ],\n },\n {\n name: 'artificial_satellite',\n code: '🛰️',\n keywords: [\n 'orbit',\n 'space',\n 'artificial_satellite',\n ],\n },\n {\n name: 'rocket',\n code: '🚀',\n keywords: [\n 'ship',\n 'launch',\n 'rocket',\n 'space',\n 'vehicle',\n ],\n },\n {\n name: 'flying_saucer',\n code: '🛸',\n keywords: [\n 'ufo',\n 'flying_saucer',\n ],\n },\n {\n name: 'bellhop_bell',\n code: '🛎️',\n keywords: [\n 'bellhop_bell',\n ],\n },\n {\n name: 'luggage',\n code: '🧳',\n keywords: [\n 'luggage',\n ],\n },\n {\n name: 'hourglass',\n code: '⌛',\n keywords: [\n 'time',\n 'hourglass',\n 'sand',\n 'timer',\n ],\n },\n {\n name: 'hourglass_flowing_sand',\n code: '⏳',\n keywords: [\n 'time',\n 'hourglass_flowing_sand',\n 'hourglass',\n 'sand',\n 'timer',\n ],\n },\n {\n name: 'watch',\n code: '⌚',\n keywords: [\n 'time',\n 'watch',\n 'clock',\n ],\n },\n {\n name: 'alarm_clock',\n code: '⏰',\n keywords: [\n 'morning',\n 'alarm_clock',\n 'alarm',\n 'clock',\n ],\n },\n {\n name: 'stopwatch',\n code: '⏱️',\n keywords: [\n 'stopwatch',\n ],\n },\n {\n name: 'timer_clock',\n code: '⏲️',\n keywords: [\n 'timer_clock',\n ],\n },\n {\n name: 'mantelpiece_clock',\n code: '🕰️',\n keywords: [\n 'mantelpiece_clock',\n ],\n },\n {\n name: 'clock12',\n code: '🕛',\n keywords: [\n 'clock12',\n '00',\n '12',\n '12:00',\n 'clock',\n 'o’clock',\n 'twelve',\n ],\n },\n {\n name: 'clock1230',\n code: '🕧',\n keywords: [\n 'clock1230',\n '12',\n '12:30',\n '30',\n 'clock',\n 'thirty',\n 'twelve',\n ],\n },\n {\n name: 'clock1',\n code: '🕐',\n keywords: [\n 'clock1',\n '00',\n '1',\n '1:00',\n 'clock',\n 'o’clock',\n 'one',\n ],\n },\n {\n name: 'clock130',\n code: '🕜',\n keywords: [\n 'clock130',\n '1',\n '1:30',\n '30',\n 'clock',\n 'one',\n 'thirty',\n ],\n },\n {\n name: 'clock2',\n code: '🕑',\n keywords: [\n 'clock2',\n '00',\n '2',\n '2:00',\n 'clock',\n 'o’clock',\n 'two',\n ],\n },\n {\n name: 'clock230',\n code: '🕝',\n keywords: [\n 'clock230',\n '2',\n '2:30',\n '30',\n 'clock',\n 'thirty',\n 'two',\n ],\n },\n {\n name: 'clock3',\n code: '🕒',\n keywords: [\n 'clock3',\n '00',\n '3',\n '3:00',\n 'clock',\n 'o’clock',\n 'three',\n ],\n },\n {\n name: 'clock330',\n code: '🕞',\n keywords: [\n 'clock330',\n '3',\n '3:30',\n '30',\n 'clock',\n 'thirty',\n 'three',\n ],\n },\n {\n name: 'clock4',\n code: '🕓',\n keywords: [\n 'clock4',\n '00',\n '4',\n '4:00',\n 'clock',\n 'four',\n 'o’clock',\n ],\n },\n {\n name: 'clock430',\n code: '🕟',\n keywords: [\n 'clock430',\n '30',\n '4',\n '4:30',\n 'clock',\n 'four',\n 'thirty',\n ],\n },\n {\n name: 'clock5',\n code: '🕔',\n keywords: [\n 'clock5',\n '00',\n '5',\n '5:00',\n 'clock',\n 'five',\n 'o’clock',\n ],\n },\n {\n name: 'clock530',\n code: '🕠',\n keywords: [\n 'clock530',\n '30',\n '5',\n '5:30',\n 'clock',\n 'five',\n 'thirty',\n ],\n },\n {\n name: 'clock6',\n code: '🕕',\n keywords: [\n 'clock6',\n '00',\n '6',\n '6:00',\n 'clock',\n 'o’clock',\n 'six',\n ],\n },\n {\n name: 'clock630',\n code: '🕡',\n keywords: [\n 'clock630',\n '30',\n '6',\n '6:30',\n 'clock',\n 'six',\n 'thirty',\n ],\n },\n {\n name: 'clock7',\n code: '🕖',\n keywords: [\n 'clock7',\n '00',\n '7',\n '7:00',\n 'clock',\n 'o’clock',\n 'seven',\n ],\n },\n {\n name: 'clock730',\n code: '🕢',\n keywords: [\n 'clock730',\n '30',\n '7',\n '7:30',\n 'clock',\n 'seven',\n 'thirty',\n ],\n },\n {\n name: 'clock8',\n code: '🕗',\n keywords: [\n 'clock8',\n '00',\n '8',\n '8:00',\n 'clock',\n 'eight',\n 'o’clock',\n ],\n },\n {\n name: 'clock830',\n code: '🕣',\n keywords: [\n 'clock830',\n '30',\n '8',\n '8:30',\n 'clock',\n 'eight',\n 'thirty',\n ],\n },\n {\n name: 'clock9',\n code: '🕘',\n keywords: [\n 'clock9',\n '00',\n '9',\n '9:00',\n 'clock',\n 'nine',\n 'o’clock',\n ],\n },\n {\n name: 'clock930',\n code: '🕤',\n keywords: [\n 'clock930',\n '30',\n '9',\n '9:30',\n 'clock',\n 'nine',\n 'thirty',\n ],\n },\n {\n name: 'clock10',\n code: '🕙',\n keywords: [\n 'clock10',\n '00',\n '10',\n '10:00',\n 'clock',\n 'o’clock',\n 'ten',\n ],\n },\n {\n name: 'clock1030',\n code: '🕥',\n keywords: [\n 'clock1030',\n '10',\n '10:30',\n '30',\n 'clock',\n 'ten',\n 'thirty',\n ],\n },\n {\n name: 'clock11',\n code: '🕚',\n keywords: [\n 'clock11',\n '00',\n '11',\n '11:00',\n 'clock',\n 'eleven',\n 'o’clock',\n ],\n },\n {\n name: 'clock1130',\n code: '🕦',\n keywords: [\n 'clock1130',\n '11',\n '11:30',\n '30',\n 'clock',\n 'eleven',\n 'thirty',\n ],\n },\n {\n name: 'new_moon',\n code: '🌑',\n keywords: [\n 'new_moon',\n 'dark',\n 'moon',\n 'space',\n 'weather',\n ],\n },\n {\n name: 'waxing_crescent_moon',\n code: '🌒',\n keywords: [\n 'waxing_crescent_moon',\n 'crescent',\n 'moon',\n 'space',\n 'waxing',\n 'weather',\n ],\n },\n {\n name: 'first_quarter_moon',\n code: '🌓',\n keywords: [\n 'first_quarter_moon',\n 'moon',\n 'quarter',\n 'space',\n 'weather',\n ],\n },\n {\n name: 'moon',\n code: '🌔',\n keywords: [\n 'moon',\n 'waxing_gibbous_moon',\n 'gibbous',\n 'space',\n 'waxing',\n 'weather',\n ],\n },\n {\n name: 'full_moon',\n code: '🌕',\n keywords: [\n 'full_moon',\n 'full',\n 'moon',\n 'space',\n 'weather',\n ],\n },\n {\n name: 'waning_gibbous_moon',\n code: '🌖',\n keywords: [\n 'waning_gibbous_moon',\n 'gibbous',\n 'moon',\n 'space',\n 'waning',\n 'weather',\n ],\n },\n {\n name: 'last_quarter_moon',\n code: '🌗',\n keywords: [\n 'last_quarter_moon',\n 'moon',\n 'quarter',\n 'space',\n 'weather',\n ],\n },\n {\n name: 'waning_crescent_moon',\n code: '🌘',\n keywords: [\n 'waning_crescent_moon',\n 'crescent',\n 'moon',\n 'space',\n 'waning',\n 'weather',\n ],\n },\n {\n name: 'crescent_moon',\n code: '🌙',\n keywords: [\n 'night',\n 'crescent_moon',\n 'crescent',\n 'moon',\n 'space',\n 'weather',\n ],\n },\n {\n name: 'new_moon_with_face',\n code: '🌚',\n keywords: [\n 'new_moon_with_face',\n 'face',\n 'moon',\n 'space',\n 'weather',\n ],\n },\n {\n name: 'first_quarter_moon_with_face',\n code: '🌛',\n keywords: [\n 'first_quarter_moon_with_face',\n 'face',\n 'moon',\n 'quarter',\n 'space',\n 'weather',\n ],\n },\n {\n name: 'last_quarter_moon_with_face',\n code: '🌜',\n keywords: [\n 'last_quarter_moon_with_face',\n 'face',\n 'moon',\n 'quarter',\n 'space',\n 'weather',\n ],\n },\n {\n name: 'thermometer',\n code: '🌡️',\n keywords: [\n 'thermometer',\n ],\n },\n {\n name: 'sunny',\n code: '☀️',\n keywords: [\n 'weather',\n 'sunny',\n 'bright',\n 'rays',\n 'space',\n 'sun',\n ],\n },\n {\n name: 'full_moon_with_face',\n code: '🌝',\n keywords: [\n 'full_moon_with_face',\n 'bright',\n 'face',\n 'full',\n 'moon',\n 'space',\n 'weather',\n ],\n },\n {\n name: 'sun_with_face',\n code: '🌞',\n keywords: [\n 'summer',\n 'sun_with_face',\n 'bright',\n 'face',\n 'space',\n 'sun',\n 'weather',\n ],\n },\n {\n name: 'ringed_planet',\n code: '🪐',\n keywords: [\n 'ringed_planet',\n ],\n },\n {\n name: 'star',\n code: '⭐',\n keywords: [\n 'star',\n ],\n },\n {\n name: 'star2',\n code: '🌟',\n keywords: [\n 'star2',\n 'glittery',\n 'glow',\n 'shining',\n 'sparkle',\n 'star',\n ],\n },\n {\n name: 'stars',\n code: '🌠',\n keywords: [\n 'stars',\n 'activity',\n 'falling',\n 'shooting',\n 'space',\n 'star',\n ],\n },\n {\n name: 'milky_way',\n code: '🌌',\n keywords: [\n 'milky_way',\n 'milky way',\n 'space',\n 'weather',\n ],\n },\n {\n name: 'cloud',\n code: '☁️',\n keywords: [\n 'cloud',\n 'weather',\n ],\n },\n {\n name: 'partly_sunny',\n code: '⛅',\n keywords: [\n 'weather',\n 'cloud',\n 'partly_sunny',\n 'sun',\n ],\n },\n {\n name: 'cloud_with_lightning_and_rain',\n code: '⛈️',\n keywords: [\n 'cloud_with_lightning_and_rain',\n ],\n },\n {\n name: 'sun_behind_small_cloud',\n code: '🌤️',\n keywords: [\n 'sun_behind_small_cloud',\n ],\n },\n {\n name: 'sun_behind_large_cloud',\n code: '🌥️',\n keywords: [\n 'sun_behind_large_cloud',\n ],\n },\n {\n name: 'sun_behind_rain_cloud',\n code: '🌦️',\n keywords: [\n 'sun_behind_rain_cloud',\n ],\n },\n {\n name: 'cloud_with_rain',\n code: '🌧️',\n keywords: [\n 'cloud_with_rain',\n ],\n },\n {\n name: 'cloud_with_snow',\n code: '🌨️',\n keywords: [\n 'cloud_with_snow',\n ],\n },\n {\n name: 'cloud_with_lightning',\n code: '🌩️',\n keywords: [\n 'cloud_with_lightning',\n ],\n },\n {\n name: 'tornado',\n code: '🌪️',\n keywords: [\n 'tornado',\n ],\n },\n {\n name: 'fog',\n code: '🌫️',\n keywords: [\n 'fog',\n ],\n },\n {\n name: 'wind_face',\n code: '🌬️',\n keywords: [\n 'wind_face',\n ],\n },\n {\n name: 'cyclone',\n code: '🌀',\n keywords: [\n 'swirl',\n 'cyclone',\n 'dizzy',\n 'twister',\n 'typhoon',\n 'weather',\n ],\n },\n {\n name: 'rainbow',\n code: '🌈',\n keywords: [\n 'rainbow',\n 'rain',\n 'weather',\n ],\n },\n {\n name: 'closed_umbrella',\n code: '🌂',\n keywords: [\n 'weather',\n 'rain',\n 'closed_umbrella',\n 'clothing',\n 'umbrella',\n ],\n },\n {\n name: 'open_umbrella',\n code: '☂️',\n keywords: [\n 'open_umbrella',\n 'clothing',\n 'rain',\n 'umbrella',\n 'weather',\n ],\n },\n {\n name: 'umbrella',\n code: '☔',\n keywords: [\n 'rain',\n 'weather',\n 'umbrella',\n 'clothing',\n 'drop',\n ],\n },\n {\n name: 'parasol_on_ground',\n code: '⛱️',\n keywords: [\n 'beach_umbrella',\n 'parasol_on_ground',\n ],\n },\n {\n name: 'zap',\n code: '⚡',\n keywords: [\n 'lightning',\n 'thunder',\n 'zap',\n 'danger',\n 'electric',\n 'electricity',\n 'voltage',\n ],\n },\n {\n name: 'snowflake',\n code: '❄️',\n keywords: [\n 'winter',\n 'cold',\n 'weather',\n 'snowflake',\n 'snow',\n ],\n },\n {\n name: 'snowman_with_snow',\n code: '☃️',\n keywords: [\n 'winter',\n 'christmas',\n 'snowman_with_snow',\n 'cold',\n 'snow',\n 'snowman',\n 'weather',\n ],\n },\n {\n name: 'snowman',\n code: '⛄',\n keywords: [\n 'winter',\n 'snowman',\n 'cold',\n 'snow',\n 'weather',\n ],\n },\n {\n name: 'comet',\n code: '☄️',\n keywords: [\n 'comet',\n 'space',\n ],\n },\n {\n name: 'fire',\n code: '🔥',\n keywords: [\n 'burn',\n 'fire',\n 'flame',\n 'tool',\n ],\n },\n {\n name: 'droplet',\n code: '💧',\n keywords: [\n 'water',\n 'droplet',\n 'cold',\n 'comic',\n 'drop',\n 'sweat',\n 'weather',\n ],\n },\n {\n name: 'ocean',\n code: '🌊',\n keywords: [\n 'sea',\n 'ocean',\n 'water',\n 'wave',\n 'weather',\n ],\n },\n {\n code: 'activities',\n header: true,\n icon: Activities,\n },\n {\n name: 'jack_o_lantern',\n code: '🎃',\n keywords: [\n 'halloween',\n 'jack_o_lantern',\n 'activity',\n 'celebration',\n 'entertainment',\n 'jack',\n 'lantern',\n ],\n },\n {\n name: 'christmas_tree',\n code: '🎄',\n keywords: [\n 'christmas_tree',\n 'activity',\n 'celebration',\n 'christmas',\n 'entertainment',\n 'tree',\n ],\n },\n {\n name: 'fireworks',\n code: '🎆',\n keywords: [\n 'festival',\n 'celebration',\n 'fireworks',\n 'activity',\n 'entertainment',\n ],\n },\n {\n name: 'sparkler',\n code: '🎇',\n keywords: [\n 'sparkler',\n 'activity',\n 'celebration',\n 'entertainment',\n 'fireworks',\n 'sparkle',\n ],\n },\n {\n name: 'firecracker',\n code: '🧨',\n keywords: [\n 'firecracker',\n ],\n },\n {\n name: 'sparkles',\n code: '✨',\n keywords: [\n 'shiny',\n 'sparkles',\n 'entertainment',\n 'sparkle',\n 'star',\n ],\n },\n {\n name: 'balloon',\n code: '🎈',\n keywords: [\n 'party',\n 'birthday',\n 'balloon',\n 'activity',\n 'celebration',\n 'entertainment',\n ],\n },\n {\n name: 'tada',\n code: '🎉',\n keywords: [\n 'hooray',\n 'party',\n 'tada',\n 'activity',\n 'celebration',\n 'entertainment',\n 'popper',\n ],\n },\n {\n name: 'confetti_ball',\n code: '🎊',\n keywords: [\n 'confetti_ball',\n 'activity',\n 'ball',\n 'celebration',\n 'confetti',\n 'entertainment',\n ],\n },\n {\n name: 'tanabata_tree',\n code: '🎋',\n keywords: [\n 'tanabata_tree',\n 'activity',\n 'banner',\n 'celebration',\n 'entertainment',\n 'japanese',\n 'tree',\n ],\n },\n {\n name: 'bamboo',\n code: '🎍',\n keywords: [\n 'bamboo',\n 'activity',\n 'celebration',\n 'japanese',\n 'pine',\n 'plant',\n ],\n },\n {\n name: 'dolls',\n code: '🎎',\n keywords: [\n 'dolls',\n 'activity',\n 'celebration',\n 'doll',\n 'entertainment',\n 'festival',\n 'japanese',\n ],\n },\n {\n name: 'flags',\n code: '🎏',\n keywords: [\n 'flags',\n 'activity',\n 'carp',\n 'celebration',\n 'entertainment',\n 'flag',\n 'streamer',\n ],\n },\n {\n name: 'wind_chime',\n code: '🎐',\n keywords: [\n 'wind_chime',\n 'activity',\n 'bell',\n 'celebration',\n 'chime',\n 'entertainment',\n 'wind',\n ],\n },\n {\n name: 'rice_scene',\n code: '🎑',\n keywords: [\n 'rice_scene',\n 'activity',\n 'celebration',\n 'ceremony',\n 'entertainment',\n 'moon',\n ],\n },\n {\n name: 'red_envelope',\n code: '🧧',\n keywords: [\n 'red_envelope',\n ],\n },\n {\n name: 'ribbon',\n code: '🎀',\n keywords: [\n 'ribbon',\n 'celebration',\n ],\n },\n {\n name: 'gift',\n code: '🎁',\n keywords: [\n 'present',\n 'birthday',\n 'christmas',\n 'gift',\n 'box',\n 'celebration',\n 'entertainment',\n 'wrapped',\n ],\n },\n {\n name: 'reminder_ribbon',\n code: '🎗️',\n keywords: [\n 'reminder_ribbon',\n ],\n },\n {\n name: 'tickets',\n code: '🎟️',\n keywords: [\n 'tickets',\n ],\n },\n {\n name: 'ticket',\n code: '🎫',\n keywords: [\n 'ticket',\n 'activity',\n 'admission',\n 'entertainment',\n ],\n },\n {\n name: 'medal_military',\n code: '🎖️',\n keywords: [\n 'medal_military',\n ],\n },\n {\n name: 'trophy',\n code: '🏆',\n keywords: [\n 'award',\n 'contest',\n 'winner',\n 'trophy',\n 'prize',\n ],\n },\n {\n name: 'medal_sports',\n code: '🏅',\n keywords: [\n 'gold',\n 'winner',\n 'medal_sports',\n 'medal',\n ],\n },\n {\n name: '1st_place_medal',\n code: '🥇',\n keywords: [\n 'gold',\n '1st_place_medal',\n 'first',\n 'medal',\n ],\n },\n {\n name: '2nd_place_medal',\n code: '🥈',\n keywords: [\n 'silver',\n '2nd_place_medal',\n 'medal',\n 'second',\n ],\n },\n {\n name: '3rd_place_medal',\n code: '🥉',\n keywords: [\n 'bronze',\n '3rd_place_medal',\n 'medal',\n 'third',\n ],\n },\n {\n name: 'soccer',\n code: '⚽',\n keywords: [\n 'sports',\n 'soccer',\n 'ball',\n ],\n },\n {\n name: 'baseball',\n code: '⚾',\n keywords: [\n 'sports',\n 'baseball',\n 'ball',\n ],\n },\n {\n name: 'softball',\n code: '🥎',\n keywords: [\n 'softball',\n ],\n },\n {\n name: 'basketball',\n code: '🏀',\n keywords: [\n 'sports',\n 'basketball',\n 'ball',\n 'hoop',\n ],\n },\n {\n name: 'volleyball',\n code: '🏐',\n keywords: [\n 'volleyball',\n 'ball',\n 'game',\n ],\n },\n {\n name: 'football',\n code: '🏈',\n keywords: [\n 'sports',\n 'football',\n 'american',\n 'ball',\n ],\n },\n {\n name: 'rugby_football',\n code: '🏉',\n keywords: [\n 'rugby_football',\n 'ball',\n 'football',\n 'rugby',\n ],\n },\n {\n name: 'tennis',\n code: '🎾',\n keywords: [\n 'sports',\n 'tennis',\n 'ball',\n 'racquet',\n ],\n },\n {\n name: 'flying_disc',\n code: '🥏',\n keywords: [\n 'flying_disc',\n ],\n },\n {\n name: 'bowling',\n code: '🎳',\n keywords: [\n 'bowling',\n 'ball',\n 'game',\n ],\n },\n {\n name: 'cricket_game',\n code: '🏏',\n keywords: [\n 'cricket_game',\n 'ball',\n 'bat',\n 'cricket',\n 'game',\n ],\n },\n {\n name: 'field_hockey',\n code: '🏑',\n keywords: [\n 'field_hockey',\n 'ball',\n 'field',\n 'game',\n 'hockey',\n 'stick',\n ],\n },\n {\n name: 'ice_hockey',\n code: '🏒',\n keywords: [\n 'ice_hockey',\n 'game',\n 'hockey',\n 'ice',\n 'puck',\n 'stick',\n ],\n },\n {\n name: 'lacrosse',\n code: '🥍',\n keywords: [\n 'lacrosse',\n ],\n },\n {\n name: 'ping_pong',\n code: '🏓',\n keywords: [\n 'ping_pong',\n 'ball',\n 'bat',\n 'game',\n 'paddle',\n 'table tennis',\n ],\n },\n {\n name: 'badminton',\n code: '🏸',\n keywords: [\n 'badminton',\n 'birdie',\n 'game',\n 'racquet',\n 'shuttlecock',\n ],\n },\n {\n name: 'boxing_glove',\n code: '🥊',\n keywords: [\n 'boxing_glove',\n 'boxing',\n 'glove',\n ],\n },\n {\n name: 'martial_arts_uniform',\n code: '🥋',\n keywords: [\n 'martial_arts_uniform',\n 'judo',\n 'karate',\n 'martial arts',\n 'taekwondo',\n 'uniform',\n ],\n },\n {\n name: 'goal_net',\n code: '🥅',\n keywords: [\n 'goal_net',\n 'goal',\n 'net',\n ],\n },\n {\n name: 'golf',\n code: '⛳',\n keywords: [\n 'golf',\n 'flag',\n 'hole',\n ],\n },\n {\n name: 'ice_skate',\n code: '⛸️',\n keywords: [\n 'skating',\n 'ice_skate',\n ],\n },\n {\n name: 'fishing_pole_and_fish',\n code: '🎣',\n keywords: [\n 'fishing_pole_and_fish',\n 'entertainment',\n 'fish',\n 'pole',\n ],\n },\n {\n name: 'diving_mask',\n code: '🤿',\n keywords: [\n 'diving_mask',\n ],\n },\n {\n name: 'running_shirt_with_sash',\n code: '🎽',\n keywords: [\n 'marathon',\n 'running_shirt_with_sash',\n 'running',\n 'sash',\n 'shirt',\n ],\n },\n {\n name: 'ski',\n code: '🎿',\n keywords: [\n 'ski',\n 'snow',\n ],\n },\n {\n name: 'sled',\n code: '🛷',\n keywords: [\n 'sled',\n ],\n },\n {\n name: 'curling_stone',\n code: '🥌',\n keywords: [\n 'curling_stone',\n ],\n },\n {\n name: 'dart',\n code: '🎯',\n keywords: [\n 'target',\n 'dart',\n 'activity',\n 'bull',\n 'bullseye',\n 'entertainment',\n 'eye',\n 'game',\n 'hit',\n ],\n },\n {\n name: 'yo_yo',\n code: '🪀',\n keywords: [\n 'yo_yo',\n ],\n },\n {\n name: 'kite',\n code: '🪁',\n keywords: [\n 'kite',\n ],\n },\n {\n name: '8ball',\n code: '🎱',\n keywords: [\n 'pool',\n 'billiards',\n '8ball',\n '8',\n '8 ball',\n 'ball',\n 'billiard',\n 'eight',\n 'game',\n ],\n },\n {\n name: 'crystal_ball',\n code: '🔮',\n keywords: [\n 'fortune',\n 'crystal_ball',\n 'ball',\n 'crystal',\n 'fairy tale',\n 'fantasy',\n 'tool',\n ],\n },\n {\n name: 'magic_wand',\n code: '🪄',\n keywords: [\n 'magic_wand',\n ],\n },\n {\n name: 'nazar_amulet',\n code: '🧿',\n keywords: [\n 'nazar_amulet',\n ],\n },\n {\n name: 'video_game',\n code: '🎮',\n keywords: [\n 'play',\n 'controller',\n 'console',\n 'video_game',\n 'entertainment',\n 'game',\n 'video game',\n ],\n },\n {\n name: 'joystick',\n code: '🕹️',\n keywords: [\n 'joystick',\n ],\n },\n {\n name: 'slot_machine',\n code: '🎰',\n keywords: [\n 'slot_machine',\n 'activity',\n 'game',\n 'slot',\n ],\n },\n {\n name: 'game_die',\n code: '🎲',\n keywords: [\n 'dice',\n 'gambling',\n 'game_die',\n 'die',\n 'entertainment',\n 'game',\n ],\n },\n {\n name: 'jigsaw',\n code: '🧩',\n keywords: [\n 'jigsaw',\n ],\n },\n {\n name: 'teddy_bear',\n code: '🧸',\n keywords: [\n 'teddy_bear',\n ],\n },\n {\n name: 'pinata',\n code: '🪅',\n keywords: [\n 'pinata',\n ],\n },\n {\n name: 'nesting_dolls',\n code: '🪆',\n keywords: [\n 'nesting_dolls',\n ],\n },\n {\n name: 'spades',\n code: '♠️',\n keywords: [\n 'spades',\n 'card',\n 'game',\n 'spade',\n 'suit',\n ],\n },\n {\n name: 'hearts',\n code: '♥️',\n keywords: [\n 'hearts',\n 'card',\n 'game',\n 'heart',\n 'suit',\n ],\n },\n {\n name: 'diamonds',\n code: '♦️',\n keywords: [\n 'diamonds',\n 'card',\n 'diamond',\n 'game',\n 'suit',\n ],\n },\n {\n name: 'clubs',\n code: '♣️',\n keywords: [\n 'clubs',\n 'card',\n 'club',\n 'game',\n 'suit',\n ],\n },\n {\n name: 'chess_pawn',\n code: '♟️',\n keywords: [\n 'chess_pawn',\n ],\n },\n {\n name: 'black_joker',\n code: '🃏',\n keywords: [\n 'black_joker',\n 'card',\n 'entertainment',\n 'game',\n 'joker',\n 'playing',\n ],\n },\n {\n name: 'mahjong',\n code: '🀄',\n keywords: [\n 'mahjong',\n 'game',\n 'red',\n ],\n },\n {\n name: 'flower_playing_cards',\n code: '🎴',\n keywords: [\n 'flower_playing_cards',\n 'activity',\n 'card',\n 'entertainment',\n 'flower',\n 'game',\n 'japanese',\n 'playing',\n ],\n },\n {\n name: 'performing_arts',\n code: '🎭',\n keywords: [\n 'theater',\n 'drama',\n 'performing_arts',\n 'activity',\n 'art',\n 'entertainment',\n 'mask',\n 'performing',\n 'theatre',\n ],\n },\n {\n name: 'framed_picture',\n code: '🖼️',\n keywords: [\n 'framed_picture',\n ],\n },\n {\n name: 'art',\n code: '🎨',\n keywords: [\n 'design',\n 'paint',\n 'art',\n 'activity',\n 'entertainment',\n 'museum',\n 'painting',\n 'palette',\n ],\n },\n {\n name: 'thread',\n code: '🧵',\n keywords: [\n 'thread',\n ],\n },\n {\n name: 'sewing_needle',\n code: '🪡',\n keywords: [\n 'sewing_needle',\n ],\n },\n {\n name: 'yarn',\n code: '🧶',\n keywords: [\n 'yarn',\n ],\n },\n {\n name: 'knot',\n code: '🪢',\n keywords: [\n 'knot',\n ],\n },\n {\n code: 'objects',\n header: true,\n icon: Objects,\n },\n {\n name: 'eyeglasses',\n code: '👓',\n keywords: [\n 'glasses',\n 'eyeglasses',\n 'clothing',\n 'eye',\n 'eyewear',\n ],\n },\n {\n name: 'dark_sunglasses',\n code: '🕶️',\n keywords: [\n 'dark_sunglasses',\n ],\n },\n {\n name: 'goggles',\n code: '🥽',\n keywords: [\n 'goggles',\n ],\n },\n {\n name: 'lab_coat',\n code: '🥼',\n keywords: [\n 'lab_coat',\n ],\n },\n {\n name: 'safety_vest',\n code: '🦺',\n keywords: [\n 'safety_vest',\n ],\n },\n {\n name: 'necktie',\n code: '👔',\n keywords: [\n 'shirt',\n 'formal',\n 'necktie',\n 'clothing',\n ],\n },\n {\n name: 'shirt',\n code: '👕',\n keywords: [\n 'shirt',\n 'tshirt',\n 'clothing',\n ],\n },\n {\n name: 'jeans',\n code: '👖',\n keywords: [\n 'pants',\n 'jeans',\n 'clothing',\n 'trousers',\n ],\n },\n {\n name: 'scarf',\n code: '🧣',\n keywords: [\n 'scarf',\n ],\n },\n {\n name: 'gloves',\n code: '🧤',\n keywords: [\n 'gloves',\n ],\n },\n {\n name: 'coat',\n code: '🧥',\n keywords: [\n 'coat',\n ],\n },\n {\n name: 'socks',\n code: '🧦',\n keywords: [\n 'socks',\n ],\n },\n {\n name: 'dress',\n code: '👗',\n keywords: [\n 'dress',\n 'clothing',\n ],\n },\n {\n name: 'kimono',\n code: '👘',\n keywords: [\n 'kimono',\n 'clothing',\n ],\n },\n {\n name: 'sari',\n code: '🥻',\n keywords: [\n 'sari',\n ],\n },\n {\n name: 'one_piece_swimsuit',\n code: '🩱',\n keywords: [\n 'one_piece_swimsuit',\n ],\n },\n {\n name: 'swim_brief',\n code: '🩲',\n keywords: [\n 'swim_brief',\n ],\n },\n {\n name: 'shorts',\n code: '🩳',\n keywords: [\n 'shorts',\n ],\n },\n {\n name: 'bikini',\n code: '👙',\n keywords: [\n 'beach',\n 'bikini',\n 'clothing',\n 'swim',\n ],\n },\n {\n name: 'womans_clothes',\n code: '👚',\n keywords: [\n 'womans_clothes',\n 'clothing',\n 'woman',\n ],\n },\n {\n name: 'purse',\n code: '👛',\n keywords: [\n 'purse',\n 'clothing',\n 'coin',\n ],\n },\n {\n name: 'handbag',\n code: '👜',\n keywords: [\n 'bag',\n 'handbag',\n 'clothing',\n ],\n },\n {\n name: 'pouch',\n code: '👝',\n keywords: [\n 'bag',\n 'pouch',\n 'clothing',\n ],\n },\n {\n name: 'shopping',\n code: '🛍️',\n keywords: [\n 'bags',\n 'shopping',\n ],\n },\n {\n name: 'school_satchel',\n code: '🎒',\n keywords: [\n 'school_satchel',\n 'activity',\n 'bag',\n 'satchel',\n 'school',\n ],\n },\n {\n name: 'thong_sandal',\n code: '🩴',\n keywords: [\n 'thong_sandal',\n ],\n },\n {\n name: 'mans_shoe',\n code: '👞',\n keywords: [\n 'mans_shoe',\n 'shoe',\n 'clothing',\n 'man',\n ],\n },\n {\n name: 'athletic_shoe',\n code: '👟',\n keywords: [\n 'sneaker',\n 'sport',\n 'running',\n 'athletic_shoe',\n 'athletic',\n 'clothing',\n 'shoe',\n ],\n },\n {\n name: 'hiking_boot',\n code: '🥾',\n keywords: [\n 'hiking_boot',\n ],\n },\n {\n name: 'flat_shoe',\n code: '🥿',\n keywords: [\n 'flat_shoe',\n ],\n },\n {\n name: 'high_heel',\n code: '👠',\n keywords: [\n 'shoe',\n 'high_heel',\n 'clothing',\n 'heel',\n 'woman',\n ],\n },\n {\n name: 'sandal',\n code: '👡',\n keywords: [\n 'shoe',\n 'sandal',\n 'clothing',\n 'woman',\n ],\n },\n {\n name: 'ballet_shoes',\n code: '🩰',\n keywords: [\n 'ballet_shoes',\n ],\n },\n {\n name: 'boot',\n code: '👢',\n keywords: [\n 'boot',\n 'clothing',\n 'shoe',\n 'woman',\n ],\n },\n {\n name: 'crown',\n code: '👑',\n keywords: [\n 'king',\n 'queen',\n 'royal',\n 'crown',\n 'clothing',\n ],\n },\n {\n name: 'womans_hat',\n code: '👒',\n keywords: [\n 'womans_hat',\n 'clothing',\n 'hat',\n 'woman',\n ],\n },\n {\n name: 'tophat',\n code: '🎩',\n keywords: [\n 'hat',\n 'classy',\n 'tophat',\n 'activity',\n 'clothing',\n 'entertainment',\n 'top',\n ],\n },\n {\n name: 'mortar_board',\n code: '🎓',\n keywords: [\n 'education',\n 'college',\n 'university',\n 'graduation',\n 'mortar_board',\n 'activity',\n 'cap',\n 'celebration',\n 'clothing',\n 'hat',\n ],\n },\n {\n name: 'billed_cap',\n code: '🧢',\n keywords: [\n 'billed_cap',\n ],\n },\n {\n name: 'military_helmet',\n code: '🪖',\n keywords: [\n 'military_helmet',\n ],\n },\n {\n name: 'rescue_worker_helmet',\n code: '⛑️',\n keywords: [\n 'rescue_worker_helmet',\n ],\n },\n {\n name: 'prayer_beads',\n code: '📿',\n keywords: [\n 'prayer_beads',\n 'beads',\n 'clothing',\n 'necklace',\n 'prayer',\n 'religion',\n ],\n },\n {\n name: 'lipstick',\n code: '💄',\n keywords: [\n 'makeup',\n 'lipstick',\n 'cosmetics',\n ],\n },\n {\n name: 'ring',\n code: '💍',\n keywords: [\n 'wedding',\n 'marriage',\n 'engaged',\n 'ring',\n 'diamond',\n 'romance',\n ],\n },\n {\n name: 'gem',\n code: '💎',\n keywords: [\n 'diamond',\n 'gem',\n 'jewel',\n 'romance',\n ],\n },\n {\n name: 'mute',\n code: '🔇',\n keywords: [\n 'sound',\n 'volume',\n 'mute',\n 'quiet',\n 'silent',\n 'speaker',\n ],\n },\n {\n name: 'speaker',\n code: '🔈',\n keywords: [\n 'speaker',\n 'volume',\n ],\n },\n {\n name: 'sound',\n code: '🔉',\n keywords: [\n 'volume',\n 'sound',\n 'low',\n 'speaker',\n 'wave',\n ],\n },\n {\n name: 'loud_sound',\n code: '🔊',\n keywords: [\n 'volume',\n 'loud_sound',\n '3',\n 'entertainment',\n 'high',\n 'loud',\n 'speaker',\n 'three',\n ],\n },\n {\n name: 'loudspeaker',\n code: '📢',\n keywords: [\n 'announcement',\n 'loudspeaker',\n 'communication',\n 'loud',\n 'public address',\n ],\n },\n {\n name: 'mega',\n code: '📣',\n keywords: [\n 'mega',\n 'cheering',\n 'communication',\n 'megaphone',\n ],\n },\n {\n name: 'postal_horn',\n code: '📯',\n keywords: [\n 'postal_horn',\n 'communication',\n 'entertainment',\n 'horn',\n 'post',\n 'postal',\n ],\n },\n {\n name: 'bell',\n code: '🔔',\n keywords: [\n 'sound',\n 'notification',\n 'bell',\n ],\n },\n {\n name: 'no_bell',\n code: '🔕',\n keywords: [\n 'volume',\n 'off',\n 'no_bell',\n 'bell',\n 'forbidden',\n 'mute',\n 'no',\n 'not',\n 'prohibited',\n 'quiet',\n 'silent',\n ],\n },\n {\n name: 'musical_score',\n code: '🎼',\n keywords: [\n 'musical_score',\n 'activity',\n 'entertainment',\n 'music',\n 'score',\n ],\n },\n {\n name: 'musical_note',\n code: '🎵',\n keywords: [\n 'musical_note',\n 'activity',\n 'entertainment',\n 'music',\n 'note',\n ],\n },\n {\n name: 'notes',\n code: '🎶',\n keywords: [\n 'music',\n 'notes',\n 'activity',\n 'entertainment',\n 'note',\n ],\n },\n {\n name: 'studio_microphone',\n code: '🎙️',\n keywords: [\n 'podcast',\n 'studio_microphone',\n ],\n },\n {\n name: 'level_slider',\n code: '🎚️',\n keywords: [\n 'level_slider',\n ],\n },\n {\n name: 'control_knobs',\n code: '🎛️',\n keywords: [\n 'control_knobs',\n ],\n },\n {\n name: 'microphone',\n code: '🎤',\n keywords: [\n 'sing',\n 'microphone',\n 'activity',\n 'entertainment',\n 'karaoke',\n 'mic',\n ],\n },\n {\n name: 'headphones',\n code: '🎧',\n keywords: [\n 'music',\n 'earphones',\n 'headphones',\n 'activity',\n 'earbud',\n 'entertainment',\n 'headphone',\n ],\n },\n {\n name: 'radio',\n code: '📻',\n keywords: [\n 'podcast',\n 'radio',\n 'entertainment',\n 'video',\n ],\n },\n {\n name: 'saxophone',\n code: '🎷',\n keywords: [\n 'saxophone',\n 'activity',\n 'entertainment',\n 'instrument',\n 'music',\n 'sax',\n ],\n },\n {\n name: 'accordion',\n code: '🪗',\n keywords: [\n 'accordion',\n ],\n },\n {\n name: 'guitar',\n code: '🎸',\n keywords: [\n 'rock',\n 'guitar',\n 'activity',\n 'entertainment',\n 'instrument',\n 'music',\n ],\n },\n {\n name: 'musical_keyboard',\n code: '🎹',\n keywords: [\n 'piano',\n 'musical_keyboard',\n 'activity',\n 'entertainment',\n 'instrument',\n 'keyboard',\n 'music',\n ],\n },\n {\n name: 'trumpet',\n code: '🎺',\n keywords: [\n 'trumpet',\n 'activity',\n 'entertainment',\n 'instrument',\n 'music',\n ],\n },\n {\n name: 'violin',\n code: '🎻',\n keywords: [\n 'violin',\n 'activity',\n 'entertainment',\n 'instrument',\n 'music',\n ],\n },\n {\n name: 'banjo',\n code: '🪕',\n keywords: [\n 'banjo',\n ],\n },\n {\n name: 'drum',\n code: '🥁',\n keywords: [\n 'drum',\n 'drumsticks',\n 'music',\n ],\n },\n {\n name: 'long_drum',\n code: '🪘',\n keywords: [\n 'long_drum',\n ],\n },\n {\n name: 'iphone',\n code: '📱',\n keywords: [\n 'smartphone',\n 'mobile',\n 'iphone',\n 'cell',\n 'communication',\n 'phone',\n 'telephone',\n ],\n },\n {\n name: 'calling',\n code: '📲',\n keywords: [\n 'call',\n 'incoming',\n 'calling',\n 'arrow',\n 'cell',\n 'communication',\n 'mobile',\n 'phone',\n 'receive',\n 'telephone',\n ],\n },\n {\n name: 'phone',\n code: '☎️',\n keywords: [\n 'phone',\n 'telephone',\n ],\n },\n {\n name: 'telephone_receiver',\n code: '📞',\n keywords: [\n 'phone',\n 'call',\n 'telephone_receiver',\n 'communication',\n 'receiver',\n 'telephone',\n ],\n },\n {\n name: 'pager',\n code: '📟',\n keywords: [\n 'pager',\n 'communication',\n ],\n },\n {\n name: 'fax',\n code: '📠',\n keywords: [\n 'fax',\n 'communication',\n ],\n },\n {\n name: 'battery',\n code: '🔋',\n keywords: [\n 'power',\n 'battery',\n ],\n },\n {\n name: 'electric_plug',\n code: '🔌',\n keywords: [\n 'electric_plug',\n 'electric',\n 'electricity',\n 'plug',\n ],\n },\n {\n name: 'computer',\n code: '💻',\n keywords: [\n 'desktop',\n 'screen',\n 'computer',\n 'pc',\n 'personal',\n ],\n },\n {\n name: 'desktop_computer',\n code: '🖥️',\n keywords: [\n 'desktop_computer',\n ],\n },\n {\n name: 'printer',\n code: '🖨️',\n keywords: [\n 'printer',\n ],\n },\n {\n name: 'keyboard',\n code: '⌨️',\n keywords: [\n 'keyboard',\n 'computer',\n ],\n },\n {\n name: 'computer_mouse',\n code: '🖱️',\n keywords: [\n 'computer_mouse',\n ],\n },\n {\n name: 'trackball',\n code: '🖲️',\n keywords: [\n 'trackball',\n ],\n },\n {\n name: 'minidisc',\n code: '💽',\n keywords: [\n 'minidisc',\n 'computer',\n 'disk',\n 'entertainment',\n 'minidisk',\n 'optical',\n ],\n },\n {\n name: 'floppy_disk',\n code: '💾',\n keywords: [\n 'save',\n 'floppy_disk',\n 'computer',\n 'disk',\n 'floppy',\n ],\n },\n {\n name: 'cd',\n code: '💿',\n keywords: [\n 'cd',\n 'blu-ray',\n 'computer',\n 'disk',\n 'dvd',\n 'optical',\n ],\n },\n {\n name: 'dvd',\n code: '📀',\n keywords: [\n 'dvd',\n 'blu-ray',\n 'cd',\n 'computer',\n 'disk',\n 'entertainment',\n 'optical',\n ],\n },\n {\n name: 'abacus',\n code: '🧮',\n keywords: [\n 'abacus',\n ],\n },\n {\n name: 'movie_camera',\n code: '🎥',\n keywords: [\n 'film',\n 'video',\n 'movie_camera',\n 'activity',\n 'camera',\n 'cinema',\n 'entertainment',\n 'movie',\n ],\n },\n {\n name: 'film_strip',\n code: '🎞️',\n keywords: [\n 'film_strip',\n ],\n },\n {\n name: 'film_projector',\n code: '📽️',\n keywords: [\n 'film_projector',\n ],\n },\n {\n name: 'clapper',\n code: '🎬',\n keywords: [\n 'film',\n 'clapper',\n 'activity',\n 'entertainment',\n 'movie',\n ],\n },\n {\n name: 'tv',\n code: '📺',\n keywords: [\n 'tv',\n 'entertainment',\n 'television',\n 'video',\n ],\n },\n {\n name: 'camera',\n code: '📷',\n keywords: [\n 'photo',\n 'camera',\n 'entertainment',\n 'video',\n ],\n },\n {\n name: 'camera_flash',\n code: '📸',\n keywords: [\n 'photo',\n 'camera_flash',\n 'camera',\n 'flash',\n 'video',\n ],\n },\n {\n name: 'video_camera',\n code: '📹',\n keywords: [\n 'video_camera',\n 'camera',\n 'entertainment',\n 'video',\n ],\n },\n {\n name: 'vhs',\n code: '📼',\n keywords: [\n 'vhs',\n 'entertainment',\n 'tape',\n 'video',\n 'videocassette',\n ],\n },\n {\n name: 'mag',\n code: '🔍',\n keywords: [\n 'search',\n 'zoom',\n 'mag',\n 'glass',\n 'magnifying',\n 'tool',\n ],\n },\n {\n name: 'mag_right',\n code: '🔎',\n keywords: [\n 'mag_right',\n 'glass',\n 'magnifying',\n 'search',\n 'tool',\n ],\n },\n {\n name: 'candle',\n code: '🕯️',\n keywords: [\n 'candle',\n ],\n },\n {\n name: 'bulb',\n code: '💡',\n keywords: [\n 'idea',\n 'light',\n 'bulb',\n 'comic',\n 'electric',\n ],\n },\n {\n name: 'flashlight',\n code: '🔦',\n keywords: [\n 'flashlight',\n 'electric',\n 'light',\n 'tool',\n 'torch',\n ],\n },\n {\n name: 'izakaya_lantern',\n code: '🏮',\n keywords: [\n 'izakaya_lantern',\n 'lantern',\n 'bar',\n 'japanese',\n 'light',\n 'red',\n ],\n },\n {\n name: 'diya_lamp',\n code: '🪔',\n keywords: [\n 'diya_lamp',\n ],\n },\n {\n name: 'notebook_with_decorative_cover',\n code: '📔',\n keywords: [\n 'notebook_with_decorative_cover',\n 'book',\n 'cover',\n 'decorated',\n 'notebook',\n ],\n },\n {\n name: 'closed_book',\n code: '📕',\n keywords: [\n 'closed_book',\n 'book',\n 'closed',\n ],\n },\n {\n name: 'book',\n code: '📖',\n keywords: [\n 'book',\n 'open_book',\n 'open',\n ],\n },\n {\n name: 'green_book',\n code: '📗',\n keywords: [\n 'green_book',\n 'book',\n 'green',\n ],\n },\n {\n name: 'blue_book',\n code: '📘',\n keywords: [\n 'blue_book',\n 'blue',\n 'book',\n ],\n },\n {\n name: 'orange_book',\n code: '📙',\n keywords: [\n 'orange_book',\n 'book',\n 'orange',\n ],\n },\n {\n name: 'books',\n code: '📚',\n keywords: [\n 'library',\n 'books',\n 'book',\n ],\n },\n {\n name: 'notebook',\n code: '📓',\n keywords: [\n 'notebook',\n ],\n },\n {\n name: 'ledger',\n code: '📒',\n keywords: [\n 'ledger',\n 'notebook',\n ],\n },\n {\n name: 'page_with_curl',\n code: '📃',\n keywords: [\n 'page_with_curl',\n 'curl',\n 'document',\n 'page',\n ],\n },\n {\n name: 'scroll',\n code: '📜',\n keywords: [\n 'document',\n 'scroll',\n 'paper',\n ],\n },\n {\n name: 'page_facing_up',\n code: '📄',\n keywords: [\n 'document',\n 'page_facing_up',\n 'page',\n ],\n },\n {\n name: 'newspaper',\n code: '📰',\n keywords: [\n 'press',\n 'newspaper',\n 'communication',\n 'news',\n 'paper',\n ],\n },\n {\n name: 'newspaper_roll',\n code: '🗞️',\n keywords: [\n 'press',\n 'newspaper_roll',\n ],\n },\n {\n name: 'bookmark_tabs',\n code: '📑',\n keywords: [\n 'bookmark_tabs',\n 'bookmark',\n 'mark',\n 'marker',\n 'tabs',\n ],\n },\n {\n name: 'bookmark',\n code: '🔖',\n keywords: [\n 'bookmark',\n 'mark',\n ],\n },\n {\n name: 'label',\n code: '🏷️',\n keywords: [\n 'tag',\n 'label',\n ],\n },\n {\n name: 'moneybag',\n code: '💰',\n keywords: [\n 'dollar',\n 'cream',\n 'moneybag',\n 'bag',\n 'money',\n ],\n },\n {\n name: 'coin',\n code: '🪙',\n keywords: [\n 'coin',\n ],\n },\n {\n name: 'yen',\n code: '💴',\n keywords: [\n 'yen',\n 'bank',\n 'banknote',\n 'bill',\n 'currency',\n 'money',\n 'note',\n ],\n },\n {\n name: 'dollar',\n code: '💵',\n keywords: [\n 'money',\n 'dollar',\n 'bank',\n 'banknote',\n 'bill',\n 'currency',\n 'note',\n ],\n },\n {\n name: 'euro',\n code: '💶',\n keywords: [\n 'euro',\n 'bank',\n 'banknote',\n 'bill',\n 'currency',\n 'money',\n 'note',\n ],\n },\n {\n name: 'pound',\n code: '💷',\n keywords: [\n 'pound',\n 'bank',\n 'banknote',\n 'bill',\n 'currency',\n 'money',\n 'note',\n ],\n },\n {\n name: 'money_with_wings',\n code: '💸',\n keywords: [\n 'dollar',\n 'money_with_wings',\n 'bank',\n 'banknote',\n 'bill',\n 'fly',\n 'money',\n 'note',\n 'wings',\n ],\n },\n {\n name: 'credit_card',\n code: '💳',\n keywords: [\n 'subscription',\n 'credit_card',\n 'bank',\n 'card',\n 'credit',\n 'money',\n ],\n },\n {\n name: 'receipt',\n code: '🧾',\n keywords: [\n 'receipt',\n ],\n },\n {\n name: 'chart',\n code: '💹',\n keywords: [\n 'chart',\n 'bank',\n 'currency',\n 'graph',\n 'growth',\n 'market',\n 'money',\n 'rise',\n 'trend',\n 'upward',\n 'yen',\n ],\n },\n {\n name: 'envelope',\n code: '✉️',\n keywords: [\n 'letter',\n 'email',\n 'envelope',\n 'e-mail',\n ],\n },\n {\n name: 'email',\n code: '📧',\n keywords: [\n 'email',\n 'e-mail',\n 'communication',\n 'letter',\n 'mail',\n ],\n },\n {\n name: 'incoming_envelope',\n code: '📨',\n keywords: [\n 'incoming_envelope',\n 'communication',\n 'e-mail',\n 'email',\n 'envelope',\n 'incoming',\n 'letter',\n 'mail',\n 'receive',\n ],\n },\n {\n name: 'envelope_with_arrow',\n code: '📩',\n keywords: [\n 'envelope_with_arrow',\n 'arrow',\n 'communication',\n 'down',\n 'e-mail',\n 'email',\n 'envelope',\n 'letter',\n 'mail',\n 'outgoing',\n 'sent',\n ],\n },\n {\n name: 'outbox_tray',\n code: '📤',\n keywords: [\n 'outbox_tray',\n 'box',\n 'communication',\n 'letter',\n 'mail',\n 'outbox',\n 'sent',\n 'tray',\n ],\n },\n {\n name: 'inbox_tray',\n code: '📥',\n keywords: [\n 'inbox_tray',\n 'box',\n 'communication',\n 'inbox',\n 'letter',\n 'mail',\n 'receive',\n 'tray',\n ],\n },\n {\n name: 'package',\n code: '📦',\n keywords: [\n 'shipping',\n 'package',\n 'box',\n 'communication',\n 'parcel',\n ],\n },\n {\n name: 'mailbox',\n code: '📫',\n keywords: [\n 'mailbox',\n 'closed',\n 'communication',\n 'flag',\n 'mail',\n 'postbox',\n ],\n },\n {\n name: 'mailbox_closed',\n code: '📪',\n keywords: [\n 'mailbox_closed',\n 'closed',\n 'communication',\n 'flag',\n 'lowered',\n 'mail',\n 'mailbox',\n 'postbox',\n ],\n },\n {\n name: 'mailbox_with_mail',\n code: '📬',\n keywords: [\n 'mailbox_with_mail',\n 'communication',\n 'flag',\n 'mail',\n 'mailbox',\n 'open',\n 'postbox',\n ],\n },\n {\n name: 'mailbox_with_no_mail',\n code: '📭',\n keywords: [\n 'mailbox_with_no_mail',\n 'communication',\n 'flag',\n 'lowered',\n 'mail',\n 'mailbox',\n 'open',\n 'postbox',\n ],\n },\n {\n name: 'postbox',\n code: '📮',\n keywords: [\n 'postbox',\n 'communication',\n 'mail',\n 'mailbox',\n ],\n },\n {\n name: 'ballot_box',\n code: '🗳️',\n keywords: [\n 'ballot_box',\n ],\n },\n {\n name: 'pencil2',\n code: '✏️',\n keywords: [\n 'pencil2',\n ],\n },\n {\n name: 'black_nib',\n code: '✒️',\n keywords: [\n 'black_nib',\n 'nib',\n 'pen',\n ],\n },\n {\n name: 'fountain_pen',\n code: '🖋️',\n keywords: [\n 'fountain_pen',\n ],\n },\n {\n name: 'pen',\n code: '🖊️',\n keywords: [\n 'pen',\n ],\n },\n {\n name: 'paintbrush',\n code: '🖌️',\n keywords: [\n 'paintbrush',\n ],\n },\n {\n name: 'crayon',\n code: '🖍️',\n keywords: [\n 'crayon',\n ],\n },\n {\n name: 'memo',\n code: '📝',\n keywords: [\n 'document',\n 'note',\n 'memo',\n 'pencil',\n 'communication',\n ],\n },\n {\n name: 'briefcase',\n code: '💼',\n keywords: [\n 'business',\n 'briefcase',\n ],\n },\n {\n name: 'file_folder',\n code: '📁',\n keywords: [\n 'directory',\n 'file_folder',\n 'file',\n 'folder',\n ],\n },\n {\n name: 'open_file_folder',\n code: '📂',\n keywords: [\n 'open_file_folder',\n 'file',\n 'folder',\n 'open',\n ],\n },\n {\n name: 'card_index_dividers',\n code: '🗂️',\n keywords: [\n 'card_index_dividers',\n ],\n },\n {\n name: 'date',\n code: '📅',\n keywords: [\n 'calendar',\n 'schedule',\n 'date',\n ],\n },\n {\n name: 'calendar',\n code: '📆',\n keywords: [\n 'schedule',\n 'calendar',\n ],\n },\n {\n name: 'spiral_notepad',\n code: '🗒️',\n keywords: [\n 'spiral_notepad',\n ],\n },\n {\n name: 'spiral_calendar',\n code: '🗓️',\n keywords: [\n 'spiral_calendar',\n ],\n },\n {\n name: 'card_index',\n code: '📇',\n keywords: [\n 'card_index',\n 'card',\n 'index',\n 'rolodex',\n ],\n },\n {\n name: 'chart_with_upwards_trend',\n code: '📈',\n keywords: [\n 'graph',\n 'metrics',\n 'chart_with_upwards_trend',\n 'chart',\n 'growth',\n 'trend',\n 'upward',\n ],\n },\n {\n name: 'chart_with_downwards_trend',\n code: '📉',\n keywords: [\n 'graph',\n 'metrics',\n 'chart_with_downwards_trend',\n 'chart',\n 'down',\n 'trend',\n ],\n },\n {\n name: 'bar_chart',\n code: '📊',\n keywords: [\n 'stats',\n 'metrics',\n 'bar_chart',\n 'bar',\n 'chart',\n 'graph',\n ],\n },\n {\n name: 'clipboard',\n code: '📋',\n keywords: [\n 'clipboard',\n ],\n },\n {\n name: 'pushpin',\n code: '📌',\n keywords: [\n 'location',\n 'pushpin',\n 'pin',\n ],\n },\n {\n name: 'round_pushpin',\n code: '📍',\n keywords: [\n 'location',\n 'round_pushpin',\n 'pin',\n 'pushpin',\n ],\n },\n {\n name: 'paperclip',\n code: '📎',\n keywords: [\n 'paperclip',\n ],\n },\n {\n name: 'paperclips',\n code: '🖇️',\n keywords: [\n 'paperclips',\n ],\n },\n {\n name: 'straight_ruler',\n code: '📏',\n keywords: [\n 'straight_ruler',\n 'ruler',\n 'straight edge',\n ],\n },\n {\n name: 'triangular_ruler',\n code: '📐',\n keywords: [\n 'triangular_ruler',\n 'ruler',\n 'set',\n 'triangle',\n ],\n },\n {\n name: 'scissors',\n code: '✂️',\n keywords: [\n 'cut',\n 'scissors',\n 'tool',\n ],\n },\n {\n name: 'card_file_box',\n code: '🗃️',\n keywords: [\n 'card_file_box',\n ],\n },\n {\n name: 'file_cabinet',\n code: '🗄️',\n keywords: [\n 'file_cabinet',\n ],\n },\n {\n name: 'wastebasket',\n code: '🗑️',\n keywords: [\n 'trash',\n 'wastebasket',\n ],\n },\n {\n name: 'lock',\n code: '🔒',\n keywords: [\n 'security',\n 'private',\n 'lock',\n 'closed',\n ],\n },\n {\n name: 'unlock',\n code: '🔓',\n keywords: [\n 'security',\n 'unlock',\n 'lock',\n 'open',\n ],\n },\n {\n name: 'lock_with_ink_pen',\n code: '🔏',\n keywords: [\n 'lock_with_ink_pen',\n 'ink',\n 'lock',\n 'nib',\n 'pen',\n 'privacy',\n ],\n },\n {\n name: 'closed_lock_with_key',\n code: '🔐',\n keywords: [\n 'security',\n 'closed_lock_with_key',\n 'closed',\n 'key',\n 'lock',\n 'secure',\n ],\n },\n {\n name: 'key',\n code: '🔑',\n keywords: [\n 'lock',\n 'password',\n 'key',\n ],\n },\n {\n name: 'old_key',\n code: '🗝️',\n keywords: [\n 'old_key',\n ],\n },\n {\n name: 'hammer',\n code: '🔨',\n keywords: [\n 'tool',\n 'hammer',\n ],\n },\n {\n name: 'axe',\n code: '🪓',\n keywords: [\n 'axe',\n ],\n },\n {\n name: 'pick',\n code: '⛏️',\n keywords: [\n 'pick',\n ],\n },\n {\n name: 'hammer_and_pick',\n code: '⚒️',\n keywords: [\n 'hammer_and_pick',\n 'hammer',\n 'pick',\n 'tool',\n ],\n },\n {\n name: 'hammer_and_wrench',\n code: '🛠️',\n keywords: [\n 'hammer_and_wrench',\n ],\n },\n {\n name: 'dagger',\n code: '🗡️',\n keywords: [\n 'dagger',\n ],\n },\n {\n name: 'crossed_swords',\n code: '⚔️',\n keywords: [\n 'crossed_swords',\n 'crossed',\n 'swords',\n 'weapon',\n ],\n },\n {\n name: 'gun',\n code: '🔫',\n keywords: [\n 'shoot',\n 'weapon',\n 'gun',\n 'handgun',\n 'pistol',\n 'revolver',\n 'tool',\n ],\n },\n {\n name: 'boomerang',\n code: '🪃',\n keywords: [\n 'boomerang',\n ],\n },\n {\n name: 'bow_and_arrow',\n code: '🏹',\n keywords: [\n 'archery',\n 'bow_and_arrow',\n 'archer',\n 'arrow',\n 'bow',\n 'sagittarius',\n 'tool',\n 'weapon',\n 'zodiac',\n ],\n },\n {\n name: 'shield',\n code: '🛡️',\n keywords: [\n 'shield',\n ],\n },\n {\n name: 'carpentry_saw',\n code: '🪚',\n keywords: [\n 'carpentry_saw',\n ],\n },\n {\n name: 'wrench',\n code: '🔧',\n keywords: [\n 'tool',\n 'wrench',\n ],\n },\n {\n name: 'screwdriver',\n code: '🪛',\n keywords: [\n 'screwdriver',\n ],\n },\n {\n name: 'nut_and_bolt',\n code: '🔩',\n keywords: [\n 'nut_and_bolt',\n 'bolt',\n 'nut',\n 'tool',\n ],\n },\n {\n name: 'gear',\n code: '⚙️',\n keywords: [\n 'gear',\n 'tool',\n ],\n },\n {\n name: 'clamp',\n code: '🗜️',\n keywords: [\n 'clamp',\n ],\n },\n {\n name: 'balance_scale',\n code: '⚖️',\n keywords: [\n 'balance_scale',\n 'balance',\n 'justice',\n 'libra',\n 'scales',\n 'tool',\n 'weight',\n 'zodiac',\n ],\n },\n {\n name: 'probing_cane',\n code: '🦯',\n keywords: [\n 'probing_cane',\n ],\n },\n {\n name: 'link',\n code: '🔗',\n keywords: [\n 'link',\n ],\n },\n {\n name: 'chains',\n code: '⛓️',\n keywords: [\n 'chains',\n ],\n },\n {\n name: 'hook',\n code: '🪝',\n keywords: [\n 'hook',\n ],\n },\n {\n name: 'toolbox',\n code: '🧰',\n keywords: [\n 'toolbox',\n ],\n },\n {\n name: 'magnet',\n code: '🧲',\n keywords: [\n 'magnet',\n ],\n },\n {\n name: 'ladder',\n code: '🪜',\n keywords: [\n 'ladder',\n ],\n },\n {\n name: 'alembic',\n code: '⚗️',\n keywords: [\n 'alembic',\n 'chemistry',\n 'tool',\n ],\n },\n {\n name: 'test_tube',\n code: '🧪',\n keywords: [\n 'test_tube',\n ],\n },\n {\n name: 'petri_dish',\n code: '🧫',\n keywords: [\n 'petri_dish',\n ],\n },\n {\n name: 'dna',\n code: '🧬',\n keywords: [\n 'dna',\n ],\n },\n {\n name: 'microscope',\n code: '🔬',\n keywords: [\n 'science',\n 'laboratory',\n 'investigate',\n 'microscope',\n 'tool',\n ],\n },\n {\n name: 'telescope',\n code: '🔭',\n keywords: [\n 'telescope',\n 'tool',\n ],\n },\n {\n name: 'satellite',\n code: '📡',\n keywords: [\n 'signal',\n 'satellite',\n 'antenna',\n 'communication',\n 'dish',\n ],\n },\n {\n name: 'syringe',\n code: '💉',\n keywords: [\n 'health',\n 'hospital',\n 'needle',\n 'syringe',\n 'doctor',\n 'medicine',\n 'shot',\n 'sick',\n 'tool',\n ],\n },\n {\n name: 'drop_of_blood',\n code: '🩸',\n keywords: [\n 'drop_of_blood',\n ],\n },\n {\n name: 'pill',\n code: '💊',\n keywords: [\n 'health',\n 'medicine',\n 'pill',\n 'doctor',\n 'sick',\n ],\n },\n {\n name: 'adhesive_bandage',\n code: '🩹',\n keywords: [\n 'adhesive_bandage',\n ],\n },\n {\n name: 'stethoscope',\n code: '🩺',\n keywords: [\n 'stethoscope',\n ],\n },\n {\n name: 'door',\n code: '🚪',\n keywords: [\n 'door',\n ],\n },\n {\n name: 'elevator',\n code: '🛗',\n keywords: [\n 'elevator',\n ],\n },\n {\n name: 'mirror',\n code: '🪞',\n keywords: [\n 'mirror',\n ],\n },\n {\n name: 'window',\n code: '🪟',\n keywords: [\n 'window',\n ],\n },\n {\n name: 'bed',\n code: '🛏️',\n keywords: [\n 'bed',\n ],\n },\n {\n name: 'couch_and_lamp',\n code: '🛋️',\n keywords: [\n 'couch_and_lamp',\n ],\n },\n {\n name: 'chair',\n code: '🪑',\n keywords: [\n 'chair',\n ],\n },\n {\n name: 'toilet',\n code: '🚽',\n keywords: [\n 'wc',\n 'toilet',\n ],\n },\n {\n name: 'plunger',\n code: '🪠',\n keywords: [\n 'plunger',\n ],\n },\n {\n name: 'shower',\n code: '🚿',\n keywords: [\n 'bath',\n 'shower',\n 'water',\n ],\n },\n {\n name: 'bathtub',\n code: '🛁',\n keywords: [\n 'bathtub',\n 'bath',\n ],\n },\n {\n name: 'mouse_trap',\n code: '🪤',\n keywords: [\n 'mouse_trap',\n ],\n },\n {\n name: 'razor',\n code: '🪒',\n keywords: [\n 'razor',\n ],\n },\n {\n name: 'lotion_bottle',\n code: '🧴',\n keywords: [\n 'lotion_bottle',\n ],\n },\n {\n name: 'safety_pin',\n code: '🧷',\n keywords: [\n 'safety_pin',\n ],\n },\n {\n name: 'broom',\n code: '🧹',\n keywords: [\n 'broom',\n ],\n },\n {\n name: 'basket',\n code: '🧺',\n keywords: [\n 'basket',\n ],\n },\n {\n name: 'roll_of_paper',\n code: '🧻',\n keywords: [\n 'toilet',\n 'roll_of_paper',\n ],\n },\n {\n name: 'bucket',\n code: '🪣',\n keywords: [\n 'bucket',\n ],\n },\n {\n name: 'soap',\n code: '🧼',\n keywords: [\n 'soap',\n ],\n },\n {\n name: 'toothbrush',\n code: '🪥',\n keywords: [\n 'toothbrush',\n ],\n },\n {\n name: 'sponge',\n code: '🧽',\n keywords: [\n 'sponge',\n ],\n },\n {\n name: 'fire_extinguisher',\n code: '🧯',\n keywords: [\n 'fire_extinguisher',\n ],\n },\n {\n name: 'shopping_cart',\n code: '🛒',\n keywords: [\n 'shopping_cart',\n 'cart',\n 'shopping',\n 'trolley',\n ],\n },\n {\n name: 'smoking',\n code: '🚬',\n keywords: [\n 'cigarette',\n 'smoking',\n 'activity',\n ],\n },\n {\n name: 'coffin',\n code: '⚰️',\n keywords: [\n 'funeral',\n 'coffin',\n ],\n },\n {\n name: 'headstone',\n code: '🪦',\n keywords: [\n 'headstone',\n ],\n },\n {\n name: 'funeral_urn',\n code: '⚱️',\n keywords: [\n 'funeral_urn',\n ],\n },\n {\n name: 'moyai',\n code: '🗿',\n keywords: [\n 'stone',\n 'moyai',\n 'face',\n 'statue',\n ],\n },\n {\n name: 'placard',\n code: '🪧',\n keywords: [\n 'placard',\n ],\n },\n {\n code: 'symbols',\n header: true,\n icon: Symbols,\n },\n {\n name: 'atm',\n code: '🏧',\n keywords: [\n 'atm',\n 'automated',\n 'bank',\n 'teller',\n ],\n },\n {\n name: 'put_litter_in_its_place',\n code: '🚮',\n keywords: [\n 'put_litter_in_its_place',\n 'litter',\n 'litterbox',\n ],\n },\n {\n name: 'potable_water',\n code: '🚰',\n keywords: [\n 'potable_water',\n 'drink',\n 'potable',\n 'water',\n ],\n },\n {\n name: 'wheelchair',\n code: '♿',\n keywords: [\n 'accessibility',\n 'wheelchair',\n 'access',\n ],\n },\n {\n name: 'mens',\n code: '🚹',\n keywords: [\n 'mens',\n 'lavatory',\n 'man',\n 'restroom',\n 'wc',\n ],\n },\n {\n name: 'womens',\n code: '🚺',\n keywords: [\n 'womens',\n 'lavatory',\n 'restroom',\n 'wc',\n 'woman',\n ],\n },\n {\n name: 'restroom',\n code: '🚻',\n keywords: [\n 'toilet',\n 'restroom',\n 'lavatory',\n 'wc',\n ],\n },\n {\n name: 'baby_symbol',\n code: '🚼',\n keywords: [\n 'baby_symbol',\n 'baby',\n 'changing',\n ],\n },\n {\n name: 'wc',\n code: '🚾',\n keywords: [\n 'toilet',\n 'restroom',\n 'wc',\n 'closet',\n 'lavatory',\n 'water',\n ],\n },\n {\n name: 'passport_control',\n code: '🛂',\n keywords: [\n 'passport_control',\n 'control',\n 'passport',\n ],\n },\n {\n name: 'customs',\n code: '🛃',\n keywords: [\n 'customs',\n ],\n },\n {\n name: 'baggage_claim',\n code: '🛄',\n keywords: [\n 'airport',\n 'baggage_claim',\n 'baggage',\n 'claim',\n ],\n },\n {\n name: 'left_luggage',\n code: '🛅',\n keywords: [\n 'left_luggage',\n 'baggage',\n 'left luggage',\n 'locker',\n 'luggage',\n ],\n },\n {\n name: 'warning',\n code: '⚠️',\n keywords: [\n 'wip',\n 'warning',\n ],\n },\n {\n name: 'children_crossing',\n code: '🚸',\n keywords: [\n 'children_crossing',\n 'child',\n 'crossing',\n 'pedestrian',\n 'traffic',\n ],\n },\n {\n name: 'no_entry',\n code: '⛔',\n keywords: [\n 'limit',\n 'no_entry',\n 'entry',\n 'forbidden',\n 'no',\n 'not',\n 'prohibited',\n 'traffic',\n ],\n },\n {\n name: 'no_entry_sign',\n code: '🚫',\n keywords: [\n 'block',\n 'forbidden',\n 'no_entry_sign',\n 'entry',\n 'no',\n 'not',\n 'prohibited',\n ],\n },\n {\n name: 'no_bicycles',\n code: '🚳',\n keywords: [\n 'no_bicycles',\n 'bicycle',\n 'bike',\n 'forbidden',\n 'no',\n 'not',\n 'prohibited',\n 'vehicle',\n ],\n },\n {\n name: 'no_smoking',\n code: '🚭',\n keywords: [\n 'no_smoking',\n 'forbidden',\n 'no',\n 'not',\n 'prohibited',\n 'smoking',\n ],\n },\n {\n name: 'do_not_litter',\n code: '🚯',\n keywords: [\n 'do_not_litter',\n 'forbidden',\n 'litter',\n 'no',\n 'not',\n 'prohibited',\n ],\n },\n {\n name: 'non-potable_water',\n code: '🚱',\n keywords: [\n 'non-potable_water',\n 'drink',\n 'forbidden',\n 'no',\n 'not',\n 'potable',\n 'prohibited',\n 'water',\n ],\n },\n {\n name: 'no_pedestrians',\n code: '🚷',\n keywords: [\n 'no_pedestrians',\n 'forbidden',\n 'no',\n 'not',\n 'pedestrian',\n 'prohibited',\n ],\n },\n {\n name: 'no_mobile_phones',\n code: '📵',\n keywords: [\n 'no_mobile_phones',\n 'cell',\n 'communication',\n 'forbidden',\n 'mobile',\n 'no',\n 'not',\n 'phone',\n 'prohibited',\n 'telephone',\n ],\n },\n {\n name: 'underage',\n code: '🔞',\n keywords: [\n 'underage',\n '18',\n 'age restriction',\n 'eighteen',\n 'forbidden',\n 'no',\n 'not',\n 'prohibited',\n ],\n },\n {\n name: 'radioactive',\n code: '☢️',\n keywords: [\n 'radioactive',\n ],\n },\n {\n name: 'biohazard',\n code: '☣️',\n keywords: [\n 'biohazard',\n ],\n },\n {\n name: 'arrow_up',\n code: '⬆️',\n keywords: [\n 'arrow_up',\n ],\n },\n {\n name: 'arrow_upper_right',\n code: '↗️',\n keywords: [\n 'arrow_upper_right',\n 'arrow',\n 'direction',\n 'intercardinal',\n 'northeast',\n ],\n },\n {\n name: 'arrow_right',\n code: '➡️',\n keywords: [\n 'arrow_right',\n ],\n },\n {\n name: 'arrow_lower_right',\n code: '↘️',\n keywords: [\n 'arrow_lower_right',\n 'arrow',\n 'direction',\n 'intercardinal',\n 'southeast',\n ],\n },\n {\n name: 'arrow_down',\n code: '⬇️',\n keywords: [\n 'arrow_down',\n ],\n },\n {\n name: 'arrow_lower_left',\n code: '↙️',\n keywords: [\n 'arrow_lower_left',\n 'arrow',\n 'direction',\n 'intercardinal',\n 'southwest',\n ],\n },\n {\n name: 'arrow_left',\n code: '⬅️',\n keywords: [\n 'arrow_left',\n ],\n },\n {\n name: 'arrow_upper_left',\n code: '↖️',\n keywords: [\n 'arrow_upper_left',\n 'arrow',\n 'direction',\n 'intercardinal',\n 'northwest',\n ],\n },\n {\n name: 'arrow_up_down',\n code: '↕️',\n keywords: [\n 'arrow_up_down',\n 'arrow',\n ],\n },\n {\n name: 'left_right_arrow',\n code: '↔️',\n keywords: [\n 'left_right_arrow',\n 'arrow',\n ],\n },\n {\n name: 'leftwards_arrow_with_hook',\n code: '↩️',\n keywords: [\n 'return',\n 'leftwards_arrow_with_hook',\n ],\n },\n {\n name: 'arrow_right_hook',\n code: '↪️',\n keywords: [\n 'arrow_right_hook',\n ],\n },\n {\n name: 'arrow_heading_up',\n code: '⤴️',\n keywords: [\n 'arrow_heading_up',\n 'arrow',\n 'up',\n ],\n },\n {\n name: 'arrow_heading_down',\n code: '⤵️',\n keywords: [\n 'arrow_heading_down',\n 'arrow',\n 'down',\n ],\n },\n {\n name: 'arrows_clockwise',\n code: '🔃',\n keywords: [\n 'arrows_clockwise',\n 'arrow',\n 'clockwise',\n 'reload',\n ],\n },\n {\n name: 'arrows_counterclockwise',\n code: '🔄',\n keywords: [\n 'sync',\n 'arrows_counterclockwise',\n 'anticlockwise',\n 'arrow',\n 'counterclockwise',\n 'withershins',\n ],\n },\n {\n name: 'back',\n code: '🔙',\n keywords: [\n 'back',\n 'arrow',\n ],\n },\n {\n name: 'end',\n code: '🔚',\n keywords: [\n 'end',\n 'arrow',\n ],\n },\n {\n name: 'on',\n code: '🔛',\n keywords: [\n 'on',\n 'arrow',\n 'mark',\n ],\n },\n {\n name: 'soon',\n code: '🔜',\n keywords: [\n 'soon',\n 'arrow',\n ],\n },\n {\n name: 'top',\n code: '🔝',\n keywords: [\n 'top',\n 'arrow',\n 'up',\n ],\n },\n {\n name: 'place_of_worship',\n code: '🛐',\n keywords: [\n 'place_of_worship',\n 'religion',\n 'worship',\n ],\n },\n {\n name: 'atom_symbol',\n code: '⚛️',\n keywords: [\n 'atom_symbol',\n ],\n },\n {\n name: 'om',\n code: '🕉️',\n keywords: [\n 'om',\n ],\n },\n {\n name: 'star_of_david',\n code: '✡️',\n keywords: [\n 'star_of_david',\n 'david',\n 'jew',\n 'jewish',\n 'religion',\n 'star',\n ],\n },\n {\n name: 'wheel_of_dharma',\n code: '☸️',\n keywords: [\n 'wheel_of_dharma',\n 'buddhist',\n 'dharma',\n 'religion',\n 'wheel',\n ],\n },\n {\n name: 'yin_yang',\n code: '☯️',\n keywords: [\n 'yin_yang',\n ],\n },\n {\n name: 'latin_cross',\n code: '✝️',\n keywords: [\n 'latin_cross',\n ],\n },\n {\n name: 'orthodox_cross',\n code: '☦️',\n keywords: [\n 'orthodox_cross',\n 'christian',\n 'cross',\n 'religion',\n ],\n },\n {\n name: 'star_and_crescent',\n code: '☪️',\n keywords: [\n 'star_and_crescent',\n ],\n },\n {\n name: 'peace_symbol',\n code: '☮️',\n keywords: [\n 'peace_symbol',\n ],\n },\n {\n name: 'menorah',\n code: '🕎',\n keywords: [\n 'menorah',\n 'candelabrum',\n 'candlestick',\n 'religion',\n ],\n },\n {\n name: 'six_pointed_star',\n code: '🔯',\n keywords: [\n 'six_pointed_star',\n 'fortune',\n 'star',\n ],\n },\n {\n name: 'aries',\n code: '♈',\n keywords: [\n 'aries',\n 'ram',\n 'zodiac',\n ],\n },\n {\n name: 'taurus',\n code: '♉',\n keywords: [\n 'taurus',\n 'bull',\n 'ox',\n 'zodiac',\n ],\n },\n {\n name: 'gemini',\n code: '♊',\n keywords: [\n 'gemini',\n 'twins',\n 'zodiac',\n ],\n },\n {\n name: 'cancer',\n code: '♋',\n keywords: [\n 'cancer',\n 'crab',\n 'zodiac',\n ],\n },\n {\n name: 'leo',\n code: '♌',\n keywords: [\n 'leo',\n 'lion',\n 'zodiac',\n ],\n },\n {\n name: 'virgo',\n code: '♍',\n keywords: [\n 'virgo',\n 'maiden',\n 'virgin',\n 'zodiac',\n ],\n },\n {\n name: 'libra',\n code: '♎',\n keywords: [\n 'libra',\n 'balance',\n 'justice',\n 'scales',\n 'zodiac',\n ],\n },\n {\n name: 'scorpius',\n code: '♏',\n keywords: [\n 'scorpius',\n 'scorpio',\n 'scorpion',\n 'zodiac',\n ],\n },\n {\n name: 'sagittarius',\n code: '♐',\n keywords: [\n 'sagittarius',\n 'archer',\n 'zodiac',\n ],\n },\n {\n name: 'capricorn',\n code: '♑',\n keywords: [\n 'capricorn',\n 'goat',\n 'zodiac',\n ],\n },\n {\n name: 'aquarius',\n code: '♒',\n keywords: [\n 'aquarius',\n 'bearer',\n 'water',\n 'zodiac',\n ],\n },\n {\n name: 'pisces',\n code: '♓',\n keywords: [\n 'pisces',\n 'fish',\n 'zodiac',\n ],\n },\n {\n name: 'ophiuchus',\n code: '⛎',\n keywords: [\n 'ophiuchus',\n 'bearer',\n 'serpent',\n 'snake',\n 'zodiac',\n ],\n },\n {\n name: 'twisted_rightwards_arrows',\n code: '🔀',\n keywords: [\n 'shuffle',\n 'twisted_rightwards_arrows',\n 'arrow',\n 'crossed',\n ],\n },\n {\n name: 'repeat',\n code: '🔁',\n keywords: [\n 'loop',\n 'repeat',\n 'arrow',\n 'clockwise',\n ],\n },\n {\n name: 'repeat_one',\n code: '🔂',\n keywords: [\n 'repeat_one',\n 'arrow',\n 'clockwise',\n 'once',\n ],\n },\n {\n name: 'arrow_forward',\n code: '▶️',\n keywords: [\n 'arrow_forward',\n ],\n },\n {\n name: 'fast_forward',\n code: '⏩',\n keywords: [\n 'fast_forward',\n 'arrow',\n 'double',\n 'fast',\n 'forward',\n ],\n },\n {\n name: 'next_track_button',\n code: '⏭️',\n keywords: [\n 'next_track_button',\n ],\n },\n {\n name: 'play_or_pause_button',\n code: '⏯️',\n keywords: [\n 'play_or_pause_button',\n ],\n },\n {\n name: 'arrow_backward',\n code: '◀️',\n keywords: [\n 'arrow_backward',\n ],\n },\n {\n name: 'rewind',\n code: '⏪',\n keywords: [\n 'rewind',\n 'arrow',\n 'double',\n ],\n },\n {\n name: 'previous_track_button',\n code: '⏮️',\n keywords: [\n 'previous_track_button',\n ],\n },\n {\n name: 'arrow_up_small',\n code: '🔼',\n keywords: [\n 'arrow_up_small',\n 'arrow',\n 'button',\n 'red',\n ],\n },\n {\n name: 'arrow_double_up',\n code: '⏫',\n keywords: [\n 'arrow_double_up',\n 'arrow',\n 'double',\n ],\n },\n {\n name: 'arrow_down_small',\n code: '🔽',\n keywords: [\n 'arrow_down_small',\n 'arrow',\n 'button',\n 'down',\n 'red',\n ],\n },\n {\n name: 'arrow_double_down',\n code: '⏬',\n keywords: [\n 'arrow_double_down',\n 'arrow',\n 'double',\n 'down',\n ],\n },\n {\n name: 'pause_button',\n code: '⏸️',\n keywords: [\n 'pause_button',\n ],\n },\n {\n name: 'stop_button',\n code: '⏹️',\n keywords: [\n 'stop_button',\n ],\n },\n {\n name: 'record_button',\n code: '⏺️',\n keywords: [\n 'record_button',\n ],\n },\n {\n name: 'eject_button',\n code: '⏏️',\n keywords: [\n 'eject_button',\n ],\n },\n {\n name: 'cinema',\n code: '🎦',\n keywords: [\n 'film',\n 'movie',\n 'cinema',\n 'activity',\n 'camera',\n 'entertainment',\n ],\n },\n {\n name: 'low_brightness',\n code: '🔅',\n keywords: [\n 'low_brightness',\n 'brightness',\n 'dim',\n 'low',\n ],\n },\n {\n name: 'high_brightness',\n code: '🔆',\n keywords: [\n 'high_brightness',\n 'bright',\n 'brightness',\n ],\n },\n {\n name: 'signal_strength',\n code: '📶',\n keywords: [\n 'wifi',\n 'signal_strength',\n 'antenna',\n 'bar',\n 'cell',\n 'communication',\n 'mobile',\n 'phone',\n 'signal',\n 'telephone',\n ],\n },\n {\n name: 'vibration_mode',\n code: '📳',\n keywords: [\n 'vibration_mode',\n 'cell',\n 'communication',\n 'mobile',\n 'mode',\n 'phone',\n 'telephone',\n 'vibration',\n ],\n },\n {\n name: 'mobile_phone_off',\n code: '📴',\n keywords: [\n 'mute',\n 'off',\n 'mobile_phone_off',\n 'cell',\n 'communication',\n 'mobile',\n 'phone',\n 'telephone',\n ],\n },\n {\n name: 'female_sign',\n code: '♀️',\n keywords: [\n 'female_sign',\n ],\n },\n {\n name: 'male_sign',\n code: '♂️',\n keywords: [\n 'male_sign',\n ],\n },\n {\n name: 'transgender_symbol',\n code: '⚧️',\n keywords: [\n 'transgender_symbol',\n ],\n },\n {\n name: 'heavy_multiplication_x',\n code: '✖️',\n keywords: [\n 'heavy_multiplication_x',\n 'cancel',\n 'multiplication',\n 'multiply',\n 'x',\n ],\n },\n {\n name: 'heavy_plus_sign',\n code: '➕',\n keywords: [\n 'heavy_plus_sign',\n 'math',\n 'plus',\n ],\n },\n {\n name: 'heavy_minus_sign',\n code: '➖',\n keywords: [\n 'heavy_minus_sign',\n 'math',\n 'minus',\n ],\n },\n {\n name: 'heavy_division_sign',\n code: '➗',\n keywords: [\n 'heavy_division_sign',\n 'division',\n 'math',\n ],\n },\n {\n name: 'infinity',\n code: '♾️',\n keywords: [\n 'infinity',\n ],\n },\n {\n name: 'bangbang',\n code: '‼️',\n keywords: [\n 'bangbang',\n ],\n },\n {\n name: 'interrobang',\n code: '⁉️',\n keywords: [\n 'interrobang',\n 'exclamation',\n 'mark',\n 'punctuation',\n 'question',\n ],\n },\n {\n name: 'question',\n code: '❓',\n keywords: [\n 'confused',\n 'question',\n 'mark',\n 'punctuation',\n ],\n },\n {\n name: 'grey_question',\n code: '❔',\n keywords: [\n 'grey_question',\n 'mark',\n 'outlined',\n 'punctuation',\n 'question',\n ],\n },\n {\n name: 'grey_exclamation',\n code: '❕',\n keywords: [\n 'grey_exclamation',\n 'exclamation',\n 'mark',\n 'outlined',\n 'punctuation',\n ],\n },\n {\n name: 'exclamation',\n code: '❗',\n keywords: [\n 'bang',\n 'exclamation',\n 'heavy_exclamation_mark',\n 'mark',\n 'punctuation',\n ],\n },\n {\n name: 'wavy_dash',\n code: '〰️',\n keywords: [\n 'wavy_dash',\n 'dash',\n 'punctuation',\n 'wavy',\n ],\n },\n {\n name: 'currency_exchange',\n code: '💱',\n keywords: [\n 'currency_exchange',\n 'bank',\n 'currency',\n 'exchange',\n 'money',\n ],\n },\n {\n name: 'heavy_dollar_sign',\n code: '💲',\n keywords: [\n 'heavy_dollar_sign',\n 'currency',\n 'dollar',\n 'money',\n ],\n },\n {\n name: 'medical_symbol',\n code: '⚕️',\n keywords: [\n 'medical_symbol',\n ],\n },\n {\n name: 'recycle',\n code: '♻️',\n keywords: [\n 'environment',\n 'green',\n 'recycle',\n ],\n },\n {\n name: 'fleur_de_lis',\n code: '⚜️',\n keywords: [\n 'fleur_de_lis',\n ],\n },\n {\n name: 'trident',\n code: '🔱',\n keywords: [\n 'trident',\n 'anchor',\n 'emblem',\n 'ship',\n 'tool',\n ],\n },\n {\n name: 'name_badge',\n code: '📛',\n keywords: [\n 'name_badge',\n 'badge',\n 'name',\n ],\n },\n {\n name: 'beginner',\n code: '🔰',\n keywords: [\n 'beginner',\n 'chevron',\n 'green',\n 'japanese',\n 'leaf',\n 'tool',\n 'yellow',\n ],\n },\n {\n name: 'o',\n code: '⭕',\n keywords: [\n 'o',\n 'circle',\n ],\n },\n {\n name: 'white_check_mark',\n code: '✅',\n keywords: [\n 'white_check_mark',\n 'check',\n 'mark',\n ],\n },\n {\n name: 'ballot_box_with_check',\n code: '☑️',\n keywords: [\n 'ballot_box_with_check',\n 'ballot',\n 'box',\n 'check',\n ],\n },\n {\n name: 'heavy_check_mark',\n code: '✔️',\n keywords: [\n 'heavy_check_mark',\n 'check',\n 'mark',\n ],\n },\n {\n name: 'x',\n code: '❌',\n keywords: [\n 'x',\n 'cancel',\n 'mark',\n 'multiplication',\n 'multiply',\n ],\n },\n {\n name: 'negative_squared_cross_mark',\n code: '❎',\n keywords: [\n 'negative_squared_cross_mark',\n 'mark',\n 'square',\n ],\n },\n {\n name: 'curly_loop',\n code: '➰',\n keywords: [\n 'curly_loop',\n 'curl',\n 'loop',\n ],\n },\n {\n name: 'loop',\n code: '➿',\n keywords: [\n 'loop',\n 'curl',\n 'double',\n ],\n },\n {\n name: 'part_alternation_mark',\n code: '〽️',\n keywords: [\n 'part_alternation_mark',\n ],\n },\n {\n name: 'eight_spoked_asterisk',\n code: '✳️',\n keywords: [\n 'eight_spoked_asterisk',\n 'asterisk',\n ],\n },\n {\n name: 'eight_pointed_black_star',\n code: '✴️',\n keywords: [\n 'eight_pointed_black_star',\n 'star',\n ],\n },\n {\n name: 'sparkle',\n code: '❇️',\n keywords: [\n 'sparkle',\n ],\n },\n {\n name: 'copyright',\n code: '©️',\n keywords: [\n 'copyright',\n ],\n },\n {\n name: 'registered',\n code: '®️',\n keywords: [\n 'registered',\n ],\n },\n {\n name: 'tm',\n code: '™️',\n keywords: [\n 'trademark',\n 'tm',\n 'mark',\n ],\n },\n {\n name: 'hash',\n code: '#️⃣',\n keywords: [\n 'number',\n 'hash',\n 'keycap',\n 'pound',\n ],\n },\n {\n name: 'asterisk',\n code: '*️⃣',\n keywords: [\n 'asterisk',\n 'keycap',\n 'star',\n ],\n },\n {\n name: 'zero',\n code: '0️⃣',\n keywords: [\n 'zero',\n '0',\n 'keycap',\n ],\n },\n {\n name: 'one',\n code: '1️⃣',\n keywords: [\n 'one',\n '1',\n 'keycap',\n ],\n },\n {\n name: 'two',\n code: '2️⃣',\n keywords: [\n 'two',\n '2',\n 'keycap',\n ],\n },\n {\n name: 'three',\n code: '3️⃣',\n keywords: [\n 'three',\n '3',\n 'keycap',\n ],\n },\n {\n name: 'four',\n code: '4️⃣',\n keywords: [\n 'four',\n '4',\n 'keycap',\n ],\n },\n {\n name: 'five',\n code: '5️⃣',\n keywords: [\n 'five',\n '5',\n 'keycap',\n ],\n },\n {\n name: 'six',\n code: '6️⃣',\n keywords: [\n 'six',\n '6',\n 'keycap',\n ],\n },\n {\n name: 'seven',\n code: '7️⃣',\n keywords: [\n 'seven',\n '7',\n 'keycap',\n ],\n },\n {\n name: 'eight',\n code: '8️⃣',\n keywords: [\n 'eight',\n '8',\n 'keycap',\n ],\n },\n {\n name: 'nine',\n code: '9️⃣',\n keywords: [\n 'nine',\n '9',\n 'keycap',\n ],\n },\n {\n name: 'keycap_ten',\n code: '🔟',\n keywords: [\n 'keycap_ten',\n '10',\n 'keycap',\n 'ten',\n ],\n },\n {\n name: 'capital_abcd',\n code: '🔠',\n keywords: [\n 'letters',\n 'capital_abcd',\n 'input',\n 'latin',\n 'uppercase',\n ],\n },\n {\n name: 'abcd',\n code: '🔡',\n keywords: [\n 'abcd',\n 'input',\n 'latin',\n 'letters',\n 'lowercase',\n ],\n },\n {\n name: '1234',\n code: '🔢',\n keywords: [\n 'numbers',\n '1234',\n 'input',\n ],\n },\n {\n name: 'symbols',\n code: '🔣',\n keywords: [\n 'symbols',\n 'input',\n ],\n },\n {\n name: 'abc',\n code: '🔤',\n keywords: [\n 'alphabet',\n 'abc',\n 'input',\n 'latin',\n 'letters',\n ],\n },\n {\n name: 'a',\n code: '🅰️',\n keywords: [\n 'a',\n ],\n },\n {\n name: 'ab',\n code: '🆎',\n keywords: [\n 'ab',\n 'blood',\n ],\n },\n {\n name: 'b',\n code: '🅱️',\n keywords: [\n 'b',\n ],\n },\n {\n name: 'cl',\n code: '🆑',\n keywords: [\n 'cl',\n ],\n },\n {\n name: 'cool',\n code: '🆒',\n keywords: [\n 'cool',\n ],\n },\n {\n name: 'free',\n code: '🆓',\n keywords: [\n 'free',\n ],\n },\n {\n name: 'information_source',\n code: 'ℹ️',\n keywords: [\n 'information_source',\n 'i',\n 'information',\n ],\n },\n {\n name: 'id',\n code: '🆔',\n keywords: [\n 'id',\n 'identity',\n ],\n },\n {\n name: 'm',\n code: 'Ⓜ️',\n keywords: [\n 'm',\n ],\n },\n {\n name: 'new',\n code: '🆕',\n keywords: [\n 'fresh',\n 'new',\n ],\n },\n {\n name: 'ng',\n code: '🆖',\n keywords: [\n 'ng',\n ],\n },\n {\n name: 'o2',\n code: '🅾️',\n keywords: [\n 'o2',\n ],\n },\n {\n name: 'ok',\n code: '🆗',\n keywords: [\n 'yes',\n 'ok',\n ],\n },\n {\n name: 'parking',\n code: '🅿️',\n keywords: [\n 'parking',\n ],\n },\n {\n name: 'sos',\n code: '🆘',\n keywords: [\n 'help',\n 'emergency',\n 'sos',\n ],\n },\n {\n name: 'up',\n code: '🆙',\n keywords: [\n 'up',\n 'mark',\n ],\n },\n {\n name: 'vs',\n code: '🆚',\n keywords: [\n 'vs',\n 'versus',\n ],\n },\n {\n name: 'koko',\n code: '🈁',\n keywords: [\n 'koko',\n 'japanese',\n ],\n },\n {\n name: 'sa',\n code: '🈂️',\n keywords: [\n 'sa',\n ],\n },\n {\n name: 'u6708',\n code: '🈷️',\n keywords: [\n 'u6708',\n ],\n },\n {\n name: 'u6709',\n code: '🈶',\n keywords: [\n 'u6709',\n 'japanese',\n ],\n },\n {\n name: 'u6307',\n code: '🈯',\n keywords: [\n 'u6307',\n 'japanese',\n ],\n },\n {\n name: 'ideograph_advantage',\n code: '🉐',\n keywords: [\n 'ideograph_advantage',\n 'japanese',\n ],\n },\n {\n name: 'u5272',\n code: '🈹',\n keywords: [\n 'u5272',\n 'japanese',\n ],\n },\n {\n name: 'u7121',\n code: '🈚',\n keywords: [\n 'u7121',\n 'japanese',\n ],\n },\n {\n name: 'u7981',\n code: '🈲',\n keywords: [\n 'u7981',\n 'japanese',\n ],\n },\n {\n name: 'accept',\n code: '🉑',\n keywords: [\n 'accept',\n 'chinese',\n ],\n },\n {\n name: 'u7533',\n code: '🈸',\n keywords: [\n 'u7533',\n 'chinese',\n ],\n },\n {\n name: 'u5408',\n code: '🈴',\n keywords: [\n 'u5408',\n 'chinese',\n ],\n },\n {\n name: 'u7a7a',\n code: '🈳',\n keywords: [\n 'u7a7a',\n 'chinese',\n ],\n },\n {\n name: 'congratulations',\n code: '㊗️',\n keywords: [\n 'congratulations',\n 'chinese',\n 'congratulation',\n 'ideograph',\n ],\n },\n {\n name: 'secret',\n code: '㊙️',\n keywords: [\n 'secret',\n 'chinese',\n 'ideograph',\n ],\n },\n {\n name: 'u55b6',\n code: '🈺',\n keywords: [\n 'u55b6',\n 'chinese',\n ],\n },\n {\n name: 'u6e80',\n code: '🈵',\n keywords: [\n 'u6e80',\n 'chinese',\n ],\n },\n {\n name: 'red_circle',\n code: '🔴',\n keywords: [\n 'red_circle',\n 'circle',\n 'geometric',\n 'red',\n ],\n },\n {\n name: 'orange_circle',\n code: '🟠',\n keywords: [\n 'orange_circle',\n ],\n },\n {\n name: 'yellow_circle',\n code: '🟡',\n keywords: [\n 'yellow_circle',\n ],\n },\n {\n name: 'green_circle',\n code: '🟢',\n keywords: [\n 'green_circle',\n ],\n },\n {\n name: 'large_blue_circle',\n code: '🔵',\n keywords: [\n 'large_blue_circle',\n 'blue',\n 'circle',\n 'geometric',\n ],\n },\n {\n name: 'purple_circle',\n code: '🟣',\n keywords: [\n 'purple_circle',\n ],\n },\n {\n name: 'brown_circle',\n code: '🟤',\n keywords: [\n 'brown_circle',\n ],\n },\n {\n name: 'black_circle',\n code: '⚫',\n keywords: [\n 'black_circle',\n 'circle',\n 'geometric',\n ],\n },\n {\n name: 'white_circle',\n code: '⚪',\n keywords: [\n 'white_circle',\n 'circle',\n 'geometric',\n ],\n },\n {\n name: 'red_square',\n code: '🟥',\n keywords: [\n 'red_square',\n ],\n },\n {\n name: 'orange_square',\n code: '🟧',\n keywords: [\n 'orange_square',\n ],\n },\n {\n name: 'yellow_square',\n code: '🟨',\n keywords: [\n 'yellow_square',\n ],\n },\n {\n name: 'green_square',\n code: '🟩',\n keywords: [\n 'green_square',\n ],\n },\n {\n name: 'blue_square',\n code: '🟦',\n keywords: [\n 'blue_square',\n ],\n },\n {\n name: 'purple_square',\n code: '🟪',\n keywords: [\n 'purple_square',\n ],\n },\n {\n name: 'brown_square',\n code: '🟫',\n keywords: [\n 'brown_square',\n ],\n },\n {\n name: 'black_large_square',\n code: '⬛',\n keywords: [\n 'black_large_square',\n 'geometric',\n 'square',\n ],\n },\n {\n name: 'white_large_square',\n code: '⬜',\n keywords: [\n 'white_large_square',\n 'geometric',\n 'square',\n ],\n },\n {\n name: 'black_medium_square',\n code: '◼️',\n keywords: [\n 'black_medium_square',\n ],\n },\n {\n name: 'white_medium_square',\n code: '◻️',\n keywords: [\n 'white_medium_square',\n ],\n },\n {\n name: 'black_medium_small_square',\n code: '◾',\n keywords: [\n 'black_medium_small_square',\n 'geometric',\n 'square',\n ],\n },\n {\n name: 'white_medium_small_square',\n code: '◽',\n keywords: [\n 'white_medium_small_square',\n 'geometric',\n 'square',\n ],\n },\n {\n name: 'black_small_square',\n code: '▪️',\n keywords: [\n 'black_small_square',\n ],\n },\n {\n name: 'white_small_square',\n code: '▫️',\n keywords: [\n 'white_small_square',\n ],\n },\n {\n name: 'large_orange_diamond',\n code: '🔶',\n keywords: [\n 'large_orange_diamond',\n 'diamond',\n 'geometric',\n 'orange',\n ],\n },\n {\n name: 'large_blue_diamond',\n code: '🔷',\n keywords: [\n 'large_blue_diamond',\n 'blue',\n 'diamond',\n 'geometric',\n ],\n },\n {\n name: 'small_orange_diamond',\n code: '🔸',\n keywords: [\n 'small_orange_diamond',\n 'diamond',\n 'geometric',\n 'orange',\n ],\n },\n {\n name: 'small_blue_diamond',\n code: '🔹',\n keywords: [\n 'small_blue_diamond',\n 'blue',\n 'diamond',\n 'geometric',\n ],\n },\n {\n name: 'small_red_triangle',\n code: '🔺',\n keywords: [\n 'small_red_triangle',\n 'geometric',\n 'red',\n ],\n },\n {\n name: 'small_red_triangle_down',\n code: '🔻',\n keywords: [\n 'small_red_triangle_down',\n 'down',\n 'geometric',\n 'red',\n ],\n },\n {\n name: 'diamond_shape_with_a_dot_inside',\n code: '💠',\n keywords: [\n 'diamond_shape_with_a_dot_inside',\n 'comic',\n 'diamond',\n 'geometric',\n 'inside',\n ],\n },\n {\n name: 'radio_button',\n code: '🔘',\n keywords: [\n 'radio_button',\n 'button',\n 'geometric',\n 'radio',\n ],\n },\n {\n name: 'white_square_button',\n code: '🔳',\n keywords: [\n 'white_square_button',\n 'button',\n 'geometric',\n 'outlined',\n 'square',\n ],\n },\n {\n name: 'black_square_button',\n code: '🔲',\n keywords: [\n 'black_square_button',\n 'button',\n 'geometric',\n 'square',\n ],\n },\n {\n code: 'flags',\n header: true,\n icon: Flags,\n },\n {\n name: 'checkered_flag',\n code: '🏁',\n keywords: [\n 'milestone',\n 'finish',\n 'checkered_flag',\n 'checkered',\n 'chequered',\n 'flag',\n 'racing',\n ],\n },\n {\n name: 'triangular_flag_on_post',\n code: '🚩',\n keywords: [\n 'triangular_flag_on_post',\n 'flag',\n 'post',\n ],\n },\n {\n name: 'crossed_flags',\n code: '🎌',\n keywords: [\n 'crossed_flags',\n 'activity',\n 'celebration',\n 'cross',\n 'crossed',\n 'flag',\n 'japanese',\n ],\n },\n {\n name: 'black_flag',\n code: '🏴',\n keywords: [\n 'black_flag',\n 'flag',\n 'waving',\n ],\n },\n {\n name: 'white_flag',\n code: '🏳️',\n keywords: [\n 'white_flag',\n ],\n },\n {\n name: 'rainbow_flag',\n code: '🏳️‍🌈',\n keywords: [\n 'pride',\n 'rainbow_flag',\n ],\n },\n {\n name: 'transgender_flag',\n code: '🏳️‍⚧️',\n keywords: [\n 'transgender_flag',\n ],\n },\n {\n name: 'pirate_flag',\n code: '🏴‍☠️',\n keywords: [\n 'pirate_flag',\n ],\n },\n {\n name: 'ascension_island',\n code: '🇦🇨',\n keywords: [\n 'ascension_island',\n 'ascension',\n 'flag',\n 'island',\n ],\n },\n {\n name: 'andorra',\n code: '🇦🇩',\n keywords: [\n 'andorra',\n 'flag',\n ],\n },\n {\n name: 'united_arab_emirates',\n code: '🇦🇪',\n keywords: [\n 'united_arab_emirates',\n 'emirates',\n 'flag',\n 'uae',\n 'united',\n ],\n },\n {\n name: 'afghanistan',\n code: '🇦🇫',\n keywords: [\n 'afghanistan',\n 'flag',\n ],\n },\n {\n name: 'antigua_barbuda',\n code: '🇦🇬',\n keywords: [\n 'antigua_barbuda',\n 'antigua',\n 'barbuda',\n 'flag',\n ],\n },\n {\n name: 'anguilla',\n code: '🇦🇮',\n keywords: [\n 'anguilla',\n 'flag',\n ],\n },\n {\n name: 'albania',\n code: '🇦🇱',\n keywords: [\n 'albania',\n 'flag',\n ],\n },\n {\n name: 'armenia',\n code: '🇦🇲',\n keywords: [\n 'armenia',\n 'flag',\n ],\n },\n {\n name: 'angola',\n code: '🇦🇴',\n keywords: [\n 'angola',\n 'flag',\n ],\n },\n {\n name: 'antarctica',\n code: '🇦🇶',\n keywords: [\n 'antarctica',\n 'flag',\n ],\n },\n {\n name: 'argentina',\n code: '🇦🇷',\n keywords: [\n 'argentina',\n 'flag',\n ],\n },\n {\n name: 'american_samoa',\n code: '🇦🇸',\n keywords: [\n 'american_samoa',\n 'american',\n 'flag',\n 'samoa',\n ],\n },\n {\n name: 'austria',\n code: '🇦🇹',\n keywords: [\n 'austria',\n 'flag',\n ],\n },\n {\n name: 'australia',\n code: '🇦🇺',\n keywords: [\n 'australia',\n 'flag',\n ],\n },\n {\n name: 'aruba',\n code: '🇦🇼',\n keywords: [\n 'aruba',\n 'flag',\n ],\n },\n {\n name: 'aland_islands',\n code: '🇦🇽',\n keywords: [\n 'aland_islands',\n 'åland',\n 'flag',\n ],\n },\n {\n name: 'azerbaijan',\n code: '🇦🇿',\n keywords: [\n 'azerbaijan',\n 'flag',\n ],\n },\n {\n name: 'bosnia_herzegovina',\n code: '🇧🇦',\n keywords: [\n 'bosnia_herzegovina',\n 'bosnia',\n 'flag',\n 'herzegovina',\n ],\n },\n {\n name: 'barbados',\n code: '🇧🇧',\n keywords: [\n 'barbados',\n 'flag',\n ],\n },\n {\n name: 'bangladesh',\n code: '🇧🇩',\n keywords: [\n 'bangladesh',\n 'flag',\n ],\n },\n {\n name: 'belgium',\n code: '🇧🇪',\n keywords: [\n 'belgium',\n 'flag',\n ],\n },\n {\n name: 'burkina_faso',\n code: '🇧🇫',\n keywords: [\n 'burkina_faso',\n 'burkina faso',\n 'flag',\n ],\n },\n {\n name: 'bulgaria',\n code: '🇧🇬',\n keywords: [\n 'bulgaria',\n 'flag',\n ],\n },\n {\n name: 'bahrain',\n code: '🇧🇭',\n keywords: [\n 'bahrain',\n 'flag',\n ],\n },\n {\n name: 'burundi',\n code: '🇧🇮',\n keywords: [\n 'burundi',\n 'flag',\n ],\n },\n {\n name: 'benin',\n code: '🇧🇯',\n keywords: [\n 'benin',\n 'flag',\n ],\n },\n {\n name: 'st_barthelemy',\n code: '🇧🇱',\n keywords: [\n 'st_barthelemy',\n 'barthelemy',\n 'barthélemy',\n 'flag',\n 'saint',\n ],\n },\n {\n name: 'bermuda',\n code: '🇧🇲',\n keywords: [\n 'bermuda',\n 'flag',\n ],\n },\n {\n name: 'brunei',\n code: '🇧🇳',\n keywords: [\n 'brunei',\n 'darussalam',\n 'flag',\n ],\n },\n {\n name: 'bolivia',\n code: '🇧🇴',\n keywords: [\n 'bolivia',\n 'flag',\n ],\n },\n {\n name: 'caribbean_netherlands',\n code: '🇧🇶',\n keywords: [\n 'caribbean_netherlands',\n 'bonaire',\n 'caribbean',\n 'eustatius',\n 'flag',\n 'netherlands',\n 'saba',\n 'sint',\n ],\n },\n {\n name: 'brazil',\n code: '🇧🇷',\n keywords: [\n 'brazil',\n 'flag',\n ],\n },\n {\n name: 'bahamas',\n code: '🇧🇸',\n keywords: [\n 'bahamas',\n 'flag',\n ],\n },\n {\n name: 'bhutan',\n code: '🇧🇹',\n keywords: [\n 'bhutan',\n 'flag',\n ],\n },\n {\n name: 'bouvet_island',\n code: '🇧🇻',\n keywords: [\n 'bouvet_island',\n 'bouvet',\n 'flag',\n 'island',\n ],\n },\n {\n name: 'botswana',\n code: '🇧🇼',\n keywords: [\n 'botswana',\n 'flag',\n ],\n },\n {\n name: 'belarus',\n code: '🇧🇾',\n keywords: [\n 'belarus',\n 'flag',\n ],\n },\n {\n name: 'belize',\n code: '🇧🇿',\n keywords: [\n 'belize',\n 'flag',\n ],\n },\n {\n name: 'canada',\n code: '🇨🇦',\n keywords: [\n 'canada',\n 'flag',\n ],\n },\n {\n name: 'cocos_islands',\n code: '🇨🇨',\n keywords: [\n 'keeling',\n 'cocos_islands',\n 'cocos',\n 'flag',\n 'island',\n ],\n },\n {\n name: 'congo_kinshasa',\n code: '🇨🇩',\n keywords: [\n 'congo_kinshasa',\n 'congo',\n 'congo-kinshasa',\n 'democratic republic of congo',\n 'drc',\n 'flag',\n 'kinshasa',\n 'republic',\n ],\n },\n {\n name: 'central_african_republic',\n code: '🇨🇫',\n keywords: [\n 'central_african_republic',\n 'central african republic',\n 'flag',\n 'republic',\n ],\n },\n {\n name: 'congo_brazzaville',\n code: '🇨🇬',\n keywords: [\n 'congo_brazzaville',\n 'brazzaville',\n 'congo',\n 'congo republic',\n 'congo-brazzaville',\n 'flag',\n 'republic',\n 'republic of the congo',\n ],\n },\n {\n name: 'switzerland',\n code: '🇨🇭',\n keywords: [\n 'switzerland',\n 'flag',\n ],\n },\n {\n name: 'cote_divoire',\n code: '🇨🇮',\n keywords: [\n 'ivory',\n 'cote_divoire',\n 'cote ivoire',\n 'côte ivoire',\n 'flag',\n 'ivory coast',\n ],\n },\n {\n name: 'cook_islands',\n code: '🇨🇰',\n keywords: [\n 'cook_islands',\n 'cook',\n 'flag',\n 'island',\n ],\n },\n {\n name: 'chile',\n code: '🇨🇱',\n keywords: [\n 'chile',\n 'flag',\n ],\n },\n {\n name: 'cameroon',\n code: '🇨🇲',\n keywords: [\n 'cameroon',\n 'flag',\n ],\n },\n {\n name: 'cn',\n code: '🇨🇳',\n keywords: [\n 'china',\n 'cn',\n 'flag',\n ],\n },\n {\n name: 'colombia',\n code: '🇨🇴',\n keywords: [\n 'colombia',\n 'flag',\n ],\n },\n {\n name: 'clipperton_island',\n code: '🇨🇵',\n keywords: [\n 'clipperton_island',\n 'clipperton',\n 'flag',\n 'island',\n ],\n },\n {\n name: 'costa_rica',\n code: '🇨🇷',\n keywords: [\n 'costa_rica',\n 'costa rica',\n 'flag',\n ],\n },\n {\n name: 'cuba',\n code: '🇨🇺',\n keywords: [\n 'cuba',\n 'flag',\n ],\n },\n {\n name: 'cape_verde',\n code: '🇨🇻',\n keywords: [\n 'cape_verde',\n 'cabo',\n 'cape',\n 'flag',\n 'verde',\n ],\n },\n {\n name: 'curacao',\n code: '🇨🇼',\n keywords: [\n 'curacao',\n 'antilles',\n 'curaçao',\n 'flag',\n ],\n },\n {\n name: 'christmas_island',\n code: '🇨🇽',\n keywords: [\n 'christmas_island',\n 'christmas',\n 'flag',\n 'island',\n ],\n },\n {\n name: 'cyprus',\n code: '🇨🇾',\n keywords: [\n 'cyprus',\n 'flag',\n ],\n },\n {\n name: 'czech_republic',\n code: '🇨🇿',\n keywords: [\n 'czech_republic',\n 'czech republic',\n 'flag',\n ],\n },\n {\n name: 'de',\n code: '🇩🇪',\n keywords: [\n 'flag',\n 'germany',\n 'de',\n ],\n },\n {\n name: 'diego_garcia',\n code: '🇩🇬',\n keywords: [\n 'diego_garcia',\n 'diego garcia',\n 'flag',\n ],\n },\n {\n name: 'djibouti',\n code: '🇩🇯',\n keywords: [\n 'djibouti',\n 'flag',\n ],\n },\n {\n name: 'denmark',\n code: '🇩🇰',\n keywords: [\n 'denmark',\n 'flag',\n ],\n },\n {\n name: 'dominica',\n code: '🇩🇲',\n keywords: [\n 'dominica',\n 'flag',\n ],\n },\n {\n name: 'dominican_republic',\n code: '🇩🇴',\n keywords: [\n 'dominican_republic',\n 'dominican republic',\n 'flag',\n ],\n },\n {\n name: 'algeria',\n code: '🇩🇿',\n keywords: [\n 'algeria',\n 'flag',\n ],\n },\n {\n name: 'ceuta_melilla',\n code: '🇪🇦',\n keywords: [\n 'ceuta_melilla',\n 'ceuta',\n 'flag',\n 'melilla',\n ],\n },\n {\n name: 'ecuador',\n code: '🇪🇨',\n keywords: [\n 'ecuador',\n 'flag',\n ],\n },\n {\n name: 'estonia',\n code: '🇪🇪',\n keywords: [\n 'estonia',\n 'flag',\n ],\n },\n {\n name: 'egypt',\n code: '🇪🇬',\n keywords: [\n 'egypt',\n 'flag',\n ],\n },\n {\n name: 'western_sahara',\n code: '🇪🇭',\n keywords: [\n 'western_sahara',\n 'flag',\n 'sahara',\n 'west',\n 'western sahara',\n ],\n },\n {\n name: 'eritrea',\n code: '🇪🇷',\n keywords: [\n 'eritrea',\n 'flag',\n ],\n },\n {\n name: 'es',\n code: '🇪🇸',\n keywords: [\n 'spain',\n 'es',\n 'flag',\n ],\n },\n {\n name: 'ethiopia',\n code: '🇪🇹',\n keywords: [\n 'ethiopia',\n 'flag',\n ],\n },\n {\n name: 'eu',\n code: '🇪🇺',\n keywords: [\n 'eu',\n 'european_union',\n 'european union',\n 'flag',\n ],\n },\n {\n name: 'finland',\n code: '🇫🇮',\n keywords: [\n 'finland',\n 'flag',\n ],\n },\n {\n name: 'fiji',\n code: '🇫🇯',\n keywords: [\n 'fiji',\n 'flag',\n ],\n },\n {\n name: 'falkland_islands',\n code: '🇫🇰',\n keywords: [\n 'falkland_islands',\n 'falkland',\n 'falklands',\n 'flag',\n 'island',\n 'islas',\n 'malvinas',\n ],\n },\n {\n name: 'micronesia',\n code: '🇫🇲',\n keywords: [\n 'micronesia',\n 'flag',\n ],\n },\n {\n name: 'faroe_islands',\n code: '🇫🇴',\n keywords: [\n 'faroe_islands',\n 'faroe',\n 'flag',\n 'island',\n ],\n },\n {\n name: 'fr',\n code: '🇫🇷',\n keywords: [\n 'france',\n 'french',\n 'fr',\n 'flag',\n ],\n },\n {\n name: 'gabon',\n code: '🇬🇦',\n keywords: [\n 'gabon',\n 'flag',\n ],\n },\n {\n name: 'gb',\n code: '🇬🇧',\n keywords: [\n 'flag',\n 'british',\n 'gb',\n 'uk',\n 'britain',\n 'cornwall',\n 'england',\n 'great britain',\n 'ireland',\n 'northern ireland',\n 'scotland',\n 'union jack',\n 'united',\n 'united kingdom',\n 'wales',\n ],\n },\n {\n name: 'grenada',\n code: '🇬🇩',\n keywords: [\n 'grenada',\n 'flag',\n ],\n },\n {\n name: 'georgia',\n code: '🇬🇪',\n keywords: [\n 'georgia',\n 'flag',\n ],\n },\n {\n name: 'french_guiana',\n code: '🇬🇫',\n keywords: [\n 'french_guiana',\n 'flag',\n 'french',\n 'guiana',\n ],\n },\n {\n name: 'guernsey',\n code: '🇬🇬',\n keywords: [\n 'guernsey',\n 'flag',\n ],\n },\n {\n name: 'ghana',\n code: '🇬🇭',\n keywords: [\n 'ghana',\n 'flag',\n ],\n },\n {\n name: 'gibraltar',\n code: '🇬🇮',\n keywords: [\n 'gibraltar',\n 'flag',\n ],\n },\n {\n name: 'greenland',\n code: '🇬🇱',\n keywords: [\n 'greenland',\n 'flag',\n ],\n },\n {\n name: 'gambia',\n code: '🇬🇲',\n keywords: [\n 'gambia',\n 'flag',\n ],\n },\n {\n name: 'guinea',\n code: '🇬🇳',\n keywords: [\n 'guinea',\n 'flag',\n ],\n },\n {\n name: 'guadeloupe',\n code: '🇬🇵',\n keywords: [\n 'guadeloupe',\n 'flag',\n ],\n },\n {\n name: 'equatorial_guinea',\n code: '🇬🇶',\n keywords: [\n 'equatorial_guinea',\n 'equatorial guinea',\n 'flag',\n 'guinea',\n ],\n },\n {\n name: 'greece',\n code: '🇬🇷',\n keywords: [\n 'greece',\n 'flag',\n ],\n },\n {\n name: 'south_georgia_south_sandwich_islands',\n code: '🇬🇸',\n keywords: [\n 'south_georgia_south_sandwich_islands',\n 'flag',\n 'georgia',\n 'island',\n 'south',\n 'south georgia',\n 'south sandwich',\n ],\n },\n {\n name: 'guatemala',\n code: '🇬🇹',\n keywords: [\n 'guatemala',\n 'flag',\n ],\n },\n {\n name: 'guam',\n code: '🇬🇺',\n keywords: [\n 'guam',\n 'flag',\n ],\n },\n {\n name: 'guinea_bissau',\n code: '🇬🇼',\n keywords: [\n 'guinea_bissau',\n 'bissau',\n 'flag',\n 'guinea',\n ],\n },\n {\n name: 'guyana',\n code: '🇬🇾',\n keywords: [\n 'guyana',\n 'flag',\n ],\n },\n {\n name: 'hong_kong',\n code: '🇭🇰',\n keywords: [\n 'hong_kong',\n 'china',\n 'flag',\n 'hong kong',\n ],\n },\n {\n name: 'heard_mcdonald_islands',\n code: '🇭🇲',\n keywords: [\n 'heard_mcdonald_islands',\n 'flag',\n 'heard',\n 'island',\n 'mcdonald',\n ],\n },\n {\n name: 'honduras',\n code: '🇭🇳',\n keywords: [\n 'honduras',\n 'flag',\n ],\n },\n {\n name: 'croatia',\n code: '🇭🇷',\n keywords: [\n 'croatia',\n 'flag',\n ],\n },\n {\n name: 'haiti',\n code: '🇭🇹',\n keywords: [\n 'haiti',\n 'flag',\n ],\n },\n {\n name: 'hungary',\n code: '🇭🇺',\n keywords: [\n 'hungary',\n 'flag',\n ],\n },\n {\n name: 'canary_islands',\n code: '🇮🇨',\n keywords: [\n 'canary_islands',\n 'canary',\n 'flag',\n 'island',\n ],\n },\n {\n name: 'indonesia',\n code: '🇮🇩',\n keywords: [\n 'indonesia',\n 'flag',\n ],\n },\n {\n name: 'ireland',\n code: '🇮🇪',\n keywords: [\n 'ireland',\n 'flag',\n ],\n },\n {\n name: 'israel',\n code: '🇮🇱',\n keywords: [\n 'israel',\n 'flag',\n ],\n },\n {\n name: 'isle_of_man',\n code: '🇮🇲',\n keywords: [\n 'isle_of_man',\n 'flag',\n 'isle of man',\n ],\n },\n {\n name: 'india',\n code: '🇮🇳',\n keywords: [\n 'india',\n 'flag',\n ],\n },\n {\n name: 'british_indian_ocean_territory',\n code: '🇮🇴',\n keywords: [\n 'british_indian_ocean_territory',\n 'british',\n 'chagos',\n 'flag',\n 'indian ocean',\n 'island',\n ],\n },\n {\n name: 'iraq',\n code: '🇮🇶',\n keywords: [\n 'iraq',\n 'flag',\n ],\n },\n {\n name: 'iran',\n code: '🇮🇷',\n keywords: [\n 'iran',\n 'flag',\n ],\n },\n {\n name: 'iceland',\n code: '🇮🇸',\n keywords: [\n 'iceland',\n 'flag',\n ],\n },\n {\n name: 'it',\n code: '🇮🇹',\n keywords: [\n 'italy',\n 'it',\n 'flag',\n ],\n },\n {\n name: 'jersey',\n code: '🇯🇪',\n keywords: [\n 'jersey',\n 'flag',\n ],\n },\n {\n name: 'jamaica',\n code: '🇯🇲',\n keywords: [\n 'jamaica',\n 'flag',\n ],\n },\n {\n name: 'jordan',\n code: '🇯🇴',\n keywords: [\n 'jordan',\n 'flag',\n ],\n },\n {\n name: 'jp',\n code: '🇯🇵',\n keywords: [\n 'japan',\n 'jp',\n 'flag',\n ],\n },\n {\n name: 'kenya',\n code: '🇰🇪',\n keywords: [\n 'kenya',\n 'flag',\n ],\n },\n {\n name: 'kyrgyzstan',\n code: '🇰🇬',\n keywords: [\n 'kyrgyzstan',\n 'flag',\n ],\n },\n {\n name: 'cambodia',\n code: '🇰🇭',\n keywords: [\n 'cambodia',\n 'flag',\n ],\n },\n {\n name: 'kiribati',\n code: '🇰🇮',\n keywords: [\n 'kiribati',\n 'flag',\n ],\n },\n {\n name: 'comoros',\n code: '🇰🇲',\n keywords: [\n 'comoros',\n 'flag',\n ],\n },\n {\n name: 'st_kitts_nevis',\n code: '🇰🇳',\n keywords: [\n 'st_kitts_nevis',\n 'flag',\n 'kitts',\n 'nevis',\n 'saint',\n ],\n },\n {\n name: 'north_korea',\n code: '🇰🇵',\n keywords: [\n 'north_korea',\n 'flag',\n 'korea',\n 'north',\n 'north korea',\n ],\n },\n {\n name: 'kr',\n code: '🇰🇷',\n keywords: [\n 'korea',\n 'kr',\n 'flag',\n 'south',\n 'south korea',\n ],\n },\n {\n name: 'kuwait',\n code: '🇰🇼',\n keywords: [\n 'kuwait',\n 'flag',\n ],\n },\n {\n name: 'cayman_islands',\n code: '🇰🇾',\n keywords: [\n 'cayman_islands',\n 'cayman',\n 'flag',\n 'island',\n ],\n },\n {\n name: 'kazakhstan',\n code: '🇰🇿',\n keywords: [\n 'kazakhstan',\n 'flag',\n ],\n },\n {\n name: 'laos',\n code: '🇱🇦',\n keywords: [\n 'laos',\n 'flag',\n ],\n },\n {\n name: 'lebanon',\n code: '🇱🇧',\n keywords: [\n 'lebanon',\n 'flag',\n ],\n },\n {\n name: 'st_lucia',\n code: '🇱🇨',\n keywords: [\n 'st_lucia',\n 'flag',\n 'lucia',\n 'saint',\n ],\n },\n {\n name: 'liechtenstein',\n code: '🇱🇮',\n keywords: [\n 'liechtenstein',\n 'flag',\n ],\n },\n {\n name: 'sri_lanka',\n code: '🇱🇰',\n keywords: [\n 'sri_lanka',\n 'flag',\n 'sri lanka',\n ],\n },\n {\n name: 'liberia',\n code: '🇱🇷',\n keywords: [\n 'liberia',\n 'flag',\n ],\n },\n {\n name: 'lesotho',\n code: '🇱🇸',\n keywords: [\n 'lesotho',\n 'flag',\n ],\n },\n {\n name: 'lithuania',\n code: '🇱🇹',\n keywords: [\n 'lithuania',\n 'flag',\n ],\n },\n {\n name: 'luxembourg',\n code: '🇱🇺',\n keywords: [\n 'luxembourg',\n 'flag',\n ],\n },\n {\n name: 'latvia',\n code: '🇱🇻',\n keywords: [\n 'latvia',\n 'flag',\n ],\n },\n {\n name: 'libya',\n code: '🇱🇾',\n keywords: [\n 'libya',\n 'flag',\n ],\n },\n {\n name: 'morocco',\n code: '🇲🇦',\n keywords: [\n 'morocco',\n 'flag',\n ],\n },\n {\n name: 'monaco',\n code: '🇲🇨',\n keywords: [\n 'monaco',\n 'flag',\n ],\n },\n {\n name: 'moldova',\n code: '🇲🇩',\n keywords: [\n 'moldova',\n 'flag',\n ],\n },\n {\n name: 'montenegro',\n code: '🇲🇪',\n keywords: [\n 'montenegro',\n 'flag',\n ],\n },\n {\n name: 'st_martin',\n code: '🇲🇫',\n keywords: [\n 'st_martin',\n 'flag',\n 'french',\n 'martin',\n 'saint',\n ],\n },\n {\n name: 'madagascar',\n code: '🇲🇬',\n keywords: [\n 'madagascar',\n 'flag',\n ],\n },\n {\n name: 'marshall_islands',\n code: '🇲🇭',\n keywords: [\n 'marshall_islands',\n 'flag',\n 'island',\n 'marshall',\n ],\n },\n {\n name: 'macedonia',\n code: '🇲🇰',\n keywords: [\n 'macedonia',\n 'flag',\n ],\n },\n {\n name: 'mali',\n code: '🇲🇱',\n keywords: [\n 'mali',\n 'flag',\n ],\n },\n {\n name: 'myanmar',\n code: '🇲🇲',\n keywords: [\n 'burma',\n 'myanmar',\n 'flag',\n ],\n },\n {\n name: 'mongolia',\n code: '🇲🇳',\n keywords: [\n 'mongolia',\n 'flag',\n ],\n },\n {\n name: 'macau',\n code: '🇲🇴',\n keywords: [\n 'macau',\n 'china',\n 'flag',\n 'macao',\n ],\n },\n {\n name: 'northern_mariana_islands',\n code: '🇲🇵',\n keywords: [\n 'northern_mariana_islands',\n 'flag',\n 'island',\n 'mariana',\n 'north',\n 'northern mariana',\n ],\n },\n {\n name: 'martinique',\n code: '🇲🇶',\n keywords: [\n 'martinique',\n 'flag',\n ],\n },\n {\n name: 'mauritania',\n code: '🇲🇷',\n keywords: [\n 'mauritania',\n 'flag',\n ],\n },\n {\n name: 'montserrat',\n code: '🇲🇸',\n keywords: [\n 'montserrat',\n 'flag',\n ],\n },\n {\n name: 'malta',\n code: '🇲🇹',\n keywords: [\n 'malta',\n 'flag',\n ],\n },\n {\n name: 'mauritius',\n code: '🇲🇺',\n keywords: [\n 'mauritius',\n 'flag',\n ],\n },\n {\n name: 'maldives',\n code: '🇲🇻',\n keywords: [\n 'maldives',\n 'flag',\n ],\n },\n {\n name: 'malawi',\n code: '🇲🇼',\n keywords: [\n 'malawi',\n 'flag',\n ],\n },\n {\n name: 'mexico',\n code: '🇲🇽',\n keywords: [\n 'mexico',\n 'flag',\n ],\n },\n {\n name: 'malaysia',\n code: '🇲🇾',\n keywords: [\n 'malaysia',\n 'flag',\n ],\n },\n {\n name: 'mozambique',\n code: '🇲🇿',\n keywords: [\n 'mozambique',\n 'flag',\n ],\n },\n {\n name: 'namibia',\n code: '🇳🇦',\n keywords: [\n 'namibia',\n 'flag',\n ],\n },\n {\n name: 'new_caledonia',\n code: '🇳🇨',\n keywords: [\n 'new_caledonia',\n 'flag',\n 'new',\n 'new caledonia',\n ],\n },\n {\n name: 'niger',\n code: '🇳🇪',\n keywords: [\n 'niger',\n 'flag',\n ],\n },\n {\n name: 'norfolk_island',\n code: '🇳🇫',\n keywords: [\n 'norfolk_island',\n 'flag',\n 'island',\n 'norfolk',\n ],\n },\n {\n name: 'nigeria',\n code: '🇳🇬',\n keywords: [\n 'nigeria',\n 'flag',\n ],\n },\n {\n name: 'nicaragua',\n code: '🇳🇮',\n keywords: [\n 'nicaragua',\n 'flag',\n ],\n },\n {\n name: 'netherlands',\n code: '🇳🇱',\n keywords: [\n 'netherlands',\n 'flag',\n ],\n },\n {\n name: 'norway',\n code: '🇳🇴',\n keywords: [\n 'norway',\n 'flag',\n ],\n },\n {\n name: 'nepal',\n code: '🇳🇵',\n keywords: [\n 'nepal',\n 'flag',\n ],\n },\n {\n name: 'nauru',\n code: '🇳🇷',\n keywords: [\n 'nauru',\n 'flag',\n ],\n },\n {\n name: 'niue',\n code: '🇳🇺',\n keywords: [\n 'niue',\n 'flag',\n ],\n },\n {\n name: 'new_zealand',\n code: '🇳🇿',\n keywords: [\n 'new_zealand',\n 'flag',\n 'new',\n 'new zealand',\n ],\n },\n {\n name: 'oman',\n code: '🇴🇲',\n keywords: [\n 'oman',\n 'flag',\n ],\n },\n {\n name: 'panama',\n code: '🇵🇦',\n keywords: [\n 'panama',\n 'flag',\n ],\n },\n {\n name: 'peru',\n code: '🇵🇪',\n keywords: [\n 'peru',\n 'flag',\n ],\n },\n {\n name: 'french_polynesia',\n code: '🇵🇫',\n keywords: [\n 'french_polynesia',\n 'flag',\n 'french',\n 'polynesia',\n ],\n },\n {\n name: 'papua_new_guinea',\n code: '🇵🇬',\n keywords: [\n 'papua_new_guinea',\n 'flag',\n 'guinea',\n 'new',\n 'papua new guinea',\n ],\n },\n {\n name: 'philippines',\n code: '🇵🇭',\n keywords: [\n 'philippines',\n 'flag',\n ],\n },\n {\n name: 'pakistan',\n code: '🇵🇰',\n keywords: [\n 'pakistan',\n 'flag',\n ],\n },\n {\n name: 'poland',\n code: '🇵🇱',\n keywords: [\n 'poland',\n 'flag',\n ],\n },\n {\n name: 'st_pierre_miquelon',\n code: '🇵🇲',\n keywords: [\n 'st_pierre_miquelon',\n 'flag',\n 'miquelon',\n 'pierre',\n 'saint',\n ],\n },\n {\n name: 'pitcairn_islands',\n code: '🇵🇳',\n keywords: [\n 'pitcairn_islands',\n 'flag',\n 'island',\n 'pitcairn',\n ],\n },\n {\n name: 'puerto_rico',\n code: '🇵🇷',\n keywords: [\n 'puerto_rico',\n 'flag',\n 'puerto rico',\n ],\n },\n {\n name: 'palestinian_territories',\n code: '🇵🇸',\n keywords: [\n 'palestinian_territories',\n 'flag',\n 'palestine',\n ],\n },\n {\n name: 'portugal',\n code: '🇵🇹',\n keywords: [\n 'portugal',\n 'flag',\n ],\n },\n {\n name: 'palau',\n code: '🇵🇼',\n keywords: [\n 'palau',\n 'flag',\n ],\n },\n {\n name: 'paraguay',\n code: '🇵🇾',\n keywords: [\n 'paraguay',\n 'flag',\n ],\n },\n {\n name: 'qatar',\n code: '🇶🇦',\n keywords: [\n 'qatar',\n 'flag',\n ],\n },\n {\n name: 'reunion',\n code: '🇷🇪',\n keywords: [\n 'reunion',\n 'flag',\n 'réunion',\n ],\n },\n {\n name: 'romania',\n code: '🇷🇴',\n keywords: [\n 'romania',\n 'flag',\n ],\n },\n {\n name: 'serbia',\n code: '🇷🇸',\n keywords: [\n 'serbia',\n 'flag',\n ],\n },\n {\n name: 'ru',\n code: '🇷🇺',\n keywords: [\n 'russia',\n 'ru',\n 'flag',\n ],\n },\n {\n name: 'rwanda',\n code: '🇷🇼',\n keywords: [\n 'rwanda',\n 'flag',\n ],\n },\n {\n name: 'saudi_arabia',\n code: '🇸🇦',\n keywords: [\n 'saudi_arabia',\n 'flag',\n 'saudi arabia',\n ],\n },\n {\n name: 'solomon_islands',\n code: '🇸🇧',\n keywords: [\n 'solomon_islands',\n 'flag',\n 'island',\n 'solomon',\n ],\n },\n {\n name: 'seychelles',\n code: '🇸🇨',\n keywords: [\n 'seychelles',\n 'flag',\n ],\n },\n {\n name: 'sudan',\n code: '🇸🇩',\n keywords: [\n 'sudan',\n 'flag',\n ],\n },\n {\n name: 'sweden',\n code: '🇸🇪',\n keywords: [\n 'sweden',\n 'flag',\n ],\n },\n {\n name: 'singapore',\n code: '🇸🇬',\n keywords: [\n 'singapore',\n 'flag',\n ],\n },\n {\n name: 'st_helena',\n code: '🇸🇭',\n keywords: [\n 'st_helena',\n 'flag',\n 'helena',\n 'saint',\n ],\n },\n {\n name: 'slovenia',\n code: '🇸🇮',\n keywords: [\n 'slovenia',\n 'flag',\n ],\n },\n {\n name: 'svalbard_jan_mayen',\n code: '🇸🇯',\n keywords: [\n 'svalbard_jan_mayen',\n 'flag',\n 'jan mayen',\n 'svalbard',\n ],\n },\n {\n name: 'slovakia',\n code: '🇸🇰',\n keywords: [\n 'slovakia',\n 'flag',\n ],\n },\n {\n name: 'sierra_leone',\n code: '🇸🇱',\n keywords: [\n 'sierra_leone',\n 'flag',\n 'sierra leone',\n ],\n },\n {\n name: 'san_marino',\n code: '🇸🇲',\n keywords: [\n 'san_marino',\n 'flag',\n 'san marino',\n ],\n },\n {\n name: 'senegal',\n code: '🇸🇳',\n keywords: [\n 'senegal',\n 'flag',\n ],\n },\n {\n name: 'somalia',\n code: '🇸🇴',\n keywords: [\n 'somalia',\n 'flag',\n ],\n },\n {\n name: 'suriname',\n code: '🇸🇷',\n keywords: [\n 'suriname',\n 'flag',\n ],\n },\n {\n name: 'south_sudan',\n code: '🇸🇸',\n keywords: [\n 'south_sudan',\n 'flag',\n 'south',\n 'south sudan',\n 'sudan',\n ],\n },\n {\n name: 'sao_tome_principe',\n code: '🇸🇹',\n keywords: [\n 'sao_tome_principe',\n 'flag',\n 'principe',\n 'príncipe',\n 'sao tome',\n 'são tomé',\n ],\n },\n {\n name: 'el_salvador',\n code: '🇸🇻',\n keywords: [\n 'el_salvador',\n 'el salvador',\n 'flag',\n ],\n },\n {\n name: 'sint_maarten',\n code: '🇸🇽',\n keywords: [\n 'sint_maarten',\n 'flag',\n 'maarten',\n 'sint',\n ],\n },\n {\n name: 'syria',\n code: '🇸🇾',\n keywords: [\n 'syria',\n 'flag',\n ],\n },\n {\n name: 'swaziland',\n code: '🇸🇿',\n keywords: [\n 'swaziland',\n 'flag',\n ],\n },\n {\n name: 'tristan_da_cunha',\n code: '🇹🇦',\n keywords: [\n 'tristan_da_cunha',\n 'flag',\n 'tristan da cunha',\n ],\n },\n {\n name: 'turks_caicos_islands',\n code: '🇹🇨',\n keywords: [\n 'turks_caicos_islands',\n 'caicos',\n 'flag',\n 'island',\n 'turks',\n ],\n },\n {\n name: 'chad',\n code: '🇹🇩',\n keywords: [\n 'chad',\n 'flag',\n ],\n },\n {\n name: 'french_southern_territories',\n code: '🇹🇫',\n keywords: [\n 'french_southern_territories',\n 'antarctic',\n 'flag',\n 'french',\n ],\n },\n {\n name: 'togo',\n code: '🇹🇬',\n keywords: [\n 'togo',\n 'flag',\n ],\n },\n {\n name: 'thailand',\n code: '🇹🇭',\n keywords: [\n 'thailand',\n 'flag',\n ],\n },\n {\n name: 'tajikistan',\n code: '🇹🇯',\n keywords: [\n 'tajikistan',\n 'flag',\n ],\n },\n {\n name: 'tokelau',\n code: '🇹🇰',\n keywords: [\n 'tokelau',\n 'flag',\n ],\n },\n {\n name: 'timor_leste',\n code: '🇹🇱',\n keywords: [\n 'timor_leste',\n 'east',\n 'east timor',\n 'flag',\n 'timor-leste',\n ],\n },\n {\n name: 'turkmenistan',\n code: '🇹🇲',\n keywords: [\n 'turkmenistan',\n 'flag',\n ],\n },\n {\n name: 'tunisia',\n code: '🇹🇳',\n keywords: [\n 'tunisia',\n 'flag',\n ],\n },\n {\n name: 'tonga',\n code: '🇹🇴',\n keywords: [\n 'tonga',\n 'flag',\n ],\n },\n {\n name: 'tr',\n code: '🇹🇷',\n keywords: [\n 'turkey',\n 'tr',\n 'flag',\n ],\n },\n {\n name: 'trinidad_tobago',\n code: '🇹🇹',\n keywords: [\n 'trinidad_tobago',\n 'flag',\n 'tobago',\n 'trinidad',\n ],\n },\n {\n name: 'tuvalu',\n code: '🇹🇻',\n keywords: [\n 'tuvalu',\n 'flag',\n ],\n },\n {\n name: 'taiwan',\n code: '🇹🇼',\n keywords: [\n 'taiwan',\n 'china',\n 'flag',\n ],\n },\n {\n name: 'tanzania',\n code: '🇹🇿',\n keywords: [\n 'tanzania',\n 'flag',\n ],\n },\n {\n name: 'ukraine',\n code: '🇺🇦',\n keywords: [\n 'ukraine',\n 'flag',\n ],\n },\n {\n name: 'uganda',\n code: '🇺🇬',\n keywords: [\n 'uganda',\n 'flag',\n ],\n },\n {\n name: 'us_outlying_islands',\n code: '🇺🇲',\n keywords: [\n 'us_outlying_islands',\n 'america',\n 'flag',\n 'island',\n 'minor outlying',\n 'united',\n 'united states',\n 'us',\n 'usa',\n ],\n },\n {\n name: 'united_nations',\n code: '🇺🇳',\n keywords: [\n 'united_nations',\n 'flag',\n ],\n },\n {\n name: 'us',\n code: '🇺🇸',\n keywords: [\n 'flag',\n 'united',\n 'america',\n 'us',\n 'stars and stripes',\n 'united states',\n ],\n },\n {\n name: 'uruguay',\n code: '🇺🇾',\n keywords: [\n 'uruguay',\n 'flag',\n ],\n },\n {\n name: 'uzbekistan',\n code: '🇺🇿',\n keywords: [\n 'uzbekistan',\n 'flag',\n ],\n },\n {\n name: 'vatican_city',\n code: '🇻🇦',\n keywords: [\n 'vatican_city',\n 'flag',\n 'vatican',\n ],\n },\n {\n name: 'st_vincent_grenadines',\n code: '🇻🇨',\n keywords: [\n 'st_vincent_grenadines',\n 'flag',\n 'grenadines',\n 'saint',\n 'vincent',\n ],\n },\n {\n name: 'venezuela',\n code: '🇻🇪',\n keywords: [\n 'venezuela',\n 'flag',\n ],\n },\n {\n name: 'british_virgin_islands',\n code: '🇻🇬',\n keywords: [\n 'british_virgin_islands',\n 'british',\n 'flag',\n 'island',\n 'virgin',\n ],\n },\n {\n name: 'us_virgin_islands',\n code: '🇻🇮',\n keywords: [\n 'us_virgin_islands',\n 'america',\n 'american',\n 'flag',\n 'island',\n 'united',\n 'united states',\n 'us',\n 'usa',\n 'virgin',\n ],\n },\n {\n name: 'vietnam',\n code: '🇻🇳',\n keywords: [\n 'vietnam',\n 'flag',\n 'viet nam',\n ],\n },\n {\n name: 'vanuatu',\n code: '🇻🇺',\n keywords: [\n 'vanuatu',\n 'flag',\n ],\n },\n {\n name: 'wallis_futuna',\n code: '🇼🇫',\n keywords: [\n 'wallis_futuna',\n 'flag',\n 'futuna',\n 'wallis',\n ],\n },\n {\n name: 'samoa',\n code: '🇼🇸',\n keywords: [\n 'samoa',\n 'flag',\n ],\n },\n {\n name: 'kosovo',\n code: '🇽🇰',\n keywords: [\n 'kosovo',\n 'flag',\n ],\n },\n {\n name: 'yemen',\n code: '🇾🇪',\n keywords: [\n 'yemen',\n 'flag',\n ],\n },\n {\n name: 'mayotte',\n code: '🇾🇹',\n keywords: [\n 'mayotte',\n 'flag',\n ],\n },\n {\n name: 'south_africa',\n code: '🇿🇦',\n keywords: [\n 'south_africa',\n 'flag',\n 'south',\n 'south africa',\n ],\n },\n {\n name: 'zambia',\n code: '🇿🇲',\n keywords: [\n 'zambia',\n 'flag',\n ],\n },\n {\n name: 'zimbabwe',\n code: '🇿🇼',\n keywords: [\n 'zimbabwe',\n 'flag',\n ],\n },\n {\n name: 'england',\n code: '🏴󠁧󠁢󠁥󠁮󠁧󠁿',\n keywords: [\n 'england',\n 'flag',\n ],\n },\n {\n name: 'scotland',\n code: '🏴󠁧󠁢󠁳󠁣󠁴󠁿',\n keywords: [\n 'scotland',\n 'flag',\n ],\n },\n {\n name: 'wales',\n code: '🏴󠁧󠁢󠁷󠁬󠁳󠁿',\n keywords: [\n 'wales',\n 'flag',\n ],\n },\n];\n\nexport {skinTones};\nexport default emojis;\n","\n\n\n\n\n","\n\n\n\n\n\n\n","\n\n\n\n\n","\n\n\n\n\n\n\n","\n\n\n\n\n\n\n","\n\n\n\n\n\n","\n\n\n\n\n","import _ from 'underscore';\nimport TrieNode from './TrieNode';\n\nclass Trie {\n constructor() {\n this.root = new TrieNode();\n }\n\n /**\n * Add a word to the Trie\n * @param {String} word\n * @param {Object} [metaData] - attach additional data to the word\n * @param {TrieNode} [node]\n * @param {Boolean} [allowEmptyWords] - empty word doesn't have any char, you shouldn't pass a true value for it because we are disallowing adding an empty word\n */\n add(word, metaData = {}, node = this.root, allowEmptyWords = false) {\n const newWord = word.toLowerCase();\n const newNode = node;\n if (newWord.length === 0 && !allowEmptyWords) {\n throw new Error('Cannot insert empty word into Trie');\n }\n if (newWord.length === 0) {\n newNode.isEndOfWord = true;\n newNode.metaData = metaData;\n return;\n }\n if (!newNode.children[newWord[0]]) {\n newNode.children[newWord[0]] = new TrieNode();\n this.add(newWord.substring(1), metaData, newNode.children[newWord[0]], true);\n }\n this.add(newWord.substring(1), metaData, newNode.children[newWord[0]], true);\n }\n\n /**\n * Search for a word in the Trie.\n * @param {String} word\n * @returns {Object|null} – the node for the word if it's found, or null if it's not found\n */\n search(word) {\n let newWord = word.toLowerCase();\n let node = this.root;\n while (newWord.length > 1) {\n if (!node.children[newWord[0]]) {\n return null;\n }\n node = node.children[newWord[0]];\n\n newWord = newWord.substring(1);\n }\n return node.children[newWord] && node.children[newWord].isEndOfWord ? node.children[newWord] : null;\n }\n\n /**\n * Update a word data in the Trie.\n * @param {String} word\n * @param {Object} metaData\n */\n update(word, metaData) {\n let newWord = word.toLowerCase();\n let node = this.root;\n while (newWord.length > 1) {\n if (!node.children[newWord[0]]) {\n throw new Error('Word does not exist in the Trie');\n }\n node = node.children[newWord[0]];\n newWord = newWord.substring(1);\n }\n node.children[newWord].metaData = metaData;\n }\n\n /**\n * Find all leaf nodes starting with a substring.\n * @param {String} substr\n * @param {Number} [limit] - matching words limit\n * @returns {Array}\n */\n getAllMatchingWords(substr, limit = 5) {\n const newSubstr = substr.toLowerCase();\n let node = this.root;\n let prefix = '';\n for (let i = 0; i < newSubstr.length; i++) {\n prefix += newSubstr[i];\n if (!node.children[newSubstr[i]]) {\n return [];\n }\n node = node.children[newSubstr[i]];\n }\n return this.getChildMatching(node, prefix, limit, []);\n }\n\n /**\n * Find all leaf nodes that are descendants of a given child node.\n * @param {TrieNode} node\n * @param {String} prefix\n * @param {Number} limit\n * @param {Array} [words]\n * @returns {Array}\n */\n getChildMatching(node, prefix, limit, words = []) {\n const matching = words;\n if (matching.length >= limit) {\n return matching;\n }\n if (node.isEndOfWord) {\n matching.push({name: prefix, metaData: node.metaData});\n }\n const children = _.keys(node.children);\n for (let i = 0; i < children.length; i++) {\n this.getChildMatching(node.children[children[i]], prefix + children[i], limit, matching);\n }\n return matching;\n }\n}\n\nexport default Trie;\n","class TrieNode {\n constructor() {\n this.children = {};\n this.isEndOfWord = false;\n this.metaData = {};\n }\n}\n\nexport default TrieNode;\n","function applyStrikethrough(html, isPendingDelete) {\n if (isPendingDelete) {\n return `${html}`;\n }\n return html;\n}\n\nexport default applyStrikethrough;\n","import React, {memo} from 'react';\nimport PropTypes from 'prop-types';\nimport styles from '../../../styles/styles';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport compose from '../../../libs/compose';\nimport Text from '../../../components/Text';\nimport {withCurrentDate} from '../../../components/OnyxProvider';\n\nconst propTypes = {\n /** UTC timestamp for when the action was created */\n created: PropTypes.string.isRequired,\n ...withLocalizePropTypes,\n};\n\nconst ReportActionItemDate = props => (\n \n {props.datetimeToCalendarTime(props.created)}\n \n);\n\nReportActionItemDate.propTypes = propTypes;\nReportActionItemDate.displayName = 'ReportActionItemDate';\n\nexport default compose(\n withLocalize,\n\n /** This component is hooked to the current date so that relative times can update when necessary\n * e.g. past midnight */\n withCurrentDate(),\n memo,\n)(ReportActionItemDate);\n","import React from 'react';\nimport {View, ScrollView} from 'react-native';\nimport PropTypes from 'prop-types';\nimport _ from 'underscore';\nimport {withOnyx} from 'react-native-onyx';\nimport Str from 'expensify-common/lib/str';\nimport lodashGet from 'lodash/get';\nimport styles from '../styles/styles';\nimport Text from '../components/Text';\nimport ONYXKEYS from '../ONYXKEYS';\nimport Avatar from '../components/Avatar';\nimport HeaderWithCloseButton from '../components/HeaderWithCloseButton';\nimport Navigation from '../libs/Navigation/Navigation';\nimport ScreenWrapper from '../components/ScreenWrapper';\nimport personalDetailsPropType from './personalDetailsPropType';\nimport withLocalize, {withLocalizePropTypes} from '../components/withLocalize';\nimport compose from '../libs/compose';\nimport CommunicationsLink from '../components/CommunicationsLink';\nimport Tooltip from '../components/Tooltip';\nimport CONST from '../CONST';\nimport * as ReportUtils from '../libs/ReportUtils';\nimport * as Expensicons from '../components/Icon/Expensicons';\nimport MenuItem from '../components/MenuItem';\nimport AttachmentModal from '../components/AttachmentModal';\nimport PressableWithoutFocus from '../components/PressableWithoutFocus';\nimport * as Report from '../libs/actions/Report';\nimport OfflineWithFeedback from '../components/OfflineWithFeedback';\nimport AutoUpdateTime from '../components/AutoUpdateTime';\nimport FullPageNotFoundView from '../components/BlockingViews/FullPageNotFoundView';\n\nconst matchType = PropTypes.shape({\n params: PropTypes.shape({\n /** login passed via route /details/:login */\n login: PropTypes.string,\n\n /** report ID passed */\n reportID: PropTypes.string,\n }),\n});\n\nconst propTypes = {\n /* Onyx Props */\n\n /** The personal details of the person who is logged in */\n personalDetails: personalDetailsPropType,\n\n /** Route params */\n route: matchType.isRequired,\n\n /** Session of currently logged in user */\n session: PropTypes.shape({\n email: PropTypes.string.isRequired,\n }),\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n // When opening someone else's profile (via deep link) before login, this is empty\n personalDetails: {},\n session: {\n email: null,\n },\n};\n\n/**\n * Gets the phone number to display for SMS logins\n *\n * @param {Object} details\n * @param {String} details.login\n * @param {String} details.displayName\n * @returns {String}\n */\nconst getPhoneNumber = (details) => {\n // If the user hasn't set a displayName, it is set to their phone number, so use that\n if (Str.isValidPhone(details.displayName)) {\n return details.displayName;\n }\n\n // If the user has set a displayName, get the phone number from the SMS login\n return Str.removeSMSDomain(details.login);\n};\n\nclass DetailsPage extends React.PureComponent {\n render() {\n const login = lodashGet(this.props.route.params, 'login', '');\n const reportID = lodashGet(this.props.route.params, 'reportID', '');\n let details = lodashGet(this.props.personalDetails, login);\n\n if (!details) {\n details = {\n login,\n displayName: ReportUtils.getDisplayNameForParticipant(login),\n avatar: ReportUtils.getAvatar(lodashGet(details, 'avatar', ''), login),\n };\n }\n\n const isSMSLogin = Str.isSMSLogin(details.login);\n\n // If we have a reportID param this means that we\n // arrived here via the ParticipantsPage and should be allowed to navigate back to it\n const shouldShowBackButton = Boolean(reportID);\n const shouldShowLocalTime = !ReportUtils.hasAutomatedExpensifyEmails([details.login]) && details.timezone;\n let pronouns = details.pronouns;\n\n if (pronouns && pronouns.startsWith(CONST.PRONOUNS.PREFIX)) {\n const localeKey = pronouns.replace(CONST.PRONOUNS.PREFIX, '');\n pronouns = this.props.translate(`pronouns.${localeKey}`);\n }\n\n return (\n \n \n Navigation.goBack()}\n onCloseButtonPress={() => Navigation.dismissModal()}\n />\n \n {details ? (\n \n \n \n {({show}) => (\n \n \n \n \n \n )}\n \n {Boolean(details.displayName) && (\n \n {isSMSLogin ? this.props.toLocalPhone(details.displayName) : details.displayName}\n \n )}\n {details.login ? (\n \n \n {this.props.translate(isSMSLogin\n ? 'common.phoneNumber'\n : 'common.email')}\n \n \n \n \n {isSMSLogin\n ? this.props.toLocalPhone(getPhoneNumber(details))\n : details.login}\n \n \n \n \n ) : null}\n {pronouns ? (\n \n \n {this.props.translate('profilePage.preferredPronouns')}\n \n \n {pronouns}\n \n \n ) : null}\n {shouldShowLocalTime && }\n \n {details.login !== this.props.session.email && (\n Report.navigateToAndOpenReport([details.login])}\n wrapperStyle={styles.breakAll}\n shouldShowRightIcon\n />\n )}\n \n ) : null}\n \n \n \n );\n }\n}\n\nDetailsPage.propTypes = propTypes;\nDetailsPage.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withOnyx({\n session: {\n key: ONYXKEYS.SESSION,\n },\n personalDetails: {\n key: ONYXKEYS.PERSONAL_DETAILS,\n },\n }),\n)(DetailsPage);\n","import React from 'react';\nimport {View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport styles from '../styles/styles';\nimport * as Expensicons from './Icon/Expensicons';\nimport Clipboard from '../libs/Clipboard';\nimport ContextMenuItem from './ContextMenuItem';\nimport withLocalize, {withLocalizePropTypes} from './withLocalize';\n\nconst propTypes = {\n /** Children to wrap in CommunicationsLink. */\n children: PropTypes.node.isRequired,\n\n /** Styles to be assigned to Container */\n // eslint-disable-next-line react/forbid-prop-types\n containerStyles: PropTypes.arrayOf(PropTypes.object),\n\n /** Value to be copied or passed via tap. */\n value: PropTypes.string.isRequired,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n containerStyles: [],\n};\n\nconst CommunicationsLink = props => (\n \n \n \n {props.children}\n \n Clipboard.setString(props.value)}\n />\n \n \n);\n\nCommunicationsLink.propTypes = propTypes;\nCommunicationsLink.defaultProps = defaultProps;\nCommunicationsLink.displayName = 'CommunicationsLink';\n\nexport default withLocalize(CommunicationsLink);\n","import React, {Component} from 'react';\nimport PropTypes from 'prop-types';\nimport MenuItem from './MenuItem';\nimport Icon from './Icon';\nimport styles from '../styles/styles';\nimport * as StyleUtils from '../styles/StyleUtils';\nimport getButtonState from '../libs/getButtonState';\nimport withDelayToggleButtonState, {withDelayToggleButtonStatePropTypes} from './withDelayToggleButtonState';\nimport BaseMiniContextMenuItem from './BaseMiniContextMenuItem';\n\nconst propTypes = {\n /** Icon Component */\n icon: PropTypes.elementType.isRequired,\n\n /** Text to display */\n text: PropTypes.string.isRequired,\n\n /** Icon to show when interaction was successful */\n successIcon: PropTypes.elementType,\n\n /** Text to show when interaction was successful */\n successText: PropTypes.string,\n\n /** Whether to show the mini menu */\n isMini: PropTypes.bool,\n\n /** Callback to fire when the item is pressed */\n onPress: PropTypes.func.isRequired,\n\n /** Automatically reset the success status */\n autoReset: PropTypes.bool,\n\n /** A description text to show under the title */\n description: PropTypes.string,\n\n ...withDelayToggleButtonStatePropTypes,\n};\n\nconst defaultProps = {\n isMini: false,\n successIcon: null,\n successText: '',\n autoReset: true,\n description: '',\n};\n\nclass ContextMenuItem extends Component {\n constructor(props) {\n super(props);\n\n this.triggerPressAndUpdateSuccess = this.triggerPressAndUpdateSuccess.bind(this);\n }\n\n /**\n * Method to call parent onPress and toggleDelayButtonState\n */\n triggerPressAndUpdateSuccess() {\n if (!this.props.isDelayButtonStateComplete) {\n this.props.onPress();\n }\n\n // We only set the success state when we have icon or text to represent the success state\n // We may want to replace this check by checking the Result from OnPress Callback in future.\n if (this.props.successIcon || this.props.successText) {\n this.props.toggleDelayButtonState(this.props.autoReset);\n }\n }\n\n render() {\n const icon = this.props.isDelayButtonStateComplete ? this.props.successIcon || this.props.icon : this.props.icon;\n const text = this.props.isDelayButtonStateComplete ? this.props.successText || this.props.text : this.props.text;\n return (\n this.props.isMini\n ? (\n \n {({hovered, pressed}) => (\n \n )}\n
          \n ) : (\n \n )\n );\n }\n}\n\nContextMenuItem.propTypes = propTypes;\nContextMenuItem.defaultProps = defaultProps;\n\nexport default withDelayToggleButtonState(ContextMenuItem);\n","import React, {PureComponent} from 'react';\nimport PropTypes from 'prop-types';\nimport {View, Animated, Keyboard} from 'react-native';\nimport Str from 'expensify-common/lib/str';\nimport lodashGet from 'lodash/get';\nimport lodashExtend from 'lodash/extend';\nimport _ from 'underscore';\nimport CONST from '../CONST';\nimport Modal from './Modal';\nimport AttachmentView from './AttachmentView';\nimport AttachmentCarousel from './AttachmentCarousel';\nimport styles from '../styles/styles';\nimport * as StyleUtils from '../styles/StyleUtils';\nimport * as FileUtils from '../libs/fileDownload/FileUtils';\nimport themeColors from '../styles/themes/default';\nimport compose from '../libs/compose';\nimport withWindowDimensions, {windowDimensionsPropTypes} from './withWindowDimensions';\nimport Button from './Button';\nimport HeaderWithCloseButton from './HeaderWithCloseButton';\nimport fileDownload from '../libs/fileDownload';\nimport withLocalize, {withLocalizePropTypes} from './withLocalize';\nimport ConfirmModal from './ConfirmModal';\nimport HeaderGap from './HeaderGap';\nimport SafeAreaConsumer from './SafeAreaConsumer';\n\n/**\n * Modal render prop component that exposes modal launching triggers that can be used\n * to display a full size image or PDF modally with optional confirmation button.\n */\n\nconst propTypes = {\n /** Optional source (URL, SVG function) for the image shown. If not passed in via props must be specified when modal is opened. */\n source: PropTypes.oneOfType([PropTypes.string, PropTypes.func]),\n\n /** Optional callback to fire when we want to preview an image and approve it for use. */\n onConfirm: PropTypes.func,\n\n /** Optional callback to fire when we want to do something after modal hide. */\n onModalHide: PropTypes.func,\n\n /** Optional original filename when uploading */\n originalFileName: PropTypes.string,\n\n /** A function as a child to pass modal launching methods to */\n children: PropTypes.func.isRequired,\n\n /** Whether source url requires authentication */\n isAuthTokenRequired: PropTypes.bool,\n\n /** Determines if download Button should be shown or not */\n allowDownload: PropTypes.bool,\n\n /** Title shown in the header of the modal */\n headerTitle: PropTypes.string,\n\n /** The ID of the report that has this attachment */\n reportID: PropTypes.string,\n\n ...withLocalizePropTypes,\n\n ...windowDimensionsPropTypes,\n};\n\nconst defaultProps = {\n source: '',\n onConfirm: null,\n originalFileName: '',\n isAuthTokenRequired: false,\n allowDownload: false,\n headerTitle: null,\n reportID: '',\n onModalHide: () => {},\n};\n\nclass AttachmentModal extends PureComponent {\n constructor(props) {\n super(props);\n\n this.state = {\n isModalOpen: false,\n shouldLoadAttachment: false,\n isAttachmentInvalid: false,\n attachmentInvalidReasonTitle: null,\n attachmentInvalidReason: null,\n source: props.source,\n modalType: CONST.MODAL.MODAL_TYPE.CENTERED_UNSWIPEABLE,\n isConfirmButtonDisabled: false,\n confirmButtonFadeAnimation: new Animated.Value(1),\n };\n\n this.submitAndClose = this.submitAndClose.bind(this);\n this.closeConfirmModal = this.closeConfirmModal.bind(this);\n this.onNavigate = this.onNavigate.bind(this);\n this.validateAndDisplayFileToUpload = this.validateAndDisplayFileToUpload.bind(this);\n this.updateConfirmButtonVisibility = this.updateConfirmButtonVisibility.bind(this);\n }\n\n /**\n * Helps to navigate between next/previous attachments\n * by setting sourceURL and file in state\n * @param {Object} attachmentData\n */\n onNavigate(attachmentData) {\n this.setState(attachmentData);\n }\n\n /**\n * If our attachment is a PDF, return the unswipeable Modal type.\n * @param {String} sourceURL\n * @param {Object} file\n * @returns {String}\n */\n getModalType(sourceURL, file) {\n return (\n sourceURL\n && (\n Str.isPDF(sourceURL)\n || (\n file\n && Str.isPDF(file.name || this.props.translate('attachmentView.unknownFilename'))\n )\n )\n )\n ? CONST.MODAL.MODAL_TYPE.CENTERED_UNSWIPEABLE\n : CONST.MODAL.MODAL_TYPE.CENTERED;\n }\n\n /**\n * @param {String} sourceURL\n */\n downloadAttachment(sourceURL) {\n const originalFileName = lodashGet(this.state, 'file.name') || this.props.originalFileName;\n fileDownload(sourceURL, originalFileName);\n\n // At ios, if the keyboard is open while opening the attachment, then after downloading\n // the attachment keyboard will show up. So, to fix it we need to dismiss the keyboard.\n Keyboard.dismiss();\n }\n\n /**\n * Execute the onConfirm callback and close the modal.\n */\n submitAndClose() {\n // If the modal has already been closed or the confirm button is disabled\n // do not submit.\n if (!this.state.isModalOpen || this.state.isConfirmButtonDisabled) {\n return;\n }\n\n if (this.props.onConfirm) {\n this.props.onConfirm(lodashExtend(this.state.file, {source: this.state.source}));\n }\n\n this.setState({isModalOpen: false});\n }\n\n /**\n * Close the confirm modal.\n */\n closeConfirmModal() {\n this.setState({isAttachmentInvalid: false});\n }\n\n /**\n * @param {Object} file\n * @returns {Boolean}\n */\n isValidFile(file) {\n const {fileExtension} = FileUtils.splitExtensionFromFileName(lodashGet(file, 'name', ''));\n if (!_.contains(CONST.API_ATTACHMENT_VALIDATIONS.ALLOWED_EXTENSIONS, fileExtension.toLowerCase())) {\n const invalidReason = `${this.props.translate('attachmentPicker.notAllowedExtension')} ${CONST.API_ATTACHMENT_VALIDATIONS.ALLOWED_EXTENSIONS.join(', ')}`;\n this.setState({\n isAttachmentInvalid: true,\n attachmentInvalidReasonTitle: this.props.translate('attachmentPicker.wrongFileType'),\n attachmentInvalidReason: invalidReason,\n });\n return false;\n }\n\n if (lodashGet(file, 'size', 0) > CONST.API_ATTACHMENT_VALIDATIONS.MAX_SIZE) {\n this.setState({\n isAttachmentInvalid: true,\n attachmentInvalidReasonTitle: this.props.translate('attachmentPicker.attachmentTooLarge'),\n attachmentInvalidReason: this.props.translate('attachmentPicker.sizeExceeded'),\n });\n return false;\n }\n\n if (lodashGet(file, 'size', 0) < CONST.API_ATTACHMENT_VALIDATIONS.MIN_SIZE) {\n this.setState({\n isAttachmentInvalid: true,\n attachmentInvalidReasonTitle: this.props.translate('attachmentPicker.attachmentTooSmall'),\n attachmentInvalidReason: this.props.translate('attachmentPicker.sizeNotMet'),\n });\n return false;\n }\n\n return true;\n }\n\n /**\n * @param {Object} file\n */\n validateAndDisplayFileToUpload(file) {\n if (!file) {\n return;\n }\n\n if (!this.isValidFile(file)) {\n return;\n }\n\n if (file instanceof File) {\n const source = URL.createObjectURL(file);\n const modalType = this.getModalType(source, file);\n this.setState({\n isModalOpen: true, source, file, modalType,\n });\n } else {\n const modalType = this.getModalType(file.uri, file);\n this.setState({\n isModalOpen: true, source: file.uri, file, modalType,\n });\n }\n }\n\n /**\n * In order to gracefully hide/show the confirm button when the keyboard\n * opens/closes, apply an animation to fade the confirm button out/in. And since\n * we're only updating the opacity of the confirm button, we must also conditionally\n * disable it.\n *\n * @param {Boolean} shouldFadeOut If true, fade out confirm button. Otherwise fade in.\n */\n updateConfirmButtonVisibility(shouldFadeOut) {\n this.setState({isConfirmButtonDisabled: shouldFadeOut});\n const toValue = shouldFadeOut ? 0 : 1;\n\n Animated.timing(this.state.confirmButtonFadeAnimation, {\n toValue,\n duration: 100,\n useNativeDriver: true,\n }).start();\n }\n\n render() {\n const source = this.state.source;\n return (\n <>\n this.setState({isModalOpen: false})}\n isVisible={this.state.isModalOpen}\n backgroundColor={themeColors.componentBG}\n onModalShow={() => this.setState({shouldLoadAttachment: true})}\n onModalHide={(e) => {\n this.props.onModalHide(e);\n this.setState({shouldLoadAttachment: false});\n }}\n propagateSwipe\n >\n {this.props.isSmallScreenWidth && }\n this.downloadAttachment(source)}\n onCloseButtonPress={() => this.setState({isModalOpen: false})}\n />\n \n {this.props.reportID ? (\n \n ) : Boolean(this.state.source) && this.state.shouldLoadAttachment && (\n \n )}\n \n {/* If we have an onConfirm method show a confirmation button */}\n {Boolean(this.props.onConfirm) && (\n \n {({safeAreaPaddingBottomStyle}) => (\n \n \n \n )}\n \n )}\n \n\n \n\n {this.props.children({\n displayFileInModal: this.validateAndDisplayFileToUpload,\n show: () => {\n this.setState({isModalOpen: true});\n },\n })}\n \n );\n }\n}\n\nAttachmentModal.propTypes = propTypes;\nAttachmentModal.defaultProps = defaultProps;\nexport default compose(\n withWindowDimensions,\n withLocalize,\n)(AttachmentModal);\n","module.exports = require('./assignIn');\n","var copyObject = require('./_copyObject'),\n createAssigner = require('./_createAssigner'),\n keysIn = require('./keysIn');\n\n/**\n * This method is like `_.assign` except that it iterates over own and\n * inherited source properties.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @alias extend\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @see _.assign\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * }\n *\n * function Bar() {\n * this.c = 3;\n * }\n *\n * Foo.prototype.b = 2;\n * Bar.prototype.d = 4;\n *\n * _.assignIn({ 'a': 0 }, new Foo, new Bar);\n * // => { 'a': 1, 'b': 2, 'c': 3, 'd': 4 }\n */\nvar assignIn = createAssigner(function(object, source) {\n copyObject(source, keysIn(source), object);\n});\n\nmodule.exports = assignIn;\n","import React, {memo} from 'react';\nimport {View, ActivityIndicator} from 'react-native';\nimport _ from 'underscore';\nimport PropTypes from 'prop-types';\nimport Str from 'expensify-common/lib/str';\nimport styles from '../styles/styles';\nimport PDFView from './PDFView';\nimport ImageView from './ImageView';\nimport Icon from './Icon';\nimport * as Expensicons from './Icon/Expensicons';\nimport withLocalize, {withLocalizePropTypes} from './withLocalize';\nimport compose from '../libs/compose';\nimport Text from './Text';\nimport Tooltip from './Tooltip';\nimport themeColors from '../styles/themes/default';\nimport variables from '../styles/variables';\nimport addEncryptedAuthTokenToURL from '../libs/addEncryptedAuthTokenToURL';\n\nconst propTypes = {\n /** Whether source url requires authentication */\n isAuthTokenRequired: PropTypes.bool,\n\n /** URL to full-sized attachment or SVG function */\n source: PropTypes.oneOfType([PropTypes.string, PropTypes.func]).isRequired,\n\n /** File object maybe be instance of File or Object */\n file: PropTypes.shape({\n name: PropTypes.string,\n }),\n\n /** Flag to show/hide download icon */\n shouldShowDownloadIcon: PropTypes.bool,\n\n /** Flag to show the loading indicator */\n shouldShowLoadingSpinnerIcon: PropTypes.bool,\n\n /** Function for handle on press */\n onPress: PropTypes.func,\n\n /** Notify parent that the UI should be modified to accommodate keyboard */\n onToggleKeyboard: PropTypes.func,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n isAuthTokenRequired: false,\n file: {\n name: '',\n },\n shouldShowDownloadIcon: false,\n shouldShowLoadingSpinnerIcon: false,\n onPress: () => {},\n onToggleKeyboard: () => {},\n};\n\nconst AttachmentView = (props) => {\n // Handles case where source is a component (ex: SVG)\n if (_.isFunction(props.source)) {\n return (\n \n );\n }\n\n // Check both source and file.name since PDFs dragged into the the text field\n // will appear with a source that is a blob\n if (Str.isPDF(props.source)\n || (props.file && Str.isPDF(props.file.name || props.translate('attachmentView.unknownFilename')))) {\n const sourceURL = props.isAuthTokenRequired\n ? addEncryptedAuthTokenToURL(props.source)\n : props.source;\n return (\n \n );\n }\n\n // For this check we use both source and file.name since temporary file source is a blob\n // both PDFs and images will appear as images when pasted into the the text field\n if (Str.isImage(props.source) || (props.file && Str.isImage(props.file.name))) {\n return (\n \n );\n }\n\n return (\n \n \n \n \n\n {props.file && props.file.name}\n {!props.shouldShowLoadingSpinnerIcon && props.shouldShowDownloadIcon && (\n \n \n \n \n \n )}\n {props.shouldShowLoadingSpinnerIcon && (\n \n \n \n \n \n )}\n \n );\n};\n\nAttachmentView.propTypes = propTypes;\nAttachmentView.defaultProps = defaultProps;\nAttachmentView.displayName = 'AttachmentView';\n\nexport default compose(\n memo,\n withLocalize,\n)(AttachmentView);\n","import React, {Component} from 'react';\nimport {TouchableWithoutFeedback, View} from 'react-native';\nimport PDF from 'react-native-pdf';\nimport KeyboardAvoidingView from '../KeyboardAvoidingView';\nimport styles from '../../styles/styles';\nimport * as StyleUtils from '../../styles/StyleUtils';\nimport FullScreenLoadingIndicator from '../FullscreenLoadingIndicator';\nimport Text from '../Text';\nimport PDFPasswordForm from './PDFPasswordForm';\nimport {propTypes as pdfViewPropTypes, defaultProps} from './pdfViewPropTypes';\nimport compose from '../../libs/compose';\nimport withWindowDimensions from '../withWindowDimensions';\nimport withKeyboardState, {keyboardStatePropTypes} from '../withKeyboardState';\nimport withLocalize from '../withLocalize';\n\nconst propTypes = {\n ...pdfViewPropTypes,\n ...keyboardStatePropTypes,\n};\n\n/**\n * On the native layer, we use react-native-pdf/PDF to display PDFs. If a PDF is\n * password-protected we render a PDFPasswordForm to request a password\n * from the user.\n *\n * In order to render things nicely during a password challenge we need\n * to keep track of additional state. In particular, the\n * react-native-pdf/PDF component is both conditionally rendered and hidden\n * depending upon the situation. It needs to be rerendered on each password\n * submission because it doesn't dynamically handle updates to its\n * password property. And we need to hide it during password challenges\n * so that PDFPasswordForm doesn't bounce when react-native-pdf/PDF\n * is (temporarily) rendered.\n */\nclass PDFView extends Component {\n constructor(props) {\n super(props);\n this.state = {\n shouldRequestPassword: false,\n shouldAttemptPDFLoad: true,\n shouldShowLoadingIndicator: true,\n isPasswordInvalid: false,\n failedToLoadPDF: false,\n password: '',\n };\n this.initiatePasswordChallenge = this.initiatePasswordChallenge.bind(this);\n this.attemptPDFLoadWithPassword = this.attemptPDFLoadWithPassword.bind(this);\n this.finishPDFLoad = this.finishPDFLoad.bind(this);\n this.handleFailureToLoadPDF = this.handleFailureToLoadPDF.bind(this);\n }\n\n componentDidUpdate() {\n this.props.onToggleKeyboard(this.props.isKeyboardShown);\n }\n\n handleFailureToLoadPDF(error) {\n if (error.message.match(/password/i)) {\n this.initiatePasswordChallenge();\n return;\n }\n\n this.setState({\n failedToLoadPDF: true,\n shouldAttemptPDFLoad: false,\n });\n }\n\n /**\n * Initiate password challenge if message received from react-native-pdf/PDF\n * indicates that a password is required or invalid.\n *\n * For a password challenge the message is \"Password required or incorrect password.\"\n * Note that the message doesn't specify whether the password is simply empty or\n * invalid.\n */\n initiatePasswordChallenge() {\n this.setState({shouldShowLoadingIndicator: false});\n\n // Render password form, and don't render PDF and loading indicator.\n this.setState({\n shouldRequestPassword: true,\n shouldAttemptPDFLoad: false,\n });\n\n // The message provided by react-native-pdf doesn't indicate whether this\n // is an initial password request or if the password is invalid. So we just assume\n // that if a password was already entered then it's an invalid password error.\n if (this.state.password) {\n this.setState({isPasswordInvalid: true});\n }\n }\n\n /**\n * When the password is submitted via PDFPasswordForm, save the password\n * in state and attempt to load the PDF. Also show the loading indicator\n * since react-native-pdf/PDF will need to reload the PDF.\n *\n * @param {String} password Password submitted via PDFPasswordForm\n */\n attemptPDFLoadWithPassword(password) {\n // Render react-native-pdf/PDF so that it can validate the password.\n // Note that at this point in the password challenge, shouldRequestPassword is true.\n // Thus react-native-pdf/PDF will be rendered - but not visible.\n this.setState({\n password,\n shouldAttemptPDFLoad: true,\n shouldShowLoadingIndicator: true,\n });\n }\n\n /**\n * After the PDF is successfully loaded hide PDFPasswordForm and the loading\n * indicator.\n */\n finishPDFLoad() {\n this.setState({\n shouldRequestPassword: false,\n shouldShowLoadingIndicator: false,\n });\n }\n\n render() {\n const pdfStyles = [\n styles.imageModalPDF,\n StyleUtils.getWidthAndHeightStyle(this.props.windowWidth, this.props.windowHeight),\n ];\n const touchableStyles = [\n styles.flex1,\n this.props.style,\n styles.w100,\n ];\n\n // If we haven't yet successfully validated the password and loaded the PDF,\n // then we need to hide the react-native-pdf/PDF component so that PDFPasswordForm\n // is positioned nicely. We're specifically hiding it because we still need to render\n // the PDF component so that it can validate the password.\n if (this.state.shouldRequestPassword) {\n pdfStyles.push(styles.invisible);\n }\n\n const containerStyles = this.state.shouldRequestPassword && this.props.isSmallScreenWidth\n ? [styles.w100, styles.flex1]\n : [styles.alignItemsCenter, styles.flex1];\n\n return (\n \n {this.state.failedToLoadPDF && (\n \n \n {this.props.translate('attachmentView.failedToLoadPDF')}\n \n \n )}\n {this.state.shouldAttemptPDFLoad && (\n \n }\n source={{uri: this.props.sourceURL}}\n style={pdfStyles}\n onError={this.handleFailureToLoadPDF}\n password={this.state.password}\n onLoadComplete={this.finishPDFLoad}\n onPageSingleTap={this.props.onPress}\n />\n \n )}\n {this.state.shouldRequestPassword && (\n \n this.setState({isPasswordInvalid: false})}\n isPasswordInvalid={this.state.isPasswordInvalid}\n shouldShowLoadingIndicator={this.state.shouldShowLoadingIndicator}\n />\n \n )}\n \n );\n }\n}\n\nPDFView.propTypes = propTypes;\nPDFView.defaultProps = defaultProps;\n\nexport default compose(\n withWindowDimensions,\n withKeyboardState,\n withLocalize,\n)(PDFView);\n","/**\n * Copyright (c) 2017-present, Wonday (@wonday.org)\n * All rights reserved.\n *\n * This source code is licensed under the MIT-style license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\nimport React, {Component} from 'react';\nimport PropTypes from 'prop-types';\nimport {\n requireNativeComponent,\n View,\n Platform,\n StyleSheet,\n Image,\n Text\n} from 'react-native';\n\nimport ReactNativeBlobUtil from 'react-native-blob-util'\nimport {ViewPropTypes} from 'deprecated-react-native-prop-types';\nconst SHA1 = require('crypto-js/sha1');\nimport PdfView from './PdfView';\n\nexport default class Pdf extends Component {\n\n static propTypes = {\n ...ViewPropTypes,\n source: PropTypes.oneOfType([\n PropTypes.shape({\n uri: PropTypes.string,\n cache: PropTypes.bool,\n cacheFileName: PropTypes.string,\n expiration: PropTypes.number,\n }),\n // Opaque type returned by require('./test.pdf')\n PropTypes.number,\n ]).isRequired,\n page: PropTypes.number,\n scale: PropTypes.number,\n minScale: PropTypes.number,\n maxScale: PropTypes.number,\n horizontal: PropTypes.bool,\n spacing: PropTypes.number,\n password: PropTypes.string,\n renderActivityIndicator: PropTypes.func,\n enableAntialiasing: PropTypes.bool,\n enableAnnotationRendering: PropTypes.bool,\n enablePaging: PropTypes.bool,\n enableRTL: PropTypes.bool,\n fitPolicy: PropTypes.number,\n trustAllCerts: PropTypes.bool,\n singlePage: PropTypes.bool,\n onLoadComplete: PropTypes.func,\n onPageChanged: PropTypes.func,\n onError: PropTypes.func,\n onPageSingleTap: PropTypes.func,\n onScaleChanged: PropTypes.func,\n onPressLink: PropTypes.func,\n\n // Props that are not available in the earlier react native version, added to prevent crashed on android\n accessibilityLabel: PropTypes.string,\n importantForAccessibility: PropTypes.string,\n renderToHardwareTextureAndroid: PropTypes.string,\n testID: PropTypes.string,\n onLayout: PropTypes.bool,\n accessibilityLiveRegion: PropTypes.string,\n accessibilityComponentType: PropTypes.string,\n };\n\n static defaultProps = {\n password: \"\",\n scale: 1,\n minScale: 1,\n maxScale: 3,\n spacing: 10,\n fitPolicy: 2, //fit both\n horizontal: false,\n page: 1,\n enableAntialiasing: true,\n enableAnnotationRendering: true,\n enablePaging: false,\n enableRTL: false,\n trustAllCerts: true,\n usePDFKit: true,\n singlePage: false,\n onLoadProgress: (percent) => {\n },\n onLoadComplete: (numberOfPages, path) => {\n },\n onPageChanged: (page, numberOfPages) => {\n },\n onError: (error) => {\n },\n onPageSingleTap: (page, x, y) => {\n },\n onScaleChanged: (scale) => {\n },\n onPressLink: (url) => {\n },\n };\n\n constructor(props) {\n\n super(props);\n this.state = {\n path: '',\n isDownloaded: false,\n progress: 0,\n isSupportPDFKit: -1\n };\n\n this.lastRNBFTask = null;\n\n }\n\n componentDidUpdate(prevProps) {\n\n const nextSource = Image.resolveAssetSource(this.props.source);\n const curSource = Image.resolveAssetSource(prevProps.source);\n\n if ((nextSource.uri !== curSource.uri)) {\n // if has download task, then cancel it.\n if (this.lastRNBFTask) {\n this.lastRNBFTask.cancel(err => {\n this._loadFromSource(this.props.source);\n });\n this.lastRNBFTask = null;\n } else {\n this._loadFromSource(this.props.source);\n }\n }\n }\n\n componentDidMount() {\n this._mounted = true;\n if (Platform.OS === \"ios\") {\n const PdfViewManagerNative = require('react-native').NativeModules.PdfViewManager;\n PdfViewManagerNative.supportPDFKit((isSupportPDFKit) => {\n if (this._mounted) {\n this.setState({isSupportPDFKit: isSupportPDFKit ? 1 : 0});\n }\n });\n }\n this._loadFromSource(this.props.source);\n }\n\n componentWillUnmount() {\n this._mounted = false;\n if (this.lastRNBFTask) {\n this.lastRNBFTask.cancel(err => {\n });\n this.lastRNBFTask = null;\n }\n\n }\n\n _loadFromSource = (newSource) => {\n\n const source = Image.resolveAssetSource(newSource) || {};\n\n let uri = source.uri || '';\n // first set to initial state\n if (this._mounted) {\n this.setState({isDownloaded: false, path: '', progress: 0});\n }\n const filename = source.cacheFileName || SHA1(uri) + '.pdf';\n const cacheFile = ReactNativeBlobUtil.fs.dirs.CacheDir + '/' + filename;\n\n if (source.cache) {\n ReactNativeBlobUtil.fs\n .stat(cacheFile)\n .then(stats => {\n if (!Boolean(source.expiration) || (source.expiration * 1000 + stats.lastModified) > (new Date().getTime())) {\n if (this._mounted) {\n this.setState({path: cacheFile, isDownloaded: true});\n }\n } else {\n // cache expirated then reload it\n this._prepareFile(source);\n }\n })\n .catch(() => {\n this._prepareFile(source);\n })\n\n } else {\n this._prepareFile(source);\n }\n };\n\n _prepareFile = async (source) => {\n\n try {\n if (source.uri) {\n let uri = source.uri || '';\n\n const isNetwork = !!(uri && uri.match(/^https?:\\/\\//));\n const isAsset = !!(uri && uri.match(/^bundle-assets:\\/\\//));\n const isBase64 = !!(uri && uri.match(/^data:application\\/pdf;base64/));\n\n const filename = source.cacheFileName || SHA1(uri) + '.pdf';\n const cacheFile = ReactNativeBlobUtil.fs.dirs.CacheDir + '/' + filename;\n\n // delete old cache file\n this._unlinkFile(cacheFile);\n\n if (isNetwork) {\n this._downloadFile(source, cacheFile);\n } else if (isAsset) {\n ReactNativeBlobUtil.fs\n .cp(uri, cacheFile)\n .then(() => {\n if (this._mounted) {\n this.setState({path: cacheFile, isDownloaded: true, progress: 1});\n }\n })\n .catch(async (error) => {\n this._unlinkFile(cacheFile);\n this._onError(error);\n })\n } else if (isBase64) {\n let data = uri.replace(/data:application\\/pdf;base64,/i, '');\n ReactNativeBlobUtil.fs\n .writeFile(cacheFile, data, 'base64')\n .then(() => {\n if (this._mounted) {\n this.setState({path: cacheFile, isDownloaded: true, progress: 1});\n }\n })\n .catch(async (error) => {\n this._unlinkFile(cacheFile);\n this._onError(error)\n });\n } else {\n if (this._mounted) {\n this.setState({\n path: uri.replace(/file:\\/\\//i, ''),\n isDownloaded: true,\n });\n }\n }\n } else {\n this._onError(new Error('no pdf source!'));\n }\n } catch (e) {\n this._onError(e)\n }\n\n\n };\n\n _downloadFile = async (source, cacheFile) => {\n\n if (this.lastRNBFTask) {\n this.lastRNBFTask.cancel(err => {\n });\n this.lastRNBFTask = null;\n }\n\n const tempCacheFile = cacheFile + '.tmp';\n this._unlinkFile(tempCacheFile);\n\n this.lastRNBFTask = ReactNativeBlobUtil.config({\n // response data will be saved to this path if it has access right.\n path: tempCacheFile,\n trusty: this.props.trustAllCerts,\n })\n .fetch(\n source.method ? source.method : 'GET',\n source.uri,\n source.headers ? source.headers : {},\n source.body ? source.body : \"\"\n )\n // listen to download progress event\n .progress((received, total) => {\n this.props.onLoadProgress && this.props.onLoadProgress(received / total);\n if (this._mounted) {\n this.setState({progress: received / total});\n }\n });\n\n this.lastRNBFTask\n .then(async (res) => {\n\n this.lastRNBFTask = null;\n\n if (res && res.respInfo && res.respInfo.headers && !res.respInfo.headers[\"Content-Encoding\"] && !res.respInfo.headers[\"Transfer-Encoding\"] && res.respInfo.headers[\"Content-Length\"]) {\n const expectedContentLength = res.respInfo.headers[\"Content-Length\"];\n let actualContentLength;\n\n try {\n const fileStats = await ReactNativeBlobUtil.fs.stat(res.path());\n\n if (!fileStats || !fileStats.size) {\n throw new Error(\"FileNotFound:\" + source.uri);\n }\n\n actualContentLength = fileStats.size;\n } catch (error) {\n throw new Error(\"DownloadFailed:\" + source.uri);\n }\n\n if (expectedContentLength != actualContentLength) {\n throw new Error(\"DownloadFailed:\" + source.uri);\n }\n }\n\n this._unlinkFile(cacheFile);\n ReactNativeBlobUtil.fs\n .cp(tempCacheFile, cacheFile)\n .then(() => {\n if (this._mounted) {\n this.setState({path: cacheFile, isDownloaded: true, progress: 1});\n }\n this._unlinkFile(tempCacheFile);\n })\n .catch(async (error) => {\n throw error;\n });\n })\n .catch(async (error) => {\n this._unlinkFile(tempCacheFile);\n this._unlinkFile(cacheFile);\n this._onError(error);\n });\n\n };\n\n _unlinkFile = async (file) => {\n try {\n await ReactNativeBlobUtil.fs.unlink(file);\n } catch (e) {\n\n }\n }\n\n setNativeProps = nativeProps => {\n if (this._root){\n this._root.setNativeProps(nativeProps);\n }\n };\n\n setPage( pageNumber ) {\n if ( (pageNumber === null) || (isNaN(pageNumber)) ) {\n throw new Error('Specified pageNumber is not a number');\n }\n this.setNativeProps({\n page: pageNumber\n });\n }\n\n _onChange = (event) => {\n\n let message = event.nativeEvent.message.split('|');\n //__DEV__ && console.log(\"onChange: \" + message);\n if (message.length > 0) {\n if (message.length > 5) {\n message[4] = message.splice(4).join('|');\n }\n if (message[0] === 'loadComplete') {\n this.props.onLoadComplete && this.props.onLoadComplete(Number(message[1]), this.state.path, {\n width: Number(message[2]),\n height: Number(message[3]),\n },\n message[4]&&JSON.parse(message[4]));\n } else if (message[0] === 'pageChanged') {\n this.props.onPageChanged && this.props.onPageChanged(Number(message[1]), Number(message[2]));\n } else if (message[0] === 'error') {\n this._onError(new Error(message[1]));\n } else if (message[0] === 'pageSingleTap') {\n this.props.onPageSingleTap && this.props.onPageSingleTap(Number(message[1]), Number(message[2]), Number(message[3]));\n } else if (message[0] === 'scaleChanged') {\n this.props.onScaleChanged && this.props.onScaleChanged(Number(message[1]));\n } else if (message[0] === 'linkPressed') {\n this.props.onPressLink && this.props.onPressLink(message[1]);\n }\n }\n\n };\n\n _onError = (error) => {\n\n this.props.onError && this.props.onError(error);\n\n };\n\n render() {\n if (Platform.OS === \"android\" || Platform.OS === \"ios\" || Platform.OS === \"windows\") {\n return (\n \n {!this.state.isDownloaded?\n (\n {this.props.renderActivityIndicator\n ? this.props.renderActivityIndicator(this.state.progress)\n : {`${(this.state.progress * 100).toFixed(2)}%`}}\n ):(\n Platform.OS === \"android\" || Platform.OS === \"windows\"?(\n (this._root = component)}\n {...this.props}\n style={[{flex:1,backgroundColor: '#EEE'}, this.props.style]}\n path={this.state.path}\n onChange={this._onChange}\n />\n ):(\n this.props.usePDFKit && this.state.isSupportPDFKit === 1?(\n (this._root = component)}\n {...this.props}\n style={[{backgroundColor: '#EEE',overflow: 'hidden'}, this.props.style]}\n path={this.state.path}\n onChange={this._onChange}\n />\n ):()\n )\n )}\n );\n } else {\n return (null);\n }\n\n\n }\n}\n\n\nif (Platform.OS === \"android\") {\n var PdfCustom = requireNativeComponent('RCTPdf', Pdf, {\n nativeOnly: {path: true, onChange: true},\n })\n} else if (Platform.OS === \"ios\") {\n var PdfCustom = requireNativeComponent('RCTPdfView', Pdf, {\n nativeOnly: {path: true, onChange: true},\n })\n} else if (Platform.OS === \"windows\") {\n var PdfCustom = requireNativeComponent('RCTPdf', Pdf, {\n nativeOnly: {path: true, onChange: true},\n })\n}\n\n\nconst styles = StyleSheet.create({\n progressContainer: {\n flex: 1,\n justifyContent: 'center',\n alignItems: 'center'\n },\n progressBar: {\n width: 200,\n height: 2\n }\n});\n","/**\n * Copyright (c) 2017-present, Wonday (@wonday.org)\n * All rights reserved.\n *\n * This source code is licensed under the MIT-style license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\nimport React, {Component} from 'react';\nimport {ScrollView, FlatList, View, StyleSheet} from 'react-native';\nimport {ViewPropTypes} from 'deprecated-react-native-prop-types';\nimport PropTypes from 'prop-types';\n\nimport PdfManager from './PdfManager';\nimport PdfPageView from './PdfPageView';\nimport DoubleTapView from './DoubleTapView';\nimport PinchZoomView from './PinchZoomView';\nimport PdfViewFlatList from './PdfViewFlatList';\n\nconst MIN_SCALE = 1;\nconst MAX_SCALE = 3;\n\nconst VIEWABILITYCONFIG = {minimumViewTime: 500, itemVisiblePercentThreshold: 10, waitForInteraction: false};\n\nexport default class PdfView extends Component {\n\n static propTypes = {\n ...ViewPropTypes,\n path: PropTypes.string,\n password: PropTypes.string,\n scale: PropTypes.number,\n minScale: PropTypes.number,\n maxScale: PropTypes.number,\n spacing: PropTypes.number,\n fitPolicy: PropTypes.number,\n horizontal: PropTypes.bool,\n page: PropTypes.number,\n currentPage: PropTypes.number,\n singlePage: PropTypes.bool,\n onPageSingleTap: PropTypes.func,\n onScaleChanged: PropTypes.func,\n };\n\n static defaultProps = {\n path: \"\",\n password: \"\",\n scale: 1,\n minScale: MIN_SCALE,\n maxScale: MAX_SCALE,\n spacing: 10,\n style: {},\n fitPolicy: 2,\n horizontal: false,\n centerContent: false,\n page: 1,\n currentPage: -1,\n enablePaging: false,\n singlePage: false,\n onPageSingleTap: (page, x, y) => {\n },\n onScaleChanged: (scale) => {\n },\n };\n\n constructor(props) {\n\n super(props);\n this.state = {\n pdfLoaded: false,\n fileNo: -1,\n numberOfPages: 0,\n page: -1,\n currentPage: -1,\n pageAspectRate: 0.5,\n pdfPageSize: {width: 0, height: 0},\n contentContainerSize: {width: 0, height: 0},\n scale: this.props.scale,\n contentOffset: {x: 0, y: 0},\n newContentOffset: {x: 0, y: 0},\n };\n\n this._flatList = null;\n this._scaleTimer = null;\n this._scrollTimer = null;\n this._mounted = false;\n\n }\n\n componentDidMount() {\n this._mounted = true;\n PdfManager.loadFile(this.props.path, this.props.password)\n .then((pdfInfo) => {\n if (this._mounted) {\n const fileNo = pdfInfo[0];\n const numberOfPages = pdfInfo[1];\n const width = pdfInfo[2];\n const height = pdfInfo[3];\n const pageAspectRatio = height === 0 ? 1 : width / height;\n\n this.setState({\n pdfLoaded: true,\n fileNo,\n numberOfPages,\n pageAspectRate: pageAspectRatio,\n pdfPageSize: {width, height},\n centerContent: numberOfPages > 1 ? false : true\n });\n if (this.props.onLoadComplete) {\n this.props.onLoadComplete(numberOfPages, this.props.path, {width, height});\n }\n }\n\n })\n .catch((error) => {\n this.props.onError(error);\n });\n\n clearTimeout(this._scrollTimer);\n this._scrollTimer = setTimeout(() => {\n if (this._flatList) {\n this._flatList.scrollToIndex({animated: false, index: this.props.page < 1 ? 0 : this.props.page - 1});\n }\n }, 200);\n }\n\n componentDidUpdate(prevProps) {\n\n if (this.props.scale !== this.state.scale) {\n this._onScaleChanged({\n scale: this.props.scale / this.state.scale,\n pageX: this.state.contentContainerSize.width / 2,\n pageY: this.state.contentContainerSize.height / 2\n });\n }\n\n if (this.props.horizontal !== prevProps.horizontal || this.props.page !== prevProps.page) {\n let page = (this.props.page) < 1 ? 1 : this.props.page;\n page = page > this.state.numberOfPages ? this.state.numberOfPages : page;\n\n if (this._flatList) {\n clearTimeout(this._scrollTimer);\n this._scrollTimer = setTimeout(() => {\n this._flatList.scrollToIndex({animated: false, index: page - 1});\n }, 200);\n }\n }\n\n }\n\n componentWillUnmount() {\n this._mounted = false;\n clearTimeout(this._scaleTimer);\n clearTimeout(this._scrollTimer);\n\n }\n\n _keyExtractor = (item, index) => \"pdf-page-\" + index;\n\n _getPageWidth = () => {\n\n let fitPolicy = this.props.fitPolicy;\n\n // if only one page, show whole page in center\n if (this.state.numberOfPages === 1 || this.props.singlePage) {\n fitPolicy = 2;\n }\n\n\n switch (fitPolicy) {\n case 0: //fit width\n return this.state.contentContainerSize.width * this.state.scale;\n case 1: //fit height\n return this.state.contentContainerSize.height * this.state.pageAspectRate * this.state.scale;\n case 2: //fit both\n default: {\n if (this.state.contentContainerSize.width/this.state.contentContainerSize.height {\n\n let fitPolicy = this.props.fitPolicy;\n\n // if only one page, show whole page in center\n if (this.state.numberOfPages === 1 || this.props.singlePage) {\n fitPolicy = 2;\n }\n\n switch (fitPolicy) {\n case 0: //fit width\n return this.state.contentContainerSize.width * (1 / this.state.pageAspectRate) * this.state.scale;\n case 1: //fit height\n return this.state.contentContainerSize.height * this.state.scale;\n case 2: //fit both\n default: {\n if (this.state.contentContainerSize.width/this.state.contentContainerSize.height (\n \n );\n\n _onItemSingleTap = (index, x, y) => {\n\n this.props.onPageSingleTap(index + 1, x, y);\n\n };\n\n _onItemDoubleTap = (index) => {\n\n if (this.state.scale >= this.props.maxScale) {\n this._onScaleChanged({\n scale: 1 / this.state.scale,\n pageX: this.state.contentContainerSize.width / 2,\n pageY: this.state.contentContainerSize.height / 2\n });\n } else {\n this._onScaleChanged({\n scale: 1.2,\n pageX: this.state.contentContainerSize.width / 2,\n pageY: this.state.contentContainerSize.height / 2\n });\n }\n\n };\n\n _onScaleChanged = (pinchInfo) => {\n\n let newScale = pinchInfo.scale * this.state.scale;\n newScale = newScale > this.props.maxScale ? this.props.maxScale : newScale;\n newScale = newScale < this.props.minScale ? this.props.minScale : newScale;\n let newContentOffset = {\n x: (this.state.contentOffset.x + pinchInfo.pageX) * (newScale / this.state.scale) - pinchInfo.pageX,\n y: (this.state.contentOffset.y + pinchInfo.pageY) * (newScale / this.state.scale) - pinchInfo.pageY\n }\n this.setState({scale: newScale, newContentOffset: newContentOffset});\n this.props.onScaleChanged(newScale);\n\n };\n\n _renderItem = ({item, index}) => {\n const pageView = (\n \n )\n\n if (this.props.singlePage) {\n return (\n \n {pageView}\n \n )\n }\n\n return (\n {\n this._onItemSingleTap(index, x, y);\n }}\n onDoubleTap={() => {\n this._onItemDoubleTap(index);\n }}\n >\n {pageView}\n {(index !== this.state.numberOfPages - 1) && this._renderSeparator()}\n \n );\n\n };\n\n _onViewableItemsChanged = (viewableInfo) => {\n\n for (let i = 0; i < viewableInfo.viewableItems.length; i++) {\n this._onPageChanged(viewableInfo.viewableItems[i].index + 1, this.state.numberOfPages);\n if (viewableInfo.viewableItems.length + viewableInfo.viewableItems[0].index < this.state.numberOfPages) break;\n }\n\n };\n\n _onPageChanged = (page, numberOfPages) => {\n if (this.props.onPageChanged && this.state.currentPage !== page) {\n this.props.onPageChanged(page, numberOfPages);\n this.setState({currentPage: page});\n }\n };\n\n\n _getRef = (ref) => this._flatList = ref;\n\n _getItemLayout = (data, index) => ({\n length: this.props.horizontal ? this._getPageWidth() : this._getPageHeight(),\n offset: ((this.props.horizontal ? this._getPageWidth() : this._getPageHeight()) + this.props.spacing * this.state.scale) * index,\n index\n });\n\n _onScroll = (e) => {\n this.setState({contentOffset: e.nativeEvent.contentOffset, newContentOffset: e.nativeEvent.contentOffset});\n };\n\n _onListContentSizeChange = (contentWidth, contentHeight) => {\n if (this.state.contentOffset.x != this.state.newContentOffset.x\n || this.state.contentOffset.y != this.state.newContentOffset.y) {\n this._flatList.scrollToXY(this.state.newContentOffset.x, this.state.newContentOffset.y);\n }\n };\n\n _renderList = () => {\n let data = [];\n\n if (this.props.singlePage) {\n data[0] = {key: this.props.currentPage >= 0 ? this.props.currentPage : 0}\n } else {\n for (let i = 0; i < this.state.numberOfPages; i++) {\n data[i] = {key: i};\n }\n }\n\n return (\n }\n initialScrollIndex={this.props.page < 1 ? 0 : this.props.page - 1}\n onViewableItemsChanged={this._onViewableItemsChanged}\n viewabilityConfig={VIEWABILITYCONFIG}\n onScroll={this._onScroll}\n onContentSizeChange={this._onListContentSizeChange}\n scrollEnabled={!this.props.singlePage}\n />\n );\n\n };\n\n _onLayout = (event) => {\n this.setState({\n contentContainerSize: {\n width: event.nativeEvent.layout.width,\n height: event.nativeEvent.layout.height\n }\n });\n };\n\n\n render() {\n if (this.props.singlePage) {\n return (\n \n {this.state.pdfLoaded && this._renderList()}\n \n )\n }\n\n return (\n \n {this.state.pdfLoaded && this._renderList()}\n \n );\n\n }\n\n}\n\nconst styles = StyleSheet.create({\n container: {\n flex: 1\n }\n});","/**\n * Copyright (c) 2017-present, Wonday (@wonday.org)\n * All rights reserved.\n *\n * This source code is licensed under the MIT-style license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nconst PdfManagerNative = require('react-native').NativeModules.PdfManager;\n\nexport default class PdfManager {\n\n static loadFile(path, password) {\n if (typeof path !== 'string') {\n throw new TypeError('path must be a valid string.');\n }\n\n if (password === undefined) {\n password = \"\";\n }\n\n return PdfManagerNative.loadFile(path, password);\n }\n}\n","/**\n * Copyright (c) 2017-present, Wonday (@wonday.org)\n * All rights reserved.\n *\n * This source code is licensed under the MIT-style license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n\n'use strict';\nimport React, {PureComponent} from 'react';\nimport PropTypes from 'prop-types';\nimport {\n requireNativeComponent,\n} from 'react-native';\nimport {ViewPropTypes} from 'deprecated-react-native-prop-types';\nexport default class PdfPageView extends PureComponent {\n _getStylePropsProps = () => {\n const {width, height} = this.props;\n if (width || height) {\n return {width, height};\n }\n return {};\n };\n\n render() {\n const {\n style,\n ...restProps\n } = this.props;\n return (\n \n );\n\n }\n}\n\nPdfPageView.propTypes = {\n ...ViewPropTypes,\n fileNo: PropTypes.number,\n page: PropTypes.number,\n width: PropTypes.number,\n height: PropTypes.number\n};\n\nPdfPageView.defaultProps = {\n style: {}\n};\n\nlet PdfPageViewCustom = requireNativeComponent('RCTPdfPageView', PdfPageView, {nativeOnly: {}});\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 * @format\n * @flow\n */\n\n'use strict';\n\nmodule.exports = {\n get ColorPropType() {\n return require('./DeprecatedColorPropType');\n },\n get EdgeInsetsPropType() {\n return require('./DeprecatedEdgeInsetsPropType');\n },\n get ImagePropTypes() {\n return require('./DeprecatedImagePropType');\n },\n get PointPropType() {\n return require('./DeprecatedPointPropType');\n },\n get TextInputPropTypes() {\n return require('./DeprecatedTextInputPropTypes');\n },\n get TextPropTypes() {\n return require('./DeprecatedTextPropTypes');\n },\n get ViewPropTypes() {\n return require('./DeprecatedViewPropTypes');\n },\n};\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 * @format\n */\n\n'use strict';\n\nconst normalizeColor = require('@react-native/normalize-color');\n\nconst colorPropType = function(\n isRequired,\n props,\n propName,\n componentName,\n location,\n propFullName,\n) {\n const color = props[propName];\n\n if (color == null) {\n if (isRequired) {\n return new Error(\n 'Required ' +\n location +\n ' `' +\n (propFullName || propName) +\n '` was not specified in `' +\n componentName +\n '`.',\n );\n }\n return;\n }\n\n if (typeof color === 'number') {\n // Developers should not use a number, but we are using the prop type\n // both for user provided colors and for transformed ones. This isn't ideal\n // and should be fixed but will do for now...\n return;\n }\n\n if (typeof color === 'string' && normalizeColor(color) === null) {\n return new Error(\n 'Invalid ' +\n location +\n ' `' +\n (propFullName || propName) +\n '` supplied to `' +\n componentName +\n '`: ' +\n color +\n '\\n' +\n `Valid color formats are\n - '#f0f' (#rgb)\n - '#f0fc' (#rgba)\n - '#ff00ff' (#rrggbb)\n - '#ff00ff00' (#rrggbbaa)\n - 'rgb(255, 255, 255)'\n - 'rgba(255, 255, 255, 1.0)'\n - 'hsl(360, 100%, 100%)'\n - 'hsla(360, 100%, 100%, 1.0)'\n - 'transparent'\n - 'red'\n - 0xff00ff00 (0xrrggbbaa)\n`,\n );\n }\n};\n\nconst ColorPropType = colorPropType.bind(null, false /* isRequired */);\nColorPropType.isRequired = colorPropType.bind(null, true /* isRequired */);\n\nmodule.exports = ColorPropType;\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 * @format\n */\n\n'use strict';\n\nconst PropTypes = require('prop-types');\n\nconst DeprecatedEdgeInsetsPropType = PropTypes.shape({\n top: PropTypes.number,\n left: PropTypes.number,\n bottom: PropTypes.number,\n right: PropTypes.number,\n});\n\nmodule.exports = DeprecatedEdgeInsetsPropType;\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 * @format\n */\n\n'use strict';\n\nconst DeprecatedEdgeInsetsPropType = require('./DeprecatedEdgeInsetsPropType');\nconst DeprecatedImageSourcePropType = require('./DeprecatedImageSourcePropType');\nconst DeprecatedImageStylePropTypes = require('./DeprecatedImageStylePropTypes');\nconst DeprecatedStyleSheetPropType = require('./DeprecatedStyleSheetPropType');\nconst PropTypes = require('prop-types');\n\nmodule.exports = {\n style: DeprecatedStyleSheetPropType(DeprecatedImageStylePropTypes),\n source: DeprecatedImageSourcePropType,\n defaultSource: PropTypes.oneOfType([\n PropTypes.shape({\n uri: PropTypes.string,\n width: PropTypes.number,\n height: PropTypes.number,\n scale: PropTypes.number,\n }),\n PropTypes.number,\n ]),\n\n accessible: PropTypes.bool,\n\n accessibilityLabel: PropTypes.node,\n\n blurRadius: PropTypes.number,\n\n capInsets: DeprecatedEdgeInsetsPropType,\n\n resizeMethod: PropTypes.oneOf(['auto', 'resize', 'scale']),\n\n resizeMode: PropTypes.oneOf([\n 'cover',\n 'contain',\n 'stretch',\n 'repeat',\n 'center',\n ]),\n\n testID: PropTypes.string,\n\n onLayout: PropTypes.func,\n\n onLoadStart: PropTypes.func,\n\n onProgress: PropTypes.func,\n\n onError: PropTypes.func,\n\n onPartialLoad: PropTypes.func,\n\n onLoad: PropTypes.func,\n\n onLoadEnd: PropTypes.func,\n};\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 * @format\n */\n\n'use strict';\n\nconst deprecatedCreateStrictShapeTypeChecker = require('./deprecatedCreateStrictShapeTypeChecker');\n\nfunction DeprecatedStyleSheetPropType(shape) {\n const shapePropType = deprecatedCreateStrictShapeTypeChecker(shape);\n return function(props, propName, componentName, location, ...rest) {\n let newProps = props;\n if (props[propName]) {\n // Just make a dummy prop object with only the flattened style\n newProps = {};\n newProps[propName] = flattenStyle(props[propName]);\n }\n return shapePropType(newProps, propName, componentName, location, ...rest);\n };\n}\n\nfunction flattenStyle(style) {\n if (style === null || typeof style !== 'object') {\n return undefined;\n }\n\n if (!Array.isArray(style)) {\n return style;\n }\n\n const result = {};\n for (let i = 0, styleLength = style.length; i < styleLength; ++i) {\n const computedStyle = flattenStyle(style[i]);\n if (computedStyle) {\n for (const key in computedStyle) {\n result[key] = computedStyle[key];\n }\n }\n }\n return result;\n}\n\nmodule.exports = DeprecatedStyleSheetPropType;\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 * @format\n */\n\n'use strict';\n\nconst invariant = require('invariant');\n\nfunction deprecatedCreateStrictShapeTypeChecker(shapeTypes) {\n function checkType(\n isRequired,\n props,\n propName,\n componentName,\n location,\n ...rest\n ) {\n if (!props[propName]) {\n if (isRequired) {\n invariant(\n false,\n `Required object \\`${propName}\\` was not specified in ` +\n `\\`${componentName}\\`.`,\n );\n }\n return;\n }\n const propValue = props[propName];\n const propType = typeof propValue;\n const locationName = location || '(unknown)';\n if (propType !== 'object') {\n invariant(\n false,\n `Invalid ${locationName} \\`${propName}\\` of type \\`${propType}\\` ` +\n `supplied to \\`${componentName}\\`, expected \\`object\\`.`,\n );\n }\n // We need to check all keys in case some are required but missing from\n // props.\n const allKeys = {...props[propName], ...shapeTypes};\n for (const key in allKeys) {\n const checker = shapeTypes[key];\n if (!checker) {\n invariant(\n false,\n `Invalid props.${propName} key \\`${key}\\` supplied to \\`${componentName}\\`.` +\n '\\nBad object: ' +\n JSON.stringify(props[propName], null, ' ') +\n '\\nValid keys: ' +\n JSON.stringify(Object.keys(shapeTypes), null, ' '),\n );\n }\n const error = checker(propValue, key, componentName, location, ...rest);\n if (error) {\n invariant(\n false,\n error.message +\n '\\nBad object: ' +\n JSON.stringify(props[propName], null, ' '),\n );\n }\n }\n }\n function chainedCheckType(props, propName, componentName, location, ...rest) {\n return checkType(false, props, propName, componentName, location, ...rest);\n }\n chainedCheckType.isRequired = checkType.bind(null, true);\n return chainedCheckType;\n}\n\nmodule.exports = deprecatedCreateStrictShapeTypeChecker;\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 * @format\n */\n\n'use strict';\n\nconst DeprecatedColorPropType = require('./DeprecatedColorPropType');\nconst DeprecatedLayoutPropTypes = require('./DeprecatedLayoutPropTypes');\nconst DeprecatedShadowPropTypesIOS = require('./DeprecatedShadowPropTypesIOS');\nconst DeprecatedTransformPropTypes = require('./DeprecatedTransformPropTypes');\nconst ReactPropTypes = require('prop-types');\n\nconst ImageStylePropTypes = {\n ...DeprecatedLayoutPropTypes,\n ...DeprecatedShadowPropTypesIOS,\n ...DeprecatedTransformPropTypes,\n resizeMode: ReactPropTypes.oneOf([\n 'center',\n 'contain',\n 'cover',\n 'repeat',\n 'stretch',\n ]),\n backfaceVisibility: ReactPropTypes.oneOf(['visible', 'hidden']),\n backgroundColor: DeprecatedColorPropType,\n borderColor: DeprecatedColorPropType,\n borderWidth: ReactPropTypes.number,\n borderRadius: ReactPropTypes.number,\n overflow: ReactPropTypes.oneOf(['visible', 'hidden']),\n\n /**\n * Changes the color of all the non-transparent pixels to the tintColor.\n */\n tintColor: DeprecatedColorPropType,\n opacity: ReactPropTypes.number,\n /**\n * When the image has rounded corners, specifying an overlayColor will\n * cause the remaining space in the corners to be filled with a solid color.\n * This is useful in cases which are not supported by the Android\n * implementation of rounded corners:\n * - Certain resize modes, such as 'contain'\n * - Animated GIFs\n *\n * A typical way to use this prop is with images displayed on a solid\n * background and setting the `overlayColor` to the same color\n * as the background.\n *\n * For details of how this works under the hood, see\n * http://frescolib.org/docs/rounded-corners-and-circles.html\n *\n * @platform android\n */\n overlayColor: ReactPropTypes.string,\n\n // Android-Specific styles\n borderTopLeftRadius: ReactPropTypes.number,\n borderTopRightRadius: ReactPropTypes.number,\n borderBottomLeftRadius: ReactPropTypes.number,\n borderBottomRightRadius: ReactPropTypes.number,\n};\n\nmodule.exports = ImageStylePropTypes;\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 * @format\n */\n\n'use strict';\n\nconst ReactPropTypes = require('prop-types');\n\nconst LayoutPropTypes = {\n display: ReactPropTypes.oneOf(['none', 'flex']),\n width: ReactPropTypes.oneOfType([\n ReactPropTypes.number,\n ReactPropTypes.string,\n ]),\n height: ReactPropTypes.oneOfType([\n ReactPropTypes.number,\n ReactPropTypes.string,\n ]),\n start: ReactPropTypes.oneOfType([\n ReactPropTypes.number,\n ReactPropTypes.string,\n ]),\n end: ReactPropTypes.oneOfType([ReactPropTypes.number, ReactPropTypes.string]),\n top: ReactPropTypes.oneOfType([ReactPropTypes.number, ReactPropTypes.string]),\n left: ReactPropTypes.oneOfType([\n ReactPropTypes.number,\n ReactPropTypes.string,\n ]),\n right: ReactPropTypes.oneOfType([\n ReactPropTypes.number,\n ReactPropTypes.string,\n ]),\n bottom: ReactPropTypes.oneOfType([\n ReactPropTypes.number,\n ReactPropTypes.string,\n ]),\n minWidth: ReactPropTypes.oneOfType([\n ReactPropTypes.number,\n ReactPropTypes.string,\n ]),\n maxWidth: ReactPropTypes.oneOfType([\n ReactPropTypes.number,\n ReactPropTypes.string,\n ]),\n minHeight: ReactPropTypes.oneOfType([\n ReactPropTypes.number,\n ReactPropTypes.string,\n ]),\n maxHeight: ReactPropTypes.oneOfType([\n ReactPropTypes.number,\n ReactPropTypes.string,\n ]),\n margin: ReactPropTypes.oneOfType([\n ReactPropTypes.number,\n ReactPropTypes.string,\n ]),\n marginVertical: ReactPropTypes.oneOfType([\n ReactPropTypes.number,\n ReactPropTypes.string,\n ]),\n marginHorizontal: ReactPropTypes.oneOfType([\n ReactPropTypes.number,\n ReactPropTypes.string,\n ]),\n marginTop: ReactPropTypes.oneOfType([\n ReactPropTypes.number,\n ReactPropTypes.string,\n ]),\n marginBottom: ReactPropTypes.oneOfType([\n ReactPropTypes.number,\n ReactPropTypes.string,\n ]),\n marginLeft: ReactPropTypes.oneOfType([\n ReactPropTypes.number,\n ReactPropTypes.string,\n ]),\n marginRight: ReactPropTypes.oneOfType([\n ReactPropTypes.number,\n ReactPropTypes.string,\n ]),\n marginStart: ReactPropTypes.oneOfType([\n ReactPropTypes.number,\n ReactPropTypes.string,\n ]),\n marginEnd: ReactPropTypes.oneOfType([\n ReactPropTypes.number,\n ReactPropTypes.string,\n ]),\n padding: ReactPropTypes.oneOfType([\n ReactPropTypes.number,\n ReactPropTypes.string,\n ]),\n paddingVertical: ReactPropTypes.oneOfType([\n ReactPropTypes.number,\n ReactPropTypes.string,\n ]),\n paddingHorizontal: ReactPropTypes.oneOfType([\n ReactPropTypes.number,\n ReactPropTypes.string,\n ]),\n paddingTop: ReactPropTypes.oneOfType([\n ReactPropTypes.number,\n ReactPropTypes.string,\n ]),\n paddingBottom: ReactPropTypes.oneOfType([\n ReactPropTypes.number,\n ReactPropTypes.string,\n ]),\n paddingLeft: ReactPropTypes.oneOfType([\n ReactPropTypes.number,\n ReactPropTypes.string,\n ]),\n paddingRight: ReactPropTypes.oneOfType([\n ReactPropTypes.number,\n ReactPropTypes.string,\n ]),\n paddingStart: ReactPropTypes.oneOfType([\n ReactPropTypes.number,\n ReactPropTypes.string,\n ]),\n paddingEnd: ReactPropTypes.oneOfType([\n ReactPropTypes.number,\n ReactPropTypes.string,\n ]),\n borderWidth: ReactPropTypes.number,\n borderTopWidth: ReactPropTypes.number,\n borderStartWidth: ReactPropTypes.number,\n borderEndWidth: ReactPropTypes.number,\n borderRightWidth: ReactPropTypes.number,\n borderBottomWidth: ReactPropTypes.number,\n borderLeftWidth: ReactPropTypes.number,\n position: ReactPropTypes.oneOf(['absolute', 'relative']),\n flexDirection: ReactPropTypes.oneOf([\n 'row',\n 'row-reverse',\n 'column',\n 'column-reverse',\n ]),\n flexWrap: ReactPropTypes.oneOf(['wrap', 'nowrap', 'wrap-reverse']),\n justifyContent: ReactPropTypes.oneOf([\n 'flex-start',\n 'flex-end',\n 'center',\n 'space-between',\n 'space-around',\n 'space-evenly',\n ]),\n alignItems: ReactPropTypes.oneOf([\n 'flex-start',\n 'flex-end',\n 'center',\n 'stretch',\n 'baseline',\n ]),\n alignSelf: ReactPropTypes.oneOf([\n 'auto',\n 'flex-start',\n 'flex-end',\n 'center',\n 'stretch',\n 'baseline',\n ]),\n alignContent: ReactPropTypes.oneOf([\n 'flex-start',\n 'flex-end',\n 'center',\n 'stretch',\n 'space-between',\n 'space-around',\n ]),\n overflow: ReactPropTypes.oneOf(['visible', 'hidden', 'scroll']),\n flex: ReactPropTypes.number,\n flexGrow: ReactPropTypes.number,\n flexShrink: ReactPropTypes.number,\n flexBasis: ReactPropTypes.oneOfType([\n ReactPropTypes.number,\n ReactPropTypes.string,\n ]),\n aspectRatio: ReactPropTypes.number,\n zIndex: ReactPropTypes.number,\n direction: ReactPropTypes.oneOf(['inherit', 'ltr', 'rtl']),\n};\n\nmodule.exports = LayoutPropTypes;\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 * @format\n */\n\n'use strict';\n\nconst DeprecatedColorPropType = require('./DeprecatedColorPropType');\nconst ReactPropTypes = require('prop-types');\n\nconst DeprecatedShadowPropTypesIOS = {\n shadowColor: DeprecatedColorPropType,\n shadowOffset: ReactPropTypes.shape({\n width: ReactPropTypes.number,\n height: ReactPropTypes.number,\n }),\n shadowOpacity: ReactPropTypes.number,\n shadowRadius: ReactPropTypes.number,\n};\n\nmodule.exports = DeprecatedShadowPropTypesIOS;\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 * @format\n */\n\n'use strict';\n\nconst ReactPropTypes = require('prop-types');\n\nconst TransformMatrixPropType = function(props, propName, componentName) {\n if (props[propName]) {\n return new Error(\n 'The transformMatrix style property is deprecated. ' +\n 'Use `transform: [{ matrix: ... }]` instead.',\n );\n }\n};\n\nconst DecomposedMatrixPropType = function(props, propName, componentName) {\n if (props[propName]) {\n return new Error(\n 'The decomposedMatrix style property is deprecated. ' +\n 'Use `transform: [...]` instead.',\n );\n }\n};\n\nconst DeprecatedTransformPropTypes = {\n transform: ReactPropTypes.arrayOf(\n ReactPropTypes.oneOfType([\n ReactPropTypes.shape({perspective: ReactPropTypes.number}),\n ReactPropTypes.shape({rotate: ReactPropTypes.string}),\n ReactPropTypes.shape({rotateX: ReactPropTypes.string}),\n ReactPropTypes.shape({rotateY: ReactPropTypes.string}),\n ReactPropTypes.shape({rotateZ: ReactPropTypes.string}),\n ReactPropTypes.shape({scale: ReactPropTypes.number}),\n ReactPropTypes.shape({scaleX: ReactPropTypes.number}),\n ReactPropTypes.shape({scaleY: ReactPropTypes.number}),\n ReactPropTypes.shape({translateX: ReactPropTypes.number}),\n ReactPropTypes.shape({translateY: ReactPropTypes.number}),\n ReactPropTypes.shape({skewX: ReactPropTypes.string}),\n ReactPropTypes.shape({skewY: ReactPropTypes.string}),\n ]),\n ),\n transformMatrix: TransformMatrixPropType,\n decomposedMatrix: DecomposedMatrixPropType,\n scaleX: deprecatedPropType(\n ReactPropTypes.number,\n 'Use the transform prop instead.',\n ),\n scaleY: deprecatedPropType(\n ReactPropTypes.number,\n 'Use the transform prop instead.',\n ),\n rotation: deprecatedPropType(\n ReactPropTypes.number,\n 'Use the transform prop instead.',\n ),\n translateX: deprecatedPropType(\n ReactPropTypes.number,\n 'Use the transform prop instead.',\n ),\n translateY: deprecatedPropType(\n ReactPropTypes.number,\n 'Use the transform prop instead.',\n ),\n};\n\n/**\n * Adds a deprecation warning when the prop is used.\n */\nfunction deprecatedPropType(propType, explanation) {\n return function validate(props, propName, componentName, ...rest) {\n if (props[propName] !== undefined) {\n console.warn(\n `\\`${propName}\\` supplied to \\`${componentName}\\` has been deprecated. ${explanation}`,\n );\n }\n\n return propType(props, propName, componentName, ...rest);\n };\n}\n\nmodule.exports = DeprecatedTransformPropTypes;\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 * @format\n */\n\n'use strict';\n\nconst PropTypes = require('prop-types');\n\nconst ImageURISourcePropType = PropTypes.shape({\n uri: PropTypes.string,\n bundle: PropTypes.string,\n method: PropTypes.string,\n headers: PropTypes.objectOf(PropTypes.string),\n body: PropTypes.string,\n cache: PropTypes.oneOf([\n 'default',\n 'reload',\n 'force-cache',\n 'only-if-cached',\n ]),\n width: PropTypes.number,\n height: PropTypes.number,\n scale: PropTypes.number,\n});\n\nconst ImageSourcePropType = PropTypes.oneOfType([\n ImageURISourcePropType,\n // Opaque type returned by require('./image.jpg')\n PropTypes.number,\n // Multiple sources\n PropTypes.arrayOf(ImageURISourcePropType),\n]);\n\nmodule.exports = ImageSourcePropType;\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 * @format\n */\n\n'use strict';\n\nconst PropTypes = require('prop-types');\n\nconst PointPropType = PropTypes.shape({\n x: PropTypes.number,\n y: PropTypes.number,\n});\n\nmodule.exports = PointPropType;\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 * @format\n */\n\n'use strict';\n\nconst DeprecatedColorPropType = require('./DeprecatedColorPropType');\nconst DeprecatedTextPropTypes = require('./DeprecatedTextPropTypes');\nconst DeprecatedViewPropTypes = require('./DeprecatedViewPropTypes');\nconst PropTypes = require('prop-types');\n\nconst DataDetectorTypes = [\n 'phoneNumber',\n 'link',\n 'address',\n 'calendarEvent',\n 'none',\n 'all',\n];\n\nmodule.exports = {\n ...DeprecatedViewPropTypes,\n /**\n * Can tell `TextInput` to automatically capitalize certain characters.\n *\n * - `characters`: all characters.\n * - `words`: first letter of each word.\n * - `sentences`: first letter of each sentence (*default*).\n * - `none`: don't auto capitalize anything.\n */\n autoCapitalize: PropTypes.oneOf(['none', 'sentences', 'words', 'characters']),\n /**\n * Determines which content to suggest on auto complete, e.g.`username`.\n * To disable auto complete, use `off`.\n *\n * *Android Only*\n *\n * The following values work on Android only:\n *\n * - `username`\n * - `password`\n * - `email`\n * - `name`\n * - `tel`\n * - `street-address`\n * - `postal-code`\n * - `cc-number`\n * - `cc-csc`\n * - `cc-exp`\n * - `cc-exp-month`\n * - `cc-exp-year`\n * - `off`\n *\n * @platform android\n */\n autoCompleteType: PropTypes.oneOf([\n 'cc-csc',\n 'cc-exp',\n 'cc-exp-month',\n 'cc-exp-year',\n 'cc-number',\n 'email',\n 'name',\n 'password',\n 'postal-code',\n 'street-address',\n 'tel',\n 'username',\n 'off',\n ]),\n /**\n * If `false`, disables auto-correct. The default value is `true`.\n */\n autoCorrect: PropTypes.bool,\n /**\n * If `false`, disables spell-check style (i.e. red underlines).\n * The default value is inherited from `autoCorrect`.\n * @platform ios\n */\n spellCheck: PropTypes.bool,\n /**\n * If `true`, focuses the input on `componentDidMount`.\n * The default value is `false`.\n */\n autoFocus: PropTypes.bool,\n /**\n * Specifies whether fonts should scale to respect Text Size accessibility settings. The\n * default is `true`.\n */\n allowFontScaling: PropTypes.bool,\n /**\n * Specifies largest possible scale a font can reach when `allowFontScaling` is enabled.\n * Possible values:\n * `null/undefined` (default): inherit from the parent node or the global default (0)\n * `0`: no max, ignore parent/global default\n * `>= 1`: sets the maxFontSizeMultiplier of this node to this value\n */\n maxFontSizeMultiplier: PropTypes.number,\n /**\n * If `false`, text is not editable. The default value is `true`.\n */\n editable: PropTypes.bool,\n /**\n * Determines which keyboard to open, e.g.`numeric`.\n *\n * The following values work across platforms:\n *\n * - `default`\n * - `numeric`\n * - `number-pad`\n * - `decimal-pad`\n * - `email-address`\n * - `phone-pad`\n *\n * *iOS Only*\n *\n * The following values work on iOS only:\n *\n * - `ascii-capable`\n * - `numbers-and-punctuation`\n * - `url`\n * - `name-phone-pad`\n * - `twitter`\n * - `web-search`\n * - `ascii-capable-number-pad`\n *\n * *Android Only*\n *\n * The following values work on Android only:\n *\n * - `visible-password`\n */\n keyboardType: PropTypes.oneOf([\n // Cross-platform\n 'default',\n 'email-address',\n 'numeric',\n 'phone-pad',\n 'number-pad',\n // iOS-only\n 'ascii-capable',\n 'numbers-and-punctuation',\n 'url',\n 'name-phone-pad',\n 'decimal-pad',\n 'twitter',\n 'web-search',\n // iOS 10+ only\n 'ascii-capable-number-pad',\n // Android-only\n 'visible-password',\n ]),\n /**\n * Determines the color of the keyboard.\n * @platform ios\n */\n keyboardAppearance: PropTypes.oneOf(['default', 'light', 'dark']),\n /**\n * Determines how the return key should look. On Android you can also use\n * `returnKeyLabel`.\n *\n * *Cross platform*\n *\n * The following values work across platforms:\n *\n * - `done`\n * - `go`\n * - `next`\n * - `search`\n * - `send`\n *\n * *Android Only*\n *\n * The following values work on Android only:\n *\n * - `none`\n * - `previous`\n *\n * *iOS Only*\n *\n * The following values work on iOS only:\n *\n * - `default`\n * - `emergency-call`\n * - `google`\n * - `join`\n * - `route`\n * - `yahoo`\n */\n returnKeyType: PropTypes.oneOf([\n // Cross-platform\n 'done',\n 'go',\n 'next',\n 'search',\n 'send',\n // Android-only\n 'none',\n 'previous',\n // iOS-only\n 'default',\n 'emergency-call',\n 'google',\n 'join',\n 'route',\n 'yahoo',\n ]),\n /**\n * Sets the return key to the label. Use it instead of `returnKeyType`.\n * @platform android\n */\n returnKeyLabel: PropTypes.string,\n /**\n * Limits the maximum number of characters that can be entered. Use this\n * instead of implementing the logic in JS to avoid flicker.\n */\n maxLength: PropTypes.number,\n /**\n * Sets the number of lines for a `TextInput`. Use it with multiline set to\n * `true` to be able to fill the lines.\n * @platform android\n */\n numberOfLines: PropTypes.number,\n /**\n * When `false`, if there is a small amount of space available around a text input\n * (e.g. landscape orientation on a phone), the OS may choose to have the user edit\n * the text inside of a full screen text input mode. When `true`, this feature is\n * disabled and users will always edit the text directly inside of the text input.\n * Defaults to `false`.\n * @platform android\n */\n disableFullscreenUI: PropTypes.bool,\n /**\n * If `true`, the keyboard disables the return key when there is no text and\n * automatically enables it when there is text. The default value is `false`.\n * @platform ios\n */\n enablesReturnKeyAutomatically: PropTypes.bool,\n /**\n * If `true`, the text input can be multiple lines.\n * The default value is `false`.\n */\n multiline: PropTypes.bool,\n /**\n * Set text break strategy on Android API Level 23+, possible values are `simple`, `highQuality`, `balanced`\n * The default value is `simple`.\n * @platform android\n */\n textBreakStrategy: PropTypes.oneOf(['simple', 'highQuality', 'balanced']),\n /**\n * Callback that is called when the text input is blurred.\n */\n onBlur: PropTypes.func,\n /**\n * Callback that is called when the text input is focused.\n */\n onFocus: PropTypes.func,\n /**\n * Callback that is called when the text input's text changes.\n */\n onChange: PropTypes.func,\n /**\n * Callback that is called when the text input's text changes.\n * Changed text is passed as an argument to the callback handler.\n */\n onChangeText: PropTypes.func,\n /**\n * Callback that is called when the text input's content size changes.\n * This will be called with\n * `{ nativeEvent: { contentSize: { width, height } } }`.\n *\n * Only called for multiline text inputs.\n */\n onContentSizeChange: PropTypes.func,\n onTextInput: PropTypes.func,\n /**\n * Callback that is called when text input ends.\n */\n onEndEditing: PropTypes.func,\n /**\n * Callback that is called when the text input selection is changed.\n * This will be called with\n * `{ nativeEvent: { selection: { start, end } } }`.\n */\n onSelectionChange: PropTypes.func,\n /**\n * Callback that is called when the text input's submit button is pressed.\n * Invalid if `multiline={true}` is specified.\n */\n onSubmitEditing: PropTypes.func,\n /**\n * Callback that is called when a key is pressed.\n * This will be called with `{ nativeEvent: { key: keyValue } }`\n * where `keyValue` is `'Enter'` or `'Backspace'` for respective keys and\n * the typed-in character otherwise including `' '` for space.\n * Fires before `onChange` callbacks.\n */\n onKeyPress: PropTypes.func,\n /**\n * Invoked on mount and layout changes with `{x, y, width, height}`.\n */\n onLayout: PropTypes.func,\n /**\n * Invoked on content scroll with `{ nativeEvent: { contentOffset: { x, y } } }`.\n * May also contain other properties from ScrollEvent but on Android contentSize\n * is not provided for performance reasons.\n */\n onScroll: PropTypes.func,\n /**\n * The string that will be rendered before text input has been entered.\n */\n placeholder: PropTypes.string,\n /**\n * The text color of the placeholder string.\n */\n placeholderTextColor: DeprecatedColorPropType,\n /**\n * If `false`, scrolling of the text view will be disabled.\n * The default value is `true`. Does only work with 'multiline={true}'.\n * @platform ios\n */\n scrollEnabled: PropTypes.bool,\n /**\n * If `true`, the text input obscures the text entered so that sensitive text\n * like passwords stay secure. The default value is `false`. Does not work with 'multiline={true}'.\n */\n secureTextEntry: PropTypes.bool,\n /**\n * The highlight and cursor color of the text input.\n */\n selectionColor: DeprecatedColorPropType,\n /**\n * The start and end of the text input's selection. Set start and end to\n * the same value to position the cursor.\n */\n selection: PropTypes.shape({\n start: PropTypes.number.isRequired,\n end: PropTypes.number,\n }),\n /**\n * The value to show for the text input. `TextInput` is a controlled\n * component, which means the native value will be forced to match this\n * value prop if provided. For most uses, this works great, but in some\n * cases this may cause flickering - one common cause is preventing edits\n * by keeping value the same. In addition to simply setting the same value,\n * either set `editable={false}`, or set/update `maxLength` to prevent\n * unwanted edits without flicker.\n */\n value: PropTypes.string,\n /**\n * Provides an initial value that will change when the user starts typing.\n * Useful for simple use-cases where you do not want to deal with listening\n * to events and updating the value prop to keep the controlled state in sync.\n */\n defaultValue: PropTypes.string,\n /**\n * When the clear button should appear on the right side of the text view.\n * This property is supported only for single-line TextInput component.\n * @platform ios\n */\n clearButtonMode: PropTypes.oneOf([\n 'never',\n 'while-editing',\n 'unless-editing',\n 'always',\n ]),\n /**\n * If `true`, clears the text field automatically when editing begins.\n * @platform ios\n */\n clearTextOnFocus: PropTypes.bool,\n /**\n * If `true`, all text will automatically be selected on focus.\n */\n selectTextOnFocus: PropTypes.bool,\n /**\n * If `true`, the text field will blur when submitted.\n * The default value is true for single-line fields and false for\n * multiline fields. Note that for multiline fields, setting `blurOnSubmit`\n * to `true` means that pressing return will blur the field and trigger the\n * `onSubmitEditing` event instead of inserting a newline into the field.\n */\n blurOnSubmit: PropTypes.bool,\n /**\n * Note that not all Text styles are supported, an incomplete list of what is not supported includes:\n *\n * - `borderLeftWidth`\n * - `borderTopWidth`\n * - `borderRightWidth`\n * - `borderBottomWidth`\n * - `borderTopLeftRadius`\n * - `borderTopRightRadius`\n * - `borderBottomRightRadius`\n * - `borderBottomLeftRadius`\n *\n * see [Issue#7070](https://github.com/facebook/react-native/issues/7070)\n * for more detail.\n *\n * [Styles](docs/style.html)\n */\n style: DeprecatedTextPropTypes.style,\n /**\n * The color of the `TextInput` underline.\n * @platform android\n */\n underlineColorAndroid: DeprecatedColorPropType,\n\n /**\n * If defined, the provided image resource will be rendered on the left.\n * The image resource must be inside `/android/app/src/main/res/drawable` and referenced\n * like\n * ```\n * \n * ```\n * @platform android\n */\n inlineImageLeft: PropTypes.string,\n\n /**\n * Padding between the inline image, if any, and the text input itself.\n * @platform android\n */\n inlineImagePadding: PropTypes.number,\n\n /**\n * If `true`, allows TextInput to pass touch events to the parent component.\n * This allows components such as SwipeableListView to be swipeable from the TextInput on iOS,\n * as is the case on Android by default.\n * If `false`, TextInput always asks to handle the input (except when disabled).\n * @platform ios\n */\n rejectResponderTermination: PropTypes.bool,\n\n /**\n * Determines the types of data converted to clickable URLs in the text input.\n * Only valid if `multiline={true}` and `editable={false}`.\n * By default no data types are detected.\n *\n * You can provide one type or an array of many types.\n *\n * Possible values for `dataDetectorTypes` are:\n *\n * - `'phoneNumber'`\n * - `'link'`\n * - `'address'`\n * - `'calendarEvent'`\n * - `'none'`\n * - `'all'`\n *\n * @platform ios\n */\n dataDetectorTypes: PropTypes.oneOfType([\n PropTypes.oneOf(DataDetectorTypes),\n PropTypes.arrayOf(PropTypes.oneOf(DataDetectorTypes)),\n ]),\n /**\n * If `true`, caret is hidden. The default value is `false`.\n * This property is supported only for single-line TextInput component on iOS.\n */\n caretHidden: PropTypes.bool,\n /*\n * If `true`, contextMenuHidden is hidden. The default value is `false`.\n */\n contextMenuHidden: PropTypes.bool,\n /**\n * An optional identifier which links a custom InputAccessoryView to\n * this text input. The InputAccessoryView is rendered above the\n * keyboard when this text input is focused.\n * @platform ios\n */\n inputAccessoryViewID: PropTypes.string,\n /**\n * Give the keyboard and the system information about the\n * expected semantic meaning for the content that users enter.\n * @platform ios\n */\n textContentType: PropTypes.oneOf([\n 'none',\n 'URL',\n 'addressCity',\n 'addressCityAndState',\n 'addressState',\n 'countryName',\n 'creditCardNumber',\n 'emailAddress',\n 'familyName',\n 'fullStreetAddress',\n 'givenName',\n 'jobTitle',\n 'location',\n 'middleName',\n 'name',\n 'namePrefix',\n 'nameSuffix',\n 'nickname',\n 'organizationName',\n 'postalCode',\n 'streetAddressLine1',\n 'streetAddressLine2',\n 'sublocality',\n 'telephoneNumber',\n 'username',\n 'password',\n 'newPassword',\n 'oneTimeCode',\n ]),\n /**\n * When `false`, it will prevent the soft keyboard from showing when the field is focused.\n * Defaults to `true`.\n */\n showSoftInputOnFocus: PropTypes.bool,\n};\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 * @format\n */\n\n'use strict';\n\nconst DeprecatedEdgeInsetsPropType = require('./DeprecatedEdgeInsetsPropType');\nconst DeprecatedStyleSheetPropType = require('./DeprecatedStyleSheetPropType');\nconst DeprecatedViewStylePropTypes = require('./DeprecatedViewStylePropTypes');\nconst PropTypes = require('prop-types');\n\nconst {DeprecatedAccessibilityRoles} = require('./DeprecatedViewAccessibility');\n\nconst stylePropType = DeprecatedStyleSheetPropType(\n DeprecatedViewStylePropTypes,\n);\n\nmodule.exports = {\n /**\n * When `true`, indicates that the view is an accessibility element.\n * By default, all the touchable elements are accessible.\n *\n * See https://reactnative.dev/docs/view.html#accessible\n */\n accessible: PropTypes.bool,\n\n /**\n * Overrides the text that's read by the screen reader when the user interacts\n * with the element. By default, the label is constructed by traversing all\n * the children and accumulating all the `Text` nodes separated by space.\n *\n * See https://reactnative.dev/docs/view.html#accessibilitylabel\n */\n accessibilityLabel: PropTypes.node,\n\n /**\n * An accessibility hint helps users understand what will happen when they perform\n * an action on the accessibility element when that result is not obvious from the\n * accessibility label.\n *\n *\n * See https://reactnative.dev/docs/view.html#accessibilityHint\n */\n accessibilityHint: PropTypes.string,\n\n /**\n * Provides an array of custom actions available for accessibility.\n *\n * @platform ios\n */\n accessibilityActions: PropTypes.arrayOf(PropTypes.string),\n\n /**\n * Prevents view from being inverted if set to true and color inversion is turned on.\n *\n * @platform ios\n */\n accessibilityIgnoresInvertColors: PropTypes.bool,\n\n /**\n * Indicates to accessibility services to treat UI component like a specific role.\n */\n accessibilityRole: PropTypes.oneOf(DeprecatedAccessibilityRoles),\n\n accessibilityState: PropTypes.object,\n accessibilityValue: PropTypes.object,\n /**\n * Indicates to accessibility services whether the user should be notified\n * when this view changes. Works for Android API >= 19 only.\n *\n * @platform android\n *\n * See https://reactnative.dev/docs/view.html#accessibilityliveregion\n */\n accessibilityLiveRegion: PropTypes.oneOf(['none', 'polite', 'assertive']),\n\n /**\n * Controls how view is important for accessibility which is if it\n * fires accessibility events and if it is reported to accessibility services\n * that query the screen. Works for Android only.\n *\n * @platform android\n *\n * See https://reactnative.dev/docs/view.html#importantforaccessibility\n */\n importantForAccessibility: PropTypes.oneOf([\n 'auto',\n 'yes',\n 'no',\n 'no-hide-descendants',\n ]),\n\n /**\n * A value indicating whether VoiceOver should ignore the elements\n * within views that are siblings of the receiver.\n * Default is `false`.\n *\n * @platform ios\n *\n * See https://reactnative.dev/docs/view.html#accessibilityviewismodal\n */\n accessibilityViewIsModal: PropTypes.bool,\n\n /**\n * A value indicating whether the accessibility elements contained within\n * this accessibility element are hidden.\n *\n * @platform ios\n *\n * See https://reactnative.dev/docs/view.html#accessibilityElementsHidden\n */\n accessibilityElementsHidden: PropTypes.bool,\n\n /**\n * When `accessible` is true, the system will try to invoke this function\n * when the user performs an accessibility custom action.\n *\n * @platform ios\n */\n onAccessibilityAction: PropTypes.func,\n\n /**\n * When `accessible` is true, the system will try to invoke this function\n * when the user performs accessibility tap gesture.\n *\n * See https://reactnative.dev/docs/view.html#onaccessibilitytap\n */\n onAccessibilityTap: PropTypes.func,\n\n /**\n * When `accessible` is `true`, the system will invoke this function when the\n * user performs the magic tap gesture.\n *\n * See https://reactnative.dev/docs/view.html#onmagictap\n */\n onMagicTap: PropTypes.func,\n\n /**\n * Used to locate this view in end-to-end tests.\n *\n * > This disables the 'layout-only view removal' optimization for this view!\n *\n * See https://reactnative.dev/docs/view.html#testid\n */\n testID: PropTypes.string,\n\n /**\n * Used to locate this view from native classes.\n *\n * > This disables the 'layout-only view removal' optimization for this view!\n *\n * See https://reactnative.dev/docs/view.html#nativeid\n */\n nativeID: PropTypes.string,\n\n /**\n * For most touch interactions, you'll simply want to wrap your component in\n * `TouchableHighlight` or `TouchableOpacity`. Check out `Touchable.js`,\n * `ScrollResponder.js` and `ResponderEventPlugin.js` for more discussion.\n */\n\n /**\n * The View is now responding for touch events. This is the time to highlight\n * and show the user what is happening.\n *\n * `View.props.onResponderGrant: (event) => {}`, where `event` is a synthetic\n * touch event as described above.\n *\n * See https://reactnative.dev/docs/view.html#onrespondergrant\n */\n onResponderGrant: PropTypes.func,\n\n /**\n * The user is moving their finger.\n *\n * `View.props.onResponderMove: (event) => {}`, where `event` is a synthetic\n * touch event as described above.\n *\n * See https://reactnative.dev/docs/view.html#onrespondermove\n */\n onResponderMove: PropTypes.func,\n\n /**\n * Another responder is already active and will not release it to that `View`\n * asking to be the responder.\n *\n * `View.props.onResponderReject: (event) => {}`, where `event` is a\n * synthetic touch event as described above.\n *\n * See https://reactnative.dev/docs/view.html#onresponderreject\n */\n onResponderReject: PropTypes.func,\n\n /**\n * Fired at the end of the touch.\n *\n * `View.props.onResponderRelease: (event) => {}`, where `event` is a\n * synthetic touch event as described above.\n *\n * See https://reactnative.dev/docs/view.html#onresponderrelease\n */\n onResponderRelease: PropTypes.func,\n\n /**\n * The responder has been taken from the `View`. Might be taken by other\n * views after a call to `onResponderTerminationRequest`, or might be taken\n * by the OS without asking (e.g., happens with control center/ notification\n * center on iOS)\n *\n * `View.props.onResponderTerminate: (event) => {}`, where `event` is a\n * synthetic touch event as described above.\n *\n * See https://reactnative.dev/docs/view.html#onresponderterminate\n */\n onResponderTerminate: PropTypes.func,\n\n /**\n * Some other `View` wants to become responder and is asking this `View` to\n * release its responder. Returning `true` allows its release.\n *\n * `View.props.onResponderTerminationRequest: (event) => {}`, where `event`\n * is a synthetic touch event as described above.\n *\n * See https://reactnative.dev/docs/view.html#onresponderterminationrequest\n */\n onResponderTerminationRequest: PropTypes.func,\n\n /**\n * Does this view want to become responder on the start of a touch?\n *\n * `View.props.onStartShouldSetResponder: (event) => [true | false]`, where\n * `event` is a synthetic touch event as described above.\n *\n * See https://reactnative.dev/docs/view.html#onstartshouldsetresponder\n */\n onStartShouldSetResponder: PropTypes.func,\n\n /**\n * If a parent `View` wants to prevent a child `View` from becoming responder\n * on a touch start, it should have this handler which returns `true`.\n *\n * `View.props.onStartShouldSetResponderCapture: (event) => [true | false]`,\n * where `event` is a synthetic touch event as described above.\n *\n * See https://reactnative.dev/docs/view.html#onstartshouldsetrespondercapture\n */\n onStartShouldSetResponderCapture: PropTypes.func,\n\n /**\n * Does this view want to \"claim\" touch responsiveness? This is called for\n * every touch move on the `View` when it is not the responder.\n *\n * `View.props.onMoveShouldSetResponder: (event) => [true | false]`, where\n * `event` is a synthetic touch event as described above.\n *\n * See https://reactnative.dev/docs/view.html#onmoveshouldsetresponder\n */\n onMoveShouldSetResponder: PropTypes.func,\n\n /**\n * If a parent `View` wants to prevent a child `View` from becoming responder\n * on a move, it should have this handler which returns `true`.\n *\n * `View.props.onMoveShouldSetResponderCapture: (event) => [true | false]`,\n * where `event` is a synthetic touch event as described above.\n *\n * See https://reactnative.dev/docs/view.html#onMoveShouldsetrespondercapture\n */\n onMoveShouldSetResponderCapture: PropTypes.func,\n\n /**\n * This defines how far a touch event can start away from the view.\n * Typical interface guidelines recommend touch targets that are at least\n * 30 - 40 points/density-independent pixels.\n *\n * > The touch area never extends past the parent view bounds and the Z-index\n * > of sibling views always takes precedence if a touch hits two overlapping\n * > views.\n *\n * See https://reactnative.dev/docs/view.html#hitslop\n */\n hitSlop: DeprecatedEdgeInsetsPropType,\n\n /**\n * Invoked on mount and layout changes with:\n *\n * `{nativeEvent: { layout: {x, y, width, height}}}`\n *\n * This event is fired immediately once the layout has been calculated, but\n * the new layout may not yet be reflected on the screen at the time the\n * event is received, especially if a layout animation is in progress.\n *\n * See https://reactnative.dev/docs/view.html#onlayout\n */\n onLayout: PropTypes.func,\n\n /**\n * Controls whether the `View` can be the target of touch events.\n *\n * See https://reactnative.dev/docs/view.html#pointerevents\n */\n pointerEvents: PropTypes.oneOf(['box-none', 'none', 'box-only', 'auto']),\n\n /**\n * See https://reactnative.dev/docs/style.html\n */\n style: stylePropType,\n\n /**\n * This is a special performance property exposed by `RCTView` and is useful\n * for scrolling content when there are many subviews, most of which are\n * offscreen. For this property to be effective, it must be applied to a\n * view that contains many subviews that extend outside its bound. The\n * subviews must also have `overflow: hidden`, as should the containing view\n * (or one of its superviews).\n *\n * See https://reactnative.dev/docs/view.html#removeclippedsubviews\n */\n removeClippedSubviews: PropTypes.bool,\n\n /**\n * Whether this `View` should render itself (and all of its children) into a\n * single hardware texture on the GPU.\n *\n * @platform android\n *\n * See https://reactnative.dev/docs/view.html#rendertohardwaretextureandroid\n */\n renderToHardwareTextureAndroid: PropTypes.bool,\n\n /**\n * Whether this `View` should be rendered as a bitmap before compositing.\n *\n * @platform ios\n *\n * See https://reactnative.dev/docs/view.html#shouldrasterizeios\n */\n shouldRasterizeIOS: PropTypes.bool,\n\n /**\n * Views that are only used to layout their children or otherwise don't draw\n * anything may be automatically removed from the native hierarchy as an\n * optimization. Set this property to `false` to disable this optimization and\n * ensure that this `View` exists in the native view hierarchy.\n *\n * @platform android\n *\n * See https://reactnative.dev/docs/view.html#collapsable\n */\n collapsable: PropTypes.bool,\n\n /**\n * Whether this `View` needs to rendered offscreen and composited with an\n * alpha in order to preserve 100% correct colors and blending behavior.\n *\n * @platform android\n *\n * See https://reactnative.dev/docs/view.html#needsoffscreenalphacompositing\n */\n needsOffscreenAlphaCompositing: PropTypes.bool,\n};\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 * @format\n */\n\n'use strict';\n\nconst DeprecatedColorPropType = require('./DeprecatedColorPropType');\nconst DeprecatedLayoutPropTypes = require('./DeprecatedLayoutPropTypes');\nconst DeprecatedShadowPropTypesIOS = require('./DeprecatedShadowPropTypesIOS');\nconst DeprecatedTransformPropTypes = require('./DeprecatedTransformPropTypes');\nconst ReactPropTypes = require('prop-types');\n\n/**\n * Warning: Some of these properties may not be supported in all releases.\n */\nconst DeprecatedViewStylePropTypes = {\n ...DeprecatedLayoutPropTypes,\n ...DeprecatedShadowPropTypesIOS,\n ...DeprecatedTransformPropTypes,\n backfaceVisibility: ReactPropTypes.oneOf(['visible', 'hidden']),\n backgroundColor: DeprecatedColorPropType,\n borderColor: DeprecatedColorPropType,\n borderTopColor: DeprecatedColorPropType,\n borderRightColor: DeprecatedColorPropType,\n borderBottomColor: DeprecatedColorPropType,\n borderLeftColor: DeprecatedColorPropType,\n borderStartColor: DeprecatedColorPropType,\n borderEndColor: DeprecatedColorPropType,\n borderRadius: ReactPropTypes.number,\n borderTopLeftRadius: ReactPropTypes.number,\n borderTopRightRadius: ReactPropTypes.number,\n borderTopStartRadius: ReactPropTypes.number,\n borderTopEndRadius: ReactPropTypes.number,\n borderBottomLeftRadius: ReactPropTypes.number,\n borderBottomRightRadius: ReactPropTypes.number,\n borderBottomStartRadius: ReactPropTypes.number,\n borderBottomEndRadius: ReactPropTypes.number,\n borderStyle: ReactPropTypes.oneOf(['solid', 'dotted', 'dashed']),\n borderWidth: ReactPropTypes.number,\n borderTopWidth: ReactPropTypes.number,\n borderRightWidth: ReactPropTypes.number,\n borderBottomWidth: ReactPropTypes.number,\n borderLeftWidth: ReactPropTypes.number,\n opacity: ReactPropTypes.number,\n /**\n * (Android-only) Sets the elevation of a view, using Android's underlying\n * [elevation API](https://developer.android.com/training/material/shadows-clipping.html#Elevation).\n * This adds a drop shadow to the item and affects z-order for overlapping views.\n * Only supported on Android 5.0+, has no effect on earlier versions.\n * @platform android\n */\n elevation: ReactPropTypes.number,\n};\n\nmodule.exports = DeprecatedViewStylePropTypes;\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 * @format\n */\n\n'use strict';\n\nmodule.exports = {\n // This must be kept in sync with the AccessibilityRolesMask in RCTViewManager.m\n DeprecatedAccessibilityRoles: [\n 'none',\n 'button',\n 'togglebutton',\n 'link',\n 'search',\n 'image',\n 'keyboardkey',\n 'text',\n 'adjustable',\n 'imagebutton',\n 'header',\n 'summary',\n 'alert',\n 'checkbox',\n 'combobox',\n 'menu',\n 'menubar',\n 'menuitem',\n 'progressbar',\n 'radio',\n 'radiogroup',\n 'scrollbar',\n 'spinbutton',\n 'switch',\n 'tab',\n 'tablist',\n 'timer',\n 'toolbar',\n ],\n};\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 * @format\n */\n\n'use strict';\n\nconst DeprecatedColorPropType = require('./DeprecatedColorPropType');\nconst DeprecatedEdgeInsetsPropType = require('./DeprecatedEdgeInsetsPropType');\nconst DeprecatedStyleSheetPropType = require('./DeprecatedStyleSheetPropType');\nconst PropTypes = require('prop-types');\nconst DeprecatedTextStylePropTypes = require('./DeprecatedTextStylePropTypes');\n\nconst stylePropType = DeprecatedStyleSheetPropType(\n DeprecatedTextStylePropTypes,\n);\n\nconst DataDetectorTypes = ['phoneNumber', 'link', 'email', 'none', 'all'];\n\nmodule.exports = {\n /**\n * When `numberOfLines` is set, this prop defines how text will be\n * truncated.\n *\n * See https://reactnative.dev/docs/text.html#ellipsizemode\n */\n ellipsizeMode: PropTypes.oneOf(['head', 'middle', 'tail', 'clip']),\n /**\n * Used to truncate the text with an ellipsis.\n *\n * See https://reactnative.dev/docs/text.html#numberoflines\n */\n numberOfLines: PropTypes.number,\n /**\n * Set text break strategy on Android.\n *\n * See https://reactnative.dev/docs/text.html#textbreakstrategy\n */\n textBreakStrategy: PropTypes.oneOf(['simple', 'highQuality', 'balanced']),\n /**\n * Invoked on mount and layout changes.\n *\n * See https://reactnative.dev/docs/text.html#onlayout\n */\n onLayout: PropTypes.func,\n /**\n * This function is called on press.\n *\n * See https://reactnative.dev/docs/text.html#onpress\n */\n onPress: PropTypes.func,\n /**\n * This function is called on long press.\n *\n * See https://reactnative.dev/docs/text.html#onlongpress\n */\n onLongPress: PropTypes.func,\n /**\n * Defines how far your touch may move off of the button, before\n * deactivating the button.\n *\n * See https://reactnative.dev/docs/text.html#pressretentionoffset\n */\n pressRetentionOffset: DeprecatedEdgeInsetsPropType,\n /**\n * Lets the user select text.\n *\n * See https://reactnative.dev/docs/text.html#selectable\n */\n selectable: PropTypes.bool,\n /**\n * The highlight color of the text.\n *\n * See https://reactnative.dev/docs/text.html#selectioncolor\n */\n selectionColor: DeprecatedColorPropType,\n /**\n * When `true`, no visual change is made when text is pressed down.\n *\n * See https://reactnative.dev/docs/text.html#supperhighlighting\n */\n suppressHighlighting: PropTypes.bool,\n style: stylePropType,\n /**\n * Used to locate this view in end-to-end tests.\n *\n * See https://reactnative.dev/docs/text.html#testid\n */\n testID: PropTypes.string,\n /**\n * Used to locate this view from native code.\n *\n * See https://reactnative.dev/docs/text.html#nativeid\n */\n nativeID: PropTypes.string,\n /**\n * Whether fonts should scale to respect Text Size accessibility settings.\n *\n * See https://reactnative.dev/docs/text.html#allowfontscaling\n */\n allowFontScaling: PropTypes.bool,\n /**\n * Specifies largest possible scale a font can reach when `allowFontScaling` is enabled.\n * Possible values:\n * `null/undefined` (default): inherit from the parent node or the global default (0)\n * `0`: no max, ignore parent/global default\n * `>= 1`: sets the maxFontSizeMultiplier of this node to this value\n */\n maxFontSizeMultiplier: PropTypes.number,\n /**\n * Indicates whether the view is an accessibility element.\n *\n * See https://reactnative.dev/docs/text.html#accessible\n */\n accessible: PropTypes.bool,\n /**\n * Whether font should be scaled down automatically.\n *\n * See https://reactnative.dev/docs/text.html#adjustsfontsizetofit\n */\n adjustsFontSizeToFit: PropTypes.bool,\n /**\n * Smallest possible scale a font can reach.\n *\n * See https://reactnative.dev/docs/text.html#minimumfontscale\n */\n minimumFontScale: PropTypes.number,\n /**\n * Specifies the disabled state of the text view for testing purposes.\n *\n * See https://reactnative.dev/docs/text.html#disabled\n */\n disabled: PropTypes.bool,\n /**\n * Determines the types of data converted to clickable URLs in text.\n *\n * See https://reactnative.dev/docs/text.html#dataDetectorType\n */\n dataDetectorType: PropTypes.oneOf(DataDetectorTypes),\n};\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 * @format\n */\n\n'use strict';\n\nconst DeprecatedColorPropType = require('./DeprecatedColorPropType');\nconst DeprecatedViewStylePropTypes = require('./DeprecatedViewStylePropTypes');\nconst ReactPropTypes = require('prop-types');\n\nconst DeprecatedTextStylePropTypes = {\n ...DeprecatedViewStylePropTypes,\n\n color: DeprecatedColorPropType,\n fontFamily: ReactPropTypes.string,\n fontSize: ReactPropTypes.number,\n fontStyle: ReactPropTypes.oneOf(['normal', 'italic']),\n /**\n * Specifies font weight. The values 'normal' and 'bold' are supported for\n * most fonts. Not all fonts have a variant for each of the numeric values,\n * in that case the closest one is chosen.\n */\n fontWeight: ReactPropTypes.oneOf([\n 'normal' /*default*/,\n 'bold',\n '100',\n '200',\n '300',\n '400',\n '500',\n '600',\n '700',\n '800',\n '900',\n ]),\n fontVariant: ReactPropTypes.arrayOf(\n ReactPropTypes.oneOf([\n 'small-caps',\n 'oldstyle-nums',\n 'lining-nums',\n 'tabular-nums',\n 'proportional-nums',\n ]),\n ),\n textShadowOffset: ReactPropTypes.shape({\n width: ReactPropTypes.number,\n height: ReactPropTypes.number,\n }),\n textShadowRadius: ReactPropTypes.number,\n textShadowColor: DeprecatedColorPropType,\n /**\n * @platform ios\n */\n letterSpacing: ReactPropTypes.number,\n lineHeight: ReactPropTypes.number,\n /**\n * Specifies text alignment. The value 'justify' is only supported on iOS and\n * fallbacks to `left` on Android.\n */\n textAlign: ReactPropTypes.oneOf([\n 'auto' /*default*/,\n 'left',\n 'right',\n 'center',\n 'justify',\n ]),\n /**\n * @platform android\n */\n textAlignVertical: ReactPropTypes.oneOf([\n 'auto' /*default*/,\n 'top',\n 'bottom',\n 'center',\n ]),\n /**\n * Set to `false` to remove extra font padding intended to make space for certain ascenders / descenders.\n * With some fonts, this padding can make text look slightly misaligned when centered vertically.\n * For best results also set `textAlignVertical` to `center`. Default is true.\n * @platform android\n */\n includeFontPadding: ReactPropTypes.bool,\n textDecorationLine: ReactPropTypes.oneOf([\n 'none' /*default*/,\n 'underline',\n 'line-through',\n 'underline line-through',\n ]),\n /**\n * @platform ios\n */\n textDecorationStyle: ReactPropTypes.oneOf([\n 'solid' /*default*/,\n 'double',\n 'dotted',\n 'dashed',\n ]),\n /**\n * @platform ios\n */\n textDecorationColor: DeprecatedColorPropType,\n textTransform: ReactPropTypes.oneOf([\n 'none' /*default*/,\n 'capitalize',\n 'uppercase',\n 'lowercase',\n ]),\n /**\n * @platform ios\n */\n writingDirection: ReactPropTypes.oneOf(['auto' /*default*/, 'ltr', 'rtl']),\n};\n\nmodule.exports = DeprecatedTextStylePropTypes;\n","/**\n * Copyright (c) 2017-present, Wonday (@wonday.org)\n * All rights reserved.\n *\n * This source code is licensed under the MIT-style license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\nimport React, {Component} from 'react';\nimport {\n View,\n PanResponder\n} from 'react-native';\nimport PropTypes from 'prop-types';\nimport {ViewPropTypes} from 'deprecated-react-native-prop-types';\nexport default class DoubleTapView extends Component {\n\n static propTypes = {\n ...ViewPropTypes,\n delay: PropTypes.number,\n radius: PropTypes.number,\n onSingleTap: PropTypes.func,\n onDoubleTap: PropTypes.func,\n };\n\n static defaultProps = {\n delay: 300,\n radius: 50,\n onSingleTap: () => {\n },\n onDoubleTap: () => {\n },\n };\n\n constructor() {\n super();\n\n this.gestureHandlers = PanResponder.create({\n onStartShouldSetPanResponder: (evt, gestureState) => (gestureState.numberActiveTouches === 1),\n onStartShouldSetResponderCapture: (evt, gestureState) => (gestureState.numberActiveTouches === 1),\n onMoveShouldSetPanResponder: (evt, gestureState) => (false),\n onMoveShouldSetResponderCapture: (evt, gestureState) => (false),\n onPanResponderTerminationRequest: (evt, gestureState) => false,\n onPanResponderRelease: this.handlePanResponderRelease,\n\n });\n\n this.prevTouchInfo = {\n prevTouchX: 0,\n prevTouchY: 0,\n prevTouchTimeStamp: 0,\n };\n\n this.timer = null;\n\n }\n\n\n distance = (x0, y0, x1, y1) => {\n return Math.sqrt(Math.pow((x1 - x0), 2) + Math.pow((y1 - y0), 2)).toFixed(1);\n };\n\n isDoubleTap = (currentTouchTimeStamp, {x0, y0}) => {\n const {prevTouchX, prevTouchY, prevTouchTimeStamp} = this.prevTouchInfo;\n const dt = currentTouchTimeStamp - prevTouchTimeStamp;\n const {delay, radius} = this.props;\n\n return (prevTouchTimeStamp > 0 && dt < delay && this.distance(prevTouchX, prevTouchY, x0, y0) < radius);\n };\n\n handlePanResponderRelease = (evt, gestureState) => {\n\n const currentTouchTimeStamp = Date.now();\n const x = evt.nativeEvent.locationX;\n const y = evt.nativeEvent.locationY; \n\n if (this.timer) {\n\n if (this.isDoubleTap(currentTouchTimeStamp, gestureState)) {\n\n clearTimeout(this.timer);\n this.timer = null;\n this.props.onDoubleTap();\n\n } else {\n\n const {prevTouchX, prevTouchY, prevTouchTimeStamp} = this.prevTouchInfo;\n const {radius} = this.props;\n\n // if not in radius, it's a move\n if (this.distance(prevTouchX, prevTouchY, gestureState.x0, gestureState.y0) < radius) {\n this.timer = null;\n this.props.onSingleTap(x, y);\n }\n\n }\n } else {\n // do not count scroll gestures as taps\n if (this.distance(0, gestureState.dx, 0, gestureState.dy) < 10) {\n\n this.timer = setTimeout(() => {\n this.props.onSingleTap(x, y);\n this.timer = null;\n }, this.props.delay);\n }\n }\n\n\n this.prevTouchInfo = {\n prevTouchX: gestureState.x0,\n prevTouchY: gestureState.y0,\n prevTouchTimeStamp: currentTouchTimeStamp,\n };\n\n };\n\n render() {\n return (\n \n {this.props.children}\n \n );\n }\n}","/**\n * Copyright (c) 2017-present, Wonday (@wonday.org)\n * All rights reserved.\n *\n * This source code is licensed under the MIT-style license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\nimport React, {Component} from 'react';\nimport PropTypes from 'prop-types';\nimport {\n View,\n StyleSheet,\n PanResponder\n} from 'react-native';\nimport {ViewPropTypes} from 'deprecated-react-native-prop-types';\nexport default class PinchZoomView extends Component {\n\n static propTypes = {\n ...ViewPropTypes,\n scalable: PropTypes.bool,\n onScaleChanged: PropTypes.func,\n };\n\n static defaultProps = {\n scalable: true,\n onScaleChanged: (scale) => {\n },\n };\n\n constructor(props) {\n\n super(props);\n this.state = {};\n this.distant = 0;\n this.gestureHandlers = PanResponder.create({\n onStartShouldSetPanResponder: this._handleStartShouldSetPanResponder,\n onMoveShouldSetResponderCapture: (evt, gestureState) => (true),\n onMoveShouldSetPanResponder: this._handleMoveShouldSetPanResponder,\n onPanResponderGrant: this._handlePanResponderGrant,\n onPanResponderMove: this._handlePanResponderMove,\n onPanResponderRelease: this._handlePanResponderEnd,\n onPanResponderTerminationRequest: evt => false,\n onPanResponderTerminate: this._handlePanResponderTerminate,\n onShouldBlockNativeResponder: evt => true\n });\n\n }\n\n _handleStartShouldSetPanResponder = (e, gestureState) => {\n\n // don't respond to single touch to avoid shielding click on child components\n return false;\n\n };\n\n _handleMoveShouldSetPanResponder = (e, gestureState) => {\n\n return this.props.scalable && (e.nativeEvent.changedTouches.length >= 2 || gestureState.numberActiveTouches >= 2);\n\n };\n\n _handlePanResponderGrant = (e, gestureState) => {\n\n if (e.nativeEvent.changedTouches.length >= 2 || gestureState.numberActiveTouches >= 2) {\n let dx = Math.abs(e.nativeEvent.touches[0].pageX - e.nativeEvent.touches[1].pageX);\n let dy = Math.abs(e.nativeEvent.touches[0].pageY - e.nativeEvent.touches[1].pageY);\n this.distant = Math.sqrt(dx * dx + dy * dy);\n }\n\n };\n\n _handlePanResponderEnd = (e, gestureState) => {\n\n this.distant = 0;\n\n };\n\n _handlePanResponderTerminate = (e, gestureState) => {\n\n this.distant = 0;\n\n };\n\n _handlePanResponderMove = (e, gestureState) => {\n\n if ((e.nativeEvent.changedTouches.length >= 2 || gestureState.numberActiveTouches >= 2) && this.distant > 100) {\n\n let dx = Math.abs(e.nativeEvent.touches[0].pageX - e.nativeEvent.touches[1].pageX);\n let dy = Math.abs(e.nativeEvent.touches[0].pageY - e.nativeEvent.touches[1].pageY);\n let distant = Math.sqrt(dx * dx + dy * dy);\n let scale = (distant / this.distant);\n let pageX = (e.nativeEvent.touches[0].pageX + e.nativeEvent.touches[1].pageX) / 2;\n let pageY = (e.nativeEvent.touches[0].pageY + e.nativeEvent.touches[1].pageY) / 2;\n let pinchInfo = {scale: scale, pageX: pageX, pageY: pageY};\n\n this.props.onScaleChanged(pinchInfo);\n this.distant = distant;\n\n }\n\n };\n\n render() {\n\n return (\n \n {this.props.children}\n \n );\n\n }\n}\n\nconst styles = StyleSheet.create({\n container: {\n flex: 1,\n justifyContent: 'center',\n alignItems: 'center'\n }\n});\n","/**\n * Copyright (c) 2017-present, Wonday (@wonday.org)\n * All rights reserved.\n *\n * This source code is licensed under the MIT-style license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\nimport React, {Component} from 'react';\nimport {\n FlatList,\n} from 'react-native';\n\nexport default class PdfViewFlatList extends FlatList {\n /**\n * Scrolls to a given x, y offset, either immediately or with a smooth animation.\n *\n * Example:\n *\n * `scrollTo({x: 0, y: 0, animated: true})`\n *\n * Note: The weird function signature is due to the fact that, for historical reasons,\n * the function also accepts separate arguments as an alternative to the options object.\n * This is deprecated due to ambiguity (y before x), and SHOULD NOT BE USED.\n */\n scrollToXY = (x, y) => {\n this._listRef._scrollRef.scrollTo({x: x, y: y, animated: false});\n }\n\n}",";(function (root, factory) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory(require(\"./core\"));\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([\"./core\"], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\tfactory(root.CryptoJS);\n\t}\n}(this, function (CryptoJS) {\n\n\t(function () {\n\t // Shortcuts\n\t var C = CryptoJS;\n\t var C_lib = C.lib;\n\t var WordArray = C_lib.WordArray;\n\t var Hasher = C_lib.Hasher;\n\t var C_algo = C.algo;\n\n\t // Reusable object\n\t var W = [];\n\n\t /**\n\t * SHA-1 hash algorithm.\n\t */\n\t var SHA1 = C_algo.SHA1 = Hasher.extend({\n\t _doReset: function () {\n\t this._hash = new WordArray.init([\n\t 0x67452301, 0xefcdab89,\n\t 0x98badcfe, 0x10325476,\n\t 0xc3d2e1f0\n\t ]);\n\t },\n\n\t _doProcessBlock: function (M, offset) {\n\t // Shortcut\n\t var H = this._hash.words;\n\n\t // Working variables\n\t var a = H[0];\n\t var b = H[1];\n\t var c = H[2];\n\t var d = H[3];\n\t var e = H[4];\n\n\t // Computation\n\t for (var i = 0; i < 80; i++) {\n\t if (i < 16) {\n\t W[i] = M[offset + i] | 0;\n\t } else {\n\t var n = W[i - 3] ^ W[i - 8] ^ W[i - 14] ^ W[i - 16];\n\t W[i] = (n << 1) | (n >>> 31);\n\t }\n\n\t var t = ((a << 5) | (a >>> 27)) + e + W[i];\n\t if (i < 20) {\n\t t += ((b & c) | (~b & d)) + 0x5a827999;\n\t } else if (i < 40) {\n\t t += (b ^ c ^ d) + 0x6ed9eba1;\n\t } else if (i < 60) {\n\t t += ((b & c) | (b & d) | (c & d)) - 0x70e44324;\n\t } else /* if (i < 80) */ {\n\t t += (b ^ c ^ d) - 0x359d3e2a;\n\t }\n\n\t e = d;\n\t d = c;\n\t c = (b << 30) | (b >>> 2);\n\t b = a;\n\t a = t;\n\t }\n\n\t // Intermediate hash value\n\t H[0] = (H[0] + a) | 0;\n\t H[1] = (H[1] + b) | 0;\n\t H[2] = (H[2] + c) | 0;\n\t H[3] = (H[3] + d) | 0;\n\t H[4] = (H[4] + e) | 0;\n\t },\n\n\t _doFinalize: function () {\n\t // Shortcuts\n\t var data = this._data;\n\t var dataWords = data.words;\n\n\t var nBitsTotal = this._nDataBytes * 8;\n\t var nBitsLeft = data.sigBytes * 8;\n\n\t // Add padding\n\t dataWords[nBitsLeft >>> 5] |= 0x80 << (24 - nBitsLeft % 32);\n\t dataWords[(((nBitsLeft + 64) >>> 9) << 4) + 14] = Math.floor(nBitsTotal / 0x100000000);\n\t dataWords[(((nBitsLeft + 64) >>> 9) << 4) + 15] = nBitsTotal;\n\t data.sigBytes = dataWords.length * 4;\n\n\t // Hash final blocks\n\t this._process();\n\n\t // Return final computed hash\n\t return this._hash;\n\t },\n\n\t clone: function () {\n\t var clone = Hasher.clone.call(this);\n\t clone._hash = this._hash.clone();\n\n\t return clone;\n\t }\n\t });\n\n\t /**\n\t * Shortcut function to the hasher's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t *\n\t * @return {WordArray} The hash.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hash = CryptoJS.SHA1('message');\n\t * var hash = CryptoJS.SHA1(wordArray);\n\t */\n\t C.SHA1 = Hasher._createHelper(SHA1);\n\n\t /**\n\t * Shortcut function to the HMAC's object interface.\n\t *\n\t * @param {WordArray|string} message The message to hash.\n\t * @param {WordArray|string} key The secret key.\n\t *\n\t * @return {WordArray} The HMAC.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hmac = CryptoJS.HmacSHA1(message, key);\n\t */\n\t C.HmacSHA1 = Hasher._createHmacHelper(SHA1);\n\t}());\n\n\n\treturn CryptoJS.SHA1;\n\n}));",";(function (root, factory) {\n\tif (typeof exports === \"object\") {\n\t\t// CommonJS\n\t\tmodule.exports = exports = factory();\n\t}\n\telse if (typeof define === \"function\" && define.amd) {\n\t\t// AMD\n\t\tdefine([], factory);\n\t}\n\telse {\n\t\t// Global (browser)\n\t\troot.CryptoJS = factory();\n\t}\n}(this, function () {\n\n\t/**\n\t * CryptoJS core components.\n\t */\n\tvar CryptoJS = CryptoJS || (function (Math, undefined) {\n\t /*\n\t * Local polyfil of Object.create\n\t */\n\t var create = Object.create || (function () {\n\t function F() {};\n\n\t return function (obj) {\n\t var subtype;\n\n\t F.prototype = obj;\n\n\t subtype = new F();\n\n\t F.prototype = null;\n\n\t return subtype;\n\t };\n\t }())\n\n\t /**\n\t * CryptoJS namespace.\n\t */\n\t var C = {};\n\n\t /**\n\t * Library namespace.\n\t */\n\t var C_lib = C.lib = {};\n\n\t /**\n\t * Base object for prototypal inheritance.\n\t */\n\t var Base = C_lib.Base = (function () {\n\n\n\t return {\n\t /**\n\t * Creates a new object that inherits from this object.\n\t *\n\t * @param {Object} overrides Properties to copy into the new object.\n\t *\n\t * @return {Object} The new object.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var MyType = CryptoJS.lib.Base.extend({\n\t * field: 'value',\n\t *\n\t * method: function () {\n\t * }\n\t * });\n\t */\n\t extend: function (overrides) {\n\t // Spawn\n\t var subtype = create(this);\n\n\t // Augment\n\t if (overrides) {\n\t subtype.mixIn(overrides);\n\t }\n\n\t // Create default initializer\n\t if (!subtype.hasOwnProperty('init') || this.init === subtype.init) {\n\t subtype.init = function () {\n\t subtype.$super.init.apply(this, arguments);\n\t };\n\t }\n\n\t // Initializer's prototype is the subtype object\n\t subtype.init.prototype = subtype;\n\n\t // Reference supertype\n\t subtype.$super = this;\n\n\t return subtype;\n\t },\n\n\t /**\n\t * Extends this object and runs the init method.\n\t * Arguments to create() will be passed to init().\n\t *\n\t * @return {Object} The new object.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var instance = MyType.create();\n\t */\n\t create: function () {\n\t var instance = this.extend();\n\t instance.init.apply(instance, arguments);\n\n\t return instance;\n\t },\n\n\t /**\n\t * Initializes a newly created object.\n\t * Override this method to add some logic when your objects are created.\n\t *\n\t * @example\n\t *\n\t * var MyType = CryptoJS.lib.Base.extend({\n\t * init: function () {\n\t * // ...\n\t * }\n\t * });\n\t */\n\t init: function () {\n\t },\n\n\t /**\n\t * Copies properties into this object.\n\t *\n\t * @param {Object} properties The properties to mix in.\n\t *\n\t * @example\n\t *\n\t * MyType.mixIn({\n\t * field: 'value'\n\t * });\n\t */\n\t mixIn: function (properties) {\n\t for (var propertyName in properties) {\n\t if (properties.hasOwnProperty(propertyName)) {\n\t this[propertyName] = properties[propertyName];\n\t }\n\t }\n\n\t // IE won't copy toString using the loop above\n\t if (properties.hasOwnProperty('toString')) {\n\t this.toString = properties.toString;\n\t }\n\t },\n\n\t /**\n\t * Creates a copy of this object.\n\t *\n\t * @return {Object} The clone.\n\t *\n\t * @example\n\t *\n\t * var clone = instance.clone();\n\t */\n\t clone: function () {\n\t return this.init.prototype.extend(this);\n\t }\n\t };\n\t }());\n\n\t /**\n\t * An array of 32-bit words.\n\t *\n\t * @property {Array} words The array of 32-bit words.\n\t * @property {number} sigBytes The number of significant bytes in this word array.\n\t */\n\t var WordArray = C_lib.WordArray = Base.extend({\n\t /**\n\t * Initializes a newly created word array.\n\t *\n\t * @param {Array} words (Optional) An array of 32-bit words.\n\t * @param {number} sigBytes (Optional) The number of significant bytes in the words.\n\t *\n\t * @example\n\t *\n\t * var wordArray = CryptoJS.lib.WordArray.create();\n\t * var wordArray = CryptoJS.lib.WordArray.create([0x00010203, 0x04050607]);\n\t * var wordArray = CryptoJS.lib.WordArray.create([0x00010203, 0x04050607], 6);\n\t */\n\t init: function (words, sigBytes) {\n\t words = this.words = words || [];\n\n\t if (sigBytes != undefined) {\n\t this.sigBytes = sigBytes;\n\t } else {\n\t this.sigBytes = words.length * 4;\n\t }\n\t },\n\n\t /**\n\t * Converts this word array to a string.\n\t *\n\t * @param {Encoder} encoder (Optional) The encoding strategy to use. Default: CryptoJS.enc.Hex\n\t *\n\t * @return {string} The stringified word array.\n\t *\n\t * @example\n\t *\n\t * var string = wordArray + '';\n\t * var string = wordArray.toString();\n\t * var string = wordArray.toString(CryptoJS.enc.Utf8);\n\t */\n\t toString: function (encoder) {\n\t return (encoder || Hex).stringify(this);\n\t },\n\n\t /**\n\t * Concatenates a word array to this word array.\n\t *\n\t * @param {WordArray} wordArray The word array to append.\n\t *\n\t * @return {WordArray} This word array.\n\t *\n\t * @example\n\t *\n\t * wordArray1.concat(wordArray2);\n\t */\n\t concat: function (wordArray) {\n\t // Shortcuts\n\t var thisWords = this.words;\n\t var thatWords = wordArray.words;\n\t var thisSigBytes = this.sigBytes;\n\t var thatSigBytes = wordArray.sigBytes;\n\n\t // Clamp excess bits\n\t this.clamp();\n\n\t // Concat\n\t if (thisSigBytes % 4) {\n\t // Copy one byte at a time\n\t for (var i = 0; i < thatSigBytes; i++) {\n\t var thatByte = (thatWords[i >>> 2] >>> (24 - (i % 4) * 8)) & 0xff;\n\t thisWords[(thisSigBytes + i) >>> 2] |= thatByte << (24 - ((thisSigBytes + i) % 4) * 8);\n\t }\n\t } else {\n\t // Copy one word at a time\n\t for (var i = 0; i < thatSigBytes; i += 4) {\n\t thisWords[(thisSigBytes + i) >>> 2] = thatWords[i >>> 2];\n\t }\n\t }\n\t this.sigBytes += thatSigBytes;\n\n\t // Chainable\n\t return this;\n\t },\n\n\t /**\n\t * Removes insignificant bits.\n\t *\n\t * @example\n\t *\n\t * wordArray.clamp();\n\t */\n\t clamp: function () {\n\t // Shortcuts\n\t var words = this.words;\n\t var sigBytes = this.sigBytes;\n\n\t // Clamp\n\t words[sigBytes >>> 2] &= 0xffffffff << (32 - (sigBytes % 4) * 8);\n\t words.length = Math.ceil(sigBytes / 4);\n\t },\n\n\t /**\n\t * Creates a copy of this word array.\n\t *\n\t * @return {WordArray} The clone.\n\t *\n\t * @example\n\t *\n\t * var clone = wordArray.clone();\n\t */\n\t clone: function () {\n\t var clone = Base.clone.call(this);\n\t clone.words = this.words.slice(0);\n\n\t return clone;\n\t },\n\n\t /**\n\t * Creates a word array filled with random bytes.\n\t *\n\t * @param {number} nBytes The number of random bytes to generate.\n\t *\n\t * @return {WordArray} The random word array.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var wordArray = CryptoJS.lib.WordArray.random(16);\n\t */\n\t random: function (nBytes) {\n\t var words = [];\n\n\t var r = (function (m_w) {\n\t var m_w = m_w;\n\t var m_z = 0x3ade68b1;\n\t var mask = 0xffffffff;\n\n\t return function () {\n\t m_z = (0x9069 * (m_z & 0xFFFF) + (m_z >> 0x10)) & mask;\n\t m_w = (0x4650 * (m_w & 0xFFFF) + (m_w >> 0x10)) & mask;\n\t var result = ((m_z << 0x10) + m_w) & mask;\n\t result /= 0x100000000;\n\t result += 0.5;\n\t return result * (Math.random() > .5 ? 1 : -1);\n\t }\n\t });\n\n\t for (var i = 0, rcache; i < nBytes; i += 4) {\n\t var _r = r((rcache || Math.random()) * 0x100000000);\n\n\t rcache = _r() * 0x3ade67b7;\n\t words.push((_r() * 0x100000000) | 0);\n\t }\n\n\t return new WordArray.init(words, nBytes);\n\t }\n\t });\n\n\t /**\n\t * Encoder namespace.\n\t */\n\t var C_enc = C.enc = {};\n\n\t /**\n\t * Hex encoding strategy.\n\t */\n\t var Hex = C_enc.Hex = {\n\t /**\n\t * Converts a word array to a hex string.\n\t *\n\t * @param {WordArray} wordArray The word array.\n\t *\n\t * @return {string} The hex string.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var hexString = CryptoJS.enc.Hex.stringify(wordArray);\n\t */\n\t stringify: function (wordArray) {\n\t // Shortcuts\n\t var words = wordArray.words;\n\t var sigBytes = wordArray.sigBytes;\n\n\t // Convert\n\t var hexChars = [];\n\t for (var i = 0; i < sigBytes; i++) {\n\t var bite = (words[i >>> 2] >>> (24 - (i % 4) * 8)) & 0xff;\n\t hexChars.push((bite >>> 4).toString(16));\n\t hexChars.push((bite & 0x0f).toString(16));\n\t }\n\n\t return hexChars.join('');\n\t },\n\n\t /**\n\t * Converts a hex string to a word array.\n\t *\n\t * @param {string} hexStr The hex string.\n\t *\n\t * @return {WordArray} The word array.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var wordArray = CryptoJS.enc.Hex.parse(hexString);\n\t */\n\t parse: function (hexStr) {\n\t // Shortcut\n\t var hexStrLength = hexStr.length;\n\n\t // Convert\n\t var words = [];\n\t for (var i = 0; i < hexStrLength; i += 2) {\n\t words[i >>> 3] |= parseInt(hexStr.substr(i, 2), 16) << (24 - (i % 8) * 4);\n\t }\n\n\t return new WordArray.init(words, hexStrLength / 2);\n\t }\n\t };\n\n\t /**\n\t * Latin1 encoding strategy.\n\t */\n\t var Latin1 = C_enc.Latin1 = {\n\t /**\n\t * Converts a word array to a Latin1 string.\n\t *\n\t * @param {WordArray} wordArray The word array.\n\t *\n\t * @return {string} The Latin1 string.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var latin1String = CryptoJS.enc.Latin1.stringify(wordArray);\n\t */\n\t stringify: function (wordArray) {\n\t // Shortcuts\n\t var words = wordArray.words;\n\t var sigBytes = wordArray.sigBytes;\n\n\t // Convert\n\t var latin1Chars = [];\n\t for (var i = 0; i < sigBytes; i++) {\n\t var bite = (words[i >>> 2] >>> (24 - (i % 4) * 8)) & 0xff;\n\t latin1Chars.push(String.fromCharCode(bite));\n\t }\n\n\t return latin1Chars.join('');\n\t },\n\n\t /**\n\t * Converts a Latin1 string to a word array.\n\t *\n\t * @param {string} latin1Str The Latin1 string.\n\t *\n\t * @return {WordArray} The word array.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var wordArray = CryptoJS.enc.Latin1.parse(latin1String);\n\t */\n\t parse: function (latin1Str) {\n\t // Shortcut\n\t var latin1StrLength = latin1Str.length;\n\n\t // Convert\n\t var words = [];\n\t for (var i = 0; i < latin1StrLength; i++) {\n\t words[i >>> 2] |= (latin1Str.charCodeAt(i) & 0xff) << (24 - (i % 4) * 8);\n\t }\n\n\t return new WordArray.init(words, latin1StrLength);\n\t }\n\t };\n\n\t /**\n\t * UTF-8 encoding strategy.\n\t */\n\t var Utf8 = C_enc.Utf8 = {\n\t /**\n\t * Converts a word array to a UTF-8 string.\n\t *\n\t * @param {WordArray} wordArray The word array.\n\t *\n\t * @return {string} The UTF-8 string.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var utf8String = CryptoJS.enc.Utf8.stringify(wordArray);\n\t */\n\t stringify: function (wordArray) {\n\t try {\n\t return decodeURIComponent(escape(Latin1.stringify(wordArray)));\n\t } catch (e) {\n\t throw new Error('Malformed UTF-8 data');\n\t }\n\t },\n\n\t /**\n\t * Converts a UTF-8 string to a word array.\n\t *\n\t * @param {string} utf8Str The UTF-8 string.\n\t *\n\t * @return {WordArray} The word array.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var wordArray = CryptoJS.enc.Utf8.parse(utf8String);\n\t */\n\t parse: function (utf8Str) {\n\t return Latin1.parse(unescape(encodeURIComponent(utf8Str)));\n\t }\n\t };\n\n\t /**\n\t * Abstract buffered block algorithm template.\n\t *\n\t * The property blockSize must be implemented in a concrete subtype.\n\t *\n\t * @property {number} _minBufferSize The number of blocks that should be kept unprocessed in the buffer. Default: 0\n\t */\n\t var BufferedBlockAlgorithm = C_lib.BufferedBlockAlgorithm = Base.extend({\n\t /**\n\t * Resets this block algorithm's data buffer to its initial state.\n\t *\n\t * @example\n\t *\n\t * bufferedBlockAlgorithm.reset();\n\t */\n\t reset: function () {\n\t // Initial values\n\t this._data = new WordArray.init();\n\t this._nDataBytes = 0;\n\t },\n\n\t /**\n\t * Adds new data to this block algorithm's buffer.\n\t *\n\t * @param {WordArray|string} data The data to append. Strings are converted to a WordArray using UTF-8.\n\t *\n\t * @example\n\t *\n\t * bufferedBlockAlgorithm._append('data');\n\t * bufferedBlockAlgorithm._append(wordArray);\n\t */\n\t _append: function (data) {\n\t // Convert string to WordArray, else assume WordArray already\n\t if (typeof data == 'string') {\n\t data = Utf8.parse(data);\n\t }\n\n\t // Append\n\t this._data.concat(data);\n\t this._nDataBytes += data.sigBytes;\n\t },\n\n\t /**\n\t * Processes available data blocks.\n\t *\n\t * This method invokes _doProcessBlock(offset), which must be implemented by a concrete subtype.\n\t *\n\t * @param {boolean} doFlush Whether all blocks and partial blocks should be processed.\n\t *\n\t * @return {WordArray} The processed data.\n\t *\n\t * @example\n\t *\n\t * var processedData = bufferedBlockAlgorithm._process();\n\t * var processedData = bufferedBlockAlgorithm._process(!!'flush');\n\t */\n\t _process: function (doFlush) {\n\t // Shortcuts\n\t var data = this._data;\n\t var dataWords = data.words;\n\t var dataSigBytes = data.sigBytes;\n\t var blockSize = this.blockSize;\n\t var blockSizeBytes = blockSize * 4;\n\n\t // Count blocks ready\n\t var nBlocksReady = dataSigBytes / blockSizeBytes;\n\t if (doFlush) {\n\t // Round up to include partial blocks\n\t nBlocksReady = Math.ceil(nBlocksReady);\n\t } else {\n\t // Round down to include only full blocks,\n\t // less the number of blocks that must remain in the buffer\n\t nBlocksReady = Math.max((nBlocksReady | 0) - this._minBufferSize, 0);\n\t }\n\n\t // Count words ready\n\t var nWordsReady = nBlocksReady * blockSize;\n\n\t // Count bytes ready\n\t var nBytesReady = Math.min(nWordsReady * 4, dataSigBytes);\n\n\t // Process blocks\n\t if (nWordsReady) {\n\t for (var offset = 0; offset < nWordsReady; offset += blockSize) {\n\t // Perform concrete-algorithm logic\n\t this._doProcessBlock(dataWords, offset);\n\t }\n\n\t // Remove processed words\n\t var processedWords = dataWords.splice(0, nWordsReady);\n\t data.sigBytes -= nBytesReady;\n\t }\n\n\t // Return processed words\n\t return new WordArray.init(processedWords, nBytesReady);\n\t },\n\n\t /**\n\t * Creates a copy of this object.\n\t *\n\t * @return {Object} The clone.\n\t *\n\t * @example\n\t *\n\t * var clone = bufferedBlockAlgorithm.clone();\n\t */\n\t clone: function () {\n\t var clone = Base.clone.call(this);\n\t clone._data = this._data.clone();\n\n\t return clone;\n\t },\n\n\t _minBufferSize: 0\n\t });\n\n\t /**\n\t * Abstract hasher template.\n\t *\n\t * @property {number} blockSize The number of 32-bit words this hasher operates on. Default: 16 (512 bits)\n\t */\n\t var Hasher = C_lib.Hasher = BufferedBlockAlgorithm.extend({\n\t /**\n\t * Configuration options.\n\t */\n\t cfg: Base.extend(),\n\n\t /**\n\t * Initializes a newly created hasher.\n\t *\n\t * @param {Object} cfg (Optional) The configuration options to use for this hash computation.\n\t *\n\t * @example\n\t *\n\t * var hasher = CryptoJS.algo.SHA256.create();\n\t */\n\t init: function (cfg) {\n\t // Apply config defaults\n\t this.cfg = this.cfg.extend(cfg);\n\n\t // Set initial values\n\t this.reset();\n\t },\n\n\t /**\n\t * Resets this hasher to its initial state.\n\t *\n\t * @example\n\t *\n\t * hasher.reset();\n\t */\n\t reset: function () {\n\t // Reset data buffer\n\t BufferedBlockAlgorithm.reset.call(this);\n\n\t // Perform concrete-hasher logic\n\t this._doReset();\n\t },\n\n\t /**\n\t * Updates this hasher with a message.\n\t *\n\t * @param {WordArray|string} messageUpdate The message to append.\n\t *\n\t * @return {Hasher} This hasher.\n\t *\n\t * @example\n\t *\n\t * hasher.update('message');\n\t * hasher.update(wordArray);\n\t */\n\t update: function (messageUpdate) {\n\t // Append\n\t this._append(messageUpdate);\n\n\t // Update the hash\n\t this._process();\n\n\t // Chainable\n\t return this;\n\t },\n\n\t /**\n\t * Finalizes the hash computation.\n\t * Note that the finalize operation is effectively a destructive, read-once operation.\n\t *\n\t * @param {WordArray|string} messageUpdate (Optional) A final message update.\n\t *\n\t * @return {WordArray} The hash.\n\t *\n\t * @example\n\t *\n\t * var hash = hasher.finalize();\n\t * var hash = hasher.finalize('message');\n\t * var hash = hasher.finalize(wordArray);\n\t */\n\t finalize: function (messageUpdate) {\n\t // Final message update\n\t if (messageUpdate) {\n\t this._append(messageUpdate);\n\t }\n\n\t // Perform concrete-hasher logic\n\t var hash = this._doFinalize();\n\n\t return hash;\n\t },\n\n\t blockSize: 512/32,\n\n\t /**\n\t * Creates a shortcut function to a hasher's object interface.\n\t *\n\t * @param {Hasher} hasher The hasher to create a helper for.\n\t *\n\t * @return {Function} The shortcut function.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var SHA256 = CryptoJS.lib.Hasher._createHelper(CryptoJS.algo.SHA256);\n\t */\n\t _createHelper: function (hasher) {\n\t return function (message, cfg) {\n\t return new hasher.init(cfg).finalize(message);\n\t };\n\t },\n\n\t /**\n\t * Creates a shortcut function to the HMAC's object interface.\n\t *\n\t * @param {Hasher} hasher The hasher to use in this HMAC helper.\n\t *\n\t * @return {Function} The shortcut function.\n\t *\n\t * @static\n\t *\n\t * @example\n\t *\n\t * var HmacSHA256 = CryptoJS.lib.Hasher._createHmacHelper(CryptoJS.algo.SHA256);\n\t */\n\t _createHmacHelper: function (hasher) {\n\t return function (message, key) {\n\t return new C_algo.HMAC.init(hasher, key).finalize(message);\n\t };\n\t }\n\t });\n\n\t /**\n\t * Algorithm namespace.\n\t */\n\t var C_algo = C.algo = {};\n\n\t return C;\n\t}(Math));\n\n\n\treturn CryptoJS;\n\n}));","import _ from 'underscore';\nimport React, {Component} from 'react';\nimport PropTypes from 'prop-types';\nimport {View, ScrollView} from 'react-native';\nimport Button from '../Button';\nimport Text from '../Text';\nimport TextInput from '../TextInput';\nimport styles from '../../styles/styles';\nimport PDFInfoMessage from './PDFInfoMessage';\nimport compose from '../../libs/compose';\nimport withLocalize, {withLocalizePropTypes} from '../withLocalize';\nimport withWindowDimensions, {windowDimensionsPropTypes} from '../withWindowDimensions';\nimport shouldDelayFocus from '../../libs/shouldDelayFocus';\n\nconst propTypes = {\n /** If the submitted password is invalid (show an error message) */\n isPasswordInvalid: PropTypes.bool,\n\n /** If loading indicator should be shown */\n shouldShowLoadingIndicator: PropTypes.bool,\n\n /** Notify parent that the password form has been submitted */\n onSubmit: PropTypes.func,\n\n /** Notify parent that the password has been updated/edited */\n onPasswordUpdated: PropTypes.func,\n\n /** Notify parent that a text field has been focused or blurred */\n onPasswordFieldFocused: PropTypes.func,\n\n ...withLocalizePropTypes,\n ...windowDimensionsPropTypes,\n};\n\nconst defaultProps = {\n isPasswordInvalid: false,\n shouldShowLoadingIndicator: false,\n onSubmit: () => {},\n onPasswordUpdated: () => {},\n onPasswordFieldFocused: () => {},\n};\n\nclass PDFPasswordForm extends Component {\n constructor(props) {\n super(props);\n this.state = {\n password: '',\n validationErrorText: '',\n shouldShowForm: false,\n };\n this.submitPassword = this.submitPassword.bind(this);\n this.updatePassword = this.updatePassword.bind(this);\n this.showForm = this.showForm.bind(this);\n this.validateAndNotifyPasswordBlur = this.validateAndNotifyPasswordBlur.bind(this);\n }\n\n submitPassword() {\n if (!this.validate()) {\n return;\n }\n this.props.onSubmit(this.state.password);\n }\n\n updatePassword(password) {\n this.props.onPasswordUpdated(password);\n if (!_.isEmpty(password) && this.state.validationErrorText) {\n this.setState({validationErrorText: ''});\n }\n this.setState({password});\n }\n\n validate() {\n if (!_.isEmpty(this.state.password)) {\n return true;\n }\n this.setState({\n validationErrorText: this.props.translate('attachmentView.passwordRequired'),\n });\n return false;\n }\n\n validateAndNotifyPasswordBlur() {\n this.validate();\n this.props.onPasswordFieldFocused(false);\n }\n\n showForm() {\n this.setState({shouldShowForm: true});\n }\n\n render() {\n const containerStyle = this.props.isSmallScreenWidth\n ? [styles.flex1, styles.w100]\n : styles.pdfPasswordForm.wideScreenWidth;\n\n return (\n <>\n {this.state.shouldShowForm ? (\n \n \n \n {this.props.translate('attachmentView.pdfPasswordForm.formLabel')}\n \n \n this.props.onPasswordFieldFocused(true)}\n onBlur={this.validateAndNotifyPasswordBlur}\n autoFocus\n shouldDelayFocus={shouldDelayFocus}\n secureTextEntry\n />\n \n \n ) : (\n \n \n \n )}\n \n );\n }\n}\n\nPDFPasswordForm.propTypes = propTypes;\nPDFPasswordForm.defaultProps = defaultProps;\n\nexport default compose(\n withWindowDimensions,\n withLocalize,\n)(PDFPasswordForm);\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport {View} from 'react-native';\nimport Text from '../Text';\nimport TextLink from '../TextLink';\nimport Icon from '../Icon';\nimport * as Expensicons from '../Icon/Expensicons';\nimport styles from '../../styles/styles';\nimport variables from '../../styles/variables';\nimport withLocalize, {withLocalizePropTypes} from '../withLocalize';\n\nconst propTypes = {\n /** Callback function to indicate that PDF password form should be shown */\n onShowForm: PropTypes.func.isRequired,\n\n ...withLocalizePropTypes,\n};\n\nconst PDFInfoMessage = props => (\n \n \n \n {props.translate('attachmentView.pdfPasswordForm.title')}\n \n {props.translate('attachmentView.pdfPasswordForm.infoText')}\n \n {props.translate('attachmentView.pdfPasswordForm.beforeLinkText')}\n \n {` ${props.translate('attachmentView.pdfPasswordForm.linkText')} `}\n \n {props.translate('attachmentView.pdfPasswordForm.afterLinkText')}\n \n \n);\n\nPDFInfoMessage.propTypes = propTypes;\nPDFInfoMessage.displayName = 'PDFInfoMessage';\n\nexport default withLocalize(PDFInfoMessage);\n","export default false;\n","import PropTypes from 'prop-types';\nimport stylePropTypes from '../../styles/stylePropTypes';\nimport {windowDimensionsPropTypes} from '../withWindowDimensions';\n\nconst propTypes = {\n /** URL to full-sized image */\n sourceURL: PropTypes.string,\n\n /** Additional style props */\n style: stylePropTypes,\n\n /** Notify parent that the keyboard has opened or closed */\n onToggleKeyboard: PropTypes.func,\n\n /** Handles press events like toggling attachment arrows natively */\n onPress: PropTypes.func,\n\n ...windowDimensionsPropTypes,\n};\n\nconst defaultProps = {\n sourceURL: '',\n style: {},\n onPress: () => {},\n onToggleKeyboard: () => {},\n};\n\nexport {propTypes, defaultProps};\n","import React, {PureComponent} from 'react';\nimport PropTypes from 'prop-types';\nimport {\n View, InteractionManager, PanResponder,\n} from 'react-native';\nimport ImageZoom from 'react-native-image-pan-zoom';\nimport _ from 'underscore';\nimport styles from '../../styles/styles';\nimport variables from '../../styles/variables';\nimport withWindowDimensions, {windowDimensionsPropTypes} from '../withWindowDimensions';\nimport FullscreenLoadingIndicator from '../FullscreenLoadingIndicator';\nimport Image from '../Image';\n\n/**\n * On the native layer, we use a image library to handle zoom functionality\n */\nconst propTypes = {\n /** Whether source url requires authentication */\n isAuthTokenRequired: PropTypes.bool,\n\n /** URL to full-sized image */\n url: PropTypes.string.isRequired,\n\n /** Function for handle on press */\n onPress: PropTypes.func,\n\n ...windowDimensionsPropTypes,\n};\n\nconst defaultProps = {\n isAuthTokenRequired: false,\n onPress: () => {},\n};\n\nclass ImageView extends PureComponent {\n constructor(props) {\n super(props);\n\n this.state = {\n isLoading: true,\n imageWidth: 0,\n imageHeight: 0,\n interactionPromise: undefined,\n };\n\n // Use the default double click interval from the ImageZoom library\n // https://github.com/ascoders/react-native-image-zoom/blob/master/src/image-zoom/image-zoom.type.ts#L79\n this.doubleClickInterval = 175;\n this.imageZoomScale = 1;\n this.lastClickTime = 0;\n this.amountOfTouches = 0;\n\n // PanResponder used to capture how many touches are active on the attachment image\n this.panResponder = PanResponder.create({\n onStartShouldSetPanResponder: this.updatePanResponderTouches.bind(this),\n });\n\n this.configureImageZoom = this.configureImageZoom.bind(this);\n this.imageLoadingStart = this.imageLoadingStart.bind(this);\n }\n\n componentDidUpdate(prevProps) {\n if (this.props.url === prevProps.url) {\n return;\n }\n\n this.imageLoadingStart();\n\n if (this.interactionPromise) {\n this.state.interactionPromise.cancel();\n }\n }\n\n componentWillUnmount() {\n if (!this.state.interactionPromise) {\n return;\n }\n this.state.interactionPromise.cancel();\n }\n\n /**\n * Updates the amount of active touches on the PanResponder on our ImageZoom overlay View\n *\n * @param {Event} e\n * @param {GestureState} gestureState\n * @returns {Boolean}\n */\n updatePanResponderTouches(e, gestureState) {\n if (_.isNumber(gestureState.numberActiveTouches)) {\n this.amountOfTouches = gestureState.numberActiveTouches;\n }\n\n // We don't need to set the panResponder since all we care about is checking the gestureState, so return false\n return false;\n }\n\n /**\n * The `ImageZoom` component requires image dimensions which\n * are calculated here from the natural image dimensions produced by\n * the `onLoad` event\n *\n * @param {Object} nativeEvent\n */\n configureImageZoom({nativeEvent}) {\n // Wait till animations are over to prevent stutter in navigation animation\n this.state.interactionPromise = InteractionManager.runAfterInteractions(() => {\n let imageWidth = nativeEvent.width;\n let imageHeight = nativeEvent.height;\n const containerWidth = Math.round(this.props.windowWidth);\n const containerHeight = Math.round(this.state.containerHeight ? this.state.containerHeight : this.props.windowHeight);\n\n const aspectRatio = Math.min(containerHeight / imageHeight, containerWidth / imageWidth);\n\n if (imageHeight > imageWidth) {\n imageHeight *= aspectRatio;\n } else {\n imageWidth *= aspectRatio;\n }\n\n // Resize the image to max dimensions possible on the Native platforms to prevent crashes on Android. To keep the same behavior, apply to IOS as well.\n const maxDimensionsScale = 11;\n imageWidth = Math.min(imageWidth, (containerWidth * maxDimensionsScale));\n imageHeight = Math.min(imageHeight, (containerHeight * maxDimensionsScale));\n this.setState({imageHeight, imageWidth, isLoading: false});\n });\n }\n\n /**\n * When the url changes and the image must load again,\n * this resets the zoom to ensure the next image loads with the correct dimensions.\n */\n resetImageZoom() {\n if (this.imageZoomScale !== 1) {\n this.imageZoomScale = 1;\n }\n\n if (this.zoom) {\n this.zoom.centerOn({\n x: 0,\n y: 0,\n scale: 1,\n duration: 0,\n });\n }\n }\n\n imageLoadingStart() {\n if (this.state.isLoading) {\n return;\n }\n this.resetImageZoom();\n this.setState({imageHeight: 0, imageWidth: 0, isLoading: true});\n }\n\n render() {\n // Default windowHeight accounts for the modal header height\n const windowHeight = this.props.windowHeight - variables.contentHeaderHeight;\n const hasImageDimensions = this.state.imageWidth !== 0 && this.state.imageHeight !== 0;\n const shouldShowLoadingIndicator = this.state.isLoading || !hasImageDimensions;\n\n // Zoom view should be loaded only after measuring actual image dimensions, otherwise it causes blurred images on Android\n return (\n {\n const layout = event.nativeEvent.layout;\n this.setState({\n containerHeight: layout.height,\n });\n }}\n >\n {Boolean(this.state.containerHeight) && (\n this.zoom = el}\n onClick={() => this.props.onPress()}\n cropWidth={this.props.windowWidth}\n cropHeight={windowHeight}\n imageWidth={this.state.imageWidth}\n imageHeight={this.state.imageHeight}\n onStartShouldSetPanResponder={() => {\n const isDoubleClick = new Date().getTime() - this.lastClickTime <= this.doubleClickInterval;\n this.lastClickTime = new Date().getTime();\n\n // Let ImageZoom handle the event if the tap is more than one touchPoint or if we are zoomed in\n if (this.amountOfTouches === 2 || this.imageZoomScale !== 1) {\n return true;\n }\n\n // When we have a double click and the zoom scale is 1 then programmatically zoom the image\n // but let the tap fall through to the parent so we can register a swipe down to dismiss\n if (isDoubleClick) {\n this.zoom.centerOn({\n x: 0,\n y: 0,\n scale: 2,\n duration: 100,\n });\n }\n\n // We must be either swiping down or double tapping since we are at zoom scale 1\n return false;\n }}\n onMove={({scale}) => {\n this.imageZoomScale = scale;\n }}\n >\n \n {/**\n Create an invisible view on top of the image so we can capture and set the amount of touches before\n the ImageZoom's PanResponder does. Children will be triggered first, so this needs to be inside the\n ImageZoom to work\n */}\n \n \n )}\n {shouldShowLoadingIndicator && (\n \n )}\n \n );\n }\n}\n\nImageView.propTypes = propTypes;\nImageView.defaultProps = defaultProps;\n\nexport default withWindowDimensions(ImageView);\n","\"use strict\";\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __exportStar = (this && this.__exportStar) || function(m, exports) {\n for (var p in m) if (p !== \"default\" && !exports.hasOwnProperty(p)) __createBinding(exports, m, p);\n}\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar image_zoom_component_1 = require(\"./image-zoom/image-zoom.component\");\nexports.default = image_zoom_component_1.default;\n__exportStar(require(\"./image-zoom/image-zoom.type\"), exports);\n//# sourceMappingURL=index.js.map","\"use strict\";\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __assign = (this && this.__assign) || function () {\n __assign = Object.assign || function(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar React = require(\"react\");\nvar react_native_1 = require(\"react-native\");\nvar image_zoom_style_1 = require(\"./image-zoom.style\");\nvar image_zoom_type_1 = require(\"./image-zoom.type\");\nvar ImageViewer = /** @class */ (function (_super) {\n __extends(ImageViewer, _super);\n function ImageViewer() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.state = new image_zoom_type_1.ImageZoomState();\n // 上次/当前/动画 x 位移\n _this.lastPositionX = null;\n _this.positionX = 0;\n _this.animatedPositionX = new react_native_1.Animated.Value(0);\n // 上次/当前/动画 y 位移\n _this.lastPositionY = null;\n _this.positionY = 0;\n _this.animatedPositionY = new react_native_1.Animated.Value(0);\n // 缩放大小\n _this.scale = 1;\n _this.animatedScale = new react_native_1.Animated.Value(1);\n _this.zoomLastDistance = null;\n _this.zoomCurrentDistance = 0;\n // 上次手按下去的时间\n _this.lastTouchStartTime = 0;\n // 滑动过程中,整体横向过界偏移量\n _this.horizontalWholeOuterCounter = 0;\n // 滑动过程中,swipeDown 偏移量\n _this.swipeDownOffset = 0;\n // 滑动过程中,x y的总位移\n _this.horizontalWholeCounter = 0;\n _this.verticalWholeCounter = 0;\n // 两手距离中心点位置\n _this.centerDiffX = 0;\n _this.centerDiffY = 0;\n // 上一次点击的时间\n _this.lastClickTime = 0;\n // 双击时的位置\n _this.doubleClickX = 0;\n _this.doubleClickY = 0;\n // 是否双击了\n _this.isDoubleClick = false;\n // 是否是长按\n _this.isLongPress = false;\n // 是否在左右滑\n _this.isHorizontalWrap = false;\n // 图片手势处理\n _this.imagePanResponder = react_native_1.PanResponder.create({\n // 要求成为响应者:\n onStartShouldSetPanResponder: _this.props.onStartShouldSetPanResponder,\n onPanResponderTerminationRequest: _this.props.onPanResponderTerminationRequest,\n onMoveShouldSetPanResponder: _this.props.onMoveShouldSetPanResponder,\n onPanResponderGrant: function (evt) {\n // 开始手势操作\n _this.lastPositionX = null;\n _this.lastPositionY = null;\n _this.zoomLastDistance = null;\n _this.horizontalWholeCounter = 0;\n _this.verticalWholeCounter = 0;\n _this.lastTouchStartTime = new Date().getTime();\n _this.isDoubleClick = false;\n _this.isLongPress = false;\n _this.isHorizontalWrap = false;\n // 任何手势开始,都清空单击计时器\n if (_this.singleClickTimeout) {\n clearTimeout(_this.singleClickTimeout);\n }\n if (evt.nativeEvent.changedTouches.length > 1) {\n var centerX = (evt.nativeEvent.changedTouches[0].pageX + evt.nativeEvent.changedTouches[1].pageX) / 2;\n _this.centerDiffX = centerX - _this.props.cropWidth / 2;\n var centerY = (evt.nativeEvent.changedTouches[0].pageY + evt.nativeEvent.changedTouches[1].pageY) / 2;\n _this.centerDiffY = centerY - _this.props.cropHeight / 2;\n }\n // 计算长按\n if (_this.longPressTimeout) {\n clearTimeout(_this.longPressTimeout);\n }\n var _a = evt.nativeEvent, locationX = _a.locationX, locationY = _a.locationY, pageX = _a.pageX, pageY = _a.pageY;\n _this.longPressTimeout = setTimeout(function () {\n _this.isLongPress = true;\n if (_this.props.onLongPress) {\n _this.props.onLongPress({ locationX: locationX, locationY: locationY, pageX: pageX, pageY: pageY });\n }\n }, _this.props.longPressTime);\n if (evt.nativeEvent.changedTouches.length <= 1) {\n // 一个手指的情况\n if (new Date().getTime() - _this.lastClickTime < (_this.props.doubleClickInterval || 0)) {\n // 认为触发了双击\n _this.lastClickTime = 0;\n // 因为可能触发放大,因此记录双击时的坐标位置\n _this.doubleClickX = evt.nativeEvent.changedTouches[0].pageX;\n _this.doubleClickY = evt.nativeEvent.changedTouches[0].pageY;\n if (_this.props.onDoubleClick) {\n _this.props.onDoubleClick({\n locationX: evt.nativeEvent.changedTouches[0].locationX,\n locationY: evt.nativeEvent.changedTouches[0].locationY,\n pageX: _this.doubleClickX,\n pageY: _this.doubleClickY,\n });\n }\n // 取消长按\n clearTimeout(_this.longPressTimeout);\n // 缩放\n _this.isDoubleClick = true;\n if (_this.props.enableDoubleClickZoom) {\n if (_this.scale > 1 || _this.scale < 1) {\n // 回归原位\n _this.scale = 1;\n _this.positionX = 0;\n _this.positionY = 0;\n }\n else {\n // 开始在位移地点缩放\n // 记录之前缩放比例\n // 此时 this.scale 一定为 1\n var beforeScale = _this.scale;\n // 开始缩放\n _this.scale = 2;\n // 缩放 diff\n var diffScale = _this.scale - beforeScale;\n // 找到两手中心点距离页面中心的位移\n // 移动位置\n _this.positionX = ((_this.props.cropWidth / 2 - _this.doubleClickX) * diffScale) / _this.scale;\n _this.positionY = ((_this.props.cropHeight / 2 - _this.doubleClickY) * diffScale) / _this.scale;\n }\n _this.imageDidMove('centerOn');\n react_native_1.Animated.parallel([\n react_native_1.Animated.timing(_this.animatedScale, {\n toValue: _this.scale,\n duration: 100,\n useNativeDriver: !!_this.props.useNativeDriver,\n }),\n react_native_1.Animated.timing(_this.animatedPositionX, {\n toValue: _this.positionX,\n duration: 100,\n useNativeDriver: !!_this.props.useNativeDriver,\n }),\n react_native_1.Animated.timing(_this.animatedPositionY, {\n toValue: _this.positionY,\n duration: 100,\n useNativeDriver: !!_this.props.useNativeDriver,\n }),\n ]).start();\n }\n }\n else {\n _this.lastClickTime = new Date().getTime();\n }\n }\n },\n onPanResponderMove: function (evt, gestureState) {\n if (_this.isDoubleClick) {\n // 有时双击会被当做位移,这里屏蔽掉\n return;\n }\n if (evt.nativeEvent.changedTouches.length <= 1) {\n // x 位移\n var diffX = gestureState.dx - (_this.lastPositionX || 0);\n if (_this.lastPositionX === null) {\n diffX = 0;\n }\n // y 位移\n var diffY = gestureState.dy - (_this.lastPositionY || 0);\n if (_this.lastPositionY === null) {\n diffY = 0;\n }\n // 保留这一次位移作为下次的上一次位移\n _this.lastPositionX = gestureState.dx;\n _this.lastPositionY = gestureState.dy;\n _this.horizontalWholeCounter += diffX;\n _this.verticalWholeCounter += diffY;\n if (Math.abs(_this.horizontalWholeCounter) > 5 || Math.abs(_this.verticalWholeCounter) > 5) {\n // 如果位移超出手指范围,取消长按监听\n clearTimeout(_this.longPressTimeout);\n }\n if (_this.props.panToMove) {\n // 处理左右滑,如果正在 swipeDown,左右滑失效\n if (_this.swipeDownOffset === 0) {\n if (Math.abs(diffX) > Math.abs(diffY)) {\n _this.isHorizontalWrap = true;\n }\n // diffX > 0 表示手往右滑,图往左移动,反之同理\n // horizontalWholeOuterCounter > 0 表示溢出在左侧,反之在右侧,绝对值越大溢出越多\n if (_this.props.imageWidth * _this.scale > _this.props.cropWidth) {\n // 如果图片宽度大图盒子宽度, 可以横向拖拽\n // 没有溢出偏移量或者这次位移完全收回了偏移量才能拖拽\n if (_this.horizontalWholeOuterCounter > 0) {\n // 溢出在右侧\n if (diffX < 0) {\n // 从右侧收紧\n if (_this.horizontalWholeOuterCounter > Math.abs(diffX)) {\n // 偏移量还没有用完\n _this.horizontalWholeOuterCounter += diffX;\n diffX = 0;\n }\n else {\n // 溢出量置为0,偏移量减去剩余溢出量,并且可以被拖动\n diffX += _this.horizontalWholeOuterCounter;\n _this.horizontalWholeOuterCounter = 0;\n if (_this.props.horizontalOuterRangeOffset) {\n _this.props.horizontalOuterRangeOffset(0);\n }\n }\n }\n else {\n // 向右侧扩增\n _this.horizontalWholeOuterCounter += diffX;\n }\n }\n else if (_this.horizontalWholeOuterCounter < 0) {\n // 溢出在左侧\n if (diffX > 0) {\n // 从左侧收紧\n if (Math.abs(_this.horizontalWholeOuterCounter) > diffX) {\n // 偏移量还没有用完\n _this.horizontalWholeOuterCounter += diffX;\n diffX = 0;\n }\n else {\n // 溢出量置为0,偏移量减去剩余溢出量,并且可以被拖动\n diffX += _this.horizontalWholeOuterCounter;\n _this.horizontalWholeOuterCounter = 0;\n if (_this.props.horizontalOuterRangeOffset) {\n _this.props.horizontalOuterRangeOffset(0);\n }\n }\n }\n else {\n // 向左侧扩增\n _this.horizontalWholeOuterCounter += diffX;\n }\n }\n else {\n // 溢出偏移量为0,正常移动\n }\n // 产生位移\n _this.positionX += diffX / _this.scale;\n // 但是横向不能出现黑边\n // 横向能容忍的绝对值\n var horizontalMax = (_this.props.imageWidth * _this.scale - _this.props.cropWidth) / 2 / _this.scale;\n if (_this.positionX < -horizontalMax) {\n // 超越了左边临界点,还在继续向左移动\n _this.positionX = -horizontalMax;\n // 让其产生细微位移,偏离轨道\n _this.horizontalWholeOuterCounter += -1 / 1e10;\n }\n else if (_this.positionX > horizontalMax) {\n // 超越了右侧临界点,还在继续向右移动\n _this.positionX = horizontalMax;\n // 让其产生细微位移,偏离轨道\n _this.horizontalWholeOuterCounter += 1 / 1e10;\n }\n _this.animatedPositionX.setValue(_this.positionX);\n }\n else {\n // 不能横向拖拽,全部算做溢出偏移量\n _this.horizontalWholeOuterCounter += diffX;\n }\n // 溢出量不会超过设定界限\n if (_this.horizontalWholeOuterCounter > (_this.props.maxOverflow || 0)) {\n _this.horizontalWholeOuterCounter = _this.props.maxOverflow || 0;\n }\n else if (_this.horizontalWholeOuterCounter < -(_this.props.maxOverflow || 0)) {\n _this.horizontalWholeOuterCounter = -(_this.props.maxOverflow || 0);\n }\n if (_this.horizontalWholeOuterCounter !== 0) {\n // 如果溢出偏移量不是0,执行溢出回调\n if (_this.props.horizontalOuterRangeOffset) {\n _this.props.horizontalOuterRangeOffset(_this.horizontalWholeOuterCounter);\n }\n }\n }\n // 如果图片高度大于盒子高度, 可以纵向弹性拖拽\n if (_this.props.imageHeight * _this.scale > _this.props.cropHeight) {\n _this.positionY += diffY / _this.scale;\n _this.animatedPositionY.setValue(_this.positionY);\n // 如果图片上边缘脱离屏幕上边缘,则进入 swipeDown 动作\n // if (\n // (this.props.imageHeight / 2 - this.positionY) * this.scale <\n // this.props.cropHeight / 2\n // ) {\n // if (this.props.enableSwipeDown) {\n // this.swipeDownOffset += diffY\n // // 只要滑动溢出量不小于 0,就可以拖动\n // if (this.swipeDownOffset > 0) {\n // this.positionY += diffY / this.scale\n // this.animatedPositionY.setValue(this.positionY)\n // // 越到下方,缩放越小\n // this.scale = this.scale - diffY / 1000\n // this.animatedScale.setValue(this.scale)\n // }\n // }\n // }\n }\n else {\n // swipeDown 不允许在已经有横向偏移量时触发\n if (_this.props.enableSwipeDown && !_this.isHorizontalWrap) {\n // 图片高度小于盒子高度,只能向下拖拽,而且一定是 swipeDown 动作\n _this.swipeDownOffset += diffY;\n // 只要滑动溢出量不小于 0,就可以拖动\n if (_this.swipeDownOffset > 0) {\n _this.positionY += diffY / _this.scale;\n _this.animatedPositionY.setValue(_this.positionY);\n // 越到下方,缩放越小\n _this.scale = _this.scale - diffY / 1000;\n _this.animatedScale.setValue(_this.scale);\n }\n }\n }\n }\n }\n else {\n // 多个手指的情况\n // 取消长按状态\n if (_this.longPressTimeout) {\n clearTimeout(_this.longPressTimeout);\n }\n if (_this.props.pinchToZoom) {\n // 找最小的 x 和最大的 x\n var minX = void 0;\n var maxX = void 0;\n if (evt.nativeEvent.changedTouches[0].locationX > evt.nativeEvent.changedTouches[1].locationX) {\n minX = evt.nativeEvent.changedTouches[1].pageX;\n maxX = evt.nativeEvent.changedTouches[0].pageX;\n }\n else {\n minX = evt.nativeEvent.changedTouches[0].pageX;\n maxX = evt.nativeEvent.changedTouches[1].pageX;\n }\n var minY = void 0;\n var maxY = void 0;\n if (evt.nativeEvent.changedTouches[0].locationY > evt.nativeEvent.changedTouches[1].locationY) {\n minY = evt.nativeEvent.changedTouches[1].pageY;\n maxY = evt.nativeEvent.changedTouches[0].pageY;\n }\n else {\n minY = evt.nativeEvent.changedTouches[0].pageY;\n maxY = evt.nativeEvent.changedTouches[1].pageY;\n }\n var widthDistance = maxX - minX;\n var heightDistance = maxY - minY;\n var diagonalDistance = Math.sqrt(widthDistance * widthDistance + heightDistance * heightDistance);\n _this.zoomCurrentDistance = Number(diagonalDistance.toFixed(1));\n if (_this.zoomLastDistance !== null) {\n var distanceDiff = (_this.zoomCurrentDistance - _this.zoomLastDistance) / 200;\n var zoom = _this.scale + distanceDiff;\n if (zoom < (_this.props.minScale || 0)) {\n zoom = _this.props.minScale || 0;\n }\n if (zoom > (_this.props.maxScale || 0)) {\n zoom = _this.props.maxScale || 0;\n }\n // 记录之前缩放比例\n var beforeScale = _this.scale;\n // 开始缩放\n _this.scale = zoom;\n _this.animatedScale.setValue(_this.scale);\n // 图片要慢慢往两个手指的中心点移动\n // 缩放 diff\n var diffScale = _this.scale - beforeScale;\n // 找到两手中心点距离页面中心的位移\n // 移动位置\n _this.positionX -= (_this.centerDiffX * diffScale) / _this.scale;\n _this.positionY -= (_this.centerDiffY * diffScale) / _this.scale;\n _this.animatedPositionX.setValue(_this.positionX);\n _this.animatedPositionY.setValue(_this.positionY);\n }\n _this.zoomLastDistance = _this.zoomCurrentDistance;\n }\n }\n _this.imageDidMove('onPanResponderMove');\n },\n onPanResponderRelease: function (evt, gestureState) {\n // 取消长按\n if (_this.longPressTimeout) {\n clearTimeout(_this.longPressTimeout);\n }\n // 双击结束,结束尾判断\n if (_this.isDoubleClick) {\n return;\n }\n // 长按结束,结束尾判断\n if (_this.isLongPress) {\n return;\n }\n // 如果是单个手指、距离上次按住大于预设秒、滑动距离小于预设值, 则可能是单击(如果后续双击间隔内没有开始手势)\n // const stayTime = new Date().getTime() - this.lastTouchStartTime!\n var moveDistance = Math.sqrt(gestureState.dx * gestureState.dx + gestureState.dy * gestureState.dy);\n var _a = evt.nativeEvent, locationX = _a.locationX, locationY = _a.locationY, pageX = _a.pageX, pageY = _a.pageY;\n if (evt.nativeEvent.changedTouches.length === 1 && moveDistance < (_this.props.clickDistance || 0)) {\n _this.singleClickTimeout = setTimeout(function () {\n if (_this.props.onClick) {\n _this.props.onClick({ locationX: locationX, locationY: locationY, pageX: pageX, pageY: pageY });\n }\n }, _this.props.doubleClickInterval);\n }\n else {\n // 多手势结束,或者滑动结束\n if (_this.props.responderRelease) {\n _this.props.responderRelease(gestureState.vx, _this.scale);\n }\n _this.panResponderReleaseResolve();\n }\n },\n onPanResponderTerminate: function () {\n //\n },\n });\n _this.resetScale = function () {\n _this.positionX = 0;\n _this.positionY = 0;\n _this.scale = 1;\n _this.animatedScale.setValue(1);\n };\n _this.panResponderReleaseResolve = function () {\n // 判断是否是 swipeDown\n if (_this.props.enableSwipeDown && _this.props.swipeDownThreshold) {\n if (_this.swipeDownOffset > _this.props.swipeDownThreshold) {\n if (_this.props.onSwipeDown) {\n _this.props.onSwipeDown();\n }\n // Stop reset.\n return;\n }\n }\n if (_this.props.enableCenterFocus && _this.scale < 1) {\n // 如果缩放小于1,强制重置为 1\n _this.scale = 1;\n react_native_1.Animated.timing(_this.animatedScale, {\n toValue: _this.scale,\n duration: 100,\n useNativeDriver: !!_this.props.useNativeDriver,\n }).start();\n }\n if (_this.props.imageWidth * _this.scale <= _this.props.cropWidth) {\n // 如果图片宽度小于盒子宽度,横向位置重置\n _this.positionX = 0;\n react_native_1.Animated.timing(_this.animatedPositionX, {\n toValue: _this.positionX,\n duration: 100,\n useNativeDriver: !!_this.props.useNativeDriver,\n }).start();\n }\n if (_this.props.imageHeight * _this.scale <= _this.props.cropHeight) {\n // 如果图片高度小于盒子高度,纵向位置重置\n _this.positionY = 0;\n react_native_1.Animated.timing(_this.animatedPositionY, {\n toValue: _this.positionY,\n duration: 100,\n useNativeDriver: !!_this.props.useNativeDriver,\n }).start();\n }\n // 横向肯定不会超出范围,由拖拽时控制\n // 如果图片高度大于盒子高度,纵向不能出现黑边\n if (_this.props.imageHeight * _this.scale > _this.props.cropHeight) {\n // 纵向能容忍的绝对值\n var verticalMax = (_this.props.imageHeight * _this.scale - _this.props.cropHeight) / 2 / _this.scale;\n if (_this.positionY < -verticalMax) {\n _this.positionY = -verticalMax;\n }\n else if (_this.positionY > verticalMax) {\n _this.positionY = verticalMax;\n }\n react_native_1.Animated.timing(_this.animatedPositionY, {\n toValue: _this.positionY,\n duration: 100,\n useNativeDriver: !!_this.props.useNativeDriver,\n }).start();\n }\n if (_this.props.imageWidth * _this.scale > _this.props.cropWidth) {\n // 纵向能容忍的绝对值\n var horizontalMax = (_this.props.imageWidth * _this.scale - _this.props.cropWidth) / 2 / _this.scale;\n if (_this.positionX < -horizontalMax) {\n _this.positionX = -horizontalMax;\n }\n else if (_this.positionX > horizontalMax) {\n _this.positionX = horizontalMax;\n }\n react_native_1.Animated.timing(_this.animatedPositionX, {\n toValue: _this.positionX,\n duration: 100,\n useNativeDriver: !!_this.props.useNativeDriver,\n }).start();\n }\n // 拖拽正常结束后,如果没有缩放,直接回到0,0点\n if (_this.props.enableCenterFocus && _this.scale === 1) {\n _this.positionX = 0;\n _this.positionY = 0;\n react_native_1.Animated.timing(_this.animatedPositionX, {\n toValue: _this.positionX,\n duration: 100,\n useNativeDriver: !!_this.props.useNativeDriver,\n }).start();\n react_native_1.Animated.timing(_this.animatedPositionY, {\n toValue: _this.positionY,\n duration: 100,\n useNativeDriver: !!_this.props.useNativeDriver,\n }).start();\n }\n // 水平溢出量置空\n _this.horizontalWholeOuterCounter = 0;\n // swipeDown 溢出量置空\n _this.swipeDownOffset = 0;\n _this.imageDidMove('onPanResponderRelease');\n };\n return _this;\n }\n ImageViewer.prototype.componentDidMount = function () {\n if (this.props.centerOn) {\n this.centerOn(this.props.centerOn);\n }\n };\n ImageViewer.prototype.componentDidUpdate = function (prevProps) {\n // Either centerOn has never been called, or it is a repeat and we should ignore it\n if ((this.props.centerOn && !prevProps.centerOn) ||\n (this.props.centerOn && prevProps.centerOn && this.didCenterOnChange(prevProps.centerOn, this.props.centerOn))) {\n this.centerOn(this.props.centerOn);\n }\n };\n ImageViewer.prototype.imageDidMove = function (type) {\n if (this.props.onMove) {\n this.props.onMove({\n type: type,\n positionX: this.positionX,\n positionY: this.positionY,\n scale: this.scale,\n zoomCurrentDistance: this.zoomCurrentDistance,\n });\n }\n };\n ImageViewer.prototype.didCenterOnChange = function (params, paramsNext) {\n return params.x !== paramsNext.x || params.y !== paramsNext.y || params.scale !== paramsNext.scale;\n };\n ImageViewer.prototype.centerOn = function (params) {\n var _this = this;\n this.positionX = params.x;\n this.positionY = params.y;\n this.scale = params.scale;\n var duration = params.duration || 300;\n react_native_1.Animated.parallel([\n react_native_1.Animated.timing(this.animatedScale, {\n toValue: this.scale,\n duration: duration,\n useNativeDriver: !!this.props.useNativeDriver,\n }),\n react_native_1.Animated.timing(this.animatedPositionX, {\n toValue: this.positionX,\n duration: duration,\n useNativeDriver: !!this.props.useNativeDriver,\n }),\n react_native_1.Animated.timing(this.animatedPositionY, {\n toValue: this.positionY,\n duration: duration,\n useNativeDriver: !!this.props.useNativeDriver,\n }),\n ]).start(function () {\n _this.imageDidMove('centerOn');\n });\n };\n /**\n * 图片区域视图渲染完毕\n */\n ImageViewer.prototype.handleLayout = function (event) {\n if (this.props.layoutChange) {\n this.props.layoutChange(event);\n }\n };\n /**\n * 重置大小和位置\n */\n ImageViewer.prototype.reset = function () {\n this.scale = 1;\n this.animatedScale.setValue(this.scale);\n this.positionX = 0;\n this.animatedPositionX.setValue(this.positionX);\n this.positionY = 0;\n this.animatedPositionY.setValue(this.positionY);\n };\n ImageViewer.prototype.render = function () {\n var animateConf = {\n transform: [\n {\n scale: this.animatedScale,\n },\n {\n translateX: this.animatedPositionX,\n },\n {\n translateY: this.animatedPositionY,\n },\n ],\n };\n var parentStyles = react_native_1.StyleSheet.flatten(this.props.style);\n return (\n \n \n {this.props.children}\n \n \n );\n };\n ImageViewer.defaultProps = new image_zoom_type_1.ImageZoomProps();\n return ImageViewer;\n}(React.Component));\nexports.default = ImageViewer;\n//# sourceMappingURL=image-zoom.component.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.ImageZoomState = exports.ImageZoomProps = void 0;\nvar ImageZoomProps = /** @class */ (function () {\n function ImageZoomProps() {\n /**\n * 操作区域宽度\n */\n this.cropWidth = 100;\n /**\n * 操作区域高度\n */\n this.cropHeight = 100;\n /**\n * 图片宽度\n */\n this.imageWidth = 100;\n /**\n * 图片高度\n */\n this.imageHeight = 100;\n /**\n * 单手是否能移动图片\n */\n this.panToMove = true;\n /**\n * 多手指是否能缩放\n */\n this.pinchToZoom = true;\n /**\n * 双击能否放大\n */\n this.enableDoubleClickZoom = true;\n /**\n * 单击最大位移\n */\n this.clickDistance = 10;\n /**\n * 最大滑动阈值\n */\n this.maxOverflow = 100;\n /**\n * 长按的阈值(毫秒)\n */\n this.longPressTime = 800;\n /**\n * 双击计时器最大间隔\n */\n this.doubleClickInterval = 175;\n this.style = {};\n /**\n * threshold for firing swipe down function\n */\n this.swipeDownThreshold = 230;\n /**\n * for enabling vertical movement if user doesn't want it\n */\n this.enableSwipeDown = false;\n /**\n * for disabling focus on image center if user doesn't want it\n */\n this.enableCenterFocus = true;\n /**\n * for disabling rendering to hardware texture on Android\n */\n this.useHardwareTextureAndroid = true;\n /**\n * minimum zoom scale\n */\n this.minScale = 0.6;\n /**\n * maximum zoom scale\n */\n this.maxScale = 10;\n /**\n * 是否启用原生动画驱动\n * Whether to use native code to perform animations.\n */\n this.useNativeDriver = false;\n /**\n * 单击的回调\n */\n this.onClick = function () {\n //\n };\n /**\n * 双击的回调\n */\n this.onDoubleClick = function () {\n //\n };\n /**\n * 长按的回调\n */\n this.onLongPress = function () {\n //\n };\n /**\n * 横向超出的距离,父级做图片切换时,可以监听这个函数\n * 当此函数触发时,可以做切换操作\n */\n this.horizontalOuterRangeOffset = function () {\n //\n };\n /**\n * 触发想切换到左边的图,向左滑动速度超出阈值时触发\n */\n this.onDragLeft = function () {\n //\n };\n /**\n * 松手但是没有取消看图的回调\n */\n this.responderRelease = function () {\n //\n };\n /**\n * If provided, this will be called everytime the map is moved\n */\n this.onMove = function () {\n //\n };\n /**\n * If provided, this method will be called when the onLayout event fires\n */\n this.layoutChange = function () {\n //\n };\n /**\n * function that fires when user swipes down\n */\n this.onSwipeDown = function () {\n //\n };\n /**\n * Allows overriding the default onStartShouldSetPanResponder behavior.\n * By default, always becomes the responder\n */\n this.onStartShouldSetPanResponder = function () { return true; };\n /**\n * Allows overriding the default onPanResponderTerminationRequest behavior.\n * By default, doesn't terminate until the press ends\n */\n this.onPanResponderTerminationRequest = function () { return false; };\n }\n return ImageZoomProps;\n}());\nexports.ImageZoomProps = ImageZoomProps;\nvar ImageZoomState = /** @class */ (function () {\n function ImageZoomState() {\n /**\n * 中心 x 坐标\n */\n this.centerX = 0.5;\n /**\n * 中心 y 坐标\n */\n this.centerY = 0.5;\n }\n return ImageZoomState;\n}());\nexports.ImageZoomState = ImageZoomState;\n//# sourceMappingURL=image-zoom.type.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar container = {\n justifyContent: 'center',\n alignItems: 'center',\n overflow: 'hidden',\n backgroundColor: 'transparent',\n};\nexports.default = {\n container: container,\n};\n//# sourceMappingURL=image-zoom.style.js.map","import React from 'react';\nimport {View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport {withOnyx} from 'react-native-onyx';\nimport _ from 'underscore';\nimport * as Expensicons from '../Icon/Expensicons';\nimport styles from '../../styles/styles';\nimport themeColors from '../../styles/themes/default';\nimport CarouselActions from './CarouselActions';\nimport Button from '../Button';\nimport * as ReportActionsUtils from '../../libs/ReportActionsUtils';\nimport AttachmentView from '../AttachmentView';\nimport addEncryptedAuthTokenToURL from '../../libs/addEncryptedAuthTokenToURL';\nimport * as DeviceCapabilities from '../../libs/DeviceCapabilities';\nimport CONST from '../../CONST';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport reportActionPropTypes from '../../pages/home/report/reportActionPropTypes';\nimport tryResolveUrlFromApiRoot from '../../libs/tryResolveUrlFromApiRoot';\nimport Tooltip from '../Tooltip';\nimport withLocalize, {withLocalizePropTypes} from '../withLocalize';\nimport compose from '../../libs/compose';\n\nconst propTypes = {\n /** source is used to determine the starting index in the array of attachments */\n source: PropTypes.string,\n\n /** Callback to update the parent modal's state with a source and name from the attachments array */\n onNavigate: PropTypes.func,\n\n /** Object of report actions for this report */\n reportActions: PropTypes.objectOf(PropTypes.shape(reportActionPropTypes)),\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n source: '',\n reportActions: {},\n onNavigate: () => {},\n};\n\nclass AttachmentCarousel extends React.Component {\n constructor(props) {\n super(props);\n\n this.canUseTouchScreen = DeviceCapabilities.canUseTouchScreen();\n this.cycleThroughAttachments = this.cycleThroughAttachments.bind(this);\n\n this.state = {\n source: this.props.source,\n shouldShowArrow: this.canUseTouchScreen,\n isForwardDisabled: true,\n isBackDisabled: true,\n };\n }\n\n componentDidMount() {\n this.makeStateWithReports();\n }\n\n componentDidUpdate(prevProps) {\n const previousReportActionsCount = _.size(prevProps.reportActions);\n const currentReportActionsCount = _.size(this.props.reportActions);\n if (previousReportActionsCount === currentReportActionsCount) {\n return;\n }\n this.makeStateWithReports();\n }\n\n /**\n * Helps to navigate between next/previous attachments\n * @param {Object} attachmentItem\n * @returns {Object}\n */\n getAttachment(attachmentItem) {\n const source = _.get(attachmentItem, 'source', '');\n const file = _.get(attachmentItem, 'file', {name: ''});\n this.props.onNavigate({source: addEncryptedAuthTokenToURL(source), file});\n\n return {\n source,\n file,\n };\n }\n\n /**\n * Toggles the visibility of the arrows\n * @param {Boolean} shouldShowArrow\n */\n toggleArrowsVisibility(shouldShowArrow) {\n this.setState({shouldShowArrow});\n }\n\n /**\n * This is called when there are new reports to set the state\n */\n makeStateWithReports() {\n let page;\n const actions = ReportActionsUtils.getSortedReportActions(_.values(this.props.reportActions), true);\n\n /**\n * Looping to filter out attachments and retrieve the src URL and name of attachments.\n */\n const attachments = [];\n _.forEach(actions, ({originalMessage, message}) => {\n // Check for attachment which hasn't been deleted\n if (!originalMessage || !originalMessage.html || _.some(message, m => m.isEdited)) {\n return;\n }\n const matches = [...originalMessage.html.matchAll(CONST.REGEX.ATTACHMENT_DATA)];\n\n // matchAll captured both source url and name of the attachment\n if (matches.length === 2) {\n const [originalSource, name] = _.map(matches, m => m[2]);\n\n // Update the image URL so the images can be accessed depending on the config environment.\n // Eg: while using Ngrok the image path is from an Ngrok URL and not an Expensify URL.\n const source = tryResolveUrlFromApiRoot(originalSource);\n if (source === this.state.source) {\n page = attachments.length;\n }\n\n attachments.push({source, file: {name}});\n }\n });\n\n const {file} = this.getAttachment(attachments[page]);\n this.setState({\n page,\n attachments,\n file,\n isForwardDisabled: page === 0,\n isBackDisabled: page === attachments.length - 1,\n });\n }\n\n /**\n * Increments or decrements the index to get another selected item\n * @param {Number} deltaSlide\n */\n cycleThroughAttachments(deltaSlide) {\n if ((deltaSlide > 0 && this.state.isForwardDisabled) || (deltaSlide < 0 && this.state.isBackDisabled)) {\n return;\n }\n\n this.setState(({attachments, page}) => {\n const nextIndex = page - deltaSlide;\n const {source, file} = this.getAttachment(attachments[nextIndex]);\n return {\n page: nextIndex,\n source,\n file,\n isBackDisabled: nextIndex === attachments.length - 1,\n isForwardDisabled: nextIndex === 0,\n };\n });\n }\n\n render() {\n const isPageSet = Number.isInteger(this.state.page);\n const authSource = addEncryptedAuthTokenToURL(this.state.source);\n return (\n this.toggleArrowsVisibility(true)}\n onMouseLeave={() => this.toggleArrowsVisibility(false)}\n >\n {(isPageSet && this.state.shouldShowArrow) && (\n <>\n {!this.state.isBackDisabled && (\n \n \n this.cycleThroughAttachments(-1)}\n />\n \n \n )}\n {!this.state.isForwardDisabled && (\n \n \n this.cycleThroughAttachments(1)}\n />\n \n \n )}\n \n )}\n this.canUseTouchScreen && this.toggleArrowsVisibility(!this.state.shouldShowArrow)}\n onCycleThroughAttachments={this.cycleThroughAttachments}\n >\n this.toggleArrowsVisibility(!this.state.shouldShowArrow)}\n source={authSource}\n key={authSource}\n file={this.state.file}\n />\n \n \n );\n }\n}\n\nAttachmentCarousel.propTypes = propTypes;\nAttachmentCarousel.defaultProps = defaultProps;\n\nexport default compose(\n withOnyx({\n reportActions: {\n key: ({reportID}) => `${ONYXKEYS.COLLECTION.REPORT_ACTIONS}${reportID}`,\n canEvict: false,\n },\n }),\n withLocalize,\n)(AttachmentCarousel);\n","import React, {Component} from 'react';\nimport {PanResponder, Dimensions, Animated} from 'react-native';\nimport PropTypes from 'prop-types';\nimport styles from '../../../styles/styles';\n\nconst propTypes = {\n /** Attachment that's rendered */\n children: PropTypes.element.isRequired,\n\n /** Callback to fire when swiping left or right */\n onCycleThroughAttachments: PropTypes.func.isRequired,\n\n /** Callback to handle a press event */\n onPress: PropTypes.func.isRequired,\n\n /** Boolean to prevent a left swipe action */\n canSwipeLeft: PropTypes.bool.isRequired,\n\n /** Boolean to prevent a right swipe action */\n canSwipeRight: PropTypes.bool.isRequired,\n};\n\nclass Carousel extends Component {\n constructor(props) {\n super(props);\n this.pan = new Animated.Value(0);\n\n this.panResponder = PanResponder.create({\n onStartShouldSetPanResponder: () => true,\n\n onPanResponderMove: (event, gestureState) => Animated.event([null, {\n dx: this.pan,\n }], {useNativeDriver: false})(event, gestureState),\n\n onPanResponderRelease: (event, gestureState) => {\n if (gestureState.dx === 0 && gestureState.dy === 0) {\n return this.props.onPress();\n }\n\n const deltaSlide = gestureState.dx > 0 ? 1 : -1;\n if (Math.abs(gestureState.vx) < 1 || (deltaSlide === 1 && !this.props.canSwipeLeft) || (deltaSlide === -1 && !this.props.canSwipeRight)) {\n return Animated.spring(this.pan, {useNativeDriver: false, toValue: 0}).start();\n }\n\n const width = Dimensions.get('window').width;\n const slideLength = deltaSlide * (width * 1.1);\n Animated.timing(this.pan, {useNativeDriver: false, duration: 100, toValue: slideLength}).start(({finished}) => {\n if (!finished) {\n return;\n }\n\n this.props.onCycleThroughAttachments(-deltaSlide);\n this.pan.setValue(-slideLength);\n Animated.timing(this.pan, {useNativeDriver: false, duration: 100, toValue: 0}).start();\n });\n },\n });\n }\n\n render() {\n return (\n \n {this.props.children}\n \n );\n }\n}\n\nCarousel.propTypes = propTypes;\n\nexport default Carousel;\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport Modal from './Modal';\nimport CONST from '../CONST';\nimport withWindowDimensions, {windowDimensionsPropTypes} from './withWindowDimensions';\nimport ConfirmContent from './ConfirmContent';\n\nconst propTypes = {\n /** Title of the modal */\n title: PropTypes.string,\n\n /** A callback to call when the form has been submitted */\n onConfirm: PropTypes.func.isRequired,\n\n /** A callback to call when the form has been closed */\n onCancel: PropTypes.func,\n\n /** Modal visibility */\n isVisible: PropTypes.bool.isRequired,\n\n /** Confirm button text */\n confirmText: PropTypes.string,\n\n /** Cancel button text */\n cancelText: PropTypes.string,\n\n /** Modal content text/element */\n prompt: PropTypes.oneOfType([PropTypes.string, PropTypes.element]),\n\n /** Whether we should use the success button color */\n success: PropTypes.bool,\n\n /** Is the action destructive */\n danger: PropTypes.bool,\n\n /** Whether we should show the cancel button */\n shouldShowCancelButton: PropTypes.bool,\n\n /** Callback method fired when the modal is hidden */\n onModalHide: PropTypes.func,\n\n /** Should we announce the Modal visibility changes? */\n shouldSetModalVisibility: PropTypes.bool,\n\n ...windowDimensionsPropTypes,\n};\n\nconst defaultProps = {\n confirmText: '',\n cancelText: '',\n prompt: '',\n success: true,\n danger: false,\n onCancel: () => {},\n shouldShowCancelButton: true,\n shouldSetModalVisibility: true,\n title: '',\n onModalHide: () => {},\n};\n\nconst ConfirmModal = props => (\n \n (props.isVisible ? props.onConfirm() : null)}\n onCancel={props.onCancel}\n confirmText={props.confirmText}\n cancelText={props.cancelText}\n prompt={props.prompt}\n success={props.success}\n danger={props.danger}\n shouldShowCancelButton={props.shouldShowCancelButton}\n />\n \n);\n\nConfirmModal.propTypes = propTypes;\nConfirmModal.defaultProps = defaultProps;\nConfirmModal.displayName = 'ConfirmModal';\nexport default withWindowDimensions(ConfirmModal);\n","import React from 'react';\nimport {View} from 'react-native';\nimport _ from 'underscore';\nimport PropTypes from 'prop-types';\nimport Header from './Header';\nimport styles from '../styles/styles';\nimport Button from './Button';\nimport withLocalize, {withLocalizePropTypes} from './withLocalize';\nimport Text from './Text';\n\nconst propTypes = {\n /** Title of the modal */\n title: PropTypes.string.isRequired,\n\n /** A callback to call when the form has been submitted */\n onConfirm: PropTypes.func.isRequired,\n\n /** A callback to call when the form has been closed */\n onCancel: PropTypes.func,\n\n /** Confirm button text */\n confirmText: PropTypes.string,\n\n /** Cancel button text */\n cancelText: PropTypes.string,\n\n /** Modal content text/element */\n prompt: PropTypes.oneOfType([PropTypes.string, PropTypes.element]),\n\n /** Whether we should use the success button color */\n success: PropTypes.bool,\n\n /** Whether we should use the danger button color. Use if the action is destructive */\n danger: PropTypes.bool,\n\n /** Whether we should show the cancel button */\n shouldShowCancelButton: PropTypes.bool,\n\n /** Styles for view */\n // eslint-disable-next-line react/forbid-prop-types\n contentStyles: PropTypes.arrayOf(PropTypes.object),\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n confirmText: '',\n cancelText: '',\n prompt: '',\n success: true,\n danger: false,\n onCancel: () => {},\n shouldShowCancelButton: true,\n contentStyles: [],\n};\n\nconst ConfirmContent = props => (\n \n \n
          \n \n\n {_.isString(props.prompt)\n ? (\n \n {props.prompt}\n \n ) : props.prompt}\n\n \n {props.shouldShowCancelButton && (\n \n )}\n \n);\n\nConfirmContent.propTypes = propTypes;\nConfirmContent.defaultProps = defaultProps;\nConfirmContent.displayName = 'ConfirmContent';\nexport default withLocalize(ConfirmContent);\n","import React from 'react';\nimport {Pressable} from 'react-native';\nimport PropTypes from 'prop-types';\n\nconst propTypes = {\n /** Element that should be clickable */\n children: PropTypes.oneOfType([\n PropTypes.node,\n PropTypes.func,\n ]).isRequired,\n\n /** Callback for onPress event */\n onPress: PropTypes.func.isRequired,\n\n /** Callback for onLongPress event */\n onLongPress: PropTypes.func,\n\n /** Styles that should be passed to touchable container */\n // eslint-disable-next-line react/forbid-prop-types\n styles: PropTypes.arrayOf(PropTypes.object),\n};\n\nconst defaultProps = {\n styles: [],\n onLongPress: undefined,\n};\n\n/**\n * This component prevents the tapped element from capturing focus.\n * We need to blur this element when clicked as it opens modal that implements focus-trapping.\n * When the modal is closed it focuses back to the last active element.\n * Therefore it shifts the element to bring it back to focus.\n * https://github.com/Expensify/App/issues/6806\n */\nclass PressableWithoutFocus extends React.Component {\n constructor(props) {\n super(props);\n this.pressAndBlur = this.pressAndBlur.bind(this);\n }\n\n pressAndBlur() {\n this.pressableRef.blur();\n this.props.onPress();\n }\n\n render() {\n return (\n this.pressableRef = el}\n style={this.props.styles}\n >\n {this.props.children}\n \n );\n }\n}\n\nPressableWithoutFocus.propTypes = propTypes;\nPressableWithoutFocus.defaultProps = defaultProps;\n\nexport default PressableWithoutFocus;\n","/**\n * Displays the user's local time and updates it every minute.\n * The time auto-update logic is extracted to this component to avoid re-rendering a more complex component, e.g. DetailsPage.\n */\nimport {View} from 'react-native';\nimport React, {\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from 'react';\nimport PropTypes from 'prop-types';\nimport styles from '../styles/styles';\nimport DateUtils from '../libs/DateUtils';\nimport withLocalize, {withLocalizePropTypes} from './withLocalize';\nimport Text from './Text';\n\nconst propTypes = {\n /** Timezone of the user from their personal details */\n timezone: PropTypes.shape({\n /** Value of selected timezone */\n selected: PropTypes.string,\n\n /** Whether timezone is automatically set */\n automatic: PropTypes.bool,\n }).isRequired,\n ...withLocalizePropTypes,\n};\n\nfunction AutoUpdateTime(props) {\n /**\n * @returns {moment} Returns the locale moment object\n */\n const getCurrentUserLocalTime = useCallback(() => (\n DateUtils.getLocalMomentFromDatetime(\n props.preferredLocale,\n null,\n props.timezone.selected,\n )\n ), [props.preferredLocale, props.timezone.selected]);\n\n const [currentUserLocalTime, setCurrentUserLocalTime] = useState(getCurrentUserLocalTime);\n const minuteRef = useRef(new Date().getMinutes());\n const timezoneName = useMemo(() => {\n // With non-GMT timezone, moment.zoneAbbr() will return the name of that timezone, so we can use it directly.\n if (Number.isNaN(Number(currentUserLocalTime.zoneAbbr()))) {\n return currentUserLocalTime.zoneAbbr();\n }\n\n // With GMT timezone, moment.zoneAbbr() will return a number, so we need to display it as GMT {abbreviations} format, e.g.: GMT +07\n return `GMT ${currentUserLocalTime.zoneAbbr()}`;\n }, [currentUserLocalTime]);\n\n useEffect(() => {\n // If the any of the props that getCurrentUserLocalTime depends on change, we want to update the displayed time immediately\n setCurrentUserLocalTime(getCurrentUserLocalTime());\n\n // Also, if the user leaves this page open, we want to make sure the displayed time is updated every minute when the clock changes\n // To do this we create an interval to check if the minute has changed every second and update the displayed time if it has\n const interval = setInterval(() => {\n const currentMinute = new Date().getMinutes();\n if (currentMinute !== minuteRef.current) {\n setCurrentUserLocalTime(getCurrentUserLocalTime());\n minuteRef.current = currentMinute;\n }\n }, 1000);\n return () => clearInterval(interval);\n }, [getCurrentUserLocalTime]);\n\n return (\n \n \n {props.translate('detailsPage.localTime')}\n \n \n {currentUserLocalTime.format('LT')}\n {' '}\n {timezoneName}\n \n \n );\n}\n\nAutoUpdateTime.propTypes = propTypes;\nAutoUpdateTime.displayName = 'AutoUpdateTime';\nexport default withLocalize(AutoUpdateTime);\n","import React, {Component} from 'react';\nimport PropTypes from 'prop-types';\nimport {withOnyx} from 'react-native-onyx';\nimport _ from 'underscore';\nimport {View, ScrollView} from 'react-native';\nimport lodashGet from 'lodash/get';\nimport RoomHeaderAvatars from '../components/RoomHeaderAvatars';\nimport compose from '../libs/compose';\nimport withLocalize, {withLocalizePropTypes} from '../components/withLocalize';\nimport ONYXKEYS from '../ONYXKEYS';\nimport ScreenWrapper from '../components/ScreenWrapper';\nimport Navigation from '../libs/Navigation/Navigation';\nimport HeaderWithCloseButton from '../components/HeaderWithCloseButton';\nimport styles from '../styles/styles';\nimport DisplayNames from '../components/DisplayNames';\nimport * as OptionsListUtils from '../libs/OptionsListUtils';\nimport * as ReportUtils from '../libs/ReportUtils';\nimport * as Policy from '../libs/actions/Policy';\nimport participantPropTypes from '../components/participantPropTypes';\nimport * as Expensicons from '../components/Icon/Expensicons';\nimport ROUTES from '../ROUTES';\nimport MenuItem from '../components/MenuItem';\nimport Text from '../components/Text';\nimport CONST from '../CONST';\nimport reportPropTypes from './reportPropTypes';\nimport withReportOrNotFound from './home/report/withReportOrNotFound';\nimport FullPageNotFoundView from '../components/BlockingViews/FullPageNotFoundView';\n\nconst propTypes = {\n ...withLocalizePropTypes,\n\n /** The report currently being looked at */\n report: reportPropTypes.isRequired,\n\n /** The policies which the user has access to and which the report could be tied to */\n policies: PropTypes.shape({\n /** Name of the policy */\n name: PropTypes.string,\n }),\n\n /** Route params */\n route: PropTypes.shape({\n params: PropTypes.shape({\n /** Report ID passed via route r/:reportID/details */\n reportID: PropTypes.string,\n }),\n }).isRequired,\n\n /** Personal details of all the users */\n personalDetails: PropTypes.objectOf(participantPropTypes),\n};\n\nconst defaultProps = {\n policies: {},\n personalDetails: {},\n};\n\nclass ReportDetailsPage extends Component {\n getMenuItems() {\n const menuItems = [];\n\n if (ReportUtils.isArchivedRoom(this.props.report)) {\n return [];\n }\n\n if (lodashGet(this.props.report, 'participants', []).length) {\n menuItems.push({\n key: CONST.REPORT_DETAILS_MENU_ITEM.MEMBERS,\n translationKey: 'common.members',\n icon: Expensicons.Users,\n subtitle: lodashGet(this.props.report, 'participants', []).length,\n action: () => { Navigation.navigate(ROUTES.getReportParticipantsRoute(this.props.report.reportID)); },\n });\n }\n\n if (ReportUtils.isPolicyExpenseChat(this.props.report) || ReportUtils.isChatRoom(this.props.report)) {\n menuItems.push({\n key: CONST.REPORT_DETAILS_MENU_ITEM.SETTINGS,\n translationKey: 'common.settings',\n icon: Expensicons.Gear,\n action: () => { Navigation.navigate(ROUTES.getReportSettingsRoute(this.props.report.reportID)); },\n });\n }\n\n const policy = this.props.policies[`${ONYXKEYS.COLLECTION.POLICY}${this.props.report.policyID}`];\n if (ReportUtils.isUserCreatedPolicyRoom(this.props.report) || ReportUtils.canLeaveRoom(this.props.report, !_.isEmpty(policy))) {\n menuItems.push({\n key: CONST.REPORT_DETAILS_MENU_ITEM.LEAVE_ROOM,\n translationKey: 'common.leaveRoom',\n icon: Expensicons.Exit,\n action: () => Policy.leaveRoom(this.props.report.reportID),\n });\n }\n\n return menuItems;\n }\n\n render() {\n const isPolicyExpenseChat = ReportUtils.isPolicyExpenseChat(this.props.report);\n const isChatRoom = ReportUtils.isChatRoom(this.props.report);\n const chatRoomSubtitle = ReportUtils.getChatRoomSubtitle(this.props.report, this.props.policies);\n const participants = lodashGet(this.props.report, 'participants', []);\n const isMultipleParticipant = participants.length > 1;\n const displayNamesWithTooltips = ReportUtils.getDisplayNamesWithTooltips(\n OptionsListUtils.getPersonalDetailsForLogins(participants, this.props.personalDetails),\n isMultipleParticipant,\n );\n const menuItems = this.getMenuItems();\n return (\n \n \n Navigation.goBack()}\n onCloseButtonPress={() => Navigation.dismissModal()}\n />\n \n \n \n \n \n \n \n \n \n \n \n {chatRoomSubtitle}\n \n \n \n \n {_.map(menuItems, (item) => {\n const brickRoadIndicator = (\n ReportUtils.hasReportNameError(this.props.report)\n && item.key === CONST.REPORT_DETAILS_MENU_ITEM.SETTINGS\n )\n ? CONST.BRICK_ROAD_INDICATOR_STATUS.ERROR\n : '';\n return (\n \n );\n })}\n \n \n \n );\n }\n}\n\nReportDetailsPage.propTypes = propTypes;\nReportDetailsPage.defaultProps = defaultProps;\nexport default compose(\n withLocalize,\n withReportOrNotFound,\n withOnyx({\n personalDetails: {\n key: ONYXKEYS.PERSONAL_DETAILS,\n },\n policies: {\n key: ONYXKEYS.COLLECTION.POLICY,\n },\n }),\n)(ReportDetailsPage);\n","import React, {memo} from 'react';\nimport PropTypes from 'prop-types';\nimport {View} from 'react-native';\nimport _ from 'underscore';\nimport styles from '../styles/styles';\nimport Text from './Text';\nimport CONST from '../CONST';\nimport Avatar from './Avatar';\nimport themeColors from '../styles/themes/default';\nimport * as StyleUtils from '../styles/StyleUtils';\nimport avatarPropTypes from './avatarPropTypes';\n\nconst propTypes = {\n icons: PropTypes.arrayOf(avatarPropTypes),\n};\n\nconst defaultProps = {\n icons: [],\n};\n\nconst RoomHeaderAvatars = (props) => {\n if (!props.icons.length) {\n return null;\n }\n\n if (props.icons.length === 1) {\n return (\n \n );\n }\n\n const iconsToDisplay = props.icons.slice(0, CONST.REPORT.MAX_PREVIEW_AVATARS);\n\n const iconStyle = [\n styles.roomHeaderAvatar,\n\n // Due to border-box box-sizing, the Avatars have to be larger when bordered to visually match size with non-bordered Avatars\n StyleUtils.getAvatarStyle(CONST.AVATAR_SIZE.LARGE_BORDERED),\n ];\n return (\n \n \n {_.map(iconsToDisplay, (icon, index) => (\n \n \n {index === CONST.REPORT.MAX_PREVIEW_AVATARS - 1 && props.icons.length - CONST.REPORT.MAX_PREVIEW_AVATARS !== 0 && (\n <>\n \n \n {`+${props.icons.length - CONST.REPORT.MAX_PREVIEW_AVATARS}`}\n \n \n )}\n \n ))}\n \n \n );\n};\n\nRoomHeaderAvatars.defaultProps = defaultProps;\nRoomHeaderAvatars.propTypes = propTypes;\nRoomHeaderAvatars.displayName = 'RoomHeaderAvatars';\n\nexport default memo(RoomHeaderAvatars);\n","import PropTypes from 'prop-types';\nimport React, {Component} from 'react';\nimport {withOnyx} from 'react-native-onyx';\nimport _ from 'underscore';\nimport getComponentDisplayName from '../../../libs/getComponentDisplayName';\nimport NotFoundPage from '../../ErrorPage/NotFoundPage';\nimport ONYXKEYS from '../../../ONYXKEYS';\nimport reportPropTypes from '../../reportPropTypes';\n\nexport default function (WrappedComponent) {\n const propTypes = {\n /** The HOC takes an optional ref as a prop and passes it as a ref to the wrapped component.\n * That way, if a ref is passed to a component wrapped in the HOC, the ref is a reference to the wrapped component, not the HOC. */\n forwardedRef: PropTypes.func,\n\n /** The report currently being looked at */\n report: reportPropTypes,\n };\n\n const defaultProps = {\n forwardedRef: () => {},\n report: {},\n };\n\n class WithReportOrNotFound extends Component {\n render() {\n if (_.isEmpty(this.props.report) || !this.props.report.reportID) {\n return ;\n }\n\n const rest = _.omit(this.props, ['forwardedRef']);\n\n return (\n \n );\n }\n }\n\n WithReportOrNotFound.propTypes = propTypes;\n WithReportOrNotFound.defaultProps = defaultProps;\n WithReportOrNotFound.displayName = `withReportOrNotFound(${getComponentDisplayName(WrappedComponent)})`;\n // eslint-disable-next-line rulesdir/no-negated-variables\n const withReportOrNotFound = React.forwardRef((props, ref) => (\n // eslint-disable-next-line react/jsx-props-no-spreading\n \n ));\n\n return withOnyx({\n report: {\n key: ({route}) => `${ONYXKEYS.COLLECTION.REPORT}${route.params.reportID}`,\n },\n })(withReportOrNotFound);\n}\n","import React, {Component} from 'react';\nimport PropTypes from 'prop-types';\nimport {View, Keyboard} from 'react-native';\nimport {withOnyx} from 'react-native-onyx';\nimport _ from 'underscore';\nimport lodashGet from 'lodash/get';\nimport CONST from '../CONST';\nimport ONYXKEYS from '../ONYXKEYS';\nimport styles from '../styles/styles';\nimport compose from '../libs/compose';\nimport Navigation from '../libs/Navigation/Navigation';\nimport * as Report from '../libs/actions/Report';\nimport * as Policy from '../libs/actions/Policy';\nimport * as ReportUtils from '../libs/ReportUtils';\nimport HeaderWithCloseButton from '../components/HeaderWithCloseButton';\nimport ScreenWrapper from '../components/ScreenWrapper';\nimport withLocalize, {withLocalizePropTypes} from '../components/withLocalize';\nimport Text from '../components/Text';\nimport RoomNameInput from '../components/RoomNameInput';\nimport Picker from '../components/Picker';\nimport * as ValidationUtils from '../libs/ValidationUtils';\nimport * as ErrorUtils from '../libs/ErrorUtils';\nimport OfflineWithFeedback from '../components/OfflineWithFeedback';\nimport reportPropTypes from './reportPropTypes';\nimport withReportOrNotFound from './home/report/withReportOrNotFound';\nimport Form from '../components/Form';\nimport FullPageNotFoundView from '../components/BlockingViews/FullPageNotFoundView';\n\nconst propTypes = {\n /** Route params */\n route: PropTypes.shape({\n params: PropTypes.shape({\n /** Report ID passed via route r/:reportID/settings */\n reportID: PropTypes.string,\n }),\n }).isRequired,\n\n ...withLocalizePropTypes,\n\n /* Onyx Props */\n\n /** The active report */\n report: reportPropTypes.isRequired,\n\n /** The policies which the user has access to and which the report could be tied to */\n policies: PropTypes.shape({\n /** The policy name */\n name: PropTypes.string,\n\n /** ID of the policy */\n id: PropTypes.string,\n }),\n\n /** All reports shared with the user */\n reports: PropTypes.objectOf(reportPropTypes),\n};\n\nconst defaultProps = {\n policies: {},\n reports: {},\n};\n\nclass ReportSettingsPage extends Component {\n constructor(props) {\n super(props);\n\n this.validate = this.validate.bind(this);\n }\n\n getNotificationPreferenceOptions() {\n return [\n {value: CONST.REPORT.NOTIFICATION_PREFERENCE.ALWAYS, label: this.props.translate('notificationPreferences.immediately')},\n {value: CONST.REPORT.NOTIFICATION_PREFERENCE.DAILY, label: this.props.translate('notificationPreferences.daily')},\n {value: CONST.REPORT.NOTIFICATION_PREFERENCE.MUTE, label: this.props.translate('notificationPreferences.mute')},\n ];\n }\n\n /**\n * @param {Object|null} linkedWorkspace - the workspace the report is on, null if the user isn't a member of the workspace\n * @returns {Boolean}\n */\n shouldDisableRename(linkedWorkspace) {\n if (ReportUtils.isDefaultRoom(this.props.report) || ReportUtils.isArchivedRoom(this.props.report)) {\n return true;\n }\n\n // The remaining checks only apply to public rooms\n if (!ReportUtils.isPublicRoom(this.props.report)) {\n return false;\n }\n\n // if the linked workspace is null, that means the person isn't a member of the workspace the report is in\n // which means this has to be a public room we want to disable renaming for\n if (!linkedWorkspace) {\n return true;\n }\n\n // If there is a linked workspace, that means the user is a member of the workspace the report is in.\n // Still, we only want policy owners and admins to be able to modify the name.\n return !Policy.isPolicyOwner(linkedWorkspace) && linkedWorkspace.role !== CONST.POLICY.ROLE.ADMIN;\n }\n\n /**\n * @param {Object} values - form input values passed by the Form component\n */\n updatePolicyRoomName(values) {\n Keyboard.dismiss();\n\n // When the room name has not changed, skip the Form submission\n if (values.newRoomName === this.props.report.reportName) {\n return;\n }\n Report.updatePolicyRoomName(this.props.report, values.newRoomName);\n }\n\n /**\n * @param {Object} values - form input values passed by the Form component\n * @returns {Boolean}\n */\n validate(values) {\n const errors = {};\n\n // We should skip validation hence we return an empty errors and we skip Form submission on the onSubmit method\n if (values.newRoomName === this.props.report.reportName) {\n return errors;\n }\n\n if (!values.newRoomName || values.newRoomName === CONST.POLICY.ROOM_PREFIX) {\n // We error if the user doesn't enter a room name or left blank\n ErrorUtils.addErrorMessage(errors, 'newRoomName', this.props.translate('newRoomPage.pleaseEnterRoomName'));\n } else if (values.newRoomName !== CONST.POLICY.ROOM_PREFIX && !ValidationUtils.isValidRoomName(values.newRoomName)) {\n // We error if the room name has invalid characters\n ErrorUtils.addErrorMessage(errors, 'newRoomName', this.props.translate('newRoomPage.roomNameInvalidError'));\n } else if (ValidationUtils.isReservedRoomName(values.newRoomName)) {\n // Certain names are reserved for default rooms and should not be used for policy rooms.\n ErrorUtils.addErrorMessage(errors, 'newRoomName', this.props.translate('newRoomPage.roomNameReservedError', {reservedName: values.newRoomName}));\n } else if (ValidationUtils.isExistingRoomName(values.newRoomName, this.props.reports, this.props.report.policyID)) {\n // Certain names are reserved for default rooms and should not be used for policy rooms.\n ErrorUtils.addErrorMessage(errors, 'newRoomName', this.props.translate('newRoomPage.roomAlreadyExistsError'));\n }\n\n return errors;\n }\n\n render() {\n const shouldShowRoomName = !ReportUtils.isPolicyExpenseChat(this.props.report);\n const linkedWorkspace = _.find(this.props.policies, policy => policy && policy.id === this.props.report.policyID);\n const shouldDisableRename = this.shouldDisableRename(linkedWorkspace);\n\n return (\n \n \n \n !shouldDisableRename && this.updatePolicyRoomName(values)}\n scrollContextEnabled\n isSubmitButtonVisible={shouldShowRoomName && !shouldDisableRename}\n enabledWhenOffline\n >\n \n \n {\n if (this.props.report.notificationPreference === notificationPreference) {\n return;\n }\n\n Report.updateNotificationPreference(\n this.props.report.reportID,\n this.props.report.notificationPreference,\n notificationPreference,\n );\n }}\n items={this.getNotificationPreferenceOptions()}\n value={this.props.report.notificationPreference}\n />\n \n \n {shouldShowRoomName && (\n \n Report.clearPolicyRoomNameErrors(this.props.report.reportID)}\n >\n \n \n {shouldDisableRename ? (\n \n \n {this.props.translate('newRoomPage.roomName')}\n \n \n {this.props.report.reportName}\n \n \n )\n : (\n \n )}\n \n \n \n \n )}\n {Boolean(linkedWorkspace) && (\n \n \n {this.props.translate('workspace.common.workspace')}\n \n \n {linkedWorkspace.name}\n \n \n )}\n {Boolean(this.props.report.visibility) && (\n \n \n {this.props.translate('newRoomPage.visibility')}\n \n \n {this.props.translate(`newRoomPage.visibilityOptions.${this.props.report.visibility}`)}\n \n \n {\n this.props.report.visibility === CONST.REPORT.VISIBILITY.RESTRICTED\n ? this.props.translate('newRoomPage.restrictedDescription')\n : this.props.translate('newRoomPage.privateDescription')\n }\n \n \n )}\n \n \n \n );\n }\n}\n\nReportSettingsPage.propTypes = propTypes;\nReportSettingsPage.defaultProps = defaultProps;\nexport default compose(\n withLocalize,\n withReportOrNotFound,\n withOnyx({\n policies: {\n key: ONYXKEYS.COLLECTION.POLICY,\n },\n reports: {\n key: ONYXKEYS.COLLECTION.REPORT,\n },\n }),\n)(ReportSettingsPage);\n","import React, {Component} from 'react';\nimport _ from 'underscore';\nimport CONST from '../../CONST';\nimport withLocalize from '../withLocalize';\nimport TextInput from '../TextInput';\nimport * as roomNameInputPropTypes from './roomNameInputPropTypes';\nimport * as RoomNameInputUtils from '../../libs/RoomNameInputUtils';\nimport getOperatingSystem from '../../libs/getOperatingSystem';\n\nclass RoomNameInput extends Component {\n constructor(props) {\n super(props);\n\n this.setModifiedRoomName = this.setModifiedRoomName.bind(this);\n }\n\n /**\n * Calls the onChangeText callback with a modified room name\n * @param {Event} event\n */\n setModifiedRoomName(event) {\n const roomName = event.nativeEvent.text;\n const modifiedRoomName = RoomNameInputUtils.modifyRoomName(roomName);\n this.props.onChangeText(modifiedRoomName);\n\n // if custom component has onInputChange, use it to trigger changes (Form input)\n if (_.isFunction(this.props.onInputChange)) {\n this.props.onInputChange(modifiedRoomName);\n }\n }\n\n render() {\n const keyboardType = getOperatingSystem() === CONST.OS.IOS ? CONST.KEYBOARD_TYPE.ASCII_CAPABLE : CONST.KEYBOARD_TYPE.VISIBLE_PASSWORD;\n return (\n \n );\n }\n}\n\nRoomNameInput.propTypes = roomNameInputPropTypes.propTypes;\nRoomNameInput.defaultProps = roomNameInputPropTypes.defaultProps;\n\nexport default withLocalize(\n React.forwardRef((props, ref) => (\n // eslint-disable-next-line react/jsx-props-no-spreading\n \n )),\n);\n","import PropTypes from 'prop-types';\nimport {withLocalizePropTypes} from '../withLocalize';\n\nconst propTypes = {\n /** Callback to execute when the text input is modified correctly */\n onChangeText: PropTypes.func,\n\n /** Room name to show in input field. This should include the '#' already prefixed to the name */\n value: PropTypes.string,\n\n /** Whether we should show the input as disabled */\n disabled: PropTypes.bool,\n\n /** Error text to show */\n errorText: PropTypes.string,\n\n ...withLocalizePropTypes,\n\n /** A ref forwarded to the TextInput */\n forwardedRef: PropTypes.func,\n\n /** The ID used to uniquely identify the input in a Form */\n inputID: PropTypes.string,\n\n /** Callback that is called when the text input is blurred */\n onBlur: PropTypes.func,\n\n /** AutoFocus */\n autoFocus: PropTypes.bool,\n\n /** Whether we should wait before focusing the TextInput, useful when using transitions on Android */\n shouldDelayFocus: PropTypes.bool,\n};\n\nconst defaultProps = {\n onChangeText: () => {},\n value: '',\n disabled: false,\n errorText: '',\n forwardedRef: () => {},\n\n inputID: undefined,\n onBlur: () => {},\n autoFocus: false,\n shouldDelayFocus: false,\n};\n\nexport {propTypes, defaultProps};\n","import CONST from '../CONST';\n\n/**\n * Replaces spaces with dashes\n *\n * @param {String} roomName\n * @returns {String}\n */\nfunction modifyRoomName(roomName) {\n const modifiedRoomNameWithoutHash = roomName\n .replace(/ /g, '-')\n\n // Replaces the smart dash on iOS devices with two hyphens\n .replace(/—/g, '--');\n\n return `${CONST.POLICY.ROOM_PREFIX}${modifiedRoomNameWithoutHash}`;\n}\n\nexport {\n // eslint-disable-next-line import/prefer-default-export\n modifyRoomName,\n};\n","import React from 'react';\nimport _ from 'underscore';\nimport {\n View,\n} from 'react-native';\nimport PropTypes from 'prop-types';\nimport {withOnyx} from 'react-native-onyx';\nimport Str from 'expensify-common/lib/str';\nimport lodashGet from 'lodash/get';\nimport styles from '../styles/styles';\nimport ONYXKEYS from '../ONYXKEYS';\nimport HeaderWithCloseButton from '../components/HeaderWithCloseButton';\nimport Navigation from '../libs/Navigation/Navigation';\nimport ScreenWrapper from '../components/ScreenWrapper';\nimport OptionsList from '../components/OptionsList';\nimport ROUTES from '../ROUTES';\nimport personalDetailsPropType from './personalDetailsPropType';\nimport withLocalize, {withLocalizePropTypes} from '../components/withLocalize';\nimport compose from '../libs/compose';\nimport * as ReportUtils from '../libs/ReportUtils';\nimport reportPropTypes from './reportPropTypes';\nimport withReportOrNotFound from './home/report/withReportOrNotFound';\nimport FullPageNotFoundView from '../components/BlockingViews/FullPageNotFoundView';\nimport CONST from '../CONST';\n\nconst propTypes = {\n /* Onyx Props */\n\n /** The personal details of the person who is logged in */\n personalDetails: personalDetailsPropType,\n\n /** The active report */\n report: reportPropTypes.isRequired,\n\n /** Route params */\n route: PropTypes.shape({\n params: PropTypes.shape({\n /** Report ID passed via route r/:reportID/participants */\n reportID: PropTypes.string,\n }),\n }).isRequired,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n personalDetails: {},\n};\n\n/**\n * Returns all the participants in the active report\n *\n * @param {Object} report The active report object\n * @param {Object} personalDetails The personal details of the users\n * @return {Array}\n */\nconst getAllParticipants = (report, personalDetails) => {\n const {participants} = report;\n\n return _.map(participants, (login) => {\n const userLogin = Str.removeSMSDomain(login);\n const userPersonalDetail = lodashGet(personalDetails, login, {displayName: userLogin, avatar: ''});\n\n return ({\n alternateText: userLogin,\n displayName: userPersonalDetail.displayName,\n icons: [{\n source: ReportUtils.getAvatar(userPersonalDetail.avatar, login),\n name: login,\n type: CONST.ICON_TYPE_AVATAR,\n }],\n keyForList: userLogin,\n login,\n text: userPersonalDetail.displayName,\n tooltipText: userLogin,\n participantsList: [{login, displayName: userPersonalDetail.displayName}],\n });\n });\n};\n\nconst ReportParticipantsPage = (props) => {\n const participants = getAllParticipants(props.report, props.personalDetails);\n\n return (\n \n {({safeAreaPaddingBottomStyle}) => (\n \n \n \n {Boolean(participants.length) && (\n {\n Navigation.navigate(ROUTES.getReportParticipantRoute(\n props.route.params.reportID, option.login,\n ));\n }}\n hideSectionHeaders\n showTitleTooltip\n disableFocusOptions\n boldStyle\n optionHoveredStyle={styles.hoveredComponentBG}\n contentContainerStyles={[safeAreaPaddingBottomStyle]}\n />\n )}\n \n \n )}\n \n );\n};\n\nReportParticipantsPage.propTypes = propTypes;\nReportParticipantsPage.defaultProps = defaultProps;\nReportParticipantsPage.displayName = 'ReportParticipantsPage';\n\nexport default compose(\n withLocalize,\n withReportOrNotFound,\n withOnyx({\n personalDetails: {\n key: ONYXKEYS.PERSONAL_DETAILS,\n },\n }),\n)(ReportParticipantsPage);\n","import _ from 'underscore';\nimport React, {Component} from 'react';\nimport {View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport {withOnyx} from 'react-native-onyx';\nimport OptionsSelector from '../components/OptionsSelector';\nimport * as OptionsListUtils from '../libs/OptionsListUtils';\nimport ONYXKEYS from '../ONYXKEYS';\nimport styles from '../styles/styles';\nimport Navigation from '../libs/Navigation/Navigation';\nimport ROUTES from '../ROUTES';\nimport withWindowDimensions, {windowDimensionsPropTypes} from '../components/withWindowDimensions';\nimport * as Report from '../libs/actions/Report';\nimport HeaderWithCloseButton from '../components/HeaderWithCloseButton';\nimport ScreenWrapper from '../components/ScreenWrapper';\nimport Timing from '../libs/actions/Timing';\nimport CONST from '../CONST';\nimport withLocalize, {withLocalizePropTypes} from '../components/withLocalize';\nimport compose from '../libs/compose';\nimport personalDetailsPropType from './personalDetailsPropType';\nimport reportPropTypes from './reportPropTypes';\nimport Performance from '../libs/Performance';\n\nconst propTypes = {\n /* Onyx Props */\n\n /** Beta features list */\n betas: PropTypes.arrayOf(PropTypes.string),\n\n /** All of the personal details for everyone */\n personalDetails: personalDetailsPropType,\n\n /** All reports shared with the user */\n reports: PropTypes.objectOf(reportPropTypes),\n\n /** Window Dimensions Props */\n ...windowDimensionsPropTypes,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n betas: [],\n personalDetails: {},\n reports: {},\n};\n\nclass SearchPage extends Component {\n constructor(props) {\n super(props);\n\n Timing.start(CONST.TIMING.SEARCH_RENDER);\n Performance.markStart(CONST.TIMING.SEARCH_RENDER);\n\n this.searchRendered = this.searchRendered.bind(this);\n this.selectReport = this.selectReport.bind(this);\n this.onChangeText = this.onChangeText.bind(this);\n this.debouncedUpdateOptions = _.debounce(this.updateOptions.bind(this), 75);\n\n const {\n recentReports,\n personalDetails,\n userToInvite,\n } = OptionsListUtils.getSearchOptions(\n props.reports,\n props.personalDetails,\n '',\n props.betas,\n );\n\n this.state = {\n searchValue: '',\n recentReports,\n personalDetails,\n userToInvite,\n };\n }\n\n onChangeText(searchValue = '') {\n this.setState({searchValue}, this.debouncedUpdateOptions);\n }\n\n /**\n * Returns the sections needed for the OptionsSelector\n *\n * @returns {Array}\n */\n getSections() {\n const sections = [];\n let indexOffset = 0;\n\n if (this.state.recentReports.length > 0) {\n sections.push(({\n data: this.state.recentReports,\n shouldShow: true,\n indexOffset,\n }));\n indexOffset += this.state.recentReports.length;\n }\n\n if (this.state.personalDetails.length > 0) {\n sections.push(({\n data: this.state.personalDetails,\n shouldShow: true,\n indexOffset,\n }));\n indexOffset += this.state.recentReports.length;\n }\n\n if (this.state.userToInvite) {\n sections.push(({\n data: [this.state.userToInvite],\n shouldShow: true,\n indexOffset,\n }));\n }\n\n return sections;\n }\n\n searchRendered() {\n Timing.end(CONST.TIMING.SEARCH_RENDER);\n Performance.markEnd(CONST.TIMING.SEARCH_RENDER);\n }\n\n updateOptions() {\n const {\n recentReports,\n personalDetails,\n userToInvite,\n } = OptionsListUtils.getSearchOptions(\n this.props.reports,\n this.props.personalDetails,\n this.state.searchValue.trim(),\n this.props.betas,\n );\n this.setState({\n userToInvite,\n recentReports,\n personalDetails,\n });\n }\n\n /**\n * Reset the search value and redirect to the selected report\n *\n * @param {Object} option\n */\n selectReport(option) {\n if (!option) {\n return;\n }\n\n if (option.reportID) {\n this.setState({\n searchValue: '',\n }, () => {\n Navigation.navigate(ROUTES.getReportRoute(option.reportID));\n });\n } else {\n Report.navigateToAndOpenReport([option.login]);\n }\n }\n\n render() {\n const sections = this.getSections();\n const headerMessage = OptionsListUtils.getHeaderMessage(\n (this.state.recentReports.length + this.state.personalDetails.length) !== 0,\n Boolean(this.state.userToInvite),\n this.state.searchValue,\n );\n return (\n \n {({didScreenTransitionEnd, safeAreaPaddingBottomStyle}) => (\n <>\n Navigation.dismissModal(true)}\n />\n \n \n \n \n )}\n \n );\n }\n}\n\nSearchPage.propTypes = propTypes;\nSearchPage.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withWindowDimensions,\n withOnyx({\n reports: {\n key: ONYXKEYS.COLLECTION.REPORT,\n },\n personalDetails: {\n key: ONYXKEYS.PERSONAL_DETAILS,\n },\n betas: {\n key: ONYXKEYS.BETAS,\n },\n }),\n)(SearchPage);\n","import _ from 'underscore';\nimport lodashTransform from 'lodash/transform';\nimport React, {Profiler, forwardRef} from 'react';\nimport {Alert, InteractionManager} from 'react-native';\n\nimport * as Metrics from './Metrics';\nimport getComponentDisplayName from './getComponentDisplayName';\nimport CONST from '../CONST';\nimport isE2ETestSession from './E2E/isE2ETestSession';\n\n/** @type {import('react-native-performance').Performance} */\nlet rnPerformance;\n\n/**\n * Deep diff between two objects. Useful for figuring out what changed about an object from one render to the next so\n * that state and props updates can be optimized.\n *\n * @param {Object} object\n * @param {Object} base\n * @return {Object}\n */\nfunction diffObject(object, base) {\n function changes(obj, comparisonObject) {\n return lodashTransform(obj, (result, value, key) => {\n if (_.isEqual(value, comparisonObject[key])) {\n return;\n }\n\n // eslint-disable-next-line no-param-reassign\n result[key] = (_.isObject(value) && _.isObject(comparisonObject[key]))\n ? changes(value, comparisonObject[key])\n : value;\n });\n }\n return changes(object, base);\n}\n\nconst Performance = {\n // When performance monitoring is disabled the implementations are blank\n diffObject,\n setupPerformanceObserver: () => {},\n getPerformanceMetrics: () => [],\n printPerformanceMetrics: () => {},\n markStart: () => {},\n markEnd: () => {},\n measureFailSafe: () => {},\n measureTTI: () => {},\n traceRender: () => {},\n withRenderTrace: () => Component => Component,\n subscribeToMeasurements: () => {},\n};\n\nif (Metrics.canCapturePerformanceMetrics()) {\n const perfModule = require('react-native-performance');\n perfModule.setResourceLoggingEnabled(true);\n rnPerformance = perfModule.default;\n\n Performance.measureFailSafe = (measureName, startOrMeasureOptions, endMark) => {\n try {\n rnPerformance.measure(measureName, startOrMeasureOptions, endMark);\n } catch (error) {\n // Sometimes there might be no start mark recorded and the measure will fail with an error\n console.debug(error.message);\n }\n };\n\n /**\n * Measures the TTI time. To be called when the app is considered to be interactive.\n * @param {String} [endMark] Optional end mark name\n */\n Performance.measureTTI = (endMark) => {\n // Make sure TTI is captured when the app is really usable\n InteractionManager.runAfterInteractions(() => {\n requestAnimationFrame(() => {\n Performance.measureFailSafe('TTI', 'nativeLaunchStart', endMark);\n\n // we don't want the alert to show on an e2e test session\n if (!isE2ETestSession()) {\n Performance.printPerformanceMetrics();\n }\n });\n });\n };\n\n /**\n * Sets up an observer to capture events recorded in the native layer before the app fully initializes.\n */\n Performance.setupPerformanceObserver = () => {\n const performanceReported = require('react-native-performance-flipper-reporter');\n performanceReported.setupDefaultFlipperReporter();\n\n // Monitor some native marks that we want to put on the timeline\n new perfModule.PerformanceObserver((list, observer) => {\n list.getEntries()\n .forEach((entry) => {\n if (entry.name === 'nativeLaunchEnd') {\n Performance.measureFailSafe('nativeLaunch', 'nativeLaunchStart', 'nativeLaunchEnd');\n }\n if (entry.name === 'downloadEnd') {\n Performance.measureFailSafe('jsBundleDownload', 'downloadStart', 'downloadEnd');\n }\n if (entry.name === 'runJsBundleEnd') {\n Performance.measureFailSafe('runJsBundle', 'runJsBundleStart', 'runJsBundleEnd');\n }\n\n // We don't need to keep the observer past this point\n if (entry.name === 'runJsBundleEnd' || entry.name === 'downloadEnd') {\n observer.disconnect();\n }\n });\n }).observe({type: 'react-native-mark', buffered: true});\n\n // Monitor for \"_end\" marks and capture \"_start\" to \"_end\" measures\n new perfModule.PerformanceObserver((list) => {\n list.getEntriesByType('mark')\n .forEach((mark) => {\n if (mark.name.endsWith('_end')) {\n const end = mark.name;\n const name = end.replace(/_end$/, '');\n const start = `${name}_start`;\n Performance.measureFailSafe(name, start, end);\n }\n\n // Capture any custom measures or metrics below\n if (mark.name === `${CONST.TIMING.SIDEBAR_LOADED}_end`) {\n Performance.measureTTI(mark.name);\n }\n });\n }).observe({type: 'mark', buffered: true});\n };\n\n Performance.getPerformanceMetrics = () => _.chain([\n ...rnPerformance.getEntriesByName('nativeLaunch'),\n ...rnPerformance.getEntriesByName('runJsBundle'),\n ...rnPerformance.getEntriesByName('jsBundleDownload'),\n ...rnPerformance.getEntriesByName('TTI'),\n ...rnPerformance.getEntriesByName('regularAppStart'),\n ...rnPerformance.getEntriesByName('appStartedToReady'),\n ])\n .filter(entry => entry.duration > 0)\n .value();\n\n /**\n * Outputs performance stats. We alert these so that they are easy to access in release builds.\n */\n Performance.printPerformanceMetrics = () => {\n const stats = Performance.getPerformanceMetrics();\n const statsAsText = _.map(stats, entry => `\\u2022 ${entry.name}: ${entry.duration.toFixed(1)}ms`)\n .join('\\n');\n\n if (stats.length > 0) {\n Alert.alert('Performance', statsAsText);\n }\n };\n\n Performance.subscribeToMeasurements = (callback) => {\n new perfModule.PerformanceObserver((list) => {\n list.getEntriesByType('measure').forEach(callback);\n }).observe({type: 'measure', buffered: true});\n };\n\n /**\n * Add a start mark to the performance entries\n * @param {string} name\n * @param {Object} [detail]\n * @returns {PerformanceMark}\n */\n Performance.markStart = (name, detail) => rnPerformance.mark(`${name}_start`, {detail});\n\n /**\n * Add an end mark to the performance entries\n * A measure between start and end is captured automatically\n * @param {string} name\n * @param {Object} [detail]\n * @returns {PerformanceMark}\n */\n Performance.markEnd = (name, detail) => rnPerformance.mark(`${name}_end`, {detail});\n\n /**\n * Put data emitted by Profiler components on the timeline\n * @param {string} id the \"id\" prop of the Profiler tree that has just committed\n * @param {'mount'|'update'} phase either \"mount\" (if the tree just mounted) or \"update\" (if it re-rendered)\n * @param {number} actualDuration time spent rendering the committed update\n * @param {number} baseDuration estimated time to render the entire subtree without memoization\n * @param {number} startTime when React began rendering this update\n * @param {number} commitTime when React committed this update\n * @param {Set} interactions the Set of interactions belonging to this update\n * @returns {PerformanceMeasure}\n */\n Performance.traceRender = (\n id,\n phase,\n actualDuration,\n baseDuration,\n startTime,\n commitTime,\n interactions,\n ) => rnPerformance.measure(id, {\n start: startTime,\n duration: actualDuration,\n detail: {\n phase,\n baseDuration,\n commitTime,\n interactions,\n },\n });\n\n /**\n * A HOC that captures render timings of the Wrapped component\n * @param {object} config\n * @param {string} config.id\n * @returns {function(React.Component): React.FunctionComponent}\n */\n Performance.withRenderTrace = ({id}) => (WrappedComponent) => {\n const WithRenderTrace = forwardRef((props, ref) => (\n \n {/* eslint-disable-next-line react/jsx-props-no-spreading */}\n \n \n ));\n\n WithRenderTrace.displayName = `withRenderTrace(${getComponentDisplayName(WrappedComponent)})`;\n return WithRenderTrace;\n };\n}\n\nexport default Performance;\n","import CONFIG from '../../CONFIG';\n\n/**\n * Is capturing performance stats enabled.\n *\n * @returns {Boolean}\n */\nconst canCapturePerformanceMetrics = () => CONFIG.CAPTURE_METRICS;\n\n/**\n * Is capturing Onyx stats enabled.\n *\n * @returns {Boolean}\n */\nconst canCaptureOnyxMetrics = () => CONFIG.ONYX_METRICS;\n\nexport {\n canCapturePerformanceMetrics,\n canCaptureOnyxMetrics,\n};\n","import CONFIG from '../../CONFIG';\n\nexport default () => CONFIG.E2E_TESTING;\n","import { addPlugin } from 'react-native-flipper';\nimport performance, { PerformanceObserver } from 'react-native-performance';\n\nconst IDENTIFIER = 'flipper-plugin-performance';\nconst SCHEMA_VERSION = 1;\n\nconst getNativeMarkMap = (\n entries = performance.getEntriesByType('react-native-mark')\n) => entries.reduce((acc, item) => acc.set(item.name, item), new Map());\n\n// The bundle download trace can be very long but has no real impact on\n// perf so we try to alter the marks to act as if it wasn't there\nconst subtractDownloadDuration = (entries, entryMap = getNativeMarkMap()) =>\n entries.map((entry) => {\n const downloadEnd = entryMap.get('downloadEnd');\n let transformed = entry.toJSON ? entry.toJSON() : { ...entry };\n if (\n downloadEnd &&\n entry.name !== 'downloadStart' &&\n entry.name !== 'downloadEnd' &&\n entry.startTime <= downloadEnd.startTime\n ) {\n const downloadStart = entryMap.get('downloadStart');\n transformed.startTime += downloadEnd.startTime - downloadStart.startTime;\n }\n return transformed;\n });\n\nconst calculateNativeMeasures = (newEntries, entryMap = getNativeMarkMap()) =>\n newEntries\n .filter(\n (entry) =>\n entry.name.endsWith('End') &&\n entry.name !== 'nativeLaunchEnd' &&\n entry.name !== 'downloadEnd'\n )\n .map((end) => {\n const name = end.name.replace(/End$/, '');\n const { startTime } = entryMap.get(`${name}Start`);\n const duration = end.startTime - startTime;\n return {\n name,\n startTime,\n duration,\n category: 'Native',\n };\n });\n\nconst calculateNativeMetrics = (newEntries, entryMap = getNativeMarkMap()) =>\n newEntries\n .filter((entry) => entry.name === 'nativeLaunchEnd')\n .map((end) => {\n const name = end.name.replace(/End$/, '');\n const { startTime } = entryMap.get(`${name}Start`);\n const value = end.startTime - startTime;\n return {\n name,\n startTime,\n value,\n unit: 'milliseconds',\n };\n });\n\nconst calculateNativeMarks = (newEntries, entryMap = getNativeMarkMap()) =>\n newEntries\n .filter((entry) => !isMeasureMark(entry))\n .map((entry) => ({\n name: entry.name,\n startTime: entry.startTime,\n }));\n\nconst isMeasureMark = (entry) =>\n entry.name.endsWith('End') || entry.name.endsWith('Start');\n\nconst getResourceName = (url) => {\n const [urlSansQuery] = url.split('?');\n return urlSansQuery.replace(/^https?:\\/\\//i, '');\n};\n\nexport function setupDefaultFlipperReporter() {\n let observers = [];\n const sessionStartedAt = Date.now();\n\n const addObserver = (callback, options) => {\n const observer = new PerformanceObserver(callback);\n observer.observe(options);\n observers.push(observer);\n };\n\n addPlugin({\n getId() {\n return IDENTIFIER;\n },\n onConnect(connection) {\n connection.send('setSession', {\n schemaVersion: SCHEMA_VERSION,\n sessionStartedAt,\n });\n\n const appendMeasures = (measures) => {\n connection.send('appendMeasures', {\n schemaVersion: SCHEMA_VERSION,\n measures,\n });\n };\n\n const appendMarks = (marks) => {\n connection.send('appendMarks', {\n schemaVersion: SCHEMA_VERSION,\n marks,\n });\n };\n\n const setMetrics = (metrics) => {\n connection.send('setMetrics', {\n schemaVersion: SCHEMA_VERSION,\n metrics,\n });\n };\n\n addObserver(\n (list) => {\n const entries = subtractDownloadDuration(list.getEntries());\n const entryMap = getNativeMarkMap(entries);\n const measures = calculateNativeMeasures(entries, entryMap);\n if (measures.length !== 0) {\n appendMeasures(measures);\n }\n const marks = calculateNativeMarks(entries, entryMap);\n if (marks.length !== 0) {\n appendMarks(marks);\n }\n const metrics = calculateNativeMetrics(entries, entryMap);\n if (metrics.length !== 0) {\n setMetrics(metrics);\n }\n },\n {\n type: 'react-native-mark',\n buffered: true,\n }\n );\n addObserver(\n (list) => {\n appendMeasures(\n list.getEntries().map((entry) => ({\n name: getResourceName(entry.name),\n startTime: entry.startTime,\n duration: entry.duration,\n category: 'Network',\n }))\n );\n },\n {\n type: 'resource',\n buffered: true,\n }\n );\n addObserver(\n (list) => {\n appendMeasures(\n list.getEntries().map((entry) => ({\n name: entry.name,\n startTime: entry.startTime,\n duration: entry.duration,\n category: 'App',\n }))\n );\n },\n {\n type: 'measure',\n buffered: true,\n }\n );\n addObserver(\n (list) => {\n setMetrics(\n list.getEntries().map((entry) => ({\n name: entry.name,\n startTime: entry.startTime,\n value: entry.value,\n unit: entry.name === 'bundleSize' ? 'bytes' : undefined,\n }))\n );\n },\n {\n type: 'metric',\n buffered: true,\n }\n );\n },\n onDisconnect() {\n observers.forEach((observer) => observer.disconnect());\n observers = [];\n },\n });\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 * @format\n */\n\n// $FlowFixMe\nimport {NativeModules, NativeEventEmitter} from 'react-native';\n\nconst {Flipper} = NativeModules;\n\nexport default Flipper;\n\nconst listeners = {}; // plugin#method -> callback\nconst plugins = {}; // plugin -> Plugin\n\nfunction assertSerializable(data) {\n if (\n data === undefined ||\n Array.isArray(data) ||\n (data && typeof data === 'object')\n ) {\n return true;\n }\n throw new Error(\n 'Flipper: Expected serializable (undefined, an array or an object). Got: ' +\n data,\n );\n}\n\nclass Connection {\n connected;\n pluginId;\n\n constructor(pluginId) {\n this.connected = false;\n this.pluginId = pluginId;\n }\n\n send(method, data) {\n if (!this.connected) {\n throw new Error('Cannot send data, not connected');\n }\n assertSerializable(data);\n Flipper.send(this.pluginId, method, JSON.stringify(data));\n }\n\n reportErrorWithMetadata(reason, stackTrace) {\n Flipper.reportErrorWithMetadata(\n this.pluginId,\n '' + reason,\n '' + stackTrace,\n );\n }\n\n reportError(error) {\n Flipper.reportError(this.pluginId, '' + error);\n }\n\n receive(method, listener) {\n if (!this.connected) {\n throw new Error('Cannot receive data, not connected');\n }\n\n listeners[this.pluginId + '#' + method] = listener;\n Flipper.subscribe(this.pluginId, method);\n }\n}\n\nclass Responder {\n responderId;\n\n constructor(responderId) {\n this.responderId = responderId;\n }\n\n success(response) {\n assertSerializable(response);\n Flipper.respondSuccess(\n this.responderId,\n response == null ? null : JSON.stringify(response),\n );\n }\n\n error(response) {\n assertSerializable(response);\n Flipper.respondError(this.responderId, JSON.stringify(response));\n }\n}\n\nfunction startEventListeners() {\n const emitter = new NativeEventEmitter(Flipper);\n\n emitter.addListener('react-native-flipper-plugin-connect', event => {\n const {plugin} = event;\n if (plugins[plugin]) {\n const p = plugins[plugin];\n p._connection.connected = true;\n p.onConnect(p._connection);\n }\n });\n\n emitter.addListener('react-native-flipper-plugin-disconnect', event => {\n const {plugin} = event;\n if (plugins[plugin]) {\n const p = plugins[plugin];\n p._connection.connected = false;\n p.onDisconnect();\n }\n });\n\n emitter.addListener('react-native-flipper-receive-event', event => {\n const {plugin, method, params, responderId} = event;\n const key = plugin + '#' + method;\n if (listeners[key]) {\n const responder =\n responderId != null ? new Responder(responderId) : undefined;\n listeners[key](JSON.parse(params), responder);\n }\n });\n}\n\n// $FlowFixMe\nexport function addPlugin(plugin) {\n if (!Flipper) {\n printNoFlipperWarning();\n return;\n }\n if (!plugin || typeof plugin !== 'object') {\n throw new Error('Expected plugin, got ' + plugin);\n }\n ['getId', 'onConnect', 'onDisconnect'].forEach(method => {\n if (typeof plugin[method] !== 'function') {\n throw new Error(`Plugin misses an implementation for '${method}'`);\n }\n });\n const runInBackground =\n typeof plugin.runInBackground === 'function'\n ? !!plugin.runInBackground()\n : false;\n const id = plugin.getId();\n plugin._connection = new Connection(id);\n plugins[id] = plugin;\n\n Flipper.registerPlugin(id, runInBackground, status => {\n if (status === 'noflipper') {\n printNoFlipperWarning();\n }\n });\n}\n\nfunction printNoFlipperWarning() {\n // $FlowFixMe\n if (typeof __DEV__ !== 'undefined' && __DEV__) {\n console.warn(\n 'The native module for Flipper seems unavailable. Please verify that `react-native-flipper` is installed as yarn dependency to your project and, for iOS, that `pod install` is run in the `ios` directory.',\n );\n }\n}\n\nif (Flipper) {\n startEventListeners();\n}\n","import React from 'react';\nimport NewChatPage from './NewChatPage';\n\n// eslint-disable-next-line react/jsx-props-no-spreading\nconst NewGroupPage = props => ;\n\nNewGroupPage.displayName = 'NewGroupPage';\n\nexport default NewGroupPage;\n","import _ from 'underscore';\nimport React, {Component} from 'react';\nimport {View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport {withOnyx} from 'react-native-onyx';\nimport OptionsSelector from '../components/OptionsSelector';\nimport * as OptionsListUtils from '../libs/OptionsListUtils';\nimport ONYXKEYS from '../ONYXKEYS';\nimport styles from '../styles/styles';\nimport * as Report from '../libs/actions/Report';\nimport CONST from '../CONST';\nimport withWindowDimensions, {windowDimensionsPropTypes} from '../components/withWindowDimensions';\nimport HeaderWithCloseButton from '../components/HeaderWithCloseButton';\nimport Navigation from '../libs/Navigation/Navigation';\nimport ScreenWrapper from '../components/ScreenWrapper';\nimport FullScreenLoadingIndicator from '../components/FullscreenLoadingIndicator';\nimport withLocalize, {withLocalizePropTypes} from '../components/withLocalize';\nimport compose from '../libs/compose';\nimport personalDetailsPropType from './personalDetailsPropType';\nimport reportPropTypes from './reportPropTypes';\n\nconst propTypes = {\n /** Whether screen is used to create group chat */\n isGroupChat: PropTypes.bool,\n\n /** Beta features list */\n betas: PropTypes.arrayOf(PropTypes.string),\n\n /** All of the personal details for everyone */\n personalDetails: personalDetailsPropType,\n\n /** All reports shared with the user */\n reports: PropTypes.objectOf(reportPropTypes),\n\n ...windowDimensionsPropTypes,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n isGroupChat: false,\n betas: [],\n personalDetails: {},\n reports: {},\n};\n\nclass NewChatPage extends Component {\n constructor(props) {\n super(props);\n\n this.toggleOption = this.toggleOption.bind(this);\n this.createChat = this.createChat.bind(this);\n this.createGroup = this.createGroup.bind(this);\n this.updateOptionsWithSearchTerm = this.updateOptionsWithSearchTerm.bind(this);\n this.excludedGroupEmails = _.without(CONST.EXPENSIFY_EMAILS, CONST.EMAIL.CONCIERGE);\n\n const {\n recentReports,\n personalDetails,\n userToInvite,\n } = OptionsListUtils.getNewChatOptions(\n props.reports,\n props.personalDetails,\n props.betas,\n '',\n [],\n this.props.isGroupChat ? this.excludedGroupEmails : [],\n );\n this.state = {\n searchTerm: '',\n recentReports,\n personalDetails,\n selectedOptions: [],\n userToInvite,\n };\n }\n\n /**\n * Returns the sections needed for the OptionsSelector\n *\n * @param {Boolean} maxParticipantsReached\n * @returns {Array}\n */\n getSections(maxParticipantsReached) {\n const sections = [];\n let indexOffset = 0;\n\n if (this.props.isGroupChat) {\n sections.push({\n title: undefined,\n data: this.state.selectedOptions,\n shouldShow: !_.isEmpty(this.state.selectedOptions),\n indexOffset,\n });\n indexOffset += this.state.selectedOptions.length;\n\n if (maxParticipantsReached) {\n return sections;\n }\n }\n\n // Filtering out selected users from the search results\n const filterText = _.reduce(this.state.selectedOptions, (str, {login}) => `${str} ${login}`, '');\n const recentReportsWithoutSelected = _.filter(this.state.recentReports, ({login}) => !filterText.includes(login));\n const personalDetailsWithoutSelected = _.filter(this.state.personalDetails, ({login}) => !filterText.includes(login));\n const hasUnselectedUserToInvite = this.state.userToInvite && !filterText.includes(this.state.userToInvite.login);\n\n sections.push({\n title: this.props.translate('common.recents'),\n data: recentReportsWithoutSelected,\n shouldShow: !_.isEmpty(recentReportsWithoutSelected),\n indexOffset,\n });\n indexOffset += recentReportsWithoutSelected.length;\n\n sections.push({\n title: this.props.translate('common.contacts'),\n data: personalDetailsWithoutSelected,\n shouldShow: !_.isEmpty(personalDetailsWithoutSelected),\n indexOffset,\n });\n indexOffset += personalDetailsWithoutSelected.length;\n\n if (hasUnselectedUserToInvite) {\n sections.push(({\n title: undefined,\n data: [this.state.userToInvite],\n shouldShow: true,\n indexOffset,\n }));\n }\n\n return sections;\n }\n\n updateOptionsWithSearchTerm(searchTerm = '') {\n const {\n recentReports,\n personalDetails,\n userToInvite,\n } = OptionsListUtils.getNewChatOptions(\n this.props.reports,\n this.props.personalDetails,\n this.props.betas,\n searchTerm,\n [],\n this.props.isGroupChat ? this.excludedGroupEmails : [],\n );\n this.setState({\n searchTerm,\n userToInvite,\n recentReports,\n personalDetails,\n });\n }\n\n /**\n * Removes a selected option from list if already selected. If not already selected add this option to the list.\n * @param {Object} option\n */\n toggleOption(option) {\n this.setState((prevState) => {\n const isOptionInList = _.some(prevState.selectedOptions, selectedOption => (\n selectedOption.login === option.login\n ));\n\n let newSelectedOptions;\n\n if (isOptionInList) {\n newSelectedOptions = _.reject(prevState.selectedOptions, selectedOption => (\n selectedOption.login === option.login\n ));\n } else {\n newSelectedOptions = [...prevState.selectedOptions, option];\n }\n\n const {\n recentReports,\n personalDetails,\n userToInvite,\n } = OptionsListUtils.getNewChatOptions(\n this.props.reports,\n this.props.personalDetails,\n this.props.betas,\n prevState.searchTerm,\n [],\n this.excludedGroupEmails,\n );\n\n return {\n selectedOptions: newSelectedOptions,\n recentReports,\n personalDetails,\n userToInvite,\n searchTerm: prevState.searchTerm,\n };\n });\n }\n\n /**\n * Creates a new 1:1 chat with the option and the current user,\n * or navigates to the existing chat if one with those participants already exists.\n *\n * @param {Object} option\n */\n createChat(option) {\n Report.navigateToAndOpenReport([option.login]);\n }\n\n /**\n * Creates a new group chat with all the selected options and the current user,\n * or navigates to the existing chat if one with those participants already exists.\n */\n createGroup() {\n if (!this.props.isGroupChat) {\n return;\n }\n\n const userLogins = _.pluck(this.state.selectedOptions, 'login');\n if (userLogins.length < 1) {\n return;\n }\n Report.navigateToAndOpenReport(userLogins);\n }\n\n render() {\n const maxParticipantsReached = this.state.selectedOptions.length === CONST.REPORT.MAXIMUM_PARTICIPANTS;\n const sections = this.getSections(maxParticipantsReached);\n const headerMessage = OptionsListUtils.getHeaderMessage(\n (this.state.personalDetails.length + this.state.recentReports.length) !== 0,\n Boolean(this.state.userToInvite),\n this.state.searchTerm,\n maxParticipantsReached,\n );\n return (\n \n {({didScreenTransitionEnd, safeAreaPaddingBottomStyle}) => (\n <>\n Navigation.dismissModal(true)}\n />\n 0 ? safeAreaPaddingBottomStyle : {}]}>\n {didScreenTransitionEnd ? (\n (this.props.isGroupChat ? this.toggleOption(option) : this.createChat(option))}\n onChangeText={this.updateOptionsWithSearchTerm}\n headerMessage={headerMessage}\n boldStyle\n shouldFocusOnSelectRow={this.props.isGroupChat}\n shouldShowConfirmButton={this.props.isGroupChat}\n confirmButtonText={this.props.translate('newChatPage.createGroup')}\n onConfirmSelection={this.createGroup}\n placeholderText={this.props.translate('optionsSelector.nameEmailOrPhoneNumber')}\n safeAreaPaddingBottomStyle={safeAreaPaddingBottomStyle}\n />\n ) : (\n \n )}\n \n \n )}\n \n );\n }\n}\n\nNewChatPage.propTypes = propTypes;\nNewChatPage.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withWindowDimensions,\n withOnyx({\n reports: {\n key: ONYXKEYS.COLLECTION.REPORT,\n },\n personalDetails: {\n key: ONYXKEYS.PERSONAL_DETAILS,\n },\n betas: {\n key: ONYXKEYS.BETAS,\n },\n }),\n)(NewChatPage);\n","import lodashGet from 'lodash/get';\nimport React from 'react';\nimport {View, ScrollView, Pressable} from 'react-native';\nimport PropTypes from 'prop-types';\nimport _ from 'underscore';\nimport {withOnyx} from 'react-native-onyx';\nimport Str from 'expensify-common/lib/str';\nimport {withNetwork} from '../../components/OnyxProvider';\nimport styles from '../../styles/styles';\nimport Text from '../../components/Text';\nimport * as Session from '../../libs/actions/Session';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport Tooltip from '../../components/Tooltip';\nimport Avatar from '../../components/Avatar';\nimport HeaderWithCloseButton from '../../components/HeaderWithCloseButton';\nimport Navigation from '../../libs/Navigation/Navigation';\nimport * as Expensicons from '../../components/Icon/Expensicons';\nimport ScreenWrapper from '../../components/ScreenWrapper';\nimport MenuItem from '../../components/MenuItem';\nimport ROUTES from '../../ROUTES';\nimport withLocalize, {withLocalizePropTypes} from '../../components/withLocalize';\nimport compose from '../../libs/compose';\nimport CONST from '../../CONST';\nimport Permissions from '../../libs/Permissions';\nimport * as App from '../../libs/actions/App';\nimport withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsPropTypes, withCurrentUserPersonalDetailsDefaultProps} from '../../components/withCurrentUserPersonalDetails';\nimport * as PaymentMethods from '../../libs/actions/PaymentMethods';\nimport bankAccountPropTypes from '../../components/bankAccountPropTypes';\nimport cardPropTypes from '../../components/cardPropTypes';\nimport * as Wallet from '../../libs/actions/Wallet';\nimport walletTermsPropTypes from '../EnablePayments/walletTermsPropTypes';\nimport * as PolicyUtils from '../../libs/PolicyUtils';\nimport ConfirmModal from '../../components/ConfirmModal';\nimport * as ReportUtils from '../../libs/ReportUtils';\nimport * as Link from '../../libs/actions/Link';\nimport OfflineWithFeedback from '../../components/OfflineWithFeedback';\nimport * as UserUtils from '../../libs/UserUtils';\nimport policyMemberPropType from '../policyMemberPropType';\nimport * as ReportActionContextMenu from '../home/report/ContextMenu/ReportActionContextMenu';\nimport {CONTEXT_MENU_TYPES} from '../home/report/ContextMenu/ContextMenuActions';\n\nconst propTypes = {\n /* Onyx Props */\n\n /** The session of the logged in person */\n session: PropTypes.shape({\n /** Email of the logged in person */\n email: PropTypes.string,\n }),\n\n /** The list of this user's policies */\n policies: PropTypes.objectOf(PropTypes.shape({\n /** The ID of the policy */\n ID: PropTypes.string,\n\n /** The name of the policy */\n name: PropTypes.string,\n\n /** The type of the policy */\n type: PropTypes.string,\n\n /** The user's role in the policy */\n role: PropTypes.string,\n\n /** The current action that is waiting to happen on the policy */\n pendingAction: PropTypes.oneOf(_.values(CONST.RED_BRICK_ROAD_PENDING_ACTION)),\n })),\n\n /** The user's wallet account */\n userWallet: PropTypes.shape({\n /** The user's current wallet balance */\n currentBalance: PropTypes.number,\n }),\n\n /** List of bank accounts */\n bankAccountList: PropTypes.objectOf(bankAccountPropTypes),\n\n /** List of cards */\n cardList: PropTypes.objectOf(cardPropTypes),\n\n /** List of betas available to current user */\n betas: PropTypes.arrayOf(PropTypes.string),\n\n /** Information about the user accepting the terms for payments */\n walletTerms: walletTermsPropTypes,\n\n /** Login list for the user that is signed in */\n loginList: PropTypes.shape({\n /** Date login was validated, used to show brickroad info status */\n validatedDate: PropTypes.string,\n\n /** Field-specific server side errors keyed by microtime */\n errorFields: PropTypes.objectOf(PropTypes.objectOf(PropTypes.string)),\n }),\n\n /** List of policy members */\n policyMembers: PropTypes.objectOf(policyMemberPropType),\n\n ...withLocalizePropTypes,\n ...withCurrentUserPersonalDetailsPropTypes,\n};\n\nconst defaultProps = {\n session: {},\n policies: {},\n userWallet: {\n currentBalance: 0,\n },\n betas: [],\n walletTerms: {},\n bankAccountList: {},\n cardList: {},\n loginList: {},\n policyMembers: {},\n ...withCurrentUserPersonalDetailsDefaultProps,\n};\n\nclass InitialSettingsPage extends React.Component {\n constructor(props) {\n super(props);\n\n this.popoverAnchor = React.createRef();\n\n this.getWalletBalance = this.getWalletBalance.bind(this);\n this.getDefaultMenuItems = this.getDefaultMenuItems.bind(this);\n this.getMenuItem = this.getMenuItem.bind(this);\n this.toggleSignoutConfirmModal = this.toggleSignoutConfirmModal.bind(this);\n this.signout = this.signOut.bind(this);\n\n this.state = {\n shouldShowSignoutConfirmModal: false,\n };\n }\n\n componentDidMount() {\n Wallet.openInitialSettingsPage();\n }\n\n /**\n * @param {Boolean} isPaymentItem whether the item being rendered is the payments menu item\n * @returns {Number} the user wallet balance\n */\n getWalletBalance(isPaymentItem) {\n return (isPaymentItem && Permissions.canUseWallet(this.props.betas))\n ? this.props.numberFormat(\n this.props.userWallet.currentBalance / 100, // Divide by 100 because balance is in cents\n {style: 'currency', currency: 'USD'},\n ) : undefined;\n }\n\n /**\n * Retuns a list of default menu items\n * @returns {Array} the default menu items\n */\n getDefaultMenuItems() {\n const policiesAvatars = _.chain(this.props.policies)\n .filter(policy => PolicyUtils.shouldShowPolicy(policy, this.props.network.isOffline))\n .sortBy(policy => policy.name)\n .map(policy => ({\n source: policy.avatar || ReportUtils.getDefaultWorkspaceAvatar(policy.name),\n name: policy.name,\n type: CONST.ICON_TYPE_WORKSPACE,\n }))\n .value();\n\n const policyBrickRoadIndicator = _.chain(this.props.policies)\n .filter(policy => policy && policy.type === CONST.POLICY.TYPE.FREE && policy.role === CONST.POLICY.ROLE.ADMIN)\n .find(policy => PolicyUtils.hasPolicyError(policy) || PolicyUtils.getPolicyBrickRoadIndicatorStatus(policy, this.props.policyMembers))\n .value() ? 'error' : null;\n const profileBrickRoadIndicator = UserUtils.getLoginListBrickRoadIndicator(this.props.loginList);\n\n return ([\n {\n translationKey: 'common.workspaces',\n icon: Expensicons.Building,\n action: () => { Navigation.navigate(ROUTES.SETTINGS_WORKSPACES); },\n floatRightAvatars: policiesAvatars,\n shouldStackHorizontally: true,\n brickRoadIndicator: policyBrickRoadIndicator,\n },\n {\n translationKey: 'common.profile',\n icon: Expensicons.Profile,\n action: () => { App.openProfile(); },\n brickRoadIndicator: profileBrickRoadIndicator,\n },\n {\n translationKey: 'common.preferences',\n icon: Expensicons.Gear,\n action: () => { Navigation.navigate(ROUTES.SETTINGS_PREFERENCES); },\n },\n {\n translationKey: 'initialSettingsPage.security',\n icon: Expensicons.Lock,\n action: () => { Navigation.navigate(ROUTES.SETTINGS_SECURITY); },\n },\n {\n translationKey: 'common.payments',\n icon: Expensicons.Wallet,\n action: () => { Navigation.navigate(ROUTES.SETTINGS_PAYMENTS); },\n brickRoadIndicator: PaymentMethods.hasPaymentMethodError(this.props.bankAccountList, this.props.cardList) || !_.isEmpty(this.props.userWallet.errors)\n || !_.isEmpty(this.props.walletTerms.errors) ? 'error' : null,\n },\n {\n translationKey: 'initialSettingsPage.help',\n icon: Expensicons.QuestionMark,\n action: () => { Link.openExternalLink(CONST.NEWHELP_URL); },\n shouldShowRightIcon: true,\n iconRight: Expensicons.NewWindow,\n link: CONST.NEWHELP_URL,\n },\n {\n translationKey: 'initialSettingsPage.about',\n icon: Expensicons.Info,\n action: () => { Navigation.navigate(ROUTES.SETTINGS_ABOUT); },\n },\n {\n translationKey: 'initialSettingsPage.signOut',\n icon: Expensicons.Exit,\n action: () => { this.signout(false); },\n },\n ]);\n }\n\n getMenuItem(item, index) {\n const keyTitle = item.translationKey ? this.props.translate(item.translationKey) : item.title;\n const isPaymentItem = item.translationKey === 'common.payments';\n\n return (\n ReportActionContextMenu.showContextMenu(CONTEXT_MENU_TYPES.LINK, e, item.link, this.popoverAnchor.current) : undefined}\n />\n );\n }\n\n toggleSignoutConfirmModal(value) {\n this.setState({shouldShowSignoutConfirmModal: value});\n }\n\n signOut(shouldForceSignout = false) {\n if (!this.props.network.isOffline || shouldForceSignout) {\n Session.signOutAndRedirectToSignIn();\n return;\n }\n\n // When offline, warn the user that any actions they took while offline will be lost if they sign out\n this.toggleSignoutConfirmModal(true);\n }\n\n openProfileSettings() {\n Navigation.navigate(ROUTES.SETTINGS_PROFILE);\n }\n\n render() {\n // On the very first sign in or after clearing storage these\n // details will not be present on the first render so we'll just\n // return nothing for now.\n if (_.isEmpty(this.props.currentUserPersonalDetails)) {\n return null;\n }\n\n return (\n \n {({safeAreaPaddingBottomStyle}) => (\n <>\n Navigation.dismissModal(true)}\n />\n \n \n \n \n \n \n \n \n \n \n\n \n \n \n {this.props.currentUserPersonalDetails.displayName\n ? this.props.currentUserPersonalDetails.displayName\n : Str.removeSMSDomain(this.props.session.email)}\n \n \n \n {Boolean(this.props.currentUserPersonalDetails.displayName) && (\n \n {Str.removeSMSDomain(this.props.session.email)}\n \n )}\n \n {_.map(this.getDefaultMenuItems(), (item, index) => this.getMenuItem(item, index))}\n\n this.signOut(true)}\n onCancel={() => this.toggleSignoutConfirmModal(false)}\n />\n \n \n \n )}\n \n );\n }\n}\n\nInitialSettingsPage.propTypes = propTypes;\nInitialSettingsPage.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withCurrentUserPersonalDetails,\n withOnyx({\n session: {\n key: ONYXKEYS.SESSION,\n },\n policies: {\n key: ONYXKEYS.COLLECTION.POLICY,\n },\n policyMembers: {\n key: ONYXKEYS.COLLECTION.POLICY_MEMBER_LIST,\n },\n userWallet: {\n key: ONYXKEYS.USER_WALLET,\n },\n betas: {\n key: ONYXKEYS.BETAS,\n },\n bankAccountList: {\n key: ONYXKEYS.BANK_ACCOUNT_LIST,\n },\n cardList: {\n key: ONYXKEYS.CARD_LIST,\n },\n walletTerms: {\n key: ONYXKEYS.WALLET_TERMS,\n },\n loginList: {\n key: ONYXKEYS.LOGIN_LIST,\n },\n }),\n withNetwork(),\n)(InitialSettingsPage);\n","import moment from 'moment-timezone';\nimport {AppState} from 'react-native';\nimport Onyx from 'react-native-onyx';\nimport lodashGet from 'lodash/get';\nimport Str from 'expensify-common/lib/str';\nimport _ from 'underscore';\nimport * as API from '../API';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport CONST from '../../CONST';\nimport Log from '../Log';\nimport Performance from '../Performance';\nimport * as Policy from './Policy';\nimport Navigation from '../Navigation/Navigation';\nimport ROUTES from '../../ROUTES';\nimport * as SessionUtils from '../SessionUtils';\nimport getCurrentUrl from '../Navigation/currentUrl';\nimport * as Session from './Session';\n\nlet currentUserAccountID;\nlet currentUserEmail = '';\nOnyx.connect({\n key: ONYXKEYS.SESSION,\n callback: (val) => {\n currentUserAccountID = lodashGet(val, 'accountID', '');\n currentUserEmail = lodashGet(val, 'email', '');\n },\n});\n\nlet isSidebarLoaded;\nOnyx.connect({\n key: ONYXKEYS.IS_SIDEBAR_LOADED,\n callback: val => isSidebarLoaded = val,\n initWithStoredValues: false,\n});\n\nlet myPersonalDetails;\nOnyx.connect({\n key: ONYXKEYS.PERSONAL_DETAILS,\n callback: (val) => {\n if (!val || !currentUserEmail) {\n return;\n }\n\n myPersonalDetails = val[currentUserEmail];\n },\n});\n\nlet allPolicies = [];\nOnyx.connect({\n key: ONYXKEYS.COLLECTION.POLICY,\n waitForCollectionCallback: true,\n callback: policies => allPolicies = policies,\n});\n\nlet preferredLocale;\nOnyx.connect({\n key: ONYXKEYS.NVP_PREFERRED_LOCALE,\n callback: val => preferredLocale = val,\n});\n\n/**\n * @param {Array} policies\n * @return {Array} array of policy ids\n*/\nfunction getNonOptimisticPolicyIDs(policies) {\n return _.chain(policies)\n .reject(policy => lodashGet(policy, 'pendingAction', null) === CONST.RED_BRICK_ROAD_PENDING_ACTION.ADD)\n .pluck('id')\n .compact()\n .value();\n}\n\n/**\n* @param {String} locale\n*/\nfunction setLocale(locale) {\n if (locale === preferredLocale) {\n return;\n }\n\n // If user is not signed in, change just locally.\n if (!currentUserAccountID) {\n Onyx.merge(ONYXKEYS.NVP_PREFERRED_LOCALE, locale);\n return;\n }\n\n // Optimistically change preferred locale\n const optimisticData = [\n {\n onyxMethod: CONST.ONYX.METHOD.MERGE,\n key: ONYXKEYS.NVP_PREFERRED_LOCALE,\n value: locale,\n },\n ];\n\n API.write('UpdatePreferredLocale', {\n value: locale,\n }, {optimisticData});\n}\n\n/**\n* @param {String} locale\n*/\nfunction setLocaleAndNavigate(locale) {\n setLocale(locale);\n Navigation.navigate(ROUTES.SETTINGS_PREFERENCES);\n}\n\nfunction setSidebarLoaded() {\n if (isSidebarLoaded) {\n return;\n }\n\n Onyx.set(ONYXKEYS.IS_SIDEBAR_LOADED, true);\n Performance.markEnd(CONST.TIMING.SIDEBAR_LOADED);\n Performance.markStart(CONST.TIMING.REPORT_INITIAL_RENDER);\n}\n\nlet appState;\nAppState.addEventListener('change', (nextAppState) => {\n if (nextAppState.match(/inactive|background/) && appState === 'active') {\n Log.info('Flushing logs as app is going inactive', true, {}, true);\n }\n appState = nextAppState;\n});\n\n/**\n * Fetches data needed for app initialization\n */\nfunction openApp() {\n // We need a fresh connection/callback here to make sure that the list of policyIDs that is sent to OpenApp is the most updated list from Onyx\n const connectionID = Onyx.connect({\n key: ONYXKEYS.COLLECTION.POLICY,\n waitForCollectionCallback: true,\n callback: (policies) => {\n Onyx.disconnect(connectionID);\n API.read('OpenApp', {policyIDList: getNonOptimisticPolicyIDs(policies)}, {\n optimisticData: [\n {\n onyxMethod: CONST.ONYX.METHOD.MERGE,\n key: ONYXKEYS.IS_LOADING_REPORT_DATA,\n value: true,\n },\n ],\n successData: [\n {\n onyxMethod: CONST.ONYX.METHOD.MERGE,\n key: ONYXKEYS.IS_LOADING_REPORT_DATA,\n value: false,\n },\n ],\n failureData: [\n {\n onyxMethod: CONST.ONYX.METHOD.MERGE,\n key: ONYXKEYS.IS_LOADING_REPORT_DATA,\n value: false,\n },\n ],\n });\n },\n });\n}\n\n/**\n * Refreshes data when the app reconnects\n */\nfunction reconnectApp() {\n API.write(CONST.NETWORK.COMMAND.RECONNECT_APP, {policyIDList: getNonOptimisticPolicyIDs(allPolicies)}, {\n optimisticData: [{\n onyxMethod: CONST.ONYX.METHOD.MERGE,\n key: ONYXKEYS.IS_LOADING_REPORT_DATA,\n value: true,\n }],\n successData: [{\n onyxMethod: CONST.ONYX.METHOD.MERGE,\n key: ONYXKEYS.IS_LOADING_REPORT_DATA,\n value: false,\n }],\n failureData: [{\n onyxMethod: CONST.ONYX.METHOD.MERGE,\n key: ONYXKEYS.IS_LOADING_REPORT_DATA,\n value: false,\n }],\n });\n}\n\n/**\n * This action runs when the Navigator is ready and the current route changes\n *\n * currentPath should be the path as reported by the NavigationContainer\n *\n * The transition link contains an exitTo param that contains the route to\n * navigate to after the user is signed in. A user can transition from OldDot\n * with a different account than the one they are currently signed in with, so\n * we only navigate if they are not signing in as a new user. Once they are\n * signed in as that new user, this action will run again and the navigation\n * will occur.\n\n * When the exitTo route is 'workspace/new', we create a new\n * workspace and navigate to it\n *\n * We subscribe to the session using withOnyx in the AuthScreens and\n * pass it in as a parameter. withOnyx guarantees that the value has been read\n * from Onyx because it will not render the AuthScreens until that point.\n * @param {Object} session\n */\nfunction setUpPoliciesAndNavigate(session) {\n const currentUrl = getCurrentUrl();\n if (!session || !currentUrl || !currentUrl.includes('exitTo')) {\n return;\n }\n\n const isLoggingInAsNewUser = SessionUtils.isLoggingInAsNewUser(currentUrl, session.email);\n const url = new URL(currentUrl);\n const exitTo = url.searchParams.get('exitTo');\n\n // Approved Accountants and Guides can enter a flow where they make a workspace for other users,\n // and those are passed as a search parameter when using transition links\n const ownerEmail = url.searchParams.get('ownerEmail');\n const makeMeAdmin = url.searchParams.get('makeMeAdmin');\n const policyName = url.searchParams.get('policyName');\n\n // Sign out the current user if we're transitioning from oldDot with a different user\n const isTransitioningFromOldDot = Str.startsWith(url.pathname, Str.normalizeUrl(ROUTES.TRANSITION_FROM_OLD_DOT));\n if (isLoggingInAsNewUser && isTransitioningFromOldDot) {\n Session.signOut();\n }\n\n const shouldCreateFreePolicy = !isLoggingInAsNewUser\n && isTransitioningFromOldDot\n && exitTo === ROUTES.WORKSPACE_NEW;\n if (shouldCreateFreePolicy) {\n Policy.createWorkspace(ownerEmail, makeMeAdmin, policyName, true);\n return;\n }\n if (!isLoggingInAsNewUser && exitTo) {\n Navigation.isNavigationReady()\n .then(() => {\n // The drawer navigation is only created after we have fetched reports from the server.\n // Thus, if we use the standard navigation and try to navigate to a drawer route before\n // the reports have been fetched, we will fail to navigate.\n Navigation.isDrawerReady()\n .then(() => {\n // We must call dismissModal() to remove the /transition route from history\n Navigation.dismissModal();\n Navigation.navigate(exitTo);\n });\n });\n }\n}\n\nfunction openProfile() {\n const oldTimezoneData = myPersonalDetails.timezone || {};\n let newTimezoneData = oldTimezoneData;\n\n if (lodashGet(oldTimezoneData, 'automatic', true)) {\n newTimezoneData = {\n automatic: true,\n selected: moment.tz.guess(true),\n };\n }\n\n API.write('OpenProfile', {\n timezone: JSON.stringify(newTimezoneData),\n }, {\n optimisticData: [{\n onyxMethod: CONST.ONYX.METHOD.MERGE,\n key: ONYXKEYS.PERSONAL_DETAILS,\n value: {\n [currentUserEmail]: {\n timezone: newTimezoneData,\n },\n },\n }],\n failureData: [{\n onyxMethod: CONST.ONYX.METHOD.MERGE,\n key: ONYXKEYS.PERSONAL_DETAILS,\n value: {\n [currentUserEmail]: {\n timezone: oldTimezoneData,\n },\n },\n }],\n });\n\n Navigation.navigate(ROUTES.SETTINGS_PROFILE);\n}\n\nexport {\n setLocale,\n setLocaleAndNavigate,\n setSidebarLoaded,\n setUpPoliciesAndNavigate,\n openProfile,\n openApp,\n reconnectApp,\n};\n","import lodashGet from 'lodash/get';\n\n/**\n * Determine if the transitioning user is logging in as a new user.\n *\n * @param {String} transitionURL\n * @param {String} sessionEmail\n * @returns {Boolean}\n */\nfunction isLoggingInAsNewUser(transitionURL, sessionEmail) {\n // The OldDot mobile app does not URL encode the parameters, but OldDot web\n // does. We don't want to deploy OldDot mobile again, so as a work around we\n // compare the session email to both the decoded and raw email from the transition link.\n const params = new URLSearchParams(transitionURL);\n const paramsEmail = params.get('email');\n\n // If the email param matches what is stored in the session then we are\n // definitely not logging in as a new user\n if (paramsEmail === sessionEmail) {\n return false;\n }\n\n // If they do not match it might be due to encoding, so check the raw value\n // Capture the un-encoded text in the email param\n const emailParamRegex = /[?&]email=([^&]*)/g;\n const matches = emailParamRegex.exec(transitionURL);\n const linkedEmail = lodashGet(matches, 1, null);\n return linkedEmail !== sessionEmail;\n}\n\nexport {\n // eslint-disable-next-line import/prefer-default-export\n isLoggingInAsNewUser,\n};\n","import _ from 'underscore';\nimport lodashGet from 'lodash/get';\nimport Str from 'expensify-common/lib/str';\nimport CONST from '../CONST';\nimport ONYXKEYS from '../ONYXKEYS';\n\n/**\n * Checks if we have any errors stored within the POLICY_MEMBER_LIST. Determines whether we should show a red brick road error or not.\n * Data structure: {email: {role:'user', errors: []}, email2: {role:'admin', errors: [{1231312313: 'Unable to do X'}]}, ...}\n *\n * @param {Object} policyMemberList\n * @returns {Boolean}\n */\nfunction hasPolicyMemberError(policyMemberList) {\n return _.some(policyMemberList, member => !_.isEmpty(member.errors));\n}\n\n/**\n * Check if the policy has any errors, and if it doesn't, then check if it has any error fields.\n *\n * @param {Object} policy\n * @param {Object} policy.errors\n * @param {Object} policy.errorFields\n * @return {Boolean}\n */\nfunction hasPolicyError(policy) {\n return !_.isEmpty(lodashGet(policy, 'errors', {}))\n ? true\n : _.some(lodashGet(policy, 'errorFields', {}), fieldErrors => !_.isEmpty(fieldErrors));\n}\n\n/**\n * Checks if we have any errors stored within the policy custom units.\n *\n * @param {Object} policy\n * @returns {Boolean}\n */\nfunction hasCustomUnitsError(policy) {\n return !_.isEmpty(_.pick(lodashGet(policy, 'customUnits', {}), 'errors'));\n}\n\n/**\n * Get the brick road indicator status for a policy. The policy has an error status if there is a policy member error or a policy error.\n *\n * @param {Object} policy\n * @param {String} policy.id\n * @param {Object} policyMembers\n * @returns {String}\n */\nfunction getPolicyBrickRoadIndicatorStatus(policy, policyMembers) {\n const policyMemberList = lodashGet(policyMembers, `${ONYXKEYS.COLLECTION.POLICY_MEMBER_LIST}${policy.id}`, {});\n if (hasPolicyMemberError(policyMemberList) || hasCustomUnitsError(policy)) {\n return CONST.BRICK_ROAD_INDICATOR_STATUS.ERROR;\n }\n return '';\n}\n\n/**\n * Check if the policy can be displayed\n * If offline, always show the policy pending deletion.\n * If online, show the policy pending deletion only if there is an error.\n * Note: Using a local ONYXKEYS.NETWORK subscription will cause a delay in\n * updating the screen. Passing the offline status from the component.\n * @param {Object} policy\n * @param {Boolean} isOffline\n * @returns {Boolean}\n */\nfunction shouldShowPolicy(policy, isOffline) {\n return policy\n && policy.type === CONST.POLICY.TYPE.FREE\n && policy.role === CONST.POLICY.ROLE.ADMIN\n && (\n isOffline\n || policy.pendingAction !== CONST.RED_BRICK_ROAD_PENDING_ACTION.DELETE\n || !_.isEmpty(policy.errors)\n );\n}\n\n/**\n * @param {string} email\n * @returns {boolean}\n */\nfunction isExpensifyTeam(email) {\n const emailDomain = Str.extractEmailDomain(email);\n return emailDomain === CONST.EXPENSIFY_PARTNER_NAME || emailDomain === CONST.EMAIL.GUIDES_DOMAIN;\n}\n\nexport {\n hasPolicyMemberError,\n hasPolicyError,\n hasCustomUnitsError,\n getPolicyBrickRoadIndicatorStatus,\n shouldShowPolicy,\n isExpensifyTeam,\n};\n","import _ from 'underscore';\nimport lodashGet from 'lodash/get';\nimport CONST from '../CONST';\n\n/**\n * Searches through given loginList for any contact method / login with an error.\n *\n * Example that should return false:\n * {{\n * test@test.com: {\n * errorFields: {\n * validateCodeSent: null\n * }\n * }\n * }}\n *\n * Example that should return true:\n * {{\n * test@test.com: {\n * errorFields: {\n * validateCodeSent: { 18092081290: 'An error' }\n * }\n * }\n * }}\n *\n * @param {Object} loginList\n * @param {Object} loginList.errorFields\n * @returns {Boolean}\n */\nfunction hasLoginListError(loginList) {\n return _.some(loginList, login => _.some(lodashGet(login, 'errorFields', {}), field => !_.isEmpty(field)));\n}\n\n/**\n * Searches through given loginList for any contact method / login that requires\n * an Info brick road status indicator. Currently this only applies if the user\n * has an unvalidated contact method.\n *\n * @param {Object} loginList\n * @param {String} loginList.validatedDate\n * @returns {Boolean}\n */\nfunction hasLoginListInfo(loginList) {\n return _.some(loginList, login => _.isEmpty(login.validatedDate));\n}\n\n/**\n * Gets the appropriate brick road indicator status for a given loginList.\n * Error status is higher priority, so we check for that first.\n *\n * @param {Object} loginList\n * @returns {String}\n */\nfunction getLoginListBrickRoadIndicator(loginList) {\n if (hasLoginListError(loginList)) {\n return CONST.BRICK_ROAD_INDICATOR_STATUS.ERROR;\n }\n if (hasLoginListInfo(loginList)) {\n return CONST.BRICK_ROAD_INDICATOR_STATUS.INFO;\n }\n return '';\n}\n\nexport {\n hasLoginListError,\n hasLoginListInfo,\n getLoginListBrickRoadIndicator,\n};\n","import PropTypes from 'prop-types';\n\nexport default PropTypes.shape({\n /** Role of the user in the policy */\n role: PropTypes.string,\n\n /**\n * Errors from api calls on the specific user\n * {: 'error message', : 'error message 2'}\n */\n errors: PropTypes.objectOf(PropTypes.string),\n\n /** Is this action pending? */\n pendingAction: PropTypes.string,\n});\n","import React, {Component} from 'react';\nimport {ScrollView} from 'react-native';\nimport {withOnyx} from 'react-native-onyx';\nimport PropTypes from 'prop-types';\nimport _ from 'underscore';\nimport HeaderWithCloseButton from '../../components/HeaderWithCloseButton';\nimport Navigation from '../../libs/Navigation/Navigation';\nimport ScreenWrapper from '../../components/ScreenWrapper';\nimport ROUTES from '../../ROUTES';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport CONST from '../../CONST';\nimport styles from '../../styles/styles';\nimport compose from '../../libs/compose';\nimport OfflineWithFeedback from '../../components/OfflineWithFeedback';\nimport withLocalize, {withLocalizePropTypes} from '../../components/withLocalize';\nimport * as Expensicons from '../../components/Icon/Expensicons';\nimport themeColors from '../../styles/themes/default';\nimport * as PolicyUtils from '../../libs/PolicyUtils';\nimport MenuItem from '../../components/MenuItem';\nimport * as Policy from '../../libs/actions/Policy';\nimport policyMemberPropType from '../policyMemberPropType';\nimport Permissions from '../../libs/Permissions';\nimport Button from '../../components/Button';\nimport FixedFooter from '../../components/FixedFooter';\nimport BlockingView from '../../components/BlockingViews/BlockingView';\nimport {withNetwork} from '../../components/OnyxProvider';\nimport * as ReportUtils from '../../libs/ReportUtils';\n\nconst propTypes = {\n /* Onyx Props */\n\n /** The list of this user's policies */\n policies: PropTypes.objectOf(PropTypes.shape({\n /** The ID of the policy */\n ID: PropTypes.string,\n\n /** The name of the policy */\n name: PropTypes.string,\n\n /** The type of the policy */\n type: PropTypes.string,\n\n /** The user's role in the policy */\n role: PropTypes.string,\n\n /** The current action that is waiting to happen on the policy */\n pendingAction: PropTypes.oneOf(_.values(CONST.RED_BRICK_ROAD_PENDING_ACTION)),\n })),\n\n /** List of policy members */\n policyMembers: PropTypes.objectOf(policyMemberPropType),\n\n /** The user's wallet account */\n userWallet: PropTypes.shape({\n /** The user's current wallet balance */\n currentBalance: PropTypes.number,\n }),\n\n /** List of betas available to current user */\n betas: PropTypes.arrayOf(PropTypes.string),\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n policies: {},\n policyMembers: {},\n userWallet: {\n currentBalance: 0,\n },\n betas: [],\n};\n\n/**\n * Dismisses the errors on one item\n *\n * @param {string} policyID\n * @param {string} pendingAction\n */\nfunction dismissWorkspaceError(policyID, pendingAction) {\n if (pendingAction === CONST.RED_BRICK_ROAD_PENDING_ACTION.DELETE) {\n Policy.clearDeleteWorkspaceError(policyID);\n return;\n }\n\n if (pendingAction === CONST.RED_BRICK_ROAD_PENDING_ACTION.ADD) {\n Policy.removeWorkspace(policyID);\n return;\n }\n throw new Error('Not implemented');\n}\n\nclass WorkspacesListPage extends Component {\n constructor(props) {\n super(props);\n\n this.getWalletBalance = this.getWalletBalance.bind(this);\n this.getWorkspaces = this.getWorkspaces.bind(this);\n this.getMenuItem = this.getMenuItem.bind(this);\n }\n\n /**\n * @param {Boolean} isPaymentItem whether the item being rendered is the payments menu item\n * @returns {Number} the user wallet balance\n */\n getWalletBalance(isPaymentItem) {\n return (isPaymentItem && Permissions.canUseWallet(this.props.betas))\n ? this.props.numberFormat(\n this.props.userWallet.currentBalance / 100, // Divide by 100 because balance is in cents\n {style: 'currency', currency: 'USD'},\n ) : undefined;\n }\n\n /**\n * Add free policies (workspaces) to the list of menu items and returns the list of menu items\n * @returns {Array} the menu item list\n */\n getWorkspaces() {\n return _.chain(this.props.policies)\n .filter(policy => PolicyUtils.shouldShowPolicy(policy, this.props.network.isOffline))\n .map(policy => ({\n title: policy.name,\n icon: policy.avatar ? policy.avatar : ReportUtils.getDefaultWorkspaceAvatar(policy.name),\n iconType: policy.avatar ? CONST.ICON_TYPE_AVATAR : CONST.ICON_TYPE_ICON,\n action: () => Navigation.navigate(ROUTES.getWorkspaceInitialRoute(policy.id)),\n iconFill: themeColors.textLight,\n fallbackIcon: Expensicons.FallbackWorkspaceAvatar,\n brickRoadIndicator: PolicyUtils.getPolicyBrickRoadIndicatorStatus(policy, this.props.policyMembers),\n pendingAction: policy.pendingAction,\n errors: policy.errors,\n dismissError: () => dismissWorkspaceError(policy.id, policy.pendingAction),\n disabled: policy.pendingAction === CONST.RED_BRICK_ROAD_PENDING_ACTION.DELETE,\n }))\n .sortBy(policy => policy.title)\n .value();\n }\n\n /**\n * Gets the menu item for each workspace\n *\n * @param {Object} item\n * @param {Number} index\n * @returns {JSX}\n */\n getMenuItem(item, index) {\n const keyTitle = item.translationKey ? this.props.translate(item.translationKey) : item.title;\n const isPaymentItem = item.translationKey === 'common.payments';\n\n return (\n \n \n \n );\n }\n\n render() {\n const workspaces = this.getWorkspaces();\n return (\n \n Navigation.navigate(ROUTES.SETTINGS)}\n onCloseButtonPress={() => Navigation.dismissModal(true)}\n />\n {_.isEmpty(workspaces) ? (\n \n ) : (\n \n {_.map(workspaces, (item, index) => this.getMenuItem(item, index))}\n \n )}\n \n Policy.createWorkspace()}\n />\n \n \n );\n }\n}\n\nWorkspacesListPage.propTypes = propTypes;\nWorkspacesListPage.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withNetwork(),\n withOnyx({\n policies: {\n key: ONYXKEYS.COLLECTION.POLICY,\n },\n policyMembers: {\n key: ONYXKEYS.COLLECTION.POLICY_MEMBER_LIST,\n },\n userWallet: {\n key: ONYXKEYS.USER_WALLET,\n },\n betas: {\n key: ONYXKEYS.BETAS,\n },\n }),\n)(WorkspacesListPage);\n","import Str from 'expensify-common/lib/str';\nimport lodashGet from 'lodash/get';\nimport React from 'react';\nimport {View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport {withOnyx} from 'react-native-onyx';\nimport {ScrollView} from 'react-native-gesture-handler';\nimport _ from 'underscore';\nimport AvatarWithImagePicker from '../../../components/AvatarWithImagePicker';\nimport HeaderWithCloseButton from '../../../components/HeaderWithCloseButton';\nimport MenuItem from '../../../components/MenuItem';\nimport MenuItemWithTopDescription from '../../../components/MenuItemWithTopDescription';\nimport OfflineWithFeedback from '../../../components/OfflineWithFeedback';\nimport ScreenWrapper from '../../../components/ScreenWrapper';\nimport withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsDefaultProps, withCurrentUserPersonalDetailsPropTypes} from '../../../components/withCurrentUserPersonalDetails';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport CONST from '../../../CONST';\nimport * as PersonalDetails from '../../../libs/actions/PersonalDetails';\nimport compose from '../../../libs/compose';\nimport Navigation from '../../../libs/Navigation/Navigation';\nimport * as ReportUtils from '../../../libs/ReportUtils';\nimport ROUTES from '../../../ROUTES';\nimport styles from '../../../styles/styles';\nimport * as Expensicons from '../../../components/Icon/Expensicons';\nimport ONYXKEYS from '../../../ONYXKEYS';\nimport * as UserUtils from '../../../libs/UserUtils';\n\nconst propTypes = {\n /* Onyx Props */\n\n /** Login list for the user that is signed in */\n loginList: PropTypes.shape({\n /** Date login was validated, used to show brickroad info status */\n validatedDate: PropTypes.string,\n\n /** Field-specific server side errors keyed by microtime */\n errorFields: PropTypes.objectOf(PropTypes.objectOf(PropTypes.string)),\n }),\n\n ...withLocalizePropTypes,\n ...withCurrentUserPersonalDetailsPropTypes,\n};\n\nconst defaultProps = {\n loginList: {},\n ...withCurrentUserPersonalDetailsDefaultProps,\n};\n\nconst ProfilePage = (props) => {\n const getPronouns = () => {\n let pronounsKey = lodashGet(props.currentUserPersonalDetails, 'pronouns', '');\n if (pronounsKey.startsWith(CONST.PRONOUNS.PREFIX)) {\n pronounsKey = pronounsKey.slice(CONST.PRONOUNS.PREFIX.length);\n }\n return lodashGet(props.translate('pronouns'), pronounsKey, props.translate('profilePage.selectYourPronouns'));\n };\n const currentUserDetails = props.currentUserPersonalDetails || {};\n const contactMethodBrickRoadIndicator = UserUtils.getLoginListBrickRoadIndicator(props.loginList);\n\n const profileSettingsOptions = [\n {\n description: props.translate('displayNamePage.headerTitle'),\n title: lodashGet(currentUserDetails, 'displayName', ''),\n pageRoute: ROUTES.SETTINGS_DISPLAY_NAME,\n },\n {\n description: props.translate('contacts.contactMethod'),\n title: Str.removeSMSDomain(lodashGet(currentUserDetails, 'login', '')),\n pageRoute: ROUTES.SETTINGS_CONTACT_METHODS,\n brickRoadIndicator: contactMethodBrickRoadIndicator,\n },\n {\n description: props.translate('pronounsPage.pronouns'),\n title: getPronouns(),\n pageRoute: ROUTES.SETTINGS_PRONOUNS,\n },\n {\n description: props.translate('timezonePage.timezone'),\n title: `${lodashGet(currentUserDetails, 'timezone.selected', '')}`,\n pageRoute: ROUTES.SETTINGS_TIMEZONE,\n },\n ];\n\n return (\n \n Navigation.navigate(ROUTES.SETTINGS)}\n onCloseButtonPress={() => Navigation.dismissModal(true)}\n />\n \n \n \n \n \n {_.map(profileSettingsOptions, (detail, index) => (\n Navigation.navigate(detail.pageRoute)}\n brickRoadIndicator={detail.brickRoadIndicator}\n />\n ))}\n \n Navigation.navigate(ROUTES.SETTINGS_PERSONAL_DETAILS)}\n shouldShowRightIcon\n />\n \n \n );\n};\n\nProfilePage.propTypes = propTypes;\nProfilePage.defaultProps = defaultProps;\nProfilePage.displayName = 'ProfilePage';\n\nexport default compose(\n withLocalize,\n withCurrentUserPersonalDetails,\n withOnyx({\n loginList: {\n key: ONYXKEYS.LOGIN_LIST,\n },\n }),\n)(ProfilePage);\n","import _ from 'underscore';\nimport React from 'react';\nimport {Pressable, View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport lodashGet from 'lodash/get';\nimport Avatar from './Avatar';\nimport Icon from './Icon';\nimport PopoverMenu from './PopoverMenu';\nimport * as Expensicons from './Icon/Expensicons';\nimport styles from '../styles/styles';\nimport themeColors from '../styles/themes/default';\nimport AttachmentPicker from './AttachmentPicker';\nimport ConfirmModal from './ConfirmModal';\nimport AvatarCropModal from './AvatarCropModal/AvatarCropModal';\nimport withLocalize, {withLocalizePropTypes} from './withLocalize';\nimport variables from '../styles/variables';\nimport CONST from '../CONST';\nimport SpinningIndicatorAnimation from '../styles/animation/SpinningIndicatorAnimation';\nimport Tooltip from './Tooltip';\nimport stylePropTypes from '../styles/stylePropTypes';\nimport * as FileUtils from '../libs/fileDownload/FileUtils';\nimport getImageResolution from '../libs/fileDownload/getImageResolution';\n\nconst propTypes = {\n /** Avatar source to display */\n source: PropTypes.oneOfType([PropTypes.string, PropTypes.func]),\n\n /** Additional style props */\n style: stylePropTypes,\n\n /** Executed once an image has been selected */\n onImageSelected: PropTypes.func,\n\n /** Execute when the user taps \"remove\" */\n onImageRemoved: PropTypes.func,\n\n /** A default avatar component to display when there is no source */\n DefaultAvatar: PropTypes.func,\n\n /** Whether we are using the default avatar */\n isUsingDefaultAvatar: PropTypes.bool,\n\n /** The anchor position of the menu */\n anchorPosition: PropTypes.shape({\n top: PropTypes.number,\n right: PropTypes.number,\n bottom: PropTypes.number,\n left: PropTypes.number,\n }).isRequired,\n\n /** Flag to see if image is being uploaded */\n isUploading: PropTypes.bool,\n\n /** Size of Indicator */\n size: PropTypes.oneOf([CONST.AVATAR_SIZE.LARGE, CONST.AVATAR_SIZE.DEFAULT]),\n\n /** A fallback avatar icon to display when there is an error on loading avatar from remote URL. */\n fallbackIcon: PropTypes.func,\n\n /** Denotes whether it is an avatar or a workspace avatar */\n type: PropTypes.oneOf([CONST.ICON_TYPE_AVATAR, CONST.ICON_TYPE_WORKSPACE]),\n\n /** Image crop vector mask */\n editorMaskImage: PropTypes.func,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n source: '',\n onImageSelected: () => {},\n onImageRemoved: () => {},\n style: [],\n DefaultAvatar: () => {},\n isUsingDefaultAvatar: false,\n isUploading: false,\n size: CONST.AVATAR_SIZE.DEFAULT,\n fallbackIcon: Expensicons.FallbackAvatar,\n type: CONST.ICON_TYPE_AVATAR,\n editorMaskImage: undefined,\n};\n\nclass AvatarWithImagePicker extends React.Component {\n constructor(props) {\n super(props);\n this.animation = new SpinningIndicatorAnimation();\n this.hideErrorModal = this.hideErrorModal.bind(this);\n this.showErrorModal = this.showErrorModal.bind(this);\n this.isValidSize = this.isValidSize.bind(this);\n this.showAvatarCropModal = this.showAvatarCropModal.bind(this);\n this.hideAvatarCropModal = this.hideAvatarCropModal.bind(this);\n this.state = {\n isMenuVisible: false,\n isErrorModalVisible: false,\n errorModalPrompt: '',\n errorModalTitle: '',\n isAvatarCropModalOpen: false,\n imageName: '',\n imageUri: '',\n imageType: '',\n };\n }\n\n componentDidMount() {\n if (!this.props.isUploading) {\n return;\n }\n\n this.animation.start();\n }\n\n componentDidUpdate(prevProps) {\n if (!prevProps.isUploading && this.props.isUploading) {\n this.animation.start();\n } else if (prevProps.isUploading && !this.props.isUploading) {\n this.animation.stop();\n }\n }\n\n componentWillUnmount() {\n this.animation.stop();\n }\n\n /**\n * @param {String} title\n * @param {String} prompt\n */\n showErrorModal(title, prompt) {\n this.setState({isErrorModalVisible: true, errorModalTitle: title, errorModalPrompt: prompt});\n }\n\n hideErrorModal() {\n this.setState({isErrorModalVisible: false});\n }\n\n /**\n * Check if the attachment extension is allowed.\n *\n * @param {Object} image\n * @returns {Boolean}\n */\n isValidExtension(image) {\n const {fileExtension} = FileUtils.splitExtensionFromFileName(lodashGet(image, 'name', ''));\n return _.contains(CONST.AVATAR_ALLOWED_EXTENSIONS, fileExtension.toLowerCase());\n }\n\n /**\n * Check if the attachment size is less than allowed size.\n *\n * @param {Object} image\n * @returns {Boolean}\n */\n isValidSize(image) {\n return image && lodashGet(image, 'size', 0) < CONST.AVATAR_MAX_ATTACHMENT_SIZE;\n }\n\n /**\n * Check if the attachment resolution matches constraints.\n *\n * @param {Object} image\n * @returns {Promise}\n */\n isValidResolution(image) {\n return getImageResolution(image).then(resolution => (\n (resolution.height >= CONST.AVATAR_MIN_HEIGHT_PX && resolution.width >= CONST.AVATAR_MIN_WIDTH_PX)\n && (resolution.height <= CONST.AVATAR_MAX_HEIGHT_PX && resolution.width <= CONST.AVATAR_MAX_WIDTH_PX)\n ));\n }\n\n /**\n * Validates if an image has a valid resolution and opens an avatar crop modal\n *\n * @param {Object} image\n */\n showAvatarCropModal(image) {\n if (!this.isValidExtension(image)) {\n this.showErrorModal(\n this.props.translate('avatarWithImagePicker.imageUploadFailed'),\n this.props.translate('avatarWithImagePicker.notAllowedExtension', {allowedExtensions: CONST.AVATAR_ALLOWED_EXTENSIONS}),\n );\n return;\n }\n if (!this.isValidSize(image)) {\n this.showErrorModal(\n this.props.translate('avatarWithImagePicker.imageUploadFailed'),\n this.props.translate('avatarWithImagePicker.sizeExceeded', {maxUploadSizeInMB: CONST.AVATAR_MAX_ATTACHMENT_SIZE / (1024 * 1024)}),\n );\n return;\n }\n\n this.isValidResolution(image)\n .then((isValidResolution) => {\n if (!isValidResolution) {\n this.showErrorModal(\n this.props.translate('avatarWithImagePicker.imageUploadFailed'),\n this.props.translate('avatarWithImagePicker.resolutionConstraints', {\n minHeightInPx: CONST.AVATAR_MIN_HEIGHT_PX,\n minWidthInPx: CONST.AVATAR_MIN_WIDTH_PX,\n maxHeightInPx: CONST.AVATAR_MAX_HEIGHT_PX,\n maxWidthInPx: CONST.AVATAR_MAX_WIDTH_PX,\n }),\n );\n return;\n }\n\n this.setState({\n isAvatarCropModalOpen: true,\n imageUri: image.uri,\n imageName: image.name,\n imageType: image.type,\n });\n });\n }\n\n hideAvatarCropModal() {\n this.setState({isAvatarCropModalOpen: false});\n }\n\n /**\n * Create menu items list for avatar menu\n *\n * @param {Function} openPicker\n * @returns {Array}\n */\n createMenuItems(openPicker) {\n const menuItems = [\n {\n icon: Expensicons.Upload,\n text: this.props.translate('avatarWithImagePicker.uploadPhoto'),\n onSelected: () => {\n openPicker({\n onPicked: this.showAvatarCropModal,\n });\n },\n },\n ];\n\n // If current avatar isn't a default avatar, allow Remove Photo option\n if (!this.props.isUsingDefaultAvatar) {\n menuItems.push({\n icon: Expensicons.Trashcan,\n text: this.props.translate('avatarWithImagePicker.removePhoto'),\n onSelected: () => {\n this.props.onImageRemoved();\n },\n });\n }\n return menuItems;\n }\n\n render() {\n const DefaultAvatar = this.props.DefaultAvatar;\n const additionalStyles = _.isArray(this.props.style) ? this.props.style : [this.props.style];\n\n return (\n \n this.setState({isMenuVisible: true})}\n >\n \n \n {this.props.source\n ? (\n \n )\n : (\n \n )}\n \n \n {({openPicker}) => (\n <>\n \n \n \n \n \n this.setState({isMenuVisible: false})}\n onItemSelected={() => this.setState({isMenuVisible: false})}\n menuItems={this.createMenuItems(openPicker)}\n anchorPosition={this.props.anchorPosition}\n />\n \n )}\n \n \n \n \n \n \n );\n }\n}\n\nAvatarWithImagePicker.propTypes = propTypes;\nAvatarWithImagePicker.defaultProps = defaultProps;\n\nexport default withLocalize(AvatarWithImagePicker);\n","/**\n * The react native image/document pickers work for iOS/Android, but we want to wrap them both within AttachmentPicker\n */\nimport _ from 'underscore';\nimport React, {Component} from 'react';\nimport {Alert, Linking, View} from 'react-native';\nimport {launchImageLibrary} from 'react-native-image-picker';\nimport RNDocumentPicker from 'react-native-document-picker';\nimport RNFetchBlob from 'react-native-blob-util';\nimport {propTypes as basePropTypes, defaultProps} from './attachmentPickerPropTypes';\nimport styles from '../../styles/styles';\nimport Popover from '../Popover';\nimport MenuItem from '../MenuItem';\nimport * as Expensicons from '../Icon/Expensicons';\nimport withWindowDimensions, {windowDimensionsPropTypes} from '../withWindowDimensions';\nimport withLocalize, {withLocalizePropTypes} from '../withLocalize';\nimport compose from '../../libs/compose';\nimport launchCamera from './launchCamera';\nimport CONST from '../../CONST';\nimport * as FileUtils from '../../libs/fileDownload/FileUtils';\n\nconst propTypes = {\n ...basePropTypes,\n ...windowDimensionsPropTypes,\n ...withLocalizePropTypes,\n};\n\n/**\n * See https://github.com/react-native-image-picker/react-native-image-picker/#options\n * for ImagePicker configuration options\n */\nconst imagePickerOptions = {\n includeBase64: false,\n saveToPhotos: false,\n selectionLimit: 1,\n includeExtra: false,\n};\n\n/**\n * Return imagePickerOptions based on the type\n * @param {String} type\n * @returns {Object}\n */\nfunction getImagePickerOptions(type) {\n // mediaType property is one of the ImagePicker configuration to restrict types'\n const mediaType = type === CONST.ATTACHMENT_PICKER_TYPE.IMAGE ? 'photo' : 'mixed';\n return {\n mediaType,\n ...imagePickerOptions,\n };\n}\n\n/**\n * See https://github.com/rnmods/react-native-document-picker#options for DocumentPicker configuration options\n */\nconst documentPickerOptions = {\n type: [RNDocumentPicker.types.allFiles],\n copyTo: 'cachesDirectory',\n};\n\n/**\n * The data returned from `show` is different on web and mobile, so use this function to ensure the data we\n * send to the xhr will be handled properly.\n *\n * @param {Object} fileData\n * @return {Promise}\n */\nfunction getDataForUpload(fileData) {\n const fileName = fileData.fileName || fileData.name || 'chat_attachment';\n const fileResult = {\n name: FileUtils.cleanFileName(fileName),\n type: fileData.type,\n width: fileData.width,\n height: fileData.height,\n uri: fileData.fileCopyUri || fileData.uri,\n size: fileData.fileSize || fileData.size,\n };\n\n if (fileResult.size) {\n return Promise.resolve(fileResult);\n }\n\n return RNFetchBlob.fs.stat(fileData.uri.replace('file://', '')).then((stats) => {\n fileResult.size = stats.size;\n return fileResult;\n });\n}\n\n/**\n * This component renders a function as a child and\n * returns a \"show attachment picker\" method that takes\n * a callback. This is the ios/android implementation\n * opening a modal with attachment options\n */\nclass AttachmentPicker extends Component {\n constructor(...args) {\n super(...args);\n\n this.state = {\n isVisible: false,\n };\n\n this.menuItemData = [\n {\n icon: Expensicons.Camera,\n textTranslationKey: 'attachmentPicker.takePhoto',\n pickAttachment: () => this.showImagePicker(launchCamera),\n },\n {\n icon: Expensicons.Gallery,\n textTranslationKey: 'attachmentPicker.chooseFromGallery',\n pickAttachment: () => this.showImagePicker(launchImageLibrary),\n },\n ];\n\n // When selecting an image on a native device, it would be redundant to have a second option for choosing a document,\n // so it is excluded in this case.\n if (this.props.type !== CONST.ATTACHMENT_PICKER_TYPE.IMAGE) {\n this.menuItemData.push(\n {\n icon: Expensicons.Paperclip,\n textTranslationKey: 'attachmentPicker.chooseDocument',\n pickAttachment: () => this.showDocumentPicker(),\n },\n );\n }\n\n this.close = this.close.bind(this);\n this.pickAttachment = this.pickAttachment.bind(this);\n }\n\n /**\n * Handles the image/document picker result and\n * sends the selected attachment to the caller (parent component)\n *\n * @param {Array} attachments\n * @returns {Promise}\n */\n pickAttachment(attachments = []) {\n if (attachments.length === 0) {\n return;\n }\n\n const fileData = _.first(attachments);\n\n if (fileData.width === -1 || fileData.height === -1) {\n this.showImageCorruptionAlert();\n return;\n }\n\n return getDataForUpload(fileData).then((result) => {\n this.completeAttachmentSelection(result);\n }).catch((error) => {\n this.showGeneralAlert(error.message);\n throw error;\n });\n }\n\n /**\n * Inform the users when they need to grant camera access and guide them to settings\n */\n showPermissionsAlert() {\n Alert.alert(\n this.props.translate('attachmentPicker.cameraPermissionRequired'),\n this.props.translate('attachmentPicker.expensifyDoesntHaveAccessToCamera'),\n [\n {\n text: this.props.translate('common.cancel'),\n style: 'cancel',\n },\n {\n text: this.props.translate('common.settings'),\n onPress: () => Linking.openSettings(),\n },\n ],\n {cancelable: false},\n );\n }\n\n /**\n * Common image picker handling\n *\n * @param {function} imagePickerFunc - RNImagePicker.launchCamera or RNImagePicker.launchImageLibrary\n * @returns {Promise}\n */\n showImagePicker(imagePickerFunc) {\n return new Promise((resolve, reject) => {\n imagePickerFunc(getImagePickerOptions(this.props.type), (response) => {\n if (response.didCancel) {\n // When the user cancelled resolve with no attachment\n return resolve();\n }\n if (response.errorCode) {\n switch (response.errorCode) {\n case 'permission':\n this.showPermissionsAlert();\n break;\n default:\n this.showGeneralAlert();\n break;\n }\n\n return reject(new Error(`Error during attachment selection: ${response.errorMessage}`));\n }\n\n return resolve(response.assets);\n });\n });\n }\n\n /**\n * A generic handling when we don't know the exact reason for an error\n *\n */\n showGeneralAlert() {\n Alert.alert(\n this.props.translate('attachmentPicker.attachmentError'),\n this.props.translate('attachmentPicker.errorWhileSelectingAttachment'),\n );\n }\n\n /**\n * An attachment error dialog when user selected malformed images\n */\n showImageCorruptionAlert() {\n Alert.alert(\n this.props.translate('attachmentPicker.attachmentError'),\n this.props.translate('attachmentPicker.errorWhileSelectingCorruptedImage'),\n );\n }\n\n /**\n * Launch the DocumentPicker. Results are in the same format as ImagePicker\n *\n * @returns {Promise}\n */\n showDocumentPicker() {\n return RNDocumentPicker.pick(documentPickerOptions).catch((error) => {\n if (RNDocumentPicker.isCancel(error)) {\n return;\n }\n\n this.showGeneralAlert(error.message);\n throw error;\n });\n }\n\n /**\n * Triggers the `onPicked` callback with the selected attachment\n */\n completeAttachmentSelection() {\n if (!this.state.result) {\n return;\n }\n\n this.state.onPicked(this.state.result);\n }\n\n /**\n * Opens the attachment modal\n *\n * @param {function} onPicked A callback that will be called with the selected attachment\n */\n open(onPicked) {\n this.completeAttachmentSelection = onPicked;\n this.setState({isVisible: true});\n }\n\n /**\n * Closes the attachment modal\n */\n close() {\n this.setState({isVisible: false});\n }\n\n /**\n * Setup native attachment selection to start after this popover closes\n *\n * @param {{pickAttachment: function}} item - an item from this.menuItemData\n */\n selectItem(item) {\n /* setTimeout delays execution to the frame after the modal closes\n * without this on iOS closing the modal closes the gallery/camera as well */\n this.onModalHide = () => setTimeout(\n () => item.pickAttachment()\n .then(this.pickAttachment)\n .catch(console.error)\n .finally(() => delete this.onModalHide),\n 200,\n );\n\n this.close();\n }\n\n /**\n * Call the `children` renderProp with the interface defined in propTypes\n *\n * @returns {React.ReactNode}\n */\n renderChildren() {\n return this.props.children({\n openPicker: ({onPicked}) => this.open(onPicked),\n });\n }\n\n render() {\n return (\n <>\n \n \n {\n _.map(this.menuItemData, item => (\n this.selectItem(item)}\n />\n ))\n }\n \n \n {this.renderChildren()}\n \n );\n }\n}\n\nAttachmentPicker.propTypes = propTypes;\nAttachmentPicker.defaultProps = defaultProps;\n\nexport default compose(\n withWindowDimensions,\n withLocalize,\n)(AttachmentPicker);\n","import { Platform, NativeModules, ModalPropsIOS } from 'react-native'\nimport invariant from 'invariant'\nimport type { PlatformTypes, SupportedPlatforms } from './fileTypes'\nimport { perPlatformTypes } from './fileTypes'\n\nexport type DocumentPickerResponse = {\n uri: string\n name: string\n copyError?: string\n fileCopyUri: string | null\n type: string | null\n size: number | null\n}\n\nexport const types = perPlatformTypes[Platform.OS]\n\nexport type DirectoryPickerResponse = {\n uri: string\n}\n\ntype DocumentPickerType = {\n pick(options: Record): Promise\n releaseSecureAccess(uris: string[]): Promise\n pickDirectory(): Promise\n}\n\nconst RNDocumentPicker: DocumentPickerType = NativeModules.RNDocumentPicker\n\nexport type TransitionStyle = 'coverVertical' | 'flipHorizontal' | 'crossDissolve' | 'partialCurl'\n\nexport type DocumentPickerOptions = {\n type?:\n | string\n | PlatformTypes[OS][keyof PlatformTypes[OS]]\n | Array\n mode?: 'import' | 'open'\n copyTo?: 'cachesDirectory' | 'documentDirectory'\n allowMultiSelection?: boolean\n transitionStyle?: TransitionStyle\n} & Pick\n\nexport async function pickDirectory(\n params?: Pick, 'presentationStyle' | 'transitionStyle'>,\n): Promise {\n if (Platform.OS === 'ios') {\n const result = await pick({\n ...params,\n mode: 'open',\n allowMultiSelection: false,\n type: ['public.folder'],\n })\n return { uri: result[0].uri }\n } else {\n return RNDocumentPicker.pickDirectory()\n }\n}\n\nexport function pickMultiple(\n opts?: DocumentPickerOptions,\n): Promise {\n const options = {\n ...opts,\n allowMultiSelection: true,\n }\n return pick(options)\n}\nexport function pickSingle(\n opts?: DocumentPickerOptions,\n): Promise {\n const options = {\n ...opts,\n allowMultiSelection: false,\n }\n return pick(options).then((results) => results[0])\n}\n\nexport function pick(\n opts?: DocumentPickerOptions,\n): Promise {\n const options = {\n // must be false to maintain old (v5) behavior\n allowMultiSelection: false,\n type: [types.allFiles],\n ...opts,\n }\n\n const newOpts: DoPickParams = {\n presentationStyle: 'formSheet',\n transitionStyle: 'coverVertical',\n ...options,\n type: Array.isArray(options.type) ? options.type : [options.type],\n }\n\n return doPick(newOpts)\n}\n\ntype DoPickParams = DocumentPickerOptions & {\n type: Array\n allowMultiSelection: boolean\n presentationStyle: NonNullable\n transitionStyle: TransitionStyle\n}\n\nfunction doPick(\n options: DoPickParams,\n): Promise {\n invariant(\n !('filetype' in options),\n 'A `filetype` option was passed to DocumentPicker.pick, the correct option is `type`',\n )\n invariant(\n !('types' in options),\n 'A `types` option was passed to DocumentPicker.pick, the correct option is `type`',\n )\n\n invariant(\n options.type.every((type: unknown) => typeof type === 'string'),\n `Unexpected type option in ${options.type}, did you try using a DocumentPicker.types.* that does not exist?`,\n )\n invariant(\n options.type.length > 0,\n '`type` option should not be an empty array, at least one type must be passed if the `type` option is not omitted',\n )\n\n invariant(\n // @ts-ignore TS2345: Argument of type 'string' is not assignable to parameter of type 'PlatformTypes[OS][keyof PlatformTypes[OS]]'.\n !options.type.includes('folder'),\n 'RN document picker: \"folder\" option was removed, use \"pickDirectory()\"',\n )\n\n if ('mode' in options && !['import', 'open'].includes(options.mode ?? '')) {\n throw new TypeError('Invalid mode option: ' + options.mode)\n }\n\n if (\n 'copyTo' in options &&\n !['cachesDirectory', 'documentDirectory'].includes(options.copyTo ?? '')\n ) {\n throw new TypeError('Invalid copyTo option: ' + options.copyTo)\n }\n\n return RNDocumentPicker.pick(options)\n}\n\nexport function releaseSecureAccess(uris: Array): Promise {\n if (Platform.OS !== 'ios') {\n return Promise.resolve()\n }\n\n invariant(\n Array.isArray(uris) && uris.every((uri) => typeof uri === 'string'),\n `\"uris\" should be an array of strings, was ${uris}`,\n )\n\n return RNDocumentPicker.releaseSecureAccess(uris)\n}\n\nconst E_DOCUMENT_PICKER_CANCELED = 'DOCUMENT_PICKER_CANCELED'\nconst E_DOCUMENT_PICKER_IN_PROGRESS = 'ASYNC_OP_IN_PROGRESS'\n\nexport type NativeModuleErrorShape = Error & { code?: string }\n\nexport function isCancel(err: unknown): boolean {\n return isErrorWithCode(err, E_DOCUMENT_PICKER_CANCELED)\n}\n\nexport function isInProgress(err: unknown): boolean {\n return isErrorWithCode(err, E_DOCUMENT_PICKER_IN_PROGRESS)\n}\n\nfunction isErrorWithCode(err: unknown, errorCode: string): boolean {\n if (err instanceof Error && 'code' in err) {\n const nativeModuleErrorInstance = err as NativeModuleErrorShape\n return nativeModuleErrorInstance?.code === errorCode\n }\n return false\n}\n\nexport default {\n isCancel,\n releaseSecureAccess,\n pickDirectory,\n pick,\n pickMultiple,\n pickSingle,\n types,\n perPlatformTypes,\n}\n","const mimeTypes = Object.freeze({\n allFiles: '*/*',\n audio: 'audio/*',\n csv: 'text/csv',\n doc: 'application/msword',\n docx: 'application/vnd.openxmlformats-officedocument.wordprocessingml.document',\n images: 'image/*',\n pdf: 'application/pdf',\n plainText: 'text/plain',\n ppt: 'application/vnd.ms-powerpoint',\n pptx: 'application/vnd.openxmlformats-officedocument.presentationml.presentation',\n video: 'video/*',\n xls: 'application/vnd.ms-excel',\n xlsx: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',\n zip: 'application/zip',\n} as const)\n\nconst utis = Object.freeze({\n allFiles: 'public.item',\n audio: 'public.audio',\n csv: 'public.comma-separated-values-text',\n doc: 'com.microsoft.word.doc',\n docx: 'org.openxmlformats.wordprocessingml.document',\n images: 'public.image',\n pdf: 'com.adobe.pdf',\n plainText: 'public.plain-text',\n ppt: 'com.microsoft.powerpoint.ppt',\n pptx: 'org.openxmlformats.presentationml.presentation',\n video: 'public.movie',\n xls: 'com.microsoft.excel.xls',\n xlsx: 'org.openxmlformats.spreadsheetml.sheet',\n zip: 'public.zip-archive',\n} as const)\n\nconst extensions = Object.freeze({\n allFiles: '*',\n audio:\n '.3g2 .3gp .aac .adt .adts .aif .aifc .aiff .asf .au .m3u .m4a .m4b .mid .midi .mp2 .mp3 .mp4 .rmi .snd .wav .wax .wma',\n csv: '.csv',\n doc: '.doc',\n docx: '.docx',\n images: '.jpeg .jpg .png',\n pdf: '.pdf',\n plainText: '.txt',\n ppt: '.ppt',\n pptx: '.pptx',\n video: '.mp4',\n xls: '.xls',\n xlsx: '.xlsx',\n zip: '.zip .gz',\n} as const)\n\nexport type PlatformTypes = {\n android: typeof mimeTypes\n ios: typeof utis\n windows: typeof extensions\n}\nexport type SupportedPlatforms = 'ios' | 'android' | 'windows'\n\nexport const perPlatformTypes = {\n android: mimeTypes,\n ios: utis,\n windows: extensions,\n // unsupported, but added to make TS happy\n macos: extensions,\n web: extensions,\n}\n\n// ensure shapes of platformTypes are the same: https://stackoverflow.com/a/67027347/2070942\n// let me know if there's a nicer way\n\ntype AssertEqualKeys = [\n keyof T1 extends keyof T2 ? 1 : 0,\n keyof T2 extends keyof T1 ? 1 : 0,\n] extends [1, 1]\n ? true\n : false\n\nconst mimesAndUtisAreEqual: AssertEqualKeys = true\nconst mimesAndExtensionsAreEqual: AssertEqualKeys = true\nexport const typesAreEqual = mimesAndUtisAreEqual && mimesAndExtensionsAreEqual\n","import {PERMISSIONS, request, RESULTS} from 'react-native-permissions';\nimport {launchCamera} from 'react-native-image-picker';\n\n/**\n * Launching the camera for iOS involves checking for permissions\n * And only then starting the camera\n * If the user deny permission the callback will be called with an error response\n * in the same format as the error returned by react-native-image-picker\n * @param {CameraOptions} options\n * @param {function} callback - callback called with the result\n */\nexport default function launchCameraIOS(options, callback) {\n // Checks current camera permissions and prompts the user in case they aren't granted\n request(PERMISSIONS.IOS.CAMERA)\n .then((permission) => {\n if (permission !== RESULTS.GRANTED) {\n const error = new Error('User did not grant permissions');\n error.errorCode = 'permission';\n throw error;\n }\n\n launchCamera(options, callback);\n })\n .catch((error) => {\n /* Intercept the permission error as well as any other errors and call the callback\n * follow the same pattern expected for image picker results */\n callback({\n errorMessage: error.message,\n errorCode: error.errorCode || 'others',\n });\n });\n}\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nvar _exportNames = {\n check: true,\n checkLocationAccuracy: true,\n checkMultiple: true,\n checkNotifications: true,\n openLimitedPhotoLibraryPicker: true,\n openSettings: true,\n request: true,\n requestLocationAccuracy: true,\n requestMultiple: true,\n requestNotifications: true,\n PERMISSIONS: true,\n RESULTS: true\n};\nObject.defineProperty(exports, \"PERMISSIONS\", {\n enumerable: true,\n get: function () {\n return _permissions.PERMISSIONS;\n }\n});\nObject.defineProperty(exports, \"RESULTS\", {\n enumerable: true,\n get: function () {\n return _results.RESULTS;\n }\n});\nexports.requestNotifications = exports.requestMultiple = exports.requestLocationAccuracy = exports.request = exports.openSettings = exports.openLimitedPhotoLibraryPicker = exports.default = exports.checkNotifications = exports.checkMultiple = exports.checkLocationAccuracy = exports.check = void 0;\n\nvar _reactNative = require(\"react-native\");\n\nvar _methods = require(\"./methods\");\n\nvar _permissions = require(\"./permissions\");\n\nvar _results = require(\"./results\");\n\nvar _types = require(\"./types\");\n\nObject.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\nif (_reactNative.NativeModules.RNPermissions == null) {\n throw new Error(`react-native-permissions: NativeModule.RNPermissions is null. To fix this issue try these steps:\n• If you are using CocoaPods on iOS, run \\`pod install\\` in the \\`ios\\` directory and then clean, rebuild and re-run the app. You may also need to re-open Xcode to get the new pods.\n• If you are getting this error while unit testing you need to mock the native module. You can use this to get started: https://github.com/zoontek/react-native-permissions/blob/master/mock.js\nIf none of these fix the issue, please open an issue on the Github repository: https://github.com/zoontek/react-native-permissions`);\n}\n\nconst check = _methods.methods.check;\nexports.check = check;\nconst checkLocationAccuracy = _methods.methods.checkLocationAccuracy;\nexports.checkLocationAccuracy = checkLocationAccuracy;\nconst checkMultiple = _methods.methods.checkMultiple;\nexports.checkMultiple = checkMultiple;\nconst checkNotifications = _methods.methods.checkNotifications;\nexports.checkNotifications = checkNotifications;\nconst openLimitedPhotoLibraryPicker = _methods.methods.openLimitedPhotoLibraryPicker;\nexports.openLimitedPhotoLibraryPicker = openLimitedPhotoLibraryPicker;\nconst openSettings = _methods.methods.openSettings;\nexports.openSettings = openSettings;\nconst request = _methods.methods.request;\nexports.request = request;\nconst requestLocationAccuracy = _methods.methods.requestLocationAccuracy;\nexports.requestLocationAccuracy = requestLocationAccuracy;\nconst requestMultiple = _methods.methods.requestMultiple;\nexports.requestMultiple = requestMultiple;\nconst requestNotifications = _methods.methods.requestNotifications;\nexports.requestNotifications = requestNotifications;\nvar _default = {\n PERMISSIONS: _permissions.PERMISSIONS,\n RESULTS: _results.RESULTS,\n check,\n checkLocationAccuracy,\n checkMultiple,\n checkNotifications,\n openLimitedPhotoLibraryPicker,\n openSettings,\n request,\n requestLocationAccuracy,\n requestMultiple,\n requestNotifications\n};\nexports.default = _default;\n//# sourceMappingURL=index.js.map","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.PERMISSIONS = void 0;\nconst IOS = Object.freeze({\n APP_TRACKING_TRANSPARENCY: 'ios.permission.APP_TRACKING_TRANSPARENCY',\n BLUETOOTH_PERIPHERAL: 'ios.permission.BLUETOOTH_PERIPHERAL',\n CALENDARS: 'ios.permission.CALENDARS',\n CAMERA: 'ios.permission.CAMERA',\n CONTACTS: 'ios.permission.CONTACTS',\n FACE_ID: 'ios.permission.FACE_ID',\n LOCATION_ALWAYS: 'ios.permission.LOCATION_ALWAYS',\n LOCATION_WHEN_IN_USE: 'ios.permission.LOCATION_WHEN_IN_USE',\n MEDIA_LIBRARY: 'ios.permission.MEDIA_LIBRARY',\n MICROPHONE: 'ios.permission.MICROPHONE',\n MOTION: 'ios.permission.MOTION',\n PHOTO_LIBRARY: 'ios.permission.PHOTO_LIBRARY',\n PHOTO_LIBRARY_ADD_ONLY: 'ios.permission.PHOTO_LIBRARY_ADD_ONLY',\n REMINDERS: 'ios.permission.REMINDERS',\n SIRI: 'ios.permission.SIRI',\n SPEECH_RECOGNITION: 'ios.permission.SPEECH_RECOGNITION',\n STOREKIT: 'ios.permission.STOREKIT'\n});\nconst PERMISSIONS = Object.freeze({\n ANDROID: {},\n IOS,\n WINDOWS: {}\n});\nexports.PERMISSIONS = PERMISSIONS;\n//# sourceMappingURL=permissions.ios.js.map","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.RESULTS = void 0;\nconst RESULTS = Object.freeze({\n UNAVAILABLE: 'unavailable',\n BLOCKED: 'blocked',\n DENIED: 'denied',\n GRANTED: 'granted',\n LIMITED: 'limited'\n});\nexports.RESULTS = RESULTS;\n//# sourceMappingURL=results.js.map","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\n//# sourceMappingURL=types.js.map","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.checkNotifications = checkNotifications;\nexports.methods = void 0;\nexports.requestNotifications = requestNotifications;\n\nvar _reactNative = require(\"react-native\");\n\nvar _results = require(\"./results\");\n\nvar _utils = require(\"./utils\");\n\nconst NativeModule = _reactNative.NativeModules.RNPermissions;\n\nasync function openLimitedPhotoLibraryPicker() {\n await NativeModule.openLimitedPhotoLibraryPicker();\n}\n\nasync function openSettings() {\n await NativeModule.openSettings();\n}\n\nasync function check(permission) {\n return NativeModule.available.includes(permission) ? NativeModule.check(permission) : _results.RESULTS.UNAVAILABLE;\n}\n\nasync function request(permission) {\n return NativeModule.available.includes(permission) ? NativeModule.request(permission) : _results.RESULTS.UNAVAILABLE;\n}\n\nfunction checkLocationAccuracy() {\n return NativeModule.checkLocationAccuracy();\n}\n\nfunction requestLocationAccuracy(options) {\n return NativeModule.requestLocationAccuracy(options.purposeKey);\n}\n\nfunction checkNotifications() {\n return NativeModule.checkNotifications();\n}\n\nfunction requestNotifications(options) {\n return NativeModule.requestNotifications(options);\n}\n\nasync function checkMultiple(permissions) {\n const output = {};\n const dedup = (0, _utils.uniq)(permissions);\n await Promise.all(dedup.map(async permission => {\n output[permission] = await check(permission);\n }));\n return output;\n}\n\nasync function requestMultiple(permissions) {\n const output = {};\n const dedup = (0, _utils.uniq)(permissions);\n\n for (let index = 0; index < dedup.length; index++) {\n const permission = dedup[index];\n output[permission] = await request(permission);\n }\n\n return output;\n}\n\nconst methods = {\n check,\n checkLocationAccuracy,\n checkMultiple,\n checkNotifications,\n openLimitedPhotoLibraryPicker,\n openSettings,\n request,\n requestLocationAccuracy,\n requestMultiple,\n requestNotifications\n};\nexports.methods = methods;\n//# sourceMappingURL=methods.ios.js.map","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.platformVersion = void 0;\nexports.uniq = uniq;\n\nvar _reactNative = require(\"react-native\");\n\nconst platformVersion = typeof _reactNative.Platform.Version === 'string' ? parseInt(_reactNative.Platform.Version, 10) : _reactNative.Platform.Version;\nexports.platformVersion = platformVersion;\n\nfunction uniq(array) {\n return array.filter((item, index) => item != null && array.indexOf(item) === index);\n}\n//# sourceMappingURL=utils.js.map","import {Platform} from 'react-native';\n\nimport {CameraOptions, ImageLibraryOptions, Callback} from './types';\nimport {\n imageLibrary as nativeImageLibrary,\n camera as nativeCamera,\n} from './platforms/native';\nimport {\n imageLibrary as webImageLibrary,\n camera as webCamera,\n} from './platforms/web';\n\nexport * from './types';\n\nexport function launchCamera(options: CameraOptions, callback?: Callback) {\n return Platform.OS === 'web'\n ? webCamera(options, callback)\n : nativeCamera(options, callback);\n}\n\nexport function launchImageLibrary(\n options: ImageLibraryOptions,\n callback?: Callback,\n) {\n return Platform.OS === 'web'\n ? webImageLibrary(options, callback)\n : nativeImageLibrary(options, callback);\n}\n","export type Callback = (response: ImagePickerResponse) => any;\n\nexport interface OptionsCommon {\n mediaType: MediaType;\n maxWidth?: number;\n maxHeight?: number;\n quality?: PhotoQuality;\n videoQuality?: AndroidVideoOptions | iOSVideoOptions;\n includeBase64?: boolean;\n includeExtra?: boolean;\n presentationStyle?:\n | 'currentContext'\n | 'fullScreen'\n | 'pageSheet'\n | 'formSheet'\n | 'popover'\n | 'overFullScreen'\n | 'overCurrentContext';\n}\n\nexport interface ImageLibraryOptions extends OptionsCommon {\n selectionLimit?: number;\n}\n\nexport interface CameraOptions extends OptionsCommon {\n durationLimit?: number;\n saveToPhotos?: boolean;\n cameraType?: CameraType;\n}\n\nexport interface Asset {\n base64?: string;\n uri?: string;\n width?: number;\n height?: number;\n fileSize?: number;\n type?: string;\n fileName?: string;\n duration?: number;\n bitrate?: number;\n timestamp?: string;\n id?: string;\n}\n\nexport interface ImagePickerResponse {\n didCancel?: boolean;\n errorCode?: ErrorCode;\n errorMessage?: string;\n assets?: Asset[];\n}\n\nexport type PhotoQuality =\n | 0\n | 0.1\n | 0.2\n | 0.3\n | 0.4\n | 0.5\n | 0.6\n | 0.7\n | 0.8\n | 0.9\n | 1;\nexport type CameraType = 'back' | 'front';\nexport type MediaType = 'photo' | 'video' | 'mixed';\nexport type AndroidVideoOptions = 'low' | 'high';\nexport type iOSVideoOptions = 'low' | 'medium' | 'high';\nexport type ErrorCode = 'camera_unavailable' | 'permission' | 'others';\n","import {\n CameraOptions,\n ImageLibraryOptions,\n Callback,\n ImagePickerResponse,\n ErrorCode,\n Asset,\n MediaType,\n} from '../types';\n\nconst DEFAULT_OPTIONS: Pick<\n ImageLibraryOptions & CameraOptions,\n 'mediaType' | 'includeBase64' | 'selectionLimit'\n> = {\n mediaType: 'photo',\n includeBase64: false,\n selectionLimit: 1,\n};\n\nexport function camera(\n options: ImageLibraryOptions = DEFAULT_OPTIONS,\n callback?: Callback,\n): Promise {\n return new Promise((resolve) => {\n const result = {\n errorCode: 'camera_unavailable' as ErrorCode,\n errorMessage: 'launchCamera is not supported for web yet',\n };\n\n if (callback) callback(result);\n\n resolve(result);\n });\n}\n\nexport function imageLibrary(\n options: ImageLibraryOptions = DEFAULT_OPTIONS,\n callback?: Callback,\n): Promise {\n // Only supporting 'photo' mediaType for now.\n if (options.mediaType !== 'photo') {\n const result = {\n errorCode: 'others' as ErrorCode,\n errorMessage: 'For now, only photo mediaType is supported for web',\n };\n\n if (callback) callback(result);\n\n return Promise.resolve(result);\n }\n\n const input = document.createElement('input');\n input.style.display = 'none';\n input.setAttribute('type', 'file');\n input.setAttribute('accept', getWebMediaType(options.mediaType));\n\n if (options.selectionLimit! > 1) {\n input.setAttribute('multiple', 'multiple');\n }\n\n document.body.appendChild(input);\n\n return new Promise((resolve) => {\n input.addEventListener('change', async () => {\n if (input.files) {\n if (options.selectionLimit! <= 1) {\n const img = await readFile(input.files[0], {\n includeBase64: options.includeBase64,\n });\n\n const result = {assets: [img]};\n\n if (callback) callback(result);\n\n resolve(result);\n } else {\n const imgs = await Promise.all(\n Array.from(input.files).map((file) =>\n readFile(file, {includeBase64: options.includeBase64}),\n ),\n );\n\n const result = {\n didCancel: false,\n assets: imgs,\n };\n\n if (callback) callback(result);\n\n resolve(result);\n }\n }\n document.body.removeChild(input);\n });\n\n const event = new MouseEvent('click');\n input.dispatchEvent(event);\n });\n}\n\nfunction readFile(\n targetFile: Blob,\n options: Partial,\n): Promise {\n return new Promise((resolve, reject) => {\n const reader = new FileReader();\n reader.onerror = () => {\n reject(\n new Error(\n `Failed to read the selected media because the operation failed.`,\n ),\n );\n };\n reader.onload = ({target}) => {\n const uri = target?.result;\n\n const returnRaw = () =>\n resolve({\n uri: uri as string,\n width: 0,\n height: 0,\n });\n\n if (typeof uri === 'string') {\n const image = new Image();\n image.src = uri;\n image.onload = () =>\n resolve({\n uri,\n width: image.naturalWidth ?? image.width,\n height: image.naturalHeight ?? image.height,\n // The blob's result cannot be directly decoded as Base64 without\n // first removing the Data-URL declaration preceding the\n // Base64-encoded data. To retrieve only the Base64 encoded string,\n // first remove data:*/*;base64, from the result.\n // https://developer.mozilla.org/en-US/docs/Web/API/FileReader/readAsDataURL\n ...(options.includeBase64 && {\n base64: uri.substr(uri.indexOf(',') + 1),\n }),\n });\n image.onerror = () => returnRaw();\n } else {\n returnRaw();\n }\n };\n\n reader.readAsDataURL(targetFile);\n });\n}\n\nfunction getWebMediaType(mediaType: MediaType) {\n const webMediaTypes = {\n photo: 'image/*',\n video: 'video/*',\n mixed: 'image/*,video/*',\n };\n\n return webMediaTypes[mediaType] ?? webMediaTypes.photo;\n}\n","import {NativeModules} from 'react-native';\n\nimport {\n CameraOptions,\n ImageLibraryOptions,\n Callback,\n ImagePickerResponse,\n} from '../types';\n\nconst DEFAULT_OPTIONS: ImageLibraryOptions & CameraOptions = {\n mediaType: 'photo',\n videoQuality: 'high',\n quality: 1,\n maxWidth: 0,\n maxHeight: 0,\n includeBase64: false,\n cameraType: 'back',\n selectionLimit: 1,\n saveToPhotos: false,\n durationLimit: 0,\n includeExtra: false,\n presentationStyle: 'pageSheet',\n};\n\n// @ts-ignore We want to check whether __turboModuleProxy exitst, it may not\nconst isTurboModuleEnabled = global.__turboModuleProxy != null;\n\nconst nativeImagePicler = isTurboModuleEnabled ?\n require(\"./NativeImagePicker\").default :\n NativeModules.ImagePicker;\n\nexport function camera(\n options: CameraOptions,\n callback?: Callback,\n): Promise {\n return new Promise((resolve) => {\n nativeImagePicler.launchCamera(\n {...DEFAULT_OPTIONS, ...options},\n (result: ImagePickerResponse) => {\n if (callback) callback(result);\n resolve(result);\n },\n );\n });\n}\n\nexport function imageLibrary(\n options: ImageLibraryOptions,\n callback?: Callback,\n): Promise {\n return new Promise((resolve) => {\n nativeImagePicler.launchImageLibrary(\n {...DEFAULT_OPTIONS, ...options},\n (result: ImagePickerResponse) => {\n if (callback) callback(result);\n resolve(result);\n },\n );\n });\n}\n","import type { TurboModule } from 'react-native/Libraries/TurboModule/RCTExport';\nimport { TurboModuleRegistry } from 'react-native';\n\nexport interface Spec extends TurboModule {\n launchCamera(options: Object, callback: () => void): void;\n launchImageLibrary(options: Object, callback: () => void): void;\n}\nexport default TurboModuleRegistry.get(\n 'ImagePicker'\n);\n","import PropTypes from 'prop-types';\nimport CONST from '../../CONST';\n\nconst propTypes = {\n /**\n * A renderProp with the following interface\n *\n * @example\n * \n * {({openPicker}) => (\n * {\n * openPicker({\n * onPicked: (file) => {\n * // Display or upload File\n * },\n * });\n * }}\n * />\n * )}\n * \n * */\n children: PropTypes.func.isRequired,\n\n /** The types of files that can be selected with this picker. */\n type: PropTypes.oneOf([CONST.ATTACHMENT_PICKER_TYPE.FILE, CONST.ATTACHMENT_PICKER_TYPE.IMAGE]),\n};\n\nconst defaultProps = {\n type: CONST.ATTACHMENT_PICKER_TYPE.FILE,\n};\n\nexport {\n propTypes,\n defaultProps,\n};\n","import PropTypes from 'prop-types';\nimport React, {\n useCallback, useEffect, useState,\n} from 'react';\nimport {\n ActivityIndicator, Image, View, Pressable,\n} from 'react-native';\nimport {GestureHandlerRootView} from 'react-native-gesture-handler';\nimport {\n runOnUI,\n interpolate,\n useAnimatedGestureHandler,\n useSharedValue,\n useWorkletCallback,\n} from 'react-native-reanimated';\nimport CONST from '../../CONST';\nimport compose from '../../libs/compose';\nimport styles from '../../styles/styles';\nimport themeColors from '../../styles/themes/default';\nimport Button from '../Button';\nimport HeaderWithCloseButton from '../HeaderWithCloseButton';\nimport Icon from '../Icon';\nimport * as Expensicons from '../Icon/Expensicons';\nimport Modal from '../Modal';\nimport Text from '../Text';\nimport withLocalize, {withLocalizePropTypes} from '../withLocalize';\nimport withWindowDimensions, {windowDimensionsPropTypes} from '../withWindowDimensions';\nimport ImageCropView from './ImageCropView';\nimport Slider from './Slider';\nimport cropOrRotateImage from '../../libs/cropOrRotateImage';\nimport HeaderGap from '../HeaderGap';\nimport * as StyleUtils from '../../styles/StyleUtils';\nimport Tooltip from '../Tooltip';\n\nconst propTypes = {\n /** Link to image for cropping */\n imageUri: PropTypes.string,\n\n /** Name of the image */\n imageName: PropTypes.string,\n\n /** Type of the image file */\n imageType: PropTypes.string,\n\n /** Callback to be called when user closes the modal */\n onClose: PropTypes.func,\n\n /** Callback to be called when user saves the image */\n onSave: PropTypes.func,\n\n /** Modal visibility */\n isVisible: PropTypes.bool.isRequired,\n\n /** Image crop vector mask */\n maskImage: PropTypes.func,\n\n ...withLocalizePropTypes,\n ...windowDimensionsPropTypes,\n};\n\nconst defaultProps = {\n imageUri: '',\n imageName: '',\n imageType: '',\n onClose: () => {},\n onSave: () => {},\n maskImage: undefined,\n};\n\n// This component can't be written using class since reanimated API uses hooks.\nconst AvatarCropModal = (props) => {\n const originalImageWidth = useSharedValue(CONST.AVATAR_CROP_MODAL.INITIAL_SIZE);\n const originalImageHeight = useSharedValue(CONST.AVATAR_CROP_MODAL.INITIAL_SIZE);\n const translateY = useSharedValue(0);\n const translateX = useSharedValue(0);\n const scale = useSharedValue(CONST.AVATAR_CROP_MODAL.MIN_SCALE);\n const rotation = useSharedValue(0);\n const translateSlider = useSharedValue(0);\n const isPressableEnabled = useSharedValue(true);\n\n // Check if image cropping, saving or uploading is in progress\n const isLoading = useSharedValue(false);\n\n // The previous offset values are maintained to recalculate the offset value in proportion\n // to the container size, especially when the window size is first decreased and then increased\n const prevMaxOffsetX = useSharedValue(0);\n const prevMaxOffsetY = useSharedValue(0);\n\n const [imageContainerSize, setImageContainerSize] = useState(CONST.AVATAR_CROP_MODAL.INITIAL_SIZE);\n const [sliderContainerSize, setSliderContainerSize] = useState(CONST.AVATAR_CROP_MODAL.INITIAL_SIZE);\n const [isImageContainerInitialized, setIsImageContainerInitialized] = useState(false);\n const [isImageInitialized, setIsImageInitialized] = useState(false);\n\n // An onLayout callback, that initializes the image container, for proper render of an image\n const initializeImageContainer = useCallback((event) => {\n setIsImageContainerInitialized(true);\n const {height, width} = event.nativeEvent.layout;\n\n // Even if the browser height is reduced too much, the relative height should not be negative\n const relativeHeight = Math.max(height, CONST.AVATAR_CROP_MODAL.INITIAL_SIZE);\n setImageContainerSize(Math.floor(Math.min(relativeHeight, width)));\n }, []);\n\n // An onLayout callback, that initializes the slider container size, for proper render of a slider\n const initializeSliderContainer = useCallback((event) => {\n setSliderContainerSize(event.nativeEvent.layout.width);\n }, []);\n\n // Changes the modal state values to initial\n const resetState = useCallback(() => {\n originalImageWidth.value = CONST.AVATAR_CROP_MODAL.INITIAL_SIZE;\n originalImageHeight.value = CONST.AVATAR_CROP_MODAL.INITIAL_SIZE;\n translateY.value = 0;\n translateX.value = 0;\n scale.value = CONST.AVATAR_CROP_MODAL.MIN_SCALE;\n rotation.value = 0;\n translateSlider.value = 0;\n prevMaxOffsetX.value = 0;\n prevMaxOffsetY.value = 0;\n isLoading.value = false;\n setImageContainerSize(CONST.AVATAR_CROP_MODAL.INITIAL_SIZE);\n setSliderContainerSize(CONST.AVATAR_CROP_MODAL.INITIAL_SIZE);\n setIsImageContainerInitialized(false);\n setIsImageInitialized(false);\n }, [originalImageHeight, originalImageWidth, prevMaxOffsetX, prevMaxOffsetY, rotation, scale, translateSlider, translateX, translateY, isLoading]);\n\n // In order to calculate proper image position/size/animation, we have to know its size.\n // And we have to update image size if image url changes.\n const imageUri = props.imageUri;\n useEffect(() => {\n if (!imageUri) {\n return;\n }\n Image.getSize(imageUri, (width, height) => {\n // We need to have image sizes in shared values to properly calculate position/size/animation\n originalImageHeight.value = height;\n originalImageWidth.value = width;\n setIsImageInitialized(true);\n\n // Because the reanimated library has some internal optimizations,\n // sometimes when the modal is hidden styles of the image and slider might not be updated.\n // To trigger the update we need to slightly change the following values:\n translateSlider.value += 0.01;\n rotation.value += 360;\n });\n }, [imageUri, originalImageHeight, originalImageWidth, rotation, translateSlider]);\n\n /**\n * Validates that value is within the provided mix/max range.\n *\n * @param {Number} value\n * @param {Array} minMax\n * @returns {Number}\n */\n const clamp = useWorkletCallback((value, [min, max]) => interpolate(value, [min, max], [min, max], 'clamp'), []);\n\n /**\n * Returns current image size taking into account scale and rotation.\n *\n * @returns {Object}\n */\n const getDisplayedImageSize = useWorkletCallback(() => {\n let height = imageContainerSize * scale.value;\n let width = imageContainerSize * scale.value;\n\n // Since the smaller side will be always equal to the imageContainerSize multiplied by scale,\n // another side can be calculated with aspect ratio.\n if (originalImageWidth.value > originalImageHeight.value) {\n width *= originalImageWidth.value / originalImageHeight.value;\n } else {\n height *= originalImageHeight.value / originalImageWidth.value;\n }\n\n return {height, width};\n }, [imageContainerSize, scale]);\n\n /**\n * Validates the offset to prevent overflow, and updates the image offset.\n *\n * @param {Number} newX\n * @param {Number} newY\n */\n const updateImageOffset = useWorkletCallback((offsetX, offsetY) => {\n const {height, width} = getDisplayedImageSize();\n const maxOffsetX = (width - imageContainerSize) / 2;\n const maxOffsetY = (height - imageContainerSize) / 2;\n translateX.value = clamp(offsetX, [maxOffsetX * -1, maxOffsetX]);\n translateY.value = clamp(offsetY, [maxOffsetY * -1, maxOffsetY]);\n prevMaxOffsetX.value = maxOffsetX;\n prevMaxOffsetY.value = maxOffsetY;\n }, [imageContainerSize, scale, clamp]);\n\n /**\n * @param {Number} newSliderValue\n * @param {Number} containerSize\n * @returns {Number}\n */\n const newScaleValue = useWorkletCallback((newSliderValue, containerSize) => {\n const {MAX_SCALE, MIN_SCALE} = CONST.AVATAR_CROP_MODAL;\n return ((newSliderValue / containerSize) * (MAX_SCALE - MIN_SCALE)) + MIN_SCALE;\n });\n\n /**\n * Calculates new x & y image translate value on image panning\n * and updates image's offset.\n */\n const panGestureEventHandler = useAnimatedGestureHandler({\n onStart: (_, context) => {\n // we have to assign translate values to a context\n // since that is required for proper work of turbo modules.\n // eslint-disable-next-line no-param-reassign\n context.translateX = translateX.value;\n // eslint-disable-next-line no-param-reassign\n context.translateY = translateY.value;\n },\n onActive: (event, context) => {\n const newX = event.translationX + context.translateX;\n const newY = event.translationY + context.translateY;\n\n updateImageOffset(newX, newY);\n },\n }, [imageContainerSize, updateImageOffset, translateX, translateY]);\n\n // This effect is needed to recalculate the maximum offset values\n // when the browser window is resized.\n useEffect(() => {\n // If no panning has happened and the value is 0, do an early return.\n if (!prevMaxOffsetX.value && !prevMaxOffsetY.value) {\n return;\n }\n const {height, width} = getDisplayedImageSize();\n const maxOffsetX = (width - imageContainerSize) / 2;\n const maxOffsetY = (height - imageContainerSize) / 2;\n\n // Since interpolation is expensive, we only want to do it if\n // image has been panned across X or Y axis by the user.\n if (prevMaxOffsetX) {\n translateX.value = interpolate(\n translateX.value,\n [prevMaxOffsetX.value * -1, prevMaxOffsetX.value],\n [maxOffsetX * -1, maxOffsetX],\n );\n }\n\n if (prevMaxOffsetY) {\n translateY.value = interpolate(\n translateY.value,\n [prevMaxOffsetY.value * -1, prevMaxOffsetY.value],\n [maxOffsetY * -1, maxOffsetY],\n );\n }\n prevMaxOffsetX.value = maxOffsetX;\n prevMaxOffsetY.value = maxOffsetY;\n }, [getDisplayedImageSize, imageContainerSize, prevMaxOffsetX, prevMaxOffsetY, translateX, translateY]);\n\n /**\n * Calculates new scale value and updates images offset to ensure\n * that image stays in the center of the container after changing scale.\n */\n const panSliderGestureEventHandler = useAnimatedGestureHandler({\n onStart: (_, context) => {\n // we have to assign this value to a context\n // since that is required for proper work of turbo modules.\n // eslint-disable-next-line no-param-reassign\n context.translateSliderX = translateSlider.value;\n isPressableEnabled.value = false;\n },\n onActive: (event, context) => {\n const newSliderValue = clamp(event.translationX + context.translateSliderX, [0, sliderContainerSize]);\n const newScale = newScaleValue(newSliderValue, sliderContainerSize);\n\n const differential = newScale / scale.value;\n\n scale.value = newScale;\n translateSlider.value = newSliderValue;\n\n const newX = translateX.value * differential;\n const newY = translateY.value * differential;\n updateImageOffset(newX, newY);\n },\n onEnd: () => isPressableEnabled.value = true,\n }, [imageContainerSize, clamp, translateX, translateY, translateSlider, scale, sliderContainerSize, isPressableEnabled]);\n\n // This effect is needed to prevent the incorrect position of\n // the slider's knob when the window's layout changes\n useEffect(() => {\n translateSlider.value = interpolate(\n scale.value,\n [CONST.AVATAR_CROP_MODAL.MIN_SCALE, CONST.AVATAR_CROP_MODAL.MAX_SCALE],\n [0, sliderContainerSize],\n );\n }, [scale.value, sliderContainerSize, translateSlider]);\n\n // Rotates the image by changing the rotation value by 90 degrees\n // and updating the position so the image remains in the same place after rotation\n const rotateImage = useCallback(() => {\n rotation.value -= 90;\n\n // Rotating 2d coordinates by applying the formula (x, y) → (-y, x).\n [translateX.value, translateY.value] = [translateY.value, translateX.value * -1];\n\n // Since we rotated the image by 90 degrees, now width becomes height and vice versa.\n [originalImageHeight.value, originalImageWidth.value] = [\n originalImageWidth.value,\n originalImageHeight.value,\n ];\n }, [originalImageHeight.value, originalImageWidth.value, rotation, translateX.value, translateY.value]);\n\n // Crops an image that was provided in the imageUri prop, using the current position/scale\n // then calls onSave and onClose callbacks\n const cropAndSaveImage = useCallback(() => {\n if (isLoading.value) {\n return;\n }\n isLoading.value = true;\n const smallerSize = Math.min(originalImageHeight.value, originalImageWidth.value);\n const size = smallerSize / scale.value;\n const imageCenterX = originalImageWidth.value / 2;\n const imageCenterY = originalImageHeight.value / 2;\n const apothem = size / 2; // apothem for squares is equals to half of it size\n\n // Since the translate value is only a distance from the image center, we are able to calculate\n // the originX and the originY - start coordinates of cropping view.\n const originX = imageCenterX - apothem - ((translateX.value / imageContainerSize / scale.value) * smallerSize);\n const originY = imageCenterY - apothem - ((translateY.value / imageContainerSize / scale.value) * smallerSize);\n\n const crop = {\n height: size, width: size, originX, originY,\n };\n\n // Svg images are converted to a png blob to preserve transparency, so we need to update the\n // image name and type accordingly.\n const isSvg = props.imageType.includes('image/svg');\n const imageName = isSvg ? 'fileName.png' : props.imageName;\n const imageType = isSvg ? 'image/png' : props.imageType;\n\n cropOrRotateImage(\n props.imageUri,\n [{rotate: rotation.value % 360}, {crop}],\n {compress: 1, name: imageName, type: imageType},\n )\n .then((newImage) => {\n props.onClose();\n props.onSave(newImage);\n })\n .catch(() => {\n isLoading.value = false;\n });\n }, [originalImageHeight.value, originalImageWidth.value, scale.value, translateX.value, imageContainerSize, translateY.value, props, rotation.value, isLoading]);\n\n /**\n * @param {Number} locationX\n */\n const sliderOnPress = (locationX) => {\n // We are using the worklet directive here and running on the UI thread to ensure the Reanimated\n // shared values are updated synchronously, as they update asynchronously on the JS thread.\n\n 'worklet';\n\n if (!locationX || !isPressableEnabled.value) {\n return;\n }\n const newSliderValue = clamp(locationX, [0, sliderContainerSize]);\n const newScale = newScaleValue(newSliderValue, sliderContainerSize);\n translateSlider.value = newSliderValue;\n const differential = newScale / scale.value;\n scale.value = newScale;\n const newX = translateX.value * differential;\n const newY = translateY.value * differential;\n updateImageOffset(newX, newY);\n };\n\n return (\n \n {props.isSmallScreenWidth && }\n \n {props.translate('avatarCropModal.description')}\n \n\n {/* To avoid layout shift we should hide this component until the image container & image is initialized */}\n {(!isImageInitialized || !isImageContainerInitialized) ? \n : (\n <>\n \n \n \n runOnUI(sliderOnPress)(e.nativeEvent.locationX)}\n >\n \n \n \n \n \n \n \n )}\n \n \n \n );\n};\n\nAvatarCropModal.displayName = 'AvatarCropModal';\nAvatarCropModal.propTypes = propTypes;\nAvatarCropModal.defaultProps = defaultProps;\nexport default compose(\n withWindowDimensions,\n withLocalize,\n)(AvatarCropModal);\n","import PropTypes from 'prop-types';\nimport React from 'react';\nimport {View} from 'react-native';\nimport {PanGestureHandler} from 'react-native-gesture-handler';\nimport Animated, {interpolate, useAnimatedStyle} from 'react-native-reanimated';\nimport styles from '../../styles/styles';\nimport Icon from '../Icon';\nimport * as Expensicons from '../Icon/Expensicons';\nimport * as StyleUtils from '../../styles/StyleUtils';\nimport gestureHandlerPropTypes from './gestureHandlerPropTypes';\nimport ControlSelection from '../../libs/ControlSelection';\n\nconst propTypes = {\n /** Link to image for cropping */\n imageUri: PropTypes.string,\n\n /** Size of the image container that will be rendered */\n containerSize: PropTypes.number,\n\n /** The height of the selected image */\n originalImageHeight: PropTypes.shape({value: PropTypes.number}).isRequired,\n\n /** The width of the selected image */\n originalImageWidth: PropTypes.shape({value: PropTypes.number}).isRequired,\n\n /** The rotation value of the selected image */\n rotation: PropTypes.shape({value: PropTypes.number}).isRequired,\n\n /** The relative image shift along X-axis */\n translateX: PropTypes.shape({value: PropTypes.number}).isRequired,\n\n /** The relative image shift along Y-axis */\n translateY: PropTypes.shape({value: PropTypes.number}).isRequired,\n\n /** The scale factor of the image */\n scale: PropTypes.shape({value: PropTypes.number}).isRequired,\n\n /** React-native-reanimated lib handler which executes when the user is panning image */\n panGestureEventHandler: gestureHandlerPropTypes,\n\n /** Image crop vector mask */\n maskImage: PropTypes.func,\n};\n\nconst defaultProps = {\n imageUri: '',\n containerSize: 0,\n panGestureEventHandler: () => {},\n maskImage: Expensicons.ImageCropCircleMask,\n};\n\nconst ImageCropView = (props) => {\n const containerStyle = StyleUtils.getWidthAndHeightStyle(props.containerSize, props.containerSize);\n\n // A reanimated memoized style, which updates when the image's size or scale changes.\n const imageStyle = useAnimatedStyle(() => {\n const height = props.originalImageHeight.value;\n const width = props.originalImageWidth.value;\n const aspectRatio = height > width ? height / width : width / height;\n const rotate = interpolate(props.rotation.value, [0, 360], [0, 360]);\n return {\n transform: [\n {translateX: props.translateX.value},\n {translateY: props.translateY.value},\n {scale: props.scale.value * aspectRatio},\n {rotate: `${rotate}deg`},\n ],\n };\n }, [props.originalImageHeight, props.originalImageWidth]);\n\n // We're preventing text selection with ControlSelection.blockElement to prevent safari\n // default behaviour of cursor - I-beam cursor on drag. See https://github.com/Expensify/App/issues/13688\n return (\n \n \n \n \n \n \n \n \n );\n};\n\nImageCropView.displayName = 'ImageCropView';\nImageCropView.propTypes = propTypes;\nImageCropView.defaultProps = defaultProps;\n\n// React.memo is needed here to prevent styles recompilation\n// which sometimes may cause glitches during rerender of the modal\nexport default React.memo(ImageCropView);\n","import PropTypes from 'prop-types';\n\nexport default PropTypes.oneOfType([\n // Executes once a gesture is triggered\n PropTypes.func,\n PropTypes.shape({\n current: PropTypes.shape({\n // Array of event names that will be handled by animation handler\n eventNames: PropTypes.arrayOf(PropTypes.string),\n\n // Array of registered event handlers ids\n registrations: PropTypes.arrayOf(PropTypes.number),\n\n // React tag of the node we want to manage\n viewTag: PropTypes.number,\n\n // Executes once a gesture is triggered\n worklet: PropTypes.func,\n }),\n }),\n]);\n","import PropTypes from 'prop-types';\nimport React, {useState} from 'react';\nimport {View} from 'react-native';\nimport {PanGestureHandler} from 'react-native-gesture-handler';\nimport Animated, {useAnimatedStyle} from 'react-native-reanimated';\nimport styles from '../../styles/styles';\nimport gestureHandlerPropTypes from './gestureHandlerPropTypes';\nimport ControlSelection from '../../libs/ControlSelection';\nimport Tooltip from '../Tooltip';\nimport withLocalize, {withLocalizePropTypes} from '../withLocalize';\n\nconst propTypes = {\n /** React-native-reanimated lib handler which executes when the user is panning slider */\n onGesture: gestureHandlerPropTypes,\n\n /** X position of the slider knob */\n sliderValue: PropTypes.shape({value: PropTypes.number}),\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n onGesture: () => {},\n sliderValue: {},\n};\n\n// This component can't be written using class since reanimated API uses hooks.\nconst Slider = (props) => {\n const [tooltipIsVisible, setTooltipIsVisible] = useState(true);\n\n // A reanimated memoized style, which tracks\n // a translateX shared value and updates the slider position.\n const rSliderStyle = useAnimatedStyle(() => ({\n transform: [{translateX: props.sliderValue.value}],\n }));\n\n // We're preventing text selection with ControlSelection.blockElement to prevent safari\n // default behaviour of cursor - I-beam cursor on drag. See https://github.com/Expensify/App/issues/13688\n return (\n \n setTooltipIsVisible(false)}\n onEnded={() => setTooltipIsVisible(true)}\n onGestureEvent={props.onGesture}\n >\n \n { tooltipIsVisible && (\n \n \n \n )}\n \n \n \n );\n};\n\nSlider.displayName = 'Slider';\nSlider.propTypes = propTypes;\nSlider.defaultProps = defaultProps;\nexport default withLocalize(Slider);\n","import RNImageManipulator from '@oguzhnatly/react-native-image-manipulator';\nimport RNFetchBlob from 'react-native-blob-util';\n\n/**\n * Crops and rotates the image on ios/android\n *\n * @param {String} uri\n * @param {Array} actions\n * @param {Object} options\n * @returns {Promise} Returns cropped and rotated image\n */\nfunction cropOrRotateImage(uri, actions, options = {}) {\n return new Promise((resolve) => {\n RNImageManipulator.manipulate(uri, actions, options).then((result) => {\n RNFetchBlob.fs.stat(result.uri.replace('file://', '')).then(({size}) => {\n resolve({\n ...result, size, type: options.type || 'image/jpeg', name: options.name || 'fileName.jpg',\n });\n });\n });\n });\n}\n\nexport default cropOrRotateImage;\n","import { NativeModules } from \"react-native\";\nconst { RNImageManipulator } = NativeModules;\nexport default RNImageManipulator;\n//# sourceMappingURL=index.js.map","import {Animated, Easing} from 'react-native';\nimport useNativeDriver from '../../libs/useNativeDriver';\n\nclass SpinningIndicatorAnimation {\n constructor() {\n this.rotate = new Animated.Value(0);\n this.scale = new Animated.Value(1);\n this.startRotation = this.startRotation.bind(this);\n this.start = this.start.bind(this);\n this.stop = this.stop.bind(this);\n this.getSyncingStyles = this.getSyncingStyles.bind(this);\n }\n\n /**\n * Rotation animation for indicator in a loop\n *\n * @memberof AvatarWithImagePicker\n */\n startRotation() {\n this.rotate.setValue(0);\n Animated.loop(\n Animated.timing(this.rotate, {\n toValue: 1,\n duration: 2000,\n easing: Easing.linear,\n isInteraction: false,\n\n // Animated.loop does not work with `useNativeDriver: true` on Web\n useNativeDriver,\n }),\n ).start();\n }\n\n /**\n * Start Animation for Indicator\n *\n * @memberof AvatarWithImagePicker\n */\n start() {\n this.startRotation();\n Animated.spring(this.scale, {\n toValue: 1.666,\n tension: 1,\n isInteraction: false,\n useNativeDriver: true,\n }).start();\n }\n\n /**\n * Stop Animation for Indicator\n *\n * @memberof AvatarWithImagePicker\n */\n stop() {\n Animated.spring(this.scale, {\n toValue: 1,\n tension: 1,\n isInteraction: false,\n useNativeDriver: true,\n }).start(() => {\n this.rotate.resetAnimation();\n this.scale.resetAnimation();\n this.rotate.setValue(0);\n });\n }\n\n /**\n * Get Indicator Styles while animating\n *\n * @returns {Object}\n */\n getSyncingStyles() {\n return {\n transform: [{\n rotate: this.rotate.interpolate({\n inputRange: [0, 1],\n outputRange: ['0deg', '-360deg'],\n }),\n },\n {\n scale: this.scale,\n }],\n };\n }\n}\n\nexport default SpinningIndicatorAnimation;\n","export default true;\n","/**\n * Get image resolution\n * Image object is returned as a result of a user selecting image using the react-native-image-picker\n * Image already has width and height properties coming from library so we just need to return them on native\n * Opposite to web where we need to create a new Image object and get dimensions from it\n *\n * @param {*} file Picked file blob\n * @returns {Promise}\n */\nfunction getImageResolution(file) {\n return Promise.resolve({width: file.width, height: file.height});\n}\n\nexport default getImageResolution;\n","import _ from 'underscore';\nimport lodashGet from 'lodash/get';\nimport React, {Component} from 'react';\nimport withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsPropTypes, withCurrentUserPersonalDetailsDefaultProps} from '../../../components/withCurrentUserPersonalDetails';\nimport ScreenWrapper from '../../../components/ScreenWrapper';\nimport HeaderWithCloseButton from '../../../components/HeaderWithCloseButton';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport ROUTES from '../../../ROUTES';\nimport Text from '../../../components/Text';\nimport styles from '../../../styles/styles';\nimport Navigation from '../../../libs/Navigation/Navigation';\nimport * as PersonalDetails from '../../../libs/actions/PersonalDetails';\nimport compose from '../../../libs/compose';\nimport themeColors from '../../../styles/themes/default';\nimport * as Expensicons from '../../../components/Icon/Expensicons';\nimport CONST from '../../../CONST';\nimport OptionsSelector from '../../../components/OptionsSelector';\n\nconst greenCheckmark = {src: Expensicons.Checkmark, color: themeColors.success};\n\nconst propTypes = {\n ...withLocalizePropTypes,\n ...withCurrentUserPersonalDetailsPropTypes,\n};\n\nconst defaultProps = {\n ...withCurrentUserPersonalDetailsDefaultProps,\n};\n\nclass PronounsPage extends Component {\n constructor(props) {\n super(props);\n\n this.loadPronouns = this.loadPronouns.bind(this);\n this.onChangeText = this.onChangeText.bind(this);\n this.getFilteredPronouns = this.getFilteredPronouns.bind(this);\n this.updatePronouns = this.updatePronouns.bind(this);\n this.initiallyFocusedOption = {};\n\n this.loadPronouns();\n this.state = {\n searchValue: this.initiallyFocusedOption.text || '',\n };\n }\n\n componentDidUpdate(prevProps) {\n // If the pronouns have changed, we need to update the pronouns list because refreshing the page\n // breaks the component lifecycle, so we need to \"manually\" reset the component.\n if (prevProps.currentUserPersonalDetails.pronouns === this.props.currentUserPersonalDetails.pronouns) {\n return;\n }\n\n this.onChangeText();\n this.loadPronouns();\n }\n\n onChangeText(searchValue = '') {\n this.setState({searchValue});\n }\n\n /**\n * Returns the pronouns list filtered by searchValue needed for the OptionsSelector.\n * Empty array is returned if the searchValue is empty.\n *\n * @returns {Array}\n */\n getFilteredPronouns() {\n const searchedValue = this.state.searchValue.trim();\n if (searchedValue.length === 0) {\n return [];\n }\n return _.filter(this.pronounsList,\n pronous => pronous.text.toLowerCase().indexOf(searchedValue.toLowerCase()) >= 0);\n }\n\n /**\n * Loads the pronouns list from the translations and adds the green checkmark icon to the currently selected value.\n *\n * @returns {void}\n */\n loadPronouns() {\n const currentPronouns = lodashGet(this.props.currentUserPersonalDetails, 'pronouns', '');\n\n this.pronounsList = _.map(this.props.translate('pronouns'), (value, key) => {\n const fullPronounKey = `${CONST.PRONOUNS.PREFIX}${key}`;\n const isCurrentPronouns = fullPronounKey === currentPronouns;\n\n if (isCurrentPronouns) {\n this.initiallyFocusedOption = {\n text: value,\n keyForList: key,\n };\n }\n\n return {\n text: value,\n value: fullPronounKey,\n keyForList: key,\n\n // Include the green checkmark icon to indicate the currently selected value\n customIcon: isCurrentPronouns ? greenCheckmark : undefined,\n\n // This property will make the currently selected value have bold text\n boldStyle: isCurrentPronouns,\n };\n });\n }\n\n /**\n * @param {Object} selectedPronouns\n */\n updatePronouns(selectedPronouns) {\n PersonalDetails.updatePronouns(selectedPronouns.keyForList === this.initiallyFocusedOption.keyForList ? '' : lodashGet(selectedPronouns, 'value', ''));\n }\n\n render() {\n const filteredPronounsList = this.getFilteredPronouns();\n const headerMessage = this.state.searchValue.trim() && !filteredPronounsList.length ? this.props.translate('common.noResultsFound') : '';\n\n return (\n \n {({safeAreaPaddingBottomStyle}) => (\n <>\n Navigation.navigate(ROUTES.SETTINGS_PROFILE)}\n onCloseButtonPress={() => Navigation.dismissModal(true)}\n />\n \n {this.props.translate('pronounsPage.isShownOnProfile')}\n \n \n \n )}\n \n );\n }\n}\n\nPronounsPage.propTypes = propTypes;\nPronounsPage.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withCurrentUserPersonalDetails,\n)(PronounsPage);\n","import lodashGet from 'lodash/get';\nimport React, {Component} from 'react';\nimport {View} from 'react-native';\nimport withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsPropTypes, withCurrentUserPersonalDetailsDefaultProps} from '../../../components/withCurrentUserPersonalDetails';\nimport ScreenWrapper from '../../../components/ScreenWrapper';\nimport HeaderWithCloseButton from '../../../components/HeaderWithCloseButton';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport ROUTES from '../../../ROUTES';\nimport Form from '../../../components/Form';\nimport ONYXKEYS from '../../../ONYXKEYS';\nimport CONST from '../../../CONST';\nimport * as ValidationUtils from '../../../libs/ValidationUtils';\nimport TextInput from '../../../components/TextInput';\nimport Text from '../../../components/Text';\nimport styles from '../../../styles/styles';\nimport Navigation from '../../../libs/Navigation/Navigation';\nimport * as PersonalDetails from '../../../libs/actions/PersonalDetails';\nimport compose from '../../../libs/compose';\nimport * as ErrorUtils from '../../../libs/ErrorUtils';\n\nconst propTypes = {\n ...withLocalizePropTypes,\n ...withCurrentUserPersonalDetailsPropTypes,\n};\n\nconst defaultProps = {\n ...withCurrentUserPersonalDetailsDefaultProps,\n};\n\nclass DisplayNamePage extends Component {\n constructor(props) {\n super(props);\n\n this.validate = this.validate.bind(this);\n this.updateDisplayName = this.updateDisplayName.bind(this);\n }\n\n /**\n * Submit form to update user's first and last name (and display name)\n * @param {Object} values\n * @param {String} values.firstName\n * @param {String} values.lastName\n */\n updateDisplayName(values) {\n PersonalDetails.updateDisplayName(\n values.firstName.trim(),\n values.lastName.trim(),\n );\n }\n\n /**\n * @param {Object} values\n * @param {String} values.firstName\n * @param {String} values.lastName\n * @returns {Object} - An object containing the errors for each inputID\n */\n validate(values) {\n const errors = {};\n\n // First we validate the first name field\n if (!ValidationUtils.isValidDisplayName(values.firstName)) {\n ErrorUtils.addErrorMessage(errors, 'firstName', this.props.translate('personalDetails.error.hasInvalidCharacter'));\n }\n if (ValidationUtils.doesContainReservedWord(values.firstName, CONST.DISPLAY_NAME.RESERVED_FIRST_NAMES)) {\n ErrorUtils.addErrorMessage(errors, 'firstName', this.props.translate('personalDetails.error.containsReservedWord'));\n }\n\n // Then we validate the last name field\n if (!ValidationUtils.isValidDisplayName(values.lastName)) {\n errors.lastName = this.props.translate('personalDetails.error.hasInvalidCharacter');\n }\n\n return errors;\n }\n\n render() {\n const currentUserDetails = this.props.currentUserPersonalDetails || {};\n\n return (\n \n Navigation.navigate(ROUTES.SETTINGS_PROFILE)}\n onCloseButtonPress={() => Navigation.dismissModal(true)}\n />\n \n \n {this.props.translate('displayNamePage.isShownOnProfile')}\n \n \n \n \n \n \n \n \n \n );\n }\n}\n\nDisplayNamePage.propTypes = propTypes;\nDisplayNamePage.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withCurrentUserPersonalDetails,\n)(DisplayNamePage);\n","import lodashGet from 'lodash/get';\nimport React from 'react';\nimport {View} from 'react-native';\nimport moment from 'moment-timezone';\nimport withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsPropTypes, withCurrentUserPersonalDetailsDefaultProps} from '../../../components/withCurrentUserPersonalDetails';\nimport ScreenWrapper from '../../../components/ScreenWrapper';\nimport HeaderWithCloseButton from '../../../components/HeaderWithCloseButton';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport ROUTES from '../../../ROUTES';\nimport CONST from '../../../CONST';\nimport Text from '../../../components/Text';\nimport styles from '../../../styles/styles';\nimport Navigation from '../../../libs/Navigation/Navigation';\nimport * as PersonalDetails from '../../../libs/actions/PersonalDetails';\nimport compose from '../../../libs/compose';\nimport Switch from '../../../components/Switch';\nimport MenuItemWithTopDescription from '../../../components/MenuItemWithTopDescription';\n\nconst propTypes = {\n ...withLocalizePropTypes,\n ...withCurrentUserPersonalDetailsPropTypes,\n};\n\nconst defaultProps = {\n ...withCurrentUserPersonalDetailsDefaultProps,\n};\n\nconst TimezoneInitialPage = (props) => {\n const timezone = lodashGet(props.currentUserPersonalDetails, 'timezone', CONST.DEFAULT_TIME_ZONE);\n\n /**\n * Updates setting for automatic timezone selection.\n * Note: If we are updating automatically, we'll immediately calculate the user's timezone.\n *\n * @param {Boolean} isAutomatic\n */\n const updateAutomaticTimezone = (isAutomatic) => {\n PersonalDetails.updateAutomaticTimezone({\n automatic: isAutomatic,\n selected: isAutomatic ? moment.tz.guess() : timezone.selected,\n });\n };\n\n return (\n \n Navigation.navigate(ROUTES.SETTINGS_PROFILE)}\n onCloseButtonPress={() => Navigation.dismissModal(true)}\n />\n \n \n \n {props.translate('timezonePage.isShownOnProfile')}\n \n \n \n {props.translate('timezonePage.getLocationAutomatically')}\n \n \n \n \n Navigation.navigate(ROUTES.SETTINGS_TIMEZONE_SELECT)}\n />\n \n \n );\n};\n\nTimezoneInitialPage.propTypes = propTypes;\nTimezoneInitialPage.defaultProps = defaultProps;\nTimezoneInitialPage.displayName = 'TimezoneInitialPage';\n\nexport default compose(\n withLocalize,\n withCurrentUserPersonalDetails,\n)(TimezoneInitialPage);\n","import React, {Component} from 'react';\nimport {TouchableOpacity, Animated} from 'react-native';\nimport PropTypes from 'prop-types';\nimport styles from '../styles/styles';\n\nconst propTypes = {\n /** Whether the switch is toggled to the on position */\n isOn: PropTypes.bool.isRequired,\n\n /** Callback to fire when the switch is toggled */\n onToggle: PropTypes.func.isRequired,\n};\n\nclass Switch extends Component {\n constructor(props) {\n super(props);\n this.offPosition = 0;\n this.onPosition = 20;\n this.offsetX = new Animated.Value(props.isOn ? this.onPosition : this.offPosition);\n\n this.toggleSwitch = this.toggleSwitch.bind(this);\n }\n\n componentDidUpdate(prevProps) {\n if (prevProps.isOn === this.props.isOn) {\n return;\n }\n\n this.toggleSwitch();\n }\n\n toggleSwitch() {\n Animated.timing(this.offsetX, {\n toValue: this.props.isOn ? this.onPosition : this.offPosition,\n duration: 300,\n useNativeDriver: true,\n }).start();\n }\n\n render() {\n const switchTransform = {transform: [{translateX: this.offsetX}]};\n return (\n this.props.onToggle(!this.props.isOn)}\n >\n \n \n );\n }\n}\n\nSwitch.propTypes = propTypes;\n\nexport default Switch;\n","import lodashGet from 'lodash/get';\nimport React, {Component} from 'react';\nimport _ from 'underscore';\nimport moment from 'moment-timezone';\nimport withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsPropTypes, withCurrentUserPersonalDetailsDefaultProps} from '../../../components/withCurrentUserPersonalDetails';\nimport ScreenWrapper from '../../../components/ScreenWrapper';\nimport HeaderWithCloseButton from '../../../components/HeaderWithCloseButton';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport ROUTES from '../../../ROUTES';\nimport CONST from '../../../CONST';\nimport styles from '../../../styles/styles';\nimport Navigation from '../../../libs/Navigation/Navigation';\nimport * as PersonalDetails from '../../../libs/actions/PersonalDetails';\nimport compose from '../../../libs/compose';\nimport OptionsSelector from '../../../components/OptionsSelector';\nimport themeColors from '../../../styles/themes/default';\nimport * as Expensicons from '../../../components/Icon/Expensicons';\n\nconst greenCheckmark = {src: Expensicons.Checkmark, color: themeColors.success};\n\nconst propTypes = {\n ...withLocalizePropTypes,\n ...withCurrentUserPersonalDetailsPropTypes,\n};\n\nconst defaultProps = {\n ...withCurrentUserPersonalDetailsDefaultProps,\n};\n\nclass TimezoneSelectPage extends Component {\n constructor(props) {\n super(props);\n\n this.saveSelectedTimezone = this.saveSelectedTimezone.bind(this);\n this.filterShownTimezones = this.filterShownTimezones.bind(this);\n this.getTimezoneOption = this.getTimezoneOption.bind(this);\n\n this.timezone = this.getUserTimezone(props.currentUserPersonalDetails);\n this.allTimezones = _.chain(moment.tz.names())\n .filter(timezone => !timezone.startsWith('Etc/GMT'))\n .map(this.getTimezoneOption)\n .value();\n\n this.state = {\n timezoneInputText: this.timezone.selected,\n timezoneOptions: this.allTimezones,\n };\n }\n\n componentDidUpdate() {\n // componentDidUpdate is added in order to update the timezone options when automatic is toggled on/off as\n // navigating back doesn't unmount the page, thus it won't update the timezone options & stay disabled without this.\n const newTimezone = this.getUserTimezone(this.props.currentUserPersonalDetails);\n if (_.isEqual(this.timezone, newTimezone)) {\n return;\n }\n this.timezone = newTimezone;\n this.allTimezones = _.map(this.allTimezones, (timezone) => {\n const text = timezone.text.split('-')[0];\n return this.getTimezoneOption(text);\n });\n\n this.setState({\n timezoneInputText: this.timezone.selected,\n timezoneOptions: this.allTimezones,\n });\n }\n\n /**\n * We add the current time to the key to fix a bug where the list options don't update unless the key is updated.\n * @param {String} text\n * @return {string} key for list item\n */\n getKey(text) {\n return `${text}-${(new Date()).getTime()}`;\n }\n\n /**\n * Get timezone option object for the list.\n * @param {String} text\n * @return {Object} Timezone list option\n */\n getTimezoneOption(text) {\n return {\n text,\n keyForList: this.getKey(text),\n\n // Include the green checkmark icon to indicate the currently selected value\n customIcon: text === this.timezone.selected ? greenCheckmark : undefined,\n\n // This property will make the currently selected value have bold text\n boldStyle: text === this.timezone.selected,\n };\n }\n\n /**\n * @param {Object} currentUserPersonalDetails\n * @return {Object} user's timezone data\n */\n getUserTimezone(currentUserPersonalDetails) {\n return lodashGet(currentUserPersonalDetails, 'timezone', CONST.DEFAULT_TIME_ZONE);\n }\n\n /**\n * @param {Object} timezone\n * @param {String} timezone.text\n */\n saveSelectedTimezone({text}) {\n PersonalDetails.updateSelectedTimezone(text);\n }\n\n /**\n * @param {String} searchText\n */\n filterShownTimezones(searchText) {\n this.setState({\n timezoneInputText: searchText,\n timezoneOptions: _.filter(this.allTimezones, (tz => tz.text.toLowerCase().includes(searchText.trim().toLowerCase()))),\n });\n }\n\n render() {\n return (\n \n {({safeAreaPaddingBottomStyle}) => (\n <>\n Navigation.navigate(ROUTES.SETTINGS_TIMEZONE)}\n onCloseButtonPress={() => Navigation.dismissModal(true)}\n />\n tz.text === this.timezone.selected)[0], 'keyForList')}\n />\n \n )}\n \n );\n }\n}\n\nTimezoneSelectPage.propTypes = propTypes;\nTimezoneSelectPage.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withCurrentUserPersonalDetails,\n)(TimezoneSelectPage);\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport {ScrollView, View} from 'react-native';\nimport {withOnyx} from 'react-native-onyx';\nimport ScreenWrapper from '../../../../components/ScreenWrapper';\nimport HeaderWithCloseButton from '../../../../components/HeaderWithCloseButton';\nimport withLocalize, {withLocalizePropTypes} from '../../../../components/withLocalize';\nimport ROUTES from '../../../../ROUTES';\nimport Text from '../../../../components/Text';\nimport styles from '../../../../styles/styles';\nimport Navigation from '../../../../libs/Navigation/Navigation';\nimport compose from '../../../../libs/compose';\nimport MenuItemWithTopDescription from '../../../../components/MenuItemWithTopDescription';\nimport * as PersonalDetails from '../../../../libs/actions/PersonalDetails';\nimport ONYXKEYS from '../../../../ONYXKEYS';\n\nconst propTypes = {\n /* Onyx Props */\n\n /** User's private personal details */\n privatePersonalDetails: PropTypes.shape({\n legalFirstName: PropTypes.string,\n legalLastName: PropTypes.string,\n dob: PropTypes.string,\n\n /** User's home address */\n address: PropTypes.shape({\n street: PropTypes.string,\n city: PropTypes.string,\n state: PropTypes.string,\n zip: PropTypes.string,\n country: PropTypes.string,\n }),\n }),\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n privatePersonalDetails: {\n legalFirstName: '',\n legalLastName: '',\n dob: '',\n address: {\n street: '',\n street2: '',\n city: '',\n state: '',\n zip: '',\n country: '',\n },\n },\n};\n\nconst PersonalDetailsInitialPage = (props) => {\n PersonalDetails.openPersonalDetailsPage();\n\n const privateDetails = props.privatePersonalDetails || {};\n const address = privateDetails.address || {};\n const legalName = `${privateDetails.legalFirstName || ''} ${privateDetails.legalLastName || ''}`.trim();\n\n /**\n * Applies common formatting to each piece of an address\n *\n * @param {String} piece\n * @returns {String}\n */\n const formatPiece = piece => (piece ? `${piece}, ` : '');\n\n /**\n * Formats an address object into an easily readable string\n *\n * @returns {String}\n */\n const getFormattedAddress = () => {\n const [street1, street2] = (address.street || '').split('\\n');\n const formattedAddress = formatPiece(street1)\n + formatPiece(street2)\n + formatPiece(address.city)\n + formatPiece(address.state)\n + formatPiece(address.zip)\n + formatPiece(address.country);\n\n // Remove the last comma of the address\n return formattedAddress.trim().replace(/,$/, '');\n };\n\n return (\n \n Navigation.navigate(ROUTES.SETTINGS_PROFILE)}\n onCloseButtonPress={() => Navigation.dismissModal(true)}\n />\n \n \n \n \n {props.translate('privatePersonalDetails.privateDataMessage')}\n \n \n Navigation.navigate(ROUTES.SETTINGS_PERSONAL_DETAILS_LEGAL_NAME)}\n />\n Navigation.navigate(ROUTES.SETTINGS_PERSONAL_DETAILS_DATE_OF_BIRTH)}\n />\n Navigation.navigate(ROUTES.SETTINGS_PERSONAL_DETAILS_ADDRESS)}\n />\n \n \n \n );\n};\n\nPersonalDetailsInitialPage.propTypes = propTypes;\nPersonalDetailsInitialPage.defaultProps = defaultProps;\nPersonalDetailsInitialPage.displayName = 'PersonalDetailsInitialPage';\n\nexport default compose(\n withLocalize,\n withOnyx({\n privatePersonalDetails: {\n key: ONYXKEYS.PRIVATE_PERSONAL_DETAILS,\n },\n }),\n)(PersonalDetailsInitialPage);\n","import _ from 'underscore';\nimport React, {Component} from 'react';\nimport PropTypes from 'prop-types';\nimport {View} from 'react-native';\nimport {withOnyx} from 'react-native-onyx';\nimport ScreenWrapper from '../../../../components/ScreenWrapper';\nimport HeaderWithCloseButton from '../../../../components/HeaderWithCloseButton';\nimport withLocalize, {withLocalizePropTypes} from '../../../../components/withLocalize';\nimport ROUTES from '../../../../ROUTES';\nimport Form from '../../../../components/Form';\nimport ONYXKEYS from '../../../../ONYXKEYS';\nimport CONST from '../../../../CONST';\nimport * as ValidationUtils from '../../../../libs/ValidationUtils';\nimport TextInput from '../../../../components/TextInput';\nimport styles from '../../../../styles/styles';\nimport Navigation from '../../../../libs/Navigation/Navigation';\nimport * as PersonalDetails from '../../../../libs/actions/PersonalDetails';\nimport compose from '../../../../libs/compose';\n\nconst propTypes = {\n /* Onyx Props */\n\n /** User's private personal details */\n privatePersonalDetails: PropTypes.shape({\n legalFirstName: PropTypes.string,\n legalLastName: PropTypes.string,\n }),\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n privatePersonalDetails: {\n legalFirstName: '',\n legalLastName: '',\n },\n};\n\nclass LegalNamePage extends Component {\n constructor(props) {\n super(props);\n\n this.validate = this.validate.bind(this);\n this.updateLegalName = this.updateLegalName.bind(this);\n }\n\n /**\n * Submit form to update user's legal first and last name\n * @param {Object} values\n * @param {String} values.legalFirstName\n * @param {String} values.legalLastName\n */\n updateLegalName(values) {\n PersonalDetails.updateLegalName(\n values.legalFirstName.trim(),\n values.legalLastName.trim(),\n );\n }\n\n /**\n * @param {Object} values\n * @param {String} values.legalFirstName\n * @param {String} values.legalLastName\n * @returns {Object} - An object containing the errors for each inputID\n */\n validate(values) {\n const errors = {};\n\n if (!ValidationUtils.isValidLegalName(values.legalFirstName)) {\n errors.legalFirstName = this.props.translate('privatePersonalDetails.error.hasInvalidCharacter');\n } else if (_.isEmpty(values.legalFirstName)) {\n errors.legalFirstName = this.props.translate('common.error.fieldRequired');\n }\n\n if (!ValidationUtils.isValidLegalName(values.legalLastName)) {\n errors.legalLastName = this.props.translate('privatePersonalDetails.error.hasInvalidCharacter');\n } else if (_.isEmpty(values.legalLastName)) {\n errors.legalLastName = this.props.translate('common.error.fieldRequired');\n }\n\n return errors;\n }\n\n render() {\n const privateDetails = this.props.privatePersonalDetails || {};\n\n return (\n \n Navigation.navigate(ROUTES.SETTINGS_PERSONAL_DETAILS)}\n onCloseButtonPress={() => Navigation.dismissModal(true)}\n />\n \n \n \n \n \n \n \n \n \n );\n }\n}\n\nLegalNamePage.propTypes = propTypes;\nLegalNamePage.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withOnyx({\n privatePersonalDetails: {\n key: ONYXKEYS.PRIVATE_PERSONAL_DETAILS,\n },\n }),\n)(LegalNamePage);\n","import React, {Component} from 'react';\nimport PropTypes from 'prop-types';\nimport {withOnyx} from 'react-native-onyx';\nimport moment from 'moment';\nimport ScreenWrapper from '../../../../components/ScreenWrapper';\nimport HeaderWithCloseButton from '../../../../components/HeaderWithCloseButton';\nimport withLocalize, {withLocalizePropTypes} from '../../../../components/withLocalize';\nimport ROUTES from '../../../../ROUTES';\nimport Form from '../../../../components/Form';\nimport ONYXKEYS from '../../../../ONYXKEYS';\nimport * as ValidationUtils from '../../../../libs/ValidationUtils';\nimport styles from '../../../../styles/styles';\nimport Navigation from '../../../../libs/Navigation/Navigation';\nimport * as PersonalDetails from '../../../../libs/actions/PersonalDetails';\nimport compose from '../../../../libs/compose';\nimport NewDatePicker from '../../../../components/NewDatePicker';\nimport CONST from '../../../../CONST';\n\nconst propTypes = {\n /* Onyx Props */\n\n /** User's private personal details */\n privatePersonalDetails: PropTypes.shape({\n dob: PropTypes.string,\n }),\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n privatePersonalDetails: {\n dob: '',\n },\n};\n\nclass DateOfBirthPage extends Component {\n constructor(props) {\n super(props);\n\n this.validate = this.validate.bind(this);\n this.updateDateOfBirth = this.updateDateOfBirth.bind(this);\n this.getYearFromRouteParams = this.getYearFromRouteParams.bind(this);\n this.minDate = moment().subtract(CONST.DATE_BIRTH.MAX_AGE, 'Y').toDate();\n this.maxDate = moment().subtract(CONST.DATE_BIRTH.MIN_AGE, 'Y').toDate();\n\n this.state = {\n selectedYear: '',\n };\n }\n\n componentDidMount() {\n this.props.navigation.addListener('focus', this.getYearFromRouteParams);\n }\n\n componentWillUnmount() {\n this.props.navigation.removeListener('focus', this.getYearFromRouteParams);\n }\n\n /**\n * Function to be called to read year from params - necessary to read passed year from the Year picker which is a separate screen\n * It allows to display selected year in the calendar picker without overwriting this value in Onyx\n */\n getYearFromRouteParams() {\n const {params} = this.props.route;\n if (params && params.year) {\n this.setState({selectedYear: params.year});\n }\n }\n\n /**\n * Submit form to update user's first and last legal name\n * @param {Object} values\n * @param {String} values.dob - date of birth\n */\n updateDateOfBirth(values) {\n PersonalDetails.updateDateOfBirth(\n values.dob,\n );\n }\n\n /**\n * @param {Object} values\n * @param {String} values.dob - date of birth\n * @returns {Object} - An object containing the errors for each inputID\n */\n validate(values) {\n const errors = {};\n const minimumAge = CONST.DATE_BIRTH.MIN_AGE;\n const maximumAge = CONST.DATE_BIRTH.MAX_AGE;\n\n if (!values.dob || !ValidationUtils.isValidDate(values.dob)) {\n errors.dob = this.props.translate('common.error.fieldRequired');\n }\n const dateError = ValidationUtils.getAgeRequirementError(values.dob, minimumAge, maximumAge);\n if (dateError) {\n errors.dob = dateError;\n }\n\n return errors;\n }\n\n render() {\n const privateDetails = this.props.privatePersonalDetails || {};\n\n return (\n \n Navigation.navigate(ROUTES.SETTINGS_PERSONAL_DETAILS)}\n onCloseButtonPress={() => Navigation.dismissModal(true)}\n />\n \n \n \n \n );\n }\n}\n\nDateOfBirthPage.propTypes = propTypes;\nDateOfBirthPage.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withOnyx({\n privatePersonalDetails: {\n key: ONYXKEYS.PRIVATE_PERSONAL_DETAILS,\n },\n }),\n)(DateOfBirthPage);\n","import React from 'react';\nimport {View, Animated} from 'react-native';\nimport moment from 'moment';\nimport TextInput from '../TextInput';\nimport CalendarPicker from '../CalendarPicker';\nimport CONST from '../../CONST';\nimport styles from '../../styles/styles';\nimport * as Expensicons from '../Icon/Expensicons';\nimport {propTypes as datePickerPropTypes, defaultProps as defaultDatePickerProps} from './datePickerPropTypes';\nimport withLocalize, {withLocalizePropTypes} from '../withLocalize';\n\nconst propTypes = {\n ...withLocalizePropTypes,\n ...datePickerPropTypes,\n};\n\nconst datePickerDefaultProps = {\n ...defaultDatePickerProps,\n};\n\nclass NewDatePicker extends React.Component {\n constructor(props) {\n super(props);\n\n this.state = {\n isPickerVisible: false,\n selectedMonth: null,\n selectedDate: moment(props.value || props.defaultValue || undefined).toDate(),\n };\n\n this.setDate = this.setDate.bind(this);\n this.showPicker = this.showPicker.bind(this);\n this.setCurrentSelectedMonth = this.setCurrentSelectedMonth.bind(this);\n\n this.opacity = new Animated.Value(0);\n\n // We're using uncontrolled input otherwise it wont be possible to\n // raise change events with a date value - each change will produce a date\n // and make us reset the text input\n this.defaultValue = props.defaultValue\n ? moment(props.defaultValue).format(CONST.DATE.MOMENT_FORMAT_STRING)\n : '';\n }\n\n componentDidMount() {\n if (!this.props.autoFocus) {\n return;\n }\n this.showPicker();\n }\n\n /**\n * Updates selected month when year picker is opened.\n * This is used to keep the last visible month in the calendar when going back from year picker screen.\n * @param {Date} currentDateView\n */\n setCurrentSelectedMonth(currentDateView) {\n this.setState({selectedMonth: currentDateView.getMonth()});\n }\n\n /**\n * Trigger the `onInputChange` handler when the user input has a complete date or is cleared\n * @param {Date} selectedDate\n */\n setDate(selectedDate) {\n this.setState({selectedDate}, () => {\n this.props.onInputChange(moment(selectedDate).format(CONST.DATE.MOMENT_FORMAT_STRING));\n });\n }\n\n /**\n * Function to animate showing the picker.\n */\n showPicker() {\n this.setState({isPickerVisible: true}, () => {\n Animated.timing(this.opacity, {\n toValue: 1,\n duration: 100,\n useNativeDriver: true,\n }).start();\n });\n }\n\n render() {\n return (\n \n \n \n \n {\n this.state.isPickerVisible && (\n \n \n \n )\n }\n \n );\n }\n}\n\nNewDatePicker.propTypes = propTypes;\nNewDatePicker.defaultProps = datePickerDefaultProps;\n\nexport default withLocalize(NewDatePicker);\n","import _ from 'underscore';\nimport React from 'react';\nimport {View, TouchableOpacity, Pressable} from 'react-native';\nimport moment from 'moment';\nimport Str from 'expensify-common/lib/str';\nimport Text from '../Text';\nimport ArrowIcon from './ArrowIcon';\nimport styles from '../../styles/styles';\nimport {propTypes as calendarPickerPropType, defaultProps as defaultCalendarPickerPropType} from './calendarPickerPropTypes';\nimport generateMonthMatrix from './generateMonthMatrix';\nimport withLocalize from '../withLocalize';\nimport Navigation from '../../libs/Navigation/Navigation';\nimport ROUTES from '../../ROUTES';\nimport CONST from '../../CONST';\nimport getButtonState from '../../libs/getButtonState';\nimport * as StyleUtils from '../../styles/StyleUtils';\n\nclass CalendarPicker extends React.PureComponent {\n constructor(props) {\n super(props);\n\n this.monthNames = _.map(moment.localeData(props.preferredLocale).months(), Str.recapitalize);\n this.daysOfWeek = _.map(moment.localeData(props.preferredLocale).weekdays(), day => day.toUpperCase());\n\n let currentDateView = props.value;\n if (props.selectedYear) {\n currentDateView = moment(currentDateView).set('year', props.selectedYear).toDate();\n }\n if (props.selectedMonth != null) {\n currentDateView = moment(currentDateView).set('month', props.selectedMonth).toDate();\n }\n if (props.maxDate < currentDateView) {\n currentDateView = props.maxDate;\n } else if (props.minDate > currentDateView) {\n currentDateView = props.minDate;\n }\n\n this.state = {\n currentDateView,\n };\n\n this.moveToPrevMonth = this.moveToPrevMonth.bind(this);\n this.moveToNextMonth = this.moveToNextMonth.bind(this);\n this.onYearPickerPressed = this.onYearPickerPressed.bind(this);\n this.onDayPressed = this.onDayPressed.bind(this);\n }\n\n componentDidMount() {\n if (this.props.minDate <= this.props.maxDate) {\n return;\n }\n throw new Error('Minimum date cannot be greater than the maximum date.');\n }\n\n componentDidUpdate(prevProps) {\n // Check if selectedYear has changed\n if (this.props.selectedYear === prevProps.selectedYear) {\n return;\n }\n\n // If the selectedYear prop has changed, update the currentDateView state with the new year value\n this.setState(prev => ({currentDateView: moment(prev.currentDateView).set('year', this.props.selectedYear).toDate()}));\n }\n\n /**\n * Handles the user pressing the year picker button.\n * Opens the year selection screen with the minimum and maximum year range\n * based on the props, the current year based on the state, and the active route.\n */\n onYearPickerPressed() {\n const minYear = moment(this.props.minDate).year();\n const maxYear = moment(this.props.maxDate).year();\n const currentYear = this.state.currentDateView.getFullYear();\n Navigation.navigate(ROUTES.getYearSelectionRoute(minYear, maxYear, currentYear, Navigation.getActiveRoute()));\n this.props.onYearPickerOpen(this.state.currentDateView);\n }\n\n /**\n * Calls the onSelected function with the selected date.\n * @param {Number} day - The day of the month that was selected.\n */\n onDayPressed(day) {\n const selectedDate = new Date(this.state.currentDateView.getFullYear(), this.state.currentDateView.getMonth(), day);\n this.props.onSelected(selectedDate);\n }\n\n moveToPrevMonth() {\n this.setState(prev => ({currentDateView: moment(prev.currentDateView).subtract(1, 'M').toDate()}));\n }\n\n moveToNextMonth() {\n this.setState(prev => ({currentDateView: moment(prev.currentDateView).add(1, 'M').toDate()}));\n }\n\n render() {\n const currentMonthView = this.state.currentDateView.getMonth();\n const currentYearView = this.state.currentDateView.getFullYear();\n const calendarDaysMatrix = generateMonthMatrix(currentYearView, currentMonthView);\n const hasAvailableDatesNextMonth = moment(this.props.maxDate).endOf('month').startOf('day') > moment(this.state.currentDateView).add(1, 'M');\n const hasAvailableDatesPrevMonth = moment(this.props.minDate).startOf('day') < moment(this.state.currentDateView).subtract(1, 'M').endOf('month');\n\n return (\n \n \n \n {currentYearView}\n \n \n \n \n {this.monthNames[currentMonthView]}\n \n \n \n \n \n \n \n \n \n \n {_.map(this.daysOfWeek, (dayOfWeek => (\n \n {dayOfWeek[0]}\n \n )))}\n \n {_.map(calendarDaysMatrix, week => (\n \n {_.map(week, (day, index) => {\n const currentDate = moment([currentYearView, currentMonthView, day]);\n const isBeforeMinDate = currentDate < moment(this.props.minDate).startOf('day');\n const isAfterMaxDate = currentDate > moment(this.props.maxDate).startOf('day');\n const isDisabled = !day || isBeforeMinDate || isAfterMaxDate;\n const isSelected = moment(this.props.value).isSame(moment([currentYearView, currentMonthView, day]), 'day');\n\n return (\n this.onDayPressed(day)}\n style={styles.calendarDayRoot}\n accessibilityLabel={day ? day.toString() : undefined}\n >\n {({hovered, pressed}) => (\n \n {day}\n \n )}\n \n );\n })}\n \n ))}\n \n );\n }\n}\n\nCalendarPicker.propTypes = calendarPickerPropType;\nCalendarPicker.defaultProps = defaultCalendarPickerPropType;\n\nexport default withLocalize(CalendarPicker);\n","import React from 'react';\nimport {View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport styles from '../../styles/styles';\nimport * as Expensicons from '../Icon/Expensicons';\nimport * as StyleUtils from '../../styles/StyleUtils';\nimport Icon from '../Icon';\nimport CONST from '../../CONST';\n\nconst propTypes = {\n /** Specifies if the arrow icon should be disabled or not. */\n disabled: PropTypes.bool,\n\n /** Specifies direction of icon */\n direction: PropTypes.oneOf([CONST.DIRECTION.LEFT, CONST.DIRECTION.RIGHT]),\n};\n\nconst defaultProps = {\n disabled: false,\n direction: CONST.DIRECTION.RIGHT,\n};\n\nconst ArrowIcon = props => (\n \n \n \n);\n\nArrowIcon.displayName = 'ArrowIcon';\nArrowIcon.propTypes = propTypes;\nArrowIcon.defaultProps = defaultProps;\n\nexport default ArrowIcon;\n","import moment from 'moment';\nimport CONST from '../../CONST';\n\n/**\n * Generates a matrix representation of a month's calendar given the year and month.\n *\n * @param {Number} year - The year for which to generate the month matrix.\n * @param {Number} month - The month (0-indexed) for which to generate the month matrix.\n * @returns {Array>} - A 2D array of the month's calendar days, with null values representing days outside the current month.\n */\nexport default function generateMonthMatrix(year, month) {\n if (typeof year !== 'number') {\n throw new TypeError('Year must be a number');\n }\n if (year < 0) {\n throw new Error('Year cannot be less than 0');\n }\n if (typeof month !== 'number') {\n throw new TypeError('Month must be a number');\n }\n if (month < 0) {\n throw new Error('Month cannot be less than 0');\n }\n if (month > 11) {\n throw new Error('Month cannot be greater than 11');\n }\n\n // Get the number of days in the month and the first day of the month\n const daysInMonth = moment([year, month]).daysInMonth();\n const firstDay = moment([year, month, 1]).locale(CONST.LOCALES.EN);\n\n // Create a matrix to hold the calendar days\n const matrix = [];\n let currentWeek = [];\n\n // Add null values for days before the first day of the month\n for (let i = 0; i < firstDay.weekday(); i++) {\n currentWeek.push(null);\n }\n\n // Add calendar days to the matrix\n for (let i = 1; i <= daysInMonth; i++) {\n const day = moment([year, month, i]).locale(CONST.LOCALES.EN);\n currentWeek.push(day.date());\n\n // Start a new row when the current week is full\n if (day.weekday() === 6) {\n matrix.push(currentWeek);\n currentWeek = [];\n }\n }\n\n // Add null values for days after the last day of the month\n if (currentWeek.length > 0) {\n for (let i = currentWeek.length; i < 7; i++) {\n currentWeek.push(null);\n }\n matrix.push(currentWeek);\n }\n return matrix;\n}\n","import PropTypes from 'prop-types';\nimport moment from 'moment';\nimport CONST from '../../CONST';\n\nconst propTypes = {\n /** An initial value of date */\n value: PropTypes.objectOf(Date),\n\n /** A minimum date (oldest) allowed to select */\n minDate: PropTypes.objectOf(Date),\n\n /** A maximum date (earliest) allowed to select */\n maxDate: PropTypes.objectOf(Date),\n\n /** Default year to be set in the calendar picker. Used with navigation to set the correct year after going back to the view with calendar */\n selectedYear: PropTypes.string,\n\n /** Default month to be set in the calendar picker. Used to keep last selected month after going back to the view with calendar */\n selectedMonth: PropTypes.number,\n\n /** A function that is called when the date changed inside the calendar component */\n onChanged: PropTypes.func,\n\n /** A function called when the date is selected */\n onSelected: PropTypes.func,\n\n /** A function called when the year picker is opened */\n onYearPickerOpen: PropTypes.func,\n};\n\nconst defaultProps = {\n value: new Date(),\n minDate: moment().year(CONST.CALENDAR_PICKER.MIN_YEAR).toDate(),\n maxDate: moment().year(CONST.CALENDAR_PICKER.MAX_YEAR).toDate(),\n selectedYear: null,\n selectedMonth: null,\n onChanged: () => {},\n onSelected: () => {},\n onYearPickerOpen: () => {},\n};\n\nexport {propTypes, defaultProps};\n","import PropTypes from 'prop-types';\nimport moment from 'moment';\nimport {\n propTypes as baseTextInputPropTypes,\n defaultProps as defaultBaseTextInputPropTypes,\n} from '../TextInput/baseTextInputPropTypes';\nimport CONST from '../../CONST';\n\nconst propTypes = {\n ...baseTextInputPropTypes,\n\n /**\n * The datepicker supports any value that `moment` can parse.\n * `onInputChange` would always be called with a Date (or null)\n */\n value: PropTypes.oneOfType([PropTypes.instanceOf(Date), PropTypes.string]),\n\n /**\n * The datepicker supports any defaultValue that `moment` can parse.\n * `onInputChange` would always be called with a Date (or null)\n */\n defaultValue: PropTypes.oneOfType([PropTypes.instanceOf(Date), PropTypes.string]),\n\n /** A minimum date of calendar to select */\n minDate: PropTypes.objectOf(Date),\n\n /** A maximum date of calendar to select */\n maxDate: PropTypes.objectOf(Date),\n\n /** Default year to be set in the calendar picker */\n selectedYear: PropTypes.string,\n};\n\nconst defaultProps = {\n ...defaultBaseTextInputPropTypes,\n minDate: moment().year(CONST.CALENDAR_PICKER.MIN_YEAR).toDate(),\n maxDate: moment().year(CONST.CALENDAR_PICKER.MAX_YEAR).toDate(),\n value: undefined,\n};\n\nexport {propTypes, defaultProps};\n","import lodashGet from 'lodash/get';\nimport _ from 'underscore';\nimport React, {Component} from 'react';\nimport PropTypes from 'prop-types';\nimport {View} from 'react-native';\nimport {CONST as COMMON_CONST} from 'expensify-common/lib/CONST';\nimport {withOnyx} from 'react-native-onyx';\nimport ScreenWrapper from '../../../../components/ScreenWrapper';\nimport HeaderWithCloseButton from '../../../../components/HeaderWithCloseButton';\nimport withLocalize, {withLocalizePropTypes} from '../../../../components/withLocalize';\nimport ROUTES from '../../../../ROUTES';\nimport Form from '../../../../components/Form';\nimport ONYXKEYS from '../../../../ONYXKEYS';\nimport CONST from '../../../../CONST';\nimport TextInput from '../../../../components/TextInput';\nimport styles from '../../../../styles/styles';\nimport Navigation from '../../../../libs/Navigation/Navigation';\nimport * as PersonalDetails from '../../../../libs/actions/PersonalDetails';\nimport * as ValidationUtils from '../../../../libs/ValidationUtils';\nimport compose from '../../../../libs/compose';\nimport AddressSearch from '../../../../components/AddressSearch';\nimport CountryPicker from '../../../../components/CountryPicker';\nimport StatePicker from '../../../../components/StatePicker';\n\nconst propTypes = {\n /* Onyx Props */\n\n /** User's private personal details */\n privatePersonalDetails: PropTypes.shape({\n /** User's home address */\n address: PropTypes.shape({\n street: PropTypes.string,\n city: PropTypes.string,\n state: PropTypes.string,\n zip: PropTypes.string,\n country: PropTypes.string,\n }),\n }),\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n privatePersonalDetails: {\n address: {\n street: '',\n city: '',\n state: '',\n zip: '',\n country: '',\n },\n },\n};\n\nclass AddressPage extends Component {\n constructor(props) {\n super(props);\n\n this.validate = this.validate.bind(this);\n this.updateAddress = this.updateAddress.bind(this);\n this.onCountryUpdate = this.onCountryUpdate.bind(this);\n\n const currentCountry = lodashGet(this.props.privatePersonalDetails, 'address.country') || '';\n const currentCountryISO = PersonalDetails.getCountryISO(currentCountry) || CONST.COUNTRY.US;\n const zipSampleFormat = lodashGet(CONST.COUNTRY_ZIP_REGEX_DATA, [currentCountryISO, 'samples'], '');\n this.state = {\n isUsaForm: (currentCountry === CONST.COUNTRY.US || currentCountry === CONST.USA_COUNTRY_NAME),\n zipFormat: this.props.translate('common.zipCodeExampleFormat', {zipSampleFormat}),\n };\n }\n\n /**\n * @param {String} newCountry - new country selected in form\n */\n onCountryUpdate(newCountry) {\n const zipSampleFormat = lodashGet(CONST.COUNTRY_ZIP_REGEX_DATA, `${newCountry}.samples`, '');\n this.setState({\n isUsaForm: newCountry === CONST.COUNTRY.US,\n zipFormat: this.props.translate('common.zipCodeExampleFormat', {zipSampleFormat}),\n });\n }\n\n /**\n * Submit form to update user's first and last legal name\n * @param {Object} values - form input values\n */\n updateAddress(values) {\n PersonalDetails.updateAddress(\n values.addressLine1.trim(),\n values.addressLine2.trim(),\n values.city.trim(),\n values.state.trim(),\n values.zipPostCode.trim(),\n values.country,\n );\n }\n\n /**\n * @param {Object} values - form input values\n * @returns {Object} - An object containing the errors for each inputID\n */\n validate(values) {\n const errors = {};\n\n const requiredFields = [\n 'addressLine1',\n 'city',\n 'country',\n 'state',\n ];\n\n // Check \"State\" dropdown is a valid state if selected Country is USA.\n if (this.state.isUsaForm && !COMMON_CONST.STATES[values.state]) {\n errors.state = this.props.translate('common.error.fieldRequired');\n }\n\n // Add \"Field required\" errors if any required field is empty\n _.each(requiredFields, (fieldKey) => {\n if (ValidationUtils.isRequiredFulfilled(values[fieldKey])) {\n return;\n }\n errors[fieldKey] = this.props.translate('common.error.fieldRequired');\n });\n\n // If no country is selected, default value is an empty string and there's no related regex data so we default to an empty object\n const countryRegexDetails = lodashGet(CONST.COUNTRY_ZIP_REGEX_DATA, values.country, {});\n\n // The postal code system might not exist for a country, so no regex either for them.\n const countrySpecificZipRegex = lodashGet(countryRegexDetails, 'regex');\n const zipFormat = lodashGet(countryRegexDetails, 'samples');\n\n if (countrySpecificZipRegex) {\n if (!countrySpecificZipRegex.test(values.zipPostCode.trim())) {\n if (ValidationUtils.isRequiredFulfilled(values.zipPostCode.trim())) {\n errors.zipPostCode = this.props.translate('privatePersonalDetails.error.incorrectZipFormat', {zipFormat});\n } else {\n errors.zipPostCode = this.props.translate('common.error.fieldRequired');\n }\n }\n } else if (!CONST.GENERIC_ZIP_CODE_REGEX.test(values.zipPostCode.trim())) {\n errors.zipPostCode = this.props.translate('privatePersonalDetails.error.incorrectZipFormat');\n }\n\n return errors;\n }\n\n render() {\n const address = lodashGet(this.props.privatePersonalDetails, 'address') || {};\n const [street1, street2] = (address.street || '').split('\\n');\n\n return (\n \n Navigation.navigate(ROUTES.SETTINGS_PERSONAL_DETAILS)}\n onCloseButtonPress={() => Navigation.dismissModal(true)}\n />\n \n \n \n \n \n \n \n \n \n \n \n {this.state.isUsaForm ? (\n \n ) : (\n \n )}\n \n \n \n \n \n \n \n \n \n );\n }\n}\n\nAddressPage.propTypes = propTypes;\nAddressPage.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withOnyx({\n privatePersonalDetails: {\n key: ONYXKEYS.PRIVATE_PERSONAL_DETAILS,\n },\n }),\n)(AddressPage);\n","import _ from 'underscore';\nimport React, {forwardRef} from 'react';\nimport PropTypes from 'prop-types';\nimport Picker from './Picker';\nimport withLocalize, {withLocalizePropTypes} from './withLocalize';\n\nconst propTypes = {\n /** The label for the field */\n label: PropTypes.string,\n\n /** A callback method that is called when the value changes and it receives the selected value as an argument. */\n onInputChange: PropTypes.func.isRequired,\n\n /** The value that needs to be selected */\n value: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n\n /** The ID used to uniquely identify the input in a form */\n inputID: PropTypes.string,\n\n /** Saves a draft of the input value when used in a form */\n shouldSaveDraft: PropTypes.bool,\n\n /** Callback that is called when the text input is blurred */\n onBlur: PropTypes.func,\n\n /** Error text to display */\n errorText: PropTypes.string,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n label: '',\n value: undefined,\n errorText: '',\n shouldSaveDraft: false,\n inputID: undefined,\n onBlur: () => {},\n};\n\nconst CountryPicker = forwardRef((props, ref) => {\n const COUNTRIES = _.map(props.translate('allCountries'), (countryName, countryISO) => ({\n value: countryISO,\n label: countryName,\n }));\n\n return (\n \n );\n});\n\nCountryPicker.propTypes = propTypes;\nCountryPicker.defaultProps = defaultProps;\nCountryPicker.displayName = 'CountryPicker';\n\nexport default withLocalize(CountryPicker);\n","import Str from 'expensify-common/lib/str';\nimport lodashGet from 'lodash/get';\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport {View} from 'react-native';\nimport {ScrollView} from 'react-native-gesture-handler';\nimport {withOnyx} from 'react-native-onyx';\nimport _ from 'underscore';\nimport Button from '../../../../components/Button';\nimport HeaderWithCloseButton from '../../../../components/HeaderWithCloseButton';\nimport ScreenWrapper from '../../../../components/ScreenWrapper';\nimport withLocalize, {withLocalizePropTypes} from '../../../../components/withLocalize';\nimport CONST from '../../../../CONST';\nimport compose from '../../../../libs/compose';\nimport Navigation from '../../../../libs/Navigation/Navigation';\nimport ONYXKEYS from '../../../../ONYXKEYS';\nimport ROUTES from '../../../../ROUTES';\nimport styles from '../../../../styles/styles';\nimport MenuItem from '../../../../components/MenuItem';\nimport Text from '../../../../components/Text';\nimport CopyTextToClipboard from '../../../../components/CopyTextToClipboard';\nimport OfflineWithFeedback from '../../../../components/OfflineWithFeedback';\nimport FixedFooter from '../../../../components/FixedFooter';\n\nconst propTypes = {\n /* Onyx Props */\n\n /** Login list for the user that is signed in */\n loginList: PropTypes.shape({\n /** The partner creating the account. It depends on the source: website, mobile, integrations, ... */\n partnerName: PropTypes.string,\n\n /** Phone/Email associated with user */\n partnerUserID: PropTypes.string,\n\n /** The date when the login was validated, used to show the brickroad status */\n validatedDate: PropTypes.string,\n\n /** Field-specific server side errors keyed by microtime */\n errorFields: PropTypes.objectOf(PropTypes.objectOf(PropTypes.string)),\n\n /** Field-specific pending states for offline UI status */\n pendingFields: PropTypes.objectOf(PropTypes.objectOf(PropTypes.string)),\n }),\n\n /** Current user session */\n session: PropTypes.shape({\n email: PropTypes.string.isRequired,\n }),\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n loginList: {},\n session: {\n email: null,\n },\n};\n\nconst ContactMethodsPage = (props) => {\n const loginMenuItems = _.map(props.loginList, (login, loginName) => {\n const pendingAction = lodashGet(login, 'pendingFields.deletedLogin') || lodashGet(login, 'pendingFields.addedLogin');\n if (!login.partnerUserID && _.isEmpty(pendingAction)) {\n return null;\n }\n\n let description = '';\n if (props.session.email === login.partnerUserID) {\n description = props.translate('contacts.getInTouch');\n } else if (lodashGet(login, 'errorFields.addedLogin')) {\n description = props.translate('contacts.failedNewContact');\n } else if (!login.validatedDate) {\n description = props.translate('contacts.pleaseVerify');\n }\n let indicator = null;\n if (_.some(lodashGet(login, 'errorFields', {}), errorField => !_.isEmpty(errorField))) {\n indicator = CONST.BRICK_ROAD_INDICATOR_STATUS.ERROR;\n } else if (!login.validatedDate) {\n indicator = CONST.BRICK_ROAD_INDICATOR_STATUS.INFO;\n }\n\n // Default to using login key if we deleted login.partnerUserID optimistically\n // but still need to show the pending login being deleted while offline.\n const partnerUserID = login.partnerUserID || loginName;\n return (\n \n Navigation.navigate(ROUTES.getEditContactMethodRoute(partnerUserID))}\n brickRoadIndicator={indicator}\n shouldShowBasicTitle\n shouldShowRightIcon\n disabled={!_.isEmpty(pendingAction)}\n />\n \n );\n });\n\n return (\n \n Navigation.navigate(ROUTES.SETTINGS_PROFILE)}\n onCloseButtonPress={() => Navigation.dismissModal(true)}\n />\n \n \n \n {props.translate('contacts.helpTextBeforeEmail')}\n \n {props.translate('contacts.helpTextAfterEmail')}\n \n \n {loginMenuItems}\n \n \n Navigation.navigate(ROUTES.SETTINGS_NEW_CONTACT_METHOD)}\n pressOnEnter\n />\n \n \n );\n};\n\nContactMethodsPage.propTypes = propTypes;\nContactMethodsPage.defaultProps = defaultProps;\nContactMethodsPage.displayName = 'ContactMethodsPage';\n\nexport default compose(\n withLocalize,\n withOnyx({\n loginList: {\n key: ONYXKEYS.LOGIN_LIST,\n },\n session: {\n key: ONYXKEYS.SESSION,\n },\n }),\n)(ContactMethodsPage);\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport Text from './Text';\nimport * as Expensicons from './Icon/Expensicons';\nimport Clipboard from '../libs/Clipboard';\nimport Icon from './Icon';\nimport Tooltip from './Tooltip';\nimport styles from '../styles/styles';\nimport themeColors from '../styles/themes/default';\nimport variables from '../styles/variables';\nimport withLocalize, {withLocalizePropTypes} from './withLocalize';\n\nconst propTypes = {\n /** The text to display and copy to the clipboard */\n text: PropTypes.string.isRequired,\n\n /** Styles to apply to the text */\n // eslint-disable-next-line react/forbid-prop-types\n textStyles: PropTypes.arrayOf(PropTypes.object),\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n textStyles: [],\n};\n\nclass CopyTextToClipboard extends React.Component {\n constructor(props) {\n super(props);\n\n this.copyToClipboard = this.copyToClipboard.bind(this);\n\n this.state = {\n showCheckmark: false,\n };\n }\n\n componentWillUnmount() {\n // Clear the interval when the component unmounts so that if the user navigates\n // away quickly, then setState() won't try to update a component that's been unmounted\n clearInterval(this.showCheckmarkInterval);\n }\n\n copyToClipboard() {\n Clipboard.setString(this.props.text);\n this.setState({showCheckmark: true}, () => {\n this.showCheckmarkInterval = setTimeout(() => {\n this.setState({showCheckmark: false});\n }, 2000);\n });\n }\n\n render() {\n return (\n \n {this.props.text}\n \n \n \n \n );\n }\n}\n\nCopyTextToClipboard.propTypes = propTypes;\nCopyTextToClipboard.defaultProps = defaultProps;\n\nexport default withLocalize(CopyTextToClipboard);\n","import Str from 'expensify-common/lib/str';\nimport lodashGet from 'lodash/get';\nimport _ from 'underscore';\nimport React, {Component} from 'react';\nimport {View, ScrollView} from 'react-native';\nimport PropTypes from 'prop-types';\nimport {withOnyx} from 'react-native-onyx';\nimport Navigation from '../../../../libs/Navigation/Navigation';\nimport ROUTES from '../../../../ROUTES';\nimport ScreenWrapper from '../../../../components/ScreenWrapper';\nimport HeaderWithCloseButton from '../../../../components/HeaderWithCloseButton';\nimport compose from '../../../../libs/compose';\nimport ONYXKEYS from '../../../../ONYXKEYS';\nimport withLocalize, {withLocalizePropTypes} from '../../../../components/withLocalize';\nimport MenuItem from '../../../../components/MenuItem';\nimport styles from '../../../../styles/styles';\nimport * as Expensicons from '../../../../components/Icon/Expensicons';\nimport Text from '../../../../components/Text';\nimport OfflineWithFeedback from '../../../../components/OfflineWithFeedback';\nimport DotIndicatorMessage from '../../../../components/DotIndicatorMessage';\nimport ConfirmModal from '../../../../components/ConfirmModal';\nimport * as User from '../../../../libs/actions/User';\nimport TextInput from '../../../../components/TextInput';\nimport CONST from '../../../../CONST';\nimport Icon from '../../../../components/Icon';\nimport colors from '../../../../styles/colors';\nimport Button from '../../../../components/Button';\nimport * as ErrorUtils from '../../../../libs/ErrorUtils';\nimport themeColors from '../../../../styles/themes/default';\nimport NotFoundPage from '../../../ErrorPage/NotFoundPage';\nimport * as ValidationUtils from '../../../../libs/ValidationUtils';\n\nconst propTypes = {\n /* Onyx Props */\n\n /** Login list for the user that is signed in */\n loginList: PropTypes.shape({\n /** Value of partner name */\n partnerName: PropTypes.string,\n\n /** Phone/Email associated with user */\n partnerUserID: PropTypes.string,\n\n /** Date when login was validated */\n validatedDate: PropTypes.string,\n\n /** Field-specific server side errors keyed by microtime */\n errorFields: PropTypes.objectOf(PropTypes.objectOf(PropTypes.string)),\n\n /** Field-specific pending states for offline UI status */\n pendingFields: PropTypes.objectOf(PropTypes.objectOf(PropTypes.string)),\n }),\n\n /** Current user session */\n session: PropTypes.shape({\n email: PropTypes.string.isRequired,\n }),\n\n /** Route params */\n route: PropTypes.shape({\n params: PropTypes.shape({\n /** Passed via route /settings/profile/contact-methods/:contactMethod/details */\n contactMethod: PropTypes.string,\n }),\n }),\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n loginList: {},\n session: {\n email: null,\n },\n route: {\n params: {\n contactMethod: '',\n },\n },\n};\n\nclass ContactMethodDetailsPage extends Component {\n constructor(props) {\n super(props);\n\n this.deleteContactMethod = this.deleteContactMethod.bind(this);\n this.toggleDeleteModal = this.toggleDeleteModal.bind(this);\n this.confirmDeleteAndHideModal = this.confirmDeleteAndHideModal.bind(this);\n this.resendValidateCode = this.resendValidateCode.bind(this);\n this.getContactMethod = this.getContactMethod.bind(this);\n this.validateAndSubmitCode = this.validateAndSubmitCode.bind(this);\n\n this.state = {\n formError: '',\n isDeleteModalOpen: false,\n validateCode: '',\n };\n }\n\n /**\n * Gets the current contact method from the route params\n *\n * @returns {string}\n */\n getContactMethod() {\n return decodeURIComponent(lodashGet(this.props.route, 'params.contactMethod'));\n }\n\n /**\n * Deletes the contact method if it has errors. Otherwise, it shows the confirmation alert and deletes it only if the user confirms.\n */\n deleteContactMethod() {\n if (!_.isEmpty(lodashGet(this.props.loginList, [this.getContactMethod(), 'errorFields'], {}))) {\n User.deleteContactMethod(this.getContactMethod());\n return;\n }\n this.toggleDeleteModal(true);\n }\n\n /**\n * Toggle delete confirm modal visibility\n * @param {Boolean} isOpen\n */\n toggleDeleteModal(isOpen) {\n this.setState({isDeleteModalOpen: isOpen});\n }\n\n /**\n * Delete the contact method and hide the modal\n */\n confirmDeleteAndHideModal() {\n this.toggleDeleteModal(false);\n User.deleteContactMethod(this.getContactMethod());\n }\n\n /**\n * Request a validate code / magic code be sent to verify this contact method\n */\n resendValidateCode() {\n User.requestContactMethodValidateCode(this.getContactMethod());\n }\n\n /**\n * Attempt to validate this contact method\n */\n validateAndSubmitCode() {\n if (!this.state.validateCode) {\n this.setState({formError: 'validateCodeForm.error.pleaseFillMagicCode'});\n } else if (!ValidationUtils.isValidValidateCode(this.state.validateCode)) {\n this.setState({formError: 'validateCodeForm.error.incorrectMagicCode'});\n } else {\n this.setState({formError: ''});\n User.validateSecondaryLogin(this.getContactMethod(), this.state.validateCode);\n }\n }\n\n render() {\n const contactMethod = this.getContactMethod();\n const loginData = this.props.loginList[contactMethod];\n if (!contactMethod || !loginData) {\n return ;\n }\n\n const isDefaultContactMethod = this.props.session.email === loginData.partnerUserID;\n const hasMagicCodeBeenSent = lodashGet(this.props.loginList, [contactMethod, 'validateCodeSent'], false);\n const formErrorText = this.state.formError ? this.props.translate(this.state.formError) : '';\n const isFailedAddContactMethod = Boolean(lodashGet(loginData, 'errorFields.addedLogin'));\n\n return (\n \n Navigation.navigate(ROUTES.SETTINGS_CONTACT_METHODS)}\n onCloseButtonPress={() => Navigation.dismissModal(true)}\n />\n \n this.toggleDeleteModal(false)}\n prompt={this.props.translate('contacts.removeAreYouSure')}\n confirmText={this.props.translate('common.yesContinue')}\n isVisible={this.state.isDeleteModalOpen}\n danger\n />\n {isFailedAddContactMethod && }\n {!loginData.validatedDate && !isFailedAddContactMethod && (\n \n \n \n \n \n {this.props.translate('contacts.enterMagicCode', {contactMethod})}\n \n \n \n this.setState({validateCode: text})}\n keyboardType={CONST.KEYBOARD_TYPE.NUMBER_PAD}\n errorText={formErrorText}\n />\n User.clearContactMethodErrors(contactMethod, 'validateCodeSent')}\n >\n \n \n {this.props.translate('contacts.resendMagicCode')}\n \n {hasMagicCodeBeenSent && (\n \n )}\n \n \n User.clearContactMethodErrors(contactMethod, 'validateLogin')}\n >\n \n \n \n )}\n {isDefaultContactMethod ? (\n \n {this.props.translate('contacts.yourDefaultContactMethod')}\n \n ) : (\n User.clearContactMethodErrors(contactMethod, 'deletedLogin')}\n >\n \n \n )}\n \n \n );\n }\n}\n\nContactMethodDetailsPage.propTypes = propTypes;\nContactMethodDetailsPage.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withOnyx({\n loginList: {\n key: ONYXKEYS.LOGIN_LIST,\n },\n session: {\n key: ONYXKEYS.SESSION,\n },\n }),\n)(ContactMethodDetailsPage);\n","import React, {Component} from 'react';\nimport PropTypes from 'prop-types';\nimport {View} from 'react-native';\nimport {ScrollView} from 'react-native-gesture-handler';\nimport {withOnyx} from 'react-native-onyx';\nimport {compose} from 'underscore';\nimport lodashGet from 'lodash/get';\nimport Str from 'expensify-common/lib/str';\nimport Button from '../../../../components/Button';\nimport FixedFooter from '../../../../components/FixedFooter';\nimport HeaderWithCloseButton from '../../../../components/HeaderWithCloseButton';\nimport ScreenWrapper from '../../../../components/ScreenWrapper';\nimport Text from '../../../../components/Text';\nimport TextInput from '../../../../components/TextInput';\nimport withLocalize, {withLocalizePropTypes} from '../../../../components/withLocalize';\nimport Navigation from '../../../../libs/Navigation/Navigation';\nimport Permissions from '../../../../libs/Permissions';\nimport ONYXKEYS from '../../../../ONYXKEYS';\nimport ROUTES from '../../../../ROUTES';\nimport styles from '../../../../styles/styles';\nimport * as User from '../../../../libs/actions/User';\nimport * as LoginUtils from '../../../../libs/LoginUtils';\n\nconst propTypes = {\n /* Onyx Props */\n\n /** List of betas available to current user */\n betas: PropTypes.arrayOf(PropTypes.string),\n\n /** Login list for the user that is signed in */\n loginList: PropTypes.shape({\n /** The partner creating the account. It depends on the source: website, mobile, integrations, ... */\n partnerName: PropTypes.string,\n\n /** Phone/Email associated with user */\n partnerUserID: PropTypes.string,\n\n /** The date when the login was validated, used to show the brickroad status */\n validatedDate: PropTypes.string,\n\n /** Field-specific server side errors keyed by microtime */\n errorFields: PropTypes.objectOf(PropTypes.objectOf(PropTypes.string)),\n\n /** Field-specific pending states for offline UI status */\n pendingFields: PropTypes.objectOf(PropTypes.objectOf(PropTypes.string)),\n }),\n\n ...withLocalizePropTypes,\n};\nconst defaultProps = {\n betas: [],\n loginList: {},\n};\n\nclass NewContactMethodPage extends Component {\n constructor(props) {\n super(props);\n\n this.state = {\n login: '',\n password: '',\n };\n this.onLoginChange = this.onLoginChange.bind(this);\n this.validateForm = this.validateForm.bind(this);\n this.submitForm = this.submitForm.bind(this);\n }\n\n onLoginChange(login) {\n this.setState({login});\n }\n\n /**\n * Determine whether the form is valid\n *\n * @returns {Boolean}\n */\n validateForm() {\n const login = this.state.login.trim();\n const phoneLogin = LoginUtils.getPhoneNumberWithoutSpecialChars(login);\n\n return (Permissions.canUsePasswordlessLogins(this.props.betas) || this.state.password)\n && (Str.isValidEmail(login) || Str.isValidPhone(phoneLogin));\n }\n\n submitForm() {\n // If this login already exists, just go back.\n if (lodashGet(this.props.loginList, this.state.login)) {\n Navigation.navigate(ROUTES.SETTINGS_CONTACT_METHODS);\n return;\n }\n User.addNewContactMethodAndNavigate(this.state.login, this.state.password);\n }\n\n render() {\n return (\n {\n if (!this.loginInputRef) {\n return;\n }\n this.loginInputRef.focus();\n }}\n >\n Navigation.navigate(ROUTES.SETTINGS_CONTACT_METHODS)}\n onCloseButtonPress={() => Navigation.dismissModal(true)}\n />\n \n \n {this.props.translate('common.pleaseEnterEmailOrPhoneNumber')}\n \n \n this.loginInputRef = el}\n value={this.state.login}\n onChangeText={this.onLoginChange}\n autoCapitalize=\"none\"\n returnKeyType={Permissions.canUsePasswordlessLogins(this.props.betas) ? 'done' : 'next'}\n />\n \n {!Permissions.canUsePasswordlessLogins(this.props.betas)\n && (\n \n this.setState({password})}\n returnKeyType=\"done\"\n />\n \n )}\n \n \n \n \n \n );\n }\n}\n\nNewContactMethodPage.propTypes = propTypes;\nNewContactMethodPage.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withOnyx({\n betas: {key: ONYXKEYS.BETAS},\n loginList: {key: ONYXKEYS.LOGIN_LIST},\n }),\n)(NewContactMethodPage);\n","import _ from 'underscore';\nimport lodashGet from 'lodash/get';\nimport React from 'react';\nimport {View, ScrollView} from 'react-native';\nimport {withOnyx} from 'react-native-onyx';\nimport PropTypes from 'prop-types';\nimport HeaderWithCloseButton from '../../../components/HeaderWithCloseButton';\nimport Navigation from '../../../libs/Navigation/Navigation';\nimport ROUTES from '../../../ROUTES';\nimport ONYXKEYS from '../../../ONYXKEYS';\nimport styles from '../../../styles/styles';\nimport Text from '../../../components/Text';\nimport CONST from '../../../CONST';\nimport * as User from '../../../libs/actions/User';\nimport ScreenWrapper from '../../../components/ScreenWrapper';\nimport Switch from '../../../components/Switch';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport compose from '../../../libs/compose';\nimport withEnvironment, {environmentPropTypes} from '../../../components/withEnvironment';\nimport TestToolMenu from '../../../components/TestToolMenu';\nimport MenuItemWithTopDescription from '../../../components/MenuItemWithTopDescription';\n\nconst propTypes = {\n /** The chat priority mode */\n priorityMode: PropTypes.string,\n\n /** The details about the user that is signed in */\n user: PropTypes.shape({\n /** Whether or not the user is subscribed to news updates */\n isSubscribedToNewsletter: PropTypes.bool,\n }),\n\n /** The preferred language of the App */\n preferredLocale: PropTypes.string.isRequired,\n\n ...withLocalizePropTypes,\n ...environmentPropTypes,\n};\n\nconst defaultProps = {\n priorityMode: CONST.PRIORITY_MODE.DEFAULT,\n user: {},\n};\n\nconst PreferencesPage = (props) => {\n const priorityModes = props.translate('priorityModePage.priorityModes');\n const languages = props.translate('languagePage.languages');\n\n // Enable additional test features in the staging or dev environments\n const shouldShowTestToolMenu = _.contains([CONST.ENVIRONMENT.STAGING, CONST.ENVIRONMENT.DEV], props.environment);\n\n return (\n \n Navigation.navigate(ROUTES.SETTINGS)}\n onCloseButtonPress={() => Navigation.dismissModal(true)}\n />\n \n \n \n {props.translate('common.notifications')}\n \n \n \n \n {props.translate('preferencesPage.receiveRelevantFeatureUpdatesAndExpensifyNews')}\n \n \n \n \n \n \n Navigation.navigate(ROUTES.SETTINGS_PRIORITY_MODE)}\n />\n Navigation.navigate(ROUTES.SETTINGS_LANGUAGE)}\n />\n {shouldShowTestToolMenu && }\n \n \n \n );\n};\n\nPreferencesPage.propTypes = propTypes;\nPreferencesPage.defaultProps = defaultProps;\nPreferencesPage.displayName = 'PreferencesPage';\n\nexport default compose(\n withEnvironment,\n withLocalize,\n withOnyx({\n priorityMode: {\n key: ONYXKEYS.NVP_PRIORITY_MODE,\n },\n user: {\n key: ONYXKEYS.USER,\n },\n }),\n)(PreferencesPage);\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport {withOnyx} from 'react-native-onyx';\nimport lodashGet from 'lodash/get';\nimport styles from '../styles/styles';\nimport Switch from './Switch';\nimport Text from './Text';\nimport * as User from '../libs/actions/User';\nimport * as Network from '../libs/actions/Network';\nimport * as Session from '../libs/actions/Session';\nimport ONYXKEYS from '../ONYXKEYS';\nimport Button from './Button';\nimport TestToolRow from './TestToolRow';\nimport networkPropTypes from './networkPropTypes';\nimport compose from '../libs/compose';\nimport {withNetwork} from './OnyxProvider';\nimport * as ApiUtils from '../libs/ApiUtils';\nimport CONFIG from '../CONFIG';\n\nconst propTypes = {\n /** User object in Onyx */\n user: PropTypes.shape({\n /** Whether we should use the staging version of the secure API server */\n shouldUseStagingServer: PropTypes.bool,\n }),\n\n /** Network object in Onyx */\n network: networkPropTypes.isRequired,\n};\n\nconst defaultProps = {\n user: {\n // The default value is environment specific and can't be set with `defaultProps` (ENV is not resolved yet)\n // When undefined (during render) STAGING defaults to `true`, other envs default to `false`\n shouldUseStagingServer: undefined,\n },\n};\n\nconst TestToolMenu = props => (\n <>\n \n Test Preferences\n \n\n {/* Option to switch between staging and default api endpoints.\n This enables QA, internal testers and external devs to take advantage of sandbox environments for 3rd party services like Plaid and Onfido.\n This toggle is not rendered for internal devs as they make environment changes directly to the .env file. */}\n {!CONFIG.IS_USING_LOCAL_WEB && (\n \n User.setShouldUseStagingServer(\n !lodashGet(props, 'user.shouldUseStagingServer', ApiUtils.isUsingStagingApi()),\n )}\n />\n \n )}\n\n {/* When toggled the app will be forced offline. */}\n \n Network.setShouldForceOffline(!props.network.shouldForceOffline)}\n />\n \n\n {/* When toggled all network requests will fail. */}\n \n Network.setShouldFailAllRequests(!props.network.shouldFailAllRequests)}\n />\n \n\n {/* Instantly invalidates a user's local authToken. Useful for testing flows related to reauthentication. */}\n \n Session.invalidateAuthToken()}\n />\n \n\n {/* Invalidate stored user auto-generated credentials. Useful for manually testing sign out logic. */}\n \n Session.invalidateCredentials()}\n />\n \n \n);\n\nTestToolMenu.propTypes = propTypes;\nTestToolMenu.defaultProps = defaultProps;\nTestToolMenu.displayName = 'TestToolMenu';\n\nexport default compose(\n withNetwork(),\n withOnyx({\n user: {\n key: ONYXKEYS.USER,\n },\n }),\n)(TestToolMenu);\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport {View} from 'react-native';\nimport styles from '../styles/styles';\nimport Text from './Text';\n\nconst propTypes = {\n /** Title of control */\n title: PropTypes.string.isRequired,\n\n /** Control component jsx */\n children: PropTypes.node.isRequired,\n};\n\nconst TestToolRow = props => (\n \n \n \n {props.title}\n \n \n \n {props.children}\n \n \n);\n\nTestToolRow.propTypes = propTypes;\nTestToolRow.displayName = 'TestToolRow';\n\nexport default TestToolRow;\n","import _, {compose} from 'underscore';\nimport React from 'react';\nimport {withOnyx} from 'react-native-onyx';\nimport PropTypes from 'prop-types';\nimport HeaderWithCloseButton from '../../../components/HeaderWithCloseButton';\nimport ScreenWrapper from '../../../components/ScreenWrapper';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport Navigation from '../../../libs/Navigation/Navigation';\nimport ROUTES from '../../../ROUTES';\nimport OptionsList from '../../../components/OptionsList';\nimport styles from '../../../styles/styles';\nimport Text from '../../../components/Text';\nimport themeColors from '../../../styles/themes/default';\nimport * as Expensicons from '../../../components/Icon/Expensicons';\nimport ONYXKEYS from '../../../ONYXKEYS';\nimport * as User from '../../../libs/actions/User';\nimport CONST from '../../../CONST';\n\nconst greenCheckmark = {src: Expensicons.Checkmark, color: themeColors.success};\n\nconst propTypes = {\n /** The chat priority mode */\n priorityMode: PropTypes.string,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n priorityMode: CONST.PRIORITY_MODE.DEFAULT,\n};\n\nconst PriorityModePage = (props) => {\n const priorityModes = _.map(props.translate('priorityModePage.priorityModes'),\n (mode, key) => (\n {\n value: key,\n text: mode.label,\n alternateText: mode.description,\n\n // Set max line to undefined to reset line restriction\n alternateTextMaxLines: undefined,\n keyForList: key,\n\n // Include the green checkmark icon to indicate the currently selected value\n customIcon: props.priorityMode === key ? greenCheckmark : undefined,\n\n // This property will make the currently selected value have bold text\n boldStyle: props.priorityMode === key,\n }\n ));\n\n return (\n \n Navigation.navigate(ROUTES.SETTINGS_PREFERENCES)}\n onCloseButtonPress={() => Navigation.dismissModal(true)}\n />\n \n {props.translate('priorityModePage.explainerText')}\n \n User.updateChatPriorityMode(mode.value)}\n hideSectionHeaders\n optionHoveredStyle={\n {\n ...styles.hoveredComponentBG,\n ...styles.mhn5,\n ...styles.ph5,\n }\n }\n shouldHaveOptionSeparator\n shouldDisableRowInnerPadding\n contentContainerStyles={[styles.ph5]}\n />\n \n );\n};\n\nPriorityModePage.displayName = 'PriorityModePage';\nPriorityModePage.propTypes = propTypes;\nPriorityModePage.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withOnyx({\n priorityMode: {\n key: ONYXKEYS.NVP_PRIORITY_MODE,\n },\n }),\n)(PriorityModePage);\n","import _ from 'underscore';\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport HeaderWithCloseButton from '../../../components/HeaderWithCloseButton';\nimport ScreenWrapper from '../../../components/ScreenWrapper';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport Navigation from '../../../libs/Navigation/Navigation';\nimport ROUTES from '../../../ROUTES';\nimport OptionsList from '../../../components/OptionsList';\nimport styles from '../../../styles/styles';\nimport themeColors from '../../../styles/themes/default';\nimport * as Expensicons from '../../../components/Icon/Expensicons';\nimport * as App from '../../../libs/actions/App';\n\nconst greenCheckmark = {src: Expensicons.Checkmark, color: themeColors.success};\n\nconst propTypes = {\n ...withLocalizePropTypes,\n\n /** The preferred language of the App */\n preferredLocale: PropTypes.string.isRequired,\n};\n\nconst LanguagePage = (props) => {\n const localesToLanguages = _.map(props.translate('languagePage.languages'),\n (language, key) => (\n {\n value: key,\n text: language.label,\n keyForList: key,\n\n // Include the green checkmark icon to indicate the currently selected value\n customIcon: props.preferredLocale === key ? greenCheckmark : undefined,\n\n // This property will make the currently selected value have bold text\n boldStyle: props.preferredLocale === key,\n }\n ));\n\n return (\n \n Navigation.navigate(ROUTES.SETTINGS_PREFERENCES)}\n onCloseButtonPress={() => Navigation.dismissModal(true)}\n />\n App.setLocaleAndNavigate(language.value)}\n hideSectionHeaders\n optionHoveredStyle={\n {\n ...styles.hoveredComponentBG,\n ...styles.mhn5,\n ...styles.ph5,\n }\n }\n shouldHaveOptionSeparator\n shouldDisableRowInnerPadding\n contentContainerStyles={[styles.ph5]}\n />\n \n );\n};\n\nLanguagePage.displayName = 'LanguagePage';\nLanguagePage.propTypes = propTypes;\n\nexport default withLocalize(LanguagePage);\n","import React, {Component} from 'react';\nimport {View, ScrollView} from 'react-native';\nimport {withOnyx} from 'react-native-onyx';\nimport PropTypes from 'prop-types';\nimport _ from 'underscore';\nimport HeaderWithCloseButton from '../../components/HeaderWithCloseButton';\nimport Navigation from '../../libs/Navigation/Navigation';\nimport ScreenWrapper from '../../components/ScreenWrapper';\nimport Text from '../../components/Text';\nimport styles from '../../styles/styles';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport Button from '../../components/Button';\nimport * as ValidationUtils from '../../libs/ValidationUtils';\nimport * as User from '../../libs/actions/User';\nimport withLocalize, {withLocalizePropTypes} from '../../components/withLocalize';\nimport compose from '../../libs/compose';\nimport FixedFooter from '../../components/FixedFooter';\nimport TextInput from '../../components/TextInput';\nimport * as Session from '../../libs/actions/Session';\nimport * as ErrorUtils from '../../libs/ErrorUtils';\nimport ConfirmationPage from '../../components/ConfirmationPage';\n\nconst propTypes = {\n /* Onyx Props */\n\n /** Holds information about the users account that is logging in */\n account: PropTypes.shape({\n /** An error message to display to the user */\n errors: PropTypes.objectOf(PropTypes.string),\n\n /** Success message to display when necessary */\n success: PropTypes.string,\n\n /** Whether a sign on form is loading (being submitted) */\n isLoading: PropTypes.bool,\n }),\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n account: {},\n};\nclass PasswordPage extends Component {\n constructor(props) {\n super(props);\n\n this.state = {\n currentPassword: '',\n newPassword: '',\n errors: {\n currentPassword: false,\n newPassword: false,\n newPasswordSameAsOld: false,\n },\n };\n\n this.submit = this.submit.bind(this);\n this.getErrorText = this.getErrorText.bind(this);\n this.validate = this.validate.bind(this);\n this.clearErrorAndSetValue = this.clearErrorAndSetValue.bind(this);\n\n this.errorKeysMap = {\n currentPassword: 'passwordPage.errors.currentPassword',\n newPasswordSameAsOld: 'passwordPage.errors.newPasswordSameAsOld',\n newPassword: 'passwordPage.errors.newPassword',\n };\n }\n\n componentWillUnmount() {\n Session.clearAccountMessages();\n }\n\n /**\n * @param {String} field\n * @returns {String}\n */\n getErrorText(field) {\n if (this.state.errors[field]) {\n return this.props.translate(this.errorKeysMap[field]);\n }\n return '';\n }\n\n /**\n * @param {String} field\n * @param {String} value\n * @param {String[]} additionalErrorsToClear\n */\n clearErrorAndSetValue(field, value, additionalErrorsToClear) {\n const errorsToReset = {\n [field]: false,\n };\n if (additionalErrorsToClear) {\n _.each(additionalErrorsToClear, (errorFlag) => {\n errorsToReset[errorFlag] = false;\n });\n }\n\n this.setState(prevState => ({\n [field]: value,\n errors: {...prevState.errors, ...errorsToReset},\n }));\n }\n\n /**\n * @returns {Boolean}\n */\n validate() {\n const errors = {};\n\n if (!this.state.currentPassword) {\n errors.currentPassword = true;\n }\n\n if (!this.state.newPassword || !ValidationUtils.isValidPassword(this.state.newPassword)) {\n errors.newPassword = true;\n }\n\n if (this.state.currentPassword && this.state.newPassword && _.isEqual(this.state.currentPassword, this.state.newPassword)) {\n errors.newPasswordSameAsOld = true;\n }\n\n this.setState({errors});\n return _.size(errors) === 0;\n }\n\n /**\n * Submit the form\n */\n submit() {\n if (!this.validate()) {\n return;\n }\n User.updatePassword(this.state.currentPassword, this.state.newPassword);\n }\n\n render() {\n const shouldShowNewPasswordPrompt = !this.state.errors.newPassword && !this.state.errors.newPasswordSameAsOld;\n return (\n {\n if (!this.currentPasswordInputRef) {\n return;\n }\n\n this.currentPasswordInputRef.focus();\n }}\n >\n Navigation.goBack()}\n onCloseButtonPress={() => Navigation.dismissModal(true)}\n />\n {!_.isEmpty(this.props.account.success)\n ? (\n \n ) : (\n <>\n \n \n {this.props.translate('passwordPage.changingYourPasswordPrompt')}\n \n \n this.currentPasswordInputRef = el}\n secureTextEntry\n autoCompleteType=\"password\"\n textContentType=\"password\"\n value={this.state.currentPassword}\n onChangeText={text => this.clearErrorAndSetValue('currentPassword', text)}\n returnKeyType=\"done\"\n hasError={this.state.errors.currentPassword}\n errorText={this.getErrorText('currentPassword')}\n onSubmitEditing={this.submit}\n />\n \n \n this.clearErrorAndSetValue('newPassword', text, ['newPasswordSameAsOld'])}\n onSubmitEditing={this.submit}\n />\n {shouldShowNewPasswordPrompt && (\n \n {this.props.translate('passwordPage.newPasswordPrompt')}\n \n )}\n \n {_.every(this.state.errors, error => !error) && !_.isEmpty(this.props.account.errors) && (\n \n {ErrorUtils.getLatestErrorMessage(this.props.account)}\n \n )}\n \n \n \n \n \n )}\n \n );\n }\n}\n\nPasswordPage.propTypes = propTypes;\nPasswordPage.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withOnyx({\n account: {\n key: ONYXKEYS.ACCOUNT,\n },\n }),\n)(PasswordPage);\n","import React, {Component} from 'react';\nimport {View} from 'react-native';\nimport {withOnyx} from 'react-native-onyx';\nimport PropTypes from 'prop-types';\nimport Str from 'expensify-common/lib/str';\nimport _ from 'underscore';\nimport HeaderWithCloseButton from '../../../components/HeaderWithCloseButton';\nimport Navigation from '../../../libs/Navigation/Navigation';\nimport ROUTES from '../../../ROUTES';\nimport * as User from '../../../libs/actions/User';\nimport compose from '../../../libs/compose';\nimport styles from '../../../styles/styles';\nimport ScreenWrapper from '../../../components/ScreenWrapper';\nimport TextInput from '../../../components/TextInput';\nimport Text from '../../../components/Text';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport withWindowDimensions, {windowDimensionsPropTypes} from '../../../components/withWindowDimensions';\nimport * as CloseAccount from '../../../libs/actions/CloseAccount';\nimport ONYXKEYS from '../../../ONYXKEYS';\nimport Form from '../../../components/Form';\nimport CONST from '../../../CONST';\nimport ConfirmModal from '../../../components/ConfirmModal';\n\nconst propTypes = {\n\n /** Session of currently logged in user */\n session: PropTypes.shape({\n /** Email address */\n email: PropTypes.string.isRequired,\n }),\n\n ...windowDimensionsPropTypes,\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n session: {\n email: null,\n },\n};\n\nclass CloseAccountPage extends Component {\n constructor(props) {\n super(props);\n\n this.onConfirm = this.onConfirm.bind(this);\n this.validate = this.validate.bind(this);\n this.hideConfirmModal = this.hideConfirmModal.bind(this);\n this.showConfirmModal = this.showConfirmModal.bind(this);\n CloseAccount.clearError();\n this.state = {\n isConfirmModalVisible: false,\n reasonForLeaving: '',\n };\n }\n\n componentWillUnmount() {\n CloseAccount.clearError();\n }\n\n onConfirm() {\n User.closeAccount(this.state.reasonForLeaving);\n this.hideConfirmModal();\n }\n\n showConfirmModal(values) {\n this.setState({\n isConfirmModalVisible: true,\n reasonForLeaving: values.reasonForLeaving,\n });\n }\n\n hideConfirmModal() {\n this.setState({isConfirmModalVisible: false});\n }\n\n validate(values) {\n const userEmailOrPhone = Str.removeSMSDomain(this.props.session.email);\n const errors = {};\n\n if (_.isEmpty(values.phoneOrEmail) || userEmailOrPhone.toLowerCase() !== values.phoneOrEmail.toLowerCase()) {\n errors.phoneOrEmail = this.props.translate('closeAccountPage.enterYourDefaultContactMethod');\n }\n return errors;\n }\n\n render() {\n const userEmailOrPhone = Str.removeSMSDomain(this.props.session.email);\n return (\n \n Navigation.navigate(ROUTES.SETTINGS_SECURITY)}\n onCloseButtonPress={() => Navigation.dismissModal(true)}\n />\n \n \n {this.props.translate('closeAccountPage.reasonForLeavingPrompt')}\n \n \n {this.props.translate('closeAccountPage.enterDefaultContactToConfirm')}\n {' '}\n \n {userEmailOrPhone}\n \n .\n \n \n \n \n \n \n );\n }\n}\n\nCloseAccountPage.propTypes = propTypes;\nCloseAccountPage.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withWindowDimensions,\n withOnyx({\n session: {\n key: ONYXKEYS.SESSION,\n },\n }),\n)(CloseAccountPage);\n","import Onyx from 'react-native-onyx';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport CONST from '../../CONST';\n\n/**\n * Clear CloseAccount error message to hide modal\n */\nfunction clearError() {\n Onyx.merge(ONYXKEYS.FORMS.CLOSE_ACCOUNT_FORM, {errors: null});\n}\n\n/**\n * Set default Onyx data\n */\nfunction setDefaultData() {\n Onyx.merge(ONYXKEYS.FORMS.CLOSE_ACCOUNT_FORM, {...CONST.DEFAULT_CLOSE_ACCOUNT_DATA});\n}\n\nexport {\n // eslint-disable-next-line import/prefer-default-export\n clearError,\n setDefaultData,\n};\n","import _ from 'underscore';\nimport React from 'react';\nimport {View, ScrollView} from 'react-native';\nimport HeaderWithCloseButton from '../../../components/HeaderWithCloseButton';\nimport Navigation from '../../../libs/Navigation/Navigation';\nimport ROUTES from '../../../ROUTES';\nimport styles from '../../../styles/styles';\nimport * as Expensicons from '../../../components/Icon/Expensicons';\nimport ScreenWrapper from '../../../components/ScreenWrapper';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport MenuItem from '../../../components/MenuItem';\n\nconst propTypes = {\n ...withLocalizePropTypes,\n};\n\nconst SecuritySettingsPage = (props) => {\n const menuItems = [\n {\n translationKey: 'passwordPage.changePassword',\n icon: Expensicons.Key,\n action: () => {\n Navigation.navigate(ROUTES.SETTINGS_PASSWORD);\n },\n },\n {\n translationKey: 'closeAccountPage.closeAccount',\n icon: Expensicons.ClosedSign,\n action: () => {\n Navigation.navigate(ROUTES.SETTINGS_CLOSE);\n },\n },\n ];\n\n return (\n \n Navigation.navigate(ROUTES.SETTINGS)}\n onCloseButtonPress={() => Navigation.dismissModal(true)}\n />\n \n \n {_.map(menuItems, item => (\n item.action()}\n shouldShowRightIcon\n />\n ))}\n \n \n \n );\n};\n\nSecuritySettingsPage.propTypes = propTypes;\nSecuritySettingsPage.displayName = 'SettingSecurityPage';\n\nexport default withLocalize(SecuritySettingsPage);\n","import _ from 'underscore';\nimport React from 'react';\nimport {View, ScrollView} from 'react-native';\nimport HeaderWithCloseButton from '../../../components/HeaderWithCloseButton';\nimport Navigation from '../../../libs/Navigation/Navigation';\nimport ROUTES from '../../../ROUTES';\nimport styles from '../../../styles/styles';\nimport Text from '../../../components/Text';\nimport TextLink from '../../../components/TextLink';\nimport CONST from '../../../CONST';\nimport * as Expensicons from '../../../components/Icon/Expensicons';\nimport ScreenWrapper from '../../../components/ScreenWrapper';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport withWindowDimensions, {windowDimensionsPropTypes} from '../../../components/withWindowDimensions';\nimport MenuItem from '../../../components/MenuItem';\nimport Logo from '../../../../assets/images/new-expensify.svg';\nimport pkg from '../../../../package.json';\nimport * as Report from '../../../libs/actions/Report';\nimport * as Link from '../../../libs/actions/Link';\nimport compose from '../../../libs/compose';\nimport * as KeyboardShortcuts from '../../../libs/actions/KeyboardShortcuts';\nimport * as ReportActionContextMenu from '../../home/report/ContextMenu/ReportActionContextMenu';\nimport {CONTEXT_MENU_TYPES} from '../../home/report/ContextMenu/ContextMenuActions';\nimport * as Environment from '../../../libs/Environment/Environment';\nimport withEnvironment from '../../../components/withEnvironment';\n\n\nconst propTypes = {\n ...withLocalizePropTypes,\n ...windowDimensionsPropTypes,\n};\n\nconst AboutPage = (props) => {\n let popoverAnchor;\n\n const menuItems = [\n {\n translationKey: 'initialSettingsPage.aboutPage.appDownloadLinks',\n icon: Expensicons.Link,\n action: () => {\n Navigation.navigate(ROUTES.SETTINGS_APP_DOWNLOAD_LINKS);\n },\n },\n {\n translationKey: 'initialSettingsPage.aboutPage.viewKeyboardShortcuts',\n icon: Expensicons.Keyboard,\n action: KeyboardShortcuts.showKeyboardShortcutModal,\n },\n {\n translationKey: 'initialSettingsPage.aboutPage.viewTheCode',\n icon: Expensicons.Eye,\n iconRight: Expensicons.NewWindow,\n action: () => {\n Link.openExternalLink(CONST.GITHUB_URL);\n },\n link: CONST.GITHUB_URL,\n },\n {\n translationKey: 'initialSettingsPage.aboutPage.viewOpenJobs',\n icon: Expensicons.MoneyBag,\n iconRight: Expensicons.NewWindow,\n action: () => {\n Link.openExternalLink(CONST.UPWORK_URL);\n },\n link: CONST.UPWORK_URL,\n },\n {\n translationKey: 'initialSettingsPage.aboutPage.reportABug',\n icon: Expensicons.Bug,\n action: Report.navigateToConciergeChat,\n },\n ];\n\n return (\n \n {({safeAreaPaddingBottomStyle}) => (\n <>\n Navigation.navigate(ROUTES.SETTINGS)}\n onCloseButtonPress={() => Navigation.dismissModal(true)}\n />\n \n \n \n \n \n \n {props.environment}\n \n \n {props.translate('initialSettingsPage.aboutPage.description')}\n \n \n \n {_.map(menuItems, item => (\n item.action()}\n shouldBlockSelection={Boolean(item.link)}\n onSecondaryInteraction={!_.isEmpty(item.link)\n ? e => ReportActionContextMenu.showContextMenu(CONTEXT_MENU_TYPES.LINK, e, item.link, popoverAnchor) : undefined}\n ref={el => popoverAnchor = el}\n shouldShowRightIcon\n />\n ))}\n \n \n \n {props.translate(\n 'initialSettingsPage.readTheTermsAndPrivacy.phrase1',\n )}\n {' '}\n \n {props.translate(\n 'initialSettingsPage.readTheTermsAndPrivacy.phrase2',\n )}\n \n {' '}\n {props.translate(\n 'initialSettingsPage.readTheTermsAndPrivacy.phrase3',\n )}\n {' '}\n \n {props.translate(\n 'initialSettingsPage.readTheTermsAndPrivacy.phrase4',\n )}\n \n .\n \n \n \n \n )}\n \n );\n};\n\nAboutPage.propTypes = propTypes;\nAboutPage.displayName = 'AboutPage';\n\nexport default compose(\n withLocalize,\n withWindowDimensions,\n withEnvironment,\n)(AboutPage);\n","\n\n\n\n\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\t\n\t\t\n\t\t\n\t\n\n\n","import Onyx from 'react-native-onyx';\nimport ONYXKEYS from '../../ONYXKEYS';\n\nlet isShortcutsModalOpen;\nOnyx.connect({\n key: ONYXKEYS.IS_SHORTCUTS_MODAL_OPEN,\n callback: flag => isShortcutsModalOpen = flag,\n});\n\n/**\n * Set keyboard shortcuts flag to show modal\n */\nfunction showKeyboardShortcutModal() {\n if (isShortcutsModalOpen) {\n return;\n }\n Onyx.set(ONYXKEYS.IS_SHORTCUTS_MODAL_OPEN, true);\n}\n\n/**\n * Unset keyboard shortcuts flag to hide modal\n */\nfunction hideKeyboardShortcutModal() {\n if (!isShortcutsModalOpen) {\n return;\n }\n Onyx.set(ONYXKEYS.IS_SHORTCUTS_MODAL_OPEN, false);\n}\n\nexport {\n showKeyboardShortcutModal,\n hideKeyboardShortcutModal,\n};\n","import _ from 'underscore';\nimport React from 'react';\nimport {ScrollView} from 'react-native';\nimport HeaderWithCloseButton from '../../components/HeaderWithCloseButton';\nimport Navigation from '../../libs/Navigation/Navigation';\nimport CONST from '../../CONST';\nimport * as Expensicons from '../../components/Icon/Expensicons';\nimport ScreenWrapper from '../../components/ScreenWrapper';\nimport withLocalize, {withLocalizePropTypes} from '../../components/withLocalize';\nimport compose from '../../libs/compose';\nimport MenuItem from '../../components/MenuItem';\nimport styles from '../../styles/styles';\nimport * as Link from '../../libs/actions/Link';\nimport withWindowDimensions, {windowDimensionsPropTypes} from '../../components/withWindowDimensions';\nimport * as ReportActionContextMenu from '../home/report/ContextMenu/ReportActionContextMenu';\nimport {CONTEXT_MENU_TYPES} from '../home/report/ContextMenu/ContextMenuActions';\n\nconst propTypes = {\n ...withLocalizePropTypes,\n ...windowDimensionsPropTypes,\n};\n\nconst AppDownloadLinksPage = (props) => {\n let popoverAnchor;\n\n const menuItems = [\n {\n translationKey: 'initialSettingsPage.appDownloadLinks.android.label',\n icon: Expensicons.Android,\n iconRight: Expensicons.NewWindow,\n action: () => {\n Link.openExternalLink(CONST.APP_DOWNLOAD_LINKS.ANDROID);\n },\n link: CONST.APP_DOWNLOAD_LINKS.ANDROID,\n },\n {\n translationKey: 'initialSettingsPage.appDownloadLinks.ios.label',\n icon: Expensicons.Apple,\n iconRight: Expensicons.NewWindow,\n action: () => {\n Link.openExternalLink(CONST.APP_DOWNLOAD_LINKS.IOS, true);\n },\n link: CONST.APP_DOWNLOAD_LINKS.IOS,\n },\n {\n translationKey: 'initialSettingsPage.appDownloadLinks.desktop.label',\n icon: Expensicons.Monitor,\n iconRight: Expensicons.NewWindow,\n action: () => {\n Link.openExternalLink(CONST.APP_DOWNLOAD_LINKS.DESKTOP);\n },\n link: CONST.APP_DOWNLOAD_LINKS.DESKTOP,\n },\n ];\n\n return (\n \n Navigation.goBack()}\n onCloseButtonPress={() => Navigation.dismissModal(true)}\n />\n \n {_.map(menuItems, item => (\n item.action()}\n onSecondaryInteraction={e => ReportActionContextMenu.showContextMenu(CONTEXT_MENU_TYPES.LINK, e, item.link, popoverAnchor)}\n onKeyDown={(event) => {\n event.target.blur();\n }}\n ref={el => popoverAnchor = el}\n title={props.translate(item.translationKey)}\n icon={item.icon}\n iconRight={item.iconRight}\n shouldBlockSelection\n shouldShowRightIcon\n />\n ))}\n \n \n );\n};\n\nAppDownloadLinksPage.propTypes = propTypes;\nAppDownloadLinksPage.displayName = 'AppDownloadLinksPage';\n\nexport default compose(\n withWindowDimensions,\n withLocalize,\n)(AppDownloadLinksPage);\n","import BasePaymentsPage from './BasePaymentsPage';\n\nexport default BasePaymentsPage;\n","import React from 'react';\nimport {\n ActivityIndicator, View, InteractionManager, LayoutAnimation,\n} from 'react-native';\nimport {withOnyx} from 'react-native-onyx';\nimport _ from 'underscore';\nimport PaymentMethodList from '../PaymentMethodList';\nimport ROUTES from '../../../../ROUTES';\nimport HeaderWithCloseButton from '../../../../components/HeaderWithCloseButton';\nimport PasswordPopover from '../../../../components/PasswordPopover';\nimport ScreenWrapper from '../../../../components/ScreenWrapper';\nimport Navigation from '../../../../libs/Navigation/Navigation';\nimport styles from '../../../../styles/styles';\nimport withLocalize from '../../../../components/withLocalize';\nimport compose from '../../../../libs/compose';\nimport * as BankAccounts from '../../../../libs/actions/BankAccounts';\nimport Popover from '../../../../components/Popover';\nimport MenuItem from '../../../../components/MenuItem';\nimport Text from '../../../../components/Text';\nimport * as PaymentMethods from '../../../../libs/actions/PaymentMethods';\nimport getClickedTargetLocation from '../../../../libs/getClickedTargetLocation';\nimport withWindowDimensions from '../../../../components/withWindowDimensions';\nimport CurrentWalletBalance from '../../../../components/CurrentWalletBalance';\nimport ONYXKEYS from '../../../../ONYXKEYS';\nimport Permissions from '../../../../libs/Permissions';\nimport AddPaymentMethodMenu from '../../../../components/AddPaymentMethodMenu';\nimport CONST from '../../../../CONST';\nimport * as Expensicons from '../../../../components/Icon/Expensicons';\nimport KYCWall from '../../../../components/KYCWall';\nimport {propTypes, defaultProps} from './paymentsPagePropTypes';\nimport {withNetwork} from '../../../../components/OnyxProvider';\nimport * as PaymentUtils from '../../../../libs/PaymentUtils';\nimport OfflineWithFeedback from '../../../../components/OfflineWithFeedback';\nimport ConfirmContent from '../../../../components/ConfirmContent';\nimport Button from '../../../../components/Button';\nimport themeColors from '../../../../styles/themes/default';\n\nclass BasePaymentsPage extends React.Component {\n constructor(props) {\n super(props);\n\n this.state = {\n shouldShowAddPaymentMenu: false,\n shouldShowDefaultDeleteMenu: false,\n shouldShowPasswordPrompt: false,\n shouldShowLoadingSpinner: false,\n isSelectedPaymentMethodDefault: false,\n selectedPaymentMethod: {},\n formattedSelectedPaymentMethod: {\n title: '',\n },\n selectedPaymentMethodType: null,\n anchorPositionTop: 0,\n anchorPositionBottom: 0,\n anchorPositionRight: 0,\n addPaymentMethodButton: null,\n methodID: null,\n showConfirmDeleteContent: false,\n };\n\n this.paymentMethodPressed = this.paymentMethodPressed.bind(this);\n this.addPaymentMethodTypePressed = this.addPaymentMethodTypePressed.bind(this);\n this.hideAddPaymentMenu = this.hideAddPaymentMenu.bind(this);\n this.hideDefaultDeleteMenu = this.hideDefaultDeleteMenu.bind(this);\n this.makeDefaultPaymentMethod = this.makeDefaultPaymentMethod.bind(this);\n this.deletePaymentMethod = this.deletePaymentMethod.bind(this);\n this.hidePasswordPrompt = this.hidePasswordPrompt.bind(this);\n this.navigateToTransferBalancePage = this.navigateToTransferBalancePage.bind(this);\n this.setMenuPosition = this.setMenuPosition.bind(this);\n this.listHeaderComponent = this.listHeaderComponent.bind(this);\n\n this.debounceSetShouldShowLoadingSpinner = _.debounce(this.setShouldShowLoadingSpinner.bind(this), CONST.TIMING.SHOW_LOADING_SPINNER_DEBOUNCE_TIME);\n }\n\n componentDidMount() {\n this.fetchData();\n }\n\n componentDidUpdate(prevProps) {\n if (this.shouldListenForResize) {\n this.setMenuPosition();\n }\n\n // If the user was previously offline, skip debouncing showing the loader\n if (prevProps.network.isOffline && !this.props.network.isOffline) {\n this.setShouldShowLoadingSpinner();\n } else {\n this.debounceSetShouldShowLoadingSpinner();\n }\n\n if (this.state.shouldShowDefaultDeleteMenu || this.state.shouldShowPasswordPrompt) {\n // We should reset selected payment method state values and close corresponding modals if the selected payment method is deleted\n let shouldResetPaymentMethodData = false;\n\n if (this.state.selectedPaymentMethodType === CONST.PAYMENT_METHODS.BANK_ACCOUNT && _.isEmpty(this.props.bankAccountList[this.state.methodID])) {\n shouldResetPaymentMethodData = true;\n } else if (this.state.selectedPaymentMethodType === CONST.PAYMENT_METHODS.DEBIT_CARD && _.isEmpty(this.props.cardList[this.state.methodID])) {\n shouldResetPaymentMethodData = true;\n } else if (this.state.selectedPaymentMethodType === CONST.PAYMENT_METHODS.PAYPAL && this.props.payPalMeData !== prevProps.payPalMeData && _.isEmpty(this.props.payPalMeData)) {\n shouldResetPaymentMethodData = true;\n }\n if (shouldResetPaymentMethodData) {\n // Close corresponding selected payment method modals which are open\n if (this.state.shouldShowDefaultDeleteMenu) {\n this.hideDefaultDeleteMenu();\n } else if (this.state.shouldShowPasswordPrompt) {\n this.hidePasswordPrompt();\n }\n }\n }\n\n // previously online OR currently offline, skip fetch\n if (!prevProps.network.isOffline || this.props.network.isOffline) {\n return;\n }\n\n this.fetchData();\n }\n\n setShouldShowLoadingSpinner() {\n // In order to prevent a loop, only update state of the spinner if there is a change\n const shouldShowLoadingSpinner = this.props.isLoadingPaymentMethods || false;\n if (shouldShowLoadingSpinner !== this.state.shouldShowLoadingSpinner) {\n this.setState({shouldShowLoadingSpinner: this.props.isLoadingPaymentMethods && !this.props.network.isOffline});\n }\n }\n\n setMenuPosition() {\n if (!this.state.addPaymentMethodButton) {\n return;\n }\n const buttonPosition = getClickedTargetLocation(this.state.addPaymentMethodButton);\n this.setPositionAddPaymentMenu(buttonPosition);\n }\n\n getSelectedPaymentMethodID() {\n if (this.state.selectedPaymentMethodType === CONST.PAYMENT_METHODS.PAYPAL) {\n return CONST.PAYMENT_METHODS.PAYPAL;\n }\n if (this.state.selectedPaymentMethodType === CONST.PAYMENT_METHODS.BANK_ACCOUNT) {\n return this.state.selectedPaymentMethod.bankAccountID;\n }\n if (this.state.selectedPaymentMethodType === CONST.PAYMENT_METHODS.DEBIT_CARD) {\n return this.state.selectedPaymentMethod.fundID;\n }\n }\n\n /**\n * Set position of the payment menu\n *\n * @param {Object} position\n */\n setPositionAddPaymentMenu(position) {\n this.setState({\n anchorPositionTop: position.top + position.height,\n anchorPositionBottom: this.props.windowHeight - position.top,\n\n // We want the position to be 13px to the right of the left border\n anchorPositionRight: (this.props.windowWidth - position.right) + 13,\n });\n }\n\n resetSelectedPaymentMethodData() {\n // The below state values are used by payment method modals and we reset them while closing the modals.\n // We should only reset the values when the modal animation is completed and so using InteractionManager.runAfterInteractions which fires after all animaitons are complete\n InteractionManager.runAfterInteractions(() => {\n // Reset to same values as in the constructor\n this.setState({\n isSelectedPaymentMethodDefault: false,\n selectedPaymentMethod: {},\n formattedSelectedPaymentMethod: {\n title: '',\n },\n methodID: null,\n selectedPaymentMethodType: null,\n });\n });\n }\n\n /**\n * Display the delete/default menu, or the add payment method menu\n *\n * @param {Object} nativeEvent\n * @param {String} accountType\n * @param {String} account\n * @param {Boolean} isDefault\n * @param {String|Number} methodID\n */\n paymentMethodPressed(nativeEvent, accountType, account, isDefault, methodID) {\n const position = getClickedTargetLocation(nativeEvent.currentTarget);\n this.setState({\n addPaymentMethodButton: nativeEvent.currentTarget,\n });\n\n // The delete/default menu\n if (accountType) {\n let formattedSelectedPaymentMethod;\n if (accountType === CONST.PAYMENT_METHODS.PAYPAL) {\n formattedSelectedPaymentMethod = {\n title: 'PayPal.me',\n icon: account.icon,\n description: PaymentUtils.getPaymentMethodDescription(accountType, account),\n type: CONST.PAYMENT_METHODS.PAYPAL,\n };\n } else if (accountType === CONST.PAYMENT_METHODS.BANK_ACCOUNT) {\n formattedSelectedPaymentMethod = {\n title: account.addressName,\n icon: account.icon,\n description: PaymentUtils.getPaymentMethodDescription(accountType, account),\n type: CONST.PAYMENT_METHODS.BANK_ACCOUNT,\n };\n } else if (accountType === CONST.PAYMENT_METHODS.DEBIT_CARD) {\n formattedSelectedPaymentMethod = {\n title: account.addressName,\n icon: account.icon,\n description: PaymentUtils.getPaymentMethodDescription(accountType, account),\n type: CONST.PAYMENT_METHODS.DEBIT_CARD,\n };\n }\n this.setState({\n isSelectedPaymentMethodDefault: isDefault,\n shouldShowDefaultDeleteMenu: true,\n selectedPaymentMethod: account,\n selectedPaymentMethodType: accountType,\n formattedSelectedPaymentMethod,\n methodID,\n });\n this.setPositionAddPaymentMenu(position);\n return;\n }\n this.setState({\n shouldShowAddPaymentMenu: true,\n });\n\n this.setPositionAddPaymentMenu(position);\n }\n\n /**\n * Navigate to the appropriate payment type addition screen\n *\n * @param {String} paymentType\n */\n addPaymentMethodTypePressed(paymentType) {\n this.hideAddPaymentMenu();\n\n if (paymentType === CONST.PAYMENT_METHODS.PAYPAL) {\n Navigation.navigate(ROUTES.SETTINGS_ADD_PAYPAL_ME);\n return;\n }\n\n if (paymentType === CONST.PAYMENT_METHODS.DEBIT_CARD) {\n Navigation.navigate(ROUTES.SETTINGS_ADD_DEBIT_CARD);\n return;\n }\n\n if (paymentType === CONST.PAYMENT_METHODS.BANK_ACCOUNT) {\n BankAccounts.openPersonalBankAccountSetupView();\n return;\n }\n\n throw new Error('Invalid payment method type selected');\n }\n\n fetchData() {\n PaymentMethods.openPaymentsPage();\n }\n\n /**\n * Hide the add payment modal\n */\n hideAddPaymentMenu() {\n this.setState({shouldShowAddPaymentMenu: false});\n }\n\n /**\n * Hide the default / delete modal\n * @param {boolean} shouldClearSelectedData - Clear selected payment method data if true\n */\n hideDefaultDeleteMenu(shouldClearSelectedData = true) {\n this.setState({shouldShowDefaultDeleteMenu: false});\n InteractionManager.runAfterInteractions(() => {\n this.setState({\n showConfirmDeleteContent: false,\n });\n if (shouldClearSelectedData) {\n this.resetSelectedPaymentMethodData();\n }\n });\n }\n\n hidePasswordPrompt(shouldClearSelectedData = true) {\n this.setState({shouldShowPasswordPrompt: false});\n if (shouldClearSelectedData) {\n this.resetSelectedPaymentMethodData();\n }\n\n // Due to iOS modal freeze issue, password modal freezes the app when closed.\n // LayoutAnimation undoes the running animation.\n LayoutAnimation.configureNext(LayoutAnimation.create(50, LayoutAnimation.Types.easeInEaseOut, LayoutAnimation.Properties.opacity));\n }\n\n makeDefaultPaymentMethod(password = '') {\n // Find the previous default payment method so we can revert if the MakeDefaultPaymentMethod command errors\n const paymentMethods = PaymentUtils.formatPaymentMethods(\n this.props.bankAccountList,\n this.props.cardList,\n );\n\n const previousPaymentMethod = _.find(paymentMethods, method => method.isDefault);\n const currentPaymentMethod = _.find(paymentMethods, method => method.methodID === this.state.methodID);\n if (this.state.selectedPaymentMethodType === CONST.PAYMENT_METHODS.BANK_ACCOUNT) {\n PaymentMethods.makeDefaultPaymentMethod(password, this.state.selectedPaymentMethod.bankAccountID, null, previousPaymentMethod, currentPaymentMethod);\n } else if (this.state.selectedPaymentMethodType === CONST.PAYMENT_METHODS.DEBIT_CARD) {\n PaymentMethods.makeDefaultPaymentMethod(password, null, this.state.selectedPaymentMethod.fundID, previousPaymentMethod, currentPaymentMethod);\n }\n this.resetSelectedPaymentMethodData();\n }\n\n deletePaymentMethod() {\n if (this.state.selectedPaymentMethodType === CONST.PAYMENT_METHODS.PAYPAL) {\n PaymentMethods.deletePayPalMe();\n } else if (this.state.selectedPaymentMethodType === CONST.PAYMENT_METHODS.BANK_ACCOUNT) {\n BankAccounts.deletePaymentBankAccount(this.state.selectedPaymentMethod.bankAccountID);\n } else if (this.state.selectedPaymentMethodType === CONST.PAYMENT_METHODS.DEBIT_CARD) {\n PaymentMethods.deletePaymentCard(this.state.selectedPaymentMethod.fundID);\n }\n this.resetSelectedPaymentMethodData();\n }\n\n navigateToTransferBalancePage() {\n Navigation.navigate(ROUTES.SETTINGS_PAYMENTS_TRANSFER_BALANCE);\n }\n\n listHeaderComponent() {\n return (\n <>\n {Permissions.canUseWallet(this.props.betas) && (\n <>\n \n {this.state.shouldShowLoadingSpinner ? (\n \n ) : (\n \n \n \n )}\n \n {this.props.userWallet.currentBalance > 0 && (\n \n {triggerKYCFlow => (\n \n )}\n \n )}\n \n )}\n \n {this.props.translate('paymentsPage.paymentMethodsTitle')}\n \n \n );\n }\n\n render() {\n const isPayPalMeSelected = this.state.formattedSelectedPaymentMethod.type === CONST.PAYMENT_METHODS.PAYPAL;\n const shouldShowMakeDefaultButton = !this.state.isSelectedPaymentMethodDefault\n && Permissions.canUseWallet(this.props.betas)\n && !isPayPalMeSelected\n && !(this.state.formattedSelectedPaymentMethod.type === CONST.PAYMENT_METHODS.BANK_ACCOUNT && this.state.selectedPaymentMethod.type === CONST.BANK_ACCOUNT.TYPE.BUSINESS);\n\n // Determines whether or not the modal popup is mounted from the bottom of the screen instead of the side mount on Web or Desktop screens\n const isPopoverBottomMount = this.state.anchorPositionTop === 0 || this.props.isSmallScreenWidth;\n return (\n \n Navigation.navigate(ROUTES.SETTINGS)}\n onCloseButtonPress={() => Navigation.dismissModal(true)}\n />\n \n PaymentMethods.clearWalletError()}\n errors={this.props.userWallet.errors}\n errorRowStyles={[styles.ph6]}\n >\n \n \n \n this.addPaymentMethodTypePressed(method)}\n />\n \n {!this.state.showConfirmDeleteContent ? (\n \n {isPopoverBottomMount && (\n \n )}\n {shouldShowMakeDefaultButton && (\n {\n this.setState({\n shouldShowDefaultDeleteMenu: false,\n });\n\n // Wait for the previous modal to close, before opening a new one. A modal will be considered completely closed when closing animation is finished.\n // InteractionManager fires after the currently running animation is completed.\n // https://github.com/Expensify/App/issues/7768#issuecomment-1044879541\n InteractionManager.runAfterInteractions(() => {\n if (Permissions.canUsePasswordlessLogins(this.props.betas)) {\n this.makeDefaultPaymentMethod();\n } else {\n this.setState({\n shouldShowPasswordPrompt: true,\n passwordButtonText: this.props.translate('paymentsPage.setDefaultConfirmation'),\n });\n }\n });\n }}\n text={this.props.translate('paymentsPage.setDefaultConfirmation')}\n />\n )}\n {\n this.setState({\n showConfirmDeleteContent: true,\n });\n }}\n style={[shouldShowMakeDefaultButton && styles.mt4]}\n text={this.props.translate('common.delete')}\n danger\n />\n \n ) : (\n {\n this.hideDefaultDeleteMenu(false);\n this.deletePaymentMethod();\n }}\n onCancel={this.hideDefaultDeleteMenu}\n contentStyles={!this.props.isSmallScreenWidth ? [styles.sidebarPopover] : undefined}\n title={this.props.translate('paymentsPage.deleteAccount')}\n prompt={this.props.translate('paymentsPage.deleteConfirmation')}\n confirmText={this.props.translate('common.delete')}\n cancelText={this.props.translate('common.cancel')}\n anchorPosition={{\n top: this.state.anchorPositionTop,\n right: this.state.anchorPositionRight,\n }}\n shouldShowCancelButton\n danger\n />\n )}\n \n {\n this.hidePasswordPrompt(false);\n this.makeDefaultPaymentMethod(password);\n }}\n submitButtonText={this.state.passwordButtonText}\n />\n \n );\n }\n}\n\nBasePaymentsPage.propTypes = propTypes;\nBasePaymentsPage.defaultProps = defaultProps;\n\nexport default compose(\n withWindowDimensions,\n withLocalize,\n withNetwork(),\n withOnyx({\n betas: {\n key: ONYXKEYS.BETAS,\n },\n walletTransfer: {\n key: ONYXKEYS.WALLET_TRANSFER,\n },\n userWallet: {\n key: ONYXKEYS.USER_WALLET,\n },\n bankAccountList: {\n key: ONYXKEYS.BANK_ACCOUNT_LIST,\n },\n cardList: {\n key: ONYXKEYS.CARD_LIST,\n },\n walletTerms: {\n key: ONYXKEYS.WALLET_TERMS,\n },\n payPalMeData: {\n key: ONYXKEYS.PAYPAL,\n },\n isLoadingPaymentMethods: {\n key: ONYXKEYS.IS_LOADING_PAYMENT_METHODS,\n },\n }),\n)(BasePaymentsPage);\n","import _ from 'underscore';\nimport React, {Component} from 'react';\nimport PropTypes from 'prop-types';\nimport {FlatList} from 'react-native';\nimport lodashGet from 'lodash/get';\nimport {withOnyx} from 'react-native-onyx';\nimport {withNetwork} from '../../../components/OnyxProvider';\nimport styles from '../../../styles/styles';\nimport * as StyleUtils from '../../../styles/StyleUtils';\nimport MenuItem from '../../../components/MenuItem';\nimport Button from '../../../components/Button';\nimport Text from '../../../components/Text';\nimport compose from '../../../libs/compose';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport ONYXKEYS from '../../../ONYXKEYS';\nimport CONST from '../../../CONST';\nimport * as Expensicons from '../../../components/Icon/Expensicons';\nimport bankAccountPropTypes from '../../../components/bankAccountPropTypes';\nimport paypalMeDataPropTypes from '../../../components/paypalMeDataPropTypes';\nimport cardPropTypes from '../../../components/cardPropTypes';\nimport * as PaymentUtils from '../../../libs/PaymentUtils';\nimport FormAlertWrapper from '../../../components/FormAlertWrapper';\nimport OfflineWithFeedback from '../../../components/OfflineWithFeedback';\nimport * as PaymentMethods from '../../../libs/actions/PaymentMethods';\nimport Log from '../../../libs/Log';\n\nconst propTypes = {\n /** What to do when a menu item is pressed */\n onPress: PropTypes.func.isRequired,\n\n /** Account details for PayPal.Me */\n payPalMeData: paypalMeDataPropTypes,\n\n /** List of bank accounts */\n bankAccountList: PropTypes.objectOf(bankAccountPropTypes),\n\n /** List of cards */\n cardList: PropTypes.objectOf(cardPropTypes),\n\n /** Whether the add Payment button be shown on the list */\n shouldShowAddPaymentMethodButton: PropTypes.bool,\n\n /** Are we loading payment methods? */\n isLoadingPaymentMethods: PropTypes.bool,\n\n /** Type to filter the payment Method list */\n filterType: PropTypes.oneOf([CONST.PAYMENT_METHODS.DEBIT_CARD, CONST.PAYMENT_METHODS.BANK_ACCOUNT, '']),\n\n /** User wallet props */\n userWallet: PropTypes.shape({\n /** The ID of the linked account */\n walletLinkedAccountID: PropTypes.number,\n\n /** The type of the linked account (debitCard or bankAccount) */\n walletLinkedAccountType: PropTypes.string,\n }),\n\n /** Type of active/highlighted payment method */\n actionPaymentMethodType: PropTypes.oneOf([..._.values(CONST.PAYMENT_METHODS), '']),\n\n /** ID of active/highlighted payment method */\n activePaymentMethodID: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n /** ID of selected payment method */\n selectedMethodID: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n /** Content for the FlatList header component */\n listHeaderComponent: PropTypes.func,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n payPalMeData: {},\n bankAccountList: {},\n cardList: {},\n userWallet: {\n walletLinkedAccountID: 0,\n walletLinkedAccountType: '',\n },\n isLoadingPaymentMethods: true,\n shouldShowAddPaymentMethodButton: true,\n filterType: '',\n actionPaymentMethodType: '',\n activePaymentMethodID: '',\n selectedMethodID: '',\n listHeaderComponent: null,\n};\n\nclass PaymentMethodList extends Component {\n constructor(props) {\n super(props);\n\n this.renderItem = this.renderItem.bind(this);\n }\n\n /**\n * @param {Boolean} isDefault\n * @returns {*}\n */\n getDefaultBadgeText(isDefault = false) {\n if (!isDefault) {\n return null;\n }\n\n const defaultablePaymentMethodCount = _.reduce(this.getFilteredPaymentMethods(), (count, method) => (\n (method.accountType === CONST.PAYMENT_METHODS.BANK_ACCOUNT || method.accountType === CONST.PAYMENT_METHODS.DEBIT_CARD)\n ? count + 1\n : count\n ), 0);\n if (defaultablePaymentMethodCount <= 1) {\n return null;\n }\n\n return this.props.translate('paymentMethodList.defaultPaymentMethod');\n }\n\n /**\n * @returns {Array}\n */\n getFilteredPaymentMethods() {\n // Hide any billing cards that are not P2P debit cards for now because you cannot make them your default method, or delete them\n const filteredCardList = _.filter(this.props.cardList, card => card.accountData.additionalData.isP2PDebitCard);\n let combinedPaymentMethods = PaymentUtils.formatPaymentMethods(this.props.bankAccountList, filteredCardList, this.props.payPalMeData);\n\n if (!_.isEmpty(this.props.filterType)) {\n combinedPaymentMethods = _.filter(combinedPaymentMethods, paymentMethod => paymentMethod.accountType === this.props.filterType);\n }\n\n if (!this.props.network.isOffline) {\n combinedPaymentMethods = _.filter(combinedPaymentMethods, paymentMethod => paymentMethod.pendingAction !== CONST.RED_BRICK_ROAD_PENDING_ACTION.DELETE\n || !_.isEmpty(paymentMethod.errors));\n }\n\n combinedPaymentMethods = _.map(combinedPaymentMethods, paymentMethod => ({\n ...paymentMethod,\n onPress: e => this.props.onPress(e, paymentMethod.accountType, paymentMethod.accountData, paymentMethod.isDefault, paymentMethod.methodID),\n iconFill: this.isPaymentMethodActive(paymentMethod) ? StyleUtils.getIconFillColor(CONST.BUTTON_STATES.PRESSED) : null,\n wrapperStyle: this.isPaymentMethodActive(paymentMethod) ? [StyleUtils.getButtonBackgroundColorStyle(CONST.BUTTON_STATES.PRESSED)] : null,\n disabled: paymentMethod.pendingAction === CONST.RED_BRICK_ROAD_PENDING_ACTION.DELETE,\n }));\n\n return combinedPaymentMethods;\n }\n\n /**\n * Dismisses the error on the payment method\n * @param {Object} item\n */\n dismissError(item) {\n const paymentList = item.accountType === CONST.PAYMENT_METHODS.BANK_ACCOUNT ? ONYXKEYS.BANK_ACCOUNT_LIST : ONYXKEYS.CARD_LIST;\n const paymentID = item.accountType === CONST.PAYMENT_METHODS.BANK_ACCOUNT ? lodashGet(item, ['accountData', 'bankAccountID'], '') : lodashGet(item, ['accountData', 'fundID'], '');\n\n if (!paymentID) {\n Log.info('Unable to clear payment method error: ', item);\n return;\n }\n\n if (item.pendingAction === CONST.RED_BRICK_ROAD_PENDING_ACTION.DELETE) {\n PaymentMethods.clearDeletePaymentMethodError(paymentList, paymentID);\n } else {\n PaymentMethods.clearAddPaymentMethodError(paymentList, paymentID);\n }\n }\n\n /**\n * @param {Object} paymentMethod\n * @param {String|Number} paymentMethod.methodID\n * @param {String} paymentMethod.accountType\n * @return {Boolean}\n */\n isPaymentMethodActive(paymentMethod) {\n return paymentMethod.accountType === this.props.actionPaymentMethodType && paymentMethod.methodID === this.props.activePaymentMethodID;\n }\n\n /**\n * Create a menuItem for each passed paymentMethod\n *\n * @param {Object} params\n * @param {Object} params.item\n *\n * @return {React.Component}\n */\n renderItem({item}) {\n return (\n this.dismissError(item)}\n pendingAction={item.pendingAction}\n errors={item.errors}\n errorRowStyles={styles.ph6}\n >\n \n \n );\n }\n\n /**\n * Show add first payment copy when payment methods are\n *\n * @return {React.Component}\n */\n renderListEmptyComponent() {\n return (\n \n {this.props.translate('paymentMethodList.addFirstPaymentMethod')}\n \n );\n }\n\n render() {\n return (\n <>\n item.key}\n ListEmptyComponent={this.renderListEmptyComponent()}\n ListHeaderComponent={this.props.listHeaderComponent}\n />\n {\n this.props.shouldShowAddPaymentMethodButton\n && (\n \n {\n isOffline => (\n this.props.onPress(e)}\n isDisabled={this.props.isLoadingPaymentMethods || isOffline}\n style={[styles.mh4, styles.buttonCTA]}\n iconStyles={[styles.buttonCTAIcon]}\n key=\"addPaymentMethodButton\"\n success\n shouldShowRightIcon\n large\n />\n )\n }\n \n )\n }\n \n );\n }\n}\n\nPaymentMethodList.propTypes = propTypes;\nPaymentMethodList.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withNetwork(),\n withOnyx({\n bankAccountList: {\n key: ONYXKEYS.BANK_ACCOUNT_LIST,\n },\n cardList: {\n key: ONYXKEYS.CARD_LIST,\n },\n isLoadingPaymentMethods: {\n key: ONYXKEYS.IS_LOADING_PAYMENT_METHODS,\n },\n payPalMeData: {\n key: ONYXKEYS.PAYPAL,\n },\n userWallet: {\n key: ONYXKEYS.USER_WALLET,\n },\n }),\n)(PaymentMethodList);\n","import React, {forwardRef} from 'react';\nimport BasePasswordPopover from './BasePasswordPopover';\nimport {propTypes, defaultProps} from './passwordPopoverPropTypes';\n\nconst PasswordPopover = forwardRef((props, ref) => (\n \n));\n\nPasswordPopover.propTypes = propTypes;\nPasswordPopover.defaultProps = defaultProps;\nPasswordPopover.displayName = 'PasswordPopover';\n\nexport default PasswordPopover;\n","import {View} from 'react-native';\nimport React, {Component} from 'react';\nimport PropTypes from 'prop-types';\nimport styles from '../../styles/styles';\nimport Text from '../Text';\nimport Popover from '../Popover';\nimport withLocalize, {withLocalizePropTypes} from '../withLocalize';\nimport compose from '../../libs/compose';\nimport withWindowDimensions from '../withWindowDimensions';\nimport TextInput from '../TextInput';\nimport KeyboardSpacer from '../KeyboardSpacer';\nimport {propTypes as passwordPopoverPropTypes, defaultProps as passwordPopoverDefaultProps} from './passwordPopoverPropTypes';\nimport Button from '../Button';\nimport withViewportOffsetTop from '../withViewportOffsetTop';\n\nconst propTypes = {\n /** Whether we should wait before focusing the TextInput, useful when using transitions on Android */\n shouldDelayFocus: PropTypes.bool,\n\n ...passwordPopoverPropTypes,\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n shouldDelayFocus: false,\n ...passwordPopoverDefaultProps,\n};\n\nclass BasePasswordPopover extends Component {\n constructor(props) {\n super(props);\n\n this.passwordInput = undefined;\n\n this.focusInput = this.focusInput.bind(this);\n\n this.state = {\n password: '',\n };\n }\n\n /**\n * Focus the password input\n */\n focusInput() {\n if (!this.passwordInput) {\n return;\n }\n this.passwordInput.focus();\n }\n\n render() {\n return (\n \n \n \n {this.props.translate('passwordForm.pleaseFillPassword')}\n \n this.passwordInput = el}\n secureTextEntry\n autoCompleteType=\"password\"\n textContentType=\"password\"\n value={this.state.currentPassword}\n onChangeText={password => this.setState({password})}\n returnKeyType=\"done\"\n onSubmitEditing={() => this.props.onSubmit(this.state.password)}\n style={styles.mt3}\n autoFocus\n shouldDelayFocus={this.props.shouldDelayFocus}\n />\n this.props.onSubmit(this.state.password)}\n style={styles.mt3}\n text={this.props.submitButtonText}\n />\n \n \n \n );\n }\n}\n\nBasePasswordPopover.propTypes = propTypes;\nBasePasswordPopover.defaultProps = defaultProps;\nexport default compose(\n withViewportOffsetTop,\n withWindowDimensions,\n withLocalize,\n)(BasePasswordPopover);\n","/**\n * On iOS the keyboard covers the input fields on the bottom of the view. This component moves the view up with the\n * keyboard allowing the user to see what they are typing.\n */\nimport React from 'react';\nimport BaseKeyboardSpacer from './BaseKeyboardSpacer';\nimport withWindowDimensions, {windowDimensionsPropTypes} from '../withWindowDimensions';\nimport * as StyleUtils from '../../styles/StyleUtils';\nimport CONST from '../../CONST';\n\nconst KeyboardSpacer = props => (\n \n);\n\nKeyboardSpacer.propTypes = windowDimensionsPropTypes;\nKeyboardSpacer.displayName = 'KeyboardSpacer';\n\nexport default withWindowDimensions(KeyboardSpacer);\n","import React, {PureComponent} from 'react';\nimport {\n Dimensions, Keyboard, View,\n} from 'react-native';\nimport * as StyleUtils from '../../styles/StyleUtils';\nimport {propTypes, defaultProps} from './BaseKeyboardSpacerPropTypes';\n\nclass BaseKeyboardSpacer extends PureComponent {\n constructor(props) {\n super(props);\n this.state = {\n keyboardSpace: 0,\n };\n this.keyboardListeners = null;\n this.updateKeyboardSpace = this.updateKeyboardSpace.bind(this);\n this.resetKeyboardSpace = this.resetKeyboardSpace.bind(this);\n }\n\n componentDidMount() {\n const updateListener = this.props.keyboardShowMethod;\n const resetListener = this.props.keyboardHideMethod;\n this.keyboardListeners = [\n Keyboard.addListener(updateListener, this.updateKeyboardSpace),\n Keyboard.addListener(resetListener, this.resetKeyboardSpace),\n ];\n }\n\n componentWillUnmount() {\n this.keyboardListeners.forEach(listener => listener.remove());\n }\n\n /**\n * Update the height of Keyboard View.\n *\n * @param {Object} [event] - A Keyboard Event.\n */\n updateKeyboardSpace(event) {\n if (!event.endCoordinates) {\n return;\n }\n\n const screenHeight = Dimensions.get('window').height;\n const keyboardSpace = (screenHeight - event.endCoordinates.screenY) + this.props.topSpacing;\n this.setState({\n keyboardSpace,\n }, this.props.onToggle(true, keyboardSpace));\n }\n\n /**\n * Reset the height of Keyboard View.\n *\n * @param {Object} [event] - A Keyboard Event.\n */\n resetKeyboardSpace() {\n this.setState({\n keyboardSpace: 0,\n }, this.props.onToggle(false, 0));\n }\n\n render() {\n return (\n \n );\n }\n}\n\nBaseKeyboardSpacer.defaultProps = defaultProps;\nBaseKeyboardSpacer.propTypes = propTypes;\n\nexport default BaseKeyboardSpacer;\n","import PropTypes from 'prop-types';\n\nconst propTypes = {\n /** Top Spacing is used when there is a requirement of additional height to view. */\n topSpacing: PropTypes.number,\n\n /** Callback to update the value of keyboard status along with keyboard height + top spacing. */\n onToggle: PropTypes.func,\n\n /** Platform specific keyboard event to show keyboard https://reactnative.dev/docs/keyboard#addlistener */\n /** Pass keyboardShow event name as a param, since iOS and android both have different event names show keyboard. */\n keyboardShowMethod: PropTypes.string.isRequired,\n\n /** Platform specific keyboard event to hide keyboard https://reactnative.dev/docs/keyboard#addlistener */\n /** Pass keyboardHide event name as a param, since iOS and android both have different event names show keyboard. */\n keyboardHideMethod: PropTypes.string.isRequired,\n};\n\nconst defaultProps = {\n topSpacing: 0,\n onToggle: () => null,\n};\n\nexport {propTypes, defaultProps};\n","import React, {Component} from 'react';\nimport PropTypes from 'prop-types';\nimport lodashGet from 'lodash/get';\nimport getComponentDisplayName from '../libs/getComponentDisplayName';\nimport addViewportResizeListener from '../libs/VisualViewport';\n\nconst viewportOffsetTopPropTypes = {\n // viewportOffsetTop returns the offset of the top edge of the visual viewport from the\n // top edge of the layout viewport in CSS pixels, when the visual viewport is resized.\n\n viewportOffsetTop: PropTypes.number.isRequired,\n};\n\nexport default function (WrappedComponent) {\n class WithViewportOffsetTop extends Component {\n constructor(props) {\n super(props);\n\n this.updateDimensions = this.updateDimensions.bind(this);\n\n this.state = {\n viewportOffsetTop: 0,\n };\n }\n\n componentDidMount() {\n this.removeViewportResizeListener = addViewportResizeListener(this.updateDimensions);\n }\n\n componentWillUnmount() {\n this.removeViewportResizeListener();\n }\n\n /**\n * @param {SyntheticEvent} e\n */\n updateDimensions(e) {\n const viewportOffsetTop = lodashGet(e, 'target.offsetTop', 0);\n this.setState({viewportOffsetTop});\n }\n\n render() {\n return (\n \n );\n }\n }\n\n WithViewportOffsetTop.displayName = `WithViewportOffsetTop(${getComponentDisplayName(WrappedComponent)})`;\n WithViewportOffsetTop.propTypes = {\n forwardedRef: PropTypes.oneOfType([\n PropTypes.func,\n PropTypes.shape({current: PropTypes.instanceOf(React.Component)}),\n ]),\n };\n WithViewportOffsetTop.defaultProps = {\n forwardedRef: undefined,\n };\n return React.forwardRef((props, ref) => (\n // eslint-disable-next-line react/jsx-props-no-spreading\n \n ));\n}\n\nexport {\n viewportOffsetTopPropTypes,\n};\n","\n/**\n * Visual Viewport is not available on native, so return an empty function.\n *\n * @returns {Function}\n */\nfunction addViewportResizeListener() {\n return () => {};\n}\n\nexport default addViewportResizeListener;\n","import PropTypes from 'prop-types';\n\nconst propTypes = {\n /** Is the popover currently showing? */\n isVisible: PropTypes.bool.isRequired,\n\n /** Function that gets called when the user closes the modal */\n onClose: PropTypes.func.isRequired,\n\n /** Where the popover should be placed */\n anchorPosition: PropTypes.shape({\n top: PropTypes.number,\n left: PropTypes.number,\n }).isRequired,\n\n /** Function that gets called when the user clicks the delete / make default button */\n onSubmit: PropTypes.func,\n\n /** The text that should be displayed in the submit button */\n submitButtonText: PropTypes.string,\n};\n\nconst defaultProps = {\n onSubmit: () => {},\n submitButtonText: '',\n};\n\nexport {propTypes, defaultProps};\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport {withOnyx} from 'react-native-onyx';\nimport styles from '../styles/styles';\nimport withLocalize, {withLocalizePropTypes} from './withLocalize';\nimport compose from '../libs/compose';\nimport ONYXKEYS from '../ONYXKEYS';\nimport Text from './Text';\n\nconst propTypes = {\n /** The user's wallet account */\n userWallet: PropTypes.shape({\n /** The user's current wallet balance */\n currentBalance: PropTypes.number,\n }),\n\n /** Styles of the amount */\n // eslint-disable-next-line react/forbid-prop-types\n balanceStyles: PropTypes.arrayOf(PropTypes.object),\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n userWallet: {\n\n // Default to zero if userWallet and currentBalance is not set yet to avoid NaN\n currentBalance: 0,\n },\n balanceStyles: [],\n};\n\nconst CurrentWalletBalance = (props) => {\n const formattedBalance = props.numberFormat(\n props.userWallet.currentBalance / 100, // Divide by 100 because balance is in cents\n {style: 'currency', currency: 'USD'},\n );\n return (\n \n {`${formattedBalance}`}\n \n );\n};\n\nCurrentWalletBalance.propTypes = propTypes;\nCurrentWalletBalance.defaultProps = defaultProps;\nCurrentWalletBalance.displayName = 'CurrentWalletBalance';\nexport default compose(\n withLocalize,\n withOnyx({\n userWallet: {\n key: ONYXKEYS.USER_WALLET,\n },\n }),\n)(CurrentWalletBalance);\n","import PropTypes from 'prop-types';\nimport walletTransferPropTypes from '../walletTransferPropTypes';\nimport {withLocalizePropTypes} from '../../../../components/withLocalize';\nimport {windowDimensionsPropTypes} from '../../../../components/withWindowDimensions';\nimport networkPropTypes from '../../../../components/networkPropTypes';\nimport bankAccountPropTypes from '../../../../components/bankAccountPropTypes';\nimport cardPropTypes from '../../../../components/cardPropTypes';\nimport userWalletPropTypes from '../../../EnablePayments/userWalletPropTypes';\nimport walletTermsPropTypes from '../../../EnablePayments/walletTermsPropTypes';\nimport paypalMeDataPropTypes from '../../../../components/paypalMeDataPropTypes';\n\nconst propTypes = {\n /** Wallet balance transfer props */\n walletTransfer: walletTransferPropTypes,\n\n /** List of betas available to current user */\n betas: PropTypes.arrayOf(PropTypes.string),\n\n /** Are we loading payment methods? */\n isLoadingPaymentMethods: PropTypes.bool,\n\n /** Listen for window resize event on web and desktop. */\n shouldListenForResize: PropTypes.bool,\n\n /** The user's wallet account */\n userWallet: userWalletPropTypes,\n\n /** Information about the network */\n network: networkPropTypes.isRequired,\n\n /** List of bank accounts */\n bankAccountList: PropTypes.objectOf(bankAccountPropTypes),\n\n /** List of cards */\n cardList: PropTypes.objectOf(cardPropTypes),\n\n /** Information about the user accepting the terms for payments */\n walletTerms: walletTermsPropTypes,\n\n /** Account details for PayPal.Me */\n payPalMeData: paypalMeDataPropTypes,\n\n ...withLocalizePropTypes,\n\n ...windowDimensionsPropTypes,\n};\n\nconst defaultProps = {\n walletTransfer: {\n shouldShowSuccess: false,\n },\n betas: [],\n isLoadingPaymentMethods: true,\n shouldListenForResize: false,\n userWallet: {},\n bankAccountList: {},\n cardList: {},\n walletTerms: {},\n payPalMeData: {},\n};\n\nexport {propTypes, defaultProps};\n","import PropTypes from 'prop-types';\nimport CONST from '../../../CONST';\n\n/** Wallet balance transfer props */\nconst walletTransferPropTypes = PropTypes.shape({\n /** Selected accountID for transfer */\n selectedAccountID: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n /** Type to filter the payment Method list */\n filterPaymentMethodType: PropTypes.oneOf([CONST.PAYMENT_METHODS.DEBIT_CARD, CONST.PAYMENT_METHODS.BANK_ACCOUNT, '']),\n\n /** Whether the success screen is shown to user. */\n shouldShowSuccess: PropTypes.bool,\n});\n\nexport default walletTransferPropTypes;\n","import _ from 'underscore';\nimport React from 'react';\nimport {View, ScrollView} from 'react-native';\nimport PropTypes from 'prop-types';\nimport {withOnyx} from 'react-native-onyx';\nimport ONYXKEYS from '../../../ONYXKEYS';\nimport HeaderWithCloseButton from '../../../components/HeaderWithCloseButton';\nimport ScreenWrapper from '../../../components/ScreenWrapper';\nimport Navigation from '../../../libs/Navigation/Navigation';\nimport styles from '../../../styles/styles';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport compose from '../../../libs/compose';\nimport * as Expensicons from '../../../components/Icon/Expensicons';\nimport MenuItem from '../../../components/MenuItem';\nimport CONST from '../../../CONST';\nimport variables from '../../../styles/variables';\nimport Text from '../../../components/Text';\nimport CurrentWalletBalance from '../../../components/CurrentWalletBalance';\nimport walletTransferPropTypes from './walletTransferPropTypes';\nimport * as PaymentMethods from '../../../libs/actions/PaymentMethods';\nimport * as PaymentUtils from '../../../libs/PaymentUtils';\nimport cardPropTypes from '../../../components/cardPropTypes';\nimport userWalletPropTypes from '../../EnablePayments/userWalletPropTypes';\nimport ROUTES from '../../../ROUTES';\nimport FormAlertWithSubmitButton from '../../../components/FormAlertWithSubmitButton';\nimport {withNetwork} from '../../../components/OnyxProvider';\nimport ConfirmationPage from '../../../components/ConfirmationPage';\n\nconst propTypes = {\n /** User's wallet information */\n userWallet: userWalletPropTypes,\n\n /** List of bank accounts */\n bankAccountList: PropTypes.objectOf(PropTypes.shape({\n /** The name of the institution (bank of america, etc) */\n addressName: PropTypes.string,\n\n /** The masked bank account number */\n accountNumber: PropTypes.string,\n\n /** The bankAccountID in the bankAccounts db */\n bankAccountID: PropTypes.number,\n\n /** The bank account type */\n type: PropTypes.string,\n })),\n\n /** List of card objects */\n cardList: PropTypes.objectOf(cardPropTypes),\n\n /** Wallet balance transfer props */\n walletTransfer: walletTransferPropTypes,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n bankAccountList: {},\n cardList: {},\n userWallet: {},\n walletTransfer: {},\n};\n\nclass TransferBalancePage extends React.Component {\n constructor(props) {\n super(props);\n\n this.paymentTypes = [\n {\n key: CONST.WALLET.TRANSFER_METHOD_TYPE.INSTANT,\n title: this.props.translate('transferAmountPage.instant'),\n description: this.props.translate('transferAmountPage.instantSummary', {\n rate: this.props.numberFormat(CONST.WALLET.TRANSFER_METHOD_TYPE_FEE.INSTANT.RATE),\n minAmount: this.props.numberFormat(\n CONST.WALLET.TRANSFER_METHOD_TYPE_FEE.INSTANT.MINIMUM_FEE / 100,\n {style: 'currency', currency: 'USD'},\n ),\n }),\n icon: Expensicons.Bolt,\n type: CONST.PAYMENT_METHODS.DEBIT_CARD,\n },\n {\n key: CONST.WALLET.TRANSFER_METHOD_TYPE.ACH,\n title: this.props.translate('transferAmountPage.ach'),\n description: this.props.translate('transferAmountPage.achSummary'),\n icon: Expensicons.Bank,\n type: CONST.PAYMENT_METHODS.BANK_ACCOUNT,\n },\n ];\n\n PaymentMethods.resetWalletTransferData();\n const selectedAccount = this.getSelectedPaymentMethodAccount();\n\n // Select the default payment account when page is opened,\n // so that user can see that preselected on choose transfer account page\n if (!selectedAccount || !selectedAccount.isDefault) {\n return;\n }\n\n PaymentMethods.saveWalletTransferAccountTypeAndID(\n selectedAccount.accountType,\n selectedAccount.methodID,\n );\n }\n\n /**\n * Get the selected/default payment method account for wallet transfer\n * @returns {Object|undefined}\n */\n getSelectedPaymentMethodAccount() {\n const paymentMethods = PaymentUtils.formatPaymentMethods(\n this.props.bankAccountList,\n this.props.cardList,\n );\n\n const defaultAccount = _.find(paymentMethods, method => method.isDefault);\n const selectedAccount = _.find(\n paymentMethods,\n method => method.accountType === this.props.walletTransfer.selectedAccountType\n && method.methodID === this.props.walletTransfer.selectedAccountID,\n );\n return selectedAccount || defaultAccount;\n }\n\n /**\n * @param {String} filterPaymentMethodType\n */\n navigateToChooseTransferAccount(filterPaymentMethodType) {\n PaymentMethods.saveWalletTransferMethodType(filterPaymentMethodType);\n\n // If we only have a single option for the given paymentMethodType do not force the user to make a selection\n const combinedPaymentMethods = PaymentUtils.formatPaymentMethods(\n this.props.bankAccountList,\n this.props.cardList,\n );\n\n const filteredMethods = _.filter(combinedPaymentMethods, paymentMethod => paymentMethod.accountType === filterPaymentMethodType);\n if (filteredMethods.length === 1) {\n const account = _.first(filteredMethods);\n PaymentMethods.saveWalletTransferAccountTypeAndID(\n filterPaymentMethodType,\n account.methodID,\n );\n return;\n }\n\n Navigation.navigate(ROUTES.SETTINGS_PAYMENTS_CHOOSE_TRANSFER_ACCOUNT);\n }\n\n render() {\n if (this.props.walletTransfer.shouldShowSuccess && !this.props.walletTransfer.loading) {\n return (\n \n \n \n \n );\n }\n const selectedAccount = this.getSelectedPaymentMethodAccount();\n const selectedPaymentType = selectedAccount && selectedAccount.accountType === CONST.PAYMENT_METHODS.BANK_ACCOUNT\n ? CONST.WALLET.TRANSFER_METHOD_TYPE.ACH\n : CONST.WALLET.TRANSFER_METHOD_TYPE.INSTANT;\n\n const calculatedFee = PaymentUtils.calculateWalletTransferBalanceFee(this.props.userWallet.currentBalance, selectedPaymentType);\n const transferAmount = this.props.userWallet.currentBalance - calculatedFee;\n const isTransferable = transferAmount > 0;\n const isButtonDisabled = !isTransferable || !selectedAccount;\n const errorMessage = !_.isEmpty(this.props.walletTransfer.errors) ? _.chain(this.props.walletTransfer.errors).values().first().value() : '';\n\n return (\n \n Navigation.goBack()}\n onCloseButtonPress={() => Navigation.dismissModal(true)}\n />\n \n \n \n \n \n {_.map(this.paymentTypes, paymentType => (\n this.navigateToChooseTransferAccount(paymentType.type)}\n />\n ))}\n \n \n {this.props.translate('transferAmountPage.whichAccount')}\n \n {Boolean(selectedAccount)\n && (\n this.navigateToChooseTransferAccount(selectedAccount.accountType)}\n />\n )}\n \n \n {this.props.translate('transferAmountPage.fee')}\n \n \n {this.props.numberFormat(\n calculatedFee / 100,\n {style: 'currency', currency: 'USD'},\n )}\n \n \n \n \n PaymentMethods.transferWalletBalance(selectedAccount)}\n isDisabled={isButtonDisabled || this.props.network.isOffline}\n message={errorMessage}\n isAlertVisible={!_.isEmpty(errorMessage)}\n />\n \n \n );\n }\n}\n\nTransferBalancePage.propTypes = propTypes;\nTransferBalancePage.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withNetwork(),\n withOnyx({\n userWallet: {\n key: ONYXKEYS.USER_WALLET,\n },\n walletTransfer: {\n key: ONYXKEYS.WALLET_TRANSFER,\n },\n bankAccountList: {\n key: ONYXKEYS.BANK_ACCOUNT_LIST,\n },\n cardList: {\n key: ONYXKEYS.CARD_LIST,\n },\n }),\n)(TransferBalancePage);\n","import React from 'react';\nimport {withOnyx} from 'react-native-onyx';\nimport {View} from 'react-native';\nimport HeaderWithCloseButton from '../../../components/HeaderWithCloseButton';\nimport ScreenWrapper from '../../../components/ScreenWrapper';\nimport Navigation from '../../../libs/Navigation/Navigation';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport CONST from '../../../CONST';\nimport PaymentMethodList from './PaymentMethodList';\nimport * as PaymentMethods from '../../../libs/actions/PaymentMethods';\nimport ROUTES from '../../../ROUTES';\nimport MenuItem from '../../../components/MenuItem';\nimport * as Expensicons from '../../../components/Icon/Expensicons';\nimport compose from '../../../libs/compose';\nimport ONYXKEYS from '../../../ONYXKEYS';\nimport walletTransferPropTypes from './walletTransferPropTypes';\nimport styles from '../../../styles/styles';\nimport * as BankAccounts from '../../../libs/actions/BankAccounts';\n\nconst propTypes = {\n /** Wallet transfer propTypes */\n walletTransfer: walletTransferPropTypes,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n walletTransfer: {},\n};\n\nconst ChooseTransferAccountPage = (props) => {\n /**\n * Go back to transfer balance screen with the selected bank account set\n * @param {Object} event Click event object\n * @param {String} accountType of the selected account type\n * @param {Object} account of the selected account data\n */\n const selectAccountAndNavigateBack = (event, accountType, account) => {\n PaymentMethods.saveWalletTransferAccountTypeAndID(\n accountType,\n accountType === CONST.PAYMENT_METHODS.BANK_ACCOUNT\n ? account.bankAccountID\n : account.fundID,\n );\n Navigation.navigate(ROUTES.SETTINGS_PAYMENTS_TRANSFER_BALANCE);\n };\n\n /**\n * @param {String} paymentType\n */\n const navigateToAddPaymentMethodPage = () => {\n if (props.walletTransfer.filterPaymentMethodType === CONST.PAYMENT_METHODS.DEBIT_CARD) {\n Navigation.navigate(ROUTES.SETTINGS_ADD_DEBIT_CARD);\n return;\n }\n BankAccounts.openPersonalBankAccountSetupView();\n };\n\n return (\n \n Navigation.goBack()}\n onCloseButtonPress={() => Navigation.dismissModal()}\n />\n \n \n \n \n \n );\n};\n\nChooseTransferAccountPage.propTypes = propTypes;\nChooseTransferAccountPage.defaultProps = defaultProps;\nChooseTransferAccountPage.displayName = 'ChooseTransferAccountPage';\n\nexport default compose(\n withLocalize,\n withOnyx({\n walletTransfer: {\n key: ONYXKEYS.WALLET_TRANSFER,\n },\n }),\n)(ChooseTransferAccountPage);\n","import React from 'react';\nimport {\n View, TouchableWithoutFeedback, Linking,\n} from 'react-native';\nimport _ from 'underscore';\nimport CONST from '../../../CONST';\nimport ROUTES from '../../../ROUTES';\nimport HeaderWithCloseButton from '../../../components/HeaderWithCloseButton';\nimport TextLink from '../../../components/TextLink';\nimport Text from '../../../components/Text';\nimport ScreenWrapper from '../../../components/ScreenWrapper';\nimport Navigation from '../../../libs/Navigation/Navigation';\nimport styles from '../../../styles/styles';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport Button from '../../../components/Button';\nimport FixedFooter from '../../../components/FixedFooter';\nimport Growl from '../../../libs/Growl';\nimport TextInput from '../../../components/TextInput';\nimport * as ValidationUtils from '../../../libs/ValidationUtils';\nimport * as User from '../../../libs/actions/User';\nimport Icon from '../../../components/Icon';\nimport * as Expensicons from '../../../components/Icon/Expensicons';\nimport variables from '../../../styles/variables';\n\nclass AddPayPalMePage extends React.Component {\n constructor(props) {\n super(props);\n\n this.state = {\n payPalMeUsername: '',\n payPalMeUsernameError: false,\n };\n this.setPayPalMeUsername = this.setPayPalMeUsername.bind(this);\n this.focusPayPalMeInput = this.focusPayPalMeInput.bind(this);\n }\n\n /**\n * Sets the payPalMeUsername for the current user\n */\n setPayPalMeUsername() {\n const isValid = ValidationUtils.isValidPaypalUsername(this.state.payPalMeUsername);\n if (!isValid) {\n this.setState({payPalMeUsernameError: true});\n return;\n }\n this.setState({payPalMeUsernameError: false});\n User.addPaypalMeAddress(this.state.payPalMeUsername);\n\n Growl.show(this.props.translate('addPayPalMePage.growlMessageOnSave'), CONST.GROWL.SUCCESS, 3000);\n Navigation.navigate(ROUTES.SETTINGS_PAYMENTS);\n }\n\n focusPayPalMeInput() {\n if (!this.payPalMeInputRef) {\n return;\n }\n\n this.payPalMeInputRef.focus();\n }\n\n render() {\n return (\n \n Navigation.navigate(ROUTES.SETTINGS_PAYMENTS)}\n onCloseButtonPress={() => Navigation.dismissModal(true)}\n />\n \n \n \n {this.props.translate('addPayPalMePage.enterYourUsernameToGetPaidViaPayPal')}\n \n this.payPalMeInputRef = el}\n label={this.props.translate('addPayPalMePage.payPalMe')}\n autoCompleteType=\"off\"\n autoCorrect={false}\n value={this.state.payPalMeUsername}\n placeholder={this.props.translate('addPayPalMePage.yourPayPalUsername')}\n onChangeText={text => this.setState({payPalMeUsername: text, payPalMeUsernameError: false})}\n returnKeyType=\"done\"\n hasError={this.state.payPalMeUsernameError}\n errorText={this.state.payPalMeUsernameError ? this.props.translate('addPayPalMePage.formatError') : ''}\n />\n \n \n {this.props.translate('addPayPalMePage.checkListOf')}\n \n Linking.openURL('https://developer.paypal.com/docs/reports/reference/paypal-supported-currencies')}\n >\n \n \n {this.props.translate('addPayPalMePage.supportedCurrencies')}\n \n \n \n \n \n \n \n \n \n \n \n \n \n );\n }\n}\n\nAddPayPalMePage.propTypes = {...withLocalizePropTypes};\n\nexport default withLocalize(AddPayPalMePage);\n","import _ from 'underscore';\nimport lodashGet from 'lodash/get';\nimport React, {useCallback, useState} from 'react';\nimport {View, ScrollView, Pressable} from 'react-native';\nimport {withOnyx} from 'react-native-onyx';\nimport PropTypes from 'prop-types';\nimport Navigation from '../../libs/Navigation/Navigation';\nimport ROUTES from '../../ROUTES';\nimport styles from '../../styles/styles';\nimport Tooltip from '../../components/Tooltip';\nimport Text from '../../components/Text';\nimport ConfirmModal from '../../components/ConfirmModal';\nimport * as Expensicons from '../../components/Icon/Expensicons';\nimport ScreenWrapper from '../../components/ScreenWrapper';\nimport withLocalize, {withLocalizePropTypes} from '../../components/withLocalize';\nimport MenuItem from '../../components/MenuItem';\nimport HeaderWithCloseButton from '../../components/HeaderWithCloseButton';\nimport compose from '../../libs/compose';\nimport Avatar from '../../components/Avatar';\nimport FullPageNotFoundView from '../../components/BlockingViews/FullPageNotFoundView';\nimport withPolicy, {policyPropTypes, policyDefaultProps} from './withPolicy';\nimport reportPropTypes from '../reportPropTypes';\nimport * as Policy from '../../libs/actions/Policy';\nimport * as PolicyUtils from '../../libs/PolicyUtils';\nimport CONST from '../../CONST';\nimport * as ReimbursementAccount from '../../libs/actions/ReimbursementAccount';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport OfflineWithFeedback from '../../components/OfflineWithFeedback';\nimport * as ReportUtils from '../../libs/ReportUtils';\n\nconst propTypes = {\n ...policyPropTypes,\n ...withLocalizePropTypes,\n\n /** All reports shared with the user (coming from Onyx) */\n reports: PropTypes.objectOf(reportPropTypes),\n\n};\n\nconst defaultProps = {\n reports: {},\n ...policyDefaultProps,\n};\n\n/**\n * @param {string} policyID\n */\nfunction openEditor(policyID) {\n Navigation.navigate(ROUTES.getWorkspaceSettingsRoute(policyID));\n}\n\n/**\n * @param {string} policyID\n */\nfunction dismissError(policyID) {\n Navigation.navigate(ROUTES.SETTINGS_WORKSPACES);\n Policy.removeWorkspace(policyID);\n}\n\nconst WorkspaceInitialPage = (props) => {\n const policy = props.policy;\n const [isDeleteModalOpen, setIsDeleteModalOpen] = useState(false);\n const hasPolicyCreationError = Boolean(policy.pendingAction === CONST.RED_BRICK_ROAD_PENDING_ACTION.ADD && policy.errors);\n\n /**\n * Call the delete policy and hide the modal\n */\n const confirmDeleteAndHideModal = useCallback(() => {\n const policyReports = _.filter(props.reports, report => report && report.policyID === policy.id);\n Policy.deleteWorkspace(policy.id, policyReports, policy.name);\n setIsDeleteModalOpen(false);\n Navigation.navigate(ROUTES.SETTINGS_WORKSPACES);\n }, [props.reports, policy]);\n\n const policyName = lodashGet(policy, 'name', '');\n const hasMembersError = PolicyUtils.hasPolicyMemberError(props.policyMemberList);\n const hasGeneralSettingsError = !_.isEmpty(lodashGet(policy, 'errorFields.generalSettings', {}))\n || !_.isEmpty(lodashGet(policy, 'errorFields.avatar', {}));\n const hasCustomUnitsError = PolicyUtils.hasCustomUnitsError(policy);\n const menuItems = [\n {\n translationKey: 'workspace.common.settings',\n icon: Expensicons.Gear,\n action: () => Navigation.navigate(ROUTES.getWorkspaceSettingsRoute(policy.id)),\n brickRoadIndicator: hasGeneralSettingsError ? CONST.BRICK_ROAD_INDICATOR_STATUS.ERROR : '',\n },\n {\n translationKey: 'workspace.common.card',\n icon: Expensicons.ExpensifyCard,\n action: () => Navigation.navigate(ROUTES.getWorkspaceCardRoute(policy.id)),\n },\n {\n translationKey: 'workspace.common.reimburse',\n icon: Expensicons.Receipt,\n action: () => Navigation.navigate(ROUTES.getWorkspaceReimburseRoute(policy.id)),\n error: hasCustomUnitsError,\n },\n {\n translationKey: 'workspace.common.bills',\n icon: Expensicons.Bill,\n action: () => Navigation.navigate(ROUTES.getWorkspaceBillsRoute(policy.id)),\n },\n {\n translationKey: 'workspace.common.invoices',\n icon: Expensicons.Invoice,\n action: () => Navigation.navigate(ROUTES.getWorkspaceInvoicesRoute(policy.id)),\n },\n {\n translationKey: 'workspace.common.travel',\n icon: Expensicons.Luggage,\n action: () => Navigation.navigate(ROUTES.getWorkspaceTravelRoute(policy.id)),\n },\n {\n translationKey: 'workspace.common.members',\n icon: Expensicons.Users,\n action: () => Navigation.navigate(ROUTES.getWorkspaceMembersRoute(policy.id)),\n brickRoadIndicator: hasMembersError ? CONST.BRICK_ROAD_INDICATOR_STATUS.ERROR : '',\n },\n {\n translationKey: 'workspace.common.bankAccount',\n icon: Expensicons.Bank,\n action: () => ReimbursementAccount.navigateToBankAccountRoute(policy.id),\n },\n ];\n\n return (\n \n {({safeAreaPaddingBottomStyle}) => (\n Navigation.navigate(ROUTES.SETTINGS_WORKSPACES)}\n >\n Navigation.navigate(ROUTES.SETTINGS_WORKSPACES)}\n onCloseButtonPress={() => Navigation.dismissModal()}\n shouldShowThreeDotsButton\n shouldShowGetAssistanceButton\n guidesCallTaskID={CONST.GUIDES_CALL_TASK_IDS.WORKSPACE_INITIAL}\n threeDotsMenuItems={[\n {\n icon: Expensicons.Trashcan,\n text: props.translate('workspace.common.delete'),\n onSelected: () => setIsDeleteModalOpen(true),\n },\n ]}\n threeDotsAnchorPosition={styles.threeDotsPopoverOffset}\n />\n \n dismissError(policy.id)}\n errors={policy.errors}\n errorRowStyles={[styles.ph6, styles.pv2]}\n >\n \n \n \n openEditor(policy.id)}\n >\n \n \n \n \n {!_.isEmpty(policy.name) && (\n openEditor(policy.id)}\n >\n \n \n {policy.name}\n \n \n \n )}\n \n \n {_.map(menuItems, item => (\n item.action()}\n shouldShowRightIcon\n brickRoadIndicator={item.brickRoadIndicator}\n />\n ))}\n \n \n \n setIsDeleteModalOpen(false)}\n prompt={props.translate('workspace.common.deleteConfirmation')}\n confirmText={props.translate('common.delete')}\n cancelText={props.translate('common.cancel')}\n danger\n />\n \n )}\n \n );\n};\n\nWorkspaceInitialPage.propTypes = propTypes;\nWorkspaceInitialPage.defaultProps = defaultProps;\nWorkspaceInitialPage.displayName = 'WorkspaceInitialPage';\n\nexport default compose(\n withLocalize,\n withPolicy,\n withOnyx({\n reports: {\n key: ONYXKEYS.COLLECTION.REPORT,\n },\n }),\n)(WorkspaceInitialPage);\n","import _ from 'underscore';\nimport lodashGet from 'lodash/get';\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport {withOnyx} from 'react-native-onyx';\nimport {useNavigationState} from '@react-navigation/native';\nimport CONST from '../../CONST';\nimport getComponentDisplayName from '../../libs/getComponentDisplayName';\nimport * as Policy from '../../libs/actions/Policy';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport policyMemberPropType from '../policyMemberPropType';\n\n/**\n * @param {Object} route\n * @returns {String}\n */\nfunction getPolicyIDFromRoute(route) {\n return lodashGet(route, 'params.policyID', '');\n}\n\nconst policyPropTypes = {\n /** The policy object for the current route */\n policy: PropTypes.shape({\n /** The ID of the policy */\n id: PropTypes.string,\n\n /** The name of the policy */\n name: PropTypes.string,\n\n /** The current user's role in the policy */\n role: PropTypes.oneOf(_.values(CONST.POLICY.ROLE)),\n\n /** The policy type */\n type: PropTypes.oneOf(_.values(CONST.POLICY.TYPE)),\n\n /** The email of the policy owner */\n owner: PropTypes.string,\n\n /** The output currency for the policy */\n outputCurrency: PropTypes.string,\n\n /** The URL for the policy avatar */\n avatar: PropTypes.string,\n\n /** Errors on the policy keyed by microtime */\n errors: PropTypes.objectOf(PropTypes.string),\n\n /**\n * Error objects keyed by field name containing errors keyed by microtime\n * E.x\n * {\n * name: {\n * [DateUtils.getMicroseconds()]: 'Sorry, there was an unexpected problem updating your workspace name.',\n * }\n * }\n */\n errorFields: PropTypes.objectOf(PropTypes.objectOf(PropTypes.string)),\n }),\n\n /** The employee list of this policy */\n policyMemberList: PropTypes.objectOf(policyMemberPropType),\n};\n\nconst policyDefaultProps = {\n policy: {},\n policyMemberList: {},\n};\n\n/*\n * HOC for connecting a policy in Onyx corresponding to the policyID in route params\n */\nexport default function (WrappedComponent) {\n const propTypes = {\n /** The HOC takes an optional ref as a prop and passes it as a ref to the wrapped component.\n * That way, if a ref is passed to a component wrapped in the HOC, the ref is a reference to the wrapped component, not the HOC. */\n forwardedRef: PropTypes.func,\n\n ...policyPropTypes,\n };\n\n const defaultProps = {\n forwardedRef: () => {},\n\n ...policyDefaultProps,\n };\n\n const WithPolicy = (props) => {\n const currentRoute = _.last(useNavigationState(state => state.routes || []));\n const policyID = getPolicyIDFromRoute(currentRoute);\n\n if (_.isString(policyID) && !_.isEmpty(policyID)) {\n Policy.updateLastAccessedWorkspace(policyID);\n }\n\n const rest = _.omit(props, ['forwardedRef']);\n return (\n \n );\n };\n\n WithPolicy.propTypes = propTypes;\n WithPolicy.defaultProps = defaultProps;\n WithPolicy.displayName = `withPolicy(${getComponentDisplayName(WrappedComponent)})`;\n const withPolicy = React.forwardRef((props, ref) => (\n // eslint-disable-next-line react/jsx-props-no-spreading\n \n ));\n\n return withOnyx({\n policy: {\n key: props => `${ONYXKEYS.COLLECTION.POLICY}${getPolicyIDFromRoute(props.route)}`,\n },\n policyMemberList: {\n key: props => `${ONYXKEYS.COLLECTION.POLICY_MEMBER_LIST}${getPolicyIDFromRoute(props.route)}`,\n },\n })(withPolicy);\n}\n\nexport {\n policyPropTypes,\n policyDefaultProps,\n};\n","import React from 'react';\nimport {Keyboard, View} from 'react-native';\nimport {withOnyx} from 'react-native-onyx';\nimport PropTypes from 'prop-types';\nimport _ from 'underscore';\nimport lodashGet from 'lodash/get';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport withLocalize, {withLocalizePropTypes} from '../../components/withLocalize';\nimport styles from '../../styles/styles';\nimport compose from '../../libs/compose';\nimport * as Policy from '../../libs/actions/Policy';\nimport * as Expensicons from '../../components/Icon/Expensicons';\nimport AvatarWithImagePicker from '../../components/AvatarWithImagePicker';\nimport CONST from '../../CONST';\nimport Picker from '../../components/Picker';\nimport TextInput from '../../components/TextInput';\nimport WorkspacePageWithSections from './WorkspacePageWithSections';\nimport withPolicy, {policyPropTypes, policyDefaultProps} from './withPolicy';\nimport {withNetwork} from '../../components/OnyxProvider';\nimport OfflineWithFeedback from '../../components/OfflineWithFeedback';\nimport Form from '../../components/Form';\nimport * as ReportUtils from '../../libs/ReportUtils';\nimport Avatar from '../../components/Avatar';\nimport Navigation from '../../libs/Navigation/Navigation';\nimport ROUTES from '../../ROUTES';\n\nconst propTypes = {\n // The currency list constant object from Onyx\n currencyList: PropTypes.objectOf(PropTypes.shape({\n // Symbol for the currency\n symbol: PropTypes.string,\n })),\n ...policyPropTypes,\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n currencyList: {},\n ...policyDefaultProps,\n};\n\nclass WorkspaceSettingsPage extends React.Component {\n constructor(props) {\n super(props);\n\n this.getCurrencyItems = this.getCurrencyItems.bind(this);\n this.submit = this.submit.bind(this);\n this.validate = this.validate.bind(this);\n }\n\n /**\n * @returns {Object[]}\n */\n getCurrencyItems() {\n const currencyListKeys = _.keys(this.props.currencyList);\n return _.map(currencyListKeys, currencyCode => ({\n value: currencyCode,\n label: `${currencyCode} - ${this.props.currencyList[currencyCode].symbol}`,\n }));\n }\n\n submit(values) {\n if (this.props.policy.isPolicyUpdating) {\n return;\n }\n const outputCurrency = values.currency;\n Policy.updateGeneralSettings(this.props.policy.id, values.name, outputCurrency);\n Keyboard.dismiss();\n Navigation.navigate(ROUTES.getWorkspaceInitialRoute(this.props.policy.id));\n }\n\n validate(values) {\n const errors = {};\n const name = values.name.trim();\n\n if (!name || !name.length) {\n errors.name = this.props.translate('workspace.editor.nameIsRequiredError');\n }\n\n return errors;\n }\n\n render() {\n const policyName = lodashGet(this.props.policy, 'name', '');\n return (\n \n {hasVBA => (\n \n Policy.clearAvatarErrors(this.props.policy.id)}\n >\n (\n \n )}\n type={CONST.ICON_TYPE_WORKSPACE}\n fallbackIcon={Expensicons.FallbackWorkspaceAvatar}\n style={[styles.mb3]}\n anchorPosition={{top: 172, right: 18}}\n isUsingDefaultAvatar={!lodashGet(this.props.policy, 'avatar', null)}\n onImageSelected={file => Policy.updateWorkspaceAvatar(lodashGet(this.props.policy, 'id', ''), file)}\n onImageRemoved={() => Policy.deleteWorkspaceAvatar(lodashGet(this.props.policy, 'id', ''))}\n editorMaskImage={Expensicons.ImageCropSquareMask}\n />\n \n \n \n \n \n \n \n \n )}\n \n );\n }\n}\n\nWorkspaceSettingsPage.propTypes = propTypes;\nWorkspaceSettingsPage.defaultProps = defaultProps;\n\nexport default compose(\n withPolicy,\n withOnyx({\n currencyList: {key: ONYXKEYS.CURRENCY_LIST},\n }),\n withLocalize,\n withNetwork(),\n)(WorkspaceSettingsPage);\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport {View} from 'react-native';\nimport {withOnyx} from 'react-native-onyx';\nimport lodashGet from 'lodash/get';\nimport _ from 'underscore';\nimport styles from '../../styles/styles';\nimport Navigation from '../../libs/Navigation/Navigation';\nimport compose from '../../libs/compose';\nimport ROUTES from '../../ROUTES';\nimport HeaderWithCloseButton from '../../components/HeaderWithCloseButton';\nimport ScreenWrapper from '../../components/ScreenWrapper';\nimport withLocalize, {withLocalizePropTypes} from '../../components/withLocalize';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport * as BankAccounts from '../../libs/actions/BankAccounts';\nimport BankAccount from '../../libs/models/BankAccount';\nimport * as ReimbursementAccountProps from '../ReimbursementAccount/reimbursementAccountPropTypes';\nimport userPropTypes from '../settings/userPropTypes';\nimport withPolicy from './withPolicy';\nimport {withNetwork} from '../../components/OnyxProvider';\nimport networkPropTypes from '../../components/networkPropTypes';\nimport FullPageNotFoundView from '../../components/BlockingViews/FullPageNotFoundView';\nimport ScrollViewWithContext from '../../components/ScrollViewWithContext';\n\nconst propTypes = {\n shouldSkipVBBACall: PropTypes.bool,\n\n /** Information about the network from Onyx */\n network: networkPropTypes.isRequired,\n\n /** The text to display in the header */\n headerText: PropTypes.string.isRequired,\n\n /** The route object passed to this page from the navigator */\n route: PropTypes.shape({\n /** Each parameter passed via the URL */\n params: PropTypes.shape({\n /** The policyID that is being configured */\n policyID: PropTypes.string.isRequired,\n }).isRequired,\n }).isRequired,\n\n /** From Onyx */\n /** Bank account attached to free plan */\n reimbursementAccount: ReimbursementAccountProps.reimbursementAccountPropTypes,\n\n /** User Data from Onyx */\n user: userPropTypes,\n\n /** Main content of the page */\n children: PropTypes.func,\n\n /** Content to be added as fixed footer */\n footer: PropTypes.element,\n\n /** The guides call task ID to associate with the workspace page being shown */\n guidesCallTaskID: PropTypes.string,\n\n /** Policy values needed in the component */\n policy: PropTypes.shape({\n name: PropTypes.string,\n }).isRequired,\n\n /** Option to use the default scroll view */\n shouldUseScrollView: PropTypes.bool,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n children: () => {},\n user: {},\n reimbursementAccount: ReimbursementAccountProps.reimbursementAccountDefaultProps,\n footer: null,\n guidesCallTaskID: '',\n shouldUseScrollView: false,\n shouldSkipVBBACall: false,\n};\n\nclass WorkspacePageWithSections extends React.Component {\n componentDidMount() {\n this.fetchData();\n }\n\n componentDidUpdate(prevProps) {\n if (!prevProps.network.isOffline || this.props.network.isOffline) {\n return;\n }\n\n this.fetchData();\n }\n\n fetchData() {\n if (this.props.shouldSkipVBBACall) {\n return;\n }\n\n BankAccounts.openWorkspaceView();\n }\n\n render() {\n const achState = lodashGet(this.props.reimbursementAccount, 'achData.state', '');\n const hasVBA = achState === BankAccount.STATE.OPEN;\n const isUsingECard = lodashGet(this.props.user, 'isUsingExpensifyCard', false);\n const policyID = lodashGet(this.props.route, 'params.policyID');\n const policyName = lodashGet(this.props.policy, 'name');\n\n return (\n \n Navigation.navigate(ROUTES.SETTINGS_WORKSPACES)}\n >\n Navigation.navigate(ROUTES.getWorkspaceInitialRoute(policyID))}\n onCloseButtonPress={() => Navigation.dismissModal()}\n />\n {this.props.shouldUseScrollView\n ? (\n \n \n\n {this.props.children(hasVBA, policyID, isUsingECard)}\n\n \n \n )\n : this.props.children(hasVBA, policyID, isUsingECard)}\n {this.props.footer}\n \n \n );\n }\n}\n\nWorkspacePageWithSections.propTypes = propTypes;\nWorkspacePageWithSections.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withOnyx({\n user: {\n key: ONYXKEYS.USER,\n },\n reimbursementAccount: {\n key: ONYXKEYS.REIMBURSEMENT_ACCOUNT,\n },\n }),\n withPolicy,\n withNetwork(),\n)(WorkspacePageWithSections);\n","import PropTypes from 'prop-types';\n\nexport default PropTypes.shape({\n /** error associated with adding a secondary login */\n error: PropTypes.string,\n\n /** Whether or not the user is on a public domain email account or not */\n isFromPublicDomain: PropTypes.bool,\n\n /** Whever Expensify Card approval flow is ongoing - checking loginList for private domains */\n isCheckingDomain: PropTypes.bool,\n\n /** Whether the form is being submitted */\n loading: PropTypes.bool,\n});\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport WorkspaceCardNoVBAView from './WorkspaceCardNoVBAView';\nimport WorkspaceCardVBANoECardView from './WorkspaceCardVBANoECardView';\nimport WorkspaceCardVBAWithECardView from './WorkspaceCardVBAWithECardView';\nimport WorkspacePageWithSections from '../WorkspacePageWithSections';\nimport CONST from '../../../CONST';\n\nconst propTypes = {\n /** The route object passed to this page from the navigator */\n route: PropTypes.shape({\n /** Each parameter passed via the URL */\n params: PropTypes.shape({\n /** The policyID that is being configured */\n policyID: PropTypes.string.isRequired,\n }).isRequired,\n }).isRequired,\n\n ...withLocalizePropTypes,\n};\n\nconst WorkspaceCardPage = props => (\n \n {(hasVBA, policyID, isUsingECard) => (\n <>\n {!hasVBA && (\n \n )}\n\n {hasVBA && !isUsingECard && (\n \n )}\n\n {hasVBA && isUsingECard && (\n \n )}\n \n )}\n \n);\n\nWorkspaceCardPage.propTypes = propTypes;\nWorkspaceCardPage.displayName = 'WorkspaceCardPage';\n\nexport default withLocalize(WorkspaceCardPage);\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport {View} from 'react-native';\nimport Text from '../../../components/Text';\nimport styles from '../../../styles/styles';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport * as Expensicons from '../../../components/Icon/Expensicons';\nimport * as Illustrations from '../../../components/Icon/Illustrations';\nimport UnorderedList from '../../../components/UnorderedList';\nimport Section from '../../../components/Section';\nimport Button from '../../../components/Button';\nimport * as ReimbursementAccount from '../../../libs/actions/ReimbursementAccount';\n\nconst propTypes = {\n /** The policy ID currently being configured */\n policyID: PropTypes.string.isRequired,\n\n ...withLocalizePropTypes,\n};\n\nconst WorkspaceCardNoVBAView = props => (\n \n \n {props.translate('workspace.card.noVBACopy')}\n \n\n \n ReimbursementAccount.navigateToBankAccountRoute(props.policyID)}\n icon={Expensicons.Bank}\n style={[styles.mt6]}\n iconStyles={[styles.mr5]}\n shouldShowRightIcon\n large\n success\n />\n \n);\n\nWorkspaceCardNoVBAView.propTypes = propTypes;\nWorkspaceCardNoVBAView.displayName = 'WorkspaceCardNoVBAView';\n\nexport default withLocalize(WorkspaceCardNoVBAView);\n","import Abracadabra from '../../../assets/images/product-illustrations/abracadabra.svg';\nimport BankArrowPink from '../../../assets/images/product-illustrations/bank-arrow--pink.svg';\nimport BankMouseGreen from '../../../assets/images/product-illustrations/bank-mouse--green.svg';\nimport BankUserGreen from '../../../assets/images/product-illustrations/bank-user--green.svg';\nimport ConciergeBlue from '../../../assets/images/product-illustrations/concierge--blue.svg';\nimport ConciergeExclamation from '../../../assets/images/product-illustrations/concierge--exclamation.svg';\nimport CreditCardsBlue from '../../../assets/images/product-illustrations/credit-cards--blue.svg';\nimport InvoiceOrange from '../../../assets/images/product-illustrations/invoice--orange.svg';\nimport JewelBoxBlue from '../../../assets/images/product-illustrations/jewel-box--blue.svg';\nimport JewelBoxGreen from '../../../assets/images/product-illustrations/jewel-box--green.svg';\nimport JewelBoxPink from '../../../assets/images/product-illustrations/jewel-box--pink.svg';\nimport JewelBoxYellow from '../../../assets/images/product-illustrations/jewel-box--yellow.svg';\nimport MagicCode from '../../../assets/images/product-illustrations/magic-code.svg';\nimport MoneyEnvelopeBlue from '../../../assets/images/product-illustrations/money-envelope--blue.svg';\nimport MoneyMousePink from '../../../assets/images/product-illustrations/money-mouse--pink.svg';\nimport ReceiptsSearchYellow from '../../../assets/images/product-illustrations/receipts-search--yellow.svg';\nimport ReceiptYellow from '../../../assets/images/product-illustrations/receipt--yellow.svg';\nimport RocketBlue from '../../../assets/images/product-illustrations/rocket--blue.svg';\nimport RocketOrange from '../../../assets/images/product-illustrations/rocket--orange.svg';\nimport SafeBlue from '../../../assets/images/product-illustrations/safe.svg';\nimport TadaYellow from '../../../assets/images/product-illustrations/tada--yellow.svg';\nimport TadaBlue from '../../../assets/images/product-illustrations/tada--blue.svg';\nimport ToddBehindCloud from '../../../assets/images/product-illustrations/todd-behind-cloud.svg';\nimport GpsTrackOrange from '../../../assets/images/product-illustrations/gps-track--orange.svg';\nimport ShieldYellow from '../../../assets/images/simple-illustrations/simple-illustration__shield.svg';\nimport MoneyReceipts from '../../../assets/images/simple-illustrations/simple-illustration__money-receipts.svg';\nimport PinkBill from '../../../assets/images/simple-illustrations/simple-illustration__bill.svg';\nimport CreditCardsNew from '../../../assets/images/simple-illustrations/simple-illustration__credit-cards.svg';\nimport InvoiceBlue from '../../../assets/images/simple-illustrations/simple-illustration__invoice.svg';\nimport LockOpen from '../../../assets/images/simple-illustrations/simple-illustration__lockopen.svg';\nimport Luggage from '../../../assets/images/simple-illustrations/simple-illustration__luggage.svg';\nimport MoneyIntoWallet from '../../../assets/images/simple-illustrations/simple-illustration__moneyintowallet.svg';\nimport MoneyWings from '../../../assets/images/simple-illustrations/simple-illustration__moneywings.svg';\nimport OpenSafe from '../../../assets/images/simple-illustrations/simple-illustration__opensafe.svg';\nimport TrackShoe from '../../../assets/images/simple-illustrations/simple-illustration__track-shoe.svg';\nimport BankArrow from '../../../assets/images/simple-illustrations/simple-illustration__bank-arrow.svg';\nimport ConciergeBubble from '../../../assets/images/simple-illustrations/simple-illustration__concierge-bubble.svg';\nimport ConciergeNew from '../../../assets/images/simple-illustrations/simple-illustration__concierge.svg';\nimport MoneyBadge from '../../../assets/images/simple-illustrations/simple-illustration__moneybadge.svg';\nimport TreasureChest from '../../../assets/images/simple-illustrations/simple-illustration__treasurechest.svg';\nimport ThumbsUpStars from '../../../assets/images/simple-illustrations/simple-illustration__thumbsupstars.svg';\nimport Hands from '../../../assets/images/product-illustrations/home-illustration-hands.svg';\n\nexport {\n Abracadabra,\n BankArrowPink,\n BankMouseGreen,\n BankUserGreen,\n ConciergeBlue,\n ConciergeExclamation,\n CreditCardsBlue,\n InvoiceOrange,\n JewelBoxBlue,\n JewelBoxGreen,\n JewelBoxPink,\n JewelBoxYellow,\n MagicCode,\n MoneyEnvelopeBlue,\n MoneyMousePink,\n ReceiptsSearchYellow,\n ReceiptYellow,\n RocketBlue,\n RocketOrange,\n SafeBlue,\n TadaYellow,\n TadaBlue,\n ToddBehindCloud,\n GpsTrackOrange,\n ShieldYellow,\n MoneyReceipts,\n PinkBill,\n CreditCardsNew,\n InvoiceBlue,\n LockOpen,\n Luggage,\n MoneyIntoWallet,\n MoneyWings,\n OpenSafe,\n TrackShoe,\n BankArrow,\n ConciergeBubble,\n ConciergeNew,\n MoneyBadge,\n TreasureChest,\n ThumbsUpStars,\n Hands,\n};\n","\n\n\n\n\n\t\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\t\n\n\n\t\n\n\n\t\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n","\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n","\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n","\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n","\n\n\n\n\n\n\n\n\n\n\n\n\n\n","\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n","\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n","\n\n\n\n\n\n\n\n\n\n\n\n\n\n","\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n","\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n","\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n","\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n","\n\n\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\t\n\n\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\t\n\t\n\n\n\t\n\n\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\n\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n\t\n\t\n\n\n","\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n","\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n","\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n","\n\n\n\n\n\n\n\n\n\n","\n\n\n\n\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\n\n","\n\n\n\n\n\t\n\t\t\n\t\n\t\n\t\t\n\t\n\t\n\t\t\n\t\t\n\t\t\n\t\t\n\t\t\n\t\t\n\t\t\n\t\t\n\t\t\n\t\t\n\t\t\n\t\t\n\t\t\n\t\t\n\t\t\n\t\t\n\t\t\n\t\t\n\t\t\n\t\t\n\t\t\n\t\t\n\t\t\n\t\t\n\t\t\n\t\t\n\t\t\n\t\t\n\t\t\n\t\t\n\t\t\n\t\n\n\n","\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n","\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n","\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n","\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n","\n\n\n\n\n\n\n\n\n\n\n\n","\n\n\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n","\n\n\n\n\n\t\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n","\n\n\n\n\n\n\n\n\n\n\t\n\t\n\n\n","\n\n\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n","\n\n\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\t\n\n\n","\n\n\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n","\n\n\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n","\n\n\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n","\n\n\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n","\n\n\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n","\n\n\n\n\n\t\n\t\t\n\t\t\t\n\t\t\n\t\t\n\t\t\t\n\t\t\n\t\t\n\t\t\t\n\t\t\n\t\t\n\t\t\t\n\t\t\n\t\t\n\t\t\t\n\t\t\n\t\t\n\t\t\t\n\t\t\n\t\t\n\t\t\t\n\t\t\n\t\t\n\t\t\t\n\t\t\n\t\t\n\t\t\t\n\t\t\n\t\t\n\t\t\t\n\t\t\n\t\t\n\t\t\t\n\t\t\n\t\t\n\t\t\t\n\t\t\n\t\t\n\t\t\t\n\t\t\n\t\t\n\t\t\t\n\t\t\n\t\t\n\t\t\t\n\t\t\n\t\t\n\t\t\t\n\t\t\n\t\t\n\t\t\t\n\t\t\n\t\n\n\n","\n\n\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n","\n\n\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n","\n\n\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n","\n\n\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n","\n\n\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n\t\n\n\n","\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n","\n\n\n\n\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\t\n\n\n","import React from 'react';\nimport _ from 'underscore';\nimport {View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport Text from './Text';\nimport styles from '../styles/styles';\n\nconst propTypes = {\n /** An array of strings to display as an unordered list */\n items: PropTypes.arrayOf(PropTypes.string),\n};\nconst defaultProps = {\n items: [],\n};\n\nconst UnorderedList = props => (\n <>\n {_.map(props.items, itemText => (\n \n {'\\u2022'}\n {itemText}\n \n ))}\n \n);\n\nUnorderedList.displayName = 'UnorderedList';\nUnorderedList.propTypes = propTypes;\nUnorderedList.defaultProps = defaultProps;\n\nexport default UnorderedList;\n","import React from 'react';\nimport {View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport Text from './Text';\nimport styles from '../styles/styles';\nimport MenuItemList from './MenuItemList';\nimport Icon from './Icon';\nimport menuItemPropTypes from './menuItemPropTypes';\n\nconst propTypes = {\n /** An array of props that are pass to individual MenuItem components */\n menuItems: PropTypes.arrayOf(PropTypes.shape(menuItemPropTypes)),\n\n /** The text to display in the title of the section */\n title: PropTypes.string.isRequired,\n\n /** The icon to display along with the title */\n icon: PropTypes.func,\n\n /** Icon component */\n IconComponent: PropTypes.func,\n\n /** Contents to display inside the section */\n children: PropTypes.node,\n\n /** Customize the Section container */\n // eslint-disable-next-line react/forbid-prop-types\n containerStyles: PropTypes.arrayOf(PropTypes.object),\n};\n\nconst defaultProps = {\n menuItems: null,\n children: null,\n icon: null,\n IconComponent: null,\n containerStyles: [],\n};\n\nconst Section = (props) => {\n const IconComponent = props.IconComponent;\n return (\n <>\n \n \n \n {props.title}\n \n \n {Boolean(props.icon) && }\n {Boolean(IconComponent) && }\n \n \n\n \n {props.children}\n \n\n \n {Boolean(props.menuItems) && }\n \n \n\n \n );\n};\n\nSection.displayName = 'Section';\nSection.propTypes = propTypes;\nSection.defaultProps = defaultProps;\n\nexport default Section;\n","import React from 'react';\nimport _ from 'underscore';\nimport PropTypes from 'prop-types';\nimport MenuItem from './MenuItem';\nimport menuItemPropTypes from './menuItemPropTypes';\nimport * as ReportActionContextMenu from '../pages/home/report/ContextMenu/ReportActionContextMenu';\nimport {CONTEXT_MENU_TYPES} from '../pages/home/report/ContextMenu/ContextMenuActions';\n\nconst propTypes = {\n /** An array of props that are pass to individual MenuItem components */\n menuItems: PropTypes.arrayOf(PropTypes.shape(menuItemPropTypes)),\n};\nconst defaultProps = {\n menuItems: [],\n};\n\nconst MenuItemList = (props) => {\n let popoverAnchor;\n\n /**\n * Handle the secondary interaction for a menu item.\n *\n * @param {*} link the menu item link or function to get the link\n * @param {Event} e the interaction event\n */\n const secondaryInteraction = (link, e) => {\n if (typeof link === 'function') {\n link().then(url => ReportActionContextMenu.showContextMenu(CONTEXT_MENU_TYPES.LINK, e, url, popoverAnchor));\n } else if (!_.isEmpty(link)) {\n ReportActionContextMenu.showContextMenu(CONTEXT_MENU_TYPES.LINK, e, link, popoverAnchor);\n }\n };\n\n return (\n <>\n {_.map(props.menuItems, menuItemProps => (\n secondaryInteraction(menuItemProps.link, e) : undefined}\n ref={el => popoverAnchor = el}\n shouldBlockSelection={Boolean(menuItemProps.link)}\n // eslint-disable-next-line react/jsx-props-no-spreading\n {...menuItemProps}\n />\n ))}\n \n );\n};\n\nMenuItemList.displayName = 'MenuItemList';\nMenuItemList.propTypes = propTypes;\nMenuItemList.defaultProps = defaultProps;\n\nexport default MenuItemList;\n","import React from 'react';\nimport {View} from 'react-native';\nimport {withOnyx} from 'react-native-onyx';\nimport Text from '../../../components/Text';\nimport Button from '../../../components/Button';\nimport styles from '../../../styles/styles';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport * as Expensicons from '../../../components/Icon/Expensicons';\nimport * as Illustrations from '../../../components/Icon/Illustrations';\nimport UnorderedList from '../../../components/UnorderedList';\nimport Section from '../../../components/Section';\nimport * as Link from '../../../libs/actions/Link';\nimport * as User from '../../../libs/actions/User';\nimport ONYXKEYS from '../../../ONYXKEYS';\nimport compose from '../../../libs/compose';\nimport CONST from '../../../CONST';\nimport userPropTypes from '../../settings/userPropTypes';\n\nconst propTypes = {\n /** Information about the logged in user's account */\n user: userPropTypes,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n user: {},\n};\n\nconst WorkspaceCardVBANoECardView = props => (\n <>\n \n \n \n \n {\n Link.openOldDotLink(CONST.ADD_SECONDARY_LOGIN_URL);\n User.subscribeToExpensifyCardUpdates();\n }}\n icon={Expensicons.Mail}\n style={[styles.mt4]}\n iconStyles={[styles.buttonCTAIcon]}\n shouldShowRightIcon\n large\n success\n />\n \n {Boolean(props.user.isCheckingDomain) && (\n \n {props.translate('workspace.card.checkingDomain')}\n \n )}\n \n);\n\nWorkspaceCardVBANoECardView.propTypes = propTypes;\nWorkspaceCardVBANoECardView.defaultProps = defaultProps;\nWorkspaceCardVBANoECardView.displayName = 'WorkspaceCardVBANoECardView';\n\nexport default compose(\n withLocalize,\n withOnyx({\n user: {\n key: ONYXKEYS.USER,\n },\n }),\n)(WorkspaceCardVBANoECardView);\n","import React from 'react';\nimport {View} from 'react-native';\nimport Text from '../../../components/Text';\nimport styles from '../../../styles/styles';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport * as Expensicons from '../../../components/Icon/Expensicons';\nimport * as Illustrations from '../../../components/Icon/Illustrations';\nimport UnorderedList from '../../../components/UnorderedList';\nimport * as Link from '../../../libs/actions/Link';\nimport Section from '../../../components/Section';\n\nconst propTypes = {\n ...withLocalizePropTypes,\n};\n\nconst MENU_LINKS = {\n ISSUE_AND_MANAGE_CARDS: 'domain_companycards',\n RECONCILE_CARDS: encodeURI('domain_companycards?param={\"section\":\"cardReconciliation\"}'),\n SETTLEMENT_FREQUENCY: encodeURI('domain_companycards?param={\"section\":\"configureSettings\"}'),\n};\n\nconst WorkspaceCardVBAWithECardView = (props) => {\n const menuItems = [\n {\n title: props.translate('workspace.common.issueAndManageCards'),\n onPress: () => Link.openOldDotLink(MENU_LINKS.ISSUE_AND_MANAGE_CARDS),\n icon: Expensicons.ExpensifyCard,\n shouldShowRightIcon: true,\n iconRight: Expensicons.NewWindow,\n wrapperStyle: [styles.cardMenuItem],\n link: () => Link.buildOldDotURL(MENU_LINKS.ISSUE_AND_MANAGE_CARDS),\n },\n {\n title: props.translate('workspace.common.reconcileCards'),\n onPress: () => Link.openOldDotLink(MENU_LINKS.RECONCILE_CARDS),\n icon: Expensicons.ReceiptSearch,\n shouldShowRightIcon: true,\n iconRight: Expensicons.NewWindow,\n wrapperStyle: [styles.cardMenuItem],\n link: () => Link.buildOldDotURL(MENU_LINKS.RECONCILE_CARDS),\n },\n {\n title: props.translate('workspace.common.settlementFrequency'),\n onPress: () => Link.openOldDotLink(MENU_LINKS.SETTLEMENT_FREQUENCY),\n icon: Expensicons.Gear,\n shouldShowRightIcon: true,\n iconRight: Expensicons.NewWindow,\n wrapperStyle: [styles.cardMenuItem],\n link: () => Link.buildOldDotURL(MENU_LINKS.SETTLEMENT_FREQUENCY),\n },\n ];\n\n return (\n \n \n {props.translate('workspace.card.VBAWithECardCopy')}\n \n\n \n \n \n \n );\n};\n\nWorkspaceCardVBAWithECardView.propTypes = propTypes;\nWorkspaceCardVBAWithECardView.displayName = 'WorkspaceCardVBAWithECardView';\n\nexport default withLocalize(WorkspaceCardVBAWithECardView);\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport WorkspaceReimburseView from './WorkspaceReimburseView';\nimport WorkspacePageWithSections from '../WorkspacePageWithSections';\nimport CONST from '../../../CONST';\nimport compose from '../../../libs/compose';\nimport withPolicy, {policyPropTypes} from '../withPolicy';\n\nconst propTypes = {\n /** The route object passed to this page from the navigator */\n route: PropTypes.shape({\n /** Each parameter passed via the URL */\n params: PropTypes.shape({\n /** The policyID that is being configured */\n policyID: PropTypes.string.isRequired,\n }).isRequired,\n }).isRequired,\n\n ...policyPropTypes,\n ...withLocalizePropTypes,\n};\n\nconst WorkspaceReimbursePage = props => (\n \n {() => (\n \n )}\n \n);\n\nWorkspaceReimbursePage.propTypes = propTypes;\nWorkspaceReimbursePage.displayName = 'WorkspaceReimbursePage';\n\nexport default compose(\n withPolicy,\n withLocalize,\n)(WorkspaceReimbursePage);\n","import React from 'react';\nimport {View} from 'react-native';\nimport {withOnyx} from 'react-native-onyx';\nimport PropTypes from 'prop-types';\nimport lodashGet from 'lodash/get';\nimport _ from 'underscore';\nimport TextInput from '../../../components/TextInput';\nimport Picker from '../../../components/Picker';\nimport Text from '../../../components/Text';\nimport styles from '../../../styles/styles';\nimport themeColors from '../../../styles/themes/default';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport * as Expensicons from '../../../components/Icon/Expensicons';\nimport * as Illustrations from '../../../components/Icon/Illustrations';\nimport Section from '../../../components/Section';\nimport CopyTextToClipboard from '../../../components/CopyTextToClipboard';\nimport * as Link from '../../../libs/actions/Link';\nimport compose from '../../../libs/compose';\nimport * as Policy from '../../../libs/actions/Policy';\nimport CONST from '../../../CONST';\nimport ONYXKEYS from '../../../ONYXKEYS';\nimport * as ReimbursementAccountProps from '../../ReimbursementAccount/reimbursementAccountPropTypes';\nimport getPermittedDecimalSeparator from '../../../libs/getPermittedDecimalSeparator';\nimport {withNetwork} from '../../../components/OnyxProvider';\nimport OfflineWithFeedback from '../../../components/OfflineWithFeedback';\nimport networkPropTypes from '../../../components/networkPropTypes';\nimport Log from '../../../libs/Log';\nimport WorkspaceReimburseSection from './WorkspaceReimburseSection';\nimport * as BankAccounts from '../../../libs/actions/BankAccounts';\n\nconst propTypes = {\n /** Policy values needed in the component */\n policy: PropTypes.shape({\n id: PropTypes.string,\n customUnits: PropTypes.objectOf(\n PropTypes.shape({\n customUnitID: PropTypes.string,\n name: PropTypes.string,\n attributes: PropTypes.shape({\n unit: PropTypes.string,\n }),\n rates: PropTypes.objectOf(\n PropTypes.shape({\n customUnitRateID: PropTypes.string,\n name: PropTypes.string,\n rate: PropTypes.number,\n }),\n ),\n }),\n ),\n outputCurrency: PropTypes.string,\n lastModified: PropTypes.number,\n }).isRequired,\n\n /** From Onyx */\n /** Bank account attached to free plan */\n reimbursementAccount: ReimbursementAccountProps.reimbursementAccountPropTypes,\n\n /** Information about the network */\n network: networkPropTypes.isRequired,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n reimbursementAccount: ReimbursementAccountProps.reimbursementAccountDefaultProps,\n};\n\nclass WorkspaceReimburseView extends React.Component {\n constructor(props) {\n super(props);\n const distanceCustomUnit = _.find(lodashGet(props, 'policy.customUnits', {}), unit => unit.name === 'Distance');\n const customUnitRate = _.find(lodashGet(distanceCustomUnit, 'rates', {}), rate => rate.name === 'Default Rate');\n\n this.state = {\n unitID: lodashGet(distanceCustomUnit, 'customUnitID', ''),\n unitName: lodashGet(distanceCustomUnit, 'name', ''),\n unitValue: lodashGet(distanceCustomUnit, 'attributes.unit', 'mi'),\n unitRateID: lodashGet(customUnitRate, 'customUnitRateID', ''),\n unitRateValue: this.getUnitRateValue(customUnitRate),\n outputCurrency: lodashGet(props, 'policy.outputCurrency', ''),\n };\n\n this.debounceUpdateOnCursorMove = this.debounceUpdateOnCursorMove.bind(this);\n this.updateRateValueDebounced = _.debounce(this.updateRateValue.bind(this), 1000);\n this.updatedValue = this.state.unitRateValue;\n }\n\n componentDidMount() {\n this.fetchData();\n }\n\n componentDidUpdate(prevProps) {\n if (prevProps.policy.customUnits !== this.props.policy.customUnits) {\n const distanceCustomUnit = _.chain(lodashGet(this.props, 'policy.customUnits', []))\n .values()\n .findWhere({name: CONST.CUSTOM_UNITS.NAME_DISTANCE})\n .value();\n const customUnitRate = _.find(lodashGet(distanceCustomUnit, 'rates', {}), rate => rate.name === 'Default Rate');\n this.setState({\n unitID: lodashGet(distanceCustomUnit, 'customUnitID', ''),\n unitName: lodashGet(distanceCustomUnit, 'name', ''),\n unitValue: lodashGet(distanceCustomUnit, 'attributes.unit', 'mi'),\n unitRateID: lodashGet(customUnitRate, 'customUnitRateID'),\n unitRateValue: this.getUnitRateValue(customUnitRate),\n });\n this.updatedValue = this.getUnitRateValue(customUnitRate);\n }\n\n const reconnecting = prevProps.network.isOffline && !this.props.network.isOffline;\n if (!reconnecting) {\n return;\n }\n\n this.fetchData();\n }\n\n getUnitRateValue(customUnitRate) {\n return this.getRateDisplayValue(lodashGet(customUnitRate, 'rate', 0) / CONST.POLICY.CUSTOM_UNIT_RATE_BASE_OFFSET);\n }\n\n getUnitItems() {\n return [\n {label: this.props.translate('workspace.reimburse.kilometers'), value: 'km'},\n {label: this.props.translate('workspace.reimburse.miles'), value: 'mi'},\n ];\n }\n\n getRateDisplayValue(value) {\n const numValue = this.getNumericValue(value);\n if (Number.isNaN(numValue)) {\n return '';\n }\n return numValue.toString().replace('.', this.props.toLocaleDigit('.')).substring(0, value.length);\n }\n\n getNumericValue(value) {\n const numValue = parseFloat(value.toString().replace(this.props.toLocaleDigit('.'), '.'));\n if (Number.isNaN(numValue)) {\n return NaN;\n }\n\n return numValue.toFixed(3);\n }\n\n setRate(inputValue) {\n const value = inputValue.replace(/[^0-9.,]/g, '');\n\n const decimalSeparator = this.props.toLocaleDigit('.');\n const rateValueRegex = RegExp(String.raw`^\\d{1,8}([${getPermittedDecimalSeparator(decimalSeparator)}]\\d{0,3})?$`, 'i');\n const isInvalidRateValue = value !== '' && !rateValueRegex.test(value);\n\n if (!isInvalidRateValue) {\n this.updatedValue = this.getRateDisplayValue(value);\n }\n this.setState({unitRateValue: value}, () => {\n // Set the corrected value with a delay and sync to the server\n this.updateRateValueDebounced(this.updatedValue);\n });\n }\n\n setUnit(value) {\n if (value === this.state.unitValue) {\n return;\n }\n\n const distanceCustomUnit = _.find(lodashGet(this.props, 'policy.customUnits', {}), unit => unit.name === 'Distance');\n if (!distanceCustomUnit) {\n Log.warn('Policy has no customUnits, returning early.', {\n policyID: this.props.policy.id,\n });\n return;\n }\n\n Policy.updateWorkspaceCustomUnit(this.props.policy.id, distanceCustomUnit, {\n customUnitID: this.state.unitID,\n name: this.state.unitName,\n attributes: {unit: value},\n }, this.props.policy.lastModified);\n }\n\n fetchData() {\n // Instead of setting the reimbursement account loading within the optimistic data of the API command, use a separate action so that the Onyx value is updated right away.\n // openWorkspaceReimburseView uses API.read which will not make the request until all WRITE requests in the sequential queue have finished responding, so there would be a delay in\n // updating Onyx with the optimistic data.\n BankAccounts.setReimbursementAccountLoading(true);\n Policy.openWorkspaceReimburseView(this.props.policy.id);\n }\n\n debounceUpdateOnCursorMove(event) {\n if (!_.contains(['ArrowLeft', 'ArrowRight'], event.key)) {\n return;\n }\n\n this.updateRateValueDebounced(this.state.unitRateValue);\n }\n\n updateRateValue(value) {\n const numValue = this.getNumericValue(value);\n\n if (_.isNaN(numValue)) {\n if (value === '') {\n this.setState({unitRateValue: value});\n }\n return;\n }\n\n const distanceCustomUnit = _.find(lodashGet(this.props, 'policy.customUnits', {}), unit => unit.name === 'Distance');\n const currentCustomUnitRate = lodashGet(distanceCustomUnit, ['rates', this.state.unitRateID], {});\n Policy.updateCustomUnitRate(this.props.policy.id, currentCustomUnitRate, this.state.unitID, {\n ...currentCustomUnitRate,\n rate: numValue * CONST.POLICY.CUSTOM_UNIT_RATE_BASE_OFFSET,\n }, this.props.policy.lastModified);\n }\n\n render() {\n const viewAllReceiptsUrl = `expenses?policyIDList=${this.props.policy.id}&billableReimbursable=reimbursable&submitterEmail=%2B%2B`;\n\n return (\n <>\n Link.openOldDotLink(viewAllReceiptsUrl),\n icon: Expensicons.Receipt,\n shouldShowRightIcon: true,\n iconRight: Expensicons.NewWindow,\n wrapperStyle: [styles.cardMenuItem],\n link: () => Link.buildOldDotURL(viewAllReceiptsUrl),\n },\n ]}\n >\n \n \n {this.props.translate('workspace.reimburse.captureNoVBACopyBeforeEmail')}\n \n {this.props.translate('workspace.reimburse.captureNoVBACopyAfterEmail')}\n \n \n \n\n \n \n {this.props.translate('workspace.reimburse.trackDistanceCopy')}\n \n Policy.clearCustomUnitErrors(this.props.policy.id, this.state.unitID, this.state.unitRateID)}\n >\n \n \n this.setRate(value)}\n value={this.state.unitRateValue}\n autoCompleteType=\"off\"\n autoCorrect={false}\n keyboardType={CONST.KEYBOARD_TYPE.DECIMAL_PAD}\n onKeyPress={this.debounceUpdateOnCursorMove}\n maxLength={12}\n />\n \n \n this.setUnit(value)}\n backgroundColor={themeColors.cardBG}\n />\n \n \n \n \n \n \n );\n }\n}\n\nWorkspaceReimburseView.defaultProps = defaultProps;\nWorkspaceReimburseView.propTypes = propTypes;\n\nexport default compose(\n withLocalize,\n withNetwork(),\n withOnyx({\n reimbursementAccount: {\n key: ONYXKEYS.REIMBURSEMENT_ACCOUNT,\n },\n }),\n)(WorkspaceReimburseView);\n","function _taggedTemplateLiteralLoose(strings, raw) {\n if (!raw) {\n raw = strings.slice(0);\n }\n\n strings.raw = raw;\n return strings;\n}\n\nmodule.exports = _taggedTemplateLiteralLoose, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","\n// On iOS keyboard can only have one symbol at a time (either dot or comma) so we accept both\n// Details: https://expensify.slack.com/archives/C01GTK53T8Q/p1658936908481629\nexport default () => '.,';\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport {ActivityIndicator, View} from 'react-native';\nimport lodashGet from 'lodash/get';\nimport _ from 'underscore';\nimport Text from '../../../components/Text';\nimport styles from '../../../styles/styles';\nimport themeColors from '../../../styles/themes/default';\nimport * as Expensicons from '../../../components/Icon/Expensicons';\nimport * as Illustrations from '../../../components/Icon/Illustrations';\nimport Section from '../../../components/Section';\nimport * as Link from '../../../libs/actions/Link';\nimport Button from '../../../components/Button';\nimport BankAccount from '../../../libs/models/BankAccount';\nimport * as ReimbursementAccountProps from '../../ReimbursementAccount/reimbursementAccountPropTypes';\nimport * as ReimbursementAccount from '../../../libs/actions/ReimbursementAccount';\nimport networkPropTypes from '../../../components/networkPropTypes';\nimport CONST from '../../../CONST';\n\nconst propTypes = {\n /** Policy values needed in the component */\n policy: PropTypes.shape({\n id: PropTypes.string,\n }).isRequired,\n\n /** Bank account attached to free plan */\n reimbursementAccount: ReimbursementAccountProps.reimbursementAccountPropTypes.isRequired,\n\n /** Information about the network */\n network: networkPropTypes.isRequired,\n\n /** Returns translated string for given locale and phrase */\n translate: PropTypes.func.isRequired,\n};\n\nclass WorkspaceReimburseSection extends React.Component {\n constructor(props) {\n super(props);\n this.state = {\n shouldShowLoadingSpinner: false,\n };\n\n this.debounceSetShouldShowLoadingSpinner = _.debounce(this.setShouldShowLoadingSpinner.bind(this), CONST.TIMING.SHOW_LOADING_SPINNER_DEBOUNCE_TIME);\n }\n\n componentDidUpdate() {\n this.debounceSetShouldShowLoadingSpinner();\n }\n\n setShouldShowLoadingSpinner() {\n const shouldShowLoadingSpinner = this.props.reimbursementAccount.isLoading || false;\n if (shouldShowLoadingSpinner !== this.state.shouldShowLoadingSpinner) {\n this.setState({shouldShowLoadingSpinner});\n }\n }\n\n render() {\n const achState = lodashGet(this.props.reimbursementAccount, 'achData.state', '');\n const hasVBA = achState === BankAccount.STATE.OPEN;\n const reimburseReceiptsUrl = `reports?policyID=${this.props.policy.id}&from=all&type=expense&showStates=Archived&isAdvancedFilterMode=true`;\n\n if (this.props.network.isOffline) {\n return (\n \n \n {`${this.props.translate('common.youAppearToBeOffline')} ${this.props.translate('common.thisFeatureRequiresInternet')}`}\n \n \n );\n }\n\n // If the reimbursementAccount is loading but not enough time has passed to show a spinner, then render nothing.\n if (this.props.reimbursementAccount.isLoading && !this.state.shouldShowLoadingSpinner) {\n return null;\n }\n\n if (this.state.shouldShowLoadingSpinner) {\n return (\n \n \n \n );\n }\n\n return (\n <>\n {hasVBA ? (\n Link.openOldDotLink(reimburseReceiptsUrl),\n icon: Expensicons.Bank,\n shouldShowRightIcon: true,\n iconRight: Expensicons.NewWindow,\n wrapperStyle: [styles.cardMenuItem],\n link: () => Link.buildOldDotURL(reimburseReceiptsUrl),\n },\n ]}\n >\n \n {this.props.translate('workspace.reimburse.fastReimbursementsVBACopy')}\n \n \n ) : (\n \n \n {this.props.translate('workspace.reimburse.unlockNoVBACopy')}\n \n ReimbursementAccount.navigateToBankAccountRoute(this.props.policy.id)}\n icon={Expensicons.Bank}\n style={[styles.mt4]}\n iconStyles={[styles.buttonCTAIcon]}\n shouldShowRightIcon\n large\n success\n />\n \n )}\n \n );\n }\n}\n\nWorkspaceReimburseSection.propTypes = propTypes;\n\nexport default WorkspaceReimburseSection;\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport WorkspaceBillsNoVBAView from './WorkspaceBillsNoVBAView';\nimport WorkspaceBillsVBAView from './WorkspaceBillsVBAView';\nimport WorkspacePageWithSections from '../WorkspacePageWithSections';\nimport CONST from '../../../CONST';\n\nconst propTypes = {\n /** The route object passed to this page from the navigator */\n route: PropTypes.shape({\n /** Each parameter passed via the URL */\n params: PropTypes.shape({\n /** The policyID that is being configured */\n policyID: PropTypes.string.isRequired,\n }).isRequired,\n }).isRequired,\n\n ...withLocalizePropTypes,\n};\n\nconst WorkspaceBillsPage = props => (\n \n {(hasVBA, policyID) => (\n <>\n {!hasVBA && (\n \n )}\n {hasVBA && (\n \n )}\n \n )}\n \n);\n\nWorkspaceBillsPage.propTypes = propTypes;\nWorkspaceBillsPage.displayName = 'WorkspaceBillsPage';\nexport default withLocalize(WorkspaceBillsPage);\n","import React from 'react';\nimport {View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport Text from '../../../components/Text';\nimport styles from '../../../styles/styles';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport * as Expensicons from '../../../components/Icon/Expensicons';\nimport * as Illustrations from '../../../components/Icon/Illustrations';\nimport Section from '../../../components/Section';\nimport WorkspaceBillsFirstSection from './WorkspaceBillsFirstSection';\nimport Button from '../../../components/Button';\nimport * as ReimbursementAccount from '../../../libs/actions/ReimbursementAccount';\n\nconst propTypes = {\n /** The policy ID currently being configured */\n policyID: PropTypes.string.isRequired,\n\n ...withLocalizePropTypes,\n};\n\nconst WorkspaceBillsNoVBAView = props => (\n <>\n \n\n \n \n {props.translate('workspace.bills.unlockNoVBACopy')}\n \n ReimbursementAccount.navigateToBankAccountRoute(props.policyID)}\n icon={Expensicons.Bank}\n style={[styles.mt4]}\n iconStyles={[styles.buttonCTAIcon]}\n shouldShowRightIcon\n large\n success\n />\n \n \n);\n\nWorkspaceBillsNoVBAView.propTypes = propTypes;\nWorkspaceBillsNoVBAView.displayName = 'WorkspaceBillsNoVBAView';\n\nexport default withLocalize(WorkspaceBillsNoVBAView);\n","import React from 'react';\nimport {View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport {withOnyx} from 'react-native-onyx';\nimport Str from 'expensify-common/lib/str';\nimport Text from '../../../components/Text';\nimport styles from '../../../styles/styles';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport * as Expensicons from '../../../components/Icon/Expensicons';\nimport * as Illustrations from '../../../components/Icon/Illustrations';\nimport Section from '../../../components/Section';\nimport CopyTextToClipboard from '../../../components/CopyTextToClipboard';\nimport * as Link from '../../../libs/actions/Link';\nimport compose from '../../../libs/compose';\nimport ONYXKEYS from '../../../ONYXKEYS';\nimport userPropTypes from '../../settings/userPropTypes';\nimport TextLink from '../../../components/TextLink';\n\nconst propTypes = {\n /** The policy ID currently being configured */\n policyID: PropTypes.string.isRequired,\n\n ...withLocalizePropTypes,\n\n /* From Onyx */\n /** Session of currently logged in user */\n session: PropTypes.shape({\n /** Email address */\n email: PropTypes.string.isRequired,\n }),\n\n /** Information about the logged in user's account */\n user: userPropTypes,\n};\n\nconst defaultProps = {\n session: {\n email: null,\n },\n user: {},\n};\n\nconst WorkspaceBillsFirstSection = (props) => {\n const emailDomain = Str.extractEmailDomain(props.session.email);\n const manageYourBillsUrl = `reports?policyID=${props.policyID}&from=all&type=bill&showStates=Open,Processing,Approved,Reimbursed,Archived&isAdvancedFilterMode=true`;\n return (\n (\n Link.openOldDotLink(manageYourBillsUrl)\n ),\n icon: Expensicons.Bill,\n shouldShowRightIcon: true,\n iconRight: Expensicons.NewWindow,\n wrapperStyle: [styles.cardMenuItem],\n link: () => Link.buildOldDotURL(manageYourBillsUrl),\n },\n ]}\n containerStyles={[styles.cardSection]}\n >\n \n \n {props.translate('workspace.bills.askYourVendorsBeforeEmail')}\n {props.user.isFromPublicDomain ? (\n Link.openExternalLink('https://community.expensify.com/discussion/7500/how-to-pay-your-company-bills-in-expensify/')}\n >\n example.com@expensify.cash\n \n ) : (\n \n )}\n {props.translate('workspace.bills.askYourVendorsAfterEmail')}\n \n \n \n );\n};\n\nWorkspaceBillsFirstSection.propTypes = propTypes;\nWorkspaceBillsFirstSection.defaultProps = defaultProps;\nWorkspaceBillsFirstSection.displayName = 'WorkspaceBillsFirstSection';\n\nexport default compose(\n withLocalize,\n withOnyx({\n session: {\n key: ONYXKEYS.SESSION,\n },\n user: {\n key: ONYXKEYS.USER,\n },\n }),\n)(WorkspaceBillsFirstSection);\n","import React from 'react';\nimport {View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport Text from '../../../components/Text';\nimport styles from '../../../styles/styles';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport * as Expensicons from '../../../components/Icon/Expensicons';\nimport * as Illustrations from '../../../components/Icon/Illustrations';\nimport Section from '../../../components/Section';\nimport * as Link from '../../../libs/actions/Link';\nimport WorkspaceBillsFirstSection from './WorkspaceBillsFirstSection';\n\nconst propTypes = {\n /** The policy ID currently being configured */\n policyID: PropTypes.string.isRequired,\n\n ...withLocalizePropTypes,\n};\n\nconst WorkspaceBillsVBAView = (props) => {\n const reportsUrl = `reports?policyID=${props.policyID}&from=all&type=bill&showStates=Processing,Approved&isAdvancedFilterMode=true`;\n\n return (\n <>\n \n\n Link.openOldDotLink(reportsUrl),\n icon: Expensicons.Bill,\n shouldShowRightIcon: true,\n iconRight: Expensicons.NewWindow,\n wrapperStyle: [styles.cardMenuItem],\n link: () => Link.buildOldDotURL(reportsUrl),\n },\n ]}\n >\n \n {props.translate('workspace.bills.VBACopy')}\n \n \n \n );\n};\n\nWorkspaceBillsVBAView.propTypes = propTypes;\nWorkspaceBillsVBAView.displayName = 'WorkspaceBillsVBAView';\n\nexport default withLocalize(WorkspaceBillsVBAView);\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport WorkspacePageWithSections from '../WorkspacePageWithSections';\nimport WorkspaceInvoicesNoVBAView from './WorkspaceInvoicesNoVBAView';\nimport WorkspaceInvoicesVBAView from './WorkspaceInvoicesVBAView';\nimport CONST from '../../../CONST';\n\nconst propTypes = {\n /** The route object passed to this page from the navigator */\n route: PropTypes.shape({\n /** Each parameter passed via the URL */\n params: PropTypes.shape({\n /** The policyID that is being configured */\n policyID: PropTypes.string.isRequired,\n }).isRequired,\n }).isRequired,\n\n ...withLocalizePropTypes,\n};\n\nconst WorkspaceInvoicesPage = props => (\n \n {(hasVBA, policyID) => (\n <>\n {!hasVBA && (\n \n )}\n {hasVBA && (\n \n )}\n \n )}\n \n);\n\nWorkspaceInvoicesPage.propTypes = propTypes;\nWorkspaceInvoicesPage.displayName = 'WorkspaceInvoicesPage';\n\nexport default withLocalize(WorkspaceInvoicesPage);\n","import React from 'react';\nimport {View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport Text from '../../../components/Text';\nimport styles from '../../../styles/styles';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport * as Expensicons from '../../../components/Icon/Expensicons';\nimport * as Illustrations from '../../../components/Icon/Illustrations';\nimport Section from '../../../components/Section';\nimport WorkspaceInvoicesFirstSection from './WorkspaceInvoicesFirstSection';\nimport Button from '../../../components/Button';\nimport * as ReimbursementAccount from '../../../libs/actions/ReimbursementAccount';\n\nconst propTypes = {\n /** The policy ID currently being configured */\n policyID: PropTypes.string.isRequired,\n\n ...withLocalizePropTypes,\n};\n\nconst WorkspaceInvoicesNoVBAView = props => (\n <>\n \n\n \n \n {props.translate('workspace.invoices.unlockNoVBACopy')}\n \n ReimbursementAccount.navigateToBankAccountRoute(props.policyID)}\n icon={Expensicons.Bank}\n style={[styles.mt4]}\n iconStyles={[styles.buttonCTAIcon]}\n shouldShowRightIcon\n large\n success\n />\n \n \n);\n\nWorkspaceInvoicesNoVBAView.propTypes = propTypes;\nWorkspaceInvoicesNoVBAView.displayName = 'WorkspaceInvoicesNoVBAView';\n\nexport default withLocalize(WorkspaceInvoicesNoVBAView);\n","import React from 'react';\nimport {View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport Text from '../../../components/Text';\nimport styles from '../../../styles/styles';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport * as Expensicons from '../../../components/Icon/Expensicons';\nimport * as Illustrations from '../../../components/Icon/Illustrations';\nimport Section from '../../../components/Section';\nimport * as Link from '../../../libs/actions/Link';\n\nconst propTypes = {\n /** The policy ID currently being configured */\n policyID: PropTypes.string.isRequired,\n\n ...withLocalizePropTypes,\n};\n\nconst WorkspaceInvoicesFirstSection = (props) => {\n const sendInvoiceUrl = encodeURI('reports?param={\"createInvoice\":true}');\n const viewAllInvoicesUrl = `reports?policyID=${props.policyID}&from=all&type=invoice&showStates=Open,Processing,Approved,Reimbursed,Archived&isAdvancedFilterMode=true`;\n\n return (\n Link.openOldDotLink(sendInvoiceUrl),\n icon: Expensicons.Send,\n shouldShowRightIcon: true,\n iconRight: Expensicons.NewWindow,\n wrapperStyle: [styles.cardMenuItem],\n link: () => Link.buildOldDotURL(sendInvoiceUrl),\n },\n {\n title: props.translate('workspace.invoices.viewAllInvoices'),\n onPress: () => (\n Link.openOldDotLink(viewAllInvoicesUrl)\n ),\n icon: Expensicons.Invoice,\n shouldShowRightIcon: true,\n iconRight: Expensicons.NewWindow,\n wrapperStyle: [styles.cardMenuItem],\n link: () => Link.buildOldDotURL(viewAllInvoicesUrl),\n },\n ]}\n containerStyles={[styles.cardSection]}\n >\n \n \n {props.translate('workspace.invoices.invoiceFirstSectionCopy')}\n \n \n \n );\n};\n\nWorkspaceInvoicesFirstSection.propTypes = propTypes;\nWorkspaceInvoicesFirstSection.displayName = 'WorkspaceInvoicesFirstSection';\n\nexport default withLocalize(WorkspaceInvoicesFirstSection);\n","import React from 'react';\nimport {View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport Text from '../../../components/Text';\nimport styles from '../../../styles/styles';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport * as Expensicons from '../../../components/Icon/Expensicons';\nimport * as Illustrations from '../../../components/Icon/Illustrations';\nimport Section from '../../../components/Section';\nimport WorkspaceInvoicesFirstSection from './WorkspaceInvoicesFirstSection';\nimport * as Link from '../../../libs/actions/Link';\n\nconst propTypes = {\n /** The policy ID currently being configured */\n policyID: PropTypes.string.isRequired,\n\n ...withLocalizePropTypes,\n};\n\nconst WorkspaceInvoicesVBAView = (props) => {\n const viewUnpaidInvoicesUrl = `reports?policyID=${props.policyID}&from=all&type=invoice&showStates=Processing&isAdvancedFilterMode=true`;\n\n return (\n <>\n \n\n Link.openOldDotLink(viewUnpaidInvoicesUrl),\n icon: Expensicons.Hourglass,\n shouldShowRightIcon: true,\n iconRight: Expensicons.NewWindow,\n wrapperStyle: [styles.cardMenuItem],\n link: () => Link.buildOldDotURL(viewUnpaidInvoicesUrl),\n },\n ]}\n >\n \n {props.translate('workspace.invoices.unlockVBACopy')}\n \n \n \n );\n};\n\nWorkspaceInvoicesVBAView.propTypes = propTypes;\nWorkspaceInvoicesVBAView.displayName = 'WorkspaceInvoicesVBAView';\n\nexport default withLocalize(WorkspaceInvoicesVBAView);\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport WorkspacePageWithSections from '../WorkspacePageWithSections';\nimport WorkspaceTravelNoVBAView from './WorkspaceTravelNoVBAView';\nimport WorkspaceTravelVBAView from './WorkspaceTravelVBAView';\nimport CONST from '../../../CONST';\n\nconst propTypes = {\n /** The route object passed to this page from the navigator */\n route: PropTypes.shape({\n /** Each parameter passed via the URL */\n params: PropTypes.shape({\n /** The policyID that is being configured */\n policyID: PropTypes.string.isRequired,\n }).isRequired,\n }).isRequired,\n\n ...withLocalizePropTypes,\n};\n\nconst WorkspaceTravelPage = props => (\n \n {(hasVBA, policyID) => (\n <>\n {!hasVBA && (\n \n )}\n {hasVBA && (\n \n )}\n \n )}\n \n);\n\nWorkspaceTravelPage.propTypes = propTypes;\nWorkspaceTravelPage.displayName = 'WorkspaceTravelPage';\n\nexport default withLocalize(WorkspaceTravelPage);\n","import React from 'react';\nimport {View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport Text from '../../../components/Text';\nimport styles from '../../../styles/styles';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport * as Expensicons from '../../../components/Icon/Expensicons';\nimport * as Illustrations from '../../../components/Icon/Illustrations';\nimport Section from '../../../components/Section';\nimport Button from '../../../components/Button';\nimport * as ReimbursementAccount from '../../../libs/actions/ReimbursementAccount';\n\nconst propTypes = {\n /** The policy ID currently being configured */\n policyID: PropTypes.string.isRequired,\n\n ...withLocalizePropTypes,\n};\n\nconst WorkspaceTravelNoVBAView = props => (\n <>\n \n \n {props.translate('workspace.travel.noVBACopy')}\n \n ReimbursementAccount.navigateToBankAccountRoute(props.policyID)}\n icon={Expensicons.Bank}\n style={[styles.mt4]}\n iconStyles={[styles.buttonCTAIcon]}\n shouldShowRightIcon\n large\n success\n />\n \n \n);\n\nWorkspaceTravelNoVBAView.propTypes = propTypes;\nWorkspaceTravelNoVBAView.displayName = 'WorkspaceTravelNoVBAView';\n\nexport default withLocalize(WorkspaceTravelNoVBAView);\n","import React from 'react';\nimport {View} from 'react-native';\nimport Text from '../../../components/Text';\nimport styles from '../../../styles/styles';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport * as Expensicons from '../../../components/Icon/Expensicons';\nimport * as Illustrations from '../../../components/Icon/Illustrations';\nimport Section from '../../../components/Section';\nimport * as Link from '../../../libs/actions/Link';\nimport * as Report from '../../../libs/actions/Report';\nimport CONST from '../../../CONST';\n\nconst propTypes = {\n ...withLocalizePropTypes,\n};\n\nconst WorkspaceTravelVBAView = props => (\n Link.openOldDotLink('domain_companycards'),\n icon: Expensicons.ExpensifyCard,\n shouldShowRightIcon: true,\n iconRight: Expensicons.NewWindow,\n wrapperStyle: [styles.cardMenuItem],\n link: () => Link.buildOldDotURL('domain_companycards'),\n },\n {\n title: props.translate('workspace.travel.bookTravelWithConcierge'),\n onPress: () => {\n Report.navigateToConciergeChat();\n },\n icon: Expensicons.Concierge,\n shouldShowRightIcon: true,\n wrapperStyle: [styles.cardMenuItem],\n },\n {\n title: props.translate('requestorStep.learnMore'),\n onPress: () => Link.openExternalLink(CONST.CONCIERGE_TRAVEL_URL),\n icon: Expensicons.Info,\n shouldShowRightIcon: true,\n iconRight: Expensicons.NewWindow,\n wrapperStyle: [styles.cardMenuItem],\n link: CONST.CONCIERGE_TRAVEL_URL,\n },\n ]}\n >\n \n {props.translate('workspace.travel.VBACopy')}\n \n \n);\n\nWorkspaceTravelVBAView.propTypes = propTypes;\nWorkspaceTravelVBAView.displayName = 'WorkspaceTravelVBAView';\n\nexport default withLocalize(WorkspaceTravelVBAView);\n","import React from 'react';\nimport _ from 'underscore';\nimport lodashGet from 'lodash/get';\nimport {\n View, TouchableOpacity,\n} from 'react-native';\nimport PropTypes from 'prop-types';\nimport {withOnyx} from 'react-native-onyx';\nimport Str from 'expensify-common/lib/str';\nimport styles from '../../styles/styles';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport HeaderWithCloseButton from '../../components/HeaderWithCloseButton';\nimport Navigation from '../../libs/Navigation/Navigation';\nimport ScreenWrapper from '../../components/ScreenWrapper';\nimport withLocalize, {withLocalizePropTypes} from '../../components/withLocalize';\nimport compose from '../../libs/compose';\nimport * as Policy from '../../libs/actions/Policy';\nimport Button from '../../components/Button';\nimport Checkbox from '../../components/Checkbox';\nimport Text from '../../components/Text';\nimport ROUTES from '../../ROUTES';\nimport ConfirmModal from '../../components/ConfirmModal';\nimport personalDetailsPropType from '../personalDetailsPropType';\nimport withWindowDimensions, {windowDimensionsPropTypes} from '../../components/withWindowDimensions';\nimport OptionRow from '../../components/OptionRow';\nimport withPolicy, {policyPropTypes, policyDefaultProps} from './withPolicy';\nimport CONST from '../../CONST';\nimport OfflineWithFeedback from '../../components/OfflineWithFeedback';\nimport {withNetwork} from '../../components/OnyxProvider';\nimport FullPageNotFoundView from '../../components/BlockingViews/FullPageNotFoundView';\nimport networkPropTypes from '../../components/networkPropTypes';\nimport * as ReportUtils from '../../libs/ReportUtils';\nimport FormHelpMessage from '../../components/FormHelpMessage';\nimport TextInput from '../../components/TextInput';\nimport KeyboardDismissingFlatList from '../../components/KeyboardDismissingFlatList';\nimport withCurrentUserPersonalDetails from '../../components/withCurrentUserPersonalDetails';\nimport * as PolicyUtils from '../../libs/PolicyUtils';\n\nconst propTypes = {\n /** The personal details of the person who is logged in */\n personalDetails: personalDetailsPropType,\n\n /** URL Route params */\n route: PropTypes.shape({\n /** Params from the URL path */\n params: PropTypes.shape({\n /** policyID passed via route: /workspace/:policyID/members */\n policyID: PropTypes.string,\n }),\n }).isRequired,\n\n /** Session info for the currently logged in user. */\n session: PropTypes.shape({\n /** Currently logged in user email */\n email: PropTypes.string,\n }),\n\n ...policyPropTypes,\n ...withLocalizePropTypes,\n ...windowDimensionsPropTypes,\n network: networkPropTypes.isRequired,\n};\n\nconst defaultProps = {\n personalDetails: {},\n session: {\n email: null,\n },\n ...policyDefaultProps,\n};\n\nclass WorkspaceMembersPage extends React.Component {\n constructor(props) {\n super(props);\n\n this.state = {\n selectedEmployees: [],\n isRemoveMembersConfirmModalVisible: false,\n errors: {},\n searchValue: '',\n };\n\n this.renderItem = this.renderItem.bind(this);\n this.updateSearchValue = this.updateSearchValue.bind(this);\n this.inviteUser = this.inviteUser.bind(this);\n this.addUser = this.addUser.bind(this);\n this.removeUser = this.removeUser.bind(this);\n this.askForConfirmationToRemove = this.askForConfirmationToRemove.bind(this);\n this.hideConfirmModal = this.hideConfirmModal.bind(this);\n }\n\n componentDidMount() {\n this.getWorkspaceMembers();\n }\n\n componentDidUpdate(prevProps) {\n if (prevProps.preferredLocale !== this.props.preferredLocale) {\n this.validate();\n }\n\n const isReconnecting = prevProps.network.isOffline && !this.props.network.isOffline;\n if (!isReconnecting) {\n return;\n }\n\n this.getWorkspaceMembers();\n }\n\n /**\n * Get members for the current workspace\n */\n getWorkspaceMembers() {\n /**\n * We filter clientMemberEmails to only pass members without errors\n * Otherwise, the members with errors would immediately be removed before the user has a chance to read the error\n */\n const clientMemberEmails = _.keys(_.pick(this.props.policyMemberList, member => _.isEmpty(member.errors)));\n Policy.openWorkspaceMembersPage(this.props.route.params.policyID, clientMemberEmails);\n }\n\n /**\n * @param {String} searchValue\n */\n updateSearchValue(searchValue = '') {\n this.setState({searchValue});\n }\n\n /**\n * Open the modal to invite a user\n */\n inviteUser() {\n this.updateSearchValue('');\n Navigation.navigate(ROUTES.getWorkspaceInviteRoute(this.props.route.params.policyID));\n }\n\n /**\n * Remove selected users from the workspace\n */\n removeUsers() {\n if (!_.isEmpty(this.state.errors)) {\n return;\n }\n\n // Remove the admin from the list\n const membersToRemove = _.without(this.state.selectedEmployees, this.props.session.email);\n Policy.removeMembers(membersToRemove, this.props.route.params.policyID);\n this.setState({\n selectedEmployees: [],\n isRemoveMembersConfirmModalVisible: false,\n });\n }\n\n /**\n * Show the modal to confirm removal of the selected members\n */\n askForConfirmationToRemove() {\n if (!_.isEmpty(this.state.errors)) {\n return;\n }\n\n this.setState({isRemoveMembersConfirmModalVisible: true});\n }\n\n /**\n * Hide the confirmation modal\n */\n hideConfirmModal() {\n this.setState({isRemoveMembersConfirmModalVisible: false});\n }\n\n /**\n * Add or remove all users passed from the selectedEmployees list\n * @param {Object} memberList\n */\n toggleAllUsers(memberList) {\n const emailList = _.keys(memberList);\n this.setState(prevState => ({\n selectedEmployees: !_.every(emailList, memberEmail => _.contains(prevState.selectedEmployees, memberEmail))\n ? emailList\n : [],\n }), () => this.validate());\n }\n\n /**\n * Toggle user from the selectedEmployees list\n *\n * @param {String} login\n * @param {String} pendingAction\n *\n */\n toggleUser(login, pendingAction) {\n if (pendingAction === CONST.RED_BRICK_ROAD_PENDING_ACTION.DELETE) {\n return;\n }\n\n // Add or remove the user if the checkbox is enabled\n if (_.contains(this.state.selectedEmployees, login)) {\n this.removeUser(login);\n } else {\n this.addUser(login);\n }\n }\n\n /**\n * Add user from the selectedEmployees list\n *\n * @param {String} login\n */\n addUser(login) {\n this.setState(prevState => ({\n selectedEmployees: [...prevState.selectedEmployees, login],\n }), () => this.validate());\n }\n\n /**\n * Remove user from the selectedEmployees list\n *\n * @param {String} login\n */\n removeUser(login) {\n this.setState(prevState => ({\n selectedEmployees: _.without(prevState.selectedEmployees, login),\n }), () => this.validate());\n }\n\n /**\n * Dismisses the errors on one item\n *\n * @param {Object} item\n */\n dismissError(item) {\n if (item.pendingAction === 'delete') {\n Policy.clearDeleteMemberError(this.props.route.params.policyID, item.login);\n } else {\n Policy.clearAddMemberError(this.props.route.params.policyID, item.login);\n }\n }\n\n validate() {\n const errors = {};\n _.each(this.state.selectedEmployees, (member) => {\n if (member !== this.props.policy.owner && member !== this.props.session.email) {\n return;\n }\n\n errors[member] = this.props.translate('workspace.people.error.cannotRemove');\n });\n\n this.setState({errors});\n }\n\n /**\n * @param {String} [value = '']\n * @param {String} keyword\n * @returns {Boolean}\n */\n isKeywordMatch(value = '', keyword) {\n return value.trim().toLowerCase().includes(keyword);\n }\n\n /**\n * Do not move this or make it an anonymous function it is a method\n * so it will not be recreated each time we render an item\n *\n * See: https://reactnative.dev/docs/optimizing-flatlist-configuration#avoid-anonymous-function-on-renderitem\n *\n * @param {Object} args\n * @param {Object} args.item\n * @param {Number} args.index\n *\n * @returns {React.Component}\n */\n renderItem({\n item,\n }) {\n return (\n this.dismissError(item)} pendingAction={item.pendingAction} errors={item.errors}>\n this.toggleUser(item.login, item.pendingAction)}\n activeOpacity={0.7}\n >\n this.toggleUser(item.login, item.pendingAction)}\n />\n \n this.toggleUser(item.login, item.pendingAction)}\n boldStyle\n option={{\n text: Str.removeSMSDomain(item.displayName),\n alternateText: Str.removeSMSDomain(item.login),\n participantsList: [item],\n icons: [{\n source: ReportUtils.getAvatar(item.avatar, item.login),\n name: item.login,\n type: CONST.ICON_TYPE_AVATAR,\n }],\n keyForList: item.login,\n }}\n />\n \n {(this.props.session.email === item.login || item.role === 'admin') && (\n \n \n {this.props.translate('common.admin')}\n \n \n )}\n \n {!_.isEmpty(this.state.errors[item.login]) && (\n \n )}\n \n );\n }\n\n render() {\n const policyMemberList = lodashGet(this.props, 'policyMemberList', {});\n const removableMembers = {};\n let data = [];\n _.each(policyMemberList, (policyMember, email) => {\n const details = lodashGet(this.props.personalDetails, email, {displayName: email, login: email});\n data.push({\n ...policyMember,\n ...details,\n });\n });\n data = _.sortBy(data, value => value.displayName.toLowerCase());\n const searchValue = this.state.searchValue.trim().toLowerCase();\n data = _.filter(data, member => this.isKeywordMatch(member.displayName, searchValue)\n || this.isKeywordMatch(member.login, searchValue)\n || this.isKeywordMatch(member.phoneNumber, searchValue)\n || this.isKeywordMatch(member.firstName, searchValue)\n || this.isKeywordMatch(member.lastName, searchValue));\n\n data = _.reject(data, (member) => {\n // If this policy is owned by Expensify then show all support (expensify.com or team.expensify.com) emails\n if (PolicyUtils.isExpensifyTeam(lodashGet(this.props.policy, 'owner'))) {\n return;\n }\n\n // We don't want to show guides as policy members unless the user is not a guide. Some customers get confused when they\n // see random people added to their policy, but guides having access to the policies help set them up.\n const isCurrentUserExpensifyTeam = PolicyUtils.isExpensifyTeam(this.props.currentUserPersonalDetails.login);\n return !isCurrentUserExpensifyTeam && PolicyUtils.isExpensifyTeam(member.login);\n });\n\n _.each(data, (member) => {\n if (member.login === this.props.session.email || member.login === this.props.policy.owner || member.pendingAction === CONST.RED_BRICK_ROAD_PENDING_ACTION.DELETE) {\n return;\n }\n removableMembers[member.login] = member;\n });\n const policyID = lodashGet(this.props.route, 'params.policyID');\n const policyName = lodashGet(this.props.policy, 'name');\n\n return (\n \n {({safeAreaPaddingBottomStyle}) => (\n Navigation.navigate(ROUTES.SETTINGS_WORKSPACES)}\n >\n Navigation.dismissModal()}\n onBackButtonPress={() => {\n this.updateSearchValue('');\n Navigation.navigate(ROUTES.getWorkspaceInitialRoute(policyID));\n }}\n shouldShowGetAssistanceButton\n guidesCallTaskID={CONST.GUIDES_CALL_TASK_IDS.WORKSPACE_MEMBERS}\n shouldShowBackButton\n />\n this.removeUsers()}\n onCancel={this.hideConfirmModal}\n prompt={this.props.translate('workspace.people.removeMembersPrompt')}\n confirmText={this.props.translate('common.remove')}\n cancelText={this.props.translate('common.cancel')}\n />\n \n \n \n \n \n \n \n \n {data.length > 0 ? (\n \n \n _.contains(this.state.selectedEmployees, memberEmail))}\n onPress={() => this.toggleAllUsers(removableMembers)}\n />\n \n \n {this.props.translate('workspace.people.selectAll')}\n \n \n \n item.login}\n showsVerticalScrollIndicator\n style={[styles.ph5, styles.pb5]}\n contentContainerStyle={safeAreaPaddingBottomStyle}\n keyboardShouldPersistTaps=\"handled\"\n />\n \n ) : (\n \n \n {this.props.translate('common.noResultsFound')}\n \n \n )}\n \n \n )}\n \n );\n }\n}\n\nWorkspaceMembersPage.propTypes = propTypes;\nWorkspaceMembersPage.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withWindowDimensions,\n withPolicy,\n withNetwork(),\n withOnyx({\n personalDetails: {\n key: ONYXKEYS.PERSONAL_DETAILS,\n },\n session: {\n key: ONYXKEYS.SESSION,\n },\n }),\n withCurrentUserPersonalDetails,\n)(WorkspaceMembersPage);\n","import React from 'react';\nimport {FlatList, Keyboard} from 'react-native';\n\nconst KeyboardDismissingFlatList = props => (\n Keyboard.dismiss()}\n />\n);\n\nKeyboardDismissingFlatList.displayName = 'KeyboardDismissingFlatList';\n\nexport default KeyboardDismissingFlatList;\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport {Pressable, View} from 'react-native';\nimport {withOnyx} from 'react-native-onyx';\nimport _ from 'underscore';\nimport lodashGet from 'lodash/get';\nimport withLocalize, {withLocalizePropTypes} from '../../components/withLocalize';\nimport ScreenWrapper from '../../components/ScreenWrapper';\nimport HeaderWithCloseButton from '../../components/HeaderWithCloseButton';\nimport Navigation from '../../libs/Navigation/Navigation';\nimport styles from '../../styles/styles';\nimport compose from '../../libs/compose';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport * as Policy from '../../libs/actions/Policy';\nimport TextInput from '../../components/TextInput';\nimport FormAlertWithSubmitButton from '../../components/FormAlertWithSubmitButton';\nimport FormSubmit from '../../components/FormSubmit';\nimport OptionsSelector from '../../components/OptionsSelector';\nimport * as OptionsListUtils from '../../libs/OptionsListUtils';\nimport CONST from '../../CONST';\nimport FullScreenLoadingIndicator from '../../components/FullscreenLoadingIndicator';\nimport * as Link from '../../libs/actions/Link';\nimport Text from '../../components/Text';\nimport withPolicy, {policyPropTypes, policyDefaultProps} from './withPolicy';\nimport {withNetwork} from '../../components/OnyxProvider';\nimport FullPageNotFoundView from '../../components/BlockingViews/FullPageNotFoundView';\nimport networkPropTypes from '../../components/networkPropTypes';\nimport ROUTES from '../../ROUTES';\nimport * as Localize from '../../libs/Localize';\n\nconst personalDetailsPropTypes = PropTypes.shape({\n /** The login of the person (either email or phone number) */\n login: PropTypes.string.isRequired,\n\n /** The URL of the person's avatar (there should already be a default avatar if\n the person doesn't have their own avatar uploaded yet) */\n avatar: PropTypes.string.isRequired,\n\n /** This is either the user's full name, or their login if full name is an empty string */\n displayName: PropTypes.string.isRequired,\n});\n\nconst propTypes = {\n /** Beta features list */\n betas: PropTypes.arrayOf(PropTypes.string),\n\n /** All of the personal details for everyone */\n personalDetails: PropTypes.objectOf(personalDetailsPropTypes),\n\n /** URL Route params */\n route: PropTypes.shape({\n /** Params from the URL path */\n params: PropTypes.shape({\n /** policyID passed via route: /workspace/:policyID/invite */\n policyID: PropTypes.string,\n }),\n }).isRequired,\n\n ...policyPropTypes,\n ...withLocalizePropTypes,\n network: networkPropTypes.isRequired,\n};\n\nconst defaultProps = {\n personalDetails: {},\n betas: [],\n ...policyDefaultProps,\n};\n\nclass WorkspaceInvitePage extends React.Component {\n constructor(props) {\n super(props);\n\n this.inviteUser = this.inviteUser.bind(this);\n this.clearErrors = this.clearErrors.bind(this);\n this.getExcludedUsers = this.getExcludedUsers.bind(this);\n this.toggleOption = this.toggleOption.bind(this);\n this.updateOptionsWithSearchTerm = this.updateOptionsWithSearchTerm.bind(this);\n this.openPrivacyURL = this.openPrivacyURL.bind(this);\n\n const {\n personalDetails,\n userToInvite,\n } = OptionsListUtils.getMemberInviteOptions(\n props.personalDetails,\n props.betas,\n '',\n this.getExcludedUsers(),\n );\n this.state = {\n searchTerm: '',\n personalDetails,\n selectedOptions: [],\n userToInvite,\n welcomeNote: this.getWelcomeNote(),\n shouldDisableButton: false,\n };\n }\n\n componentDidMount() {\n this.clearErrors();\n\n const clientPolicyMembers = _.keys(this.props.policyMemberList);\n Policy.openWorkspaceInvitePage(this.props.route.params.policyID, clientPolicyMembers);\n }\n\n componentDidUpdate(prevProps) {\n if (\n prevProps.preferredLocale !== this.props.preferredLocale\n && this.state.welcomeNote === Localize.translate(prevProps.preferredLocale, 'workspace.invite.welcomeNote', {workspaceName: this.props.policy.name})\n ) {\n this.setState({welcomeNote: this.getWelcomeNote()});\n }\n\n const isReconnecting = prevProps.network.isOffline && !this.props.network.isOffline;\n if (!isReconnecting) {\n return;\n }\n\n const clientPolicyMembers = _.keys(this.props.policyMemberList);\n Policy.openWorkspaceInvitePage(this.props.route.params.policyID, clientPolicyMembers);\n }\n\n getExcludedUsers() {\n const policyMemberList = lodashGet(this.props, 'policyMemberList', {});\n const usersToExclude = _.filter(_.keys(policyMemberList), policyMember => (\n this.props.network.isOffline\n || policyMemberList[policyMember].pendingAction !== CONST.RED_BRICK_ROAD_PENDING_ACTION.DELETE\n || !_.isEmpty(policyMemberList[policyMember].errors)\n ));\n return [...CONST.EXPENSIFY_EMAILS, ...usersToExclude];\n }\n\n /**\n * Gets the welcome note default text\n *\n * @returns {Object}\n */\n getWelcomeNote() {\n return this.props.translate('workspace.invite.welcomeNote', {\n workspaceName: this.props.policy.name,\n });\n }\n\n /**\n * @returns {Boolean}\n */\n getShouldShowAlertPrompt() {\n return _.size(lodashGet(this.props.policy, 'errors', {})) > 0 || lodashGet(this.props.policy, 'alertMessage', '').length > 0;\n }\n\n /**\n * Returns the sections needed for the OptionsSelector\n * @returns {Array}\n */\n getSections() {\n const sections = [];\n let indexOffset = 0;\n\n sections.push({\n title: undefined,\n data: this.state.selectedOptions,\n shouldShow: true,\n indexOffset,\n });\n indexOffset += this.state.selectedOptions.length;\n\n // Filtering out selected users from the search results\n const filterText = _.reduce(this.state.selectedOptions, (str, {login}) => `${str} ${login}`, '');\n const personalDetailsWithoutSelected = _.filter(this.state.personalDetails, ({login}) => !filterText.includes(login));\n const hasUnselectedUserToInvite = this.state.userToInvite && !filterText.includes(this.state.userToInvite.login);\n\n sections.push({\n title: this.props.translate('common.contacts'),\n data: personalDetailsWithoutSelected,\n shouldShow: !_.isEmpty(personalDetailsWithoutSelected),\n indexOffset,\n });\n indexOffset += personalDetailsWithoutSelected.length;\n\n if (hasUnselectedUserToInvite) {\n sections.push(({\n title: undefined,\n data: [this.state.userToInvite],\n shouldShow: true,\n indexOffset,\n }));\n }\n\n return sections;\n }\n\n updateOptionsWithSearchTerm(searchTerm = '') {\n const {\n personalDetails,\n userToInvite,\n } = OptionsListUtils.getMemberInviteOptions(\n this.props.personalDetails,\n this.props.betas,\n searchTerm,\n this.getExcludedUsers(),\n );\n this.setState({\n searchTerm,\n userToInvite,\n personalDetails,\n });\n }\n\n openPrivacyURL(e) {\n e.preventDefault();\n Link.openExternalLink(CONST.PRIVACY_URL);\n }\n\n clearErrors(closeModal = false) {\n Policy.setWorkspaceErrors(this.props.route.params.policyID, {});\n Policy.hideWorkspaceAlertMessage(this.props.route.params.policyID);\n if (closeModal) {\n Navigation.dismissModal();\n }\n }\n\n /**\n * Removes a selected option from list if already selected. If not already selected add this option to the list.\n * @param {Object} option\n */\n toggleOption(option) {\n this.clearErrors();\n\n this.setState((prevState) => {\n const isOptionInList = _.some(prevState.selectedOptions, selectedOption => (\n selectedOption.login === option.login\n ));\n\n let newSelectedOptions;\n\n if (isOptionInList) {\n newSelectedOptions = _.reject(prevState.selectedOptions, selectedOption => (\n selectedOption.login === option.login\n ));\n } else {\n newSelectedOptions = [...prevState.selectedOptions, option];\n }\n\n const {\n personalDetails,\n userToInvite,\n } = OptionsListUtils.getMemberInviteOptions(\n this.props.personalDetails,\n this.props.betas,\n prevState.searchTerm,\n this.getExcludedUsers(),\n );\n\n return {\n selectedOptions: newSelectedOptions,\n personalDetails,\n userToInvite,\n searchTerm: prevState.searchTerm,\n };\n });\n }\n\n /**\n * Handle the invite button click\n */\n inviteUser() {\n if (!this.validate()) {\n return;\n }\n\n this.setState({shouldDisableButton: true}, () => {\n const logins = _.map(this.state.selectedOptions, option => option.login);\n const filteredLogins = _.uniq(_.compact(_.map(logins, login => login.toLowerCase().trim())));\n Policy.addMembersToWorkspace(filteredLogins, this.state.welcomeNote, this.props.route.params.policyID);\n Navigation.goBack();\n });\n }\n\n /**\n * @returns {Boolean}\n */\n validate() {\n const errors = {};\n if (this.state.selectedOptions.length <= 0) {\n errors.noUserSelected = true;\n }\n\n Policy.setWorkspaceErrors(this.props.route.params.policyID, errors);\n return _.size(errors) <= 0;\n }\n\n render() {\n const sections = this.getSections();\n const headerMessage = OptionsListUtils.getHeaderMessage(\n this.state.personalDetails.length !== 0,\n Boolean(this.state.userToInvite),\n this.state.searchTerm,\n );\n const policyName = lodashGet(this.props.policy, 'name');\n\n return (\n \n {({didScreenTransitionEnd}) => (\n Navigation.navigate(ROUTES.SETTINGS_WORKSPACES)}\n >\n \n this.clearErrors(true)}\n shouldShowGetAssistanceButton\n guidesCallTaskID={CONST.GUIDES_CALL_TASK_IDS.WORKSPACE_MEMBERS}\n shouldShowBackButton\n onBackButtonPress={() => Navigation.goBack()}\n />\n \n {didScreenTransitionEnd ? (\n \n ) : (\n \n )}\n \n \n \n this.setState({welcomeNote: text})}\n />\n \n \n \n \n \n {this.props.translate('common.privacy')}\n \n \n \n \n \n \n )}\n \n );\n }\n}\n\nWorkspaceInvitePage.propTypes = propTypes;\nWorkspaceInvitePage.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withPolicy,\n withNetwork(),\n withOnyx({\n personalDetails: {\n key: ONYXKEYS.PERSONAL_DETAILS,\n },\n betas: {\n key: ONYXKEYS.BETAS,\n },\n }),\n)(WorkspaceInvitePage);\n","import React from 'react';\nimport {View} from 'react-native';\nimport _ from 'underscore';\nimport {withOnyx} from 'react-native-onyx';\nimport PropTypes from 'prop-types';\nimport * as Report from '../../libs/actions/Report';\nimport withLocalize, {withLocalizePropTypes} from '../../components/withLocalize';\nimport compose from '../../libs/compose';\nimport HeaderWithCloseButton from '../../components/HeaderWithCloseButton';\nimport Navigation from '../../libs/Navigation/Navigation';\nimport ScreenWrapper from '../../components/ScreenWrapper';\nimport styles from '../../styles/styles';\nimport RoomNameInput from '../../components/RoomNameInput';\nimport Picker from '../../components/Picker';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport CONST from '../../CONST';\nimport Text from '../../components/Text';\nimport Permissions from '../../libs/Permissions';\nimport Log from '../../libs/Log';\nimport * as ErrorUtils from '../../libs/ErrorUtils';\nimport * as ValidationUtils from '../../libs/ValidationUtils';\nimport Form from '../../components/Form';\nimport shouldDelayFocus from '../../libs/shouldDelayFocus';\n\nconst propTypes = {\n /** All reports shared with the user */\n reports: PropTypes.shape({\n /** The report name */\n reportName: PropTypes.string,\n\n /** The report type */\n type: PropTypes.string,\n\n /** ID of the policy */\n policyID: PropTypes.string,\n }),\n\n /** List of betas available to current user */\n betas: PropTypes.arrayOf(PropTypes.string),\n\n /** The list of policies the user has access to. */\n policies: PropTypes.objectOf(PropTypes.shape({\n /** The policy type */\n type: PropTypes.oneOf(_.values(CONST.POLICY.TYPE)),\n\n /** The name of the policy */\n name: PropTypes.string,\n\n /** The ID of the policy */\n id: PropTypes.string,\n })),\n\n ...withLocalizePropTypes,\n};\nconst defaultProps = {\n betas: [],\n reports: {},\n policies: {},\n};\n\nclass WorkspaceNewRoomPage extends React.Component {\n constructor(props) {\n super(props);\n\n this.state = {\n visibilityDescription: this.props.translate('newRoomPage.restrictedDescription'),\n };\n\n this.validate = this.validate.bind(this);\n this.submit = this.submit.bind(this);\n this.updateVisibilityDescription = this.updateVisibilityDescription.bind(this);\n }\n\n /**\n * @param {Object} values - form input values passed by the Form component\n */\n submit(values) {\n const policyID = this.props.policies[`${ONYXKEYS.COLLECTION.POLICY}${values.policyID}`];\n Report.addPolicyReport(policyID, values.roomName, values.visibility);\n }\n\n /**\n * @param {String} visibility - form input value passed by the Form component\n */\n updateVisibilityDescription(visibility) {\n const visibilityDescription = this.props.translate(`newRoomPage.${visibility}Description`);\n if (visibilityDescription === this.state.visibilityDescription) {\n return;\n }\n this.setState({visibilityDescription});\n }\n\n /**\n * @param {Object} values - form input values passed by the Form component\n * @returns {Boolean}\n */\n validate(values) {\n const errors = {};\n\n if (!values.roomName || values.roomName === CONST.POLICY.ROOM_PREFIX) {\n // We error if the user doesn't enter a room name or left blank\n ErrorUtils.addErrorMessage(errors, 'roomName', this.props.translate('newRoomPage.pleaseEnterRoomName'));\n } else if (values.roomName !== CONST.POLICY.ROOM_PREFIX && !ValidationUtils.isValidRoomName(values.roomName)) {\n // We error if the room name has invalid characters\n ErrorUtils.addErrorMessage(errors, 'roomName', this.props.translate('newRoomPage.roomNameInvalidError'));\n } else if (ValidationUtils.isReservedRoomName(values.roomName)) {\n // Certain names are reserved for default rooms and should not be used for policy rooms.\n ErrorUtils.addErrorMessage(errors, 'roomName', this.props.translate('newRoomPage.roomNameReservedError', {reservedName: values.roomName}));\n } else if (ValidationUtils.isExistingRoomName(values.roomName, this.props.reports, values.policyID)) {\n // Certain names are reserved for default rooms and should not be used for policy rooms.\n ErrorUtils.addErrorMessage(errors, 'roomName', this.props.translate('newRoomPage.roomAlreadyExistsError'));\n }\n\n if (!values.policyID) {\n errors.policyID = this.props.translate('newRoomPage.pleaseSelectWorkspace');\n }\n\n return errors;\n }\n\n render() {\n if (!Permissions.canUsePolicyRooms(this.props.betas)) {\n Log.info('Not showing create Policy Room page since user is not on policy rooms beta');\n Navigation.dismissModal();\n return null;\n }\n\n // Workspaces are policies with type === 'free'\n const workspaceOptions = _.map(\n _.filter(this.props.policies, policy => policy && policy.type === CONST.POLICY.TYPE.FREE),\n policy => ({label: policy.name, key: policy.id, value: policy.id}),\n );\n\n const visibilityOptions = _.map(_.filter(_.values(CONST.REPORT.VISIBILITY), visibilityOption => visibilityOption !== CONST.REPORT.VISIBILITY.PUBLIC_ANNOUNCE), visibilityOption => ({\n label: this.props.translate(`newRoomPage.visibilityOptions.${visibilityOption}`),\n value: visibilityOption,\n description: this.props.translate(`newRoomPage.${visibilityOption}Description`),\n }));\n\n return (\n \n Navigation.dismissModal()}\n />\n \n \n \n \n \n \n \n \n \n \n \n {this.state.visibilityDescription}\n \n \n \n );\n }\n}\n\nWorkspaceNewRoomPage.propTypes = propTypes;\nWorkspaceNewRoomPage.defaultProps = defaultProps;\n\nexport default compose(\n withOnyx({\n betas: {\n key: ONYXKEYS.BETAS,\n },\n policies: {\n key: ONYXKEYS.COLLECTION.POLICY,\n },\n reports: {\n key: ONYXKEYS.COLLECTION.REPORT,\n },\n }),\n withLocalize,\n)(WorkspaceNewRoomPage);\n","import _ from 'underscore';\nimport lodashGet from 'lodash/get';\nimport React from 'react';\nimport {withOnyx} from 'react-native-onyx';\nimport Str from 'expensify-common/lib/str';\nimport {View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport ScreenWrapper from '../../components/ScreenWrapper';\nimport * as BankAccounts from '../../libs/actions/BankAccounts';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport ReimbursementAccountLoadingIndicator from '../../components/ReimbursementAccountLoadingIndicator';\nimport Navigation from '../../libs/Navigation/Navigation';\nimport CONST from '../../CONST';\nimport BankAccount from '../../libs/models/BankAccount';\nimport withLocalize, {withLocalizePropTypes} from '../../components/withLocalize';\nimport compose from '../../libs/compose';\nimport styles from '../../styles/styles';\nimport getPlaidOAuthReceivedRedirectURI from '../../libs/getPlaidOAuthReceivedRedirectURI';\nimport Text from '../../components/Text';\nimport {withNetwork} from '../../components/OnyxProvider';\nimport networkPropTypes from '../../components/networkPropTypes';\nimport BankAccountStep from './BankAccountStep';\nimport CompanyStep from './CompanyStep';\nimport ContinueBankAccountSetup from './ContinueBankAccountSetup';\nimport RequestorStep from './RequestorStep';\nimport ValidationStep from './ValidationStep';\nimport ACHContractStep from './ACHContractStep';\nimport EnableStep from './EnableStep';\nimport ROUTES from '../../ROUTES';\nimport HeaderWithCloseButton from '../../components/HeaderWithCloseButton';\nimport * as ReimbursementAccountProps from './reimbursementAccountPropTypes';\nimport reimbursementAccountDraftPropTypes from './ReimbursementAccountDraftPropTypes';\nimport withPolicy from '../workspace/withPolicy';\n\nconst propTypes = {\n /** Plaid SDK token to use to initialize the widget */\n plaidLinkToken: PropTypes.string,\n\n /** ACH data for the withdrawal account actively being set up */\n reimbursementAccount: ReimbursementAccountProps.reimbursementAccountPropTypes,\n\n /** The draft values of the bank account being setup */\n reimbursementAccountDraft: reimbursementAccountDraftPropTypes,\n\n /** The token required to initialize the Onfido SDK */\n onfidoToken: PropTypes.string,\n\n /** Information about the network */\n network: networkPropTypes.isRequired,\n\n /** Current session for the user */\n session: PropTypes.shape({\n /** User login */\n email: PropTypes.string,\n }),\n\n /** Route object from navigation */\n route: PropTypes.shape({\n /** Params that are passed into the route */\n params: PropTypes.shape({\n /** A step to navigate to if we need to drop the user into a specific point in the flow */\n stepToOpen: PropTypes.string,\n policyID: PropTypes.string,\n }),\n }),\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n reimbursementAccount: ReimbursementAccountProps.reimbursementAccountDefaultProps,\n reimbursementAccountDraft: {},\n onfidoToken: '',\n plaidLinkToken: '',\n session: {\n email: null,\n },\n route: {\n params: {\n stepToOpen: '',\n policyID: '',\n },\n },\n};\n\nclass ReimbursementAccountPage extends React.Component {\n constructor(props) {\n super(props);\n this.continue = this.continue.bind(this);\n this.getDefaultStateForField = this.getDefaultStateForField.bind(this);\n this.goBack = this.goBack.bind(this);\n const achData = lodashGet(this.props.reimbursementAccount, 'achData', {});\n const hasInProgressVBBA = achData.bankAccountID && achData.state !== BankAccount.STATE.OPEN && achData.state !== BankAccount.STATE.LOCKED;\n\n this.state = {\n shouldHideContinueSetupButton: !hasInProgressVBBA,\n };\n }\n\n componentDidMount() {\n this.fetchData();\n }\n\n componentDidUpdate(prevProps) {\n if (prevProps.network.isOffline && !this.props.network.isOffline) {\n this.fetchData();\n }\n const currentStep = lodashGet(this.props.reimbursementAccount, 'achData.currentStep') || CONST.BANK_ACCOUNT.STEP.BANK_ACCOUNT;\n const previousStep = lodashGet(prevProps.reimbursementAccount, 'achData.currentStep') || CONST.BANK_ACCOUNT.STEP.BANK_ACCOUNT;\n if (currentStep === previousStep) {\n return;\n }\n\n // When the step changes we will navigate to update the route params. This is mostly cosmetic as we only use\n // the route params when the component first mounts to jump to a specific route instead of picking up where the\n // user left off in the flow.\n BankAccounts.hideBankAccountErrors();\n Navigation.navigate(ROUTES.getBankAccountRoute(\n this.getRouteForCurrentStep(currentStep), lodashGet(this.props.route.params, 'policyID'),\n ));\n }\n\n /**\n * @param {String} fieldName\n * @param {*} defaultValue\n *\n * @returns {*}\n */\n getDefaultStateForField(fieldName, defaultValue = '') {\n return lodashGet(this.props.reimbursementAccount, ['achData', fieldName], defaultValue);\n }\n\n /**\n * We can pass stepToOpen in the URL to force which step to show.\n * Mainly needed when user finished the flow in verifying state, and Ops ask them to modify some fields from a specific step.\n * @returns {String}\n */\n getStepToOpenFromRouteParams() {\n switch (lodashGet(this.props.route, ['params', 'stepToOpen'])) {\n case 'new':\n return CONST.BANK_ACCOUNT.STEP.BANK_ACCOUNT;\n case 'company':\n return CONST.BANK_ACCOUNT.STEP.COMPANY;\n case 'personal-information':\n return CONST.BANK_ACCOUNT.STEP.REQUESTOR;\n case 'contract':\n return CONST.BANK_ACCOUNT.STEP.ACH_CONTRACT;\n case 'validate':\n return CONST.BANK_ACCOUNT.STEP.VALIDATION;\n case 'enable':\n return CONST.BANK_ACCOUNT.STEP.ENABLE;\n default:\n return '';\n }\n }\n\n /**\n * @param {String} currentStep\n * @returns {String}\n */\n getRouteForCurrentStep(currentStep) {\n switch (currentStep) {\n case CONST.BANK_ACCOUNT.STEP.COMPANY:\n return 'company';\n case CONST.BANK_ACCOUNT.STEP.REQUESTOR:\n return 'personal-information';\n case CONST.BANK_ACCOUNT.STEP.ACH_CONTRACT:\n return 'contract';\n case CONST.BANK_ACCOUNT.STEP.VALIDATION:\n return 'validate';\n case CONST.BANK_ACCOUNT.STEP.ENABLE:\n return 'enable';\n case CONST.BANK_ACCOUNT.STEP.BANK_ACCOUNT:\n default:\n return 'new';\n }\n }\n\n /**\n * Retrieve verified business bank account currently being set up.\n * @param {boolean} ignoreLocalCurrentStep Pass true if you want the last \"updated\" view (from db), not the last \"viewed\" view (from onyx).\n */\n fetchData(ignoreLocalCurrentStep) {\n // Show loader right away, as optimisticData might be set only later in case multiple calls are in the queue\n BankAccounts.setReimbursementAccountLoading(true);\n\n // We can specify a step to navigate to by using route params when the component mounts.\n // We want to use the same stepToOpen variable when the network state changes because we can be redirected to a different step when the account refreshes.\n const stepToOpen = this.getStepToOpenFromRouteParams();\n const achData = lodashGet(this.props.reimbursementAccount, 'achData', {});\n const subStep = achData.subStep || '';\n const localCurrentStep = achData.currentStep || '';\n BankAccounts.openReimbursementAccountPage(stepToOpen, subStep, ignoreLocalCurrentStep ? '' : localCurrentStep);\n }\n\n continue() {\n this.setState({\n shouldHideContinueSetupButton: true,\n });\n this.fetchData(true);\n }\n\n goBack() {\n const achData = lodashGet(this.props.reimbursementAccount, 'achData', {});\n const currentStep = achData.currentStep || CONST.BANK_ACCOUNT.STEP.BANK_ACCOUNT;\n const subStep = achData.subStep;\n const shouldShowOnfido = this.props.onfidoToken && !achData.isOnfidoSetupComplete;\n const hasInProgressVBBA = achData.bankAccountID && achData.state !== BankAccount.STATE.OPEN && achData.state !== BankAccount.STATE.LOCKED;\n switch (currentStep) {\n case CONST.BANK_ACCOUNT.STEP.BANK_ACCOUNT:\n if (hasInProgressVBBA) {\n this.setState({shouldHideContinueSetupButton: false});\n }\n if (subStep) {\n BankAccounts.setBankAccountSubStep(null);\n } else {\n Navigation.goBack();\n }\n break;\n case CONST.BANK_ACCOUNT.STEP.COMPANY:\n BankAccounts.goToWithdrawalAccountSetupStep(CONST.BANK_ACCOUNT.STEP.BANK_ACCOUNT, {subStep: CONST.BANK_ACCOUNT.SUBSTEP.MANUAL});\n break;\n case CONST.BANK_ACCOUNT.STEP.REQUESTOR:\n if (shouldShowOnfido) {\n BankAccounts.clearOnfidoToken();\n } else {\n BankAccounts.goToWithdrawalAccountSetupStep(CONST.BANK_ACCOUNT.STEP.COMPANY);\n }\n break;\n case CONST.BANK_ACCOUNT.STEP.ACH_CONTRACT:\n BankAccounts.clearOnfidoToken();\n BankAccounts.goToWithdrawalAccountSetupStep(CONST.BANK_ACCOUNT.STEP.REQUESTOR);\n break;\n case CONST.BANK_ACCOUNT.STEP.VALIDATION:\n if (_.contains([BankAccount.STATE.VERIFYING, BankAccount.STATE.SETUP], achData.state)) {\n BankAccounts.goToWithdrawalAccountSetupStep(CONST.BANK_ACCOUNT.STEP.ACH_CONTRACT);\n } else if (achData.state === BankAccount.STATE.PENDING) {\n this.setState({\n shouldHideContinueSetupButton: false,\n });\n } else {\n Navigation.goBack();\n }\n break;\n default: Navigation.goBack();\n }\n }\n\n render() {\n // The SetupWithdrawalAccount flow allows us to continue the flow from various points depending on where the\n // user left off. This view will refer to the achData as the single source of truth to determine which route to\n // display. We can also specify a specific route to navigate to via route params when the component first\n // mounts which will set the achData.currentStep after the account data is fetched and overwrite the logical\n // next step.\n const achData = lodashGet(this.props.reimbursementAccount, 'achData', {});\n const currentStep = achData.currentStep || CONST.BANK_ACCOUNT.STEP.BANK_ACCOUNT;\n const policyName = lodashGet(this.props.policy, 'name');\n\n // Don't show the loading indicator if we're offline and restarted the bank account setup process\n if (this.props.reimbursementAccount.isLoading && !(this.props.network.isOffline && currentStep === CONST.BANK_ACCOUNT.STEP.BANK_ACCOUNT)) {\n const isSubmittingVerificationsData = _.contains([\n CONST.BANK_ACCOUNT.STEP.COMPANY,\n CONST.BANK_ACCOUNT.STEP.REQUESTOR,\n CONST.BANK_ACCOUNT.STEP.ACH_CONTRACT,\n ], currentStep);\n return (\n \n );\n }\n\n // Show the \"Continue with setup\" button if a bank account setup is already in progress and no specific further step was passed in the url\n // We'll show the workspace bank account reset modal if the user wishes to start over\n if (!this.state.shouldHideContinueSetupButton\n && Boolean(achData.bankAccountID)\n && achData.state !== BankAccount.STATE.OPEN\n && achData.state !== BankAccount.STATE.LOCKED\n && (\n _.contains([CONST.BANK_ACCOUNT.STEP.BANK_ACCOUNT, ''], this.getStepToOpenFromRouteParams())\n || achData.state === BankAccount.STATE.PENDING\n )) {\n return (\n this.setState({shouldHideContinueSetupButton: true})}\n policyName={policyName}\n />\n );\n }\n\n let errorComponent;\n const userHasPhonePrimaryEmail = Str.endsWith(this.props.session.email, CONST.SMS.DOMAIN);\n\n if (userHasPhonePrimaryEmail) {\n errorComponent = (\n \n {this.props.translate('bankAccount.hasPhoneLoginError')}\n \n );\n }\n\n const throttledDate = lodashGet(this.props.reimbursementAccount, 'throttledDate');\n if (throttledDate) {\n errorComponent = (\n \n \n {this.props.translate('bankAccount.hasBeenThrottledError')}\n \n \n );\n }\n\n if (errorComponent) {\n return (\n \n \n {errorComponent}\n \n );\n }\n\n if (currentStep === CONST.BANK_ACCOUNT.STEP.BANK_ACCOUNT) {\n return (\n \n );\n }\n\n if (currentStep === CONST.BANK_ACCOUNT.STEP.COMPANY) {\n return (\n \n );\n }\n\n if (currentStep === CONST.BANK_ACCOUNT.STEP.REQUESTOR) {\n const shouldShowOnfido = this.props.onfidoToken && !achData.isOnfidoSetupComplete;\n return (\n \n );\n }\n\n if (currentStep === CONST.BANK_ACCOUNT.STEP.ACH_CONTRACT) {\n return (\n \n );\n }\n\n if (currentStep === CONST.BANK_ACCOUNT.STEP.VALIDATION) {\n return (\n \n );\n }\n\n if (currentStep === CONST.BANK_ACCOUNT.STEP.ENABLE) {\n return (\n \n );\n }\n }\n}\n\nReimbursementAccountPage.propTypes = propTypes;\nReimbursementAccountPage.defaultProps = defaultProps;\n\nexport default compose(\n withNetwork(),\n withOnyx({\n reimbursementAccount: {\n key: ONYXKEYS.REIMBURSEMENT_ACCOUNT,\n },\n reimbursementAccountDraft: {\n key: ONYXKEYS.REIMBURSEMENT_ACCOUNT_DRAFT,\n },\n session: {\n key: ONYXKEYS.SESSION,\n },\n plaidLinkToken: {\n key: ONYXKEYS.PLAID_LINK_TOKEN,\n },\n onfidoToken: {\n key: ONYXKEYS.ONFIDO_TOKEN,\n },\n }),\n withLocalize,\n withPolicy,\n)(ReimbursementAccountPage);\n","import React from 'react';\nimport {StyleSheet, View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport Lottie from 'lottie-react-native';\nimport ReviewingBankInfoAnimation from '../../assets/animations/ReviewingBankInfo.json';\nimport styles from '../styles/styles';\nimport withLocalize, {withLocalizePropTypes} from './withLocalize';\nimport Text from './Text';\nimport HeaderWithCloseButton from './HeaderWithCloseButton';\nimport Navigation from '../libs/Navigation/Navigation';\nimport ScreenWrapper from './ScreenWrapper';\nimport FullScreenLoadingIndicator from './FullscreenLoadingIndicator';\nimport FullPageOfflineBlockingView from './BlockingViews/FullPageOfflineBlockingView';\nimport compose from '../libs/compose';\nimport {withNetwork} from './OnyxProvider';\n\nconst propTypes = {\n /** Whether the user is submitting verifications data */\n isSubmittingVerificationsData: PropTypes.bool.isRequired,\n\n /** Method to trigger when pressing back button of the header */\n onBackButtonPress: PropTypes.func.isRequired,\n ...withLocalizePropTypes,\n};\n\nconst ReimbursementAccountLoadingIndicator = props => (\n \n \n \n {props.isSubmittingVerificationsData ? (\n \n \n \n \n {props.translate('reimbursementAccountLoadingAnimation.explanationLine')}\n \n \n \n ) : (\n \n )}\n \n \n);\n\nReimbursementAccountLoadingIndicator.propTypes = propTypes;\nReimbursementAccountLoadingIndicator.displayName = 'ReimbursementAccountLoadingIndicator';\n\nexport default compose(\n withLocalize,\n withNetwork(),\n)(ReimbursementAccountLoadingIndicator);\n\n","import React from 'react';\nimport {\n View, ScrollView, TouchableWithoutFeedback, Linking,\n} from 'react-native';\nimport {withOnyx} from 'react-native-onyx';\nimport PropTypes from 'prop-types';\nimport lodashGet from 'lodash/get';\nimport BankAccountManualStep from './BankAccountManualStep';\nimport BankAccountPlaidStep from './BankAccountPlaidStep';\nimport HeaderWithCloseButton from '../../components/HeaderWithCloseButton';\nimport MenuItem from '../../components/MenuItem';\nimport * as Expensicons from '../../components/Icon/Expensicons';\nimport styles from '../../styles/styles';\nimport TextLink from '../../components/TextLink';\nimport Icon from '../../components/Icon';\nimport colors from '../../styles/colors';\nimport Navigation from '../../libs/Navigation/Navigation';\nimport CONST from '../../CONST';\nimport withLocalize from '../../components/withLocalize';\nimport Text from '../../components/Text';\nimport * as BankAccounts from '../../libs/actions/BankAccounts';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport compose from '../../libs/compose';\nimport Section from '../../components/Section';\nimport * as Illustrations from '../../components/Icon/Illustrations';\nimport getPlaidDesktopMessage from '../../libs/getPlaidDesktopMessage';\nimport CONFIG from '../../CONFIG';\nimport ROUTES from '../../ROUTES';\nimport Button from '../../components/Button';\nimport ScreenWrapper from '../../components/ScreenWrapper';\nimport StepPropTypes from './StepPropTypes';\n\nconst propTypes = {\n ...StepPropTypes,\n\n /** The OAuth URI + stateID needed to re-initialize the PlaidLink after the user logs into their bank */\n receivedRedirectURI: PropTypes.string,\n\n /** During the OAuth flow we need to use the plaidLink token that we initially connected with */\n plaidLinkOAuthToken: PropTypes.string,\n\n /** Object with various information about the user */\n user: PropTypes.shape({\n /** Is the user account validated? */\n validated: PropTypes.bool,\n }),\n\n /** If the plaid button has been disabled */\n isPlaidDisabled: PropTypes.bool,\n\n /* The workspace name */\n policyName: PropTypes.string,\n};\n\nconst defaultProps = {\n receivedRedirectURI: null,\n plaidLinkOAuthToken: '',\n user: {},\n isPlaidDisabled: false,\n policyName: '',\n};\n\nconst BankAccountStep = (props) => {\n let subStep = lodashGet(props.reimbursementAccount, 'achData.subStep', '');\n const shouldReinitializePlaidLink = props.plaidLinkOAuthToken && props.receivedRedirectURI && subStep !== CONST.BANK_ACCOUNT.SUBSTEP.MANUAL;\n if (shouldReinitializePlaidLink) {\n subStep = CONST.BANK_ACCOUNT.SETUP_TYPE.PLAID;\n }\n const plaidDesktopMessage = getPlaidDesktopMessage();\n const bankAccountRoute = `${CONFIG.EXPENSIFY.NEW_EXPENSIFY_URL}${ROUTES.BANK_ACCOUNT}`;\n\n if (subStep === CONST.BANK_ACCOUNT.SETUP_TYPE.MANUAL) {\n return (\n \n );\n }\n\n if (subStep === CONST.BANK_ACCOUNT.SETUP_TYPE.PLAID) {\n return (\n \n );\n }\n\n return (\n \n \n \n \n \n \n {props.translate('bankAccount.toGetStarted')}\n \n {Boolean(plaidDesktopMessage) && (\n \n \n {props.translate(plaidDesktopMessage)}\n \n \n )}\n BankAccounts.openPlaidView()}\n disabled={props.isPlaidDisabled || !props.user.validated}\n style={[styles.mt4]}\n iconStyles={[styles.buttonCTAIcon]}\n shouldShowRightIcon\n success\n large\n />\n {Boolean(props.error) && (\n \n {props.error}\n \n )}\n \n BankAccounts.setBankAccountSubStep(CONST.BANK_ACCOUNT.SETUP_TYPE.MANUAL)}\n shouldShowRightIcon\n wrapperStyle={[styles.cardMenuItem]}\n />\n \n \n {!props.user.validated && (\n \n \n \n {props.translate('bankAccount.validateAccountError')}\n \n \n )}\n \n \n {props.translate('common.privacy')}\n \n Linking.openURL('https://community.expensify.com/discussion/5677/deep-dive-how-expensify-protects-your-information/')}\n >\n \n \n {props.translate('bankAccount.yourDataIsSecure')}\n \n \n \n \n \n \n \n \n \n \n\n );\n};\n\nBankAccountStep.propTypes = propTypes;\nBankAccountStep.defaultProps = defaultProps;\nBankAccountStep.displayName = 'BankAccountStep';\n\nexport default compose(\n withLocalize,\n withOnyx({\n user: {\n key: ONYXKEYS.USER,\n },\n isPlaidDisabled: {\n key: ONYXKEYS.IS_PLAID_DISABLED,\n },\n }),\n)(BankAccountStep);\n","import React from 'react';\nimport {Image} from 'react-native';\nimport lodashGet from 'lodash/get';\nimport HeaderWithCloseButton from '../../components/HeaderWithCloseButton';\nimport CONST from '../../CONST';\nimport * as BankAccounts from '../../libs/actions/BankAccounts';\nimport Navigation from '../../libs/Navigation/Navigation';\nimport Text from '../../components/Text';\nimport TextInput from '../../components/TextInput';\nimport styles from '../../styles/styles';\nimport CheckboxWithLabel from '../../components/CheckboxWithLabel';\nimport TextLink from '../../components/TextLink';\nimport withLocalize from '../../components/withLocalize';\nimport * as ValidationUtils from '../../libs/ValidationUtils';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport exampleCheckImage from './exampleCheckImage';\nimport Form from '../../components/Form';\nimport shouldDelayFocus from '../../libs/shouldDelayFocus';\nimport ScreenWrapper from '../../components/ScreenWrapper';\nimport StepPropTypes from './StepPropTypes';\n\nconst propTypes = {\n ...StepPropTypes,\n};\n\nclass BankAccountManualStep extends React.Component {\n constructor(props) {\n super(props);\n this.submit = this.submit.bind(this);\n this.validate = this.validate.bind(this);\n }\n\n /**\n * @param {Object} values - form input values passed by the Form component\n * @returns {Object}\n */\n validate(values) {\n const errorFields = {};\n const routingNumber = values.routingNumber && values.routingNumber.trim();\n\n if (\n !values.accountNumber\n || (!CONST.BANK_ACCOUNT.REGEX.US_ACCOUNT_NUMBER.test(values.accountNumber.trim()) && !CONST.BANK_ACCOUNT.REGEX.MASKED_US_ACCOUNT_NUMBER.test(values.accountNumber.trim()))\n ) {\n errorFields.accountNumber = this.props.translate('bankAccount.error.accountNumber');\n }\n if (!routingNumber || !CONST.BANK_ACCOUNT.REGEX.SWIFT_BIC.test(routingNumber) || !ValidationUtils.isValidRoutingNumber(routingNumber)) {\n errorFields.routingNumber = this.props.translate('bankAccount.error.routingNumber');\n }\n if (!values.acceptTerms) {\n errorFields.acceptTerms = this.props.translate('common.error.acceptTerms');\n }\n\n return errorFields;\n }\n\n submit(values) {\n BankAccounts.connectBankAccountManually(\n lodashGet(this.props.reimbursementAccount, 'achData.bankAccountID') || 0,\n values.accountNumber,\n values.routingNumber,\n this.props.getDefaultStateForField('plaidMask'),\n );\n }\n\n render() {\n const shouldDisableInputs = Boolean(lodashGet(this.props.reimbursementAccount, 'achData.bankAccountID'));\n\n return (\n \n \n \n \n {this.props.translate('bankAccount.checkHelpLine')}\n \n \n \n \n (\n \n {this.props.translate('common.iAcceptThe')}\n e.preventDefault()}\n >\n {this.props.translate('common.expensifyTermsOfService')}\n \n \n )}\n defaultValue={this.props.getDefaultStateForField('acceptTerms', false)}\n shouldSaveDraft\n />\n \n \n );\n }\n}\n\nBankAccountManualStep.propTypes = propTypes;\nexport default withLocalize(BankAccountManualStep);\n","import exampleCheckImageEn from '../../../assets/images/example-check-image-en.png';\nimport exampleCheckImageEs from '../../../assets/images/example-check-image-es.png';\nimport CONST from '../../CONST';\n\nconst images = {\n [CONST.LOCALES.EN]: exampleCheckImageEn,\n [CONST.LOCALES.ES]: exampleCheckImageEs,\n};\n\nfunction exampleCheckImage(languageKey = CONST.LOCALES.EN) {\n return images[languageKey];\n}\n\nexport default exampleCheckImage;\n","","","import PropTypes from 'prop-types';\nimport * as ReimbursementAccountProps from './reimbursementAccountPropTypes';\nimport reimbursementAccountDraftPropTypes from './ReimbursementAccountDraftPropTypes';\nimport {withLocalizePropTypes} from '../../components/withLocalize';\n\nexport default {\n /** The bank account currently in setup */\n reimbursementAccount: ReimbursementAccountProps.reimbursementAccountPropTypes.isRequired,\n\n /** The draft values of the bank account being setup */\n reimbursementAccountDraft: reimbursementAccountDraftPropTypes.isRequired,\n\n /** Goes to the previous step */\n onBackButtonPress: PropTypes.func.isRequired,\n\n /** Get a field value from Onyx reimbursementAccountDraft or reimbursementAccount */\n getDefaultStateForField: PropTypes.func.isRequired,\n\n ...withLocalizePropTypes,\n};\n","import PropTypes from 'prop-types';\n\nexport default PropTypes.shape({\n bankAccountID: PropTypes.number,\n\n /** Props needed for BankAccountStep */\n accountNumber: PropTypes.string,\n routingNumber: PropTypes.string,\n acceptTerms: PropTypes.bool,\n plaidAccountID: PropTypes.string,\n plaidMask: PropTypes.string,\n\n /** Props needed for CompanyStep */\n companyName: PropTypes.string,\n addressStreet: PropTypes.string,\n addressCity: PropTypes.string,\n addressState: PropTypes.string,\n addressZipCode: PropTypes.string,\n companyPhone: PropTypes.string,\n website: PropTypes.string,\n companyTaxID: PropTypes.string,\n incorporationType: PropTypes.string,\n incorporationDate: PropTypes.oneOfType([PropTypes.string, PropTypes.instanceOf(Date)]),\n incorporationState: PropTypes.string,\n hasNoConnectionToCannabis: PropTypes.bool,\n\n /** Props needed for RequestorStep */\n firstName: PropTypes.string,\n lastName: PropTypes.string,\n requestorAddressStreet: PropTypes.string,\n requestorAddressCity: PropTypes.string,\n requestorAddressState: PropTypes.string,\n requestorAddressZipCode: PropTypes.string,\n dob: PropTypes.oneOfType([PropTypes.string, PropTypes.instanceOf(Date)]),\n ssnLast4: PropTypes.string,\n isControllingOfficer: PropTypes.bool,\n isOnfidoSetupComplete: PropTypes.bool,\n\n /** Props needed for ACHContractStep */\n ownsMoreThan25Percent: PropTypes.bool,\n hasOtherBeneficialOwners: PropTypes.bool,\n acceptTermsAndConditions: PropTypes.bool,\n certifyTrueInformation: PropTypes.bool,\n beneficialOwners: PropTypes.arrayOf(PropTypes.string),\n});\n","import _ from 'underscore';\nimport React from 'react';\nimport {withOnyx} from 'react-native-onyx';\nimport PropTypes from 'prop-types';\nimport lodashGet from 'lodash/get';\nimport HeaderWithCloseButton from '../../components/HeaderWithCloseButton';\nimport CONST from '../../CONST';\nimport * as BankAccounts from '../../libs/actions/BankAccounts';\nimport Navigation from '../../libs/Navigation/Navigation';\nimport withLocalize from '../../components/withLocalize';\nimport compose from '../../libs/compose';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport AddPlaidBankAccount from '../../components/AddPlaidBankAccount';\nimport * as ReimbursementAccount from '../../libs/actions/ReimbursementAccount';\nimport Form from '../../components/Form';\nimport styles from '../../styles/styles';\nimport ScreenWrapper from '../../components/ScreenWrapper';\nimport * as PlaidDataProps from './plaidDataPropTypes';\nimport StepPropTypes from './StepPropTypes';\n\nconst propTypes = {\n ...StepPropTypes,\n\n /** Contains plaid data */\n plaidData: PlaidDataProps.plaidDataPropTypes,\n\n /** The OAuth URI + stateID needed to re-initialize the PlaidLink after the user logs into their bank */\n receivedRedirectURI: PropTypes.string,\n\n /** During the OAuth flow we need to use the plaidLink token that we initially connected with */\n plaidLinkOAuthToken: PropTypes.string,\n};\n\nconst defaultProps = {\n plaidData: PlaidDataProps.plaidDataDefaultProps,\n receivedRedirectURI: null,\n plaidLinkOAuthToken: '',\n};\n\nclass BankAccountPlaidStep extends React.Component {\n constructor(props) {\n super(props);\n this.submit = this.submit.bind(this);\n }\n\n submit() {\n const selectedPlaidBankAccount = _.findWhere(lodashGet(this.props.plaidData, 'bankAccounts', []), {\n plaidAccountID: lodashGet(this.props.reimbursementAccountDraft, 'plaidAccountID', ''),\n });\n\n const bankAccountData = {\n routingNumber: selectedPlaidBankAccount.routingNumber,\n accountNumber: selectedPlaidBankAccount.accountNumber,\n plaidMask: selectedPlaidBankAccount.mask,\n isSavings: selectedPlaidBankAccount.isSavings,\n bankName: lodashGet(this.props.plaidData, 'bankName') || '',\n plaidAccountID: selectedPlaidBankAccount.plaidAccountID,\n plaidAccessToken: lodashGet(this.props.plaidData, 'plaidAccessToken') || '',\n };\n ReimbursementAccount.updateReimbursementAccountDraft(bankAccountData);\n\n const bankAccountID = lodashGet(this.props.reimbursementAccount, 'achData.bankAccountID') || 0;\n BankAccounts.connectBankAccountWithPlaid(bankAccountID, bankAccountData);\n }\n\n render() {\n const bankAccountID = lodashGet(this.props.reimbursementAccount, 'achData.bankAccountID') || 0;\n const selectedPlaidAccountID = lodashGet(this.props.reimbursementAccountDraft, 'plaidAccountID', '');\n\n return (\n \n \n ({})}\n onSubmit={this.submit}\n scrollContextEnabled\n submitButtonText={this.props.translate('common.saveAndContinue')}\n style={[styles.mh5, styles.flexGrow1]}\n isSubmitButtonVisible={Boolean(selectedPlaidAccountID) && !_.isEmpty(lodashGet(this.props.plaidData, 'bankAccounts'))}\n >\n {\n ReimbursementAccount.updateReimbursementAccountDraft({plaidAccountID});\n }}\n plaidData={this.props.plaidData}\n onExitPlaid={() => BankAccounts.setBankAccountSubStep(null)}\n receivedRedirectURI={this.props.receivedRedirectURI}\n plaidLinkOAuthToken={this.props.plaidLinkOAuthToken}\n allowDebit\n bankAccountID={bankAccountID}\n selectedPlaidAccountID={selectedPlaidAccountID}\n />\n \n \n );\n }\n}\n\nBankAccountPlaidStep.propTypes = propTypes;\nBankAccountPlaidStep.defaultProps = defaultProps;\nexport default compose(\n withLocalize,\n withOnyx({\n plaidData: {\n key: ONYXKEYS.PLAID_DATA,\n },\n }),\n)(BankAccountPlaidStep);\n","export default () => {};\n","import _ from 'underscore';\nimport lodashGet from 'lodash/get';\nimport React from 'react';\nimport {View} from 'react-native';\nimport Str from 'expensify-common/lib/str';\nimport {withOnyx} from 'react-native-onyx';\nimport PropTypes from 'prop-types';\nimport HeaderWithCloseButton from '../../components/HeaderWithCloseButton';\nimport CONST from '../../CONST';\nimport * as BankAccounts from '../../libs/actions/BankAccounts';\nimport Navigation from '../../libs/Navigation/Navigation';\nimport Text from '../../components/Text';\nimport DatePicker from '../../components/DatePicker';\nimport TextInput from '../../components/TextInput';\nimport styles from '../../styles/styles';\nimport CheckboxWithLabel from '../../components/CheckboxWithLabel';\nimport TextLink from '../../components/TextLink';\nimport StatePicker from '../../components/StatePicker';\nimport withLocalize from '../../components/withLocalize';\nimport * as ValidationUtils from '../../libs/ValidationUtils';\nimport * as LoginUtils from '../../libs/LoginUtils';\nimport compose from '../../libs/compose';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport Picker from '../../components/Picker';\nimport AddressForm from './AddressForm';\nimport Form from '../../components/Form';\nimport ScreenWrapper from '../../components/ScreenWrapper';\nimport StepPropTypes from './StepPropTypes';\n\nconst propTypes = {\n ...StepPropTypes,\n\n /** Session info for the currently logged in user. */\n session: PropTypes.shape({\n /** Currently logged in user email */\n email: PropTypes.string,\n }),\n\n /** Object with various information about the user */\n user: PropTypes.shape({\n /** Whether or not the user is on a public domain email account or not */\n isFromPublicDomain: PropTypes.bool,\n }),\n};\n\nconst defaultProps = {\n session: {\n email: null,\n },\n user: {},\n};\n\nclass CompanyStep extends React.Component {\n constructor(props) {\n super(props);\n\n this.submit = this.submit.bind(this);\n this.validate = this.validate.bind(this);\n\n this.defaultWebsite = lodashGet(props, 'user.isFromPublicDomain', false)\n ? 'https://'\n : `https://www.${Str.extractEmailDomain(props.session.email, '')}`;\n }\n\n componentWillUnmount() {\n BankAccounts.resetReimbursementAccount();\n }\n\n /**\n * @param {Array} fieldNames\n *\n * @returns {*}\n */\n getBankAccountFields(fieldNames) {\n return {\n ..._.pick(lodashGet(this.props.reimbursementAccount, 'achData'), ...fieldNames),\n ..._.pick(this.props.reimbursementAccountDraft, ...fieldNames),\n };\n }\n\n /**\n * @param {Object} values - form input values passed by the Form component\n * @returns {Object} - Object containing the errors for each inputID, e.g. {inputID1: error1, inputID2: error2}\n */\n validate(values) {\n const errors = {};\n\n if (!values.companyName) {\n errors.companyName = this.props.translate('bankAccount.error.companyName');\n }\n\n if (!values.addressStreet || !ValidationUtils.isValidAddress(values.addressStreet)) {\n errors.addressStreet = this.props.translate('bankAccount.error.addressStreet');\n }\n\n if (!values.addressZipCode || !ValidationUtils.isValidZipCode(values.addressZipCode)) {\n errors.addressZipCode = this.props.translate('bankAccount.error.zipCode');\n }\n\n if (!values.addressCity) {\n errors.addressCity = this.props.translate('bankAccount.error.addressCity');\n }\n\n if (!values.addressState) {\n errors.addressState = this.props.translate('bankAccount.error.addressState');\n }\n\n if (!values.companyPhone || !ValidationUtils.isValidUSPhone(values.companyPhone, true)) {\n errors.companyPhone = this.props.translate('bankAccount.error.phoneNumber');\n }\n\n if (!values.website || !ValidationUtils.isValidWebsite(values.website)) {\n errors.website = this.props.translate('bankAccount.error.website');\n }\n\n if (!values.companyTaxID || !ValidationUtils.isValidTaxID(values.companyTaxID)) {\n errors.companyTaxID = this.props.translate('bankAccount.error.taxID');\n }\n\n if (!values.incorporationType) {\n errors.incorporationType = this.props.translate('bankAccount.error.companyType');\n }\n\n if (!values.incorporationDate || !ValidationUtils.isValidDate(values.incorporationDate)) {\n errors.incorporationDate = this.props.translate('common.error.dateInvalid');\n } else if (!values.incorporationDate || !ValidationUtils.isValidPastDate(values.incorporationDate)) {\n errors.incorporationDate = this.props.translate('bankAccount.error.incorporationDateFuture');\n }\n\n if (!values.incorporationState) {\n errors.incorporationState = this.props.translate('bankAccount.error.incorporationState');\n }\n\n if (!values.hasNoConnectionToCannabis) {\n errors.hasNoConnectionToCannabis = this.props.translate('bankAccount.error.restrictedBusiness');\n }\n\n return errors;\n }\n\n submit(values) {\n const bankAccount = {\n bankAccountID: lodashGet(this.props.reimbursementAccount, 'achData.bankAccountID') || 0,\n\n // Fields from BankAccount step\n ...this.getBankAccountFields(['routingNumber', 'accountNumber', 'bankName', 'plaidAccountID', 'plaidAccessToken', 'isSavings']),\n\n // Fields from Company step\n ...values,\n companyTaxID: values.companyTaxID.replace(CONST.REGEX.NON_NUMERIC, ''),\n companyPhone: LoginUtils.getPhoneNumberWithoutUSCountryCodeAndSpecialChars(values.companyPhone),\n };\n\n BankAccounts.updateCompanyInformationForBankAccount(bankAccount);\n }\n\n render() {\n const bankAccountID = lodashGet(this.props.reimbursementAccount, 'achData.bankAccountID', 0);\n const shouldDisableCompanyName = Boolean(bankAccountID && this.props.getDefaultStateForField('companyName'));\n const shouldDisableCompanyTaxID = Boolean(bankAccountID && this.props.getDefaultStateForField('companyTaxID'));\n\n return (\n \n \n \n {this.props.translate('companyStep.subtitle')}\n \n \n \n \n \n \n ({value, label}))}\n placeholder={{value: '', label: '-'}}\n defaultValue={this.props.getDefaultStateForField('incorporationType')}\n shouldSaveDraft\n />\n \n \n \n \n \n \n \n (\n \n {`${this.props.translate('companyStep.confirmCompanyIsNot')} `}\n \n {`${this.props.translate('companyStep.listOfRestrictedBusinesses')}.`}\n \n \n )}\n style={[styles.mt4]}\n shouldSaveDraft\n />\n \n \n );\n }\n}\n\nCompanyStep.propTypes = propTypes;\nCompanyStep.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withOnyx({\n session: {\n key: ONYXKEYS.SESSION,\n },\n user: {\n key: ONYXKEYS.USER,\n },\n }),\n)(CompanyStep);\n","import PropTypes from 'prop-types';\nimport React from 'react';\nimport {ScrollView} from 'react-native';\nimport _ from 'underscore';\nimport * as Expensicons from '../../components/Icon/Expensicons';\nimport * as Illustrations from '../../components/Icon/Illustrations';\nimport withLocalize, {withLocalizePropTypes} from '../../components/withLocalize';\nimport Button from '../../components/Button';\nimport compose from '../../libs/compose';\nimport CONST from '../../CONST';\nimport FullPageNotFoundView from '../../components/BlockingViews/FullPageNotFoundView';\nimport HeaderWithCloseButton from '../../components/HeaderWithCloseButton';\nimport MenuItem from '../../components/MenuItem';\nimport Navigation from '../../libs/Navigation/Navigation';\nimport styles from '../../styles/styles';\nimport ScreenWrapper from '../../components/ScreenWrapper';\nimport Section from '../../components/Section';\nimport Text from '../../components/Text';\nimport withPolicy from '../workspace/withPolicy';\nimport * as ReimbursementAccountProps from './reimbursementAccountPropTypes';\nimport WorkspaceResetBankAccountModal from '../workspace/WorkspaceResetBankAccountModal';\nimport * as BankAccounts from '../../libs/actions/BankAccounts';\n\nconst propTypes = {\n /** Bank account currently in setup */\n reimbursementAccount: ReimbursementAccountProps.reimbursementAccountPropTypes.isRequired,\n\n /** Callback to continue to the next step of the setup */\n continue: PropTypes.func.isRequired,\n\n /** Callback to reset the bank account */\n startOver: PropTypes.func.isRequired,\n\n /** Policy values needed in the component */\n policy: PropTypes.shape({\n name: PropTypes.string,\n }).isRequired,\n\n /* The workspace name */\n policyName: PropTypes.string,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {policyName: ''};\n\nconst ContinueBankAccountSetup = props => (\n \n \n \n \n \n \n {props.translate('workspace.bankAccount.youreAlmostDone')}\n \n \n BankAccounts.requestResetFreePlanBankAccount()}\n shouldShowRightIcon\n wrapperStyle={[styles.cardMenuItem]}\n />\n \n \n \n\n {props.reimbursementAccount.shouldShowResetModal && (\n \n )}\n \n);\n\nContinueBankAccountSetup.propTypes = propTypes;\nContinueBankAccountSetup.defaultProps = defaultProps;\nContinueBankAccountSetup.displayName = 'ContinueBankAccountSetup';\n\nexport default compose(\n withPolicy,\n withLocalize,\n)(ContinueBankAccountSetup);\n","import lodashGet from 'lodash/get';\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport ConfirmModal from '../../components/ConfirmModal';\nimport * as BankAccounts from '../../libs/actions/BankAccounts';\nimport withLocalize, {withLocalizePropTypes} from '../../components/withLocalize';\nimport * as ReimbursementAccountProps from '../ReimbursementAccount/reimbursementAccountPropTypes';\nimport Text from '../../components/Text';\nimport styles from '../../styles/styles';\nimport BankAccount from '../../libs/models/BankAccount';\n\nconst propTypes = {\n /** Reimbursement account data */\n reimbursementAccount: ReimbursementAccountProps.reimbursementAccountPropTypes.isRequired,\n\n /** Callback when the user confirms resetting the workspace bank account */\n onConfirm: PropTypes.func,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n onConfirm: () => {},\n};\n\nconst WorkspaceResetBankAccountModal = (props) => {\n const achData = lodashGet(props.reimbursementAccount, 'achData') || {};\n const isInOpenState = achData.state === BankAccount.STATE.OPEN;\n const bankAccountID = achData.bankAccountID;\n const bankShortName = `${achData.addressName || ''} ${(achData.accountNumber || '').slice(-4)}`;\n\n return (\n \n {props.translate('workspace.bankAccount.disconnectYour')}\n \n {bankShortName}\n \n {props.translate('workspace.bankAccount.bankAccountAnyTransactions')}\n \n ) : props.translate('workspace.bankAccount.clearProgress')}\n danger\n onCancel={BankAccounts.cancelResetFreePlanBankAccount}\n onConfirm={() => {\n BankAccounts.resetFreePlanBankAccount(bankAccountID);\n props.onConfirm();\n }}\n shouldShowCancelButton\n isVisible\n />\n );\n};\n\nWorkspaceResetBankAccountModal.displayName = 'WorkspaceResetBankAccountModal';\nWorkspaceResetBankAccountModal.propTypes = propTypes;\nWorkspaceResetBankAccountModal.defaultProps = defaultProps;\n\nexport default withLocalize(WorkspaceResetBankAccountModal);\n","import React from 'react';\nimport {View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport lodashGet from 'lodash/get';\nimport styles from '../../styles/styles';\nimport withLocalize from '../../components/withLocalize';\nimport HeaderWithCloseButton from '../../components/HeaderWithCloseButton';\nimport CONST from '../../CONST';\nimport TextLink from '../../components/TextLink';\nimport Navigation from '../../libs/Navigation/Navigation';\nimport CheckboxWithLabel from '../../components/CheckboxWithLabel';\nimport Text from '../../components/Text';\nimport * as BankAccounts from '../../libs/actions/BankAccounts';\nimport IdentityForm from './IdentityForm';\nimport * as ValidationUtils from '../../libs/ValidationUtils';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport RequestorOnfidoStep from './RequestorOnfidoStep';\nimport Form from '../../components/Form';\nimport ScreenWrapper from '../../components/ScreenWrapper';\nimport StepPropTypes from './StepPropTypes';\n\nconst propTypes = {\n ...StepPropTypes,\n\n /** If we should show Onfido flow */\n shouldShowOnfido: PropTypes.bool.isRequired,\n};\n\nclass RequestorStep extends React.Component {\n constructor(props) {\n super(props);\n\n this.validate = this.validate.bind(this);\n this.submit = this.submit.bind(this);\n }\n\n /**\n * @param {Object} values\n * @returns {Object}\n */\n validate(values) {\n const errors = {};\n\n if (!ValidationUtils.isRequiredFulfilled(values.firstName)) {\n errors.firstName = this.props.translate('bankAccount.error.firstName');\n }\n\n if (!ValidationUtils.isRequiredFulfilled(values.lastName)) {\n errors.lastName = this.props.translate('bankAccount.error.lastName');\n }\n\n if (!ValidationUtils.isRequiredFulfilled(values.dob)) {\n errors.dob = this.props.translate('bankAccount.error.dob');\n }\n\n if (values.dob && !ValidationUtils.meetsAgeRequirements(values.dob)) {\n errors.dob = this.props.translate('bankAccount.error.age');\n }\n\n if (!ValidationUtils.isRequiredFulfilled(values.ssnLast4) || !ValidationUtils.isValidSSNLastFour(values.ssnLast4)) {\n errors.ssnLast4 = this.props.translate('bankAccount.error.ssnLast4');\n }\n\n if (!ValidationUtils.isRequiredFulfilled(values.requestorAddressStreet)) {\n errors.requestorAddressStreet = this.props.translate('bankAccount.error.address');\n }\n\n if (values.requestorAddressStreet && !ValidationUtils.isValidAddress(values.requestorAddressStreet)) {\n errors.requestorAddressStreet = this.props.translate('bankAccount.error.addressStreet');\n }\n\n if (!ValidationUtils.isRequiredFulfilled(values.requestorAddressCity)) {\n errors.requestorAddressCity = this.props.translate('bankAccount.error.addressCity');\n }\n\n if (!ValidationUtils.isRequiredFulfilled(values.requestorAddressState)) {\n errors.requestorAddressState = this.props.translate('bankAccount.error.addressState');\n }\n\n if (!ValidationUtils.isRequiredFulfilled(values.requestorAddressZipCode) || !ValidationUtils.isValidZipCode(values.requestorAddressZipCode)) {\n errors.requestorAddressZipCode = this.props.translate('bankAccount.error.zipCode');\n }\n\n if (!ValidationUtils.isRequiredFulfilled(values.isControllingOfficer)) {\n errors.isControllingOfficer = this.props.translate('requestorStep.isControllingOfficerError');\n }\n\n return errors;\n }\n\n submit(values) {\n const payload = {\n bankAccountID: lodashGet(this.props.reimbursementAccount, 'achData.bankAccountID') || 0,\n ...values,\n };\n\n BankAccounts.updatePersonalInformationForBankAccount(payload);\n }\n\n render() {\n if (this.props.shouldShowOnfido) {\n return (\n \n );\n }\n\n return (\n \n \n \n {this.props.translate('requestorStep.subtitle')}\n \n \n {`${this.props.translate('requestorStep.learnMore')}`}\n \n {' | '}\n \n {`${this.props.translate('requestorStep.isMyDataSafe')}`}\n \n \n \n (\n \n \n {this.props.translate('requestorStep.isControllingOfficer')}\n \n \n )}\n style={[styles.mt4]}\n shouldSaveDraft\n />\n \n {this.props.translate('requestorStep.onFidoConditions')}\n \n {this.props.translate('onfidoStep.facialScan')}\n \n {', '}\n \n {this.props.translate('common.privacy')}\n \n {` ${this.props.translate('common.and')} `}\n \n {this.props.translate('common.termsOfService')}\n \n \n \n \n );\n }\n}\n\nRequestorStep.propTypes = propTypes;\n\nexport default withLocalize(RequestorStep);\n","import React from 'react';\nimport {View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport moment from 'moment/moment';\nimport _ from 'underscore';\nimport TextInput from '../../components/TextInput';\nimport styles from '../../styles/styles';\nimport CONST from '../../CONST';\nimport DatePicker from '../../components/DatePicker';\nimport AddressForm from './AddressForm';\n\nconst propTypes = {\n /** Style for wrapping View */\n style: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.object), PropTypes.object]),\n\n /** Callback fired when a field changes. Passes args as {[fieldName]: val} */\n onFieldChange: PropTypes.func,\n\n /** Form values */\n values: PropTypes.shape({\n /** First name field */\n firstName: PropTypes.string,\n\n /** Last name field */\n lastName: PropTypes.string,\n\n /** Address street field */\n street: PropTypes.string,\n\n /** Address city field */\n city: PropTypes.string,\n\n /** Address state field */\n state: PropTypes.string,\n\n /** Address zip code field */\n zipCode: PropTypes.string,\n\n /** Date of birth field */\n dob: PropTypes.oneOfType([PropTypes.string, PropTypes.instanceOf(Date)]),\n\n /** Last 4 digits of SSN */\n ssnLast4: PropTypes.string,\n }),\n\n /** Default values */\n defaultValues: PropTypes.shape({\n /** First name field */\n firstName: PropTypes.string,\n\n /** Last name field */\n lastName: PropTypes.string,\n\n /** Address street field */\n street: PropTypes.string,\n\n /** Address city field */\n city: PropTypes.string,\n\n /** Address state field */\n state: PropTypes.string,\n\n /** Address zip code field */\n zipCode: PropTypes.string,\n\n /** Date of birth field */\n dob: PropTypes.oneOfType([PropTypes.string, PropTypes.instanceOf(Date)]),\n\n /** Last 4 digits of SSN */\n ssnLast4: PropTypes.string,\n }),\n\n /** Any errors that can arise from form validation */\n errors: PropTypes.objectOf(PropTypes.bool),\n\n /** The map for inputID of the inputs */\n inputKeys: PropTypes.shape({\n firstName: PropTypes.string,\n lastName: PropTypes.string,\n dob: PropTypes.string,\n ssnLast4: PropTypes.string,\n street: PropTypes.string,\n city: PropTypes.string,\n state: PropTypes.string,\n zipCode: PropTypes.string,\n }),\n\n /** Saves a draft of the input value when used in a form */\n shouldSaveDraft: PropTypes.bool,\n\n /** Returns translated string for given locale and phrase */\n translate: PropTypes.func.isRequired,\n};\n\nconst defaultProps = {\n style: {},\n values: {\n firstName: undefined,\n lastName: undefined,\n street: undefined,\n city: undefined,\n state: undefined,\n zipCode: undefined,\n dob: undefined,\n ssnLast4: undefined,\n },\n defaultValues: {\n firstName: undefined,\n lastName: undefined,\n street: undefined,\n city: undefined,\n state: undefined,\n zipCode: undefined,\n dob: undefined,\n ssnLast4: undefined,\n },\n errors: {},\n inputKeys: {\n firstName: '',\n lastName: '',\n street: '',\n city: '',\n state: '',\n zipCode: '',\n dob: '',\n ssnLast4: '',\n },\n shouldSaveDraft: false,\n onFieldChange: () => {},\n};\n\nconst IdentityForm = (props) => {\n // dob field has multiple validations/errors, we are handling it temporarily like this.\n const dobErrorText = (props.errors.dob ? props.translate('bankAccount.error.dob') : '')\n || (props.errors.dobAge ? props.translate('bankAccount.error.age') : '');\n const identityFormInputKeys = ['firstName', 'lastName', 'dob', 'ssnLast4'];\n\n const minDate = moment().subtract(CONST.DATE_BIRTH.MAX_AGE, 'Y').toDate();\n const maxDate = moment().subtract(CONST.DATE_BIRTH.MIN_AGE_FOR_PAYMENT, 'Y').toDate();\n\n return (\n \n \n \n props.onFieldChange({firstName: value})}\n errorText={props.errors.firstName ? props.translate('bankAccount.error.firstName') : ''}\n />\n \n \n props.onFieldChange({lastName: value})}\n errorText={props.errors.lastName ? props.translate('bankAccount.error.lastName') : ''}\n />\n \n \n props.onFieldChange({dob: value})}\n errorText={dobErrorText}\n minDate={minDate}\n maxDate={maxDate}\n />\n props.onFieldChange({ssnLast4: value})}\n errorText={props.errors.ssnLast4 ? props.translate('bankAccount.error.ssnLast4') : ''}\n maxLength={CONST.BANK_ACCOUNT.MAX_LENGTH.SSN}\n />\n \n \n );\n};\n\nIdentityForm.propTypes = propTypes;\nIdentityForm.defaultProps = defaultProps;\nIdentityForm.displayName = 'IdentityForm';\nexport default IdentityForm;\n","import React from 'react';\nimport {ScrollView} from 'react-native';\nimport {withOnyx} from 'react-native-onyx';\nimport PropTypes from 'prop-types';\nimport lodashGet from 'lodash/get';\nimport styles from '../../styles/styles';\nimport withLocalize from '../../components/withLocalize';\nimport * as BankAccounts from '../../libs/actions/BankAccounts';\nimport Onfido from '../../components/Onfido';\nimport compose from '../../libs/compose';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport Growl from '../../libs/Growl';\nimport CONST from '../../CONST';\nimport FullPageOfflineBlockingView from '../../components/BlockingViews/FullPageOfflineBlockingView';\nimport StepPropTypes from './StepPropTypes';\nimport HeaderWithCloseButton from '../../components/HeaderWithCloseButton';\nimport Navigation from '../../libs/Navigation/Navigation';\nimport ScreenWrapper from '../../components/ScreenWrapper';\n\nconst propTypes = {\n ...StepPropTypes,\n\n /** The token required to initialize the Onfido SDK */\n onfidoToken: PropTypes.string,\n};\n\nconst defaultProps = {\n onfidoToken: null,\n};\n\nclass RequestorOnfidoStep extends React.Component {\n constructor(props) {\n super(props);\n this.submit = this.submit.bind(this);\n }\n\n submit(onfidoData) {\n BankAccounts.verifyIdentityForBankAccount(\n lodashGet(this.props.reimbursementAccount, 'achData.bankAccountID') || 0,\n onfidoData,\n );\n\n BankAccounts.updateReimbursementAccountDraft({isOnfidoSetupComplete: true});\n }\n\n render() {\n return (\n \n \n \n \n {\n BankAccounts.clearOnfidoToken();\n BankAccounts.goToWithdrawalAccountSetupStep(CONST.BANK_ACCOUNT.STEP.REQUESTOR);\n }}\n onError={() => {\n // In case of any unexpected error we log it to the server, show a growl, and return the user back to the requestor step so they can try again.\n Growl.error(this.props.translate('onfidoStep.genericError'), 10000);\n BankAccounts.clearOnfidoToken();\n BankAccounts.goToWithdrawalAccountSetupStep(CONST.BANK_ACCOUNT.STEP.REQUESTOR);\n }}\n onSuccess={(onfidoData) => {\n this.submit(onfidoData);\n }}\n />\n \n \n \n );\n }\n}\n\nRequestorOnfidoStep.propTypes = propTypes;\nRequestorOnfidoStep.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withOnyx({\n onfidoToken: {\n key: ONYXKEYS.ONFIDO_TOKEN,\n },\n }),\n)(RequestorOnfidoStep);\n","import lodashGet from 'lodash/get';\nimport React from 'react';\nimport {ScrollView, View} from 'react-native';\nimport {withOnyx} from 'react-native-onyx';\nimport Str from 'expensify-common/lib/str';\nimport _ from 'underscore';\nimport PropTypes from 'prop-types';\nimport styles from '../../styles/styles';\nimport withLocalize, {withLocalizePropTypes} from '../../components/withLocalize';\nimport compose from '../../libs/compose';\nimport * as BankAccounts from '../../libs/actions/BankAccounts';\nimport * as Report from '../../libs/actions/Report';\nimport HeaderWithCloseButton from '../../components/HeaderWithCloseButton';\nimport Navigation from '../../libs/Navigation/Navigation';\nimport TextInput from '../../components/TextInput';\nimport Text from '../../components/Text';\nimport BankAccount from '../../libs/models/BankAccount';\nimport TextLink from '../../components/TextLink';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport * as ValidationUtils from '../../libs/ValidationUtils';\nimport EnableStep from './EnableStep';\nimport * as ReimbursementAccountProps from './reimbursementAccountPropTypes';\nimport Form from '../../components/Form';\nimport * as Expensicons from '../../components/Icon/Expensicons';\nimport * as Illustrations from '../../components/Icon/Illustrations';\nimport Section from '../../components/Section';\nimport CONST from '../../CONST';\nimport Button from '../../components/Button';\nimport MenuItem from '../../components/MenuItem';\nimport WorkspaceResetBankAccountModal from '../workspace/WorkspaceResetBankAccountModal';\nimport Enable2FAPrompt from './Enable2FAPrompt';\nimport ScreenWrapper from '../../components/ScreenWrapper';\n\nconst propTypes = {\n ...withLocalizePropTypes,\n\n /** Bank account currently in setup */\n reimbursementAccount: ReimbursementAccountProps.reimbursementAccountPropTypes.isRequired,\n\n onBackButtonPress: PropTypes.func.isRequired,\n\n /** User's account who is setting up bank account */\n account: PropTypes.shape({\n\n /** If user has Two factor authentication enabled */\n requiresTwoFactorAuth: PropTypes.bool,\n }),\n};\n\nconst defaultProps = {\n account: {\n requiresTwoFactorAuth: false,\n },\n};\n\nclass ValidationStep extends React.Component {\n constructor(props) {\n super(props);\n\n this.submit = this.submit.bind(this);\n this.validate = this.validate.bind(this);\n }\n\n /**\n * @param {Object} values - form input values passed by the Form component\n * @returns {Object}\n */\n validate(values) {\n const errors = {};\n\n _.each(values, (value, key) => {\n const filteredValue = this.filterInput(value);\n if (ValidationUtils.isRequiredFulfilled(filteredValue)) {\n return;\n }\n errors[key] = this.props.translate('common.error.invalidAmount');\n });\n\n return errors;\n }\n\n /**\n * @param {Object} values - form input values passed by the Form component\n */\n submit(values) {\n const amount1 = this.filterInput(values.amount1);\n const amount2 = this.filterInput(values.amount2);\n const amount3 = this.filterInput(values.amount3);\n\n const validateCode = [amount1, amount2, amount3].join(',');\n\n // Send valid amounts to BankAccountAPI::validateBankAccount in Web-Expensify\n const bankaccountID = lodashGet(this.props.reimbursementAccount, 'achData.bankAccountID');\n BankAccounts.validateBankAccount(bankaccountID, validateCode);\n }\n\n /**\n * Filter input for validation amount\n * Anything that isn't a number is returned as an empty string\n * Any dollar amount (e.g. 1.12) will be returned as 112\n *\n * @param {String} amount field input\n *\n * @returns {String}\n */\n filterInput(amount) {\n let value = amount ? amount.toString().trim() : '';\n if (value === '' || !Math.abs(Str.fromUSDToNumber(value)) || _.isNaN(Number(value))) {\n return '';\n }\n\n // If the user enters the values in dollars, convert it to the respective cents amount\n if (_.contains(value, '.')) {\n value = Str.fromUSDToNumber(value);\n }\n\n return value;\n }\n\n render() {\n const state = lodashGet(this.props.reimbursementAccount, 'achData.state');\n\n // If a user tries to navigate directly to the validate page we'll show them the EnableStep\n if (state === BankAccount.STATE.OPEN) {\n return ;\n }\n\n const maxAttemptsReached = lodashGet(this.props.reimbursementAccount, 'maxAttemptsReached');\n const isVerifying = !maxAttemptsReached && state === BankAccount.STATE.VERIFYING;\n const requiresTwoFactorAuth = lodashGet(this.props, 'account.requiresTwoFactorAuth');\n\n return (\n \n \n {maxAttemptsReached && (\n \n \n {this.props.translate('validationStep.maxAttemptsReached')}\n {' '}\n {this.props.translate('common.please')}\n {' '}\n \n {this.props.translate('common.contactUs')}\n \n .\n \n \n )}\n {!maxAttemptsReached && state === BankAccount.STATE.PENDING && (\n \n \n \n {this.props.translate('validationStep.description')}\n \n \n {this.props.translate('validationStep.descriptionCTA')}\n \n \n \n \n \n \n \n {!requiresTwoFactorAuth && (\n \n \n \n )}\n \n )}\n {isVerifying && (\n \n \n \n {this.props.translate('validationStep.letsChatText')}\n \n \n \n \n {this.props.reimbursementAccount.shouldShowResetModal && (\n \n )}\n {!requiresTwoFactorAuth && (\n \n )}\n \n )}\n \n );\n }\n}\n\nValidationStep.propTypes = propTypes;\nValidationStep.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withOnyx({\n account: {\n key: ONYXKEYS.ACCOUNT,\n },\n }),\n)(ValidationStep);\n","import React from 'react';\nimport {ScrollView} from 'react-native';\nimport {withOnyx} from 'react-native-onyx';\nimport PropTypes from 'prop-types';\nimport lodashGet from 'lodash/get';\nimport styles from '../../styles/styles';\nimport withLocalize, {withLocalizePropTypes} from '../../components/withLocalize';\nimport HeaderWithCloseButton from '../../components/HeaderWithCloseButton';\nimport Navigation from '../../libs/Navigation/Navigation';\nimport Text from '../../components/Text';\nimport compose from '../../libs/compose';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport CONST from '../../CONST';\nimport Button from '../../components/Button';\nimport * as Expensicons from '../../components/Icon/Expensicons';\nimport MenuItem from '../../components/MenuItem';\nimport getBankIcon from '../../components/Icon/BankIcons';\nimport * as ReimbursementAccountProps from './reimbursementAccountPropTypes';\nimport userPropTypes from '../settings/userPropTypes';\nimport Section from '../../components/Section';\nimport * as Illustrations from '../../components/Icon/Illustrations';\nimport * as Link from '../../libs/actions/Link';\nimport * as User from '../../libs/actions/User';\nimport ScreenWrapper from '../../components/ScreenWrapper';\nimport * as BankAccounts from '../../libs/actions/ReimbursementAccount';\nimport WorkspaceResetBankAccountModal from '../workspace/WorkspaceResetBankAccountModal';\n\nconst propTypes = {\n /** Bank account currently in setup */\n reimbursementAccount: ReimbursementAccountProps.reimbursementAccountPropTypes.isRequired,\n\n /* Onyx Props */\n user: userPropTypes,\n\n /* The workspace name */\n policyName: PropTypes.string,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n user: {},\n policyName: '',\n};\n\nconst EnableStep = (props) => {\n const isUsingExpensifyCard = props.user.isUsingExpensifyCard;\n const achData = lodashGet(props.reimbursementAccount, 'achData') || {};\n const {icon, iconSize} = getBankIcon(achData.bankName);\n const formattedBankAccountNumber = achData.accountNumber\n ? `${props.translate('paymentMethodList.accountLastFour')} ${\n achData.accountNumber.slice(-4)\n }`\n : '';\n const bankName = achData.addressName;\n\n return (\n \n Navigation.goBack()}\n />\n \n \n \n \n {!isUsingExpensifyCard\n ? props.translate('workspace.bankAccount.accountDescriptionNoCards')\n : props.translate('workspace.bankAccount.accountDescriptionWithCards')}\n \n {!isUsingExpensifyCard && (\n {\n Link.openOldDotLink(CONST.ADD_SECONDARY_LOGIN_URL);\n User.subscribeToExpensifyCardUpdates();\n }}\n icon={Expensicons.Mail}\n style={[styles.mt4]}\n iconStyles={[styles.buttonCTAIcon]}\n shouldShowRightIcon\n large\n success\n />\n )}\n \n \n {Boolean(props.user.isCheckingDomain) && (\n \n {props.translate('workspace.card.checkingDomain')}\n \n )}\n \n {props.reimbursementAccount.shouldShowResetModal && (\n \n )}\n \n );\n};\n\nEnableStep.displayName = 'EnableStep';\nEnableStep.propTypes = propTypes;\nEnableStep.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withOnyx({\n user: {\n key: ONYXKEYS.USER,\n },\n }),\n)(EnableStep);\n","import React from 'react';\nimport {View} from 'react-native';\nimport Text from '../../components/Text';\nimport styles from '../../styles/styles';\nimport withLocalize, {withLocalizePropTypes} from '../../components/withLocalize';\nimport * as Expensicons from '../../components/Icon/Expensicons';\nimport * as Illustrations from '../../components/Icon/Illustrations';\nimport Section from '../../components/Section';\nimport * as Link from '../../libs/actions/Link';\nimport ROUTES from '../../ROUTES';\nimport themeColors from '../../styles/themes/default';\n\nconst propTypes = {\n ...withLocalizePropTypes,\n};\nconst Enable2FAPrompt = (props) => {\n const secureYourAccountUrl = encodeURI(`settings?param={\"section\":\"account\",\"action\":\"enableTwoFactorAuth\",\"exitTo\":\"${ROUTES.getBankAccountRoute()}\",\"isFromNewDot\":\"true\"}`);\n\n return (\n {\n Link.openOldDotLink(secureYourAccountUrl);\n },\n icon: Expensicons.Shield,\n shouldShowRightIcon: true,\n iconRight: Expensicons.NewWindow,\n iconFill: themeColors.success,\n wrapperStyle: [styles.cardMenuItem],\n link: () => Link.buildOldDotURL(secureYourAccountUrl),\n },\n ]}\n >\n \n \n {props.translate('validationStep.enable2FAText')}\n \n \n \n );\n};\n\nEnable2FAPrompt.propTypes = propTypes;\nEnable2FAPrompt.displayName = 'Enable2FAPrompt';\n\nexport default withLocalize(Enable2FAPrompt);\n","import _ from 'underscore';\nimport lodashGet from 'lodash/get';\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport {View} from 'react-native';\nimport Str from 'expensify-common/lib/str';\nimport Text from '../../components/Text';\nimport HeaderWithCloseButton from '../../components/HeaderWithCloseButton';\nimport styles from '../../styles/styles';\nimport CheckboxWithLabel from '../../components/CheckboxWithLabel';\nimport TextLink from '../../components/TextLink';\nimport IdentityForm from './IdentityForm';\nimport withLocalize from '../../components/withLocalize';\nimport * as BankAccounts from '../../libs/actions/BankAccounts';\nimport Navigation from '../../libs/Navigation/Navigation';\nimport CONST from '../../CONST';\nimport * as ValidationUtils from '../../libs/ValidationUtils';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport Form from '../../components/Form';\nimport * as FormActions from '../../libs/actions/FormActions';\nimport ScreenWrapper from '../../components/ScreenWrapper';\nimport StepPropTypes from './StepPropTypes';\n\nconst propTypes = {\n ...StepPropTypes,\n\n /** Name of the company */\n companyName: PropTypes.string.isRequired,\n};\n\nclass ACHContractStep extends React.Component {\n constructor(props) {\n super(props);\n this.validate = this.validate.bind(this);\n\n this.addBeneficialOwner = this.addBeneficialOwner.bind(this);\n this.submit = this.submit.bind(this);\n\n this.state = {\n\n // Array of strings containing the keys to render associated Identity Forms\n beneficialOwners: props.getDefaultStateForField('beneficialOwners', []),\n };\n }\n\n /**\n * @param {Object} values - input values passed by the Form component\n * @returns {Object}\n */\n validate(values) {\n const errors = {};\n\n const errorKeys = {\n street: 'address',\n city: 'addressCity',\n state: 'addressState',\n };\n const requiredFields = ['firstName', 'lastName', 'dob', 'ssnLast4', 'street', 'city', 'zipCode', 'state'];\n if (values.hasOtherBeneficialOwners) {\n _.each(this.state.beneficialOwners, (ownerKey) => {\n // eslint-disable-next-line rulesdir/prefer-early-return\n _.each(requiredFields, (inputKey) => {\n if (!ValidationUtils.isRequiredFulfilled(values[`beneficialOwner_${ownerKey}_${inputKey}`])) {\n const errorKey = errorKeys[inputKey] || inputKey;\n errors[`beneficialOwner_${ownerKey}_${inputKey}`] = this.props.translate(`bankAccount.error.${errorKey}`);\n }\n });\n\n if (values[`beneficialOwner_${ownerKey}_dob`] && !ValidationUtils.meetsAgeRequirements(values[`beneficialOwner_${ownerKey}_dob`])) {\n errors[`beneficialOwner_${ownerKey}_dob`] = this.props.translate('bankAccount.error.age');\n }\n\n if (values[`beneficialOwner_${ownerKey}_ssnLast4`] && !ValidationUtils.isValidSSNLastFour(values[`beneficialOwner_${ownerKey}_ssnLast4`])) {\n errors[`beneficialOwner_${ownerKey}_ssnLast4`] = this.props.translate('bankAccount.error.ssnLast4');\n }\n\n if (values[`beneficialOwner_${ownerKey}_street`] && !ValidationUtils.isValidAddress(values[`beneficialOwner_${ownerKey}_street`])) {\n errors[`beneficialOwner_${ownerKey}_street`] = this.props.translate('bankAccount.error.addressStreet');\n }\n\n if (values[`beneficialOwner_${ownerKey}_zipCode`] && !ValidationUtils.isValidZipCode(values[`beneficialOwner_${ownerKey}_zipCode`])) {\n errors[`beneficialOwner_${ownerKey}_zipCode`] = this.props.translate('bankAccount.error.zipCode');\n }\n });\n }\n\n if (!ValidationUtils.isRequiredFulfilled(values.acceptTermsAndConditions)) {\n errors.acceptTermsAndConditions = this.props.translate('common.error.acceptTerms');\n }\n\n if (!ValidationUtils.isRequiredFulfilled(values.certifyTrueInformation)) {\n errors.certifyTrueInformation = this.props.translate('beneficialOwnersStep.error.certify');\n }\n\n return errors;\n }\n\n /**\n * @param {Number} ownerKey - ID connected to the beneficial owner identity form\n */\n removeBeneficialOwner(ownerKey) {\n this.setState((prevState) => {\n const beneficialOwners = _.without(prevState.beneficialOwners, ownerKey);\n\n FormActions.setDraftValues(ONYXKEYS.REIMBURSEMENT_ACCOUNT, {beneficialOwners});\n\n return {beneficialOwners};\n });\n }\n\n addBeneficialOwner() {\n this.setState((prevState) => {\n // Each beneficial owner is assigned a unique key that will connect it to an Identity Form.\n // That way we can dynamically render each Identity Form based on which keys are present in the beneficial owners array.\n const beneficialOwners = [...prevState.beneficialOwners, Str.guid()];\n\n FormActions.setDraftValues(ONYXKEYS.REIMBURSEMENT_ACCOUNT, {beneficialOwners});\n return {beneficialOwners};\n });\n }\n\n /**\n * @param {Boolean} ownsMoreThan25Percent\n * @returns {Boolean}\n */\n canAddMoreBeneficialOwners(ownsMoreThan25Percent) {\n return _.size(this.state.beneficialOwners) < 3\n || (_.size(this.state.beneficialOwners) === 3 && !ownsMoreThan25Percent);\n }\n\n /**\n * @param {Object} values - object containing form input values\n */\n submit(values) {\n const bankAccountID = lodashGet(this.props.reimbursementAccount, 'achData.bankAccountID') || 0;\n\n const beneficialOwners = !values.hasOtherBeneficialOwners ? []\n : _.map(this.state.beneficialOwners, ownerKey => ({\n firstName: lodashGet(values, `beneficialOwner_${ownerKey}_firstName`),\n lastName: lodashGet(values, `beneficialOwner_${ownerKey}_lastName`),\n dob: lodashGet(values, `beneficialOwner_${ownerKey}_dob`),\n ssnLast4: lodashGet(values, `beneficialOwner_${ownerKey}_ssnLast4`),\n street: lodashGet(values, `beneficialOwner_${ownerKey}_street`),\n city: lodashGet(values, `beneficialOwner_${ownerKey}_city`),\n state: lodashGet(values, `beneficialOwner_${ownerKey}_state`),\n zipCode: lodashGet(values, `beneficialOwner_${ownerKey}_zipCode`),\n }));\n\n BankAccounts.updateBeneficialOwnersForBankAccount({\n ownsMoreThan25Percent: values.ownsMoreThan25Percent,\n hasOtherBeneficialOwners: values.hasOtherBeneficialOwners,\n acceptTermsAndConditions: values.acceptTermsAndConditions,\n certifyTrueInformation: values.certifyTrueInformation,\n beneficialOwners: JSON.stringify(beneficialOwners),\n bankAccountID,\n });\n }\n\n render() {\n return (\n \n \n \n {({inputValues}) => (\n <>\n \n {this.props.translate('beneficialOwnersStep.checkAllThatApply')}\n \n (\n \n {this.props.translate('beneficialOwnersStep.iOwnMoreThan25Percent')}\n {this.props.companyName}\n \n )}\n // eslint-disable-next-line rulesdir/prefer-early-return\n onValueChange={(ownsMoreThan25Percent) => {\n if (ownsMoreThan25Percent && this.state.beneficialOwners.length > 3) {\n // If the user owns more than 25% of the company, then there can only be a maximum of 3 other beneficial owners who owns more than 25%.\n // We have to remove the 4th beneficial owner if the checkbox is checked.\n this.setState(prevState => ({beneficialOwners: prevState.beneficialOwners.slice(0, -1)}));\n }\n }}\n defaultValue={this.props.getDefaultStateForField('ownsMoreThan25Percent', false)}\n shouldSaveDraft\n />\n (\n \n {this.props.translate('beneficialOwnersStep.someoneOwnsMoreThan25Percent')}\n {this.props.companyName}\n \n )}\n // eslint-disable-next-line rulesdir/prefer-early-return\n onValueChange={(hasOtherBeneficialOwners) => {\n if (hasOtherBeneficialOwners && this.state.beneficialOwners.length === 0) {\n this.addBeneficialOwner();\n }\n }}\n defaultValue={this.props.getDefaultStateForField('hasOtherBeneficialOwners', false)}\n shouldSaveDraft\n />\n {Boolean(inputValues.hasOtherBeneficialOwners) && (\n \n {_.map(this.state.beneficialOwners, (ownerKey, index) => (\n \n \n {this.props.translate('beneficialOwnersStep.additionalOwner')}\n \n \n {this.state.beneficialOwners.length > 1 && (\n this.removeBeneficialOwner(ownerKey)}>\n {this.props.translate('beneficialOwnersStep.removeOwner')}\n \n )}\n \n ))}\n {this.canAddMoreBeneficialOwners(inputValues.ownsMoreThan25Percent) && (\n \n {this.props.translate('beneficialOwnersStep.addAnotherIndividual')}\n {this.props.companyName}\n \n )}\n \n )}\n \n {this.props.translate('beneficialOwnersStep.agreement')}\n \n (\n \n {this.props.translate('common.iAcceptThe')}\n \n {`${this.props.translate('beneficialOwnersStep.termsAndConditions')}`}\n \n \n )}\n defaultValue={this.props.getDefaultStateForField('acceptTermsAndConditions', false)}\n shouldSaveDraft\n />\n (\n {this.props.translate('beneficialOwnersStep.certifyTrueAndAccurate')}\n )}\n defaultValue={this.props.getDefaultStateForField('certifyTrueInformation', false)}\n shouldSaveDraft\n />\n \n )}\n \n \n );\n }\n}\n\nACHContractStep.propTypes = propTypes;\nexport default withLocalize(ACHContractStep);\n","import React from 'react';\nimport {View, ScrollView, Linking} from 'react-native';\nimport PropTypes from 'prop-types';\nimport {withOnyx} from 'react-native-onyx';\nimport lodashGet from 'lodash/get';\nimport ScreenWrapper from '../components/ScreenWrapper';\nimport withLocalize, {withLocalizePropTypes} from '../components/withLocalize';\nimport HeaderWithCloseButton from '../components/HeaderWithCloseButton';\nimport Section from '../components/Section';\nimport Navigation from '../libs/Navigation/Navigation';\nimport styles from '../styles/styles';\nimport Text from '../components/Text';\nimport * as Expensicons from '../components/Icon/Expensicons';\nimport * as Illustrations from '../components/Icon/Illustrations';\nimport * as Report from '../libs/actions/Report';\nimport * as Link from '../libs/actions/Link';\nimport CONST from '../CONST';\nimport compose from '../libs/compose';\nimport ONYXKEYS from '../ONYXKEYS';\n\nconst propTypes = {\n /** Route object from navigation */\n route: PropTypes.shape({\n params: PropTypes.shape({\n /** The task ID to request the call for */\n taskID: PropTypes.string,\n }),\n }).isRequired,\n\n /** The details about the account that the user is signing in with */\n account: PropTypes.shape({\n /** URL to the assigned guide's appointment booking calendar */\n guideCalendarLink: PropTypes.string,\n }),\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n account: {\n guideCalendarLink: null,\n },\n};\n\nconst GetAssistancePage = (props) => {\n const menuItems = [{\n title: props.translate('getAssistancePage.chatWithConcierge'),\n onPress: () => Report.navigateToConciergeChat(),\n icon: Expensicons.ChatBubble,\n shouldShowRightIcon: true,\n wrapperStyle: [styles.cardMenuItem],\n },\n {\n title: props.translate('getAssistancePage.exploreHelpDocs'),\n onPress: () => Link.openExternalLink(CONST.NEWHELP_URL),\n icon: Expensicons.QuestionMark,\n shouldShowRightIcon: true,\n iconRight: Expensicons.NewWindow,\n wrapperStyle: [styles.cardMenuItem],\n link: CONST.NEWHELP_URL,\n }];\n\n // If the user is eligible for calls with their Guide, add the 'Schedule a setup call' item at the second position in the list\n const guideCalendarLink = lodashGet(props.account, 'guideCalendarLink');\n if (guideCalendarLink) {\n menuItems.splice(1, 0, {\n title: props.translate('getAssistancePage.scheduleSetupCall'),\n onPress: () => Linking.openURL(guideCalendarLink),\n icon: Expensicons.Phone,\n shouldShowRightIcon: true,\n iconRight: Expensicons.NewWindow,\n wrapperStyle: [styles.cardMenuItem],\n });\n }\n\n return (\n \n Navigation.dismissModal(true)}\n shouldShowBackButton\n onBackButtonPress={() => Navigation.goBack()}\n />\n \n \n \n {props.translate('getAssistancePage.description')}\n \n \n \n \n );\n};\n\nGetAssistancePage.propTypes = propTypes;\nGetAssistancePage.defaultProps = defaultProps;\nGetAssistancePage.displayName = 'GetAssistancePage';\n\nexport default compose(\n withLocalize,\n withOnyx({\n account: {\n key: ONYXKEYS.ACCOUNT,\n selector: account => account && ({guideCalendarLink: account.guideCalendarLink}),\n },\n }),\n)(GetAssistancePage);\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport lodashGet from 'lodash/get';\nimport {withOnyx} from 'react-native-onyx';\nimport moment from 'moment';\nimport Str from 'expensify-common/lib/str';\nimport Navigation from '../../libs/Navigation/Navigation';\nimport withLocalize, {withLocalizePropTypes} from '../../components/withLocalize';\nimport HeaderWithCloseButton from '../../components/HeaderWithCloseButton';\nimport ScreenWrapper from '../../components/ScreenWrapper';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport compose from '../../libs/compose';\nimport CONFIG from '../../CONFIG';\nimport WalletStatementModal from '../../components/WalletStatementModal';\nimport * as User from '../../libs/actions/User';\nimport fileDownload from '../../libs/fileDownload';\nimport Growl from '../../libs/Growl';\nimport CONST from '../../CONST';\nimport FullPageOfflineBlockingView from '../../components/BlockingViews/FullPageOfflineBlockingView';\nimport {withNetwork} from '../../components/OnyxProvider';\nimport networkPropTypes from '../../components/networkPropTypes';\n\nconst propTypes = {\n /** The route object passed to this page from the navigator */\n route: PropTypes.shape({\n\n /** Each parameter passed via the URL */\n params: PropTypes.shape({\n\n /** The statement year and month as one string, i.e. 202110 */\n yearMonth: PropTypes.string.isRequired,\n }).isRequired,\n }).isRequired,\n\n walletStatement: PropTypes.shape({\n /** Whether we are currently generating a PDF version of the statement */\n isGenerating: PropTypes.bool,\n }),\n\n /** Information about the network */\n network: networkPropTypes.isRequired,\n\n /** Indicates which locale the user currently has selected */\n preferredLocale: PropTypes.string,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n walletStatement: {\n isGenerating: false,\n },\n preferredLocale: CONST.LOCALES.DEFAULT,\n};\n\nclass WalletStatementPage extends React.Component {\n constructor(props) {\n super(props);\n\n this.processDownload = this.processDownload.bind(this);\n this.yearMonth = lodashGet(this.props.route.params, 'yearMonth', null);\n }\n\n componentDidMount() {\n const currentYearMonth = moment().format('YYYYMM');\n if (!this.yearMonth || this.yearMonth.length !== 6 || this.yearMonth > currentYearMonth) {\n Navigation.dismissModal(true);\n }\n }\n\n processDownload(yearMonth) {\n if (this.props.walletStatement.isGenerating) {\n return;\n }\n\n if (this.props.walletStatement[yearMonth]) {\n // We already have a file URL for this statement, so we can download it immediately\n const downloadFileName = `Expensify_Statement_${yearMonth}.pdf`;\n const fileName = this.props.walletStatement[yearMonth];\n const pdfURL = `${CONFIG.EXPENSIFY.EXPENSIFY_URL}secure?secureType=pdfreport&filename=${fileName}&downloadName=${downloadFileName}`;\n fileDownload(pdfURL, downloadFileName);\n return;\n }\n\n Growl.show(this.props.translate('statementPage.generatingPDF'), CONST.GROWL.SUCCESS, 3000);\n User.generateStatementPDF(this.yearMonth);\n }\n\n render() {\n moment.locale(this.props.preferredLocale);\n const year = this.yearMonth.substring(0, 4) || moment().year();\n const month = this.yearMonth.substring(4) || moment().month();\n const monthName = moment(month, 'M').format('MMMM');\n const title = `${monthName} ${year} statement`;\n const url = `${CONFIG.EXPENSIFY.EXPENSIFY_URL}statement.php?period=${this.yearMonth}`;\n\n return (\n \n Navigation.dismissModal(true)}\n onDownloadButtonPress={() => this.processDownload(this.yearMonth)}\n />\n \n \n \n \n );\n }\n}\n\nWalletStatementPage.propTypes = propTypes;\nWalletStatementPage.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withOnyx({\n preferredLocale: {\n key: ONYXKEYS.NVP_PREFERRED_LOCALE,\n },\n walletStatement: {\n key: ONYXKEYS.WALLET_STATEMENT,\n },\n }),\n withNetwork(),\n)(WalletStatementPage);\n","import React from 'react';\nimport {WebView} from 'react-native-webview';\nimport lodashGet from 'lodash/get';\nimport {withOnyx} from 'react-native-onyx';\nimport _ from 'underscore';\nimport withLocalize from '../withLocalize';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport compose from '../../libs/compose';\nimport {walletStatementPropTypes, walletStatementDefaultProps} from './WalletStatementModalPropTypes';\nimport FullScreenLoadingIndicator from '../FullscreenLoadingIndicator';\nimport * as Report from '../../libs/actions/Report';\nimport Navigation from '../../libs/Navigation/Navigation';\nimport ROUTES from '../../ROUTES';\n\nclass WalletStatementModal extends React.Component {\n constructor(props) {\n super(props);\n\n this.authToken = lodashGet(props, 'session.authToken', null);\n this.navigate = this.navigate.bind(this);\n }\n\n /**\n * Handles in-app navigation for webview links\n *\n * @param {String} params.type\n * @param {String} params.url\n */\n navigate({type, url}) {\n if (!this.webview || (type !== 'STATEMENT_NAVIGATE' && type !== 'CONCIERGE_NAVIGATE')) {\n return;\n }\n\n if (type === 'CONCIERGE_NAVIGATE') {\n this.webview.stopLoading();\n Report.navigateToConciergeChat();\n }\n\n if (type === 'STATEMENT_NAVIGATE' && url) {\n const iouRoutes = [ROUTES.IOU_REQUEST, ROUTES.IOU_SEND, ROUTES.IOU_BILL];\n const navigateToIOURoute = _.find(iouRoutes, iouRoute => url.includes(iouRoute));\n if (navigateToIOURoute) {\n this.webview.stopLoading();\n Navigation.navigate(navigateToIOURoute);\n }\n }\n }\n\n render() {\n return (\n this.webview = node}\n originWhitelist={['https://*']}\n source={{\n uri: this.props.statementPageURL,\n headers: {\n Cookie: `authToken=${this.authToken}`,\n },\n }}\n incognito // 'incognito' prop required for Android, issue here https://github.com/react-native-webview/react-native-webview/issues/1352\n startInLoadingState\n renderLoading={() => }\n onNavigationStateChange={this.navigate}\n />\n );\n }\n}\n\nWalletStatementModal.propTypes = walletStatementPropTypes;\nWalletStatementModal.defaultProps = walletStatementDefaultProps;\n\nexport default compose(\n withLocalize,\n withOnyx({\n session: {\n key: ONYXKEYS.SESSION,\n },\n }),\n)(WalletStatementModal);\n","import WebView from './lib/WebView';\n\nexport { WebView };\nexport default WebView;\n","var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nvar __generator = (this && this.__generator) || function (thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n function verb(n) { return function (v) { return step([n, v]); }; }\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: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n};\nvar __rest = (this && this.__rest) || function (s, e) {\n var t = {};\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\n 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]))\n t[p[i]] = s[p[i]];\n }\n return t;\n};\nimport React, { forwardRef, useCallback, useImperativeHandle, useRef } from 'react';\nimport { Image, View, NativeModules, } from 'react-native';\nimport invariant from 'invariant';\n// @ts-expect-error react-native doesn't have this type\nimport codegenNativeCommandsUntyped from 'react-native/Libraries/Utilities/codegenNativeCommands';\nimport RNCWebView from \"./WebViewNativeComponent.ios\";\nimport { defaultOriginWhitelist, defaultRenderError, defaultRenderLoading, useWebWiewLogic, } from './WebViewShared';\nimport styles from './WebView.styles';\nvar codegenNativeCommands = codegenNativeCommandsUntyped;\nvar Commands = codegenNativeCommands({\n supportedCommands: ['goBack', 'goForward', 'reload', 'stopLoading', 'injectJavaScript', 'requestFocus', 'postMessage', 'loadUrl']\n});\nvar resolveAssetSource = Image.resolveAssetSource;\nvar processDecelerationRate = function (decelerationRate) {\n var newDecelerationRate = decelerationRate;\n if (newDecelerationRate === 'normal') {\n newDecelerationRate = 0.998;\n }\n else if (newDecelerationRate === 'fast') {\n newDecelerationRate = 0.99;\n }\n return newDecelerationRate;\n};\nvar RNCWebViewManager = NativeModules.RNCWebViewManager;\nvar useWarnIfChanges = function (value, name) {\n var ref = useRef(value);\n if (ref.current !== value) {\n console.warn(\"Changes to property \".concat(name, \" do nothing after the initial render.\"));\n ref.current = value;\n }\n};\nvar WebViewComponent = forwardRef(function (_a, ref) {\n var _b = _a.javaScriptEnabled, javaScriptEnabled = _b === void 0 ? true : _b, _c = _a.cacheEnabled, cacheEnabled = _c === void 0 ? true : _c, _d = _a.originWhitelist, originWhitelist = _d === void 0 ? defaultOriginWhitelist : _d, _e = _a.useSharedProcessPool, useSharedProcessPool = _e === void 0 ? true : _e, _f = _a.textInteractionEnabled, textInteractionEnabled = _f === void 0 ? true : _f, injectedJavaScript = _a.injectedJavaScript, injectedJavaScriptBeforeContentLoaded = _a.injectedJavaScriptBeforeContentLoaded, _g = _a.injectedJavaScriptForMainFrameOnly, injectedJavaScriptForMainFrameOnly = _g === void 0 ? true : _g, _h = _a.injectedJavaScriptBeforeContentLoadedForMainFrameOnly, injectedJavaScriptBeforeContentLoadedForMainFrameOnly = _h === void 0 ? true : _h, startInLoadingState = _a.startInLoadingState, onNavigationStateChange = _a.onNavigationStateChange, onLoadStart = _a.onLoadStart, onError = _a.onError, onLoad = _a.onLoad, onLoadEnd = _a.onLoadEnd, onLoadProgress = _a.onLoadProgress, onContentProcessDidTerminateProp = _a.onContentProcessDidTerminate, onFileDownload = _a.onFileDownload, onHttpErrorProp = _a.onHttpError, onMessageProp = _a.onMessage, renderLoading = _a.renderLoading, renderError = _a.renderError, style = _a.style, containerStyle = _a.containerStyle, source = _a.source, nativeConfig = _a.nativeConfig, allowsInlineMediaPlayback = _a.allowsInlineMediaPlayback, allowsAirPlayForMediaPlayback = _a.allowsAirPlayForMediaPlayback, mediaPlaybackRequiresUserAction = _a.mediaPlaybackRequiresUserAction, dataDetectorTypes = _a.dataDetectorTypes, incognito = _a.incognito, decelerationRateProp = _a.decelerationRate, onShouldStartLoadWithRequestProp = _a.onShouldStartLoadWithRequest, otherProps = __rest(_a, [\"javaScriptEnabled\", \"cacheEnabled\", \"originWhitelist\", \"useSharedProcessPool\", \"textInteractionEnabled\", \"injectedJavaScript\", \"injectedJavaScriptBeforeContentLoaded\", \"injectedJavaScriptForMainFrameOnly\", \"injectedJavaScriptBeforeContentLoadedForMainFrameOnly\", \"startInLoadingState\", \"onNavigationStateChange\", \"onLoadStart\", \"onError\", \"onLoad\", \"onLoadEnd\", \"onLoadProgress\", \"onContentProcessDidTerminate\", \"onFileDownload\", \"onHttpError\", \"onMessage\", \"renderLoading\", \"renderError\", \"style\", \"containerStyle\", \"source\", \"nativeConfig\", \"allowsInlineMediaPlayback\", \"allowsAirPlayForMediaPlayback\", \"mediaPlaybackRequiresUserAction\", \"dataDetectorTypes\", \"incognito\", \"decelerationRate\", \"onShouldStartLoadWithRequest\"]);\n var webViewRef = useRef(null);\n var onShouldStartLoadWithRequestCallback = useCallback(function (shouldStart, _url, lockIdentifier) {\n if (lockIdentifier === void 0) { lockIdentifier = 0; }\n var viewManager = (nativeConfig === null || nativeConfig === void 0 ? void 0 : nativeConfig.viewManager)\n || RNCWebViewManager;\n viewManager.startLoadWithResult(!!shouldStart, lockIdentifier);\n }, [nativeConfig === null || nativeConfig === void 0 ? void 0 : nativeConfig.viewManager]);\n var _j = useWebWiewLogic({\n onNavigationStateChange: onNavigationStateChange,\n onLoad: onLoad,\n onError: onError,\n onHttpErrorProp: onHttpErrorProp,\n onLoadEnd: onLoadEnd,\n onLoadProgress: onLoadProgress,\n onLoadStart: onLoadStart,\n onMessageProp: onMessageProp,\n startInLoadingState: startInLoadingState,\n originWhitelist: originWhitelist,\n onShouldStartLoadWithRequestProp: onShouldStartLoadWithRequestProp,\n onShouldStartLoadWithRequestCallback: onShouldStartLoadWithRequestCallback,\n onContentProcessDidTerminateProp: onContentProcessDidTerminateProp\n }), onLoadingStart = _j.onLoadingStart, onShouldStartLoadWithRequest = _j.onShouldStartLoadWithRequest, onMessage = _j.onMessage, viewState = _j.viewState, setViewState = _j.setViewState, lastErrorEvent = _j.lastErrorEvent, onHttpError = _j.onHttpError, onLoadingError = _j.onLoadingError, onLoadingFinish = _j.onLoadingFinish, onLoadingProgress = _j.onLoadingProgress, onContentProcessDidTerminate = _j.onContentProcessDidTerminate;\n useImperativeHandle(ref, function () { return ({\n goForward: function () { return Commands.goForward(webViewRef.current); },\n goBack: function () { return Commands.goBack(webViewRef.current); },\n reload: function () {\n setViewState('LOADING');\n Commands.reload(webViewRef.current);\n },\n stopLoading: function () { return Commands.stopLoading(webViewRef.current); },\n postMessage: function (data) { return Commands.postMessage(webViewRef.current, data); },\n injectJavaScript: function (data) { return Commands.injectJavaScript(webViewRef.current, data); },\n requestFocus: function () { return Commands.requestFocus(webViewRef.current); }\n }); }, [setViewState, webViewRef]);\n useWarnIfChanges(allowsInlineMediaPlayback, 'allowsInlineMediaPlayback');\n useWarnIfChanges(allowsAirPlayForMediaPlayback, 'allowsAirPlayForMediaPlayback');\n useWarnIfChanges(incognito, 'incognito');\n useWarnIfChanges(mediaPlaybackRequiresUserAction, 'mediaPlaybackRequiresUserAction');\n useWarnIfChanges(dataDetectorTypes, 'dataDetectorTypes');\n var otherView = null;\n if (viewState === 'LOADING') {\n otherView = (renderLoading || defaultRenderLoading)();\n }\n else if (viewState === 'ERROR') {\n invariant(lastErrorEvent != null, 'lastErrorEvent expected to be non-null');\n otherView = (renderError || defaultRenderError)(lastErrorEvent.domain, lastErrorEvent.code, lastErrorEvent.description);\n }\n else if (viewState !== 'IDLE') {\n console.error(\"RNCWebView invalid state encountered: \".concat(viewState));\n }\n var webViewStyles = [styles.container, styles.webView, style];\n var webViewContainerStyle = [styles.container, containerStyle];\n var decelerationRate = processDecelerationRate(decelerationRateProp);\n var NativeWebView = (nativeConfig === null || nativeConfig === void 0 ? void 0 : nativeConfig.component)\n || RNCWebView;\n var webView = ();\n return (\n {webView}\n {otherView}\n );\n});\n// no native implementation for iOS, depends only on permissions\nvar isFileUploadSupported = function () { return __awaiter(void 0, void 0, void 0, function () { return __generator(this, function (_a) {\n return [2 /*return*/, true];\n}); }); };\nvar WebView = Object.assign(WebViewComponent, { isFileUploadSupported: isFileUploadSupported });\nexport default WebView;\n","import { requireNativeComponent } from \"react-native\";\nvar RNCWebView = requireNativeComponent('RNCWebView');\nexport default RNCWebView;\n","import { StyleSheet } from 'react-native';\nvar styles = StyleSheet.create({\n container: {\n flex: 1,\n overflow: 'hidden'\n },\n loadingOrErrorView: {\n position: 'absolute',\n flex: 1,\n justifyContent: 'center',\n alignItems: 'center',\n height: '100%',\n width: '100%',\n backgroundColor: 'white'\n },\n loadingProgressBar: {\n height: 20\n },\n errorText: {\n fontSize: 14,\n textAlign: 'center',\n marginBottom: 2\n },\n errorTextTitle: {\n fontSize: 15,\n fontWeight: '500',\n marginBottom: 10\n },\n webView: {\n backgroundColor: '#ffffff'\n }\n});\nexport default styles;\n","var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {\n if (pack || arguments.length === 2) 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};\nimport escapeStringRegexp from 'escape-string-regexp';\nimport React, { useCallback, useMemo, useRef, useState } from 'react';\nimport { Linking, View, ActivityIndicator, Text, Platform } from 'react-native';\nimport styles from './WebView.styles';\nvar defaultOriginWhitelist = ['http://*', 'https://*'];\nvar extractOrigin = function (url) {\n var result = /^[A-Za-z][A-Za-z0-9+\\-.]+:(\\/\\/)?[^/]*/.exec(url);\n return result === null ? '' : result[0];\n};\nvar originWhitelistToRegex = function (originWhitelist) {\n return \"^\".concat(escapeStringRegexp(originWhitelist).replace(/\\\\\\*/g, '.*'));\n};\nvar passesWhitelist = function (compiledWhitelist, url) {\n var origin = extractOrigin(url);\n return compiledWhitelist.some(function (x) { return new RegExp(x).test(origin); });\n};\nvar compileWhitelist = function (originWhitelist) {\n return __spreadArray(['about:blank'], (originWhitelist || []), true).map(originWhitelistToRegex);\n};\nvar createOnShouldStartLoadWithRequest = function (loadRequest, originWhitelist, onShouldStartLoadWithRequest) {\n return function (_a) {\n var nativeEvent = _a.nativeEvent;\n var shouldStart = true;\n var url = nativeEvent.url, lockIdentifier = nativeEvent.lockIdentifier;\n if (!passesWhitelist(compileWhitelist(originWhitelist), url)) {\n Linking.canOpenURL(url).then(function (supported) {\n if (supported) {\n return Linking.openURL(url);\n }\n console.warn(\"Can't open url: \".concat(url));\n return undefined;\n })[\"catch\"](function (e) {\n console.warn('Error opening URL: ', e);\n });\n shouldStart = false;\n }\n else if (onShouldStartLoadWithRequest) {\n shouldStart = onShouldStartLoadWithRequest(nativeEvent);\n }\n loadRequest(shouldStart, url, lockIdentifier);\n };\n};\nvar defaultRenderLoading = function () { return (\n \n ); };\nvar defaultRenderError = function (errorDomain, errorCode, errorDesc) { return (\n Error loading page\n {\"Domain: \".concat(errorDomain)}\n {\"Error Code: \".concat(errorCode)}\n {\"Description: \".concat(errorDesc)}\n ); };\nexport { defaultOriginWhitelist, createOnShouldStartLoadWithRequest, defaultRenderLoading, defaultRenderError, };\nexport var useWebWiewLogic = function (_a) {\n var startInLoadingState = _a.startInLoadingState, onNavigationStateChange = _a.onNavigationStateChange, onLoadStart = _a.onLoadStart, onLoad = _a.onLoad, onLoadProgress = _a.onLoadProgress, onLoadEnd = _a.onLoadEnd, onError = _a.onError, onHttpErrorProp = _a.onHttpErrorProp, onMessageProp = _a.onMessageProp, onRenderProcessGoneProp = _a.onRenderProcessGoneProp, onContentProcessDidTerminateProp = _a.onContentProcessDidTerminateProp, originWhitelist = _a.originWhitelist, onShouldStartLoadWithRequestProp = _a.onShouldStartLoadWithRequestProp, onShouldStartLoadWithRequestCallback = _a.onShouldStartLoadWithRequestCallback;\n var _b = useState(startInLoadingState ? \"LOADING\" : \"IDLE\"), viewState = _b[0], setViewState = _b[1];\n var _c = useState(null), lastErrorEvent = _c[0], setLastErrorEvent = _c[1];\n var startUrl = useRef(null);\n var updateNavigationState = useCallback(function (event) {\n onNavigationStateChange === null || onNavigationStateChange === void 0 ? void 0 : onNavigationStateChange(event.nativeEvent);\n }, [onNavigationStateChange]);\n var onLoadingStart = useCallback(function (event) {\n // Needed for android\n startUrl.current = event.nativeEvent.url;\n // !Needed for android\n onLoadStart === null || onLoadStart === void 0 ? void 0 : onLoadStart(event);\n updateNavigationState(event);\n }, [onLoadStart, updateNavigationState]);\n var onLoadingError = useCallback(function (event) {\n event.persist();\n if (onError) {\n onError(event);\n }\n else {\n console.warn('Encountered an error loading page', event.nativeEvent);\n }\n onLoadEnd === null || onLoadEnd === void 0 ? void 0 : onLoadEnd(event);\n if (event.isDefaultPrevented()) {\n return;\n }\n ;\n setViewState('ERROR');\n setLastErrorEvent(event.nativeEvent);\n }, [onError, onLoadEnd]);\n var onHttpError = useCallback(function (event) {\n onHttpErrorProp === null || onHttpErrorProp === void 0 ? void 0 : onHttpErrorProp(event);\n }, [onHttpErrorProp]);\n // Android Only\n var onRenderProcessGone = useCallback(function (event) {\n onRenderProcessGoneProp === null || onRenderProcessGoneProp === void 0 ? void 0 : onRenderProcessGoneProp(event);\n }, [onRenderProcessGoneProp]);\n // !Android Only\n // iOS Only\n var onContentProcessDidTerminate = useCallback(function (event) {\n onContentProcessDidTerminateProp === null || onContentProcessDidTerminateProp === void 0 ? void 0 : onContentProcessDidTerminateProp(event);\n }, [onContentProcessDidTerminateProp]);\n // !iOS Only\n var onLoadingFinish = useCallback(function (event) {\n onLoad === null || onLoad === void 0 ? void 0 : onLoad(event);\n onLoadEnd === null || onLoadEnd === void 0 ? void 0 : onLoadEnd(event);\n var url = event.nativeEvent.url;\n // on Android, only if url === startUrl\n if (Platform.OS !== \"android\" || url === startUrl.current) {\n setViewState('IDLE');\n }\n // !on Android, only if url === startUrl\n updateNavigationState(event);\n }, [onLoad, onLoadEnd, updateNavigationState]);\n var onMessage = useCallback(function (event) {\n onMessageProp === null || onMessageProp === void 0 ? void 0 : onMessageProp(event);\n }, [onMessageProp]);\n var onLoadingProgress = useCallback(function (event) {\n var progress = event.nativeEvent.progress;\n // patch for Android only\n if (Platform.OS === \"android\" && progress === 1) {\n setViewState(function (prevViewState) { return prevViewState === 'LOADING' ? 'IDLE' : prevViewState; });\n }\n // !patch for Android only\n onLoadProgress === null || onLoadProgress === void 0 ? void 0 : onLoadProgress(event);\n }, [onLoadProgress]);\n var onShouldStartLoadWithRequest = useMemo(function () { return createOnShouldStartLoadWithRequest(onShouldStartLoadWithRequestCallback, originWhitelist, onShouldStartLoadWithRequestProp); }, [originWhitelist, onShouldStartLoadWithRequestProp, onShouldStartLoadWithRequestCallback]);\n return {\n onShouldStartLoadWithRequest: onShouldStartLoadWithRequest,\n onLoadingStart: onLoadingStart,\n onLoadingProgress: onLoadingProgress,\n onLoadingError: onLoadingError,\n onLoadingFinish: onLoadingFinish,\n onHttpError: onHttpError,\n onRenderProcessGone: onRenderProcessGone,\n onContentProcessDidTerminate: onContentProcessDidTerminate,\n onMessage: onMessage,\n viewState: viewState,\n setViewState: setViewState,\n lastErrorEvent: lastErrorEvent\n };\n};\n","'use strict';\n\nconst matchOperatorsRegex = /[|\\\\{}()[\\]^$+*?.-]/g;\n\nmodule.exports = string => {\n\tif (typeof string !== 'string') {\n\t\tthrow new TypeError('Expected a string');\n\t}\n\n\treturn string.replace(matchOperatorsRegex, '\\\\$&');\n};\n","import PropTypes from 'prop-types';\n\nconst walletStatementPropTypes = {\n /* Onyx Props */\n /** Session info for the currently logged in user. */\n session: PropTypes.shape({\n\n /** Currently logged in user authToken */\n authToken: PropTypes.string,\n }),\n\n /** URL for oldDot (expensify.com) statements page to display */\n statementPageURL: PropTypes.string,\n};\n\nconst walletStatementDefaultProps = {\n session: {\n authToken: null,\n },\n};\n\nexport {\n walletStatementPropTypes,\n walletStatementDefaultProps,\n};\n","import _ from 'underscore';\nimport React from 'react';\nimport {withCurrentUserPersonalDetailsPropTypes, withCurrentUserPersonalDetailsDefaultProps} from '../components/withCurrentUserPersonalDetails';\nimport ScreenWrapper from '../components/ScreenWrapper';\nimport HeaderWithCloseButton from '../components/HeaderWithCloseButton';\nimport withLocalize, {withLocalizePropTypes} from '../components/withLocalize';\nimport ROUTES from '../ROUTES';\nimport styles from '../styles/styles';\nimport Navigation from '../libs/Navigation/Navigation';\nimport OptionsSelector from '../components/OptionsSelector';\nimport themeColors from '../styles/themes/default';\nimport * as Expensicons from '../components/Icon/Expensicons';\nimport CONST from '../CONST';\n\nconst greenCheckmark = {src: Expensicons.Checkmark, color: themeColors.success};\n\nconst propTypes = {\n ...withLocalizePropTypes,\n ...withCurrentUserPersonalDetailsPropTypes,\n};\n\nconst defaultProps = {\n ...withCurrentUserPersonalDetailsDefaultProps,\n};\n\nclass YearPickerPage extends React.Component {\n constructor(props) {\n super(props);\n\n const {params} = props.route;\n const minYear = Number(params.min);\n const maxYear = Number(params.max);\n const currentYear = Number(params.year);\n\n this.currentYear = currentYear;\n this.yearList = _.map(Array.from({length: (maxYear - minYear) + 1}, (v, i) => i + minYear), value => ({\n text: value.toString(),\n value,\n keyForList: value.toString(),\n\n // Include the green checkmark icon to indicate the currently selected value\n customIcon: value === currentYear ? greenCheckmark : undefined,\n\n // This property will make the currently selected value have bold text\n boldStyle: value === currentYear,\n }));\n\n this.updateYearOfBirth = this.updateSelectedYear.bind(this);\n this.filterYearList = this.filterYearList.bind(this);\n\n this.state = {\n inputText: '',\n yearOptions: this.yearList,\n };\n }\n\n /**\n * Function called on selection of the year, to take user back to the previous screen\n *\n * @param {String} selectedYear\n */\n updateSelectedYear(selectedYear) {\n // We have to navigate using concatenation here as it is not possible to pass a function as a route param\n Navigation.navigate(`${this.props.route.params.backTo}?year=${selectedYear}`);\n }\n\n /**\n * Function filtering the list of the items when using search input\n *\n * @param {String} text\n */\n filterYearList(text) {\n this.setState({\n inputText: text,\n yearOptions: _.filter(this.yearList, year => year.text.includes(text.trim())),\n });\n }\n\n render() {\n const headerMessage = this.state.inputText.trim() && !this.state.yearOptions.length ? this.props.translate('common.noResultsFound') : '';\n return (\n \n Navigation.navigate(`${this.props.route.params.backTo}?year=${this.currentYear}` || ROUTES.HOME)}\n onCloseButtonPress={() => Navigation.dismissModal(true)}\n />\n this.updateSelectedYear(option.value)}\n headerMessage={headerMessage}\n initiallyFocusedOptionKey={this.currentYear.toString()}\n hideSectionHeaders\n optionHoveredStyle={styles.hoveredComponentBG}\n shouldHaveOptionSeparator\n contentContainerStyles={[styles.ph5]}\n />\n \n );\n }\n}\n\nYearPickerPage.propTypes = propTypes;\nYearPickerPage.defaultProps = defaultProps;\n\nexport default withLocalize(YearPickerPage);\n","const defaultScreenOptions = {\n cardStyle: {\n overflow: 'visible',\n flex: 1,\n },\n headerShown: false,\n animationTypeForReplace: 'pop',\n};\n\nexport default defaultScreenOptions;\n","import React, {Component} from 'react';\nimport PropTypes from 'prop-types';\nimport lodashGet from 'lodash/get';\nimport {withOnyx} from 'react-native-onyx';\nimport _ from 'underscore';\n\nimport ONYXKEYS from '../../../ONYXKEYS';\nimport SCREENS from '../../../SCREENS';\nimport Permissions from '../../Permissions';\nimport Timing from '../../actions/Timing';\nimport CONST from '../../../CONST';\n\n// Screens\nimport ReportScreen from '../../../pages/home/ReportScreen';\nimport SidebarScreen from '../../../pages/home/sidebar/SidebarScreen';\nimport BaseDrawerNavigator from './BaseDrawerNavigator';\nimport * as ReportUtils from '../../ReportUtils';\nimport reportPropTypes from '../../../pages/reportPropTypes';\nimport Navigation from '../Navigation';\nimport {withNavigationPropTypes} from '../../../components/withNavigation';\n\nconst propTypes = {\n /** Available reports that would be displayed in this navigator */\n reports: PropTypes.objectOf(reportPropTypes),\n\n /** Beta features list */\n betas: PropTypes.arrayOf(PropTypes.string),\n\n /** The policies which the user has access to */\n policies: PropTypes.objectOf(PropTypes.shape({\n /** The policy name */\n name: PropTypes.string,\n\n /** The type of the policy */\n type: PropTypes.string,\n })),\n\n route: PropTypes.shape({\n params: PropTypes.shape({\n openOnAdminRoom: PropTypes.bool,\n }),\n }).isRequired,\n\n ...withNavigationPropTypes,\n};\n\nconst defaultProps = {\n reports: {},\n betas: [],\n policies: {},\n};\n\n/**\n * Get the most recently accessed report for the user\n *\n * @param {Object} reports\n * @param {Boolean} [ignoreDefaultRooms]\n * @param {Object} policies\n * @param {Boolean} openOnAdminRoom\n * @returns {Object}\n */\nconst getInitialReportScreenParams = (reports, ignoreDefaultRooms, policies, openOnAdminRoom) => {\n const last = ReportUtils.findLastAccessedReport(reports, ignoreDefaultRooms, policies, openOnAdminRoom);\n\n // Fallback to empty if for some reason reportID cannot be derived - prevents the app from crashing\n const reportID = lodashGet(last, 'reportID', '');\n return {reportID: String(reportID)};\n};\n\nclass MainDrawerNavigator extends Component {\n constructor(props) {\n super(props);\n this.trackAppStartTiming = this.trackAppStartTiming.bind(this);\n this.initialParams = getInitialReportScreenParams(\n props.reports,\n !Permissions.canUseDefaultRooms(props.betas),\n props.policies,\n lodashGet(props, 'route.params.openOnAdminRoom', false),\n );\n\n // When we have chat reports the moment this component got created\n // we know that the data was served from storage/cache\n this.isFromCache = _.size(props.reports) > 0;\n }\n\n shouldComponentUpdate(nextProps) {\n const initialNextParams = getInitialReportScreenParams(\n nextProps.reports,\n !Permissions.canUseDefaultRooms(nextProps.betas),\n nextProps.policies,\n lodashGet(nextProps, 'route.params.openOnAdminRoom', false),\n );\n if (this.initialParams.reportID === initialNextParams.reportID) {\n return false;\n }\n\n // Update the report screen initial params after the reports are available\n // to show the correct report instead of the \"no access\" report.\n // https://github.com/Expensify/App/issues/12698#issuecomment-1352632883\n if (!this.initialParams.reportID) {\n const state = this.props.navigation.getState();\n const reportScreenKey = lodashGet(state, 'routes[0].state.routes[0].key', '');\n Navigation.setParams(initialNextParams, reportScreenKey);\n }\n this.initialParams = initialNextParams;\n return true;\n }\n\n trackAppStartTiming() {\n // We only want to report timing events when rendering from cached data\n if (!this.isFromCache) {\n return;\n }\n\n Timing.end(CONST.TIMING.SIDEBAR_LOADED);\n }\n\n render() {\n return (\n {\n // This state belongs to the drawer so it should always have the ReportScreen as it's initial (and only) route\n const reportIDFromRoute = lodashGet(state, ['routes', 0, 'params', 'reportID']);\n return (\n \n );\n }}\n screens={[\n {\n name: SCREENS.REPORT,\n component: ReportScreen,\n initialParams: this.initialParams,\n },\n ]}\n isMainScreen\n />\n );\n }\n}\n\nMainDrawerNavigator.propTypes = propTypes;\nMainDrawerNavigator.defaultProps = defaultProps;\nMainDrawerNavigator.displayName = 'MainDrawerNavigator';\n\nexport default withOnyx({\n reports: {\n key: ONYXKEYS.COLLECTION.REPORT,\n },\n betas: {\n key: ONYXKEYS.BETAS,\n },\n policies: {\n key: ONYXKEYS.COLLECTION.POLICY,\n },\n})(MainDrawerNavigator);\n","import React from 'react';\nimport {withOnyx} from 'react-native-onyx';\nimport PropTypes from 'prop-types';\nimport {View} from 'react-native';\nimport lodashGet from 'lodash/get';\nimport _ from 'underscore';\nimport {Freeze} from 'react-freeze';\nimport {PortalHost} from '@gorhom/portal';\nimport styles from '../../styles/styles';\nimport ScreenWrapper from '../../components/ScreenWrapper';\nimport HeaderView from './HeaderView';\nimport Navigation from '../../libs/Navigation/Navigation';\nimport ROUTES from '../../ROUTES';\nimport * as Report from '../../libs/actions/Report';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport Permissions from '../../libs/Permissions';\nimport * as ReportUtils from '../../libs/ReportUtils';\nimport ReportActionsView from './report/ReportActionsView';\nimport CONST from '../../CONST';\nimport ReportActionsSkeletonView from '../../components/ReportActionsSkeletonView';\nimport reportActionPropTypes from './report/reportActionPropTypes';\nimport toggleReportActionComposeView from '../../libs/toggleReportActionComposeView';\nimport {withNetwork} from '../../components/OnyxProvider';\nimport compose from '../../libs/compose';\nimport Visibility from '../../libs/Visibility';\nimport networkPropTypes from '../../components/networkPropTypes';\nimport withWindowDimensions, {windowDimensionsPropTypes} from '../../components/withWindowDimensions';\nimport OfflineWithFeedback from '../../components/OfflineWithFeedback';\nimport withDrawerState, {withDrawerPropTypes} from '../../components/withDrawerState';\nimport ReportFooter from './report/ReportFooter';\nimport Banner from '../../components/Banner';\nimport withLocalize from '../../components/withLocalize';\nimport reportPropTypes from '../reportPropTypes';\nimport FullPageNotFoundView from '../../components/BlockingViews/FullPageNotFoundView';\nimport ReportHeaderSkeletonView from '../../components/ReportHeaderSkeletonView';\nimport withViewportOffsetTop, {viewportOffsetTopPropTypes} from '../../components/withViewportOffsetTop';\nimport * as ReportActionsUtils from '../../libs/ReportActionsUtils';\nimport personalDetailsPropType from '../personalDetailsPropType';\nimport getIsReportFullyVisible from '../../libs/getIsReportFullyVisible';\nimport EmojiPicker from '../../components/EmojiPicker/EmojiPicker';\nimport * as EmojiPickerAction from '../../libs/actions/EmojiPickerAction';\n\nconst propTypes = {\n /** Navigation route context info provided by react navigation */\n route: PropTypes.shape({\n /** Route specific parameters used on this screen */\n params: PropTypes.shape({\n /** The ID of the report this screen should display */\n reportID: PropTypes.string,\n }).isRequired,\n }).isRequired,\n\n /** Tells us if the sidebar has rendered */\n isSidebarLoaded: PropTypes.bool,\n\n /** The report currently being looked at */\n report: reportPropTypes,\n\n /** Array of report actions for this report */\n reportActions: PropTypes.arrayOf(PropTypes.shape(reportActionPropTypes)),\n\n /** Whether the composer is full size */\n isComposerFullSize: PropTypes.bool,\n\n /** Beta features list */\n betas: PropTypes.arrayOf(PropTypes.string),\n\n /** The policies which the user has access to */\n policies: PropTypes.objectOf(PropTypes.shape({\n /** The policy name */\n name: PropTypes.string,\n\n /** The type of the policy */\n type: PropTypes.string,\n })),\n\n /** Information about the network */\n network: networkPropTypes.isRequired,\n\n /** The account manager report ID */\n accountManagerReportID: PropTypes.string,\n\n /** All of the personal details for everyone */\n personalDetails: PropTypes.objectOf(personalDetailsPropType),\n\n ...windowDimensionsPropTypes,\n ...withDrawerPropTypes,\n ...viewportOffsetTopPropTypes,\n};\n\nconst defaultProps = {\n isSidebarLoaded: false,\n reportActions: {},\n report: {\n hasOutstandingIOU: false,\n isLoadingReportActions: false,\n },\n isComposerFullSize: false,\n betas: [],\n policies: {},\n accountManagerReportID: null,\n personalDetails: {},\n};\n\n/**\n * Get the currently viewed report ID as number\n *\n * @param {Object} route\n * @param {Object} route.params\n * @param {String} route.params.reportID\n * @returns {String}\n */\nfunction getReportID(route) {\n return route.params.reportID.toString();\n}\n\n// Keep a reference to the list view height so we can use it when a new ReportScreen component mounts\nlet reportActionsListViewHeight = 0;\n\nclass ReportScreen extends React.Component {\n constructor(props) {\n super(props);\n\n this.onSubmitComment = this.onSubmitComment.bind(this);\n this.chatWithAccountManager = this.chatWithAccountManager.bind(this);\n this.dismissBanner = this.dismissBanner.bind(this);\n\n this.state = {\n skeletonViewContainerHeight: reportActionsListViewHeight,\n isBannerVisible: true,\n };\n }\n\n componentDidMount() {\n this.unsubscribeVisibilityListener = Visibility.onVisibilityChange(() => {\n // If the report is not fully visible (AKA on small screen devices and LHR is open) or the report is optimistic (AKA not yet created)\n // we don't need to call openReport\n if (!getIsReportFullyVisible(this.props.isDrawerOpen, this.props.isSmallScreenWidth) || this.props.report.isOptimisticReport) {\n return;\n }\n\n Report.openReport(this.props.report.reportID);\n });\n\n this.fetchReportIfNeeded();\n toggleReportActionComposeView(true);\n Navigation.setIsReportScreenIsReady();\n }\n\n componentDidUpdate(prevProps) {\n // If you already have a report open and are deeplinking to a new report on native,\n // the ReportScreen never actually unmounts and the reportID in the route also doesn't change.\n // Therefore, we need to compare if the existing reportID is the same as the one in the route\n // before deciding that we shouldn't call OpenReport.\n const onyxReportID = this.props.report.reportID;\n const routeReportID = getReportID(this.props.route);\n if (onyxReportID === prevProps.report.reportID && (!onyxReportID || onyxReportID === routeReportID)) {\n return;\n }\n\n this.fetchReportIfNeeded();\n toggleReportActionComposeView(true);\n }\n\n componentWillUnmount() {\n if (this.unsubscribeVisibilityListener) {\n this.unsubscribeVisibilityListener();\n }\n Navigation.resetIsReportScreenReadyPromise();\n }\n\n /**\n * @param {String} text\n */\n onSubmitComment(text) {\n Report.addComment(getReportID(this.props.route), text);\n }\n\n /**\n * When false the ReportActionsView will completely unmount and we will show a loader until it returns true.\n *\n * @returns {Boolean}\n */\n isReportReadyForDisplay() {\n const reportIDFromPath = getReportID(this.props.route);\n\n // This is necessary so that when we are retrieving the next report data from Onyx the ReportActionsView will remount completely\n const isTransitioning = this.props.report && this.props.report.reportID !== reportIDFromPath;\n return reportIDFromPath !== '' && this.props.report.reportID && !isTransitioning;\n }\n\n fetchReportIfNeeded() {\n const reportIDFromPath = getReportID(this.props.route);\n\n // Report ID will be empty when the reports collection is empty.\n // This could happen when we are loading the collection for the first time after logging in.\n if (!reportIDFromPath) {\n return;\n }\n\n // It possible that we may not have the report object yet in Onyx yet e.g. we navigated to a URL for an accessible report that\n // is not stored locally yet. If props.report.reportID exists, then the report has been stored locally and nothing more needs to be done.\n // If it doesn't exist, then we fetch the report from the API.\n if (this.props.report.reportID && this.props.report.reportID === getReportID(this.props.route)) {\n return;\n }\n\n Report.openReport(reportIDFromPath);\n }\n\n dismissBanner() {\n this.setState({isBannerVisible: false});\n }\n\n chatWithAccountManager() {\n Navigation.navigate(ROUTES.getReportRoute(this.props.accountManagerReportID));\n }\n\n render() {\n // We are either adding a workspace room, or we're creating a chat, it isn't possible for both of these to be pending, or to have errors for the same report at the same time, so\n // simply looking up the first truthy value for each case will get the relevant property if it's set.\n const reportID = getReportID(this.props.route);\n const addWorkspaceRoomOrChatPendingAction = lodashGet(this.props.report, 'pendingFields.addWorkspaceRoom') || lodashGet(this.props.report, 'pendingFields.createChat');\n const addWorkspaceRoomOrChatErrors = lodashGet(this.props.report, 'errorFields.addWorkspaceRoom') || lodashGet(this.props.report, 'errorFields.createChat');\n const screenWrapperStyle = [styles.appContent, styles.flex1, {marginTop: this.props.viewportOffsetTop}];\n\n // There are no reportActions at all to display and we are still in the process of loading the next set of actions.\n const isLoadingInitialReportActions = _.isEmpty(this.props.reportActions) && this.props.report.isLoadingReportActions;\n\n // Users not in the Default Room or Policy Room Betas can't view the report\n const shouldHideReport = (\n ReportUtils.isDefaultRoom(this.props.report) && !ReportUtils.canSeeDefaultRoom(this.props.report, this.props.policies, this.props.betas))\n || (ReportUtils.isUserCreatedPolicyRoom(this.props.report) && !Permissions.canUsePolicyRooms(this.props.betas));\n\n // When the ReportScreen is not open/in the viewport, we want to \"freeze\" it for performance reasons\n const shouldFreeze = this.props.isSmallScreenWidth && this.props.isDrawerOpen;\n\n const isLoading = !reportID || !this.props.isSidebarLoaded || _.isEmpty(this.props.personalDetails);\n\n // the moment the ReportScreen becomes unfrozen we want to start the animation of the placeholder skeleton content\n // (which is shown, until all the actual views of the ReportScreen have been rendered)\n const shouldAnimate = !shouldFreeze;\n\n return (\n \n \n \n \n \n \n \n \n )}\n >\n {\n Navigation.navigate(ROUTES.HOME);\n }}\n >\n {isLoading ? : (\n <>\n \n Navigation.navigate(ROUTES.HOME)}\n personalDetails={this.props.personalDetails}\n report={this.props.report}\n policies={this.props.policies}\n />\n \n {Boolean(this.props.accountManagerReportID) && ReportUtils.isConciergeChatReport(this.props.report) && this.state.isBannerVisible && (\n \n )}\n \n )}\n {\n const skeletonViewContainerHeight = event.nativeEvent.layout.height;\n\n // The height can be 0 if the component unmounts - we are not interested in this value and want to know how much space it\n // takes up so we can set the skeleton view container height.\n if (skeletonViewContainerHeight === 0) {\n return;\n }\n reportActionsListViewHeight = skeletonViewContainerHeight;\n this.setState({skeletonViewContainerHeight});\n }}\n >\n {(this.isReportReadyForDisplay() && !isLoadingInitialReportActions && !isLoading) && (\n \n )}\n\n {/* Note: The report should be allowed to mount even if the initial report actions are not loaded. If we prevent rendering the report while they are loading then\n we'll unnecessarily unmount the ReportActionsView which will clear the new marker lines initial state. */}\n {(!this.isReportReadyForDisplay() || isLoadingInitialReportActions || isLoading) && (\n \n )}\n\n {this.isReportReadyForDisplay() && (\n <>\n \n \n )}\n\n {!this.isReportReadyForDisplay() && (\n \n )}\n\n \n \n \n \n \n \n );\n }\n}\n\nReportScreen.propTypes = propTypes;\nReportScreen.defaultProps = defaultProps;\n\nexport default compose(\n withViewportOffsetTop,\n withLocalize,\n withWindowDimensions,\n withDrawerState,\n withNetwork(),\n withOnyx({\n isSidebarLoaded: {\n key: ONYXKEYS.IS_SIDEBAR_LOADED,\n },\n reportActions: {\n key: ({route}) => `${ONYXKEYS.COLLECTION.REPORT_ACTIONS}${getReportID(route)}`,\n canEvict: false,\n selector: ReportActionsUtils.getSortedReportActionsForDisplay,\n },\n report: {\n key: ({route}) => `${ONYXKEYS.COLLECTION.REPORT}${getReportID(route)}`,\n },\n isComposerFullSize: {\n key: ({route}) => `${ONYXKEYS.COLLECTION.REPORT_IS_COMPOSER_FULL_SIZE}${getReportID(route)}`,\n },\n betas: {\n key: ONYXKEYS.BETAS,\n },\n policies: {\n key: ONYXKEYS.COLLECTION.POLICY,\n },\n accountManagerReportID: {\n key: ONYXKEYS.ACCOUNT_MANAGER_REPORT_ID,\n },\n personalDetails: {\n key: ONYXKEYS.PERSONAL_DETAILS,\n },\n }),\n)(ReportScreen);\n","import _ from 'underscore';\nimport React from 'react';\nimport {View, Pressable} from 'react-native';\nimport PropTypes from 'prop-types';\nimport lodashGet from 'lodash/get';\nimport {withOnyx} from 'react-native-onyx';\nimport styles from '../../styles/styles';\nimport themeColors from '../../styles/themes/default';\nimport Icon from '../../components/Icon';\nimport * as Expensicons from '../../components/Icon/Expensicons';\nimport compose from '../../libs/compose';\nimport * as Report from '../../libs/actions/Report';\nimport withWindowDimensions, {windowDimensionsPropTypes} from '../../components/withWindowDimensions';\nimport MultipleAvatars from '../../components/MultipleAvatars';\nimport SubscriptAvatar from '../../components/SubscriptAvatar';\nimport DisplayNames from '../../components/DisplayNames';\nimport * as OptionsListUtils from '../../libs/OptionsListUtils';\nimport participantPropTypes from '../../components/participantPropTypes';\nimport VideoChatButtonAndMenu from '../../components/VideoChatButtonAndMenu';\nimport withLocalize, {withLocalizePropTypes} from '../../components/withLocalize';\nimport CONST from '../../CONST';\nimport * as ReportUtils from '../../libs/ReportUtils';\nimport Text from '../../components/Text';\nimport Tooltip from '../../components/Tooltip';\nimport variables from '../../styles/variables';\nimport colors from '../../styles/colors';\nimport reportPropTypes from '../reportPropTypes';\nimport ONYXKEYS from '../../ONYXKEYS';\n\nconst propTypes = {\n /** Toggles the navigationMenu open and closed */\n onNavigationMenuButtonClicked: PropTypes.func.isRequired,\n\n /* Onyx Props */\n\n /** The report currently being looked at */\n report: reportPropTypes,\n\n /** The policies which the user has access to and which the report could be tied to */\n policies: PropTypes.shape({\n /** Name of the policy */\n name: PropTypes.string,\n }),\n\n /** Personal details of all the users */\n personalDetails: PropTypes.objectOf(participantPropTypes),\n\n /** The details about the account that the user is signing in with */\n account: PropTypes.shape({\n /** URL to the assigned guide's appointment booking calendar */\n guideCalendarLink: PropTypes.string,\n }),\n\n ...windowDimensionsPropTypes,\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n personalDetails: {},\n policies: {},\n report: null,\n account: {\n guideCalendarLink: null,\n },\n};\n\nconst HeaderView = (props) => {\n const participants = lodashGet(props.report, 'participants', []);\n const participantPersonalDetails = OptionsListUtils.getPersonalDetailsForLogins(participants, props.personalDetails);\n const isMultipleParticipant = participants.length > 1;\n const displayNamesWithTooltips = ReportUtils.getDisplayNamesWithTooltips(participantPersonalDetails, isMultipleParticipant);\n const isChatRoom = ReportUtils.isChatRoom(props.report);\n const isPolicyExpenseChat = ReportUtils.isPolicyExpenseChat(props.report);\n const title = ReportUtils.getReportName(props.report, props.policies);\n\n const subtitle = ReportUtils.getChatRoomSubtitle(props.report, props.policies);\n const isConcierge = participants.length === 1 && _.contains(participants, CONST.EMAIL.CONCIERGE);\n const isAutomatedExpensifyAccount = (participants.length === 1 && ReportUtils.hasAutomatedExpensifyEmails(participants));\n const guideCalendarLink = lodashGet(props.account, 'guideCalendarLink');\n\n // We hide the button when we are chatting with an automated Expensify account since it's not possible to contact\n // these users via alternative means. It is possible to request a call with Concierge so we leave the option for them.\n const shouldShowCallButton = (isConcierge && guideCalendarLink) || !isAutomatedExpensifyAccount;\n const avatarTooltip = isChatRoom ? undefined : _.pluck(displayNamesWithTooltips, 'tooltip');\n const shouldShowSubscript = isPolicyExpenseChat && !props.report.isOwnPolicyExpenseChat && !ReportUtils.isArchivedRoom(props.report);\n const icons = ReportUtils.getIcons(props.report, props.personalDetails, props.policies);\n const brickRoadIndicator = ReportUtils.hasReportNameError(props.report) ? CONST.BRICK_ROAD_INDICATOR_STATUS.ERROR : '';\n return (\n \n \n {props.isSmallScreenWidth && (\n \n \n \n \n \n )}\n {Boolean(props.report && title) && (\n \n ReportUtils.navigateToDetailsPage(props.report)}\n style={[styles.flexRow, styles.alignItemsCenter, styles.flex1]}\n >\n {shouldShowSubscript ? (\n \n ) : (\n \n )}\n \n \n {(isChatRoom || isPolicyExpenseChat) && (\n \n {subtitle}\n \n )}\n \n {brickRoadIndicator === CONST.BRICK_ROAD_INDICATOR_STATUS.ERROR && (\n \n \n \n )}\n \n \n {shouldShowCallButton && }\n \n Report.togglePinnedState(props.report)}\n style={[styles.touchableButtonImage]}\n >\n \n \n \n \n \n )}\n \n \n );\n};\nHeaderView.propTypes = propTypes;\nHeaderView.displayName = 'HeaderView';\nHeaderView.defaultProps = defaultProps;\n\nexport default compose(\n withWindowDimensions,\n withLocalize,\n withOnyx({\n account: {\n key: ONYXKEYS.ACCOUNT,\n selector: account => account && ({guideCalendarLink: account.guideCalendarLink}),\n },\n }),\n)(HeaderView);\n","import React from 'react';\nimport CONST from '../../CONST';\nimport {propTypes, defaultProps} from './videoChatButtonAndMenuPropTypes';\nimport BaseVideoChatButtonAndMenu from './BaseVideoChatButtonAndMenu';\n\nconst VideoChatButtonAndMenu = props => (\n \n);\n\nVideoChatButtonAndMenu.propTypes = propTypes;\nVideoChatButtonAndMenu.defaultProps = defaultProps;\nVideoChatButtonAndMenu.displayName = 'VideoChatButtonAndMenu';\nexport default VideoChatButtonAndMenu;\n","import _ from 'underscore';\nimport React, {Component} from 'react';\nimport {\n View, Pressable, Dimensions, Linking,\n} from 'react-native';\nimport PropTypes from 'prop-types';\nimport Icon from '../Icon';\nimport * as Expensicons from '../Icon/Expensicons';\nimport Popover from '../Popover';\nimport MenuItem from '../MenuItem';\nimport ZoomIcon from '../../../assets/images/zoom-icon.svg';\nimport GoogleMeetIcon from '../../../assets/images/google-meet.svg';\nimport CONST from '../../CONST';\nimport styles from '../../styles/styles';\nimport themeColors from '../../styles/themes/default';\nimport withWindowDimensions, {windowDimensionsPropTypes} from '../withWindowDimensions';\nimport withLocalize, {withLocalizePropTypes} from '../withLocalize';\nimport compose from '../../libs/compose';\nimport Tooltip from '../Tooltip';\nimport {propTypes as videoChatButtonAndMenuPropTypes, defaultProps} from './videoChatButtonAndMenuPropTypes';\n\nconst propTypes = {\n /** Link to open when user wants to create a new google meet meeting */\n googleMeetURL: PropTypes.string.isRequired,\n\n ...videoChatButtonAndMenuPropTypes,\n ...withLocalizePropTypes,\n ...windowDimensionsPropTypes,\n};\n\nclass BaseVideoChatButtonAndMenu extends Component {\n constructor(props) {\n super(props);\n\n this.dimensionsEventListener = null;\n\n this.measureVideoChatIconPosition = this.measureVideoChatIconPosition.bind(this);\n this.videoChatIconWrapper = null;\n this.menuItemData = [\n {\n icon: ZoomIcon,\n text: props.translate('videoChatButtonAndMenu.zoom'),\n onPress: () => {\n this.setMenuVisibility(false);\n Linking.openURL(CONST.NEW_ZOOM_MEETING_URL);\n },\n },\n {\n icon: GoogleMeetIcon,\n text: props.translate('videoChatButtonAndMenu.googleMeet'),\n onPress: () => {\n this.setMenuVisibility(false);\n Linking.openURL(this.props.googleMeetURL);\n },\n },\n ];\n\n this.state = {\n isVideoChatMenuActive: false,\n videoChatIconPosition: {x: 0, y: 0},\n };\n }\n\n componentDidMount() {\n this.dimensionsEventListener = Dimensions.addEventListener('change', this.measureVideoChatIconPosition);\n }\n\n componentWillUnmount() {\n if (!this.dimensionsEventListener) {\n return;\n }\n this.dimensionsEventListener.remove();\n }\n\n /**\n * Set the state variable isVideoChatMenuActive\n * @param {Boolean} isVideoChatMenuActive\n */\n setMenuVisibility(isVideoChatMenuActive) {\n this.setState({isVideoChatMenuActive});\n }\n\n /**\n * This gets called onLayout to find the cooridnates of the wrapper for the video chat button.\n */\n measureVideoChatIconPosition() {\n if (!this.videoChatIconWrapper) {\n return;\n }\n\n this.videoChatIconWrapper.measureInWindow((x, y) => this.setState({\n videoChatIconPosition: {x, y},\n }));\n }\n\n render() {\n return (\n <>\n this.videoChatIconWrapper = el}\n onLayout={this.measureVideoChatIconPosition}\n >\n \n this.videoChatButton = el}\n onPress={() => {\n // Drop focus to avoid blue focus ring.\n this.videoChatButton.blur();\n\n // If this is the Concierge chat, we'll open the modal for requesting a setup call instead\n if (this.props.isConcierge && this.props.guideCalendarLink) {\n Linking.openURL(this.props.guideCalendarLink);\n return;\n }\n this.setMenuVisibility(true);\n }}\n style={[styles.touchableButtonImage]}\n >\n \n \n \n \n this.setMenuVisibility(false)}\n isVisible={this.state.isVideoChatMenuActive}\n anchorPosition={{\n left: this.state.videoChatIconPosition.x - 150,\n top: this.state.videoChatIconPosition.y + 40,\n }}\n >\n {_.map(this.menuItemData, ({icon, text, onPress}) => (\n \n ))}\n \n \n );\n }\n}\n\nBaseVideoChatButtonAndMenu.propTypes = propTypes;\nBaseVideoChatButtonAndMenu.defaultProps = defaultProps;\n\nexport default compose(\n withWindowDimensions,\n withLocalize,\n)(BaseVideoChatButtonAndMenu);\n","","","import PropTypes from 'prop-types';\n\nconst propTypes = {\n /** If this is the Concierge chat, we'll open the modal for requesting a setup call instead of showing popover menu */\n isConcierge: PropTypes.bool,\n\n /** URL to the assigned guide's appointment booking calendar */\n guideCalendarLink: PropTypes.string,\n};\n\nconst defaultProps = {\n isConcierge: false,\n guideCalendarLink: null,\n};\n\nexport {propTypes, defaultProps};\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport _ from 'underscore';\nimport lodashGet from 'lodash/get';\nimport * as Report from '../../../libs/actions/Report';\nimport reportActionPropTypes from './reportActionPropTypes';\nimport Visibility from '../../../libs/Visibility';\nimport Timing from '../../../libs/actions/Timing';\nimport CONST from '../../../CONST';\nimport compose from '../../../libs/compose';\nimport withWindowDimensions, {windowDimensionsPropTypes} from '../../../components/withWindowDimensions';\nimport {withDrawerPropTypes} from '../../../components/withDrawerState';\nimport * as ReportScrollManager from '../../../libs/ReportScrollManager';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport Performance from '../../../libs/Performance';\nimport {withNetwork} from '../../../components/OnyxProvider';\nimport FloatingMessageCounter from './FloatingMessageCounter';\nimport networkPropTypes from '../../../components/networkPropTypes';\nimport ReportActionsList from './ReportActionsList';\nimport CopySelectionHelper from '../../../components/CopySelectionHelper';\nimport * as ReportActionsUtils from '../../../libs/ReportActionsUtils';\nimport * as ReportUtils from '../../../libs/ReportUtils';\nimport reportPropTypes from '../../reportPropTypes';\nimport getIsReportFullyVisible from '../../../libs/getIsReportFullyVisible';\n\nconst propTypes = {\n /** The report currently being looked at */\n report: reportPropTypes.isRequired,\n\n /** Array of report actions for this report */\n reportActions: PropTypes.arrayOf(PropTypes.shape(reportActionPropTypes)),\n\n /** Whether the composer is full size */\n isComposerFullSize: PropTypes.bool.isRequired,\n\n /** Information about the network */\n network: networkPropTypes.isRequired,\n\n ...windowDimensionsPropTypes,\n ...withDrawerPropTypes,\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n reportActions: [],\n};\n\nclass ReportActionsView extends React.Component {\n constructor(props) {\n super(props);\n\n this.didLayout = false;\n this.didSubscribeToReportTypingEvents = false;\n this.unsubscribeVisibilityListener = null;\n this.hasCachedActions = _.size(props.reportActions) > 0;\n\n this.state = {\n isFloatingMessageCounterVisible: false,\n newMarkerReportActionID: ReportUtils.getNewMarkerReportActionID(this.props.report, props.reportActions),\n };\n\n this.currentScrollOffset = 0;\n this.mostRecentIOUReportActionID = ReportActionsUtils.getMostRecentIOURequestActionID(props.reportActions);\n this.trackScroll = this.trackScroll.bind(this);\n this.toggleFloatingMessageCounter = this.toggleFloatingMessageCounter.bind(this);\n this.loadMoreChats = this.loadMoreChats.bind(this);\n this.recordTimeToMeasureItemLayout = this.recordTimeToMeasureItemLayout.bind(this);\n this.scrollToBottomAndMarkReportAsRead = this.scrollToBottomAndMarkReportAsRead.bind(this);\n this.openReportIfNecessary = this.openReportIfNecessary.bind(this);\n }\n\n componentDidMount() {\n this.unsubscribeVisibilityListener = Visibility.onVisibilityChange(() => {\n if (!this.isReportFullyVisible()) {\n return;\n }\n\n // If the app user becomes active and they have no unread actions we clear the new marker to sync their device\n // e.g. they could have read these messages on another device and only just become active here\n const hasUnreadActions = ReportUtils.isUnread(this.props.report);\n if (!hasUnreadActions) {\n this.setState({newMarkerReportActionID: ''});\n }\n });\n\n if (this.isReportFullyVisible()) {\n this.openReportIfNecessary();\n }\n\n // This callback is triggered when a new action arrives via Pusher and the event is emitted from Report.js. This allows us to maintain\n // a single source of truth for the \"new action\" event instead of trying to derive that a new action has appeared from looking at props.\n this.unsubscribeFromNewActionEvent = Report.subscribeToNewActionEvent(this.props.report.reportID, (isFromCurrentUser, newActionID) => {\n const isNewMarkerReportActionIDSet = !_.isEmpty(this.state.newMarkerReportActionID);\n\n // If a new comment is added and it's from the current user scroll to the bottom otherwise leave the user positioned where\n // they are now in the list.\n if (isFromCurrentUser) {\n ReportScrollManager.scrollToBottom();\n\n // If the current user sends a new message in the chat we clear the new marker since they have \"read\" the report\n this.setState({newMarkerReportActionID: ''});\n } else if (this.isReportFullyVisible()) {\n // We use the scroll position to determine whether the report should be marked as read and the new line indicator reset.\n // If the user is scrolled up and no new line marker is set we will set it otherwise we will do nothing so the new marker\n // stays in it's previous position.\n if (this.currentScrollOffset === 0) {\n Report.readNewestAction(this.props.report.reportID);\n this.setState({newMarkerReportActionID: ''});\n } else if (!isNewMarkerReportActionIDSet) {\n this.setState({newMarkerReportActionID: newActionID});\n }\n } else if (!isNewMarkerReportActionIDSet) {\n // The report is not in view and we received a comment from another user while the new marker is not set\n // so we will set the new marker now.\n this.setState({newMarkerReportActionID: newActionID});\n }\n });\n }\n\n shouldComponentUpdate(nextProps, nextState) {\n if (!_.isEqual(nextProps.reportActions, this.props.reportActions)) {\n this.mostRecentIOUReportActionID = ReportActionsUtils.getMostRecentIOURequestActionID(nextProps.reportActions);\n return true;\n }\n\n if (lodashGet(nextProps.network, 'isOffline') !== lodashGet(this.props.network, 'isOffline')) {\n return true;\n }\n\n if (nextProps.report.isLoadingMoreReportActions !== this.props.report.isLoadingMoreReportActions) {\n return true;\n }\n\n if (nextProps.report.isLoadingReportActions !== this.props.report.isLoadingReportActions) {\n return true;\n }\n\n if (nextProps.report.lastReadTime !== this.props.report.lastReadTime) {\n return true;\n }\n\n if (nextState.isFloatingMessageCounterVisible !== this.state.isFloatingMessageCounterVisible) {\n return true;\n }\n\n if (nextState.newMarkerReportActionID !== this.state.newMarkerReportActionID) {\n return true;\n }\n\n if (this.props.isSmallScreenWidth !== nextProps.isSmallScreenWidth) {\n return true;\n }\n\n if (this.props.isDrawerOpen !== nextProps.isDrawerOpen) {\n return true;\n }\n\n if (lodashGet(this.props.report, 'hasOutstandingIOU') !== lodashGet(nextProps.report, 'hasOutstandingIOU')) {\n return true;\n }\n\n if (this.props.isComposerFullSize !== nextProps.isComposerFullSize) {\n return true;\n }\n\n if (\n lodashGet(this.props.report, 'statusNum') !== lodashGet(nextProps.report, 'statusNum')\n || lodashGet(this.props.report, 'stateNum') !== lodashGet(nextProps.report, 'stateNum')\n ) {\n return true;\n }\n\n return !_.isEqual(lodashGet(this.props.report, 'icons', []), lodashGet(nextProps.report, 'icons', []));\n }\n\n componentDidUpdate(prevProps) {\n const isReportFullyVisible = this.isReportFullyVisible();\n\n // When returning from offline to online state we want to trigger a request to OpenReport which\n // will fetch the reportActions data and mark the report as read. If the report is not fully visible\n // then we call ReconnectToReport which only loads the reportActions data without marking the report as read.\n const wasNetworkChangeDetected = lodashGet(prevProps.network, 'isOffline') && !lodashGet(this.props.network, 'isOffline');\n if (wasNetworkChangeDetected) {\n if (isReportFullyVisible) {\n this.openReportIfNecessary();\n } else {\n Report.reconnect(this.props.report.reportID);\n }\n }\n\n // If the report was previously hidden by the side bar, or the view is expanded from mobile to desktop layout\n // we update the new marker position, mark the report as read, and fetch new report actions\n const didSidebarClose = prevProps.isDrawerOpen && !this.props.isDrawerOpen;\n const didScreenSizeIncrease = prevProps.isSmallScreenWidth && !this.props.isSmallScreenWidth;\n const didReportBecomeVisible = isReportFullyVisible && (didSidebarClose || didScreenSizeIncrease);\n if (didReportBecomeVisible) {\n this.setState({\n newMarkerReportActionID: ReportUtils.isUnread(this.props.report)\n ? ReportUtils.getNewMarkerReportActionID(this.props.report, this.props.reportActions)\n : '',\n });\n this.openReportIfNecessary();\n }\n\n // If the report is unread, we want to check if the number of actions has decreased. If so, then it seems that one of them was deleted. In this case, if the deleted action was the\n // one marking the unread point, we need to recalculate which action should be the unread marker.\n if (ReportUtils.isUnread(this.props.report) && prevProps.reportActions.length > this.props.reportActions.length) {\n this.setState({\n newMarkerReportActionID: ReportUtils.getNewMarkerReportActionID(this.props.report, this.props.reportActions),\n });\n }\n\n // When the user navigates to the LHN the ReportActionsView doesn't unmount and just remains hidden.\n // The next time we navigate to the same report (e.g. by swiping or tapping the LHN row) we want the new marker to clear.\n const didSidebarOpen = !prevProps.isDrawerOpen && this.props.isDrawerOpen;\n const didUserNavigateToSidebarAfterReadingReport = didSidebarOpen && !ReportUtils.isUnread(this.props.report);\n if (didUserNavigateToSidebarAfterReadingReport) {\n this.setState({newMarkerReportActionID: ''});\n }\n\n // Checks to see if a report comment has been manually \"marked as unread\". All other times when the lastReadTime\n // changes it will be because we marked the entire report as read.\n const didManuallyMarkReportAsUnread = (prevProps.report.lastReadTime !== this.props.report.lastReadTime)\n && ReportUtils.isUnread(this.props.report);\n if (didManuallyMarkReportAsUnread) {\n this.setState({newMarkerReportActionID: ReportUtils.getNewMarkerReportActionID(this.props.report, this.props.reportActions)});\n }\n\n // Ensures subscription event succeeds when the report/workspace room is created optimistically.\n // Check if the optimistic `OpenReport` or `AddWorkspaceRoom` has succeeded by confirming\n // any `pendingFields.createChat` or `pendingFields.addWorkspaceRoom` fields are set to null.\n // Existing reports created will have empty fields for `pendingFields`.\n const didCreateReportSuccessfully = !this.props.report.pendingFields\n || (!this.props.report.pendingFields.addWorkspaceRoom && !this.props.report.pendingFields.createChat);\n if (!this.didSubscribeToReportTypingEvents && didCreateReportSuccessfully) {\n Report.subscribeToReportTypingEvents(this.props.report.reportID);\n this.didSubscribeToReportTypingEvents = true;\n }\n }\n\n componentWillUnmount() {\n if (this.unsubscribeVisibilityListener) {\n this.unsubscribeVisibilityListener();\n }\n\n if (this.unsubscribeFromNewActionEvent) {\n this.unsubscribeFromNewActionEvent();\n }\n\n Report.unsubscribeFromReportChannel(this.props.report.reportID);\n }\n\n /**\n * @returns {Boolean}\n */\n isReportFullyVisible() {\n return getIsReportFullyVisible(this.props.isDrawerOpen, this.props.isSmallScreenWidth);\n }\n\n // If the report is optimistic (AKA not yet created) we don't need to call openReport again\n openReportIfNecessary() {\n if (this.props.report.isOptimisticReport) {\n return;\n }\n\n Report.openReport(this.props.report.reportID);\n }\n\n /**\n * Retrieves the next set of report actions for the chat once we are nearing the end of what we are currently\n * displaying.\n */\n loadMoreChats() {\n // Only fetch more if we are not already fetching so that we don't initiate duplicate requests.\n if (this.props.report.isLoadingMoreReportActions) {\n return;\n }\n\n const oldestReportAction = _.last(this.props.reportActions);\n\n // Don't load more chats if we're already at the beginning of the chat history\n if (oldestReportAction.actionName === CONST.REPORT.ACTIONS.TYPE.CREATED) {\n return;\n }\n\n // Retrieve the next REPORT.ACTIONS.LIMIT sized page of comments\n Report.readOldestAction(this.props.report.reportID, oldestReportAction.reportActionID);\n }\n\n scrollToBottomAndMarkReportAsRead() {\n ReportScrollManager.scrollToBottom();\n Report.readNewestAction(this.props.report.reportID);\n }\n\n /**\n * Show/hide the new floating message counter when user is scrolling back/forth in the history of messages.\n */\n toggleFloatingMessageCounter() {\n if (this.currentScrollOffset < -200 && !this.state.isFloatingMessageCounterVisible) {\n this.setState({isFloatingMessageCounterVisible: true});\n }\n\n if (this.currentScrollOffset > -200 && this.state.isFloatingMessageCounterVisible) {\n this.setState({isFloatingMessageCounterVisible: false});\n }\n }\n\n /**\n * keeps track of the Scroll offset of the main messages list\n *\n * @param {Object} {nativeEvent}\n */\n trackScroll({nativeEvent}) {\n this.currentScrollOffset = -nativeEvent.contentOffset.y;\n this.toggleFloatingMessageCounter();\n }\n\n /**\n * Runs when the FlatList finishes laying out\n */\n recordTimeToMeasureItemLayout() {\n if (this.didLayout) {\n return;\n }\n\n this.didLayout = true;\n Timing.end(CONST.TIMING.SWITCH_REPORT, this.hasCachedActions ? CONST.TIMING.WARM : CONST.TIMING.COLD);\n\n // Capture the init measurement only once not per each chat switch as the value gets overwritten\n if (!ReportActionsView.initMeasured) {\n Performance.markEnd(CONST.TIMING.REPORT_INITIAL_RENDER);\n ReportActionsView.initMeasured = true;\n } else {\n Performance.markEnd(CONST.TIMING.SWITCH_REPORT);\n }\n }\n\n render() {\n // Comments have not loaded at all yet do nothing\n if (!_.size(this.props.reportActions)) {\n return null;\n }\n return (\n <>\n \n \n \n \n );\n }\n}\n\nReportActionsView.propTypes = propTypes;\nReportActionsView.defaultProps = defaultProps;\n\nexport default compose(\n Performance.withRenderTrace({id: ' rendering'}),\n withWindowDimensions,\n withLocalize,\n withNetwork(),\n)(ReportActionsView);\n","import React, {PureComponent} from 'react';\nimport {Animated, View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport styles from '../../../../styles/styles';\nimport Button from '../../../../components/Button';\nimport Text from '../../../../components/Text';\nimport Icon from '../../../../components/Icon';\nimport * as Expensicons from '../../../../components/Icon/Expensicons';\nimport themeColors from '../../../../styles/themes/default';\nimport withLocalize, {withLocalizePropTypes} from '../../../../components/withLocalize';\nimport FloatingMessageCounterContainer from './FloatingMessageCounterContainer';\n\nconst propTypes = {\n /** Whether the New Messages indicator is active */\n isActive: PropTypes.bool,\n\n /** Callback to be called when user clicks the New Messages indicator */\n onClick: PropTypes.func,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n isActive: false,\n onClick: () => {},\n};\n\nconst MARKER_INACTIVE_TRANSLATE_Y = -40;\nconst MARKER_ACTIVE_TRANSLATE_Y = 10;\n\nclass FloatingMessageCounter extends PureComponent {\n constructor(props) {\n super(props);\n this.translateY = new Animated.Value(MARKER_INACTIVE_TRANSLATE_Y);\n this.show = this.show.bind(this);\n this.hide = this.hide.bind(this);\n }\n\n componentDidUpdate() {\n if (this.props.isActive) {\n this.show();\n } else {\n this.hide();\n }\n }\n\n show() {\n Animated.spring(this.translateY, {\n toValue: MARKER_ACTIVE_TRANSLATE_Y,\n duration: 80,\n useNativeDriver: true,\n }).start();\n }\n\n hide() {\n Animated.spring(this.translateY, {\n toValue: MARKER_INACTIVE_TRANSLATE_Y,\n duration: 80,\n useNativeDriver: true,\n }).start();\n }\n\n render() {\n return (\n \n \n \n (\n \n \n \n {this.props.translate('newMessages')}\n \n \n )}\n />\n \n \n \n );\n }\n}\n\nFloatingMessageCounter.propTypes = propTypes;\nFloatingMessageCounter.defaultProps = defaultProps;\n\nexport default withLocalize(FloatingMessageCounter);\n","import React from 'react';\nimport {Animated} from 'react-native';\nimport styles from '../../../../../styles/styles';\nimport floatingMessageCounterContainerPropTypes from './floatingMessageCounterContainerPropTypes';\n\nconst FloatingMessageCounterContainer = props => (\n \n {props.children}\n \n);\n\nFloatingMessageCounterContainer.propTypes = floatingMessageCounterContainerPropTypes;\nFloatingMessageCounterContainer.displayName = 'FloatingMessageCounterContainer';\n\nexport default FloatingMessageCounterContainer;\n","import PropTypes from 'prop-types';\n\nconst propTypes = {\n /** Styles to be assigned to Container */\n containerStyles: PropTypes.arrayOf(PropTypes.object).isRequired,\n\n /** Rendered child component */\n children: PropTypes.element.isRequired,\n};\n\nexport default propTypes;\n","import PropTypes from 'prop-types';\nimport React, {useCallback, useEffect, useState} from 'react';\nimport Animated, {useSharedValue, useAnimatedStyle, withTiming} from 'react-native-reanimated';\nimport _ from 'underscore';\nimport InvertedFlatList from '../../../components/InvertedFlatList';\nimport withDrawerState, {withDrawerPropTypes} from '../../../components/withDrawerState';\nimport compose from '../../../libs/compose';\nimport * as ReportScrollManager from '../../../libs/ReportScrollManager';\nimport styles from '../../../styles/styles';\nimport * as ReportUtils from '../../../libs/ReportUtils';\nimport withWindowDimensions, {windowDimensionsPropTypes} from '../../../components/withWindowDimensions';\nimport {withNetwork, withPersonalDetails} from '../../../components/OnyxProvider';\nimport ReportActionItem from './ReportActionItem';\nimport ReportActionsSkeletonView from '../../../components/ReportActionsSkeletonView';\nimport variables from '../../../styles/variables';\nimport participantPropTypes from '../../../components/participantPropTypes';\nimport * as ReportActionsUtils from '../../../libs/ReportActionsUtils';\nimport reportActionPropTypes from './reportActionPropTypes';\nimport CONST from '../../../CONST';\nimport reportPropTypes from '../../reportPropTypes';\nimport networkPropTypes from '../../../components/networkPropTypes';\nimport withLocalize from '../../../components/withLocalize';\n\nconst propTypes = {\n /** Position of the \"New\" line marker */\n newMarkerReportActionID: PropTypes.string,\n\n /** Personal details of all the users */\n personalDetails: PropTypes.objectOf(participantPropTypes),\n\n /** The report currently being looked at */\n report: reportPropTypes.isRequired,\n\n /** Sorted actions prepared for display */\n sortedReportActions: PropTypes.arrayOf(PropTypes.shape(reportActionPropTypes)).isRequired,\n\n /** The ID of the most recent IOU report action connected with the shown report */\n mostRecentIOUReportActionID: PropTypes.string,\n\n /** Are we loading more report actions? */\n isLoadingMoreReportActions: PropTypes.bool,\n\n /** Callback executed on list layout */\n onLayout: PropTypes.func.isRequired,\n\n /** Callback executed on scroll */\n onScroll: PropTypes.func.isRequired,\n\n /** Function to load more chats */\n loadMoreChats: PropTypes.func.isRequired,\n\n /** Information about the network */\n network: networkPropTypes.isRequired,\n\n ...withDrawerPropTypes,\n ...windowDimensionsPropTypes,\n};\n\nconst defaultProps = {\n newMarkerReportActionID: '',\n personalDetails: {},\n mostRecentIOUReportActionID: '',\n isLoadingMoreReportActions: false,\n};\n\n/**\n * Create a unique key for each action in the FlatList.\n * We use the reportActionID that is a string representation of a random 64-bit int, which should be\n * random enough to avoid collisions\n * @param {Object} item\n * @param {Object} item.action\n * @return {String}\n */\nfunction keyExtractor(item) {\n return item.reportActionID;\n}\n\nconst ReportActionsList = (props) => {\n const opacity = useSharedValue(0);\n const animatedStyles = useAnimatedStyle(() => ({\n opacity: withTiming(opacity.value, {duration: 100}),\n }));\n useEffect(() => {\n opacity.value = 1;\n }, [opacity]);\n const [skeletonViewHeight, setSkeletonViewHeight] = useState(0);\n\n const windowHeight = props.windowHeight;\n\n /**\n * Calculates the ideal number of report actions to render in the first render, based on the screen height and on\n * the height of the smallest report action possible.\n * @return {Number}\n */\n const calculateInitialNumToRender = useCallback(() => {\n const minimumReportActionHeight = styles.chatItem.paddingTop + styles.chatItem.paddingBottom\n + variables.fontSizeNormalHeight;\n const availableHeight = windowHeight\n - (CONST.CHAT_FOOTER_MIN_HEIGHT + variables.contentHeaderHeight);\n return Math.ceil(availableHeight / minimumReportActionHeight);\n }, [windowHeight]);\n\n const report = props.report;\n const hasOutstandingIOU = props.report.hasOutstandingIOU;\n const newMarkerReportActionID = props.newMarkerReportActionID;\n const sortedReportActions = props.sortedReportActions;\n const mostRecentIOUReportActionID = props.mostRecentIOUReportActionID;\n\n /**\n * @param {Object} args\n * @param {Number} args.index\n * @returns {React.Component}\n */\n const renderItem = useCallback(({\n item: reportAction,\n index,\n }) => {\n // When the new indicator should not be displayed we explicitly set it to null\n const shouldDisplayNewMarker = reportAction.reportActionID === newMarkerReportActionID;\n return (\n \n );\n }, [report, hasOutstandingIOU, newMarkerReportActionID, sortedReportActions, mostRecentIOUReportActionID]);\n\n // Native mobile does not render updates flatlist the changes even though component did update called.\n // To notify there something changes we can use extraData prop to flatlist\n const extraData = (!props.isDrawerOpen && props.isSmallScreenWidth) ? props.newMarkerReportActionID : undefined;\n const shouldShowReportRecipientLocalTime = ReportUtils.canShowReportRecipientLocalTime(props.personalDetails, props.report);\n return (\n \n {\n if (props.report.isLoadingMoreReportActions) {\n return (\n \n );\n }\n\n // Make sure the oldest report action loaded is not the first. This is so we do not show the\n // skeleton view above the created action in a newly generated optimistic chat or one with not\n // that many comments.\n const lastReportAction = _.last(props.sortedReportActions) || {};\n if (props.report.isLoadingReportActions && lastReportAction.actionName !== CONST.REPORT.ACTIONS.TYPE.CREATED) {\n return (\n \n );\n }\n\n return null;\n }}\n keyboardShouldPersistTaps=\"handled\"\n onLayout={(event) => {\n setSkeletonViewHeight(event.nativeEvent.layout.height);\n props.onLayout(event);\n }}\n onScroll={props.onScroll}\n extraData={extraData}\n />\n \n );\n};\n\nReportActionsList.propTypes = propTypes;\nReportActionsList.defaultProps = defaultProps;\nReportActionsList.displayName = 'ReportActionsList';\n\nexport default compose(\n withDrawerState,\n withWindowDimensions,\n withLocalize,\n withPersonalDetails(),\n withNetwork(),\n)(ReportActionsList);\n","import React, {forwardRef} from 'react';\nimport BaseInvertedFlatList from './BaseInvertedFlatList';\n\nexport default forwardRef((props, ref) => (\n \n));\n","/* eslint-disable react/jsx-props-no-multi-spaces */\nimport _ from 'underscore';\nimport React, {forwardRef, Component} from 'react';\nimport PropTypes from 'prop-types';\nimport {FlatList, View} from 'react-native';\nimport * as CollectionUtils from '../../libs/CollectionUtils';\n\nconst propTypes = {\n /** Same as FlatList can be any array of anything */\n // eslint-disable-next-line react/forbid-prop-types\n data: PropTypes.arrayOf(PropTypes.any),\n\n /** Same as FlatList although we wrap it in a measuring helper before passing to the actual FlatList component */\n renderItem: PropTypes.func.isRequired,\n\n /** This must be set to the minimum size of one of the renderItem rows. Web experiences issues when inaccurate. */\n initialRowHeight: PropTypes.number.isRequired,\n\n /** Passed via forwardRef so we can access the FlatList ref */\n innerRef: PropTypes.oneOfType([\n PropTypes.func,\n PropTypes.shape({current: PropTypes.instanceOf(FlatList)}),\n ]).isRequired,\n\n /** Should we measure these items and call getItemLayout? */\n shouldMeasureItems: PropTypes.bool,\n};\n\nconst defaultProps = {\n data: [],\n shouldMeasureItems: false,\n};\n\nclass BaseInvertedFlatList extends Component {\n constructor(props) {\n super(props);\n\n this.renderItem = this.renderItem.bind(this);\n this.getItemLayout = this.getItemLayout.bind(this);\n\n // Stores each item's computed height after it renders\n // once and is then referenced for the life of this component.\n // This is essential to getting FlatList inverted to work on web\n // and also enables more predictable scrolling on native platforms.\n this.sizeMap = {};\n }\n\n /**\n * Return default or previously cached height for\n * a renderItem row\n *\n * @param {*} data\n * @param {Number} index\n *\n * @return {Object}\n */\n getItemLayout(data, index) {\n const size = this.sizeMap[index];\n\n if (size) {\n return {\n length: size.length,\n offset: size.offset,\n index,\n };\n }\n\n // If we don't have a size yet means we haven't measured this\n // item yet. However, we can still calculate the offset by looking\n // at the last size we have recorded (if any)\n const lastMeasuredItem = CollectionUtils.lastItem(this.sizeMap);\n\n return {\n // We haven't measured this so we must return the minimum row height\n length: this.props.initialRowHeight,\n\n // Offset will either be based on the lastMeasuredItem or the index +\n // initialRowHeight since we can only assume that all previous items\n // have not yet been measured\n offset: _.isUndefined(lastMeasuredItem)\n ? this.props.initialRowHeight * index\n : lastMeasuredItem.offset + this.props.initialRowHeight,\n index,\n };\n }\n\n /**\n * Measure item and cache the returned length (a.k.a. height)\n *\n * @param {React.NativeSyntheticEvent} nativeEvent\n * @param {Number} index\n */\n measureItemLayout(nativeEvent, index) {\n const computedHeight = nativeEvent.layout.height;\n\n // We've already measured this item so we don't need to\n // measure it again.\n if (this.sizeMap[index]) {\n return;\n }\n\n const previousItem = this.sizeMap[index - 1] || {};\n\n // If there is no previousItem this can mean we haven't yet measured\n // the previous item or that we are at index 0 and there is no previousItem\n const previousLength = previousItem.length || 0;\n const previousOffset = previousItem.offset || 0;\n this.sizeMap[index] = {\n length: computedHeight,\n offset: previousLength + previousOffset,\n };\n }\n\n /**\n * Render item method wraps the prop renderItem to render in a\n * View component so we can attach an onLayout handler and\n * measure it when it renders.\n *\n * @param {Object} params\n * @param {Object} params.item\n * @param {Number} params.index\n *\n * @return {React.Component}\n */\n renderItem({item, index}) {\n if (this.props.shouldMeasureItems) {\n return (\n this.measureItemLayout(nativeEvent, index)}>\n {this.props.renderItem({item, index})}\n \n );\n }\n\n return this.props.renderItem({item, index});\n }\n\n render() {\n return (\n \n );\n }\n}\n\nBaseInvertedFlatList.propTypes = propTypes;\nBaseInvertedFlatList.defaultProps = defaultProps;\n\nexport default forwardRef((props, ref) => (\n // eslint-disable-next-line react/jsx-props-no-spreading\n \n));\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport {useDrawerStatus} from '@react-navigation/drawer';\nimport getComponentDisplayName from '../libs/getComponentDisplayName';\n\nconst withDrawerPropTypes = {\n isDrawerOpen: PropTypes.bool.isRequired,\n};\n\nexport default function withDrawerState(WrappedComponent) {\n const WithDrawerState = (props) => {\n const drawerStatus = useDrawerStatus();\n\n return (\n \n );\n };\n\n WithDrawerState.displayName = `withDrawerState(${getComponentDisplayName(WrappedComponent)})`;\n WithDrawerState.propTypes = {\n forwardedRef: PropTypes.oneOfType([\n PropTypes.func,\n PropTypes.shape({current: PropTypes.instanceOf(React.Component)}),\n ]),\n };\n WithDrawerState.defaultProps = {\n forwardedRef: undefined,\n };\n return React.forwardRef((props, ref) => (\n // eslint-disable-next-line react/jsx-props-no-spreading\n \n ));\n}\n\nexport {\n withDrawerPropTypes,\n};\n","/**\n * Navigators\n */\nexport { default as createDrawerNavigator } from './navigators/createDrawerNavigator';\n\n/**\n * Views\n */\nexport { default as DrawerContent } from './views/DrawerContent';\nexport { default as DrawerContentScrollView } from './views/DrawerContentScrollView';\nexport { default as DrawerItem } from './views/DrawerItem';\nexport { default as DrawerItemList } from './views/DrawerItemList';\nexport { default as DrawerToggleButton } from './views/DrawerToggleButton';\nexport { default as DrawerView } from './views/DrawerView';\n\n/**\n * Utilities\n */\nexport { default as DrawerGestureContext } from './utils/DrawerGestureContext';\nexport { default as DrawerProgressContext } from './utils/DrawerProgressContext';\nexport { default as getDrawerStatusFromState } from './utils/getDrawerStatusFromState';\nexport { default as useDrawerProgress } from './utils/useDrawerProgress';\nexport { default as useDrawerStatus } from './utils/useDrawerStatus';\n\n/**\n * Types\n */\nexport type {\n DrawerContentComponentProps,\n DrawerHeaderProps,\n DrawerNavigationEventMap,\n DrawerNavigationOptions,\n DrawerNavigationProp,\n DrawerScreenProps,\n} from './types';\n","import {\n createNavigatorFactory,\n DefaultNavigatorOptions,\n DrawerActionHelpers,\n DrawerNavigationState,\n DrawerRouter,\n DrawerRouterOptions,\n DrawerStatus,\n ParamListBase,\n useNavigationBuilder,\n} from '@react-navigation/native';\nimport * as React from 'react';\nimport warnOnce from 'warn-once';\n\nimport type {\n DrawerNavigationConfig,\n DrawerNavigationEventMap,\n DrawerNavigationOptions,\n} from '../types';\nimport DrawerView from '../views/DrawerView';\n\ntype Props = DefaultNavigatorOptions<\n ParamListBase,\n DrawerNavigationState,\n DrawerNavigationOptions,\n DrawerNavigationEventMap\n> &\n DrawerRouterOptions &\n DrawerNavigationConfig;\n\nfunction DrawerNavigator({\n id,\n initialRouteName,\n defaultStatus: customDefaultStatus,\n backBehavior,\n children,\n screenListeners,\n screenOptions,\n ...restWithDeprecated\n}: Props) {\n const {\n // @ts-expect-error: openByDefault is deprecated\n openByDefault,\n // @ts-expect-error: lazy is deprecated\n lazy,\n // @ts-expect-error: drawerContentOptions is deprecated\n drawerContentOptions,\n ...rest\n } = restWithDeprecated;\n\n let defaultScreenOptions: DrawerNavigationOptions = {};\n\n if (drawerContentOptions) {\n Object.assign(defaultScreenOptions, {\n drawerPosition: drawerContentOptions.drawerPosition,\n drawerType: drawerContentOptions.drawerType,\n swipeEdgeWidth: drawerContentOptions.edgeWidth,\n drawerHideStatusBarOnOpen: drawerContentOptions.hideStatusBar,\n keyboardDismissMode: drawerContentOptions.keyboardDismissMode,\n swipeMinDistance: drawerContentOptions.minSwipeDistance,\n overlayColor: drawerContentOptions.overlayColor,\n drawerStatusBarAnimation: drawerContentOptions.statusBarAnimation,\n gestureHandlerProps: drawerContentOptions.gestureHandlerProps,\n });\n\n (\n Object.keys(defaultScreenOptions) as (keyof DrawerNavigationOptions)[]\n ).forEach((key) => {\n if (defaultScreenOptions[key] === undefined) {\n // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n delete defaultScreenOptions[key];\n }\n });\n\n warnOnce(\n drawerContentOptions,\n `Drawer Navigator: 'drawerContentOptions' is deprecated. Migrate the options to 'screenOptions' instead.\\n\\nPlace the following in 'screenOptions' in your code to keep current behavior:\\n\\n${JSON.stringify(\n defaultScreenOptions,\n null,\n 2\n )}\\n\\nSee https://reactnavigation.org/docs/drawer-navigator#options for more details.`\n );\n }\n\n if (typeof lazy === 'boolean') {\n defaultScreenOptions.lazy = lazy;\n\n warnOnce(\n true,\n `Drawer Navigator: 'lazy' in props is deprecated. Move it to 'screenOptions' instead.\\n\\nSee https://reactnavigation.org/docs/drawer-navigator/#lazy for more details.`\n );\n }\n\n if (typeof openByDefault === 'boolean') {\n warnOnce(\n true,\n `Drawer Navigator: 'openByDefault' is deprecated. Use 'defaultStatus' and set it to 'open' or 'closed' instead.\\n\\nSee https://reactnavigation.org/docs/drawer-navigator/#defaultstatus for more details.`\n );\n }\n\n const defaultStatus: DrawerStatus =\n customDefaultStatus !== undefined\n ? customDefaultStatus\n : openByDefault\n ? 'open'\n : 'closed';\n\n const { state, descriptors, navigation, NavigationContent } =\n useNavigationBuilder<\n DrawerNavigationState,\n DrawerRouterOptions,\n DrawerActionHelpers,\n DrawerNavigationOptions,\n DrawerNavigationEventMap\n >(DrawerRouter, {\n id,\n initialRouteName,\n defaultStatus,\n backBehavior,\n children,\n screenListeners,\n screenOptions,\n defaultScreenOptions,\n });\n\n return (\n \n \n \n );\n}\n\nexport default createNavigatorFactory<\n DrawerNavigationState,\n DrawerNavigationOptions,\n DrawerNavigationEventMap,\n typeof DrawerNavigator\n>(DrawerNavigator);\n","import {\n getHeaderTitle,\n Header,\n SafeAreaProviderCompat,\n Screen,\n} from '@react-navigation/elements';\nimport {\n DrawerActions,\n DrawerNavigationState,\n DrawerStatus,\n ParamListBase,\n useTheme,\n} from '@react-navigation/native';\nimport * as React from 'react';\nimport {\n BackHandler,\n I18nManager,\n Platform,\n StyleSheet,\n View,\n} from 'react-native';\nimport * as Reanimated from 'react-native-reanimated';\nimport { useSafeAreaFrame } from 'react-native-safe-area-context';\n\nimport type {\n DrawerContentComponentProps,\n DrawerDescriptorMap,\n DrawerHeaderProps,\n DrawerNavigationConfig,\n DrawerNavigationHelpers,\n DrawerNavigationProp,\n DrawerProps,\n} from '../types';\nimport DrawerPositionContext from '../utils/DrawerPositionContext';\nimport DrawerStatusContext from '../utils/DrawerStatusContext';\nimport getDrawerStatusFromState from '../utils/getDrawerStatusFromState';\nimport DrawerContent from './DrawerContent';\nimport DrawerToggleButton from './DrawerToggleButton';\nimport { GestureHandlerRootView } from './GestureHandler';\nimport { MaybeScreen, MaybeScreenContainer } from './ScreenFallback';\n\ntype Props = DrawerNavigationConfig & {\n defaultStatus: DrawerStatus;\n state: DrawerNavigationState;\n navigation: DrawerNavigationHelpers;\n descriptors: DrawerDescriptorMap;\n};\n\nconst getDefaultDrawerWidth = ({\n height,\n width,\n}: {\n height: number;\n width: number;\n}) => {\n /*\n * Default drawer width is screen width - header height\n * with a max width of 280 on mobile and 320 on tablet\n * https://material.io/components/navigation-drawer\n */\n const smallerAxisSize = Math.min(height, width);\n const isLandscape = width > height;\n const isTablet = smallerAxisSize >= 600;\n const appBarHeight = Platform.OS === 'ios' ? (isLandscape ? 32 : 44) : 56;\n const maxWidth = isTablet ? 320 : 280;\n\n return Math.min(smallerAxisSize - appBarHeight, maxWidth);\n};\n\nconst GestureHandlerWrapper = GestureHandlerRootView ?? View;\n\nfunction DrawerViewBase({\n state,\n navigation,\n descriptors,\n defaultStatus,\n drawerContent = (props: DrawerContentComponentProps) => (\n \n ),\n detachInactiveScreens = Platform.OS === 'web' ||\n Platform.OS === 'android' ||\n Platform.OS === 'ios',\n // Reanimated 2 is not configured\n // @ts-expect-error: the type definitions are incomplete\n useLegacyImplementation = !Reanimated.isConfigured?.(),\n}: Props) {\n // Reanimated v3 dropped legacy v1 syntax\n const legacyImplemenationNotAvailable =\n require('react-native-reanimated').abs === undefined;\n\n if (useLegacyImplementation && legacyImplemenationNotAvailable) {\n throw new Error(\n 'The `useLegacyImplementation` prop is not available with Reanimated 3 as it no longer includes support for Reanimated 1 legacy API. Remove the `useLegacyImplementation` prop from `Drawer.Navigator` to be able to use it.'\n );\n }\n\n const Drawer: React.ComponentType = useLegacyImplementation\n ? require('./legacy/Drawer').default\n : require('./modern/Drawer').default;\n\n const focusedRouteKey = state.routes[state.index].key;\n const {\n drawerHideStatusBarOnOpen = false,\n drawerPosition = I18nManager.getConstants().isRTL ? 'right' : 'left',\n drawerStatusBarAnimation = 'slide',\n drawerStyle,\n drawerType = Platform.select({ ios: 'slide', default: 'front' }),\n gestureHandlerProps,\n keyboardDismissMode = 'on-drag',\n overlayColor = 'rgba(0, 0, 0, 0.5)',\n swipeEdgeWidth = 32,\n swipeEnabled = Platform.OS !== 'web' &&\n Platform.OS !== 'windows' &&\n Platform.OS !== 'macos',\n swipeMinDistance = 60,\n } = descriptors[focusedRouteKey].options;\n\n const [loaded, setLoaded] = React.useState([focusedRouteKey]);\n\n if (!loaded.includes(focusedRouteKey)) {\n setLoaded([...loaded, focusedRouteKey]);\n }\n\n const dimensions = useSafeAreaFrame();\n\n const { colors } = useTheme();\n\n const drawerStatus = getDrawerStatusFromState(state);\n\n const handleDrawerOpen = React.useCallback(() => {\n navigation.dispatch({\n ...DrawerActions.openDrawer(),\n target: state.key,\n });\n }, [navigation, state.key]);\n\n const handleDrawerClose = React.useCallback(() => {\n navigation.dispatch({\n ...DrawerActions.closeDrawer(),\n target: state.key,\n });\n }, [navigation, state.key]);\n\n React.useEffect(() => {\n if (drawerStatus === defaultStatus || drawerType === 'permanent') {\n return;\n }\n\n const handleHardwareBack = () => {\n // We shouldn't handle the back button if the parent screen isn't focused\n // This will avoid the drawer overriding event listeners from a focused screen\n if (!navigation.isFocused()) {\n return false;\n }\n\n if (defaultStatus === 'open') {\n handleDrawerOpen();\n } else {\n handleDrawerClose();\n }\n\n return true;\n };\n\n const handleEscape = (e: KeyboardEvent) => {\n if (e.key === 'Escape') {\n handleHardwareBack();\n }\n };\n\n // We only add the listeners when drawer opens\n // This way we can make sure that the listener is added as late as possible\n // This will make sure that our handler will run first when back button is pressed\n const subscription = BackHandler.addEventListener(\n 'hardwareBackPress',\n handleHardwareBack\n );\n\n if (Platform.OS === 'web') {\n document?.body?.addEventListener?.('keyup', handleEscape);\n }\n\n return () => {\n subscription.remove();\n\n if (Platform.OS === 'web') {\n document?.body?.removeEventListener?.('keyup', handleEscape);\n }\n };\n }, [\n defaultStatus,\n drawerStatus,\n drawerType,\n handleDrawerClose,\n handleDrawerOpen,\n navigation,\n ]);\n\n const renderDrawerContent = () => {\n return (\n \n {drawerContent({\n state: state,\n navigation: navigation,\n descriptors: descriptors,\n })}\n \n );\n };\n\n const renderSceneContent = () => {\n return (\n \n {state.routes.map((route, index) => {\n const descriptor = descriptors[route.key];\n const { lazy = true, unmountOnBlur } = descriptor.options;\n const isFocused = state.index === index;\n\n if (unmountOnBlur && !isFocused) {\n return null;\n }\n\n if (lazy && !loaded.includes(route.key) && !isFocused) {\n // Don't render a lazy screen if we've never navigated to it\n return null;\n }\n\n const {\n freezeOnBlur,\n header = ({ layout, options }: DrawerHeaderProps) => (\n )\n }\n />\n ),\n headerShown,\n headerStatusBarHeight,\n headerTransparent,\n sceneContainerStyle,\n } = descriptor.options;\n\n return (\n \n ,\n options: descriptor.options,\n })}\n style={sceneContainerStyle}\n >\n {descriptor.render()}\n \n \n );\n })}\n \n );\n };\n\n return (\n \n \n \n );\n}\n\nexport default function DrawerView({ navigation, ...rest }: Props) {\n return (\n \n \n \n \n \n );\n}\n\nconst styles = StyleSheet.create({\n content: {\n flex: 1,\n },\n});\n","import * as React from 'react';\n\nexport default React.createContext<'left' | 'right' | undefined>(undefined);\n","import type { DrawerStatus } from '@react-navigation/native';\nimport * as React from 'react';\n\nconst DrawerStatusContext = React.createContext(\n undefined\n);\n\nexport default DrawerStatusContext;\n","import type {\n DrawerNavigationState,\n DrawerStatus,\n ParamListBase,\n} from '@react-navigation/native';\n\nexport default function getDrawerStatusFromState(\n state: DrawerNavigationState\n): DrawerStatus {\n if (state.history == null) {\n throw new Error(\n \"Couldn't find the drawer status in the state object. Is it a valid state object of drawer navigator?\"\n );\n }\n\n const entry = state.history.find((it) => it.type === 'drawer') as\n | { type: 'drawer'; status: DrawerStatus }\n | undefined;\n\n return entry?.status ?? state.default ?? 'closed';\n}\n","import * as React from 'react';\n\nimport type { DrawerContentComponentProps } from '../types';\nimport DrawerContentScrollView from './DrawerContentScrollView';\nimport DrawerItemList from './DrawerItemList';\n\nexport default function DrawerContent({\n descriptors,\n state,\n ...rest\n}: DrawerContentComponentProps) {\n const focusedRoute = state.routes[state.index];\n const focusedDescriptor = descriptors[focusedRoute.key];\n const focusedOptions = focusedDescriptor.options;\n\n const { drawerContentStyle, drawerContentContainerStyle } = focusedOptions;\n\n return (\n \n \n \n );\n}\n","import * as React from 'react';\nimport {\n I18nManager,\n ScrollView,\n ScrollViewProps,\n StyleSheet,\n} from 'react-native';\nimport { useSafeAreaInsets } from 'react-native-safe-area-context';\n\nimport DrawerPositionContext from '../utils/DrawerPositionContext';\n\ntype Props = ScrollViewProps & {\n children: React.ReactNode;\n};\n\nfunction DrawerContentScrollView(\n { contentContainerStyle, style, children, ...rest }: Props,\n ref?: React.Ref\n) {\n const drawerPosition = React.useContext(DrawerPositionContext);\n const insets = useSafeAreaInsets();\n\n const isRight = I18nManager.getConstants().isRTL\n ? drawerPosition === 'left'\n : drawerPosition === 'right';\n\n return (\n \n {children}\n \n );\n}\n\nexport default React.forwardRef(DrawerContentScrollView);\n\nconst styles = StyleSheet.create({\n container: {\n flex: 1,\n },\n});\n","import {\n CommonActions,\n DrawerActions,\n DrawerNavigationState,\n ParamListBase,\n useLinkBuilder,\n} from '@react-navigation/native';\nimport * as React from 'react';\n\nimport type { DrawerDescriptorMap, DrawerNavigationHelpers } from '../types';\nimport DrawerItem from './DrawerItem';\n\ntype Props = {\n state: DrawerNavigationState;\n navigation: DrawerNavigationHelpers;\n descriptors: DrawerDescriptorMap;\n};\n\n/**\n * Component that renders the navigation list in the drawer.\n */\nexport default function DrawerItemList({\n state,\n navigation,\n descriptors,\n}: Props) {\n const buildLink = useLinkBuilder();\n\n const focusedRoute = state.routes[state.index];\n const focusedDescriptor = descriptors[focusedRoute.key];\n const focusedOptions = focusedDescriptor.options;\n\n const {\n drawerActiveTintColor,\n drawerInactiveTintColor,\n drawerActiveBackgroundColor,\n drawerInactiveBackgroundColor,\n } = focusedOptions;\n\n return state.routes.map((route, i) => {\n const focused = i === state.index;\n\n const onPress = () => {\n const event = navigation.emit({\n type: 'drawerItemPress',\n target: route.key,\n canPreventDefault: true,\n });\n\n if (!event.defaultPrevented) {\n navigation.dispatch({\n ...(focused\n ? DrawerActions.closeDrawer()\n : CommonActions.navigate({ name: route.name, merge: true })),\n target: state.key,\n });\n }\n };\n\n const {\n title,\n drawerLabel,\n drawerIcon,\n drawerLabelStyle,\n drawerItemStyle,\n drawerAllowFontScaling,\n } = descriptors[route.key].options;\n\n return (\n \n );\n }) as React.ReactNode as React.ReactElement;\n}\n","import { PlatformPressable } from '@react-navigation/elements';\nimport { Link, useTheme } from '@react-navigation/native';\nimport Color from 'color';\nimport * as React from 'react';\nimport {\n Platform,\n StyleProp,\n StyleSheet,\n Text,\n TextStyle,\n View,\n ViewStyle,\n} from 'react-native';\n\ntype Props = {\n /**\n * The label text of the item.\n */\n label:\n | string\n | ((props: { focused: boolean; color: string }) => React.ReactNode);\n /**\n * Icon to display for the `DrawerItem`.\n */\n icon?: (props: {\n focused: boolean;\n size: number;\n color: string;\n }) => React.ReactNode;\n /**\n * URL to use for the link to the tab.\n */\n to?: string;\n /**\n * Whether to highlight the drawer item as active.\n */\n focused?: boolean;\n /**\n * Function to execute on press.\n */\n onPress: () => void;\n /**\n * Color for the icon and label when the item is active.\n */\n activeTintColor?: string;\n /**\n * Color for the icon and label when the item is inactive.\n */\n inactiveTintColor?: string;\n /**\n * Background color for item when its active.\n */\n activeBackgroundColor?: string;\n /**\n * Background color for item when its inactive.\n */\n inactiveBackgroundColor?: string;\n /**\n * Color of the touchable effect on press.\n * Only supported on Android.\n *\n * @platform android\n */\n pressColor?: string;\n /**\n * Opacity of the touchable effect on press.\n * Only supported on iOS.\n *\n * @platform ios\n */\n pressOpacity?: number;\n /**\n * Style object for the label element.\n */\n labelStyle?: StyleProp;\n /**\n * Style object for the wrapper element.\n */\n style?: StyleProp;\n /**\n * Whether label font should scale to respect Text Size accessibility settings.\n */\n allowFontScaling?: boolean;\n};\n\nconst LinkPressable = ({\n children,\n style,\n onPress,\n onLongPress,\n onPressIn,\n onPressOut,\n to,\n accessibilityRole,\n ...rest\n}: Omit, 'style'> & {\n style: StyleProp;\n} & {\n to?: string;\n children: React.ReactNode;\n onPress?: () => void;\n}) => {\n if (Platform.OS === 'web' && to) {\n // React Native Web doesn't forward `onClick` if we use `TouchableWithoutFeedback`.\n // We need to use `onClick` to be able to prevent default browser handling of links.\n return (\n {\n if (\n !(e.metaKey || e.altKey || e.ctrlKey || e.shiftKey) && // ignore clicks with modifier keys\n (e.button == null || e.button === 0) // ignore everything but left clicks\n ) {\n e.preventDefault();\n onPress?.(e);\n }\n }}\n // types for PressableProps and TextProps are incompatible with each other by `null` so we\n // can't use {...rest} for these 3 props\n onLongPress={onLongPress ?? undefined}\n onPressIn={onPressIn ?? undefined}\n onPressOut={onPressOut ?? undefined}\n >\n {children}\n \n );\n } else {\n return (\n \n {children}\n \n );\n }\n};\n\n/**\n * A component used to show an action item with an icon and a label in a navigation drawer.\n */\nexport default function DrawerItem(props: Props) {\n const { colors } = useTheme();\n\n const {\n icon,\n label,\n labelStyle,\n to,\n focused = false,\n allowFontScaling,\n activeTintColor = colors.primary,\n inactiveTintColor = Color(colors.text).alpha(0.68).rgb().string(),\n activeBackgroundColor = Color(activeTintColor).alpha(0.12).rgb().string(),\n inactiveBackgroundColor = 'transparent',\n style,\n onPress,\n pressColor,\n pressOpacity,\n ...rest\n } = props;\n\n const { borderRadius = 4 } = StyleSheet.flatten(style || {});\n const color = focused ? activeTintColor : inactiveTintColor;\n const backgroundColor = focused\n ? activeBackgroundColor\n : inactiveBackgroundColor;\n\n const iconNode = icon ? icon({ size: 24, focused, color }) : null;\n\n return (\n \n \n \n {iconNode}\n \n {typeof label === 'string' ? (\n \n {label}\n \n ) : (\n label({ color, focused })\n )}\n \n \n \n \n );\n}\n\nconst styles = StyleSheet.create({\n container: {\n marginHorizontal: 10,\n marginVertical: 4,\n overflow: 'hidden',\n },\n wrapper: {\n flexDirection: 'row',\n alignItems: 'center',\n padding: 8,\n },\n label: {\n marginRight: 32,\n flex: 1,\n },\n button: {\n display: 'flex',\n },\n});\n","import { PlatformPressable } from '@react-navigation/elements';\nimport {\n DrawerActions,\n ParamListBase,\n useNavigation,\n} from '@react-navigation/native';\nimport * as React from 'react';\nimport { Image, Platform, StyleSheet } from 'react-native';\n\nimport type { DrawerNavigationProp } from '../types';\n\ntype Props = {\n accessibilityLabel?: string;\n pressColor?: string;\n pressOpacity?: number;\n tintColor?: string;\n};\n\nexport default function DrawerToggleButton({ tintColor, ...rest }: Props) {\n const navigation = useNavigation>();\n\n return (\n navigation.dispatch(DrawerActions.toggleDrawer())}\n style={styles.touchable}\n hitSlop={Platform.select({\n ios: undefined,\n default: { top: 16, right: 16, bottom: 16, left: 16 },\n })}\n >\n \n \n );\n}\n\nconst styles = StyleSheet.create({\n icon: {\n height: 24,\n width: 24,\n margin: 3,\n resizeMode: 'contain',\n },\n touchable: {\n marginHorizontal: 11,\n },\n});\n","","export * from './GestureHandlerNative';\n","import * as React from 'react';\nimport {\n PanGestureHandler as PanGestureHandlerNative,\n PanGestureHandlerProperties,\n} from 'react-native-gesture-handler';\n\nimport DrawerGestureContext from '../utils/DrawerGestureContext';\n\nexport function PanGestureHandler(props: PanGestureHandlerProperties) {\n const gestureRef = React.useRef(null);\n\n return (\n \n \n \n );\n}\n\nexport type { PanGestureHandlerGestureEvent } from 'react-native-gesture-handler';\nexport {\n GestureHandlerRootView,\n State as GestureState,\n TapGestureHandler,\n} from 'react-native-gesture-handler';\n","import * as React from 'react';\n\nexport default React.createContext | null>(null);\n","import * as React from 'react';\nimport {\n I18nManager,\n InteractionManager,\n Keyboard,\n LayoutChangeEvent,\n Platform,\n StatusBar,\n StyleSheet,\n View,\n} from 'react-native';\nimport Animated from 'react-native-reanimated';\n\nimport type { DrawerProps } from '../../types';\nimport DrawerProgressContext from '../../utils/DrawerProgressContext';\nimport { GestureState, PanGestureHandler } from '../GestureHandler';\nimport Overlay from './Overlay';\n\nconst {\n Clock,\n Value,\n onChange,\n clockRunning,\n startClock,\n stopClock,\n spring,\n abs,\n add,\n and,\n block,\n call,\n cond,\n divide,\n eq,\n event,\n greaterThan,\n lessThan,\n max,\n min,\n multiply,\n neq,\n or,\n set,\n sub,\n} = Animated;\n\nconst TRUE = 1;\nconst FALSE = 0;\nconst NOOP = 0;\nconst UNSET = -1;\n\nconst DIRECTION_LEFT = 1;\nconst DIRECTION_RIGHT = -1;\n\nconst SWIPE_DISTANCE_MINIMUM = 5;\n\nconst DEFAULT_DRAWER_WIDTH = '80%';\n\nconst SPRING_CONFIG = {\n stiffness: 1000,\n damping: 500,\n mass: 3,\n overshootClamping: true,\n restDisplacementThreshold: 0.01,\n restSpeedThreshold: 0.01,\n};\n\nconst ANIMATED_ZERO = new Animated.Value(0);\nconst ANIMATED_ONE = new Animated.Value(1);\n\ntype Binary = 0 | 1;\n\nexport default class DrawerView extends React.Component {\n componentDidUpdate(prevProps: DrawerProps) {\n const {\n open,\n drawerPosition,\n drawerType,\n swipeDistanceThreshold,\n swipeVelocityThreshold,\n hideStatusBarOnOpen: hideStatusBar,\n } = this.props;\n\n if (\n // If we're not in the middle of a transition, sync the drawer's open state\n typeof this.pendingOpenValue !== 'boolean' ||\n open !== this.pendingOpenValue\n ) {\n this.toggleDrawer(open);\n }\n\n this.pendingOpenValue = undefined;\n\n if (open !== prevProps.open && hideStatusBar) {\n this.toggleStatusBar(open);\n }\n\n if (prevProps.drawerPosition !== drawerPosition) {\n this.drawerPosition.setValue(\n drawerPosition === 'right' ? DIRECTION_RIGHT : DIRECTION_LEFT\n );\n }\n\n if (prevProps.drawerType !== drawerType) {\n this.isDrawerTypeFront.setValue(drawerType === 'front' ? TRUE : FALSE);\n }\n\n if (prevProps.swipeDistanceThreshold !== swipeDistanceThreshold) {\n this.swipeDistanceThreshold.setValue(swipeDistanceThreshold);\n }\n\n if (prevProps.swipeVelocityThreshold !== swipeVelocityThreshold) {\n this.swipeVelocityThreshold.setValue(swipeVelocityThreshold);\n }\n }\n\n componentWillUnmount() {\n this.toggleStatusBar(false);\n this.handleEndInteraction();\n }\n\n private handleEndInteraction = () => {\n if (this.interactionHandle !== undefined) {\n InteractionManager.clearInteractionHandle(this.interactionHandle);\n this.interactionHandle = undefined;\n }\n };\n\n private handleStartInteraction = () => {\n if (this.interactionHandle === undefined) {\n this.interactionHandle = InteractionManager.createInteractionHandle();\n }\n };\n\n private getDrawerWidth = (): number => {\n const { drawerStyle, dimensions } = this.props;\n const { width = DEFAULT_DRAWER_WIDTH } =\n StyleSheet.flatten(drawerStyle) || {};\n\n if (typeof width === 'string' && width.endsWith('%')) {\n // Try to calculate width if a percentage is given\n const percentage = Number(width.replace(/%$/, ''));\n\n if (Number.isFinite(percentage)) {\n return dimensions.width * (percentage / 100);\n }\n }\n\n return typeof width === 'number' ? width : 0;\n };\n\n private clock = new Clock();\n private interactionHandle: number | undefined;\n\n private isDrawerTypeFront = new Value(\n this.props.drawerType === 'front' ? TRUE : FALSE\n );\n\n private isOpen = new Value(this.props.open ? TRUE : FALSE);\n private nextIsOpen = new Value(UNSET);\n private isSwiping = new Value(FALSE);\n\n private initialDrawerWidth = this.getDrawerWidth();\n\n private gestureState = new Value(GestureState.UNDETERMINED);\n private touchX = new Value(0);\n private velocityX = new Value(0);\n private gestureX = new Value(0);\n private offsetX = new Value(0);\n private position = new Value(\n this.props.open\n ? this.initialDrawerWidth *\n (this.props.drawerPosition === 'right'\n ? DIRECTION_RIGHT\n : DIRECTION_LEFT)\n : 0\n );\n\n private containerWidth = new Value(this.props.dimensions.width);\n private drawerWidth = new Value(this.initialDrawerWidth);\n private drawerOpacity = new Value(\n this.props.drawerType === 'permanent' ? 1 : 0\n );\n private drawerPosition = new Value(\n this.props.drawerPosition === 'right' ? DIRECTION_RIGHT : DIRECTION_LEFT\n );\n\n // Comment stolen from react-native-gesture-handler/DrawerLayout\n //\n // While closing the drawer when user starts gesture outside of its area (in greyed\n // out part of the window), we want the drawer to follow only once finger reaches the\n // edge of the drawer.\n // E.g. on the diagram below drawer is illustrate by X signs and the greyed out area by\n // dots. The touch gesture starts at '*' and moves left, touch path is indicated by\n // an arrow pointing left\n // 1) +---------------+ 2) +---------------+ 3) +---------------+ 4) +---------------+\n // |XXXXXXXX|......| |XXXXXXXX|......| |XXXXXXXX|......| |XXXXX|.........|\n // |XXXXXXXX|......| |XXXXXXXX|......| |XXXXXXXX|......| |XXXXX|.........|\n // |XXXXXXXX|......| |XXXXXXXX|......| |XXXXXXXX|......| |XXXXX|.........|\n // |XXXXXXXX|......| |XXXXXXXX|.<-*..| |XXXXXXXX|<--*..| |XXXXX|<-----*..|\n // |XXXXXXXX|......| |XXXXXXXX|......| |XXXXXXXX|......| |XXXXX|.........|\n // |XXXXXXXX|......| |XXXXXXXX|......| |XXXXXXXX|......| |XXXXX|.........|\n // |XXXXXXXX|......| |XXXXXXXX|......| |XXXXXXXX|......| |XXXXX|.........|\n // +---------------+ +---------------+ +---------------+ +---------------+\n //\n // For the above to work properly we define animated value that will keep start position\n // of the gesture. Then we use that value to calculate how much we need to subtract from\n // the dragX. If the gesture started on the greyed out area we take the distance from the\n // edge of the drawer to the start position. Otherwise we don't subtract at all and the\n // drawer be pulled back as soon as you start the pan.\n //\n // This is used only when drawerType is \"front\"\n private touchDistanceFromDrawer = cond(\n this.isDrawerTypeFront,\n cond(\n eq(this.drawerPosition, DIRECTION_LEFT),\n max(\n // Distance of touch start from left screen edge - Drawer width\n sub(sub(this.touchX, this.gestureX), this.drawerWidth),\n 0\n ),\n min(\n multiply(\n // Distance of drawer from left screen edge - Touch start point\n sub(\n sub(this.containerWidth, this.drawerWidth),\n sub(this.touchX, this.gestureX)\n ),\n DIRECTION_RIGHT\n ),\n 0\n )\n ),\n 0\n );\n\n private swipeDistanceThreshold = new Value(\n this.props.swipeDistanceThreshold\n );\n private swipeVelocityThreshold = new Value(\n this.props.swipeVelocityThreshold\n );\n\n private currentOpenValue: boolean = this.props.open;\n private pendingOpenValue: boolean | undefined;\n\n private isStatusBarHidden: boolean = false;\n\n private manuallyTriggerSpring = new Value(FALSE);\n\n private transitionTo = (isOpen: number | Animated.Node) => {\n const toValue = new Value(0);\n const frameTime = new Value(0);\n\n const state = {\n position: this.position,\n time: new Value(0),\n finished: new Value(FALSE),\n velocity: new Value(0),\n };\n\n return block([\n cond(clockRunning(this.clock), NOOP, [\n // Animation wasn't running before\n // Set the initial values and start the clock\n set(toValue, multiply(isOpen, this.drawerWidth, this.drawerPosition)),\n set(frameTime, 0),\n set(state.time, 0),\n set(state.finished, FALSE),\n set(state.velocity, this.velocityX),\n set(this.isOpen, isOpen),\n startClock(this.clock),\n call([], this.handleStartInteraction),\n set(this.manuallyTriggerSpring, FALSE),\n ]),\n spring(this.clock, state, { ...SPRING_CONFIG, toValue }),\n cond(state.finished, [\n // Reset gesture and velocity from previous gesture\n set(this.touchX, 0),\n set(this.gestureX, 0),\n set(this.velocityX, 0),\n set(this.offsetX, 0),\n // When the animation finishes, stop the clock\n stopClock(this.clock),\n call([this.isOpen], ([value]: readonly Binary[]) => {\n const open = Boolean(value);\n this.handleEndInteraction();\n\n if (open !== this.props.open) {\n // Sync drawer's state after animation finished\n // This shouldn't be necessary, but there seems to be an issue on iOS\n this.toggleDrawer(this.props.open);\n }\n }),\n ]),\n ]);\n };\n\n private dragX = block([\n onChange(\n this.isOpen,\n call([this.isOpen], ([value]: readonly Binary[]) => {\n const open = Boolean(value);\n\n this.currentOpenValue = open;\n\n // Without this check, the drawer can go to an infinite update <-> animate loop for sync updates\n if (open !== this.props.open) {\n // If the mode changed, update state\n if (open) {\n this.props.onOpen();\n } else {\n this.props.onClose();\n }\n\n this.pendingOpenValue = open;\n\n // Force componentDidUpdate to fire, whether user does a setState or not\n // This allows us to detect when the user drops the update and revert back\n // It's necessary to make sure that the state stays in sync\n this.forceUpdate();\n }\n })\n ),\n onChange(\n this.nextIsOpen,\n cond(neq(this.nextIsOpen, UNSET), [\n // Stop any running animations\n cond(clockRunning(this.clock), stopClock(this.clock)),\n // Update the open value to trigger the transition\n set(this.isOpen, this.nextIsOpen),\n set(this.gestureX, 0),\n set(this.nextIsOpen, UNSET),\n ])\n ),\n // This block must be after the this.isOpen listener since we check for current value\n onChange(\n this.isSwiping,\n // Listen to updates for this value only when it changes\n // Without `onChange`, this will fire even if the value didn't change\n // We don't want to call the listeners if the value didn't change\n call([this.isSwiping], ([value]: readonly Binary[]) => {\n const { keyboardDismissMode } = this.props;\n\n if (value === TRUE) {\n if (keyboardDismissMode === 'on-drag') {\n Keyboard.dismiss();\n }\n\n this.toggleStatusBar(true);\n } else {\n this.toggleStatusBar(this.currentOpenValue);\n }\n })\n ),\n onChange(\n this.gestureState,\n cond(\n eq(this.gestureState, GestureState.ACTIVE),\n call([], this.handleStartInteraction)\n )\n ),\n cond(\n eq(this.gestureState, GestureState.ACTIVE),\n [\n cond(this.isSwiping, NOOP, [\n // We weren't dragging before, set it to true\n set(this.isSwiping, TRUE),\n // Also update the drag offset to the last position\n set(this.offsetX, this.position),\n ]),\n // Update position with previous offset + gesture distance\n set(\n this.position,\n add(this.offsetX, this.gestureX, this.touchDistanceFromDrawer)\n ),\n // Stop animations while we're dragging\n stopClock(this.clock),\n ],\n [\n set(this.isSwiping, FALSE),\n set(this.touchX, 0),\n this.transitionTo(\n cond(\n this.manuallyTriggerSpring,\n this.isOpen,\n cond(\n or(\n and(\n greaterThan(abs(this.gestureX), SWIPE_DISTANCE_MINIMUM),\n greaterThan(abs(this.velocityX), this.swipeVelocityThreshold)\n ),\n greaterThan(abs(this.gestureX), this.swipeDistanceThreshold)\n ),\n cond(\n eq(this.drawerPosition, DIRECTION_LEFT),\n // If swiped to right, open the drawer, otherwise close it\n greaterThan(\n cond(eq(this.velocityX, 0), this.gestureX, this.velocityX),\n 0\n ),\n // If swiped to left, open the drawer, otherwise close it\n lessThan(\n cond(eq(this.velocityX, 0), this.gestureX, this.velocityX),\n 0\n )\n ),\n this.isOpen\n )\n )\n ),\n ]\n ),\n this.position,\n ]);\n\n private translateX = cond(\n eq(this.drawerPosition, DIRECTION_RIGHT),\n min(max(multiply(this.drawerWidth, -1), this.dragX), 0),\n max(min(this.drawerWidth, this.dragX), 0)\n );\n\n private progress = cond(\n // Check if the drawer width is available to avoid division by zero\n eq(this.drawerWidth, 0),\n 0,\n abs(divide(this.translateX, this.drawerWidth))\n );\n\n private handleGestureEvent = event([\n {\n nativeEvent: {\n x: this.touchX,\n translationX: this.gestureX,\n velocityX: this.velocityX,\n },\n },\n ]);\n\n private handleGestureStateChange = event([\n {\n nativeEvent: {\n state: (s: Animated.Value) => set(this.gestureState, s),\n },\n },\n ]);\n\n private handleContainerLayout = (e: LayoutChangeEvent) =>\n this.containerWidth.setValue(e.nativeEvent.layout.width);\n\n private handleDrawerLayout = (e: LayoutChangeEvent) => {\n this.drawerWidth.setValue(e.nativeEvent.layout.width);\n this.toggleDrawer(this.props.open);\n\n // Until layout is available, drawer is hidden with opacity: 0 by default\n // Show it in the next frame when layout is available\n // If we don't delay it until the next frame, there's a visible flicker\n requestAnimationFrame(() =>\n requestAnimationFrame(() => this.drawerOpacity.setValue(1))\n );\n };\n\n private toggleDrawer = (open: boolean) => {\n if (this.currentOpenValue !== open) {\n this.nextIsOpen.setValue(open ? TRUE : FALSE);\n\n // This value will also be set shortly after as changing this.nextIsOpen changes this.isOpen\n // However, there's a race condition on Android, so we need to set a bit earlier\n this.currentOpenValue = open;\n }\n };\n\n private toggleStatusBar = (hidden: boolean) => {\n const { hideStatusBarOnOpen: hideStatusBar, statusBarAnimation } =\n this.props;\n\n if (hideStatusBar && this.isStatusBarHidden !== hidden) {\n this.isStatusBarHidden = hidden;\n StatusBar.setHidden(hidden, statusBarAnimation);\n }\n };\n\n render() {\n const {\n open,\n swipeEnabled,\n drawerPosition,\n drawerType,\n swipeEdgeWidth,\n drawerStyle,\n overlayStyle,\n renderDrawerContent,\n renderSceneContent,\n gestureHandlerProps,\n } = this.props;\n\n const isOpen = drawerType === 'permanent' ? true : open;\n const isRight = drawerPosition === 'right';\n\n const contentTranslateX =\n drawerType === 'front' ? ANIMATED_ZERO : this.translateX;\n\n const drawerTranslateX =\n drawerType === 'back'\n ? I18nManager.getConstants().isRTL\n ? multiply(\n sub(this.containerWidth, this.drawerWidth),\n isRight ? 1 : -1\n )\n : ANIMATED_ZERO\n : this.translateX;\n\n const offset =\n drawerType === 'back'\n ? 0\n : I18nManager.getConstants().isRTL\n ? '100%'\n : multiply(this.drawerWidth, -1);\n\n // FIXME: Currently hitSlop is broken when on Android when drawer is on right\n // https://github.com/software-mansion/react-native-gesture-handler/issues/569\n const hitSlop = isRight\n ? // Extend hitSlop to the side of the screen when drawer is closed\n // This lets the user drag the drawer from the side of the screen\n { right: 0, width: isOpen ? undefined : swipeEdgeWidth }\n : { left: 0, width: isOpen ? undefined : swipeEdgeWidth };\n\n const progress = drawerType === 'permanent' ? ANIMATED_ONE : this.progress;\n\n return (\n \n \n \n \n \n {renderSceneContent()}\n \n {\n // Disable overlay if sidebar is permanent\n drawerType === 'permanent' ? null : (\n this.toggleDrawer(false)}\n style={overlayStyle as any}\n accessibilityElementsHidden={!isOpen}\n importantForAccessibility={\n isOpen ? 'auto' : 'no-hide-descendants'\n }\n />\n )\n }\n \n \n {drawerType === 'permanent' ? null : (\n (this.currentOpenValue = false)),\n ]),\n ]),\n ])}\n />\n )}\n \n {renderDrawerContent()}\n \n \n \n \n );\n }\n}\n\nconst styles = StyleSheet.create({\n container: {\n backgroundColor: 'white',\n maxWidth: '100%',\n },\n nonPermanent: {\n position: 'absolute',\n top: 0,\n bottom: 0,\n width: DEFAULT_DRAWER_WIDTH,\n },\n content: {\n flex: 1,\n },\n main: {\n flex: 1,\n ...Platform.select({\n // FIXME: We need to hide `overflowX` on Web so the translated content doesn't show offscreen.\n // But adding `overflowX: 'hidden'` prevents content from collapsing the URL bar.\n web: null,\n default: { overflow: 'hidden' },\n }),\n },\n});\n","import * as React from 'react';\nimport type Animated from 'react-native-reanimated';\n\nexport default React.createContext<\n Readonly> | Animated.Node | undefined\n>(undefined);\n","import * as React from 'react';\nimport { Platform, Pressable, StyleSheet } from 'react-native';\nimport Animated from 'react-native-reanimated';\n\nconst {\n // @ts-expect-error: this is to support reanimated 1\n interpolate: interpolateDeprecated,\n interpolateNode,\n cond,\n greaterThan,\n} = Animated;\n\nconst interpolate: typeof interpolateNode =\n interpolateNode ?? interpolateDeprecated;\n\nconst PROGRESS_EPSILON = 0.05;\n\ntype Props = React.ComponentProps & {\n progress: Animated.Node;\n onPress: () => void;\n};\n\nconst Overlay = React.forwardRef(function Overlay(\n { progress, onPress, style, ...props }: Props,\n ref: React.Ref\n) {\n const animatedStyle = {\n opacity: interpolate(progress, {\n // Default input range is [PROGRESS_EPSILON, 1]\n // On Windows, the output value is 1 when input value is out of range for some reason\n // The default value 0 will be interpolated to 1 in this case, which is not what we want.\n // Therefore changing input range on Windows to [0,1] instead.\n inputRange:\n Platform.OS === 'windows' || Platform.OS === 'macos'\n ? [0, 1]\n : [PROGRESS_EPSILON, 1],\n outputRange: [0, 1],\n }),\n // We don't want the user to be able to press through the overlay when drawer is open\n // One approach is to adjust the pointerEvents based on the progress\n // But we can also send the overlay behind the screen, which works, and is much less code\n zIndex: cond(greaterThan(progress, PROGRESS_EPSILON), 0, -1),\n };\n\n return (\n \n \n \n );\n});\n\nconst overlayStyle = Platform.select>({\n web: {\n // Disable touch highlight on mobile Safari.\n // WebkitTapHighlightColor must be used outside of StyleSheet.create because react-native-web will omit the property.\n WebkitTapHighlightColor: 'transparent',\n },\n default: {},\n});\n\nconst styles = StyleSheet.create({\n overlay: {\n ...StyleSheet.absoluteFillObject,\n backgroundColor: 'rgba(0, 0, 0, 0.5)',\n },\n pressable: {\n flex: 1,\n },\n});\n\nexport default Overlay;\n","import * as React from 'react';\nimport {\n I18nManager,\n InteractionManager,\n Keyboard,\n Platform,\n StatusBar,\n StyleSheet,\n View,\n} from 'react-native';\nimport {\n Gesture,\n GestureDetector,\n State as GestureState,\n} from 'react-native-gesture-handler';\nimport Animated, {\n interpolate,\n runOnJS,\n useAnimatedStyle,\n useDerivedValue,\n useSharedValue,\n withSpring,\n} from 'react-native-reanimated';\n\nimport type { DrawerProps } from '../../types';\nimport DrawerProgressContext from '../../utils/DrawerProgressContext';\nimport Overlay from './Overlay';\n\nconst SWIPE_DISTANCE_MINIMUM = 5;\nconst DEFAULT_DRAWER_WIDTH = '80%';\n\nconst minmax = (value: number, start: number, end: number) => {\n 'worklet';\n\n return Math.min(Math.max(value, start), end);\n};\n\nexport default function Drawer({\n dimensions,\n drawerPosition,\n drawerStyle,\n drawerType,\n gestureHandlerProps,\n hideStatusBarOnOpen,\n keyboardDismissMode,\n onClose,\n onOpen,\n open,\n overlayStyle,\n renderDrawerContent,\n renderSceneContent,\n statusBarAnimation,\n swipeDistanceThreshold,\n swipeEdgeWidth,\n swipeEnabled,\n swipeVelocityThreshold,\n}: DrawerProps) {\n const getDrawerWidth = (): number => {\n const { width = DEFAULT_DRAWER_WIDTH } =\n StyleSheet.flatten(drawerStyle) || {};\n\n if (typeof width === 'string' && width.endsWith('%')) {\n // Try to calculate width if a percentage is given\n const percentage = Number(width.replace(/%$/, ''));\n\n if (Number.isFinite(percentage)) {\n return dimensions.width * (percentage / 100);\n }\n }\n\n return typeof width === 'number' ? width : 0;\n };\n\n const drawerWidth = getDrawerWidth();\n\n const isOpen = drawerType === 'permanent' ? true : open;\n const isRight = drawerPosition === 'right';\n\n const getDrawerTranslationX = React.useCallback(\n (open: boolean) => {\n 'worklet';\n\n if (drawerPosition === 'left') {\n return open ? 0 : -drawerWidth;\n }\n\n return open ? 0 : drawerWidth;\n },\n [drawerPosition, drawerWidth]\n );\n\n const hideStatusBar = React.useCallback(\n (hide: boolean) => {\n if (hideStatusBarOnOpen) {\n StatusBar.setHidden(hide, statusBarAnimation);\n }\n },\n [hideStatusBarOnOpen, statusBarAnimation]\n );\n\n React.useEffect(() => {\n hideStatusBar(isOpen);\n\n return () => hideStatusBar(false);\n }, [isOpen, hideStatusBarOnOpen, statusBarAnimation, hideStatusBar]);\n\n const interactionHandleRef = React.useRef(null);\n\n const startInteraction = () => {\n interactionHandleRef.current = InteractionManager.createInteractionHandle();\n };\n\n const endInteraction = () => {\n if (interactionHandleRef.current != null) {\n InteractionManager.clearInteractionHandle(interactionHandleRef.current);\n interactionHandleRef.current = null;\n }\n };\n\n const hideKeyboard = () => {\n if (keyboardDismissMode === 'on-drag') {\n Keyboard.dismiss();\n }\n };\n\n const onGestureStart = () => {\n startInteraction();\n hideKeyboard();\n hideStatusBar(true);\n };\n\n const onGestureFinish = () => {\n endInteraction();\n };\n\n // FIXME: Currently hitSlop is broken when on Android when drawer is on right\n // https://github.com/software-mansion/react-native-gesture-handler/issues/569\n const hitSlop = isRight\n ? // Extend hitSlop to the side of the screen when drawer is closed\n // This lets the user drag the drawer from the side of the screen\n { right: 0, width: isOpen ? undefined : swipeEdgeWidth }\n : { left: 0, width: isOpen ? undefined : swipeEdgeWidth };\n\n const touchStartX = useSharedValue(0);\n const touchX = useSharedValue(0);\n const translationX = useSharedValue(getDrawerTranslationX(open));\n const gestureState = useSharedValue(GestureState.UNDETERMINED);\n\n const toggleDrawer = React.useCallback(\n (open: boolean, velocity?: number) => {\n 'worklet';\n\n const translateX = getDrawerTranslationX(open);\n\n touchStartX.value = 0;\n touchX.value = 0;\n translationX.value = withSpring(translateX, {\n velocity,\n stiffness: 1000,\n damping: 500,\n mass: 3,\n overshootClamping: true,\n restDisplacementThreshold: 0.01,\n restSpeedThreshold: 0.01,\n });\n\n if (open) {\n runOnJS(onOpen)();\n } else {\n runOnJS(onClose)();\n }\n },\n [getDrawerTranslationX, onClose, onOpen, touchStartX, touchX, translationX]\n );\n\n React.useEffect(() => toggleDrawer(open), [open, toggleDrawer]);\n\n const startX = useSharedValue(0);\n let panGesture = Gesture.Pan()\n .activeOffsetX([-SWIPE_DISTANCE_MINIMUM, SWIPE_DISTANCE_MINIMUM])\n .hitSlop(hitSlop)\n .enabled(drawerType !== 'permanent' && swipeEnabled)\n .onStart((event) => {\n startX.value = translationX.value;\n gestureState.value = event.state;\n touchStartX.value = event.x;\n\n runOnJS(onGestureStart)();\n })\n .onUpdate((event) => {\n touchX.value = event.x;\n translationX.value = startX.value + event.translationX;\n gestureState.value = event.state;\n })\n .onEnd((event) => {\n gestureState.value = event.state;\n\n const nextOpen =\n (Math.abs(event.translationX) > SWIPE_DISTANCE_MINIMUM &&\n Math.abs(event.translationX) > swipeVelocityThreshold) ||\n Math.abs(event.translationX) > swipeDistanceThreshold\n ? drawerPosition === 'left'\n ? // If swiped to right, open the drawer, otherwise close it\n (event.velocityX === 0 ? event.translationX : event.velocityX) > 0\n : // If swiped to left, open the drawer, otherwise close it\n (event.velocityX === 0 ? event.translationX : event.velocityX) < 0\n : open;\n\n toggleDrawer(nextOpen, event.velocityX);\n })\n .onFinalize(() => {\n runOnJS(onGestureFinish)();\n });\n // @ts-expect-error Ref types incompatible yet, needs to get fixed upstream\n panGesture.config = {\n ...panGesture.config,\n ...gestureHandlerProps,\n };\n\n const translateX = useDerivedValue(() => {\n // Comment stolen from react-native-gesture-handler/DrawerLayout\n //\n // While closing the drawer when user starts gesture outside of its area (in greyed\n // out part of the window), we want the drawer to follow only once finger reaches the\n // edge of the drawer.\n // E.g. on the diagram below drawer is illustrate by X signs and the greyed out area by\n // dots. The touch gesture starts at '*' and moves left, touch path is indicated by\n // an arrow pointing left\n // 1) +---------------+ 2) +---------------+ 3) +---------------+ 4) +---------------+\n // |XXXXXXXX|......| |XXXXXXXX|......| |XXXXXXXX|......| |XXXXX|.........|\n // |XXXXXXXX|......| |XXXXXXXX|......| |XXXXXXXX|......| |XXXXX|.........|\n // |XXXXXXXX|......| |XXXXXXXX|......| |XXXXXXXX|......| |XXXXX|.........|\n // |XXXXXXXX|......| |XXXXXXXX|.<-*..| |XXXXXXXX|<--*..| |XXXXX|<-----*..|\n // |XXXXXXXX|......| |XXXXXXXX|......| |XXXXXXXX|......| |XXXXX|.........|\n // |XXXXXXXX|......| |XXXXXXXX|......| |XXXXXXXX|......| |XXXXX|.........|\n // |XXXXXXXX|......| |XXXXXXXX|......| |XXXXXXXX|......| |XXXXX|.........|\n // +---------------+ +---------------+ +---------------+ +---------------+\n //\n // For the above to work properly we define animated value that will keep start position\n // of the gesture. Then we use that value to calculate how much we need to subtract from\n // the translationX. If the gesture started on the greyed out area we take the distance from the\n // edge of the drawer to the start position. Otherwise we don't subtract at all and the\n // drawer be pulled back as soon as you start the pan.\n //\n // This is used only when drawerType is \"front\"\n const touchDistance =\n drawerType === 'front' && gestureState.value === GestureState.ACTIVE\n ? minmax(\n drawerPosition === 'left'\n ? touchStartX.value - drawerWidth\n : dimensions.width - drawerWidth - touchStartX.value,\n 0,\n dimensions.width\n )\n : 0;\n\n const translateX =\n drawerPosition === 'left'\n ? minmax(translationX.value + touchDistance, -drawerWidth, 0)\n : minmax(translationX.value - touchDistance, 0, drawerWidth);\n\n return translateX;\n });\n\n const isRTL = I18nManager.getConstants().isRTL;\n const drawerAnimatedStyle = useAnimatedStyle(() => {\n const distanceFromEdge = dimensions.width - drawerWidth;\n\n return {\n transform:\n drawerType === 'permanent'\n ? // Reanimated needs the property to be present, but it results in Browser bug\n // https://bugs.chromium.org/p/chromium/issues/detail?id=20574\n []\n : [\n {\n translateX:\n // The drawer stays in place when `drawerType` is `back`\n (drawerType === 'back' ? 0 : translateX.value) +\n (drawerPosition === 'left'\n ? isRTL\n ? -distanceFromEdge\n : 0\n : isRTL\n ? 0\n : distanceFromEdge),\n },\n ],\n };\n });\n\n const contentAnimatedStyle = useAnimatedStyle(() => {\n return {\n transform:\n drawerType === 'permanent'\n ? // Reanimated needs the property to be present, but it results in Browser bug\n // https://bugs.chromium.org/p/chromium/issues/detail?id=20574\n []\n : [\n {\n translateX:\n // The screen content stays in place when `drawerType` is `front`\n drawerType === 'front'\n ? 0\n : translateX.value +\n drawerWidth * (drawerPosition === 'left' ? 1 : -1),\n },\n ],\n };\n });\n\n const progress = useDerivedValue(() => {\n return drawerType === 'permanent'\n ? 1\n : interpolate(\n translateX.value,\n [getDrawerTranslationX(false), getDrawerTranslationX(true)],\n [0, 1]\n );\n });\n\n return (\n \n \n {/* Immediate child of gesture handler needs to be an Animated.View */}\n \n \n \n {renderSceneContent()}\n \n {drawerType !== 'permanent' ? (\n toggleDrawer(false)}\n style={overlayStyle}\n />\n ) : null}\n \n \n {renderDrawerContent()}\n \n \n \n \n );\n}\n\nconst styles = StyleSheet.create({\n container: {\n top: 0,\n bottom: 0,\n maxWidth: '100%',\n width: DEFAULT_DRAWER_WIDTH,\n },\n content: {\n flex: 1,\n },\n main: {\n flex: 1,\n ...Platform.select({\n // FIXME: We need to hide `overflowX` on Web so the translated content doesn't show offscreen.\n // But adding `overflowX: 'hidden'` prevents content from collapsing the URL bar.\n web: null,\n default: { overflow: 'hidden' },\n }),\n },\n});\n","import * as React from 'react';\nimport { Platform, Pressable, StyleSheet } from 'react-native';\nimport Animated, {\n useAnimatedProps,\n useAnimatedStyle,\n} from 'react-native-reanimated';\n\nconst PROGRESS_EPSILON = 0.05;\n\ntype Props = React.ComponentProps & {\n progress: Animated.SharedValue;\n onPress: () => void;\n};\n\nconst Overlay = React.forwardRef(function Overlay(\n { progress, onPress, style, ...props }: Props,\n ref: React.Ref\n) {\n const animatedStyle = useAnimatedStyle(() => {\n return {\n opacity: progress.value,\n // We don't want the user to be able to press through the overlay when drawer is open\n // We can send the overlay behind the screen to avoid it\n zIndex: progress.value > PROGRESS_EPSILON ? 0 : -1,\n };\n });\n\n const animatedProps = useAnimatedProps(() => {\n const active = progress.value > PROGRESS_EPSILON;\n\n return {\n pointerEvents: active ? 'auto' : 'none',\n accessibilityElementsHidden: !active,\n importantForAccessibility: active ? 'auto' : 'no-hide-descendants',\n } as const;\n });\n\n return (\n \n \n \n );\n});\n\nconst overlayStyle = Platform.select>({\n web: {\n // Disable touch highlight on mobile Safari.\n // WebkitTapHighlightColor must be used outside of StyleSheet.create because react-native-web will omit the property.\n WebkitTapHighlightColor: 'transparent',\n },\n default: {},\n});\n\nconst styles = StyleSheet.create({\n overlay: {\n ...StyleSheet.absoluteFillObject,\n backgroundColor: 'rgba(0, 0, 0, 0.5)',\n },\n pressable: {\n flex: 1,\n },\n});\n\nexport default Overlay;\n","import { ResourceSavingView } from '@react-navigation/elements';\nimport * as React from 'react';\nimport { StyleProp, View, ViewProps, ViewStyle } from 'react-native';\n\ntype Props = {\n visible: boolean;\n children: React.ReactNode;\n enabled: boolean;\n freezeOnBlur?: boolean;\n style?: StyleProp;\n};\n\nlet Screens: typeof import('react-native-screens') | undefined;\n\ntry {\n Screens = require('react-native-screens');\n} catch (e) {\n // Ignore\n}\n\nexport const MaybeScreenContainer = ({\n enabled,\n ...rest\n}: ViewProps & {\n enabled: boolean;\n hasTwoStates: boolean;\n children: React.ReactNode;\n}) => {\n if (Screens?.screensEnabled?.()) {\n return ;\n }\n\n return ;\n};\n\nexport function MaybeScreen({ visible, children, ...rest }: Props) {\n if (Screens?.screensEnabled?.()) {\n return (\n \n {children}\n \n );\n }\n\n return (\n \n {children}\n \n );\n}\n","import * as React from 'react';\nimport type Animated from 'react-native-reanimated';\n\nimport DrawerProgressContext from './DrawerProgressContext';\n\nexport default function useDrawerProgress():\n | Readonly>\n | Animated.Node {\n const progress = React.useContext(DrawerProgressContext);\n\n if (progress === undefined) {\n throw new Error(\n \"Couldn't find a drawer. Is your component inside a drawer navigator?\"\n );\n }\n\n return progress;\n}\n","import type { DrawerStatus } from '@react-navigation/native';\nimport * as React from 'react';\n\nimport DrawerStatusContext from './DrawerStatusContext';\n\n/**\n * Hook to detect if the drawer's status in a parent navigator.\n * Returns 'open' if the drawer is open, 'closed' if the drawer is closed.\n */\nexport default function useDrawerStatus(): DrawerStatus {\n const drawerStatus = React.useContext(DrawerStatusContext);\n\n if (drawerStatus === undefined) {\n throw new Error(\n \"Couldn't find a drawer. Is your component inside a drawer navigator?\"\n );\n }\n\n return drawerStatus;\n}\n","import _ from 'underscore';\nimport lodashGet from 'lodash/get';\nimport React, {Component} from 'react';\nimport {View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport {withOnyx} from 'react-native-onyx';\nimport CONST from '../../../CONST';\nimport ONYXKEYS from '../../../ONYXKEYS';\nimport reportActionPropTypes from './reportActionPropTypes';\nimport * as StyleUtils from '../../../styles/StyleUtils';\nimport PressableWithSecondaryInteraction from '../../../components/PressableWithSecondaryInteraction';\nimport Hoverable from '../../../components/Hoverable';\nimport ReportActionItemSingle from './ReportActionItemSingle';\nimport ReportActionItemGrouped from './ReportActionItemGrouped';\nimport IOUAction from '../../../components/ReportActionItem/IOUAction';\nimport ReportActionItemMessage from './ReportActionItemMessage';\nimport UnreadActionIndicator from '../../../components/UnreadActionIndicator';\nimport ReportActionItemMessageEdit from './ReportActionItemMessageEdit';\nimport ReportActionItemCreated from './ReportActionItemCreated';\nimport compose from '../../../libs/compose';\nimport withWindowDimensions, {windowDimensionsPropTypes} from '../../../components/withWindowDimensions';\nimport ControlSelection from '../../../libs/ControlSelection';\nimport * as DeviceCapabilities from '../../../libs/DeviceCapabilities';\nimport MiniReportActionContextMenu from './ContextMenu/MiniReportActionContextMenu';\nimport * as ReportActionContextMenu from './ContextMenu/ReportActionContextMenu';\nimport * as ContextMenuActions from './ContextMenu/ContextMenuActions';\nimport {withBlockedFromConcierge, withNetwork, withReportActionsDrafts} from '../../../components/OnyxProvider';\nimport RenameAction from '../../../components/ReportActionItem/RenameAction';\nimport InlineSystemMessage from '../../../components/InlineSystemMessage';\nimport styles from '../../../styles/styles';\nimport SelectionScraper from '../../../libs/SelectionScraper';\nimport * as User from '../../../libs/actions/User';\nimport * as ReportUtils from '../../../libs/ReportUtils';\nimport OfflineWithFeedback from '../../../components/OfflineWithFeedback';\nimport * as ReportActions from '../../../libs/actions/ReportActions';\nimport reportPropTypes from '../../reportPropTypes';\nimport {ShowContextMenuContext} from '../../../components/ShowContextMenuContext';\nimport focusTextInputAfterAnimation from '../../../libs/focusTextInputAfterAnimation';\nimport ChronosOOOListActions from '../../../components/ReportActionItem/ChronosOOOListActions';\nimport ReportActionItemReactions from '../../../components/Reactions/ReportActionItemReactions';\nimport * as Report from '../../../libs/actions/Report';\nimport withLocalize from '../../../components/withLocalize';\n\nconst propTypes = {\n /** Report for this action */\n report: reportPropTypes.isRequired,\n\n /** All the data of the action item */\n action: PropTypes.shape(reportActionPropTypes).isRequired,\n\n /** Should the comment have the appearance of being grouped with the previous comment? */\n displayAsGroup: PropTypes.bool.isRequired,\n\n /** Is this the most recent IOU Action? */\n isMostRecentIOUReportAction: PropTypes.bool.isRequired,\n\n /** Whether there is an outstanding amount in IOU */\n hasOutstandingIOU: PropTypes.bool,\n\n /** Should we display the new marker on top of the comment? */\n shouldDisplayNewMarker: PropTypes.bool.isRequired,\n\n /** Position index of the report action in the overall report FlatList view */\n index: PropTypes.number.isRequired,\n\n /** Draft message - if this is set the comment is in 'edit' mode */\n draftMessage: PropTypes.string,\n\n /** Stores user's preferred skin tone */\n preferredSkinTone: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n\n ...windowDimensionsPropTypes,\n};\n\nconst defaultProps = {\n draftMessage: '',\n hasOutstandingIOU: false,\n preferredSkinTone: CONST.EMOJI_DEFAULT_SKIN_TONE,\n};\n\nclass ReportActionItem extends Component {\n constructor(props) {\n super(props);\n this.popoverAnchor = undefined;\n this.state = {\n isContextMenuActive: ReportActionContextMenu.isActiveReportAction(props.action.reportActionID),\n };\n this.checkIfContextMenuActive = this.checkIfContextMenuActive.bind(this);\n this.showPopover = this.showPopover.bind(this);\n this.renderItemContent = this.renderItemContent.bind(this);\n this.toggleReaction = this.toggleReaction.bind(this);\n }\n\n shouldComponentUpdate(nextProps, nextState) {\n return this.props.displayAsGroup !== nextProps.displayAsGroup\n || this.props.draftMessage !== nextProps.draftMessage\n || this.props.isMostRecentIOUReportAction !== nextProps.isMostRecentIOUReportAction\n || this.props.hasOutstandingIOU !== nextProps.hasOutstandingIOU\n || this.props.shouldDisplayNewMarker !== nextProps.shouldDisplayNewMarker\n || !_.isEqual(this.props.action, nextProps.action)\n || this.state.isContextMenuActive !== nextState.isContextMenuActive\n || lodashGet(this.props.report, 'statusNum') !== lodashGet(nextProps.report, 'statusNum')\n || lodashGet(this.props.report, 'stateNum') !== lodashGet(nextProps.report, 'stateNum');\n }\n\n componentDidUpdate(prevProps) {\n if (prevProps.draftMessage || !this.props.draftMessage) {\n return;\n }\n\n // Only focus the input when user edits a message, skip it for existing drafts being edited of the report.\n // There is an animation when the comment is hidden and the edit form is shown, and there can be bugs on different mobile platforms\n // if the input is given focus in the middle of that animation which can prevent the keyboard from opening.\n focusTextInputAfterAnimation(this.textInput, 100);\n }\n\n checkIfContextMenuActive() {\n this.setState({isContextMenuActive: ReportActionContextMenu.isActiveReportAction(this.props.action.reportActionID)});\n }\n\n /**\n * Show the ReportActionContextMenu modal popover.\n *\n * @param {Object} [event] - A press event.\n */\n showPopover(event) {\n // Block menu on the message being Edited\n if (this.props.draftMessage) {\n return;\n }\n\n this.setState({isContextMenuActive: true});\n\n const selection = SelectionScraper.getCurrentSelection();\n ReportActionContextMenu.showContextMenu(\n ContextMenuActions.CONTEXT_MENU_TYPES.REPORT_ACTION,\n event,\n selection,\n this.popoverAnchor,\n this.props.report.reportID,\n this.props.action,\n this.props.draftMessage,\n undefined,\n this.checkIfContextMenuActive,\n ReportUtils.isArchivedRoom(this.props.report),\n ReportUtils.chatIncludesChronos(this.props.report),\n );\n }\n\n toggleReaction(emoji) {\n Report.toggleEmojiReaction(this.props.report.reportID, this.props.action, emoji);\n }\n\n /**\n * Get the content of ReportActionItem\n * @param {Boolean} hovered whether the ReportActionItem is hovered\n * @returns {Object} child component(s)\n */\n renderItemContent(hovered = false) {\n let children;\n if (this.props.action.actionName === CONST.REPORT.ACTIONS.TYPE.IOU) {\n children = (\n \n );\n } else {\n const message = _.last(lodashGet(this.props.action, 'message', [{}]));\n const isAttachment = _.has(this.props.action, 'isAttachment')\n ? this.props.action.isAttachment\n : ReportUtils.isReportMessageAttachment(message);\n children = (\n \n {!this.props.draftMessage\n ? (\n \n ) : (\n this.textInput = el}\n report={this.props.report}\n\n // Avoid defining within component due to an existing Onyx bug\n preferredSkinTone={this.props.preferredSkinTone}\n shouldDisableEmojiPicker={\n (ReportUtils.chatIncludesConcierge(this.props.report) && User.isBlockedFromConcierge(this.props.blockedFromConcierge))\n || ReportUtils.isArchivedRoom(this.props.report)\n }\n />\n )}\n \n );\n }\n\n const reactions = _.get(this.props, ['action', 'message', 0, 'reactions'], []);\n const hasReactions = reactions.length > 0;\n\n return (\n <>\n {children}\n {hasReactions && (\n \n )}\n \n );\n }\n\n render() {\n if (this.props.action.actionName === CONST.REPORT.ACTIONS.TYPE.CREATED) {\n return ;\n }\n if (this.props.action.actionName === CONST.REPORT.ACTIONS.TYPE.RENAMED) {\n return ;\n }\n if (this.props.action.actionName === CONST.REPORT.ACTIONS.TYPE.CHRONOSOOOLIST) {\n return ;\n }\n return (\n this.popoverAnchor = el}\n onPressIn={() => this.props.isSmallScreenWidth && DeviceCapabilities.canUseTouchScreen() && ControlSelection.block()}\n onPressOut={() => ControlSelection.unblock()}\n onSecondaryInteraction={this.showPopover}\n preventDefaultContentMenu={!this.props.draftMessage}\n withoutFocusOnSecondaryInteraction\n >\n \n {hovered => (\n \n {this.props.shouldDisplayNewMarker && (\n \n )}\n \n {\n if (this.props.action.pendingAction === CONST.RED_BRICK_ROAD_PENDING_ACTION.ADD) {\n ReportActions.deleteOptimisticReportAction(this.props.report.reportID, this.props.action.reportActionID);\n } else {\n ReportActions.clearReportActionErrors(this.props.report.reportID, this.props.action.reportActionID);\n }\n }}\n pendingAction={this.props.draftMessage ? null : this.props.action.pendingAction}\n errors={this.props.action.errors}\n errorRowStyles={[styles.ml10, styles.mr2]}\n needsOffscreenAlphaCompositing={this.props.action.actionName === CONST.REPORT.ACTIONS.TYPE.IOU}\n >\n {!this.props.displayAsGroup\n ? (\n \n {this.renderItemContent(hovered || this.state.isContextMenuActive)}\n \n )\n : (\n \n {this.renderItemContent(hovered || this.state.isContextMenuActive)}\n \n )}\n \n \n \n \n )}\n \n \n \n \n \n );\n }\n}\nReportActionItem.propTypes = propTypes;\nReportActionItem.defaultProps = defaultProps;\n\nexport default compose(\n withWindowDimensions,\n withLocalize,\n withNetwork(),\n withBlockedFromConcierge({propName: 'blockedFromConcierge'}),\n withReportActionsDrafts({\n propName: 'draftMessage',\n transformValue: (drafts, props) => {\n const draftKey = `${ONYXKEYS.COLLECTION.REPORT_ACTIONS_DRAFTS}${props.report.reportID}_${props.action.reportActionID}`;\n return lodashGet(drafts, draftKey, '');\n },\n }),\n withOnyx({\n preferredSkinTone: {\n key: ONYXKEYS.PREFERRED_EMOJI_SKIN_TONE,\n },\n }),\n)(ReportActionItem);\n","import React from 'react';\nimport {View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport styles from '../../../styles/styles';\n\nconst propTypes = {\n /** Children view component for this action item */\n children: PropTypes.node.isRequired,\n};\n\nconst ReportActionItemGrouped = props => (\n \n \n {props.children}\n \n \n);\n\nReportActionItemGrouped.propTypes = propTypes;\nReportActionItemGrouped.displayName = 'ReportActionItemGrouped';\nexport default ReportActionItemGrouped;\n","import _ from 'underscore';\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport {withOnyx} from 'react-native-onyx';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport CONST from '../../CONST';\nimport {withNetwork} from '../OnyxProvider';\nimport compose from '../../libs/compose';\nimport IOUQuote from './IOUQuote';\nimport reportActionPropTypes from '../../pages/home/report/reportActionPropTypes';\nimport networkPropTypes from '../networkPropTypes';\nimport iouReportPropTypes from '../../pages/iouReportPropTypes';\nimport IOUPreview from './IOUPreview';\nimport Navigation from '../../libs/Navigation/Navigation';\nimport ROUTES from '../../ROUTES';\nimport styles from '../../styles/styles';\nimport * as IOUUtils from '../../libs/IOUUtils';\n\nconst propTypes = {\n /** All the data of the action */\n action: PropTypes.shape(reportActionPropTypes).isRequired,\n\n /** The ID of the associated chatReport */\n chatReportID: PropTypes.string.isRequired,\n\n /** Is this IOUACTION the most recent? */\n isMostRecentIOUReportAction: PropTypes.bool.isRequired,\n\n /** Popover context menu anchor, used for showing context menu */\n contextMenuAnchor: PropTypes.shape({current: PropTypes.elementType}),\n\n /** Callback for updating context menu active state, used for showing context menu */\n checkIfContextMenuActive: PropTypes.func,\n\n /* Onyx Props */\n /** chatReport associated with iouReport */\n chatReport: PropTypes.shape({\n /** The participants of this report */\n participants: PropTypes.arrayOf(PropTypes.string),\n\n /** Whether the chat report has an outstanding IOU */\n hasOutstandingIOU: PropTypes.bool.isRequired,\n }),\n\n /** IOU report data object */\n iouReport: iouReportPropTypes,\n\n /** Array of report actions for this report */\n reportActions: PropTypes.objectOf(PropTypes.shape(reportActionPropTypes)),\n\n /** Whether the IOU is hovered so we can modify its style */\n isHovered: PropTypes.bool,\n\n network: networkPropTypes.isRequired,\n};\n\nconst defaultProps = {\n contextMenuAnchor: undefined,\n checkIfContextMenuActive: () => {},\n chatReport: {\n participants: [],\n },\n iouReport: {},\n reportActions: {},\n isHovered: false,\n};\n\nconst IOUAction = (props) => {\n const launchDetailsModal = () => {\n Navigation.navigate(ROUTES.getIouDetailsRoute(props.chatReportID, props.action.originalMessage.IOUReportID));\n };\n\n const shouldShowIOUPreview = (\n props.isMostRecentIOUReportAction\n && Boolean(props.action.originalMessage.IOUReportID)\n && props.chatReport.hasOutstandingIOU) || props.action.originalMessage.type === 'pay';\n\n let shouldShowPendingConversionMessage = false;\n if (\n !_.isEmpty(props.iouReport)\n && !_.isEmpty(props.reportActions)\n && props.chatReport.hasOutstandingIOU\n && props.isMostRecentIOUReportAction\n && props.action.pendingAction === CONST.RED_BRICK_ROAD_PENDING_ACTION.ADD\n && props.network.isOffline\n ) {\n shouldShowPendingConversionMessage = IOUUtils.isIOUReportPendingCurrencyConversion(props.reportActions, props.iouReport);\n }\n\n return (\n <>\n \n {shouldShowIOUPreview && (\n \n )}\n \n );\n};\n\nIOUAction.propTypes = propTypes;\nIOUAction.defaultProps = defaultProps;\nIOUAction.displayName = 'IOUAction';\n\nexport default compose(\n withOnyx({\n chatReport: {\n key: ({chatReportID}) => `${ONYXKEYS.COLLECTION.REPORT}${chatReportID}`,\n },\n iouReport: {\n key: ({action}) => `${ONYXKEYS.COLLECTION.REPORT}${action.originalMessage.IOUReportID}`,\n },\n reportActions: {\n key: ({chatReportID}) => `${ONYXKEYS.COLLECTION.REPORT_ACTIONS}${chatReportID}`,\n canEvict: false,\n },\n }),\n withNetwork(),\n)(IOUAction);\n","import React from 'react';\nimport {View, Pressable} from 'react-native';\nimport PropTypes from 'prop-types';\nimport _ from 'underscore';\nimport Text from '../Text';\nimport Icon from '../Icon';\nimport * as Expensicons from '../Icon/Expensicons';\nimport styles from '../../styles/styles';\nimport themeColors from '../../styles/themes/default';\nimport reportActionPropTypes from '../../pages/home/report/reportActionPropTypes';\nimport withLocalize, {withLocalizePropTypes} from '../withLocalize';\nimport ControlSelection from '../../libs/ControlSelection';\nimport * as DeviceCapabilities from '../../libs/DeviceCapabilities';\nimport {showContextMenuForReport} from '../ShowContextMenuContext';\nimport * as StyleUtils from '../../styles/StyleUtils';\nimport getButtonState from '../../libs/getButtonState';\n\nconst propTypes = {\n /** All the data of the action */\n action: PropTypes.shape(reportActionPropTypes).isRequired,\n\n /** The associated chatReport */\n chatReportID: PropTypes.string.isRequired,\n\n /** Popover context menu anchor, used for showing context menu */\n contextMenuAnchor: PropTypes.shape({current: PropTypes.elementType}),\n\n /** Whether it is allowed to view details. */\n shouldAllowViewDetails: PropTypes.bool,\n\n /** Callback invoked when View Details is pressed */\n onViewDetailsPressed: PropTypes.func,\n\n /** Callback for updating context menu active state, used for showing context menu */\n checkIfContextMenuActive: PropTypes.func,\n\n /** Whether the IOU is hovered so we can modify its style */\n isHovered: PropTypes.bool,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n contextMenuAnchor: null,\n shouldAllowViewDetails: false,\n isHovered: false,\n onViewDetailsPressed: () => {},\n checkIfContextMenuActive: () => {},\n};\n\nconst IOUQuote = props => (\n \n {_.map(props.action.message, (fragment, index) => (\n {}}\n onPressIn={() => DeviceCapabilities.canUseTouchScreen() && ControlSelection.block()}\n onPressOut={() => ControlSelection.unblock()}\n onLongPress={event => showContextMenuForReport(\n event,\n props.contextMenuAnchor,\n props.chatReportID,\n props.action,\n props.checkIfContextMenuActive,\n )}\n style={[styles.flexRow, styles.justifyContentBetween,\n props.shouldAllowViewDetails\n ? undefined\n : styles.cursorDefault,\n ]}\n focusable={props.shouldAllowViewDetails}\n >\n \n \n {/* Get first word of IOU message */}\n {fragment.text.split(' ')[0]}\n \n \n {/* Get remainder of IOU message */}\n {fragment.text.substring(fragment.text.indexOf(' '))}\n \n \n \n \n ))}\n \n);\n\nIOUQuote.propTypes = propTypes;\nIOUQuote.defaultProps = defaultProps;\nIOUQuote.displayName = 'IOUQuote';\n\nexport default withLocalize(IOUQuote);\n","import PropTypes from 'prop-types';\n\nexport default PropTypes.shape({\n /** The report ID of the IOU */\n reportID: PropTypes.string,\n\n /** The report ID of the chat associated with the IOU */\n chatReportID: PropTypes.string,\n\n /** The total amount in cents */\n total: PropTypes.number,\n\n /** The owner of the IOUReport */\n ownerEmail: PropTypes.string,\n\n /** The currency of the IOUReport */\n currency: PropTypes.string,\n});\n","import React from 'react';\nimport {View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport _ from 'underscore';\nimport lodashGet from 'lodash/get';\nimport styles from '../../../styles/styles';\nimport ReportActionItemFragment from './ReportActionItemFragment';\nimport reportActionPropTypes from './reportActionPropTypes';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\n\nconst propTypes = {\n /** The report action */\n action: PropTypes.shape(reportActionPropTypes).isRequired,\n\n /** Additional styles to add after local styles. */\n style: PropTypes.oneOfType([\n PropTypes.arrayOf(PropTypes.object),\n PropTypes.object,\n ]),\n\n /** localization props */\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n style: [],\n};\n\nconst ReportActionItemMessage = props => (\n \n {_.map(_.compact(props.action.previousMessage || props.action.message), (fragment, index) => (\n \n ))}\n \n);\n\nReportActionItemMessage.propTypes = propTypes;\nReportActionItemMessage.defaultProps = defaultProps;\nReportActionItemMessage.displayName = 'ReportActionItemMessage';\n\nexport default withLocalize(ReportActionItemMessage);\n","import React from 'react';\nimport {View} from 'react-native';\nimport styles from '../styles/styles';\nimport Text from './Text';\nimport withLocalize, {withLocalizePropTypes} from './withLocalize';\n\nconst UnreadActionIndicator = props => (\n \n \n \n {props.translate('common.new')}\n \n \n);\n\nUnreadActionIndicator.propTypes = {...withLocalizePropTypes};\n\nUnreadActionIndicator.displayName = 'UnreadActionIndicator';\nexport default withLocalize(UnreadActionIndicator);\n","/* eslint-disable rulesdir/onyx-props-must-have-default */\nimport lodashGet from 'lodash/get';\nimport React from 'react';\nimport {InteractionManager, Keyboard, View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport _ from 'underscore';\nimport ExpensiMark from 'expensify-common/lib/ExpensiMark';\nimport {withOnyx} from 'react-native-onyx';\nimport reportActionPropTypes from './reportActionPropTypes';\nimport styles from '../../../styles/styles';\nimport Composer from '../../../components/Composer';\nimport * as Report from '../../../libs/actions/Report';\nimport * as ReportScrollManager from '../../../libs/ReportScrollManager';\nimport toggleReportActionComposeView from '../../../libs/toggleReportActionComposeView';\nimport openReportActionComposeViewWhenClosingMessageEdit from '../../../libs/openReportActionComposeViewWhenClosingMessageEdit';\nimport Button from '../../../components/Button';\nimport ReportActionComposeFocusManager from '../../../libs/ReportActionComposeFocusManager';\nimport compose from '../../../libs/compose';\nimport EmojiPickerButton from '../../../components/EmojiPicker/EmojiPickerButton';\nimport * as ReportActionContextMenu from './ContextMenu/ReportActionContextMenu';\nimport * as ReportUtils from '../../../libs/ReportUtils';\nimport * as EmojiUtils from '../../../libs/EmojiUtils';\nimport reportPropTypes from '../../reportPropTypes';\nimport ExceededCommentLength from '../../../components/ExceededCommentLength';\nimport CONST from '../../../CONST';\nimport withWindowDimensions, {windowDimensionsPropTypes} from '../../../components/withWindowDimensions';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport withKeyboardState, {keyboardStatePropTypes} from '../../../components/withKeyboardState';\nimport ONYXKEYS from '../../../ONYXKEYS';\n\nconst propTypes = {\n /** All the data of the action */\n action: PropTypes.shape(reportActionPropTypes).isRequired,\n\n /** Draft message */\n draftMessage: PropTypes.string.isRequired,\n\n /** Number of lines for the draft message */\n numberOfLines: PropTypes.number,\n\n /** ReportID that holds the comment we're editing */\n reportID: PropTypes.string.isRequired,\n\n /** Position index of the report action in the overall report FlatList view */\n index: PropTypes.number.isRequired,\n\n /** A ref to forward to the text input */\n forwardedRef: PropTypes.func,\n\n /** The report currently being looked at */\n // eslint-disable-next-line react/no-unused-prop-types\n report: reportPropTypes,\n\n /** Whether or not the emoji picker is disabled */\n shouldDisableEmojiPicker: PropTypes.bool,\n\n /** Stores user's preferred skin tone */\n preferredSkinTone: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n\n ...withLocalizePropTypes,\n ...windowDimensionsPropTypes,\n ...keyboardStatePropTypes,\n};\n\nconst defaultProps = {\n forwardedRef: () => {},\n report: {},\n shouldDisableEmojiPicker: false,\n numberOfLines: undefined,\n preferredSkinTone: CONST.EMOJI_DEFAULT_SKIN_TONE,\n};\n\nclass ReportActionItemMessageEdit extends React.Component {\n constructor(props) {\n super(props);\n this.updateDraft = this.updateDraft.bind(this);\n this.deleteDraft = this.deleteDraft.bind(this);\n this.debouncedSaveDraft = _.debounce(this.debouncedSaveDraft.bind(this), 1000);\n this.publishDraft = this.publishDraft.bind(this);\n this.triggerSaveOrCancel = this.triggerSaveOrCancel.bind(this);\n this.onSelectionChange = this.onSelectionChange.bind(this);\n this.addEmojiToTextBox = this.addEmojiToTextBox.bind(this);\n this.setExceededMaxCommentLength = this.setExceededMaxCommentLength.bind(this);\n this.updateNumberOfLines = this.updateNumberOfLines.bind(this);\n this.saveButtonID = 'saveButton';\n this.cancelButtonID = 'cancelButton';\n this.emojiButtonID = 'emojiButton';\n this.messageEditInput = 'messageEditInput';\n\n const parser = new ExpensiMark();\n const draftMessage = parser.htmlToMarkdown(this.props.draftMessage).trim();\n\n this.state = {\n draft: draftMessage,\n selection: {\n start: draftMessage.length,\n end: draftMessage.length,\n },\n isFocused: false,\n hasExceededMaxCommentLength: false,\n };\n }\n\n componentWillUnmount() {\n // Skip if this is not the focused message so the other edit composer stays focused.\n if (!this.state.isFocused) {\n return;\n }\n\n // Show the main composer when the focused message is deleted from another client\n // to prevent the main composer stays hidden until we swtich to another chat.\n toggleReportActionComposeView(true, this.props.isSmallScreenWidth);\n }\n\n /**\n * Update Selection on change cursor position.\n *\n * @param {Event} e\n */\n onSelectionChange(e) {\n this.setState({selection: e.nativeEvent.selection});\n }\n\n /**\n * Updates the composer when the comment length is exceeded\n * Shows red borders and prevents the comment from being sent\n *\n * @param {Boolean} hasExceededMaxCommentLength\n */\n setExceededMaxCommentLength(hasExceededMaxCommentLength) {\n this.setState({hasExceededMaxCommentLength});\n }\n\n /**\n * Update the value of the draft in Onyx\n *\n * @param {String} draft\n */\n updateDraft(draft) {\n const newDraft = EmojiUtils.replaceEmojis(draft, this.props.isSmallScreenWidth, this.props.preferredSkinTone);\n this.setState((prevState) => {\n const newState = {draft: newDraft};\n if (draft !== newDraft) {\n const remainder = prevState.draft.slice(prevState.selection.end).length;\n newState.selection = {\n start: newDraft.length - remainder,\n end: newDraft.length - remainder,\n };\n }\n return newState;\n });\n\n // This component is rendered only when draft is set to a non-empty string. In order to prevent component\n // unmount when user deletes content of textarea, we set previous message instead of empty string.\n if (newDraft.trim().length > 0) {\n this.debouncedSaveDraft(newDraft);\n } else {\n this.debouncedSaveDraft(this.props.action.message[0].html);\n }\n }\n\n /**\n * Update the number of lines for a draft in Onyx\n * @param {Number} numberOfLines\n */\n updateNumberOfLines(numberOfLines) {\n Report.saveReportActionDraftNumberOfLines(this.props.reportID, this.props.action.reportActionID, numberOfLines);\n }\n\n /**\n * Delete the draft of the comment being edited. This will take the comment out of \"edit mode\" with the old content.\n */\n deleteDraft() {\n this.debouncedSaveDraft.cancel();\n Report.saveReportActionDraft(this.props.reportID, this.props.action.reportActionID, '');\n toggleReportActionComposeView(true, this.props.isSmallScreenWidth);\n ReportActionComposeFocusManager.focus();\n\n // Scroll to the last comment after editing to make sure the whole comment is clearly visible in the report.\n if (this.props.index === 0) {\n const keyboardDidHideListener = Keyboard.addListener('keyboardDidHide', () => {\n ReportScrollManager.scrollToIndex({animated: true, index: this.props.index}, false);\n keyboardDidHideListener.remove();\n });\n }\n }\n\n /**\n * Save the draft of the comment. This debounced so that we're not ceaselessly saving your edit. Saving the draft\n * allows one to navigate somewhere else and come back to the comment and still have it in edit mode.\n * @param {String} newDraft\n */\n debouncedSaveDraft(newDraft) {\n Report.saveReportActionDraft(this.props.reportID, this.props.action.reportActionID, newDraft);\n }\n\n /**\n * Save the draft of the comment to be the new comment message. This will take the comment out of \"edit mode\" with\n * the new content.\n */\n publishDraft() {\n // Do nothing if draft exceed the character limit\n if (ReportUtils.getCommentLength(this.state.draft) > CONST.MAX_COMMENT_LENGTH) {\n return;\n }\n\n // To prevent re-mount after user saves edit before debounce duration (example: within 1 second), we cancel\n // debounce here.\n this.debouncedSaveDraft.cancel();\n\n const trimmedNewDraft = this.state.draft.trim();\n\n // When user tries to save the empty message, it will delete it. Prompt the user to confirm deleting.\n if (!trimmedNewDraft) {\n ReportActionContextMenu.showDeleteModal(\n this.props.reportID,\n this.props.action,\n false,\n this.deleteDraft,\n () => InteractionManager.runAfterInteractions(() => this.textInput.focus()),\n );\n return;\n }\n Report.editReportComment(this.props.reportID, this.props.action, trimmedNewDraft);\n this.deleteDraft();\n }\n\n /**\n * @param {String} emoji\n */\n addEmojiToTextBox(emoji) {\n const newComment = this.state.draft.slice(0, this.state.selection.start)\n + emoji + this.state.draft.slice(this.state.selection.end, this.state.draft.length);\n this.setState(prevState => ({\n selection: {\n start: prevState.selection.start + emoji.length,\n end: prevState.selection.start + emoji.length,\n },\n }));\n this.updateDraft(newComment);\n }\n\n /**\n * Key event handlers that short cut to saving/canceling.\n *\n * @param {Event} e\n */\n triggerSaveOrCancel(e) {\n // Do not trigger actions for mobileWeb or native clients that have the keyboard open because for those devices, we want the return key to insert newlines rather than submit the form\n if (!e || this.props.isSmallScreenWidth || this.props.isKeyboardShown) {\n return;\n }\n if (e.key === 'Enter' && !e.shiftKey) {\n e.preventDefault();\n this.publishDraft();\n } else if (e.key === 'Escape') {\n e.preventDefault();\n this.deleteDraft();\n }\n }\n\n render() {\n const hasExceededMaxCommentLength = this.state.hasExceededMaxCommentLength;\n return (\n \n \n {\n this.textInput = el;\n this.props.forwardedRef(el);\n }}\n nativeID={this.messageEditInput}\n onChangeText={this.updateDraft} // Debounced saveDraftComment\n onKeyPress={this.triggerSaveOrCancel}\n value={this.state.draft}\n maxLines={16} // This is the same that slack has\n style={[styles.textInputCompose, styles.flex4, styles.editInputComposeSpacing]}\n onFocus={() => {\n this.setState({isFocused: true});\n ReportScrollManager.scrollToIndex({animated: true, index: this.props.index}, true);\n toggleReportActionComposeView(false, this.props.isSmallScreenWidth);\n }}\n onBlur={(event) => {\n this.setState({isFocused: false});\n const relatedTargetId = lodashGet(event, 'nativeEvent.relatedTarget.id');\n\n // Return to prevent re-render when save/cancel button is pressed which cancels the onPress event by re-rendering\n if (_.contains([this.saveButtonID, this.cancelButtonID, this.emojiButtonID], relatedTargetId)) {\n return;\n }\n\n if (this.messageEditInput === relatedTargetId) {\n return;\n }\n openReportActionComposeViewWhenClosingMessageEdit(this.props.isSmallScreenWidth);\n }}\n selection={this.state.selection}\n onSelectionChange={this.onSelectionChange}\n numberOfLines={this.props.numberOfLines}\n onNumberOfLinesChange={this.updateNumberOfLines}\n />\n \n InteractionManager.runAfterInteractions(() => this.textInput.focus())}\n onEmojiSelected={this.addEmojiToTextBox}\n nativeID={this.emojiButtonID}\n />\n \n\n \n \n \n \n \n \n \n );\n }\n}\n\nReportActionItemMessageEdit.propTypes = propTypes;\nReportActionItemMessageEdit.defaultProps = defaultProps;\nexport default compose(\n withLocalize,\n withWindowDimensions,\n withKeyboardState,\n withOnyx({\n numberOfLines: {\n key: ({reportID, action}) => `${ONYXKEYS.COLLECTION.REPORT_DRAFT_COMMENT_NUMBER_OF_LINES}${reportID}_${action.reportActionID}`,\n initWithStoredValues: false,\n },\n }),\n)(React.forwardRef((props, ref) => (\n /* eslint-disable-next-line react/jsx-props-no-spreading */\n \n)));\n","import React from 'react';\nimport {StyleSheet} from 'react-native';\nimport PropTypes from 'prop-types';\nimport _ from 'underscore';\nimport RNTextInput from '../RNTextInput';\nimport themeColors from '../../styles/themes/default';\nimport CONST from '../../CONST';\nimport * as ComposerUtils from '../../libs/ComposerUtils';\n\nconst propTypes = {\n /** If the input should clear, it actually gets intercepted instead of .clear() */\n shouldClear: PropTypes.bool,\n\n /** A ref to forward to the text input */\n forwardedRef: PropTypes.func,\n\n /** When the input has cleared whoever owns this input should know about it */\n onClear: PropTypes.func,\n\n /** Set focus to this component the first time it renders.\n * Override this in case you need to set focus on one field out of many, or when you want to disable autoFocus */\n autoFocus: PropTypes.bool,\n\n /** Prevent edits and interactions like focus for this input. */\n isDisabled: PropTypes.bool,\n\n /** Selection Object */\n selection: PropTypes.shape({\n start: PropTypes.number,\n end: PropTypes.number,\n }),\n\n /** Whether the full composer can be opened */\n isFullComposerAvailable: PropTypes.bool,\n\n /** Allow the full composer to be opened */\n setIsFullComposerAvailable: PropTypes.func,\n\n /** Whether the composer is full size */\n isComposerFullSize: PropTypes.bool,\n\n /** General styles to apply to the text input */\n // eslint-disable-next-line react/forbid-prop-types\n style: PropTypes.any,\n\n};\n\nconst defaultProps = {\n shouldClear: false,\n onClear: () => {},\n autoFocus: false,\n isDisabled: false,\n forwardedRef: null,\n selection: {\n start: 0,\n end: 0,\n },\n isFullComposerAvailable: false,\n setIsFullComposerAvailable: () => {},\n isComposerFullSize: false,\n style: null,\n};\n\nclass Composer extends React.Component {\n constructor(props) {\n super(props);\n\n this.state = {\n propStyles: StyleSheet.flatten(this.props.style),\n };\n }\n\n componentDidMount() {\n // This callback prop is used by the parent component using the constructor to\n // get a ref to the inner textInput element e.g. if we do\n // this.textInput = el} /> this will not\n // return a ref to the component, but rather the HTML element by default\n if (!this.props.forwardedRef || !_.isFunction(this.props.forwardedRef)) {\n return;\n }\n\n this.props.forwardedRef(this.textInput);\n }\n\n componentDidUpdate(prevProps) {\n if (prevProps.shouldClear || !this.props.shouldClear) {\n return;\n }\n\n this.textInput.clear();\n this.props.onClear();\n }\n\n render() {\n // On native layers we like to have the Text Input not focused so the\n // user can read new chats without the keyboard in the way of the view.\n // On Android, the selection prop is required on the TextInput but this prop has issues on IOS\n // https://github.com/facebook/react-native/issues/29063\n const propsToPass = _.omit(this.props, 'selection');\n return (\n this.textInput = el}\n maxHeight={this.props.isComposerFullSize ? '100%' : CONST.COMPOSER_MAX_HEIGHT}\n onContentSizeChange={e => ComposerUtils.updateNumberOfLines(this.props, e)}\n rejectResponderTermination={false}\n textAlignVertical=\"center\"\n style={this.state.propStyles}\n /* eslint-disable-next-line react/jsx-props-no-spreading */\n {...propsToPass}\n editable={!this.props.isDisabled}\n />\n );\n }\n}\n\nComposer.propTypes = propTypes;\nComposer.defaultProps = defaultProps;\n\nexport default React.forwardRef((props, ref) => (\n /* eslint-disable-next-line react/jsx-props-no-spreading */\n \n));\n","import lodashGet from 'lodash/get';\nimport styles from '../../styles/styles';\nimport updateIsFullComposerAvailable from './updateIsFullComposerAvailable';\n\n/**\n * Get the current number of lines in the composer\n *\n * @param {Number} lineHeight\n * @param {Number} paddingTopAndBottom\n * @param {Number} scrollHeight\n *\n * @returns {Number}\n */\nfunction getNumberOfLines(lineHeight, paddingTopAndBottom, scrollHeight) {\n return Math.ceil((scrollHeight - paddingTopAndBottom) / lineHeight);\n}\n\n/**\n * Check the current scrollHeight of the textarea (minus any padding) and\n * divide by line height to get the total number of rows for the textarea.\n * @param {Object} props\n * @param {Event} e\n */\nfunction updateNumberOfLines(props, e) {\n const lineHeight = styles.textInputCompose.lineHeight;\n const paddingTopAndBottom = styles.textInputComposeSpacing.paddingVertical * 2;\n const inputHeight = lodashGet(e, 'nativeEvent.contentSize.height', null);\n if (!inputHeight) {\n return;\n }\n const numberOfLines = getNumberOfLines(lineHeight, paddingTopAndBottom, inputHeight);\n updateIsFullComposerAvailable(props, numberOfLines);\n}\n\nexport {\n getNumberOfLines,\n updateNumberOfLines,\n};\n","import CONST from '../../CONST';\n\n/**\n * Update isFullComposerAvailable if needed\n * @param {Object} props\n * @param {Number} numberOfLines The number of lines in the text input\n */\nfunction updateIsFullComposerAvailable(props, numberOfLines) {\n const isFullComposerAvailable = numberOfLines >= CONST.COMPOSER.FULL_COMPOSER_MIN_LINES;\n if (isFullComposerAvailable !== props.isFullComposerAvailable) {\n props.setIsFullComposerAvailable(isFullComposerAvailable);\n }\n}\n\nexport default updateIsFullComposerAvailable;\n","import * as Composer from '../actions/Composer';\n\nexport default shouldShowComposeInput => Composer.setShouldShowComposeInput(shouldShowComposeInput);\n","import Onyx from 'react-native-onyx';\nimport ONYXKEYS from '../../ONYXKEYS';\n\n/**\n * @param {Boolean} shouldShowComposeInput\n */\nfunction setShouldShowComposeInput(shouldShowComposeInput) {\n Onyx.set(ONYXKEYS.SHOULD_SHOW_COMPOSE_INPUT, shouldShowComposeInput);\n}\n\nexport {\n // eslint-disable-next-line import/prefer-default-export\n setShouldShowComposeInput,\n};\n","import {Keyboard} from 'react-native';\nimport toggleReportActionComposeView from '../toggleReportActionComposeView';\n\nexport default (isSmallScreenWidth = true) => {\n const keyboardDidHideListener = Keyboard.addListener('keyboardDidHide', () => {\n toggleReportActionComposeView(true, isSmallScreenWidth);\n keyboardDidHideListener.remove();\n });\n};\n","import React from 'react';\nimport {Pressable} from 'react-native';\nimport PropTypes from 'prop-types';\nimport styles from '../../styles/styles';\nimport * as StyleUtils from '../../styles/StyleUtils';\nimport getButtonState from '../../libs/getButtonState';\nimport * as Expensicons from '../Icon/Expensicons';\nimport Tooltip from '../Tooltip';\nimport Icon from '../Icon';\nimport withLocalize, {withLocalizePropTypes} from '../withLocalize';\nimport * as EmojiPickerAction from '../../libs/actions/EmojiPickerAction';\n\nconst propTypes = {\n /** Flag to disable the emoji picker button */\n isDisabled: PropTypes.bool,\n\n /** Id to use for the emoji picker button */\n nativeID: PropTypes.string,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n isDisabled: false,\n nativeID: '',\n};\n\nconst EmojiPickerButton = (props) => {\n let emojiPopoverAnchor = null;\n return (\n \n emojiPopoverAnchor = el}\n style={({hovered, pressed}) => ([\n styles.chatItemEmojiButton,\n StyleUtils.getButtonBackgroundColorStyle(getButtonState(hovered, pressed)),\n ])}\n disabled={props.isDisabled}\n onPress={() => EmojiPickerAction.showEmojiPicker(props.onModalHide, props.onEmojiSelected, emojiPopoverAnchor)}\n nativeID={props.nativeID}\n >\n {({hovered, pressed}) => (\n \n )}\n \n \n );\n};\n\nEmojiPickerButton.propTypes = propTypes;\nEmojiPickerButton.defaultProps = defaultProps;\nEmojiPickerButton.displayName = 'EmojiPickerButton';\nexport default withLocalize(EmojiPickerButton);\n","import React, {PureComponent} from 'react';\nimport PropTypes from 'prop-types';\nimport {debounce} from 'lodash';\nimport CONST from '../CONST';\nimport * as ReportUtils from '../libs/ReportUtils';\nimport Text from './Text';\nimport styles from '../styles/styles';\n\nconst propTypes = {\n /** Text Comment */\n comment: PropTypes.string.isRequired,\n\n /** Update UI on parent when comment length is exceeded */\n onExceededMaxCommentLength: PropTypes.func.isRequired,\n};\n\nclass ExceededCommentLength extends PureComponent {\n constructor(props) {\n super(props);\n\n this.state = {\n commentLength: 0,\n };\n\n // By debouncing, we defer the calculation until there is a break in typing\n this.updateCommentLength = debounce(this.updateCommentLength.bind(this), CONST.TIMING.COMMENT_LENGTH_DEBOUNCE_TIME);\n }\n\n componentDidMount() {\n this.updateCommentLength();\n }\n\n componentDidUpdate(prevProps) {\n if (prevProps.comment === this.props.comment) {\n return;\n }\n\n this.updateCommentLength();\n }\n\n updateCommentLength() {\n const commentLength = ReportUtils.getCommentLength(this.props.comment);\n this.setState({commentLength});\n this.props.onExceededMaxCommentLength(commentLength > CONST.MAX_COMMENT_LENGTH);\n }\n\n render() {\n if (this.state.commentLength <= CONST.MAX_COMMENT_LENGTH) {\n return null;\n }\n\n return (\n \n {`${this.state.commentLength}/${CONST.MAX_COMMENT_LENGTH}`}\n \n );\n }\n}\n\nExceededCommentLength.propTypes = propTypes;\n\nexport default ExceededCommentLength;\n","import React from 'react';\nimport {Pressable, View, Image} from 'react-native';\nimport lodashGet from 'lodash/get';\nimport {withOnyx} from 'react-native-onyx';\nimport PropTypes from 'prop-types';\nimport ONYXKEYS from '../../../ONYXKEYS';\nimport RoomHeaderAvatars from '../../../components/RoomHeaderAvatars';\nimport ReportWelcomeText from '../../../components/ReportWelcomeText';\nimport participantPropTypes from '../../../components/participantPropTypes';\nimport * as ReportUtils from '../../../libs/ReportUtils';\nimport styles from '../../../styles/styles';\nimport OfflineWithFeedback from '../../../components/OfflineWithFeedback';\nimport * as Report from '../../../libs/actions/Report';\nimport reportPropTypes from '../../reportPropTypes';\nimport EmptyStateBackgroundImage from '../../../../assets/images/empty-state_background-fade.png';\nimport * as StyleUtils from '../../../styles/StyleUtils';\nimport withWindowDimensions, {windowDimensionsPropTypes} from '../../../components/withWindowDimensions';\nimport compose from '../../../libs/compose';\nimport withLocalize from '../../../components/withLocalize';\n\nconst propTypes = {\n /** The id of the report */\n reportID: PropTypes.string.isRequired,\n\n /** The report currently being looked at */\n report: reportPropTypes,\n\n /** Personal details of all the users */\n personalDetails: PropTypes.objectOf(participantPropTypes),\n\n /** The policies which the user has access to and which the report could be tied to */\n policies: PropTypes.shape({\n /** Name of the policy */\n name: PropTypes.string,\n }),\n\n ...windowDimensionsPropTypes,\n};\nconst defaultProps = {\n report: {},\n personalDetails: {},\n policies: {},\n};\n\nconst ReportActionItemCreated = (props) => {\n const icons = ReportUtils.getIcons(props.report, props.personalDetails, props.policies);\n return (\n Report.navigateToConciergeChatAndDeleteReport(props.report.reportID)}\n >\n \n \n \n ReportUtils.navigateToDetailsPage(props.report)}\n style={[styles.ph5, styles.pb3, styles.alignSelfStart]}\n >\n \n \n \n \n \n \n \n \n );\n};\n\nReportActionItemCreated.defaultProps = defaultProps;\nReportActionItemCreated.propTypes = propTypes;\nReportActionItemCreated.displayName = 'ReportActionItemCreated';\n\nexport default compose(\n withWindowDimensions,\n withLocalize,\n withOnyx({\n report: {\n key: ({reportID}) => `${ONYXKEYS.COLLECTION.REPORT}${reportID}`,\n },\n personalDetails: {\n key: ONYXKEYS.PERSONAL_DETAILS,\n },\n policies: {\n key: ONYXKEYS.COLLECTION.POLICY,\n },\n }),\n)(ReportActionItemCreated);\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport lodashGet from 'lodash/get';\nimport {View} from 'react-native';\nimport {withOnyx} from 'react-native-onyx';\nimport _ from 'underscore';\nimport styles from '../styles/styles';\nimport Text from './Text';\nimport withLocalize, {withLocalizePropTypes} from './withLocalize';\nimport compose from '../libs/compose';\nimport * as ReportUtils from '../libs/ReportUtils';\nimport * as OptionsListUtils from '../libs/OptionsListUtils';\nimport ONYXKEYS from '../ONYXKEYS';\nimport Navigation from '../libs/Navigation/Navigation';\nimport ROUTES from '../ROUTES';\nimport Tooltip from './Tooltip';\nimport reportPropTypes from '../pages/reportPropTypes';\nimport CONST from '../CONST';\n\nconst personalDetailsPropTypes = PropTypes.shape({\n /** The login of the person (either email or phone number) */\n login: PropTypes.string.isRequired,\n\n /** The URL of the person's avatar (there should already be a default avatar if\n the person doesn't have their own avatar uploaded yet) */\n avatar: PropTypes.string.isRequired,\n\n /** This is either the user's full name, or their login if full name is an empty string */\n displayName: PropTypes.string.isRequired,\n});\n\nconst propTypes = {\n /** The report currently being looked at */\n report: reportPropTypes,\n\n /* Onyx Props */\n\n /** All of the personal details for everyone */\n personalDetails: PropTypes.objectOf(personalDetailsPropTypes),\n\n /** The policies which the user has access to and which the report could be tied to */\n policies: PropTypes.shape({\n /** The policy name */\n name: PropTypes.string,\n }),\n\n /** List of betas available to current user */\n betas: PropTypes.arrayOf(PropTypes.string),\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n report: {},\n policies: {},\n personalDetails: {},\n betas: [],\n};\n\nconst ReportWelcomeText = (props) => {\n const isPolicyExpenseChat = ReportUtils.isPolicyExpenseChat(props.report);\n const isChatRoom = ReportUtils.isChatRoom(props.report);\n const isDefault = !(isChatRoom || isPolicyExpenseChat);\n const participants = lodashGet(props.report, 'participants', []);\n const isMultipleParticipant = participants.length > 1;\n const displayNamesWithTooltips = ReportUtils.getDisplayNamesWithTooltips(\n OptionsListUtils.getPersonalDetailsForLogins(participants, props.personalDetails),\n isMultipleParticipant,\n );\n const roomWelcomeMessage = ReportUtils.getRoomWelcomeMessage(props.report, props.policies);\n const moneyRequestOptions = ReportUtils.getMoneyRequestOptions(props.report, participants, props.betas);\n return (\n <>\n \n \n {props.translate('reportActionsView.sayHello')}\n \n \n \n {isPolicyExpenseChat && (\n <>\n \n {props.translate('reportActionsView.beginningOfChatHistoryPolicyExpenseChatPartOne')}\n \n \n {/* Use the policyExpenseChat owner's first name or their email if it's undefined or an empty string */}\n {lodashGet(props.personalDetails, [props.report.ownerEmail, 'firstName']) || props.report.ownerEmail}\n \n \n {props.translate('reportActionsView.beginningOfChatHistoryPolicyExpenseChatPartTwo')}\n \n \n {ReportUtils.getPolicyName(props.report, props.policies)}\n \n \n {props.translate('reportActionsView.beginningOfChatHistoryPolicyExpenseChatPartThree')}\n \n \n )}\n {isChatRoom && (\n <>\n \n {roomWelcomeMessage.phrase1}\n \n Navigation.navigate(ROUTES.getReportDetailsRoute(props.report.reportID))}>\n {ReportUtils.getReportName(props.report, props.policies)}\n \n \n {roomWelcomeMessage.phrase2}\n \n \n )}\n {isDefault && (\n \n \n {props.translate('reportActionsView.beginningOfChatHistory')}\n \n {_.map(displayNamesWithTooltips, ({\n displayName, pronouns, tooltip,\n }, index) => (\n \n \n Navigation.navigate(ROUTES.getDetailsRoute(participants[index]))}>\n {displayName}\n \n \n {!_.isEmpty(pronouns) && {` (${pronouns})`}}\n {(index === displayNamesWithTooltips.length - 1) && .}\n {(index === displayNamesWithTooltips.length - 2) && {` ${props.translate('common.and')} `}}\n {(index < displayNamesWithTooltips.length - 2) && , }\n \n ))}\n \n )}\n {(moneyRequestOptions.includes(CONST.IOU.MONEY_REQUEST_TYPE.SEND) || moneyRequestOptions.includes(CONST.IOU.MONEY_REQUEST_TYPE.REQUEST)) && (\n \n {/* Need to confirm copy for the below with marketing, and then add to translations. */}\n {props.translate('reportActionsView.usePlusButton')}\n \n )}\n \n \n );\n};\n\nReportWelcomeText.defaultProps = defaultProps;\nReportWelcomeText.propTypes = propTypes;\nReportWelcomeText.displayName = 'ReportWelcomeText';\n\nexport default compose(\n withLocalize,\n withOnyx({\n betas: {\n key: ONYXKEYS.BETAS,\n },\n personalDetails: {\n key: ONYXKEYS.PERSONAL_DETAILS,\n },\n policies: {\n key: ONYXKEYS.COLLECTION.POLICY,\n },\n }),\n)(ReportWelcomeText);\n","","export default () => null;\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport lodashGet from 'lodash/get';\nimport Text from '../Text';\nimport styles from '../../styles/styles';\nimport reportActionPropTypes from '../../pages/home/report/reportActionPropTypes';\nimport withLocalize, {withLocalizePropTypes} from '../withLocalize';\n\nconst propTypes = {\n /** All the data of the action */\n action: PropTypes.shape(reportActionPropTypes).isRequired,\n\n ...withLocalizePropTypes,\n};\n\nconst RenameAction = (props) => {\n const displayName = lodashGet(props.action, ['message', 0, 'text']);\n const oldName = lodashGet(props.action, 'originalMessage.oldName', '');\n const newName = lodashGet(props.action, 'originalMessage.newName', '');\n\n return (\n \n \n {displayName}\n \n {props.translate('newRoomPage.renamedRoomAction', {oldName, newName})}\n \n );\n};\n\nRenameAction.propTypes = propTypes;\nRenameAction.displayName = 'RenameAction';\n\nexport default withLocalize(RenameAction);\n","import React from 'react';\nimport {View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport styles from '../styles/styles';\nimport theme from '../styles/themes/default';\nimport Text from './Text';\nimport * as Expensicons from './Icon/Expensicons';\nimport Icon from './Icon';\n\nconst propTypes = {\n /** Error to display */\n message: PropTypes.string,\n};\n\nconst defaultProps = {\n message: '',\n};\n\nconst InlineSystemMessage = (props) => {\n if (props.message.length === 0) {\n return null;\n }\n return (\n \n \n {props.message}\n \n );\n};\n\nInlineSystemMessage.propTypes = propTypes;\nInlineSystemMessage.defaultProps = defaultProps;\nInlineSystemMessage.displayName = 'InlineSystemMessage';\nexport default InlineSystemMessage;\n","export default {\n // This is a no-op function for native devices because they wouldn't be able to support Selection API like a website.\n getCurrentSelection: () => '',\n};\n","/**\n * This library is a no-op for all platforms except for Android and will immediately focus the given input without any delays. This is important for native iOS clients because\n * text inputs can only be focused from user interactions and wrapping the focus() inside a setTimeout breaks that use case since it's no longer triggered from a user interaction.\n *\n * @param {Object} inputRef\n */\nconst focusTextInputAfterAnimation = (inputRef) => {\n inputRef.focus();\n};\n\nexport default focusTextInputAfterAnimation;\n","import React from 'react';\nimport {View} from 'react-native';\nimport _ from 'underscore';\nimport PropTypes from 'prop-types';\nimport lodashGet from 'lodash/get';\nimport reportActionPropTypes from '../../pages/home/report/reportActionPropTypes';\nimport styles from '../../styles/styles';\nimport Text from '../Text';\nimport Button from '../Button';\nimport * as Chronos from '../../libs/actions/Chronos';\nimport withLocalize, {withLocalizePropTypes} from '../withLocalize';\nimport DateUtils from '../../libs/DateUtils';\nimport OfflineWithFeedback from '../OfflineWithFeedback';\n\nconst propTypes = {\n /** The ID of the report */\n reportID: PropTypes.string.isRequired,\n\n /** All the data of the action */\n action: PropTypes.shape(reportActionPropTypes).isRequired,\n\n ...withLocalizePropTypes,\n};\n\nconst ChronosOOOListActions = (props) => {\n const events = lodashGet(props.action, 'originalMessage.events', []);\n\n if (!events.length) {\n return (\n \n You haven't created any events\n \n );\n }\n\n return (\n \n \n {_.map(events, (event) => {\n const start = DateUtils.getLocalMomentFromDatetime(props.preferredLocale, lodashGet(event, 'start.date', ''));\n const end = DateUtils.getLocalMomentFromDatetime(props.preferredLocale, lodashGet(event, 'end.date', ''));\n return (\n \n \n {event.lengthInDays > 0 ? (\n props.translate('chronos.oooEventSummaryFullDay', {\n summary: event.summary,\n dayCount: event.lengthInDays,\n date: end.format('dddd LL'),\n })\n ) : (\n props.translate('chronos.oooEventSummaryPartialDay', {\n summary: event.summary,\n timePeriod: `${start.format('LT')} - ${end.format('LT')}`,\n date: end.format('dddd LL'),\n })\n )}\n \n Chronos.removeEvent(props.reportID, props.action.reportActionID, event.id, events)}\n ContentComponent={() => (\n \n {props.translate('common.remove')}\n \n )}\n />\n \n );\n })}\n \n \n );\n};\n\nChronosOOOListActions.propTypes = propTypes;\nChronosOOOListActions.displayName = 'ChronosOOOListActions';\n\nexport default withLocalize(ChronosOOOListActions);\n","import _ from 'underscore';\nimport CONST from '../../CONST';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport * as API from '../API';\n\n/**\n * @param {String} reportID\n * @param {String} reportActionID\n * @param {String} eventID\n * @param {Object[]} events\n */\nconst removeEvent = (reportID, reportActionID, eventID, events) => {\n const optimisticData = [\n {\n onyxMethod: CONST.ONYX.METHOD.MERGE,\n key: `${ONYXKEYS.COLLECTION.REPORT_ACTIONS}${reportID}`,\n value: {\n [reportActionID]: {\n pendingAction: CONST.RED_BRICK_ROAD_PENDING_ACTION.UPDATE,\n originalMessage: {\n events: _.reject(events, event => event.id === eventID),\n },\n },\n },\n },\n ];\n\n const successData = [\n {\n onyxMethod: CONST.ONYX.METHOD.MERGE,\n key: `${ONYXKEYS.COLLECTION.REPORT_ACTIONS}${reportID}`,\n value: {\n [reportActionID]: {\n pendingAction: null,\n },\n },\n },\n ];\n\n const failureData = [\n {\n onyxMethod: CONST.ONYX.METHOD.MERGE,\n key: `${ONYXKEYS.COLLECTION.REPORT_ACTIONS}${reportID}`,\n value: {\n [reportActionID]: {\n originalMessage: {events},\n pendingAction: null,\n },\n },\n },\n ];\n\n API.write('Chronos_RemoveOOOEvent', {\n googleEventID: eventID,\n reportActionID,\n }, {optimisticData, successData, failureData});\n};\n\nexport {\n // eslint-disable-next-line import/prefer-default-export\n removeEvent,\n};\n","import React from 'react';\nimport _ from 'underscore';\nimport {View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport styles from '../../styles/styles';\nimport EmojiReactionBubble from './EmojiReactionBubble';\nimport emojis from '../../../assets/emojis';\nimport AddReactionBubble from './AddReactionBubble';\nimport getPreferredEmojiCode from './getPreferredEmojiCode';\nimport Tooltip from '../Tooltip';\nimport ReactionTooltipContent from './ReactionTooltipContent';\n\n/**\n * Given an emoji object and a list of senders it will return an\n * array of emoji codes, that represents all used variations of the\n * emoji.\n * @param {{ name: string, code: string, types: string[] }} emoji\n * @param {Array} users\n * @return {string[]}\n * */\nconst getUniqueEmojiCodes = (emoji, users) => {\n const emojiCodes = [];\n _.forEach(users, (user) => {\n const emojiCode = getPreferredEmojiCode(emoji, user.skinTone);\n\n if (emojiCode && !emojiCodes.includes(emojiCode)) {\n emojiCodes.push(emojiCode);\n }\n });\n return emojiCodes;\n};\n\nconst propTypes = {\n /**\n * An array of objects containing the reaction data.\n * The shape of a reaction looks like this:\n *\n * \"reactionName\": {\n * emoji: string,\n * users: {\n * accountID: string,\n * skinTone: number,\n * }[]\n * }\n */\n // eslint-disable-next-line react/forbid-prop-types\n reactions: PropTypes.arrayOf(PropTypes.object).isRequired,\n\n /**\n * Function to call when the user presses on an emoji.\n * This can also be an emoji the user already reacted with,\n * hence this function asks to toggle the reaction by emoji.\n */\n toggleReaction: PropTypes.func.isRequired,\n};\n\nconst ReportActionItemReactions = (props) => {\n const reactionsWithCount = _.filter(props.reactions, reaction => reaction.users.length > 0);\n\n return (\n \n {_.map(reactionsWithCount, (reaction) => {\n const reactionCount = reaction.users.length;\n const reactionUsers = _.map(reaction.users, sender => sender.accountID.toString());\n const emoji = _.find(emojis, e => e.name === reaction.emoji);\n const emojiCodes = getUniqueEmojiCodes(emoji, reaction.users);\n\n const onPress = () => {\n props.toggleReaction(emoji);\n };\n\n return (\n (\n \n )}\n key={reaction.emoji}\n >\n \n \n );\n })}\n {reactionsWithCount.length > 0 && }\n \n );\n};\n\nReportActionItemReactions.displayName = 'ReportActionItemReactions';\nReportActionItemReactions.propTypes = propTypes;\nexport default ReportActionItemReactions;\n","import React from 'react';\nimport {View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport _ from 'underscore';\nimport styles from '../../styles/styles';\nimport {withPersonalDetails} from '../OnyxProvider';\nimport * as PersonalDetailsUtils from '../../libs/PersonalDetailsUtils';\nimport Text from '../Text';\nimport withCurrentUserPersonalDetails, {\n withCurrentUserPersonalDetailsPropTypes,\n} from '../withCurrentUserPersonalDetails';\nimport compose from '../../libs/compose';\nimport withLocalize from '../withLocalize';\n\nconst propTypes = {\n /**\n * A list of emoji codes to display in the tooltip.\n */\n emojiCodes: PropTypes.arrayOf(PropTypes.string).isRequired,\n\n /**\n * The name of the emoji to display in the tooltip.\n */\n emojiName: PropTypes.string.isRequired,\n\n /**\n * A list of account IDs to display in the tooltip.\n */\n accountIDs: PropTypes.arrayOf(PropTypes.string).isRequired,\n\n ...withCurrentUserPersonalDetailsPropTypes,\n};\n\nconst ReactionTooltipContent = (props) => {\n const users = PersonalDetailsUtils.getPersonalDetailsByIDs(props.accountIDs, true);\n const namesString = _.filter(_.map(users, user => user && user.displayName), n => n).join(', ');\n\n return (\n \n \n {_.map(props.emojiCodes, emojiCode => (\n \n {emojiCode}\n \n ))}\n \n\n \n {namesString}\n \n\n \n {`${props.translate('emojiReactions.reactedWith')} :${props.emojiName}:`}\n \n \n );\n};\n\nReactionTooltipContent.propTypes = propTypes;\nReactionTooltipContent.defaultProps = withCurrentUserPersonalDetails;\nReactionTooltipContent.displayName = 'ReactionTooltipContent';\nexport default React.memo(compose(\n withPersonalDetails(),\n withLocalize,\n)(ReactionTooltipContent));\n","import Onyx from 'react-native-onyx';\nimport _ from 'underscore';\nimport ONYXKEYS from '../ONYXKEYS';\nimport * as Report from './actions/Report';\nimport * as Localize from './Localize';\n\nlet personalDetails = [];\nOnyx.connect({\n key: ONYXKEYS.PERSONAL_DETAILS,\n callback: val => personalDetails = _.values(val),\n});\n\n/**\n * Given a list of account IDs (as string) it will return an array of personal details objects.\n * @param {Array} accountIDs - Array of accountIDs\n * @param {boolean} shouldChangeUserDisplayName - It will replace the current user's personal detail object's displayName with 'You'.\n * @returns {Array} - Array of personal detail objects\n */\nfunction getPersonalDetailsByIDs(accountIDs, shouldChangeUserDisplayName = false) {\n const result = [];\n const currentAccountID = Report.getCurrentUserAccountID();\n _.each(personalDetails, (detail) => {\n for (let i = 0; i < accountIDs.length; i++) {\n if (detail.accountID === accountIDs[i]) {\n if (shouldChangeUserDisplayName && currentAccountID.toString() === detail.accountID) {\n result[i] = {\n ...detail,\n displayName: Localize.translateLocal('common.you'),\n };\n } else {\n result[i] = detail;\n }\n break;\n }\n }\n });\n return result;\n}\n\nexport {\n // eslint-disable-next-line import/prefer-default-export\n getPersonalDetailsByIDs,\n};\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport SkeletonViewLines from './SkeletonViewLines';\nimport CONST from '../../CONST';\n\nconst propTypes = {\n /** Height of the container component */\n containerHeight: PropTypes.number.isRequired,\n\n /** Whether to animate the skeleton view */\n shouldAnimate: PropTypes.bool,\n};\n\nconst defaultProps = {\n shouldAnimate: true,\n};\n\nconst ReportActionsSkeletonView = (props) => {\n // Determines the number of content items based on container height\n const possibleVisibleContentItems = Math.ceil(props.containerHeight / CONST.CHAT_SKELETON_VIEW.AVERAGE_ROW_HEIGHT);\n const skeletonViewLines = [];\n for (let index = 0; index < possibleVisibleContentItems; index++) {\n const iconIndex = (index + 1) % 4;\n switch (iconIndex) {\n case 2:\n skeletonViewLines.push();\n break;\n case 0:\n skeletonViewLines.push();\n break;\n default:\n skeletonViewLines.push();\n }\n }\n return <>{skeletonViewLines};\n};\n\nReportActionsSkeletonView.displayName = 'ReportActionsSkeletonView';\nReportActionsSkeletonView.propTypes = propTypes;\nReportActionsSkeletonView.defaultProps = defaultProps;\nexport default ReportActionsSkeletonView;\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport {Rect, Circle} from 'react-native-svg';\nimport SkeletonViewContentLoader from 'react-content-loader/native';\nimport CONST from '../../CONST';\nimport themeColors from '../../styles/themes/default';\nimport styles from '../../styles/styles';\n\nconst propTypes = {\n /** Number of rows to show in Skeleton UI block */\n numberOfRows: PropTypes.number.isRequired,\n shouldAnimate: PropTypes.bool,\n};\n\nconst defaultTypes = {\n shouldAnimate: true,\n};\n\nconst SkeletonViewLines = props => (\n \n \n \n \n {props.numberOfRows > 1 && }\n {props.numberOfRows > 2 && }\n \n);\n\nSkeletonViewLines.displayName = 'SkeletonViewLines';\nSkeletonViewLines.propTypes = propTypes;\nSkeletonViewLines.defaultProps = defaultTypes;\nexport default SkeletonViewLines;\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nfunction _interopDefault (ex) { return (ex && (typeof ex === 'object') && 'default' in ex) ? ex['default'] : ex; }\n\nvar React = require('react');\nvar React__default = _interopDefault(React);\nvar Svg = require('react-native-svg');\nvar Svg__default = _interopDefault(Svg);\nvar reactNative = require('react-native');\n\n/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation. All rights reserved.\r\nLicensed under the Apache License, Version 2.0 (the \"License\"); you may not use\r\nthis file except in compliance with the License. You may obtain a copy of the\r\nLicense at http://www.apache.org/licenses/LICENSE-2.0\r\n\r\nTHIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\r\nKIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED\r\nWARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,\r\nMERCHANTABLITY OR NON-INFRINGEMENT.\r\n\r\nSee the Apache Version 2.0 License for specific language governing permissions\r\nand limitations under the License.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nfunction __extends(d, b) {\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nvar __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n };\r\n return __assign.apply(this, arguments);\r\n};\r\n\r\nfunction __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\n\nvar uid = (function () {\r\n return Math.random()\r\n .toString(36)\r\n .substring(6);\r\n});\n\nvar AnimatedLinearGradient = reactNative.Animated.createAnimatedComponent(Svg.LinearGradient);\r\nvar NativeSvg = /** @class */ (function (_super) {\r\n __extends(NativeSvg, _super);\r\n function NativeSvg() {\r\n var _this = _super !== null && _super.apply(this, arguments) || this;\r\n _this.animatedValue = new reactNative.Animated.Value(-1);\r\n _this.fixedId = _this.props.uniqueKey || uid();\r\n _this.idClip = _this.fixedId + \"-diff\";\r\n _this.idGradient = _this.fixedId + \"-animated-diff\";\r\n _this.unmounted = false;\r\n _this.setAnimation = function () {\r\n // props.speed is in seconds as it is compatible with web\r\n // convert to milliseconds\r\n var durMs = _this.props.speed * 1000;\r\n var delay = durMs * _this.props.interval;\r\n reactNative.Animated.timing(_this.animatedValue, {\r\n toValue: 2,\r\n delay: delay,\r\n duration: durMs,\r\n useNativeDriver: true,\r\n }).start(function () {\r\n if (!_this.unmounted && _this.props.animate) {\r\n _this.animatedValue.setValue(-1);\r\n _this.setAnimation();\r\n }\r\n });\r\n };\r\n _this.componentDidMount = function () {\r\n if (_this.props.animate) {\r\n _this.setAnimation();\r\n }\r\n };\r\n return _this;\r\n }\r\n NativeSvg.prototype.componentDidUpdate = function (prevProps) {\r\n if (!prevProps.animate && this.props.animate) {\r\n this.setAnimation();\r\n }\r\n };\r\n NativeSvg.prototype.componentWillUnmount = function () {\r\n this.unmounted = true;\r\n };\r\n NativeSvg.prototype.render = function () {\r\n var _a = this.props, children = _a.children, backgroundColor = _a.backgroundColor, foregroundColor = _a.foregroundColor, rtl = _a.rtl, style = _a.style, beforeMask = _a.beforeMask, props = __rest(_a, [\"children\", \"backgroundColor\", \"foregroundColor\", \"rtl\", \"style\", \"beforeMask\"]);\r\n var x1Animation = this.animatedValue.interpolate({\r\n extrapolate: 'clamp',\r\n inputRange: [-1, 2],\r\n outputRange: ['-100%', '100%'],\r\n });\r\n var x2Animation = this.animatedValue.interpolate({\r\n extrapolate: 'clamp',\r\n inputRange: [-1, 2],\r\n outputRange: ['0%', '200%'],\r\n });\r\n var rtlStyle = rtl ? { transform: [{ rotateY: '180deg' }] } : {};\r\n var svgStyle = Object.assign(Object.assign({}, style), rtlStyle);\r\n // Remove unnecessary keys\r\n delete props.uniqueKey;\r\n delete props.animate;\r\n delete props.speed;\r\n return (React__default.createElement(Svg__default, __assign({ style: svgStyle }, props),\r\n beforeMask && React.isValidElement(beforeMask) ? beforeMask : null,\r\n React__default.createElement(Svg.Rect, { x: \"0\", y: \"0\", width: \"100%\", height: \"100%\", fill: \"url(#\" + this.idClip + \")\", clipPath: \"url(#\" + this.idGradient + \")\" }),\r\n React__default.createElement(Svg.Defs, null,\r\n React__default.createElement(Svg.ClipPath, { id: this.idGradient }, children),\r\n React__default.createElement(AnimatedLinearGradient, { id: this.idClip, x1: x1Animation, x2: x2Animation, y1: 0, y2: 0 },\r\n React__default.createElement(Svg.Stop, { offset: 0, stopColor: backgroundColor }),\r\n React__default.createElement(Svg.Stop, { offset: 0.5, stopColor: foregroundColor }),\r\n React__default.createElement(Svg.Stop, { offset: 1, stopColor: backgroundColor })))));\r\n };\r\n NativeSvg.defaultProps = {\r\n animate: true,\r\n backgroundColor: '#f5f6f7',\r\n foregroundColor: '#eee',\r\n rtl: false,\r\n speed: 1.2,\r\n interval: 0.25,\r\n style: {},\r\n beforeMask: null,\r\n };\r\n return NativeSvg;\r\n}(React.Component));\n\nvar ContentLoader = function (props) {\r\n return props.children ? React.createElement(NativeSvg, __assign({}, props)) : React.createElement(ReactContentLoaderFacebook, __assign({}, props));\r\n};\n\nvar ReactContentLoaderFacebook = function (props) { return (React.createElement(ContentLoader, __assign({ viewBox: \"0 0 476 124\", width: 476, height: 124 }, props),\r\n React.createElement(Svg.Rect, { x: \"48\", y: \"8\", width: \"88\", height: \"6\", rx: \"3\" }),\r\n React.createElement(Svg.Rect, { x: \"48\", y: \"26\", width: \"52\", height: \"6\", rx: \"3\" }),\r\n React.createElement(Svg.Rect, { x: \"0\", y: \"56\", width: \"410\", height: \"6\", rx: \"3\" }),\r\n React.createElement(Svg.Rect, { x: \"0\", y: \"72\", width: \"380\", height: \"6\", rx: \"3\" }),\r\n React.createElement(Svg.Rect, { x: \"0\", y: \"88\", width: \"178\", height: \"6\", rx: \"3\" }),\r\n React.createElement(Svg.Circle, { cx: \"20\", cy: \"20\", r: \"20\" }))); };\n\nvar ReactContentLoaderInstagram = function (props) { return (React.createElement(ContentLoader, __assign({ viewBox: \"0 0 400 460\", width: 400, height: 460 }, props),\r\n React.createElement(Svg.Circle, { cx: \"31\", cy: \"31\", r: \"15\" }),\r\n React.createElement(Svg.Rect, { x: \"58\", y: \"18\", rx: \"2\", ry: \"2\", width: \"140\", height: \"10\" }),\r\n React.createElement(Svg.Rect, { x: \"58\", y: \"34\", rx: \"2\", ry: \"2\", width: \"140\", height: \"10\" }),\r\n React.createElement(Svg.Rect, { x: \"0\", y: \"60\", rx: \"2\", ry: \"2\", width: \"400\", height: \"400\" }))); };\n\nvar ReactContentLoaderCode = function (props) { return (React.createElement(ContentLoader, __assign({ viewBox: \"0 0 340 84\", width: 340, height: 84 }, props),\r\n React.createElement(Svg.Rect, { x: \"0\", y: \"0\", width: \"67\", height: \"11\", rx: \"3\" }),\r\n React.createElement(Svg.Rect, { x: \"76\", y: \"0\", width: \"140\", height: \"11\", rx: \"3\" }),\r\n React.createElement(Svg.Rect, { x: \"127\", y: \"48\", width: \"53\", height: \"11\", rx: \"3\" }),\r\n React.createElement(Svg.Rect, { x: \"187\", y: \"48\", width: \"72\", height: \"11\", rx: \"3\" }),\r\n React.createElement(Svg.Rect, { x: \"18\", y: \"48\", width: \"100\", height: \"11\", rx: \"3\" }),\r\n React.createElement(Svg.Rect, { x: \"0\", y: \"71\", width: \"37\", height: \"11\", rx: \"3\" }),\r\n React.createElement(Svg.Rect, { x: \"18\", y: \"23\", width: \"140\", height: \"11\", rx: \"3\" }),\r\n React.createElement(Svg.Rect, { x: \"166\", y: \"23\", width: \"173\", height: \"11\", rx: \"3\" }))); };\n\nvar ReactContentLoaderListStyle = function (props) { return (React.createElement(ContentLoader, __assign({ viewBox: \"0 0 400 110\", width: 400, height: 110 }, props),\r\n React.createElement(Svg.Rect, { x: \"0\", y: \"0\", rx: \"3\", ry: \"3\", width: \"250\", height: \"10\" }),\r\n React.createElement(Svg.Rect, { x: \"20\", y: \"20\", rx: \"3\", ry: \"3\", width: \"220\", height: \"10\" }),\r\n React.createElement(Svg.Rect, { x: \"20\", y: \"40\", rx: \"3\", ry: \"3\", width: \"170\", height: \"10\" }),\r\n React.createElement(Svg.Rect, { x: \"0\", y: \"60\", rx: \"3\", ry: \"3\", width: \"250\", height: \"10\" }),\r\n React.createElement(Svg.Rect, { x: \"20\", y: \"80\", rx: \"3\", ry: \"3\", width: \"200\", height: \"10\" }),\r\n React.createElement(Svg.Rect, { x: \"20\", y: \"100\", rx: \"3\", ry: \"3\", width: \"80\", height: \"10\" }))); };\n\nvar ReactContentLoaderBulletList = function (props) { return (React.createElement(ContentLoader, __assign({ viewBox: \"0 0 245 125\", width: 245, height: 125 }, props),\r\n React.createElement(Svg.Circle, { cx: \"10\", cy: \"20\", r: \"8\" }),\r\n React.createElement(Svg.Rect, { x: \"25\", y: \"15\", rx: \"5\", ry: \"5\", width: \"220\", height: \"10\" }),\r\n React.createElement(Svg.Circle, { cx: \"10\", cy: \"50\", r: \"8\" }),\r\n React.createElement(Svg.Rect, { x: \"25\", y: \"45\", rx: \"5\", ry: \"5\", width: \"220\", height: \"10\" }),\r\n React.createElement(Svg.Circle, { cx: \"10\", cy: \"80\", r: \"8\" }),\r\n React.createElement(Svg.Rect, { x: \"25\", y: \"75\", rx: \"5\", ry: \"5\", width: \"220\", height: \"10\" }),\r\n React.createElement(Svg.Circle, { cx: \"10\", cy: \"110\", r: \"8\" }),\r\n React.createElement(Svg.Rect, { x: \"25\", y: \"105\", rx: \"5\", ry: \"5\", width: \"220\", height: \"10\" }))); };\n\nObject.defineProperty(exports, 'Circle', {\n enumerable: true,\n get: function () {\n return Svg.Circle;\n }\n});\nObject.defineProperty(exports, 'Path', {\n enumerable: true,\n get: function () {\n return Svg.Path;\n }\n});\nObject.defineProperty(exports, 'Rect', {\n enumerable: true,\n get: function () {\n return Svg.Rect;\n }\n});\nexports.BulletList = ReactContentLoaderBulletList;\nexports.Code = ReactContentLoaderCode;\nexports.Facebook = ReactContentLoaderFacebook;\nexports.Instagram = ReactContentLoaderInstagram;\nexports.List = ReactContentLoaderListStyle;\nexports.default = ContentLoader;\n//# sourceMappingURL=react-content-loader.native.cjs.js.map\n","import React from 'react';\nimport ExpensiMark from 'expensify-common/lib/ExpensiMark';\nimport Str from 'expensify-common/lib/str';\nimport CONST from '../CONST';\nimport KeyboardShortcut from '../libs/KeyboardShortcut';\nimport Clipboard from '../libs/Clipboard';\nimport SelectionScraper from '../libs/SelectionScraper';\n\nclass CopySelectionHelper extends React.Component {\n componentDidMount() {\n const copyShortcutConfig = CONST.KEYBOARD_SHORTCUTS.COPY;\n this.unsubscribeCopyShortcut = KeyboardShortcut.subscribe(\n copyShortcutConfig.shortcutKey,\n this.copySelectionToClipboard,\n copyShortcutConfig.descriptionKey,\n copyShortcutConfig.modifiers,\n false,\n );\n }\n\n componentWillUnmount() {\n if (!this.unsubscribeCopyShortcut) {\n return;\n }\n\n this.unsubscribeCopyShortcut();\n }\n\n copySelectionToClipboard() {\n const selection = SelectionScraper.getCurrentSelection();\n if (!selection) {\n return;\n }\n const parser = new ExpensiMark();\n if (!Clipboard.canSetHtml()) {\n Clipboard.setString(parser.htmlToMarkdown(selection));\n return;\n }\n\n Clipboard.setHtml(selection, Str.htmlDecode(parser.htmlToText(selection)));\n }\n\n render() {\n return null;\n }\n}\n\nexport default CopySelectionHelper;\n","import Visibility from './Visibility';\n\n/**\n * When the app is visible and the LHN is not opening in small-screen devices we can assume that the report is fully visible.\n *\n * @param {Boolean} isDrawerOpen\n * @param {Boolean} isSmallScreenWidth\n *\n * @returns {Boolean}\n */\nexport default function getIsReportFullyVisible(isDrawerOpen, isSmallScreenWidth) {\n const isSidebarCoveringReportView = isSmallScreenWidth && isDrawerOpen;\n return Visibility.isVisible() && !isSidebarCoveringReportView;\n}\n","import React from 'react';\nimport _ from 'underscore';\nimport PropTypes from 'prop-types';\nimport {withOnyx} from 'react-native-onyx';\nimport {View, Keyboard} from 'react-native';\nimport CONST from '../../../CONST';\nimport ReportActionCompose from './ReportActionCompose';\nimport SwipeableView from '../../../components/SwipeableView';\nimport OfflineIndicator from '../../../components/OfflineIndicator';\nimport ArchivedReportFooter from '../../../components/ArchivedReportFooter';\nimport compose from '../../../libs/compose';\nimport ONYXKEYS from '../../../ONYXKEYS';\nimport withWindowDimensions, {windowDimensionsPropTypes} from '../../../components/withWindowDimensions';\nimport styles from '../../../styles/styles';\nimport reportActionPropTypes from './reportActionPropTypes';\nimport reportPropTypes from '../../reportPropTypes';\nimport * as ReportUtils from '../../../libs/ReportUtils';\n\nconst propTypes = {\n /** Report object for the current report */\n report: reportPropTypes,\n\n /** Report actions for the current report */\n reportActions: PropTypes.arrayOf(PropTypes.shape(reportActionPropTypes)),\n\n /** Offline status */\n isOffline: PropTypes.bool.isRequired,\n\n /** Callback fired when the comment is submitted */\n onSubmitComment: PropTypes.func,\n\n /** Any errors associated with an attempt to create a chat */\n // eslint-disable-next-line react/forbid-prop-types\n errors: PropTypes.object,\n\n /** The pending action when we are adding a chat */\n pendingAction: PropTypes.string,\n\n /** Whether the composer input should be shown */\n shouldShowComposeInput: PropTypes.bool,\n\n /** Whether user interactions should be disabled */\n shouldDisableCompose: PropTypes.bool,\n\n ...windowDimensionsPropTypes,\n};\n\nconst defaultProps = {\n report: {reportID: '0'},\n reportActions: [],\n onSubmitComment: () => {},\n errors: {},\n pendingAction: null,\n shouldShowComposeInput: true,\n shouldDisableCompose: false,\n};\n\nclass ReportFooter extends React.Component {\n /**\n * @returns {Object}\n */\n getChatFooterStyles() {\n return {...styles.chatFooter, minHeight: !this.props.isOffline ? CONST.CHAT_FOOTER_MIN_HEIGHT : 0};\n }\n\n render() {\n const isArchivedRoom = ReportUtils.isArchivedRoom(this.props.report);\n const hideComposer = isArchivedRoom || !_.isEmpty(this.props.errors);\n\n return (\n <>\n {(isArchivedRoom || hideComposer) && (\n \n {isArchivedRoom && (\n \n )}\n {!this.props.isSmallScreenWidth && (\n \n {hideComposer && (\n \n )}\n \n )}\n \n )}\n {(!hideComposer && this.props.shouldShowComposeInput) && (\n \n \n \n \n \n )}\n \n );\n }\n}\n\nReportFooter.propTypes = propTypes;\nReportFooter.defaultProps = defaultProps;\nexport default compose(\n withWindowDimensions,\n withOnyx({\n shouldShowComposeInput: {key: ONYXKEYS.SHOULD_SHOW_COMPOSE_INPUT},\n }),\n)(ReportFooter);\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport {\n View,\n TouchableOpacity,\n InteractionManager,\n LayoutAnimation,\n} from 'react-native';\nimport _ from 'underscore';\nimport lodashGet from 'lodash/get';\nimport {withOnyx} from 'react-native-onyx';\nimport styles from '../../../styles/styles';\nimport themeColors from '../../../styles/themes/default';\nimport Composer from '../../../components/Composer';\nimport ONYXKEYS from '../../../ONYXKEYS';\nimport Icon from '../../../components/Icon';\nimport * as Expensicons from '../../../components/Icon/Expensicons';\nimport AttachmentPicker from '../../../components/AttachmentPicker';\nimport * as Report from '../../../libs/actions/Report';\nimport ReportTypingIndicator from './ReportTypingIndicator';\nimport AttachmentModal from '../../../components/AttachmentModal';\nimport compose from '../../../libs/compose';\nimport PopoverMenu from '../../../components/PopoverMenu';\nimport withWindowDimensions, {windowDimensionsPropTypes} from '../../../components/withWindowDimensions';\nimport withDrawerState from '../../../components/withDrawerState';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport willBlurTextInputOnTapOutside from '../../../libs/willBlurTextInputOnTapOutside';\nimport CONST from '../../../CONST';\nimport Navigation from '../../../libs/Navigation/Navigation';\nimport ROUTES from '../../../ROUTES';\nimport reportActionPropTypes from './reportActionPropTypes';\nimport * as ReportUtils from '../../../libs/ReportUtils';\nimport ReportActionComposeFocusManager from '../../../libs/ReportActionComposeFocusManager';\nimport participantPropTypes from '../../../components/participantPropTypes';\nimport ParticipantLocalTime from './ParticipantLocalTime';\nimport withCurrentUserPersonalDetails, {withCurrentUserPersonalDetailsPropTypes, withCurrentUserPersonalDetailsDefaultProps} from '../../../components/withCurrentUserPersonalDetails';\nimport {withNetwork, withPersonalDetails} from '../../../components/OnyxProvider';\nimport * as User from '../../../libs/actions/User';\nimport Tooltip from '../../../components/Tooltip';\nimport EmojiPickerButton from '../../../components/EmojiPicker/EmojiPickerButton';\nimport * as DeviceCapabilities from '../../../libs/DeviceCapabilities';\nimport toggleReportActionComposeView from '../../../libs/toggleReportActionComposeView';\nimport OfflineIndicator from '../../../components/OfflineIndicator';\nimport ExceededCommentLength from '../../../components/ExceededCommentLength';\nimport withNavigationFocus from '../../../components/withNavigationFocus';\nimport * as EmojiUtils from '../../../libs/EmojiUtils';\nimport ReportDropUI from './ReportDropUI';\nimport DragAndDrop from '../../../components/DragAndDrop';\nimport reportPropTypes from '../../reportPropTypes';\nimport EmojiSuggestions from '../../../components/EmojiSuggestions';\nimport withKeyboardState, {keyboardStatePropTypes} from '../../../components/withKeyboardState';\nimport ArrowKeyFocusManager from '../../../components/ArrowKeyFocusManager';\nimport OfflineWithFeedback from '../../../components/OfflineWithFeedback';\nimport KeyboardShortcut from '../../../libs/KeyboardShortcut';\n\nconst propTypes = {\n /** Beta features list */\n betas: PropTypes.arrayOf(PropTypes.string),\n\n /** A method to call when the form is submitted */\n onSubmit: PropTypes.func.isRequired,\n\n /** The comment left by the user */\n comment: PropTypes.string,\n\n /** Number of lines for the comment */\n numberOfLines: PropTypes.number,\n\n /** The ID of the report actions will be created for */\n reportID: PropTypes.string.isRequired,\n\n /** Details about any modals being used */\n modal: PropTypes.shape({\n /** Indicates if there is a modal currently visible or not */\n isVisible: PropTypes.bool,\n }),\n\n /** Personal details of all the users */\n personalDetails: PropTypes.objectOf(participantPropTypes),\n\n /** The report currently being looked at */\n report: reportPropTypes,\n\n /** Array of report actions for this report */\n reportActions: PropTypes.arrayOf(PropTypes.shape(reportActionPropTypes)),\n\n /** Is the report view covered by the drawer */\n isDrawerOpen: PropTypes.bool.isRequired,\n\n /** Is the window width narrow, like on a mobile device */\n isSmallScreenWidth: PropTypes.bool.isRequired,\n\n /** Is composer screen focused */\n isFocused: PropTypes.bool.isRequired,\n\n /** Is composer full size */\n isComposerFullSize: PropTypes.bool,\n\n /** Whether user interactions should be disabled */\n disabled: PropTypes.bool,\n\n // The NVP describing a user's block status\n blockedFromConcierge: PropTypes.shape({\n // The date that the user will be unblocked\n expiresAt: PropTypes.string,\n }),\n\n /** Stores user's preferred skin tone */\n preferredSkinTone: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n\n /** User's frequently used emojis */\n frequentlyUsedEmojis: PropTypes.arrayOf(PropTypes.shape({\n code: PropTypes.string.isRequired,\n keywords: PropTypes.arrayOf(PropTypes.string),\n })),\n\n /** The type of action that's pending */\n pendingAction: PropTypes.oneOf(['add', 'update', 'delete']),\n\n ...windowDimensionsPropTypes,\n ...withLocalizePropTypes,\n ...withCurrentUserPersonalDetailsPropTypes,\n ...keyboardStatePropTypes,\n};\n\nconst defaultProps = {\n betas: [],\n comment: '',\n numberOfLines: undefined,\n modal: {},\n report: {},\n reportActions: [],\n blockedFromConcierge: {},\n personalDetails: {},\n preferredSkinTone: CONST.EMOJI_DEFAULT_SKIN_TONE,\n frequentlyUsedEmojis: [],\n isComposerFullSize: false,\n pendingAction: null,\n ...withCurrentUserPersonalDetailsDefaultProps,\n};\n\n/**\n * Return the max available index for arrow manager.\n * @param {Number} numRows\n * @param {Boolean} isEmojiPickerLarge\n * @returns {Number}\n */\nconst getMaxArrowIndex = (numRows, isEmojiPickerLarge) => {\n // EmojiRowCount is number of emoji suggestions. For small screen we can fit 3 items and for large we show up to 5 items\n const emojiRowCount = isEmojiPickerLarge\n ? Math.max(numRows, CONST.EMOJI_SUGGESTER.MAX_AMOUNT_OF_ITEMS)\n : Math.max(numRows, CONST.EMOJI_SUGGESTER.MIN_AMOUNT_OF_ITEMS);\n\n // -1 because we start at 0\n return emojiRowCount - 1;\n};\n\nclass ReportActionCompose extends React.Component {\n constructor(props) {\n super(props);\n this.calculateEmojiSuggestion = _.debounce(this.calculateEmojiSuggestion, 10, false);\n this.updateComment = this.updateComment.bind(this);\n this.debouncedSaveReportComment = _.debounce(this.debouncedSaveReportComment.bind(this), 1000, false);\n this.debouncedBroadcastUserIsTyping = _.debounce(this.debouncedBroadcastUserIsTyping.bind(this), 100, true);\n this.triggerHotkeyActions = this.triggerHotkeyActions.bind(this);\n this.submitForm = this.submitForm.bind(this);\n this.setIsFocused = this.setIsFocused.bind(this);\n this.setIsFullComposerAvailable = this.setIsFullComposerAvailable.bind(this);\n this.focus = this.focus.bind(this);\n this.addEmojiToTextBox = this.addEmojiToTextBox.bind(this);\n this.onSelectionChange = this.onSelectionChange.bind(this);\n this.isEmojiCode = this.isEmojiCode.bind(this);\n this.setTextInputRef = this.setTextInputRef.bind(this);\n this.getInputPlaceholder = this.getInputPlaceholder.bind(this);\n this.getMoneyRequestOptions = this.getMoneyRequestOptions.bind(this);\n this.addAttachment = this.addAttachment.bind(this);\n this.insertSelectedEmoji = this.insertSelectedEmoji.bind(this);\n this.setExceededMaxCommentLength = this.setExceededMaxCommentLength.bind(this);\n this.updateNumberOfLines = this.updateNumberOfLines.bind(this);\n this.comment = props.comment;\n\n // React Native will retain focus on an input for native devices but web/mWeb behave differently so we have some focus management\n // code that will refocus the compose input after a user closes a modal or some other actions, see usage of ReportActionComposeFocusManager\n this.willBlurTextInputOnTapOutside = willBlurTextInputOnTapOutside();\n\n this.state = {\n isFocused: this.willBlurTextInputOnTapOutside && !this.props.modal.isVisible && !this.props.modal.willAlertModalBecomeVisible,\n isFullComposerAvailable: props.isComposerFullSize,\n textInputShouldClear: false,\n isCommentEmpty: props.comment.length === 0,\n isMenuVisible: false,\n isDraggingOver: false,\n selection: {\n start: props.comment.length,\n end: props.comment.length,\n },\n maxLines: props.isSmallScreenWidth ? CONST.COMPOSER.MAX_LINES_SMALL_SCREEN : CONST.COMPOSER.MAX_LINES,\n value: props.comment,\n\n // If we are on a small width device then don't show last 3 items from conciergePlaceholderOptions\n conciergePlaceholderRandomIndex: _.random(this.props.translate('reportActionCompose.conciergePlaceholderOptions').length - (this.props.isSmallScreenWidth ? 4 : 1)),\n suggestedEmojis: [],\n highlightedEmojiIndex: 0,\n colonIndex: -1,\n shouldShowSuggestionMenu: false,\n isEmojiPickerLarge: false,\n composerHeight: 0,\n hasExceededMaxCommentLength: false,\n };\n }\n\n componentDidMount() {\n // This callback is used in the contextMenuActions to manage giving focus back to the compose input.\n // TODO: we should clean up this convoluted code and instead move focus management to something like ReportFooter.js or another higher up component\n ReportActionComposeFocusManager.onComposerFocus(() => {\n if (!this.willBlurTextInputOnTapOutside || !this.props.isFocused) {\n return;\n }\n\n this.focus(false);\n });\n\n const shortcutConfig = CONST.KEYBOARD_SHORTCUTS.ESCAPE;\n this.unsubscribeEscapeKey = KeyboardShortcut.subscribe(shortcutConfig.shortcutKey, () => {\n if (!this.state.isFocused || this.comment.length === 0) {\n return;\n }\n\n this.updateComment('', true);\n }, shortcutConfig.descriptionKey, shortcutConfig.modifiers, true, true);\n\n this.setMaxLines();\n this.updateComment(this.comment);\n }\n\n componentDidUpdate(prevProps) {\n const sidebarOpened = !prevProps.isDrawerOpen && this.props.isDrawerOpen;\n if (sidebarOpened) {\n toggleReportActionComposeView(true);\n }\n\n // We want to focus or refocus the input when a modal has been closed and the underlying screen is focused.\n // We avoid doing this on native platforms since the software keyboard popping\n // open creates a jarring and broken UX.\n if (this.willBlurTextInputOnTapOutside && this.props.isFocused\n && prevProps.modal.isVisible && !this.props.modal.isVisible) {\n this.focus();\n }\n\n if (this.props.isComposerFullSize !== prevProps.isComposerFullSize) {\n this.setMaxLines();\n }\n\n // Value state does not have the same value as comment props when the comment gets changed from another tab.\n // In this case, we should synchronize the value between tabs.\n const shouldSyncComment = prevProps.comment !== this.props.comment && this.state.value !== this.props.comment;\n\n // As the report IDs change, make sure to update the composer comment as we need to make sure\n // we do not show incorrect data in there (ie. draft of message from other report).\n if (this.props.report.reportID === prevProps.report.reportID && !shouldSyncComment) {\n return;\n }\n\n this.updateComment(this.props.comment);\n }\n\n componentWillUnmount() {\n ReportActionComposeFocusManager.clear();\n\n if (this.unsubscribeEscapeKey) {\n this.unsubscribeEscapeKey();\n }\n }\n\n onSelectionChange(e) {\n this.setState({selection: e.nativeEvent.selection});\n this.calculateEmojiSuggestion();\n }\n\n /**\n * Updates the Highlight state of the composer\n *\n * @param {Boolean} shouldHighlight\n */\n setIsFocused(shouldHighlight) {\n this.setState({isFocused: shouldHighlight});\n }\n\n setIsFullComposerAvailable(isFullComposerAvailable) {\n this.setState({isFullComposerAvailable});\n }\n\n /**\n * Updates the should clear state of the composer\n *\n * @param {Boolean} shouldClear\n */\n setTextInputShouldClear(shouldClear) {\n this.setState({textInputShouldClear: shouldClear});\n }\n\n /**\n * Updates the visibility state of the menu\n *\n * @param {Boolean} isMenuVisible\n */\n setMenuVisibility(isMenuVisible) {\n this.setState({isMenuVisible});\n }\n\n /**\n * Set the TextInput Ref\n *\n * @param {Element} el\n * @memberof ReportActionCompose\n */\n setTextInputRef(el) {\n ReportActionComposeFocusManager.composerRef.current = el;\n this.textInput = el;\n }\n\n /**\n * Get the placeholder to display in the chat input.\n *\n * @return {String}\n */\n getInputPlaceholder() {\n if (ReportUtils.chatIncludesConcierge(this.props.report)) {\n if (User.isBlockedFromConcierge(this.props.blockedFromConcierge)) {\n return this.props.translate('reportActionCompose.blockedFromConcierge');\n }\n\n return this.props.translate('reportActionCompose.conciergePlaceholderOptions')[this.state.conciergePlaceholderRandomIndex];\n }\n\n return this.props.translate('reportActionCompose.writeSomething');\n }\n\n /**\n * Returns the list of IOU Options\n *\n * @param {Array} reportParticipants\n * @returns {Array}\n */\n getMoneyRequestOptions(reportParticipants) {\n const options = {\n [CONST.IOU.MONEY_REQUEST_TYPE.SPLIT]: {\n icon: Expensicons.Receipt,\n text: this.props.translate('iou.splitBill'),\n onSelected: () => Navigation.navigate(ROUTES.getIouSplitRoute(this.props.reportID)),\n },\n [CONST.IOU.MONEY_REQUEST_TYPE.REQUEST]: {\n icon: Expensicons.MoneyCircle,\n text: this.props.translate('iou.requestMoney'),\n onSelected: () => Navigation.navigate(ROUTES.getIouRequestRoute(this.props.reportID)),\n },\n [CONST.IOU.MONEY_REQUEST_TYPE.SEND]: {\n icon: Expensicons.Send,\n text: this.props.translate('iou.sendMoney'),\n onSelected: () => Navigation.navigate(ROUTES.getIOUSendRoute(this.props.reportID)),\n },\n };\n return _.map(ReportUtils.getMoneyRequestOptions(this.props.report, reportParticipants, this.props.betas), option => options[option]);\n }\n\n /**\n * Updates the composer when the comment length is exceeded\n * Shows red borders and prevents the comment from being sent\n *\n * @param {Boolean} hasExceededMaxCommentLength\n */\n setExceededMaxCommentLength(hasExceededMaxCommentLength) {\n this.setState({hasExceededMaxCommentLength});\n }\n\n /**\n * Set the maximum number of lines for the composer\n */\n setMaxLines() {\n let maxLines = this.props.isSmallScreenWidth ? CONST.COMPOSER.MAX_LINES_SMALL_SCREEN : CONST.COMPOSER.MAX_LINES;\n if (this.props.isComposerFullSize) {\n maxLines = CONST.COMPOSER.MAX_LINES_FULL;\n }\n this.setState({maxLines});\n }\n\n // eslint-disable-next-line rulesdir/prefer-early-return\n setShouldShowSuggestionMenuToFalse() {\n if (this.state && this.state.shouldShowSuggestionMenu) {\n this.setState({shouldShowSuggestionMenu: false});\n }\n }\n\n /**\n * Clean data related to EmojiSuggestions\n */\n resetSuggestedEmojis() {\n this.setState({\n suggestedEmojis: [],\n shouldShowSuggestionMenu: false,\n });\n }\n\n /**\n * Calculates and cares about the content of an Emoji Suggester\n */\n calculateEmojiSuggestion() {\n const leftString = this.state.value.substring(0, this.state.selection.end);\n const colonIndex = leftString.lastIndexOf(':');\n const isCurrentlyShowingEmojiSuggestion = this.isEmojiCode(this.state.value, this.state.selection.end);\n\n // the larger composerHeight the less space for EmojiPicker, Pixel 2 has pretty small screen and this value equal 5.3\n const hasEnoughSpaceForLargeSuggestion = this.props.windowHeight / this.state.composerHeight >= 6.8;\n const isEmojiPickerLarge = !this.props.isSmallScreenWidth || (this.props.isSmallScreenWidth && hasEnoughSpaceForLargeSuggestion);\n\n const nextState = {\n suggestedEmojis: [],\n highlightedEmojiIndex: 0,\n colonIndex,\n shouldShowSuggestionMenu: false,\n isEmojiPickerLarge,\n };\n const newSuggestedEmojis = EmojiUtils.suggestEmojis(leftString);\n\n if (newSuggestedEmojis.length && isCurrentlyShowingEmojiSuggestion) {\n nextState.suggestedEmojis = newSuggestedEmojis;\n nextState.shouldShowSuggestionMenu = !_.isEmpty(newSuggestedEmojis);\n }\n\n LayoutAnimation.configureNext(LayoutAnimation.create(50, LayoutAnimation.Types.easeInEaseOut, LayoutAnimation.Properties.opacity));\n\n this.setState(nextState);\n }\n\n /**\n * Check if this piece of string looks like an emoji\n * @param {String} str\n * @param {Number} pos\n * @returns {Boolean}\n */\n isEmojiCode(str, pos) {\n const leftWords = str.slice(0, pos).split(CONST.REGEX.NEW_LINE_OR_WHITE_SPACE);\n const leftWord = _.last(leftWords);\n\n return CONST.REGEX.HAS_COLON_ONLY_AT_THE_BEGINNING.test(leftWord) && leftWord.length > 2;\n }\n\n /**\n * Replace the code of emoji and update selection\n * @param {Number} highlightedEmojiIndex\n */\n insertSelectedEmoji(highlightedEmojiIndex) {\n const commentBeforeColon = this.state.value.slice(0, this.state.colonIndex);\n const emojiObject = this.state.suggestedEmojis[highlightedEmojiIndex];\n const emojiCode = emojiObject.types && emojiObject.types[this.props.preferredSkinTone] ? emojiObject.types[this.props.preferredSkinTone] : emojiObject.code;\n const commentAfterColonWithEmojiNameRemoved = this.state.value.slice(this.state.selection.end).replace(CONST.REGEX.EMOJI_REPLACER, CONST.SPACE);\n\n this.updateComment(`${commentBeforeColon}${emojiCode} ${commentAfterColonWithEmojiNameRemoved}`, true);\n this.setState(prevState => ({\n selection: {\n start: prevState.colonIndex + emojiCode.length + CONST.SPACE_LENGTH,\n end: prevState.colonIndex + emojiCode.length + CONST.SPACE_LENGTH,\n },\n suggestedEmojis: [],\n }));\n EmojiUtils.addToFrequentlyUsedEmojis(this.props.frequentlyUsedEmojis, emojiObject);\n }\n\n isEmptyChat() {\n return _.size(this.props.reportActions) === 1;\n }\n\n /**\n * Callback for the emoji picker to add whatever emoji is chosen into the main input\n *\n * @param {String} emoji\n */\n addEmojiToTextBox(emoji) {\n const emojiWithSpace = `${emoji} `;\n const newComment = this.comment.slice(0, this.state.selection.start)\n + emojiWithSpace\n + this.comment.slice(this.state.selection.end, this.comment.length);\n this.setState(prevState => ({\n selection: {\n start: prevState.selection.start + emojiWithSpace.length,\n end: prevState.selection.start + emojiWithSpace.length,\n },\n }));\n this.updateComment(newComment);\n }\n\n /**\n * Focus the composer text input\n * @param {Boolean} [shouldelay=false] Impose delay before focusing the composer\n * @memberof ReportActionCompose\n */\n focus(shouldelay = false) {\n // There could be other animations running while we trigger manual focus.\n // This prevents focus from making those animations janky.\n InteractionManager.runAfterInteractions(() => {\n if (!this.textInput) {\n return;\n }\n\n if (!shouldelay) {\n this.textInput.focus();\n } else {\n // Keyboard is not opened after Emoji Picker is closed\n // SetTimeout is used as a workaround\n // https://github.com/react-native-modal/react-native-modal/issues/114\n // We carefully choose a delay. 100ms is found enough for keyboard to open.\n setTimeout(() => this.textInput.focus(), 100);\n }\n });\n }\n\n /**\n * Save our report comment in Onyx. We debounce this method in the constructor so that it's not called too often\n * to update Onyx and re-render this component.\n *\n * @param {String} comment\n */\n debouncedSaveReportComment(comment) {\n Report.saveReportComment(this.props.reportID, comment || '');\n }\n\n /**\n * Broadcast that the user is typing. We debounce this method in the constructor to limit how often we publish\n * client events.\n */\n debouncedBroadcastUserIsTyping() {\n Report.broadcastUserIsTyping(this.props.reportID);\n }\n\n /**\n * Update the value of the comment in Onyx\n *\n * @param {String} comment\n * @param {Boolean} shouldDebounceSaveComment\n */\n updateComment(comment, shouldDebounceSaveComment) {\n const newComment = EmojiUtils.replaceEmojis(comment, this.props.isSmallScreenWidth, this.props.preferredSkinTone);\n this.setState((prevState) => {\n const newState = {\n isCommentEmpty: !!newComment.match(/^(\\s)*$/),\n value: newComment,\n };\n if (comment !== newComment) {\n const remainder = prevState.value.slice(prevState.selection.end).length;\n newState.selection = {\n start: newComment.length - remainder,\n end: newComment.length - remainder,\n };\n }\n return newState;\n });\n\n // Indicate that draft has been created.\n if (this.comment.length === 0 && newComment.length !== 0) {\n Report.setReportWithDraft(this.props.reportID, true);\n }\n\n // The draft has been deleted.\n if (newComment.length === 0) {\n Report.setReportWithDraft(this.props.reportID, false);\n }\n\n this.comment = newComment;\n if (shouldDebounceSaveComment) {\n this.debouncedSaveReportComment(newComment);\n } else {\n Report.saveReportComment(this.props.reportID, newComment || '');\n }\n if (newComment) {\n this.debouncedBroadcastUserIsTyping();\n }\n }\n\n /**\n * Update the number of lines for a comment in Onyx\n * @param {Number} numberOfLines\n */\n updateNumberOfLines(numberOfLines) {\n Report.saveReportCommentNumberOfLines(this.props.reportID, numberOfLines);\n }\n\n /**\n * Listens for keyboard shortcuts and applies the action\n *\n * @param {Object} e\n */\n triggerHotkeyActions(e) {\n // Do not trigger actions for mobileWeb or native clients that have the keyboard open because for those devices, we want the return key to insert newlines rather than submit the form\n if (!e || this.props.isSmallScreenWidth || this.props.isKeyboardShown) {\n return;\n }\n\n if ((e.key === CONST.KEYBOARD_SHORTCUTS.ENTER.shortcutKey || e.key === CONST.KEYBOARD_SHORTCUTS.TAB.shortcutKey) && this.state.suggestedEmojis.length) {\n e.preventDefault();\n this.insertSelectedEmoji(this.state.highlightedEmojiIndex);\n return;\n }\n if (e.key === CONST.KEYBOARD_SHORTCUTS.ESCAPE.shortcutKey && this.state.suggestedEmojis.length) {\n e.preventDefault();\n this.resetSuggestedEmojis();\n return;\n }\n\n // Submit the form when Enter is pressed\n if (e.key === CONST.KEYBOARD_SHORTCUTS.ENTER.shortcutKey && !e.shiftKey) {\n e.preventDefault();\n this.submitForm();\n }\n\n // Trigger the edit box for last sent message if ArrowUp is pressed and the comment is empty and Chronos is not in the participants\n if (\n e.key === CONST.KEYBOARD_SHORTCUTS.ARROW_UP.shortcutKey && this.textInput.selectionStart === 0 && this.state.isCommentEmpty && !ReportUtils.chatIncludesChronos(this.props.report)\n ) {\n e.preventDefault();\n\n const lastReportAction = _.find(\n this.props.reportActions,\n action => ReportUtils.canEditReportAction(action),\n );\n\n if (lastReportAction !== -1 && lastReportAction) {\n Report.saveReportActionDraft(this.props.reportID, lastReportAction.reportActionID, _.last(lastReportAction.message).html);\n }\n }\n }\n\n /**\n * @returns {String}\n */\n prepareCommentAndResetComposer() {\n const trimmedComment = this.comment.trim();\n\n // Don't submit empty comments or comments that exceed the character limit\n if (this.state.isCommentEmpty || ReportUtils.getCommentLength(trimmedComment) > CONST.MAX_COMMENT_LENGTH) {\n return '';\n }\n\n this.updateComment('');\n this.setTextInputShouldClear(true);\n if (this.props.isComposerFullSize) {\n Report.setIsComposerFullSize(this.props.reportID, false);\n }\n this.setState({isFullComposerAvailable: false});\n\n return trimmedComment;\n }\n\n /**\n * @param {Object} file\n */\n addAttachment(file) {\n // Since we're submitting the form here which should clear the composer\n // We don't really care about saving the draft the user was typing\n // We need to make sure an empty draft gets saved instead\n this.debouncedSaveReportComment.cancel();\n const comment = this.prepareCommentAndResetComposer();\n Report.addAttachment(this.props.reportID, file, comment);\n this.setTextInputShouldClear(false);\n }\n\n /**\n * Add a new comment to this chat\n *\n * @param {SyntheticEvent} [e]\n */\n submitForm(e) {\n if (e) {\n e.preventDefault();\n }\n\n // Since we're submitting the form here which should clear the composer\n // We don't really care about saving the draft the user was typing\n // We need to make sure an empty draft gets saved instead\n this.debouncedSaveReportComment.cancel();\n\n const comment = this.prepareCommentAndResetComposer();\n if (!comment) {\n return;\n }\n\n this.props.onSubmit(comment);\n }\n\n render() {\n const reportParticipants = _.without(lodashGet(this.props.report, 'participants', []), this.props.currentUserPersonalDetails.login);\n const participantsWithoutExpensifyEmails = _.difference(reportParticipants, CONST.EXPENSIFY_EMAILS);\n const reportRecipient = this.props.personalDetails[participantsWithoutExpensifyEmails[0]];\n\n const shouldShowReportRecipientLocalTime = ReportUtils.canShowReportRecipientLocalTime(this.props.personalDetails, this.props.report)\n && !this.props.isComposerFullSize;\n\n // Prevents focusing and showing the keyboard while the drawer is covering the chat.\n const isComposeDisabled = this.props.isDrawerOpen && this.props.isSmallScreenWidth;\n const isBlockedFromConcierge = ReportUtils.chatIncludesConcierge(this.props.report) && User.isBlockedFromConcierge(this.props.blockedFromConcierge);\n const inputPlaceholder = this.getInputPlaceholder();\n const shouldUseFocusedColor = !isBlockedFromConcierge && !this.props.disabled && (this.state.isFocused || this.state.isDraggingOver);\n const hasExceededMaxCommentLength = this.state.hasExceededMaxCommentLength;\n\n return (\n \n \n {shouldShowReportRecipientLocalTime && }\n \n \n {({displayFileInModal}) => (\n <>\n \n {({openPicker}) => (\n <>\n \n {this.props.isComposerFullSize && (\n \n {\n e.preventDefault();\n this.setShouldShowSuggestionMenuToFalse();\n Report.setIsComposerFullSize(this.props.reportID, false);\n }}\n\n // Keep focus on the composer when Collapse button is clicked.\n onMouseDown={e => e.preventDefault()}\n style={styles.composerSizeButton}\n disabled={isBlockedFromConcierge || this.props.disabled}\n >\n \n \n \n\n )}\n {(!this.props.isComposerFullSize && this.state.isFullComposerAvailable) && (\n \n {\n e.preventDefault();\n this.setShouldShowSuggestionMenuToFalse();\n Report.setIsComposerFullSize(this.props.reportID, true);\n }}\n\n // Keep focus on the composer when Expand button is clicked.\n onMouseDown={e => e.preventDefault()}\n style={styles.composerSizeButton}\n disabled={isBlockedFromConcierge || this.props.disabled}\n >\n \n \n \n )}\n \n this.actionButton = el}\n onPress={(e) => {\n e.preventDefault();\n\n // Drop focus to avoid blue focus ring.\n this.actionButton.blur();\n this.setMenuVisibility(true);\n }}\n style={styles.composerSizeButton}\n disabled={isBlockedFromConcierge || this.props.disabled}\n >\n \n \n \n \n this.setMenuVisibility(false)}\n onItemSelected={() => this.setMenuVisibility(false)}\n anchorPosition={styles.createMenuPositionReportActionCompose}\n menuItems={[...this.getMoneyRequestOptions(reportParticipants),\n {\n icon: Expensicons.Paperclip,\n text: this.props.translate('reportActionCompose.addAttachment'),\n onSelected: () => {\n openPicker({\n onPicked: displayFileInModal,\n });\n },\n },\n ]}\n />\n \n )}\n \n \n {\n this.setState({isDraggingOver: true});\n }}\n onDragLeave={() => {\n this.setState({isDraggingOver: false});\n }}\n onDrop={(e) => {\n e.preventDefault();\n\n const file = lodashGet(e, ['dataTransfer', 'files', 0]);\n\n displayFileInModal(file);\n\n this.setState({isDraggingOver: false});\n }}\n disabled={this.props.disabled}\n >\n this.updateComment(comment, true)}\n onKeyPress={this.triggerHotkeyActions}\n style={[styles.textInputCompose, this.props.isComposerFullSize ? styles.textInputFullCompose : styles.flex4]}\n maxLines={this.state.maxLines}\n onFocus={() => this.setIsFocused(true)}\n onBlur={() => {\n this.setIsFocused(false);\n this.resetSuggestedEmojis();\n }}\n onPasteFile={displayFileInModal}\n shouldClear={this.state.textInputShouldClear}\n onClear={() => this.setTextInputShouldClear(false)}\n isDisabled={isComposeDisabled || isBlockedFromConcierge || this.props.disabled}\n selection={this.state.selection}\n onSelectionChange={this.onSelectionChange}\n isFullComposerAvailable={this.state.isFullComposerAvailable}\n setIsFullComposerAvailable={this.setIsFullComposerAvailable}\n isComposerFullSize={this.props.isComposerFullSize}\n value={this.state.value}\n numberOfLines={this.props.numberOfLines}\n onNumberOfLinesChange={this.updateNumberOfLines}\n onLayout={(e) => {\n const composerHeight = e.nativeEvent.layout.height;\n if (this.state.composerHeight === composerHeight) {\n return;\n }\n this.setState({composerHeight});\n }}\n onScroll={() => this.setShouldShowSuggestionMenuToFalse()}\n />\n \n \n \n )}\n \n {DeviceCapabilities.canUseTouchScreen() && this.props.isMediumScreenWidth ? null : (\n {\n this.focus(true);\n }}\n onEmojiSelected={this.addEmojiToTextBox}\n />\n )}\n e.preventDefault()}\n >\n \n \n \n \n \n \n \n \n {!this.props.isSmallScreenWidth && }\n \n \n \n \n {this.state.isDraggingOver && }\n {!_.isEmpty(this.state.suggestedEmojis) && this.state.shouldShowSuggestionMenu && (\n this.setState({highlightedEmojiIndex: index})}\n >\n this.setState({suggestedEmojis: []})}\n highlightedEmojiIndex={this.state.highlightedEmojiIndex}\n emojis={this.state.suggestedEmojis}\n comment={this.state.value}\n updateComment={newComment => this.setState({value: newComment})}\n colonIndex={this.state.colonIndex}\n prefix={this.state.value.slice(this.state.colonIndex + 1).split(' ')[0]}\n onSelect={this.insertSelectedEmoji}\n isComposerFullSize={this.props.isComposerFullSize}\n preferredSkinToneIndex={this.props.preferredSkinTone}\n isEmojiPickerLarge={this.state.isEmojiPickerLarge}\n composerHeight={this.state.composerHeight}\n shouldIncludeReportRecipientLocalTimeHeight={shouldShowReportRecipientLocalTime}\n />\n \n )}\n \n );\n }\n}\n\nReportActionCompose.propTypes = propTypes;\nReportActionCompose.defaultProps = defaultProps;\n\nexport default compose(\n withWindowDimensions,\n withDrawerState,\n withNavigationFocus,\n withLocalize,\n withNetwork(),\n withPersonalDetails(),\n withCurrentUserPersonalDetails,\n withKeyboardState,\n withOnyx({\n betas: {\n key: ONYXKEYS.BETAS,\n },\n comment: {\n key: ({reportID}) => `${ONYXKEYS.COLLECTION.REPORT_DRAFT_COMMENT}${reportID}`,\n },\n numberOfLines: {\n key: ({reportID}) => `${ONYXKEYS.COLLECTION.REPORT_DRAFT_COMMENT_NUMBER_OF_LINES}${reportID}`,\n },\n modal: {\n key: ONYXKEYS.MODAL,\n },\n blockedFromConcierge: {\n key: ONYXKEYS.NVP_BLOCKED_FROM_CONCIERGE,\n },\n frequentlyUsedEmojis: {\n key: ONYXKEYS.FREQUENTLY_USED_EMOJIS,\n },\n preferredSkinTone: {\n key: ONYXKEYS.PREFERRED_EMOJI_SKIN_TONE,\n },\n }),\n)(ReportActionCompose);\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport _ from 'underscore';\nimport {withOnyx} from 'react-native-onyx';\nimport {withNetwork} from '../../../components/OnyxProvider';\nimport networkPropTypes from '../../../components/networkPropTypes';\nimport compose from '../../../libs/compose';\nimport ONYXKEYS from '../../../ONYXKEYS';\nimport styles from '../../../styles/styles';\nimport * as PersonalDetails from '../../../libs/actions/PersonalDetails';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport Text from '../../../components/Text';\nimport TextWithEllipsis from '../../../components/TextWithEllipsis';\n\nconst propTypes = {\n /** Key-value pairs of user logins and whether or not they are typing. Keys are logins. */\n userTypingStatuses: PropTypes.objectOf(PropTypes.bool),\n\n /** Information about the network */\n network: networkPropTypes.isRequired,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n userTypingStatuses: {},\n};\n\nclass ReportTypingIndicator extends React.Component {\n constructor(props) {\n super(props);\n\n const usersTyping = props.userTypingStatuses\n ? _.filter(_.keys(props.userTypingStatuses), login => props.userTypingStatuses[login])\n : [];\n this.state = {usersTyping};\n }\n\n componentDidUpdate(prevProps) {\n // Make sure we only update the state if there's been a change in who's typing.\n if (_.isEqual(prevProps.userTypingStatuses, this.props.userTypingStatuses)) {\n return;\n }\n\n const usersTyping = _.filter(_.keys(this.props.userTypingStatuses), login => this.props.userTypingStatuses[login]);\n\n // eslint-disable-next-line react/no-did-update-set-state\n this.setState({usersTyping});\n }\n\n render() {\n const numUsersTyping = _.size(this.state.usersTyping);\n\n // If we are offline, the user typing statuses are not up-to-date so do not show them\n if (this.props.network.isOffline) {\n return null;\n }\n\n // Decide on the Text element that will hold the display based on the number of users that are typing.\n switch (numUsersTyping) {\n case 0:\n return null;\n\n case 1:\n return (\n \n );\n\n default:\n return (\n \n {this.props.translate('reportTypingIndicator.multipleUsers')}\n {` ${this.props.translate('reportTypingIndicator.areTyping')}`}\n \n );\n }\n }\n}\n\nReportTypingIndicator.propTypes = propTypes;\nReportTypingIndicator.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withNetwork(),\n withOnyx({\n userTypingStatuses: {\n key: ({reportID}) => `${ONYXKEYS.COLLECTION.REPORT_USER_IS_TYPING}${reportID}`,\n },\n }),\n)(ReportTypingIndicator);\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport {View} from 'react-native';\nimport Text from '../Text';\nimport styles from '../../styles/styles';\nimport stylePropTypes from '../../styles/stylePropTypes';\nimport * as StyleUtils from '../../styles/StyleUtils';\n\nconst propTypes = {\n /** Leading text before the ellipsis */\n leadingText: PropTypes.string.isRequired,\n\n /** Text after the ellipsis */\n trailingText: PropTypes.string.isRequired,\n\n /** Styles for leading and trailing text */\n textStyle: stylePropTypes,\n\n /** Styles for leading text View */\n leadingTextParentStyle: stylePropTypes,\n\n /** Styles for parent View */\n wrapperStyle: stylePropTypes,\n};\n\nconst defaultProps = {\n textStyle: {},\n leadingTextParentStyle: {},\n wrapperStyle: {},\n};\n\nconst TextWithEllipsis = props => (\n \n \n \n {props.leadingText}\n \n \n \n \n {props.trailingText}\n \n \n \n);\n\nTextWithEllipsis.propTypes = propTypes;\nTextWithEllipsis.defaultProps = defaultProps;\nTextWithEllipsis.displayName = 'TextWithEllipsis';\n\nexport default TextWithEllipsis;\n","export default () => false;\n","import React, {PureComponent} from 'react';\nimport {\n View,\n} from 'react-native';\nimport lodashGet from 'lodash/get';\nimport Str from 'expensify-common/lib/str';\nimport styles from '../../../styles/styles';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport participantPropTypes from '../../../components/participantPropTypes';\nimport Text from '../../../components/Text';\nimport Timers from '../../../libs/Timers';\nimport CONST from '../../../CONST';\nimport DateUtils from '../../../libs/DateUtils';\n\nconst propTypes = {\n /** Personal details of the participant */\n participant: participantPropTypes.isRequired,\n\n ...withLocalizePropTypes,\n};\n\nclass ParticipantLocalTime extends PureComponent {\n constructor(props) {\n super(props);\n this.getParticipantLocalTime = this.getParticipantLocalTime.bind(this);\n this.state = {\n localTime: this.getParticipantLocalTime(),\n };\n }\n\n componentDidMount() {\n this.timer = Timers.register(setInterval(() => {\n this.setState({\n localTime: this.getParticipantLocalTime(),\n });\n }, 1000));\n }\n\n componentWillUnmount() {\n clearInterval(this.timer);\n }\n\n getParticipantLocalTime() {\n const reportRecipientTimezone = lodashGet(this.props.participant, 'timezone', CONST.DEFAULT_TIME_ZONE);\n const reportTimezone = DateUtils.getLocalMomentFromDatetime(this.props.preferredLocale, null, reportRecipientTimezone.selected);\n const currentTimezone = DateUtils.getLocalMomentFromDatetime(this.props.preferredLocale);\n const reportRecipientDay = reportTimezone.format('dddd');\n const currentUserDay = currentTimezone.format('dddd');\n\n if (reportRecipientDay !== currentUserDay) {\n return `${reportTimezone.format('LT')} ${reportRecipientDay}`;\n }\n return `${reportTimezone.format('LT')}`;\n }\n\n render() {\n const reportRecipientDisplayName = this.props.participant.firstName\n || (Str.isSMSLogin(this.props.participant.login)\n ? this.props.toLocalPhone(this.props.participant.displayName)\n : this.props.participant.displayName);\n\n return (\n \n \n {this.props.translate(\n 'reportActionCompose.localTime',\n {\n user: reportRecipientDisplayName,\n time: this.state.localTime,\n },\n )}\n \n \n );\n }\n}\n\nParticipantLocalTime.propTypes = propTypes;\nexport default withLocalize(ParticipantLocalTime);\n","import React from 'react';\nimport {View} from 'react-native';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport styles from '../../../styles/styles';\nimport Text from '../../../components/Text';\nimport CONST from '../../../CONST';\nimport DropZone from '../../../components/DragAndDrop/DropZone';\nimport Icon from '../../../components/Icon';\nimport * as Expensicons from '../../../components/Icon/Expensicons';\n\nconst propTypes = {\n ...withLocalizePropTypes,\n};\n\nconst ReportDropUI = props => (\n \n \n \n \n \n {props.translate('reportActionCompose.dropToUpload')}\n \n \n);\n\nReportDropUI.displayName = 'ReportDropUI';\nReportDropUI.propTypes = propTypes;\n\nexport default withLocalize(ReportDropUI);\n","const DropZone = props => props.children;\n\nDropZone.displayName = 'DropZone';\n\nexport default DropZone;\n","const DragAndDrop = props => props.children;\n\nDragAndDrop.displayName = 'DragAndDrop';\n\nexport default DragAndDrop;\n","import React from 'react';\nimport {View, Pressable} from 'react-native';\nimport PropTypes from 'prop-types';\nimport _ from 'underscore';\n\n// We take FlatList from this package to properly handle the scrolling of EmojiSuggestions in chats since one scroll is nested inside another\nimport {FlatList} from 'react-native-gesture-handler';\nimport styles from '../styles/styles';\nimport * as StyleUtils from '../styles/StyleUtils';\nimport * as EmojiUtils from '../libs/EmojiUtils';\nimport Text from './Text';\nimport CONST from '../CONST';\nimport getStyledTextArray from '../libs/GetStyledTextArray';\n\nconst propTypes = {\n /** The index of the highlighted emoji */\n highlightedEmojiIndex: PropTypes.number,\n\n /** Array of suggested emoji */\n emojis: PropTypes.arrayOf(PropTypes.shape({\n /** The emoji code */\n code: PropTypes.string,\n\n /** The name of the emoji */\n name: PropTypes.string,\n })).isRequired,\n\n /** Fired when the user selects an emoji */\n onSelect: PropTypes.func.isRequired,\n\n /** Emoji prefix that follows the colon */\n prefix: PropTypes.string.isRequired,\n\n /** Show that we can use large emoji picker.\n * Depending on available space and whether the input is expanded, we can have a small or large emoji suggester.\n * When this value is false, the suggester will have a height of 2.5 items. When this value is true, the height can be up to 5 items. */\n isEmojiPickerLarge: PropTypes.bool.isRequired,\n\n /** Show that we should include ReportRecipientLocalTime view height */\n shouldIncludeReportRecipientLocalTimeHeight: PropTypes.bool.isRequired,\n\n /** Stores user's preferred skin tone */\n preferredSkinToneIndex: PropTypes.number.isRequired,\n};\n\nconst defaultProps = {\n highlightedEmojiIndex: 0,\n};\n\n/**\n * @param {Number} numRows\n * @param {Boolean} isEmojiPickerLarge\n * @returns {Number}\n */\nconst measureHeightOfEmojiRows = (numRows, isEmojiPickerLarge) => {\n if (isEmojiPickerLarge) {\n return numRows * CONST.EMOJI_SUGGESTER.ITEM_HEIGHT;\n }\n if (numRows > 2) {\n // on small screens, we display a scrollable window with a height of 2.5 items, indicating that there are more items available beyond what is currently visible\n return CONST.EMOJI_SUGGESTER.SMALL_CONTAINER_HEIGHT_FACTOR * CONST.EMOJI_SUGGESTER.ITEM_HEIGHT;\n }\n return numRows * CONST.EMOJI_SUGGESTER.ITEM_HEIGHT;\n};\n\n/**\n * Create unique keys for each emoji item\n * @param {Object} item\n * @param {Number} index\n * @returns {String}\n */\nconst keyExtractor = (item, index) => `${item.name}+${index}}`;\n\nconst EmojiSuggestions = (props) => {\n /**\n * Render a suggestion menu item component.\n * @param {Object} params.item\n * @param {Number} params.index\n * @returns {JSX.Element}\n */\n const renderSuggestionMenuItem = ({item, index}) => {\n const styledTextArray = getStyledTextArray(item.name, props.prefix);\n\n return (\n StyleUtils.getEmojiSuggestionItemStyle(\n props.highlightedEmojiIndex,\n CONST.EMOJI_SUGGESTER.ITEM_HEIGHT,\n hovered,\n index,\n )}\n onMouseDown={e => e.preventDefault()}\n onPress={() => props.onSelect(index)}\n >\n \n {EmojiUtils.getEmojiCodeWithSkinColor(item, props.preferredSkinToneIndex)}\n \n :\n {_.map(styledTextArray, ({text, isColored}, i) => (\n \n {text}\n \n ))}\n :\n \n \n \n );\n };\n\n const rowHeight = measureHeightOfEmojiRows(\n props.emojis.length,\n props.isEmojiPickerLarge,\n );\n\n return (\n \n \n \n );\n};\n\nEmojiSuggestions.propTypes = propTypes;\nEmojiSuggestions.defaultProps = defaultProps;\nEmojiSuggestions.displayName = 'EmojiSuggestions';\n\nexport default EmojiSuggestions;\n","import Str from 'expensify-common/lib/str';\n\n/**\n * Render a suggestion menu item component.\n * @param {String} name\n * @param {String} prefix\n * @returns {Array}\n */\nconst getStyledTextArray = (name, prefix) => {\n const texts = [];\n const prefixLowercase = prefix.toLowerCase();\n const prefixLocation = name.search(Str.escapeForRegExp(prefixLowercase));\n\n if (prefixLocation === 0 && prefix.length === name.length) {\n texts.push({text: prefixLowercase, isColored: true});\n } else if (prefixLocation === 0 && prefix.length !== name.length) {\n texts.push(\n {text: name.slice(0, prefix.length), isColored: true},\n {text: name.slice(prefix.length), isColored: false},\n );\n } else if (prefixLocation > 0 && prefix.length !== name.length) {\n texts.push(\n {text: name.slice(0, prefixLocation), isColored: false},\n {\n text: name.slice(prefixLocation, prefixLocation + prefix.length),\n isColored: true,\n },\n {\n text: name.slice(prefixLocation + prefix.length),\n isColored: false,\n },\n );\n } else {\n texts.push({text: name, isColored: false});\n }\n return texts;\n};\n\nexport default getStyledTextArray;\n","import React, {PureComponent} from 'react';\nimport {PanResponder, View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport CONST from '../../CONST';\n\nconst propTypes = {\n children: PropTypes.element.isRequired,\n\n /** Callback to fire when the user swipes down on the child content */\n onSwipeDown: PropTypes.func.isRequired,\n};\n\nclass SwipeableView extends PureComponent {\n constructor(props) {\n super(props);\n\n const minimumPixelDistance = CONST.COMPOSER_MAX_HEIGHT;\n this.oldY = 0;\n this.panResponder = PanResponder.create({\n\n // The PanResponder gets focus only when the y-axis movement is over minimumPixelDistance\n // & swip direction is downwards\n onMoveShouldSetPanResponderCapture:\n (_event, gestureState) => {\n if ((gestureState.dy - this.oldY) > 0 && gestureState.dy > minimumPixelDistance) {\n return true;\n }\n this.oldY = gestureState.dy;\n },\n\n // Calls the callback when the swipe down is released; after the completion of the gesture\n onPanResponderRelease: this.props.onSwipeDown,\n });\n }\n\n render() {\n return (\n // eslint-disable-next-line react/jsx-props-no-spreading\n \n {this.props.children}\n \n );\n }\n}\n\nSwipeableView.propTypes = propTypes;\n\nexport default SwipeableView;\n","import lodashGet from 'lodash/get';\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport {withOnyx} from 'react-native-onyx';\nimport CONST from '../CONST';\nimport Banner from './Banner';\nimport withLocalize, {withLocalizePropTypes} from './withLocalize';\nimport compose from '../libs/compose';\nimport personalDetailsPropType from '../pages/personalDetailsPropType';\nimport ONYXKEYS from '../ONYXKEYS';\nimport * as ReportUtils from '../libs/ReportUtils';\nimport reportPropTypes from '../pages/reportPropTypes';\nimport * as ReportActionsUtils from '../libs/ReportActionsUtils';\nimport styles from '../styles/styles';\n\nconst propTypes = {\n /** The reason this report was archived */\n reportClosedAction: PropTypes.shape({\n /** Message attached to the report closed action */\n originalMessage: PropTypes.shape({\n /** The reason the report was closed */\n reason: PropTypes.string.isRequired,\n\n /** (For accountMerged reason only), the email of the previous owner of this report. */\n oldLogin: PropTypes.string,\n\n /** (For accountMerged reason only), the email of the account the previous owner was merged into */\n newLogin: PropTypes.string,\n }).isRequired,\n }),\n\n /** The archived report */\n report: reportPropTypes.isRequired,\n\n /** Personal details of all users */\n personalDetails: PropTypes.objectOf(personalDetailsPropType),\n\n /** The list of policies the user has access to. */\n policies: PropTypes.objectOf(PropTypes.shape({\n /** The name of the policy */\n name: PropTypes.string,\n })),\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n reportClosedAction: {\n originalMessage: {\n reason: CONST.REPORT.ARCHIVE_REASON.DEFAULT,\n },\n },\n personalDetails: {},\n policies: {},\n};\n\nconst ArchivedReportFooter = (props) => {\n const archiveReason = lodashGet(props.reportClosedAction, 'originalMessage.reason', CONST.REPORT.ARCHIVE_REASON.DEFAULT);\n let displayName = lodashGet(props.personalDetails, `${props.report.ownerEmail}.displayName`, props.report.ownerEmail);\n\n let oldDisplayName;\n if (archiveReason === CONST.REPORT.ARCHIVE_REASON.ACCOUNT_MERGED) {\n const newLogin = props.reportClosedAction.originalMessage.newLogin;\n const oldLogin = props.reportClosedAction.originalMessage.oldLogin;\n displayName = lodashGet(props.personalDetails, `${newLogin}.displayName`, newLogin);\n oldDisplayName = lodashGet(props.personalDetails, `${oldLogin}.displayName`, oldLogin);\n }\n\n return (\n ${displayName}`,\n oldDisplayName: `${oldDisplayName}`,\n policyName: `${ReportUtils.getPolicyName(props.report, props.policies)}`,\n })}\n shouldRenderHTML={archiveReason !== CONST.REPORT.ARCHIVE_REASON.DEFAULT}\n shouldShowIcon\n />\n );\n};\n\nArchivedReportFooter.propTypes = propTypes;\nArchivedReportFooter.defaultProps = defaultProps;\nArchivedReportFooter.displayName = 'ArchivedReportFooter';\n\nexport default compose(\n withLocalize,\n withOnyx({\n personalDetails: {\n key: ONYXKEYS.PERSONAL_DETAILS,\n },\n policies: {\n key: ONYXKEYS.COLLECTION.POLICY,\n },\n reportClosedAction: {\n key: ({report}) => `${ONYXKEYS.COLLECTION.REPORT_ACTIONS}${report.reportID}`,\n canEvict: false,\n selector: ReportActionsUtils.getLastClosedReportAction,\n },\n }),\n)(ArchivedReportFooter);\n","import React, {memo} from 'react';\nimport PropTypes from 'prop-types';\nimport {View, Pressable} from 'react-native';\nimport compose from '../libs/compose';\nimport Hoverable from './Hoverable';\nimport Icon from './Icon';\nimport * as Expensicons from './Icon/Expensicons';\nimport RenderHTML from './RenderHTML';\nimport Text from './Text';\nimport styles from '../styles/styles';\nimport * as StyleUtils from '../styles/StyleUtils';\nimport getButtonState from '../libs/getButtonState';\nimport Tooltip from './Tooltip';\nimport withLocalize, {withLocalizePropTypes} from './withLocalize';\n\nconst propTypes = {\n /** Text to display in the banner. */\n text: PropTypes.string.isRequired,\n\n /** Should this component render the left-aligned exclamation icon? */\n shouldShowIcon: PropTypes.bool,\n\n /** Should this component render a close button? */\n shouldShowCloseButton: PropTypes.bool,\n\n /** Should this component render the text as HTML? */\n shouldRenderHTML: PropTypes.bool,\n\n /** Callback called when the close button is pressed */\n onClose: PropTypes.func,\n\n /** Callback called when the message is pressed */\n onPress: PropTypes.func,\n\n /** Styles to be assigned to the Banner container */\n // eslint-disable-next-line react/forbid-prop-types\n containerStyles: PropTypes.arrayOf(PropTypes.object),\n\n /** Styles to be assigned to the Banner text */\n // eslint-disable-next-line react/forbid-prop-types\n textStyles: PropTypes.arrayOf(PropTypes.object),\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n shouldRenderHTML: false,\n shouldShowIcon: false,\n shouldShowCloseButton: false,\n onClose: undefined,\n onPress: undefined,\n containerStyles: [],\n textStyles: [],\n};\n\nconst Banner = props => (\n \n {(isHovered) => {\n const isClickable = props.onClose || props.onPress;\n const shouldHighlight = isClickable && isHovered;\n return (\n \n \n {props.shouldShowIcon && (\n \n \n \n )}\n {\n props.shouldRenderHTML\n ? \n : {props.text}\n }\n \n {props.shouldShowCloseButton && (\n \n \n \n \n \n )}\n \n );\n }}\n \n);\n\nBanner.propTypes = propTypes;\nBanner.defaultProps = defaultProps;\nBanner.displayName = 'Banner';\n\nexport default compose(\n withLocalize,\n memo,\n)(Banner);\n","import React from 'react';\nimport {Pressable, View} from 'react-native';\nimport {Rect, Circle} from 'react-native-svg';\nimport SkeletonViewContentLoader from 'react-content-loader/native';\nimport PropTypes from 'prop-types';\nimport styles from '../styles/styles';\nimport Icon from './Icon';\nimport * as Expensicons from './Icon/Expensicons';\nimport withWindowDimensions, {windowDimensionsPropTypes} from './withWindowDimensions';\nimport variables from '../styles/variables';\nimport themeColors from '../styles/themes/default';\n\nconst propTypes = {\n ...windowDimensionsPropTypes,\n shouldAnimate: PropTypes.bool,\n};\n\nconst defaultProps = {\n shouldAnimate: true,\n};\n\nconst ReportHeaderSkeletonView = props => (\n \n \n {props.isSmallScreenWidth && (\n {}}\n style={[styles.LHNToggle]}\n >\n \n \n )}\n \n \n \n \n \n \n \n);\n\nReportHeaderSkeletonView.propTypes = propTypes;\nReportHeaderSkeletonView.defaultProps = defaultProps;\nReportHeaderSkeletonView.displayName = 'ReportHeaderSkeletonView';\nexport default withWindowDimensions(ReportHeaderSkeletonView);\n","import React from 'react';\nimport {Dimensions, Keyboard} from 'react-native';\nimport _ from 'underscore';\nimport EmojiPickerMenu from './EmojiPickerMenu';\nimport CONST from '../../CONST';\nimport PopoverWithMeasuredContent from '../PopoverWithMeasuredContent';\n\nconst DEFAULT_ANCHOR_ORIGIN = {\n horizontal: CONST.MODAL.ANCHOR_ORIGIN_HORIZONTAL.RIGHT,\n vertical: CONST.MODAL.ANCHOR_ORIGIN_VERTICAL.BOTTOM,\n};\n\nclass EmojiPicker extends React.Component {\n constructor(props) {\n super(props);\n\n this.hideEmojiPicker = this.hideEmojiPicker.bind(this);\n this.showEmojiPicker = this.showEmojiPicker.bind(this);\n this.selectEmoji = this.selectEmoji.bind(this);\n this.measureEmojiPopoverAnchorPosition = this.measureEmojiPopoverAnchorPosition.bind(this);\n this.measureEmojiPopoverAnchorPositionAndUpdateState = this.measureEmojiPopoverAnchorPositionAndUpdateState.bind(this);\n this.focusEmojiSearchInput = this.focusEmojiSearchInput.bind(this);\n this.measureContent = this.measureContent.bind(this);\n this.onModalHide = () => {};\n this.onEmojiSelected = () => {};\n\n this.state = {\n isEmojiPickerVisible: false,\n\n // The horizontal and vertical position (relative to the window) where the emoji popover will display.\n emojiPopoverAnchorPosition: {\n horizontal: 0,\n vertical: 0,\n },\n\n emojiPopoverAnchorOrigin: DEFAULT_ANCHOR_ORIGIN,\n };\n }\n\n componentDidMount() {\n this.emojiPopoverDimensionListener = Dimensions.addEventListener('change', this.measureEmojiPopoverAnchorPositionAndUpdateState);\n }\n\n componentDidUpdate(prevProps, prevState) {\n if (prevState.isEmojiPickerVisible === this.state.isEmojiPickerVisible || !this.state.isEmojiPickerVisible) {\n return;\n }\n\n // Dismiss the keyboard to provide a focus for the emoji picker to avoid selection issues.\n Keyboard.dismiss();\n }\n\n componentWillUnmount() {\n if (!this.emojiPopoverDimensionListener) {\n return;\n }\n this.emojiPopoverDimensionListener.remove();\n }\n\n /**\n * Callback for the emoji picker to add whatever emoji is chosen into the main input\n *\n * @param {String} emoji\n * @param {Object} emojiObject\n */\n selectEmoji(emoji, emojiObject) {\n // Prevent fast click / multiple emoji selection;\n // The first click will hide the emoji picker by calling the hideEmojiPicker() function\n // and in that function the emojiPopoverAnchor prop to will be set to null (synchronously)\n // thus we rely on that prop to prevent fast click / multiple emoji selection\n if (!this.emojiPopoverAnchor) {\n return;\n }\n\n this.hideEmojiPicker();\n if (_.isFunction(this.onEmojiSelected)) {\n this.onEmojiSelected(emoji, emojiObject);\n }\n }\n\n /**\n * Hide the emoji picker menu.\n *\n * @param {Boolean} isNavigating\n */\n hideEmojiPicker(isNavigating) {\n if (isNavigating) { this.onModalHide = () => {}; }\n this.emojiPopoverAnchor = null;\n this.setState({isEmojiPickerVisible: false});\n }\n\n /**\n * Show the emoji picker menu.\n *\n * @param {Function} [onModalHide=() => {}] - Run a callback when Modal hides.\n * @param {Function} [onEmojiSelected=() => {}] - Run a callback when Emoji selected.\n * @param {Element} emojiPopoverAnchor - Element to which Popover is anchored\n * @param {Object} [anchorOrigin=DEFAULT_ANCHOR_ORIGIN] - Anchor origin for Popover\n * @param {Function} [onWillShow=() => {}] - Run a callback when Popover will show\n */\n showEmojiPicker(onModalHide, onEmojiSelected, emojiPopoverAnchor, anchorOrigin, onWillShow = () => {}) {\n this.onModalHide = onModalHide;\n this.onEmojiSelected = onEmojiSelected;\n this.emojiPopoverAnchor = emojiPopoverAnchor;\n\n if (this.emojiPopoverAnchor) {\n // Drop focus to avoid blue focus ring.\n emojiPopoverAnchor.blur();\n }\n\n this.measureEmojiPopoverAnchorPosition().then((emojiPopoverAnchorPosition) => {\n onWillShow();\n this.setState({isEmojiPickerVisible: true, emojiPopoverAnchorPosition, emojiPopoverAnchorOrigin: anchorOrigin || DEFAULT_ANCHOR_ORIGIN});\n });\n }\n\n measureEmojiPopoverAnchorPosition() {\n return new Promise((resolve) => {\n if (!this.emojiPopoverAnchor) {\n return resolve({horizontal: 0, vertical: 0});\n }\n this.emojiPopoverAnchor.measureInWindow((x, y, width) => resolve({horizontal: x + width, vertical: y}));\n });\n }\n\n measureEmojiPopoverAnchorPositionAndUpdateState() {\n this.measureEmojiPopoverAnchorPosition().then((emojiPopoverAnchorPosition) => {\n this.setState({emojiPopoverAnchorPosition});\n });\n }\n\n /**\n * Used to calculate the EmojiPicker Dimensions\n *\n * @returns {JSX}\n */\n measureContent() {\n return (\n this.emojiSearchInput = el}\n />\n );\n }\n\n /**\n * Focus the search input in the emoji picker.\n */\n focusEmojiSearchInput() {\n if (!this.emojiSearchInput) {\n return;\n }\n this.emojiSearchInput.focus();\n }\n\n render() {\n // There is no way to disable animations and they are really laggy, because there are so many\n // emojis. The best alternative is to set it to 1ms so it just \"pops\" in and out\n return (\n \n this.emojiSearchInput = el}\n />\n \n );\n }\n}\n\nexport default EmojiPicker;\n","import React, {Component} from 'react';\nimport {View, findNodeHandle} from 'react-native';\nimport {withOnyx} from 'react-native-onyx';\nimport PropTypes from 'prop-types';\nimport _ from 'underscore';\nimport Animated, {runOnUI, _scrollTo} from 'react-native-reanimated';\nimport compose from '../../../libs/compose';\nimport withWindowDimensions, {windowDimensionsPropTypes} from '../../withWindowDimensions';\nimport CONST from '../../../CONST';\nimport ONYXKEYS from '../../../ONYXKEYS';\nimport styles from '../../../styles/styles';\nimport emojis from '../../../../assets/emojis';\nimport EmojiPickerMenuItem from '../EmojiPickerMenuItem';\nimport Text from '../../Text';\nimport withLocalize, {withLocalizePropTypes} from '../../withLocalize';\nimport EmojiSkinToneList from '../EmojiSkinToneList';\nimport * as EmojiUtils from '../../../libs/EmojiUtils';\nimport * as User from '../../../libs/actions/User';\nimport CategoryShortcutBar from '../CategoryShortcutBar';\n\nconst propTypes = {\n /** Function to add the selected emoji to the main compose text input */\n onEmojiSelected: PropTypes.func.isRequired,\n\n /** Stores user's preferred skin tone */\n preferredSkinTone: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n\n /** User's frequently used emojis */\n frequentlyUsedEmojis: PropTypes.arrayOf(PropTypes.shape({\n code: PropTypes.string.isRequired,\n keywords: PropTypes.arrayOf(PropTypes.string),\n })),\n\n /** Props related to the dimensions of the window */\n ...windowDimensionsPropTypes,\n\n /** Props related to translation */\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n preferredSkinTone: CONST.EMOJI_DEFAULT_SKIN_TONE,\n frequentlyUsedEmojis: [],\n};\n\nclass EmojiPickerMenu extends Component {\n constructor(props) {\n super(props);\n\n // Ref for emoji FlatList\n this.emojiList = undefined;\n\n this.emojis = EmojiUtils.mergeEmojisWithFrequentlyUsedEmojis(emojis, this.props.frequentlyUsedEmojis);\n\n // Get the header emojis along with the code, index and icon.\n // index is the actual header index starting at the first emoji and counting each one\n this.headerEmojis = EmojiUtils.getHeaderEmojis(this.emojis);\n\n // This is the indices of each header's Row\n // The positions are static, and are calculated as index/numColumns (8 in our case)\n // This is because each row of 8 emojis counts as one index to the flatlist\n this.headerRowIndices = _.map(this.headerEmojis, headerEmoji => Math.floor(headerEmoji.index / CONST.EMOJI_NUM_PER_ROW));\n\n this.renderItem = this.renderItem.bind(this);\n this.isMobileLandscape = this.isMobileLandscape.bind(this);\n this.updatePreferredSkinTone = this.updatePreferredSkinTone.bind(this);\n this.scrollToHeader = this.scrollToHeader.bind(this);\n this.getItemLayout = this.getItemLayout.bind(this);\n }\n\n getItemLayout(data, index) {\n return {length: CONST.EMOJI_PICKER_ITEM_HEIGHT, offset: CONST.EMOJI_PICKER_ITEM_HEIGHT * index, index};\n }\n\n /**\n * @param {String} emoji\n * @param {Object} emojiObject\n */\n addToFrequentAndSelectEmoji(emoji, emojiObject) {\n EmojiUtils.addToFrequentlyUsedEmojis(this.props.frequentlyUsedEmojis, emojiObject);\n this.props.onEmojiSelected(emoji, emojiObject);\n }\n\n /**\n * Check if its a landscape mode of mobile device\n *\n * @returns {Boolean}\n */\n isMobileLandscape() {\n return this.props.windowWidth >= this.props.windowHeight;\n }\n\n /**\n * @param {Number} skinTone\n */\n updatePreferredSkinTone(skinTone) {\n if (this.props.preferredSkinTone === skinTone) {\n return;\n }\n\n User.updatePreferredSkinTone(skinTone);\n }\n\n scrollToHeader(headerIndex) {\n const calculatedOffset = Math.floor(headerIndex / CONST.EMOJI_NUM_PER_ROW) * CONST.EMOJI_PICKER_HEADER_HEIGHT;\n this.emojiList.flashScrollIndicators();\n const node = findNodeHandle(this.emojiList);\n runOnUI(() => {\n 'worklet';\n\n _scrollTo(node, 0, calculatedOffset, true);\n })();\n }\n\n /**\n * Given an emoji item object, render a component based on its type.\n * Items with the code \"SPACER\" return nothing and are used to fill rows up to 8\n * so that the sticky headers function properly\n *\n * @param {Object} item\n * @returns {*}\n */\n renderItem({item}) {\n const {code, types} = item;\n if (item.spacer) {\n return null;\n }\n\n if (item.header) {\n return (\n \n \n {this.props.translate(`emojiPicker.headers.${item.code}`)}\n \n \n );\n }\n\n const emojiCode = types && types[this.props.preferredSkinTone]\n ? types[this.props.preferredSkinTone]\n : code;\n\n return (\n this.addToFrequentAndSelectEmoji(emoji, item)}\n emoji={emojiCode}\n />\n );\n }\n\n render() {\n return (\n \n \n \n \n this.emojiList = el}\n data={this.emojis}\n renderItem={this.renderItem}\n keyExtractor={item => (`emoji_picker_${item.code}`)}\n numColumns={CONST.EMOJI_NUM_PER_ROW}\n style={[\n styles.emojiPickerList,\n this.isMobileLandscape() && styles.emojiPickerListLandscape,\n ]}\n stickyHeaderIndices={this.headerRowIndices}\n getItemLayout={this.getItemLayout}\n showsVerticalScrollIndicator\n />\n \n \n );\n }\n}\n\nEmojiPickerMenu.propTypes = propTypes;\nEmojiPickerMenu.defaultProps = defaultProps;\n\nexport default compose(\n withWindowDimensions,\n withLocalize,\n withOnyx({\n preferredSkinTone: {\n key: ONYXKEYS.PREFERRED_EMOJI_SKIN_TONE,\n },\n frequentlyUsedEmojis: {\n key: ONYXKEYS.FREQUENTLY_USED_EMOJIS,\n },\n }),\n)(React.forwardRef((props, ref) => (\n // eslint-disable-next-line react/jsx-props-no-spreading\n \n)));\n","import React, {PureComponent} from 'react';\nimport PropTypes from 'prop-types';\nimport {Pressable} from 'react-native';\nimport styles from '../../styles/styles';\nimport * as StyleUtils from '../../styles/StyleUtils';\nimport getButtonState from '../../libs/getButtonState';\nimport Text from '../Text';\n\nconst propTypes = {\n /** The unicode that is used to display the emoji */\n emoji: PropTypes.string.isRequired,\n\n /** The function to call when an emoji is selected */\n onPress: PropTypes.func.isRequired,\n\n /** Handles what to do when we hover over this item with our cursor */\n onHoverIn: PropTypes.func,\n\n /** Handles what to do when the hover is out */\n onHoverOut: PropTypes.func,\n\n /** Handles what to do when the pressable is focused */\n onFocus: PropTypes.func,\n\n /** Handles what to do when the pressable is blurred */\n onBlur: PropTypes.func,\n\n /** Whether this menu item is currently highlighted or not */\n isHighlighted: PropTypes.bool,\n\n /** Whether this menu item is currently focused or not */\n isFocused: PropTypes.bool,\n\n /** Whether the emoji is highlighted by the keyboard/mouse */\n isUsingKeyboardMovement: PropTypes.bool,\n};\n\nclass EmojiPickerMenuItem extends PureComponent {\n constructor(props) {\n super(props);\n\n this.ref = null;\n }\n\n componentDidMount() {\n if (!this.props.isFocused) {\n return;\n }\n this.ref.focus();\n }\n\n componentDidUpdate(prevProps) {\n if (prevProps.isFocused === this.props.isFocused) {\n return;\n }\n if (!this.props.isFocused) {\n return;\n }\n this.ref.focus();\n }\n\n render() {\n return (\n this.props.onPress(this.props.emoji)}\n onHoverIn={this.props.onHoverIn}\n onHoverOut={this.props.onHoverOut}\n onFocus={this.props.onFocus}\n onBlur={this.props.onBlur}\n ref={ref => this.ref = ref}\n style={({\n pressed,\n }) => ([\n StyleUtils.getButtonBackgroundColorStyle(getButtonState(false, pressed)),\n this.props.isHighlighted && this.props.isUsingKeyboardMovement ? styles.emojiItemKeyboardHighlighted : {},\n this.props.isHighlighted && !this.props.isUsingKeyboardMovement ? styles.emojiItemHighlighted : {},\n styles.emojiItem,\n ])}\n >\n \n {this.props.emoji}\n \n \n );\n }\n}\n\nEmojiPickerMenuItem.propTypes = propTypes;\nEmojiPickerMenuItem.defaultProps = {\n isHighlighted: false,\n isFocused: false,\n isUsingKeyboardMovement: false,\n onHoverIn: () => {},\n onHoverOut: () => {},\n onFocus: () => {},\n onBlur: () => {},\n};\n\n// Significantly speeds up re-renders of the EmojiPickerMenu's FlatList\n// by only re-rendering at most two EmojiPickerMenuItems that are highlighted/un-highlighted per user action.\nexport default React.memo(\n EmojiPickerMenuItem,\n (prevProps, nextProps) => prevProps.isHighlighted === nextProps.isHighlighted\n && prevProps.emoji === nextProps.emoji\n && prevProps.isUsingKeyboardMovement === nextProps.isUsingKeyboardMovement,\n);\n","import _ from 'underscore';\nimport React, {Component} from 'react';\nimport {View, Pressable} from 'react-native';\nimport PropTypes from 'prop-types';\nimport styles from '../../styles/styles';\nimport * as Emojis from '../../../assets/emojis';\nimport withLocalize, {withLocalizePropTypes} from '../withLocalize';\nimport Text from '../Text';\nimport EmojiPickerMenuItem from './EmojiPickerMenuItem';\nimport getSkinToneEmojiFromIndex from './getSkinToneEmojiFromIndex';\n\nconst propTypes = {\n\n /** Stores user's preferred skin tone */\n preferredSkinTone: PropTypes.oneOfType([PropTypes.number, PropTypes.string]).isRequired,\n\n /** Function to sync the selected skin tone with parent, onyx and nvp */\n updatePreferredSkinTone: PropTypes.func.isRequired,\n\n /** Props related to translation */\n ...withLocalizePropTypes,\n};\n\nclass EmojiSkinToneList extends Component {\n constructor(props) {\n super(props);\n\n this.updateSelectedSkinTone = this.updateSelectedSkinTone.bind(this);\n\n this.state = {\n highlightedIndex: -1,\n isSkinToneListVisible: false,\n };\n }\n\n componentDidMount() {\n // Get the selected skinToneEmoji based on the index\n const selectedEmoji = getSkinToneEmojiFromIndex(this.props.preferredSkinTone);\n this.setState({highlightedIndex: selectedEmoji.skinTone});\n }\n\n componentDidUpdate(prevProps) {\n // Update the highlighted skin tone only if the selected one changes\n if (prevProps.preferredSkinTone === this.props.preferredSkinTone) {\n return;\n }\n\n const selectedEmoji = getSkinToneEmojiFromIndex(this.props.preferredSkinTone);\n this.setState({highlightedIndex: selectedEmoji.skinTone});\n }\n\n /**\n * Pass the skinTone to props and hide the picker\n * @param {object} skinToneEmoji\n */\n updateSelectedSkinTone(skinToneEmoji) {\n this.setState(prev => ({isSkinToneListVisible: !prev.isSkinToneListVisible, highlightedIndex: skinToneEmoji.skinTone}));\n this.props.updatePreferredSkinTone(skinToneEmoji.skinTone);\n }\n\n render() {\n const selectedEmoji = getSkinToneEmojiFromIndex(this.props.preferredSkinTone);\n return (\n \n {\n !this.state.isSkinToneListVisible && (\n this.setState(prev => ({isSkinToneListVisible: !prev.isSkinToneListVisible}))\n }\n style={[\n styles.flex1,\n styles.flexRow,\n styles.alignSelfCenter,\n styles.justifyContentStart,\n styles.alignItemsCenter,\n ]}\n >\n \n \n {selectedEmoji.code}\n \n \n \n {this.props.translate('emojiPicker.skinTonePickerLabel')}\n \n \n )\n }\n {\n this.state.isSkinToneListVisible && (\n\n \n {\n _.map(Emojis.skinTones, skinToneEmoji => (\n this.updateSelectedSkinTone(skinToneEmoji)}\n onHoverIn={() => this.setState({highlightedIndex: skinToneEmoji.skinTone})}\n onHoverOut={() => this.setState({highlightedIndex: selectedEmoji.skinTone})}\n key={skinToneEmoji.code}\n emoji={skinToneEmoji.code}\n isHighlighted={skinToneEmoji.skinTone === this.state.highlightedIndex || skinToneEmoji.skinTone === selectedEmoji.skinTone}\n />\n ))\n }\n \n )\n }\n \n );\n }\n}\n\nEmojiSkinToneList.propTypes = propTypes;\n\nexport default withLocalize(EmojiSkinToneList);\n","import _ from 'underscore';\nimport * as Emojis from '../../../assets/emojis';\n\n/**\n * Fetch the emoji code of selected skinTone\n * @param {Number} skinToneIndex\n * @returns {String}\n */\nfunction getSkinToneEmojiFromIndex(skinToneIndex) {\n return _.find(Emojis.skinTones, emoji => emoji.skinTone === skinToneIndex) || Emojis.skinTones[0];\n}\n\nexport default getSkinToneEmojiFromIndex;\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport {View} from 'react-native';\nimport _ from 'underscore';\nimport styles from '../../styles/styles';\nimport CategoryShortcutButton from './CategoryShortcutButton';\n\nconst propTypes = {\n /** The function to call when an emoji is selected */\n onPress: PropTypes.func.isRequired,\n\n /** The emojis consisting emoji code and indices that the icons should link to */\n headerEmojis: PropTypes.arrayOf(PropTypes.shape({\n code: PropTypes.string.isRequired,\n index: PropTypes.number.isRequired,\n icon: PropTypes.func.isRequired,\n })).isRequired,\n};\n\nconst CategoryShortcutBar = props => (\n \n {_.map(props.headerEmojis, (headerEmoji, i) => (\n props.onPress(headerEmoji.index)}\n key={`categoryShortcut${i}`}\n code={headerEmoji.code}\n />\n ))}\n \n);\n\nCategoryShortcutBar.propTypes = propTypes;\nCategoryShortcutBar.displayName = 'CategoryShortcutBar';\n\nexport default CategoryShortcutBar;\n","import React, {PureComponent} from 'react';\nimport PropTypes from 'prop-types';\nimport {Pressable} from 'react-native';\nimport Icon from '../Icon';\nimport Tooltip from '../Tooltip';\nimport withLocalize, {withLocalizePropTypes} from '../withLocalize';\nimport variables from '../../styles/variables';\nimport styles from '../../styles/styles';\nimport * as StyleUtils from '../../styles/StyleUtils';\nimport getButtonState from '../../libs/getButtonState';\nimport themeColors from '../../styles/themes/default';\n\nconst propTypes = {\n /** The emoji code of the category header */\n code: PropTypes.string.isRequired,\n\n /** The icon representation of the category that this button links to */\n icon: PropTypes.func.isRequired,\n\n /** The function to call when an emoji is selected */\n onPress: PropTypes.func.isRequired,\n\n ...withLocalizePropTypes,\n};\n\nclass CategoryShortcutButton extends PureComponent {\n constructor(props) {\n super(props);\n this.state = {\n isHighlighted: false,\n };\n }\n\n render() {\n return (\n this.setState({isHighlighted: true})}\n onHoverOut={() => this.setState({isHighlighted: false})}\n style={({pressed}) => ([\n StyleUtils.getButtonBackgroundColorStyle(getButtonState(false, pressed)),\n styles.categoryShortcutButton,\n this.state.isHighlighted && styles.emojiItemHighlighted,\n ])}\n >\n \n \n \n \n );\n }\n}\nCategoryShortcutButton.propTypes = propTypes;\n\nexport default withLocalize(CategoryShortcutButton);\n","import _ from 'underscore';\nimport React, {Component} from 'react';\nimport PropTypes from 'prop-types';\nimport {View} from 'react-native';\nimport lodashGet from 'lodash/get';\nimport Popover from './Popover';\nimport {propTypes as popoverPropTypes, defaultProps as defaultPopoverProps} from './Popover/popoverPropTypes';\nimport withWindowDimensions, {windowDimensionsPropTypes} from './withWindowDimensions';\nimport CONST from '../CONST';\nimport styles from '../styles/styles';\nimport {computeHorizontalShift, computeVerticalShift} from '../styles/getPopoverWithMeasuredContentStyles';\n\nconst propTypes = {\n // All popover props except:\n // 1) anchorPosition (which is overridden for this component)\n ...(_.omit(popoverPropTypes, ['anchorPosition'])),\n\n /** The horizontal and vertical anchors points for the popover */\n anchorPosition: PropTypes.shape({\n horizontal: PropTypes.number.isRequired,\n vertical: PropTypes.number.isRequired,\n }).isRequired,\n\n /** Where the popover should be positioned relative to the anchor points. */\n anchorOrigin: PropTypes.shape({\n horizontal: PropTypes.oneOf(_.values(CONST.MODAL.ANCHOR_ORIGIN_HORIZONTAL)),\n vertical: PropTypes.oneOf(_.values(CONST.MODAL.ANCHOR_ORIGIN_VERTICAL)),\n }),\n\n /** A function with content to measure. This component will use this.props.children by default,\n but in the case the children are not displayed, the measurement will not work. */\n measureContent: PropTypes.func.isRequired,\n\n /** Static dimensions for the popover.\n * Note: When passed, it will skip dimensions measuring of the popover, and provided dimensions will be used to calculate the anchor position.\n */\n popoverDimensions: PropTypes.shape({\n height: PropTypes.number,\n width: PropTypes.number,\n }),\n\n ...windowDimensionsPropTypes,\n};\n\nconst defaultProps = {\n ...defaultPopoverProps,\n\n // Default positioning of the popover\n anchorOrigin: {\n horizontal: CONST.MODAL.ANCHOR_ORIGIN_HORIZONTAL.LEFT,\n vertical: CONST.MODAL.ANCHOR_ORIGIN_VERTICAL.BOTTOM,\n },\n popoverDimensions: {\n height: 0,\n width: 0,\n },\n};\n\n/**\n * This is a convenient wrapper around the regular Popover component that allows us to use a more sophisticated\n * positioning schema responsively (without having to provide a static width and height for the popover content).\n * This way, we can shift the position of popover so that the content is anchored where we want it relative to the\n * anchor position.\n */\nclass PopoverWithMeasuredContent extends Component {\n constructor(props) {\n super(props);\n\n this.popoverWidth = lodashGet(this.props, 'popoverDimensions.width', 0);\n this.popoverHeight = lodashGet(this.props, 'popoverDimensions.height', 0);\n\n this.state = {\n isContentMeasured: this.popoverWidth > 0 && this.popoverHeight > 0,\n isVisible: false,\n };\n\n this.measurePopover = this.measurePopover.bind(this);\n }\n\n /**\n * When Popover becomes visible, we need to recalculate the Dimensions.\n * Skip render on Popover until recalculations have done by setting isContentMeasured false as early as possible.\n *\n * @static\n * @param {Object} props\n * @param {Object} state\n * @return {Object|null}\n */\n static getDerivedStateFromProps(props, state) {\n // When Popover is shown recalculate\n if (!state.isVisible && props.isVisible) {\n return {isContentMeasured: lodashGet(props, 'popoverDimensions.width', 0) > 0 && lodashGet(props, 'popoverDimensions.height', 0) > 0, isVisible: true};\n }\n if (!props.isVisible) {\n return {isVisible: false};\n }\n return null;\n }\n\n shouldComponentUpdate(nextProps, nextState) {\n if (this.props.isVisible\n && (nextProps.windowWidth !== this.props.windowWidth\n || nextProps.windowHeight !== this.props.windowHeight)) {\n return true;\n }\n\n // This component does not require re-render until any prop or state changes as we get the necessary info\n // at first render. This component is attached to each message on the Chat list thus we prevent its re-renders\n return !_.isEqual(\n _.omit(this.props, ['windowWidth', 'windowHeight']),\n _.omit(nextProps, ['windowWidth', 'windowHeight']),\n ) || !_.isEqual(this.state, nextState);\n }\n\n /**\n * Measure the size of the popover's content.\n *\n * @param {Object} nativeEvent\n */\n measurePopover({nativeEvent}) {\n this.popoverWidth = nativeEvent.layout.width;\n this.popoverHeight = nativeEvent.layout.height;\n this.setState({isContentMeasured: true});\n }\n\n /**\n * Calculate the adjusted position of the popover.\n *\n * @returns {Object}\n */\n calculateAdjustedAnchorPosition() {\n let horizontalConstraint;\n switch (this.props.anchorOrigin.horizontal) {\n case CONST.MODAL.ANCHOR_ORIGIN_HORIZONTAL.RIGHT:\n horizontalConstraint = {left: this.props.anchorPosition.horizontal - this.popoverWidth};\n break;\n case CONST.MODAL.ANCHOR_ORIGIN_HORIZONTAL.CENTER:\n horizontalConstraint = {\n left: Math.floor(this.props.anchorPosition.horizontal - (this.popoverWidth / 2)),\n };\n break;\n case CONST.MODAL.ANCHOR_ORIGIN_HORIZONTAL.LEFT:\n default:\n horizontalConstraint = {left: this.props.anchorPosition.horizontal};\n }\n\n let verticalConstraint;\n switch (this.props.anchorOrigin.vertical) {\n case CONST.MODAL.ANCHOR_ORIGIN_VERTICAL.BOTTOM:\n verticalConstraint = {top: this.props.anchorPosition.vertical - this.popoverHeight};\n break;\n case CONST.MODAL.ANCHOR_ORIGIN_VERTICAL.CENTER:\n verticalConstraint = {\n top: Math.floor(this.props.anchorPosition.vertical - (this.popoverHeight / 2)),\n };\n break;\n case CONST.MODAL.ANCHOR_ORIGIN_VERTICAL.TOP:\n default:\n verticalConstraint = {top: this.props.anchorPosition.vertical};\n }\n\n return {\n ...horizontalConstraint,\n ...verticalConstraint,\n };\n }\n\n render() {\n const adjustedAnchorPosition = this.calculateAdjustedAnchorPosition();\n const horizontalShift = computeHorizontalShift(\n adjustedAnchorPosition.left,\n this.popoverWidth,\n this.props.windowWidth,\n );\n const verticalShift = computeVerticalShift(\n adjustedAnchorPosition.top,\n this.popoverHeight,\n this.props.windowHeight,\n );\n const shifedAnchorPosition = {\n left: adjustedAnchorPosition.left + horizontalShift,\n top: adjustedAnchorPosition.top + verticalShift,\n };\n return this.state.isContentMeasured\n ? (\n \n {this.props.measureContent()}\n \n ) : (\n\n /*\n This is an invisible view used to measure the size of the popover,\n before it ever needs to be displayed.\n We do this because we need to know its dimensions in order to correctly animate the popover,\n but we can't measure its dimensions without first rendering it.\n */\n \n {this.props.children}\n \n );\n }\n}\n\nPopoverWithMeasuredContent.propTypes = propTypes;\nPopoverWithMeasuredContent.defaultProps = defaultProps;\n\nexport default withWindowDimensions(PopoverWithMeasuredContent);\n","import roundToNearestMultipleOfFour from './roundToNearestMultipleOfFour';\nimport variables from './variables';\n\n/**\n * Compute the amount that the Context menu's Anchor needs to be horizontally shifted\n * in order to keep it from displaying in the gutters.\n *\n * @param {Number} anchorLeftEdge - Menu's anchor Left edge.\n * @param {Number} menuWidth - The width of the menu itself.\n * @param {Number} windowWidth - The width of the Window.\n * @returns {Number}\n */\nfunction computeHorizontalShift(anchorLeftEdge, menuWidth, windowWidth) {\n const popoverRightEdge = anchorLeftEdge + menuWidth;\n if (anchorLeftEdge < variables.gutterWidth) {\n // Anchor is in left gutter, shift right by a multiple of four.\n return roundToNearestMultipleOfFour(variables.gutterWidth - anchorLeftEdge);\n }\n\n if (popoverRightEdge > (windowWidth - variables.gutterWidth)) {\n // Anchor is in right gutter, shift left by a multiple of four.\n return roundToNearestMultipleOfFour(windowWidth - variables.gutterWidth - popoverRightEdge);\n }\n\n // Anchor is not in the gutter, so no need to shift it horizontally\n return 0;\n}\n\n/**\n * Compute the amount that the Context menu's Anchor needs to be vertically shifted\n * in order to keep it from displaying in the window.\n *\n * @param {Number} anchorTopEdge - Menu's anchor Top edge.\n * @param {Number} menuHeight - The height of the menu itself.\n * @param {Number} windowHeight - The height of the Window.\n * @returns {Number}\n */\nfunction computeVerticalShift(anchorTopEdge, menuHeight, windowHeight) {\n const popoverBottomEdge = anchorTopEdge + menuHeight;\n\n if (anchorTopEdge < 0) {\n // Anchor is in top window Edge, shift bottom by a multiple of four.\n return roundToNearestMultipleOfFour(0 - anchorTopEdge);\n }\n\n if (popoverBottomEdge > windowHeight) {\n // Anchor is in Bottom window Edge, shift top by a multiple of four.\n return roundToNearestMultipleOfFour(windowHeight - popoverBottomEdge);\n }\n\n // Anchor is not in the gutter, so no need to shift it vertically\n return 0;\n}\n\nexport {\n computeHorizontalShift,\n computeVerticalShift,\n};\n","/**\n * This repo is very consistent about doing spacing in multiples of 4.\n * In an effort to maintain that consistency, we'll make sure that any distance we're shifting the components\n * are a multiple of 4.\n *\n * @param {Number} n\n * @returns {Number}\n */\nfunction roundToNearestMultipleOfFour(n) {\n if (n > 0) {\n return Math.ceil(n / 4.0) * 4;\n }\n\n if (n < 0) {\n return Math.floor(n / 4.0) * 4;\n }\n\n return 0;\n}\n\nexport default roundToNearestMultipleOfFour;\n","export { Portal } from './components/portal/Portal';\nexport { PortalHost } from './components/portalHost/PortalHost';\nexport { PortalProvider } from './components/portalProvider/PortalProvider';\nexport { usePortal } from './hooks/usePortal';\nexport { enableLogging } from './utilities/logger';\n","import { memo, useCallback, useEffect, useMemo, useRef } from 'react';\nimport { nanoid } from 'nanoid/non-secure';\nimport { usePortal } from '../../hooks/usePortal';\nimport type { PortalProps } from './types';\n\nconst PortalComponent = ({\n name: _providedName,\n hostName,\n handleOnMount: _providedHandleOnMount,\n handleOnUnmount: _providedHandleOnUnmount,\n handleOnUpdate: _providedHandleOnUpdate,\n children,\n}: PortalProps) => {\n //#region hooks\n const { addPortal: addUpdatePortal, removePortal } = usePortal(hostName);\n //#endregion\n\n //#region variables\n const name = useMemo(() => _providedName || nanoid(), [_providedName]);\n //#endregion\n\n //#region refs\n const handleOnMountRef = useRef();\n const handleOnUnmountRef = useRef();\n const handleOnUpdateRef = useRef();\n //#endregion\n\n //#region callbacks\n const handleOnMount = useCallback(() => {\n if (_providedHandleOnMount) {\n _providedHandleOnMount(() => addUpdatePortal(name, children));\n } else {\n addUpdatePortal(name, children);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [_providedHandleOnMount, addUpdatePortal]);\n handleOnMountRef.current = handleOnMount;\n\n const handleOnUnmount = useCallback(() => {\n if (_providedHandleOnUnmount) {\n _providedHandleOnUnmount(() => removePortal(name));\n } else {\n removePortal(name);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [_providedHandleOnUnmount, removePortal]);\n handleOnUnmountRef.current = handleOnUnmount;\n\n const handleOnUpdate = useCallback(() => {\n if (_providedHandleOnUpdate) {\n _providedHandleOnUpdate(() => addUpdatePortal(name, children));\n } else {\n addUpdatePortal(name, children);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [_providedHandleOnUpdate, addUpdatePortal, children]);\n handleOnUpdateRef.current = handleOnUpdate;\n //#endregion\n\n //#region effects\n useEffect(() => {\n handleOnMountRef.current?.();\n return () => {\n handleOnUnmountRef.current?.();\n\n // remove callbacks refs\n handleOnMountRef.current = undefined;\n handleOnUnmountRef.current = undefined;\n handleOnUpdateRef.current = undefined;\n };\n }, []);\n useEffect(() => {\n handleOnUpdateRef.current?.();\n }, [children]);\n //#endregion\n\n return null;\n};\n\nexport const Portal = memo(PortalComponent);\nPortal.displayName = 'Portal';\n","import { ReactNode, useCallback, useContext } from 'react';\nimport { ACTIONS } from '../state/constants';\nimport { PortalDispatchContext } from '../contexts/portal';\n\nexport const usePortal = (hostName: string = 'root') => {\n const dispatch = useContext(PortalDispatchContext);\n\n if (dispatch === null) {\n throw new Error(\n \"'PortalDispatchContext' cannot be null, please add 'PortalProvider' to the root component.\"\n );\n }\n\n //#region methods\n const registerHost = useCallback(() => {\n dispatch({\n type: ACTIONS.REGISTER_HOST,\n hostName: hostName,\n });\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n const deregisterHost = useCallback(() => {\n dispatch({\n type: ACTIONS.DEREGISTER_HOST,\n hostName: hostName,\n });\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n const addUpdatePortal = useCallback((name: string, node: ReactNode) => {\n dispatch({\n type: ACTIONS.ADD_UPDATE_PORTAL,\n hostName,\n portalName: name,\n node,\n });\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n const removePortal = useCallback((name: string) => {\n dispatch({\n type: ACTIONS.REMOVE_PORTAL,\n hostName,\n portalName: name,\n });\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n //#endregion\n\n return {\n registerHost,\n deregisterHost,\n addPortal: addUpdatePortal,\n updatePortal: addUpdatePortal,\n removePortal,\n };\n};\n","import { createContext } from 'react';\nimport type { ActionTypes } from '../state/types';\nimport type { PortalType } from '../types';\n\nexport const PortalStateContext = createContext\n> | null>(null);\nexport const PortalDispatchContext =\n createContext | null>(null);\n","enum ACTIONS {\n REGISTER_HOST,\n DEREGISTER_HOST,\n ADD_UPDATE_PORTAL,\n REMOVE_PORTAL,\n}\n\nconst INITIAL_STATE = {};\n\nexport { ACTIONS, INITIAL_STATE };\n","import React, { memo, useEffect } from 'react';\nimport { usePortalState } from '../../hooks/usePortalState';\nimport { usePortal } from '../../hooks/usePortal';\nimport type { PortalHostProps } from './types';\n\nconst PortalHostComponent = ({ name }: PortalHostProps) => {\n //#region hooks\n const state = usePortalState(name);\n const { registerHost, deregisterHost } = usePortal(name);\n //#endregion\n\n //#region effects\n useEffect(() => {\n registerHost();\n return () => {\n deregisterHost();\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n //#endregion\n\n //#region render\n return <>{state.map(item => item.node)};\n //#endregion\n};\n\nexport const PortalHost = memo(PortalHostComponent);\nPortalHost.displayName = 'PortalHost';\n","import { useContext } from 'react';\nimport { PortalStateContext } from '../contexts/portal';\n\nexport const usePortalState = (hostName: string) => {\n const state = useContext(PortalStateContext);\n\n if (state === null) {\n throw new Error(\n \"'PortalStateContext' cannot be null, please add 'PortalProvider' to the root component.\"\n );\n }\n\n return state[hostName] || [];\n};\n","import React, { memo, useReducer } from 'react';\nimport { PortalHost } from '../portalHost/PortalHost';\nimport {\n PortalDispatchContext,\n PortalStateContext,\n} from '../../contexts/portal';\nimport { INITIAL_STATE } from '../../state/constants';\nimport { reducer } from '../../state/reducer';\nimport type { PortalProviderProps } from './types';\n\nconst PortalProviderComponent = ({\n rootHostName = 'root',\n shouldAddRootHost = true,\n children,\n}: PortalProviderProps) => {\n const [state, dispatch] = useReducer(reducer, INITIAL_STATE);\n return (\n \n \n {children}\n {shouldAddRootHost && }\n \n \n );\n};\n\nexport const PortalProvider = memo(PortalProviderComponent);\nPortalProvider.displayName = 'PortalProvider';\n","import { ACTIONS } from './constants';\nimport { print } from '../utilities/logger';\nimport type { PortalType } from '../types';\nimport type {\n ActionTypes,\n AddUpdatePortalAction,\n RemovePortalAction,\n} from './types';\n\nconst registerHost = (\n state: Record>,\n hostName: string\n) => {\n if (!(hostName in state)) {\n state[hostName] = [];\n }\n return state;\n};\n\nconst deregisterHost = (\n state: Record>,\n hostName: string\n) => {\n delete state[hostName];\n return state;\n};\n\nconst addUpdatePortal = (\n state: Record>,\n hostName: string,\n portalName: string,\n node: any\n) => {\n if (!(hostName in state)) {\n state = registerHost(state, hostName);\n }\n\n /**\n * updated portal, if it was already added.\n */\n const index = state[hostName].findIndex(item => item.name === portalName);\n if (index !== -1) {\n state[hostName][index].node = node;\n } else {\n state[hostName].push({\n name: portalName,\n node,\n });\n }\n return state;\n};\n\nconst removePortal = (\n state: Record>,\n hostName: string,\n portalName: string\n) => {\n if (!(hostName in state)) {\n print({\n component: reducer.name,\n method: removePortal.name,\n params: `Failed to remove portal '${portalName}', '${hostName}' was not registered!`,\n });\n return state;\n }\n\n const index = state[hostName].findIndex(item => item.name === portalName);\n if (index !== -1) state[hostName].splice(index, 1);\n return state;\n};\n\nexport const reducer = (\n state: Record>,\n action: ActionTypes\n) => {\n const { type } = action;\n let clonedState = { ...state };\n switch (type) {\n case ACTIONS.REGISTER_HOST:\n return registerHost(clonedState, action.hostName);\n case ACTIONS.DEREGISTER_HOST:\n return deregisterHost(clonedState, action.hostName);\n case ACTIONS.ADD_UPDATE_PORTAL:\n return addUpdatePortal(\n clonedState,\n action.hostName,\n (action as AddUpdatePortalAction).portalName,\n (action as AddUpdatePortalAction).node\n );\n case ACTIONS.REMOVE_PORTAL:\n return removePortal(\n clonedState,\n action.hostName,\n (action as RemovePortalAction).portalName\n );\n default:\n return state;\n }\n};\n","interface PrintOptions {\n component?: string;\n method?: string;\n params?: Record | string | number | boolean;\n}\n\ntype Print = (options: PrintOptions) => void;\n\nlet isLoggingEnabled = false;\n\n// __DEV__ global is by default not defined in React Native Web builds\nconst isDev = Boolean(typeof __DEV__ !== 'undefined' && __DEV__);\n\nconst enableLogging = () => {\n if (!isDev) {\n console.warn('[Portal] could not enable logging on production!');\n return;\n }\n isLoggingEnabled = true;\n};\n\nlet print: Print = () => {};\n\nif (isDev) {\n print = ({ component, method, params }) => {\n if (!isLoggingEnabled) {\n return;\n }\n let message = '';\n\n if (typeof params === 'object') {\n message = Object.keys(params)\n .map(key => `${key}:${params[key]}`)\n .join(' ');\n } else {\n message = `${params ?? ''}`;\n }\n console.log(\n `[Portal::${[component, method].filter(Boolean).join('::')}]`,\n message\n );\n };\n}\n\nObject.freeze(print);\n\nexport { print, enableLogging };\n","import React from 'react';\nimport sidebarPropTypes from './sidebarPropTypes';\nimport BaseSidebarScreen from './BaseSidebarScreen';\nimport FloatingActionButtonAndPopover from './FloatingActionButtonAndPopover';\n\nconst SidebarScreen = props => (\n \n \n \n);\n\nSidebarScreen.propTypes = sidebarPropTypes;\nSidebarScreen.displayName = 'SidebarScreen';\n\nexport default SidebarScreen;\n","import PropTypes from 'prop-types';\n\nconst sidebarPropTypes = {\n\n /** reportID in the current navigation state */\n reportIDFromRoute: PropTypes.string,\n\n /** Callback when onLayout of sidebar is called */\n onLayout: PropTypes.func,\n};\nexport default sidebarPropTypes;\n","import React, {Component} from 'react';\nimport {View} from 'react-native';\nimport styles from '../../../../styles/styles';\nimport SidebarLinks from '../SidebarLinks';\nimport ScreenWrapper from '../../../../components/ScreenWrapper';\nimport Navigation from '../../../../libs/Navigation/Navigation';\nimport ROUTES from '../../../../ROUTES';\nimport Timing from '../../../../libs/actions/Timing';\nimport CONST from '../../../../CONST';\nimport Performance from '../../../../libs/Performance';\nimport withDrawerState from '../../../../components/withDrawerState';\nimport withWindowDimensions, {windowDimensionsPropTypes} from '../../../../components/withWindowDimensions';\nimport compose from '../../../../libs/compose';\nimport sidebarPropTypes from './sidebarPropTypes';\n\nconst propTypes = {\n ...sidebarPropTypes,\n ...windowDimensionsPropTypes,\n};\n\nclass BaseSidebarScreen extends Component {\n constructor(props) {\n super(props);\n\n this.startTimer = this.startTimer.bind(this);\n this.navigateToSettings = this.navigateToSettings.bind(this);\n }\n\n componentDidMount() {\n Performance.markStart(CONST.TIMING.SIDEBAR_LOADED);\n Timing.start(CONST.TIMING.SIDEBAR_LOADED, true);\n }\n\n /**\n * Method called when avatar is clicked\n */\n navigateToSettings() {\n Navigation.navigate(ROUTES.SETTINGS);\n }\n\n /**\n * Method called when a pinned chat is selected.\n */\n startTimer() {\n Timing.start(CONST.TIMING.SWITCH_REPORT);\n Performance.markStart(CONST.TIMING.SWITCH_REPORT);\n }\n\n render() {\n return (\n \n {({insets}) => (\n <>\n \n \n \n {this.props.children}\n \n )}\n \n );\n }\n}\n\nBaseSidebarScreen.propTypes = propTypes;\n\nexport default compose(\n withWindowDimensions,\n withDrawerState,\n)(BaseSidebarScreen);\n","/* eslint-disable rulesdir/onyx-props-must-have-default */\nimport lodashGet from 'lodash/get';\nimport React from 'react';\nimport {View, TouchableOpacity} from 'react-native';\nimport _ from 'underscore';\nimport PropTypes from 'prop-types';\nimport {withOnyx} from 'react-native-onyx';\nimport {Freeze} from 'react-freeze';\nimport styles from '../../../styles/styles';\nimport * as StyleUtils from '../../../styles/StyleUtils';\nimport ONYXKEYS from '../../../ONYXKEYS';\nimport safeAreaInsetPropTypes from '../../safeAreaInsetPropTypes';\nimport compose from '../../../libs/compose';\nimport Navigation from '../../../libs/Navigation/Navigation';\nimport ROUTES from '../../../ROUTES';\nimport Icon from '../../../components/Icon';\nimport Header from '../../../components/Header';\nimport * as Expensicons from '../../../components/Icon/Expensicons';\nimport AvatarWithIndicator from '../../../components/AvatarWithIndicator';\nimport Tooltip from '../../../components/Tooltip';\nimport CONST from '../../../CONST';\nimport participantPropTypes from '../../../components/participantPropTypes';\nimport withLocalize, {withLocalizePropTypes} from '../../../components/withLocalize';\nimport * as App from '../../../libs/actions/App';\nimport * as ReportUtils from '../../../libs/ReportUtils';\nimport withCurrentUserPersonalDetails from '../../../components/withCurrentUserPersonalDetails';\nimport withWindowDimensions from '../../../components/withWindowDimensions';\nimport reportActionPropTypes from '../report/reportActionPropTypes';\nimport LHNOptionsList from '../../../components/LHNOptionsList/LHNOptionsList';\nimport SidebarUtils from '../../../libs/SidebarUtils';\nimport reportPropTypes from '../../reportPropTypes';\nimport OfflineWithFeedback from '../../../components/OfflineWithFeedback';\nimport LHNSkeletonView from '../../../components/LHNSkeletonView';\n\nconst propTypes = {\n /** Toggles the navigation menu open and closed */\n onLinkClick: PropTypes.func.isRequired,\n\n /** Safe area insets required for mobile devices margins */\n insets: safeAreaInsetPropTypes.isRequired,\n\n /* Onyx Props */\n /** List of reports */\n // eslint-disable-next-line react/no-unused-prop-types\n chatReports: PropTypes.objectOf(reportPropTypes),\n\n /** All report actions for all reports */\n // eslint-disable-next-line react/no-unused-prop-types\n reportActions: PropTypes.objectOf(PropTypes.arrayOf(PropTypes.shape(reportActionPropTypes))),\n\n /** List of users' personal details */\n personalDetails: PropTypes.objectOf(participantPropTypes),\n\n /** The personal details of the person who is logged in */\n currentUserPersonalDetails: PropTypes.shape({\n /** Display name of the current user */\n displayName: PropTypes.string,\n\n /** Avatar URL or SVG of the current user */\n avatar: PropTypes.oneOfType([PropTypes.string, PropTypes.func]),\n\n /** Login email of the current user */\n login: PropTypes.string,\n }),\n\n /** Current reportID from the route in react navigation state object */\n reportIDFromRoute: PropTypes.string,\n\n /** Callback when onLayout of sidebar is called */\n onLayout: PropTypes.func,\n\n /** Whether we are viewing below the responsive breakpoint */\n isSmallScreenWidth: PropTypes.bool.isRequired,\n\n /** The chat priority mode */\n priorityMode: PropTypes.string,\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n chatReports: {},\n reportActions: {},\n personalDetails: {},\n currentUserPersonalDetails: {\n avatar: '',\n },\n reportIDFromRoute: '',\n onLayout: () => {},\n priorityMode: CONST.PRIORITY_MODE.DEFAULT,\n};\n\nclass SidebarLinks extends React.Component {\n constructor(props) {\n super(props);\n\n this.showSearchPage = this.showSearchPage.bind(this);\n this.showSettingsPage = this.showSettingsPage.bind(this);\n this.showReportPage = this.showReportPage.bind(this);\n }\n\n showSearchPage() {\n if (this.props.isCreateMenuOpen) {\n // Prevent opening Search page when click Search icon quickly after clicking FAB icon\n return;\n }\n Navigation.navigate(ROUTES.SEARCH);\n }\n\n showSettingsPage() {\n if (this.props.isCreateMenuOpen) {\n // Prevent opening Settings page when click profile avatar quickly after clicking FAB icon\n return;\n }\n Navigation.navigate(ROUTES.SETTINGS);\n }\n\n /**\n * Show Report page with selected report id\n *\n * @param {Object} option\n * @param {String} option.reportID\n */\n showReportPage(option) {\n if (this.props.isCreateMenuOpen) {\n // Prevent opening Report page when click LHN row quickly after clicking FAB icon\n return;\n }\n Navigation.navigate(ROUTES.getReportRoute(option.reportID));\n this.props.onLinkClick();\n }\n\n render() {\n const isLoading = _.isEmpty(this.props.personalDetails) || _.isEmpty(this.props.chatReports);\n const shouldFreeze = this.props.isSmallScreenWidth && !this.props.isDrawerOpen && this.isSidebarLoaded;\n const optionListItems = SidebarUtils.getOrderedReportIDs(this.props.reportIDFromRoute);\n\n const skeletonPlaceholder = ;\n\n return (\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n {isLoading ? skeletonPlaceholder : (\n option.toString() === this.props.reportIDFromRoute\n ))}\n onSelectRow={this.showReportPage}\n shouldDisableFocusOptions={this.props.isSmallScreenWidth}\n optionMode={this.props.priorityMode === CONST.PRIORITY_MODE.GSD ? CONST.OPTION_MODE.COMPACT : CONST.OPTION_MODE.DEFAULT}\n onLayout={() => {\n this.props.onLayout();\n App.setSidebarLoaded();\n this.isSidebarLoaded = true;\n }}\n />\n )}\n \n \n );\n }\n}\n\nSidebarLinks.propTypes = propTypes;\nSidebarLinks.defaultProps = defaultProps;\n\n/**\n * This function (and the few below it), narrow down the data from Onyx to just the properties that we want to trigger a re-render of the component. This helps minimize re-rendering\n * and makes the entire component more performant because it's not re-rendering when a bunch of properties change which aren't ever used in the UI.\n * @param {Object} [report]\n * @returns {Object|undefined}\n */\nconst chatReportSelector = (report) => {\n if (ReportUtils.isIOUReport(report)) {\n return null;\n }\n return report && ({\n reportID: report.reportID,\n participants: report.participants,\n hasDraft: report.hasDraft,\n isPinned: report.isPinned,\n errorFields: {\n addWorkspaceRoom: report.errorFields && report.errorFields.addWorkspaceRoom,\n },\n lastReadTime: report.lastReadTime,\n lastMessageText: report.lastMessageText,\n lastVisibleActionCreated: report.lastVisibleActionCreated,\n iouReportID: report.iouReportID,\n hasOutstandingIOU: report.hasOutstandingIOU,\n statusNum: report.statusNum,\n stateNum: report.stateNum,\n chatType: report.chatType,\n policyID: report.policyID,\n reportName: report.reportName,\n });\n};\n\n/**\n * @param {Object} [personalDetails]\n * @returns {Object|undefined}\n */\nconst personalDetailsSelector = personalDetails => _.reduce(personalDetails, (finalPersonalDetails, personalData, login) => {\n // It's OK to do param-reassignment in _.reduce() because we absolutely know the starting state of finalPersonalDetails\n // eslint-disable-next-line no-param-reassign\n finalPersonalDetails[login] = {\n login: personalData.login,\n displayName: personalData.displayName,\n firstName: personalData.firstName,\n avatar: ReportUtils.getAvatar(personalData.avatar, personalData.login),\n };\n return finalPersonalDetails;\n}, {});\n\n/**\n * @param {Object} [reportActions]\n * @returns {Object|undefined}\n */\nconst reportActionsSelector = reportActions => reportActions && _.map(reportActions, reportAction => ({\n errors: reportAction.errors,\n}));\n\n/**\n * @param {Object} [policy]\n * @returns {Object|undefined}\n */\nconst policySelector = policy => policy && ({\n type: policy.type,\n name: policy.name,\n});\n\nexport default compose(\n withLocalize,\n withCurrentUserPersonalDetails,\n withWindowDimensions,\n withOnyx({\n // Note: It is very important that the keys subscribed to here are the same\n // keys that are subscribed to at the top of SidebarUtils.js. If there was a key missing from here and data was updated\n // for that key, then there would be no re-render and the options wouldn't reflect the new data because SidebarUtils.getOrderedReportIDs() wouldn't be triggered.\n // This could be changed if each OptionRowLHN used withOnyx() to connect to the Onyx keys, but if you had 10,000 reports\n // with 10,000 withOnyx() connections, it would have unknown performance implications.\n chatReports: {\n key: ONYXKEYS.COLLECTION.REPORT,\n selector: chatReportSelector,\n },\n personalDetails: {\n key: ONYXKEYS.PERSONAL_DETAILS,\n selector: personalDetailsSelector,\n },\n priorityMode: {\n key: ONYXKEYS.NVP_PRIORITY_MODE,\n },\n betas: {\n key: ONYXKEYS.BETAS,\n },\n reportActions: {\n key: ONYXKEYS.COLLECTION.REPORT_ACTIONS,\n selector: reportActionsSelector,\n },\n policies: {\n key: ONYXKEYS.COLLECTION.POLICY,\n selector: policySelector,\n },\n preferredLocale: {\n key: ONYXKEYS.NVP_PREFERRED_LOCALE,\n },\n }),\n)(SidebarLinks);\n","import PropTypes from 'prop-types';\n\nconst safeAreaInsetPropTypes = PropTypes.shape({\n top: PropTypes.number,\n left: PropTypes.number,\n right: PropTypes.number,\n bottom: PropTypes.number,\n});\n\nexport default safeAreaInsetPropTypes;\n","import _ from 'underscore';\nimport React from 'react';\nimport {StyleSheet, View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport {withOnyx} from 'react-native-onyx';\nimport Avatar from './Avatar';\nimport styles from '../styles/styles';\nimport Tooltip from './Tooltip';\nimport ONYXKEYS from '../ONYXKEYS';\nimport policyMemberPropType from '../pages/policyMemberPropType';\nimport bankAccountPropTypes from './bankAccountPropTypes';\nimport cardPropTypes from './cardPropTypes';\nimport userWalletPropTypes from '../pages/EnablePayments/userWalletPropTypes';\nimport {policyPropTypes} from '../pages/workspace/withPolicy';\nimport walletTermsPropTypes from '../pages/EnablePayments/walletTermsPropTypes';\nimport * as PolicyUtils from '../libs/PolicyUtils';\nimport * as PaymentMethods from '../libs/actions/PaymentMethods';\nimport * as ReportUtils from '../libs/ReportUtils';\nimport * as UserUtils from '../libs/UserUtils';\nimport themeColors from '../styles/themes/default';\n\nconst propTypes = {\n /** URL for the avatar */\n source: PropTypes.oneOfType([PropTypes.string, PropTypes.func]).isRequired,\n\n /** To show a tooltip on hover */\n tooltipText: PropTypes.string,\n\n /* Onyx Props */\n\n /** The employee list of all policies (coming from Onyx) */\n policiesMemberList: PropTypes.objectOf(policyMemberPropType),\n\n /** All the user's policies (from Onyx via withFullPolicy) */\n policies: PropTypes.objectOf(policyPropTypes.policy),\n\n /** List of bank accounts */\n bankAccountList: PropTypes.objectOf(bankAccountPropTypes),\n\n /** List of cards */\n cardList: PropTypes.objectOf(cardPropTypes),\n\n /** The user's wallet (coming from Onyx) */\n userWallet: userWalletPropTypes,\n\n /** Information about the user accepting the terms for payments */\n walletTerms: walletTermsPropTypes,\n\n /** Login list for the user that is signed in */\n loginList: PropTypes.shape({\n /** Date login was validated, used to show info indicator status */\n validatedDate: PropTypes.string,\n\n /** Field-specific server side errors keyed by microtime */\n errorFields: PropTypes.objectOf(PropTypes.objectOf(PropTypes.string)),\n }),\n};\n\nconst defaultProps = {\n tooltipText: '',\n policiesMemberList: {},\n policies: {},\n bankAccountList: {},\n cardList: {},\n userWallet: {},\n walletTerms: {},\n loginList: {},\n};\n\nconst AvatarWithIndicator = (props) => {\n // If a policy was just deleted from Onyx, then Onyx will pass a null value to the props, and\n // those should be cleaned out before doing any error checking\n const cleanPolicies = _.pick(props.policies, policy => policy);\n const cleanPolicyMembers = _.pick(props.policiesMemberList, member => member);\n\n // All of the error & info-checking methods are put into an array. This is so that using _.some() will return\n // early as soon as the first error / info condition is returned. This makes the checks very efficient since\n // we only care if a single error / info condition exists anywhere.\n const errorCheckingMethods = [\n () => !_.isEmpty(props.userWallet.errors),\n () => PaymentMethods.hasPaymentMethodError(props.bankAccountList, props.cardList),\n () => _.some(cleanPolicies, PolicyUtils.hasPolicyError),\n () => _.some(cleanPolicies, PolicyUtils.hasCustomUnitsError),\n () => _.some(cleanPolicyMembers, PolicyUtils.hasPolicyMemberError),\n () => UserUtils.hasLoginListError(props.loginList),\n\n // Wallet term errors that are not caused by an IOU (we show the red brick indicator for those in the LHN instead)\n () => !_.isEmpty(props.walletTerms.errors) && !props.walletTerms.chatReportID,\n ];\n const infoCheckingMethods = [\n () => UserUtils.hasLoginListInfo(props.loginList),\n ];\n const shouldShowErrorIndicator = _.some(errorCheckingMethods, errorCheckingMethod => errorCheckingMethod());\n const shouldShowInfoIndicator = !shouldShowErrorIndicator && _.some(infoCheckingMethods, infoCheckingMethod => infoCheckingMethod());\n\n const indicatorColor = shouldShowErrorIndicator ? themeColors.danger : themeColors.success;\n const indicatorStyles = [\n styles.alignItemsCenter,\n styles.justifyContentCenter,\n styles.statusIndicator(indicatorColor),\n ];\n\n return (\n \n \n \n {(shouldShowErrorIndicator || shouldShowInfoIndicator) && (\n \n )}\n \n \n );\n};\n\nAvatarWithIndicator.defaultProps = defaultProps;\nAvatarWithIndicator.propTypes = propTypes;\nAvatarWithIndicator.displayName = 'AvatarWithIndicator';\n\nexport default withOnyx({\n policiesMemberList: {\n key: ONYXKEYS.COLLECTION.POLICY_MEMBER_LIST,\n },\n policies: {\n key: ONYXKEYS.COLLECTION.POLICY,\n },\n bankAccountList: {\n key: ONYXKEYS.BANK_ACCOUNT_LIST,\n },\n cardList: {\n key: ONYXKEYS.CARD_LIST,\n },\n userWallet: {\n key: ONYXKEYS.USER_WALLET,\n },\n walletTerms: {\n key: ONYXKEYS.WALLET_TERMS,\n },\n loginList: {\n key: ONYXKEYS.LOGIN_LIST,\n },\n})(AvatarWithIndicator);\n","import _ from 'underscore';\nimport React, {Component} from 'react';\nimport {View, FlatList} from 'react-native';\nimport PropTypes from 'prop-types';\nimport styles from '../../styles/styles';\nimport OptionRowLHN from './OptionRowLHN';\nimport variables from '../../styles/variables';\nimport CONST from '../../CONST';\n\nconst propTypes = {\n /** Extra styles for the section list container */\n // eslint-disable-next-line react/forbid-prop-types\n contentContainerStyles: PropTypes.arrayOf(PropTypes.object).isRequired,\n\n /** Sections for the section list */\n data: PropTypes.arrayOf(PropTypes.string).isRequired,\n\n /** Index for option to focus on */\n focusedIndex: PropTypes.number.isRequired,\n\n /** Callback to fire when a row is selected */\n onSelectRow: PropTypes.func.isRequired,\n\n /** Toggle between compact and default view of the option */\n optionMode: PropTypes.oneOf(_.values(CONST.OPTION_MODE)).isRequired,\n\n /** Callback to execute when the SectionList lays out */\n onLayout: PropTypes.func.isRequired,\n\n /** Whether to allow option focus or not */\n shouldDisableFocusOptions: PropTypes.bool,\n};\n\nconst defaultProps = {\n shouldDisableFocusOptions: false,\n};\n\nclass LHNOptionsList extends Component {\n constructor(props) {\n super(props);\n\n this.renderItem = this.renderItem.bind(this);\n this.getItemLayout = this.getItemLayout.bind(this);\n }\n\n /**\n * This function is used to compute the layout of any given item in our list. Since we know that each item will have the exact same height, this is a performance optimization\n * so that the heights can be determined before the options are rendered. Otherwise, the heights are determined when each option is rendering and it causes a lot of overhead on large\n * lists.\n *\n * @param {Array} data - This is the same as the data we pass into the component\n * @param {Number} index the current item's index in the set of data\n *\n * @returns {Object}\n */\n getItemLayout(data, index) {\n const optionHeight = this.props.optionMode === CONST.OPTION_MODE.COMPACT ? variables.optionRowHeightCompact : variables.optionRowHeight;\n return {\n length: optionHeight,\n offset: index * optionHeight,\n index,\n };\n }\n\n /**\n * Function which renders a row in the list\n *\n * @param {Object} params\n * @param {Object} params.item\n * @param {Number} params.index\n *\n * @return {Component}\n */\n renderItem({item, index}) {\n return (\n \n );\n }\n\n render() {\n return (\n \n item}\n stickySectionHeadersEnabled={false}\n renderItem={this.renderItem}\n getItemLayout={this.getItemLayout}\n extraData={this.props.focusedIndex}\n initialNumToRender={5}\n maxToRenderPerBatch={5}\n windowSize={5}\n onLayout={this.props.onLayout}\n />\n \n );\n }\n}\n\nLHNOptionsList.propTypes = propTypes;\nLHNOptionsList.defaultProps = defaultProps;\n\nexport default LHNOptionsList;\n","import _ from 'underscore';\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport {\n TouchableOpacity,\n View,\n StyleSheet,\n} from 'react-native';\nimport * as optionRowStyles from '../../styles/optionRowStyles';\nimport styles from '../../styles/styles';\nimport * as StyleUtils from '../../styles/StyleUtils';\nimport Icon from '../Icon';\nimport * as Expensicons from '../Icon/Expensicons';\nimport MultipleAvatars from '../MultipleAvatars';\nimport Hoverable from '../Hoverable';\nimport DisplayNames from '../DisplayNames';\nimport colors from '../../styles/colors';\nimport withLocalize, {withLocalizePropTypes} from '../withLocalize';\nimport Text from '../Text';\nimport SubscriptAvatar from '../SubscriptAvatar';\nimport CONST from '../../CONST';\nimport variables from '../../styles/variables';\nimport themeColors from '../../styles/themes/default';\nimport SidebarUtils from '../../libs/SidebarUtils';\nimport TextPill from '../TextPill';\nimport OfflineWithFeedback from '../OfflineWithFeedback';\n\nconst propTypes = {\n /** Style for hovered state */\n // eslint-disable-next-line react/forbid-prop-types\n hoverStyle: PropTypes.object,\n\n /** The ID of the report that the option is for */\n reportID: PropTypes.string.isRequired,\n\n /** Whether this option is currently in focus so we can modify its style */\n isFocused: PropTypes.bool,\n\n /** A function that is called when an option is selected. Selected option is passed as a param */\n onSelectRow: PropTypes.func,\n\n /** Toggle between compact and default view */\n viewMode: PropTypes.oneOf(_.values(CONST.OPTION_MODE)),\n\n style: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.object), PropTypes.object]),\n\n ...withLocalizePropTypes,\n};\n\nconst defaultProps = {\n hoverStyle: styles.sidebarLinkHover,\n viewMode: 'default',\n onSelectRow: () => {},\n isFocused: false,\n style: null,\n};\n\nconst OptionRowLHN = (props) => {\n const optionItem = SidebarUtils.getOptionData(props.reportID);\n if (!optionItem) {\n return null;\n }\n\n let touchableRef = null;\n const textStyle = props.isFocused\n ? styles.sidebarLinkActiveText\n : styles.sidebarLinkText;\n const textUnreadStyle = optionItem.isUnread\n ? [textStyle, styles.sidebarLinkTextBold] : [textStyle];\n const displayNameStyle = StyleUtils.combineStyles([styles.optionDisplayName, styles.optionDisplayNameCompact, styles.pre, ...textUnreadStyle], props.style);\n const textPillStyle = props.isFocused\n ? [styles.ml1, StyleUtils.getBackgroundColorWithOpacityStyle(themeColors.icon, 0.5)]\n : [styles.ml1];\n const alternateTextStyle = StyleUtils.combineStyles(props.viewMode === CONST.OPTION_MODE.COMPACT\n ? [textStyle, styles.optionAlternateText, styles.pre, styles.textLabelSupporting, styles.optionAlternateTextCompact, styles.ml2]\n : [textStyle, styles.optionAlternateText, styles.pre, styles.textLabelSupporting], props.style);\n const contentContainerStyles = props.viewMode === CONST.OPTION_MODE.COMPACT\n ? [styles.flex1, styles.flexRow, styles.overflowHidden, optionRowStyles.compactContentContainerStyles]\n : [styles.flex1];\n const sidebarInnerRowStyle = StyleSheet.flatten(props.viewMode === CONST.OPTION_MODE.COMPACT ? [\n styles.chatLinkRowPressable,\n styles.flexGrow1,\n styles.optionItemAvatarNameWrapper,\n styles.optionRowCompact,\n styles.justifyContentCenter,\n ] : [\n styles.chatLinkRowPressable,\n styles.flexGrow1,\n styles.optionItemAvatarNameWrapper,\n styles.optionRow,\n styles.justifyContentCenter,\n ]);\n const hoveredBackgroundColor = props.hoverStyle && props.hoverStyle.backgroundColor\n ? props.hoverStyle.backgroundColor\n : themeColors.sidebar;\n const focusedBackgroundColor = styles.sidebarLinkActive.backgroundColor;\n\n const avatarTooltips = !optionItem.isChatRoom && !optionItem.isArchivedRoom ? _.pluck(optionItem.displayNamesWithTooltips, 'tooltip') : undefined;\n\n return (\n \n \n {hovered => (\n touchableRef = el}\n onPress={(e) => {\n if (e) {\n e.preventDefault();\n }\n\n props.onSelectRow(optionItem, touchableRef);\n }}\n activeOpacity={0.8}\n style={[\n styles.flexRow,\n styles.alignItemsCenter,\n styles.justifyContentBetween,\n styles.sidebarLink,\n styles.sidebarLinkInner,\n StyleUtils.getBackgroundColorStyle(themeColors.sidebar),\n props.isFocused ? styles.sidebarLinkActive : null,\n hovered && !props.isFocused ? props.hoverStyle : null,\n ]}\n >\n \n \n {\n !_.isEmpty(optionItem.icons)\n && (\n optionItem.shouldShowSubscript ? (\n \n ) : (\n \n )\n )\n }\n \n \n \n {optionItem.isChatRoom && (\n \n )}\n \n {optionItem.alternateText ? (\n \n {optionItem.alternateText}\n \n ) : null}\n \n {optionItem.descriptiveText ? (\n \n \n {optionItem.descriptiveText}\n \n \n ) : null}\n {optionItem.brickRoadIndicator === CONST.BRICK_ROAD_INDICATOR_STATUS.ERROR && (\n \n \n \n )}\n \n \n \n {optionItem.hasDraftComment && (\n \n \n \n )}\n {optionItem.hasOutstandingIOU && !optionItem.isIOUReportOwner && }\n {optionItem.isPinned && (\n \n \n \n )}\n \n \n )}\n \n \n );\n};\n\nOptionRowLHN.propTypes = propTypes;\nOptionRowLHN.defaultProps = defaultProps;\nOptionRowLHN.displayName = 'OptionRowLHN';\n\nexport default withLocalize(OptionRowLHN);\n","import styles from '../styles';\n\n/**\n * On native platforms, alignItemsBaseline does not work correctly\n * in lining the items together. As such, on native platform, we're\n * keeping compactContentContainerStyles as it is.\n * https://github.com/Expensify/App/issues/14148\n*/\n\nconst compactContentContainerStyles = styles.alignItemsCenter;\n\nexport {\n // eslint-disable-next-line import/prefer-default-export\n compactContentContainerStyles,\n};\n","import Onyx from 'react-native-onyx';\nimport _ from 'underscore';\nimport lodashGet from 'lodash/get';\nimport lodashOrderBy from 'lodash/orderBy';\nimport Str from 'expensify-common/lib/str';\nimport ONYXKEYS from '../ONYXKEYS';\nimport * as ReportUtils from './ReportUtils';\nimport * as ReportActionsUtils from './ReportActionsUtils';\nimport * as Localize from './Localize';\nimport CONST from '../CONST';\nimport * as OptionsListUtils from './OptionsListUtils';\nimport * as CollectionUtils from './CollectionUtils';\n\n// Note: It is very important that the keys subscribed to here are the same\n// keys that are connected to SidebarLinks withOnyx(). If there was a key missing from SidebarLinks and it's data was updated\n// for that key, then there would be no re-render and the options wouldn't reflect the new data because SidebarUtils.getOrderedReportIDs() wouldn't be triggered.\n// There are a couple of keys here which are OK to have stale data. iouReports for example, doesn't need to exist in withOnyx() because\n// when IOUs change, it also triggers a change on the reports collection. Having redundant subscriptions causes more re-renders which should be avoided.\n// Session also can remain stale because the only way for the current user to change is to sign out and sign in, which would clear out all the Onyx\n// data anyway and cause SidebarLinks to rerender.\n\nconst chatReports = {};\nconst iouReports = {};\nOnyx.connect({\n key: ONYXKEYS.COLLECTION.REPORT,\n callback: (report, key) => {\n if (!report) {\n delete iouReports[key];\n delete chatReports[key];\n } else if (ReportUtils.isIOUReport(report)) {\n iouReports[key] = report;\n } else {\n chatReports[key] = report;\n }\n },\n});\n\nlet personalDetails;\nOnyx.connect({\n key: ONYXKEYS.PERSONAL_DETAILS,\n callback: val => personalDetails = val,\n});\n\nlet priorityMode;\nOnyx.connect({\n key: ONYXKEYS.NVP_PRIORITY_MODE,\n callback: val => priorityMode = val,\n});\n\nlet betas;\nOnyx.connect({\n key: ONYXKEYS.BETAS,\n callback: val => betas = val,\n});\n\nconst visibleReportActionItems = {};\nconst lastReportActions = {};\nconst reportActions = {};\nOnyx.connect({\n key: ONYXKEYS.COLLECTION.REPORT_ACTIONS,\n callback: (actions, key) => {\n if (!key || !actions) {\n return;\n }\n const reportID = CollectionUtils.extractCollectionItemID(key);\n\n const actionsArray = _.toArray(actions);\n lastReportActions[reportID] = _.last(actionsArray);\n\n // The report is only visible if it is the last action not deleted that\n // does not match a closed or created state.\n const reportActionsForDisplay = _.filter(actionsArray, (reportAction, actionKey) => (ReportActionsUtils.shouldReportActionBeVisible(reportAction, actionKey)\n && (reportAction.actionName !== CONST.REPORT.ACTIONS.TYPE.CREATED)));\n visibleReportActionItems[reportID] = _.first(ReportActionsUtils.getSortedReportActions(reportActionsForDisplay, true));\n\n reportActions[key] = actions;\n },\n});\n\nlet policies;\nOnyx.connect({\n key: ONYXKEYS.COLLECTION.POLICY,\n waitForCollectionCallback: true,\n callback: val => policies = val,\n});\n\nlet currentUserLogin;\nOnyx.connect({\n key: ONYXKEYS.SESSION,\n callback: val => currentUserLogin = val,\n});\n\nlet preferredLocale;\nOnyx.connect({\n key: ONYXKEYS.NVP_PREFERRED_LOCALE,\n callback: val => preferredLocale = val || CONST.LOCALES.DEFAULT,\n});\n\n/**\n * @param {String} reportIDFromRoute\n * @returns {String[]} An array of reportIDs sorted in the proper order\n */\nfunction getOrderedReportIDs(reportIDFromRoute) {\n const isInGSDMode = priorityMode === CONST.PRIORITY_MODE.GSD;\n const isInDefaultMode = !isInGSDMode;\n\n // Filter out all the reports that shouldn't be displayed\n const reportsToDisplay = _.filter(chatReports, report => ReportUtils.shouldReportBeInOptionList(report, reportIDFromRoute, isInGSDMode, currentUserLogin, iouReports, betas, policies));\n\n // There are a few properties that need to be calculated for the report which are used when sorting reports.\n _.each(reportsToDisplay, (report) => {\n // Normally, the spread operator would be used here to clone the report and prevent the need to reassign the params.\n // However, this code needs to be very performant to handle thousands of reports, so in the interest of speed, we're just going to disable this lint rule and add\n // the reportDisplayName property to the report object directly.\n // eslint-disable-next-line no-param-reassign\n report.displayName = ReportUtils.getReportName(report, policies);\n\n // eslint-disable-next-line no-param-reassign\n report.iouReportAmount = ReportUtils.getIOUTotal(report, iouReports);\n });\n\n // The LHN is split into five distinct groups, and each group is sorted a little differently. The groups will ALWAYS be in this order:\n // 1. Pinned - Always sorted by reportDisplayName\n // 2. Outstanding IOUs - Always sorted by iouReportAmount with the largest amounts at the top of the group\n // 3. Drafts - Always sorted by reportDisplayName\n // 4. Non-archived reports\n // - Sorted by lastVisibleActionCreated in default (most recent) view mode\n // - Sorted by reportDisplayName in GSD (focus) view mode\n // 5. Archived reports\n // - Sorted by lastVisibleActionCreated in default (most recent) view mode\n // - Sorted by reportDisplayName in GSD (focus) view mode\n let pinnedReports = [];\n let outstandingIOUReports = [];\n let draftReports = [];\n let nonArchivedReports = [];\n let archivedReports = [];\n\n _.each(reportsToDisplay, (report) => {\n if (report.isPinned) {\n pinnedReports.push(report);\n return;\n }\n\n if (report.hasOutstandingIOU && !ReportUtils.isIOUOwnedByCurrentUser(report, iouReports)) {\n outstandingIOUReports.push(report);\n return;\n }\n\n if (report.hasDraft) {\n draftReports.push(report);\n return;\n }\n\n if (ReportUtils.isArchivedRoom(report)) {\n archivedReports.push(report);\n return;\n }\n\n nonArchivedReports.push(report);\n });\n\n // Sort each group of reports accordingly\n pinnedReports = _.sortBy(pinnedReports, report => report.displayName.toLowerCase());\n outstandingIOUReports = lodashOrderBy(outstandingIOUReports, ['iouReportAmount', report => report.displayName.toLowerCase()], ['desc', 'asc']);\n draftReports = _.sortBy(draftReports, report => report.displayName.toLowerCase());\n nonArchivedReports = isInDefaultMode\n ? lodashOrderBy(nonArchivedReports, ['lastVisibleActionCreated', report => report.displayName.toLowerCase()], ['desc', 'asc'])\n : lodashOrderBy(nonArchivedReports, [report => report.displayName.toLowerCase()], ['asc']);\n archivedReports = _.sortBy(archivedReports, report => (isInDefaultMode ? report.lastVisibleActionCreated : report.displayName.toLowerCase()));\n\n // For archived reports ensure that most recent reports are at the top by reversing the order of the arrays because underscore will only sort them in ascending order\n if (isInDefaultMode) {\n archivedReports.reverse();\n }\n\n // Now that we have all the reports grouped and sorted, they must be flattened into an array and only return the reportID.\n // The order the arrays are concatenated in matters and will determine the order that the groups are displayed in the sidebar.\n return _.pluck([]\n .concat(pinnedReports)\n .concat(outstandingIOUReports)\n .concat(draftReports)\n .concat(nonArchivedReports)\n .concat(archivedReports), 'reportID');\n}\n\n/**\n * Gets all the data necessary for rendering an OptionRowLHN component\n *\n * @param {String} reportID\n * @returns {Object}\n */\nfunction getOptionData(reportID) {\n const report = chatReports[`${ONYXKEYS.COLLECTION.REPORT}${reportID}`];\n\n // When a user signs out, Onyx is cleared. Due to the lazy rendering with a virtual list, it's possible for\n // this method to be called after the Onyx data has been cleared out. In that case, it's fine to do\n // a null check here and return early.\n if (!report || !personalDetails) {\n return;\n }\n const result = {\n text: null,\n alternateText: null,\n pendingAction: null,\n allReportErrors: null,\n brickRoadIndicator: null,\n icons: null,\n tooltipText: null,\n ownerEmail: null,\n subtitle: null,\n participantsList: null,\n login: null,\n reportID: null,\n phoneNumber: null,\n payPalMeAddress: null,\n isUnread: null,\n hasDraftComment: false,\n keyForList: null,\n searchText: null,\n isPinned: false,\n hasOutstandingIOU: false,\n iouReportID: null,\n isIOUReportOwner: null,\n iouReportAmount: 0,\n isChatRoom: false,\n isArchivedRoom: false,\n shouldShowSubscript: false,\n isPolicyExpenseChat: false,\n };\n\n const participantPersonalDetailList = _.values(OptionsListUtils.getPersonalDetailsForLogins(report.participants, personalDetails));\n const personalDetail = participantPersonalDetailList[0] || {};\n\n result.isChatRoom = ReportUtils.isChatRoom(report);\n result.isArchivedRoom = ReportUtils.isArchivedRoom(report);\n result.isPolicyExpenseChat = ReportUtils.isPolicyExpenseChat(report);\n result.shouldShowSubscript = result.isPolicyExpenseChat && !report.isOwnPolicyExpenseChat && !result.isArchivedRoom;\n result.pendingAction = report.pendingFields ? (report.pendingFields.addWorkspaceRoom || report.pendingFields.createChat) : null;\n result.allReportErrors = OptionsListUtils.getAllReportErrors(report, reportActions);\n result.brickRoadIndicator = !_.isEmpty(result.allReportErrors) ? CONST.BRICK_ROAD_INDICATOR_STATUS.ERROR : '';\n result.ownerEmail = report.ownerEmail;\n result.reportID = report.reportID;\n result.isUnread = ReportUtils.isUnread(report);\n result.hasDraftComment = report.hasDraft;\n result.isPinned = report.isPinned;\n result.iouReportID = report.iouReportID;\n result.keyForList = String(report.reportID);\n result.tooltipText = ReportUtils.getReportParticipantsTitle(report.participants || []);\n result.hasOutstandingIOU = report.hasOutstandingIOU;\n\n const hasMultipleParticipants = participantPersonalDetailList.length > 1 || result.isChatRoom || result.isPolicyExpenseChat;\n const subtitle = ReportUtils.getChatRoomSubtitle(report, policies);\n\n // We only create tooltips for the first 10 users or so since some reports have hundreds of users, causing performance to degrade.\n const displayNamesWithTooltips = ReportUtils.getDisplayNamesWithTooltips((participantPersonalDetailList || []).slice(0, 10), hasMultipleParticipants);\n\n let lastMessageTextFromReport = '';\n if (ReportUtils.isReportMessageAttachment({text: report.lastMessageText, html: report.lastMessageHtml})) {\n lastMessageTextFromReport = `[${Localize.translateLocal('common.attachment')}]`;\n } else {\n lastMessageTextFromReport = report ? report.lastMessageText || '' : '';\n }\n\n // If the last actor's details are not currently saved in Onyx Collection,\n // then try to get that from the last report action if that action is valid\n // to get data from.\n let lastActorDetails = personalDetails[report.lastActorEmail] || null;\n if (!lastActorDetails && visibleReportActionItems[report.reportID]) {\n const lastActorDisplayName = lodashGet(visibleReportActionItems[report.reportID], 'person[0].text');\n lastActorDetails = lastActorDisplayName ? {\n displayName: lastActorDisplayName,\n login: report.lastActorEmail,\n } : null;\n }\n let lastMessageText = hasMultipleParticipants && lastActorDetails && (lastActorDetails.login !== currentUserLogin.email)\n ? `${lastActorDetails.displayName}: `\n : '';\n lastMessageText += report ? lastMessageTextFromReport : '';\n\n if (result.isPolicyExpenseChat && result.isArchivedRoom) {\n const archiveReason = (lastReportActions[report.reportID] && lastReportActions[report.reportID].originalMessage && lastReportActions[report.reportID].originalMessage.reason)\n || CONST.REPORT.ARCHIVE_REASON.DEFAULT;\n lastMessageText = Localize.translate(preferredLocale, `reportArchiveReasons.${archiveReason}`, {\n displayName: archiveReason.displayName || report.lastActorEmail,\n policyName: ReportUtils.getPolicyName(report, policies),\n });\n }\n\n if (result.isChatRoom || result.isPolicyExpenseChat) {\n result.alternateText = lastMessageTextFromReport.length > 0 ? lastMessageText : Localize.translate(preferredLocale, 'report.noActivityYet');\n } else {\n if (!lastMessageText) {\n // Here we get the beginning of chat history message and append the display name for each user, adding pronouns if there are any.\n // We also add a fullstop after the final name, the word \"and\" before the final name and commas between all previous names.\n lastMessageText = Localize.translate(preferredLocale, 'reportActionsView.beginningOfChatHistory')\n + _.map(displayNamesWithTooltips, ({displayName, pronouns}, index) => {\n const formattedText = _.isEmpty(pronouns) ? displayName : `${displayName} (${pronouns})`;\n\n if (index === displayNamesWithTooltips.length - 1) { return `${formattedText}.`; }\n if (index === displayNamesWithTooltips.length - 2) { return `${formattedText} ${Localize.translate(preferredLocale, 'common.and')}`; }\n if (index < displayNamesWithTooltips.length - 2) { return `${formattedText},`; }\n }).join(' ');\n }\n\n result.alternateText = lastMessageText || Str.removeSMSDomain(personalDetail.login);\n }\n\n result.isIOUReportOwner = ReportUtils.isIOUOwnedByCurrentUser(result, iouReports);\n result.iouReportAmount = ReportUtils.getIOUTotal(result, iouReports);\n\n if (!hasMultipleParticipants) {\n result.login = personalDetail.login;\n result.phoneNumber = personalDetail.phoneNumber;\n result.payPalMeAddress = personalDetail.payPalMeAddress;\n }\n\n const reportName = ReportUtils.getReportName(report, policies);\n result.text = reportName;\n result.subtitle = subtitle;\n result.participantsList = participantPersonalDetailList;\n\n result.icons = ReportUtils.getIcons(report, personalDetails, policies, ReportUtils.getAvatar(personalDetail.avatar, personalDetail.login));\n result.searchText = OptionsListUtils.getSearchText(report, reportName, participantPersonalDetailList, result.isChatRoom || result.isPolicyExpenseChat);\n result.displayNamesWithTooltips = displayNamesWithTooltips;\n\n return result;\n}\n\nexport default {\n getOptionData,\n getOrderedReportIDs,\n};\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport Text from './Text';\nimport styles from '../styles/styles';\nimport stylePropTypes from '../styles/stylePropTypes';\nimport * as StyleUtils from '../styles/StyleUtils';\n\nconst propTypes = {\n text: PropTypes.string.isRequired,\n\n /** Text additional style */\n style: stylePropTypes,\n};\n\nconst defaultProps = {\n style: [],\n};\n\nconst TextPill = (props) => {\n const propsStyle = StyleUtils.parseStyleAsArray(props.style);\n\n // eslint-disable-next-line react/jsx-props-no-spreading\n return {props.text};\n};\n\nTextPill.propTypes = propTypes;\nTextPill.defaultProps = defaultProps;\nTextPill.displayName = 'TextPill';\n\nexport default TextPill;\n","import React from 'react';\nimport {View} from 'react-native';\nimport PropTypes from 'prop-types';\nimport {Rect, Circle} from 'react-native-svg';\nimport SkeletonViewContentLoader from 'react-content-loader/native';\nimport CONST from '../CONST';\nimport themeColors from '../styles/themes/default';\nimport styles from '../styles/styles';\n\nconst propTypes = {\n /** Whether to animate the skeleton view */\n shouldAnimate: PropTypes.bool,\n};\n\nconst defaultTypes = {\n shouldAnimate: true,\n};\n\nclass LHNSkeletonView extends React.Component {\n constructor(props) {\n super(props);\n this.state = {\n skeletonViewItems: [],\n };\n }\n\n /**\n * Generate the skeleton view items.\n *\n * @param {Number} numItems\n */\n generateSkeletonViewItems(numItems) {\n if (this.state.skeletonViewItems.length === numItems) {\n return;\n }\n\n if (this.state.skeletonViewItems.length > numItems) {\n this.setState(prevState => ({\n skeletonViewItems: prevState.skeletonViewItems.slice(0, numItems),\n }));\n return;\n }\n\n const skeletonViewItems = [];\n for (let i = this.state.skeletonViewItems.length; i < numItems; i++) {\n const step = i % 3;\n let lineWidth;\n switch (step) {\n case 0:\n lineWidth = '100%';\n break;\n case 1:\n lineWidth = '50%';\n break;\n default:\n lineWidth = '25%';\n }\n skeletonViewItems.push(\n \n \n \n \n ,\n );\n }\n\n this.setState(prevState => ({\n skeletonViewItems: [...prevState.skeletonViewItems, ...skeletonViewItems],\n }));\n }\n\n render() {\n return (\n {\n const numItems = Math.ceil(event.nativeEvent.layout.height / CONST.LHN_SKELETON_VIEW_ITEM_HEIGHT);\n this.generateSkeletonViewItems(numItems);\n }}\n >\n {this.state.skeletonViewItems}\n \n );\n }\n}\n\nLHNSkeletonView.propTypes = propTypes;\nLHNSkeletonView.defaultProps = defaultTypes;\n\nexport default LHNSkeletonView;\n","import React from 'react';\nimport _ from 'underscore';\nimport {withOnyx} from 'react-native-onyx';\nimport PropTypes from 'prop-types';\nimport lodashGet from 'lodash/get';\nimport {View} from 'react-native';\nimport styles from '../../../../styles/styles';\nimport * as Expensicons from '../../../../components/Icon/Expensicons';\nimport Navigation from '../../../../libs/Navigation/Navigation';\nimport ROUTES from '../../../../ROUTES';\nimport Permissions from '../../../../libs/Permissions';\nimport * as Policy from '../../../../libs/actions/Policy';\nimport PopoverMenu from '../../../../components/PopoverMenu';\nimport CONST from '../../../../CONST';\nimport FloatingActionButton from '../../../../components/FloatingActionButton';\nimport compose from '../../../../libs/compose';\nimport withLocalize, {withLocalizePropTypes} from '../../../../components/withLocalize';\nimport withWindowDimensions from '../../../../components/withWindowDimensions';\nimport ONYXKEYS from '../../../../ONYXKEYS';\nimport withNavigation from '../../../../components/withNavigation';\nimport * as Welcome from '../../../../libs/actions/Welcome';\nimport withNavigationFocus from '../../../../components/withNavigationFocus';\nimport withDrawerState from '../../../../components/withDrawerState';\n\n/**\n * @param {Object} [policy]\n * @returns {Object|undefined}\n */\nconst policySelector = policy => policy && ({\n type: policy.type,\n role: policy.role,\n});\n\nconst propTypes = {\n /* Callback function when the menu is shown */\n onShowCreateMenu: PropTypes.func,\n\n /* Callback function before the menu is hidden */\n onHideCreateMenu: PropTypes.func,\n\n /** The list of policies the user has access to. */\n allPolicies: PropTypes.shape({\n /** The policy name */\n name: PropTypes.string,\n }),\n\n /* Beta features list */\n betas: PropTypes.arrayOf(PropTypes.string),\n\n /** Indicated whether the report data is loading */\n isLoading: PropTypes.bool,\n\n ...withLocalizePropTypes,\n};\nconst defaultProps = {\n onHideCreateMenu: () => {},\n onShowCreateMenu: () => {},\n allPolicies: {},\n betas: [],\n isLoading: false,\n};\n\n/**\n * Responsible for rendering the {@link PopoverMenu}, and the accompanying\n * FAB that can open or close the menu.\n */\nclass FloatingActionButtonAndPopover extends React.Component {\n constructor(props) {\n super(props);\n\n this.showCreateMenu = this.showCreateMenu.bind(this);\n this.hideCreateMenu = this.hideCreateMenu.bind(this);\n\n this.state = {\n isCreateMenuActive: false,\n };\n }\n\n componentDidMount() {\n const routes = lodashGet(this.props.navigation.getState(), 'routes', []);\n Welcome.show({routes, showCreateMenu: this.showCreateMenu});\n }\n\n componentDidUpdate(prevProps) {\n if (!this.didScreenBecomeInactive(prevProps)) {\n return;\n }\n\n // Hide menu manually when other pages are opened using shortcut key\n this.hideCreateMenu();\n }\n\n /**\n * Check if LHN status changed from active to inactive.\n * Used to close already opened FAB menu when open any other pages (i.e. Press Command + K on web).\n *\n * @param {Object} prevProps\n * @return {Boolean}\n */\n didScreenBecomeInactive(prevProps) {\n // When the Drawer gets closed and ReportScreen is shown\n if (!this.props.isDrawerOpen && prevProps.isDrawerOpen) {\n return true;\n }\n\n // When any other page is opened over LHN\n if (!this.props.isFocused && prevProps.isFocused) {\n return true;\n }\n\n return false;\n }\n\n /**\n * Check if LHN is inactive.\n * Used to prevent FAB menu showing after opening any other pages.\n *\n * @return {Boolean}\n */\n isScreenInactive() {\n // When drawer is closed and Report page is open\n if (this.props.isSmallScreenWidth && !this.props.isDrawerOpen) {\n return true;\n }\n\n // When any other page is open\n if (!this.props.isFocused) {\n return true;\n }\n\n return false;\n }\n\n /**\n * Method called when we click the floating action button\n */\n showCreateMenu() {\n if (this.isScreenInactive()) {\n // Prevent showing menu when click FAB icon quickly after opening other pages\n return;\n }\n this.setState({\n isCreateMenuActive: true,\n });\n this.props.onShowCreateMenu();\n }\n\n /**\n * Method called either when:\n * - Pressing the floating action button to open the CreateMenu modal\n * - Selecting an item on CreateMenu or closing it by clicking outside of the modal component\n */\n hideCreateMenu() {\n if (!this.state.isCreateMenuActive) {\n return;\n }\n this.props.onHideCreateMenu();\n this.setState({\n isCreateMenuActive: false,\n });\n }\n\n render() {\n // Workspaces are policies with type === 'free'\n const workspaces = _.filter(this.props.allPolicies, policy => policy && policy.type === CONST.POLICY.TYPE.FREE);\n\n return (\n \n Navigation.navigate(ROUTES.NEW_CHAT),\n },\n {\n icon: Expensicons.Users,\n text: this.props.translate('sidebarScreen.newGroup'),\n onSelected: () => Navigation.navigate(ROUTES.NEW_GROUP),\n },\n ...(Permissions.canUsePolicyRooms(this.props.betas) && workspaces.length ? [\n {\n icon: Expensicons.Hashtag,\n text: this.props.translate('sidebarScreen.newRoom'),\n onSelected: () => Navigation.navigate(ROUTES.WORKSPACE_NEW_ROOM),\n },\n ] : []),\n ...(Permissions.canUseIOUSend(this.props.betas) ? [\n {\n icon: Expensicons.Send,\n text: this.props.translate('iou.sendMoney'),\n onSelected: () => Navigation.navigate(ROUTES.IOU_SEND),\n },\n ] : []),\n ...(Permissions.canUseIOU(this.props.betas) ? [\n {\n icon: Expensicons.MoneyCircle,\n text: this.props.translate('iou.requestMoney'),\n onSelected: () => Navigation.navigate(ROUTES.IOU_REQUEST),\n },\n ] : []),\n ...(Permissions.canUseIOU(this.props.betas) ? [\n {\n icon: Expensicons.Receipt,\n text: this.props.translate('iou.splitBill'),\n onSelected: () => Navigation.navigate(ROUTES.IOU_BILL),\n },\n ] : []),\n ...(!this.props.isLoading && !Policy.hasActiveFreePolicy(this.props.allPolicies) ? [\n {\n icon: Expensicons.NewWorkspace,\n iconWidth: 46,\n iconHeight: 40,\n text: this.props.translate('workspace.new.newWorkspace'),\n description: this.props.translate('workspace.new.getTheExpensifyCardAndMore'),\n onSelected: () => Policy.createWorkspace(),\n },\n ] : []),\n ]}\n />\n \n \n );\n }\n}\n\nFloatingActionButtonAndPopover.propTypes = propTypes;\nFloatingActionButtonAndPopover.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withNavigation,\n withNavigationFocus,\n withDrawerState,\n withWindowDimensions,\n withOnyx({\n allPolicies: {\n key: ONYXKEYS.COLLECTION.POLICY,\n selector: policySelector,\n },\n betas: {\n key: ONYXKEYS.BETAS,\n },\n isLoading: {\n key: ONYXKEYS.IS_LOADING_REPORT_DATA,\n },\n }),\n)(FloatingActionButtonAndPopover);\n","import React, {PureComponent} from 'react';\nimport {\n Pressable, Animated, Easing, View,\n} from 'react-native';\nimport PropTypes from 'prop-types';\nimport Icon from './Icon';\nimport * as Expensicons from './Icon/Expensicons';\nimport styles from '../styles/styles';\nimport * as StyleUtils from '../styles/StyleUtils';\nimport themeColors from '../styles/themes/default';\nimport Tooltip from './Tooltip';\nimport withLocalize, {withLocalizePropTypes} from './withLocalize';\n\nconst AnimatedIcon = Animated.createAnimatedComponent(Icon);\nAnimatedIcon.displayName = 'AnimatedIcon';\n\nconst AnimatedPressable = Animated.createAnimatedComponent(Pressable);\nAnimatedPressable.displayName = 'AnimatedPressable';\n\nconst propTypes = {\n // Callback to fire on request to toggle the FloatingActionButton\n onPress: PropTypes.func.isRequired,\n\n // Current state (active or not active) of the component\n isActive: PropTypes.bool.isRequired,\n\n ...withLocalizePropTypes,\n};\n\nclass FloatingActionButton extends PureComponent {\n constructor(props) {\n super(props);\n this.animatedValue = new Animated.Value(props.isActive ? 1 : 0);\n }\n\n componentDidUpdate(prevProps) {\n if (prevProps.isActive === this.props.isActive) {\n return;\n }\n\n this.animateFloatingActionButton();\n }\n\n /**\n * Animates the floating action button\n * Method is called when the isActive prop changes\n */\n animateFloatingActionButton() {\n const animationFinalValue = this.props.isActive ? 1 : 0;\n\n Animated.timing(this.animatedValue, {\n toValue: animationFinalValue,\n duration: 340,\n easing: Easing.inOut(Easing.ease),\n useNativeDriver: false,\n }).start();\n }\n\n render() {\n const rotate = this.animatedValue.interpolate({\n inputRange: [0, 1],\n outputRange: ['0deg', '135deg'],\n });\n\n const backgroundColor = this.animatedValue.interpolate({\n inputRange: [0, 1],\n outputRange: [themeColors.success, themeColors.buttonDefaultBG],\n });\n\n const fill = this.animatedValue.interpolate({\n inputRange: [0, 1],\n outputRange: [themeColors.textLight, themeColors.textDark],\n });\n\n return (\n \n \n this.fabPressable = el}\n accessibilityLabel={this.props.accessibilityLabel}\n accessibilityRole={this.props.accessibilityRole}\n onPress={(e) => {\n // Drop focus to avoid blue focus ring.\n this.fabPressable.blur();\n this.props.onPress(e);\n }}\n style={[\n styles.floatingActionButton,\n StyleUtils.getAnimatedFABStyle(rotate, backgroundColor),\n ]}\n >\n \n \n \n \n );\n }\n}\n\nFloatingActionButton.propTypes = propTypes;\n\nexport default withLocalize(FloatingActionButton);\n","import React, {Component} from 'react';\nimport _ from 'underscore';\nimport PropTypes from 'prop-types';\nimport {createDrawerNavigator} from '@react-navigation/drawer';\nimport {View} from 'react-native';\nimport withWindowDimensions, {windowDimensionsPropTypes} from '../../../components/withWindowDimensions';\nimport styles from '../../../styles/styles';\nimport * as StyleUtils from '../../../styles/StyleUtils';\n\nimport Navigation from '../Navigation';\n\nconst propTypes = {\n /** Screens to be passed in the Drawer */\n screens: PropTypes.arrayOf(PropTypes.shape({\n /** Name of the Screen */\n name: PropTypes.string.isRequired,\n\n /** Component for the Screen */\n component: PropTypes.elementType.isRequired,\n\n /** Optional params to be passed to the Screen */\n // eslint-disable-next-line react/forbid-prop-types\n initialParams: PropTypes.object,\n })).isRequired,\n\n /** Drawer content Component */\n drawerContent: PropTypes.elementType.isRequired,\n\n /** If it's the main screen, don't wrap the content even if it's a full screen modal. */\n isMainScreen: PropTypes.bool,\n\n /** Window Dimensions props */\n ...windowDimensionsPropTypes,\n};\nconst Drawer = createDrawerNavigator();\n\nconst defaultProps = {\n isMainScreen: false,\n};\n\nclass BaseDrawerNavigator extends Component {\n constructor(props) {\n super(props);\n this.state = {\n // Calculate the defaultStatus only once on mount to prevent breaking the navigation internal state.\n // Directly passing the dynamically calculated defaultStatus to drawer Navigator breaks the internal state\n // And prevents the drawer actions from reaching to active Drawer Navigator while screen is resized on from Web to mobile Web.\n defaultStatus: Navigation.getDefaultDrawerState(props.isSmallScreenWidth),\n };\n }\n\n componentDidMount() {\n // We need to resolve the isDrawerReady promise so that any pending drawer actions, like direct navigation from OldDot to\n // a NewDot report, can happen.\n Navigation.setIsDrawerReady();\n }\n\n componentDidUpdate(prevProps) {\n if (prevProps.isSmallScreenWidth === this.props.isSmallScreenWidth) {\n return;\n }\n\n // eslint-disable-next-line react/no-did-update-set-state\n this.setState({\n defaultStatus: Navigation.getDefaultDrawerState(this.props.isSmallScreenWidth),\n });\n }\n\n componentWillUnmount() {\n // When logging into NewDot first, then navigating from OldDot to NewDot with a different account, this component will be remounted.\n // We need to reset the isDrawerReady promise so that we can delay the call to dismissModal until the drawer is really ready.\n Navigation.resetDrawerIsReadyPromise();\n }\n\n render() {\n const content = (\n \n {_.map(this.props.screens, screen => (\n \n ))}\n \n );\n\n if (!this.props.isMainScreen && !this.props.isSmallScreenWidth) {\n return (\n \n {content}\n \n );\n }\n\n return content;\n }\n}\n\nBaseDrawerNavigator.propTypes = propTypes;\nBaseDrawerNavigator.defaultProps = defaultProps;\nBaseDrawerNavigator.displayName = 'BaseDrawerNavigator';\nexport default withWindowDimensions(BaseDrawerNavigator);\n","import React, {Component} from 'react';\nimport PropTypes from 'prop-types';\nimport {withOnyx} from 'react-native-onyx';\nimport lodashGet from 'lodash/get';\nimport {\n propTypes as validateLinkPropTypes,\n defaultProps as validateLinkDefaultProps,\n} from './validateLinkPropTypes';\nimport * as User from '../../libs/actions/User';\nimport FullScreenLoadingIndicator from '../../components/FullscreenLoadingIndicator';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport * as Session from '../../libs/actions/Session';\nimport Permissions from '../../libs/Permissions';\nimport Navigation from '../../libs/Navigation/Navigation';\n\nconst propTypes = {\n /** The accountID and validateCode are passed via the URL */\n route: validateLinkPropTypes,\n\n /** List of betas available to current user */\n betas: PropTypes.arrayOf(PropTypes.string),\n\n /** Session of currently logged in user */\n session: PropTypes.shape({\n /** Currently logged in user authToken */\n authToken: PropTypes.string,\n }),\n};\n\nconst defaultProps = {\n route: validateLinkDefaultProps,\n betas: [],\n session: {\n authToken: null,\n },\n};\n\nclass ValidateLoginPage extends Component {\n componentDidMount() {\n const accountID = lodashGet(this.props.route.params, 'accountID', '');\n const validateCode = lodashGet(this.props.route.params, 'validateCode', '');\n if (Permissions.canUsePasswordlessLogins(this.props.betas)) {\n if (lodashGet(this.props, 'session.authToken')) {\n // If already signed in, do not show the validate code if not on web,\n // because we don't want to block the user with the interstitial page.\n Navigation.goBack(false);\n } else {\n Session.signInWithValidateCodeAndNavigate(accountID, validateCode);\n }\n } else {\n User.validateLogin(accountID, validateCode);\n }\n }\n\n render() {\n return ;\n }\n}\n\nValidateLoginPage.propTypes = propTypes;\nValidateLoginPage.defaultProps = defaultProps;\n\nexport default withOnyx({\n betas: {key: ONYXKEYS.BETAS},\n session: {key: ONYXKEYS.SESSION},\n})(ValidateLoginPage);\n","import PropTypes from 'prop-types';\n\nconst propTypes = PropTypes.shape({\n // The name of the route\n name: PropTypes.string,\n\n // Unique key associated with the route\n key: PropTypes.string,\n\n // Each parameter passed via the URL\n params: PropTypes.shape({\n // AccountID associated with the validation link\n accountID: PropTypes.string,\n\n // Validation code associated with the validation link\n validateCode: PropTypes.string,\n }),\n});\n\nconst defaultProps = {\n params: {},\n};\n\nexport {\n propTypes,\n defaultProps,\n};\n","import React, {Component} from 'react';\nimport {Linking} from 'react-native';\nimport lodashGet from 'lodash/get';\nimport PropTypes from 'prop-types';\nimport {withOnyx} from 'react-native-onyx';\nimport ONYXKEYS from '../ONYXKEYS';\nimport * as Session from '../libs/actions/Session';\nimport FullScreenLoadingIndicator from '../components/FullscreenLoadingIndicator';\nimport * as SessionUtils from '../libs/SessionUtils';\n\nconst propTypes = {\n /** The data about the current session which will be set once the user is authenticated and we return to this component as an AuthScreen */\n session: PropTypes.shape({\n /** The user's email for the current session */\n email: PropTypes.string,\n }),\n};\n\nconst defaultProps = {\n session: {\n email: null,\n },\n};\n\nclass LogOutPreviousUserPage extends Component {\n componentDidMount() {\n Linking.getInitialURL()\n .then((transitionURL) => {\n const sessionEmail = this.props.session.email;\n const isLoggingInAsNewUser = SessionUtils.isLoggingInAsNewUser(transitionURL, sessionEmail);\n\n if (isLoggingInAsNewUser) {\n Session.signOutAndRedirectToSignIn();\n }\n\n // We need to signin and fetch a new authToken, if a user was already authenticated in NewDot, and was redirected to OldDot\n // and their authToken stored in Onyx becomes invalid.\n // This workflow is triggered while setting up VBBA. User is redirected from NewDot to OldDot to set up 2FA, and then redirected back to NewDot\n // On Enabling 2FA, authToken stored in Onyx becomes expired and hence we need to fetch new authToken\n const shouldForceLogin = lodashGet(this.props, 'route.params.shouldForceLogin', '') === 'true';\n if (shouldForceLogin) {\n const email = lodashGet(this.props, 'route.params.email', '');\n const shortLivedAuthToken = lodashGet(this.props, 'route.params.shortLivedAuthToken', '');\n Session.signInWithShortLivedAuthToken(email, shortLivedAuthToken);\n }\n });\n }\n\n render() {\n return ;\n }\n}\n\nLogOutPreviousUserPage.propTypes = propTypes;\nLogOutPreviousUserPage.defaultProps = defaultProps;\nexport default withOnyx({\n session: {\n key: ONYXKEYS.SESSION,\n },\n})(LogOutPreviousUserPage);\n","import _ from 'underscore';\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport {withOnyx} from 'react-native-onyx';\nimport ONYXKEYS from '../ONYXKEYS';\nimport FullScreenLoadingIndicator from '../components/FullscreenLoadingIndicator';\nimport Navigation from '../libs/Navigation/Navigation';\nimport * as Report from '../libs/actions/Report';\n\nconst propTypes = {\n /** Session info for the currently logged in user. */\n session: PropTypes.shape({\n /** Currently logged in user authToken */\n authToken: PropTypes.string,\n }),\n};\n\nconst defaultProps = {\n session: {\n authToken: null,\n },\n};\n\n/*\n * This is a \"utility page\", that does this:\n * - If the user is authenticated, find their concierge chat and re-route to it\n * - Else re-route to the login page\n */\nconst ConciergePage = (props) => {\n if (_.has(props.session, 'authToken')) {\n Navigation.isDrawerReady().then(() => {\n Report.navigateToConciergeChat();\n });\n } else {\n Navigation.navigate();\n }\n\n return ;\n};\n\nConciergePage.propTypes = propTypes;\nConciergePage.defaultProps = defaultProps;\nConciergePage.displayName = 'ConciergePage';\n\nexport default withOnyx({\n session: {\n key: ONYXKEYS.SESSION,\n },\n})(ConciergePage);\n","import React from 'react';\nimport {createStackNavigator} from '@react-navigation/stack';\nimport SignInPage from '../../../pages/signin/SignInPage';\nimport SetPasswordPage from '../../../pages/SetPasswordPage';\nimport ValidateLoginPage from '../../../pages/ValidateLoginPage';\nimport LogInWithShortLivedAuthTokenPage from '../../../pages/LogInWithShortLivedAuthTokenPage';\nimport SCREENS from '../../../SCREENS';\nimport defaultScreenOptions from './defaultScreenOptions';\n\nconst RootStack = createStackNavigator();\n\nconst PublicScreens = () => (\n \n \n \n \n \n \n);\n\nPublicScreens.displayName = 'PublicScreens';\nexport default PublicScreens;\n","import React, {Component} from 'react';\nimport PropTypes from 'prop-types';\nimport {withOnyx} from 'react-native-onyx';\nimport lodashGet from 'lodash/get';\nimport Str from 'expensify-common/lib/str';\nimport {SafeAreaView} from 'react-native-safe-area-context';\nimport ONYXKEYS from '../../ONYXKEYS';\nimport styles from '../../styles/styles';\nimport compose from '../../libs/compose';\nimport SignInPageLayout from './SignInPageLayout';\nimport LoginForm from './LoginForm';\nimport PasswordForm from './PasswordForm';\nimport ValidateCodeForm from './ValidateCodeForm';\nimport ResendValidationForm from './ResendValidationForm';\nimport withLocalize, {withLocalizePropTypes} from '../../components/withLocalize';\nimport Performance from '../../libs/Performance';\nimport * as App from '../../libs/actions/App';\nimport Permissions from '../../libs/Permissions';\nimport withWindowDimensions, {windowDimensionsPropTypes} from '../../components/withWindowDimensions';\nimport * as Localize from '../../libs/Localize';\n\nconst propTypes = {\n /* Onyx Props */\n\n /** The details about the account that the user is signing in with */\n account: PropTypes.shape({\n /** Error to display when there is an account error returned */\n errors: PropTypes.objectOf(PropTypes.string),\n\n /** Whether the account is validated */\n validated: PropTypes.bool,\n }),\n\n /** List of betas available to current user */\n betas: PropTypes.arrayOf(PropTypes.string),\n\n /** The credentials of the person signing in */\n credentials: PropTypes.shape({\n login: PropTypes.string,\n password: PropTypes.string,\n twoFactorAuthCode: PropTypes.string,\n }),\n\n ...withLocalizePropTypes,\n\n ...windowDimensionsPropTypes,\n};\n\nconst defaultProps = {\n account: {},\n betas: [],\n credentials: {},\n};\n\nclass SignInPage extends Component {\n componentDidMount() {\n Performance.measureTTI();\n\n App.setLocale(Localize.getDevicePreferredLocale());\n }\n\n render() {\n // Show the login form if\n // - A login has not been entered yet\n // - AND a validateCode has not been cached with sign in link\n const showLoginForm = !this.props.credentials.login && !this.props.credentials.validateCode;\n\n // Show the old password form if\n // - A login has been entered\n // - AND an account exists and is validated for this login\n // - AND a password hasn't been entered yet\n // - AND haven't forgotten password\n // - AND the user is NOT on the passwordless beta\n const showPasswordForm = Boolean(this.props.credentials.login)\n && this.props.account.validated\n && !this.props.credentials.password\n && !this.props.account.forgotPassword\n && !Permissions.canUsePasswordlessLogins(this.props.betas);\n\n // Show the new magic code / validate code form if\n // - A login has been entered or a validateCode has been cached from sign in link\n // - AND the user is on the 'passwordless' beta\n const showValidateCodeForm = (this.props.credentials.login\n || this.props.credentials.validateCode)\n && Permissions.canUsePasswordlessLogins(this.props.betas);\n\n // Show the resend validation link form if\n // - A login has been entered\n // - AND is not validated or password is forgotten\n // - AND user is not on 'passwordless' beta\n const showResendValidationForm = Boolean(this.props.credentials.login)\n && (!this.props.account.validated || this.props.account.forgotPassword)\n && !Permissions.canUsePasswordlessLogins(this.props.betas);\n\n let welcomeHeader = '';\n let welcomeText = '';\n if (showValidateCodeForm) {\n if (this.props.account.requiresTwoFactorAuth) {\n // We will only know this after a user signs in successfully, without their 2FA code\n welcomeHeader = this.props.isSmallScreenWidth ? '' : this.props.translate('welcomeText.welcomeBack');\n welcomeText = this.props.translate('validateCodeForm.enterAuthenticatorCode');\n } else {\n const userLogin = Str.removeSMSDomain(lodashGet(this.props, 'credentials.login', ''));\n\n if (this.props.account.validated) {\n welcomeHeader = this.props.isSmallScreenWidth ? '' : this.props.translate('welcomeText.welcomeBack');\n welcomeText = this.props.isSmallScreenWidth\n ? `${this.props.translate('welcomeText.welcomeBack')} ${this.props.translate('welcomeText.welcomeEnterMagicCode', {login: userLogin})}`\n : this.props.translate('welcomeText.welcomeEnterMagicCode', {login: userLogin});\n } else {\n welcomeHeader = this.props.isSmallScreenWidth ? '' : this.props.translate('welcomeText.welcome');\n welcomeText = this.props.isSmallScreenWidth\n ? `${this.props.translate('welcomeText.welcome')} ${this.props.translate('welcomeText.newFaceEnterMagicCode', {login: userLogin})}`\n : this.props.translate('welcomeText.newFaceEnterMagicCode', {login: userLogin});\n }\n }\n } else if (showPasswordForm) {\n welcomeHeader = this.props.isSmallScreenWidth ? '' : this.props.translate('welcomeText.welcomeBack');\n welcomeText = this.props.isSmallScreenWidth\n ? `${this.props.translate('welcomeText.welcomeBack')} ${this.props.translate('welcomeText.enterPassword')}`\n : this.props.translate('welcomeText.enterPassword');\n } else if (!showResendValidationForm) {\n welcomeHeader = this.props.isSmallScreenWidth ? this.props.translate('login.hero.header') : this.props.translate('welcomeText.getStarted');\n welcomeText = this.props.isSmallScreenWidth ? this.props.translate('welcomeText.getStarted') : '';\n }\n\n return (\n \n \n {/* LoginForm and PasswordForm must use the isVisible prop. This keeps them mounted, but visually hidden\n so that password managers can access the values. Conditionally rendering these components will break this feature. */}\n \n {showValidateCodeForm ? (\n \n ) : (\n \n )}\n {showResendValidationForm && }\n \n \n );\n }\n}\n\nSignInPage.propTypes = propTypes;\nSignInPage.defaultProps = defaultProps;\n\nexport default compose(\n withLocalize,\n withWindowDimensions,\n withOnyx({\n account: {key: ONYXKEYS.ACCOUNT},\n betas: {key: ONYXKEYS.BETAS},\n credentials: {key: ONYXKEYS.CREDENTIALS},\n }),\n)(SignInPage);\n","import React, {useRef} from 'react';\nimport {View, ScrollView} from 'react-native';\nimport {withSafeAreaInsets} from 'react-native-safe-area-context';\nimport PropTypes from 'prop-types';\nimport compose from '../../../libs/compose';\nimport SignInPageContent from './SignInPageContent';\nimport Footer from './Footer';\nimport withWindowDimensions, {windowDimensionsPropTypes} from '../../../components/withWindowDimensions';\nimport styles from '../../../styles/styles';\nimport SignInPageHero from '../SignInPageHero';\nimport * as StyleUtils from '../../../styles/StyleUtils';\nimport scrollViewContentContainerStyles from './signInPageStyles';\nimport themeColors from '../../../styles/themes/default';\nimport SignInHeroBackgroundImage from '../../../../assets/images/home-background--desktop.svg';\nimport SignInHeroBackgroundImageMobile from '../../../../assets/images/home-background--mobile.svg';\nimport SignInGradient from '../../../../assets/images/home-fade-gradient.svg';\nimport variables from '../../../styles/variables';\n\nconst propTypes = {\n /** The children to show inside the layout */\n children: PropTypes.node.isRequired,\n\n /** Welcome text to show in the header of the form, changes depending\n * on form type (set password, sign in, etc.) */\n welcomeText: PropTypes.string.isRequired,\n\n /** Welcome header to show in the header of the form, changes depending\n * on form type (set password, sign in, etc.) and small vs large screens */\n welcomeHeader: PropTypes.string.isRequired,\n\n /** Whether to show welcome text on a particular page */\n shouldShowWelcomeText: PropTypes.bool.isRequired,\n\n /** Whether to show welcome header on a particular page */\n shouldShowWelcomeHeader: PropTypes.bool.isRequired,\n\n ...windowDimensionsPropTypes,\n};\n\nconst SignInPageLayout = (props) => {\n const scrollViewRef = useRef(null);\n let containerStyles = [styles.flex1, styles.signInPageInner];\n let contentContainerStyles = [styles.flex1, styles.flexRow];\n\n // To scroll on both mobile and web, we need to set the container height manually\n const containerHeight = props.windowHeight - props.insets.top - props.insets.bottom;\n\n if (props.isSmallScreenWidth) {\n containerStyles = [styles.flex1];\n contentContainerStyles = [styles.flex1, styles.flexColumn];\n }\n\n return (\n \n {!props.isSmallScreenWidth\n ? (\n \n \n {props.children}\n \n \n \n \n \n \n \n \n \n \n \n \n