@angular/cdk 18.0.0-next.5 → 18.0.0-next.6

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.
Files changed (131) hide show
  1. package/drag-drop/index.d.ts +4 -8
  2. package/esm2022/a11y/a11y-module.mjs +4 -4
  3. package/esm2022/a11y/aria-describer/aria-describer.mjs +3 -3
  4. package/esm2022/a11y/focus-monitor/focus-monitor.mjs +6 -6
  5. package/esm2022/a11y/focus-trap/configurable-focus-trap-factory.mjs +3 -3
  6. package/esm2022/a11y/focus-trap/focus-trap-manager.mjs +3 -3
  7. package/esm2022/a11y/focus-trap/focus-trap.mjs +6 -6
  8. package/esm2022/a11y/high-contrast-mode/high-contrast-mode-detector.mjs +3 -3
  9. package/esm2022/a11y/input-modality/input-modality-detector.mjs +3 -3
  10. package/esm2022/a11y/interactivity-checker/interactivity-checker.mjs +3 -3
  11. package/esm2022/a11y/key-manager/list-key-manager.mjs +2 -2
  12. package/esm2022/a11y/live-announcer/live-announcer.mjs +6 -6
  13. package/esm2022/accordion/accordion-item.mjs +3 -3
  14. package/esm2022/accordion/accordion-module.mjs +4 -4
  15. package/esm2022/accordion/accordion.mjs +3 -3
  16. package/esm2022/bidi/bidi-module.mjs +4 -4
  17. package/esm2022/bidi/dir.mjs +3 -3
  18. package/esm2022/bidi/directionality.mjs +3 -3
  19. package/esm2022/clipboard/clipboard-module.mjs +4 -4
  20. package/esm2022/clipboard/clipboard.mjs +3 -3
  21. package/esm2022/clipboard/copy-to-clipboard.mjs +3 -3
  22. package/esm2022/collections/unique-selection-dispatcher.mjs +3 -3
  23. package/esm2022/dialog/dialog-container.mjs +3 -3
  24. package/esm2022/dialog/dialog-module.mjs +4 -4
  25. package/esm2022/dialog/dialog.mjs +3 -3
  26. package/esm2022/drag-drop/directives/drag-handle.mjs +3 -3
  27. package/esm2022/drag-drop/directives/drag-placeholder.mjs +3 -3
  28. package/esm2022/drag-drop/directives/drag-preview.mjs +3 -3
  29. package/esm2022/drag-drop/directives/drag.mjs +3 -3
  30. package/esm2022/drag-drop/directives/drop-list-group.mjs +3 -3
  31. package/esm2022/drag-drop/directives/drop-list.mjs +3 -3
  32. package/esm2022/drag-drop/dom/root-node.mjs +21 -0
  33. package/esm2022/drag-drop/dom/styling.mjs +21 -1
  34. package/esm2022/drag-drop/drag-drop-module.mjs +4 -4
  35. package/esm2022/drag-drop/drag-drop-registry.mjs +3 -3
  36. package/esm2022/drag-drop/drag-drop.mjs +3 -3
  37. package/esm2022/drag-drop/drag-ref.mjs +11 -99
  38. package/esm2022/drag-drop/preview-ref.mjs +135 -0
  39. package/esm2022/layout/breakpoints-observer.mjs +3 -3
  40. package/esm2022/layout/layout-module.mjs +4 -4
  41. package/esm2022/layout/media-matcher.mjs +3 -3
  42. package/esm2022/listbox/listbox-module.mjs +4 -4
  43. package/esm2022/listbox/listbox.mjs +6 -6
  44. package/esm2022/menu/context-menu-trigger.mjs +6 -6
  45. package/esm2022/menu/menu-aim.mjs +6 -6
  46. package/esm2022/menu/menu-bar.mjs +3 -3
  47. package/esm2022/menu/menu-base.mjs +3 -3
  48. package/esm2022/menu/menu-group.mjs +3 -3
  49. package/esm2022/menu/menu-item-checkbox.mjs +3 -3
  50. package/esm2022/menu/menu-item-radio.mjs +3 -3
  51. package/esm2022/menu/menu-item-selectable.mjs +3 -3
  52. package/esm2022/menu/menu-item.mjs +3 -3
  53. package/esm2022/menu/menu-module.mjs +4 -4
  54. package/esm2022/menu/menu-stack.mjs +3 -3
  55. package/esm2022/menu/menu-trigger-base.mjs +3 -3
  56. package/esm2022/menu/menu-trigger.mjs +3 -3
  57. package/esm2022/menu/menu.mjs +3 -3
  58. package/esm2022/observers/observe-content.mjs +13 -13
  59. package/esm2022/observers/private/shared-resize-observer.mjs +3 -3
  60. package/esm2022/overlay/dispatchers/base-overlay-dispatcher.mjs +3 -3
  61. package/esm2022/overlay/dispatchers/overlay-keyboard-dispatcher.mjs +3 -3
  62. package/esm2022/overlay/dispatchers/overlay-outside-click-dispatcher.mjs +3 -3
  63. package/esm2022/overlay/fullscreen-overlay-container.mjs +3 -3
  64. package/esm2022/overlay/overlay-container.mjs +3 -3
  65. package/esm2022/overlay/overlay-directives.mjs +6 -6
  66. package/esm2022/overlay/overlay-module.mjs +4 -4
  67. package/esm2022/overlay/overlay.mjs +3 -3
  68. package/esm2022/overlay/position/overlay-position-builder.mjs +3 -3
  69. package/esm2022/overlay/scroll/scroll-strategy-options.mjs +3 -3
  70. package/esm2022/platform/platform-module.mjs +4 -4
  71. package/esm2022/platform/platform.mjs +3 -3
  72. package/esm2022/portal/portal-directives.mjs +16 -16
  73. package/esm2022/scrolling/fixed-size-virtual-scroll.mjs +3 -3
  74. package/esm2022/scrolling/scroll-dispatcher.mjs +3 -3
  75. package/esm2022/scrolling/scrollable.mjs +3 -3
  76. package/esm2022/scrolling/scrolling-module.mjs +8 -8
  77. package/esm2022/scrolling/viewport-ruler.mjs +3 -3
  78. package/esm2022/scrolling/virtual-for-of.mjs +3 -3
  79. package/esm2022/scrolling/virtual-scroll-viewport.mjs +3 -3
  80. package/esm2022/scrolling/virtual-scrollable-element.mjs +3 -3
  81. package/esm2022/scrolling/virtual-scrollable-window.mjs +3 -3
  82. package/esm2022/scrolling/virtual-scrollable.mjs +3 -3
  83. package/esm2022/stepper/step-header.mjs +3 -3
  84. package/esm2022/stepper/step-label.mjs +3 -3
  85. package/esm2022/stepper/stepper-button.mjs +6 -6
  86. package/esm2022/stepper/stepper-module.mjs +4 -4
  87. package/esm2022/stepper/stepper.mjs +6 -6
  88. package/esm2022/table/cell.mjs +21 -21
  89. package/esm2022/table/coalesced-style-scheduler.mjs +3 -3
  90. package/esm2022/table/row.mjs +27 -27
  91. package/esm2022/table/table-module.mjs +4 -4
  92. package/esm2022/table/table.mjs +18 -18
  93. package/esm2022/table/text-column.mjs +3 -3
  94. package/esm2022/text-field/autofill.mjs +6 -6
  95. package/esm2022/text-field/autosize.mjs +3 -3
  96. package/esm2022/text-field/text-field-module.mjs +4 -4
  97. package/esm2022/tree/nested-node.mjs +3 -3
  98. package/esm2022/tree/node.mjs +3 -3
  99. package/esm2022/tree/outlet.mjs +3 -3
  100. package/esm2022/tree/padding.mjs +3 -3
  101. package/esm2022/tree/toggle.mjs +3 -3
  102. package/esm2022/tree/tree-module.mjs +4 -4
  103. package/esm2022/tree/tree.mjs +6 -6
  104. package/esm2022/version.mjs +1 -1
  105. package/fesm2022/a11y.mjs +41 -41
  106. package/fesm2022/a11y.mjs.map +1 -1
  107. package/fesm2022/accordion.mjs +10 -10
  108. package/fesm2022/bidi.mjs +10 -10
  109. package/fesm2022/cdk.mjs +1 -1
  110. package/fesm2022/cdk.mjs.map +1 -1
  111. package/fesm2022/clipboard.mjs +10 -10
  112. package/fesm2022/collections.mjs +3 -3
  113. package/fesm2022/dialog.mjs +10 -10
  114. package/fesm2022/drag-drop.mjs +220 -151
  115. package/fesm2022/drag-drop.mjs.map +1 -1
  116. package/fesm2022/layout.mjs +10 -10
  117. package/fesm2022/listbox.mjs +10 -10
  118. package/fesm2022/menu.mjs +49 -49
  119. package/fesm2022/observers/private.mjs +3 -3
  120. package/fesm2022/observers.mjs +13 -13
  121. package/fesm2022/overlay.mjs +34 -34
  122. package/fesm2022/platform.mjs +7 -7
  123. package/fesm2022/portal.mjs +16 -16
  124. package/fesm2022/scrolling.mjs +35 -35
  125. package/fesm2022/stepper.mjs +22 -22
  126. package/fesm2022/table.mjs +76 -76
  127. package/fesm2022/text-field.mjs +13 -13
  128. package/fesm2022/tree.mjs +25 -25
  129. package/package.json +1 -1
  130. package/schematics/ng-add/index.js +1 -1
  131. package/schematics/ng-add/index.mjs +1 -1
