Commit 0bc6583
committed
feat(cdk/drag-drop): add mixed orientation support
Currently the drop list sorts items by moving them using a `transform` which keeps the DOM stable and allows for the sorting to be animated, but has the drawback of only allowing sorting in one direction.
These changes implement a new `DropListSortStrategy` that allows sorting of lists that can wrap by moving the DOM nodes around directly, rather than via a `transform`. It has the caveat that it can't animate the sorting action.
The new strategy can be enabled by setting `cdkDropListOrientation="mixed"`.
Fixes #13372.1 parent d0ca10b commit 0bc6583
File tree
17 files changed
+683
-41
lines changed- src
- cdk/drag-drop
- directives
- sorting
- components-examples/cdk/drag-drop
- cdk-drag-drop-mixed-sorting
- dev-app/drag-drop
- tools/public_api_guard/cdk
17 files changed
+683
-41
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
19 | 19 | | |
20 | 20 | | |
21 | 21 | | |
22 | | - | |
| 22 | + | |
23 | 23 | | |
24 | 24 | | |
25 | 25 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | | - | |
| 2 | + | |
3 | 3 | | |
4 | 4 | | |
5 | 5 | | |
| |||
803 | 803 | | |
804 | 804 | | |
805 | 805 | | |
| 806 | + | |
| 807 | + | |
| 808 | + | |
| 809 | + | |
| 810 | + | |
| 811 | + | |
| 812 | + | |
| 813 | + | |
| 814 | + | |
| 815 | + | |
| 816 | + | |
| 817 | + | |
| 818 | + | |
| 819 | + | |
| 820 | + | |
| 821 | + | |
| 822 | + | |
| 823 | + | |
| 824 | + | |
| 825 | + | |
806 | 826 | | |
807 | 827 | | |
808 | 828 | | |
| |||
1489 | 1509 | | |
1490 | 1510 | | |
1491 | 1511 | | |
1492 | | - | |
| 1512 | + | |
1493 | 1513 | | |
1494 | 1514 | | |
1495 | 1515 | | |
| |||
1503 | 1523 | | |
1504 | 1524 | | |
1505 | 1525 | | |
1506 | | - | |
| 1526 | + | |
1507 | 1527 | | |
1508 | 1528 | | |
1509 | 1529 | | |
| |||
1515 | 1535 | | |
1516 | 1536 | | |
1517 | 1537 | | |
1518 | | - | |
| 1538 | + | |
1519 | 1539 | | |
1520 | 1540 | | |
1521 | 1541 | | |
| |||
1529 | 1549 | | |
1530 | 1550 | | |
1531 | 1551 | | |
1532 | | - | |
| 1552 | + | |
1533 | 1553 | | |
1534 | 1554 | | |
1535 | 1555 | | |
| |||
1541 | 1561 | | |
1542 | 1562 | | |
1543 | 1563 | | |
1544 | | - | |
| 1564 | + | |
1545 | 1565 | | |
1546 | 1566 | | |
1547 | 1567 | | |
| |||
1552 | 1572 | | |
1553 | 1573 | | |
1554 | 1574 | | |
1555 | | - | |
| 1575 | + | |
1556 | 1576 | | |
1557 | 1577 | | |
1558 | 1578 | | |
| |||
1901 | 1921 | | |
1902 | 1922 | | |
1903 | 1923 | | |
| 1924 | + | |
| 1925 | + | |
| 1926 | + | |
| 1927 | + | |
| 1928 | + | |
1904 | 1929 | | |
1905 | 1930 | | |
| 1931 | + | |
| 1932 | + | |
| 1933 | + | |
| 1934 | + | |
| 1935 | + | |
| 1936 | + | |
| 1937 | + | |
| 1938 | + | |
1906 | 1939 | | |
1907 | 1940 | | |
1908 | 1941 | | |
1909 | 1942 | | |
1910 | 1943 | | |
1911 | 1944 | | |
1912 | | - | |
| 1945 | + | |
1913 | 1946 | | |
1914 | 1947 | | |
1915 | 1948 | | |
| |||
1918 | 1951 | | |
1919 | 1952 | | |
1920 | 1953 | | |
1921 | | - | |
| 1954 | + | |
| 1955 | + | |
| 1956 | + | |
1922 | 1957 | | |
1923 | 1958 | | |
1924 | 1959 | | |
| |||
2603 | 2638 | | |
2604 | 2639 | | |
2605 | 2640 | | |
| 2641 | + | |
| 2642 | + | |
2606 | 2643 | | |
2607 | 2644 | | |
2608 | 2645 | | |
| |||
3130 | 3167 | | |
3131 | 3168 | | |
3132 | 3169 | | |
3133 | | - | |
| 3170 | + | |
3134 | 3171 | | |
3135 | 3172 | | |
3136 | 3173 | | |
| |||
3394 | 3431 | | |
3395 | 3432 | | |
3396 | 3433 | | |
3397 | | - | |
| 3434 | + | |
3398 | 3435 | | |
3399 | 3436 | | |
3400 | 3437 | | |
| |||
4674 | 4711 | | |
4675 | 4712 | | |
4676 | 4713 | | |
4677 | | - | |
| 4714 | + | |
4678 | 4715 | | |
4679 | 4716 | | |
4680 | 4717 | | |
| |||
4714 | 4751 | | |
4715 | 4752 | | |
4716 | 4753 | | |
4717 | | - | |
| 4754 | + | |
4718 | 4755 | | |
4719 | 4756 | | |
4720 | 4757 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
| 90 | + | |
| 91 | + | |
| 92 | + | |
| 93 | + | |
| 94 | + | |
| 95 | + | |
| 96 | + | |
| 97 | + | |
| 98 | + | |
| 99 | + | |
| 100 | + | |
| 101 | + | |
| 102 | + | |
| 103 | + | |
| 104 | + | |
| 105 | + | |
| 106 | + | |
| 107 | + | |
| 108 | + | |
| 109 | + | |
| 110 | + | |
| 111 | + | |
| 112 | + | |
| 113 | + | |
| 114 | + | |
| 115 | + | |
| 116 | + | |
| 117 | + | |
| 118 | + | |
| 119 | + | |
| 120 | + | |
| 121 | + | |
| 122 | + | |
| 123 | + | |
| 124 | + | |
| 125 | + | |
| 126 | + | |
| 127 | + | |
| 128 | + | |
| 129 | + | |
| 130 | + | |
| 131 | + | |
| 132 | + | |
| 133 | + | |
| 134 | + | |
| 135 | + | |
| 136 | + | |
| 137 | + | |
| 138 | + | |
| 139 | + | |
| 140 | + | |
| 141 | + | |
| 142 | + | |
| 143 | + | |
| 144 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
157 | 157 | | |
158 | 158 | | |
159 | 159 | | |
160 | | - | |
| 160 | + | |
161 | 161 | | |
162 | 162 | | |
163 | 163 | | |
| 164 | + | |
| 165 | + | |
| 166 | + | |
| 167 | + | |
| 168 | + | |
| 169 | + | |
| 170 | + | |
| 171 | + | |
| 172 | + | |
| 173 | + | |
| 174 | + | |
| 175 | + | |
164 | 176 | | |
165 | 177 | | |
166 | 178 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
822 | 822 | | |
823 | 823 | | |
824 | 824 | | |
825 | | - | |
| 825 | + | |
| 826 | + | |
826 | 827 | | |
827 | 828 | | |
828 | 829 | | |
| |||
0 commit comments