@sapphire-ion/framework 1.0.33 → 1.0.34
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/default/default-table/th-filter/th-filter.component.mjs +1 -1
- package/esm2022/lib/components/drawer/drawer.component.mjs +2 -2
- package/esm2022/lib/components/inputs/input-color/input-color.component.mjs +1 -1
- package/esm2022/lib/components/inputs/input-date/input-date.component.mjs +3 -3
- package/esm2022/lib/components/inputs/input-select/input-select.component.mjs +22 -6
- package/esm2022/lib/components/inputs/input-select/input.select.configuration.mjs +16 -1
- package/esm2022/lib/components/main-content/main-content.component.mjs +1 -1
- package/esm2022/lib/components/popover/sion-popover/sion-popover.component.mjs +118 -108
- package/esm2022/lib/components/popover/sion-popover.module.mjs +3 -6
- package/fesm2022/sapphire-ion-framework.mjs +162 -124
- package/fesm2022/sapphire-ion-framework.mjs.map +1 -1
- package/lib/components/inputs/input-select/input-select.component.d.ts +4 -1
- package/lib/components/inputs/input-select/input.select.configuration.d.ts +19 -0
- package/lib/components/popover/sion-popover/sion-popover.component.d.ts +21 -13
- package/package.json +1 -1
- package/themes/components/popover/sion-popover/sion-popover.component.scss +14 -32
|
@@ -74,7 +74,7 @@ export class MainContentComponent {
|
|
|
74
74
|
}
|
|
75
75
|
}
|
|
76
76
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MainContentComponent, deps: [{ token: i1.AuthService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
77
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: MainContentComponent, isStandalone: true, selector: "main-content", inputs: { backdrop: "backdrop", shadowColor: "shadowColor", colapsed: "colapsed", drawerComponent: "drawerComponent" }, viewQueries: [{ propertyName: "FullScreenConteiner", first: true, predicate: ["target"], descendants: true }], ngImport: i0, template: "<div class=\"size-full flex flex-col\" [ngClass]=\"{'bg-light/50': fullScreen}\" #target>\r\n <div class=\"w-full h-14 relative shrink-0\">\r\n <ion-card class=\"m-0 rounded-none size-full border-none\">\r\n <ion-card-content class=\"p-0 px-2 size-full flex\">\r\n <div class=\"w-1/2 h-full flex items-center justify-start\">\r\n @if (!fullScreen) {\r\n <ion-menu-button [routerLink]=\"['/']\" [autoHide]=\"true\"></ion-menu-button>\r\n }\r\n <ng-content select=\"[slot=start]\"></ng-content>\r\n </div>\r\n\r\n <div class=\"w-1/2 h-full flex items-center justify-end gap-2\">\r\n <ng-content select=\"[slot=end]\"></ng-content>\r\n\r\n <ion-button (click)=\"FullScreen()\" fill=\"outline\" color=\"dark\" size=\"small\" class=\"size-10 aspect-square portrait:hidden\">\r\n <ion-icon slot=\"icon-only\" name=\"expand\"></ion-icon>\r\n </ion-button>\r\n\r\n\r\n @if (!fullScreen) {\r\n <div #anchor>\r\n <ion-button (click)=\"userPopover.present($event)\" size=\"small\" class=\"size-10 aspect-square\">\r\n <span class=\"uppercase text-white\">{{Token ? Token.Nome[0] : ''}}</span>\r\n </ion-button>\r\n </div>\r\n <sion-popover #userPopover [anchor]=\"anchor\" [flip]=\"false\" width=\"13rem\">\r\n <div class=\"w-full flex flex-col overflow-hidden\">\r\n <div class=\"w-full flex p-2 gap-2 overflow-hidden\">\r\n <div class=\"size-10 shrink-0 aspect-square rounded-2xl text-sm flex items-center justify-center bg-primary\">\r\n <span class=\"uppercase text-white\">{{Token ? Token.Nome[0] : ''}}</span>\r\n </div>\r\n\r\n <div class=\"shrink-0 w-full flex flex-col justify-center items-start overflow-hidden text-sm\">\r\n <span class=\"truncate\"> {{Token ? Token.Nome : ''}} </span>\r\n <span class=\"truncate text-secondary\"> @{{Token ? Token.Apelido : ''}} </span>\r\n </div>\r\n </div>\r\n\r\n <div class=\"w-full\">\r\n <ng-content class=\"size-full\" select=\"[slot=user-popover]\"></ng-content>\r\n </div>\r\n\r\n <div class=\"w-full p-1 !pb-0 translucid-border !border-x-0 !border-b-0\">\r\n <div class=\"rounded-xl flex gap-2 items-center justify-start default-transition py-1 px-2\">\r\n <ion-icon name=\"contrast\"></ion-icon>\r\n <ion-text> Tema </ion-text>\r\n </div>\r\n\r\n <div class=\"flex flex-col pl-4\">\r\n <ion-radio-group alignment=\"start\" [allowEmptySelection]=\"false\" [value]=\"Theme\" (ionChange)=\"SetTheme($event.detail.value)\">\r\n <ion-item class=\"bg-transparent\" lines=\"full\">\r\n <ion-icon name=\"cog\" slot=\"start\"></ion-icon>\r\n <ion-radio class=\"w-full\" [value]=\"0\">Sistema</ion-radio>\r\n </ion-item>\r\n <ion-item class=\"bg-transparent\" lines=\"full\">\r\n <ion-icon name=\"sunny\" slot=\"start\"></ion-icon>\r\n <ion-radio class=\"w-full\" [value]=\"1\">Claro</ion-radio>\r\n </ion-item>\r\n <ion-item class=\"bg-transparent\" lines=\"none\">\r\n <ion-icon name=\"moon\" slot=\"start\"></ion-icon>\r\n <ion-radio class=\"w-full\" [value]=\"2\">Escuro</ion-radio>\r\n </ion-item>\r\n </ion-radio-group>\r\n\r\n\r\n <!-- <div class=\"w-full p-1 translucid-border !border-x-0 !border-b-0 overflow-hidden\">\r\n <div class=\"rounded-xl flex gap-2 items-center justify-start cursor-pointer hover:bg-medium/30 default-transition py-1 px-2\">\r\n <ion-checkbox [checked]=\"Theme == 0\" (ionChange)=\"SetTheme(0)\" ></ion-checkbox>\r\n <ion-icon name=\"cog\"></ion-icon>\r\n <ion-text> Sistema </ion-text>\r\n </div>\r\n </div>\r\n <div class=\"w-full p-1 translucid-border !border-x-0 !border-b-0 overflow-hidden\">\r\n <div class=\"rounded-xl flex gap-2 items-center justify-start cursor-pointer hover:bg-medium/30 default-transition py-1 px-2\">\r\n <ion-checkbox [checked]=\"Theme == 1\" (ionChange)=\"SetTheme(1)\" ></ion-checkbox>\r\n <ion-icon name=\"sunny\"></ion-icon>\r\n <ion-text> Claro </ion-text>\r\n </div>\r\n </div>\r\n <div class=\"w-full p-1 translucid-border !border-x-0 !border-b-0 overflow-hidden\">\r\n <div class=\"rounded-xl flex gap-2 items-center justify-start cursor-pointer hover:bg-medium/30 default-transition py-1 px-2\">\r\n <ion-checkbox [checked]=\"Theme == 2\" (ionChange)=\"SetTheme(2)\" ></ion-checkbox>\r\n <ion-icon name=\"moon\"></ion-icon>\r\n <ion-text> Escuro </ion-text>\r\n </div>\r\n </div> -->\r\n </div>\r\n </div>\r\n\r\n\r\n <div class=\"w-full p-1 translucid-border !border-x-0 !border-b-0\">\r\n <div (click)=\"authService.Loggout()\" class=\"rounded-xl flex gap-2 cursor-pointer items-center justify-start hover:bg-medium/10 default-transition py-1 px-2\">\r\n <ion-icon color=\"danger\" name=\"exit\"></ion-icon>\r\n <ion-text> Log Out </ion-text>\r\n </div>\r\n\r\n <!-- <ion-text> Log Out </ion-text>\r\n <ion-button (click)=\"authService.Loggout()\" class=\"size-8 shrink-0\" size=\"small\" fill=\"clear\" color=\"danger\">\r\n <ion-icon slot=\"icon-only\" name=\"exit-outline\"></ion-icon> \r\n </ion-button> -->\r\n </div>\r\n </div>\r\n\r\n <!-- <div class=\"size-full\">\r\n <div class=\"w-full p-1 flex items-center\">\r\n <div class=\"size-10 shrink-0 aspect-square rounded-2xl text-sm flex items-center justify-center default-transition\" style=\"background-color: var(--ion-color-primary);\">\r\n <span class=\"uppercase text-white\">{{Token ? Token.Nome[0] : ''}}</span>\r\n </div>\r\n <div class=\"grow min-w-10 p-2 justify-center items-center whitespace-nowrap text-ellipsis overflow-hidden block default-transition\" [ngClass]=\"{'opacity-0 w-0': colapsed}\">\r\n <span>{{Token ? Token.Nome : ''}}</span> <br>\r\n <ion-text color=\"secondary\" class=\"text-sm\">\r\n @{{Token ? Token.Apelido : ''}}\r\n </ion-text>\r\n </div>\r\n </div>\r\n <div class=\"w-full\">\r\n <ng-content class=\"size-full\" select=\"[slot=user-popover]\"></ng-content>\r\n </div>\r\n <div class=\"w-full p-1 px-2 translucid-border !border-x-0 !border-b-0 flex items-center justify-between\">\r\n <div class=\"hover:bg-medium/30 default-transition size-full\">\r\n <ion-button color=\"dark\" fill=\"clear\" size=\"small\" class=\"rounded-xl w-full text-left overflow-hidden\">\r\n <ion-icon slot=\"start\" name=\"contrast\"></ion-icon>\r\n <ion-label class=\"text-sm\">Tema</ion-label>\r\n </ion-button>\r\n </div>\r\n </div>\r\n <div class=\"w-full p-1 px-2 translucid-border !border-x-0 !border-b-0 flex items-center justify-between\">\r\n <ion-text> Log Out </ion-text>\r\n <ion-button (click)=\"authService.Loggout()\" class=\"size-8 shrink-0\" size=\"small\" fill=\"clear\" color=\"danger\">\r\n <ion-icon slot=\"icon-only\" name=\"exit-outline\"></ion-icon> \r\n </ion-button>\r\n </div>\r\n </div> -->\r\n </sion-popover>\r\n }\r\n </div>\r\n </ion-card-content>\r\n </ion-card>\r\n </div>\r\n <div class=\"size-full relative p-2 pt-0 bg-light\">\r\n <div class=\"size-full relative rounded-2xl content-shadow overflow-hidden {{backdrop}}\" style=\"--shadow-color: {{shadowColor}}\">\r\n <ng-content></ng-content> \r\n </div>\r\n </div>\r\n</div>", styles: ["#popover-user{--width: 17rem}.content-shadow{--shadow-color: color-mix(in srgb, var(--ion-color-primary) 15%, transparent);box-shadow:0 0 0 1px var(--shadow-color),0 6px 10px -4px var(--shadow-color)}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: IonicModule }, { kind: "component", type: i3.IonButton, selector: "ion-button", inputs: ["buttonType", "color", "disabled", "download", "expand", "fill", "form", "href", "mode", "rel", "routerAnimation", "routerDirection", "shape", "size", "strong", "target", "type"] }, { kind: "component", type: i3.IonCard, selector: "ion-card", inputs: ["button", "color", "disabled", "download", "href", "mode", "rel", "routerAnimation", "routerDirection", "target", "type"] }, { kind: "component", type: i3.IonCardContent, selector: "ion-card-content", inputs: ["mode"] }, { kind: "component", type: i3.IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }, { kind: "component", type: i3.IonItem, selector: "ion-item", inputs: ["button", "color", "detail", "detailIcon", "disabled", "download", "href", "lines", "mode", "rel", "routerAnimation", "routerDirection", "target", "type"] }, { kind: "component", type: i3.IonMenuButton, selector: "ion-menu-button", inputs: ["autoHide", "color", "disabled", "menu", "mode", "type"] }, { kind: "component", type: i3.IonRadio, selector: "ion-radio", inputs: ["alignment", "color", "disabled", "justify", "labelPlacement", "mode", "name", "value"] }, { kind: "component", type: i3.IonRadioGroup, selector: "ion-radio-group", inputs: ["allowEmptySelection", "compareWith", "errorText", "helperText", "name", "value"] }, { kind: "component", type: i3.IonText, selector: "ion-text", inputs: ["color", "mode"] }, { kind: "directive", type: i3.SelectValueAccessor, selector: "ion-select, ion-radio-group, ion-segment, ion-datetime" }, { kind: "directive", type: i3.RouterLinkDelegate, selector: ":not(a):not(area)[routerLink]" }, { kind: "directive", type: RouterLinkWithHref, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "ngmodule", type: SIonPopoverModule }, { kind: "component", type: i4.SIonPopoverComponent, selector: "sion-popover", inputs: ["fill", "arrow", "flip", "placement", "height", "width", "anchor"], outputs: ["onWillPresent", "onDidPresent", "onWillDismiss", "onDidDismiss", "isVisibleChange"] }] }); }
|
|
77
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: MainContentComponent, isStandalone: true, selector: "main-content", inputs: { backdrop: "backdrop", shadowColor: "shadowColor", colapsed: "colapsed", drawerComponent: "drawerComponent" }, viewQueries: [{ propertyName: "FullScreenConteiner", first: true, predicate: ["target"], descendants: true }], ngImport: i0, template: "<div class=\"size-full flex flex-col\" [ngClass]=\"{'bg-light/50': fullScreen}\" #target>\r\n <div class=\"w-full h-14 relative shrink-0\">\r\n <ion-card class=\"m-0 rounded-none size-full border-none\">\r\n <ion-card-content class=\"p-0 px-2 size-full flex\">\r\n <div class=\"w-1/2 h-full flex items-center justify-start\">\r\n @if (!fullScreen) {\r\n <ion-menu-button [routerLink]=\"['/']\" [autoHide]=\"true\"></ion-menu-button>\r\n }\r\n <ng-content select=\"[slot=start]\"></ng-content>\r\n </div>\r\n\r\n <div class=\"w-1/2 h-full flex items-center justify-end gap-2\">\r\n <ng-content select=\"[slot=end]\"></ng-content>\r\n\r\n <ion-button (click)=\"FullScreen()\" fill=\"outline\" color=\"dark\" size=\"small\" class=\"size-10 aspect-square portrait:hidden\">\r\n <ion-icon slot=\"icon-only\" name=\"expand\"></ion-icon>\r\n </ion-button>\r\n\r\n\r\n @if (!fullScreen) {\r\n <div #anchor>\r\n <ion-button (click)=\"userPopover.present($event)\" size=\"small\" class=\"size-10 aspect-square\">\r\n <span class=\"uppercase text-white\">{{Token ? Token.Nome[0] : ''}}</span>\r\n </ion-button>\r\n </div>\r\n <sion-popover #userPopover [anchor]=\"anchor\" [flip]=\"false\" width=\"13rem\">\r\n <div class=\"w-full flex flex-col overflow-hidden\">\r\n <div class=\"w-full flex p-2 gap-2 overflow-hidden\">\r\n <div class=\"size-10 shrink-0 aspect-square rounded-2xl text-sm flex items-center justify-center bg-primary\">\r\n <span class=\"uppercase text-white\">{{Token ? Token.Nome[0] : ''}}</span>\r\n </div>\r\n\r\n <div class=\"shrink-0 w-full flex flex-col justify-center items-start overflow-hidden text-sm\">\r\n <span class=\"truncate\"> {{Token ? Token.Nome : ''}} </span>\r\n <span class=\"truncate text-secondary\"> @{{Token ? Token.Apelido : ''}} </span>\r\n </div>\r\n </div>\r\n\r\n <div class=\"w-full\">\r\n <ng-content class=\"size-full\" select=\"[slot=user-popover]\"></ng-content>\r\n </div>\r\n\r\n <div class=\"w-full p-1 !pb-0 translucid-border !border-x-0 !border-b-0\">\r\n <div class=\"rounded-xl flex gap-2 items-center justify-start default-transition py-1 px-2\">\r\n <ion-icon name=\"contrast\"></ion-icon>\r\n <ion-text> Tema </ion-text>\r\n </div>\r\n\r\n <div class=\"flex flex-col pl-4\">\r\n <ion-radio-group alignment=\"start\" [allowEmptySelection]=\"false\" [value]=\"Theme\" (ionChange)=\"SetTheme($event.detail.value)\">\r\n <ion-item class=\"bg-transparent\" lines=\"full\">\r\n <ion-icon name=\"cog\" slot=\"start\"></ion-icon>\r\n <ion-radio class=\"w-full\" [value]=\"0\">Sistema</ion-radio>\r\n </ion-item>\r\n <ion-item class=\"bg-transparent\" lines=\"full\">\r\n <ion-icon name=\"sunny\" slot=\"start\"></ion-icon>\r\n <ion-radio class=\"w-full\" [value]=\"1\">Claro</ion-radio>\r\n </ion-item>\r\n <ion-item class=\"bg-transparent\" lines=\"none\">\r\n <ion-icon name=\"moon\" slot=\"start\"></ion-icon>\r\n <ion-radio class=\"w-full\" [value]=\"2\">Escuro</ion-radio>\r\n </ion-item>\r\n </ion-radio-group>\r\n\r\n\r\n <!-- <div class=\"w-full p-1 translucid-border !border-x-0 !border-b-0 overflow-hidden\">\r\n <div class=\"rounded-xl flex gap-2 items-center justify-start cursor-pointer hover:bg-medium/30 default-transition py-1 px-2\">\r\n <ion-checkbox [checked]=\"Theme == 0\" (ionChange)=\"SetTheme(0)\" ></ion-checkbox>\r\n <ion-icon name=\"cog\"></ion-icon>\r\n <ion-text> Sistema </ion-text>\r\n </div>\r\n </div>\r\n <div class=\"w-full p-1 translucid-border !border-x-0 !border-b-0 overflow-hidden\">\r\n <div class=\"rounded-xl flex gap-2 items-center justify-start cursor-pointer hover:bg-medium/30 default-transition py-1 px-2\">\r\n <ion-checkbox [checked]=\"Theme == 1\" (ionChange)=\"SetTheme(1)\" ></ion-checkbox>\r\n <ion-icon name=\"sunny\"></ion-icon>\r\n <ion-text> Claro </ion-text>\r\n </div>\r\n </div>\r\n <div class=\"w-full p-1 translucid-border !border-x-0 !border-b-0 overflow-hidden\">\r\n <div class=\"rounded-xl flex gap-2 items-center justify-start cursor-pointer hover:bg-medium/30 default-transition py-1 px-2\">\r\n <ion-checkbox [checked]=\"Theme == 2\" (ionChange)=\"SetTheme(2)\" ></ion-checkbox>\r\n <ion-icon name=\"moon\"></ion-icon>\r\n <ion-text> Escuro </ion-text>\r\n </div>\r\n </div> -->\r\n </div>\r\n </div>\r\n\r\n\r\n <div class=\"w-full p-1 translucid-border !border-x-0 !border-b-0\">\r\n <div (click)=\"authService.Loggout()\" class=\"rounded-xl flex gap-2 cursor-pointer items-center justify-start hover:bg-medium/10 default-transition py-1 px-2\">\r\n <ion-icon color=\"danger\" name=\"exit\"></ion-icon>\r\n <ion-text> Log Out </ion-text>\r\n </div>\r\n\r\n <!-- <ion-text> Log Out </ion-text>\r\n <ion-button (click)=\"authService.Loggout()\" class=\"size-8 shrink-0\" size=\"small\" fill=\"clear\" color=\"danger\">\r\n <ion-icon slot=\"icon-only\" name=\"exit-outline\"></ion-icon> \r\n </ion-button> -->\r\n </div>\r\n </div>\r\n\r\n <!-- <div class=\"size-full\">\r\n <div class=\"w-full p-1 flex items-center\">\r\n <div class=\"size-10 shrink-0 aspect-square rounded-2xl text-sm flex items-center justify-center default-transition\" style=\"background-color: var(--ion-color-primary);\">\r\n <span class=\"uppercase text-white\">{{Token ? Token.Nome[0] : ''}}</span>\r\n </div>\r\n <div class=\"grow min-w-10 p-2 justify-center items-center whitespace-nowrap text-ellipsis overflow-hidden block default-transition\" [ngClass]=\"{'opacity-0 w-0': colapsed}\">\r\n <span>{{Token ? Token.Nome : ''}}</span> <br>\r\n <ion-text color=\"secondary\" class=\"text-sm\">\r\n @{{Token ? Token.Apelido : ''}}\r\n </ion-text>\r\n </div>\r\n </div>\r\n <div class=\"w-full\">\r\n <ng-content class=\"size-full\" select=\"[slot=user-popover]\"></ng-content>\r\n </div>\r\n <div class=\"w-full p-1 px-2 translucid-border !border-x-0 !border-b-0 flex items-center justify-between\">\r\n <div class=\"hover:bg-medium/30 default-transition size-full\">\r\n <ion-button color=\"dark\" fill=\"clear\" size=\"small\" class=\"rounded-xl w-full text-left overflow-hidden\">\r\n <ion-icon slot=\"start\" name=\"contrast\"></ion-icon>\r\n <ion-label class=\"text-sm\">Tema</ion-label>\r\n </ion-button>\r\n </div>\r\n </div>\r\n <div class=\"w-full p-1 px-2 translucid-border !border-x-0 !border-b-0 flex items-center justify-between\">\r\n <ion-text> Log Out </ion-text>\r\n <ion-button (click)=\"authService.Loggout()\" class=\"size-8 shrink-0\" size=\"small\" fill=\"clear\" color=\"danger\">\r\n <ion-icon slot=\"icon-only\" name=\"exit-outline\"></ion-icon> \r\n </ion-button>\r\n </div>\r\n </div> -->\r\n </sion-popover>\r\n }\r\n </div>\r\n </ion-card-content>\r\n </ion-card>\r\n </div>\r\n <div class=\"size-full relative p-2 pt-0 bg-light\">\r\n <div class=\"size-full relative rounded-2xl content-shadow overflow-hidden {{backdrop}}\" style=\"--shadow-color: {{shadowColor}}\">\r\n <ng-content></ng-content> \r\n </div>\r\n </div>\r\n</div>", styles: ["#popover-user{--width: 17rem}.content-shadow{--shadow-color: color-mix(in srgb, var(--ion-color-primary) 15%, transparent);box-shadow:0 0 0 1px var(--shadow-color),0 6px 10px -4px var(--shadow-color)}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: IonicModule }, { kind: "component", type: i3.IonButton, selector: "ion-button", inputs: ["buttonType", "color", "disabled", "download", "expand", "fill", "form", "href", "mode", "rel", "routerAnimation", "routerDirection", "shape", "size", "strong", "target", "type"] }, { kind: "component", type: i3.IonCard, selector: "ion-card", inputs: ["button", "color", "disabled", "download", "href", "mode", "rel", "routerAnimation", "routerDirection", "target", "type"] }, { kind: "component", type: i3.IonCardContent, selector: "ion-card-content", inputs: ["mode"] }, { kind: "component", type: i3.IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }, { kind: "component", type: i3.IonItem, selector: "ion-item", inputs: ["button", "color", "detail", "detailIcon", "disabled", "download", "href", "lines", "mode", "rel", "routerAnimation", "routerDirection", "target", "type"] }, { kind: "component", type: i3.IonMenuButton, selector: "ion-menu-button", inputs: ["autoHide", "color", "disabled", "menu", "mode", "type"] }, { kind: "component", type: i3.IonRadio, selector: "ion-radio", inputs: ["alignment", "color", "disabled", "justify", "labelPlacement", "mode", "name", "value"] }, { kind: "component", type: i3.IonRadioGroup, selector: "ion-radio-group", inputs: ["allowEmptySelection", "compareWith", "errorText", "helperText", "name", "value"] }, { kind: "component", type: i3.IonText, selector: "ion-text", inputs: ["color", "mode"] }, { kind: "directive", type: i3.SelectValueAccessor, selector: "ion-select, ion-radio-group, ion-segment, ion-datetime" }, { kind: "directive", type: i3.RouterLinkDelegate, selector: ":not(a):not(area)[routerLink]" }, { kind: "directive", type: RouterLinkWithHref, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "ngmodule", type: SIonPopoverModule }, { kind: "component", type: i4.SIonPopoverComponent, selector: "sion-popover", inputs: ["fill", "arrow", "flip", "placement", "height", "width", "anchor"], outputs: ["onWillPresent", "onDidPresent", "onWillDismiss", "onDidDismiss"] }] }); }
|
|
78
78
|
}
|
|
79
79
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MainContentComponent, decorators: [{
|
|
80
80
|
type: Component,
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component,
|
|
1
|
+
import { Component, ElementRef, EventEmitter, Input, NgZone, Output, TemplateRef, ViewChild, ViewContainerRef } from '@angular/core';
|
|
2
2
|
import { autoUpdate, computePosition, flip, limitShift, offset, shift, arrow } from '@floating-ui/dom';
|
|
3
3
|
import { Timeout } from '../../../services/utils.service';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
@@ -18,130 +18,143 @@ export class SIonPopoverComponent {
|
|
|
18
18
|
this.onWillDismiss = new EventEmitter();
|
|
19
19
|
this.onDidDismiss = new EventEmitter();
|
|
20
20
|
this.anchor = undefined;
|
|
21
|
-
this.
|
|
22
|
-
this.isVisibleChange = new EventEmitter();
|
|
23
|
-
this.lock = false;
|
|
24
|
-
}
|
|
25
|
-
async present(event) {
|
|
26
|
-
if (this.isVisible) {
|
|
27
|
-
return;
|
|
28
|
-
}
|
|
29
|
-
await waitUntil(() => !this.lock);
|
|
30
|
-
this.lock = true;
|
|
31
|
-
this.onWillPresent.emit();
|
|
32
|
-
this.CreatePopoverInBody();
|
|
33
|
-
await Timeout(0);
|
|
34
|
-
const refEl = this.anchor ? this.anchor : event.target;
|
|
35
|
-
const popEl = this.popoverInstance;
|
|
36
|
-
const arrowEl = this.popoverInstance.querySelector('.popover-arrow');
|
|
37
|
-
const computePositionRetrun = await this.GetComputePositionReturn(refEl, popEl, arrowEl);
|
|
38
|
-
Object.assign(this.popoverInstance.style, {
|
|
39
|
-
left: `${computePositionRetrun.x}px`,
|
|
40
|
-
top: `${computePositionRetrun.y}px`,
|
|
41
|
-
width: this.width,
|
|
42
|
-
height: this.height,
|
|
43
|
-
position: 'absolute',
|
|
44
|
-
});
|
|
45
|
-
this.cleanupAutoUpdate = autoUpdate(refEl, popEl, async () => {
|
|
46
|
-
const computePositionRetrun = await this.GetComputePositionReturn(refEl, popEl, arrowEl);
|
|
47
|
-
Object.assign(popEl.style, {
|
|
48
|
-
left: `${computePositionRetrun.x}px`,
|
|
49
|
-
top: `${computePositionRetrun.y}px`,
|
|
50
|
-
});
|
|
51
|
-
if (computePositionRetrun.middlewareData.arrow) {
|
|
52
|
-
const { x: arrowX, y: arrowY } = computePositionRetrun.middlewareData.arrow;
|
|
53
|
-
const position = computePositionRetrun.placement.split('-')[0];
|
|
54
|
-
const staticSide = staticSides[position];
|
|
55
|
-
Object.assign(arrowEl.style, {
|
|
56
|
-
left: arrowX != null ? `${arrowX}px` : '',
|
|
57
|
-
top: arrowY != null ? `${arrowY}px` : '',
|
|
58
|
-
right: '',
|
|
59
|
-
bottom: '',
|
|
60
|
-
[staticSide]: `-7px`,
|
|
61
|
-
});
|
|
62
|
-
arrowEl.style.setProperty(`--rotation`, rotations[position]);
|
|
63
|
-
}
|
|
64
|
-
});
|
|
65
|
-
await Timeout(50);
|
|
66
|
-
this.isVisible = true;
|
|
67
|
-
this.popoverInstance.style.setProperty('display', 'block');
|
|
68
|
-
this.isVisibleChange.emit(this.isVisible);
|
|
69
|
-
await Timeout(200);
|
|
70
|
-
this.onDidPresent.emit();
|
|
71
|
-
this.lock = false;
|
|
72
|
-
}
|
|
73
|
-
async GetComputePositionReturn(refEl, popEl, arrowEl) {
|
|
74
|
-
return await computePosition(refEl, popEl, {
|
|
75
|
-
placement: this.placement,
|
|
76
|
-
middleware: [
|
|
77
|
-
offset(10),
|
|
78
|
-
this.flip ? flip({ crossAxis: false }) : undefined,
|
|
79
|
-
shift({ limiter: limitShift(), padding: 5 }),
|
|
80
|
-
this.arrow ? arrow({ element: arrowEl, padding: 10 }) : undefined,
|
|
81
|
-
].filter(p => p),
|
|
82
|
-
});
|
|
83
|
-
}
|
|
84
|
-
CreatePopoverInBody() {
|
|
85
|
-
// Create a container for the template
|
|
86
|
-
const embeddedView = this.popoverTemplate.createEmbeddedView({});
|
|
87
|
-
this.viewContainerRef.insert(embeddedView);
|
|
88
|
-
// Get the popover element and append to body
|
|
89
|
-
this.popoverInstance = embeddedView.rootNodes[0];
|
|
90
|
-
document.body.appendChild(this.popoverInstance);
|
|
91
|
-
this.popoverInstance.style.setProperty('display', 'none');
|
|
92
|
-
}
|
|
93
|
-
onClick(event) {
|
|
94
|
-
if (!this.popoverInstance) {
|
|
95
|
-
return;
|
|
96
|
-
}
|
|
97
|
-
if (!this.popoverInstance.contains(event.target) &&
|
|
98
|
-
!this.anchor.contains(event.target)) {
|
|
99
|
-
this.dismiss();
|
|
100
|
-
}
|
|
21
|
+
this.state = POPOVER_STATE.IDLE;
|
|
101
22
|
}
|
|
102
23
|
ngOnInit() {
|
|
24
|
+
this.CreateEmbeddedView();
|
|
25
|
+
this.CreateInstance();
|
|
103
26
|
//TODO: Use Renderer2 to add event listeners for better Angular compatibility when updating to Angular 19
|
|
104
27
|
this.ngZone.runOutsideAngular(() => {
|
|
105
28
|
this.documentClickListener = (event) => {
|
|
106
29
|
// Run back inside Angular's zone when handling the event
|
|
107
30
|
this.ngZone.run(() => {
|
|
108
|
-
this.
|
|
31
|
+
if (!this._instance) {
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
if (!this._instance.contains(event.target) &&
|
|
35
|
+
!this.anchor.contains(event.target)) {
|
|
36
|
+
this.dismiss();
|
|
37
|
+
}
|
|
109
38
|
});
|
|
110
39
|
};
|
|
111
40
|
// Use the native DOM API directly with capture phase
|
|
112
41
|
document.addEventListener('click', this.documentClickListener, true);
|
|
113
42
|
});
|
|
114
43
|
}
|
|
44
|
+
CreateEmbeddedView() {
|
|
45
|
+
if (this._embeddedView) {
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
this._embeddedView = this.popoverTemplate.createEmbeddedView({});
|
|
49
|
+
this.viewRef = this.viewContainerRef.insert(this._embeddedView);
|
|
50
|
+
}
|
|
51
|
+
CreateInstance() {
|
|
52
|
+
this._instance = this._embeddedView.rootNodes[0];
|
|
53
|
+
document.body.appendChild(this._instance);
|
|
54
|
+
// const style = {
|
|
55
|
+
// "solid" : ['bg-light'],
|
|
56
|
+
// "outline": ['bg-transparent'],
|
|
57
|
+
// "blur" : ['backdrop-blur-md', 'bg-light/80'],
|
|
58
|
+
// "clear" : ['!border-0 bg-transparent'],
|
|
59
|
+
// }[this.fill];
|
|
60
|
+
// style.forEach(s => {
|
|
61
|
+
// this._instance.classList.add(s);
|
|
62
|
+
// this.arrowEl?.classList.add(s);
|
|
63
|
+
// });
|
|
64
|
+
}
|
|
65
|
+
get arrowEl() {
|
|
66
|
+
return this._instance.querySelector('.popover-arrow');
|
|
67
|
+
}
|
|
68
|
+
async present(event) {
|
|
69
|
+
if (this.state != POPOVER_STATE.IDLE) {
|
|
70
|
+
return;
|
|
71
|
+
}
|
|
72
|
+
this.onWillPresent.emit();
|
|
73
|
+
this.state = POPOVER_STATE.PRESENTING;
|
|
74
|
+
const refEl = this.anchor ? this.anchor : event.target;
|
|
75
|
+
const arrowEl = this.arrowEl;
|
|
76
|
+
await this.update(refEl, arrowEl);
|
|
77
|
+
this._instance.classList.add('show');
|
|
78
|
+
this.cleanupAutoUpdate = autoUpdate(refEl, this._instance, async () => this.update(refEl, arrowEl));
|
|
79
|
+
this.state = POPOVER_STATE.VISIBLE;
|
|
80
|
+
this.onDidPresent.emit();
|
|
81
|
+
}
|
|
82
|
+
async update(refEl, arrowEl) {
|
|
83
|
+
const computePositionReturn = await this.GetComputePositionReturn(refEl, this._instance, arrowEl);
|
|
84
|
+
this.HandleComputePositionReturn(computePositionReturn, arrowEl);
|
|
85
|
+
}
|
|
115
86
|
async dismiss() {
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
87
|
+
if (this.state == POPOVER_STATE.IDLE) {
|
|
88
|
+
return;
|
|
89
|
+
}
|
|
119
90
|
if (this.cleanupAutoUpdate) {
|
|
120
91
|
this.cleanupAutoUpdate();
|
|
121
92
|
this.cleanupAutoUpdate = undefined;
|
|
122
93
|
}
|
|
123
|
-
this.
|
|
124
|
-
this.
|
|
94
|
+
this.onWillDismiss.emit();
|
|
95
|
+
this.state = POPOVER_STATE.DISMISSING;
|
|
96
|
+
this._instance.classList.remove('show');
|
|
125
97
|
await Timeout(200);
|
|
126
|
-
|
|
127
|
-
document.body.removeChild(this.popoverInstance);
|
|
128
|
-
this.popoverInstance = undefined;
|
|
129
|
-
}
|
|
98
|
+
this.state = POPOVER_STATE.IDLE;
|
|
130
99
|
this.onDidDismiss.emit();
|
|
131
|
-
|
|
100
|
+
}
|
|
101
|
+
HandleComputePositionReturn(computePositionReturn, arrowEl) {
|
|
102
|
+
Object.assign(this._instance.style, {
|
|
103
|
+
left: `${computePositionReturn.x}px`,
|
|
104
|
+
top: `${computePositionReturn.y}px`,
|
|
105
|
+
width: this.width,
|
|
106
|
+
height: this.height,
|
|
107
|
+
position: 'absolute',
|
|
108
|
+
});
|
|
109
|
+
if (computePositionReturn.middlewareData.arrow) {
|
|
110
|
+
const { x: arrowX, y: arrowY } = computePositionReturn.middlewareData.arrow;
|
|
111
|
+
const position = computePositionReturn.placement.split('-')[0];
|
|
112
|
+
const staticSide = STATIC_SIDES[position];
|
|
113
|
+
Object.assign(arrowEl.style, {
|
|
114
|
+
left: arrowX != null ? `${arrowX}px` : '',
|
|
115
|
+
top: arrowY != null ? `${arrowY}px` : '',
|
|
116
|
+
right: '',
|
|
117
|
+
bottom: '',
|
|
118
|
+
[staticSide]: `-7px`,
|
|
119
|
+
});
|
|
120
|
+
arrowEl.style.setProperty(`--rotation`, ROTATIONS[position]);
|
|
121
|
+
}
|
|
132
122
|
}
|
|
133
123
|
ngOnDestroy() {
|
|
124
|
+
if (this._instance) {
|
|
125
|
+
document.body.removeChild(this._instance);
|
|
126
|
+
this._instance.remove();
|
|
127
|
+
this._instance = undefined;
|
|
128
|
+
}
|
|
129
|
+
if (this._embeddedView) {
|
|
130
|
+
this._embeddedView.destroy();
|
|
131
|
+
this._embeddedView = undefined;
|
|
132
|
+
}
|
|
134
133
|
if (this.documentClickListener) {
|
|
135
134
|
document.removeEventListener('click', this.documentClickListener, true);
|
|
136
135
|
}
|
|
137
|
-
this.
|
|
136
|
+
if (this.viewRef) {
|
|
137
|
+
this.viewRef.destroy();
|
|
138
|
+
this.viewRef = undefined;
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
async GetComputePositionReturn(refEl, popEl, arrowEl) {
|
|
142
|
+
return await computePosition(refEl, popEl, {
|
|
143
|
+
placement: this.placement,
|
|
144
|
+
middleware: [
|
|
145
|
+
offset(10),
|
|
146
|
+
this.flip ? flip({ crossAxis: false }) : undefined,
|
|
147
|
+
shift({ limiter: limitShift(), padding: 5 }),
|
|
148
|
+
this.arrow ? arrow({ element: arrowEl, padding: 10 }) : undefined,
|
|
149
|
+
].filter(p => p),
|
|
150
|
+
});
|
|
138
151
|
}
|
|
139
152
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SIonPopoverComponent, deps: [{ token: i0.ViewContainerRef }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
140
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
153
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: SIonPopoverComponent, selector: "sion-popover", inputs: { fill: "fill", arrow: "arrow", flip: "flip", placement: "placement", height: "height", width: "width", anchor: "anchor" }, outputs: { onWillPresent: "onWillPresent", onDidPresent: "onDidPresent", onWillDismiss: "onWillDismiss", onDidDismiss: "onDidDismiss" }, viewQueries: [{ propertyName: "popoverTemplate", first: true, predicate: ["popoverTemplate"], descendants: true, static: true }, { propertyName: "contentContainer", first: true, predicate: ["popoverWrapper"], descendants: true }, { propertyName: "arrowElement", first: true, predicate: ["popoverArrow"], descendants: true }], ngImport: i0, template: "<ng-template #popoverTemplate>\r\n <div #popoverWrapper \r\n class=\"popover-wrapper translucid-border\"\r\n [style.height]=\"height\"\r\n [style.width]=\"width\"\r\n [ngClass]=\"{\r\n 'bg-light' : fill == 'solid',\r\n 'bg-transparent' : fill == 'outline',\r\n 'backdrop-blur-md bg-light/80': fill == 'blur',\r\n '!border-0' : fill == 'clear',\r\n }\"\r\n > \r\n <div #popoverArrow class=\"popover-arrow size-4 translucid-border\"\r\n [ngClass]=\"{\r\n 'bg-light' : fill == 'solid',\r\n 'bg-transparent' : fill == 'outline',\r\n 'backdrop-blur-md bg-light/80': fill == 'blur',\r\n '!border-0' : fill == 'clear',\r\n }\"\r\n ></div>\r\n\r\n <ng-content #content></ng-content>\r\n </div>\r\n</ng-template>", styles: [".popover-wrapper{z-index:50;border-radius:.75rem;width:max-content;position:absolute;will-change:left,top,bottom,right,auto,opacity,filter;opacity:0;transition:opacity .15s ease-in-out,transform .15s ease-in-out,filter .15s ease-in-out;min-width:2rem;min-height:2rem;filter:grayscale(.9);transform:scale(.95)}.popover-arrow{border-radius:.125rem;position:absolute;transform:scale(1) rotate(var(--rotation))!important;clip-path:var(--clip-path-triangle, polygon(0% 0%, 0% 100%, 100% 100%))}.show{filter:grayscale(0);transform:scale(1);opacity:1}.popover-wrapper:not(.show){pointer-events:none}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] }); }
|
|
141
154
|
}
|
|
142
155
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SIonPopoverComponent, decorators: [{
|
|
143
156
|
type: Component,
|
|
144
|
-
args: [{ selector: 'sion-popover', template: "<ng-template #popoverTemplate>\r\n <div #popoverWrapper class=\"popover-wrapper translucid-border\"\r\n
|
|
157
|
+
args: [{ selector: 'sion-popover', template: "<ng-template #popoverTemplate>\r\n <div #popoverWrapper \r\n class=\"popover-wrapper translucid-border\"\r\n [style.height]=\"height\"\r\n [style.width]=\"width\"\r\n [ngClass]=\"{\r\n 'bg-light' : fill == 'solid',\r\n 'bg-transparent' : fill == 'outline',\r\n 'backdrop-blur-md bg-light/80': fill == 'blur',\r\n '!border-0' : fill == 'clear',\r\n }\"\r\n > \r\n <div #popoverArrow class=\"popover-arrow size-4 translucid-border\"\r\n [ngClass]=\"{\r\n 'bg-light' : fill == 'solid',\r\n 'bg-transparent' : fill == 'outline',\r\n 'backdrop-blur-md bg-light/80': fill == 'blur',\r\n '!border-0' : fill == 'clear',\r\n }\"\r\n ></div>\r\n\r\n <ng-content #content></ng-content>\r\n </div>\r\n</ng-template>", styles: [".popover-wrapper{z-index:50;border-radius:.75rem;width:max-content;position:absolute;will-change:left,top,bottom,right,auto,opacity,filter;opacity:0;transition:opacity .15s ease-in-out,transform .15s ease-in-out,filter .15s ease-in-out;min-width:2rem;min-height:2rem;filter:grayscale(.9);transform:scale(.95)}.popover-arrow{border-radius:.125rem;position:absolute;transform:scale(1) rotate(var(--rotation))!important;clip-path:var(--clip-path-triangle, polygon(0% 0%, 0% 100%, 100% 100%))}.show{filter:grayscale(0);transform:scale(1);opacity:1}.popover-wrapper:not(.show){pointer-events:none}\n"] }]
|
|
145
158
|
}], ctorParameters: () => [{ type: i0.ViewContainerRef }, { type: i0.NgZone }], propDecorators: { fill: [{
|
|
146
159
|
type: Input
|
|
147
160
|
}], arrow: [{
|
|
@@ -173,27 +186,24 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
173
186
|
}], arrowElement: [{
|
|
174
187
|
type: ViewChild,
|
|
175
188
|
args: ['popoverArrow']
|
|
176
|
-
}], contentChildren: [{
|
|
177
|
-
type: ContentChildren,
|
|
178
|
-
args: ['*', { descendants: true }]
|
|
179
|
-
}], isVisibleChange: [{
|
|
180
|
-
type: Output
|
|
181
189
|
}] } });
|
|
182
|
-
|
|
190
|
+
var POPOVER_STATE;
|
|
191
|
+
(function (POPOVER_STATE) {
|
|
192
|
+
POPOVER_STATE[POPOVER_STATE["IDLE"] = 1] = "IDLE";
|
|
193
|
+
POPOVER_STATE[POPOVER_STATE["PRESENTING"] = 2] = "PRESENTING";
|
|
194
|
+
POPOVER_STATE[POPOVER_STATE["DISMISSING"] = 3] = "DISMISSING";
|
|
195
|
+
POPOVER_STATE[POPOVER_STATE["VISIBLE"] = 4] = "VISIBLE";
|
|
196
|
+
})(POPOVER_STATE || (POPOVER_STATE = {}));
|
|
197
|
+
const STATIC_SIDES = {
|
|
183
198
|
top: "bottom",
|
|
184
199
|
right: "left",
|
|
185
200
|
bottom: "top",
|
|
186
201
|
left: "right"
|
|
187
202
|
};
|
|
188
|
-
const
|
|
203
|
+
const ROTATIONS = {
|
|
189
204
|
bottom: "135deg",
|
|
190
205
|
top: "315deg",
|
|
191
206
|
left: "225deg",
|
|
192
207
|
right: "45deg",
|
|
193
208
|
};
|
|
194
|
-
async function waitUntil(condition, interval = 50) {
|
|
195
|
-
while (!condition()) {
|
|
196
|
-
await new Promise(resolve => setTimeout(resolve, interval));
|
|
197
|
-
}
|
|
198
|
-
}
|
|
199
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sion-popover.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/popover/sion-popover/sion-popover.component.ts","../../../../../../src/lib/components/popover/sion-popover/sion-popover.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ContentChildren, ElementRef, EventEmitter, HostListener, Input, NgZone, OnDestroy, OnInit, Output, QueryList, Renderer2, TemplateRef, ViewChild, ViewContainerRef } from '@angular/core';\r\nimport { autoUpdate, computePosition, ComputePositionReturn, flip, limitShift, offset, Placement, shift, arrow } from '@floating-ui/dom';\r\nimport { Timeout } from '../../../services/utils.service';\r\n\r\ntype Fill = 'solid' | 'outline' | 'blur' | 'clear';\r\n\r\n@Component({\r\n  selector: 'sion-popover',\r\n  templateUrl: './sion-popover.component.html',\r\n  styleUrls: ['./sion-popover.component.scss'],\r\n})\r\nexport class SIonPopoverComponent implements OnDestroy, OnInit {\r\n\r\n  @Input() fill: Fill = 'blur';\r\n  @Input() arrow: boolean = true;\r\n  @Input() flip : boolean = true;\r\n\r\n\r\n  @Input() placement: Placement = 'bottom';\r\n  @Input() height: string = 'auto';\r\n  @Input() width: string = 'auto';\r\n\r\n\r\n  @Output() onWillPresent: EventEmitter<void> = new EventEmitter<void>();\r\n  @Output() onDidPresent: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @Output() onWillDismiss: EventEmitter<void> = new EventEmitter<void>();\r\n  @Output() onDidDismiss: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @Input() anchor: HTMLElement | undefined = undefined;\r\n\r\n  constructor(\r\n    private viewContainerRef: ViewContainerRef,\r\n    private ngZone: NgZone\r\n  ) { }\r\n\r\n  @ViewChild('popoverTemplate', { static: true }) popoverTemplate!: TemplateRef<any>;\r\n  @ViewChild('popoverWrapper') contentContainer: ElementRef<HTMLDivElement>;\r\n  @ViewChild('popoverArrow'  ) arrowElement    : ElementRef<HTMLElement>;\r\n  \r\n  // Track all content children for change detection\r\n  @ContentChildren('*', { descendants: true }) contentChildren!: QueryList<any>;\r\n\r\n  isVisible = false;\r\n  private cleanupAutoUpdate?: () => void;\r\n  private popoverInstance?: HTMLElement;\r\n  @Output() isVisibleChange: EventEmitter<boolean> = new EventEmitter<boolean>();\r\n\r\n  private lock: boolean = false; \r\n  public async present(event?: Event): Promise<void> {\r\n    if(this.isVisible){ return; }\r\n    await waitUntil(() => !this.lock);\r\n    this.lock = true;\r\n\r\n    this.onWillPresent.emit();\r\n    \r\n    this.CreatePopoverInBody();\r\n    await Timeout(0);\r\n    \r\n    const refEl   = this.anchor ? this.anchor : event.target as HTMLElement;\r\n    const popEl   = this.popoverInstance;\r\n    const arrowEl = this.popoverInstance.querySelector('.popover-arrow') as HTMLElement;\r\n\r\n    const computePositionRetrun: ComputePositionReturn = await this.GetComputePositionReturn(refEl, popEl, arrowEl);\r\n    Object.assign(this.popoverInstance.style, {\r\n      left: `${computePositionRetrun.x}px`,\r\n      top:  `${computePositionRetrun.y}px`,\r\n      width : this.width,\r\n      height: this.height,\r\n      position: 'absolute',\r\n    });\r\n\r\n    this.cleanupAutoUpdate = autoUpdate(\r\n      refEl,\r\n      popEl,\r\n      async () => {\r\n        const computePositionRetrun: ComputePositionReturn = await this.GetComputePositionReturn(refEl, popEl, arrowEl);\r\n\r\n        Object.assign(popEl.style, {\r\n          left: `${computePositionRetrun.x}px`,\r\n          top:  `${computePositionRetrun.y}px`,\r\n        });\r\n        if(computePositionRetrun.middlewareData.arrow){\r\n          const { x: arrowX, y: arrowY } = computePositionRetrun.middlewareData.arrow;\r\n\r\n          const position = computePositionRetrun.placement.split('-')[0];\r\n          const staticSide = staticSides[position];\r\n          Object.assign(arrowEl.style, {\r\n            left: arrowX != null ? `${arrowX}px` : '',\r\n            top : arrowY != null ? `${arrowY}px` : '',\r\n            right : '',\r\n            bottom: '',\r\n            [staticSide]: `-7px`,\r\n          });\r\n          arrowEl.style.setProperty(`--rotation`, rotations[position]);\r\n        }\r\n      }\r\n    );\r\n\r\n    await Timeout(50);\r\n    this.isVisible = true;\r\n    this.popoverInstance.style.setProperty('display', 'block');\r\n    this.isVisibleChange.emit(this.isVisible);\r\n    await Timeout(200);\r\n    this.onDidPresent.emit();\r\n    this.lock = false;\r\n  }\r\n\r\n  async GetComputePositionReturn(refEl: HTMLElement, popEl: HTMLElement, arrowEl: HTMLElement): Promise<ComputePositionReturn> {\r\n    return await computePosition(refEl, popEl, {\r\n      placement: this.placement,\r\n      middleware: [ \r\n        offset(10), \r\n        this.flip  ? flip({ crossAxis: false }) : undefined, \r\n        shift({ limiter: limitShift(), padding: 5 }), \r\n        this.arrow ? arrow({ element: arrowEl, padding: 10 }) : undefined,\r\n      ].filter(p => p),\r\n    });\r\n  }\r\n\r\n  private CreatePopoverInBody(): void {\r\n    // Create a container for the template\r\n    const embeddedView = this.popoverTemplate.createEmbeddedView({});\r\n    this.viewContainerRef.insert(embeddedView);\r\n\r\n    // Get the popover element and append to body\r\n    this.popoverInstance = embeddedView.rootNodes[0] as HTMLElement;\r\n    document.body.appendChild(this.popoverInstance);\r\n    this.popoverInstance.style.setProperty('display', 'none');\r\n  }\r\n\r\n  onClick(event: MouseEvent) {\r\n    if(!this.popoverInstance){ return;}\r\n    if (\r\n      !this.popoverInstance.contains(event.target as Node) &&\r\n      !this.anchor.contains(event.target as Node)\r\n    ) {\r\n      this.dismiss();\r\n    }\r\n  }\r\n\r\n  documentClickListener: (event: MouseEvent) => void;\r\n  ngOnInit(): void {\r\n    //TODO: Use Renderer2 to add event listeners for better Angular compatibility when updating to Angular 19\r\n    this.ngZone.runOutsideAngular(() => {\r\n      this.documentClickListener = (event: MouseEvent) => {\r\n        // Run back inside Angular's zone when handling the event\r\n        this.ngZone.run(() => {\r\n          this.onClick(event);\r\n        });\r\n      };\r\n      \r\n      // Use the native DOM API directly with capture phase\r\n      document.addEventListener('click', this.documentClickListener, true);\r\n    });\r\n  }\r\n\r\n\r\n  public async dismiss(): Promise<void>{\r\n    await waitUntil(() => !this.lock);\r\n    this.lock = true;\r\n\r\n    this.onWillDismiss.emit();\r\n    if(this.cleanupAutoUpdate){\r\n      this.cleanupAutoUpdate();\r\n      this.cleanupAutoUpdate = undefined;\r\n\r\n    }\r\n    this.isVisible = false;\r\n    this.isVisibleChange.emit(this.isVisible);\r\n    await Timeout(200);\r\n\r\n    if (this.popoverInstance) {\r\n      document.body.removeChild(this.popoverInstance);\r\n      this.popoverInstance = undefined;\r\n    }\r\n    this.onDidDismiss.emit();\r\n    this.lock = false;\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    if (this.documentClickListener) {\r\n      document.removeEventListener('click', this.documentClickListener, true);\r\n    }\r\n\r\n    this.dismiss();\r\n  }\r\n}\r\n\r\nconst staticSides = {\r\n  top: \"bottom\",\r\n  right: \"left\",\r\n  bottom: \"top\",\r\n  left: \"right\"\r\n};\r\nconst rotations = {\r\n  bottom: \"135deg\",\r\n  top: \"315deg\",\r\n  left: \"225deg\",\r\n  right: \"45deg\",\r\n}\r\n\r\nasync function waitUntil(condition: () => boolean, interval: number = 50): Promise<void> {\r\n  while (!condition()) {\r\n    await new Promise(resolve => setTimeout(resolve, interval));\r\n  }\r\n}\r\n","<ng-template #popoverTemplate>\r\n  <div #popoverWrapper class=\"popover-wrapper translucid-border\"\r\n      [ngClass]=\"{\r\n        'bg-light'        : fill == 'solid',\r\n        'bg-transparent'  : fill == 'outline',\r\n        'backdrop-blur-md bg-light/80': fill == 'blur',\r\n        '!border-0'       : fill == 'clear',\r\n        'visible-anim'    : isVisible,\r\n        'invisible-anim'  : !isVisible,\r\n      }\"\r\n    [style.height]=\"height\"\r\n    [style.width]=\"width\"\r\n  >\r\n  <!-- 'solid' | 'outline' | 'blur' | 'clear' -->\r\n    @if(arrow){\r\n      <div #popoverArrow class=\"popover-arrow size-4 translucid-border\"\r\n        [ngClass]=\"{\r\n          'bg-light'        : fill == 'solid',\r\n          'bg-transparent'  : fill == 'outline',\r\n          'backdrop-blur-md': fill == 'blur',\r\n          'visible-anim'    : isVisible,\r\n          'invisible-anim'  : !isVisible,\r\n      }\"\r\n      ></div>\r\n    }\r\n    <ng-content #content></ng-content>\r\n  </div>\r\n</ng-template>"]}
|
|
209
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sion-popover.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/popover/sion-popover/sion-popover.component.ts","../../../../../../src/lib/components/popover/sion-popover/sion-popover.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EmbeddedViewRef, EventEmitter, Input, NgZone, OnDestroy, OnInit, Output, TemplateRef, ViewChild, ViewContainerRef, ViewRef } from '@angular/core';\r\nimport { autoUpdate, computePosition, ComputePositionReturn, flip, limitShift, offset, Placement, shift, arrow } from '@floating-ui/dom';\r\nimport { Timeout } from '../../../services/utils.service';\r\n\r\ntype Fill = 'solid' | 'outline' | 'blur' | 'clear';\r\n\r\n@Component({\r\n  selector: 'sion-popover',\r\n  templateUrl: './sion-popover.component.html',\r\n  styleUrls: ['./sion-popover.component.scss'],\r\n})\r\nexport class SIonPopoverComponent implements OnInit, OnDestroy {\r\n\r\n  @Input() fill: Fill = 'blur';\r\n  @Input() arrow: boolean = true;\r\n  @Input() flip : boolean = true;\r\n\r\n\r\n  @Input() placement: Placement = 'bottom';\r\n  @Input() height: string = 'auto';\r\n  @Input() width: string = 'auto';\r\n\r\n\r\n  @Output() onWillPresent: EventEmitter<void> = new EventEmitter<void>();\r\n  @Output() onDidPresent: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @Output() onWillDismiss: EventEmitter<void> = new EventEmitter<void>();\r\n  @Output() onDidDismiss: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @Input() anchor: HTMLElement | undefined = undefined;\r\n\r\n  constructor(\r\n    private viewContainerRef: ViewContainerRef,\r\n    private ngZone: NgZone\r\n  ) { }\r\n\r\n\r\n\r\n  @ViewChild('popoverTemplate', { static: true }) popoverTemplate!: TemplateRef<any>;\r\n  @ViewChild('popoverWrapper') contentContainer: ElementRef<HTMLDivElement>;\r\n  @ViewChild('popoverArrow'  ) arrowElement    : ElementRef<HTMLElement>;\r\n\r\n  ngOnInit() {\r\n    this.CreateEmbeddedView();\r\n    this.CreateInstance();\r\n  \r\n    //TODO: Use Renderer2 to add event listeners for better Angular compatibility when updating to Angular 19\r\n    this.ngZone.runOutsideAngular(() => {\r\n      this.documentClickListener = (event: MouseEvent) => {\r\n        // Run back inside Angular's zone when handling the event\r\n        this.ngZone.run(() => {\r\n          if(!this._instance){ return;}\r\n          if (\r\n            !this._instance.contains(event.target as Node) &&\r\n            !this.anchor.contains(event.target as Node)\r\n          ) {\r\n            this.dismiss();\r\n          }\r\n        });\r\n      };\r\n      \r\n      // Use the native DOM API directly with capture phase\r\n      document.addEventListener('click', this.documentClickListener, true);\r\n    });\r\n  }\r\n  documentClickListener: (event: MouseEvent) => void;\r\n  viewRef?: ViewRef;\r\n\r\n  private _embeddedView?: EmbeddedViewRef<any> | undefined;\r\n  CreateEmbeddedView(): void {\r\n    if(this._embeddedView){ return; }\r\n    this._embeddedView = this.popoverTemplate.createEmbeddedView({});\r\n    this.viewRef = this.viewContainerRef.insert(this._embeddedView);\r\n  }\r\n  private _instance?: HTMLElement | undefined;\r\n  CreateInstance(): void {\r\n    this._instance = this._embeddedView.rootNodes[0] as HTMLElement;\r\n    document.body.appendChild(this._instance);\r\n\r\n    // const style = {\r\n    //   \"solid\"  : ['bg-light'],\r\n    //   \"outline\": ['bg-transparent'],\r\n    //   \"blur\"   : ['backdrop-blur-md', 'bg-light/80'],\r\n    //   \"clear\"  : ['!border-0 bg-transparent'],\r\n    // }[this.fill];\r\n    // style.forEach(s => {\r\n    //   this._instance.classList.add(s);\r\n    //   this.arrowEl?.classList.add(s);\r\n    // });\r\n  }\r\n\r\n  get arrowEl(): HTMLElement | undefined {\r\n    return this._instance.querySelector('.popover-arrow') as HTMLElement;\r\n  }\r\n  \r\n  private cleanupAutoUpdate?: () => void;\r\n  public state: POPOVER_STATE = POPOVER_STATE.IDLE;\r\n  public async present(event?: Event): Promise<void> {\r\n    if(this.state != POPOVER_STATE.IDLE) { return; }\r\n    this.onWillPresent.emit();\r\n    \r\n    this.state = POPOVER_STATE.PRESENTING;\r\n    const refEl   = this.anchor ? this.anchor : event.target as HTMLElement;\r\n    const arrowEl = this.arrowEl;\r\n\r\n    await this.update(refEl, arrowEl)\r\n    this._instance.classList.add('show');\r\n    this.cleanupAutoUpdate = autoUpdate(refEl, this._instance, async () => this.update(refEl, arrowEl));\r\n    \r\n    this.state = POPOVER_STATE.VISIBLE;\r\n    this.onDidPresent.emit();\r\n  }\r\n\r\n  private async update(refEl: HTMLElement, arrowEl: HTMLElement): Promise<void> {\r\n    const computePositionReturn: ComputePositionReturn = await this.GetComputePositionReturn(refEl, this._instance, arrowEl);\r\n    this.HandleComputePositionReturn(computePositionReturn, arrowEl);\r\n  }\r\n\r\n  public async dismiss(): Promise<void> {\r\n    if(this.state == POPOVER_STATE.IDLE) { return; }\r\n    if(this.cleanupAutoUpdate) {\r\n      this.cleanupAutoUpdate();\r\n      this.cleanupAutoUpdate = undefined;\r\n    }\r\n    this.onWillDismiss.emit();\r\n    this.state = POPOVER_STATE.DISMISSING;\r\n    this._instance.classList.remove('show');\r\n    await Timeout(200);\r\n    this.state = POPOVER_STATE.IDLE;\r\n    this.onDidDismiss.emit();\r\n  }\r\n\r\n  HandleComputePositionReturn(computePositionReturn: ComputePositionReturn, arrowEl: HTMLElement): void {\r\n    Object.assign(this._instance.style, {\r\n      left: `${computePositionReturn.x}px`,\r\n      top:  `${computePositionReturn.y}px`,\r\n      width : this.width,\r\n      height: this.height,\r\n      position: 'absolute',\r\n    });\r\n    if(computePositionReturn.middlewareData.arrow){\r\n      const { x: arrowX, y: arrowY } = computePositionReturn.middlewareData.arrow;\r\n      const position = computePositionReturn.placement.split('-')[0];\r\n      const staticSide = STATIC_SIDES[position];\r\n      Object.assign(arrowEl.style, {\r\n        left: arrowX != null ? `${arrowX}px` : '',\r\n        top : arrowY != null ? `${arrowY}px` : '',\r\n        right : '',\r\n        bottom: '',\r\n        [staticSide]: `-7px`,\r\n      });\r\n      arrowEl.style.setProperty(`--rotation`, ROTATIONS[position]);\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    if(this._instance) {\r\n      document.body.removeChild(this._instance);\r\n      this._instance.remove();\r\n      this._instance = undefined;\r\n    }\r\n    if(this._embeddedView) {\r\n      this._embeddedView.destroy();\r\n      this._embeddedView = undefined;\r\n    }\r\n\r\n    if (this.documentClickListener) {\r\n      document.removeEventListener('click', this.documentClickListener, true);\r\n    }\r\n    if (this.viewRef) {\r\n      this.viewRef.destroy();\r\n      this.viewRef = undefined;\r\n    }\r\n  }\r\n\r\n  async GetComputePositionReturn(refEl: HTMLElement, popEl: HTMLElement, arrowEl: HTMLElement): Promise<ComputePositionReturn> {\r\n    return await computePosition(refEl, popEl, {\r\n      placement: this.placement,\r\n      middleware: [ \r\n        offset(10), \r\n        this.flip  ? flip({ crossAxis: false }) : undefined, \r\n        shift({ limiter: limitShift(), padding: 5 }), \r\n        this.arrow ? arrow({ element: arrowEl, padding: 10 }) : undefined,\r\n      ].filter(p => p),\r\n    });\r\n  }\r\n}\r\n\r\nenum POPOVER_STATE{\r\n  IDLE       = 1,\r\n  PRESENTING = 2,\r\n  DISMISSING = 3,\r\n  VISIBLE    = 4\r\n}\r\nconst STATIC_SIDES = {\r\n  top: \"bottom\",\r\n  right: \"left\",\r\n  bottom: \"top\",\r\n  left: \"right\"\r\n};\r\nconst ROTATIONS = {\r\n  bottom: \"135deg\",\r\n  top: \"315deg\",\r\n  left: \"225deg\",\r\n  right: \"45deg\",\r\n}\r\n","<ng-template #popoverTemplate>\r\n  <div #popoverWrapper \r\n    class=\"popover-wrapper translucid-border\"\r\n    [style.height]=\"height\"\r\n    [style.width]=\"width\"\r\n    [ngClass]=\"{\r\n        'bg-light'        : fill == 'solid',\r\n        'bg-transparent'  : fill == 'outline',\r\n        'backdrop-blur-md bg-light/80': fill == 'blur',\r\n        '!border-0'       : fill == 'clear',\r\n      }\"\r\n  > \r\n    <div #popoverArrow class=\"popover-arrow size-4 translucid-border\"\r\n      [ngClass]=\"{\r\n        'bg-light'        : fill == 'solid',\r\n        'bg-transparent'  : fill == 'outline',\r\n        'backdrop-blur-md bg-light/80': fill == 'blur',\r\n        '!border-0'       : fill == 'clear',\r\n      }\"\r\n    ></div>\r\n\r\n    <ng-content #content></ng-content>\r\n  </div>\r\n</ng-template>"]}
|
|
@@ -2,9 +2,6 @@ import { NgModule } from '@angular/core';
|
|
|
2
2
|
import { CommonModule } from '@angular/common';
|
|
3
3
|
import { SIonPopoverComponent } from './sion-popover/sion-popover.component';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
|
-
const lstComponents = [
|
|
6
|
-
SIonPopoverComponent,
|
|
7
|
-
];
|
|
8
5
|
export class SIonPopoverModule {
|
|
9
6
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SIonPopoverModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
10
7
|
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: SIonPopoverModule, declarations: [SIonPopoverComponent], imports: [CommonModule], exports: [SIonPopoverComponent] }); }
|
|
@@ -13,11 +10,11 @@ export class SIonPopoverModule {
|
|
|
13
10
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SIonPopoverModule, decorators: [{
|
|
14
11
|
type: NgModule,
|
|
15
12
|
args: [{
|
|
16
|
-
declarations: [
|
|
17
|
-
exports: [
|
|
13
|
+
declarations: [SIonPopoverComponent],
|
|
14
|
+
exports: [SIonPopoverComponent],
|
|
18
15
|
imports: [
|
|
19
16
|
CommonModule
|
|
20
17
|
]
|
|
21
18
|
}]
|
|
22
19
|
}] });
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lvbi1wb3BvdmVyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy9wb3BvdmVyL3Npb24tcG9wb3Zlci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7O0FBUzdFLE1BQU0sT0FBTyxpQkFBaUI7K0dBQWpCLGlCQUFpQjtnSEFBakIsaUJBQWlCLGlCQU5aLG9CQUFvQixhQUdsQyxZQUFZLGFBRkgsb0JBQW9CO2dIQUtwQixpQkFBaUIsWUFIMUIsWUFBWTs7NEZBR0gsaUJBQWlCO2tCQVA3QixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFFLG9CQUFvQixDQUFHO29CQUN2QyxPQUFPLEVBQUUsQ0FBRSxvQkFBb0IsQ0FBRTtvQkFDakMsT0FBTyxFQUFFO3dCQUNQLFlBQVk7cUJBQ2I7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBTSW9uUG9wb3ZlckNvbXBvbmVudCB9IGZyb20gJy4vc2lvbi1wb3BvdmVyL3Npb24tcG9wb3Zlci5jb21wb25lbnQnO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBkZWNsYXJhdGlvbnM6IFsgU0lvblBvcG92ZXJDb21wb25lbnQgIF0sXHJcbiAgZXhwb3J0czogWyBTSW9uUG9wb3ZlckNvbXBvbmVudCBdLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZVxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIFNJb25Qb3BvdmVyTW9kdWxlIHsgfVxyXG4iXX0=
|