From 7962275cebbc3fce74ffd1ef16ae6927c9293a24 Mon Sep 17 00:00:00 2001 From: ppl Date: Thu, 25 Apr 2024 12:02:00 +0200 Subject: [PATCH 1/6] remove HttpClientModule import --- package-lock.json | 4 ++-- src/app/components/fileupload/fileupload.ts | 4 ++-- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/package-lock.json b/package-lock.json index fd49c715bb6..a663dd4da82 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,12 +1,12 @@ { "name": "primeng", - "version": "17.13.0", + "version": "17.14.1", "lockfileVersion": 3, "requires": true, "packages": { "": { "name": "primeng", - "version": "17.13.0", + "version": "17.14.1", "license": "SEE LICENSE IN LICENSE.md", "devDependencies": { "@angular-devkit/build-angular": "^17.3.1", diff --git a/src/app/components/fileupload/fileupload.ts b/src/app/components/fileupload/fileupload.ts index ecc54ff1c5c..9485d7aa332 100755 --- a/src/app/components/fileupload/fileupload.ts +++ b/src/app/components/fileupload/fileupload.ts @@ -1,5 +1,5 @@ import { CommonModule, DOCUMENT, isPlatformBrowser } from '@angular/common'; -import { HttpClient, HttpClientModule, HttpEvent, HttpEventType, HttpHeaders } from '@angular/common/http'; +import { HttpClient, HttpEvent, HttpEventType, HttpHeaders } from '@angular/common/http'; import { AfterContentInit, AfterViewInit, @@ -932,7 +932,7 @@ export class FileUpload implements AfterViewInit, AfterContentInit, OnInit, OnDe } @NgModule({ - imports: [CommonModule, HttpClientModule, SharedModule, ButtonModule, ProgressBarModule, MessagesModule, RippleModule, PlusIcon, UploadIcon, TimesIcon], + imports: [CommonModule, SharedModule, ButtonModule, ProgressBarModule, MessagesModule, RippleModule, PlusIcon, UploadIcon, TimesIcon], exports: [FileUpload, SharedModule, ButtonModule, ProgressBarModule, MessagesModule], declarations: [FileUpload] }) From 7a0d156a293424c0aeac5042efe323cfe63a78c1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Janik=20M=C3=BCnzenberger?= Date: Thu, 25 Apr 2024 21:04:52 +0200 Subject: [PATCH 2/6] fix style for vertical dotted divider --- src/app/components/divider/divider.css | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/app/components/divider/divider.css b/src/app/components/divider/divider.css index 2738f847c0b..e64ed71bcc9 100644 --- a/src/app/components/divider/divider.css +++ b/src/app/components/divider/divider.css @@ -80,7 +80,7 @@ border-top-style: dotted; } - .p-divider-dotted.p-divider-horizontal:before { + .p-divider-dotted.p-divider-vertical:before { border-left-style: dotted; } } From c438702b6f0ead17c051024b3c4b4c6762458885 Mon Sep 17 00:00:00 2001 From: Dive576 <62649460+Dive576@users.noreply.github.com> Date: Thu, 25 Apr 2024 19:47:31 -0400 Subject: [PATCH 3/6] Fixed #15367 - Non-linear menu items are misaligned --- src/app/components/speeddial/speeddial.css | 8 ++++++++ src/app/components/speeddial/speeddial.ts | 5 ++--- 2 files changed, 10 insertions(+), 3 deletions(-) diff --git a/src/app/components/speeddial/speeddial.css b/src/app/components/speeddial/speeddial.css index f6f7dd57b38..c2fd94184a9 100755 --- a/src/app/components/speeddial/speeddial.css +++ b/src/app/components/speeddial/speeddial.css @@ -5,6 +5,14 @@ z-index: 1; } + .p-speeddial:not(.p-speeddial-opened) { + pointer-events: none; + } + + .p-speeddial:not(.p-speeddial-opened) .p-speeddial-button { + pointer-events: auto; + } + .p-speeddial-list { margin: 0; padding: 0; diff --git a/src/app/components/speeddial/speeddial.ts b/src/app/components/speeddial/speeddial.ts index c0445e208b9..4db568de217 100644 --- a/src/app/components/speeddial/speeddial.ts +++ b/src/app/components/speeddial/speeddial.ts @@ -92,7 +92,7 @@ import { asapScheduler } from 'rxjs'; item.id === this.focusedOptionIndex); + const itemIndex = [...items].findIndex((item) => item.id === this.focusedOptionIndex()); this.onItemClick(event, this.model[itemIndex]); this.onBlur(event); From d5cb5695ebc12e690170339560106b162a22247c Mon Sep 17 00:00:00 2001 From: Rob Gardiner Date: Fri, 26 Apr 2024 11:21:55 +0100 Subject: [PATCH 4/6] Can now resize columns with tablet --- src/app/components/table/table.ts | 50 ++++++++++++++++++++++++++----- 1 file changed, 43 insertions(+), 7 deletions(-) diff --git a/src/app/components/table/table.ts b/src/app/components/table/table.ts index 9d08e9b4e86..2819068d194 100644 --- a/src/app/components/table/table.ts +++ b/src/app/components/table/table.ts @@ -2483,7 +2483,11 @@ export class Table implements OnInit, AfterViewInit, AfterContentInit, Blockable let containerLeft = DomHandler.getOffset(this.containerViewChild?.nativeElement).left; this.resizeColumnElement = event.target.parentElement; this.columnResizing = true; - this.lastResizerHelperX = event.pageX - containerLeft + this.containerViewChild?.nativeElement.scrollLeft; + if (event.type == 'touchstart') { + this.lastResizerHelperX = event.changedTouches[0].clientX - containerLeft + this.containerViewChild?.nativeElement.scrollLeft; + } else { + this.lastResizerHelperX = event.pageX - containerLeft + this.containerViewChild?.nativeElement.scrollLeft; + } this.onColumnResize(event); event.preventDefault(); } @@ -2493,8 +2497,11 @@ export class Table implements OnInit, AfterViewInit, AfterContentInit, Blockable DomHandler.addClass(this.containerViewChild?.nativeElement, 'p-unselectable-text'); (this.resizeHelperViewChild).nativeElement.style.height = this.containerViewChild?.nativeElement.offsetHeight + 'px'; (this.resizeHelperViewChild).nativeElement.style.top = 0 + 'px'; - (this.resizeHelperViewChild).nativeElement.style.left = event.pageX - containerLeft + this.containerViewChild?.nativeElement.scrollLeft + 'px'; - + if (event.type == 'touchmove') { + (this.resizeHelperViewChild).nativeElement.style.left = event.changedTouches[0].clientX - containerLeft + this.containerViewChild?.nativeElement.scrollLeft + 'px'; + } else { + (this.resizeHelperViewChild).nativeElement.style.left = event.pageX - containerLeft + this.containerViewChild?.nativeElement.scrollLeft + 'px'; + } (this.resizeHelperViewChild).nativeElement.style.display = 'block'; } @@ -3904,6 +3911,12 @@ export class ResizableColumn implements AfterViewInit, OnDestroy { resizerMouseDownListener: VoidListener; + resizerTouchStartListener: VoidListener; + + resizerTouchMoveListener: VoidListener; + + resizerTouchEndListener: VoidListener; + documentMouseMoveListener: VoidListener; documentMouseUpListener: VoidListener; @@ -3920,6 +3933,7 @@ export class ResizableColumn implements AfterViewInit, OnDestroy { this.zone.runOutsideAngular(() => { this.resizerMouseDownListener = this.renderer.listen(this.resizer, 'mousedown', this.onMouseDown.bind(this)); + this.resizerTouchStartListener = this.renderer.listen(this.resizer, 'touchstart', this.onTouchStart.bind(this)); }); } } @@ -3929,6 +3943,8 @@ export class ResizableColumn implements AfterViewInit, OnDestroy { this.zone.runOutsideAngular(() => { this.documentMouseMoveListener = this.renderer.listen(this.document, 'mousemove', this.onDocumentMouseMove.bind(this)); this.documentMouseUpListener = this.renderer.listen(this.document, 'mouseup', this.onDocumentMouseUp.bind(this)); + this.resizerTouchMoveListener = this.renderer.listen(this.resizer, 'touchmove', this.onTouchMove.bind(this)); + this.resizerTouchEndListener = this.renderer.listen(this.resizer, 'touchend', this.onTouchEnd.bind(this)); }); } @@ -3942,15 +3958,30 @@ export class ResizableColumn implements AfterViewInit, OnDestroy { this.documentMouseUpListener(); this.documentMouseUpListener = null; } + if (this.resizerTouchMoveListener) { + this.resizerTouchMoveListener(); + this.resizerTouchMoveListener = null; + } + + if (this.resizerTouchEndListener) { + this.resizerTouchEndListener(); + this.resizerTouchEndListener = null; + } } onMouseDown(event: MouseEvent) { - if (event.which === 1) { - this.dt.onColumnResizeBegin(event); - this.bindDocumentEvents(); - } + this.dt.onColumnResizeBegin(event); + this.bindDocumentEvents(); } + onTouchStart(event: TouchEvent) { + this.dt.onColumnResizeBegin(event); + this.bindDocumentEvents(); + } + + onTouchMove(event: TouchEvent) { + this.dt.onColumnResize(event); + } onDocumentMouseMove(event: MouseEvent) { this.dt.onColumnResize(event); } @@ -3960,6 +3991,11 @@ export class ResizableColumn implements AfterViewInit, OnDestroy { this.unbindDocumentEvents(); } + onTouchEnd(event: TouchEvent) { + this.dt.onColumnResizeEnd(); + this.unbindDocumentEvents(); + } + isEnabled() { return this.pResizableColumnDisabled !== true; } From 0eb4e90b16de0c440831e637e7a611eef4e1ceb3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C3=87etin?= <69278826+cetincakiroglu@users.noreply.github.com> Date: Fri, 26 Apr 2024 16:01:30 +0300 Subject: [PATCH 5/6] Revert typo & fix #15306 --- src/app/components/table/table.ts | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/app/components/table/table.ts b/src/app/components/table/table.ts index d125813610d..3ff7388ea29 100644 --- a/src/app/components/table/table.ts +++ b/src/app/components/table/table.ts @@ -708,7 +708,7 @@ export class Table implements OnInit, AfterViewInit, AfterContentInit, Blockable * The breakpoint to define the maximum width boundary when using stack responsive layout. * @group Props */ - @Input() breakpoint: string = '640px'; + @Input() breakpoint: string = '960px'; /** * Locale to be used in paginator formatting. * @group Props @@ -5207,7 +5207,7 @@ export class ColumnFilter implements AfterContentInit { * Enables currency input. * @group Props */ - @Input({transform: booleanAttribute}) currency: boolean | undefined; + @Input({ transform: booleanAttribute }) currency: boolean | undefined; /** * Defines the display of the currency input. * @group Props From 6f06ab57bbae80b903eb6b1cee7a3abaf20475eb Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C3=87etin?= <69278826+cetincakiroglu@users.noreply.github.com> Date: Fri, 26 Apr 2024 16:02:34 +0300 Subject: [PATCH 6/6] Update docs --- src/app/showcase/doc/apidoc/index.json | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/app/showcase/doc/apidoc/index.json b/src/app/showcase/doc/apidoc/index.json index e511b759265..f1506b4ddb3 100644 --- a/src/app/showcase/doc/apidoc/index.json +++ b/src/app/showcase/doc/apidoc/index.json @@ -6021,7 +6021,7 @@ "name": "style", "optional": false, "readonly": false, - "type": "Object", + "type": null, "description": "Inline style of the element." }, { @@ -23396,7 +23396,7 @@ "optional": false, "readonly": false, "type": "string", - "default": "640px", + "default": "960px", "description": "The breakpoint to define the maximum width boundary when using stack responsive layout." }, {