primeng 11.1.0 → 11.2.3
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 +1 -0
- package/api/confirmaeventtype.d.ts +5 -0
- package/api/filtermatchmode.d.ts +4 -0
- package/api/filterservice.d.ts +4 -0
- package/api/primeng-api.metadata.json +1 -1
- package/api/public_api.d.ts +1 -0
- package/api/translation.d.ts +4 -0
- package/autocomplete/autocomplete.d.ts +8 -1
- package/autocomplete/primeng-autocomplete.metadata.json +1 -1
- package/avatar/primeng-avatar.metadata.json +1 -1
- package/bundles/primeng-api.umd.js +56 -6
- package/bundles/primeng-api.umd.js.map +1 -1
- package/bundles/primeng-api.umd.min.js +1 -1
- package/bundles/primeng-api.umd.min.js.map +1 -1
- package/bundles/primeng-autocomplete.umd.js +86 -17
- package/bundles/primeng-autocomplete.umd.js.map +1 -1
- package/bundles/primeng-autocomplete.umd.min.js +1 -1
- package/bundles/primeng-autocomplete.umd.min.js.map +1 -1
- package/bundles/primeng-avatar.umd.js +1 -1
- package/bundles/primeng-avatar.umd.min.js +1 -1
- package/bundles/primeng-avatar.umd.min.js.map +1 -1
- package/bundles/primeng-calendar.umd.js +6 -0
- package/bundles/primeng-calendar.umd.js.map +1 -1
- package/bundles/primeng-calendar.umd.min.js +1 -1
- package/bundles/primeng-calendar.umd.min.js.map +1 -1
- package/bundles/primeng-cascadeselect.umd.js +8 -5
- package/bundles/primeng-cascadeselect.umd.js.map +1 -1
- package/bundles/primeng-cascadeselect.umd.min.js +2 -2
- package/bundles/primeng-cascadeselect.umd.min.js.map +1 -1
- package/bundles/primeng-colorpicker.umd.js.map +1 -1
- package/bundles/primeng-colorpicker.umd.min.js.map +1 -1
- package/bundles/primeng-confirmdialog.umd.js +11 -8
- package/bundles/primeng-confirmdialog.umd.js.map +1 -1
- package/bundles/primeng-confirmdialog.umd.min.js +1 -1
- package/bundles/primeng-confirmdialog.umd.min.js.map +1 -1
- package/bundles/primeng-contextmenu.umd.js +2 -2
- package/bundles/primeng-contextmenu.umd.js.map +1 -1
- package/bundles/primeng-contextmenu.umd.min.js +1 -1
- package/bundles/primeng-contextmenu.umd.min.js.map +1 -1
- package/bundles/primeng-dialog.umd.js +1 -1
- package/bundles/primeng-dialog.umd.min.js +1 -1
- package/bundles/primeng-dialog.umd.min.js.map +1 -1
- package/bundles/primeng-dom.umd.js +3 -0
- package/bundles/primeng-dom.umd.js.map +1 -1
- package/bundles/primeng-dom.umd.min.js +1 -1
- package/bundles/primeng-dom.umd.min.js.map +1 -1
- package/bundles/primeng-dropdown.umd.js +1 -1
- package/bundles/primeng-dropdown.umd.js.map +1 -1
- package/bundles/primeng-dropdown.umd.min.js +1 -1
- package/bundles/primeng-dropdown.umd.min.js.map +1 -1
- package/bundles/primeng-dynamicdialog.umd.js +1 -1
- package/bundles/primeng-dynamicdialog.umd.min.js +1 -1
- package/bundles/primeng-dynamicdialog.umd.min.js.map +1 -1
- package/bundles/primeng-inputmask.umd.js +5 -2
- package/bundles/primeng-inputmask.umd.js.map +1 -1
- package/bundles/primeng-inputmask.umd.min.js +1 -1
- package/bundles/primeng-inputmask.umd.min.js.map +1 -1
- package/bundles/primeng-inputnumber.umd.js +16 -2
- package/bundles/primeng-inputnumber.umd.js.map +1 -1
- package/bundles/primeng-inputnumber.umd.min.js +1 -1
- package/bundles/primeng-inputnumber.umd.min.js.map +1 -1
- package/bundles/primeng-knob.umd.js +1 -1
- package/bundles/primeng-knob.umd.js.map +1 -1
- package/bundles/primeng-knob.umd.min.js +1 -1
- package/bundles/primeng-knob.umd.min.js.map +1 -1
- package/bundles/primeng-lightbox.umd.js +1 -1
- package/bundles/primeng-lightbox.umd.min.js +1 -1
- package/bundles/primeng-lightbox.umd.min.js.map +1 -1
- package/bundles/primeng-listbox.umd.js +133 -34
- package/bundles/primeng-listbox.umd.js.map +1 -1
- package/bundles/primeng-listbox.umd.min.js +1 -1
- package/bundles/primeng-listbox.umd.min.js.map +1 -1
- package/bundles/primeng-multiselect.umd.js +146 -32
- package/bundles/primeng-multiselect.umd.js.map +1 -1
- package/bundles/primeng-multiselect.umd.min.js +2 -2
- package/bundles/primeng-multiselect.umd.min.js.map +1 -1
- package/bundles/primeng-sidebar.umd.js.map +1 -1
- package/bundles/primeng-sidebar.umd.min.js.map +1 -1
- package/bundles/primeng-slider.umd.js +1 -0
- package/bundles/primeng-slider.umd.js.map +1 -1
- package/bundles/primeng-slider.umd.min.js +1 -1
- package/bundles/primeng-slider.umd.min.js.map +1 -1
- package/bundles/primeng-table.umd.js +117 -16
- package/bundles/primeng-table.umd.js.map +1 -1
- package/bundles/primeng-table.umd.min.js +1 -1
- package/bundles/primeng-table.umd.min.js.map +1 -1
- package/bundles/primeng-tabview.umd.js +25 -3
- package/bundles/primeng-tabview.umd.js.map +1 -1
- package/bundles/primeng-tabview.umd.min.js +1 -1
- package/bundles/primeng-tabview.umd.min.js.map +1 -1
- package/bundles/primeng-treetable.umd.js +1 -1
- package/bundles/primeng-treetable.umd.js.map +1 -1
- package/bundles/primeng-treetable.umd.min.js +1 -1
- package/bundles/primeng-treetable.umd.min.js.map +1 -1
- package/bundles/primeng-virtualscroller.umd.js +3 -2
- package/bundles/primeng-virtualscroller.umd.js.map +1 -1
- package/bundles/primeng-virtualscroller.umd.min.js +1 -1
- package/bundles/primeng-virtualscroller.umd.min.js.map +1 -1
- package/calendar/primeng-calendar.metadata.json +1 -1
- package/cascadeselect/cascadeselect.d.ts +3 -3
- package/cascadeselect/primeng-cascadeselect.metadata.json +1 -1
- package/colorpicker/colorpicker.d.ts +1 -1
- package/confirmdialog/confirmdialog.d.ts +3 -2
- package/confirmdialog/primeng-confirmdialog.metadata.json +1 -1
- package/dialog/primeng-dialog.metadata.json +1 -1
- package/dom/primeng-dom.metadata.json +1 -1
- package/dropdown/primeng-dropdown.metadata.json +1 -1
- package/dynamicdialog/primeng-dynamicdialog.metadata.json +1 -1
- package/esm2015/api/confirmaeventtype.js +7 -0
- package/esm2015/api/filtermatchmode.js +5 -1
- package/esm2015/api/filterservice.js +39 -3
- package/esm2015/api/primengconfig.js +9 -5
- package/esm2015/api/public_api.js +2 -1
- package/esm2015/api/translation.js +1 -1
- package/esm2015/autocomplete/autocomplete.js +105 -22
- package/esm2015/avatar/avatar.js +1 -1
- package/esm2015/calendar/calendar.js +7 -1
- package/esm2015/cascadeselect/cascadeselect.js +9 -6
- package/esm2015/colorpicker/colorpicker.js +1 -1
- package/esm2015/confirmdialog/confirmdialog.js +14 -11
- package/esm2015/contextmenu/contextmenu.js +3 -3
- package/esm2015/dialog/dialog.js +1 -1
- package/esm2015/dom/domhandler.js +4 -1
- package/esm2015/dropdown/dropdown.js +2 -2
- package/esm2015/dynamicdialog/dynamicdialog.js +1 -1
- package/esm2015/inputmask/inputmask.js +6 -3
- package/esm2015/inputnumber/inputnumber.js +13 -3
- package/esm2015/knob/knob.js +2 -2
- package/esm2015/lightbox/lightbox.js +1 -1
- package/esm2015/listbox/listbox.js +134 -42
- package/esm2015/multiselect/multiselect.js +149 -42
- package/esm2015/sidebar/sidebar.js +1 -1
- package/esm2015/slider/slider.js +2 -1
- package/esm2015/table/table.js +127 -17
- package/esm2015/tabview/tabview.js +18 -4
- package/esm2015/treetable/treetable.js +2 -2
- package/esm2015/virtualscroller/virtualscroller.js +4 -3
- package/fesm2015/primeng-api.js +58 -7
- package/fesm2015/primeng-api.js.map +1 -1
- package/fesm2015/primeng-autocomplete.js +104 -21
- package/fesm2015/primeng-autocomplete.js.map +1 -1
- package/fesm2015/primeng-avatar.js +1 -1
- package/fesm2015/primeng-calendar.js +6 -0
- package/fesm2015/primeng-calendar.js.map +1 -1
- package/fesm2015/primeng-cascadeselect.js +8 -5
- package/fesm2015/primeng-cascadeselect.js.map +1 -1
- package/fesm2015/primeng-colorpicker.js.map +1 -1
- package/fesm2015/primeng-confirmdialog.js +13 -10
- package/fesm2015/primeng-confirmdialog.js.map +1 -1
- package/fesm2015/primeng-contextmenu.js +2 -2
- package/fesm2015/primeng-contextmenu.js.map +1 -1
- package/fesm2015/primeng-dialog.js +1 -1
- package/fesm2015/primeng-dom.js +3 -0
- package/fesm2015/primeng-dom.js.map +1 -1
- package/fesm2015/primeng-dropdown.js +1 -1
- package/fesm2015/primeng-dropdown.js.map +1 -1
- package/fesm2015/primeng-dynamicdialog.js +1 -1
- package/fesm2015/primeng-inputmask.js +5 -2
- package/fesm2015/primeng-inputmask.js.map +1 -1
- package/fesm2015/primeng-inputnumber.js +12 -2
- package/fesm2015/primeng-inputnumber.js.map +1 -1
- package/fesm2015/primeng-knob.js +1 -1
- package/fesm2015/primeng-knob.js.map +1 -1
- package/fesm2015/primeng-lightbox.js +1 -1
- package/fesm2015/primeng-listbox.js +133 -41
- package/fesm2015/primeng-listbox.js.map +1 -1
- package/fesm2015/primeng-multiselect.js +148 -41
- package/fesm2015/primeng-multiselect.js.map +1 -1
- package/fesm2015/primeng-sidebar.js.map +1 -1
- package/fesm2015/primeng-slider.js +1 -0
- package/fesm2015/primeng-slider.js.map +1 -1
- package/fesm2015/primeng-table.js +126 -16
- package/fesm2015/primeng-table.js.map +1 -1
- package/fesm2015/primeng-tabview.js +17 -3
- package/fesm2015/primeng-tabview.js.map +1 -1
- package/fesm2015/primeng-treetable.js +1 -1
- package/fesm2015/primeng-treetable.js.map +1 -1
- package/fesm2015/primeng-virtualscroller.js +3 -2
- package/fesm2015/primeng-virtualscroller.js.map +1 -1
- package/inputmask/inputmask.d.ts +2 -1
- package/inputmask/primeng-inputmask.metadata.json +1 -1
- package/inputnumber/inputnumber.d.ts +3 -1
- package/inputnumber/primeng-inputnumber.metadata.json +1 -1
- package/knob/primeng-knob.metadata.json +1 -1
- package/lightbox/primeng-lightbox.metadata.json +1 -1
- package/listbox/listbox.d.ts +7 -1
- package/listbox/primeng-listbox.metadata.json +1 -1
- package/multiselect/multiselect.d.ts +8 -1
- package/multiselect/primeng-multiselect.metadata.json +1 -1
- package/package.json +1 -1
- package/resources/components/avatar/avatar.css +3 -2
- package/resources/components/dialog/dialog.css +2 -0
- package/resources/components/virtualscroller/virtualscroller.css +2 -16
- package/resources/themes/arya-blue/theme.css +26 -38
- package/resources/themes/arya-green/theme.css +26 -38
- package/resources/themes/arya-orange/theme.css +26 -38
- package/resources/themes/arya-purple/theme.css +26 -38
- package/resources/themes/bootstrap4-dark-blue/theme.css +26 -38
- package/resources/themes/bootstrap4-dark-purple/theme.css +26 -38
- package/resources/themes/bootstrap4-light-blue/theme.css +26 -38
- package/resources/themes/bootstrap4-light-purple/theme.css +26 -38
- package/resources/themes/fluent-light/theme.css +26 -38
- package/resources/themes/luna-amber/theme.css +26 -38
- package/resources/themes/luna-blue/theme.css +26 -38
- package/resources/themes/luna-green/theme.css +26 -38
- package/resources/themes/luna-pink/theme.css +26 -38
- package/resources/themes/md-dark-deeppurple/theme.css +89 -69
- package/resources/themes/md-dark-indigo/theme.css +89 -69
- package/resources/themes/md-light-deeppurple/theme.css +293 -273
- package/resources/themes/md-light-indigo/theme.css +293 -273
- package/resources/themes/mdc-dark-deeppurple/theme.css +89 -69
- package/resources/themes/mdc-dark-indigo/theme.css +89 -69
- package/resources/themes/mdc-light-deeppurple/theme.css +293 -273
- package/resources/themes/mdc-light-indigo/theme.css +293 -273
- package/resources/themes/nova/theme.css +26 -38
- package/resources/themes/nova-accent/theme.css +26 -38
- package/resources/themes/nova-alt/theme.css +26 -38
- package/resources/themes/rhea/theme.css +26 -38
- package/resources/themes/saga-blue/theme.css +26 -38
- package/resources/themes/saga-green/theme.css +26 -38
- package/resources/themes/saga-orange/theme.css +26 -38
- package/resources/themes/saga-purple/theme.css +26 -38
- package/resources/themes/vela-blue/theme.css +26 -38
- package/resources/themes/vela-green/theme.css +26 -38
- package/resources/themes/vela-orange/theme.css +26 -38
- package/resources/themes/vela-purple/theme.css +26 -38
- package/sidebar/sidebar.d.ts +1 -1
- package/slider/primeng-slider.metadata.json +1 -1
- package/table/primeng-table.metadata.json +1 -1
- package/table/table.d.ts +12 -0
- package/tabview/primeng-tabview.metadata.json +1 -1
- package/tabview/tabview.d.ts +6 -2
- package/treetable/primeng-treetable.metadata.json +1 -1
- package/virtualscroller/primeng-virtualscroller.metadata.json +1 -1
@@ -179,7 +179,7 @@
|
|
179
179
|
template: "\n <div [ngStyle]=\"style\" [class]=\"styleClass\" *ngIf=\"(type == 'image')\">\n <a *ngFor=\"let image of images; let i = index;\" [href]=\"image.source\" (click)=\"onImageClick($event,image,i,content)\">\n <img [src]=\"image.thumbnail\" [title]=\"image.title\" [alt]=\"image.alt\">\n </a>\n </div>\n <span [ngStyle]=\"style\" [class]=\"styleClass\" *ngIf=\"(type == 'content')\" (click)=\"onLinkClick($event,content)\">\n <ng-content select=\"a\"></ng-content>\n </span>\n <div class=\"ui-lightbox ui-widget ui-corner-all ui-shadow\" [style.display]=\"visible ? 'block' : 'none'\" [style.zIndex]=\"zindex\"\n [ngClass]=\"{'ui-lightbox-loading': loading}\"\n [style.transitionProperty]=\"'all'\" [style.transitionDuration]=\"effectDuration\" [style.transitionTimingFunction]=\"easing\" (click)=\"preventDocumentClickListener=true\">\n <div class=\"ui-lightbox-content-wrapper\">\n <a class=\"ui-state-default ui-lightbox-nav-left ui-corner-right\" [style.zIndex]=\"zindex + 1\" (click)=\"prev(img)\"\n [ngClass]=\"{'ui-helper-hidden':!leftVisible}\"><span class=\"ui-lightbox-nav-icon pi pi-chevron-left\"></span></a>\n <div #content class=\"ui-lightbox-content ui-corner-all\" \n [style.transitionProperty]=\"'width,height'\" [style.transitionDuration]=\"effectDuration\" [style.transitionTimingFunction]=\"easing\">\n <img #img [src]=\"currentImage ? currentImage.source||'' : ''\" (load)=\"onImageLoad($event,content)\" style=\"display:none\">\n <ng-content></ng-content>\n </div>\n <a class=\"ui-state-default ui-lightbox-nav-right ui-corner-left ui-helper-hidden\" [style.zIndex]=\"zindex + 1\" (click)=\"next(img)\"\n [ngClass]=\"{'ui-helper-hidden':!rightVisible}\"><span class=\"ui-lightbox-nav-icon pi pi-chevron-right\"></span></a>\n </div>\n <div class=\"ui-lightbox-caption ui-widget-header\" [style.display]=\"captionText ? 'block' : 'none'\">\n <span class=\"ui-lightbox-caption-text\">{{captionText}}</span><a class=\"ui-lightbox-close ui-corner-all\" tabindex=\"0\" (click)=\"hide($event)\" (keydown.enter)=\"hide($event)\"><span class=\"pi pi-times\"></span></a>\n <div style=\"clear:both\"></div>\n </div>\n </div>\n ",
|
180
180
|
changeDetection: core.ChangeDetectionStrategy.Default,
|
181
181
|
encapsulation: core.ViewEncapsulation.None,
|
182
|
-
styles: [".ui-lightbox{display:none;left:50%;position:fixed;top:50%;transform:translateX(-50%) translateY(-50%)}.ui-lightbox-content-wrapper{position:relative}.ui-lightbox-content{background-color:#000;margin:0;padding:0;position:relative}.ui-lightbox-nav-left,.ui-lightbox-nav-right{cursor:pointer;position:absolute;top:50%}.ui-lightbox-nav-left{left:0}.ui-lightbox-nav-right{right:0}.ui-lightbox-loading .ui-lightbox-content{background:url(\"\") #000 50% no-repeat}.ui-lightbox-caption{display:none;padding:.2em .4em}.ui-lightbox-caption-text{float:left;margin:.3em 0 .1em}.ui-lightbox-close{float:right;margin:0;padding:.125em}.ui-lightbox-close.ui-state-hover{padding:0}.ui-lightbox-nav-left,.ui-lightbox-nav-right{opacity:.5}.ui-lightbox-nav-left:hover,.ui-lightbox-nav-right:hover{opacity:1}", ".p-dialog-mask{align-items:center;background-color:transparent;display:flex;height:100%;justify-content:center;left:0;pointer-events:none;position:fixed;top:0;transition-property:background-color;width:100%}.p-dialog,.p-dialog-mask.p-component-overlay{pointer-events:auto}.p-dialog{display:flex;flex-direction:column;max-height:90%;position:relative;transform:scale(1)}.p-dialog-content{overflow-y:auto}.p-dialog-header{align-items:center;display:flex;flex-shrink:0;justify-content:space-between}.p-dialog-footer{flex-shrink:0}.p-dialog .p-dialog-header-icons{align-items:center;display:flex}.p-dialog .p-dialog-header-icon{align-items:center;display:flex;justify-content:center;overflow:hidden;position:relative}.p-dialog-mask.p-dialog-mask-leave{background-color:transparent}.p-fluid .p-dialog-footer .p-button{width:auto}.p-dialog-bottom-left .p-dialog,.p-dialog-bottom-right .p-dialog,.p-dialog-bottom .p-dialog,.p-dialog-left .p-dialog,.p-dialog-right .p-dialog,.p-dialog-top-left .p-dialog,.p-dialog-top-right .p-dialog,.p-dialog-top .p-dialog{margin:.75rem;transform:translateZ(0)}.p-dialog-maximized{height:100%;max-height:100%;transform:none;transition:none;width:100vw!important}.p-dialog-maximized .p-dialog-content{flex-grow:1}.p-dialog-left{justify-content:flex-start}.p-dialog-right{justify-content:flex-end}.p-dialog-top,.p-dialog-top-left{align-items:flex-start}.p-dialog-top-left{justify-content:flex-start}.p-dialog-top-right{align-items:flex-start;justify-content:flex-end}.p-dialog-bottom{align-items:flex-end}.p-dialog-bottom-left{align-items:flex-end;justify-content:flex-start}.p-dialog-bottom-right{align-items:flex-end;justify-content:flex-end}.p-dialog .p-resizable-handle{bottom:1px;cursor:se-resize;display:block;font-size:.1px;height:12px;position:absolute;right:1px;width:12px}.p-confirm-dialog .p-dialog-content{align-items:center;display:flex}"]
|
182
|
+
styles: [".ui-lightbox{display:none;left:50%;position:fixed;top:50%;transform:translateX(-50%) translateY(-50%)}.ui-lightbox-content-wrapper{position:relative}.ui-lightbox-content{background-color:#000;margin:0;padding:0;position:relative}.ui-lightbox-nav-left,.ui-lightbox-nav-right{cursor:pointer;position:absolute;top:50%}.ui-lightbox-nav-left{left:0}.ui-lightbox-nav-right{right:0}.ui-lightbox-loading .ui-lightbox-content{background:url(\"\") #000 50% no-repeat}.ui-lightbox-caption{display:none;padding:.2em .4em}.ui-lightbox-caption-text{float:left;margin:.3em 0 .1em}.ui-lightbox-close{float:right;margin:0;padding:.125em}.ui-lightbox-close.ui-state-hover{padding:0}.ui-lightbox-nav-left,.ui-lightbox-nav-right{opacity:.5}.ui-lightbox-nav-left:hover,.ui-lightbox-nav-right:hover{opacity:1}", ".p-dialog-mask{align-items:center;background-color:transparent;display:flex;height:100%;justify-content:center;left:0;pointer-events:none;position:fixed;top:0;transition-property:background-color;width:100%}.p-dialog,.p-dialog-mask.p-component-overlay{pointer-events:auto}.p-dialog{display:flex;flex-direction:column;max-height:90%;position:relative;transform:scale(1)}.p-dialog-content{overflow-y:auto}.p-dialog-header{align-items:center;display:flex;flex-shrink:0;justify-content:space-between}.p-dialog-footer{flex-shrink:0}.p-dialog .p-dialog-header-icons{align-items:center;display:flex}.p-dialog .p-dialog-header-icon{align-items:center;display:flex;justify-content:center;overflow:hidden;position:relative}.p-dialog-mask.p-dialog-mask-leave{background-color:transparent}.p-fluid .p-dialog-footer .p-button{width:auto}.p-dialog-bottom-left .p-dialog,.p-dialog-bottom-right .p-dialog,.p-dialog-bottom .p-dialog,.p-dialog-left .p-dialog,.p-dialog-right .p-dialog,.p-dialog-top-left .p-dialog,.p-dialog-top-right .p-dialog,.p-dialog-top .p-dialog{margin:.75rem;transform:translateZ(0)}.p-dialog-maximized{height:100%;left:0!important;max-height:100%;top:0!important;transform:none;transition:none;width:100vw!important}.p-dialog-maximized .p-dialog-content{flex-grow:1}.p-dialog-left{justify-content:flex-start}.p-dialog-right{justify-content:flex-end}.p-dialog-top,.p-dialog-top-left{align-items:flex-start}.p-dialog-top-left{justify-content:flex-start}.p-dialog-top-right{align-items:flex-start;justify-content:flex-end}.p-dialog-bottom{align-items:flex-end}.p-dialog-bottom-left{align-items:flex-end;justify-content:flex-start}.p-dialog-bottom-right{align-items:flex-end;justify-content:flex-end}.p-dialog .p-resizable-handle{bottom:1px;cursor:se-resize;display:block;font-size:.1px;height:12px;position:absolute;right:1px;width:12px}.p-confirm-dialog .p-dialog-content{align-items:center;display:flex}"]
|
183
183
|
},] }
|
184
184
|
];
|
185
185
|
Lightbox.ctorParameters = function () { return [
|
@@ -1,2 +1,2 @@
|
|
1
|
-
!function(A,i){"object"==typeof exports&&"undefined"!=typeof module?i(exports,require("@angular/core"),require("@angular/common"),require("primeng/dom")):"function"==typeof define&&define.amd?define("primeng/lightbox",["exports","@angular/core","@angular/common","primeng/dom"],i):i(((A="undefined"!=typeof globalThis?globalThis:A||self).primeng=A.primeng||{},A.primeng.lightbox={}),A.ng.core,A.ng.common,A.primeng.dom)}(this,(function(A,i,e,t){"use strict";var o=function(){function A(A,i,e){this.el=A,this.renderer=i,this.cd=e,this.type="image",this.effectDuration="500ms",this.autoZIndex=!0,this.baseZIndex=0,this.closeOnEscape=!0}return A.prototype.onImageClick=function(A,i,e,t){this.index=e,this.loading=!0,t.style.width="32px",t.style.height="32px",this.preventDocumentClickListener=!0,this.show(),this.displayImage(i),A.preventDefault()},A.prototype.ngAfterViewInit=function(){this.panel=t.DomHandler.findSingle(this.el.nativeElement,".ui-lightbox "),this.appendTo&&("body"===this.appendTo?document.body.appendChild(this.panel):t.DomHandler.appendChild(this.panel,this.appendTo))},A.prototype.onLinkClick=function(A,i){this.preventDocumentClickListener=!0,this.show(),A.preventDefault()},A.prototype.displayImage=function(A){var i=this;setTimeout((function(){i.cd.markForCheck(),i.currentImage=A,i.captionText=A.title,i.center()}),1e3)},A.prototype.show=function(){this.mask=document.createElement("div"),t.DomHandler.addMultipleClasses(this.mask,"ui-widget-overlay ui-dialog-mask"),document.body.appendChild(this.mask),this.autoZIndex&&(this.zindex=this.baseZIndex+ ++t.DomHandler.zindex),this.mask.style.zIndex=this.zindex-1,this.center(),this.visible=!0,this.bindGlobalListeners()},A.prototype.hide=function(A){this.captionText=null,this.index=null,this.currentImage=null,this.visible=!1,this.mask&&(document.body.removeChild(this.mask),this.mask=null),this.unbindGlobalListeners(),A.preventDefault()},A.prototype.center=function(){var A=t.DomHandler.getOuterWidth(this.panel),i=t.DomHandler.getOuterHeight(this.panel);0==A&&0==i&&(this.panel.style.visibility="hidden",this.panel.style.display="block",A=t.DomHandler.getOuterWidth(this.panel),i=t.DomHandler.getOuterHeight(this.panel),this.panel.style.display="none",this.panel.style.visibility="visible")},A.prototype.onImageLoad=function(A,i){var e=this,o=A.target;o.style.visibility="hidden",o.style.display="block";var g=t.DomHandler.getOuterWidth(o),n=t.DomHandler.getOuterHeight(o);o.style.display="none",o.style.visibility="visible",i.style.width=g+"px",i.style.height=n+"px",this.panel.style.left=parseInt(this.panel.style.left)+(t.DomHandler.getOuterWidth(this.panel)-g)/2+"px",this.panel.style.top=parseInt(this.panel.style.top)+(t.DomHandler.getOuterHeight(this.panel)-n)/2+"px",setTimeout((function(){e.cd.markForCheck(),t.DomHandler.fadeIn(o,500),o.style.display="block",e.loading=!1}),parseInt(this.effectDuration))},A.prototype.prev=function(A){this.captionText=null,this.loading=!0,A.style.display="none",this.index>0&&this.displayImage(this.images[--this.index])},A.prototype.next=function(A){this.captionText=null,this.loading=!0,A.style.display="none",this.index<=this.images.length-1&&this.displayImage(this.images[++this.index])},A.prototype.bindGlobalListeners=function(){var A=this,i=this.el?this.el.nativeElement.ownerDocument:"document";this.documentClickListener=this.renderer.listen(i,"click",(function(i){!A.preventDocumentClickListener&&A.visible&&A.hide(i),A.preventDocumentClickListener=!1,A.cd.markForCheck()})),this.closeOnEscape&&!this.documentEscapeListener&&(this.documentEscapeListener=this.renderer.listen(i,"keydown",(function(i){27==i.which&&parseInt(A.panel.style.zIndex)===t.DomHandler.zindex+A.baseZIndex&&A.hide(i)})))},A.prototype.unbindGlobalListeners=function(){this.documentEscapeListener&&(this.documentEscapeListener(),this.documentEscapeListener=null),this.documentClickListener&&(this.documentClickListener(),this.documentClickListener=null)},Object.defineProperty(A.prototype,"leftVisible",{get:function(){return this.images&&this.images.length&&0!=this.index&&!this.loading},enumerable:!1,configurable:!0}),Object.defineProperty(A.prototype,"rightVisible",{get:function(){return this.images&&this.images.length&&this.index<this.images.length-1&&!this.loading},enumerable:!1,configurable:!0}),A.prototype.ngOnDestroy=function(){this.unbindGlobalListeners(),this.appendTo&&this.el.nativeElement.appendChild(this.panel)},A}();o.decorators=[{type:i.Component,args:[{selector:"p-lightbox",template:'\n <div [ngStyle]="style" [class]="styleClass" *ngIf="(type == \'image\')">\n <a *ngFor="let image of images; let i = index;" [href]="image.source" (click)="onImageClick($event,image,i,content)">\n <img [src]="image.thumbnail" [title]="image.title" [alt]="image.alt">\n </a>\n </div>\n <span [ngStyle]="style" [class]="styleClass" *ngIf="(type == \'content\')" (click)="onLinkClick($event,content)">\n <ng-content select="a"></ng-content>\n </span>\n <div class="ui-lightbox ui-widget ui-corner-all ui-shadow" [style.display]="visible ? \'block\' : \'none\'" [style.zIndex]="zindex"\n [ngClass]="{\'ui-lightbox-loading\': loading}"\n [style.transitionProperty]="\'all\'" [style.transitionDuration]="effectDuration" [style.transitionTimingFunction]="easing" (click)="preventDocumentClickListener=true">\n <div class="ui-lightbox-content-wrapper">\n <a class="ui-state-default ui-lightbox-nav-left ui-corner-right" [style.zIndex]="zindex + 1" (click)="prev(img)"\n [ngClass]="{\'ui-helper-hidden\':!leftVisible}"><span class="ui-lightbox-nav-icon pi pi-chevron-left"></span></a>\n <div #content class="ui-lightbox-content ui-corner-all" \n [style.transitionProperty]="\'width,height\'" [style.transitionDuration]="effectDuration" [style.transitionTimingFunction]="easing">\n <img #img [src]="currentImage ? currentImage.source||\'\' : \'\'" (load)="onImageLoad($event,content)" style="display:none">\n <ng-content></ng-content>\n </div>\n <a class="ui-state-default ui-lightbox-nav-right ui-corner-left ui-helper-hidden" [style.zIndex]="zindex + 1" (click)="next(img)"\n [ngClass]="{\'ui-helper-hidden\':!rightVisible}"><span class="ui-lightbox-nav-icon pi pi-chevron-right"></span></a>\n </div>\n <div class="ui-lightbox-caption ui-widget-header" [style.display]="captionText ? \'block\' : \'none\'">\n <span class="ui-lightbox-caption-text">{{captionText}}</span><a class="ui-lightbox-close ui-corner-all" tabindex="0" (click)="hide($event)" (keydown.enter)="hide($event)"><span class="pi pi-times"></span></a>\n <div style="clear:both"></div>\n </div>\n </div>\n ',changeDetection:i.ChangeDetectionStrategy.Default,encapsulation:i.ViewEncapsulation.None,styles:['.ui-lightbox{display:none;left:50%;position:fixed;top:50%;transform:translateX(-50%) translateY(-50%)}.ui-lightbox-content-wrapper{position:relative}.ui-lightbox-content{background-color:#000;margin:0;padding:0;position:relative}.ui-lightbox-nav-left,.ui-lightbox-nav-right{cursor:pointer;position:absolute;top:50%}.ui-lightbox-nav-left{left:0}.ui-lightbox-nav-right{right:0}.ui-lightbox-loading .ui-lightbox-content{background:url("") #000 50% no-repeat}.ui-lightbox-caption{display:none;padding:.2em .4em}.ui-lightbox-caption-text{float:left;margin:.3em 0 .1em}.ui-lightbox-close{float:right;margin:0;padding:.125em}.ui-lightbox-close.ui-state-hover{padding:0}.ui-lightbox-nav-left,.ui-lightbox-nav-right{opacity:.5}.ui-lightbox-nav-left:hover,.ui-lightbox-nav-right:hover{opacity:1}',".p-dialog-mask{align-items:center;background-color:transparent;display:flex;height:100%;justify-content:center;left:0;pointer-events:none;position:fixed;top:0;transition-property:background-color;width:100%}.p-dialog,.p-dialog-mask.p-component-overlay{pointer-events:auto}.p-dialog{display:flex;flex-direction:column;max-height:90%;position:relative;transform:scale(1)}.p-dialog-content{overflow-y:auto}.p-dialog-header{align-items:center;display:flex;flex-shrink:0;justify-content:space-between}.p-dialog-footer{flex-shrink:0}.p-dialog .p-dialog-header-icons{align-items:center;display:flex}.p-dialog .p-dialog-header-icon{align-items:center;display:flex;justify-content:center;overflow:hidden;position:relative}.p-dialog-mask.p-dialog-mask-leave{background-color:transparent}.p-fluid .p-dialog-footer .p-button{width:auto}.p-dialog-bottom-left .p-dialog,.p-dialog-bottom-right .p-dialog,.p-dialog-bottom .p-dialog,.p-dialog-left .p-dialog,.p-dialog-right .p-dialog,.p-dialog-top-left .p-dialog,.p-dialog-top-right .p-dialog,.p-dialog-top .p-dialog{margin:.75rem;transform:translateZ(0)}.p-dialog-maximized{height:100%;max-height:100%;transform:none;transition:none;width:100vw!important}.p-dialog-maximized .p-dialog-content{flex-grow:1}.p-dialog-left{justify-content:flex-start}.p-dialog-right{justify-content:flex-end}.p-dialog-top,.p-dialog-top-left{align-items:flex-start}.p-dialog-top-left{justify-content:flex-start}.p-dialog-top-right{align-items:flex-start;justify-content:flex-end}.p-dialog-bottom{align-items:flex-end}.p-dialog-bottom-left{align-items:flex-end;justify-content:flex-start}.p-dialog-bottom-right{align-items:flex-end;justify-content:flex-end}.p-dialog .p-resizable-handle{bottom:1px;cursor:se-resize;display:block;font-size:.1px;height:12px;position:absolute;right:1px;width:12px}.p-confirm-dialog .p-dialog-content{align-items:center;display:flex}"]}]}],o.ctorParameters=function(){return[{type:i.ElementRef},{type:i.Renderer2},{type:i.ChangeDetectorRef}]},o.propDecorators={images:[{type:i.Input}],type:[{type:i.Input}],style:[{type:i.Input}],styleClass:[{type:i.Input}],appendTo:[{type:i.Input}],easing:[{type:i.Input}],effectDuration:[{type:i.Input}],autoZIndex:[{type:i.Input}],baseZIndex:[{type:i.Input}],closeOnEscape:[{type:i.Input}]};var g=function(){};g.decorators=[{type:i.NgModule,args:[{imports:[e.CommonModule],exports:[o],declarations:[o]}]}],A.Lightbox=o,A.LightboxModule=g,Object.defineProperty(A,"__esModule",{value:!0})}));
|
1
|
+
!function(A,i){"object"==typeof exports&&"undefined"!=typeof module?i(exports,require("@angular/core"),require("@angular/common"),require("primeng/dom")):"function"==typeof define&&define.amd?define("primeng/lightbox",["exports","@angular/core","@angular/common","primeng/dom"],i):i(((A="undefined"!=typeof globalThis?globalThis:A||self).primeng=A.primeng||{},A.primeng.lightbox={}),A.ng.core,A.ng.common,A.primeng.dom)}(this,(function(A,i,e,t){"use strict";var o=function(){function A(A,i,e){this.el=A,this.renderer=i,this.cd=e,this.type="image",this.effectDuration="500ms",this.autoZIndex=!0,this.baseZIndex=0,this.closeOnEscape=!0}return A.prototype.onImageClick=function(A,i,e,t){this.index=e,this.loading=!0,t.style.width="32px",t.style.height="32px",this.preventDocumentClickListener=!0,this.show(),this.displayImage(i),A.preventDefault()},A.prototype.ngAfterViewInit=function(){this.panel=t.DomHandler.findSingle(this.el.nativeElement,".ui-lightbox "),this.appendTo&&("body"===this.appendTo?document.body.appendChild(this.panel):t.DomHandler.appendChild(this.panel,this.appendTo))},A.prototype.onLinkClick=function(A,i){this.preventDocumentClickListener=!0,this.show(),A.preventDefault()},A.prototype.displayImage=function(A){var i=this;setTimeout((function(){i.cd.markForCheck(),i.currentImage=A,i.captionText=A.title,i.center()}),1e3)},A.prototype.show=function(){this.mask=document.createElement("div"),t.DomHandler.addMultipleClasses(this.mask,"ui-widget-overlay ui-dialog-mask"),document.body.appendChild(this.mask),this.autoZIndex&&(this.zindex=this.baseZIndex+ ++t.DomHandler.zindex),this.mask.style.zIndex=this.zindex-1,this.center(),this.visible=!0,this.bindGlobalListeners()},A.prototype.hide=function(A){this.captionText=null,this.index=null,this.currentImage=null,this.visible=!1,this.mask&&(document.body.removeChild(this.mask),this.mask=null),this.unbindGlobalListeners(),A.preventDefault()},A.prototype.center=function(){var A=t.DomHandler.getOuterWidth(this.panel),i=t.DomHandler.getOuterHeight(this.panel);0==A&&0==i&&(this.panel.style.visibility="hidden",this.panel.style.display="block",A=t.DomHandler.getOuterWidth(this.panel),i=t.DomHandler.getOuterHeight(this.panel),this.panel.style.display="none",this.panel.style.visibility="visible")},A.prototype.onImageLoad=function(A,i){var e=this,o=A.target;o.style.visibility="hidden",o.style.display="block";var g=t.DomHandler.getOuterWidth(o),n=t.DomHandler.getOuterHeight(o);o.style.display="none",o.style.visibility="visible",i.style.width=g+"px",i.style.height=n+"px",this.panel.style.left=parseInt(this.panel.style.left)+(t.DomHandler.getOuterWidth(this.panel)-g)/2+"px",this.panel.style.top=parseInt(this.panel.style.top)+(t.DomHandler.getOuterHeight(this.panel)-n)/2+"px",setTimeout((function(){e.cd.markForCheck(),t.DomHandler.fadeIn(o,500),o.style.display="block",e.loading=!1}),parseInt(this.effectDuration))},A.prototype.prev=function(A){this.captionText=null,this.loading=!0,A.style.display="none",this.index>0&&this.displayImage(this.images[--this.index])},A.prototype.next=function(A){this.captionText=null,this.loading=!0,A.style.display="none",this.index<=this.images.length-1&&this.displayImage(this.images[++this.index])},A.prototype.bindGlobalListeners=function(){var A=this,i=this.el?this.el.nativeElement.ownerDocument:"document";this.documentClickListener=this.renderer.listen(i,"click",(function(i){!A.preventDocumentClickListener&&A.visible&&A.hide(i),A.preventDocumentClickListener=!1,A.cd.markForCheck()})),this.closeOnEscape&&!this.documentEscapeListener&&(this.documentEscapeListener=this.renderer.listen(i,"keydown",(function(i){27==i.which&&parseInt(A.panel.style.zIndex)===t.DomHandler.zindex+A.baseZIndex&&A.hide(i)})))},A.prototype.unbindGlobalListeners=function(){this.documentEscapeListener&&(this.documentEscapeListener(),this.documentEscapeListener=null),this.documentClickListener&&(this.documentClickListener(),this.documentClickListener=null)},Object.defineProperty(A.prototype,"leftVisible",{get:function(){return this.images&&this.images.length&&0!=this.index&&!this.loading},enumerable:!1,configurable:!0}),Object.defineProperty(A.prototype,"rightVisible",{get:function(){return this.images&&this.images.length&&this.index<this.images.length-1&&!this.loading},enumerable:!1,configurable:!0}),A.prototype.ngOnDestroy=function(){this.unbindGlobalListeners(),this.appendTo&&this.el.nativeElement.appendChild(this.panel)},A}();o.decorators=[{type:i.Component,args:[{selector:"p-lightbox",template:'\n <div [ngStyle]="style" [class]="styleClass" *ngIf="(type == \'image\')">\n <a *ngFor="let image of images; let i = index;" [href]="image.source" (click)="onImageClick($event,image,i,content)">\n <img [src]="image.thumbnail" [title]="image.title" [alt]="image.alt">\n </a>\n </div>\n <span [ngStyle]="style" [class]="styleClass" *ngIf="(type == \'content\')" (click)="onLinkClick($event,content)">\n <ng-content select="a"></ng-content>\n </span>\n <div class="ui-lightbox ui-widget ui-corner-all ui-shadow" [style.display]="visible ? \'block\' : \'none\'" [style.zIndex]="zindex"\n [ngClass]="{\'ui-lightbox-loading\': loading}"\n [style.transitionProperty]="\'all\'" [style.transitionDuration]="effectDuration" [style.transitionTimingFunction]="easing" (click)="preventDocumentClickListener=true">\n <div class="ui-lightbox-content-wrapper">\n <a class="ui-state-default ui-lightbox-nav-left ui-corner-right" [style.zIndex]="zindex + 1" (click)="prev(img)"\n [ngClass]="{\'ui-helper-hidden\':!leftVisible}"><span class="ui-lightbox-nav-icon pi pi-chevron-left"></span></a>\n <div #content class="ui-lightbox-content ui-corner-all" \n [style.transitionProperty]="\'width,height\'" [style.transitionDuration]="effectDuration" [style.transitionTimingFunction]="easing">\n <img #img [src]="currentImage ? currentImage.source||\'\' : \'\'" (load)="onImageLoad($event,content)" style="display:none">\n <ng-content></ng-content>\n </div>\n <a class="ui-state-default ui-lightbox-nav-right ui-corner-left ui-helper-hidden" [style.zIndex]="zindex + 1" (click)="next(img)"\n [ngClass]="{\'ui-helper-hidden\':!rightVisible}"><span class="ui-lightbox-nav-icon pi pi-chevron-right"></span></a>\n </div>\n <div class="ui-lightbox-caption ui-widget-header" [style.display]="captionText ? \'block\' : \'none\'">\n <span class="ui-lightbox-caption-text">{{captionText}}</span><a class="ui-lightbox-close ui-corner-all" tabindex="0" (click)="hide($event)" (keydown.enter)="hide($event)"><span class="pi pi-times"></span></a>\n <div style="clear:both"></div>\n </div>\n </div>\n ',changeDetection:i.ChangeDetectionStrategy.Default,encapsulation:i.ViewEncapsulation.None,styles:['.ui-lightbox{display:none;left:50%;position:fixed;top:50%;transform:translateX(-50%) translateY(-50%)}.ui-lightbox-content-wrapper{position:relative}.ui-lightbox-content{background-color:#000;margin:0;padding:0;position:relative}.ui-lightbox-nav-left,.ui-lightbox-nav-right{cursor:pointer;position:absolute;top:50%}.ui-lightbox-nav-left{left:0}.ui-lightbox-nav-right{right:0}.ui-lightbox-loading .ui-lightbox-content{background:url("") #000 50% no-repeat}.ui-lightbox-caption{display:none;padding:.2em .4em}.ui-lightbox-caption-text{float:left;margin:.3em 0 .1em}.ui-lightbox-close{float:right;margin:0;padding:.125em}.ui-lightbox-close.ui-state-hover{padding:0}.ui-lightbox-nav-left,.ui-lightbox-nav-right{opacity:.5}.ui-lightbox-nav-left:hover,.ui-lightbox-nav-right:hover{opacity:1}',".p-dialog-mask{align-items:center;background-color:transparent;display:flex;height:100%;justify-content:center;left:0;pointer-events:none;position:fixed;top:0;transition-property:background-color;width:100%}.p-dialog,.p-dialog-mask.p-component-overlay{pointer-events:auto}.p-dialog{display:flex;flex-direction:column;max-height:90%;position:relative;transform:scale(1)}.p-dialog-content{overflow-y:auto}.p-dialog-header{align-items:center;display:flex;flex-shrink:0;justify-content:space-between}.p-dialog-footer{flex-shrink:0}.p-dialog .p-dialog-header-icons{align-items:center;display:flex}.p-dialog .p-dialog-header-icon{align-items:center;display:flex;justify-content:center;overflow:hidden;position:relative}.p-dialog-mask.p-dialog-mask-leave{background-color:transparent}.p-fluid .p-dialog-footer .p-button{width:auto}.p-dialog-bottom-left .p-dialog,.p-dialog-bottom-right .p-dialog,.p-dialog-bottom .p-dialog,.p-dialog-left .p-dialog,.p-dialog-right .p-dialog,.p-dialog-top-left .p-dialog,.p-dialog-top-right .p-dialog,.p-dialog-top .p-dialog{margin:.75rem;transform:translateZ(0)}.p-dialog-maximized{height:100%;left:0!important;max-height:100%;top:0!important;transform:none;transition:none;width:100vw!important}.p-dialog-maximized .p-dialog-content{flex-grow:1}.p-dialog-left{justify-content:flex-start}.p-dialog-right{justify-content:flex-end}.p-dialog-top,.p-dialog-top-left{align-items:flex-start}.p-dialog-top-left{justify-content:flex-start}.p-dialog-top-right{align-items:flex-start;justify-content:flex-end}.p-dialog-bottom{align-items:flex-end}.p-dialog-bottom-left{align-items:flex-end;justify-content:flex-start}.p-dialog-bottom-right{align-items:flex-end;justify-content:flex-end}.p-dialog .p-resizable-handle{bottom:1px;cursor:se-resize;display:block;font-size:.1px;height:12px;position:absolute;right:1px;width:12px}.p-confirm-dialog .p-dialog-content{align-items:center;display:flex}"]}]}],o.ctorParameters=function(){return[{type:i.ElementRef},{type:i.Renderer2},{type:i.ChangeDetectorRef}]},o.propDecorators={images:[{type:i.Input}],type:[{type:i.Input}],style:[{type:i.Input}],styleClass:[{type:i.Input}],appendTo:[{type:i.Input}],easing:[{type:i.Input}],effectDuration:[{type:i.Input}],autoZIndex:[{type:i.Input}],baseZIndex:[{type:i.Input}],closeOnEscape:[{type:i.Input}]};var g=function(){};g.decorators=[{type:i.NgModule,args:[{imports:[e.CommonModule],exports:[o],declarations:[o]}]}],A.Lightbox=o,A.LightboxModule=g,Object.defineProperty(A,"__esModule",{value:!0})}));
|
2
2
|
//# sourceMappingURL=primeng-lightbox.umd.min.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"sources":["../../src/app/components/lightbox/lightbox.ts"],"names":["Lightbox","el","renderer","cd","this","type","effectDuration","autoZIndex","baseZIndex","closeOnEscape","prototype","onImageClick","event","image","i","content","index","loading","style","width","height","preventDocumentClickListener","show","displayImage","preventDefault","ngAfterViewInit","panel","DomHandler","findSingle","nativeElement","appendTo","document","body","appendChild","onLinkClick","_this","setTimeout","markForCheck","currentImage","captionText","title","center","mask","createElement","addMultipleClasses","zindex","zIndex","visible","bindGlobalListeners","hide","removeChild","unbindGlobalListeners","elementWidth","getOuterWidth","elementHeight","getOuterHeight","visibility","display","onImageLoad","target","imageWidth","imageHeight","left","parseInt","top","fadeIn","prev","placeholder","images","next","length","documentTarget","ownerDocument","documentClickListener","listen","documentEscapeListener","which","Object","defineProperty","ngOnDestroy","Component","args","selector","template","changeDetection","ChangeDetectionStrategy","Default","encapsulation","ViewEncapsulation","None","ElementRef","Renderer2","ChangeDetectorRef","Input","NgModule","imports","CommonModule","exports","declarations"],"mappings":"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","sourcesContent":["import {NgModule,Component,ElementRef,Input,Renderer2,AfterViewInit,OnDestroy,ChangeDetectorRef,ChangeDetectionStrategy, ViewEncapsulation} from '@angular/core';\nimport {CommonModule} from '@angular/common';\nimport {DomHandler} from 'primeng/dom';\n\n@Component({\n selector: 'p-lightbox',\n template: `\n <div [ngStyle]=\"style\" [class]=\"styleClass\" *ngIf=\"(type == 'image')\">\n <a *ngFor=\"let image of images; let i = index;\" [href]=\"image.source\" (click)=\"onImageClick($event,image,i,content)\">\n <img [src]=\"image.thumbnail\" [title]=\"image.title\" [alt]=\"image.alt\">\n </a>\n </div>\n <span [ngStyle]=\"style\" [class]=\"styleClass\" *ngIf=\"(type == 'content')\" (click)=\"onLinkClick($event,content)\">\n <ng-content select=\"a\"></ng-content>\n </span>\n <div class=\"ui-lightbox ui-widget ui-corner-all ui-shadow\" [style.display]=\"visible ? 'block' : 'none'\" [style.zIndex]=\"zindex\"\n [ngClass]=\"{'ui-lightbox-loading': loading}\"\n [style.transitionProperty]=\"'all'\" [style.transitionDuration]=\"effectDuration\" [style.transitionTimingFunction]=\"easing\" (click)=\"preventDocumentClickListener=true\">\n <div class=\"ui-lightbox-content-wrapper\">\n <a class=\"ui-state-default ui-lightbox-nav-left ui-corner-right\" [style.zIndex]=\"zindex + 1\" (click)=\"prev(img)\"\n [ngClass]=\"{'ui-helper-hidden':!leftVisible}\"><span class=\"ui-lightbox-nav-icon pi pi-chevron-left\"></span></a>\n <div #content class=\"ui-lightbox-content ui-corner-all\" \n [style.transitionProperty]=\"'width,height'\" [style.transitionDuration]=\"effectDuration\" [style.transitionTimingFunction]=\"easing\">\n <img #img [src]=\"currentImage ? currentImage.source||'' : ''\" (load)=\"onImageLoad($event,content)\" style=\"display:none\">\n <ng-content></ng-content>\n </div>\n <a class=\"ui-state-default ui-lightbox-nav-right ui-corner-left ui-helper-hidden\" [style.zIndex]=\"zindex + 1\" (click)=\"next(img)\"\n [ngClass]=\"{'ui-helper-hidden':!rightVisible}\"><span class=\"ui-lightbox-nav-icon pi pi-chevron-right\"></span></a>\n </div>\n <div class=\"ui-lightbox-caption ui-widget-header\" [style.display]=\"captionText ? 'block' : 'none'\">\n <span class=\"ui-lightbox-caption-text\">{{captionText}}</span><a class=\"ui-lightbox-close ui-corner-all\" tabindex=\"0\" (click)=\"hide($event)\" (keydown.enter)=\"hide($event)\"><span class=\"pi pi-times\"></span></a>\n <div style=\"clear:both\"></div>\n </div>\n </div>\n `,\n changeDetection: ChangeDetectionStrategy.Default,\n encapsulation: ViewEncapsulation.None,\n styleUrls: [\n './lightbox.css',\n '../dialog/dialog.css'\n ]\n})\nexport class Lightbox implements AfterViewInit,OnDestroy {\n\n @Input() images: any[];\n \n @Input() type: string = 'image';\n\n @Input() style: any;\n \n @Input() styleClass: string;\n \n @Input() appendTo: any;\n \n @Input() easing: 'ease-out';\n \n @Input() effectDuration: any = '500ms';\n\n @Input() autoZIndex: boolean = true;\n \n @Input() baseZIndex: number = 0;\n \n @Input() closeOnEscape: boolean = true;\n\n public visible: boolean;\n \n public loading: boolean;\n \n public currentImage: any;\n \n public captionText: string;\n \n public zindex: any;\n \n public panel: any;\n \n public index: number;\n \n public mask: any;\n \n public preventDocumentClickListener: boolean;\n \n public documentClickListener: any;\n\n public documentEscapeListener: any;\n\n constructor(public el: ElementRef, public renderer: Renderer2,private cd: ChangeDetectorRef) {}\n \n onImageClick(event,image,i,content) {\n this.index = i;\n this.loading = true;\n content.style.width = 32 + 'px';\n content.style.height = 32 + 'px';\n this.preventDocumentClickListener = true;\n this.show();\n this.displayImage(image);\n event.preventDefault();\n }\n \n ngAfterViewInit() {\n this.panel = DomHandler.findSingle(this.el.nativeElement, '.ui-lightbox ');\n \n if (this.appendTo) {\n if (this.appendTo === 'body')\n document.body.appendChild(this.panel);\n else\n DomHandler.appendChild(this.panel, this.appendTo);\n }\n }\n \n onLinkClick(event,content) {\n this.preventDocumentClickListener = true;\n this.show();\n event.preventDefault();\n }\n \n displayImage(image) {\n setTimeout(() => {\n this.cd.markForCheck();\n this.currentImage = image;\n this.captionText = image.title;\n this.center();\n }, 1000);\n }\n \n show() {\n this.mask = document.createElement('div');\n \n DomHandler.addMultipleClasses(this.mask, 'ui-widget-overlay ui-dialog-mask');\n document.body.appendChild(this.mask);\n if (this.autoZIndex) {\n this.zindex = this.baseZIndex + (++DomHandler.zindex);\n }\n this.mask.style.zIndex = this.zindex - 1;\n this.center();\n this.visible = true;\n this.bindGlobalListeners();\n }\n \n hide(event) {\n this.captionText = null;\n this.index = null;\n this.currentImage = null;\n this.visible = false;\n \n if (this.mask) {\n document.body.removeChild(this.mask);\n this.mask = null;\n }\n \n this.unbindGlobalListeners();\n event.preventDefault();\n }\n \n center() {\n let elementWidth = DomHandler.getOuterWidth(this.panel);\n let elementHeight = DomHandler.getOuterHeight(this.panel);\n if (elementWidth == 0 && elementHeight == 0) {\n this.panel.style.visibility = 'hidden';\n this.panel.style.display = 'block';\n elementWidth = DomHandler.getOuterWidth(this.panel);\n elementHeight = DomHandler.getOuterHeight(this.panel);\n this.panel.style.display = 'none';\n this.panel.style.visibility = 'visible';\n }\n }\n \n onImageLoad(event,content) {\n let image = event.target;\n image.style.visibility = 'hidden';\n image.style.display = 'block';\n let imageWidth = DomHandler.getOuterWidth(image);\n let imageHeight = DomHandler.getOuterHeight(image);\n image.style.display = 'none';\n image.style.visibility = 'visible';\n\n content.style.width = imageWidth + 'px';\n content.style.height = imageHeight + 'px';\n this.panel.style.left = parseInt(this.panel.style.left) + (DomHandler.getOuterWidth(this.panel) - imageWidth) / 2 + 'px';\n this.panel.style.top = parseInt(this.panel.style.top) + (DomHandler.getOuterHeight(this.panel) - imageHeight) / 2 + 'px';\n\n setTimeout(() => {\n this.cd.markForCheck();\n DomHandler.fadeIn(image, 500);\n image.style.display = 'block';\n //this.captionText = this.currentImage.title;\n this.loading = false;\n }, parseInt(this.effectDuration));\n }\n \n prev(placeholder: any) {\n this.captionText = null;\n this.loading = true;\n placeholder.style.display = 'none';\n if (this.index > 0) {\n this.displayImage(this.images[--this.index]);\n }\n }\n \n next(placeholder: any) {\n this.captionText = null;\n this.loading = true;\n placeholder.style.display = 'none';\n if (this.index <= (this.images.length - 1)) {\n this.displayImage(this.images[++this.index]);\n }\n }\n\n bindGlobalListeners() {\n const documentTarget: any = this.el ? this.el.nativeElement.ownerDocument : 'document';\n\n this.documentClickListener = this.renderer.listen(documentTarget, 'click', (event) => {\n if (!this.preventDocumentClickListener && this.visible) {\n this.hide(event);\n }\n this.preventDocumentClickListener = false;\n this.cd.markForCheck();\n });\n if (this.closeOnEscape && !this.documentEscapeListener) {\n this.documentEscapeListener = this.renderer.listen(documentTarget, 'keydown', (event) => {\n if (event.which == 27) {\n if (parseInt(this.panel.style.zIndex) === (DomHandler.zindex + this.baseZIndex)) {\n this.hide(event);\n }\n }\n });\n }\n }\n\n unbindGlobalListeners() {\n if (this.documentEscapeListener){\n this.documentEscapeListener();\n this.documentEscapeListener = null;\n }\n\n if (this.documentClickListener) {\n this.documentClickListener();\n this.documentClickListener = null;\n }\n }\n \n get leftVisible():boolean {\n return this.images && this.images.length && this.index != 0 && !this.loading; \n }\n \n get rightVisible():boolean {\n return this.images && this.images.length && this.index < (this.images.length - 1) && !this.loading; \n }\n \n ngOnDestroy() {\n this.unbindGlobalListeners();\n \n if (this.appendTo) {\n this.el.nativeElement.appendChild(this.panel);\n }\n }\n \n}\n\n@NgModule({\n imports: [CommonModule],\n exports: [Lightbox],\n declarations: [Lightbox]\n})\nexport class LightboxModule { }\n"]}
|
1
|
+
{"version":3,"sources":["../../src/app/components/lightbox/lightbox.ts"],"names":["Lightbox","el","renderer","cd","this","type","effectDuration","autoZIndex","baseZIndex","closeOnEscape","prototype","onImageClick","event","image","i","content","index","loading","style","width","height","preventDocumentClickListener","show","displayImage","preventDefault","ngAfterViewInit","panel","DomHandler","findSingle","nativeElement","appendTo","document","body","appendChild","onLinkClick","_this","setTimeout","markForCheck","currentImage","captionText","title","center","mask","createElement","addMultipleClasses","zindex","zIndex","visible","bindGlobalListeners","hide","removeChild","unbindGlobalListeners","elementWidth","getOuterWidth","elementHeight","getOuterHeight","visibility","display","onImageLoad","target","imageWidth","imageHeight","left","parseInt","top","fadeIn","prev","placeholder","images","next","length","documentTarget","ownerDocument","documentClickListener","listen","documentEscapeListener","which","Object","defineProperty","ngOnDestroy","Component","args","selector","template","changeDetection","ChangeDetectionStrategy","Default","encapsulation","ViewEncapsulation","None","ElementRef","Renderer2","ChangeDetectorRef","Input","NgModule","imports","CommonModule","exports","declarations"],"mappings":"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","sourcesContent":["import {NgModule,Component,ElementRef,Input,Renderer2,AfterViewInit,OnDestroy,ChangeDetectorRef,ChangeDetectionStrategy, ViewEncapsulation} from '@angular/core';\nimport {CommonModule} from '@angular/common';\nimport {DomHandler} from 'primeng/dom';\n\n@Component({\n selector: 'p-lightbox',\n template: `\n <div [ngStyle]=\"style\" [class]=\"styleClass\" *ngIf=\"(type == 'image')\">\n <a *ngFor=\"let image of images; let i = index;\" [href]=\"image.source\" (click)=\"onImageClick($event,image,i,content)\">\n <img [src]=\"image.thumbnail\" [title]=\"image.title\" [alt]=\"image.alt\">\n </a>\n </div>\n <span [ngStyle]=\"style\" [class]=\"styleClass\" *ngIf=\"(type == 'content')\" (click)=\"onLinkClick($event,content)\">\n <ng-content select=\"a\"></ng-content>\n </span>\n <div class=\"ui-lightbox ui-widget ui-corner-all ui-shadow\" [style.display]=\"visible ? 'block' : 'none'\" [style.zIndex]=\"zindex\"\n [ngClass]=\"{'ui-lightbox-loading': loading}\"\n [style.transitionProperty]=\"'all'\" [style.transitionDuration]=\"effectDuration\" [style.transitionTimingFunction]=\"easing\" (click)=\"preventDocumentClickListener=true\">\n <div class=\"ui-lightbox-content-wrapper\">\n <a class=\"ui-state-default ui-lightbox-nav-left ui-corner-right\" [style.zIndex]=\"zindex + 1\" (click)=\"prev(img)\"\n [ngClass]=\"{'ui-helper-hidden':!leftVisible}\"><span class=\"ui-lightbox-nav-icon pi pi-chevron-left\"></span></a>\n <div #content class=\"ui-lightbox-content ui-corner-all\" \n [style.transitionProperty]=\"'width,height'\" [style.transitionDuration]=\"effectDuration\" [style.transitionTimingFunction]=\"easing\">\n <img #img [src]=\"currentImage ? currentImage.source||'' : ''\" (load)=\"onImageLoad($event,content)\" style=\"display:none\">\n <ng-content></ng-content>\n </div>\n <a class=\"ui-state-default ui-lightbox-nav-right ui-corner-left ui-helper-hidden\" [style.zIndex]=\"zindex + 1\" (click)=\"next(img)\"\n [ngClass]=\"{'ui-helper-hidden':!rightVisible}\"><span class=\"ui-lightbox-nav-icon pi pi-chevron-right\"></span></a>\n </div>\n <div class=\"ui-lightbox-caption ui-widget-header\" [style.display]=\"captionText ? 'block' : 'none'\">\n <span class=\"ui-lightbox-caption-text\">{{captionText}}</span><a class=\"ui-lightbox-close ui-corner-all\" tabindex=\"0\" (click)=\"hide($event)\" (keydown.enter)=\"hide($event)\"><span class=\"pi pi-times\"></span></a>\n <div style=\"clear:both\"></div>\n </div>\n </div>\n `,\n changeDetection: ChangeDetectionStrategy.Default,\n encapsulation: ViewEncapsulation.None,\n styleUrls: [\n './lightbox.css',\n '../dialog/dialog.css'\n ]\n})\nexport class Lightbox implements AfterViewInit,OnDestroy {\n\n @Input() images: any[];\n \n @Input() type: string = 'image';\n\n @Input() style: any;\n \n @Input() styleClass: string;\n \n @Input() appendTo: any;\n \n @Input() easing: 'ease-out';\n \n @Input() effectDuration: any = '500ms';\n\n @Input() autoZIndex: boolean = true;\n \n @Input() baseZIndex: number = 0;\n \n @Input() closeOnEscape: boolean = true;\n\n public visible: boolean;\n \n public loading: boolean;\n \n public currentImage: any;\n \n public captionText: string;\n \n public zindex: any;\n \n public panel: any;\n \n public index: number;\n \n public mask: any;\n \n public preventDocumentClickListener: boolean;\n \n public documentClickListener: any;\n\n public documentEscapeListener: any;\n\n constructor(public el: ElementRef, public renderer: Renderer2,private cd: ChangeDetectorRef) {}\n \n onImageClick(event,image,i,content) {\n this.index = i;\n this.loading = true;\n content.style.width = 32 + 'px';\n content.style.height = 32 + 'px';\n this.preventDocumentClickListener = true;\n this.show();\n this.displayImage(image);\n event.preventDefault();\n }\n \n ngAfterViewInit() {\n this.panel = DomHandler.findSingle(this.el.nativeElement, '.ui-lightbox ');\n \n if (this.appendTo) {\n if (this.appendTo === 'body')\n document.body.appendChild(this.panel);\n else\n DomHandler.appendChild(this.panel, this.appendTo);\n }\n }\n \n onLinkClick(event,content) {\n this.preventDocumentClickListener = true;\n this.show();\n event.preventDefault();\n }\n \n displayImage(image) {\n setTimeout(() => {\n this.cd.markForCheck();\n this.currentImage = image;\n this.captionText = image.title;\n this.center();\n }, 1000);\n }\n \n show() {\n this.mask = document.createElement('div');\n \n DomHandler.addMultipleClasses(this.mask, 'ui-widget-overlay ui-dialog-mask');\n document.body.appendChild(this.mask);\n if (this.autoZIndex) {\n this.zindex = this.baseZIndex + (++DomHandler.zindex);\n }\n this.mask.style.zIndex = this.zindex - 1;\n this.center();\n this.visible = true;\n this.bindGlobalListeners();\n }\n \n hide(event) {\n this.captionText = null;\n this.index = null;\n this.currentImage = null;\n this.visible = false;\n \n if (this.mask) {\n document.body.removeChild(this.mask);\n this.mask = null;\n }\n \n this.unbindGlobalListeners();\n event.preventDefault();\n }\n \n center() {\n let elementWidth = DomHandler.getOuterWidth(this.panel);\n let elementHeight = DomHandler.getOuterHeight(this.panel);\n if (elementWidth == 0 && elementHeight == 0) {\n this.panel.style.visibility = 'hidden';\n this.panel.style.display = 'block';\n elementWidth = DomHandler.getOuterWidth(this.panel);\n elementHeight = DomHandler.getOuterHeight(this.panel);\n this.panel.style.display = 'none';\n this.panel.style.visibility = 'visible';\n }\n }\n \n onImageLoad(event,content) {\n let image = event.target;\n image.style.visibility = 'hidden';\n image.style.display = 'block';\n let imageWidth = DomHandler.getOuterWidth(image);\n let imageHeight = DomHandler.getOuterHeight(image);\n image.style.display = 'none';\n image.style.visibility = 'visible';\n\n content.style.width = imageWidth + 'px';\n content.style.height = imageHeight + 'px';\n this.panel.style.left = parseInt(this.panel.style.left) + (DomHandler.getOuterWidth(this.panel) - imageWidth) / 2 + 'px';\n this.panel.style.top = parseInt(this.panel.style.top) + (DomHandler.getOuterHeight(this.panel) - imageHeight) / 2 + 'px';\n\n setTimeout(() => {\n this.cd.markForCheck();\n DomHandler.fadeIn(image, 500);\n image.style.display = 'block';\n //this.captionText = this.currentImage.title;\n this.loading = false;\n }, parseInt(this.effectDuration));\n }\n \n prev(placeholder: any) {\n this.captionText = null;\n this.loading = true;\n placeholder.style.display = 'none';\n if (this.index > 0) {\n this.displayImage(this.images[--this.index]);\n }\n }\n \n next(placeholder: any) {\n this.captionText = null;\n this.loading = true;\n placeholder.style.display = 'none';\n if (this.index <= (this.images.length - 1)) {\n this.displayImage(this.images[++this.index]);\n }\n }\n\n bindGlobalListeners() {\n const documentTarget: any = this.el ? this.el.nativeElement.ownerDocument : 'document';\n\n this.documentClickListener = this.renderer.listen(documentTarget, 'click', (event) => {\n if (!this.preventDocumentClickListener && this.visible) {\n this.hide(event);\n }\n this.preventDocumentClickListener = false;\n this.cd.markForCheck();\n });\n if (this.closeOnEscape && !this.documentEscapeListener) {\n this.documentEscapeListener = this.renderer.listen(documentTarget, 'keydown', (event) => {\n if (event.which == 27) {\n if (parseInt(this.panel.style.zIndex) === (DomHandler.zindex + this.baseZIndex)) {\n this.hide(event);\n }\n }\n });\n }\n }\n\n unbindGlobalListeners() {\n if (this.documentEscapeListener){\n this.documentEscapeListener();\n this.documentEscapeListener = null;\n }\n\n if (this.documentClickListener) {\n this.documentClickListener();\n this.documentClickListener = null;\n }\n }\n \n get leftVisible():boolean {\n return this.images && this.images.length && this.index != 0 && !this.loading; \n }\n \n get rightVisible():boolean {\n return this.images && this.images.length && this.index < (this.images.length - 1) && !this.loading; \n }\n \n ngOnDestroy() {\n this.unbindGlobalListeners();\n \n if (this.appendTo) {\n this.el.nativeElement.appendChild(this.panel);\n }\n }\n \n}\n\n@NgModule({\n imports: [CommonModule],\n exports: [Lightbox],\n declarations: [Lightbox]\n})\nexport class LightboxModule { }\n"]}
|
@@ -350,7 +350,7 @@
|
|
350
350
|
},
|
351
351
|
set: function (val) {
|
352
352
|
this._filterValue = val;
|
353
|
-
this.
|
353
|
+
this.activateFilter();
|
354
354
|
},
|
355
355
|
enumerable: false,
|
356
356
|
configurable: true
|
@@ -362,6 +362,9 @@
|
|
362
362
|
case 'item':
|
363
363
|
_this.itemTemplate = item.template;
|
364
364
|
break;
|
365
|
+
case 'group':
|
366
|
+
_this.groupTemplate = item.template;
|
367
|
+
break;
|
365
368
|
case 'header':
|
366
369
|
_this.headerTemplate = item.template;
|
367
370
|
break;
|
@@ -377,6 +380,12 @@
|
|
377
380
|
Listbox.prototype.getOptionLabel = function (option) {
|
378
381
|
return this.optionLabel ? utils.ObjectUtils.resolveFieldData(option, this.optionLabel) : (option.label != undefined ? option.label : option);
|
379
382
|
};
|
383
|
+
Listbox.prototype.getOptionGroupChildren = function (optionGroup) {
|
384
|
+
return this.optionGroupChildren ? utils.ObjectUtils.resolveFieldData(optionGroup, this.optionGroupChildren) : optionGroup.items;
|
385
|
+
};
|
386
|
+
Listbox.prototype.getOptionGroupLabel = function (optionGroup) {
|
387
|
+
return this.optionGroupLabel ? utils.ObjectUtils.resolveFieldData(optionGroup, this.optionGroupLabel) : (optionGroup.label != undefined ? optionGroup.label : optionGroup);
|
388
|
+
};
|
380
389
|
Listbox.prototype.getOptionValue = function (option) {
|
381
390
|
return this.optionValue ? utils.ObjectUtils.resolveFieldData(option, this.optionValue) : (this.optionLabel ? option : option.value);
|
382
391
|
};
|
@@ -553,7 +562,7 @@
|
|
553
562
|
};
|
554
563
|
Object.defineProperty(Listbox.prototype, "allChecked", {
|
555
564
|
get: function () {
|
556
|
-
var e_2, _a;
|
565
|
+
var e_2, _a, e_3, _b;
|
557
566
|
var optionsToRender = this.optionsToRender;
|
558
567
|
if (!optionsToRender || optionsToRender.length === 0) {
|
559
568
|
return false;
|
@@ -562,22 +571,55 @@
|
|
562
571
|
var selectedDisabledItemsLength = 0;
|
563
572
|
var unselectedDisabledItemsLength = 0;
|
564
573
|
var selectedEnabledItemsLength = 0;
|
574
|
+
var visibleOptionsLength = this.group ? 0 : this.optionsToRender.length;
|
565
575
|
try {
|
566
576
|
for (var optionsToRender_1 = __values(optionsToRender), optionsToRender_1_1 = optionsToRender_1.next(); !optionsToRender_1_1.done; optionsToRender_1_1 = optionsToRender_1.next()) {
|
567
577
|
var option = optionsToRender_1_1.value;
|
568
|
-
|
569
|
-
|
570
|
-
|
571
|
-
if (
|
572
|
-
|
573
|
-
|
574
|
-
|
578
|
+
if (!this.group) {
|
579
|
+
var disabled = this.isOptionDisabled(option);
|
580
|
+
var selected = this.isSelected(option);
|
581
|
+
if (disabled) {
|
582
|
+
if (selected)
|
583
|
+
selectedDisabledItemsLength++;
|
584
|
+
else
|
585
|
+
unselectedDisabledItemsLength++;
|
586
|
+
}
|
587
|
+
else {
|
588
|
+
if (selected)
|
589
|
+
selectedEnabledItemsLength++;
|
590
|
+
else
|
591
|
+
return false;
|
592
|
+
}
|
575
593
|
}
|
576
|
-
else {
|
577
|
-
|
578
|
-
|
579
|
-
|
580
|
-
|
594
|
+
else if (option.items) {
|
595
|
+
try {
|
596
|
+
for (var _c = (e_3 = void 0, __values(option.items)), _d = _c.next(); !_d.done; _d = _c.next()) {
|
597
|
+
var opt = _d.value;
|
598
|
+
var disabled = this.isOptionDisabled(opt);
|
599
|
+
var selected = this.isSelected(opt);
|
600
|
+
if (disabled) {
|
601
|
+
if (selected)
|
602
|
+
selectedDisabledItemsLength++;
|
603
|
+
else
|
604
|
+
unselectedDisabledItemsLength++;
|
605
|
+
}
|
606
|
+
else {
|
607
|
+
if (selected)
|
608
|
+
selectedEnabledItemsLength++;
|
609
|
+
else {
|
610
|
+
return false;
|
611
|
+
}
|
612
|
+
}
|
613
|
+
visibleOptionsLength++;
|
614
|
+
}
|
615
|
+
}
|
616
|
+
catch (e_3_1) { e_3 = { error: e_3_1 }; }
|
617
|
+
finally {
|
618
|
+
try {
|
619
|
+
if (_d && !_d.done && (_b = _c.return)) _b.call(_c);
|
620
|
+
}
|
621
|
+
finally { if (e_3) throw e_3.error; }
|
622
|
+
}
|
581
623
|
}
|
582
624
|
}
|
583
625
|
}
|
@@ -588,9 +630,9 @@
|
|
588
630
|
}
|
589
631
|
finally { if (e_2) throw e_2.error; }
|
590
632
|
}
|
591
|
-
return (
|
592
|
-
||
|
593
|
-
|| selectedEnabledItemsLength &&
|
633
|
+
return (visibleOptionsLength === selectedDisabledItemsLength
|
634
|
+
|| visibleOptionsLength === selectedEnabledItemsLength
|
635
|
+
|| selectedEnabledItemsLength && visibleOptionsLength === (selectedEnabledItemsLength + unselectedDisabledItemsLength + selectedDisabledItemsLength));
|
594
636
|
}
|
595
637
|
},
|
596
638
|
enumerable: false,
|
@@ -608,18 +650,48 @@
|
|
608
650
|
};
|
609
651
|
Listbox.prototype.onFilter = function (event) {
|
610
652
|
this._filterValue = event.target.value;
|
611
|
-
this.
|
653
|
+
this.activateFilter();
|
612
654
|
};
|
613
|
-
Listbox.prototype.
|
655
|
+
Listbox.prototype.activateFilter = function () {
|
656
|
+
var e_4, _a;
|
614
657
|
var _this = this;
|
615
|
-
if (this.hasFilter() && this._options)
|
616
|
-
|
617
|
-
|
658
|
+
if (this.hasFilter() && this._options) {
|
659
|
+
if (this.group) {
|
660
|
+
var searchFields = (this.optionLabel || 'label').split(',');
|
661
|
+
var filteredGroups = [];
|
662
|
+
try {
|
663
|
+
for (var _b = __values(this.options), _c = _b.next(); !_c.done; _c = _b.next()) {
|
664
|
+
var optgroup = _c.value;
|
665
|
+
var filteredSubOptions = this.filterService.filter(this.getOptionGroupChildren(optgroup), searchFields, this.filterValue, this.filterMatchMode, this.filterLocale);
|
666
|
+
if (filteredSubOptions && filteredSubOptions.length) {
|
667
|
+
filteredGroups.push({
|
668
|
+
label: optgroup.label,
|
669
|
+
value: optgroup.value,
|
670
|
+
items: filteredSubOptions
|
671
|
+
});
|
672
|
+
}
|
673
|
+
}
|
674
|
+
}
|
675
|
+
catch (e_4_1) { e_4 = { error: e_4_1 }; }
|
676
|
+
finally {
|
677
|
+
try {
|
678
|
+
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
|
679
|
+
}
|
680
|
+
finally { if (e_4) throw e_4.error; }
|
681
|
+
}
|
682
|
+
this._filteredOptions = filteredGroups;
|
683
|
+
}
|
684
|
+
else {
|
685
|
+
this._filteredOptions = this._options.filter(function (option) { return _this.filterService.filters[_this.filterMatchMode](_this.getOptionLabel(option), _this._filterValue, _this.filterLocale); });
|
686
|
+
}
|
687
|
+
}
|
688
|
+
else {
|
618
689
|
this._filteredOptions = null;
|
690
|
+
}
|
619
691
|
};
|
620
692
|
Object.defineProperty(Listbox.prototype, "toggleAllDisabled", {
|
621
693
|
get: function () {
|
622
|
-
var
|
694
|
+
var e_5, _a;
|
623
695
|
var optionsToRender = this.optionsToRender;
|
624
696
|
if (!optionsToRender || optionsToRender.length === 0) {
|
625
697
|
return true;
|
@@ -632,12 +704,12 @@
|
|
632
704
|
return false;
|
633
705
|
}
|
634
706
|
}
|
635
|
-
catch (
|
707
|
+
catch (e_5_1) { e_5 = { error: e_5_1 }; }
|
636
708
|
finally {
|
637
709
|
try {
|
638
710
|
if (optionsToRender_2_1 && !optionsToRender_2_1.done && (_a = optionsToRender_2.return)) _a.call(optionsToRender_2);
|
639
711
|
}
|
640
|
-
finally { if (
|
712
|
+
finally { if (e_5) throw e_5.error; }
|
641
713
|
}
|
642
714
|
return true;
|
643
715
|
}
|
@@ -663,9 +735,21 @@
|
|
663
735
|
var optionsToRender = this.optionsToRender;
|
664
736
|
var val = [];
|
665
737
|
optionsToRender.forEach(function (opt) {
|
666
|
-
|
667
|
-
|
668
|
-
|
738
|
+
if (!_this.group) {
|
739
|
+
var optionDisabled = _this.isOptionDisabled(opt);
|
740
|
+
if (!optionDisabled || (optionDisabled && _this.isSelected(opt))) {
|
741
|
+
val.push(_this.getOptionValue(opt));
|
742
|
+
}
|
743
|
+
}
|
744
|
+
else {
|
745
|
+
if (opt.items) {
|
746
|
+
opt.items.forEach(function (option) {
|
747
|
+
var optionDisabled = _this.isOptionDisabled(option);
|
748
|
+
if (!optionDisabled || (optionDisabled && _this.isSelected(option))) {
|
749
|
+
val.push(_this.getOptionValue(option));
|
750
|
+
}
|
751
|
+
});
|
752
|
+
}
|
669
753
|
}
|
670
754
|
});
|
671
755
|
this.value = val;
|
@@ -675,9 +759,21 @@
|
|
675
759
|
var optionsToRender = this.optionsToRender;
|
676
760
|
var val = [];
|
677
761
|
optionsToRender.forEach(function (opt) {
|
678
|
-
|
679
|
-
|
680
|
-
|
762
|
+
if (!_this.group) {
|
763
|
+
var optionDisabled = _this.isOptionDisabled(opt);
|
764
|
+
if (optionDisabled && _this.isSelected(opt)) {
|
765
|
+
val.push(_this.getOptionValue(opt));
|
766
|
+
}
|
767
|
+
}
|
768
|
+
else {
|
769
|
+
if (opt.items) {
|
770
|
+
opt.items.forEach(function (option) {
|
771
|
+
var optionDisabled = _this.isOptionDisabled(option);
|
772
|
+
if (optionDisabled && _this.isSelected(option)) {
|
773
|
+
val.push(_this.getOptionValue(option));
|
774
|
+
}
|
775
|
+
});
|
776
|
+
}
|
681
777
|
}
|
682
778
|
});
|
683
779
|
this.value = val;
|
@@ -714,14 +810,14 @@
|
|
714
810
|
Listbox.prototype.findNextItem = function (item) {
|
715
811
|
var nextItem = item.nextElementSibling;
|
716
812
|
if (nextItem)
|
717
|
-
return dom.DomHandler.hasClass(nextItem, 'p-disabled') || dom.DomHandler.isHidden(nextItem) ? this.findNextItem(nextItem) : nextItem;
|
813
|
+
return dom.DomHandler.hasClass(nextItem, 'p-disabled') || dom.DomHandler.isHidden(nextItem) || dom.DomHandler.hasClass(nextItem, 'p-listbox-item-group') ? this.findNextItem(nextItem) : nextItem;
|
718
814
|
else
|
719
815
|
return null;
|
720
816
|
};
|
721
817
|
Listbox.prototype.findPrevItem = function (item) {
|
722
818
|
var prevItem = item.previousElementSibling;
|
723
819
|
if (prevItem)
|
724
|
-
return dom.DomHandler.hasClass(prevItem, 'p-disabled') || dom.DomHandler.isHidden(prevItem) ? this.findPrevItem(prevItem) : prevItem;
|
820
|
+
return dom.DomHandler.hasClass(prevItem, 'p-disabled') || dom.DomHandler.isHidden(prevItem) || dom.DomHandler.hasClass(prevItem, 'p-listbox-item-group') ? this.findPrevItem(prevItem) : prevItem;
|
725
821
|
else
|
726
822
|
return null;
|
727
823
|
};
|
@@ -736,7 +832,7 @@
|
|
736
832
|
Listbox.decorators = [
|
737
833
|
{ type: core.Component, args: [{
|
738
834
|
selector: 'p-listbox',
|
739
|
-
template: "\n <div [ngClass]=\"{'p-listbox p-component': true, 'p-disabled': disabled}\" [ngStyle]=\"style\" [class]=\"styleClass\">\n <div class=\"p-listbox-header\" *ngIf=\"headerFacet || headerTemplate\">\n <ng-content select=\"p-header\"></ng-content>\n <ng-container *ngTemplateOutlet=\"headerTemplate\"></ng-container>\n </div>\n <div class=\"p-listbox-header\" *ngIf=\"(checkbox && multiple && showToggleAll) || filter\">\n <div class=\"p-checkbox p-component\" *ngIf=\"checkbox && multiple && showToggleAll\" [ngClass]=\"{'p-checkbox-disabled': disabled || toggleAllDisabled}\">\n <div class=\"p-hidden-accessible\">\n <input type=\"checkbox\" readonly=\"readonly\" [checked]=\"allChecked\" (focus)=\"onHeaderCheckboxFocus()\" (blur)=\"onHeaderCheckboxBlur()\" (keydown.space)=\"toggleAll($event)\" [attr.disabled]=\"disabled || toggleAllDisabled\">\n </div>\n <div #headerchkbox class=\"p-checkbox-box\" [ngClass]=\"{'p-highlight': allChecked, 'p-focus': headerCheckboxFocus, 'p-disabled': disabled || toggleAllDisabled}\" (click)=\"toggleAll($event)\">\n <span class=\"p-checkbox-icon\" [ngClass]=\"{'pi pi-check':allChecked}\"></span>\n </div>\n </div>\n <div class=\"p-listbox-filter-container\" *ngIf=\"filter\">\n <input type=\"text\" [value]=\"filterValue||''\" (input)=\"onFilter($event)\" class=\"p-listbox-filter p-inputtext p-component\" [disabled]=\"disabled\" [attr.placeholder]=\"filterPlaceHolder\" [attr.aria-label]=\"ariaFilterLabel\">\n <span class=\"p-listbox-filter-icon pi pi-search\"></span>\n </div>\n </div>\n <div [ngClass]=\"'p-listbox-list-wrapper'\" [ngStyle]=\"listStyle\" [class]=\"listStyleClass\">\n <ul class=\"p-listbox-list\" role=\"listbox\" aria-multiselectable=\"multiple\">\n
|
835
|
+
template: "\n <div [ngClass]=\"{'p-listbox p-component': true, 'p-disabled': disabled}\" [ngStyle]=\"style\" [class]=\"styleClass\">\n <div class=\"p-listbox-header\" *ngIf=\"headerFacet || headerTemplate\">\n <ng-content select=\"p-header\"></ng-content>\n <ng-container *ngTemplateOutlet=\"headerTemplate\"></ng-container>\n </div>\n <div class=\"p-listbox-header\" *ngIf=\"(checkbox && multiple && showToggleAll) || filter\">\n <div class=\"p-checkbox p-component\" *ngIf=\"checkbox && multiple && showToggleAll\" [ngClass]=\"{'p-checkbox-disabled': disabled || toggleAllDisabled}\">\n <div class=\"p-hidden-accessible\">\n <input type=\"checkbox\" readonly=\"readonly\" [checked]=\"allChecked\" (focus)=\"onHeaderCheckboxFocus()\" (blur)=\"onHeaderCheckboxBlur()\" (keydown.space)=\"toggleAll($event)\" [attr.disabled]=\"disabled || toggleAllDisabled\">\n </div>\n <div #headerchkbox class=\"p-checkbox-box\" [ngClass]=\"{'p-highlight': allChecked, 'p-focus': headerCheckboxFocus, 'p-disabled': disabled || toggleAllDisabled}\" (click)=\"toggleAll($event)\">\n <span class=\"p-checkbox-icon\" [ngClass]=\"{'pi pi-check':allChecked}\"></span>\n </div>\n </div>\n <div class=\"p-listbox-filter-container\" *ngIf=\"filter\">\n <input type=\"text\" [value]=\"filterValue||''\" (input)=\"onFilter($event)\" class=\"p-listbox-filter p-inputtext p-component\" [disabled]=\"disabled\" [attr.placeholder]=\"filterPlaceHolder\" [attr.aria-label]=\"ariaFilterLabel\">\n <span class=\"p-listbox-filter-icon pi pi-search\"></span>\n </div>\n </div>\n <div [ngClass]=\"'p-listbox-list-wrapper'\" [ngStyle]=\"listStyle\" [class]=\"listStyleClass\">\n <ul class=\"p-listbox-list\" role=\"listbox\" aria-multiselectable=\"multiple\">\n <ng-container *ngIf=\"group\">\n <ng-template ngFor let-optgroup [ngForOf]=\"optionsToRender\">\n <li class=\"p-listbox-item-group\">\n <span *ngIf=\"!groupTemplate\">{{getOptionGroupLabel(optgroup)||'empty'}}</span>\n <ng-container *ngTemplateOutlet=\"groupTemplate; context: {$implicit: optgroup}\"></ng-container>\n </li>\n <ng-container *ngTemplateOutlet=\"itemslist; context: {$implicit: getOptionGroupChildren(optgroup)}\"></ng-container>\n </ng-template>\n </ng-container>\n <ng-container *ngIf=\"!group\">\n <ng-container *ngTemplateOutlet=\"itemslist; context: {$implicit: optionsToRender}\"></ng-container>\n </ng-container>\n <ng-template #itemslist let-optionsToDisplay>\n <li *ngFor=\"let option of optionsToDisplay; let i = index;\" [attr.tabindex]=\"disabled || isOptionDisabled(option) ? null : '0'\" pRipple\n [ngClass]=\"{'p-listbox-item':true,'p-highlight':isSelected(option), 'p-disabled': this.isOptionDisabled(option)}\" role=\"option\" [attr.aria-label]=\"getOptionLabel(option)\"\n [attr.aria-selected]=\"isSelected(option)\" (click)=\"onOptionClick($event,option)\" (dblclick)=\"onOptionDoubleClick($event,option)\" (touchend)=\"onOptionTouchEnd(option)\" (keydown)=\"onOptionKeyDown($event,option)\">\n <div class=\"p-checkbox p-component\" *ngIf=\"checkbox && multiple\" [ngClass]=\"{'p-checkbox-disabled': disabled || isOptionDisabled(option)}\">\n <div class=\"p-checkbox-box\" [ngClass]=\"{'p-highlight':isSelected(option)}\">\n <span class=\"p-checkbox-icon\" [ngClass]=\"{'pi pi-check':isSelected(option)}\"></span>\n </div>\n </div>\n <span *ngIf=\"!itemTemplate\">{{getOptionLabel(option)}}</span>\n <ng-container *ngTemplateOutlet=\"itemTemplate; context: {$implicit: option, index: i}\"></ng-container>\n </li>\n </ng-template>\n </ul>\n </div>\n <div class=\"p-listbox-footer\" *ngIf=\"footerFacet || footerTemplate\">\n <ng-content select=\"p-footer\"></ng-content>\n <ng-container *ngTemplateOutlet=\"footerTemplate\"></ng-container>\n </div>\n </div>\n ",
|
740
836
|
providers: [LISTBOX_VALUE_ACCESSOR],
|
741
837
|
changeDetection: core.ChangeDetectionStrategy.OnPush,
|
742
838
|
encapsulation: core.ViewEncapsulation.None,
|
@@ -765,9 +861,12 @@
|
|
765
861
|
showToggleAll: [{ type: core.Input }],
|
766
862
|
optionLabel: [{ type: core.Input }],
|
767
863
|
optionValue: [{ type: core.Input }],
|
864
|
+
optionGroupChildren: [{ type: core.Input }],
|
865
|
+
optionGroupLabel: [{ type: core.Input }],
|
768
866
|
optionDisabled: [{ type: core.Input }],
|
769
867
|
ariaFilterLabel: [{ type: core.Input }],
|
770
868
|
filterPlaceHolder: [{ type: core.Input }],
|
869
|
+
group: [{ type: core.Input }],
|
771
870
|
onChange: [{ type: core.Output }],
|
772
871
|
onClick: [{ type: core.Output }],
|
773
872
|
onDblClick: [{ type: core.Output }],
|