Демо с возможностью перетаскивания только div с иконки
Код приложения: https://stackblitz.com/edit/angular-drag-and-drop-example?file=src/app/app.component.ts
Подход:
- Изменить
<i class="material-icons">reorder</i>
на
<i class="material-icons" cdkDragHandle >reorder</i>
- Использовал
cdkDragHandle
, чтобы сделать этот значок перетаскиваемым, удалил cursor: move
из div и применил его к тегу <i>
.
Обновление 1 (в соответствии с вопросом флажка):
- другой похожий тег
<i>
сохраняется как маска, которая не позволяет запускать перетаскиванием, если флажок не установлен, и при флажке флажок мы разрешаем этой маске исчезать, так что div можно перетаскивать из основного тега <i>
.
Обновление 2 (в соответствии с вопросом об удалении и добавлении):
- добавлены функции удаления и добавления.