initial set of feather icons
This commit is contained in:
commit
3472a4efb0
180
.eslintrc
Normal file
180
.eslintrc
Normal file
@ -0,0 +1,180 @@
|
||||
{
|
||||
root: true,
|
||||
parser: 'babel-eslint',
|
||||
plugins: [/*'import', */'jsx-a11y', 'react'],
|
||||
env: {
|
||||
browser: true,
|
||||
commonjs: true,
|
||||
es6: true,
|
||||
jest: true,
|
||||
node: true
|
||||
},
|
||||
parserOptions: {
|
||||
ecmaVersion: 6,
|
||||
sourceType: 'module',
|
||||
ecmaFeatures: {
|
||||
jsx: true,
|
||||
generators: true,
|
||||
experimentalObjectRestSpread: true
|
||||
}
|
||||
},
|
||||
settings: {
|
||||
'import/ignore': [
|
||||
'node_modules',
|
||||
'\\.(json|css|jpg|png|gif|eot|otf|webp|svg|ttf|woff|woff2|mp4|webm)$',
|
||||
],
|
||||
'import/extensions': ['.js'],
|
||||
'import/resolver': {
|
||||
node: {
|
||||
extensions: ['.js', '.json']
|
||||
}
|
||||
}
|
||||
},
|
||||
rules: {
|
||||
// http://eslint.org/docs/rules/
|
||||
'array-callback-return': 'warn',
|
||||
'camelcase': 'warn',
|
||||
'curly': 'warn',
|
||||
'default-case': ['warn', { commentPattern: '^no default$' }],
|
||||
'dot-location': ['warn', 'property'],
|
||||
'eol-last': 'warn',
|
||||
'eqeqeq': ['warn', 'always'],
|
||||
'indent': ['warn', 2, { "SwitchCase": 1 }],
|
||||
'guard-for-in': 'warn',
|
||||
'keyword-spacing': 'warn',
|
||||
'new-parens': 'warn',
|
||||
'no-array-constructor': 'warn',
|
||||
'no-caller': 'warn',
|
||||
'no-cond-assign': ['warn', 'always'],
|
||||
'no-const-assign': 'warn',
|
||||
'no-control-regex': 'warn',
|
||||
'no-delete-var': 'warn',
|
||||
'no-dupe-args': 'warn',
|
||||
'no-dupe-class-members': 'warn',
|
||||
'no-dupe-keys': 'warn',
|
||||
'no-duplicate-case': 'warn',
|
||||
'no-empty-character-class': 'warn',
|
||||
'no-empty-pattern': 'warn',
|
||||
'no-eval': 'warn',
|
||||
'no-ex-assign': 'warn',
|
||||
'no-extend-native': 'warn',
|
||||
'no-extra-bind': 'warn',
|
||||
'no-extra-label': 'warn',
|
||||
'no-fallthrough': 'warn',
|
||||
'no-func-assign': 'warn',
|
||||
'no-global-assign': 'warn',
|
||||
'no-implied-eval': 'warn',
|
||||
'no-invalid-regexp': 'warn',
|
||||
'no-iterator': 'warn',
|
||||
'no-label-var': 'warn',
|
||||
'no-labels': ['warn', { allowLoop: false, allowSwitch: false }],
|
||||
'no-lone-blocks': 'warn',
|
||||
'no-loop-func': 'warn',
|
||||
'no-mixed-operators': ['warn', {
|
||||
groups: [
|
||||
['&', '|', '^', '~', '<<', '>>', '>>>'],
|
||||
['==', '!=', '===', '!==', '>', '>=', '<', '<='],
|
||||
['&&', '||'],
|
||||
['in', 'instanceof']
|
||||
],
|
||||
allowSamePrecedence: false
|
||||
}],
|
||||
'no-multi-str': 'warn',
|
||||
'no-new-func': 'warn',
|
||||
'no-new-object': 'warn',
|
||||
'no-new-symbol': 'warn',
|
||||
'no-new-wrappers': 'warn',
|
||||
'no-obj-calls': 'warn',
|
||||
'no-octal': 'warn',
|
||||
'no-octal-escape': 'warn',
|
||||
'no-redeclare': 'warn',
|
||||
'no-regex-spaces': 'warn',
|
||||
'no-restricted-syntax': [
|
||||
'warn',
|
||||
'LabeledStatement',
|
||||
'WithStatement',
|
||||
],
|
||||
'no-script-url': 'warn',
|
||||
'no-self-assign': 'warn',
|
||||
'no-self-compare': 'warn',
|
||||
'no-sequences': 'warn',
|
||||
'no-shadow-restricted-names': 'warn',
|
||||
'no-sparse-arrays': 'warn',
|
||||
'no-template-curly-in-string': 'warn',
|
||||
'no-this-before-super': 'warn',
|
||||
'no-throw-literal': 'warn',
|
||||
'no-undef': 'warn',
|
||||
'no-unexpected-multiline': 'warn',
|
||||
'no-unreachable': 'warn',
|
||||
'no-unsafe-negation': 'warn',
|
||||
'no-unused-expressions': 'warn',
|
||||
'no-unused-labels': 'warn',
|
||||
'no-unused-vars': ['warn', { vars: 'local', args: 'none' }],
|
||||
'no-use-before-define': ['warn', 'nofunc'],
|
||||
'no-useless-computed-key': 'warn',
|
||||
'no-useless-concat': 'warn',
|
||||
'no-useless-constructor': 'warn',
|
||||
'no-useless-escape': 'warn',
|
||||
'no-useless-rename': ['warn', {
|
||||
ignoreDestructuring: false,
|
||||
ignoreImport: false,
|
||||
ignoreExport: false,
|
||||
}],
|
||||
'no-with': 'warn',
|
||||
'no-whitespace-before-property': 'warn',
|
||||
'object-curly-spacing': ['warn', 'always'],
|
||||
'operator-assignment': ['warn', 'always'],
|
||||
radix: 'warn',
|
||||
'require-yield': 'warn',
|
||||
'rest-spread-spacing': ['warn', 'never'],
|
||||
'semi': 'warn',
|
||||
strict: ['warn', 'never'],
|
||||
'unicode-bom': ['warn', 'never'],
|
||||
'use-isnan': 'warn',
|
||||
'valid-typeof': 'warn',
|
||||
'react/jsx-boolean-value': 'warn',
|
||||
'react/jsx-closing-bracket-location': 'warn',
|
||||
'react/jsx-curly-spacing': 'warn',
|
||||
'react/jsx-equals-spacing': ['warn', 'never'],
|
||||
'react/jsx-first-prop-new-line': ['warn', 'multiline'],
|
||||
'react/jsx-handler-names': 'warn',
|
||||
'react/jsx-indent': ['warn', 2],
|
||||
'react/jsx-indent-props': ['warn', 2],
|
||||
'react/jsx-key': 'warn',
|
||||
'react/jsx-max-props-per-line': 'warn',
|
||||
'react/jsx-no-bind': ['warn', {'allowArrowFunctions': true}],
|
||||
'react/jsx-no-comment-textnodes': 'warn',
|
||||
'react/jsx-no-duplicate-props': ['warn', { ignoreCase: true }],
|
||||
'react/jsx-no-undef': 'warn',
|
||||
'react/jsx-pascal-case': ['warn', {
|
||||
allowAllCaps: true,
|
||||
ignore: [],
|
||||
}],
|
||||
'react/jsx-sort-props': 'warn',
|
||||
'react/jsx-tag-spacing': 'warn',
|
||||
'react/jsx-uses-react': 'warn',
|
||||
'react/jsx-uses-vars': 'warn',
|
||||
'react/jsx-wrap-multilines': 'warn',
|
||||
'react/no-deprecated': 'warn',
|
||||
'react/no-did-mount-set-state': 'warn',
|
||||
'react/no-did-update-set-state': 'warn',
|
||||
'react/no-direct-mutation-state': 'warn',
|
||||
'react/no-is-mounted': 'warn',
|
||||
'react/no-unused-prop-types': 'warn',
|
||||
'react/prefer-es6-class': 'warn',
|
||||
'react/prefer-stateless-function': 'warn',
|
||||
'react/prop-types': 'warn',
|
||||
'react/react-in-jsx-scope': 'warn',
|
||||
'react/require-render-return': 'warn',
|
||||
'react/self-closing-comp': 'warn',
|
||||
'react/sort-comp': 'warn',
|
||||
'react/sort-prop-types': 'warn',
|
||||
'react/style-prop-object': 'warn',
|
||||
'react/void-dom-elements-no-children': 'warn',
|
||||
// https://github.com/evcohen/eslint-plugin-jsx-a11y/tree/master/docs/rules
|
||||
'jsx-a11y/aria-role': 'warn',
|
||||
'jsx-a11y/img-has-alt': 'warn',
|
||||
'jsx-a11y/img-redundant-alt': 'warn',
|
||||
'jsx-a11y/no-access-key': 'warn'
|
||||
}
|
||||
}
|
||||
4
.gitignore
vendored
Normal file
4
.gitignore
vendored
Normal file
@ -0,0 +1,4 @@
|
||||
.DS_Store
|
||||
build
|
||||
node_modules
|
||||
*.log
|
||||
2
.npmignore
Normal file
2
.npmignore
Normal file
@ -0,0 +1,2 @@
|
||||
.babelrc
|
||||
src
|
||||
15
README.md
Normal file
15
README.md
Normal file
@ -0,0 +1,15 @@
|
||||
Feather Icons React
|
||||
|
||||
`npm install --save feather-icons-react`
|
||||
|
||||
This package lets you use Feather Icons as a React Component.
|
||||
Feather Icons is an svg font library by Cole Bemis (https://feathericons.com/).
|
||||
|
||||
Example usage:
|
||||
`import FeatherIcon from 'feather-icons-react';`
|
||||
`<FeatherIcon icon="close" />`
|
||||
Setting a size:
|
||||
Size can be passed as either string or number.
|
||||
e.g.: `<FeatherIcon icon="copy" size="24" />` or `<... size={24} />`
|
||||
|
||||
The icon names can all be referenced at: https://feathericons.com/
|
||||
6732
package-lock.json
generated
Normal file
6732
package-lock.json
generated
Normal file
File diff suppressed because it is too large
Load Diff
45
package.json
Normal file
45
package.json
Normal file
@ -0,0 +1,45 @@
|
||||
{
|
||||
"name": "feather-icons-react",
|
||||
"version": "0.0.1",
|
||||
"description": "Feather Icons as a React component.",
|
||||
"main": "index.js",
|
||||
"scripts": {
|
||||
"test": "npm run test",
|
||||
"build": "babel src -d build",
|
||||
"lint": "eslint src/**; exit 0",
|
||||
"lint:watch": "esw -w lib/**",
|
||||
"prepublish": "npm run build"
|
||||
},
|
||||
"repository": {
|
||||
"type": "git",
|
||||
"url": "git+https://github.com/ianmiller347/feather-icons-react.git"
|
||||
},
|
||||
"keywords": [
|
||||
"feather",
|
||||
"icons",
|
||||
"react",
|
||||
"svg"
|
||||
],
|
||||
"author": "Ian J. Miller",
|
||||
"license": "ISC",
|
||||
"bugs": {
|
||||
"url": "https://github.com/ianmiller347/feather-icons-react/issues"
|
||||
},
|
||||
"homepage": "https://github.com/ianmiller347/feather-icons-react#readme",
|
||||
"devDependencies": {
|
||||
"prop-types": "^15.6.0",
|
||||
"react": "^16.0.0",
|
||||
"react-dom": "^16.0.0",
|
||||
"react-scripts": "^1.0.16",
|
||||
"babel-cli": "^6.26.0",
|
||||
"babel-core": "^6.26.0",
|
||||
"babel-eslint": "^8.0.1",
|
||||
"babel-preset-es2015": "^6.24.1",
|
||||
"babel-preset-react": "^6.24.1",
|
||||
"eslint": "^4.10.0",
|
||||
"eslint-plugin-import": "^2.8.0",
|
||||
"eslint-plugin-jsx-a11y": "^6.0.2",
|
||||
"eslint-plugin-react": "^7.4.0",
|
||||
"eslint-watch": "^3.1.3"
|
||||
}
|
||||
}
|
||||
113
src/FeatherIcon.js
Normal file
113
src/FeatherIcon.js
Normal file
@ -0,0 +1,113 @@
|
||||
import React, { Component } from 'react';
|
||||
import PropTypes from 'prop-types';
|
||||
|
||||
class FeatherIcon extends Component {
|
||||
constructor(props) {
|
||||
super(props);
|
||||
}
|
||||
|
||||
render() {
|
||||
const { icon, size, ...otherProps } = this.props;
|
||||
|
||||
return (
|
||||
<svg width={size}
|
||||
height={size}
|
||||
viewBox="0 0 24 24"
|
||||
fill="none"
|
||||
stroke="currentColor"
|
||||
strokeWidth="2"
|
||||
strokeLinecap="round"
|
||||
strokeLinejoin="round"
|
||||
className={`feather feather-${icon}`}
|
||||
{...otherProps}>
|
||||
{this._renderInner(icon)}
|
||||
</svg>
|
||||
);
|
||||
}
|
||||
|
||||
_renderInner(icon) {
|
||||
/* this is just a bunch of if statements to return the innards of the svg
|
||||
* based on the type of icon it is.
|
||||
* yes it's ok to not use our width and height variables here.
|
||||
* the sizes are relative based on the viewBox attribute.
|
||||
* our width and height variables will scale the SVG accordingly.
|
||||
* <g> is just a wrapper it does nothing except let me use valid JSX markup
|
||||
*/
|
||||
if (icon === 'copy') {
|
||||
return (
|
||||
<g>
|
||||
<rect x="9" y="9" width="13" height="13" rx="2" ry="2"></rect>
|
||||
<path d="M5 15H4a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h9a2 2 0 0 1 2 2v1"></path>
|
||||
</g>
|
||||
);
|
||||
}
|
||||
if (icon === 'x-circle') {
|
||||
return (
|
||||
<g>
|
||||
<circle cx="12" cy="12" r="10"></circle>
|
||||
<line x1="15" y1="9" x2="9" y2="15"></line>
|
||||
<line x1="9" y1="9" x2="15" y2="15"></line>
|
||||
</g>
|
||||
);
|
||||
}
|
||||
if (icon === 'plus-square') {
|
||||
return (
|
||||
<g>
|
||||
<rect x="3" y="3" width="18" height="18" rx="2" ry="2"></rect>
|
||||
<line x1="12" y1="8" x2="12" y2="16"></line>
|
||||
<line x1="8" y1="12" x2="16" y2="12"></line>
|
||||
</g>
|
||||
);
|
||||
}
|
||||
if (icon === 'save') {
|
||||
return (
|
||||
<g>
|
||||
<path d="M19 21H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h11l5 5v11a2 2 0 0 1-2 2z"></path>
|
||||
<polyline points="17 21 17 13 7 13 7 21"></polyline>
|
||||
<polyline points="7 3 7 8 15 8"></polyline>
|
||||
</g>
|
||||
);
|
||||
}
|
||||
if (icon === 'delete') {
|
||||
return (
|
||||
<g>
|
||||
<path d="M21 4H8l-7 8 7 8h13a2 2 0 0 0 2-2V6a2 2 0 0 0-2-2z"></path>
|
||||
<line x1="18" y1="9" x2="12" y2="15"></line>
|
||||
<line x1="12" y1="9" x2="18" y2="15"></line>
|
||||
</g>
|
||||
);
|
||||
}
|
||||
if (icon === 'chevron-up') {
|
||||
return (
|
||||
<polyline points="18 15 12 9 6 15"></polyline>
|
||||
);
|
||||
}
|
||||
if (icon === 'chevron-down') {
|
||||
return (
|
||||
<polyline points="6 9 12 15 18 9"></polyline>
|
||||
);
|
||||
}
|
||||
if (icon === 'info') {
|
||||
return (
|
||||
<g>
|
||||
<circle cx="12" cy="12" r="10"></circle>
|
||||
<line x1="12" y1="16" x2="12" y2="12"></line>
|
||||
<line x1="12" y1="8" x2="12" y2="8"></line>
|
||||
</g>
|
||||
);
|
||||
}
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
FeatherIcon.propTypes = {
|
||||
icon: PropTypes.string.isRequired,
|
||||
size: PropTypes.oneOfType([PropTypes.string, PropTypes.number])
|
||||
}
|
||||
|
||||
FeatherIcon.defaultProps = {
|
||||
color: 'currentColor',
|
||||
size: 24
|
||||
}
|
||||
|
||||
export default FeatherIcon;
|
||||
1
src/index.js
Normal file
1
src/index.js
Normal file
@ -0,0 +1 @@
|
||||
export FeatherIcon from './FeatherIcon';
|
||||
Loading…
Reference in New Issue
Block a user