@acorex/components 18.10.4 → 18.10.5
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/map/acorex-components-map.mjs +5 -0
 - package/esm2022/map/index.mjs +3 -0
 - package/esm2022/map/lib/map.component.mjs +74 -0
 - package/esm2022/map/lib/map.module.mjs +18 -0
 - package/esm2022/menu/index.mjs +2 -1
 - package/esm2022/menu/lib/menu-item/menu-item.component.mjs +5 -18
 - package/esm2022/menu/lib/menu-item-text/menu-item-text.component.mjs +11 -0
 - package/esm2022/menu/lib/menu.component.mjs +9 -117
 - package/esm2022/menu/lib/menu.module.mjs +4 -3
 - package/esm2022/menu/lib/menu.service.mjs +2 -7
 - package/esm2022/rate-picker/acorex-components-rate-picker.mjs +5 -0
 - package/esm2022/rate-picker/index.mjs +3 -0
 - package/esm2022/rate-picker/lib/calculatePercentage.mjs +45 -0
 - package/esm2022/rate-picker/lib/rate-picker.component.mjs +184 -0
 - package/esm2022/rate-picker/lib/rate-picker.module.mjs +18 -0
 - package/esm2022/time-line/acorex-components-time-line.mjs +5 -0
 - package/esm2022/time-line/index.mjs +4 -0
 - package/esm2022/time-line/lib/time-line-item.component.mjs +34 -0
 - package/esm2022/time-line/lib/time-line.component.mjs +11 -0
 - package/esm2022/time-line/lib/time-line.module.mjs +19 -0
 - package/fesm2022/acorex-components-map.mjs +96 -0
 - package/fesm2022/acorex-components-map.mjs.map +1 -0
 - package/fesm2022/acorex-components-menu.mjs +24 -141
 - package/fesm2022/acorex-components-menu.mjs.map +1 -1
 - package/fesm2022/acorex-components-rate-picker.mjs +250 -0
 - package/fesm2022/acorex-components-rate-picker.mjs.map +1 -0
 - package/fesm2022/acorex-components-time-line.mjs +65 -0
 - package/fesm2022/acorex-components-time-line.mjs.map +1 -0
 - package/map/README.md +3 -0
 - package/map/index.d.ts +3 -0
 - package/map/lib/map.component.d.ts +24 -0
 - package/map/lib/map.module.d.ts +8 -0
 - package/menu/index.d.ts +1 -0
 - package/menu/lib/menu-item/menu-item.component.d.ts +1 -3
 - package/menu/lib/menu-item-text/menu-item-text.component.d.ts +5 -0
 - package/menu/lib/menu.component.d.ts +1 -6
 - package/menu/lib/menu.module.d.ts +9 -8
 - package/menu/lib/menu.service.d.ts +0 -5
 - package/package.json +55 -37
 - package/rate-picker/README.md +3 -0
 - package/rate-picker/index.d.ts +2 -0
 - package/rate-picker/lib/calculatePercentage.d.ts +27 -0
 - package/rate-picker/lib/rate-picker.component.d.ts +69 -0
 - package/rate-picker/lib/rate-picker.module.d.ts +8 -0
 - package/time-line/README.md +3 -0
 - package/time-line/index.d.ts +3 -0
 - package/time-line/lib/time-line-item.component.d.ts +7 -0
 - package/time-line/lib/time-line.component.d.ts +5 -0
 - package/time-line/lib/time-line.module.d.ts +9 -0
 
| 
         @@ -0,0 +1,45 @@ 
     | 
|
| 
      
 1 
     | 
    
         
            +
            /**
         
     | 
| 
      
 2 
     | 
    
         
            +
             * Calculates the horizontal position of a pointer event (mouse or touch) as a percentage
         
     | 
| 
      
 3 
     | 
    
         
            +
             * of the target element's width.
         
     | 
| 
      
 4 
     | 
    
         
            +
             *
         
     | 
| 
      
 5 
     | 
    
         
            +
             * @param event - The mouse or touch event to get the pointer position from.
         
     | 
| 
      
 6 
     | 
    
         
            +
             * @returns The percentage of the event's position relative to the target element's width,
         
     | 
| 
      
 7 
     | 
    
         
            +
             *          or -1 if the event is invalid.
         
     | 
| 
      
 8 
     | 
    
         
            +
             *
         
     | 
| 
      
 9 
     | 
    
         
            +
             * @remarks
         
     | 
| 
      
 10 
     | 
    
         
            +
             * - For `MouseEvent`, it uses the `clientX` property.
         
     | 
| 
      
 11 
     | 
    
         
            +
             * - For `TouchEvent`, it uses the `clientX` of the first touch point.
         
     | 
| 
      
 12 
     | 
    
         
            +
             * - Returns `-1` if the event is neither a valid `MouseEvent` nor a `TouchEvent`.
         
     | 
| 
      
 13 
     | 
    
         
            +
             *
         
     | 
| 
      
 14 
     | 
    
         
            +
             * @example
         
     | 
| 
      
 15 
     | 
    
         
            +
             * ```typescript
         
     | 
| 
      
 16 
     | 
    
         
            +
             * document.addEventListener('click', function(event) {
         
     | 
| 
      
 17 
     | 
    
         
            +
             *   const percentage = getPointerPercentage(event);
         
     | 
| 
      
 18 
     | 
    
         
            +
             *   console.log(`Click position: ${percentage.toFixed(2)}% of the element's width`);
         
     | 
| 
      
 19 
     | 
    
         
            +
             * });
         
     | 
| 
      
 20 
     | 
    
         
            +
             *
         
     | 
| 
      
 21 
     | 
    
         
            +
             * document.addEventListener('touchstart', function(event) {
         
     | 
| 
      
 22 
     | 
    
         
            +
             *   const percentage = getPointerPercentage(event);
         
     | 
| 
      
 23 
     | 
    
         
            +
             *   console.log(`Touch position: ${percentage.toFixed(2)}% of the element's width`);
         
     | 
| 
      
 24 
     | 
    
         
            +
             * });
         
     | 
| 
      
 25 
     | 
    
         
            +
             * ```
         
     | 
| 
      
 26 
     | 
    
         
            +
             */
         
     | 
| 
      
 27 
     | 
    
         
            +
            export function getPointerPercentage(event) {
         
     | 
| 
      
 28 
     | 
    
         
            +
                let clientX;
         
     | 
| 
      
 29 
     | 
    
         
            +
                if (event instanceof MouseEvent) {
         
     | 
| 
      
 30 
     | 
    
         
            +
                    clientX = event.clientX; // Mouse event uses clientX
         
     | 
| 
      
 31 
     | 
    
         
            +
                }
         
     | 
| 
      
 32 
     | 
    
         
            +
                else if (event instanceof TouchEvent && event.touches.length > 0) {
         
     | 
| 
      
 33 
     | 
    
         
            +
                    clientX = event.touches[0].clientX; // Touch event uses the first touch's clientX
         
     | 
| 
      
 34 
     | 
    
         
            +
                }
         
     | 
| 
      
 35 
     | 
    
         
            +
                else {
         
     | 
| 
      
 36 
     | 
    
         
            +
                    return -1; // Return -1 for invalid events
         
     | 
| 
      
 37 
     | 
    
         
            +
                }
         
     | 
| 
      
 38 
     | 
    
         
            +
                // Use currentTarget to get the bounding box of the element the event listener is attached to
         
     | 
| 
      
 39 
     | 
    
         
            +
                const rect = event.currentTarget.getBoundingClientRect();
         
     | 
| 
      
 40 
     | 
    
         
            +
                const clickX = clientX - rect.left; // Calculate X position relative to the element
         
     | 
| 
      
 41 
     | 
    
         
            +
                const divWidth = rect.width; // Get the width from the bounding box
         
     | 
| 
      
 42 
     | 
    
         
            +
                const percentage = (clickX / divWidth) * 100; // Calculate percentage
         
     | 
| 
      
 43 
     | 
    
         
            +
                return percentage;
         
     | 
| 
      
 44 
     | 
    
         
            +
            }
         
     | 