@@ -71,34 +71,25 @@ function combineTransforms(transform, initialTransform) {
71
71
  ? transform + ' ' + initialTransform
72
72
  : transform;
73
73
  }
74
-
75
- /** Parses a CSS time value to milliseconds. */
76
- function parseCssTimeUnitsToMs(value) {
77
- // Some browsers will return it in seconds, whereas others will return milliseconds.
78
- const multiplier = value.toLowerCase().indexOf('ms') > -1 ? 1 : 1000;
79
- return parseFloat(value) * multiplier;
80
- }
81
- /** Gets the transform transition duration, including the delay, of an element in milliseconds. */
82
- function getTransformTransitionDurationInMs(element) {
83
- const computedStyle = getComputedStyle(element);
84
- const transitionedProperties = parseCssPropertyValue(computedStyle, 'transition-property');
85
- const property = transitionedProperties.find(prop => prop === 'transform' || prop === 'all');
86
- // If there's no transition for `all` or `transform`, we shouldn't do anything.
87
- if (!property) {
88
- return 0;
89
- }
90
- // Get the index of the property that we're interested in and match
91
- // it up to the same index in `transition-delay` and `transition-duration`.
92
- const propertyIndex = transitionedProperties.indexOf(property);
93
- const rawDurations = parseCssPropertyValue(computedStyle, 'transition-duration');
94
- const rawDelays = parseCssPropertyValue(computedStyle, 'transition-delay');
95
- return (parseCssTimeUnitsToMs(rawDurations[propertyIndex]) +
96
- parseCssTimeUnitsToMs(rawDelays[propertyIndex]));
74
+ /**
75
+ * Matches the target element's size to the source's size.
76
+ * @param target Element that needs to be resized.
77
+ * @param sourceRect Dimensions of the source element.
78
+ */
79
+ function matchElementSize(target, sourceRect) {
80
+ target.style.width = `${sourceRect.width}px`;
81
+ target.style.height = `${sourceRect.height}px`;
82
+ target.style.transform = getTransform(sourceRect.left, sourceRect.top);
97
83
  }
98
- /** Parses out multiple values from a computed style into an array. */
99
- function parseCssPropertyValue(computedStyle, name) {
100
- const value = computedStyle.getPropertyValue(name);
101
- return value.split(',').map(part => part.trim());
84
+ /**
85
+ * Gets a 3d `transform` that can be applied to an element.
86
+ * @param x Desired position of the element along the X axis.
87
+ * @param y Desired position of the element along the Y axis.
88
+ */
89
+ function getTransform(x, y) {
90
+ // Round the transforms since some browsers will
91
+ // blur the elements for sub-pixel transforms.
92
+ return `translate3d(${Math.round(x)}px, ${Math.round(y)}px, 0)`;
102
93
  }
103
94
 
104
95
  /** Gets a mutable version of an element's bounding `DOMRect`. */
@@ -283,6 +274,173 @@ function transferCanvasData(source, clone) {
283
274
  }
284
275
  }
285
276
 
277
+ /**
278
+ * Gets the root HTML element of an embedded view.
279
+ * If the root is not an HTML element it gets wrapped in one.
280
+ */
281
+ function getRootNode(viewRef, _document) {
282
+ const rootNodes = viewRef.rootNodes;
283
+ if (rootNodes.length === 1 && rootNodes[0].nodeType === _document.ELEMENT_NODE) {
284
+ return rootNodes[0];
285
+ }
286
+ const wrapper = _document.createElement('div');
287
+ rootNodes.forEach(node => wrapper.appendChild(node));
288
+ return wrapper;
289
+ }
290
+
291
+ /** Parses a CSS time value to milliseconds. */
292
+ function parseCssTimeUnitsToMs(value) {
293
+ // Some browsers will return it in seconds, whereas others will return milliseconds.
294
+ const multiplier = value.toLowerCase().indexOf('ms') > -1 ? 1 : 1000;
295
+ return parseFloat(value) * multiplier;
296
+ }
297
+ /** Gets the transform transition duration, including the delay, of an element in milliseconds. */
298
+ function getTransformTransitionDurationInMs(element) {
299
+ const computedStyle = getComputedStyle(element);
300
+ const transitionedProperties = parseCssPropertyValue(computedStyle, 'transition-property');
301
+ const property = transitionedProperties.find(prop => prop === 'transform' || prop === 'all');
302
+ // If there's no transition for `all` or `transform`, we shouldn't do anything.
303
+ if (!property) {
304
+ return 0;
305
+ }
306
+ // Get the index of the property that we're interested in and match
307
+ // it up to the same index in `transition-delay` and `transition-duration`.
308
+ const propertyIndex = transitionedProperties.indexOf(property);
309
+ const rawDurations = parseCssPropertyValue(computedStyle, 'transition-duration');
310
+ const rawDelays = parseCssPropertyValue(computedStyle, 'transition-delay');
311
+ return (parseCssTimeUnitsToMs(rawDurations[propertyIndex]) +
312
+ parseCssTimeUnitsToMs(rawDelays[propertyIndex]));
313
+ }
314
+ /** Parses out multiple values from a computed style into an array. */
315
+ function parseCssPropertyValue(computedStyle, name) {
316
+ const value = computedStyle.getPropertyValue(name);
317
+ return value.split(',').map(part => part.trim());
318
+ }
319
+
320
+ /** Inline styles to be set as `!important` while dragging. */
321
+ const importantProperties = new Set([
322
+ // Needs to be important, because some `mat-table` sets `position: sticky !important`. See #22781.
323
+ 'position',
324
+ ]);
325
+ class PreviewRef {
326
+ constructor(_document, _rootElement, _direction, _initialDomRect, _previewTemplate, _previewClass, _pickupPositionOnPage, _initialTransform, _zIndex) {
327
+ this._document = _document;
328
+ this._rootElement = _rootElement;
329
+ this._direction = _direction;
330
+ this._initialDomRect = _initialDomRect;
331
+ this._previewTemplate = _previewTemplate;
332
+ this._previewClass = _previewClass;
333
+ this._pickupPositionOnPage = _pickupPositionOnPage;
334
+ this._initialTransform = _initialTransform;
335
+ this._zIndex = _zIndex;
336
+ }
337
+ attach(parent) {
338
+ this._wrapper = this._createWrapper();
339
+ this._preview = this._createPreview();
340
+ this._wrapper.appendChild(this._preview);
341
+ parent.appendChild(this._wrapper);
342
+ // The null check is necessary for browsers that don't support the popover API.
343
+ if (this._wrapper.showPopover) {
344
+ this._wrapper.showPopover();
345
+ }
346
+ }
347
+ destroy() {
348
+ this._wrapper?.remove();
349
+ this._previewEmbeddedView?.destroy();
350
+ this._preview = this._wrapper = this._previewEmbeddedView = null;
351
+ }
352
+ setTransform(value) {
353
+ this._preview.style.transform = value;
354
+ }
355
+ getBoundingClientRect() {
356
+ return this._preview.getBoundingClientRect();
357
+ }
358
+ addClass(className) {
359
+ this._preview.classList.add(className);
360
+ }
361
+ getTransitionDuration() {
362
+ return getTransformTransitionDurationInMs(this._preview);
363
+ }
364
+ addEventListener(name, handler) {
365
+ this._preview.addEventListener(name, handler);
366
+ }
367
+ removeEventListener(name, handler) {
368
+ this._preview.removeEventListener(name, handler);
369
+ }
370
+ _createWrapper() {
371
+ const wrapper = this._document.createElement('div');
372
+ wrapper.setAttribute('popover', 'manual');
373
+ wrapper.setAttribute('dir', this._direction);
374
+ wrapper.classList.add('cdk-drag-preview-container');
375
+ extendStyles(wrapper.style, {
376
+ // This is redundant, but we need it for browsers that don't support the popover API.
377
+ 'position': 'fixed',
378
+ 'top': '0',
379
+ 'left': '0',
380
+ 'width': '100%',
381
+ 'height': '100%',
382
+ 'z-index': this._zIndex + '',
383
+ // Reset the user agent styles.
384
+ 'background': 'none',
385
+ 'border': 'none',
386
+ 'pointer-events': 'none',
387
+ 'margin': '0',
388
+ 'padding': '0',
389
+ });
390
+ toggleNativeDragInteractions(wrapper, false);
391
+ return wrapper;
392
+ }
393
+ _createPreview() {
394
+ const previewConfig = this._previewTemplate;
395
+ const previewClass = this._previewClass;
396
+ const previewTemplate = previewConfig ? previewConfig.template : null;
397
+ let preview;
398
+ if (previewTemplate && previewConfig) {
399
+ // Measure the element before we've inserted the preview
400
+ // since the insertion could throw off the measurement.
401
+ const rootRect = previewConfig.matchSize ? this._initialDomRect : null;
402
+ const viewRef = previewConfig.viewContainer.createEmbeddedView(previewTemplate, previewConfig.context);
403
+ viewRef.detectChanges();
404
+ preview = getRootNode(viewRef, this._document);
405
+ this._previewEmbeddedView = viewRef;
406
+ if (previewConfig.matchSize) {
407
+ matchElementSize(preview, rootRect);
408
+ }
409
+ else {
410
+ preview.style.transform = getTransform(this._pickupPositionOnPage.x, this._pickupPositionOnPage.y);
411
+ }
412
+ }
413
+ else {
414
+ preview = deepCloneNode(this._rootElement);
415
+ matchElementSize(preview, this._initialDomRect);
416
+ if (this._initialTransform) {
417
+ preview.style.transform = this._initialTransform;
418
+ }
419
+ }
420
+ extendStyles(preview.style, {
421
+ // It's important that we disable the pointer events on the preview, because
422
+ // it can throw off the `document.elementFromPoint` calls in the `CdkDropList`.
423
+ 'pointer-events': 'none',
424
+ // We have to reset the margin, because it can throw off positioning relative to the viewport.
425
+ 'margin': '0',
426
+ 'position': 'absolute',
427
+ 'top': '0',
428
+ 'left': '0',
429
+ }, importantProperties);
430
+ toggleNativeDragInteractions(preview, false);
431
+ preview.classList.add('cdk-drag-preview');
432
+ if (previewClass) {
433
+ if (Array.isArray(previewClass)) {
434
+ previewClass.forEach(className => preview.classList.add(className));
435
+ }
436
+ else {
437
+ preview.classList.add(previewClass);
438
+ }
439
+ }
440
+ return preview;
441
+ }
442
+ }
443
+
286
444
  /** Options that can be used to bind a passive event listener. */
287
445
  const passiveEventListenerOptions = normalizePassiveListenerOptions({ passive: true });
288
446
  /** Options that can be used to bind an active event listener. */
@@ -704,9 +862,8 @@ class DragRef {
704
862
  }
705
863
  /** Destroys the preview element and its ViewRef. */
706
864
  _destroyPreview() {
707
- this._preview?.remove();
708
- this._previewRef?.destroy();
709
- this._preview = this._previewRef = null;
865
+ this._preview?.destroy();
866
+ this._preview = null;
710
867
  }
711
868
  /** Destroys the placeholder element and its ViewRef. */
712
869
  _destroyPlaceholder() {
@@ -793,13 +950,13 @@ class DragRef {
793
950
  this._initialTransform = element.style.transform || '';
794
951
  // Create the preview after the initial transform has
795
952
  // been cached, because it can be affected by the transform.
796
- this._preview = this._createPreviewElement();
953
+ this._preview = new PreviewRef(this._document, this._rootElement, this._direction, this._initialDomRect, this._previewTemplate || null, this.previewClass || null, this._pickupPositionOnPage, this._initialTransform, this._config.zIndex || 1000);
954
+ this._preview.attach(this._getPreviewInsertionPoint(parent, shadowRoot));
797
955
  // We move the element out at the end of the body and we make it hidden, because keeping it in
798
956
  // place will throw off the consumer's `:last-child` selectors. We can't remove the element
799
957
  // from the DOM completely, because iOS will stop firing all subsequent events in the chain.
800
958
  toggleVisibility(element, false, dragImportantProperties);
801
959
  this._document.body.appendChild(parent.replaceChild(placeholder, element));
802
- this._getPreviewInsertionPoint(parent, shadowRoot).appendChild(this._preview);
803
960
  this.started.next({ source: this, event }); // Emit before notifying the container.
804
961
  dropContainer.start();
805
962
  this._initialContainer = dropContainer;
@@ -972,61 +1129,6 @@ class DragRef {
972
1129
  }
973
1130
  }
974
1131
  }
975
- /**
976
- * Creates the element that will be rendered next to the user's pointer
977
- * and will be used as a preview of the element that is being dragged.
978
- */
979
- _createPreviewElement() {
980
- const previewConfig = this._previewTemplate;
981
- const previewClass = this.previewClass;
982
- const previewTemplate = previewConfig ? previewConfig.template : null;
983
- let preview;
984
- if (previewTemplate && previewConfig) {
985
- // Measure the element before we've inserted the preview
986
- // since the insertion could throw off the measurement.
987
- const rootRect = previewConfig.matchSize ? this._initialDomRect : null;
988
- const viewRef = previewConfig.viewContainer.createEmbeddedView(previewTemplate, previewConfig.context);
989
- viewRef.detectChanges();
990
- preview = getRootNode(viewRef, this._document);
991
- this._previewRef = viewRef;
992
- if (previewConfig.matchSize) {
993
- matchElementSize(preview, rootRect);
994
- }
995
- else {
996
- preview.style.transform = getTransform(this._pickupPositionOnPage.x, this._pickupPositionOnPage.y);
997
- }
998
- }
999
- else {
1000
- preview = deepCloneNode(this._rootElement);
1001
- matchElementSize(preview, this._initialDomRect);
1002
- if (this._initialTransform) {
1003
- preview.style.transform = this._initialTransform;
1004
- }
1005
- }
1006
- extendStyles(preview.style, {
1007
- // It's important that we disable the pointer events on the preview, because
1008
- // it can throw off the `document.elementFromPoint` calls in the `CdkDropList`.
1009
- 'pointer-events': 'none',
1010
- // We have to reset the margin, because it can throw off positioning relative to the viewport.
1011
- 'margin': '0',
1012
- 'position': 'fixed',
1013
- 'top': '0',
1014
- 'left': '0',
1015
- 'z-index': `${this._config.zIndex || 1000}`,
1016
- }, dragImportantProperties);
1017
- toggleNativeDragInteractions(preview, false);
1018
- preview.classList.add('cdk-drag-preview');
1019
- preview.setAttribute('dir', this._direction);
1020
- if (previewClass) {
1021
- if (Array.isArray(previewClass)) {
1022
- previewClass.forEach(className => preview.classList.add(className));
1023
- }
1024
- else {
1025
- preview.classList.add(previewClass);
1026
- }
1027
- }
1028
- return preview;
1029
- }
1030
1132
  /**
1031
1133
  * Animates the preview element from its current position to the location of the drop placeholder.
1032
1134
  * @returns Promise that resolves when the animation completes.
@@ -1038,14 +1140,14 @@ class DragRef {
1038
1140
  }
1039
1141
  const placeholderRect = this._placeholder.getBoundingClientRect();
1040
1142
  // Apply the class that adds a transition to the preview.
1041
- this._preview.classList.add('cdk-drag-animating');
1143
+ this._preview.addClass('cdk-drag-animating');
1042
1144
  // Move the preview to the placeholder position.
1043
1145
  this._applyPreviewTransform(placeholderRect.left, placeholderRect.top);
1044
1146
  // If the element doesn't have a `transition`, the `transitionend` event won't fire. Since
1045
1147
  // we need to trigger a style recalculation in order for the `cdk-drag-animating` class to
1046
1148
  // apply its style, we take advantage of the available info to figure out whether we need to
1047
1149
  // bind the event in the first place.
1048
- const duration = getTransformTransitionDurationInMs(this._preview);
1150
+ const duration = this._preview.getTransitionDuration();
1049
1151
  if (duration === 0) {
1050
1152
  return Promise.resolve();
1051
1153
  }
@@ -1233,7 +1335,7 @@ class DragRef {
1233
1335
  // it could be completely different and the transform might not make sense anymore.
1234
1336
  const initialTransform = this._previewTemplate?.template ? undefined : this._initialTransform;
1235
1337
  const transform = getTransform(x, y);
1236
- this._preview.style.transform = combineTransforms(transform, initialTransform);
1338
+ this._preview.setTransform(combineTransforms(transform, initialTransform));
1237
1339
  }
1238
1340
  /**
1239
1341
  * Gets the distance that the user has dragged during the current drag sequence.
@@ -1392,16 +1494,6 @@ class DragRef {
1392
1494
  });
1393
1495
  }
1394
1496
  }
1395
- /**
1396
- * Gets a 3d `transform` that can be applied to an element.
1397
- * @param x Desired position of the element along the X axis.
1398
- * @param y Desired position of the element along the Y axis.
1399
- */
1400
- function getTransform(x, y) {
1401
- // Round the transforms since some browsers will
1402
- // blur the elements for sub-pixel transforms.
1403
- return `translate3d(${Math.round(x)}px, ${Math.round(y)}px, 0)`;
1404
- }
1405
1497
  /** Clamps a value between a minimum and a maximum. */
1406
1498
  function clamp$1(value, min, max) {
1407
1499
  return Math.max(min, Math.min(max, value));
@@ -1413,29 +1505,6 @@ function isTouchEvent(event) {
1413
1505
  // that if the event's name starts with `t`, it's a touch event.
1414
1506
  return event.type[0] === 't';
1415
1507
  }
1416
- /**
1417
- * Gets the root HTML element of an embedded view.
1418
- * If the root is not an HTML element it gets wrapped in one.
1419
- */
1420
- function getRootNode(viewRef, _document) {
1421
- const rootNodes = viewRef.rootNodes;
1422
- if (rootNodes.length === 1 && rootNodes[0].nodeType === _document.ELEMENT_NODE) {
1423
- return rootNodes[0];
1424
- }
1425
- const wrapper = _document.createElement('div');
1426
- rootNodes.forEach(node => wrapper.appendChild(node));
1427
- return wrapper;
1428
- }
1429
- /**
1430
- * Matches the target element's size to the source's size.
1431
- * @param target Element that needs to be resized.
1432
- * @param sourceRect Dimensions of the source element.
1433
- */
1434
- function matchElementSize(target, sourceRect) {
1435
- target.style.width = `${sourceRect.width}px`;
1436
- target.style.height = `${sourceRect.height}px`;
1437
- target.style.transform = getTransform(sourceRect.left, sourceRect.top);
1438
- }
1439
1508
  /** Callback invoked for `selectstart` events inside the shadow DOM. */
1440
1509
  function shadowDomSelectStart(event) {
1441
1510
  event.preventDefault();
@@ -2635,10 +2704,10 @@ class DragDropRegistry {
2635
2704
  });
2636
2705
  this._globalListeners.clear();
2637
2706
  }
2638
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.1", ngImport: i0, type: DragDropRegistry, deps: [{ token: i0.NgZone }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable }); }
2639
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.0-next.1", ngImport: i0, type: DragDropRegistry, providedIn: 'root' }); }
2707
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.5", ngImport: i0, type: DragDropRegistry, deps: [{ token: i0.NgZone }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable }); }
2708
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.0-next.5", ngImport: i0, type: DragDropRegistry, providedIn: 'root' }); }
2640
2709
  }
