aui
Version:
Aui is Semantic-UI + React
188 lines (166 loc) • 20 kB
JavaScript
(function() {
var Aui, AuiMixin, AuiOptions, React, cache, jQuery, ref1, ref2, ref3, ref4, ref5,
hasProp = {}.hasOwnProperty,
indexOf = [].indexOf || function(item) { for (var i = 0, l = this.length; i < l; i++) { if (i in this && this[i] === item) return i; } return -1; };
ref1 = window || global, React = ref1.React, jQuery = ref1.jQuery;
if (React == null) {
throw new Error("Aui: window.React not found.");
}
if (jQuery == null) {
console.warn("Aui: window.jQuery not found, Modules and Semantic-UI will be disabled.");
}
if ((jQuery != null ? (ref2 = jQuery.site) != null ? (ref3 = ref2.settings) != null ? ref3.modules : void 0 : void 0 : void 0) == null) {
console.warn('Aui: No Semantic-UI window.jQuery.site.settings.modules found, Semantic will be disabled.');
}
AuiMixin = {
$: function(ref) {
return jQuery(React.findDOMNode(this.refs[ref] || ref));
},
componentWillMount: function() {
var render;
render = this.render;
return this.render = function() {
var element;
element = render != null ? typeof render.apply === "function" ? render.apply(this, arguments) : void 0 : void 0;
if (React.isValidElement(element)) {
return Aui.classify(element);
} else {
return Aui.classify(Aui.warning('Aui.Mixin: Child is not a React.isValidElement', element));
}
};
}
};
Aui = React.createClass({
mixins: [AuiMixin],
render: function() {
return Aui.warning('<Aui/> tag is depricated, use Aui.Mixin instead', this.props.children);
},
componentDidMount: function() {
return console.warn(React.findDOMNode(this));
}
});
Aui.Mixin = Aui.AuiMixin = AuiMixin;
Aui.Aui = Aui;
Aui.$ = jQuery;
Aui.classify = function(element, options) {
var classify;
options = AuiOptions(options);
if (!React.isValidElement(element)) {
element = Aui.warning('Aui.classify: element is not a React.isValidElement', element);
}
classify = function(element) {
var className, classNames, i, key, len, modules, props, ref4, ref5, value;
if (!React.isValidElement(element)) {
return element;
}
classNames = {};
modules = null;
props = {};
if (element.props.className != null) {
ref4 = ("" + element.props.className).split(/\s+/g);
for (i = 0, len = ref4.length; i < len; i++) {
className = ref4[i];
classNames[className] = true;
}
}
ref5 = element.props;
for (key in ref5) {
if (!hasProp.call(ref5, key)) continue;
value = ref5[key];
if (value === true) {
classNames[key] = true;
}
if ((!options.disableModules) && (Array.isArray(value)) && (indexOf.call(Aui.modules, key) >= 0)) {
classNames[key] = true;
modules || (modules = {});
modules[key] = value;
}
props[key] = value;
}
props.className = Object.keys(classNames).join(' ');
if (!props.className.length) {
delete props.className;
}
element = React.cloneElement(element, props, options.ignoreChildren ? element.props.children : React.Children.map(element.props.children, classify));
if (modules) {
return React.createElement(Aui.Module, {
modules: modules,
options: options
}, element);
} else {
return element;
}
};
return classify(element);
};
Aui.warning = function(message, element) {
console.warn(message, element);
return React.DOM.span({
'data-warning': message
}, element);
};
Aui.settings = {
disableModules: jQuery == null,
ignoreChildren: false
};
AuiOptions = (function() {
function AuiOptions(options) {
var key, ref4, value;
if (options instanceof AuiOptions) {
return options;
}
if (!(this instanceof AuiOptions)) {
return new AuiOptions(options);
}
options || (options = {});
ref4 = Aui.settings;
for (key in ref4) {
if (!hasProp.call(ref4, key)) continue;
value = ref4[key];
this[key] = options[key] != null ? options[key] : value;
}
}
return AuiOptions;
})();
Aui.modules = ((jQuery != null ? (ref4 = jQuery.site) != null ? (ref5 = ref4.settings) != null ? ref5.modules : void 0 : void 0 : void 0) || []).slice();
cache = {};
Aui.Module = React.createClass({
render: function() {
return React.Children.only(this.props.children);
},
componentDidMount: function() {
return this.callModules(this.props.children.props);
},
componentWillReceiveProps: function(props) {
return this.callModules(props.children.props);
},
callModules: function(props) {
var $element, module, name, options, ref6, stringifiedOptions;
$element = jQuery(React.findDOMNode(this));
this.id = $element.attr('data-reactid');
cache[name = this.id] || (cache[name] = {});
ref6 = this.props.modules;
for (module in ref6) {
if (!hasProp.call(ref6, module)) continue;
options = ref6[module];
stringifiedOptions = JSON.stringify(options);
if (cache[this.id][module] !== stringifiedOptions) {
cache[this.id][module] = stringifiedOptions;
if (typeof $element[module] === "function") {
$element[module].apply($element, this.props.children.props[module]);
}
}
}
},
componentWillUnmount: function() {
return delete cache[this.id];
}
});
if (typeof window !== "undefined" && window !== null) {
window.Aui = Aui;
}
if (typeof module !== "undefined" && module !== null) {
module.exports = Aui;
}
}).call(this);
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["aui.coffee"],"names":[],"mappings":"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","file":"aui.js","sourceRoot":"/source/","sourcesContent":["{React, jQuery} = window or global\r\nunless React? then throw new Error \"Aui: window.React not found.\"\r\nunless jQuery? then console.warn \"Aui: window.jQuery not found, Modules and Semantic-UI will be disabled.\"\r\nunless jQuery?.site?.settings?.modules? then console.warn 'Aui: No Semantic-UI window.jQuery.site.settings.modules found, Semantic will be disabled.'\r\n\r\n## Aui.Mixin\r\n# [JSFiddle around with the examples here!](http://javascriptismagic.github.io/aui/)\r\n# Aui.Mixin is the main wrapper around React Components\r\n# it recursively goes through all it's children,\r\n# finding props that === true or are on the `Aui.modules` list,\r\n# and merges them into the className of each element.\r\nAuiMixin =\r\n  ## this.$('react ref')\r\n  # jQuery wraps a React ref `<div ref=\"react ref\" />` or jQuery selector `this.$('react ref')`.\r\n  # This is the intended way to interact with jQuery to supply utility functionality.\r\n  # **Warning!** Use this only in `componentDidMount` or event handlers!\r\n  # Do NOT use jQuery to re-arange the dom or you will run into Invarient erros in React,\r\n  # use React to arange your dom ahead of time as React is expecting.\r\n  $: (ref) -> jQuery React.findDOMNode @refs[ref] or ref\r\n  componentWillMount: ->\r\n    render = @render\r\n    @render = ->\r\n      element = render?.apply? @, arguments\r\n      if React.isValidElement element\r\n        Aui.classify element\r\n      else\r\n        Aui.classify Aui.warning 'Aui.Mixin: Child is not a React.isValidElement', element\r\n\r\n# (depricated) `<Aui/>` tag, use Aui.Mixin instead.\r\nAui = React.createClass\r\n  mixins: [AuiMixin]\r\n  render: ->\r\n    Aui.warning '<Aui/> tag is depricated, use Aui.Mixin instead', @props.children\r\n  componentDidMount: ->\r\n    console.warn React.findDOMNode @\r\nAui.Mixin = Aui.AuiMixin = AuiMixin\r\nAui.Aui = Aui\r\n## Aui.$\r\n# The instance of jQuery Aui is using, if needed.\r\nAui.$ = jQuery\r\n\r\n## Aui.classify(element)\r\n# finds all the props that === true or are on the `Aui.modules` list,\r\n# and merging them with the className prop.\r\n# Use this inside the render function like a React helper function.\r\n# Example: `Aui.classify(<div ui grid><div column>content</div></div>)`\r\n# returns `<div ui grid className=\"ui grid\"><div column className=\"column\">content</div></div>`\r\nAui.classify = (element, options) ->\r\n  options = AuiOptions options\r\n  unless React.isValidElement element\r\n    element = Aui.warning 'Aui.classify: element is not a React.isValidElement', element\r\n  classify = (element) ->\r\n    return element unless React.isValidElement element\r\n    classNames = {}\r\n    modules = null\r\n    props = {}\r\n    if element.props.className?\r\n      for className in \"#{element.props.className}\".split /\\s+/g\r\n        classNames[className] = yes\r\n    for own key, value of element.props\r\n      classNames[key] = yes if value is yes\r\n      if (not options.disableModules) and (Array.isArray value) and (key in Aui.modules)\r\n        classNames[key] = yes\r\n        modules or= {}\r\n        modules[key] = value\r\n      props[key] = value\r\n    props.className = Object.keys(classNames).join ' '\r\n    unless props.className.length\r\n      delete props.className\r\n    element = React.cloneElement element, props, if options.ignoreChildren then element.props.children else React.Children.map element.props.children, classify\r\n    if modules\r\n      React.createElement Aui.Module, { modules, options }, element\r\n    else element\r\n  classify element\r\n\r\n## Aui.warning('string', element)\r\n# console.warn a warning message inside a ReactElement durring a React Component's render function.\r\n# returns the element wrapped in a warning span.\r\n# Use inside the render function of a React Component\r\nAui.warning = (message, element) ->\r\n  console.warn message, element\r\n  React.DOM.span { 'data-warning': message }, element\r\n\r\nAui.settings =\r\n  ## Aui.settings.disableModules\r\n  # disables jQuery based Aui.modules from calling\r\n  disableModules: not jQuery?\r\n  ## Aui.settings.ignoreChildren\r\n  # disables recursively calling `Aui.classify` to `props.children`.\r\n  ignoreChildren: no\r\n\r\n# (internal) AuiOptions defaults options for `Aui.classify`\r\nclass AuiOptions\r\n  constructor: (options) ->\r\n    if options instanceof AuiOptions\r\n      return options\r\n    unless @ instanceof AuiOptions\r\n      return new AuiOptions options\r\n    options or= {}\r\n    for own key, value of Aui.settings\r\n      @[key] = if options[key]? then options[key] else value\r\n\r\n## Aui.modules\r\n# A whitelist of jQuery modules.\r\n# `Aui.modules.push('widget')` to configure Aui to support `$.fn.widget`.\r\n# By default this includes `window.jQuery.site.settings.modules` from Semantic-UI.\r\n# When a property is encountered on a ReactElement that matches this whitelist and is an Array,\r\n# the corisponding `window.jQuery.fn[modulename]` will be called with the property's array value.\r\n# This is mostly intended for use with Semantic-UI's javascript,\r\n# but in theory could be used to call any `$.fn` function.\r\nAui.modules = (jQuery?.site?.settings?.modules or []).slice()\r\n\r\n# internal global cache of options passed to module functions.\r\ncache = {}\r\n\r\n# (internal) `<Aui.Module/>`\r\n# This class provides support for `Aui.modules` internally and generally is not used directly.\r\n# `<Aui.Module/>` handles calling jQuery.fn[module] calls when used inside a React Component's render.\r\n# `<div ui checkbox={[]}/>` will automatically call `$.fn.checkbox()`, and\r\n# `<form ui form={[{...}]}></form>` will automatically call `$.fn.form({...})`\r\nAui.Module = React.createClass\r\n  render: -> React.Children.only @props.children\r\n  componentDidMount: ->\r\n    @callModules @props.children.props\r\n  componentWillReceiveProps: (props) ->\r\n    @callModules props.children.props\r\n  callModules: (props) ->\r\n    $element = jQuery React.findDOMNode @\r\n    @id = $element.attr 'data-reactid'\r\n    cache[@id] or= {}\r\n    for own module, options of @props.modules\r\n      stringifiedOptions = JSON.stringify options\r\n      if cache[@id][module] isnt stringifiedOptions\r\n        cache[@id][module] = stringifiedOptions\r\n        $element[module]? @props.children.props[module]...\r\n    return\r\n  componentWillUnmount: ->\r\n    delete cache[@id]\r\n\r\nwindow?.Aui = Aui\r\nmodule?.exports = Aui\r\n"]}