@acorex/cdk 20.2.59 → 20.3.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.
|
@@ -0,0 +1,185 @@
|
|
|
1
|
+
import * as i0 from '@angular/core';
|
|
2
|
+
import { signal, output, inject, Renderer2, ElementRef, effect, untracked, Directive } from '@angular/core';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Fullscreen directive that provides CSS-based fullscreen functionality
|
|
6
|
+
* Usage: <element axFullscreen #fullscreen="axFullscreen"></element>
|
|
7
|
+
* Then: fullscreen.toggle() or fullscreen.enter() or fullscreen.exit()
|
|
8
|
+
*/
|
|
9
|
+
class AXFullScreenDirective {
|
|
10
|
+
constructor() {
|
|
11
|
+
/**
|
|
12
|
+
* Current fullscreen state
|
|
13
|
+
*/
|
|
14
|
+
this.isFullscreenState = signal(false, ...(ngDevMode ? [{ debugName: "isFullscreenState" }] : []));
|
|
15
|
+
/**
|
|
16
|
+
* Original element styles to restore
|
|
17
|
+
*/
|
|
18
|
+
this.originalStyles = {};
|
|
19
|
+
/**
|
|
20
|
+
* Original parent element reference
|
|
21
|
+
*/
|
|
22
|
+
this.originalParent = null;
|
|
23
|
+
/**
|
|
24
|
+
* Fullscreen container element
|
|
25
|
+
*/
|
|
26
|
+
this.fullscreenContainer = null;
|
|
27
|
+
/**
|
|
28
|
+
* Fullscreen change event
|
|
29
|
+
*/
|
|
30
|
+
this.fullscreenChange = output();
|
|
31
|
+
this.renderer = inject(Renderer2);
|
|
32
|
+
this.elementRef = inject(ElementRef);
|
|
33
|
+
// Sync state changes to output
|
|
34
|
+
effect(() => {
|
|
35
|
+
const isFullscreen = this.isFullscreenState();
|
|
36
|
+
untracked(() => {
|
|
37
|
+
this.fullscreenChange.emit(isFullscreen);
|
|
38
|
+
});
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* Toggle fullscreen state
|
|
43
|
+
*/
|
|
44
|
+
toggle() {
|
|
45
|
+
if (this.isFullscreenState()) {
|
|
46
|
+
this.exit();
|
|
47
|
+
}
|
|
48
|
+
else {
|
|
49
|
+
this.enter();
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
/**
|
|
53
|
+
* Enter fullscreen mode using CSS
|
|
54
|
+
*/
|
|
55
|
+
enter() {
|
|
56
|
+
if (this.isFullscreenState()) {
|
|
57
|
+
return;
|
|
58
|
+
}
|
|
59
|
+
const element = this.elementRef.nativeElement;
|
|
60
|
+
try {
|
|
61
|
+
// Store original styles and parent
|
|
62
|
+
this.storeOriginalStyles(element);
|
|
63
|
+
this.originalParent = element.parentElement;
|
|
64
|
+
// Create fullscreen container
|
|
65
|
+
this.fullscreenContainer = this.renderer.createElement('div');
|
|
66
|
+
this.renderer.setStyle(this.fullscreenContainer, 'position', 'fixed');
|
|
67
|
+
this.renderer.setStyle(this.fullscreenContainer, 'top', '0');
|
|
68
|
+
this.renderer.setStyle(this.fullscreenContainer, 'left', '0');
|
|
69
|
+
this.renderer.setStyle(this.fullscreenContainer, 'width', '100vw');
|
|
70
|
+
this.renderer.setStyle(this.fullscreenContainer, 'height', '100vh');
|
|
71
|
+
this.renderer.setStyle(this.fullscreenContainer, 'z-index', '100');
|
|
72
|
+
this.renderer.setStyle(this.fullscreenContainer, 'background-color', '#ffffff');
|
|
73
|
+
this.renderer.setStyle(this.fullscreenContainer, 'overflow', 'auto');
|
|
74
|
+
// Move element to container
|
|
75
|
+
this.renderer.appendChild(this.fullscreenContainer, element);
|
|
76
|
+
// Apply fullscreen styles to element
|
|
77
|
+
this.renderer.setStyle(element, 'position', 'relative');
|
|
78
|
+
this.renderer.setStyle(element, 'width', '100%');
|
|
79
|
+
this.renderer.setStyle(element, 'height', '100%');
|
|
80
|
+
this.renderer.setStyle(element, 'margin', '0');
|
|
81
|
+
this.renderer.setStyle(element, 'padding', '0');
|
|
82
|
+
// Append container to body
|
|
83
|
+
this.renderer.appendChild(document.body, this.fullscreenContainer);
|
|
84
|
+
// Prevent body scroll
|
|
85
|
+
this.renderer.setStyle(document.body, 'overflow', 'hidden');
|
|
86
|
+
this.isFullscreenState.set(true);
|
|
87
|
+
}
|
|
88
|
+
catch (error) {
|
|
89
|
+
console.error('Error entering fullscreen:', error);
|
|
90
|
+
this.restoreOriginalStyles(element);
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* Exit fullscreen mode
|
|
95
|
+
*/
|
|
96
|
+
exit() {
|
|
97
|
+
if (!this.isFullscreenState()) {
|
|
98
|
+
return;
|
|
99
|
+
}
|
|
100
|
+
const element = this.elementRef.nativeElement;
|
|
101
|
+
try {
|
|
102
|
+
// Restore body scroll
|
|
103
|
+
this.renderer.removeStyle(document.body, 'overflow');
|
|
104
|
+
// Move element back to original parent
|
|
105
|
+
if (this.fullscreenContainer && this.originalParent) {
|
|
106
|
+
this.renderer.removeChild(this.fullscreenContainer, element);
|
|
107
|
+
this.renderer.appendChild(this.originalParent, element);
|
|
108
|
+
// Remove container
|
|
109
|
+
this.renderer.removeChild(document.body, this.fullscreenContainer);
|
|
110
|
+
this.fullscreenContainer = null;
|
|
111
|
+
}
|
|
112
|
+
// Restore original styles
|
|
113
|
+
this.restoreOriginalStyles(element);
|
|
114
|
+
this.isFullscreenState.set(false);
|
|
115
|
+
}
|
|
116
|
+
catch (error) {
|
|
117
|
+
console.error('Error exiting fullscreen:', error);
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
/**
|
|
121
|
+
* Check if currently in fullscreen mode
|
|
122
|
+
*/
|
|
123
|
+
isFullscreen() {
|
|
124
|
+
return this.isFullscreenState();
|
|
125
|
+
}
|
|
126
|
+
/**
|
|
127
|
+
* Store original element styles
|
|
128
|
+
*/
|
|
129
|
+
storeOriginalStyles(element) {
|
|
130
|
+
const computedStyle = window.getComputedStyle(element);
|
|
131
|
+
this.originalStyles = {
|
|
132
|
+
position: computedStyle.position,
|
|
133
|
+
top: computedStyle.top,
|
|
134
|
+
left: computedStyle.left,
|
|
135
|
+
width: computedStyle.width,
|
|
136
|
+
height: computedStyle.height,
|
|
137
|
+
zIndex: computedStyle.zIndex,
|
|
138
|
+
backgroundColor: computedStyle.backgroundColor,
|
|
139
|
+
margin: computedStyle.margin,
|
|
140
|
+
padding: computedStyle.padding,
|
|
141
|
+
};
|
|
142
|
+
}
|
|
143
|
+
/**
|
|
144
|
+
* Restore original element styles
|
|
145
|
+
*/
|
|
146
|
+
restoreOriginalStyles(element) {
|
|
147
|
+
if (!this.originalStyles) {
|
|
148
|
+
return;
|
|
149
|
+
}
|
|
150
|
+
// Restore each style property
|
|
151
|
+
Object.entries(this.originalStyles).forEach(([key, value]) => {
|
|
152
|
+
const styleKey = this.camelToKebabCase(key);
|
|
153
|
+
if (value) {
|
|
154
|
+
this.renderer.setStyle(element, styleKey, value);
|
|
155
|
+
}
|
|
156
|
+
else {
|
|
157
|
+
this.renderer.removeStyle(element, styleKey);
|
|
158
|
+
}
|
|
159
|
+
});
|
|
160
|
+
this.originalStyles = {};
|
|
161
|
+
}
|
|
162
|
+
/**
|
|
163
|
+
* Convert camelCase to kebab-case for CSS properties
|
|
164
|
+
*/
|
|
165
|
+
camelToKebabCase(str) {
|
|
166
|
+
return str.replace(/([a-z0-9]|(?=[A-Z]))([A-Z])/g, '$1-$2').toLowerCase();
|
|
167
|
+
}
|
|
168
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.9", ngImport: i0, type: AXFullScreenDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
169
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "20.3.9", type: AXFullScreenDirective, isStandalone: true, selector: "[axFullscreen]", outputs: { fullscreenChange: "fullscreenChange" }, exportAs: ["axFullscreen"], ngImport: i0 }); }
|
|
170
|
+
}
|
|
171
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.9", ngImport: i0, type: AXFullScreenDirective, decorators: [{
|
|
172
|
+
type: Directive,
|
|
173
|
+
args: [{
|
|
174
|
+
selector: '[axFullscreen]',
|
|
175
|
+
standalone: true,
|
|
176
|
+
exportAs: 'axFullscreen',
|
|
177
|
+
}]
|
|
178
|
+
}], ctorParameters: () => [], propDecorators: { fullscreenChange: [{ type: i0.Output, args: ["fullscreenChange"] }] } });
|
|
179
|
+
|
|
180
|
+
/**
|
|
181
|
+
* Generated bundle index. Do not edit.
|
|
182
|
+
*/
|
|
183
|
+
|
|
184
|
+
export { AXFullScreenDirective };
|
|
185
|
+
//# sourceMappingURL=acorex-cdk-full-screen.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"acorex-cdk-full-screen.mjs","sources":["../tmp-esm2022/full-screen/lib/full-screen.directive.js","../tmp-esm2022/full-screen/acorex-cdk-full-screen.js"],"sourcesContent":["import { Directive, effect, ElementRef, inject, output, Renderer2, signal, untracked } from '@angular/core';\nimport * as i0 from \"@angular/core\";\n/**\n * Fullscreen directive that provides CSS-based fullscreen functionality\n * Usage: <element axFullscreen #fullscreen=\"axFullscreen\"></element>\n * Then: fullscreen.toggle() or fullscreen.enter() or fullscreen.exit()\n */\nexport class AXFullScreenDirective {\n constructor() {\n /**\n * Current fullscreen state\n */\n this.isFullscreenState = signal(false, ...(ngDevMode ? [{ debugName: \"isFullscreenState\" }] : []));\n /**\n * Original element styles to restore\n */\n this.originalStyles = {};\n /**\n * Original parent element reference\n */\n this.originalParent = null;\n /**\n * Fullscreen container element\n */\n this.fullscreenContainer = null;\n /**\n * Fullscreen change event\n */\n this.fullscreenChange = output();\n this.renderer = inject(Renderer2);\n this.elementRef = inject(ElementRef);\n // Sync state changes to output\n effect(() => {\n const isFullscreen = this.isFullscreenState();\n untracked(() => {\n this.fullscreenChange.emit(isFullscreen);\n });\n });\n }\n /**\n * Toggle fullscreen state\n */\n toggle() {\n if (this.isFullscreenState()) {\n this.exit();\n }\n else {\n this.enter();\n }\n }\n /**\n * Enter fullscreen mode using CSS\n */\n enter() {\n if (this.isFullscreenState()) {\n return;\n }\n const element = this.elementRef.nativeElement;\n try {\n // Store original styles and parent\n this.storeOriginalStyles(element);\n this.originalParent = element.parentElement;\n // Create fullscreen container\n this.fullscreenContainer = this.renderer.createElement('div');\n this.renderer.setStyle(this.fullscreenContainer, 'position', 'fixed');\n this.renderer.setStyle(this.fullscreenContainer, 'top', '0');\n this.renderer.setStyle(this.fullscreenContainer, 'left', '0');\n this.renderer.setStyle(this.fullscreenContainer, 'width', '100vw');\n this.renderer.setStyle(this.fullscreenContainer, 'height', '100vh');\n this.renderer.setStyle(this.fullscreenContainer, 'z-index', '100');\n this.renderer.setStyle(this.fullscreenContainer, 'background-color', '#ffffff');\n this.renderer.setStyle(this.fullscreenContainer, 'overflow', 'auto');\n // Move element to container\n this.renderer.appendChild(this.fullscreenContainer, element);\n // Apply fullscreen styles to element\n this.renderer.setStyle(element, 'position', 'relative');\n this.renderer.setStyle(element, 'width', '100%');\n this.renderer.setStyle(element, 'height', '100%');\n this.renderer.setStyle(element, 'margin', '0');\n this.renderer.setStyle(element, 'padding', '0');\n // Append container to body\n this.renderer.appendChild(document.body, this.fullscreenContainer);\n // Prevent body scroll\n this.renderer.setStyle(document.body, 'overflow', 'hidden');\n this.isFullscreenState.set(true);\n }\n catch (error) {\n console.error('Error entering fullscreen:', error);\n this.restoreOriginalStyles(element);\n }\n }\n /**\n * Exit fullscreen mode\n */\n exit() {\n if (!this.isFullscreenState()) {\n return;\n }\n const element = this.elementRef.nativeElement;\n try {\n // Restore body scroll\n this.renderer.removeStyle(document.body, 'overflow');\n // Move element back to original parent\n if (this.fullscreenContainer && this.originalParent) {\n this.renderer.removeChild(this.fullscreenContainer, element);\n this.renderer.appendChild(this.originalParent, element);\n // Remove container\n this.renderer.removeChild(document.body, this.fullscreenContainer);\n this.fullscreenContainer = null;\n }\n // Restore original styles\n this.restoreOriginalStyles(element);\n this.isFullscreenState.set(false);\n }\n catch (error) {\n console.error('Error exiting fullscreen:', error);\n }\n }\n /**\n * Check if currently in fullscreen mode\n */\n isFullscreen() {\n return this.isFullscreenState();\n }\n /**\n * Store original element styles\n */\n storeOriginalStyles(element) {\n const computedStyle = window.getComputedStyle(element);\n this.originalStyles = {\n position: computedStyle.position,\n top: computedStyle.top,\n left: computedStyle.left,\n width: computedStyle.width,\n height: computedStyle.height,\n zIndex: computedStyle.zIndex,\n backgroundColor: computedStyle.backgroundColor,\n margin: computedStyle.margin,\n padding: computedStyle.padding,\n };\n }\n /**\n * Restore original element styles\n */\n restoreOriginalStyles(element) {\n if (!this.originalStyles) {\n return;\n }\n // Restore each style property\n Object.entries(this.originalStyles).forEach(([key, value]) => {\n const styleKey = this.camelToKebabCase(key);\n if (value) {\n this.renderer.setStyle(element, styleKey, value);\n }\n else {\n this.renderer.removeStyle(element, styleKey);\n }\n });\n this.originalStyles = {};\n }\n /**\n * Convert camelCase to kebab-case for CSS properties\n */\n camelToKebabCase(str) {\n return str.replace(/([a-z0-9]|(?=[A-Z]))([A-Z])/g, '$1-$2').toLowerCase();\n }\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.3.9\", ngImport: i0, type: AXFullScreenDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }\n static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: \"14.0.0\", version: \"20.3.9\", type: AXFullScreenDirective, isStandalone: true, selector: \"[axFullscreen]\", outputs: { fullscreenChange: \"fullscreenChange\" }, exportAs: [\"axFullscreen\"], ngImport: i0 }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.3.9\", ngImport: i0, type: AXFullScreenDirective, decorators: [{\n type: Directive,\n args: [{\n selector: '[axFullscreen]',\n standalone: true,\n exportAs: 'axFullscreen',\n }]\n }], ctorParameters: () => [], propDecorators: { fullscreenChange: [{ type: i0.Output, args: [\"fullscreenChange\"] }] } });\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"full-screen.directive.js","sourceRoot":"","sources":["../../../../../../packages/cdk/full-screen/src/lib/full-screen.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, effect, ElementRef, inject, output, Renderer2, signal, untracked } from '@angular/core';\n\n/**\n * Fullscreen directive that provides CSS-based fullscreen functionality\n * Usage: <element axFullscreen #fullscreen=\"axFullscreen\"></element>\n * Then: fullscreen.toggle() or fullscreen.enter() or fullscreen.exit()\n */\n@Directive({\n  selector: '[axFullscreen]',\n  standalone: true,\n  exportAs: 'axFullscreen',\n})\nexport class AXFullScreenDirective {\n  /**\n   * Current fullscreen state\n   */\n  private readonly isFullscreenState = signal<boolean>(false);\n\n  /**\n   * Original element styles to restore\n   */\n  private originalStyles: {\n    position?: string;\n    top?: string;\n    left?: string;\n    width?: string;\n    height?: string;\n    zIndex?: string;\n    backgroundColor?: string;\n    margin?: string;\n    padding?: string;\n  } = {};\n\n  /**\n   * Original parent element reference\n   */\n  private originalParent: HTMLElement | null = null;\n\n  /**\n   * Fullscreen container element\n   */\n  private fullscreenContainer: HTMLElement | null = null;\n\n  /**\n   * Fullscreen change event\n   */\n  readonly fullscreenChange = output<boolean>();\n\n  private readonly renderer = inject(Renderer2);\n  private readonly elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n\n  constructor() {\n    // Sync state changes to output\n    effect(() => {\n      const isFullscreen = this.isFullscreenState();\n      untracked(() => {\n        this.fullscreenChange.emit(isFullscreen);\n      });\n    });\n  }\n\n  /**\n   * Toggle fullscreen state\n   */\n  toggle(): void {\n    if (this.isFullscreenState()) {\n      this.exit();\n    } else {\n      this.enter();\n    }\n  }\n\n  /**\n   * Enter fullscreen mode using CSS\n   */\n  enter(): void {\n    if (this.isFullscreenState()) {\n      return;\n    }\n\n    const element = this.elementRef.nativeElement;\n\n    try {\n      // Store original styles and parent\n      this.storeOriginalStyles(element);\n      this.originalParent = element.parentElement;\n\n      // Create fullscreen container\n      this.fullscreenContainer = this.renderer.createElement('div');\n      this.renderer.setStyle(this.fullscreenContainer, 'position', 'fixed');\n      this.renderer.setStyle(this.fullscreenContainer, 'top', '0');\n      this.renderer.setStyle(this.fullscreenContainer, 'left', '0');\n      this.renderer.setStyle(this.fullscreenContainer, 'width', '100vw');\n      this.renderer.setStyle(this.fullscreenContainer, 'height', '100vh');\n      this.renderer.setStyle(this.fullscreenContainer, 'z-index', '100');\n      this.renderer.setStyle(this.fullscreenContainer, 'background-color', '#ffffff');\n      this.renderer.setStyle(this.fullscreenContainer, 'overflow', 'auto');\n\n      // Move element to container\n      this.renderer.appendChild(this.fullscreenContainer, element);\n\n      // Apply fullscreen styles to element\n      this.renderer.setStyle(element, 'position', 'relative');\n      this.renderer.setStyle(element, 'width', '100%');\n      this.renderer.setStyle(element, 'height', '100%');\n      this.renderer.setStyle(element, 'margin', '0');\n      this.renderer.setStyle(element, 'padding', '0');\n\n      // Append container to body\n      this.renderer.appendChild(document.body, this.fullscreenContainer);\n\n      // Prevent body scroll\n      this.renderer.setStyle(document.body, 'overflow', 'hidden');\n\n      this.isFullscreenState.set(true);\n    } catch (error) {\n      console.error('Error entering fullscreen:', error);\n      this.restoreOriginalStyles(element);\n    }\n  }\n\n  /**\n   * Exit fullscreen mode\n   */\n  exit(): void {\n    if (!this.isFullscreenState()) {\n      return;\n    }\n\n    const element = this.elementRef.nativeElement;\n\n    try {\n      // Restore body scroll\n      this.renderer.removeStyle(document.body, 'overflow');\n\n      // Move element back to original parent\n      if (this.fullscreenContainer && this.originalParent) {\n        this.renderer.removeChild(this.fullscreenContainer, element);\n        this.renderer.appendChild(this.originalParent, element);\n\n        // Remove container\n        this.renderer.removeChild(document.body, this.fullscreenContainer);\n        this.fullscreenContainer = null;\n      }\n\n      // Restore original styles\n      this.restoreOriginalStyles(element);\n\n      this.isFullscreenState.set(false);\n    } catch (error) {\n      console.error('Error exiting fullscreen:', error);\n    }\n  }\n\n  /**\n   * Check if currently in fullscreen mode\n   */\n  isFullscreen(): boolean {\n    return this.isFullscreenState();\n  }\n\n  /**\n   * Store original element styles\n   */\n  private storeOriginalStyles(element: HTMLElement): void {\n    const computedStyle = window.getComputedStyle(element);\n    this.originalStyles = {\n      position: computedStyle.position,\n      top: computedStyle.top,\n      left: computedStyle.left,\n      width: computedStyle.width,\n      height: computedStyle.height,\n      zIndex: computedStyle.zIndex,\n      backgroundColor: computedStyle.backgroundColor,\n      margin: computedStyle.margin,\n      padding: computedStyle.padding,\n    };\n  }\n\n  /**\n   * Restore original element styles\n   */\n  private restoreOriginalStyles(element: HTMLElement): void {\n    if (!this.originalStyles) {\n      return;\n    }\n\n    // Restore each style property\n    Object.entries(this.originalStyles).forEach(([key, value]) => {\n      const styleKey = this.camelToKebabCase(key);\n      if (value) {\n        this.renderer.setStyle(element, styleKey, value);\n      } else {\n        this.renderer.removeStyle(element, styleKey);\n      }\n    });\n\n    this.originalStyles = {};\n  }\n\n  /**\n   * Convert camelCase to kebab-case for CSS properties\n   */\n  private camelToKebabCase(str: string): string {\n    return str.replace(/([a-z0-9]|(?=[A-Z]))([A-Z])/g, '$1-$2').toLowerCase();\n  }\n}\n"]}","/**\n * Generated bundle index. Do not edit.\n */\nexport * from './index';\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNvcmV4LWNkay1mdWxsLXNjcmVlbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2Nkay9mdWxsLXNjcmVlbi9zcmMvYWNvcmV4LWNkay1mdWxsLXNjcmVlbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ=="],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import * as i0 from '@angular/core';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Fullscreen directive that provides CSS-based fullscreen functionality
|
|
5
|
+
* Usage: <element axFullscreen #fullscreen="axFullscreen"></element>
|
|
6
|
+
* Then: fullscreen.toggle() or fullscreen.enter() or fullscreen.exit()
|
|
7
|
+
*/
|
|
8
|
+
declare class AXFullScreenDirective {
|
|
9
|
+
/**
|
|
10
|
+
* Current fullscreen state
|
|
11
|
+
*/
|
|
12
|
+
private readonly isFullscreenState;
|
|
13
|
+
/**
|
|
14
|
+
* Original element styles to restore
|
|
15
|
+
*/
|
|
16
|
+
private originalStyles;
|
|
17
|
+
/**
|
|
18
|
+
* Original parent element reference
|
|
19
|
+
*/
|
|
20
|
+
private originalParent;
|
|
21
|
+
/**
|
|
22
|
+
* Fullscreen container element
|
|
23
|
+
*/
|
|
24
|
+
private fullscreenContainer;
|
|
25
|
+
/**
|
|
26
|
+
* Fullscreen change event
|
|
27
|
+
*/
|
|
28
|
+
readonly fullscreenChange: i0.OutputEmitterRef<boolean>;
|
|
29
|
+
private readonly renderer;
|
|
30
|
+
private readonly elementRef;
|
|
31
|
+
constructor();
|
|
32
|
+
/**
|
|
33
|
+
* Toggle fullscreen state
|
|
34
|
+
*/
|
|
35
|
+
toggle(): void;
|
|
36
|
+
/**
|
|
37
|
+
* Enter fullscreen mode using CSS
|
|
38
|
+
*/
|
|
39
|
+
enter(): void;
|
|
40
|
+
/**
|
|
41
|
+
* Exit fullscreen mode
|
|
42
|
+
*/
|
|
43
|
+
exit(): void;
|
|
44
|
+
/**
|
|
45
|
+
* Check if currently in fullscreen mode
|
|
46
|
+
*/
|
|
47
|
+
isFullscreen(): boolean;
|
|
48
|
+
/**
|
|
49
|
+
* Store original element styles
|
|
50
|
+
*/
|
|
51
|
+
private storeOriginalStyles;
|
|
52
|
+
/**
|
|
53
|
+
* Restore original element styles
|
|
54
|
+
*/
|
|
55
|
+
private restoreOriginalStyles;
|
|
56
|
+
/**
|
|
57
|
+
* Convert camelCase to kebab-case for CSS properties
|
|
58
|
+
*/
|
|
59
|
+
private camelToKebabCase;
|
|
60
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<AXFullScreenDirective, never>;
|
|
61
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<AXFullScreenDirective, "[axFullscreen]", ["axFullscreen"], {}, { "fullscreenChange": "fullscreenChange"; }, never, never, true, never>;
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
export { AXFullScreenDirective };
|
package/package.json
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@acorex/cdk",
|
|
3
|
-
"version": "20.
|
|
3
|
+
"version": "20.3.1",
|
|
4
4
|
"peerDependencies": {
|
|
5
|
-
"@acorex/core": "20.
|
|
5
|
+
"@acorex/core": "20.3.1",
|
|
6
6
|
"@angular/common": "^20.0.0",
|
|
7
7
|
"@angular/core": "^20.0.0",
|
|
8
8
|
"quill": ">=2.0.2",
|
|
@@ -57,6 +57,10 @@
|
|
|
57
57
|
"types": "./focus-trap/index.d.ts",
|
|
58
58
|
"default": "./fesm2022/acorex-cdk-focus-trap.mjs"
|
|
59
59
|
},
|
|
60
|
+
"./full-screen": {
|
|
61
|
+
"types": "./full-screen/index.d.ts",
|
|
62
|
+
"default": "./fesm2022/acorex-cdk-full-screen.mjs"
|
|
63
|
+
},
|
|
60
64
|
"./input-mask": {
|
|
61
65
|
"types": "./input-mask/index.d.ts",
|
|
62
66
|
"default": "./fesm2022/acorex-cdk-input-mask.mjs"
|