New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

ember-shopify-draggable

Package Overview
Dependencies
Maintainers
2
Versions
16
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

ember-shopify-draggable

Ember components for Shopify's drag and drop

  • 0.2.1
  • Source
  • npm
  • Socket score

Version published
Maintainers
2
Created
Source

ember-shopify-draggable

Addon for using @shopify/draggable in ember projects.

Doggie

  • Easy to use
  • Fastboot Compatible (doesn't run in fastboot)
  • Easily Extendable

Demo

https://gavant.github.io/ember-shopify-draggable/#/sortable

Installation

ember install ember-shopify-draggable

Usage

Right now this addon contains ember components for swappable and sortable. We hope to have full parity with all features of @shopify/draggable soon.

Sortable functionality

This addon allows you to pass in a list object to the container component, and an item object to the item component. This will give you the ability to keep track of the underlying JS list automatically. You can see an example of this below.

Here we pass in list which is an array of js objects, and give item to each container.item. When any action is performed the group.container component sends an action and you can just have it mutate the list. So each time the list is modified by drag/drop your passed in list will be updated with those changes!

{{#sortable-group sorted=(action 'sorted') as |group|}}
    {{#group.container list
        itemReordered=(action (mut list))
        itemAdded=(action (mut list))
        itemRemoved=(action (mut list)) as |container|}}
            {{#each container.items as |item|}}
                {{#container.item item}}
                    {{item.name}}
                {{/container.item}}
            {{else}}
                Im empty
            {{/each}}
    {{/group.container}}
    {{#group.container listTwo
        itemReordered=(action (mut listTwo))
        itemAdded=(action (mut listTwo))
        itemRemoved=(action (mut listTwo)) as |container|}}
            {{#each container.items as |item|}}
                {{#container.item item}}
                    {{item.name}}
                {{/container.item}}
            {{else}}
                Im Empty
            {{/each}}
    {{/group.container}}
{{/sortable-group}}

Possible events for sortable can be found at Sortable Events

You can see an example of the sorted event being used above.

Sortable Options

You can customize several of the underlying Sortable instance's options by passing in additional properties to the {{sortable-group}} component.

  • delay - (default: 100) adds a delay to the drag interaction when a sortable item is clicked.
  • handle - (default: null) a CSS selector for a handle element within the sortable item elements if you don't want to allow dragging from anywhere on the entire item element.

For more details on these options see:
https://github.com/Shopify/draggable/tree/master/src/Draggable#options

NOTE: These options do not support dynamically changing values, and will only respect the initial value that is passed in when the component is first rendered.

Swappable functionality

NOTE: Currently only works with one container

{{#swappable-group swapped=(action 'swapped') as |group|}}
    {{#group.container list
        itemReordered=(action (mut list))
        as |container|}}
            {{#each container.items as |item index|}}
                {{#container.item item index=index}}
                    {{item.name}}
                {{/container.item}}
            {{else}}
                Im empty
            {{/each}}
    {{/group.container}}
{{/swappable-group}}

Possible events for swappable can be found at Swappable Events

You can see an example of the swapped event being used above.

Contributing

Installation

  • git clone <repository-url>
  • cd ember-shopify-draggable
  • npm install

Linting

  • npm run lint:js
  • npm run lint:js -- --fix

Running tests

  • ember test – Runs the test suite on the current Ember version
  • ember test --server – Runs the test suite in "watch mode"
  • ember try:each – Runs the test suite against multiple Ember versions

Running the dummy application

For more information on using ember-cli, visit https://ember-cli.com/.

License

This project is licensed under the MIT License.

Keywords

FAQs

Package last updated on 07 Mar 2019

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc