@dropi/ui-components 1.0.12 → 1.0.13
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +55 -36
- package/dist/README.md +58 -38
- package/dist/components-source/accordion/accordion-item/accordion-item.component.d.ts +31 -0
- package/dist/components-source/accordion/accordion.component.d.ts +26 -0
- package/dist/components-source/alert/alert.component.d.ts +32 -0
- package/dist/components-source/alert-modal/alert-modal.component.d.ts +78 -0
- package/dist/components-source/alert-validation/alert-validation.component.d.ts +21 -0
- package/dist/components-source/badge/badge.component.d.ts +12 -0
- package/dist/components-source/beta-tag/beta-tag.component.d.ts +5 -0
- package/dist/components-source/breadcrumb/breadcrumb.component.d.ts +11 -0
- package/dist/components-source/card-product/card-product.component.d.ts +204 -0
- package/dist/components-source/card-section/card-section.component.d.ts +31 -0
- package/dist/components-source/checkbox-selection-list/checkbox-selection-list.component.d.ts +26 -0
- package/dist/components-source/city-selector/city-selector.component.d.ts +17 -0
- package/dist/components-source/color-picker/color-picker.component.d.ts +73 -0
- package/dist/components-source/confirm-dialog/confirm-dialog.component.d.ts +10 -0
- package/dist/components-source/country-flags/country-flags.component.d.ts +12 -0
- package/dist/components-source/date-picker/date-picker.component.d.ts +27 -0
- package/dist/components-source/date-picker-range/date-picker-range.component.d.ts +26 -0
- package/dist/components-source/dropi-avatars/dropi-avatars.component.d.ts +11 -0
- package/dist/components-source/dropi-badge/dropi-badge.component.d.ts +29 -0
- package/dist/components-source/dropi-banner-external/dropi-banner-external.component.d.ts +19 -0
- package/dist/components-source/dropi-breadcrumb/dropi-breadcrumb.component.d.ts +22 -0
- package/dist/components-source/dropi-card-checkbox/dropi-card-checkbox.component.d.ts +20 -0
- package/dist/components-source/dropi-carousel/dropi-carousel.component.d.ts +52 -0
- package/dist/components-source/dropi-checkbox/dropi-checkbox.component.d.ts +11 -0
- package/dist/components-source/dropi-chips/dropi-chips.component.d.ts +17 -0
- package/dist/components-source/dropi-country-selector/countries.data.d.ts +6 -0
- package/dist/components-source/dropi-country-selector/dropi-country-selector.component.d.ts +90 -0
- package/dist/components-source/dropi-drawer/dropi-drawer.component.d.ts +20 -0
- package/dist/components-source/dropi-dropdown/dropi-dropdown.component.d.ts +20 -0
- package/dist/components-source/dropi-favorite-button/dropi-favorite-button.component.d.ts +12 -0
- package/dist/components-source/dropi-file-upload/card-view/card-view.component.d.ts +19 -0
- package/dist/components-source/dropi-file-upload/drop-zone/drop-zone.component.d.ts +38 -0
- package/dist/components-source/dropi-file-upload/dropi-file-upload.component.d.ts +18 -0
- package/dist/components-source/dropi-file-upload/file-list/file-list.component.d.ts +39 -0
- package/dist/components-source/dropi-file-upload/grid-view/grid-view.component.d.ts +15 -0
- package/dist/components-source/dropi-ilustration-icon/dropi-ilustration-icon.component.d.ts +20 -0
- package/dist/components-source/dropi-image-overlay/dropi-image-overlay.component.d.ts +8 -0
- package/dist/components-source/dropi-languages-selector/dropi-languages-selector.component.d.ts +18 -0
- package/dist/components-source/dropi-logo/dropi-logo.component.d.ts +12 -0
- package/dist/components-source/dropi-modal/dropi-modal.component.d.ts +34 -0
- package/dist/components-source/dropi-modal/p-template.directive.d.ts +9 -0
- package/dist/components-source/dropi-navbar/dropi-navbar.component.d.ts +20 -0
- package/dist/components-source/dropi-paginator/dropi-paginator.component.d.ts +21 -0
- package/dist/components-source/dropi-phone-input/dropi-phone-input.component.d.ts +55 -0
- package/dist/components-source/dropi-radio-button/dropi-radio-button.component.d.ts +17 -0
- package/dist/components-source/dropi-search/dropi-search.component.d.ts +40 -0
- package/dist/components-source/dropi-select/dropi-select.component.d.ts +34 -0
- package/dist/components-source/dropi-skeleton/dropi-skeleton.component.d.ts +14 -0
- package/dist/components-source/dropi-steps/dropi-steps.component.d.ts +64 -0
- package/dist/components-source/dropi-switch/dropi-switch.component.d.ts +11 -0
- package/dist/components-source/dropi-table/dropi-table.component.d.ts +82 -0
- package/dist/components-source/dropi-tag/dropi-tag.component.d.ts +15 -0
- package/dist/components-source/dropi-text-area/dropi-text-area.component.d.ts +14 -0
- package/dist/components-source/dropi-tooltip/dropi-tooltip.component.d.ts +28 -0
- package/dist/components-source/dropi-youtube-lazy-video/dropi-youtube-lazy-video.component.d.ts +16 -0
- package/dist/components-source/empty/empty.component.d.ts +9 -0
- package/dist/components-source/empty-state/empty-state.component.d.ts +17 -0
- package/dist/components-source/file-upload-progress-bar/file-upload-progress-bar.component.d.ts +30 -0
- package/dist/components-source/index.d.ts +85 -0
- package/dist/components-source/input/input.component.d.ts +33 -0
- package/dist/components-source/lottie-loader/lottie-loader.component.d.ts +9 -0
- package/dist/components-source/otp-send-code/otp-send-code.component.d.ts +83 -0
- package/dist/components-source/radio-selection-list/radio-selection-list.component.d.ts +30 -0
- package/dist/components-source/read-more/read-more.component.d.ts +60 -0
- package/dist/components-source/sidebar/sidebar.component.d.ts +27 -0
- package/dist/components-source/simple-stepper/simple-stepper.component.d.ts +21 -0
- package/dist/components-source/spinner/spinner.component.d.ts +9 -0
- package/dist/components-source/tabs/tabs.component.d.ts +27 -0
- package/dist/components-source/tag-type-product/tag-type-product.component.d.ts +5 -0
- package/dist/components-source/toast/toast.component.d.ts +21 -0
- package/dist/components-source/toggle/input-toggle.component.d.ts +11 -0
- package/dist/components-source/tooltip/tooltip.component.d.ts +15 -0
- package/dist/components-source/vertical-steps/vertical-steps.component.d.ts +27 -0
- package/dist/esm2022/components-source/accordion/accordion-item/accordion-item.component.mjs +51 -0
- package/dist/esm2022/components-source/accordion/accordion.component.mjs +46 -0
- package/dist/esm2022/components-source/alert/alert.component.mjs +114 -0
- package/dist/esm2022/components-source/alert-modal/alert-modal.component.mjs +247 -0
- package/dist/esm2022/components-source/alert-validation/alert-validation.component.mjs +53 -0
- package/dist/esm2022/components-source/badge/badge.component.mjs +23 -0
- package/dist/esm2022/components-source/beta-tag/beta-tag.component.mjs +11 -0
- package/dist/esm2022/components-source/breadcrumb/breadcrumb.component.mjs +26 -0
- package/dist/esm2022/components-source/card-product/card-product.component.mjs +534 -0
- package/dist/esm2022/components-source/card-section/card-section.component.mjs +91 -0
- package/dist/esm2022/components-source/checkbox-selection-list/checkbox-selection-list.component.mjs +79 -0
- package/dist/esm2022/components-source/city-selector/city-selector.component.mjs +53 -0
- package/dist/esm2022/components-source/color-picker/color-picker.component.mjs +320 -0
- package/dist/esm2022/components-source/confirm-dialog/confirm-dialog.component.mjs +27 -0
- package/dist/esm2022/components-source/country-flags/country-flags.component.mjs +27 -0
- package/dist/esm2022/components-source/date-picker/date-picker.component.mjs +73 -0
- package/dist/esm2022/components-source/date-picker-range/date-picker-range.component.mjs +67 -0
- package/dist/esm2022/components-source/dropi-avatars/dropi-avatars.component.mjs +31 -0
- package/dist/esm2022/components-source/dropi-badge/dropi-badge.component.mjs +45 -0
- package/dist/esm2022/components-source/dropi-banner-external/dropi-banner-external.component.mjs +39 -0
- package/dist/esm2022/components-source/dropi-breadcrumb/dropi-breadcrumb.component.mjs +45 -0
- package/dist/esm2022/components-source/dropi-card-checkbox/dropi-card-checkbox.component.mjs +53 -0
- package/dist/esm2022/components-source/dropi-carousel/dropi-carousel.component.mjs +243 -0
- package/dist/esm2022/components-source/dropi-checkbox/dropi-checkbox.component.mjs +31 -0
- package/dist/esm2022/components-source/dropi-chips/dropi-chips.component.mjs +38 -0
- package/dist/esm2022/components-source/dropi-country-selector/countries.data.mjs +254 -0
- package/dist/esm2022/components-source/dropi-country-selector/dropi-country-selector.component.mjs +183 -0
- package/dist/esm2022/components-source/dropi-drawer/dropi-drawer.component.mjs +69 -0
- package/dist/esm2022/components-source/dropi-dropdown/dropi-dropdown.component.mjs +59 -0
- package/dist/esm2022/components-source/dropi-favorite-button/dropi-favorite-button.component.mjs +33 -0
- package/dist/esm2022/components-source/dropi-file-upload/card-view/card-view.component.mjs +47 -0
- package/dist/esm2022/components-source/dropi-file-upload/drop-zone/drop-zone.component.mjs +115 -0
- package/dist/esm2022/components-source/dropi-file-upload/dropi-file-upload.component.mjs +66 -0
- package/dist/esm2022/components-source/dropi-file-upload/file-list/file-list.component.mjs +95 -0
- package/dist/esm2022/components-source/dropi-file-upload/grid-view/grid-view.component.mjs +37 -0
- package/dist/esm2022/components-source/dropi-ilustration-icon/dropi-ilustration-icon.component.mjs +59 -0
- package/dist/esm2022/components-source/dropi-image-overlay/dropi-image-overlay.component.mjs +31 -0
- package/dist/esm2022/components-source/dropi-languages-selector/dropi-languages-selector.component.mjs +38 -0
- package/dist/esm2022/components-source/dropi-logo/dropi-logo.component.mjs +27 -0
- package/dist/esm2022/components-source/dropi-modal/dropi-modal.component.mjs +92 -0
- package/dist/esm2022/components-source/dropi-modal/p-template.directive.mjs +22 -0
- package/dist/esm2022/components-source/dropi-navbar/dropi-navbar.component.mjs +51 -0
- package/dist/esm2022/components-source/dropi-paginator/dropi-paginator.component.mjs +89 -0
- package/dist/esm2022/components-source/dropi-phone-input/dropi-phone-input.component.mjs +155 -0
- package/dist/esm2022/components-source/dropi-radio-button/dropi-radio-button.component.mjs +48 -0
- package/dist/esm2022/components-source/dropi-search/dropi-search.component.mjs +104 -0
- package/dist/esm2022/components-source/dropi-select/dropi-select.component.mjs +96 -0
- package/dist/esm2022/components-source/dropi-skeleton/dropi-skeleton.component.mjs +39 -0
- package/dist/esm2022/components-source/dropi-steps/dropi-steps.component.mjs +97 -0
- package/dist/esm2022/components-source/dropi-switch/dropi-switch.component.mjs +22 -0
- package/dist/esm2022/components-source/dropi-table/dropi-table.component.mjs +333 -0
- package/dist/esm2022/components-source/dropi-tag/dropi-tag.component.mjs +36 -0
- package/dist/esm2022/components-source/dropi-text-area/dropi-text-area.component.mjs +53 -0
- package/dist/esm2022/components-source/dropi-tooltip/dropi-tooltip.component.mjs +78 -0
- package/dist/esm2022/components-source/dropi-youtube-lazy-video/dropi-youtube-lazy-video.component.mjs +46 -0
- package/dist/esm2022/components-source/empty/empty.component.mjs +18 -0
- package/dist/esm2022/components-source/empty-state/empty-state.component.mjs +62 -0
- package/dist/esm2022/components-source/file-upload-progress-bar/file-upload-progress-bar.component.mjs +91 -0
- package/dist/esm2022/components-source/index.mjs +107 -0
- package/dist/esm2022/components-source/input/input.component.mjs +104 -0
- package/dist/esm2022/components-source/lottie-loader/lottie-loader.component.mjs +25 -0
- package/dist/esm2022/components-source/otp-send-code/otp-send-code.component.mjs +201 -0
- package/dist/esm2022/components-source/radio-selection-list/radio-selection-list.component.mjs +89 -0
- package/dist/esm2022/components-source/read-more/read-more.component.mjs +91 -0
- package/dist/esm2022/components-source/sidebar/sidebar.component.mjs +88 -0
- package/dist/esm2022/components-source/simple-stepper/simple-stepper.component.mjs +60 -0
- package/dist/esm2022/components-source/spinner/spinner.component.mjs +19 -0
- package/dist/esm2022/components-source/tabs/tabs.component.mjs +83 -0
- package/dist/esm2022/components-source/tag-type-product/tag-type-product.component.mjs +11 -0
- package/dist/esm2022/components-source/toast/toast.component.mjs +47 -0
- package/dist/esm2022/components-source/toggle/input-toggle.component.mjs +36 -0
- package/dist/esm2022/components-source/tooltip/tooltip.component.mjs +34 -0
- package/dist/esm2022/components-source/vertical-steps/vertical-steps.component.mjs +75 -0
- package/dist/esm2022/lib/elements-registry.mjs +343 -2
- package/dist/esm2022/utilities/interfaces/ui/dropi-table.interface.mjs +2 -0
- package/dist/esm2022/utilities/interfaces/ui/input-interface.mjs +2 -0
- package/dist/esm2022/utilities/interfaces/ui/select-interface.mjs +2 -0
- package/dist/esm2022/utilities/interfaces/ui/selection-list-interface.mjs +2 -0
- package/dist/esm2022/utilities/interfaces/ui/upload.model.mjs +5 -0
- package/dist/fesm2022/dropi-ui-components.mjs +5913 -2
- package/dist/fesm2022/dropi-ui-components.mjs.map +1 -1
- package/dist/utilities/interfaces/ui/dropi-table.interface.d.ts +45 -0
- package/dist/utilities/interfaces/ui/input-interface.d.ts +33 -0
- package/dist/utilities/interfaces/ui/select-interface.d.ts +8 -0
- package/dist/utilities/interfaces/ui/selection-list-interface.d.ts +24 -0
- package/dist/utilities/interfaces/ui/upload.model.d.ts +30 -0
- package/package.json +18 -6
- package/src/components-source/alert/alert.component.ts +12 -129
- package/src/components-source/alert-modal/alert-modal.component.ts +84 -114
- package/src/components-source/alert-validation/alert-validation.component.html +8 -0
- package/src/components-source/alert-validation/alert-validation.component.scss +225 -0
- package/src/components-source/alert-validation/alert-validation.component.ts +43 -0
- package/src/components-source/beta-tag/beta-tag.component.html +1 -0
- package/src/components-source/beta-tag/beta-tag.component.scss +26 -0
- package/src/components-source/beta-tag/beta-tag.component.ts +11 -0
- package/src/components-source/breadcrumb/breadcrumb.component.html +13 -5
- package/src/components-source/breadcrumb/breadcrumb.component.scss +8 -1
- package/src/components-source/breadcrumb/breadcrumb.component.spec.ts +26 -26
- package/src/components-source/breadcrumb/breadcrumb.component.ts +10 -12
- package/src/components-source/card-product/card-product.component.spec.ts +9 -9
- package/src/components-source/card-product/card-product.component.stories.ts +2 -2
- package/src/components-source/card-product/card-product.component.ts +294 -818
- package/src/components-source/card-section/card-section.component.html +7 -7
- package/src/components-source/card-section/card-section.component.ts +41 -15
- package/src/components-source/checkbox-selection-list/checkbox-selection-list.component.ts +42 -179
- package/src/components-source/city-selector/city-selector.component.ts +37 -137
- package/src/components-source/confirm-dialog/confirm-dialog.component.html +26 -0
- package/src/components-source/confirm-dialog/confirm-dialog.component.scss +55 -0
- package/src/components-source/confirm-dialog/confirm-dialog.component.ts +22 -0
- package/src/components-source/country-flags/country-flags.component.ts +20 -12
- package/src/components-source/date-picker/date-picker.component.ts +32 -292
- package/src/components-source/date-picker-range/date-picker-range.component.html +15 -7
- package/src/components-source/date-picker-range/date-picker-range.component.ts +42 -235
- package/src/components-source/dropi-banner-external/dropi-banner-external.component.ts +24 -185
- package/src/components-source/dropi-breadcrumb/dropi-breadcrumb.component.html +21 -21
- package/src/components-source/dropi-breadcrumb/dropi-breadcrumb.component.spec.ts +9 -9
- package/src/components-source/dropi-breadcrumb/dropi-breadcrumb.component.ts +41 -23
- package/src/components-source/dropi-breadcrumb/dropi-breadcrumb.stories.ts +12 -12
- package/src/components-source/dropi-chips/dropi-chips.component.ts +22 -87
- package/src/components-source/dropi-country-selector/countries.data.ts +256 -236
- package/src/components-source/dropi-country-selector/dropi-country-selector.component.ts +37 -25
- package/src/components-source/dropi-drawer/dropi-drawer.component.ts +91 -78
- package/src/components-source/dropi-dropdown/dropi-dropdown.component.ts +44 -47
- package/src/components-source/dropi-file-upload/card-view/card-view.component.ts +33 -53
- package/src/components-source/dropi-file-upload/drop-zone/drop-zone.component.ts +52 -123
- package/src/components-source/dropi-file-upload/dropi-file-upload.component.ts +38 -294
- package/src/components-source/dropi-file-upload/file-list/file-list.component.ts +62 -43
- package/src/components-source/dropi-file-upload/grid-view/grid-view.component.ts +23 -22
- package/src/components-source/dropi-ilustration-icon/dropi-ilustration-icon.component.scss +6 -2
- package/src/components-source/dropi-image-overlay/dropi-image-overlay.component.ts +16 -71
- package/src/components-source/dropi-modal/dropi-modal.component.ts +56 -372
- package/src/components-source/dropi-navbar/dropi-navbar.component.ts +17 -17
- package/src/components-source/dropi-paginator/dropi-paginator.component.html +18 -7
- package/src/components-source/dropi-paginator/dropi-paginator.component.ts +40 -32
- package/src/components-source/dropi-phone-input/dropi-phone-input.component.html +78 -79
- package/src/components-source/dropi-phone-input/dropi-phone-input.component.ts +29 -85
- package/src/components-source/dropi-search/dropi-search.component.ts +59 -222
- package/src/components-source/dropi-select/dropi-select.component.html +82 -131
- package/src/components-source/dropi-select/dropi-select.component.ts +60 -423
- package/src/components-source/dropi-table/dropi-table.component.html +40 -23
- package/src/components-source/dropi-table/dropi-table.component.ts +130 -374
- package/src/components-source/dropi-tag/dropi-tag.component.ts +20 -90
- package/src/components-source/dropi-text-area/dropi-text-area.component.ts +22 -48
- package/src/components-source/dropi-tooltip/dropi-tooltip.component.ts +40 -129
- package/src/components-source/empty/empty.component.html +3 -0
- package/src/components-source/empty/empty.component.scss +0 -0
- package/src/components-source/empty/empty.component.ts +16 -0
- package/src/components-source/empty-state/empty-state.component.ts +47 -19
- package/src/components-source/index.ts +82 -37
- package/src/components-source/input/input.component.html +79 -63
- package/src/components-source/input/input.component.ts +51 -97
- package/src/components-source/lottie-loader/lottie-loader.component.ts +13 -16
- package/src/components-source/otp-send-code/otp-send-code.component.ts +60 -528
- package/src/components-source/radio-selection-list/radio-selection-list.component.ts +36 -97
- package/src/components-source/sidebar/sidebar.component.spec.ts +11 -11
- package/src/components-source/sidebar/sidebar.component.stories.ts +3 -3
- package/src/components-source/sidebar/sidebar.component.ts +51 -47
- package/src/components-source/simple-stepper/simple-stepper.component.ts +20 -35
- package/src/components-source/spinner/spinner.component.html +6 -0
- package/src/components-source/spinner/spinner.component.scss +15 -0
- package/src/components-source/spinner/spinner.component.ts +17 -0
- package/src/components-source/tabs/tabs.component.spec.ts +8 -8
- package/src/components-source/tabs/tabs.component.stories.ts +5 -5
- package/src/components-source/tabs/tabs.component.ts +41 -83
- package/src/components-source/toast/toast.component.ts +40 -46
- package/src/components-source/toggle/input-toggle.component.html +34 -0
- package/src/components-source/toggle/input-toggle.component.scss +0 -0
- package/src/components-source/toggle/input-toggle.component.ts +27 -0
- package/src/components-source/toggle/inputToggleConfig.ts +11 -0
- package/src/components-source/tooltip/tooltip.component.html +22 -11
- package/src/components-source/tooltip/tooltip.component.ts +28 -13
- package/src/components-source/vertical-steps/vertical-steps.component.ts +16 -78
- package/src/lib/elements-registry.ts +413 -1
- package/src/lib/router-stub.ts +7 -0
- package/src/libreria work space.code-workspace +11 -8
- package/src/utilities/interfaces/ui/dropi-table.interface.ts +60 -0
- package/src/utilities/interfaces/ui/input-interface.ts +34 -0
- package/src/utilities/interfaces/ui/select-interface.ts +8 -0
- package/src/utilities/interfaces/ui/selection-list-interface.ts +15 -0
- package/src/utilities/interfaces/ui/upload.model.ts +41 -0
|
@@ -0,0 +1,534 @@
|
|
|
1
|
+
import { Component, Input, Output, EventEmitter, HostListener, Inject, Pipe, CUSTOM_ELEMENTS_SCHEMA, } from "@angular/core";
|
|
2
|
+
import { CommonModule, TitleCasePipe } from "@angular/common";
|
|
3
|
+
import { IconComponent } from "../icon/icon.component";
|
|
4
|
+
import { DropiTagComponent } from "../dropi-tag/dropi-tag.component";
|
|
5
|
+
// import { Howl } from "howler"; // Eliminado para evitar errores de dependencia
|
|
6
|
+
import { DropiIlustrationIconComponent } from "../dropi-ilustration-icon/dropi-ilustration-icon.component";
|
|
7
|
+
import { TranslateModule } from "@ngx-translate/core";
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "@angular/common";
|
|
10
|
+
import * as i2 from "@ngx-translate/core";
|
|
11
|
+
export class AdjustNamePipeStub {
|
|
12
|
+
transform(value) {
|
|
13
|
+
return value;
|
|
14
|
+
}
|
|
15
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: AdjustNamePipeStub, deps: [], target: i0.ɵɵFactoryTarget.Pipe });
|
|
16
|
+
static ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "18.2.14", ngImport: i0, type: AdjustNamePipeStub, isStandalone: true, name: "adjustName" });
|
|
17
|
+
}
|
|
18
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: AdjustNamePipeStub, decorators: [{
|
|
19
|
+
type: Pipe,
|
|
20
|
+
args: [{
|
|
21
|
+
name: "adjustName",
|
|
22
|
+
standalone: true,
|
|
23
|
+
}]
|
|
24
|
+
}] });
|
|
25
|
+
export class CurrencyComponentStub {
|
|
26
|
+
value;
|
|
27
|
+
class;
|
|
28
|
+
style;
|
|
29
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CurrencyComponentStub, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
30
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: CurrencyComponentStub, isStandalone: true, selector: "currency", inputs: { value: "value", class: "class", style: "style" }, ngImport: i0, template: "{{value}}", isInline: true });
|
|
31
|
+
}
|
|
32
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CurrencyComponentStub, decorators: [{
|
|
33
|
+
type: Component,
|
|
34
|
+
args: [{
|
|
35
|
+
selector: "currency",
|
|
36
|
+
standalone: true,
|
|
37
|
+
template: "{{value}}",
|
|
38
|
+
}]
|
|
39
|
+
}], propDecorators: { value: [{
|
|
40
|
+
type: Input
|
|
41
|
+
}], class: [{
|
|
42
|
+
type: Input
|
|
43
|
+
}], style: [{
|
|
44
|
+
type: Input
|
|
45
|
+
}] } });
|
|
46
|
+
export class BetaTagComponentStub {
|
|
47
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: BetaTagComponentStub, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
48
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: BetaTagComponentStub, isStandalone: true, selector: "app-beta-tag", ngImport: i0, template: "", isInline: true });
|
|
49
|
+
}
|
|
50
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: BetaTagComponentStub, decorators: [{
|
|
51
|
+
type: Component,
|
|
52
|
+
args: [{
|
|
53
|
+
selector: "app-beta-tag",
|
|
54
|
+
standalone: true,
|
|
55
|
+
template: "",
|
|
56
|
+
}]
|
|
57
|
+
}] });
|
|
58
|
+
export class CardProductComponent {
|
|
59
|
+
settingService;
|
|
60
|
+
favoriteService;
|
|
61
|
+
orderManual;
|
|
62
|
+
router;
|
|
63
|
+
product;
|
|
64
|
+
state = "default";
|
|
65
|
+
aS = true;
|
|
66
|
+
bettaTester = false;
|
|
67
|
+
onAddToCart = new EventEmitter();
|
|
68
|
+
onProductClick = new EventEmitter();
|
|
69
|
+
changeFavorite = new EventEmitter();
|
|
70
|
+
imageError = false;
|
|
71
|
+
brandName = "";
|
|
72
|
+
onFavoriteHover = false;
|
|
73
|
+
randomClasses = {
|
|
74
|
+
card: "",
|
|
75
|
+
imageContainer: "",
|
|
76
|
+
image: "",
|
|
77
|
+
tags: "",
|
|
78
|
+
tagsRow: "",
|
|
79
|
+
favoriteButton: "",
|
|
80
|
+
productInfo: "",
|
|
81
|
+
productHeader: "",
|
|
82
|
+
category: "",
|
|
83
|
+
stockInfo: "",
|
|
84
|
+
stockLabel: "",
|
|
85
|
+
stockValue: "",
|
|
86
|
+
productName: "",
|
|
87
|
+
supplierInfo: "",
|
|
88
|
+
supplierLabel: "",
|
|
89
|
+
supplierName: "",
|
|
90
|
+
priceContainer: "",
|
|
91
|
+
priceItem: "",
|
|
92
|
+
priceLabel: "",
|
|
93
|
+
priceValue: "",
|
|
94
|
+
separator: "",
|
|
95
|
+
actionButton: "",
|
|
96
|
+
buttonText: "",
|
|
97
|
+
};
|
|
98
|
+
mixedData = {
|
|
99
|
+
stockDivs: [],
|
|
100
|
+
supplierPriceDivs: [],
|
|
101
|
+
suggestedPriceDivs: [],
|
|
102
|
+
};
|
|
103
|
+
fakeStyles = {
|
|
104
|
+
stock: "",
|
|
105
|
+
price: "",
|
|
106
|
+
};
|
|
107
|
+
isMobile = false;
|
|
108
|
+
constructor(settingService, favoriteService, orderManual, router) {
|
|
109
|
+
this.settingService = settingService;
|
|
110
|
+
this.favoriteService = favoriteService;
|
|
111
|
+
this.orderManual = orderManual;
|
|
112
|
+
this.router = router;
|
|
113
|
+
}
|
|
114
|
+
ngOnInit() {
|
|
115
|
+
this.brandName =
|
|
116
|
+
this.settingService?.getBrandInfo()?.name?.toLowerCase() || "dropi";
|
|
117
|
+
this.generateRandomClasses();
|
|
118
|
+
this.generateFakeStyles();
|
|
119
|
+
this.generateMixedData();
|
|
120
|
+
this.checkScreenSize();
|
|
121
|
+
}
|
|
122
|
+
ngOnChanges(changes) {
|
|
123
|
+
if (changes["product"] || changes["aS"]) {
|
|
124
|
+
this.generateMixedData();
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
onResize(event) {
|
|
128
|
+
this.checkScreenSize();
|
|
129
|
+
}
|
|
130
|
+
checkScreenSize() {
|
|
131
|
+
this.isMobile = window.innerWidth <= 420;
|
|
132
|
+
}
|
|
133
|
+
generateRandomClasses() {
|
|
134
|
+
this.randomClasses = {
|
|
135
|
+
card: this.generateRandomClass("dropi-card-product"),
|
|
136
|
+
imageContainer: this.generateRandomClass("product-image-container"),
|
|
137
|
+
image: this.generateRandomClass("product-image"),
|
|
138
|
+
tags: this.generateRandomClass("product-tags"),
|
|
139
|
+
tagsRow: this.generateRandomClass("tags-row"),
|
|
140
|
+
favoriteButton: this.generateRandomClass("favorite-button"),
|
|
141
|
+
productInfo: this.generateRandomClass("product-info"),
|
|
142
|
+
productHeader: this.generateRandomClass("product-header"),
|
|
143
|
+
category: this.generateRandomClass("category"),
|
|
144
|
+
stockInfo: this.generateRandomClass("stock-info"),
|
|
145
|
+
stockLabel: this.generateRandomClass("stock-label"),
|
|
146
|
+
stockValue: this.generateRandomClass("stock-value"),
|
|
147
|
+
productName: this.generateRandomClass("product-name"),
|
|
148
|
+
supplierInfo: this.generateRandomClass("supplier-info"),
|
|
149
|
+
supplierLabel: this.generateRandomClass("supplier-label"),
|
|
150
|
+
supplierName: this.generateRandomClass("supplier-name"),
|
|
151
|
+
priceContainer: this.generateRandomClass("price-container"),
|
|
152
|
+
priceItem: this.generateRandomClass("price-item"),
|
|
153
|
+
priceLabel: this.generateRandomClass("price-label"),
|
|
154
|
+
priceValue: this.generateRandomClass("price-value"),
|
|
155
|
+
separator: this.generateRandomClass("separator"),
|
|
156
|
+
actionButton: this.generateRandomClass("action-button"),
|
|
157
|
+
buttonText: this.generateRandomClass("button-text"),
|
|
158
|
+
};
|
|
159
|
+
}
|
|
160
|
+
generateMixedData() {
|
|
161
|
+
this.mixedData.stockDivs = this.generateMixedStockDivs();
|
|
162
|
+
this.mixedData.supplierPriceDivs = this.getMixedSupplierPriceDivs();
|
|
163
|
+
this.mixedData.suggestedPriceDivs = this.getMixedSuggestedPriceDivs();
|
|
164
|
+
}
|
|
165
|
+
generateFakeStyles() {
|
|
166
|
+
this.fakeStyles.stock = this.generateFakeStyleVariant();
|
|
167
|
+
this.fakeStyles.price = this.generateFakeStyleVariant();
|
|
168
|
+
}
|
|
169
|
+
get imageUrl() {
|
|
170
|
+
if (this.product && this.product.image) {
|
|
171
|
+
return `https://img.dropi.co/${this.product.image}`;
|
|
172
|
+
}
|
|
173
|
+
if (this.product && this.product.imageUrl) {
|
|
174
|
+
return this.product.imageUrl;
|
|
175
|
+
}
|
|
176
|
+
return undefined;
|
|
177
|
+
}
|
|
178
|
+
onError(event) {
|
|
179
|
+
this.imageError = true;
|
|
180
|
+
event.target.src = "./assets/utils/no-image.jpg";
|
|
181
|
+
}
|
|
182
|
+
get productTags() {
|
|
183
|
+
const tags = [];
|
|
184
|
+
if (this.product?.type?.includes("variable")) {
|
|
185
|
+
tags.push({
|
|
186
|
+
text: "Variable",
|
|
187
|
+
type: "primary",
|
|
188
|
+
state: "default",
|
|
189
|
+
});
|
|
190
|
+
}
|
|
191
|
+
if (this.product?.type?.includes("privado")) {
|
|
192
|
+
tags.push({
|
|
193
|
+
text: "Privado",
|
|
194
|
+
type: "primary",
|
|
195
|
+
state: "warning",
|
|
196
|
+
showIcon: true,
|
|
197
|
+
icon: "Lock",
|
|
198
|
+
});
|
|
199
|
+
}
|
|
200
|
+
if (this.product?.type?.includes("combo")) {
|
|
201
|
+
tags.push({
|
|
202
|
+
text: "Combo",
|
|
203
|
+
type: "primary",
|
|
204
|
+
state: "info",
|
|
205
|
+
});
|
|
206
|
+
}
|
|
207
|
+
return tags;
|
|
208
|
+
}
|
|
209
|
+
getProductStock() {
|
|
210
|
+
if (this.product?.type === "VARIABLE" && this.product?.is_variation) {
|
|
211
|
+
return this.product?.variation_stock || 0;
|
|
212
|
+
}
|
|
213
|
+
return this.product?.stock_simple || 0;
|
|
214
|
+
}
|
|
215
|
+
get stockStatus() {
|
|
216
|
+
const stock = this.getProductStock();
|
|
217
|
+
if (stock === 0)
|
|
218
|
+
return "error";
|
|
219
|
+
if (stock <= 10)
|
|
220
|
+
return "warning";
|
|
221
|
+
return "success";
|
|
222
|
+
}
|
|
223
|
+
get stockStatusClass() {
|
|
224
|
+
switch (this.stockStatus) {
|
|
225
|
+
case "success":
|
|
226
|
+
return "stock-success";
|
|
227
|
+
case "warning":
|
|
228
|
+
return "stock-warning";
|
|
229
|
+
case "error":
|
|
230
|
+
return "stock-error";
|
|
231
|
+
default:
|
|
232
|
+
return "stock-success";
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
handleAddToCart() {
|
|
236
|
+
const stock = this.getProductStock();
|
|
237
|
+
if (stock > 0) {
|
|
238
|
+
this.onAddToCart.emit(this.product);
|
|
239
|
+
if (this.orderManual) {
|
|
240
|
+
this.orderManual.setModalOpen(true);
|
|
241
|
+
this.orderManual.clearProductsIds();
|
|
242
|
+
this.orderManual.setProductsIds(Number(this.product.id));
|
|
243
|
+
}
|
|
244
|
+
}
|
|
245
|
+
}
|
|
246
|
+
handleFavoriteToggle() {
|
|
247
|
+
if (!this.product || !this.product.id)
|
|
248
|
+
return;
|
|
249
|
+
let body = { product_id: this.product.id };
|
|
250
|
+
if (!this.product.favorite) {
|
|
251
|
+
this.favoriteService?.addFavoriteProduct(body).subscribe({
|
|
252
|
+
next: (response) => {
|
|
253
|
+
if (response?.is_successful) {
|
|
254
|
+
this.product.favorite = true;
|
|
255
|
+
this.playAudio();
|
|
256
|
+
this.changeFavorite.emit(true);
|
|
257
|
+
}
|
|
258
|
+
},
|
|
259
|
+
});
|
|
260
|
+
}
|
|
261
|
+
else {
|
|
262
|
+
this.favoriteService?.removeFavoriteProduct(body).subscribe({
|
|
263
|
+
next: (response) => {
|
|
264
|
+
if (response?.is_successful) {
|
|
265
|
+
this.product.favorite = false;
|
|
266
|
+
this.playAudio();
|
|
267
|
+
this.changeFavorite.emit(false);
|
|
268
|
+
}
|
|
269
|
+
},
|
|
270
|
+
});
|
|
271
|
+
}
|
|
272
|
+
}
|
|
273
|
+
getFavoriteIconColor() {
|
|
274
|
+
if (this.product?.favorite) {
|
|
275
|
+
return "#fff";
|
|
276
|
+
}
|
|
277
|
+
return this.onFavoriteHover ? "#f49a3d" : "#858ea6";
|
|
278
|
+
}
|
|
279
|
+
playAudio() {
|
|
280
|
+
// try {
|
|
281
|
+
// let sound = new Howl({
|
|
282
|
+
// src: ["assets/audio/pop.mp3"],
|
|
283
|
+
// });
|
|
284
|
+
// sound.volume(0.4);
|
|
285
|
+
// sound.play();
|
|
286
|
+
// } catch (e) {}
|
|
287
|
+
}
|
|
288
|
+
getProductDetails() {
|
|
289
|
+
let nameProductUrl = this.product.name || "producto";
|
|
290
|
+
const url = `/dashboard/product-details/${this.product.id}/${nameProductUrl}`;
|
|
291
|
+
window.open(url, "_blank");
|
|
292
|
+
}
|
|
293
|
+
getProvidersDetails() {
|
|
294
|
+
const cleanName = this.product?.supplier?.name || "proveedor";
|
|
295
|
+
if (this.router?.url === "/dashboard/search") {
|
|
296
|
+
const url = `/dashboard/provider/${this.product.supplier.id}/${cleanName}`;
|
|
297
|
+
window.open(url, "_blank");
|
|
298
|
+
}
|
|
299
|
+
else {
|
|
300
|
+
this.router?.navigate?.([
|
|
301
|
+
"/dashboard/provider",
|
|
302
|
+
this.product.supplier.id,
|
|
303
|
+
cleanName,
|
|
304
|
+
]);
|
|
305
|
+
}
|
|
306
|
+
}
|
|
307
|
+
getMixedSupplierPriceDivs() {
|
|
308
|
+
return [
|
|
309
|
+
{
|
|
310
|
+
value: this.product?.supplierPrice || this.product?.sale_price || 0,
|
|
311
|
+
class: "price-real",
|
|
312
|
+
isReal: true,
|
|
313
|
+
},
|
|
314
|
+
];
|
|
315
|
+
}
|
|
316
|
+
getMixedSuggestedPriceDivs() {
|
|
317
|
+
return [
|
|
318
|
+
{
|
|
319
|
+
value: this.product?.suggestedPrice || this.product?.suggested_price || 0,
|
|
320
|
+
class: "price-real",
|
|
321
|
+
isReal: true,
|
|
322
|
+
},
|
|
323
|
+
];
|
|
324
|
+
}
|
|
325
|
+
hasStock() {
|
|
326
|
+
return this.getProductStock() > 0;
|
|
327
|
+
}
|
|
328
|
+
// Helper fakes for anti-scraping
|
|
329
|
+
generateRandomClass(base) {
|
|
330
|
+
return base + "-" + Math.random().toString(36).slice(2, 7);
|
|
331
|
+
}
|
|
332
|
+
generateFakeStyleVariant() {
|
|
333
|
+
return "";
|
|
334
|
+
}
|
|
335
|
+
generateMixedStockDivs() {
|
|
336
|
+
return [
|
|
337
|
+
{ value: this.getProductStock(), class: "stock-real", isReal: true },
|
|
338
|
+
];
|
|
339
|
+
}
|
|
340
|
+
// Re-added missing template methods
|
|
341
|
+
getCardStyles() {
|
|
342
|
+
return {};
|
|
343
|
+
}
|
|
344
|
+
getRandomProviderCategoryStyles() {
|
|
345
|
+
return {};
|
|
346
|
+
}
|
|
347
|
+
getImageContainerStyles() {
|
|
348
|
+
return {};
|
|
349
|
+
}
|
|
350
|
+
getImageStyles() {
|
|
351
|
+
return {};
|
|
352
|
+
}
|
|
353
|
+
getTagsContainerStyles() {
|
|
354
|
+
return {};
|
|
355
|
+
}
|
|
356
|
+
getTagsRowStyles() {
|
|
357
|
+
return {};
|
|
358
|
+
}
|
|
359
|
+
getFavoriteButtonStyles() {
|
|
360
|
+
return {};
|
|
361
|
+
}
|
|
362
|
+
getProductInfoStyles() {
|
|
363
|
+
return {};
|
|
364
|
+
}
|
|
365
|
+
getProductHeaderStyles() {
|
|
366
|
+
return {};
|
|
367
|
+
}
|
|
368
|
+
getCategoryStyles() {
|
|
369
|
+
return {};
|
|
370
|
+
}
|
|
371
|
+
getStockInfoStyles() {
|
|
372
|
+
return {};
|
|
373
|
+
}
|
|
374
|
+
getStockLabelStyles() {
|
|
375
|
+
return {};
|
|
376
|
+
}
|
|
377
|
+
getStockValueStyles() {
|
|
378
|
+
return {};
|
|
379
|
+
}
|
|
380
|
+
getProductNameStyles() {
|
|
381
|
+
return {};
|
|
382
|
+
}
|
|
383
|
+
getSupplierInfoStyles() {
|
|
384
|
+
return {};
|
|
385
|
+
}
|
|
386
|
+
getSupplierLabelStyles() {
|
|
387
|
+
return {};
|
|
388
|
+
}
|
|
389
|
+
getSupplierNameStyles() {
|
|
390
|
+
return {};
|
|
391
|
+
}
|
|
392
|
+
getPriceContainerStyles() {
|
|
393
|
+
return {};
|
|
394
|
+
}
|
|
395
|
+
getPriceItemStyles() {
|
|
396
|
+
return {};
|
|
397
|
+
}
|
|
398
|
+
getPriceLabelStyles() {
|
|
399
|
+
return {};
|
|
400
|
+
}
|
|
401
|
+
getPriceValueStyles() {
|
|
402
|
+
return {};
|
|
403
|
+
}
|
|
404
|
+
getSeparatorStyles() {
|
|
405
|
+
return {};
|
|
406
|
+
}
|
|
407
|
+
getActionButtonStyles() {
|
|
408
|
+
return {};
|
|
409
|
+
}
|
|
410
|
+
getButtonTextStyles() {
|
|
411
|
+
return {};
|
|
412
|
+
}
|
|
413
|
+
getFakeStockStyles() {
|
|
414
|
+
return {};
|
|
415
|
+
}
|
|
416
|
+
getFakePriceStyles() {
|
|
417
|
+
return {};
|
|
418
|
+
}
|
|
419
|
+
getRandomCardClass() {
|
|
420
|
+
return this.randomClasses.card;
|
|
421
|
+
}
|
|
422
|
+
getRandomImageContainerClass() {
|
|
423
|
+
return this.randomClasses.imageContainer;
|
|
424
|
+
}
|
|
425
|
+
getRandomImageClass() {
|
|
426
|
+
return this.randomClasses.image;
|
|
427
|
+
}
|
|
428
|
+
getRandomTagsClass() {
|
|
429
|
+
return this.randomClasses.tags;
|
|
430
|
+
}
|
|
431
|
+
getRandomTagsRowClass() {
|
|
432
|
+
return this.randomClasses.tagsRow;
|
|
433
|
+
}
|
|
434
|
+
getRandomFavoriteButtonClass() {
|
|
435
|
+
return this.randomClasses.favoriteButton;
|
|
436
|
+
}
|
|
437
|
+
getRandomProductInfoClass() {
|
|
438
|
+
return this.randomClasses.productInfo;
|
|
439
|
+
}
|
|
440
|
+
getRandomProductHeaderClass() {
|
|
441
|
+
return this.randomClasses.productHeader;
|
|
442
|
+
}
|
|
443
|
+
getRandomCategoryClass() {
|
|
444
|
+
return this.randomClasses.category;
|
|
445
|
+
}
|
|
446
|
+
getRandomStockInfoClass() {
|
|
447
|
+
return this.randomClasses.stockInfo;
|
|
448
|
+
}
|
|
449
|
+
getRandomStockLabelClass() {
|
|
450
|
+
return this.randomClasses.stockLabel;
|
|
451
|
+
}
|
|
452
|
+
getRandomProductNameClass() {
|
|
453
|
+
return this.randomClasses.productName;
|
|
454
|
+
}
|
|
455
|
+
getRandomSupplierInfoClass() {
|
|
456
|
+
return this.randomClasses.supplierInfo;
|
|
457
|
+
}
|
|
458
|
+
getRandomSupplierLabelClass() {
|
|
459
|
+
return this.randomClasses.supplierLabel;
|
|
460
|
+
}
|
|
461
|
+
getRandomSupplierNameClass() {
|
|
462
|
+
return this.randomClasses.supplierName;
|
|
463
|
+
}
|
|
464
|
+
getRandomPriceContainerClass() {
|
|
465
|
+
return this.randomClasses.priceContainer;
|
|
466
|
+
}
|
|
467
|
+
getRandomPriceItemClass() {
|
|
468
|
+
return this.randomClasses.priceItem;
|
|
469
|
+
}
|
|
470
|
+
getRandomPriceLabelClass() {
|
|
471
|
+
return this.randomClasses.priceLabel;
|
|
472
|
+
}
|
|
473
|
+
getRandomPriceValueClass() {
|
|
474
|
+
return this.randomClasses.priceValue;
|
|
475
|
+
}
|
|
476
|
+
getRandomSeparatorClass() {
|
|
477
|
+
return this.randomClasses.separator;
|
|
478
|
+
}
|
|
479
|
+
getRandomActionButtonClass() {
|
|
480
|
+
return this.randomClasses.actionButton;
|
|
481
|
+
}
|
|
482
|
+
getRandomButtonTextClass() {
|
|
483
|
+
return this.randomClasses.buttonText;
|
|
484
|
+
}
|
|
485
|
+
getMixedStockDivs() {
|
|
486
|
+
return this.generateMixedStockDivs();
|
|
487
|
+
}
|
|
488
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CardProductComponent, deps: [{ token: "SettingsService" }, { token: "ProductstService" }, { token: "OrderManualService" }, { token: "Router" }], target: i0.ɵɵFactoryTarget.Component });
|
|
489
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: CardProductComponent, isStandalone: true, selector: "dropi-card-product", inputs: { product: "product", state: "state", aS: "aS", bettaTester: "bettaTester" }, outputs: { onAddToCart: "onAddToCart", onProductClick: "onProductClick", changeFavorite: "changeFavorite" }, host: { listeners: { "window:resize": "onResize($event)" } }, usesOnChanges: true, ngImport: i0, template: "<div [class]=\"getRandomCardClass()\" [style]=\"getCardStyles()\" (click)=\"getProductDetails()\">\n <app-beta-tag *ngIf=\"bettaTester\"></app-beta-tag>\n <!-- Contenedor de imagen con altura fija de 214px como en Figma -->\n <div [class]=\"getRandomImageContainerClass()\" [style]=\"getImageContainerStyles()\">\n <div [class]=\"getRandomImageClass()\" [style]=\"getImageStyles()\">\n <!-- Imagen del producto con manejo de errores -->\n <img\n [src]=\"imageUrl\"\n [alt]=\"product?.name || 'Product Image'\"\n (error)=\"onError($event)\"\n [ngClass]=\"{ 'error-img': imageError }\"\n style=\"width: 100%; height: 100%; object-fit: cover; border-radius: 8px\"\n />\n\n <!-- Tags superpuestos en la esquina superior izquierda -->\n <div\n [class]=\"getRandomTagsClass()\"\n [style]=\"getTagsContainerStyles()\"\n *ngIf=\"productTags?.length > 0\"\n >\n <div [class]=\"getRandomTagsRowClass()\" [style]=\"getTagsRowStyles()\">\n <app-dropi-tag\n *ngFor=\"let tag of productTags.slice(0, 2)\"\n [type]=\"tag?.type\"\n [state]=\"tag?.state\"\n [showIcon]=\"tag?.showIcon\"\n [icon]=\"tag?.icon\"\n [text]=\"tag?.text\"\n >\n </app-dropi-tag>\n </div>\n </div>\n\n <!-- Bot\u00F3n de favorito superpuesto en la esquina inferior derecha -->\n <div\n [class]=\"getRandomFavoriteButtonClass()\"\n [ngClass]=\"{ 'favorite-button': true, 'favorite-active': product?.favorite }\"\n [style]=\"getFavoriteButtonStyles()\"\n (click)=\"handleFavoriteToggle(); $event.stopPropagation()\"\n >\n <app-icon\n [name]=\"product?.favorite ? 'Heart-solid' : 'Heart'\"\n width=\"18px\"\n height=\"18px\"\n [color]=\"product?.favorite ? '#fff' : '#858ea6'\"\n [style]=\"{ display: 'flex', 'align-items': 'center', 'justify-content': 'center' }\"\n >\n </app-icon>\n </div>\n </div>\n </div>\n\n <!-- Informaci\u00F3n del producto -->\n <div [class]=\"getRandomProductInfoClass()\" [style]=\"getProductInfoStyles()\">\n <!-- Header con categor\u00EDa y stock -->\n <div [class]=\"getRandomProductHeaderClass()\" [style]=\"getProductHeaderStyles()\">\n <dropi-ilustration-icon\n *ngIf=\"product?.supplier?.icon\"\n [style]=\"getRandomProviderCategoryStyles()\"\n [type]=\"'insignia'\"\n [stateInsignia]=\"product?.supplier?.icon\"\n [tagProduct]=\"true\"\n ></dropi-ilustration-icon>\n\n <span\n [class]=\"getRandomCategoryClass()\"\n [style]=\"getCategoryStyles()\"\n *ngIf=\"product?.categories && product?.categories.length > 0\"\n >{{ product?.categories[0]?.name | adjustName }}</span\n >\n\n <div [class]=\"getRandomStockInfoClass()\" [style]=\"getStockInfoStyles()\">\n <span [class]=\"getRandomStockLabelClass()\" [style]=\"getStockLabelStyles()\">{{ \"stock\" | translate }}:</span>\n\n <!-- Stocks mezclados aleatoriamente (real + falsos) -->\n <span\n *ngFor=\"let stockItem of getMixedStockDivs()\"\n [class]=\"stockItem.class\"\n [style]=\"stockItem.isReal ? getStockValueStyles() : getFakeStockStyles()\"\n >\n {{ stockItem.value }}\n </span>\n\n <span\n *ngIf=\"product?.private_user_stock && product?.private_user_stock > 0\"\n class=\"stock-private-user\"\n [style]=\"{\n 'font-weight': '500',\n padding: '0px 6px',\n 'margin-left': '6px',\n 'border-radius': '4px',\n background: 'var(--Success-Success-50, #e7f8f3)',\n color: 'var(--Success-Success-500, #0abb87)',\n 'text-align': 'center'\n }\"\n >\n {{ product?.private_user_stock }}\n </span>\n </div>\n </div>\n\n <!-- Nombre del producto -->\n <h3 [class]=\"getRandomProductNameClass()\" [style]=\"getProductNameStyles()\">\n {{ product?.name | adjustName }}\n </h3>\n\n <!-- Proveedor -->\n <div [class]=\"getRandomSupplierInfoClass()\" [style]=\"getSupplierInfoStyles()\">\n <span [class]=\"getRandomSupplierLabelClass()\" [style]=\"getSupplierLabelStyles()\"\n >{{ \"supplier\" | translate }}:</span\n >\n <span\n [class]=\"getRandomSupplierNameClass()\"\n [style]=\"getSupplierNameStyles()\"\n (click)=\"getProvidersDetails(); $event.stopPropagation()\"\n >{{ product?.supplier?.name | adjustName }}</span\n >\n </div>\n\n <!-- Precios -->\n <div [class]=\"getRandomPriceContainerClass()\" [style]=\"getPriceContainerStyles()\">\n <div [class]=\"getRandomPriceItemClass()\" [style]=\"getPriceItemStyles()\">\n <span [class]=\"getRandomPriceLabelClass()\" [style]=\"getPriceLabelStyles()\"\n >{{ \"supplier price\" | translate }}</span\n >\n\n <!-- Precios de proveedor mezclados aleatoriamente (real + falsos) -->\n <currency\n *ngFor=\"let priceItem of getMixedSupplierPriceDivs()\"\n [class]=\"priceItem.class\"\n [style]=\"priceItem.isReal ? getPriceValueStyles() : getFakePriceStyles()\"\n [value]=\"priceItem.value\"\n >\n </currency>\n </div>\n <div [class]=\"getRandomPriceItemClass()\" [style]=\"getPriceItemStyles()\">\n <span [class]=\"getRandomPriceLabelClass()\" [style]=\"getPriceLabelStyles()\"\n >{{ \"suggested price\" | translate }}</span\n >\n\n <!-- Precios sugeridos mezclados aleatoriamente (real + falsos) -->\n <currency\n *ngFor=\"let priceItem of getMixedSuggestedPriceDivs()\"\n [class]=\"priceItem.class\"\n [style]=\"priceItem.isReal ? getPriceValueStyles() : getFakePriceStyles()\"\n [value]=\"priceItem.value\"\n >\n </currency>\n </div>\n </div>\n </div>\n\n <!-- Separador horizontal -->\n <div [class]=\"getRandomSeparatorClass()\" [style]=\"getSeparatorStyles()\"></div>\n\n <!-- Bot\u00F3n de acci\u00F3n principal -->\n <div\n [class]=\"getRandomActionButtonClass()\"\n [style]=\"getActionButtonStyles()\"\n (click)=\"handleAddToCart(); $event.stopPropagation()\"\n >\n <app-icon\n name=\"Shopping-cart-arrow-rigth\"\n width=\"20px\"\n height=\"20px\"\n color=\"#f49a3d\"\n [style]=\"{ display: 'flex', 'align-items': 'center', 'justify-content': 'center' }\"\n ></app-icon>\n <span [class]=\"getRandomButtonTextClass()\" [style]=\"getButtonTextStyles()\"\n >{{ \"send to client\" | translate }}</span\n >\n </div>\n</div>\n", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: IconComponent, selector: "app-icon", inputs: ["name", "width", "height", "color"] }, { kind: "component", type: CurrencyComponentStub, selector: "currency", inputs: ["value", "class", "style"] }, { kind: "pipe", type: AdjustNamePipeStub, name: "adjustName" }, { kind: "component", type: BetaTagComponentStub, selector: "app-beta-tag" }, { kind: "component", type: DropiIlustrationIconComponent, selector: "dropi-ilustration-icon", inputs: ["type", "state", "stateInsignia", "tagProduct"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }] });
|
|
490
|
+
}
|
|
491
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CardProductComponent, decorators: [{
|
|
492
|
+
type: Component,
|
|
493
|
+
args: [{ selector: "dropi-card-product", standalone: true, imports: [
|
|
494
|
+
CommonModule,
|
|
495
|
+
IconComponent,
|
|
496
|
+
DropiTagComponent,
|
|
497
|
+
CurrencyComponentStub,
|
|
498
|
+
TitleCasePipe,
|
|
499
|
+
AdjustNamePipeStub,
|
|
500
|
+
BetaTagComponentStub,
|
|
501
|
+
DropiIlustrationIconComponent,
|
|
502
|
+
TranslateModule,
|
|
503
|
+
], schemas: [CUSTOM_ELEMENTS_SCHEMA], template: "<div [class]=\"getRandomCardClass()\" [style]=\"getCardStyles()\" (click)=\"getProductDetails()\">\n <app-beta-tag *ngIf=\"bettaTester\"></app-beta-tag>\n <!-- Contenedor de imagen con altura fija de 214px como en Figma -->\n <div [class]=\"getRandomImageContainerClass()\" [style]=\"getImageContainerStyles()\">\n <div [class]=\"getRandomImageClass()\" [style]=\"getImageStyles()\">\n <!-- Imagen del producto con manejo de errores -->\n <img\n [src]=\"imageUrl\"\n [alt]=\"product?.name || 'Product Image'\"\n (error)=\"onError($event)\"\n [ngClass]=\"{ 'error-img': imageError }\"\n style=\"width: 100%; height: 100%; object-fit: cover; border-radius: 8px\"\n />\n\n <!-- Tags superpuestos en la esquina superior izquierda -->\n <div\n [class]=\"getRandomTagsClass()\"\n [style]=\"getTagsContainerStyles()\"\n *ngIf=\"productTags?.length > 0\"\n >\n <div [class]=\"getRandomTagsRowClass()\" [style]=\"getTagsRowStyles()\">\n <app-dropi-tag\n *ngFor=\"let tag of productTags.slice(0, 2)\"\n [type]=\"tag?.type\"\n [state]=\"tag?.state\"\n [showIcon]=\"tag?.showIcon\"\n [icon]=\"tag?.icon\"\n [text]=\"tag?.text\"\n >\n </app-dropi-tag>\n </div>\n </div>\n\n <!-- Bot\u00F3n de favorito superpuesto en la esquina inferior derecha -->\n <div\n [class]=\"getRandomFavoriteButtonClass()\"\n [ngClass]=\"{ 'favorite-button': true, 'favorite-active': product?.favorite }\"\n [style]=\"getFavoriteButtonStyles()\"\n (click)=\"handleFavoriteToggle(); $event.stopPropagation()\"\n >\n <app-icon\n [name]=\"product?.favorite ? 'Heart-solid' : 'Heart'\"\n width=\"18px\"\n height=\"18px\"\n [color]=\"product?.favorite ? '#fff' : '#858ea6'\"\n [style]=\"{ display: 'flex', 'align-items': 'center', 'justify-content': 'center' }\"\n >\n </app-icon>\n </div>\n </div>\n </div>\n\n <!-- Informaci\u00F3n del producto -->\n <div [class]=\"getRandomProductInfoClass()\" [style]=\"getProductInfoStyles()\">\n <!-- Header con categor\u00EDa y stock -->\n <div [class]=\"getRandomProductHeaderClass()\" [style]=\"getProductHeaderStyles()\">\n <dropi-ilustration-icon\n *ngIf=\"product?.supplier?.icon\"\n [style]=\"getRandomProviderCategoryStyles()\"\n [type]=\"'insignia'\"\n [stateInsignia]=\"product?.supplier?.icon\"\n [tagProduct]=\"true\"\n ></dropi-ilustration-icon>\n\n <span\n [class]=\"getRandomCategoryClass()\"\n [style]=\"getCategoryStyles()\"\n *ngIf=\"product?.categories && product?.categories.length > 0\"\n >{{ product?.categories[0]?.name | adjustName }}</span\n >\n\n <div [class]=\"getRandomStockInfoClass()\" [style]=\"getStockInfoStyles()\">\n <span [class]=\"getRandomStockLabelClass()\" [style]=\"getStockLabelStyles()\">{{ \"stock\" | translate }}:</span>\n\n <!-- Stocks mezclados aleatoriamente (real + falsos) -->\n <span\n *ngFor=\"let stockItem of getMixedStockDivs()\"\n [class]=\"stockItem.class\"\n [style]=\"stockItem.isReal ? getStockValueStyles() : getFakeStockStyles()\"\n >\n {{ stockItem.value }}\n </span>\n\n <span\n *ngIf=\"product?.private_user_stock && product?.private_user_stock > 0\"\n class=\"stock-private-user\"\n [style]=\"{\n 'font-weight': '500',\n padding: '0px 6px',\n 'margin-left': '6px',\n 'border-radius': '4px',\n background: 'var(--Success-Success-50, #e7f8f3)',\n color: 'var(--Success-Success-500, #0abb87)',\n 'text-align': 'center'\n }\"\n >\n {{ product?.private_user_stock }}\n </span>\n </div>\n </div>\n\n <!-- Nombre del producto -->\n <h3 [class]=\"getRandomProductNameClass()\" [style]=\"getProductNameStyles()\">\n {{ product?.name | adjustName }}\n </h3>\n\n <!-- Proveedor -->\n <div [class]=\"getRandomSupplierInfoClass()\" [style]=\"getSupplierInfoStyles()\">\n <span [class]=\"getRandomSupplierLabelClass()\" [style]=\"getSupplierLabelStyles()\"\n >{{ \"supplier\" | translate }}:</span\n >\n <span\n [class]=\"getRandomSupplierNameClass()\"\n [style]=\"getSupplierNameStyles()\"\n (click)=\"getProvidersDetails(); $event.stopPropagation()\"\n >{{ product?.supplier?.name | adjustName }}</span\n >\n </div>\n\n <!-- Precios -->\n <div [class]=\"getRandomPriceContainerClass()\" [style]=\"getPriceContainerStyles()\">\n <div [class]=\"getRandomPriceItemClass()\" [style]=\"getPriceItemStyles()\">\n <span [class]=\"getRandomPriceLabelClass()\" [style]=\"getPriceLabelStyles()\"\n >{{ \"supplier price\" | translate }}</span\n >\n\n <!-- Precios de proveedor mezclados aleatoriamente (real + falsos) -->\n <currency\n *ngFor=\"let priceItem of getMixedSupplierPriceDivs()\"\n [class]=\"priceItem.class\"\n [style]=\"priceItem.isReal ? getPriceValueStyles() : getFakePriceStyles()\"\n [value]=\"priceItem.value\"\n >\n </currency>\n </div>\n <div [class]=\"getRandomPriceItemClass()\" [style]=\"getPriceItemStyles()\">\n <span [class]=\"getRandomPriceLabelClass()\" [style]=\"getPriceLabelStyles()\"\n >{{ \"suggested price\" | translate }}</span\n >\n\n <!-- Precios sugeridos mezclados aleatoriamente (real + falsos) -->\n <currency\n *ngFor=\"let priceItem of getMixedSuggestedPriceDivs()\"\n [class]=\"priceItem.class\"\n [style]=\"priceItem.isReal ? getPriceValueStyles() : getFakePriceStyles()\"\n [value]=\"priceItem.value\"\n >\n </currency>\n </div>\n </div>\n </div>\n\n <!-- Separador horizontal -->\n <div [class]=\"getRandomSeparatorClass()\" [style]=\"getSeparatorStyles()\"></div>\n\n <!-- Bot\u00F3n de acci\u00F3n principal -->\n <div\n [class]=\"getRandomActionButtonClass()\"\n [style]=\"getActionButtonStyles()\"\n (click)=\"handleAddToCart(); $event.stopPropagation()\"\n >\n <app-icon\n name=\"Shopping-cart-arrow-rigth\"\n width=\"20px\"\n height=\"20px\"\n color=\"#f49a3d\"\n [style]=\"{ display: 'flex', 'align-items': 'center', 'justify-content': 'center' }\"\n ></app-icon>\n <span [class]=\"getRandomButtonTextClass()\" [style]=\"getButtonTextStyles()\"\n >{{ \"send to client\" | translate }}</span\n >\n </div>\n</div>\n" }]
|
|
504
|
+
}], ctorParameters: () => [{ type: undefined, decorators: [{
|
|
505
|
+
type: Inject,
|
|
506
|
+
args: ["SettingsService"]
|
|
507
|
+
}] }, { type: undefined, decorators: [{
|
|
508
|
+
type: Inject,
|
|
509
|
+
args: ["ProductstService"]
|
|
510
|
+
}] }, { type: undefined, decorators: [{
|
|
511
|
+
type: Inject,
|
|
512
|
+
args: ["OrderManualService"]
|
|
513
|
+
}] }, { type: undefined, decorators: [{
|
|
514
|
+
type: Inject,
|
|
515
|
+
args: ["Router"]
|
|
516
|
+
}] }], propDecorators: { product: [{
|
|
517
|
+
type: Input
|
|
518
|
+
}], state: [{
|
|
519
|
+
type: Input
|
|
520
|
+
}], aS: [{
|
|
521
|
+
type: Input
|
|
522
|
+
}], bettaTester: [{
|
|
523
|
+
type: Input
|
|
524
|
+
}], onAddToCart: [{
|
|
525
|
+
type: Output
|
|
526
|
+
}], onProductClick: [{
|
|
527
|
+
type: Output
|
|
528
|
+
}], changeFavorite: [{
|
|
529
|
+
type: Output
|
|
530
|
+
}], onResize: [{
|
|
531
|
+
type: HostListener,
|
|
532
|
+
args: ["window:resize", ["$event"]]
|
|
533
|
+
}] } });
|
|
534
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"card-product.component.js","sourceRoot":"","sources":["../../../../src/components-source/card-product/card-product.component.ts","../../../../src/components-source/card-product/card-product.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,KAAK,EACL,MAAM,EACN,YAAY,EAGZ,YAAY,EACZ,MAAM,EACN,IAAI,EAEJ,sBAAsB,GACvB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAC9D,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AACrE,iFAAiF;AACjF,OAAO,EAAE,6BAA6B,EAAE,MAAM,4DAA4D,CAAC;AAC3G,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;;;;AAMtD,MAAM,OAAO,kBAAkB;IAC7B,SAAS,CAAC,KAAU;QAClB,OAAO,KAAK,CAAC;IACf,CAAC;wGAHU,kBAAkB;sGAAlB,kBAAkB;;4FAAlB,kBAAkB;kBAJ9B,IAAI;mBAAC;oBACJ,IAAI,EAAE,YAAY;oBAClB,UAAU,EAAE,IAAI;iBACjB;;AAYD,MAAM,OAAO,qBAAqB;IACvB,KAAK,CAAM;IACX,KAAK,CAAM;IACX,KAAK,CAAM;wGAHT,qBAAqB;4FAArB,qBAAqB,gIAFtB,WAAW;;4FAEV,qBAAqB;kBALjC,SAAS;mBAAC;oBACT,QAAQ,EAAE,UAAU;oBACpB,UAAU,EAAE,IAAI;oBAChB,QAAQ,EAAE,WAAW;iBACtB;8BAEU,KAAK;sBAAb,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,KAAK;sBAAb,KAAK;;AAQR,MAAM,OAAO,oBAAoB;wGAApB,oBAAoB;4FAApB,oBAAoB,wEAFrB,EAAE;;4FAED,oBAAoB;kBALhC,SAAS;mBAAC;oBACT,QAAQ,EAAE,cAAc;oBACxB,UAAU,EAAE,IAAI;oBAChB,QAAQ,EAAE,EAAE;iBACb;;AAsDD,MAAM,OAAO,oBAAoB;IA6DM;IACC;IACE;IACZ;IA/DnB,OAAO,CAAe;IACtB,KAAK,GAAc,SAAS,CAAC;IAC7B,EAAE,GAAY,IAAI,CAAC;IACnB,WAAW,GAAY,KAAK,CAAC;IAC5B,WAAW,GAAG,IAAI,YAAY,EAAe,CAAC;IAC9C,cAAc,GAAG,IAAI,YAAY,EAAe,CAAC;IACjD,cAAc,GAAG,IAAI,YAAY,EAAW,CAAC;IAEhD,UAAU,GAAG,KAAK,CAAC;IACnB,SAAS,GAAW,EAAE,CAAC;IACvB,eAAe,GAAG,KAAK,CAAC;IAExB,aAAa,GAAG;QACrB,IAAI,EAAE,EAAE;QACR,cAAc,EAAE,EAAE;QAClB,KAAK,EAAE,EAAE;QACT,IAAI,EAAE,EAAE;QACR,OAAO,EAAE,EAAE;QACX,cAAc,EAAE,EAAE;QAClB,WAAW,EAAE,EAAE;QACf,aAAa,EAAE,EAAE;QACjB,QAAQ,EAAE,EAAE;QACZ,SAAS,EAAE,EAAE;QACb,UAAU,EAAE,EAAE;QACd,UAAU,EAAE,EAAE;QACd,WAAW,EAAE,EAAE;QACf,YAAY,EAAE,EAAE;QAChB,aAAa,EAAE,EAAE;QACjB,YAAY,EAAE,EAAE;QAChB,cAAc,EAAE,EAAE;QAClB,SAAS,EAAE,EAAE;QACb,UAAU,EAAE,EAAE;QACd,UAAU,EAAE,EAAE;QACd,SAAS,EAAE,EAAE;QACb,YAAY,EAAE,EAAE;QAChB,UAAU,EAAE,EAAE;KACf,CAAC;IAEK,SAAS,GAAG;QACjB,SAAS,EAAE,EAA8D;QACzE,iBAAiB,EAAE,EAIjB;QACF,kBAAkB,EAAE,EAIlB;KACH,CAAC;IAEK,UAAU,GAAG;QAClB,KAAK,EAAE,EAAE;QACT,KAAK,EAAE,EAAE;KACV,CAAC;IAEK,QAAQ,GAAY,KAAK,CAAC;IAEjC,YACqC,cAAmB,EAClB,eAAoB,EAClB,WAAgB,EAC5B,MAAW;QAHF,mBAAc,GAAd,cAAc,CAAK;QAClB,oBAAe,GAAf,eAAe,CAAK;QAClB,gBAAW,GAAX,WAAW,CAAK;QAC5B,WAAM,GAAN,MAAM,CAAK;IACpC,CAAC;IAEJ,QAAQ;QACN,IAAI,CAAC,SAAS;YACZ,IAAI,CAAC,cAAc,EAAE,YAAY,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE,IAAI,OAAO,CAAC;QACtE,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC7B,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC1B,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,SAAS,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;YACxC,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC3B,CAAC;IACH,CAAC;IAGD,QAAQ,CAAC,KAAU;QACjB,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAEO,eAAe;QACrB,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,UAAU,IAAI,GAAG,CAAC;IAC3C,CAAC;IAEO,qBAAqB;QAC3B,IAAI,CAAC,aAAa,GAAG;YACnB,IAAI,EAAE,IAAI,CAAC,mBAAmB,CAAC,oBAAoB,CAAC;YACpD,cAAc,EAAE,IAAI,CAAC,mBAAmB,CAAC,yBAAyB,CAAC;YACnE,KAAK,EAAE,IAAI,CAAC,mBAAmB,CAAC,eAAe,CAAC;YAChD,IAAI,EAAE,IAAI,CAAC,mBAAmB,CAAC,cAAc,CAAC;YAC9C,OAAO,EAAE,IAAI,CAAC,mBAAmB,CAAC,UAAU,CAAC;YAC7C,cAAc,EAAE,IAAI,CAAC,mBAAmB,CAAC,iBAAiB,CAAC;YAC3D,WAAW,EAAE,IAAI,CAAC,mBAAmB,CAAC,cAAc,CAAC;YACrD,aAAa,EAAE,IAAI,CAAC,mBAAmB,CAAC,gBAAgB,CAAC;YACzD,QAAQ,EAAE,IAAI,CAAC,mBAAmB,CAAC,UAAU,CAAC;YAC9C,SAAS,EAAE,IAAI,CAAC,mBAAmB,CAAC,YAAY,CAAC;YACjD,UAAU,EAAE,IAAI,CAAC,mBAAmB,CAAC,aAAa,CAAC;YACnD,UAAU,EAAE,IAAI,CAAC,mBAAmB,CAAC,aAAa,CAAC;YACnD,WAAW,EAAE,IAAI,CAAC,mBAAmB,CAAC,cAAc,CAAC;YACrD,YAAY,EAAE,IAAI,CAAC,mBAAmB,CAAC,eAAe,CAAC;YACvD,aAAa,EAAE,IAAI,CAAC,mBAAmB,CAAC,gBAAgB,CAAC;YACzD,YAAY,EAAE,IAAI,CAAC,mBAAmB,CAAC,eAAe,CAAC;YACvD,cAAc,EAAE,IAAI,CAAC,mBAAmB,CAAC,iBAAiB,CAAC;YAC3D,SAAS,EAAE,IAAI,CAAC,mBAAmB,CAAC,YAAY,CAAC;YACjD,UAAU,EAAE,IAAI,CAAC,mBAAmB,CAAC,aAAa,CAAC;YACnD,UAAU,EAAE,IAAI,CAAC,mBAAmB,CAAC,aAAa,CAAC;YACnD,SAAS,EAAE,IAAI,CAAC,mBAAmB,CAAC,WAAW,CAAC;YAChD,YAAY,EAAE,IAAI,CAAC,mBAAmB,CAAC,eAAe,CAAC;YACvD,UAAU,EAAE,IAAI,CAAC,mBAAmB,CAAC,aAAa,CAAC;SACpD,CAAC;IACJ,CAAC;IAEO,iBAAiB;QACvB,IAAI,CAAC,SAAS,CAAC,SAAS,GAAG,IAAI,CAAC,sBAAsB,EAAE,CAAC;QACzD,IAAI,CAAC,SAAS,CAAC,iBAAiB,GAAG,IAAI,CAAC,yBAAyB,EAAE,CAAC;QACpE,IAAI,CAAC,SAAS,CAAC,kBAAkB,GAAG,IAAI,CAAC,0BAA0B,EAAE,CAAC;IACxE,CAAC;IAEO,kBAAkB;QACxB,IAAI,CAAC,UAAU,CAAC,KAAK,GAAG,IAAI,CAAC,wBAAwB,EAAE,CAAC;QACxD,IAAI,CAAC,UAAU,CAAC,KAAK,GAAG,IAAI,CAAC,wBAAwB,EAAE,CAAC;IAC1D,CAAC;IAED,IAAI,QAAQ;QACV,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;YACvC,OAAO,wBAAwB,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;QACtD,CAAC;QAED,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;YAC1C,OAAO,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC;QAC/B,CAAC;QAED,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,OAAO,CAAC,KAAU;QAChB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QACvB,KAAK,CAAC,MAAM,CAAC,GAAG,GAAG,6BAA6B,CAAC;IACnD,CAAC;IAED,IAAI,WAAW;QAOb,MAAM,IAAI,GAAG,EAAE,CAAC;QAEhB,IAAI,IAAI,CAAC,OAAO,EAAE,IAAI,EAAE,QAAQ,CAAC,UAAU,CAAC,EAAE,CAAC;YAC7C,IAAI,CAAC,IAAI,CAAC;gBACR,IAAI,EAAE,UAAU;gBAChB,IAAI,EAAE,SAAkB;gBACxB,KAAK,EAAE,SAAkB;aAC1B,CAAC,CAAC;QACL,CAAC;QAED,IAAI,IAAI,CAAC,OAAO,EAAE,IAAI,EAAE,QAAQ,CAAC,SAAS,CAAC,EAAE,CAAC;YAC5C,IAAI,CAAC,IAAI,CAAC;gBACR,IAAI,EAAE,SAAS;gBACf,IAAI,EAAE,SAAkB;gBACxB,KAAK,EAAE,SAAkB;gBACzB,QAAQ,EAAE,IAAI;gBACd,IAAI,EAAE,MAAM;aACb,CAAC,CAAC;QACL,CAAC;QAED,IAAI,IAAI,CAAC,OAAO,EAAE,IAAI,EAAE,QAAQ,CAAC,OAAO,CAAC,EAAE,CAAC;YAC1C,IAAI,CAAC,IAAI,CAAC;gBACR,IAAI,EAAE,OAAO;gBACb,IAAI,EAAE,SAAkB;gBACxB,KAAK,EAAE,MAAe;aACvB,CAAC,CAAC;QACL,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAEO,eAAe;QACrB,IAAI,IAAI,CAAC,OAAO,EAAE,IAAI,KAAK,UAAU,IAAI,IAAI,CAAC,OAAO,EAAE,YAAY,EAAE,CAAC;YACpE,OAAO,IAAI,CAAC,OAAO,EAAE,eAAe,IAAI,CAAC,CAAC;QAC5C,CAAC;QACD,OAAO,IAAI,CAAC,OAAO,EAAE,YAAY,IAAI,CAAC,CAAC;IACzC,CAAC;IAED,IAAI,WAAW;QACb,MAAM,KAAK,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QACrC,IAAI,KAAK,KAAK,CAAC;YAAE,OAAO,OAAO,CAAC;QAChC,IAAI,KAAK,IAAI,EAAE;YAAE,OAAO,SAAS,CAAC;QAClC,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,IAAI,gBAAgB;QAClB,QAAQ,IAAI,CAAC,WAAW,EAAE,CAAC;YACzB,KAAK,SAAS;gBACZ,OAAO,eAAe,CAAC;YACzB,KAAK,SAAS;gBACZ,OAAO,eAAe,CAAC;YACzB,KAAK,OAAO;gBACV,OAAO,aAAa,CAAC;YACvB;gBACE,OAAO,eAAe,CAAC;QAC3B,CAAC;IACH,CAAC;IAED,eAAe;QACb,MAAM,KAAK,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QACrC,IAAI,KAAK,GAAG,CAAC,EAAE,CAAC;YACd,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YACpC,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;gBACrB,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;gBACpC,IAAI,CAAC,WAAW,CAAC,gBAAgB,EAAE,CAAC;gBACpC,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC;YAC3D,CAAC;QACH,CAAC;IACH,CAAC;IAED,oBAAoB;QAClB,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE;YAAE,OAAO;QAE9C,IAAI,IAAI,GAAG,EAAE,UAAU,EAAE,IAAI,CAAC,OAAO,CAAC,EAAE,EAAE,CAAC;QAE3C,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;YAC3B,IAAI,CAAC,eAAe,EAAE,kBAAkB,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC;gBACvD,IAAI,EAAE,CAAC,QAAa,EAAE,EAAE;oBACtB,IAAI,QAAQ,EAAE,aAAa,EAAE,CAAC;wBAC5B,IAAI,CAAC,OAAO,CAAC,QAAQ,GAAG,IAAI,CAAC;wBAC7B,IAAI,CAAC,SAAS,EAAE,CAAC;wBACjB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;oBACjC,CAAC;gBACH,CAAC;aACF,CAAC,CAAC;QACL,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,eAAe,EAAE,qBAAqB,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC;gBAC1D,IAAI,EAAE,CAAC,QAAa,EAAE,EAAE;oBACtB,IAAI,QAAQ,EAAE,aAAa,EAAE,CAAC;wBAC5B,IAAI,CAAC,OAAO,CAAC,QAAQ,GAAG,KAAK,CAAC;wBAC9B,IAAI,CAAC,SAAS,EAAE,CAAC;wBACjB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;oBAClC,CAAC;gBACH,CAAC;aACF,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,oBAAoB;QAClB,IAAI,IAAI,CAAC,OAAO,EAAE,QAAQ,EAAE,CAAC;YAC3B,OAAO,MAAM,CAAC;QAChB,CAAC;QACD,OAAO,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC;IACtD,CAAC;IAED,SAAS;QACP,QAAQ;QACR,2BAA2B;QAC3B,qCAAqC;QACrC,QAAQ;QACR,uBAAuB;QACvB,kBAAkB;QAClB,iBAAiB;IACnB,CAAC;IAED,iBAAiB;QACf,IAAI,cAAc,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,IAAI,UAAU,CAAC;QACrD,MAAM,GAAG,GAAG,8BAA8B,IAAI,CAAC,OAAO,CAAC,EAAE,IAAI,cAAc,EAAE,CAAC;QAC9E,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;IAC7B,CAAC;IAED,mBAAmB;QACjB,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,EAAE,QAAQ,EAAE,IAAI,IAAI,WAAW,CAAC;QAC9D,IAAI,IAAI,CAAC,MAAM,EAAE,GAAG,KAAK,mBAAmB,EAAE,CAAC;YAC7C,MAAM,GAAG,GAAG,uBAAuB,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,IAAI,SAAS,EAAE,CAAC;YAC3E,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;QAC7B,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,MAAM,EAAE,QAAQ,EAAE,CAAC;gBACtB,qBAAqB;gBACrB,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE;gBACxB,SAAS;aACV,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,yBAAyB;QACvB,OAAO;YACL;gBACE,KAAK,EAAE,IAAI,CAAC,OAAO,EAAE,aAAa,IAAI,IAAI,CAAC,OAAO,EAAE,UAAU,IAAI,CAAC;gBACnE,KAAK,EAAE,YAAY;gBACnB,MAAM,EAAE,IAAI;aACb;SACF,CAAC;IACJ,CAAC;IAED,0BAA0B;QACxB,OAAO;YACL;gBACE,KAAK,EACH,IAAI,CAAC,OAAO,EAAE,cAAc,IAAI,IAAI,CAAC,OAAO,EAAE,eAAe,IAAI,CAAC;gBACpE,KAAK,EAAE,YAAY;gBACnB,MAAM,EAAE,IAAI;aACb;SACF,CAAC;IACJ,CAAC;IAED,QAAQ;QACN,OAAO,IAAI,CAAC,eAAe,EAAE,GAAG,CAAC,CAAC;IACpC,CAAC;IAED,iCAAiC;IACzB,mBAAmB,CAAC,IAAY;QACtC,OAAO,IAAI,GAAG,GAAG,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAC7D,CAAC;IACO,wBAAwB;QAC9B,OAAO,EAAE,CAAC;IACZ,CAAC;IACO,sBAAsB;QAC5B,OAAO;YACL,EAAE,KAAK,EAAE,IAAI,CAAC,eAAe,EAAE,EAAE,KAAK,EAAE,YAAY,EAAE,MAAM,EAAE,IAAI,EAAE;SACrE,CAAC;IACJ,CAAC;IAED,oCAAoC;IACpC,aAAa;QACX,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,+BAA+B;QAC7B,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,uBAAuB;QACrB,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,cAAc;QACZ,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,sBAAsB;QACpB,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,gBAAgB;QACd,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,uBAAuB;QACrB,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,oBAAoB;QAClB,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,sBAAsB;QACpB,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,iBAAiB;QACf,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,kBAAkB;QAChB,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,mBAAmB;QACjB,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,mBAAmB;QACjB,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,oBAAoB;QAClB,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,qBAAqB;QACnB,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,sBAAsB;QACpB,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,qBAAqB;QACnB,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,uBAAuB;QACrB,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,kBAAkB;QAChB,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,mBAAmB;QACjB,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,mBAAmB;QACjB,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,kBAAkB;QAChB,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,qBAAqB;QACnB,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,mBAAmB;QACjB,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,kBAAkB;QAChB,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,kBAAkB;QAChB,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,kBAAkB;QAChB,OAAO,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC;IACjC,CAAC;IACD,4BAA4B;QAC1B,OAAO,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC;IAC3C,CAAC;IACD,mBAAmB;QACjB,OAAO,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC;IAClC,CAAC;IACD,kBAAkB;QAChB,OAAO,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC;IACjC,CAAC;IACD,qBAAqB;QACnB,OAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC;IACpC,CAAC;IACD,4BAA4B;QAC1B,OAAO,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC;IAC3C,CAAC;IACD,yBAAyB;QACvB,OAAO,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC;IACxC,CAAC;IACD,2BAA2B;QACzB,OAAO,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC;IAC1C,CAAC;IACD,sBAAsB;QACpB,OAAO,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC;IACrC,CAAC;IACD,uBAAuB;QACrB,OAAO,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC;IACtC,CAAC;IACD,wBAAwB;QACtB,OAAO,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC;IACvC,CAAC;IACD,yBAAyB;QACvB,OAAO,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC;IACxC,CAAC;IACD,0BAA0B;QACxB,OAAO,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC;IACzC,CAAC;IACD,2BAA2B;QACzB,OAAO,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC;IAC1C,CAAC;IACD,0BAA0B;QACxB,OAAO,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC;IACzC,CAAC;IACD,4BAA4B;QAC1B,OAAO,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC;IAC3C,CAAC;IACD,uBAAuB;QACrB,OAAO,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC;IACtC,CAAC;IACD,wBAAwB;QACtB,OAAO,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC;IACvC,CAAC;IACD,wBAAwB;QACtB,OAAO,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC;IACvC,CAAC;IACD,uBAAuB;QACrB,OAAO,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC;IACtC,CAAC;IACD,0BAA0B;QACxB,OAAO,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC;IACzC,CAAC;IACD,wBAAwB;QACtB,OAAO,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC;IACvC,CAAC;IAED,iBAAiB;QACf,OAAO,IAAI,CAAC,sBAAsB,EAAE,CAAC;IACvC,CAAC;wGA5dU,oBAAoB,kBA6DrB,iBAAiB,aACjB,kBAAkB,aAClB,oBAAoB,aACpB,QAAQ;4FAhEP,oBAAoB,oWCnGjC,woNA6KA,2CDvFI,YAAY,8VACZ,aAAa,mGApDJ,qBAAqB,qFAXrB,kBAAkB,mDAsBlB,oBAAoB,yDA+C7B,6BAA6B,4HAC7B,eAAe;;4FAKN,oBAAoB;kBAjBhC,SAAS;+BACE,oBAAoB,cAClB,IAAI,WACP;wBACP,YAAY;wBACZ,aAAa;wBACb,iBAAiB;wBACjB,qBAAqB;wBACrB,aAAa;wBACb,kBAAkB;wBAClB,oBAAoB;wBACpB,6BAA6B;wBAC7B,eAAe;qBAChB,WACQ,CAAC,sBAAsB,CAAC;;0BAgE9B,MAAM;2BAAC,iBAAiB;;0BACxB,MAAM;2BAAC,kBAAkB;;0BACzB,MAAM;2BAAC,oBAAoB;;0BAC3B,MAAM;2BAAC,QAAQ;yCA/DT,OAAO;sBAAf,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,EAAE;sBAAV,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACI,WAAW;sBAApB,MAAM;gBACG,cAAc;sBAAvB,MAAM;gBACG,cAAc;sBAAvB,MAAM;gBA4EP,QAAQ;sBADP,YAAY;uBAAC,eAAe,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  OnInit,\n  SimpleChanges,\n  HostListener,\n  Inject,\n  Pipe,\n  PipeTransform,\n  CUSTOM_ELEMENTS_SCHEMA,\n} from \"@angular/core\";\nimport { CommonModule, TitleCasePipe } from \"@angular/common\";\nimport { IconComponent } from \"../icon/icon.component\";\nimport { DropiTagComponent } from \"../dropi-tag/dropi-tag.component\";\n// import { Howl } from \"howler\"; // Eliminado para evitar errores de dependencia\nimport { DropiIlustrationIconComponent } from \"../dropi-ilustration-icon/dropi-ilustration-icon.component\";\nimport { TranslateModule } from \"@ngx-translate/core\";\n\n@Pipe({\n  name: \"adjustName\",\n  standalone: true,\n})\nexport class AdjustNamePipeStub implements PipeTransform {\n  transform(value: any): any {\n    return value;\n  }\n}\n\n@Component({\n  selector: \"currency\",\n  standalone: true,\n  template: \"{{value}}\",\n})\nexport class CurrencyComponentStub {\n  @Input() value: any;\n  @Input() class: any;\n  @Input() style: any;\n}\n\n@Component({\n  selector: \"app-beta-tag\",\n  standalone: true,\n  template: \"\",\n})\nexport class BetaTagComponentStub {}\n\nexport interface ProductData {\n  id: string | number;\n  sku?: string;\n  name: string;\n  type?: string;\n  sale_price: number;\n  suggested_price: number;\n  private_product: boolean;\n  variation_stock?: number;\n  stock_simple: number;\n  is_variation: boolean;\n  favorite: boolean;\n  supplier: {\n    id: number;\n    name: string;\n    category_user: string;\n    icon?: \"verified\" | \"premium\" | \"exclusive\";\n  };\n  categories: Array<{\n    name: string;\n  }>;\n  private_user_stock?: number;\n  legacy_img?: boolean;\n  image: string;\n  category?: string;\n  stock?: number;\n  supplierPrice?: number;\n  suggestedPrice?: number;\n  imageUrl?: string;\n  isFavorite?: boolean;\n}\n\nexport type CardState = \"default\" | \"hover\" | \"select\";\n\n@Component({\n  selector: \"dropi-card-product\",\n  standalone: true,\n  imports: [\n    CommonModule,\n    IconComponent,\n    DropiTagComponent,\n    CurrencyComponentStub,\n    TitleCasePipe,\n    AdjustNamePipeStub,\n    BetaTagComponentStub,\n    DropiIlustrationIconComponent,\n    TranslateModule,\n  ],\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\n  templateUrl: \"./card-product.component.html\",\n})\nexport class CardProductComponent implements OnInit {\n  @Input() product!: ProductData;\n  @Input() state: CardState = \"default\";\n  @Input() aS: boolean = true;\n  @Input() bettaTester: boolean = false;\n  @Output() onAddToCart = new EventEmitter<ProductData>();\n  @Output() onProductClick = new EventEmitter<ProductData>();\n  @Output() changeFavorite = new EventEmitter<Boolean>();\n\n  public imageError = false;\n  public brandName: string = \"\";\n  public onFavoriteHover = false;\n\n  public randomClasses = {\n    card: \"\",\n    imageContainer: \"\",\n    image: \"\",\n    tags: \"\",\n    tagsRow: \"\",\n    favoriteButton: \"\",\n    productInfo: \"\",\n    productHeader: \"\",\n    category: \"\",\n    stockInfo: \"\",\n    stockLabel: \"\",\n    stockValue: \"\",\n    productName: \"\",\n    supplierInfo: \"\",\n    supplierLabel: \"\",\n    supplierName: \"\",\n    priceContainer: \"\",\n    priceItem: \"\",\n    priceLabel: \"\",\n    priceValue: \"\",\n    separator: \"\",\n    actionButton: \"\",\n    buttonText: \"\",\n  };\n\n  public mixedData = {\n    stockDivs: [] as Array<{ value: number; class: string; isReal: boolean }>,\n    supplierPriceDivs: [] as Array<{\n      value: number;\n      class: string;\n      isReal: boolean;\n    }>,\n    suggestedPriceDivs: [] as Array<{\n      value: number;\n      class: string;\n      isReal: boolean;\n    }>,\n  };\n\n  public fakeStyles = {\n    stock: \"\",\n    price: \"\",\n  };\n\n  public isMobile: boolean = false;\n\n  constructor(\n    @Inject(\"SettingsService\") private settingService: any,\n    @Inject(\"ProductstService\") private favoriteService: any,\n    @Inject(\"OrderManualService\") private orderManual: any,\n    @Inject(\"Router\") private router: any,\n  ) {}\n\n  ngOnInit() {\n    this.brandName =\n      this.settingService?.getBrandInfo()?.name?.toLowerCase() || \"dropi\";\n    this.generateRandomClasses();\n    this.generateFakeStyles();\n    this.generateMixedData();\n    this.checkScreenSize();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes[\"product\"] || changes[\"aS\"]) {\n      this.generateMixedData();\n    }\n  }\n\n  @HostListener(\"window:resize\", [\"$event\"])\n  onResize(event: any) {\n    this.checkScreenSize();\n  }\n\n  private checkScreenSize() {\n    this.isMobile = window.innerWidth <= 420;\n  }\n\n  private generateRandomClasses() {\n    this.randomClasses = {\n      card: this.generateRandomClass(\"dropi-card-product\"),\n      imageContainer: this.generateRandomClass(\"product-image-container\"),\n      image: this.generateRandomClass(\"product-image\"),\n      tags: this.generateRandomClass(\"product-tags\"),\n      tagsRow: this.generateRandomClass(\"tags-row\"),\n      favoriteButton: this.generateRandomClass(\"favorite-button\"),\n      productInfo: this.generateRandomClass(\"product-info\"),\n      productHeader: this.generateRandomClass(\"product-header\"),\n      category: this.generateRandomClass(\"category\"),\n      stockInfo: this.generateRandomClass(\"stock-info\"),\n      stockLabel: this.generateRandomClass(\"stock-label\"),\n      stockValue: this.generateRandomClass(\"stock-value\"),\n      productName: this.generateRandomClass(\"product-name\"),\n      supplierInfo: this.generateRandomClass(\"supplier-info\"),\n      supplierLabel: this.generateRandomClass(\"supplier-label\"),\n      supplierName: this.generateRandomClass(\"supplier-name\"),\n      priceContainer: this.generateRandomClass(\"price-container\"),\n      priceItem: this.generateRandomClass(\"price-item\"),\n      priceLabel: this.generateRandomClass(\"price-label\"),\n      priceValue: this.generateRandomClass(\"price-value\"),\n      separator: this.generateRandomClass(\"separator\"),\n      actionButton: this.generateRandomClass(\"action-button\"),\n      buttonText: this.generateRandomClass(\"button-text\"),\n    };\n  }\n\n  private generateMixedData() {\n    this.mixedData.stockDivs = this.generateMixedStockDivs();\n    this.mixedData.supplierPriceDivs = this.getMixedSupplierPriceDivs();\n    this.mixedData.suggestedPriceDivs = this.getMixedSuggestedPriceDivs();\n  }\n\n  private generateFakeStyles() {\n    this.fakeStyles.stock = this.generateFakeStyleVariant();\n    this.fakeStyles.price = this.generateFakeStyleVariant();\n  }\n\n  get imageUrl(): string | undefined {\n    if (this.product && this.product.image) {\n      return `https://img.dropi.co/${this.product.image}`;\n    }\n\n    if (this.product && this.product.imageUrl) {\n      return this.product.imageUrl;\n    }\n\n    return undefined;\n  }\n\n  onError(event: any) {\n    this.imageError = true;\n    event.target.src = \"./assets/utils/no-image.jpg\";\n  }\n\n  get productTags(): Array<{\n    text: string;\n    type: \"primary\" | \"secondary\";\n    state: \"default\" | \"warning\" | \"info\";\n    showIcon?: boolean;\n    icon?: string;\n  }> {\n    const tags = [];\n\n    if (this.product?.type?.includes(\"variable\")) {\n      tags.push({\n        text: \"Variable\",\n        type: \"primary\" as const,\n        state: \"default\" as const,\n      });\n    }\n\n    if (this.product?.type?.includes(\"privado\")) {\n      tags.push({\n        text: \"Privado\",\n        type: \"primary\" as const,\n        state: \"warning\" as const,\n        showIcon: true,\n        icon: \"Lock\",\n      });\n    }\n\n    if (this.product?.type?.includes(\"combo\")) {\n      tags.push({\n        text: \"Combo\",\n        type: \"primary\" as const,\n        state: \"info\" as const,\n      });\n    }\n\n    return tags;\n  }\n\n  private getProductStock(): number {\n    if (this.product?.type === \"VARIABLE\" && this.product?.is_variation) {\n      return this.product?.variation_stock || 0;\n    }\n    return this.product?.stock_simple || 0;\n  }\n\n  get stockStatus(): \"success\" | \"warning\" | \"error\" {\n    const stock = this.getProductStock();\n    if (stock === 0) return \"error\";\n    if (stock <= 10) return \"warning\";\n    return \"success\";\n  }\n\n  get stockStatusClass(): string {\n    switch (this.stockStatus) {\n      case \"success\":\n        return \"stock-success\";\n      case \"warning\":\n        return \"stock-warning\";\n      case \"error\":\n        return \"stock-error\";\n      default:\n        return \"stock-success\";\n    }\n  }\n\n  handleAddToCart(): void {\n    const stock = this.getProductStock();\n    if (stock > 0) {\n      this.onAddToCart.emit(this.product);\n      if (this.orderManual) {\n        this.orderManual.setModalOpen(true);\n        this.orderManual.clearProductsIds();\n        this.orderManual.setProductsIds(Number(this.product.id));\n      }\n    }\n  }\n\n  handleFavoriteToggle(): void {\n    if (!this.product || !this.product.id) return;\n\n    let body = { product_id: this.product.id };\n\n    if (!this.product.favorite) {\n      this.favoriteService?.addFavoriteProduct(body).subscribe({\n        next: (response: any) => {\n          if (response?.is_successful) {\n            this.product.favorite = true;\n            this.playAudio();\n            this.changeFavorite.emit(true);\n          }\n        },\n      });\n    } else {\n      this.favoriteService?.removeFavoriteProduct(body).subscribe({\n        next: (response: any) => {\n          if (response?.is_successful) {\n            this.product.favorite = false;\n            this.playAudio();\n            this.changeFavorite.emit(false);\n          }\n        },\n      });\n    }\n  }\n\n  getFavoriteIconColor(): string {\n    if (this.product?.favorite) {\n      return \"#fff\";\n    }\n    return this.onFavoriteHover ? \"#f49a3d\" : \"#858ea6\";\n  }\n\n  playAudio() {\n    // try {\n    //   let sound = new Howl({\n    //     src: [\"assets/audio/pop.mp3\"],\n    //   });\n    //   sound.volume(0.4);\n    //   sound.play();\n    // } catch (e) {}\n  }\n\n  getProductDetails(): void {\n    let nameProductUrl = this.product.name || \"producto\";\n    const url = `/dashboard/product-details/${this.product.id}/${nameProductUrl}`;\n    window.open(url, \"_blank\");\n  }\n\n  getProvidersDetails(): void {\n    const cleanName = this.product?.supplier?.name || \"proveedor\";\n    if (this.router?.url === \"/dashboard/search\") {\n      const url = `/dashboard/provider/${this.product.supplier.id}/${cleanName}`;\n      window.open(url, \"_blank\");\n    } else {\n      this.router?.navigate?.([\n        \"/dashboard/provider\",\n        this.product.supplier.id,\n        cleanName,\n      ]);\n    }\n  }\n\n  getMixedSupplierPriceDivs() {\n    return [\n      {\n        value: this.product?.supplierPrice || this.product?.sale_price || 0,\n        class: \"price-real\",\n        isReal: true,\n      },\n    ];\n  }\n\n  getMixedSuggestedPriceDivs() {\n    return [\n      {\n        value:\n          this.product?.suggestedPrice || this.product?.suggested_price || 0,\n        class: \"price-real\",\n        isReal: true,\n      },\n    ];\n  }\n\n  hasStock(): boolean {\n    return this.getProductStock() > 0;\n  }\n\n  // Helper fakes for anti-scraping\n  private generateRandomClass(base: string): string {\n    return base + \"-\" + Math.random().toString(36).slice(2, 7);\n  }\n  private generateFakeStyleVariant(): string {\n    return \"\";\n  }\n  private generateMixedStockDivs(): any[] {\n    return [\n      { value: this.getProductStock(), class: \"stock-real\", isReal: true },\n    ];\n  }\n\n  // Re-added missing template methods\n  getCardStyles() {\n    return {};\n  }\n  getRandomProviderCategoryStyles() {\n    return {};\n  }\n  getImageContainerStyles() {\n    return {};\n  }\n  getImageStyles() {\n    return {};\n  }\n  getTagsContainerStyles() {\n    return {};\n  }\n  getTagsRowStyles() {\n    return {};\n  }\n  getFavoriteButtonStyles() {\n    return {};\n  }\n  getProductInfoStyles() {\n    return {};\n  }\n  getProductHeaderStyles() {\n    return {};\n  }\n  getCategoryStyles() {\n    return {};\n  }\n  getStockInfoStyles() {\n    return {};\n  }\n  getStockLabelStyles() {\n    return {};\n  }\n  getStockValueStyles() {\n    return {};\n  }\n  getProductNameStyles() {\n    return {};\n  }\n  getSupplierInfoStyles() {\n    return {};\n  }\n  getSupplierLabelStyles() {\n    return {};\n  }\n  getSupplierNameStyles() {\n    return {};\n  }\n  getPriceContainerStyles() {\n    return {};\n  }\n  getPriceItemStyles() {\n    return {};\n  }\n  getPriceLabelStyles() {\n    return {};\n  }\n  getPriceValueStyles() {\n    return {};\n  }\n  getSeparatorStyles() {\n    return {};\n  }\n  getActionButtonStyles() {\n    return {};\n  }\n  getButtonTextStyles() {\n    return {};\n  }\n  getFakeStockStyles() {\n    return {};\n  }\n  getFakePriceStyles() {\n    return {};\n  }\n\n  getRandomCardClass() {\n    return this.randomClasses.card;\n  }\n  getRandomImageContainerClass() {\n    return this.randomClasses.imageContainer;\n  }\n  getRandomImageClass() {\n    return this.randomClasses.image;\n  }\n  getRandomTagsClass() {\n    return this.randomClasses.tags;\n  }\n  getRandomTagsRowClass() {\n    return this.randomClasses.tagsRow;\n  }\n  getRandomFavoriteButtonClass() {\n    return this.randomClasses.favoriteButton;\n  }\n  getRandomProductInfoClass() {\n    return this.randomClasses.productInfo;\n  }\n  getRandomProductHeaderClass() {\n    return this.randomClasses.productHeader;\n  }\n  getRandomCategoryClass() {\n    return this.randomClasses.category;\n  }\n  getRandomStockInfoClass() {\n    return this.randomClasses.stockInfo;\n  }\n  getRandomStockLabelClass() {\n    return this.randomClasses.stockLabel;\n  }\n  getRandomProductNameClass() {\n    return this.randomClasses.productName;\n  }\n  getRandomSupplierInfoClass() {\n    return this.randomClasses.supplierInfo;\n  }\n  getRandomSupplierLabelClass() {\n    return this.randomClasses.supplierLabel;\n  }\n  getRandomSupplierNameClass() {\n    return this.randomClasses.supplierName;\n  }\n  getRandomPriceContainerClass() {\n    return this.randomClasses.priceContainer;\n  }\n  getRandomPriceItemClass() {\n    return this.randomClasses.priceItem;\n  }\n  getRandomPriceLabelClass() {\n    return this.randomClasses.priceLabel;\n  }\n  getRandomPriceValueClass() {\n    return this.randomClasses.priceValue;\n  }\n  getRandomSeparatorClass() {\n    return this.randomClasses.separator;\n  }\n  getRandomActionButtonClass() {\n    return this.randomClasses.actionButton;\n  }\n  getRandomButtonTextClass() {\n    return this.randomClasses.buttonText;\n  }\n\n  getMixedStockDivs() {\n    return this.generateMixedStockDivs();\n  }\n}\n","<div [class]=\"getRandomCardClass()\" [style]=\"getCardStyles()\" (click)=\"getProductDetails()\">\n  <app-beta-tag *ngIf=\"bettaTester\"></app-beta-tag>\n  <!-- Contenedor de imagen con altura fija de 214px como en Figma -->\n  <div [class]=\"getRandomImageContainerClass()\" [style]=\"getImageContainerStyles()\">\n    <div [class]=\"getRandomImageClass()\" [style]=\"getImageStyles()\">\n      <!-- Imagen del producto con manejo de errores -->\n      <img\n        [src]=\"imageUrl\"\n        [alt]=\"product?.name || 'Product Image'\"\n        (error)=\"onError($event)\"\n        [ngClass]=\"{ 'error-img': imageError }\"\n        style=\"width: 100%; height: 100%; object-fit: cover; border-radius: 8px\"\n      />\n\n      <!-- Tags superpuestos en la esquina superior izquierda -->\n      <div\n        [class]=\"getRandomTagsClass()\"\n        [style]=\"getTagsContainerStyles()\"\n        *ngIf=\"productTags?.length > 0\"\n      >\n        <div [class]=\"getRandomTagsRowClass()\" [style]=\"getTagsRowStyles()\">\n          <app-dropi-tag\n            *ngFor=\"let tag of productTags.slice(0, 2)\"\n            [type]=\"tag?.type\"\n            [state]=\"tag?.state\"\n            [showIcon]=\"tag?.showIcon\"\n            [icon]=\"tag?.icon\"\n            [text]=\"tag?.text\"\n          >\n          </app-dropi-tag>\n        </div>\n      </div>\n\n      <!-- Botón de favorito superpuesto en la esquina inferior derecha -->\n      <div\n        [class]=\"getRandomFavoriteButtonClass()\"\n        [ngClass]=\"{ 'favorite-button': true, 'favorite-active': product?.favorite }\"\n        [style]=\"getFavoriteButtonStyles()\"\n        (click)=\"handleFavoriteToggle(); $event.stopPropagation()\"\n      >\n        <app-icon\n          [name]=\"product?.favorite ? 'Heart-solid' : 'Heart'\"\n          width=\"18px\"\n          height=\"18px\"\n          [color]=\"product?.favorite ? '#fff' : '#858ea6'\"\n          [style]=\"{ display: 'flex', 'align-items': 'center', 'justify-content': 'center' }\"\n        >\n        </app-icon>\n      </div>\n    </div>\n  </div>\n\n  <!-- Información del producto -->\n  <div [class]=\"getRandomProductInfoClass()\" [style]=\"getProductInfoStyles()\">\n    <!-- Header con categoría y stock -->\n    <div [class]=\"getRandomProductHeaderClass()\" [style]=\"getProductHeaderStyles()\">\n      <dropi-ilustration-icon\n        *ngIf=\"product?.supplier?.icon\"\n        [style]=\"getRandomProviderCategoryStyles()\"\n        [type]=\"'insignia'\"\n        [stateInsignia]=\"product?.supplier?.icon\"\n        [tagProduct]=\"true\"\n      ></dropi-ilustration-icon>\n\n      <span\n        [class]=\"getRandomCategoryClass()\"\n        [style]=\"getCategoryStyles()\"\n        *ngIf=\"product?.categories && product?.categories.length > 0\"\n        >{{ product?.categories[0]?.name | adjustName }}</span\n      >\n\n      <div [class]=\"getRandomStockInfoClass()\" [style]=\"getStockInfoStyles()\">\n        <span [class]=\"getRandomStockLabelClass()\" [style]=\"getStockLabelStyles()\">{{ \"stock\" | translate }}:</span>\n\n        <!-- Stocks mezclados aleatoriamente (real + falsos) -->\n        <span\n          *ngFor=\"let stockItem of getMixedStockDivs()\"\n          [class]=\"stockItem.class\"\n          [style]=\"stockItem.isReal ? getStockValueStyles() : getFakeStockStyles()\"\n        >\n          {{ stockItem.value }}\n        </span>\n\n        <span\n          *ngIf=\"product?.private_user_stock && product?.private_user_stock > 0\"\n          class=\"stock-private-user\"\n          [style]=\"{\n            'font-weight': '500',\n            padding: '0px 6px',\n            'margin-left': '6px',\n            'border-radius': '4px',\n            background: 'var(--Success-Success-50, #e7f8f3)',\n            color: 'var(--Success-Success-500, #0abb87)',\n            'text-align': 'center'\n          }\"\n        >\n          {{ product?.private_user_stock }}\n        </span>\n      </div>\n    </div>\n\n    <!-- Nombre del producto -->\n    <h3 [class]=\"getRandomProductNameClass()\" [style]=\"getProductNameStyles()\">\n      {{ product?.name | adjustName }}\n    </h3>\n\n    <!-- Proveedor -->\n    <div [class]=\"getRandomSupplierInfoClass()\" [style]=\"getSupplierInfoStyles()\">\n      <span [class]=\"getRandomSupplierLabelClass()\" [style]=\"getSupplierLabelStyles()\"\n        >{{ \"supplier\" | translate }}:</span\n      >\n      <span\n        [class]=\"getRandomSupplierNameClass()\"\n        [style]=\"getSupplierNameStyles()\"\n        (click)=\"getProvidersDetails(); $event.stopPropagation()\"\n        >{{ product?.supplier?.name | adjustName }}</span\n      >\n    </div>\n\n    <!-- Precios -->\n    <div [class]=\"getRandomPriceContainerClass()\" [style]=\"getPriceContainerStyles()\">\n      <div [class]=\"getRandomPriceItemClass()\" [style]=\"getPriceItemStyles()\">\n        <span [class]=\"getRandomPriceLabelClass()\" [style]=\"getPriceLabelStyles()\"\n          >{{ \"supplier price\" | translate }}</span\n        >\n\n        <!-- Precios de proveedor mezclados aleatoriamente (real + falsos) -->\n        <currency\n          *ngFor=\"let priceItem of getMixedSupplierPriceDivs()\"\n          [class]=\"priceItem.class\"\n          [style]=\"priceItem.isReal ? getPriceValueStyles() : getFakePriceStyles()\"\n          [value]=\"priceItem.value\"\n        >\n        </currency>\n      </div>\n      <div [class]=\"getRandomPriceItemClass()\" [style]=\"getPriceItemStyles()\">\n        <span [class]=\"getRandomPriceLabelClass()\" [style]=\"getPriceLabelStyles()\"\n          >{{ \"suggested price\" | translate }}</span\n        >\n\n        <!-- Precios sugeridos mezclados aleatoriamente (real + falsos) -->\n        <currency\n          *ngFor=\"let priceItem of getMixedSuggestedPriceDivs()\"\n          [class]=\"priceItem.class\"\n          [style]=\"priceItem.isReal ? getPriceValueStyles() : getFakePriceStyles()\"\n          [value]=\"priceItem.value\"\n        >\n        </currency>\n      </div>\n    </div>\n  </div>\n\n  <!-- Separador horizontal -->\n  <div [class]=\"getRandomSeparatorClass()\" [style]=\"getSeparatorStyles()\"></div>\n\n  <!-- Botón de acción principal -->\n  <div\n    [class]=\"getRandomActionButtonClass()\"\n    [style]=\"getActionButtonStyles()\"\n    (click)=\"handleAddToCart(); $event.stopPropagation()\"\n  >\n    <app-icon\n      name=\"Shopping-cart-arrow-rigth\"\n      width=\"20px\"\n      height=\"20px\"\n      color=\"#f49a3d\"\n      [style]=\"{ display: 'flex', 'align-items': 'center', 'justify-content': 'center' }\"\n    ></app-icon>\n    <span [class]=\"getRandomButtonTextClass()\" [style]=\"getButtonTextStyles()\"\n      >{{ \"send to client\" | translate }}</span\n    >\n  </div>\n</div>\n"]}
|