| 
      
 45 
     | 
    
         
            +
            //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsY3VsYXRlUGVyY2VudGFnZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9yYXRlLXBpY2tlci9zcmMvbGliL2NhbGN1bGF0ZVBlcmNlbnRhZ2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0F5Qkc7QUFDSCxNQUFNLFVBQVUsb0JBQW9CLENBQUMsS0FBOEI7SUFDakUsSUFBSSxPQUFlLENBQUM7SUFFcEIsSUFBSSxLQUFLLFlBQVksVUFBVSxFQUFFLENBQUM7UUFDaEMsT0FBTyxHQUFHLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQywyQkFBMkI7SUFDdEQsQ0FBQztTQUFNLElBQUksS0FBSyxZQUFZLFVBQVUsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUUsQ0FBQztRQUNuRSxPQUFPLEdBQUcsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyw2Q0FBNkM7SUFDbkYsQ0FBQztTQUFNLENBQUM7UUFDTixPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsK0JBQStCO0lBQzVDLENBQUM7SUFFRCw2RkFBNkY7SUFDN0YsTUFBTSxJQUFJLEdBQUksS0FBSyxDQUFDLGFBQTZCLENBQUMscUJBQXFCLEVBQUUsQ0FBQztJQUMxRSxNQUFNLE1BQU0sR0FBRyxPQUFPLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLCtDQUErQztJQUNuRixNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsc0NBQXNDO0lBQ25FLE1BQU0sVUFBVSxHQUFHLENBQUMsTUFBTSxHQUFHLFFBQVEsQ0FBQyxHQUFHLEdBQUcsQ0FBQyxDQUFDLHVCQUF1QjtJQUVyRSxPQUFPLFVBQVUsQ0FBQztBQUNwQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDYWxjdWxhdGVzIHRoZSBob3Jpem9udGFsIHBvc2l0aW9uIG9mIGEgcG9pbnRlciBldmVudCAobW91c2Ugb3IgdG91Y2gpIGFzIGEgcGVyY2VudGFnZVxuICogb2YgdGhlIHRhcmdldCBlbGVtZW50J3Mgd2lkdGguXG4gKlxuICogQHBhcmFtIGV2ZW50IC0gVGhlIG1vdXNlIG9yIHRvdWNoIGV2ZW50IHRvIGdldCB0aGUgcG9pbnRlciBwb3NpdGlvbiBmcm9tLlxuICogQHJldHVybnMgVGhlIHBlcmNlbnRhZ2Ugb2YgdGhlIGV2ZW50J3MgcG9zaXRpb24gcmVsYXRpdmUgdG8gdGhlIHRhcmdldCBlbGVtZW50J3Mgd2lkdGgsXG4gKiAgICAgICAgICBvciAtMSBpZiB0aGUgZXZlbnQgaXMgaW52YWxpZC5cbiAqXG4gKiBAcmVtYXJrc1xuICogLSBGb3IgYE1vdXNlRXZlbnRgLCBpdCB1c2VzIHRoZSBgY2xpZW50WGAgcHJvcGVydHkuXG4gKiAtIEZvciBgVG91Y2hFdmVudGAsIGl0IHVzZXMgdGhlIGBjbGllbnRYYCBvZiB0aGUgZmlyc3QgdG91Y2ggcG9pbnQuXG4gKiAtIFJldHVybnMgYC0xYCBpZiB0aGUgZXZlbnQgaXMgbmVpdGhlciBhIHZhbGlkIGBNb3VzZUV2ZW50YCBub3IgYSBgVG91Y2hFdmVudGAuXG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYHR5cGVzY3JpcHRcbiAqIGRvY3VtZW50LmFkZEV2ZW50TGlzdGVuZXIoJ2NsaWNrJywgZnVuY3Rpb24oZXZlbnQpIHtcbiAqICAgY29uc3QgcGVyY2VudGFnZSA9IGdldFBvaW50ZXJQZXJjZW50YWdlKGV2ZW50KTtcbiAqICAgY29uc29sZS5sb2coYENsaWNrIHBvc2l0aW9uOiAke3BlcmNlbnRhZ2UudG9GaXhlZCgyKX0lIG9mIHRoZSBlbGVtZW50J3Mgd2lkdGhgKTtcbiAqIH0pO1xuICpcbiAqIGRvY3VtZW50LmFkZEV2ZW50TGlzdGVuZXIoJ3RvdWNoc3RhcnQnLCBmdW5jdGlvbihldmVudCkge1xuICogICBjb25zdCBwZXJjZW50YWdlID0gZ2V0UG9pbnRlclBlcmNlbnRhZ2UoZXZlbnQpO1xuICogICBjb25zb2xlLmxvZyhgVG91Y2ggcG9zaXRpb246ICR7cGVyY2VudGFnZS50b0ZpeGVkKDIpfSUgb2YgdGhlIGVsZW1lbnQncyB3aWR0aGApO1xuICogfSk7XG4gKiBgYGBcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldFBvaW50ZXJQZXJjZW50YWdlKGV2ZW50OiBNb3VzZUV2ZW50IHwgVG91Y2hFdmVudCk6IG51bWJlciB7XG4gIGxldCBjbGllbnRYOiBudW1iZXI7XG5cbiAgaWYgKGV2ZW50IGluc3RhbmNlb2YgTW91c2VFdmVudCkge1xuICAgIGNsaWVudFggPSBldmVudC5jbGllbnRYOyAvLyBNb3VzZSBldmVudCB1c2VzIGNsaWVudFhcbiAgfSBlbHNlIGlmIChldmVudCBpbnN0YW5jZW9mIFRvdWNoRXZlbnQgJiYgZXZlbnQudG91Y2hlcy5sZW5ndGggPiAwKSB7XG4gICAgY2xpZW50WCA9IGV2ZW50LnRvdWNoZXNbMF0uY2xpZW50WDsgLy8gVG91Y2ggZXZlbnQgdXNlcyB0aGUgZmlyc3QgdG91Y2gncyBjbGllbnRYXG4gIH0gZWxzZSB7XG4gICAgcmV0dXJuIC0xOyAvLyBSZXR1cm4gLTEgZm9yIGludmFsaWQgZXZlbnRzXG4gIH1cblxuICAvLyBVc2UgY3VycmVudFRhcmdldCB0byBnZXQgdGhlIGJvdW5kaW5nIGJveCBvZiB0aGUgZWxlbWVudCB0aGUgZXZlbnQgbGlzdGVuZXIgaXMgYXR0YWNoZWQgdG9cbiAgY29uc3QgcmVjdCA9IChldmVudC5jdXJyZW50VGFyZ2V0IGFzIEhUTUxFbGVtZW50KS5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKTtcbiAgY29uc3QgY2xpY2tYID0gY2xpZW50WCAtIHJlY3QubGVmdDsgLy8gQ2FsY3VsYXRlIFggcG9zaXRpb24gcmVsYXRpdmUgdG8gdGhlIGVsZW1lbnRcbiAgY29uc3QgZGl2V2lkdGggPSByZWN0LndpZHRoOyAvLyBHZXQgdGhlIHdpZHRoIGZyb20gdGhlIGJvdW5kaW5nIGJveFxuICBjb25zdCBwZXJjZW50YWdlID0gKGNsaWNrWCAvIGRpdldpZHRoKSAqIDEwMDsgLy8gQ2FsY3VsYXRlIHBlcmNlbnRhZ2VcblxuICByZXR1cm4gcGVyY2VudGFnZTtcbn1cbiJdfQ==
         
     | 
| 
         @@ -0,0 +1,184 @@ 
     | 
|
| 
      
 1 
     | 
    
         
            +
            import { AXValuableComponent, MXValueComponent } from '@acorex/components/common';
         
     | 
| 
      
 2 
     | 
    
         
            +
            import { ChangeDetectionStrategy, Component, computed, effect, forwardRef, HostBinding, inject, input, Renderer2, signal, viewChild, ViewEncapsulation, } from '@angular/core';
         
     | 
| 
      
 3 
     | 
    
         
            +
            import { NG_VALUE_ACCESSOR } from '@angular/forms';
         
     | 
| 
      
 4 
     | 
    
         
            +
            import { getPointerPercentage } from './calculatePercentage';
         
     | 
| 
      
 5 
     | 
    
         
            +
            import * as i0 from "@angular/core";
         
     | 
| 
      
 6 
     | 
    
         
            +
            /**
         
     | 
| 
      
 7 
     | 
    
         
            +
             * A component for selecting a rating using star icons.
         
     | 
| 
      
 8 
     | 
    
         
            +
             *
         
     | 
| 
      
 9 
     | 
    
         
            +
             * This component allows users to pick a rating by clicking or dragging over star icons.
         
     | 
| 
      
 10 
     | 
    
         
            +
             * It supports rounding options and manages the rating state internally.
         
     | 
| 
      
 11 
     | 
    
         
            +
             */
         
     | 
