@cqa-lib/cqa-ui 1.0.53 → 1.0.55

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.
@@ -43,59 +43,75 @@ export class TailwindOverlayContainer extends OverlayContainer {
43
43
  // Also check immediately in case overlays already exist
44
44
  requestAnimationFrame(() => this.updateContainerClass());
45
45
  }
46
- isElementVisible(element) {
46
+ isElementClosing(element) {
47
+ // Check if element is closing (very low opacity AND shrinking dimensions)
47
48
  const style = window.getComputedStyle(element);
48
- // Check if element is visible (not display: none, not opacity: 0, not visibility: hidden)
49
- const isDisplayed = style.display !== 'none';
50
- const isOpaque = parseFloat(style.opacity) > 0.01; // Allow for very small opacity values during animations
51
- const isVisible = style.visibility !== 'hidden';
52
- // Also check if element has dimensions (width/height > 0)
49
+ const opacity = parseFloat(style.opacity);
53
50
  const rect = element.getBoundingClientRect();
54
- const hasSize = rect.width > 0 && rect.height > 0;
55
- return isDisplayed && isOpaque && isVisible && hasSize;
51
+ // If opacity is very low (< 0.1) AND dimensions are very small, it's likely closing
52
+ // This helps filter out closing animations while allowing opening animations
53
+ return opacity < 0.1 && (rect.width < 10 || rect.height < 10);
56
54
  }
57
55
  updateContainerClass() {
58
56
  if (!this._containerElement)
59
57
  return;
60
58
  // Count library overlays (dialogs, select panels, datepicker panels)
61
- // Only count overlays that are actually visible/active (not hidden or closing)
62
- // Library dialogs - check visibility
59
+ // Count them if they exist in DOM (even during opening animations)
60
+ // But exclude them if they're clearly closing (very low opacity + small size)
61
+ // Library dialogs - count if not closing
63
62
  const libraryDialogs = Array.from(this._containerElement.querySelectorAll('.cqa-dialog-panel'));
64
- const visibleLibraryDialogs = libraryDialogs.filter(dialog => this.isElementVisible(dialog)).length;
65
- // Library backdrops - check visibility (backdrops can be transparent but still present)
63
+ const activeLibraryDialogs = libraryDialogs.filter(dialog => {
64
+ const style = window.getComputedStyle(dialog);
65
+ return style.display !== 'none' && !this.isElementClosing(dialog);
66
+ }).length;
67
+ // Library backdrops - check if showing (backdrops can be transparent but still present)
66
68
  const libraryBackdrops = Array.from(this._containerElement.querySelectorAll('.cqa-dialog-backdrop'));
67
- const visibleLibraryBackdrops = libraryBackdrops.filter(backdrop => {
68
- // Backdrops might have low opacity but should still be considered if they're showing
69
+ const activeLibraryBackdrops = libraryBackdrops.filter(backdrop => {
69
70
  const style = window.getComputedStyle(backdrop);
71
+ // Backdrop is active if it's showing (has the showing class) and not display: none
70
72
  return style.display !== 'none' && backdrop.classList.contains('cdk-overlay-backdrop-showing');
71
73
  }).length;
72
- // Select panels - check visibility
74
+ // Select panels - count if not closing
73
75
  const selectPanels = Array.from(this._containerElement.querySelectorAll('.ctc-select-panel'));
74
- const visibleSelectPanels = selectPanels.filter(panel => this.isElementVisible(panel)).length;
75
- // Date panels - check visibility
76
+ const activeSelectPanels = selectPanels.filter(panel => {
77
+ const style = window.getComputedStyle(panel);
78
+ return style.display !== 'none' && !this.isElementClosing(panel);
79
+ }).length;
80
+ // Date panels - count if not closing
76
81
  const datePanels = Array.from(this._containerElement.querySelectorAll('.ctc-date-range-panel'));
77
- const visibleDatePanels = datePanels.filter(panel => this.isElementVisible(panel)).length;
78
- const totalLibraryOverlays = visibleLibraryDialogs + visibleLibraryBackdrops + visibleSelectPanels + visibleDatePanels;
82
+ const activeDatePanels = datePanels.filter(panel => {
83
+ const style = window.getComputedStyle(panel);
84
+ return style.display !== 'none' && !this.isElementClosing(panel);
85
+ }).length;
86
+ const totalLibraryOverlays = activeLibraryDialogs + activeLibraryBackdrops + activeSelectPanels + activeDatePanels;
79
87
  // Check for portal Material dialogs (those without .cqa-dialog-panel class)
80
88
  // Portal dialogs use .mat-dialog-container but NOT .cqa-dialog-panel
89
+ // Only count visible portal dialogs to avoid false positives
81
90
  const portalDialogs = Array.from(this._containerElement.querySelectorAll('.mat-dialog-container:not(.cqa-dialog-panel)'));
82
- const visiblePortalDialogs = portalDialogs.filter(dialog => this.isElementVisible(dialog)).length;
83
- // Decision logic: Only add cqa-ui-root when VISIBLE library overlays are present
84
- // This ensures portal Material dialogs don't get affected by library CSS
85
- // even if library overlays are in the DOM but closing/hidden
91
+ const visiblePortalDialogs = portalDialogs.filter(dialog => {
92
+ const style = window.getComputedStyle(dialog);
93
+ const rect = dialog.getBoundingClientRect();
94
+ return style.display !== 'none' &&
95
+ parseFloat(style.opacity) > 0.1 &&
96
+ rect.width > 0 &&
97
+ rect.height > 0;
98
+ }).length;
99
+ // Decision logic: Add cqa-ui-root when library overlays are present (even during opening animations)
100
+ // Remove it only when library overlays are clearly gone or closing
101
+ // This ensures library overlays get styles immediately, while portal dialogs don't get affected
86
102
  if (totalLibraryOverlays > 0) {
87
- // Visible library overlays exist - add the class (they need Tailwind styles scoped to .cqa-ui-root)
103
+ // Library overlays exist - add the class (they need Tailwind styles scoped to .cqa-ui-root)
88
104
  this._containerElement.classList.add('cqa-ui-root');
89
105
  }
90
106
  else {
91
- // No visible library overlays exist - remove the class
107
+ // No active library overlays exist - remove the class
92
108
  // This handles:
93
109
  // 1. Only portal dialogs exist (should not have cqa-ui-root)
94
- // 2. Library overlays are closing/hidden (should not have cqa-ui-root)
110
+ // 2. Library overlays are closing/closed (should not have cqa-ui-root)
95
111
  // 3. No overlays exist at all (clean state)
96
112
  this._containerElement.classList.remove('cqa-ui-root');
97
113
  }
98
- // Note: If both library overlays and portal dialogs exist simultaneously and are visible,
114
+ // Note: If both library overlays and portal dialogs exist simultaneously,
99
115
  // the class will be present because library overlays need it. In this case,
100
116
  // portal dialogs may be affected by library CSS. To avoid this, ensure library
101
117
  // overlays are closed before opening portal dialogs, or use CSS specificity
@@ -107,4 +123,4 @@ TailwindOverlayContainer.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0
107
123
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: TailwindOverlayContainer, decorators: [{
108
124
  type: Injectable
109
125
  }] });
110
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tw-overlay-container.js","sourceRoot":"","sources":["../../../../../src/lib/utils/tw-overlay-container.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { OverlayContainer } from '@angular/cdk/overlay';\n\n/**\n * Ensures Angular CDK overlay content (e.g., MatSelect, Datepicker panels, library dialogs)\n * is nested under an element with class=\"cqa-ui-root\" so Tailwind utilities\n * configured with important: '.cqa-ui-root' are applied inside overlays.\n * \n * IMPORTANT: Only sets class=\"cqa-ui-root\" when library overlays are present.\n * Portal Material dialogs should NOT have this class to prevent library CSS from affecting them.\n */\n@Injectable()\nexport class TailwindOverlayContainer extends OverlayContainer {\n  private updateTimeout: number | null = null;\n\n  protected override _createContainer(): void {\n    super._createContainer();\n    if (this._containerElement) {\n      // Don't set class initially - we'll set it dynamically when library overlays are created\n      this._containerElement.classList.remove('cqa-ui-root');\n      \n      // Use MutationObserver to detect when library overlays are created/destroyed\n      this.observeLibraryOverlays();\n    }\n  }\n\n  private observeLibraryOverlays(): void {\n    if (!this._containerElement) return;\n\n    const observer = new MutationObserver(() => {\n      // Debounce updates to avoid excessive checks during rapid DOM changes\n      if (this.updateTimeout !== null) {\n        cancelAnimationFrame(this.updateTimeout);\n      }\n      this.updateTimeout = requestAnimationFrame(() => {\n        this.updateContainerClass();\n        this.updateTimeout = null;\n      });\n    });\n\n    observer.observe(this._containerElement, {\n      childList: true,\n      subtree: true,\n    });\n\n    // Also check immediately in case overlays already exist\n    requestAnimationFrame(() => this.updateContainerClass());\n  }\n\n  private isElementVisible(element: Element): boolean {\n    const style = window.getComputedStyle(element);\n    // Check if element is visible (not display: none, not opacity: 0, not visibility: hidden)\n    const isDisplayed = style.display !== 'none';\n    const isOpaque = parseFloat(style.opacity) > 0.01; // Allow for very small opacity values during animations\n    const isVisible = style.visibility !== 'hidden';\n    \n    // Also check if element has dimensions (width/height > 0)\n    const rect = element.getBoundingClientRect();\n    const hasSize = rect.width > 0 && rect.height > 0;\n    \n    return isDisplayed && isOpaque && isVisible && hasSize;\n  }\n\n  private updateContainerClass(): void {\n    if (!this._containerElement) return;\n\n    // Count library overlays (dialogs, select panels, datepicker panels)\n    // Only count overlays that are actually visible/active (not hidden or closing)\n    \n    // Library dialogs - check visibility\n    const libraryDialogs = Array.from(this._containerElement.querySelectorAll('.cqa-dialog-panel'));\n    const visibleLibraryDialogs = libraryDialogs.filter(dialog => this.isElementVisible(dialog)).length;\n    \n    // Library backdrops - check visibility (backdrops can be transparent but still present)\n    const libraryBackdrops = Array.from(this._containerElement.querySelectorAll('.cqa-dialog-backdrop'));\n    const visibleLibraryBackdrops = libraryBackdrops.filter(backdrop => {\n      // Backdrops might have low opacity but should still be considered if they're showing\n      const style = window.getComputedStyle(backdrop);\n      return style.display !== 'none' && backdrop.classList.contains('cdk-overlay-backdrop-showing');\n    }).length;\n    \n    // Select panels - check visibility\n    const selectPanels = Array.from(this._containerElement.querySelectorAll('.ctc-select-panel'));\n    const visibleSelectPanels = selectPanels.filter(panel => this.isElementVisible(panel)).length;\n    \n    // Date panels - check visibility\n    const datePanels = Array.from(this._containerElement.querySelectorAll('.ctc-date-range-panel'));\n    const visibleDatePanels = datePanels.filter(panel => this.isElementVisible(panel)).length;\n    \n    const totalLibraryOverlays = visibleLibraryDialogs + visibleLibraryBackdrops + visibleSelectPanels + visibleDatePanels;\n    \n    // Check for portal Material dialogs (those without .cqa-dialog-panel class)\n    // Portal dialogs use .mat-dialog-container but NOT .cqa-dialog-panel\n    const portalDialogs = Array.from(this._containerElement.querySelectorAll('.mat-dialog-container:not(.cqa-dialog-panel)'));\n    const visiblePortalDialogs = portalDialogs.filter(dialog => this.isElementVisible(dialog)).length;\n\n    // Decision logic: Only add cqa-ui-root when VISIBLE library overlays are present\n    // This ensures portal Material dialogs don't get affected by library CSS\n    // even if library overlays are in the DOM but closing/hidden\n    \n    if (totalLibraryOverlays > 0) {\n      // Visible library overlays exist - add the class (they need Tailwind styles scoped to .cqa-ui-root)\n      this._containerElement.classList.add('cqa-ui-root');\n    } else {\n      // No visible library overlays exist - remove the class\n      // This handles:\n      // 1. Only portal dialogs exist (should not have cqa-ui-root)\n      // 2. Library overlays are closing/hidden (should not have cqa-ui-root)\n      // 3. No overlays exist at all (clean state)\n      this._containerElement.classList.remove('cqa-ui-root');\n    }\n    \n    // Note: If both library overlays and portal dialogs exist simultaneously and are visible,\n    // the class will be present because library overlays need it. In this case,\n    // portal dialogs may be affected by library CSS. To avoid this, ensure library\n    // overlays are closed before opening portal dialogs, or use CSS specificity\n    // to override library styles within portal dialogs.\n  }\n}\n\n\n"]}
126
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tw-overlay-container.js","sourceRoot":"","sources":["../../../../../src/lib/utils/tw-overlay-container.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { OverlayContainer } from '@angular/cdk/overlay';\n\n/**\n * Ensures Angular CDK overlay content (e.g., MatSelect, Datepicker panels, library dialogs)\n * is nested under an element with class=\"cqa-ui-root\" so Tailwind utilities\n * configured with important: '.cqa-ui-root' are applied inside overlays.\n * \n * IMPORTANT: Only sets class=\"cqa-ui-root\" when library overlays are present.\n * Portal Material dialogs should NOT have this class to prevent library CSS from affecting them.\n */\n@Injectable()\nexport class TailwindOverlayContainer extends OverlayContainer {\n  private updateTimeout: number | null = null;\n\n  protected override _createContainer(): void {\n    super._createContainer();\n    if (this._containerElement) {\n      // Don't set class initially - we'll set it dynamically when library overlays are created\n      this._containerElement.classList.remove('cqa-ui-root');\n      \n      // Use MutationObserver to detect when library overlays are created/destroyed\n      this.observeLibraryOverlays();\n    }\n  }\n\n  private observeLibraryOverlays(): void {\n    if (!this._containerElement) return;\n\n    const observer = new MutationObserver(() => {\n      // Debounce updates to avoid excessive checks during rapid DOM changes\n      if (this.updateTimeout !== null) {\n        cancelAnimationFrame(this.updateTimeout);\n      }\n      this.updateTimeout = requestAnimationFrame(() => {\n        this.updateContainerClass();\n        this.updateTimeout = null;\n      });\n    });\n\n    observer.observe(this._containerElement, {\n      childList: true,\n      subtree: true,\n    });\n\n    // Also check immediately in case overlays already exist\n    requestAnimationFrame(() => this.updateContainerClass());\n  }\n\n  private isElementClosing(element: Element): boolean {\n    // Check if element is closing (very low opacity AND shrinking dimensions)\n    const style = window.getComputedStyle(element);\n    const opacity = parseFloat(style.opacity);\n    const rect = element.getBoundingClientRect();\n    \n    // If opacity is very low (< 0.1) AND dimensions are very small, it's likely closing\n    // This helps filter out closing animations while allowing opening animations\n    return opacity < 0.1 && (rect.width < 10 || rect.height < 10);\n  }\n\n  private updateContainerClass(): void {\n    if (!this._containerElement) return;\n\n    // Count library overlays (dialogs, select panels, datepicker panels)\n    // Count them if they exist in DOM (even during opening animations)\n    // But exclude them if they're clearly closing (very low opacity + small size)\n    \n    // Library dialogs - count if not closing\n    const libraryDialogs = Array.from(this._containerElement.querySelectorAll('.cqa-dialog-panel'));\n    const activeLibraryDialogs = libraryDialogs.filter(dialog => {\n      const style = window.getComputedStyle(dialog);\n      return style.display !== 'none' && !this.isElementClosing(dialog);\n    }).length;\n    \n    // Library backdrops - check if showing (backdrops can be transparent but still present)\n    const libraryBackdrops = Array.from(this._containerElement.querySelectorAll('.cqa-dialog-backdrop'));\n    const activeLibraryBackdrops = libraryBackdrops.filter(backdrop => {\n      const style = window.getComputedStyle(backdrop);\n      // Backdrop is active if it's showing (has the showing class) and not display: none\n      return style.display !== 'none' && backdrop.classList.contains('cdk-overlay-backdrop-showing');\n    }).length;\n    \n    // Select panels - count if not closing\n    const selectPanels = Array.from(this._containerElement.querySelectorAll('.ctc-select-panel'));\n    const activeSelectPanels = selectPanels.filter(panel => {\n      const style = window.getComputedStyle(panel);\n      return style.display !== 'none' && !this.isElementClosing(panel);\n    }).length;\n    \n    // Date panels - count if not closing\n    const datePanels = Array.from(this._containerElement.querySelectorAll('.ctc-date-range-panel'));\n    const activeDatePanels = datePanels.filter(panel => {\n      const style = window.getComputedStyle(panel);\n      return style.display !== 'none' && !this.isElementClosing(panel);\n    }).length;\n    \n    const totalLibraryOverlays = activeLibraryDialogs + activeLibraryBackdrops + activeSelectPanels + activeDatePanels;\n    \n    // Check for portal Material dialogs (those without .cqa-dialog-panel class)\n    // Portal dialogs use .mat-dialog-container but NOT .cqa-dialog-panel\n    // Only count visible portal dialogs to avoid false positives\n    const portalDialogs = Array.from(this._containerElement.querySelectorAll('.mat-dialog-container:not(.cqa-dialog-panel)'));\n    const visiblePortalDialogs = portalDialogs.filter(dialog => {\n      const style = window.getComputedStyle(dialog);\n      const rect = dialog.getBoundingClientRect();\n      return style.display !== 'none' && \n             parseFloat(style.opacity) > 0.1 && \n             rect.width > 0 && \n             rect.height > 0;\n    }).length;\n\n    // Decision logic: Add cqa-ui-root when library overlays are present (even during opening animations)\n    // Remove it only when library overlays are clearly gone or closing\n    // This ensures library overlays get styles immediately, while portal dialogs don't get affected\n    \n    if (totalLibraryOverlays > 0) {\n      // Library overlays exist - add the class (they need Tailwind styles scoped to .cqa-ui-root)\n      this._containerElement.classList.add('cqa-ui-root');\n    } else {\n      // No active library overlays exist - remove the class\n      // This handles:\n      // 1. Only portal dialogs exist (should not have cqa-ui-root)\n      // 2. Library overlays are closing/closed (should not have cqa-ui-root)\n      // 3. No overlays exist at all (clean state)\n      this._containerElement.classList.remove('cqa-ui-root');\n    }\n    \n    // Note: If both library overlays and portal dialogs exist simultaneously,\n    // the class will be present because library overlays need it. In this case,\n    // portal dialogs may be affected by library CSS. To avoid this, ensure library\n    // overlays are closed before opening portal dialogs, or use CSS specificity\n    // to override library styles within portal dialogs.\n  }\n}\n\n\n"]}
@@ -4255,59 +4255,75 @@ class TailwindOverlayContainer extends OverlayContainer {
4255
4255
  // Also check immediately in case overlays already exist
4256
4256
  requestAnimationFrame(() => this.updateContainerClass());
4257
4257
  }
4258
- isElementVisible(element) {
4258
+ isElementClosing(element) {
4259
+ // Check if element is closing (very low opacity AND shrinking dimensions)
4259
4260
  const style = window.getComputedStyle(element);
4260
- // Check if element is visible (not display: none, not opacity: 0, not visibility: hidden)
4261
- const isDisplayed = style.display !== 'none';
4262
- const isOpaque = parseFloat(style.opacity) > 0.01; // Allow for very small opacity values during animations
4263
- const isVisible = style.visibility !== 'hidden';
4264
- // Also check if element has dimensions (width/height > 0)
4261
+ const opacity = parseFloat(style.opacity);
4265
4262
  const rect = element.getBoundingClientRect();
4266
- const hasSize = rect.width > 0 && rect.height > 0;
4267
- return isDisplayed && isOpaque && isVisible && hasSize;
4263
+ // If opacity is very low (< 0.1) AND dimensions are very small, it's likely closing
4264
+ // This helps filter out closing animations while allowing opening animations
4265
+ return opacity < 0.1 && (rect.width < 10 || rect.height < 10);
4268
4266
  }
4269
4267
  updateContainerClass() {
4270
4268
  if (!this._containerElement)
4271
4269
  return;
4272
4270
  // Count library overlays (dialogs, select panels, datepicker panels)
4273
- // Only count overlays that are actually visible/active (not hidden or closing)
4274
- // Library dialogs - check visibility
4271
+ // Count them if they exist in DOM (even during opening animations)
4272
+ // But exclude them if they're clearly closing (very low opacity + small size)
4273
+ // Library dialogs - count if not closing
4275
4274
  const libraryDialogs = Array.from(this._containerElement.querySelectorAll('.cqa-dialog-panel'));
4276
- const visibleLibraryDialogs = libraryDialogs.filter(dialog => this.isElementVisible(dialog)).length;
4277
- // Library backdrops - check visibility (backdrops can be transparent but still present)
4275
+ const activeLibraryDialogs = libraryDialogs.filter(dialog => {
4276
+ const style = window.getComputedStyle(dialog);
4277
+ return style.display !== 'none' && !this.isElementClosing(dialog);
4278
+ }).length;
4279
+ // Library backdrops - check if showing (backdrops can be transparent but still present)
4278
4280
  const libraryBackdrops = Array.from(this._containerElement.querySelectorAll('.cqa-dialog-backdrop'));
4279
- const visibleLibraryBackdrops = libraryBackdrops.filter(backdrop => {
4280
- // Backdrops might have low opacity but should still be considered if they're showing
4281
+ const activeLibraryBackdrops = libraryBackdrops.filter(backdrop => {
4281
4282
  const style = window.getComputedStyle(backdrop);
4283
+ // Backdrop is active if it's showing (has the showing class) and not display: none
4282
4284
  return style.display !== 'none' && backdrop.classList.contains('cdk-overlay-backdrop-showing');
4283
4285
  }).length;
4284
- // Select panels - check visibility
4286
+ // Select panels - count if not closing
4285
4287
  const selectPanels = Array.from(this._containerElement.querySelectorAll('.ctc-select-panel'));
4286
- const visibleSelectPanels = selectPanels.filter(panel => this.isElementVisible(panel)).length;
4287
- // Date panels - check visibility
4288
+ const activeSelectPanels = selectPanels.filter(panel => {
4289
+ const style = window.getComputedStyle(panel);
4290
+ return style.display !== 'none' && !this.isElementClosing(panel);
4291
+ }).length;
4292
+ // Date panels - count if not closing
4288
4293
  const datePanels = Array.from(this._containerElement.querySelectorAll('.ctc-date-range-panel'));
4289
- const visibleDatePanels = datePanels.filter(panel => this.isElementVisible(panel)).length;
4290
- const totalLibraryOverlays = visibleLibraryDialogs + visibleLibraryBackdrops + visibleSelectPanels + visibleDatePanels;
4294
+ const activeDatePanels = datePanels.filter(panel => {
4295
+ const style = window.getComputedStyle(panel);
4296
+ return style.display !== 'none' && !this.isElementClosing(panel);
4297
+ }).length;
4298
+ const totalLibraryOverlays = activeLibraryDialogs + activeLibraryBackdrops + activeSelectPanels + activeDatePanels;
4291
4299
  // Check for portal Material dialogs (those without .cqa-dialog-panel class)
4292
4300
  // Portal dialogs use .mat-dialog-container but NOT .cqa-dialog-panel
4301
+ // Only count visible portal dialogs to avoid false positives
4293
4302
  const portalDialogs = Array.from(this._containerElement.querySelectorAll('.mat-dialog-container:not(.cqa-dialog-panel)'));
4294
- const visiblePortalDialogs = portalDialogs.filter(dialog => this.isElementVisible(dialog)).length;
4295
- // Decision logic: Only add cqa-ui-root when VISIBLE library overlays are present
4296
- // This ensures portal Material dialogs don't get affected by library CSS
4297
- // even if library overlays are in the DOM but closing/hidden
4303
+ const visiblePortalDialogs = portalDialogs.filter(dialog => {
4304
+ const style = window.getComputedStyle(dialog);
4305
+ const rect = dialog.getBoundingClientRect();
4306
+ return style.display !== 'none' &&
4307
+ parseFloat(style.opacity) > 0.1 &&
4308
+ rect.width > 0 &&
4309
+ rect.height > 0;
4310
+ }).length;
4311
+ // Decision logic: Add cqa-ui-root when library overlays are present (even during opening animations)
4312
+ // Remove it only when library overlays are clearly gone or closing
4313
+ // This ensures library overlays get styles immediately, while portal dialogs don't get affected
4298
4314
  if (totalLibraryOverlays > 0) {
4299
- // Visible library overlays exist - add the class (they need Tailwind styles scoped to .cqa-ui-root)
4315
+ // Library overlays exist - add the class (they need Tailwind styles scoped to .cqa-ui-root)
4300
4316
  this._containerElement.classList.add('cqa-ui-root');
4301
4317
  }
4302
4318
  else {
4303
- // No visible library overlays exist - remove the class
4319
+ // No active library overlays exist - remove the class
4304
4320
  // This handles:
4305
4321
  // 1. Only portal dialogs exist (should not have cqa-ui-root)
4306
- // 2. Library overlays are closing/hidden (should not have cqa-ui-root)
4322
+ // 2. Library overlays are closing/closed (should not have cqa-ui-root)
4307
4323
  // 3. No overlays exist at all (clean state)
4308
4324
  this._containerElement.classList.remove('cqa-ui-root');
4309
4325
  }
4310
- // Note: If both library overlays and portal dialogs exist simultaneously and are visible,
4326
+ // Note: If both library overlays and portal dialogs exist simultaneously,
4311
4327
  // the class will be present because library overlays need it. In this case,
4312
4328
  // portal dialogs may be affected by library CSS. To avoid this, ensure library
4313
4329
  // overlays are closed before opening portal dialogs, or use CSS specificity