ca-components 0.0.19 → 0.0.20

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.
@@ -5,7 +5,7 @@ import { FormsModule, ReactiveFormsModule } from '@angular/forms';
5
5
  import { AngularSvgIconModule } from 'angular-svg-icon';
6
6
  import { NgbModule } from '@ng-bootstrap/ng-bootstrap';
7
7
  // pipes
8
- import { SafeHtmlPipe } from '@shared/pipes/safe-html.pipe';
8
+ import { SafeHtmlPipe } from '../../pipes/safe-html.pipe';
9
9
  //helper
10
10
  import { CopyPasteHelper } from '../ca-note/utils/helper/copy-paste.helper';
11
11
  //components
@@ -182,4 +182,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
182
182
  }], styledValueEmitter: [{
183
183
  type: Output
184
184
  }] } });
185
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-input-note.component.js","sourceRoot":"","sources":["../../../../../../projects/ca-components/src/lib/components/ca-input-note/ca-input-note.component.ts","../../../../../../projects/ca-components/src/lib/components/ca-input-note/ca-input-note.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Output,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\n// modules\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { AngularSvgIconModule } from 'angular-svg-icon';\nimport { NgbModule } from '@ng-bootstrap/ng-bootstrap';\n\n// pipes\nimport { SafeHtmlPipe } from '@shared/pipes/safe-html.pipe';\n\n//helper\nimport { CopyPasteHelper } from '../ca-note/utils/helper/copy-paste.helper';\n//components\nimport { CaNoteContainerComponent } from '../ca-note-container/ca-note-container.component';\nimport { CaSpinnerComponent } from '../ca-spinner/ca-spinner.component';\n//animation\nimport { accordionAnimation } from '../../animations/accordion-animation';\n//svg-routes\nimport { SvgRoutes } from '../../utils/svg-routes/payroll-list-summary-svg-routes';\n\n@Component({\n  selector: 'app-ca-input-note',\n  templateUrl: './ca-input-note.component.html',\n  styleUrls: ['./ca-input-note.component.scss'],\n  animations: [accordionAnimation('showHideCardBody')],\n  standalone: true,\n  imports: [\n    // Module\n    CommonModule,\n    FormsModule,\n    ReactiveFormsModule,\n    NgbModule,\n    AngularSvgIconModule,\n    // Component\n    CaNoteContainerComponent,\n    CaSpinnerComponent,\n\n    // Pipe\n    SafeHtmlPipe,\n  ],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class CaInputNoteComponent {\n  @ViewChild('main_editor', { static: true }) public noteRef:\n    | ElementRef\n    | undefined;\n  @ViewChild('noteContainer', { static: true })\n  public noteContainer!: CaNoteContainerComponent;\n\n  @Input() set note(value: string) {\n    if (\n      (value && value != '' && value != 'null' && !this.isValue) ||\n      this.isBlankNote\n    ) {\n      this.showNote = value;\n    }\n  }\n  @Input() set isVisibleNote(value: boolean) {\n    this.noActive = value ? 'active' : 'innactive';\n    this._isVisibleNote = value ? true : false;\n  }\n  @Input() isBlankNote: boolean = false;\n  @Input() noteType: string = '';\n  @Input() entityId: number = 0;\n  @Input() entityType: string = '';\n  @Input() hasDefArrow: boolean = true;\n  @Input() isVisibleArrow: boolean = true;\n  @Input() noteLabel: string = 'Note';\n  @Input() placeholder: string = 'Type Something...';\n  @Input() isReadOnly: boolean = false;\n  @Input() customClass: string = '';\n\n  @Output() styledValueEmitter = new EventEmitter<string>();\n  //note properties\n  public _isVisibleNote: boolean | string = 'null';\n  public selectionTaken!: Selection;\n  public range!: Range;\n  private isValue: boolean = false;\n  public showNote!: string;\n  public value: string = '';\n  public isFocused: boolean = false;\n  private blurNoteTimeout!: NodeJS.Timeout;\n  public noActive!: string;\n\n  //saving\n  public isSavingNote: boolean = false;\n  private saveInterval: number | undefined;\n  private isSaveIntervalStarted!: boolean;\n  public savedValue: string = '';\n\n  constructor() {}\n\n  public openNote(): void {\n    this.noActive = '';\n    this._isVisibleNote = !this._isVisibleNote;\n\n    if (this._isVisibleNote) {\n      this.checkActiveItems();\n    }\n  }\n\n  public checkFocus(): void {\n    this.isFocused = true;\n    if (!this._isVisibleNote) {\n      setTimeout(() => {\n        this.checkActiveItems();\n      }, 150);\n    }\n  }\n\n  public changeValue(event: Event): void {\n    this.isValue = true;\n    const target = event.target as HTMLElement;\n    this.value = target.innerHTML;\n    this.checkActiveItems();\n  }\n\n  public saveNote(allowSave?: boolean): void {\n    if (this.value == '<br>') {\n      this.value = this.value.replace('<br>', '');\n    }\n    if (allowSave) {\n      this.savedValue = this.value;\n      const val = !this.value || this.value == '' ? null : this.value;\n    }\n    if (\n      this.noteType == 'details-card' &&\n      this.entityId &&\n      this.entityType != ''\n    ) {\n      this.isSavingNote = true;\n      setTimeout(() => {\n        this.isSavingNote = false;\n      }, 700);\n      this.updateNote();\n    }\n\n    this.styledValueEmitter.emit(this.noteRef!.nativeElement.innerHTML);\n  }\n\n  public stopBlurRemoveTimeout(): void {\n    clearTimeout(this.blurNoteTimeout);\n  }\n\n  public checkActiveItems(): void {\n    if (this.noteContainer && this.noteContainer?.checkActiveItems) {\n      this.noteContainer?.checkActiveItems();\n    }\n  }\n  public prepareForTextRange(): void {\n    this.isFocused = false;\n    this.selectionTaken = window.getSelection()!;\n    if (this.selectionTaken.rangeCount && this.selectionTaken.getRangeAt) {\n      this.range = this.selectionTaken.getRangeAt(0);\n      this.selectionTaken.removeAllRanges();\n      this.selectionTaken.addRange(this.range);\n\n      this.blurNoteTimeout = setTimeout(() => {\n        this.selectionTaken.removeAllRanges();\n      }, 100);\n    }\n    this.isSaveIntervalStarted = false;\n    clearInterval(this.saveInterval);\n    if (this.savedValue != this.value) {\n      this.saveNote(true);\n    }\n\n    this.styledValueEmitter.emit(this.noteRef!.nativeElement.innerHTML);\n  }\n\n  public updateNote(): void {\n    this.showNote = this.value;\n  }\n\n  public onPaste(event: ClipboardEvent): void {\n    CopyPasteHelper.onPaste(event);\n  }\n\n  public getSvgPath(propertyName: keyof typeof SvgRoutes): string {\n    return SvgRoutes[propertyName] as string;\n  }\n}\n","<div class=\"note-container {{ customClass }}\">\n  <!-- Header -->\n  <div\n    class=\"note-header d-flex align-items-center\"\n    [class.pointer]=\"isVisibleArrow\"\n  >\n    <div\n      class=\"d-flex align-items-center note-label\"\n      [ngStyle]=\"{ color: _isVisibleNote ? '#424242' : '#6C6C6C' }\"\n      (click)=\"isVisibleArrow ? openNote() : ''\"\n    >\n      {{ noteLabel }}\n    </div>\n\n    <div\n      class=\"note_tools_container\"\n      (click)=\"isVisibleArrow && !_isVisibleNote ? openNote() : ''\"\n    >\n      <app-ca-note-container\n        #noteContainer\n        [isExpanded]=\"_isVisibleNote && _isVisibleNote != 'null'\"\n        [range]=\"range\"\n        [selectionTaken]=\"selectionTaken\"\n        [value]=\"value\"\n        [isPopoverNote]=\"false\"\n        [selectedEditor]=\"noteRef?.nativeElement\"\n        [isVisibleArrow]=\"isVisibleArrow\"\n        (stopBlurRemoveTimeout)=\"stopBlurRemoveTimeout()\"\n      ></app-ca-note-container>\n    </div>\n\n    <ng-container *ngIf=\"isVisibleArrow\">\n      <div\n        class=\"note_upper_hold d-flex justify-content-center align-items-center\"\n      >\n        <svg-icon\n          class=\"note-arrow\"\n          [ngClass]=\"{\n            rotate: _isVisibleNote && _isVisibleNote != 'null',\n          }\"\n          [src]=\"hasDefArrow ? getSvgPath('downArrow') : getSvgPath('upArrow')\"\n          (click)=\"openNote()\"\n        ></svg-icon>\n      </div>\n    </ng-container>\n  </div>\n\n  <!-- Body -->\n\n  <div\n    class=\"note-body\"\n    [ngClass]=\"noActive\"\n    #noteBody\n    [@showHideCardBody]=\"{\n      value: _isVisibleNote.toString(),\n      params: {\n        marginTop: '0px',\n        marginBottom: '0px',\n      },\n    }\"\n  >\n    <div\n      #main_editor\n      id=\"main_editor\"\n      class=\"note-textarea\"\n      [class.details_textarea]=\"noteType == 'details-card'\"\n      contenteditable=\"true\"\n      [attr.data-text]=\"placeholder\"\n      spellcheck=\"false\"\n      (input)=\"changeValue($event)\"\n      (focus)=\"checkFocus()\"\n      (blur)=\"prepareForTextRange()\"\n      [innerHTML]=\"showNote | safeHtml\"\n      (paste)=\"onPaste($event)\"\n    ></div>\n\n    <!-- Spinner -->\n\n    <ng-container *ngIf=\"isSavingNote && noteType == 'details-card'\">\n      <div class=\"spinner d-flex\">\n        <app-ca-spinner [size]=\"'small'\" [color]=\"'blueDark'\"></app-ca-spinner>\n      </div>\n    </ng-container>\n  </div>\n</div>\n"]}
185
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-input-note.component.js","sourceRoot":"","sources":["../../../../../../projects/ca-components/src/lib/components/ca-input-note/ca-input-note.component.ts","../../../../../../projects/ca-components/src/lib/components/ca-input-note/ca-input-note.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Output,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\n// modules\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { AngularSvgIconModule } from 'angular-svg-icon';\nimport { NgbModule } from '@ng-bootstrap/ng-bootstrap';\n\n// pipes\nimport { SafeHtmlPipe } from '../../pipes/safe-html.pipe';\n\n//helper\nimport { CopyPasteHelper } from '../ca-note/utils/helper/copy-paste.helper';\n//components\nimport { CaNoteContainerComponent } from '../ca-note-container/ca-note-container.component';\nimport { CaSpinnerComponent } from '../ca-spinner/ca-spinner.component';\n//animation\nimport { accordionAnimation } from '../../animations/accordion-animation';\n//svg-routes\nimport { SvgRoutes } from '../../utils/svg-routes/payroll-list-summary-svg-routes';\n\n@Component({\n  selector: 'app-ca-input-note',\n  templateUrl: './ca-input-note.component.html',\n  styleUrls: ['./ca-input-note.component.scss'],\n  animations: [accordionAnimation('showHideCardBody')],\n  standalone: true,\n  imports: [\n    // Module\n    CommonModule,\n    FormsModule,\n    ReactiveFormsModule,\n    NgbModule,\n    AngularSvgIconModule,\n    // Component\n    CaNoteContainerComponent,\n    CaSpinnerComponent,\n\n    // Pipe\n    SafeHtmlPipe,\n  ],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class CaInputNoteComponent {\n  @ViewChild('main_editor', { static: true }) public noteRef:\n    | ElementRef\n    | undefined;\n  @ViewChild('noteContainer', { static: true })\n  public noteContainer!: CaNoteContainerComponent;\n\n  @Input() set note(value: string) {\n    if (\n      (value && value != '' && value != 'null' && !this.isValue) ||\n      this.isBlankNote\n    ) {\n      this.showNote = value;\n    }\n  }\n  @Input() set isVisibleNote(value: boolean) {\n    this.noActive = value ? 'active' : 'innactive';\n    this._isVisibleNote = value ? true : false;\n  }\n  @Input() isBlankNote: boolean = false;\n  @Input() noteType: string = '';\n  @Input() entityId: number = 0;\n  @Input() entityType: string = '';\n  @Input() hasDefArrow: boolean = true;\n  @Input() isVisibleArrow: boolean = true;\n  @Input() noteLabel: string = 'Note';\n  @Input() placeholder: string = 'Type Something...';\n  @Input() isReadOnly: boolean = false;\n  @Input() customClass: string = '';\n\n  @Output() styledValueEmitter = new EventEmitter<string>();\n  //note properties\n  public _isVisibleNote: boolean | string = 'null';\n  public selectionTaken!: Selection;\n  public range!: Range;\n  private isValue: boolean = false;\n  public showNote!: string;\n  public value: string = '';\n  public isFocused: boolean = false;\n  private blurNoteTimeout!: NodeJS.Timeout;\n  public noActive!: string;\n\n  //saving\n  public isSavingNote: boolean = false;\n  private saveInterval: number | undefined;\n  private isSaveIntervalStarted!: boolean;\n  public savedValue: string = '';\n\n  constructor() {}\n\n  public openNote(): void {\n    this.noActive = '';\n    this._isVisibleNote = !this._isVisibleNote;\n\n    if (this._isVisibleNote) {\n      this.checkActiveItems();\n    }\n  }\n\n  public checkFocus(): void {\n    this.isFocused = true;\n    if (!this._isVisibleNote) {\n      setTimeout(() => {\n        this.checkActiveItems();\n      }, 150);\n    }\n  }\n\n  public changeValue(event: Event): void {\n    this.isValue = true;\n    const target = event.target as HTMLElement;\n    this.value = target.innerHTML;\n    this.checkActiveItems();\n  }\n\n  public saveNote(allowSave?: boolean): void {\n    if (this.value == '<br>') {\n      this.value = this.value.replace('<br>', '');\n    }\n    if (allowSave) {\n      this.savedValue = this.value;\n      const val = !this.value || this.value == '' ? null : this.value;\n    }\n    if (\n      this.noteType == 'details-card' &&\n      this.entityId &&\n      this.entityType != ''\n    ) {\n      this.isSavingNote = true;\n      setTimeout(() => {\n        this.isSavingNote = false;\n      }, 700);\n      this.updateNote();\n    }\n\n    this.styledValueEmitter.emit(this.noteRef!.nativeElement.innerHTML);\n  }\n\n  public stopBlurRemoveTimeout(): void {\n    clearTimeout(this.blurNoteTimeout);\n  }\n\n  public checkActiveItems(): void {\n    if (this.noteContainer && this.noteContainer?.checkActiveItems) {\n      this.noteContainer?.checkActiveItems();\n    }\n  }\n  public prepareForTextRange(): void {\n    this.isFocused = false;\n    this.selectionTaken = window.getSelection()!;\n    if (this.selectionTaken.rangeCount && this.selectionTaken.getRangeAt) {\n      this.range = this.selectionTaken.getRangeAt(0);\n      this.selectionTaken.removeAllRanges();\n      this.selectionTaken.addRange(this.range);\n\n      this.blurNoteTimeout = setTimeout(() => {\n        this.selectionTaken.removeAllRanges();\n      }, 100);\n    }\n    this.isSaveIntervalStarted = false;\n    clearInterval(this.saveInterval);\n    if (this.savedValue != this.value) {\n      this.saveNote(true);\n    }\n\n    this.styledValueEmitter.emit(this.noteRef!.nativeElement.innerHTML);\n  }\n\n  public updateNote(): void {\n    this.showNote = this.value;\n  }\n\n  public onPaste(event: ClipboardEvent): void {\n    CopyPasteHelper.onPaste(event);\n  }\n\n  public getSvgPath(propertyName: keyof typeof SvgRoutes): string {\n    return SvgRoutes[propertyName] as string;\n  }\n}\n","<div class=\"note-container {{ customClass }}\">\n  <!-- Header -->\n  <div\n    class=\"note-header d-flex align-items-center\"\n    [class.pointer]=\"isVisibleArrow\"\n  >\n    <div\n      class=\"d-flex align-items-center note-label\"\n      [ngStyle]=\"{ color: _isVisibleNote ? '#424242' : '#6C6C6C' }\"\n      (click)=\"isVisibleArrow ? openNote() : ''\"\n    >\n      {{ noteLabel }}\n    </div>\n\n    <div\n      class=\"note_tools_container\"\n      (click)=\"isVisibleArrow && !_isVisibleNote ? openNote() : ''\"\n    >\n      <app-ca-note-container\n        #noteContainer\n        [isExpanded]=\"_isVisibleNote && _isVisibleNote != 'null'\"\n        [range]=\"range\"\n        [selectionTaken]=\"selectionTaken\"\n        [value]=\"value\"\n        [isPopoverNote]=\"false\"\n        [selectedEditor]=\"noteRef?.nativeElement\"\n        [isVisibleArrow]=\"isVisibleArrow\"\n        (stopBlurRemoveTimeout)=\"stopBlurRemoveTimeout()\"\n      ></app-ca-note-container>\n    </div>\n\n    <ng-container *ngIf=\"isVisibleArrow\">\n      <div\n        class=\"note_upper_hold d-flex justify-content-center align-items-center\"\n      >\n        <svg-icon\n          class=\"note-arrow\"\n          [ngClass]=\"{\n            rotate: _isVisibleNote && _isVisibleNote != 'null',\n          }\"\n          [src]=\"hasDefArrow ? getSvgPath('downArrow') : getSvgPath('upArrow')\"\n          (click)=\"openNote()\"\n        ></svg-icon>\n      </div>\n    </ng-container>\n  </div>\n\n  <!-- Body -->\n\n  <div\n    class=\"note-body\"\n    [ngClass]=\"noActive\"\n    #noteBody\n    [@showHideCardBody]=\"{\n      value: _isVisibleNote.toString(),\n      params: {\n        marginTop: '0px',\n        marginBottom: '0px',\n      },\n    }\"\n  >\n    <div\n      #main_editor\n      id=\"main_editor\"\n      class=\"note-textarea\"\n      [class.details_textarea]=\"noteType == 'details-card'\"\n      contenteditable=\"true\"\n      [attr.data-text]=\"placeholder\"\n      spellcheck=\"false\"\n      (input)=\"changeValue($event)\"\n      (focus)=\"checkFocus()\"\n      (blur)=\"prepareForTextRange()\"\n      [innerHTML]=\"showNote | safeHtml\"\n      (paste)=\"onPaste($event)\"\n    ></div>\n\n    <!-- Spinner -->\n\n    <ng-container *ngIf=\"isSavingNote && noteType == 'details-card'\">\n      <div class=\"spinner d-flex\">\n        <app-ca-spinner [size]=\"'small'\" [color]=\"'blueDark'\"></app-ca-spinner>\n      </div>\n    </ng-container>\n  </div>\n</div>\n"]}
@@ -5,7 +5,7 @@ import { LoadComponent } from '../ca-pickup-delivery-block/components/ca-load/ca
5
5
  // Helpers