| 
      
 12 
     | 
    
         
            +
            export class AXRatePickerComponent extends MXValueComponent {
         
     | 
| 
      
 13 
     | 
    
         
            +
                /**
         
     | 
| 
      
 14 
     | 
    
         
            +
                 * Initializes the component and sets up value change subscription.
         
     | 
| 
      
 15 
     | 
    
         
            +
                 */
         
     | 
| 
      
 16 
     | 
    
         
            +
                constructor() {
         
     | 
| 
      
 17 
     | 
    
         
            +
                    super();
         
     | 
| 
      
 18 
     | 
    
         
            +
                    /** The icon name to use for stars (e.g., 'fa-star'). */
         
     | 
| 
      
 19 
     | 
    
         
            +
                    this.iconName = input('fa-star');
         
     | 
| 
      
 20 
     | 
    
         
            +
                    /** The maximum rating value (e.g., 5 stars). */
         
     | 
| 
      
 21 
     | 
    
         
            +
                    this.max = input(5);
         
     | 
| 
      
 22 
     | 
    
         
            +
                    /** Determines if the rating should be rounded to the nearest integer. */
         
     | 
| 
      
 23 
     | 
    
         
            +
                    this.isRound = input(true);
         
     | 
| 
      
 24 
     | 
    
         
            +
                    /** choosing to have css transition for unchanging value after hover. */
         
     | 
| 
      
 25 
     | 
    
         
            +
                    this.hasTransition = input(true);
         
     | 
| 
      
 26 
     | 
    
         
            +
                    /** The percentage of the current rating value relative to the maximum rating. */
         
     | 
| 
      
 27 
     | 
    
         
            +
                    this.ratePercentage = computed(() => Math.round((this.currentValue() / this.max()) * 10000) / 100);
         
     | 
| 
      
 28 
     | 
    
         
            +
                    /** The current rating value as a signal. */
         
     | 
| 
      
 29 
     | 
    
         
            +
                    this.currentValue = signal(this.max());
         
     | 
| 
      
 30 
     | 
    
         
            +
                    /** State for tracking hover status and previous value. */
         
     | 
| 
      
 31 
     | 
    
         
            +
                    this.prevState = {
         
     | 
| 
      
 32 
     | 
    
         
            +
                        ishover: false,
         
     | 
| 
      
 33 
     | 
    
         
            +
                        previousValue: undefined,
         
     | 
| 
      
 34 
     | 
    
         
            +
                    };
         
     | 
| 
      
 35 
     | 
    
         
            +
                    /** Reference to the container element. */
         
     | 
| 
      
 36 
     | 
    
         
            +
                    this.containerEl = viewChild.required('c');
         
     | 
| 
      
 37 
     | 
    
         
            +
                    /** Reference to the rating element. */
         
     | 
| 
      
 38 
     | 
    
         
            +
                    this.ratingEl = viewChild.required('r');
         
     | 
| 
      
 39 
     | 
    
         
            +
                    /** Renderer for manipulating styles. */
         
     | 
| 
      
 40 
     | 
    
         
            +
                    this.renderer = inject(Renderer2);
         
     | 
| 
      
 41 
     | 
    
         
            +
                    /** Array of rating values from 1 to `max`. */
         
     | 
| 
      
 42 
     | 
    
         
            +
                    this.rates = computed(() => Array(this.max())
         
     | 
| 
      
 43 
     | 
    
         
            +
                        .fill(0)
         
     | 
| 
      
 44 
     | 
    
         
            +
                        .map((_, index) => index + 1));
         
     | 
| 
      
 45 
     | 
    
         
            +
                    effect(() => {
         
     | 
| 
      
 46 
     | 
    
         
            +
                        if (!this.hasTransition()) {
         
     | 
| 
      
 47 
     | 
    
         
            +
                            this.renderer.removeStyle(this.ratingEl().nativeElement, 'transition');
         
     | 
| 
      
 48 
     | 
    
         
            +
                        }
         
     | 
| 
      
 49 
     | 
    
         
            +
                        return this.hasTransition();
         
     | 
| 
      
 50 
     | 
    
         
            +
                    });
         
     | 
| 
      
 51 
     | 
    
         
            +
                    this.onValueChanged.subscribe((val) => {
         
     | 
| 
      
 52 
     | 
    
         
            +
                        if (val.value < 0) {
         
     | 
| 
      
 53 
     | 
    
         
            +
                            this.currentValue.set(0);
         
     | 
| 
      
 54 
     | 
    
         
            +
                            console.warn('ax-rate-picker: value cant be negative!');
         
     | 
| 
      
 55 
     | 
    
         
            +
                        }
         
     | 
| 
      
 56 
     | 
    
         
            +
                        else if (val.value > this.max()) {
         
     | 
| 
      
 57 
     | 
    
         
            +
                            this.currentValue.set(this.max());
         
     | 
| 
      
 58 
     | 
    
         
            +
                            console.warn('ax-rate-picker: value cant be more than max!');
         
     | 
| 
      
 59 
     | 
    
         
            +
                        }
         
     | 
| 
      
 60 
     | 
    
         
            +
                        else {
         
     | 
| 
      
 61 
     | 
    
         
            +
                            this.currentValue.set(val.value);
         
     | 
| 
      
 62 
     | 
    
         
            +
                        }
         
     | 
| 
      
 63 
     | 
    
         
            +
                    });
         
     | 
| 
      
 64 
     | 
    
         
            +
                }
         
     | 
| 
      
 65 
     | 
    
         
            +
                /**
         
     | 
| 
      
 66 
     | 
    
         
            +
                 * Calculates and updates the rating based on the mouse or touch event.
         
     | 
| 
      
 67 
     | 
    
         
            +
                 *
         
     | 
| 
      
 68 
     | 
    
         
            +
                 * @param event - The mouse or touch event triggering the rating calculation.
         
     | 
| 
      
 69 
     | 
    
         
            +
                 */
         
     | 
| 
      
 70 
     | 
    
         
            +
                calculateRate(event) {
         
     | 
| 
      
 71 
     | 
    
         
            +
                    if (this.hasTransition()) {
         
     | 
| 
      
 72 
     | 
    
         
            +
                        this.renderer.removeStyle(this.ratingEl().nativeElement, 'transition');
         
     | 
| 
      
 73 
     | 
    
         
            +
                    }
         
     | 
| 
      
 74 
     | 
    
         
            +
                    event.preventDefault();
         
     | 
| 
      
 75 
     | 
    
         
            +
                    if (!this.readonly && !this.disabled) {
         
     | 
| 
      
 76 
     | 
    
         
            +
                        const pointerPercentage = getPointerPercentage(event);
         
     | 
| 
      
 77 
     | 
    
         
            +
                        if (pointerPercentage === -1) {
         
     | 
| 
      
 78 
     | 
    
         
            +
                            return console.log('Only support touch and click events.');
         
     | 
| 
      
 79 
     | 
    
         
            +
                        }
         
     | 
| 
      
 80 
     | 
    
         
            +
                        const value = (pointerPercentage / 100) * this.max();
         
     | 
| 
      
 81 
     | 
    
         
            +
                        const finalValue = this.isRound() ? Math.ceil(value) : Number.parseFloat(value.toFixed(2));
         
     | 
| 
      
 82 
     | 
    
         
            +
                        if (finalValue !== this.value) {
         
     | 
| 
      
 83 
     | 
    
         
            +
                            if (this.prevState.ishover === true) {
         
     | 
| 
      
 84 
     | 
    
         
            +
                                this.currentValue.set(finalValue);
         
     | 
| 
      
 85 
     | 
    
         
            +
                            }
         
     | 
| 
      
 86 
     | 
    
         
            +
                            else {
         
     | 
| 
      
 87 
     | 
    
         
            +
                                this.commitValue(finalValue);
         
     | 
| 
      
 88 
     | 
    
         
            +
                            }
         
     | 
| 
      
 89 
     | 
    
         
            +
                        }
         
     | 
| 
      
 90 
     | 
    
         
            +
                    }
         
     | 
| 
      
 91 
     | 
    
         
            +
                }
         
     | 
| 
      
 92 
     | 
    
         
            +
                /**
         
     | 
| 
      
 93 
     | 
    
         
            +
                 * Handles mouse enter events to start tracking mouse movements for rating.
         
     | 
| 
      
 94 
     | 
    
         
            +
                 */
         
     | 
| 
      
 95 
     | 
    
         
            +
                mouseEnter() {
         
     | 
| 
      
 96 
     | 
    
         
            +
                    this.prevState = {
         
     | 
| 
      
 97 
     | 
    
         
            +
                        ishover: true,
         
     | 
| 
      
 98 
     | 
    
         
            +
                        previousValue: this.value,
         
     | 
| 
      
 99 
     | 
    
         
            +
                    };
         
     | 
| 
      
 100 
     | 
    
         
            +
                    if (this.hasTransition()) {
         
     | 
| 
      
 101 
     | 
    
         
            +
                        this.renderer.setStyle(this.ratingEl().nativeElement, 'opacity', '80%');
         
     | 
| 
      
 102 
     | 
    
         
            +
                    }
         
     | 
| 
      
 103 
     | 
    
         
            +
                    const moveListener = (moveEvent) => this.calculateRate(moveEvent);
         
     | 
| 
      
 104 
     | 
    
         
            +
                    const endListener = () => this.onEnd(moveListener, endListener);
         
     | 
| 
      
 105 
     | 
    
         
            +
                    const container = this.containerEl().nativeElement;
         
     | 
| 
      
 106 
     | 
    
         
            +
                    container.addEventListener('mousemove', moveListener);
         
     | 
| 
      
 107 
     | 
    
         
            +
                    container.addEventListener('mouseup', endListener);
         
     | 
| 
      
 108 
     | 
    
         
            +
                    container.addEventListener('mouseleave', endListener);
         
     | 
| 
      
 109 
     | 
    
         
            +
                }
         
     | 
| 
      
 110 
     | 
    
         
            +
                mouseLeave() {
         
     | 
| 
      
 111 
     | 
    
         
            +
                    if (this.hasTransition()) {
         
     | 
| 
      
 112 
     | 
    
         
            +
                        this.renderer.removeStyle(this.ratingEl().nativeElement, 'opacity');
         
     | 
| 
      
 113 
     | 
    
         
            +
                    }
         
     | 
| 
      
 114 
     | 
    
         
            +
                }
         
     | 
| 
      
 115 
     | 
    
         
            +
                /**
         
     | 
| 
      
 116 
     | 
    
         
            +
                 * Cleans up event listeners and restores the previous rating value.
         
     | 
| 
      
 117 
     | 
    
         
            +
                 *
         
     | 
| 
      
 118 
     | 
    
         
            +
                 * @param moveListener - The function to remove for mouse move events.
         
     | 
| 
      
 119 
     | 
    
         
            +
                 * @param endListener - The function to remove for mouse end events.
         
     | 
| 
      
 120 
     | 
    
         
            +
                 */
         
     | 
| 
      
 121 
     | 
    
         
            +
                onEnd(moveListener, endListener) {
         
     | 
| 
      
 122 
     | 
    
         
            +
                    if (this.hasTransition()) {
         
     | 
| 
      
 123 
     | 
    
         
            +
                        this.renderer.setStyle(this.ratingEl().nativeElement, 'transition', `width ${this.max() * 50 + 250}ms cubic-bezier(0.29, 0.72, 0.68, 0.85)`);
         
     | 
| 
      
 124 
     | 
    
         
            +
                        this.renderer.removeStyle(this.ratingEl().nativeElement, 'opacity');
         
     | 
| 
      
 125 
     | 
    
         
            +
                    }
         
     | 
| 
      
 126 
     | 
    
         
            +
                    this.currentValue.set(this.prevState.previousValue);
         
     | 
| 
      
 127 
     | 
    
         
            +
                    this.prevState = {
         
     | 
| 
      
 128 
     | 
    
         
            +
                        ishover: false,
         
     | 
| 
      
 129 
     | 
    
         
            +
                        previousValue: undefined,
         
     | 
| 
      
 130 
     | 
    
         
            +
                    };
         
     | 
| 
      
 131 
     | 
    
         
            +
                    const container = this.containerEl().nativeElement;
         
     | 
| 
      
 132 
     | 
    
         
            +
                    container.removeEventListener('mousemove', moveListener);
         
     | 
| 
      
 133 
     | 
    
         
            +
                    container.removeEventListener('mouseup', endListener);
         
     | 
| 
      
 134 
     | 
    
         
            +
                    container.removeEventListener('mouseleave', endListener);
         
     | 
| 
      
 135 
     | 
    
         
            +
                }
         
     | 
| 
      
 136 
     | 
    
         
            +
                /**
         
     | 
| 
      
 137 
     | 
    
         
            +
                 * Determines if the component is active (i.e., not readonly or disabled).
         
     | 
| 
      
 138 
     | 
    
         
            +
                 */
         
     | 
| 
      
 139 
     | 
    
         
            +
                get isActive() {
         
     | 
| 
      
 140 
     | 
    
         
            +
                    return !this.readonly && !this.disabled;
         
     | 
| 
      
 141 
     | 
    
         
            +
                }
         
     | 
| 
      
 142 
     | 
    
         
            +
                /**
         
     | 
| 
      
 143 
     | 
    
         
            +
                 * Determines if the component is in readonly mode.
         
     | 
| 
      
 144 
     | 
    
         
            +
                 */
         
     | 
| 
      
 145 
     | 
    
         
            +
                get isReadonly() {
         
     | 
| 
      
 146 
     | 
    
         
            +
                    return this.readonly;
         
     | 
| 
      
 147 
     | 
    
         
            +
                }
         
     | 
| 
      
 148 
     | 
    
         
            +
                /**
         
     | 
| 
      
 149 
     | 
    
         
            +
                 * Determines if the component is disabled.
         
     | 
| 
      
 150 
     | 
    
         
            +
                 */
         
     | 
| 
      
 151 
     | 
    
         
            +
                get isDisabled() {
         
     | 
| 
      
 152 
     | 
    
         
            +
                    return this.disabled;
         
     | 
| 
      
 153 
     | 
    
         
            +
                }
         
     | 
| 
      
 154 
     | 
    
         
            +
                static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXRatePickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
         
     | 
| 
      
 155 
     | 
    
         
            +
                static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: AXRatePickerComponent, selector: "ax-rate-picker", inputs: { readonly: { classPropertyName: "readonly", publicName: "readonly", isSignal: false, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: false, isRequired: false, transformFunction: null }, iconName: { classPropertyName: "iconName", publicName: "iconName", isSignal: true, isRequired: false, transformFunction: null }, max: { classPropertyName: "max", publicName: "max", isSignal: true, isRequired: false, transformFunction: null }, isRound: { classPropertyName: "isRound", publicName: "isRound", isSignal: true, isRequired: false, transformFunction: null }, hasTransition: { classPropertyName: "hasTransition", publicName: "hasTransition", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "class.active": "this.isActive", "class.readonly": "this.isReadonly", "class.disable": "this.isDisabled" } }, providers: [
         
     | 
| 
      
 156 
     | 
    
         
            +
                        { provide: AXValuableComponent, useExisting: AXRatePickerComponent },
         
     | 
| 
      
 157 
     | 
    
         
            +
                        {
         
     | 
| 
      
 158 
     | 
    
         
            +
                            provide: NG_VALUE_ACCESSOR,
         
     | 
| 
      
 159 
     | 
    
         
            +
                            useExisting: forwardRef(() => AXRatePickerComponent),
         
     | 
| 
      
 160 
     | 
    
         
            +
                            multi: true,
         
     | 
| 
      
 161 
     | 
    
         
            +
                        },
         
     | 
| 
      
 162 
     | 
    
         
            +
                    ], viewQueries: [{ propertyName: "containerEl", first: true, predicate: ["c"], descendants: true, isSignal: true }, { propertyName: "ratingEl", first: true, predicate: ["r"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<div\n  #c\n  class=\"ax-rate-picker-container\"\n  (click)=\"calculateRate($event)\"\n  (touchstart)=\"calculateRate($event)\"\n  (mouseenter)=\"mouseEnter()\"\n  (mouseleave)=\"mouseLeave()\"\n>\n  <div #r class=\"ax-rate-picker-rating\" [style.width.%]=\"ratePercentage()\">\n    <div class=\"ax-rate-picker-icons ax-rp-active\">\n      @for (rate of rates(); track rate) {\n        <i class=\"ax-rate-picker-icon fa-solid\" [class]=\"iconName()\" [class.pointer]=\"!this.readonly\"></i>\n      }\n    </div>\n  </div>\n  <div class=\"ax-rate-picker-icons ax-rp-inactive\">\n    @for (rate of rates(); track rate) {\n      <i class=\"ax-rate-picker-icon fa-solid\" [class]=\"iconName()\"></i>\n    }\n  </div>\n</div>\n", styles: [":root{--ax-rate-picker-color: rgba(var(--ax-color-primary-500));--ax-rate-picker-background: rgba(var(--ax-color-neutral-300))}ax-rate-picker.active{cursor:pointer}ax-rate-picker.readonly{opacity:.75}ax-rate-picker.disable{cursor:not-allowed;opacity:.5}ax-rate-picker.ax-sm{font-size:1rem}ax-rate-picker.ax-md{font-size:1.5rem}ax-rate-picker.ax-lg{font-size:2rem}ax-rate-picker.ax-xl{font-size:2.5rem}ax-rate-picker.ax-2xl{font-size:3rem}ax-rate-picker.ax-3xl{font-size:4rem}ax-rate-picker .ax-rate-picker-container{position:relative;width:min-content}ax-rate-picker .ax-rate-picker-container .ax-rate-picker-rating{position:relative;z-index:10;overflow:hidden}ax-rate-picker .ax-rate-picker-container .ax-rate-picker-rating .ax-rate-picker-icons{display:flex}ax-rate-picker .ax-rate-picker-container .ax-rate-picker-rating .ax-rate-picker-icons.ax-rp-active{color:var(--ax-rate-picker-color)}ax-rate-picker .ax-rate-picker-container .ax-rate-picker-icons{display:flex}ax-rate-picker .ax-rate-picker-container .ax-rate-picker-icons.ax-rp-inactive{color:var(--ax-rate-picker-background);position:absolute;left:50%;top:50%;translate:-50% -50%;z-index:5}.ax-dark :root{--ax-rate-picker-color: rgba(var(--ax-color-primary-300));--ax-rate-picker-background: rgba(var(--ax-color-neutral-600))}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
         
     | 
| 
      
 163 
     | 
    
         
            +
            }
         
     | 
| 
      
 164 
     | 
    
         
            +
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXRatePickerComponent, decorators: [{
         
     | 
| 
      
 165 
     | 
    
         
            +
                        type: Component,
         
     | 
| 
      
 166 
     | 
    
         
            +
                        args: [{ selector: 'ax-rate-picker', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, inputs: ['readonly', 'disabled'], providers: [
         
     | 
| 
      
 167 
     | 
    
         
            +
                                    { provide: AXValuableComponent, useExisting: AXRatePickerComponent },
         
     | 
| 
      
 168 
     | 
    
         
            +
                                    {
         
     | 
| 
      
 169 
     | 
    
         
            +
                                        provide: NG_VALUE_ACCESSOR,
         
     | 
| 
      
 170 
     | 
    
         
            +
                                        useExisting: forwardRef(() => AXRatePickerComponent),
         
     | 
| 
      
 171 
     | 
    
         
            +
                                        multi: true,
         
     | 
| 
      
 172 
     | 
    
         
            +
                                    },
         
     | 
| 
      
 173 
     | 
    
         
            +
                                ], template: "<div\n  #c\n  class=\"ax-rate-picker-container\"\n  (click)=\"calculateRate($event)\"\n  (touchstart)=\"calculateRate($event)\"\n  (mouseenter)=\"mouseEnter()\"\n  (mouseleave)=\"mouseLeave()\"\n>\n  <div #r class=\"ax-rate-picker-rating\" [style.width.%]=\"ratePercentage()\">\n    <div class=\"ax-rate-picker-icons ax-rp-active\">\n      @for (rate of rates(); track rate) {\n        <i class=\"ax-rate-picker-icon fa-solid\" [class]=\"iconName()\" [class.pointer]=\"!this.readonly\"></i>\n      }\n    </div>\n  </div>\n  <div class=\"ax-rate-picker-icons ax-rp-inactive\">\n    @for (rate of rates(); track rate) {\n      <i class=\"ax-rate-picker-icon fa-solid\" [class]=\"iconName()\"></i>\n    }\n  </div>\n</div>\n", styles: [":root{--ax-rate-picker-color: rgba(var(--ax-color-primary-500));--ax-rate-picker-background: rgba(var(--ax-color-neutral-300))}ax-rate-picker.active{cursor:pointer}ax-rate-picker.readonly{opacity:.75}ax-rate-picker.disable{cursor:not-allowed;opacity:.5}ax-rate-picker.ax-sm{font-size:1rem}ax-rate-picker.ax-md{font-size:1.5rem}ax-rate-picker.ax-lg{font-size:2rem}ax-rate-picker.ax-xl{font-size:2.5rem}ax-rate-picker.ax-2xl{font-size:3rem}ax-rate-picker.ax-3xl{font-size:4rem}ax-rate-picker .ax-rate-picker-container{position:relative;width:min-content}ax-rate-picker .ax-rate-picker-container .ax-rate-picker-rating{position:relative;z-index:10;overflow:hidden}ax-rate-picker .ax-rate-picker-container .ax-rate-picker-rating .ax-rate-picker-icons{display:flex}ax-rate-picker .ax-rate-picker-container .ax-rate-picker-rating .ax-rate-picker-icons.ax-rp-active{color:var(--ax-rate-picker-color)}ax-rate-picker .ax-rate-picker-container .ax-rate-picker-icons{display:flex}ax-rate-picker .ax-rate-picker-container .ax-rate-picker-icons.ax-rp-inactive{color:var(--ax-rate-picker-background);position:absolute;left:50%;top:50%;translate:-50% -50%;z-index:5}.ax-dark :root{--ax-rate-picker-color: rgba(var(--ax-color-primary-300));--ax-rate-picker-background: rgba(var(--ax-color-neutral-600))}\n"] }]
         
     | 
| 
      
 174 
     | 
    
         
            +
                    }], ctorParameters: () => [], propDecorators: { isActive: [{
         
     | 
| 
      
 175 
     | 
    
         
            +
                            type: HostBinding,
         
     | 
| 
      
 176 
     | 
    
         
            +
                            args: ['class.active']
         
     | 
| 
      
 177 
     | 
    
         
            +
                        }], isReadonly: [{
         
     | 
| 
      
 178 
     | 
    
         
            +
                            type: HostBinding,
         
     | 
| 
      
 179 
     | 
    
         
            +
                            args: ['class.readonly']
         
     | 
| 
      
 180 
     | 
    
         
            +
                        }], isDisabled: [{
         
     | 
| 
      
 181 
     | 
    
         
            +
                            type: HostBinding,
         
     | 
| 
      
 182 
     | 
    
         
            +
                            args: ['class.disable']
         
     | 
| 
      
 183 
     | 
    
         
            +
                        }] } });
         
     | 
| 
      
 184 
     | 
    
         
            +
            //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rate-picker.component.js","sourceRoot":"","sources":["../../../../../../libs/components/rate-picker/src/lib/rate-picker.component.ts","../../../../../../libs/components/rate-picker/src/lib/rate-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXValuableComponent, MXValueComponent } from '@acorex/components/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  computed,\n  effect,\n  ElementRef,\n  forwardRef,\n  HostBinding,\n  inject,\n  input,\n  Renderer2,\n  signal,\n  viewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { getPointerPercentage } from './calculatePercentage';\n\n/**\n * A component for selecting a rating using star icons.\n *\n * This component allows users to pick a rating by clicking or dragging over star icons.\n * It supports rounding options and manages the rating state internally.\n */\n@Component({\n  selector: 'ax-rate-picker',\n  templateUrl: './rate-picker.component.html',\n  styleUrls: ['./rate-picker.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  inputs: ['readonly', 'disabled'],\n  providers: [\n    { provide: AXValuableComponent, useExisting: AXRatePickerComponent },\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => AXRatePickerComponent),\n      multi: true,\n    },\n  ],\n})\nexport class AXRatePickerComponent extends MXValueComponent<number> {\n  /** The icon name to use for stars (e.g., 'fa-star'). */\n  iconName = input('fa-star');\n\n  /** The maximum rating value (e.g., 5 stars). */\n  max = input(5);\n\n  /** Determines if the rating should be rounded to the nearest integer. */\n  isRound = input(true);\n\n  /** choosing to have css transition for unchanging value after hover. */\n  hasTransition = input(true);\n\n  /** The percentage of the current rating value relative to the maximum rating. */\n  protected ratePercentage = computed(() => Math.round((this.currentValue() / this.max()) * 10000) / 100);\n\n  /** The current rating value as a signal. */\n  private currentValue = signal(this.max());\n\n  /** State for tracking hover status and previous value. */\n  private prevState: { ishover: boolean; previousValue?: number } = {\n    ishover: false,\n    previousValue: undefined,\n  };\n\n  /** Reference to the container element. */\n  containerEl = viewChild.required<ElementRef>('c');\n\n  /** Reference to the rating element. */\n  ratingEl = viewChild.required<ElementRef>('r');\n\n  /** Renderer for manipulating styles. */\n  renderer = inject(Renderer2);\n\n  /** Array of rating values from 1 to `max`. */\n  protected rates = computed(() =>\n    Array(this.max())\n      .fill(0)\n      .map((_, index) => index + 1),\n  );\n\n  /**\n   * Initializes the component and sets up value change subscription.\n   */\n  constructor() {\n    super();\n    effect(() => {\n      if (!this.hasTransition()) {\n        this.renderer.removeStyle(this.ratingEl().nativeElement, 'transition');\n      }\n      return this.hasTransition();\n    });\n    this.onValueChanged.subscribe((val: { value }) => {\n      if (val.value < 0) {\n        this.currentValue.set(0);\n        console.warn('ax-rate-picker: value cant be negative!');\n      } else if (val.value > this.max()) {\n        this.currentValue.set(this.max());\n        console.warn('ax-rate-picker: value cant be more than max!');\n      } else {\n        this.currentValue.set(val.value);\n      }\n    });\n  }\n\n  /**\n   * Calculates and updates the rating based on the mouse or touch event.\n   *\n   * @param event - The mouse or touch event triggering the rating calculation.\n   */\n  protected calculateRate(event: MouseEvent | TouchEvent): void {\n    if (this.hasTransition()) {\n      this.renderer.removeStyle(this.ratingEl().nativeElement, 'transition');\n    }\n    event.preventDefault();\n    if (!this.readonly && !this.disabled) {\n      const pointerPercentage = getPointerPercentage(event);\n      if (pointerPercentage === -1) {\n        return console.log('Only support touch and click events.');\n      }\n      const value = (pointerPercentage / 100) * this.max();\n      const finalValue = this.isRound() ? Math.ceil(value) : Number.parseFloat(value.toFixed(2));\n      if (finalValue !== this.value) {\n        if (this.prevState.ishover === true) {\n          this.currentValue.set(finalValue);\n        } else {\n          this.commitValue(finalValue);\n        }\n      }\n    }\n  }\n\n  /**\n   * Handles mouse enter events to start tracking mouse movements for rating.\n   */\n  protected mouseEnter() {\n    this.prevState = {\n      ishover: true,\n      previousValue: this.value,\n    };\n    if (this.hasTransition()) {\n      this.renderer.setStyle(this.ratingEl().nativeElement, 'opacity', '80%');\n    }\n    const moveListener = (moveEvent: MouseEvent | TouchEvent) => this.calculateRate(moveEvent);\n    const endListener = () => this.onEnd(moveListener, endListener);\n    const container = this.containerEl().nativeElement;\n    container.addEventListener('mousemove', moveListener);\n    container.addEventListener('mouseup', endListener);\n    container.addEventListener('mouseleave', endListener);\n  }\n  mouseLeave() {\n    if (this.hasTransition()) {\n      this.renderer.removeStyle(this.ratingEl().nativeElement, 'opacity');\n    }\n  }\n  /**\n   * Cleans up event listeners and restores the previous rating value.\n   *\n   * @param moveListener - The function to remove for mouse move events.\n   * @param endListener - The function to remove for mouse end events.\n   */\n  private onEnd(moveListener: (event: MouseEvent | TouchEvent) => void, endListener: () => void): void {\n    if (this.hasTransition()) {\n      this.renderer.setStyle(\n        this.ratingEl().nativeElement,\n        'transition',\n        `width ${this.max() * 50 + 250}ms cubic-bezier(0.29, 0.72, 0.68, 0.85)`,\n      );\n      this.renderer.removeStyle(this.ratingEl().nativeElement, 'opacity');\n    }\n\n    this.currentValue.set(this.prevState.previousValue);\n    this.prevState = {\n      ishover: false,\n      previousValue: undefined,\n    };\n\n    const container = this.containerEl().nativeElement;\n    container.removeEventListener('mousemove', moveListener);\n    container.removeEventListener('mouseup', endListener);\n    container.removeEventListener('mouseleave', endListener);\n  }\n\n  /**\n   * Determines if the component is active (i.e., not readonly or disabled).\n   */\n  @HostBinding('class.active') get isActive() {\n    return !this.readonly && !this.disabled;\n  }\n\n  /**\n   * Determines if the component is in readonly mode.\n   */\n  @HostBinding('class.readonly') get isReadonly() {\n    return this.readonly;\n  }\n\n  /**\n   * Determines if the component is disabled.\n   */\n  @HostBinding('class.disable') get isDisabled() {\n    return this.disabled;\n  }\n}\n","<div\n  #c\n  class=\"ax-rate-picker-container\"\n  (click)=\"calculateRate($event)\"\n  (touchstart)=\"calculateRate($event)\"\n  (mouseenter)=\"mouseEnter()\"\n  (mouseleave)=\"mouseLeave()\"\n>\n  <div #r class=\"ax-rate-picker-rating\" [style.width.%]=\"ratePercentage()\">\n    <div class=\"ax-rate-picker-icons ax-rp-active\">\n      @for (rate of rates(); track rate) {\n        <i class=\"ax-rate-picker-icon fa-solid\" [class]=\"iconName()\" [class.pointer]=\"!this.readonly\"></i>\n      }\n    </div>\n  </div>\n  <div class=\"ax-rate-picker-icons ax-rp-inactive\">\n    @for (rate of rates(); track rate) {\n      <i class=\"ax-rate-picker-icon fa-solid\" [class]=\"iconName()\"></i>\n    }\n  </div>\n</div>\n"]}
         
     | 
| 
         @@ -0,0 +1,18 @@ 
     | 
|
| 
      
 1 
     | 
    
         
            +
            import { CommonModule } from '@angular/common';
         
     | 
| 
      
 2 
     | 
    
         
            +
            import { NgModule } from '@angular/core';
         
     | 
| 
      
 3 
     | 
    
         
            +
            import { AXRatePickerComponent } from './rate-picker.component';
         
     | 
| 
      
 4 
     | 
    
         
            +
            import * as i0 from "@angular/core";
         
     | 
| 
      
 5 
     | 
    
         
            +
            export class AXRatePickerModule {
         
     | 
| 
      
 6 
     | 
    
         
            +
                static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXRatePickerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
         
     | 
| 
      
 7 
     | 
    
         
            +
                static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.0", ngImport: i0, type: AXRatePickerModule, declarations: [AXRatePickerComponent], imports: [CommonModule], exports: [AXRatePickerComponent] }); }
         
     | 
| 
      
 8 
     | 
    
         
            +
                static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXRatePickerModule, imports: [CommonModule] }); }
         
     | 
