@progress/kendo-angular-common 21.4.1-develop.1 → 22.0.0-develop.1
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/fesm2022/progress-kendo-angular-common.mjs +34 -34
- package/package.json +5 -7
- package/esm2022/adornments/prefix.directive.mjs +0 -53
- package/esm2022/adornments/separator-orientation.mjs +0 -5
- package/esm2022/adornments/separator.component.mjs +0 -70
- package/esm2022/adornments/suffix.directive.mjs +0 -59
- package/esm2022/adornments.mjs +0 -7
- package/esm2022/directives.mjs +0 -68
- package/esm2022/dom-queries/closest-by-selector.mjs +0 -20
- package/esm2022/dom-queries/closest-in-scope.mjs +0 -13
- package/esm2022/dom-queries/closest.mjs +0 -10
- package/esm2022/dom-queries/contains.mjs +0 -13
- package/esm2022/dom-queries/find-element.mjs +0 -22
- package/esm2022/dom-queries/find-focusable-child.mjs +0 -9
- package/esm2022/dom-queries/find-focusable.mjs +0 -9
- package/esm2022/dom-queries/has-classes.mjs +0 -9
- package/esm2022/dom-queries/is-focusable-with-tab-key.mjs +0 -14
- package/esm2022/dom-queries/is-focusable.mjs +0 -14
- package/esm2022/dom-queries/is-visible.mjs +0 -12
- package/esm2022/dom-queries/matches-classes.mjs +0 -6
- package/esm2022/dom-queries/matches-node-name.mjs +0 -11
- package/esm2022/dom-queries/rtl-scroll-position.mjs +0 -17
- package/esm2022/dom-queries.mjs +0 -18
- package/esm2022/draggable/draggable.directive.mjs +0 -68
- package/esm2022/draggable.mjs +0 -5
- package/esm2022/enums/keys.mjs +0 -75
- package/esm2022/enums.mjs +0 -5
- package/esm2022/events/events-outside-angular.directive.mjs +0 -58
- package/esm2022/events.mjs +0 -5
- package/esm2022/index.mjs +0 -24
- package/esm2022/localization/replace-message-placeholder.mjs +0 -8
- package/esm2022/preventable-event.mjs +0 -22
- package/esm2022/progress-kendo-angular-common.mjs +0 -8
- package/esm2022/resize-sensor/compat.service.mjs +0 -103
- package/esm2022/resize-sensor/observer.service.mjs +0 -41
- package/esm2022/resize-sensor/resize-batch.service.mjs +0 -69
- package/esm2022/resize-sensor/resize-sensor.component.mjs +0 -71
- package/esm2022/resize-sensor/resize.service.mjs +0 -65
- package/esm2022/resize-sensor.mjs +0 -8
- package/esm2022/template-context/index.mjs +0 -5
- package/esm2022/template-context/template-context.directive.mjs +0 -37
- package/esm2022/toggle-button-tab-stop/toggle-button-tab-stop.directive.mjs +0 -262
- package/esm2022/toggle-button-tab-stop/toggle-button-tab-stop.mjs +0 -10
- package/esm2022/toggle-button-tab-stop.mjs +0 -6
- package/esm2022/tokens.mjs +0 -6
- package/esm2022/utils/any-changed.mjs +0 -9
- package/esm2022/utils/detect-browser.mjs +0 -28
- package/esm2022/utils/focusable-selectors.mjs +0 -20
- package/esm2022/utils/forms-utils.mjs +0 -13
- package/esm2022/utils/getter.mjs +0 -27
- package/esm2022/utils/guid.mjs +0 -29
- package/esm2022/utils/has-observers.mjs +0 -8
- package/esm2022/utils/html-attributes.mjs +0 -49
- package/esm2022/utils/is-changed.mjs +0 -10
- package/esm2022/utils/is-document-available.mjs +0 -8
- package/esm2022/utils/keys-normalizer.mjs +0 -95
- package/esm2022/utils/ng-class-parser.mjs +0 -78
- package/esm2022/utils/objects-equal.mjs +0 -12
- package/esm2022/utils/process-css-value.mjs +0 -23
- package/esm2022/utils/scrollbar-width.service.mjs +0 -43
- package/esm2022/utils/setter.mjs +0 -28
- package/esm2022/utils.mjs +0 -14
- package/esm2022/watermark/index.mjs +0 -6
- package/esm2022/watermark/utils.mjs +0 -58
- package/esm2022/watermark/validation.mjs +0 -22
- package/esm2022/watermark/watermark.component.mjs +0 -116
|
@@ -1,95 +0,0 @@
|
|
|
1
|
-
/**-----------------------------------------------------------------------------------------
|
|
2
|
-
* Copyright © 2026 Progress Software Corporation. All rights reserved.
|
|
3
|
-
* Licensed under commercial license. See LICENSE.md in the project root for more information
|
|
4
|
-
*-------------------------------------------------------------------------------------------*/
|
|
5
|
-
import { Keys } from "../enums";
|
|
6
|
-
/**
|
|
7
|
-
* @hidden
|
|
8
|
-
*
|
|
9
|
-
* Maps keyCode values (65-90) to Keys enum values (KeyA-KeyZ).
|
|
10
|
-
* Used to handle letter keys correctly across different keyboard layouts.
|
|
11
|
-
*/
|
|
12
|
-
const keyCodeToKeysMap = {
|
|
13
|
-
65: Keys.KeyA,
|
|
14
|
-
66: Keys.KeyB,
|
|
15
|
-
67: Keys.KeyC,
|
|
16
|
-
68: Keys.KeyD,
|
|
17
|
-
69: Keys.KeyE,
|
|
18
|
-
70: Keys.KeyF,
|
|
19
|
-
71: Keys.KeyG,
|
|
20
|
-
72: Keys.KeyH,
|
|
21
|
-
73: Keys.KeyI,
|
|
22
|
-
74: Keys.KeyJ,
|
|
23
|
-
75: Keys.KeyK,
|
|
24
|
-
76: Keys.KeyL,
|
|
25
|
-
77: Keys.KeyM,
|
|
26
|
-
78: Keys.KeyN,
|
|
27
|
-
79: Keys.KeyO,
|
|
28
|
-
80: Keys.KeyP,
|
|
29
|
-
81: Keys.KeyQ,
|
|
30
|
-
82: Keys.KeyR,
|
|
31
|
-
83: Keys.KeyS,
|
|
32
|
-
84: Keys.KeyT,
|
|
33
|
-
85: Keys.KeyU,
|
|
34
|
-
86: Keys.KeyV,
|
|
35
|
-
87: Keys.KeyW,
|
|
36
|
-
88: Keys.KeyX,
|
|
37
|
-
89: Keys.KeyY,
|
|
38
|
-
90: Keys.KeyZ
|
|
39
|
-
};
|
|
40
|
-
/**
|
|
41
|
-
* @hidden
|
|
42
|
-
*
|
|
43
|
-
* Normalizes keyboard events to ensure consistent key handling across different keyboard layouts.
|
|
44
|
-
*
|
|
45
|
-
* This function addresses the following scenarios:
|
|
46
|
-
* 1. On some keyboards, PageUp/Down, Home/End, and arrow keys are mapped to Numpad keys
|
|
47
|
-
* 2. For letter keys (KeyA-KeyZ), checks the deprecated keyCode property to handle non-QWERTY layouts
|
|
48
|
-
* (e.g., AZERTY, QWERTZ) where event.code may not match the expected letter
|
|
49
|
-
*
|
|
50
|
-
* @param event - The keyboard event to normalize
|
|
51
|
-
* @returns The normalized key code string (e.g., 'KeyA', 'ArrowDown', 'Enter')
|
|
52
|
-
*
|
|
53
|
-
* @example
|
|
54
|
-
* // On an AZERTY layout, pressing Ctrl+A (where 'A' is physically at 'Q' position)
|
|
55
|
-
* // event.code = 'KeyQ', event.keyCode = 65
|
|
56
|
-
* const code = normalizeKeys(event); // Returns 'KeyA'
|
|
57
|
-
*/
|
|
58
|
-
export const normalizeKeys = (event) => {
|
|
59
|
-
const keyCode = event.keyCode;
|
|
60
|
-
if (keyCode >= 65 && keyCode <= 90) {
|
|
61
|
-
const normalizedKey = keyCodeToKeysMap[keyCode];
|
|
62
|
-
if (normalizedKey) {
|
|
63
|
-
return normalizedKey;
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
// Handle numpad keys that may be mapped to navigation keys
|
|
67
|
-
if (event.code === Keys.Numpad1 && event.key === Keys.End) {
|
|
68
|
-
return Keys.End;
|
|
69
|
-
}
|
|
70
|
-
if (event.code === Keys.Numpad2 && event.key === Keys.ArrowDown) {
|
|
71
|
-
return Keys.ArrowDown;
|
|
72
|
-
}
|
|
73
|
-
if (event.code === Keys.Numpad3 && event.key === Keys.PageDown) {
|
|
74
|
-
return Keys.PageDown;
|
|
75
|
-
}
|
|
76
|
-
if (event.code === Keys.Numpad4 && event.key === Keys.ArrowLeft) {
|
|
77
|
-
return Keys.ArrowLeft;
|
|
78
|
-
}
|
|
79
|
-
if (event.code === Keys.Numpad6 && event.key === Keys.ArrowRight) {
|
|
80
|
-
return Keys.ArrowRight;
|
|
81
|
-
}
|
|
82
|
-
if (event.code === Keys.Numpad7 && event.key === Keys.Home) {
|
|
83
|
-
return Keys.Home;
|
|
84
|
-
}
|
|
85
|
-
if (event.code === Keys.Numpad8 && event.key === Keys.ArrowUp) {
|
|
86
|
-
return Keys.ArrowUp;
|
|
87
|
-
}
|
|
88
|
-
if (event.code === Keys.Numpad9 && event.key === Keys.PageUp) {
|
|
89
|
-
return Keys.PageUp;
|
|
90
|
-
}
|
|
91
|
-
if (event.code === Keys.NumpadEnter) {
|
|
92
|
-
return Keys.Enter;
|
|
93
|
-
}
|
|
94
|
-
return event.code;
|
|
95
|
-
};
|
|
@@ -1,78 +0,0 @@
|
|
|
1
|
-
/**-----------------------------------------------------------------------------------------
|
|
2
|
-
* Copyright © 2026 Progress Software Corporation. All rights reserved.
|
|
3
|
-
* Licensed under commercial license. See LICENSE.md in the project root for more information
|
|
4
|
-
*-------------------------------------------------------------------------------------------*/
|
|
5
|
-
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
6
|
-
/**
|
|
7
|
-
* @hidden
|
|
8
|
-
*/
|
|
9
|
-
export const isPresent = (value) => value !== null && value !== undefined;
|
|
10
|
-
/**
|
|
11
|
-
* @hidden
|
|
12
|
-
*/
|
|
13
|
-
export const isObjectPresent = (value) => {
|
|
14
|
-
return isObject(value) && Object.keys(value).length > 0;
|
|
15
|
-
};
|
|
16
|
-
/**
|
|
17
|
-
* @hidden
|
|
18
|
-
*/
|
|
19
|
-
export const isString = (value) => value instanceof String || typeof value === 'string';
|
|
20
|
-
/**
|
|
21
|
-
* @hidden
|
|
22
|
-
*/
|
|
23
|
-
export const isObject = (value) => isPresent(value) && !Array.isArray(value) && typeof value === 'object';
|
|
24
|
-
/**
|
|
25
|
-
* @hidden
|
|
26
|
-
*/
|
|
27
|
-
export const isSet = (value) => isPresent(value) && value instanceof Set;
|
|
28
|
-
/**
|
|
29
|
-
* @hidden
|
|
30
|
-
*/
|
|
31
|
-
export const splitStringToArray = (value) => value.trim().replace(/\s+/g, " ").split(' ');
|
|
32
|
-
/**
|
|
33
|
-
* Receives CSS class declarations either as an object, string, set or array and returns an array of the class names.
|
|
34
|
-
*
|
|
35
|
-
* @hidden
|
|
36
|
-
*/
|
|
37
|
-
export const parseCSSClassNames = (value) => {
|
|
38
|
-
if (Array.isArray(value)) {
|
|
39
|
-
return parseArrayClassNames(value);
|
|
40
|
-
}
|
|
41
|
-
if (isSet(value)) {
|
|
42
|
-
return parseArrayClassNames(Array.from(value));
|
|
43
|
-
}
|
|
44
|
-
if (isObject(value)) {
|
|
45
|
-
return parseObjectClassNames(value);
|
|
46
|
-
}
|
|
47
|
-
if (isString(value)) {
|
|
48
|
-
return parseStringClassNames(value);
|
|
49
|
-
}
|
|
50
|
-
};
|
|
51
|
-
const parseObjectClassNames = (value) => {
|
|
52
|
-
const classes = [];
|
|
53
|
-
Object.keys(value).forEach((className) => {
|
|
54
|
-
const currentClassName = splitStringToArray(className);
|
|
55
|
-
if (value[className] && currentClassName.length) {
|
|
56
|
-
classes.push(...currentClassName);
|
|
57
|
-
}
|
|
58
|
-
});
|
|
59
|
-
return classes;
|
|
60
|
-
};
|
|
61
|
-
const parseStringClassNames = (value) => {
|
|
62
|
-
const classes = [];
|
|
63
|
-
const classesArray = splitStringToArray(value);
|
|
64
|
-
classesArray.forEach((className) => {
|
|
65
|
-
classes.push(className);
|
|
66
|
-
});
|
|
67
|
-
return classes;
|
|
68
|
-
};
|
|
69
|
-
const parseArrayClassNames = (value) => {
|
|
70
|
-
const classes = [];
|
|
71
|
-
value.forEach((className) => {
|
|
72
|
-
const current = splitStringToArray(className);
|
|
73
|
-
if (current[0]) {
|
|
74
|
-
classes.push(...current);
|
|
75
|
-
}
|
|
76
|
-
});
|
|
77
|
-
return classes;
|
|
78
|
-
};
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
/**-----------------------------------------------------------------------------------------
|
|
2
|
-
* Copyright © 2026 Progress Software Corporation. All rights reserved.
|
|
3
|
-
* Licensed under commercial license. See LICENSE.md in the project root for more information
|
|
4
|
-
*-------------------------------------------------------------------------------------------*/
|
|
5
|
-
export const areObjectsEqual = (firstObject, secondObject) => {
|
|
6
|
-
if (Object.keys(firstObject).length !== Object.keys(secondObject).length) {
|
|
7
|
-
return false;
|
|
8
|
-
}
|
|
9
|
-
const equalSettings = Object.entries(firstObject)
|
|
10
|
-
.filter(([key, value]) => value === secondObject[key.toString()]);
|
|
11
|
-
return equalSettings.length === Object.keys(firstObject).length;
|
|
12
|
-
};
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
/**-----------------------------------------------------------------------------------------
|
|
2
|
-
* Copyright © 2026 Progress Software Corporation. All rights reserved.
|
|
3
|
-
* Licensed under commercial license. See LICENSE.md in the project root for more information
|
|
4
|
-
*-------------------------------------------------------------------------------------------*/
|
|
5
|
-
export const processCssValue = (value) => {
|
|
6
|
-
if (typeof value === 'number') {
|
|
7
|
-
return `${value}px`;
|
|
8
|
-
}
|
|
9
|
-
else if (typeof value === 'string') {
|
|
10
|
-
const trimmedValue = value.trim();
|
|
11
|
-
const numValue = parseInt(trimmedValue, 10);
|
|
12
|
-
if (!isNaN(numValue) && Number.isFinite(numValue)) {
|
|
13
|
-
if (numValue.toString() === trimmedValue) {
|
|
14
|
-
return `${numValue}px`;
|
|
15
|
-
}
|
|
16
|
-
else {
|
|
17
|
-
return value;
|
|
18
|
-
}
|
|
19
|
-
}
|
|
20
|
-
return null;
|
|
21
|
-
}
|
|
22
|
-
return null;
|
|
23
|
-
};
|
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
/**-----------------------------------------------------------------------------------------
|
|
2
|
-
* Copyright © 2026 Progress Software Corporation. All rights reserved.
|
|
3
|
-
* Licensed under commercial license. See LICENSE.md in the project root for more information
|
|
4
|
-
*-------------------------------------------------------------------------------------------*/
|
|
5
|
-
import { Injectable, EventEmitter } from '@angular/core';
|
|
6
|
-
import { isDocumentAvailable } from './is-document-available';
|
|
7
|
-
import * as i0 from "@angular/core";
|
|
8
|
-
const canCreateElement = () => isDocumentAvailable() && document.createElement;
|
|
9
|
-
const propName = '--kendo-scrollbar-width';
|
|
10
|
-
/**
|
|
11
|
-
* @hidden
|
|
12
|
-
*/
|
|
13
|
-
export const scrollbarWidth = () => {
|
|
14
|
-
let scrollbarWidth = 0;
|
|
15
|
-
if (canCreateElement()) {
|
|
16
|
-
const div = document.createElement('div');
|
|
17
|
-
div.style.cssText = 'overflow:scroll;overflow-x:hidden;zoom:1;clear:both;display:block';
|
|
18
|
-
div.innerHTML = ' ';
|
|
19
|
-
document.body.appendChild(div);
|
|
20
|
-
scrollbarWidth = div.offsetWidth - div.scrollWidth;
|
|
21
|
-
document.body.removeChild(div);
|
|
22
|
-
}
|
|
23
|
-
return scrollbarWidth;
|
|
24
|
-
};
|
|
25
|
-
/**
|
|
26
|
-
* @hidden
|
|
27
|
-
*/
|
|
28
|
-
export class ScrollbarWidthService {
|
|
29
|
-
changes = new EventEmitter();
|
|
30
|
-
constructor() {
|
|
31
|
-
if (typeof window !== 'undefined' && isDocumentAvailable()) {
|
|
32
|
-
document.body.style.setProperty(propName, `${scrollbarWidth()}px`);
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: ScrollbarWidthService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
36
|
-
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: ScrollbarWidthService, providedIn: 'root' });
|
|
37
|
-
}
|
|
38
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: ScrollbarWidthService, decorators: [{
|
|
39
|
-
type: Injectable,
|
|
40
|
-
args: [{
|
|
41
|
-
providedIn: 'root'
|
|
42
|
-
}]
|
|
43
|
-
}], ctorParameters: () => [] });
|
package/esm2022/utils/setter.mjs
DELETED
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
/**-----------------------------------------------------------------------------------------
|
|
2
|
-
* Copyright © 2026 Progress Software Corporation. All rights reserved.
|
|
3
|
-
* Licensed under commercial license. See LICENSE.md in the project root for more information
|
|
4
|
-
*-------------------------------------------------------------------------------------------*/
|
|
5
|
-
const FIELD_REGEX = /\[(?:(\d+)|['"](.*?)['"])\]|((?:(?!\[.*?\]|\.).)+)/g;
|
|
6
|
-
const setterCache = {};
|
|
7
|
-
setterCache['undefined'] = (obj) => obj;
|
|
8
|
-
/**
|
|
9
|
-
* @hidden
|
|
10
|
-
*/
|
|
11
|
-
export function setter(field) {
|
|
12
|
-
if (setterCache[field]) {
|
|
13
|
-
return setterCache[field];
|
|
14
|
-
}
|
|
15
|
-
const fields = [];
|
|
16
|
-
field.replace(FIELD_REGEX, function (_match, index, indexAccessor, fieldName) {
|
|
17
|
-
fields.push(index !== undefined ? index : (indexAccessor || fieldName));
|
|
18
|
-
});
|
|
19
|
-
setterCache[field] = function (obj, value) {
|
|
20
|
-
let root = obj;
|
|
21
|
-
const depth = fields.length - 1;
|
|
22
|
-
for (let idx = 0; idx < depth && root; idx++) {
|
|
23
|
-
root = root[fields[idx]] = root[fields[idx]] || {};
|
|
24
|
-
}
|
|
25
|
-
root[fields[depth]] = value;
|
|
26
|
-
};
|
|
27
|
-
return setterCache[field];
|
|
28
|
-
}
|
package/esm2022/utils.mjs
DELETED
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
/**-----------------------------------------------------------------------------------------
|
|
2
|
-
* Copyright © 2026 Progress Software Corporation. All rights reserved.
|
|
3
|
-
* Licensed under commercial license. See LICENSE.md in the project root for more information
|
|
4
|
-
*-------------------------------------------------------------------------------------------*/
|
|
5
|
-
export { isDocumentAvailable } from './utils/is-document-available';
|
|
6
|
-
export { isChanged } from './utils/is-changed';
|
|
7
|
-
export { anyChanged } from './utils/any-changed';
|
|
8
|
-
export { hasObservers } from './utils/has-observers';
|
|
9
|
-
export { guid } from './utils/guid';
|
|
10
|
-
export { isSafari, isFirefox, firefoxMaxHeight } from './utils/detect-browser';
|
|
11
|
-
export * from './utils/html-attributes';
|
|
12
|
-
export { isControlRequired } from './utils/forms-utils';
|
|
13
|
-
export { areObjectsEqual } from './utils/objects-equal';
|
|
14
|
-
export { processCssValue } from './utils/process-css-value';
|
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
/**-----------------------------------------------------------------------------------------
|
|
2
|
-
* Copyright © 2026 Progress Software Corporation. All rights reserved.
|
|
3
|
-
* Licensed under commercial license. See LICENSE.md in the project root for more information
|
|
4
|
-
*-------------------------------------------------------------------------------------------*/
|
|
5
|
-
export { WatermarkOverlayComponent } from './watermark.component';
|
|
6
|
-
export { shouldShowValidationUI, getLicenseMessage } from './validation';
|
|
@@ -1,58 +0,0 @@
|
|
|
1
|
-
/**-----------------------------------------------------------------------------------------
|
|
2
|
-
* Copyright © 2026 Progress Software Corporation. All rights reserved.
|
|
3
|
-
* Licensed under commercial license. See LICENSE.md in the project root for more information
|
|
4
|
-
*-------------------------------------------------------------------------------------------*/
|
|
5
|
-
/**
|
|
6
|
-
* @hidden
|
|
7
|
-
*/
|
|
8
|
-
export const watermarkStyles = `
|
|
9
|
-
position: absolute;
|
|
10
|
-
width: 100%;
|
|
11
|
-
height: 100%;
|
|
12
|
-
top: 0;
|
|
13
|
-
left: 0;
|
|
14
|
-
right: 0;
|
|
15
|
-
bottom: 0;
|
|
16
|
-
opacity: 0.2;
|
|
17
|
-
zIndex: 101;
|
|
18
|
-
pointerEvents: none;
|
|
19
|
-
backgroundImage: url('');
|
|
20
|
-
`;
|
|
21
|
-
/**
|
|
22
|
-
* @hidden
|
|
23
|
-
*/
|
|
24
|
-
export const bannerStyles = {
|
|
25
|
-
display: 'flex',
|
|
26
|
-
justifyContent: 'center',
|
|
27
|
-
alignItems: 'center',
|
|
28
|
-
position: 'fixed',
|
|
29
|
-
top: '16px',
|
|
30
|
-
right: '16px',
|
|
31
|
-
padding: '12px',
|
|
32
|
-
borderRadius: '4px',
|
|
33
|
-
boxShadow: '0px 4px 5px 0px rgba(0, 0, 0, 0.04), 0px 2px 4px 0px rgba(0, 0, 0, 0.03)',
|
|
34
|
-
fontSize: '14px',
|
|
35
|
-
fontWeight: 400,
|
|
36
|
-
lineHeight: '20px',
|
|
37
|
-
backgroundColor: '#FFC000',
|
|
38
|
-
color: '#1E1E1E',
|
|
39
|
-
zIndex: 20000
|
|
40
|
-
};
|
|
41
|
-
/**
|
|
42
|
-
* @hidden
|
|
43
|
-
*/
|
|
44
|
-
export const buttonStyles = {
|
|
45
|
-
display: 'inline-flex',
|
|
46
|
-
position: 'relative',
|
|
47
|
-
border: 'none',
|
|
48
|
-
borderRadius: '4px',
|
|
49
|
-
padding: '5px',
|
|
50
|
-
backgroundColor: 'transparent',
|
|
51
|
-
transition: 'color 0.2s ease-in-out',
|
|
52
|
-
outline: 'none',
|
|
53
|
-
cursor: 'pointer'
|
|
54
|
-
};
|
|
55
|
-
/**
|
|
56
|
-
* @hidden
|
|
57
|
-
*/
|
|
58
|
-
export const licenseKeyUrl = 'https://www.telerik.com/kendo-angular-ui/components/my-license/?utm_medium=product&utm_source=kendoangular&utm_campaign=kendo-ui-angular-purchase-license-keys-banner';
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
/**-----------------------------------------------------------------------------------------
|
|
2
|
-
* Copyright © 2026 Progress Software Corporation. All rights reserved.
|
|
3
|
-
* Licensed under commercial license. See LICENSE.md in the project root for more information
|
|
4
|
-
*-------------------------------------------------------------------------------------------*/
|
|
5
|
-
import { getLicenseStatus } from "@progress/kendo-licensing";
|
|
6
|
-
const allowed = ['telerik.com', 'progress.com', 'stackblitz.io', 'csb.app'];
|
|
7
|
-
/**
|
|
8
|
-
* @hidden
|
|
9
|
-
*/
|
|
10
|
-
export function shouldShowValidationUI(isPackageValid) {
|
|
11
|
-
const skip = allowed.some((hostname) => globalThis.document?.location.hostname.endsWith(hostname));
|
|
12
|
-
return !skip && !isPackageValid;
|
|
13
|
-
}
|
|
14
|
-
/**
|
|
15
|
-
* @hidden
|
|
16
|
-
*
|
|
17
|
-
* Returns the notification message to display, if any.
|
|
18
|
-
*/
|
|
19
|
-
export function getLicenseMessage(meta) {
|
|
20
|
-
const message = getLicenseStatus(meta).message;
|
|
21
|
-
return message?.notificationMessage;
|
|
22
|
-
}
|
|
@@ -1,116 +0,0 @@
|
|
|
1
|
-
/**-----------------------------------------------------------------------------------------
|
|
2
|
-
* Copyright © 2026 Progress Software Corporation. All rights reserved.
|
|
3
|
-
* Licensed under commercial license. See LICENSE.md in the project root for more information
|
|
4
|
-
*-------------------------------------------------------------------------------------------*/
|
|
5
|
-
import { Component, ElementRef, HostBinding, Input, ViewChild } from '@angular/core';
|
|
6
|
-
import { watermarkStyles, bannerStyles, licenseKeyUrl, buttonStyles } from './utils';
|
|
7
|
-
import { isDocumentAvailable } from '../utils';
|
|
8
|
-
import { NgStyle } from '@angular/common';
|
|
9
|
-
import * as i0 from "@angular/core";
|
|
10
|
-
let bannerPresentOnPage = false;
|
|
11
|
-
/**
|
|
12
|
-
* @hidden
|
|
13
|
-
*/
|
|
14
|
-
export class WatermarkOverlayComponent {
|
|
15
|
-
watermarkStyle = watermarkStyles;
|
|
16
|
-
licenseMessage;
|
|
17
|
-
banner;
|
|
18
|
-
isOpen = true;
|
|
19
|
-
bannerMounted = false;
|
|
20
|
-
bannerStyles = bannerStyles;
|
|
21
|
-
buttonStyles = buttonStyles;
|
|
22
|
-
licenseKeyUrl = licenseKeyUrl;
|
|
23
|
-
ngOnInit() {
|
|
24
|
-
if (!bannerPresentOnPage) {
|
|
25
|
-
this.bannerMounted = true;
|
|
26
|
-
bannerPresentOnPage = true;
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
ngAfterViewInit() {
|
|
30
|
-
if (this.isBannerRendered) {
|
|
31
|
-
document.body.appendChild(this.banner.nativeElement);
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
ngOnDestroy() {
|
|
35
|
-
if (this.isBannerRendered) {
|
|
36
|
-
document.body.removeChild(this.banner.nativeElement);
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
closeBanner() {
|
|
40
|
-
this.isOpen = false;
|
|
41
|
-
}
|
|
42
|
-
get isBannerRendered() {
|
|
43
|
-
return isDocumentAvailable() && !!this.banner?.nativeElement;
|
|
44
|
-
}
|
|
45
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: WatermarkOverlayComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
46
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: WatermarkOverlayComponent, isStandalone: true, selector: "div[kendoWatermarkOverlay]", inputs: { licenseMessage: "licenseMessage" }, host: { properties: { "style": "this.watermarkStyle" } }, viewQueries: [{ propertyName: "banner", first: true, predicate: ["banner"], descendants: true }], ngImport: i0, template: `
|
|
47
|
-
@if (isOpen && bannerMounted) {
|
|
48
|
-
<div #banner [ngStyle]="bannerStyles">
|
|
49
|
-
<span [ngStyle]="{ display: 'flex', alignSelf: 'center', marginRight: '8px' }">
|
|
50
|
-
<svg width="16" height="16" viewBox="0 0 16 16" fill="none">
|
|
51
|
-
<path fill-rule="evenodd" clip-rule="evenodd" d="M8 1L0 15H16L8 1ZM7 6V11H9V6H7ZM7 14V12H9V14H7Z" fill="#1E1E1E"/>
|
|
52
|
-
</svg>
|
|
53
|
-
</span>
|
|
54
|
-
@if (licenseMessage) {
|
|
55
|
-
<span [innerHtml]="licenseMessage"></span>
|
|
56
|
-
}
|
|
57
|
-
@if (!licenseMessage) {
|
|
58
|
-
<span>
|
|
59
|
-
We couldn't verify your <a [href]="licenseKeyUrl">license key</a> for Kendo UI for Angular. Please see the browser
|
|
60
|
-
console for details and resolution steps.
|
|
61
|
-
</span>
|
|
62
|
-
}
|
|
63
|
-
<div [ngStyle]="{ display: 'flex', alignItems: 'center', marginLeft: '24px' }">
|
|
64
|
-
<button title='Close' [ngStyle]="buttonStyles" (click)="closeBanner()">
|
|
65
|
-
<svg width="16" height="16" viewBox="0 0 16 16" fill="none">
|
|
66
|
-
<path d="M13 4.41562L9.41563 8L13 11.5844L11.5844 13L8 9.41563L4.41562 13L3 11.5844L6.58437 8L3 4.41562L4.41562 3L8 6.58437L11.5844 3L13 4.41562Z" fill="#1E1E1E"/>
|
|
67
|
-
</svg>
|
|
68
|
-
</button>
|
|
69
|
-
</div>
|
|
70
|
-
</div>
|
|
71
|
-
}
|
|
72
|
-
`, isInline: true, dependencies: [{ kind: "directive", type: NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
|
|
73
|
-
}
|
|
74
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: WatermarkOverlayComponent, decorators: [{
|
|
75
|
-
type: Component,
|
|
76
|
-
args: [{
|
|
77
|
-
selector: 'div[kendoWatermarkOverlay]',
|
|
78
|
-
template: `
|
|
79
|
-
@if (isOpen && bannerMounted) {
|
|
80
|
-
<div #banner [ngStyle]="bannerStyles">
|
|
81
|
-
<span [ngStyle]="{ display: 'flex', alignSelf: 'center', marginRight: '8px' }">
|
|
82
|
-
<svg width="16" height="16" viewBox="0 0 16 16" fill="none">
|
|
83
|
-
<path fill-rule="evenodd" clip-rule="evenodd" d="M8 1L0 15H16L8 1ZM7 6V11H9V6H7ZM7 14V12H9V14H7Z" fill="#1E1E1E"/>
|
|
84
|
-
</svg>
|
|
85
|
-
</span>
|
|
86
|
-
@if (licenseMessage) {
|
|
87
|
-
<span [innerHtml]="licenseMessage"></span>
|
|
88
|
-
}
|
|
89
|
-
@if (!licenseMessage) {
|
|
90
|
-
<span>
|
|
91
|
-
We couldn't verify your <a [href]="licenseKeyUrl">license key</a> for Kendo UI for Angular. Please see the browser
|
|
92
|
-
console for details and resolution steps.
|
|
93
|
-
</span>
|
|
94
|
-
}
|
|
95
|
-
<div [ngStyle]="{ display: 'flex', alignItems: 'center', marginLeft: '24px' }">
|
|
96
|
-
<button title='Close' [ngStyle]="buttonStyles" (click)="closeBanner()">
|
|
97
|
-
<svg width="16" height="16" viewBox="0 0 16 16" fill="none">
|
|
98
|
-
<path d="M13 4.41562L9.41563 8L13 11.5844L11.5844 13L8 9.41563L4.41562 13L3 11.5844L6.58437 8L3 4.41562L4.41562 3L8 6.58437L11.5844 3L13 4.41562Z" fill="#1E1E1E"/>
|
|
99
|
-
</svg>
|
|
100
|
-
</button>
|
|
101
|
-
</div>
|
|
102
|
-
</div>
|
|
103
|
-
}
|
|
104
|
-
`,
|
|
105
|
-
standalone: true,
|
|
106
|
-
imports: [NgStyle]
|
|
107
|
-
}]
|
|
108
|
-
}], propDecorators: { watermarkStyle: [{
|
|
109
|
-
type: HostBinding,
|
|
110
|
-
args: ['style']
|
|
111
|
-
}], licenseMessage: [{
|
|
112
|
-
type: Input
|
|
113
|
-
}], banner: [{
|
|
114
|
-
type: ViewChild,
|
|
115
|
-
args: ['banner']
|
|
116
|
-
}] } });
|