KAdefine("third_party/javascript-khansrc/react-components/js/info-tip.jsx", function(require, module, exports) {
var React=require("react")
var RCSS=require("rcss")
var _=require("underscore")
var colors={grayLight:"#aaa",basicBorderColor:"#ccc",white:"#fff"}
var infoTip={display:"inline-block",marginLeft:"5px",position:"relative"}
var infoTipI={cursor:"pointer"}
var infoTipContainer={position:"absolute",top:"-12px",left:"22px",zIndex:"1000"}
var triangleBeforeAfter={borderBottom:"9px solid transparent",borderTop:"9px solid transparent",content:" ",height:"0",position:"absolute",top:"0",width:"0"}
var infoTipTriangle={height:"10px",left:"0",position:"absolute",top:"8px",width:"0",zIndex:"1",":before":_.extend({},triangleBeforeAfter,{borderRight:"9px solid #bbb",right:"0"}),":after":_.extend({},triangleBeforeAfter,{borderRight:"9px solid "+colors.white,right:"-1px"})}
var basicBorder={border:"1px solid "+colors.basicBorderColor}
var boxShadow=function(e){return{boxShadow:e}}
var verticalShadow=RCSS.merge(basicBorder,boxShadow("0 1px 3px "+colors.basicBorderColor),{borderBottom:"1px solid "+colors.grayLight})
var infoTipContentContainer=RCSS.merge(verticalShadow,{background:colors.white,padding:"5px 10px",width:"240px"})
RCSS.createClass(infoTip)
RCSS.createClass(infoTipI)
RCSS.createClass(infoTipTriangle)
RCSS.createClass(verticalShadow)
RCSS.createClass(infoTipContainer)
RCSS.createClass(infoTipContentContainer)
var questionMark=""
var InfoTip=React.createClass({displayName:"InfoTip",getInitialState:function(){return{hover:false}},render:function(){return React.createElement("div",{className:infoTip.className},React.createElement("img",{width:10,height:10,src:questionMark,onMouseEnter:this.handleMouseEnter,onMouseLeave:this.handleMouseLeave}),React.createElement("div",{className:infoTipContainer.className,style:{display:this.state.hover?"block":"none"}},React.createElement("div",{className:infoTipTriangle.className}),React.createElement("div",{className:infoTipContentContainer.className},this.props.children)))},handleMouseEnter:function(){this.setState({hover:true})},handleMouseLeave:function(){this.setState({hover:false})}})
module.exports=InfoTip
});
Example #2
0
var RCSS = require('rcss');

var style = {
  display: 'inline-block',
  color: 'red',
  padding: '6px 12px',
};

module.exports = RCSS.createClass(style);
Example #3
0
var React = require('react');
var RCSS = require('rcss');
var _ = require('underscore');
var styles = require('./styles.js');

var buttonStyle = styles.button.buttonStyle;
var selectedStyle = styles.button.selectedStyle;

RCSS.createClass(buttonStyle);
RCSS.createClass(selectedStyle);

/* ButtonGroup is an aesthetically pleasing group of buttons.
 *
 * The class requires these properties:
 *   buttons - an array of objects with keys:
 *     "value": this is the value returned when the button is selected
 *     "content": this is the JSX shown within the button, typically a string
 *         that gets rendered as the button's display text
 *     "title": this is the title-text shown on hover
 *   onChange - a function that is provided with the updated value
 *     (which it then is responsible for updating)
 *
 * The class has these optional properties:
 *   value - the initial value of the button selected, defaults to null.
 *   allowEmpty - if false, exactly one button _must_ be selected; otherwise
 *     it defaults to true and _at most_ one button (0 or 1) may be selected.
 *
 * Requires stylesheets/perseus-admin-package/editor.less to look nice.
 */

var ButtonGroup = React.createClass({displayName: 'ButtonGroup',