ca-components 0.0.53 → 0.0.54
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.
|
@@ -11,8 +11,8 @@ import { CaProfileImageComponent } from '../../../ca-profile-image/ca-profile-im
|
|
|
11
11
|
import { CaAppTooltipV2Component } from '../../../ca-app-tooltip-v2/ca-app-tooltip-v2.component';
|
|
12
12
|
//enums
|
|
13
13
|
import { RatingReviewsEnum } from '../../enums/rating-reviews-type.enums';
|
|
14
|
-
//pipes
|
|
15
|
-
import { DateFormatPipe } from '
|
|
14
|
+
//pipes
|
|
15
|
+
import { DateFormatPipe } from '../../../../pipes/date.pipe';
|
|
16
16
|
import * as i0 from "@angular/core";
|
|
17
17
|
import * as i1 from "@angular/forms";
|
|
18
18
|
import * as i2 from "@angular/common";
|
|
@@ -149,4 +149,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
149
149
|
}], ratingReviewData: [{
|
|
150
150
|
type: Output
|
|
151
151
|
}] } });
|
|
152
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-rating-review-user.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ca-components/src/lib/components/ca-rating-review/components/ca-rating-review-user/ca-rating-review-user.component.ts","../../../../../../../../projects/ca-components/src/lib/components/ca-rating-review/components/ca-rating-review-user/ca-rating-review-user.component.html"],"names":[],"mappings":"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","sourcesContent":["\nimport { CommonModule } from '@angular/common';\nimport { HttpClientModule } from '@angular/common/http';\nimport {\n    Component,\n    Input,\n    ViewChild,\n    ChangeDetectorRef,\n    ElementRef,\n    QueryList,\n    ViewChildren,\n    OnInit,\n    Output,\n    EventEmitter,\n} from '@angular/core';\nimport { NgbModule, NgbTooltipModule } from '@ng-bootstrap/ng-bootstrap';\nimport { AngularSvgIconModule } from 'angular-svg-icon';\nimport {\n    FormsModule,\n    FormGroup,\n    FormBuilder,\n    FormControl,\n    ReactiveFormsModule,\n} from '@angular/forms';\n\n//routes\nimport { RatingReviewsRoutes } from '../../utils/svg-routes/ratings-reviews.routes';\n\n//components\n\nimport { CaProfileImageComponent } from '../../../ca-profile-image/ca-profile-image.component';\nimport { CaAppTooltipV2Component } from '../../../ca-app-tooltip-v2/ca-app-tooltip-v2.component';\n//models\nimport { RatingReviewModel } from '../../models/rating-review.model';\n\n//enums\nimport { RatingReviewsEnum } from '../../enums/rating-reviews-type.enums';\n\n//pipes\nimport { DateFormatPipe } from 'projects/ca-components/src/lib/pipes/date.pipe';\n\n\n@Component({\n    selector: 'app-ca-rating-review-user',\n    templateUrl: './ca-rating-review-user.component.html',\n    styleUrls: ['./ca-rating-review-user.component.scss'],\n    standalone: true,\n    imports: [\n        // modules\n        CommonModule,\n        HttpClientModule,\n        NgbModule,\n        FormsModule,\n        AngularSvgIconModule,\n        NgbTooltipModule,\n        ReactiveFormsModule,\n\n        //components\n        CaAppTooltipV2Component,\n        CaProfileImageComponent,\n\n        //pipes\n        DateFormatPipe,\n    ],\n})\nexport class CaRatingReviewUserComponent implements OnInit {\n    @ViewChildren('reviewMessage') reviewMessageRef!: QueryList<ElementRef>;\n    @ViewChild('content') contentElement!: ElementRef;\n    @Input() isRating?: boolean;\n    @Input() isNewReview?: boolean;\n    @Input() isFilter?: boolean;\n    @Input() data!: RatingReviewModel;\n    @Output() ratingReviewData = new EventEmitter<any>();\n\n    public reviewForm!: FormGroup;\n    public isEdit!: boolean;\n    public isExpanded: boolean = false;\n    public isOverflowing: boolean = false;\n\n    constructor(private cdr: ChangeDetectorRef, private fb: FormBuilder) {}\n\n    ngOnInit(): void {\n        this.createForm();\n    }\n\n    ngAfterViewInit() {\n        this.checkOverflow();\n    }\n\n    public createForm(): void {\n        this.reviewForm = this.fb.group({\n            reviewMessage: new FormControl(this.data?.comment || ''),\n            reaction: new FormControl(this.data?.thumb || null),\n        });\n    }\n\n    public getSvgPath(propertyName: keyof typeof RatingReviewsRoutes): string {\n        return RatingReviewsRoutes[propertyName] as string;\n    }\n\n    get reviewMessageControl(): FormControl {\n        return this.reviewForm.get(\n            RatingReviewsEnum.REVIEW_MESSAGE\n        ) as FormControl;\n    }\n\n    get reactionControl(): FormControl {\n        return this.reviewForm.get(RatingReviewsEnum.REACTION) as FormControl;\n    }\n\n    public checkOverflow(): void {\n        if (this.data?.comment) {\n            const content = this.contentElement.nativeElement;\n            this.isOverflowing = content.scrollWidth > content.clientWidth;\n            this.cdr.detectChanges();\n        }\n    }\n\n    public toggleExpand(): void {\n        this.isExpanded = !this.isExpanded;\n    }\n\n    public toggleReaction(reactionValue: number): void {\n        const currentReaction = this.reactionControl.value;\n\n        if (currentReaction === reactionValue) {\n            this.reactionControl.setValue(null);\n        } else {\n            this.reactionControl.setValue(reactionValue);\n        }\n    }\n\n    public editData(): void {\n        this.isEdit = !this.isEdit;\n\n        if (this.isEdit) {\n            this.reviewForm.patchValue({\n                reviewMessage: this.data?.comment || '',\n                reaction: this.data?.thumb || null,\n            });\n        }\n\n        this.ratingReviewData.emit({\n            action: RatingReviewsEnum.SAVE,\n            data: this.data,\n        });\n    }\n\n    public saveReview(): void {\n        if (this.reviewForm.valid) {\n            const updatedData = this.reviewForm.value;\n            this.data.comment = updatedData.reviewMessage;\n            this.data.thumb = updatedData.reaction;\n            this.data.updatedAt = new Date();\n            this.isEdit = false;\n            this.ratingReviewData.emit({\n                action: RatingReviewsEnum.SAVE,\n                data: this.data,\n            });\n        }\n    }\n\n    public deleteReview(): void {\n        this.ratingReviewData.emit({\n            action: RatingReviewsEnum.DELETE,\n            data: this.data,\n        });\n    }\n\n    public cancelReview(): void {\n        if (this.data.id) {\n            this.isEdit = false;\n        }\n    }\n\n    public saveComment(): void {\n        this.isEdit = false;\n    }\n}\n","<div\n  class=\"ta-user-review d-flex flex-column\"\n  [ngClass]=\"{\n    expanded: isOverflowing,\n    edit: (isEdit || isNewReview) && !isFilter,\n    'edit-dark': (isEdit || isNewReview) && isFilter,\n    darkText: isFilter,\n    whiteTex: !isFilter,\n  }\"\n  (click)=\"toggleExpand()\"\n>\n  <div\n    class=\"ta-user-information d-flex align-items-center justify-content-between\"\n  >\n    <div class=\"no-profile-image\">\n      <app-ca-profile-image\n        [avatarImg]=\"data?.user?.avatarImage\"\n        [size]=\"'small'\"\n        [isHoverEffect]=\"false\"\n      ></app-ca-profile-image>\n    </div>\n\n    <div class=\"ta-user-data d-flex\">\n      <div\n        class=\"ta-user-name-rating\"\n        [ngClass]=\"{ 'justify-content-between': isEdit }\"\n      >\n        <p\n          class=\"ta-user-fullname\"\n          [ngClass]=\"{\n            'ta-user-fullname-edit': isEdit && !isFilter,\n            darkText: isFilter && !isEdit,\n            'edit-dark': (isEdit || isNewReview) && isFilter,\n          }\"\n        >\n          {{ data?.user?.name }}\n          <ng-container *ngIf=\"data?.owner && !isEdit && !isNewReview\">\n            <span class=\"current-user\">(Me)</span>\n          </ng-container>\n        </p>\n\n        <ng-container *ngIf=\"!isEdit && !isNewReview && data?.thumb\">\n          <svg-icon\n            class=\"ta-user-reaction\"\n            [ngClass]=\"{ like: data?.thumb === 1, dislike: data?.thumb === -1 }\"\n            [src]=\"\n              data?.thumb === -1\n                ? getSvgPath('dislikeButton')\n                : getSvgPath('likesButton')\n            \"\n          ></svg-icon>\n        </ng-container>\n      </div>\n      <div class=\"ta-user-datetime\">\n        <ng-container *ngIf=\"isEdit || isNewReview; else showDate\">\n          <p class=\"edit-review\">\n            {{ isEdit ? 'Edit Review' : 'Posting Publicly' }}\n          </p>\n        </ng-container>\n        <ng-template #showDate>\n          <div class=\"ta-user-date\">\n            {{ data?.updatedAt! | dateFormat }}\n          </div>\n        </ng-template>\n      </div>\n    </div>\n\n    <ng-container\n      *ngIf=\"\n        (data?.owner && ((isExpanded && isOverflowing) || !isOverflowing)) ||\n        isNewReview\n      \"\n    >\n      <div\n        class=\"ta-user-actions d-flex align-items-center justify-content-center\"\n        [ngClass]=\"{ 'd-flex': isEdit || isNewReview }\"\n      >\n        <ng-container *ngIf=\"isEdit || isNewReview\">\n          <div class=\"ta-user-actions-reaction d-flex justify-content-between\">\n            <div\n              class=\"ta-user-reaction\"\n              ngbTooltip\n              [mainTooltip]=\"\n                reactionControl.value === 1 ? ' Remove Like' : ' like'\n              \"\n              position=\"top\"\n              tooltipBackground=\"#CCCCCC\"\n              [ngClass]=\"{ like: reactionControl.value === 1 }\"\n            >\n              <svg-icon\n                [src]=\"getSvgPath('likesButton')\"\n                (click)=\"toggleReaction(1)\"\n              >\n              </svg-icon>\n            </div>\n            <div\n              class=\"ta-user-reaction\"\n              ngbTooltip\n              [mainTooltip]=\"\n                reactionControl.value === -1 ? 'Remove Dislike' : ' Dislike'\n              \"\n              position=\"top\"\n              tooltipBackground=\"#CCCCCC\"\n              [ngClass]=\"{ dislike: reactionControl.value === -1 }\"\n            >\n              <svg-icon\n                [src]=\"getSvgPath('dislikeButton')\"\n                (click)=\"toggleReaction(-1)\"\n              >\n              </svg-icon>\n            </div>\n          </div>\n        </ng-container>\n        <div\n          ngbTooltip\n          [mainTooltip]=\"isEdit ? 'Post Review' : 'Edit'\"\n          position=\"top\"\n          tooltipBackground=\"#CCCCCC\"\n          class=\"action-edit\"\n        >\n          <svg-icon\n            [src]=\"\n              isEdit || isNewReview ? getSvgPath('confirm') : getSvgPath('pen')\n            \"\n            (click)=\"isEdit || isNewReview ? saveReview() : editData()\"\n          ></svg-icon>\n        </div>\n        <div\n          ngbTooltip\n          [mainTooltip]=\"isNewReview || isEdit ? 'Cancel' : 'Delete'\"\n          position=\"top\"\n          [tooltipBackground]=\"isNewReview || isEdit ? '#CCCCCC' : '#EF5350'\"\n          [ngClass]=\"isEdit || isNewReview ? 'action-cancel' : 'action-delete'\"\n        >\n          <svg-icon\n            [src]=\"\n              isEdit || isNewReview ? getSvgPath('cancel') : getSvgPath('trash')\n            \"\n            (click)=\"isEdit || isNewReview ? cancelReview() : deleteReview()\"\n          ></svg-icon>\n        </div>\n      </div>\n    </ng-container>\n    <ng-container *ngIf=\"isOverflowing\">\n      <svg-icon\n        class=\"colaps\"\n        [ngStyle]=\"{\n          transform: isExpanded ? 'rotate(180deg)' : 'rotate(0deg)',\n        }\"\n        [src]=\"getSvgPath('colaps')\"\n      ></svg-icon>\n    </ng-container>\n  </div>\n\n  <ng-container *ngIf=\"isEdit || isNewReview; else displayComment\">\n    <div class=\"textarea\">\n      <textarea\n        #reviewMessage\n        class=\"review-textarea\"\n        [ngClass]=\"{ 'edit-dark': (isEdit || isNewReview) && isFilter }\"\n        [formControl]=\"reviewMessageControl\"\n      ></textarea>\n    </div>\n  </ng-container>\n\n  <ng-template #displayComment>\n    <ng-container *ngIf=\"data.comment\">\n      <div\n        class=\"review d-flex\"\n        [ngClass]=\"{ expanded: isExpanded, darkText: isFilter }\"\n        [style.height]=\"isExpanded ? 'auto' : '18px'\"\n        #content\n      >\n        {{ data.comment }}\n      </div>\n    </ng-container>\n  </ng-template>\n</div>\n"]}
|
|
152
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-rating-review-user.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ca-components/src/lib/components/ca-rating-review/components/ca-rating-review-user/ca-rating-review-user.component.ts","../../../../../../../../projects/ca-components/src/lib/components/ca-rating-review/components/ca-rating-review-user/ca-rating-review-user.component.html"],"names":[],"mappings":"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","sourcesContent":["\nimport { CommonModule } from '@angular/common';\nimport { HttpClientModule } from '@angular/common/http';\nimport {\n    Component,\n    Input,\n    ViewChild,\n    ChangeDetectorRef,\n    ElementRef,\n    QueryList,\n    ViewChildren,\n    OnInit,\n    Output,\n    EventEmitter,\n} from '@angular/core';\nimport { NgbModule, NgbTooltipModule } from '@ng-bootstrap/ng-bootstrap';\nimport { AngularSvgIconModule } from 'angular-svg-icon';\nimport {\n    FormsModule,\n    FormGroup,\n    FormBuilder,\n    FormControl,\n    ReactiveFormsModule,\n} from '@angular/forms';\n\n//routes\nimport { RatingReviewsRoutes } from '../../utils/svg-routes/ratings-reviews.routes';\n\n//components\n\nimport { CaProfileImageComponent } from '../../../ca-profile-image/ca-profile-image.component';\nimport { CaAppTooltipV2Component } from '../../../ca-app-tooltip-v2/ca-app-tooltip-v2.component';\n//models\nimport { RatingReviewModel } from '../../models/rating-review.model';\n\n//enums\nimport { RatingReviewsEnum } from '../../enums/rating-reviews-type.enums';\n\n//pipes \nimport { DateFormatPipe } from '../../../../pipes/date.pipe';\n\n@Component({\n    selector: 'app-ca-rating-review-user',\n    templateUrl: './ca-rating-review-user.component.html',\n    styleUrls: ['./ca-rating-review-user.component.scss'],\n    standalone: true,\n    imports: [\n        // modules\n        CommonModule,\n        HttpClientModule,\n        NgbModule,\n        FormsModule,\n        AngularSvgIconModule,\n        NgbTooltipModule,\n        ReactiveFormsModule,\n\n        //components\n        CaAppTooltipV2Component,\n        CaProfileImageComponent,\n\n        //pipes\n        DateFormatPipe,\n    ],\n})\nexport class CaRatingReviewUserComponent implements OnInit {\n    @ViewChildren('reviewMessage') reviewMessageRef!: QueryList<ElementRef>;\n    @ViewChild('content') contentElement!: ElementRef;\n    @Input() isRating?: boolean;\n    @Input() isNewReview?: boolean;\n    @Input() isFilter?: boolean;\n    @Input() data!: RatingReviewModel;\n    @Output() ratingReviewData = new EventEmitter<any>();\n\n    public reviewForm!: FormGroup;\n    public isEdit!: boolean;\n    public isExpanded: boolean = false;\n    public isOverflowing: boolean = false;\n\n    constructor(private cdr: ChangeDetectorRef, private fb: FormBuilder) {}\n\n    ngOnInit(): void {\n        this.createForm();\n    }\n\n    ngAfterViewInit() {\n        this.checkOverflow();\n    }\n\n    public createForm(): void {\n        this.reviewForm = this.fb.group({\n            reviewMessage: new FormControl(this.data?.comment || ''),\n            reaction: new FormControl(this.data?.thumb || null),\n        });\n    }\n\n    public getSvgPath(propertyName: keyof typeof RatingReviewsRoutes): string {\n        return RatingReviewsRoutes[propertyName] as string;\n    }\n\n    get reviewMessageControl(): FormControl {\n        return this.reviewForm.get(\n            RatingReviewsEnum.REVIEW_MESSAGE\n        ) as FormControl;\n    }\n\n    get reactionControl(): FormControl {\n        return this.reviewForm.get(RatingReviewsEnum.REACTION) as FormControl;\n    }\n\n    public checkOverflow(): void {\n        if (this.data?.comment) {\n            const content = this.contentElement.nativeElement;\n            this.isOverflowing = content.scrollWidth > content.clientWidth;\n            this.cdr.detectChanges();\n        }\n    }\n\n    public toggleExpand(): void {\n        this.isExpanded = !this.isExpanded;\n    }\n\n    public toggleReaction(reactionValue: number): void {\n        const currentReaction = this.reactionControl.value;\n\n        if (currentReaction === reactionValue) {\n            this.reactionControl.setValue(null);\n        } else {\n            this.reactionControl.setValue(reactionValue);\n        }\n    }\n\n    public editData(): void {\n        this.isEdit = !this.isEdit;\n\n        if (this.isEdit) {\n            this.reviewForm.patchValue({\n                reviewMessage: this.data?.comment || '',\n                reaction: this.data?.thumb || null,\n            });\n        }\n\n        this.ratingReviewData.emit({\n            action: RatingReviewsEnum.SAVE,\n            data: this.data,\n        });\n    }\n\n    public saveReview(): void {\n        if (this.reviewForm.valid) {\n            const updatedData = this.reviewForm.value;\n            this.data.comment = updatedData.reviewMessage;\n            this.data.thumb = updatedData.reaction;\n            this.data.updatedAt = new Date();\n            this.isEdit = false;\n            this.ratingReviewData.emit({\n                action: RatingReviewsEnum.SAVE,\n                data: this.data,\n            });\n        }\n    }\n\n    public deleteReview(): void {\n        this.ratingReviewData.emit({\n            action: RatingReviewsEnum.DELETE,\n            data: this.data,\n        });\n    }\n\n    public cancelReview(): void {\n        if (this.data.id) {\n            this.isEdit = false;\n        }\n    }\n\n    public saveComment(): void {\n        this.isEdit = false;\n    }\n}\n","<div\n  class=\"ta-user-review d-flex flex-column\"\n  [ngClass]=\"{\n    expanded: isOverflowing,\n    edit: (isEdit || isNewReview) && !isFilter,\n    'edit-dark': (isEdit || isNewReview) && isFilter,\n    darkText: isFilter,\n    whiteTex: !isFilter,\n  }\"\n  (click)=\"toggleExpand()\"\n>\n  <div\n    class=\"ta-user-information d-flex align-items-center justify-content-between\"\n  >\n    <div class=\"no-profile-image\">\n      <app-ca-profile-image\n        [avatarImg]=\"data?.user?.avatarImage\"\n        [size]=\"'small'\"\n        [isHoverEffect]=\"false\"\n      ></app-ca-profile-image>\n    </div>\n\n    <div class=\"ta-user-data d-flex\">\n      <div\n        class=\"ta-user-name-rating\"\n        [ngClass]=\"{ 'justify-content-between': isEdit }\"\n      >\n        <p\n          class=\"ta-user-fullname\"\n          [ngClass]=\"{\n            'ta-user-fullname-edit': isEdit && !isFilter,\n            darkText: isFilter && !isEdit,\n            'edit-dark': (isEdit || isNewReview) && isFilter,\n          }\"\n        >\n          {{ data?.user?.name }}\n          <ng-container *ngIf=\"data?.owner && !isEdit && !isNewReview\">\n            <span class=\"current-user\">(Me)</span>\n          </ng-container>\n        </p>\n\n        <ng-container *ngIf=\"!isEdit && !isNewReview && data?.thumb\">\n          <svg-icon\n            class=\"ta-user-reaction\"\n            [ngClass]=\"{ like: data?.thumb === 1, dislike: data?.thumb === -1 }\"\n            [src]=\"\n              data?.thumb === -1\n                ? getSvgPath('dislikeButton')\n                : getSvgPath('likesButton')\n            \"\n          ></svg-icon>\n        </ng-container>\n      </div>\n      <div class=\"ta-user-datetime\">\n        <ng-container *ngIf=\"isEdit || isNewReview; else showDate\">\n          <p class=\"edit-review\">\n            {{ isEdit ? 'Edit Review' : 'Posting Publicly' }}\n          </p>\n        </ng-container>\n        <ng-template #showDate>\n          <div class=\"ta-user-date\">\n            {{ data?.updatedAt! | dateFormat }}\n          </div>\n        </ng-template>\n      </div>\n    </div>\n\n    <ng-container\n      *ngIf=\"\n        (data?.owner && ((isExpanded && isOverflowing) || !isOverflowing)) ||\n        isNewReview\n      \"\n    >\n      <div\n        class=\"ta-user-actions d-flex align-items-center justify-content-center\"\n        [ngClass]=\"{ 'd-flex': isEdit || isNewReview }\"\n      >\n        <ng-container *ngIf=\"isEdit || isNewReview\">\n          <div class=\"ta-user-actions-reaction d-flex justify-content-between\">\n            <div\n              class=\"ta-user-reaction\"\n              ngbTooltip\n              [mainTooltip]=\"\n                reactionControl.value === 1 ? ' Remove Like' : ' like'\n              \"\n              position=\"top\"\n              tooltipBackground=\"#CCCCCC\"\n              [ngClass]=\"{ like: reactionControl.value === 1 }\"\n            >\n              <svg-icon\n                [src]=\"getSvgPath('likesButton')\"\n                (click)=\"toggleReaction(1)\"\n              >\n              </svg-icon>\n            </div>\n            <div\n              class=\"ta-user-reaction\"\n              ngbTooltip\n              [mainTooltip]=\"\n                reactionControl.value === -1 ? 'Remove Dislike' : ' Dislike'\n              \"\n              position=\"top\"\n              tooltipBackground=\"#CCCCCC\"\n              [ngClass]=\"{ dislike: reactionControl.value === -1 }\"\n            >\n              <svg-icon\n                [src]=\"getSvgPath('dislikeButton')\"\n                (click)=\"toggleReaction(-1)\"\n              >\n              </svg-icon>\n            </div>\n          </div>\n        </ng-container>\n        <div\n          ngbTooltip\n          [mainTooltip]=\"isEdit ? 'Post Review' : 'Edit'\"\n          position=\"top\"\n          tooltipBackground=\"#CCCCCC\"\n          class=\"action-edit\"\n        >\n          <svg-icon\n            [src]=\"\n              isEdit || isNewReview ? getSvgPath('confirm') : getSvgPath('pen')\n            \"\n            (click)=\"isEdit || isNewReview ? saveReview() : editData()\"\n          ></svg-icon>\n        </div>\n        <div\n          ngbTooltip\n          [mainTooltip]=\"isNewReview || isEdit ? 'Cancel' : 'Delete'\"\n          position=\"top\"\n          [tooltipBackground]=\"isNewReview || isEdit ? '#CCCCCC' : '#EF5350'\"\n          [ngClass]=\"isEdit || isNewReview ? 'action-cancel' : 'action-delete'\"\n        >\n          <svg-icon\n            [src]=\"\n              isEdit || isNewReview ? getSvgPath('cancel') : getSvgPath('trash')\n            \"\n            (click)=\"isEdit || isNewReview ? cancelReview() : deleteReview()\"\n          ></svg-icon>\n        </div>\n      </div>\n    </ng-container>\n    <ng-container *ngIf=\"isOverflowing\">\n      <svg-icon\n        class=\"colaps\"\n        [ngStyle]=\"{\n          transform: isExpanded ? 'rotate(180deg)' : 'rotate(0deg)',\n        }\"\n        [src]=\"getSvgPath('colaps')\"\n      ></svg-icon>\n    </ng-container>\n  </div>\n\n  <ng-container *ngIf=\"isEdit || isNewReview; else displayComment\">\n    <div class=\"textarea\">\n      <textarea\n        #reviewMessage\n        class=\"review-textarea\"\n        [ngClass]=\"{ 'edit-dark': (isEdit || isNewReview) && isFilter }\"\n        [formControl]=\"reviewMessageControl\"\n      ></textarea>\n    </div>\n  </ng-container>\n\n  <ng-template #displayComment>\n    <ng-container *ngIf=\"data.comment\">\n      <div\n        class=\"review d-flex\"\n        [ngClass]=\"{ expanded: isExpanded, darkText: isFilter }\"\n        [style.height]=\"isExpanded ? 'auto' : '18px'\"\n        #content\n      >\n        {{ data.comment }}\n      </div>\n    </ng-container>\n  </ng-template>\n</div>\n"]}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
2
|
import { Component, Input, TemplateRef, Host, ViewChild, EventEmitter, ViewEncapsulation, ChangeDetectionStrategy, Output, Pipe, Directive, HostListener, Injectable, Inject, forwardRef, ViewContainerRef, CUSTOM_ELEMENTS_SCHEMA, Self, ViewChildren, NgModule } from '@angular/core';
|
|
3
3
|
import * as i1 from '@angular/common';
|
|
4
|
-
import { CommonModule } from '@angular/common';
|
|
4
|
+
import { CommonModule, DatePipe } from '@angular/common';
|
|
5
5
|
import * as i3 from '@ng-bootstrap/ng-bootstrap';
|
|
6
6
|
import { NgbModule, NgbPopover, NgbDropdownConfig, NgbPopoverModule, NgbTooltipModule, NgbNavModule } from '@ng-bootstrap/ng-bootstrap';
|
|
7
7
|
import * as i2 from 'angular-svg-icon';
|
|
@@ -27,7 +27,6 @@ import * as i2$2 from 'ngx-lottie';
|
|
|
27
27
|
import { LottieModule } from 'ngx-lottie';
|
|
28
28
|
import * as i4 from '@angular/cdk/drag-drop';
|
|
29
29
|
import { moveItemInArray, DragDropModule } from '@angular/cdk/drag-drop';
|
|
30
|
-
import { DateFormatPipe } from 'projects/ca-components/src/lib/pipes/date.pipe';
|
|
31
30
|
|
|
32
31
|
class CaProfileImageComponent {
|
|
33
32
|
constructor() {
|
|
@@ -14806,6 +14805,39 @@ var RatingReviewsEnum;
|
|
|
14806
14805
|
RatingReviewsEnum["REVIEWS"] = "reviews";
|
|
14807
14806
|
})(RatingReviewsEnum || (RatingReviewsEnum = {}));
|
|
14808
14807
|
|
|
14808
|
+
class DateFormatPipe {
|
|
14809
|
+
transform(value) {
|
|
14810
|
+
if (!value)
|
|
14811
|
+
return;
|
|
14812
|
+
const today = new Date();
|
|
14813
|
+
const yesterday = new Date(today);
|
|
14814
|
+
yesterday.setDate(yesterday.getDate() - 1);
|
|
14815
|
+
const timeFormat = new DatePipe('en-US').transform(value, 'HH:mm a');
|
|
14816
|
+
if (value.getFullYear() == today.getFullYear() &&
|
|
14817
|
+
value.getMonth() == today.getMonth() &&
|
|
14818
|
+
value.getDate() == today.getDate()) {
|
|
14819
|
+
return `Today, ${timeFormat}`;
|
|
14820
|
+
}
|
|
14821
|
+
else if (value.getFullYear() == yesterday.getFullYear() &&
|
|
14822
|
+
value.getMonth() == yesterday.getMonth() &&
|
|
14823
|
+
value.getDate() == yesterday.getDate()) {
|
|
14824
|
+
return `Yesterday, ${timeFormat}`;
|
|
14825
|
+
}
|
|
14826
|
+
else {
|
|
14827
|
+
return new DatePipe('en-US').transform(value, 'dd/MM/yyyy, HH:mm');
|
|
14828
|
+
}
|
|
14829
|
+
}
|
|
14830
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DateFormatPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
14831
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: DateFormatPipe, isStandalone: true, name: "dateFormat" }); }
|
|
14832
|
+
}
|
|
14833
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DateFormatPipe, decorators: [{
|
|
14834
|
+
type: Pipe,
|
|
14835
|
+
args: [{
|
|
14836
|
+
standalone: true,
|
|
14837
|
+
name: 'dateFormat',
|
|
14838
|
+
}]
|
|
14839
|
+
}] });
|
|
14840
|
+
|
|
14809
14841
|
class CaRatingReviewUserComponent {
|
|
14810
14842
|
constructor(cdr, fb) {
|
|
14811
14843
|
this.cdr = cdr;
|