@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.
@@ -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
  &lt;/div&gt;
322
316
  }
323
- &lt;/div&gt;`
317
+ &lt;/div&gt;`,
324
318
  },
325
319
  {
326
320
  id: 2,
@@ -344,8 +338,8 @@ export class LibsUiDragDropDemoComponent {
344
338
  {{ item }}
345
339
  &lt;/div&gt;
346
340
  }
347
- &lt;/div&gt;`
348
- }
341
+ &lt;/div&gt;`,
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>&#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.
366
+ <code>&#64;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 &#64;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 &#64;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 LibsUiComponentsDragContainerDirective
409
- [(items)]="basicItems"
410
- [acceptDragSameGroup]="true">
403
+ <div
404
+ LibsUiComponentsDragContainerDirective
405
+ [(items)]="basicItems"
406
+ [acceptDragSameGroup]="true">
411
407
  @for (item of basicItems; track item) {
412
- <div class="list-item"
413
- LibsUiDragItemDirective>
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 class="kanban-column"
428
- LibsUiComponentsDragContainerDirective
429
- [(items)]="column.items"
430
- [groupName]="column.id"
431
- [dropToGroupName]="columnsIds"
432
- [acceptDragSameGroup]="true">
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 class="kanban-item"
436
- LibsUiDragItemDirective>
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 class="item-status" [class]="'status-' + item.status">
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 LibsUiComponentsDragContainerDirective
456
- [(items)]="nestedItems"
457
- [groupName]="'parent'"
458
- [mode]="'copy'"
459
- [acceptDragSameGroup]="true">
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 class="nested-item"
462
- LibsUiDragItemDirective>
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 LibsUiComponentsDragContainerDirective
468
- [(items)]="item.subItems"
469
- [groupName]="'child'"
470
- [acceptDragSameGroup]="true">
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 class="sub-item"
473
- LibsUiDragItemDirective>
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><code>{{input.name}}</code></td>
505
- <td><code>{{input.type}}</code></td>
506
- <td>{{input.default}}</td>
507
- <td>{{input.description}}</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><code>{{output.name}}</code></td>
528
- <td><code>{{output.type}}</code></td>
529
- <td>{{output.description}}</td>
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>&#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.
606
+ <code>&#64;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 &#64;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 &#64;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 LibsUiComponentsDragContainerDirective
635
- [(items)]="basicItems"
636
- [acceptDragSameGroup]="true">
643
+ <div
644
+ LibsUiComponentsDragContainerDirective
645
+ [(items)]="basicItems"
646
+ [acceptDragSameGroup]="true">
637
647
  @for (item of basicItems; track item) {
638
- <div class="list-item"
639
- LibsUiDragItemDirective>
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 class="kanban-column"
654
- LibsUiComponentsDragContainerDirective
655
- [(items)]="column.items"
656
- [groupName]="column.id"
657
- [dropToGroupName]="columnsIds"
658
- [acceptDragSameGroup]="true">
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 class="kanban-item"
662
- LibsUiDragItemDirective>
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 class="item-status" [class]="'status-' + item.status">
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 LibsUiComponentsDragContainerDirective
682
- [(items)]="nestedItems"
683
- [groupName]="'parent'"
684
- [mode]="'copy'"
685
- [acceptDragSameGroup]="true">
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 class="nested-item"
688
- LibsUiDragItemDirective>
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 LibsUiComponentsDragContainerDirective
694
- [(items)]="item.subItems"
695
- [groupName]="'child'"
696
- [acceptDragSameGroup]="true">
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 class="sub-item"
699
- LibsUiDragItemDirective>
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><code>{{input.name}}</code></td>
731
- <td><code>{{input.type}}</code></td>
732
- <td>{{input.default}}</td>
733
- <td>{{input.description}}</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><code>{{output.name}}</code></td>
754
- <td><code>{{output.type}}</code></td>
755
- <td>{{output.description}}</td>
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":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC1C,OAAO,EAAE,sCAAsC,EAAE,MAAM,oCAAoC,CAAC;AAC5F,OAAO,EAAE,sCAAsC,EAAE,MAAM,wBAAwB,CAAC;AAChF,OAAO,EAAE,uBAAuB,EAAE,MAAM,wBAAwB,CAAC;;AAklBjE,MAAM,OAAO,2BAA2B;IACtC,mBAAmB;IACnB,UAAU,GAAG;QACX,QAAQ;QACR,QAAQ;QACR,QAAQ;QACR,QAAQ;QACR,QAAQ;KACT,CAAC;IAEF,uBAAuB;IACvB,UAAU,GAAG,CAAC,MAAM,EAAE,aAAa,EAAE,MAAM,CAAC,CAAC;IAC7C,OAAO,GAAa;QAClB;YACE,EAAE,EAAE,MAAM;YACV,KAAK,EAAE,OAAO;YACd,KAAK,EAAE;gBACL;oBACE,EAAE,EAAE,CAAC;oBACL,KAAK,EAAE,yBAAyB;oBAChC,WAAW,EAAE,kDAAkD;oBAC/D,MAAM,EAAE,MAAM;iBACf;gBACD;oBACE,EAAE,EAAE,CAAC;oBACL,KAAK,EAAE,gBAAgB;oBACvB,WAAW,EAAE,+CAA+C;oBAC5D,MAAM,EAAE,MAAM;iBACf;aACF;SACF;QACD;YACE,EAAE,EAAE,aAAa;YACjB,KAAK,EAAE,aAAa;YACpB,KAAK,EAAE;gBACL;oBACE,EAAE,EAAE,CAAC;oBACL,KAAK,EAAE,oBAAoB;oBAC3B,WAAW,EAAE,wCAAwC;oBACrD,MAAM,EAAE,aAAa;iBACtB;aACF;SACF;QACD;YACE,EAAE,EAAE,MAAM;YACV,KAAK,EAAE,MAAM;YACb,KAAK,EAAE;gBACL;oBACE,EAAE,EAAE,CAAC;oBACL,KAAK,EAAE,yBAAyB;oBAChC,WAAW,EAAE,sDAAsD;oBACnE,MAAM,EAAE,MAAM;iBACf;aACF;SACF;KACF,CAAC;IAEF,eAAe;IACf,WAAW,GAAG;QACZ;YACE,EAAE,EAAE,CAAC;YACL,KAAK,EAAE,WAAW;YAClB,QAAQ,EAAE,CAAC,QAAQ,EAAE,QAAQ,EAAE,QAAQ,CAAC;SACzC;QACD;YACE,EAAE,EAAE,CAAC;YACL,KAAK,EAAE,WAAW;YAClB,QAAQ,EAAE,CAAC,QAAQ,EAAE,QAAQ,CAAC;SAC/B;QACD;YACE,EAAE,EAAE,CAAC;YACL,KAAK,EAAE,WAAW;YAClB,QAAQ,EAAE,CAAC,QAAQ,EAAE,QAAQ,EAAE,QAAQ,CAAC;SACzC;KACF,CAAC;IAEF,oBAAoB;IACpB,SAAS,GAAG;QACV;YACE,IAAI,EAAE,OAAO;YACb,IAAI,EAAE,gBAAgB;YACtB,OAAO,EAAE,IAAI;YACb,WAAW,EAAE,iDAAiD;SAC/D;QACD;YACE,IAAI,EAAE,MAAM;YACZ,IAAI,EAAE,8BAA8B;YACpC,OAAO,EAAE,QAAQ;YACjB,WAAW,EAAE,mCAAmC;SACjD;QACD;YACE,IAAI,EAAE,eAAe;YACrB,IAAI,EAAE,2BAA2B;YACjC,OAAO,EAAE,WAAW;YACpB,WAAW,EAAE,4BAA4B;SAC1C;QACD;YACE,IAAI,EAAE,mBAAmB;YACzB,IAAI,EAAE,qBAAqB;YAC3B,OAAO,EAAE,YAAY;YACrB,WAAW,EAAE,qCAAqC;SACnD;QACD;YACE,IAAI,EAAE,sBAAsB;YAC5B,IAAI,EAAE,SAAS;YACf,OAAO,EAAE,WAAW;YACpB,WAAW,EAAE,sDAAsD;SACpE;QACD;YACE,IAAI,EAAE,qBAAqB;YAC3B,IAAI,EAAE,SAAS;YACf,OAAO,EAAE,OAAO;YAChB,WAAW,EAAE,yDAAyD;SACvE;QACD;YACE,IAAI,EAAE,aAAa;YACnB,IAAI,EAAE,SAAS;YACf,OAAO,EAAE,MAAM;YACf,WAAW,EAAE,yCAAyC;SACvD;QACD;YACE,IAAI,EAAE,WAAW;YACjB,IAAI,EAAE,QAAQ;YACd,OAAO,EAAE,2BAA2B;YACpC,WAAW,EAAE,gDAAgD;SAC9D;QACD;YACE,IAAI,EAAE,iBAAiB;YACvB,IAAI,EAAE,sBAAsB;YAC5B,OAAO,EAAE,MAAM;YACf,WAAW,EAAE,+DAA+D;SAC7E;QACD;YACE,IAAI,EAAE,gBAAgB;YACtB,IAAI,EAAE,8CAA8C;YACpD,OAAO,EAAE,WAAW;YACpB,WAAW,EAAE,qDAAqD;SACnE;KACF,CAAC;IAEF,UAAU,GAAG;QACX;YACE,IAAI,EAAE,uBAAuB;YAC7B,IAAI,EAAE,YAAY;YAClB,WAAW,EAAE,qDAAqD;SACnE;QACD;YACE,IAAI,EAAE,sBAAsB;YAC5B,IAAI,EAAE,WAAW;YACjB,WAAW,EAAE,gDAAgD;SAC9D;QACD;YACE,IAAI,EAAE,uBAAuB;YAC7B,IAAI,EAAE,YAAY;YAClB,WAAW,EAAE,kDAAkD;SAChE;QACD;YACE,IAAI,EAAE,qBAAqB;YAC3B,IAAI,EAAE,UAAU;YAChB,WAAW,EAAE,mDAAmD;SACjE;QACD;YACE,IAAI,EAAE,qBAAqB;YAC3B,IAAI,EAAE,OAAO;YACb,WAAW,EAAE,wDAAwD;SACtE;QACD;YACE,IAAI,EAAE,0BAA0B;YAChC,IAAI,EAAE,OAAO;YACb,WAAW,EAAE,6DAA6D;SAC3E;QACD;YACE,IAAI,EAAE,oBAAoB;YAC1B,IAAI,EAAE,+BAA+B;YACrC,WAAW,EAAE,kDAAkD;SAChE;KACF,CAAC;IAEF,0BAA0B;IAC1B,aAAa,GAAG;QACd;YACE,IAAI,EAAE,WAAW;YACjB,IAAI,EAAE;;;;;EAKV;YACI,WAAW,EAAE,0GAA0G;SACxH;QACD;YACE,IAAI,EAAE,YAAY;YAClB,IAAI,EAAE;;;;EAIV;YACI,WAAW,EAAE,iEAAiE;SAC/E;QACD;YACE,IAAI,EAAE,WAAW;YACjB,IAAI,EAAE;;;;;EAKV;YACI,WAAW,EAAE,2FAA2F;SACzG;QACD;YACE,IAAI,EAAE,YAAY;YAClB,IAAI,EAAE;;;;EAIV;YACI,WAAW,EAAE,0FAA0F;SACxG;QACD;YACE,IAAI,EAAE,UAAU;YAChB,IAAI,EAAE;;;;EAIV;YACI,WAAW,EAAE,6DAA6D;SAC3E;QACD;YACE,IAAI,EAAE,OAAO;YACb,IAAI,EAAE;;;;EAIV;YACI,WAAW,EAAE,iEAAiE;SAC/E;QACD;YACE,IAAI,EAAE,eAAe;YACrB,IAAI,EAAE;;;;;;;;;EASV;YACI,WAAW,EAAE,4EAA4E;SAC1F;QACD;YACE,IAAI,EAAE,mCAAmC;YACzC,IAAI,EAAE;;;;;;;;;EASV;YACI,WAAW,EAAE,sHAAsH;SACpI;QACD;YACE,IAAI,EAAE,gBAAgB;YACtB,IAAI,EAAE;;;EAGV;YACI,WAAW,EAAE,mDAAmD;SACjE;QACD;YACE,IAAI,EAAE,+BAA+B;YACrC,IAAI,EAAE;;EAEV;YACI,WAAW,EAAE,+CAA+C;SAC7D;KACF,CAAC;IAEF,WAAW;IACX,QAAQ,GAAG;QACT;YACE,EAAE,EAAE,CAAC;YACL,IAAI,EAAE,IAAI;YACV,KAAK,EAAE,wBAAwB;YAC/B,WAAW,EAAE,0FAA0F;SACxG;QACD;YACE,EAAE,EAAE,CAAC;YACL,IAAI,EAAE,IAAI;YACV,KAAK,EAAE,mBAAmB;YAC1B,WAAW,EAAE,kEAAkE;SAChF;QACD;YACE,EAAE,EAAE,CAAC;YACL,IAAI,EAAE,IAAI;YACV,KAAK,EAAE,mBAAmB;YAC1B,WAAW,EAAE,kEAAkE;SAChF;QACD;YACE,EAAE,EAAE,CAAC;YACL,IAAI,EAAE,IAAI;YACV,KAAK,EAAE,iBAAiB;YACxB,WAAW,EAAE,mDAAmD;SACjE;KACF,CAAC;IAEF,gBAAgB;IAChB,YAAY,GAAG;QACb;YACE,EAAE,EAAE,CAAC;YACL,KAAK,EAAE,aAAa;YACpB,IAAI,EAAE;;;;;;;;;aASC;SACR;QACD;YACE,EAAE,EAAE,CAAC;YACL,KAAK,EAAE,wBAAwB;YAC/B,IAAI,EAAE;;;;;;;;;;;;;;;;;;;aAmBC;SACR;KAAC,CAAC;IAEL;;OAEG;IACH,eAAe,CAAC,IAAY;QAC1B,SAAS,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,IAAI,CACtC,GAAG,EAAE;YACH,KAAK,CAAC,qBAAqB,CAAC,CAAC;QAC/B,CAAC,EACD,CAAC,GAAG,EAAE,EAAE;YACN,OAAO,CAAC,KAAK,CAAC,uBAAuB,EAAE,GAAG,CAAC,CAAC;QAC9C,CAAC,CACF,CAAC;IACJ,CAAC;wGA1WU,2BAA2B;4FAA3B,2BAA2B,8EA1jB5B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAyNT,06HA9NC,YAAY,+BACZ,sCAAsC,0cACtC,uBAAuB,+ZACvB,sCAAsC;;4FA4jB7B,2BAA2B;kBAnkBvC,SAAS;+BACE,oBAAoB,cAClB,IAAI,WACP;wBACP,YAAY;wBACZ,sCAAsC;wBACtC,uBAAuB;wBACvB,sCAAsC;qBACvC,YACS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAyNT","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":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC1C,OAAO,EAAE,sCAAsC,EAAE,MAAM,oCAAoC,CAAC;AAC5F,OAAO,EAAE,sCAAsC,EAAE,MAAM,wBAAwB,CAAC;AAChF,OAAO,EAAE,uBAAuB,EAAE,MAAM,wBAAwB,CAAC;;AAomBjE,MAAM,OAAO,2BAA2B;IACtC,mBAAmB;IACnB,UAAU,GAAG,CAAC,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,CAAC,CAAC;IAEhE,uBAAuB;IACvB,UAAU,GAAG,CAAC,MAAM,EAAE,aAAa,EAAE,MAAM,CAAC,CAAC;IAC7C,OAAO,GAAa;QAClB;YACE,EAAE,EAAE,MAAM;YACV,KAAK,EAAE,OAAO;YACd,KAAK,EAAE;gBACL;oBACE,EAAE,EAAE,CAAC;oBACL,KAAK,EAAE,yBAAyB;oBAChC,WAAW,EAAE,kDAAkD;oBAC/D,MAAM,EAAE,MAAM;iBACf;gBACD;oBACE,EAAE,EAAE,CAAC;oBACL,KAAK,EAAE,gBAAgB;oBACvB,WAAW,EAAE,+CAA+C;oBAC5D,MAAM,EAAE,MAAM;iBACf;aACF;SACF;QACD;YACE,EAAE,EAAE,aAAa;YACjB,KAAK,EAAE,aAAa;YACpB,KAAK,EAAE;gBACL;oBACE,EAAE,EAAE,CAAC;oBACL,KAAK,EAAE,oBAAoB;oBAC3B,WAAW,EAAE,wCAAwC;oBACrD,MAAM,EAAE,aAAa;iBACtB;aACF;SACF;QACD;YACE,EAAE,EAAE,MAAM;YACV,KAAK,EAAE,MAAM;YACb,KAAK,EAAE;gBACL;oBACE,EAAE,EAAE,CAAC;oBACL,KAAK,EAAE,yBAAyB;oBAChC,WAAW,EAAE,sDAAsD;oBACnE,MAAM,EAAE,MAAM;iBACf;aACF;SACF;KACF,CAAC;IAEF,eAAe;IACf,WAAW,GAAG;QACZ;YACE,EAAE,EAAE,CAAC;YACL,KAAK,EAAE,WAAW;YAClB,QAAQ,EAAE,CAAC,QAAQ,EAAE,QAAQ,EAAE,QAAQ,CAAC;SACzC;QACD;YACE,EAAE,EAAE,CAAC;YACL,KAAK,EAAE,WAAW;YAClB,QAAQ,EAAE,CAAC,QAAQ,EAAE,QAAQ,CAAC;SAC/B;QACD;YACE,EAAE,EAAE,CAAC;YACL,KAAK,EAAE,WAAW;YAClB,QAAQ,EAAE,CAAC,QAAQ,EAAE,QAAQ,EAAE,QAAQ,CAAC;SACzC;KACF,CAAC;IAEF,oBAAoB;IACpB,SAAS,GAAG;QACV;YACE,IAAI,EAAE,OAAO;YACb,IAAI,EAAE,gBAAgB;YACtB,OAAO,EAAE,IAAI;YACb,WAAW,EAAE,iDAAiD;SAC/D;QACD;YACE,IAAI,EAAE,MAAM;YACZ,IAAI,EAAE,8BAA8B;YACpC,OAAO,EAAE,QAAQ;YACjB,WAAW,EAAE,mCAAmC;SACjD;QACD;YACE,IAAI,EAAE,eAAe;YACrB,IAAI,EAAE,2BAA2B;YACjC,OAAO,EAAE,WAAW;YACpB,WAAW,EAAE,4BAA4B;SAC1C;QACD;YACE,IAAI,EAAE,mBAAmB;YACzB,IAAI,EAAE,qBAAqB;YAC3B,OAAO,EAAE,YAAY;YACrB,WAAW,EAAE,qCAAqC;SACnD;QACD;YACE,IAAI,EAAE,sBAAsB;YAC5B,IAAI,EAAE,SAAS;YACf,OAAO,EAAE,WAAW;YACpB,WAAW,EAAE,sDAAsD;SACpE;QACD;YACE,IAAI,EAAE,qBAAqB;YAC3B,IAAI,EAAE,SAAS;YACf,OAAO,EAAE,OAAO;YAChB,WAAW,EAAE,yDAAyD;SACvE;QACD;YACE,IAAI,EAAE,aAAa;YACnB,IAAI,EAAE,SAAS;YACf,OAAO,EAAE,MAAM;YACf,WAAW,EAAE,yCAAyC;SACvD;QACD;YACE,IAAI,EAAE,WAAW;YACjB,IAAI,EAAE,QAAQ;YACd,OAAO,EAAE,2BAA2B;YACpC,WAAW,EAAE,gDAAgD;SAC9D;QACD;YACE,IAAI,EAAE,iBAAiB;YACvB,IAAI,EAAE,sBAAsB;YAC5B,OAAO,EAAE,MAAM;YACf,WAAW,EAAE,+DAA+D;SAC7E;QACD;YACE,IAAI,EAAE,gBAAgB;YACtB,IAAI,EAAE,8CAA8C;YACpD,OAAO,EAAE,WAAW;YACpB,WAAW,EAAE,qDAAqD;SACnE;KACF,CAAC;IAEF,UAAU,GAAG;QACX;YACE,IAAI,EAAE,uBAAuB;YAC7B,IAAI,EAAE,YAAY;YAClB,WAAW,EAAE,qDAAqD;SACnE;QACD;YACE,IAAI,EAAE,sBAAsB;YAC5B,IAAI,EAAE,WAAW;YACjB,WAAW,EAAE,gDAAgD;SAC9D;QACD;YACE,IAAI,EAAE,uBAAuB;YAC7B,IAAI,EAAE,YAAY;YAClB,WAAW,EAAE,kDAAkD;SAChE;QACD;YACE,IAAI,EAAE,qBAAqB;YAC3B,IAAI,EAAE,UAAU;YAChB,WAAW,EAAE,mDAAmD;SACjE;QACD;YACE,IAAI,EAAE,qBAAqB;YAC3B,IAAI,EAAE,OAAO;YACb,WAAW,EAAE,wDAAwD;SACtE;QACD;YACE,IAAI,EAAE,0BAA0B;YAChC,IAAI,EAAE,OAAO;YACb,WAAW,EAAE,6DAA6D;SAC3E;QACD;YACE,IAAI,EAAE,oBAAoB;YAC1B,IAAI,EAAE,+BAA+B;YACrC,WAAW,EAAE,kDAAkD;SAChE;KACF,CAAC;IAEF,0BAA0B;IAC1B,aAAa,GAAG;QACd;YACE,IAAI,EAAE,WAAW;YACjB,IAAI,EAAE;;;;;EAKV;YACI,WAAW,EAAE,0GAA0G;SACxH;QACD;YACE,IAAI,EAAE,YAAY;YAClB,IAAI,EAAE;;;;EAIV;YACI,WAAW,EAAE,iEAAiE;SAC/E;QACD;YACE,IAAI,EAAE,WAAW;YACjB,IAAI,EAAE;;;;;EAKV;YACI,WAAW,EAAE,2FAA2F;SACzG;QACD;YACE,IAAI,EAAE,YAAY;YAClB,IAAI,EAAE;;;;EAIV;YACI,WAAW,EAAE,0FAA0F;SACxG;QACD;YACE,IAAI,EAAE,UAAU;YAChB,IAAI,EAAE;;;;EAIV;YACI,WAAW,EAAE,6DAA6D;SAC3E;QACD;YACE,IAAI,EAAE,OAAO;YACb,IAAI,EAAE;;;;EAIV;YACI,WAAW,EAAE,iEAAiE;SAC/E;QACD;YACE,IAAI,EAAE,eAAe;YACrB,IAAI,EAAE;;;;;;;;;EASV;YACI,WAAW,EAAE,4EAA4E;SAC1F;QACD;YACE,IAAI,EAAE,mCAAmC;YACzC,IAAI,EAAE;;;;;;;;;EASV;YACI,WAAW,EAAE,sHAAsH;SACpI;QACD;YACE,IAAI,EAAE,gBAAgB;YACtB,IAAI,EAAE;;;EAGV;YACI,WAAW,EAAE,mDAAmD;SACjE;QACD;YACE,IAAI,EAAE,+BAA+B;YACrC,IAAI,EAAE;;EAEV;YACI,WAAW,EAAE,+CAA+C;SAC7D;KACF,CAAC;IAEF,WAAW;IACX,QAAQ,GAAG;QACT;YACE,EAAE,EAAE,CAAC;YACL,IAAI,EAAE,IAAI;YACV,KAAK,EAAE,wBAAwB;YAC/B,WAAW,EAAE,0FAA0F;SACxG;QACD;YACE,EAAE,EAAE,CAAC;YACL,IAAI,EAAE,IAAI;YACV,KAAK,EAAE,mBAAmB;YAC1B,WAAW,EAAE,kEAAkE;SAChF;QACD;YACE,EAAE,EAAE,CAAC;YACL,IAAI,EAAE,IAAI;YACV,KAAK,EAAE,mBAAmB;YAC1B,WAAW,EAAE,kEAAkE;SAChF;QACD;YACE,EAAE,EAAE,CAAC;YACL,IAAI,EAAE,IAAI;YACV,KAAK,EAAE,iBAAiB;YACxB,WAAW,EAAE,mDAAmD;SACjE;KACF,CAAC;IAEF,gBAAgB;IAChB,YAAY,GAAG;QACb;YACE,EAAE,EAAE,CAAC;YACL,KAAK,EAAE,aAAa;YACpB,IAAI,EAAE;;;;;;;;;aASC;SACR;QACD;YACE,EAAE,EAAE,CAAC;YACL,KAAK,EAAE,wBAAwB;YAC/B,IAAI,EAAE;;;;;;;;;;;;;;;;;;;aAmBC;SACR;KACF,CAAC;IAEF;;OAEG;IACH,eAAe,CAAC,IAAY;QAC1B,SAAS,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,IAAI,CACtC,GAAG,EAAE;YACH,KAAK,CAAC,qBAAqB,CAAC,CAAC;QAC/B,CAAC,EACD,CAAC,GAAG,EAAE,EAAE;YACN,OAAO,CAAC,KAAK,CAAC,uBAAuB,EAAE,GAAG,CAAC,CAAC;QAC9C,CAAC,CACF,CAAC;IACJ,CAAC;wGArWU,2BAA2B;4FAA3B,2BAA2B,8EAjlB5B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4OT,06HA7OS,YAAY,+BAAE,sCAAsC,0cAAE,uBAAuB,+ZAAE,sCAAsC;;4FAklBpH,2BAA2B;kBArlBvC,SAAS;+BACE,oBAAoB,cAClB,IAAI,WACP,CAAC,YAAY,EAAE,sCAAsC,EAAE,uBAAuB,EAAE,sCAAsC,CAAC,YACtH;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4OT","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"]}