@progress/kendo-angular-dialog 19.3.0-develop.32 → 19.3.0-develop.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/common/util.d.ts CHANGED
@@ -11,21 +11,6 @@ export declare const isPresent: (value: any) => boolean;
11
11
  * @hidden
12
12
  */
13
13
  export declare const isTruthy: (value: any) => boolean;
14
- /**
15
- * @hidden
16
- */
17
- export declare enum Keys {
18
- 'esc' = 27,
19
- 'tab' = 9,
20
- 'enter' = 13,
21
- 'space' = 32,
22
- 'ctrl' = 17,
23
- 'shift' = 16,
24
- 'left' = 37,
25
- 'up' = 38,
26
- 'right' = 39,
27
- 'down' = 40
28
- }
29
14
  /**
30
15
  * @hidden
31
16
  */
@@ -14,22 +14,6 @@ export const isPresent = (value) => value !== null && value !== undefined;
14
14
  export const isTruthy = (value) => !!value;
15
15
  const toClassList = (classNames) => String(classNames).trim().split(' ');
16
16
  const focusableRegex = /^(?:a|input|select|textarea|button|object)$/i;
17
- /**
18
- * @hidden
19
- */
20
- export var Keys;
21
- (function (Keys) {
22
- Keys[Keys["esc"] = 27] = "esc";
23
- Keys[Keys["tab"] = 9] = "tab";
24
- Keys[Keys["enter"] = 13] = "enter";
25
- Keys[Keys["space"] = 32] = "space";
26
- Keys[Keys["ctrl"] = 17] = "ctrl";
27
- Keys[Keys["shift"] = 16] = "shift";
28
- Keys[Keys["left"] = 37] = "left";
29
- Keys[Keys["up"] = 38] = "up";
30
- Keys[Keys["right"] = 39] = "right";
31
- Keys[Keys["down"] = 40] = "down";
32
- })(Keys || (Keys = {}));
33
17
  /**
34
18
  * @hidden
35
19
  */
@@ -10,8 +10,8 @@ import { DialogTitleBarComponent } from './dialog-titlebar.component';
10
10
  import { LocalizationService, L10N_PREFIX } from '@progress/kendo-angular-l10n';
11
11
  import { validatePackage } from '@progress/kendo-licensing';
12
12
  import { packageMetadata } from '../package-metadata';
13
- import { hasClasses, Keys, isPresent, isFocusable, DIALOG_ELEMENTS_HANDLING_ARROWS, DIALOG_ELEMENTS_HANDLING_ESC_KEY, createValueWithUnit, parseCSSClassNames, findPrimaryButton } from '../common/util';
14
- import { focusableSelector, shouldShowValidationUI, getLicenseMessage, setHTMLAttributes } from '@progress/kendo-angular-common';
13
+ import { hasClasses, isPresent, isFocusable, DIALOG_ELEMENTS_HANDLING_ARROWS, DIALOG_ELEMENTS_HANDLING_ESC_KEY, createValueWithUnit, parseCSSClassNames, findPrimaryButton } from '../common/util';
14
+ import { focusableSelector, shouldShowValidationUI, getLicenseMessage, setHTMLAttributes, Keys, normalizeNumpadKeys } from '@progress/kendo-angular-common';
15
15
  import { DialogCloseResult } from './models/dialog-close-result';
16
16
  import { DIALOG_LOCALIZATION_SERVICE } from './../localization/dialog-localization.service';
17
17
  import { take } from 'rxjs/operators';