6
6
  import { PickupDeliveryHelper } from '../ca-pickup-delivery-block/utils/helpers/pickup-delivery.helper';
7
7
  // Pipes
8
- import { DateFromStringPipe } from '@shared/pipes/date-from-string.pipe';
8
+ import { DateFromStringPipe } from '../../pipes/date-from-string.pipe';
9
9
  // Modules
10
10
  import { NgbModule } from '@ng-bootstrap/ng-bootstrap';
11
11
  import * as i0 from "@angular/core";
@@ -48,4 +48,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
48
48
  }], ctorParameters: function () { return []; }, propDecorators: { loads: [{
49
49
  type: Input
50
50
  }] } });
51
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-pickup-delivery-block.component.js","sourceRoot":"","sources":["../../../../../../projects/ca-components/src/lib/components/ca-pickup-delivery-block/ca-pickup-delivery-block.component.ts","../../../../../../projects/ca-components/src/lib/components/ca-pickup-delivery-block/ca-pickup-delivery-block.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,KAAK,EAAU,MAAM,eAAe,CAAC;AAKzD,aAAa;AACb,OAAO,EAAE,aAAa,EAAE,MAAM,kEAAkE,CAAC;AAMjG,UAAU;AACV,OAAO,EAAE,oBAAoB,EAAE,MAAM,kEAAkE,CAAC;AAGxG,QAAQ;AACR,OAAO,EAAE,kBAAkB,EAAE,MAAM,qCAAqC,CAAC;AAEzE,UAAU;AACV,OAAO,EAAE,SAAS,EAAc,MAAM,4BAA4B,CAAC;;;;AASnE,MAAM,OAAO,4BAA4B;IAQvC;QALO,aAAQ,GAAsB,EAAuB,CAAC;QACtD,YAAO,GAAY,KAAK,CAAC;QAEzB,kBAAa,GAAY,KAAK,CAAC;IAEvB,CAAC;IAEhB,QAAQ;QACN,IAAI,CAAC,qBAAqB,EAAE,CAAC;IAC/B,CAAC;IAEO,qBAAqB;QAC3B,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,GAAG,oBAAoB,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC3E,IAAI,IAAI,EAAE;YACR,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;YACrB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;YACpB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;SAC1B;aAAM;YACL,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;SACtB;IACH,CAAC;IAEM,WAAW,CAAC,EAAc;QAC/B,EAAE,CAAC,IAAI,EAAE,CAAC;QACV,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;IAC5B,CAAC;IAEM,YAAY,CAAC,EAAc;QAChC,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAC3B,EAAE,CAAC,KAAK,EAAE,CAAC;IACb,CAAC;+GAjCU,4BAA4B;mGAA5B,4BAA4B,oHC9BzC,s7EAiEA,mh5KDtCY,YAAY,4NAAE,kBAAkB,2DAAE,aAAa,wFAAE,SAAS;;4FAGzD,4BAA4B;kBAPxC,SAAS;+BACE,8BAA8B,WAG/B,CAAC,YAAY,EAAE,kBAAkB,EAAE,aAAa,EAAE,SAAS,CAAC,cACzD,IAAI;0EAGP,KAAK;sBAAb,KAAK","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, Input, OnInit } from '@angular/core';\n\n// Modals\nimport { NgbModal } from '@ng-bootstrap/ng-bootstrap';\n\n// Components\nimport { LoadComponent } from '../ca-pickup-delivery-block/components/ca-load/ca-load.component';\n\n// Models\nimport { DispatchAssignedLoadListResponse } from '../ca-pickup-delivery-block/models/dispatch-assigned-load-list-response';\nimport { LoadShortResponse } from '../ca-pickup-delivery-block/models/load-short-response';\n\n// Helpers\nimport { PickupDeliveryHelper } from '../ca-pickup-delivery-block/utils/helpers/pickup-delivery.helper';\nimport { StatusTypeEnum } from '../ca-pickup-delivery-block/models/status-types.enum';\n\n// Pipes\nimport { DateFromStringPipe } from '@shared/pipes/date-from-string.pipe';\n\n// Modules\nimport { NgbModule, NgbPopover } from '@ng-bootstrap/ng-bootstrap';\n\n@Component({\n  selector: 'app-ca-pickup-delivery-block',\n  templateUrl: './ca-pickup-delivery-block.component.html',\n  styleUrls: ['./ca-pickup-delivery-block.component.scss'],\n  imports: [CommonModule, DateFromStringPipe, LoadComponent, NgbModule],\n  standalone: true,\n})\nexport class PickupDeliveryBlockComponent implements OnInit {\n  @Input() loads!: DispatchAssignedLoadListResponse;\n\n  public loadInfo: LoadShortResponse = {} as LoadShortResponse;\n  public hasLoad: boolean = false;\n  public loadType!: StatusTypeEnum;\n  public isPopoverOpen: boolean = false;\n\n  constructor() {}\n\n  ngOnInit(): void {\n    this.initializeLoadDetails();\n  }\n\n  private initializeLoadDetails(): void {\n    const { load, loadType } = PickupDeliveryHelper.setLoadDetails(this.loads);\n    if (load) {\n      this.loadInfo = load;\n      this.hasLoad = true;\n      this.loadType = loadType;\n    } else {\n      this.hasLoad = false;\n    }\n  }\n\n  public openPopover(t2: NgbPopover): void {\n    t2.open();\n    this.isPopoverOpen = true;\n  }\n\n  public closePopover(t2: NgbPopover): void {\n    this.isPopoverOpen = false;\n    t2.close();\n  }\n}\n","<div class=\"incomplete-table-container\">\n  <ng-container *ngIf=\"hasLoad; else noLoadInfo\">\n    <div\n      class=\"incomplete-table-holder stops d-flex justify-content-between align-items-center\"\n      #t2=\"ngbPopover\"\n      [ngClass]=\"{ popoverOpen: isPopoverOpen }\"\n      [ngbPopover]=\"loadDetailsPopover\"\n      triggers=\"manual\"\n      [autoClose]=\"'outside'\"\n      container=\"body\"\n      [placement]=\"'bottom'\"\n      (click)=\"openPopover(t2)\"\n      (hidden)=\"closePopover(t2)\"\n      (shown)=\"isPopoverOpen = true\"\n    >\n      <div class=\"stops-side d-flex align-items-center left\">\n        <span\n          class=\"d-flex justify-content-center align-items-center pickupStationNumber ca-font-bold\"\n          [ngClass]=\"{\n            'active-pickup': loadType === 'ACTIVE',\n            'pending-pickup': loadType === 'PENDING',\n          }\"\n          >{{ loadInfo.pickupCount }}</span\n        >\n        <div class=\"d-flex flex-column\">\n          <span class=\"location ca-font-semi-bold\"\n            >{{ loadInfo.pickup?.shipper?.address?.city }},\n            {{ loadInfo.pickup?.shipper?.address?.state }}</span\n          >\n          <span class=\"date ca-font-regular d-flex justify-content-start\">{{\n            loadInfo.pickup?.dateFrom | dateFromStringPipe\n          }}</span>\n        </div>\n      </div>\n\n      <div class=\"stops-side d-flex align-items-center right\">\n        <span\n          class=\"d-flex justify-content-center align-items-center deliveryStationNumber ca-font-bold\"\n          [ngClass]=\"{\n            'active-delivery': loadType === 'ACTIVE',\n            'pending-delivery': loadType === 'PENDING',\n          }\"\n          >{{ loadInfo.deliveryCount }}</span\n        >\n        <div class=\"d-flex flex-column\">\n          <span class=\"location ca-font-semi-bold\"\n            >{{ loadInfo.delivery?.shipper?.address?.city }},\n            {{ loadInfo.delivery?.shipper?.address?.state }}</span\n          >\n          <span class=\"date ca-font-regular d-flex justify-content-start\">{{\n            loadInfo.delivery?.dateFrom | dateFromStringPipe\n          }}</span>\n        </div>\n      </div>\n    </div>\n  </ng-container>\n\n  <ng-template #noLoadInfo>\n    <div class=\"incomplete-table-holder\"></div>\n  </ng-template>\n\n  <ng-template #loadDetailsPopover>\n    <app-ca-load [focusedTab]=\"loadType\" [loads]=\"loads\"></app-ca-load>\n  </ng-template>\n</div>\n"]}
51
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-pickup-delivery-block.component.js","sourceRoot":"","sources":["../../../../../../projects/ca-components/src/lib/components/ca-pickup-delivery-block/ca-pickup-delivery-block.component.ts","../../../../../../projects/ca-components/src/lib/components/ca-pickup-delivery-block/ca-pickup-delivery-block.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,KAAK,EAAU,MAAM,eAAe,CAAC;AAKzD,aAAa;AACb,OAAO,EAAE,aAAa,EAAE,MAAM,kEAAkE,CAAC;AAMjG,UAAU;AACV,OAAO,EAAE,oBAAoB,EAAE,MAAM,kEAAkE,CAAC;AAGxG,QAAQ;AACR,OAAO,EAAE,kBAAkB,EAAE,MAAM,mCAAmC,CAAC;AAEvE,UAAU;AACV,OAAO,EAAE,SAAS,EAAc,MAAM,4BAA4B,CAAC;;;;AASnE,MAAM,OAAO,4BAA4B;IAQvC;QALO,aAAQ,GAAsB,EAAuB,CAAC;QACtD,YAAO,GAAY,KAAK,CAAC;QAEzB,kBAAa,GAAY,KAAK,CAAC;IAEvB,CAAC;IAEhB,QAAQ;QACN,IAAI,CAAC,qBAAqB,EAAE,CAAC;IAC/B,CAAC;IAEO,qBAAqB;QAC3B,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,GAAG,oBAAoB,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC3E,IAAI,IAAI,EAAE;YACR,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;YACrB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;YACpB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;SAC1B;aAAM;YACL,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;SACtB;IACH,CAAC;IAEM,WAAW,CAAC,EAAc;QAC/B,EAAE,CAAC,IAAI,EAAE,CAAC;QACV,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;IAC5B,CAAC;IAEM,YAAY,CAAC,EAAc;QAChC,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAC3B,EAAE,CAAC,KAAK,EAAE,CAAC;IACb,CAAC;+GAjCU,4BAA4B;mGAA5B,4BAA4B,oHC9BzC,s7EAiEA,mh5KDtCY,YAAY,4NAAE,kBAAkB,2DAAE,aAAa,wFAAE,SAAS;;4FAGzD,4BAA4B;kBAPxC,SAAS;+BACE,8BAA8B,WAG/B,CAAC,YAAY,EAAE,kBAAkB,EAAE,aAAa,EAAE,SAAS,CAAC,cACzD,IAAI;0EAGP,KAAK;sBAAb,KAAK","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, Input, OnInit } from '@angular/core';\n\n// Modals\nimport { NgbModal } from '@ng-bootstrap/ng-bootstrap';\n\n// Components\nimport { LoadComponent } from '../ca-pickup-delivery-block/components/ca-load/ca-load.component';\n\n// Models\nimport { DispatchAssignedLoadListResponse } from '../ca-pickup-delivery-block/models/dispatch-assigned-load-list-response';\nimport { LoadShortResponse } from '../ca-pickup-delivery-block/models/load-short-response';\n\n// Helpers\nimport { PickupDeliveryHelper } from '../ca-pickup-delivery-block/utils/helpers/pickup-delivery.helper';\nimport { StatusTypeEnum } from '../ca-pickup-delivery-block/models/status-types.enum';\n\n// Pipes\nimport { DateFromStringPipe } from '../../pipes/date-from-string.pipe';\n\n// Modules\nimport { NgbModule, NgbPopover } from '@ng-bootstrap/ng-bootstrap';\n\n@Component({\n  selector: 'app-ca-pickup-delivery-block',\n  templateUrl: './ca-pickup-delivery-block.component.html',\n  styleUrls: ['./ca-pickup-delivery-block.component.scss'],\n  imports: [CommonModule, DateFromStringPipe, LoadComponent, NgbModule],\n  standalone: true,\n})\nexport class PickupDeliveryBlockComponent implements OnInit {\n  @Input() loads!: DispatchAssignedLoadListResponse;\n\n  public loadInfo: LoadShortResponse = {} as LoadShortResponse;\n  public hasLoad: boolean = false;\n  public loadType!: StatusTypeEnum;\n  public isPopoverOpen: boolean = false;\n\n  constructor() {}\n\n  ngOnInit(): void {\n    this.initializeLoadDetails();\n  }\n\n  private initializeLoadDetails(): void {\n    const { load, loadType } = PickupDeliveryHelper.setLoadDetails(this.loads);\n    if (load) {\n      this.loadInfo = load;\n      this.hasLoad = true;\n      this.loadType = loadType;\n    } else {\n      this.hasLoad = false;\n    }\n  }\n\n  public openPopover(t2: NgbPopover): void {\n    t2.open();\n    this.isPopoverOpen = true;\n  }\n\n  public closePopover(t2: NgbPopover): void {\n    this.isPopoverOpen = false;\n    t2.close();\n  }\n}\n","<div class=\"incomplete-table-container\">\n  <ng-container *ngIf=\"hasLoad; else noLoadInfo\">\n    <div\n      class=\"incomplete-table-holder stops d-flex justify-content-between align-items-center\"\n      #t2=\"ngbPopover\"\n      [ngClass]=\"{ popoverOpen: isPopoverOpen }\"\n      [ngbPopover]=\"loadDetailsPopover\"\n      triggers=\"manual\"\n      [autoClose]=\"'outside'\"\n      container=\"body\"\n      [placement]=\"'bottom'\"\n      (click)=\"openPopover(t2)\"\n      (hidden)=\"closePopover(t2)\"\n      (shown)=\"isPopoverOpen = true\"\n    >\n      <div class=\"stops-side d-flex align-items-center left\">\n        <span\n          class=\"d-flex justify-content-center align-items-center pickupStationNumber ca-font-bold\"\n          [ngClass]=\"{\n            'active-pickup': loadType === 'ACTIVE',\n            'pending-pickup': loadType === 'PENDING',\n          }\"\n          >{{ loadInfo.pickupCount }}</span\n        >\n        <div class=\"d-flex flex-column\">\n          <span class=\"location ca-font-semi-bold\"\n            >{{ loadInfo.pickup?.shipper?.address?.city }},\n            {{ loadInfo.pickup?.shipper?.address?.state }}</span\n          >\n          <span class=\"date ca-font-regular d-flex justify-content-start\">{{\n            loadInfo.pickup?.dateFrom | dateFromStringPipe\n          }}</span>\n        </div>\n      </div>\n\n      <div class=\"stops-side d-flex align-items-center right\">\n        <span\n          class=\"d-flex justify-content-center align-items-center deliveryStationNumber ca-font-bold\"\n          [ngClass]=\"{\n            'active-delivery': loadType === 'ACTIVE',\n            'pending-delivery': loadType === 'PENDING',\n          }\"\n          >{{ loadInfo.deliveryCount }}</span\n        >\n        <div class=\"d-flex flex-column\">\n          <span class=\"location ca-font-semi-bold\"\n            >{{ loadInfo.delivery?.shipper?.address?.city }},\n            {{ loadInfo.delivery?.shipper?.address?.state }}</span\n          >\n          <span class=\"date ca-font-regular d-flex justify-content-start\">{{\n            loadInfo.delivery?.dateFrom | dateFromStringPipe\n          }}</span>\n        </div>\n      </div>\n    </div>\n  </ng-container>\n\n  <ng-template #noLoadInfo>\n    <div class=\"incomplete-table-holder\"></div>\n  </ng-template>\n\n  <ng-template #loadDetailsPopover>\n    <app-ca-load [focusedTab]=\"loadType\" [loads]=\"loads\"></app-ca-load>\n  </ng-template>\n</div>\n"]}
@@ -13,7 +13,7 @@ import { OptionsButtonIconsSvgRoutes } from '../../../../../ca-pickup-delivery-b
13
13
  import { PickupDeliveryBlockConstants } from '../../../../../ca-pickup-delivery-block/utils/constants/pickup-delivery-block.constants';
