@libs-ui/components-drag-drop 0.2.304 → 0.2.306-10
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 +51 -45
- package/drag-drop.directive.d.ts +5 -4
- package/drag-drop.service.d.ts +3 -3
- package/drag-item-in-container-virtual-scroll.directive.d.ts +5 -5
- package/drag-item.directive.d.ts +3 -3
- package/drag-scroll.directive.d.ts +5 -5
- package/esm2022/defines/css.define.mjs +18 -16
- package/esm2022/demo/demo.component.mjs +184 -157
- package/esm2022/drag-drop.directive.mjs +65 -47
- package/esm2022/drag-drop.service.mjs +9 -5
- package/esm2022/drag-item-in-container-virtual-scroll.directive.mjs +21 -20
- package/esm2022/drag-item.directive.mjs +27 -22
- package/esm2022/drag-scroll.directive.mjs +21 -15
- package/esm2022/index.mjs +1 -1
- package/esm2022/interfaces/event.interface.mjs +1 -1
- package/fesm2022/libs-ui-components-drag-drop.mjs +319 -256
- package/fesm2022/libs-ui-components-drag-drop.mjs.map +1 -1
- package/interfaces/event.interface.d.ts +1 -1
- package/package.json +3 -3
|
@@ -6,13 +6,7 @@ import { LibsUiDragItemDirective } from '../drag-item.directive';
|
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
7
|
export class LibsUiDragDropDemoComponent {
|
|
8
8
|
// Basic List Items
|
|
9
|
-
basicItems = [
|
|
10
|
-
'Task 1',
|
|
11
|
-
'Task 2',
|
|
12
|
-
'Task 3',
|
|
13
|
-
'Task 4',
|
|
14
|
-
'Task 5'
|
|
15
|
-
];
|
|
9
|
+
basicItems = ['Task 1', 'Task 2', 'Task 3', 'Task 4', 'Task 5'];
|
|
16
10
|
// Kanban Board Columns
|
|
17
11
|
columnsIds = ['todo', 'in-progress', 'done'];
|
|
18
12
|
columns = [
|
|
@@ -24,15 +18,15 @@ export class LibsUiDragDropDemoComponent {
|
|
|
24
18
|
id: 1,
|
|
25
19
|
title: 'Implement drag and drop',
|
|
26
20
|
description: 'Add drag and drop functionality to the component',
|
|
27
|
-
status: 'todo'
|
|
21
|
+
status: 'todo',
|
|
28
22
|
},
|
|
29
23
|
{
|
|
30
24
|
id: 2,
|
|
31
25
|
title: 'Add animations',
|
|
32
26
|
description: 'Implement smooth animations for drag and drop',
|
|
33
|
-
status: 'todo'
|
|
34
|
-
}
|
|
35
|
-
]
|
|
27
|
+
status: 'todo',
|
|
28
|
+
},
|
|
29
|
+
],
|
|
36
30
|
},
|
|
37
31
|
{
|
|
38
32
|
id: 'in-progress',
|
|
@@ -42,9 +36,9 @@ export class LibsUiDragDropDemoComponent {
|
|
|
42
36
|
id: 3,
|
|
43
37
|
title: 'Fix styling issues',
|
|
44
38
|
description: 'Resolve CSS conflicts in the component',
|
|
45
|
-
status: 'in-progress'
|
|
46
|
-
}
|
|
47
|
-
]
|
|
39
|
+
status: 'in-progress',
|
|
40
|
+
},
|
|
41
|
+
],
|
|
48
42
|
},
|
|
49
43
|
{
|
|
50
44
|
id: 'done',
|
|
@@ -54,28 +48,28 @@ export class LibsUiDragDropDemoComponent {
|
|
|
54
48
|
id: 4,
|
|
55
49
|
title: 'Setup project structure',
|
|
56
50
|
description: 'Initialize the project with necessary configurations',
|
|
57
|
-
status: 'done'
|
|
58
|
-
}
|
|
59
|
-
]
|
|
60
|
-
}
|
|
51
|
+
status: 'done',
|
|
52
|
+
},
|
|
53
|
+
],
|
|
54
|
+
},
|
|
61
55
|
];
|
|
62
56
|
// Nested Items
|
|
63
57
|
nestedItems = [
|
|
64
58
|
{
|
|
65
59
|
id: 1,
|
|
66
60
|
title: 'Project A',
|
|
67
|
-
subItems: ['Task 1', 'Task 2', 'Task 3']
|
|
61
|
+
subItems: ['Task 1', 'Task 2', 'Task 3'],
|
|
68
62
|
},
|
|
69
63
|
{
|
|
70
64
|
id: 2,
|
|
71
65
|
title: 'Project B',
|
|
72
|
-
subItems: ['Task 4', 'Task 5']
|
|
66
|
+
subItems: ['Task 4', 'Task 5'],
|
|
73
67
|
},
|
|
74
68
|
{
|
|
75
69
|
id: 3,
|
|
76
70
|
title: 'Project C',
|
|
77
|
-
subItems: ['Task 6', 'Task 7', 'Task 8']
|
|
78
|
-
}
|
|
71
|
+
subItems: ['Task 6', 'Task 7', 'Task 8'],
|
|
72
|
+
},
|
|
79
73
|
];
|
|
80
74
|
// API Documentation
|
|
81
75
|
inputsDoc = [
|
|
@@ -83,99 +77,99 @@ export class LibsUiDragDropDemoComponent {
|
|
|
83
77
|
name: 'items',
|
|
84
78
|
type: 'Array<unknown>',
|
|
85
79
|
default: '[]',
|
|
86
|
-
description: 'Array of items to be displayed in the container'
|
|
80
|
+
description: 'Array of items to be displayed in the container',
|
|
87
81
|
},
|
|
88
82
|
{
|
|
89
83
|
name: 'mode',
|
|
90
84
|
type: "'move' | 'copy' | 'deepCopy'",
|
|
91
85
|
default: "'move'",
|
|
92
|
-
description: 'Mode for drag and drop operations'
|
|
86
|
+
description: 'Mode for drag and drop operations',
|
|
93
87
|
},
|
|
94
88
|
{
|
|
95
89
|
name: 'directionDrag',
|
|
96
90
|
type: "'horizontal' | 'vertical'",
|
|
97
91
|
default: 'undefined',
|
|
98
|
-
description: 'Direction of drag movement'
|
|
92
|
+
description: 'Direction of drag movement',
|
|
99
93
|
},
|
|
100
94
|
{
|
|
101
95
|
name: 'viewEncapsulation',
|
|
102
96
|
type: "'emulated' | 'none'",
|
|
103
97
|
default: "'emulated'",
|
|
104
|
-
description: 'View encapsulation mode for styling'
|
|
98
|
+
description: 'View encapsulation mode for styling',
|
|
105
99
|
},
|
|
106
100
|
{
|
|
107
101
|
name: 'disableDragContainer',
|
|
108
102
|
type: 'boolean',
|
|
109
103
|
default: 'undefined',
|
|
110
|
-
description: 'Whether to disable drag operations for the container'
|
|
104
|
+
description: 'Whether to disable drag operations for the container',
|
|
111
105
|
},
|
|
112
106
|
{
|
|
113
107
|
name: 'acceptDragSameGroup',
|
|
114
108
|
type: 'boolean',
|
|
115
109
|
default: 'false',
|
|
116
|
-
description: 'Whether to accept drag operations within the same group'
|
|
110
|
+
description: 'Whether to accept drag operations within the same group',
|
|
117
111
|
},
|
|
118
112
|
{
|
|
119
113
|
name: 'placeholder',
|
|
120
114
|
type: 'boolean',
|
|
121
115
|
default: 'true',
|
|
122
|
-
description: 'Whether to show placeholder during drag'
|
|
116
|
+
description: 'Whether to show placeholder during drag',
|
|
123
117
|
},
|
|
124
118
|
{
|
|
125
119
|
name: 'groupName',
|
|
126
120
|
type: 'string',
|
|
127
121
|
default: "'groupDragAndDropDefault'",
|
|
128
|
-
description: 'Name of the group for drag and drop operations'
|
|
122
|
+
description: 'Name of the group for drag and drop operations',
|
|
129
123
|
},
|
|
130
124
|
{
|
|
131
125
|
name: 'dropToGroupName',
|
|
132
126
|
type: 'Array<string> | null',
|
|
133
127
|
default: 'null',
|
|
134
|
-
description: 'List of group names that can accept drops from this container'
|
|
128
|
+
description: 'List of group names that can accept drops from this container',
|
|
135
129
|
},
|
|
136
130
|
{
|
|
137
131
|
name: 'stylesOverride',
|
|
138
132
|
type: 'Array<{ className: string, styles: string }>',
|
|
139
133
|
default: 'undefined',
|
|
140
|
-
description: 'Custom styles to override default drag-drop styling'
|
|
141
|
-
}
|
|
134
|
+
description: 'Custom styles to override default drag-drop styling',
|
|
135
|
+
},
|
|
142
136
|
];
|
|
143
137
|
outputsDoc = [
|
|
144
138
|
{
|
|
145
139
|
name: 'outDragStartContainer',
|
|
146
140
|
type: 'IDragStart',
|
|
147
|
-
description: 'Event emitted when dragging starts in the container'
|
|
141
|
+
description: 'Event emitted when dragging starts in the container',
|
|
148
142
|
},
|
|
149
143
|
{
|
|
150
144
|
name: 'outDragOverContainer',
|
|
151
145
|
type: 'IDragOver',
|
|
152
|
-
description: 'Event emitted when dragging over the container'
|
|
146
|
+
description: 'Event emitted when dragging over the container',
|
|
153
147
|
},
|
|
154
148
|
{
|
|
155
149
|
name: 'outDragLeaveContainer',
|
|
156
150
|
type: 'IDragLeave',
|
|
157
|
-
description: 'Event emitted when dragging leaves the container'
|
|
151
|
+
description: 'Event emitted when dragging leaves the container',
|
|
158
152
|
},
|
|
159
153
|
{
|
|
160
154
|
name: 'outDragEndContainer',
|
|
161
155
|
type: 'IDragEnd',
|
|
162
|
-
description: 'Event emitted when dragging ends in the container'
|
|
156
|
+
description: 'Event emitted when dragging ends in the container',
|
|
163
157
|
},
|
|
164
158
|
{
|
|
165
159
|
name: 'outDroppedContainer',
|
|
166
160
|
type: 'IDrop',
|
|
167
|
-
description: 'Event emitted when an item is dropped in the container'
|
|
161
|
+
description: 'Event emitted when an item is dropped in the container',
|
|
168
162
|
},
|
|
169
163
|
{
|
|
170
164
|
name: 'outDroppedContainerEmpty',
|
|
171
165
|
type: 'IDrop',
|
|
172
|
-
description: 'Event emitted when an item is dropped in an empty container'
|
|
166
|
+
description: 'Event emitted when an item is dropped in an empty container',
|
|
173
167
|
},
|
|
174
168
|
{
|
|
175
169
|
name: 'outFunctionControl',
|
|
176
170
|
type: 'IDragDropFunctionControlEvent',
|
|
177
|
-
description: 'Event emitted to control drag-drop functionality'
|
|
178
|
-
}
|
|
171
|
+
description: 'Event emitted to control drag-drop functionality',
|
|
172
|
+
},
|
|
179
173
|
];
|
|
180
174
|
// Interface Documentation
|
|
181
175
|
interfacesDoc = [
|
|
@@ -187,7 +181,7 @@ export class LibsUiDragDropDemoComponent {
|
|
|
187
181
|
elementKeepContainer?: boolean;
|
|
188
182
|
itemDragInfo?: IItemDragInfo;
|
|
189
183
|
}`,
|
|
190
|
-
description: 'Interface for drag operation events, containing information about the dragged element and mouse position'
|
|
184
|
+
description: 'Interface for drag operation events, containing information about the dragged element and mouse position',
|
|
191
185
|
},
|
|
192
186
|
{
|
|
193
187
|
name: 'IDragStart',
|
|
@@ -196,7 +190,7 @@ export class LibsUiDragDropDemoComponent {
|
|
|
196
190
|
elementDrag: HTMLElement;
|
|
197
191
|
itemDragInfo?: IItemDragInfo;
|
|
198
192
|
}`,
|
|
199
|
-
description: 'Interface for drag start events, triggered when dragging begins'
|
|
193
|
+
description: 'Interface for drag start events, triggered when dragging begins',
|
|
200
194
|
},
|
|
201
195
|
{
|
|
202
196
|
name: 'IDragOver',
|
|
@@ -206,7 +200,7 @@ export class LibsUiDragDropDemoComponent {
|
|
|
206
200
|
elementDragOver: HTMLElement;
|
|
207
201
|
itemDragInfo?: IItemDragInfo;
|
|
208
202
|
}`,
|
|
209
|
-
description: 'Interface for drag over events, triggered when an element is dragged over another element'
|
|
203
|
+
description: 'Interface for drag over events, triggered when an element is dragged over another element',
|
|
210
204
|
},
|
|
211
205
|
{
|
|
212
206
|
name: 'IDragLeave',
|
|
@@ -215,7 +209,7 @@ export class LibsUiDragDropDemoComponent {
|
|
|
215
209
|
elementDragLeave: HTMLElement;
|
|
216
210
|
itemDragInfo?: IItemDragInfo;
|
|
217
211
|
}`,
|
|
218
|
-
description: 'Interface for drag leave events, triggered when a dragged element leaves another element'
|
|
212
|
+
description: 'Interface for drag leave events, triggered when a dragged element leaves another element',
|
|
219
213
|
},
|
|
220
214
|
{
|
|
221
215
|
name: 'IDragEnd',
|
|
@@ -224,7 +218,7 @@ export class LibsUiDragDropDemoComponent {
|
|
|
224
218
|
elementDrag: HTMLElement;
|
|
225
219
|
itemDragInfo?: IItemDragInfo;
|
|
226
220
|
}`,
|
|
227
|
-
description: 'Interface for drag end events, triggered when dragging ends'
|
|
221
|
+
description: 'Interface for drag end events, triggered when dragging ends',
|
|
228
222
|
},
|
|
229
223
|
{
|
|
230
224
|
name: 'IDrop',
|
|
@@ -233,7 +227,7 @@ export class LibsUiDragDropDemoComponent {
|
|
|
233
227
|
elementDrop: HTMLElement;
|
|
234
228
|
itemDragInfo?: IItemDragInfo;
|
|
235
229
|
}`,
|
|
236
|
-
description: 'Interface for drop events, triggered when an element is dropped'
|
|
230
|
+
description: 'Interface for drop events, triggered when an element is dropped',
|
|
237
231
|
},
|
|
238
232
|
{
|
|
239
233
|
name: 'IItemDragInfo',
|
|
@@ -247,7 +241,7 @@ export class LibsUiDragDropDemoComponent {
|
|
|
247
241
|
containerDrag?: HTMLElement;
|
|
248
242
|
containerDrop?: HTMLElement;
|
|
249
243
|
}`,
|
|
250
|
-
description: 'Interface containing information about the dragged item and its containers'
|
|
244
|
+
description: 'Interface containing information about the dragged item and its containers',
|
|
251
245
|
},
|
|
252
246
|
{
|
|
253
247
|
name: 'IDragItemInContainerVirtualScroll',
|
|
@@ -261,7 +255,7 @@ export class LibsUiDragDropDemoComponent {
|
|
|
261
255
|
dragBoundaryAcceptMouseLeaveContainer?: boolean;
|
|
262
256
|
ignoreStopEvent?: boolean;
|
|
263
257
|
}`,
|
|
264
|
-
description: 'Interface for virtual scrolling drag operations, containing information about drag boundaries and container elements'
|
|
258
|
+
description: 'Interface for virtual scrolling drag operations, containing information about drag boundaries and container elements',
|
|
265
259
|
},
|
|
266
260
|
{
|
|
267
261
|
name: 'IMousePosition',
|
|
@@ -269,15 +263,15 @@ export class LibsUiDragDropDemoComponent {
|
|
|
269
263
|
clientX: number;
|
|
270
264
|
clientY: number;
|
|
271
265
|
}`,
|
|
272
|
-
description: 'Interface representing mouse position coordinates'
|
|
266
|
+
description: 'Interface representing mouse position coordinates',
|
|
273
267
|
},
|
|
274
268
|
{
|
|
275
269
|
name: 'IDragDropFunctionControlEvent',
|
|
276
270
|
code: `interface IDragDropFunctionControlEvent {
|
|
277
271
|
setAttributeElementAndItemDrag: () => Promise<void>;
|
|
278
272
|
}`,
|
|
279
|
-
description: 'Interface for drag and drop control functions'
|
|
280
|
-
}
|
|
273
|
+
description: 'Interface for drag and drop control functions',
|
|
274
|
+
},
|
|
281
275
|
];
|
|
282
276
|
// Features
|
|
283
277
|
features = [
|
|
@@ -285,26 +279,26 @@ export class LibsUiDragDropDemoComponent {
|
|
|
285
279
|
id: 1,
|
|
286
280
|
icon: '🔄',
|
|
287
281
|
title: 'Flexible Drag and Drop',
|
|
288
|
-
description: 'Support for container-to-container dragging with customizable group names and drop zones'
|
|
282
|
+
description: 'Support for container-to-container dragging with customizable group names and drop zones',
|
|
289
283
|
},
|
|
290
284
|
{
|
|
291
285
|
id: 2,
|
|
292
286
|
icon: '📜',
|
|
293
287
|
title: 'Virtual Scrolling',
|
|
294
|
-
description: 'Efficient handling of large lists with virtual scrolling support'
|
|
288
|
+
description: 'Efficient handling of large lists with virtual scrolling support',
|
|
295
289
|
},
|
|
296
290
|
{
|
|
297
291
|
id: 3,
|
|
298
292
|
icon: '🎯',
|
|
299
293
|
title: 'Custom Boundaries',
|
|
300
|
-
description: 'Define custom drag boundaries and drop zones for precise control'
|
|
294
|
+
description: 'Define custom drag boundaries and drop zones for precise control',
|
|
301
295
|
},
|
|
302
296
|
{
|
|
303
297
|
id: 4,
|
|
304
298
|
icon: '🎨',
|
|
305
299
|
title: 'Styling Options',
|
|
306
|
-
description: 'Customizable styles for drag items and containers'
|
|
307
|
-
}
|
|
300
|
+
description: 'Customizable styles for drag items and containers',
|
|
301
|
+
},
|
|
308
302
|
];
|
|
309
303
|
// Code Examples
|
|
310
304
|
codeExamples = [
|
|
@@ -320,7 +314,7 @@ export class LibsUiDragDropDemoComponent {
|
|
|
320
314
|
{{ item }}
|
|
321
315
|
</div>
|
|
322
316
|
}
|
|
323
|
-
</div>
|
|
317
|
+
</div>`,
|
|
324
318
|
},
|
|
325
319
|
{
|
|
326
320
|
id: 2,
|
|
@@ -344,8 +338,8 @@ export class LibsUiDragDropDemoComponent {
|
|
|
344
338
|
{{ item }}
|
|
345
339
|
</div>
|
|
346
340
|
}
|
|
347
|
-
</div>
|
|
348
|
-
}
|
|
341
|
+
</div>`,
|
|
342
|
+
},
|
|
349
343
|
];
|
|
350
344
|
/**
|
|
351
345
|
* Copy text to clipboard
|
|
@@ -369,14 +363,15 @@ export class LibsUiDragDropDemoComponent {
|
|
|
369
363
|
<section class="intro-section">
|
|
370
364
|
<h2>Introduction</h2>
|
|
371
365
|
<p>
|
|
372
|
-
<code>@libs-ui/components-drag-drop</code>
|
|
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.
|
|
373
368
|
</p>
|
|
374
369
|
</section>
|
|
375
370
|
|
|
376
371
|
<section class="installation-section">
|
|
377
372
|
<h2>Installation</h2>
|
|
378
373
|
<p>To install the library, use npm or yarn:</p>
|
|
379
|
-
|
|
374
|
+
|
|
380
375
|
<div class="install-command">
|
|
381
376
|
<pre>
|
|
382
377
|
<code>npm install @libs-ui/components-drag-drop</code>
|
|
@@ -385,9 +380,9 @@ export class LibsUiDragDropDemoComponent {
|
|
|
385
380
|
(outClick)="copyToClipboard('npm install @libs-ui/components-drag-drop')" />
|
|
386
381
|
</pre>
|
|
387
382
|
</div>
|
|
388
|
-
|
|
383
|
+
|
|
389
384
|
<p>Or with yarn:</p>
|
|
390
|
-
|
|
385
|
+
|
|
391
386
|
<div class="install-command">
|
|
392
387
|
<pre>
|
|
393
388
|
<code>yarn add @libs-ui/components-drag-drop</code>
|
|
@@ -405,12 +400,14 @@ export class LibsUiDragDropDemoComponent {
|
|
|
405
400
|
<div class="demo-example">
|
|
406
401
|
<h3>Basic List</h3>
|
|
407
402
|
<div class="list-container">
|
|
408
|
-
<div
|
|
409
|
-
|
|
410
|
-
|
|
403
|
+
<div
|
|
404
|
+
LibsUiComponentsDragContainerDirective
|
|
405
|
+
[(items)]="basicItems"
|
|
406
|
+
[acceptDragSameGroup]="true">
|
|
411
407
|
@for (item of basicItems; track item) {
|
|
412
|
-
<div
|
|
413
|
-
|
|
408
|
+
<div
|
|
409
|
+
class="list-item"
|
|
410
|
+
LibsUiDragItemDirective>
|
|
414
411
|
<span class="item-icon">📋</span>
|
|
415
412
|
<span class="item-text">{{ item }}</span>
|
|
416
413
|
</div>
|
|
@@ -424,19 +421,23 @@ export class LibsUiDragDropDemoComponent {
|
|
|
424
421
|
<h3>Kanban Board</h3>
|
|
425
422
|
<div class="kanban-board">
|
|
426
423
|
@for (column of columns; track column) {
|
|
427
|
-
<div
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
|
|
431
|
-
|
|
432
|
-
|
|
424
|
+
<div
|
|
425
|
+
class="kanban-column"
|
|
426
|
+
LibsUiComponentsDragContainerDirective
|
|
427
|
+
[(items)]="column.items"
|
|
428
|
+
[groupName]="column.id"
|
|
429
|
+
[dropToGroupName]="columnsIds"
|
|
430
|
+
[acceptDragSameGroup]="true">
|
|
433
431
|
<h4>{{ column.title }}</h4>
|
|
434
432
|
@for (item of column.items; track item) {
|
|
435
|
-
<div
|
|
436
|
-
|
|
433
|
+
<div
|
|
434
|
+
class="kanban-item"
|
|
435
|
+
LibsUiDragItemDirective>
|
|
437
436
|
<div class="kanban-item-header">
|
|
438
437
|
<span class="item-title">{{ item.title }}</span>
|
|
439
|
-
<span
|
|
438
|
+
<span
|
|
439
|
+
class="item-status"
|
|
440
|
+
[class]="'status-' + item.status">
|
|
440
441
|
{{ item.status }}
|
|
441
442
|
</span>
|
|
442
443
|
</div>
|
|
@@ -452,25 +453,29 @@ export class LibsUiDragDropDemoComponent {
|
|
|
452
453
|
<div class="demo-example">
|
|
453
454
|
<h3>Nested Containers copy</h3>
|
|
454
455
|
<div class="nested-container">
|
|
455
|
-
<div
|
|
456
|
-
|
|
457
|
-
|
|
458
|
-
|
|
459
|
-
|
|
456
|
+
<div
|
|
457
|
+
LibsUiComponentsDragContainerDirective
|
|
458
|
+
[(items)]="nestedItems"
|
|
459
|
+
[groupName]="'parent'"
|
|
460
|
+
[mode]="'copy'"
|
|
461
|
+
[acceptDragSameGroup]="true">
|
|
460
462
|
@for (item of nestedItems; track item) {
|
|
461
|
-
<div
|
|
462
|
-
|
|
463
|
+
<div
|
|
464
|
+
class="nested-item"
|
|
465
|
+
LibsUiDragItemDirective>
|
|
463
466
|
<div class="nested-item-header">
|
|
464
467
|
<span class="item-title">{{ item.title }}</span>
|
|
465
468
|
</div>
|
|
466
469
|
<div class="nested-item-content">
|
|
467
|
-
<div
|
|
468
|
-
|
|
469
|
-
|
|
470
|
-
|
|
470
|
+
<div
|
|
471
|
+
LibsUiComponentsDragContainerDirective
|
|
472
|
+
[(items)]="item.subItems"
|
|
473
|
+
[groupName]="'child'"
|
|
474
|
+
[acceptDragSameGroup]="true">
|
|
471
475
|
@for (subItem of item.subItems; track subItem) {
|
|
472
|
-
<div
|
|
473
|
-
|
|
476
|
+
<div
|
|
477
|
+
class="sub-item"
|
|
478
|
+
LibsUiDragItemDirective>
|
|
474
479
|
{{ subItem }}
|
|
475
480
|
</div>
|
|
476
481
|
}
|
|
@@ -486,7 +491,7 @@ export class LibsUiDragDropDemoComponent {
|
|
|
486
491
|
|
|
487
492
|
<section class="api-doc-section">
|
|
488
493
|
<h2>API Documentation</h2>
|
|
489
|
-
|
|
494
|
+
|
|
490
495
|
<h3>Inputs</h3>
|
|
491
496
|
<div class="table-container">
|
|
492
497
|
<table class="api-table">
|
|
@@ -501,10 +506,14 @@ export class LibsUiDragDropDemoComponent {
|
|
|
501
506
|
<tbody>
|
|
502
507
|
@for (input of inputsDoc; track input.name) {
|
|
503
508
|
<tr>
|
|
504
|
-
<td
|
|
505
|
-
|
|
506
|
-
|
|
507
|
-
<td>
|
|
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>
|
|
508
517
|
</tr>
|
|
509
518
|
}
|
|
510
519
|
</tbody>
|
|
@@ -524,9 +533,13 @@ export class LibsUiDragDropDemoComponent {
|
|
|
524
533
|
<tbody>
|
|
525
534
|
@for (output of outputsDoc; track output.name) {
|
|
526
535
|
<tr>
|
|
527
|
-
<td
|
|
528
|
-
|
|
529
|
-
|
|
536
|
+
<td>
|
|
537
|
+
<code>{{ output.name }}</code>
|
|
538
|
+
</td>
|
|
539
|
+
<td>
|
|
540
|
+
<code>{{ output.type }}</code>
|
|
541
|
+
</td>
|
|
542
|
+
<td>{{ output.description }}</td>
|
|
530
543
|
</tr>
|
|
531
544
|
}
|
|
532
545
|
</tbody>
|
|
@@ -539,9 +552,9 @@ export class LibsUiDragDropDemoComponent {
|
|
|
539
552
|
<div class="interface-docs">
|
|
540
553
|
@for (interfaceItem of interfacesDoc; track interfaceItem.name) {
|
|
541
554
|
<div class="interface-item">
|
|
542
|
-
<h3>{{interfaceItem.name}}</h3>
|
|
555
|
+
<h3>{{ interfaceItem.name }}</h3>
|
|
543
556
|
<pre><code>{{interfaceItem.code}}</code></pre>
|
|
544
|
-
<p>{{interfaceItem.description}}</p>
|
|
557
|
+
<p>{{ interfaceItem.description }}</p>
|
|
545
558
|
</div>
|
|
546
559
|
}
|
|
547
560
|
</div>
|
|
@@ -552,10 +565,10 @@ export class LibsUiDragDropDemoComponent {
|
|
|
552
565
|
<ul>
|
|
553
566
|
@for (feature of features; track feature.id) {
|
|
554
567
|
<li>
|
|
555
|
-
<span class="feature-icon">{{feature.icon}}</span>
|
|
568
|
+
<span class="feature-icon">{{ feature.icon }}</span>
|
|
556
569
|
<div class="feature-info">
|
|
557
|
-
<h3>{{feature.title}}</h3>
|
|
558
|
-
<p>{{feature.description}}</p>
|
|
570
|
+
<h3>{{ feature.title }}</h3>
|
|
571
|
+
<p>{{ feature.description }}</p>
|
|
559
572
|
</div>
|
|
560
573
|
</li>
|
|
561
574
|
}
|
|
@@ -567,7 +580,7 @@ export class LibsUiDragDropDemoComponent {
|
|
|
567
580
|
<div class="code-examples">
|
|
568
581
|
@for (example of codeExamples; track example.id) {
|
|
569
582
|
<div class="code-example">
|
|
570
|
-
<h3>{{example.title}}</h3>
|
|
583
|
+
<h3>{{ example.title }}</h3>
|
|
571
584
|
<pre><code [innerHTML]="example.code"></code></pre>
|
|
572
585
|
</div>
|
|
573
586
|
}
|
|
@@ -579,12 +592,7 @@ export class LibsUiDragDropDemoComponent {
|
|
|
579
592
|
}
|
|
580
593
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiDragDropDemoComponent, decorators: [{
|
|
581
594
|
type: Component,
|
|
582
|
-
args: [{ selector: 'lib-drag-drop-demo', standalone: true, imports: [
|
|
583
|
-
CommonModule,
|
|
584
|
-
LibsUiComponentsDragContainerDirective,
|
|
585
|
-
LibsUiDragItemDirective,
|
|
586
|
-
LibsUiComponentsButtonsButtonComponent
|
|
587
|
-
], template: `
|
|
595
|
+
args: [{ selector: 'lib-drag-drop-demo', standalone: true, imports: [CommonModule, LibsUiComponentsDragContainerDirective, LibsUiDragItemDirective, LibsUiComponentsButtonsButtonComponent], template: `
|
|
588
596
|
<div class="page-container">
|
|
589
597
|
<header>
|
|
590
598
|
<h1>Demo Drag and Drop Component</h1>
|
|
@@ -595,14 +603,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
595
603
|
<section class="intro-section">
|
|
596
604
|
<h2>Introduction</h2>
|
|
597
605
|
<p>
|
|
598
|
-
<code>@libs-ui/components-drag-drop</code>
|
|
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.
|
|
599
608
|
</p>
|
|
600
609
|
</section>
|
|
601
610
|
|
|
602
611
|
<section class="installation-section">
|
|
603
612
|
<h2>Installation</h2>
|
|
604
613
|
<p>To install the library, use npm or yarn:</p>
|
|
605
|
-
|
|
614
|
+
|
|
606
615
|
<div class="install-command">
|
|
607
616
|
<pre>
|
|
608
617
|
<code>npm install @libs-ui/components-drag-drop</code>
|
|
@@ -611,9 +620,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
611
620
|
(outClick)="copyToClipboard('npm install @libs-ui/components-drag-drop')" />
|
|
612
621
|
</pre>
|
|
613
622
|
</div>
|
|
614
|
-
|
|
623
|
+
|
|
615
624
|
<p>Or with yarn:</p>
|
|
616
|
-
|
|
625
|
+
|
|
617
626
|
<div class="install-command">
|
|
618
627
|
<pre>
|
|
619
628
|
<code>yarn add @libs-ui/components-drag-drop</code>
|
|
@@ -631,12 +640,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
631
640
|
<div class="demo-example">
|
|
632
641
|
<h3>Basic List</h3>
|
|
633
642
|
<div class="list-container">
|
|
634
|
-
<div
|
|
635
|
-
|
|
636
|
-
|
|
643
|
+
<div
|
|
644
|
+
LibsUiComponentsDragContainerDirective
|
|
645
|
+
[(items)]="basicItems"
|
|
646
|
+
[acceptDragSameGroup]="true">
|
|
637
647
|
@for (item of basicItems; track item) {
|
|
638
|
-
<div
|
|
639
|
-
|
|
648
|
+
<div
|
|
649
|
+
class="list-item"
|
|
650
|
+
LibsUiDragItemDirective>
|
|
640
651
|
<span class="item-icon">📋</span>
|
|
641
652
|
<span class="item-text">{{ item }}</span>
|
|
642
653
|
</div>
|
|
@@ -650,19 +661,23 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
650
661
|
<h3>Kanban Board</h3>
|
|
651
662
|
<div class="kanban-board">
|
|
652
663
|
@for (column of columns; track column) {
|
|
653
|
-
<div
|
|
654
|
-
|
|
655
|
-
|
|
656
|
-
|
|
657
|
-
|
|
658
|
-
|
|
664
|
+
<div
|
|
665
|
+
class="kanban-column"
|
|
666
|
+
LibsUiComponentsDragContainerDirective
|
|
667
|
+
[(items)]="column.items"
|
|
668
|
+
[groupName]="column.id"
|
|
669
|
+
[dropToGroupName]="columnsIds"
|
|
670
|
+
[acceptDragSameGroup]="true">
|
|
659
671
|
<h4>{{ column.title }}</h4>
|
|
660
672
|
@for (item of column.items; track item) {
|
|
661
|
-
<div
|
|
662
|
-
|
|
673
|
+
<div
|
|
674
|
+
class="kanban-item"
|
|
675
|
+
LibsUiDragItemDirective>
|
|
663
676
|
<div class="kanban-item-header">
|
|
664
677
|
<span class="item-title">{{ item.title }}</span>
|
|
665
|
-
<span
|
|
678
|
+
<span
|
|
679
|
+
class="item-status"
|
|
680
|
+
[class]="'status-' + item.status">
|
|
666
681
|
{{ item.status }}
|
|
667
682
|
</span>
|
|
668
683
|
</div>
|
|
@@ -678,25 +693,29 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
678
693
|
<div class="demo-example">
|
|
679
694
|
<h3>Nested Containers copy</h3>
|
|
680
695
|
<div class="nested-container">
|
|
681
|
-
<div
|
|
682
|
-
|
|
683
|
-
|
|
684
|
-
|
|
685
|
-
|
|
696
|
+
<div
|
|
697
|
+
LibsUiComponentsDragContainerDirective
|
|
698
|
+
[(items)]="nestedItems"
|
|
699
|
+
[groupName]="'parent'"
|
|
700
|
+
[mode]="'copy'"
|
|
701
|
+
[acceptDragSameGroup]="true">
|
|
686
702
|
@for (item of nestedItems; track item) {
|
|
687
|
-
<div
|
|
688
|
-
|
|
703
|
+
<div
|
|
704
|
+
class="nested-item"
|
|
705
|
+
LibsUiDragItemDirective>
|
|
689
706
|
<div class="nested-item-header">
|
|
690
707
|
<span class="item-title">{{ item.title }}</span>
|
|
691
708
|
</div>
|
|
692
709
|
<div class="nested-item-content">
|
|
693
|
-
<div
|
|
694
|
-
|
|
695
|
-
|
|
696
|
-
|
|
710
|
+
<div
|
|
711
|
+
LibsUiComponentsDragContainerDirective
|
|
712
|
+
[(items)]="item.subItems"
|
|
713
|
+
[groupName]="'child'"
|
|
714
|
+
[acceptDragSameGroup]="true">
|
|
697
715
|
@for (subItem of item.subItems; track subItem) {
|
|
698
|
-
<div
|
|
699
|
-
|
|
716
|
+
<div
|
|
717
|
+
class="sub-item"
|
|
718
|
+
LibsUiDragItemDirective>
|
|
700
719
|
{{ subItem }}
|
|
701
720
|
</div>
|
|
702
721
|
}
|
|
@@ -712,7 +731,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
712
731
|
|
|
713
732
|
<section class="api-doc-section">
|
|
714
733
|
<h2>API Documentation</h2>
|
|
715
|
-
|
|
734
|
+
|
|
716
735
|
<h3>Inputs</h3>
|
|
717
736
|
<div class="table-container">
|
|
718
737
|
<table class="api-table">
|
|
@@ -727,10 +746,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
727
746
|
<tbody>
|
|
728
747
|
@for (input of inputsDoc; track input.name) {
|
|
729
748
|
<tr>
|
|
730
|
-
<td
|
|
731
|
-
|
|
732
|
-
|
|
733
|
-
<td>
|
|
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>
|
|
734
757
|
</tr>
|
|
735
758
|
}
|
|
736
759
|
</tbody>
|
|
@@ -750,9 +773,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
750
773
|
<tbody>
|
|
751
774
|
@for (output of outputsDoc; track output.name) {
|
|
752
775
|
<tr>
|
|
753
|
-
<td
|
|
754
|
-
|
|
755
|
-
|
|
776
|
+
<td>
|
|
777
|
+
<code>{{ output.name }}</code>
|
|
778
|
+
</td>
|
|
779
|
+
<td>
|
|
780
|
+
<code>{{ output.type }}</code>
|
|
781
|
+
</td>
|
|
782
|
+
<td>{{ output.description }}</td>
|
|
756
783
|
</tr>
|
|
757
784
|
}
|
|
758
785
|
</tbody>
|
|
@@ -765,9 +792,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
765
792
|
<div class="interface-docs">
|
|
766
793
|
@for (interfaceItem of interfacesDoc; track interfaceItem.name) {
|
|
767
794
|
<div class="interface-item">
|
|
768
|
-
<h3>{{interfaceItem.name}}</h3>
|
|
795
|
+
<h3>{{ interfaceItem.name }}</h3>
|
|
769
796
|
<pre><code>{{interfaceItem.code}}</code></pre>
|
|
770
|
-
<p>{{interfaceItem.description}}</p>
|
|
797
|
+
<p>{{ interfaceItem.description }}</p>
|
|
771
798
|
</div>
|
|
772
799
|
}
|
|
773
800
|
</div>
|
|
@@ -778,10 +805,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
778
805
|
<ul>
|
|
779
806
|
@for (feature of features; track feature.id) {
|
|
780
807
|
<li>
|
|
781
|
-
<span class="feature-icon">{{feature.icon}}</span>
|
|
808
|
+
<span class="feature-icon">{{ feature.icon }}</span>
|
|
782
809
|
<div class="feature-info">
|
|
783
|
-
<h3>{{feature.title}}</h3>
|
|
784
|
-
<p>{{feature.description}}</p>
|
|
810
|
+
<h3>{{ feature.title }}</h3>
|
|
811
|
+
<p>{{ feature.description }}</p>
|
|
785
812
|
</div>
|
|
786
813
|
</li>
|
|
787
814
|
}
|
|
@@ -793,7 +820,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
793
820
|
<div class="code-examples">
|
|
794
821
|
@for (example of codeExamples; track example.id) {
|
|
795
822
|
<div class="code-example">
|
|
796
|
-
<h3>{{example.title}}</h3>
|
|
823
|
+
<h3>{{ example.title }}</h3>
|
|
797
824
|
<pre><code [innerHTML]="example.code"></code></pre>
|
|
798
825
|
</div>
|
|
799
826
|
}
|
|
@@ -803,4 +830,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
803
830
|
</div>
|
|
804
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"] }]
|
|
805
832
|
}] });
|
|
806
|
-
//# 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: [\n    CommonModule,\n    LibsUiComponentsDragContainerDirective,\n    LibsUiDragItemDirective,\n    LibsUiComponentsButtonsButtonComponent\n  ],\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> 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 LibsUiComponentsDragContainerDirective \n                     [(items)]=\"basicItems\"\n                     [acceptDragSameGroup]=\"true\">\n                  @for (item of basicItems; track item) {\n                    <div 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 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 class=\"kanban-item\"\n                           LibsUiDragItemDirective>\n                        <div class=\"kanban-item-header\">\n                          <span class=\"item-title\">{{ item.title }}</span>\n                          <span class=\"item-status\" [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 LibsUiComponentsDragContainerDirective \n                     [(items)]=\"nestedItems\"\n                     [groupName]=\"'parent'\"\n                     [mode]=\"'copy'\"\n                     [acceptDragSameGroup]=\"true\">\n                  @for (item of nestedItems; track item) {\n                    <div 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 LibsUiComponentsDragContainerDirective \n                             [(items)]=\"item.subItems\"\n                             [groupName]=\"'child'\"\n                             [acceptDragSameGroup]=\"true\">\n                          @for (subItem of item.subItems; track subItem) {\n                            <div 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><code>{{input.name}}</code></td>\n                    <td><code>{{input.type}}</code></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><code>{{output.name}}</code></td>\n                    <td><code>{{output.type}}</code></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    .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: transform 0.2s, 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})\nexport class LibsUiDragDropDemoComponent {\n  // Basic List Items\n  basicItems = [\n    'Task 1',\n    'Task 2',\n    'Task 3',\n    'Task 4',\n    'Task 5'\n  ];\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   * 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} "]}
|
|
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"]}
|