ca-components 1.1.9997 → 1.1.9999
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/esm2022/lib/components/ca-input-address-dropdown/ca-input-address-dropdown.component.mjs
CHANGED
|
@@ -33,6 +33,11 @@ export class CaInputAddressDropdownComponent {
|
|
|
33
33
|
valid: value.address && value.longLat ? true : false,
|
|
34
34
|
longLat: value.longLat,
|
|
35
35
|
};
|
|
36
|
+
this.onChange({
|
|
37
|
+
...value.address,
|
|
38
|
+
latitude: value.longLat?.latitude,
|
|
39
|
+
longitude: value.longLat?.longitude,
|
|
40
|
+
});
|
|
36
41
|
this.selectedAddress.emit(this.currentAddressData);
|
|
37
42
|
}
|
|
38
43
|
}
|
|
@@ -342,4 +347,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
342
347
|
type: HostListener,
|
|
343
348
|
args: ['document:keydown', ['$event']]
|
|
344
349
|
}] } });
|
|
345
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-input-address-dropdown.component.js","sourceRoot":"","sources":["../../../../../../projects/ca-components/src/lib/components/ca-input-address-dropdown/ca-input-address-dropdown.component.ts","../../../../../../projects/ca-components/src/lib/components/ca-input-address-dropdown/ca-input-address-dropdown.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAe,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAClE,OAAO,EACH,SAAS,EACT,YAAY,EACZ,KAAK,EAGL,MAAM,EACN,IAAI,EACJ,SAAS,EACT,iBAAiB,EAEjB,YAAY,GAEf,MAAM,eAAe,CAAC;AACvB,OAAO,EACH,eAAe,EACf,UAAU,EACV,YAAY,EACZ,oBAAoB,EACpB,MAAM,EAEN,EAAE,EACF,OAAO,EACP,SAAS,EACT,SAAS,EACT,GAAG,GACN,MAAM,MAAM,CAAC;AACd,OAAO,EAIH,WAAW,GACd,MAAM,gBAAgB,CAAC;AAKxB,aAAa;AACb,OAAO,EAAE,wBAAwB,EAAE,MAAM,kDAAkD,CAAC;AAE5F,UAAU;AACV,OAAO,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;AACxD,OAAO,EAAE,SAAS,EAAE,MAAM,4BAA4B,CAAC;AAEvD,QAAQ;AACR,OAAO,EAAE,8BAA8B,EAAE,MAAM,4CAA4C,CAAC;AAC5F,OAAO,EAAE,+BAA+B,EAAE,MAAM,8CAA8C,CAAC;AAC/F,OAAO,EAAE,0BAA0B,EAAE,MAAM,wCAAwC,CAAC;AACpF,OAAO,EAAE,4BAA4B,EAAE,MAAM,0CAA0C,CAAC;AACxF,OAAO,EAAE,iBAAiB,EAAE,MAAM,yCAAyC,CAAC;AAO5E,OAAO,EAAE,uBAAuB,EAAE,MAAM,kDAAkD,CAAC;AAC3F,OAAO,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AAKxD,OAAO,EAAE,2BAA2B,EAAE,MAAM,iDAAiD,CAAC;;;;;;AAyB9F,MAAM,OAAO,+BAA+B;IAMxC,IAAa,eAAe,CAAC,KAAa;QACtC,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;IAClC,CAAC;IAED,IAAoB,mBAAmB,CAAC,KAAyB;QAC7D,IAAI,KAAK,EAAE,CAAC;YACR,IAAI,CAAC,kBAAkB,GAAG;gBACtB,OAAO,EAAE,KAAK,CAAC,OAAQ;gBACvB,KAAK,EAAE,KAAK,CAAC,OAAO,IAAI,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK;gBACpD,OAAO,EAAE,KAAK,CAAC,OAAO;aACzB,CAAC;YAEF,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,kBAAmB,CAAC,CAAC;QACxD,CAAC;IACL,CAAC;IACD,IAAoB,mBAAmB,CAAC,KAAiC;QACrE,IAAI,CAAC,oBAAoB,GAAG,KAAK,CAAC;QAClC,IAAI,KAAK,EAAE,SAAS,EAAE,CAAC;YACnB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,SAAS,CAAC,GAAG,CACjC,CAAC,IAAY,EAAE,IAAY,EAAE,EAAE;gBAC3B,OAAO;oBACH,OAAO,EAAE,IAAI;oBACb,EAAE,EAAE,IAAI;iBACX,CAAC;YACN,CAAC,CACJ,CAAC;QACN,CAAC;IACL,CAAC;IA4BD,mBAAmB,CAAC,KAAoB;QACpC,MAAM,GAAG,GAAG,KAAK,CAAC,GAAG,CAAC;QACtB,IACI,IAAI,CAAC,WAAW,CAAC,IAAI,IAAI,0BAA0B,CAAC,eAAe,EACrE,CAAC;YACC,IAAI,GAAG,KAAK,8BAA8B,CAAC,KAAK,EAAE,CAAC;gBAC/C,IAAI,IAAI,CAAC,kBAAkB,EAAE,CAAC;oBAC1B,IAAI,CAAC,UAAU,CACX,KAAK,EACL,8BAA8B,CAAC,OAAO,CACzC,CAAC;gBACN,CAAC;YACL,CAAC;iBAAM,IAAI,GAAG,KAAK,8BAA8B,CAAC,MAAM,EAAE,CAAC;gBACvD,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;YAC3B,CAAC;QACL,CAAC;IACL,CAAC;IAiBD,YACmB,YAAuB,EAC9B,GAAsB;QADf,iBAAY,GAAZ,YAAY,CAAW;QAC9B,QAAG,GAAH,GAAG,CAAmB;QA7DjB,qBAAgB,GAC7B,IAAI,YAAY,EAAU,CAAC;QAIf,cAAS,GAAY,KAAK,CAAC;QAC3B,iBAAY,GAAY,KAAK,CAAC;QAE9B,oBAAe,GAAY,KAAK,CAAC;QAGvC,oBAAe,GACrB,IAAI,YAAY,EAAe,CAAC;QAC1B,oBAAe,GACrB,IAAI,YAAY,EAAmB,CAAC;QAGxC,kBAAa,GAA0B,IAAI,YAAY,EAAW,CAAC;QACzD,iBAAY,GAAmC,IAAI,YAAY,EAEtE,CAAC;QACM,eAAU,GAA0B,IAAI,YAAY,EAAW,CAAC;QAChE,mBAAc,GACpB,IAAI,YAAY,EAAW,CAAC;QAuBzB,uBAAkB,GAAuB,IAAI,CAAC;QAErD,OAAO;QACA,oBAAe,GAAY,KAAK,CAAC;QACjC,uBAAkB,GAAY,KAAK,CAAC;QACnC,oBAAe,GAAY,KAAK,CAAC;QAClC,aAAQ,GAAW,+BAA+B,CAAC,KAAK,CAAC;QACxD,gBAAW,GAAY,KAAK,CAAC;QAC9B,yBAAoB,GAA+B,IAAI,CAAC;QAEvD,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;QA4C/B,0BAAqB,GAAG,IAAI,eAAe,CAAS,EAAE,CAAC,CAAC;QACzD,2BAAsB,GACzB,IAAI,CAAC,qBAAqB,CAAC,YAAY,EAAE,CAAC;QAvC1C,IAAI,CAAC,YAAY,CAAC,aAAa,GAAG,IAAI,CAAC;IAC3C,CAAC;IAED,kBAAkB,KAAU,CAAC;IAE7B,UAAU,CAAC,OAAY;QACnB,IAAI,OAAO,EAAE,CAAC;YACV,IAAI,CAAC,aAAa,EAAE,gBAAgB,CAAC,OAAO,EAAE,SAAS,EAAE,SAAS,CAAC,CAAC;YAEpE,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;QAC3B,CAAC;IACL,CAAC;IAEM,gBAAgB,CAAC,EAAO;QAC3B,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACvB,CAAC;IAEM,QAAQ,CAAC,CAAM,IAAS,CAAC;IAEzB,iBAAiB,CAAC,CAAM,IAAS,CAAC;IAEzC,QAAQ;QACJ,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC3B,IAAI,CAAC,6BAA6B,EAAE,CAAC;IACzC,CAAC;IAEM,6BAA6B;QAChC,MAAM,iBAAiB,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS;YACjD,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC;YAC/B,CAAC,CAAC,EAAE,CAAC;QACT,IAAI,CAAC,YAAY,EAAE,OAAO,EAAE,aAAa,CAAC;YACtC,GAAG,iBAAiB;YACpB,2BAA2B,EAAE;SAChC,CAAC,CAAC;QACH,IAAI,CAAC,YAAY,EAAE,OAAO,EAAE,sBAAsB,EAAE,CAAC;IACzD,CAAC;IAMM,iBAAiB,CAAC,IAAY;QACjC,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC1C,CAAC;IAEM,mBAAmB;QACtB,IAAI,CAAC,sBAAsB;aACtB,IAAI,CACD,oBAAoB,EAAE,EACtB,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,EACxB,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;YACT,IAAI,CAAC,WAAW,GAAG;gBACf,GAAG,IAAI,CAAC,WAAW;gBACnB,cAAc,EAAE;oBACZ,GAAG,IAAI,CAAC,WAAW,CAAC,cAAc;oBAClC,SAAS,EAAE,IAAI;oBACf,IAAI,EAAE,iBAAiB,CAAC,KAAK;oBAC7B,KAAK,EAAE,iBAAiB,CAAC,KAAK;iBACjC;aACJ,CAAC;YAEF,IAAI,CAAC,IAAI,EAAE,CAAC;gBACR,IAAI,CAAC,WAAW,GAAG;oBACf,GAAG,IAAI,CAAC,WAAW;oBACnB,cAAc,EAAE;wBACZ,GAAG,IAAI,CAAC,WAAW,CAAC,cAAc;wBAClC,SAAS,EAAE,KAAK;qBACnB;iBACJ,CAAC;gBACF,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;YACzB,CAAC;iBAAM,IACH,IAAI,KAAK,IAAI,CAAC,kBAAkB,EAAE,OAAO,CAAC,OAAO;gBACjD,IAAI,CAAC,WAAW,CAAC,IAAI;oBACjB,0BAA0B,CAAC,eAAe,EAChD,CAAC;gBACC,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;YACnC,CAAC;YACD,IACI,IAAI,CAAC,WAAW,CAAC,IAAI;gBACjB,0BAA0B,CAAC,eAAe;gBAC9C,IAAI,CAAC,eAAe;gBACpB,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,YAAY,EAC1C,CAAC;gBACC,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;gBACzB,MAAM,WAAW,GAAG;oBAChB,OAAO,EAAE,EAAE;oBACX,KAAK,EAAE,KAAK;oBACZ,OAAO,EAAE,EAAE;iBACd,CAAC;gBACF,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;YAC3C,CAAC;YAED,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;QAChC,CAAC,CAAC,EACF,MAAM,CAAC,CAAC,IAAY,EAAE,EAAE;YACpB,OAAO,IAAI,EAAE,MAAM,IAAI,CAAC,CAAC;QAC7B,CAAC,CAAC,EACF,YAAY,CAAC,GAAG,CAAC,EACjB,SAAS,CAAC,CAAC,KAAa,EAAE,EAAE;YACxB,MAAM,MAAM,GAAG;gBACX,KAAK,EAAE,KAAK;gBACZ,YAAY,EAAE,IAAI,CAAC,YAAY;gBAC/B,YAAY,EAAE,IAAI,CAAC,YAAY;aAClC,CAAC;YAEF,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAElC,OAAO,EAAE,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC,IAAI,CACpC,UAAU,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAC3B,CAAC;QACN,CAAC,CAAC,CACL;aACA,SAAS,CAAC,GAAG,EAAE;YACZ,IAAI,CAAC,WAAW,GAAG;gBACf,GAAG,IAAI,CAAC,WAAW;gBACnB,cAAc,EAAE;oBACZ,GAAG,IAAI,CAAC,WAAW,CAAC,cAAc;oBAClC,SAAS,EAAE,KAAK;iBACnB;aACJ,CAAC;YAEF,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QAC7B,CAAC,CAAC,CAAC;IACX,CAAC;IAED,IAAI,eAAe;QACf,OAAO,IAAI,CAAC,YAAY,CAAC,OAAsB,CAAC;IACpD,CAAC;IAEM,eAAe,CAAC,KAAc;QACjC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACnC,CAAC;IAEM,cAAc,CAAC,OAAe;QACjC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QAExB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACxC,CAAC;IAEM,gBAAgB,CAAC,KAAyB;QAC7C,IAAI,KAAK,EAAE,OAAO,EAAE,CAAC;YACjB,IAAI,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,KAAK,4BAA4B,CAAC,OAAO,EAAE,CAAC;gBAChE,MAAM,OAAO,GAAG,IAAI,CAAC,sBAAsB,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;gBAE3D,IAAI,OAAO,EAAE,CAAC;oBACV,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;oBACnC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;oBAC7B,6CAA6C;gBACjD,CAAC;YACL,CAAC;iBAAM,CAAC;gBACJ,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;gBACnC,6CAA6C;gBAC7C,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YACjC,CAAC;YAED,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;QACnC,CAAC;aAAM,CAAC;YACJ,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACzB,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;YAC/B,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;QACzB,CAAC;QACD,IAAI,CAAC,aAAa,EAAE,UAAU,EAAE,KAAK,EAAE,CAAC;IAC5C,CAAC;IAEM,UAAU,CACb,KAAoB,EACpB,IAAgC;QAEhC,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;QAExB,IACI,CAAC,IAAI,KAAK,8BAA8B,CAAC,OAAO;YAC5C,IAAI,CAAC,kBAAkB,CAAC;YAC5B,IAAI,KAAK,8BAA8B,CAAC,MAAM,EAChD,CAAC;YACC,IAAI,CAAC,kBAAmB,CAAC,IAAI,GAAG,IAAI,CAAC;YACrC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,kBAAkB,IAAI,EAAE,CAAC,CAAC;YAEtD,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QAC3B,CAAC;IACL,CAAC;IAEM,aAAa;QAChB,IAAI,CAAC,IAAI,CAAC,eAAe;YAAE,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;IAC3D,CAAC;IAEM,YAAY;QACf,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;IACjC,CAAC;IAEM,UAAU,CAAC,KAAoB;QAClC,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;QAC/B,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;QACrB,IAAI,CAAC,aAAa,EAAE,QAAQ,EAAE,UAAU,CAAC,KAAK,CAAC,CAAC;QAChD,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;IACpC,CAAC;IAEO,iBAAiB,CAAC,KAAa;QACnC,IAAI,CAAC,YAAY;YACb,KAAK,KAAK,0BAA0B,CAAC,YAAY;gBAC7C,CAAC,CAAC,CAAC,4BAA4B,CAAC,OAAO,CAAC;gBACxC,CAAC,CAAC,KAAK,KAAK,0BAA0B,CAAC,aAAa;oBAClD,CAAC,CAAC,CAAC,4BAA4B,CAAC,QAAQ,CAAC;oBACzC,CAAC,CAAC,EAAE,CAAC;IACnB,CAAC;IAEM,cAAc;QACjB,IAAI,IAAI,GAAG,KAAK,CAAC;QACjB,IAAI,IAAI,CAAC,QAAQ,KAAK,+BAA+B,CAAC,KAAK,EAAE,CAAC;YAC1D,IAAI,CAAC,QAAQ,GAAG,+BAA+B,CAAC,MAAM,CAAC;YACvD,IAAI,GAAG,IAAI,CAAC;QAChB,CAAC;aAAM,CAAC;YACJ,IAAI,CAAC,QAAQ,GAAG,+BAA+B,CAAC,KAAK,CAAC;QAC1D,CAAC;QAED,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAE3B,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC3B,IAAI,CAAC,aAAa,EAAE,QAAQ,EAAE,YAAY,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;YACjE,UAAU,CAAC,GAAG,EAAE;gBACZ,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,YAAY,GAAG,IAAI,CAAC;YACpD,CAAC,EAAE,GAAG,CAAC,CAAC;QACZ,CAAC;IACL,CAAC;IAEM,gBAAgB,CAAC,KAAc;QAClC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACpC,CAAC;IAEM,iBAAiB;QACpB,MAAM,WAAW,GAAG;YAChB,OAAO,EAAE,EAAE;YACX,KAAK,EAAE,KAAK;YACZ,OAAO,EAAE,EAAE;SACd,CAAC;QACF,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IAC3C,CAAC;IAEO,sBAAsB,CAAC,OAAe;QAC1C,MAAM,SAAS,GAAG,QAAQ,CAAC;QAE3B,OAAO,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC;IAClD,CAAC;IAED,WAAW;QACP,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC7B,CAAC;+GA3VQ,+BAA+B;mGAA/B,+BAA+B,01BCzF5C,+rGA+EA;gBDHQ,UAAU;gBACV,YAAY,4HACZ,WAAW,sIACX,SAAS,sWACT,mBAAmB,iNACnB,oBAAoB,gOACpB,gBAAgB;gBAEhB,aAAa;gBACb,wBAAwB,2iBACxB,uBAAuB;;4FAGlB,+BAA+B;kBAvB3C,SAAS;+BACI,+BAA+B,iBAM1B,iBAAiB,CAAC,IAAI,cACzB,IAAI,WACP;wBACL,UAAU;wBACV,YAAY;wBACZ,WAAW;wBACX,SAAS;wBACT,mBAAmB;wBACnB,oBAAoB;wBACpB,gBAAgB;wBAEhB,aAAa;wBACb,wBAAwB;wBACxB,uBAAuB;qBAC1B;;0BAiGI,IAAI;yEA3FT,aAAa;sBADZ,SAAS;uBAAC,eAAe,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAG/B,eAAe;sBAA3B,KAAK;gBAIc,mBAAmB;sBAAtC,KAAK;gBAWc,mBAAmB;sBAAtC,KAAK;gBAcW,gBAAgB;sBAAhC,MAAM;gBAGS,WAAW;sBAA1B,KAAK;gBACU,cAAc;sBAA7B,KAAK;gBACU,SAAS;sBAAxB,KAAK;gBACU,YAAY;sBAA3B,KAAK;gBACU,cAAc;sBAA7B,KAAK;gBACU,eAAe;sBAA9B,KAAK;gBAGI,eAAe;sBAAxB,MAAM;gBAEG,eAAe;sBAAxB,MAAM;gBAIP,aAAa;sBADZ,MAAM;gBAEG,YAAY;sBAArB,MAAM;gBAGG,UAAU;sBAAnB,MAAM;gBACG,cAAc;sBAAvB,MAAM;gBAIP,mBAAmB;sBADlB,YAAY;uBAAC,kBAAkB,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { FormControl, ReactiveFormsModule } from '@angular/forms';\nimport {\n    Component,\n    EventEmitter,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output,\n    Self,\n    ViewChild,\n    ViewEncapsulation,\n    ChangeDetectorRef,\n    HostListener,\n    AfterContentInit,\n} from '@angular/core';\nimport {\n    BehaviorSubject,\n    catchError,\n    debounceTime,\n    distinctUntilChanged,\n    filter,\n    Observable,\n    of,\n    Subject,\n    switchMap,\n    takeUntil,\n    tap,\n} from 'rxjs';\nimport {\n    UntypedFormGroup,\n    NgControl,\n    ControlValueAccessor,\n    FormsModule,\n} from '@angular/forms';\n\n// Config\nimport { ICaInput } from '../ca-input/config/ca-input.config';\n\n// Components\nimport { CaInputDropdownComponent } from '../ca-input-dropdown/ca-input-dropdown.component';\n\n// Modules\nimport { AngularSvgIconModule } from 'angular-svg-icon';\nimport { NgbModule } from '@ng-bootstrap/ng-bootstrap';\n\n// enums\nimport { InputAddressCommandsStringEnum } from './enums/input-address-commands-string.enum';\nimport { InputAddressStopTypesStringEnum } from './enums/input-address-stop-types-string.enum';\nimport { InputAddressTypeStringEnum } from './enums/input-address-type-string.enum';\nimport { InputAddressLayersStringEnum } from './enums/input-address-layers-string.enum';\nimport { eInputBasicString } from './enums/input-address-basic-string.enum';\n\n// models\nimport { AddressData } from './models/address-data.model';\nimport { AddressList } from './models/address-list.model';\nimport { CommandsHandler } from './models/commands-handler.model';\nimport { AutocompleteSearchLayer } from '../../models/autocomplete-search-layer.model';\nimport { CaAppTooltipV2Component } from '../ca-app-tooltip-v2/ca-app-tooltip-v2.component';\nimport { HttpClientModule } from '@angular/common/http';\nimport { InputAddressCommandsString } from './models/input-address-commands-string.model';\nimport { SentAddressData } from './models/sent-address-data.model';\nimport { AddressListResponse } from '../../models/address-list-response.model';\nimport { AddressEntity } from '../../models/address-entity.model';\nimport { addressNameWithDotValidator } from './validators/ca-input-address-value.validations';\n\n@Component({\n    selector: 'app-ca-input-address-dropdown',\n    templateUrl: './ca-input-address-dropdown.component.html',\n    styleUrls: [\n        './ca-input-address-dropdown.component.scss',\n        '../ca-input/ca-input.component.scss',\n    ],\n    encapsulation: ViewEncapsulation.None,\n    standalone: true,\n    imports: [\n        // Modules\n        CommonModule,\n        FormsModule,\n        NgbModule,\n        ReactiveFormsModule,\n        AngularSvgIconModule,\n        HttpClientModule,\n\n        // Components\n        CaInputDropdownComponent,\n        CaAppTooltipV2Component,\n    ],\n})\nexport class CaInputAddressDropdownComponent\n    implements OnInit, ControlValueAccessor, OnDestroy, AfterContentInit\n{\n    @ViewChild('inputDropdown', { static: true })\n    inputDropdown!: CaInputDropdownComponent;\n\n    @Input() set placeholderType(value: string) {\n        this.checkSearchLayers(value);\n    }\n\n    @Input() public set receivedAddressData(value: AddressData | null) {\n        if (value) {\n            this.currentAddressData = {\n                address: value.address!,\n                valid: value.address && value.longLat ? true : false,\n                longLat: value.longLat,\n            };\n\n            this.selectedAddress.emit(this.currentAddressData!);\n        }\n    }\n    @Input() public set receivedAddressList(value: AddressListResponse | null) {\n        this._receivedAddressList = value;\n        if (value?.addresses) {\n            this.addresList = value.addresses.map(\n                (item: string, indx: number) => {\n                    return {\n                        address: item,\n                        id: indx,\n                    };\n                }\n            );\n        }\n    }\n\n    @Output() public sentAddressValue: EventEmitter<string> =\n        new EventEmitter<string>();\n\n    @Input() public inputConfig!: ICaInput;\n    @Input() public commandHandler!: CommandsHandler;\n    @Input() public isRouting: boolean = false;\n    @Input() public closedBorder: boolean = false;\n    @Input() public incorrectValue!: boolean;\n    @Input() public hideEmptyLoaded: boolean = false;\n    public addresList!: AddressList[];\n\n    @Output() selectedAddress: EventEmitter<AddressData> =\n        new EventEmitter<AddressData>();\n    @Output() sentAddressData: EventEmitter<SentAddressData> =\n        new EventEmitter<SentAddressData>();\n\n    @Output()\n    closeDropdown: EventEmitter<boolean> = new EventEmitter<boolean>();\n    @Output() commandEvent: EventEmitter<AddressData | {}> = new EventEmitter<\n        AddressData | {}\n    >();\n    @Output() changeFlag: EventEmitter<boolean> = new EventEmitter<boolean>();\n    @Output() incorrectEvent: EventEmitter<boolean> =\n        new EventEmitter<boolean>();\n\n    @HostListener('document:keydown', ['$event'])\n    handleKeyboardEvent(event: KeyboardEvent) {\n        const key = event.key;\n        if (\n            this.inputConfig.name == InputAddressTypeStringEnum.ROUTING_ADDRESS\n        ) {\n            if (key === InputAddressCommandsStringEnum.ENTER) {\n                if (this.currentAddressData) {\n                    this.onCommands(\n                        event,\n                        InputAddressCommandsStringEnum.CONFIRM\n                    );\n                }\n            } else if (key === InputAddressCommandsStringEnum.ESCAPE) {\n                this.clearInput(event);\n            }\n        }\n    }\n\n    //Address data\n    private searchLayers!: AutocompleteSearchLayer[];\n    public currentAddressData: AddressData | null = null;\n\n    //Confg\n    public addressExpanded: boolean = false;\n    public chosenFromDropdown: boolean = false;\n    private allowValidation: boolean = false;\n    public stopType: string = InputAddressStopTypesStringEnum.EMPTY;\n    private requestSent: boolean = false;\n    public _receivedAddressList: AddressListResponse | null = null;\n\n    private destroy$ = new Subject<void>();\n    public addressForm!: UntypedFormGroup;\n\n    constructor(\n        @Self() public superControl: NgControl,\n        private ref: ChangeDetectorRef\n    ) {\n        this.superControl.valueAccessor = this;\n    }\n\n    ngAfterContentInit(): void {}\n\n    writeValue(address: any): void {\n        if (address) {\n            this.inputDropdown?.setDropdownValue(address, undefined, 'address');\n\n            this.onChange(address);\n        }\n    }\n\n    public registerOnChange(fn: any): void {\n        this.onChange = fn;\n    }\n\n    public onChange(_: any): void {}\n\n    public registerOnTouched(_: any): void {}\n\n    ngOnInit(): void {\n        this.initChangesListener();\n        this.attachAddressStreetValidation();\n    }\n\n    public attachAddressStreetValidation() {\n        const currentValidators = this.superControl.validator\n            ? [this.superControl.validator]\n            : [];\n        this.superControl?.control?.setValidators([\n            ...currentValidators,\n            addressNameWithDotValidator(),\n        ]);\n        this.superControl?.control?.updateValueAndValidity();\n    }\n\n    private observableInputSearch = new BehaviorSubject<string>('');\n    public observableInputSearch$: Observable<string> =\n        this.observableInputSearch.asObservable();\n\n    public handleSearchInput(text: string): void {\n        this.observableInputSearch.next(text);\n    }\n\n    public initChangesListener(): void {\n        this.observableInputSearch$\n            .pipe(\n                distinctUntilChanged(),\n                takeUntil(this.destroy$),\n                tap((term) => {\n                    this.inputConfig = {\n                        ...this.inputConfig,\n                        loadingSpinner: {\n                            ...this.inputConfig.loadingSpinner,\n                            isLoading: true,\n                            size: eInputBasicString.SMALL,\n                            color: eInputBasicString.WHITE,\n                        },\n                    };\n\n                    if (!term) {\n                        this.inputConfig = {\n                            ...this.inputConfig,\n                            loadingSpinner: {\n                                ...this.inputConfig.loadingSpinner,\n                                isLoading: false,\n                            },\n                        };\n                        this.addresList = [];\n                    } else if (\n                        term !== this.currentAddressData?.address.address &&\n                        this.inputConfig.name ===\n                            InputAddressTypeStringEnum.ROUTING_ADDRESS\n                    ) {\n                        this.currentAddressData = null;\n                    }\n                    if (\n                        this.inputConfig.name !==\n                            InputAddressTypeStringEnum.ROUTING_ADDRESS &&\n                        this.allowValidation &&\n                        this.inputDropdown.inputRef.isFocusInput\n                    ) {\n                        this.requestSent = false;\n                        const addressData = {\n                            address: {},\n                            valid: false,\n                            longLat: {},\n                        };\n                        this.selectedAddress.emit(addressData);\n                    }\n\n                    this.allowValidation = true;\n                }),\n                filter((term: string) => {\n                    return term?.length >= 3;\n                }),\n                debounceTime(500),\n                switchMap((query: string) => {\n                    const params = {\n                        query: query,\n                        searchLayers: this.searchLayers,\n                        closedBorder: this.closedBorder,\n                    };\n\n                    this.sentAddressData.next(params);\n\n                    return of(this.receivedAddressList).pipe(\n                        catchError(() => of([]))\n                    );\n                })\n            )\n            .subscribe(() => {\n                this.inputConfig = {\n                    ...this.inputConfig,\n                    loadingSpinner: {\n                        ...this.inputConfig.loadingSpinner,\n                        isLoading: false,\n                    },\n                };\n\n                this.ref.detectChanges();\n            });\n    }\n\n    get getSuperControl() {\n        return this.superControl.control as FormControl;\n    }\n\n    public onCloseDropdown(event: boolean): void {\n        this.closeDropdown.emit(event);\n    }\n\n    public getAddressData(address: string): void {\n        this.requestSent = true;\n\n        this.sentAddressValue.emit(address);\n    }\n\n    public onSelectDropdown(event: AddressList | null): void {\n        if (event?.address) {\n            if (this.searchLayers[0] === InputAddressLayersStringEnum.ADDRESS) {\n                const isValid = this.checkAddressValidation(event.address);\n\n                if (isValid) {\n                    this.getAddressData(event.address);\n                    this.onChange(event.address);\n                    //this.getSuperControl!.setValue(event.name);\n                }\n            } else {\n                this.getAddressData(event.address);\n                //this.getSuperControl!.setValue(event.name);\n                this.onChange(event.address);\n            }\n\n            this.chosenFromDropdown = true;\n        } else {\n            this.onClearInputEvent();\n            this.currentAddressData = null;\n            this.addresList = [];\n        }\n        this.inputDropdown?.popoverRef?.close();\n    }\n\n    public onCommands(\n        event: KeyboardEvent,\n        type: InputAddressCommandsString\n    ): void {\n        event.preventDefault();\n        event.stopPropagation();\n\n        if (\n            (type === InputAddressCommandsStringEnum.CONFIRM &&\n                this.currentAddressData) ||\n            type === InputAddressCommandsStringEnum.CANCEL\n        ) {\n            this.currentAddressData!.type = type;\n            this.commandEvent.emit(this.currentAddressData ?? {});\n\n            this.closeAddress();\n            this.clearInput(event);\n        }\n    }\n\n    public addressExpand(): void {\n        if (!this.addressExpanded) this.addressExpanded = true;\n    }\n\n    public closeAddress(): void {\n        this.addressExpanded = false;\n    }\n\n    public clearInput(event: KeyboardEvent): void {\n        this.currentAddressData = null;\n        this.addresList = [];\n        this.inputDropdown?.inputRef?.clearInput(event);\n        this.chosenFromDropdown = false;\n    }\n\n    private checkSearchLayers(value: string): void {\n        this.searchLayers =\n            value === InputAddressTypeStringEnum.LONG_ADDRESS\n                ? [InputAddressLayersStringEnum.ADDRESS]\n                : value === InputAddressTypeStringEnum.SHORT_ADDRESS\n                  ? [InputAddressLayersStringEnum.LOCALITY]\n                  : [];\n    }\n\n    public changeStopType(): void {\n        let flag = false;\n        if (this.stopType === InputAddressStopTypesStringEnum.EMPTY) {\n            this.stopType = InputAddressStopTypesStringEnum.LOADED;\n            flag = true;\n        } else {\n            this.stopType = InputAddressStopTypesStringEnum.EMPTY;\n        }\n\n        this.changeFlag.emit(flag);\n\n        if (!this.chosenFromDropdown) {\n            this.inputDropdown?.inputRef?.inputElement.nativeElement.focus();\n            setTimeout(() => {\n                this.inputDropdown.inputRef.isFocusInput = true;\n            }, 500);\n        }\n    }\n\n    public onIncorrectInput(event: boolean): void {\n        this.incorrectEvent.emit(event);\n    }\n\n    public onClearInputEvent(): void {\n        const addressData = {\n            address: {},\n            valid: false,\n            longLat: {},\n        };\n        this.selectedAddress.emit(addressData);\n    }\n\n    private checkAddressValidation(address: string): boolean {\n        const streetNum = /\\d.*\\d/;\n\n        return streetNum.test(address) ? true : false;\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n}\n","<div class=\"address_holder d-flex align-items-center\" (click)=\"addressExpand()\">\n    <div\n        class=\"main_address_holder\"\n        [ngClass]=\"{\n            input_for_routing: isRouting,\n            not_expanded: isRouting && !addressExpanded,\n            expanded_address: isRouting && addressExpanded,\n        }\"\n    >\n        <app-ca-input-dropdown\n            [label]=\"'address'\"\n            #inputDropdown\n            [formControl]=\"getSuperControl\"\n            [inputConfig]=\"inputConfig\"\n            [options]=\"addresList\"\n            [activeItem]=\"getSuperControl?.value\"\n            [isIncorrectValue]=\"incorrectValue\"\n            [isAddressDropdown]=\"true\"\n            (incorrectEvent)=\"onIncorrectInput($event)\"\n            (selectedItem)=\"onSelectDropdown($event)\"\n            (closeDropdown)=\"onCloseDropdown($event)\"\n            (clearInputEvent)=\"onClearInputEvent()\"\n            (searchInputEvent)=\"handleSearchInput($event)\"\n        ></app-ca-input-dropdown>\n        @if (isRouting && addressExpanded && !hideEmptyLoaded) {\n            <div\n                class=\"stop_hold d-flex justify-content-center align-items-center\"\n                (click)=\"changeStopType()\"\n            >\n                <div class=\"stop_text\">{{ stopType }}</div>\n            </div>\n        }\n    </div>\n    @if (isRouting && addressExpanded) {\n        <div class=\"ca-input-commands address-flag d-flex align-items-center\">\n            <div\n                class=\"main-commands ca-input-command-first\"\n                ngbTooltip\n                [mainCaTooltip]=\"\n                    commandHandler.commands?.firstCommand?.popup?.name\n                \"\n                [tooltipBackground]=\"\n                    commandHandler.commands?.firstCommand?.popup\n                        ?.backgroundColor\n                \"\n                [disableTooltip]=\"!commandHandler.commands?.firstCommand?.popup\"\n                position=\"top\"\n            >\n                <svg-icon\n                    class=\"ca-input-command-svg-first\"\n                    [class.allow_confirm]=\"chosenFromDropdown\"\n                    [src]=\"commandHandler.commands.firstCommand.svg\"\n                    (keydown)=\"onCommands($event, 'confirm')\"\n                ></svg-icon>\n            </div>\n            <div\n                class=\"main-commands ca-input-command-second\"\n                ngbTooltip\n                [mainCaTooltip]=\"\n                    commandHandler.commands?.secondCommand?.popup?.name\n                \"\n                [tooltipBackground]=\"\n                    commandHandler.commands?.secondCommand?.popup\n                        ?.backgroundColor\n                \"\n                [disableTooltip]=\"\n                    !commandHandler.commands?.secondCommand?.popup\n                \"\n                position=\"top\"\n            >\n                <svg-icon\n                    class=\"ca-input-command-svg-second\"\n                    [src]=\"commandHandler.commands.secondCommand.svg\"\n                    (keydown)=\"onCommands($event, 'cancel')\"\n                ></svg-icon>\n            </div>\n        </div>\n    }\n</div>\n"]}
|
|
350
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-input-address-dropdown.component.js","sourceRoot":"","sources":["../../../../../../projects/ca-components/src/lib/components/ca-input-address-dropdown/ca-input-address-dropdown.component.ts","../../../../../../projects/ca-components/src/lib/components/ca-input-address-dropdown/ca-input-address-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { FormControl, ReactiveFormsModule } from '@angular/forms';\nimport {\n    Component,\n    EventEmitter,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output,\n    Self,\n    ViewChild,\n    ViewEncapsulation,\n    ChangeDetectorRef,\n    HostListener,\n    AfterContentInit,\n} from '@angular/core';\nimport {\n    BehaviorSubject,\n    catchError,\n    debounceTime,\n    distinctUntilChanged,\n    filter,\n    Observable,\n    of,\n    Subject,\n    switchMap,\n    takeUntil,\n    tap,\n} from 'rxjs';\nimport {\n    UntypedFormGroup,\n    NgControl,\n    ControlValueAccessor,\n    FormsModule,\n} from '@angular/forms';\n\n// Config\nimport { ICaInput } from '../ca-input/config/ca-input.config';\n\n// Components\nimport { CaInputDropdownComponent } from '../ca-input-dropdown/ca-input-dropdown.component';\n\n// Modules\nimport { AngularSvgIconModule } from 'angular-svg-icon';\nimport { NgbModule } from '@ng-bootstrap/ng-bootstrap';\n\n// enums\nimport { InputAddressCommandsStringEnum } from './enums/input-address-commands-string.enum';\nimport { InputAddressStopTypesStringEnum } from './enums/input-address-stop-types-string.enum';\nimport { InputAddressTypeStringEnum } from './enums/input-address-type-string.enum';\nimport { InputAddressLayersStringEnum } from './enums/input-address-layers-string.enum';\nimport { eInputBasicString } from './enums/input-address-basic-string.enum';\n\n// models\nimport { AddressData } from './models/address-data.model';\nimport { AddressList } from './models/address-list.model';\nimport { CommandsHandler } from './models/commands-handler.model';\nimport { AutocompleteSearchLayer } from '../../models/autocomplete-search-layer.model';\nimport { CaAppTooltipV2Component } from '../ca-app-tooltip-v2/ca-app-tooltip-v2.component';\nimport { HttpClientModule } from '@angular/common/http';\nimport { InputAddressCommandsString } from './models/input-address-commands-string.model';\nimport { SentAddressData } from './models/sent-address-data.model';\nimport { AddressListResponse } from '../../models/address-list-response.model';\nimport { AddressEntity } from '../../models/address-entity.model';\nimport { addressNameWithDotValidator } from './validators/ca-input-address-value.validations';\n\n@Component({\n    selector: 'app-ca-input-address-dropdown',\n    templateUrl: './ca-input-address-dropdown.component.html',\n    styleUrls: [\n        './ca-input-address-dropdown.component.scss',\n        '../ca-input/ca-input.component.scss',\n    ],\n    encapsulation: ViewEncapsulation.None,\n    standalone: true,\n    imports: [\n        // Modules\n        CommonModule,\n        FormsModule,\n        NgbModule,\n        ReactiveFormsModule,\n        AngularSvgIconModule,\n        HttpClientModule,\n\n        // Components\n        CaInputDropdownComponent,\n        CaAppTooltipV2Component,\n    ],\n})\nexport class CaInputAddressDropdownComponent\n    implements OnInit, ControlValueAccessor, OnDestroy, AfterContentInit\n{\n    @ViewChild('inputDropdown', { static: true })\n    inputDropdown!: CaInputDropdownComponent;\n\n    @Input() set placeholderType(value: string) {\n        this.checkSearchLayers(value);\n    }\n\n    @Input() public set receivedAddressData(value: AddressData | null) {\n        if (value) {\n            this.currentAddressData = {\n                address: value.address!,\n                valid: value.address && value.longLat ? true : false,\n                longLat: value.longLat,\n            };\n\n            this.onChange({\n                ...value.address,\n                latitude: value.longLat?.latitude,\n                longitude: value.longLat?.longitude,\n            });\n\n            this.selectedAddress.emit(this.currentAddressData!);\n        }\n    }\n    @Input() public set receivedAddressList(value: AddressListResponse | null) {\n        this._receivedAddressList = value;\n        if (value?.addresses) {\n            this.addresList = value.addresses.map(\n                (item: string, indx: number) => {\n                    return {\n                        address: item,\n                        id: indx,\n                    };\n                }\n            );\n        }\n    }\n\n    @Output() public sentAddressValue: EventEmitter<string> =\n        new EventEmitter<string>();\n\n    @Input() public inputConfig!: ICaInput;\n    @Input() public commandHandler!: CommandsHandler;\n    @Input() public isRouting: boolean = false;\n    @Input() public closedBorder: boolean = false;\n    @Input() public incorrectValue!: boolean;\n    @Input() public hideEmptyLoaded: boolean = false;\n    public addresList!: AddressList[];\n\n    @Output() selectedAddress: EventEmitter<AddressData> =\n        new EventEmitter<AddressData>();\n    @Output() sentAddressData: EventEmitter<SentAddressData> =\n        new EventEmitter<SentAddressData>();\n\n    @Output()\n    closeDropdown: EventEmitter<boolean> = new EventEmitter<boolean>();\n    @Output() commandEvent: EventEmitter<AddressData | {}> = new EventEmitter<\n        AddressData | {}\n    >();\n    @Output() changeFlag: EventEmitter<boolean> = new EventEmitter<boolean>();\n    @Output() incorrectEvent: EventEmitter<boolean> =\n        new EventEmitter<boolean>();\n\n    @HostListener('document:keydown', ['$event'])\n    handleKeyboardEvent(event: KeyboardEvent) {\n        const key = event.key;\n        if (\n            this.inputConfig.name == InputAddressTypeStringEnum.ROUTING_ADDRESS\n        ) {\n            if (key === InputAddressCommandsStringEnum.ENTER) {\n                if (this.currentAddressData) {\n                    this.onCommands(\n                        event,\n                        InputAddressCommandsStringEnum.CONFIRM\n                    );\n                }\n            } else if (key === InputAddressCommandsStringEnum.ESCAPE) {\n                this.clearInput(event);\n            }\n        }\n    }\n\n    //Address data\n    private searchLayers!: AutocompleteSearchLayer[];\n    public currentAddressData: AddressData | null = null;\n\n    //Confg\n    public addressExpanded: boolean = false;\n    public chosenFromDropdown: boolean = false;\n    private allowValidation: boolean = false;\n    public stopType: string = InputAddressStopTypesStringEnum.EMPTY;\n    private requestSent: boolean = false;\n    public _receivedAddressList: AddressListResponse | null = null;\n\n    private destroy$ = new Subject<void>();\n    public addressForm!: UntypedFormGroup;\n\n    constructor(\n        @Self() public superControl: NgControl,\n        private ref: ChangeDetectorRef\n    ) {\n        this.superControl.valueAccessor = this;\n    }\n\n    ngAfterContentInit(): void {}\n\n    writeValue(address: any): void {\n        if (address) {\n            this.inputDropdown?.setDropdownValue(address, undefined, 'address');\n\n            this.onChange(address);\n        }\n    }\n\n    public registerOnChange(fn: any): void {\n        this.onChange = fn;\n    }\n\n    public onChange(_: any): void {}\n\n    public registerOnTouched(_: any): void {}\n\n    ngOnInit(): void {\n        this.initChangesListener();\n        this.attachAddressStreetValidation();\n    }\n\n    public attachAddressStreetValidation() {\n        const currentValidators = this.superControl.validator\n            ? [this.superControl.validator]\n            : [];\n        this.superControl?.control?.setValidators([\n            ...currentValidators,\n            addressNameWithDotValidator(),\n        ]);\n        this.superControl?.control?.updateValueAndValidity();\n    }\n\n    private observableInputSearch = new BehaviorSubject<string>('');\n    public observableInputSearch$: Observable<string> =\n        this.observableInputSearch.asObservable();\n\n    public handleSearchInput(text: string): void {\n        this.observableInputSearch.next(text);\n    }\n\n    public initChangesListener(): void {\n        this.observableInputSearch$\n            .pipe(\n                distinctUntilChanged(),\n                takeUntil(this.destroy$),\n                tap((term) => {\n                    this.inputConfig = {\n                        ...this.inputConfig,\n                        loadingSpinner: {\n                            ...this.inputConfig.loadingSpinner,\n                            isLoading: true,\n                            size: eInputBasicString.SMALL,\n                            color: eInputBasicString.WHITE,\n                        },\n                    };\n\n                    if (!term) {\n                        this.inputConfig = {\n                            ...this.inputConfig,\n                            loadingSpinner: {\n                                ...this.inputConfig.loadingSpinner,\n                                isLoading: false,\n                            },\n                        };\n                        this.addresList = [];\n                    } else if (\n                        term !== this.currentAddressData?.address.address &&\n                        this.inputConfig.name ===\n                            InputAddressTypeStringEnum.ROUTING_ADDRESS\n                    ) {\n                        this.currentAddressData = null;\n                    }\n                    if (\n                        this.inputConfig.name !==\n                            InputAddressTypeStringEnum.ROUTING_ADDRESS &&\n                        this.allowValidation &&\n                        this.inputDropdown.inputRef.isFocusInput\n                    ) {\n                        this.requestSent = false;\n                        const addressData = {\n                            address: {},\n                            valid: false,\n                            longLat: {},\n                        };\n                        this.selectedAddress.emit(addressData);\n                    }\n\n                    this.allowValidation = true;\n                }),\n                filter((term: string) => {\n                    return term?.length >= 3;\n                }),\n                debounceTime(500),\n                switchMap((query: string) => {\n                    const params = {\n                        query: query,\n                        searchLayers: this.searchLayers,\n                        closedBorder: this.closedBorder,\n                    };\n\n                    this.sentAddressData.next(params);\n\n                    return of(this.receivedAddressList).pipe(\n                        catchError(() => of([]))\n                    );\n                })\n            )\n            .subscribe(() => {\n                this.inputConfig = {\n                    ...this.inputConfig,\n                    loadingSpinner: {\n                        ...this.inputConfig.loadingSpinner,\n                        isLoading: false,\n                    },\n                };\n\n                this.ref.detectChanges();\n            });\n    }\n\n    get getSuperControl() {\n        return this.superControl.control as FormControl;\n    }\n\n    public onCloseDropdown(event: boolean): void {\n        this.closeDropdown.emit(event);\n    }\n\n    public getAddressData(address: string): void {\n        this.requestSent = true;\n\n        this.sentAddressValue.emit(address);\n    }\n\n    public onSelectDropdown(event: AddressList | null): void {\n        if (event?.address) {\n            if (this.searchLayers[0] === InputAddressLayersStringEnum.ADDRESS) {\n                const isValid = this.checkAddressValidation(event.address);\n\n                if (isValid) {\n                    this.getAddressData(event.address);\n                    this.onChange(event.address);\n                    //this.getSuperControl!.setValue(event.name);\n                }\n            } else {\n                this.getAddressData(event.address);\n                //this.getSuperControl!.setValue(event.name);\n                this.onChange(event.address);\n            }\n\n            this.chosenFromDropdown = true;\n        } else {\n            this.onClearInputEvent();\n            this.currentAddressData = null;\n            this.addresList = [];\n        }\n        this.inputDropdown?.popoverRef?.close();\n    }\n\n    public onCommands(\n        event: KeyboardEvent,\n        type: InputAddressCommandsString\n    ): void {\n        event.preventDefault();\n        event.stopPropagation();\n\n        if (\n            (type === InputAddressCommandsStringEnum.CONFIRM &&\n                this.currentAddressData) ||\n            type === InputAddressCommandsStringEnum.CANCEL\n        ) {\n            this.currentAddressData!.type = type;\n            this.commandEvent.emit(this.currentAddressData ?? {});\n\n            this.closeAddress();\n            this.clearInput(event);\n        }\n    }\n\n    public addressExpand(): void {\n        if (!this.addressExpanded) this.addressExpanded = true;\n    }\n\n    public closeAddress(): void {\n        this.addressExpanded = false;\n    }\n\n    public clearInput(event: KeyboardEvent): void {\n        this.currentAddressData = null;\n        this.addresList = [];\n        this.inputDropdown?.inputRef?.clearInput(event);\n        this.chosenFromDropdown = false;\n    }\n\n    private checkSearchLayers(value: string): void {\n        this.searchLayers =\n            value === InputAddressTypeStringEnum.LONG_ADDRESS\n                ? [InputAddressLayersStringEnum.ADDRESS]\n                : value === InputAddressTypeStringEnum.SHORT_ADDRESS\n                  ? [InputAddressLayersStringEnum.LOCALITY]\n                  : [];\n    }\n\n    public changeStopType(): void {\n        let flag = false;\n        if (this.stopType === InputAddressStopTypesStringEnum.EMPTY) {\n            this.stopType = InputAddressStopTypesStringEnum.LOADED;\n            flag = true;\n        } else {\n            this.stopType = InputAddressStopTypesStringEnum.EMPTY;\n        }\n\n        this.changeFlag.emit(flag);\n\n        if (!this.chosenFromDropdown) {\n            this.inputDropdown?.inputRef?.inputElement.nativeElement.focus();\n            setTimeout(() => {\n                this.inputDropdown.inputRef.isFocusInput = true;\n            }, 500);\n        }\n    }\n\n    public onIncorrectInput(event: boolean): void {\n        this.incorrectEvent.emit(event);\n    }\n\n    public onClearInputEvent(): void {\n        const addressData = {\n            address: {},\n            valid: false,\n            longLat: {},\n        };\n        this.selectedAddress.emit(addressData);\n    }\n\n    private checkAddressValidation(address: string): boolean {\n        const streetNum = /\\d.*\\d/;\n\n        return streetNum.test(address) ? true : false;\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n}\n","<div class=\"address_holder d-flex align-items-center\" (click)=\"addressExpand()\">\n    <div\n        class=\"main_address_holder\"\n        [ngClass]=\"{\n            input_for_routing: isRouting,\n            not_expanded: isRouting && !addressExpanded,\n            expanded_address: isRouting && addressExpanded,\n        }\"\n    >\n        <app-ca-input-dropdown\n            [label]=\"'address'\"\n            #inputDropdown\n            [formControl]=\"getSuperControl\"\n            [inputConfig]=\"inputConfig\"\n            [options]=\"addresList\"\n            [activeItem]=\"getSuperControl?.value\"\n            [isIncorrectValue]=\"incorrectValue\"\n            [isAddressDropdown]=\"true\"\n            (incorrectEvent)=\"onIncorrectInput($event)\"\n            (selectedItem)=\"onSelectDropdown($event)\"\n            (closeDropdown)=\"onCloseDropdown($event)\"\n            (clearInputEvent)=\"onClearInputEvent()\"\n            (searchInputEvent)=\"handleSearchInput($event)\"\n        ></app-ca-input-dropdown>\n        @if (isRouting && addressExpanded && !hideEmptyLoaded) {\n            <div\n                class=\"stop_hold d-flex justify-content-center align-items-center\"\n                (click)=\"changeStopType()\"\n            >\n                <div class=\"stop_text\">{{ stopType }}</div>\n            </div>\n        }\n    </div>\n    @if (isRouting && addressExpanded) {\n        <div class=\"ca-input-commands address-flag d-flex align-items-center\">\n            <div\n                class=\"main-commands ca-input-command-first\"\n                ngbTooltip\n                [mainCaTooltip]=\"\n                    commandHandler.commands?.firstCommand?.popup?.name\n                \"\n                [tooltipBackground]=\"\n                    commandHandler.commands?.firstCommand?.popup\n                        ?.backgroundColor\n                \"\n                [disableTooltip]=\"!commandHandler.commands?.firstCommand?.popup\"\n                position=\"top\"\n            >\n                <svg-icon\n                    class=\"ca-input-command-svg-first\"\n                    [class.allow_confirm]=\"chosenFromDropdown\"\n                    [src]=\"commandHandler.commands.firstCommand.svg\"\n                    (keydown)=\"onCommands($event, 'confirm')\"\n                ></svg-icon>\n            </div>\n            <div\n                class=\"main-commands ca-input-command-second\"\n                ngbTooltip\n                [mainCaTooltip]=\"\n                    commandHandler.commands?.secondCommand?.popup?.name\n                \"\n                [tooltipBackground]=\"\n                    commandHandler.commands?.secondCommand?.popup\n                        ?.backgroundColor\n                \"\n                [disableTooltip]=\"\n                    !commandHandler.commands?.secondCommand?.popup\n                \"\n                position=\"top\"\n            >\n                <svg-icon\n                    class=\"ca-input-command-svg-second\"\n                    [src]=\"commandHandler.commands.secondCommand.svg\"\n                    (keydown)=\"onCommands($event, 'cancel')\"\n                ></svg-icon>\n            </div>\n        </div>\n    }\n</div>\n"]}
|
|
@@ -339,7 +339,7 @@ export class CaMapComponent {
|
|
|
339
339
|
this.destroy$.complete();
|
|
340
340
|
}
|
|
341
341
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CaMapComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i1.MapMarkerIconService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
342
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: CaMapComponent, isStandalone: true, selector: "app-ca-map", inputs: { data: "data" }, outputs: { resetSelectedMarkerItem: "resetSelectedMarkerItem", clusterMarkerClick: "clusterMarkerClick", clusterListScrollEvent: "clusterListScrollEvent", getInfoWindowData: "getInfoWindowData", boundsChanged: "boundsChanged", openInMapEvent: "openInMapEvent" }, viewQueries: [{ propertyName: "maps", first: true, predicate: GoogleMap, descendants: true }, { propertyName: "markerDropdown", first: true, predicate: ["markerDropdown"], descendants: true }, { propertyName: "clusterDropdown", first: true, predicate: ["clusterDropdown"], descendants: true }], ngImport: i0, template: "<google-map\n class=\"position-relative\"\n [class.dark-mode-map]=\"mapData.darkMode\"\n height=\"100%\"\n width=\"100%\"\n [zoom]=\"mapZoom\"\n [center]=\"mapCenter\"\n [options]=\"mapOptions\"\n (mapInitialized)=\"onMapReady($event)\"\n [mapId]=\"mapStyleId\"\n>\n @for (marker of mapData.markers; let i = $index; track marker.data.id) {\n <map-advanced-marker\n [position]=\"marker.position\"\n [content]=\"marker.content\"\n [zIndex]=\"\n openedInfoWindowData?.data?.id === marker.data.id ? 999 : i\n \"\n (mapClick)=\"onMarkerClick(marker)\"\n >\n </map-advanced-marker>\n }\n\n <div\n #markerDropdown\n class=\"marker-dropdown dropdown-hidden\"\n [ngClass]=\"{ 'dropdown-hidden': !isMarkerDropdownOpen }\"\n >\n <app-ca-map-dropdown\n [infoWindowContent]=\"\n !isClusterDropdownOpen\n ? openedInfoWindowData?.infoWindowContent\n : null\n \"\n [markerData]=\"openedInfoWindowData?.data\"\n (onClusterItemClick)=\"getMarkerInfoWindow($event)\"\n (onClusterListScrollToEnd)=\"onClusterListScrollToEnd()\"\n (onBackButtonClick)=\"onClusterBackButtonClick()\"\n ></app-ca-map-dropdown>\n </div>\n\n @for (\n clusterMarker of mapData.clusterMarkers;\n let i = $index;\n track trackByPosition($index, clusterMarker)\n ) {\n <map-advanced-marker\n [position]=\"clusterMarker.position\"\n [content]=\"clusterMarker.content\"\n [zIndex]=\"\n checkInfoWindowPosition(clusterMarker, openedInfoWindowData)\n ? 999\n : i\n \"\n (mapClick)=\"onClusterMarkerClick(clusterMarker)\"\n >\n </map-advanced-marker>\n }\n\n @for (route of routePolylines; let i = $index; track i) {\n <map-polyline [options]=\"route\"></map-polyline>\n }\n\n <div\n #clusterDropdown\n class=\"marker-dropdown cluster-dropdown dropdown-hidden\"\n [ngClass]=\"{ 'dropdown-hidden': !isClusterDropdownOpen }\"\n >\n <app-ca-map-dropdown\n [infoWindowContent]=\"\n !isMarkerDropdownOpen\n ? openedInfoWindowData?.infoWindowContent\n : null\n \"\n [markerData]=\"openedInfoWindowData?.data\"\n (onClusterItemClick)=\"getMarkerInfoWindow($event)\"\n (onClusterListScrollToEnd)=\"onClusterListScrollToEnd()\"\n (onBackButtonClick)=\"onClusterBackButtonClick()\"\n ></app-ca-map-dropdown>\n </div>\n\n @if (isAreaFilterActive) {\n <map-circle\n [options]=\"areaFilterData.options\"\n [center]=\"areaFilterData.center\"\n [radius]=\"areaFilterData.radius\"\n ></map-circle>\n }\n\n @for (\n routingMarker of mapData.routingMarkers;\n let i = $index;\n track trackByPosition($index, routingMarker)\n ) {\n <map-advanced-marker\n [position]=\"routingMarker.position\"\n [content]=\"routingMarker.content\"\n >\n </map-advanced-marker>\n }\n\n @if (mapData.isOpenInMapShown) {\n <div\n class=\"open-in-map-container d-flex align-items-center justify-content-center\"\n ngbTooltip\n mainCaTooltip=\"Open in Map\"\n tooltipBackground=\"#424242\"\n position=\"bottom\"\n (click)=\"onOpenInMap()\"\n >\n <svg-icon\n class=\"d-flex\"\n src=\"assets/ca-components/svg/common/ic_location_map.svg\"\n [svgStyle]=\"{ 'width.px': 18, 'height.px': 18 }\"\n ></svg-icon>\n </div>\n }\n\n @if (mapData.isZoomShown) {\n <div\n class=\"map-zoom-container d-flex flex-column align-items-end gap-1\"\n [ngClass]=\"{\n 'flex-column': !mapData.isVerticalZoom,\n 'vertical-zoom-buttons': mapData.isVerticalZoom,\n }\"\n >\n <div\n class=\"map-zoom-buttons d-flex align-items-center\"\n [class.flex-column]=\"mapData.isVerticalZoom\"\n >\n <div\n class=\"zoom-button-container d-flex align-items-center justify-content-center flex-1\"\n (click)=\"onZoomChange(true)\"\n >\n <svg-icon\n class=\"d-flex\"\n src=\"assets/ca-components/svg/popup/Minus.svg\"\n [svgStyle]=\"{ 'width.px': 14, 'height.px': 14 }\"\n ></svg-icon>\n </div>\n <div\n class=\"zoom-button-container d-flex align-items-center justify-content-center flex-1\"\n (click)=\"onZoomChange(false)\"\n >\n <svg-icon\n class=\"d-flex\"\n src=\"assets/ca-components/svg/common/ic_plus.svg\"\n [svgStyle]=\"{ 'width.px': 14, 'height.px': 14 }\"\n ></svg-icon>\n </div>\n </div>\n <div class=\"map-zoom-range d-flex align-items-center\">\n <div class=\"range-line\"></div>\n <div class=\"range-text ca-font-medium\">50 mi</div>\n <div class=\"range-line\"></div>\n </div>\n </div>\n }\n</google-map>\n", styles: ["@keyframes dropdown{0%{margin-top:20px;visibility:hidden;opacity:0}to{opacity:1;margin-top:10px;visibility:visible!important}}@keyframes dropup{0%{margin-top:-19px;visibility:hidden;opacity:0}to{margin-top:inherit;visibility:visible!important}}.gm-style-iw-a .gm-style-iw-t .gm-style-iw.gm-style-iw-c{padding:0!important;border-radius:3px!important;top:70px!important;transform:translate(-50%)!important}.gm-style-iw-a .gm-style-iw-t .gm-style-iw-tc{display:none!important}.gm-style div[aria-hidden=true],.marker-label{position:absolute;left:100%;top:50%;transform:translateY(-50%);width:100px;opacity:1;transition:opacity .2s ease-in-out;text-shadow:1px 1px 0px #ffffff,1px -1px 0px #ffffff,-1px -1px 0px #ffffff,-1px 1px 0px #ffffff;font-size:11px;line-height:12px;text-align:left;font-weight:500;font-family:Montserrat,sans-serif!important;color:#424242;white-space:nowrap;text-overflow:ellipsis;overflow:hidden;-webkit-user-select:none;user-select:none}@supports (-webkit-line-clamp: 2){.gm-style div[aria-hidden=true],.marker-label{overflow:hidden;text-overflow:ellipsis;white-space:initial;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}}.map-zoom-container{position:absolute;right:8px;bottom:16px}.map-zoom-container .map-zoom-buttons{width:52px;min-height:26px;background:#fff;border-width:3px;border-style:solid;border-color:#eee;border-radius:2px}.map-zoom-container .map-zoom-buttons .zoom-button-container{height:100%}.map-zoom-container .map-zoom-buttons .zoom-button-container svg-icon svg path{transition:fill .2s ease-in-out;fill:#919191}.map-zoom-container .map-zoom-buttons .zoom-button-container:hover{cursor:pointer}.map-zoom-container .map-zoom-buttons .zoom-button-container:hover svg-icon svg path{fill:#424242}.map-zoom-container .map-zoom-range{gap:2px;background:#fff;padding:0 4px;border-width:3px;border-style:solid;border-color:#eee;border-radius:2px}.map-zoom-container .map-zoom-range .range-text{min-width:fit-content;font-size:8px;line-height:10px;color:#424242;-webkit-user-select:none;user-select:none}.map-zoom-container .map-zoom-range .range-line{width:38px;height:2px;border-radius:1px;background:#919191}.map-zoom-container.vertical-zoom-buttons .map-zoom-range{order:1}.map-zoom-container.vertical-zoom-buttons .map-zoom-buttons{order:2;width:26px;min-height:52px}.map-zoom-container.vertical-zoom-buttons .map-zoom-buttons .zoom-button-container:first-child{order:2}.open-in-map-container{position:absolute;top:4px;right:4px;width:30px;height:30px;background:#6c6c6ce6;border-radius:1px}.open-in-map-container svg-icon svg path{transition:fill .2s ease-in-out;fill:#dadada}.open-in-map-container:hover{cursor:pointer}.open-in-map-container:hover svg-icon svg path{fill:#fff}.dark-mode-map .map-zoom-container .map-zoom-buttons,.dark-mode-map .map-zoom-range{background:#2f2f2f;border-color:#1d1d1d}.dark-mode-map .map-zoom-range .range-text{color:#fff}.marker-icon{position:relative}.marker-icon .marker-svg{transform:scale(1);transform-origin:center 30px;transition:transform .2s ease-in-out}.marker-icon .marker-svg .outside-circle,.marker-icon .marker-svg .white-circle,.marker-icon .marker-svg .inside-shape{transform-origin:center;transition:transform .2s ease-in-out}.marker-icon .marker-svg .shadow-circle{transition:transform .2s ease-in-out;transform-origin:14px 30px}.marker-icon.selected .marker-svg,.marker-icon.selected-permanently .marker-svg{transform:scale(1.5);transition:transform .2s ease-in-out}.marker-icon.selected .marker-svg .outside-circle,.marker-icon.selected-permanently .marker-svg .outside-circle{transform:scale(1.074)}.marker-icon.selected .marker-svg .white-circle,.marker-icon.selected-permanently .marker-svg .white-circle{transform:scale(.8665)}.marker-icon.selected .marker-svg .shadow-circle,.marker-icon.selected-permanently .marker-svg .shadow-circle{transform:scale(.889,.667)}.marker-icon.selected .marker-label,.marker-icon.selected-permanently .marker-label{opacity:0;pointer-events:none!important}.marker-icon.selected-permanently .marker-label{top:8px;left:calc(100% + 4px)}.marker-icon.selected-permanently:hover .marker-label{opacity:1!important}.marker-dropdown{position:absolute;top:35px;left:50%;transition:transform .2s ease-in-out,opacity .2s ease-in-out;transform:translate(-50%) scale(1);opacity:1;width:360px;min-height:64px;padding:0;background:#fff;box-shadow:0 0 4px #00000026;border-radius:3px;pointer-events:none}.marker-dropdown.dropdown-hidden{transform:translate(-50%) scale(.5);opacity:0;pointer-events:none!important}.marker-dropdown.cluster-dropdown{top:55px}.cluster-icon{position:relative}.cluster-icon .marker-svg g path{fill:#fff;transition:all .2s ease-in-out}.cluster-icon.selected .marker-svg g path{fill:#fab15c}\n"], dependencies: [{ kind: "ngmodule", type:
|
|
342
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: CaMapComponent, isStandalone: true, selector: "app-ca-map", inputs: { data: "data" }, outputs: { resetSelectedMarkerItem: "resetSelectedMarkerItem", clusterMarkerClick: "clusterMarkerClick", clusterListScrollEvent: "clusterListScrollEvent", getInfoWindowData: "getInfoWindowData", boundsChanged: "boundsChanged", openInMapEvent: "openInMapEvent" }, viewQueries: [{ propertyName: "maps", first: true, predicate: GoogleMap, descendants: true }, { propertyName: "markerDropdown", first: true, predicate: ["markerDropdown"], descendants: true }, { propertyName: "clusterDropdown", first: true, predicate: ["clusterDropdown"], descendants: true }], ngImport: i0, template: "<google-map\n class=\"position-relative\"\n [class.dark-mode-map]=\"mapData.darkMode\"\n height=\"100%\"\n width=\"100%\"\n [zoom]=\"mapZoom\"\n [center]=\"mapCenter\"\n [options]=\"mapOptions\"\n (mapInitialized)=\"onMapReady($event)\"\n [mapId]=\"mapStyleId\"\n>\n @for (marker of mapData.markers; let i = $index; track marker.data.id) {\n <map-advanced-marker\n [position]=\"marker.position\"\n [content]=\"marker.content\"\n [zIndex]=\"\n openedInfoWindowData?.data?.id === marker.data.id ? 999 : i\n \"\n (mapClick)=\"onMarkerClick(marker)\"\n >\n </map-advanced-marker>\n }\n\n <div\n #markerDropdown\n class=\"marker-dropdown dropdown-hidden\"\n [ngClass]=\"{ 'dropdown-hidden': !isMarkerDropdownOpen }\"\n >\n <app-ca-map-dropdown\n [infoWindowContent]=\"\n !isClusterDropdownOpen\n ? openedInfoWindowData?.infoWindowContent\n : null\n \"\n [markerData]=\"openedInfoWindowData?.data\"\n (onClusterItemClick)=\"getMarkerInfoWindow($event)\"\n (onClusterListScrollToEnd)=\"onClusterListScrollToEnd()\"\n (onBackButtonClick)=\"onClusterBackButtonClick()\"\n ></app-ca-map-dropdown>\n </div>\n\n @for (\n clusterMarker of mapData.clusterMarkers;\n let i = $index;\n track clusterMarker.position.lat + clusterMarker.position.lng\n ) {\n <map-advanced-marker\n [position]=\"clusterMarker.position\"\n [content]=\"clusterMarker.content\"\n [zIndex]=\"\n checkInfoWindowPosition(clusterMarker, openedInfoWindowData)\n ? 999\n : i\n \"\n (mapClick)=\"onClusterMarkerClick(clusterMarker)\"\n >\n </map-advanced-marker>\n }\n\n @for (route of routePolylines; let i = $index; track i) {\n <map-polyline [options]=\"route\"></map-polyline>\n }\n\n <div\n #clusterDropdown\n class=\"marker-dropdown cluster-dropdown dropdown-hidden\"\n [ngClass]=\"{ 'dropdown-hidden': !isClusterDropdownOpen }\"\n >\n <app-ca-map-dropdown\n [infoWindowContent]=\"\n !isMarkerDropdownOpen\n ? openedInfoWindowData?.infoWindowContent\n : null\n \"\n [markerData]=\"openedInfoWindowData?.data\"\n (onClusterItemClick)=\"getMarkerInfoWindow($event)\"\n (onClusterListScrollToEnd)=\"onClusterListScrollToEnd()\"\n (onBackButtonClick)=\"onClusterBackButtonClick()\"\n ></app-ca-map-dropdown>\n </div>\n\n @if (isAreaFilterActive) {\n <map-circle\n [options]=\"areaFilterData.options\"\n [center]=\"areaFilterData.center\"\n [radius]=\"areaFilterData.radius\"\n ></map-circle>\n }\n\n @for (\n routingMarker of mapData.routingMarkers;\n let i = $index;\n track trackByPosition($index, routingMarker)\n ) {\n <map-advanced-marker\n [position]=\"routingMarker.position\"\n [content]=\"routingMarker.content\"\n >\n </map-advanced-marker>\n }\n\n @if (mapData.isOpenInMapShown) {\n <div\n class=\"open-in-map-container d-flex align-items-center justify-content-center\"\n ngbTooltip\n mainCaTooltip=\"Open in Map\"\n tooltipBackground=\"#424242\"\n position=\"bottom\"\n (click)=\"onOpenInMap()\"\n >\n <svg-icon\n class=\"d-flex\"\n src=\"assets/ca-components/svg/common/ic_location_map.svg\"\n [svgStyle]=\"{ 'width.px': 18, 'height.px': 18 }\"\n ></svg-icon>\n </div>\n }\n\n @if (mapData.isZoomShown) {\n <div\n class=\"map-zoom-container d-flex flex-column align-items-end gap-1\"\n [ngClass]=\"{\n 'flex-column': !mapData.isVerticalZoom,\n 'vertical-zoom-buttons': mapData.isVerticalZoom,\n }\"\n >\n <div\n class=\"map-zoom-buttons d-flex align-items-center\"\n [class.flex-column]=\"mapData.isVerticalZoom\"\n >\n <div\n class=\"zoom-button-container d-flex align-items-center justify-content-center flex-1\"\n (click)=\"onZoomChange(true)\"\n >\n <svg-icon\n class=\"d-flex\"\n src=\"assets/ca-components/svg/popup/Minus.svg\"\n [svgStyle]=\"{ 'width.px': 14, 'height.px': 14 }\"\n ></svg-icon>\n </div>\n <div\n class=\"zoom-button-container d-flex align-items-center justify-content-center flex-1\"\n (click)=\"onZoomChange(false)\"\n >\n <svg-icon\n class=\"d-flex\"\n src=\"assets/ca-components/svg/common/ic_plus.svg\"\n [svgStyle]=\"{ 'width.px': 14, 'height.px': 14 }\"\n ></svg-icon>\n </div>\n </div>\n <div class=\"map-zoom-range d-flex align-items-center\">\n <div class=\"range-line\"></div>\n <div class=\"range-text ca-font-medium\">50 mi</div>\n <div class=\"range-line\"></div>\n </div>\n </div>\n }\n</google-map>\n", styles: ["@keyframes dropdown{0%{margin-top:20px;visibility:hidden;opacity:0}to{opacity:1;margin-top:10px;visibility:visible!important}}@keyframes dropup{0%{margin-top:-19px;visibility:hidden;opacity:0}to{margin-top:inherit;visibility:visible!important}}.gm-style-iw-a .gm-style-iw-t .gm-style-iw.gm-style-iw-c{padding:0!important;border-radius:3px!important;top:70px!important;transform:translate(-50%)!important}.gm-style-iw-a .gm-style-iw-t .gm-style-iw-tc{display:none!important}.gm-style div[aria-hidden=true],.marker-label{position:absolute;left:100%;top:50%;transform:translateY(-50%);width:100px;opacity:1;transition:opacity .2s ease-in-out;text-shadow:1px 1px 0px #ffffff,1px -1px 0px #ffffff,-1px -1px 0px #ffffff,-1px 1px 0px #ffffff;font-size:11px;line-height:12px;text-align:left;font-weight:500;font-family:Montserrat,sans-serif!important;color:#424242;white-space:nowrap;text-overflow:ellipsis;overflow:hidden;-webkit-user-select:none;user-select:none}@supports (-webkit-line-clamp: 2){.gm-style div[aria-hidden=true],.marker-label{overflow:hidden;text-overflow:ellipsis;white-space:initial;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}}.map-zoom-container{position:absolute;right:8px;bottom:16px}.map-zoom-container .map-zoom-buttons{width:52px;min-height:26px;background:#fff;border-width:3px;border-style:solid;border-color:#eee;border-radius:2px}.map-zoom-container .map-zoom-buttons .zoom-button-container{height:100%}.map-zoom-container .map-zoom-buttons .zoom-button-container svg-icon svg path{transition:fill .2s ease-in-out;fill:#919191}.map-zoom-container .map-zoom-buttons .zoom-button-container:hover{cursor:pointer}.map-zoom-container .map-zoom-buttons .zoom-button-container:hover svg-icon svg path{fill:#424242}.map-zoom-container .map-zoom-range{gap:2px;background:#fff;padding:0 4px;border-width:3px;border-style:solid;border-color:#eee;border-radius:2px}.map-zoom-container .map-zoom-range .range-text{min-width:fit-content;font-size:8px;line-height:10px;color:#424242;-webkit-user-select:none;user-select:none}.map-zoom-container .map-zoom-range .range-line{width:38px;height:2px;border-radius:1px;background:#919191}.map-zoom-container.vertical-zoom-buttons .map-zoom-range{order:1}.map-zoom-container.vertical-zoom-buttons .map-zoom-buttons{order:2;width:26px;min-height:52px}.map-zoom-container.vertical-zoom-buttons .map-zoom-buttons .zoom-button-container:first-child{order:2}.open-in-map-container{position:absolute;top:4px;right:4px;width:30px;height:30px;background:#6c6c6ce6;border-radius:1px}.open-in-map-container svg-icon svg path{transition:fill .2s ease-in-out;fill:#dadada}.open-in-map-container:hover{cursor:pointer}.open-in-map-container:hover svg-icon svg path{fill:#fff}.dark-mode-map .map-zoom-container .map-zoom-buttons,.dark-mode-map .map-zoom-range{background:#2f2f2f;border-color:#1d1d1d}.dark-mode-map .map-zoom-range .range-text{color:#fff}.marker-icon{position:relative}.marker-icon .marker-svg{transform:scale(1);transform-origin:center 30px;transition:transform .2s ease-in-out}.marker-icon .marker-svg .outside-circle,.marker-icon .marker-svg .white-circle,.marker-icon .marker-svg .inside-shape{transform-origin:center;transition:transform .2s ease-in-out}.marker-icon .marker-svg .shadow-circle{transition:transform .2s ease-in-out;transform-origin:14px 30px}.marker-icon.selected .marker-svg,.marker-icon.selected-permanently .marker-svg{transform:scale(1.5);transition:transform .2s ease-in-out}.marker-icon.selected .marker-svg .outside-circle,.marker-icon.selected-permanently .marker-svg .outside-circle{transform:scale(1.074)}.marker-icon.selected .marker-svg .white-circle,.marker-icon.selected-permanently .marker-svg .white-circle{transform:scale(.8665)}.marker-icon.selected .marker-svg .shadow-circle,.marker-icon.selected-permanently .marker-svg .shadow-circle{transform:scale(.889,.667)}.marker-icon.selected .marker-label,.marker-icon.selected-permanently .marker-label{opacity:0;pointer-events:none!important}.marker-icon.selected-permanently .marker-label{top:8px;left:calc(100% + 4px)}.marker-icon.selected-permanently:hover .marker-label{opacity:1!important}.marker-dropdown{position:absolute;top:35px;left:50%;transition:transform .2s ease-in-out,opacity .2s ease-in-out;transform:translate(-50%) scale(1);opacity:1;width:360px;min-height:64px;padding:0;background:#fff;box-shadow:0 0 4px #00000026;border-radius:3px;pointer-events:none}.marker-dropdown.dropdown-hidden{transform:translate(-50%) scale(.5);opacity:0;pointer-events:none!important}.marker-dropdown.cluster-dropdown{top:55px}.cluster-icon{position:relative}.cluster-icon .marker-svg g path{fill:#fff;transition:all .2s ease-in-out}.cluster-icon.selected .marker-svg g path{fill:#fab15c}\n"], dependencies: [{ kind: "ngmodule", type:
|
|
343
343
|
// Modules
|
|
344
344
|
GoogleMapsModule }, { kind: "component", type: i2.GoogleMap, selector: "google-map", inputs: ["height", "width", "mapId", "mapTypeId", "center", "zoom", "options"], outputs: ["mapInitialized", "authFailure", "boundsChanged", "centerChanged", "mapClick", "mapDblclick", "mapDrag", "mapDragend", "mapDragstart", "headingChanged", "idle", "maptypeidChanged", "mapMousemove", "mapMouseout", "mapMouseover", "projectionChanged", "mapRightclick", "tilesloaded", "tiltChanged", "zoomChanged"], exportAs: ["googleMap"] }, { kind: "directive", type: i2.MapCircle, selector: "map-circle", inputs: ["options", "center", "radius"], outputs: ["centerChanged", "circleClick", "circleDblclick", "circleDrag", "circleDragend", "circleDragstart", "circleMousedown", "circleMousemove", "circleMouseout", "circleMouseover", "circleMouseup", "radiusChanged", "circleRightclick", "circleInitialized"], exportAs: ["mapCircle"] }, { kind: "directive", type: i2.MapAdvancedMarker, selector: "map-advanced-marker", inputs: ["title", "position", "content", "gmpDraggable", "options", "zIndex"], outputs: ["mapClick", "mapDrag", "mapDragend", "mapDragstart", "markerInitialized"], exportAs: ["mapAdvancedMarker"] }, { kind: "directive", type: i2.MapPolyline, selector: "map-polyline", inputs: ["options", "path"], outputs: ["polylineClick", "polylineDblclick", "polylineDrag", "polylineDragend", "polylineDragstart", "polylineMousedown", "polylineMousemove", "polylineMouseout", "polylineMouseover", "polylineMouseup", "polylineRightclick", "polylineInitialized"], exportAs: ["mapPolyline"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: AngularSvgIconModule }, { kind: "component", type: i4.SvgIconComponent, selector: "svg-icon", inputs: ["src", "name", "stretch", "applyClass", "applyCss", "svgClass", "class", "viewBox", "svgAriaLabel", "svgStyle"] }, { kind: "ngmodule", type: NgbTooltipModule }, { kind: "directive", type: i5.NgbTooltip, selector: "[ngbTooltip]", inputs: ["animation", "autoClose", "placement", "popperOptions", "triggers", "positionTarget", "container", "disableTooltip", "tooltipClass", "tooltipContext", "openDelay", "closeDelay", "ngbTooltip"], outputs: ["shown", "hidden"], exportAs: ["ngbTooltip"] }, { kind: "component", type:
|
|
345
345
|
// Components
|
|
@@ -356,7 +356,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
356
356
|
// Components
|
|
357
357
|
CaMapDropdownComponent,
|
|
358
358
|
CaAppTooltipV2Component,
|
|
359
|
-
], encapsulation: ViewEncapsulation.None, template: "<google-map\n class=\"position-relative\"\n [class.dark-mode-map]=\"mapData.darkMode\"\n height=\"100%\"\n width=\"100%\"\n [zoom]=\"mapZoom\"\n [center]=\"mapCenter\"\n [options]=\"mapOptions\"\n (mapInitialized)=\"onMapReady($event)\"\n [mapId]=\"mapStyleId\"\n>\n @for (marker of mapData.markers; let i = $index; track marker.data.id) {\n <map-advanced-marker\n [position]=\"marker.position\"\n [content]=\"marker.content\"\n [zIndex]=\"\n openedInfoWindowData?.data?.id === marker.data.id ? 999 : i\n \"\n (mapClick)=\"onMarkerClick(marker)\"\n >\n </map-advanced-marker>\n }\n\n <div\n #markerDropdown\n class=\"marker-dropdown dropdown-hidden\"\n [ngClass]=\"{ 'dropdown-hidden': !isMarkerDropdownOpen }\"\n >\n <app-ca-map-dropdown\n [infoWindowContent]=\"\n !isClusterDropdownOpen\n ? openedInfoWindowData?.infoWindowContent\n : null\n \"\n [markerData]=\"openedInfoWindowData?.data\"\n (onClusterItemClick)=\"getMarkerInfoWindow($event)\"\n (onClusterListScrollToEnd)=\"onClusterListScrollToEnd()\"\n (onBackButtonClick)=\"onClusterBackButtonClick()\"\n ></app-ca-map-dropdown>\n </div>\n\n @for (\n clusterMarker of mapData.clusterMarkers;\n let i = $index;\n track trackByPosition($index, clusterMarker)\n ) {\n <map-advanced-marker\n [position]=\"clusterMarker.position\"\n [content]=\"clusterMarker.content\"\n [zIndex]=\"\n checkInfoWindowPosition(clusterMarker, openedInfoWindowData)\n ? 999\n : i\n \"\n (mapClick)=\"onClusterMarkerClick(clusterMarker)\"\n >\n </map-advanced-marker>\n }\n\n @for (route of routePolylines; let i = $index; track i) {\n <map-polyline [options]=\"route\"></map-polyline>\n }\n\n <div\n #clusterDropdown\n class=\"marker-dropdown cluster-dropdown dropdown-hidden\"\n [ngClass]=\"{ 'dropdown-hidden': !isClusterDropdownOpen }\"\n >\n <app-ca-map-dropdown\n [infoWindowContent]=\"\n !isMarkerDropdownOpen\n ? openedInfoWindowData?.infoWindowContent\n : null\n \"\n [markerData]=\"openedInfoWindowData?.data\"\n (onClusterItemClick)=\"getMarkerInfoWindow($event)\"\n (onClusterListScrollToEnd)=\"onClusterListScrollToEnd()\"\n (onBackButtonClick)=\"onClusterBackButtonClick()\"\n ></app-ca-map-dropdown>\n </div>\n\n @if (isAreaFilterActive) {\n <map-circle\n [options]=\"areaFilterData.options\"\n [center]=\"areaFilterData.center\"\n [radius]=\"areaFilterData.radius\"\n ></map-circle>\n }\n\n @for (\n routingMarker of mapData.routingMarkers;\n let i = $index;\n track trackByPosition($index, routingMarker)\n ) {\n <map-advanced-marker\n [position]=\"routingMarker.position\"\n [content]=\"routingMarker.content\"\n >\n </map-advanced-marker>\n }\n\n @if (mapData.isOpenInMapShown) {\n <div\n class=\"open-in-map-container d-flex align-items-center justify-content-center\"\n ngbTooltip\n mainCaTooltip=\"Open in Map\"\n tooltipBackground=\"#424242\"\n position=\"bottom\"\n (click)=\"onOpenInMap()\"\n >\n <svg-icon\n class=\"d-flex\"\n src=\"assets/ca-components/svg/common/ic_location_map.svg\"\n [svgStyle]=\"{ 'width.px': 18, 'height.px': 18 }\"\n ></svg-icon>\n </div>\n }\n\n @if (mapData.isZoomShown) {\n <div\n class=\"map-zoom-container d-flex flex-column align-items-end gap-1\"\n [ngClass]=\"{\n 'flex-column': !mapData.isVerticalZoom,\n 'vertical-zoom-buttons': mapData.isVerticalZoom,\n }\"\n >\n <div\n class=\"map-zoom-buttons d-flex align-items-center\"\n [class.flex-column]=\"mapData.isVerticalZoom\"\n >\n <div\n class=\"zoom-button-container d-flex align-items-center justify-content-center flex-1\"\n (click)=\"onZoomChange(true)\"\n >\n <svg-icon\n class=\"d-flex\"\n src=\"assets/ca-components/svg/popup/Minus.svg\"\n [svgStyle]=\"{ 'width.px': 14, 'height.px': 14 }\"\n ></svg-icon>\n </div>\n <div\n class=\"zoom-button-container d-flex align-items-center justify-content-center flex-1\"\n (click)=\"onZoomChange(false)\"\n >\n <svg-icon\n class=\"d-flex\"\n src=\"assets/ca-components/svg/common/ic_plus.svg\"\n [svgStyle]=\"{ 'width.px': 14, 'height.px': 14 }\"\n ></svg-icon>\n </div>\n </div>\n <div class=\"map-zoom-range d-flex align-items-center\">\n <div class=\"range-line\"></div>\n <div class=\"range-text ca-font-medium\">50 mi</div>\n <div class=\"range-line\"></div>\n </div>\n </div>\n }\n</google-map>\n", styles: ["@keyframes dropdown{0%{margin-top:20px;visibility:hidden;opacity:0}to{opacity:1;margin-top:10px;visibility:visible!important}}@keyframes dropup{0%{margin-top:-19px;visibility:hidden;opacity:0}to{margin-top:inherit;visibility:visible!important}}.gm-style-iw-a .gm-style-iw-t .gm-style-iw.gm-style-iw-c{padding:0!important;border-radius:3px!important;top:70px!important;transform:translate(-50%)!important}.gm-style-iw-a .gm-style-iw-t .gm-style-iw-tc{display:none!important}.gm-style div[aria-hidden=true],.marker-label{position:absolute;left:100%;top:50%;transform:translateY(-50%);width:100px;opacity:1;transition:opacity .2s ease-in-out;text-shadow:1px 1px 0px #ffffff,1px -1px 0px #ffffff,-1px -1px 0px #ffffff,-1px 1px 0px #ffffff;font-size:11px;line-height:12px;text-align:left;font-weight:500;font-family:Montserrat,sans-serif!important;color:#424242;white-space:nowrap;text-overflow:ellipsis;overflow:hidden;-webkit-user-select:none;user-select:none}@supports (-webkit-line-clamp: 2){.gm-style div[aria-hidden=true],.marker-label{overflow:hidden;text-overflow:ellipsis;white-space:initial;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}}.map-zoom-container{position:absolute;right:8px;bottom:16px}.map-zoom-container .map-zoom-buttons{width:52px;min-height:26px;background:#fff;border-width:3px;border-style:solid;border-color:#eee;border-radius:2px}.map-zoom-container .map-zoom-buttons .zoom-button-container{height:100%}.map-zoom-container .map-zoom-buttons .zoom-button-container svg-icon svg path{transition:fill .2s ease-in-out;fill:#919191}.map-zoom-container .map-zoom-buttons .zoom-button-container:hover{cursor:pointer}.map-zoom-container .map-zoom-buttons .zoom-button-container:hover svg-icon svg path{fill:#424242}.map-zoom-container .map-zoom-range{gap:2px;background:#fff;padding:0 4px;border-width:3px;border-style:solid;border-color:#eee;border-radius:2px}.map-zoom-container .map-zoom-range .range-text{min-width:fit-content;font-size:8px;line-height:10px;color:#424242;-webkit-user-select:none;user-select:none}.map-zoom-container .map-zoom-range .range-line{width:38px;height:2px;border-radius:1px;background:#919191}.map-zoom-container.vertical-zoom-buttons .map-zoom-range{order:1}.map-zoom-container.vertical-zoom-buttons .map-zoom-buttons{order:2;width:26px;min-height:52px}.map-zoom-container.vertical-zoom-buttons .map-zoom-buttons .zoom-button-container:first-child{order:2}.open-in-map-container{position:absolute;top:4px;right:4px;width:30px;height:30px;background:#6c6c6ce6;border-radius:1px}.open-in-map-container svg-icon svg path{transition:fill .2s ease-in-out;fill:#dadada}.open-in-map-container:hover{cursor:pointer}.open-in-map-container:hover svg-icon svg path{fill:#fff}.dark-mode-map .map-zoom-container .map-zoom-buttons,.dark-mode-map .map-zoom-range{background:#2f2f2f;border-color:#1d1d1d}.dark-mode-map .map-zoom-range .range-text{color:#fff}.marker-icon{position:relative}.marker-icon .marker-svg{transform:scale(1);transform-origin:center 30px;transition:transform .2s ease-in-out}.marker-icon .marker-svg .outside-circle,.marker-icon .marker-svg .white-circle,.marker-icon .marker-svg .inside-shape{transform-origin:center;transition:transform .2s ease-in-out}.marker-icon .marker-svg .shadow-circle{transition:transform .2s ease-in-out;transform-origin:14px 30px}.marker-icon.selected .marker-svg,.marker-icon.selected-permanently .marker-svg{transform:scale(1.5);transition:transform .2s ease-in-out}.marker-icon.selected .marker-svg .outside-circle,.marker-icon.selected-permanently .marker-svg .outside-circle{transform:scale(1.074)}.marker-icon.selected .marker-svg .white-circle,.marker-icon.selected-permanently .marker-svg .white-circle{transform:scale(.8665)}.marker-icon.selected .marker-svg .shadow-circle,.marker-icon.selected-permanently .marker-svg .shadow-circle{transform:scale(.889,.667)}.marker-icon.selected .marker-label,.marker-icon.selected-permanently .marker-label{opacity:0;pointer-events:none!important}.marker-icon.selected-permanently .marker-label{top:8px;left:calc(100% + 4px)}.marker-icon.selected-permanently:hover .marker-label{opacity:1!important}.marker-dropdown{position:absolute;top:35px;left:50%;transition:transform .2s ease-in-out,opacity .2s ease-in-out;transform:translate(-50%) scale(1);opacity:1;width:360px;min-height:64px;padding:0;background:#fff;box-shadow:0 0 4px #00000026;border-radius:3px;pointer-events:none}.marker-dropdown.dropdown-hidden{transform:translate(-50%) scale(.5);opacity:0;pointer-events:none!important}.marker-dropdown.cluster-dropdown{top:55px}.cluster-icon{position:relative}.cluster-icon .marker-svg g path{fill:#fff;transition:all .2s ease-in-out}.cluster-icon.selected .marker-svg g path{fill:#fab15c}\n"] }]
|
|
359
|
+
], encapsulation: ViewEncapsulation.None, template: "<google-map\n class=\"position-relative\"\n [class.dark-mode-map]=\"mapData.darkMode\"\n height=\"100%\"\n width=\"100%\"\n [zoom]=\"mapZoom\"\n [center]=\"mapCenter\"\n [options]=\"mapOptions\"\n (mapInitialized)=\"onMapReady($event)\"\n [mapId]=\"mapStyleId\"\n>\n @for (marker of mapData.markers; let i = $index; track marker.data.id) {\n <map-advanced-marker\n [position]=\"marker.position\"\n [content]=\"marker.content\"\n [zIndex]=\"\n openedInfoWindowData?.data?.id === marker.data.id ? 999 : i\n \"\n (mapClick)=\"onMarkerClick(marker)\"\n >\n </map-advanced-marker>\n }\n\n <div\n #markerDropdown\n class=\"marker-dropdown dropdown-hidden\"\n [ngClass]=\"{ 'dropdown-hidden': !isMarkerDropdownOpen }\"\n >\n <app-ca-map-dropdown\n [infoWindowContent]=\"\n !isClusterDropdownOpen\n ? openedInfoWindowData?.infoWindowContent\n : null\n \"\n [markerData]=\"openedInfoWindowData?.data\"\n (onClusterItemClick)=\"getMarkerInfoWindow($event)\"\n (onClusterListScrollToEnd)=\"onClusterListScrollToEnd()\"\n (onBackButtonClick)=\"onClusterBackButtonClick()\"\n ></app-ca-map-dropdown>\n </div>\n\n @for (\n clusterMarker of mapData.clusterMarkers;\n let i = $index;\n track clusterMarker.position.lat + clusterMarker.position.lng\n ) {\n <map-advanced-marker\n [position]=\"clusterMarker.position\"\n [content]=\"clusterMarker.content\"\n [zIndex]=\"\n checkInfoWindowPosition(clusterMarker, openedInfoWindowData)\n ? 999\n : i\n \"\n (mapClick)=\"onClusterMarkerClick(clusterMarker)\"\n >\n </map-advanced-marker>\n }\n\n @for (route of routePolylines; let i = $index; track i) {\n <map-polyline [options]=\"route\"></map-polyline>\n }\n\n <div\n #clusterDropdown\n class=\"marker-dropdown cluster-dropdown dropdown-hidden\"\n [ngClass]=\"{ 'dropdown-hidden': !isClusterDropdownOpen }\"\n >\n <app-ca-map-dropdown\n [infoWindowContent]=\"\n !isMarkerDropdownOpen\n ? openedInfoWindowData?.infoWindowContent\n : null\n \"\n [markerData]=\"openedInfoWindowData?.data\"\n (onClusterItemClick)=\"getMarkerInfoWindow($event)\"\n (onClusterListScrollToEnd)=\"onClusterListScrollToEnd()\"\n (onBackButtonClick)=\"onClusterBackButtonClick()\"\n ></app-ca-map-dropdown>\n </div>\n\n @if (isAreaFilterActive) {\n <map-circle\n [options]=\"areaFilterData.options\"\n [center]=\"areaFilterData.center\"\n [radius]=\"areaFilterData.radius\"\n ></map-circle>\n }\n\n @for (\n routingMarker of mapData.routingMarkers;\n let i = $index;\n track trackByPosition($index, routingMarker)\n ) {\n <map-advanced-marker\n [position]=\"routingMarker.position\"\n [content]=\"routingMarker.content\"\n >\n </map-advanced-marker>\n }\n\n @if (mapData.isOpenInMapShown) {\n <div\n class=\"open-in-map-container d-flex align-items-center justify-content-center\"\n ngbTooltip\n mainCaTooltip=\"Open in Map\"\n tooltipBackground=\"#424242\"\n position=\"bottom\"\n (click)=\"onOpenInMap()\"\n >\n <svg-icon\n class=\"d-flex\"\n src=\"assets/ca-components/svg/common/ic_location_map.svg\"\n [svgStyle]=\"{ 'width.px': 18, 'height.px': 18 }\"\n ></svg-icon>\n </div>\n }\n\n @if (mapData.isZoomShown) {\n <div\n class=\"map-zoom-container d-flex flex-column align-items-end gap-1\"\n [ngClass]=\"{\n 'flex-column': !mapData.isVerticalZoom,\n 'vertical-zoom-buttons': mapData.isVerticalZoom,\n }\"\n >\n <div\n class=\"map-zoom-buttons d-flex align-items-center\"\n [class.flex-column]=\"mapData.isVerticalZoom\"\n >\n <div\n class=\"zoom-button-container d-flex align-items-center justify-content-center flex-1\"\n (click)=\"onZoomChange(true)\"\n >\n <svg-icon\n class=\"d-flex\"\n src=\"assets/ca-components/svg/popup/Minus.svg\"\n [svgStyle]=\"{ 'width.px': 14, 'height.px': 14 }\"\n ></svg-icon>\n </div>\n <div\n class=\"zoom-button-container d-flex align-items-center justify-content-center flex-1\"\n (click)=\"onZoomChange(false)\"\n >\n <svg-icon\n class=\"d-flex\"\n src=\"assets/ca-components/svg/common/ic_plus.svg\"\n [svgStyle]=\"{ 'width.px': 14, 'height.px': 14 }\"\n ></svg-icon>\n </div>\n </div>\n <div class=\"map-zoom-range d-flex align-items-center\">\n <div class=\"range-line\"></div>\n <div class=\"range-text ca-font-medium\">50 mi</div>\n <div class=\"range-line\"></div>\n </div>\n </div>\n }\n</google-map>\n", styles: ["@keyframes dropdown{0%{margin-top:20px;visibility:hidden;opacity:0}to{opacity:1;margin-top:10px;visibility:visible!important}}@keyframes dropup{0%{margin-top:-19px;visibility:hidden;opacity:0}to{margin-top:inherit;visibility:visible!important}}.gm-style-iw-a .gm-style-iw-t .gm-style-iw.gm-style-iw-c{padding:0!important;border-radius:3px!important;top:70px!important;transform:translate(-50%)!important}.gm-style-iw-a .gm-style-iw-t .gm-style-iw-tc{display:none!important}.gm-style div[aria-hidden=true],.marker-label{position:absolute;left:100%;top:50%;transform:translateY(-50%);width:100px;opacity:1;transition:opacity .2s ease-in-out;text-shadow:1px 1px 0px #ffffff,1px -1px 0px #ffffff,-1px -1px 0px #ffffff,-1px 1px 0px #ffffff;font-size:11px;line-height:12px;text-align:left;font-weight:500;font-family:Montserrat,sans-serif!important;color:#424242;white-space:nowrap;text-overflow:ellipsis;overflow:hidden;-webkit-user-select:none;user-select:none}@supports (-webkit-line-clamp: 2){.gm-style div[aria-hidden=true],.marker-label{overflow:hidden;text-overflow:ellipsis;white-space:initial;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}}.map-zoom-container{position:absolute;right:8px;bottom:16px}.map-zoom-container .map-zoom-buttons{width:52px;min-height:26px;background:#fff;border-width:3px;border-style:solid;border-color:#eee;border-radius:2px}.map-zoom-container .map-zoom-buttons .zoom-button-container{height:100%}.map-zoom-container .map-zoom-buttons .zoom-button-container svg-icon svg path{transition:fill .2s ease-in-out;fill:#919191}.map-zoom-container .map-zoom-buttons .zoom-button-container:hover{cursor:pointer}.map-zoom-container .map-zoom-buttons .zoom-button-container:hover svg-icon svg path{fill:#424242}.map-zoom-container .map-zoom-range{gap:2px;background:#fff;padding:0 4px;border-width:3px;border-style:solid;border-color:#eee;border-radius:2px}.map-zoom-container .map-zoom-range .range-text{min-width:fit-content;font-size:8px;line-height:10px;color:#424242;-webkit-user-select:none;user-select:none}.map-zoom-container .map-zoom-range .range-line{width:38px;height:2px;border-radius:1px;background:#919191}.map-zoom-container.vertical-zoom-buttons .map-zoom-range{order:1}.map-zoom-container.vertical-zoom-buttons .map-zoom-buttons{order:2;width:26px;min-height:52px}.map-zoom-container.vertical-zoom-buttons .map-zoom-buttons .zoom-button-container:first-child{order:2}.open-in-map-container{position:absolute;top:4px;right:4px;width:30px;height:30px;background:#6c6c6ce6;border-radius:1px}.open-in-map-container svg-icon svg path{transition:fill .2s ease-in-out;fill:#dadada}.open-in-map-container:hover{cursor:pointer}.open-in-map-container:hover svg-icon svg path{fill:#fff}.dark-mode-map .map-zoom-container .map-zoom-buttons,.dark-mode-map .map-zoom-range{background:#2f2f2f;border-color:#1d1d1d}.dark-mode-map .map-zoom-range .range-text{color:#fff}.marker-icon{position:relative}.marker-icon .marker-svg{transform:scale(1);transform-origin:center 30px;transition:transform .2s ease-in-out}.marker-icon .marker-svg .outside-circle,.marker-icon .marker-svg .white-circle,.marker-icon .marker-svg .inside-shape{transform-origin:center;transition:transform .2s ease-in-out}.marker-icon .marker-svg .shadow-circle{transition:transform .2s ease-in-out;transform-origin:14px 30px}.marker-icon.selected .marker-svg,.marker-icon.selected-permanently .marker-svg{transform:scale(1.5);transition:transform .2s ease-in-out}.marker-icon.selected .marker-svg .outside-circle,.marker-icon.selected-permanently .marker-svg .outside-circle{transform:scale(1.074)}.marker-icon.selected .marker-svg .white-circle,.marker-icon.selected-permanently .marker-svg .white-circle{transform:scale(.8665)}.marker-icon.selected .marker-svg .shadow-circle,.marker-icon.selected-permanently .marker-svg .shadow-circle{transform:scale(.889,.667)}.marker-icon.selected .marker-label,.marker-icon.selected-permanently .marker-label{opacity:0;pointer-events:none!important}.marker-icon.selected-permanently .marker-label{top:8px;left:calc(100% + 4px)}.marker-icon.selected-permanently:hover .marker-label{opacity:1!important}.marker-dropdown{position:absolute;top:35px;left:50%;transition:transform .2s ease-in-out,opacity .2s ease-in-out;transform:translate(-50%) scale(1);opacity:1;width:360px;min-height:64px;padding:0;background:#fff;box-shadow:0 0 4px #00000026;border-radius:3px;pointer-events:none}.marker-dropdown.dropdown-hidden{transform:translate(-50%) scale(.5);opacity:0;pointer-events:none!important}.marker-dropdown.cluster-dropdown{top:55px}.cluster-icon{position:relative}.cluster-icon .marker-svg g path{fill:#fff;transition:all .2s ease-in-out}.cluster-icon.selected .marker-svg g path{fill:#fab15c}\n"] }]
|
|
360
360
|
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i1.MapMarkerIconService }], propDecorators: { maps: [{
|
|
361
361
|
type: ViewChild,
|
|
362
362
|
args: [GoogleMap, { static: false }]
|
|
@@ -381,4 +381,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
381
381
|
}], openInMapEvent: [{
|
|
382
382
|
type: Output
|
|
383
383
|
}] } });
|
|
384
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-map.component.js","sourceRoot":"","sources":["../../../../../../projects/ca-components/src/lib/components/ca-map/ca-map.component.ts","../../../../../../projects/ca-components/src/lib/components/ca-map/ca-map.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    Input,\n    Output,\n    Renderer2,\n    ViewChild,\n    ViewEncapsulation,\n} from '@angular/core';\nimport { Subject, takeUntil } from 'rxjs';\n\n// Modules\nimport { AngularSvgIconModule } from 'angular-svg-icon';\nimport { NgbTooltipModule } from '@ng-bootstrap/ng-bootstrap';\nimport { GoogleMap, GoogleMapsModule } from '@angular/google-maps';\n\n// Components\nimport { CaMapDropdownComponent } from '../ca-map-dropdown/ca-map-dropdown.component';\nimport { CaAppTooltipV2Component } from '../ca-app-tooltip-v2/ca-app-tooltip-v2.component';\n\n// Enums\nimport { GoogleMapEnum } from '../ca-map/enums/google-map.enum';\nimport { MapMarkerStringEnum } from './enums';\n\n// Models\nimport {\n    IMapMarkers,\n    ICaMapProps,\n    IMapOptions,\n    IRoutePath,\n    IMapBoundsZoom,\n    IMapSelectedMarkerData,\n} from '../ca-map/models';\n\n// Helpers\nimport { MapHelper } from '../ca-map/utils/helpers/map.helper';\n\n// Constants\nimport { MapOptionsConstants, MapConstants } from './utils/constants';\n\n// Services\nimport { MapMarkerIconService } from './utils/services';\n\n@Component({\n    selector: 'app-ca-map',\n    templateUrl: './ca-map.component.html',\n    styleUrls: ['./ca-map.component.scss'],\n    standalone: true,\n    imports: [\n        // Modules\n        GoogleMapsModule,\n        CommonModule,\n        AngularSvgIconModule,\n        NgbTooltipModule,\n\n        // Components\n        CaMapDropdownComponent,\n        CaAppTooltipV2Component,\n    ],\n    encapsulation: ViewEncapsulation.None,\n})\nexport class CaMapComponent {\n    constructor(\n        public cd: ChangeDetectorRef,\n        private el: ElementRef,\n        private renderer: Renderer2,\n\n        // Services\n        private markerIconService: MapMarkerIconService\n    ) {}\n    @ViewChild(GoogleMap, { static: false }) maps!: GoogleMap;\n    @ViewChild('markerDropdown') markerDropdown!: ElementRef;\n    @ViewChild('clusterDropdown') clusterDropdown!: ElementRef;\n\n    @Input() set data(values: ICaMapProps) {\n        this.handleMapData(values);\n    }\n\n    @Output() resetSelectedMarkerItem = new EventEmitter<boolean>();\n    @Output() clusterMarkerClick = new EventEmitter<IMapMarkers>();\n    @Output() clusterListScrollEvent = new EventEmitter<IMapMarkers>();\n    @Output() getInfoWindowData = new EventEmitter<number>();\n    @Output() boundsChanged = new EventEmitter<IMapBoundsZoom>();\n    @Output() openInMapEvent = new EventEmitter();\n\n    private destroy$ = new Subject<void>();\n\n    public directionsRenderers: google.maps.DirectionsRenderer[] = [];\n\n    public mapOptions: IMapOptions = MapOptionsConstants.defaultMapOptions;\n    public mapZoom: number = MapOptionsConstants.defaultMapZoom;\n    public mapCenter: IRoutePath = MapOptionsConstants.defaultMapCenter;\n    public map: google.maps.Map | null = null;\n    public mapStyleId: string = 'd681904a390a8402';\n    public mapData: ICaMapProps = {};\n\n    public openedInfoWindowData: IMapMarkers | null = null;\n    public areaFilterData = MapOptionsConstants.areaFilterData;\n\n    public clusterMarkerIds: IMapMarkers[] = [];\n    public routingMarkerIds: IMapMarkers[] = [];\n    public routePolylines: google.maps.PolylineOptions[] = [];\n\n    public isMarkerDropdownOpen: boolean = false;\n    public isClusterDropdownOpen: boolean = false;\n    public isCurrentlyOpenWindow: boolean = false;\n    public isMapCenterSet: boolean = false;\n    public isAreaFilterActive: boolean = false;\n\n    public openDropdownTimeout: NodeJS.Timeout | number = 0;\n\n    ngOnInit() {\n        // Reset all icons to their initial state on page load\n        this.resetMarkersIcons();\n\n        this.getServiceData();\n    }\n\n    ngAfterViewInit() {\n        this.maps.googleMap?.addListener('click', () => {\n            this.closeInfoWindow();\n        });\n    }\n\n    public onClusterMarkerClick(markerItem: IMapMarkers): void {\n        const isInfoWindowOpened = this.checkInfoWindowPosition(\n            markerItem,\n            this.openedInfoWindowData\n        );\n\n        if (!isInfoWindowOpened) this.clusterMarkerClick.emit(markerItem);\n        else this.closeInfoWindow();\n    }\n\n    public getMarkerInfoWindow(markerId: number): void {\n        if (markerId) this.getInfoWindowData.emit(markerId);\n    }\n\n    public onMarkerClick(markerItem: IMapMarkers): void {\n        const isInfoWindowOpened = this.checkInfoWindowPosition(\n            markerItem,\n            this.openedInfoWindowData\n        );\n\n        if (!isInfoWindowOpened) this.getMarkerInfoWindow(markerItem.data.id);\n        else this.closeInfoWindow();\n    }\n\n    public setDirectionsOnMap(): void {\n        if (this.maps?.googleMap) {\n            this.directionsRenderers.forEach((renderer) =>\n                renderer.setMap(this.maps?.googleMap!)\n            );\n        }\n    }\n\n    public calculateAndDisplayRoute(): void {\n        if (this.mapData.routePaths) {\n            // Clear previous directions renderers\n            this.directionsRenderers.forEach((renderer) =>\n                renderer.setMap(null)\n            );\n            this.directionsRenderers = [];\n\n            this.routePolylines = [];\n\n            this.mapData.routePaths!.forEach((route, index) => {\n                if (route.decodedShape) {\n                    const polyLineCoordinates = route.decodedShape?.map(\n                        (item) => {\n                            const coordinates = {\n                                lat: item.latitude!,\n                                lng: item.longitude!,\n                            };\n                            return coordinates;\n                        }\n                    );\n\n                    const routePolyline: google.maps.PolylineOptions = {\n                        path: polyLineCoordinates,\n                        geodesic: true,\n                        strokeColor:\n                            route.strokeColor || GoogleMapEnum.STROKE_COLOR,\n                        strokeOpacity: !route.isDashed\n                            ? route.strokeOpacity ||\n                              GoogleMapEnum.STROKE_OPACITY\n                            : 0,\n                        strokeWeight:\n                            route.strokeWeight || GoogleMapEnum.STROKE_WEIGHT,\n                        icons: route.isDashed\n                            ? (route.dashedLineStyle ??\n                              MapOptionsConstants.routingDashedLineIcon)\n                            : null,\n                        zIndex: index,\n                    };\n\n                    this.routePolylines.push(routePolyline);\n                }\n            });\n        }\n    }\n\n    public resetMarkersIcons(): void {\n        this.mapData.markers?.map((marker: IMapMarkers, index: number) => {\n            const markerIcon = this.el.nativeElement.querySelector(\n                '#marker-' + marker.id\n            );\n            if (markerIcon)\n                this.renderer.removeClass(\n                    markerIcon,\n                    MapMarkerStringEnum.SELECTED\n                );\n            this.isMarkerDropdownOpen = false;\n\n            return {\n                ...marker,\n                options: { zIndex: index + 1 },\n            };\n        });\n\n        this.mapData.clusterMarkers?.map(\n            (clusterMarker: IMapMarkers, index: number) => {\n                const clusterId = this.getClusterId(clusterMarker);\n                const markerIcon = this.el.nativeElement.querySelector(\n                    '#cluster-' + clusterId\n                );\n                if (markerIcon)\n                    this.renderer.removeClass(\n                        markerIcon,\n                        MapMarkerStringEnum.SELECTED\n                    );\n                this.isClusterDropdownOpen = false;\n            }\n        );\n\n        this.cd.detectChanges();\n    }\n\n    public onMapReady(mapInstance: google.maps.Map): {\n        fillColor?: string;\n        strokeColor?: string;\n        strokeWeight?: number;\n        fillOpacity?: number;\n    } | void {\n        this.map = mapInstance;\n\n        if (this.mapData?.darkMode) {\n            const styledMapType = new google.maps.StyledMapType(\n                MapConstants.GOOGLE_MAP_DARK_STYLES\n            );\n            this.map!.mapTypes.set(GoogleMapEnum.DARK_MAP, styledMapType);\n            this.map!.setMapTypeId(GoogleMapEnum.DARK_MAP);\n        }\n\n        if (this.mapData.stateBoundariesUrl) {\n            const stateBoundariesUrl = this.mapData.stateBoundariesUrl.url;\n            this.maps.googleMap?.data.loadGeoJson(stateBoundariesUrl);\n\n            this.maps.googleMap?.data.setStyle((feature) => {\n                const stateDensity = feature.getProperty('density');\n                const { fillColor, fillOpacity } =\n                    MapHelper.getFillColorForState(\n                        stateDensity as number,\n                        this.mapData.view || ''\n                    );\n                return {\n                    fillColor: fillColor,\n                    strokeColor: '#EEEEEE',\n                    strokeWeight: 0.6,\n                    fillOpacity: fillOpacity,\n                };\n            });\n        }\n\n        this.sendBoundsChangedEvent();\n        this.setMapStyles();\n        this.getMapIdleEvent(mapInstance);\n    }\n\n    public setMapStyles(): void {\n        if (this.mapData?.darkMode)\n            this.mapOptions = {\n                ...this.mapOptions,\n                styles: MapConstants.GOOGLE_MAP_DARK_STYLES,\n            };\n\n        const allMarkersCombined = [\n            ...(this.mapData.routingMarkers ?? []),\n            ...(this.mapData.clusterMarkers ?? []),\n            ...(this.mapData.markers ?? []),\n        ];\n\n        if (allMarkersCombined?.length) {\n            const mapCenterAndBounds =\n                MapHelper.getMapCenterAndZoom(allMarkersCombined);\n\n            this.map!.panTo(mapCenterAndBounds.mapCenter);\n            if (mapCenterAndBounds.bounds)\n                this.map?.fitBounds(mapCenterAndBounds.bounds);\n            if (mapCenterAndBounds.mapZoom)\n                this.map?.setZoom(mapCenterAndBounds.mapZoom);\n\n            this.isMapCenterSet = true;\n        }\n    }\n\n    public getMapIdleEvent(map: google.maps.Map): void {\n        map.addListener('idle', () => {\n            this.sendBoundsChangedEvent();\n        });\n    }\n\n    public sendBoundsChangedEvent(): void {\n        if (this.map) {\n            const mapBounds = this.map.getBounds();\n            const mapZoom = this.map.getZoom();\n\n            if (mapBounds && mapZoom) {\n                const boundsObject = { bounds: mapBounds, zoom: mapZoom };\n                this.boundsChanged.emit(boundsObject);\n            }\n        }\n    }\n\n    public onClusterBackButtonClick(): void {\n        this.resetSelectedMarkerItem.emit(true);\n    }\n\n    public openMarkerInfoWindow(markerItem: IMapSelectedMarkerData): void {\n        const isInfoWindowOpened = this.checkInfoWindowPosition(\n            markerItem,\n            this.openedInfoWindowData\n        );\n\n        const combinedMarkers = [\n            ...this.mapData.markers!,\n            ...this.mapData.clusterMarkers!,\n        ];\n\n        combinedMarkers.forEach((item: IMapMarkers, index: number) => {\n            const isSelectedMarker = this.checkInfoWindowPosition(\n                item,\n                markerItem\n            );\n\n            const isClusterMarker = item?.data?.count > 1;\n\n            const clusterId = isClusterMarker ? this.getClusterId(item) : null;\n\n            const markerIconId = isClusterMarker\n                ? '#cluster-' + clusterId\n                : '#marker-' + item.id;\n\n            const dropdownElement = isClusterMarker\n                ? this.clusterDropdown.nativeElement\n                : this.markerDropdown.nativeElement;\n\n            if (isSelectedMarker) {\n                item.options = { zIndex: 999 };\n\n                if (isClusterMarker) this.isMarkerDropdownOpen = false;\n                else this.isClusterDropdownOpen = false;\n\n                clearTimeout(this.openDropdownTimeout);\n\n                this.openDropdownTimeout = setTimeout(() => {\n                    const markerIcon =\n                        this.el.nativeElement.querySelector(markerIconId);\n\n                    if (!(markerIcon?.previousSibling === dropdownElement))\n                        this.renderer.insertBefore(\n                            markerIcon?.parentNode,\n                            dropdownElement,\n                            markerIcon\n                        );\n\n                    if (\n                        markerIcon &&\n                        !markerIcon.classList?.contains(\n                            MapMarkerStringEnum.SELECTED\n                        )\n                    )\n                        this.renderer.addClass(\n                            markerIcon,\n                            MapMarkerStringEnum.SELECTED\n                        );\n\n                    this.isMarkerDropdownOpen = !isClusterMarker;\n                    this.isClusterDropdownOpen = isClusterMarker;\n\n                    this.cd.detectChanges();\n                }, 50);\n            } else {\n                const markerIcon =\n                    this.el.nativeElement.querySelector(markerIconId);\n\n                if (\n                    markerIcon?.classList?.contains(\n                        MapMarkerStringEnum.SELECTED\n                    )\n                )\n                    this.renderer.removeClass(\n                        markerIcon,\n                        MapMarkerStringEnum.SELECTED\n                    );\n\n                setTimeout(() => {\n                    item.options = { zIndex: index + 1 };\n                }, 50);\n            }\n        });\n\n        this.isCurrentlyOpenWindow = true;\n        this.openedInfoWindowData = markerItem;\n\n        if (!isInfoWindowOpened) this.map!.panTo(markerItem.position);\n    }\n\n    public checkInfoWindowPosition(\n        markerItem: IMapMarkers,\n        markerItem2?: IMapMarkers | null\n    ): boolean {\n        return (\n            markerItem.position.lat === markerItem2?.position?.lat &&\n            markerItem.position.lng === markerItem2?.position?.lng\n        );\n    }\n\n    public closeInfoWindow(): void {\n        this.resetMarkersIcons();\n\n        setTimeout(() => (this.openedInfoWindowData = null), 250);\n\n        clearTimeout(this.openDropdownTimeout);\n        this.isMarkerDropdownOpen = false;\n        this.isClusterDropdownOpen = false;\n        this.isCurrentlyOpenWindow = false;\n        this.resetSelectedMarkerItem.emit();\n    }\n\n    public handleMapData(newData: ICaMapProps): void {\n        this.mapData = { ...newData };\n\n        if (this.mapData.selectedMarkerData)\n            this.openMarkerInfoWindow(this.mapData.selectedMarkerData);\n\n        if (newData && !this.isMapCenterSet && this.map) {\n            if (\n                newData.markers?.length ||\n                newData.clusterMarkers?.length ||\n                newData.routingMarkers?.length\n            )\n                this.setMapStyles();\n        }\n\n        // Display routes for routingMarkers\n        this.calculateAndDisplayRoute();\n\n        this.cd.detectChanges();\n    }\n\n    public getClusterId(clusterData: IMapMarkers): number | null {\n        const clusterId = this.clusterMarkerIds.find(\n            (item) =>\n                clusterData.position.lat === item.position.lat &&\n                clusterData.position.lng === item.position.lng\n        )?.id;\n\n        return clusterId || null;\n    }\n\n    public getRoutingId(markerData: IMapMarkers): number | null {\n        const routingId = this.routingMarkerIds.find(\n            (item) =>\n                markerData.position.lat === item.position.lat &&\n                markerData.position.lng === item.position.lng\n        )?.id;\n\n        return routingId || null;\n    }\n\n    public onClusterListScrollToEnd(): void {\n        if (this.openedInfoWindowData)\n            this.clusterListScrollEvent.emit(this.openedInfoWindowData);\n    }\n\n    public onZoomChange(isMinusClick?: boolean): void {\n        const currentZoomLevel = this.map?.getZoom();\n\n        if (currentZoomLevel) {\n            const nextZoomLevel = isMinusClick\n                ? currentZoomLevel - 1\n                : currentZoomLevel + 1;\n            this.map?.setZoom(nextZoomLevel);\n        }\n    }\n\n    public onOpenInMap(): void {\n        this.openInMapEvent.emit();\n    }\n\n    public getServiceData(): void {\n        this.markerIconService.clusterMarkerIds$\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((clusterIds) => {\n                this.clusterMarkerIds = clusterIds;\n            });\n\n        this.markerIconService.routingMarkerIds$\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((routingIds) => {\n                this.routingMarkerIds = routingIds;\n            });\n    }\n\n    public trackById(index: number, marker: IMapMarkers): number {\n        return marker.data.id;\n    }\n\n    public trackByPosition(index: number, marker: IMapMarkers): number {\n        return marker.position.lat + marker.position.lng;\n    }\n\n    public identity(index: number): number {\n        return index;\n    }\n\n    ngOnDestroy() {\n        this.directionsRenderers.forEach((renderer) => renderer.setMap(null));\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n}\n","<google-map\n    class=\"position-relative\"\n    [class.dark-mode-map]=\"mapData.darkMode\"\n    height=\"100%\"\n    width=\"100%\"\n    [zoom]=\"mapZoom\"\n    [center]=\"mapCenter\"\n    [options]=\"mapOptions\"\n    (mapInitialized)=\"onMapReady($event)\"\n    [mapId]=\"mapStyleId\"\n>\n    @for (marker of mapData.markers; let i = $index; track marker.data.id) {\n        <map-advanced-marker\n            [position]=\"marker.position\"\n            [content]=\"marker.content\"\n            [zIndex]=\"\n                openedInfoWindowData?.data?.id === marker.data.id ? 999 : i\n            \"\n            (mapClick)=\"onMarkerClick(marker)\"\n        >\n        </map-advanced-marker>\n    }\n\n    <div\n        #markerDropdown\n        class=\"marker-dropdown dropdown-hidden\"\n        [ngClass]=\"{ 'dropdown-hidden': !isMarkerDropdownOpen }\"\n    >\n        <app-ca-map-dropdown\n            [infoWindowContent]=\"\n                !isClusterDropdownOpen\n                    ? openedInfoWindowData?.infoWindowContent\n                    : null\n            \"\n            [markerData]=\"openedInfoWindowData?.data\"\n            (onClusterItemClick)=\"getMarkerInfoWindow($event)\"\n            (onClusterListScrollToEnd)=\"onClusterListScrollToEnd()\"\n            (onBackButtonClick)=\"onClusterBackButtonClick()\"\n        ></app-ca-map-dropdown>\n    </div>\n\n    @for (\n        clusterMarker of mapData.clusterMarkers;\n        let i = $index;\n        track trackByPosition($index, clusterMarker)\n    ) {\n        <map-advanced-marker\n            [position]=\"clusterMarker.position\"\n            [content]=\"clusterMarker.content\"\n            [zIndex]=\"\n                checkInfoWindowPosition(clusterMarker, openedInfoWindowData)\n                    ? 999\n                    : i\n            \"\n            (mapClick)=\"onClusterMarkerClick(clusterMarker)\"\n        >\n        </map-advanced-marker>\n    }\n\n    @for (route of routePolylines; let i = $index; track i) {\n        <map-polyline [options]=\"route\"></map-polyline>\n    }\n\n    <div\n        #clusterDropdown\n        class=\"marker-dropdown cluster-dropdown dropdown-hidden\"\n        [ngClass]=\"{ 'dropdown-hidden': !isClusterDropdownOpen }\"\n    >\n        <app-ca-map-dropdown\n            [infoWindowContent]=\"\n                !isMarkerDropdownOpen\n                    ? openedInfoWindowData?.infoWindowContent\n                    : null\n            \"\n            [markerData]=\"openedInfoWindowData?.data\"\n            (onClusterItemClick)=\"getMarkerInfoWindow($event)\"\n            (onClusterListScrollToEnd)=\"onClusterListScrollToEnd()\"\n            (onBackButtonClick)=\"onClusterBackButtonClick()\"\n        ></app-ca-map-dropdown>\n    </div>\n\n    @if (isAreaFilterActive) {\n        <map-circle\n            [options]=\"areaFilterData.options\"\n            [center]=\"areaFilterData.center\"\n            [radius]=\"areaFilterData.radius\"\n        ></map-circle>\n    }\n\n    @for (\n        routingMarker of mapData.routingMarkers;\n        let i = $index;\n        track trackByPosition($index, routingMarker)\n    ) {\n        <map-advanced-marker\n            [position]=\"routingMarker.position\"\n            [content]=\"routingMarker.content\"\n        >\n        </map-advanced-marker>\n    }\n\n    @if (mapData.isOpenInMapShown) {\n        <div\n            class=\"open-in-map-container d-flex align-items-center justify-content-center\"\n            ngbTooltip\n            mainCaTooltip=\"Open in Map\"\n            tooltipBackground=\"#424242\"\n            position=\"bottom\"\n            (click)=\"onOpenInMap()\"\n        >\n            <svg-icon\n                class=\"d-flex\"\n                src=\"assets/ca-components/svg/common/ic_location_map.svg\"\n                [svgStyle]=\"{ 'width.px': 18, 'height.px': 18 }\"\n            ></svg-icon>\n        </div>\n    }\n\n    @if (mapData.isZoomShown) {\n        <div\n            class=\"map-zoom-container d-flex flex-column align-items-end gap-1\"\n            [ngClass]=\"{\n                'flex-column': !mapData.isVerticalZoom,\n                'vertical-zoom-buttons': mapData.isVerticalZoom,\n            }\"\n        >\n            <div\n                class=\"map-zoom-buttons d-flex align-items-center\"\n                [class.flex-column]=\"mapData.isVerticalZoom\"\n            >\n                <div\n                    class=\"zoom-button-container d-flex align-items-center justify-content-center flex-1\"\n                    (click)=\"onZoomChange(true)\"\n                >\n                    <svg-icon\n                        class=\"d-flex\"\n                        src=\"assets/ca-components/svg/popup/Minus.svg\"\n                        [svgStyle]=\"{ 'width.px': 14, 'height.px': 14 }\"\n                    ></svg-icon>\n                </div>\n                <div\n                    class=\"zoom-button-container d-flex align-items-center justify-content-center flex-1\"\n                    (click)=\"onZoomChange(false)\"\n                >\n                    <svg-icon\n                        class=\"d-flex\"\n                        src=\"assets/ca-components/svg/common/ic_plus.svg\"\n                        [svgStyle]=\"{ 'width.px': 14, 'height.px': 14 }\"\n                    ></svg-icon>\n                </div>\n            </div>\n            <div class=\"map-zoom-range d-flex align-items-center\">\n                <div class=\"range-line\"></div>\n                <div class=\"range-text ca-font-medium\">50 mi</div>\n                <div class=\"range-line\"></div>\n            </div>\n        </div>\n    }\n</google-map>\n"]}
|
|
384
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-map.component.js","sourceRoot":"","sources":["../../../../../../projects/ca-components/src/lib/components/ca-map/ca-map.component.ts","../../../../../../projects/ca-components/src/lib/components/ca-map/ca-map.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    Input,\n    Output,\n    Renderer2,\n    ViewChild,\n    ViewEncapsulation,\n} from '@angular/core';\nimport { Subject, takeUntil } from 'rxjs';\n\n// Modules\nimport { AngularSvgIconModule } from 'angular-svg-icon';\nimport { NgbTooltipModule } from '@ng-bootstrap/ng-bootstrap';\nimport { GoogleMap, GoogleMapsModule } from '@angular/google-maps';\n\n// Components\nimport { CaMapDropdownComponent } from '../ca-map-dropdown/ca-map-dropdown.component';\nimport { CaAppTooltipV2Component } from '../ca-app-tooltip-v2/ca-app-tooltip-v2.component';\n\n// Enums\nimport { GoogleMapEnum } from '../ca-map/enums/google-map.enum';\nimport { MapMarkerStringEnum } from './enums';\n\n// Models\nimport {\n    IMapMarkers,\n    ICaMapProps,\n    IMapOptions,\n    IRoutePath,\n    IMapBoundsZoom,\n    IMapSelectedMarkerData,\n} from '../ca-map/models';\n\n// Helpers\nimport { MapHelper } from '../ca-map/utils/helpers/map.helper';\n\n// Constants\nimport { MapOptionsConstants, MapConstants } from './utils/constants';\n\n// Services\nimport { MapMarkerIconService } from './utils/services';\n\n@Component({\n    selector: 'app-ca-map',\n    templateUrl: './ca-map.component.html',\n    styleUrls: ['./ca-map.component.scss'],\n    standalone: true,\n    imports: [\n        // Modules\n        GoogleMapsModule,\n        CommonModule,\n        AngularSvgIconModule,\n        NgbTooltipModule,\n\n        // Components\n        CaMapDropdownComponent,\n        CaAppTooltipV2Component,\n    ],\n    encapsulation: ViewEncapsulation.None,\n})\nexport class CaMapComponent {\n    constructor(\n        public cd: ChangeDetectorRef,\n        private el: ElementRef,\n        private renderer: Renderer2,\n\n        // Services\n        private markerIconService: MapMarkerIconService\n    ) {}\n    @ViewChild(GoogleMap, { static: false }) maps!: GoogleMap;\n    @ViewChild('markerDropdown') markerDropdown!: ElementRef;\n    @ViewChild('clusterDropdown') clusterDropdown!: ElementRef;\n\n    @Input() set data(values: ICaMapProps) {\n        this.handleMapData(values);\n    }\n\n    @Output() resetSelectedMarkerItem = new EventEmitter<boolean>();\n    @Output() clusterMarkerClick = new EventEmitter<IMapMarkers>();\n    @Output() clusterListScrollEvent = new EventEmitter<IMapMarkers>();\n    @Output() getInfoWindowData = new EventEmitter<number>();\n    @Output() boundsChanged = new EventEmitter<IMapBoundsZoom>();\n    @Output() openInMapEvent = new EventEmitter();\n\n    private destroy$ = new Subject<void>();\n\n    public directionsRenderers: google.maps.DirectionsRenderer[] = [];\n\n    public mapOptions: IMapOptions = MapOptionsConstants.defaultMapOptions;\n    public mapZoom: number = MapOptionsConstants.defaultMapZoom;\n    public mapCenter: IRoutePath = MapOptionsConstants.defaultMapCenter;\n    public map: google.maps.Map | null = null;\n    public mapStyleId: string = 'd681904a390a8402';\n    public mapData: ICaMapProps = {};\n\n    public openedInfoWindowData: IMapMarkers | null = null;\n    public areaFilterData = MapOptionsConstants.areaFilterData;\n\n    public clusterMarkerIds: IMapMarkers[] = [];\n    public routingMarkerIds: IMapMarkers[] = [];\n    public routePolylines: google.maps.PolylineOptions[] = [];\n\n    public isMarkerDropdownOpen: boolean = false;\n    public isClusterDropdownOpen: boolean = false;\n    public isCurrentlyOpenWindow: boolean = false;\n    public isMapCenterSet: boolean = false;\n    public isAreaFilterActive: boolean = false;\n\n    public openDropdownTimeout: NodeJS.Timeout | number = 0;\n\n    ngOnInit() {\n        // Reset all icons to their initial state on page load\n        this.resetMarkersIcons();\n\n        this.getServiceData();\n    }\n\n    ngAfterViewInit() {\n        this.maps.googleMap?.addListener('click', () => {\n            this.closeInfoWindow();\n        });\n    }\n\n    public onClusterMarkerClick(markerItem: IMapMarkers): void {\n        const isInfoWindowOpened = this.checkInfoWindowPosition(\n            markerItem,\n            this.openedInfoWindowData\n        );\n\n        if (!isInfoWindowOpened) this.clusterMarkerClick.emit(markerItem);\n        else this.closeInfoWindow();\n    }\n\n    public getMarkerInfoWindow(markerId: number): void {\n        if (markerId) this.getInfoWindowData.emit(markerId);\n    }\n\n    public onMarkerClick(markerItem: IMapMarkers): void {\n        const isInfoWindowOpened = this.checkInfoWindowPosition(\n            markerItem,\n            this.openedInfoWindowData\n        );\n\n        if (!isInfoWindowOpened) this.getMarkerInfoWindow(markerItem.data.id);\n        else this.closeInfoWindow();\n    }\n\n    public setDirectionsOnMap(): void {\n        if (this.maps?.googleMap) {\n            this.directionsRenderers.forEach((renderer) =>\n                renderer.setMap(this.maps?.googleMap!)\n            );\n        }\n    }\n\n    public calculateAndDisplayRoute(): void {\n        if (this.mapData.routePaths) {\n            // Clear previous directions renderers\n            this.directionsRenderers.forEach((renderer) =>\n                renderer.setMap(null)\n            );\n            this.directionsRenderers = [];\n\n            this.routePolylines = [];\n\n            this.mapData.routePaths!.forEach((route, index) => {\n                if (route.decodedShape) {\n                    const polyLineCoordinates = route.decodedShape?.map(\n                        (item) => {\n                            const coordinates = {\n                                lat: item.latitude!,\n                                lng: item.longitude!,\n                            };\n                            return coordinates;\n                        }\n                    );\n\n                    const routePolyline: google.maps.PolylineOptions = {\n                        path: polyLineCoordinates,\n                        geodesic: true,\n                        strokeColor:\n                            route.strokeColor || GoogleMapEnum.STROKE_COLOR,\n                        strokeOpacity: !route.isDashed\n                            ? route.strokeOpacity ||\n                              GoogleMapEnum.STROKE_OPACITY\n                            : 0,\n                        strokeWeight:\n                            route.strokeWeight || GoogleMapEnum.STROKE_WEIGHT,\n                        icons: route.isDashed\n                            ? (route.dashedLineStyle ??\n                              MapOptionsConstants.routingDashedLineIcon)\n                            : null,\n                        zIndex: index,\n                    };\n\n                    this.routePolylines.push(routePolyline);\n                }\n            });\n        }\n    }\n\n    public resetMarkersIcons(): void {\n        this.mapData.markers?.map((marker: IMapMarkers, index: number) => {\n            const markerIcon = this.el.nativeElement.querySelector(\n                '#marker-' + marker.id\n            );\n            if (markerIcon)\n                this.renderer.removeClass(\n                    markerIcon,\n                    MapMarkerStringEnum.SELECTED\n                );\n            this.isMarkerDropdownOpen = false;\n\n            return {\n                ...marker,\n                options: { zIndex: index + 1 },\n            };\n        });\n\n        this.mapData.clusterMarkers?.map(\n            (clusterMarker: IMapMarkers, index: number) => {\n                const clusterId = this.getClusterId(clusterMarker);\n                const markerIcon = this.el.nativeElement.querySelector(\n                    '#cluster-' + clusterId\n                );\n                if (markerIcon)\n                    this.renderer.removeClass(\n                        markerIcon,\n                        MapMarkerStringEnum.SELECTED\n                    );\n                this.isClusterDropdownOpen = false;\n            }\n        );\n\n        this.cd.detectChanges();\n    }\n\n    public onMapReady(mapInstance: google.maps.Map): {\n        fillColor?: string;\n        strokeColor?: string;\n        strokeWeight?: number;\n        fillOpacity?: number;\n    } | void {\n        this.map = mapInstance;\n\n        if (this.mapData?.darkMode) {\n            const styledMapType = new google.maps.StyledMapType(\n                MapConstants.GOOGLE_MAP_DARK_STYLES\n            );\n            this.map!.mapTypes.set(GoogleMapEnum.DARK_MAP, styledMapType);\n            this.map!.setMapTypeId(GoogleMapEnum.DARK_MAP);\n        }\n\n        if (this.mapData.stateBoundariesUrl) {\n            const stateBoundariesUrl = this.mapData.stateBoundariesUrl.url;\n            this.maps.googleMap?.data.loadGeoJson(stateBoundariesUrl);\n\n            this.maps.googleMap?.data.setStyle((feature) => {\n                const stateDensity = feature.getProperty('density');\n                const { fillColor, fillOpacity } =\n                    MapHelper.getFillColorForState(\n                        stateDensity as number,\n                        this.mapData.view || ''\n                    );\n                return {\n                    fillColor: fillColor,\n                    strokeColor: '#EEEEEE',\n                    strokeWeight: 0.6,\n                    fillOpacity: fillOpacity,\n                };\n            });\n        }\n\n        this.sendBoundsChangedEvent();\n        this.setMapStyles();\n        this.getMapIdleEvent(mapInstance);\n    }\n\n    public setMapStyles(): void {\n        if (this.mapData?.darkMode)\n            this.mapOptions = {\n                ...this.mapOptions,\n                styles: MapConstants.GOOGLE_MAP_DARK_STYLES,\n            };\n\n        const allMarkersCombined = [\n            ...(this.mapData.routingMarkers ?? []),\n            ...(this.mapData.clusterMarkers ?? []),\n            ...(this.mapData.markers ?? []),\n        ];\n\n        if (allMarkersCombined?.length) {\n            const mapCenterAndBounds =\n                MapHelper.getMapCenterAndZoom(allMarkersCombined);\n\n            this.map!.panTo(mapCenterAndBounds.mapCenter);\n            if (mapCenterAndBounds.bounds)\n                this.map?.fitBounds(mapCenterAndBounds.bounds);\n            if (mapCenterAndBounds.mapZoom)\n                this.map?.setZoom(mapCenterAndBounds.mapZoom);\n\n            this.isMapCenterSet = true;\n        }\n    }\n\n    public getMapIdleEvent(map: google.maps.Map): void {\n        map.addListener('idle', () => {\n            this.sendBoundsChangedEvent();\n        });\n    }\n\n    public sendBoundsChangedEvent(): void {\n        if (this.map) {\n            const mapBounds = this.map.getBounds();\n            const mapZoom = this.map.getZoom();\n\n            if (mapBounds && mapZoom) {\n                const boundsObject = { bounds: mapBounds, zoom: mapZoom };\n                this.boundsChanged.emit(boundsObject);\n            }\n        }\n    }\n\n    public onClusterBackButtonClick(): void {\n        this.resetSelectedMarkerItem.emit(true);\n    }\n\n    public openMarkerInfoWindow(markerItem: IMapSelectedMarkerData): void {\n        const isInfoWindowOpened = this.checkInfoWindowPosition(\n            markerItem,\n            this.openedInfoWindowData\n        );\n\n        const combinedMarkers = [\n            ...this.mapData.markers!,\n            ...this.mapData.clusterMarkers!,\n        ];\n\n        combinedMarkers.forEach((item: IMapMarkers, index: number) => {\n            const isSelectedMarker = this.checkInfoWindowPosition(\n                item,\n                markerItem\n            );\n\n            const isClusterMarker = item?.data?.count > 1;\n\n            const clusterId = isClusterMarker ? this.getClusterId(item) : null;\n\n            const markerIconId = isClusterMarker\n                ? '#cluster-' + clusterId\n                : '#marker-' + item.id;\n\n            const dropdownElement = isClusterMarker\n                ? this.clusterDropdown.nativeElement\n                : this.markerDropdown.nativeElement;\n\n            if (isSelectedMarker) {\n                item.options = { zIndex: 999 };\n\n                if (isClusterMarker) this.isMarkerDropdownOpen = false;\n                else this.isClusterDropdownOpen = false;\n\n                clearTimeout(this.openDropdownTimeout);\n\n                this.openDropdownTimeout = setTimeout(() => {\n                    const markerIcon =\n                        this.el.nativeElement.querySelector(markerIconId);\n\n                    if (!(markerIcon?.previousSibling === dropdownElement))\n                        this.renderer.insertBefore(\n                            markerIcon?.parentNode,\n                            dropdownElement,\n                            markerIcon\n                        );\n\n                    if (\n                        markerIcon &&\n                        !markerIcon.classList?.contains(\n                            MapMarkerStringEnum.SELECTED\n                        )\n                    )\n                        this.renderer.addClass(\n                            markerIcon,\n                            MapMarkerStringEnum.SELECTED\n                        );\n\n                    this.isMarkerDropdownOpen = !isClusterMarker;\n                    this.isClusterDropdownOpen = isClusterMarker;\n\n                    this.cd.detectChanges();\n                }, 50);\n            } else {\n                const markerIcon =\n                    this.el.nativeElement.querySelector(markerIconId);\n\n                if (\n                    markerIcon?.classList?.contains(\n                        MapMarkerStringEnum.SELECTED\n                    )\n                )\n                    this.renderer.removeClass(\n                        markerIcon,\n                        MapMarkerStringEnum.SELECTED\n                    );\n\n                setTimeout(() => {\n                    item.options = { zIndex: index + 1 };\n                }, 50);\n            }\n        });\n\n        this.isCurrentlyOpenWindow = true;\n        this.openedInfoWindowData = markerItem;\n\n        if (!isInfoWindowOpened) this.map!.panTo(markerItem.position);\n    }\n\n    public checkInfoWindowPosition(\n        markerItem: IMapMarkers,\n        markerItem2?: IMapMarkers | null\n    ): boolean {\n        return (\n            markerItem.position.lat === markerItem2?.position?.lat &&\n            markerItem.position.lng === markerItem2?.position?.lng\n        );\n    }\n\n    public closeInfoWindow(): void {\n        this.resetMarkersIcons();\n\n        setTimeout(() => (this.openedInfoWindowData = null), 250);\n\n        clearTimeout(this.openDropdownTimeout);\n        this.isMarkerDropdownOpen = false;\n        this.isClusterDropdownOpen = false;\n        this.isCurrentlyOpenWindow = false;\n        this.resetSelectedMarkerItem.emit();\n    }\n\n    public handleMapData(newData: ICaMapProps): void {\n        this.mapData = { ...newData };\n\n        if (this.mapData.selectedMarkerData)\n            this.openMarkerInfoWindow(this.mapData.selectedMarkerData);\n\n        if (newData && !this.isMapCenterSet && this.map) {\n            if (\n                newData.markers?.length ||\n                newData.clusterMarkers?.length ||\n                newData.routingMarkers?.length\n            )\n                this.setMapStyles();\n        }\n\n        // Display routes for routingMarkers\n        this.calculateAndDisplayRoute();\n\n        this.cd.detectChanges();\n    }\n\n    public getClusterId(clusterData: IMapMarkers): number | null {\n        const clusterId = this.clusterMarkerIds.find(\n            (item) =>\n                clusterData.position.lat === item.position.lat &&\n                clusterData.position.lng === item.position.lng\n        )?.id;\n\n        return clusterId || null;\n    }\n\n    public getRoutingId(markerData: IMapMarkers): number | null {\n        const routingId = this.routingMarkerIds.find(\n            (item) =>\n                markerData.position.lat === item.position.lat &&\n                markerData.position.lng === item.position.lng\n        )?.id;\n\n        return routingId || null;\n    }\n\n    public onClusterListScrollToEnd(): void {\n        if (this.openedInfoWindowData)\n            this.clusterListScrollEvent.emit(this.openedInfoWindowData);\n    }\n\n    public onZoomChange(isMinusClick?: boolean): void {\n        const currentZoomLevel = this.map?.getZoom();\n\n        if (currentZoomLevel) {\n            const nextZoomLevel = isMinusClick\n                ? currentZoomLevel - 1\n                : currentZoomLevel + 1;\n            this.map?.setZoom(nextZoomLevel);\n        }\n    }\n\n    public onOpenInMap(): void {\n        this.openInMapEvent.emit();\n    }\n\n    public getServiceData(): void {\n        this.markerIconService.clusterMarkerIds$\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((clusterIds) => {\n                this.clusterMarkerIds = clusterIds;\n            });\n\n        this.markerIconService.routingMarkerIds$\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((routingIds) => {\n                this.routingMarkerIds = routingIds;\n            });\n    }\n\n    public trackById(index: number, marker: IMapMarkers): number {\n        return marker.data.id;\n    }\n\n    public trackByPosition(index: number, marker: IMapMarkers): number {\n        return marker.position.lat + marker.position.lng;\n    }\n\n    public identity(index: number): number {\n        return index;\n    }\n\n    ngOnDestroy() {\n        this.directionsRenderers.forEach((renderer) => renderer.setMap(null));\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n}\n","<google-map\n    class=\"position-relative\"\n    [class.dark-mode-map]=\"mapData.darkMode\"\n    height=\"100%\"\n    width=\"100%\"\n    [zoom]=\"mapZoom\"\n    [center]=\"mapCenter\"\n    [options]=\"mapOptions\"\n    (mapInitialized)=\"onMapReady($event)\"\n    [mapId]=\"mapStyleId\"\n>\n    @for (marker of mapData.markers; let i = $index; track marker.data.id) {\n        <map-advanced-marker\n            [position]=\"marker.position\"\n            [content]=\"marker.content\"\n            [zIndex]=\"\n                openedInfoWindowData?.data?.id === marker.data.id ? 999 : i\n            \"\n            (mapClick)=\"onMarkerClick(marker)\"\n        >\n        </map-advanced-marker>\n    }\n\n    <div\n        #markerDropdown\n        class=\"marker-dropdown dropdown-hidden\"\n        [ngClass]=\"{ 'dropdown-hidden': !isMarkerDropdownOpen }\"\n    >\n        <app-ca-map-dropdown\n            [infoWindowContent]=\"\n                !isClusterDropdownOpen\n                    ? openedInfoWindowData?.infoWindowContent\n                    : null\n            \"\n            [markerData]=\"openedInfoWindowData?.data\"\n            (onClusterItemClick)=\"getMarkerInfoWindow($event)\"\n            (onClusterListScrollToEnd)=\"onClusterListScrollToEnd()\"\n            (onBackButtonClick)=\"onClusterBackButtonClick()\"\n        ></app-ca-map-dropdown>\n    </div>\n\n    @for (\n        clusterMarker of mapData.clusterMarkers;\n        let i = $index;\n        track clusterMarker.position.lat + clusterMarker.position.lng\n    ) {\n        <map-advanced-marker\n            [position]=\"clusterMarker.position\"\n            [content]=\"clusterMarker.content\"\n            [zIndex]=\"\n                checkInfoWindowPosition(clusterMarker, openedInfoWindowData)\n                    ? 999\n                    : i\n            \"\n            (mapClick)=\"onClusterMarkerClick(clusterMarker)\"\n        >\n        </map-advanced-marker>\n    }\n\n    @for (route of routePolylines; let i = $index; track i) {\n        <map-polyline [options]=\"route\"></map-polyline>\n    }\n\n    <div\n        #clusterDropdown\n        class=\"marker-dropdown cluster-dropdown dropdown-hidden\"\n        [ngClass]=\"{ 'dropdown-hidden': !isClusterDropdownOpen }\"\n    >\n        <app-ca-map-dropdown\n            [infoWindowContent]=\"\n                !isMarkerDropdownOpen\n                    ? openedInfoWindowData?.infoWindowContent\n                    : null\n            \"\n            [markerData]=\"openedInfoWindowData?.data\"\n            (onClusterItemClick)=\"getMarkerInfoWindow($event)\"\n            (onClusterListScrollToEnd)=\"onClusterListScrollToEnd()\"\n            (onBackButtonClick)=\"onClusterBackButtonClick()\"\n        ></app-ca-map-dropdown>\n    </div>\n\n    @if (isAreaFilterActive) {\n        <map-circle\n            [options]=\"areaFilterData.options\"\n            [center]=\"areaFilterData.center\"\n            [radius]=\"areaFilterData.radius\"\n        ></map-circle>\n    }\n\n    @for (\n        routingMarker of mapData.routingMarkers;\n        let i = $index;\n        track trackByPosition($index, routingMarker)\n    ) {\n        <map-advanced-marker\n            [position]=\"routingMarker.position\"\n            [content]=\"routingMarker.content\"\n        >\n        </map-advanced-marker>\n    }\n\n    @if (mapData.isOpenInMapShown) {\n        <div\n            class=\"open-in-map-container d-flex align-items-center justify-content-center\"\n            ngbTooltip\n            mainCaTooltip=\"Open in Map\"\n            tooltipBackground=\"#424242\"\n            position=\"bottom\"\n            (click)=\"onOpenInMap()\"\n        >\n            <svg-icon\n                class=\"d-flex\"\n                src=\"assets/ca-components/svg/common/ic_location_map.svg\"\n                [svgStyle]=\"{ 'width.px': 18, 'height.px': 18 }\"\n            ></svg-icon>\n        </div>\n    }\n\n    @if (mapData.isZoomShown) {\n        <div\n            class=\"map-zoom-container d-flex flex-column align-items-end gap-1\"\n            [ngClass]=\"{\n                'flex-column': !mapData.isVerticalZoom,\n                'vertical-zoom-buttons': mapData.isVerticalZoom,\n            }\"\n        >\n            <div\n                class=\"map-zoom-buttons d-flex align-items-center\"\n                [class.flex-column]=\"mapData.isVerticalZoom\"\n            >\n                <div\n                    class=\"zoom-button-container d-flex align-items-center justify-content-center flex-1\"\n                    (click)=\"onZoomChange(true)\"\n                >\n                    <svg-icon\n                        class=\"d-flex\"\n                        src=\"assets/ca-components/svg/popup/Minus.svg\"\n                        [svgStyle]=\"{ 'width.px': 14, 'height.px': 14 }\"\n                    ></svg-icon>\n                </div>\n                <div\n                    class=\"zoom-button-container d-flex align-items-center justify-content-center flex-1\"\n                    (click)=\"onZoomChange(false)\"\n                >\n                    <svg-icon\n                        class=\"d-flex\"\n                        src=\"assets/ca-components/svg/common/ic_plus.svg\"\n                        [svgStyle]=\"{ 'width.px': 14, 'height.px': 14 }\"\n                    ></svg-icon>\n                </div>\n            </div>\n            <div class=\"map-zoom-range d-flex align-items-center\">\n                <div class=\"range-line\"></div>\n                <div class=\"range-text ca-font-medium\">50 mi</div>\n                <div class=\"range-line\"></div>\n            </div>\n        </div>\n    }\n</google-map>\n"]}
|