A lightweight and customisable component using SVG that takes a basic vue-router config and renders it radially.
There is a demo page which also serves as documentation.
npm install vue-nav-wheel
In the app entrypoint file (main.js)
import NavWheel from "vue-nav-wheel";
import("vue-nav-wheel/dist/nav-wheel.css");
Vue.component("nav-wheel", NavWheel);
Use the component with 2 parameters, as size and a config
<nav-wheel :size="600" :config="navWheelConfig" />
Take a look at node_modules/vue-nav-wheel/dist/nav-wheel.css
for the available classes to style.
A custom css file with some or all of those classes can be loaded to override that stylesheet. There are some examples in the demo site.
import("./nav-wheel-overrides.css")
Take a look at the parameters available in node_modules/vue-nav-wheel/src/nav-wheel-config.js
for the configurable parameters.
{
padAngle: 0.04,
spaceBetweenParentChild: 10,
shrinkRouteScale: 5,
scale: 1,
cornerSharpness: 100,
startRadius: 100,
childAngleSpread: 0.04,
defaultTransition: "fade",
isPanOnSelectEnabled: true, // For touch, should the touched route be panned into focus.
isPanOnMouseMoveEnabled: true, // Pan according to the currently mouse position.
hierarchyLevelsDisplayLimit: 3, // The limit of levels of hierarchy to display at once.
hierarchyLevelFocus: 2 // The limit at which routes stop displaying the parent's hierarchy.
}
Built using Vue CLI, so the normal commands will work for setting up your development environment
npm install
npm run test
npm run serve
npm run build:demo