mis-crystal-design-system 18.1.7 → 18.1.8
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/input/directives/input/input.directive.mjs +7 -15
- package/esm2022/input/mis-input.component.mjs +41 -25
- package/esm2022/table/table.component.mjs +10 -2
- package/esm2022/timerangepicker/timerangepicker.component.mjs +27 -10
- package/fesm2022/mis-crystal-design-system-input.mjs +46 -38
- package/fesm2022/mis-crystal-design-system-input.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-table.mjs +9 -1
- package/fesm2022/mis-crystal-design-system-table.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-timerangepicker.mjs +26 -9
- package/fesm2022/mis-crystal-design-system-timerangepicker.mjs.map +1 -1
- package/input/mis-input.component.d.ts +1 -0
- package/input/mis-input.component.scss +17 -10
- package/package.json +13 -13
|
@@ -82,18 +82,35 @@ export class TimeRangePickerComponent {
|
|
|
82
82
|
// Update previous values
|
|
83
83
|
this._previousStartDateEpoch = currentStartDate;
|
|
84
84
|
this._previousEndDateEpoch = currentEndDate;
|
|
85
|
-
//
|
|
86
|
-
this.
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
85
|
+
// PRESERVE the currently selected times (don't reset them!)
|
|
86
|
+
const currentStartTimeString = this.startTime().time;
|
|
87
|
+
const currentEndTimeString = this.endTime().time;
|
|
88
|
+
// Calculate new epochs with the new date but SAME time
|
|
89
|
+
const newStartEpoch = dayjs.tz(`${this.getStartDate()} ${currentStartTimeString}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf();
|
|
90
|
+
const newEndEpoch = dayjs.tz(`${this.getEndDate()} ${currentEndTimeString}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf();
|
|
91
|
+
// Update the time signals with preserved times but new epochs
|
|
92
|
+
this.startTime.set({
|
|
93
|
+
valid: true,
|
|
94
|
+
time: currentStartTimeString,
|
|
95
|
+
epoch: newStartEpoch
|
|
96
|
+
});
|
|
97
|
+
this.endTime.set({
|
|
98
|
+
valid: true,
|
|
99
|
+
time: currentEndTimeString,
|
|
100
|
+
epoch: newEndEpoch
|
|
101
|
+
});
|
|
102
|
+
// Update firstIntervals for the dropdown options based on new date
|
|
103
|
+
this.setFirstIntervals();
|
|
104
|
+
// Emit the updated time range with preserved times but new date
|
|
105
|
+
const validity = this.checkTimeValidity(currentStartTimeString.trim(), this.startDateEpoch()) &&
|
|
106
|
+
this.checkTimeValidity(currentEndTimeString.trim(), this.endDateEpoch());
|
|
90
107
|
this.rangeValidation(validity);
|
|
91
108
|
this.emitTimeRange({
|
|
92
109
|
valid: validity && this.rangeValidity(),
|
|
93
|
-
startTime:
|
|
94
|
-
endTime:
|
|
95
|
-
startEpoch:
|
|
96
|
-
endEpoch:
|
|
110
|
+
startTime: currentStartTimeString,
|
|
111
|
+
endTime: currentEndTimeString,
|
|
112
|
+
startEpoch: newStartEpoch,
|
|
113
|
+
endEpoch: newEndEpoch
|
|
97
114
|
});
|
|
98
115
|
});
|
|
99
116
|
}, { allowSignalWrites: true });
|
|
@@ -325,4 +342,4 @@ export class TimeRangePickerComponent {
|
|
|
325
342
|
args: [{ selector: "mis-timerangepicker", template: "<div class=\"rangepicker-container\" [ngStyle]=\"{'flexDirection': direction(), 'gap': gap()}\">\n <mis-timepicker\n [clockFormat]=\"clockFormat()\"\n [interval]=\"interval()\"\n [dateAsEpoch]=\"startDateEpoch()\"\n [firstInterval]=\"firstIntervals().start\"\n (timeEmitter)=\"startPickerHandler($event)\"\n [timezone]=\"timezone()\"\n [height]=\"height()\"\n [inputWidth]=\"inputWidth()\"\n [dropdownWidth]=\"dropdownWidth()\"\n [showTooltip]=\"showTooltip()\"\n [givenTime]=\"givenStartTime()\"\n [disable]=\"disableStartTime()\"\n [disableUserInput]=\"disableUserInput()\"\n [fontSize]=\"fontSize()\"\n ></mis-timepicker>\n <p *ngIf=\"direction() === 'row'\">-</p>\n <mis-timepicker\n [clockFormat]=\"clockFormat()\"\n [interval]=\"interval()\"\n [dateAsEpoch]=\"endDateEpoch()\"\n [firstInterval]=\"firstIntervals().end\"\n (timeEmitter)=\"endPickerHandler($event)\"\n [rangeValidity]=\"rangeValidity()\"\n [timezone]=\"timezone()\"\n [height]=\"height()\"\n [inputWidth]=\"inputWidth()\"\n [dropdownWidth]=\"dropdownWidth()\"\n [showTooltip]=\"showTooltip()\"\n [givenTime]=\"givenEndTime()\"\n [triggerChange]=\"triggerChange()\"\n [disable]=\"disableEndTime()\"\n [disableUserInput]=\"disableUserInput()\"\n [fontSize]=\"fontSize()\"\n ></mis-timepicker>\n</div>\n\n", styles: [".rangepicker-container{display:flex;gap:1rem;align-items:center}p{margin:0;display:inline-flex;align-items:center}\n"] }]
|
|
326
343
|
}], () => [], null); })();
|
|
327
344
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(TimeRangePickerComponent, { className: "TimeRangePickerComponent" }); })();
|
|
328
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timerangepicker.component.js","sourceRoot":"","sources":["../../../../projects/mis-components/timerangepicker/timerangepicker.component.ts","../../../../projects/mis-components/timerangepicker/timerangepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, input, output, signal, computed, effect, untracked, OnInit } from \"@angular/core\";\nimport { ITimeRange, ITime, TDirection } from \"./timerange.namespace\";\nimport dayjs from 'dayjs';\nimport timezone from 'dayjs/plugin/timezone';\nimport utc from 'dayjs/plugin/utc';\n\ndayjs.extend(utc);\ndayjs.extend(timezone);\n\n@Component({\n  selector: \"mis-timerangepicker\",\n  templateUrl: \"./timerangepicker.component.html\", // Corrected file name\n  styleUrls: [\"./timerangepicker.component.scss\"]\n})\nexport class TimeRangePickerComponent implements OnInit {\n  // --- Input Signals (read-only) ---\n  inputWidth = input<string>(\"100px\");\n  dropdownWidth = input<string | undefined>(undefined);\n  height = input<string>(\"46px\");\n  timezone = input<string>(\"Asia/Kolkata\");\n  startDateEpoch = input<number>(dayjs.tz(dayjs(), this.timezone()).valueOf());\n  endDateEpoch = input<number>(dayjs.tz(dayjs(), this.timezone()).valueOf());\n  givenStartTime = input<number | undefined>(undefined);\n  givenEndTime = input<number | undefined>(undefined);\n  clockFormat = input<number>(12);\n  interval = input<number>(15);\n  showTooltip = input<boolean>(true);\n  direction = input<TDirection>('row');\n  gap = input<string>('1rem');\n  disableStartTime = input<boolean>(false);\n  disableEndTime = input<boolean>(false);\n  fontSize = input<string>(\"14px\");\n  disableUserInput = input<boolean>(false);\n\n  // --- Output Signal ---\n  timeRangeEmitter = output<ITimeRange>();\n\n  // --- Internal Writable Signals ---\n  startTime = signal<ITime | null>(null);\n  endTime = signal<ITime | null>(null);\n  rangeValidity = signal<boolean>(true);\n  triggerChange = signal<boolean>(true);\n  private _firstIntervals = signal<{ start: number, end: number }>({ start: 0, end: 0 });\n  private _isInitializing = false;\n  private _previousStartDateEpoch: number | null = null;\n  private _previousEndDateEpoch: number | null = null;\n\n  // --- Computed Signals (Derived State) ---\n  firstIntervals = computed(() => this._firstIntervals()); // A public computed signal to access the writable one\n  \n  // Helper methods instead of computed signals to avoid signal write conflicts\n  private getTimeFormat(): string {\n    return this.clockFormat() === 12 ? \"hh:mm a\" : \"HH:mm\";\n  }\n  \n  private getStartDate(): string {\n    return dayjs.tz(this.startDateEpoch(), this.timezone()).format(\"DD-MM-YYYY\");\n  }\n  \n  private getEndDate(): string {\n    return dayjs.tz(this.endDateEpoch(), this.timezone()).format(\"DD-MM-YYYY\");\n  }\n  \n  private getCurrDate(): string {\n    return dayjs.tz(dayjs(), this.timezone()).format(\"DD-MM-YYYY\");\n  }\n  \n  constructor() {\n    // Effect to watch for changes in startDateEpoch and endDateEpoch\n    effect(() => {\n      // ONLY track these two signals - this is the only line that creates dependencies\n      const currentStartDate = this.startDateEpoch();\n      const currentEndDate = this.endDateEpoch();\n      \n      // Use untracked() for everything else to prevent infinite loops\n      untracked(() => {\n        // Skip if component is initializing\n        if (this._isInitializing) {\n          return;\n        }\n        \n        // Skip if component hasn't been initialized yet\n        if (!this.startTime() || !this.endTime()) {\n          return;\n        }\n        \n        // Skip if dates haven't actually changed (prevents initial double-run)\n        if (this._previousStartDateEpoch === currentStartDate && \n            this._previousEndDateEpoch === currentEndDate) {\n          return;\n        }\n        \n        // Update previous values\n        this._previousStartDateEpoch = currentStartDate;\n        this._previousEndDateEpoch = currentEndDate;\n        \n        // Reinitialize and emit when date inputs change\n        this.initializeComponent();\n        \n        // Emit the updated time range\n        const validity =\n          this.checkTimeValidity(this.startTime()!.time.trim(), this.startDateEpoch()) &&\n          this.checkTimeValidity(this.endTime()!.time.trim(), this.endDateEpoch());\n\n        this.rangeValidation(validity);\n        this.emitTimeRange({\n          valid: validity && this.rangeValidity(),\n          startTime: this.startTime()!.time,\n          endTime: this.endTime()!.time,\n          startEpoch: dayjs.tz(`${this.getStartDate()} ${this.startTime()!.time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf(),\n          endEpoch: dayjs.tz(`${this.getEndDate()} ${this.endTime()!.time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf()\n        });\n      });\n    }, { allowSignalWrites: true });\n  }\n\n  ngOnInit(): void {\n    // Initialize the component once\n    this.initializeComponent();\n    \n    // Store initial values to prevent effect from running on first load\n    this._previousStartDateEpoch = this.startDateEpoch();\n    this._previousEndDateEpoch = this.endDateEpoch();\n  }\n\n  private initializeComponent(): void {\n    this._isInitializing = true;\n    \n    this.setFirstIntervals();\n    const firstIntervals = this._firstIntervals();\n\n    this.startTime.set({\n      valid: true,\n      time: dayjs.tz(firstIntervals.start, this.timezone()).format(this.getTimeFormat()),\n      epoch: dayjs.tz(firstIntervals.start, this.timezone()).valueOf()\n    });\n    \n    // Ensure end time is always after start time\n    let endTimeEpoch = firstIntervals.end;\n    const startTimeEpoch = firstIntervals.start;\n    \n    // If end time is same or before start time, add one interval to end time\n    if (endTimeEpoch <= startTimeEpoch) {\n      endTimeEpoch = dayjs.tz(startTimeEpoch, this.timezone()).add(this.interval(), 'm').valueOf();\n      \n      // Update the firstIntervals to reflect the adjusted end time\n      this._firstIntervals.set({\n        start: firstIntervals.start,\n        end: endTimeEpoch\n      });\n    }\n    \n    this.endTime.set({\n      valid: true,\n      time: dayjs.tz(endTimeEpoch, this.timezone()).format(this.getTimeFormat()),\n      epoch: endTimeEpoch\n    });\n    \n    this._isInitializing = false;\n  }\n\n  // calculate the first interval of the picker\n  private setFirstIntervals(): void {\n    let firstIntervalForStartPicker: number;\n    let firstIntervalForEndPicker: number;\n\n    const minutes = dayjs.tz(dayjs(), this.timezone()).minute();\n    const offset = this.interval() - (minutes % this.interval());\n    const currentTime = dayjs.tz(dayjs(), this.timezone()).valueOf();\n\n    if( this.getStartDate() === this.getCurrDate() ){\n      if(this.getStartDate() === this.getEndDate()){\n        if(currentTime >= dayjs.tz(this.startDateEpoch(), this.timezone()).endOf(\"d\").subtract(this.interval(),\"m\").valueOf()){\n          firstIntervalForStartPicker = currentTime;\n          firstIntervalForEndPicker = dayjs.tz(this.endDateEpoch(), this.timezone()).endOf(\"d\").valueOf();\n        } else {\n          firstIntervalForStartPicker = dayjs.tz(dayjs(), this.timezone()).add(offset, \"m\").valueOf();\n          // For same date, end picker should start from beginning of day to avoid validation issues\n          firstIntervalForEndPicker = dayjs.tz(this.endDateEpoch(), this.timezone()).startOf(\"d\").valueOf();\n        }\n      } else {\n        if(currentTime >= dayjs.tz(this.startDateEpoch(), this.timezone()).endOf(\"d\").subtract(this.interval(),\"m\").valueOf()){\n          firstIntervalForStartPicker = currentTime;\n          firstIntervalForEndPicker = dayjs.tz(this.endDateEpoch(), this.timezone()).endOf(\"d\").valueOf();\n        } else {\n          firstIntervalForStartPicker = dayjs.tz(dayjs(), this.timezone()).add(offset, \"m\").valueOf();\n          firstIntervalForEndPicker = dayjs.tz(this.endDateEpoch(), this.timezone()).startOf(\"d\").valueOf();\n        }\n      }\n      } else {\n        if(this.getStartDate() === this.getEndDate()){\n        firstIntervalForStartPicker = dayjs.tz(this.startDateEpoch(), this.timezone()).startOf(\"d\").valueOf();\n        firstIntervalForEndPicker = dayjs.tz(this.endDateEpoch(), this.timezone()).add(this.interval(), \"m\").valueOf();\n      } else {\n        firstIntervalForStartPicker = dayjs.tz(this.startDateEpoch(), this.timezone()).startOf(\"d\").valueOf();\n        firstIntervalForEndPicker = dayjs.tz(this.endDateEpoch(), this.timezone()).startOf(\"d\").valueOf();\n      }\n    }\n\n    if(this.givenStartTime()) {\n      firstIntervalForStartPicker = this.givenStartTime()!;\n    }\n    \n    if(this.givenEndTime()) {\n      firstIntervalForEndPicker = this.givenEndTime()!;\n    }\n      \n    this._firstIntervals.set({ start: firstIntervalForStartPicker, end: firstIntervalForEndPicker });\n  }\n\n  // --- Public Methods ---\n  emitTimeRange(data: ITimeRange): void {\n    this.timeRangeEmitter.emit(data);\n  }\n\n  startPickerHandler(time: ITime): void {\n    this.startTime.set(time);\n    this.rangeValidity.set(true);\n    \n    // Don't emit during initialization\n    if (this._isInitializing) {\n      return;\n    }\n\n    // Calculate start time epoch for comparison\n    const startTimeEpoch = dayjs.tz(`${this.getStartDate()} ${this.startTime()!.time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf();\n    const endTimeEpoch = dayjs.tz(`${this.getEndDate()} ${this.endTime()!.time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf();\n\n    // Auto-adjust end time if start time > end time (for both same and different dates)\n    // This ensures end time is always after start time\n    if (startTimeEpoch > endTimeEpoch) {\n      // Calculate new end time as start time + interval\n      let newEndTimeEpoch = dayjs.tz(startTimeEpoch, this.timezone()).add(this.interval(), \"m\").valueOf();\n      \n      // If same date, check if the new end time would go beyond end of day\n      if (this.getStartDate() === this.getEndDate()) {\n        const endOfDay = dayjs.tz(this.startDateEpoch(), this.timezone()).endOf(\"d\").valueOf();\n        if (newEndTimeEpoch > endOfDay) {\n          // Set end time to 11:59 PM (end of day) when start time is last interval\n          newEndTimeEpoch = endOfDay;\n        }\n      }\n      \n      // Update the end time signal\n      this.endTime.set({\n        valid: true,\n        time: dayjs.tz(newEndTimeEpoch, this.timezone()).format(this.getTimeFormat()),\n        epoch: newEndTimeEpoch\n      });\n      \n      // Update the firstIntervals to reflect the new end time\n      this._firstIntervals.set({ \n        start: this._firstIntervals().start, \n        end: newEndTimeEpoch \n      });\n      \n      // Trigger change to force end timepicker to update its display with the new end time\n      // This is necessary when we reset the end time due to conflict\n      this.triggerChange.update(value => !value);\n    }\n\n    // Update end timepicker's firstInterval when both timepickers are on the same day\n    // ALWAYS update to ensure dropdown starts from next interval after start time\n    // This fixes the bug where selecting an earlier start time doesn't update end picker intervals\n    // NOTE: We only update firstInterval (dropdown options), NOT the selected end time value\n    // The timepicker component now handles firstInterval changes separately and won't reset chosenTime\n    if (this.getStartDate() === this.getEndDate()) {\n      // Only update firstInterval if there's no conflict (start < end)\n      // If there's a conflict, it's already handled above and firstInterval was updated there\n      if (startTimeEpoch < endTimeEpoch) {\n        // Calculate the next interval after the selected start time\n        let nextIntervalAfterStart = dayjs.tz(startTimeEpoch, this.timezone()).add(this.interval(), \"m\").valueOf();\n        \n        // If next interval would go beyond end of day, use end of day instead\n        const endOfDay = dayjs.tz(this.startDateEpoch(), this.timezone()).endOf(\"d\").valueOf();\n        if (nextIntervalAfterStart > endOfDay) {\n          nextIntervalAfterStart = endOfDay;\n        }\n        \n        // Update the firstIntervals to make end timepicker dropdown start from next interval after start time\n        // This ensures users can always select times between the new start time and the current end time\n        // The timepicker component will update the dropdown but preserve the selected end time value\n        this._firstIntervals.set({ \n          start: this._firstIntervals().start, \n          end: nextIntervalAfterStart \n        });\n        // NOTE: We don't call triggerChange here because we only want to update the dropdown,\n        // not reset the selected end time. The timepicker's separate effect for firstInterval\n        // will handle updating the dropdown without resetting chosenTime.\n      }\n    }\n\n    // Always validate and emit the time range\n    const validity =\n      this.checkTimeValidity(this.startTime()!.time.trim(), this.startDateEpoch()) &&\n      this.checkTimeValidity(this.endTime()!.time.trim(), this.endDateEpoch());\n\n    this.rangeValidation(validity);\n    this.emitTimeRange({\n      valid: validity && this.rangeValidity(),\n      startTime: this.startTime()!.time,\n      endTime: this.endTime()!.time,\n      startEpoch: dayjs.tz(`${this.getStartDate()} ${this.startTime()!.time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf(),\n      endEpoch: dayjs.tz(`${this.getEndDate()} ${this.endTime()!.time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf()\n    });\n  }\n\n  endPickerHandler(time: ITime): void {\n    this.endTime.set(time);\n    \n    // Don't emit during initialization\n    if (this._isInitializing) {\n      return;\n    }\n\n    const validity =\n      this.checkTimeValidity(this.startTime()!.time.trim(), this.startDateEpoch()) && \n      this.checkTimeValidity(this.endTime()!.time.trim(), this.endDateEpoch());\n\n    this.rangeValidation(validity);\n    this.emitTimeRange({\n      valid: validity && this.rangeValidity(),\n      startTime: this.startTime()!.time,\n      endTime: this.endTime()!.time,\n      startEpoch: dayjs.tz(`${this.getStartDate()} ${this.startTime()!.time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf(),\n      endEpoch: dayjs.tz(`${this.getEndDate()} ${this.endTime()!.time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf()\n    });\n  }\n\n  checkTimeValidity(time: string, date: number): boolean {\n    const RE12 = /^(([0][1-9]|1[0-2]):([0-5][0-9])( )?(am|pm|AM|PM))$/i;\n    const RE24 = /^([01][0-9]|2[0-3]):[0-5][0-9]$/;\n    const RE = this.clockFormat() === 12 ? RE12 : RE24;\n\n    const timedayjs = dayjs.tz(`${dayjs.tz(date, this.timezone()).format(\"DD-MM-YYYY\")} ${time}`, `'DD-MM-YYYY' ${this.getTimeFormat()}`, this.timezone());\n    let flag: boolean = false;\n\n    if ((this.givenStartTime() && this.givenEndTime()) || (this.getStartDate() !== this.getEndDate() && this.getStartDate() !== this.getCurrDate())) {\n      flag = time.match(RE) ? true : false;\n    } else {\n      flag = time.match(RE) && timedayjs.diff(dayjs.tz(dayjs(), this.timezone()), \"m\") >= 0 ? true : false;\n    }\n    return flag;\n  }\n\n  rangeValidation(validity: boolean) {\n    if (validity && this.getStartDate() === this.getEndDate()) {\n      const startdayjs = dayjs.tz(this.startTime()!.time, this.getTimeFormat(), this.timezone());\n      const enddayjs = dayjs.tz(this.endTime()!.time, this.getTimeFormat(), this.timezone());\n      this.rangeValidity.set(enddayjs.diff(startdayjs, \"m\") >= 1);\n    }\n  }\n}\n\n\n","<div class=\"rangepicker-container\" [ngStyle]=\"{'flexDirection': direction(), 'gap': gap()}\">\n  <mis-timepicker\n    [clockFormat]=\"clockFormat()\"\n    [interval]=\"interval()\"\n    [dateAsEpoch]=\"startDateEpoch()\"\n    [firstInterval]=\"firstIntervals().start\"\n    (timeEmitter)=\"startPickerHandler($event)\"\n    [timezone]=\"timezone()\"\n    [height]=\"height()\"\n    [inputWidth]=\"inputWidth()\"\n    [dropdownWidth]=\"dropdownWidth()\"\n    [showTooltip]=\"showTooltip()\"\n    [givenTime]=\"givenStartTime()\"\n    [disable]=\"disableStartTime()\"\n    [disableUserInput]=\"disableUserInput()\"\n    [fontSize]=\"fontSize()\"\n  ></mis-timepicker>\n  <p *ngIf=\"direction() === 'row'\">-</p>\n  <mis-timepicker\n    [clockFormat]=\"clockFormat()\"\n    [interval]=\"interval()\"\n    [dateAsEpoch]=\"endDateEpoch()\"\n    [firstInterval]=\"firstIntervals().end\"\n    (timeEmitter)=\"endPickerHandler($event)\"\n    [rangeValidity]=\"rangeValidity()\"\n    [timezone]=\"timezone()\"\n    [height]=\"height()\"\n    [inputWidth]=\"inputWidth()\"\n    [dropdownWidth]=\"dropdownWidth()\"\n    [showTooltip]=\"showTooltip()\"\n    [givenTime]=\"givenEndTime()\"\n    [triggerChange]=\"triggerChange()\"\n    [disable]=\"disableEndTime()\"\n    [disableUserInput]=\"disableUserInput()\"\n    [fontSize]=\"fontSize()\"\n  ></mis-timepicker>\n</div>\n\n"]}
|
|
345
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timerangepicker.component.js","sourceRoot":"","sources":["../../../../projects/mis-components/timerangepicker/timerangepicker.component.ts","../../../../projects/mis-components/timerangepicker/timerangepicker.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAU,MAAM,eAAe,CAAC;AAEtG,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,QAAQ,MAAM,uBAAuB,CAAC;AAC7C,OAAO,GAAG,MAAM,kBAAkB,CAAC;;;;;;ICajC,yBAAiC;IAAA,iBAAC;IAAA,iBAAI;;ADXxC,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;AAClB,KAAK,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;AAOvB,MAAM,OAAO,wBAAwB;IAoCnC,6EAA6E;IACrE,aAAa;QACnB,OAAO,IAAI,CAAC,WAAW,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC;IACzD,CAAC;IAEO,YAAY;QAClB,OAAO,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,cAAc,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;IAC/E,CAAC;IAEO,UAAU;QAChB,OAAO,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,YAAY,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;IAC7E,CAAC;IAEO,WAAW;QACjB,OAAO,KAAK,CAAC,EAAE,CAAC,KAAK,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;IACjE,CAAC;IAED;QApDA,oCAAoC;QACpC,eAAU,GAAG,KAAK,CAAS,OAAO,CAAC,CAAC;QACpC,kBAAa,GAAG,KAAK,CAAqB,SAAS,CAAC,CAAC;QACrD,WAAM,GAAG,KAAK,CAAS,MAAM,CAAC,CAAC;QAC/B,aAAQ,GAAG,KAAK,CAAS,cAAc,CAAC,CAAC;QACzC,mBAAc,GAAG,KAAK,CAAS,KAAK,CAAC,EAAE,CAAC,KAAK,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC;QAC7E,iBAAY,GAAG,KAAK,CAAS,KAAK,CAAC,EAAE,CAAC,KAAK,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC;QAC3E,mBAAc,GAAG,KAAK,CAAqB,SAAS,CAAC,CAAC;QACtD,iBAAY,GAAG,KAAK,CAAqB,SAAS,CAAC,CAAC;QACpD,gBAAW,GAAG,KAAK,CAAS,EAAE,CAAC,CAAC;QAChC,aAAQ,GAAG,KAAK,CAAS,EAAE,CAAC,CAAC;QAC7B,gBAAW,GAAG,KAAK,CAAU,IAAI,CAAC,CAAC;QACnC,cAAS,GAAG,KAAK,CAAa,KAAK,CAAC,CAAC;QACrC,QAAG,GAAG,KAAK,CAAS,MAAM,CAAC,CAAC;QAC5B,qBAAgB,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;QACzC,mBAAc,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;QACvC,aAAQ,GAAG,KAAK,CAAS,MAAM,CAAC,CAAC;QACjC,qBAAgB,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;QAEzC,wBAAwB;QACxB,qBAAgB,GAAG,MAAM,EAAc,CAAC;QAExC,oCAAoC;QACpC,cAAS,GAAG,MAAM,CAAe,IAAI,CAAC,CAAC;QACvC,YAAO,GAAG,MAAM,CAAe,IAAI,CAAC,CAAC;QACrC,kBAAa,GAAG,MAAM,CAAU,IAAI,CAAC,CAAC;QACtC,kBAAa,GAAG,MAAM,CAAU,IAAI,CAAC,CAAC;QAC9B,oBAAe,GAAG,MAAM,CAAiC,EAAE,KAAK,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC;QAC/E,oBAAe,GAAG,KAAK,CAAC;QACxB,4BAAuB,GAAkB,IAAI,CAAC;QAC9C,0BAAqB,GAAkB,IAAI,CAAC;QAEpD,2CAA2C;QAC3C,mBAAc,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC,CAAC,sDAAsD;QAoB7G,iEAAiE;QACjE,MAAM,CAAC,GAAG,EAAE;YACV,iFAAiF;YACjF,MAAM,gBAAgB,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;YAC/C,MAAM,cAAc,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;YAE3C,gEAAgE;YAChE,SAAS,CAAC,GAAG,EAAE;gBACb,oCAAoC;gBACpC,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;oBACzB,OAAO;gBACT,CAAC;gBAED,gDAAgD;gBAChD,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC;oBACzC,OAAO;gBACT,CAAC;gBAED,uEAAuE;gBACvE,IAAI,IAAI,CAAC,uBAAuB,KAAK,gBAAgB;oBACjD,IAAI,CAAC,qBAAqB,KAAK,cAAc,EAAE,CAAC;oBAClD,OAAO;gBACT,CAAC;gBAED,yBAAyB;gBACzB,IAAI,CAAC,uBAAuB,GAAG,gBAAgB,CAAC;gBAChD,IAAI,CAAC,qBAAqB,GAAG,cAAc,CAAC;gBAE5C,4DAA4D;gBAC5D,MAAM,sBAAsB,GAAG,IAAI,CAAC,SAAS,EAAG,CAAC,IAAI,CAAC;gBACtD,MAAM,oBAAoB,GAAG,IAAI,CAAC,OAAO,EAAG,CAAC,IAAI,CAAC;gBAElD,uDAAuD;gBACvD,MAAM,aAAa,GAAG,KAAK,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,YAAY,EAAE,IAAI,sBAAsB,EAAE,EAAE,cAAc,IAAI,CAAC,aAAa,EAAE,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC;gBACpJ,MAAM,WAAW,GAAG,KAAK,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,UAAU,EAAE,IAAI,oBAAoB,EAAE,EAAE,cAAc,IAAI,CAAC,aAAa,EAAE,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC;gBAE9I,8DAA8D;gBAC9D,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC;oBACjB,KAAK,EAAE,IAAI;oBACX,IAAI,EAAE,sBAAsB;oBAC5B,KAAK,EAAE,aAAa;iBACrB,CAAC,CAAC;gBAEH,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC;oBACf,KAAK,EAAE,IAAI;oBACX,IAAI,EAAE,oBAAoB;oBAC1B,KAAK,EAAE,WAAW;iBACnB,CAAC,CAAC;gBAEH,mEAAmE;gBACnE,IAAI,CAAC,iBAAiB,EAAE,CAAC;gBAEzB,gEAAgE;gBAChE,MAAM,QAAQ,GACZ,IAAI,CAAC,iBAAiB,CAAC,sBAAsB,CAAC,IAAI,EAAE,EAAE,IAAI,CAAC,cAAc,EAAE,CAAC;oBAC5E,IAAI,CAAC,iBAAiB,CAAC,oBAAoB,CAAC,IAAI,EAAE,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;gBAE3E,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC;gBAC/B,IAAI,CAAC,aAAa,CAAC;oBACjB,KAAK,EAAE,QAAQ,IAAI,IAAI,CAAC,aAAa,EAAE;oBACvC,SAAS,EAAE,sBAAsB;oBACjC,OAAO,EAAE,oBAAoB;oBAC7B,UAAU,EAAE,aAAa;oBACzB,QAAQ,EAAE,WAAW;iBACtB,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;QACL,CAAC,EAAE,EAAE,iBAAiB,EAAE,IAAI,EAAE,CAAC,CAAC;IAClC,CAAC;IAED,QAAQ;QACN,gCAAgC;QAChC,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAE3B,oEAAoE;QACpE,IAAI,CAAC,uBAAuB,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;QACrD,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;IACnD,CAAC;IAEO,mBAAmB;QACzB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;QAE5B,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,MAAM,cAAc,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QAE9C,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC;YACjB,KAAK,EAAE,IAAI;YACX,IAAI,EAAE,KAAK,CAAC,EAAE,CAAC,cAAc,CAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;YAClF,KAAK,EAAE,KAAK,CAAC,EAAE,CAAC,cAAc,CAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,OAAO,EAAE;SACjE,CAAC,CAAC;QAEH,6CAA6C;QAC7C,IAAI,YAAY,GAAG,cAAc,CAAC,GAAG,CAAC;QACtC,MAAM,cAAc,GAAG,cAAc,CAAC,KAAK,CAAC;QAE5C,yEAAyE;QACzE,IAAI,YAAY,IAAI,cAAc,EAAE,CAAC;YACnC,YAAY,GAAG,KAAK,CAAC,EAAE,CAAC,cAAc,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,EAAE,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC;YAE7F,6DAA6D;YAC7D,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC;gBACvB,KAAK,EAAE,cAAc,CAAC,KAAK;gBAC3B,GAAG,EAAE,YAAY;aAClB,CAAC,CAAC;QACL,CAAC;QAED,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC;YACf,KAAK,EAAE,IAAI;YACX,IAAI,EAAE,KAAK,CAAC,EAAE,CAAC,YAAY,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;YAC1E,KAAK,EAAE,YAAY;SACpB,CAAC,CAAC;QAEH,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;IAC/B,CAAC;IAED,6CAA6C;IACrC,iBAAiB;QACvB,IAAI,2BAAmC,CAAC;QACxC,IAAI,yBAAiC,CAAC;QAEtC,MAAM,OAAO,GAAG,KAAK,CAAC,EAAE,CAAC,KAAK,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC;QAC5D,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,EAAE,GAAG,CAAC,OAAO,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC7D,MAAM,WAAW,GAAG,KAAK,CAAC,EAAE,CAAC,KAAK,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC;QAEjE,IAAI,IAAI,CAAC,YAAY,EAAE,KAAK,IAAI,CAAC,WAAW,EAAE,EAAE,CAAC;YAC/C,IAAG,IAAI,CAAC,YAAY,EAAE,KAAK,IAAI,CAAC,UAAU,EAAE,EAAC,CAAC;gBAC5C,IAAG,WAAW,IAAI,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,cAAc,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,EAAE,EAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAC,CAAC;oBACrH,2BAA2B,GAAG,WAAW,CAAC;oBAC1C,yBAAyB,GAAG,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,YAAY,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC;gBAClG,CAAC;qBAAM,CAAC;oBACN,2BAA2B,GAAG,KAAK,CAAC,EAAE,CAAC,KAAK,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,GAAG,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC;oBAC5F,0FAA0F;oBAC1F,yBAAyB,GAAG,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,YAAY,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC;gBACpG,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,IAAG,WAAW,IAAI,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,cAAc,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,EAAE,EAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAC,CAAC;oBACrH,2BAA2B,GAAG,WAAW,CAAC;oBAC1C,yBAAyB,GAAG,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,YAAY,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC;gBAClG,CAAC;qBAAM,CAAC;oBACN,2BAA2B,GAAG,KAAK,CAAC,EAAE,CAAC,KAAK,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,GAAG,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC;oBAC5F,yBAAyB,GAAG,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,YAAY,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC;gBACpG,CAAC;YACH,CAAC;QACD,CAAC;aAAM,CAAC;YACN,IAAG,IAAI,CAAC,YAAY,EAAE,KAAK,IAAI,CAAC,UAAU,EAAE,EAAC,CAAC;gBAC9C,2BAA2B,GAAG,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,cAAc,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC;gBACtG,yBAAyB,GAAG,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,YAAY,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,EAAE,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC;YACjH,CAAC;iBAAM,CAAC;gBACN,2BAA2B,GAAG,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,cAAc,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC;gBACtG,yBAAyB,GAAG,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,YAAY,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC;YACpG,CAAC;QACH,CAAC;QAED,IAAG,IAAI,CAAC,cAAc,EAAE,EAAE,CAAC;YACzB,2BAA2B,GAAG,IAAI,CAAC,cAAc,EAAG,CAAC;QACvD,CAAC;QAED,IAAG,IAAI,CAAC,YAAY,EAAE,EAAE,CAAC;YACvB,yBAAyB,GAAG,IAAI,CAAC,YAAY,EAAG,CAAC;QACnD,CAAC;QAED,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,2BAA2B,EAAE,GAAG,EAAE,yBAAyB,EAAE,CAAC,CAAC;IACnG,CAAC;IAED,yBAAyB;IACzB,aAAa,CAAC,IAAgB;QAC5B,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACnC,CAAC;IAED,kBAAkB,CAAC,IAAW;QAC5B,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACzB,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAE7B,mCAAmC;QACnC,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;YACzB,OAAO;QACT,CAAC;QAED,4CAA4C;QAC5C,MAAM,cAAc,GAAG,KAAK,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,YAAY,EAAE,IAAI,IAAI,CAAC,SAAS,EAAG,CAAC,IAAI,EAAE,EAAE,cAAc,IAAI,CAAC,aAAa,EAAE,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC;QACrJ,MAAM,YAAY,GAAG,KAAK,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,UAAU,EAAE,IAAI,IAAI,CAAC,OAAO,EAAG,CAAC,IAAI,EAAE,EAAE,cAAc,IAAI,CAAC,aAAa,EAAE,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC;QAE/I,oFAAoF;QACpF,mDAAmD;QACnD,IAAI,cAAc,GAAG,YAAY,EAAE,CAAC;YAClC,kDAAkD;YAClD,IAAI,eAAe,GAAG,KAAK,CAAC,EAAE,CAAC,cAAc,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,EAAE,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC;YAEpG,qEAAqE;YACrE,IAAI,IAAI,CAAC,YAAY,EAAE,KAAK,IAAI,CAAC,UAAU,EAAE,EAAE,CAAC;gBAC9C,MAAM,QAAQ,GAAG,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,cAAc,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC;gBACvF,IAAI,eAAe,GAAG,QAAQ,EAAE,CAAC;oBAC/B,yEAAyE;oBACzE,eAAe,GAAG,QAAQ,CAAC;gBAC7B,CAAC;YACH,CAAC;YAED,6BAA6B;YAC7B,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC;gBACf,KAAK,EAAE,IAAI;gBACX,IAAI,EAAE,KAAK,CAAC,EAAE,CAAC,eAAe,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;gBAC7E,KAAK,EAAE,eAAe;aACvB,CAAC,CAAC;YAEH,wDAAwD;YACxD,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC;gBACvB,KAAK,EAAE,IAAI,CAAC,eAAe,EAAE,CAAC,KAAK;gBACnC,GAAG,EAAE,eAAe;aACrB,CAAC,CAAC;YAEH,qFAAqF;YACrF,+DAA+D;YAC/D,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC;QAC7C,CAAC;QAED,kFAAkF;QAClF,8EAA8E;QAC9E,+FAA+F;QAC/F,yFAAyF;QACzF,mGAAmG;QACnG,IAAI,IAAI,CAAC,YAAY,EAAE,KAAK,IAAI,CAAC,UAAU,EAAE,EAAE,CAAC;YAC9C,iEAAiE;YACjE,wFAAwF;YACxF,IAAI,cAAc,GAAG,YAAY,EAAE,CAAC;gBAClC,4DAA4D;gBAC5D,IAAI,sBAAsB,GAAG,KAAK,CAAC,EAAE,CAAC,cAAc,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,EAAE,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC;gBAE3G,sEAAsE;gBACtE,MAAM,QAAQ,GAAG,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,cAAc,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC;gBACvF,IAAI,sBAAsB,GAAG,QAAQ,EAAE,CAAC;oBACtC,sBAAsB,GAAG,QAAQ,CAAC;gBACpC,CAAC;gBAED,sGAAsG;gBACtG,iGAAiG;gBACjG,6FAA6F;gBAC7F,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC;oBACvB,KAAK,EAAE,IAAI,CAAC,eAAe,EAAE,CAAC,KAAK;oBACnC,GAAG,EAAE,sBAAsB;iBAC5B,CAAC,CAAC;gBACH,sFAAsF;gBACtF,sFAAsF;gBACtF,kEAAkE;YACpE,CAAC;QACH,CAAC;QAED,0CAA0C;QAC1C,MAAM,QAAQ,GACZ,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,SAAS,EAAG,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE,IAAI,CAAC,cAAc,EAAE,CAAC;YAC5E,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,OAAO,EAAG,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;QAE3E,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC;QAC/B,IAAI,CAAC,aAAa,CAAC;YACjB,KAAK,EAAE,QAAQ,IAAI,IAAI,CAAC,aAAa,EAAE;YACvC,SAAS,EAAE,IAAI,CAAC,SAAS,EAAG,CAAC,IAAI;YACjC,OAAO,EAAE,IAAI,CAAC,OAAO,EAAG,CAAC,IAAI;YAC7B,UAAU,EAAE,KAAK,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,YAAY,EAAE,IAAI,IAAI,CAAC,SAAS,EAAG,CAAC,IAAI,EAAE,EAAE,cAAc,IAAI,CAAC,aAAa,EAAE,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,OAAO,EAAE;YACzI,QAAQ,EAAE,KAAK,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,UAAU,EAAE,IAAI,IAAI,CAAC,OAAO,EAAG,CAAC,IAAI,EAAE,EAAE,cAAc,IAAI,CAAC,aAAa,EAAE,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,OAAO,EAAE;SACpI,CAAC,CAAC;IACL,CAAC;IAED,gBAAgB,CAAC,IAAW;QAC1B,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAEvB,mCAAmC;QACnC,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;YACzB,OAAO;QACT,CAAC;QAED,MAAM,QAAQ,GACZ,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,SAAS,EAAG,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE,IAAI,CAAC,cAAc,EAAE,CAAC;YAC5E,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,OAAO,EAAG,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;QAE3E,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC;QAC/B,IAAI,CAAC,aAAa,CAAC;YACjB,KAAK,EAAE,QAAQ,IAAI,IAAI,CAAC,aAAa,EAAE;YACvC,SAAS,EAAE,IAAI,CAAC,SAAS,EAAG,CAAC,IAAI;YACjC,OAAO,EAAE,IAAI,CAAC,OAAO,EAAG,CAAC,IAAI;YAC7B,UAAU,EAAE,KAAK,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,YAAY,EAAE,IAAI,IAAI,CAAC,SAAS,EAAG,CAAC,IAAI,EAAE,EAAE,cAAc,IAAI,CAAC,aAAa,EAAE,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,OAAO,EAAE;YACzI,QAAQ,EAAE,KAAK,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,UAAU,EAAE,IAAI,IAAI,CAAC,OAAO,EAAG,CAAC,IAAI,EAAE,EAAE,cAAc,IAAI,CAAC,aAAa,EAAE,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,OAAO,EAAE;SACpI,CAAC,CAAC;IACL,CAAC;IAED,iBAAiB,CAAC,IAAY,EAAE,IAAY;QAC1C,MAAM,IAAI,GAAG,sDAAsD,CAAC;QACpE,MAAM,IAAI,GAAG,iCAAiC,CAAC;QAC/C,MAAM,EAAE,GAAG,IAAI,CAAC,WAAW,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;QAEnD,MAAM,SAAS,GAAG,KAAK,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,IAAI,IAAI,EAAE,EAAE,gBAAgB,IAAI,CAAC,aAAa,EAAE,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QACvJ,IAAI,IAAI,GAAY,KAAK,CAAC;QAE1B,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,KAAK,IAAI,CAAC,UAAU,EAAE,IAAI,IAAI,CAAC,YAAY,EAAE,KAAK,IAAI,CAAC,WAAW,EAAE,CAAC,EAAE,CAAC;YAChJ,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC;QACvC,CAAC;aAAM,CAAC;YACN,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC;QACvG,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,eAAe,CAAC,QAAiB;QAC/B,IAAI,QAAQ,IAAI,IAAI,CAAC,YAAY,EAAE,KAAK,IAAI,CAAC,UAAU,EAAE,EAAE,CAAC;YAC1D,MAAM,UAAU,GAAG,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,EAAG,CAAC,IAAI,EAAE,IAAI,CAAC,aAAa,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;YAC3F,MAAM,QAAQ,GAAG,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,EAAG,CAAC,IAAI,EAAE,IAAI,CAAC,aAAa,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;YACvF,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC;QAC9D,CAAC;IACH,CAAC;yHAtWU,wBAAwB;oEAAxB,wBAAwB;YCbnC,AADF,8BAA4F,wBAgBzF;YAVC,+HAAe,8BAA0B,IAAC;YAU3C,iBAAiB;YAClB,qEAAiC;YACjC,yCAiBC;YAZC,+HAAe,4BAAwB,IAAC;YAa5C,AADG,iBAAiB,EACd;;YApC6B,iFAAwD;YAEvF,cAA6B;YAa7B,AADA,AADA,AADA,AADA,AADA,AADA,AADA,AADA,AAFA,AADA,AADA,AADA,+CAA6B,4BACN,qCACS,6CACQ,4BAEjB,wBACJ,gCACQ,sCACM,kCACJ,mCACC,mCACA,4CACS,4BAChB;YAErB,cAA2B;YAA3B,gDAA2B;YAE7B,cAA6B;YAe7B,AADA,AADA,AADA,AADA,AADA,AADA,AADA,AADA,AADA,AADA,AAFA,AADA,AADA,AADA,+CAA6B,4BACN,mCACO,2CACQ,sCAEL,4BACV,wBACJ,gCACQ,sCACM,kCACJ,iCACD,sCACK,iCACL,4CACW,4BAChB;;;iFDpBd,wBAAwB;cALpC,SAAS;2BACE,qBAAqB;;kFAIpB,wBAAwB","sourcesContent":["import { Component, input, output, signal, computed, effect, untracked, OnInit } from \"@angular/core\";\nimport { ITimeRange, ITime, TDirection } from \"./timerange.namespace\";\nimport dayjs from 'dayjs';\nimport timezone from 'dayjs/plugin/timezone';\nimport utc from 'dayjs/plugin/utc';\n\ndayjs.extend(utc);\ndayjs.extend(timezone);\n\n@Component({\n  selector: \"mis-timerangepicker\",\n  templateUrl: \"./timerangepicker.component.html\", // Corrected file name\n  styleUrls: [\"./timerangepicker.component.scss\"]\n})\nexport class TimeRangePickerComponent implements OnInit {\n  // --- Input Signals (read-only) ---\n  inputWidth = input<string>(\"100px\");\n  dropdownWidth = input<string | undefined>(undefined);\n  height = input<string>(\"46px\");\n  timezone = input<string>(\"Asia/Kolkata\");\n  startDateEpoch = input<number>(dayjs.tz(dayjs(), this.timezone()).valueOf());\n  endDateEpoch = input<number>(dayjs.tz(dayjs(), this.timezone()).valueOf());\n  givenStartTime = input<number | undefined>(undefined);\n  givenEndTime = input<number | undefined>(undefined);\n  clockFormat = input<number>(12);\n  interval = input<number>(15);\n  showTooltip = input<boolean>(true);\n  direction = input<TDirection>('row');\n  gap = input<string>('1rem');\n  disableStartTime = input<boolean>(false);\n  disableEndTime = input<boolean>(false);\n  fontSize = input<string>(\"14px\");\n  disableUserInput = input<boolean>(false);\n\n  // --- Output Signal ---\n  timeRangeEmitter = output<ITimeRange>();\n\n  // --- Internal Writable Signals ---\n  startTime = signal<ITime | null>(null);\n  endTime = signal<ITime | null>(null);\n  rangeValidity = signal<boolean>(true);\n  triggerChange = signal<boolean>(true);\n  private _firstIntervals = signal<{ start: number, end: number }>({ start: 0, end: 0 });\n  private _isInitializing = false;\n  private _previousStartDateEpoch: number | null = null;\n  private _previousEndDateEpoch: number | null = null;\n\n  // --- Computed Signals (Derived State) ---\n  firstIntervals = computed(() => this._firstIntervals()); // A public computed signal to access the writable one\n  \n  // Helper methods instead of computed signals to avoid signal write conflicts\n  private getTimeFormat(): string {\n    return this.clockFormat() === 12 ? \"hh:mm a\" : \"HH:mm\";\n  }\n  \n  private getStartDate(): string {\n    return dayjs.tz(this.startDateEpoch(), this.timezone()).format(\"DD-MM-YYYY\");\n  }\n  \n  private getEndDate(): string {\n    return dayjs.tz(this.endDateEpoch(), this.timezone()).format(\"DD-MM-YYYY\");\n  }\n  \n  private getCurrDate(): string {\n    return dayjs.tz(dayjs(), this.timezone()).format(\"DD-MM-YYYY\");\n  }\n  \n  constructor() {\n    // Effect to watch for changes in startDateEpoch and endDateEpoch\n    effect(() => {\n      // ONLY track these two signals - this is the only line that creates dependencies\n      const currentStartDate = this.startDateEpoch();\n      const currentEndDate = this.endDateEpoch();\n      \n      // Use untracked() for everything else to prevent infinite loops\n      untracked(() => {\n        // Skip if component is initializing\n        if (this._isInitializing) {\n          return;\n        }\n        \n        // Skip if component hasn't been initialized yet\n        if (!this.startTime() || !this.endTime()) {\n          return;\n        }\n        \n        // Skip if dates haven't actually changed (prevents initial double-run)\n        if (this._previousStartDateEpoch === currentStartDate && \n            this._previousEndDateEpoch === currentEndDate) {\n          return;\n        }\n        \n        // Update previous values\n        this._previousStartDateEpoch = currentStartDate;\n        this._previousEndDateEpoch = currentEndDate;\n        \n        // PRESERVE the currently selected times (don't reset them!)\n        const currentStartTimeString = this.startTime()!.time;\n        const currentEndTimeString = this.endTime()!.time;\n        \n        // Calculate new epochs with the new date but SAME time\n        const newStartEpoch = dayjs.tz(`${this.getStartDate()} ${currentStartTimeString}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf();\n        const newEndEpoch = dayjs.tz(`${this.getEndDate()} ${currentEndTimeString}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf();\n        \n        // Update the time signals with preserved times but new epochs\n        this.startTime.set({\n          valid: true,\n          time: currentStartTimeString,\n          epoch: newStartEpoch\n        });\n        \n        this.endTime.set({\n          valid: true,\n          time: currentEndTimeString,\n          epoch: newEndEpoch\n        });\n        \n        // Update firstIntervals for the dropdown options based on new date\n        this.setFirstIntervals();\n        \n        // Emit the updated time range with preserved times but new date\n        const validity =\n          this.checkTimeValidity(currentStartTimeString.trim(), this.startDateEpoch()) &&\n          this.checkTimeValidity(currentEndTimeString.trim(), this.endDateEpoch());\n\n        this.rangeValidation(validity);\n        this.emitTimeRange({\n          valid: validity && this.rangeValidity(),\n          startTime: currentStartTimeString,\n          endTime: currentEndTimeString,\n          startEpoch: newStartEpoch,\n          endEpoch: newEndEpoch\n        });\n      });\n    }, { allowSignalWrites: true });\n  }\n\n  ngOnInit(): void {\n    // Initialize the component once\n    this.initializeComponent();\n    \n    // Store initial values to prevent effect from running on first load\n    this._previousStartDateEpoch = this.startDateEpoch();\n    this._previousEndDateEpoch = this.endDateEpoch();\n  }\n\n  private initializeComponent(): void {\n    this._isInitializing = true;\n    \n    this.setFirstIntervals();\n    const firstIntervals = this._firstIntervals();\n\n    this.startTime.set({\n      valid: true,\n      time: dayjs.tz(firstIntervals.start, this.timezone()).format(this.getTimeFormat()),\n      epoch: dayjs.tz(firstIntervals.start, this.timezone()).valueOf()\n    });\n    \n    // Ensure end time is always after start time\n    let endTimeEpoch = firstIntervals.end;\n    const startTimeEpoch = firstIntervals.start;\n    \n    // If end time is same or before start time, add one interval to end time\n    if (endTimeEpoch <= startTimeEpoch) {\n      endTimeEpoch = dayjs.tz(startTimeEpoch, this.timezone()).add(this.interval(), 'm').valueOf();\n      \n      // Update the firstIntervals to reflect the adjusted end time\n      this._firstIntervals.set({\n        start: firstIntervals.start,\n        end: endTimeEpoch\n      });\n    }\n    \n    this.endTime.set({\n      valid: true,\n      time: dayjs.tz(endTimeEpoch, this.timezone()).format(this.getTimeFormat()),\n      epoch: endTimeEpoch\n    });\n    \n    this._isInitializing = false;\n  }\n\n  // calculate the first interval of the picker\n  private setFirstIntervals(): void {\n    let firstIntervalForStartPicker: number;\n    let firstIntervalForEndPicker: number;\n\n    const minutes = dayjs.tz(dayjs(), this.timezone()).minute();\n    const offset = this.interval() - (minutes % this.interval());\n    const currentTime = dayjs.tz(dayjs(), this.timezone()).valueOf();\n\n    if( this.getStartDate() === this.getCurrDate() ){\n      if(this.getStartDate() === this.getEndDate()){\n        if(currentTime >= dayjs.tz(this.startDateEpoch(), this.timezone()).endOf(\"d\").subtract(this.interval(),\"m\").valueOf()){\n          firstIntervalForStartPicker = currentTime;\n          firstIntervalForEndPicker = dayjs.tz(this.endDateEpoch(), this.timezone()).endOf(\"d\").valueOf();\n        } else {\n          firstIntervalForStartPicker = dayjs.tz(dayjs(), this.timezone()).add(offset, \"m\").valueOf();\n          // For same date, end picker should start from beginning of day to avoid validation issues\n          firstIntervalForEndPicker = dayjs.tz(this.endDateEpoch(), this.timezone()).startOf(\"d\").valueOf();\n        }\n      } else {\n        if(currentTime >= dayjs.tz(this.startDateEpoch(), this.timezone()).endOf(\"d\").subtract(this.interval(),\"m\").valueOf()){\n          firstIntervalForStartPicker = currentTime;\n          firstIntervalForEndPicker = dayjs.tz(this.endDateEpoch(), this.timezone()).endOf(\"d\").valueOf();\n        } else {\n          firstIntervalForStartPicker = dayjs.tz(dayjs(), this.timezone()).add(offset, \"m\").valueOf();\n          firstIntervalForEndPicker = dayjs.tz(this.endDateEpoch(), this.timezone()).startOf(\"d\").valueOf();\n        }\n      }\n      } else {\n        if(this.getStartDate() === this.getEndDate()){\n        firstIntervalForStartPicker = dayjs.tz(this.startDateEpoch(), this.timezone()).startOf(\"d\").valueOf();\n        firstIntervalForEndPicker = dayjs.tz(this.endDateEpoch(), this.timezone()).add(this.interval(), \"m\").valueOf();\n      } else {\n        firstIntervalForStartPicker = dayjs.tz(this.startDateEpoch(), this.timezone()).startOf(\"d\").valueOf();\n        firstIntervalForEndPicker = dayjs.tz(this.endDateEpoch(), this.timezone()).startOf(\"d\").valueOf();\n      }\n    }\n\n    if(this.givenStartTime()) {\n      firstIntervalForStartPicker = this.givenStartTime()!;\n    }\n    \n    if(this.givenEndTime()) {\n      firstIntervalForEndPicker = this.givenEndTime()!;\n    }\n      \n    this._firstIntervals.set({ start: firstIntervalForStartPicker, end: firstIntervalForEndPicker });\n  }\n\n  // --- Public Methods ---\n  emitTimeRange(data: ITimeRange): void {\n    this.timeRangeEmitter.emit(data);\n  }\n\n  startPickerHandler(time: ITime): void {\n    this.startTime.set(time);\n    this.rangeValidity.set(true);\n    \n    // Don't emit during initialization\n    if (this._isInitializing) {\n      return;\n    }\n\n    // Calculate start time epoch for comparison\n    const startTimeEpoch = dayjs.tz(`${this.getStartDate()} ${this.startTime()!.time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf();\n    const endTimeEpoch = dayjs.tz(`${this.getEndDate()} ${this.endTime()!.time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf();\n\n    // Auto-adjust end time if start time > end time (for both same and different dates)\n    // This ensures end time is always after start time\n    if (startTimeEpoch > endTimeEpoch) {\n      // Calculate new end time as start time + interval\n      let newEndTimeEpoch = dayjs.tz(startTimeEpoch, this.timezone()).add(this.interval(), \"m\").valueOf();\n      \n      // If same date, check if the new end time would go beyond end of day\n      if (this.getStartDate() === this.getEndDate()) {\n        const endOfDay = dayjs.tz(this.startDateEpoch(), this.timezone()).endOf(\"d\").valueOf();\n        if (newEndTimeEpoch > endOfDay) {\n          // Set end time to 11:59 PM (end of day) when start time is last interval\n          newEndTimeEpoch = endOfDay;\n        }\n      }\n      \n      // Update the end time signal\n      this.endTime.set({\n        valid: true,\n        time: dayjs.tz(newEndTimeEpoch, this.timezone()).format(this.getTimeFormat()),\n        epoch: newEndTimeEpoch\n      });\n      \n      // Update the firstIntervals to reflect the new end time\n      this._firstIntervals.set({ \n        start: this._firstIntervals().start, \n        end: newEndTimeEpoch \n      });\n      \n      // Trigger change to force end timepicker to update its display with the new end time\n      // This is necessary when we reset the end time due to conflict\n      this.triggerChange.update(value => !value);\n    }\n\n    // Update end timepicker's firstInterval when both timepickers are on the same day\n    // ALWAYS update to ensure dropdown starts from next interval after start time\n    // This fixes the bug where selecting an earlier start time doesn't update end picker intervals\n    // NOTE: We only update firstInterval (dropdown options), NOT the selected end time value\n    // The timepicker component now handles firstInterval changes separately and won't reset chosenTime\n    if (this.getStartDate() === this.getEndDate()) {\n      // Only update firstInterval if there's no conflict (start < end)\n      // If there's a conflict, it's already handled above and firstInterval was updated there\n      if (startTimeEpoch < endTimeEpoch) {\n        // Calculate the next interval after the selected start time\n        let nextIntervalAfterStart = dayjs.tz(startTimeEpoch, this.timezone()).add(this.interval(), \"m\").valueOf();\n        \n        // If next interval would go beyond end of day, use end of day instead\n        const endOfDay = dayjs.tz(this.startDateEpoch(), this.timezone()).endOf(\"d\").valueOf();\n        if (nextIntervalAfterStart > endOfDay) {\n          nextIntervalAfterStart = endOfDay;\n        }\n        \n        // Update the firstIntervals to make end timepicker dropdown start from next interval after start time\n        // This ensures users can always select times between the new start time and the current end time\n        // The timepicker component will update the dropdown but preserve the selected end time value\n        this._firstIntervals.set({ \n          start: this._firstIntervals().start, \n          end: nextIntervalAfterStart \n        });\n        // NOTE: We don't call triggerChange here because we only want to update the dropdown,\n        // not reset the selected end time. The timepicker's separate effect for firstInterval\n        // will handle updating the dropdown without resetting chosenTime.\n      }\n    }\n\n    // Always validate and emit the time range\n    const validity =\n      this.checkTimeValidity(this.startTime()!.time.trim(), this.startDateEpoch()) &&\n      this.checkTimeValidity(this.endTime()!.time.trim(), this.endDateEpoch());\n\n    this.rangeValidation(validity);\n    this.emitTimeRange({\n      valid: validity && this.rangeValidity(),\n      startTime: this.startTime()!.time,\n      endTime: this.endTime()!.time,\n      startEpoch: dayjs.tz(`${this.getStartDate()} ${this.startTime()!.time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf(),\n      endEpoch: dayjs.tz(`${this.getEndDate()} ${this.endTime()!.time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf()\n    });\n  }\n\n  endPickerHandler(time: ITime): void {\n    this.endTime.set(time);\n    \n    // Don't emit during initialization\n    if (this._isInitializing) {\n      return;\n    }\n\n    const validity =\n      this.checkTimeValidity(this.startTime()!.time.trim(), this.startDateEpoch()) && \n      this.checkTimeValidity(this.endTime()!.time.trim(), this.endDateEpoch());\n\n    this.rangeValidation(validity);\n    this.emitTimeRange({\n      valid: validity && this.rangeValidity(),\n      startTime: this.startTime()!.time,\n      endTime: this.endTime()!.time,\n      startEpoch: dayjs.tz(`${this.getStartDate()} ${this.startTime()!.time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf(),\n      endEpoch: dayjs.tz(`${this.getEndDate()} ${this.endTime()!.time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf()\n    });\n  }\n\n  checkTimeValidity(time: string, date: number): boolean {\n    const RE12 = /^(([0][1-9]|1[0-2]):([0-5][0-9])( )?(am|pm|AM|PM))$/i;\n    const RE24 = /^([01][0-9]|2[0-3]):[0-5][0-9]$/;\n    const RE = this.clockFormat() === 12 ? RE12 : RE24;\n\n    const timedayjs = dayjs.tz(`${dayjs.tz(date, this.timezone()).format(\"DD-MM-YYYY\")} ${time}`, `'DD-MM-YYYY' ${this.getTimeFormat()}`, this.timezone());\n    let flag: boolean = false;\n\n    if ((this.givenStartTime() && this.givenEndTime()) || (this.getStartDate() !== this.getEndDate() && this.getStartDate() !== this.getCurrDate())) {\n      flag = time.match(RE) ? true : false;\n    } else {\n      flag = time.match(RE) && timedayjs.diff(dayjs.tz(dayjs(), this.timezone()), \"m\") >= 0 ? true : false;\n    }\n    return flag;\n  }\n\n  rangeValidation(validity: boolean) {\n    if (validity && this.getStartDate() === this.getEndDate()) {\n      const startdayjs = dayjs.tz(this.startTime()!.time, this.getTimeFormat(), this.timezone());\n      const enddayjs = dayjs.tz(this.endTime()!.time, this.getTimeFormat(), this.timezone());\n      this.rangeValidity.set(enddayjs.diff(startdayjs, \"m\") >= 1);\n    }\n  }\n}\n\n\n","<div class=\"rangepicker-container\" [ngStyle]=\"{'flexDirection': direction(), 'gap': gap()}\">\n  <mis-timepicker\n    [clockFormat]=\"clockFormat()\"\n    [interval]=\"interval()\"\n    [dateAsEpoch]=\"startDateEpoch()\"\n    [firstInterval]=\"firstIntervals().start\"\n    (timeEmitter)=\"startPickerHandler($event)\"\n    [timezone]=\"timezone()\"\n    [height]=\"height()\"\n    [inputWidth]=\"inputWidth()\"\n    [dropdownWidth]=\"dropdownWidth()\"\n    [showTooltip]=\"showTooltip()\"\n    [givenTime]=\"givenStartTime()\"\n    [disable]=\"disableStartTime()\"\n    [disableUserInput]=\"disableUserInput()\"\n    [fontSize]=\"fontSize()\"\n  ></mis-timepicker>\n  <p *ngIf=\"direction() === 'row'\">-</p>\n  <mis-timepicker\n    [clockFormat]=\"clockFormat()\"\n    [interval]=\"interval()\"\n    [dateAsEpoch]=\"endDateEpoch()\"\n    [firstInterval]=\"firstIntervals().end\"\n    (timeEmitter)=\"endPickerHandler($event)\"\n    [rangeValidity]=\"rangeValidity()\"\n    [timezone]=\"timezone()\"\n    [height]=\"height()\"\n    [inputWidth]=\"inputWidth()\"\n    [dropdownWidth]=\"dropdownWidth()\"\n    [showTooltip]=\"showTooltip()\"\n    [givenTime]=\"givenEndTime()\"\n    [triggerChange]=\"triggerChange()\"\n    [disable]=\"disableEndTime()\"\n    [disableUserInput]=\"disableUserInput()\"\n    [fontSize]=\"fontSize()\"\n  ></mis-timepicker>\n</div>\n\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import { signal, inject, ElementRef, DestroyRef,
|
|
2
|
+
import { signal, inject, ElementRef, DestroyRef, Directive, input, computed, contentChild, effect, Component, NgModule } from '@angular/core';
|
|
3
3
|
import { NgControl, FormsModule } from '@angular/forms';
|
|
4
4
|
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
5
5
|
import * as i1 from '@angular/common';
|
|
@@ -18,18 +18,10 @@ class MisInputDirective {
|
|
|
18
18
|
const element = this.el.nativeElement;
|
|
19
19
|
const initialValue = this.control?.control?.value ?? element.value ?? '';
|
|
20
20
|
this.value.set(initialValue);
|
|
21
|
-
//
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
const controlValue = this.control?.control?.value;
|
|
26
|
-
if (controlValue !== undefined && controlValue !== null) {
|
|
27
|
-
this.value.set(controlValue);
|
|
28
|
-
}
|
|
29
|
-
else if (attrValue) {
|
|
30
|
-
this.value.set(attrValue);
|
|
31
|
-
}
|
|
32
|
-
}, { allowSignalWrites: true });
|
|
21
|
+
// Ensure input has placeholder attribute for CSS :placeholder-shown to work
|
|
22
|
+
if (!element.placeholder) {
|
|
23
|
+
element.placeholder = ' ';
|
|
24
|
+
}
|
|
33
25
|
if (this.control?.control) {
|
|
34
26
|
// Track status changes
|
|
35
27
|
this.control.control.statusChanges
|
|
@@ -37,7 +29,7 @@ class MisInputDirective {
|
|
|
37
29
|
.subscribe(() => {
|
|
38
30
|
this.validity.set(!this.control.control.invalid);
|
|
39
31
|
});
|
|
40
|
-
// Track value changes
|
|
32
|
+
// Track value changes via FormControl
|
|
41
33
|
this.control.control.valueChanges
|
|
42
34
|
.pipe(takeUntilDestroyed(this.destroyRef))
|
|
43
35
|
.subscribe(value => {
|
|
@@ -57,12 +49,24 @@ class MisInputDirective {
|
|
|
57
49
|
|
|
58
50
|
const _c0 = [[["", "mis-input-icon", ""]], [["input"]], [["", "mis-input-act", ""]], [["", "mis-input-hint", ""]], [["", "mis-input-error", ""]]];
|
|
59
51
|
const _c1 = ["[mis-input-icon]", "input", "[mis-input-act]", "[mis-input-hint]", "[mis-input-error]"];
|
|
60
|
-
const _c2 = (a0, a1, a2, a3, a4, a5) => ({ rounded: a0, floating: a1, "has-error": a2, "no-hint": a3, "mis-disabled": a4, "has-value": a5 });
|
|
61
|
-
function
|
|
62
|
-
i0.ɵɵelementStart(0, "span",
|
|
52
|
+
const _c2 = (a0, a1, a2, a3, a4, a5, a6) => ({ rounded: a0, floating: a1, "has-error": a2, "no-hint": a3, "mis-disabled": a4, "has-value": a5, "has-custom-placeholder": a6 });
|
|
53
|
+
function MisInputComponent_span_5_span_2_Template(rf, ctx) { if (rf & 1) {
|
|
54
|
+
i0.ɵɵelementStart(0, "span", 6);
|
|
63
55
|
i0.ɵɵtext(1, "*");
|
|
64
56
|
i0.ɵɵelementEnd();
|
|
65
57
|
} }
|
|
58
|
+
function MisInputComponent_span_5_Template(rf, ctx) { if (rf & 1) {
|
|
59
|
+
i0.ɵɵelementStart(0, "span", 4);
|
|
60
|
+
i0.ɵɵtext(1);
|
|
61
|
+
i0.ɵɵtemplate(2, MisInputComponent_span_5_span_2_Template, 2, 0, "span", 5);
|
|
62
|
+
i0.ɵɵelementEnd();
|
|
63
|
+
} if (rf & 2) {
|
|
64
|
+
const ctx_r0 = i0.ɵɵnextContext();
|
|
65
|
+
i0.ɵɵadvance();
|
|
66
|
+
i0.ɵɵtextInterpolate(ctx_r0.placeholder());
|
|
67
|
+
i0.ɵɵadvance();
|
|
68
|
+
i0.ɵɵproperty("ngIf", ctx_r0.isMandatory());
|
|
69
|
+
} }
|
|
66
70
|
class MisInputComponent {
|
|
67
71
|
constructor() {
|
|
68
72
|
// Signal Inputs replacing @Input()
|
|
@@ -72,6 +76,8 @@ class MisInputComponent {
|
|
|
72
76
|
this.noHints = input(false);
|
|
73
77
|
this.hasError = input(false);
|
|
74
78
|
this.isMandatory = input(false);
|
|
79
|
+
// Computed signal to check if we should show custom placeholder
|
|
80
|
+
this.hasCustomPlaceholder = computed(() => !!this.placeholder());
|
|
75
81
|
// Computed signal to track if input has value
|
|
76
82
|
this.hasValue = computed(() => {
|
|
77
83
|
const formInput = this.formInput();
|
|
@@ -90,14 +96,21 @@ class MisInputComponent {
|
|
|
90
96
|
this.inputValidity = computed(() => this.formInput()?.validity() ?? true);
|
|
91
97
|
// Computed signal to determine the overall invalid state
|
|
92
98
|
this.isInvalid = computed(() => !this.inputValidity() || this.hasError());
|
|
93
|
-
//
|
|
94
|
-
//
|
|
99
|
+
// Ensure input always has placeholder attribute (even if empty) for CSS :placeholder-shown to work
|
|
100
|
+
// This allows pure CSS detection of when input has value, no JavaScript listeners needed
|
|
95
101
|
effect(() => {
|
|
96
102
|
const formInput = this.formInput();
|
|
97
103
|
const inputElement = formInput?.el.nativeElement;
|
|
98
|
-
|
|
99
|
-
if (inputElement
|
|
100
|
-
|
|
104
|
+
const hasCustom = this.hasCustomPlaceholder();
|
|
105
|
+
if (inputElement) {
|
|
106
|
+
if (hasCustom) {
|
|
107
|
+
// When using custom placeholder, set invisible placeholder for :placeholder-shown detection
|
|
108
|
+
// CSS will hide the native placeholder, but attribute is needed for pseudo-class
|
|
109
|
+
if (!inputElement.placeholder || inputElement.placeholder.trim() === '') {
|
|
110
|
+
inputElement.placeholder = ' '; // Single space - invisible but allows :placeholder-shown
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
// If native placeholder exists, keep it (directive already ensures placeholder exists)
|
|
101
114
|
}
|
|
102
115
|
});
|
|
103
116
|
}
|
|
@@ -106,35 +119,30 @@ class MisInputComponent {
|
|
|
106
119
|
i0.ɵɵcontentQuerySignal(dirIndex, ctx.formInput, MisInputDirective, 5);
|
|
107
120
|
} if (rf & 2) {
|
|
108
121
|
i0.ɵɵqueryAdvance();
|
|
109
|
-
} }, inputs: { type: [1, "type"], size: [1, "size"], placeholder: [1, "placeholder"], noHints: [1, "noHints"], hasError: [1, "hasError"], isMandatory: [1, "isMandatory"] }, ngContentSelectors: _c1, decls:
|
|
122
|
+
} }, inputs: { type: [1, "type"], size: [1, "size"], placeholder: [1, "placeholder"], noHints: [1, "noHints"], hasError: [1, "hasError"], isMandatory: [1, "isMandatory"] }, ngContentSelectors: _c1, decls: 9, vars: 12, consts: [[3, "ngClass"], [1, "input-wrapper"], [1, "mis-input"], ["class", "mis-placeholder", 4, "ngIf"], [1, "mis-placeholder"], ["style", "color: red;", 4, "ngIf"], [2, "color", "red"]], template: function MisInputComponent_Template(rf, ctx) { if (rf & 1) {
|
|
110
123
|
i0.ɵɵprojectionDef(_c0);
|
|
111
124
|
i0.ɵɵelementStart(0, "div", 0)(1, "div", 1);
|
|
112
125
|
i0.ɵɵprojection(2);
|
|
113
126
|
i0.ɵɵelementStart(3, "div", 2);
|
|
114
127
|
i0.ɵɵprojection(4, 1);
|
|
115
|
-
i0.ɵɵ
|
|
116
|
-
i0.ɵɵ
|
|
117
|
-
i0.ɵɵ
|
|
118
|
-
i0.ɵɵelementEnd()();
|
|
119
|
-
i0.ɵɵprojection(8, 2);
|
|
128
|
+
i0.ɵɵtemplate(5, MisInputComponent_span_5_Template, 3, 2, "span", 3);
|
|
129
|
+
i0.ɵɵelementEnd();
|
|
130
|
+
i0.ɵɵprojection(6, 2);
|
|
120
131
|
i0.ɵɵelementEnd();
|
|
121
|
-
i0.ɵɵprojection(
|
|
122
|
-
i0.ɵɵprojection(
|
|
132
|
+
i0.ɵɵprojection(7, 3);
|
|
133
|
+
i0.ɵɵprojection(8, 4);
|
|
123
134
|
i0.ɵɵelementEnd();
|
|
124
135
|
} if (rf & 2) {
|
|
125
136
|
let tmp_1_0;
|
|
126
|
-
let tmp_2_0;
|
|
127
137
|
i0.ɵɵclassMap("input-container " + ctx.size());
|
|
128
|
-
i0.ɵɵproperty("ngClass", i0.ɵɵ
|
|
129
|
-
i0.ɵɵadvance(
|
|
130
|
-
i0.ɵɵ
|
|
131
|
-
|
|
132
|
-
i0.ɵɵproperty("ngIf", ctx.isMandatory());
|
|
133
|
-
} }, dependencies: [i1.NgClass, i1.NgIf], styles: ["[_ngcontent-%COMP%]:root{--pmry-200: #99BAF7;--pmry-100: #CBDDFB;--pmry-500: #0937B2;--pmry-400: #3C68D0;--pmry-600: #062A99;--pmry-700: #041F80;--pmry-300: #638FE7;--pmry-800: #021567;--pmry-900: #010F55;--sec-d-purple: #40447F;--sec-maroon: #6B034E;--sec-mud-red: #B23600;--sec-orange: #ED711C;--sec-purple: #815FD5;--sec-teal: #10ADAE;--sec-yellow: #D4900C;--sec-green: #547F40;--sec-bright-green: #27D22E;--sec-dark-teal: #035F6B;--sec-chocolate: #7C2F33;--sec-rube-pink: #C13D6D;--sec-cerulean: #0087B2;--sem-error: #B00020;--sem-info: #0091FF;--sem-warning: #FF9D00;--sem-success: #38AF49;--grey-bg-1: #FAFAFA;--grey-bg: #F5F5F5;--grey-seperators: #E0E0E0;--grey-disabled: #C8CDD3;--grey-hover: #F5F7FC;--grey-pressed: #E6EBF7;--grey-row: #F5F7FC;--dec-light-yellow: #F4E7C3;--dec-light-purple: #DACFF9;--dec-light-green: #E4F5E9;--dec-light-green2: #F1FFF3;--dec-light-pink: #FAE1EA;--dec-: #F4CBC1;--dec-lt-orange: #FAEFED;--dec-light-blue: #CFECF9;--dec-row-selection: #F1FDF8;--dec-row-selection2: #F2FBFF;--dec-row-lines: #D3E1E9;--text-white: #FFFFFF;--text-muted: #6A737D;--text-black: #181F33;--MR-solid-blue2:#C8D5F6;--MR-solid-purple:#C9C3FB;--MR-solid-orange:#EEAC9F;--MR-solid-green:#ACDADA;--MR-solid-brown:#E8C8AF;--MR-solid-yellow:#FFEFC7;--MR-solid-blue:#BBE6FF;--MR-solid-pink:#FFC6F2;--tr-hover:#F0F3FA;--tr-pressed:#DAE1F3;--brand-primary: #0937B2;--brand-primary-light: #3C68D0;--brand-primary-dark: #062A99;--brand-primary-darker: #041F80;--brand-primary-lighter: #638FE7;--brand-primary-lightest: #CBDDFB;--brand-primary-hover: #F0F3FA;--brand-primary-active: #DAE1F3;--brand-secondary: #ED711C;--brand-secondary-light: #F09E65;--brand-secondary-dark: #B23600;--brand-secondary-lighter: #FFC6F2;--brand-accent: #10ADAE;--brand-accent-light: #16CBBC;--brand-accent-dark: #035F6B;--brand-accent-lighter: #ACDADA;--brand-success: #38AF49;--brand-success-light: #4CAF50;--brand-success-dark: #216531;--brand-success-lighter: #E4F5E9;--brand-success-lightest: #F1FFF3;--brand-error: #B00020;--brand-error-light: #F04E4E;--brand-error-dark: #A60060;--brand-error-lighter: #FAE1EA;--brand-error-lightest: #FDF2F2;--brand-warning: #FF9D00;--brand-warning-light: #D4900C;--brand-warning-dark: #624000;--brand-warning-lighter: #F4E7C3;--brand-warning-lightest: #FAEFED;--brand-info: #0091FF;--brand-info-light: #35A1FF;--brand-info-dark: #0087B2;--brand-info-lighter: #CFECF9;--text-primary: #181F33;--text-secondary: #6A737D;--text-tertiary: #929DAB;--text-disabled: #929DAB;--text-primary-87: rgba(24, 31, 51, .87);--text-primary-60: rgba(24, 31, 51, .6);--text-primary-38: rgba(24, 31, 51, .38);--text-primary-12: rgba(24, 31, 51, .12);--bg-primary: #FFFFFF;--bg-secondary: #FAFAFA;--bg-tertiary: #F5F5F5;--bg-overlay: rgba(0, 0, 0, .32);--bg-overlay-light: rgba(0, 0, 0, .12);--bg-overlay-lighter: rgba(0, 0, 0, .08);--bg-overlay-lightest: rgba(0, 0, 0, .04);--border-primary: #E0E0E0;--border-secondary: #D6DCE2;--border-tertiary: #C8CDD3;--border-light: #F1F4F8;--border-primary-12: rgba(0, 0, 0, .12);--border-primary-08: rgba(0, 0, 0, .08);--border-primary-06: rgba(0, 0, 0, .06);--shadow-primary: rgba(0, 0, 0, .12);--shadow-secondary: rgba(0, 0, 0, .08);--shadow-tertiary: rgba(0, 0, 0, .04);--shadow-light: rgba(0, 0, 0, .06);--status-available: #929DAB;--status-unavailable: #CCD3DA;--status-hotseat: #857BFF;--status-multiteam: #10ADAE;--status-selected: #10ADAE;--status-upcoming: #D4900C;--status-room: #38AF49;--status-room-booked: #B23600;--status-room-unavailable: #181F33;--team-color-1: #F8C52E;--team-color-2: #FA8E20;--team-color-3: #987CDD;--team-color-4: #16CBBC;--team-color-5: #E65010;--team-color-6: #A60060;--team-color-7: #ED323B;--team-color-8: #35A1FF;--team-color-9: #80D348}.input-container[_ngcontent-%COMP%]{position:relative;padding-bottom:24px}.input-container.mis-disabled[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]{pointer-events:none!important}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]{box-sizing:border-box;display:flex;align-items:center;flex-direction:row;flex-wrap:nowrap;transition:all ease-in 60ms;background-color:var(--bg-primary, #FFFFFF);padding:3px 16px;gap:16px}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] .mis-input[_ngcontent-%COMP%]{flex:1 1 auto;z-index:0;position:relative;display:flex;align-items:center}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] input[_ngcontent-%COMP%]{flex:1 1 auto;border:none;outline:none;height:100%;padding:0;font-family:Lato;font-style:normal;font-weight:400;font-size:16px;height:24px;color:var(--text-primary, #181F33);background-color:transparent;width:100%;vertical-align:middle;position:relative}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] input[_ngcontent-%COMP%]::placeholder{transition:all ease-in .1s;opacity:0;transform-origin:left center;color:transparent}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] .mis-placeholder[_ngcontent-%COMP%]{position:absolute;font-family:Lato;font-style:normal;font-weight:400;font-size:16px;line-height:24px;color:var(--text-secondary, #6A737D);transition:all ease-in .15s;pointer-events:none}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]:focus-within{background-color:var(--bg-tertiary, #F5F5F5)}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]:focus-within{border:1px solid #0937B2}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] [mis-input-act][_ngcontent-%COMP%], .input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] [mis-input-icon][_ngcontent-%COMP%]{width:18px;height:18px;color:var(--text-secondary, #6A737D);font-size:24px;line-height:18px}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] [mis-input-act][_ngcontent-%COMP%]{cursor:pointer}.input-container.no-hint[_ngcontent-%COMP%]{padding-bottom:0}.input-container.has-value[_ngcontent-%COMP%] .mis-input[_ngcontent-%COMP%] .mis-placeholder[_ngcontent-%COMP%]{color:transparent!important}.input-container.rounded[_ngcontent-%COMP%] input[_ngcontent-%COMP%]{box-sizing:initial}.input-container.rounded.sm[_ngcontent-%COMP%] input[_ngcontent-%COMP%]{padding:3px 16px}.input-container.rounded.md[_ngcontent-%COMP%] input[_ngcontent-%COMP%]{padding:9px 16px}.input-container.rounded.lg[_ngcontent-%COMP%] input[_ngcontent-%COMP%]{padding:15px 16px}.input-container.rounded[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]{border-radius:4px;border:1px solid var(--border-primary, #E0E0E0);padding:0}.input-container.rounded[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]:hover{background-color:var(--bg-tertiary, #F5F5F5)}.input-container.rounded[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]:focus-within{border:1px solid var(--brand-primary, #0937B2)}.input-container.rounded[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] .mis-placeholder[_ngcontent-%COMP%]{color:var(--text-secondary, #6A737D)}.input-container.rounded[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] .mis-placeholder[_ngcontent-%COMP%]{margin-left:16px;transition-duration:50ms}.input-container.rounded.has-error[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]{border:1px solid var(--brand-error, #B00020)!important}.input-container.floating[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]{padding-top:24px;padding-bottom:7px;border-bottom:1px solid var(--border-primary, #E0E0E0)}.input-container.floating[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] input[_ngcontent-%COMP%]:focus + .mis-placeholder[_ngcontent-%COMP%]{color:var(--brand-primary, #0937B2)!important}.input-container.floating[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] input[_ngcontent-%COMP%]:not(:placeholder-shown) + .mis-placeholder[_ngcontent-%COMP%], .input-container.floating[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] input[_ngcontent-%COMP%]:focus + .mis-placeholder[_ngcontent-%COMP%]{transform:translateY(calc(-100% + 6px))!important;font-size:12px!important;letter-spacing:.2px!important}.input-container.floating[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]:focus-within{border:none;border-bottom:1px solid var(--brand-primary, #0937B2)}.input-container.floating[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]:focus-within input[_ngcontent-%COMP%]::placeholder{color:var(--text-secondary, #6A737D);opacity:1;font-size:16px}.input-container.floating.has-error[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]{border-bottom:1px solid var(--brand-error, #B00020)!important}.input-container.floating.has-error[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] .mis-placeholder[_ngcontent-%COMP%]{color:var(--brand-error, #B00020)!important}.input-container[_ngcontent-%COMP%] [mis-input-hint][_ngcontent-%COMP%], .input-container[_ngcontent-%COMP%] [mis-input-error][_ngcontent-%COMP%]{position:absolute;left:0;right:0;bottom:0;line-height:24px;height:24px;font-size:12px;color:var(--text-secondary, #6A737D);letter-spacing:.2px}.input-container[_ngcontent-%COMP%] [mis-input-error][_ngcontent-%COMP%]{color:var(--brand-error, #B00020)}"] }); }
|
|
138
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction7(4, _c2, ctx.type() === "rounded", ctx.type() === "floating", ctx.isInvalid(), ctx.noHints(), (tmp_1_0 = ctx.inputCtrl()) == null ? null : tmp_1_0.disabled, ctx.hasValue(), ctx.hasCustomPlaceholder()));
|
|
139
|
+
i0.ɵɵadvance(5);
|
|
140
|
+
i0.ɵɵproperty("ngIf", ctx.hasCustomPlaceholder());
|
|
141
|
+
} }, dependencies: [i1.NgClass, i1.NgIf], styles: ["[_ngcontent-%COMP%]:root{--pmry-200: #99BAF7;--pmry-100: #CBDDFB;--pmry-500: #0937B2;--pmry-400: #3C68D0;--pmry-600: #062A99;--pmry-700: #041F80;--pmry-300: #638FE7;--pmry-800: #021567;--pmry-900: #010F55;--sec-d-purple: #40447F;--sec-maroon: #6B034E;--sec-mud-red: #B23600;--sec-orange: #ED711C;--sec-purple: #815FD5;--sec-teal: #10ADAE;--sec-yellow: #D4900C;--sec-green: #547F40;--sec-bright-green: #27D22E;--sec-dark-teal: #035F6B;--sec-chocolate: #7C2F33;--sec-rube-pink: #C13D6D;--sec-cerulean: #0087B2;--sem-error: #B00020;--sem-info: #0091FF;--sem-warning: #FF9D00;--sem-success: #38AF49;--grey-bg-1: #FAFAFA;--grey-bg: #F5F5F5;--grey-seperators: #E0E0E0;--grey-disabled: #C8CDD3;--grey-hover: #F5F7FC;--grey-pressed: #E6EBF7;--grey-row: #F5F7FC;--dec-light-yellow: #F4E7C3;--dec-light-purple: #DACFF9;--dec-light-green: #E4F5E9;--dec-light-green2: #F1FFF3;--dec-light-pink: #FAE1EA;--dec-: #F4CBC1;--dec-lt-orange: #FAEFED;--dec-light-blue: #CFECF9;--dec-row-selection: #F1FDF8;--dec-row-selection2: #F2FBFF;--dec-row-lines: #D3E1E9;--text-white: #FFFFFF;--text-muted: #6A737D;--text-black: #181F33;--MR-solid-blue2:#C8D5F6;--MR-solid-purple:#C9C3FB;--MR-solid-orange:#EEAC9F;--MR-solid-green:#ACDADA;--MR-solid-brown:#E8C8AF;--MR-solid-yellow:#FFEFC7;--MR-solid-blue:#BBE6FF;--MR-solid-pink:#FFC6F2;--tr-hover:#F0F3FA;--tr-pressed:#DAE1F3;--brand-primary: #0937B2;--brand-primary-light: #3C68D0;--brand-primary-dark: #062A99;--brand-primary-darker: #041F80;--brand-primary-lighter: #638FE7;--brand-primary-lightest: #CBDDFB;--brand-primary-hover: #F0F3FA;--brand-primary-active: #DAE1F3;--brand-secondary: #ED711C;--brand-secondary-light: #F09E65;--brand-secondary-dark: #B23600;--brand-secondary-lighter: #FFC6F2;--brand-accent: #10ADAE;--brand-accent-light: #16CBBC;--brand-accent-dark: #035F6B;--brand-accent-lighter: #ACDADA;--brand-success: #38AF49;--brand-success-light: #4CAF50;--brand-success-dark: #216531;--brand-success-lighter: #E4F5E9;--brand-success-lightest: #F1FFF3;--brand-error: #B00020;--brand-error-light: #F04E4E;--brand-error-dark: #A60060;--brand-error-lighter: #FAE1EA;--brand-error-lightest: #FDF2F2;--brand-warning: #FF9D00;--brand-warning-light: #D4900C;--brand-warning-dark: #624000;--brand-warning-lighter: #F4E7C3;--brand-warning-lightest: #FAEFED;--brand-info: #0091FF;--brand-info-light: #35A1FF;--brand-info-dark: #0087B2;--brand-info-lighter: #CFECF9;--text-primary: #181F33;--text-secondary: #6A737D;--text-tertiary: #929DAB;--text-disabled: #929DAB;--text-primary-87: rgba(24, 31, 51, .87);--text-primary-60: rgba(24, 31, 51, .6);--text-primary-38: rgba(24, 31, 51, .38);--text-primary-12: rgba(24, 31, 51, .12);--bg-primary: #FFFFFF;--bg-secondary: #FAFAFA;--bg-tertiary: #F5F5F5;--bg-overlay: rgba(0, 0, 0, .32);--bg-overlay-light: rgba(0, 0, 0, .12);--bg-overlay-lighter: rgba(0, 0, 0, .08);--bg-overlay-lightest: rgba(0, 0, 0, .04);--border-primary: #E0E0E0;--border-secondary: #D6DCE2;--border-tertiary: #C8CDD3;--border-light: #F1F4F8;--border-primary-12: rgba(0, 0, 0, .12);--border-primary-08: rgba(0, 0, 0, .08);--border-primary-06: rgba(0, 0, 0, .06);--shadow-primary: rgba(0, 0, 0, .12);--shadow-secondary: rgba(0, 0, 0, .08);--shadow-tertiary: rgba(0, 0, 0, .04);--shadow-light: rgba(0, 0, 0, .06);--status-available: #929DAB;--status-unavailable: #CCD3DA;--status-hotseat: #857BFF;--status-multiteam: #10ADAE;--status-selected: #10ADAE;--status-upcoming: #D4900C;--status-room: #38AF49;--status-room-booked: #B23600;--status-room-unavailable: #181F33;--team-color-1: #F8C52E;--team-color-2: #FA8E20;--team-color-3: #987CDD;--team-color-4: #16CBBC;--team-color-5: #E65010;--team-color-6: #A60060;--team-color-7: #ED323B;--team-color-8: #35A1FF;--team-color-9: #80D348}.input-container[_ngcontent-%COMP%]{position:relative;padding-bottom:24px}.input-container.mis-disabled[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]{pointer-events:none!important}.input-container.has-custom-placeholder[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] input[_ngcontent-%COMP%]::placeholder{transition:all ease-in .1s;opacity:0;transform-origin:left center;color:transparent}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]{box-sizing:border-box;display:flex;align-items:center;flex-direction:row;flex-wrap:nowrap;transition:all ease-in 60ms;background-color:var(--bg-primary, #FFFFFF);padding:3px 16px;gap:16px}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] .mis-input[_ngcontent-%COMP%]{flex:1 1 auto;z-index:0;position:relative;display:flex;align-items:center}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] input[_ngcontent-%COMP%]{flex:1 1 auto;border:none;outline:none;height:100%;padding:0;font-family:Lato;font-style:normal;font-weight:400;font-size:16px;height:24px;color:var(--text-primary, #181F33);background-color:transparent;width:100%;vertical-align:middle;position:relative}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] .mis-placeholder[_ngcontent-%COMP%]{position:absolute;font-family:Lato;font-style:normal;font-weight:400;font-size:16px;line-height:24px;color:var(--text-secondary, #6A737D);transition:all ease-in .15s;pointer-events:none}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]:focus-within{background-color:var(--bg-tertiary, #F5F5F5)}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]:focus-within{border:1px solid #0937B2}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] [mis-input-act][_ngcontent-%COMP%], .input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] [mis-input-icon][_ngcontent-%COMP%]{width:18px;height:18px;color:var(--text-secondary, #6A737D);font-size:24px;line-height:18px}.input-container[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] [mis-input-act][_ngcontent-%COMP%]{cursor:pointer}.input-container.no-hint[_ngcontent-%COMP%]{padding-bottom:0}.input-container.has-custom-placeholder[_ngcontent-%COMP%] input[_ngcontent-%COMP%]:not(:placeholder-shown) + .mis-placeholder[_ngcontent-%COMP%]{opacity:0;pointer-events:none}.input-container.has-value[_ngcontent-%COMP%] .mis-input[_ngcontent-%COMP%] .mis-placeholder[_ngcontent-%COMP%]{color:transparent!important}.input-container.rounded[_ngcontent-%COMP%] input[_ngcontent-%COMP%]{box-sizing:initial}.input-container.rounded.sm[_ngcontent-%COMP%] input[_ngcontent-%COMP%]{padding:3px 16px}.input-container.rounded.md[_ngcontent-%COMP%] input[_ngcontent-%COMP%]{padding:9px 16px}.input-container.rounded.lg[_ngcontent-%COMP%] input[_ngcontent-%COMP%]{padding:15px 16px}.input-container.rounded[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]{border-radius:4px;border:1px solid var(--border-primary, #E0E0E0);padding:0}.input-container.rounded[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]:hover{background-color:var(--bg-tertiary, #F5F5F5)}.input-container.rounded[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]:focus-within{border:1px solid var(--brand-primary, #0937B2)}.input-container.rounded[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] .mis-placeholder[_ngcontent-%COMP%]{margin-left:16px;transition-duration:50ms}.input-container.rounded.has-error[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]{border:1px solid var(--brand-error, #B00020)!important}.input-container.floating[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]{padding-top:24px;padding-bottom:7px;border-bottom:1px solid var(--border-primary, #E0E0E0)}.input-container.floating[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] input[_ngcontent-%COMP%]:focus + .mis-placeholder[_ngcontent-%COMP%]{color:var(--brand-primary, #0937B2)!important}.input-container.floating[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] input[_ngcontent-%COMP%]:not(:placeholder-shown) + .mis-placeholder[_ngcontent-%COMP%], .input-container.floating[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] input[_ngcontent-%COMP%]:focus + .mis-placeholder[_ngcontent-%COMP%]{transform:translateY(calc(-100% + 6px))!important;font-size:12px!important;letter-spacing:.2px!important}.input-container.floating[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]:focus-within{border:none;border-bottom:1px solid var(--brand-primary, #0937B2)}.input-container.floating[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]:focus-within input[_ngcontent-%COMP%]::placeholder{color:var(--text-secondary, #6A737D);opacity:1;font-size:16px}.input-container.floating.has-error[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%]{border-bottom:1px solid var(--brand-error, #B00020)!important}.input-container.floating.has-error[_ngcontent-%COMP%] .input-wrapper[_ngcontent-%COMP%] .mis-placeholder[_ngcontent-%COMP%]{color:var(--brand-error, #B00020)!important}.input-container[_ngcontent-%COMP%] [mis-input-hint][_ngcontent-%COMP%], .input-container[_ngcontent-%COMP%] [mis-input-error][_ngcontent-%COMP%]{position:absolute;left:0;right:0;bottom:0;line-height:24px;height:24px;font-size:12px;color:var(--text-secondary, #6A737D);letter-spacing:.2px}.input-container[_ngcontent-%COMP%] [mis-input-error][_ngcontent-%COMP%]{color:var(--brand-error, #B00020)}"] }); }
|
|
134
142
|
}
|
|
135
143
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(MisInputComponent, [{
|
|
136
144
|
type: Component,
|
|
137
|
-
args: [{ selector: "mis-input", template: "<div\n [class]=\"'input-container ' + size()\"\n [ngClass]=\"{\n rounded: type() === 'rounded',\n floating: type() === 'floating',\n 'has-error': isInvalid(),\n 'no-hint': noHints(),\n 'mis-disabled': inputCtrl()?.disabled,\n 'has-value': hasValue()\n }\"\n>\n <div class=\"input-wrapper\">\n <ng-content select=\"[mis-input-icon]\"></ng-content>\n <div class=\"mis-input\">\n <ng-content select=\"input\"></ng-content>\n <span class=\"mis-placeholder\">{{ placeholder()
|
|
145
|
+
args: [{ selector: "mis-input", template: "<div\n [class]=\"'input-container ' + size()\"\n [ngClass]=\"{\n rounded: type() === 'rounded',\n floating: type() === 'floating',\n 'has-error': isInvalid(),\n 'no-hint': noHints(),\n 'mis-disabled': inputCtrl()?.disabled,\n 'has-value': hasValue(),\n 'has-custom-placeholder': hasCustomPlaceholder()\n }\"\n>\n <div class=\"input-wrapper\">\n <ng-content select=\"[mis-input-icon]\"></ng-content>\n <div class=\"mis-input\">\n <ng-content select=\"input\"></ng-content>\n <span class=\"mis-placeholder\" *ngIf=\"hasCustomPlaceholder()\">{{ placeholder() }}<span *ngIf=\"isMandatory()\" style=\"color: red;\">*</span></span>\n </div>\n <ng-content select=\"[mis-input-act]\"></ng-content>\n </div>\n <ng-content select=\"[mis-input-hint]\"></ng-content>\n <ng-content select=\"[mis-input-error]\"></ng-content>\n</div>\n\n", styles: [":root{--pmry-200: #99BAF7;--pmry-100: #CBDDFB;--pmry-500: #0937B2;--pmry-400: #3C68D0;--pmry-600: #062A99;--pmry-700: #041F80;--pmry-300: #638FE7;--pmry-800: #021567;--pmry-900: #010F55;--sec-d-purple: #40447F;--sec-maroon: #6B034E;--sec-mud-red: #B23600;--sec-orange: #ED711C;--sec-purple: #815FD5;--sec-teal: #10ADAE;--sec-yellow: #D4900C;--sec-green: #547F40;--sec-bright-green: #27D22E;--sec-dark-teal: #035F6B;--sec-chocolate: #7C2F33;--sec-rube-pink: #C13D6D;--sec-cerulean: #0087B2;--sem-error: #B00020;--sem-info: #0091FF;--sem-warning: #FF9D00;--sem-success: #38AF49;--grey-bg-1: #FAFAFA;--grey-bg: #F5F5F5;--grey-seperators: #E0E0E0;--grey-disabled: #C8CDD3;--grey-hover: #F5F7FC;--grey-pressed: #E6EBF7;--grey-row: #F5F7FC;--dec-light-yellow: #F4E7C3;--dec-light-purple: #DACFF9;--dec-light-green: #E4F5E9;--dec-light-green2: #F1FFF3;--dec-light-pink: #FAE1EA;--dec-: #F4CBC1;--dec-lt-orange: #FAEFED;--dec-light-blue: #CFECF9;--dec-row-selection: #F1FDF8;--dec-row-selection2: #F2FBFF;--dec-row-lines: #D3E1E9;--text-white: #FFFFFF;--text-muted: #6A737D;--text-black: #181F33;--MR-solid-blue2:#C8D5F6;--MR-solid-purple:#C9C3FB;--MR-solid-orange:#EEAC9F;--MR-solid-green:#ACDADA;--MR-solid-brown:#E8C8AF;--MR-solid-yellow:#FFEFC7;--MR-solid-blue:#BBE6FF;--MR-solid-pink:#FFC6F2;--tr-hover:#F0F3FA;--tr-pressed:#DAE1F3;--brand-primary: #0937B2;--brand-primary-light: #3C68D0;--brand-primary-dark: #062A99;--brand-primary-darker: #041F80;--brand-primary-lighter: #638FE7;--brand-primary-lightest: #CBDDFB;--brand-primary-hover: #F0F3FA;--brand-primary-active: #DAE1F3;--brand-secondary: #ED711C;--brand-secondary-light: #F09E65;--brand-secondary-dark: #B23600;--brand-secondary-lighter: #FFC6F2;--brand-accent: #10ADAE;--brand-accent-light: #16CBBC;--brand-accent-dark: #035F6B;--brand-accent-lighter: #ACDADA;--brand-success: #38AF49;--brand-success-light: #4CAF50;--brand-success-dark: #216531;--brand-success-lighter: #E4F5E9;--brand-success-lightest: #F1FFF3;--brand-error: #B00020;--brand-error-light: #F04E4E;--brand-error-dark: #A60060;--brand-error-lighter: #FAE1EA;--brand-error-lightest: #FDF2F2;--brand-warning: #FF9D00;--brand-warning-light: #D4900C;--brand-warning-dark: #624000;--brand-warning-lighter: #F4E7C3;--brand-warning-lightest: #FAEFED;--brand-info: #0091FF;--brand-info-light: #35A1FF;--brand-info-dark: #0087B2;--brand-info-lighter: #CFECF9;--text-primary: #181F33;--text-secondary: #6A737D;--text-tertiary: #929DAB;--text-disabled: #929DAB;--text-primary-87: rgba(24, 31, 51, .87);--text-primary-60: rgba(24, 31, 51, .6);--text-primary-38: rgba(24, 31, 51, .38);--text-primary-12: rgba(24, 31, 51, .12);--bg-primary: #FFFFFF;--bg-secondary: #FAFAFA;--bg-tertiary: #F5F5F5;--bg-overlay: rgba(0, 0, 0, .32);--bg-overlay-light: rgba(0, 0, 0, .12);--bg-overlay-lighter: rgba(0, 0, 0, .08);--bg-overlay-lightest: rgba(0, 0, 0, .04);--border-primary: #E0E0E0;--border-secondary: #D6DCE2;--border-tertiary: #C8CDD3;--border-light: #F1F4F8;--border-primary-12: rgba(0, 0, 0, .12);--border-primary-08: rgba(0, 0, 0, .08);--border-primary-06: rgba(0, 0, 0, .06);--shadow-primary: rgba(0, 0, 0, .12);--shadow-secondary: rgba(0, 0, 0, .08);--shadow-tertiary: rgba(0, 0, 0, .04);--shadow-light: rgba(0, 0, 0, .06);--status-available: #929DAB;--status-unavailable: #CCD3DA;--status-hotseat: #857BFF;--status-multiteam: #10ADAE;--status-selected: #10ADAE;--status-upcoming: #D4900C;--status-room: #38AF49;--status-room-booked: #B23600;--status-room-unavailable: #181F33;--team-color-1: #F8C52E;--team-color-2: #FA8E20;--team-color-3: #987CDD;--team-color-4: #16CBBC;--team-color-5: #E65010;--team-color-6: #A60060;--team-color-7: #ED323B;--team-color-8: #35A1FF;--team-color-9: #80D348}.input-container{position:relative;padding-bottom:24px}.input-container.mis-disabled .input-wrapper{pointer-events:none!important}.input-container.has-custom-placeholder .input-wrapper input::placeholder{transition:all ease-in .1s;opacity:0;transform-origin:left center;color:transparent}.input-container .input-wrapper{box-sizing:border-box;display:flex;align-items:center;flex-direction:row;flex-wrap:nowrap;transition:all ease-in 60ms;background-color:var(--bg-primary, #FFFFFF);padding:3px 16px;gap:16px}.input-container .input-wrapper .mis-input{flex:1 1 auto;z-index:0;position:relative;display:flex;align-items:center}.input-container .input-wrapper input{flex:1 1 auto;border:none;outline:none;height:100%;padding:0;font-family:Lato;font-style:normal;font-weight:400;font-size:16px;height:24px;color:var(--text-primary, #181F33);background-color:transparent;width:100%;vertical-align:middle;position:relative}.input-container .input-wrapper .mis-placeholder{position:absolute;font-family:Lato;font-style:normal;font-weight:400;font-size:16px;line-height:24px;color:var(--text-secondary, #6A737D);transition:all ease-in .15s;pointer-events:none}.input-container .input-wrapper:focus-within{background-color:var(--bg-tertiary, #F5F5F5)}.input-container .input-wrapper:focus-within{border:1px solid #0937B2}.input-container .input-wrapper [mis-input-act],.input-container .input-wrapper [mis-input-icon]{width:18px;height:18px;color:var(--text-secondary, #6A737D);font-size:24px;line-height:18px}.input-container .input-wrapper [mis-input-act]{cursor:pointer}.input-container.no-hint{padding-bottom:0}.input-container.has-custom-placeholder input:not(:placeholder-shown)+.mis-placeholder{opacity:0;pointer-events:none}.input-container.has-value .mis-input .mis-placeholder{color:transparent!important}.input-container.rounded input{box-sizing:initial}.input-container.rounded.sm input{padding:3px 16px}.input-container.rounded.md input{padding:9px 16px}.input-container.rounded.lg input{padding:15px 16px}.input-container.rounded .input-wrapper{border-radius:4px;border:1px solid var(--border-primary, #E0E0E0);padding:0}.input-container.rounded .input-wrapper:hover{background-color:var(--bg-tertiary, #F5F5F5)}.input-container.rounded .input-wrapper:focus-within{border:1px solid var(--brand-primary, #0937B2)}.input-container.rounded .input-wrapper .mis-placeholder{margin-left:16px;transition-duration:50ms}.input-container.rounded.has-error .input-wrapper{border:1px solid var(--brand-error, #B00020)!important}.input-container.floating .input-wrapper{padding-top:24px;padding-bottom:7px;border-bottom:1px solid var(--border-primary, #E0E0E0)}.input-container.floating .input-wrapper input:focus+.mis-placeholder{color:var(--brand-primary, #0937B2)!important}.input-container.floating .input-wrapper input:not(:placeholder-shown)+.mis-placeholder,.input-container.floating .input-wrapper input:focus+.mis-placeholder{transform:translateY(calc(-100% + 6px))!important;font-size:12px!important;letter-spacing:.2px!important}.input-container.floating .input-wrapper:focus-within{border:none;border-bottom:1px solid var(--brand-primary, #0937B2)}.input-container.floating .input-wrapper:focus-within input::placeholder{color:var(--text-secondary, #6A737D);opacity:1;font-size:16px}.input-container.floating.has-error .input-wrapper{border-bottom:1px solid var(--brand-error, #B00020)!important}.input-container.floating.has-error .input-wrapper .mis-placeholder{color:var(--brand-error, #B00020)!important}.input-container [mis-input-hint],.input-container [mis-input-error]{position:absolute;left:0;right:0;bottom:0;line-height:24px;height:24px;font-size:12px;color:var(--text-secondary, #6A737D);letter-spacing:.2px}.input-container [mis-input-error]{color:var(--brand-error, #B00020)}\n"] }]
|
|
138
146
|
}], () => [], null); })();
|
|
139
147
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(MisInputComponent, { className: "MisInputComponent" }); })();
|
|
140
148
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mis-crystal-design-system-input.mjs","sources":["../../../projects/mis-components/input/directives/input/input.directive.ts","../../../projects/mis-components/input/mis-input.component.html","../../../projects/mis-components/input/mis-input.component.ts","../../../projects/mis-components/input/mis-input.module.ts","../../../projects/mis-components/input/mis-crystal-design-system-input.ts"],"sourcesContent":["import { Directive, ElementRef, OnInit, Optional, Self, signal, effect, OnDestroy, inject, DestroyRef } from \"@angular/core\";\nimport { NgControl } from \"@angular/forms\";\nimport { takeUntilDestroyed } from \"@angular/core/rxjs-interop\";\n\n@Directive({\n selector: \"input[misInput]\"\n})\nexport class MisInputDirective{\n // Public signals to expose directive state\n public validity = signal<boolean>(true);\n public value = signal<any>('');\n \n // Dependencies injected for use with signals\n public el = inject(ElementRef);\n public control = inject(NgControl, { optional: true, self: true });\n private destroyRef = inject(DestroyRef);\n\n constructor() {\n // Handle initial value synchronously\n const element = this.el.nativeElement;\n const initialValue = this.control?.control?.value ?? element.value ?? '';\n this.value.set(initialValue);\n\n // Then track changes\n effect(() => {\n const element = this.el.nativeElement;\n const attrValue = element.value;\n const controlValue = this.control?.control?.value;\n \n if (controlValue !== undefined && controlValue !== null) {\n this.value.set(controlValue);\n } else if (attrValue) {\n this.value.set(attrValue);\n }\n }, { allowSignalWrites: true });\n\n if (this.control?.control) {\n // Track status changes\n this.control.control.statusChanges\n .pipe(takeUntilDestroyed(this.destroyRef))\n .subscribe(() => {\n this.validity.set(!this.control!.control!.invalid);\n });\n\n // Track value changes\n this.control.control.valueChanges\n .pipe(takeUntilDestroyed(this.destroyRef))\n .subscribe(value => {\n this.value.set(value ?? '');\n });\n }\n }\n}\n\n\n","<div\n [class]=\"'input-container ' + size()\"\n [ngClass]=\"{\n rounded: type() === 'rounded',\n floating: type() === 'floating',\n 'has-error': isInvalid(),\n 'no-hint': noHints(),\n 'mis-disabled': inputCtrl()?.disabled,\n 'has-value': hasValue()\n }\"\n>\n <div class=\"input-wrapper\">\n <ng-content select=\"[mis-input-icon]\"></ng-content>\n <div class=\"mis-input\">\n <ng-content select=\"input\"></ng-content>\n <span class=\"mis-placeholder\">{{ placeholder() || formInput()?.el.nativeElement.placeholder }}<span *ngIf=\"isMandatory()\" style=\"color: red;\">*</span></span>\n </div>\n <ng-content select=\"[mis-input-act]\"></ng-content>\n </div>\n <ng-content select=\"[mis-input-hint]\"></ng-content>\n <ng-content select=\"[mis-input-error]\"></ng-content>\n</div>\n\n","import { Component, OnInit, OnDestroy, ViewEncapsulation, computed, contentChild, input, effect, signal, inject, DestroyRef } from \"@angular/core\";\nimport { MisInputDirective } from \"./directives/input/input.directive\";\n\n@Component({\n selector: \"mis-input\",\n templateUrl: \"./mis-input.component.html\",\n styleUrls: [\"./mis-input.component.scss\"],\n})\nexport class MisInputComponent{\n // Signal Inputs replacing @Input()\n public type = input<\"rounded\" | \"floating\">(\"floating\");\n public size = input<\"sm\" | \"md\" | \"lg\">(\"sm\");\n public placeholder = input<string | undefined>(undefined);\n public noHints = input<boolean>(false);\n public hasError = input<boolean>(false);\n public isMandatory = input<boolean>(false);\n\n // Computed signal to track if input has value\n public hasValue = computed(() => {\n const formInput = this.formInput();\n if (!formInput) return false;\n \n const value = formInput.value(); // Use the directive's value signal\n return value !== null && value !== undefined && value !== '';\n });\n\n // Content Child as a signal\n public formInput = contentChild(MisInputDirective);\n\n // Use a computed signal to derive the input control from the content child.\n // This will automatically update when the content child becomes available.\n public inputCtrl = computed(() => this.formInput()?.control?.control || null);\n\n // Use a computed signal to derive the validity state.\n // It reads the signal from the directive and updates whenever the directive's signal changes.\n public inputValidity = computed(() => this.formInput()?.validity() ?? true);\n\n constructor() {\n // This effect is now only for a side-effect (modifying a DOM element)\n // and no longer writes to signals.\n effect(() => {\n const formInput = this.formInput();\n const inputElement = formInput?.el.nativeElement;\n\n // For floating labels, we must clear the native placeholder to prevent it from overlapping.\n if (inputElement && this.type() === 'floating' && !this.placeholder() && inputElement.placeholder) {\n inputElement.placeholder = '';\n }\n });\n }\n\n // Computed signal to determine the overall invalid state\n public isInvalid = computed(() => !this.inputValidity() || this.hasError());\n}\n","import { CommonModule } from \"@angular/common\";\nimport { NgModule } from \"@angular/core\";\nimport { FormsModule } from \"@angular/forms\";\nimport { MisInputDirective } from \"./directives/input/input.directive\";\nimport { MisInputComponent } from \"./mis-input.component\";\n\n@NgModule({\n declarations: [MisInputComponent, MisInputDirective],\n imports: [CommonModule, FormsModule],\n exports: [MisInputComponent, MisInputDirective]\n})\nexport class MisInputModule {}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"mis-crystal-design-system-input.mjs","sources":["../../../projects/mis-components/input/directives/input/input.directive.ts","../../../projects/mis-components/input/mis-input.component.html","../../../projects/mis-components/input/mis-input.component.ts","../../../projects/mis-components/input/mis-input.module.ts","../../../projects/mis-components/input/mis-crystal-design-system-input.ts"],"sourcesContent":["import { Directive, ElementRef, signal, inject, DestroyRef } from \"@angular/core\";\nimport { NgControl } from \"@angular/forms\";\nimport { takeUntilDestroyed } from \"@angular/core/rxjs-interop\";\n\n@Directive({\n selector: \"input[misInput]\"\n})\nexport class MisInputDirective{\n // Public signals to expose directive state\n public validity = signal<boolean>(true);\n public value = signal<any>('');\n \n // Dependencies injected for use with signals\n public el = inject(ElementRef);\n public control = inject(NgControl, { optional: true, self: true });\n private destroyRef = inject(DestroyRef);\n\n constructor() {\n // Handle initial value synchronously\n const element = this.el.nativeElement;\n const initialValue = this.control?.control?.value ?? element.value ?? '';\n this.value.set(initialValue);\n\n // Ensure input has placeholder attribute for CSS :placeholder-shown to work\n if (!element.placeholder) {\n element.placeholder = ' ';\n }\n\n if (this.control?.control) {\n // Track status changes\n this.control.control.statusChanges\n .pipe(takeUntilDestroyed(this.destroyRef))\n .subscribe(() => {\n this.validity.set(!this.control!.control!.invalid);\n });\n\n // Track value changes via FormControl\n this.control.control.valueChanges\n .pipe(takeUntilDestroyed(this.destroyRef))\n .subscribe(value => {\n this.value.set(value ?? '');\n });\n }\n }\n}\n\n\n","<div\n [class]=\"'input-container ' + size()\"\n [ngClass]=\"{\n rounded: type() === 'rounded',\n floating: type() === 'floating',\n 'has-error': isInvalid(),\n 'no-hint': noHints(),\n 'mis-disabled': inputCtrl()?.disabled,\n 'has-value': hasValue(),\n 'has-custom-placeholder': hasCustomPlaceholder()\n }\"\n>\n <div class=\"input-wrapper\">\n <ng-content select=\"[mis-input-icon]\"></ng-content>\n <div class=\"mis-input\">\n <ng-content select=\"input\"></ng-content>\n <span class=\"mis-placeholder\" *ngIf=\"hasCustomPlaceholder()\">{{ placeholder() }}<span *ngIf=\"isMandatory()\" style=\"color: red;\">*</span></span>\n </div>\n <ng-content select=\"[mis-input-act]\"></ng-content>\n </div>\n <ng-content select=\"[mis-input-hint]\"></ng-content>\n <ng-content select=\"[mis-input-error]\"></ng-content>\n</div>\n\n","import { Component, computed, contentChild, input, effect, inject } from \"@angular/core\";\nimport { MisInputDirective } from \"./directives/input/input.directive\";\n\n@Component({\n selector: \"mis-input\",\n templateUrl: \"./mis-input.component.html\",\n styleUrls: [\"./mis-input.component.scss\"],\n})\nexport class MisInputComponent{\n // Signal Inputs replacing @Input()\n public type = input<\"rounded\" | \"floating\">(\"floating\");\n public size = input<\"sm\" | \"md\" | \"lg\">(\"sm\");\n public placeholder = input<string | undefined>(undefined);\n public noHints = input<boolean>(false);\n public hasError = input<boolean>(false);\n public isMandatory = input<boolean>(false);\n\n // Computed signal to check if we should show custom placeholder\n public hasCustomPlaceholder = computed(() => !!this.placeholder());\n\n // Computed signal to track if input has value\n public hasValue = computed(() => {\n const formInput = this.formInput();\n if (!formInput) return false;\n \n const value = formInput.value(); // Use the directive's value signal\n return value !== null && value !== undefined && value !== '';\n });\n\n // Content Child as a signal\n public formInput = contentChild(MisInputDirective);\n\n // Use a computed signal to derive the input control from the content child.\n // This will automatically update when the content child becomes available.\n public inputCtrl = computed(() => this.formInput()?.control?.control || null);\n\n // Use a computed signal to derive the validity state.\n // It reads the signal from the directive and updates whenever the directive's signal changes.\n public inputValidity = computed(() => this.formInput()?.validity() ?? true);\n\n constructor() {\n // Ensure input always has placeholder attribute (even if empty) for CSS :placeholder-shown to work\n // This allows pure CSS detection of when input has value, no JavaScript listeners needed\n effect(() => {\n const formInput = this.formInput();\n const inputElement = formInput?.el.nativeElement;\n const hasCustom = this.hasCustomPlaceholder();\n\n if (inputElement) {\n if (hasCustom) {\n // When using custom placeholder, set invisible placeholder for :placeholder-shown detection\n // CSS will hide the native placeholder, but attribute is needed for pseudo-class\n if (!inputElement.placeholder || inputElement.placeholder.trim() === '') {\n inputElement.placeholder = ' '; // Single space - invisible but allows :placeholder-shown\n }\n }\n // If native placeholder exists, keep it (directive already ensures placeholder exists)\n }\n });\n }\n\n // Computed signal to determine the overall invalid state\n public isInvalid = computed(() => !this.inputValidity() || this.hasError());\n}\n","import { CommonModule } from \"@angular/common\";\nimport { NgModule } from \"@angular/core\";\nimport { FormsModule } from \"@angular/forms\";\nimport { MisInputDirective } from \"./directives/input/input.directive\";\nimport { MisInputComponent } from \"./mis-input.component\";\n\n@NgModule({\n declarations: [MisInputComponent, MisInputDirective],\n imports: [CommonModule, FormsModule],\n exports: [MisInputComponent, MisInputDirective]\n})\nexport class MisInputModule {}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
|
|
@@ -417,11 +417,19 @@ class TableComponent {
|
|
|
417
417
|
// --- PAGINATION PAGE ARRAY LOGIC (MOVED/REPLACED initializePagination) ---
|
|
418
418
|
const len = config?.paginationConfig?.noOfPages;
|
|
419
419
|
const disablePageJumping = config?.paginationConfig?.disablePageJumping;
|
|
420
|
+
// Sync selectedPage from config if provided (for when parent updates the page)
|
|
421
|
+
if (config?.paginationConfig?.selectedPage !== undefined && config?.paginationConfig?.selectedPage !== null) {
|
|
422
|
+
const configSelectedPage = config.paginationConfig.selectedPage;
|
|
423
|
+
// Only update if different to avoid unnecessary updates
|
|
424
|
+
if (this.selectedPage() !== configSelectedPage) {
|
|
425
|
+
this.selectedPage.set(configSelectedPage);
|
|
426
|
+
}
|
|
427
|
+
}
|
|
420
428
|
// Only run if pagination is configured and page jumping is enabled
|
|
421
429
|
if (len && len > 0 && !disablePageJumping) {
|
|
422
430
|
// Read the internal state of the selected page for calculating the pages array.
|
|
423
431
|
// Since this runs on every config change, we rely on the value set
|
|
424
|
-
// by updateSelectedPage().
|
|
432
|
+
// by updateSelectedPage() or synced from config above.
|
|
425
433
|
const pageNumber = this.selectedPage();
|
|
426
434
|
if (len <= 7) {
|
|
427
435
|
const newPages = [];
|