@@ -307,20 +307,21 @@ export class DialogComponent {
307
307
  onKeyDown(event) {
308
308
  const target = event.target;
309
309
  const parent = target.parentElement;
310
+ const code = normalizeNumpadKeys(event);
310
311
  if (hasClasses(target, DIALOG_ELEMENTS_HANDLING_ESC_KEY) || hasClasses(parent, DIALOG_ELEMENTS_HANDLING_ESC_KEY)) {
311
- if (event.keyCode === Keys.esc) {
312
+ if (code === Keys.Escape) {
312
313
  this.ngZone.run(() => {
313
314
  this.close.emit(new DialogCloseResult());
314
315
  });
315
316
  }
316
317
  }
317
318
  if (hasClasses(target, 'k-button') && hasClasses(parent, DIALOG_ELEMENTS_HANDLING_ARROWS) &&
318
- (event.keyCode === Keys.left || event.keyCode === Keys.right)) {
319
+ (code === Keys.ArrowLeft || code === Keys.ArrowRight)) {
319
320
  this.ngZone.run(() => {
320
- this.handleActionButtonFocus(parent, event.keyCode);
321
+ this.handleActionButtonFocus(parent, code);
321
322
  });
322
323
  }
323
- if (event.keyCode === Keys.tab) {
324
+ if (code === Keys.Tab) {
324
325
  this.ngZone.run(() => {
325
326
  this.keepFocusWithinComponent(target, event);
326
327
  });
@@ -373,11 +374,11 @@ export class DialogComponent {
373
374
  for (let i = 0; i < focusableActionButtons.length; i++) {
374
375
  const current = focusableActionButtons[i];
375
376
  if (current === document.activeElement) {
376
- if (key === Keys.left && i > 0) {
377
+ if (key === Keys.ArrowLeft && i > 0) {
377
378
  focusableActionButtons[i - 1].focus();
378
379
  break;
379
380
  }
380
- if (key === Keys.right && i < focusableActionButtons.length - 1) {
381
+ if (key === Keys.ArrowRight && i < focusableActionButtons.length - 1) {
381
382
  focusableActionButtons[i + 1].focus();
382
383
  break;
383
384
  }
@@ -10,7 +10,7 @@ export const packageMetadata = {
10
10
  productName: 'Kendo UI for Angular',
11
11
  productCode: 'KENDOUIANGULAR',
12
12
  productCodes: ['KENDOUIANGULAR'],
13
- publishDate: 1754579377,
14
- version: '19.3.0-develop.32',
13
+ publishDate: 1754894764,
14
+ version: '19.3.0-develop.34',
15
15
  licensingDocsUrl: 'https://www.telerik.com/kendo-angular-ui/my-license/'
16
16
  };
@@ -4,7 +4,8 @@
4
4
  *-------------------------------------------------------------------------------------------*/
5
5
  import { Injectable, NgZone } from "@angular/core";
6
6
  import { DragResizeService } from './drag-resize.service';
7
- import { isPresent, OFFSET_STYLES, Keys, WINDOW_CLASSES, hasClasses, WINDOW_ELEMENTS_HANDLING_ESC_KEY } from '../common/util';
7
+ import { isPresent, OFFSET_STYLES, WINDOW_CLASSES, hasClasses, WINDOW_ELEMENTS_HANDLING_ESC_KEY } from '../common/util';
8
+ import { Keys, normalizeNumpadKeys } from "@progress/kendo-angular-common";
8
9
  import * as i0 from "@angular/core";
9
10
  import * as i1 from "./drag-resize.service";
10
11
  /**
@@ -18,13 +19,13 @@ export class NavigationService {
18
19
  this.ngZone = ngZone;
19
20
  }
20
21
  process(ev) {
21
- const key = ev.keyCode;
22
+ const key = normalizeNumpadKeys(ev);
22
23
  const target = ev.target;
23
24
  switch (key) {
24
- case Keys.up:
25
- case Keys.down:
26
- case Keys.left:
27
- case Keys.right: {
25
+ case Keys.ArrowUp:
26
+ case Keys.ArrowDown:
27
+ case Keys.ArrowLeft:
28
+ case Keys.ArrowRight: {
28
29
  if (hasClasses(target, WINDOW_CLASSES)) {
29
30
  ev.preventDefault();
30
31
  this.ngZone.run(() => {
@@ -33,7 +34,7 @@ export class NavigationService {
33
34
  }
34
35
  break;
35
36
  }
36
- case Keys.esc:
37
+ case Keys.Escape:
37
38
  if (hasClasses(target, WINDOW_ELEMENTS_HANDLING_ESC_KEY)) {
38
39
  this.ngZone.run(() => {
39
40
  this.handleEscape();
@@ -69,18 +70,18 @@ export class NavigationService {
69
70
  const restoreOptions = this.window.restoreOptions;
70
71
  const ev = {};
71
72
  let delta = 10;
72
- if (key === Keys.left || key === Keys.up) {
73
+ if (key === Keys.ArrowLeft || key === Keys.ArrowUp) {
73
74
  delta *= -1;
74
75
  }
75
76
  switch (key) {
76
- case Keys.left:
77
- case Keys.right: {
77
+ case Keys.ArrowLeft:
78
+ case Keys.ArrowRight: {
78
79
  ev.left = offset.x + delta;
79
80
  options.left = ev.left;
80
81
  break;
81
82
  }
82
- case Keys.up:
83
- case Keys.down: {
83
+ case Keys.ArrowUp:
84
+ case Keys.ArrowDown: {
84
85
  ev.top = offset.y + delta;
85
86
  options.top = ev.top;
86
87
  break;
@@ -104,20 +105,20 @@ export class NavigationService {
104
105
  let newHeight;
105
106
  const ev = {};
106
107
  let delta = 10;
107
- if (key === Keys.left || key === Keys.up) {
108
+ if (key === Keys.ArrowLeft || key === Keys.ArrowUp) {
108
109
  delta *= -1;
109
110
  }
110
111
  switch (key) {
111
- case Keys.left:
112
- case Keys.right: {
112
+ case Keys.ArrowLeft:
113
+ case Keys.ArrowRight: {
113
114
  newWidth = offset.width + delta;
114
115
  if (newWidth !== options.width && newWidth >= options.minWidth) {
115
116
  ev.width = newWidth;
116
117
  }
117
118
  break;
118
119
  }
119
- case Keys.up:
120
- case Keys.down: {
120
+ case Keys.ArrowUp:
121
+ case Keys.ArrowDown: {
121
122
  newHeight = offset.height + delta;
122
123
  if (newHeight !== options.height && newHeight >= options.minHeight) {
123
124
  ev.height = newHeight;
@@ -137,16 +138,16 @@ export class NavigationService {
137
138
  }
138
139
  }
139
140
  handleStateChange(key, state) {
140
- if ((state === 'minimized' && key === Keys.up) ||
141
- (state === 'maximized' && key === Keys.down)) {
141
+ if ((state === 'minimized' && key === Keys.ArrowUp) ||
142
+ (state === 'maximized' && key === Keys.ArrowDown)) {
142
143
  this.window.restoreAction();
143
144
  return;
144
145
  }
145
146
  if (state === 'default') {
146
- if (key === Keys.up) {
147
+ if (key === Keys.ArrowUp) {
147
148
  this.window.maximizeAction();
148
149
  }
149
- else if (key === Keys.down) {
150
+ else if (key === Keys.ArrowDown) {
150
151
  this.window.minimizeAction();
151
152
  }
152
153
  }
@@ -16,7 +16,7 @@ import { xIcon, windowRestoreIcon, windowIcon, windowMinimizeIcon } from '@progr
16
16
  import { validatePackage } from '@progress/kendo-licensing';
17
17
  import { of, Subscription, Subject, merge } from 'rxjs';
18
18
  import * as i1$2 from '@progress/kendo-angular-common';
19
- import { setHTMLAttributes, getLicenseMessage, shouldShowValidationUI, isDocumentAvailable, focusableSelector, WatermarkOverlayComponent, DraggableDirective, isChanged } from '@progress/kendo-angular-common';
19
+ import { setHTMLAttributes, getLicenseMessage, shouldShowValidationUI, isDocumentAvailable, normalizeNumpadKeys, Keys, focusableSelector, WatermarkOverlayComponent, DraggableDirective, isChanged } from '@progress/kendo-angular-common';
20
20
  import { offset, scrollPosition, positionWithScroll, getDocumentElement, getWindowViewPort } from '@progress/kendo-popup-common';
21
21
  import { IconWrapperComponent, IconsService } from '@progress/kendo-angular-icons';
22
22
 
@@ -498,8 +498,8 @@ const packageMetadata = {
498
498
  productName: 'Kendo UI for Angular',
499
499
  productCode: 'KENDOUIANGULAR',
500
500
  productCodes: ['KENDOUIANGULAR'],
501
- publishDate: 1754579377,
502
- version: '19.3.0-develop.32',
501
+ publishDate: 1754894764,
502
+ version: '19.3.0-develop.34',
503
503
  licensingDocsUrl: 'https://www.telerik.com/kendo-angular-ui/my-license/'
504
504
  };
505
505
 
@@ -513,22 +513,6 @@ const isPresent = (value) => value !== null && value !== undefined;
513
513
  const isTruthy = (value) => !!value;
514
514
  const toClassList = (classNames) => String(classNames).trim().split(' ');
515
515
  const focusableRegex = /^(?:a|input|select|textarea|button|object)$/i;
516
- /**
517
- * @hidden
518
- */
519
- var Keys;
520
- (function (Keys) {
521
- Keys[Keys["esc"] = 27] = "esc";
522
- Keys[Keys["tab"] = 9] = "tab";
523
- Keys[Keys["enter"] = 13] = "enter";
524
- Keys[Keys["space"] = 32] = "space";
525
- Keys[Keys["ctrl"] = 17] = "ctrl";
526
- Keys[Keys["shift"] = 16] = "shift";
527
- Keys[Keys["left"] = 37] = "left";
528
- Keys[Keys["up"] = 38] = "up";
529
- Keys[Keys["right"] = 39] = "right";
530
- Keys[Keys["down"] = 40] = "down";
531
- })(Keys || (Keys = {}));
532
516
  /**
533
517
  * @hidden
534
518
  */
@@ -1069,20 +1053,21 @@ class DialogComponent {
1069
1053
  onKeyDown(event) {
1070
1054
  const target = event.target;
1071
1055
  const parent = target.parentElement;
1056
+ const code = normalizeNumpadKeys(event);
1072
1057
  if (hasClasses(target, DIALOG_ELEMENTS_HANDLING_ESC_KEY) || hasClasses(parent, DIALOG_ELEMENTS_HANDLING_ESC_KEY)) {
1073
- if (event.keyCode === Keys.esc) {
1058
+ if (code === Keys.Escape) {
1074
1059
  this.ngZone.run(() => {
1075
1060
  this.close.emit(new DialogCloseResult());
1076
1061
  });
1077
1062
  }
1078
1063
  }
1079
1064
  if (hasClasses(target, 'k-button') && hasClasses(parent, DIALOG_ELEMENTS_HANDLING_ARROWS) &&
1080
- (event.keyCode === Keys.left || event.keyCode === Keys.right)) {
1065
+ (code === Keys.ArrowLeft || code === Keys.ArrowRight)) {
1081
1066
  this.ngZone.run(() => {
1082
- this.handleActionButtonFocus(parent, event.keyCode);
1067
+ this.handleActionButtonFocus(parent, code);
1083
1068
  });
1084
1069
  }
1085
- if (event.keyCode === Keys.tab) {
1070
+ if (code === Keys.Tab) {
1086
1071
  this.ngZone.run(() => {
1087
1072
  this.keepFocusWithinComponent(target, event);
1088
1073
  });
@@ -1135,11 +1120,11 @@ class DialogComponent {
1135
1120
  for (let i = 0; i < focusableActionButtons.length; i++) {
1136
1121
  const current = focusableActionButtons[i];
1137
1122
  if (current === document.activeElement) {
1138
- if (key === Keys.left && i > 0) {
1123
+ if (key === Keys.ArrowLeft && i > 0) {
1139
1124
  focusableActionButtons[i - 1].focus();
1140
1125
  break;
1141
1126
  }
1142
- if (key === Keys.right && i < focusableActionButtons.length - 1) {
1127
+ if (key === Keys.ArrowRight && i < focusableActionButtons.length - 1) {
1143
1128
  focusableActionButtons[i + 1].focus();
1144
1129
  break;
1145
1130
  }
@@ -2365,13 +2350,13 @@ class NavigationService {
2365
2350
  this.ngZone = ngZone;
2366
2351
  }
2367
2352
  process(ev) {
2368
- const key = ev.keyCode;
2353
+ const key = normalizeNumpadKeys(ev);
2369
2354
  const target = ev.target;
2370
2355
  switch (key) {
2371
- case Keys.up:
2372
- case Keys.down:
2373
- case Keys.left:
2374
- case Keys.right: {
2356
+ case Keys.ArrowUp:
2357
+ case Keys.ArrowDown:
2358
+ case Keys.ArrowLeft:
2359
+ case Keys.ArrowRight: {
2375
2360
  if (hasClasses(target, WINDOW_CLASSES)) {
2376
2361
  ev.preventDefault();
2377
2362
  this.ngZone.run(() => {
@@ -2380,7 +2365,7 @@ class NavigationService {
2380
2365
  }
2381
2366
  break;
2382
2367
  }
2383
- case Keys.esc:
2368
+ case Keys.Escape:
2384
2369
  if (hasClasses(target, WINDOW_ELEMENTS_HANDLING_ESC_KEY)) {
2385
2370
  this.ngZone.run(() => {
2386
2371
  this.handleEscape();
@@ -2416,18 +2401,18 @@ class NavigationService {
2416
2401
  const restoreOptions = this.window.restoreOptions;
2417
2402
  const ev = {};
2418
2403
  let delta = 10;
2419
- if (key === Keys.left || key === Keys.up) {
2404
+ if (key === Keys.ArrowLeft || key === Keys.ArrowUp) {
2420
2405
  delta *= -1;
2421
2406
  }
2422
2407
  switch (key) {
2423
- case Keys.left:
2424
- case Keys.right: {
2408
+ case Keys.ArrowLeft:
2409
+ case Keys.ArrowRight: {
2425
2410
  ev.left = offset.x + delta;
2426
2411
  options.left = ev.left;
2427
2412
  break;
2428
2413
  }
2429
- case Keys.up:
2430
- case Keys.down: {
2414
+ case Keys.ArrowUp:
2415
+ case Keys.ArrowDown: {
2431
2416
  ev.top = offset.y + delta;
2432
2417
  options.top = ev.top;
2433
2418
  break;
@@ -2451,20 +2436,20 @@ class NavigationService {
2451
2436
  let newHeight;
2452
2437
  const ev = {};
2453
2438
  let delta = 10;
2454
- if (key === Keys.left || key === Keys.up) {
2439
+ if (key === Keys.ArrowLeft || key === Keys.ArrowUp) {
2455
2440
  delta *= -1;
2456
2441
  }
2457
2442
  switch (key) {
2458
- case Keys.left:
2459
- case Keys.right: {
2443
+ case Keys.ArrowLeft:
2444
+ case Keys.ArrowRight: {
2460
2445
  newWidth = offset.width + delta;
2461
2446
  if (newWidth !== options.width && newWidth >= options.minWidth) {
2462
2447
  ev.width = newWidth;
2463
2448
  }
2464
2449
  break;
2465
2450
  }
2466
- case Keys.up:
2467
- case Keys.down: {
2451
+ case Keys.ArrowUp:
2452
+ case Keys.ArrowDown: {
2468
2453
  newHeight = offset.height + delta;
2469
2454
  if (newHeight !== options.height && newHeight >= options.minHeight) {
2470
2455
  ev.height = newHeight;
@@ -2484,16 +2469,16 @@ class NavigationService {
2484
2469
  }
2485
2470
  }
2486
2471
  handleStateChange(key, state) {
2487
- if ((state === 'minimized' && key === Keys.up) ||
2488
- (state === 'maximized' && key === Keys.down)) {
2472
+ if ((state === 'minimized' && key === Keys.ArrowUp) ||
2473
+ (state === 'maximized' && key === Keys.ArrowDown)) {
2489
2474
  this.window.restoreAction();
2490
2475
  return;
2491
2476
  }
2492
2477
  if (state === 'default') {
2493
- if (key === Keys.up) {
2478
+ if (key === Keys.ArrowUp) {
2494
2479
  this.window.maximizeAction();
2495
2480
  }
2496
- else if (key === Keys.down) {
2481
+ else if (key === Keys.ArrowDown) {
2497
2482
  this.window.minimizeAction();
2498
2483
  }
2499
2484
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@progress/kendo-angular-dialog",
3
- "version": "19.3.0-develop.32",
3
+ "version": "19.3.0-develop.34",
4
4
  "description": "Dialog Package for Angular",
5
5
  "license": "SEE LICENSE IN LICENSE.md",
6
6
  "author": "Progress",
@@ -23,7 +23,7 @@
23
23
  "package": {
24
24
  "productName": "Kendo UI for Angular",
25
25
  "productCode": "KENDOUIANGULAR",
26
- "publishDate": 1754579377,
26
+ "publishDate": 1754894764,
27
27
  "licensingDocsUrl": "https://www.telerik.com/kendo-angular-ui/my-license/"
28
28
  }
29
29
  },
@@ -33,15 +33,15 @@
33
33
  "@angular/core": "16 - 20",
34
34
  "@angular/platform-browser": "16 - 20",
35
35
  "@progress/kendo-licensing": "^1.7.0",
36
- "@progress/kendo-angular-buttons": "19.3.0-develop.32",
37
- "@progress/kendo-angular-common": "19.3.0-develop.32",
38
- "@progress/kendo-angular-icons": "19.3.0-develop.32",
39
- "@progress/kendo-angular-l10n": "19.3.0-develop.32",
36
+ "@progress/kendo-angular-buttons": "19.3.0-develop.34",
37
+ "@progress/kendo-angular-common": "19.3.0-develop.34",
38
+ "@progress/kendo-angular-icons": "19.3.0-develop.34",
39
+ "@progress/kendo-angular-l10n": "19.3.0-develop.34",
40
40
  "rxjs": "^6.5.3 || ^7.0.0"
41
41
  },
42
42
  "dependencies": {
43
43
  "tslib": "^2.3.1",
44
- "@progress/kendo-angular-schematics": "19.3.0-develop.32",
44
+ "@progress/kendo-angular-schematics": "19.3.0-develop.34",
45
45
  "@progress/kendo-popup-common": "^1.7.0"
46
46
  },
47
47
  "schematics": "./schematics/collection.json",
@@ -4,7 +4,7 @@ const schematics_1 = require("@angular-devkit/schematics");
4
4
  function default_1(options) {
5
5
  const finalOptions = Object.assign(Object.assign({}, options), { mainNgModule: 'DialogsModule', package: 'dialog', peerDependencies: {
6
6
  // Peer dependency of buttons
7
- '@progress/kendo-angular-popup': '19.3.0-develop.32',
7
+ '@progress/kendo-angular-popup': '19.3.0-develop.34',
8
8
  // Peer dependency of icons
9
9
  '@progress/kendo-svg-icons': '^4.0.0'
10
10
  } });
@@ -6,6 +6,15 @@
6
6
  * @hidden
7
7
  */
8
8
  export type WindowPosition = 'absolute' | 'fixed';
9
+ /**
10
+ * Represents the possible states of the Window component.
11
+ */
9
12
  export type WindowState = 'minimized' | 'maximized' | 'default';
13
+ /**
14
+ * Represents the dimensions of the Window that can be resized dynamically.
15
+ */
10
16
  export type WindowDimensionSetting = 'width' | 'height';
17
+ /**
18
+ * Represents the offset of the Window that can be set dynamically.
19
+ */
11
20
  export type WindowOffsetSetting = 'top' | 'left';
@@ -13,12 +13,12 @@ export declare class NavigationService {
13
13
  private window;
14
14
  private ngZone;
15
15
  constructor(window: DragResizeService, ngZone: NgZone);
16
- process(ev: any): void;
17
- handleArrow(key: number, ev: KeyboardEvent): void;
16
+ process(ev: KeyboardEvent): void;
17
+ handleArrow(key: string, ev: KeyboardEvent): void;
18
18
  handleEscape(): void;
19
- handleDrag(key: number): void;
20
- handleResize(key: number): void;
21
- handleStateChange(key: number, state: WindowState): void;
19
+ handleDrag(key: string): void;
20
+ handleResize(key: string): void;
21
+ handleStateChange(key: string, state: WindowState): void;
22
22
  static ɵfac: i0.ɵɵFactoryDeclaration<NavigationService, never>;
23
23
  static ɵprov: i0.ɵɵInjectableDeclaration<NavigationService>;
24
24
  }