2641
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.1", ngImport: i0, type: DragDropRegistry, decorators: [{
2710
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.5", ngImport: i0, type: DragDropRegistry, decorators: [{
2642
2711
  type: Injectable,
2643
2712
  args: [{ providedIn: 'root' }]
2644
2713
  }], ctorParameters: () => [{ type: i0.NgZone }, { type: undefined, decorators: [{
@@ -2676,10 +2745,10 @@ class DragDrop {
2676
2745
  createDropList(element) {
2677
2746
  return new DropListRef(element, this._dragDropRegistry, this._document, this._ngZone, this._viewportRuler);
2678
2747
  }
2679
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.1", ngImport: i0, type: DragDrop, deps: [{ token: DOCUMENT }, { token: i0.NgZone }, { token: i1.ViewportRuler }, { token: DragDropRegistry }], target: i0.ɵɵFactoryTarget.Injectable }); }
2680
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.0-next.1", ngImport: i0, type: DragDrop, providedIn: 'root' }); }
2748
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.5", ngImport: i0, type: DragDrop, deps: [{ token: DOCUMENT }, { token: i0.NgZone }, { token: i1.ViewportRuler }, { token: DragDropRegistry }], target: i0.ɵɵFactoryTarget.Injectable }); }
2749
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.0-next.5", ngImport: i0, type: DragDrop, providedIn: 'root' }); }
2681
2750
  }
2682
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.1", ngImport: i0, type: DragDrop, decorators: [{
2751
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.5", ngImport: i0, type: DragDrop, decorators: [{
2683
2752
  type: Injectable,
2684
2753
  args: [{ providedIn: 'root' }]
2685
2754
  }], ctorParameters: () => [{ type: undefined, decorators: [{
@@ -2737,10 +2806,10 @@ class CdkDragHandle {
2737
2806
  this._parentDrag?._removeHandle(this);
2738
2807
  this._stateChanges.complete();
2739
2808
  }
2740
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.1", ngImport: i0, type: CdkDragHandle, deps: [{ token: i0.ElementRef }, { token: CDK_DRAG_PARENT, optional: true, skipSelf: true }], target: i0.ɵɵFactoryTarget.Directive }); }
2741
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "18.0.0-next.1", type: CdkDragHandle, isStandalone: true, selector: "[cdkDragHandle]", inputs: { disabled: ["cdkDragHandleDisabled", "disabled", booleanAttribute] }, host: { classAttribute: "cdk-drag-handle" }, providers: [{ provide: CDK_DRAG_HANDLE, useExisting: CdkDragHandle }], ngImport: i0 }); }
2809
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.5", ngImport: i0, type: CdkDragHandle, deps: [{ token: i0.ElementRef }, { token: CDK_DRAG_PARENT, optional: true, skipSelf: true }], target: i0.ɵɵFactoryTarget.Directive }); }
2810
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "18.0.0-next.5", type: CdkDragHandle, isStandalone: true, selector: "[cdkDragHandle]", inputs: { disabled: ["cdkDragHandleDisabled", "disabled", booleanAttribute] }, host: { classAttribute: "cdk-drag-handle" }, providers: [{ provide: CDK_DRAG_HANDLE, useExisting: CdkDragHandle }], ngImport: i0 }); }
2742
2811
  }
