--- /home/fdroid/fdroiddata/tmp/com.superproductivity.superproductivity_1601000000.apk +++ /home/fdroid/fdroiddata/tmp/sigcp_com.superproductivity.superproductivity_1601000000.apk ├── zipinfo {} │ @@ -139,46 +139,42 @@ │ -rw-r--r-- 0.0 unx 32056 b- defN 81-Jan-01 01:01 assets/public/chunk-3E43H4SH.js.map │ -rw-r--r-- 0.0 unx 11730 b- defN 81-Jan-01 01:01 assets/public/chunk-3H2FJG22.js │ -rw-r--r-- 0.0 unx 18636 b- defN 81-Jan-01 01:01 assets/public/chunk-3H2FJG22.js.map │ -rw-r--r-- 0.0 unx 289602 b- defN 81-Jan-01 01:01 assets/public/chunk-3JNAQVCX.js │ -rw-r--r-- 0.0 unx 1092647 b- defN 81-Jan-01 01:01 assets/public/chunk-3JNAQVCX.js.map │ -rw-r--r-- 0.0 unx 615 b- defN 81-Jan-01 01:01 assets/public/chunk-3UB54IM4.js │ -rw-r--r-- 0.0 unx 2240 b- defN 81-Jan-01 01:01 assets/public/chunk-3UB54IM4.js.map │ --rw-r--r-- 0.0 unx 66923 b- defN 81-Jan-01 01:01 assets/public/chunk-3UN2ZJEW.js │ --rw-r--r-- 0.0 unx 263769 b- defN 81-Jan-01 01:01 assets/public/chunk-3UN2ZJEW.js.map │ -rw-r--r-- 0.0 unx 320096 b- defN 81-Jan-01 01:01 assets/public/chunk-3YGNIIAP.js │ -rw-r--r-- 0.0 unx 3107378 b- defN 81-Jan-01 01:01 assets/public/chunk-3YGNIIAP.js.map │ +-rw-r--r-- 0.0 unx 3128 b- defN 81-Jan-01 01:01 assets/public/chunk-4RLJGC7Y.js │ +-rw-r--r-- 0.0 unx 9576 b- defN 81-Jan-01 01:01 assets/public/chunk-4RLJGC7Y.js.map │ -rw-r--r-- 0.0 unx 4853 b- defN 81-Jan-01 01:01 assets/public/chunk-4WKVJOAH.js │ -rw-r--r-- 0.0 unx 56024 b- defN 81-Jan-01 01:01 assets/public/chunk-4WKVJOAH.js.map │ -rw-r--r-- 0.0 unx 729 b- defN 81-Jan-01 01:01 assets/public/chunk-4ZJF7VAV.js │ -rw-r--r-- 0.0 unx 2317 b- defN 81-Jan-01 01:01 assets/public/chunk-4ZJF7VAV.js.map │ -rw-r--r-- 0.0 unx 1201 b- defN 81-Jan-01 01:01 assets/public/chunk-5FY5BJAX.js │ -rw-r--r-- 0.0 unx 3448 b- defN 81-Jan-01 01:01 assets/public/chunk-5FY5BJAX.js.map │ -rw-r--r-- 0.0 unx 2832 b- defN 81-Jan-01 01:01 assets/public/chunk-5GGCGH4Z.js │ -rw-r--r-- 0.0 unx 4560 b- defN 81-Jan-01 01:01 assets/public/chunk-5GGCGH4Z.js.map │ -rw-r--r-- 0.0 unx 11550 b- defN 81-Jan-01 01:01 assets/public/chunk-5Q2SPJG4.js │ -rw-r--r-- 0.0 unx 46053 b- defN 81-Jan-01 01:01 assets/public/chunk-5Q2SPJG4.js.map │ --rw-r--r-- 0.0 unx 1239 b- defN 81-Jan-01 01:01 assets/public/chunk-5QMEDHY4.js │ --rw-r--r-- 0.0 unx 93 b- defN 81-Jan-01 01:01 assets/public/chunk-5QMEDHY4.js.map │ -rw-r--r-- 0.0 unx 1476 b- defN 81-Jan-01 01:01 assets/public/chunk-5YKVP3TE.js │ -rw-r--r-- 0.0 unx 4788 b- defN 81-Jan-01 01:01 assets/public/chunk-5YKVP3TE.js.map │ -rw-r--r-- 0.0 unx 51630 b- defN 81-Jan-01 01:01 assets/public/chunk-6IO6G5NZ.js │ -rw-r--r-- 0.0 unx 186219 b- defN 81-Jan-01 01:01 assets/public/chunk-6IO6G5NZ.js.map │ -rw-r--r-- 0.0 unx 8065 b- defN 81-Jan-01 01:01 assets/public/chunk-6MWZ5TDN.js │ -rw-r--r-- 0.0 unx 28045 b- defN 81-Jan-01 01:01 assets/public/chunk-6MWZ5TDN.js.map │ -rw-r--r-- 0.0 unx 602 b- defN 81-Jan-01 01:01 assets/public/chunk-6Q234R2T.js │ -rw-r--r-- 0.0 unx 2080 b- defN 81-Jan-01 01:01 assets/public/chunk-6Q234R2T.js.map │ -rw-r--r-- 0.0 unx 64006 b- defN 81-Jan-01 01:01 assets/public/chunk-6T5VISW6.js │ -rw-r--r-- 0.0 unx 320342 b- defN 81-Jan-01 01:01 assets/public/chunk-6T5VISW6.js.map │ -rw-r--r-- 0.0 unx 9378 b- defN 81-Jan-01 01:01 assets/public/chunk-6XQACCEC.js │ -rw-r--r-- 0.0 unx 21304 b- defN 81-Jan-01 01:01 assets/public/chunk-6XQACCEC.js.map │ -rw-r--r-- 0.0 unx 2204 b- defN 81-Jan-01 01:01 assets/public/chunk-75YLN6G6.js │ -rw-r--r-- 0.0 unx 8779 b- defN 81-Jan-01 01:01 assets/public/chunk-75YLN6G6.js.map │ --rw-r--r-- 0.0 unx 60151 b- defN 81-Jan-01 01:01 assets/public/chunk-7E7XZV7L.js │ --rw-r--r-- 0.0 unx 171870 b- defN 81-Jan-01 01:01 assets/public/chunk-7E7XZV7L.js.map │ -rw-r--r-- 0.0 unx 23638 b- defN 81-Jan-01 01:01 assets/public/chunk-7LFRM354.js │ -rw-r--r-- 0.0 unx 41275 b- defN 81-Jan-01 01:01 assets/public/chunk-7LFRM354.js.map │ -rw-r--r-- 0.0 unx 4447 b- defN 81-Jan-01 01:01 assets/public/chunk-7TTGPFQ5.js │ -rw-r--r-- 0.0 unx 6897 b- defN 81-Jan-01 01:01 assets/public/chunk-7TTGPFQ5.js.map │ -rw-r--r-- 0.0 unx 10796 b- defN 81-Jan-01 01:01 assets/public/chunk-A5MBRGPF.js │ -rw-r--r-- 0.0 unx 41610 b- defN 81-Jan-01 01:01 assets/public/chunk-A5MBRGPF.js.map │ -rw-r--r-- 0.0 unx 335 b- defN 81-Jan-01 01:01 assets/public/chunk-A6QD6H33.js │ @@ -187,14 +183,18 @@ │ -rw-r--r-- 0.0 unx 69151 b- defN 81-Jan-01 01:01 assets/public/chunk-AS3S2TBN.js.map │ -rw-r--r-- 0.0 unx 72868 b- defN 81-Jan-01 01:01 assets/public/chunk-AZM2QNV4.js │ -rw-r--r-- 0.0 unx 190910 b- defN 81-Jan-01 01:01 assets/public/chunk-AZM2QNV4.js.map │ -rw-r--r-- 0.0 unx 18421 b- defN 81-Jan-01 01:01 assets/public/chunk-B6XN2BK4.js │ -rw-r--r-- 0.0 unx 70107 b- defN 81-Jan-01 01:01 assets/public/chunk-B6XN2BK4.js.map │ -rw-r--r-- 0.0 unx 2372 b- defN 81-Jan-01 01:01 assets/public/chunk-BMHAY4F7.js │ -rw-r--r-- 0.0 unx 4992 b- defN 81-Jan-01 01:01 assets/public/chunk-BMHAY4F7.js.map │ +-rw-r--r-- 0.0 unx 66923 b- defN 81-Jan-01 01:01 assets/public/chunk-BMOQZ47J.js │ +-rw-r--r-- 0.0 unx 263769 b- defN 81-Jan-01 01:01 assets/public/chunk-BMOQZ47J.js.map │ +-rw-r--r-- 0.0 unx 11487 b- defN 81-Jan-01 01:01 assets/public/chunk-BN6Q5XR6.js │ +-rw-r--r-- 0.0 unx 22568 b- defN 81-Jan-01 01:01 assets/public/chunk-BN6Q5XR6.js.map │ -rw-r--r-- 0.0 unx 997 b- defN 81-Jan-01 01:01 assets/public/chunk-BOROUNNF.js │ -rw-r--r-- 0.0 unx 93 b- defN 81-Jan-01 01:01 assets/public/chunk-BOROUNNF.js.map │ -rw-r--r-- 0.0 unx 426 b- defN 81-Jan-01 01:01 assets/public/chunk-CEBZA2UK.js │ -rw-r--r-- 0.0 unx 949 b- defN 81-Jan-01 01:01 assets/public/chunk-CEBZA2UK.js.map │ -rw-r--r-- 0.0 unx 2757 b- defN 81-Jan-01 01:01 assets/public/chunk-CHZIB6D3.js │ -rw-r--r-- 0.0 unx 10909 b- defN 81-Jan-01 01:01 assets/public/chunk-CHZIB6D3.js.map │ -rw-r--r-- 0.0 unx 139991 b- defN 81-Jan-01 01:01 assets/public/chunk-COMUK3PO.js │ @@ -205,20 +205,16 @@ │ -rw-r--r-- 0.0 unx 84790 b- defN 81-Jan-01 01:01 assets/public/chunk-DEIXUMEX.js.map │ -rw-r--r-- 0.0 unx 24246 b- defN 81-Jan-01 01:01 assets/public/chunk-EIOJRFED.js │ -rw-r--r-- 0.0 unx 97875 b- defN 81-Jan-01 01:01 assets/public/chunk-EIOJRFED.js.map │ -rw-r--r-- 0.0 unx 8870 b- defN 81-Jan-01 01:01 assets/public/chunk-EKZCH65S.js │ -rw-r--r-- 0.0 unx 44826 b- defN 81-Jan-01 01:01 assets/public/chunk-EKZCH65S.js.map │ -rw-r--r-- 0.0 unx 2589 b- defN 81-Jan-01 01:01 assets/public/chunk-EQ4JYBLN.js │ -rw-r--r-- 0.0 unx 6355 b- defN 81-Jan-01 01:01 assets/public/chunk-EQ4JYBLN.js.map │ --rw-r--r-- 0.0 unx 308589 b- defN 81-Jan-01 01:01 assets/public/chunk-ESEBWQAA.js │ --rw-r--r-- 0.0 unx 986258 b- defN 81-Jan-01 01:01 assets/public/chunk-ESEBWQAA.js.map │ -rw-r--r-- 0.0 unx 7075 b- defN 81-Jan-01 01:01 assets/public/chunk-FDVZKVGI.js │ -rw-r--r-- 0.0 unx 25025 b- defN 81-Jan-01 01:01 assets/public/chunk-FDVZKVGI.js.map │ --rw-r--r-- 0.0 unx 121414 b- defN 81-Jan-01 01:01 assets/public/chunk-FPT5Z6JU.js │ --rw-r--r-- 0.0 unx 183450 b- defN 81-Jan-01 01:01 assets/public/chunk-FPT5Z6JU.js.map │ -rw-r--r-- 0.0 unx 15302 b- defN 81-Jan-01 01:01 assets/public/chunk-FQ7WHKEJ.js │ -rw-r--r-- 0.0 unx 38211 b- defN 81-Jan-01 01:01 assets/public/chunk-FQ7WHKEJ.js.map │ -rw-r--r-- 0.0 unx 21584 b- defN 81-Jan-01 01:01 assets/public/chunk-FXWGNVSN.js │ -rw-r--r-- 0.0 unx 63836 b- defN 81-Jan-01 01:01 assets/public/chunk-FXWGNVSN.js.map │ -rw-r--r-- 0.0 unx 76950 b- defN 81-Jan-01 01:01 assets/public/chunk-G3HJ2GL3.js │ -rw-r--r-- 0.0 unx 182973 b- defN 81-Jan-01 01:01 assets/public/chunk-G3HJ2GL3.js.map │ -rw-r--r-- 0.0 unx 58453 b- defN 81-Jan-01 01:01 assets/public/chunk-GFYDE73T.js │ @@ -227,36 +223,34 @@ │ -rw-r--r-- 0.0 unx 7789 b- defN 81-Jan-01 01:01 assets/public/chunk-GQ3B3APM.js.map │ -rw-r--r-- 0.0 unx 511 b- defN 81-Jan-01 01:01 assets/public/chunk-GR6WLWW6.js │ -rw-r--r-- 0.0 unx 1526 b- defN 81-Jan-01 01:01 assets/public/chunk-GR6WLWW6.js.map │ -rw-r--r-- 0.0 unx 2469 b- defN 81-Jan-01 01:01 assets/public/chunk-GTBEH26W.js │ -rw-r--r-- 0.0 unx 6496 b- defN 81-Jan-01 01:01 assets/public/chunk-GTBEH26W.js.map │ -rw-r--r-- 0.0 unx 16047 b- defN 81-Jan-01 01:01 assets/public/chunk-GXVY7KCK.js │ -rw-r--r-- 0.0 unx 30930 b- defN 81-Jan-01 01:01 assets/public/chunk-GXVY7KCK.js.map │ --rw-r--r-- 0.0 unx 30088 b- defN 81-Jan-01 01:01 assets/public/chunk-H53RCMH4.js │ --rw-r--r-- 0.0 unx 109138 b- defN 81-Jan-01 01:01 assets/public/chunk-H53RCMH4.js.map │ -rw-r--r-- 0.0 unx 4045 b- defN 81-Jan-01 01:01 assets/public/chunk-HHRVCHRC.js │ -rw-r--r-- 0.0 unx 10549 b- defN 81-Jan-01 01:01 assets/public/chunk-HHRVCHRC.js.map │ -rw-r--r-- 0.0 unx 20772 b- defN 81-Jan-01 01:01 assets/public/chunk-HK5C6VCX.js │ -rw-r--r-- 0.0 unx 35313 b- defN 81-Jan-01 01:01 assets/public/chunk-HK5C6VCX.js.map │ -rw-r--r-- 0.0 unx 29922 b- defN 81-Jan-01 01:01 assets/public/chunk-IC3NSLMU.js │ -rw-r--r-- 0.0 unx 82098 b- defN 81-Jan-01 01:01 assets/public/chunk-IC3NSLMU.js.map │ -rw-r--r-- 0.0 unx 3591 b- defN 81-Jan-01 01:01 assets/public/chunk-IEH6VBVE.js │ -rw-r--r-- 0.0 unx 10962 b- defN 81-Jan-01 01:01 assets/public/chunk-IEH6VBVE.js.map │ -rw-r--r-- 0.0 unx 676 b- defN 81-Jan-01 01:01 assets/public/chunk-ISS7OXYA.js │ -rw-r--r-- 0.0 unx 2139 b- defN 81-Jan-01 01:01 assets/public/chunk-ISS7OXYA.js.map │ -rw-r--r-- 0.0 unx 42728 b- defN 81-Jan-01 01:01 assets/public/chunk-J6NQAXQS.js │ -rw-r--r-- 0.0 unx 170408 b- defN 81-Jan-01 01:01 assets/public/chunk-J6NQAXQS.js.map │ +-rw-r--r-- 0.0 unx 121414 b- defN 81-Jan-01 01:01 assets/public/chunk-JFDPASXB.js │ +-rw-r--r-- 0.0 unx 183450 b- defN 81-Jan-01 01:01 assets/public/chunk-JFDPASXB.js.map │ -rw-r--r-- 0.0 unx 1560 b- defN 81-Jan-01 01:01 assets/public/chunk-JPCQKKKF.js │ -rw-r--r-- 0.0 unx 4533 b- defN 81-Jan-01 01:01 assets/public/chunk-JPCQKKKF.js.map │ -rw-r--r-- 0.0 unx 1195 b- defN 81-Jan-01 01:01 assets/public/chunk-K4YYFBL5.js │ -rw-r--r-- 0.0 unx 2945 b- defN 81-Jan-01 01:01 assets/public/chunk-K4YYFBL5.js.map │ --rw-r--r-- 0.0 unx 1157 b- defN 81-Jan-01 01:01 assets/public/chunk-K7NMWD4N.js │ --rw-r--r-- 0.0 unx 93 b- defN 81-Jan-01 01:01 assets/public/chunk-K7NMWD4N.js.map │ --rw-r--r-- 0.0 unx 65206 b- defN 81-Jan-01 01:01 assets/public/chunk-KCXVAHDW.js │ --rw-r--r-- 0.0 unx 164867 b- defN 81-Jan-01 01:01 assets/public/chunk-KCXVAHDW.js.map │ +-rw-r--r-- 0.0 unx 60151 b- defN 81-Jan-01 01:01 assets/public/chunk-L3GF7I2Z.js │ +-rw-r--r-- 0.0 unx 171870 b- defN 81-Jan-01 01:01 assets/public/chunk-L3GF7I2Z.js.map │ -rw-r--r-- 0.0 unx 3295 b- defN 81-Jan-01 01:01 assets/public/chunk-L4MCALUY.js │ -rw-r--r-- 0.0 unx 13598 b- defN 81-Jan-01 01:01 assets/public/chunk-L4MCALUY.js.map │ -rw-r--r-- 0.0 unx 2003 b- defN 81-Jan-01 01:01 assets/public/chunk-LASEIKFS.js │ -rw-r--r-- 0.0 unx 3277 b- defN 81-Jan-01 01:01 assets/public/chunk-LASEIKFS.js.map │ -rw-r--r-- 0.0 unx 20083 b- defN 81-Jan-01 01:01 assets/public/chunk-LOPNAQUA.js │ -rw-r--r-- 0.0 unx 30423 b- defN 81-Jan-01 01:01 assets/public/chunk-LOPNAQUA.js.map │ -rw-r--r-- 0.0 unx 3415 b- defN 81-Jan-01 01:01 assets/public/chunk-MAMSXR4J.js │ @@ -265,32 +259,34 @@ │ -rw-r--r-- 0.0 unx 959 b- defN 81-Jan-01 01:01 assets/public/chunk-MASHVMAF.js.map │ -rw-r--r-- 0.0 unx 88574 b- defN 81-Jan-01 01:01 assets/public/chunk-ME6P3K44.js │ -rw-r--r-- 0.0 unx 260163 b- defN 81-Jan-01 01:01 assets/public/chunk-ME6P3K44.js.map │ -rw-r--r-- 0.0 unx 479 b- defN 81-Jan-01 01:01 assets/public/chunk-MKQ5S2AR.js │ -rw-r--r-- 0.0 unx 4619 b- defN 81-Jan-01 01:01 assets/public/chunk-MKQ5S2AR.js.map │ -rw-r--r-- 0.0 unx 5654 b- defN 81-Jan-01 01:01 assets/public/chunk-N2NWBZ3C.js │ -rw-r--r-- 0.0 unx 20575 b- defN 81-Jan-01 01:01 assets/public/chunk-N2NWBZ3C.js.map │ +-rw-r--r-- 0.0 unx 1239 b- defN 81-Jan-01 01:01 assets/public/chunk-NVQIQL7A.js │ +-rw-r--r-- 0.0 unx 93 b- defN 81-Jan-01 01:01 assets/public/chunk-NVQIQL7A.js.map │ -rw-r--r-- 0.0 unx 4604 b- defN 81-Jan-01 01:01 assets/public/chunk-NWTLDK7P.js │ -rw-r--r-- 0.0 unx 8705 b- defN 81-Jan-01 01:01 assets/public/chunk-NWTLDK7P.js.map │ -rw-r--r-- 0.0 unx 120407 b- defN 81-Jan-01 01:01 assets/public/chunk-OCWFHHQL.js │ -rw-r--r-- 0.0 unx 455554 b- defN 81-Jan-01 01:01 assets/public/chunk-OCWFHHQL.js.map │ -rw-r--r-- 0.0 unx 4381 b- defN 81-Jan-01 01:01 assets/public/chunk-OOOTUPN3.js │ -rw-r--r-- 0.0 unx 12382 b- defN 81-Jan-01 01:01 assets/public/chunk-OOOTUPN3.js.map │ -rw-r--r-- 0.0 unx 3929 b- defN 81-Jan-01 01:01 assets/public/chunk-OVAWK6DV.js │ -rw-r--r-- 0.0 unx 9310 b- defN 81-Jan-01 01:01 assets/public/chunk-OVAWK6DV.js.map │ -rw-r--r-- 0.0 unx 202242 b- defN 81-Jan-01 01:01 assets/public/chunk-OXDOKNTF.js │ -rw-r--r-- 0.0 unx 824865 b- defN 81-Jan-01 01:01 assets/public/chunk-OXDOKNTF.js.map │ --rw-r--r-- 0.0 unx 11487 b- defN 81-Jan-01 01:01 assets/public/chunk-OZT432CE.js │ --rw-r--r-- 0.0 unx 22568 b- defN 81-Jan-01 01:01 assets/public/chunk-OZT432CE.js.map │ -rw-r--r-- 0.0 unx 8263 b- defN 81-Jan-01 01:01 assets/public/chunk-PEJGMLLQ.js │ -rw-r--r-- 0.0 unx 32372 b- defN 81-Jan-01 01:01 assets/public/chunk-PEJGMLLQ.js.map │ -rw-r--r-- 0.0 unx 131880 b- defN 81-Jan-01 01:01 assets/public/chunk-PJXD7IVF.js │ -rw-r--r-- 0.0 unx 435740 b- defN 81-Jan-01 01:01 assets/public/chunk-PJXD7IVF.js.map │ -rw-r--r-- 0.0 unx 3990 b- defN 81-Jan-01 01:01 assets/public/chunk-PNLDAEIU.js │ -rw-r--r-- 0.0 unx 13802 b- defN 81-Jan-01 01:01 assets/public/chunk-PNLDAEIU.js.map │ +-rw-r--r-- 0.0 unx 1157 b- defN 81-Jan-01 01:01 assets/public/chunk-PP3XGOFY.js │ +-rw-r--r-- 0.0 unx 93 b- defN 81-Jan-01 01:01 assets/public/chunk-PP3XGOFY.js.map │ -rw-r--r-- 0.0 unx 2699 b- defN 81-Jan-01 01:01 assets/public/chunk-Q56B2KJS.js │ -rw-r--r-- 0.0 unx 11365 b- defN 81-Jan-01 01:01 assets/public/chunk-Q56B2KJS.js.map │ -rw-r--r-- 0.0 unx 35797 b- defN 81-Jan-01 01:01 assets/public/chunk-Q5BN5VPC.js │ -rw-r--r-- 0.0 unx 149379 b- defN 81-Jan-01 01:01 assets/public/chunk-Q5BN5VPC.js.map │ -rw-r--r-- 0.0 unx 2562 b- defN 81-Jan-01 01:01 assets/public/chunk-QC3JWOUK.js │ -rw-r--r-- 0.0 unx 10428 b- defN 81-Jan-01 01:01 assets/public/chunk-QC3JWOUK.js.map │ -rw-r--r-- 0.0 unx 411 b- defN 81-Jan-01 01:01 assets/public/chunk-QX6K6DBU.js │ @@ -303,42 +299,46 @@ │ -rw-r--r-- 0.0 unx 53817 b- defN 81-Jan-01 01:01 assets/public/chunk-RC2FJQR5.js.map │ -rw-r--r-- 0.0 unx 17890 b- defN 81-Jan-01 01:01 assets/public/chunk-RG7L3PKS.js │ -rw-r--r-- 0.0 unx 61979 b- defN 81-Jan-01 01:01 assets/public/chunk-RG7L3PKS.js.map │ -rw-r--r-- 0.0 unx 46053 b- defN 81-Jan-01 01:01 assets/public/chunk-RHU3AIGY.js │ -rw-r--r-- 0.0 unx 232748 b- defN 81-Jan-01 01:01 assets/public/chunk-RHU3AIGY.js.map │ -rw-r--r-- 0.0 unx 594 b- defN 81-Jan-01 01:01 assets/public/chunk-RIUWQQE2.js │ -rw-r--r-- 0.0 unx 2136 b- defN 81-Jan-01 01:01 assets/public/chunk-RIUWQQE2.js.map │ +-rw-r--r-- 0.0 unx 65206 b- defN 81-Jan-01 01:01 assets/public/chunk-RK7AP4LR.js │ +-rw-r--r-- 0.0 unx 164867 b- defN 81-Jan-01 01:01 assets/public/chunk-RK7AP4LR.js.map │ -rw-r--r-- 0.0 unx 8679 b- defN 81-Jan-01 01:01 assets/public/chunk-RR36S4JZ.js │ -rw-r--r-- 0.0 unx 14186 b- defN 81-Jan-01 01:01 assets/public/chunk-RR36S4JZ.js.map │ -rw-r--r-- 0.0 unx 126899 b- defN 81-Jan-01 01:01 assets/public/chunk-RSJU6TEG.js │ -rw-r--r-- 0.0 unx 307709 b- defN 81-Jan-01 01:01 assets/public/chunk-RSJU6TEG.js.map │ -rw-r--r-- 0.0 unx 3655 b- defN 81-Jan-01 01:01 assets/public/chunk-TF4ZGOZ4.js │ -rw-r--r-- 0.0 unx 11641 b- defN 81-Jan-01 01:01 assets/public/chunk-TF4ZGOZ4.js.map │ --rw-r--r-- 0.0 unx 3128 b- defN 81-Jan-01 01:01 assets/public/chunk-TLVKTX5S.js │ --rw-r--r-- 0.0 unx 9576 b- defN 81-Jan-01 01:01 assets/public/chunk-TLVKTX5S.js.map │ -rw-r--r-- 0.0 unx 826979 b- defN 81-Jan-01 01:01 assets/public/chunk-TU2ETAFZ.js │ -rw-r--r-- 0.0 unx 1914613 b- defN 81-Jan-01 01:01 assets/public/chunk-TU2ETAFZ.js.map │ -rw-r--r-- 0.0 unx 32087 b- defN 81-Jan-01 01:01 assets/public/chunk-U233VVFY.js │ -rw-r--r-- 0.0 unx 143700 b- defN 81-Jan-01 01:01 assets/public/chunk-U233VVFY.js.map │ -rw-r--r-- 0.0 unx 42285 b- defN 81-Jan-01 01:01 assets/public/chunk-UNSYVKTP.js │ -rw-r--r-- 0.0 unx 342603 b- defN 81-Jan-01 01:01 assets/public/chunk-UNSYVKTP.js.map │ -rw-r--r-- 0.0 unx 4716 b- defN 81-Jan-01 01:01 assets/public/chunk-USV4YXDW.js │ -rw-r--r-- 0.0 unx 18923 b- defN 81-Jan-01 01:01 assets/public/chunk-USV4YXDW.js.map │ -rw-r--r-- 0.0 unx 27443 b- defN 81-Jan-01 01:01 assets/public/chunk-UVYK2G5X.js │ -rw-r--r-- 0.0 unx 75505 b- defN 81-Jan-01 01:01 assets/public/chunk-UVYK2G5X.js.map │ -rw-r--r-- 0.0 unx 903 b- defN 81-Jan-01 01:01 assets/public/chunk-VALZJMB4.js │ -rw-r--r-- 0.0 unx 1735 b- defN 81-Jan-01 01:01 assets/public/chunk-VALZJMB4.js.map │ -rw-r--r-- 0.0 unx 22325 b- defN 81-Jan-01 01:01 assets/public/chunk-VLI2QFPH.js │ -rw-r--r-- 0.0 unx 54165 b- defN 81-Jan-01 01:01 assets/public/chunk-VLI2QFPH.js.map │ +-rw-r--r-- 0.0 unx 308589 b- defN 81-Jan-01 01:01 assets/public/chunk-VOQG7765.js │ +-rw-r--r-- 0.0 unx 986258 b- defN 81-Jan-01 01:01 assets/public/chunk-VOQG7765.js.map │ -rw-r--r-- 0.0 unx 33182 b- defN 81-Jan-01 01:01 assets/public/chunk-W2DLB2HC.js │ -rw-r--r-- 0.0 unx 112433 b- defN 81-Jan-01 01:01 assets/public/chunk-W2DLB2HC.js.map │ -rw-r--r-- 0.0 unx 965 b- defN 81-Jan-01 01:01 assets/public/chunk-W3EHXDVY.js │ -rw-r--r-- 0.0 unx 3891 b- defN 81-Jan-01 01:01 assets/public/chunk-W3EHXDVY.js.map │ -rw-r--r-- 0.0 unx 1343 b- defN 81-Jan-01 01:01 assets/public/chunk-WG4QBSGF.js │ -rw-r--r-- 0.0 unx 8779 b- defN 81-Jan-01 01:01 assets/public/chunk-WG4QBSGF.js.map │ +-rw-r--r-- 0.0 unx 30088 b- defN 81-Jan-01 01:01 assets/public/chunk-WKAXUHLX.js │ +-rw-r--r-- 0.0 unx 109138 b- defN 81-Jan-01 01:01 assets/public/chunk-WKAXUHLX.js.map │ -rw-r--r-- 0.0 unx 288 b- defN 81-Jan-01 01:01 assets/public/chunk-X3R6V6IB.js │ -rw-r--r-- 0.0 unx 816 b- defN 81-Jan-01 01:01 assets/public/chunk-X3R6V6IB.js.map │ -rw-r--r-- 0.0 unx 3212 b- defN 81-Jan-01 01:01 assets/public/chunk-X6UXMYRE.js │ -rw-r--r-- 0.0 unx 11375 b- defN 81-Jan-01 01:01 assets/public/chunk-X6UXMYRE.js.map │ -rw-r--r-- 0.0 unx 867 b- defN 81-Jan-01 01:01 assets/public/chunk-XG4UROP3.js │ -rw-r--r-- 0.0 unx 1567 b- defN 81-Jan-01 01:01 assets/public/chunk-XG4UROP3.js.map │ -rw-r--r-- 0.0 unx 770 b- defN 81-Jan-01 01:01 assets/public/chunk-XU2E3I7U.js │ @@ -440,16 +440,16 @@ │ -rw-r--r-- 0.0 unx 1777 b- defN 81-Jan-01 01:01 assets/public/issue-provider-setup-overview.component-R4UMPHXJ.css.map │ -rw-r--r-- 0.0 unx 1899 b- defN 81-Jan-01 01:01 assets/public/issue-provider-tab.component-IAK65AKV.css.map │ -rw-r--r-- 0.0 unx 325 b- defN 81-Jan-01 01:01 assets/public/jira-additional-cfg.component-42ZCNEAB.css.map │ -rw-r--r-- 0.0 unx 2327 b- defN 81-Jan-01 01:01 assets/public/jira-issue-content.component-UYCKI7MC.css.map │ -rw-r--r-- 0.0 unx 393 b- defN 81-Jan-01 01:01 assets/public/jira-link.component-AKJUVRHV.css.map │ -rw-r--r-- 0.0 unx 1353 b- defN 81-Jan-01 01:01 assets/public/lazy-chart.component-644ZU4YB.css.map │ -rw-r--r-- 0.0 unx 8599 b- defN 81-Jan-01 01:01 assets/public/magic-side-nav.component-WC2RHZBN.css.map │ --rw-r--r-- 0.0 unx 830652 b- defN 81-Jan-01 01:01 assets/public/main-VRZ5LKGF.js │ --rw-r--r-- 0.0 unx 2857001 b- defN 81-Jan-01 01:01 assets/public/main-VRZ5LKGF.js.map │ +-rw-r--r-- 0.0 unx 830652 b- defN 81-Jan-01 01:01 assets/public/main-QGPZ4TJP.js │ +-rw-r--r-- 0.0 unx 2857001 b- defN 81-Jan-01 01:01 assets/public/main-QGPZ4TJP.js.map │ -rw-r--r-- 0.0 unx 15607 b- defN 81-Jan-01 01:01 assets/public/main-header.component-7V3W6NDP.css.map │ -rw-r--r-- 0.0 unx 926 b- defN 81-Jan-01 01:01 assets/public/manifest.json │ -rw-r--r-- 0.0 unx 356840 b- defN 81-Jan-01 01:01 assets/public/media/MaterialIcons-Regular-5HNTTCIU.ttf │ -rw-r--r-- 0.0 unx 11076 b- defN 81-Jan-01 01:01 assets/public/media/open-sans-cyrillic-300-normal-NXEWA4HB.woff2 │ -rw-r--r-- 0.0 unx 9056 b- defN 81-Jan-01 01:01 assets/public/media/open-sans-cyrillic-300-normal-UZNP3MNX.woff │ -rw-r--r-- 0.0 unx 10724 b- defN 81-Jan-01 01:01 assets/public/media/open-sans-cyrillic-400-italic-74FQI23K.woff │ -rw-r--r-- 0.0 unx 12596 b- defN 81-Jan-01 01:01 assets/public/media/open-sans-cyrillic-400-italic-SOA5CBZH.woff2 │ @@ -1383,8 +1383,8 @@ │ -rw---- 0.0 fat 308 b- defN 81-Jan-01 01:01 res/zn.xml │ -rw---- 0.0 fat 448 b- defN 81-Jan-01 01:01 res/zp.xml │ -rw---- 0.0 fat 464 b- defN 81-Jan-01 01:01 res/zq.xml │ -rw---- 0.0 fat 503540 b- stor 81-Jan-01 01:01 resources.arsc │ -rw---- 2.0 fat 141776 b- defN 81-Jan-01 01:01 META-INF/F4E24334.SF │ -rw---- 2.0 fat 1342 b- defN 81-Jan-01 01:01 META-INF/F4E24334.RSA │ -rw---- 2.0 fat 141649 b- defN 81-Jan-01 01:01 META-INF/MANIFEST.MF │ -1388 files, 43549846 bytes uncompressed, 14979676 bytes compressed: 65.6% │ +1388 files, 43549846 bytes uncompressed, 14979686 bytes compressed: 65.6% ├── assets/public/ngsw.json │ ├── Pretty-printed │ │┄ Similarity: 0.9314202724358974% │ │┄ Differences: {"'assetGroups'": "{0: {'urls': {insert: [(7, '/chunk-4RLJGC7Y.js'), (28, '/chunk-BMOQZ47J.js'), " │ │┄ "(29, '/chunk-BN6Q5XR6.js'), (54, '/chunk-JFDPASXB.js'), (57, " │ │┄ "'/chunk-L3GF7I2Z.js'), (66, '/chunk-NVQIQL7A.js'), (75, '/chunk-PP3XGOFY.js'), " │ │┄ "(86, '/chunk-RK7AP4LR.js'), (97, '/chunk-VOQG7765.js'), (101, " │ │┄ "'/chunk-WKAXUHLX.js'), (114, '/main-QGPZ4TJP.js')], delete: [114, 91, 74, 60, " │ │┄ '59, 50, 41, 39, 21, 13, 6]}}}' […] │ │ @@ -11,123 +11,123 @@ │ │ "urls": [ │ │ "/chunk-2NYJ54WT.js", │ │ "/chunk-2PLQ4CGJ.js", │ │ "/chunk-3E43H4SH.js", │ │ "/chunk-3H2FJG22.js", │ │ "/chunk-3JNAQVCX.js", │ │ "/chunk-3UB54IM4.js", │ │ - "/chunk-3UN2ZJEW.js", │ │ "/chunk-3YGNIIAP.js", │ │ + "/chunk-4RLJGC7Y.js", │ │ "/chunk-4WKVJOAH.js", │ │ "/chunk-4ZJF7VAV.js", │ │ "/chunk-5FY5BJAX.js", │ │ "/chunk-5GGCGH4Z.js", │ │ "/chunk-5Q2SPJG4.js", │ │ - "/chunk-5QMEDHY4.js", │ │ "/chunk-5YKVP3TE.js", │ │ "/chunk-6IO6G5NZ.js", │ │ "/chunk-6MWZ5TDN.js", │ │ "/chunk-6Q234R2T.js", │ │ "/chunk-6T5VISW6.js", │ │ "/chunk-6XQACCEC.js", │ │ "/chunk-75YLN6G6.js", │ │ - "/chunk-7E7XZV7L.js", │ │ "/chunk-7LFRM354.js", │ │ "/chunk-7TTGPFQ5.js", │ │ "/chunk-A5MBRGPF.js", │ │ "/chunk-A6QD6H33.js", │ │ "/chunk-AS3S2TBN.js", │ │ "/chunk-AZM2QNV4.js", │ │ "/chunk-B6XN2BK4.js", │ │ "/chunk-BMHAY4F7.js", │ │ + "/chunk-BMOQZ47J.js", │ │ + "/chunk-BN6Q5XR6.js", │ │ "/chunk-BOROUNNF.js", │ │ "/chunk-CEBZA2UK.js", │ │ "/chunk-CHZIB6D3.js", │ │ "/chunk-COMUK3PO.js", │ │ "/chunk-CYSQ52VO.js", │ │ "/chunk-DEIXUMEX.js", │ │ "/chunk-EIOJRFED.js", │ │ "/chunk-EKZCH65S.js", │ │ "/chunk-EQ4JYBLN.js", │ │ - "/chunk-ESEBWQAA.js", │ │ "/chunk-FDVZKVGI.js", │ │ - "/chunk-FPT5Z6JU.js", │ │ "/chunk-FQ7WHKEJ.js", │ │ "/chunk-FXWGNVSN.js", │ │ "/chunk-G3HJ2GL3.js", │ │ "/chunk-GFYDE73T.js", │ │ "/chunk-GQ3B3APM.js", │ │ "/chunk-GR6WLWW6.js", │ │ "/chunk-GTBEH26W.js", │ │ "/chunk-GXVY7KCK.js", │ │ - "/chunk-H53RCMH4.js", │ │ "/chunk-HHRVCHRC.js", │ │ "/chunk-HK5C6VCX.js", │ │ "/chunk-IC3NSLMU.js", │ │ "/chunk-IEH6VBVE.js", │ │ "/chunk-ISS7OXYA.js", │ │ "/chunk-J6NQAXQS.js", │ │ + "/chunk-JFDPASXB.js", │ │ "/chunk-JPCQKKKF.js", │ │ "/chunk-K4YYFBL5.js", │ │ - "/chunk-K7NMWD4N.js", │ │ - "/chunk-KCXVAHDW.js", │ │ + "/chunk-L3GF7I2Z.js", │ │ "/chunk-L4MCALUY.js", │ │ "/chunk-LASEIKFS.js", │ │ "/chunk-LOPNAQUA.js", │ │ "/chunk-MAMSXR4J.js", │ │ "/chunk-MASHVMAF.js", │ │ "/chunk-ME6P3K44.js", │ │ "/chunk-MKQ5S2AR.js", │ │ "/chunk-N2NWBZ3C.js", │ │ + "/chunk-NVQIQL7A.js", │ │ "/chunk-NWTLDK7P.js", │ │ "/chunk-OCWFHHQL.js", │ │ "/chunk-OOOTUPN3.js", │ │ "/chunk-OVAWK6DV.js", │ │ "/chunk-OXDOKNTF.js", │ │ - "/chunk-OZT432CE.js", │ │ "/chunk-PEJGMLLQ.js", │ │ "/chunk-PJXD7IVF.js", │ │ "/chunk-PNLDAEIU.js", │ │ + "/chunk-PP3XGOFY.js", │ │ "/chunk-Q56B2KJS.js", │ │ "/chunk-Q5BN5VPC.js", │ │ "/chunk-QC3JWOUK.js", │ │ "/chunk-QX6K6DBU.js", │ │ "/chunk-QXTD3TOT.js", │ │ "/chunk-RAGNH4OF.js", │ │ "/chunk-RC2FJQR5.js", │ │ "/chunk-RG7L3PKS.js", │ │ "/chunk-RHU3AIGY.js", │ │ "/chunk-RIUWQQE2.js", │ │ + "/chunk-RK7AP4LR.js", │ │ "/chunk-RR36S4JZ.js", │ │ "/chunk-RSJU6TEG.js", │ │ "/chunk-TF4ZGOZ4.js", │ │ - "/chunk-TLVKTX5S.js", │ │ "/chunk-TU2ETAFZ.js", │ │ "/chunk-U233VVFY.js", │ │ "/chunk-UNSYVKTP.js", │ │ "/chunk-USV4YXDW.js", │ │ "/chunk-UVYK2G5X.js", │ │ "/chunk-VALZJMB4.js", │ │ "/chunk-VLI2QFPH.js", │ │ + "/chunk-VOQG7765.js", │ │ "/chunk-W2DLB2HC.js", │ │ "/chunk-W3EHXDVY.js", │ │ "/chunk-WG4QBSGF.js", │ │ + "/chunk-WKAXUHLX.js", │ │ "/chunk-X3R6V6IB.js", │ │ "/chunk-X6UXMYRE.js", │ │ "/chunk-XG4UROP3.js", │ │ "/chunk-XU2E3I7U.js", │ │ "/chunk-YOFN2FEJ.js", │ │ "/chunk-YRVYLTSS.js", │ │ "/chunk-ZA2NVDXB.js", │ │ "/chunk-ZBQGB7XI.js", │ │ "/chunk-ZGW3Y4C4.js", │ │ "/chunk-ZLVLY2OX.js", │ │ "/favicon.ico", │ │ "/index.html", │ │ - "/main-VRZ5LKGF.js", │ │ + "/main-QGPZ4TJP.js", │ │ "/manifest.json", │ │ "/polyfills-D4CWKFPZ.js", │ │ "/styles-F5KBAZ2V.css", │ │ "/worker-7ALLQJVW.js" │ │ ] │ │ }, │ │ { │ │ @@ -406,123 +406,123 @@ │ │ "/assets/unicorn.png": "0326afe4a8f85faa5c3a01fd38efeafeb58094a2", │ │ "/chunk-2NYJ54WT.js": "6b2058100c2940dca4d746dd3f5d18ab6c115902", │ │ "/chunk-2PLQ4CGJ.js": "40f83e6dc5da8ad1f8011214555fc11418856029", │ │ "/chunk-3E43H4SH.js": "33caa87bbac6b8a44c021550f0bba30292886b0d", │ │ "/chunk-3H2FJG22.js": "722ba45b7203ecefacefb25c844a19a2d6627377", │ │ "/chunk-3JNAQVCX.js": "ad95b17e8bd954c040d8d51b065c017592f93572", │ │ "/chunk-3UB54IM4.js": "6dd0205087c3166a305b1af5ec8ad771cd5ce0e3", │ │ - "/chunk-3UN2ZJEW.js": "1bb5de0efdf737b513e4931dc5674a78d251aecf", │ │ "/chunk-3YGNIIAP.js": "d9a5fc500fa6f6556bfad2fabeb3c499ffc53ea0", │ │ + "/chunk-4RLJGC7Y.js": "d982464172d60786a32cbe562de604b1557ced64", │ │ "/chunk-4WKVJOAH.js": "755c38ce168a294972eb8d09e0b4d2ee35e45efa", │ │ "/chunk-4ZJF7VAV.js": "9deb19597680a4997613d8eb10ee9cca14627a7b", │ │ "/chunk-5FY5BJAX.js": "1004a56432a90f9520d6e19b9a7e6761bfdd05db", │ │ "/chunk-5GGCGH4Z.js": "2d32477e9900b482695738a4a738e9a619c78c9a", │ │ "/chunk-5Q2SPJG4.js": "99ae678a67a95858256d3fe17fe66174dc230fac", │ │ - "/chunk-5QMEDHY4.js": "dbe267ce3eef08eb9cfc19e986112c49ee3e18c6", │ │ "/chunk-5YKVP3TE.js": "77fa05e8a910fc1caa2a307c19b1f27a16c09f98", │ │ "/chunk-6IO6G5NZ.js": "9937f9018fdd1cb5c43cc96bbbf3ebcab8b289ac", │ │ "/chunk-6MWZ5TDN.js": "61e488fdb803d592d102d5ea21de39ea8af39d5c", │ │ "/chunk-6Q234R2T.js": "2ef78e3683b4bc9d88b5e931bfe756d6179f5585", │ │ "/chunk-6T5VISW6.js": "d0811e95d01af7acc2fb06a3a318d95efb0c9988", │ │ "/chunk-6XQACCEC.js": "65d79cd75b3c01f2d984e161cb9cb415b59fba85", │ │ "/chunk-75YLN6G6.js": "773548ff4b87610a89553e63b1d3e8418608a9ce", │ │ - "/chunk-7E7XZV7L.js": "b0d6db061f116cb9e3f11d6d316027701a38b24a", │ │ "/chunk-7LFRM354.js": "6542fd5e3b7fd56fe0a3e4c16fd6b883a490f9d0", │ │ "/chunk-7TTGPFQ5.js": "f8a5345e385898a38c5969588a187f030a3f7107", │ │ "/chunk-A5MBRGPF.js": "1370eaa81f6ec887d8231e675fe4147619b78acd", │ │ "/chunk-A6QD6H33.js": "ec517b8d910ffcac343b58e04d3dbc538e2fd731", │ │ "/chunk-AS3S2TBN.js": "82e372ffe83fa0284bf4f5bf13504c55babd103f", │ │ "/chunk-AZM2QNV4.js": "2d45e87fa94d2bc710cb70055f13d9d668df8d58", │ │ "/chunk-B6XN2BK4.js": "d60920d3549ad846102a0ea7456b4aae78182a0e", │ │ "/chunk-BMHAY4F7.js": "99235dfa19242d56d6e0c7b648ad2382793f3c2d", │ │ + "/chunk-BMOQZ47J.js": "a049c3db81efbdadd653543e6ea4021b26a8a980", │ │ + "/chunk-BN6Q5XR6.js": "f88310eb45841e7b12bffbf0ddd4e78062c24525", │ │ "/chunk-BOROUNNF.js": "459f904bd4a5c44bc789798d548ad8a666e2f15c", │ │ "/chunk-CEBZA2UK.js": "3683f356f8b314946c40627cb26d7d09aa5b016e", │ │ "/chunk-CHZIB6D3.js": "678081ccd6b513565c750d25a3f6f6263fdcc738", │ │ "/chunk-COMUK3PO.js": "c9be9cf9606db24d1ac8503ef145cedefedfd7db", │ │ "/chunk-CYSQ52VO.js": "ba942803986518679495625d6cdb5bc053fd6ba8", │ │ "/chunk-DEIXUMEX.js": "3ff807b5f52e1e06d89a3c9622af3bc375fd8ddd", │ │ "/chunk-EIOJRFED.js": "b8c32a2f6c84ec99a7fc6dca2af8ddd49f591f85", │ │ "/chunk-EKZCH65S.js": "a2fe3fb0284d8839edaea37297344195e7f25222", │ │ "/chunk-EQ4JYBLN.js": "ac795f1fda6ef0b5209070d686e09ff1226e5616", │ │ - "/chunk-ESEBWQAA.js": "61a58398e0ad5fc19f1893090ff1905caeaa98a8", │ │ "/chunk-FDVZKVGI.js": "cd526823dfbc82ff96849c6294214712128d984d", │ │ - "/chunk-FPT5Z6JU.js": "c41a0b3d4d1603665f5cca7518be7f4d45c6b68f", │ │ "/chunk-FQ7WHKEJ.js": "ff6b833e6336728dcda6a0cde6d86e2d8147ead2", │ │ "/chunk-FXWGNVSN.js": "dce71b1f1924a80fa66466d9a7dc7e815920426a", │ │ "/chunk-G3HJ2GL3.js": "3d73e1d29e09206004362596665eebb63f73b850", │ │ "/chunk-GFYDE73T.js": "10a9a6acfbec4cf4b8604283a0a8723b8569fce7", │ │ "/chunk-GQ3B3APM.js": "fa04bb8b8aa9326e5ee9c2dddce054ea917b03d5", │ │ "/chunk-GR6WLWW6.js": "a4973dc7d7489faa82647b0cc6cc7c8011cea876", │ │ "/chunk-GTBEH26W.js": "afe9fee1529226a888c1cdbf8138b3c52a2cce55", │ │ "/chunk-GXVY7KCK.js": "b345dc4db95b32224659168d76596ad83282eb62", │ │ - "/chunk-H53RCMH4.js": "1e2b546439524e89588861b933d619bb9fe65fb2", │ │ "/chunk-HHRVCHRC.js": "cd1666c6fe58a489a0a7eacdba0a65fcee8cb6b4", │ │ "/chunk-HK5C6VCX.js": "d5c9474acb002c5d81b3e036d0f78da55a20d285", │ │ "/chunk-IC3NSLMU.js": "806539121a3cb4f280504e453058496975fe45e3", │ │ "/chunk-IEH6VBVE.js": "c981410704ce34002bf08157045129f2fe7bc237", │ │ "/chunk-ISS7OXYA.js": "12445d1bd8ffed3dcbf70c9b6dc3bf550913a3a0", │ │ "/chunk-J6NQAXQS.js": "b190c72c2b909ec502956c6f8cda6d66947a1993", │ │ + "/chunk-JFDPASXB.js": "d634132066f752d5960228d6b7c65d817698f5b3", │ │ "/chunk-JPCQKKKF.js": "6836bf08466cdab38799dda083dc4cb07002831c", │ │ "/chunk-K4YYFBL5.js": "095e8aae82048a8f7c28f0fbc9abce482078517d", │ │ - "/chunk-K7NMWD4N.js": "5dfe1a592a88c1ed16c4839a17a1a9e13461f687", │ │ - "/chunk-KCXVAHDW.js": "60ee9b23641da5a7576b09387fc223d5eac91986", │ │ + "/chunk-L3GF7I2Z.js": "7292f09151c3e840b84c4e5550a8e7a560d3db7a", │ │ "/chunk-L4MCALUY.js": "5f4ee206f28949d6e7b5b358a851f78ea8aaed60", │ │ "/chunk-LASEIKFS.js": "30ceb63557cc528469a083b48c338b3827b209d7", │ │ "/chunk-LOPNAQUA.js": "52dcf3c69c8f675d1b418897cbc767295739368c", │ │ "/chunk-MAMSXR4J.js": "2edca602220b8e80e81d1293ec972a4a8c97dc85", │ │ "/chunk-MASHVMAF.js": "c3e060e28a228fc25d8d7a1a90983cfc33f80afa", │ │ "/chunk-ME6P3K44.js": "e32180b1998e77c4cb7d55fa0074cb2efe205280", │ │ "/chunk-MKQ5S2AR.js": "9368b54b4f102d5c8000a30747eda3da95a162a5", │ │ "/chunk-N2NWBZ3C.js": "29704d54974fe9fd93d9bb9964b224d24c52423d", │ │ + "/chunk-NVQIQL7A.js": "38801e7fed767a5f69e17168c785d0456a4e6bd7", │ │ "/chunk-NWTLDK7P.js": "0f3bfb931060186b20a1003451de21b4744a9b37", │ │ "/chunk-OCWFHHQL.js": "de8fb99383010505a33f4c813db547c4b43cf01e", │ │ "/chunk-OOOTUPN3.js": "bad2b797511a5f4351c7adaa25104b3655f2de1c", │ │ "/chunk-OVAWK6DV.js": "4361aa6648b214c9f6cc6a5bc622280f547db7f0", │ │ "/chunk-OXDOKNTF.js": "501996a33f7f3e92729fcabc7c0b3cad82f22134", │ │ - "/chunk-OZT432CE.js": "8c5398247813d506033e2d4a6bab877523f8166c", │ │ "/chunk-PEJGMLLQ.js": "fe6775dde0b3e793079d9c7be74b708dd45a79ea", │ │ "/chunk-PJXD7IVF.js": "133f633ffbff0154e32823f4872fadd57bd4ca0f", │ │ "/chunk-PNLDAEIU.js": "7018ab57da1e4b2988363302f3b082de477e607a", │ │ + "/chunk-PP3XGOFY.js": "8c8592033f2c679440c2dda69f39f8210f99db27", │ │ "/chunk-Q56B2KJS.js": "3d34a03917ce508254b6b817c994f458a65d5d30", │ │ "/chunk-Q5BN5VPC.js": "a739a3c4f45882f2997e2221583f7e11e57549c4", │ │ "/chunk-QC3JWOUK.js": "1f20d3489bc844787a782bad8d48dd1a5487455b", │ │ "/chunk-QX6K6DBU.js": "9b505d4545b3bfc6f057c6506c939bd36d20c70d", │ │ "/chunk-QXTD3TOT.js": "d003c5b915aa863b5584051263295a163bcb8e5a", │ │ "/chunk-RAGNH4OF.js": "75ff18fbdd84fcc5abb73f6492cb9b1b652583c0", │ │ "/chunk-RC2FJQR5.js": "4139f9348f44dcb61dcf1d8199ab6471888cd69f", │ │ "/chunk-RG7L3PKS.js": "f6aaa3e6ebb4010d72a7ad094d91220c639d290a", │ │ "/chunk-RHU3AIGY.js": "70f3005532610e087402505fa642745a0759fb44", │ │ "/chunk-RIUWQQE2.js": "b74cfe3c5c2eba130ef53513460f349d63be3810", │ │ + "/chunk-RK7AP4LR.js": "dd51915ce5a97355ed694d9da0ab21aee12b8e49", │ │ "/chunk-RR36S4JZ.js": "75c20e2b0ecdaacd05b98cee5d5ee2353104f5a8", │ │ "/chunk-RSJU6TEG.js": "08a5b56ef0f818c3bec4a75ebaade2096e405eb5", │ │ "/chunk-TF4ZGOZ4.js": "3b2d5e0263022f68badc757d01738d52419d106a", │ │ - "/chunk-TLVKTX5S.js": "5862c945ca60fdb20ecd6cd75679cbb5f0975475", │ │ "/chunk-TU2ETAFZ.js": "7a46423b22d4f29ae4b8f0b64116a9ae804017f2", │ │ "/chunk-U233VVFY.js": "51f1f8a1d3f2ed2951838a10456ad42172522001", │ │ "/chunk-UNSYVKTP.js": "3f65871483b52a1fa64e04cc830e24b7d3d98540", │ │ "/chunk-USV4YXDW.js": "b8c0eeae4a1434c1504717cdacb19031eabcde10", │ │ "/chunk-UVYK2G5X.js": "39b4b4e3b681ea5acec3f126efaed6a4b265a206", │ │ "/chunk-VALZJMB4.js": "3178219d2e9a366851c6f9c278783f9c5628bdc6", │ │ "/chunk-VLI2QFPH.js": "ab8057d8d2c2c3cd60653cae0f3e27ba6d46e4d9", │ │ + "/chunk-VOQG7765.js": "8e224780239d8c897eb99e9c114d5442a443310a", │ │ "/chunk-W2DLB2HC.js": "5d009b6e75cdb6147b0953e5679e026154c52f88", │ │ "/chunk-W3EHXDVY.js": "23e1348651bae932954b8eb0918f95913e86d7bd", │ │ "/chunk-WG4QBSGF.js": "14db0f50e036cf1190acb115c89601529037efb2", │ │ + "/chunk-WKAXUHLX.js": "d5503b698bb093b4f389fe940597f87ee9280de1", │ │ "/chunk-X3R6V6IB.js": "d851887b625df3e17fa35bbd2eeb019846a22d0c", │ │ "/chunk-X6UXMYRE.js": "f7bec55de02a6ec9dcc6a6460158f5e213d8faf1", │ │ "/chunk-XG4UROP3.js": "ea1d41aa888db064c2ea1a7f4222d42505f4135a", │ │ "/chunk-XU2E3I7U.js": "42be333379abd934534b707aa2e0824a038af868", │ │ "/chunk-YOFN2FEJ.js": "c1768af5c4be0319c51bc4ed47bad7b61a27e956", │ │ "/chunk-YRVYLTSS.js": "954754a003e486a6db52e9a04f72d4d86b439b54", │ │ "/chunk-ZA2NVDXB.js": "4374d5e2ac32f5a2d0475b42bb01c0c50e91f9ea", │ │ "/chunk-ZBQGB7XI.js": "39f308d717692ee69fec4c25f4b67a9442a1284f", │ │ "/chunk-ZGW3Y4C4.js": "b566298d3c0757956a3a926f244807bcef16c14f", │ │ "/chunk-ZLVLY2OX.js": "11386baa0b7a269d6ff352c5074b0ed0d30770c1", │ │ "/favicon.ico": "041b337586bb0e48da6f4fdfc846ef3594373009", │ │ - "/index.html": "e6b477b34f84dc31af4b063d405db22fd8118fc1", │ │ - "/main-VRZ5LKGF.js": "469353158694870c81aa9d6a2d273224f4dc857c", │ │ + "/index.html": "add0b2ae8322de6b1e5340c40e89b4abb013edaf", │ │ + "/main-QGPZ4TJP.js": "a1b4caeec5e051281759f9a26835c2e6c160323e", │ │ "/manifest.json": "94d39d23fcd194a0c89eb3bcd838730cec7cabee", │ │ "/polyfills-D4CWKFPZ.js": "be63e19dcbf7539a31849701283857d1ebe28b56", │ │ "/styles-F5KBAZ2V.css": "ee7445d5a2d4a2c849c40c84c404acb3c15336f2", │ │ "/worker-7ALLQJVW.js": "1554e5dbbc3edf6cccfb2a99ee8359cfeaa97a66" │ │ }, │ │ "index": "/index.html", │ │ "navigationRequestStrategy": "performance", │ │ @@ -540,9 +540,9 @@ │ │ "regex": "^\\/(?:.+\\/)?[^/]*__[^/]*$" │ │ }, │ │ { │ │ "positive": false, │ │ "regex": "^\\/(?:.+\\/)?[^/]*__[^/]*\\/.*$" │ │ } │ │ ], │ │ - "timestamp": 1761445058004 │ │ + "timestamp": 1761608702937 │ │ } ├── assets/public/index.html │ @@ -7024,16 +7024,16 @@ │ 0001b6f0: 6970 735b 7261 6e64 6f6d 496e 6465 785d ips[randomIndex] │ 0001b700: 5b31 5d3b 0a20 2020 203c 2f73 6372 6970 [1];. .
  • │ +0001b8d0: 6e6b 2d34 524c 4a47 4337 592e 6a73 223e nk-4RLJGC7Y.js"> │ 0001b8e0: 3c6c 696e 6b20 7265 6c3d 226d 6f64 756c .. │ --- assets/public/main-VRZ5LKGF.js.map ├── +++ assets/public/main-QGPZ4TJP.js.map │┄ Files identical despite different names │ --- assets/public/main-VRZ5LKGF.js ├── +++ assets/public/main-QGPZ4TJP.js │┄ Files 99% similar despite different names │ ├── js-beautify {} │ │ @@ -29,15 +29,15 @@ │ │ t as OA, │ │ u as wc, │ │ v as py, │ │ w as my, │ │ x as DA, │ │ y as Qp, │ │ z as uy │ │ -} from "./chunk-3UN2ZJEW.js"; │ │ +} from "./chunk-BMOQZ47J.js"; │ │ import { │ │ a as $n, │ │ b as ls │ │ } from "./chunk-GR6WLWW6.js"; │ │ import { │ │ a as bT, │ │ d as yT, │ │ @@ -92,38 +92,38 @@ │ │ import { │ │ b as _y, │ │ c as FA │ │ } from "./chunk-5FY5BJAX.js"; │ │ import { │ │ a as gy, │ │ b as NA │ │ -} from "./chunk-OZT432CE.js"; │ │ +} from "./chunk-BN6Q5XR6.js"; │ │ import { │ │ a as s0, │ │ b as LO, │ │ c as eb, │ │ d as ZD, │ │ e as nb, │ │ f as iA, │ │ g as Xp, │ │ h as Xb │ │ -} from "./chunk-TLVKTX5S.js"; │ │ +} from "./chunk-4RLJGC7Y.js"; │ │ import { │ │ a as LT, │ │ b as BT, │ │ c as gD │ │ } from "./chunk-VLI2QFPH.js"; │ │ import { │ │ a as np, │ │ b as vT │ │ } from "./chunk-3UB54IM4.js"; │ │ import { │ │ f as ba, │ │ g as Vp │ │ -} from "./chunk-H53RCMH4.js"; │ │ +} from "./chunk-WKAXUHLX.js"; │ │ import { │ │ a as ib, │ │ b as tA, │ │ c as Qb, │ │ d as Zb, │ │ e as ey │ │ } from "./chunk-IEH6VBVE.js"; │ │ @@ -361,15 +361,15 @@ │ │ h as Po │ │ } from "./chunk-W3EHXDVY.js"; │ │ import { │ │ a as to, │ │ b as aA, │ │ k as br, │ │ l as Mc │ │ -} from "./chunk-FPT5Z6JU.js"; │ │ +} from "./chunk-JFDPASXB.js"; │ │ import { │ │ A as US, │ │ B as WS, │ │ C as $h, │ │ D as YS, │ │ E as GD, │ │ F as Vh, │ │ @@ -398,15 +398,15 @@ │ │ l as NS, │ │ m as WD, │ │ n as cs, │ │ o as zD, │ │ x as qe, │ │ y as Bh, │ │ z as Bp │ │ -} from "./chunk-ESEBWQAA.js"; │ │ +} from "./chunk-VOQG7765.js"; │ │ import { │ │ a as pr, │ │ b as hc, │ │ c as Rh, │ │ d as Tc, │ │ e as Sc, │ │ f as Fh, │ │ @@ -13232,15 +13232,15 @@ │ │ var Tw, Sw = O(() => { │ │ "use strict"; │ │ gw(); │ │ ho(); │ │ vw(); │ │ Tw = [{ │ │ path: "config", │ │ - loadComponent: () => import("./chunk-7E7XZV7L.js").then(i => i.ConfigPageComponent), │ │ + loadComponent: () => import("./chunk-L3GF7I2Z.js").then(i => i.ConfigPageComponent), │ │ data: { │ │ page: "config" │ │ }, │ │ canActivate: [ei] │ │ }, { │ │ path: "search", │ │ loadComponent: () => import("./chunk-Q5BN5VPC.js").then(i => i.SearchPageComponent), │ │ @@ -13302,22 +13302,22 @@ │ │ loadComponent: () => import("./chunk-3H2FJG22.js").then(i => i.QuickHistoryComponent), │ │ data: { │ │ page: "quick-history" │ │ }, │ │ canActivate: [Ea, ei] │ │ }, { │ │ path: "tag/:id/daily-summary", │ │ - loadComponent: () => import("./chunk-KCXVAHDW.js").then(i => i.DailySummaryComponent), │ │ + loadComponent: () => import("./chunk-RK7AP4LR.js").then(i => i.DailySummaryComponent), │ │ data: { │ │ page: "daily-summary" │ │ }, │ │ canActivate: [Ea, ei] │ │ }, { │ │ path: "tag/:id/daily-summary/:dayStr", │ │ - loadComponent: () => import("./chunk-KCXVAHDW.js").then(i => i.DailySummaryComponent), │ │ + loadComponent: () => import("./chunk-RK7AP4LR.js").then(i => i.DailySummaryComponent), │ │ data: { │ │ page: "daily-summary" │ │ }, │ │ canActivate: [Ea, ei] │ │ }, { │ │ path: "tag/:id/metrics", │ │ loadComponent: () => import("./chunk-UVYK2G5X.js").then(i => i.MetricPageComponent), │ │ @@ -13358,41 +13358,41 @@ │ │ loadComponent: () => import("./chunk-UVYK2G5X.js").then(i => i.MetricPageComponent), │ │ data: { │ │ page: "metrics" │ │ }, │ │ canActivate: [Pa, ei] │ │ }, { │ │ path: "project/:id/daily-summary", │ │ - loadComponent: () => import("./chunk-KCXVAHDW.js").then(i => i.DailySummaryComponent), │ │ + loadComponent: () => import("./chunk-RK7AP4LR.js").then(i => i.DailySummaryComponent), │ │ data: { │ │ page: "daily-summary" │ │ }, │ │ canActivate: [Pa, ei] │ │ }, { │ │ path: "project/:id/daily-summary/:dayStr", │ │ - loadComponent: () => import("./chunk-KCXVAHDW.js").then(i => i.DailySummaryComponent), │ │ + loadComponent: () => import("./chunk-RK7AP4LR.js").then(i => i.DailySummaryComponent), │ │ data: { │ │ page: "daily-summary" │ │ }, │ │ canActivate: [Pa, ei] │ │ }, { │ │ path: "active/:subPageType", │ │ canActivate: [Um, ei], │ │ - loadComponent: () => import("./chunk-7E7XZV7L.js").then(i => i.ConfigPageComponent) │ │ + loadComponent: () => import("./chunk-L3GF7I2Z.js").then(i => i.ConfigPageComponent) │ │ }, { │ │ path: "active/:subPageType/:param", │ │ canActivate: [Um, ei], │ │ - loadComponent: () => import("./chunk-7E7XZV7L.js").then(i => i.ConfigPageComponent) │ │ + loadComponent: () => import("./chunk-L3GF7I2Z.js").then(i => i.ConfigPageComponent) │ │ }, { │ │ path: "active", │ │ canActivate: [Um, ei], │ │ - loadComponent: () => import("./chunk-7E7XZV7L.js").then(i => i.ConfigPageComponent) │ │ + loadComponent: () => import("./chunk-L3GF7I2Z.js").then(i => i.ConfigPageComponent) │ │ }, { │ │ path: "plugins/:pluginId/index", │ │ - loadComponent: () => import("./chunk-5QMEDHY4.js").then(i => i.PluginIndexComponent), │ │ + loadComponent: () => import("./chunk-NVQIQL7A.js").then(i => i.PluginIndexComponent), │ │ data: { │ │ page: "plugin-index" │ │ }, │ │ canActivate: [ei] │ │ }, { │ │ path: "**", │ │ redirectTo: `tag/${nt.id}/tasks` │ │ @@ -30571,8 +30571,8 @@ │ │ ie.log("Time window for completing sync started"), yield d0(2e4), ie.log("Time window for completing sync ended. Closing app!"), Sg.finish({ │ │ taskId: e │ │ }) │ │ })) │ │ }))) │ │ }); │ │ export default EU(); │ │ -//# sourceMappingURL=main-VRZ5LKGF.js.map │ │ +//# sourceMappingURL=main-QGPZ4TJP.js.map │ --- assets/public/chunk-TLVKTX5S.js.map ├── +++ assets/public/chunk-4RLJGC7Y.js.map │┄ Files identical despite different names │ --- assets/public/chunk-TLVKTX5S.js ├── +++ assets/public/chunk-4RLJGC7Y.js │┄ Files 94% similar despite different names │ ├── js-beautify {} │ │ @@ -1,15 +1,15 @@ │ │ import { │ │ f as V, │ │ g as X │ │ -} from "./chunk-H53RCMH4.js"; │ │ +} from "./chunk-WKAXUHLX.js"; │ │ import { │ │ a as L, │ │ b as $ │ │ -} from "./chunk-ESEBWQAA.js"; │ │ +} from "./chunk-VOQG7765.js"; │ │ import { │ │ a as E, │ │ b as q, │ │ r as H, │ │ w as A, │ │ x as O │ │ } from "./chunk-TU2ETAFZ.js"; │ │ @@ -160,8 +160,8 @@ │ │ let t = new SpeechSynthesisUtterance; │ │ t.text = e, t.voice = l.getVoices().find(i => n.includes(i.name)) || l.getVoices().find(i => i.default) || null, console.log(o), t.volume = o / 100, l.speak(t) │ │ } │ │ }); │ │ export { │ │ oe as a, J as b, re as c, K as d, Ie as e, ee as f, ve as g, Z as h │ │ }; │ │ -//# sourceMappingURL=chunk-TLVKTX5S.js.map │ │ +//# sourceMappingURL=chunk-4RLJGC7Y.js.map │ --- assets/public/chunk-OZT432CE.js.map ├── +++ assets/public/chunk-BN6Q5XR6.js.map │┄ Files identical despite different names │ --- assets/public/chunk-OZT432CE.js ├── +++ assets/public/chunk-BN6Q5XR6.js │┄ Files 99% similar despite different names │ ├── js-beautify {} │ │ @@ -1,11 +1,11 @@ │ │ import { │ │ f as ie, │ │ g as we │ │ -} from "./chunk-H53RCMH4.js"; │ │ +} from "./chunk-WKAXUHLX.js"; │ │ import { │ │ a as re, │ │ b as oe, │ │ c as ae, │ │ f as le, │ │ g as Oe │ │ } from "./chunk-FDVZKVGI.js"; │ │ @@ -14,15 +14,15 @@ │ │ l as ve, │ │ m as Z, │ │ n as ee, │ │ o as te, │ │ p as Ie, │ │ q as ne, │ │ r as Me │ │ -} from "./chunk-FPT5Z6JU.js"; │ │ +} from "./chunk-JFDPASXB.js"; │ │ import { │ │ a as Y, │ │ c as xe │ │ } from "./chunk-6XQACCEC.js"; │ │ import { │ │ c as W, │ │ d as N, │ │ @@ -321,8 +321,8 @@ │ │ } │ │ return t │ │ })() │ │ }); │ │ export { │ │ rt as a, De as b │ │ }; │ │ -//# sourceMappingURL=chunk-OZT432CE.js.map │ │ +//# sourceMappingURL=chunk-BN6Q5XR6.js.map │ --- assets/public/chunk-KCXVAHDW.js.map ├── +++ assets/public/chunk-RK7AP4LR.js.map │┄ Files identical despite different names │ --- assets/public/chunk-KCXVAHDW.js ├── +++ assets/public/chunk-RK7AP4LR.js │┄ Files 99% similar despite different names │ ├── js-beautify {} │ │ @@ -40,15 +40,15 @@ │ │ p as xo, │ │ q as nn, │ │ r as ko, │ │ u as Cn, │ │ v as Fo, │ │ y as yn, │ │ z as $o │ │ -} from "./chunk-3UN2ZJEW.js"; │ │ +} from "./chunk-BMOQZ47J.js"; │ │ import { │ │ a as $i, │ │ b as uo │ │ } from "./chunk-GR6WLWW6.js"; │ │ import { │ │ b as di, │ │ c as _i, │ │ @@ -106,15 +106,15 @@ │ │ import { │ │ U as Yi, │ │ V as To, │ │ r as Vi, │ │ s as ho, │ │ t as Wi, │ │ u as So │ │ -} from "./chunk-ESEBWQAA.js"; │ │ +} from "./chunk-VOQG7765.js"; │ │ import "./chunk-USV4YXDW.js"; │ │ import "./chunk-G3HJ2GL3.js"; │ │ import "./chunk-GTBEH26W.js"; │ │ import { │ │ e as Pi, │ │ f as co │ │ } from "./chunk-TF4ZGOZ4.js"; │ │ @@ -2259,8 +2259,8 @@ │ │ return e │ │ })() │ │ }); │ │ nr(); │ │ export { │ │ Xl as DailySummaryComponent │ │ }; │ │ -//# sourceMappingURL=chunk-KCXVAHDW.js.map │ │ +//# sourceMappingURL=chunk-RK7AP4LR.js.map │ --- assets/public/chunk-K7NMWD4N.js ├── +++ assets/public/chunk-NVQIQL7A.js │┄ Files 94% similar despite different names │ ├── js-beautify {} │ │ @@ -1,12 +1,15 @@ │ │ import { │ │ - s as a, │ │ - t as b │ │ -} from "./chunk-FPT5Z6JU.js"; │ │ -import "./chunk-ESEBWQAA.js"; │ │ + a, │ │ + b │ │ +} from "./chunk-BN6Q5XR6.js"; │ │ +import "./chunk-WKAXUHLX.js"; │ │ +import "./chunk-FDVZKVGI.js"; │ │ +import "./chunk-JFDPASXB.js"; │ │ +import "./chunk-VOQG7765.js"; │ │ import "./chunk-PNLDAEIU.js"; │ │ import "./chunk-USV4YXDW.js"; │ │ import "./chunk-G3HJ2GL3.js"; │ │ import "./chunk-GTBEH26W.js"; │ │ import "./chunk-TF4ZGOZ4.js"; │ │ import "./chunk-OCWFHHQL.js"; │ │ import "./chunk-WG4QBSGF.js"; │ │ @@ -37,10 +40,10 @@ │ │ import "./chunk-3YGNIIAP.js"; │ │ import "./chunk-MKQ5S2AR.js"; │ │ import "./chunk-OXDOKNTF.js"; │ │ import "./chunk-PEJGMLLQ.js"; │ │ import "./chunk-2NYJ54WT.js"; │ │ b(); │ │ export { │ │ - a as PluginRunner │ │ + a as PluginIndexComponent │ │ }; │ │ -//# sourceMappingURL=chunk-K7NMWD4N.js.map │ │ +//# sourceMappingURL=chunk-NVQIQL7A.js.map │ --- assets/public/chunk-H53RCMH4.js.map ├── +++ assets/public/chunk-WKAXUHLX.js.map │┄ Files identical despite different names │ --- assets/public/chunk-H53RCMH4.js ├── +++ assets/public/chunk-WKAXUHLX.js │┄ Files 99% similar despite different names │ ├── js-beautify {} │ │ @@ -5,21 +5,21 @@ │ │ f as Qe, │ │ i as Ne, │ │ j as et, │ │ q as Ae, │ │ r as tt, │ │ s as $e, │ │ t as it │ │ -} from "./chunk-FPT5Z6JU.js"; │ │ +} from "./chunk-JFDPASXB.js"; │ │ import { │ │ K as Ce, │ │ L as Je, │ │ j as Ie, │ │ k as Xe │ │ -} from "./chunk-ESEBWQAA.js"; │ │ +} from "./chunk-VOQG7765.js"; │ │ import { │ │ e as fe, │ │ f as me, │ │ g as Pe, │ │ i as _e, │ │ j as Se, │ │ k as Ee, │ │ @@ -1118,8 +1118,8 @@ │ │ } │ │ return d │ │ })() │ │ }); │ │ export { │ │ Te as a, Le as b, Z as c, Y as d, Oe as e, oi as f, nt as g │ │ }; │ │ -//# sourceMappingURL=chunk-H53RCMH4.js.map │ │ +//# sourceMappingURL=chunk-WKAXUHLX.js.map │ --- assets/public/chunk-FPT5Z6JU.js.map ├── +++ assets/public/chunk-JFDPASXB.js.map │┄ Files identical despite different names │ --- assets/public/chunk-FPT5Z6JU.js ├── +++ assets/public/chunk-JFDPASXB.js │┄ Files 99% similar despite different names │ ├── js-beautify {} │ │ @@ -1,11 +1,11 @@ │ │ import { │ │ U as Ar, │ │ V as ct │ │ -} from "./chunk-ESEBWQAA.js"; │ │ +} from "./chunk-VOQG7765.js"; │ │ import { │ │ c as gr, │ │ d as fr, │ │ g as mr, │ │ h as hr, │ │ i as Tr, │ │ j as ut, │ │ @@ -2845,15 +2845,15 @@ │ │ } │ │ }) │ │ } │ │ sendMessageToPlugin(t, o) { │ │ return S(this, null, function*() { │ │ let { │ │ PluginRunner: l │ │ - } = yield import("./chunk-K7NMWD4N.js"); │ │ + } = yield import("./chunk-PP3XGOFY.js"); │ │ return this._injector.get(l).sendMessageToPlugin(t, o) │ │ }) │ │ } │ │ _initWindowFocusTracking() { │ │ window.addEventListener("focus", () => { │ │ this._isWindowFocused = !0, this._notifyFocusHandlers(!0) │ │ }), window.addEventListener("blur", () => { │ │ @@ -3500,8 +3500,8 @@ │ │ } │ │ return y │ │ })() │ │ }); │ │ export { │ │ de as a, oe as b, Pr as c, wr as d, Z as e, ue as f, Cr as g, br as h, ee as i, _e as j, Or as k, Ur as l, Ja as m, Va as n, Ya as o, xr as p, Nr as q, jr as r, ls as s, kt as t │ │ }; │ │ -//# sourceMappingURL=chunk-FPT5Z6JU.js.map │ │ +//# sourceMappingURL=chunk-JFDPASXB.js.map │ --- assets/public/chunk-ESEBWQAA.js.map ├── +++ assets/public/chunk-VOQG7765.js.map │┄ Files 99% similar despite different names │ ├── Pretty-printed │ │┄ Similarity: 0.9982638888888888% │ │┄ Differences: {"'sourcesContent'": "{insert: [(63, '// This file is auto-generated by tools/load-env.js\\n// Do " │ │┄ 'not modify directly - edit .env file instead\\n// Generated at: ' │ │┄ '2025-10-27T23:42:45.520Z\\n\\n/**\\n * Environment variables loaded from ' │ │┄ '.env file\\n * Access these constants instead of process.env in your Angular ' │ │┄ 'app\\n */\\nexport const ENV = {\\n\\n} as const;\\n\\n// Type-safe helper ' │ │┄ 'to en […] │ │ @@ -4701,15 +4701,15 @@ │ │ "import * as i0 from '@angular/core';\nimport { ChangeDetectionStrategy, Component, NgModule } from '@angular/core';\nimport { FieldType, FormlyMatFormFieldModule } from '@ngx-formly/material/form-field';\nimport * as i1 from '@angular/forms';\nimport { ReactiveFormsModule } from '@angular/forms';\nimport * as i2 from '@angular/material/slider';\nimport { MatSliderModule } from '@angular/material/slider';\nimport * as i3 from '@ngx-formly/core';\nimport { FormlyModule } from '@ngx-formly/core';\nimport { CommonModule } from '@angular/common';\nimport { MatCommonModule, MatRippleModule } from '@angular/material/core';\nlet FormlyFieldSlider = /*#__PURE__*/(() => {\n class FormlyFieldSlider extends FieldType {\n constructor() {\n super(...arguments);\n this.defaultOptions = {\n props: {\n hideFieldUnderline: true,\n floatLabel: 'always',\n displayWith: value => `${value}`\n }\n };\n }\n static {\n this.\u0275fac = /* @__PURE__ */(() => {\n let \u0275FormlyFieldSlider_BaseFactory;\n return function FormlyFieldSlider_Factory(__ngFactoryType__) {\n return (\u0275FormlyFieldSlider_BaseFactory || (\u0275FormlyFieldSlider_BaseFactory = i0.\u0275\u0275getInheritedFactory(FormlyFieldSlider)))(__ngFactoryType__ || FormlyFieldSlider);\n };\n })();\n }\n static {\n this.\u0275cmp = /* @__PURE__ */i0.\u0275\u0275defineComponent({\n type: FormlyFieldSlider,\n selectors: [[\"formly-field-mat-slider\"]],\n standalone: false,\n features: [i0.\u0275\u0275InheritDefinitionFeature],\n decls: 2,\n vars: 15,\n consts: [[3, \"input\", \"change\", \"id\", \"formlyAttributes\", \"tabIndex\", \"color\", \"displayWith\", \"max\", \"min\", \"step\", \"discrete\", \"showTickMarks\"], [\"matSliderThumb\", \"\", 3, \"formControl\", \"formlyAttributes\"]],\n template: function FormlyFieldSlider_Template(rf, ctx) {\n if (rf & 1) {\n i0.\u0275\u0275elementStart(0, \"mat-slider\", 0);\n i0.\u0275\u0275listener(\"input\", function FormlyFieldSlider_Template_mat_slider_input_0_listener($event) {\n return ctx.props.input && ctx.props.input(ctx.field, $event);\n })(\"change\", function FormlyFieldSlider_Template_mat_slider_change_0_listener($event) {\n return ctx.props.change && ctx.props.change(ctx.field, $event);\n });\n i0.\u0275\u0275element(1, \"input\", 1);\n i0.\u0275\u0275elementEnd();\n }\n if (rf & 2) {\n i0.\u0275\u0275styleProp(\"width\", \"100%\");\n i0.\u0275\u0275property(\"id\", ctx.id)(\"formlyAttributes\", ctx.field)(\"tabIndex\", ctx.props.tabindex)(\"color\", ctx.props.color)(\"displayWith\", ctx.props.displayWith)(\"max\", ctx.props.max)(\"min\", ctx.props.min)(\"step\", ctx.props.step)(\"discrete\", ctx.props.discrete)(\"showTickMarks\", ctx.props.showTickMarks)(\"step\", ctx.props.step);\n i0.\u0275\u0275advance();\n i0.\u0275\u0275property(\"formControl\", ctx.formControl)(\"formlyAttributes\", ctx.field);\n }\n },\n dependencies: [i1.DefaultValueAccessor, i1.NgControlStatus, i1.FormControlDirective, i2.MatSlider, i2.MatSliderThumb, i3.LegacyFormlyAttributes],\n encapsulation: 2,\n changeDetection: 0\n });\n }\n }\n return FormlyFieldSlider;\n})();\n(() => {\n (typeof ngDevMode === \"undefined\" || ngDevMode) && void 0;\n})();\nfunction withFormlyFieldSlider() {\n return {\n types: [{\n name: 'slider',\n component: FormlyFieldSlider,\n wrappers: ['form-field']\n }]\n };\n}\nlet FormlyMatSliderModule = /*#__PURE__*/(() => {\n class FormlyMatSliderModule {\n static {\n this.\u0275fac = function FormlyMatSliderModule_Factory(__ngFactoryType__) {\n return new (__ngFactoryType__ || FormlyMatSliderModule)();\n };\n }\n static {\n this.\u0275mod = /* @__PURE__ */i0.\u0275\u0275defineNgModule({\n type: FormlyMatSliderModule\n });\n }\n static {\n this.\u0275inj = /* @__PURE__ */i0.\u0275\u0275defineInjector({\n imports: [CommonModule, MatCommonModule, MatRippleModule, ReactiveFormsModule, MatSliderModule, FormlyMatFormFieldModule, FormlyModule.forChild(withFormlyFieldSlider())]\n });\n }\n }\n return FormlyMatSliderModule;\n})();\n(() => {\n (typeof ngDevMode === \"undefined\" || ngDevMode) && void 0;\n})();\n\n/**\n * Generated bundle index. Do not edit.\n */\n\nexport { FormlyFieldSlider, FormlyMatSliderModule, withFormlyFieldSlider };\n", │ │ "import {\n ChangeDetectionStrategy,\n Component,\n computed,\n DestroyRef,\n ElementRef,\n inject,\n input,\n output,\n signal,\n viewChild,\n} from '@angular/core';\nimport {\n MatAutocomplete,\n MatAutocompleteSelectedEvent,\n MatAutocompleteTrigger,\n MatOption,\n} from '@angular/material/autocomplete';\nimport {\n MatChipGrid,\n MatChipInput,\n MatChipInputEvent,\n MatChipRemove,\n MatChipRow,\n} from '@angular/material/chips';\nimport { MatIcon } from '@angular/material/icon';\nimport { ReactiveFormsModule, UntypedFormControl } from '@angular/forms';\nimport { COMMA, ENTER } from '@angular/cdk/keycodes';\nimport { T } from '../../../t.const';\nimport { TagService } from '../tag.service';\nimport { TaskService } from '../../tasks/task.service';\nimport { TaskCopy } from '../../tasks/task.model';\nimport { TagComponent } from '../tag/tag.component';\nimport { TranslatePipe } from '@ngx-translate/core';\nimport { TODAY_TAG } from '../tag.const';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\n\ninterface Suggestion {\n id: string;\n title: string;\n\n [key: string]: any;\n}\n\nconst DEFAULT_SEPARATOR_KEY_CODES: number[] = [ENTER, COMMA];\n\n@Component({\n selector: 'tag-edit',\n standalone: true,\n imports: [\n MatAutocomplete,\n MatAutocompleteTrigger,\n MatChipGrid,\n MatChipInput,\n MatChipRow,\n MatIcon,\n MatChipRemove,\n TagComponent,\n ReactiveFormsModule,\n MatOption,\n TranslatePipe,\n ],\n templateUrl: './tag-edit.component.html',\n styleUrl: './tag-edit.component.scss',\n changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TagEditComponent {\n T: typeof T = T;\n\n private _tagService = inject(TagService);\n private _taskService = inject(TaskService);\n private readonly _destroyRef = inject(DestroyRef);\n\n task = input();\n isShowMyDayTag = input(false);\n tagIds = input.required();\n excludedTagIds = input();\n tagUpdate = output();\n\n escapePress = output();\n\n inputCtrl: UntypedFormControl = new UntypedFormControl();\n separatorKeysCodes: number[] = DEFAULT_SEPARATOR_KEY_CODES;\n\n readonly inputEl = viewChild>('inputElRef');\n readonly matAutocomplete = viewChild('autoElRef');\n\n inputVal = signal('');\n tagSuggestions = computed(() =>\n this.isShowMyDayTag()\n ? this._tagService.tagsSortedForUI()\n : this._tagService.tagsNoMyDayAndNoListSorted(),\n );\n\n constructor() {\n this.inputCtrl.valueChanges\n .pipe(takeUntilDestroyed(this._destroyRef))\n .subscribe((value: string | null) => {\n this.inputVal.set(value ?? '');\n });\n }\n\n allExcludedTagIds = computed(() => [\n ...this.tagIds(),\n ...(this.excludedTagIds() || []),\n TODAY_TAG.id,\n ]);\n filteredSuggestions = computed(() => {\n const val = this.inputVal();\n const allExcludedTagIds = this.allExcludedTagIds();\n\n if (!val) {\n return this.tagSuggestions().filter(\n (suggestion) => !allExcludedTagIds.includes(suggestion.id),\n );\n }\n const filterValue = val.toLowerCase();\n\n return this.tagSuggestions().filter(\n (suggestion) =>\n suggestion.title.toLowerCase().indexOf(filterValue) === 0 &&\n !allExcludedTagIds.includes(suggestion.id),\n );\n });\n\n tagItems = computed(() => {\n const suggestions = this.tagSuggestions();\n return suggestions.length\n ? (this.tagIds()\n .map((id) => suggestions.find((suggestion) => suggestion.id === id))\n .filter((v) => v) as Suggestion[])\n : [];\n });\n\n add(event: MatChipInputEvent): void {\n const matAutocomplete = this.matAutocomplete();\n if (!matAutocomplete) {\n throw new Error('Auto complete undefined');\n }\n\n if (!matAutocomplete.isOpen) {\n const inp = event.input;\n const value = event.value;\n\n // Add our fruit\n if ((value || '').trim()) {\n this._addByTitle(value.trim());\n }\n\n inp.value = '';\n\n this.inputCtrl.setValue(null);\n }\n }\n\n onKeydown(event: KeyboardEvent): void {\n if (event.code === 'Escape') {\n this.escapePress.emit();\n }\n }\n\n focusInput(): void {\n const inputEl = this.inputEl();\n if (inputEl) {\n inputEl.nativeElement.focus();\n }\n }\n\n remove(id: string): void {\n this._updateModel(this.tagIds().filter((tid) => tid !== id));\n }\n\n selected(event: MatAutocompleteSelectedEvent): void {\n this._add(event.option.value);\n const inputEl = this.inputEl();\n if (inputEl) {\n inputEl.nativeElement.value = '';\n }\n this.inputCtrl.setValue(null);\n }\n\n private _updateModel(v: string[]): void {\n this.tagUpdate.emit(v);\n const task = this.task();\n if (task) {\n this._taskService.updateTags(task, v);\n }\n }\n\n private _getExistingSuggestionByTitle(v: string): Suggestion | undefined {\n return this.tagSuggestions().find((suggestion) => suggestion.title === v);\n }\n\n private _add(id: string): void {\n // prevent double items\n if (!this.tagIds().includes(id)) {\n this._updateModel([...this.tagIds(), id]);\n }\n }\n\n private _addByTitle(v: string): void {\n const existing = this._getExistingSuggestionByTitle(v);\n if (existing) {\n if (!this.allExcludedTagIds().includes(existing.id)) {\n this._add(existing.id);\n }\n } else {\n this._createNewTag(v);\n }\n }\n\n private _createNewTag(title: string): void {\n const cleanTitle = (t: string): string => {\n return t.replace('#', '');\n };\n\n const id = this._tagService.addTag({ title: cleanTitle(title) });\n this._add(id);\n }\n\n protected readonly onkeydown = onkeydown;\n}\n", │ │ "\n @for (modelItem of tagItems(); track modelItem.id) {\n \n \n\n cancel\n \n \n }\n \n\n\n @for (suggestion of filteredSuggestions(); track suggestion.id) {\n \n \n \n }\n\n", │ │ "import { ChangeDetectionStrategy, Component } from '@angular/core';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { FieldType } from '@ngx-formly/material';\nimport { FormlyFieldConfig, FormlyModule } from '@ngx-formly/core';\nimport { T } from 'src/app/t.const';\nimport { TagEditComponent } from '../../features/tag/tag-edit/tag-edit.component';\n\n@Component({\n selector: 'formly-tag-selection',\n standalone: true,\n imports: [FormsModule, FormlyModule, ReactiveFormsModule, TagEditComponent],\n templateUrl: './formly-tag-selection.component.html',\n styleUrl: './formly-tag-selection.component.scss',\n changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class FormlyTagSelectionComponent extends FieldType {\n T: typeof T = T;\n}\n", │ │ "\n\n\n\n", │ │ "import { ChangeDetectionStrategy, Component } from '@angular/core';\nimport { FormlyFieldConfig, FormlyModule } from '@ngx-formly/core';\nimport { FieldType } from '@ngx-formly/material';\nimport { MatButton } from '@angular/material/button';\nimport { TranslatePipe } from '@ngx-translate/core';\nimport { Log } from '../../core/log';\n\n@Component({\n selector: 'formly-btn',\n templateUrl: './formly-btn.component.html',\n styleUrl: './formly-btn.component.scss',\n changeDetection: ChangeDetectionStrategy.OnPush,\n imports: [FormlyModule, MatButton, TranslatePipe],\n})\nexport class FormlyBtnComponent extends FieldType {\n onClick(): void {\n if (this.to.onClick) {\n const r = this.to.onClick(this.field, this.form, this.model);\n if (r && 'then' in r) {\n r.then((v) => {\n Log.log('update', v, this);\n this.formControl.setValue(v);\n this.form.markAsDirty();\n });\n } else {\n this.formControl.setValue(r);\n }\n }\n }\n}\n", │ │ "@if (value) {\n
    {{ value }}
    \n}\n\n {{ (to.text | translate) || 'Click Me' }}\n\n", │ │ - "// This file is auto-generated by tools/load-env.js\n// Do not modify directly - edit .env file instead\n// Generated at: 2025-10-26T02:13:58.541Z\n\n/**\n * Environment variables loaded from .env file\n * Access these constants instead of process.env in your Angular app\n */\nexport const ENV = {\n\n} as const;\n\n// Type-safe helper to ensure all expected env vars are defined\nexport type EnvVars = typeof ENV;\n", │ │ + "// This file is auto-generated by tools/load-env.js\n// Do not modify directly - edit .env file instead\n// Generated at: 2025-10-27T23:42:45.520Z\n\n/**\n * Environment variables loaded from .env file\n * Access these constants instead of process.env in your Angular app\n */\nexport const ENV = {\n\n} as const;\n\n// Type-safe helper to ensure all expected env vars are defined\nexport type EnvVars = typeof ENV;\n", │ │ "/**\n * Pure functions for accessing environment variables.\n * These can be used anywhere in the codebase, including outside Angular context.\n */\n\n// Import the generated environment constants\n// This file is auto-generated from .env by tools/load-env.js\nimport { ENV } from '../config/env.generated';\n\n/**\n * Get an environment variable value.\n * Returns undefined if the variable is not set.\n */\nexport const getEnv = (key: keyof typeof ENV): string | undefined => {\n return ENV[key] || undefined;\n};\n\n/**\n * Get an optional environment variable that may not be in the required list.\n * Use this for environment variables that are truly optional and may not be defined\n * in the REQUIRED_ENV_KEYS list in load-env.js.\n * Returns undefined if the variable is not set.\n */\nexport const getEnvOptional = (key: string): string | undefined => {\n return (ENV as any)[key] || undefined;\n};\n\n/**\n * Get an environment variable as a number.\n * Returns undefined if the value is not a valid number.\n */\nexport const getEnvNumber = (key: keyof typeof ENV): number | undefined => {\n const value = getEnv(key);\n if (value === undefined) return undefined;\n const num = Number(value);\n return isNaN(num) ? undefined : num;\n};\n\n/**\n * Get all environment variables as an object.\n * Useful for debugging or passing multiple values.\n */\nexport const getAllEnv = (): typeof ENV => ENV;\n", │ │ "import { Injectable, inject } from '@angular/core';\nimport { HttpClient } from '@angular/common/http';\nimport { Observable, of } from 'rxjs';\nimport { catchError } from 'rxjs/operators';\nimport { getEnvOptional } from '../../util/env';\n\nexport interface UnsplashPhoto {\n id: string;\n urls: {\n raw: string;\n full: string;\n regular: string;\n small: string;\n thumb: string;\n };\n links?: {\n self?: string;\n html?: string;\n download?: string;\n download_location?: string;\n };\n description: string | null;\n alt_description: string | null;\n user: {\n name: string;\n links?: {\n html?: string;\n };\n };\n}\n\nexport interface UnsplashSearchResponse {\n results: UnsplashPhoto[];\n total: number;\n total_pages: number;\n}\n\n@Injectable({\n providedIn: 'root',\n})\nexport class UnsplashService {\n private _http = inject(HttpClient);\n\n private readonly API_URL = 'https://api.unsplash.com';\n // Register your app at https://unsplash.com/developers?utm_source=super-productivity&utm_medium=referral&utm_campaign=api-credit for a free Access Key (50 req/hour)\n // The Access Key is used with \"Client-ID\" prefix in the Authorization header\n private readonly ACCESS_KEY = getEnvOptional('UNSPLASH_KEY');\n\n isAvailable(): boolean {\n return !!this.ACCESS_KEY;\n }\n\n searchPhotos(query: string, page = 1): Observable {\n if (!query || query.trim() === '') {\n return of({ results: [], total: 0, total_pages: 0 });\n }\n\n if (!this.ACCESS_KEY) {\n console.warn(\n 'No Unsplash Access Key configured. Register at https://unsplash.com/developers?utm_source=super-productivity&utm_medium=referral&utm_campaign=api-credit',\n );\n return of({ results: [], total: 0, total_pages: 0 });\n }\n\n const params = {\n query: query.trim(),\n page: page.toString(),\n per_page: '20',\n orientation: 'landscape',\n };\n\n const url = `${this.API_URL}/search/photos`;\n const headers = {\n Authorization: `Client-ID ${this.ACCESS_KEY}`,\n };\n\n return this._http\n .get(url, {\n params,\n headers,\n })\n .pipe(\n catchError((error) => {\n console.error('Unsplash API error:', error);\n return of({ results: [], total: 0, total_pages: 0 });\n }),\n );\n }\n\n getPhotoUrl(\n photo: UnsplashPhoto,\n size: 'thumb' | 'small' | 'regular' = 'regular',\n ): string {\n return photo.urls[size];\n }\n\n /**\n * Get optimized image URL for backgrounds\n * @param photo - The Unsplash photo object\n * @param width - Desired width (default 2560 for high res displays)\n * @param quality - Image quality 1-100 (default 85)\n */\n getBackgroundImageUrl(photo: UnsplashPhoto, width = 2560, quality = 85): string {\n return `${photo.urls.raw}&w=${width}&q=${quality}&auto=format`;\n }\n\n /**\n * Add UTM parameters to Unsplash attribution links as required\n * @param url - The original Unsplash URL\n */\n addUtmParams(url: string): string {\n if (!url) return url;\n\n const separator = url.includes('?') ? '&' : '?';\n return `${url}${separator}utm_source=super-productivity&utm_medium=referral&utm_campaign=api-credit`;\n }\n\n /**\n * Trigger download tracking as required by Unsplash API guidelines\n * This must be called when a user selects a photo for use\n * @param photo - The selected photo\n */\n trackPhotoDownload(photo: UnsplashPhoto): Observable {\n if (!photo.links?.download_location) {\n console.warn('No download_location available for photo', photo.id);\n return of(null);\n }\n\n if (!this.ACCESS_KEY) {\n console.warn('No Unsplash Access Key configured');\n return of(null);\n }\n\n const headers = {\n Authorization: `Client-ID ${this.ACCESS_KEY}`,\n };\n\n // Call the download endpoint to track usage\n return this._http.get(photo.links.download_location, { headers }).pipe(\n catchError((error) => {\n console.error('Failed to track photo download:', error);\n // Don't fail the selection if tracking fails\n return of(null);\n }),\n );\n }\n}\n", │ │ "export const IS_MAC = navigator.platform.toUpperCase().indexOf('MAC') >= 0;\n", │ │ "import * as i0 from '@angular/core';\nimport { InjectionToken, Injectable, EventEmitter, Directive, Optional, Inject, Input, Output } from '@angular/core';\nimport { registerables, Chart, defaults } from 'chart.js';\nimport { merge } from 'lodash-es';\nimport { BehaviorSubject } from 'rxjs';\nimport { distinctUntilChanged } from 'rxjs/operators';\nconst NG_CHARTS_CONFIGURATION = new InjectionToken('Configuration for ngCharts');\n/**\n * Provide all the default registerable as defined by Chart.js\n */\nfunction withDefaultRegisterables(...registerables$1) {\n return {\n registerables: [...registerables, ...registerables$1]\n };\n}\n/**\n * Provide configuration for ngCharts. In most cases, you have to pass it some registerables. So either\n * `withDefaultRegisterables()`, or a custom list of registerables tailored to your needs to reduce bundle size.\n */\nfunction provideCharts(...configurations) {\n const config = merge({}, ...configurations);\n return {\n provide: NG_CHARTS_CONFIGURATION,\n useValue: config\n };\n}\nlet ThemeService = /*#__PURE__*/(() => {\n class ThemeService {\n constructor() {\n this.colorschemesOptions = new BehaviorSubject(undefined);\n }\n setColorschemesOptions(options) {\n this.pColorschemesOptions = options;\n this.colorschemesOptions.next(options);\n }\n getColorschemesOptions() {\n return this.pColorschemesOptions;\n }\n static {\n this.\u0275fac = function ThemeService_Factory(__ngFactoryType__) {\n return new (__ngFactoryType__ || ThemeService)();\n };\n }\n static {\n this.\u0275prov = /* @__PURE__ */i0.\u0275\u0275defineInjectable({\n token: ThemeService,\n factory: ThemeService.\u0275fac,\n providedIn: 'root'\n });\n }\n }\n return ThemeService;\n})();\n(() => {\n (typeof ngDevMode === \"undefined\" || ngDevMode) && void 0;\n})();\nlet BaseChartDirective = /*#__PURE__*/(() => {\n class BaseChartDirective {\n constructor(element, zone, themeService, config) {\n this.zone = zone;\n this.themeService = themeService;\n this.type = 'bar';\n this.plugins = [];\n this.chartClick = new EventEmitter();\n this.chartHover = new EventEmitter();\n this.subs = [];\n this.themeOverrides = {};\n if (config?.registerables) {\n Chart.register(...config.registerables);\n }\n if (config?.defaults) {\n defaults.set(config.defaults);\n }\n this.ctx = element.nativeElement.getContext('2d');\n this.subs.push(this.themeService.colorschemesOptions.pipe(distinctUntilChanged()).subscribe(r => this.themeChanged(r)));\n }\n ngOnChanges(changes) {\n const requireRender = ['type'];\n const propertyNames = Object.getOwnPropertyNames(changes);\n if (propertyNames.some(key => requireRender.includes(key)) || propertyNames.every(key => changes[key].isFirstChange())) {\n this.render();\n } else {\n const config = this.getChartConfiguration();\n // Using assign to avoid changing the original object reference\n if (this.chart) {\n Object.assign(this.chart.config.data, config.data);\n if (this.chart.config.plugins) {\n Object.assign(this.chart.config.plugins, config.plugins);\n }\n if (this.chart.config.options) {\n Object.assign(this.chart.config.options, config.options);\n }\n }\n this.update();\n }\n }\n ngOnDestroy() {\n if (this.chart) {\n this.chart.destroy();\n this.chart = void 0;\n }\n this.subs.forEach(s => s.unsubscribe());\n }\n render() {\n if (this.chart) {\n this.chart.destroy();\n }\n return this.zone.runOutsideAngular(() => this.chart = new Chart(this.ctx, this.getChartConfiguration()));\n }\n update(mode) {\n if (this.chart) {\n this.zone.runOutsideAngular(() => this.chart?.update(mode));\n }\n }\n hideDataset(index, hidden) {\n if (this.chart) {\n this.chart.getDatasetMeta(index).hidden = hidden;\n this.update();\n }\n }\n isDatasetHidden(index) {\n return this.chart?.getDatasetMeta(index)?.hidden;\n }\n toBase64Image() {\n return this.chart?.toBase64Image();\n }\n themeChanged(options) {\n this.themeOverrides = options;\n if (this.chart) {\n if (this.chart.config.options) {\n Object.assign(this.chart.config.options, this.getChartOptions());\n }\n this.update();\n }\n }\n getChartOptions() {\n return merge({\n onHover: (event, active) => {\n if (!this.chartHover.observed && !this.chartHover.observers?.length) {\n return;\n }\n this.zone.run(() => this.chartHover.emit({\n event,\n active\n }));\n },\n onClick: (event, active) => {\n if (!this.chartClick.observed && !this.chartClick.observers?.length) {\n return;\n }\n this.zone.run(() => this.chartClick.emit({\n event,\n active\n }));\n }\n }, this.themeOverrides, this.options, {\n plugins: {\n legend: {\n display: this.legend\n }\n }\n });\n }\n getChartConfiguration() {\n return {\n type: this.type,\n data: this.getChartData(),\n options: this.getChartOptions(),\n plugins: this.plugins\n };\n }\n getChartData() {\n return this.data ? this.data : {\n labels: this.labels || [],\n datasets: this.datasets || []\n };\n }\n static {\n this.\u0275fac = function BaseChartDirective_Factory(__ngFactoryType__) {\n return new (__ngFactoryType__ || BaseChartDirective)(i0.\u0275\u0275directiveInject(i0.ElementRef), i0.\u0275\u0275directiveInject(i0.NgZone), i0.\u0275\u0275directiveInject(ThemeService), i0.\u0275\u0275directiveInject(NG_CHARTS_CONFIGURATION, 8));\n };\n }\n static {\n this.\u0275dir = /* @__PURE__ */i0.\u0275\u0275defineDirective({\n type: BaseChartDirective,\n selectors: [[\"canvas\", \"baseChart\", \"\"]],\n inputs: {\n type: \"type\",\n legend: \"legend\",\n data: \"data\",\n options: \"options\",\n plugins: \"plugins\",\n labels: \"labels\",\n datasets: \"datasets\"\n },\n outputs: {\n chartClick: \"chartClick\",\n chartHover: \"chartHover\"\n },\n exportAs: [\"base-chart\"],\n features: [i0.\u0275\u0275NgOnChangesFeature]\n });\n }\n }\n return BaseChartDirective;\n})();\n(() => {\n (typeof ngDevMode === \"undefined\" || ngDevMode) && void 0;\n})();\n\n/*\n * Public API Surface of ng2-charts\n */\n\n/**\n * Generated bundle index. Do not edit.\n */\n\nexport { BaseChartDirective, NG_CHARTS_CONFIGURATION, ThemeService, provideCharts, withDefaultRegisterables };\n", │ │ "export const IS_FIREFOX = navigator.userAgent.toLowerCase().indexOf('firefox') > -1;\n", │ │ "import { inject, Injectable } from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\nimport { Log } from '../log';\n\nexport interface CustomTheme {\n id: string;\n name: string;\n url: string;\n requiredMode?: 'dark' | 'light' | 'system';\n}\n\nexport const AVAILABLE_CUSTOM_THEMES: CustomTheme[] = [\n {\n id: 'default',\n name: 'Default',\n url: '',\n requiredMode: 'system',\n },\n {\n id: 'arc',\n name: 'Arc',\n url: 'assets/themes/arc.css',\n requiredMode: 'dark',\n },\n {\n id: 'dark-base',\n name: 'Dark Base',\n url: 'assets/themes/dark-base.css',\n requiredMode: 'dark',\n },\n {\n id: 'dracula',\n name: 'Dracula',\n url: 'assets/themes/dracula.css',\n requiredMode: 'dark',\n },\n {\n id: 'everforest',\n name: 'Everforest',\n url: 'assets/themes/everforest.css',\n requiredMode: 'system',\n },\n {\n id: 'rainbow',\n name: 'Rainbow',\n url: 'assets/themes/rainbow.css',\n requiredMode: 'system',\n },\n {\n id: 'glass',\n name: 'Glass',\n url: 'assets/themes/glass.css',\n requiredMode: 'dark',\n },\n {\n id: 'nord-polar-night',\n name: 'Nord Polar Night',\n url: 'assets/themes/nord-polar-night.css',\n requiredMode: 'dark',\n },\n {\n id: 'nord-snow-storm',\n name: 'Nord Snow Storm',\n url: 'assets/themes/nord-snow-storm.css',\n requiredMode: 'light',\n },\n];\n\n@Injectable({ providedIn: 'root' })\nexport class CustomThemeService {\n private document = inject(DOCUMENT);\n private currentThemeLinkElement: HTMLLinkElement | null = null;\n\n loadTheme(themeId: string): void {\n const theme = AVAILABLE_CUSTOM_THEMES.find((t) => t.id === themeId);\n\n if (!theme) {\n Log.err(`Theme with id ${themeId} not found`);\n return;\n }\n\n // Remove existing theme\n this.unloadCurrentTheme();\n\n // If default theme, no need to load external CSS\n if (theme.id === 'default' || !theme.url) {\n return;\n }\n\n // Create new link element for theme\n const linkElement = this.document.createElement('link');\n linkElement.rel = 'stylesheet';\n linkElement.href = theme.url;\n linkElement.id = 'custom-theme-stylesheet';\n\n // Add to head\n this.document.head.appendChild(linkElement);\n this.currentThemeLinkElement = linkElement;\n }\n\n unloadCurrentTheme(): void {\n if (this.currentThemeLinkElement) {\n this.currentThemeLinkElement.remove();\n this.currentThemeLinkElement = null;\n }\n\n // Also remove any existing custom theme stylesheets\n const existingThemeLink = this.document.getElementById('custom-theme-stylesheet');\n if (existingThemeLink) {\n existingThemeLink.remove();\n }\n }\n\n getAvailableThemes(): CustomTheme[] {\n return AVAILABLE_CUSTOM_THEMES;\n }\n}\n", │ │ "import { effect, inject, Injectable, signal } from '@angular/core';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\nimport { BodyClass, IS_ELECTRON } from '../../app.constants';\nimport { IS_MAC } from '../../util/is-mac';\nimport { distinctUntilChanged, map, startWith, switchMap, take } from 'rxjs/operators';\nimport { IS_TOUCH_ONLY } from '../../util/is-touch-only';\nimport { MaterialCssVarsService } from 'angular-material-css-vars';\nimport { DOCUMENT } from '@angular/common';\nimport { MatIconRegistry } from '@angular/material/icon';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport { ChromeExtensionInterfaceService } from '../chrome-extension-interface/chrome-extension-interface.service';\nimport { ThemeService as NgChartThemeService } from 'ng2-charts';\nimport { GlobalConfigService } from '../../features/config/global-config.service';\nimport { WorkContextThemeCfg } from '../../features/work-context/work-context.model';\nimport { WorkContextService } from '../../features/work-context/work-context.service';\nimport { combineLatest, fromEvent, Observable, of } from 'rxjs';\nimport { IS_FIREFOX } from '../../util/is-firefox';\nimport { ImexViewService } from '../../imex/imex-meta/imex-view.service';\nimport { IS_MOUSE_PRIMARY, IS_TOUCH_PRIMARY } from '../../util/is-mouse-primary';\nimport { ChartConfiguration } from 'chart.js';\nimport { IS_ANDROID_WEB_VIEW } from '../../util/is-android-web-view';\nimport { androidInterface } from '../../features/android/android-interface';\nimport { HttpClient } from '@angular/common/http';\nimport { LS } from '../persistence/storage-keys.const';\nimport { CustomThemeService } from './custom-theme.service';\nimport { Log } from '../log';\nimport { LayoutService } from '../../core-ui/layout/layout.service';\n\nexport type DarkModeCfg = 'dark' | 'light' | 'system';\n\n@Injectable({ providedIn: 'root' })\nexport class GlobalThemeService {\n private document = inject(DOCUMENT);\n private _layoutService = inject(LayoutService);\n private _materialCssVarsService = inject(MaterialCssVarsService);\n private _workContextService = inject(WorkContextService);\n private _globalConfigService = inject(GlobalConfigService);\n private _matIconRegistry = inject(MatIconRegistry);\n private _domSanitizer = inject(DomSanitizer);\n private _chartThemeService = inject(NgChartThemeService);\n private _chromeExtensionInterfaceService = inject(ChromeExtensionInterfaceService);\n private _imexMetaService = inject(ImexViewService);\n private _http = inject(HttpClient);\n private _customThemeService = inject(CustomThemeService);\n\n darkMode = signal(\n (localStorage.getItem(LS.DARK_MODE) as DarkModeCfg) || 'system',\n );\n\n private _isDarkThemeObs$: Observable = toObservable(this.darkMode).pipe(\n switchMap((darkMode) => {\n switch (darkMode) {\n case 'dark':\n return of(true);\n case 'light':\n return of(false);\n default:\n const darkModePreference = window.matchMedia('(prefers-color-scheme: dark)');\n return fromEvent(darkModePreference, 'change').pipe(\n map((e: any) => e.matches),\n startWith(darkModePreference.matches),\n );\n }\n }),\n distinctUntilChanged(),\n );\n\n isDarkTheme = toSignal(this._isDarkThemeObs$, { initialValue: false });\n\n private _backgroundImgObs$: Observable = combineLatest([\n this._workContextService.currentTheme$,\n this._isDarkThemeObs$,\n ]).pipe(\n map(([theme, isDarkMode]) =>\n isDarkMode ? theme.backgroundImageDark : theme.backgroundImageLight,\n ),\n distinctUntilChanged(),\n );\n\n backgroundImg = toSignal(this._backgroundImgObs$);\n\n init(): void {\n // This is here to make web page reloads on non-work-context pages at least usable\n this._setBackgroundTint(true);\n this._initIcons();\n this._initHandlersForInitialBodyClasses();\n this._initThemeWatchers();\n\n // Set up dark mode persistence effect\n effect(() => {\n const darkMode = this.darkMode();\n localStorage.setItem(LS.DARK_MODE, darkMode);\n });\n\n // Set up reactive custom theme updates\n this._setupCustomThemeEffect();\n }\n\n private _setDarkTheme(isDarkTheme: boolean): void {\n this._materialCssVarsService.setDarkTheme(isDarkTheme);\n this._setChartTheme(isDarkTheme);\n // this._materialCssVarsService.setDarkTheme(true);\n // this._materialCssVarsService.setDarkTheme(false);\n }\n\n private _setColorTheme(theme: WorkContextThemeCfg): void {\n this._materialCssVarsService.setAutoContrastEnabled(!!theme.isAutoContrast);\n this._setBackgroundTint(!!theme.isDisableBackgroundTint);\n\n // NOTE: setting undefined values does not seem to be a problem so we use !\n if (!theme.isAutoContrast) {\n this._materialCssVarsService.setContrastColorThresholdPrimary(theme.huePrimary!);\n this._materialCssVarsService.setContrastColorThresholdAccent(theme.hueAccent!);\n this._materialCssVarsService.setContrastColorThresholdWarn(theme.hueWarn!);\n }\n\n this._materialCssVarsService.setPrimaryColor(theme.primary!);\n this._materialCssVarsService.setAccentColor(theme.accent!);\n this._materialCssVarsService.setWarnColor(theme.warn!);\n }\n\n private _setBackgroundTint(isDisableBackgroundTint: boolean): void {\n // Simplify: toggle only the disable flag; CSS handles the rest\n this.document.body.classList.toggle(\n BodyClass.isDisableBackgroundTint,\n !!isDisableBackgroundTint,\n );\n }\n\n private _initIcons(): void {\n const icons: [string, string][] = [\n ['sp', 'assets/icons/sp.svg'],\n ['play', 'assets/icons/play.svg'],\n ['github', 'assets/icons/github.svg'],\n ['gitlab', 'assets/icons/gitlab.svg'],\n ['jira', 'assets/icons/jira.svg'],\n ['caldav', 'assets/icons/caldav.svg'],\n ['open_project', 'assets/icons/open-project.svg'],\n ['drag_handle', 'assets/icons/drag-handle.svg'],\n ['remove_today', 'assets/icons/remove-today-48px.svg'],\n ['estimate_remaining', 'assets/icons/estimate-remaining.svg'],\n ['working_today', 'assets/icons/working-today.svg'],\n ['repeat', 'assets/icons/repeat.svg'],\n ['gitea', 'assets/icons/gitea.svg'],\n ['redmine', 'assets/icons/redmine.svg'],\n ['calendar', 'assets/icons/calendar.svg'],\n ['early_on', 'assets/icons/early-on.svg'],\n ['tomorrow', 'assets/icons/tomorrow.svg'],\n ['next_week', 'assets/icons/next-week.svg'],\n ['keep', 'assets/icons/keep.svg'],\n ['keep_filled', 'assets/icons/keep-filled.svg'],\n ];\n\n // todo test if can be removed with airplane mode and wifi without internet\n icons.forEach(([name, path]) => {\n this._matIconRegistry.addSvgIcon(\n name,\n this._domSanitizer.bypassSecurityTrustResourceUrl(path),\n );\n });\n\n this.preloadIcons(icons);\n }\n\n preloadIcons(icons: [string, string][]): Promise {\n // Map each icon name to a promise that fetches and registers the icon.\n const iconPromises = icons.map(([iconName, url]) => {\n // Construct the URL for the SVG file.\n // Adjust the path if your SVGs are located elsewhere.\n return this._http\n .get(url, { responseType: 'text' })\n .toPromise()\n .then((svg) => {\n // Register the fetched SVG as an inline icon.\n this._matIconRegistry.addSvgIconLiteral(\n iconName,\n this._domSanitizer.bypassSecurityTrustHtml(svg),\n );\n })\n .catch((error) => {\n Log.err(`Error loading icon: ${iconName} from ${url}`, error);\n });\n });\n\n // Return a promise that resolves when all icons have been processed.\n return Promise.all(iconPromises);\n }\n\n private _initThemeWatchers(): void {\n // init theme watchers\n this._workContextService.currentTheme$.subscribe((theme: WorkContextThemeCfg) =>\n this._setColorTheme(theme),\n );\n this._isDarkThemeObs$.subscribe((isDarkTheme) => this._setDarkTheme(isDarkTheme));\n }\n\n private _initHandlersForInitialBodyClasses(): void {\n this.document.body.classList.add(BodyClass.isNoAdvancedFeatures);\n\n if (!IS_FIREFOX) {\n this.document.body.classList.add(BodyClass.isNoFirefox);\n }\n\n if (IS_MAC) {\n this.document.body.classList.add(BodyClass.isMac);\n } else {\n this.document.body.classList.add(BodyClass.isNoMac);\n }\n\n if (IS_ELECTRON) {\n this.document.body.classList.add(BodyClass.isElectron);\n this.document.body.classList.add(BodyClass.isAdvancedFeatures);\n this.document.body.classList.remove(BodyClass.isNoAdvancedFeatures);\n } else {\n this.document.body.classList.add(BodyClass.isWeb);\n this._chromeExtensionInterfaceService.onReady$.pipe(take(1)).subscribe(() => {\n this.document.body.classList.add(BodyClass.isExtension);\n this.document.body.classList.add(BodyClass.isAdvancedFeatures);\n this.document.body.classList.remove(BodyClass.isNoAdvancedFeatures);\n });\n }\n\n if (IS_ANDROID_WEB_VIEW) {\n androidInterface.isKeyboardShown$.subscribe((isShown) => {\n Log.log('isShown', isShown);\n\n this.document.body.classList.remove(BodyClass.isAndroidKeyboardHidden);\n this.document.body.classList.remove(BodyClass.isAndroidKeyboardShown);\n this.document.body.classList.add(\n isShown ? BodyClass.isAndroidKeyboardShown : BodyClass.isAndroidKeyboardHidden,\n );\n });\n }\n\n // Use effect to reactively update animation class\n effect(() => {\n const misc = this._globalConfigService.misc();\n if (misc?.isDisableAnimations) {\n this.document.body.classList.add(BodyClass.isDisableAnimations);\n } else {\n this.document.body.classList.remove(BodyClass.isDisableAnimations);\n }\n });\n\n // Add/remove hasBgImage class to body when background image changes\n effect(() => {\n if (this.backgroundImg()) {\n this.document.body.classList.add(BodyClass.hasBgImage);\n } else {\n this.document.body.classList.remove(BodyClass.hasBgImage);\n }\n });\n\n // Add/remove has-mobile-bottom-nav class to body for snack bar positioning\n effect(() => {\n if (this._layoutService.isShowMobileBottomNav) {\n this.document.body.classList.add(BodyClass.hasMobileBottomNav);\n } else {\n this.document.body.classList.remove(BodyClass.hasMobileBottomNav);\n }\n });\n\n this._imexMetaService.isDataImportInProgress$.subscribe((isInProgress) => {\n // timer(1000, 5000)\n // .pipe(map((val) => val % 2 === 0))\n // .subscribe((isInProgress) => {\n if (isInProgress) {\n this.document.body.classList.add(BodyClass.isDataImportInProgress);\n } else {\n this.document.body.classList.remove(BodyClass.isDataImportInProgress);\n }\n });\n\n if (IS_TOUCH_ONLY) {\n this.document.body.classList.add(BodyClass.isTouchOnly);\n } else {\n this.document.body.classList.add(BodyClass.isNoTouchOnly);\n }\n\n if (IS_MOUSE_PRIMARY) {\n this.document.body.classList.add(BodyClass.isMousePrimary);\n } else if (IS_TOUCH_PRIMARY) {\n this.document.body.classList.add(BodyClass.isTouchPrimary);\n }\n }\n\n private _setChartTheme(isDarkTheme: boolean): void {\n const overrides: ChartConfiguration['options'] = isDarkTheme\n ? {\n // legend: {\n // labels: { fontColor: 'white' },\n // },\n scales: {\n x: {\n ticks: {\n color: 'white',\n },\n grid: {\n color: 'rgba(255,255,255,0.1)',\n },\n },\n\n y: {\n ticks: {\n color: 'white',\n },\n grid: {\n color: 'rgba(255,255,255,0.1)',\n },\n },\n },\n }\n : {\n scales: {},\n };\n this._chartThemeService.setColorschemesOptions(overrides);\n }\n\n private _setupCustomThemeEffect(): void {\n // Track previous theme to avoid unnecessary reloads\n let previousThemeId: string | null = null;\n\n // Set up effect to reactively update custom theme when config changes\n effect(() => {\n const misc = this._globalConfigService.misc();\n const themeId = misc?.customTheme || 'default';\n\n // Only load theme if it has changed\n if (themeId !== previousThemeId) {\n this._customThemeService.loadTheme(themeId);\n previousThemeId = themeId;\n }\n });\n }\n}\n", │ --- assets/public/chunk-ESEBWQAA.js ├── +++ assets/public/chunk-VOQG7765.js │┄ Files 99% similar despite different names │ ├── js-beautify {} │ │ @@ -10316,8 +10316,8 @@ │ │ } │ │ return r │ │ })() │ │ }); │ │ export { │ │ ye as a, As as b, xt as c, Ym as d, zh as e, jh as f, ip as g, Qs as h, Xs as i, Lt as j, mr as k, uo as l, ed as m, _t as n, Ks as o, Un as p, Zs as q, su as r, ql as s, cu as t, Wl as u, Yl as v, Ql as w, tb as x, sc as y, kc as z, so as A, vc as B, lo as C, Tc as D, Sc as E, R_ as F, hl as G, Bc as H, Uc as I, $c as J, zc as K, jc as L, Hc as M, Wc as N, Kc as O, Zc as P, ln as Q, po as R, cd as S, dd as T, md as U, pd as V │ │ }; │ │ -//# sourceMappingURL=chunk-ESEBWQAA.js.map │ │ +//# sourceMappingURL=chunk-VOQG7765.js.map │ --- assets/public/chunk-7E7XZV7L.js.map ├── +++ assets/public/chunk-L3GF7I2Z.js.map │┄ Files identical despite different names │ --- assets/public/chunk-7E7XZV7L.js ├── +++ assets/public/chunk-L3GF7I2Z.js │┄ Files 99% similar despite different names │ ├── js-beautify {} │ │ @@ -11,15 +11,15 @@ │ │ b as rn, │ │ c as Se, │ │ d as Vt, │ │ e as Ht, │ │ f as bn, │ │ g as ai, │ │ h as Dn │ │ -} from "./chunk-TLVKTX5S.js"; │ │ +} from "./chunk-4RLJGC7Y.js"; │ │ import { │ │ a as ft, │ │ b as It, │ │ c as gn │ │ } from "./chunk-VLI2QFPH.js"; │ │ import { │ │ a as X, │ │ @@ -29,15 +29,15 @@ │ │ a as qt, │ │ b as Nn, │ │ c as zt, │ │ d as Rn, │ │ e as Pn, │ │ f as jt, │ │ g as kn │ │ -} from "./chunk-H53RCMH4.js"; │ │ +} from "./chunk-WKAXUHLX.js"; │ │ import { │ │ a as Qt, │ │ b as ei, │ │ c as ti, │ │ d as ii, │ │ e as ni, │ │ f as oi, │ │ @@ -50,15 +50,15 @@ │ │ import { │ │ e as Wt, │ │ f as yn, │ │ g as Xt, │ │ h as Fn, │ │ k as $t, │ │ l as Mn │ │ -} from "./chunk-FPT5Z6JU.js"; │ │ +} from "./chunk-JFDPASXB.js"; │ │ import { │ │ A as xt, │ │ C as Sn, │ │ H as Lt, │ │ I as Ut, │ │ J as Bt, │ │ K as Kt, │ │ @@ -68,15 +68,15 @@ │ │ U as Yt, │ │ V as An, │ │ p as Ae, │ │ q as Cn, │ │ v as Rt, │ │ w as On, │ │ z as kt │ │ -} from "./chunk-ESEBWQAA.js"; │ │ +} from "./chunk-VOQG7765.js"; │ │ import "./chunk-PNLDAEIU.js"; │ │ import "./chunk-USV4YXDW.js"; │ │ import { │ │ b as vt, │ │ e as Gt, │ │ j as Tn │ │ } from "./chunk-G3HJ2GL3.js"; │ │ @@ -2593,8 +2593,8 @@ │ │ return i │ │ })() │ │ }); │ │ go(); │ │ export { │ │ Rl as ConfigPageComponent │ │ }; │ │ -//# sourceMappingURL=chunk-7E7XZV7L.js.map │ │ +//# sourceMappingURL=chunk-L3GF7I2Z.js.map │ --- assets/public/chunk-5QMEDHY4.js ├── +++ assets/public/chunk-PP3XGOFY.js │┄ Files 90% similar despite different names │ ├── js-beautify {} │ │ @@ -1,15 +1,12 @@ │ │ import { │ │ - a, │ │ - b │ │ -} from "./chunk-OZT432CE.js"; │ │ -import "./chunk-H53RCMH4.js"; │ │ -import "./chunk-FDVZKVGI.js"; │ │ -import "./chunk-FPT5Z6JU.js"; │ │ -import "./chunk-ESEBWQAA.js"; │ │ + s as a, │ │ + t as b │ │ +} from "./chunk-JFDPASXB.js"; │ │ +import "./chunk-VOQG7765.js"; │ │ import "./chunk-PNLDAEIU.js"; │ │ import "./chunk-USV4YXDW.js"; │ │ import "./chunk-G3HJ2GL3.js"; │ │ import "./chunk-GTBEH26W.js"; │ │ import "./chunk-TF4ZGOZ4.js"; │ │ import "./chunk-OCWFHHQL.js"; │ │ import "./chunk-WG4QBSGF.js"; │ │ @@ -40,10 +37,10 @@ │ │ import "./chunk-3YGNIIAP.js"; │ │ import "./chunk-MKQ5S2AR.js"; │ │ import "./chunk-OXDOKNTF.js"; │ │ import "./chunk-PEJGMLLQ.js"; │ │ import "./chunk-2NYJ54WT.js"; │ │ b(); │ │ export { │ │ - a as PluginIndexComponent │ │ + a as PluginRunner │ │ }; │ │ -//# sourceMappingURL=chunk-5QMEDHY4.js.map │ │ +//# sourceMappingURL=chunk-PP3XGOFY.js.map │ --- assets/public/chunk-3UN2ZJEW.js.map ├── +++ assets/public/chunk-BMOQZ47J.js.map │┄ Files identical despite different names │ --- assets/public/chunk-3UN2ZJEW.js ├── +++ assets/public/chunk-BMOQZ47J.js │┄ Files 99% similar despite different names │ ├── js-beautify {} │ │ @@ -14,15 +14,15 @@ │ │ import { │ │ f as gi, │ │ h as Ki │ │ } from "./chunk-W3EHXDVY.js"; │ │ import { │ │ e as ge, │ │ i as at │ │ -} from "./chunk-ESEBWQAA.js"; │ │ +} from "./chunk-VOQG7765.js"; │ │ import { │ │ N as pi, │ │ O as Xi │ │ } from "./chunk-OCWFHHQL.js"; │ │ import { │ │ a as ui, │ │ b as qi │ │ @@ -2569,8 +2569,8 @@ │ │ } │ │ return o │ │ })() │ │ }); │ │ export { │ │ Yo as a, Zi as b, wi as c, Ci as d, sa as e, la as f, ca as g, da as h, ua as i, ma as j, ha as k, fa as l, pa as m, ga as n, _a as o, jo as p, Zo as q, Ji as r, Ye as s, ht as t, tr as u, _o as v, Di as w, vi as x, Vn as y, fo as z, kr as A, xo as B │ │ }; │ │ -//# sourceMappingURL=chunk-3UN2ZJEW.js.map │ │ +//# sourceMappingURL=chunk-BMOQZ47J.js.map