@progress/kendo-angular-common 22.1.0-develop.7 → 22.1.0-develop.9
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.
|
@@ -3,13 +3,13 @@
|
|
|
3
3
|
* Licensed under commercial license. See LICENSE.md in the project root for more information
|
|
4
4
|
*-------------------------------------------------------------------------------------------*/
|
|
5
5
|
import * as i0 from '@angular/core';
|
|
6
|
-
import { EventEmitter, Output, Input, Directive, Injectable, Component,
|
|
6
|
+
import { EventEmitter, Output, Input, Directive, Injectable, Component, HostBinding, ViewChild, Optional, isDevMode } from '@angular/core';
|
|
7
7
|
import { detectDesktopBrowser, detectMobileOS } from '@progress/kendo-common';
|
|
8
8
|
import { take, auditTime } from 'rxjs/operators';
|
|
9
9
|
import { Draggable } from '@progress/kendo-draggable';
|
|
10
10
|
import { merge, fromEvent, from, Subscription } from 'rxjs';
|
|
11
|
-
import { NgStyle } from '@angular/common';
|
|
12
|
-
import { getLicenseStatus } from '@progress/kendo-licensing';
|
|
11
|
+
import { NgStyle, NgTemplateOutlet } from '@angular/common';
|
|
12
|
+
import { registerLicenseMessage, getLicenseStatus } from '@progress/kendo-licensing';
|
|
13
13
|
|
|
14
14
|
/**
|
|
15
15
|
* @hidden
|
|
@@ -1051,40 +1051,6 @@ const watermarkStyles = `
|
|
|
1051
1051
|
pointerEvents: none;
|
|
1052
1052
|
backgroundImage: url('');
|
|
1053
1053
|
`;
|
|
1054
|
-
/**
|
|
1055
|
-
* @hidden
|
|
1056
|
-
*/
|
|
1057
|
-
const bannerStyles = {
|
|
1058
|
-
display: 'flex',
|
|
1059
|
-
justifyContent: 'center',
|
|
1060
|
-
alignItems: 'center',
|
|
1061
|
-
position: 'fixed',
|
|
1062
|
-
top: '16px',
|
|
1063
|
-
right: '16px',
|
|
1064
|
-
padding: '12px',
|
|
1065
|
-
borderRadius: '4px',
|
|
1066
|
-
boxShadow: '0px 4px 5px 0px rgba(0, 0, 0, 0.04), 0px 2px 4px 0px rgba(0, 0, 0, 0.03)',
|
|
1067
|
-
fontSize: '14px',
|
|
1068
|
-
fontWeight: 400,
|
|
1069
|
-
lineHeight: '20px',
|
|
1070
|
-
backgroundColor: '#FFC000',
|
|
1071
|
-
color: '#1E1E1E',
|
|
1072
|
-
zIndex: 20000
|
|
1073
|
-
};
|
|
1074
|
-
/**
|
|
1075
|
-
* @hidden
|
|
1076
|
-
*/
|
|
1077
|
-
const buttonStyles = {
|
|
1078
|
-
display: 'inline-flex',
|
|
1079
|
-
position: 'relative',
|
|
1080
|
-
border: 'none',
|
|
1081
|
-
borderRadius: '4px',
|
|
1082
|
-
padding: '5px',
|
|
1083
|
-
backgroundColor: 'transparent',
|
|
1084
|
-
transition: 'color 0.2s ease-in-out',
|
|
1085
|
-
outline: 'none',
|
|
1086
|
-
cursor: 'pointer'
|
|
1087
|
-
};
|
|
1088
1054
|
/**
|
|
1089
1055
|
* @hidden
|
|
1090
1056
|
*/
|
|
@@ -1095,19 +1061,45 @@ let bannerPresentOnPage = false;
|
|
|
1095
1061
|
* @hidden
|
|
1096
1062
|
*/
|
|
1097
1063
|
class WatermarkOverlayComponent {
|
|
1098
|
-
watermarkStyle = watermarkStyles;
|
|
1099
1064
|
licenseMessage;
|
|
1100
1065
|
banner;
|
|
1066
|
+
watermarkStyle = watermarkStyles;
|
|
1101
1067
|
isOpen = true;
|
|
1068
|
+
isMobile = false;
|
|
1069
|
+
isNarrow = false;
|
|
1070
|
+
isCloseHovered = false;
|
|
1102
1071
|
bannerMounted = false;
|
|
1103
|
-
|
|
1104
|
-
|
|
1072
|
+
get messages() {
|
|
1073
|
+
return [
|
|
1074
|
+
this.primaryMessage, ...this.extraMessages
|
|
1075
|
+
];
|
|
1076
|
+
}
|
|
1077
|
+
extraMessages = [];
|
|
1078
|
+
get primaryMessage() {
|
|
1079
|
+
return this.licenseMessage || {
|
|
1080
|
+
severity: 'ERROR',
|
|
1081
|
+
productName: '',
|
|
1082
|
+
code: '',
|
|
1083
|
+
message: '',
|
|
1084
|
+
notificationTitle: 'License key missing for Kendo UI for Angular.',
|
|
1085
|
+
notificationBody: `We couldn't verify your <a href="${this.licenseKeyUrl}">license key</a> for Kendo UI for Angular.` +
|
|
1086
|
+
`Please see the browser console for details and resolution steps.`
|
|
1087
|
+
};
|
|
1088
|
+
}
|
|
1105
1089
|
licenseKeyUrl = licenseKeyUrl;
|
|
1090
|
+
unsubscribeLicenseMessage = () => {
|
|
1091
|
+
/* noop */
|
|
1092
|
+
};
|
|
1093
|
+
unsubscribeResize = () => {
|
|
1094
|
+
/* noop */
|
|
1095
|
+
};
|
|
1106
1096
|
ngOnInit() {
|
|
1107
|
-
if (!
|
|
1108
|
-
|
|
1109
|
-
bannerPresentOnPage = true;
|
|
1097
|
+
if (bannerPresentOnPage || !this.licenseMessage) {
|
|
1098
|
+
return;
|
|
1110
1099
|
}
|
|
1100
|
+
this.subscribeLicenseMessage();
|
|
1101
|
+
this.subscribeResize();
|
|
1102
|
+
bannerPresentOnPage = true;
|
|
1111
1103
|
}
|
|
1112
1104
|
ngAfterViewInit() {
|
|
1113
1105
|
if (this.isBannerRendered) {
|
|
@@ -1115,6 +1107,8 @@ class WatermarkOverlayComponent {
|
|
|
1115
1107
|
}
|
|
1116
1108
|
}
|
|
1117
1109
|
ngOnDestroy() {
|
|
1110
|
+
this.unsubscribeLicenseMessage();
|
|
1111
|
+
this.unsubscribeResize();
|
|
1118
1112
|
if (this.isBannerRendered) {
|
|
1119
1113
|
document.body.removeChild(this.banner.nativeElement);
|
|
1120
1114
|
}
|
|
@@ -1125,77 +1119,318 @@ class WatermarkOverlayComponent {
|
|
|
1125
1119
|
get isBannerRendered() {
|
|
1126
1120
|
return isDocumentAvailable() && !!this.banner?.nativeElement;
|
|
1127
1121
|
}
|
|
1122
|
+
subscribeLicenseMessage() {
|
|
1123
|
+
this.unsubscribeLicenseMessage = registerLicenseMessage(this.licenseMessage, 'KENDOUIANGULAR', ({ message }) => {
|
|
1124
|
+
// Add messages from other suites
|
|
1125
|
+
this.extraMessages.push(message);
|
|
1126
|
+
}, () => {
|
|
1127
|
+
// Show our own message dialog
|
|
1128
|
+
this.bannerMounted = true;
|
|
1129
|
+
});
|
|
1130
|
+
}
|
|
1131
|
+
subscribeResize() {
|
|
1132
|
+
const handleResize = () => {
|
|
1133
|
+
this.isMobile = window.innerWidth < 500;
|
|
1134
|
+
this.isNarrow = window.innerWidth < 768;
|
|
1135
|
+
};
|
|
1136
|
+
window.addEventListener('resize', handleResize);
|
|
1137
|
+
this.unsubscribeResize = () => window.removeEventListener('resize', handleResize);
|
|
1138
|
+
}
|
|
1139
|
+
// Used in tests to reset the static presence check flag
|
|
1140
|
+
resetPresenceCheck() {
|
|
1141
|
+
bannerPresentOnPage = false;
|
|
1142
|
+
}
|
|
1128
1143
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.18", ngImport: i0, type: WatermarkOverlayComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
1129
1144
|
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.18", 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: `
|
|
1130
|
-
|
|
1131
|
-
|
|
1132
|
-
|
|
1133
|
-
|
|
1134
|
-
|
|
1135
|
-
|
|
1136
|
-
|
|
1137
|
-
|
|
1138
|
-
|
|
1139
|
-
|
|
1140
|
-
|
|
1141
|
-
|
|
1142
|
-
|
|
1143
|
-
|
|
1144
|
-
|
|
1145
|
-
|
|
1146
|
-
|
|
1147
|
-
|
|
1148
|
-
<svg width="16" height="16" viewBox="0 0 16 16" fill="none">
|
|
1149
|
-
<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"/>
|
|
1145
|
+
<ng-template #buttonTemplate>
|
|
1146
|
+
<button [ngStyle]="{
|
|
1147
|
+
backgroundColor: isCloseHovered ? '#3d3d3d14' : 'transparent',
|
|
1148
|
+
border: 'none',
|
|
1149
|
+
borderRadius: '4px',
|
|
1150
|
+
cursor: 'pointer',
|
|
1151
|
+
display: 'flex',
|
|
1152
|
+
padding: '4px',
|
|
1153
|
+
position: isMobile ? 'absolute' : 'static',
|
|
1154
|
+
top: isMobile ? '12px' : 'auto',
|
|
1155
|
+
right: isMobile ? '12px' : 'auto',
|
|
1156
|
+
}"
|
|
1157
|
+
title="Close" (click)="closeBanner()" (mouseenter)="isCloseHovered = true" (mouseleave)="isCloseHovered = false">
|
|
1158
|
+
<svg width="20" height="20" viewBox="0 0 16 16" fill="none">
|
|
1159
|
+
<path
|
|
1160
|
+
d="M11.9309 3.1838C12.1754 2.93933 12.5712 2.93937 12.8157 3.1838C13.0601 3.4283 13.0601 3.82407 12.8157 4.06857L8.885 7.99923L12.8166 11.9309C13.0611 12.1754 13.0611 12.5721 12.8166 12.8166C12.5721 13.0611 12.1754 13.0611 11.9309 12.8166L7.99925 8.88497L4.06859 12.8166C3.8241 13.0611 3.42732 13.0611 3.18285 12.8166C2.93862 12.5721 2.93851 12.1753 3.18285 11.9309L7.11449 7.99923L3.18382 4.06857C2.93947 3.82413 2.93955 3.42829 3.18382 3.1838C3.42831 2.9393 3.82508 2.9393 4.06957 3.1838L7.99925 7.11349L11.9309 3.1838Z"
|
|
1161
|
+
fill="#212529"
|
|
1162
|
+
/>
|
|
1150
1163
|
</svg>
|
|
1151
|
-
|
|
1164
|
+
</button>
|
|
1165
|
+
</ng-template>
|
|
1166
|
+
@if (isOpen && bannerMounted) {
|
|
1167
|
+
<div #banner [ngStyle]="{
|
|
1168
|
+
position: 'fixed',
|
|
1169
|
+
top: isNarrow ? '0' : '16px',
|
|
1170
|
+
left: '50%',
|
|
1171
|
+
transform: 'translateX(-50%)',
|
|
1172
|
+
display: 'flex',
|
|
1173
|
+
flexDirection: isMobile ? 'column' : 'row',
|
|
1174
|
+
justifyContent: 'center',
|
|
1175
|
+
alignItems: isMobile ? 'flex-start' : 'center',
|
|
1176
|
+
borderRadius: isNarrow ? '0' : '6px',
|
|
1177
|
+
borderLeft: '6px solid #FFC000',
|
|
1178
|
+
borderTop: '1px solid #00000029',
|
|
1179
|
+
borderRight: '1px solid #00000029',
|
|
1180
|
+
borderBottom: '1px solid #00000029',
|
|
1181
|
+
boxSizing: 'border-box',
|
|
1182
|
+
fontSize: '14px',
|
|
1183
|
+
lineHeight: '20px',
|
|
1184
|
+
color: '#1E1E1E',
|
|
1185
|
+
zIndex: 2000,
|
|
1186
|
+
boxShadow: '0px 4px 5px 0px #0000000A, 0px 2px 4px 0px #00000008',
|
|
1187
|
+
maxWidth: isNarrow ? 'none' : '768px',
|
|
1188
|
+
width: '100%',
|
|
1189
|
+
backgroundColor: '#fff',
|
|
1190
|
+
padding: isMobile ? '12px' : '0',
|
|
1191
|
+
}">
|
|
1192
|
+
@if (isMobile) {
|
|
1193
|
+
<ng-container *ngTemplateOutlet="buttonTemplate"></ng-container>
|
|
1194
|
+
}
|
|
1195
|
+
|
|
1196
|
+
<span [ngStyle]="{
|
|
1197
|
+
display: 'flex',
|
|
1198
|
+
alignSelf: isMobile ? 'flex-start' : 'center',
|
|
1199
|
+
padding: isMobile ? '0 0 12px 0' : '9px 12px',
|
|
1200
|
+
}">
|
|
1201
|
+
<svg
|
|
1202
|
+
width="32"
|
|
1203
|
+
height="32"
|
|
1204
|
+
viewBox="0 0 32 32"
|
|
1205
|
+
fill="none"
|
|
1206
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
1207
|
+
>
|
|
1208
|
+
<path
|
|
1209
|
+
fillRule="evenodd"
|
|
1210
|
+
clipRule="evenodd"
|
|
1211
|
+
d="M22.702 2.1821C24.3149 2.51082 25.8077 3.27291 27.0199 4.38645C28.2321 5.49999 29.1179 6.92286 29.582 8.5021C30.012 9.9501 30.076 11.4821 29.768 12.9621C29.3228 14.9898 28.2025 16.8063 26.5904 18.1143C24.9783 19.4223 22.9699 20.1443 20.894 20.1621C20.018 20.1621 19.146 20.0361 18.308 19.7821L16.708 21.6581L15.95 22.0081H14V25.0081L13 26.0081H10V29.0081L9 30.0081H3L2 29.0081V24.3941L2.292 23.6881L12.24 13.7401C11.9577 12.8308 11.8226 11.8821 11.84 10.9301C11.8582 9.59817 12.1701 8.28666 12.7533 7.08907C13.3365 5.89147 14.1767 4.83728 15.214 4.00164C16.2514 3.166 17.4603 2.56949 18.7546 2.25464C20.0489 1.93978 21.3967 1.91633 22.702 2.1821ZM25.338 16.5821C26.5944 15.5647 27.4681 14.1509 27.816 12.5721L27.824 12.5821C28.0718 11.4277 28.0272 10.2297 27.6943 9.09691C27.3614 7.96412 26.7507 6.93248 25.9177 6.09572C25.0847 5.25896 24.0558 4.64361 22.9246 4.30557C21.7933 3.96753 20.5955 3.91753 19.44 4.1601C17.8816 4.506 16.4837 5.36334 15.4688 6.59561C14.454 7.82789 13.8806 9.36426 13.84 10.9601C13.82 11.8721 13.98 12.7761 14.318 13.6201L14.098 14.7061L4 24.8081V28.0081H8V25.0081L9 24.0081H12V21.0081L13 20.0081H15.49L17.242 17.9761L18.364 17.6961C19.1728 18.0121 20.0337 18.1736 20.902 18.1721C22.5181 18.1597 24.082 17.5991 25.338 16.5821ZM23.662 11.1181C23.8197 10.9002 23.9318 10.6527 23.9916 10.3905C24.0515 10.1283 24.0578 9.85665 24.0103 9.59192C23.9627 9.32718 23.8622 9.07476 23.7148 8.84975C23.5675 8.62474 23.3762 8.43177 23.1526 8.28238C22.9289 8.133 22.6774 8.03026 22.4131 7.98033C22.1488 7.93039 21.8771 7.93428 21.6144 7.99176C21.3516 8.04925 21.1031 8.15914 20.8838 8.31487C20.6645 8.4706 20.4789 8.66896 20.338 8.8981C20.067 9.33887 19.9774 9.86752 20.088 10.373C20.1985 10.8784 20.5007 11.3214 20.931 11.6087C21.3613 11.8961 21.8862 12.0055 22.3954 11.914C22.9047 11.8226 23.3587 11.5373 23.662 11.1181Z"
|
|
1212
|
+
fill="black"
|
|
1213
|
+
/>
|
|
1214
|
+
<path
|
|
1215
|
+
d="M23.1299 16.0186L31.1387 31.0273L31.0068 31.25H14.9932L14.8604 31.0273L22.8955 16.0186H23.1299Z"
|
|
1216
|
+
fill="#FFC000"
|
|
1217
|
+
stroke="black"
|
|
1218
|
+
strokeWidth="1.5"
|
|
1219
|
+
/>
|
|
1220
|
+
<rect x="22.25" y="21.2686" width="1.5" height="5" rx="0.75" fill="black" />
|
|
1221
|
+
<path
|
|
1222
|
+
d="M24 28.2686C24 27.7163 23.5523 27.2686 23 27.2686C22.4479 27.2687 22 27.7164 22 28.2686C22 28.8207 22.4479 29.2684 23 29.2686C23.5523 29.2686 24 28.8208 24 28.2686Z"
|
|
1223
|
+
fill="black"
|
|
1224
|
+
/>
|
|
1225
|
+
</svg>
|
|
1226
|
+
</span>
|
|
1227
|
+
|
|
1228
|
+
<div [ngStyle]="{
|
|
1229
|
+
display: 'flex',
|
|
1230
|
+
flexDirection: 'column',
|
|
1231
|
+
gap: '12px',
|
|
1232
|
+
padding: isMobile ? '0 0 12px 0' : '12px',
|
|
1233
|
+
flex: isMobile ? 'none' : '1'}">
|
|
1234
|
+
@for (msg of messages; track msg.message) {
|
|
1235
|
+
<div [ngStyle]="{
|
|
1236
|
+
display: 'flex',
|
|
1237
|
+
flexDirection: 'column',
|
|
1238
|
+
gap: '4px',
|
|
1239
|
+
flex: isMobile ? 'none' : '1'}">
|
|
1240
|
+
@if (msg.notificationTitle) {
|
|
1241
|
+
<span
|
|
1242
|
+
[ngStyle]="{
|
|
1243
|
+
fontFamily: 'system-ui, sans-serif',
|
|
1244
|
+
fontWeight: 700,
|
|
1245
|
+
fontSize: '14px',
|
|
1246
|
+
lineHeight: '142%'}"
|
|
1247
|
+
>
|
|
1248
|
+
{{ msg.notificationTitle }}
|
|
1249
|
+
</span>
|
|
1250
|
+
}
|
|
1251
|
+
<span
|
|
1252
|
+
[ngStyle]="{
|
|
1253
|
+
fontFamily: 'system-ui, sans-serif',
|
|
1254
|
+
fontSize: '14px',
|
|
1255
|
+
lineHeight: '20px',
|
|
1256
|
+
}"
|
|
1257
|
+
[innerHTML]="msg.notificationBody || msg.notificationMessage"
|
|
1258
|
+
>
|
|
1259
|
+
</span>
|
|
1260
|
+
</div>
|
|
1261
|
+
}
|
|
1262
|
+
</div>
|
|
1263
|
+
|
|
1264
|
+
@if (!isMobile) {
|
|
1265
|
+
<div
|
|
1266
|
+
[ngStyle]="{
|
|
1267
|
+
display: 'flex',
|
|
1268
|
+
alignItems: 'center',
|
|
1269
|
+
padding: isMobile ? '0' : '9px 12px',
|
|
1270
|
+
gap: '16px',
|
|
1271
|
+
marginLeft: isMobile ? '0' : 'auto',
|
|
1272
|
+
width: isMobile ? '100%' : 'auto',
|
|
1273
|
+
}"
|
|
1274
|
+
>
|
|
1275
|
+
<ng-container *ngTemplateOutlet="buttonTemplate"></ng-container>
|
|
1276
|
+
</div>
|
|
1277
|
+
}
|
|
1152
1278
|
</div>
|
|
1153
|
-
</div>
|
|
1154
1279
|
}
|
|
1155
|
-
|
|
1280
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }] });
|
|
1156
1281
|
}
|
|
1157
1282
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.18", ngImport: i0, type: WatermarkOverlayComponent, decorators: [{
|
|
1158
1283
|
type: Component,
|
|
1159
1284
|
args: [{
|
|
1160
1285
|
selector: 'div[kendoWatermarkOverlay]',
|
|
1161
1286
|
template: `
|
|
1162
|
-
|
|
1163
|
-
|
|
1164
|
-
|
|
1165
|
-
|
|
1166
|
-
|
|
1167
|
-
|
|
1168
|
-
|
|
1169
|
-
|
|
1170
|
-
|
|
1171
|
-
|
|
1172
|
-
|
|
1173
|
-
|
|
1174
|
-
|
|
1175
|
-
|
|
1176
|
-
|
|
1177
|
-
|
|
1178
|
-
|
|
1179
|
-
|
|
1180
|
-
<svg width="16" height="16" viewBox="0 0 16 16" fill="none">
|
|
1181
|
-
<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"/>
|
|
1287
|
+
<ng-template #buttonTemplate>
|
|
1288
|
+
<button [ngStyle]="{
|
|
1289
|
+
backgroundColor: isCloseHovered ? '#3d3d3d14' : 'transparent',
|
|
1290
|
+
border: 'none',
|
|
1291
|
+
borderRadius: '4px',
|
|
1292
|
+
cursor: 'pointer',
|
|
1293
|
+
display: 'flex',
|
|
1294
|
+
padding: '4px',
|
|
1295
|
+
position: isMobile ? 'absolute' : 'static',
|
|
1296
|
+
top: isMobile ? '12px' : 'auto',
|
|
1297
|
+
right: isMobile ? '12px' : 'auto',
|
|
1298
|
+
}"
|
|
1299
|
+
title="Close" (click)="closeBanner()" (mouseenter)="isCloseHovered = true" (mouseleave)="isCloseHovered = false">
|
|
1300
|
+
<svg width="20" height="20" viewBox="0 0 16 16" fill="none">
|
|
1301
|
+
<path
|
|
1302
|
+
d="M11.9309 3.1838C12.1754 2.93933 12.5712 2.93937 12.8157 3.1838C13.0601 3.4283 13.0601 3.82407 12.8157 4.06857L8.885 7.99923L12.8166 11.9309C13.0611 12.1754 13.0611 12.5721 12.8166 12.8166C12.5721 13.0611 12.1754 13.0611 11.9309 12.8166L7.99925 8.88497L4.06859 12.8166C3.8241 13.0611 3.42732 13.0611 3.18285 12.8166C2.93862 12.5721 2.93851 12.1753 3.18285 11.9309L7.11449 7.99923L3.18382 4.06857C2.93947 3.82413 2.93955 3.42829 3.18382 3.1838C3.42831 2.9393 3.82508 2.9393 4.06957 3.1838L7.99925 7.11349L11.9309 3.1838Z"
|
|
1303
|
+
fill="#212529"
|
|
1304
|
+
/>
|
|
1182
1305
|
</svg>
|
|
1183
|
-
|
|
1306
|
+
</button>
|
|
1307
|
+
</ng-template>
|
|
1308
|
+
@if (isOpen && bannerMounted) {
|
|
1309
|
+
<div #banner [ngStyle]="{
|
|
1310
|
+
position: 'fixed',
|
|
1311
|
+
top: isNarrow ? '0' : '16px',
|
|
1312
|
+
left: '50%',
|
|
1313
|
+
transform: 'translateX(-50%)',
|
|
1314
|
+
display: 'flex',
|
|
1315
|
+
flexDirection: isMobile ? 'column' : 'row',
|
|
1316
|
+
justifyContent: 'center',
|
|
1317
|
+
alignItems: isMobile ? 'flex-start' : 'center',
|
|
1318
|
+
borderRadius: isNarrow ? '0' : '6px',
|
|
1319
|
+
borderLeft: '6px solid #FFC000',
|
|
1320
|
+
borderTop: '1px solid #00000029',
|
|
1321
|
+
borderRight: '1px solid #00000029',
|
|
1322
|
+
borderBottom: '1px solid #00000029',
|
|
1323
|
+
boxSizing: 'border-box',
|
|
1324
|
+
fontSize: '14px',
|
|
1325
|
+
lineHeight: '20px',
|
|
1326
|
+
color: '#1E1E1E',
|
|
1327
|
+
zIndex: 2000,
|
|
1328
|
+
boxShadow: '0px 4px 5px 0px #0000000A, 0px 2px 4px 0px #00000008',
|
|
1329
|
+
maxWidth: isNarrow ? 'none' : '768px',
|
|
1330
|
+
width: '100%',
|
|
1331
|
+
backgroundColor: '#fff',
|
|
1332
|
+
padding: isMobile ? '12px' : '0',
|
|
1333
|
+
}">
|
|
1334
|
+
@if (isMobile) {
|
|
1335
|
+
<ng-container *ngTemplateOutlet="buttonTemplate"></ng-container>
|
|
1336
|
+
}
|
|
1337
|
+
|
|
1338
|
+
<span [ngStyle]="{
|
|
1339
|
+
display: 'flex',
|
|
1340
|
+
alignSelf: isMobile ? 'flex-start' : 'center',
|
|
1341
|
+
padding: isMobile ? '0 0 12px 0' : '9px 12px',
|
|
1342
|
+
}">
|
|
1343
|
+
<svg
|
|
1344
|
+
width="32"
|
|
1345
|
+
height="32"
|
|
1346
|
+
viewBox="0 0 32 32"
|
|
1347
|
+
fill="none"
|
|
1348
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
1349
|
+
>
|
|
1350
|
+
<path
|
|
1351
|
+
fillRule="evenodd"
|
|
1352
|
+
clipRule="evenodd"
|
|
1353
|
+
d="M22.702 2.1821C24.3149 2.51082 25.8077 3.27291 27.0199 4.38645C28.2321 5.49999 29.1179 6.92286 29.582 8.5021C30.012 9.9501 30.076 11.4821 29.768 12.9621C29.3228 14.9898 28.2025 16.8063 26.5904 18.1143C24.9783 19.4223 22.9699 20.1443 20.894 20.1621C20.018 20.1621 19.146 20.0361 18.308 19.7821L16.708 21.6581L15.95 22.0081H14V25.0081L13 26.0081H10V29.0081L9 30.0081H3L2 29.0081V24.3941L2.292 23.6881L12.24 13.7401C11.9577 12.8308 11.8226 11.8821 11.84 10.9301C11.8582 9.59817 12.1701 8.28666 12.7533 7.08907C13.3365 5.89147 14.1767 4.83728 15.214 4.00164C16.2514 3.166 17.4603 2.56949 18.7546 2.25464C20.0489 1.93978 21.3967 1.91633 22.702 2.1821ZM25.338 16.5821C26.5944 15.5647 27.4681 14.1509 27.816 12.5721L27.824 12.5821C28.0718 11.4277 28.0272 10.2297 27.6943 9.09691C27.3614 7.96412 26.7507 6.93248 25.9177 6.09572C25.0847 5.25896 24.0558 4.64361 22.9246 4.30557C21.7933 3.96753 20.5955 3.91753 19.44 4.1601C17.8816 4.506 16.4837 5.36334 15.4688 6.59561C14.454 7.82789 13.8806 9.36426 13.84 10.9601C13.82 11.8721 13.98 12.7761 14.318 13.6201L14.098 14.7061L4 24.8081V28.0081H8V25.0081L9 24.0081H12V21.0081L13 20.0081H15.49L17.242 17.9761L18.364 17.6961C19.1728 18.0121 20.0337 18.1736 20.902 18.1721C22.5181 18.1597 24.082 17.5991 25.338 16.5821ZM23.662 11.1181C23.8197 10.9002 23.9318 10.6527 23.9916 10.3905C24.0515 10.1283 24.0578 9.85665 24.0103 9.59192C23.9627 9.32718 23.8622 9.07476 23.7148 8.84975C23.5675 8.62474 23.3762 8.43177 23.1526 8.28238C22.9289 8.133 22.6774 8.03026 22.4131 7.98033C22.1488 7.93039 21.8771 7.93428 21.6144 7.99176C21.3516 8.04925 21.1031 8.15914 20.8838 8.31487C20.6645 8.4706 20.4789 8.66896 20.338 8.8981C20.067 9.33887 19.9774 9.86752 20.088 10.373C20.1985 10.8784 20.5007 11.3214 20.931 11.6087C21.3613 11.8961 21.8862 12.0055 22.3954 11.914C22.9047 11.8226 23.3587 11.5373 23.662 11.1181Z"
|
|
1354
|
+
fill="black"
|
|
1355
|
+
/>
|
|
1356
|
+
<path
|
|
1357
|
+
d="M23.1299 16.0186L31.1387 31.0273L31.0068 31.25H14.9932L14.8604 31.0273L22.8955 16.0186H23.1299Z"
|
|
1358
|
+
fill="#FFC000"
|
|
1359
|
+
stroke="black"
|
|
1360
|
+
strokeWidth="1.5"
|
|
1361
|
+
/>
|
|
1362
|
+
<rect x="22.25" y="21.2686" width="1.5" height="5" rx="0.75" fill="black" />
|
|
1363
|
+
<path
|
|
1364
|
+
d="M24 28.2686C24 27.7163 23.5523 27.2686 23 27.2686C22.4479 27.2687 22 27.7164 22 28.2686C22 28.8207 22.4479 29.2684 23 29.2686C23.5523 29.2686 24 28.8208 24 28.2686Z"
|
|
1365
|
+
fill="black"
|
|
1366
|
+
/>
|
|
1367
|
+
</svg>
|
|
1368
|
+
</span>
|
|
1369
|
+
|
|
1370
|
+
<div [ngStyle]="{
|
|
1371
|
+
display: 'flex',
|
|
1372
|
+
flexDirection: 'column',
|
|
1373
|
+
gap: '12px',
|
|
1374
|
+
padding: isMobile ? '0 0 12px 0' : '12px',
|
|
1375
|
+
flex: isMobile ? 'none' : '1'}">
|
|
1376
|
+
@for (msg of messages; track msg.message) {
|
|
1377
|
+
<div [ngStyle]="{
|
|
1378
|
+
display: 'flex',
|
|
1379
|
+
flexDirection: 'column',
|
|
1380
|
+
gap: '4px',
|
|
1381
|
+
flex: isMobile ? 'none' : '1'}">
|
|
1382
|
+
@if (msg.notificationTitle) {
|
|
1383
|
+
<span
|
|
1384
|
+
[ngStyle]="{
|
|
1385
|
+
fontFamily: 'system-ui, sans-serif',
|
|
1386
|
+
fontWeight: 700,
|
|
1387
|
+
fontSize: '14px',
|
|
1388
|
+
lineHeight: '142%'}"
|
|
1389
|
+
>
|
|
1390
|
+
{{ msg.notificationTitle }}
|
|
1391
|
+
</span>
|
|
1392
|
+
}
|
|
1393
|
+
<span
|
|
1394
|
+
[ngStyle]="{
|
|
1395
|
+
fontFamily: 'system-ui, sans-serif',
|
|
1396
|
+
fontSize: '14px',
|
|
1397
|
+
lineHeight: '20px',
|
|
1398
|
+
}"
|
|
1399
|
+
[innerHTML]="msg.notificationBody || msg.notificationMessage"
|
|
1400
|
+
>
|
|
1401
|
+
</span>
|
|
1402
|
+
</div>
|
|
1403
|
+
}
|
|
1404
|
+
</div>
|
|
1405
|
+
|
|
1406
|
+
@if (!isMobile) {
|
|
1407
|
+
<div
|
|
1408
|
+
[ngStyle]="{
|
|
1409
|
+
display: 'flex',
|
|
1410
|
+
alignItems: 'center',
|
|
1411
|
+
padding: isMobile ? '0' : '9px 12px',
|
|
1412
|
+
gap: '16px',
|
|
1413
|
+
marginLeft: isMobile ? '0' : 'auto',
|
|
1414
|
+
width: isMobile ? '100%' : 'auto',
|
|
1415
|
+
}"
|
|
1416
|
+
>
|
|
1417
|
+
<ng-container *ngTemplateOutlet="buttonTemplate"></ng-container>
|
|
1418
|
+
</div>
|
|
1419
|
+
}
|
|
1184
1420
|
</div>
|
|
1185
|
-
</div>
|
|
1186
1421
|
}
|
|
1187
|
-
|
|
1422
|
+
`,
|
|
1188
1423
|
standalone: true,
|
|
1189
|
-
imports: [NgStyle]
|
|
1424
|
+
imports: [NgStyle, NgTemplateOutlet]
|
|
1190
1425
|
}]
|
|
1191
|
-
}], propDecorators: {
|
|
1192
|
-
type: HostBinding,
|
|
1193
|
-
args: ['style']
|
|
1194
|
-
}], licenseMessage: [{
|
|
1426
|
+
}], propDecorators: { licenseMessage: [{
|
|
1195
1427
|
type: Input
|
|
1196
1428
|
}], banner: [{
|
|
1197
1429
|
type: ViewChild,
|
|
1198
1430
|
args: ['banner']
|
|
1431
|
+
}], watermarkStyle: [{
|
|
1432
|
+
type: HostBinding,
|
|
1433
|
+
args: ['style']
|
|
1199
1434
|
}] } });
|
|
1200
1435
|
|
|
1201
1436
|
const allowed = ['telerik.com', 'progress.com', 'stackblitz.io', 'csb.app'];
|
|
@@ -1212,8 +1447,8 @@ function shouldShowValidationUI(isPackageValid) {
|
|
|
1212
1447
|
* Returns the notification message to display, if any.
|
|
1213
1448
|
*/
|
|
1214
1449
|
function getLicenseMessage(meta) {
|
|
1215
|
-
const
|
|
1216
|
-
return message
|
|
1450
|
+
const status = getLicenseStatus(meta);
|
|
1451
|
+
return status?.message;
|
|
1217
1452
|
}
|
|
1218
1453
|
|
|
1219
1454
|
/**
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@progress/kendo-angular-common",
|
|
3
|
-
"version": "22.1.0-develop.
|
|
3
|
+
"version": "22.1.0-develop.9",
|
|
4
4
|
"description": "Kendo UI for Angular - Utility Package",
|
|
5
5
|
"license": "SEE LICENSE IN LICENSE.md",
|
|
6
6
|
"author": "Progress",
|
|
@@ -23,7 +23,7 @@
|
|
|
23
23
|
"@progress/kendo-common": "^1.0.1",
|
|
24
24
|
"@progress/kendo-draggable": "^3.0.2",
|
|
25
25
|
"tslib": "^2.3.1",
|
|
26
|
-
"@progress/kendo-angular-schematics": "22.1.0-develop.
|
|
26
|
+
"@progress/kendo-angular-schematics": "22.1.0-develop.9"
|
|
27
27
|
},
|
|
28
28
|
"publishConfig": {
|
|
29
29
|
"access": "public"
|
package/watermark/utils.d.ts
CHANGED
|
@@ -6,40 +6,6 @@
|
|
|
6
6
|
* @hidden
|
|
7
7
|
*/
|
|
8
8
|
export declare const watermarkStyles = "\n position: absolute;\n width: 100%;\n height: 100%;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n opacity: 0.2;\n zIndex: 101;\n pointerEvents: none;\n backgroundImage: url('');\n";
|
|
9
|
-
/**
|
|
10
|
-
* @hidden
|
|
11
|
-
*/
|
|
12
|
-
export declare const bannerStyles: {
|
|
13
|
-
display: string;
|
|
14
|
-
justifyContent: string;
|
|
15
|
-
alignItems: string;
|
|
16
|
-
position: string;
|
|
17
|
-
top: string;
|
|
18
|
-
right: string;
|
|
19
|
-
padding: string;
|
|
20
|
-
borderRadius: string;
|
|
21
|
-
boxShadow: string;
|
|
22
|
-
fontSize: string;
|
|
23
|
-
fontWeight: number;
|
|
24
|
-
lineHeight: string;
|
|
25
|
-
backgroundColor: string;
|
|
26
|
-
color: string;
|
|
27
|
-
zIndex: number;
|
|
28
|
-
};
|
|
29
|
-
/**
|
|
30
|
-
* @hidden
|
|
31
|
-
*/
|
|
32
|
-
export declare const buttonStyles: {
|
|
33
|
-
display: string;
|
|
34
|
-
position: string;
|
|
35
|
-
border: string;
|
|
36
|
-
borderRadius: string;
|
|
37
|
-
padding: string;
|
|
38
|
-
backgroundColor: string;
|
|
39
|
-
transition: string;
|
|
40
|
-
outline: string;
|
|
41
|
-
cursor: string;
|
|
42
|
-
};
|
|
43
9
|
/**
|
|
44
10
|
* @hidden
|
|
45
11
|
*/
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
* Copyright © 2026 Progress Software Corporation. All rights reserved.
|
|
3
3
|
* Licensed under commercial license. See LICENSE.md in the project root for more information
|
|
4
4
|
*-------------------------------------------------------------------------------------------*/
|
|
5
|
-
import { PackageMetadata } from "@progress/kendo-licensing";
|
|
5
|
+
import { LicenseMessage, PackageMetadata } from "@progress/kendo-licensing";
|
|
6
6
|
/**
|
|
7
7
|
* @hidden
|
|
8
8
|
*/
|
|
@@ -12,4 +12,4 @@ export declare function shouldShowValidationUI(isPackageValid: boolean): boolean
|
|
|
12
12
|
*
|
|
13
13
|
* Returns the notification message to display, if any.
|
|
14
14
|
*/
|
|
15
|
-
export declare function getLicenseMessage(meta: PackageMetadata):
|
|
15
|
+
export declare function getLicenseMessage(meta: PackageMetadata): LicenseMessage | undefined;
|
|
@@ -3,50 +3,34 @@
|
|
|
3
3
|
* Licensed under commercial license. See LICENSE.md in the project root for more information
|
|
4
4
|
*-------------------------------------------------------------------------------------------*/
|
|
5
5
|
import { AfterViewInit, ElementRef, OnDestroy, OnInit } from '@angular/core';
|
|
6
|
+
import { LicenseMessage } from '@progress/kendo-licensing';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
/**
|
|
8
9
|
* @hidden
|
|
9
10
|
*/
|
|
10
11
|
export declare class WatermarkOverlayComponent implements OnInit, AfterViewInit, OnDestroy {
|
|
11
|
-
|
|
12
|
-
licenseMessage?: string;
|
|
12
|
+
licenseMessage?: LicenseMessage;
|
|
13
13
|
banner: ElementRef;
|
|
14
|
+
watermarkStyle: string;
|
|
14
15
|
isOpen: boolean;
|
|
16
|
+
isMobile: boolean;
|
|
17
|
+
isNarrow: boolean;
|
|
18
|
+
isCloseHovered: boolean;
|
|
15
19
|
bannerMounted: boolean;
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
alignItems: string;
|
|
20
|
-
position: string;
|
|
21
|
-
top: string;
|
|
22
|
-
right: string;
|
|
23
|
-
padding: string;
|
|
24
|
-
borderRadius: string;
|
|
25
|
-
boxShadow: string;
|
|
26
|
-
fontSize: string;
|
|
27
|
-
fontWeight: number;
|
|
28
|
-
lineHeight: string;
|
|
29
|
-
backgroundColor: string;
|
|
30
|
-
color: string;
|
|
31
|
-
zIndex: number;
|
|
32
|
-
};
|
|
33
|
-
buttonStyles: {
|
|
34
|
-
display: string;
|
|
35
|
-
position: string;
|
|
36
|
-
border: string;
|
|
37
|
-
borderRadius: string;
|
|
38
|
-
padding: string;
|
|
39
|
-
backgroundColor: string;
|
|
40
|
-
transition: string;
|
|
41
|
-
outline: string;
|
|
42
|
-
cursor: string;
|
|
43
|
-
};
|
|
20
|
+
get messages(): LicenseMessage[];
|
|
21
|
+
extraMessages: LicenseMessage[];
|
|
22
|
+
get primaryMessage(): LicenseMessage;
|
|
44
23
|
licenseKeyUrl: string;
|
|
24
|
+
private unsubscribeLicenseMessage;
|
|
25
|
+
private unsubscribeResize;
|
|
45
26
|
ngOnInit(): void;
|
|
46
27
|
ngAfterViewInit(): void;
|
|
47
28
|
ngOnDestroy(): void;
|
|
48
29
|
closeBanner(): void;
|
|
49
30
|
get isBannerRendered(): boolean;
|
|
31
|
+
private subscribeLicenseMessage;
|
|
32
|
+
private subscribeResize;
|
|
33
|
+
resetPresenceCheck(): void;
|
|
50
34
|
static ɵfac: i0.ɵɵFactoryDeclaration<WatermarkOverlayComponent, never>;
|
|
51
35
|
static ɵcmp: i0.ɵɵComponentDeclaration<WatermarkOverlayComponent, "div[kendoWatermarkOverlay]", never, { "licenseMessage": { "alias": "licenseMessage"; "required": false; }; }, {}, never, never, true, never>;
|
|
52
36
|
}
|