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

@axa-ch/materials

v16.0.8

Published

The materials component for the AXA Pattern Library

Downloads

3,003

Readme

AXA Materials

Materials provides common used icons and images in the SVG format. In addition materials exports styles like colors, helpers, typography and layouts.

Usage

Important: If this component needs to run in Internet Explorer 11, you need to use our polyfill.

npm install @axa-ch/materials
import { unsafeHTML } from 'lit/directives/unsafe-html.js';
import { Arrow_forwardSvg } from '@axa-ch/materials/icons/material-design';

<span>${unsafeHTML(Arrow_forwardSvg)}</span>;

React

import ArrowForwardSvg from '@axa-ch/materials/icons-raw/material-design/arrow-forward.svg';

<ArrowForwardSvg />;

React with Typescript

import { ReactComponent as ArrowForwardSvg } from '@axa-ch/materials/icons-raw/material-design/arrow-forward.svg';

<ArrowForwardSvg />;

You need to use SVGR that takes external SVG files and transforms them into React components with Webpack. It is installed automatically if you use create-pod-app.

If you need to install it manually:

npm install @svgr/webpack --save-dev
{
  test: /\.svg$/,
  use: ['@svgr/webpack'],
}

Styles - Scss Mixins and Variables

Colors

@import '@axa-ch/materials/styles/00-colors.scss';

body {
  background-color: $color-axa-blue;
}

animations

@import '@axa-ch/materials/styles/20-animations.scss';

Breakpoints

@import '@axa-ch/materials/styles/variables.scss';

body {
  // Rules for devices bigger than portrait mobile
  @media (min-width: $breakpoint-xs) {
    margin: 8px;
  }
}

Typography

@import '@axa-ch/materials/styles/typography.scss';

body {
  font-family: $font-family-primary;
}

Variables

@import '@axa-ch/materials/styles/variables.scss';

body {
  margin: $spacing-1;
}

.box {
  box-shadow: $box-shadow-1;
}

Icon/Image set

Sizes

Please note the size classes of icons and images here. Please just use these dimensions.

SVGs

(Complete list is visible here)

| icons | | ---------------- | | AddSvg | | ArrowLeftSvg | | ArrowRightSvg | | AttachFileSvg | | CancelSvg | | CaretSvg | | CheckCircleSvg | | ClearSvg | | CloudUploadSvg | | CollapseSvg | | DateInputSvg | | DeleteForeverSvg | | DocumentSvg | | DownloadSvg | | EmailSvg | | ExpandSvg | | FacebookSvg | | InfoSvg | | InstagramSvg | | KeySvg | | LinkedinSvg | | MobileSvg | | MessageSvg | | PersonSvg | | PhoneSvg | | PowerSvg | | SearchSvg | | TwitterSvg | | UploadSvg | | XingSvg | | YoutubeSvg |

| images | | ------------------------------- | | AxaLogoSvg | | AxaLogoOpenSvg | | ... and many more in subfolders |

Contribution

Process of adding a new image

  1. Involve a designer by sending him the new SVG in question, unless the designer already has the file. He will review it and possibly change some things, for example by adjusting inner padding etc. in order to guarantee overall quality.
  2. Remove unnecessary code inside the SVG:
    • a. data-name="Layer 2" # layer info for vector drawing software
    • b. <path fill="#fff" d="M0 0h96v96H0z"/> # outer bounding box filled with white background
    • a. use the internal svgo -invoking script npm run build-images from the materials-folder itself to clean up and optimize the SVGs, then copy the optimized files back from the .tmp folder to images-raw
    • b. alternatively use the online SVG optimizer for the same purpose
  3. Manually review the SVGs produced in the last step: add or edit <path> attributes, setting fill="currentColor" and/or strokes="currentColor" as appropriate. Remove unnecessary attributes.
  4. Run npm run build to generate a js file for each svg file found. The generated files can be found in the images folder.

Updating materials (UNIX only)

All our icons in the "icons" section are the material icons from google (and nothing else). To update the material icons from google (https://github.com/google/material-design-icons/releases), follow these steps.

  1. Remove the contents of the icons-raw folder.
  2. Download the newest version of material icons as a ZIP file to your download folder.
  3. Extract the material icons zip file into the downloads folder.
  4. Rename the extracted folder to material-design-icons.
  5. Open a terminal and cd into the materials root folder (src/components/00-materials/).
  6. Run sh material-importer.sh.
  7. Run a search on only the folder src/components/00-materials/icons-raw and search for <path (whitespace at the end).
  8. Replace all occurences with <path fill="currentColor" (whitespace at the end).
  9. Run a search on only the folder src/components/00-materials/icons-raw and search for <circle (whitespace at the end).
  10. Replace all occurences with <circle fill="currentColor" (whitespace at the end).

Done. This seems to be the fastest and most efficient approach with the current importer script.