react-lightning-design-components
Version:
Salesforce Lightning Design System components built with React 16
238 lines (182 loc) • 34.2 kB
JavaScript
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _slicedToArray2 = require('babel-runtime/helpers/slicedToArray');
var _slicedToArray3 = _interopRequireDefault(_slicedToArray2);
var _extends2 = require('babel-runtime/helpers/extends');
var _extends3 = _interopRequireDefault(_extends2);
var _defineProperty2 = require('babel-runtime/helpers/defineProperty');
var _defineProperty3 = _interopRequireDefault(_defineProperty2);
var _objectWithoutProperties2 = require('babel-runtime/helpers/objectWithoutProperties');
var _objectWithoutProperties3 = _interopRequireDefault(_objectWithoutProperties2);
var _getPrototypeOf = require('babel-runtime/core-js/object/get-prototype-of');
var _getPrototypeOf2 = _interopRequireDefault(_getPrototypeOf);
var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck');
var _classCallCheck3 = _interopRequireDefault(_classCallCheck2);
var _createClass2 = require('babel-runtime/helpers/createClass');
var _createClass3 = _interopRequireDefault(_createClass2);
var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn');
var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2);
var _inherits2 = require('babel-runtime/helpers/inherits');
var _inherits3 = _interopRequireDefault(_inherits2);
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _reactDom = require('react-dom');
var _reactDom2 = _interopRequireDefault(_reactDom);
var _classnames2 = require('classnames');
var _classnames3 = _interopRequireDefault(_classnames2);
var _svg4everybody = require('svg4everybody');
var _svg4everybody2 = _interopRequireDefault(_svg4everybody);
var _util = require('./util');
var _util2 = _interopRequireDefault(_util);
var _propTypes = require('prop-types');
var _propTypes2 = _interopRequireDefault(_propTypes);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
(0, _svg4everybody2.default)();
/* eslint-disable max-len */
var STANDARD_ICONS = '\naccount,announcement,answer_best,answer_private,answer_public,approval,apps,apps_admin,\narticle,avatar,avatar_loading,calibration,call,call_history,campaign,campaign_members,\ncanvas,case,case_change_status,case_comment,case_email,case_log_a_call,case_transcript,\nclient,coaching,connected_apps,contact,contract,custom,dashboard,default,document,\ndrafts,email,email_IQ,email_chatter,empty,endorsement,environment_hub,event,feed,feedback,\nfile,flow,folder,generic_loading,goals,group_loading,groups,hierarchy,home,household,insights,investment_account,\nlead,link,log_a_call,marketing_actions,metrics,news,note,opportunity,\norders,people,performance,person_account,photo,poll,portal,post,pricebook,process,product,question_best,\nquestion_feed,quotes,recent,record,related_list,report,reward,scan_card,skill_entity,\nsocial,solution,sossession,task,task2,team_member,thanks,thanks_loading,today,topic,\nunmatched,user,work_order,work_order_item\n'.replace(/^\s+|\s+$/g, '').split(/[\s,]+/);
var CUSTOM_ICONS = new Array(101).join('_').split('').map(function (a, i) {
return 'custom' + (i + 1);
});
var ACTION_ICONS = '\nadd_contact,announcement,apex,approval,back,call,canvas,change_owner,change_record_type,\ncheck,clone,close,defer,delete,description,dial_in,download,edit,edit_groups,edit_relationship,\nemail,fallback,filter,flow,follow,following,freeze_user,goal,google_news,info,join_group,\nlead_convert,leave_group,log_a_call,log_event,manage_perm_sets,map,more,new,new_account,\nnew_campaign,new_case,new_child_case,new_contact,new_event,new_group,new_lead,new_note,\nnew_notebook,new_opportunity,new_person_account,new_task,password_unlock,preview,priority,question_post_action,\nquote,record,refresh,reject,remove,reset_password,share,share_file,share_link,share_poll,\nshare_post,share_thanks,sort,submit_for_approval,update,update_status,upload,user,user_activation,\nweb_link,\nnew_custom7,new_custom8,new_custom9,new_custom10,new_custom11,new_custom12,new_custom13,\nnew_custom14,new_custom15,new_custom16,new_custom17,new_custom18,new_custom19,new_custom20,\nnew_custom21,new_custom22,new_custom23,new_custom24,new_custom25,new_custom26,new_custom27,\nnew_custom28,new_custom29,new_custom30,new_custom31,new_custom32,new_custom33,new_custom34,\nnew_custom35,new_custom36,new_custom37,new_custom38,new_custom39,new_custom40,new_custom41,\nnew_custom42,new_custom43,new_custom44,new_custom45,new_custom46,new_custom47,new_custom48,\nnew_custom49,new_custom50,new_custom51,new_custom52,new_custom53,new_custom54,new_custom55,\nnew_custom56,new_custom57,new_custom58,new_custom59,new_custom60,new_custom61,new_custom62,\nnew_custom63,new_custom64,new_custom65,new_custom66,new_custom67,new_custom68,new_custom69,\nnew_custom70,new_custom71,new_custom72,new_custom73,new_custom74,new_custom75,new_custom76,\nnew_custom77,new_custom78,new_custom79,new_custom80,new_custom81,new_custom82,new_custom83,\nnew_custom84,new_custom85,new_custom86,new_custom87,new_custom88,new_custom89,new_custom90,\nnew_custom91,new_custom92,new_custom93,new_custom94,new_custom95,new_custom96,new_custom97,\nnew_custom98,new_custom99,new_custom100\n'.replace(/^\s+|\s+$/g, '').split(/[\s,]+/);
var DOCTYPE_ICONS = '\nai,attachment,audio,box_notes,csv,eps,excel,exe,flash,gdoc,gdocs,gpres,gsheet,html,image,keynote,\nlink,mp4,overlay,pack,pages,pdf,ppt,psd,rtf,slide,stypi,txt,unknown,video,visio,\nwebex,word,xml,zip\n'.replace(/^\s+|\s+$/g, '').split(/[\s,]+/);
var UTILITY_ICONS = '\nadd,adduser,announcement,answer,apps,arrowdown,arrowup,attach,back,ban,bold,bookmark,brush,\nbucket,builder,call,capslock,cases,center_align_text,chart,chat,check,checkin,chevrondown,\nchevronleft,chevronright,chevronup,clear,clock,close,comments,company,connected_apps,\ncontract,contract_alt,copy,crossfilter,custom_apps,cut,dash,datadotcom,dayview,delete,deprecate,\ndescription,desktop,down,download,edit,edit_form,email,end_call,erect_window,error,event,expand,\nexpand_alt,favorite,feed,file,filter,filterList,forward,frozen,groups,help,home,identity,image,inbox,info,\ninsert_tag_field,insert_template,italic,justify_text,kanban,knowledge_base,layers,layout,\nleft,left_align_text,like,link,list,location,lock,log_a_call,logout,magicwand,matrix,metrics,minimize_window,\nmoneybag,monthlyview,move,muted,new,new_window,news,note,notebook,notification,office365,offline,\nopen,open_folder,opened_folder,overflow,package,package_org,package_org_beta,page,palette,paste,\npeople,phone_landscape,phone_portrait,photo,picklist,power,preview,priority,process,push,puzzle,\nquestion,questions_and_answers,record,redo,refresh,relate,remove_formatting,remove_link,\nreplace,reply,reset_password,retweet,richtextbulletedlist,richtextindent,richtextnumberedlist,\nrichtextoutdent,right,right_align_text,rotate,rows,salesforce1,search,settings,setup,setup_assistant_guide,\nshare,share_post,shield,side_list,signpost,sms,snippet,socialshare,sort,spinner,standard_objects,\nstop,strikethrough,success,summary,summarydetail,switch,table,tablet_landscape,tablet_portrait,\ntabset,task,text_background_color,text_color,threedots,tile_card_list,topic,touch_action,trail,undelete,undeprecate,\nunderline,undo,unlock,unmuted,up,upload,user,user_role,volume_high,volume_low,volume_off,warning,\nweeklyview,world,zoomin,zoomout\n'.replace(/^\s+|\s+$/g, '').split(/[\s,]+/);
/* eslint-enable max-len */
var Icon = function (_React$Component) {
(0, _inherits3.default)(Icon, _React$Component);
function Icon(props) {
(0, _classCallCheck3.default)(this, Icon);
var _this = (0, _possibleConstructorReturn3.default)(this, (Icon.__proto__ || (0, _getPrototypeOf2.default)(Icon)).call(this, props));
_this.state = {};
_this.svgIconRef = _this.svgIconRef.bind(_this);
_this.iconContainerRef = _this.iconContainerRef.bind(_this);
return _this;
}
(0, _createClass3.default)(Icon, [{
key: 'componentDidMount',
value: function componentDidMount() {
this.checkIconColor();
var svgEl = _reactDom2.default.findDOMNode(this.svgIcon);
svgEl.setAttribute('focusable', this.props.tabIndex >= 0);
}
}, {
key: 'componentDidUpdate',
value: function componentDidUpdate() {
this.checkIconColor();
}
}, {
key: 'getIconColor',
value: function getIconColor(fillColor, category, icon) {
/* eslint-disable no-unneeded-ternary */
return this.state.iconColor ? this.state.iconColor : category === 'doctype' ? null : fillColor === 'none' ? null : fillColor ? fillColor : category === 'utility' ? null : category === 'custom' ? icon.replace(/^custom/, 'custom-') : category === 'action' && /^new_custom/.test(icon) ? icon.replace(/^new_custom/, 'custom-') : category + '-' + (icon || '').replace(/_/g, '-');
}
}, {
key: 'checkIconColor',
value: function checkIconColor() {
var _props = this.props,
fillColor = _props.fillColor,
_props$category = _props.category,
category = _props$category === undefined ? 'utility' : _props$category,
container = _props.container;
if (fillColor === 'none' || category === 'doctype' || !fillColor && category === 'utility') {
return;
}
var el = _reactDom2.default.findDOMNode(container ? this.iconContainer : this.svgIcon);
if (!(el && getComputedStyle(el))) {
return;
}
var bgColorStyle = getComputedStyle(el)['background-color'];
// if no background color set to the icon
if (/^(transparent|rgba\(0,\s*0,\s*0,\s*0\))$/.test(bgColorStyle)) {
this.setState({ iconColor: 'standard-default' });
}
}
}, {
key: 'svgIconRef',
value: function svgIconRef(ref) {
this.svgIcon = ref;
}
}, {
key: 'iconContainerRef',
value: function iconContainerRef(ref) {
this.iconContainer = ref;
}
}, {
key: 'renderSVG',
value: function renderSVG(_ref) {
var _classnames;
var className = _ref.className,
_ref$category = _ref.category,
category = _ref$category === undefined ? 'utility' : _ref$category,
icon = _ref.icon,
size = _ref.size,
align = _ref.align,
fillColor = _ref.fillColor,
container = _ref.container,
_ref$textColor = _ref.textColor,
textColor = _ref$textColor === undefined ? 'default' : _ref$textColor,
props = (0, _objectWithoutProperties3.default)(_ref, ['className', 'category', 'icon', 'size', 'align', 'fillColor', 'container', 'textColor']);
var iconColor = this.getIconColor(fillColor, category, icon);
var iconClassNames = (0, _classnames3.default)((_classnames = {
'slds-icon': !/slds\-button__icon/.test(className)
}, (0, _defineProperty3.default)(_classnames, 'slds-icon--' + size, /^(x-small|small|large)$/.test(size)), (0, _defineProperty3.default)(_classnames, 'slds-icon-text-' + textColor, /^(default|warning|error)$/.test(textColor) && !container && !iconColor), (0, _defineProperty3.default)(_classnames, 'slds-icon-' + iconColor, !container && iconColor), (0, _defineProperty3.default)(_classnames, 'slds-m-left--x-small', align === 'right'), (0, _defineProperty3.default)(_classnames, 'slds-m-right--x-small', align === 'left'), _classnames), className);
/* eslint-disable max-len */
var useHtml = '<use xlink:href="' + _util2.default.getAssetRoot() + '/icons/' + category + '-sprite/svg/symbols.svg#' + icon + '"></use>';
return _react2.default.createElement('svg', (0, _extends3.default)({
className: iconClassNames,
'aria-hidden': true,
dangerouslySetInnerHTML: { __html: useHtml },
ref: this.svgIconRef
}, props));
}
}, {
key: 'render',
value: function render() {
var _props2 = this.props,
container = _props2.container,
props = (0, _objectWithoutProperties3.default)(_props2, ['container']);
var category = props.category,
icon = props.icon;
if (icon.indexOf(':') > 0) {
var _icon$split = icon.split(':');
var _icon$split2 = (0, _slicedToArray3.default)(_icon$split, 2);
category = _icon$split2[0];
icon = _icon$split2[1];
}
if (container) {
var className = props.className,
fillColor = props.fillColor,
pprops = (0, _objectWithoutProperties3.default)(props, ['className', 'fillColor']);
var iconColor = this.getIconColor(fillColor, category, icon);
var containerClassName = (0, _classnames3.default)('slds-icon__container', container === 'circle' ? 'slds-icon__container--circle' : null, iconColor ? 'slds-icon-' + iconColor : null, className);
return _react2.default.createElement(
'span',
{ className: containerClassName, ref: this.iconContainerRef },
this.renderSVG((0, _extends3.default)({ category: category, icon: icon, fillColor: iconColor, container: container }, pprops))
);
}
return this.renderSVG((0, _extends3.default)({}, props, { category: category, icon: icon }));
}
}]);
return Icon;
}(_react2.default.Component);
exports.default = Icon;
Icon.propTypes = {
className: _propTypes2.default.string,
category: _propTypes2.default.oneOf(['action', 'custom', 'doctype', 'samanage', 'standard', 'utility']),
icon: _propTypes2.default.string,
container: _propTypes2.default.oneOfType([_propTypes2.default.bool, _propTypes2.default.oneOf(['default', 'circle'])]),
color: _propTypes2.default.string,
textColor: _propTypes2.default.oneOf(['default', 'warning', 'error']),
tabIndex: _propTypes2.default.number,
fillColor: _propTypes2.default.string
};
Icon.ICONS = {
STANDARD_ICONS: STANDARD_ICONS,
CUSTOM_ICONS: CUSTOM_ICONS,
ACTION_ICONS: ACTION_ICONS,
DOCTYPE_ICONS: DOCTYPE_ICONS,
UTILITY_ICONS: UTILITY_ICONS
};
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/scripts/Icon.js"],"names":["STANDARD_ICONS","replace","split","CUSTOM_ICONS","Array","join","map","a","i","ACTION_ICONS","DOCTYPE_ICONS","UTILITY_ICONS","Icon","props","state","svgIconRef","bind","iconContainerRef","checkIconColor","svgEl","findDOMNode","svgIcon","setAttribute","tabIndex","fillColor","category","icon","iconColor","test","container","el","iconContainer","getComputedStyle","bgColorStyle","setState","ref","className","size","align","textColor","getIconColor","iconClassNames","useHtml","getAssetRoot","__html","indexOf","pprops","containerClassName","renderSVG","Component","propTypes","string","oneOf","oneOfType","bool","color","number","ICONS"],"mappings":"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","file":"Icon.js","sourcesContent":["import React from 'react';\nimport ReactDOM from 'react-dom';\nimport classnames from 'classnames';\nimport svg4everybody from 'svg4everybody';\nimport util from './util';\nimport PropTypes from 'prop-types';\n\nsvg4everybody();\n\n/* eslint-disable max-len */\nconst STANDARD_ICONS = `\naccount,announcement,answer_best,answer_private,answer_public,approval,apps,apps_admin,\narticle,avatar,avatar_loading,calibration,call,call_history,campaign,campaign_members,\ncanvas,case,case_change_status,case_comment,case_email,case_log_a_call,case_transcript,\nclient,coaching,connected_apps,contact,contract,custom,dashboard,default,document,\ndrafts,email,email_IQ,email_chatter,empty,endorsement,environment_hub,event,feed,feedback,\nfile,flow,folder,generic_loading,goals,group_loading,groups,hierarchy,home,household,insights,investment_account,\nlead,link,log_a_call,marketing_actions,metrics,news,note,opportunity,\norders,people,performance,person_account,photo,poll,portal,post,pricebook,process,product,question_best,\nquestion_feed,quotes,recent,record,related_list,report,reward,scan_card,skill_entity,\nsocial,solution,sossession,task,task2,team_member,thanks,thanks_loading,today,topic,\nunmatched,user,work_order,work_order_item\n`\n.replace(/^\\s+|\\s+$/g, '').split(/[\\s,]+/);\n\nconst CUSTOM_ICONS =\n  new Array(101).join('_').split('')\n    .map((a, i) => `custom${(i + 1)}`);\n\nconst ACTION_ICONS = `\nadd_contact,announcement,apex,approval,back,call,canvas,change_owner,change_record_type,\ncheck,clone,close,defer,delete,description,dial_in,download,edit,edit_groups,edit_relationship,\nemail,fallback,filter,flow,follow,following,freeze_user,goal,google_news,info,join_group,\nlead_convert,leave_group,log_a_call,log_event,manage_perm_sets,map,more,new,new_account,\nnew_campaign,new_case,new_child_case,new_contact,new_event,new_group,new_lead,new_note,\nnew_notebook,new_opportunity,new_person_account,new_task,password_unlock,preview,priority,question_post_action,\nquote,record,refresh,reject,remove,reset_password,share,share_file,share_link,share_poll,\nshare_post,share_thanks,sort,submit_for_approval,update,update_status,upload,user,user_activation,\nweb_link,\nnew_custom7,new_custom8,new_custom9,new_custom10,new_custom11,new_custom12,new_custom13,\nnew_custom14,new_custom15,new_custom16,new_custom17,new_custom18,new_custom19,new_custom20,\nnew_custom21,new_custom22,new_custom23,new_custom24,new_custom25,new_custom26,new_custom27,\nnew_custom28,new_custom29,new_custom30,new_custom31,new_custom32,new_custom33,new_custom34,\nnew_custom35,new_custom36,new_custom37,new_custom38,new_custom39,new_custom40,new_custom41,\nnew_custom42,new_custom43,new_custom44,new_custom45,new_custom46,new_custom47,new_custom48,\nnew_custom49,new_custom50,new_custom51,new_custom52,new_custom53,new_custom54,new_custom55,\nnew_custom56,new_custom57,new_custom58,new_custom59,new_custom60,new_custom61,new_custom62,\nnew_custom63,new_custom64,new_custom65,new_custom66,new_custom67,new_custom68,new_custom69,\nnew_custom70,new_custom71,new_custom72,new_custom73,new_custom74,new_custom75,new_custom76,\nnew_custom77,new_custom78,new_custom79,new_custom80,new_custom81,new_custom82,new_custom83,\nnew_custom84,new_custom85,new_custom86,new_custom87,new_custom88,new_custom89,new_custom90,\nnew_custom91,new_custom92,new_custom93,new_custom94,new_custom95,new_custom96,new_custom97,\nnew_custom98,new_custom99,new_custom100\n`\n.replace(/^\\s+|\\s+$/g, '').split(/[\\s,]+/);\n\n\nconst DOCTYPE_ICONS = `\nai,attachment,audio,box_notes,csv,eps,excel,exe,flash,gdoc,gdocs,gpres,gsheet,html,image,keynote,\nlink,mp4,overlay,pack,pages,pdf,ppt,psd,rtf,slide,stypi,txt,unknown,video,visio,\nwebex,word,xml,zip\n`\n.replace(/^\\s+|\\s+$/g, '').split(/[\\s,]+/);\n\n\nconst UTILITY_ICONS = `\nadd,adduser,announcement,answer,apps,arrowdown,arrowup,attach,back,ban,bold,bookmark,brush,\nbucket,builder,call,capslock,cases,center_align_text,chart,chat,check,checkin,chevrondown,\nchevronleft,chevronright,chevronup,clear,clock,close,comments,company,connected_apps,\ncontract,contract_alt,copy,crossfilter,custom_apps,cut,dash,datadotcom,dayview,delete,deprecate,\ndescription,desktop,down,download,edit,edit_form,email,end_call,erect_window,error,event,expand,\nexpand_alt,favorite,feed,file,filter,filterList,forward,frozen,groups,help,home,identity,image,inbox,info,\ninsert_tag_field,insert_template,italic,justify_text,kanban,knowledge_base,layers,layout,\nleft,left_align_text,like,link,list,location,lock,log_a_call,logout,magicwand,matrix,metrics,minimize_window,\nmoneybag,monthlyview,move,muted,new,new_window,news,note,notebook,notification,office365,offline,\nopen,open_folder,opened_folder,overflow,package,package_org,package_org_beta,page,palette,paste,\npeople,phone_landscape,phone_portrait,photo,picklist,power,preview,priority,process,push,puzzle,\nquestion,questions_and_answers,record,redo,refresh,relate,remove_formatting,remove_link,\nreplace,reply,reset_password,retweet,richtextbulletedlist,richtextindent,richtextnumberedlist,\nrichtextoutdent,right,right_align_text,rotate,rows,salesforce1,search,settings,setup,setup_assistant_guide,\nshare,share_post,shield,side_list,signpost,sms,snippet,socialshare,sort,spinner,standard_objects,\nstop,strikethrough,success,summary,summarydetail,switch,table,tablet_landscape,tablet_portrait,\ntabset,task,text_background_color,text_color,threedots,tile_card_list,topic,touch_action,trail,undelete,undeprecate,\nunderline,undo,unlock,unmuted,up,upload,user,user_role,volume_high,volume_low,volume_off,warning,\nweeklyview,world,zoomin,zoomout\n`\n.replace(/^\\s+|\\s+$/g, '').split(/[\\s,]+/);\n/* eslint-enable max-len */\n\nexport default class Icon extends React.Component {\n  constructor(props) {\n    super(props);\n    this.state = {};\n    this.svgIconRef = this.svgIconRef.bind(this);\n    this.iconContainerRef = this.iconContainerRef.bind(this);\n  }\n\n  componentDidMount() {\n    this.checkIconColor();\n    const svgEl = ReactDOM.findDOMNode(this.svgIcon);\n    svgEl.setAttribute('focusable', this.props.tabIndex >= 0);\n  }\n\n  componentDidUpdate() {\n    this.checkIconColor();\n  }\n\n  getIconColor(fillColor, category, icon) {\n    /* eslint-disable no-unneeded-ternary */\n    return (\n      this.state.iconColor ? this.state.iconColor :\n      category === 'doctype' ? null :\n      fillColor === 'none' ? null :\n      fillColor ? fillColor :\n      category === 'utility' ? null :\n      category === 'custom' ? icon.replace(/^custom/, 'custom-') :\n      category === 'action' && /^new_custom/.test(icon) ? icon.replace(/^new_custom/, 'custom-') :\n      `${category}-${(icon || '').replace(/_/g, '-')}`\n    );\n  }\n\n  checkIconColor() {\n    const { fillColor, category = 'utility', container } = this.props;\n    if (fillColor === 'none' || category === 'doctype' || (!fillColor && category === 'utility')) {\n      return;\n    }\n    const el = ReactDOM.findDOMNode(container ? this.iconContainer : this.svgIcon);\n    if (!(el && getComputedStyle(el))) { return; }\n    const bgColorStyle = getComputedStyle(el)['background-color'];\n    // if no background color set to the icon\n    if (/^(transparent|rgba\\(0,\\s*0,\\s*0,\\s*0\\))$/.test(bgColorStyle)) {\n      this.setState({ iconColor: 'standard-default' });\n    }\n  }\n\n  svgIconRef(ref) {\n    this.svgIcon = ref;\n  }\n\n  iconContainerRef(ref) {\n    this.iconContainer = ref;\n  }\n\n  renderSVG({\n    className, category = 'utility', icon, size, align, fillColor, container,\n    textColor = 'default', ...props,\n  }) {\n    const iconColor = this.getIconColor(fillColor, category, icon);\n    const iconClassNames = classnames(\n      {\n        'slds-icon': !/slds\\-button__icon/.test(className),\n        [`slds-icon--${size}`]: /^(x-small|small|large)$/.test(size),\n        [`slds-icon-text-${textColor}`]: /^(default|warning|error)$/.test(textColor) &&\n          !container && !iconColor,\n        [`slds-icon-${iconColor}`]: !container && iconColor,\n        'slds-m-left--x-small': align === 'right',\n        'slds-m-right--x-small': align === 'left',\n      },\n      className\n    );\n    /* eslint-disable max-len */\n    const useHtml = `<use xlink:href=\"${util.getAssetRoot()}/icons/${category}-sprite/svg/symbols.svg#${icon}\"></use>`;\n    return (\n      <svg\n        className={ iconClassNames }\n        aria-hidden\n        dangerouslySetInnerHTML={ { __html: useHtml } }\n        ref={this.svgIconRef}\n        {...props}\n      />\n    );\n  }\n\n  render() {\n    const { container, ...props } = this.props;\n    let { category, icon } = props;\n\n    if (icon.indexOf(':') > 0) {\n      [category, icon] = icon.split(':');\n    }\n    if (container) {\n      const { className, fillColor, ...pprops } = props;\n      const iconColor = this.getIconColor(fillColor, category, icon);\n      const containerClassName = classnames(\n        'slds-icon__container',\n        container === 'circle' ? 'slds-icon__container--circle' : null,\n        iconColor ? `slds-icon-${iconColor}` : null,\n        className\n      );\n      return (\n        <span className={ containerClassName } ref={this.iconContainerRef}>\n          { this.renderSVG({ category, icon, fillColor: iconColor, container, ...pprops }) }\n        </span>\n      );\n    }\n\n    return this.renderSVG({ ...props, category, icon });\n  }\n}\n\nIcon.propTypes = {\n  className: PropTypes.string,\n  category: PropTypes.oneOf(['action', 'custom', 'doctype', 'samanage', 'standard', 'utility']),\n  icon: PropTypes.string,\n  container: PropTypes.oneOfType([\n    PropTypes.bool,\n    PropTypes.oneOf(['default', 'circle']),\n  ]),\n  color: PropTypes.string,\n  textColor: PropTypes.oneOf(['default', 'warning', 'error']),\n  tabIndex: PropTypes.number,\n  fillColor: PropTypes.string,\n};\n\nIcon.ICONS = {\n  STANDARD_ICONS,\n  CUSTOM_ICONS,\n  ACTION_ICONS,\n  DOCTYPE_ICONS,\n  UTILITY_ICONS,\n};\n"]}