| 
      
 9 
     | 
    
         
            +
            }
         
     | 
| 
      
 10 
     | 
    
         
            +
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXRatePickerModule, decorators: [{
         
     | 
| 
      
 11 
     | 
    
         
            +
                        type: NgModule,
         
     | 
| 
      
 12 
     | 
    
         
            +
                        args: [{
         
     | 
| 
      
 13 
     | 
    
         
            +
                                declarations: [AXRatePickerComponent],
         
     | 
| 
      
 14 
     | 
    
         
            +
                                imports: [CommonModule],
         
     | 
| 
      
 15 
     | 
    
         
            +
                                exports: [AXRatePickerComponent],
         
     | 
| 
      
 16 
     | 
    
         
            +
                            }]
         
     | 
| 
      
 17 
     | 
    
         
            +
                    }] });
         
     | 
| 
      
 18 
     | 
    
         
            +
            //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmF0ZS1waWNrZXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL3JhdGUtcGlja2VyL3NyYy9saWIvcmF0ZS1waWNrZXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHlCQUF5QixDQUFDOztBQU9oRSxNQUFNLE9BQU8sa0JBQWtCOzhHQUFsQixrQkFBa0I7K0dBQWxCLGtCQUFrQixpQkFKZCxxQkFBcUIsYUFDMUIsWUFBWSxhQUNaLHFCQUFxQjsrR0FFcEIsa0JBQWtCLFlBSG5CLFlBQVk7OzJGQUdYLGtCQUFrQjtrQkFMOUIsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxxQkFBcUIsQ0FBQztvQkFDckMsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO29CQUN2QixPQUFPLEVBQUUsQ0FBQyxxQkFBcUIsQ0FBQztpQkFDakMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEFYUmF0ZVBpY2tlckNvbXBvbmVudCB9IGZyb20gJy4vcmF0ZS1waWNrZXIuY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbQVhSYXRlUGlja2VyQ29tcG9uZW50XSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG4gIGV4cG9ydHM6IFtBWFJhdGVQaWNrZXJDb21wb25lbnRdLFxufSlcbmV4cG9ydCBjbGFzcyBBWFJhdGVQaWNrZXJNb2R1bGUge31cbiJdfQ==
         
     | 