2743
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.1", ngImport: i0, type: CdkDragHandle, decorators: [{
2812
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.5", ngImport: i0, type: CdkDragHandle, decorators: [{
2744
2813
  type: Directive,
2745
2814
  args: [{
2746
2815
  selector: '[cdkDragHandle]',
@@ -3153,10 +3222,10 @@ class CdkDrag {
3153
3222
  handleInstance.disabled ? dragRef.disableHandle(handle) : dragRef.enableHandle(handle);
3154
3223
  });
3155
3224
  }
3156
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.1", ngImport: i0, type: CdkDrag, deps: [{ token: i0.ElementRef }, { token: CDK_DROP_LIST, optional: true, skipSelf: true }, { token: DOCUMENT }, { token: i0.NgZone }, { token: i0.ViewContainerRef }, { token: CDK_DRAG_CONFIG, optional: true }, { token: i1$1.Directionality, optional: true }, { token: DragDrop }, { token: i0.ChangeDetectorRef }, { token: CDK_DRAG_HANDLE, optional: true, self: true }, { token: CDK_DRAG_PARENT, optional: true, skipSelf: true }], target: i0.ɵɵFactoryTarget.Directive }); }
3157
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "18.0.0-next.1", type: CdkDrag, isStandalone: true, selector: "[cdkDrag]", inputs: { data: ["cdkDragData", "data"], lockAxis: ["cdkDragLockAxis", "lockAxis"], rootElementSelector: ["cdkDragRootElement", "rootElementSelector"], boundaryElement: ["cdkDragBoundary", "boundaryElement"], dragStartDelay: ["cdkDragStartDelay", "dragStartDelay"], freeDragPosition: ["cdkDragFreeDragPosition", "freeDragPosition"], disabled: ["cdkDragDisabled", "disabled", booleanAttribute], constrainPosition: ["cdkDragConstrainPosition", "constrainPosition"], previewClass: ["cdkDragPreviewClass", "previewClass"], previewContainer: ["cdkDragPreviewContainer", "previewContainer"] }, outputs: { started: "cdkDragStarted", released: "cdkDragReleased", ended: "cdkDragEnded", entered: "cdkDragEntered", exited: "cdkDragExited", dropped: "cdkDragDropped", moved: "cdkDragMoved" }, host: { properties: { "class.cdk-drag-disabled": "disabled", "class.cdk-drag-dragging": "_dragRef.isDragging()" }, classAttribute: "cdk-drag" }, providers: [{ provide: CDK_DRAG_PARENT, useExisting: CdkDrag }], exportAs: ["cdkDrag"], usesOnChanges: true, ngImport: i0 }); }
3225
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.5", ngImport: i0, type: CdkDrag, deps: [{ token: i0.ElementRef }, { token: CDK_DROP_LIST, optional: true, skipSelf: true }, { token: DOCUMENT }, { token: i0.NgZone }, { token: i0.ViewContainerRef }, { token: CDK_DRAG_CONFIG, optional: true }, { token: i1$1.Directionality, optional: true }, { token: DragDrop }, { token: i0.ChangeDetectorRef }, { token: CDK_DRAG_HANDLE, optional: true, self: true }, { token: CDK_DRAG_PARENT, optional: true, skipSelf: true }], target: i0.ɵɵFactoryTarget.Directive }); }
3226
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "18.0.0-next.5", type: CdkDrag, isStandalone: true, selector: "[cdkDrag]", inputs: { data: ["cdkDragData", "data"], lockAxis: ["cdkDragLockAxis", "lockAxis"], rootElementSelector: ["cdkDragRootElement", "rootElementSelector"], boundaryElement: ["cdkDragBoundary", "boundaryElement"], dragStartDelay: ["cdkDragStartDelay", "dragStartDelay"], freeDragPosition: ["cdkDragFreeDragPosition", "freeDragPosition"], disabled: ["cdkDragDisabled", "disabled", booleanAttribute], constrainPosition: ["cdkDragConstrainPosition", "constrainPosition"], previewClass: ["cdkDragPreviewClass", "previewClass"], previewContainer: ["cdkDragPreviewContainer", "previewContainer"] }, outputs: { started: "cdkDragStarted", released: "cdkDragReleased", ended: "cdkDragEnded", entered: "cdkDragEntered", exited: "cdkDragExited", dropped: "cdkDragDropped", moved: "cdkDragMoved" }, host: { properties: { "class.cdk-drag-disabled": "disabled", "class.cdk-drag-dragging": "_dragRef.isDragging()" }, classAttribute: "cdk-drag" }, providers: [{ provide: CDK_DRAG_PARENT, useExisting: CdkDrag }], exportAs: ["cdkDrag"], usesOnChanges: true, ngImport: i0 }); }
3158
3227
  }
