--- /home/fdroid/fdroiddata/tmp/com.superproductivity.superproductivity_1503000000.apk +++ /home/fdroid/fdroiddata/tmp/sigcp_com.superproductivity.superproductivity_1503000000.apk ├── zipinfo {} │ @@ -130,66 +130,62 @@ │ -rw-r--r-- 0.0 unx 756 b- defN 81-Jan-01 01:01 assets/public/chip-list-input.component-GQQYZYBD.css.map │ -rw-r--r-- 0.0 unx 3962 b- defN 81-Jan-01 01:01 assets/public/chunk-2NLKHL2W.js │ -rw-r--r-- 0.0 unx 13802 b- defN 81-Jan-01 01:01 assets/public/chunk-2NLKHL2W.js.map │ -rw-r--r-- 0.0 unx 2044 b- defN 81-Jan-01 01:01 assets/public/chunk-2NYJ54WT.js │ -rw-r--r-- 0.0 unx 93 b- defN 81-Jan-01 01:01 assets/public/chunk-2NYJ54WT.js.map │ -rw-r--r-- 0.0 unx 20617 b- defN 81-Jan-01 01:01 assets/public/chunk-2WM3YZAK.js │ -rw-r--r-- 0.0 unx 35313 b- defN 81-Jan-01 01:01 assets/public/chunk-2WM3YZAK.js.map │ --rw-r--r-- 0.0 unx 65047 b- defN 81-Jan-01 01:01 assets/public/chunk-327SFFJ7.js │ --rw-r--r-- 0.0 unx 164867 b- defN 81-Jan-01 01:01 assets/public/chunk-327SFFJ7.js.map │ -rw-r--r-- 0.0 unx 24217 b- defN 81-Jan-01 01:01 assets/public/chunk-3DA7NDG7.js │ -rw-r--r-- 0.0 unx 97875 b- defN 81-Jan-01 01:01 assets/public/chunk-3DA7NDG7.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 4348 b- defN 81-Jan-01 01:01 assets/public/chunk-3JK22HTK.js │ -rw-r--r-- 0.0 unx 12382 b- defN 81-Jan-01 01:01 assets/public/chunk-3JK22HTK.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 16007 b- defN 81-Jan-01 01:01 assets/public/chunk-3XDH4HMG.js │ -rw-r--r-- 0.0 unx 30930 b- defN 81-Jan-01 01:01 assets/public/chunk-3XDH4HMG.js.map │ -rw-r--r-- 0.0 unx 602 b- defN 81-Jan-01 01:01 assets/public/chunk-3YQA2ZCY.js │ -rw-r--r-- 0.0 unx 2080 b- defN 81-Jan-01 01:01 assets/public/chunk-3YQA2ZCY.js.map │ --rw-r--r-- 0.0 unx 11454 b- defN 81-Jan-01 01:01 assets/public/chunk-4TIGGGHV.js │ --rw-r--r-- 0.0 unx 22568 b- defN 81-Jan-01 01:01 assets/public/chunk-4TIGGGHV.js.map │ -rw-r--r-- 0.0 unx 2337 b- defN 81-Jan-01 01:01 assets/public/chunk-4U7DROTX.js │ -rw-r--r-- 0.0 unx 4992 b- defN 81-Jan-01 01:01 assets/public/chunk-4U7DROTX.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 51600 b- defN 81-Jan-01 01:01 assets/public/chunk-5QROK3OX.js │ -rw-r--r-- 0.0 unx 186219 b- defN 81-Jan-01 01:01 assets/public/chunk-5QROK3OX.js.map │ -rw-r--r-- 0.0 unx 100133 b- defN 81-Jan-01 01:01 assets/public/chunk-6FYAD2CQ.js │ -rw-r--r-- 0.0 unx 259731 b- defN 81-Jan-01 01:01 assets/public/chunk-6FYAD2CQ.js.map │ -rw-r--r-- 0.0 unx 29745 b- defN 81-Jan-01 01:01 assets/public/chunk-6HDPB3YX.js │ -rw-r--r-- 0.0 unx 82049 b- defN 81-Jan-01 01:01 assets/public/chunk-6HDPB3YX.js.map │ --rw-r--r-- 0.0 unx 30026 b- defN 81-Jan-01 01:01 assets/public/chunk-6TSABQXM.js │ --rw-r--r-- 0.0 unx 109138 b- defN 81-Jan-01 01:01 assets/public/chunk-6TSABQXM.js.map │ -rw-r--r-- 0.0 unx 511 b- defN 81-Jan-01 01:01 assets/public/chunk-74EGGIJI.js │ -rw-r--r-- 0.0 unx 1526 b- defN 81-Jan-01 01:01 assets/public/chunk-74EGGIJI.js.map │ -rw-r--r-- 0.0 unx 3538 b- defN 81-Jan-01 01:01 assets/public/chunk-76QGHBDI.js │ -rw-r--r-- 0.0 unx 10230 b- defN 81-Jan-01 01:01 assets/public/chunk-76QGHBDI.js.map │ -rw-r--r-- 0.0 unx 31579 b- defN 81-Jan-01 01:01 assets/public/chunk-7XF3V5GI.js │ -rw-r--r-- 0.0 unx 84113 b- defN 81-Jan-01 01:01 assets/public/chunk-7XF3V5GI.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 │ -rw-r--r-- 0.0 unx 680 b- defN 81-Jan-01 01:01 assets/public/chunk-A6QD6H33.js.map │ --rw-r--r-- 0.0 unx 121387 b- defN 81-Jan-01 01:01 assets/public/chunk-ADCYWBC4.js │ --rw-r--r-- 0.0 unx 183450 b- defN 81-Jan-01 01:01 assets/public/chunk-ADCYWBC4.js.map │ -rw-r--r-- 0.0 unx 1214 b- defN 81-Jan-01 01:01 assets/public/chunk-AE7XKJXJ.js │ -rw-r--r-- 0.0 unx 3481 b- defN 81-Jan-01 01:01 assets/public/chunk-AE7XKJXJ.js.map │ +-rw-r--r-- 0.0 unx 1099 b- defN 81-Jan-01 01:01 assets/public/chunk-AG53IFIE.js │ +-rw-r--r-- 0.0 unx 93 b- defN 81-Jan-01 01:01 assets/public/chunk-AG53IFIE.js.map │ -rw-r--r-- 0.0 unx 1956 b- defN 81-Jan-01 01:01 assets/public/chunk-ANYCFL6X.js │ -rw-r--r-- 0.0 unx 7789 b- defN 81-Jan-01 01:01 assets/public/chunk-ANYCFL6X.js.map │ -rw-r--r-- 0.0 unx 255 b- defN 81-Jan-01 01:01 assets/public/chunk-BE62ACRB.js │ -rw-r--r-- 0.0 unx 816 b- defN 81-Jan-01 01:01 assets/public/chunk-BE62ACRB.js.map │ -rw-r--r-- 0.0 unx 76947 b- defN 81-Jan-01 01:01 assets/public/chunk-BF66PHNY.js │ -rw-r--r-- 0.0 unx 182973 b- defN 81-Jan-01 01:01 assets/public/chunk-BF66PHNY.js.map │ -rw-r--r-- 0.0 unx 729 b- defN 81-Jan-01 01:01 assets/public/chunk-BHLU5KMJ.js │ -rw-r--r-- 0.0 unx 2317 b- defN 81-Jan-01 01:01 assets/public/chunk-BHLU5KMJ.js.map │ -rw-r--r-- 0.0 unx 4604 b- defN 81-Jan-01 01:01 assets/public/chunk-BI2OH7XR.js │ -rw-r--r-- 0.0 unx 8705 b- defN 81-Jan-01 01:01 assets/public/chunk-BI2OH7XR.js.map │ +-rw-r--r-- 0.0 unx 30026 b- defN 81-Jan-01 01:01 assets/public/chunk-BIEIICW4.js │ +-rw-r--r-- 0.0 unx 109138 b- defN 81-Jan-01 01:01 assets/public/chunk-BIEIICW4.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 9256 b- defN 81-Jan-01 01:01 assets/public/chunk-C4KDVV5E.js │ -rw-r--r-- 0.0 unx 39639 b- defN 81-Jan-01 01:01 assets/public/chunk-C4KDVV5E.js.map │ -rw-r--r-- 0.0 unx 58438 b- defN 81-Jan-01 01:01 assets/public/chunk-CIAWTZY4.js │ -rw-r--r-- 0.0 unx 260466 b- defN 81-Jan-01 01:01 assets/public/chunk-CIAWTZY4.js.map │ -rw-r--r-- 0.0 unx 123985 b- defN 81-Jan-01 01:01 assets/public/chunk-DAWDIIWC.js │ @@ -204,32 +200,34 @@ │ -rw-r--r-- 0.0 unx 10923 b- defN 81-Jan-01 01:01 assets/public/chunk-G3I24IXL.js.map │ -rw-r--r-- 0.0 unx 426 b- defN 81-Jan-01 01:01 assets/public/chunk-GYQZ4E6P.js │ -rw-r--r-- 0.0 unx 949 b- defN 81-Jan-01 01:01 assets/public/chunk-GYQZ4E6P.js.map │ -rw-r--r-- 0.0 unx 18953 b- defN 81-Jan-01 01:01 assets/public/chunk-HKWYPOTM.js │ -rw-r--r-- 0.0 unx 53227 b- defN 81-Jan-01 01:01 assets/public/chunk-HKWYPOTM.js.map │ -rw-r--r-- 0.0 unx 10450 b- defN 81-Jan-01 01:01 assets/public/chunk-HQZVBSHO.js │ -rw-r--r-- 0.0 unx 29209 b- defN 81-Jan-01 01:01 assets/public/chunk-HQZVBSHO.js.map │ +-rw-r--r-- 0.0 unx 66829 b- defN 81-Jan-01 01:01 assets/public/chunk-HX6H4D5R.js │ +-rw-r--r-- 0.0 unx 263769 b- defN 81-Jan-01 01:01 assets/public/chunk-HX6H4D5R.js.map │ -rw-r--r-- 0.0 unx 42689 b- defN 81-Jan-01 01:01 assets/public/chunk-I5HQRRLR.js │ -rw-r--r-- 0.0 unx 170408 b- defN 81-Jan-01 01:01 assets/public/chunk-I5HQRRLR.js.map │ -rw-r--r-- 0.0 unx 288511 b- defN 81-Jan-01 01:01 assets/public/chunk-I6NHNS44.js │ -rw-r--r-- 0.0 unx 1089003 b- defN 81-Jan-01 01:01 assets/public/chunk-I6NHNS44.js.map │ --rw-r--r-- 0.0 unx 66829 b- defN 81-Jan-01 01:01 assets/public/chunk-IH4C37MG.js │ --rw-r--r-- 0.0 unx 263769 b- defN 81-Jan-01 01:01 assets/public/chunk-IH4C37MG.js.map │ -rw-r--r-- 0.0 unx 2751 b- defN 81-Jan-01 01:01 assets/public/chunk-ILL7PQHQ.js │ -rw-r--r-- 0.0 unx 10701 b- defN 81-Jan-01 01:01 assets/public/chunk-ILL7PQHQ.js.map │ -rw-r--r-- 0.0 unx 1162 b- defN 81-Jan-01 01:01 assets/public/chunk-IQ6PRZNS.js │ -rw-r--r-- 0.0 unx 2945 b- defN 81-Jan-01 01:01 assets/public/chunk-IQ6PRZNS.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 35727 b- defN 81-Jan-01 01:01 assets/public/chunk-J6ISZPCF.js │ -rw-r--r-- 0.0 unx 149379 b- defN 81-Jan-01 01:01 assets/public/chunk-J6ISZPCF.js.map │ -rw-r--r-- 0.0 unx 23637 b- defN 81-Jan-01 01:01 assets/public/chunk-JGLVFTHL.js │ -rw-r--r-- 0.0 unx 41275 b- defN 81-Jan-01 01:01 assets/public/chunk-JGLVFTHL.js.map │ -rw-r--r-- 0.0 unx 4447 b- defN 81-Jan-01 01:01 assets/public/chunk-JIAINNPA.js │ -rw-r--r-- 0.0 unx 6897 b- defN 81-Jan-01 01:01 assets/public/chunk-JIAINNPA.js.map │ +-rw-r--r-- 0.0 unx 1017 b- defN 81-Jan-01 01:01 assets/public/chunk-JJXTGRC4.js │ +-rw-r--r-- 0.0 unx 93 b- defN 81-Jan-01 01:01 assets/public/chunk-JJXTGRC4.js.map │ -rw-r--r-- 0.0 unx 49252 b- defN 81-Jan-01 01:01 assets/public/chunk-K2CLIKPD.js │ -rw-r--r-- 0.0 unx 184328 b- defN 81-Jan-01 01:01 assets/public/chunk-K2CLIKPD.js.map │ -rw-r--r-- 0.0 unx 3941 b- defN 81-Jan-01 01:01 assets/public/chunk-L3RTD537.js │ -rw-r--r-- 0.0 unx 10584 b- defN 81-Jan-01 01:01 assets/public/chunk-L3RTD537.js.map │ -rw-r--r-- 0.0 unx 2469 b- defN 81-Jan-01 01:01 assets/public/chunk-LGJRHL6M.js │ -rw-r--r-- 0.0 unx 6496 b- defN 81-Jan-01 01:01 assets/public/chunk-LGJRHL6M.js.map │ -rw-r--r-- 0.0 unx 1139 b- defN 81-Jan-01 01:01 assets/public/chunk-LIA5ARM4.js │ @@ -260,20 +258,18 @@ │ -rw-r--r-- 0.0 unx 25025 b- defN 81-Jan-01 01:01 assets/public/chunk-ODC53ZA5.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 9376 b- defN 81-Jan-01 01:01 assets/public/chunk-P76QKORU.js │ -rw-r--r-- 0.0 unx 21304 b- defN 81-Jan-01 01:01 assets/public/chunk-P76QKORU.js.map │ --rw-r--r-- 0.0 unx 1017 b- defN 81-Jan-01 01:01 assets/public/chunk-PBRU3XFX.js │ --rw-r--r-- 0.0 unx 93 b- defN 81-Jan-01 01:01 assets/public/chunk-PBRU3XFX.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 3098 b- defN 81-Jan-01 01:01 assets/public/chunk-QF7DVNE3.js │ --rw-r--r-- 0.0 unx 9576 b- defN 81-Jan-01 01:01 assets/public/chunk-QF7DVNE3.js.map │ +-rw-r--r-- 0.0 unx 60010 b- defN 81-Jan-01 01:01 assets/public/chunk-PPSDU5N6.js │ +-rw-r--r-- 0.0 unx 171888 b- defN 81-Jan-01 01:01 assets/public/chunk-PPSDU5N6.js.map │ -rw-r--r-- 0.0 unx 1443 b- defN 81-Jan-01 01:01 assets/public/chunk-QH6TSZG4.js │ -rw-r--r-- 0.0 unx 4788 b- defN 81-Jan-01 01:01 assets/public/chunk-QH6TSZG4.js.map │ -rw-r--r-- 0.0 unx 15134 b- defN 81-Jan-01 01:01 assets/public/chunk-QMJZV4FP.js │ -rw-r--r-- 0.0 unx 37882 b- defN 81-Jan-01 01:01 assets/public/chunk-QMJZV4FP.js.map │ -rw-r--r-- 0.0 unx 3324 b- defN 81-Jan-01 01:01 assets/public/chunk-QQNZ2EQ2.js │ -rw-r--r-- 0.0 unx 22451 b- defN 81-Jan-01 01:01 assets/public/chunk-QQNZ2EQ2.js.map │ -rw-r--r-- 0.0 unx 8837 b- defN 81-Jan-01 01:01 assets/public/chunk-R44RDGNH.js │ @@ -284,52 +280,56 @@ │ -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 25217 b- defN 81-Jan-01 01:01 assets/public/chunk-RISNPNQN.js │ -rw-r--r-- 0.0 unx 69151 b- defN 81-Jan-01 01:01 assets/public/chunk-RISNPNQN.js.map │ -rw-r--r-- 0.0 unx 3415 b- defN 81-Jan-01 01:01 assets/public/chunk-RVOBCK53.js │ -rw-r--r-- 0.0 unx 16186 b- defN 81-Jan-01 01:01 assets/public/chunk-RVOBCK53.js.map │ -rw-r--r-- 0.0 unx 2001 b- defN 81-Jan-01 01:01 assets/public/chunk-RXNLVNG6.js │ -rw-r--r-- 0.0 unx 3277 b- defN 81-Jan-01 01:01 assets/public/chunk-RXNLVNG6.js.map │ --rw-r--r-- 0.0 unx 307427 b- defN 81-Jan-01 01:01 assets/public/chunk-SEAKVT5E.js │ --rw-r--r-- 0.0 unx 982257 b- defN 81-Jan-01 01:01 assets/public/chunk-SEAKVT5E.js.map │ -rw-r--r-- 0.0 unx 4213 b- defN 81-Jan-01 01:01 assets/public/chunk-SFH7Q7UW.js │ -rw-r--r-- 0.0 unx 16703 b- defN 81-Jan-01 01:01 assets/public/chunk-SFH7Q7UW.js.map │ -rw-r--r-- 0.0 unx 11667 b- defN 81-Jan-01 01:01 assets/public/chunk-SHCPU7P2.js │ -rw-r--r-- 0.0 unx 18636 b- defN 81-Jan-01 01:01 assets/public/chunk-SHCPU7P2.js.map │ +-rw-r--r-- 0.0 unx 121387 b- defN 81-Jan-01 01:01 assets/public/chunk-SLB7M5PF.js │ +-rw-r--r-- 0.0 unx 183450 b- defN 81-Jan-01 01:01 assets/public/chunk-SLB7M5PF.js.map │ -rw-r--r-- 0.0 unx 33021 b- defN 81-Jan-01 01:01 assets/public/chunk-T2ZDFRFV.js │ -rw-r--r-- 0.0 unx 112433 b- defN 81-Jan-01 01:01 assets/public/chunk-T2ZDFRFV.js.map │ -rw-r--r-- 0.0 unx 131675 b- defN 81-Jan-01 01:01 assets/public/chunk-TFUMAMRZ.js │ -rw-r--r-- 0.0 unx 436025 b- defN 81-Jan-01 01:01 assets/public/chunk-TFUMAMRZ.js.map │ +-rw-r--r-- 0.0 unx 307427 b- defN 81-Jan-01 01:01 assets/public/chunk-TILX7ESY.js │ +-rw-r--r-- 0.0 unx 982257 b- defN 81-Jan-01 01:01 assets/public/chunk-TILX7ESY.js.map │ -rw-r--r-- 0.0 unx 3648 b- defN 81-Jan-01 01:01 assets/public/chunk-TLXRLWM2.js │ -rw-r--r-- 0.0 unx 11641 b- defN 81-Jan-01 01:01 assets/public/chunk-TLXRLWM2.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 5189 b- defN 81-Jan-01 01:01 assets/public/chunk-UPCMCXR6.js │ -rw-r--r-- 0.0 unx 9498 b- defN 81-Jan-01 01:01 assets/public/chunk-UPCMCXR6.js.map │ -rw-r--r-- 0.0 unx 8532 b- defN 81-Jan-01 01:01 assets/public/chunk-URYU4E6G.js │ -rw-r--r-- 0.0 unx 14186 b- defN 81-Jan-01 01:01 assets/public/chunk-URYU4E6G.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 11454 b- defN 81-Jan-01 01:01 assets/public/chunk-VAOB4JG2.js │ +-rw-r--r-- 0.0 unx 22568 b- defN 81-Jan-01 01:01 assets/public/chunk-VAOB4JG2.js.map │ -rw-r--r-- 0.0 unx 2434 b- defN 81-Jan-01 01:01 assets/public/chunk-VHUERUA4.js │ -rw-r--r-- 0.0 unx 3017 b- defN 81-Jan-01 01:01 assets/public/chunk-VHUERUA4.js.map │ +-rw-r--r-- 0.0 unx 3098 b- defN 81-Jan-01 01:01 assets/public/chunk-VJQR3OQG.js │ +-rw-r--r-- 0.0 unx 9576 b- defN 81-Jan-01 01:01 assets/public/chunk-VJQR3OQG.js.map │ -rw-r--r-- 0.0 unx 5627 b- defN 81-Jan-01 01:01 assets/public/chunk-VV6ZHKLO.js │ -rw-r--r-- 0.0 unx 20575 b- defN 81-Jan-01 01:01 assets/public/chunk-VV6ZHKLO.js.map │ -rw-r--r-- 0.0 unx 2173 b- defN 81-Jan-01 01:01 assets/public/chunk-VZC2YUAA.js │ -rw-r--r-- 0.0 unx 8779 b- defN 81-Jan-01 01:01 assets/public/chunk-VZC2YUAA.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 1099 b- defN 81-Jan-01 01:01 assets/public/chunk-W3WYTWJF.js │ --rw-r--r-- 0.0 unx 93 b- defN 81-Jan-01 01:01 assets/public/chunk-W3WYTWJF.js.map │ --rw-r--r-- 0.0 unx 60010 b- defN 81-Jan-01 01:01 assets/public/chunk-WN36MJWA.js │ --rw-r--r-- 0.0 unx 171888 b- defN 81-Jan-01 01:01 assets/public/chunk-WN36MJWA.js.map │ -rw-r--r-- 0.0 unx 20711 b- defN 81-Jan-01 01:01 assets/public/chunk-WXJTT6GG.js │ -rw-r--r-- 0.0 unx 61007 b- defN 81-Jan-01 01:01 assets/public/chunk-WXJTT6GG.js.map │ -rw-r--r-- 0.0 unx 120352 b- defN 81-Jan-01 01:01 assets/public/chunk-XKTBNCB7.js │ -rw-r--r-- 0.0 unx 455554 b- defN 81-Jan-01 01:01 assets/public/chunk-XKTBNCB7.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 65047 b- defN 81-Jan-01 01:01 assets/public/chunk-YH7JAVPA.js │ +-rw-r--r-- 0.0 unx 164867 b- defN 81-Jan-01 01:01 assets/public/chunk-YH7JAVPA.js.map │ -rw-r--r-- 0.0 unx 411 b- defN 81-Jan-01 01:01 assets/public/chunk-YJ6NNGK3.js │ -rw-r--r-- 0.0 unx 938 b- defN 81-Jan-01 01:01 assets/public/chunk-YJ6NNGK3.js.map │ -rw-r--r-- 0.0 unx 212254 b- defN 81-Jan-01 01:01 assets/public/chunk-YY3AIJQH.js │ -rw-r--r-- 0.0 unx 663107 b- defN 81-Jan-01 01:01 assets/public/chunk-YY3AIJQH.js.map │ -rw-r--r-- 0.0 unx 1560 b- defN 81-Jan-01 01:01 assets/public/chunk-ZEGOSSOH.js │ -rw-r--r-- 0.0 unx 4533 b- defN 81-Jan-01 01:01 assets/public/chunk-ZEGOSSOH.js.map │ -rw-r--r-- 0.0 unx 55071 b- defN 81-Jan-01 01:01 assets/public/chunk-ZSD34TY2.js │ @@ -416,16 +416,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 802018 b- defN 81-Jan-01 01:01 assets/public/main-WUIV3A3S.js │ --rw-r--r-- 0.0 unx 2767241 b- defN 81-Jan-01 01:01 assets/public/main-WUIV3A3S.js.map │ +-rw-r--r-- 0.0 unx 802018 b- defN 81-Jan-01 01:01 assets/public/main-NMCHICC3.js │ +-rw-r--r-- 0.0 unx 2767241 b- defN 81-Jan-01 01:01 assets/public/main-NMCHICC3.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 │ @@ -1356,8 +1356,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 138717 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 138590 b- defN 81-Jan-01 01:01 META-INF/MANIFEST.MF │ -1361 files, 43126587 bytes uncompressed, 14855576 bytes compressed: 65.6% │ +1361 files, 43126587 bytes uncompressed, 14855577 bytes compressed: 65.6% ├── assets/public/ngsw.json │ ├── Pretty-printed │ │┄ Similarity: 0.9311224278814344% │ │┄ Differences: {"'assetGroups'": "{0: {'urls': {insert: [(20, '/chunk-AG53IFIE.js'), (26, '/chunk-BIEIICW4.js'), " │ │┄ "(38, '/chunk-HX6H4D5R.js'), (47, '/chunk-JJXTGRC4.js'), (68, " │ │┄ "'/chunk-PPSDU5N6.js'), (80, '/chunk-SLB7M5PF.js'), (83, '/chunk-TILX7ESY.js'), " │ │┄ "(89, '/chunk-VAOB4JG2.js'), (91, '/chunk-VJQR3OQG.js'), (98, " │ │┄ "'/chunk-YH7JAVPA.js'), (105, '/main-NMCHICC3.js')], delete: [105, 95, 94, 80, " │ │┄ '70, 68, 42, 22, 16, 10, 3]}}}' […] │ │ @@ -8,60 +8,59 @@ │ │ "name": "app", │ │ "patterns": [], │ │ "updateMode": "prefetch", │ │ "urls": [ │ │ "/chunk-2NLKHL2W.js", │ │ "/chunk-2NYJ54WT.js", │ │ "/chunk-2WM3YZAK.js", │ │ - "/chunk-327SFFJ7.js", │ │ "/chunk-3DA7NDG7.js", │ │ "/chunk-3E43H4SH.js", │ │ "/chunk-3JK22HTK.js", │ │ "/chunk-3UB54IM4.js", │ │ "/chunk-3XDH4HMG.js", │ │ "/chunk-3YQA2ZCY.js", │ │ - "/chunk-4TIGGGHV.js", │ │ "/chunk-4U7DROTX.js", │ │ "/chunk-4WKVJOAH.js", │ │ "/chunk-5QROK3OX.js", │ │ "/chunk-6FYAD2CQ.js", │ │ "/chunk-6HDPB3YX.js", │ │ - "/chunk-6TSABQXM.js", │ │ "/chunk-74EGGIJI.js", │ │ "/chunk-76QGHBDI.js", │ │ "/chunk-7XF3V5GI.js", │ │ "/chunk-A5MBRGPF.js", │ │ "/chunk-A6QD6H33.js", │ │ - "/chunk-ADCYWBC4.js", │ │ "/chunk-AE7XKJXJ.js", │ │ + "/chunk-AG53IFIE.js", │ │ "/chunk-ANYCFL6X.js", │ │ "/chunk-BE62ACRB.js", │ │ "/chunk-BF66PHNY.js", │ │ "/chunk-BHLU5KMJ.js", │ │ "/chunk-BI2OH7XR.js", │ │ + "/chunk-BIEIICW4.js", │ │ "/chunk-BOROUNNF.js", │ │ "/chunk-C4KDVV5E.js", │ │ "/chunk-CIAWTZY4.js", │ │ "/chunk-DAWDIIWC.js", │ │ "/chunk-DMDKJLM7.js", │ │ "/chunk-DPS3MBSF.js", │ │ "/chunk-F7LW7WUC.js", │ │ "/chunk-G3I24IXL.js", │ │ "/chunk-GYQZ4E6P.js", │ │ "/chunk-HKWYPOTM.js", │ │ "/chunk-HQZVBSHO.js", │ │ + "/chunk-HX6H4D5R.js", │ │ "/chunk-I5HQRRLR.js", │ │ "/chunk-I6NHNS44.js", │ │ - "/chunk-IH4C37MG.js", │ │ "/chunk-ILL7PQHQ.js", │ │ "/chunk-IQ6PRZNS.js", │ │ "/chunk-ISS7OXYA.js", │ │ "/chunk-J6ISZPCF.js", │ │ "/chunk-JGLVFTHL.js", │ │ "/chunk-JIAINNPA.js", │ │ + "/chunk-JJXTGRC4.js", │ │ "/chunk-K2CLIKPD.js", │ │ "/chunk-L3RTD537.js", │ │ "/chunk-LGJRHL6M.js", │ │ "/chunk-LIA5ARM4.js", │ │ "/chunk-MASHVMAF.js", │ │ "/chunk-MHRVXTMU.js", │ │ "/chunk-MIRHI7I6.js", │ │ @@ -73,52 +72,53 @@ │ │ "/chunk-NXHPN2SE.js", │ │ "/chunk-O3XSPFWI.js", │ │ "/chunk-O4FSZO2U.js", │ │ "/chunk-ODC53ZA5.js", │ │ "/chunk-OVAWK6DV.js", │ │ "/chunk-OXDOKNTF.js", │ │ "/chunk-P76QKORU.js", │ │ - "/chunk-PBRU3XFX.js", │ │ "/chunk-PEJGMLLQ.js", │ │ - "/chunk-QF7DVNE3.js", │ │ + "/chunk-PPSDU5N6.js", │ │ "/chunk-QH6TSZG4.js", │ │ "/chunk-QMJZV4FP.js", │ │ "/chunk-QQNZ2EQ2.js", │ │ "/chunk-R44RDGNH.js", │ │ "/chunk-R64NO3YZ.js", │ │ "/chunk-RHU3AIGY.js", │ │ "/chunk-RISNPNQN.js", │ │ "/chunk-RVOBCK53.js", │ │ "/chunk-RXNLVNG6.js", │ │ - "/chunk-SEAKVT5E.js", │ │ "/chunk-SFH7Q7UW.js", │ │ "/chunk-SHCPU7P2.js", │ │ + "/chunk-SLB7M5PF.js", │ │ "/chunk-T2ZDFRFV.js", │ │ "/chunk-TFUMAMRZ.js", │ │ + "/chunk-TILX7ESY.js", │ │ "/chunk-TLXRLWM2.js", │ │ "/chunk-U233VVFY.js", │ │ "/chunk-UPCMCXR6.js", │ │ "/chunk-URYU4E6G.js", │ │ "/chunk-VALZJMB4.js", │ │ + "/chunk-VAOB4JG2.js", │ │ "/chunk-VHUERUA4.js", │ │ + "/chunk-VJQR3OQG.js", │ │ "/chunk-VV6ZHKLO.js", │ │ "/chunk-VZC2YUAA.js", │ │ "/chunk-W3EHXDVY.js", │ │ - "/chunk-W3WYTWJF.js", │ │ - "/chunk-WN36MJWA.js", │ │ "/chunk-WXJTT6GG.js", │ │ "/chunk-XKTBNCB7.js", │ │ "/chunk-XU2E3I7U.js", │ │ + "/chunk-YH7JAVPA.js", │ │ "/chunk-YJ6NNGK3.js", │ │ "/chunk-YY3AIJQH.js", │ │ "/chunk-ZEGOSSOH.js", │ │ "/chunk-ZSD34TY2.js", │ │ "/favicon.ico", │ │ "/index.html", │ │ - "/main-WUIV3A3S.js", │ │ + "/main-NMCHICC3.js", │ │ "/manifest.json", │ │ "/polyfills-D4CWKFPZ.js", │ │ "/styles-Y6K4QT55.css", │ │ "/worker-OC7FNYPQ.js" │ │ ] │ │ }, │ │ { │ │ @@ -390,60 +390,59 @@ │ │ "/assets/themes/nord-polar-night.css": "3b790e539cd4e6a2bc1409bb5486c747d1ddf940", │ │ "/assets/themes/nord-snow-storm.css": "0586ddf104fb8944b2b1b05526566e9d312085db", │ │ "/assets/themes/rainbow.css": "ee65200ba809b4830928bd123544c43e5bab1dfc", │ │ "/assets/unicorn.png": "0326afe4a8f85faa5c3a01fd38efeafeb58094a2", │ │ "/chunk-2NLKHL2W.js": "1032608cf55bd95f067cb572bf97bf9035e1ae70", │ │ "/chunk-2NYJ54WT.js": "6b2058100c2940dca4d746dd3f5d18ab6c115902", │ │ "/chunk-2WM3YZAK.js": "6f10ea0dd11de995a697ad5b6848a8f54ce725c2", │ │ - "/chunk-327SFFJ7.js": "0f90706ecaa4ed47646c5354223442eec98291d0", │ │ "/chunk-3DA7NDG7.js": "dedf586a356a4e0ecdbfcd6bef11557538dca7ed", │ │ "/chunk-3E43H4SH.js": "33caa87bbac6b8a44c021550f0bba30292886b0d", │ │ "/chunk-3JK22HTK.js": "581706cfb4039120e40df8bae925ecfa28accdfe", │ │ "/chunk-3UB54IM4.js": "6dd0205087c3166a305b1af5ec8ad771cd5ce0e3", │ │ "/chunk-3XDH4HMG.js": "3c4a468dc0e1722ba82405c48d969c004e86c01c", │ │ "/chunk-3YQA2ZCY.js": "5a245d461a4cd129b8a557a8623997c0a13a59e1", │ │ - "/chunk-4TIGGGHV.js": "abd89a5934a80939d9225872c39691fc629390c9", │ │ "/chunk-4U7DROTX.js": "159f36eabd6e43fe9a29b6a366f46bc1811ff1de", │ │ "/chunk-4WKVJOAH.js": "755c38ce168a294972eb8d09e0b4d2ee35e45efa", │ │ "/chunk-5QROK3OX.js": "4e484c67a44d3c2536ee698b1652928e6a24a346", │ │ "/chunk-6FYAD2CQ.js": "5dac7a32fe4c55babb1e23fe74f0f4a627aa7390", │ │ "/chunk-6HDPB3YX.js": "04473f72d161f641d627e51ae147e9265d58896d", │ │ - "/chunk-6TSABQXM.js": "e6f91b49223111c74a871b6056e92a3c1861934a", │ │ "/chunk-74EGGIJI.js": "6e9db77832200c58ee2632ea87013dc191d89624", │ │ "/chunk-76QGHBDI.js": "8b65d6ae0073b42b13d40113362042c27d2b153b", │ │ "/chunk-7XF3V5GI.js": "eebf58b1b3255d1c6e91f051b479203536148f7f", │ │ "/chunk-A5MBRGPF.js": "1370eaa81f6ec887d8231e675fe4147619b78acd", │ │ "/chunk-A6QD6H33.js": "ec517b8d910ffcac343b58e04d3dbc538e2fd731", │ │ - "/chunk-ADCYWBC4.js": "cdd3a38f8f586d2abb9e8de91722969ca36bb6b8", │ │ "/chunk-AE7XKJXJ.js": "17c0475e2ddda43a9e2eae9e2e4971c976ffbfa0", │ │ + "/chunk-AG53IFIE.js": "3c784dad9c201d0f77280cf98b6cd01b1c6be2c6", │ │ "/chunk-ANYCFL6X.js": "265ceb169f783969ad8a05f499937e4009c9a329", │ │ "/chunk-BE62ACRB.js": "0d78b38fdd6c9925a05b2afd10dc9503765de280", │ │ "/chunk-BF66PHNY.js": "2e0b4e386b37fc059ed31c0b8be52c6adb0d61cb", │ │ "/chunk-BHLU5KMJ.js": "00ef336a36f6efe1dd841480a2ac81eaa9769191", │ │ "/chunk-BI2OH7XR.js": "56ecf41ba230a5212f9227853828905793ace7eb", │ │ + "/chunk-BIEIICW4.js": "19046e1ac3771b20de15330852e71c887295eb53", │ │ "/chunk-BOROUNNF.js": "459f904bd4a5c44bc789798d548ad8a666e2f15c", │ │ "/chunk-C4KDVV5E.js": "e55f93cce655327d03846756930cf1203a4ac90a", │ │ "/chunk-CIAWTZY4.js": "78ef0c25a31d64c62ebefaa3a2a1ca6160235dbc", │ │ "/chunk-DAWDIIWC.js": "165c0bab923b508419380c78249f314167d898c0", │ │ "/chunk-DMDKJLM7.js": "10f3e0d11a70c0e856d470e040ff88a4ae5261cc", │ │ "/chunk-DPS3MBSF.js": "a70c6a19512b89a04a4758ed248c4f7b57ca41bc", │ │ "/chunk-F7LW7WUC.js": "4228829db73cc94067210f61b4121e8287b11d9e", │ │ "/chunk-G3I24IXL.js": "8122c448d357f24625d649a7436c20d2049b600f", │ │ "/chunk-GYQZ4E6P.js": "c855ad0d63138a1a868a395490a58e8d4982f6ee", │ │ "/chunk-HKWYPOTM.js": "3f584ef322612305a41a5295ecd7b1f994ef17f6", │ │ "/chunk-HQZVBSHO.js": "389529c21c5ef77e84f71d623b5aaab138817d17", │ │ + "/chunk-HX6H4D5R.js": "0b2a12e3c419f6ad07f3664c24dc520a2de49066", │ │ "/chunk-I5HQRRLR.js": "d5500c03c401b90ae55af2866d3060915e2c8bd6", │ │ "/chunk-I6NHNS44.js": "7e6a64e0a48e6cb8c1604b06441f5e659fa4f939", │ │ - "/chunk-IH4C37MG.js": "dd31146ffb610432f491db4ccdc9dba8e759b05b", │ │ "/chunk-ILL7PQHQ.js": "b919fb134812d4182d6e8f5ee136a2d97ab51e41", │ │ "/chunk-IQ6PRZNS.js": "ea7b479dab4438d07b05377ca6e223ec80c4bac9", │ │ "/chunk-ISS7OXYA.js": "12445d1bd8ffed3dcbf70c9b6dc3bf550913a3a0", │ │ "/chunk-J6ISZPCF.js": "ff20018e5a31c01cb79ccdc781a96c9b5661bc34", │ │ "/chunk-JGLVFTHL.js": "d0c1039daad2b26f2d7bd0a372179bb463792d92", │ │ "/chunk-JIAINNPA.js": "904668a8f38e5e080e0bf44fcdf6a32d9d18e97f", │ │ + "/chunk-JJXTGRC4.js": "7e0dc907de76e1f075d3e9684333161c0ed580db", │ │ "/chunk-K2CLIKPD.js": "b5805b4069359576e05da8bfe71816a5f87dc66a", │ │ "/chunk-L3RTD537.js": "c20dcea0afab2bf6a7431d1c8dd47d0140a8aca5", │ │ "/chunk-LGJRHL6M.js": "fd06053ae2fa7464aeb166aac3ae4bb18162833a", │ │ "/chunk-LIA5ARM4.js": "70897dc2c4451b118aae4113f763d05d80bf306d", │ │ "/chunk-MASHVMAF.js": "c3e060e28a228fc25d8d7a1a90983cfc33f80afa", │ │ "/chunk-MHRVXTMU.js": "9c2f7e1a8cd7f0aa45e3d559bd5ddd44ba899569", │ │ "/chunk-MIRHI7I6.js": "04de9cc9bb32ccb7ba98fdb334be92c03d460950", │ │ @@ -455,52 +454,53 @@ │ │ "/chunk-NXHPN2SE.js": "c5d8433de4584321a176bfb4fd434053b490492e", │ │ "/chunk-O3XSPFWI.js": "5f56de03a106225a2ec63e24f64c9bcd7e1fe323", │ │ "/chunk-O4FSZO2U.js": "33612c13e474112de8f14be876c57b472ddb117b", │ │ "/chunk-ODC53ZA5.js": "1896164b6c361bd894bf3d469d3d81b757c06ea0", │ │ "/chunk-OVAWK6DV.js": "4361aa6648b214c9f6cc6a5bc622280f547db7f0", │ │ "/chunk-OXDOKNTF.js": "501996a33f7f3e92729fcabc7c0b3cad82f22134", │ │ "/chunk-P76QKORU.js": "6a520ec23d90b2dd9d11c59c5fb56b5870798138", │ │ - "/chunk-PBRU3XFX.js": "3276687d6c732d87bfbc8d626b59770b6cbcb109", │ │ "/chunk-PEJGMLLQ.js": "fe6775dde0b3e793079d9c7be74b708dd45a79ea", │ │ - "/chunk-QF7DVNE3.js": "36c2e4346bb161725b98d66307e293aee5830f78", │ │ + "/chunk-PPSDU5N6.js": "3f5d314a0b5a0f235b549b7ccea9b5ec725ae428", │ │ "/chunk-QH6TSZG4.js": "11a3ddd14763cdc8eed2c30ba41d0af9da668b64", │ │ "/chunk-QMJZV4FP.js": "44b4f94b479110e73b7d9b40b33afe36d0697ce7", │ │ "/chunk-QQNZ2EQ2.js": "127bd3d0ca7209821f08c6cbc7bb961c484f21cd", │ │ "/chunk-R44RDGNH.js": "37b52ba99e1d19e5d182b567e4d9b0d2dc9d1909", │ │ "/chunk-R64NO3YZ.js": "68337d38122becd3d459f981863a97e1e509a4f2", │ │ "/chunk-RHU3AIGY.js": "70f3005532610e087402505fa642745a0759fb44", │ │ "/chunk-RISNPNQN.js": "1c31921e9cecb1157d41212b5fd4b6f3f7f6726a", │ │ "/chunk-RVOBCK53.js": "28bcaa8c47007b8f4adbcc0e44240ca5b2aa478a", │ │ "/chunk-RXNLVNG6.js": "cab60bea4125b79fa7fbd995a24fcd640b0af593", │ │ - "/chunk-SEAKVT5E.js": "6a726c72799ec6d93727645e78d39f7349429cea", │ │ "/chunk-SFH7Q7UW.js": "e45f6251f46c1057ee5db17f63d1c767967b296d", │ │ "/chunk-SHCPU7P2.js": "228b10b47273bcc538ba0e7f9812dc6fb1915119", │ │ + "/chunk-SLB7M5PF.js": "99c07a7e704ebcda02e62cf8ec1c50106873d229", │ │ "/chunk-T2ZDFRFV.js": "69bf3f77040a2c6735f2985544ad00056ed13cc7", │ │ "/chunk-TFUMAMRZ.js": "6d49b70ed87c65546ae1828231c0da3c9c3bff53", │ │ + "/chunk-TILX7ESY.js": "eceb911c5c6d20a908faf9bf6c18e9b9b7deb436", │ │ "/chunk-TLXRLWM2.js": "b7b912222742a26c2a73a1c2b500683426be0e74", │ │ "/chunk-U233VVFY.js": "51f1f8a1d3f2ed2951838a10456ad42172522001", │ │ "/chunk-UPCMCXR6.js": "5efd38c4b52c6ce100c58f9c570447da03f84808", │ │ "/chunk-URYU4E6G.js": "c12ef861424945cca4f5d4faeed2686d6e70e50c", │ │ "/chunk-VALZJMB4.js": "3178219d2e9a366851c6f9c278783f9c5628bdc6", │ │ + "/chunk-VAOB4JG2.js": "09b46656dcf5b80fca6e1e5c600b4f9533276130", │ │ "/chunk-VHUERUA4.js": "42791c14f0ae5261a0cbe2010b8939c329ec89b4", │ │ + "/chunk-VJQR3OQG.js": "d88cbf3ecd52fc2148836e3a226a0471af18112e", │ │ "/chunk-VV6ZHKLO.js": "476e8b38d589d5430015746bbc0c55054449e532", │ │ "/chunk-VZC2YUAA.js": "623d3738465293b5c13dd6f74d5efb8025d3f1d0", │ │ "/chunk-W3EHXDVY.js": "23e1348651bae932954b8eb0918f95913e86d7bd", │ │ - "/chunk-W3WYTWJF.js": "57c8a8cdf08ce75689c1104deb016830234eacb1", │ │ - "/chunk-WN36MJWA.js": "f29dce7a4d1bd981856a1cb72a84d087d914a6f9", │ │ "/chunk-WXJTT6GG.js": "28fcd1c5ea59e7a03fad127e6112ecdecc816377", │ │ "/chunk-XKTBNCB7.js": "6494cc2bf7e0bbfb32dcf301b8a14af96b994b45", │ │ "/chunk-XU2E3I7U.js": "42be333379abd934534b707aa2e0824a038af868", │ │ + "/chunk-YH7JAVPA.js": "252430bae6eaf83e6eaf2b555b7ab81a703d28e3", │ │ "/chunk-YJ6NNGK3.js": "1ce2cd7e47f6de6c64979699c2d47b88f9ac2139", │ │ "/chunk-YY3AIJQH.js": "807628432566c02b2930d7774a6da086569919dc", │ │ "/chunk-ZEGOSSOH.js": "f902fc8f20f20cb362689d1008c20ec9a55da818", │ │ "/chunk-ZSD34TY2.js": "7c1c45968c7fbe4ed92cf94e34b5839905342c3c", │ │ "/favicon.ico": "041b337586bb0e48da6f4fdfc846ef3594373009", │ │ - "/index.html": "16e069394b766e9e83e7cc5656eee5c74c4c80d2", │ │ - "/main-WUIV3A3S.js": "9221b2b538460bec23605c0b8b5c38f831f5c019", │ │ + "/index.html": "95eca70bde7b42ac3f7bec77e1aa109fb8d76c74", │ │ + "/main-NMCHICC3.js": "c9d7c7a96da1f0ed738634ad47c4a50fdba2958f", │ │ "/manifest.json": "94d39d23fcd194a0c89eb3bcd838730cec7cabee", │ │ "/polyfills-D4CWKFPZ.js": "be63e19dcbf7539a31849701283857d1ebe28b56", │ │ "/styles-Y6K4QT55.css": "de63ca55473be33ee5b3f30d83004b3f735b6d8f", │ │ "/worker-OC7FNYPQ.js": "af4f7cd6209a2d59ab0d778ee2b1dd46f1c1db50" │ │ }, │ │ "index": "/index.html", │ │ "navigationRequestStrategy": "performance", │ │ @@ -518,9 +518,9 @@ │ │ "regex": "^\\/(?:.+\\/)?[^/]*__[^/]*$" │ │ }, │ │ { │ │ "positive": false, │ │ "regex": "^\\/(?:.+\\/)?[^/]*__[^/]*\\/.*$" │ │ } │ │ ], │ │ - "timestamp": 1760726139357 │ │ + "timestamp": 1761820906436 │ │ } ├── 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/main-WUIV3A3S.js.map ├── +++ assets/public/main-NMCHICC3.js.map │┄ Files identical despite different names │ --- assets/public/main-WUIV3A3S.js ├── +++ assets/public/main-NMCHICC3.js │┄ Files 99% similar despite different names │ ├── js-beautify {} │ │ @@ -23,15 +23,15 @@ │ │ t as ZD, │ │ u as Mc, │ │ v as Jb, │ │ w as qb, │ │ x as eA, │ │ y as Jp, │ │ z as Xb │ │ -} from "./chunk-IH4C37MG.js"; │ │ +} from "./chunk-HX6H4D5R.js"; │ │ import { │ │ a as An, │ │ b as ts │ │ } from "./chunk-74EGGIJI.js"; │ │ import { │ │ a as fT, │ │ d as _T, │ │ @@ -80,15 +80,15 @@ │ │ import { │ │ b as Zb, │ │ c as iA │ │ } from "./chunk-AE7XKJXJ.js"; │ │ import { │ │ a as ey, │ │ b as nA │ │ -} from "./chunk-4TIGGGHV.js"; │ │ +} from "./chunk-VAOB4JG2.js"; │ │ import { │ │ a as Ic, │ │ b as oA, │ │ c as ty, │ │ d as rA │ │ } from "./chunk-HKWYPOTM.js"; │ │ import { │ │ @@ -96,28 +96,28 @@ │ │ b as pO, │ │ c as GS, │ │ d as MD, │ │ e as JS, │ │ f as ED, │ │ g as Yp, │ │ h as jb │ │ -} from "./chunk-QF7DVNE3.js"; │ │ +} from "./chunk-VJQR3OQG.js"; │ │ import { │ │ a as ap, │ │ b as sp, │ │ c as PT │ │ } from "./chunk-MIRHI7I6.js"; │ │ import { │ │ a as tp, │ │ b as mT │ │ } from "./chunk-3UB54IM4.js"; │ │ import { │ │ f as fa, │ │ g as Vp │ │ -} from "./chunk-6TSABQXM.js"; │ │ +} from "./chunk-BIEIICW4.js"; │ │ import { │ │ a as YS, │ │ b as wD │ │ } from "./chunk-DMDKJLM7.js"; │ │ import { │ │ a as Ub, │ │ b as qD │ │ @@ -337,15 +337,15 @@ │ │ h as yo │ │ } from "./chunk-W3EHXDVY.js"; │ │ import { │ │ a as Jn, │ │ b as AD, │ │ k as _r, │ │ l as xc │ │ -} from "./chunk-ADCYWBC4.js"; │ │ +} from "./chunk-SLB7M5PF.js"; │ │ import { │ │ A as RS, │ │ B as FS, │ │ C as Rh, │ │ D as VS, │ │ E as vD, │ │ F as Fh, │ │ @@ -374,15 +374,15 @@ │ │ l as wS, │ │ m as _D, │ │ n as is, │ │ o as CD, │ │ x as Je, │ │ y as Ah, │ │ z as Bp │ │ -} from "./chunk-SEAKVT5E.js"; │ │ +} from "./chunk-TILX7ESY.js"; │ │ import { │ │ a as ar, │ │ b as uc, │ │ c as Eh, │ │ d as vc, │ │ e as Tc, │ │ f as Ph, │ │ @@ -13169,15 +13169,15 @@ │ │ var nI, oI = O(() => { │ │ "use strict"; │ │ eI(); │ │ Oo(); │ │ iI(); │ │ nI = [{ │ │ path: "config", │ │ - loadComponent: () => import("./chunk-WN36MJWA.js").then(i => i.ConfigPageComponent), │ │ + loadComponent: () => import("./chunk-PPSDU5N6.js").then(i => i.ConfigPageComponent), │ │ data: { │ │ page: "config" │ │ }, │ │ canActivate: [Zt] │ │ }, { │ │ path: "search", │ │ loadComponent: () => import("./chunk-J6ISZPCF.js").then(i => i.SearchPageComponent), │ │ @@ -13239,22 +13239,22 @@ │ │ loadComponent: () => import("./chunk-SHCPU7P2.js").then(i => i.QuickHistoryComponent), │ │ data: { │ │ page: "quick-history" │ │ }, │ │ canActivate: [ba, Zt] │ │ }, { │ │ path: "tag/:id/daily-summary", │ │ - loadComponent: () => import("./chunk-327SFFJ7.js").then(i => i.DailySummaryComponent), │ │ + loadComponent: () => import("./chunk-YH7JAVPA.js").then(i => i.DailySummaryComponent), │ │ data: { │ │ page: "daily-summary" │ │ }, │ │ canActivate: [ba, Zt] │ │ }, { │ │ path: "tag/:id/daily-summary/:dayStr", │ │ - loadComponent: () => import("./chunk-327SFFJ7.js").then(i => i.DailySummaryComponent), │ │ + loadComponent: () => import("./chunk-YH7JAVPA.js").then(i => i.DailySummaryComponent), │ │ data: { │ │ page: "daily-summary" │ │ }, │ │ canActivate: [ba, Zt] │ │ }, { │ │ path: "tag/:id/metrics", │ │ loadComponent: () => import("./chunk-HQZVBSHO.js").then(i => i.MetricPageComponent), │ │ @@ -13295,41 +13295,41 @@ │ │ loadComponent: () => import("./chunk-HQZVBSHO.js").then(i => i.MetricPageComponent), │ │ data: { │ │ page: "metrics" │ │ }, │ │ canActivate: [ya, Zt] │ │ }, { │ │ path: "project/:id/daily-summary", │ │ - loadComponent: () => import("./chunk-327SFFJ7.js").then(i => i.DailySummaryComponent), │ │ + loadComponent: () => import("./chunk-YH7JAVPA.js").then(i => i.DailySummaryComponent), │ │ data: { │ │ page: "daily-summary" │ │ }, │ │ canActivate: [ya, Zt] │ │ }, { │ │ path: "project/:id/daily-summary/:dayStr", │ │ - loadComponent: () => import("./chunk-327SFFJ7.js").then(i => i.DailySummaryComponent), │ │ + loadComponent: () => import("./chunk-YH7JAVPA.js").then(i => i.DailySummaryComponent), │ │ data: { │ │ page: "daily-summary" │ │ }, │ │ canActivate: [ya, Zt] │ │ }, { │ │ path: "active/:subPageType", │ │ canActivate: [$m, Zt], │ │ - loadComponent: () => import("./chunk-WN36MJWA.js").then(i => i.ConfigPageComponent) │ │ + loadComponent: () => import("./chunk-PPSDU5N6.js").then(i => i.ConfigPageComponent) │ │ }, { │ │ path: "active/:subPageType/:param", │ │ canActivate: [$m, Zt], │ │ - loadComponent: () => import("./chunk-WN36MJWA.js").then(i => i.ConfigPageComponent) │ │ + loadComponent: () => import("./chunk-PPSDU5N6.js").then(i => i.ConfigPageComponent) │ │ }, { │ │ path: "active", │ │ canActivate: [$m, Zt], │ │ - loadComponent: () => import("./chunk-WN36MJWA.js").then(i => i.ConfigPageComponent) │ │ + loadComponent: () => import("./chunk-PPSDU5N6.js").then(i => i.ConfigPageComponent) │ │ }, { │ │ path: "plugins/:pluginId/index", │ │ - loadComponent: () => import("./chunk-W3WYTWJF.js").then(i => i.PluginIndexComponent), │ │ + loadComponent: () => import("./chunk-AG53IFIE.js").then(i => i.PluginIndexComponent), │ │ data: { │ │ page: "plugin-index" │ │ }, │ │ canActivate: [Zt] │ │ }, { │ │ path: "**", │ │ redirectTo: `tag/${at.id}/tasks` │ │ @@ -29597,8 +29597,8 @@ │ │ re.log("Time window for completing sync started"), yield r0(2e4), re.log("Time window for completing sync ended. Closing app!"), fg.finish({ │ │ taskId: e │ │ }) │ │ })) │ │ }))) │ │ }); │ │ export default E5(); │ │ -//# sourceMappingURL=main-WUIV3A3S.js.map │ │ +//# sourceMappingURL=main-NMCHICC3.js.map │ --- assets/public/chunk-WN36MJWA.js.map ├── +++ assets/public/chunk-PPSDU5N6.js.map │┄ Files identical despite different names │ --- assets/public/chunk-WN36MJWA.js ├── +++ assets/public/chunk-PPSDU5N6.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-QF7DVNE3.js"; │ │ +} from "./chunk-VJQR3OQG.js"; │ │ import { │ │ a as ft, │ │ b as It, │ │ c as gn │ │ } from "./chunk-MIRHI7I6.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-6TSABQXM.js"; │ │ +} from "./chunk-BIEIICW4.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-ADCYWBC4.js"; │ │ +} from "./chunk-SLB7M5PF.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-SEAKVT5E.js"; │ │ +} from "./chunk-TILX7ESY.js"; │ │ import "./chunk-2NLKHL2W.js"; │ │ import "./chunk-SFH7Q7UW.js"; │ │ import { │ │ b as vt, │ │ e as Gt, │ │ j as Tn │ │ } from "./chunk-BF66PHNY.js"; │ │ @@ -2584,8 +2584,8 @@ │ │ return i │ │ })() │ │ }); │ │ go(); │ │ export { │ │ Rl as ConfigPageComponent │ │ }; │ │ -//# sourceMappingURL=chunk-WN36MJWA.js.map │ │ +//# sourceMappingURL=chunk-PPSDU5N6.js.map │ --- assets/public/chunk-W3WYTWJF.js ├── +++ assets/public/chunk-JJXTGRC4.js │┄ Files 92% similar despite different names │ ├── js-beautify {} │ │ @@ -1,15 +1,12 @@ │ │ import { │ │ - a, │ │ - b │ │ -} from "./chunk-4TIGGGHV.js"; │ │ -import "./chunk-6TSABQXM.js"; │ │ -import "./chunk-ODC53ZA5.js"; │ │ -import "./chunk-ADCYWBC4.js"; │ │ -import "./chunk-SEAKVT5E.js"; │ │ + s as a, │ │ + t as b │ │ +} from "./chunk-SLB7M5PF.js"; │ │ +import "./chunk-TILX7ESY.js"; │ │ import "./chunk-2NLKHL2W.js"; │ │ import "./chunk-SFH7Q7UW.js"; │ │ import "./chunk-BF66PHNY.js"; │ │ import "./chunk-LGJRHL6M.js"; │ │ import "./chunk-TLXRLWM2.js"; │ │ import "./chunk-XKTBNCB7.js"; │ │ import "./chunk-MNBCNST4.js"; │ │ @@ -35,10 +32,10 @@ │ │ import "./chunk-DPS3MBSF.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-W3WYTWJF.js.map │ │ +//# sourceMappingURL=chunk-JJXTGRC4.js.map │ --- assets/public/chunk-SEAKVT5E.js.map ├── +++ assets/public/chunk-TILX7ESY.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-10-30T10:40:00.123Z\\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 […] │ │ @@ -4648,15 +4648,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-17T18:32:15.213Z\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-30T10:40:00.123Z\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 () => {\n const darkMode = this.darkMode();\n localStorage.setItem(LS.DARK_MODE, darkMode);\n },\n { allowSignalWrites: false },\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-SEAKVT5E.js ├── +++ assets/public/chunk-TILX7ESY.js │┄ Files 99% similar despite different names │ ├── js-beautify {} │ │ @@ -10248,8 +10248,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-SEAKVT5E.js.map │ │ +//# sourceMappingURL=chunk-TILX7ESY.js.map │ --- assets/public/chunk-QF7DVNE3.js.map ├── +++ assets/public/chunk-VJQR3OQG.js.map │┄ Files identical despite different names │ --- assets/public/chunk-QF7DVNE3.js ├── +++ assets/public/chunk-VJQR3OQG.js │┄ Files 90% similar despite different names │ ├── js-beautify {} │ │ @@ -1,15 +1,15 @@ │ │ import { │ │ f as V, │ │ g as X │ │ -} from "./chunk-6TSABQXM.js"; │ │ +} from "./chunk-BIEIICW4.js"; │ │ import { │ │ a as L, │ │ b as $ │ │ -} from "./chunk-SEAKVT5E.js"; │ │ +} from "./chunk-TILX7ESY.js"; │ │ import { │ │ b as F, │ │ d as W │ │ } from "./chunk-ZSD34TY2.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-QF7DVNE3.js.map │ │ +//# sourceMappingURL=chunk-VJQR3OQG.js.map │ --- assets/public/chunk-PBRU3XFX.js ├── +++ assets/public/chunk-AG53IFIE.js │┄ Files 86% similar despite different names │ ├── js-beautify {} │ │ @@ -1,12 +1,15 @@ │ │ import { │ │ - s as a, │ │ - t as b │ │ -} from "./chunk-ADCYWBC4.js"; │ │ -import "./chunk-SEAKVT5E.js"; │ │ + a, │ │ + b │ │ +} from "./chunk-VAOB4JG2.js"; │ │ +import "./chunk-BIEIICW4.js"; │ │ +import "./chunk-ODC53ZA5.js"; │ │ +import "./chunk-SLB7M5PF.js"; │ │ +import "./chunk-TILX7ESY.js"; │ │ import "./chunk-2NLKHL2W.js"; │ │ import "./chunk-SFH7Q7UW.js"; │ │ import "./chunk-BF66PHNY.js"; │ │ import "./chunk-LGJRHL6M.js"; │ │ import "./chunk-TLXRLWM2.js"; │ │ import "./chunk-XKTBNCB7.js"; │ │ import "./chunk-MNBCNST4.js"; │ │ @@ -32,10 +35,10 @@ │ │ import "./chunk-DPS3MBSF.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-PBRU3XFX.js.map │ │ +//# sourceMappingURL=chunk-AG53IFIE.js.map │ --- assets/public/chunk-IH4C37MG.js.map ├── +++ assets/public/chunk-HX6H4D5R.js.map │┄ Files identical despite different names │ --- assets/public/chunk-IH4C37MG.js ├── +++ assets/public/chunk-HX6H4D5R.js │┄ Files identical 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-SEAKVT5E.js"; │ │ +} from "./chunk-TILX7ESY.js"; │ │ import { │ │ N as pi, │ │ O as Xi │ │ } from "./chunk-XKTBNCB7.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-IH4C37MG.js.map │ │ +//# sourceMappingURL=chunk-HX6H4D5R.js.map │ --- assets/public/chunk-ADCYWBC4.js.map ├── +++ assets/public/chunk-SLB7M5PF.js.map │┄ Files identical despite different names │ --- assets/public/chunk-ADCYWBC4.js ├── +++ assets/public/chunk-SLB7M5PF.js │┄ Files 99% similar despite different names │ ├── js-beautify {} │ │ @@ -1,11 +1,11 @@ │ │ import { │ │ U as Ar, │ │ V as ct │ │ -} from "./chunk-SEAKVT5E.js"; │ │ +} from "./chunk-TILX7ESY.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-PBRU3XFX.js"); │ │ + } = yield import("./chunk-JJXTGRC4.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-ADCYWBC4.js.map │ │ +//# sourceMappingURL=chunk-SLB7M5PF.js.map │ --- assets/public/chunk-6TSABQXM.js.map ├── +++ assets/public/chunk-BIEIICW4.js.map │┄ Files identical despite different names │ --- assets/public/chunk-6TSABQXM.js ├── +++ assets/public/chunk-BIEIICW4.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-ADCYWBC4.js"; │ │ +} from "./chunk-SLB7M5PF.js"; │ │ import { │ │ K as Ce, │ │ L as Je, │ │ j as Ie, │ │ k as Xe │ │ -} from "./chunk-SEAKVT5E.js"; │ │ +} from "./chunk-TILX7ESY.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-6TSABQXM.js.map │ │ +//# sourceMappingURL=chunk-BIEIICW4.js.map │ --- assets/public/chunk-4TIGGGHV.js.map ├── +++ assets/public/chunk-VAOB4JG2.js.map │┄ Files identical despite different names │ --- assets/public/chunk-4TIGGGHV.js ├── +++ assets/public/chunk-VAOB4JG2.js │┄ Files 98% similar despite different names │ ├── js-beautify {} │ │ @@ -1,11 +1,11 @@ │ │ import { │ │ f as ie, │ │ g as we │ │ -} from "./chunk-6TSABQXM.js"; │ │ +} from "./chunk-BIEIICW4.js"; │ │ import { │ │ a as re, │ │ b as oe, │ │ c as ae, │ │ f as le, │ │ g as Oe │ │ } from "./chunk-ODC53ZA5.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-ADCYWBC4.js"; │ │ +} from "./chunk-SLB7M5PF.js"; │ │ import { │ │ a as Y, │ │ c as xe │ │ } from "./chunk-P76QKORU.js"; │ │ import { │ │ c as W, │ │ d as N, │ │ @@ -319,8 +319,8 @@ │ │ } │ │ return t │ │ })() │ │ }); │ │ export { │ │ rt as a, De as b │ │ }; │ │ -//# sourceMappingURL=chunk-4TIGGGHV.js.map │ │ +//# sourceMappingURL=chunk-VAOB4JG2.js.map │ --- assets/public/chunk-327SFFJ7.js.map ├── +++ assets/public/chunk-YH7JAVPA.js.map │┄ Files identical despite different names │ --- assets/public/chunk-327SFFJ7.js ├── +++ assets/public/chunk-YH7JAVPA.js │┄ Files 99% similar despite different names │ ├── js-beautify {} │ │ @@ -41,15 +41,15 @@ │ │ p as xo, │ │ q as nn, │ │ r as ko, │ │ u as Cn, │ │ v as Fo, │ │ y as yn, │ │ z as $o │ │ -} from "./chunk-IH4C37MG.js"; │ │ +} from "./chunk-HX6H4D5R.js"; │ │ import { │ │ a as $i, │ │ b as uo │ │ } from "./chunk-74EGGIJI.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-SEAKVT5E.js"; │ │ +} from "./chunk-TILX7ESY.js"; │ │ import "./chunk-SFH7Q7UW.js"; │ │ import "./chunk-BF66PHNY.js"; │ │ import "./chunk-LGJRHL6M.js"; │ │ import { │ │ e as Pi, │ │ f as co │ │ } from "./chunk-TLXRLWM2.js"; │ │ @@ -2249,8 +2249,8 @@ │ │ return e │ │ })() │ │ }); │ │ nr(); │ │ export { │ │ Xl as DailySummaryComponent │ │ }; │ │ -//# sourceMappingURL=chunk-327SFFJ7.js.map │ │ +//# sourceMappingURL=chunk-YH7JAVPA.js.map