Skip to content

Highly configurable drag and drop module for Angular.

Notifications You must be signed in to change notification settings

thbl/angular-drag-and-drop

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

26 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Angular Drag and Drop

Customizable drag and drop behaviour for Angular.

Getting Started

Bower

bower install angular-drag-and-drop-directives

Or download the files from github, then:

In your HTML:

  1. Add angular-drag-and-drop.js
  2. Add angular-drag-and-drop.css
  3. Add required markup
```html
<drag-and-drop>

  <drag-item>
      <p>Anything in here</p>
      <p>will be draggable</p>
  </drag-item>

  <drop-spot>
    <p>Drop Here</p>
  </drop-spot>

</drag-and-drop>
```

In your Angular module:

  1. Add "laneolson.ui.dragdrop" as a dependency to the module.
  2. In your controller, add functions for handling various events in the drag and drop.

Customizing

Directive Attributes

You can pass various functions and options to the directive by assigning the following attributes:

drag-and-drop - element or attribute

  • on-drag-start: function - fired when an item starts being dragged
  • on-drag-end: function - fired when an item is released
  • on-drag-enter: function - fired when an item is dragged over a drop spot
  • on-drag-leave: function - fired when an item is dragged outside of a drop spot
  • on-item-placed: function - fired when an item is dropped inside of a drop spot
  • on-item-removed: function - fired when and item is removed from its drop spot
  • enable-swap: boolean - an item will be swapped out when dropping a drag item on to a drop spot that has reached its maximum number of items
  • fixed-positions: boolean - when set to true, items return to their start positions when dropped outside of a drop spot

drag-item - element or attribute

  • drag-id: an identifier that is used for this drag item. When set, the drag-item element will have a class that matches the drag-id.
  • drag-data: object - use to associate any additional data you may want for the draggable item.
  • drop-to: string - used to position the element within the drop spot (e.g. "top", or "bottom left")
  • x: int - the pixel x offset of the drag item from it's original position
  • y: int - the pixel y offset of the drag item from it's original position
  • clone : boolean - a clone item is dragged instead of the original item
  • lock-vertical: boolean - locks the item so it may only be moved left and right

drop-spot - element or attribute

  • drop-id: string - an identifier that is used for this drop item. When set, the drop-spot element will have a class that matches the drag-id.
  • max-items: int - Used to specify the maximum number of items allowed in this drop spot

Classes

The following classes are added to elements to allow styling based on the current state of the drag and drop.

  • dragging: Added to the drag-and-drop wrapper when an item is being dragged.
  • drop-hovering: Added to an drop-spot element when an item has been dragged over top of the drop spot.
  • drop-full: Added to an drop-spot when it has reached its maximum number of items (assigned through max-items)
  • drag-active: added to a drag-item element when it is being dragged
  • {{DRAG_ID}}: added to an drag-item element if the drag-id attribute is set
  • {{DROP_ID}}: added to an drop-spot element if the drop-id attribute is set. An drag-item element will be given the class in-{{DROP_ID}} when it is placed within that drop spot.

Todo

  • proper z-indexing when lifting and placing drag items

About

Highly configurable drag and drop module for Angular.

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • CoffeeScript 92.7%
  • CSS 7.3%