3159
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.1", ngImport: i0, type: CdkDrag, decorators: [{
3228
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.5", ngImport: i0, type: CdkDrag, decorators: [{
3160
3229
  type: Directive,
3161
3230
  args: [{
3162
3231
  selector: '[cdkDrag]',
@@ -3275,10 +3344,10 @@ class CdkDropListGroup {
3275
3344
  ngOnDestroy() {
3276
3345
  this._items.clear();
3277
3346
  }
3278
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.1", ngImport: i0, type: CdkDropListGroup, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
3279
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "18.0.0-next.1", type: CdkDropListGroup, isStandalone: true, selector: "[cdkDropListGroup]", inputs: { disabled: ["cdkDropListGroupDisabled", "disabled", booleanAttribute] }, providers: [{ provide: CDK_DROP_LIST_GROUP, useExisting: CdkDropListGroup }], exportAs: ["cdkDropListGroup"], ngImport: i0 }); }
3347
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.5", ngImport: i0, type: CdkDropListGroup, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
3348
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "18.0.0-next.5", type: CdkDropListGroup, isStandalone: true, selector: "[cdkDropListGroup]", inputs: { disabled: ["cdkDropListGroupDisabled", "disabled", booleanAttribute] }, providers: [{ provide: CDK_DROP_LIST_GROUP, useExisting: CdkDropListGroup }], exportAs: ["cdkDropListGroup"], ngImport: i0 }); }
3280
3349
  }