14
14
  //Pipes
15
15
  import { FormatCurrencyPipe } from '../../../../../../pipes/format-currency.pipe';
16
- import { DateFromStringPipe } from '@shared/pipes/date-from-string.pipe';
16
+ import { DateFromStringPipe } from '../../../../../../pipes/date-from-string.pipe';
17
17
  import * as i0 from "@angular/core";
18
18
  import * as i1 from "../../../../../../pipes/format-currency.pipe";
19
19
  import * as i2 from "@angular/common";
@@ -105,4 +105,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
105
105
  }], focusLoadEmitter: [{
106
106
  type: Output
107
107
  }] } });
108
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-load-list.component.js","sourceRoot":"","sources":["../../../../../../../../../../projects/ca-components/src/lib/components/ca-pickup-delivery-block/components/ca-load/components/ca-load-list/ca-load-list.component.ts","../../../../../../../../../../projects/ca-components/src/lib/components/ca-pickup-delivery-block/components/ca-load/components/ca-load-list/ca-load-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport { CommonModule } from '@angular/common';\n//Models\nimport { LoadShortResponse } from '../../../../../ca-pickup-delivery-block/models/load-short-response';\nimport { IItemList } from '../../../../../../models/dropdown.model';\nimport { StatusTypeEnum } from '../../../../../ca-pickup-delivery-block/models/status-types.enum';\n//Modules\nimport { AngularSvgIconModule } from 'angular-svg-icon';\n\n//Components\nimport { CaDropdownComponent } from '../../../../../ca-dropdown/ca-dropdown.component';\nimport { ActiveLoadComponent } from '../../../../../ca-pickup-delivery-block/components/ca-load/components/ca-load-single/ca-load-single.component';\n\n//Svg routes\nimport { PickupDeliverySvgRoutes } from '../../../../../ca-pickup-delivery-block/utils/svg-routes/pickup-delivery-svg.routes';\nimport { OptionsButtonIconsSvgRoutes } from '../../../../../ca-pickup-delivery-block/utils/svg-routes/options-icon.routes';\n\n//Dropdown options\nimport { PickupDeliveryBlockConstants } from '../../../../../ca-pickup-delivery-block/utils/constants/pickup-delivery-block.constants';\n\n//Pipes\nimport { FormatCurrencyPipe } from '../../../../../../pipes/format-currency.pipe';\nimport { DateFromStringPipe } from '@shared/pipes/date-from-string.pipe';\n\n@Component({\n  selector: 'app-ca-load-list',\n  templateUrl: './ca-load-list.component.html',\n  styleUrls: ['./ca-load-list.component.scss'],\n  standalone: true,\n  providers: [\n    //Pipes\n    FormatCurrencyPipe,\n  ],\n  imports: [\n    //Angular\n    CommonModule,\n\n    //Modules\n    AngularSvgIconModule,\n\n    //Components\n    CaDropdownComponent,\n    ActiveLoadComponent,\n\n    //Pipes\n    DateFromStringPipe,\n  ],\n})\nexport class LoadListComponent {\n  @Input() loads!: Array<LoadShortResponse>;\n  @Input() focusedTab!: StatusTypeEnum;\n  @Input() isFocusingLoad: boolean = false;\n  @Output() focusLoadEmitter = new EventEmitter<boolean>();\n\n  public focusedLoad!: Array<LoadShortResponse>;\n\n  //Icons\n  public originalIcon: string = OptionsButtonIconsSvgRoutes.optionsDefault;\n  public alternateIcon: string = OptionsButtonIconsSvgRoutes.optionsClicked;\n\n  //Dropdown options\n  public dropdownOptions!: IItemList[];\n  private dropdownStates: { [key: string]: boolean } = {};\n  private activeLoadNumber: number = -1;\n\n  constructor(public formatCurrencyPipe: FormatCurrencyPipe) {}\n\n  ngOnInit() {\n    this.setDropdownOptions();\n  }\n\n  private setDropdownOptions(): void {\n    switch (this.focusedTab) {\n      case StatusTypeEnum.CLOSED:\n        this.dropdownOptions = PickupDeliveryBlockConstants.closedOptions;\n        break;\n      case StatusTypeEnum.PENDING:\n        this.dropdownOptions = PickupDeliveryBlockConstants.pendingOptions;\n        break;\n      default:\n        this.dropdownOptions = [];\n        break;\n    }\n  }\n\n  public focusLoad(load: LoadShortResponse): void {\n    this.isFocusingLoad = !this.isFocusingLoad;\n    this.focusLoadEmitter.emit(this.isFocusingLoad);\n    this.focusedLoad = [{ ...load }];\n  }\n\n  public dropDownClickEvent(loadNumber: number): void {\n    if (this.activeLoadNumber !== -1 && this.activeLoadNumber !== loadNumber) {\n      this.dropdownStates[this.activeLoadNumber] = false;\n    }\n\n    this.dropdownStates[loadNumber] = !this.dropdownStates[loadNumber];\n    this.activeLoadNumber = this.dropdownStates[loadNumber] ? loadNumber : -1;\n  }\n\n  public isDropdownEnabled(loadNumber: number): boolean {\n    return !!this.dropdownStates[loadNumber];\n  }\n\n  public trackByIdentity(index: number): number {\n    return index;\n  }\n\n  public getSvgPath(\n    propertyName: keyof typeof PickupDeliverySvgRoutes\n  ): string {\n    return PickupDeliverySvgRoutes[propertyName] as string;\n  }\n}\n","<ng-container *ngIf=\"!isFocusingLoad; else focusedLoadTemplate\">\n  <ng-template #loadList>\n    <div class=\"wrapper-container\">\n      <ng-container *ngFor=\"let load of loads; trackBy: trackByIdentity\">\n        <div class=\"wrapper\" (click)=\"focusLoad(load)\">\n          <div class=\"d-flex justify-content-around dispatch-stops\">\n            <div\n              class=\"load-num ca-font-bold d-flex justify-content-between align-items-center\"\n            >\n              <span class=\"loadNumber-companyName\">\n                <span class=\"loadNumber\">{{ load.loadNumber }}</span>\n                <span class=\"company-name ca-font-regular\">\n                  {{ load.broker?.businessName }}\n                </span>\n              </span>\n              <span class=\"price\">{{\n                formatCurrencyPipe.transform(load.totalRate!)\n              }}</span>\n            </div>\n            <div class=\"button-container d-flex align-items-center\">\n              <app-ca-dropdown\n                [icon]=\"\n                  isDropdownEnabled(load.id) ? alternateIcon : originalIcon\n                \"\n                [itemList]=\"dropdownOptions\"\n                [isPopupShown]=\"isDropdownEnabled(load.id)\"\n                (click)=\"$event.stopPropagation()\"\n                (onClick)=\"dropDownClickEvent(load.id)\"\n              ></app-ca-dropdown>\n            </div>\n          </div>\n          <div class=\"stops d-flex justify-content-around\">\n            <div class=\"stops-side d-flex align-items-center\">\n              <span\n                class=\"line-left line-right d-flex justify-content-center align-items-center\"\n              >\n                {{ load.pickupCount }}</span\n              >\n              <div\n                class=\"date-location left d-flex flex-column align-items-start\"\n              >\n                <span class=\"location ca-font-semi-bold\">\n                  {{ load.pickup?.shipper?.address?.city }},\n                  {{ load.pickup?.shipper?.address?.state }}\n                </span>\n                <span class=\"date ca-font-regular\">\n                  {{ load.pickup?.dateFrom | dateFromStringPipe }}\n                </span>\n              </div>\n            </div>\n            <span class=\"d-flex justify-content-center align-items-center\">\n              <svg-icon\n                [src]=\"getSvgPath('arrowRight')\"\n                [svgStyle]=\"{ 'width.px': 14 }\"\n              ></svg-icon>\n            </span>\n            <div class=\"stops-side right d-flex align-items-center\">\n              <div\n                class=\"date-location right d-flex flex-column align-items-end\"\n              >\n                <span class=\"location ca-font-semi-bold\">\n                  {{ load.delivery?.shipper?.address?.city }},\n                  {{ load.delivery?.shipper?.address?.state }}\n                </span>\n                <span class=\"date ca-font-regular\">\n                  {{ load.delivery?.dateFrom | dateFromStringPipe }}\n                </span>\n              </div>\n              <span\n                class=\"line-right d-flex justify-content-center align-items-center\"\n              >\n                {{ load.deliveryCount }}</span\n              >\n            </div>\n          </div>\n        </div>\n      </ng-container>\n    </div>\n  </ng-template>\n\n  <div class=\"wrapper-container\">\n    <ng-container *ngTemplateOutlet=\"loadList\"></ng-container>\n  </div>\n</ng-container>\n\n<ng-template #focusedLoadTemplate>\n  <div class=\"focused-load-template\">\n    <app-ca-load-single\n      [activeLoad]=\"focusedLoad\"\n      [status]=\"focusedTab\"\n    ></app-ca-load-single>\n  </div>\n</ng-template>\n"]}
108
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-load-list.component.js","sourceRoot":"","sources":["../../../../../../../../../../projects/ca-components/src/lib/components/ca-pickup-delivery-block/components/ca-load/components/ca-load-list/ca-load-list.component.ts","../../../../../../../../../../projects/ca-components/src/lib/components/ca-pickup-delivery-block/components/ca-load/components/ca-load-list/ca-load-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport { CommonModule } from '@angular/common';\n//Models\nimport { LoadShortResponse } from '../../../../../ca-pickup-delivery-block/models/load-short-response';\nimport { IItemList } from '../../../../../../models/dropdown.model';\nimport { StatusTypeEnum } from '../../../../../ca-pickup-delivery-block/models/status-types.enum';\n//Modules\nimport { AngularSvgIconModule } from 'angular-svg-icon';\n\n//Components\nimport { CaDropdownComponent } from '../../../../../ca-dropdown/ca-dropdown.component';\nimport { ActiveLoadComponent } from '../../../../../ca-pickup-delivery-block/components/ca-load/components/ca-load-single/ca-load-single.component';\n\n//Svg routes\nimport { PickupDeliverySvgRoutes } from '../../../../../ca-pickup-delivery-block/utils/svg-routes/pickup-delivery-svg.routes';\nimport { OptionsButtonIconsSvgRoutes } from '../../../../../ca-pickup-delivery-block/utils/svg-routes/options-icon.routes';\n\n//Dropdown options\nimport { PickupDeliveryBlockConstants } from '../../../../../ca-pickup-delivery-block/utils/constants/pickup-delivery-block.constants';\n\n//Pipes\nimport { FormatCurrencyPipe } from '../../../../../../pipes/format-currency.pipe';\nimport { DateFromStringPipe } from '../../../../../../pipes/date-from-string.pipe';\n\n@Component({\n  selector: 'app-ca-load-list',\n  templateUrl: './ca-load-list.component.html',\n  styleUrls: ['./ca-load-list.component.scss'],\n  standalone: true,\n  providers: [\n    //Pipes\n    FormatCurrencyPipe,\n  ],\n  imports: [\n    //Angular\n    CommonModule,\n\n    //Modules\n    AngularSvgIconModule,\n\n    //Components\n    CaDropdownComponent,\n    ActiveLoadComponent,\n\n    //Pipes\n    DateFromStringPipe,\n  ],\n})\nexport class LoadListComponent {\n  @Input() loads!: Array<LoadShortResponse>;\n  @Input() focusedTab!: StatusTypeEnum;\n  @Input() isFocusingLoad: boolean = false;\n  @Output() focusLoadEmitter = new EventEmitter<boolean>();\n\n  public focusedLoad!: Array<LoadShortResponse>;\n\n  //Icons\n  public originalIcon: string = OptionsButtonIconsSvgRoutes.optionsDefault;\n  public alternateIcon: string = OptionsButtonIconsSvgRoutes.optionsClicked;\n\n  //Dropdown options\n  public dropdownOptions!: IItemList[];\n  private dropdownStates: { [key: string]: boolean } = {};\n  private activeLoadNumber: number = -1;\n\n  constructor(public formatCurrencyPipe: FormatCurrencyPipe) {}\n\n  ngOnInit() {\n    this.setDropdownOptions();\n  }\n\n  private setDropdownOptions(): void {\n    switch (this.focusedTab) {\n      case StatusTypeEnum.CLOSED:\n        this.dropdownOptions = PickupDeliveryBlockConstants.closedOptions;\n        break;\n      case StatusTypeEnum.PENDING:\n        this.dropdownOptions = PickupDeliveryBlockConstants.pendingOptions;\n        break;\n      default:\n        this.dropdownOptions = [];\n        break;\n    }\n  }\n\n  public focusLoad(load: LoadShortResponse): void {\n    this.isFocusingLoad = !this.isFocusingLoad;\n    this.focusLoadEmitter.emit(this.isFocusingLoad);\n    this.focusedLoad = [{ ...load }];\n  }\n\n  public dropDownClickEvent(loadNumber: number): void {\n    if (this.activeLoadNumber !== -1 && this.activeLoadNumber !== loadNumber) {\n      this.dropdownStates[this.activeLoadNumber] = false;\n    }\n\n    this.dropdownStates[loadNumber] = !this.dropdownStates[loadNumber];\n    this.activeLoadNumber = this.dropdownStates[loadNumber] ? loadNumber : -1;\n  }\n\n  public isDropdownEnabled(loadNumber: number): boolean {\n    return !!this.dropdownStates[loadNumber];\n  }\n\n  public trackByIdentity(index: number): number {\n    return index;\n  }\n\n  public getSvgPath(\n    propertyName: keyof typeof PickupDeliverySvgRoutes\n  ): string {\n    return PickupDeliverySvgRoutes[propertyName] as string;\n  }\n}\n","<ng-container *ngIf=\"!isFocusingLoad; else focusedLoadTemplate\">\n  <ng-template #loadList>\n    <div class=\"wrapper-container\">\n      <ng-container *ngFor=\"let load of loads; trackBy: trackByIdentity\">\n        <div class=\"wrapper\" (click)=\"focusLoad(load)\">\n          <div class=\"d-flex justify-content-around dispatch-stops\">\n            <div\n              class=\"load-num ca-font-bold d-flex justify-content-between align-items-center\"\n            >\n              <span class=\"loadNumber-companyName\">\n                <span class=\"loadNumber\">{{ load.loadNumber }}</span>\n                <span class=\"company-name ca-font-regular\">\n                  {{ load.broker?.businessName }}\n                </span>\n              </span>\n              <span class=\"price\">{{\n                formatCurrencyPipe.transform(load.totalRate!)\n              }}</span>\n            </div>\n            <div class=\"button-container d-flex align-items-center\">\n              <app-ca-dropdown\n                [icon]=\"\n                  isDropdownEnabled(load.id) ? alternateIcon : originalIcon\n                \"\n                [itemList]=\"dropdownOptions\"\n                [isPopupShown]=\"isDropdownEnabled(load.id)\"\n                (click)=\"$event.stopPropagation()\"\n                (onClick)=\"dropDownClickEvent(load.id)\"\n              ></app-ca-dropdown>\n            </div>\n          </div>\n          <div class=\"stops d-flex justify-content-around\">\n            <div class=\"stops-side d-flex align-items-center\">\n              <span\n                class=\"line-left line-right d-flex justify-content-center align-items-center\"\n              >\n                {{ load.pickupCount }}</span\n              >\n              <div\n                class=\"date-location left d-flex flex-column align-items-start\"\n              >\n                <span class=\"location ca-font-semi-bold\">\n                  {{ load.pickup?.shipper?.address?.city }},\n                  {{ load.pickup?.shipper?.address?.state }}\n                </span>\n                <span class=\"date ca-font-regular\">\n                  {{ load.pickup?.dateFrom | dateFromStringPipe }}\n                </span>\n              </div>\n            </div>\n            <span class=\"d-flex justify-content-center align-items-center\">\n              <svg-icon\n                [src]=\"getSvgPath('arrowRight')\"\n                [svgStyle]=\"{ 'width.px': 14 }\"\n              ></svg-icon>\n            </span>\n            <div class=\"stops-side right d-flex align-items-center\">\n              <div\n                class=\"date-location right d-flex flex-column align-items-end\"\n              >\n                <span class=\"location ca-font-semi-bold\">\n                  {{ load.delivery?.shipper?.address?.city }},\n                  {{ load.delivery?.shipper?.address?.state }}\n                </span>\n                <span class=\"date ca-font-regular\">\n                  {{ load.delivery?.dateFrom | dateFromStringPipe }}\n                </span>\n              </div>\n              <span\n                class=\"line-right d-flex justify-content-center align-items-center\"\n              >\n                {{ load.deliveryCount }}</span\n              >\n            </div>\n          </div>\n        </div>\n      </ng-container>\n    </div>\n  </ng-template>\n\n  <div class=\"wrapper-container\">\n    <ng-container *ngTemplateOutlet=\"loadList\"></ng-container>\n  </div>\n</ng-container>\n\n<ng-template #focusedLoadTemplate>\n  <div class=\"focused-load-template\">\n    <app-ca-load-single\n      [activeLoad]=\"focusedLoad\"\n      [status]=\"focusedTab\"\n    ></app-ca-load-single>\n  </div>\n</ng-template>\n"]}
@@ -12,9 +12,9 @@ import { CaDropdownComponent } from '../../../../../ca-dropdown/ca-dropdown.comp
12
12
  import { PickupDeliveryBlockConstants } from '../../../../../ca-pickup-delivery-block/utils/constants/pickup-delivery-block.constants';
