Skip to content

A lightweight reorderable (via HTML5 drag+drop) list in TypeScript with no dependencies.

License

Notifications You must be signed in to change notification settings

ca-la/typescript-sortable-list

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

7 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

typescript-sortable-list

A lightweight reorderable (via HTML5 drag+drop) list in TypeScript with no dependencies.

Usage / Example

import { SortableItem, SortableList } from 'sortable-list';

class MyComponent extends React.Component {
  public render(): JSX.Element {
    return (
      <SortableList onItemMove={this.onItemMove}>
        {this.state.items.map(this.renderItem)}
      </SortableList>
    );
  }

  private renderItem = (item: Item): JSX.Element => {
    return (
      <SortableItem>{item.title}</SortableItem>
    );
  }

  private onItemMove = (oldIndex: number, newIndex: number): void => {
    // Update your state to put `items` in the new correct order.
    // The SortableList is a "controlled" component that resets its own state
    // after the drag operation is  complete, so it's up to the parent component
    // to persist any changes.
  }
}

Roadmap

  • Touch support
  • Add full working example

About

A lightweight reorderable (via HTML5 drag+drop) list in TypeScript with no dependencies.

Resources

License

Stars

Watchers

Forks

Packages

No packages published