@libs-ui/components-drag-drop 0.1.1-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.
- package/README.md +451 -0
- package/defines/css.define.d.ts +4 -0
- package/demo/demo.component.d.ts +56 -0
- package/drag-drop.directive.d.ts +39 -0
- package/drag-drop.service.d.ts +45 -0
- package/drag-item-in-container-virtual-scroll.directive.d.ts +25 -0
- package/drag-item.directive.d.ts +30 -0
- package/drag-scroll.directive.d.ts +24 -0
- package/esm2022/defines/css.define.mjs +104 -0
- package/esm2022/demo/demo.component.mjs +833 -0
- package/esm2022/drag-drop.directive.mjs +482 -0
- package/esm2022/drag-drop.service.mjs +96 -0
- package/esm2022/drag-item-in-container-virtual-scroll.directive.mjs +134 -0
- package/esm2022/drag-item.directive.mjs +267 -0
- package/esm2022/drag-scroll.directive.mjs +144 -0
- package/esm2022/index.mjs +7 -0
- package/esm2022/interfaces/event.interface.mjs +2 -0
- package/esm2022/libs-ui-components-drag-drop.mjs +5 -0
- package/fesm2022/libs-ui-components-drag-drop.mjs +2043 -0
- package/fesm2022/libs-ui-components-drag-drop.mjs.map +1 -0
- package/index.d.ts +6 -0
- package/interfaces/event.interface.d.ts +60 -0
- package/package.json +28 -0
|
@@ -0,0 +1,833 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { Component } from '@angular/core';
|
|
3
|
+
import { LibsUiComponentsButtonsButtonComponent } from '@libs-ui/components-buttons-button';
|
|
4
|
+
import { LibsUiComponentsDragContainerDirective } from '../drag-drop.directive';
|
|
5
|
+
import { LibsUiDragItemDirective } from '../drag-item.directive';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
export class LibsUiDragDropDemoComponent {
|
|
8
|
+
// Basic List Items
|
|
9
|
+
basicItems = ['Task 1', 'Task 2', 'Task 3', 'Task 4', 'Task 5'];
|
|
10
|
+
// Kanban Board Columns
|
|
11
|
+
columnsIds = ['todo', 'in-progress', 'done'];
|
|
12
|
+
columns = [
|
|
13
|
+
{
|
|
14
|
+
id: 'todo',
|
|
15
|
+
title: 'To Do',
|
|
16
|
+
items: [
|
|
17
|
+
{
|
|
18
|
+
id: 1,
|
|
19
|
+
title: 'Implement drag and drop',
|
|
20
|
+
description: 'Add drag and drop functionality to the component',
|
|
21
|
+
status: 'todo',
|
|
22
|
+
},
|
|
23
|
+
{
|
|
24
|
+
id: 2,
|
|
25
|
+
title: 'Add animations',
|
|
26
|
+
description: 'Implement smooth animations for drag and drop',
|
|
27
|
+
status: 'todo',
|
|
28
|
+
},
|
|
29
|
+
],
|
|
30
|
+
},
|
|
31
|
+
{
|
|
32
|
+
id: 'in-progress',
|
|
33
|
+
title: 'In Progress',
|
|
34
|
+
items: [
|
|
35
|
+
{
|
|
36
|
+
id: 3,
|
|
37
|
+
title: 'Fix styling issues',
|
|
38
|
+
description: 'Resolve CSS conflicts in the component',
|
|
39
|
+
status: 'in-progress',
|
|
40
|
+
},
|
|
41
|
+
],
|
|
42
|
+
},
|
|
43
|
+
{
|
|
44
|
+
id: 'done',
|
|
45
|
+
title: 'Done',
|
|
46
|
+
items: [
|
|
47
|
+
{
|
|
48
|
+
id: 4,
|
|
49
|
+
title: 'Setup project structure',
|
|
50
|
+
description: 'Initialize the project with necessary configurations',
|
|
51
|
+
status: 'done',
|
|
52
|
+
},
|
|
53
|
+
],
|
|
54
|
+
},
|
|
55
|
+
];
|
|
56
|
+
// Nested Items
|
|
57
|
+
nestedItems = [
|
|
58
|
+
{
|
|
59
|
+
id: 1,
|
|
60
|
+
title: 'Project A',
|
|
61
|
+
subItems: ['Task 1', 'Task 2', 'Task 3'],
|
|
62
|
+
},
|
|
63
|
+
{
|
|
64
|
+
id: 2,
|
|
65
|
+
title: 'Project B',
|
|
66
|
+
subItems: ['Task 4', 'Task 5'],
|
|
67
|
+
},
|
|
68
|
+
{
|
|
69
|
+
id: 3,
|
|
70
|
+
title: 'Project C',
|
|
71
|
+
subItems: ['Task 6', 'Task 7', 'Task 8'],
|
|
72
|
+
},
|
|
73
|
+
];
|
|
74
|
+
// API Documentation
|
|
75
|
+
inputsDoc = [
|
|
76
|
+
{
|
|
77
|
+
name: 'items',
|
|
78
|
+
type: 'Array<unknown>',
|
|
79
|
+
default: '[]',
|
|
80
|
+
description: 'Array of items to be displayed in the container',
|
|
81
|
+
},
|
|
82
|
+
{
|
|
83
|
+
name: 'mode',
|
|
84
|
+
type: "'move' | 'copy' | 'deepCopy'",
|
|
85
|
+
default: "'move'",
|
|
86
|
+
description: 'Mode for drag and drop operations',
|
|
87
|
+
},
|
|
88
|
+
{
|
|
89
|
+
name: 'directionDrag',
|
|
90
|
+
type: "'horizontal' | 'vertical'",
|
|
91
|
+
default: 'undefined',
|
|
92
|
+
description: 'Direction of drag movement',
|
|
93
|
+
},
|
|
94
|
+
{
|
|
95
|
+
name: 'viewEncapsulation',
|
|
96
|
+
type: "'emulated' | 'none'",
|
|
97
|
+
default: "'emulated'",
|
|
98
|
+
description: 'View encapsulation mode for styling',
|
|
99
|
+
},
|
|
100
|
+
{
|
|
101
|
+
name: 'disableDragContainer',
|
|
102
|
+
type: 'boolean',
|
|
103
|
+
default: 'undefined',
|
|
104
|
+
description: 'Whether to disable drag operations for the container',
|
|
105
|
+
},
|
|
106
|
+
{
|
|
107
|
+
name: 'acceptDragSameGroup',
|
|
108
|
+
type: 'boolean',
|
|
109
|
+
default: 'false',
|
|
110
|
+
description: 'Whether to accept drag operations within the same group',
|
|
111
|
+
},
|
|
112
|
+
{
|
|
113
|
+
name: 'placeholder',
|
|
114
|
+
type: 'boolean',
|
|
115
|
+
default: 'true',
|
|
116
|
+
description: 'Whether to show placeholder during drag',
|
|
117
|
+
},
|
|
118
|
+
{
|
|
119
|
+
name: 'groupName',
|
|
120
|
+
type: 'string',
|
|
121
|
+
default: "'groupDragAndDropDefault'",
|
|
122
|
+
description: 'Name of the group for drag and drop operations',
|
|
123
|
+
},
|
|
124
|
+
{
|
|
125
|
+
name: 'dropToGroupName',
|
|
126
|
+
type: 'Array<string> | null',
|
|
127
|
+
default: 'null',
|
|
128
|
+
description: 'List of group names that can accept drops from this container',
|
|
129
|
+
},
|
|
130
|
+
{
|
|
131
|
+
name: 'stylesOverride',
|
|
132
|
+
type: 'Array<{ className: string, styles: string }>',
|
|
133
|
+
default: 'undefined',
|
|
134
|
+
description: 'Custom styles to override default drag-drop styling',
|
|
135
|
+
},
|
|
136
|
+
];
|
|
137
|
+
outputsDoc = [
|
|
138
|
+
{
|
|
139
|
+
name: 'outDragStartContainer',
|
|
140
|
+
type: 'IDragStart',
|
|
141
|
+
description: 'Event emitted when dragging starts in the container',
|
|
142
|
+
},
|
|
143
|
+
{
|
|
144
|
+
name: 'outDragOverContainer',
|
|
145
|
+
type: 'IDragOver',
|
|
146
|
+
description: 'Event emitted when dragging over the container',
|
|
147
|
+
},
|
|
148
|
+
{
|
|
149
|
+
name: 'outDragLeaveContainer',
|
|
150
|
+
type: 'IDragLeave',
|
|
151
|
+
description: 'Event emitted when dragging leaves the container',
|
|
152
|
+
},
|
|
153
|
+
{
|
|
154
|
+
name: 'outDragEndContainer',
|
|
155
|
+
type: 'IDragEnd',
|
|
156
|
+
description: 'Event emitted when dragging ends in the container',
|
|
157
|
+
},
|
|
158
|
+
{
|
|
159
|
+
name: 'outDroppedContainer',
|
|
160
|
+
type: 'IDrop',
|
|
161
|
+
description: 'Event emitted when an item is dropped in the container',
|
|
162
|
+
},
|
|
163
|
+
{
|
|
164
|
+
name: 'outDroppedContainerEmpty',
|
|
165
|
+
type: 'IDrop',
|
|
166
|
+
description: 'Event emitted when an item is dropped in an empty container',
|
|
167
|
+
},
|
|
168
|
+
{
|
|
169
|
+
name: 'outFunctionControl',
|
|
170
|
+
type: 'IDragDropFunctionControlEvent',
|
|
171
|
+
description: 'Event emitted to control drag-drop functionality',
|
|
172
|
+
},
|
|
173
|
+
];
|
|
174
|
+
// Interface Documentation
|
|
175
|
+
interfacesDoc = [
|
|
176
|
+
{
|
|
177
|
+
name: 'IDragging',
|
|
178
|
+
code: `interface IDragging {
|
|
179
|
+
mousePosition: IMousePosition;
|
|
180
|
+
elementDrag: HTMLElement;
|
|
181
|
+
elementKeepContainer?: boolean;
|
|
182
|
+
itemDragInfo?: IItemDragInfo;
|
|
183
|
+
}`,
|
|
184
|
+
description: 'Interface for drag operation events, containing information about the dragged element and mouse position',
|
|
185
|
+
},
|
|
186
|
+
{
|
|
187
|
+
name: 'IDragStart',
|
|
188
|
+
code: `interface IDragStart {
|
|
189
|
+
mousePosition: IMousePosition;
|
|
190
|
+
elementDrag: HTMLElement;
|
|
191
|
+
itemDragInfo?: IItemDragInfo;
|
|
192
|
+
}`,
|
|
193
|
+
description: 'Interface for drag start events, triggered when dragging begins',
|
|
194
|
+
},
|
|
195
|
+
{
|
|
196
|
+
name: 'IDragOver',
|
|
197
|
+
code: `interface IDragOver {
|
|
198
|
+
mousePosition: IMousePosition;
|
|
199
|
+
elementDrag: HTMLElement;
|
|
200
|
+
elementDragOver: HTMLElement;
|
|
201
|
+
itemDragInfo?: IItemDragInfo;
|
|
202
|
+
}`,
|
|
203
|
+
description: 'Interface for drag over events, triggered when an element is dragged over another element',
|
|
204
|
+
},
|
|
205
|
+
{
|
|
206
|
+
name: 'IDragLeave',
|
|
207
|
+
code: `interface IDragLeave {
|
|
208
|
+
elementDrag: HTMLElement;
|
|
209
|
+
elementDragLeave: HTMLElement;
|
|
210
|
+
itemDragInfo?: IItemDragInfo;
|
|
211
|
+
}`,
|
|
212
|
+
description: 'Interface for drag leave events, triggered when a dragged element leaves another element',
|
|
213
|
+
},
|
|
214
|
+
{
|
|
215
|
+
name: 'IDragEnd',
|
|
216
|
+
code: `interface IDragEnd {
|
|
217
|
+
mousePosition: IMousePosition;
|
|
218
|
+
elementDrag: HTMLElement;
|
|
219
|
+
itemDragInfo?: IItemDragInfo;
|
|
220
|
+
}`,
|
|
221
|
+
description: 'Interface for drag end events, triggered when dragging ends',
|
|
222
|
+
},
|
|
223
|
+
{
|
|
224
|
+
name: 'IDrop',
|
|
225
|
+
code: `interface IDrop {
|
|
226
|
+
elementDrag: HTMLElement;
|
|
227
|
+
elementDrop: HTMLElement;
|
|
228
|
+
itemDragInfo?: IItemDragInfo;
|
|
229
|
+
}`,
|
|
230
|
+
description: 'Interface for drop events, triggered when an element is dropped',
|
|
231
|
+
},
|
|
232
|
+
{
|
|
233
|
+
name: 'IItemDragInfo',
|
|
234
|
+
code: `interface IItemDragInfo {
|
|
235
|
+
item: object;
|
|
236
|
+
itemsMove?: WritableSignal<Array<unknown>>;
|
|
237
|
+
indexDrag?: number;
|
|
238
|
+
indexDrop?: number;
|
|
239
|
+
itemsDrag: WritableSignal<Array<unknown>>;
|
|
240
|
+
itemsDrop?: WritableSignal<Array<unknown>>;
|
|
241
|
+
containerDrag?: HTMLElement;
|
|
242
|
+
containerDrop?: HTMLElement;
|
|
243
|
+
}`,
|
|
244
|
+
description: 'Interface containing information about the dragged item and its containers',
|
|
245
|
+
},
|
|
246
|
+
{
|
|
247
|
+
name: 'IDragItemInContainerVirtualScroll',
|
|
248
|
+
code: `interface IDragItemInContainerVirtualScroll {
|
|
249
|
+
itemDragInfo?: IItemDragInfo;
|
|
250
|
+
elementDrag: HTMLElement;
|
|
251
|
+
distanceStartElementAndMouseTop: number;
|
|
252
|
+
distanceStartElementAndMouseLeft: number;
|
|
253
|
+
elementContainer?: HTMLElement;
|
|
254
|
+
dragBoundary?: boolean;
|
|
255
|
+
dragBoundaryAcceptMouseLeaveContainer?: boolean;
|
|
256
|
+
ignoreStopEvent?: boolean;
|
|
257
|
+
}`,
|
|
258
|
+
description: 'Interface for virtual scrolling drag operations, containing information about drag boundaries and container elements',
|
|
259
|
+
},
|
|
260
|
+
{
|
|
261
|
+
name: 'IMousePosition',
|
|
262
|
+
code: `interface IMousePosition {
|
|
263
|
+
clientX: number;
|
|
264
|
+
clientY: number;
|
|
265
|
+
}`,
|
|
266
|
+
description: 'Interface representing mouse position coordinates',
|
|
267
|
+
},
|
|
268
|
+
{
|
|
269
|
+
name: 'IDragDropFunctionControlEvent',
|
|
270
|
+
code: `interface IDragDropFunctionControlEvent {
|
|
271
|
+
setAttributeElementAndItemDrag: () => Promise<void>;
|
|
272
|
+
}`,
|
|
273
|
+
description: 'Interface for drag and drop control functions',
|
|
274
|
+
},
|
|
275
|
+
];
|
|
276
|
+
// Features
|
|
277
|
+
features = [
|
|
278
|
+
{
|
|
279
|
+
id: 1,
|
|
280
|
+
icon: '🔄',
|
|
281
|
+
title: 'Flexible Drag and Drop',
|
|
282
|
+
description: 'Support for container-to-container dragging with customizable group names and drop zones',
|
|
283
|
+
},
|
|
284
|
+
{
|
|
285
|
+
id: 2,
|
|
286
|
+
icon: '📜',
|
|
287
|
+
title: 'Virtual Scrolling',
|
|
288
|
+
description: 'Efficient handling of large lists with virtual scrolling support',
|
|
289
|
+
},
|
|
290
|
+
{
|
|
291
|
+
id: 3,
|
|
292
|
+
icon: '🎯',
|
|
293
|
+
title: 'Custom Boundaries',
|
|
294
|
+
description: 'Define custom drag boundaries and drop zones for precise control',
|
|
295
|
+
},
|
|
296
|
+
{
|
|
297
|
+
id: 4,
|
|
298
|
+
icon: '🎨',
|
|
299
|
+
title: 'Styling Options',
|
|
300
|
+
description: 'Customizable styles for drag items and containers',
|
|
301
|
+
},
|
|
302
|
+
];
|
|
303
|
+
// Code Examples
|
|
304
|
+
codeExamples = [
|
|
305
|
+
{
|
|
306
|
+
id: 1,
|
|
307
|
+
title: 'Basic Usage',
|
|
308
|
+
code: `<div LibsUiComponentsDragContainerDirective
|
|
309
|
+
[(items)]="items"
|
|
310
|
+
[groupName]="'myGroup'"
|
|
311
|
+
[acceptDragSameGroup]="true">
|
|
312
|
+
@for (item of items; track item) {
|
|
313
|
+
<div LibsUiDragItemDirective>
|
|
314
|
+
{{ item }}
|
|
315
|
+
</div>
|
|
316
|
+
}
|
|
317
|
+
</div>`,
|
|
318
|
+
},
|
|
319
|
+
{
|
|
320
|
+
id: 2,
|
|
321
|
+
title: 'Container-to-Container',
|
|
322
|
+
code: `<div LibsUiComponentsDragContainerDirective
|
|
323
|
+
[(items)]="sourceItems"
|
|
324
|
+
[groupName]="'source'">
|
|
325
|
+
@for (item of sourceItems; track item) {
|
|
326
|
+
<div LibsUiDragItemDirective>
|
|
327
|
+
{{ item }}
|
|
328
|
+
</div>
|
|
329
|
+
}
|
|
330
|
+
</div>
|
|
331
|
+
|
|
332
|
+
<div LibsUiComponentsDragContainerDirective
|
|
333
|
+
[(items)]="targetItems"
|
|
334
|
+
[groupName]="'target'"
|
|
335
|
+
[dropToGroupName]="['source']">
|
|
336
|
+
@for (item of targetItems; track item) {
|
|
337
|
+
<div LibsUiDragItemDirective>
|
|
338
|
+
{{ item }}
|
|
339
|
+
</div>
|
|
340
|
+
}
|
|
341
|
+
</div>`,
|
|
342
|
+
},
|
|
343
|
+
];
|
|
344
|
+
/**
|
|
345
|
+
* Copy text to clipboard
|
|
346
|
+
*/
|
|
347
|
+
copyToClipboard(text) {
|
|
348
|
+
navigator.clipboard.writeText(text).then(() => {
|
|
349
|
+
alert('Copied to clipboard');
|
|
350
|
+
}, (err) => {
|
|
351
|
+
console.error('Could not copy text: ', err);
|
|
352
|
+
});
|
|
353
|
+
}
|
|
354
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: LibsUiDragDropDemoComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
355
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: LibsUiDragDropDemoComponent, isStandalone: true, selector: "lib-drag-drop-demo", ngImport: i0, template: `
|
|
356
|
+
<div class="page-container">
|
|
357
|
+
<header>
|
|
358
|
+
<h1>Demo Drag and Drop Component</h1>
|
|
359
|
+
<p>Angular component library for drag and drop functionality</p>
|
|
360
|
+
</header>
|
|
361
|
+
|
|
362
|
+
<main>
|
|
363
|
+
<section class="intro-section">
|
|
364
|
+
<h2>Introduction</h2>
|
|
365
|
+
<p>
|
|
366
|
+
<code>@libs-ui/components-drag-drop</code>
|
|
367
|
+
is a powerful Angular component that enables drag and drop functionality with features like virtual scrolling, multi-selection, and custom boundaries.
|
|
368
|
+
</p>
|
|
369
|
+
</section>
|
|
370
|
+
|
|
371
|
+
<section class="installation-section">
|
|
372
|
+
<h2>Installation</h2>
|
|
373
|
+
<p>To install the library, use npm or yarn:</p>
|
|
374
|
+
|
|
375
|
+
<div class="install-command">
|
|
376
|
+
<pre>
|
|
377
|
+
<code>npm install @libs-ui/components-drag-drop</code>
|
|
378
|
+
<libs_ui-components-buttons-button
|
|
379
|
+
[label]="'Copy'"
|
|
380
|
+
(outClick)="copyToClipboard('npm install @libs-ui/components-drag-drop')" />
|
|
381
|
+
</pre>
|
|
382
|
+
</div>
|
|
383
|
+
|
|
384
|
+
<p>Or with yarn:</p>
|
|
385
|
+
|
|
386
|
+
<div class="install-command">
|
|
387
|
+
<pre>
|
|
388
|
+
<code>yarn add @libs-ui/components-drag-drop</code>
|
|
389
|
+
<libs_ui-components-buttons-button
|
|
390
|
+
[label]="'Copy'"
|
|
391
|
+
(outClick)="copyToClipboard('yarn add @libs-ui/components-drag-drop')" />
|
|
392
|
+
</pre>
|
|
393
|
+
</div>
|
|
394
|
+
</section>
|
|
395
|
+
|
|
396
|
+
<section class="demo-section">
|
|
397
|
+
<h2>Live Demo</h2>
|
|
398
|
+
<div class="demo-container">
|
|
399
|
+
<!-- Basic List Demo -->
|
|
400
|
+
<div class="demo-example">
|
|
401
|
+
<h3>Basic List</h3>
|
|
402
|
+
<div class="list-container">
|
|
403
|
+
<div
|
|
404
|
+
LibsUiComponentsDragContainerDirective
|
|
405
|
+
[(items)]="basicItems"
|
|
406
|
+
[acceptDragSameGroup]="true">
|
|
407
|
+
@for (item of basicItems; track item) {
|
|
408
|
+
<div
|
|
409
|
+
class="list-item"
|
|
410
|
+
LibsUiDragItemDirective>
|
|
411
|
+
<span class="item-icon">📋</span>
|
|
412
|
+
<span class="item-text">{{ item }}</span>
|
|
413
|
+
</div>
|
|
414
|
+
}
|
|
415
|
+
</div>
|
|
416
|
+
</div>
|
|
417
|
+
</div>
|
|
418
|
+
|
|
419
|
+
<!-- Kanban Board Demo -->
|
|
420
|
+
<div class="demo-example">
|
|
421
|
+
<h3>Kanban Board</h3>
|
|
422
|
+
<div class="kanban-board">
|
|
423
|
+
@for (column of columns; track column) {
|
|
424
|
+
<div
|
|
425
|
+
class="kanban-column"
|
|
426
|
+
LibsUiComponentsDragContainerDirective
|
|
427
|
+
[(items)]="column.items"
|
|
428
|
+
[groupName]="column.id"
|
|
429
|
+
[dropToGroupName]="columnsIds"
|
|
430
|
+
[acceptDragSameGroup]="true">
|
|
431
|
+
<h4>{{ column.title }}</h4>
|
|
432
|
+
@for (item of column.items; track item) {
|
|
433
|
+
<div
|
|
434
|
+
class="kanban-item"
|
|
435
|
+
LibsUiDragItemDirective>
|
|
436
|
+
<div class="kanban-item-header">
|
|
437
|
+
<span class="item-title">{{ item.title }}</span>
|
|
438
|
+
<span
|
|
439
|
+
class="item-status"
|
|
440
|
+
[class]="'status-' + item.status">
|
|
441
|
+
{{ item.status }}
|
|
442
|
+
</span>
|
|
443
|
+
</div>
|
|
444
|
+
<p class="item-description">{{ item.description }}</p>
|
|
445
|
+
</div>
|
|
446
|
+
}
|
|
447
|
+
</div>
|
|
448
|
+
}
|
|
449
|
+
</div>
|
|
450
|
+
</div>
|
|
451
|
+
|
|
452
|
+
<!-- Nested Containers Demo -->
|
|
453
|
+
<div class="demo-example">
|
|
454
|
+
<h3>Nested Containers copy</h3>
|
|
455
|
+
<div class="nested-container">
|
|
456
|
+
<div
|
|
457
|
+
LibsUiComponentsDragContainerDirective
|
|
458
|
+
[(items)]="nestedItems"
|
|
459
|
+
[groupName]="'parent'"
|
|
460
|
+
[mode]="'copy'"
|
|
461
|
+
[acceptDragSameGroup]="true">
|
|
462
|
+
@for (item of nestedItems; track item) {
|
|
463
|
+
<div
|
|
464
|
+
class="nested-item"
|
|
465
|
+
LibsUiDragItemDirective>
|
|
466
|
+
<div class="nested-item-header">
|
|
467
|
+
<span class="item-title">{{ item.title }}</span>
|
|
468
|
+
</div>
|
|
469
|
+
<div class="nested-item-content">
|
|
470
|
+
<div
|
|
471
|
+
LibsUiComponentsDragContainerDirective
|
|
472
|
+
[(items)]="item.subItems"
|
|
473
|
+
[groupName]="'child'"
|
|
474
|
+
[acceptDragSameGroup]="true">
|
|
475
|
+
@for (subItem of item.subItems; track subItem) {
|
|
476
|
+
<div
|
|
477
|
+
class="sub-item"
|
|
478
|
+
LibsUiDragItemDirective>
|
|
479
|
+
{{ subItem }}
|
|
480
|
+
</div>
|
|
481
|
+
}
|
|
482
|
+
</div>
|
|
483
|
+
</div>
|
|
484
|
+
</div>
|
|
485
|
+
}
|
|
486
|
+
</div>
|
|
487
|
+
</div>
|
|
488
|
+
</div>
|
|
489
|
+
</div>
|
|
490
|
+
</section>
|
|
491
|
+
|
|
492
|
+
<section class="api-doc-section">
|
|
493
|
+
<h2>API Documentation</h2>
|
|
494
|
+
|
|
495
|
+
<h3>Inputs</h3>
|
|
496
|
+
<div class="table-container">
|
|
497
|
+
<table class="api-table">
|
|
498
|
+
<thead>
|
|
499
|
+
<tr>
|
|
500
|
+
<th>Name</th>
|
|
501
|
+
<th>Type</th>
|
|
502
|
+
<th>Default</th>
|
|
503
|
+
<th>Description</th>
|
|
504
|
+
</tr>
|
|
505
|
+
</thead>
|
|
506
|
+
<tbody>
|
|
507
|
+
@for (input of inputsDoc; track input.name) {
|
|
508
|
+
<tr>
|
|
509
|
+
<td>
|
|
510
|
+
<code>{{ input.name }}</code>
|
|
511
|
+
</td>
|
|
512
|
+
<td>
|
|
513
|
+
<code>{{ input.type }}</code>
|
|
514
|
+
</td>
|
|
515
|
+
<td>{{ input.default }}</td>
|
|
516
|
+
<td>{{ input.description }}</td>
|
|
517
|
+
</tr>
|
|
518
|
+
}
|
|
519
|
+
</tbody>
|
|
520
|
+
</table>
|
|
521
|
+
</div>
|
|
522
|
+
|
|
523
|
+
<h3>Outputs</h3>
|
|
524
|
+
<div class="table-container">
|
|
525
|
+
<table class="api-table">
|
|
526
|
+
<thead>
|
|
527
|
+
<tr>
|
|
528
|
+
<th>Name</th>
|
|
529
|
+
<th>Type</th>
|
|
530
|
+
<th>Description</th>
|
|
531
|
+
</tr>
|
|
532
|
+
</thead>
|
|
533
|
+
<tbody>
|
|
534
|
+
@for (output of outputsDoc; track output.name) {
|
|
535
|
+
<tr>
|
|
536
|
+
<td>
|
|
537
|
+
<code>{{ output.name }}</code>
|
|
538
|
+
</td>
|
|
539
|
+
<td>
|
|
540
|
+
<code>{{ output.type }}</code>
|
|
541
|
+
</td>
|
|
542
|
+
<td>{{ output.description }}</td>
|
|
543
|
+
</tr>
|
|
544
|
+
}
|
|
545
|
+
</tbody>
|
|
546
|
+
</table>
|
|
547
|
+
</div>
|
|
548
|
+
</section>
|
|
549
|
+
|
|
550
|
+
<section class="interfaces-section">
|
|
551
|
+
<h2>Interfaces</h2>
|
|
552
|
+
<div class="interface-docs">
|
|
553
|
+
@for (interfaceItem of interfacesDoc; track interfaceItem.name) {
|
|
554
|
+
<div class="interface-item">
|
|
555
|
+
<h3>{{ interfaceItem.name }}</h3>
|
|
556
|
+
<pre><code>{{interfaceItem.code}}</code></pre>
|
|
557
|
+
<p>{{ interfaceItem.description }}</p>
|
|
558
|
+
</div>
|
|
559
|
+
}
|
|
560
|
+
</div>
|
|
561
|
+
</section>
|
|
562
|
+
|
|
563
|
+
<section class="features-section">
|
|
564
|
+
<h2>Features</h2>
|
|
565
|
+
<ul>
|
|
566
|
+
@for (feature of features; track feature.id) {
|
|
567
|
+
<li>
|
|
568
|
+
<span class="feature-icon">{{ feature.icon }}</span>
|
|
569
|
+
<div class="feature-info">
|
|
570
|
+
<h3>{{ feature.title }}</h3>
|
|
571
|
+
<p>{{ feature.description }}</p>
|
|
572
|
+
</div>
|
|
573
|
+
</li>
|
|
574
|
+
}
|
|
575
|
+
</ul>
|
|
576
|
+
</section>
|
|
577
|
+
|
|
578
|
+
<section class="usage-section">
|
|
579
|
+
<h2>Usage</h2>
|
|
580
|
+
<div class="code-examples">
|
|
581
|
+
@for (example of codeExamples; track example.id) {
|
|
582
|
+
<div class="code-example">
|
|
583
|
+
<h3>{{ example.title }}</h3>
|
|
584
|
+
<pre><code [innerHTML]="example.code"></code></pre>
|
|
585
|
+
</div>
|
|
586
|
+
}
|
|
587
|
+
</div>
|
|
588
|
+
</section>
|
|
589
|
+
</main>
|
|
590
|
+
</div>
|
|
591
|
+
`, isInline: true, styles: [".page-container{max-width:1200px;margin:0 auto;padding:20px;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.6;color:#333}header{text-align:center;padding:40px 0;background-color:#fff;border-radius:8px;margin-bottom:30px;box-shadow:0 2px 5px #0000001a}header h1{font-size:2.5rem;color:#2c3e50;margin-bottom:10px}header p{font-size:1.2rem;color:#7f8c8d}section{background-color:#fff;border-radius:8px;padding:30px;margin-bottom:30px;box-shadow:0 2px 5px #0000001a}h2{font-size:1.8rem;color:#2c3e50;margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid #ecf0f1}h3{font-size:1.4rem;color:#34495e;margin-bottom:15px}h4{font-size:1.2rem;color:#34495e;margin-bottom:10px}p{margin-bottom:15px}code{font-family:Courier New,Courier,monospace;background-color:#f7f7f7;padding:2px 5px;border-radius:3px;font-size:.9em}pre{background-color:#f7f7f7;padding:15px;border-radius:5px;overflow-x:auto;margin-bottom:20px;display:flex;align-items:center;justify-content:space-between}pre code{background-color:transparent;padding:0}.installation-section .install-command{position:relative;margin-bottom:20px}.installation-section .copy-button{position:absolute;top:10px;right:10px;background:#3498db;color:#fff;border:none;border-radius:4px;padding:5px 10px;font-size:.9rem;cursor:pointer;transition:background .2s}.installation-section .copy-button:hover{background:#2980b9}.demo-container{display:grid;grid-template-columns:1fr;gap:30px}.demo-example{background:#f7f7f7;padding:20px;border-radius:8px;margin-bottom:20px}.list-container{max-width:400px;margin:20px auto}.list-item{padding:12px;margin:8px 0;background:#fff;border:1px solid #e0e0e0;border-radius:6px;display:flex;align-items:center;transition:transform .2s,box-shadow .2s}.list-item:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.item-icon{margin-right:12px;font-size:1.2em}.kanban-board{display:flex;gap:20px;padding:20px;overflow-x:auto}.kanban-column{flex:1;min-width:300px;background:#f5f5f5;padding:15px;border-radius:8px}.kanban-item{background:#fff;padding:12px;margin:8px 0;border-radius:6px;box-shadow:0 1px 3px #0000001a}.kanban-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.item-title{font-weight:500}.item-status{padding:4px 8px;border-radius:4px;font-size:.8em}.status-todo{background:#ffebee;color:#c62828}.status-in-progress{background:#fff3e0;color:#ef6c00}.status-done{background:#e8f5e9;color:#2e7d32}.item-description{font-size:.9em;color:#666}.nested-container{max-width:800px;margin:0 auto}.nested-item{background:#fff;border:1px solid #e0e0e0;border-radius:8px;margin:12px 0;overflow:hidden}.nested-item-header{padding:12px;background:#f5f5f5;border-bottom:1px solid #e0e0e0}.nested-item-content{padding:12px}.sub-item{padding:8px;margin:4px 0;background:#f9f9f9;border:1px solid #e0e0e0;border-radius:4px}.api-doc-section{margin-bottom:40px}.table-container{overflow-x:auto;margin-bottom:30px}.api-table{width:100%;border-collapse:collapse;margin-bottom:20px}.api-table th,.api-table td{padding:12px 15px;text-align:left;border-bottom:1px solid #e1e1e1}.api-table th{background-color:#f5f5f5;font-weight:700}.api-table tbody tr:hover{background-color:#f9f9f9}.features-section ul{list-style:none}.features-section li{display:flex;margin-bottom:25px;align-items:flex-start}.feature-icon{font-size:2rem;margin-right:20px;min-width:40px;text-align:center}.feature-info{flex:1}.code-examples{display:grid;grid-template-columns:1fr;gap:20px}@media (min-width: 768px){.code-examples{grid-template-columns:repeat(2,1fr)}}@media (min-width: 992px){.code-examples{grid-template-columns:repeat(3,1fr)}}.code-example{border:1px solid #ecf0f1;border-radius:5px;padding:15px}@media (max-width: 768px){header{padding:30px 0}header h1{font-size:2rem}section{padding:20px}.kanban-board{flex-direction:column}.kanban-column{min-width:100%}.feature-icon{font-size:1.5rem;margin-right:15px}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: LibsUiComponentsDragContainerDirective, selector: "[LibsUiComponentsDragContainerDirective]", inputs: ["disableDragContainer", "mode", "directionDrag", "viewEncapsulation", "acceptDragSameGroup", "placeholder", "groupName", "dropToGroupName", "items", "stylesOverride"], outputs: ["itemsChange", "outDragStartContainer", "outDragOverContainer", "outDragLeaveContainer", "outDragEndContainer", "outDroppedContainer", "outDroppedContainerEmpty", "outFunctionControl"] }, { kind: "directive", type: LibsUiDragItemDirective, selector: "[LibsUiDragItemDirective]", inputs: ["fieldId", "item", "itemInContainerVirtualScroll", "throttleTimeHandlerDraggingEvent", "ignoreStopEvent", "onlyMouseDownStopEvent", "dragRootElement", "dragBoundary", "dragBoundaryAcceptMouseLeaveContainer", "elementContainer", "zIndex", "disable"], outputs: ["outDragStart", "outDragOver", "outDragLeave", "outDragEnd", "outDropped"] }, { kind: "component", type: LibsUiComponentsButtonsButtonComponent, selector: "libs_ui-components-buttons-button", inputs: ["flagMouse", "type", "buttonCustom", "sizeButton", "label", "disable", "isPending", "imageLeft", "classInclude", "classIconLeft", "classIconRight", "classLabel", "iconOnlyType", "popover", "ignoreStopPropagationEvent", "zIndex", "widthLabelPopover", "styleIconLeft", "styleButton", "ignoreFocusWhenInputTab", "ignoreSetClickWhenShowPopover", "ignorePointerEvent", "isActive", "isHandlerEnterDocumentClickButton"], outputs: ["outClick", "outPopoverEvent", "outFunctionsControl"] }] });
|
|
592
|
+
}
|
|
593
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: LibsUiDragDropDemoComponent, decorators: [{
|
|
594
|
+
type: Component,
|
|
595
|
+
args: [{ selector: 'lib-drag-drop-demo', standalone: true, imports: [CommonModule, LibsUiComponentsDragContainerDirective, LibsUiDragItemDirective, LibsUiComponentsButtonsButtonComponent], template: `
|
|
596
|
+
<div class="page-container">
|
|
597
|
+
<header>
|
|
598
|
+
<h1>Demo Drag and Drop Component</h1>
|
|
599
|
+
<p>Angular component library for drag and drop functionality</p>
|
|
600
|
+
</header>
|
|
601
|
+
|
|
602
|
+
<main>
|
|
603
|
+
<section class="intro-section">
|
|
604
|
+
<h2>Introduction</h2>
|
|
605
|
+
<p>
|
|
606
|
+
<code>@libs-ui/components-drag-drop</code>
|
|
607
|
+
is a powerful Angular component that enables drag and drop functionality with features like virtual scrolling, multi-selection, and custom boundaries.
|
|
608
|
+
</p>
|
|
609
|
+
</section>
|
|
610
|
+
|
|
611
|
+
<section class="installation-section">
|
|
612
|
+
<h2>Installation</h2>
|
|
613
|
+
<p>To install the library, use npm or yarn:</p>
|
|
614
|
+
|
|
615
|
+
<div class="install-command">
|
|
616
|
+
<pre>
|
|
617
|
+
<code>npm install @libs-ui/components-drag-drop</code>
|
|
618
|
+
<libs_ui-components-buttons-button
|
|
619
|
+
[label]="'Copy'"
|
|
620
|
+
(outClick)="copyToClipboard('npm install @libs-ui/components-drag-drop')" />
|
|
621
|
+
</pre>
|
|
622
|
+
</div>
|
|
623
|
+
|
|
624
|
+
<p>Or with yarn:</p>
|
|
625
|
+
|
|
626
|
+
<div class="install-command">
|
|
627
|
+
<pre>
|
|
628
|
+
<code>yarn add @libs-ui/components-drag-drop</code>
|
|
629
|
+
<libs_ui-components-buttons-button
|
|
630
|
+
[label]="'Copy'"
|
|
631
|
+
(outClick)="copyToClipboard('yarn add @libs-ui/components-drag-drop')" />
|
|
632
|
+
</pre>
|
|
633
|
+
</div>
|
|
634
|
+
</section>
|
|
635
|
+
|
|
636
|
+
<section class="demo-section">
|
|
637
|
+
<h2>Live Demo</h2>
|
|
638
|
+
<div class="demo-container">
|
|
639
|
+
<!-- Basic List Demo -->
|
|
640
|
+
<div class="demo-example">
|
|
641
|
+
<h3>Basic List</h3>
|
|
642
|
+
<div class="list-container">
|
|
643
|
+
<div
|
|
644
|
+
LibsUiComponentsDragContainerDirective
|
|
645
|
+
[(items)]="basicItems"
|
|
646
|
+
[acceptDragSameGroup]="true">
|
|
647
|
+
@for (item of basicItems; track item) {
|
|
648
|
+
<div
|
|
649
|
+
class="list-item"
|
|
650
|
+
LibsUiDragItemDirective>
|
|
651
|
+
<span class="item-icon">📋</span>
|
|
652
|
+
<span class="item-text">{{ item }}</span>
|
|
653
|
+
</div>
|
|
654
|
+
}
|
|
655
|
+
</div>
|
|
656
|
+
</div>
|
|
657
|
+
</div>
|
|
658
|
+
|
|
659
|
+
<!-- Kanban Board Demo -->
|
|
660
|
+
<div class="demo-example">
|
|
661
|
+
<h3>Kanban Board</h3>
|
|
662
|
+
<div class="kanban-board">
|
|
663
|
+
@for (column of columns; track column) {
|
|
664
|
+
<div
|
|
665
|
+
class="kanban-column"
|
|
666
|
+
LibsUiComponentsDragContainerDirective
|
|
667
|
+
[(items)]="column.items"
|
|
668
|
+
[groupName]="column.id"
|
|
669
|
+
[dropToGroupName]="columnsIds"
|
|
670
|
+
[acceptDragSameGroup]="true">
|
|
671
|
+
<h4>{{ column.title }}</h4>
|
|
672
|
+
@for (item of column.items; track item) {
|
|
673
|
+
<div
|
|
674
|
+
class="kanban-item"
|
|
675
|
+
LibsUiDragItemDirective>
|
|
676
|
+
<div class="kanban-item-header">
|
|
677
|
+
<span class="item-title">{{ item.title }}</span>
|
|
678
|
+
<span
|
|
679
|
+
class="item-status"
|
|
680
|
+
[class]="'status-' + item.status">
|
|
681
|
+
{{ item.status }}
|
|
682
|
+
</span>
|
|
683
|
+
</div>
|
|
684
|
+
<p class="item-description">{{ item.description }}</p>
|
|
685
|
+
</div>
|
|
686
|
+
}
|
|
687
|
+
</div>
|
|
688
|
+
}
|
|
689
|
+
</div>
|
|
690
|
+
</div>
|
|
691
|
+
|
|
692
|
+
<!-- Nested Containers Demo -->
|
|
693
|
+
<div class="demo-example">
|
|
694
|
+
<h3>Nested Containers copy</h3>
|
|
695
|
+
<div class="nested-container">
|
|
696
|
+
<div
|
|
697
|
+
LibsUiComponentsDragContainerDirective
|
|
698
|
+
[(items)]="nestedItems"
|
|
699
|
+
[groupName]="'parent'"
|
|
700
|
+
[mode]="'copy'"
|
|
701
|
+
[acceptDragSameGroup]="true">
|
|
702
|
+
@for (item of nestedItems; track item) {
|
|
703
|
+
<div
|
|
704
|
+
class="nested-item"
|
|
705
|
+
LibsUiDragItemDirective>
|
|
706
|
+
<div class="nested-item-header">
|
|
707
|
+
<span class="item-title">{{ item.title }}</span>
|
|
708
|
+
</div>
|
|
709
|
+
<div class="nested-item-content">
|
|
710
|
+
<div
|
|
711
|
+
LibsUiComponentsDragContainerDirective
|
|
712
|
+
[(items)]="item.subItems"
|
|
713
|
+
[groupName]="'child'"
|
|
714
|
+
[acceptDragSameGroup]="true">
|
|
715
|
+
@for (subItem of item.subItems; track subItem) {
|
|
716
|
+
<div
|
|
717
|
+
class="sub-item"
|
|
718
|
+
LibsUiDragItemDirective>
|
|
719
|
+
{{ subItem }}
|
|
720
|
+
</div>
|
|
721
|
+
}
|
|
722
|
+
</div>
|
|
723
|
+
</div>
|
|
724
|
+
</div>
|
|
725
|
+
}
|
|
726
|
+
</div>
|
|
727
|
+
</div>
|
|
728
|
+
</div>
|
|
729
|
+
</div>
|
|
730
|
+
</section>
|
|
731
|
+
|
|
732
|
+
<section class="api-doc-section">
|
|
733
|
+
<h2>API Documentation</h2>
|
|
734
|
+
|
|
735
|
+
<h3>Inputs</h3>
|
|
736
|
+
<div class="table-container">
|
|
737
|
+
<table class="api-table">
|
|
738
|
+
<thead>
|
|
739
|
+
<tr>
|
|
740
|
+
<th>Name</th>
|
|
741
|
+
<th>Type</th>
|
|
742
|
+
<th>Default</th>
|
|
743
|
+
<th>Description</th>
|
|
744
|
+
</tr>
|
|
745
|
+
</thead>
|
|
746
|
+
<tbody>
|
|
747
|
+
@for (input of inputsDoc; track input.name) {
|
|
748
|
+
<tr>
|
|
749
|
+
<td>
|
|
750
|
+
<code>{{ input.name }}</code>
|
|
751
|
+
</td>
|
|
752
|
+
<td>
|
|
753
|
+
<code>{{ input.type }}</code>
|
|
754
|
+
</td>
|
|
755
|
+
<td>{{ input.default }}</td>
|
|
756
|
+
<td>{{ input.description }}</td>
|
|
757
|
+
</tr>
|
|
758
|
+
}
|
|
759
|
+
</tbody>
|
|
760
|
+
</table>
|
|
761
|
+
</div>
|
|
762
|
+
|
|
763
|
+
<h3>Outputs</h3>
|
|
764
|
+
<div class="table-container">
|
|
765
|
+
<table class="api-table">
|
|
766
|
+
<thead>
|
|
767
|
+
<tr>
|
|
768
|
+
<th>Name</th>
|
|
769
|
+
<th>Type</th>
|
|
770
|
+
<th>Description</th>
|
|
771
|
+
</tr>
|
|
772
|
+
</thead>
|
|
773
|
+
<tbody>
|
|
774
|
+
@for (output of outputsDoc; track output.name) {
|
|
775
|
+
<tr>
|
|
776
|
+
<td>
|
|
777
|
+
<code>{{ output.name }}</code>
|
|
778
|
+
</td>
|
|
779
|
+
<td>
|
|
780
|
+
<code>{{ output.type }}</code>
|
|
781
|
+
</td>
|
|
782
|
+
<td>{{ output.description }}</td>
|
|
783
|
+
</tr>
|
|
784
|
+
}
|
|
785
|
+
</tbody>
|
|
786
|
+
</table>
|
|
787
|
+
</div>
|
|
788
|
+
</section>
|
|
789
|
+
|
|
790
|
+
<section class="interfaces-section">
|
|
791
|
+
<h2>Interfaces</h2>
|
|
792
|
+
<div class="interface-docs">
|
|
793
|
+
@for (interfaceItem of interfacesDoc; track interfaceItem.name) {
|
|
794
|
+
<div class="interface-item">
|
|
795
|
+
<h3>{{ interfaceItem.name }}</h3>
|
|
796
|
+
<pre><code>{{interfaceItem.code}}</code></pre>
|
|
797
|
+
<p>{{ interfaceItem.description }}</p>
|
|
798
|
+
</div>
|
|
799
|
+
}
|
|
800
|
+
</div>
|
|
801
|
+
</section>
|
|
802
|
+
|
|
803
|
+
<section class="features-section">
|
|
804
|
+
<h2>Features</h2>
|
|
805
|
+
<ul>
|
|
806
|
+
@for (feature of features; track feature.id) {
|
|
807
|
+
<li>
|
|
808
|
+
<span class="feature-icon">{{ feature.icon }}</span>
|
|
809
|
+
<div class="feature-info">
|
|
810
|
+
<h3>{{ feature.title }}</h3>
|
|
811
|
+
<p>{{ feature.description }}</p>
|
|
812
|
+
</div>
|
|
813
|
+
</li>
|
|
814
|
+
}
|
|
815
|
+
</ul>
|
|
816
|
+
</section>
|
|
817
|
+
|
|
818
|
+
<section class="usage-section">
|
|
819
|
+
<h2>Usage</h2>
|
|
820
|
+
<div class="code-examples">
|
|
821
|
+
@for (example of codeExamples; track example.id) {
|
|
822
|
+
<div class="code-example">
|
|
823
|
+
<h3>{{ example.title }}</h3>
|
|
824
|
+
<pre><code [innerHTML]="example.code"></code></pre>
|
|
825
|
+
</div>
|
|
826
|
+
}
|
|
827
|
+
</div>
|
|
828
|
+
</section>
|
|
829
|
+
</main>
|
|
830
|
+
</div>
|
|
831
|
+
`, styles: [".page-container{max-width:1200px;margin:0 auto;padding:20px;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.6;color:#333}header{text-align:center;padding:40px 0;background-color:#fff;border-radius:8px;margin-bottom:30px;box-shadow:0 2px 5px #0000001a}header h1{font-size:2.5rem;color:#2c3e50;margin-bottom:10px}header p{font-size:1.2rem;color:#7f8c8d}section{background-color:#fff;border-radius:8px;padding:30px;margin-bottom:30px;box-shadow:0 2px 5px #0000001a}h2{font-size:1.8rem;color:#2c3e50;margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid #ecf0f1}h3{font-size:1.4rem;color:#34495e;margin-bottom:15px}h4{font-size:1.2rem;color:#34495e;margin-bottom:10px}p{margin-bottom:15px}code{font-family:Courier New,Courier,monospace;background-color:#f7f7f7;padding:2px 5px;border-radius:3px;font-size:.9em}pre{background-color:#f7f7f7;padding:15px;border-radius:5px;overflow-x:auto;margin-bottom:20px;display:flex;align-items:center;justify-content:space-between}pre code{background-color:transparent;padding:0}.installation-section .install-command{position:relative;margin-bottom:20px}.installation-section .copy-button{position:absolute;top:10px;right:10px;background:#3498db;color:#fff;border:none;border-radius:4px;padding:5px 10px;font-size:.9rem;cursor:pointer;transition:background .2s}.installation-section .copy-button:hover{background:#2980b9}.demo-container{display:grid;grid-template-columns:1fr;gap:30px}.demo-example{background:#f7f7f7;padding:20px;border-radius:8px;margin-bottom:20px}.list-container{max-width:400px;margin:20px auto}.list-item{padding:12px;margin:8px 0;background:#fff;border:1px solid #e0e0e0;border-radius:6px;display:flex;align-items:center;transition:transform .2s,box-shadow .2s}.list-item:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.item-icon{margin-right:12px;font-size:1.2em}.kanban-board{display:flex;gap:20px;padding:20px;overflow-x:auto}.kanban-column{flex:1;min-width:300px;background:#f5f5f5;padding:15px;border-radius:8px}.kanban-item{background:#fff;padding:12px;margin:8px 0;border-radius:6px;box-shadow:0 1px 3px #0000001a}.kanban-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.item-title{font-weight:500}.item-status{padding:4px 8px;border-radius:4px;font-size:.8em}.status-todo{background:#ffebee;color:#c62828}.status-in-progress{background:#fff3e0;color:#ef6c00}.status-done{background:#e8f5e9;color:#2e7d32}.item-description{font-size:.9em;color:#666}.nested-container{max-width:800px;margin:0 auto}.nested-item{background:#fff;border:1px solid #e0e0e0;border-radius:8px;margin:12px 0;overflow:hidden}.nested-item-header{padding:12px;background:#f5f5f5;border-bottom:1px solid #e0e0e0}.nested-item-content{padding:12px}.sub-item{padding:8px;margin:4px 0;background:#f9f9f9;border:1px solid #e0e0e0;border-radius:4px}.api-doc-section{margin-bottom:40px}.table-container{overflow-x:auto;margin-bottom:30px}.api-table{width:100%;border-collapse:collapse;margin-bottom:20px}.api-table th,.api-table td{padding:12px 15px;text-align:left;border-bottom:1px solid #e1e1e1}.api-table th{background-color:#f5f5f5;font-weight:700}.api-table tbody tr:hover{background-color:#f9f9f9}.features-section ul{list-style:none}.features-section li{display:flex;margin-bottom:25px;align-items:flex-start}.feature-icon{font-size:2rem;margin-right:20px;min-width:40px;text-align:center}.feature-info{flex:1}.code-examples{display:grid;grid-template-columns:1fr;gap:20px}@media (min-width: 768px){.code-examples{grid-template-columns:repeat(2,1fr)}}@media (min-width: 992px){.code-examples{grid-template-columns:repeat(3,1fr)}}.code-example{border:1px solid #ecf0f1;border-radius:5px;padding:15px}@media (max-width: 768px){header{padding:30px 0}header h1{font-size:2rem}section{padding:20px}.kanban-board{flex-direction:column}.kanban-column{min-width:100%}.feature-icon{font-size:1.5rem;margin-right:15px}}\n"] }]
|
|
832
|
+
}] });
|
|
833
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"demo.component.js","sourceRoot":"","sources":["../../../../../../libs-ui/components/drag-drop/src/demo/demo.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component } from '@angular/core';\nimport { LibsUiComponentsButtonsButtonComponent } from '@libs-ui/components-buttons-button';\nimport { LibsUiComponentsDragContainerDirective } from '../drag-drop.directive';\nimport { LibsUiDragItemDirective } from '../drag-item.directive';\n\ninterface Task {\n  id: number;\n  title: string;\n  description: string;\n  status: 'todo' | 'in-progress' | 'done';\n}\n\ninterface Column {\n  id: string;\n  title: string;\n  items: Task[];\n}\n\n@Component({\n  selector: 'lib-drag-drop-demo',\n  standalone: true,\n  imports: [CommonModule, LibsUiComponentsDragContainerDirective, LibsUiDragItemDirective, LibsUiComponentsButtonsButtonComponent],\n  template: `\n    <div class=\"page-container\">\n      <header>\n        <h1>Demo Drag and Drop Component</h1>\n        <p>Angular component library for drag and drop functionality</p>\n      </header>\n\n      <main>\n        <section class=\"intro-section\">\n          <h2>Introduction</h2>\n          <p>\n            <code>&#64;libs-ui/components-drag-drop</code>\n            is a powerful Angular component that enables drag and drop functionality with features like virtual scrolling, multi-selection, and custom boundaries.\n          </p>\n        </section>\n\n        <section class=\"installation-section\">\n          <h2>Installation</h2>\n          <p>To install the library, use npm or yarn:</p>\n\n          <div class=\"install-command\">\n            <pre>\n              <code>npm install &#64;libs-ui/components-drag-drop</code>\n              <libs_ui-components-buttons-button\n                [label]=\"'Copy'\"\n                (outClick)=\"copyToClipboard('npm install @libs-ui/components-drag-drop')\" />\n            </pre>\n          </div>\n\n          <p>Or with yarn:</p>\n\n          <div class=\"install-command\">\n            <pre>\n              <code>yarn add &#64;libs-ui/components-drag-drop</code>\n              <libs_ui-components-buttons-button\n                [label]=\"'Copy'\"\n                (outClick)=\"copyToClipboard('yarn add @libs-ui/components-drag-drop')\" />\n            </pre>\n          </div>\n        </section>\n\n        <section class=\"demo-section\">\n          <h2>Live Demo</h2>\n          <div class=\"demo-container\">\n            <!-- Basic List Demo -->\n            <div class=\"demo-example\">\n              <h3>Basic List</h3>\n              <div class=\"list-container\">\n                <div\n                  LibsUiComponentsDragContainerDirective\n                  [(items)]=\"basicItems\"\n                  [acceptDragSameGroup]=\"true\">\n                  @for (item of basicItems; track item) {\n                    <div\n                      class=\"list-item\"\n                      LibsUiDragItemDirective>\n                      <span class=\"item-icon\">📋</span>\n                      <span class=\"item-text\">{{ item }}</span>\n                    </div>\n                  }\n                </div>\n              </div>\n            </div>\n\n            <!-- Kanban Board Demo -->\n            <div class=\"demo-example\">\n              <h3>Kanban Board</h3>\n              <div class=\"kanban-board\">\n                @for (column of columns; track column) {\n                  <div\n                    class=\"kanban-column\"\n                    LibsUiComponentsDragContainerDirective\n                    [(items)]=\"column.items\"\n                    [groupName]=\"column.id\"\n                    [dropToGroupName]=\"columnsIds\"\n                    [acceptDragSameGroup]=\"true\">\n                    <h4>{{ column.title }}</h4>\n                    @for (item of column.items; track item) {\n                      <div\n                        class=\"kanban-item\"\n                        LibsUiDragItemDirective>\n                        <div class=\"kanban-item-header\">\n                          <span class=\"item-title\">{{ item.title }}</span>\n                          <span\n                            class=\"item-status\"\n                            [class]=\"'status-' + item.status\">\n                            {{ item.status }}\n                          </span>\n                        </div>\n                        <p class=\"item-description\">{{ item.description }}</p>\n                      </div>\n                    }\n                  </div>\n                }\n              </div>\n            </div>\n\n            <!-- Nested Containers Demo -->\n            <div class=\"demo-example\">\n              <h3>Nested Containers copy</h3>\n              <div class=\"nested-container\">\n                <div\n                  LibsUiComponentsDragContainerDirective\n                  [(items)]=\"nestedItems\"\n                  [groupName]=\"'parent'\"\n                  [mode]=\"'copy'\"\n                  [acceptDragSameGroup]=\"true\">\n                  @for (item of nestedItems; track item) {\n                    <div\n                      class=\"nested-item\"\n                      LibsUiDragItemDirective>\n                      <div class=\"nested-item-header\">\n                        <span class=\"item-title\">{{ item.title }}</span>\n                      </div>\n                      <div class=\"nested-item-content\">\n                        <div\n                          LibsUiComponentsDragContainerDirective\n                          [(items)]=\"item.subItems\"\n                          [groupName]=\"'child'\"\n                          [acceptDragSameGroup]=\"true\">\n                          @for (subItem of item.subItems; track subItem) {\n                            <div\n                              class=\"sub-item\"\n                              LibsUiDragItemDirective>\n                              {{ subItem }}\n                            </div>\n                          }\n                        </div>\n                      </div>\n                    </div>\n                  }\n                </div>\n              </div>\n            </div>\n          </div>\n        </section>\n\n        <section class=\"api-doc-section\">\n          <h2>API Documentation</h2>\n\n          <h3>Inputs</h3>\n          <div class=\"table-container\">\n            <table class=\"api-table\">\n              <thead>\n                <tr>\n                  <th>Name</th>\n                  <th>Type</th>\n                  <th>Default</th>\n                  <th>Description</th>\n                </tr>\n              </thead>\n              <tbody>\n                @for (input of inputsDoc; track input.name) {\n                  <tr>\n                    <td>\n                      <code>{{ input.name }}</code>\n                    </td>\n                    <td>\n                      <code>{{ input.type }}</code>\n                    </td>\n                    <td>{{ input.default }}</td>\n                    <td>{{ input.description }}</td>\n                  </tr>\n                }\n              </tbody>\n            </table>\n          </div>\n\n          <h3>Outputs</h3>\n          <div class=\"table-container\">\n            <table class=\"api-table\">\n              <thead>\n                <tr>\n                  <th>Name</th>\n                  <th>Type</th>\n                  <th>Description</th>\n                </tr>\n              </thead>\n              <tbody>\n                @for (output of outputsDoc; track output.name) {\n                  <tr>\n                    <td>\n                      <code>{{ output.name }}</code>\n                    </td>\n                    <td>\n                      <code>{{ output.type }}</code>\n                    </td>\n                    <td>{{ output.description }}</td>\n                  </tr>\n                }\n              </tbody>\n            </table>\n          </div>\n        </section>\n\n        <section class=\"interfaces-section\">\n          <h2>Interfaces</h2>\n          <div class=\"interface-docs\">\n            @for (interfaceItem of interfacesDoc; track interfaceItem.name) {\n              <div class=\"interface-item\">\n                <h3>{{ interfaceItem.name }}</h3>\n                <pre><code>{{interfaceItem.code}}</code></pre>\n                <p>{{ interfaceItem.description }}</p>\n              </div>\n            }\n          </div>\n        </section>\n\n        <section class=\"features-section\">\n          <h2>Features</h2>\n          <ul>\n            @for (feature of features; track feature.id) {\n              <li>\n                <span class=\"feature-icon\">{{ feature.icon }}</span>\n                <div class=\"feature-info\">\n                  <h3>{{ feature.title }}</h3>\n                  <p>{{ feature.description }}</p>\n                </div>\n              </li>\n            }\n          </ul>\n        </section>\n\n        <section class=\"usage-section\">\n          <h2>Usage</h2>\n          <div class=\"code-examples\">\n            @for (example of codeExamples; track example.id) {\n              <div class=\"code-example\">\n                <h3>{{ example.title }}</h3>\n                <pre><code [innerHTML]=\"example.code\"></code></pre>\n              </div>\n            }\n          </div>\n        </section>\n      </main>\n    </div>\n  `,\n  styles: [\n    `\n      .page-container {\n        max-width: 1200px;\n        margin: 0 auto;\n        padding: 20px;\n        font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;\n        line-height: 1.6;\n        color: #333;\n      }\n\n      header {\n        text-align: center;\n        padding: 40px 0;\n        background-color: #ffffff;\n        border-radius: 8px;\n        margin-bottom: 30px;\n        box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);\n      }\n\n      header h1 {\n        font-size: 2.5rem;\n        color: #2c3e50;\n        margin-bottom: 10px;\n      }\n\n      header p {\n        font-size: 1.2rem;\n        color: #7f8c8d;\n      }\n\n      section {\n        background-color: #ffffff;\n        border-radius: 8px;\n        padding: 30px;\n        margin-bottom: 30px;\n        box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);\n      }\n\n      h2 {\n        font-size: 1.8rem;\n        color: #2c3e50;\n        margin-bottom: 20px;\n        padding-bottom: 10px;\n        border-bottom: 2px solid #ecf0f1;\n      }\n\n      h3 {\n        font-size: 1.4rem;\n        color: #34495e;\n        margin-bottom: 15px;\n      }\n\n      h4 {\n        font-size: 1.2rem;\n        color: #34495e;\n        margin-bottom: 10px;\n      }\n\n      p {\n        margin-bottom: 15px;\n      }\n\n      code {\n        font-family: 'Courier New', Courier, monospace;\n        background-color: #f7f7f7;\n        padding: 2px 5px;\n        border-radius: 3px;\n        font-size: 0.9em;\n      }\n\n      pre {\n        background-color: #f7f7f7;\n        padding: 15px;\n        border-radius: 5px;\n        overflow-x: auto;\n        margin-bottom: 20px;\n        display: flex;\n        align-items: center;\n        justify-content: space-between;\n      }\n\n      pre code {\n        background-color: transparent;\n        padding: 0;\n      }\n\n      /* Installation section styles */\n      .installation-section .install-command {\n        position: relative;\n        margin-bottom: 20px;\n      }\n\n      .installation-section .copy-button {\n        position: absolute;\n        top: 10px;\n        right: 10px;\n        background: #3498db;\n        color: white;\n        border: none;\n        border-radius: 4px;\n        padding: 5px 10px;\n        font-size: 0.9rem;\n        cursor: pointer;\n        transition: background 0.2s;\n      }\n\n      .installation-section .copy-button:hover {\n        background: #2980b9;\n      }\n\n      /* Demo section styles */\n      .demo-container {\n        display: grid;\n        grid-template-columns: 1fr;\n        gap: 30px;\n      }\n\n      .demo-example {\n        background: #f7f7f7;\n        padding: 20px;\n        border-radius: 8px;\n        margin-bottom: 20px;\n      }\n\n      /* List styles */\n      .list-container {\n        max-width: 400px;\n        margin: 20px auto;\n      }\n\n      .list-item {\n        padding: 12px;\n        margin: 8px 0;\n        background: white;\n        border: 1px solid #e0e0e0;\n        border-radius: 6px;\n        display: flex;\n        align-items: center;\n        transition:\n          transform 0.2s,\n          box-shadow 0.2s;\n      }\n\n      .list-item:hover {\n        transform: translateY(-2px);\n        box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);\n      }\n\n      .item-icon {\n        margin-right: 12px;\n        font-size: 1.2em;\n      }\n\n      /* Kanban styles */\n      .kanban-board {\n        display: flex;\n        gap: 20px;\n        padding: 20px;\n        overflow-x: auto;\n      }\n\n      .kanban-column {\n        flex: 1;\n        min-width: 300px;\n        background: #f5f5f5;\n        padding: 15px;\n        border-radius: 8px;\n      }\n\n      .kanban-item {\n        background: white;\n        padding: 12px;\n        margin: 8px 0;\n        border-radius: 6px;\n        box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);\n      }\n\n      .kanban-item-header {\n        display: flex;\n        justify-content: space-between;\n        align-items: center;\n        margin-bottom: 8px;\n      }\n\n      .item-title {\n        font-weight: 500;\n      }\n\n      .item-status {\n        padding: 4px 8px;\n        border-radius: 4px;\n        font-size: 0.8em;\n      }\n\n      .status-todo {\n        background: #ffebee;\n        color: #c62828;\n      }\n\n      .status-in-progress {\n        background: #fff3e0;\n        color: #ef6c00;\n      }\n\n      .status-done {\n        background: #e8f5e9;\n        color: #2e7d32;\n      }\n\n      .item-description {\n        font-size: 0.9em;\n        color: #666;\n      }\n\n      /* Nested containers styles */\n      .nested-container {\n        max-width: 800px;\n        margin: 0 auto;\n      }\n\n      .nested-item {\n        background: white;\n        border: 1px solid #e0e0e0;\n        border-radius: 8px;\n        margin: 12px 0;\n        overflow: hidden;\n      }\n\n      .nested-item-header {\n        padding: 12px;\n        background: #f5f5f5;\n        border-bottom: 1px solid #e0e0e0;\n      }\n\n      .nested-item-content {\n        padding: 12px;\n      }\n\n      .sub-item {\n        padding: 8px;\n        margin: 4px 0;\n        background: #f9f9f9;\n        border: 1px solid #e0e0e0;\n        border-radius: 4px;\n      }\n\n      /* API documentation styles */\n      .api-doc-section {\n        margin-bottom: 40px;\n      }\n\n      .table-container {\n        overflow-x: auto;\n        margin-bottom: 30px;\n      }\n\n      .api-table {\n        width: 100%;\n        border-collapse: collapse;\n        margin-bottom: 20px;\n      }\n\n      .api-table th,\n      .api-table td {\n        padding: 12px 15px;\n        text-align: left;\n        border-bottom: 1px solid #e1e1e1;\n      }\n\n      .api-table th {\n        background-color: #f5f5f5;\n        font-weight: bold;\n      }\n\n      .api-table tbody tr:hover {\n        background-color: #f9f9f9;\n      }\n\n      /* Features section */\n      .features-section ul {\n        list-style: none;\n      }\n\n      .features-section li {\n        display: flex;\n        margin-bottom: 25px;\n        align-items: flex-start;\n      }\n\n      .feature-icon {\n        font-size: 2rem;\n        margin-right: 20px;\n        min-width: 40px;\n        text-align: center;\n      }\n\n      .feature-info {\n        flex: 1;\n      }\n\n      /* Code examples */\n      .code-examples {\n        display: grid;\n        grid-template-columns: 1fr;\n        gap: 20px;\n      }\n\n      @media (min-width: 768px) {\n        .code-examples {\n          grid-template-columns: repeat(2, 1fr);\n        }\n      }\n\n      @media (min-width: 992px) {\n        .code-examples {\n          grid-template-columns: repeat(3, 1fr);\n        }\n      }\n\n      .code-example {\n        border: 1px solid #ecf0f1;\n        border-radius: 5px;\n        padding: 15px;\n      }\n\n      /* Responsive adjustments */\n      @media (max-width: 768px) {\n        header {\n          padding: 30px 0;\n        }\n\n        header h1 {\n          font-size: 2rem;\n        }\n\n        section {\n          padding: 20px;\n        }\n\n        .kanban-board {\n          flex-direction: column;\n        }\n\n        .kanban-column {\n          min-width: 100%;\n        }\n\n        .feature-icon {\n          font-size: 1.5rem;\n          margin-right: 15px;\n        }\n      }\n    `,\n  ],\n})\nexport class LibsUiDragDropDemoComponent {\n  // Basic List Items\n  basicItems = ['Task 1', 'Task 2', 'Task 3', 'Task 4', 'Task 5'];\n\n  // Kanban Board Columns\n  columnsIds = ['todo', 'in-progress', 'done'];\n  columns: Column[] = [\n    {\n      id: 'todo',\n      title: 'To Do',\n      items: [\n        {\n          id: 1,\n          title: 'Implement drag and drop',\n          description: 'Add drag and drop functionality to the component',\n          status: 'todo',\n        },\n        {\n          id: 2,\n          title: 'Add animations',\n          description: 'Implement smooth animations for drag and drop',\n          status: 'todo',\n        },\n      ],\n    },\n    {\n      id: 'in-progress',\n      title: 'In Progress',\n      items: [\n        {\n          id: 3,\n          title: 'Fix styling issues',\n          description: 'Resolve CSS conflicts in the component',\n          status: 'in-progress',\n        },\n      ],\n    },\n    {\n      id: 'done',\n      title: 'Done',\n      items: [\n        {\n          id: 4,\n          title: 'Setup project structure',\n          description: 'Initialize the project with necessary configurations',\n          status: 'done',\n        },\n      ],\n    },\n  ];\n\n  // Nested Items\n  nestedItems = [\n    {\n      id: 1,\n      title: 'Project A',\n      subItems: ['Task 1', 'Task 2', 'Task 3'],\n    },\n    {\n      id: 2,\n      title: 'Project B',\n      subItems: ['Task 4', 'Task 5'],\n    },\n    {\n      id: 3,\n      title: 'Project C',\n      subItems: ['Task 6', 'Task 7', 'Task 8'],\n    },\n  ];\n\n  // API Documentation\n  inputsDoc = [\n    {\n      name: 'items',\n      type: 'Array<unknown>',\n      default: '[]',\n      description: 'Array of items to be displayed in the container',\n    },\n    {\n      name: 'mode',\n      type: \"'move' | 'copy' | 'deepCopy'\",\n      default: \"'move'\",\n      description: 'Mode for drag and drop operations',\n    },\n    {\n      name: 'directionDrag',\n      type: \"'horizontal' | 'vertical'\",\n      default: 'undefined',\n      description: 'Direction of drag movement',\n    },\n    {\n      name: 'viewEncapsulation',\n      type: \"'emulated' | 'none'\",\n      default: \"'emulated'\",\n      description: 'View encapsulation mode for styling',\n    },\n    {\n      name: 'disableDragContainer',\n      type: 'boolean',\n      default: 'undefined',\n      description: 'Whether to disable drag operations for the container',\n    },\n    {\n      name: 'acceptDragSameGroup',\n      type: 'boolean',\n      default: 'false',\n      description: 'Whether to accept drag operations within the same group',\n    },\n    {\n      name: 'placeholder',\n      type: 'boolean',\n      default: 'true',\n      description: 'Whether to show placeholder during drag',\n    },\n    {\n      name: 'groupName',\n      type: 'string',\n      default: \"'groupDragAndDropDefault'\",\n      description: 'Name of the group for drag and drop operations',\n    },\n    {\n      name: 'dropToGroupName',\n      type: 'Array<string> | null',\n      default: 'null',\n      description: 'List of group names that can accept drops from this container',\n    },\n    {\n      name: 'stylesOverride',\n      type: 'Array<{ className: string, styles: string }>',\n      default: 'undefined',\n      description: 'Custom styles to override default drag-drop styling',\n    },\n  ];\n\n  outputsDoc = [\n    {\n      name: 'outDragStartContainer',\n      type: 'IDragStart',\n      description: 'Event emitted when dragging starts in the container',\n    },\n    {\n      name: 'outDragOverContainer',\n      type: 'IDragOver',\n      description: 'Event emitted when dragging over the container',\n    },\n    {\n      name: 'outDragLeaveContainer',\n      type: 'IDragLeave',\n      description: 'Event emitted when dragging leaves the container',\n    },\n    {\n      name: 'outDragEndContainer',\n      type: 'IDragEnd',\n      description: 'Event emitted when dragging ends in the container',\n    },\n    {\n      name: 'outDroppedContainer',\n      type: 'IDrop',\n      description: 'Event emitted when an item is dropped in the container',\n    },\n    {\n      name: 'outDroppedContainerEmpty',\n      type: 'IDrop',\n      description: 'Event emitted when an item is dropped in an empty container',\n    },\n    {\n      name: 'outFunctionControl',\n      type: 'IDragDropFunctionControlEvent',\n      description: 'Event emitted to control drag-drop functionality',\n    },\n  ];\n\n  // Interface Documentation\n  interfacesDoc = [\n    {\n      name: 'IDragging',\n      code: `interface IDragging {\n  mousePosition: IMousePosition;\n  elementDrag: HTMLElement;\n  elementKeepContainer?: boolean;\n  itemDragInfo?: IItemDragInfo;\n}`,\n      description: 'Interface for drag operation events, containing information about the dragged element and mouse position',\n    },\n    {\n      name: 'IDragStart',\n      code: `interface IDragStart {\n  mousePosition: IMousePosition;\n  elementDrag: HTMLElement;\n  itemDragInfo?: IItemDragInfo;\n}`,\n      description: 'Interface for drag start events, triggered when dragging begins',\n    },\n    {\n      name: 'IDragOver',\n      code: `interface IDragOver {\n  mousePosition: IMousePosition;\n  elementDrag: HTMLElement;\n  elementDragOver: HTMLElement;\n  itemDragInfo?: IItemDragInfo;\n}`,\n      description: 'Interface for drag over events, triggered when an element is dragged over another element',\n    },\n    {\n      name: 'IDragLeave',\n      code: `interface IDragLeave {\n  elementDrag: HTMLElement;\n  elementDragLeave: HTMLElement;\n  itemDragInfo?: IItemDragInfo;\n}`,\n      description: 'Interface for drag leave events, triggered when a dragged element leaves another element',\n    },\n    {\n      name: 'IDragEnd',\n      code: `interface IDragEnd {\n  mousePosition: IMousePosition;\n  elementDrag: HTMLElement;\n  itemDragInfo?: IItemDragInfo;\n}`,\n      description: 'Interface for drag end events, triggered when dragging ends',\n    },\n    {\n      name: 'IDrop',\n      code: `interface IDrop {\n  elementDrag: HTMLElement;\n  elementDrop: HTMLElement;\n  itemDragInfo?: IItemDragInfo;\n}`,\n      description: 'Interface for drop events, triggered when an element is dropped',\n    },\n    {\n      name: 'IItemDragInfo',\n      code: `interface IItemDragInfo {\n  item: object;\n  itemsMove?: WritableSignal<Array<unknown>>;\n  indexDrag?: number;\n  indexDrop?: number;\n  itemsDrag: WritableSignal<Array<unknown>>;\n  itemsDrop?: WritableSignal<Array<unknown>>;\n  containerDrag?: HTMLElement;\n  containerDrop?: HTMLElement;\n}`,\n      description: 'Interface containing information about the dragged item and its containers',\n    },\n    {\n      name: 'IDragItemInContainerVirtualScroll',\n      code: `interface IDragItemInContainerVirtualScroll {\n  itemDragInfo?: IItemDragInfo;\n  elementDrag: HTMLElement;\n  distanceStartElementAndMouseTop: number;\n  distanceStartElementAndMouseLeft: number;\n  elementContainer?: HTMLElement;\n  dragBoundary?: boolean;\n  dragBoundaryAcceptMouseLeaveContainer?: boolean;\n  ignoreStopEvent?: boolean;\n}`,\n      description: 'Interface for virtual scrolling drag operations, containing information about drag boundaries and container elements',\n    },\n    {\n      name: 'IMousePosition',\n      code: `interface IMousePosition {\n  clientX: number;\n  clientY: number;\n}`,\n      description: 'Interface representing mouse position coordinates',\n    },\n    {\n      name: 'IDragDropFunctionControlEvent',\n      code: `interface IDragDropFunctionControlEvent {\n  setAttributeElementAndItemDrag: () => Promise<void>;\n}`,\n      description: 'Interface for drag and drop control functions',\n    },\n  ];\n\n  // Features\n  features = [\n    {\n      id: 1,\n      icon: '🔄',\n      title: 'Flexible Drag and Drop',\n      description: 'Support for container-to-container dragging with customizable group names and drop zones',\n    },\n    {\n      id: 2,\n      icon: '📜',\n      title: 'Virtual Scrolling',\n      description: 'Efficient handling of large lists with virtual scrolling support',\n    },\n    {\n      id: 3,\n      icon: '🎯',\n      title: 'Custom Boundaries',\n      description: 'Define custom drag boundaries and drop zones for precise control',\n    },\n    {\n      id: 4,\n      icon: '🎨',\n      title: 'Styling Options',\n      description: 'Customizable styles for drag items and containers',\n    },\n  ];\n\n  // Code Examples\n  codeExamples = [\n    {\n      id: 1,\n      title: 'Basic Usage',\n      code: `&lt;div LibsUiComponentsDragContainerDirective \n  [(items)]=\"items\"\n  [groupName]=\"'myGroup'\"\n  [acceptDragSameGroup]=\"true\"&gt;\n  @for (item of items; track item) {\n    &lt;div LibsUiDragItemDirective&gt;\n      {{ item }}\n    &lt;/div&gt;\n  }\n&lt;/div&gt;`,\n    },\n    {\n      id: 2,\n      title: 'Container-to-Container',\n      code: `&lt;div LibsUiComponentsDragContainerDirective \n  [(items)]=\"sourceItems\"\n  [groupName]=\"'source'\"&gt;\n  @for (item of sourceItems; track item) {\n    &lt;div LibsUiDragItemDirective&gt;\n      {{ item }}\n    &lt;/div&gt;\n  }\n&lt;/div&gt;\n\n&lt;div LibsUiComponentsDragContainerDirective \n  [(items)]=\"targetItems\"\n  [groupName]=\"'target'\"\n  [dropToGroupName]=\"['source']\"&gt;\n  @for (item of targetItems; track item) {\n    &lt;div LibsUiDragItemDirective&gt;\n      {{ item }}\n    &lt;/div&gt;\n  }\n&lt;/div&gt;`,\n    },\n  ];\n\n  /**\n   * Copy text to clipboard\n   */\n  copyToClipboard(text: string) {\n    navigator.clipboard.writeText(text).then(\n      () => {\n        alert('Copied to clipboard');\n      },\n      (err) => {\n        console.error('Could not copy text: ', err);\n      }\n    );\n  }\n}\n"]}
|