npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

vue-list-picker

v0.3.0

Published

Just a simple list picker component made with Vue.js

Downloads

456

Readme

Demo

Go to https://vuelistpicker.now.sh

How to install

npm

$ npm install vue-list-picker --save

yarn

$ yarn add vue-list-picker

Quick start

Vue.js

You can import in your main.js file

import Vue from "vue";
import VueListPicker from "vue-list-picker";

Vue.use(VueListPicker);

Or locally in any component

import { VueListPicker } from "vue-list-picker";

export default {
  components: {
    VueListPicker,
  },
};

Nuxt.js

You can import as a Nuxt.js plugin

~/plugins/vue-list-picker.js

import Vue from "vue";
import VueListPicker from "vue-list-picker";

Vue.use(VueListPicker);

and then import it in your nuxt.config.js file

plugins: ["~/plugins/vue-list-picker.js"];

There's a window mouseup event listener so you should use the <no-ssr> tag

Basic usage

<template>
  <vue-list-picker :left-items="leftItems" :right-items="rightItems" />
</template>

<script>
  export default {
    data() {
      const example1 = {
        key: 1,
        content: "Item 1",
      };
      const example2 = {
        key: 2,
        content: "Item 2",
      };
      const example3 = {
        key: 3,
        content: "Item 3",
      };
      const example4 = {
        key: 4,
        content: "Item 4",
      };

      const leftItems = [example1, example2];
      const rightItems = [example3, example4];

      return { leftItems, rightItems };
    },
  };
</script>

Props

| Property name | Type | Default | Description | | ------------------- | ------- | ----------------- | ----------------------------------------------------------------------------------------------- | | left-items | Array | null | Array of objects to be displayed in the left. Must have at least a key and content property | | right-items | Array | null | Array of objects to be displayed in the right. Must have at least a key and content property | | moved-item-location | String | 'top' | After move a item, if this is set to top will move the item to the top, otherwise to the bottom | | title-left | String | 'Items available' | Title name of the left column | | title-right | String | 'Items selected' | Title name of the right column | | title-centered | Boolean | true | Centralizes the title text | | title-class | String | '' | If you want to set a custom class to the columns title, set it here | | title-substr | String | 20 | Number of characters to display inside the columns title. Above this, will set a '...' mask | | button-class | String | '' | If you want to set a custom class to all the buttons in between the columns, set it here | | content-key | String | 'key' | Property name inside the objects inside each items array, that will be used to move the object | | content-attr | String | 'content' | Property name inside the objects inside each items array, that will set the text content | | content-centered | Boolean | false | Centralizes all the text content | | content-class | String | '' | If you want to set a custom class to the each content item, set it here | | content-substr | String | 23 | Number of characters to display inside the content item. Above this, will set a '...' mask | | min-height | String | '450px' | Min-height of each column | | height | String | '' | Height of each column | | min-width | String | '220px' | Min-width of each column | | width | String | '' | Width of each column |

Events (optional usage)

| Event name | Return type | Description | | -------------- | ----------- | -------------------- | | move-all-right | Array | Array of items moved | | move-right | Object | Item object moved | | move-left | Object | Item object moved | | move-all-left | Array | Array of items moved | | unselect-all | Array | Empty array |

Slots (optional usage)

| Slot name | Description | | ------------ | --------------------------------------------------------------------------- | | moveAllRight | Use this to change the icon (chevrons-right) inside the first action button | | moveRight | Use this to change the icon (chevron-right) inside the second action button | | moveLeft | Use this to change the icon (chevron-left) inside the third action button | | moveAllLeft | Use this to change the icon (chevrons-left) inside the fourth action button | | unselectAll | Use this to change the icon (x) inside the fifth action button |

Instructions

Generics

  1. Right now there's no draggable depency. But if you click and hold your mouse down and drag it into another itens in the same column, all of them it'll selected.
  2. The title and content background are both blue (#0052c0), but you can change those using the content-class and title-class props.
  3. By default the height isn't set, but it has an overflow-y CSS property, so if you use the height prop, you'll have a vertical scroll inside each panel.
  4. If you pass anything other than top to movedItemLocation, the item after moved will go to the bottom.
  5. The content key should be an unique key inside each array of objects (left-items / right-items).

Actions

From top to bottom:

  1. The first button moves all the left items to the right.
  2. The second button moves all the selected left items to the right.
  3. The third button moves all the right items to the left.
  4. The fourth button moves all the selected right items to the left.
  5. The fifth button unselect all the selected items from all columns (left and right).

Development

contributions welcome

Fork the project and enter this commands in your terminal

git clone https://github.com/YOUR_GITHUB_USERNAME/vue-list-picker.git
cd vue-list-picker
yarn

Storybook

For visual testing, this project contains storybook which you can run by doing the next command

$ yarn storybook

Jest

Before making the PR, if you changed something that needs to be tested, please make the tests inside the tests/unit folder.

To run the tests, you can use the next command

$ yarn test:unit

Commitlint

This project follows the commitlint guidelines, with minor changes.

You can commit using npm run commit to help you with that.

There's a pre-push hook that runs all the unit tests before you can push it.

If an error occurs, you can use the npm run commit:retry command that runs the previous npm run commit that you already filled.

ko-fi

License

MIT © guastallaigor