3281
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.1", ngImport: i0, type: CdkDropListGroup, decorators: [{
3350
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.5", ngImport: i0, type: CdkDropListGroup, decorators: [{
3282
3351
  type: Directive,
3283
3352
  args: [{
3284
3353
  selector: '[cdkDropListGroup]',
@@ -3524,14 +3593,14 @@ class CdkDropList {
3524
3593
  _syncItemsWithRef() {
3525
3594
  this._dropListRef.withItems(this.getSortedItems().map(item => item._dragRef));
3526
3595
  }
3527
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.1", ngImport: i0, type: CdkDropList, deps: [{ token: i0.ElementRef }, { token: DragDrop }, { token: i0.ChangeDetectorRef }, { token: i1.ScrollDispatcher }, { token: i1$1.Directionality, optional: true }, { token: CDK_DROP_LIST_GROUP, optional: true, skipSelf: true }, { token: CDK_DRAG_CONFIG, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
3528
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "18.0.0-next.1", type: CdkDropList, isStandalone: true, selector: "[cdkDropList], cdk-drop-list", inputs: { connectedTo: ["cdkDropListConnectedTo", "connectedTo"], data: ["cdkDropListData", "data"], orientation: ["cdkDropListOrientation", "orientation"], id: "id", lockAxis: ["cdkDropListLockAxis", "lockAxis"], disabled: ["cdkDropListDisabled", "disabled", booleanAttribute], sortingDisabled: ["cdkDropListSortingDisabled", "sortingDisabled", booleanAttribute], enterPredicate: ["cdkDropListEnterPredicate", "enterPredicate"], sortPredicate: ["cdkDropListSortPredicate", "sortPredicate"], autoScrollDisabled: ["cdkDropListAutoScrollDisabled", "autoScrollDisabled", booleanAttribute], autoScrollStep: ["cdkDropListAutoScrollStep", "autoScrollStep"] }, outputs: { dropped: "cdkDropListDropped", entered: "cdkDropListEntered", exited: "cdkDropListExited", sorted: "cdkDropListSorted" }, host: { properties: { "attr.id": "id", "class.cdk-drop-list-disabled": "disabled", "class.cdk-drop-list-dragging": "_dropListRef.isDragging()", "class.cdk-drop-list-receiving": "_dropListRef.isReceiving()" }, classAttribute: "cdk-drop-list" }, providers: [
3596
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.5", ngImport: i0, type: CdkDropList, deps: [{ token: i0.ElementRef }, { token: DragDrop }, { token: i0.ChangeDetectorRef }, { token: i1.ScrollDispatcher }, { token: i1$1.Directionality, optional: true }, { token: CDK_DROP_LIST_GROUP, optional: true, skipSelf: true }, { token: CDK_DRAG_CONFIG, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
3597
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "18.0.0-next.5", type: CdkDropList, isStandalone: true, selector: "[cdkDropList], cdk-drop-list", inputs: { connectedTo: ["cdkDropListConnectedTo", "connectedTo"], data: ["cdkDropListData", "data"], orientation: ["cdkDropListOrientation", "orientation"], id: "id", lockAxis: ["cdkDropListLockAxis", "lockAxis"], disabled: ["cdkDropListDisabled", "disabled", booleanAttribute], sortingDisabled: ["cdkDropListSortingDisabled", "sortingDisabled", booleanAttribute], enterPredicate: ["cdkDropListEnterPredicate", "enterPredicate"], sortPredicate: ["cdkDropListSortPredicate", "sortPredicate"], autoScrollDisabled: ["cdkDropListAutoScrollDisabled", "autoScrollDisabled", booleanAttribute], autoScrollStep: ["cdkDropListAutoScrollStep", "autoScrollStep"] }, outputs: { dropped: "cdkDropListDropped", entered: "cdkDropListEntered", exited: "cdkDropListExited", sorted: "cdkDropListSorted" }, host: { properties: { "attr.id": "id", "class.cdk-drop-list-disabled": "disabled", "class.cdk-drop-list-dragging": "_dropListRef.isDragging()", "class.cdk-drop-list-receiving": "_dropListRef.isReceiving()" }, classAttribute: "cdk-drop-list" }, providers: [
3529
3598
  // Prevent child drop lists from picking up the same group as their parent.
3530
3599
  { provide: CDK_DROP_LIST_GROUP, useValue: undefined },
3531
3600
  { provide: CDK_DROP_LIST, useExisting: CdkDropList },
3532
3601
  ], exportAs: ["cdkDropList"], ngImport: i0 }); }
3533
3602
  }