| 
         @@ -0,0 +1,5 @@ 
     | 
|
| 
      
 1 
     | 
    
         
            +
            /**
         
     | 
| 
      
 2 
     | 
    
         
            +
             * Generated bundle index. Do not edit.
         
     | 
| 
      
 3 
     | 
    
         
            +
             */
         
     | 
| 
      
 4 
     | 
    
         
            +
            export * from './index';
         
     | 
| 
      
 5 
     | 
    
         
            +
            //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNvcmV4LWNvbXBvbmVudHMtdGltZS1saW5lLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL3RpbWUtbGluZS9zcmMvYWNvcmV4LWNvbXBvbmVudHMtdGltZS1saW5lLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vaW5kZXgnO1xuIl19
         
     | 
| 
         @@ -0,0 +1,4 @@ 
     | 
|
| 
      
 1 
     | 
    
         
            +
            export * from './lib/time-line-item.component';
         
     | 
| 
      
 2 
     | 
    
         
            +
            export * from './lib/time-line.component';
         
     | 
| 
      
 3 
     | 
    
         
            +
            export * from './lib/time-line.module';
         
     | 
| 
      
 4 
     | 
    
         
            +
            //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvdGltZS1saW5lL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGdDQUFnQyxDQUFDO0FBQy9DLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyx3QkFBd0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL3RpbWUtbGluZS1pdGVtLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90aW1lLWxpbmUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RpbWUtbGluZS5tb2R1bGUnO1xuIl19
         
     | 