13
13
  //Pipes
14
14
  import { FormatCurrencyPipe } from '../../../../../../pipes/format-currency.pipe';
15
+ import { DateFromStringPipe } from '../../../../../../pipes/date-from-string.pipe';
15
16
  //Enums
16
17
  import { StatusTypeEnum } from '../../../../../ca-pickup-delivery-block/models/status-types.enum';
17
- import { DateFromStringPipe } from '@shared/pipes/date-from-string.pipe';
18
18
  import * as i0 from "@angular/core";
19
19
  import * as i1 from "../../../../../../pipes/format-currency.pipe";
20
20
  import * as i2 from "angular-svg-icon";
@@ -80,4 +80,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
80
80
  }], status: [{
81
81
  type: Input
82
82
  }] } });
83
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-load-single.component.js","sourceRoot":"","sources":["../../../../../../../../../../projects/ca-components/src/lib/components/ca-pickup-delivery-block/components/ca-load/components/ca-load-single/ca-load-single.component.ts","../../../../../../../../../../projects/ca-components/src/lib/components/ca-pickup-delivery-block/components/ca-load/components/ca-load-single/ca-load-single.component.html"],"names":[],"mappings":"AAAA,uBAAuB;AACvB,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AACxD,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,sBAAsB;AACtB,OAAO,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;AAMxD,YAAY;AACZ,OAAO,EAAE,uBAAuB,EAAE,MAAM,yDAAyD,CAAC;AAClG,OAAO,EAAE,2BAA2B,EAAE,MAAM,kDAAkD,CAAC;AAE/F,UAAU;AACV,OAAO,EAAE,mBAAmB,EAAE,MAAM,kDAAkD,CAAC;AACvF,OAAO,EAAE,4BAA4B,EAAE,MAAM,yFAAyF,CAAC;AACvI,OAAO;AACP,OAAO,EAAE,kBAAkB,EAAE,MAAM,8CAA8C,CAAC;AAElF,OAAO;AACP,OAAO,EAAE,cAAc,EAAE,MAAM,kEAAkE,CAAC;AAClG,OAAO,EAAE,kBAAkB,EAAE,MAAM,qCAAqC,CAAC;;;;;AAmBzE,MAAM,OAAO,mBAAmB;IAa9B,YAAmB,kBAAsC;QAAtC,uBAAkB,GAAlB,kBAAkB,CAAoB;QATzD,OAAO;QACA,iBAAY,GAAW,2BAA2B,CAAC,cAAc,CAAC;QAClE,kBAAa,GAAW,2BAA2B,CAAC,cAAc,CAAC;QACnE,gBAAW,GAAW,IAAI,CAAC,YAAY,CAAC;QAE/C,kBAAkB;QACX,sBAAiB,GAAY,KAAK,CAAC;IAGkB,CAAC;IAE7D,QAAQ;QACN,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC5B,CAAC;IAEO,kBAAkB;QACxB,QAAQ,IAAI,CAAC,MAAM,EAAE;YACnB,KAAK,cAAc,CAAC,MAAM;gBACxB,IAAI,CAAC,eAAe,GAAG,4BAA4B,CAAC,aAAa,CAAC;gBAClE,MAAM;YACR,KAAK,cAAc,CAAC,MAAM;gBACxB,IAAI,CAAC,eAAe,GAAG,4BAA4B,CAAC,aAAa,CAAC;gBAClE,MAAM;YACR,KAAK,cAAc,CAAC,OAAO;gBACzB,IAAI,CAAC,eAAe,GAAG,4BAA4B,CAAC,cAAc,CAAC;gBACnE,MAAM;YACR;gBACE,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;gBAC1B,MAAM;SACT;IACH,CAAC;IAEM,kBAAkB;QACvB,IAAI,CAAC,iBAAiB,GAAG,CAAC,IAAI,CAAC,iBAAiB,CAAC;QACjD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,iBAAiB;YACvC,CAAC,CAAC,IAAI,CAAC,aAAa;YACpB,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC;IACxB,CAAC;IAEM,UAAU,CACf,YAAkD;QAElD,OAAO,uBAAuB,CAAC,YAAY,CAAW,CAAC;IACzD,CAAC;+GA/CU,mBAAmB;mGAAnB,mBAAmB,yHAZnB;YACT,OAAO;YACP,kBAAkB;SACnB,0BCjCH,6kJAuIA,w05KDpGI,oBAAoB,gOACpB,gBAAgB,+BAChB,mBAAmB,+HACnB,YAAY,8HACZ,kBAAkB;;4FAGT,mBAAmB;kBAjB/B,SAAS;+BACE,oBAAoB,cAGlB,IAAI,aACL;wBACT,OAAO;wBACP,kBAAkB;qBACnB,WACQ;wBACP,oBAAoB;wBACpB,gBAAgB;wBAChB,mBAAmB;wBACnB,YAAY;wBACZ,kBAAkB;qBACnB;yGAGQ,UAAU;sBAAlB,KAAK;gBACG,MAAM;sBAAd,KAAK","sourcesContent":["// Angular core modules\nimport { Component, Input } from '@angular/core';\nimport { HttpClientModule } from '@angular/common/http';\nimport { CommonModule } from '@angular/common';\n// Third-party modules\nimport { AngularSvgIconModule } from 'angular-svg-icon';\n\n// Models\nimport { LoadShortResponse } from '../../../../../ca-pickup-delivery-block/models/load-short-response';\nimport { IItemList } from '../../../../../../models/dropdown.model';\n\n//Svg routes\nimport { PickupDeliverySvgRoutes } from '../../../../utils/svg-routes/pickup-delivery-svg.routes';\nimport { OptionsButtonIconsSvgRoutes } from '../../../../utils/svg-routes/options-icon.routes';\n\n//Dropdown\nimport { CaDropdownComponent } from '../../../../../ca-dropdown/ca-dropdown.component';\nimport { PickupDeliveryBlockConstants } from '../../../../../ca-pickup-delivery-block/utils/constants/pickup-delivery-block.constants';\n//Pipes\nimport { FormatCurrencyPipe } from '../../../../../../pipes/format-currency.pipe';\n\n//Enums\nimport { StatusTypeEnum } from '../../../../../ca-pickup-delivery-block/models/status-types.enum';\nimport { DateFromStringPipe } from '@shared/pipes/date-from-string.pipe';\n\n@Component({\n  selector: 'app-ca-load-single',\n  templateUrl: './ca-load-single.component.html',\n  styleUrls: ['./ca-load-single.component.scss'],\n  standalone: true,\n  providers: [\n    //Pipes\n    FormatCurrencyPipe,\n  ],\n  imports: [\n    AngularSvgIconModule,\n    HttpClientModule,\n    CaDropdownComponent,\n    CommonModule,\n    DateFromStringPipe,\n  ],\n})\nexport class ActiveLoadComponent {\n  @Input() activeLoad!: Array<LoadShortResponse>;\n  @Input() status!: StatusTypeEnum;\n\n  //Icons\n  public originalIcon: string = OptionsButtonIconsSvgRoutes.optionsDefault;\n  public alternateIcon: string = OptionsButtonIconsSvgRoutes.optionsClicked;\n  public currentIcon: string = this.originalIcon;\n\n  //Dropdown options\n  public isDropdownEnabled: boolean = false;\n  public dropdownOptions!: IItemList[];\n\n  constructor(public formatCurrencyPipe: FormatCurrencyPipe) {}\n\n  ngOnInit() {\n    this.setDropdownOptions();\n  }\n\n  private setDropdownOptions(): void {\n    switch (this.status) {\n      case StatusTypeEnum.ACTIVE:\n        this.dropdownOptions = PickupDeliveryBlockConstants.activeOptions;\n        break;\n      case StatusTypeEnum.CLOSED:\n        this.dropdownOptions = PickupDeliveryBlockConstants.closedOptions;\n        break;\n      case StatusTypeEnum.PENDING:\n        this.dropdownOptions = PickupDeliveryBlockConstants.pendingOptions;\n        break;\n      default:\n        this.dropdownOptions = [];\n        break;\n    }\n  }\n\n  public dropDownClickEvent() {\n    this.isDropdownEnabled = !this.isDropdownEnabled;\n    this.currentIcon = this.isDropdownEnabled\n      ? this.alternateIcon\n      : this.originalIcon;\n  }\n\n  public getSvgPath(\n    propertyName: keyof typeof PickupDeliverySvgRoutes\n  ): string {\n    return PickupDeliverySvgRoutes[propertyName] as string;\n  }\n}\n","<ng-container *ngIf=\"activeLoad && activeLoad.length; else noActiveLoad\">\n  <div class=\"load-details d-flex\">\n    <div class=\"details-container d-flex flex-column justify-content-between\">\n      <div class=\"top-details d-flex justify-content-between\">\n        <span class=\"price ca-font-medium\">\n          LOAD {{ activeLoad[0].loadNumber }}\n          <svg-icon\n            [src]=\"getSvgPath('vector')\"\n            [svgStyle]=\"{ 'width.px': 18 }\"\n          ></svg-icon>\n        </span>\n        <span class=\"load ca-font-bold\">{{\n          formatCurrencyPipe.transform(activeLoad[0].totalRate!)\n        }}</span>\n      </div>\n\n      <div class=\"bottom-details d-flex justify-content-between\">\n        <p class=\"miles-ref\">\n          <svg-icon\n            [src]=\"getSvgPath('miles')\"\n            [svgStyle]=\"{ 'width.px': 14 }\"\n          ></svg-icon>\n          {{ activeLoad[0].totalMiles }}\n          <span class=\"ref-text ca-font-bold\">Ref.</span>\n          {{ activeLoad[0].referenceNumber }}\n        </p>\n        <p class=\"ca-font-bold\">\n          Adj.\n          <span class=\"adj-price\">{{\n            formatCurrencyPipe.transform(activeLoad[0].totalAdjustedRate!)\n          }}</span>\n        </p>\n      </div>\n    </div>\n\n    <div class=\"d-flex flex-column button-container align-items-start\">\n      <app-ca-dropdown\n        [icon]=\"currentIcon\"\n        [itemList]=\"dropdownOptions\"\n        (onClick)=\"dropDownClickEvent()\"\n        [isPopupShown]=\"isDropdownEnabled\"\n      ></app-ca-dropdown>\n    </div>\n  </div>\n\n  <div class=\"stops d-flex justify-content-around\">\n    <div class=\"stops-side d-flex align-items-center\">\n      <span class=\"line-left d-flex justify-content-center align-items-center\">\n        {{ activeLoad[0].pickupCount }}\n      </span>\n      <div class=\"date-location left d-flex flex-column align-items-start\">\n        <span class=\"location ca-font-semi-bold\">\n          {{ activeLoad[0].pickup?.shipper?.address?.city }},\n          {{ activeLoad[0].pickup?.shipper?.address?.state }}\n        </span>\n        <span class=\"date ca-font-regular\">{{\n          activeLoad[0].pickup?.dateFrom | dateFromStringPipe\n        }}</span>\n      </div>\n    </div>\n\n    <span class=\"arrow d-flex justify-content-center align-items-center\">\n      <svg-icon\n        [src]=\"getSvgPath('arrowRight')\"\n        [svgStyle]=\"{ 'width.px': 14 }\"\n      ></svg-icon>\n    </span>\n\n    <div class=\"stops-side right d-flex align-items-center\">\n      <div class=\"date-location right d-flex flex-column align-items-start\">\n        <span class=\"location ca-font-semi-bold\">\n          {{ activeLoad[0].delivery?.shipper?.address?.city }},\n          {{ activeLoad[0].delivery?.shipper?.address?.state }}\n        </span>\n        <span class=\"date ca-font-regular\">{{\n          activeLoad[0].delivery?.dateFrom | dateFromStringPipe\n        }}</span>\n      </div>\n      <span class=\"line-right d-flex justify-content-center align-items-center\">\n        {{ activeLoad[0].deliveryCount }}\n      </span>\n    </div>\n  </div>\n\n  <div class=\"dispatch-stops\">\n    <span class=\"bussiness-name ca-font-bold\">{{\n      activeLoad[0].broker?.businessName\n    }}</span>\n\n    <div class=\"broker ca-font-regular\">\n      <ng-container *ngIf=\"activeLoad[0].broker?.contactName\">\n        <p>\n          <svg-icon\n            [src]=\"getSvgPath('userIcon')\"\n            [svgStyle]=\"{ 'width.px': 16 }\"\n          ></svg-icon>\n          {{ activeLoad[0].broker?.contactName }}\n        </p>\n      </ng-container>\n      <ng-container *ngIf=\"activeLoad[0].broker?.phone\">\n        <p>\n          <svg-icon\n            [src]=\"getSvgPath('phoneIcon')\"\n            [svgStyle]=\"{ 'width.px': 16 }\"\n          ></svg-icon>\n          {{ activeLoad[0].broker?.phone }}\n        </p>\n      </ng-container>\n      <ng-container *ngIf=\"activeLoad[0].broker?.email\">\n        <p>\n          <svg-icon\n            [src]=\"getSvgPath('mailIcon')\"\n            [svgStyle]=\"{ 'width.px': 16 }\"\n          ></svg-icon>\n          {{ activeLoad[0].broker?.email }}\n        </p>\n      </ng-container>\n    </div>\n  </div>\n\n  <ng-container *ngIf=\"status === 'ACTIVE'\">\n    <div class=\"driverMessage\">\n      <h3 class=\"ca-font-bold\">DRIVER MESSAGE</h3>\n      <span class=\"message ca-font-regular\">{{\n        activeLoad[0].driverMessage\n      }}</span>\n    </div>\n  </ng-container>\n</ng-container>\n\n<ng-template #noActiveLoad>\n  <div class=\"no-active-load-message\">\n    <h2>No active load</h2>\n  </div>\n</ng-template>\n"]}
83
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-load-single.component.js","sourceRoot":"","sources":["../../../../../../../../../../projects/ca-components/src/lib/components/ca-pickup-delivery-block/components/ca-load/components/ca-load-single/ca-load-single.component.ts","../../../../../../../../../../projects/ca-components/src/lib/components/ca-pickup-delivery-block/components/ca-load/components/ca-load-single/ca-load-single.component.html"],"names":[],"mappings":"AAAA,uBAAuB;AACvB,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AACxD,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,sBAAsB;AACtB,OAAO,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;AAMxD,YAAY;AACZ,OAAO,EAAE,uBAAuB,EAAE,MAAM,yDAAyD,CAAC;AAClG,OAAO,EAAE,2BAA2B,EAAE,MAAM,kDAAkD,CAAC;AAE/F,UAAU;AACV,OAAO,EAAE,mBAAmB,EAAE,MAAM,kDAAkD,CAAC;AACvF,OAAO,EAAE,4BAA4B,EAAE,MAAM,yFAAyF,CAAC;AACvI,OAAO;AACP,OAAO,EAAE,kBAAkB,EAAE,MAAM,8CAA8C,CAAC;AAClF,OAAO,EAAE,kBAAkB,EAAE,MAAM,+CAA+C,CAAC;AAEnF,OAAO;AACP,OAAO,EAAE,cAAc,EAAE,MAAM,kEAAkE,CAAC;;;;;AAmBlG,MAAM,OAAO,mBAAmB;IAa9B,YAAmB,kBAAsC;QAAtC,uBAAkB,GAAlB,kBAAkB,CAAoB;QATzD,OAAO;QACA,iBAAY,GAAW,2BAA2B,CAAC,cAAc,CAAC;QAClE,kBAAa,GAAW,2BAA2B,CAAC,cAAc,CAAC;QACnE,gBAAW,GAAW,IAAI,CAAC,YAAY,CAAC;QAE/C,kBAAkB;QACX,sBAAiB,GAAY,KAAK,CAAC;IAGkB,CAAC;IAE7D,QAAQ;QACN,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC5B,CAAC;IAEO,kBAAkB;QACxB,QAAQ,IAAI,CAAC,MAAM,EAAE;YACnB,KAAK,cAAc,CAAC,MAAM;gBACxB,IAAI,CAAC,eAAe,GAAG,4BAA4B,CAAC,aAAa,CAAC;gBAClE,MAAM;YACR,KAAK,cAAc,CAAC,MAAM;gBACxB,IAAI,CAAC,eAAe,GAAG,4BAA4B,CAAC,aAAa,CAAC;gBAClE,MAAM;YACR,KAAK,cAAc,CAAC,OAAO;gBACzB,IAAI,CAAC,eAAe,GAAG,4BAA4B,CAAC,cAAc,CAAC;gBACnE,MAAM;YACR;gBACE,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;gBAC1B,MAAM;SACT;IACH,CAAC;IAEM,kBAAkB;QACvB,IAAI,CAAC,iBAAiB,GAAG,CAAC,IAAI,CAAC,iBAAiB,CAAC;QACjD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,iBAAiB;YACvC,CAAC,CAAC,IAAI,CAAC,aAAa;YACpB,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC;IACxB,CAAC;IAEM,UAAU,CACf,YAAkD;QAElD,OAAO,uBAAuB,CAAC,YAAY,CAAW,CAAC;IACzD,CAAC;+GA/CU,mBAAmB;mGAAnB,mBAAmB,yHAZnB;YACT,OAAO;YACP,kBAAkB;SACnB,0BCjCH,6kJAuIA,w05KDpGI,oBAAoB,gOACpB,gBAAgB,+BAChB,mBAAmB,+HACnB,YAAY,8HACZ,kBAAkB;;4FAGT,mBAAmB;kBAjB/B,SAAS;+BACE,oBAAoB,cAGlB,IAAI,aACL;wBACT,OAAO;wBACP,kBAAkB;qBACnB,WACQ;wBACP,oBAAoB;wBACpB,gBAAgB;wBAChB,mBAAmB;wBACnB,YAAY;wBACZ,kBAAkB;qBACnB;yGAGQ,UAAU;sBAAlB,KAAK;gBACG,MAAM;sBAAd,KAAK","sourcesContent":["// Angular core modules\nimport { Component, Input } from '@angular/core';\nimport { HttpClientModule } from '@angular/common/http';\nimport { CommonModule } from '@angular/common';\n// Third-party modules\nimport { AngularSvgIconModule } from 'angular-svg-icon';\n\n// Models\nimport { LoadShortResponse } from '../../../../../ca-pickup-delivery-block/models/load-short-response';\nimport { IItemList } from '../../../../../../models/dropdown.model';\n\n//Svg routes\nimport { PickupDeliverySvgRoutes } from '../../../../utils/svg-routes/pickup-delivery-svg.routes';\nimport { OptionsButtonIconsSvgRoutes } from '../../../../utils/svg-routes/options-icon.routes';\n\n//Dropdown\nimport { CaDropdownComponent } from '../../../../../ca-dropdown/ca-dropdown.component';\nimport { PickupDeliveryBlockConstants } from '../../../../../ca-pickup-delivery-block/utils/constants/pickup-delivery-block.constants';\n//Pipes\nimport { FormatCurrencyPipe } from '../../../../../../pipes/format-currency.pipe';\nimport { DateFromStringPipe } from '../../../../../../pipes/date-from-string.pipe';\n\n//Enums\nimport { StatusTypeEnum } from '../../../../../ca-pickup-delivery-block/models/status-types.enum';\n\n@Component({\n  selector: 'app-ca-load-single',\n  templateUrl: './ca-load-single.component.html',\n  styleUrls: ['./ca-load-single.component.scss'],\n  standalone: true,\n  providers: [\n    //Pipes\n    FormatCurrencyPipe,\n  ],\n  imports: [\n    AngularSvgIconModule,\n    HttpClientModule,\n    CaDropdownComponent,\n    CommonModule,\n    DateFromStringPipe,\n  ],\n})\nexport class ActiveLoadComponent {\n  @Input() activeLoad!: Array<LoadShortResponse>;\n  @Input() status!: StatusTypeEnum;\n\n  //Icons\n  public originalIcon: string = OptionsButtonIconsSvgRoutes.optionsDefault;\n  public alternateIcon: string = OptionsButtonIconsSvgRoutes.optionsClicked;\n  public currentIcon: string = this.originalIcon;\n\n  //Dropdown options\n  public isDropdownEnabled: boolean = false;\n  public dropdownOptions!: IItemList[];\n\n  constructor(public formatCurrencyPipe: FormatCurrencyPipe) {}\n\n  ngOnInit() {\n    this.setDropdownOptions();\n  }\n\n  private setDropdownOptions(): void {\n    switch (this.status) {\n      case StatusTypeEnum.ACTIVE:\n        this.dropdownOptions = PickupDeliveryBlockConstants.activeOptions;\n        break;\n      case StatusTypeEnum.CLOSED:\n        this.dropdownOptions = PickupDeliveryBlockConstants.closedOptions;\n        break;\n      case StatusTypeEnum.PENDING:\n        this.dropdownOptions = PickupDeliveryBlockConstants.pendingOptions;\n        break;\n      default:\n        this.dropdownOptions = [];\n        break;\n    }\n  }\n\n  public dropDownClickEvent() {\n    this.isDropdownEnabled = !this.isDropdownEnabled;\n    this.currentIcon = this.isDropdownEnabled\n      ? this.alternateIcon\n      : this.originalIcon;\n  }\n\n  public getSvgPath(\n    propertyName: keyof typeof PickupDeliverySvgRoutes\n  ): string {\n    return PickupDeliverySvgRoutes[propertyName] as string;\n  }\n}\n","<ng-container *ngIf=\"activeLoad && activeLoad.length; else noActiveLoad\">\n  <div class=\"load-details d-flex\">\n    <div class=\"details-container d-flex flex-column justify-content-between\">\n      <div class=\"top-details d-flex justify-content-between\">\n        <span class=\"price ca-font-medium\">\n          LOAD {{ activeLoad[0].loadNumber }}\n          <svg-icon\n            [src]=\"getSvgPath('vector')\"\n            [svgStyle]=\"{ 'width.px': 18 }\"\n          ></svg-icon>\n        </span>\n        <span class=\"load ca-font-bold\">{{\n          formatCurrencyPipe.transform(activeLoad[0].totalRate!)\n        }}</span>\n      </div>\n\n      <div class=\"bottom-details d-flex justify-content-between\">\n        <p class=\"miles-ref\">\n          <svg-icon\n            [src]=\"getSvgPath('miles')\"\n            [svgStyle]=\"{ 'width.px': 14 }\"\n          ></svg-icon>\n          {{ activeLoad[0].totalMiles }}\n          <span class=\"ref-text ca-font-bold\">Ref.</span>\n          {{ activeLoad[0].referenceNumber }}\n        </p>\n        <p class=\"ca-font-bold\">\n          Adj.\n          <span class=\"adj-price\">{{\n            formatCurrencyPipe.transform(activeLoad[0].totalAdjustedRate!)\n          }}</span>\n        </p>\n      </div>\n    </div>\n\n    <div class=\"d-flex flex-column button-container align-items-start\">\n      <app-ca-dropdown\n        [icon]=\"currentIcon\"\n        [itemList]=\"dropdownOptions\"\n        (onClick)=\"dropDownClickEvent()\"\n        [isPopupShown]=\"isDropdownEnabled\"\n      ></app-ca-dropdown>\n    </div>\n  </div>\n\n  <div class=\"stops d-flex justify-content-around\">\n    <div class=\"stops-side d-flex align-items-center\">\n      <span class=\"line-left d-flex justify-content-center align-items-center\">\n        {{ activeLoad[0].pickupCount }}\n      </span>\n      <div class=\"date-location left d-flex flex-column align-items-start\">\n        <span class=\"location ca-font-semi-bold\">\n          {{ activeLoad[0].pickup?.shipper?.address?.city }},\n          {{ activeLoad[0].pickup?.shipper?.address?.state }}\n        </span>\n        <span class=\"date ca-font-regular\">{{\n          activeLoad[0].pickup?.dateFrom | dateFromStringPipe\n        }}</span>\n      </div>\n    </div>\n\n    <span class=\"arrow d-flex justify-content-center align-items-center\">\n      <svg-icon\n        [src]=\"getSvgPath('arrowRight')\"\n        [svgStyle]=\"{ 'width.px': 14 }\"\n      ></svg-icon>\n    </span>\n\n    <div class=\"stops-side right d-flex align-items-center\">\n      <div class=\"date-location right d-flex flex-column align-items-start\">\n        <span class=\"location ca-font-semi-bold\">\n          {{ activeLoad[0].delivery?.shipper?.address?.city }},\n          {{ activeLoad[0].delivery?.shipper?.address?.state }}\n        </span>\n        <span class=\"date ca-font-regular\">{{\n          activeLoad[0].delivery?.dateFrom | dateFromStringPipe\n        }}</span>\n      </div>\n      <span class=\"line-right d-flex justify-content-center align-items-center\">\n        {{ activeLoad[0].deliveryCount }}\n      </span>\n    </div>\n  </div>\n\n  <div class=\"dispatch-stops\">\n    <span class=\"bussiness-name ca-font-bold\">{{\n      activeLoad[0].broker?.businessName\n    }}</span>\n\n    <div class=\"broker ca-font-regular\">\n      <ng-container *ngIf=\"activeLoad[0].broker?.contactName\">\n        <p>\n          <svg-icon\n            [src]=\"getSvgPath('userIcon')\"\n            [svgStyle]=\"{ 'width.px': 16 }\"\n          ></svg-icon>\n          {{ activeLoad[0].broker?.contactName }}\n        </p>\n      </ng-container>\n      <ng-container *ngIf=\"activeLoad[0].broker?.phone\">\n        <p>\n          <svg-icon\n            [src]=\"getSvgPath('phoneIcon')\"\n            [svgStyle]=\"{ 'width.px': 16 }\"\n          ></svg-icon>\n          {{ activeLoad[0].broker?.phone }}\n        </p>\n      </ng-container>\n      <ng-container *ngIf=\"activeLoad[0].broker?.email\">\n        <p>\n          <svg-icon\n            [src]=\"getSvgPath('mailIcon')\"\n            [svgStyle]=\"{ 'width.px': 16 }\"\n          ></svg-icon>\n          {{ activeLoad[0].broker?.email }}\n        </p>\n      </ng-container>\n    </div>\n  </div>\n\n  <ng-container *ngIf=\"status === 'ACTIVE'\">\n    <div class=\"driverMessage\">\n      <h3 class=\"ca-font-bold\">DRIVER MESSAGE</h3>\n      <span class=\"message ca-font-regular\">{{\n        activeLoad[0].driverMessage\n      }}</span>\n    </div>\n  </ng-container>\n</ng-container>\n\n<ng-template #noActiveLoad>\n  <div class=\"no-active-load-message\">\n    <h2>No active load</h2>\n  </div>\n</ng-template>\n"]}