cloud-ide-element 1.0.2 → 1.0.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +63 -271
- package/fesm2022/cloud-ide-element.mjs +614 -618
- package/fesm2022/cloud-ide-element.mjs.map +1 -1
- package/index.d.ts +1362 -3
- package/package.json +4 -31
- package/esm2022/cloud-ide-element.mjs +0 -5
- package/esm2022/lib/components/confirmation-modal/confirmation-modal.component.mjs +0 -182
- package/esm2022/lib/components/data-grid/data-grid.component.mjs +0 -1363
- package/esm2022/lib/components/data-grid/data-grid.types.mjs +0 -37
- package/esm2022/lib/components/dropdown/dropdown.component.mjs +0 -396
- package/esm2022/lib/components/global-notifications/global-notifications.component.mjs +0 -30
- package/esm2022/lib/components/json-editor/json-editor.component.mjs +0 -521
- package/esm2022/lib/components/skeleton-loader/skeleton-loader.component.mjs +0 -33
- package/esm2022/lib/components/toast-notification/toast-notification.component.mjs +0 -152
- package/esm2022/lib/elements/button/cide-ele-button.component.mjs +0 -249
- package/esm2022/lib/elements/file-input/file-input.component.mjs +0 -83
- package/esm2022/lib/elements/icon/icon.component.mjs +0 -26
- package/esm2022/lib/elements/input/input.component.mjs +0 -467
- package/esm2022/lib/elements/select/select.component.mjs +0 -471
- package/esm2022/lib/elements/spinner/spinner.component.mjs +0 -32
- package/esm2022/lib/elements/tab/cide-ele-tab.component.mjs +0 -74
- package/esm2022/lib/elements/textarea/textarea.component.mjs +0 -157
- package/esm2022/lib/services/confirmation.service.mjs +0 -151
- package/esm2022/lib/services/dropdown-manager.service.mjs +0 -93
- package/esm2022/lib/services/notification.service.mjs +0 -196
- package/esm2022/lib/utils/directives/resizer/resizer.directive.mjs +0 -231
- package/esm2022/lib/utils/directives/tooltip/tooltip.directive.mjs +0 -294
- package/esm2022/lib/utils/pipes/capitalize/capitalize.pipe.mjs +0 -38
- package/esm2022/lib/utils/services/elements/elements.service.mjs +0 -39
- package/esm2022/public-api.mjs +0 -31
- package/lib/components/confirmation-modal/confirmation-modal.component.d.ts +0 -16
- package/lib/components/data-grid/data-grid.component.d.ts +0 -244
- package/lib/components/data-grid/data-grid.types.d.ts +0 -146
- package/lib/components/dropdown/dropdown.component.d.ts +0 -75
- package/lib/components/global-notifications/global-notifications.component.d.ts +0 -5
- package/lib/components/json-editor/json-editor.component.d.ts +0 -116
- package/lib/components/skeleton-loader/skeleton-loader.component.d.ts +0 -11
- package/lib/components/toast-notification/toast-notification.component.d.ts +0 -13
- package/lib/elements/button/cide-ele-button.component.d.ts +0 -85
- package/lib/elements/file-input/file-input.component.d.ts +0 -25
- package/lib/elements/icon/icon.component.d.ts +0 -9
- package/lib/elements/input/input.component.d.ts +0 -182
- package/lib/elements/select/select.component.d.ts +0 -91
- package/lib/elements/spinner/spinner.component.d.ts +0 -19
- package/lib/elements/tab/cide-ele-tab.component.d.ts +0 -26
- package/lib/elements/textarea/textarea.component.d.ts +0 -47
- package/lib/services/confirmation.service.d.ts +0 -65
- package/lib/services/dropdown-manager.service.d.ts +0 -22
- package/lib/services/notification.service.d.ts +0 -81
- package/lib/utils/directives/resizer/resizer.directive.d.ts +0 -44
- package/lib/utils/directives/tooltip/tooltip.directive.d.ts +0 -43
- package/lib/utils/pipes/capitalize/capitalize.pipe.d.ts +0 -7
- package/lib/utils/services/elements/elements.service.d.ts +0 -12
- package/public-api.d.ts +0 -22
|
@@ -1,196 +0,0 @@
|
|
|
1
|
-
import { Injectable, signal, computed } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
export class NotificationService {
|
|
4
|
-
constructor() {
|
|
5
|
-
this.notifications = signal([]);
|
|
6
|
-
this.maxNotifications = 5; // Maximum notifications to show at once
|
|
7
|
-
// Computed signals
|
|
8
|
-
this.activeNotifications = computed(() => this.notifications().filter(n => n.isVisible));
|
|
9
|
-
}
|
|
10
|
-
/**
|
|
11
|
-
* Show a success notification
|
|
12
|
-
*/
|
|
13
|
-
success(message, options) {
|
|
14
|
-
return this.show({
|
|
15
|
-
message,
|
|
16
|
-
type: 'success',
|
|
17
|
-
icon: 'check_circle',
|
|
18
|
-
duration: 3000,
|
|
19
|
-
...options
|
|
20
|
-
});
|
|
21
|
-
}
|
|
22
|
-
/**
|
|
23
|
-
* Show an error notification
|
|
24
|
-
*/
|
|
25
|
-
error(message, options) {
|
|
26
|
-
return this.show({
|
|
27
|
-
message,
|
|
28
|
-
type: 'error',
|
|
29
|
-
icon: 'error',
|
|
30
|
-
duration: 5000,
|
|
31
|
-
...options
|
|
32
|
-
});
|
|
33
|
-
}
|
|
34
|
-
/**
|
|
35
|
-
* Show a warning notification
|
|
36
|
-
*/
|
|
37
|
-
warning(message, options) {
|
|
38
|
-
return this.show({
|
|
39
|
-
message,
|
|
40
|
-
type: 'warning',
|
|
41
|
-
icon: 'warning',
|
|
42
|
-
duration: 4000,
|
|
43
|
-
...options
|
|
44
|
-
});
|
|
45
|
-
}
|
|
46
|
-
/**
|
|
47
|
-
* Show an info notification
|
|
48
|
-
*/
|
|
49
|
-
info(message, options) {
|
|
50
|
-
return this.show({
|
|
51
|
-
message,
|
|
52
|
-
type: 'info',
|
|
53
|
-
icon: 'info',
|
|
54
|
-
duration: 3000,
|
|
55
|
-
...options
|
|
56
|
-
});
|
|
57
|
-
}
|
|
58
|
-
/**
|
|
59
|
-
* Show a notification with undo functionality
|
|
60
|
-
*/
|
|
61
|
-
showWithUndo(message, undoAction, options) {
|
|
62
|
-
return this.show({
|
|
63
|
-
message,
|
|
64
|
-
type: 'info',
|
|
65
|
-
icon: 'info',
|
|
66
|
-
duration: 8000,
|
|
67
|
-
showUndo: true,
|
|
68
|
-
undoAction,
|
|
69
|
-
undoText: 'Undo',
|
|
70
|
-
...options
|
|
71
|
-
});
|
|
72
|
-
}
|
|
73
|
-
/**
|
|
74
|
-
* Show a notification for reversible destructive actions
|
|
75
|
-
*/
|
|
76
|
-
showReversibleAction(action, itemName, undoAction, options) {
|
|
77
|
-
return this.showWithUndo(`${action} "${itemName}"`, undoAction, {
|
|
78
|
-
type: 'warning',
|
|
79
|
-
icon: 'delete',
|
|
80
|
-
title: `${action} completed`,
|
|
81
|
-
...options
|
|
82
|
-
});
|
|
83
|
-
}
|
|
84
|
-
/**
|
|
85
|
-
* Show a notification for background tasks
|
|
86
|
-
*/
|
|
87
|
-
showBackgroundTask(taskName, isComplete = true, options) {
|
|
88
|
-
return this.show({
|
|
89
|
-
message: isComplete ? `${taskName} completed successfully` : `${taskName} in progress...`,
|
|
90
|
-
type: isComplete ? 'success' : 'info',
|
|
91
|
-
icon: isComplete ? 'check_circle' : 'sync',
|
|
92
|
-
duration: isComplete ? 3000 : 0, // Don't auto-dismiss for in-progress tasks
|
|
93
|
-
...options
|
|
94
|
-
});
|
|
95
|
-
}
|
|
96
|
-
/**
|
|
97
|
-
* Core show method
|
|
98
|
-
*/
|
|
99
|
-
show(options) {
|
|
100
|
-
const notification = {
|
|
101
|
-
id: this.generateId(),
|
|
102
|
-
message: options.message,
|
|
103
|
-
type: options.type || 'info',
|
|
104
|
-
duration: options.duration || 3000,
|
|
105
|
-
showUndo: options.showUndo || false,
|
|
106
|
-
undoAction: options.undoAction,
|
|
107
|
-
undoText: options.undoText || 'Undo',
|
|
108
|
-
icon: options.icon || this.getDefaultIcon(options.type || 'info'),
|
|
109
|
-
title: options.title,
|
|
110
|
-
timestamp: Date.now(),
|
|
111
|
-
isVisible: true
|
|
112
|
-
};
|
|
113
|
-
this.addNotification(notification);
|
|
114
|
-
return notification.id;
|
|
115
|
-
}
|
|
116
|
-
/**
|
|
117
|
-
* Remove a specific notification
|
|
118
|
-
*/
|
|
119
|
-
remove(id) {
|
|
120
|
-
this.notifications.update(notifications => notifications.map(n => n.id === id ? { ...n, isVisible: false } : n));
|
|
121
|
-
// Remove from array after animation
|
|
122
|
-
setTimeout(() => {
|
|
123
|
-
this.notifications.update(notifications => notifications.filter(n => n.id !== id));
|
|
124
|
-
}, 300);
|
|
125
|
-
}
|
|
126
|
-
/**
|
|
127
|
-
* Remove all notifications
|
|
128
|
-
*/
|
|
129
|
-
clearAll() {
|
|
130
|
-
this.notifications.update(notifications => notifications.map(n => ({ ...n, isVisible: false })));
|
|
131
|
-
setTimeout(() => {
|
|
132
|
-
this.notifications.set([]);
|
|
133
|
-
}, 300);
|
|
134
|
-
}
|
|
135
|
-
/**
|
|
136
|
-
* Execute undo action for a notification
|
|
137
|
-
*/
|
|
138
|
-
executeUndo(id) {
|
|
139
|
-
const notification = this.notifications().find(n => n.id === id);
|
|
140
|
-
if (notification && notification.undoAction) {
|
|
141
|
-
notification.undoAction();
|
|
142
|
-
this.remove(id);
|
|
143
|
-
}
|
|
144
|
-
}
|
|
145
|
-
// Internal methods
|
|
146
|
-
addNotification(notification) {
|
|
147
|
-
this.notifications.update(notifications => {
|
|
148
|
-
const newNotifications = [...notifications, notification];
|
|
149
|
-
// Limit the number of visible notifications
|
|
150
|
-
if (newNotifications.length > this.maxNotifications) {
|
|
151
|
-
// Remove oldest notifications
|
|
152
|
-
const toRemove = newNotifications.length - this.maxNotifications;
|
|
153
|
-
for (let i = 0; i < toRemove; i++) {
|
|
154
|
-
if (newNotifications[i]) {
|
|
155
|
-
newNotifications[i] = { ...newNotifications[i], isVisible: false };
|
|
156
|
-
}
|
|
157
|
-
}
|
|
158
|
-
}
|
|
159
|
-
return newNotifications;
|
|
160
|
-
});
|
|
161
|
-
// Auto-remove after duration (if not 0)
|
|
162
|
-
if (notification.duration > 0) {
|
|
163
|
-
setTimeout(() => {
|
|
164
|
-
this.remove(notification.id);
|
|
165
|
-
}, notification.duration);
|
|
166
|
-
}
|
|
167
|
-
}
|
|
168
|
-
generateId() {
|
|
169
|
-
return `notification-${Date.now()}-${Math.random().toString(36).substr(2, 9)}`;
|
|
170
|
-
}
|
|
171
|
-
getDefaultIcon(type) {
|
|
172
|
-
const iconMap = {
|
|
173
|
-
success: 'check_circle',
|
|
174
|
-
error: 'error',
|
|
175
|
-
warning: 'warning',
|
|
176
|
-
info: 'info'
|
|
177
|
-
};
|
|
178
|
-
return iconMap[type];
|
|
179
|
-
}
|
|
180
|
-
// Public getters for components
|
|
181
|
-
getNotifications() {
|
|
182
|
-
return this.notifications;
|
|
183
|
-
}
|
|
184
|
-
getActiveNotifications() {
|
|
185
|
-
return this.activeNotifications;
|
|
186
|
-
}
|
|
187
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: NotificationService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
188
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: NotificationService, providedIn: 'root' }); }
|
|
189
|
-
}
|
|
190
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: NotificationService, decorators: [{
|
|
191
|
-
type: Injectable,
|
|
192
|
-
args: [{
|
|
193
|
-
providedIn: 'root'
|
|
194
|
-
}]
|
|
195
|
-
}], ctorParameters: () => [] });
|
|
196
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notification.service.js","sourceRoot":"","sources":["../../../../../projects/cloud-ide-element/src/lib/services/notification.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, signal, computed } from '@angular/core';\r\nimport { Observable, Subject } from 'rxjs';\r\n\r\nexport interface NotificationOptions {\r\n  message: string;\r\n  type?: 'success' | 'error' | 'warning' | 'info';\r\n  duration?: number;\r\n  showUndo?: boolean;\r\n  undoAction?: () => void;\r\n  undoText?: string;\r\n  icon?: string;\r\n  title?: string;\r\n}\r\n\r\nexport interface NotificationItem {\r\n  id: string;\r\n  message: string;\r\n  type: 'success' | 'error' | 'warning' | 'info';\r\n  duration: number;\r\n  showUndo: boolean;\r\n  undoAction?: () => void;\r\n  undoText: string;\r\n  icon: string;\r\n  title?: string;\r\n  timestamp: number;\r\n  isVisible: boolean;\r\n}\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class NotificationService {\r\n  private notifications = signal<NotificationItem[]>([]);\r\n  private maxNotifications = 5; // Maximum notifications to show at once\r\n\r\n  // Computed signals\r\n  activeNotifications = computed(() => \r\n    this.notifications().filter(n => n.isVisible)\r\n  );\r\n\r\n  constructor() {}\r\n\r\n  /**\r\n   * Show a success notification\r\n   */\r\n  success(message: string, options?: Partial<NotificationOptions>): string {\r\n    return this.show({\r\n      message,\r\n      type: 'success',\r\n      icon: 'check_circle',\r\n      duration: 3000,\r\n      ...options\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Show an error notification\r\n   */\r\n  error(message: string, options?: Partial<NotificationOptions>): string {\r\n    return this.show({\r\n      message,\r\n      type: 'error',\r\n      icon: 'error',\r\n      duration: 5000,\r\n      ...options\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Show a warning notification\r\n   */\r\n  warning(message: string, options?: Partial<NotificationOptions>): string {\r\n    return this.show({\r\n      message,\r\n      type: 'warning',\r\n      icon: 'warning',\r\n      duration: 4000,\r\n      ...options\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Show an info notification\r\n   */\r\n  info(message: string, options?: Partial<NotificationOptions>): string {\r\n    return this.show({\r\n      message,\r\n      type: 'info',\r\n      icon: 'info',\r\n      duration: 3000,\r\n      ...options\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Show a notification with undo functionality\r\n   */\r\n  showWithUndo(\r\n    message: string, \r\n    undoAction: () => void, \r\n    options?: Partial<NotificationOptions>\r\n  ): string {\r\n    return this.show({\r\n      message,\r\n      type: 'info',\r\n      icon: 'info',\r\n      duration: 8000,\r\n      showUndo: true,\r\n      undoAction,\r\n      undoText: 'Undo',\r\n      ...options\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Show a notification for reversible destructive actions\r\n   */\r\n  showReversibleAction(\r\n    action: string,\r\n    itemName: string,\r\n    undoAction: () => void,\r\n    options?: Partial<NotificationOptions>\r\n  ): string {\r\n    return this.showWithUndo(\r\n      `${action} \"${itemName}\"`,\r\n      undoAction,\r\n      {\r\n        type: 'warning',\r\n        icon: 'delete',\r\n        title: `${action} completed`,\r\n        ...options\r\n      }\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Show a notification for background tasks\r\n   */\r\n  showBackgroundTask(\r\n    taskName: string,\r\n    isComplete: boolean = true,\r\n    options?: Partial<NotificationOptions>\r\n  ): string {\r\n    return this.show({\r\n      message: isComplete ? `${taskName} completed successfully` : `${taskName} in progress...`,\r\n      type: isComplete ? 'success' : 'info',\r\n      icon: isComplete ? 'check_circle' : 'sync',\r\n      duration: isComplete ? 3000 : 0, // Don't auto-dismiss for in-progress tasks\r\n      ...options\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Core show method\r\n   */\r\n  private show(options: NotificationOptions): string {\r\n    const notification: NotificationItem = {\r\n      id: this.generateId(),\r\n      message: options.message,\r\n      type: options.type || 'info',\r\n      duration: options.duration || 3000,\r\n      showUndo: options.showUndo || false,\r\n      undoAction: options.undoAction,\r\n      undoText: options.undoText || 'Undo',\r\n      icon: options.icon || this.getDefaultIcon(options.type || 'info'),\r\n      title: options.title,\r\n      timestamp: Date.now(),\r\n      isVisible: true\r\n    };\r\n\r\n    this.addNotification(notification);\r\n    return notification.id;\r\n  }\r\n\r\n  /**\r\n   * Remove a specific notification\r\n   */\r\n  remove(id: string): void {\r\n    this.notifications.update(notifications => \r\n      notifications.map(n => \r\n        n.id === id ? { ...n, isVisible: false } : n\r\n      )\r\n    );\r\n\r\n    // Remove from array after animation\r\n    setTimeout(() => {\r\n      this.notifications.update(notifications => \r\n        notifications.filter(n => n.id !== id)\r\n      );\r\n    }, 300);\r\n  }\r\n\r\n  /**\r\n   * Remove all notifications\r\n   */\r\n  clearAll(): void {\r\n    this.notifications.update(notifications => \r\n      notifications.map(n => ({ ...n, isVisible: false }))\r\n    );\r\n\r\n    setTimeout(() => {\r\n      this.notifications.set([]);\r\n    }, 300);\r\n  }\r\n\r\n  /**\r\n   * Execute undo action for a notification\r\n   */\r\n  executeUndo(id: string): void {\r\n    const notification = this.notifications().find(n => n.id === id);\r\n    if (notification && notification.undoAction) {\r\n      notification.undoAction();\r\n      this.remove(id);\r\n    }\r\n  }\r\n\r\n  // Internal methods\r\n  private addNotification(notification: NotificationItem): void {\r\n    this.notifications.update(notifications => {\r\n      const newNotifications = [...notifications, notification];\r\n      \r\n      // Limit the number of visible notifications\r\n      if (newNotifications.length > this.maxNotifications) {\r\n        // Remove oldest notifications\r\n        const toRemove = newNotifications.length - this.maxNotifications;\r\n        for (let i = 0; i < toRemove; i++) {\r\n          if (newNotifications[i]) {\r\n            newNotifications[i] = { ...newNotifications[i], isVisible: false };\r\n          }\r\n        }\r\n      }\r\n      \r\n      return newNotifications;\r\n    });\r\n\r\n    // Auto-remove after duration (if not 0)\r\n    if (notification.duration > 0) {\r\n      setTimeout(() => {\r\n        this.remove(notification.id);\r\n      }, notification.duration);\r\n    }\r\n  }\r\n\r\n  private generateId(): string {\r\n    return `notification-${Date.now()}-${Math.random().toString(36).substr(2, 9)}`;\r\n  }\r\n\r\n  private getDefaultIcon(type: 'success' | 'error' | 'warning' | 'info'): string {\r\n    const iconMap = {\r\n      success: 'check_circle',\r\n      error: 'error',\r\n      warning: 'warning',\r\n      info: 'info'\r\n    };\r\n    return iconMap[type];\r\n  }\r\n\r\n  // Public getters for components\r\n  getNotifications() {\r\n    return this.notifications;\r\n  }\r\n\r\n  getActiveNotifications() {\r\n    return this.activeNotifications;\r\n  }\r\n}\r\n\r\n"]}
|
|
@@ -1,231 +0,0 @@
|
|
|
1
|
-
import { Directive, EventEmitter, HostListener, Input, Output } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
/**
|
|
4
|
-
<!-- Basic horizontal (left-right) layout -->
|
|
5
|
-
<div class="panel-container">
|
|
6
|
-
<div class="left-panel">
|
|
7
|
-
Left Panel Content
|
|
8
|
-
</div>
|
|
9
|
-
|
|
10
|
-
<div cideEleResizer direction="horizontal" [minPrevSize]="100" [minNextSize]="100">resize
|
|
11
|
-
</div>
|
|
12
|
-
|
|
13
|
-
<div class="right-panel">
|
|
14
|
-
Right Panel Content
|
|
15
|
-
</div>
|
|
16
|
-
</div>
|
|
17
|
-
|
|
18
|
-
<!-- Basic vertical (top-bottom) layout -->
|
|
19
|
-
<div class="panel-container-vertical">
|
|
20
|
-
<div class="top-panel">
|
|
21
|
-
Top Panel Content
|
|
22
|
-
</div>
|
|
23
|
-
|
|
24
|
-
<div cideEleResizer direction="vertical" [minPrevSize]="50" [minNextSize]="50">resize
|
|
25
|
-
</div>
|
|
26
|
-
|
|
27
|
-
<div class="bottom-panel">
|
|
28
|
-
Bottom Panel Content
|
|
29
|
-
</div>
|
|
30
|
-
</div>
|
|
31
|
-
|
|
32
|
-
<!-- Using with custom selectors -->
|
|
33
|
-
<div class="complex-layout">
|
|
34
|
-
<div id="panel1">Panel 1</div>
|
|
35
|
-
<div id="panel2">Panel 2</div>
|
|
36
|
-
|
|
37
|
-
<div cideEleResizer direction="horizontal" prevElementSelector="#panel1" nextElementSelector="#panel2"
|
|
38
|
-
[usePercentage]="true">resize
|
|
39
|
-
</div>
|
|
40
|
-
|
|
41
|
-
<div id="panel3">Panel 3</div>
|
|
42
|
-
</div>
|
|
43
|
-
*/
|
|
44
|
-
export class CideEleResizerDirective {
|
|
45
|
-
constructor(el, renderer) {
|
|
46
|
-
this.el = el;
|
|
47
|
-
this.renderer = renderer;
|
|
48
|
-
this.direction = 'horizontal';
|
|
49
|
-
this.to = "";
|
|
50
|
-
this.prevElementSelector = ''; // Selector for previous element
|
|
51
|
-
this.nextElementSelector = ''; // Selector for next element
|
|
52
|
-
this.parentElementSelector = ''; // Selector for parent element
|
|
53
|
-
this.minPrevSize = 0; // Minimum size of previous element (px)
|
|
54
|
-
this.minNextSize = 0; // Minimum size of next element (px)
|
|
55
|
-
this.usePercentage = false; // Use percentage instead of pixels
|
|
56
|
-
this.resizeStart = new EventEmitter();
|
|
57
|
-
this.resizing = new EventEmitter();
|
|
58
|
-
this.resizeEnd = new EventEmitter();
|
|
59
|
-
this.isResizing = false;
|
|
60
|
-
this.startPosition = 0;
|
|
61
|
-
this.prevElement = null;
|
|
62
|
-
this.nextElement = null;
|
|
63
|
-
this.prevSize = 0;
|
|
64
|
-
this.nextSize = 0;
|
|
65
|
-
this.containerSize = 0;
|
|
66
|
-
this.startPrevSize = 0;
|
|
67
|
-
this.startNextSize = 0;
|
|
68
|
-
this.onMouseMove = (event) => {
|
|
69
|
-
if (!this.isResizing)
|
|
70
|
-
return;
|
|
71
|
-
// Calculate movement
|
|
72
|
-
const currentPosition = this.direction === 'horizontal' ? event.clientX : event.clientY;
|
|
73
|
-
const delta = currentPosition - this.startPosition;
|
|
74
|
-
// Calculate new sizes
|
|
75
|
-
let newPrevSize = this.startPrevSize + delta;
|
|
76
|
-
let newNextSize = this.startNextSize - delta;
|
|
77
|
-
// Apply constraints
|
|
78
|
-
if (newPrevSize < this.minPrevSize) {
|
|
79
|
-
const diff = this.minPrevSize - newPrevSize;
|
|
80
|
-
newPrevSize = this.minPrevSize;
|
|
81
|
-
newNextSize = this.startNextSize - delta + diff;
|
|
82
|
-
// skip if previsus size is equal to the minimum size, note above code is dark code which will not be executed
|
|
83
|
-
return;
|
|
84
|
-
}
|
|
85
|
-
if (newNextSize < this.minNextSize) {
|
|
86
|
-
const diff = this.minNextSize - newNextSize;
|
|
87
|
-
newNextSize = this.minNextSize;
|
|
88
|
-
newPrevSize = this.startPrevSize + delta - diff;
|
|
89
|
-
// skip if next size is equal to the minimum size, note above code is dark code which will not be executed
|
|
90
|
-
return;
|
|
91
|
-
}
|
|
92
|
-
// Update sizes
|
|
93
|
-
this.prevSize = newPrevSize;
|
|
94
|
-
this.nextSize = newNextSize;
|
|
95
|
-
// Apply new sizes
|
|
96
|
-
if (this.usePercentage) {
|
|
97
|
-
const prevPercent = (newPrevSize / this.containerSize) * 100;
|
|
98
|
-
const nextPercent = (newNextSize / this.containerSize) * 100;
|
|
99
|
-
this.renderer.setStyle(this.prevElement, this.getSizeProperty(), `${prevPercent}%`);
|
|
100
|
-
this.renderer.setStyle(this.nextElement, this.getSizeProperty(), `${nextPercent}%`);
|
|
101
|
-
}
|
|
102
|
-
else {
|
|
103
|
-
this.renderer.setStyle(this.prevElement, this.getSizeProperty(), `${newPrevSize}px`);
|
|
104
|
-
this.renderer.setStyle(this.nextElement, this.getSizeProperty(), `${newNextSize}px`);
|
|
105
|
-
}
|
|
106
|
-
// Emit resizing event
|
|
107
|
-
this.resizing.emit({ prevSize: newPrevSize, nextSize: newNextSize });
|
|
108
|
-
};
|
|
109
|
-
this.onMouseUp = () => {
|
|
110
|
-
this.isResizing = false;
|
|
111
|
-
// Remove event listeners
|
|
112
|
-
document.removeEventListener('mousemove', this.onMouseMove);
|
|
113
|
-
document.removeEventListener('mouseup', this.onMouseUp);
|
|
114
|
-
// Restore text selection
|
|
115
|
-
document.body.style.userSelect = '';
|
|
116
|
-
// Emit resizeEnd event
|
|
117
|
-
if (this.prevElement && this.nextElement) {
|
|
118
|
-
this.resizeEnd.emit({ prevSize: this.prevSize, nextSize: this.nextSize });
|
|
119
|
-
}
|
|
120
|
-
// Remove visual feedback
|
|
121
|
-
this.renderer.removeClass(this.el.nativeElement, 'resizing');
|
|
122
|
-
};
|
|
123
|
-
}
|
|
124
|
-
ngOnInit() {
|
|
125
|
-
// Set cursor style based on direction
|
|
126
|
-
this.renderer.setStyle(this.el.nativeElement, 'cursor', this.direction === 'horizontal' ? 'ew-resize' : 'ns-resize');
|
|
127
|
-
// Add a class to help with styling
|
|
128
|
-
this.renderer.addClass(this.el.nativeElement, 'panel-resizer');
|
|
129
|
-
this.renderer.addClass(this.el.nativeElement, `panel-resizer-${this.direction}`);
|
|
130
|
-
this.renderer.addClass(this.el.nativeElement, `cide-lyt-devider-${this.direction}`);
|
|
131
|
-
if (this.to) {
|
|
132
|
-
this.renderer.addClass(this.el.nativeElement, `cide-lyt-devider-${this.direction}-${this.to}`);
|
|
133
|
-
}
|
|
134
|
-
}
|
|
135
|
-
onMouseDown(event) {
|
|
136
|
-
event.preventDefault();
|
|
137
|
-
// Get the elements to resize
|
|
138
|
-
this.prevElement = this.getPrevElement();
|
|
139
|
-
this.nextElement = this.getNextElement();
|
|
140
|
-
// if (!this.prevElement || !this.nextElement) {
|
|
141
|
-
// console.error('Could not find elements to resize');
|
|
142
|
-
// return;
|
|
143
|
-
// }
|
|
144
|
-
// Get container size
|
|
145
|
-
const parent = this.parentElementSelector ? document.querySelector(this.parentElementSelector) : this.el.nativeElement.parentElement;
|
|
146
|
-
if (parent) {
|
|
147
|
-
console.log(parent.offsetWidth, "parent.offsetWidth");
|
|
148
|
-
this.containerSize = this.direction === 'horizontal'
|
|
149
|
-
? parent.offsetWidth
|
|
150
|
-
: parent.offsetHeight;
|
|
151
|
-
}
|
|
152
|
-
// Store initial positions and sizes
|
|
153
|
-
this.startPosition = this.direction === 'horizontal' ? event.clientX : event.clientY;
|
|
154
|
-
if (this.prevElement) {
|
|
155
|
-
console.log(this.prevElement.offsetWidth, "this.prevElement.offsetWidth");
|
|
156
|
-
this.startPrevSize = this.direction === 'horizontal'
|
|
157
|
-
? this.prevElement.offsetWidth
|
|
158
|
-
: this.prevElement.offsetHeight;
|
|
159
|
-
}
|
|
160
|
-
if (this.nextElement) {
|
|
161
|
-
console.log(this.nextElement.offsetWidth, "this.nextElement.offsetWidth");
|
|
162
|
-
this.startNextSize = this.direction === 'horizontal'
|
|
163
|
-
? this.nextElement.offsetWidth
|
|
164
|
-
: this.nextElement.offsetHeight;
|
|
165
|
-
}
|
|
166
|
-
this.prevSize = this.startPrevSize;
|
|
167
|
-
this.nextSize = this.startNextSize;
|
|
168
|
-
this.isResizing = true;
|
|
169
|
-
// Add event listeners
|
|
170
|
-
document.addEventListener('mousemove', this.onMouseMove);
|
|
171
|
-
document.addEventListener('mouseup', this.onMouseUp);
|
|
172
|
-
// Disable text selection
|
|
173
|
-
document.body.style.userSelect = 'none';
|
|
174
|
-
// Emit resizeStart event
|
|
175
|
-
this.resizeStart.emit();
|
|
176
|
-
// Add visual feedback
|
|
177
|
-
this.renderer.addClass(this.el.nativeElement, 'resizing');
|
|
178
|
-
}
|
|
179
|
-
getPrevElement() {
|
|
180
|
-
if (this.prevElementSelector) {
|
|
181
|
-
const parent = this.parentElementSelector ? document.querySelector(this.parentElementSelector) : this.el.nativeElement.parentElement;
|
|
182
|
-
return parent?.querySelector(this.prevElementSelector) || null;
|
|
183
|
-
}
|
|
184
|
-
return this.el.nativeElement.previousElementSibling;
|
|
185
|
-
}
|
|
186
|
-
getNextElement() {
|
|
187
|
-
if (this.nextElementSelector) {
|
|
188
|
-
const parent = this.parentElementSelector ? document.querySelector(this.parentElementSelector) : this.el.nativeElement.parentElement;
|
|
189
|
-
return parent?.querySelector(this.nextElementSelector) || null;
|
|
190
|
-
}
|
|
191
|
-
return this.el.nativeElement.nextElementSibling;
|
|
192
|
-
}
|
|
193
|
-
getSizeProperty() {
|
|
194
|
-
return this.direction === 'horizontal' ? 'width' : 'height';
|
|
195
|
-
}
|
|
196
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: CideEleResizerDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
197
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.7", type: CideEleResizerDirective, isStandalone: true, selector: "[cideEleResizer]", inputs: { direction: "direction", to: "to", prevElementSelector: "prevElementSelector", nextElementSelector: "nextElementSelector", parentElementSelector: "parentElementSelector", minPrevSize: "minPrevSize", minNextSize: "minNextSize", usePercentage: "usePercentage" }, outputs: { resizeStart: "resizeStart", resizing: "resizing", resizeEnd: "resizeEnd" }, host: { listeners: { "mousedown": "onMouseDown($event)" } }, ngImport: i0 }); }
|
|
198
|
-
}
|
|
199
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: CideEleResizerDirective, decorators: [{
|
|
200
|
-
type: Directive,
|
|
201
|
-
args: [{
|
|
202
|
-
selector: '[cideEleResizer]',
|
|
203
|
-
standalone: true
|
|
204
|
-
}]
|
|
205
|
-
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }], propDecorators: { direction: [{
|
|
206
|
-
type: Input
|
|
207
|
-
}], to: [{
|
|
208
|
-
type: Input
|
|
209
|
-
}], prevElementSelector: [{
|
|
210
|
-
type: Input
|
|
211
|
-
}], nextElementSelector: [{
|
|
212
|
-
type: Input
|
|
213
|
-
}], parentElementSelector: [{
|
|
214
|
-
type: Input
|
|
215
|
-
}], minPrevSize: [{
|
|
216
|
-
type: Input
|
|
217
|
-
}], minNextSize: [{
|
|
218
|
-
type: Input
|
|
219
|
-
}], usePercentage: [{
|
|
220
|
-
type: Input
|
|
221
|
-
}], resizeStart: [{
|
|
222
|
-
type: Output
|
|
223
|
-
}], resizing: [{
|
|
224
|
-
type: Output
|
|
225
|
-
}], resizeEnd: [{
|
|
226
|
-
type: Output
|
|
227
|
-
}], onMouseDown: [{
|
|
228
|
-
type: HostListener,
|
|
229
|
-
args: ['mousedown', ['$event']]
|
|
230
|
-
}] } });
|
|
231
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resizer.directive.js","sourceRoot":"","sources":["../../../../../../../projects/cloud-ide-element/src/lib/utils/directives/resizer/resizer.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, EventEmitter, HostListener, Input, OnInit, Output, Renderer2 } from '@angular/core';\r\n\r\nexport type CideEleResizerDirection = 'horizontal' | 'vertical';\r\nexport type CideEleResizerDirectionTo = \"right-to-left\" | \"left-to-right\" | \"\";\r\n\r\n@Directive({\r\n  selector: '[cideEleResizer]',\r\n  standalone: true\r\n})\r\n\r\n/**\r\n<!-- Basic horizontal (left-right) layout -->\r\n<div class=\"panel-container\">\r\n    <div class=\"left-panel\">\r\n        Left Panel Content\r\n    </div>\r\n\r\n    <div cideEleResizer direction=\"horizontal\" [minPrevSize]=\"100\" [minNextSize]=\"100\">resize\r\n    </div>\r\n\r\n    <div class=\"right-panel\">\r\n        Right Panel Content\r\n    </div>\r\n</div>\r\n\r\n<!-- Basic vertical (top-bottom) layout -->\r\n<div class=\"panel-container-vertical\">\r\n    <div class=\"top-panel\">\r\n        Top Panel Content\r\n    </div>\r\n\r\n    <div cideEleResizer direction=\"vertical\" [minPrevSize]=\"50\" [minNextSize]=\"50\">resize\r\n    </div>\r\n\r\n    <div class=\"bottom-panel\">\r\n        Bottom Panel Content\r\n    </div>\r\n</div>\r\n\r\n<!-- Using with custom selectors -->\r\n<div class=\"complex-layout\">\r\n    <div id=\"panel1\">Panel 1</div>\r\n    <div id=\"panel2\">Panel 2</div>\r\n\r\n    <div cideEleResizer direction=\"horizontal\" prevElementSelector=\"#panel1\" nextElementSelector=\"#panel2\"\r\n        [usePercentage]=\"true\">resize\r\n    </div>\r\n\r\n    <div id=\"panel3\">Panel 3</div>\r\n</div>\r\n */\r\nexport class CideEleResizerDirective implements OnInit {\r\n  @Input() direction: CideEleResizerDirection = 'horizontal';\r\n  @Input() to: CideEleResizerDirectionTo = \"\";\r\n  @Input() prevElementSelector = '';  // Selector for previous element\r\n  @Input() nextElementSelector = '';  // Selector for next element\r\n  @Input() parentElementSelector = '';  // Selector for parent element\r\n  @Input() minPrevSize = 0;           // Minimum size of previous element (px)\r\n  @Input() minNextSize = 0;           // Minimum size of next element (px)\r\n  @Input() usePercentage = false;     // Use percentage instead of pixels\r\n  @Output() resizeStart = new EventEmitter<void>();\r\n  @Output() resizing = new EventEmitter<{ prevSize: number, nextSize: number }>();\r\n  @Output() resizeEnd = new EventEmitter<{ prevSize: number, nextSize: number }>();\r\n\r\n  private isResizing = false;\r\n  private startPosition = 0;\r\n  private prevElement: HTMLElement | null = null;\r\n  private nextElement: HTMLElement | null = null;\r\n  private prevSize = 0;\r\n  private nextSize = 0;\r\n  private containerSize = 0;\r\n  private startPrevSize = 0;\r\n  private startNextSize = 0;\r\n\r\n  constructor(private el: ElementRef, private renderer: Renderer2) { }\r\n\r\n  ngOnInit() {\r\n    // Set cursor style based on direction\r\n    this.renderer.setStyle(\r\n      this.el.nativeElement,\r\n      'cursor',\r\n      this.direction === 'horizontal' ? 'ew-resize' : 'ns-resize'\r\n    );\r\n\r\n    // Add a class to help with styling\r\n    this.renderer.addClass(this.el.nativeElement, 'panel-resizer');\r\n    this.renderer.addClass(this.el.nativeElement, `panel-resizer-${this.direction}`);\r\n    this.renderer.addClass(this.el.nativeElement, `cide-lyt-devider-${this.direction}`);\r\n    if (this.to) {\r\n      this.renderer.addClass(this.el.nativeElement, `cide-lyt-devider-${this.direction}-${this.to}`);\r\n    }\r\n  }\r\n\r\n  @HostListener('mousedown', ['$event'])\r\n  onMouseDown(event: MouseEvent) {\r\n    event.preventDefault();\r\n\r\n    // Get the elements to resize\r\n    this.prevElement = this.getPrevElement();\r\n    this.nextElement = this.getNextElement();\r\n\r\n    // if (!this.prevElement || !this.nextElement) {\r\n    //   console.error('Could not find elements to resize');\r\n    //   return;\r\n    // }\r\n\r\n    // Get container size\r\n\r\n    const parent = this.parentElementSelector ? document.querySelector(this.parentElementSelector) : this.el.nativeElement.parentElement;\r\n    if (parent) {\r\n      console.log(parent.offsetWidth, \"parent.offsetWidth\")\r\n      this.containerSize = this.direction === 'horizontal'\r\n        ? parent.offsetWidth\r\n        : parent.offsetHeight;\r\n    }\r\n\r\n    \r\n    // Store initial positions and sizes\r\n    this.startPosition = this.direction === 'horizontal' ? event.clientX : event.clientY;\r\n    if (this.prevElement) {\r\n      console.log(this.prevElement.offsetWidth, \"this.prevElement.offsetWidth\")\r\n      this.startPrevSize = this.direction === 'horizontal'\r\n        ? this.prevElement.offsetWidth\r\n        : this.prevElement.offsetHeight;\r\n    }\r\n    if (this.nextElement) {\r\n      console.log(this.nextElement.offsetWidth, \"this.nextElement.offsetWidth\")\r\n      this.startNextSize = this.direction === 'horizontal'\r\n        ? this.nextElement.offsetWidth\r\n        : this.nextElement.offsetHeight;\r\n    }\r\n\r\n    this.prevSize = this.startPrevSize;\r\n    this.nextSize = this.startNextSize;\r\n\r\n    this.isResizing = true;\r\n\r\n    // Add event listeners\r\n    document.addEventListener('mousemove', this.onMouseMove);\r\n    document.addEventListener('mouseup', this.onMouseUp);\r\n\r\n    // Disable text selection\r\n    document.body.style.userSelect = 'none';\r\n\r\n    // Emit resizeStart event\r\n    this.resizeStart.emit();\r\n\r\n    // Add visual feedback\r\n    this.renderer.addClass(this.el.nativeElement, 'resizing');\r\n  }\r\n\r\n  private onMouseMove = (event: MouseEvent) => {\r\n    if (!this.isResizing) return;\r\n\r\n    // Calculate movement\r\n    const currentPosition = this.direction === 'horizontal' ? event.clientX : event.clientY;\r\n    const delta = currentPosition - this.startPosition;\r\n\r\n    // Calculate new sizes\r\n    let newPrevSize = this.startPrevSize + delta;\r\n    let newNextSize = this.startNextSize - delta;\r\n\r\n    // Apply constraints\r\n    if (newPrevSize < this.minPrevSize) {\r\n      const diff = this.minPrevSize - newPrevSize;\r\n      newPrevSize = this.minPrevSize;\r\n      newNextSize = this.startNextSize - delta + diff;\r\n      // skip if previsus size is equal to the minimum size, note above code is dark code which will not be executed\r\n      return;\r\n    }\r\n\r\n    if (newNextSize < this.minNextSize) {\r\n      const diff = this.minNextSize - newNextSize;\r\n      newNextSize = this.minNextSize;\r\n      newPrevSize = this.startPrevSize + delta - diff;\r\n      // skip if next size is equal to the minimum size, note above code is dark code which will not be executed\r\n      return;\r\n    }\r\n\r\n    // Update sizes\r\n    this.prevSize = newPrevSize;\r\n    this.nextSize = newNextSize;\r\n\r\n    // Apply new sizes\r\n    if (this.usePercentage) {\r\n      const prevPercent = (newPrevSize / this.containerSize) * 100;\r\n      const nextPercent = (newNextSize / this.containerSize) * 100;\r\n\r\n      this.renderer.setStyle(this.prevElement, this.getSizeProperty(), `${prevPercent}%`);\r\n      this.renderer.setStyle(this.nextElement, this.getSizeProperty(), `${nextPercent}%`);\r\n    } else {\r\n      this.renderer.setStyle(this.prevElement, this.getSizeProperty(), `${newPrevSize}px`);\r\n      this.renderer.setStyle(this.nextElement, this.getSizeProperty(), `${newNextSize}px`);\r\n    }\r\n\r\n    // Emit resizing event\r\n    this.resizing.emit({ prevSize: newPrevSize, nextSize: newNextSize });\r\n  }\r\n\r\n  private onMouseUp = () => {\r\n    this.isResizing = false;\r\n\r\n    // Remove event listeners\r\n    document.removeEventListener('mousemove', this.onMouseMove);\r\n    document.removeEventListener('mouseup', this.onMouseUp);\r\n\r\n    // Restore text selection\r\n    document.body.style.userSelect = '';\r\n\r\n    // Emit resizeEnd event\r\n    if (this.prevElement && this.nextElement) {\r\n      this.resizeEnd.emit({ prevSize: this.prevSize, nextSize: this.nextSize });\r\n    }\r\n\r\n    // Remove visual feedback\r\n    this.renderer.removeClass(this.el.nativeElement, 'resizing');\r\n  }\r\n\r\n  private getPrevElement(): HTMLElement | null {\r\n    if (this.prevElementSelector) {\r\n      const parent = this.parentElementSelector ? document.querySelector(this.parentElementSelector) : this.el.nativeElement.parentElement;\r\n      return parent?.querySelector(this.prevElementSelector) || null;\r\n    }\r\n    return this.el.nativeElement.previousElementSibling as HTMLElement;\r\n  }\r\n\r\n  private getNextElement(): HTMLElement | null {\r\n    if (this.nextElementSelector) {\r\n      const parent = this.parentElementSelector ? document.querySelector(this.parentElementSelector) : this.el.nativeElement.parentElement;\r\n      return parent?.querySelector(this.nextElementSelector) || null;\r\n    }\r\n    return this.el.nativeElement.nextElementSibling as HTMLElement;\r\n  }\r\n\r\n  private getSizeProperty(): string {\r\n    return this.direction === 'horizontal' ? 'width' : 'height';\r\n  }\r\n}"]}
|