paw-vue-icons v1.0.4
Vue Material Design Icon Components
This is an extension of the original library made by @robcresswell and the link is here
I copied it to adapt it to my personal needs, if you want to provide support to make it better I'm open to collaborate. Hit me up with a PR
This library is a collection of Vue single-file components to render Material Design Icons, sourced from the MaterialDesign project. It also includes some CSS that helps make the scaling of the icons a little easier.
Getting started
- Install the package - yarn add paw-vue-icons- OR - npm i paw-vue-icons
- Import the icon, and declare it as a local component: - import MenuIcon from 'paw-vue-icons/dist/Menu.vue'; components: { MenuIcon; }- OR - Declare it as a global component: - import MenuIcon from 'paw-vue-icons/dist/Menu.vue'; Vue.component('menu-icon', MenuIcon);- Note Icon files are pascal cased, e.g. - CheckboxMarkedCircle.vue, and their default name has- Iconappended e.g.- CheckboxMarkedCircleIcon.
- Then use it in your template code! - <menu-icon />
- Optional Add the included stylesheet. This few lines of CSS will cause the icons to scale with any surrounding text, which can be helpful when you primarily style with CSS. Note that if you intend to handle sizing with the - sizeprop, you probably don't want to use this as it may conflict.- import 'paw-vue-icons/styles.css';
Props
- title- This changes the hover tooltip as well as the title shown to screen readers. By default, those values are a "human readable" conversion of the icon names; for example- chevron-down-iconbecomes "Chevron down icon".- Example: - <android-icon title="this is an icon!" />
- decorative- This denotes whether an icon is purely decorative, or has some meaninfgul value. If an icon is decorative, it will be hidden from screen readers. By default, this is- false.- Example: - <android-icon decorative />
- fillColor- This property allows you to set the fill colour of an icon via JS instead of requiring CSS changes. Note that any CSS values, such as- fill: currentColor;provided by the optional CSS file, may override colours set with this prop.- Example: - <android-icon fillColor="#FF0000" />
- size- This property overrides the- widthand- heightattributes on the SVG. The default is- 24.- Example: - <android-icon :size="48" />
Icons
A list of the icons can be found at the
Material Design Icons website. The icons packaged here are pascal cased
versions of the names displayed on the website, to match the
Vue Style Guide. For example, the icon
named ultra-high-definition would be imported as
"paw-vue-icons/UltraHighDefinition.vue".
Tips
- Use - resolvein your Webpack config to clean up the imports:- resolve: { alias : { "icons": path.resolve(__dirname, "node_modules/paw-vue-icons") }, extensions: [ ".vue" ] }- This will give you much shorter and more readable imports, like - import Android from "icons/Android", rather than- import Android from "paw-vue-icons/Android.vue". Much better!
- If you want custom sizing, add your own css to adjust the height and width of the icons - .material-design-icon.icon-2x { height: 2em; width: 2em; } .material-design-icon.icon-2x > .material-design-icon__svg { height: 2em; width: 2em; }- Then add your size class - <fullscreen-icon class="icon-2x" />- While I recommend using CSS for styling, you can also pass in a - sizeprop, detailed in the- Propssection above.