homebridge-eufy-security 2.1.2 → 2.1.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.angular/cache/13.3.8/angular-webpack/5c469ae2ec9b3e3444d34d56e7c70f3aa2560d00/0.pack +0 -0
- package/.angular/cache/13.3.8/angular-webpack/5c469ae2ec9b3e3444d34d56e7c70f3aa2560d00/index.pack +0 -0
- package/.angular/cache/13.3.8/babel-webpack/002b767f336bba4a19522b7001fdc9b0.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/01030dc9cf6ace516c5e21a11a51e514.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/016384ad7d62e5dbc2ee70c28b77bd33.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/031cd7cdf7943a415e924a9bd8128beb.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/052db9656c92d22373c12ebe3e254dd4.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/0531356196812f38430f56879f62470e.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/05725b64be0203c8d738c859f49ff405.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/062f6b5564c03c877d5ca52593b3b84b.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/065481f4d76a32e7e22e45cbaaf7825f.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/0666a98d8aab522670ce30753fd2f458.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/06dae47ab777cda8f0450790afc70025.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/07327b5d1e655671ee9b925dd372d49b.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/08004e90d212fca2a295493a98f3ba77.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/08774f00ef3c205e99175c2b9da49f2b.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/0af00780c4947ca8fd33e0b65cb5ea72.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/0af971038ef69574cca173d8fe2103ec.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/0b0b779faf1c39010031922b0e26ea0e.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/0cc5f5c0d0699ac0e44f99d1e88cd4c3.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/0ea0dd52ab9118e6d87a54ddc6b131ed.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/100429b5082c9f5b148d923f63be053b.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/10a1421cf7b46f7b3a45fb4d8219fe91.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/11e1f133849ff16a3097bdfe6fe5ee13.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/1270c1ff7a60022a1aa57342495267a1.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/132c8edfd0cd38acf02806ab58e8e342.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/13efa114bcdf71c8d1dd6e357fc96b38.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/14cc9c26f157ea0ed289c80aa16f84f4.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/153924e34aecb770553db2728af5931e.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/1550d75086d96874e41f3a9d370731f4.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/1a7f6499cefe53a91f2f8667d50cdbca.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/1a8288e5abb45e773ad1a85443bc5657.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/1b8dee5bab79ed93f24f0d6da8092510.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/1bd605fdf506ed9a0ff60978ef2df4b9.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/1bf109ad03caa833e13e667c1d9f2e47.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/1c9227ff67ce23ac82a282e3fb06c095.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/1cfe39783d86ba5c07e5614b1ec404f7.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/1dbc0980fd50e2f2fafa29f1763d1fe1.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/1dfb517adcaf071e8bd2ab77a28b1d35.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/2280aeda8abc7b63f49942444aec136f.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/23ff81c6e504d78e456e195f76a3621b.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/2532da45d53ab9d70eb682a31552950b.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/25647909666a00be07bf38169e041be2.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/258ce5624159326d68ae8aee3732119b.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/25cc498a9011bfe34a0c1febeae89e16.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/261a759a77de28fa767c29524940d6cc.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/26269fd9cae4fe30738831979db08c38.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/270221a53faa5e3c9061a0e8af50bb86.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/27d4bf45f79956b092b163ad19cf9e89.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/29a8da37097e6c923af711271baec17c.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/2d054cedefc8ff37848a2616550b8aaf.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/2d4670a3c225024b10ab496350f7aee3.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/2d7e93363c9300593386133460b237f8.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/2eef96834e778035a7937b18ea6143fc.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/2f1dba70cd0bdc43524b8b7a65bacb29.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/2fb65b04240fcce5b926c609f2400529.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/2ff9789499e2786f623bf0db087e88d1.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/30448d7918d0317a2c085755868cf6ca.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/30d576b2a16732c44ce6053b6aa974e9.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/325abc3f4c36271afbbcefde8586dfb9.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/32ce9fee8ef079a8a53d503a4d7261e5.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/34415e07a1f080036d319f9b2c38f651.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/344e62d8fa5508cbe60258b031745896.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/34cb39d1ff500829727fee82bfd1f6b7.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/34d4df2bd91b606a2d05b63a3f91cd67.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/371e1540688780cd53699c01d3cbb3d7.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/3798287f8a756c447af5d2c202139966.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/37cc822bd5240b358dc56fb6a8f72cab.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/37cf9e3961050209da17e3643f9b96a2.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/393adeab7f49f0dc13085c23473fa88c.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/3a4cd0895f382899b668066a8493f3ce.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/3b2a3070b835723a9b1595e7d1a07359.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/3ba824534546af066a817fa0a3f400d3.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/3c0153bae74856d5b87a9d550c21a9eb.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/3c98b4603069d16c8d5574f7e887d943.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/3d0f141c3d5a487cc999dfd4e46c7e76.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/3da8a56fc5b1a180258bfc49d495dd0a.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/3dec37f90ad593c5e046d12e3fd83212.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/3e9091097711fd6166dbe75a30a2a4b9.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/3ef8f2b32f318f0bb4d6741b36153c18.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/3faa2db6dd6b37bf84cf23df280ae371.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/401cf04b9635bf4287fae7d54ac85e10.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/4143509c8fef21f44cadcd1ea2f332d8.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/41e9bedcdebbf887933887ca4cf22c2a.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/422cb89a641d38c1d5501c23b7c016a8.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/42a45fce70dece14c2bf55a986045606.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/42ecb9d49401cbdc4351b2ba7bfd1665.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/44f114c3483c720ec820b3feb1d59d05.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/44fda3bdb9741b14b6c76f839d37b7ad.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/464348a2dc9f5a7801e593b16b322bf5.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/4649f81af11ab967f112df339ff5769d.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/465fcc59e903556ea77850f0f79a8471.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/468b6d85983ecc7c976b7fdbe1c3cded.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/47173d576132855887972723e24015cd.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/4829478c5a8b97334cdec2218b002975.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/484d86bf741b6c5e6081efd4394c19c0.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/489f8f732e234c7ac2ec3e006bc677c0.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/48b0ff30bcd8bf1a1241fa9ba2e2a721.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/4984f233d58a807c95d77c58760bb8d1.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/49968fac28967061f8ba0773544aa4d4.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/49f24e3c6e037b60aaa97dca0732729e.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/49fa7418f40089c10022436e32588e26.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/4b4c45724ccac31a75716db793d78301.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/4c0e3dde3a954173292d3507ae8d8800.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/4c4a47266dbbd98ce6017fc2c4c16ab3.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/4c96fba9bc62fb6f1c63003516298f1c.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/4cca923dd39b1b68e675cb8d3e950a52.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/4daf0fe84bb8cae6a38a04196ec98cc4.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/4df0a5af25e9de5468e7ba40b7fee3bf.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/4e3522f06633365908c6a755ee4f7ae2.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/4fe2c18c7438dcc8d3bd1923274e2436.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/5009f4f03e78e7231475ebacb4d3cb2b.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/5033d4f94ec879440ab69ce7414f6486.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/5033f8defd60862ef0fe3cb41f2a927d.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/50a24abc129121eab5bcc4e0e7013ba9.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/51b3ec1d8e0a6bc69d42eaf0f1daeccb.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/51ca9e5390150126951cf0e49ed0f2fe.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/5345701941753864dbc3d6a2a1d4a015.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/53a8d17b51367157500e522b7c6d8197.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/54f97adf03da9afd3a08ddfaf49eab08.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/5504faf61da3e420003d77c44633c4e4.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/5563340c9e848ed24018ba313024fd8a.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/55bc0b6328492e14e699699ca9262bfe.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/5714c49932c371c6da63af63a01bddfc.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/57168bffb5e0bdca5ac4cf7f7ad84c16.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/57fbd00776674a76b440117bbe06a06b.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/5a077e69c799caf22d23efae17cf1e2d.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/5aac8614496f60c990efe8f74fdde586.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/5ab6a0ec43a189cdfe1e3ec22227730a.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/5c48bf55a0b28ef23d9a4576b5140e1d.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/5cd0b3cf17233c2754f8c98f1fda3e6c.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/5d4f879a80a4d6e46d0d8bcef1330395.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/5f9209a5cb234d569edc9200c749e2e0.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/6144ffa2c0dbc83bf8d9803a0a62491f.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/620fd3110133f761d0b7931d2f26b9a3.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/626979296b5ad1d3e1d0239c4393cc8b.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/627c2de9e10f88ad60b4ecd050dc9e87.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/62e89a7b9a089e888beaf0e58074cc3d.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/63d96b6b85ee5b164ad31fa4f62a4c37.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/63fa8926e36f9a08b3edd4612120d091.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/6461bbfdc47be7c54acdceb1e912bd1f.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/6571b553a64d8710e2d993fb3c17d791.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/659a925ca3b85535e82d6e8e3bd8321f.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/667e152369048e521dc578dbfe705afd.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/67c2867db19110bc07d468a31663b082.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/6915cdb3b410d12086de37baa1b80a13.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/69f6c96e258b8f5cbaa6ef8a0968ea8d.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/6ab4d8e3aa8e69681619e3dcfa7c2b1f.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/6b5fe499289b5a30c0d55d5b26d405d9.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/6bd846c9cb2fa982d31fb84286711398.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/6c0d66bfaa813d1decfd38bb748f1629.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/6c6837527a1673b4a16b4641ca2443c2.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/6e5845a65dd2f18c67922fc986035589.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/6f9d93a23559c2592f58781802cdbfad.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/6fdcb04b6b486092a35f2a562b470132.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/6fe9064763ddc74eb2e60b19bdcd348a.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/706c71f4c0a758cd7eb5422a0556cd8d.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/708bbfec6aaa490c1ee1a4a2db0c9dce.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/72d1926b6da79407ac2307aa242b7441.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/741fd2072a66ddffb835ab604c7b2348.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/74dfdb01aede70196bb29e3b8ef656da.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/75b409f8a1b798089336a83c230990a7.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/769f290e0375c736b7c71d24a0116679.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/76ddbf24cc7c413441a3d9591e8bb7d9.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/77751a54089601bdd7607b5509d66e23.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/77ce825c7716d5316a0f16c42452a87b.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/78be25a27f5b0e5db1fde15164e5dbcc.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/78ee5111123bf9926f2196ef82161ab3.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/79279197a3876a629e83e4a210b9b4d1.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/7977f6f82cf1646ae7e8be3a9362dc45.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/7a408d4d78bda49400eebbaf10a41695.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/7bb709bbff1e7f63cabf9ebf6424812a.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/7cb455299ee59fd075819074454baad8.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/7d9bc884038ee3ce50b86af6c49a172c.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/7f2a10f1c76f0ccbc31fb4dbfc83cf79.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/8003eeff572554d1ecf833627e8013b5.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/810a0190c65ff4a7163712fff1ce5589.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/81a9bc9d5a78eb9336fda4a4b51a9db1.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/825a38018882116e97529b92d3e971bb.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/827322420b0bf4e571321c200204f131.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/83baf9ca4e3395d2d5e5b924c74b5d69.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/83f118a093bfed771c90b2be60915ec2.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/86f90bd133cc14bd5e56f0799ddf9078.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/87851d6e26a3d008e043f7dfe633fed6.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/87b764acce5c285ebc92c67a512be949.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/886449f9f291fa3749aa80e90b3b9baa.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/8996307ea201cc088e8ae52c3147034e.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/8ad06ced1b426df27f86e698e23cd7bc.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/8b72b92a68c0aa36907479d54f6054ff.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/8b87157fd8f1fd92951de100c4338217.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/8d9f1796f742e95e3cfca5b9d522de84.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/8f69db7fd3359e9a1bd0697ba8267a8c.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/8f7d13df8bb26b1cf12a1a66af10a642.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/8ff6cb151e5ed105330f8dd6869861e2.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/905811c589a08ff992dd16401158f01d.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/91bfe0227693f3f6a28b93f16ce90aba.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/92e32b8e0b7d6cfa56e253e9949b28b5.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/93022f8c3568cc0763b7bad0ee433b8b.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/938bb3acf3bd6d51461354f14ba81282.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/9400d7ebd38390b019c049d6c636db71.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/947f408ca8e3872a9cfa4163c2c284c8.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/95f4a24c39887555c0e1d85b1979bcf6.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/9617d48f11c90169d8297e26a46c26d7.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/98ba64e212e975e34df2fcc90d0caf6e.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/9ad5a1f9a21e742680cf3cb1818861ad.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/9c2c51a3a60e6d9f9165b003e76d401a.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/9caf482a8cafdd62827fb068390c19d2.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/9cdd3dce1fca0a68c50c30c3b154784e.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/9dd9f9069a5a9d39bff4ba3aebf3aacd.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/9e04c25c398c9641b70773472b91e9f4.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/9e67ca1c65c2b233d408cb44f808ab1f.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/a06a5557d63854b094d704445b9cbba0.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/a0cba8d6bad5dbf6e2cd9c1dce6a6d8c.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/a17ae6b26968359520d47b0650868869.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/a19e2c547578cfc1624d80296e6cc6e9.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/a3cc87818516e8313e437b957c96de27.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/a63c7a2e141525144e120979dfab330e.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/a77291233507e897c763cd5708171f2c.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/a9d0e9a36e846d7722eb6cbf86cf0eab.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/aa8d07367b1673dc078e853d9f54bd4f.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/aaa7865da0ed6c92e751d36c340f0412.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/ab14fddae15293d3e96649edb59ab6ee.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/ab5001b86bfe76ad7eabaa3bb03ee91c.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/ac115cfdb4ae57d5be899b6109d5c66d.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/ad5fd8e37c0ee6ec03716556349bcd7c.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/af15b0ed03ff515cf83a61a8f8ba8114.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/afd65bb5d81dd8ed61398e262960e379.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/b088264162bac1b5481bed0300f6aa8c.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/b10dbba09a3bfc69ebac1af564d03ab0.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/b11cb6660865c10be2d7a63cb962fb22.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/b2f5da40326881237ded1223a9e2b91e.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/b308ff5fbdb2e0d0962a00b3fdb4bba3.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/b4a250ad486dbf53468ea3f79f1aa56e.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/b4dc46a9366a3638f5263324f76d1257.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/b5214ad5a0cd4b989daa7cf3b2c81788.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/b54ab58104a20cf6abd4a7ade0cb5efe.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/b67b8d5d0e99959f9b731f548adc8bfa.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/b6b67c74aff89c2642a888b7375ab497.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/b78bf462c67d0084c64d890dd61e44a5.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/b7b45e6f3d9017ec4d9a9505ec6b1032.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/b902ae2d3307471e3f109cafebff941b.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/ba20ff82523086fc151c328e0fdc4e4e.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/bb5667c873411096eeb80085b1ca161e.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/bb58549725b01927dafeb42503c665a8.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/bb95ba87259582460ac5794209b3da28.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/bbb58b2daf454bd0a76ec382e06b07b0.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/bc4011f3189c2f439af86f17561ec9ce.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/bcbfbc473b03621491e4aba8e3148afc.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/bdf02e15e2b0f2252eec6075bfe0656b.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/bf69385e02b170469c07539aa0e90b86.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/bffbc2e7cd917a26abe867f247a50355.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/c01e2106240c1038b3f131aaacdf3127.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/c03b6674aa649f98a7f74af2be55e968.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/c12caf9d4638d85c0f0f11c0cc1f60f8.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/c151b4d148d17e99d9078e817b5cbed7.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/c21157f72fa81b896cfc69398590ffcd.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/c3d1530cf1bdc0040772700037b47739.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/c3e6c41249e1d8472be77446873e1863.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/c4118a992fb6bea0691521256e115d01.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/c42938d588314e5b841269e3b53d04b6.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/c4334ab9356f466b6056f380ab481291.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/c45c0e77d8f42cf281137812403551db.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/c527cc7cf1eaafe2ef74a5b64bc41bca.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/c5e17599d9c6b12eb0529b7431b1196f.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/c5f513e2805dbebd48256ec6d3d095a8.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/c6d1565e62b101ed183b3f447b21e774.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/c71837e43e0372efdecc0e3b9578f599.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/c926a68c65f1f4e1cb91c6d9136d43a3.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/c933131ed6ab617ba88b8dcf1c32f88d.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/caf3200b607bc0d82b1e238a1fa92e3e.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/cb5688b77172c4f2464646fb48434431.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/cc7c1b7d60e30e27fc3ac384ca5790c3.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/ccf739c4cd78fe256f7fe4c3d8ecb5a6.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/cd7be29a67ce0a719a6bba6b756c968c.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/cdf324523d7093bd7d83db7315f1e53d.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/ce55f0ec957ad17390ca1626b0fa54dc.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/ce83a29846bd4d7c9363952117125cd8.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/ce87faab295452b86a55b10f3328e88e.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/cee8ad61bbb1c8501799c125130713e2.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/cf725e286e3156c367900f91bb6fe0f4.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/d00e50c8700890444ea390a517892393.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/d13e22c859c1503702dce6b3d2bdb825.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/d296e6e39d7b1da9a2730657c6b9a8a8.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/d382ecfa087acfe724fe1d27b8aade26.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/d4b1b33e1be5887d55716f5de6c8619e.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/d66d388dd8029afedacbb3bf5eea9f2a.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/d670c34e6297a533c9f989c256fa904e.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/d6ea2139d4e7ebde4fb5d9ca685f6156.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/d97f611e91ff2e958d4bd563d5577d4c.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/db0e61ea8a2bf6305dc6436ced7873bd.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/db2764d8627cf6541a57cdc803977954.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/dc2f0c3883ddba73b7610bad5d3e5a7c.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/dcba1c12c2235201507746f191aaae34.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/dd132f3f48c7788bd78bb61cd39389c0.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/dd14d17f6181a4e509f4b1af92e01189.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/dd9efed6889cb2f2c9dcae0ac34cfd3b.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/de5be13a077040d81a6be92739ac9424.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/df3e709dc4474fbc4a1ffba664469834.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/df6c6ef53d881b53b959a9395f172cb5.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/dfddd41dde86972d7d471f6655361e6b.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/e11abe9c0fa21ad541612d9d18926c83.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/e177a98234698cea48aaeb7a5c3d62d9.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/e2bb776bc5c66c1b7cb2d8710f0075bd.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/e332faec2bafe37908a0aa88a1ac1aa5.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/e4d51765fc0d4ef65d8e4283090bc08f.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/e50b91f0d84ab2adfede57f92162e129.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/e65a6f02a72fab74ab88d8cea6fb91a4.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/e68b59f5f6e55f9bed2db51b554a6d9b.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/e6d1b308346f3e288e57688424c071f9.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/e72efbcdf47558156e4c4c5c03ad9922.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/e74d56fbbec5a1cee2fe5efc42f42482.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/e7afea9fd4aa90dc195b45e7eafa08ed.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/e8538d1514392ef4bd9f4175e3859b64.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/e92299f62ba1e277c1f0febcc42f6f6c.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/e9ce2aceaa98de9c401e914987675185.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/eaf2f107db46caef610605458d470dd6.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/ebe9fcdfddc0049f2a3539bdf372182a.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/ebf00c7d547a3fd380303a0677afd6fd.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/ec62a0272ab85622ae90a9ded37faac6.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/ec6ec0a385bca5a0af84b0764b68f2eb.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/ed25182b670a7ef1f75cffc990301abd.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/ed859e0eb8c893c50d86dc06f044e2f2.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/eddb54479fc84d9a7fb12de46687ccbb.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/efa7bcb095fd93cacda7678eab41687b.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/efc0dedea79d75441c21fd90de356e24.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/f0af07e622f23258c8ca1e7c5bfec120.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/f0c44de2465dcbd9e88c8a03509d0256.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/f1162e154ed889f4a293300795d69259.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/f177c4de766e451f4beff650f84ecb5a.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/f25518eac9526bb125e8e70536d9873e.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/f2c1dc64b41106092be1791fec494ac9.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/f34ab63ab5b8337d0023eab174e66515.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/f3811f682513cc105b9f7980bf5465ca.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/f46796dc6bf3d6d7c3611e8d607bdcda.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/f48109d62480024bdc089c7318d3d104.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/f50dbb569f9e2a941366366e228b7e7b.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/f56763c4978e4735e2b8fabbd1774db6.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/f6abd512586dde031ecd5b3305daaf95.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/f70e5c60d842462753b2f323debb32e4.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/f7a848e3fc241a5c78b17669a7bd1fa7.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/fa2e761077559ae9ecc7e380ec7f3aef.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/fa5305b0e1d7ebfd40cfa6b317c98780.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/fa53f4380f7b2ff4417f9785ac323634.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/fa5ce8a874423e1be3adde2dab6bd603.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/fddb68d0661d96a618e00d6674ca7dad.json +1 -0
- package/.angular/cache/13.3.8/babel-webpack/fe890ed50c86989a4ac3c56913c146bc.json +1 -0
- package/CHANGELOG.md +12 -0
- package/homebridge-ui/public/index.html +1 -1
- package/homebridge-ui/public/main.ef1d40566bd2fdc0.js +1 -0
- package/package.json +1 -1
- package/homebridge-ui/public/main.ece8fc9a34c8f89b.js +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import { operate } from '../util/lift';\nimport { createOperatorSubscriber } from './OperatorSubscriber';\nimport { identity } from '../util/identity';\nimport { timer } from '../observable/timer';\nimport { innerFrom } from '../observable/innerFrom';\nexport function retry(configOrCount = Infinity) {\n let config;\n\n if (configOrCount && typeof configOrCount === 'object') {\n config = configOrCount;\n } else {\n config = {\n count: configOrCount\n };\n }\n\n const {\n count = Infinity,\n delay,\n resetOnSuccess = false\n } = config;\n return count <= 0 ? identity : operate((source, subscriber) => {\n let soFar = 0;\n let innerSub;\n\n const subscribeForRetry = () => {\n let syncUnsub = false;\n innerSub = source.subscribe(createOperatorSubscriber(subscriber, value => {\n if (resetOnSuccess) {\n soFar = 0;\n }\n\n subscriber.next(value);\n }, undefined, err => {\n if (soFar++ < count) {\n const resub = () => {\n if (innerSub) {\n innerSub.unsubscribe();\n innerSub = null;\n subscribeForRetry();\n } else {\n syncUnsub = true;\n }\n };\n\n if (delay != null) {\n const notifier = typeof delay === 'number' ? timer(delay) : innerFrom(delay(err, soFar));\n const notifierSubscriber = createOperatorSubscriber(subscriber, () => {\n notifierSubscriber.unsubscribe();\n resub();\n }, () => {\n subscriber.complete();\n });\n notifier.subscribe(notifierSubscriber);\n } else {\n resub();\n }\n } else {\n subscriber.error(err);\n }\n }));\n\n if (syncUnsub) {\n innerSub.unsubscribe();\n innerSub = null;\n subscribeForRetry();\n }\n };\n\n subscribeForRetry();\n });\n} //# sourceMappingURL=retry.js.map","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import { BehaviorSubject } from '../BehaviorSubject';\nimport { ConnectableObservable } from '../observable/ConnectableObservable';\nexport function publishBehavior(initialValue) {\n return source => {\n const subject = new BehaviorSubject(initialValue);\n return new ConnectableObservable(source, () => subject);\n };\n} //# sourceMappingURL=publishBehavior.js.map","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import { Observable } from '../Observable';\nimport { innerFrom } from './innerFrom';\nimport { argsOrArgArray } from '../util/argsOrArgArray';\nimport { createOperatorSubscriber } from '../operators/OperatorSubscriber';\nexport function race(...sources) {\n sources = argsOrArgArray(sources);\n return sources.length === 1 ? innerFrom(sources[0]) : new Observable(raceInit(sources));\n}\nexport function raceInit(sources) {\n return subscriber => {\n let subscriptions = [];\n\n for (let i = 0; subscriptions && !subscriber.closed && i < sources.length; i++) {\n subscriptions.push(innerFrom(sources[i]).subscribe(createOperatorSubscriber(subscriber, value => {\n if (subscriptions) {\n for (let s = 0; s < subscriptions.length; s++) {\n s !== i && subscriptions[s].unsubscribe();\n }\n\n subscriptions = null;\n }\n\n subscriber.next(value);\n })));\n }\n };\n} //# sourceMappingURL=race.js.map","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import { operate } from '../util/lift';\nimport { concatAll } from './concatAll';\nimport { popScheduler } from '../util/args';\nimport { from } from '../observable/from';\nexport function concat(...args) {\n const scheduler = popScheduler(args);\n return operate((source, subscriber) => {\n concatAll()(from([source, ...args], scheduler)).subscribe(subscriber);\n });\n} //# sourceMappingURL=concat.js.map","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"/**\n * @license Angular v13.3.11\n * (c) 2010-2022 Google LLC. https://angular.io/\n * License: MIT\n */\nimport { ɵDomAdapter, ɵsetRootDomAdapter, ɵparseCookieValue, ɵgetDOM, DOCUMENT, ɵPLATFORM_BROWSER_ID, XhrFactory, CommonModule } from '@angular/common';\nexport { ɵgetDOM } from '@angular/common';\nimport * as i0 from '@angular/core';\nimport { InjectionToken, ApplicationInitStatus, APP_INITIALIZER, Injector, setTestabilityGetter, ɵglobal, Injectable, Inject, ViewEncapsulation, APP_ID, RendererStyleFlags2, ErrorHandler, ɵsetDocument, PLATFORM_ID, PLATFORM_INITIALIZER, createPlatformFactory, platformCore, ɵINJECTOR_SCOPE, NgZone, RendererFactory2, Testability, ApplicationModule, NgModule, Optional, SkipSelf, ɵɵinject, ApplicationRef, ɵConsole, forwardRef, SecurityContext, ɵallowSanitizationBypassAndThrow, ɵunwrapSafeValue, ɵgetSanitizationBypassType, ɵ_sanitizeUrl, ɵ_sanitizeHtml, ɵbypassSanitizationTrustHtml, ɵbypassSanitizationTrustStyle, ɵbypassSanitizationTrustScript, ɵbypassSanitizationTrustUrl, ɵbypassSanitizationTrustResourceUrl, Version } from '@angular/core';\n/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n/**\n * Provides DOM operations in any browser environment.\n *\n * @security Tread carefully! Interacting with the DOM directly is dangerous and\n * can introduce XSS risks.\n */\n\nclass GenericBrowserDomAdapter extends ɵDomAdapter {\n constructor() {\n super(...arguments);\n this.supportsDOMEvents = true;\n }\n\n}\n/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n/**\n * A `DomAdapter` powered by full browser DOM APIs.\n *\n * @security Tread carefully! Interacting with the DOM directly is dangerous and\n * can introduce XSS risks.\n */\n\n/* tslint:disable:requireParameterType no-console */\n\n\nclass BrowserDomAdapter extends GenericBrowserDomAdapter {\n static makeCurrent() {\n ɵsetRootDomAdapter(new BrowserDomAdapter());\n }\n\n onAndCancel(el, evt, listener) {\n el.addEventListener(evt, listener, false); // Needed to follow Dart's subscription semantic, until fix of\n // https://code.google.com/p/dart/issues/detail?id=17406\n\n return () => {\n el.removeEventListener(evt, listener, false);\n };\n }\n\n dispatchEvent(el, evt) {\n el.dispatchEvent(evt);\n }\n\n remove(node) {\n if (node.parentNode) {\n node.parentNode.removeChild(node);\n }\n }\n\n createElement(tagName, doc) {\n doc = doc || this.getDefaultDocument();\n return doc.createElement(tagName);\n }\n\n createHtmlDocument() {\n return document.implementation.createHTMLDocument('fakeTitle');\n }\n\n getDefaultDocument() {\n return document;\n }\n\n isElementNode(node) {\n return node.nodeType === Node.ELEMENT_NODE;\n }\n\n isShadowRoot(node) {\n return node instanceof DocumentFragment;\n }\n /** @deprecated No longer being used in Ivy code. To be removed in version 14. */\n\n\n getGlobalEventTarget(doc, target) {\n if (target === 'window') {\n return window;\n }\n\n if (target === 'document') {\n return doc;\n }\n\n if (target === 'body') {\n return doc.body;\n }\n\n return null;\n }\n\n getBaseHref(doc) {\n const href = getBaseElementHref();\n return href == null ? null : relativePath(href);\n }\n\n resetBaseElement() {\n baseElement = null;\n }\n\n getUserAgent() {\n return window.navigator.userAgent;\n }\n\n getCookie(name) {\n return ɵparseCookieValue(document.cookie, name);\n }\n\n}\n\nlet baseElement = null;\n\nfunction getBaseElementHref() {\n baseElement = baseElement || document.querySelector('base');\n return baseElement ? baseElement.getAttribute('href') : null;\n} // based on urlUtils.js in AngularJS 1\n\n\nlet urlParsingNode;\n\nfunction relativePath(url) {\n urlParsingNode = urlParsingNode || document.createElement('a');\n urlParsingNode.setAttribute('href', url);\n const pathName = urlParsingNode.pathname;\n return pathName.charAt(0) === '/' ? pathName : `/${pathName}`;\n}\n/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n/**\n * An id that identifies a particular application being bootstrapped, that should\n * match across the client/server boundary.\n */\n\n\nconst TRANSITION_ID = /*#__PURE__*/new InjectionToken('TRANSITION_ID');\n\nfunction appInitializerFactory(transitionId, document, injector) {\n return () => {\n // Wait for all application initializers to be completed before removing the styles set by\n // the server.\n injector.get(ApplicationInitStatus).donePromise.then(() => {\n const dom = ɵgetDOM();\n const styles = document.querySelectorAll(`style[ng-transition=\"${transitionId}\"]`);\n\n for (let i = 0; i < styles.length; i++) {\n dom.remove(styles[i]);\n }\n });\n };\n}\n\nconst SERVER_TRANSITION_PROVIDERS = [{\n provide: APP_INITIALIZER,\n useFactory: appInitializerFactory,\n deps: [TRANSITION_ID, DOCUMENT, Injector],\n multi: true\n}];\n/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nclass BrowserGetTestability {\n static init() {\n setTestabilityGetter(new BrowserGetTestability());\n }\n\n addToWindow(registry) {\n ɵglobal['getAngularTestability'] = (elem, findInAncestors = true) => {\n const testability = registry.findTestabilityInTree(elem, findInAncestors);\n\n if (testability == null) {\n throw new Error('Could not find testability for element.');\n }\n\n return testability;\n };\n\n ɵglobal['getAllAngularTestabilities'] = () => registry.getAllTestabilities();\n\n ɵglobal['getAllAngularRootElements'] = () => registry.getAllRootElements();\n\n const whenAllStable = (callback\n /** TODO #9100 */\n ) => {\n const testabilities = ɵglobal['getAllAngularTestabilities']();\n let count = testabilities.length;\n let didWork = false;\n\n const decrement = function (didWork_\n /** TODO #9100 */\n ) {\n didWork = didWork || didWork_;\n count--;\n\n if (count == 0) {\n callback(didWork);\n }\n };\n\n testabilities.forEach(function (testability\n /** TODO #9100 */\n ) {\n testability.whenStable(decrement);\n });\n };\n\n if (!ɵglobal['frameworkStabilizers']) {\n ɵglobal['frameworkStabilizers'] = [];\n }\n\n ɵglobal['frameworkStabilizers'].push(whenAllStable);\n }\n\n findTestabilityInTree(registry, elem, findInAncestors) {\n if (elem == null) {\n return null;\n }\n\n const t = registry.getTestability(elem);\n\n if (t != null) {\n return t;\n } else if (!findInAncestors) {\n return null;\n }\n\n if (ɵgetDOM().isShadowRoot(elem)) {\n return this.findTestabilityInTree(registry, elem.host, true);\n }\n\n return this.findTestabilityInTree(registry, elem.parentElement, true);\n }\n\n}\n/**\n * A factory for `HttpXhrBackend` that uses the `XMLHttpRequest` browser API.\n */\n\n\nlet BrowserXhr = /*#__PURE__*/(() => {\n class BrowserXhr {\n build() {\n return new XMLHttpRequest();\n }\n\n }\n\n BrowserXhr.ɵfac = function BrowserXhr_Factory(t) {\n return new (t || BrowserXhr)();\n };\n\n BrowserXhr.ɵprov = /* @__PURE__ */i0.ɵɵdefineInjectable({\n token: BrowserXhr,\n factory: BrowserXhr.ɵfac\n });\n return BrowserXhr;\n})();\n\n/*#__PURE__*/\n(function () {\n (typeof ngDevMode === \"undefined\" || ngDevMode) && void 0;\n})();\n/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n/**\n * The injection token for the event-manager plug-in service.\n *\n * @publicApi\n */\n\n\nconst EVENT_MANAGER_PLUGINS = /*#__PURE__*/new InjectionToken('EventManagerPlugins');\n/**\n * An injectable service that provides event management for Angular\n * through a browser plug-in.\n *\n * @publicApi\n */\n\nlet EventManager = /*#__PURE__*/(() => {\n class EventManager {\n /**\n * Initializes an instance of the event-manager service.\n */\n constructor(plugins, _zone) {\n this._zone = _zone;\n this._eventNameToPlugin = new Map();\n plugins.forEach(p => p.manager = this);\n this._plugins = plugins.slice().reverse();\n }\n /**\n * Registers a handler for a specific element and event.\n *\n * @param element The HTML element to receive event notifications.\n * @param eventName The name of the event to listen for.\n * @param handler A function to call when the notification occurs. Receives the\n * event object as an argument.\n * @returns A callback function that can be used to remove the handler.\n */\n\n\n addEventListener(element, eventName, handler) {\n const plugin = this._findPluginFor(eventName);\n\n return plugin.addEventListener(element, eventName, handler);\n }\n /**\n * Registers a global handler for an event in a target view.\n *\n * @param target A target for global event notifications. One of \"window\", \"document\", or \"body\".\n * @param eventName The name of the event to listen for.\n * @param handler A function to call when the notification occurs. Receives the\n * event object as an argument.\n * @returns A callback function that can be used to remove the handler.\n * @deprecated No longer being used in Ivy code. To be removed in version 14.\n */\n\n\n addGlobalEventListener(target, eventName, handler) {\n const plugin = this._findPluginFor(eventName);\n\n return plugin.addGlobalEventListener(target, eventName, handler);\n }\n /**\n * Retrieves the compilation zone in which event listeners are registered.\n */\n\n\n getZone() {\n return this._zone;\n }\n /** @internal */\n\n\n _findPluginFor(eventName) {\n const plugin = this._eventNameToPlugin.get(eventName);\n\n if (plugin) {\n return plugin;\n }\n\n const plugins = this._plugins;\n\n for (let i = 0; i < plugins.length; i++) {\n const plugin = plugins[i];\n\n if (plugin.supports(eventName)) {\n this._eventNameToPlugin.set(eventName, plugin);\n\n return plugin;\n }\n }\n\n throw new Error(`No event manager plugin found for event ${eventName}`);\n }\n\n }\n\n EventManager.ɵfac = function EventManager_Factory(t) {\n return new (t || EventManager)(i0.ɵɵinject(EVENT_MANAGER_PLUGINS), i0.ɵɵinject(i0.NgZone));\n };\n\n EventManager.ɵprov = /* @__PURE__ */i0.ɵɵdefineInjectable({\n token: EventManager,\n factory: EventManager.ɵfac\n });\n return EventManager;\n})();\n\n/*#__PURE__*/\n(function () {\n (typeof ngDevMode === \"undefined\" || ngDevMode) && void 0;\n})();\n\nclass EventManagerPlugin {\n constructor(_doc) {\n this._doc = _doc;\n }\n\n addGlobalEventListener(element, eventName, handler) {\n const target = ɵgetDOM().getGlobalEventTarget(this._doc, element);\n\n if (!target) {\n throw new Error(`Unsupported event target ${target} for event ${eventName}`);\n }\n\n return this.addEventListener(target, eventName, handler);\n }\n\n}\n/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n\nlet SharedStylesHost = /*#__PURE__*/(() => {\n class SharedStylesHost {\n constructor() {\n /** @internal */\n this._stylesSet = new Set();\n }\n\n addStyles(styles) {\n const additions = new Set();\n styles.forEach(style => {\n if (!this._stylesSet.has(style)) {\n this._stylesSet.add(style);\n\n additions.add(style);\n }\n });\n this.onStylesAdded(additions);\n }\n\n onStylesAdded(additions) {}\n\n getAllStyles() {\n return Array.from(this._stylesSet);\n }\n\n }\n\n SharedStylesHost.ɵfac = function SharedStylesHost_Factory(t) {\n return new (t || SharedStylesHost)();\n };\n\n SharedStylesHost.ɵprov = /* @__PURE__ */i0.ɵɵdefineInjectable({\n token: SharedStylesHost,\n factory: SharedStylesHost.ɵfac\n });\n return SharedStylesHost;\n})();\n\n/*#__PURE__*/\n(function () {\n (typeof ngDevMode === \"undefined\" || ngDevMode) && void 0;\n})();\n\nlet DomSharedStylesHost = /*#__PURE__*/(() => {\n class DomSharedStylesHost extends SharedStylesHost {\n constructor(_doc) {\n super();\n this._doc = _doc; // Maps all registered host nodes to a list of style nodes that have been added to the host node.\n\n this._hostNodes = new Map();\n\n this._hostNodes.set(_doc.head, []);\n }\n\n _addStylesToHost(styles, host, styleNodes) {\n styles.forEach(style => {\n const styleEl = this._doc.createElement('style');\n\n styleEl.textContent = style;\n styleNodes.push(host.appendChild(styleEl));\n });\n }\n\n addHost(hostNode) {\n const styleNodes = [];\n\n this._addStylesToHost(this._stylesSet, hostNode, styleNodes);\n\n this._hostNodes.set(hostNode, styleNodes);\n }\n\n removeHost(hostNode) {\n const styleNodes = this._hostNodes.get(hostNode);\n\n if (styleNodes) {\n styleNodes.forEach(removeStyle);\n }\n\n this._hostNodes.delete(hostNode);\n }\n\n onStylesAdded(additions) {\n this._hostNodes.forEach((styleNodes, hostNode) => {\n this._addStylesToHost(additions, hostNode, styleNodes);\n });\n }\n\n ngOnDestroy() {\n this._hostNodes.forEach(styleNodes => styleNodes.forEach(removeStyle));\n }\n\n }\n\n DomSharedStylesHost.ɵfac = function DomSharedStylesHost_Factory(t) {\n return new (t || DomSharedStylesHost)(i0.ɵɵinject(DOCUMENT));\n };\n\n DomSharedStylesHost.ɵprov = /* @__PURE__ */i0.ɵɵdefineInjectable({\n token: DomSharedStylesHost,\n factory: DomSharedStylesHost.ɵfac\n });\n return DomSharedStylesHost;\n})();\n\n/*#__PURE__*/\n(function () {\n (typeof ngDevMode === \"undefined\" || ngDevMode) && void 0;\n})();\n\nfunction removeStyle(styleNode) {\n ɵgetDOM().remove(styleNode);\n}\n/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n\nconst NAMESPACE_URIS = {\n 'svg': 'http://www.w3.org/2000/svg',\n 'xhtml': 'http://www.w3.org/1999/xhtml',\n 'xlink': 'http://www.w3.org/1999/xlink',\n 'xml': 'http://www.w3.org/XML/1998/namespace',\n 'xmlns': 'http://www.w3.org/2000/xmlns/',\n 'math': 'http://www.w3.org/1998/MathML/'\n};\nconst COMPONENT_REGEX = /%COMP%/g;\nconst NG_DEV_MODE = typeof ngDevMode === 'undefined' || !!ngDevMode;\nconst COMPONENT_VARIABLE = '%COMP%';\nconst HOST_ATTR = `_nghost-${COMPONENT_VARIABLE}`;\nconst CONTENT_ATTR = `_ngcontent-${COMPONENT_VARIABLE}`;\n\nfunction shimContentAttribute(componentShortId) {\n return CONTENT_ATTR.replace(COMPONENT_REGEX, componentShortId);\n}\n\nfunction shimHostAttribute(componentShortId) {\n return HOST_ATTR.replace(COMPONENT_REGEX, componentShortId);\n}\n\nfunction flattenStyles(compId, styles, target) {\n for (let i = 0; i < styles.length; i++) {\n let style = styles[i];\n\n if (Array.isArray(style)) {\n flattenStyles(compId, style, target);\n } else {\n style = style.replace(COMPONENT_REGEX, compId);\n target.push(style);\n }\n }\n\n return target;\n}\n\nfunction decoratePreventDefault(eventHandler) {\n // `DebugNode.triggerEventHandler` needs to know if the listener was created with\n // decoratePreventDefault or is a listener added outside the Angular context so it can handle the\n // two differently. In the first case, the special '__ngUnwrap__' token is passed to the unwrap\n // the listener (see below).\n return event => {\n // Ivy uses '__ngUnwrap__' as a special token that allows us to unwrap the function\n // so that it can be invoked programmatically by `DebugNode.triggerEventHandler`. The debug_node\n // can inspect the listener toString contents for the existence of this special token. Because\n // the token is a string literal, it is ensured to not be modified by compiled code.\n if (event === '__ngUnwrap__') {\n return eventHandler;\n }\n\n const allowDefaultBehavior = eventHandler(event);\n\n if (allowDefaultBehavior === false) {\n // TODO(tbosch): move preventDefault into event plugins...\n event.preventDefault();\n event.returnValue = false;\n }\n\n return undefined;\n };\n}\n\nlet hasLoggedNativeEncapsulationWarning = false;\nlet DomRendererFactory2 = /*#__PURE__*/(() => {\n class DomRendererFactory2 {\n constructor(eventManager, sharedStylesHost, appId) {\n this.eventManager = eventManager;\n this.sharedStylesHost = sharedStylesHost;\n this.appId = appId;\n this.rendererByCompId = new Map();\n this.defaultRenderer = new DefaultDomRenderer2(eventManager);\n }\n\n createRenderer(element, type) {\n if (!element || !type) {\n return this.defaultRenderer;\n }\n\n switch (type.encapsulation) {\n case ViewEncapsulation.Emulated:\n {\n let renderer = this.rendererByCompId.get(type.id);\n\n if (!renderer) {\n renderer = new EmulatedEncapsulationDomRenderer2(this.eventManager, this.sharedStylesHost, type, this.appId);\n this.rendererByCompId.set(type.id, renderer);\n }\n\n renderer.applyToHost(element);\n return renderer;\n }\n // @ts-ignore TODO: Remove as part of FW-2290. TS complains about us dealing with an enum\n // value that is not known (but previously was the value for ViewEncapsulation.Native)\n\n case 1:\n case ViewEncapsulation.ShadowDom:\n // TODO(FW-2290): remove the `case 1:` fallback logic and the warning in v12.\n if ((typeof ngDevMode === 'undefined' || ngDevMode) && // @ts-ignore TODO: Remove as part of FW-2290. TS complains about us dealing with an\n // enum value that is not known (but previously was the value for\n // ViewEncapsulation.Native)\n !hasLoggedNativeEncapsulationWarning && type.encapsulation === 1) {\n hasLoggedNativeEncapsulationWarning = true;\n console.warn('ViewEncapsulation.Native is no longer supported. Falling back to ViewEncapsulation.ShadowDom. The fallback will be removed in v12.');\n }\n\n return new ShadowDomRenderer(this.eventManager, this.sharedStylesHost, element, type);\n\n default:\n {\n if (!this.rendererByCompId.has(type.id)) {\n const styles = flattenStyles(type.id, type.styles, []);\n this.sharedStylesHost.addStyles(styles);\n this.rendererByCompId.set(type.id, this.defaultRenderer);\n }\n\n return this.defaultRenderer;\n }\n }\n }\n\n begin() {}\n\n end() {}\n\n }\n\n DomRendererFactory2.ɵfac = function DomRendererFactory2_Factory(t) {\n return new (t || DomRendererFactory2)(i0.ɵɵinject(EventManager), i0.ɵɵinject(DomSharedStylesHost), i0.ɵɵinject(APP_ID));\n };\n\n DomRendererFactory2.ɵprov = /* @__PURE__ */i0.ɵɵdefineInjectable({\n token: DomRendererFactory2,\n factory: DomRendererFactory2.ɵfac\n });\n return DomRendererFactory2;\n})();\n\n/*#__PURE__*/\n(function () {\n (typeof ngDevMode === \"undefined\" || ngDevMode) && void 0;\n})();\n\nclass DefaultDomRenderer2 {\n constructor(eventManager) {\n this.eventManager = eventManager;\n this.data = Object.create(null);\n this.destroyNode = null;\n }\n\n destroy() {}\n\n createElement(name, namespace) {\n if (namespace) {\n // TODO: `|| namespace` was added in\n // https://github.com/angular/angular/commit/2b9cc8503d48173492c29f5a271b61126104fbdb to\n // support how Ivy passed around the namespace URI rather than short name at the time. It did\n // not, however extend the support to other parts of the system (setAttribute, setAttribute,\n // and the ServerRenderer). We should decide what exactly the semantics for dealing with\n // namespaces should be and make it consistent.\n // Related issues:\n // https://github.com/angular/angular/issues/44028\n // https://github.com/angular/angular/issues/44883\n return document.createElementNS(NAMESPACE_URIS[namespace] || namespace, name);\n }\n\n return document.createElement(name);\n }\n\n createComment(value) {\n return document.createComment(value);\n }\n\n createText(value) {\n return document.createTextNode(value);\n }\n\n appendChild(parent, newChild) {\n parent.appendChild(newChild);\n }\n\n insertBefore(parent, newChild, refChild) {\n if (parent) {\n parent.insertBefore(newChild, refChild);\n }\n }\n\n removeChild(parent, oldChild) {\n if (parent) {\n parent.removeChild(oldChild);\n }\n }\n\n selectRootElement(selectorOrNode, preserveContent) {\n let el = typeof selectorOrNode === 'string' ? document.querySelector(selectorOrNode) : selectorOrNode;\n\n if (!el) {\n throw new Error(`The selector \"${selectorOrNode}\" did not match any elements`);\n }\n\n if (!preserveContent) {\n el.textContent = '';\n }\n\n return el;\n }\n\n parentNode(node) {\n return node.parentNode;\n }\n\n nextSibling(node) {\n return node.nextSibling;\n }\n\n setAttribute(el, name, value, namespace) {\n if (namespace) {\n name = namespace + ':' + name;\n const namespaceUri = NAMESPACE_URIS[namespace];\n\n if (namespaceUri) {\n el.setAttributeNS(namespaceUri, name, value);\n } else {\n el.setAttribute(name, value);\n }\n } else {\n el.setAttribute(name, value);\n }\n }\n\n removeAttribute(el, name, namespace) {\n if (namespace) {\n const namespaceUri = NAMESPACE_URIS[namespace];\n\n if (namespaceUri) {\n el.removeAttributeNS(namespaceUri, name);\n } else {\n el.removeAttribute(`${namespace}:${name}`);\n }\n } else {\n el.removeAttribute(name);\n }\n }\n\n addClass(el, name) {\n el.classList.add(name);\n }\n\n removeClass(el, name) {\n el.classList.remove(name);\n }\n\n setStyle(el, style, value, flags) {\n if (flags & (RendererStyleFlags2.DashCase | RendererStyleFlags2.Important)) {\n el.style.setProperty(style, value, flags & RendererStyleFlags2.Important ? 'important' : '');\n } else {\n el.style[style] = value;\n }\n }\n\n removeStyle(el, style, flags) {\n if (flags & RendererStyleFlags2.DashCase) {\n el.style.removeProperty(style);\n } else {\n // IE requires '' instead of null\n // see https://github.com/angular/angular/issues/7916\n el.style[style] = '';\n }\n }\n\n setProperty(el, name, value) {\n NG_DEV_MODE && checkNoSyntheticProp(name, 'property');\n el[name] = value;\n }\n\n setValue(node, value) {\n node.nodeValue = value;\n }\n\n listen(target, event, callback) {\n NG_DEV_MODE && checkNoSyntheticProp(event, 'listener');\n\n if (typeof target === 'string') {\n return this.eventManager.addGlobalEventListener(target, event, decoratePreventDefault(callback));\n }\n\n return this.eventManager.addEventListener(target, event, decoratePreventDefault(callback));\n }\n\n}\n\nconst AT_CHARCODE = /*#__PURE__*/(() => '@'.charCodeAt(0))();\n\nfunction checkNoSyntheticProp(name, nameKind) {\n if (name.charCodeAt(0) === AT_CHARCODE) {\n throw new Error(`Unexpected synthetic ${nameKind} ${name} found. Please make sure that:\n - Either \\`BrowserAnimationsModule\\` or \\`NoopAnimationsModule\\` are imported in your application.\n - There is corresponding configuration for the animation named \\`${name}\\` defined in the \\`animations\\` field of the \\`@Component\\` decorator (see https://angular.io/api/core/Component#animations).`);\n }\n}\n\nclass EmulatedEncapsulationDomRenderer2 extends DefaultDomRenderer2 {\n constructor(eventManager, sharedStylesHost, component, appId) {\n super(eventManager);\n this.component = component;\n const styles = flattenStyles(appId + '-' + component.id, component.styles, []);\n sharedStylesHost.addStyles(styles);\n this.contentAttr = shimContentAttribute(appId + '-' + component.id);\n this.hostAttr = shimHostAttribute(appId + '-' + component.id);\n }\n\n applyToHost(element) {\n super.setAttribute(element, this.hostAttr, '');\n }\n\n createElement(parent, name) {\n const el = super.createElement(parent, name);\n super.setAttribute(el, this.contentAttr, '');\n return el;\n }\n\n}\n\nclass ShadowDomRenderer extends DefaultDomRenderer2 {\n constructor(eventManager, sharedStylesHost, hostEl, component) {\n super(eventManager);\n this.sharedStylesHost = sharedStylesHost;\n this.hostEl = hostEl;\n this.shadowRoot = hostEl.attachShadow({\n mode: 'open'\n });\n this.sharedStylesHost.addHost(this.shadowRoot);\n const styles = flattenStyles(component.id, component.styles, []);\n\n for (let i = 0; i < styles.length; i++) {\n const styleEl = document.createElement('style');\n styleEl.textContent = styles[i];\n this.shadowRoot.appendChild(styleEl);\n }\n }\n\n nodeOrShadowRoot(node) {\n return node === this.hostEl ? this.shadowRoot : node;\n }\n\n destroy() {\n this.sharedStylesHost.removeHost(this.shadowRoot);\n }\n\n appendChild(parent, newChild) {\n return super.appendChild(this.nodeOrShadowRoot(parent), newChild);\n }\n\n insertBefore(parent, newChild, refChild) {\n return super.insertBefore(this.nodeOrShadowRoot(parent), newChild, refChild);\n }\n\n removeChild(parent, oldChild) {\n return super.removeChild(this.nodeOrShadowRoot(parent), oldChild);\n }\n\n parentNode(node) {\n return this.nodeOrShadowRoot(super.parentNode(this.nodeOrShadowRoot(node)));\n }\n\n}\n/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n\nlet DomEventsPlugin = /*#__PURE__*/(() => {\n class DomEventsPlugin extends EventManagerPlugin {\n constructor(doc) {\n super(doc);\n } // This plugin should come last in the list of plugins, because it accepts all\n // events.\n\n\n supports(eventName) {\n return true;\n }\n\n addEventListener(element, eventName, handler) {\n element.addEventListener(eventName, handler, false);\n return () => this.removeEventListener(element, eventName, handler);\n }\n\n removeEventListener(target, eventName, callback) {\n return target.removeEventListener(eventName, callback);\n }\n\n }\n\n DomEventsPlugin.ɵfac = function DomEventsPlugin_Factory(t) {\n return new (t || DomEventsPlugin)(i0.ɵɵinject(DOCUMENT));\n };\n\n DomEventsPlugin.ɵprov = /* @__PURE__ */i0.ɵɵdefineInjectable({\n token: DomEventsPlugin,\n factory: DomEventsPlugin.ɵfac\n });\n return DomEventsPlugin;\n})();\n\n/*#__PURE__*/\n(function () {\n (typeof ngDevMode === \"undefined\" || ngDevMode) && void 0;\n})();\n/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n/**\n * Defines supported modifiers for key events.\n */\n\n\nconst MODIFIER_KEYS = ['alt', 'control', 'meta', 'shift'];\nconst DOM_KEY_LOCATION_NUMPAD = 3; // Map to convert some key or keyIdentifier values to what will be returned by getEventKey\n\nconst _keyMap = {\n // The following values are here for cross-browser compatibility and to match the W3C standard\n // cf https://www.w3.org/TR/DOM-Level-3-Events-key/\n '\\b': 'Backspace',\n '\\t': 'Tab',\n '\\x7F': 'Delete',\n '\\x1B': 'Escape',\n 'Del': 'Delete',\n 'Esc': 'Escape',\n 'Left': 'ArrowLeft',\n 'Right': 'ArrowRight',\n 'Up': 'ArrowUp',\n 'Down': 'ArrowDown',\n 'Menu': 'ContextMenu',\n 'Scroll': 'ScrollLock',\n 'Win': 'OS'\n}; // There is a bug in Chrome for numeric keypad keys:\n// https://code.google.com/p/chromium/issues/detail?id=155654\n// 1, 2, 3 ... are reported as A, B, C ...\n\nconst _chromeNumKeyPadMap = {\n 'A': '1',\n 'B': '2',\n 'C': '3',\n 'D': '4',\n 'E': '5',\n 'F': '6',\n 'G': '7',\n 'H': '8',\n 'I': '9',\n 'J': '*',\n 'K': '+',\n 'M': '-',\n 'N': '.',\n 'O': '/',\n '\\x60': '0',\n '\\x90': 'NumLock'\n};\n/**\n * Retrieves modifiers from key-event objects.\n */\n\nconst MODIFIER_KEY_GETTERS = {\n 'alt': event => event.altKey,\n 'control': event => event.ctrlKey,\n 'meta': event => event.metaKey,\n 'shift': event => event.shiftKey\n};\n/**\n * @publicApi\n * A browser plug-in that provides support for handling of key events in Angular.\n */\n\nlet KeyEventsPlugin = /*#__PURE__*/(() => {\n class KeyEventsPlugin extends EventManagerPlugin {\n /**\n * Initializes an instance of the browser plug-in.\n * @param doc The document in which key events will be detected.\n */\n constructor(doc) {\n super(doc);\n }\n /**\n * Reports whether a named key event is supported.\n * @param eventName The event name to query.\n * @return True if the named key event is supported.\n */\n\n\n supports(eventName) {\n return KeyEventsPlugin.parseEventName(eventName) != null;\n }\n /**\n * Registers a handler for a specific element and key event.\n * @param element The HTML element to receive event notifications.\n * @param eventName The name of the key event to listen for.\n * @param handler A function to call when the notification occurs. Receives the\n * event object as an argument.\n * @returns The key event that was registered.\n */\n\n\n addEventListener(element, eventName, handler) {\n const parsedEvent = KeyEventsPlugin.parseEventName(eventName);\n const outsideHandler = KeyEventsPlugin.eventCallback(parsedEvent['fullKey'], handler, this.manager.getZone());\n return this.manager.getZone().runOutsideAngular(() => {\n return ɵgetDOM().onAndCancel(element, parsedEvent['domEventName'], outsideHandler);\n });\n }\n\n static parseEventName(eventName) {\n const parts = eventName.toLowerCase().split('.');\n const domEventName = parts.shift();\n\n if (parts.length === 0 || !(domEventName === 'keydown' || domEventName === 'keyup')) {\n return null;\n }\n\n const key = KeyEventsPlugin._normalizeKey(parts.pop());\n\n let fullKey = '';\n MODIFIER_KEYS.forEach(modifierName => {\n const index = parts.indexOf(modifierName);\n\n if (index > -1) {\n parts.splice(index, 1);\n fullKey += modifierName + '.';\n }\n });\n fullKey += key;\n\n if (parts.length != 0 || key.length === 0) {\n // returning null instead of throwing to let another plugin process the event\n return null;\n } // NOTE: Please don't rewrite this as so, as it will break JSCompiler property renaming.\n // The code must remain in the `result['domEventName']` form.\n // return {domEventName, fullKey};\n\n\n const result = {};\n result['domEventName'] = domEventName;\n result['fullKey'] = fullKey;\n return result;\n }\n\n static getEventFullKey(event) {\n let fullKey = '';\n let key = getEventKey(event);\n key = key.toLowerCase();\n\n if (key === ' ') {\n key = 'space'; // for readability\n } else if (key === '.') {\n key = 'dot'; // because '.' is used as a separator in event names\n }\n\n MODIFIER_KEYS.forEach(modifierName => {\n if (modifierName != key) {\n const modifierGetter = MODIFIER_KEY_GETTERS[modifierName];\n\n if (modifierGetter(event)) {\n fullKey += modifierName + '.';\n }\n }\n });\n fullKey += key;\n return fullKey;\n }\n /**\n * Configures a handler callback for a key event.\n * @param fullKey The event name that combines all simultaneous keystrokes.\n * @param handler The function that responds to the key event.\n * @param zone The zone in which the event occurred.\n * @returns A callback function.\n */\n\n\n static eventCallback(fullKey, handler, zone) {\n return (event\n /** TODO #9100 */\n ) => {\n if (KeyEventsPlugin.getEventFullKey(event) === fullKey) {\n zone.runGuarded(() => handler(event));\n }\n };\n }\n /** @internal */\n\n\n static _normalizeKey(keyName) {\n // TODO: switch to a Map if the mapping grows too much\n switch (keyName) {\n case 'esc':\n return 'escape';\n\n default:\n return keyName;\n }\n }\n\n }\n\n KeyEventsPlugin.ɵfac = function KeyEventsPlugin_Factory(t) {\n return new (t || KeyEventsPlugin)(i0.ɵɵinject(DOCUMENT));\n };\n\n KeyEventsPlugin.ɵprov = /* @__PURE__ */i0.ɵɵdefineInjectable({\n token: KeyEventsPlugin,\n factory: KeyEventsPlugin.ɵfac\n });\n return KeyEventsPlugin;\n})();\n\n/*#__PURE__*/\n(function () {\n (typeof ngDevMode === \"undefined\" || ngDevMode) && void 0;\n})();\n\nfunction getEventKey(event) {\n let key = event.key;\n\n if (key == null) {\n key = event.keyIdentifier; // keyIdentifier is defined in the old draft of DOM Level 3 Events implemented by Chrome and\n // Safari cf\n // https://www.w3.org/TR/2007/WD-DOM-Level-3-Events-20071221/events.html#Events-KeyboardEvents-Interfaces\n\n if (key == null) {\n return 'Unidentified';\n }\n\n if (key.startsWith('U+')) {\n key = String.fromCharCode(parseInt(key.substring(2), 16));\n\n if (event.location === DOM_KEY_LOCATION_NUMPAD && _chromeNumKeyPadMap.hasOwnProperty(key)) {\n // There is a bug in Chrome for numeric keypad keys:\n // https://code.google.com/p/chromium/issues/detail?id=155654\n // 1, 2, 3 ... are reported as A, B, C ...\n key = _chromeNumKeyPadMap[key];\n }\n }\n }\n\n return _keyMap[key] || key;\n}\n/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n\nfunction initDomAdapter() {\n BrowserDomAdapter.makeCurrent();\n BrowserGetTestability.init();\n}\n\nfunction errorHandler() {\n return new ErrorHandler();\n}\n\nfunction _document() {\n // Tell ivy about the global document\n ɵsetDocument(document);\n return document;\n}\n\nconst INTERNAL_BROWSER_PLATFORM_PROVIDERS = [{\n provide: PLATFORM_ID,\n useValue: ɵPLATFORM_BROWSER_ID\n}, {\n provide: PLATFORM_INITIALIZER,\n useValue: initDomAdapter,\n multi: true\n}, {\n provide: DOCUMENT,\n useFactory: _document,\n deps: []\n}];\n/**\n * A factory function that returns a `PlatformRef` instance associated with browser service\n * providers.\n *\n * @publicApi\n */\n\nconst platformBrowser = /*#__PURE__*/createPlatformFactory(platformCore, 'browser', INTERNAL_BROWSER_PLATFORM_PROVIDERS);\nconst BROWSER_MODULE_PROVIDERS = [{\n provide: ɵINJECTOR_SCOPE,\n useValue: 'root'\n}, {\n provide: ErrorHandler,\n useFactory: errorHandler,\n deps: []\n}, {\n provide: EVENT_MANAGER_PLUGINS,\n useClass: DomEventsPlugin,\n multi: true,\n deps: [DOCUMENT, NgZone, PLATFORM_ID]\n}, {\n provide: EVENT_MANAGER_PLUGINS,\n useClass: KeyEventsPlugin,\n multi: true,\n deps: [DOCUMENT]\n}, {\n provide: DomRendererFactory2,\n useClass: DomRendererFactory2,\n deps: [EventManager, DomSharedStylesHost, APP_ID]\n}, {\n provide: RendererFactory2,\n useExisting: DomRendererFactory2\n}, {\n provide: SharedStylesHost,\n useExisting: DomSharedStylesHost\n}, {\n provide: DomSharedStylesHost,\n useClass: DomSharedStylesHost,\n deps: [DOCUMENT]\n}, {\n provide: Testability,\n useClass: Testability,\n deps: [NgZone]\n}, {\n provide: EventManager,\n useClass: EventManager,\n deps: [EVENT_MANAGER_PLUGINS, NgZone]\n}, {\n provide: XhrFactory,\n useClass: BrowserXhr,\n deps: []\n}];\n/**\n * Exports required infrastructure for all Angular apps.\n * Included by default in all Angular apps created with the CLI\n * `new` command.\n * Re-exports `CommonModule` and `ApplicationModule`, making their\n * exports and providers available to all apps.\n *\n * @publicApi\n */\n\nlet BrowserModule = /*#__PURE__*/(() => {\n class BrowserModule {\n constructor(parentModule) {\n if (parentModule) {\n throw new Error(`BrowserModule has already been loaded. If you need access to common directives such as NgIf and NgFor from a lazy loaded module, import CommonModule instead.`);\n }\n }\n /**\n * Configures a browser-based app to transition from a server-rendered app, if\n * one is present on the page.\n *\n * @param params An object containing an identifier for the app to transition.\n * The ID must match between the client and server versions of the app.\n * @returns The reconfigured `BrowserModule` to import into the app's root `AppModule`.\n */\n\n\n static withServerTransition(params) {\n return {\n ngModule: BrowserModule,\n providers: [{\n provide: APP_ID,\n useValue: params.appId\n }, {\n provide: TRANSITION_ID,\n useExisting: APP_ID\n }, SERVER_TRANSITION_PROVIDERS]\n };\n }\n\n }\n\n BrowserModule.ɵfac = function BrowserModule_Factory(t) {\n return new (t || BrowserModule)(i0.ɵɵinject(BrowserModule, 12));\n };\n\n BrowserModule.ɵmod = /* @__PURE__ */i0.ɵɵdefineNgModule({\n type: BrowserModule\n });\n BrowserModule.ɵinj = /* @__PURE__ */i0.ɵɵdefineInjector({\n providers: BROWSER_MODULE_PROVIDERS,\n imports: [CommonModule, ApplicationModule]\n });\n return BrowserModule;\n})();\n\n/*#__PURE__*/\n(function () {\n (typeof ngDevMode === \"undefined\" || ngDevMode) && void 0;\n})();\n/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n/**\n * Factory to create a `Meta` service instance for the current DOM document.\n */\n\n\nfunction createMeta() {\n return new Meta(ɵɵinject(DOCUMENT));\n}\n/**\n * A service for managing HTML `<meta>` tags.\n *\n * Properties of the `MetaDefinition` object match the attributes of the\n * HTML `<meta>` tag. These tags define document metadata that is important for\n * things like configuring a Content Security Policy, defining browser compatibility\n * and security settings, setting HTTP Headers, defining rich content for social sharing,\n * and Search Engine Optimization (SEO).\n *\n * To identify specific `<meta>` tags in a document, use an attribute selection\n * string in the format `\"tag_attribute='value string'\"`.\n * For example, an `attrSelector` value of `\"name='description'\"` matches a tag\n * whose `name` attribute has the value `\"description\"`.\n * Selectors are used with the `querySelector()` Document method,\n * in the format `meta[{attrSelector}]`.\n *\n * @see [HTML meta tag](https://developer.mozilla.org/docs/Web/HTML/Element/meta)\n * @see [Document.querySelector()](https://developer.mozilla.org/docs/Web/API/Document/querySelector)\n *\n *\n * @publicApi\n */\n\n\nlet Meta = /*#__PURE__*/(() => {\n class Meta {\n constructor(_doc) {\n this._doc = _doc;\n this._dom = ɵgetDOM();\n }\n /**\n * Retrieves or creates a specific `<meta>` tag element in the current HTML document.\n * In searching for an existing tag, Angular attempts to match the `name` or `property` attribute\n * values in the provided tag definition, and verifies that all other attribute values are equal.\n * If an existing element is found, it is returned and is not modified in any way.\n * @param tag The definition of a `<meta>` element to match or create.\n * @param forceCreation True to create a new element without checking whether one already exists.\n * @returns The existing element with the same attributes and values if found,\n * the new element if no match is found, or `null` if the tag parameter is not defined.\n */\n\n\n addTag(tag, forceCreation = false) {\n if (!tag) return null;\n return this._getOrCreateElement(tag, forceCreation);\n }\n /**\n * Retrieves or creates a set of `<meta>` tag elements in the current HTML document.\n * In searching for an existing tag, Angular attempts to match the `name` or `property` attribute\n * values in the provided tag definition, and verifies that all other attribute values are equal.\n * @param tags An array of tag definitions to match or create.\n * @param forceCreation True to create new elements without checking whether they already exist.\n * @returns The matching elements if found, or the new elements.\n */\n\n\n addTags(tags, forceCreation = false) {\n if (!tags) return [];\n return tags.reduce((result, tag) => {\n if (tag) {\n result.push(this._getOrCreateElement(tag, forceCreation));\n }\n\n return result;\n }, []);\n }\n /**\n * Retrieves a `<meta>` tag element in the current HTML document.\n * @param attrSelector The tag attribute and value to match against, in the format\n * `\"tag_attribute='value string'\"`.\n * @returns The matching element, if any.\n */\n\n\n getTag(attrSelector) {\n if (!attrSelector) return null;\n return this._doc.querySelector(`meta[${attrSelector}]`) || null;\n }\n /**\n * Retrieves a set of `<meta>` tag elements in the current HTML document.\n * @param attrSelector The tag attribute and value to match against, in the format\n * `\"tag_attribute='value string'\"`.\n * @returns The matching elements, if any.\n */\n\n\n getTags(attrSelector) {\n if (!attrSelector) return [];\n\n const list\n /*NodeList*/\n = this._doc.querySelectorAll(`meta[${attrSelector}]`);\n\n return list ? [].slice.call(list) : [];\n }\n /**\n * Modifies an existing `<meta>` tag element in the current HTML document.\n * @param tag The tag description with which to replace the existing tag content.\n * @param selector A tag attribute and value to match against, to identify\n * an existing tag. A string in the format `\"tag_attribute=`value string`\"`.\n * If not supplied, matches a tag with the same `name` or `property` attribute value as the\n * replacement tag.\n * @return The modified element.\n */\n\n\n updateTag(tag, selector) {\n if (!tag) return null;\n selector = selector || this._parseSelector(tag);\n const meta = this.getTag(selector);\n\n if (meta) {\n return this._setMetaElementAttributes(tag, meta);\n }\n\n return this._getOrCreateElement(tag, true);\n }\n /**\n * Removes an existing `<meta>` tag element from the current HTML document.\n * @param attrSelector A tag attribute and value to match against, to identify\n * an existing tag. A string in the format `\"tag_attribute=`value string`\"`.\n */\n\n\n removeTag(attrSelector) {\n this.removeTagElement(this.getTag(attrSelector));\n }\n /**\n * Removes an existing `<meta>` tag element from the current HTML document.\n * @param meta The tag definition to match against to identify an existing tag.\n */\n\n\n removeTagElement(meta) {\n if (meta) {\n this._dom.remove(meta);\n }\n }\n\n _getOrCreateElement(meta, forceCreation = false) {\n if (!forceCreation) {\n const selector = this._parseSelector(meta); // It's allowed to have multiple elements with the same name so it's not enough to\n // just check that element with the same name already present on the page. We also need to\n // check if element has tag attributes\n\n\n const elem = this.getTags(selector).filter(elem => this._containsAttributes(meta, elem))[0];\n if (elem !== undefined) return elem;\n }\n\n const element = this._dom.createElement('meta');\n\n this._setMetaElementAttributes(meta, element);\n\n const head = this._doc.getElementsByTagName('head')[0];\n\n head.appendChild(element);\n return element;\n }\n\n _setMetaElementAttributes(tag, el) {\n Object.keys(tag).forEach(prop => el.setAttribute(this._getMetaKeyMap(prop), tag[prop]));\n return el;\n }\n\n _parseSelector(tag) {\n const attr = tag.name ? 'name' : 'property';\n return `${attr}=\"${tag[attr]}\"`;\n }\n\n _containsAttributes(tag, elem) {\n return Object.keys(tag).every(key => elem.getAttribute(this._getMetaKeyMap(key)) === tag[key]);\n }\n\n _getMetaKeyMap(prop) {\n return META_KEYS_MAP[prop] || prop;\n }\n\n }\n\n Meta.ɵfac = function Meta_Factory(t) {\n return new (t || Meta)(i0.ɵɵinject(DOCUMENT));\n };\n\n Meta.ɵprov = /* @__PURE__ */i0.ɵɵdefineInjectable({\n token: Meta,\n factory: function Meta_Factory(t) {\n let r = null;\n\n if (t) {\n r = new t();\n } else {\n r = createMeta();\n }\n\n return r;\n },\n providedIn: 'root'\n });\n return Meta;\n})();\n\n/*#__PURE__*/\n(function () {\n (typeof ngDevMode === \"undefined\" || ngDevMode) && void 0;\n})();\n/**\n * Mapping for MetaDefinition properties with their correct meta attribute names\n */\n\n\nconst META_KEYS_MAP = {\n httpEquiv: 'http-equiv'\n};\n/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n/**\n * Factory to create Title service.\n */\n\nfunction createTitle() {\n return new Title(ɵɵinject(DOCUMENT));\n}\n/**\n * A service that can be used to get and set the title of a current HTML document.\n *\n * Since an Angular application can't be bootstrapped on the entire HTML document (`<html>` tag)\n * it is not possible to bind to the `text` property of the `HTMLTitleElement` elements\n * (representing the `<title>` tag). Instead, this service can be used to set and get the current\n * title value.\n *\n * @publicApi\n */\n\n\nlet Title = /*#__PURE__*/(() => {\n class Title {\n constructor(_doc) {\n this._doc = _doc;\n }\n /**\n * Get the title of the current HTML document.\n */\n\n\n getTitle() {\n return this._doc.title;\n }\n /**\n * Set the title of the current HTML document.\n * @param newTitle\n */\n\n\n setTitle(newTitle) {\n this._doc.title = newTitle || '';\n }\n\n }\n\n Title.ɵfac = function Title_Factory(t) {\n return new (t || Title)(i0.ɵɵinject(DOCUMENT));\n };\n\n Title.ɵprov = /* @__PURE__ */i0.ɵɵdefineInjectable({\n token: Title,\n factory: function Title_Factory(t) {\n let r = null;\n\n if (t) {\n r = new t();\n } else {\n r = createTitle();\n }\n\n return r;\n },\n providedIn: 'root'\n });\n return Title;\n})();\n\n/*#__PURE__*/\n(function () {\n (typeof ngDevMode === \"undefined\" || ngDevMode) && void 0;\n})();\n/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n\nconst CAMEL_CASE_REGEXP = /([A-Z])/g;\nconst DASH_CASE_REGEXP = /-([a-z])/g;\n\nfunction camelCaseToDashCase(input) {\n return input.replace(CAMEL_CASE_REGEXP, (...m) => '-' + m[1].toLowerCase());\n}\n\nfunction dashCaseToCamelCase(input) {\n return input.replace(DASH_CASE_REGEXP, (...m) => m[1].toUpperCase());\n}\n/**\n * Exports the value under a given `name` in the global property `ng`. For example `ng.probe` if\n * `name` is `'probe'`.\n * @param name Name under which it will be exported. Keep in mind this will be a property of the\n * global `ng` object.\n * @param value The value to export.\n */\n\n\nfunction exportNgVar(name, value) {\n if (typeof COMPILED === 'undefined' || !COMPILED) {\n // Note: we can't export `ng` when using closure enhanced optimization as:\n // - closure declares globals itself for minified names, which sometimes clobber our `ng` global\n // - we can't declare a closure extern as the namespace `ng` is already used within Google\n // for typings for angularJS (via `goog.provide('ng....')`).\n const ng = ɵglobal['ng'] = ɵglobal['ng'] || {};\n ng[name] = value;\n }\n}\n/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n\nconst win = typeof window !== 'undefined' && window || {};\n/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nclass ChangeDetectionPerfRecord {\n constructor(msPerTick, numTicks) {\n this.msPerTick = msPerTick;\n this.numTicks = numTicks;\n }\n\n}\n/**\n * Entry point for all Angular profiling-related debug tools. This object\n * corresponds to the `ng.profiler` in the dev console.\n */\n\n\nclass AngularProfiler {\n constructor(ref) {\n this.appRef = ref.injector.get(ApplicationRef);\n } // tslint:disable:no-console\n\n /**\n * Exercises change detection in a loop and then prints the average amount of\n * time in milliseconds how long a single round of change detection takes for\n * the current state of the UI. It runs a minimum of 5 rounds for a minimum\n * of 500 milliseconds.\n *\n * Optionally, a user may pass a `config` parameter containing a map of\n * options. Supported options are:\n *\n * `record` (boolean) - causes the profiler to record a CPU profile while\n * it exercises the change detector. Example:\n *\n * ```\n * ng.profiler.timeChangeDetection({record: true})\n * ```\n */\n\n\n timeChangeDetection(config) {\n const record = config && config['record'];\n const profileName = 'Change Detection'; // Profiler is not available in Android browsers without dev tools opened\n\n const isProfilerAvailable = win.console.profile != null;\n\n if (record && isProfilerAvailable) {\n win.console.profile(profileName);\n }\n\n const start = performanceNow();\n let numTicks = 0;\n\n while (numTicks < 5 || performanceNow() - start < 500) {\n this.appRef.tick();\n numTicks++;\n }\n\n const end = performanceNow();\n\n if (record && isProfilerAvailable) {\n win.console.profileEnd(profileName);\n }\n\n const msPerTick = (end - start) / numTicks;\n win.console.log(`ran ${numTicks} change detection cycles`);\n win.console.log(`${msPerTick.toFixed(2)} ms per check`);\n return new ChangeDetectionPerfRecord(msPerTick, numTicks);\n }\n\n}\n\nfunction performanceNow() {\n return win.performance && win.performance.now ? win.performance.now() : new Date().getTime();\n}\n/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n\nconst PROFILER_GLOBAL_NAME = 'profiler';\n/**\n * Enabled Angular debug tools that are accessible via your browser's\n * developer console.\n *\n * Usage:\n *\n * 1. Open developer console (e.g. in Chrome Ctrl + Shift + j)\n * 1. Type `ng.` (usually the console will show auto-complete suggestion)\n * 1. Try the change detection profiler `ng.profiler.timeChangeDetection()`\n * then hit Enter.\n *\n * @publicApi\n */\n\nfunction enableDebugTools(ref) {\n exportNgVar(PROFILER_GLOBAL_NAME, new AngularProfiler(ref));\n return ref;\n}\n/**\n * Disables Angular tools.\n *\n * @publicApi\n */\n\n\nfunction disableDebugTools() {\n exportNgVar(PROFILER_GLOBAL_NAME, null);\n}\n/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n\nfunction escapeHtml(text) {\n const escapedText = {\n '&': '&a;',\n '\"': '&q;',\n '\\'': '&s;',\n '<': '&l;',\n '>': '&g;'\n };\n return text.replace(/[&\"'<>]/g, s => escapedText[s]);\n}\n\nfunction unescapeHtml(text) {\n const unescapedText = {\n '&a;': '&',\n '&q;': '\"',\n '&s;': '\\'',\n '&l;': '<',\n '&g;': '>'\n };\n return text.replace(/&[^;]+;/g, s => unescapedText[s]);\n}\n/**\n * Create a `StateKey<T>` that can be used to store value of type T with `TransferState`.\n *\n * Example:\n *\n * ```\n * const COUNTER_KEY = makeStateKey<number>('counter');\n * let value = 10;\n *\n * transferState.set(COUNTER_KEY, value);\n * ```\n *\n * @publicApi\n */\n\n\nfunction makeStateKey(key) {\n return key;\n}\n/**\n * A key value store that is transferred from the application on the server side to the application\n * on the client side.\n *\n * `TransferState` will be available as an injectable token. To use it import\n * `ServerTransferStateModule` on the server and `BrowserTransferStateModule` on the client.\n *\n * The values in the store are serialized/deserialized using JSON.stringify/JSON.parse. So only\n * boolean, number, string, null and non-class objects will be serialized and deserialized in a\n * non-lossy manner.\n *\n * @publicApi\n */\n\n\nlet TransferState = /*#__PURE__*/(() => {\n class TransferState {\n constructor() {\n this.store = {};\n this.onSerializeCallbacks = {};\n }\n /** @internal */\n\n\n static init(initState) {\n const transferState = new TransferState();\n transferState.store = initState;\n return transferState;\n }\n /**\n * Get the value corresponding to a key. Return `defaultValue` if key is not found.\n */\n\n\n get(key, defaultValue) {\n return this.store[key] !== undefined ? this.store[key] : defaultValue;\n }\n /**\n * Set the value corresponding to a key.\n */\n\n\n set(key, value) {\n this.store[key] = value;\n }\n /**\n * Remove a key from the store.\n */\n\n\n remove(key) {\n delete this.store[key];\n }\n /**\n * Test whether a key exists in the store.\n */\n\n\n hasKey(key) {\n return this.store.hasOwnProperty(key);\n }\n /**\n * Register a callback to provide the value for a key when `toJson` is called.\n */\n\n\n onSerialize(key, callback) {\n this.onSerializeCallbacks[key] = callback;\n }\n /**\n * Serialize the current state of the store to JSON.\n */\n\n\n toJson() {\n // Call the onSerialize callbacks and put those values into the store.\n for (const key in this.onSerializeCallbacks) {\n if (this.onSerializeCallbacks.hasOwnProperty(key)) {\n try {\n this.store[key] = this.onSerializeCallbacks[key]();\n } catch (e) {\n console.warn('Exception in onSerialize callback: ', e);\n }\n }\n }\n\n return JSON.stringify(this.store);\n }\n\n }\n\n TransferState.ɵfac = function TransferState_Factory(t) {\n return new (t || TransferState)();\n };\n\n TransferState.ɵprov = /* @__PURE__ */i0.ɵɵdefineInjectable({\n token: TransferState,\n factory: TransferState.ɵfac\n });\n return TransferState;\n})();\n\n/*#__PURE__*/\n(function () {\n (typeof ngDevMode === \"undefined\" || ngDevMode) && void 0;\n})();\n\nfunction initTransferState(doc, appId) {\n // Locate the script tag with the JSON data transferred from the server.\n // The id of the script tag is set to the Angular appId + 'state'.\n const script = doc.getElementById(appId + '-state');\n let initialState = {};\n\n if (script && script.textContent) {\n try {\n // Avoid using any here as it triggers lint errors in google3 (any is not allowed).\n initialState = JSON.parse(unescapeHtml(script.textContent));\n } catch (e) {\n console.warn('Exception while restoring TransferState for app ' + appId, e);\n }\n }\n\n return TransferState.init(initialState);\n}\n/**\n * NgModule to install on the client side while using the `TransferState` to transfer state from\n * server to client.\n *\n * @publicApi\n */\n\n\nlet BrowserTransferStateModule = /*#__PURE__*/(() => {\n class BrowserTransferStateModule {}\n\n BrowserTransferStateModule.ɵfac = function BrowserTransferStateModule_Factory(t) {\n return new (t || BrowserTransferStateModule)();\n };\n\n BrowserTransferStateModule.ɵmod = /* @__PURE__ */i0.ɵɵdefineNgModule({\n type: BrowserTransferStateModule\n });\n BrowserTransferStateModule.ɵinj = /* @__PURE__ */i0.ɵɵdefineInjector({\n providers: [{\n provide: TransferState,\n useFactory: initTransferState,\n deps: [DOCUMENT, APP_ID]\n }]\n });\n return BrowserTransferStateModule;\n})();\n\n/*#__PURE__*/\n(function () {\n (typeof ngDevMode === \"undefined\" || ngDevMode) && void 0;\n})();\n/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n/**\n * Predicates for use with {@link DebugElement}'s query functions.\n *\n * @publicApi\n */\n\n\nclass By {\n /**\n * Match all nodes.\n *\n * @usageNotes\n * ### Example\n *\n * {@example platform-browser/dom/debug/ts/by/by.ts region='by_all'}\n */\n static all() {\n return () => true;\n }\n /**\n * Match elements by the given CSS selector.\n *\n * @usageNotes\n * ### Example\n *\n * {@example platform-browser/dom/debug/ts/by/by.ts region='by_css'}\n */\n\n\n static css(selector) {\n return debugElement => {\n return debugElement.nativeElement != null ? elementMatches(debugElement.nativeElement, selector) : false;\n };\n }\n /**\n * Match nodes that have the given directive present.\n *\n * @usageNotes\n * ### Example\n *\n * {@example platform-browser/dom/debug/ts/by/by.ts region='by_directive'}\n */\n\n\n static directive(type) {\n return debugNode => debugNode.providerTokens.indexOf(type) !== -1;\n }\n\n}\n\nfunction elementMatches(n, selector) {\n if (ɵgetDOM().isElementNode(n)) {\n return n.matches && n.matches(selector) || n.msMatchesSelector && n.msMatchesSelector(selector) || n.webkitMatchesSelector && n.webkitMatchesSelector(selector);\n }\n\n return false;\n}\n/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n/**\n * Supported HammerJS recognizer event names.\n */\n\n\nconst EVENT_NAMES = {\n // pan\n 'pan': true,\n 'panstart': true,\n 'panmove': true,\n 'panend': true,\n 'pancancel': true,\n 'panleft': true,\n 'panright': true,\n 'panup': true,\n 'pandown': true,\n // pinch\n 'pinch': true,\n 'pinchstart': true,\n 'pinchmove': true,\n 'pinchend': true,\n 'pinchcancel': true,\n 'pinchin': true,\n 'pinchout': true,\n // press\n 'press': true,\n 'pressup': true,\n // rotate\n 'rotate': true,\n 'rotatestart': true,\n 'rotatemove': true,\n 'rotateend': true,\n 'rotatecancel': true,\n // swipe\n 'swipe': true,\n 'swipeleft': true,\n 'swiperight': true,\n 'swipeup': true,\n 'swipedown': true,\n // tap\n 'tap': true,\n 'doubletap': true\n};\n/**\n * DI token for providing [HammerJS](https://hammerjs.github.io/) support to Angular.\n * @see `HammerGestureConfig`\n *\n * @ngModule HammerModule\n * @publicApi\n */\n\nconst HAMMER_GESTURE_CONFIG = /*#__PURE__*/new InjectionToken('HammerGestureConfig');\n/**\n * Injection token used to provide a {@link HammerLoader} to Angular.\n *\n * @publicApi\n */\n\nconst HAMMER_LOADER = /*#__PURE__*/new InjectionToken('HammerLoader');\n/**\n * An injectable [HammerJS Manager](https://hammerjs.github.io/api/#hammermanager)\n * for gesture recognition. Configures specific event recognition.\n * @publicApi\n */\n\nlet HammerGestureConfig = /*#__PURE__*/(() => {\n class HammerGestureConfig {\n constructor() {\n /**\n * A set of supported event names for gestures to be used in Angular.\n * Angular supports all built-in recognizers, as listed in\n * [HammerJS documentation](https://hammerjs.github.io/).\n */\n this.events = [];\n /**\n * Maps gesture event names to a set of configuration options\n * that specify overrides to the default values for specific properties.\n *\n * The key is a supported event name to be configured,\n * and the options object contains a set of properties, with override values\n * to be applied to the named recognizer event.\n * For example, to disable recognition of the rotate event, specify\n * `{\"rotate\": {\"enable\": false}}`.\n *\n * Properties that are not present take the HammerJS default values.\n * For information about which properties are supported for which events,\n * and their allowed and default values, see\n * [HammerJS documentation](https://hammerjs.github.io/).\n *\n */\n\n this.overrides = {};\n }\n /**\n * Creates a [HammerJS Manager](https://hammerjs.github.io/api/#hammermanager)\n * and attaches it to a given HTML element.\n * @param element The element that will recognize gestures.\n * @returns A HammerJS event-manager object.\n */\n\n\n buildHammer(element) {\n const mc = new Hammer(element, this.options);\n mc.get('pinch').set({\n enable: true\n });\n mc.get('rotate').set({\n enable: true\n });\n\n for (const eventName in this.overrides) {\n mc.get(eventName).set(this.overrides[eventName]);\n }\n\n return mc;\n }\n\n }\n\n HammerGestureConfig.ɵfac = function HammerGestureConfig_Factory(t) {\n return new (t || HammerGestureConfig)();\n };\n\n HammerGestureConfig.ɵprov = /* @__PURE__ */i0.ɵɵdefineInjectable({\n token: HammerGestureConfig,\n factory: HammerGestureConfig.ɵfac\n });\n return HammerGestureConfig;\n})();\n\n/*#__PURE__*/\n(function () {\n (typeof ngDevMode === \"undefined\" || ngDevMode) && void 0;\n})();\n/**\n * Event plugin that adds Hammer support to an application.\n *\n * @ngModule HammerModule\n */\n\n\nlet HammerGesturesPlugin = /*#__PURE__*/(() => {\n class HammerGesturesPlugin extends EventManagerPlugin {\n constructor(doc, _config, console, loader) {\n super(doc);\n this._config = _config;\n this.console = console;\n this.loader = loader;\n this._loaderPromise = null;\n }\n\n supports(eventName) {\n if (!EVENT_NAMES.hasOwnProperty(eventName.toLowerCase()) && !this.isCustomEvent(eventName)) {\n return false;\n }\n\n if (!window.Hammer && !this.loader) {\n if (typeof ngDevMode === 'undefined' || ngDevMode) {\n this.console.warn(`The \"${eventName}\" event cannot be bound because Hammer.JS is not ` + `loaded and no custom loader has been specified.`);\n }\n\n return false;\n }\n\n return true;\n }\n\n addEventListener(element, eventName, handler) {\n const zone = this.manager.getZone();\n eventName = eventName.toLowerCase(); // If Hammer is not present but a loader is specified, we defer adding the event listener\n // until Hammer is loaded.\n\n if (!window.Hammer && this.loader) {\n this._loaderPromise = this._loaderPromise || this.loader(); // This `addEventListener` method returns a function to remove the added listener.\n // Until Hammer is loaded, the returned function needs to *cancel* the registration rather\n // than remove anything.\n\n let cancelRegistration = false;\n\n let deregister = () => {\n cancelRegistration = true;\n };\n\n this._loaderPromise.then(() => {\n // If Hammer isn't actually loaded when the custom loader resolves, give up.\n if (!window.Hammer) {\n if (typeof ngDevMode === 'undefined' || ngDevMode) {\n this.console.warn(`The custom HAMMER_LOADER completed, but Hammer.JS is not present.`);\n }\n\n deregister = () => {};\n\n return;\n }\n\n if (!cancelRegistration) {\n // Now that Hammer is loaded and the listener is being loaded for real,\n // the deregistration function changes from canceling registration to removal.\n deregister = this.addEventListener(element, eventName, handler);\n }\n }).catch(() => {\n if (typeof ngDevMode === 'undefined' || ngDevMode) {\n this.console.warn(`The \"${eventName}\" event cannot be bound because the custom ` + `Hammer.JS loader failed.`);\n }\n\n deregister = () => {};\n }); // Return a function that *executes* `deregister` (and not `deregister` itself) so that we\n // can change the behavior of `deregister` once the listener is added. Using a closure in\n // this way allows us to avoid any additional data structures to track listener removal.\n\n\n return () => {\n deregister();\n };\n }\n\n return zone.runOutsideAngular(() => {\n // Creating the manager bind events, must be done outside of angular\n const mc = this._config.buildHammer(element);\n\n const callback = function (eventObj) {\n zone.runGuarded(function () {\n handler(eventObj);\n });\n };\n\n mc.on(eventName, callback);\n return () => {\n mc.off(eventName, callback); // destroy mc to prevent memory leak\n\n if (typeof mc.destroy === 'function') {\n mc.destroy();\n }\n };\n });\n }\n\n isCustomEvent(eventName) {\n return this._config.events.indexOf(eventName) > -1;\n }\n\n }\n\n HammerGesturesPlugin.ɵfac = function HammerGesturesPlugin_Factory(t) {\n return new (t || HammerGesturesPlugin)(i0.ɵɵinject(DOCUMENT), i0.ɵɵinject(HAMMER_GESTURE_CONFIG), i0.ɵɵinject(i0.ɵConsole), i0.ɵɵinject(HAMMER_LOADER, 8));\n };\n\n HammerGesturesPlugin.ɵprov = /* @__PURE__ */i0.ɵɵdefineInjectable({\n token: HammerGesturesPlugin,\n factory: HammerGesturesPlugin.ɵfac\n });\n return HammerGesturesPlugin;\n})();\n\n/*#__PURE__*/\n(function () {\n (typeof ngDevMode === \"undefined\" || ngDevMode) && void 0;\n})();\n/**\n * Adds support for HammerJS.\n *\n * Import this module at the root of your application so that Angular can work with\n * HammerJS to detect gesture events.\n *\n * Note that applications still need to include the HammerJS script itself. This module\n * simply sets up the coordination layer between HammerJS and Angular's EventManager.\n *\n * @publicApi\n */\n\n\nlet HammerModule = /*#__PURE__*/(() => {\n class HammerModule {}\n\n HammerModule.ɵfac = function HammerModule_Factory(t) {\n return new (t || HammerModule)();\n };\n\n HammerModule.ɵmod = /* @__PURE__ */i0.ɵɵdefineNgModule({\n type: HammerModule\n });\n HammerModule.ɵinj = /* @__PURE__ */i0.ɵɵdefineInjector({\n providers: [{\n provide: EVENT_MANAGER_PLUGINS,\n useClass: HammerGesturesPlugin,\n multi: true,\n deps: [DOCUMENT, HAMMER_GESTURE_CONFIG, ɵConsole, [new Optional(), HAMMER_LOADER]]\n }, {\n provide: HAMMER_GESTURE_CONFIG,\n useClass: HammerGestureConfig,\n deps: []\n }]\n });\n return HammerModule;\n})();\n\n/*#__PURE__*/\n(function () {\n (typeof ngDevMode === \"undefined\" || ngDevMode) && void 0;\n})();\n/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n/**\n * DomSanitizer helps preventing Cross Site Scripting Security bugs (XSS) by sanitizing\n * values to be safe to use in the different DOM contexts.\n *\n * For example, when binding a URL in an `<a [href]=\"someValue\">` hyperlink, `someValue` will be\n * sanitized so that an attacker cannot inject e.g. a `javascript:` URL that would execute code on\n * the website.\n *\n * In specific situations, it might be necessary to disable sanitization, for example if the\n * application genuinely needs to produce a `javascript:` style link with a dynamic value in it.\n * Users can bypass security by constructing a value with one of the `bypassSecurityTrust...`\n * methods, and then binding to that value from the template.\n *\n * These situations should be very rare, and extraordinary care must be taken to avoid creating a\n * Cross Site Scripting (XSS) security bug!\n *\n * When using `bypassSecurityTrust...`, make sure to call the method as early as possible and as\n * close as possible to the source of the value, to make it easy to verify no security bug is\n * created by its use.\n *\n * It is not required (and not recommended) to bypass security if the value is safe, e.g. a URL that\n * does not start with a suspicious protocol, or an HTML snippet that does not contain dangerous\n * code. The sanitizer leaves safe values intact.\n *\n * @security Calling any of the `bypassSecurityTrust...` APIs disables Angular's built-in\n * sanitization for the value passed in. Carefully check and audit all values and code paths going\n * into this call. Make sure any user data is appropriately escaped for this security context.\n * For more detail, see the [Security Guide](https://g.co/ng/security).\n *\n * @publicApi\n */\n\n\nlet DomSanitizer = /*#__PURE__*/(() => {\n class DomSanitizer {}\n\n DomSanitizer.ɵfac = function DomSanitizer_Factory(t) {\n return new (t || DomSanitizer)();\n };\n\n DomSanitizer.ɵprov = /* @__PURE__ */i0.ɵɵdefineInjectable({\n token: DomSanitizer,\n factory: function DomSanitizer_Factory(t) {\n let r = null;\n\n if (t) {\n r = new (t || DomSanitizer)();\n } else {\n r = i0.ɵɵinject(DomSanitizerImpl);\n }\n\n return r;\n },\n providedIn: 'root'\n });\n return DomSanitizer;\n})();\n\n/*#__PURE__*/\n(function () {\n (typeof ngDevMode === \"undefined\" || ngDevMode) && void 0;\n})();\n\nfunction domSanitizerImplFactory(injector) {\n return new DomSanitizerImpl(injector.get(DOCUMENT));\n}\n\nlet DomSanitizerImpl = /*#__PURE__*/(() => {\n class DomSanitizerImpl extends DomSanitizer {\n constructor(_doc) {\n super();\n this._doc = _doc;\n }\n\n sanitize(ctx, value) {\n if (value == null) return null;\n\n switch (ctx) {\n case SecurityContext.NONE:\n return value;\n\n case SecurityContext.HTML:\n if (ɵallowSanitizationBypassAndThrow(value, \"HTML\"\n /* Html */\n )) {\n return ɵunwrapSafeValue(value);\n }\n\n return ɵ_sanitizeHtml(this._doc, String(value)).toString();\n\n case SecurityContext.STYLE:\n if (ɵallowSanitizationBypassAndThrow(value, \"Style\"\n /* Style */\n )) {\n return ɵunwrapSafeValue(value);\n }\n\n return value;\n\n case SecurityContext.SCRIPT:\n if (ɵallowSanitizationBypassAndThrow(value, \"Script\"\n /* Script */\n )) {\n return ɵunwrapSafeValue(value);\n }\n\n throw new Error('unsafe value used in a script context');\n\n case SecurityContext.URL:\n const type = ɵgetSanitizationBypassType(value);\n\n if (ɵallowSanitizationBypassAndThrow(value, \"URL\"\n /* Url */\n )) {\n return ɵunwrapSafeValue(value);\n }\n\n return ɵ_sanitizeUrl(String(value));\n\n case SecurityContext.RESOURCE_URL:\n if (ɵallowSanitizationBypassAndThrow(value, \"ResourceURL\"\n /* ResourceUrl */\n )) {\n return ɵunwrapSafeValue(value);\n }\n\n throw new Error('unsafe value used in a resource URL context (see https://g.co/ng/security#xss)');\n\n default:\n throw new Error(`Unexpected SecurityContext ${ctx} (see https://g.co/ng/security#xss)`);\n }\n }\n\n bypassSecurityTrustHtml(value) {\n return ɵbypassSanitizationTrustHtml(value);\n }\n\n bypassSecurityTrustStyle(value) {\n return ɵbypassSanitizationTrustStyle(value);\n }\n\n bypassSecurityTrustScript(value) {\n return ɵbypassSanitizationTrustScript(value);\n }\n\n bypassSecurityTrustUrl(value) {\n return ɵbypassSanitizationTrustUrl(value);\n }\n\n bypassSecurityTrustResourceUrl(value) {\n return ɵbypassSanitizationTrustResourceUrl(value);\n }\n\n }\n\n DomSanitizerImpl.ɵfac = function DomSanitizerImpl_Factory(t) {\n return new (t || DomSanitizerImpl)(i0.ɵɵinject(DOCUMENT));\n };\n\n DomSanitizerImpl.ɵprov = /* @__PURE__ */i0.ɵɵdefineInjectable({\n token: DomSanitizerImpl,\n factory: function DomSanitizerImpl_Factory(t) {\n let r = null;\n\n if (t) {\n r = new t();\n } else {\n r = domSanitizerImplFactory(i0.ɵɵinject(Injector));\n }\n\n return r;\n },\n providedIn: 'root'\n });\n return DomSanitizerImpl;\n})();\n\n/*#__PURE__*/\n(function () {\n (typeof ngDevMode === \"undefined\" || ngDevMode) && void 0;\n})();\n/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n/**\n * @publicApi\n */\n\n\nconst VERSION = /*#__PURE__*/new Version('13.3.11');\n/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n// This file only reexports content of the `src` folder. Keep it that way.\n\n/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n/**\n * Generated bundle index. Do not edit.\n */\n\nexport { BrowserModule, BrowserTransferStateModule, By, DomSanitizer, EVENT_MANAGER_PLUGINS, EventManager, HAMMER_GESTURE_CONFIG, HAMMER_LOADER, HammerGestureConfig, HammerModule, Meta, Title, TransferState, VERSION, disableDebugTools, enableDebugTools, makeStateKey, platformBrowser, BrowserDomAdapter as ɵBrowserDomAdapter, BrowserGetTestability as ɵBrowserGetTestability, DomEventsPlugin as ɵDomEventsPlugin, DomRendererFactory2 as ɵDomRendererFactory2, DomSanitizerImpl as ɵDomSanitizerImpl, DomSharedStylesHost as ɵDomSharedStylesHost, HammerGesturesPlugin as ɵHammerGesturesPlugin, INTERNAL_BROWSER_PLATFORM_PROVIDERS as ɵINTERNAL_BROWSER_PLATFORM_PROVIDERS, KeyEventsPlugin as ɵKeyEventsPlugin, NAMESPACE_URIS as ɵNAMESPACE_URIS, SharedStylesHost as ɵSharedStylesHost, TRANSITION_ID as ɵTRANSITION_ID, escapeHtml as ɵescapeHtml, flattenStyles as ɵflattenStyles, initDomAdapter as ɵinitDomAdapter, shimContentAttribute as ɵshimContentAttribute, shimHostAttribute as ɵshimHostAttribute }; //# sourceMappingURL=platform-browser.mjs.map","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import { QueueAction } from './QueueAction';\nimport { QueueScheduler } from './QueueScheduler';\nexport const queueScheduler = new QueueScheduler(QueueAction);\nexport const queue = queueScheduler; //# sourceMappingURL=queue.js.map","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import { ConfigOptionsInterpreter } from '../config-options/config-options-interpreter';\nimport { Device } from '../util/eufy-security-client.utils';\nimport * as i0 from \"@angular/core\";\nimport * as i1 from \"../plugin.service\";\nimport * as i2 from \"@angular/router\";\nimport * as i3 from \"@angular/common\";\nimport * as i4 from \"../config-options/ignore-accessory/ignore-accessory.component\";\nimport * as i5 from \"../config-options/enable-camera/enable-camera.component\";\nimport * as i6 from \"../config-options/livestream-cache/livestream-cache.component\";\nimport * as i7 from \"../config-options/rtsp-streaming/rtsp-streaming.component\";\nimport * as i8 from \"../config-options/enable-audio/enable-audio.component\";\nimport * as i9 from \"../config-options/talkback/talkback.component\";\nimport * as i10 from \"../config-options/camera-buttons/camera-buttons.component\";\nimport * as i11 from \"../config-options/unbridge-accessory/unbridge-accessory.component\";\nimport * as i12 from \"../config-options/snapshot-handling-method/snapshot-handling-method.component\";\nimport * as i13 from \"../config-options/immediate-notification-on-ring/immediate-notification-on-ring.component\";\nimport * as i14 from \"../config-options/delay-camera-snapshots/delay-camera-snapshots.component\";\nimport * as i15 from \"../config-options/periodic-snapshot-refresh/periodic-snapshot-refresh.component\";\nimport * as i16 from \"../config-options/force-refreshsnap/force-refreshsnap.component\";\nimport * as i17 from \"../config-options/advanced-videoconfig/advanced-videoconfig.component\";\n\nfunction CameraConfigOptionsComponent_div_2_div_9_hr_5_Template(rf, ctx) {\n if (rf & 1) {\n i0.ɵɵelement(0, \"hr\");\n }\n}\n\nfunction CameraConfigOptionsComponent_div_2_div_9_app_rtsp_streaming_6_Template(rf, ctx) {\n if (rf & 1) {\n i0.ɵɵelement(0, \"app-rtsp-streaming\", 6);\n }\n\n if (rf & 2) {\n const ctx_r4 = i0.ɵɵnextContext(3);\n i0.ɵɵproperty(\"accessory\", ctx_r4.accessory);\n }\n}\n\nfunction CameraConfigOptionsComponent_div_2_div_9_hr_9_Template(rf, ctx) {\n if (rf & 1) {\n i0.ɵɵelement(0, \"hr\");\n }\n}\n\nfunction CameraConfigOptionsComponent_div_2_div_9_app_talkback_10_Template(rf, ctx) {\n if (rf & 1) {\n i0.ɵɵelement(0, \"app-talkback\", 6);\n }\n\n if (rf & 2) {\n const ctx_r6 = i0.ɵɵnextContext(3);\n i0.ɵɵproperty(\"accessory\", ctx_r6.accessory);\n }\n}\n\nfunction CameraConfigOptionsComponent_div_2_div_9_Template(rf, ctx) {\n if (rf & 1) {\n i0.ɵɵelementStart(0, \"div\");\n i0.ɵɵelement(1, \"hr\")(2, \"app-enable-camera\", 6)(3, \"hr\")(4, \"app-livestream-cache\", 6);\n i0.ɵɵtemplate(5, CameraConfigOptionsComponent_div_2_div_9_hr_5_Template, 1, 0, \"hr\", 2);\n i0.ɵɵtemplate(6, CameraConfigOptionsComponent_div_2_div_9_app_rtsp_streaming_6_Template, 1, 1, \"app-rtsp-streaming\", 7);\n i0.ɵɵelement(7, \"hr\")(8, \"app-enable-audio\", 6);\n i0.ɵɵtemplate(9, CameraConfigOptionsComponent_div_2_div_9_hr_9_Template, 1, 0, \"hr\", 2);\n i0.ɵɵtemplate(10, CameraConfigOptionsComponent_div_2_div_9_app_talkback_10_Template, 1, 1, \"app-talkback\", 7);\n i0.ɵɵelementEnd();\n }\n\n if (rf & 2) {\n const ctx_r2 = i0.ɵɵnextContext(2);\n i0.ɵɵadvance(2);\n i0.ɵɵproperty(\"accessory\", ctx_r2.accessory);\n i0.ɵɵadvance(2);\n i0.ɵɵproperty(\"accessory\", ctx_r2.accessory);\n i0.ɵɵadvance(1);\n i0.ɵɵproperty(\"ngIf\", ctx_r2.supportsRTSP);\n i0.ɵɵadvance(1);\n i0.ɵɵproperty(\"ngIf\", ctx_r2.supportsRTSP);\n i0.ɵɵadvance(2);\n i0.ɵɵproperty(\"accessory\", ctx_r2.accessory);\n i0.ɵɵadvance(1);\n i0.ɵɵproperty(\"ngIf\", ctx_r2.supportsTalkback);\n i0.ɵɵadvance(1);\n i0.ɵɵproperty(\"ngIf\", ctx_r2.supportsTalkback);\n }\n}\n\nfunction CameraConfigOptionsComponent_div_2_Template(rf, ctx) {\n if (rf & 1) {\n i0.ɵɵelementStart(0, \"div\", 3)(1, \"div\", 4)(2, \"b\");\n i0.ɵɵtext(3, \"Camera Settings\");\n i0.ɵɵelementEnd();\n i0.ɵɵtext(4, \" for \");\n i0.ɵɵelementStart(5, \"i\");\n i0.ɵɵtext(6);\n i0.ɵɵelementEnd()();\n i0.ɵɵelementStart(7, \"div\", 5);\n i0.ɵɵelement(8, \"app-ignore-accessory\", 6);\n i0.ɵɵtemplate(9, CameraConfigOptionsComponent_div_2_div_9_Template, 11, 7, \"div\", 2);\n i0.ɵɵelementEnd()();\n }\n\n if (rf & 2) {\n const ctx_r0 = i0.ɵɵnextContext();\n i0.ɵɵadvance(6);\n i0.ɵɵtextInterpolate2(\"\", ctx_r0.accessory.displayName, \" (\", ctx_r0.accessory.uniqueId, \")\");\n i0.ɵɵadvance(2);\n i0.ɵɵproperty(\"accessory\", ctx_r0.accessory);\n i0.ɵɵadvance(1);\n i0.ɵɵproperty(\"ngIf\", ctx_r0.isCamera);\n }\n}\n\nfunction CameraConfigOptionsComponent_div_3_div_2_Template(rf, ctx) {\n if (rf & 1) {\n i0.ɵɵelementStart(0, \"div\", 3)(1, \"div\", 4)(2, \"b\");\n i0.ɵɵtext(3, \"HomeKit Behaviour\");\n i0.ɵɵelementEnd();\n i0.ɵɵtext(4, \" for \");\n i0.ɵɵelementStart(5, \"i\");\n i0.ɵɵtext(6);\n i0.ɵɵelementEnd()();\n i0.ɵɵelementStart(7, \"div\", 5);\n i0.ɵɵelement(8, \"app-camera-buttons\", 6)(9, \"hr\")(10, \"app-unbridge-accessory\", 6);\n i0.ɵɵelementEnd()();\n }\n\n if (rf & 2) {\n const ctx_r7 = i0.ɵɵnextContext(2);\n i0.ɵɵadvance(6);\n i0.ɵɵtextInterpolate2(\"\", ctx_r7.accessory.displayName, \" (\", ctx_r7.accessory.uniqueId, \")\");\n i0.ɵɵadvance(2);\n i0.ɵɵproperty(\"accessory\", ctx_r7.accessory);\n i0.ɵɵadvance(2);\n i0.ɵɵproperty(\"accessory\", ctx_r7.accessory);\n }\n}\n\nfunction CameraConfigOptionsComponent_div_3_div_4_hr_9_Template(rf, ctx) {\n if (rf & 1) {\n i0.ɵɵelement(0, \"hr\");\n }\n}\n\nfunction CameraConfigOptionsComponent_div_3_div_4_app_immediate_notification_on_ring_10_Template(rf, ctx) {\n if (rf & 1) {\n i0.ɵɵelement(0, \"app-immediate-notification-on-ring\", 6);\n }\n\n if (rf & 2) {\n const ctx_r10 = i0.ɵɵnextContext(3);\n i0.ɵɵproperty(\"accessory\", ctx_r10.accessory);\n }\n}\n\nfunction CameraConfigOptionsComponent_div_3_div_4_div_15_Template(rf, ctx) {\n if (rf & 1) {\n i0.ɵɵelementStart(0, \"div\");\n i0.ɵɵelement(1, \"app-force-refreshsnap\", 6);\n i0.ɵɵelementEnd();\n }\n\n if (rf & 2) {\n const ctx_r11 = i0.ɵɵnextContext(3);\n i0.ɵɵadvance(1);\n i0.ɵɵproperty(\"accessory\", ctx_r11.accessory);\n }\n}\n\nfunction CameraConfigOptionsComponent_div_3_div_4_Template(rf, ctx) {\n if (rf & 1) {\n i0.ɵɵelementStart(0, \"div\", 3)(1, \"div\", 4)(2, \"b\");\n i0.ɵɵtext(3, \"Snapshot Behaviour\");\n i0.ɵɵelementEnd();\n i0.ɵɵtext(4, \" for \");\n i0.ɵɵelementStart(5, \"i\");\n i0.ɵɵtext(6);\n i0.ɵɵelementEnd()();\n i0.ɵɵelementStart(7, \"div\", 5);\n i0.ɵɵelement(8, \"app-snapshot-handling-method\", 6);\n i0.ɵɵtemplate(9, CameraConfigOptionsComponent_div_3_div_4_hr_9_Template, 1, 0, \"hr\", 2);\n i0.ɵɵtemplate(10, CameraConfigOptionsComponent_div_3_div_4_app_immediate_notification_on_ring_10_Template, 1, 1, \"app-immediate-notification-on-ring\", 7);\n i0.ɵɵelement(11, \"hr\")(12, \"app-delay-camera-snapshots\", 6)(13, \"hr\")(14, \"app-periodic-snapshot-refresh\", 6);\n i0.ɵɵtemplate(15, CameraConfigOptionsComponent_div_3_div_4_div_15_Template, 2, 1, \"div\", 2);\n i0.ɵɵelementEnd()();\n }\n\n if (rf & 2) {\n const ctx_r8 = i0.ɵɵnextContext(2);\n i0.ɵɵadvance(6);\n i0.ɵɵtextInterpolate2(\"\", ctx_r8.accessory.displayName, \" (\", ctx_r8.accessory.uniqueId, \")\");\n i0.ɵɵadvance(2);\n i0.ɵɵproperty(\"accessory\", ctx_r8.accessory);\n i0.ɵɵadvance(1);\n i0.ɵɵproperty(\"ngIf\", ctx_r8.isDoorbell);\n i0.ɵɵadvance(1);\n i0.ɵɵproperty(\"ngIf\", ctx_r8.isDoorbell);\n i0.ɵɵadvance(2);\n i0.ɵɵproperty(\"accessory\", ctx_r8.accessory);\n i0.ɵɵadvance(2);\n i0.ɵɵproperty(\"accessory\", ctx_r8.accessory);\n i0.ɵɵadvance(1);\n i0.ɵɵproperty(\"ngIf\", !ctx_r8.showEnhancedSnapshotBehaviour);\n }\n}\n\nfunction CameraConfigOptionsComponent_div_3_Template(rf, ctx) {\n if (rf & 1) {\n i0.ɵɵelementStart(0, \"div\");\n i0.ɵɵelement(1, \"p\");\n i0.ɵɵtemplate(2, CameraConfigOptionsComponent_div_3_div_2_Template, 11, 4, \"div\", 1);\n i0.ɵɵelement(3, \"p\");\n i0.ɵɵtemplate(4, CameraConfigOptionsComponent_div_3_div_4_Template, 16, 8, \"div\", 1);\n i0.ɵɵelement(5, \"p\")(6, \"app-advanced-videoconfig\", 6);\n i0.ɵɵelementEnd();\n }\n\n if (rf & 2) {\n const ctx_r1 = i0.ɵɵnextContext();\n i0.ɵɵadvance(2);\n i0.ɵɵproperty(\"ngIf\", ctx_r1.accessory);\n i0.ɵɵadvance(2);\n i0.ɵɵproperty(\"ngIf\", ctx_r1.accessory);\n i0.ɵɵadvance(2);\n i0.ɵɵproperty(\"accessory\", ctx_r1.accessory);\n }\n}\n\nexport let CameraConfigOptionsComponent = /*#__PURE__*/(() => {\n class CameraConfigOptionsComponent extends ConfigOptionsInterpreter {\n constructor(pluginService, route) {\n super(pluginService);\n this.route = route;\n this.showEnhancedSnapshotBehaviour = true;\n this.isDoorbell = false;\n this.isCamera = false;\n this.supportsRTSP = false;\n this.supportsTalkback = false;\n }\n\n ngOnInit() {\n const uniqueId = this.route.snapshot.paramMap.get('uniqueId');\n this.accessory = this.pluginService.getDevice(uniqueId);\n\n if (this.accessory) {\n this.isDoorbell = Device.isDoorbell(this.accessory.type);\n this.isCamera = Device.isCamera(this.accessory.type);\n this.supportsRTSP = Device.supportsRTSP(this.accessory.type);\n this.supportsTalkback = Device.supportsTalkback(this.accessory.type); // reset rtsp and talkback setting if these are not supported\n\n if (!this.supportsRTSP) {\n this.updateConfig({\n rtsp: false\n }, this.accessory);\n }\n\n if (!this.supportsTalkback) {\n this.updateConfig({\n talkback: false\n }, this.accessory);\n }\n }\n }\n\n updateSnapshotView(value) {\n this.showEnhancedSnapshotBehaviour = value;\n }\n\n }\n\n CameraConfigOptionsComponent.ɵfac = function CameraConfigOptionsComponent_Factory(t) {\n return new (t || CameraConfigOptionsComponent)(i0.ɵɵdirectiveInject(i1.PluginService), i0.ɵɵdirectiveInject(i2.ActivatedRoute));\n };\n\n CameraConfigOptionsComponent.ɵcmp = /*@__PURE__*/i0.ɵɵdefineComponent({\n type: CameraConfigOptionsComponent,\n selectors: [[\"app-camera-config-options\"]],\n features: [i0.ɵɵInheritDefinitionFeature],\n decls: 4,\n vars: 2,\n consts: [[\"routerLink\", \"/accessories\", 1, \"btn\", \"btn-secondary\", \"mb-3\"], [\"class\", \"card\", 4, \"ngIf\"], [4, \"ngIf\"], [1, \"card\"], [1, \"card-header\"], [1, \"card-body\", \"pt-0\", \"pb-4\"], [3, \"accessory\"], [3, \"accessory\", 4, \"ngIf\"]],\n template: function CameraConfigOptionsComponent_Template(rf, ctx) {\n if (rf & 1) {\n i0.ɵɵelementStart(0, \"a\", 0);\n i0.ɵɵtext(1, \"Back to Devices List\");\n i0.ɵɵelementEnd();\n i0.ɵɵtemplate(2, CameraConfigOptionsComponent_div_2_Template, 10, 4, \"div\", 1);\n i0.ɵɵtemplate(3, CameraConfigOptionsComponent_div_3_Template, 7, 3, \"div\", 2);\n }\n\n if (rf & 2) {\n i0.ɵɵadvance(2);\n i0.ɵɵproperty(\"ngIf\", ctx.accessory);\n i0.ɵɵadvance(1);\n i0.ɵɵproperty(\"ngIf\", ctx.isCamera);\n }\n },\n directives: [i2.RouterLinkWithHref, i3.NgIf, i4.IgnoreAccessoryComponent, i5.EnableCameraComponent, i6.LivestreamCacheComponent, i7.RtspStreamingComponent, i8.EnableAudioComponent, i9.TalkbackComponent, i10.CameraButtonsComponent, i11.UnbridgeAccessoryComponent, i12.SnapshotHandlingMethodComponent, i13.ImmediateNotificationOnRingComponent, i14.DelayCameraSnapshotsComponent, i15.PeriodicSnapshotRefreshComponent, i16.ForceRefreshsnapComponent, i17.AdvancedVideoconfigComponent],\n encapsulation: 2\n });\n return CameraConfigOptionsComponent;\n})();","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import { asyncScheduler } from '../scheduler/async';\nimport { defaultThrottleConfig, throttle } from './throttle';\nimport { timer } from '../observable/timer';\nexport function throttleTime(duration, scheduler = asyncScheduler, config = defaultThrottleConfig) {\n const duration$ = timer(duration, scheduler);\n return throttle(() => duration$, config);\n} //# sourceMappingURL=throttleTime.js.map","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import getWindow from \"./getWindow.js\";\nexport default function getWindowScroll(node) {\n var win = getWindow(node);\n var scrollLeft = win.pageXOffset;\n var scrollTop = win.pageYOffset;\n return {\n scrollLeft: scrollLeft,\n scrollTop: scrollTop\n };\n}","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import _asyncToGenerator from \"/Users/rene/dev/eufy-plugin/publish/plugin/node_modules/@babel/runtime/helpers/esm/asyncToGenerator.js\";\nimport * as i0 from \"@angular/core\";\nimport * as i1 from \"./plugin.service\";\nexport let LoginService = /*#__PURE__*/(() => {\n class LoginService {\n constructor(pluginService) {\n this.pluginService = pluginService;\n }\n\n getCredentials() {\n var _this = this;\n\n return _asyncToGenerator(function* () {\n try {\n const config = yield _this.pluginService.getConfig();\n\n if (!config['username'] || !config['password']) {\n return Promise.reject('no full credentials in config');\n }\n\n return Promise.resolve({\n username: config['username'],\n password: config['password'],\n country: config['country'] ? config['country'] : 'US',\n deviceName: config['deviceName']\n });\n } catch (err) {\n return Promise.reject('no config');\n }\n })();\n }\n\n login(options) {\n return _asyncToGenerator(function* () {\n try {\n const result = yield window.homebridge.request('/login', options);\n return Promise.resolve(result);\n } catch (err) {\n return Promise.reject(err);\n }\n })();\n }\n\n updateConfigCredentials(credentials) {\n var _this2 = this;\n\n return _asyncToGenerator(function* () {\n let config = {};\n\n try {\n config = yield _this2.pluginService.getConfig();\n } catch (err) {\n console.log('Could not get credentials from config: ' + err);\n }\n\n config['username'] = credentials.username;\n config['password'] = credentials.password;\n config['country'] = credentials.country;\n config['deviceName'] = credentials.deviceName;\n yield _this2.pluginService.updateConfig(config, true);\n })();\n }\n\n }\n\n LoginService.ɵfac = function LoginService_Factory(t) {\n return new (t || LoginService)(i0.ɵɵinject(i1.PluginService));\n };\n\n LoginService.ɵprov = /*@__PURE__*/i0.ɵɵdefineInjectable({\n token: LoginService,\n factory: LoginService.ɵfac,\n providedIn: 'root'\n });\n return LoginService;\n})();","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"const {\n isArray\n} = Array;\nexport function argsOrArgArray(args) {\n return args.length === 1 && isArray(args[0]) ? args[0] : args;\n} //# sourceMappingURL=argsOrArgArray.js.map","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import getParentNode from \"./getParentNode.js\";\nimport isScrollParent from \"./isScrollParent.js\";\nimport getNodeName from \"./getNodeName.js\";\nimport { isHTMLElement } from \"./instanceOf.js\";\nexport default function getScrollParent(node) {\n if (['html', 'body', '#document'].indexOf(getNodeName(node)) >= 0) {\n // $FlowFixMe[incompatible-return]: assume body is always available\n return node.ownerDocument.body;\n }\n\n if (isHTMLElement(node) && isScrollParent(node)) {\n return node;\n }\n\n return getScrollParent(getParentNode(node));\n}","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import { max as mathMax, min as mathMin } from \"./math.js\";\nexport function within(min, value, max) {\n return mathMax(min, mathMin(value, max));\n}\nexport function withinMaxClamp(min, value, max) {\n var v = within(min, value, max);\n return v > max ? max : v;\n}","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import { ReplaySubject } from '../ReplaySubject';\nimport { multicast } from './multicast';\nimport { isFunction } from '../util/isFunction';\nexport function publishReplay(bufferSize, windowTime, selectorOrScheduler, timestampProvider) {\n if (selectorOrScheduler && !isFunction(selectorOrScheduler)) {\n timestampProvider = selectorOrScheduler;\n }\n\n const selector = isFunction(selectorOrScheduler) ? selectorOrScheduler : undefined;\n return source => multicast(new ReplaySubject(bufferSize, windowTime, timestampProvider), selector)(source);\n} //# sourceMappingURL=publishReplay.js.map","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import { ConfigOptionsInterpreter } from '../config-options-interpreter';\nimport * as i0 from \"@angular/core\";\nimport * as i1 from \"../../plugin.service\";\nimport * as i2 from \"@angular/forms\";\nexport let OmitLogFilesComponent = /*#__PURE__*/(() => {\n class OmitLogFilesComponent extends ConfigOptionsInterpreter {\n constructor(pluginService) {\n super(pluginService);\n /** Customize from here */\n\n /** updateConfig() will overwrite any settings that you'll provide */\n\n /** Don't try and 'append'/'push' to arrays this way - add a custom method instead */\n\n /** see config option to ignore devices as example */\n\n /** updateConfig() takes an optional second parameter to specify the accessoriy for which the setting is changed */\n\n this.value = false;\n }\n\n ngOnInit() {\n this.readValue();\n }\n\n readValue() {\n if (Object.prototype.hasOwnProperty.call(this.config, 'omitLogFiles')) {\n this.value = this.config['omitLogFiles'];\n }\n }\n\n update() {\n this.updateConfig({\n omitLogFiles: this.value\n });\n }\n\n }\n\n OmitLogFilesComponent.ɵfac = function OmitLogFilesComponent_Factory(t) {\n return new (t || OmitLogFilesComponent)(i0.ɵɵdirectiveInject(i1.PluginService));\n };\n\n OmitLogFilesComponent.ɵcmp = /*@__PURE__*/i0.ɵɵdefineComponent({\n type: OmitLogFilesComponent,\n selectors: [[\"app-omit-log-files\"]],\n features: [i0.ɵɵInheritDefinitionFeature],\n decls: 9,\n vars: 1,\n consts: [[1, \"settingsItem\", \"row\", \"p-3\"], [1, \"d-flex\", \"justify-content-between\", \"align-items-center\", \"mb-2\"], [1, \"form-check\", \"form-switch\"], [\"type\", \"checkbox\", \"role\", \"switch\", \"id\", \"flexSwitchCheckDefault\", 1, \"form-check-input\", 3, \"ngModel\", \"ngModelChange\", \"change\"]],\n template: function OmitLogFilesComponent_Template(rf, ctx) {\n if (rf & 1) {\n i0.ɵɵelementStart(0, \"div\", 0)(1, \"div\", 1)(2, \"span\");\n i0.ɵɵtext(3, \"Don't store log files\");\n i0.ɵɵelementEnd();\n i0.ɵɵelementStart(4, \"div\", 2)(5, \"input\", 3);\n i0.ɵɵlistener(\"ngModelChange\", function OmitLogFilesComponent_Template_input_ngModelChange_5_listener($event) {\n return ctx.value = $event;\n })(\"change\", function OmitLogFilesComponent_Template_input_change_5_listener() {\n return ctx.update();\n });\n i0.ɵɵelementEnd()()();\n i0.ɵɵelementStart(6, \"small\")(7, \"i\");\n i0.ɵɵtext(8, \" This setting prevents log files to be stored to disk. If enabled, log messages will only be written to the Homebridge UI log window. \");\n i0.ɵɵelementEnd()()();\n }\n\n if (rf & 2) {\n i0.ɵɵadvance(5);\n i0.ɵɵproperty(\"ngModel\", ctx.value);\n }\n },\n directives: [i2.CheckboxControlValueAccessor, i2.NgControlStatus, i2.NgModel],\n encapsulation: 2\n });\n return OmitLogFilesComponent;\n})();","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import { identity } from '../util/identity';\nimport { operate } from '../util/lift';\nimport { createOperatorSubscriber } from './OperatorSubscriber';\nexport function distinctUntilChanged(comparator, keySelector = identity) {\n comparator = comparator !== null && comparator !== void 0 ? comparator : defaultCompare;\n return operate((source, subscriber) => {\n let previousKey;\n let first = true;\n source.subscribe(createOperatorSubscriber(subscriber, value => {\n const currentKey = keySelector(value);\n\n if (first || !comparator(previousKey, currentKey)) {\n first = false;\n previousKey = currentKey;\n subscriber.next(value);\n }\n }));\n });\n}\n\nfunction defaultCompare(a, b) {\n return a === b;\n} //# sourceMappingURL=distinctUntilChanged.js.map","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import { mergeAll } from '../operators/mergeAll';\nimport { innerFrom } from './innerFrom';\nimport { EMPTY } from './empty';\nimport { popNumber, popScheduler } from '../util/args';\nimport { from } from './from';\nexport function merge(...args) {\n const scheduler = popScheduler(args);\n const concurrent = popNumber(args, Infinity);\n const sources = args;\n return !sources.length ? EMPTY : sources.length === 1 ? innerFrom(sources[0]) : mergeAll(concurrent)(from(sources, scheduler));\n} //# sourceMappingURL=merge.js.map","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import { AsyncScheduler } from './AsyncScheduler';\nexport class AsapScheduler extends AsyncScheduler {\n flush(action) {\n this._active = true;\n const flushId = this._scheduled;\n this._scheduled = undefined;\n const {\n actions\n } = this;\n let error;\n action = action || actions.shift();\n\n do {\n if (error = action.execute(action.state, action.delay)) {\n break;\n }\n } while ((action = actions[0]) && action.id === flushId && actions.shift());\n\n this._active = false;\n\n if (error) {\n while ((action = actions[0]) && action.id === flushId && actions.shift()) {\n action.unsubscribe();\n }\n\n throw error;\n }\n }\n\n} //# sourceMappingURL=AsapScheduler.js.map","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import _asyncToGenerator from \"/Users/rene/dev/eufy-plugin/publish/plugin/node_modules/@babel/runtime/helpers/esm/asyncToGenerator.js\";\nimport { ConfigOptionsInterpreter } from '../config-options-interpreter';\nimport { Device } from '../../../app/util/eufy-security-client.utils';\nimport * as i0 from \"@angular/core\";\nimport * as i1 from \"../../../app/plugin.service\";\nimport * as i2 from \"@angular/forms\";\nimport * as i3 from \"@angular/common\";\n\nfunction EnableCameraComponent_small_10_Template(rf, ctx) {\n if (rf & 1) {\n i0.ɵɵelementStart(0, \"small\")(1, \"i\");\n i0.ɵɵtext(2, \" This option is disabled since doorbells are handled always as cameras. \");\n i0.ɵɵelementEnd()();\n }\n}\n\nfunction EnableCameraComponent_small_11_Template(rf, ctx) {\n if (rf & 1) {\n i0.ɵɵelementStart(0, \"small\")(1, \"i\");\n i0.ɵɵtext(2, \" Cameras are handled as Motion Sensor by default, switch this setting to use as Camera \");\n i0.ɵɵelementEnd()();\n }\n}\n\nexport let EnableCameraComponent = /*#__PURE__*/(() => {\n class EnableCameraComponent extends ConfigOptionsInterpreter {\n constructor(pluginService) {\n super(pluginService);\n this.value = false;\n this.disabled = false;\n }\n\n ngOnInit() {\n this.readValue();\n }\n\n readValue() {\n var _this = this;\n\n return _asyncToGenerator(function* () {\n var _a;\n\n if (_this.accessory && Device.isDoorbell(_this.accessory.type)) {\n _this.value = true;\n _this.disabled = true;\n\n _this.update();\n }\n\n const config = yield _this.getCameraConfig(((_a = _this.accessory) === null || _a === void 0 ? void 0 : _a.uniqueId) || '');\n\n if (config && Object.prototype.hasOwnProperty.call(config, 'enableCamera')) {\n _this.value = config['enableCamera'];\n }\n })();\n }\n\n update() {\n this.updateConfig({\n enableCamera: this.value\n }, this.accessory);\n }\n\n }\n\n EnableCameraComponent.ɵfac = function EnableCameraComponent_Factory(t) {\n return new (t || EnableCameraComponent)(i0.ɵɵdirectiveInject(i1.PluginService));\n };\n\n EnableCameraComponent.ɵcmp = /*@__PURE__*/i0.ɵɵdefineComponent({\n type: EnableCameraComponent,\n selectors: [[\"app-enable-camera\"]],\n inputs: {\n accessory: \"accessory\"\n },\n features: [i0.ɵɵInheritDefinitionFeature],\n decls: 12,\n vars: 4,\n consts: [[1, \"settingsItem\", \"row\", \"p-3\"], [1, \"d-flex\", \"flex-column\", \"flex-sm-row\", \"justify-content-between\", \"align-items-start\", \"align-items-sm-center\", \"mb-2\"], [1, \"col-12\", \"col-sm-4\"], [\"aria-label\", \"Device Operation Mode\", 1, \"form-select\", 3, \"ngModel\", \"ngModelChange\", \"change\"], [\"value\", \"false\"], [\"value\", \"true\"], [4, \"ngIf\"]],\n template: function EnableCameraComponent_Template(rf, ctx) {\n if (rf & 1) {\n i0.ɵɵelementStart(0, \"div\", 0)(1, \"div\", 1)(2, \"span\");\n i0.ɵɵtext(3, \"Operation Mode\");\n i0.ɵɵelementEnd();\n i0.ɵɵelementStart(4, \"div\", 2)(5, \"select\", 3);\n i0.ɵɵlistener(\"ngModelChange\", function EnableCameraComponent_Template_select_ngModelChange_5_listener($event) {\n return ctx.value = $event;\n })(\"change\", function EnableCameraComponent_Template_select_change_5_listener() {\n return ctx.update();\n });\n i0.ɵɵelementStart(6, \"option\", 4);\n i0.ɵɵtext(7, \"Motion Sensor\");\n i0.ɵɵelementEnd();\n i0.ɵɵelementStart(8, \"option\", 5);\n i0.ɵɵtext(9, \"Camera\");\n i0.ɵɵelementEnd()()()();\n i0.ɵɵtemplate(10, EnableCameraComponent_small_10_Template, 3, 0, \"small\", 6);\n i0.ɵɵtemplate(11, EnableCameraComponent_small_11_Template, 3, 0, \"small\", 6);\n i0.ɵɵelementEnd();\n }\n\n if (rf & 2) {\n i0.ɵɵadvance(5);\n i0.ɵɵproperty(\"ngModel\", ctx.value);\n i0.ɵɵattribute(\"disabled\", ctx.disabled ? true : null);\n i0.ɵɵadvance(5);\n i0.ɵɵproperty(\"ngIf\", ctx.disabled);\n i0.ɵɵadvance(1);\n i0.ɵɵproperty(\"ngIf\", !ctx.disabled);\n }\n },\n directives: [i2.SelectControlValueAccessor, i2.NgControlStatus, i2.NgModel, i2.NgSelectOption, i2.ɵNgSelectMultipleOption, i3.NgIf],\n encapsulation: 2\n });\n return EnableCameraComponent;\n})();","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"export function noop() {} //# sourceMappingURL=noop.js.map","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import { operate } from '../util/lift';\nimport { createOperatorSubscriber } from './OperatorSubscriber';\nexport function map(project, thisArg) {\n return operate((source, subscriber) => {\n let index = 0;\n source.subscribe(createOperatorSubscriber(subscriber, value => {\n subscriber.next(project.call(thisArg, value, index++));\n }));\n });\n} //# sourceMappingURL=map.js.map","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import { Observable } from '../Observable';\nimport { argsArgArrayOrObject } from '../util/argsArgArrayOrObject';\nimport { innerFrom } from './innerFrom';\nimport { popResultSelector } from '../util/args';\nimport { createOperatorSubscriber } from '../operators/OperatorSubscriber';\nimport { mapOneOrManyArgs } from '../util/mapOneOrManyArgs';\nimport { createObject } from '../util/createObject';\nexport function forkJoin(...args) {\n const resultSelector = popResultSelector(args);\n const {\n args: sources,\n keys\n } = argsArgArrayOrObject(args);\n const result = new Observable(subscriber => {\n const {\n length\n } = sources;\n\n if (!length) {\n subscriber.complete();\n return;\n }\n\n const values = new Array(length);\n let remainingCompletions = length;\n let remainingEmissions = length;\n\n for (let sourceIndex = 0; sourceIndex < length; sourceIndex++) {\n let hasValue = false;\n innerFrom(sources[sourceIndex]).subscribe(createOperatorSubscriber(subscriber, value => {\n if (!hasValue) {\n hasValue = true;\n remainingEmissions--;\n }\n\n values[sourceIndex] = value;\n }, () => remainingCompletions--, undefined, () => {\n if (!remainingCompletions || !hasValue) {\n if (!remainingEmissions) {\n subscriber.next(keys ? createObject(keys, values) : values);\n }\n\n subscriber.complete();\n }\n }));\n }\n });\n return resultSelector ? result.pipe(mapOneOrManyArgs(resultSelector)) : result;\n} //# sourceMappingURL=forkJoin.js.map","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import { AsyncAction } from './AsyncAction';\nimport { AsyncScheduler } from './AsyncScheduler';\nexport const asyncScheduler = new AsyncScheduler(AsyncAction);\nexport const async = asyncScheduler; //# sourceMappingURL=async.js.map","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"let nextHandle = 1;\nlet resolved;\nconst activeHandles = {};\n\nfunction findAndClearHandle(handle) {\n if (handle in activeHandles) {\n delete activeHandles[handle];\n return true;\n }\n\n return false;\n}\n\nexport const Immediate = {\n setImmediate(cb) {\n const handle = nextHandle++;\n activeHandles[handle] = true;\n\n if (!resolved) {\n resolved = Promise.resolve();\n }\n\n resolved.then(() => findAndClearHandle(handle) && cb());\n return handle;\n },\n\n clearImmediate(handle) {\n findAndClearHandle(handle);\n }\n\n};\nexport const TestTools = {\n pending() {\n return Object.keys(activeHandles).length;\n }\n\n}; //# sourceMappingURL=Immediate.js.map","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import { Subscription } from '../Subscription';\nimport { operate } from '../util/lift';\nimport { innerFrom } from '../observable/innerFrom';\nimport { createOperatorSubscriber } from './OperatorSubscriber';\nimport { noop } from '../util/noop';\nimport { arrRemove } from '../util/arrRemove';\nexport function bufferToggle(openings, closingSelector) {\n return operate((source, subscriber) => {\n const buffers = [];\n innerFrom(openings).subscribe(createOperatorSubscriber(subscriber, openValue => {\n const buffer = [];\n buffers.push(buffer);\n const closingSubscription = new Subscription();\n\n const emitBuffer = () => {\n arrRemove(buffers, buffer);\n subscriber.next(buffer);\n closingSubscription.unsubscribe();\n };\n\n closingSubscription.add(innerFrom(closingSelector(openValue)).subscribe(createOperatorSubscriber(subscriber, emitBuffer, noop)));\n }, noop));\n source.subscribe(createOperatorSubscriber(subscriber, value => {\n for (const buffer of buffers) {\n buffer.push(value);\n }\n }, () => {\n while (buffers.length > 0) {\n subscriber.next(buffers.shift());\n }\n\n subscriber.complete();\n }));\n });\n} //# sourceMappingURL=bufferToggle.js.map","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import getBasePlacement from \"./getBasePlacement.js\";\nimport getVariation from \"./getVariation.js\";\nimport getMainAxisFromPlacement from \"./getMainAxisFromPlacement.js\";\nimport { top, right, bottom, left, start, end } from \"../enums.js\";\nexport default function computeOffsets(_ref) {\n var reference = _ref.reference,\n element = _ref.element,\n placement = _ref.placement;\n var basePlacement = placement ? getBasePlacement(placement) : null;\n var variation = placement ? getVariation(placement) : null;\n var commonX = reference.x + reference.width / 2 - element.width / 2;\n var commonY = reference.y + reference.height / 2 - element.height / 2;\n var offsets;\n\n switch (basePlacement) {\n case top:\n offsets = {\n x: commonX,\n y: reference.y - element.height\n };\n break;\n\n case bottom:\n offsets = {\n x: commonX,\n y: reference.y + reference.height\n };\n break;\n\n case right:\n offsets = {\n x: reference.x + reference.width,\n y: commonY\n };\n break;\n\n case left:\n offsets = {\n x: reference.x - element.width,\n y: commonY\n };\n break;\n\n default:\n offsets = {\n x: reference.x,\n y: reference.y\n };\n }\n\n var mainAxis = basePlacement ? getMainAxisFromPlacement(basePlacement) : null;\n\n if (mainAxis != null) {\n var len = mainAxis === 'y' ? 'height' : 'width';\n\n switch (variation) {\n case start:\n offsets[mainAxis] = offsets[mainAxis] - (reference[len] / 2 - element[len] / 2);\n break;\n\n case end:\n offsets[mainAxis] = offsets[mainAxis] + (reference[len] / 2 - element[len] / 2);\n break;\n\n default:\n }\n }\n\n return offsets;\n}","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import _asyncToGenerator from \"/Users/rene/dev/eufy-plugin/publish/plugin/node_modules/@babel/runtime/helpers/esm/asyncToGenerator.js\";\nimport { LoginFailReason } from '../util/types';\nimport { COUNTRIES } from '../countries';\nimport * as i0 from \"@angular/core\";\nimport * as i1 from \"../login.service\";\nimport * as i2 from \"@angular/router\";\nimport * as i3 from \"@angular/common\";\nimport * as i4 from \"@ng-bootstrap/ng-bootstrap\";\nimport * as i5 from \"@angular/forms\";\n\nfunction LoginComponent_ng_template_5_Template(rf, ctx) {\n if (rf & 1) {\n i0.ɵɵnamespaceSVG();\n i0.ɵɵtext(0, \" If you login here the new connection might interfere with any already established connection that was made by the eufy plugin itself.\");\n i0.ɵɵnamespaceHTML();\n i0.ɵɵelement(1, \"p\");\n i0.ɵɵelementStart(2, \"i\");\n i0.ɵɵtext(3, \"So even if you do not change any settings we recommened that you restart the plugin after you've connected to the eufy cloud here.\");\n i0.ɵɵelementEnd();\n }\n}\n\nfunction LoginComponent_p_8_Template(rf, ctx) {\n if (rf & 1) {\n const _r7 = i0.ɵɵgetCurrentView();\n\n i0.ɵɵelementStart(0, \"p\", 10)(1, \"ngb-alert\", 11);\n i0.ɵɵlistener(\"closed\", function LoginComponent_p_8_Template_ngb_alert_closed_1_listener() {\n i0.ɵɵrestoreView(_r7);\n const ctx_r6 = i0.ɵɵnextContext();\n return ctx_r6.resetLoginFailed();\n });\n i0.ɵɵnamespaceSVG();\n i0.ɵɵelementStart(2, \"svg\", 12);\n i0.ɵɵelement(3, \"use\", 13);\n i0.ɵɵelementEnd();\n i0.ɵɵnamespaceHTML();\n i0.ɵɵelementStart(4, \"strong\");\n i0.ɵɵtext(5, \"Login was not successful!\");\n i0.ɵɵelementEnd()()();\n }\n\n if (rf & 2) {\n i0.ɵɵadvance(1);\n i0.ɵɵproperty(\"dismissible\", true);\n }\n}\n\nfunction LoginComponent_div_10_div_1_Template(rf, ctx) {\n if (rf & 1) {\n i0.ɵɵelementStart(0, \"div\", 32);\n i0.ɵɵnamespaceSVG();\n i0.ɵɵelementStart(1, \"svg\", 33);\n i0.ɵɵelement(2, \"use\", 34);\n i0.ɵɵelementEnd();\n i0.ɵɵnamespaceHTML();\n i0.ɵɵelementStart(3, \"div\");\n i0.ɵɵtext(4, \" Please make sure to restart plugin after you're done. \");\n i0.ɵɵelementStart(5, \"u\", 35);\n i0.ɵɵtext(6, \" Tell me why... \");\n i0.ɵɵelementEnd()()();\n }\n\n if (rf & 2) {\n i0.ɵɵnextContext(2);\n\n const _r0 = i0.ɵɵreference(6);\n\n i0.ɵɵadvance(5);\n i0.ɵɵproperty(\"autoClose\", \"outside\")(\"ngbPopover\", _r0);\n }\n}\n\nfunction LoginComponent_div_10_ng_template_13_Template(rf, ctx) {\n if (rf & 1) {\n i0.ɵɵtext(0, \"You can leave this field blank.\");\n i0.ɵɵelement(1, \"p\");\n i0.ɵɵtext(2, \"This will set the an option in the api calls to the eufy cloud, so that the servers think this plugin uses the official eufy app on the given device. If left blank the plugin will use a random device identifier. See \");\n i0.ɵɵelementStart(3, \"a\", 36);\n i0.ɵɵtext(4, \"this disussion\");\n i0.ɵɵelementEnd();\n i0.ɵɵtext(5, \" to learn more.\");\n }\n}\n\nfunction LoginComponent_div_10_option_21_Template(rf, ctx) {\n if (rf & 1) {\n i0.ɵɵelementStart(0, \"option\");\n i0.ɵɵtext(1);\n i0.ɵɵelementEnd();\n }\n\n if (rf & 2) {\n const country_r14 = ctx.$implicit;\n const ctx_r11 = i0.ɵɵnextContext(2);\n i0.ɵɵattribute(\"value\", country_r14.short)(\"selected\", ctx_r11.credentials.country === country_r14.short ? true : null);\n i0.ɵɵadvance(1);\n i0.ɵɵtextInterpolate1(\"\", country_r14.long, \" \");\n }\n}\n\nfunction LoginComponent_div_10_span_28_Template(rf, ctx) {\n if (rf & 1) {\n i0.ɵɵelement(0, \"span\", 37);\n }\n}\n\nfunction LoginComponent_div_10_span_30_Template(rf, ctx) {\n if (rf & 1) {\n i0.ɵɵelementStart(0, \"span\");\n i0.ɵɵtext(1, \"...\");\n i0.ɵɵelementEnd();\n }\n}\n\nfunction LoginComponent_div_10_Template(rf, ctx) {\n if (rf & 1) {\n const _r16 = i0.ɵɵgetCurrentView();\n\n i0.ɵɵelementStart(0, \"div\");\n i0.ɵɵtemplate(1, LoginComponent_div_10_div_1_Template, 7, 2, \"div\", 14);\n i0.ɵɵelementStart(2, \"div\", 15)(3, \"input\", 16);\n i0.ɵɵlistener(\"ngModelChange\", function LoginComponent_div_10_Template_input_ngModelChange_3_listener($event) {\n i0.ɵɵrestoreView(_r16);\n const ctx_r15 = i0.ɵɵnextContext();\n return ctx_r15.credentials.username = $event;\n });\n i0.ɵɵelementEnd();\n i0.ɵɵelementStart(4, \"label\", 17);\n i0.ɵɵtext(5, \"Email address\");\n i0.ɵɵelementEnd()();\n i0.ɵɵelement(6, \"p\");\n i0.ɵɵelementStart(7, \"div\", 15)(8, \"input\", 18);\n i0.ɵɵlistener(\"ngModelChange\", function LoginComponent_div_10_Template_input_ngModelChange_8_listener($event) {\n i0.ɵɵrestoreView(_r16);\n const ctx_r17 = i0.ɵɵnextContext();\n return ctx_r17.credentials.password = $event;\n });\n i0.ɵɵelementEnd();\n i0.ɵɵelementStart(9, \"label\", 19);\n i0.ɵɵtext(10, \"Password\");\n i0.ɵɵelementEnd()();\n i0.ɵɵelement(11, \"p\");\n i0.ɵɵelementStart(12, \"div\", 15);\n i0.ɵɵtemplate(13, LoginComponent_div_10_ng_template_13_Template, 6, 0, \"ng-template\", null, 20, i0.ɵɵtemplateRefExtractor);\n i0.ɵɵelementStart(15, \"input\", 21);\n i0.ɵɵlistener(\"ngModelChange\", function LoginComponent_div_10_Template_input_ngModelChange_15_listener($event) {\n i0.ɵɵrestoreView(_r16);\n const ctx_r18 = i0.ɵɵnextContext();\n return ctx_r18.credentials.deviceName = $event;\n });\n i0.ɵɵelementEnd();\n i0.ɵɵelementStart(16, \"label\", 22);\n i0.ɵɵtext(17, \"Device Name\");\n i0.ɵɵelementEnd()();\n i0.ɵɵelementStart(18, \"div\", 23)(19, \"div\", 24)(20, \"select\", 25);\n i0.ɵɵlistener(\"ngModelChange\", function LoginComponent_div_10_Template_select_ngModelChange_20_listener($event) {\n i0.ɵɵrestoreView(_r16);\n const ctx_r19 = i0.ɵɵnextContext();\n return ctx_r19.credentials.country = $event;\n });\n i0.ɵɵtemplate(21, LoginComponent_div_10_option_21_Template, 2, 3, \"option\", 26);\n i0.ɵɵelementEnd();\n i0.ɵɵelementStart(22, \"small\")(23, \"i\");\n i0.ɵɵtext(24, \" Make sure to use the same country that you use to login with the eufy app. \");\n i0.ɵɵelementEnd()()();\n i0.ɵɵelement(25, \"span\", 27);\n i0.ɵɵelementStart(26, \"div\", 28)(27, \"button\", 29);\n i0.ɵɵlistener(\"click\", function LoginComponent_div_10_Template_button_click_27_listener() {\n i0.ɵɵrestoreView(_r16);\n const ctx_r20 = i0.ɵɵnextContext();\n return ctx_r20.login();\n });\n i0.ɵɵtemplate(28, LoginComponent_div_10_span_28_Template, 1, 0, \"span\", 30);\n i0.ɵɵtext(29, \" Login \");\n i0.ɵɵtemplate(30, LoginComponent_div_10_span_30_Template, 2, 0, \"span\", 9);\n i0.ɵɵelementEnd();\n i0.ɵɵelementStart(31, \"button\", 31);\n i0.ɵɵlistener(\"click\", function LoginComponent_div_10_Template_button_click_31_listener() {\n i0.ɵɵrestoreView(_r16);\n const ctx_r21 = i0.ɵɵnextContext();\n return ctx_r21.cancelLogin();\n });\n i0.ɵɵtext(32, \" Cancel \");\n i0.ɵɵelementEnd()()()();\n }\n\n if (rf & 2) {\n const _r9 = i0.ɵɵreference(14);\n\n const ctx_r3 = i0.ɵɵnextContext();\n i0.ɵɵadvance(1);\n i0.ɵɵproperty(\"ngIf\", !ctx_r3.firstLoginAssumed);\n i0.ɵɵadvance(2);\n i0.ɵɵproperty(\"ngModel\", ctx_r3.credentials.username);\n i0.ɵɵattribute(\"class\", ctx_r3.emailIsValid ? \"form-control\" : \"form-control is-invalid\")(\"disabled\", ctx_r3.loginInProgress ? true : null);\n i0.ɵɵadvance(5);\n i0.ɵɵproperty(\"ngModel\", ctx_r3.credentials.password);\n i0.ɵɵattribute(\"class\", ctx_r3.passwordIsValid ? \"form-control\" : \"form-control is-invalid\")(\"disabled\", ctx_r3.loginInProgress ? true : null);\n i0.ɵɵadvance(7);\n i0.ɵɵproperty(\"ngModel\", ctx_r3.credentials.deviceName)(\"ngbTooltip\", _r9)(\"closeDelay\", 2500);\n i0.ɵɵattribute(\"class\", ctx_r3.passwordIsValid ? \"form-control\" : \"form-control is-invalid\")(\"disabled\", ctx_r3.loginInProgress ? true : null);\n i0.ɵɵadvance(5);\n i0.ɵɵproperty(\"ngModel\", ctx_r3.credentials.country);\n i0.ɵɵattribute(\"disabled\", ctx_r3.loginInProgress ? true : null);\n i0.ɵɵadvance(1);\n i0.ɵɵproperty(\"ngForOf\", ctx_r3.countries);\n i0.ɵɵadvance(6);\n i0.ɵɵattribute(\"disabled\", ctx_r3.loginInProgress ? true : null);\n i0.ɵɵadvance(1);\n i0.ɵɵproperty(\"ngIf\", ctx_r3.loginInProgress);\n i0.ɵɵadvance(2);\n i0.ɵɵproperty(\"ngIf\", ctx_r3.loginInProgress);\n i0.ɵɵadvance(1);\n i0.ɵɵattribute(\"disabled\", ctx_r3.loginInProgress ? true : null);\n }\n}\n\nfunction LoginComponent_div_11_span_11_Template(rf, ctx) {\n if (rf & 1) {\n i0.ɵɵelement(0, \"span\", 37);\n }\n}\n\nfunction LoginComponent_div_11_span_13_Template(rf, ctx) {\n if (rf & 1) {\n i0.ɵɵelementStart(0, \"span\");\n i0.ɵɵtext(1, \"...\");\n i0.ɵɵelementEnd();\n }\n}\n\nfunction LoginComponent_div_11_Template(rf, ctx) {\n if (rf & 1) {\n const _r25 = i0.ɵɵgetCurrentView();\n\n i0.ɵɵelementStart(0, \"div\")(1, \"div\", 38);\n i0.ɵɵtext(2, \"You should have gotten a 2FA verification code from eufy in your mail. Please enter this below.\");\n i0.ɵɵelementEnd();\n i0.ɵɵelementStart(3, \"div\", 6)(4, \"div\", 39)(5, \"input\", 40);\n i0.ɵɵlistener(\"ngModelChange\", function LoginComponent_div_11_Template_input_ngModelChange_5_listener($event) {\n i0.ɵɵrestoreView(_r25);\n const ctx_r24 = i0.ɵɵnextContext();\n return ctx_r24.otp = $event;\n });\n i0.ɵɵelementEnd();\n i0.ɵɵelementStart(6, \"label\", 41);\n i0.ɵɵtext(7, \"2FA Code\");\n i0.ɵɵelementEnd()()();\n i0.ɵɵelementStart(8, \"div\", 42)(9, \"div\", 43)(10, \"button\", 44);\n i0.ɵɵlistener(\"click\", function LoginComponent_div_11_Template_button_click_10_listener() {\n i0.ɵɵrestoreView(_r25);\n const ctx_r26 = i0.ɵɵnextContext();\n return ctx_r26.login();\n });\n i0.ɵɵtemplate(11, LoginComponent_div_11_span_11_Template, 1, 0, \"span\", 30);\n i0.ɵɵtext(12, \" Verify \");\n i0.ɵɵtemplate(13, LoginComponent_div_11_span_13_Template, 2, 0, \"span\", 9);\n i0.ɵɵelementEnd()()();\n i0.ɵɵelementStart(14, \"div\", 6)(15, \"div\", 43)(16, \"button\", 31);\n i0.ɵɵlistener(\"click\", function LoginComponent_div_11_Template_button_click_16_listener() {\n i0.ɵɵrestoreView(_r25);\n const ctx_r27 = i0.ɵɵnextContext();\n return ctx_r27.cancelLogin();\n });\n i0.ɵɵtext(17, \" Cancel \");\n i0.ɵɵelementEnd()()()();\n }\n\n if (rf & 2) {\n const ctx_r4 = i0.ɵɵnextContext();\n i0.ɵɵadvance(5);\n i0.ɵɵproperty(\"ngModel\", ctx_r4.otp);\n i0.ɵɵattribute(\"class\", ctx_r4.otpIsValid ? \"form-control\" : \"form-control is-invalid\")(\"disabled\", ctx_r4.loginInProgress ? true : null);\n i0.ɵɵadvance(5);\n i0.ɵɵattribute(\"disabled\", ctx_r4.loginInProgress ? true : null);\n i0.ɵɵadvance(1);\n i0.ɵɵproperty(\"ngIf\", ctx_r4.loginInProgress);\n i0.ɵɵadvance(2);\n i0.ɵɵproperty(\"ngIf\", ctx_r4.loginInProgress);\n i0.ɵɵadvance(3);\n i0.ɵɵattribute(\"disabled\", ctx_r4.loginInProgress ? true : null);\n }\n}\n\nfunction LoginComponent_div_12_span_13_Template(rf, ctx) {\n if (rf & 1) {\n i0.ɵɵelement(0, \"span\", 37);\n }\n}\n\nfunction LoginComponent_div_12_span_15_Template(rf, ctx) {\n if (rf & 1) {\n i0.ɵɵelementStart(0, \"span\");\n i0.ɵɵtext(1, \"...\");\n i0.ɵɵelementEnd();\n }\n}\n\nfunction LoginComponent_div_12_Template(rf, ctx) {\n if (rf & 1) {\n const _r31 = i0.ɵɵgetCurrentView();\n\n i0.ɵɵelementStart(0, \"div\")(1, \"div\", 38);\n i0.ɵɵtext(2, \"Please enter the captcha below.\");\n i0.ɵɵelementEnd();\n i0.ɵɵelementStart(3, \"div\", 42);\n i0.ɵɵelement(4, \"img\", 45);\n i0.ɵɵelementEnd();\n i0.ɵɵelementStart(5, \"div\", 6)(6, \"div\", 39)(7, \"input\", 40);\n i0.ɵɵlistener(\"ngModelChange\", function LoginComponent_div_12_Template_input_ngModelChange_7_listener($event) {\n i0.ɵɵrestoreView(_r31);\n const ctx_r30 = i0.ɵɵnextContext();\n return ctx_r30.captcha = $event;\n });\n i0.ɵɵelementEnd();\n i0.ɵɵelementStart(8, \"label\", 41);\n i0.ɵɵtext(9, \"Captcha\");\n i0.ɵɵelementEnd()()();\n i0.ɵɵelementStart(10, \"div\", 42)(11, \"div\", 43)(12, \"button\", 44);\n i0.ɵɵlistener(\"click\", function LoginComponent_div_12_Template_button_click_12_listener() {\n i0.ɵɵrestoreView(_r31);\n const ctx_r32 = i0.ɵɵnextContext();\n return ctx_r32.login();\n });\n i0.ɵɵtemplate(13, LoginComponent_div_12_span_13_Template, 1, 0, \"span\", 30);\n i0.ɵɵtext(14, \" Verify \");\n i0.ɵɵtemplate(15, LoginComponent_div_12_span_15_Template, 2, 0, \"span\", 9);\n i0.ɵɵelementEnd()()();\n i0.ɵɵelementStart(16, \"div\", 6)(17, \"div\", 43)(18, \"button\", 31);\n i0.ɵɵlistener(\"click\", function LoginComponent_div_12_Template_button_click_18_listener() {\n i0.ɵɵrestoreView(_r31);\n const ctx_r33 = i0.ɵɵnextContext();\n return ctx_r33.cancelLogin();\n });\n i0.ɵɵtext(19, \" Cancel \");\n i0.ɵɵelementEnd()()()();\n }\n\n if (rf & 2) {\n const ctx_r5 = i0.ɵɵnextContext();\n i0.ɵɵadvance(4);\n i0.ɵɵproperty(\"src\", ctx_r5.captchaImageData, i0.ɵɵsanitizeUrl);\n i0.ɵɵadvance(3);\n i0.ɵɵproperty(\"ngModel\", ctx_r5.captcha);\n i0.ɵɵattribute(\"class\", ctx_r5.captchaIsValid ? \"form-control\" : \"form-control is-invalid\")(\"disabled\", ctx_r5.loginInProgress ? true : null);\n i0.ɵɵadvance(5);\n i0.ɵɵattribute(\"disabled\", ctx_r5.loginInProgress ? true : null);\n i0.ɵɵadvance(1);\n i0.ɵɵproperty(\"ngIf\", ctx_r5.loginInProgress);\n i0.ɵɵadvance(2);\n i0.ɵɵproperty(\"ngIf\", ctx_r5.loginInProgress);\n i0.ɵɵadvance(3);\n i0.ɵɵattribute(\"disabled\", ctx_r5.loginInProgress ? true : null);\n }\n}\n\nvar LoginStep = /*#__PURE__*/(() => {\n (function (LoginStep) {\n LoginStep[LoginStep[\"LOGIN\"] = 1] = \"LOGIN\";\n LoginStep[LoginStep[\"TFA\"] = 2] = \"TFA\";\n LoginStep[LoginStep[\"CAPTCHA\"] = 3] = \"CAPTCHA\";\n })(LoginStep || (LoginStep = {}));\n\n return LoginStep;\n})();\nexport let LoginComponent = /*#__PURE__*/(() => {\n class LoginComponent {\n constructor(loginService, routerService) {\n this.loginService = loginService;\n this.routerService = routerService;\n this.countries = [];\n this.credentials = {\n username: '',\n password: '',\n country: 'US',\n deviceName: ''\n };\n this.otp = '';\n this.captcha = '';\n this.captchaImageData = '';\n this.captchaId = '';\n this.loginInProgress = false;\n this.loginFailed = false;\n this.loginStep = LoginStep.LOGIN;\n this.firstLoginAssumed = false;\n this.emailIsValid = true;\n this.passwordIsValid = true;\n this.otpIsValid = true;\n this.captchaIsValid = true;\n }\n\n ngOnInit() {\n this.getCredentials();\n this.fillCountryArray();\n }\n\n getCredentials() {\n this.loginService.getCredentials().then(creds => this.credentials = creds).catch(err => {\n this.firstLoginAssumed = true;\n console.log('Could not get config in login component: ' + err);\n });\n }\n\n fillCountryArray() {\n Object.entries(COUNTRIES).forEach(([key, value]) => {\n this.countries.push({\n short: key,\n long: value\n });\n });\n }\n\n login() {\n if (this.inputIsInvalid()) {\n return;\n }\n\n this.resetLoginFailed();\n this.loginInProgress = true;\n\n if (this.loginStep === LoginStep.LOGIN) {\n this.loginWithCredentials();\n }\n\n if (this.loginStep === LoginStep.TFA) {\n this.loginWithTFA();\n }\n\n if (this.loginStep === LoginStep.CAPTCHA) {\n this.loginWithCaptcha();\n }\n }\n\n loginWithCredentials() {\n var _this = this;\n\n return _asyncToGenerator(function* () {\n let loginResult = undefined;\n\n try {\n loginResult = yield _this.loginService.login(_this.credentials);\n } catch (err) {\n console.log('login error: ' + err);\n }\n\n _this.evaluateLoginResult(loginResult);\n })();\n }\n\n loginWithTFA() {\n var _this2 = this;\n\n return _asyncToGenerator(function* () {\n let loginResult = undefined;\n\n try {\n loginResult = yield _this2.loginService.login({\n verifyCode: _this2.otp\n });\n } catch (err) {\n console.log('login error: ' + err);\n }\n\n _this2.evaluateLoginResult(loginResult);\n })();\n }\n\n loginWithCaptcha() {\n var _this3 = this;\n\n return _asyncToGenerator(function* () {\n let loginResult = undefined;\n\n try {\n loginResult = yield _this3.loginService.login({\n captcha: {\n captchaCode: _this3.captcha,\n captchaId: _this3.captchaId\n }\n });\n } catch (err) {\n console.log('login error: ' + err);\n }\n\n _this3.evaluateLoginResult(loginResult);\n })();\n }\n\n evaluateLoginResult(loginResult) {\n this.loginInProgress = false;\n\n if (loginResult && loginResult.success) {\n this.loginService.updateConfigCredentials(this.credentials);\n this.routerService.navigate(['/accessories', {\n waitForAccessories: true\n }]);\n } else {\n if (loginResult && loginResult.failReason && loginResult.failReason === LoginFailReason.TFA) {\n this.loginStep = LoginStep.TFA;\n return;\n }\n\n if (loginResult && loginResult.failReason && loginResult.failReason === LoginFailReason.CAPTCHA && loginResult.data && loginResult.data.id && loginResult.data.captcha) {\n this.loginStep = LoginStep.CAPTCHA;\n this.captchaId = loginResult.data.id;\n this.captchaImageData = loginResult.data.captcha;\n return;\n }\n\n this.loginStep = LoginStep.LOGIN;\n this.loginFailed = true;\n }\n }\n\n inputIsInvalid() {\n this.emailIsValid = true;\n this.passwordIsValid = true;\n this.otpIsValid = true;\n let inputError = false;\n\n if (this.loginStep === LoginStep.LOGIN && this.credentials.username.length < 4) {\n this.emailIsValid = false;\n inputError = true;\n }\n\n if (this.loginStep === LoginStep.LOGIN && this.credentials.password.length < 4) {\n this.passwordIsValid = false;\n inputError = true;\n }\n\n if (this.loginStep === LoginStep.TFA && this.otp.length < 6) {\n this.otpIsValid = false;\n inputError = true;\n }\n\n if (this.loginStep === LoginStep.CAPTCHA && this.captcha.length < 4) {\n this.captchaIsValid = false;\n inputError = true;\n }\n\n return inputError;\n }\n\n resetLoginFailed() {\n this.loginFailed = false;\n }\n\n cancelLogin() {\n this.routerService.navigate(['/accessories']);\n }\n\n }\n\n LoginComponent.ɵfac = function LoginComponent_Factory(t) {\n return new (t || LoginComponent)(i0.ɵɵdirectiveInject(i1.LoginService), i0.ɵɵdirectiveInject(i2.Router));\n };\n\n LoginComponent.ɵcmp = /*@__PURE__*/i0.ɵɵdefineComponent({\n type: LoginComponent,\n selectors: [[\"app-login\"]],\n decls: 13,\n vars: 4,\n consts: [[\"xmlns\", \"http://www.w3.org/2000/svg\", 2, \"display\", \"none\"], [\"id\", \"info-fill\", \"fill\", \"currentColor\", \"viewBox\", \"0 0 16 16\"], [\"d\", \"M8 16A8 8 0 1 0 8 0a8 8 0 0 0 0 16zm.93-9.412-1 4.705c-.07.34.029.533.304.533.194 0 .487-.07.686-.246l-.088.416c-.287.346-.92.598-1.465.598-.703 0-1.002-.422-.808-1.319l.738-3.468c.064-.293.006-.399-.287-.47l-.451-.081.082-.381 2.29-.287zM8 5.5a1 1 0 1 1 0-2 1 1 0 0 1 0 2z\"], [\"id\", \"exclamation-triangle-fill\", \"fill\", \"currentColor\", \"viewBox\", \"0 0 16 16\"], [\"d\", \"M8.982 1.566a1.13 1.13 0 0 0-1.96 0L.165 13.233c-.457.778.091 1.767.98 1.767h13.713c.889 0 1.438-.99.98-1.767L8.982 1.566zM8 5c.535 0 .954.462.9.995l-.35 3.507a.552.552 0 0 1-1.1 0L7.1 5.995A.905.905 0 0 1 8 5zm.002 6a1 1 0 1 1 0 2 1 1 0 0 1 0-2z\"], [\"popInfo\", \"\"], [1, \"row\", \"d-flex\", \"justify-content-center\"], [\"class\", \"col-11 col-sm-7\", 4, \"ngIf\"], [1, \"col-11\", \"col-sm-7\", \"card\", \"p-4\"], [4, \"ngIf\"], [1, \"col-11\", \"col-sm-7\"], [\"type\", \"danger\", 3, \"dismissible\", \"closed\"], [\"width\", \"24\", \"height\", \"24\", \"role\", \"img\", \"aria-label\", \"Login Error\", 1, \"bi\", \"flex-shrink-0\", \"me-2\"], [0, \"xlink\", \"href\", \"#exclamation-triangle-fill\"], [\"class\", \"alert alert-warning d-flex align-items-center\", \"role\", \"alert\", 4, \"ngIf\"], [1, \"form-floating\", \"mb-3\"], [\"type\", \"email\", \"id\", \"floatingInput\", \"placeholder\", \"name@example.com\", \"ngModel\", \"\", \"email\", \"\", 3, \"ngModel\", \"ngModelChange\"], [\"for\", \"floatingInput\"], [\"type\", \"password\", \"id\", \"floatingPassword\", \"placeholder\", \"Password\", 3, \"ngModel\", \"ngModelChange\"], [\"for\", \"floatingPassword\"], [\"deviceNameExplanation\", \"\"], [\"type\", \"text\", \"id\", \"floatingDevice\", \"placeholder\", \"Device Name\", \"placement\", \"top\", 3, \"ngModel\", \"ngbTooltip\", \"closeDelay\", \"ngModelChange\"], [\"for\", \"floatingDevice\"], [1, \"row\"], [1, \"col-12\", \"col-sm-6\", \"mb-3\", \"mb-sm0\"], [\"aria-label\", \"select country\", 1, \"form-select\", \"mb-3\", 3, \"ngModel\", \"ngModelChange\"], [4, \"ngFor\", \"ngForOf\"], [1, \"col-0\", \"col-sm-1\"], [1, \"col-12\", \"col-sm-5\", \"text-end\", \"mb-3\"], [\"type\", \"button\", 1, \"btn\", \"btn-success\", \"col-12\", \"mb-3\", 3, \"click\"], [\"class\", \"spinner-border spinner-border-sm\", \"role\", \"status\", \"aria-hidden\", \"true\", 4, \"ngIf\"], [\"type\", \"button\", 1, \"btn\", \"btn-secondary\", \"col-12\", 3, \"click\"], [\"role\", \"alert\", 1, \"alert\", \"alert-warning\", \"d-flex\", \"align-items-center\"], [\"width\", \"24\", \"height\", \"24\", \"role\", \"img\", \"aria-label\", \"Warning:\", 1, \"bi\", \"flex-shrink-0\", \"me-2\"], [0, \"xlink\", \"href\", \"#info-fill\"], [\"role\", \"button\", \"popoverTitle\", \"Please restart after login\", 3, \"autoClose\", \"ngbPopover\"], [\"href\", \"https://github.com/homebridge-eufy-security/plugin/issues/201\", \"target\", \"_blank\", \"rel\", \"noopener noreferrer\", 2, \"color\", \"white\"], [\"role\", \"status\", \"aria-hidden\", \"true\", 1, \"spinner-border\", \"spinner-border-sm\"], [1, \"row\", \"mb-3\"], [1, \"form-floating\", \"mb-3\", \"col-8\", \"col-sm-6\"], [\"type\", \"text\", \"id\", \"floatingOTP\", \"placeholder\", \"\", 3, \"ngModel\", \"ngModelChange\"], [\"for\", \"floatingOTP\"], [1, \"row\", \"d-flex\", \"justify-content-center\", \"mb-3\"], [1, \"col-8\", \"col-sm-6\"], [\"type\", \"button\", 1, \"btn\", \"btn-success\", \"col-12\", 3, \"click\"], [1, \"col-10\", \"col-sm-8\", 3, \"src\"]],\n template: function LoginComponent_Template(rf, ctx) {\n if (rf & 1) {\n i0.ɵɵnamespaceSVG();\n i0.ɵɵelementStart(0, \"svg\", 0)(1, \"symbol\", 1);\n i0.ɵɵelement(2, \"path\", 2);\n i0.ɵɵelementEnd();\n i0.ɵɵelementStart(3, \"symbol\", 3);\n i0.ɵɵelement(4, \"path\", 4);\n i0.ɵɵelementEnd()();\n i0.ɵɵtemplate(5, LoginComponent_ng_template_5_Template, 4, 0, \"ng-template\", null, 5, i0.ɵɵtemplateRefExtractor);\n i0.ɵɵnamespaceHTML();\n i0.ɵɵelementStart(7, \"div\", 6);\n i0.ɵɵtemplate(8, LoginComponent_p_8_Template, 6, 1, \"p\", 7);\n i0.ɵɵelementStart(9, \"div\", 8);\n i0.ɵɵtemplate(10, LoginComponent_div_10_Template, 33, 19, \"div\", 9);\n i0.ɵɵtemplate(11, LoginComponent_div_11_Template, 18, 7, \"div\", 9);\n i0.ɵɵtemplate(12, LoginComponent_div_12_Template, 20, 8, \"div\", 9);\n i0.ɵɵelementEnd()();\n }\n\n if (rf & 2) {\n i0.ɵɵadvance(8);\n i0.ɵɵproperty(\"ngIf\", ctx.loginFailed);\n i0.ɵɵadvance(2);\n i0.ɵɵproperty(\"ngIf\", ctx.loginStep === 1);\n i0.ɵɵadvance(1);\n i0.ɵɵproperty(\"ngIf\", ctx.loginStep === 2);\n i0.ɵɵadvance(1);\n i0.ɵɵproperty(\"ngIf\", ctx.loginStep === 3);\n }\n },\n directives: [i3.NgIf, i4.NgbAlert, i4.NgbPopover, i5.DefaultValueAccessor, i5.NgControlStatus, i5.NgModel, i5.EmailValidator, i4.NgbTooltip, i5.SelectControlValueAccessor, i3.NgForOf, i5.NgSelectOption, i5.ɵNgSelectMultipleOption],\n encapsulation: 2\n });\n return LoginComponent;\n})();","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import { ConfigOptionsInterpreter } from '../config-options-interpreter';\nimport * as i0 from \"@angular/core\";\nimport * as i1 from \"../../../app/plugin.service\";\nimport * as i2 from \"@angular/forms\";\nexport let EnableDetailedLoggingComponent = /*#__PURE__*/(() => {\n class EnableDetailedLoggingComponent extends ConfigOptionsInterpreter {\n constructor(pluginService) {\n super(pluginService);\n /** Customize from here */\n\n /** updateConfig() will overwrite any settings that you'll provide */\n\n /** Don't try and 'append'/'push' to arrays this way - add a custom method instead */\n\n /** see config option to ignore devices as example */\n\n /** updateConfig() takes an optional second parameter to specify the accessoriy for which the setting is changed */\n\n this.model = false;\n }\n\n ngOnInit() {\n this.readValue();\n }\n\n readValue() {\n if (Object.prototype.hasOwnProperty.call(this.config, 'enableDetailedLogging')) {\n this.model = this.config['enableDetailedLogging'];\n }\n }\n\n update() {\n this.updateConfig({\n enableDetailedLogging: this.model\n });\n }\n\n }\n\n EnableDetailedLoggingComponent.ɵfac = function EnableDetailedLoggingComponent_Factory(t) {\n return new (t || EnableDetailedLoggingComponent)(i0.ɵɵdirectiveInject(i1.PluginService));\n };\n\n EnableDetailedLoggingComponent.ɵcmp = /*@__PURE__*/i0.ɵɵdefineComponent({\n type: EnableDetailedLoggingComponent,\n selectors: [[\"app-enable-detailed-logging\"]],\n features: [i0.ɵɵInheritDefinitionFeature],\n decls: 9,\n vars: 1,\n consts: [[1, \"settingsItem\", \"row\", \"p-3\"], [1, \"d-flex\", \"justify-content-between\", \"align-items-center\", \"mb-2\"], [1, \"form-check\", \"form-switch\"], [\"type\", \"checkbox\", \"role\", \"switch\", \"id\", \"flexSwitchCheckDefault\", 1, \"form-check-input\", 3, \"ngModel\", \"ngModelChange\", \"change\"]],\n template: function EnableDetailedLoggingComponent_Template(rf, ctx) {\n if (rf & 1) {\n i0.ɵɵelementStart(0, \"div\", 0)(1, \"div\", 1)(2, \"span\");\n i0.ɵɵtext(3, \"Debug Mode\");\n i0.ɵɵelementEnd();\n i0.ɵɵelementStart(4, \"div\", 2)(5, \"input\", 3);\n i0.ɵɵlistener(\"ngModelChange\", function EnableDetailedLoggingComponent_Template_input_ngModelChange_5_listener($event) {\n return ctx.model = $event;\n })(\"change\", function EnableDetailedLoggingComponent_Template_input_change_5_listener() {\n return ctx.update();\n });\n i0.ɵɵelementEnd()()();\n i0.ɵɵelementStart(6, \"small\")(7, \"i\");\n i0.ɵɵtext(8, \" This will output more information to the homebridge logs. This helps the plugin team to understand what's going on. \");\n i0.ɵɵelementEnd()()();\n }\n\n if (rf & 2) {\n i0.ɵɵadvance(5);\n i0.ɵɵproperty(\"ngModel\", ctx.model);\n }\n },\n directives: [i2.CheckboxControlValueAccessor, i2.NgControlStatus, i2.NgModel],\n encapsulation: 2\n });\n return EnableDetailedLoggingComponent;\n})();","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import { Scheduler } from '../Scheduler';\nexport class AsyncScheduler extends Scheduler {\n constructor(SchedulerAction, now = Scheduler.now) {\n super(SchedulerAction, now);\n this.actions = [];\n this._active = false;\n this._scheduled = undefined;\n }\n\n flush(action) {\n const {\n actions\n } = this;\n\n if (this._active) {\n actions.push(action);\n return;\n }\n\n let error;\n this._active = true;\n\n do {\n if (error = action.execute(action.state, action.delay)) {\n break;\n }\n } while (action = actions.shift());\n\n this._active = false;\n\n if (error) {\n while (action = actions.shift()) {\n action.unsubscribe();\n }\n\n throw error;\n }\n }\n\n} //# sourceMappingURL=AsyncScheduler.js.map","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"export const intervalProvider = {\n setInterval(handler, timeout, ...args) {\n const {\n delegate\n } = intervalProvider;\n\n if (delegate === null || delegate === void 0 ? void 0 : delegate.setInterval) {\n return delegate.setInterval(handler, timeout, ...args);\n }\n\n return setInterval(handler, timeout, ...args);\n },\n\n clearInterval(handle) {\n const {\n delegate\n } = intervalProvider;\n return ((delegate === null || delegate === void 0 ? void 0 : delegate.clearInterval) || clearInterval)(handle);\n },\n\n delegate: undefined\n}; //# sourceMappingURL=intervalProvider.js.map","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import { isShadowRoot } from \"./instanceOf.js\";\nexport default function contains(parent, child) {\n var rootNode = child.getRootNode && child.getRootNode(); // First, attempt with faster native method\n\n if (parent.contains(child)) {\n return true;\n } // then fallback to custom implementation with Shadow DOM support\n else if (rootNode && isShadowRoot(rootNode)) {\n var next = child;\n\n do {\n if (next && parent.isSameNode(next)) {\n return true;\n } // $FlowFixMe[prop-missing]: need a better way to handle this...\n\n\n next = next.parentNode || next.host;\n } while (next);\n } // Give up, the result is false\n\n\n return false;\n}","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import getDocumentElement from \"./getDocumentElement.js\";\nimport getComputedStyle from \"./getComputedStyle.js\";\nimport getWindowScrollBarX from \"./getWindowScrollBarX.js\";\nimport getWindowScroll from \"./getWindowScroll.js\";\nimport { max } from \"../utils/math.js\"; // Gets the entire size of the scrollable document area, even extending outside\n// of the `<html>` and `<body>` rect bounds if horizontally scrollable\n\nexport default function getDocumentRect(element) {\n var _element$ownerDocumen;\n\n var html = getDocumentElement(element);\n var winScroll = getWindowScroll(element);\n var body = (_element$ownerDocumen = element.ownerDocument) == null ? void 0 : _element$ownerDocumen.body;\n var width = max(html.scrollWidth, html.clientWidth, body ? body.scrollWidth : 0, body ? body.clientWidth : 0);\n var height = max(html.scrollHeight, html.clientHeight, body ? body.scrollHeight : 0, body ? body.clientHeight : 0);\n var x = -winScroll.scrollLeft + getWindowScrollBarX(element);\n var y = -winScroll.scrollTop;\n\n if (getComputedStyle(body || html).direction === 'rtl') {\n x += max(html.clientWidth, body ? body.clientWidth : 0) - width;\n }\n\n return {\n width: width,\n height: height,\n x: x,\n y: y\n };\n}","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import { asyncScheduler } from '../scheduler/async';\nimport { operate } from '../util/lift';\nimport { createOperatorSubscriber } from './OperatorSubscriber';\nexport function debounceTime(dueTime, scheduler = asyncScheduler) {\n return operate((source, subscriber) => {\n let activeTask = null;\n let lastValue = null;\n let lastTime = null;\n\n const emit = () => {\n if (activeTask) {\n activeTask.unsubscribe();\n activeTask = null;\n const value = lastValue;\n lastValue = null;\n subscriber.next(value);\n }\n };\n\n function emitWhenIdle() {\n const targetTime = lastTime + dueTime;\n const now = scheduler.now();\n\n if (now < targetTime) {\n activeTask = this.schedule(undefined, targetTime - now);\n subscriber.add(activeTask);\n return;\n }\n\n emit();\n }\n\n source.subscribe(createOperatorSubscriber(subscriber, value => {\n lastValue = value;\n lastTime = scheduler.now();\n\n if (!activeTask) {\n activeTask = scheduler.schedule(emitWhenIdle, dueTime);\n subscriber.add(activeTask);\n }\n }, () => {\n emit();\n subscriber.complete();\n }, undefined, () => {\n lastValue = activeTask = null;\n }));\n });\n} //# sourceMappingURL=debounceTime.js.map","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import getWindow from \"../dom-utils/getWindow.js\"; // eslint-disable-next-line import/no-unused-modules\n\nvar passive = {\n passive: true\n};\n\nfunction effect(_ref) {\n var state = _ref.state,\n instance = _ref.instance,\n options = _ref.options;\n var _options$scroll = options.scroll,\n scroll = _options$scroll === void 0 ? true : _options$scroll,\n _options$resize = options.resize,\n resize = _options$resize === void 0 ? true : _options$resize;\n var window = getWindow(state.elements.popper);\n var scrollParents = [].concat(state.scrollParents.reference, state.scrollParents.popper);\n\n if (scroll) {\n scrollParents.forEach(function (scrollParent) {\n scrollParent.addEventListener('scroll', instance.update, passive);\n });\n }\n\n if (resize) {\n window.addEventListener('resize', instance.update, passive);\n }\n\n return function () {\n if (scroll) {\n scrollParents.forEach(function (scrollParent) {\n scrollParent.removeEventListener('scroll', instance.update, passive);\n });\n }\n\n if (resize) {\n window.removeEventListener('resize', instance.update, passive);\n }\n };\n} // eslint-disable-next-line import/no-unused-modules\n\n\nexport default {\n name: 'eventListeners',\n enabled: true,\n phase: 'write',\n fn: function fn() {},\n effect: effect,\n data: {}\n};","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import { ReplaySubject } from '../ReplaySubject';\nimport { share } from './share';\nexport function shareReplay(configOrBufferSize, windowTime, scheduler) {\n let bufferSize;\n let refCount = false;\n\n if (configOrBufferSize && typeof configOrBufferSize === 'object') {\n ({\n bufferSize = Infinity,\n windowTime = Infinity,\n refCount = false,\n scheduler\n } = configOrBufferSize);\n } else {\n bufferSize = configOrBufferSize !== null && configOrBufferSize !== void 0 ? configOrBufferSize : Infinity;\n }\n\n return share({\n connector: () => new ReplaySubject(bufferSize, windowTime, scheduler),\n resetOnError: true,\n resetOnComplete: false,\n resetOnRefCountZero: refCount\n });\n} //# sourceMappingURL=shareReplay.js.map","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import { isHTMLElement } from \"./instanceOf.js\";\nimport { round } from \"../utils/math.js\";\nexport default function getBoundingClientRect(element, includeScale) {\n if (includeScale === void 0) {\n includeScale = false;\n }\n\n var rect = element.getBoundingClientRect();\n var scaleX = 1;\n var scaleY = 1;\n\n if (isHTMLElement(element) && includeScale) {\n var offsetHeight = element.offsetHeight;\n var offsetWidth = element.offsetWidth; // Do not attempt to divide by 0, otherwise we get `Infinity` as scale\n // Fallback to 1 in case both values are `0`\n\n if (offsetWidth > 0) {\n scaleX = round(rect.width) / offsetWidth || 1;\n }\n\n if (offsetHeight > 0) {\n scaleY = round(rect.height) / offsetHeight || 1;\n }\n }\n\n return {\n width: rect.width / scaleX,\n height: rect.height / scaleY,\n top: rect.top / scaleY,\n right: rect.right / scaleX,\n bottom: rect.bottom / scaleY,\n left: rect.left / scaleX,\n x: rect.left / scaleX,\n y: rect.top / scaleY\n };\n}","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import format from \"./format.js\";\nimport { modifierPhases } from \"../enums.js\";\nvar INVALID_MODIFIER_ERROR = 'Popper: modifier \"%s\" provided an invalid %s property, expected %s but got %s';\nvar MISSING_DEPENDENCY_ERROR = 'Popper: modifier \"%s\" requires \"%s\", but \"%s\" modifier is not available';\nvar VALID_PROPERTIES = ['name', 'enabled', 'phase', 'fn', 'effect', 'requires', 'options'];\nexport default function validateModifiers(modifiers) {\n modifiers.forEach(function (modifier) {\n [].concat(Object.keys(modifier), VALID_PROPERTIES) // IE11-compatible replacement for `new Set(iterable)`\n .filter(function (value, index, self) {\n return self.indexOf(value) === index;\n }).forEach(function (key) {\n switch (key) {\n case 'name':\n if (typeof modifier.name !== 'string') {\n console.error(format(INVALID_MODIFIER_ERROR, String(modifier.name), '\"name\"', '\"string\"', \"\\\"\" + String(modifier.name) + \"\\\"\"));\n }\n\n break;\n\n case 'enabled':\n if (typeof modifier.enabled !== 'boolean') {\n console.error(format(INVALID_MODIFIER_ERROR, modifier.name, '\"enabled\"', '\"boolean\"', \"\\\"\" + String(modifier.enabled) + \"\\\"\"));\n }\n\n break;\n\n case 'phase':\n if (modifierPhases.indexOf(modifier.phase) < 0) {\n console.error(format(INVALID_MODIFIER_ERROR, modifier.name, '\"phase\"', \"either \" + modifierPhases.join(', '), \"\\\"\" + String(modifier.phase) + \"\\\"\"));\n }\n\n break;\n\n case 'fn':\n if (typeof modifier.fn !== 'function') {\n console.error(format(INVALID_MODIFIER_ERROR, modifier.name, '\"fn\"', '\"function\"', \"\\\"\" + String(modifier.fn) + \"\\\"\"));\n }\n\n break;\n\n case 'effect':\n if (modifier.effect != null && typeof modifier.effect !== 'function') {\n console.error(format(INVALID_MODIFIER_ERROR, modifier.name, '\"effect\"', '\"function\"', \"\\\"\" + String(modifier.fn) + \"\\\"\"));\n }\n\n break;\n\n case 'requires':\n if (modifier.requires != null && !Array.isArray(modifier.requires)) {\n console.error(format(INVALID_MODIFIER_ERROR, modifier.name, '\"requires\"', '\"array\"', \"\\\"\" + String(modifier.requires) + \"\\\"\"));\n }\n\n break;\n\n case 'requiresIfExists':\n if (!Array.isArray(modifier.requiresIfExists)) {\n console.error(format(INVALID_MODIFIER_ERROR, modifier.name, '\"requiresIfExists\"', '\"array\"', \"\\\"\" + String(modifier.requiresIfExists) + \"\\\"\"));\n }\n\n break;\n\n case 'options':\n case 'data':\n break;\n\n default:\n console.error(\"PopperJS: an invalid property has been provided to the \\\"\" + modifier.name + \"\\\" modifier, valid properties are \" + VALID_PROPERTIES.map(function (s) {\n return \"\\\"\" + s + \"\\\"\";\n }).join(', ') + \"; but \\\"\" + key + \"\\\" was provided.\");\n }\n\n modifier.requires && modifier.requires.forEach(function (requirement) {\n if (modifiers.find(function (mod) {\n return mod.name === requirement;\n }) == null) {\n console.error(format(MISSING_DEPENDENCY_ERROR, String(modifier.name), requirement, requirement));\n }\n });\n });\n });\n}","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import { reduce } from './reduce';\nexport function count(predicate) {\n return reduce((total, value, i) => !predicate || predicate(value, i) ? total + 1 : total, 0);\n} //# sourceMappingURL=count.js.map","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import { isFunction } from './isFunction';\nexport function hasLift(source) {\n return isFunction(source === null || source === void 0 ? void 0 : source.lift);\n}\nexport function operate(init) {\n return source => {\n if (hasLift(source)) {\n return source.lift(function (liftedSource) {\n try {\n return init(liftedSource, this);\n } catch (err) {\n this.error(err);\n }\n });\n }\n\n throw new TypeError('Unable to lift unknown Observable type');\n };\n} //# sourceMappingURL=lift.js.map","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import getNodeName from \"./getNodeName.js\";\nimport getDocumentElement from \"./getDocumentElement.js\";\nimport { isShadowRoot } from \"./instanceOf.js\";\nexport default function getParentNode(element) {\n if (getNodeName(element) === 'html') {\n return element;\n }\n\n return (// this is a quicker (but less type safe) way to save quite some bytes from the bundle\n // $FlowFixMe[incompatible-return]\n // $FlowFixMe[prop-missing]\n element.assignedSlot || // step into the shadow DOM of the parent of a slotted node\n element.parentNode || ( // DOM Element detected\n isShadowRoot(element) ? element.host : null) || // ShadowRoot detected\n // $FlowFixMe[incompatible-call]: HTMLElement is a Node\n getDocumentElement(element) // fallback\n\n );\n}","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import getFreshSideObject from \"./getFreshSideObject.js\";\nexport default function mergePaddingObject(paddingObject) {\n return Object.assign({}, getFreshSideObject(), paddingObject);\n}","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import { Action } from './Action';\nimport { intervalProvider } from './intervalProvider';\nimport { arrRemove } from '../util/arrRemove';\nexport class AsyncAction extends Action {\n constructor(scheduler, work) {\n super(scheduler, work);\n this.scheduler = scheduler;\n this.work = work;\n this.pending = false;\n }\n\n schedule(state, delay = 0) {\n if (this.closed) {\n return this;\n }\n\n this.state = state;\n const id = this.id;\n const scheduler = this.scheduler;\n\n if (id != null) {\n this.id = this.recycleAsyncId(scheduler, id, delay);\n }\n\n this.pending = true;\n this.delay = delay;\n this.id = this.id || this.requestAsyncId(scheduler, this.id, delay);\n return this;\n }\n\n requestAsyncId(scheduler, _id, delay = 0) {\n return intervalProvider.setInterval(scheduler.flush.bind(scheduler, this), delay);\n }\n\n recycleAsyncId(_scheduler, id, delay = 0) {\n if (delay != null && this.delay === delay && this.pending === false) {\n return id;\n }\n\n intervalProvider.clearInterval(id);\n return undefined;\n }\n\n execute(state, delay) {\n if (this.closed) {\n return new Error('executing a cancelled action');\n }\n\n this.pending = false;\n\n const error = this._execute(state, delay);\n\n if (error) {\n return error;\n } else if (this.pending === false && this.id != null) {\n this.id = this.recycleAsyncId(this.scheduler, this.id, null);\n }\n }\n\n _execute(state, _delay) {\n let errored = false;\n let errorValue;\n\n try {\n this.work(state);\n } catch (e) {\n errored = true;\n errorValue = e ? e : new Error('Scheduled action threw falsy error');\n }\n\n if (errored) {\n this.unsubscribe();\n return errorValue;\n }\n }\n\n unsubscribe() {\n if (!this.closed) {\n const {\n id,\n scheduler\n } = this;\n const {\n actions\n } = scheduler;\n this.work = this.state = this.scheduler = null;\n this.pending = false;\n arrRemove(actions, this);\n\n if (id != null) {\n this.id = this.recycleAsyncId(scheduler, id, null);\n }\n\n this.delay = null;\n super.unsubscribe();\n }\n }\n\n} //# sourceMappingURL=AsyncAction.js.map","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import { switchMap } from './switchMap';\nimport { identity } from '../util/identity';\nexport function switchAll() {\n return switchMap(identity);\n} //# sourceMappingURL=switchAll.js.map","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import { not } from '../util/not';\nimport { filter } from './filter';\nexport function partition(predicate, thisArg) {\n return source => [filter(predicate, thisArg)(source), filter(not(predicate, thisArg))(source)];\n} //# sourceMappingURL=partition.js.map","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import _asyncToGenerator from \"/Users/rene/dev/eufy-plugin/publish/plugin/node_modules/@babel/runtime/helpers/esm/asyncToGenerator.js\";\nimport { DEFAULT_CAMERACONFIG_VALUES } from '../../util/default-config-values';\nimport { ConfigOptionsInterpreter } from '../config-options-interpreter';\nimport * as i0 from \"@angular/core\";\nimport * as i1 from \"../../../app/plugin.service\";\nimport * as i2 from \"@angular/forms\";\nexport let UnbridgeAccessoryComponent = /*#__PURE__*/(() => {\n class UnbridgeAccessoryComponent extends ConfigOptionsInterpreter {\n constructor(pluginService) {\n super(pluginService);\n this.value = DEFAULT_CAMERACONFIG_VALUES.unbridge;\n }\n\n ngOnInit() {\n this.readValue();\n }\n\n readValue() {\n var _this = this;\n\n return _asyncToGenerator(function* () {\n var _a;\n\n const config = yield _this.getCameraConfig(((_a = _this.accessory) === null || _a === void 0 ? void 0 : _a.uniqueId) || '');\n\n if (config && Object.prototype.hasOwnProperty.call(config, 'unbridge')) {\n _this.value = config['unbridge'];\n }\n })();\n }\n\n update() {\n this.updateConfig({\n unbridge: this.value\n }, this.accessory);\n }\n\n }\n\n UnbridgeAccessoryComponent.ɵfac = function UnbridgeAccessoryComponent_Factory(t) {\n return new (t || UnbridgeAccessoryComponent)(i0.ɵɵdirectiveInject(i1.PluginService));\n };\n\n UnbridgeAccessoryComponent.ɵcmp = /*@__PURE__*/i0.ɵɵdefineComponent({\n type: UnbridgeAccessoryComponent,\n selectors: [[\"app-unbridge-accessory\"]],\n inputs: {\n accessory: \"accessory\"\n },\n features: [i0.ɵɵInheritDefinitionFeature],\n decls: 12,\n vars: 1,\n consts: [[1, \"settingsItem\", \"row\", \"p-3\"], [1, \"d-flex\", \"justify-content-between\", \"align-items-center\", \"mb-2\"], [1, \"form-check\", \"form-switch\"], [\"type\", \"checkbox\", \"role\", \"switch\", \"id\", \"flexSwitchCheckDefault\", 1, \"form-check-input\", 3, \"ngModel\", \"ngModelChange\", \"change\"], [\"href\", \"https://github.com/homebridge-eufy-security/plugin/wiki/Bridged-and-Unbridged-Mode-and-Problems\", \"target\", \"_blank\", \"rel\", \"noopener noreferrer\"]],\n template: function UnbridgeAccessoryComponent_Template(rf, ctx) {\n if (rf & 1) {\n i0.ɵɵelementStart(0, \"div\", 0)(1, \"div\", 1)(2, \"span\");\n i0.ɵɵtext(3, \"Unbridge Camera\");\n i0.ɵɵelementEnd();\n i0.ɵɵelementStart(4, \"div\", 2)(5, \"input\", 3);\n i0.ɵɵlistener(\"ngModelChange\", function UnbridgeAccessoryComponent_Template_input_ngModelChange_5_listener($event) {\n return ctx.value = $event;\n })(\"change\", function UnbridgeAccessoryComponent_Template_input_change_5_listener() {\n return ctx.update();\n });\n i0.ɵɵelementEnd()()();\n i0.ɵɵelementStart(6, \"small\")(7, \"i\");\n i0.ɵɵtext(8, \" Bridged cameras can cause slowdowns of the entire Homebridge instance. If unbridged, the camera will need to be added to HomeKit manually. See \");\n i0.ɵɵelementStart(9, \"a\", 4);\n i0.ɵɵtext(10, \"here\");\n i0.ɵɵelementEnd();\n i0.ɵɵtext(11, \" for mor details. \");\n i0.ɵɵelementEnd()()();\n }\n\n if (rf & 2) {\n i0.ɵɵadvance(5);\n i0.ɵɵproperty(\"ngModel\", ctx.value);\n }\n },\n directives: [i2.CheckboxControlValueAccessor, i2.NgControlStatus, i2.NgModel],\n encapsulation: 2\n });\n return UnbridgeAccessoryComponent;\n})();","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"export function isFunction(value) {\n return typeof value === 'function';\n} //# sourceMappingURL=isFunction.js.map","map":null,"metadata":{},"sourceType":"module"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"ast":null,"code":"import { observeNotification } from '../Notification';\nimport { operate } from '../util/lift';\nimport { createOperatorSubscriber } from './OperatorSubscriber';\nexport function dematerialize() {\n return operate((source, subscriber) => {\n source.subscribe(createOperatorSubscriber(subscriber, notification => observeNotification(notification, subscriber)));\n });\n} //# sourceMappingURL=dematerialize.js.map","map":null,"metadata":{},"sourceType":"module"}
|