SVG icons for popular brands
Go to file
Eric Cornelissen db442fb0c1 Improve search performance (#1170)
* Improve performance of search on website

By reducing the number of times a search query loops over all icons or
all icons that match the search query (from 3 to 1 and 2 to 0
respectively) the search on simpleicons.org should now be noticeably
faster (if it was slow before). Especially in conjunction with #1169.

This was achieved by utilizing CSS (which operates faster then plain
JavaScript) to do most of the heavy lifting. A class on <body> now
dictates the order of the icons rather then a JavaScript for-loop (found
in the removed function `orderIcons`).

It was also achieved by more cleverly utilizing the fuzzy search logic
and recognizing that the CSS `order` property also works if number are
not consecutive. Less relevant numbers will have a higher value assigned
by fuzzy search, which is what the `order`-value of the icon will
become, removing the need for sorting and an additional loop.

Some resources that helped me:
- https://css-tricks.com/css-attr-function-got-nothin-custom-properties/
- https://developer.mozilla.org/en-US/docs/Web/CSS/Using_CSS_variables
    Specifically the "Values in JavaScript" section

* * *

One unrelated change in stylesheet.css where 2 separate rulesets for
.grid-item__link have been merged.

* Simplify script with regard to button states

* Reduce complexity of `previousQuery` variables
2019-02-03 22:31:22 +01:00
_data Update Slack (#1172) 2019-02-03 20:41:16 +02:00
.github Add a point to the pr template checklist (#1122) 2018-12-14 14:33:37 +02:00
icons Update Slack (#1172) 2019-02-03 20:41:16 +02:00
images Adds better OG preview image 2017-04-27 18:19:18 +01:00
scripts Add Apple Pay, AT&T, T-Mobile, Sprint, Verizon, Boost, Framer (#973) 2018-09-11 08:42:29 +02:00
tests Test the NPM package (#972) 2018-09-09 21:58:53 +02:00
.gitignore Add "jsonhint" dependency 2017-09-11 21:53:21 +02:00
.jsonlintschema Change wording in schema 2017-09-13 21:44:59 +02:00
.npmignore Add index.js to .npmignore whitelist 2017-09-17 03:49:13 +02:00
.svglintrc.js Remove aria-labelledby and ids from SVGs (#1062) 2018-11-06 17:10:17 +01:00
.travis.yml Refine xmlstarlet options (#1159) 2019-01-07 22:18:22 +01:00
CNAME Update CNAME 2015-11-02 14:20:14 +00:00
CONTRIBUTING.md Remove aria-labelledby and ids from SVGs (#1062) 2018-11-06 17:10:17 +01:00
index.html Improve search performance (#1170) 2019-02-03 22:31:22 +01:00
LICENSE.md Markdown fix (#928) 2018-08-10 15:22:29 +02:00
package-lock.json Update package-lock.json 2018-11-18 00:49:14 +01:00
package.json Version bump 2019-02-03 20:46:48 +02:00
README.md readme: Update example icons to be that of Simple Icons (#1174) 2019-02-03 20:40:37 +02:00
site_script.js Improve search performance (#1170) 2019-02-03 22:31:22 +01:00
stylesheet.css Improve search performance (#1170) 2019-02-03 22:31:22 +01:00

Simple Icons

Simple Icons

Free SVG icons for popular brands. See them all on one page at SimpleIcons.org. Contributions, corrections & requests can be made on GitHub. Started by Dan Leech.

Usage

General Usage

Icons can be downloaded as SVGs directly from our website - simply click the icon you want, and the download should start automatically.

CDN Usage

Icons can be served from a CDN such as JSDelivr or Unpkg. Simply use the simple-icons npm package and specify a version in the URL like the following:

<img height="32" width="32" src="https://cdn.jsdelivr.net/npm/simple-icons@latest/icons/[ICON NAME].svg" />
<img height="32" width="32" src="https://unpkg.com/simple-icons@latest/icons/[ICON NAME].svg" />

Where [ICON NAME] is replaced by the icon name, for example:

<img height="32" width="32" src="https://cdn.jsdelivr.net/npm/simple-icons@latest/icons/simpleicons.svg" />
<img height="32" width="32" src="https://unpkg.com/simple-icons@latest/icons/simpleicons.svg" />

Node Usage

The icons are also available through our npm package. To install, simply run:

$ npm install simple-icons

The API can then be used as follows:

const simpleIcons = require('simple-icons');

console.log(simpleIcons['Simple Icons']);

/*
{
    title: 'Simple Icons',
    hex: '111111',
    source: 'https://simpleicons.org/',
    svg: '<svg role="img" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg">...</svg>'
}
*/

Alternatively you can import the needed icons individually. This is useful if you are e.g. compiling your code with webpack and therefore have to be mindful of your package size:

const icon = require('simple-icons/icons/simpleicons');

console.log(icon);

/*
{
    title: 'Simple Icons',
    hex: '111111',
    source: 'https://simpleicons.org/',
    svg: '<svg role="img" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg">...</svg>'
}
*/

Third Party Extensions

WordPress

Icons are also available on WordPress through a simple plugin created by @tjtaylo, which you can find here.

Status

Build Status npm version