apeman-react-icon
Version:
apeman react package for icon components.
291 lines (214 loc) • 22.3 kB
JavaScript
(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){
const React = require('react')
const ReactDOM = require('react-dom')
const Demo = require('./demo.component.js').default
window.addEventListener('load', function onLoad () {
window.React = React
let DemoFactory = React.createFactory(Demo)
ReactDOM.render(DemoFactory(), document.getElementById('demo-wrap'))
})
},{"./demo.component.js":2,"react":"react","react-dom":"react-dom"}],2:[function(require,module,exports){
;Object.defineProperty(exports,'__esModule',{value:true});var _react=require('react');var _react2=_interopRequireDefault(_react);var _ap_icon=require('../../lib/ap_icon');var _ap_icon2=_interopRequireDefault(_ap_icon);var _ap_ion_icon=require('../../lib/ap_ion_icon');var _ap_ion_icon2=_interopRequireDefault(_ap_ion_icon);var _ap_fa_icon=require('../../lib/ap_fa_icon');var _ap_fa_icon2=_interopRequireDefault(_ap_fa_icon);function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}var Demo=_react2.default.createClass({displayName:'Demo',render:function render(){return _react2.default.createElement('div',null,_react2.default.createElement('div',null,_react2.default.createElement(_ap_fa_icon2.default,{type:'money'}),_react2.default.createElement(_ap_fa_icon2.default,{type:'pencil'}),_react2.default.createElement(_ap_fa_icon2.default,{type:'phone'})),_react2.default.createElement('div',null,_react2.default.createElement(_ap_ion_icon2.default,{type:'ios-circle-filled'}),_react2.default.createElement(_ap_ion_icon2.default,{type:'ios-circle-outline'}),_react2.default.createElement(_ap_ion_icon2.default,{type:'ios-checkmark-outline'}),_react2.default.createElement(_ap_ion_icon2.default,{type:'ios-checkmark'})),_react2.default.createElement('div',null,_react2.default.createElement(_ap_icon2.default,{className:'ion an-invalid-style-class'})))}});exports.default=Demo;
},{"../../lib/ap_fa_icon":3,"../../lib/ap_icon":4,"../../lib/ap_ion_icon":5,"react":"react"}],3:[function(require,module,exports){
/**
* Icon for font awesome.
* @class ApFaIcon
*/
;
Object.defineProperty(exports, "__esModule", {
value: true
});
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _classnames = require('classnames');
var _classnames2 = _interopRequireDefault(_classnames);
var _ap_icon = require('./ap_icon');
var _ap_icon2 = _interopRequireDefault(_ap_icon);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/** @lends ApFaIcon */
var ApFaIcon = _react2.default.createClass({
displayName: 'ApFaIcon',
// --------------------
// Specs
// --------------------
propTypes: {
type: _react.PropTypes.string.isRequired
},
mixins: [],
statics: {},
getInitialState: function getInitialState() {
return {};
},
getDefaultProps: function getDefaultProps() {
return {
type: null
};
},
render: function render() {
var s = this;
var props = s.props;
return _react2.default.createElement(_ap_icon2.default, { className: (0, _classnames2.default)('ap-fa-icon', 'fa', props.className, 'fa-' + props.type),
style: Object.assign({}, props.style) });
}
});
exports.default = ApFaIcon;
},{"./ap_icon":4,"classnames":"classnames","react":"react"}],4:[function(require,module,exports){
/**
* apeman react package for icon components.
* @class ApIcon
*/
;
Object.defineProperty(exports, "__esModule", {
value: true
});
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _apemanReactMixins = require('apeman-react-mixins');
var _classnames = require('classnames');
var _classnames2 = _interopRequireDefault(_classnames);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var assertCache = {};
/** @lends ApIcon */
var ApIcon = _react2.default.createClass({
displayName: 'ApIcon',
// --------------------
// Specs
// --------------------
propTypes: {},
mixins: [_apemanReactMixins.ApPureMixin],
statics: {
/**
* Check if has style.
* @param className
*/
hasStyleWithClass: function hasStyleWithClass(className) {
var styleSheets = document.styleSheets || [];
for (var i = 0; i < styleSheets.length; i++) {
var styleSheet = styleSheets[i];
var rules = styleSheet.rules || styleSheet.cssRules || [];
for (var j = 0; j < rules.length; j++) {
var rule = rules[j];
var selectorText = rule.selectorText;
var hit = selectorText && new RegExp('.' + className).test(selectorText);
if (hit) {
return true;
}
}
}
return false;
}
},
getInitialState: function getInitialState() {
return {};
},
getDefaultProps: function getDefaultProps() {
return {};
},
render: function render() {
var s = this;
var props = s.props;
return _react2.default.createElement('i', { className: (0, _classnames2.default)('ap-icon', props.className),
style: Object.assign({}, props.style) });
},
// --------------------
// Lifecycle
// --------------------
componentDidMount: function componentDidMount() {
var s = this;
var props = s.props;
s.assertClassName(props.className);
},
componentWillReceiveProps: function componentWillReceiveProps(nextProps) {
var s = this;
if (nextProps.hasOwnProperty('className')) {
s.assertClassName(nextProps.className);
}
},
componentWillUnmount: function componentWillUnmount() {
var s = this;
clearTimeout(s._assertTimer);
},
// ------------------
// Helper
// ------------------
assertClassName: function assertClassName(className) {
if (!className) {
return;
}
var s = this;
clearTimeout(s._assertTimer);
s._assertTimer = setTimeout(function () {
var isMounted = s.isMounted();
if (!isMounted) {
return;
}
className.split(/\s/g).forEach(function (className) {
if (!className) {
return;
}
if (assertCache.hasOwnProperty(className)) {
return;
}
if (/^ap/.test(className)) {
return;
}
var valid = ApIcon.hasStyleWithClass(className);
if (!valid) {
console.warn('[ApIcon] No style found for class "' + className + '". You may misspell the name or miss some stylesheets.');
}
assertCache[className] = valid;
});
}, 100);
},
// ------------------
// Private
// ------------------
_assertTimer: -1
});
exports.default = ApIcon;
},{"apeman-react-mixins":"apeman-react-mixins","classnames":"classnames","react":"react"}],5:[function(require,module,exports){
/**
* Icon for font awesome.
* @class ApIonIcon
*/
;
Object.defineProperty(exports, "__esModule", {
value: true
});
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _classnames = require('classnames');
var _classnames2 = _interopRequireDefault(_classnames);
var _ap_icon = require('./ap_icon');
var _ap_icon2 = _interopRequireDefault(_ap_icon);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/** @lends ApIonIcon */
var ApIonIcon = _react2.default.createClass({
displayName: 'ApIonIcon',
// --------------------
// Specs
// --------------------
propTypes: {
type: _react.PropTypes.string.isRequired
},
mixins: [],
statics: {},
getInitialState: function getInitialState() {
return {};
},
getDefaultProps: function getDefaultProps() {
return {
type: null
};
},
render: function render() {
var s = this;
var props = s.props;
return _react2.default.createElement(_ap_icon2.default, { className: (0, _classnames2.default)('ap-ion-icon', 'ion', props.className, 'ion-' + props.type),
style: Object.assign({}, props.style) });
}
});
exports.default = ApIonIcon;
},{"./ap_icon":4,"classnames":"classnames","react":"react"}]},{},[1])
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../.nvm/versions/node/v6.0.0/lib/node_modules/browserify/node_modules/browser-pack/_prelude.js","doc/demo/demo.browser.js","/Users/okunishinishi/Projects/apeman-projects/apeman-react-icon/doc/demo/demo.component.jsx","/Users/okunishinishi/Projects/apeman-projects/apeman-react-icon/lib/ap_fa_icon.jsx","/Users/okunishinishi/Projects/apeman-projects/apeman-react-icon/lib/ap_icon.jsx","/Users/okunishinishi/Projects/apeman-projects/apeman-react-icon/lib/ap_ion_icon.jsx"],"names":[],"mappings":"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","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","'use strict'\n\nconst React = require('react')\nconst ReactDOM = require('react-dom')\n\nconst Demo = require('./demo.component.js').default\n\nwindow.addEventListener('load', function onLoad () {\n  window.React = React\n  let DemoFactory = React.createFactory(Demo)\n  ReactDOM.render(DemoFactory(), document.getElementById('demo-wrap'))\n})\n","'use strict'\n\nimport React from 'react'\nimport ApIcon from '../../lib/ap_icon'\nimport ApIonIcon from '../../lib/ap_ion_icon'\nimport ApFaIcon from '../../lib/ap_fa_icon'\n\nconst Demo = React.createClass({\n  render () {\n    return (\n      <div>\n        <div>\n          <ApFaIcon type=\"money\"/>\n          <ApFaIcon type=\"pencil\"/>\n          <ApFaIcon type=\"phone\"/>\n        </div>\n        <div>\n          <ApIonIcon type=\"ios-circle-filled\"/>\n          <ApIonIcon type=\"ios-circle-outline\"/>\n          <ApIonIcon type=\"ios-checkmark-outline\"/>\n          <ApIonIcon type=\"ios-checkmark\"/>\n        </div>\n        <div>\n          <ApIcon className=\"ion an-invalid-style-class\"/>\n        </div>\n      </div>\n    )\n  }\n})\n\nexport default Demo\n","/**\n * Icon for font awesome.\n * @class ApFaIcon\n */\n\n'use strict'\n\nimport React, {PropTypes as types} from 'react'\nimport classnames from 'classnames'\n\nimport ApIcon from './ap_icon'\n\n/** @lends ApFaIcon */\nconst ApFaIcon = React.createClass({\n\n  // --------------------\n  // Specs\n  // --------------------\n\n  propTypes: {\n    type: types.string.isRequired\n  },\n\n  mixins: [],\n\n  statics: {},\n\n  getInitialState () {\n    return {}\n  },\n\n  getDefaultProps () {\n    return {\n      type: null\n    }\n  },\n\n  render () {\n    const s = this\n    let { props } = s\n\n    return (\n      <ApIcon className={ classnames('ap-fa-icon', 'fa', props.className,\n             `fa-${props.type}`) }\n              style={ Object.assign({}, props.style) }>\n      </ApIcon>\n    )\n  }\n})\n\nexport default ApFaIcon\n","/**\n * apeman react package for icon components.\n * @class ApIcon\n */\n\n'use strict'\n\nimport React, {PropTypes as types} from 'react'\nimport {ApPureMixin} from 'apeman-react-mixins'\nimport classnames from 'classnames'\n\nlet assertCache = {}\n\n/** @lends ApIcon */\nconst ApIcon = React.createClass({\n\n  // --------------------\n  // Specs\n  // --------------------\n\n  propTypes: {},\n\n  mixins: [\n    ApPureMixin\n  ],\n\n  statics: {\n    /**\n     * Check if has style.\n     * @param className\n     */\n    hasStyleWithClass (className) {\n      let styleSheets = document.styleSheets || []\n      for (let i = 0; i < styleSheets.length; i++) {\n        let styleSheet = styleSheets[ i ]\n        let rules = styleSheet.rules || styleSheet.cssRules || []\n        for (let j = 0; j < rules.length; j++) {\n          let rule = rules[ j ]\n          let selectorText = rule.selectorText\n          let hit = selectorText && new RegExp(`\\.${className}`).test(selectorText)\n          if (hit) {\n            return true\n          }\n        }\n      }\n      return false\n    }\n  },\n\n  getInitialState () {\n    return {}\n  },\n\n  getDefaultProps () {\n    return {}\n  },\n\n  render () {\n    const s = this\n    let { props } = s\n\n    return (\n      <i className={ classnames('ap-icon', props.className) }\n         style={Object.assign({}, props.style)}>\n      </i>\n    )\n  },\n\n  // --------------------\n  // Lifecycle\n  // --------------------\n\n  componentDidMount () {\n    const s = this\n    let { props } = s\n    s.assertClassName(props.className)\n  },\n\n  componentWillReceiveProps (nextProps) {\n    const s = this\n    if (nextProps.hasOwnProperty('className')) {\n      s.assertClassName(nextProps.className)\n    }\n  },\n\n  componentWillUnmount () {\n    const s = this\n    clearTimeout(s._assertTimer)\n  },\n\n  // ------------------\n  // Helper\n  // ------------------\n\n  assertClassName (className) {\n    if (!className) {\n      return\n    }\n    const s = this\n    clearTimeout(s._assertTimer)\n    s._assertTimer = setTimeout(() => {\n      let isMounted = s.isMounted()\n      if (!isMounted) {\n        return\n      }\n      className.split(/\\s/g).forEach((className) => {\n        if (!className) {\n          return\n        }\n        if (assertCache.hasOwnProperty(className)) {\n          return\n        }\n        if (/^ap/.test(className)) {\n          return\n        }\n        let valid = ApIcon.hasStyleWithClass(className)\n        if (!valid) {\n          console.warn(`[ApIcon] No style found for class \"${className}\". You may misspell the name or miss some stylesheets.`)\n        }\n        assertCache[ className ] = valid\n      })\n    }, 100)\n  },\n\n  // ------------------\n  // Private\n  // ------------------\n\n  _assertTimer: -1\n})\n\nexport default ApIcon\n","/**\n * Icon for font awesome.\n * @class ApIonIcon\n */\n\n'use strict'\n\nimport React, {PropTypes as types} from 'react'\nimport classnames from 'classnames'\nimport ApIcon from './ap_icon'\n\n/** @lends ApIonIcon */\nconst ApIonIcon = React.createClass({\n\n  // --------------------\n  // Specs\n  // --------------------\n\n  propTypes: {\n    type: types.string.isRequired\n  },\n\n  mixins: [],\n\n  statics: {},\n\n  getInitialState () {\n    return {}\n  },\n\n  getDefaultProps () {\n    return {\n      type: null\n    }\n  },\n\n  render () {\n    const s = this\n    let { props } = s\n\n    return (\n      <ApIcon className={ classnames('ap-ion-icon', 'ion', props.className,\n             `ion-${props.type}`) }\n              style={ Object.assign({}, props.style) }>\n      </ApIcon>\n    )\n  }\n})\n\nexport default ApIonIcon\n"]}