3534
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.1", ngImport: i0, type: CdkDropList, decorators: [{
3603
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.5", ngImport: i0, type: CdkDropList, decorators: [{
3535
3604
  type: Directive,
3536
3605
  args: [{
3537
3606
  selector: '[cdkDropList], cdk-drop-list',
@@ -3631,10 +3700,10 @@ class CdkDragPreview {
3631
3700
  ngOnDestroy() {
3632
3701
  this._drag?._resetPreviewTemplate(this);
3633
3702
  }
3634
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.1", ngImport: i0, type: CdkDragPreview, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive }); }
3635
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "18.0.0-next.1", type: CdkDragPreview, isStandalone: true, selector: "ng-template[cdkDragPreview]", inputs: { data: "data", matchSize: ["matchSize", "matchSize", booleanAttribute] }, providers: [{ provide: CDK_DRAG_PREVIEW, useExisting: CdkDragPreview }], ngImport: i0 }); }
3703
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.5", ngImport: i0, type: CdkDragPreview, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive }); }
3704
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "18.0.0-next.5", type: CdkDragPreview, isStandalone: true, selector: "ng-template[cdkDragPreview]", inputs: { data: "data", matchSize: ["matchSize", "matchSize", booleanAttribute] }, providers: [{ provide: CDK_DRAG_PREVIEW, useExisting: CdkDragPreview }], ngImport: i0 }); }
3636
3705
  }
