--- /home/fdroid/fdroiddata/tmp/com.superproductivity.superproductivity_1600000000.apk +++ /home/fdroid/fdroiddata/tmp/sigcp_com.superproductivity.superproductivity_1600000000.apk ├── zipinfo {} │ @@ -138,16 +138,20 @@ │ -rw-r--r-- 0.0 unx 259545 b- defN 81-Jan-01 01:01 assets/public/chunk-2Q6UTZAM.js.map │ -rw-r--r-- 0.0 unx 2751 b- defN 81-Jan-01 01:01 assets/public/chunk-363GNZ4I.js │ -rw-r--r-- 0.0 unx 10701 b- defN 81-Jan-01 01:01 assets/public/chunk-363GNZ4I.js.map │ -rw-r--r-- 0.0 unx 20711 b- defN 81-Jan-01 01:01 assets/public/chunk-37YHURHI.js │ -rw-r--r-- 0.0 unx 61007 b- defN 81-Jan-01 01:01 assets/public/chunk-37YHURHI.js.map │ -rw-r--r-- 0.0 unx 9276 b- defN 81-Jan-01 01:01 assets/public/chunk-3E43H4SH.js │ -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 307404 b- defN 81-Jan-01 01:01 assets/public/chunk-3FBG5TIB.js │ +-rw-r--r-- 0.0 unx 982155 b- defN 81-Jan-01 01:01 assets/public/chunk-3FBG5TIB.js.map │ -rw-r--r-- 0.0 unx 4604 b- defN 81-Jan-01 01:01 assets/public/chunk-3FZSARDD.js │ -rw-r--r-- 0.0 unx 8705 b- defN 81-Jan-01 01:01 assets/public/chunk-3FZSARDD.js.map │ +-rw-r--r-- 0.0 unx 11454 b- defN 81-Jan-01 01:01 assets/public/chunk-3ISLZ73Y.js │ +-rw-r--r-- 0.0 unx 22568 b- defN 81-Jan-01 01:01 assets/public/chunk-3ISLZ73Y.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 124844 b- defN 81-Jan-01 01:01 assets/public/chunk-4HVTW7Z2.js │ -rw-r--r-- 0.0 unx 301311 b- defN 81-Jan-01 01:01 assets/public/chunk-4HVTW7Z2.js.map │ -rw-r--r-- 0.0 unx 20617 b- defN 81-Jan-01 01:01 assets/public/chunk-4PDR4WZL.js │ -rw-r--r-- 0.0 unx 35313 b- defN 81-Jan-01 01:01 assets/public/chunk-4PDR4WZL.js.map │ -rw-r--r-- 0.0 unx 4853 b- defN 81-Jan-01 01:01 assets/public/chunk-4WKVJOAH.js │ @@ -160,16 +164,14 @@ │ -rw-r--r-- 0.0 unx 816 b- defN 81-Jan-01 01:01 assets/public/chunk-5BKCBYJJ.js.map │ -rw-r--r-- 0.0 unx 4699 b- defN 81-Jan-01 01:01 assets/public/chunk-5J3KQ7C3.js │ -rw-r--r-- 0.0 unx 18780 b- defN 81-Jan-01 01:01 assets/public/chunk-5J3KQ7C3.js.map │ -rw-r--r-- 0.0 unx 25217 b- defN 81-Jan-01 01:01 assets/public/chunk-5TOMTPKS.js │ -rw-r--r-- 0.0 unx 69151 b- defN 81-Jan-01 01:01 assets/public/chunk-5TOMTPKS.js.map │ -rw-r--r-- 0.0 unx 55071 b- defN 81-Jan-01 01:01 assets/public/chunk-6GJV2O5S.js │ -rw-r--r-- 0.0 unx 403411 b- defN 81-Jan-01 01:01 assets/public/chunk-6GJV2O5S.js.map │ --rw-r--r-- 0.0 unx 1099 b- defN 81-Jan-01 01:01 assets/public/chunk-6YS2XM2X.js │ --rw-r--r-- 0.0 unx 93 b- defN 81-Jan-01 01:01 assets/public/chunk-6YS2XM2X.js.map │ -rw-r--r-- 0.0 unx 1143140 b- defN 81-Jan-01 01:01 assets/public/chunk-7MUS6TGI.js │ -rw-r--r-- 0.0 unx 5011803 b- defN 81-Jan-01 01:01 assets/public/chunk-7MUS6TGI.js.map │ -rw-r--r-- 0.0 unx 288581 b- defN 81-Jan-01 01:01 assets/public/chunk-7WVOLTF5.js │ -rw-r--r-- 0.0 unx 1089405 b- defN 81-Jan-01 01:01 assets/public/chunk-7WVOLTF5.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 │ @@ -178,44 +180,42 @@ │ -rw-r--r-- 0.0 unx 21304 b- defN 81-Jan-01 01:01 assets/public/chunk-AHTHF7YH.js.map │ -rw-r--r-- 0.0 unx 3415 b- defN 81-Jan-01 01:01 assets/public/chunk-ARMD7SBG.js │ -rw-r--r-- 0.0 unx 16186 b- defN 81-Jan-01 01:01 assets/public/chunk-ARMD7SBG.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-BPBACDO4.js │ -rw-r--r-- 0.0 unx 949 b- defN 81-Jan-01 01:01 assets/public/chunk-BPBACDO4.js.map │ --rw-r--r-- 0.0 unx 65047 b- defN 81-Jan-01 01:01 assets/public/chunk-BV4AT7XT.js │ --rw-r--r-- 0.0 unx 164867 b- defN 81-Jan-01 01:01 assets/public/chunk-BV4AT7XT.js.map │ -rw-r--r-- 0.0 unx 3962 b- defN 81-Jan-01 01:01 assets/public/chunk-BYEHZBJ4.js │ -rw-r--r-- 0.0 unx 13802 b- defN 81-Jan-01 01:01 assets/public/chunk-BYEHZBJ4.js.map │ -rw-r--r-- 0.0 unx 23637 b- defN 81-Jan-01 01:01 assets/public/chunk-CU2KLGF3.js │ -rw-r--r-- 0.0 unx 41275 b- defN 81-Jan-01 01:01 assets/public/chunk-CU2KLGF3.js.map │ -rw-r--r-- 0.0 unx 5627 b- defN 81-Jan-01 01:01 assets/public/chunk-DDWJ4CHR.js │ -rw-r--r-- 0.0 unx 20575 b- defN 81-Jan-01 01:01 assets/public/chunk-DDWJ4CHR.js.map │ -rw-r--r-- 0.0 unx 1162 b- defN 81-Jan-01 01:01 assets/public/chunk-DML37YFT.js │ -rw-r--r-- 0.0 unx 2945 b- defN 81-Jan-01 01:01 assets/public/chunk-DML37YFT.js.map │ -rw-r--r-- 0.0 unx 3648 b- defN 81-Jan-01 01:01 assets/public/chunk-DQJP63QP.js │ -rw-r--r-- 0.0 unx 11641 b- defN 81-Jan-01 01:01 assets/public/chunk-DQJP63QP.js.map │ --rw-r--r-- 0.0 unx 121387 b- defN 81-Jan-01 01:01 assets/public/chunk-DRZXYCK7.js │ --rw-r--r-- 0.0 unx 183450 b- defN 81-Jan-01 01:01 assets/public/chunk-DRZXYCK7.js.map │ -rw-r--r-- 0.0 unx 35727 b- defN 81-Jan-01 01:01 assets/public/chunk-DXYAAW36.js │ -rw-r--r-- 0.0 unx 149379 b- defN 81-Jan-01 01:01 assets/public/chunk-DXYAAW36.js.map │ -rw-r--r-- 0.0 unx 58446 b- defN 81-Jan-01 01:01 assets/public/chunk-EQS2GCSI.js │ -rw-r--r-- 0.0 unx 260466 b- defN 81-Jan-01 01:01 assets/public/chunk-EQS2GCSI.js.map │ -rw-r--r-- 0.0 unx 729 b- defN 81-Jan-01 01:01 assets/public/chunk-F72Y3JGR.js │ -rw-r--r-- 0.0 unx 2317 b- defN 81-Jan-01 01:01 assets/public/chunk-F72Y3JGR.js.map │ -rw-r--r-- 0.0 unx 2337 b- defN 81-Jan-01 01:01 assets/public/chunk-GA52WCJ3.js │ -rw-r--r-- 0.0 unx 4992 b- defN 81-Jan-01 01:01 assets/public/chunk-GA52WCJ3.js.map │ -rw-r--r-- 0.0 unx 2001 b- defN 81-Jan-01 01:01 assets/public/chunk-GBUDZ7F6.js │ -rw-r--r-- 0.0 unx 3277 b- defN 81-Jan-01 01:01 assets/public/chunk-GBUDZ7F6.js.map │ --rw-r--r-- 0.0 unx 307404 b- defN 81-Jan-01 01:01 assets/public/chunk-GLK464BM.js │ --rw-r--r-- 0.0 unx 982155 b- defN 81-Jan-01 01:01 assets/public/chunk-GLK464BM.js.map │ -rw-r--r-- 0.0 unx 411 b- defN 81-Jan-01 01:01 assets/public/chunk-GMHRIRJF.js │ -rw-r--r-- 0.0 unx 938 b- defN 81-Jan-01 01:01 assets/public/chunk-GMHRIRJF.js.map │ +-rw-r--r-- 0.0 unx 65047 b- defN 81-Jan-01 01:01 assets/public/chunk-GQBD5ET4.js │ +-rw-r--r-- 0.0 unx 164867 b- defN 81-Jan-01 01:01 assets/public/chunk-GQBD5ET4.js.map │ -rw-r--r-- 0.0 unx 2173 b- defN 81-Jan-01 01:01 assets/public/chunk-GVXWKB3V.js │ -rw-r--r-- 0.0 unx 8779 b- defN 81-Jan-01 01:01 assets/public/chunk-GVXWKB3V.js.map │ +-rw-r--r-- 0.0 unx 60010 b- defN 81-Jan-01 01:01 assets/public/chunk-HGBYEZ3P.js │ +-rw-r--r-- 0.0 unx 171888 b- defN 81-Jan-01 01:01 assets/public/chunk-HGBYEZ3P.js.map │ -rw-r--r-- 0.0 unx 33021 b- defN 81-Jan-01 01:01 assets/public/chunk-HHS3UL2X.js │ -rw-r--r-- 0.0 unx 112433 b- defN 81-Jan-01 01:01 assets/public/chunk-HHS3UL2X.js.map │ -rw-r--r-- 0.0 unx 3538 b- defN 81-Jan-01 01:01 assets/public/chunk-HIFXKWVD.js │ -rw-r--r-- 0.0 unx 10230 b- defN 81-Jan-01 01:01 assets/public/chunk-HIFXKWVD.js.map │ -rw-r--r-- 0.0 unx 4447 b- defN 81-Jan-01 01:01 assets/public/chunk-HV2FSRRA.js │ -rw-r--r-- 0.0 unx 6897 b- defN 81-Jan-01 01:01 assets/public/chunk-HV2FSRRA.js.map │ -rw-r--r-- 0.0 unx 212254 b- defN 81-Jan-01 01:01 assets/public/chunk-IA3UJFNX.js │ @@ -234,28 +234,30 @@ │ -rw-r--r-- 0.0 unx 4788 b- defN 81-Jan-01 01:01 assets/public/chunk-K7IO7EFT.js.map │ -rw-r--r-- 0.0 unx 24217 b- defN 81-Jan-01 01:01 assets/public/chunk-KVZXBMSZ.js │ -rw-r--r-- 0.0 unx 97875 b- defN 81-Jan-01 01:01 assets/public/chunk-KVZXBMSZ.js.map │ -rw-r--r-- 0.0 unx 16007 b- defN 81-Jan-01 01:01 assets/public/chunk-LVYP6C7Q.js │ -rw-r--r-- 0.0 unx 30930 b- defN 81-Jan-01 01:01 assets/public/chunk-LVYP6C7Q.js.map │ -rw-r--r-- 0.0 unx 291 b- defN 81-Jan-01 01:01 assets/public/chunk-MASHVMAF.js │ -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 30026 b- defN 81-Jan-01 01:01 assets/public/chunk-MG45FVR3.js │ +-rw-r--r-- 0.0 unx 109138 b- defN 81-Jan-01 01:01 assets/public/chunk-MG45FVR3.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 2699 b- defN 81-Jan-01 01:01 assets/public/chunk-MTS2G7QO.js │ -rw-r--r-- 0.0 unx 11365 b- defN 81-Jan-01 01:01 assets/public/chunk-MTS2G7QO.js.map │ --rw-r--r-- 0.0 unx 30026 b- defN 81-Jan-01 01:01 assets/public/chunk-MWP7PIHW.js │ --rw-r--r-- 0.0 unx 109138 b- defN 81-Jan-01 01:01 assets/public/chunk-MWP7PIHW.js.map │ -rw-r--r-- 0.0 unx 43128 b- defN 81-Jan-01 01:01 assets/public/chunk-MYRZ2UB7.js │ -rw-r--r-- 0.0 unx 158051 b- defN 81-Jan-01 01:01 assets/public/chunk-MYRZ2UB7.js.map │ --rw-r--r-- 0.0 unx 3098 b- defN 81-Jan-01 01:01 assets/public/chunk-N7XAWOJQ.js │ --rw-r--r-- 0.0 unx 9576 b- defN 81-Jan-01 01:01 assets/public/chunk-N7XAWOJQ.js.map │ -rw-r--r-- 0.0 unx 1139 b- defN 81-Jan-01 01:01 assets/public/chunk-ND36FQSY.js │ -rw-r--r-- 0.0 unx 2013 b- defN 81-Jan-01 01:01 assets/public/chunk-ND36FQSY.js.map │ +-rw-r--r-- 0.0 unx 66829 b- defN 81-Jan-01 01:01 assets/public/chunk-NE6ZQYIQ.js │ +-rw-r--r-- 0.0 unx 263769 b- defN 81-Jan-01 01:01 assets/public/chunk-NE6ZQYIQ.js.map │ -rw-r--r-- 0.0 unx 88456 b- defN 81-Jan-01 01:01 assets/public/chunk-NNZXV35Q.js │ -rw-r--r-- 0.0 unx 260174 b- defN 81-Jan-01 01:01 assets/public/chunk-NNZXV35Q.js.map │ +-rw-r--r-- 0.0 unx 121387 b- defN 81-Jan-01 01:01 assets/public/chunk-NQOAW23X.js │ +-rw-r--r-- 0.0 unx 183450 b- defN 81-Jan-01 01:01 assets/public/chunk-NQOAW23X.js.map │ -rw-r--r-- 0.0 unx 31579 b- defN 81-Jan-01 01:01 assets/public/chunk-NYJ6WMSJ.js │ -rw-r--r-- 0.0 unx 84113 b- defN 81-Jan-01 01:01 assets/public/chunk-NYJ6WMSJ.js.map │ -rw-r--r-- 0.0 unx 9256 b- defN 81-Jan-01 01:01 assets/public/chunk-O66WK4QV.js │ -rw-r--r-- 0.0 unx 39639 b- defN 81-Jan-01 01:01 assets/public/chunk-O66WK4QV.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 │ @@ -278,26 +280,28 @@ │ -rw-r--r-- 0.0 unx 14186 b- defN 81-Jan-01 01:01 assets/public/chunk-QUNJYTX5.js.map │ -rw-r--r-- 0.0 unx 10450 b- defN 81-Jan-01 01:01 assets/public/chunk-RAYMZOZ2.js │ -rw-r--r-- 0.0 unx 29209 b- defN 81-Jan-01 01:01 assets/public/chunk-RAYMZOZ2.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 18901 b- defN 81-Jan-01 01:01 assets/public/chunk-RPBIE5C7.js │ -rw-r--r-- 0.0 unx 72134 b- defN 81-Jan-01 01:01 assets/public/chunk-RPBIE5C7.js.map │ +-rw-r--r-- 0.0 unx 3098 b- defN 81-Jan-01 01:01 assets/public/chunk-SN3MQOUX.js │ +-rw-r--r-- 0.0 unx 9576 b- defN 81-Jan-01 01:01 assets/public/chunk-SN3MQOUX.js.map │ -rw-r--r-- 0.0 unx 42689 b- defN 81-Jan-01 01:01 assets/public/chunk-SOJAORWW.js │ -rw-r--r-- 0.0 unx 170408 b- defN 81-Jan-01 01:01 assets/public/chunk-SOJAORWW.js.map │ -rw-r--r-- 0.0 unx 602 b- defN 81-Jan-01 01:01 assets/public/chunk-ST3KQVF4.js │ -rw-r--r-- 0.0 unx 2080 b- defN 81-Jan-01 01:01 assets/public/chunk-ST3KQVF4.js.map │ +-rw-r--r-- 0.0 unx 1017 b- defN 81-Jan-01 01:01 assets/public/chunk-SZ5PK2ML.js │ +-rw-r--r-- 0.0 unx 93 b- defN 81-Jan-01 01:01 assets/public/chunk-SZ5PK2ML.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 15134 b- defN 81-Jan-01 01:01 assets/public/chunk-UMOZ4H6K.js │ -rw-r--r-- 0.0 unx 37882 b- defN 81-Jan-01 01:01 assets/public/chunk-UMOZ4H6K.js.map │ -rw-r--r-- 0.0 unx 2086 b- defN 81-Jan-01 01:01 assets/public/chunk-UNMRK3W7.js │ -rw-r--r-- 0.0 unx 6640 b- defN 81-Jan-01 01:01 assets/public/chunk-UNMRK3W7.js.map │ --rw-r--r-- 0.0 unx 60010 b- defN 81-Jan-01 01:01 assets/public/chunk-UOINLFDQ.js │ --rw-r--r-- 0.0 unx 171888 b- defN 81-Jan-01 01:01 assets/public/chunk-UOINLFDQ.js.map │ -rw-r--r-- 0.0 unx 22325 b- defN 81-Jan-01 01:01 assets/public/chunk-USJLDBUR.js │ -rw-r--r-- 0.0 unx 54165 b- defN 81-Jan-01 01:01 assets/public/chunk-USJLDBUR.js.map │ -rw-r--r-- 0.0 unx 29745 b- defN 81-Jan-01 01:01 assets/public/chunk-UYZLPEHT.js │ -rw-r--r-- 0.0 unx 82049 b- defN 81-Jan-01 01:01 assets/public/chunk-UYZLPEHT.js.map │ -rw-r--r-- 0.0 unx 76947 b- defN 81-Jan-01 01:01 assets/public/chunk-UZ6PFR4N.js │ -rw-r--r-- 0.0 unx 182973 b- defN 81-Jan-01 01:01 assets/public/chunk-UZ6PFR4N.js.map │ -rw-r--r-- 0.0 unx 903 b- defN 81-Jan-01 01:01 assets/public/chunk-VALZJMB4.js │ @@ -326,20 +330,16 @@ │ -rw-r--r-- 0.0 unx 18636 b- defN 81-Jan-01 01:01 assets/public/chunk-XATCGJCU.js.map │ -rw-r--r-- 0.0 unx 770 b- defN 81-Jan-01 01:01 assets/public/chunk-XU2E3I7U.js │ -rw-r--r-- 0.0 unx 2780 b- defN 81-Jan-01 01:01 assets/public/chunk-XU2E3I7U.js.map │ -rw-r--r-- 0.0 unx 4348 b- defN 81-Jan-01 01:01 assets/public/chunk-XWBZMDDQ.js │ -rw-r--r-- 0.0 unx 12382 b- defN 81-Jan-01 01:01 assets/public/chunk-XWBZMDDQ.js.map │ -rw-r--r-- 0.0 unx 10511 b- defN 81-Jan-01 01:01 assets/public/chunk-Y3KFKWZW.js │ -rw-r--r-- 0.0 unx 15310 b- defN 81-Jan-01 01:01 assets/public/chunk-Y3KFKWZW.js.map │ --rw-r--r-- 0.0 unx 66829 b- defN 81-Jan-01 01:01 assets/public/chunk-Y5JLO2N2.js │ --rw-r--r-- 0.0 unx 263769 b- defN 81-Jan-01 01:01 assets/public/chunk-Y5JLO2N2.js.map │ --rw-r--r-- 0.0 unx 1017 b- defN 81-Jan-01 01:01 assets/public/chunk-Y5QHOD6A.js │ --rw-r--r-- 0.0 unx 93 b- defN 81-Jan-01 01:01 assets/public/chunk-Y5QHOD6A.js.map │ --rw-r--r-- 0.0 unx 11454 b- defN 81-Jan-01 01:01 assets/public/chunk-YSZPGIR3.js │ --rw-r--r-- 0.0 unx 22568 b- defN 81-Jan-01 01:01 assets/public/chunk-YSZPGIR3.js.map │ +-rw-r--r-- 0.0 unx 1099 b- defN 81-Jan-01 01:01 assets/public/chunk-YUXD5HP3.js │ +-rw-r--r-- 0.0 unx 93 b- defN 81-Jan-01 01:01 assets/public/chunk-YUXD5HP3.js.map │ -rw-r--r-- 0.0 unx 120352 b- defN 81-Jan-01 01:01 assets/public/chunk-Z4CB7MDJ.js │ -rw-r--r-- 0.0 unx 455554 b- defN 81-Jan-01 01:01 assets/public/chunk-Z4CB7MDJ.js.map │ -rw-r--r-- 0.0 unx 1344 b- defN 81-Jan-01 01:01 assets/public/collapsible.component-CBYP37WQ.css.map │ -rw-r--r-- 0.0 unx 1638 b- defN 81-Jan-01 01:01 assets/public/config-form.component-FM6QXSE2.css.map │ -rw-r--r-- 0.0 unx 3405 b- defN 81-Jan-01 01:01 assets/public/config-page.component-QIQF5R3W.css.map │ -rw-r--r-- 0.0 unx 3342 b- defN 81-Jan-01 01:01 assets/public/config-section.component-Q36LTOMV.css.map │ -rw-r--r-- 0.0 unx 1343 b- defN 81-Jan-01 01:01 assets/public/config-sound-form.component-SGP4LNG3.css.map │ @@ -421,16 +421,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 891 b- defN 81-Jan-01 01:01 assets/public/lazy-chart.component-S7BZ22QP.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 815760 b- defN 81-Jan-01 01:01 assets/public/main-RUYWC6Y7.js │ --rw-r--r-- 0.0 unx 2811830 b- defN 81-Jan-01 01:01 assets/public/main-RUYWC6Y7.js.map │ +-rw-r--r-- 0.0 unx 815760 b- defN 81-Jan-01 01:01 assets/public/main-ZCHNZPZH.js │ +-rw-r--r-- 0.0 unx 2811830 b- defN 81-Jan-01 01:01 assets/public/main-ZCHNZPZH.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 │ @@ -1362,8 +1362,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 139458 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 139331 b- defN 81-Jan-01 01:01 META-INF/MANIFEST.MF │ -1367 files, 43240815 bytes uncompressed, 14890148 bytes compressed: 65.6% │ +1367 files, 43240815 bytes uncompressed, 14890141 bytes compressed: 65.6% ├── assets/public/ngsw.json │ ├── Pretty-printed │ │┄ Similarity: 0.9312037756736387% │ │┄ Differences: {"'assetGroups'": "{0: {'urls': {insert: [(6, '/chunk-3FBG5TIB.js'), (8, '/chunk-3ISLZ73Y.js'), " │ │┄ "(38, '/chunk-GQBD5ET4.js'), (40, '/chunk-HGBYEZ3P.js'), (54, " │ │┄ "'/chunk-MG45FVR3.js'), (59, '/chunk-NE6ZQYIQ.js'), (61, '/chunk-NQOAW23X.js'), " │ │┄ "(77, '/chunk-SN3MQOUX.js'), (80, '/chunk-SZ5PK2ML.js'), (102, " │ │┄ "'/chunk-YUXD5HP3.js'), (106, '/main-ZCHNZPZH.js')], delete: [106, 102, 101, " │ │┄ '100, 81, 58, 56, 38, 32, 26, 17]} […] │ │ @@ -11,69 +11,70 @@ │ │ "urls": [ │ │ "/chunk-2FG4XLJJ.js", │ │ "/chunk-2NYJ54WT.js", │ │ "/chunk-2Q6UTZAM.js", │ │ "/chunk-363GNZ4I.js", │ │ "/chunk-37YHURHI.js", │ │ "/chunk-3E43H4SH.js", │ │ + "/chunk-3FBG5TIB.js", │ │ "/chunk-3FZSARDD.js", │ │ + "/chunk-3ISLZ73Y.js", │ │ "/chunk-3UB54IM4.js", │ │ "/chunk-4HVTW7Z2.js", │ │ "/chunk-4PDR4WZL.js", │ │ "/chunk-4WKVJOAH.js", │ │ "/chunk-54T2PZS2.js", │ │ "/chunk-5BEPRP7V.js", │ │ "/chunk-5BKCBYJJ.js", │ │ "/chunk-5J3KQ7C3.js", │ │ "/chunk-5TOMTPKS.js", │ │ "/chunk-6GJV2O5S.js", │ │ - "/chunk-6YS2XM2X.js", │ │ "/chunk-7MUS6TGI.js", │ │ "/chunk-7WVOLTF5.js", │ │ "/chunk-A5MBRGPF.js", │ │ "/chunk-A6QD6H33.js", │ │ "/chunk-AHTHF7YH.js", │ │ "/chunk-ARMD7SBG.js", │ │ "/chunk-BOROUNNF.js", │ │ "/chunk-BPBACDO4.js", │ │ - "/chunk-BV4AT7XT.js", │ │ "/chunk-BYEHZBJ4.js", │ │ "/chunk-CU2KLGF3.js", │ │ "/chunk-DDWJ4CHR.js", │ │ "/chunk-DML37YFT.js", │ │ "/chunk-DQJP63QP.js", │ │ - "/chunk-DRZXYCK7.js", │ │ "/chunk-DXYAAW36.js", │ │ "/chunk-EQS2GCSI.js", │ │ "/chunk-F72Y3JGR.js", │ │ "/chunk-GA52WCJ3.js", │ │ "/chunk-GBUDZ7F6.js", │ │ - "/chunk-GLK464BM.js", │ │ "/chunk-GMHRIRJF.js", │ │ + "/chunk-GQBD5ET4.js", │ │ "/chunk-GVXWKB3V.js", │ │ + "/chunk-HGBYEZ3P.js", │ │ "/chunk-HHS3UL2X.js", │ │ "/chunk-HIFXKWVD.js", │ │ "/chunk-HV2FSRRA.js", │ │ "/chunk-IA3UJFNX.js", │ │ "/chunk-IBUEQXYK.js", │ │ "/chunk-ISS7OXYA.js", │ │ "/chunk-IXUSB7N5.js", │ │ "/chunk-JNQEVTHV.js", │ │ "/chunk-JS63JK73.js", │ │ "/chunk-K7IO7EFT.js", │ │ "/chunk-KVZXBMSZ.js", │ │ "/chunk-LVYP6C7Q.js", │ │ "/chunk-MASHVMAF.js", │ │ + "/chunk-MG45FVR3.js", │ │ "/chunk-MKQ5S2AR.js", │ │ "/chunk-MTS2G7QO.js", │ │ - "/chunk-MWP7PIHW.js", │ │ "/chunk-MYRZ2UB7.js", │ │ - "/chunk-N7XAWOJQ.js", │ │ "/chunk-ND36FQSY.js", │ │ + "/chunk-NE6ZQYIQ.js", │ │ "/chunk-NNZXV35Q.js", │ │ + "/chunk-NQOAW23X.js", │ │ "/chunk-NYJ6WMSJ.js", │ │ "/chunk-O66WK4QV.js", │ │ "/chunk-OVAWK6DV.js", │ │ "/chunk-OXDOKNTF.js", │ │ "/chunk-P3HRPERN.js", │ │ "/chunk-PCQTKHSS.js", │ │ "/chunk-PEJGMLLQ.js", │ │ @@ -81,20 +82,21 @@ │ │ "/chunk-QADC43SF.js", │ │ "/chunk-QGLNKCRM.js", │ │ "/chunk-QQX7ZUDW.js", │ │ "/chunk-QUNJYTX5.js", │ │ "/chunk-RAYMZOZ2.js", │ │ "/chunk-RHU3AIGY.js", │ │ "/chunk-RPBIE5C7.js", │ │ + "/chunk-SN3MQOUX.js", │ │ "/chunk-SOJAORWW.js", │ │ "/chunk-ST3KQVF4.js", │ │ + "/chunk-SZ5PK2ML.js", │ │ "/chunk-U233VVFY.js", │ │ "/chunk-UMOZ4H6K.js", │ │ "/chunk-UNMRK3W7.js", │ │ - "/chunk-UOINLFDQ.js", │ │ "/chunk-USJLDBUR.js", │ │ "/chunk-UYZLPEHT.js", │ │ "/chunk-UZ6PFR4N.js", │ │ "/chunk-VALZJMB4.js", │ │ "/chunk-VKSDQHEV.js", │ │ "/chunk-VSH7WL2P.js", │ │ "/chunk-W2TGRLG6.js", │ │ @@ -105,21 +107,19 @@ │ │ "/chunk-WV4BNBNC.js", │ │ "/chunk-X4JVVUVN.js", │ │ "/chunk-X5JJYUOW.js", │ │ "/chunk-XATCGJCU.js", │ │ "/chunk-XU2E3I7U.js", │ │ "/chunk-XWBZMDDQ.js", │ │ "/chunk-Y3KFKWZW.js", │ │ - "/chunk-Y5JLO2N2.js", │ │ - "/chunk-Y5QHOD6A.js", │ │ - "/chunk-YSZPGIR3.js", │ │ + "/chunk-YUXD5HP3.js", │ │ "/chunk-Z4CB7MDJ.js", │ │ "/favicon.ico", │ │ "/index.html", │ │ - "/main-RUYWC6Y7.js", │ │ + "/main-ZCHNZPZH.js", │ │ "/manifest.json", │ │ "/polyfills-D4CWKFPZ.js", │ │ "/styles-6SQYOQ3R.css", │ │ "/worker-VLSMHDI7.js" │ │ ] │ │ }, │ │ { │ │ @@ -398,69 +398,70 @@ │ │ "/assets/unicorn.png": "0326afe4a8f85faa5c3a01fd38efeafeb58094a2", │ │ "/chunk-2FG4XLJJ.js": "5067cba295176d5508838d2f74f807e125e94fbf", │ │ "/chunk-2NYJ54WT.js": "6b2058100c2940dca4d746dd3f5d18ab6c115902", │ │ "/chunk-2Q6UTZAM.js": "f0a9ec6f23a70da7e4a96c2b190fbb1341395ced", │ │ "/chunk-363GNZ4I.js": "7f709ccff33fc0f494b4b077065e3ace3b4c0814", │ │ "/chunk-37YHURHI.js": "6d128def345069ea95a2104670dab4826fda6545", │ │ "/chunk-3E43H4SH.js": "33caa87bbac6b8a44c021550f0bba30292886b0d", │ │ + "/chunk-3FBG5TIB.js": "5cca26bf51f8e2a622661301f0f5a3e0c3a0f887", │ │ "/chunk-3FZSARDD.js": "dfb94522a82a37bfd9e0cd4e34139a57f3eba33e", │ │ + "/chunk-3ISLZ73Y.js": "8460aa391564cedc5f7ad25efc8de8ccea2372d4", │ │ "/chunk-3UB54IM4.js": "6dd0205087c3166a305b1af5ec8ad771cd5ce0e3", │ │ "/chunk-4HVTW7Z2.js": "a8f170c989b293f1f4f7e2cdba3e1654bbdb4026", │ │ "/chunk-4PDR4WZL.js": "6b1c26edb00ecdbac074ddc8892403e1367159f9", │ │ "/chunk-4WKVJOAH.js": "755c38ce168a294972eb8d09e0b4d2ee35e45efa", │ │ "/chunk-54T2PZS2.js": "be29bd377e31c313a391565e4838258155bfb517", │ │ "/chunk-5BEPRP7V.js": "4591c74568429d2a20d4c37577a992024d6843de", │ │ "/chunk-5BKCBYJJ.js": "037f884284ee545bc89cdda9297a7cfeeacb5208", │ │ "/chunk-5J3KQ7C3.js": "5806b6f4705bdce24825baa40f8827b789820869", │ │ "/chunk-5TOMTPKS.js": "0bec56381d40b29d658cab0ad98c2b781fb0002d", │ │ "/chunk-6GJV2O5S.js": "d1f2067222b45f637c71928cba3d5139b9e60405", │ │ - "/chunk-6YS2XM2X.js": "fbe13502d784d3110adc878eb855b6e075367686", │ │ "/chunk-7MUS6TGI.js": "6c25ca93c279ccdf40249e8dc8fa9ef9ee22dd3a", │ │ "/chunk-7WVOLTF5.js": "c9a423b69d3d57ec6cf1825952bfbac2c71d51cc", │ │ "/chunk-A5MBRGPF.js": "1370eaa81f6ec887d8231e675fe4147619b78acd", │ │ "/chunk-A6QD6H33.js": "ec517b8d910ffcac343b58e04d3dbc538e2fd731", │ │ "/chunk-AHTHF7YH.js": "390105bdef52a4291102068b092e0b368dc1511b", │ │ "/chunk-ARMD7SBG.js": "f17b095d0a10d600a1e270c98865866de436ff4a", │ │ "/chunk-BOROUNNF.js": "459f904bd4a5c44bc789798d548ad8a666e2f15c", │ │ "/chunk-BPBACDO4.js": "7bd408767ab40146e3b5e1f228f3212a121283bc", │ │ - "/chunk-BV4AT7XT.js": "82997f0fc2ab196491db76d626abd86b84f97b40", │ │ "/chunk-BYEHZBJ4.js": "29b738febbc6dd5e4d179b029ec835a52d70e5ba", │ │ "/chunk-CU2KLGF3.js": "97f26cc5dc2d9bb02ddcb2c0e23a2281ec8c5464", │ │ "/chunk-DDWJ4CHR.js": "bec2e3f1badfd8cccf388bc6d23d243e308ead1f", │ │ "/chunk-DML37YFT.js": "b68ef2ddc963b2e6a5074cd26ad4571b25df2808", │ │ "/chunk-DQJP63QP.js": "4fdb64ab51766bf993e81bbae063a812057a26f1", │ │ - "/chunk-DRZXYCK7.js": "fefeddbc0b0f684021198d175781aca49c8ef3ae", │ │ "/chunk-DXYAAW36.js": "a12a4a0fd60a56833f5c34a508f914fef991288e", │ │ "/chunk-EQS2GCSI.js": "2ac1165f338d8d4cd2087a147c6910dfb6b142d2", │ │ "/chunk-F72Y3JGR.js": "95463e1c79c110a7a8633cfbc59c3e766504f00c", │ │ "/chunk-GA52WCJ3.js": "7bab09da330fa05f5deddb168635ab76666c130d", │ │ "/chunk-GBUDZ7F6.js": "4be2b7f1cec1b7fcbb980ad9c92fe52b96888dd6", │ │ - "/chunk-GLK464BM.js": "18d2998a0a2c120f9f40edf25c502167c8e6f02c", │ │ "/chunk-GMHRIRJF.js": "759ca85750c2aecebbfb34b9f0fc1ca7710ad74d", │ │ + "/chunk-GQBD5ET4.js": "5eeff927b306a78512eed4c40fa81744371836d9", │ │ "/chunk-GVXWKB3V.js": "a152233e73a9dac95190362e4841ac70c1332fab", │ │ + "/chunk-HGBYEZ3P.js": "16108ebcbf3d9b4cdc92f0cafd5fc02e6784bc9d", │ │ "/chunk-HHS3UL2X.js": "9605ebb443ce3a1b8b35e13afa6c3b6dbde8a4ab", │ │ "/chunk-HIFXKWVD.js": "40a7960b8776d80635a704e4fdacf185da30270b", │ │ "/chunk-HV2FSRRA.js": "6cc27a2838cabeaa1c2c8629650a4ff15e315f16", │ │ "/chunk-IA3UJFNX.js": "45797f3e5a1e393485f669794b8a00460d80ca14", │ │ "/chunk-IBUEQXYK.js": "34eb1505792edee15c755c40da2113f8d350e0c3", │ │ "/chunk-ISS7OXYA.js": "12445d1bd8ffed3dcbf70c9b6dc3bf550913a3a0", │ │ "/chunk-IXUSB7N5.js": "ae1152abccf791f2264438d87dc8b1ae3a13860e", │ │ "/chunk-JNQEVTHV.js": "509ff9899b35f2d1d47c495628dfb307846465d6", │ │ "/chunk-JS63JK73.js": "7bfabc31df89999e57d49661a5a80f62d0d7722b", │ │ "/chunk-K7IO7EFT.js": "31bd058bd5967fd8673c77a8d1c864667775fdb9", │ │ "/chunk-KVZXBMSZ.js": "417063860516b7f9b9418765e9248f4b7381eead", │ │ "/chunk-LVYP6C7Q.js": "2e5bf1916994380ab46db57ce7aeecb86db98d43", │ │ "/chunk-MASHVMAF.js": "c3e060e28a228fc25d8d7a1a90983cfc33f80afa", │ │ + "/chunk-MG45FVR3.js": "75df617ef5b0b67c971fdbdb39af24f34b4b8d4b", │ │ "/chunk-MKQ5S2AR.js": "9368b54b4f102d5c8000a30747eda3da95a162a5", │ │ "/chunk-MTS2G7QO.js": "253349619b497962b3d03432d3b35dc7abb69db3", │ │ - "/chunk-MWP7PIHW.js": "8d6ce943bde28ee256cd110d423792ee0a77fb60", │ │ "/chunk-MYRZ2UB7.js": "51d6bec7d959f950040f02d3cb7f2df911dd24ed", │ │ - "/chunk-N7XAWOJQ.js": "e29a05ddecc97fdda7de8317bc033b214bf332b0", │ │ "/chunk-ND36FQSY.js": "1799a516e7f750e332f93a46bc6dc94eed16eaba", │ │ + "/chunk-NE6ZQYIQ.js": "eb704b53bf7d1f14a0435716fbf35730eb0953f0", │ │ "/chunk-NNZXV35Q.js": "e71dd0504b4fe9b0d639d7ded547681064d31fb2", │ │ + "/chunk-NQOAW23X.js": "6573d92d825013a7a70d349e589253887da151d2", │ │ "/chunk-NYJ6WMSJ.js": "6e7feb5fe40c3ea4c8aef20b13ab3550cde64e33", │ │ "/chunk-O66WK4QV.js": "ef6ea66dbdfb844667ea87ae12386c253ece0f1a", │ │ "/chunk-OVAWK6DV.js": "4361aa6648b214c9f6cc6a5bc622280f547db7f0", │ │ "/chunk-OXDOKNTF.js": "501996a33f7f3e92729fcabc7c0b3cad82f22134", │ │ "/chunk-P3HRPERN.js": "47b2abb83a74ee663c76c7682f1ded404f35760b", │ │ "/chunk-PCQTKHSS.js": "c8f386cd85cb3ac4b0467e1fc89f97148b590d12", │ │ "/chunk-PEJGMLLQ.js": "fe6775dde0b3e793079d9c7be74b708dd45a79ea", │ │ @@ -468,20 +469,21 @@ │ │ "/chunk-QADC43SF.js": "259e396e19ac0eb95b135c7c207ad54feb2d479c", │ │ "/chunk-QGLNKCRM.js": "ccba581de1192dd86b57f45ec4f8245490037a33", │ │ "/chunk-QQX7ZUDW.js": "6a8ba678c02447c73e0d3e26fc1fce51fdc2e107", │ │ "/chunk-QUNJYTX5.js": "ee59f5c10080d50632508ae4e7121f710f338d98", │ │ "/chunk-RAYMZOZ2.js": "d8313b0e5aaaff72f3cb77f6509debcec84902fa", │ │ "/chunk-RHU3AIGY.js": "70f3005532610e087402505fa642745a0759fb44", │ │ "/chunk-RPBIE5C7.js": "a40101d86f7fed3885a730b43896e4429e586c4a", │ │ + "/chunk-SN3MQOUX.js": "fec815448a51399d10324661b457ef0472532a60", │ │ "/chunk-SOJAORWW.js": "c4ddbb4e8605b301ad6c9ed0bb6595e679b3184c", │ │ "/chunk-ST3KQVF4.js": "f6e15a5853502b0c3ab60474cb2c7ccc153c5300", │ │ + "/chunk-SZ5PK2ML.js": "a67b2c2e3b8b602daeecbb3f6953a0510c6be20e", │ │ "/chunk-U233VVFY.js": "51f1f8a1d3f2ed2951838a10456ad42172522001", │ │ "/chunk-UMOZ4H6K.js": "35aa340ef07f8b2960879a7eb61c74b2f0cf063f", │ │ "/chunk-UNMRK3W7.js": "fb89e1c4bc47c356787e6b1d2013cc603405db97", │ │ - "/chunk-UOINLFDQ.js": "6bc0f6e536c76bb39af2dd08e8837ffdd2b1e279", │ │ "/chunk-USJLDBUR.js": "c47189eaf547ebfa5833a1cdec2c63d676d1bc8c", │ │ "/chunk-UYZLPEHT.js": "f70e7c228ca33b908fb60b00159efe0cd2cce889", │ │ "/chunk-UZ6PFR4N.js": "1f9ae9ed065ed604fd2b2babcac06a07ae0548ab", │ │ "/chunk-VALZJMB4.js": "3178219d2e9a366851c6f9c278783f9c5628bdc6", │ │ "/chunk-VKSDQHEV.js": "e8458c2958b94a55db96d700499165bb20a382f1", │ │ "/chunk-VSH7WL2P.js": "f7e887ac5b3e0e852dc4b1a20414db894161b927", │ │ "/chunk-W2TGRLG6.js": "a990bb3073f020bc1dec4a57643ff12864683b97", │ │ @@ -492,21 +494,19 @@ │ │ "/chunk-WV4BNBNC.js": "5f219ced53acbcb88e28ea956a8a2d0c3b14a656", │ │ "/chunk-X4JVVUVN.js": "51e9fc9559b2fd0512ec57c4cb4f6f80dfc9617f", │ │ "/chunk-X5JJYUOW.js": "9751f8f05a97575c47a4822a2523394bc2843129", │ │ "/chunk-XATCGJCU.js": "5aaee44bdcc293ec2bc8e96e194a29b688f0ef23", │ │ "/chunk-XU2E3I7U.js": "42be333379abd934534b707aa2e0824a038af868", │ │ "/chunk-XWBZMDDQ.js": "4a3c9625aa8256f0770014b556f70ff3224b21d3", │ │ "/chunk-Y3KFKWZW.js": "969723eb03c8e108ed92be078e9903c5371e25e9", │ │ - "/chunk-Y5JLO2N2.js": "e8885d62b78a0c6f6d9c2a1b3c89b622bd3be3e6", │ │ - "/chunk-Y5QHOD6A.js": "d2d51dfae72ca1f5e2984dbba8f5a060a5ff1a4f", │ │ - "/chunk-YSZPGIR3.js": "c52c5a8f3d162fe02a784b5e91cf95611cf49cb3", │ │ + "/chunk-YUXD5HP3.js": "5781dc3d81c7a4b7cb2c2ff47649bf922cc89ce5", │ │ "/chunk-Z4CB7MDJ.js": "743eeffe696922e0b4d42d739bd9464ec22d4745", │ │ "/favicon.ico": "041b337586bb0e48da6f4fdfc846ef3594373009", │ │ - "/index.html": "2ac84b4d73912baedc8b09f8c17164393eaf3f2c", │ │ - "/main-RUYWC6Y7.js": "d0e22e28bcdf16f1ce5f220e6bce90fdb72253ae", │ │ + "/index.html": "0d5e4931cb620b104cfb1e1958f6969343b6d9f8", │ │ + "/main-ZCHNZPZH.js": "4a54192d21c5e42cd3271062fb10e66ebf599465", │ │ "/manifest.json": "94d39d23fcd194a0c89eb3bcd838730cec7cabee", │ │ "/polyfills-D4CWKFPZ.js": "be63e19dcbf7539a31849701283857d1ebe28b56", │ │ "/styles-6SQYOQ3R.css": "678082a44ddaa9aeea72ed66c39bf8d6c3bfbbbe", │ │ "/worker-VLSMHDI7.js": "b4739af47989aa734305de529322a6d914a64166" │ │ }, │ │ "index": "/index.html", │ │ "navigationRequestStrategy": "performance", │ │ @@ -524,9 +524,9 @@ │ │ "regex": "^\\/(?:.+\\/)?[^/]*__[^/]*$" │ │ }, │ │ { │ │ "positive": false, │ │ "regex": "^\\/(?:.+\\/)?[^/]*__[^/]*\\/.*$" │ │ } │ │ ], │ │ - "timestamp": 1761298719433 │ │ + "timestamp": 1762226572191 │ │ } ├── assets/public/index.html │ @@ -7021,46 +7021,46 @@ │ 0001b6c0: 6765 7445 6c65 6d65 6e74 4279 4964 2827 getElementById(' │ 0001b6d0: 7465 7874 2729 2e69 6e6e 6572 5465 7874 text').innerText │ 0001b6e0: 203d 2070 726f 6475 6374 6976 6974 7954 = productivityT │ 0001b6f0: 6970 735b 7261 6e64 6f6d 496e 6465 785d ips[randomIndex] │ 0001b700: 5b31 5d3b 0a20 2020 203c 2f73 6372 6970 [1];. .
  • │ 0001b8e0: 3c6c 696e 6b20 7265 6c3d 226d 6f64 756c .. │ --- assets/public/chunk-GLK464BM.js ├── +++ assets/public/chunk-3FBG5TIB.js │┄ Files 99% similar despite different names │ ├── js-beautify {} │ │ @@ -10246,8 +10246,8 @@ │ │ } │ │ return r │ │ })() │ │ }); │ │ export { │ │ be as a, Is as b, Ct as c, zm as d, Nh as e, Lh as f, Xm as g, qs as h, Hs as i, Pt as j, mr as k, mo as l, Qc as m, _t as n, Ws as o, Bn as p, Gs as q, tu as r, Bl as s, ru as t, $l as u, jl as v, ql as w, Q0 as x, ic as y, _c as z, ao as A, fc as B, so as C, kc as D, vc as E, I_ as F, cl as G, Nc as H, Lc as I, Vc as J, Bc as K, Uc as L, zc as M, jc as N, Wc as O, Gc as P, ln as Q, co as R, nd as S, od as T, ad as U, sd as V │ │ }; │ │ -//# sourceMappingURL=chunk-GLK464BM.js.map │ │ +//# sourceMappingURL=chunk-3FBG5TIB.js.map │ --- assets/public/chunk-Y5QHOD6A.js ├── +++ assets/public/chunk-SZ5PK2ML.js │┄ Files 94% similar despite different names │ ├── js-beautify {} │ │ @@ -1,12 +1,12 @@ │ │ import { │ │ s as a, │ │ t as b │ │ -} from "./chunk-DRZXYCK7.js"; │ │ -import "./chunk-GLK464BM.js"; │ │ +} from "./chunk-NQOAW23X.js"; │ │ +import "./chunk-3FBG5TIB.js"; │ │ import "./chunk-BYEHZBJ4.js"; │ │ import "./chunk-5J3KQ7C3.js"; │ │ import "./chunk-UZ6PFR4N.js"; │ │ import "./chunk-WS4Y2BQK.js"; │ │ import "./chunk-DQJP63QP.js"; │ │ import "./chunk-Z4CB7MDJ.js"; │ │ import "./chunk-2FG4XLJJ.js"; │ │ @@ -34,8 +34,8 @@ │ │ import "./chunk-OXDOKNTF.js"; │ │ import "./chunk-PEJGMLLQ.js"; │ │ import "./chunk-2NYJ54WT.js"; │ │ b(); │ │ export { │ │ a as PluginRunner │ │ }; │ │ -//# sourceMappingURL=chunk-Y5QHOD6A.js.map │ │ +//# sourceMappingURL=chunk-SZ5PK2ML.js.map │ --- assets/public/chunk-YSZPGIR3.js.map ├── +++ assets/public/chunk-3ISLZ73Y.js.map │┄ Files identical despite different names │ --- assets/public/chunk-Y5JLO2N2.js ├── +++ assets/public/chunk-NE6ZQYIQ.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-GLK464BM.js"; │ │ +} from "./chunk-3FBG5TIB.js"; │ │ import { │ │ N as pi, │ │ O as Xi │ │ } from "./chunk-Z4CB7MDJ.js"; │ │ import { │ │ a as ui, │ │ b as qi │ │ @@ -2563,8 +2563,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-Y5JLO2N2.js.map │ │ +//# sourceMappingURL=chunk-NE6ZQYIQ.js.map │ --- assets/public/chunk-Y5JLO2N2.js.map ├── +++ assets/public/chunk-NE6ZQYIQ.js.map │┄ Files identical despite different names │ --- assets/public/chunk-YSZPGIR3.js ├── +++ assets/public/chunk-3ISLZ73Y.js │┄ Files 98% similar despite different names │ ├── js-beautify {} │ │ @@ -1,11 +1,11 @@ │ │ import { │ │ f as ie, │ │ g as we │ │ -} from "./chunk-MWP7PIHW.js"; │ │ +} from "./chunk-MG45FVR3.js"; │ │ import { │ │ a as re, │ │ b as oe, │ │ c as ae, │ │ f as le, │ │ g as Oe │ │ } from "./chunk-WFJJ2WJN.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-DRZXYCK7.js"; │ │ +} from "./chunk-NQOAW23X.js"; │ │ import { │ │ a as Y, │ │ c as xe │ │ } from "./chunk-AHTHF7YH.js"; │ │ import { │ │ c as W, │ │ d as N, │ │ @@ -319,8 +319,8 @@ │ │ } │ │ return t │ │ })() │ │ }); │ │ export { │ │ rt as a, De as b │ │ }; │ │ -//# sourceMappingURL=chunk-YSZPGIR3.js.map │ │ +//# sourceMappingURL=chunk-3ISLZ73Y.js.map │ --- assets/public/main-RUYWC6Y7.js.map ├── +++ assets/public/main-ZCHNZPZH.js.map │┄ Files identical despite different names │ --- assets/public/chunk-BV4AT7XT.js.map ├── +++ assets/public/chunk-GQBD5ET4.js.map │┄ Files identical despite different names │ --- assets/public/chunk-DRZXYCK7.js.map ├── +++ assets/public/chunk-NQOAW23X.js.map │┄ Files identical despite different names │ --- assets/public/chunk-N7XAWOJQ.js.map ├── +++ assets/public/chunk-SN3MQOUX.js.map │┄ Files identical despite different names │ --- assets/public/chunk-UOINLFDQ.js ├── +++ assets/public/chunk-HGBYEZ3P.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-N7XAWOJQ.js"; │ │ +} from "./chunk-SN3MQOUX.js"; │ │ import { │ │ a as ft, │ │ b as It, │ │ c as gn │ │ } from "./chunk-USJLDBUR.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-MWP7PIHW.js"; │ │ +} from "./chunk-MG45FVR3.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-DRZXYCK7.js"; │ │ +} from "./chunk-NQOAW23X.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-GLK464BM.js"; │ │ +} from "./chunk-3FBG5TIB.js"; │ │ import "./chunk-BYEHZBJ4.js"; │ │ import "./chunk-5J3KQ7C3.js"; │ │ import { │ │ b as vt, │ │ e as Gt, │ │ j as Tn │ │ } from "./chunk-UZ6PFR4N.js"; │ │ @@ -2584,8 +2584,8 @@ │ │ return i │ │ })() │ │ }); │ │ go(); │ │ export { │ │ Rl as ConfigPageComponent │ │ }; │ │ -//# sourceMappingURL=chunk-UOINLFDQ.js.map │ │ +//# sourceMappingURL=chunk-HGBYEZ3P.js.map │ --- assets/public/main-RUYWC6Y7.js ├── +++ assets/public/main-ZCHNZPZH.js │┄ Files 99% similar despite different names │ ├── js-beautify {} │ │ @@ -23,15 +23,15 @@ │ │ t as TA, │ │ u as Ic, │ │ v as rb, │ │ w as ab, │ │ x as SA, │ │ y as qp, │ │ z as sb │ │ -} from "./chunk-Y5JLO2N2.js"; │ │ +} from "./chunk-NE6ZQYIQ.js"; │ │ import { │ │ a as Ln, │ │ b as as │ │ } from "./chunk-PWRUPOTK.js"; │ │ import { │ │ a as TT, │ │ d as ST, │ │ @@ -82,15 +82,15 @@ │ │ import { │ │ b as cb, │ │ c as bA │ │ } from "./chunk-W2TGRLG6.js"; │ │ import { │ │ a as db, │ │ b as kA │ │ -} from "./chunk-YSZPGIR3.js"; │ │ +} from "./chunk-3ISLZ73Y.js"; │ │ import { │ │ a as Ec, │ │ b as xA, │ │ c as pb, │ │ d as MA │ │ } from "./chunk-IBUEQXYK.js"; │ │ import { │ │ @@ -98,28 +98,28 @@ │ │ b as MO, │ │ c as XS, │ │ d as jD, │ │ e as ey, │ │ f as HD, │ │ g as Jp, │ │ h as Yy │ │ -} from "./chunk-N7XAWOJQ.js"; │ │ +} from "./chunk-SN3MQOUX.js"; │ │ import { │ │ a as sp, │ │ b as lp, │ │ c as FT │ │ } from "./chunk-USJLDBUR.js"; │ │ import { │ │ a as ip, │ │ b as gT │ │ } from "./chunk-3UB54IM4.js"; │ │ import { │ │ f as Ta, │ │ g as jp │ │ -} from "./chunk-MWP7PIHW.js"; │ │ +} from "./chunk-MG45FVR3.js"; │ │ import { │ │ a as ZS, │ │ b as WD │ │ } from "./chunk-UNMRK3W7.js"; │ │ import { │ │ a as Jy, │ │ b as mA │ │ @@ -354,15 +354,15 @@ │ │ h as ko │ │ } from "./chunk-W3EHXDVY.js"; │ │ import { │ │ a as Xn, │ │ b as YD, │ │ k as vr, │ │ l as wc │ │ -} from "./chunk-DRZXYCK7.js"; │ │ +} from "./chunk-NQOAW23X.js"; │ │ import { │ │ A as $S, │ │ B as VS, │ │ C as Fh, │ │ D as zS, │ │ E as RD, │ │ F as Nh, │ │ @@ -391,15 +391,15 @@ │ │ l as AS, │ │ m as OD, │ │ n as ss, │ │ o as AD, │ │ x as Je, │ │ y as Rh, │ │ z as $p │ │ -} from "./chunk-GLK464BM.js"; │ │ +} from "./chunk-3FBG5TIB.js"; │ │ import { │ │ a as cr, │ │ b as fc, │ │ c as Ph, │ │ d as Sc, │ │ e as yc, │ │ f as Oh, │ │ @@ -13190,15 +13190,15 @@ │ │ var uw, hw = O(() => { │ │ "use strict"; │ │ dw(); │ │ Ro(); │ │ mw(); │ │ uw = [{ │ │ path: "config", │ │ - loadComponent: () => import("./chunk-UOINLFDQ.js").then(i => i.ConfigPageComponent), │ │ + loadComponent: () => import("./chunk-HGBYEZ3P.js").then(i => i.ConfigPageComponent), │ │ data: { │ │ page: "config" │ │ }, │ │ canActivate: [Zt] │ │ }, { │ │ path: "search", │ │ loadComponent: () => import("./chunk-DXYAAW36.js").then(i => i.SearchPageComponent), │ │ @@ -13260,22 +13260,22 @@ │ │ loadComponent: () => import("./chunk-XATCGJCU.js").then(i => i.QuickHistoryComponent), │ │ data: { │ │ page: "quick-history" │ │ }, │ │ canActivate: [Ia, Zt] │ │ }, { │ │ path: "tag/:id/daily-summary", │ │ - loadComponent: () => import("./chunk-BV4AT7XT.js").then(i => i.DailySummaryComponent), │ │ + loadComponent: () => import("./chunk-GQBD5ET4.js").then(i => i.DailySummaryComponent), │ │ data: { │ │ page: "daily-summary" │ │ }, │ │ canActivate: [Ia, Zt] │ │ }, { │ │ path: "tag/:id/daily-summary/:dayStr", │ │ - loadComponent: () => import("./chunk-BV4AT7XT.js").then(i => i.DailySummaryComponent), │ │ + loadComponent: () => import("./chunk-GQBD5ET4.js").then(i => i.DailySummaryComponent), │ │ data: { │ │ page: "daily-summary" │ │ }, │ │ canActivate: [Ia, Zt] │ │ }, { │ │ path: "tag/:id/metrics", │ │ loadComponent: () => import("./chunk-RAYMZOZ2.js").then(i => i.MetricPageComponent), │ │ @@ -13316,41 +13316,41 @@ │ │ loadComponent: () => import("./chunk-RAYMZOZ2.js").then(i => i.MetricPageComponent), │ │ data: { │ │ page: "metrics" │ │ }, │ │ canActivate: [Ea, Zt] │ │ }, { │ │ path: "project/:id/daily-summary", │ │ - loadComponent: () => import("./chunk-BV4AT7XT.js").then(i => i.DailySummaryComponent), │ │ + loadComponent: () => import("./chunk-GQBD5ET4.js").then(i => i.DailySummaryComponent), │ │ data: { │ │ page: "daily-summary" │ │ }, │ │ canActivate: [Ea, Zt] │ │ }, { │ │ path: "project/:id/daily-summary/:dayStr", │ │ - loadComponent: () => import("./chunk-BV4AT7XT.js").then(i => i.DailySummaryComponent), │ │ + loadComponent: () => import("./chunk-GQBD5ET4.js").then(i => i.DailySummaryComponent), │ │ data: { │ │ page: "daily-summary" │ │ }, │ │ canActivate: [Ea, Zt] │ │ }, { │ │ path: "active/:subPageType", │ │ canActivate: [Vm, Zt], │ │ - loadComponent: () => import("./chunk-UOINLFDQ.js").then(i => i.ConfigPageComponent) │ │ + loadComponent: () => import("./chunk-HGBYEZ3P.js").then(i => i.ConfigPageComponent) │ │ }, { │ │ path: "active/:subPageType/:param", │ │ canActivate: [Vm, Zt], │ │ - loadComponent: () => import("./chunk-UOINLFDQ.js").then(i => i.ConfigPageComponent) │ │ + loadComponent: () => import("./chunk-HGBYEZ3P.js").then(i => i.ConfigPageComponent) │ │ }, { │ │ path: "active", │ │ canActivate: [Vm, Zt], │ │ - loadComponent: () => import("./chunk-UOINLFDQ.js").then(i => i.ConfigPageComponent) │ │ + loadComponent: () => import("./chunk-HGBYEZ3P.js").then(i => i.ConfigPageComponent) │ │ }, { │ │ path: "plugins/:pluginId/index", │ │ - loadComponent: () => import("./chunk-6YS2XM2X.js").then(i => i.PluginIndexComponent), │ │ + loadComponent: () => import("./chunk-YUXD5HP3.js").then(i => i.PluginIndexComponent), │ │ data: { │ │ page: "plugin-index" │ │ }, │ │ canActivate: [Zt] │ │ }, { │ │ path: "**", │ │ redirectTo: `tag/${at.id}/tasks` │ │ @@ -30032,8 +30032,8 @@ │ │ ie.log("Time window for completing sync started"), yield c0(2e4), ie.log("Time window for completing sync ended. Closing app!"), vg.finish({ │ │ taskId: e │ │ }) │ │ })) │ │ }))) │ │ }); │ │ export default oU(); │ │ -//# sourceMappingURL=main-RUYWC6Y7.js.map │ │ +//# sourceMappingURL=main-ZCHNZPZH.js.map │ --- assets/public/chunk-BV4AT7XT.js ├── +++ assets/public/chunk-GQBD5ET4.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-Y5JLO2N2.js"; │ │ +} from "./chunk-NE6ZQYIQ.js"; │ │ import { │ │ a as $i, │ │ b as uo │ │ } from "./chunk-PWRUPOTK.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-GLK464BM.js"; │ │ +} from "./chunk-3FBG5TIB.js"; │ │ import "./chunk-5J3KQ7C3.js"; │ │ import "./chunk-UZ6PFR4N.js"; │ │ import "./chunk-WS4Y2BQK.js"; │ │ import { │ │ e as Pi, │ │ f as co │ │ } from "./chunk-DQJP63QP.js"; │ │ @@ -2249,8 +2249,8 @@ │ │ return e │ │ })() │ │ }); │ │ nr(); │ │ export { │ │ Xl as DailySummaryComponent │ │ }; │ │ -//# sourceMappingURL=chunk-BV4AT7XT.js.map │ │ +//# sourceMappingURL=chunk-GQBD5ET4.js.map │ --- assets/public/chunk-DRZXYCK7.js ├── +++ assets/public/chunk-NQOAW23X.js │┄ Files 99% similar despite different names │ ├── js-beautify {} │ │ @@ -1,11 +1,11 @@ │ │ import { │ │ U as Ar, │ │ V as ct │ │ -} from "./chunk-GLK464BM.js"; │ │ +} from "./chunk-3FBG5TIB.js"; │ │ import { │ │ c as gr, │ │ d as fr, │ │ g as mr, │ │ h as hr, │ │ i as Tr, │ │ j as ut, │ │ @@ -2843,15 +2843,15 @@ │ │ } │ │ }) │ │ } │ │ sendMessageToPlugin(t, o) { │ │ return S(this, null, function*() { │ │ let { │ │ PluginRunner: l │ │ - } = yield import("./chunk-Y5QHOD6A.js"); │ │ + } = yield import("./chunk-SZ5PK2ML.js"); │ │ return this._injector.get(l).sendMessageToPlugin(t, o) │ │ }) │ │ } │ │ _initWindowFocusTracking() { │ │ window.addEventListener("focus", () => { │ │ this._isWindowFocused = !0, this._notifyFocusHandlers(!0) │ │ }), window.addEventListener("blur", () => { │ │ @@ -3498,8 +3498,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-DRZXYCK7.js.map │ │ +//# sourceMappingURL=chunk-NQOAW23X.js.map │ --- assets/public/chunk-6YS2XM2X.js ├── +++ assets/public/chunk-YUXD5HP3.js │┄ Files 94% similar despite different names │ ├── js-beautify {} │ │ @@ -1,15 +1,15 @@ │ │ import { │ │ a, │ │ b │ │ -} from "./chunk-YSZPGIR3.js"; │ │ -import "./chunk-MWP7PIHW.js"; │ │ +} from "./chunk-3ISLZ73Y.js"; │ │ +import "./chunk-MG45FVR3.js"; │ │ import "./chunk-WFJJ2WJN.js"; │ │ -import "./chunk-DRZXYCK7.js"; │ │ -import "./chunk-GLK464BM.js"; │ │ +import "./chunk-NQOAW23X.js"; │ │ +import "./chunk-3FBG5TIB.js"; │ │ import "./chunk-BYEHZBJ4.js"; │ │ import "./chunk-5J3KQ7C3.js"; │ │ import "./chunk-UZ6PFR4N.js"; │ │ import "./chunk-WS4Y2BQK.js"; │ │ import "./chunk-DQJP63QP.js"; │ │ import "./chunk-Z4CB7MDJ.js"; │ │ import "./chunk-2FG4XLJJ.js"; │ │ @@ -37,8 +37,8 @@ │ │ import "./chunk-OXDOKNTF.js"; │ │ import "./chunk-PEJGMLLQ.js"; │ │ import "./chunk-2NYJ54WT.js"; │ │ b(); │ │ export { │ │ a as PluginIndexComponent │ │ }; │ │ -//# sourceMappingURL=chunk-6YS2XM2X.js.map │ │ +//# sourceMappingURL=chunk-YUXD5HP3.js.map │ --- assets/public/chunk-UOINLFDQ.js.map ├── +++ assets/public/chunk-HGBYEZ3P.js.map │┄ Files identical despite different names │ --- assets/public/chunk-MWP7PIHW.js ├── +++ assets/public/chunk-MG45FVR3.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-DRZXYCK7.js"; │ │ +} from "./chunk-NQOAW23X.js"; │ │ import { │ │ K as Ce, │ │ L as Je, │ │ j as Ie, │ │ k as Xe │ │ -} from "./chunk-GLK464BM.js"; │ │ +} from "./chunk-3FBG5TIB.js"; │ │ import { │ │ e as fe, │ │ f as me, │ │ g as Pe, │ │ i as _e, │ │ j as Se, │ │ k as Ee, │ │ @@ -1114,8 +1114,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-MWP7PIHW.js.map │ │ +//# sourceMappingURL=chunk-MG45FVR3.js.map │ --- assets/public/chunk-GLK464BM.js.map ├── +++ assets/public/chunk-3FBG5TIB.js.map │┄ Files 99% similar despite different names │ ├── Pretty-printed │ │┄ Similarity: 0.99822695035461% │ │┄ 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-11-04T03:20:06.493Z\\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 […] │ │ @@ -4647,15 +4647,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 ElementRef,\n inject,\n input,\n output,\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 { toObservable, toSignal } from '@angular/core/rxjs-interop';\nimport { TaskCopy } from '../../tasks/task.model';\nimport { TagComponent } from '../tag/tag.component';\nimport { TranslatePipe } from '@ngx-translate/core';\nimport { switchMap } from 'rxjs/operators';\nimport { TODAY_TAG } from '../tag.const';\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\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 = toSignal(this.inputCtrl.valueChanges);\n tagSuggestions = toSignal(\n toObservable(this.isShowMyDayTag).pipe(\n switchMap((isShowMyDay) =>\n isShowMyDay ? this._tagService.tags$ : this._tagService.tagsNoMyDayAndNoList$,\n ),\n ),\n { initialValue: [] },\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 {{ suggestion.title }}\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-24T09:35:15.217Z\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-11-04T03:20:06.493Z\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-MWP7PIHW.js.map ├── +++ assets/public/chunk-MG45FVR3.js.map │┄ Files identical despite different names │ --- assets/public/chunk-N7XAWOJQ.js ├── +++ assets/public/chunk-SN3MQOUX.js │┄ Files 98% similar despite different names │ ├── js-beautify {} │ │ @@ -1,15 +1,15 @@ │ │ import { │ │ f as V, │ │ g as X │ │ -} from "./chunk-MWP7PIHW.js"; │ │ +} from "./chunk-MG45FVR3.js"; │ │ import { │ │ a as L, │ │ b as $ │ │ -} from "./chunk-GLK464BM.js"; │ │ +} from "./chunk-3FBG5TIB.js"; │ │ import { │ │ b as F, │ │ d as W │ │ } from "./chunk-6GJV2O5S.js"; │ │ import { │ │ Ab as _, │ │ Fb as y, │ │ @@ -158,8 +158,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-N7XAWOJQ.js.map │ │ +//# sourceMappingURL=chunk-SN3MQOUX.js.map