UNPKG

@vtmn/assets

Version:
95 lines (65 loc) 3.53 kB
# `@vtmn/assets` > Decathlon Design System - Vitamin assets library <a href="https://www.decathlon.design/726f8c765/p/895daa-assets"><img src="https://img.shields.io/badge/decathlon.design-docs-007dbc" alt="documentation" /></a> <a href="https://www.npmjs.com/package/@vtmn/assets"><img src="https://img.shields.io/npm/v/@vtmn/assets?style=flat&logo=npm" alt="npm version" /></a> ## Install package After installing [npm](https://docs.npmjs.com/downloading-and-installing-node-js-and-npm) or [yarn](https://yarnpkg.com/en/docs/install), you can install `@vtmn/assets` with this command: ```sh # with npm npm i -S @vtmn/assets # with yarn yarn add @vtmn/assets ``` Or you can also install it with a CDN like `unpkg.com`. You can browse content [here](https://unpkg.com/@vtmn/assets/). ## Usage Once you have installed this package, depending on your setup, you can include `@vtmn/assets` in a handful of ways. - Reference via `<img>` element - Include via CSS - Copy-paste SVGs as embedded HTML Vitamin assets gives you SVGs, so you can include them into your HTML in a few ways depending on how your project is setup. Our assets include a `width` and `height` of `16px` by default to allow for easy resizing via `font-size`. ### External image Reference assets SVGs like normal images with the `<img>` element. ```html <img src="/node_modules/@vtmn/assets/dist/vitamix/svg/home-fill.svg" alt="Home icon filled" width="32" height="32" /> ``` ### CSS You can also use the SVG within your CSS (**be sure to escape any characters**, such as `#` to `%23` when specifying hex color values). When no dimensions are specified via `width` and `height` on the `<svg>`, the icon will fill the available space. The `viewBox` attribute is required if you wish to resize assets with `background-size`. Note that the `xmlns` attribute is required. ```css .your-class { content: ''; background-image: url("data:image/svg+xml,%3Csvg width='28' height='20' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Crect x='0.25' y='0.25' width='27.5' height='19.5' rx='1.75' fill='#fff' stroke='#f5f5f5' stroke-width='0.5'/%3E%3Cmask id='a' style='mask-type:alpha' maskUnits='userSpaceOnUse' x='0' y='0' width='28' height='20'%3E%3Crect x='0.25' y='0.25' width='27.5' height='19.5' rx='1.75' fill='#fff' stroke='#fff' stroke-width='0.5'/%3E%3C/mask%3E%3Cg mask='url(#a)'%3E%3Cpath fill='#f44653' d='M18.6670h28v20h-9.333z'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M020h9.333v0h0v20z' fill='#1035bb'/%3E%3C/g%3E%3C/svg%3E"); background-repeat: no-repeat; background-size: 1rem 1rem; } ``` ### Embedded Embed your assets within the HTML of your page (as opposed to an external image file, not really recommended). Here we’ve used a custom `width` and `height`. ```html <svg width="16" height="16" fill="#001018" viewbox="0 0 16 16" xmlns="http://www.w3.org/2000/svg" > <path d="M7.333 7.333v-4h1.334v4h4v1.334h-4v4H7.333v-4h-4V7.333h4z" fill="#001018" /> </svg> ``` ## Changelog If you want to know the different changes between versions of this package, [look at the changelog here](https://github.com/Decathlon/vitamin-web/blob/main/packages/sources/assets/CHANGELOG.md). ## I have an issue, what should I do? Please file the issue [here](https://github.com/Decathlon/vitamin-web/issues/new). ## Contributing See [the contributing docs](https://github.com/Decathlon/vitamin-web/blob/main/CONTRIBUTING.md). ## License Apache-2.0 © [Decathlon](https://github.com/Decathlon)