3637
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.1", ngImport: i0, type: CdkDragPreview, decorators: [{
3706
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.5", ngImport: i0, type: CdkDragPreview, decorators: [{
3638
3707
  type: Directive,
3639
3708
  args: [{
3640
3709
  selector: 'ng-template[cdkDragPreview]',
@@ -3667,10 +3736,10 @@ class CdkDragPlaceholder {
3667
3736
  ngOnDestroy() {
3668
3737
  this._drag?._resetPlaceholderTemplate(this);
3669
3738
  }
3670
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.1", ngImport: i0, type: CdkDragPlaceholder, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive }); }
3671
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.0-next.1", type: CdkDragPlaceholder, isStandalone: true, selector: "ng-template[cdkDragPlaceholder]", inputs: { data: "data" }, providers: [{ provide: CDK_DRAG_PLACEHOLDER, useExisting: CdkDragPlaceholder }], ngImport: i0 }); }
3739
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.5", ngImport: i0, type: CdkDragPlaceholder, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive }); }
3740
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.0-next.5", type: CdkDragPlaceholder, isStandalone: true, selector: "ng-template[cdkDragPlaceholder]", inputs: { data: "data" }, providers: [{ provide: CDK_DRAG_PLACEHOLDER, useExisting: CdkDragPlaceholder }], ngImport: i0 }); }
3672
3741
  }
3673
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.1", ngImport: i0, type: CdkDragPlaceholder, decorators: [{
3742
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.5", ngImport: i0, type: CdkDragPlaceholder, decorators: [{
3674
3743
  type: Directive,
3675
3744
  args: [{
3676
3745
  selector: 'ng-template[cdkDragPlaceholder]',
@@ -3690,8 +3759,8 @@ const DRAG_DROP_DIRECTIVES = [
3690
3759
  CdkDragPlaceholder,
3691
3760
  ];
3692
3761
  class DragDropModule {
3693
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.1", ngImport: i0, type: DragDropModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
3694
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.0.0-next.1", ngImport: i0, type: DragDropModule, imports: [CdkDropList,
3762
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-next.5", ngImport: i0, type: DragDropModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
3763
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.0.0-next.5", ngImport: i0, type: DragDropModule, imports: [CdkDropList,
3695
3764
  CdkDropListGroup,
3696
3765
  CdkDrag,
3697
3766
  CdkDragHandle,
@@ -3702,9 +3771,9 @@ class DragDropModule {
3702
3771
  CdkDragHandle,
3703
3772
  CdkDragPreview,
3704
3773
  CdkDragPlaceholder] }); }
3705
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.0.0-next.1", ngImport: i0, type: DragDropModule, providers: [DragDrop], imports: [CdkScrollableModule] }); }
3774
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.0.0-next.5", ngImport: i0, type: DragDropModule, providers: [DragDrop], imports: [CdkScrollableModule] }); }
3706
3775
  }
3707
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.1", ngImport: i0, type: DragDropModule, decorators: [{
3776
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-next.5", ngImport: i0, type: DragDropModule, decorators: [{
3708
3777
  type: NgModule,
3709
3778
  args: [{
3710
3779
  imports: DRAG_DROP_DIRECTIVES,