@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, ViewChild, HostBinding, Optional, isDevMode } from '@angular/core';
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
- bannerStyles = bannerStyles;
1104
- buttonStyles = buttonStyles;
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 (!bannerPresentOnPage) {
1108
- this.bannerMounted = true;
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
- @if (isOpen && bannerMounted) {
1131
- <div #banner [ngStyle]="bannerStyles">
1132
- <span [ngStyle]="{ display: 'flex', alignSelf: 'center', marginRight: '8px' }">
1133
- <svg width="16" height="16" viewBox="0 0 16 16" fill="none">
1134
- <path fill-rule="evenodd" clip-rule="evenodd" d="M8 1L0 15H16L8 1ZM7 6V11H9V6H7ZM7 14V12H9V14H7Z" fill="#1E1E1E"/>
1135
- </svg>
1136
- </span>
1137
- @if (licenseMessage) {
1138
- <span [innerHtml]="licenseMessage"></span>
1139
- }
1140
- @if (!licenseMessage) {
1141
- <span>
1142
- We couldn't verify your <a [href]="licenseKeyUrl">license key</a> for Kendo UI for Angular. Please see the browser
1143
- console for details and resolution steps.
1144
- </span>
1145
- }
1146
- <div [ngStyle]="{ display: 'flex', alignItems: 'center', marginLeft: '24px' }">
1147
- <button title='Close' [ngStyle]="buttonStyles" (click)="closeBanner()">
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
- </button>
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
- `, isInline: true, dependencies: [{ kind: "directive", type: NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
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
- @if (isOpen && bannerMounted) {
1163
- <div #banner [ngStyle]="bannerStyles">
1164
- <span [ngStyle]="{ display: 'flex', alignSelf: 'center', marginRight: '8px' }">
1165
- <svg width="16" height="16" viewBox="0 0 16 16" fill="none">
1166
- <path fill-rule="evenodd" clip-rule="evenodd" d="M8 1L0 15H16L8 1ZM7 6V11H9V6H7ZM7 14V12H9V14H7Z" fill="#1E1E1E"/>
1167
- </svg>
1168
- </span>
1169
- @if (licenseMessage) {
1170
- <span [innerHtml]="licenseMessage"></span>
1171
- }
1172
- @if (!licenseMessage) {
1173
- <span>
1174
- We couldn't verify your <a [href]="licenseKeyUrl">license key</a> for Kendo UI for Angular. Please see the browser
1175
- console for details and resolution steps.
1176
- </span>
1177
- }
1178
- <div [ngStyle]="{ display: 'flex', alignItems: 'center', marginLeft: '24px' }">
1179
- <button title='Close' [ngStyle]="buttonStyles" (click)="closeBanner()">
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
- </button>
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: { watermarkStyle: [{
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 message = getLicenseStatus(meta).message;
1216
- return message?.notificationMessage;
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.7",
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.7"
26
+ "@progress/kendo-angular-schematics": "22.1.0-develop.9"
27
27
  },
28
28
  "publishConfig": {
29
29
  "access": "public"
@@ -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): string | undefined;
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
- watermarkStyle: string;
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
- bannerStyles: {
17
- display: string;
18
- justifyContent: string;
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
  }