| 
         @@ -0,0 +1,34 @@ 
     | 
|
| 
      
 1 
     | 
    
         
            +
            import { ChangeDetectionStrategy, Component, input, signal, ViewEncapsulation } from '@angular/core';
         
     | 
| 
      
 2 
     | 
    
         
            +
            import * as i0 from "@angular/core";
         
     | 
| 
      
 3 
     | 
    
         
            +
            import * as i1 from "@angular/common";
         
     | 
| 
      
 4 
     | 
    
         
            +
            export class AXTimeLineItemComponent {
         
     | 
| 
      
 5 
     | 
    
         
            +
                constructor() {
         
     | 
| 
      
 6 
     | 
    
         
            +
                    this.text = input('');
         
     | 
| 
      
 7 
     | 
    
         
            +
                    this.isCollapsed = signal(false);
         
     | 
| 
      
 8 
     | 
    
         
            +
                }
         
     | 
| 
      
 9 
     | 
    
         
            +
                static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXTimeLineItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
         
     | 
| 
      
 10 
     | 
    
         
            +
                static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.0", type: AXTimeLineItemComponent, selector: "ax-time-line-item", inputs: { text: { classPropertyName: "text", publicName: "text", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: `
         
     | 
| 
      
 11 
     | 
    
         
            +
                <div class="ax-time-line-header">
         
     | 
| 
      
 12 
     | 
    
         
            +
                  <span class="ax-time-line-text">{{ text() }}</span>
         
     | 
| 
      
 13 
     | 
    
         
            +
                  <span
         
     | 
| 
      
 14 
     | 
    
         
            +
                    class="ax-icon ax-icon-chevron-down ax-collapse-arrow"
         
     | 
| 
      
 15 
     | 
    
         
            +
                    [ngClass]="{ '-rotation-90': isCollapsed(), 'rotation-90': !isCollapsed() }"
         
     | 
| 
      
 16 
     | 
    
         
            +
                  ></span>
         
     | 
| 
      
 17 
     | 
    
         
            +
                </div>
         
     | 
| 
      
 18 
     | 
    
         
            +
                <div class="ax-time-line-content"><ng-content></ng-content></div>
         
     | 
| 
      
 19 
     | 
    
         
            +
              `, isInline: true, styles: ["ax-time-line-item{padding-bottom:.75rem;display:block}ax-time-line-item .ax-time-line-header{display:flex;justify-content:space-between;align-items:center;padding:0 .75rem}ax-time-line-item .ax-time-line-header .ax-time-line-text{flex:1}ax-time-line-item .ax-time-line-content{padding:.75rem}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
         
     | 
| 
      
 20 
     | 
    
         
            +
            }
         
     | 
| 
      
 21 
     | 
    
         
            +
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXTimeLineItemComponent, decorators: [{
         
     | 
| 
      
 22 
     | 
    
         
            +
                        type: Component,
         
     | 
| 
      
 23 
     | 
    
         
            +
                        args: [{ selector: 'ax-time-line-item', template: `
         
     | 
| 
      
 24 
     | 
    
         
            +
                <div class="ax-time-line-header">
         
     | 
| 
      
 25 
     | 
    
         
            +
                  <span class="ax-time-line-text">{{ text() }}</span>
         
     | 
| 
      
 26 
     | 
    
         
            +
                  <span
         
     | 
| 
      
 27 
     | 
    
         
            +
                    class="ax-icon ax-icon-chevron-down ax-collapse-arrow"
         
     | 
| 
      
 28 
     | 
    
         
            +
                    [ngClass]="{ '-rotation-90': isCollapsed(), 'rotation-90': !isCollapsed() }"
         
     | 
| 
      
 29 
     | 
    
         
            +
                  ></span>
         
     | 
| 
      
 30 
     | 
    
         
            +
                </div>
         
     | 
| 
      
 31 
     | 
    
         
            +
                <div class="ax-time-line-content"><ng-content></ng-content></div>
         
     | 
| 
      
 32 
     | 
    
         
            +
              `, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, styles: ["ax-time-line-item{padding-bottom:.75rem;display:block}ax-time-line-item .ax-time-line-header{display:flex;justify-content:space-between;align-items:center;padding:0 .75rem}ax-time-line-item .ax-time-line-header .ax-time-line-text{flex:1}ax-time-line-item .ax-time-line-content{padding:.75rem}\n"] }]
         
     | 
| 
      
 33 
     | 
    
         
            +
                    }] });
         
     | 
| 
      
 34 
     | 
    
         
            +
            //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGltZS1saW5lLWl0ZW0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL3RpbWUtbGluZS9zcmMvbGliL3RpbWUtbGluZS1pdGVtLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQWtCckcsTUFBTSxPQUFPLHVCQUF1QjtJQWhCcEM7UUFpQkUsU0FBSSxHQUFHLEtBQUssQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUVqQixnQkFBVyxHQUFHLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztLQUM3Qjs4R0FKWSx1QkFBdUI7a0dBQXZCLHVCQUF1QiwwTEFkeEI7Ozs7Ozs7OztHQVNUOzsyRkFLVSx1QkFBdUI7a0JBaEJuQyxTQUFTOytCQUNFLG1CQUFtQixZQUNuQjs7Ozs7Ozs7O0dBU1QsaUJBRWMsaUJBQWlCLENBQUMsSUFBSSxtQkFDcEIsdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGlucHV0LCBzaWduYWwsIFZpZXdFbmNhcHN1bGF0aW9uIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2F4LXRpbWUtbGluZS1pdGVtJyxcbiAgdGVtcGxhdGU6IGBcbiAgICA8ZGl2IGNsYXNzPVwiYXgtdGltZS1saW5lLWhlYWRlclwiPlxuICAgICAgPHNwYW4gY2xhc3M9XCJheC10aW1lLWxpbmUtdGV4dFwiPnt7IHRleHQoKSB9fTwvc3Bhbj5cbiAgICAgIDxzcGFuXG4gICAgICAgIGNsYXNzPVwiYXgtaWNvbiBheC1pY29uLWNoZXZyb24tZG93biBheC1jb2xsYXBzZS1hcnJvd1wiXG4gICAgICAgIFtuZ0NsYXNzXT1cInsgJy1yb3RhdGlvbi05MCc6IGlzQ29sbGFwc2VkKCksICdyb3RhdGlvbi05MCc6ICFpc0NvbGxhcHNlZCgpIH1cIlxuICAgICAgPjwvc3Bhbj5cbiAgICA8L2Rpdj5cbiAgICA8ZGl2IGNsYXNzPVwiYXgtdGltZS1saW5lLWNvbnRlbnRcIj48bmctY29udGVudD48L25nLWNvbnRlbnQ+PC9kaXY+XG4gIGAsXG4gIHN0eWxlVXJsOiAnLi90aW1lLWxpbmUtaXRlbS5jb21wb25lbnQuc2NzcycsXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBBWFRpbWVMaW5lSXRlbUNvbXBvbmVudCB7XG4gIHRleHQgPSBpbnB1dCgnJyk7XG5cbiAgaXNDb2xsYXBzZWQgPSBzaWduYWwoZmFsc2UpO1xufVxuIl19
         
     | 
| 
         @@ -0,0 +1,11 @@ 
     | 
|
| 
      
 1 
     | 
    
         
            +
            import { Component } from '@angular/core';
         
     | 
| 
      
 2 
     | 
    
         
            +
            import * as i0 from "@angular/core";
         
     | 
| 
      
 3 
     | 
    
         
            +
            export class AXTimeLineComponent {
         
     | 
| 
      
 4 
     | 
    
         
            +
                static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXTimeLineComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
         
     | 
| 
      
 5 
     | 
    
         
            +
                static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.0", type: AXTimeLineComponent, selector: "ax-time-line", ngImport: i0, template: "<ng-content></ng-content>\n", styles: [""] }); }
         
     | 
| 
      
 6 
     | 
    
         
            +
            }
         
     | 
| 
      
 7 
     | 
    
         
            +
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXTimeLineComponent, decorators: [{
         
     | 
| 
      
 8 
     | 
    
         
            +
                        type: Component,
         
     | 
| 
      
 9 
     | 
    
         
            +
                        args: [{ selector: 'ax-time-line', template: "<ng-content></ng-content>\n" }]
         
     | 
| 
      
 10 
     | 
    
         
            +
                    }] });
         
     | 
| 
      
 11 
     | 
    
         
            +
            //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGltZS1saW5lLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy90aW1lLWxpbmUvc3JjL2xpYi90aW1lLWxpbmUuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL3RpbWUtbGluZS9zcmMvbGliL3RpbWUtbGluZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQU8xQyxNQUFNLE9BQU8sbUJBQW1COzhHQUFuQixtQkFBbUI7a0dBQW5CLG1CQUFtQixvRENQaEMsNkJBQ0E7OzJGRE1hLG1CQUFtQjtrQkFML0IsU0FBUzsrQkFDRSxjQUFjIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2F4LXRpbWUtbGluZScsXG4gIHRlbXBsYXRlVXJsOiAnLi90aW1lLWxpbmUuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi90aW1lLWxpbmUuY29tcG9uZW50LnNjc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgQVhUaW1lTGluZUNvbXBvbmVudCB7fVxuIiwiPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuIl19
         
     | 
| 
         @@ -0,0 +1,19 @@ 
     | 
|
| 
      
 1 
     | 
    
         
            +
            import { CommonModule } from '@angular/common';
         
     | 
| 
      
 2 
     | 
    
         
            +
            import { NgModule } from '@angular/core';
         
     | 
| 
      
 3 
     | 
    
         
            +
            import { AXTimeLineItemComponent } from './time-line-item.component';
         
     | 
| 
      
 4 
     | 
    
         
            +
            import { AXTimeLineComponent } from './time-line.component';
         
     | 
| 
      
 5 
     | 
    
         
            +
            import * as i0 from "@angular/core";
         
     | 
| 
      
 6 
     | 
    
         
            +
            export class AXTimeLineModule {
         
     | 
| 
      
 7 
     | 
    
         
            +
                static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXTimeLineModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
         
     | 
| 
      
 8 
     | 
    
         
            +
                static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.0", ngImport: i0, type: AXTimeLineModule, declarations: [AXTimeLineComponent, AXTimeLineItemComponent], imports: [CommonModule], exports: [AXTimeLineComponent, AXTimeLineItemComponent] }); }
         
     | 
| 
      
 9 
     | 
    
         
            +
                static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXTimeLineModule, imports: [CommonModule] }); }
         
     | 
| 
      
 10 
     | 
    
         
            +
            }
         
     | 
| 
      
 11 
     | 
    
         
            +
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXTimeLineModule, decorators: [{
         
     | 
| 
      
 12 
     | 
    
         
            +
                        type: NgModule,
         
     | 
| 
      
 13 
     | 
    
         
            +
                        args: [{
         
     | 
| 
      
 14 
     | 
    
         
            +
                                declarations: [AXTimeLineComponent, AXTimeLineItemComponent],
         
     | 
| 
      
 15 
     | 
    
         
            +
                                imports: [CommonModule],
         
     | 
| 
      
 16 
     | 
    
         
            +
                                exports: [AXTimeLineComponent, AXTimeLineItemComponent],
         
     | 
| 
      
 17 
     | 
    
         
            +
                            }]
         
     | 
| 
      
 18 
     | 
    
         
            +
                    }] });
         
     | 
| 
      
 19 
     | 
    
         
            +
            //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGltZS1saW5lLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy90aW1lLWxpbmUvc3JjL2xpYi90aW1lLWxpbmUubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQ3JFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDOztBQU81RCxNQUFNLE9BQU8sZ0JBQWdCOzhHQUFoQixnQkFBZ0I7K0dBQWhCLGdCQUFnQixpQkFKWixtQkFBbUIsRUFBRSx1QkFBdUIsYUFDakQsWUFBWSxhQUNaLG1CQUFtQixFQUFFLHVCQUF1QjsrR0FFM0MsZ0JBQWdCLFlBSGpCLFlBQVk7OzJGQUdYLGdCQUFnQjtrQkFMNUIsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxtQkFBbUIsRUFBRSx1QkFBdUIsQ0FBQztvQkFDNUQsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO29CQUN2QixPQUFPLEVBQUUsQ0FBQyxtQkFBbUIsRUFBRSx1QkFBdUIsQ0FBQztpQkFDeEQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEFYVGltZUxpbmVJdGVtQ29tcG9uZW50IH0gZnJvbSAnLi90aW1lLWxpbmUtaXRlbS5jb21wb25lbnQnO1xuaW1wb3J0IHsgQVhUaW1lTGluZUNvbXBvbmVudCB9IGZyb20gJy4vdGltZS1saW5lLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW0FYVGltZUxpbmVDb21wb25lbnQsIEFYVGltZUxpbmVJdGVtQ29tcG9uZW50XSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG4gIGV4cG9ydHM6IFtBWFRpbWVMaW5lQ29tcG9uZW50LCBBWFRpbWVMaW5lSXRlbUNvbXBvbmVudF0sXG59KVxuZXhwb3J0IGNsYXNzIEFYVGltZUxpbmVNb2R1bGUge31cbiJdfQ==
         
     | 
| 
         @@ -0,0 +1,96 @@ 
     | 
|
| 
      
 1 
     | 
    
         
            +
            import { AXLeafletService } from '@acorex/cdk/map';
         
     | 
| 
      
 2 
     | 
    
         
            +
            import * as i0 from '@angular/core';
         
     | 
| 
      
 3 
     | 
    
         
            +
            import { input, output, viewChild, effect, Component, ChangeDetectionStrategy, ViewEncapsulation, NgModule } from '@angular/core';
         
     | 
| 
      
 4 
     | 
    
         
            +
            import { distinctUntilChanged } from 'rxjs/operators';
         
     | 
| 
      
 5 
     | 
    
         
            +
            import { CommonModule } from '@angular/common';
         
     | 
| 
      
 6 
     | 
    
         
            +
             
     | 
| 
      
 7 
     | 
    
         
            +
            class AXMapComponent {
         
     | 
| 
      
 8 
     | 
    
         
            +
                ngAfterViewInit() {
         
     | 
| 
      
 9 
     | 
    
         
            +
                    this.leaflet = new AXLeafletService(this.mapContainer().nativeElement, { latitude: this.latitude(), longitude: this.longitude() }, this.zoomLevel());
         
     | 
| 
      
 10 
     | 
    
         
            +
                    if (this.markers()) {
         
     | 
| 
      
 11 
     | 
    
         
            +
                        this.leaflet.addMarker(this.markers());
         
     | 
| 
      
 12 
     | 
    
         
            +
                    }
         
     | 
| 
      
 13 
     | 
    
         
            +
                }
         
     | 
| 
      
 14 
     | 
    
         
            +
                addMarker(location) {
         
     | 
| 
      
 15 
     | 
    
         
            +
                    this.leaflet.addMarker(location);
         
     | 
| 
      
 16 
     | 
    
         
            +
                }
         
     | 
| 
      
 17 
     | 
    
         
            +
                flyTo(location, zoom, setMarker, duration) {
         
     | 
| 
      
 18 
     | 
    
         
            +
                    this.leaflet.flyTo(location, zoom, setMarker, duration);
         
     | 
| 
      
 19 
     | 
    
         
            +
                }
         
     | 
| 
      
 20 
     | 
    
         
            +
                constructor() {
         
     | 
| 
      
 21 
     | 
    
         
            +
                    this.zoomLevel = input(13);
         
     | 
| 
      
 22 
     | 
    
         
            +
                    this.latitude = input(51.505);
         
     | 
| 
      
 23 
     | 
    
         
            +
                    this.longitude = input(-0.09);
         
     | 
| 
      
 24 
     | 
    
         
            +
                    this.hasMarker = input(false);
         
     | 
| 
      
 25 
     | 
    
         
            +
                    this.markerPlace = input('topleft');
         
     | 
| 
      
 26 
     | 
    
         
            +
                    this.hasLocator = input(false);
         
     | 
| 
      
 27 
     | 
    
         
            +
                    this.locatePlace = input('bottomright');
         
     | 
| 
      
 28 
     | 
    
         
            +
                    this.markers = input(undefined);
         
     | 
| 
      
 29 
     | 
    
         
            +
                    this.onMarkerAdded = output();
         
     | 
| 
      
 30 
     | 
    
         
            +
                    this.onLocationFound = output();
         
     | 
| 
      
 31 
     | 
    
         
            +
                    this.mapContainer = viewChild('mapContainer');
         
     | 
| 
      
 32 
     | 
    
         
            +
                    effect(() => {
         
     | 
| 
      
 33 
     | 
    
         
            +
                        if (!this.hasLocator()) {
         
     | 
| 
      
 34 
     | 
    
         
            +
                            this.leaflet.removeLocateControl();
         
     | 
| 
      
 35 
     | 
    
         
            +
                        }
         
     | 
| 
      
 36 
     | 
    
         
            +
                        else {
         
     | 
| 
      
 37 
     | 
    
         
            +
                            this.leaflet.addLocateControl(this.locatePlace());
         
     | 
| 
      
 38 
     | 
    
         
            +
                            this.leaflet.onLocationFound
         
     | 
| 
      
 39 
     | 
    
         
            +
                                .pipe(distinctUntilChanged((prev, curr) => prev.latitude === curr.latitude && prev.longitude === curr.longitude))
         
     | 
| 
      
 40 
     | 
    
         
            +
                                .subscribe((location) => {
         
     | 
| 
      
 41 
     | 
    
         
            +
                                this.onLocationFound.emit(location);
         
     | 
| 
      
 42 
     | 
    
         
            +
                            });
         
     | 
| 
      
 43 
     | 
    
         
            +
                        }
         
     | 
| 
      
 44 
     | 
    
         
            +
                    });
         
     | 
| 
      
 45 
     | 
    
         
            +
                    effect(() => {
         
     | 
| 
      
 46 
     | 
    
         
            +
                        if (!this.hasMarker()) {
         
     | 
| 
      
 47 
     | 
    
         
            +
                            this.leaflet.removeDrawControl(this.markerPlace());
         
     | 
| 
      
 48 
     | 
    
         
            +
                        }
         
     | 
| 
      
 49 
     | 
    
         
            +
                        else {
         
     | 
| 
      
 50 
     | 
    
         
            +
                            this.leaflet.addDrawControl();
         
     | 
| 
      
 51 
     | 
    
         
            +
                            this.leaflet.onMarkerAdded.subscribe((location) => {
         
     | 
| 
      
 52 
     | 
    
         
            +
                                this.onMarkerAdded.emit(location);
         
     | 
| 
      
 53 
     | 
    
         
            +
                            });
         
     | 
| 
      
 54 
     | 
    
         
            +
                        }
         
     | 
| 
      
 55 
     | 
    
         
            +
                    });
         
     | 
| 
      
 56 
     | 
    
         
            +
                    effect(() => {
         
     | 
| 
      
 57 
     | 
    
         
            +
                        this.leaflet.setZoomLevel(this.zoomLevel());
         
     | 
| 
      
 58 
     | 
    
         
            +
                    }, {});
         
     | 
| 
      
 59 
     | 
    
         
            +
                    effect(() => {
         
     | 
| 
      
 60 
     | 
    
         
            +
                        this.leaflet.setCenter({
         
     | 
| 
      
 61 
     | 
    
         
            +
                            latitude: this.latitude(),
         
     | 
| 
      
 62 
     | 
    
         
            +
                            longitude: this.longitude(),
         
     | 
| 
      
 63 
     | 
    
         
            +
                        });
         
     | 
| 
      
 64 
     | 
    
         
            +
                    });
         
     | 
| 
      
 65 
     | 
    
         
            +
                }
         
     | 
| 
      
 66 
     | 
    
         
            +
                ngOnDestroy() {
         
     | 
| 
      
 67 
     | 
    
         
            +
                    this.leaflet.destroyMap();
         
     | 
| 
      
 68 
     | 
    
         
            +
                }
         
     | 
| 
      
 69 
     | 
    
         
            +
                static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXMapComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
         
     | 
| 
      
 70 
     | 
    
         
            +
                static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.0", type: AXMapComponent, selector: "ax-map", inputs: { zoomLevel: { classPropertyName: "zoomLevel", publicName: "zoomLevel", isSignal: true, isRequired: false, transformFunction: null }, latitude: { classPropertyName: "latitude", publicName: "latitude", isSignal: true, isRequired: false, transformFunction: null }, longitude: { classPropertyName: "longitude", publicName: "longitude", isSignal: true, isRequired: false, transformFunction: null }, hasMarker: { classPropertyName: "hasMarker", publicName: "hasMarker", isSignal: true, isRequired: false, transformFunction: null }, markerPlace: { classPropertyName: "markerPlace", publicName: "markerPlace", isSignal: true, isRequired: false, transformFunction: null }, hasLocator: { classPropertyName: "hasLocator", publicName: "hasLocator", isSignal: true, isRequired: false, transformFunction: null }, locatePlace: { classPropertyName: "locatePlace", publicName: "locatePlace", isSignal: true, isRequired: false, transformFunction: null }, markers: { classPropertyName: "markers", publicName: "markers", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onMarkerAdded: "onMarkerAdded", onLocationFound: "onLocationFound" }, viewQueries: [{ propertyName: "mapContainer", first: true, predicate: ["mapContainer"], descendants: true, isSignal: true }], ngImport: i0, template: "<div #mapContainer class=\"ax-map-container\"></div>\n", styles: [".ax-map-container{height:100%;width:100%}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
         
     | 
| 
      
 71 
     | 
    
         
            +
            }
         
     | 
| 
      
 72 
     | 
    
         
            +
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXMapComponent, decorators: [{
         
     | 
| 
      
 73 
     | 
    
         
            +
                        type: Component,
         
     | 
| 
      
 74 
     | 
    
         
            +
                        args: [{ selector: 'ax-map', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: "<div #mapContainer class=\"ax-map-container\"></div>\n", styles: [".ax-map-container{height:100%;width:100%}\n"] }]
         
     | 
| 
      
 75 
     | 
    
         
            +
                    }], ctorParameters: () => [] });
         
     | 
| 
      
 76 
     | 
    
         
            +
             
     | 
| 
      
 77 
     | 
    
         
            +
            class AXMapModule {
         
     | 
| 
      
 78 
     | 
    
         
            +
                static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXMapModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
         
     | 
| 
      
 79 
     | 
    
         
            +
                static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.0", ngImport: i0, type: AXMapModule, declarations: [AXMapComponent], imports: [CommonModule], exports: [AXMapComponent] }); }
         
     | 
| 
      
 80 
     | 
    
         
            +
                static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXMapModule, imports: [CommonModule] }); }
         
     | 
| 
      
 81 
     | 
    
         
            +
            }
         
     | 
| 
      
 82 
     | 
    
         
            +
            i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXMapModule, decorators: [{
         
     | 
| 
      
 83 
     | 
    
         
            +
                        type: NgModule,
         
     | 
| 
      
 84 
     | 
    
         
            +
                        args: [{
         
     | 
| 
      
 85 
     | 
    
         
            +
                                declarations: [AXMapComponent],
         
     | 
| 
      
 86 
     | 
    
         
            +
                                imports: [CommonModule],
         
     | 
| 
      
 87 
     | 
    
         
            +
                                exports: [AXMapComponent],
         
     | 
| 
      
 88 
     | 
    
         
            +
                            }]
         
     | 
| 
      
 89 
     | 
    
         
            +
                    }] });
         
     | 
| 
      
 90 
     | 
    
         
            +
             
     | 
| 
      
 91 
     | 
    
         
            +
            /**
         
     | 
| 
      
 92 
     | 
    
         
            +
             * Generated bundle index. Do not edit.
         
     | 
| 
      
 93 
     | 
    
         
            +
             */
         
     | 
| 
      
 94 
     | 
    
         
            +
             
     | 
| 
      
 95 
     | 
    
         
            +
            export { AXMapComponent, AXMapModule };
         
     | 
| 
      
 96 
     | 
    
         
            +
            //# sourceMappingURL=acorex-components-map.mjs.map
         
     | 
| 
         @@ -0,0 +1 @@ 
     | 
|
| 
      
 1 
     | 
    
         
            +
            {"version":3,"file":"acorex-components-map.mjs","sources":["../../../../libs/components/map/src/lib/map.component.ts","../../../../libs/components/map/src/lib/map.component.html","../../../../libs/components/map/src/lib/map.module.ts","../../../../libs/components/map/src/acorex-components-map.ts"],"sourcesContent":["import { AXLeafletService, AXMapControlPlace, AXMapLocation } from '@acorex/cdk/map';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  effect,\n  ElementRef,\n  input,\n  OnDestroy,\n  output,\n  viewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { distinctUntilChanged } from 'rxjs/operators';\n\n@Component({\n  selector: 'ax-map',\n  templateUrl: './map.component.html',\n  styleUrls: ['./map.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class AXMapComponent implements AfterViewInit, OnDestroy {\n  zoomLevel = input(13);\n  latitude = input(51.505);\n  longitude = input(-0.09);\n  hasMarker = input(false);\n  markerPlace = input<AXMapControlPlace>('topleft');\n  hasLocator = input(false);\n  locatePlace = input<AXMapControlPlace>('bottomright');\n  markers = input<AXMapLocation | AXMapLocation[] | undefined>(undefined);\n  onMarkerAdded = output<AXMapLocation>();\n  onLocationFound = output<AXMapLocation>();\n\n  private mapContainer = viewChild<ElementRef>('mapContainer');\n  private leaflet;\n\n  ngAfterViewInit() {\n    this.leaflet = new AXLeafletService(\n      this.mapContainer().nativeElement,\n      { latitude: this.latitude(), longitude: this.longitude() },\n      this.zoomLevel(),\n    );\n    if (this.markers()) {\n      this.leaflet.addMarker(this.markers());\n    }\n  }\n\n  addMarker(location: AXMapLocation) {\n    this.leaflet.addMarker(location);\n  }\n\n  flyTo(location: AXMapLocation, zoom?: number, setMarker?: boolean, duration?: number) {\n    this.leaflet.flyTo(location, zoom, setMarker, duration);\n  }\n\n  constructor() {\n    effect(() => {\n      if (!this.hasLocator()) {\n        this.leaflet.removeLocateControl();\n      } else {\n        this.leaflet.addLocateControl(this.locatePlace());\n        this.leaflet.onLocationFound\n          .pipe(\n            distinctUntilChanged(\n              (prev: AXMapLocation, curr: AXMapLocation) =>\n                prev.latitude === curr.latitude && prev.longitude === curr.longitude,\n            ),\n          )\n          .subscribe((location: AXMapLocation) => {\n            this.onLocationFound.emit(location);\n          });\n      }\n    });\n    effect(() => {\n      if (!this.hasMarker()) {\n        this.leaflet.removeDrawControl(this.markerPlace());\n      } else {\n        this.leaflet.addDrawControl();\n        this.leaflet.onMarkerAdded.subscribe((location: AXMapLocation) => {\n          this.onMarkerAdded.emit(location);\n        });\n      }\n    });\n    effect(() => {\n      this.leaflet.setZoomLevel(this.zoomLevel());\n    }, {});\n    effect(() => {\n      this.leaflet.setCenter({\n        latitude: this.latitude(),\n        longitude: this.longitude(),\n      } as AXMapLocation);\n    });\n  }\n  ngOnDestroy(): void {\n    this.leaflet.destroyMap();\n  }\n}\n","<div #mapContainer class=\"ax-map-container\"></div>\n","import { CommonModule } from '@angular/common';\nimport { NgModule } from '@angular/core';\nimport { AXMapComponent } from './map.component';\n\n@NgModule({\n  declarations: [AXMapComponent],\n  imports: [CommonModule],\n  exports: [AXMapComponent],\n})\nexport class AXMapModule {}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
         
     |