Skip to content

A "spinny", radial tool menu directive for AngularJS

License

Notifications You must be signed in to change notification settings

SignalPath/sp-spinny-menu

Repository files navigation

sp-spinny-menu - spinny tool menu

Developed by the folks at SignalPath

spinny in action

Installation

  1. This is an AngularJS directive, so first make sure that Angular is installed.

  2. bower install sp-spinny-menu

  3. Add to your index.html:

    <link rel="stylesheet" href="bower_components/font-awesome/css/font-awesome.css">
    <link rel="stylesheet" href="bower_components/sp-spinny-menu/dist/css/sp-spinny.css">
    
    <script src="bower_components/angular-fontawesome/dist/angular-fontawesome.js"></script>
    <script src="bower_components/sp-spinny-menu/dist/js/sp-spinny.js"></script>
    
  4. Add the signalpath.spinny module to your module dependencies:

    angular.module('myModule', ['signalpath.spinny']);
    
  5. Add tool button definitions to your controller:

    // see possible icon names at http://fontawesome.io/icons/
    vm.tools = [{icon: 'filter', action: doMyAction}];
    
    function doMyAction() {
        console.log('It works!');
    }
    
  6. Add the directive to your view:

    <div sp-spinny-menu="myCtrl.tools"></div>
    

###Additional Options To add multiple levels of buttons, add buttons to the children property:

vm.tools = [
    {icon: 'filter', action: doMyAction},
    {icon: 'eye', children: [
        {icon: 'list'},
        {icon: 'calendar'},
        {icon: 'th-large', children: [
            {icon: 'list', disabled: true} // set disabled to true to disable button
        ]}
    ]}
];

Todos

  • Add support for other icon libraries
  • Allow for more than 5 sub-buttons in a level