@rsltda/components 1.0.21 → 1.0.23
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/README.md +44 -3
- package/custom-elements.json +3 -3
- package/dist/components/rs-whatsapp.d.ts +4 -0
- package/dist/rs-components.es.js +798 -656
- package/dist/rs-components.es.js.map +1 -1
- package/dist/rs-components.iife.js +146 -20
- package/dist/rs-components.iife.js.map +1 -1
- package/package.json +1 -1
package/dist/rs-components.es.js
CHANGED
|
@@ -1,34 +1,34 @@
|
|
|
1
|
-
var
|
|
2
|
-
var
|
|
3
|
-
var
|
|
4
|
-
function _(
|
|
5
|
-
customElements.get(
|
|
1
|
+
var V = Object.defineProperty;
|
|
2
|
+
var J = (d, x, t) => x in d ? V(d, x, { enumerable: !0, configurable: !0, writable: !0, value: t }) : d[x] = t;
|
|
3
|
+
var l = (d, x, t) => J(d, typeof x != "symbol" ? x + "" : x, t);
|
|
4
|
+
function _(d, x) {
|
|
5
|
+
customElements.get(d) || customElements.define(d, x);
|
|
6
6
|
}
|
|
7
|
-
const j = "data:image/png;base64,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", K = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAABXFJREFUeNrUW0tsE0cY/u0aBC3YRtCSQBCO6COkUkuqAlEuJCggwQEw5EClKsR9obZAidQeWoRIyoGqqtQEEIgL4SWBxCuckJIUzAUoqIp7SVukCkuJUah4ODYvJelj/vHs4KSJ45mdmV3/0mjt9fze+b/5/sfM7nrAkFz1vx4kh0WkVZMWYJ+z5Qo7RkmLVaVuJU2My6PZ6BA5rCNt0xgGTyQIxFHS2nWC4dFo+C7SGhT8HRrfTlqjDiA8GmiOhm/XgCsa30pAaHIlAMR4pPh50kKa3TZGWpgAEVfxZ15FxiPVLxswHlgs6WaAO88AZnwbmBd0iRrChJhjADhovDIQPDZ9vhucFwShQjYmeCWNDzKfd4MEWfA1GgTb2IXdIovIpPxoxAXIhaplZ39q+TyY/+VWmFwyJ2+d/sPH4K9THfl2LxV1BZ+EHbtkjH9l40pYcGifsF6ovEwEAGRmjTYGyM7+pNkBqPjlJ3hh+nT6faDzEtw7cx6GBtJ56T+8eE3kckIsEGXAFzKzP2vtCm58/94DcHtnq854gAyNKGcAi/wPZUZUfuYgBFYsh7/TabhR8i49V3b4e5ixYe2Eutk6+aZFwoAZOhhQLWM80h+NR0l1XOLB0DL+6W9/wD+p1MjU5PfD1IVvjNARSYvoqgSEqGoAlsnS35K7pzPpuui99c9XNpVr/qfzautODsCDji6Zy1az/QSlAEgtPgKVS+hxqO8OD2Yz16/j9H6r4wT9PJxKQ0/dp5kprF3OfxfIANnytg4XkALAvzJjTLLrOZW9gUxAxMD40tLF9HP8qx2Z/lVvwiRWJ0jQn2dPHQBIVX5jBbBcQW3OR5v4Z0n6C02WDzQKBrtsf5+w/8IyHjDRZSTpLyQ+3Rco2vaZsA76/q2PtxhZRGgF4GlPL/y5eSsUfVCft84TkhYTh45QXRMiUgj9CwUkpA7wqGZAcrxAOJav9+0/Qo8lWxroEctfjPAzV9XyPsMDKeg/fo734SvAk+dg+H4qp651PsdYlbtAbLxqsPTbb2Ba5WJ4dP0m+PyZFOcjRrzWsoenOTQq1PQ1TCGru2c9v3O6L9izg6bKbN37F7vostmqFpNXb0Dxh/U0QD7++SY9N0iC5ARjVQ5APFep27f7Oyje/jnN7RjE5m5uoMZjqYtV3azVtbTYsYy3gEFAHpy9QIsfK//jTKPxlm6wagkMJu5w41Enj8lSviP061gnp71TTo+zI/XUODQe5eWG90fU+fi7NcPZNT8ChsYPJhJcFzOHpYvnsHJ8kZXG3H1SaeGx2g2C426CFn9SB1PmzeV+bUnvD238d+4aAT89PutNwL0LnXStMFoX+2AMGbo7wP8b+2f3w9iBv9vdExDdELkNZm5+2BG8s1yhwwVQ2gsgAx4V6ezV+ecOSbs2ANgdmJibjRfdFZa5L9DqYgCExyZ1a8ylwTBOZr9UVEn2zpAbY0Gz1sXQKAYEWU0QKuTZl2YAe1an2UWzH5FVtPt8QDdI7hUqlCiZkBpZZbuPyDS6YPZtjcEWAOzmg5PVYYvdR2S8imYg6YDxSuKQbQBY5eVEQIyoeHBS5XOCl0Hy/qHpwKfaBUwHxKSdtKcNABaMTLhCs6qnRJW6gKHaQBn1dbiAbldQSn1tALDaoMXt1NfJAGtlFldMfR2g6gGA5eeIQuqHdUVUXQxQ6QqRgntlRmFWwD2+sM7xeUG/RGxQP6J7cNoBYAWSTGoMm3h1zgQDgEXwqGDKi5oYmxEArBnNc9kcVf1mmCsAYHQO5+H3YYOTYpQBVmrMtWCqMfXKrCMAMBCaxokHjXa3twoCgKx4EB+V71ucGIgjAIyKB3ET+d6Vgu8dqnoDVFb+E2AAEkYQxr2UiokAAAAASUVORK5CYII=", X = "data:image/png;base64,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", $ = "data:image/png;base64,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", ee = "data:image/png;base64,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", te = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAABG5JREFUeNrkW01ME0EUfm0UDxgoqOGgCa1EPWBiBZSDBwsoZxuNeNNe0JuSmBi8ABeBk3BS8EC44V9s4s2D1sQLEW09ikFqwsXESDV4QRN8L51Kf2bbnd2Z2dn4kkmbne523jff996b2d0AaLKtAQjhRxRbDFsj+15sr9lnClsm8BByOsYVUOx0GD/OYbvMcbiWERDz2JIqwQgodHwE2xUJlyPnk9iGVAARUEBzcvyGAlzJ+WkEYdRIANB5ovgzbGHFss1giyMQWRkXC0pynqj+SoPzwGJJmgHuPQOY83Og30gSPciEjGcAeOi8NBACLjWfBu+NQDjuNCYEHTofYpo3wUIs+GoNgnPsj02xKE7KXS0SwD+KGTT75RYRlYITBoyAuTanlAGGz74jFogy4DqYbyNKGMAi/7rIxb/8wBN+S4x0e+2lRWRAk91r7hD4/5jogDteAnzflON8F7r0tt9eWiSpIggp2QCcFhnwz18Aw4f5fSvYd3+18vi1CEBbPf+cMy1CeMXYfoJUACwXH7exEH1XtlI/uw/gZnteBoNF9WInCqmprvIazXjs3sn896cYwmbLwliknkngD8ClxUppPT4B0LAN3jEVEohazfT4x8rjk0fzjpDzBRkMHAC4g8f3PK/8/cX9285fWKzsv3UoD6aVrBpKmWN7VSqSBbiV3ywn4bTtBni0lnekMNjhIwALp9DBNb4DVw9aO18rpvS32GerGwZwbXy58tj6ZikrnnQDnA9XB2xlo7rzfW+s+0hunmyI0IzxZsQq8pNcXnzl91Vzvma2CXkEwMSyvd9RHCD9TnyyyAob7ljY2+IBAJlvAEucsogCHY8RROGZVXv5XqSP5ONGyCIAlCS6mc/8YLTQzR8ozXKtoohiRZcFnalGmGy3rf+cCgAyxVrmFTKD4fxskCPNdWIzUQiUSzl+H9UI7zl9naHqY5WZBf7F74ZdAOk+61q9tREH22t/HdC0M38O2YMO6z4CuLwijGoE4EPxWbUWJjToVskLHip2ovWCY5UogRT4x1LSAWBbz1kfOJ9RuSGS9AEA8yrrgHkfAJBUBgCTQcZk53XsCk8bDIDw2BzdGtsagFXQcydYxLI4+xFdawETY8GYk5OcMoDqr7RBLHA0+44ZwJ7VGTNo9hNOT3T7fACxIOqx8ymckB5PNkTQhgyYfVdjcAUAu/ngZXU45fYRmaAk/eU8cF5KHHINgIcBMSHjwUmZzwnSbfOYHwKfbAnoDog5N2lPGQAsGOmQwpisp0SlSkBTbSCN+iokoFoKUqmvDABWG0yZTn1lElC0WJJOfZUSKNQGCYnUj6uKqEFVF5YohYTvXpmRmBVojy+ucnxBUG8JF9RPqB6ccgBYgeQkNcZ1vDqngwEEAsWClGDKS2kZm66lG0uNtJtc64EWZSnPMwYUpca4Dd3HQaMFdf4Zo3W1BVOPrldmPQGAgTBqEQ+G3G5v+QKAQoSH0lvtSRYo4b8AoCweZHXkeyON3juU9QaoU/srwAB77Uga7jO8tAAAAABJRU5ErkJggg==", ne = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA3hJREFUeNrkWv91sjAUTXv6v+0EuoFsIJ2gdgM2KE4gTsBxAusE6ATRCdAJaCdAJ+DLTX2U9tNWKCSB3HPeIUgE7s19+QHcMHW4F+GIcEX0TuUitqftRsROxIF1AAMRvohYRFYyuAjvJFwriS8qkD4X6elcrRACNxnWRPycEIHJ5JHTSUPkixGfHGYUvFMLZYoiPdOJaiWfaQgjRNBF3ggRHM3kiyIMdPT2qSECUMeoFJFB5ClCVeRdA8lTKEkFbrAA3ObWV+KCqAUCLMoQuqnQ85cbLu4/1jCHw8fq1nEc9vb2JrfngGMI13VlnMNms5FxAbjQQxOtP67SIlEUZYvFQpYFoQzAfhzH2SWMx+PsJwRB8Nt13SYEKLXKA0kiikA5SRJJLk3TzPO8//4ThmFOEMB+xTQItPb+IEtAq4s0kKQBYX0ZJMJgMJB1EHALOYDqX3LIL/cQNSFAei15EAE5AATpdzgA5LFPIvi+/4Us5zw/FwlDQalRrKNyZngVedgdhBAgXHQEEaU+gVoa5KhPOJcaFHDSlQJkygUAKSJebE2y9Xfgd+Q6iEMoOAVbcsUfO8GsiWHw4knFzTMhwOfj3e2W9Xq9fKjDsPb+/p4f7/f78j/AbreTQ+V6vZb1ptMp2+/3X+rgfLSP+vP5XNatg9tdHdagcXs2m7HRaJSP+SCGMsitVqvP3pTz/NhyuWQiFSQ57GP7/Pws64AsiQABUT4ej0y4hj081DPU39WZIyBPQpAIaLmnpye5j2Ovr6+yBeEO1Ad5YDgcSlFo4gRMJhN5vDhpgrN+mAQ1KsDhp0fTuKnHx0cm8lOSQGuBIAAHFGdvLy8vOSlKATgEZRCk3+ECAIKhDpwGAa+8V6tWgZVXhbdlUr1FL2Z2TQiwb5EAjdyr06IUaOyZQNIC8qWmwbclBVi1wP5LG94FaH0wGhtMPlJhMc9gAVxVeWZiZ5hUIXJrYkdTETOVF7s3zAWJDsU9G3PfxBGB68w7E16Vaf9KROfrstCE3lfXxxIpM+jbQV+DAGPTxmFuS8ene6Gk5aOoaxEoEMA3fT0e22Z9VXMDo63/HaGN1m9yscRZC+GyDk54dKTCmLUcfxkVItYBODZav461gss6hjJrhYB1ENcumznrMFyb8r7KgslhloC3fapb91Q5YhaC5geJDXl/CZ7uvP8nwAAeipVa4iJE4AAAAABJRU5ErkJggg==", oe = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAABIlJREFUeNrkWs11ozAQlnf3bm8H7iD4treQCuKtIKSCcM0p5LgnXiqwOyCpAPu2NzsV4A5wKmD1sR4iE4k/I4HN9948jBlAM5o/jRgxc5hwsjjZnMaH3yLWh+OK05bTnl0AppxcThtOSU0KOTkHxZ2l4IsGQssoPjzrLBSBQfotCS5ThNf2gEctPgs+HRxmX81kWWw6naZHEdvtlu12u/RYAjD85rTr08w7hxmSzt58Pk8Wi0USx3FSBvCA17btMmuw+iS8dKCO4yRRFCVNgXuhvD4rQSo8N/EkDMOkLeBZeGbflGCpZr2KqdcFnqlwi7gs7uiK9rFMeN3AOyRK2JhWQNCF8CVK8E0Jb+dfDtM0CbgDT6MyJRhxhVB86WQyOSnSN8Vms1GVz2Zn3/f9pCt4nmfcCoJ8uusScAVYYE4BC12lMEX+DLxiYzwgFd603/9f1fKBZiUvSmFVyYtroNVqxdbrtZTn+vqa8biT/n5+fmbcEo5eyemnjtmf582tSr5HJUcZAgUNZQxFEEspCILChRFMX6wWJTy2DgX4+fq+LFWRoCD8hstAOJgt6v08XNfNBMQR51UgUaanPfoXBT8xT2PWRV9F9AaREjCD4AFR3U9KKrKQkmAY6FDAUeWnqvUhPK3+wEcpkiwAwlMag5BQpCisWFOQYojINfJ1h8RltFSGpf5PJg+BQJQlyCJIUIoJNNMQjsxY5hpi1JcpgGJLjvQqQCY8CS7Opmo5i/9huhAcioKl4EhWUTUIEpoqYFRTAZ8nyecpOjn39/ef1RJPUUh/lOootYn8IOoQgff29jblQVrDfyIPnkfnuPbw8HD0vFSQ0aiRbD9a6YAe8jbyMY7j8TirAZD/IRyf8Yz/5uYmu3Z3d8fe3t5S4XCOI3eNlIcUQe8gntlsxrg7fKk1mqCxAjCY/CxAeNDT01NW+IAPAuIchQ0Exgy+v7+nvLgG4Pzj4+NIGO4K7PX1Nb0mCktFkNhPNKGAvdiazisAg+LBKDVhDBLXISAAC8B1GvjLy0s26Kurq8wFyB3INWAFABSG/6E8WeUpsYC99jpAFoi6AhVQTVaF3+pYfVtm1zbI0nKt89bhNlkL6IZiLeDosIAval4ul53PPuJJlbG2hegM+gG1yuDvDTY9f4nRFwVIPi2ZwuPjo8z//3D6a2wvoGc9QSON0S97/ajnTQZEvEuxUxSYsDxHtSNkCgXdJGO+GHWhBMx8wWZpZDL+eKqlKpbAOtwBcaaoj1gn97e1NxipBoPAmG9bnQI0SYpaZKZnv/S7ANEaTtkmx70lH0oY9/3SjCAjmC66PFXSJdIbeBVRvvXtsFO/EbLrDgB9ASx16UgLK+ogNWhuzHQtfhpvlRskn/UA0o8lDFDMevTtoNuBAuasZwgNCh+yHsIyaPpT1lN4BhTgsp5jMzTTl9UGgzP9PPwhmn7lxdKlmr4uV+hVwdOFK8zZmeOUrBCwC4A1RNNvY61gswtDnbWCxy4QVZfNIbtg2EPy+yYLJosNBOG5l7ptl8oBGyCoPoiG4PcqOF37/T8BBgCThigH5VpvfwAAAABJRU5ErkJggg==", ae = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAABJZJREFUeNrsW79PE1Ec/9ZWfoWDm4yLeOwidZaEDg4mLDiqgx1hsk7oRJmECV10BBZ0McUB49aSYOJgUrAOJg4t8Ae0iAFKgPN966Fce+/uvbt77+6on+RLmvbufd/3+76/7wBoc8Qk8VEJpQiNEkoapDZdUyO0YdAaoYLxXaSBQucI6S4pZ6wRScGLHgRvpnxUFKF6PHEWi1DDGgOSxgY1R/MY6QG1/xIkb/5hv/FVh9ruKRTW91n4VAjdM2JFaJAmVKWdnNqf0DOTffrGepeu18CW8Bq8Fu+xsYSqwTM0wlMFX3ytOApNI7zXQRGBKyFJO/n0A0WvbsddC39GuAauZWMJySADXtlqY15O3c4abJSgBqGAnCzhGZSQCyLPSxWeQQlS64S8lc+LFv6MKDGhLKsOSBkK+BcM+hNQLumg9p1AZacDtrYTtgtcHzgG7dqRa+3Xfsbh1kgCKtv15p+wPliR7vvnTX9+VnGs6DC1lUsdIlwhJyPym5hqA50taQu/c1ICqQY9uwKFD1dGSLgwf3MV9LCD/P1niugG+dU4cYMe24UeP9Uhxpm8ss8UmJ7aM/HOPm9xg3FCi6IsYL5Z4yzlrRWhCzhUeY5ug7wtrp0XaQHJ5uA3fOOQevH7D72wUYrZBsM0Nkaq7sx4SCeB85fpO+SNe6jtHlP36De4/JhyQiYaH+v1FAdwDxbrMiPOqYCsydnGuuHunTr14qtXjiEWU0ibS095338cEQtQoF5PwNbO5RbaJSkP16Fhs9QNn7+07GFGlAuYUwKD6WLQmp6i/772qQdSY3v0oDOr2LoZyx7scCnodnL09n5DSCsQ94DMxJ5Q/glZgmJAfPHqlPLrCZCcbqTUc6lych/CBk/FzPBQt21AXFnulR4EeV2gYBrObZ9w3byyfNJIW9TR0uQhLL1RGv0EKyz2UBCpgIqZeZ1rs9gAVbeOgZxcC5HavpHPM08PiJLYFIu8LRqiikgFrLWc6mqnL7716P4eZCb7iCK6GuU0k0VZ814TGQM0p2bISxnMO1OgNEOa6EBY9GMS1Nw2o0J4hqiUdrgoIxNk/LCC5gjOmwEop5+RoQDNKoWRVtW1K+CDEJ77kBcllWogCXm/8jjvZAh5AP0BqrRSeImWxze/dfGZE8dsENdGHjx7EokqbXDhxhJYTt5mgFJ2K0TcgwK6rUZkh/VTePvuqNEGp0aOfNH0zJwCE09+Ndam4CVvBShkQGqVHQqr7oefeC/DgDWwR2OIBZZ5HjZBmPdZAh5egzneqXE6R1kvAnh9QULj9T8iGAwOxP++HHEGfEmiTBqbzdIB1zMSQoMQ8MtUCyDulRihpy+0MJJAvvh+3AcF1AxXSklW/Byhj2GZFKlg846QACoHGfmZmySBlIaQoixB+DyEGCkJCkhCyCHyTdF5iAA0QQGxGsbAR0O2nQIf8+zwogY+GpI+mr4GEYUfrpCBiKPYbqbvlytE2vT9cIUMXDAU28303RZIkSp4eJFmUMA4XHAsRL3W92N4YhUPitBGaP5fowuV8tzEg8D8PhGgAhYJDRufV+A/gsFvAQYAGFubR/xBobMAAAAASUVORK5CYII=", ie = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA9xJREFUeNrsWz124jAQHjY5gEtK7wkwJ1hKSvYGvkGcE4Qtt+JxAucGpkxn6NKZdOnMDUyZzqvhmd2gSLJk/dmw33vzSBxjSaOZb37kANw4Ro7GCYjMiPwgEjUSUPcciewb2RHZNtcGDVx0RqTuKFnzjEEuvNBYOC35UBQRaO64jEUEfeWAqJlg2GoesxkEQQBRFJ1+3+/3cDweYbvdyoxzIPKz4YreICZS8XaOLLZOkqQuiqJuA96D9+J3BJZQNWP2ZvHchadpWncFfrdFEd6VEPF2Po7juqqqWhf4DHyWwBIin4RXsiams+siaxAoIfChgMzV4iWUkPmI804XL6EEp3lCzvJ5V+BwQukqD5g1CvhHBiSml2V5+jwcDicRIQzDk3QF5gzT6ZQ1DuYHG+e+/9n0V6tVa0aHoY0ozIYrZC6Y/2JQspNfwhZea1MCyQa1XYEzjlJEuO9g/pdZUHyZi6Ab5Hne6gaPj48wGql54HK5hKenp4ux8RqFBZFnWxawojUuk96ygC7QkuW1ug2Ozbh3ZdMCInq3zwUNC5vNBt7e3oRkeC6M2jCZTL4QJ46N30VS5M3RNJT8mLNDF7JYLLR4AOfAeK407hQVcOFwZPIwn8+5N4/H45Ofi8rc9/f30y5+fHz8DaGfBXcXn8MDWtjr6yt9+ZcTCyAEpM3khDCFFoJhVQScg44FfPPeOyMcQBbJ/BtaWJIkVse/d7VQJMT1ei0kRDqkPjw89K7np5XMENYWmnuWZc5JUKsIorNA3dh/7iCppMmMbDC3qYCUnrRuTk/n9qgE2U4Sjs1QZGqTBHcs3zbSWCT+j4RHFCGVGAnG3tm0gLCtGNJxBdWeAqcYCm0TYWGiE0SXzSqmLyiHCxeRIDFhBTSDq0YAzu4nLhQQshi8S1Z4dgU8CFEBJ/tzYv7cnmDXOK4aRXAM4B+g+j0Nwt3s2h+QAT5bkEc4PyWqeEroYgkyOy9YfAkesBSltSYqRQmfP8vS19GYcGLI1Fju6pTKEg1Wb0djzNSYJVgEYdyXITy8B2N8W+FkavdHBkKikv9hHw9LX7qXiC9JYAcIP1XOSIh8B88vU6Vg75WYXvq+VGLkQIz4/p0BBRwbV5o5VvxvIi996RQFIHhHyIKUPplfukiyKDH0FKWDxefQY8wcKCCCnsPmm6IrGABCS4RY9ZH4OhVK10Z80r3DayU+btpv0PRDGChMuEICA0dxa6ZvyhUGbfomXCGBK0Nxa6bfNUEaVMKjilhCAQu4cqRDz/VNNE9YfFDADYH+X6OrCnld+MCb3997VMAzkUnz8wb+ww/+CDAA4q4zpysTtacAAAAASUVORK5CYII=", se = /* @__PURE__ */ Object.assign({
|
|
8
|
-
"../json/PuntosMapas_gasgas_0.json": () => import("./PuntosMapas_gasgas_0-CjccjpQ8.js").then((
|
|
9
|
-
"../json/PuntosMapas_gasgas_1.json": () => import("./PuntosMapas_gasgas_1-inakGBZ_.js").then((
|
|
10
|
-
"../json/PuntosMapas_hqv_0.json": () => import("./PuntosMapas_hqv_0-OSIxCcrz.js").then((
|
|
11
|
-
"../json/PuntosMapas_hqv_1.json": () => import("./PuntosMapas_hqv_1-Cr9cIOs3.js").then((
|
|
12
|
-
"../json/PuntosMapas_ktm_0.json": () => import("./PuntosMapas_ktm_0-ChWkcgec.js").then((
|
|
13
|
-
"../json/PuntosMapas_ktm_1.json": () => import("./PuntosMapas_ktm_1-DCq6GRnp.js").then((
|
|
14
|
-
"../json/PuntosMapas_voge_0.json": () => import("./PuntosMapas_voge_0-DL0EWJWf.js").then((
|
|
15
|
-
"../json/PuntosMapas_voge_1.json": () => import("./PuntosMapas_voge_1-Clawdtrj.js").then((
|
|
16
|
-
}),
|
|
7
|
+
const j = "data:image/png;base64,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", K = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAABXFJREFUeNrUW0tsE0cY/u0aBC3YRtCSQBCO6COkUkuqAlEuJCggwQEw5EClKsR9obZAidQeWoRIyoGqqtQEEIgL4SWBxCuckJIUzAUoqIp7SVukCkuJUah4ODYvJelj/vHs4KSJ45mdmV3/0mjt9fze+b/5/sfM7nrAkFz1vx4kh0WkVZMWYJ+z5Qo7RkmLVaVuJU2My6PZ6BA5rCNt0xgGTyQIxFHS2nWC4dFo+C7SGhT8HRrfTlqjDiA8GmiOhm/XgCsa30pAaHIlAMR4pPh50kKa3TZGWpgAEVfxZ15FxiPVLxswHlgs6WaAO88AZnwbmBd0iRrChJhjADhovDIQPDZ9vhucFwShQjYmeCWNDzKfd4MEWfA1GgTb2IXdIovIpPxoxAXIhaplZ39q+TyY/+VWmFwyJ2+d/sPH4K9THfl2LxV1BZ+EHbtkjH9l40pYcGifsF6ovEwEAGRmjTYGyM7+pNkBqPjlJ3hh+nT6faDzEtw7cx6GBtJ56T+8eE3kckIsEGXAFzKzP2vtCm58/94DcHtnq854gAyNKGcAi/wPZUZUfuYgBFYsh7/TabhR8i49V3b4e5ixYe2Eutk6+aZFwoAZOhhQLWM80h+NR0l1XOLB0DL+6W9/wD+p1MjU5PfD1IVvjNARSYvoqgSEqGoAlsnS35K7pzPpuui99c9XNpVr/qfzautODsCDji6Zy1az/QSlAEgtPgKVS+hxqO8OD2Yz16/j9H6r4wT9PJxKQ0/dp5kprF3OfxfIANnytg4XkALAvzJjTLLrOZW9gUxAxMD40tLF9HP8qx2Z/lVvwiRWJ0jQn2dPHQBIVX5jBbBcQW3OR5v4Z0n6C02WDzQKBrtsf5+w/8IyHjDRZSTpLyQ+3Rco2vaZsA76/q2PtxhZRGgF4GlPL/y5eSsUfVCft84TkhYTh45QXRMiUgj9CwUkpA7wqGZAcrxAOJav9+0/Qo8lWxroEctfjPAzV9XyPsMDKeg/fo734SvAk+dg+H4qp651PsdYlbtAbLxqsPTbb2Ba5WJ4dP0m+PyZFOcjRrzWsoenOTQq1PQ1TCGru2c9v3O6L9izg6bKbN37F7vostmqFpNXb0Dxh/U0QD7++SY9N0iC5ARjVQ5APFep27f7Oyje/jnN7RjE5m5uoMZjqYtV3azVtbTYsYy3gEFAHpy9QIsfK//jTKPxlm6wagkMJu5w41Enj8lSviP061gnp71TTo+zI/XUODQe5eWG90fU+fi7NcPZNT8ChsYPJhJcFzOHpYvnsHJ8kZXG3H1SaeGx2g2C426CFn9SB1PmzeV+bUnvD238d+4aAT89PutNwL0LnXStMFoX+2AMGbo7wP8b+2f3w9iBv9vdExDdELkNZm5+2BG8s1yhwwVQ2gsgAx4V6ezV+ecOSbs2ANgdmJibjRfdFZa5L9DqYgCExyZ1a8ylwTBOZr9UVEn2zpAbY0Gz1sXQKAYEWU0QKuTZl2YAe1an2UWzH5FVtPt8QDdI7hUqlCiZkBpZZbuPyDS6YPZtjcEWAOzmg5PVYYvdR2S8imYg6YDxSuKQbQBY5eVEQIyoeHBS5XOCl0Hy/qHpwKfaBUwHxKSdtKcNABaMTLhCs6qnRJW6gKHaQBn1dbiAbldQSn1tALDaoMXt1NfJAGtlFldMfR2g6gGA5eeIQuqHdUVUXQxQ6QqRgntlRmFWwD2+sM7xeUG/RGxQP6J7cNoBYAWSTGoMm3h1zgQDgEXwqGDKi5oYmxEArBnNc9kcVf1mmCsAYHQO5+H3YYOTYpQBVmrMtWCqMfXKrCMAMBCaxokHjXa3twoCgKx4EB+V71ucGIgjAIyKB3ET+d6Vgu8dqnoDVFb+E2AAEkYQxr2UiokAAAAASUVORK5CYII=", X = "data:image/png;base64,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", $ = "data:image/png;base64,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", tt = "data:image/png;base64,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", et = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAABG5JREFUeNrkW01ME0EUfm0UDxgoqOGgCa1EPWBiBZSDBwsoZxuNeNNe0JuSmBi8ABeBk3BS8EC44V9s4s2D1sQLEW09ikFqwsXESDV4QRN8L51Kf2bbnd2Z2dn4kkmbne523jff996b2d0AaLKtAQjhRxRbDFsj+15sr9lnClsm8BByOsYVUOx0GD/OYbvMcbiWERDz2JIqwQgodHwE2xUJlyPnk9iGVAARUEBzcvyGAlzJ+WkEYdRIANB5ovgzbGHFss1giyMQWRkXC0pynqj+SoPzwGJJmgHuPQOY83Og30gSPciEjGcAeOi8NBACLjWfBu+NQDjuNCYEHTofYpo3wUIs+GoNgnPsj02xKE7KXS0SwD+KGTT75RYRlYITBoyAuTanlAGGz74jFogy4DqYbyNKGMAi/7rIxb/8wBN+S4x0e+2lRWRAk91r7hD4/5jogDteAnzflON8F7r0tt9eWiSpIggp2QCcFhnwz18Aw4f5fSvYd3+18vi1CEBbPf+cMy1CeMXYfoJUACwXH7exEH1XtlI/uw/gZnteBoNF9WInCqmprvIazXjs3sn896cYwmbLwliknkngD8ClxUppPT4B0LAN3jEVEohazfT4x8rjk0fzjpDzBRkMHAC4g8f3PK/8/cX9285fWKzsv3UoD6aVrBpKmWN7VSqSBbiV3ywn4bTtBni0lnekMNjhIwALp9DBNb4DVw9aO18rpvS32GerGwZwbXy58tj6ZikrnnQDnA9XB2xlo7rzfW+s+0hunmyI0IzxZsQq8pNcXnzl91Vzvma2CXkEwMSyvd9RHCD9TnyyyAob7ljY2+IBAJlvAEucsogCHY8RROGZVXv5XqSP5ONGyCIAlCS6mc/8YLTQzR8ozXKtoohiRZcFnalGmGy3rf+cCgAyxVrmFTKD4fxskCPNdWIzUQiUSzl+H9UI7zl9naHqY5WZBf7F74ZdAOk+61q9tREH22t/HdC0M38O2YMO6z4CuLwijGoE4EPxWbUWJjToVskLHip2ovWCY5UogRT4x1LSAWBbz1kfOJ9RuSGS9AEA8yrrgHkfAJBUBgCTQcZk53XsCk8bDIDw2BzdGtsagFXQcydYxLI4+xFdawETY8GYk5OcMoDqr7RBLHA0+44ZwJ7VGTNo9hNOT3T7fACxIOqx8ymckB5PNkTQhgyYfVdjcAUAu/ngZXU45fYRmaAk/eU8cF5KHHINgIcBMSHjwUmZzwnSbfOYHwKfbAnoDog5N2lPGQAsGOmQwpisp0SlSkBTbSCN+iokoFoKUqmvDABWG0yZTn1lElC0WJJOfZUSKNQGCYnUj6uKqEFVF5YohYTvXpmRmBVojy+ucnxBUG8JF9RPqB6ccgBYgeQkNcZ1vDqngwEEAsWClGDKS2kZm66lG0uNtJtc64EWZSnPMwYUpca4Dd3HQaMFdf4Zo3W1BVOPrldmPQGAgTBqEQ+G3G5v+QKAQoSH0lvtSRYo4b8AoCweZHXkeyON3juU9QaoU/srwAB77Uga7jO8tAAAAABJRU5ErkJggg==", ot = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA3hJREFUeNrkWv91sjAUTXv6v+0EuoFsIJ2gdgM2KE4gTsBxAusE6ATRCdAJaCdAJ+DLTX2U9tNWKCSB3HPeIUgE7s19+QHcMHW4F+GIcEX0TuUitqftRsROxIF1AAMRvohYRFYyuAjvJFwriS8qkD4X6elcrRACNxnWRPycEIHJ5JHTSUPkixGfHGYUvFMLZYoiPdOJaiWfaQgjRNBF3ggRHM3kiyIMdPT2qSECUMeoFJFB5ClCVeRdA8lTKEkFbrAA3ObWV+KCqAUCLMoQuqnQ85cbLu4/1jCHw8fq1nEc9vb2JrfngGMI13VlnMNms5FxAbjQQxOtP67SIlEUZYvFQpYFoQzAfhzH2SWMx+PsJwRB8Nt13SYEKLXKA0kiikA5SRJJLk3TzPO8//4ThmFOEMB+xTQItPb+IEtAq4s0kKQBYX0ZJMJgMJB1EHALOYDqX3LIL/cQNSFAei15EAE5AATpdzgA5LFPIvi+/4Us5zw/FwlDQalRrKNyZngVedgdhBAgXHQEEaU+gVoa5KhPOJcaFHDSlQJkygUAKSJebE2y9Xfgd+Q6iEMoOAVbcsUfO8GsiWHw4knFzTMhwOfj3e2W9Xq9fKjDsPb+/p4f7/f78j/AbreTQ+V6vZb1ptMp2+/3X+rgfLSP+vP5XNatg9tdHdagcXs2m7HRaJSP+SCGMsitVqvP3pTz/NhyuWQiFSQ57GP7/Pws64AsiQABUT4ej0y4hj081DPU39WZIyBPQpAIaLmnpye5j2Ovr6+yBeEO1Ad5YDgcSlFo4gRMJhN5vDhpgrN+mAQ1KsDhp0fTuKnHx0cm8lOSQGuBIAAHFGdvLy8vOSlKATgEZRCk3+ECAIKhDpwGAa+8V6tWgZVXhbdlUr1FL2Z2TQiwb5EAjdyr06IUaOyZQNIC8qWmwbclBVi1wP5LG94FaH0wGhtMPlJhMc9gAVxVeWZiZ5hUIXJrYkdTETOVF7s3zAWJDsU9G3PfxBGB68w7E16Vaf9KROfrstCE3lfXxxIpM+jbQV+DAGPTxmFuS8ene6Gk5aOoaxEoEMA3fT0e22Z9VXMDo63/HaGN1m9yscRZC+GyDk54dKTCmLUcfxkVItYBODZav461gss6hjJrhYB1ENcumznrMFyb8r7KgslhloC3fapb91Q5YhaC5geJDXl/CZ7uvP8nwAAeipVa4iJE4AAAAABJRU5ErkJggg==", nt = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAABIlJREFUeNrkWs11ozAQlnf3bm8H7iD4treQCuKtIKSCcM0p5LgnXiqwOyCpAPu2NzsV4A5wKmD1sR4iE4k/I4HN9948jBlAM5o/jRgxc5hwsjjZnMaH3yLWh+OK05bTnl0AppxcThtOSU0KOTkHxZ2l4IsGQssoPjzrLBSBQfotCS5ThNf2gEctPgs+HRxmX81kWWw6naZHEdvtlu12u/RYAjD85rTr08w7hxmSzt58Pk8Wi0USx3FSBvCA17btMmuw+iS8dKCO4yRRFCVNgXuhvD4rQSo8N/EkDMOkLeBZeGbflGCpZr2KqdcFnqlwi7gs7uiK9rFMeN3AOyRK2JhWQNCF8CVK8E0Jb+dfDtM0CbgDT6MyJRhxhVB86WQyOSnSN8Vms1GVz2Zn3/f9pCt4nmfcCoJ8uusScAVYYE4BC12lMEX+DLxiYzwgFd603/9f1fKBZiUvSmFVyYtroNVqxdbrtZTn+vqa8biT/n5+fmbcEo5eyemnjtmf582tSr5HJUcZAgUNZQxFEEspCILChRFMX6wWJTy2DgX4+fq+LFWRoCD8hstAOJgt6v08XNfNBMQR51UgUaanPfoXBT8xT2PWRV9F9AaREjCD4AFR3U9KKrKQkmAY6FDAUeWnqvUhPK3+wEcpkiwAwlMag5BQpCisWFOQYojINfJ1h8RltFSGpf5PJg+BQJQlyCJIUIoJNNMQjsxY5hpi1JcpgGJLjvQqQCY8CS7Opmo5i/9huhAcioKl4EhWUTUIEpoqYFRTAZ8nyecpOjn39/ef1RJPUUh/lOootYn8IOoQgff29jblQVrDfyIPnkfnuPbw8HD0vFSQ0aiRbD9a6YAe8jbyMY7j8TirAZD/IRyf8Yz/5uYmu3Z3d8fe3t5S4XCOI3eNlIcUQe8gntlsxrg7fKk1mqCxAjCY/CxAeNDT01NW+IAPAuIchQ0Exgy+v7+nvLgG4Pzj4+NIGO4K7PX1Nb0mCktFkNhPNKGAvdiazisAg+LBKDVhDBLXISAAC8B1GvjLy0s26Kurq8wFyB3INWAFABSG/6E8WeUpsYC99jpAFoi6AhVQTVaF3+pYfVtm1zbI0nKt89bhNlkL6IZiLeDosIAval4ul53PPuJJlbG2hegM+gG1yuDvDTY9f4nRFwVIPi2ZwuPjo8z//3D6a2wvoGc9QSON0S97/ajnTQZEvEuxUxSYsDxHtSNkCgXdJGO+GHWhBMx8wWZpZDL+eKqlKpbAOtwBcaaoj1gn97e1NxipBoPAmG9bnQI0SYpaZKZnv/S7ANEaTtkmx70lH0oY9/3SjCAjmC66PFXSJdIbeBVRvvXtsFO/EbLrDgB9ASx16UgLK+ogNWhuzHQtfhpvlRskn/UA0o8lDFDMevTtoNuBAuasZwgNCh+yHsIyaPpT1lN4BhTgsp5jMzTTl9UGgzP9PPwhmn7lxdKlmr4uV+hVwdOFK8zZmeOUrBCwC4A1RNNvY61gswtDnbWCxy4QVZfNIbtg2EPy+yYLJosNBOG5l7ptl8oBGyCoPoiG4PcqOF37/T8BBgCThigH5VpvfwAAAABJRU5ErkJggg==", at = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAABJZJREFUeNrsW79PE1Ec/9ZWfoWDm4yLeOwidZaEDg4mLDiqgx1hsk7oRJmECV10BBZ0McUB49aSYOJgUrAOJg4t8Ae0iAFKgPN966Fce+/uvbt77+6on+RLmvbufd/3+76/7wBoc8Qk8VEJpQiNEkoapDZdUyO0YdAaoYLxXaSBQucI6S4pZ6wRScGLHgRvpnxUFKF6PHEWi1DDGgOSxgY1R/MY6QG1/xIkb/5hv/FVh9ruKRTW91n4VAjdM2JFaJAmVKWdnNqf0DOTffrGepeu18CW8Bq8Fu+xsYSqwTM0wlMFX3ytOApNI7zXQRGBKyFJO/n0A0WvbsddC39GuAauZWMJySADXtlqY15O3c4abJSgBqGAnCzhGZSQCyLPSxWeQQlS64S8lc+LFv6MKDGhLKsOSBkK+BcM+hNQLumg9p1AZacDtrYTtgtcHzgG7dqRa+3Xfsbh1kgCKtv15p+wPliR7vvnTX9+VnGs6DC1lUsdIlwhJyPym5hqA50taQu/c1ICqQY9uwKFD1dGSLgwf3MV9LCD/P1niugG+dU4cYMe24UeP9Uhxpm8ss8UmJ7aM/HOPm9xg3FCi6IsYL5Z4yzlrRWhCzhUeY5ug7wtrp0XaQHJ5uA3fOOQevH7D72wUYrZBsM0Nkaq7sx4SCeB85fpO+SNe6jtHlP36De4/JhyQiYaH+v1FAdwDxbrMiPOqYCsydnGuuHunTr14qtXjiEWU0ibS095338cEQtQoF5PwNbO5RbaJSkP16Fhs9QNn7+07GFGlAuYUwKD6WLQmp6i/772qQdSY3v0oDOr2LoZyx7scCnodnL09n5DSCsQ94DMxJ5Q/glZgmJAfPHqlPLrCZCcbqTUc6lych/CBk/FzPBQt21AXFnulR4EeV2gYBrObZ9w3byyfNJIW9TR0uQhLL1RGv0EKyz2UBCpgIqZeZ1rs9gAVbeOgZxcC5HavpHPM08PiJLYFIu8LRqiikgFrLWc6mqnL7716P4eZCb7iCK6GuU0k0VZ814TGQM0p2bISxnMO1OgNEOa6EBY9GMS1Nw2o0J4hqiUdrgoIxNk/LCC5gjOmwEop5+RoQDNKoWRVtW1K+CDEJ77kBcllWogCXm/8jjvZAh5AP0BqrRSeImWxze/dfGZE8dsENdGHjx7EokqbXDhxhJYTt5mgFJ2K0TcgwK6rUZkh/VTePvuqNEGp0aOfNH0zJwCE09+Ndam4CVvBShkQGqVHQqr7oefeC/DgDWwR2OIBZZ5HjZBmPdZAh5egzneqXE6R1kvAnh9QULj9T8iGAwOxP++HHEGfEmiTBqbzdIB1zMSQoMQ8MtUCyDulRihpy+0MJJAvvh+3AcF1AxXSklW/Byhj2GZFKlg846QACoHGfmZmySBlIaQoixB+DyEGCkJCkhCyCHyTdF5iAA0QQGxGsbAR0O2nQIf8+zwogY+GpI+mr4GEYUfrpCBiKPYbqbvlytE2vT9cIUMXDAU28303RZIkSp4eJFmUMA4XHAsRL3W92N4YhUPitBGaP5fowuV8tzEg8D8PhGgAhYJDRufV+A/gsFvAQYAGFubR/xBobMAAAAASUVORK5CYII=", it = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA9xJREFUeNrsWz124jAQHjY5gEtK7wkwJ1hKSvYGvkGcE4Qtt+JxAucGpkxn6NKZdOnMDUyZzqvhmd2gSLJk/dmw33vzSBxjSaOZb37kANw4Ro7GCYjMiPwgEjUSUPcciewb2RHZNtcGDVx0RqTuKFnzjEEuvNBYOC35UBQRaO64jEUEfeWAqJlg2GoesxkEQQBRFJ1+3+/3cDweYbvdyoxzIPKz4YreICZS8XaOLLZOkqQuiqJuA96D9+J3BJZQNWP2ZvHchadpWncFfrdFEd6VEPF2Po7juqqqWhf4DHyWwBIin4RXsiams+siaxAoIfChgMzV4iWUkPmI804XL6EEp3lCzvJ5V+BwQukqD5g1CvhHBiSml2V5+jwcDicRIQzDk3QF5gzT6ZQ1DuYHG+e+/9n0V6tVa0aHoY0ozIYrZC6Y/2JQspNfwhZea1MCyQa1XYEzjlJEuO9g/pdZUHyZi6Ab5Hne6gaPj48wGql54HK5hKenp4ux8RqFBZFnWxawojUuk96ygC7QkuW1ug2Ozbh3ZdMCInq3zwUNC5vNBt7e3oRkeC6M2jCZTL4QJ46N30VS5M3RNJT8mLNDF7JYLLR4AOfAeK407hQVcOFwZPIwn8+5N4/H45Ofi8rc9/f30y5+fHz8DaGfBXcXn8MDWtjr6yt9+ZcTCyAEpM3khDCFFoJhVQScg44FfPPeOyMcQBbJ/BtaWJIkVse/d7VQJMT1ei0kRDqkPjw89K7np5XMENYWmnuWZc5JUKsIorNA3dh/7iCppMmMbDC3qYCUnrRuTk/n9qgE2U4Sjs1QZGqTBHcs3zbSWCT+j4RHFCGVGAnG3tm0gLCtGNJxBdWeAqcYCm0TYWGiE0SXzSqmLyiHCxeRIDFhBTSDq0YAzu4nLhQQshi8S1Z4dgU8CFEBJ/tzYv7cnmDXOK4aRXAM4B+g+j0Nwt3s2h+QAT5bkEc4PyWqeEroYgkyOy9YfAkesBSltSYqRQmfP8vS19GYcGLI1Fju6pTKEg1Wb0djzNSYJVgEYdyXITy8B2N8W+FkavdHBkKikv9hHw9LX7qXiC9JYAcIP1XOSIh8B88vU6Vg75WYXvq+VGLkQIz4/p0BBRwbV5o5VvxvIi996RQFIHhHyIKUPplfukiyKDH0FKWDxefQY8wcKCCCnsPmm6IrGABCS4RY9ZH4OhVK10Z80r3DayU+btpv0PRDGChMuEICA0dxa6ZvyhUGbfomXCGBK0Nxa6bfNUEaVMKjilhCAQu4cqRDz/VNNE9YfFDADYH+X6OrCnld+MCb3997VMAzkUnz8wb+ww/+CDAA4q4zpysTtacAAAAASUVORK5CYII=", st = /* @__PURE__ */ Object.assign({
|
|
8
|
+
"../json/PuntosMapas_gasgas_0.json": () => import("./PuntosMapas_gasgas_0-CjccjpQ8.js").then((d) => d.default),
|
|
9
|
+
"../json/PuntosMapas_gasgas_1.json": () => import("./PuntosMapas_gasgas_1-inakGBZ_.js").then((d) => d.default),
|
|
10
|
+
"../json/PuntosMapas_hqv_0.json": () => import("./PuntosMapas_hqv_0-OSIxCcrz.js").then((d) => d.default),
|
|
11
|
+
"../json/PuntosMapas_hqv_1.json": () => import("./PuntosMapas_hqv_1-Cr9cIOs3.js").then((d) => d.default),
|
|
12
|
+
"../json/PuntosMapas_ktm_0.json": () => import("./PuntosMapas_ktm_0-ChWkcgec.js").then((d) => d.default),
|
|
13
|
+
"../json/PuntosMapas_ktm_1.json": () => import("./PuntosMapas_ktm_1-DCq6GRnp.js").then((d) => d.default),
|
|
14
|
+
"../json/PuntosMapas_voge_0.json": () => import("./PuntosMapas_voge_0-DL0EWJWf.js").then((d) => d.default),
|
|
15
|
+
"../json/PuntosMapas_voge_1.json": () => import("./PuntosMapas_voge_1-Clawdtrj.js").then((d) => d.default)
|
|
16
|
+
}), rt = /* @__PURE__ */ Object.assign({
|
|
17
17
|
"../pin/gasgas.png": j,
|
|
18
18
|
"../pin/gasgas_distribuidor.png": K,
|
|
19
19
|
"../pin/hqv.png": X,
|
|
20
20
|
"../pin/hqv_distribuidor.png": $,
|
|
21
|
-
"../pin/ktm.png":
|
|
22
|
-
"../pin/ktm_distribuidor.png":
|
|
23
|
-
"../pin/rs.png":
|
|
24
|
-
"../pin/rs_distribuidor.png":
|
|
25
|
-
"../pin/voge.png":
|
|
26
|
-
"../pin/voge_distribuidor.png":
|
|
27
|
-
}), q = "#000000", U = "/assets/fontawesome/css/all.min.css",
|
|
21
|
+
"../pin/ktm.png": tt,
|
|
22
|
+
"../pin/ktm_distribuidor.png": et,
|
|
23
|
+
"../pin/rs.png": ot,
|
|
24
|
+
"../pin/rs_distribuidor.png": nt,
|
|
25
|
+
"../pin/voge.png": at,
|
|
26
|
+
"../pin/voge_distribuidor.png": it
|
|
27
|
+
}), q = "#000000", U = "/assets/fontawesome/css/all.min.css", Y = "https://ap2.rs-shop.cl/web/PuntosMapas", lt = {
|
|
28
28
|
gasgas: "#cb0d25",
|
|
29
29
|
hqv: "#2b3d60",
|
|
30
30
|
ktm: "#ff6600"
|
|
31
|
-
},
|
|
31
|
+
}, H = {
|
|
32
32
|
gas: "gasgas",
|
|
33
33
|
gasgas: "gasgas",
|
|
34
34
|
rsltda: "rs",
|
|
@@ -36,20 +36,20 @@ const j = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAA
|
|
|
36
36
|
}, N = {
|
|
37
37
|
sucursal: 0,
|
|
38
38
|
distribuidor: 1
|
|
39
|
-
},
|
|
39
|
+
}, ct = ["norte", "rm", "centro", "sur"], pt = {
|
|
40
40
|
norte: "Zona Norte",
|
|
41
41
|
rm: "RM",
|
|
42
42
|
centro: "Zona Centro",
|
|
43
43
|
sur: "Zona Sur"
|
|
44
|
-
},
|
|
44
|
+
}, T = {
|
|
45
45
|
0: "Sucursales",
|
|
46
46
|
1: "Distribuidores"
|
|
47
|
-
},
|
|
47
|
+
}, L = {
|
|
48
48
|
minLat: -56.5,
|
|
49
49
|
maxLat: -17,
|
|
50
50
|
minLng: -76,
|
|
51
51
|
maxLng: -66
|
|
52
|
-
}, R = 720 * 60 * 60 * 1e3, O = 0,
|
|
52
|
+
}, R = 720 * 60 * 60 * 1e3, O = 0, dt = "rs-map-cache", E = "points", W = {
|
|
53
53
|
"region de arica y parinacota": "norte",
|
|
54
54
|
"arica y parinacota": "norte",
|
|
55
55
|
"region de tarapaca": "norte",
|
|
@@ -90,73 +90,73 @@ const j = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAA
|
|
|
90
90
|
}, A = class A extends HTMLElement {
|
|
91
91
|
constructor() {
|
|
92
92
|
super();
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
93
|
+
l(this, "root");
|
|
94
|
+
l(this, "mapEl");
|
|
95
|
+
l(this, "map");
|
|
96
|
+
l(this, "pointModalOverlayEl");
|
|
97
|
+
l(this, "pointModalTitleEl");
|
|
98
|
+
l(this, "pointModalBodyEl");
|
|
99
|
+
l(this, "pointModalCloseButton");
|
|
100
|
+
l(this, "markers", []);
|
|
101
|
+
l(this, "marca", "");
|
|
102
|
+
l(this, "marcaKey", "default");
|
|
103
|
+
l(this, "tipo", "");
|
|
104
|
+
l(this, "tipoCode", null);
|
|
105
|
+
l(this, "pointsController");
|
|
106
|
+
l(this, "points", []);
|
|
107
|
+
l(this, "pointsByZone", {
|
|
108
108
|
norte: [],
|
|
109
109
|
rm: [],
|
|
110
110
|
centro: [],
|
|
111
111
|
sur: []
|
|
112
112
|
});
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
var
|
|
137
|
-
this.pointModalOverlayEl && (this.pointModalOverlayEl.setAttribute("hidden", ""), (
|
|
113
|
+
l(this, "initialViewApplied", !1);
|
|
114
|
+
l(this, "zonesContainer");
|
|
115
|
+
l(this, "componentMessageEl");
|
|
116
|
+
l(this, "mapLayoutEl");
|
|
117
|
+
l(this, "zoneButtons", []);
|
|
118
|
+
l(this, "nearestButton");
|
|
119
|
+
l(this, "panelTitleEl");
|
|
120
|
+
l(this, "activeZone", "all");
|
|
121
|
+
l(this, "mapHeight", "");
|
|
122
|
+
l(this, "googleMapsApiKey", "");
|
|
123
|
+
l(this, "pointsApiUrl", Y);
|
|
124
|
+
l(this, "markerIconBaseUrl", "");
|
|
125
|
+
l(this, "defaultMarkerIconUrl", "");
|
|
126
|
+
l(this, "pointsCacheTtlMs", R);
|
|
127
|
+
l(this, "refreshIntervalMs", O);
|
|
128
|
+
l(this, "refreshIntervalId", null);
|
|
129
|
+
l(this, "panAnimationFrame", null);
|
|
130
|
+
l(this, "highlightTimeout", null);
|
|
131
|
+
l(this, "isSyncingInitialAttributes", !1);
|
|
132
|
+
l(this, "refreshQueued", !1);
|
|
133
|
+
l(this, "refreshQueuedForce", !1);
|
|
134
|
+
l(this, "localPointsRequests", /* @__PURE__ */ new Map());
|
|
135
|
+
l(this, "closePointModal", () => {
|
|
136
|
+
var t;
|
|
137
|
+
this.pointModalOverlayEl && (this.pointModalOverlayEl.setAttribute("hidden", ""), (t = this.pointModalBodyEl) == null || t.replaceChildren());
|
|
138
138
|
});
|
|
139
|
-
|
|
140
|
-
|
|
139
|
+
l(this, "handlePointModalOverlayClick", (t) => {
|
|
140
|
+
t.target === this.pointModalOverlayEl && this.closePointModal();
|
|
141
141
|
});
|
|
142
|
-
|
|
143
|
-
|
|
142
|
+
l(this, "handlePointModalKeydown", (t) => {
|
|
143
|
+
t.key === "Escape" && this.pointModalOverlayEl && !this.pointModalOverlayEl.hasAttribute("hidden") && this.closePointModal();
|
|
144
144
|
});
|
|
145
|
-
|
|
146
|
-
const
|
|
147
|
-
|
|
145
|
+
l(this, "handleZoneButtonClick", (t) => {
|
|
146
|
+
const o = t.currentTarget.dataset.zone;
|
|
147
|
+
o && (this.setActiveZone(o), this.scrollToZoneSection(o));
|
|
148
148
|
});
|
|
149
|
-
|
|
149
|
+
l(this, "handleNearestClick", () => {
|
|
150
150
|
if (!navigator.geolocation) {
|
|
151
151
|
alert("La geolocalizacion no esta soportada en este navegador.");
|
|
152
152
|
return;
|
|
153
153
|
}
|
|
154
154
|
navigator.geolocation.getCurrentPosition(
|
|
155
|
-
(
|
|
156
|
-
const { latitude:
|
|
157
|
-
if (
|
|
158
|
-
const a = this.getPointPosition(
|
|
159
|
-
a && this.centerMapOnPoint(a.lat, a.lng), this.scrollToPointCard(
|
|
155
|
+
(t) => {
|
|
156
|
+
const { latitude: e, longitude: o } = t.coords, n = this.findNearestPoint(e, o);
|
|
157
|
+
if (n) {
|
|
158
|
+
const a = this.getPointPosition(n);
|
|
159
|
+
a && this.centerMapOnPoint(a.lat, a.lng), this.scrollToPointCard(n.id);
|
|
160
160
|
} else
|
|
161
161
|
alert("No hay puntos disponibles para calcular la tienda cercana.");
|
|
162
162
|
},
|
|
@@ -165,7 +165,7 @@ const j = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAA
|
|
|
165
165
|
}
|
|
166
166
|
);
|
|
167
167
|
});
|
|
168
|
-
|
|
168
|
+
l(this, "handleVisibilityChange", () => {
|
|
169
169
|
!document.hidden && this.isConnected && this.refreshIntervalMs > 0 && this.forceRefresh();
|
|
170
170
|
});
|
|
171
171
|
A.ensureFontAwesome(), this.root = this.attachShadow({ mode: "open" }), this.root.innerHTML = `
|
|
@@ -794,137 +794,137 @@ const j = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAA
|
|
|
794
794
|
];
|
|
795
795
|
}
|
|
796
796
|
connectedCallback() {
|
|
797
|
-
this.mapEl = this.root.querySelector("#map"), this.panelTitleEl = this.root.querySelector("[data-panel-title]"), this.zonesContainer = this.root.querySelector("[data-zone-container]"), this.componentMessageEl = this.root.querySelector("[data-component-message]"), this.mapLayoutEl = this.root.querySelector("[data-map-layout]"), this.pointModalOverlayEl = this.root.querySelector("[data-point-modal-overlay]"), this.pointModalTitleEl = this.root.querySelector("[data-point-modal-title]"), this.pointModalBodyEl = this.root.querySelector("[data-point-modal-body]"), this.pointModalCloseButton = this.root.querySelector("[data-point-modal-close]"), this.zoneButtons = Array.from(this.root.querySelectorAll("[data-zone]")), this.nearestButton = this.root.querySelector('[data-action="nearest"]'), this.zoneButtons.forEach((
|
|
797
|
+
this.mapEl = this.root.querySelector("#map"), this.panelTitleEl = this.root.querySelector("[data-panel-title]"), this.zonesContainer = this.root.querySelector("[data-zone-container]"), this.componentMessageEl = this.root.querySelector("[data-component-message]"), this.mapLayoutEl = this.root.querySelector("[data-map-layout]"), this.pointModalOverlayEl = this.root.querySelector("[data-point-modal-overlay]"), this.pointModalTitleEl = this.root.querySelector("[data-point-modal-title]"), this.pointModalBodyEl = this.root.querySelector("[data-point-modal-body]"), this.pointModalCloseButton = this.root.querySelector("[data-point-modal-close]"), this.zoneButtons = Array.from(this.root.querySelectorAll("[data-zone]")), this.nearestButton = this.root.querySelector('[data-action="nearest"]'), this.zoneButtons.forEach((t) => t.addEventListener("click", this.handleZoneButtonClick)), this.nearestButton && this.nearestButton.addEventListener("click", this.handleNearestClick), this.pointModalOverlayEl.addEventListener("click", this.handlePointModalOverlayClick), this.pointModalCloseButton.addEventListener("click", this.closePointModal), window.addEventListener("keydown", this.handlePointModalKeydown), this.updateZoneButtons(), this.setMapHeight(this.getAttribute("height")), this.setComponentState("loading"), this.applyRefreshInterval(this.getAttribute("refresh-interval")), document.addEventListener("visibilitychange", this.handleVisibilityChange), this.syncAttributesToState();
|
|
798
798
|
}
|
|
799
799
|
disconnectedCallback() {
|
|
800
|
-
var
|
|
801
|
-
(
|
|
800
|
+
var t, e, o;
|
|
801
|
+
(t = this.pointsController) == null || t.abort(), this.clearRefreshTimer(), this.zoneButtons.forEach((n) => n.removeEventListener("click", this.handleZoneButtonClick)), this.nearestButton && this.nearestButton.removeEventListener("click", this.handleNearestClick), (e = this.pointModalOverlayEl) == null || e.removeEventListener("click", this.handlePointModalOverlayClick), (o = this.pointModalCloseButton) == null || o.removeEventListener("click", this.closePointModal), window.removeEventListener("keydown", this.handlePointModalKeydown), document.removeEventListener("visibilitychange", this.handleVisibilityChange);
|
|
802
802
|
}
|
|
803
|
-
attributeChangedCallback(
|
|
804
|
-
|
|
803
|
+
attributeChangedCallback(t, e, o) {
|
|
804
|
+
t === "marca" ? this.setMarca(o != null ? o : "") : t === "tipo" ? this.setTipo(o != null ? o : "") : t === "height" ? this.setMapHeight(o) : t === "google-maps-key" ? this.setGoogleMapsKey(o) : t === "points-api-url" ? this.setPointsApiUrl(o) : t === "cache-days" ? this.setCacheDays(o) : t === "refresh-interval" ? this.applyRefreshInterval(o) : t === "refresh-token" ? this.isConnected && o !== e && this.queueRefreshPoints(!0) : t === "marker-icon-base" ? this.setMarkerIconBase(o) : t === "marker-icon-default" && this.setDefaultMarkerIcon(o);
|
|
805
805
|
}
|
|
806
806
|
loadGoogleMaps() {
|
|
807
807
|
return window._rsGoogleMapsLoaded ? Promise.resolve().then(() => {
|
|
808
808
|
this.initMap();
|
|
809
|
-
}) : this.googleMapsApiKey ? (A.googleMapsLoaderPromise || (A.googleMapsLoaderPromise = new Promise((
|
|
810
|
-
const
|
|
811
|
-
if (
|
|
812
|
-
|
|
809
|
+
}) : this.googleMapsApiKey ? (A.googleMapsLoaderPromise || (A.googleMapsLoaderPromise = new Promise((t, e) => {
|
|
810
|
+
const o = document.querySelector('script[data-rs-google-maps="true"]');
|
|
811
|
+
if (o) {
|
|
812
|
+
o.addEventListener("load", () => t(), { once: !0 }), o.addEventListener(
|
|
813
813
|
"error",
|
|
814
|
-
() =>
|
|
814
|
+
() => e(new Error("Error al cargar la API de Google Maps")),
|
|
815
815
|
{ once: !0 }
|
|
816
816
|
);
|
|
817
817
|
return;
|
|
818
818
|
}
|
|
819
|
-
const
|
|
819
|
+
const n = document.createElement("script"), a = new URLSearchParams({
|
|
820
820
|
key: this.googleMapsApiKey,
|
|
821
821
|
v: "weekly"
|
|
822
822
|
});
|
|
823
|
-
|
|
824
|
-
window._rsGoogleMapsLoaded = !0,
|
|
825
|
-
},
|
|
826
|
-
A.googleMapsLoaderPromise = null,
|
|
827
|
-
}, document.head.appendChild(
|
|
823
|
+
n.src = `https://maps.googleapis.com/maps/api/js?${a.toString()}`, n.async = !0, n.defer = !0, n.dataset.rsGoogleMaps = "true", n.onload = () => {
|
|
824
|
+
window._rsGoogleMapsLoaded = !0, t();
|
|
825
|
+
}, n.onerror = () => {
|
|
826
|
+
A.googleMapsLoaderPromise = null, e(new Error("Error al cargar la API de Google Maps"));
|
|
827
|
+
}, document.head.appendChild(n);
|
|
828
828
|
})), A.googleMapsLoaderPromise.then(() => {
|
|
829
829
|
window._rsGoogleMapsLoaded = !0, this.initMap();
|
|
830
|
-
}).catch((
|
|
831
|
-
console.error(
|
|
830
|
+
}).catch((t) => {
|
|
831
|
+
console.error(t instanceof Error ? t.message : "Error al cargar la API de Google Maps");
|
|
832
832
|
})) : (console.error('Falta la clave de Google Maps. Define el atributo "google-maps-key" en <rs-map>.'), Promise.resolve());
|
|
833
833
|
}
|
|
834
834
|
initMap() {
|
|
835
|
-
const
|
|
836
|
-
if (!
|
|
835
|
+
const t = window.google;
|
|
836
|
+
if (!t) {
|
|
837
837
|
console.error("Google Maps aun no esta disponible.");
|
|
838
838
|
return;
|
|
839
839
|
}
|
|
840
|
-
const
|
|
841
|
-
this.map = new
|
|
842
|
-
center:
|
|
840
|
+
const e = this.getInitialCenter();
|
|
841
|
+
this.map = new t.maps.Map(this.mapEl, {
|
|
842
|
+
center: e,
|
|
843
843
|
zoom: 14,
|
|
844
844
|
mapTypeId: "roadmap"
|
|
845
845
|
}), this.points.length && this.updateMarkers(this.points);
|
|
846
846
|
}
|
|
847
847
|
getInitialCenter() {
|
|
848
|
-
const
|
|
849
|
-
return
|
|
848
|
+
const t = this.getFirstValidPoint();
|
|
849
|
+
return t || { lat: -33.4489, lng: -70.6693 };
|
|
850
850
|
}
|
|
851
851
|
getFirstValidPoint() {
|
|
852
|
-
for (const
|
|
853
|
-
const
|
|
854
|
-
if (
|
|
855
|
-
return
|
|
852
|
+
for (const t of this.points) {
|
|
853
|
+
const e = this.getPointPosition(t);
|
|
854
|
+
if (e)
|
|
855
|
+
return e;
|
|
856
856
|
}
|
|
857
857
|
return null;
|
|
858
858
|
}
|
|
859
859
|
syncAttributesToState() {
|
|
860
|
-
var
|
|
861
|
-
this.isSyncingInitialAttributes = !0, this.setMarca((
|
|
860
|
+
var t, e;
|
|
861
|
+
this.isSyncingInitialAttributes = !0, this.setMarca((t = this.getAttribute("marca")) != null ? t : ""), this.setTipo((e = this.getAttribute("tipo")) != null ? e : ""), this.setGoogleMapsKey(this.getAttribute("google-maps-key")), this.setPointsApiUrl(this.getAttribute("points-api-url")), this.setCacheDays(this.getAttribute("cache-days")), this.setMarkerIconBase(this.getAttribute("marker-icon-base")), this.setDefaultMarkerIcon(this.getAttribute("marker-icon-default")), this.isSyncingInitialAttributes = !1, this.queueRefreshPoints();
|
|
862
862
|
}
|
|
863
|
-
setMapHeight(
|
|
864
|
-
const
|
|
865
|
-
if (!
|
|
863
|
+
setMapHeight(t) {
|
|
864
|
+
const e = (t != null ? t : "").trim();
|
|
865
|
+
if (!e) {
|
|
866
866
|
this.mapHeight = "", this.style.removeProperty("--map-height");
|
|
867
867
|
return;
|
|
868
868
|
}
|
|
869
|
-
this.mapHeight =
|
|
869
|
+
this.mapHeight = e, this.style.setProperty("--map-height", e);
|
|
870
870
|
}
|
|
871
|
-
setGoogleMapsKey(
|
|
872
|
-
this.googleMapsApiKey = (
|
|
871
|
+
setGoogleMapsKey(t) {
|
|
872
|
+
this.googleMapsApiKey = (t != null ? t : "").trim(), this.googleMapsApiKey && this.isConnected && this.loadGoogleMaps();
|
|
873
873
|
}
|
|
874
|
-
setPointsApiUrl(
|
|
875
|
-
const
|
|
876
|
-
this.pointsApiUrl =
|
|
874
|
+
setPointsApiUrl(t) {
|
|
875
|
+
const e = (t != null ? t : "").trim();
|
|
876
|
+
this.pointsApiUrl = e || Y, this.pointsApiUrl && this.isConnected && !this.isSyncingInitialAttributes && this.queueRefreshPoints();
|
|
877
877
|
}
|
|
878
|
-
setCacheDays(
|
|
879
|
-
const
|
|
880
|
-
if (!
|
|
878
|
+
setCacheDays(t) {
|
|
879
|
+
const e = (t != null ? t : "").trim();
|
|
880
|
+
if (!e) {
|
|
881
881
|
this.pointsCacheTtlMs = R;
|
|
882
882
|
return;
|
|
883
883
|
}
|
|
884
|
-
const
|
|
885
|
-
if (!Number.isFinite(
|
|
884
|
+
const o = Number(e);
|
|
885
|
+
if (!Number.isFinite(o) || o < 0) {
|
|
886
886
|
this.pointsCacheTtlMs = R;
|
|
887
887
|
return;
|
|
888
888
|
}
|
|
889
|
-
this.pointsCacheTtlMs =
|
|
889
|
+
this.pointsCacheTtlMs = o * 24 * 60 * 60 * 1e3;
|
|
890
890
|
}
|
|
891
|
-
applyRefreshInterval(
|
|
892
|
-
const
|
|
893
|
-
this.refreshIntervalMs =
|
|
891
|
+
applyRefreshInterval(t) {
|
|
892
|
+
const e = (t != null ? t : "").trim(), o = this.parseRefreshInterval(e);
|
|
893
|
+
this.refreshIntervalMs = o, this.clearRefreshTimer(), this.isConnected && this.refreshIntervalMs > 0 && (this.refreshIntervalId = window.setInterval(() => {
|
|
894
894
|
document.hidden || this.forceRefresh();
|
|
895
895
|
}, this.refreshIntervalMs));
|
|
896
896
|
}
|
|
897
|
-
parseRefreshInterval(
|
|
898
|
-
if (!
|
|
897
|
+
parseRefreshInterval(t) {
|
|
898
|
+
if (!t)
|
|
899
899
|
return O;
|
|
900
|
-
const
|
|
901
|
-
return !Number.isFinite(
|
|
900
|
+
const e = Number(t);
|
|
901
|
+
return !Number.isFinite(e) || e <= 0 ? O : Math.round(e * 60 * 1e3);
|
|
902
902
|
}
|
|
903
903
|
clearRefreshTimer() {
|
|
904
904
|
this.refreshIntervalId !== null && (window.clearInterval(this.refreshIntervalId), this.refreshIntervalId = null);
|
|
905
905
|
}
|
|
906
|
-
setMarkerIconBase(
|
|
907
|
-
const
|
|
908
|
-
if (!
|
|
906
|
+
setMarkerIconBase(t) {
|
|
907
|
+
const e = (t != null ? t : "").trim();
|
|
908
|
+
if (!e) {
|
|
909
909
|
this.markerIconBaseUrl = "";
|
|
910
910
|
return;
|
|
911
911
|
}
|
|
912
|
-
this.markerIconBaseUrl =
|
|
912
|
+
this.markerIconBaseUrl = e.endsWith("/") ? e : `${e}/`;
|
|
913
913
|
}
|
|
914
|
-
setDefaultMarkerIcon(
|
|
915
|
-
this.defaultMarkerIconUrl = (
|
|
914
|
+
setDefaultMarkerIcon(t) {
|
|
915
|
+
this.defaultMarkerIconUrl = (t != null ? t : "").trim();
|
|
916
916
|
}
|
|
917
|
-
setMarca(
|
|
918
|
-
this.marca =
|
|
917
|
+
setMarca(t) {
|
|
918
|
+
this.marca = t.trim(), this.marcaKey = this.normalizeBrandKey(this.marca), this.applyBrandColor(), this.isSyncingInitialAttributes || this.queueRefreshPoints();
|
|
919
919
|
}
|
|
920
|
-
setTipo(
|
|
921
|
-
this.tipo =
|
|
920
|
+
setTipo(t) {
|
|
921
|
+
this.tipo = t.trim(), this.tipoCode = this.normalizeTipo(this.tipo), this.updatePanelTitle(), this.isSyncingInitialAttributes || this.queueRefreshPoints();
|
|
922
922
|
}
|
|
923
|
-
queueRefreshPoints(
|
|
924
|
-
|
|
923
|
+
queueRefreshPoints(t = !1) {
|
|
924
|
+
t && (this.refreshQueuedForce = !0), !this.refreshQueued && (this.refreshQueued = !0, queueMicrotask(() => {
|
|
925
925
|
this.refreshQueued = !1;
|
|
926
|
-
const
|
|
927
|
-
this.refreshQueuedForce = !1, this.refreshPoints({ force:
|
|
926
|
+
const e = this.refreshQueuedForce;
|
|
927
|
+
this.refreshQueuedForce = !1, this.refreshPoints({ force: e });
|
|
928
928
|
}));
|
|
929
929
|
}
|
|
930
930
|
forceRefresh() {
|
|
@@ -939,32 +939,32 @@ const j = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAA
|
|
|
939
939
|
updatePanelTitle() {
|
|
940
940
|
if (!this.panelTitleEl)
|
|
941
941
|
return;
|
|
942
|
-
const
|
|
943
|
-
this.panelTitleEl.textContent =
|
|
942
|
+
const t = this.getTipoLabel();
|
|
943
|
+
this.panelTitleEl.textContent = t != null ? t : "Puntos del mapa";
|
|
944
944
|
}
|
|
945
945
|
getTipoLabel() {
|
|
946
|
-
if (this.tipoCode !== null && this.tipoCode in
|
|
947
|
-
return
|
|
948
|
-
const
|
|
949
|
-
return
|
|
946
|
+
if (this.tipoCode !== null && this.tipoCode in T)
|
|
947
|
+
return T[this.tipoCode];
|
|
948
|
+
const t = this.tipo.trim().toLowerCase(), e = t && t in N ? N[t] : null;
|
|
949
|
+
return e !== null && e in T ? T[e] : null;
|
|
950
950
|
}
|
|
951
951
|
applyBrandColor() {
|
|
952
|
-
var
|
|
953
|
-
const
|
|
954
|
-
this.style.setProperty("--rs-map-accent",
|
|
952
|
+
var e;
|
|
953
|
+
const t = (e = lt[this.marcaKey]) != null ? e : q;
|
|
954
|
+
this.style.setProperty("--rs-map-accent", t);
|
|
955
955
|
}
|
|
956
|
-
normalizeTipo(
|
|
957
|
-
if (!
|
|
956
|
+
normalizeTipo(t) {
|
|
957
|
+
if (!t)
|
|
958
958
|
return null;
|
|
959
|
-
const
|
|
960
|
-
if (
|
|
961
|
-
return N[
|
|
962
|
-
const
|
|
963
|
-
return Number.isFinite(
|
|
959
|
+
const e = t.trim().toLowerCase();
|
|
960
|
+
if (e in N)
|
|
961
|
+
return N[e];
|
|
962
|
+
const o = Number(e);
|
|
963
|
+
return Number.isFinite(o) && (o === 0 || o === 1) ? o : null;
|
|
964
964
|
}
|
|
965
|
-
async refreshPoints(
|
|
965
|
+
async refreshPoints(t = {}) {
|
|
966
966
|
var r, u;
|
|
967
|
-
const
|
|
967
|
+
const e = (r = t.force) != null ? r : !1;
|
|
968
968
|
if (!this.isConnected || !this.marca || this.tipoCode === null)
|
|
969
969
|
return;
|
|
970
970
|
if (!this.pointsApiUrl) {
|
|
@@ -972,27 +972,27 @@ const j = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAA
|
|
|
972
972
|
return;
|
|
973
973
|
}
|
|
974
974
|
(u = this.pointsController) == null || u.abort();
|
|
975
|
-
const
|
|
976
|
-
this.pointsController =
|
|
977
|
-
const
|
|
978
|
-
marca:
|
|
975
|
+
const o = new AbortController();
|
|
976
|
+
this.pointsController = o;
|
|
977
|
+
const n = this.getMarcaRequestValue(), a = new URLSearchParams({
|
|
978
|
+
marca: n,
|
|
979
979
|
tipo: String(this.tipoCode)
|
|
980
|
-
}), s = this.pointsApiUrl.includes("?"), i = s && !/[?&]$/.test(this.pointsApiUrl),
|
|
980
|
+
}), s = this.pointsApiUrl.includes("?"), i = s && !/[?&]$/.test(this.pointsApiUrl), c = s ? i ? "&" : "" : "?", p = `${this.pointsApiUrl}${c}${a.toString()}`, m = this.getPointsCacheKey(p), h = e ? null : await this.readPointsCache(m), f = h && Date.now() - h.timestamp < this.pointsCacheTtlMs, b = !e && !h ? await this.getLocalPointsFallback(n, this.tipoCode) : null;
|
|
981
981
|
if (h) {
|
|
982
982
|
if (this.applyPointsPayload(h.data), this.setComponentState("ready"), f)
|
|
983
983
|
return;
|
|
984
|
-
} else b ? (this.applyPointsPayload(b), this.setComponentState("ready")) : (!
|
|
984
|
+
} else b ? (this.applyPointsPayload(b), this.setComponentState("ready")) : (!e || this.points.length === 0) && this.setComponentState("loading");
|
|
985
985
|
try {
|
|
986
|
-
const g = await fetch(
|
|
987
|
-
signal:
|
|
986
|
+
const g = await fetch(p, {
|
|
987
|
+
signal: o.signal
|
|
988
988
|
});
|
|
989
989
|
if (!g.ok)
|
|
990
990
|
throw new Error(`Respuesta ${g.status}`);
|
|
991
|
-
const
|
|
992
|
-
if (!Array.isArray(
|
|
991
|
+
const w = await g.json();
|
|
992
|
+
if (!Array.isArray(w))
|
|
993
993
|
throw new Error("La respuesta de puntos no es valida.");
|
|
994
|
-
const
|
|
995
|
-
await this.writePointsCache(m,
|
|
994
|
+
const C = w;
|
|
995
|
+
await this.writePointsCache(m, C), this.applyPointsPayload(C), this.setComponentState("ready");
|
|
996
996
|
} catch (g) {
|
|
997
997
|
if (g instanceof DOMException && g.name === "AbortError")
|
|
998
998
|
return;
|
|
@@ -1000,222 +1000,222 @@ const j = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAA
|
|
|
1000
1000
|
console.warn("Se mantienen puntos locales por error al refrescar el mapa", g);
|
|
1001
1001
|
return;
|
|
1002
1002
|
}
|
|
1003
|
-
if (
|
|
1003
|
+
if (e && this.points.length > 0) {
|
|
1004
1004
|
console.warn("No se pudo forzar la actualizacion de puntos, se conservan los datos actuales", g);
|
|
1005
1005
|
return;
|
|
1006
1006
|
}
|
|
1007
1007
|
console.error("No se pudieron cargar los puntos del mapa", g), this.setComponentState("error");
|
|
1008
1008
|
}
|
|
1009
1009
|
}
|
|
1010
|
-
applyPointsPayload(
|
|
1011
|
-
this.points = this.transformPoints(
|
|
1010
|
+
applyPointsPayload(t) {
|
|
1011
|
+
this.points = this.transformPoints(t), this.reportUnmappablePoints(this.points), this.renderPoints(this.points), this.initialViewApplied = !1, this.updateMarkers(this.points);
|
|
1012
1012
|
}
|
|
1013
|
-
reportUnmappablePoints(
|
|
1014
|
-
const
|
|
1015
|
-
id:
|
|
1016
|
-
titulo:
|
|
1017
|
-
direccion:
|
|
1018
|
-
lat:
|
|
1019
|
-
lng:
|
|
1013
|
+
reportUnmappablePoints(t) {
|
|
1014
|
+
const e = t.filter((o) => !this.getPointPosition(o)).map((o) => ({
|
|
1015
|
+
id: o.id,
|
|
1016
|
+
titulo: o.titulo,
|
|
1017
|
+
direccion: o.direccion,
|
|
1018
|
+
lat: o.lat,
|
|
1019
|
+
lng: o.lng
|
|
1020
1020
|
}));
|
|
1021
|
-
|
|
1021
|
+
e.length && console.warn("Puntos con coordenadas fuera de rango o invalidas; no se muestran como markers.", e);
|
|
1022
1022
|
}
|
|
1023
|
-
getPointsCacheKey(
|
|
1024
|
-
return `rs-map:points:${
|
|
1023
|
+
getPointsCacheKey(t) {
|
|
1024
|
+
return `rs-map:points:${t}`;
|
|
1025
1025
|
}
|
|
1026
|
-
async getLocalPointsFallback(
|
|
1027
|
-
const
|
|
1026
|
+
async getLocalPointsFallback(t, e) {
|
|
1027
|
+
const n = `../json/PuntosMapas_${this.normalizeBrandKey(t)}_${e}.json`, a = this.localPointsRequests.get(n);
|
|
1028
1028
|
if (a)
|
|
1029
1029
|
return a;
|
|
1030
|
-
const s =
|
|
1030
|
+
const s = st[n];
|
|
1031
1031
|
if (!s)
|
|
1032
1032
|
return null;
|
|
1033
|
-
const i = s().then((
|
|
1034
|
-
const
|
|
1035
|
-
return
|
|
1033
|
+
const i = s().then((c) => {
|
|
1034
|
+
const p = this.parseLocalPointsPayload(c);
|
|
1035
|
+
return p != null && p.length ? p : null;
|
|
1036
1036
|
}).catch(() => null);
|
|
1037
|
-
return this.localPointsRequests.set(
|
|
1037
|
+
return this.localPointsRequests.set(n, i), i;
|
|
1038
1038
|
}
|
|
1039
|
-
parseLocalPointsPayload(
|
|
1040
|
-
return Array.isArray(
|
|
1039
|
+
parseLocalPointsPayload(t) {
|
|
1040
|
+
return Array.isArray(t) ? t : null;
|
|
1041
1041
|
}
|
|
1042
|
-
async readPointsCache(
|
|
1043
|
-
const
|
|
1044
|
-
if (
|
|
1045
|
-
return
|
|
1042
|
+
async readPointsCache(t) {
|
|
1043
|
+
const e = await this.readPointsCacheFromIndexedDb(t);
|
|
1044
|
+
if (e)
|
|
1045
|
+
return e;
|
|
1046
1046
|
try {
|
|
1047
|
-
const
|
|
1048
|
-
if (!
|
|
1047
|
+
const o = window.localStorage.getItem(t);
|
|
1048
|
+
if (!o)
|
|
1049
1049
|
return null;
|
|
1050
|
-
const
|
|
1051
|
-
return !
|
|
1050
|
+
const n = JSON.parse(o);
|
|
1051
|
+
return !n || !Array.isArray(n.data) || !Number.isFinite(n.timestamp) ? (window.localStorage.removeItem(t), null) : n;
|
|
1052
1052
|
} catch {
|
|
1053
1053
|
return null;
|
|
1054
1054
|
}
|
|
1055
1055
|
}
|
|
1056
|
-
async writePointsCache(
|
|
1057
|
-
const
|
|
1056
|
+
async writePointsCache(t, e) {
|
|
1057
|
+
const o = {
|
|
1058
1058
|
timestamp: Date.now(),
|
|
1059
|
-
data:
|
|
1059
|
+
data: e
|
|
1060
1060
|
};
|
|
1061
|
-
await this.writePointsCacheToIndexedDb(
|
|
1061
|
+
await this.writePointsCacheToIndexedDb(t, o);
|
|
1062
1062
|
try {
|
|
1063
|
-
window.localStorage.setItem(
|
|
1063
|
+
window.localStorage.setItem(t, JSON.stringify(o));
|
|
1064
1064
|
} catch {
|
|
1065
1065
|
}
|
|
1066
1066
|
}
|
|
1067
|
-
async readPointsCacheFromIndexedDb(
|
|
1068
|
-
const
|
|
1069
|
-
return
|
|
1070
|
-
const s =
|
|
1067
|
+
async readPointsCacheFromIndexedDb(t) {
|
|
1068
|
+
const e = await A.openPointsCacheDb();
|
|
1069
|
+
return e ? new Promise((o) => {
|
|
1070
|
+
const s = e.transaction(E, "readonly").objectStore(E).get(t);
|
|
1071
1071
|
s.onsuccess = () => {
|
|
1072
1072
|
const i = s.result;
|
|
1073
1073
|
if (!i || !Array.isArray(i.data) || !Number.isFinite(i.timestamp)) {
|
|
1074
|
-
|
|
1074
|
+
o(null);
|
|
1075
1075
|
return;
|
|
1076
1076
|
}
|
|
1077
|
-
|
|
1077
|
+
o({
|
|
1078
1078
|
timestamp: i.timestamp,
|
|
1079
1079
|
data: i.data
|
|
1080
1080
|
});
|
|
1081
|
-
}, s.onerror = () =>
|
|
1081
|
+
}, s.onerror = () => o(null);
|
|
1082
1082
|
}) : null;
|
|
1083
1083
|
}
|
|
1084
|
-
async writePointsCacheToIndexedDb(
|
|
1085
|
-
const
|
|
1086
|
-
|
|
1087
|
-
const i =
|
|
1088
|
-
key:
|
|
1089
|
-
timestamp:
|
|
1090
|
-
data:
|
|
1084
|
+
async writePointsCacheToIndexedDb(t, e) {
|
|
1085
|
+
const o = await A.openPointsCacheDb();
|
|
1086
|
+
o && await new Promise((n) => {
|
|
1087
|
+
const i = o.transaction(E, "readwrite").objectStore(E).put({
|
|
1088
|
+
key: t,
|
|
1089
|
+
timestamp: e.timestamp,
|
|
1090
|
+
data: e.data
|
|
1091
1091
|
});
|
|
1092
|
-
i.onsuccess = () =>
|
|
1092
|
+
i.onsuccess = () => n(), i.onerror = () => n();
|
|
1093
1093
|
});
|
|
1094
1094
|
}
|
|
1095
1095
|
static openPointsCacheDb() {
|
|
1096
|
-
return typeof window == "undefined" || !("indexedDB" in window) ? Promise.resolve(null) : (A.pointsCacheDbPromise || (A.pointsCacheDbPromise = new Promise((
|
|
1097
|
-
const
|
|
1098
|
-
|
|
1099
|
-
const
|
|
1100
|
-
|
|
1101
|
-
},
|
|
1096
|
+
return typeof window == "undefined" || !("indexedDB" in window) ? Promise.resolve(null) : (A.pointsCacheDbPromise || (A.pointsCacheDbPromise = new Promise((t) => {
|
|
1097
|
+
const e = window.indexedDB.open(dt, 1);
|
|
1098
|
+
e.onupgradeneeded = () => {
|
|
1099
|
+
const o = e.result;
|
|
1100
|
+
o.objectStoreNames.contains(E) || o.createObjectStore(E, { keyPath: "key" });
|
|
1101
|
+
}, e.onsuccess = () => t(e.result), e.onerror = () => t(null);
|
|
1102
1102
|
})), A.pointsCacheDbPromise);
|
|
1103
1103
|
}
|
|
1104
|
-
transformPoints(
|
|
1105
|
-
return
|
|
1106
|
-
...
|
|
1107
|
-
zone: this.getZoneForPoint(
|
|
1104
|
+
transformPoints(t) {
|
|
1105
|
+
return t.map((e) => ({
|
|
1106
|
+
...e,
|
|
1107
|
+
zone: this.getZoneForPoint(e)
|
|
1108
1108
|
}));
|
|
1109
1109
|
}
|
|
1110
|
-
renderPoints(
|
|
1110
|
+
renderPoints(t) {
|
|
1111
1111
|
if (!this.zonesContainer)
|
|
1112
1112
|
return;
|
|
1113
|
-
const
|
|
1114
|
-
this.pointsByZone =
|
|
1115
|
-
const
|
|
1116
|
-
|
|
1113
|
+
const e = this.groupPoints(t);
|
|
1114
|
+
this.pointsByZone = e, this.updateZoneButtonCounts();
|
|
1115
|
+
const o = document.createDocumentFragment();
|
|
1116
|
+
ct.forEach((n) => {
|
|
1117
1117
|
const a = document.createElement("section");
|
|
1118
|
-
a.className = "zone-section", a.dataset.zoneSection =
|
|
1118
|
+
a.className = "zone-section", a.dataset.zoneSection = n;
|
|
1119
1119
|
const s = document.createElement("div");
|
|
1120
1120
|
s.className = "zone-section__header";
|
|
1121
1121
|
const i = document.createElement("span");
|
|
1122
|
-
if (i.textContent =
|
|
1123
|
-
const
|
|
1124
|
-
|
|
1122
|
+
if (i.textContent = pt[n], s.appendChild(i), a.appendChild(s), e[n].length === 0) {
|
|
1123
|
+
const c = document.createElement("p");
|
|
1124
|
+
c.className = "zone-section__empty", c.textContent = "Sin puntos en esta zona.", a.appendChild(c);
|
|
1125
1125
|
} else {
|
|
1126
|
-
const
|
|
1127
|
-
|
|
1128
|
-
|
|
1129
|
-
}), a.appendChild(
|
|
1126
|
+
const c = document.createElement("div");
|
|
1127
|
+
c.className = "zone-section__list", e[n].forEach((p) => {
|
|
1128
|
+
c.appendChild(this.createPointCard(p));
|
|
1129
|
+
}), a.appendChild(c);
|
|
1130
1130
|
}
|
|
1131
|
-
|
|
1132
|
-
}), this.zonesContainer.replaceChildren(
|
|
1131
|
+
o.appendChild(a);
|
|
1132
|
+
}), this.zonesContainer.replaceChildren(o), this.updateZoneVisibility();
|
|
1133
1133
|
}
|
|
1134
|
-
groupPoints(
|
|
1135
|
-
const
|
|
1134
|
+
groupPoints(t) {
|
|
1135
|
+
const e = {
|
|
1136
1136
|
norte: [],
|
|
1137
1137
|
rm: [],
|
|
1138
1138
|
centro: [],
|
|
1139
1139
|
sur: []
|
|
1140
1140
|
};
|
|
1141
|
-
return
|
|
1142
|
-
|
|
1143
|
-
}),
|
|
1141
|
+
return t.forEach((o) => {
|
|
1142
|
+
e[o.zone].push(o);
|
|
1143
|
+
}), e;
|
|
1144
1144
|
}
|
|
1145
|
-
createPointCard(
|
|
1145
|
+
createPointCard(t) {
|
|
1146
1146
|
var b;
|
|
1147
|
-
const
|
|
1148
|
-
|
|
1149
|
-
const
|
|
1150
|
-
|
|
1147
|
+
const e = document.createElement("article");
|
|
1148
|
+
e.className = "point-card", e.dataset.pointId = String(t.id);
|
|
1149
|
+
const o = this.getPointCoordinateWarning(t), n = document.createElement("h3");
|
|
1150
|
+
n.className = "point-card__title", n.textContent = t.titulo || "Sin nombre", e.appendChild(n);
|
|
1151
1151
|
const a = document.createElement("div");
|
|
1152
1152
|
a.className = "point-card__address-block";
|
|
1153
1153
|
const s = document.createElement("p");
|
|
1154
|
-
if (s.className = "point-card__address", s.textContent =
|
|
1154
|
+
if (s.className = "point-card__address", s.textContent = t.direccion || "Sin direccion", a.appendChild(s), t.comuna_name) {
|
|
1155
1155
|
const r = document.createElement("p");
|
|
1156
|
-
r.className = "point-card__meta", r.textContent =
|
|
1156
|
+
r.className = "point-card__meta", r.textContent = t.comuna_name, a.appendChild(r);
|
|
1157
1157
|
}
|
|
1158
|
-
if (
|
|
1158
|
+
if (t.provincia_name) {
|
|
1159
1159
|
const r = document.createElement("p");
|
|
1160
|
-
r.className = "point-card__meta", r.textContent =
|
|
1160
|
+
r.className = "point-card__meta", r.textContent = t.provincia_name, a.appendChild(r);
|
|
1161
1161
|
}
|
|
1162
|
-
if (
|
|
1162
|
+
if (t.region_name) {
|
|
1163
1163
|
const r = document.createElement("p");
|
|
1164
|
-
r.className = "point-card__meta", r.textContent =
|
|
1164
|
+
r.className = "point-card__meta", r.textContent = t.region_name, a.appendChild(r);
|
|
1165
1165
|
}
|
|
1166
|
-
|
|
1166
|
+
e.appendChild(a);
|
|
1167
1167
|
let i = null;
|
|
1168
|
-
const
|
|
1169
|
-
if (
|
|
1168
|
+
const c = this.getPointPosition(t);
|
|
1169
|
+
if (c) {
|
|
1170
1170
|
const r = document.createElement("div");
|
|
1171
1171
|
r.className = "point-card__map-actions";
|
|
1172
1172
|
const u = document.createElement("button");
|
|
1173
1173
|
u.type = "button", u.className = "point-card__focus";
|
|
1174
1174
|
const g = this.createIconElement("fa-solid fa-location-crosshairs");
|
|
1175
1175
|
u.appendChild(g), u.appendChild(document.createTextNode(" Ver en el mapa")), u.addEventListener("click", () => {
|
|
1176
|
-
this.focusPointWithZoom(
|
|
1177
|
-
}), r.appendChild(u), r.appendChild(this.createMobileNavigationActions(
|
|
1178
|
-
} else if (
|
|
1176
|
+
this.focusPointWithZoom(c.lat, c.lng), this.scrollToPointCard(t.id);
|
|
1177
|
+
}), r.appendChild(u), r.appendChild(this.createMobileNavigationActions(c)), i = r;
|
|
1178
|
+
} else if (o) {
|
|
1179
1179
|
const r = document.createElement("div");
|
|
1180
1180
|
r.className = "point-card__coordinate-warning";
|
|
1181
1181
|
const u = this.createIconElement("fa-solid fa-circle-info");
|
|
1182
1182
|
r.appendChild(u);
|
|
1183
1183
|
const g = document.createElement("span");
|
|
1184
|
-
g.textContent =
|
|
1184
|
+
g.textContent = o, r.appendChild(g), i = r;
|
|
1185
1185
|
}
|
|
1186
|
-
const
|
|
1187
|
-
|
|
1186
|
+
const p = document.createElement("div");
|
|
1187
|
+
p.className = "point-card__details", p.hidden = !0;
|
|
1188
1188
|
let m = !1;
|
|
1189
1189
|
const h = document.createElement("div");
|
|
1190
1190
|
h.className = "point-card__actions";
|
|
1191
1191
|
let f = null;
|
|
1192
|
-
if (
|
|
1192
|
+
if (t.url && t.url !== "#") {
|
|
1193
1193
|
const r = document.createElement("a");
|
|
1194
|
-
r.href =
|
|
1194
|
+
r.href = t.url, r.target = "_blank", r.rel = "noopener noreferrer", r.className = "point-card__action";
|
|
1195
1195
|
const u = this.createIconElement("fa-solid fa-globe");
|
|
1196
1196
|
r.appendChild(u), r.appendChild(document.createTextNode("Sitio web")), h.appendChild(r);
|
|
1197
1197
|
}
|
|
1198
|
-
if (
|
|
1198
|
+
if (t.email) {
|
|
1199
1199
|
const r = document.createElement("a");
|
|
1200
|
-
r.href = `mailto:${
|
|
1200
|
+
r.href = `mailto:${t.email}`, r.target = "_blank", r.rel = "noopener noreferrer", r.className = "point-card__action point-card__action--text";
|
|
1201
1201
|
const u = this.createIconElement("fa-solid fa-envelope");
|
|
1202
|
-
r.appendChild(u), r.appendChild(document.createTextNode(
|
|
1202
|
+
r.appendChild(u), r.appendChild(document.createTextNode(t.email)), h.appendChild(r);
|
|
1203
1203
|
}
|
|
1204
|
-
if (h.childElementCount && (
|
|
1204
|
+
if (h.childElementCount && (p.appendChild(h), m = !0), (b = t.telefonos) != null && b.length) {
|
|
1205
1205
|
const r = document.createElement("div");
|
|
1206
1206
|
r.className = "point-card__contact";
|
|
1207
1207
|
const u = document.createElement("div");
|
|
1208
1208
|
u.className = "point-card__contact-title";
|
|
1209
1209
|
const g = this.createIconElement("fa-solid fa-phone");
|
|
1210
1210
|
u.appendChild(g), u.appendChild(document.createTextNode("Telefonos")), r.appendChild(u);
|
|
1211
|
-
const
|
|
1212
|
-
|
|
1211
|
+
const w = document.createElement("ul");
|
|
1212
|
+
w.className = "point-card__phone-list", t.telefonos.slice().sort((C, y) => C.orden - y.orden).forEach((C) => {
|
|
1213
1213
|
const y = document.createElement("li");
|
|
1214
1214
|
y.className = "point-card__phone-item";
|
|
1215
1215
|
const k = document.createElement("span");
|
|
1216
1216
|
k.className = "point-card__phone-icon";
|
|
1217
|
-
const
|
|
1218
|
-
if (
|
|
1217
|
+
const z = this.isWhatsappPhone(C);
|
|
1218
|
+
if (z) {
|
|
1219
1219
|
const B = this.createIconElement("fa-brands fa-whatsapp");
|
|
1220
1220
|
k.appendChild(B);
|
|
1221
1221
|
} else
|
|
@@ -1223,126 +1223,126 @@ const j = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAA
|
|
|
1223
1223
|
y.appendChild(k);
|
|
1224
1224
|
const S = document.createElement("div");
|
|
1225
1225
|
S.className = "point-card__phone-content";
|
|
1226
|
-
const
|
|
1227
|
-
|
|
1228
|
-
const
|
|
1229
|
-
if (
|
|
1230
|
-
const B = this.getWhatsappLink(
|
|
1231
|
-
B && (
|
|
1232
|
-
}
|
|
1233
|
-
|
|
1234
|
-
}), r.appendChild(
|
|
1226
|
+
const D = document.createElement("span");
|
|
1227
|
+
D.className = "point-card__phone-name", D.textContent = C.nombre, S.appendChild(D);
|
|
1228
|
+
const v = z ? document.createElement("a") : document.createElement("span");
|
|
1229
|
+
if (v.className = "point-card__phone-number", z) {
|
|
1230
|
+
const B = this.getWhatsappLink(C.telefono);
|
|
1231
|
+
B && (v.href = B, v.target = "_blank", v.rel = "noopener noreferrer", v.classList.add("point-card__phone-number--link"));
|
|
1232
|
+
}
|
|
1233
|
+
v.textContent = C.telefono, S.appendChild(v), y.appendChild(S), w.appendChild(y);
|
|
1234
|
+
}), r.appendChild(w), p.appendChild(r), m = !0;
|
|
1235
1235
|
}
|
|
1236
|
-
if (
|
|
1236
|
+
if (t.adicional) {
|
|
1237
1237
|
const r = document.createElement("p");
|
|
1238
|
-
r.className = "point-card__extra", r.innerHTML =
|
|
1238
|
+
r.className = "point-card__extra", r.innerHTML = t.adicional, r.querySelectorAll("a").forEach((u) => {
|
|
1239
1239
|
u.classList.add("point-card__extra-link");
|
|
1240
1240
|
const g = this.createIconElement("fa-solid fa-arrow-up-right-from-square");
|
|
1241
1241
|
g.classList.add("point-card__extra-icon"), u.appendChild(g);
|
|
1242
|
-
}),
|
|
1242
|
+
}), p.appendChild(r), m = !0;
|
|
1243
1243
|
}
|
|
1244
|
-
if (
|
|
1245
|
-
f = document.createElement("a"), f.href =
|
|
1244
|
+
if (t.googlelink) {
|
|
1245
|
+
f = document.createElement("a"), f.href = t.googlelink, f.target = "_blank", f.rel = "noopener noreferrer", f.className = "point-card__action";
|
|
1246
1246
|
const r = this.createIconElement("fa-solid fa-map-location-dot");
|
|
1247
1247
|
f.appendChild(r), f.appendChild(document.createTextNode("Google Maps"));
|
|
1248
1248
|
}
|
|
1249
1249
|
if (f) {
|
|
1250
1250
|
const r = document.createElement("div");
|
|
1251
|
-
r.className = "point-card__actions", r.appendChild(f),
|
|
1251
|
+
r.className = "point-card__actions", r.appendChild(f), p.appendChild(r), m = !0;
|
|
1252
1252
|
}
|
|
1253
1253
|
if (m) {
|
|
1254
1254
|
const r = document.createElement("button");
|
|
1255
1255
|
r.type = "button", r.className = "point-card__toggle";
|
|
1256
1256
|
const u = this.createIconElement("fa-solid fa-circle-info"), g = document.createElement("span");
|
|
1257
1257
|
g.textContent = "Mas informacion", r.appendChild(u), r.appendChild(g), r.addEventListener("click", () => {
|
|
1258
|
-
const
|
|
1259
|
-
|
|
1260
|
-
}),
|
|
1258
|
+
const w = p.hidden;
|
|
1259
|
+
p.hidden = !w, g.textContent = w ? "Ocultar informacion" : "Mas informacion", u.className = w ? "fa-solid fa-circle-xmark" : "fa-solid fa-circle-info";
|
|
1260
|
+
}), e.appendChild(r), e.appendChild(p);
|
|
1261
1261
|
}
|
|
1262
|
-
return i &&
|
|
1262
|
+
return i && e.appendChild(i), e;
|
|
1263
1263
|
}
|
|
1264
|
-
createMobileNavigationActions(
|
|
1265
|
-
const
|
|
1266
|
-
return
|
|
1264
|
+
createMobileNavigationActions(t) {
|
|
1265
|
+
const e = document.createElement("div");
|
|
1266
|
+
return e.className = "point-card__mobile-navigation", e.appendChild(
|
|
1267
1267
|
this.createMobileNavigationLink(
|
|
1268
|
-
`https://www.google.com/maps/dir/?api=1&destination=${
|
|
1268
|
+
`https://www.google.com/maps/dir/?api=1&destination=${t.lat},${t.lng}&travelmode=driving`,
|
|
1269
1269
|
"Ir con Google Maps",
|
|
1270
1270
|
"fa-brands fa-google"
|
|
1271
1271
|
)
|
|
1272
|
-
),
|
|
1272
|
+
), e.appendChild(
|
|
1273
1273
|
this.createMobileNavigationLink(
|
|
1274
|
-
`https://waze.com/ul?ll=${
|
|
1274
|
+
`https://waze.com/ul?ll=${t.lat},${t.lng}&navigate=yes`,
|
|
1275
1275
|
"Ir con Waze",
|
|
1276
1276
|
"fa-brands fa-waze"
|
|
1277
1277
|
)
|
|
1278
|
-
),
|
|
1278
|
+
), e;
|
|
1279
1279
|
}
|
|
1280
|
-
createMobileNavigationLink(
|
|
1281
|
-
const
|
|
1282
|
-
return
|
|
1280
|
+
createMobileNavigationLink(t, e, o) {
|
|
1281
|
+
const n = document.createElement("a");
|
|
1282
|
+
return n.href = t, n.target = "_blank", n.rel = "noopener noreferrer", n.className = "point-card__mobile-nav-link", n.appendChild(this.createIconElement(o)), n.appendChild(document.createTextNode(e)), n;
|
|
1283
1283
|
}
|
|
1284
|
-
getZoneForPoint(
|
|
1285
|
-
const
|
|
1286
|
-
return
|
|
1284
|
+
getZoneForPoint(t) {
|
|
1285
|
+
const e = this.normalizeRegionName(t.region_name || "");
|
|
1286
|
+
return e && e in W ? W[e] : e.includes("metropolitana") ? "rm" : e.includes("araucania") || e.includes("rios") || e.includes("lagos") || e.includes("aysen") || e.includes("magallanes") ? "sur" : e.includes("arica") || e.includes("tarapaca") || e.includes("antofagasta") || e.includes("atacama") || e.includes("coquimbo") ? "norte" : "centro";
|
|
1287
1287
|
}
|
|
1288
|
-
normalizeRegionName(
|
|
1289
|
-
return
|
|
1288
|
+
normalizeRegionName(t) {
|
|
1289
|
+
return t.toLowerCase().normalize("NFD").replace(/[\u0300-\u036f]/g, "").trim();
|
|
1290
1290
|
}
|
|
1291
1291
|
getMarcaRequestValue() {
|
|
1292
|
-
var
|
|
1293
|
-
const
|
|
1294
|
-
return (
|
|
1292
|
+
var e;
|
|
1293
|
+
const t = this.normalizeBrandToken(this.marca);
|
|
1294
|
+
return (e = H[t]) != null ? e : this.marca;
|
|
1295
1295
|
}
|
|
1296
|
-
normalizeBrandKey(
|
|
1297
|
-
var
|
|
1298
|
-
const
|
|
1299
|
-
return
|
|
1296
|
+
normalizeBrandKey(t) {
|
|
1297
|
+
var o;
|
|
1298
|
+
const e = this.normalizeBrandToken(t);
|
|
1299
|
+
return e ? (o = H[e]) != null ? o : e : "default";
|
|
1300
1300
|
}
|
|
1301
|
-
normalizeBrandToken(
|
|
1302
|
-
return
|
|
1301
|
+
normalizeBrandToken(t) {
|
|
1302
|
+
return t.toLowerCase().normalize("NFD").replace(/[\u0300-\u036f]/g, "").replace(/[^a-z0-9]+/g, "");
|
|
1303
1303
|
}
|
|
1304
|
-
getMarkerIcon(
|
|
1305
|
-
const
|
|
1306
|
-
return
|
|
1304
|
+
getMarkerIcon(t) {
|
|
1305
|
+
const e = this.marcaKey || "default", o = this.getLocalMarkerIconUrl(e, t);
|
|
1306
|
+
return o || (this.markerIconBaseUrl ? `${this.markerIconBaseUrl}${e}.png` : this.defaultMarkerIconUrl ? this.defaultMarkerIconUrl : null);
|
|
1307
1307
|
}
|
|
1308
|
-
getLocalMarkerIconUrl(
|
|
1308
|
+
getLocalMarkerIconUrl(t, e) {
|
|
1309
1309
|
var s;
|
|
1310
|
-
const
|
|
1311
|
-
return (s =
|
|
1310
|
+
const o = e ? Number(e.tipo) : NaN, a = (Number.isFinite(o) ? o : this.tipoCode) === 1 ? `${t}_distribuidor.png` : `${t}.png`;
|
|
1311
|
+
return (s = rt[`../pin/${a}`]) != null ? s : null;
|
|
1312
1312
|
}
|
|
1313
|
-
getPointCoordinateWarning(
|
|
1314
|
-
if (this.getPointPosition(
|
|
1313
|
+
getPointCoordinateWarning(t) {
|
|
1314
|
+
if (this.getPointPosition(t))
|
|
1315
1315
|
return null;
|
|
1316
|
-
const
|
|
1317
|
-
return !Number.isFinite(
|
|
1316
|
+
const e = Number(t.lat), o = Number(t.lng), n = `lat ${t.lat || "sin dato"}, lng ${t.lng || "sin dato"}`;
|
|
1317
|
+
return !Number.isFinite(e) || !Number.isFinite(o) ? `Ubicacion por revisar: ${n}.` : `Ubicacion por revisar: ${n}.`;
|
|
1318
1318
|
}
|
|
1319
|
-
getPointPosition(
|
|
1320
|
-
const
|
|
1321
|
-
return this.isMappableCoordinate(
|
|
1319
|
+
getPointPosition(t) {
|
|
1320
|
+
const e = Number(t.lat), o = Number(t.lng);
|
|
1321
|
+
return this.isMappableCoordinate(e, o) ? { lat: e, lng: o } : null;
|
|
1322
1322
|
}
|
|
1323
|
-
isMappableCoordinate(
|
|
1324
|
-
return Number.isFinite(
|
|
1323
|
+
isMappableCoordinate(t, e) {
|
|
1324
|
+
return Number.isFinite(t) && Number.isFinite(e) && t >= L.minLat && t <= L.maxLat && e >= L.minLng && e <= L.maxLng;
|
|
1325
1325
|
}
|
|
1326
|
-
updateMarkers(
|
|
1327
|
-
const
|
|
1328
|
-
if (!
|
|
1326
|
+
updateMarkers(t) {
|
|
1327
|
+
const e = window.google;
|
|
1328
|
+
if (!e || !this.map)
|
|
1329
1329
|
return;
|
|
1330
1330
|
this.markers.forEach((a) => a.setMap(null)), this.markers = [];
|
|
1331
|
-
const
|
|
1332
|
-
if (
|
|
1331
|
+
const o = [];
|
|
1332
|
+
if (t.forEach((a) => {
|
|
1333
1333
|
const s = this.getPointPosition(a);
|
|
1334
|
-
s &&
|
|
1335
|
-
}), !
|
|
1334
|
+
s && o.push({ point: a, position: s });
|
|
1335
|
+
}), !o.length)
|
|
1336
1336
|
return;
|
|
1337
|
-
const
|
|
1338
|
-
if (
|
|
1339
|
-
const { lat: i, lng:
|
|
1340
|
-
url:
|
|
1341
|
-
scaledSize: new
|
|
1342
|
-
anchor: new
|
|
1343
|
-
} : void 0, h = new
|
|
1337
|
+
const n = new e.maps.LatLngBounds();
|
|
1338
|
+
if (o.forEach(({ point: a, position: s }) => {
|
|
1339
|
+
const { lat: i, lng: c } = s, p = this.getMarkerIcon(a), m = p && this.map ? {
|
|
1340
|
+
url: p,
|
|
1341
|
+
scaledSize: new e.maps.Size(64, 64),
|
|
1342
|
+
anchor: new e.maps.Point(32, 64)
|
|
1343
|
+
} : void 0, h = new e.maps.Marker({
|
|
1344
1344
|
map: this.map,
|
|
1345
|
-
position: { lat: i, lng:
|
|
1345
|
+
position: { lat: i, lng: c },
|
|
1346
1346
|
title: a.titulo,
|
|
1347
1347
|
icon: m
|
|
1348
1348
|
});
|
|
@@ -1350,7 +1350,7 @@ const j = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAA
|
|
|
1350
1350
|
this.openPointModal(a), this.scrollToPointCard(a.id);
|
|
1351
1351
|
}), this.markers.push(h);
|
|
1352
1352
|
const f = h.getPosition();
|
|
1353
|
-
f &&
|
|
1353
|
+
f && n.extend(f);
|
|
1354
1354
|
}), !this.initialViewApplied && this.markers.length) {
|
|
1355
1355
|
const a = this.markers[0].getPosition();
|
|
1356
1356
|
if (a) {
|
|
@@ -1362,194 +1362,194 @@ const j = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAA
|
|
|
1362
1362
|
const a = this.markers[0].getPosition();
|
|
1363
1363
|
a && this.map.setCenter(a), this.map.setZoom(14);
|
|
1364
1364
|
} else
|
|
1365
|
-
this.map.fitBounds(
|
|
1365
|
+
this.map.fitBounds(n);
|
|
1366
1366
|
}
|
|
1367
|
-
openPointModal(
|
|
1368
|
-
var
|
|
1369
|
-
!this.pointModalOverlayEl || !this.pointModalTitleEl || !this.pointModalBodyEl || (this.pointModalTitleEl.textContent =
|
|
1367
|
+
openPointModal(t) {
|
|
1368
|
+
var e;
|
|
1369
|
+
!this.pointModalOverlayEl || !this.pointModalTitleEl || !this.pointModalBodyEl || (this.pointModalTitleEl.textContent = t.titulo || "Sin nombre", this.pointModalBodyEl.replaceChildren(this.createPointModalContent(t)), this.pointModalOverlayEl.removeAttribute("hidden"), (e = this.pointModalCloseButton) == null || e.focus());
|
|
1370
1370
|
}
|
|
1371
|
-
createPointModalContent(
|
|
1371
|
+
createPointModalContent(t) {
|
|
1372
1372
|
var s;
|
|
1373
|
-
const
|
|
1374
|
-
if (
|
|
1373
|
+
const e = document.createDocumentFragment();
|
|
1374
|
+
if (t.portada) {
|
|
1375
1375
|
const i = document.createElement("img");
|
|
1376
|
-
i.className = "point-modal__cover", i.src =
|
|
1376
|
+
i.className = "point-modal__cover", i.src = t.portada, i.alt = t.titulo || "Imagen del punto", i.loading = "lazy", i.addEventListener("error", () => i.remove(), { once: !0 }), e.appendChild(i);
|
|
1377
1377
|
}
|
|
1378
|
-
const n = this.createPointModalSection();
|
|
1379
|
-
this.appendPointModalLine(n, "Direccion", e.direccion), this.appendPointModalLine(n, "Comuna", e.comuna_name), this.appendPointModalLine(n, "Provincia", e.provincia_name), this.appendPointModalLine(n, "Region", e.region_name), this.appendPointModalLine(n, "RUT", e.rut), n.childElementCount && t.appendChild(n);
|
|
1380
1378
|
const o = this.createPointModalSection();
|
|
1381
|
-
|
|
1379
|
+
this.appendPointModalLine(o, "Direccion", t.direccion), this.appendPointModalLine(o, "Comuna", t.comuna_name), this.appendPointModalLine(o, "Provincia", t.provincia_name), this.appendPointModalLine(o, "Region", t.region_name), this.appendPointModalLine(o, "RUT", t.rut), o.childElementCount && e.appendChild(o);
|
|
1380
|
+
const n = this.createPointModalSection();
|
|
1381
|
+
if (this.appendPointModalLine(n, "Correo", t.email), (s = t.telefonos) != null && s.length) {
|
|
1382
1382
|
const i = document.createElement("p");
|
|
1383
1383
|
i.className = "point-modal__line";
|
|
1384
|
-
const
|
|
1385
|
-
|
|
1386
|
-
const
|
|
1387
|
-
|
|
1388
|
-
|
|
1389
|
-
}),
|
|
1384
|
+
const c = document.createElement("span");
|
|
1385
|
+
c.className = "point-modal__label", c.textContent = "Telefonos:", i.appendChild(c), n.appendChild(i);
|
|
1386
|
+
const p = document.createElement("ul");
|
|
1387
|
+
p.className = "point-modal__phone-list", t.telefonos.slice().sort((m, h) => m.orden - h.orden).forEach((m) => {
|
|
1388
|
+
p.appendChild(this.createPointModalPhoneItem(m));
|
|
1389
|
+
}), n.appendChild(p);
|
|
1390
1390
|
}
|
|
1391
|
-
if (
|
|
1392
|
-
const i = this.createPointModalSection(),
|
|
1393
|
-
|
|
1394
|
-
|
|
1395
|
-
}), i.appendChild(
|
|
1391
|
+
if (n.childElementCount && e.appendChild(n), t.adicional) {
|
|
1392
|
+
const i = this.createPointModalSection(), c = document.createElement("div");
|
|
1393
|
+
c.className = "point-modal__extra", c.innerHTML = t.adicional, c.querySelectorAll("a").forEach((p) => {
|
|
1394
|
+
p.target = "_blank", p.rel = "noopener noreferrer";
|
|
1395
|
+
}), i.appendChild(c), e.appendChild(i);
|
|
1396
1396
|
}
|
|
1397
|
-
const a = this.createPointModalActions(
|
|
1398
|
-
return a.childElementCount &&
|
|
1397
|
+
const a = this.createPointModalActions(t);
|
|
1398
|
+
return a.childElementCount && e.appendChild(a), e;
|
|
1399
1399
|
}
|
|
1400
1400
|
createPointModalSection() {
|
|
1401
|
-
const
|
|
1402
|
-
return
|
|
1401
|
+
const t = document.createElement("div");
|
|
1402
|
+
return t.className = "point-modal__section", t;
|
|
1403
1403
|
}
|
|
1404
|
-
appendPointModalLine(
|
|
1405
|
-
const
|
|
1406
|
-
if (!
|
|
1404
|
+
appendPointModalLine(t, e, o) {
|
|
1405
|
+
const n = (o != null ? o : "").trim();
|
|
1406
|
+
if (!n || n === "#")
|
|
1407
1407
|
return;
|
|
1408
1408
|
const a = document.createElement("p");
|
|
1409
1409
|
a.className = "point-modal__line";
|
|
1410
1410
|
const s = document.createElement("span");
|
|
1411
|
-
s.className = "point-modal__label", s.textContent = `${
|
|
1411
|
+
s.className = "point-modal__label", s.textContent = `${e}: `, a.appendChild(s), a.appendChild(document.createTextNode(n)), t.appendChild(a);
|
|
1412
1412
|
}
|
|
1413
|
-
createPointModalPhoneItem(
|
|
1413
|
+
createPointModalPhoneItem(t) {
|
|
1414
1414
|
var s;
|
|
1415
|
-
const
|
|
1416
|
-
|
|
1417
|
-
const
|
|
1418
|
-
|
|
1419
|
-
const
|
|
1415
|
+
const e = document.createElement("li");
|
|
1416
|
+
e.className = "point-modal__phone-item";
|
|
1417
|
+
const o = document.createElement("span");
|
|
1418
|
+
o.className = "point-modal__label", o.textContent = `${t.nombre || "Telefono"}: `, e.appendChild(o);
|
|
1419
|
+
const n = ((s = t.telefono) != null ? s : "").trim(), a = this.isWhatsappPhone(t) ? this.getWhatsappLink(n) : null;
|
|
1420
1420
|
if (a) {
|
|
1421
1421
|
const i = document.createElement("a");
|
|
1422
|
-
i.href = a, i.target = "_blank", i.rel = "noopener noreferrer", i.className = "point-modal__link", i.textContent =
|
|
1422
|
+
i.href = a, i.target = "_blank", i.rel = "noopener noreferrer", i.className = "point-modal__link", i.textContent = n, e.appendChild(i);
|
|
1423
1423
|
} else
|
|
1424
|
-
|
|
1425
|
-
return
|
|
1424
|
+
e.appendChild(document.createTextNode(n));
|
|
1425
|
+
return e;
|
|
1426
1426
|
}
|
|
1427
|
-
createPointModalActions(
|
|
1428
|
-
const
|
|
1429
|
-
return
|
|
1427
|
+
createPointModalActions(t) {
|
|
1428
|
+
const e = document.createElement("div");
|
|
1429
|
+
return e.className = "point-modal__section point-modal__actions", t.url && t.url !== "#" && e.appendChild(this.createPointModalLink(t.url, "Sitio web", !0, "fa-solid fa-globe")), t.googlelink && e.appendChild(this.createPointModalLink(t.googlelink, "Google Maps")), t.email && e.appendChild(this.createPointModalLink(`mailto:${t.email}`, "Enviar correo", !1, "fa-solid fa-envelope")), e;
|
|
1430
1430
|
}
|
|
1431
|
-
createPointModalLink(
|
|
1431
|
+
createPointModalLink(t, e, o = !0, n) {
|
|
1432
1432
|
const a = document.createElement("a");
|
|
1433
|
-
return a.href =
|
|
1433
|
+
return a.href = t, a.className = "point-modal__link", n && a.appendChild(this.createIconElement(n)), a.appendChild(document.createTextNode(e)), o && (a.target = "_blank", a.rel = "noopener noreferrer"), a;
|
|
1434
1434
|
}
|
|
1435
|
-
setActiveZone(
|
|
1435
|
+
setActiveZone(t) {
|
|
1436
1436
|
}
|
|
1437
|
-
scrollToZoneSection(
|
|
1437
|
+
scrollToZoneSection(t) {
|
|
1438
1438
|
if (!this.zonesContainer)
|
|
1439
1439
|
return;
|
|
1440
|
-
const
|
|
1441
|
-
|
|
1440
|
+
const e = this.zonesContainer.querySelector(`[data-zone-section="${t}"]`);
|
|
1441
|
+
e && e.scrollIntoView({ behavior: "smooth", block: "start" });
|
|
1442
1442
|
}
|
|
1443
1443
|
updateZoneButtons() {
|
|
1444
|
-
this.zoneButtons.forEach((
|
|
1445
|
-
const
|
|
1446
|
-
|
|
1444
|
+
this.zoneButtons.forEach((t) => {
|
|
1445
|
+
const e = t.dataset.zone, o = this.activeZone === e;
|
|
1446
|
+
t.classList.toggle("is-active", o), t.setAttribute("aria-pressed", String(o));
|
|
1447
1447
|
});
|
|
1448
1448
|
}
|
|
1449
1449
|
updateZoneButtonCounts() {
|
|
1450
|
-
this.zoneButtons.forEach((
|
|
1451
|
-
|
|
1452
|
-
const
|
|
1453
|
-
|
|
1450
|
+
this.zoneButtons.forEach((t) => {
|
|
1451
|
+
t.dataset.zone;
|
|
1452
|
+
const e = t.dataset.label || t.textContent || "";
|
|
1453
|
+
t.textContent = e;
|
|
1454
1454
|
});
|
|
1455
1455
|
}
|
|
1456
1456
|
updateZoneVisibility() {
|
|
1457
1457
|
if (!this.zonesContainer)
|
|
1458
1458
|
return;
|
|
1459
|
-
this.zonesContainer.querySelectorAll("[data-zone-section]").forEach((
|
|
1460
|
-
|
|
1459
|
+
this.zonesContainer.querySelectorAll("[data-zone-section]").forEach((e) => {
|
|
1460
|
+
e.removeAttribute("hidden");
|
|
1461
1461
|
});
|
|
1462
1462
|
}
|
|
1463
|
-
findNearestPoint(
|
|
1463
|
+
findNearestPoint(t, e) {
|
|
1464
1464
|
if (!this.points.length)
|
|
1465
1465
|
return null;
|
|
1466
|
-
let
|
|
1466
|
+
let o = null, n = 1 / 0;
|
|
1467
1467
|
return this.points.forEach((a) => {
|
|
1468
1468
|
const s = this.getPointPosition(a);
|
|
1469
1469
|
if (!s)
|
|
1470
1470
|
return;
|
|
1471
|
-
const i = this.haversine(
|
|
1472
|
-
i <
|
|
1473
|
-
}),
|
|
1471
|
+
const i = this.haversine(t, e, s.lat, s.lng);
|
|
1472
|
+
i < n && (n = i, o = a);
|
|
1473
|
+
}), o;
|
|
1474
1474
|
}
|
|
1475
|
-
haversine(e,
|
|
1476
|
-
const a = (h) => h * Math.PI / 180, i = a(
|
|
1477
|
-
return 6371e3 * (2 * Math.atan2(Math.sqrt(
|
|
1475
|
+
haversine(t, e, o, n) {
|
|
1476
|
+
const a = (h) => h * Math.PI / 180, i = a(o - t), c = a(n - e), p = Math.sin(i / 2) * Math.sin(i / 2) + Math.cos(a(t)) * Math.cos(a(o)) * Math.sin(c / 2) * Math.sin(c / 2);
|
|
1477
|
+
return 6371e3 * (2 * Math.atan2(Math.sqrt(p), Math.sqrt(1 - p)));
|
|
1478
1478
|
}
|
|
1479
|
-
scrollToPointCard(
|
|
1479
|
+
scrollToPointCard(t) {
|
|
1480
1480
|
if (!this.zonesContainer)
|
|
1481
1481
|
return;
|
|
1482
|
-
const
|
|
1483
|
-
|
|
1484
|
-
}
|
|
1485
|
-
highlightPointCard(
|
|
1486
|
-
var
|
|
1487
|
-
this.highlightTimeout !== null && (clearTimeout(this.highlightTimeout), this.highlightTimeout = null), (
|
|
1488
|
-
|
|
1489
|
-
}),
|
|
1490
|
-
|
|
1482
|
+
const e = this.zonesContainer.querySelector(`[data-point-id="${t}"]`);
|
|
1483
|
+
e && (e.scrollIntoView({ behavior: "smooth", block: "center" }), this.highlightPointCard(e));
|
|
1484
|
+
}
|
|
1485
|
+
highlightPointCard(t) {
|
|
1486
|
+
var e;
|
|
1487
|
+
this.highlightTimeout !== null && (clearTimeout(this.highlightTimeout), this.highlightTimeout = null), (e = this.zonesContainer) == null || e.querySelectorAll(".point-card--highlight").forEach((o) => {
|
|
1488
|
+
o.classList.remove("point-card--highlight");
|
|
1489
|
+
}), t.classList.add("point-card--highlight"), this.highlightTimeout = window.setTimeout(() => {
|
|
1490
|
+
t.classList.remove("point-card--highlight"), this.highlightTimeout = null;
|
|
1491
1491
|
}, 3500);
|
|
1492
1492
|
}
|
|
1493
|
-
setComponentState(
|
|
1493
|
+
setComponentState(t) {
|
|
1494
1494
|
if (!(!this.componentMessageEl || !this.mapLayoutEl))
|
|
1495
|
-
if (
|
|
1495
|
+
if (t === "ready")
|
|
1496
1496
|
this.componentMessageEl.setAttribute("hidden", ""), this.mapLayoutEl.removeAttribute("hidden");
|
|
1497
1497
|
else {
|
|
1498
|
-
const
|
|
1499
|
-
this.componentMessageEl.textContent =
|
|
1498
|
+
const e = t === "loading" ? "Cargando puntos..." : "Mapa temporalmente no disponible";
|
|
1499
|
+
this.componentMessageEl.textContent = e, this.componentMessageEl.removeAttribute("hidden"), this.mapLayoutEl.setAttribute("hidden", "");
|
|
1500
1500
|
}
|
|
1501
1501
|
}
|
|
1502
|
-
centerMapOnPoint(
|
|
1503
|
-
if (!window.google || !this.map || !Number.isFinite(
|
|
1502
|
+
centerMapOnPoint(t, e, o = 14) {
|
|
1503
|
+
if (!window.google || !this.map || !Number.isFinite(t) || !Number.isFinite(e))
|
|
1504
1504
|
return;
|
|
1505
|
-
const a = typeof this.map.getZoom == "function" ? this.map.getZoom() : null, s = !a || a <
|
|
1506
|
-
this.animateMapPan(
|
|
1507
|
-
s && this.map.setZoom(
|
|
1505
|
+
const a = typeof this.map.getZoom == "function" ? this.map.getZoom() : null, s = !a || a < o;
|
|
1506
|
+
this.animateMapPan(t, e, () => {
|
|
1507
|
+
s && this.map.setZoom(o);
|
|
1508
1508
|
});
|
|
1509
1509
|
}
|
|
1510
|
-
async focusPointWithZoom(
|
|
1511
|
-
!window.google || !this.map || !Number.isFinite(
|
|
1512
|
-
this.animateMapPan(
|
|
1510
|
+
async focusPointWithZoom(t, e) {
|
|
1511
|
+
!window.google || !this.map || !Number.isFinite(t) || !Number.isFinite(e) || (await this.animateZoomTo(8, 800), await this.wait(500), await new Promise((n) => {
|
|
1512
|
+
this.animateMapPan(t, e, n);
|
|
1513
1513
|
}), await this.wait(500), await this.animateZoomTo(18, 800));
|
|
1514
1514
|
}
|
|
1515
|
-
wait(
|
|
1516
|
-
return new Promise((
|
|
1517
|
-
window.setTimeout(
|
|
1515
|
+
wait(t) {
|
|
1516
|
+
return new Promise((e) => {
|
|
1517
|
+
window.setTimeout(e, t);
|
|
1518
1518
|
});
|
|
1519
1519
|
}
|
|
1520
|
-
async animateZoomTo(
|
|
1520
|
+
async animateZoomTo(t, e = 600) {
|
|
1521
1521
|
if (!window.google || !this.map || typeof this.map.getZoom != "function" || typeof this.map.setZoom != "function")
|
|
1522
1522
|
return;
|
|
1523
|
-
const
|
|
1524
|
-
if (!Number.isFinite(
|
|
1525
|
-
this.map.setZoom(
|
|
1523
|
+
const n = this.map.getZoom();
|
|
1524
|
+
if (!Number.isFinite(n)) {
|
|
1525
|
+
this.map.setZoom(t);
|
|
1526
1526
|
return;
|
|
1527
1527
|
}
|
|
1528
|
-
const a =
|
|
1528
|
+
const a = t - n;
|
|
1529
1529
|
if (Math.abs(a) < 0.01) {
|
|
1530
|
-
this.map.setZoom(
|
|
1530
|
+
this.map.setZoom(t);
|
|
1531
1531
|
return;
|
|
1532
1532
|
}
|
|
1533
1533
|
await new Promise((s) => {
|
|
1534
|
-
const i = performance.now(),
|
|
1535
|
-
const h = m - i, f = Math.min(h /
|
|
1536
|
-
this.map.setZoom(Math.round(r * 100) / 100), f < 1 ? requestAnimationFrame(
|
|
1534
|
+
const i = performance.now(), c = (m) => 1 - Math.pow(1 - m, 3), p = (m) => {
|
|
1535
|
+
const h = m - i, f = Math.min(h / e, 1), b = c(f), r = n + a * b;
|
|
1536
|
+
this.map.setZoom(Math.round(r * 100) / 100), f < 1 ? requestAnimationFrame(p) : (this.map.setZoom(t), s());
|
|
1537
1537
|
};
|
|
1538
|
-
requestAnimationFrame(
|
|
1538
|
+
requestAnimationFrame(p);
|
|
1539
1539
|
});
|
|
1540
1540
|
}
|
|
1541
|
-
animateMapPan(
|
|
1541
|
+
animateMapPan(t, e, o) {
|
|
1542
1542
|
if (!window.google || !this.map)
|
|
1543
1543
|
return;
|
|
1544
1544
|
this.panAnimationFrame !== null && (cancelAnimationFrame(this.panAnimationFrame), this.panAnimationFrame = null);
|
|
1545
1545
|
const a = this.map.getCenter();
|
|
1546
1546
|
if (!a) {
|
|
1547
|
-
this.map.setCenter({ lat:
|
|
1547
|
+
this.map.setCenter({ lat: t, lng: e }), o == null || o();
|
|
1548
1548
|
return;
|
|
1549
1549
|
}
|
|
1550
|
-
const s = a.lat(), i = a.lng(),
|
|
1551
|
-
const u = r - h, g = Math.min(u / m, 1),
|
|
1552
|
-
this.map.setCenter({ lat:
|
|
1550
|
+
const s = a.lat(), i = a.lng(), c = t - s, p = e - i, m = 600, h = performance.now(), f = (r) => 1 - Math.pow(1 - r, 3), b = (r) => {
|
|
1551
|
+
const u = r - h, g = Math.min(u / m, 1), w = f(g), C = s + c * w, y = i + p * w;
|
|
1552
|
+
this.map.setCenter({ lat: C, lng: y }), g < 1 ? this.panAnimationFrame = requestAnimationFrame(b) : (this.panAnimationFrame = null, o == null || o());
|
|
1553
1553
|
};
|
|
1554
1554
|
this.panAnimationFrame = requestAnimationFrame(b);
|
|
1555
1555
|
}
|
|
@@ -1560,52 +1560,52 @@ const j = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAYAAACqaXHeAAA
|
|
|
1560
1560
|
A.fontAwesomeAttached = !0;
|
|
1561
1561
|
return;
|
|
1562
1562
|
}
|
|
1563
|
-
const
|
|
1564
|
-
|
|
1563
|
+
const e = document.createElement("link");
|
|
1564
|
+
e.rel = "stylesheet", e.href = U, e.crossOrigin = "anonymous", e.referrerPolicy = "no-referrer", e.addEventListener("load", () => {
|
|
1565
1565
|
A.fontAwesomeAttached = !0;
|
|
1566
|
-
}), document.head.appendChild(
|
|
1566
|
+
}), document.head.appendChild(e);
|
|
1567
1567
|
}
|
|
1568
|
-
createIconElement(
|
|
1569
|
-
const
|
|
1570
|
-
return
|
|
1568
|
+
createIconElement(t) {
|
|
1569
|
+
const e = document.createElement("i");
|
|
1570
|
+
return e.className = t, e.setAttribute("aria-hidden", "true"), e;
|
|
1571
1571
|
}
|
|
1572
|
-
isWhatsappPhone(
|
|
1573
|
-
return !!(
|
|
1572
|
+
isWhatsappPhone(t) {
|
|
1573
|
+
return !!(t.whatsapp || t.watshapp);
|
|
1574
1574
|
}
|
|
1575
|
-
getWhatsappLink(
|
|
1576
|
-
const
|
|
1577
|
-
return
|
|
1575
|
+
getWhatsappLink(t) {
|
|
1576
|
+
const e = t.replace(/\D+/g, "");
|
|
1577
|
+
return e ? `https://wa.me/${e}` : null;
|
|
1578
1578
|
}
|
|
1579
1579
|
};
|
|
1580
|
-
|
|
1580
|
+
l(A, "tag", "rs-map"), l(A, "googleMapsLoaderPromise", null), l(A, "pointsCacheDbPromise", null), l(A, "fontAwesomeAttached", !1);
|
|
1581
1581
|
let I = A;
|
|
1582
|
-
const
|
|
1582
|
+
const ht = `<?xml version="1.0" encoding="utf-8"?>\r
|
|
1583
1583
|
<!-- Svg Vector Icons : http://www.onlinewebfonts.com/icon -->\r
|
|
1584
1584
|
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">\r
|
|
1585
1585
|
<svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" viewBox="0 0 1000 1000" enable-background="new 0 0 1000 1000" xml:space="preserve" style="fill: #ffffff;">\r
|
|
1586
1586
|
<metadata> Svg Vector Icons : http://www.onlinewebfonts.com/icon </metadata>\r
|
|
1587
1587
|
<g><path d="M965.1,437.2c-24.9-8.4-52.2-8.7-78.1-13.5c-41.3-8.3-45.5-55.5-61.6-87c-17.4-27.9-1.8-58.7,17.9-80.2c16.7-22.2,45.4-50.8,21.8-78.9c-22.1-17.9-37.3-48.8-67.4-53.1c-30.2,2.7-50,30-74.7,45.2c-33.8,26.5-71.6-3.8-105.1-14.8c-30.2-6.9-45.2-36.2-45.6-65.2c-5.5-27.6-1.1-66.3-34.8-76.6c-36.1-3.3-99-13.6-104.1,37.7c-7.8,33.8-0.3,78.4-36.1,97.9c-30.8,10.5-59.5,30.1-92.3,31.9c-38.2-5.7-59.8-46-96.2-55.8c-32.6-2.2-48.3,31.8-70.7,49.7c-23.6,20.9-7.6,51.7,9.9,70.3c18.9,24.9,47.2,54.4,28.4,87.8c-16.4,31.3-19.6,75.8-57,89.7c-29.6,7.7-62.6,3.9-89.8,18.5c-25.6,30-28.1,94.8,5.4,120.4c36.3,14.9,84.8,0.8,111.7,35.3c13.3,29.6,28.4,59.5,35.6,91.1c-0.7,43.9-48.4,67.1-58.2,107.8c9.5,38.8,52.5,81.3,96.4,74.3c33.2-16.3,57.3-56.9,98.4-51.3c30.2,11.8,62.2,21.7,89.5,39.2c29.7,30.2,13.4,78.3,33.4,112.9c29.9,25.7,94.7,28.3,120.1-5.4c14.8-36.3,0.9-84.9,35.2-111.8c29.5-13.3,59.5-28.4,91-35.6c42.3,0,64.7,46,103.3,56c32.5,2.2,48.3-31.8,70.7-49.7c24.5-22.1,6.1-53.2-11.6-72.5c-18.9-24-45-53.3-26.7-85.6c16.4-31.3,19.6-75.7,57-89.6c29.6-7.7,62.6-4,89.8-18.5C996.1,527.5,998.6,462.7,965.1,437.2z M577.6,593.4c-21.6,18-49.5,28-77.5,27.9c-79.1,3-142.8-83.6-116.4-158.4c20.6-76,121.1-111.4,184.6-64.9C634.9,439.4,640,545.6,577.6,593.4z"/></g>\r
|
|
1588
|
-
</svg>`,
|
|
1588
|
+
</svg>`, mt = `<?xml version="1.0" encoding="utf-8"?>\r
|
|
1589
1589
|
<!-- Svg Vector Icons : http://www.onlinewebfonts.com/icon -->\r
|
|
1590
1590
|
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">\r
|
|
1591
1591
|
<svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" viewBox="0 0 1000 1000" enable-background="new 0 0 1000 1000" xml:space="preserve" style="fill: #ffffff;">\r
|
|
1592
1592
|
<metadata> Svg Vector Icons : http://www.onlinewebfonts.com/icon </metadata>\r
|
|
1593
1593
|
<g><g><g><path d="M171.2,451.6c-89,0-161.2,72.2-161.2,161.2c0,89,72.2,161.2,161.2,161.2c65,0,120.9-38.6,146.4-94l38.3,29.5c0,0,281.5,2,296.9-6.7c0,0-34.9-95.4,9.4-135.7c4.7-4.2,10.5-9.1,17-14.2c-7.4,18.5-11.6,38.7-11.6,59.9c0,89,72.2,161.2,161.2,161.2c89,0,161.2-72.2,161.2-161.2c0-89.1-72.2-161.2-161.2-161.2c-1.5,0-2.9,0.2-4.3,0.2c11.6-7.6,19.1-12.3,19.1-12.3l-12.1-10.8c0,0,34.9-8,26.9-25.5c-8.1-17.5-92.7-122.3-92.7-122.3s15-32.2-16-55.1l-14.9,32.2c0,0-38-26.2-53.1-21.2c-15.1,5-37.8,7.6-44.8,18.6l-7,6.6c0,0-2,11.6,9.6,28.7c0,0,116.4,35.8,121.9,62c0,0,8.1,16.6-26.7,20.6l-7,9.1l-18.7,1l-33.7-77.1c0,0-32.3,8.6-48.9,21.7l2.5,13.1c0,0-135.5-92.2-263,44.3c0,0-94.2,27.2-160.2-56.4c0,0-1-27.2-160.2-22.2l11.1,11.6c0,0-11.1,1-15.6,8.1c-4.5,7,2.5,14.6,38.8,14.6c0,0,82.1,93.7,145.1,88.2l89.7,43.3l39.8,68c0,0,0.1,5.8,0.5,14.8c-9.2,2-19.6,4.2-30.6,6.5C302.9,497.9,242.5,451.6,171.2,451.6z M828.8,501c61.7,0,111.8,50.2,111.8,111.8c0,61.7-50.2,111.8-111.8,111.8c-61.7,0-111.8-50.2-111.8-111.8C717,551.2,767.1,501,828.8,501z M171.2,724.7c-61.6,0-111.8-50.2-111.8-111.8c0-61.7,50.2-111.8,111.8-111.8c47.4,0,87.9,29.7,104.1,71.4c-59.3,12.6-118.1,25.2-118.1,25.2l7.6,41.8l116.1-5.1C270.9,685.7,225.5,724.7,171.2,724.7z M364.8,630.6c3.3,11.2,7.6,20.1,13.2,23.9l-51.8,2c2.2-7.9,3.9-16.1,4.9-24.5L364.8,630.6z"/></g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g><g></g></g>\r
|
|
1594
|
-
</svg>`,
|
|
1595
|
-
"../ws/gear.svg":
|
|
1596
|
-
"../ws/motorcycle.svg":
|
|
1597
|
-
}),
|
|
1594
|
+
</svg>`, ut = "WhatsApp", gt = "Contactar por WhatsApp", ft = "compra de motos", At = "En este momento no es posible atender su solicitud. Le invitamos a contactarnos dentro de nuestro horario de atencion.", Z = "#25d366", bt = "#000000", Q = "motorcycle", xt = "America/Santiago", wt = "https://wa.me/", Ct = /* @__PURE__ */ Object.assign({
|
|
1595
|
+
"../ws/gear.svg": ht,
|
|
1596
|
+
"../ws/motorcycle.svg": mt
|
|
1597
|
+
}), yt = {
|
|
1598
1598
|
gasgas: "#cb0d25",
|
|
1599
1599
|
hqv: "#2b3d60",
|
|
1600
1600
|
ktm: "#ff6600",
|
|
1601
1601
|
rs: "#000000",
|
|
1602
1602
|
voge: "#000000"
|
|
1603
|
-
},
|
|
1603
|
+
}, vt = {
|
|
1604
1604
|
gas: "gasgas",
|
|
1605
1605
|
gasgas: "gasgas",
|
|
1606
1606
|
rsltda: "rs",
|
|
1607
1607
|
husqvarna: "hqv"
|
|
1608
|
-
},
|
|
1608
|
+
}, Et = {
|
|
1609
1609
|
0: 0,
|
|
1610
1610
|
7: 0,
|
|
1611
1611
|
dom: 0,
|
|
@@ -1642,7 +1642,7 @@ const he = `<?xml version="1.0" encoding="utf-8"?>\r
|
|
|
1642
1642
|
sabado: 6,
|
|
1643
1643
|
sat: 6,
|
|
1644
1644
|
saturday: 6
|
|
1645
|
-
},
|
|
1645
|
+
}, Pt = {
|
|
1646
1646
|
sun: 0,
|
|
1647
1647
|
mon: 1,
|
|
1648
1648
|
tue: 2,
|
|
@@ -1650,85 +1650,132 @@ const he = `<?xml version="1.0" encoding="utf-8"?>\r
|
|
|
1650
1650
|
thu: 4,
|
|
1651
1651
|
fri: 5,
|
|
1652
1652
|
sat: 6
|
|
1653
|
-
},
|
|
1654
|
-
Object.entries(
|
|
1655
|
-
var
|
|
1656
|
-
const
|
|
1657
|
-
return [P(
|
|
1653
|
+
}, Mt = Object.fromEntries(
|
|
1654
|
+
Object.entries(Ct).map(([d, x]) => {
|
|
1655
|
+
var e, o;
|
|
1656
|
+
const t = (o = (e = d.split("/").pop()) == null ? void 0 : e.replace(/\.svg$/i, "")) != null ? o : "";
|
|
1657
|
+
return [P(t), kt(x)];
|
|
1658
1658
|
})
|
|
1659
1659
|
);
|
|
1660
|
-
function
|
|
1661
|
-
return
|
|
1660
|
+
function kt(d) {
|
|
1661
|
+
return d.replace(/<\?xml[\s\S]*?\?>\s*/i, "").replace(/<!DOCTYPE[\s\S]*?>\s*/i, "").replace(/<metadata>[\s\S]*?<\/metadata>\s*/i, "").replace(/<svg\b/i, '<svg class="menu-link-icon" aria-hidden="true" focusable="false"').replace(/style="fill:\s*#ffffff;?"/i, 'style="fill: currentColor;"');
|
|
1662
1662
|
}
|
|
1663
|
-
function P(
|
|
1664
|
-
return
|
|
1663
|
+
function P(d) {
|
|
1664
|
+
return d.normalize("NFD").replace(/[\u0300-\u036f]/g, "").trim().toLowerCase().replace(/[^a-z0-9]+/g, "");
|
|
1665
1665
|
}
|
|
1666
|
-
function
|
|
1667
|
-
return /^(https?:\/\/|\/\/|data:image\/|blob:|\/|\.\/|\.\.\/)/i.test(
|
|
1666
|
+
function St(d) {
|
|
1667
|
+
return /^(https?:\/\/|\/\/|data:image\/|blob:|\/|\.\/|\.\.\/)/i.test(d.trim());
|
|
1668
1668
|
}
|
|
1669
1669
|
class G extends HTMLElement {
|
|
1670
1670
|
constructor() {
|
|
1671
1671
|
super();
|
|
1672
|
-
|
|
1673
|
-
|
|
1674
|
-
|
|
1675
|
-
|
|
1676
|
-
|
|
1677
|
-
|
|
1678
|
-
|
|
1679
|
-
|
|
1680
|
-
|
|
1681
|
-
|
|
1672
|
+
l(this, "root");
|
|
1673
|
+
l(this, "buttonEl");
|
|
1674
|
+
l(this, "menuEl");
|
|
1675
|
+
l(this, "generatedOptionsEl");
|
|
1676
|
+
l(this, "customMenuSlotEl");
|
|
1677
|
+
l(this, "closedMessageEl");
|
|
1678
|
+
l(this, "closedMessageTextEl");
|
|
1679
|
+
l(this, "labelEl");
|
|
1680
|
+
l(this, "hostAttributeObserver");
|
|
1681
|
+
l(this, "childrenObserver");
|
|
1682
|
+
l(this, "appliedCssVariableNames", /* @__PURE__ */ new Set());
|
|
1683
|
+
l(this, "handleButtonClick", () => {
|
|
1682
1684
|
this.menuEl.hidden && this.syncAttributesToState(), this.setMenuOpen(this.menuEl.hidden);
|
|
1683
1685
|
});
|
|
1684
|
-
|
|
1685
|
-
const
|
|
1686
|
-
if (
|
|
1687
|
-
|
|
1686
|
+
l(this, "handleMenuClick", (t) => {
|
|
1687
|
+
const e = t.composedPath();
|
|
1688
|
+
if (e.find((a) => a instanceof HTMLAnchorElement && a.getAttribute("aria-disabled") === "true")) {
|
|
1689
|
+
t.preventDefault();
|
|
1688
1690
|
return;
|
|
1689
1691
|
}
|
|
1690
|
-
|
|
1692
|
+
e.find((a) => a instanceof HTMLAnchorElement || a instanceof HTMLButtonElement) && this.setMenuOpen(!1);
|
|
1691
1693
|
});
|
|
1692
|
-
|
|
1694
|
+
l(this, "handleCustomMenuSlotChange", () => {
|
|
1693
1695
|
this.syncAttributesToState();
|
|
1694
1696
|
});
|
|
1695
|
-
|
|
1697
|
+
l(this, "handleHostAttributesMutation", (t) => {
|
|
1698
|
+
t.some((e) => {
|
|
1699
|
+
var o;
|
|
1700
|
+
return (o = e.attributeName) == null ? void 0 : o.startsWith("--");
|
|
1701
|
+
}) && this.syncAttributesToState();
|
|
1702
|
+
});
|
|
1703
|
+
l(this, "handleChildrenMutation", () => {
|
|
1696
1704
|
this.syncAttributesToState();
|
|
1697
1705
|
});
|
|
1698
|
-
|
|
1699
|
-
this.menuEl.hidden ||
|
|
1706
|
+
l(this, "handleDocumentClick", (t) => {
|
|
1707
|
+
this.menuEl.hidden || t.composedPath().includes(this) || this.setMenuOpen(!1);
|
|
1700
1708
|
});
|
|
1701
|
-
|
|
1702
|
-
this.menuEl.hidden ||
|
|
1709
|
+
l(this, "handleDocumentKeydown", (t) => {
|
|
1710
|
+
this.menuEl.hidden || t.key !== "Escape" || (this.setMenuOpen(!1), this.buttonEl.focus());
|
|
1703
1711
|
});
|
|
1704
1712
|
this.root = this.attachShadow({ mode: "open" }), this.root.innerHTML = `
|
|
1705
1713
|
<style>
|
|
1706
1714
|
:host {
|
|
1707
1715
|
position: fixed;
|
|
1708
|
-
right: var(--rs-whatsapp-right, 24px);
|
|
1709
|
-
bottom: var(--rs-whatsapp-bottom, 24px);
|
|
1716
|
+
right: calc(var(--rs-whatsapp-right, 24px) + var(--rs-whatsapp-offset-x, 0px));
|
|
1717
|
+
bottom: calc(var(--rs-whatsapp-bottom, 24px) + var(--rs-whatsapp-offset-y, 0px));
|
|
1710
1718
|
z-index: var(--rs-whatsapp-z-index, 9999);
|
|
1711
1719
|
display: inline-block;
|
|
1712
1720
|
--rs-whatsapp-brand-color: ${Z};
|
|
1713
1721
|
font-family: var(--rs-whatsapp-font-family, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif);
|
|
1722
|
+
transform: none;
|
|
1714
1723
|
}
|
|
1715
1724
|
:host([position="bottom-left"]) {
|
|
1716
1725
|
right: auto;
|
|
1717
|
-
left: var(--rs-whatsapp-left, 24px);
|
|
1718
|
-
bottom: var(--rs-whatsapp-bottom, 24px);
|
|
1726
|
+
left: calc(var(--rs-whatsapp-left, 24px) + var(--rs-whatsapp-offset-x, 0px));
|
|
1727
|
+
bottom: calc(var(--rs-whatsapp-bottom, 24px) + var(--rs-whatsapp-offset-y, 0px));
|
|
1719
1728
|
top: auto;
|
|
1729
|
+
transform: none;
|
|
1730
|
+
}
|
|
1731
|
+
:host([position="bottom-center"]) {
|
|
1732
|
+
right: auto;
|
|
1733
|
+
left: calc(50% + var(--rs-whatsapp-offset-x, 0px));
|
|
1734
|
+
bottom: calc(var(--rs-whatsapp-bottom, 24px) + var(--rs-whatsapp-offset-y, 0px));
|
|
1735
|
+
top: auto;
|
|
1736
|
+
transform: translateX(-50%);
|
|
1720
1737
|
}
|
|
1721
1738
|
:host([position="top-right"]) {
|
|
1722
|
-
right: var(--rs-whatsapp-right, 24px);
|
|
1739
|
+
right: calc(var(--rs-whatsapp-right, 24px) + var(--rs-whatsapp-offset-x, 0px));
|
|
1723
1740
|
left: auto;
|
|
1724
1741
|
bottom: auto;
|
|
1725
|
-
top: var(--rs-whatsapp-top, 24px);
|
|
1742
|
+
top: calc(var(--rs-whatsapp-top, 24px) + var(--rs-whatsapp-offset-y, 0px));
|
|
1743
|
+
transform: none;
|
|
1726
1744
|
}
|
|
1727
1745
|
:host([position="top-left"]) {
|
|
1728
1746
|
right: auto;
|
|
1729
|
-
left: var(--rs-whatsapp-left, 24px);
|
|
1747
|
+
left: calc(var(--rs-whatsapp-left, 24px) + var(--rs-whatsapp-offset-x, 0px));
|
|
1748
|
+
bottom: auto;
|
|
1749
|
+
top: calc(var(--rs-whatsapp-top, 24px) + var(--rs-whatsapp-offset-y, 0px));
|
|
1750
|
+
transform: none;
|
|
1751
|
+
}
|
|
1752
|
+
:host([position="top-center"]) {
|
|
1753
|
+
right: auto;
|
|
1754
|
+
left: calc(50% + var(--rs-whatsapp-offset-x, 0px));
|
|
1755
|
+
bottom: auto;
|
|
1756
|
+
top: calc(var(--rs-whatsapp-top, 24px) + var(--rs-whatsapp-offset-y, 0px));
|
|
1757
|
+
transform: translateX(-50%);
|
|
1758
|
+
}
|
|
1759
|
+
:host([position="center-left"]) {
|
|
1760
|
+
right: auto;
|
|
1761
|
+
left: calc(var(--rs-whatsapp-left, 24px) + var(--rs-whatsapp-offset-x, 0px));
|
|
1762
|
+
bottom: auto;
|
|
1763
|
+
top: calc(50% + var(--rs-whatsapp-offset-y, 0px));
|
|
1764
|
+
transform: translateY(-50%);
|
|
1765
|
+
}
|
|
1766
|
+
:host([position="center"]) {
|
|
1767
|
+
right: auto;
|
|
1768
|
+
left: calc(50% + var(--rs-whatsapp-offset-x, 0px));
|
|
1769
|
+
bottom: auto;
|
|
1770
|
+
top: calc(50% + var(--rs-whatsapp-offset-y, 0px));
|
|
1771
|
+
transform: translate(-50%, -50%);
|
|
1772
|
+
}
|
|
1773
|
+
:host([position="center-right"]) {
|
|
1774
|
+
right: calc(var(--rs-whatsapp-right, 24px) + var(--rs-whatsapp-offset-x, 0px));
|
|
1775
|
+
left: auto;
|
|
1730
1776
|
bottom: auto;
|
|
1731
|
-
top: var(--rs-whatsapp-
|
|
1777
|
+
top: calc(50% + var(--rs-whatsapp-offset-y, 0px));
|
|
1778
|
+
transform: translateY(-50%);
|
|
1732
1779
|
}
|
|
1733
1780
|
.button {
|
|
1734
1781
|
box-sizing: border-box;
|
|
@@ -1875,6 +1922,14 @@ class G extends HTMLElement {
|
|
|
1875
1922
|
left: 0;
|
|
1876
1923
|
transform-origin: bottom left;
|
|
1877
1924
|
}
|
|
1925
|
+
:host([position="bottom-center"]) .menu {
|
|
1926
|
+
right: auto;
|
|
1927
|
+
left: 50%;
|
|
1928
|
+
bottom: calc(var(--rs-whatsapp-size, 60px) + 12px);
|
|
1929
|
+
top: auto;
|
|
1930
|
+
transform: translateX(-50%);
|
|
1931
|
+
transform-origin: bottom center;
|
|
1932
|
+
}
|
|
1878
1933
|
:host([position="top-right"]) .menu {
|
|
1879
1934
|
top: calc(var(--rs-whatsapp-size, 60px) + 12px);
|
|
1880
1935
|
bottom: auto;
|
|
@@ -1887,6 +1942,38 @@ class G extends HTMLElement {
|
|
|
1887
1942
|
left: 0;
|
|
1888
1943
|
transform-origin: top left;
|
|
1889
1944
|
}
|
|
1945
|
+
:host([position="top-center"]) .menu {
|
|
1946
|
+
top: calc(var(--rs-whatsapp-size, 60px) + 12px);
|
|
1947
|
+
right: auto;
|
|
1948
|
+
bottom: auto;
|
|
1949
|
+
left: 50%;
|
|
1950
|
+
transform: translateX(-50%);
|
|
1951
|
+
transform-origin: top center;
|
|
1952
|
+
}
|
|
1953
|
+
:host([position="center-left"]) .menu {
|
|
1954
|
+
left: calc(var(--rs-whatsapp-size, 60px) + 12px);
|
|
1955
|
+
right: auto;
|
|
1956
|
+
top: 50%;
|
|
1957
|
+
bottom: auto;
|
|
1958
|
+
transform: translateY(-50%);
|
|
1959
|
+
transform-origin: left center;
|
|
1960
|
+
}
|
|
1961
|
+
:host([position="center"]) .menu {
|
|
1962
|
+
left: 50%;
|
|
1963
|
+
right: auto;
|
|
1964
|
+
top: auto;
|
|
1965
|
+
bottom: calc(var(--rs-whatsapp-size, 60px) + 12px);
|
|
1966
|
+
transform: translateX(-50%);
|
|
1967
|
+
transform-origin: bottom center;
|
|
1968
|
+
}
|
|
1969
|
+
:host([position="center-right"]) .menu {
|
|
1970
|
+
right: calc(var(--rs-whatsapp-size, 60px) + 12px);
|
|
1971
|
+
left: auto;
|
|
1972
|
+
top: 50%;
|
|
1973
|
+
bottom: auto;
|
|
1974
|
+
transform: translateY(-50%);
|
|
1975
|
+
transform-origin: right center;
|
|
1976
|
+
}
|
|
1890
1977
|
.menu-link,
|
|
1891
1978
|
::slotted(a),
|
|
1892
1979
|
::slotted(button) {
|
|
@@ -1931,18 +2018,65 @@ class G extends HTMLElement {
|
|
|
1931
2018
|
}
|
|
1932
2019
|
@media (max-width: 640px) {
|
|
1933
2020
|
:host {
|
|
1934
|
-
right: var(--rs-whatsapp-mobile-right, 16px);
|
|
1935
|
-
bottom: var(--rs-whatsapp-mobile-bottom, 16px);
|
|
2021
|
+
right: calc(var(--rs-whatsapp-mobile-right, 16px) + var(--rs-whatsapp-offset-x, 0px));
|
|
2022
|
+
bottom: calc(var(--rs-whatsapp-mobile-bottom, 16px) + var(--rs-whatsapp-offset-y, 0px));
|
|
2023
|
+
transform: none;
|
|
1936
2024
|
}
|
|
1937
2025
|
:host([position="bottom-left"]) {
|
|
1938
|
-
|
|
2026
|
+
right: auto;
|
|
2027
|
+
left: calc(var(--rs-whatsapp-mobile-left, 16px) + var(--rs-whatsapp-offset-x, 0px));
|
|
2028
|
+
bottom: calc(var(--rs-whatsapp-mobile-bottom, 16px) + var(--rs-whatsapp-offset-y, 0px));
|
|
2029
|
+
top: auto;
|
|
2030
|
+
transform: none;
|
|
2031
|
+
}
|
|
2032
|
+
:host([position="bottom-center"]) {
|
|
2033
|
+
right: auto;
|
|
2034
|
+
left: calc(50% + var(--rs-whatsapp-offset-x, 0px));
|
|
2035
|
+
bottom: calc(var(--rs-whatsapp-mobile-bottom, 16px) + var(--rs-whatsapp-offset-y, 0px));
|
|
2036
|
+
top: auto;
|
|
2037
|
+
transform: translateX(-50%);
|
|
1939
2038
|
}
|
|
1940
2039
|
:host([position="top-right"]) {
|
|
1941
|
-
|
|
2040
|
+
right: calc(var(--rs-whatsapp-mobile-right, 16px) + var(--rs-whatsapp-offset-x, 0px));
|
|
2041
|
+
left: auto;
|
|
2042
|
+
bottom: auto;
|
|
2043
|
+
top: calc(var(--rs-whatsapp-mobile-top, 16px) + var(--rs-whatsapp-offset-y, 0px));
|
|
2044
|
+
transform: none;
|
|
1942
2045
|
}
|
|
1943
2046
|
:host([position="top-left"]) {
|
|
1944
|
-
|
|
1945
|
-
|
|
2047
|
+
right: auto;
|
|
2048
|
+
left: calc(var(--rs-whatsapp-mobile-left, 16px) + var(--rs-whatsapp-offset-x, 0px));
|
|
2049
|
+
bottom: auto;
|
|
2050
|
+
top: calc(var(--rs-whatsapp-mobile-top, 16px) + var(--rs-whatsapp-offset-y, 0px));
|
|
2051
|
+
transform: none;
|
|
2052
|
+
}
|
|
2053
|
+
:host([position="top-center"]) {
|
|
2054
|
+
right: auto;
|
|
2055
|
+
left: calc(50% + var(--rs-whatsapp-offset-x, 0px));
|
|
2056
|
+
bottom: auto;
|
|
2057
|
+
top: calc(var(--rs-whatsapp-mobile-top, 16px) + var(--rs-whatsapp-offset-y, 0px));
|
|
2058
|
+
transform: translateX(-50%);
|
|
2059
|
+
}
|
|
2060
|
+
:host([position="center-left"]) {
|
|
2061
|
+
right: auto;
|
|
2062
|
+
left: calc(var(--rs-whatsapp-mobile-left, 16px) + var(--rs-whatsapp-offset-x, 0px));
|
|
2063
|
+
bottom: auto;
|
|
2064
|
+
top: calc(50% + var(--rs-whatsapp-offset-y, 0px));
|
|
2065
|
+
transform: translateY(-50%);
|
|
2066
|
+
}
|
|
2067
|
+
:host([position="center"]) {
|
|
2068
|
+
right: auto;
|
|
2069
|
+
left: calc(50% + var(--rs-whatsapp-offset-x, 0px));
|
|
2070
|
+
bottom: auto;
|
|
2071
|
+
top: calc(50% + var(--rs-whatsapp-offset-y, 0px));
|
|
2072
|
+
transform: translate(-50%, -50%);
|
|
2073
|
+
}
|
|
2074
|
+
:host([position="center-right"]) {
|
|
2075
|
+
right: calc(var(--rs-whatsapp-mobile-right, 16px) + var(--rs-whatsapp-offset-x, 0px));
|
|
2076
|
+
left: auto;
|
|
2077
|
+
bottom: auto;
|
|
2078
|
+
top: calc(50% + var(--rs-whatsapp-offset-y, 0px));
|
|
2079
|
+
transform: translateY(-50%);
|
|
1946
2080
|
}
|
|
1947
2081
|
:host([show-label]) .label {
|
|
1948
2082
|
max-width: 120px;
|
|
@@ -2001,7 +2135,10 @@ class G extends HTMLElement {
|
|
|
2001
2135
|
];
|
|
2002
2136
|
}
|
|
2003
2137
|
connectedCallback() {
|
|
2004
|
-
this.cacheShadowElements(), this.buttonEl.addEventListener("click", this.handleButtonClick), this.menuEl.addEventListener("click", this.handleMenuClick), this.customMenuSlotEl.addEventListener("slotchange", this.handleCustomMenuSlotChange), document.addEventListener("click", this.handleDocumentClick), document.addEventListener("keydown", this.handleDocumentKeydown), this.
|
|
2138
|
+
this.cacheShadowElements(), this.buttonEl.addEventListener("click", this.handleButtonClick), this.menuEl.addEventListener("click", this.handleMenuClick), this.customMenuSlotEl.addEventListener("slotchange", this.handleCustomMenuSlotChange), document.addEventListener("click", this.handleDocumentClick), document.addEventListener("keydown", this.handleDocumentKeydown), this.hostAttributeObserver = new MutationObserver(this.handleHostAttributesMutation), this.hostAttributeObserver.observe(this, {
|
|
2139
|
+
attributes: !0,
|
|
2140
|
+
attributeOldValue: !0
|
|
2141
|
+
}), this.childrenObserver = new MutationObserver(this.handleChildrenMutation), this.childrenObserver.observe(this, {
|
|
2005
2142
|
childList: !0,
|
|
2006
2143
|
subtree: !0,
|
|
2007
2144
|
characterData: !0,
|
|
@@ -2013,215 +2150,220 @@ class G extends HTMLElement {
|
|
|
2013
2150
|
this.buttonEl = this.root.querySelector("button"), this.menuEl = this.root.querySelector(".menu"), this.generatedOptionsEl = this.root.querySelector("[data-generated-options]"), this.customMenuSlotEl = this.root.querySelector('slot[name="menu"]'), this.closedMessageEl = this.root.querySelector("[data-closed-message]"), this.closedMessageTextEl = this.root.querySelector("[data-closed-message-text]"), this.labelEl = this.root.querySelector(".label");
|
|
2014
2151
|
}
|
|
2015
2152
|
disconnectedCallback() {
|
|
2016
|
-
var e,
|
|
2017
|
-
(
|
|
2153
|
+
var t, e, o, n, a;
|
|
2154
|
+
(t = this.buttonEl) == null || t.removeEventListener("click", this.handleButtonClick), (e = this.menuEl) == null || e.removeEventListener("click", this.handleMenuClick), (o = this.customMenuSlotEl) == null || o.removeEventListener("slotchange", this.handleCustomMenuSlotChange), document.removeEventListener("click", this.handleDocumentClick), document.removeEventListener("keydown", this.handleDocumentKeydown), (n = this.hostAttributeObserver) == null || n.disconnect(), (a = this.childrenObserver) == null || a.disconnect();
|
|
2018
2155
|
}
|
|
2019
2156
|
attributeChangedCallback() {
|
|
2020
2157
|
this.isConnected && this.syncAttributesToState();
|
|
2021
2158
|
}
|
|
2022
2159
|
syncAttributesToState() {
|
|
2023
|
-
var i,
|
|
2024
|
-
const
|
|
2025
|
-
if (this.labelEl.textContent =
|
|
2160
|
+
var i, c, p, m, h;
|
|
2161
|
+
const t = ((i = this.getAttribute("label")) != null ? i : "").trim() || ut, e = ((c = this.getAttribute("menu-label")) != null ? c : "").trim() || ft, o = ((p = this.getAttribute("aria-label")) != null ? p : "").trim() || gt, n = ((m = this.getAttribute("target")) != null ? m : "_blank").trim() || "_blank", a = ((h = this.getAttribute("icon")) != null ? h : Q).trim() || Q, s = this.isOutsideBusinessHours();
|
|
2162
|
+
if (this.labelEl.textContent = t, this.buttonEl.setAttribute("aria-label", o), this.buttonEl.setAttribute("title", o), this.syncBrandVariant(), this.syncCssVariablesFromAttributes(), this.closedMessageTextEl.textContent = this.getClosedMessage(), this.closedMessageEl.hidden = !s, this.customMenuSlotEl.hidden = s, s) {
|
|
2026
2163
|
this.generatedOptionsEl.hidden = !0, this.generatedOptionsEl.replaceChildren();
|
|
2027
2164
|
return;
|
|
2028
2165
|
}
|
|
2029
|
-
this.renderMenuOptions(
|
|
2166
|
+
this.renderMenuOptions(e, n, a);
|
|
2030
2167
|
}
|
|
2031
|
-
buildWhatsappUrl(
|
|
2032
|
-
const
|
|
2033
|
-
if (!
|
|
2168
|
+
buildWhatsappUrl(t, e) {
|
|
2169
|
+
const o = this.sanitizePhone(t);
|
|
2170
|
+
if (!o)
|
|
2034
2171
|
return "";
|
|
2035
|
-
const
|
|
2036
|
-
return `${
|
|
2037
|
-
}
|
|
2038
|
-
sanitizePhone(
|
|
2039
|
-
return (
|
|
2172
|
+
const n = (e != null ? e : "").trim(), a = n ? `?text=${encodeURIComponent(n)}` : "";
|
|
2173
|
+
return `${wt}${o}${a}`;
|
|
2174
|
+
}
|
|
2175
|
+
sanitizePhone(t) {
|
|
2176
|
+
return (t != null ? t : "").replace(/[^\d]/g, "");
|
|
2177
|
+
}
|
|
2178
|
+
syncCssVariablesFromAttributes() {
|
|
2179
|
+
const t = /* @__PURE__ */ new Set();
|
|
2180
|
+
for (const e of Array.from(this.attributes)) {
|
|
2181
|
+
if (!e.name.startsWith("--"))
|
|
2182
|
+
continue;
|
|
2183
|
+
const o = e.value.trim();
|
|
2184
|
+
o && (t.add(e.name), this.style.setProperty(e.name, o));
|
|
2185
|
+
}
|
|
2186
|
+
for (const e of this.appliedCssVariableNames)
|
|
2187
|
+
t.has(e) || this.style.removeProperty(e);
|
|
2188
|
+
this.appliedCssVariableNames = t;
|
|
2040
2189
|
}
|
|
2041
2190
|
syncBrandVariant() {
|
|
2042
|
-
var
|
|
2043
|
-
const
|
|
2044
|
-
if (!
|
|
2191
|
+
var n, a;
|
|
2192
|
+
const t = ((n = this.getAttribute("marca")) != null ? n : "").trim();
|
|
2193
|
+
if (!t) {
|
|
2045
2194
|
this.style.setProperty("--rs-whatsapp-brand-color", Z);
|
|
2046
2195
|
return;
|
|
2047
2196
|
}
|
|
2048
|
-
const
|
|
2049
|
-
this.style.setProperty("--rs-whatsapp-brand-color",
|
|
2197
|
+
const e = this.normalizeBrandKey(t), o = (a = yt[e]) != null ? a : bt;
|
|
2198
|
+
this.style.setProperty("--rs-whatsapp-brand-color", o);
|
|
2050
2199
|
}
|
|
2051
|
-
normalizeBrandKey(
|
|
2052
|
-
var
|
|
2053
|
-
const
|
|
2054
|
-
return (
|
|
2200
|
+
normalizeBrandKey(t) {
|
|
2201
|
+
var o;
|
|
2202
|
+
const e = P(t);
|
|
2203
|
+
return (o = vt[e]) != null ? o : e;
|
|
2055
2204
|
}
|
|
2056
|
-
renderMenuOptions(
|
|
2205
|
+
renderMenuOptions(t, e, o) {
|
|
2057
2206
|
if (this.customMenuSlotEl.assignedElements({ flatten: !0 }).length > 0) {
|
|
2058
2207
|
this.generatedOptionsEl.hidden = !0, this.generatedOptionsEl.replaceChildren();
|
|
2059
2208
|
return;
|
|
2060
2209
|
}
|
|
2061
|
-
const s = this.getWhatsappOptions(
|
|
2210
|
+
const s = this.getWhatsappOptions(t, e, o).filter((i) => this.sanitizePhone(i.telefono)).map((i) => this.createMenuLink(i));
|
|
2062
2211
|
this.generatedOptionsEl.replaceChildren(...s), this.generatedOptionsEl.hidden = !1;
|
|
2063
2212
|
}
|
|
2064
|
-
getWhatsappOptions(
|
|
2213
|
+
getWhatsappOptions(t, e, o) {
|
|
2065
2214
|
var a, s;
|
|
2066
|
-
const
|
|
2067
|
-
return
|
|
2068
|
-
var
|
|
2215
|
+
const n = Array.from(this.querySelectorAll(F.tag));
|
|
2216
|
+
return n.length ? n.map((i) => {
|
|
2217
|
+
var c, p, m, h, f, b;
|
|
2069
2218
|
return {
|
|
2070
|
-
label: ((
|
|
2219
|
+
label: ((p = (c = i.getAttribute("label")) != null ? c : i.textContent) != null ? p : "").trim() || t,
|
|
2071
2220
|
telefono: ((m = i.getAttribute("telefono")) != null ? m : "").trim(),
|
|
2072
2221
|
mensaje: ((h = i.getAttribute("mensaje")) != null ? h : "").trim(),
|
|
2073
|
-
target: ((f = i.getAttribute("target")) != null ? f :
|
|
2074
|
-
icon: ((b = i.getAttribute("icon")) != null ? b :
|
|
2222
|
+
target: ((f = i.getAttribute("target")) != null ? f : e).trim() || e,
|
|
2223
|
+
icon: ((b = i.getAttribute("icon")) != null ? b : o).trim() || o
|
|
2075
2224
|
};
|
|
2076
2225
|
}) : [
|
|
2077
2226
|
{
|
|
2078
|
-
label:
|
|
2227
|
+
label: t,
|
|
2079
2228
|
telefono: ((a = this.getAttribute("telefono")) != null ? a : "").trim(),
|
|
2080
2229
|
mensaje: ((s = this.getAttribute("mensaje")) != null ? s : "").trim(),
|
|
2081
|
-
target:
|
|
2082
|
-
icon:
|
|
2230
|
+
target: e,
|
|
2231
|
+
icon: o
|
|
2083
2232
|
}
|
|
2084
2233
|
];
|
|
2085
2234
|
}
|
|
2086
|
-
createMenuLink(
|
|
2087
|
-
const
|
|
2088
|
-
|
|
2089
|
-
const a = this.createOptionIcon(
|
|
2090
|
-
return a &&
|
|
2235
|
+
createMenuLink(t) {
|
|
2236
|
+
const e = document.createElement("a"), o = document.createElement("span"), n = this.buildWhatsappUrl(t.telefono, t.mensaje);
|
|
2237
|
+
e.className = "menu-link", e.rel = "noopener noreferrer", e.target = t.target, o.className = "menu-label", o.textContent = t.label;
|
|
2238
|
+
const a = this.createOptionIcon(t.icon);
|
|
2239
|
+
return a && e.append(a), e.append(o), n ? (e.href = n, e.tabIndex = 0, e) : (e.setAttribute("aria-disabled", "true"), e.tabIndex = -1, e);
|
|
2091
2240
|
}
|
|
2092
|
-
createOptionIcon(
|
|
2241
|
+
createOptionIcon(t) {
|
|
2093
2242
|
var s, i;
|
|
2094
|
-
const
|
|
2095
|
-
if (
|
|
2243
|
+
const e = t.trim(), o = P(e);
|
|
2244
|
+
if (o === "none")
|
|
2096
2245
|
return null;
|
|
2097
|
-
if (
|
|
2098
|
-
const
|
|
2099
|
-
return
|
|
2246
|
+
if (St(e)) {
|
|
2247
|
+
const c = document.createElement("img");
|
|
2248
|
+
return c.className = "menu-link-icon", c.src = e, c.alt = "", c.setAttribute("aria-hidden", "true"), c.decoding = "async", c;
|
|
2100
2249
|
}
|
|
2101
|
-
const
|
|
2102
|
-
if (!
|
|
2250
|
+
const n = Mt[o || Q];
|
|
2251
|
+
if (!n)
|
|
2103
2252
|
return null;
|
|
2104
2253
|
const a = document.createElement("template");
|
|
2105
|
-
return a.innerHTML =
|
|
2254
|
+
return a.innerHTML = n, (i = (s = a.content.firstElementChild) == null ? void 0 : s.cloneNode(!0)) != null ? i : document.createElement("span");
|
|
2106
2255
|
}
|
|
2107
2256
|
getClosedMessage() {
|
|
2108
|
-
var
|
|
2109
|
-
const
|
|
2110
|
-
return
|
|
2257
|
+
var o;
|
|
2258
|
+
const t = ((o = this.getAttribute("mensaje-fuera-horario")) != null ? o : "").trim() || At, e = this.getScheduleSummary();
|
|
2259
|
+
return e ? `${t}
|
|
2111
2260
|
Horario de atencion:
|
|
2112
|
-
${
|
|
2261
|
+
${e}` : t;
|
|
2113
2262
|
}
|
|
2114
2263
|
isOutsideBusinessHours() {
|
|
2115
|
-
const
|
|
2116
|
-
if (
|
|
2117
|
-
const
|
|
2118
|
-
return
|
|
2264
|
+
const t = this.getAttribute("fuera-horario");
|
|
2265
|
+
if (t !== null) {
|
|
2266
|
+
const o = P(t);
|
|
2267
|
+
return o !== "false" && o !== "0" && o !== "no";
|
|
2119
2268
|
}
|
|
2120
|
-
const
|
|
2121
|
-
return
|
|
2269
|
+
const e = this.getScheduleSegments().join(";");
|
|
2270
|
+
return e ? !this.isWithinBusinessHours(e) : !1;
|
|
2122
2271
|
}
|
|
2123
2272
|
getScheduleSegments() {
|
|
2124
|
-
var
|
|
2125
|
-
const
|
|
2126
|
-
return
|
|
2127
|
-
var i,
|
|
2128
|
-
const
|
|
2129
|
-
return !
|
|
2130
|
-
}).filter(Boolean) : ((
|
|
2273
|
+
var e;
|
|
2274
|
+
const t = Array.from(this.querySelectorAll(M.tag));
|
|
2275
|
+
return t.length ? t.map((o) => {
|
|
2276
|
+
var i, c, p;
|
|
2277
|
+
const n = ((i = o.getAttribute("dias")) != null ? i : "").trim(), a = ((c = o.getAttribute("desde")) != null ? c : "").trim(), s = ((p = o.getAttribute("hasta")) != null ? p : "").trim();
|
|
2278
|
+
return !n || !a || !s ? "" : `${n} ${a}-${s}`;
|
|
2279
|
+
}).filter(Boolean) : ((e = this.getAttribute("horario")) != null ? e : "").split(";").map((o) => o.trim()).filter(Boolean);
|
|
2131
2280
|
}
|
|
2132
2281
|
getScheduleSummary() {
|
|
2133
|
-
var
|
|
2134
|
-
const
|
|
2135
|
-
return
|
|
2136
|
-
var i,
|
|
2137
|
-
const
|
|
2138
|
-
return !
|
|
2282
|
+
var e;
|
|
2283
|
+
const t = Array.from(this.querySelectorAll(M.tag));
|
|
2284
|
+
return t.length ? t.map((o) => {
|
|
2285
|
+
var i, c, p;
|
|
2286
|
+
const n = ((i = o.getAttribute("dias")) != null ? i : "").trim(), a = ((c = o.getAttribute("desde")) != null ? c : "").trim(), s = ((p = o.getAttribute("hasta")) != null ? p : "").trim();
|
|
2287
|
+
return !n || !a || !s ? "" : `${n} ${a}-${s}`;
|
|
2139
2288
|
}).filter(Boolean).join(`
|
|
2140
|
-
`) : ((
|
|
2289
|
+
`) : ((e = this.getAttribute("horario")) != null ? e : "").split(";").map((o) => o.trim()).filter(Boolean).join(`
|
|
2141
2290
|
`);
|
|
2142
2291
|
}
|
|
2143
|
-
isWithinBusinessHours(
|
|
2144
|
-
const
|
|
2145
|
-
return
|
|
2292
|
+
isWithinBusinessHours(t) {
|
|
2293
|
+
const e = this.getCurrentTimeParts();
|
|
2294
|
+
return t.split(";").some((o) => this.isScheduleSegmentActive(o, e.day, e.minutes));
|
|
2146
2295
|
}
|
|
2147
2296
|
getCurrentTimeParts() {
|
|
2148
|
-
var
|
|
2149
|
-
const
|
|
2150
|
-
if (!e) {
|
|
2151
|
-
const l = /* @__PURE__ */ new Date();
|
|
2152
|
-
return {
|
|
2153
|
-
day: l.getDay(),
|
|
2154
|
-
minutes: l.getHours() * 60 + l.getMinutes()
|
|
2155
|
-
};
|
|
2156
|
-
}
|
|
2297
|
+
var e, o, n, a, s, i;
|
|
2298
|
+
const t = ((e = this.getAttribute("time-zone")) != null ? e : "").trim() || xt;
|
|
2157
2299
|
try {
|
|
2158
|
-
const
|
|
2159
|
-
timeZone:
|
|
2300
|
+
const c = /* @__PURE__ */ new Date(), p = new Intl.DateTimeFormat("en-US", {
|
|
2301
|
+
timeZone: t,
|
|
2160
2302
|
weekday: "short"
|
|
2161
|
-
}).format(
|
|
2162
|
-
timeZone:
|
|
2303
|
+
}).format(c).toLowerCase(), m = new Intl.DateTimeFormat("en-US", {
|
|
2304
|
+
timeZone: t,
|
|
2163
2305
|
hour12: !1,
|
|
2164
2306
|
hour: "2-digit",
|
|
2165
2307
|
minute: "2-digit"
|
|
2166
|
-
}).formatToParts(
|
|
2308
|
+
}).formatToParts(c), h = Number((n = (o = m.find((b) => b.type === "hour")) == null ? void 0 : o.value) != null ? n : 0) % 24, f = Number((s = (a = m.find((b) => b.type === "minute")) == null ? void 0 : a.value) != null ? s : 0);
|
|
2167
2309
|
return {
|
|
2168
|
-
day: (i =
|
|
2310
|
+
day: (i = Pt[p]) != null ? i : c.getDay(),
|
|
2169
2311
|
minutes: h * 60 + f
|
|
2170
2312
|
};
|
|
2171
2313
|
} catch {
|
|
2172
|
-
const
|
|
2314
|
+
const c = /* @__PURE__ */ new Date();
|
|
2173
2315
|
return {
|
|
2174
|
-
day:
|
|
2175
|
-
minutes:
|
|
2316
|
+
day: c.getDay(),
|
|
2317
|
+
minutes: c.getHours() * 60 + c.getMinutes()
|
|
2176
2318
|
};
|
|
2177
2319
|
}
|
|
2178
2320
|
}
|
|
2179
|
-
isScheduleSegmentActive(
|
|
2180
|
-
const
|
|
2181
|
-
if (!
|
|
2321
|
+
isScheduleSegmentActive(t, e, o) {
|
|
2322
|
+
const n = t.trim().normalize("NFD").replace(/[\u0300-\u036f]/g, "").toLowerCase().match(/^(.+?)\s+(\d{1,2}:\d{2})\s*-\s*(\d{1,2}:\d{2})$/);
|
|
2323
|
+
if (!n)
|
|
2182
2324
|
return !1;
|
|
2183
|
-
const a = this.parseScheduleDays(
|
|
2184
|
-
return !a.includes(
|
|
2325
|
+
const a = this.parseScheduleDays(n[1]), s = this.parseScheduleTime(n[2]), i = this.parseScheduleTime(n[3]);
|
|
2326
|
+
return !a.includes(e) || s === null || i === null ? !1 : s <= i ? o >= s && o <= i : o >= s || o <= i;
|
|
2185
2327
|
}
|
|
2186
|
-
parseScheduleDays(
|
|
2187
|
-
const
|
|
2188
|
-
return
|
|
2189
|
-
const [
|
|
2328
|
+
parseScheduleDays(t) {
|
|
2329
|
+
const e = t.normalize("NFD").replace(/[\u0300-\u036f]/g, "").toLowerCase().replace(/\s+/g, "");
|
|
2330
|
+
return e === "*" || e === "todos" || e === "all" ? [0, 1, 2, 3, 4, 5, 6] : e.split(",").flatMap((o) => {
|
|
2331
|
+
const [n, a] = o.split("-"), s = this.parseScheduleDay(n), i = a ? this.parseScheduleDay(a) : s;
|
|
2190
2332
|
if (s === null || i === null)
|
|
2191
2333
|
return [];
|
|
2192
2334
|
if (s === i)
|
|
2193
2335
|
return [s];
|
|
2194
|
-
const
|
|
2195
|
-
let
|
|
2336
|
+
const c = [];
|
|
2337
|
+
let p = s;
|
|
2196
2338
|
for (; ; ) {
|
|
2197
|
-
if (
|
|
2198
|
-
return
|
|
2199
|
-
|
|
2339
|
+
if (c.push(p), p === i)
|
|
2340
|
+
return c;
|
|
2341
|
+
p = (p + 1) % 7;
|
|
2200
2342
|
}
|
|
2201
2343
|
});
|
|
2202
2344
|
}
|
|
2203
|
-
parseScheduleDay(
|
|
2204
|
-
var
|
|
2205
|
-
if (!
|
|
2345
|
+
parseScheduleDay(t) {
|
|
2346
|
+
var o;
|
|
2347
|
+
if (!t)
|
|
2206
2348
|
return null;
|
|
2207
|
-
const
|
|
2208
|
-
return (
|
|
2349
|
+
const e = P(t);
|
|
2350
|
+
return (o = Et[e]) != null ? o : null;
|
|
2209
2351
|
}
|
|
2210
|
-
parseScheduleTime(
|
|
2211
|
-
const [
|
|
2212
|
-
return !Number.isInteger(
|
|
2352
|
+
parseScheduleTime(t) {
|
|
2353
|
+
const [e, o] = t.split(":"), n = Number(e), a = Number(o);
|
|
2354
|
+
return !Number.isInteger(n) || !Number.isInteger(a) || n < 0 || n > 23 || a < 0 || a > 59 ? null : n * 60 + a;
|
|
2213
2355
|
}
|
|
2214
|
-
setMenuOpen(
|
|
2215
|
-
this.menuEl.hidden = !
|
|
2356
|
+
setMenuOpen(t) {
|
|
2357
|
+
this.menuEl.hidden = !t, this.buttonEl.setAttribute("aria-expanded", String(t)), this.toggleAttribute("open", t);
|
|
2216
2358
|
}
|
|
2217
2359
|
}
|
|
2218
|
-
|
|
2360
|
+
l(G, "tag", "rs-whatsapp");
|
|
2219
2361
|
class F extends HTMLElement {
|
|
2220
2362
|
}
|
|
2221
|
-
|
|
2363
|
+
l(F, "tag", "rs-whatsapp-option");
|
|
2222
2364
|
class M extends HTMLElement {
|
|
2223
2365
|
}
|
|
2224
|
-
|
|
2366
|
+
l(M, "tag", "rs-whatsapp-schedule");
|
|
2225
2367
|
_(I.tag, I);
|
|
2226
2368
|
_(F.tag, F);
|
|
2227
2369
|
_(M.tag, M);
|