UNPKG

@blueprintjs/core

Version:
66 lines (64 loc) 12.2 kB
/* * Copyright 2015 Palantir Technologies, Inc. All rights reserved. * Licensed under the BSD-3 License as modified (the “License”); you may obtain a copy * of the license at https://github.com/palantir/blueprint/blob/master/LICENSE * and https://github.com/palantir/blueprint/blob/master/PATENTS */ "use strict"; var __extends = (this && this.__extends) || function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; function __() { this.constructor = d; } d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; var __assign = (this && this.__assign) || Object.assign || function(t) { for (var s, i = 1, n = arguments.length; i < n; i++) { s = arguments[i]; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; } return t; }; var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var classNames = require("classnames"); var PureRender = require("pure-render-decorator"); var React = require("react"); var Classes = require("../../common/classes"); var position_1 = require("../../common/position"); var popover_1 = require("../popover/popover"); var Tooltip = (function (_super) { __extends(Tooltip, _super); function Tooltip() { _super.apply(this, arguments); this.displayName = "Blueprint.Tooltip"; } Tooltip.prototype.render = function () { var _a = this.props, children = _a.children, intent = _a.intent, tooltipClassName = _a.tooltipClassName; var classes = classNames(Classes.TOOLTIP, Classes.intentClass(intent), tooltipClassName); return (React.createElement(popover_1.Popover, __assign({}, this.props, {arrowSize: 22, autoFocus: false, canEscapeKeyClose: false, enforceFocus: false, interactionKind: popover_1.PopoverInteractionKind.HOVER_TARGET_ONLY, lazy: true, popoverClassName: classes, transitionDuration: 200}), children)); }; Tooltip.defaultProps = { className: "", content: "", hoverCloseDelay: 0, hoverOpenDelay: 150, isDisabled: false, position: position_1.Position.TOP, rootElementTag: "span", tooltipClassName: "", transitionDuration: 100, useSmartArrowPositioning: true, useSmartPositioning: false, }; Tooltip = __decorate([ PureRender ], Tooltip); return Tooltip; }(React.Component)); exports.Tooltip = Tooltip; exports.TooltipFactory = React.createFactory(Tooltip); //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/components/tooltip/tooltip.tsx"],"names":[],"mappings":"AAAA;;;;;GAKG;;;;;;;;;;;;;;;;;;;;;AAEH,IAAY,UAAU,WAAM,YAAY,CAAC,CAAA;AACzC,IAAY,UAAU,WAAM,uBAAuB,CAAC,CAAA;AACpD,IAAY,KAAK,WAAM,OAAO,CAAC,CAAA;AAE/B,IAAY,OAAO,WAAM,sBAAsB,CAAC,CAAA;AAChD,yBAAyB,uBAAuB,CAAC,CAAA;AAIjD,wBAAgD,oBAAoB,CAAC,CAAA;AA8GrE;IAA6B,2BAAkC;IAA/D;QAA6B,8BAAkC;QAepD,gBAAW,GAAG,mBAAmB,CAAC;IAsB7C,CAAC;IApBU,wBAAM,GAAb;QACI,IAAA,eAAyD,EAAjD,sBAAQ,EAAE,kBAAM,EAAE,sCAAgB,CAAgB;QAC1D,IAAM,OAAO,GAAG,UAAU,CAAC,OAAO,CAAC,OAAO,EAAE,OAAO,CAAC,WAAW,CAAC,MAAM,CAAC,EAAE,gBAAgB,CAAC,CAAC;QAE3F,MAAM,CAAC,CACH,oBAAC,iBAAO,eACA,IAAI,CAAC,KAAK,GACd,SAAS,EAAE,EAAG,EACd,SAAS,EAAE,KAAM,EACjB,iBAAiB,EAAE,KAAM,EACzB,YAAY,EAAE,KAAM,EACpB,eAAe,EAAE,gCAAsB,CAAC,iBAAkB,EAC1D,IAAI,EAAE,IAAK,EACX,gBAAgB,EAAE,OAAQ,EAC1B,kBAAkB,EAAE,GAAI,IAEvB,QAAS,CACJ,CACb,CAAC;IACN,CAAC;IAnCa,oBAAY,GAAkB;QACxC,SAAS,EAAE,EAAE;QACb,OAAO,EAAE,EAAE;QACX,eAAe,EAAE,CAAC;QAClB,cAAc,EAAE,GAAG;QACnB,UAAU,EAAE,KAAK;QACjB,QAAQ,EAAE,mBAAQ,CAAC,GAAG;QACtB,cAAc,EAAE,MAAM;QACtB,gBAAgB,EAAE,EAAE;QACpB,kBAAkB,EAAE,GAAG;QACvB,wBAAwB,EAAE,IAAI;QAC9B,mBAAmB,EAAE,KAAK;KAC7B,CAAC;IAdN;QAAC,UAAU;eAAA;IAsCX,cAAC;AAAD,CArCA,AAqCC,CArC4B,KAAK,CAAC,SAAS,GAqC3C;AArCY,eAAO,UAqCnB,CAAA;AAEY,sBAAc,GAAG,KAAK,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC","file":"components/tooltip/tooltip.js","sourcesContent":["/*\n * Copyright 2015 Palantir Technologies, Inc. All rights reserved.\n * Licensed under the BSD-3 License as modified (the “License”); you may obtain a copy\n * of the license at https://github.com/palantir/blueprint/blob/master/LICENSE\n * and https://github.com/palantir/blueprint/blob/master/PATENTS\n */\n\nimport * as classNames from \"classnames\";\nimport * as PureRender from \"pure-render-decorator\";\nimport * as React from \"react\";\n\nimport * as Classes from \"../../common/classes\";\nimport { Position } from \"../../common/position\";\nimport { IIntentProps, IProps } from \"../../common/props\";\nimport { ITetherConstraint } from \"../../common/tetherUtils\";\n\nimport { Popover, PopoverInteractionKind } from \"../popover/popover\";\n\nexport interface ITooltipProps extends IProps, IIntentProps {\n    /**\n     * The content that will be displayed inside of the tooltip.\n     */\n    content: JSX.Element | string;\n\n    /**\n     * Constraints for the underlying Tether instance.\n     * @see http://github.hubspot.com/tether/#constraints\n     */\n    constraints?: ITetherConstraint[];\n\n    /**\n     * Whether the tooltip is initially open.\n     * @default false\n     */\n    defaultIsOpen?: boolean;\n\n    /**\n     * The amount of time in milliseconds the tooltip should remain open after the\n     * user hovers off the trigger. The timer is canceled if the user mouses over the\n     * target before it expires.\n     * @default 0\n     */\n    hoverCloseDelay?: number;\n\n    /**\n     * The amount of time in milliseconds the tooltip should wait before opening after the\n     * user hovers over the trigger. The timer is canceled if the user mouses away from the\n     * target before it expires.\n     * @default 150\n     */\n    hoverOpenDelay?: number;\n\n    /**\n     * Whether the tooltip is rendered inline (as a sibling of the target element).\n     * If false, it is attached to a new element appended to <body>.\n     * @default false\n     */\n    inline?: boolean;\n\n    /**\n     * Prevents the tooltip from appearing when `true`.\n     * @default false\n     */\n    isDisabled?: boolean;\n\n    /**\n     * Whether or not the tooltip is visible. Passing this property will put the tooltip in\n     * controlled mode, where the only way to change visibility is by updating this property.\n     * @default undefined\n     */\n    isOpen?: boolean;\n\n    /**\n     * Callback invoked in controlled mode when the tooltip open state *would* change due to\n     * user interaction.\n     */\n    onInteraction?: (nextOpenState: boolean) => void;\n\n    /**\n     * Space-delimited string of class names applied to the\n     * portal which holds the tooltip if `inline = false`.\n     */\n    portalClassName?: string;\n\n    /**\n     * The position (relative to the target) at which the tooltip should appear.\n     * @default Position.TOP\n     */\n    position?: Position;\n\n    /**\n     * The name of the HTML tag to use when rendering the tooltip target wrapper element.\n     * @default \"span\"\n     */\n    rootElementTag?: string;\n\n    /**\n     * A space-delimited string of class names that are applied to the tooltip (but not the target).\n     */\n    tooltipClassName?: string;\n\n    /**\n     * Indicates how long (in milliseconds) the tooltip's appear/disappear transition takes.\n     * This is used by React `CSSTransitionGroup` to know when a transition completes\n     * and must match the duration of the animation in CSS.\n     * Only set this prop if you override Blueprint's default transitions with new transitions of a different length.\n     * @default 100\n     */\n    transitionDuration?: number;\n\n    /**\n     * Whether the arrow's offset should be computed such that it always points at the center\n     * of the target. If false, arrow position is hardcoded via CSS, which expects a 30px target.\n     * @default true\n     */\n    useSmartArrowPositioning?: boolean;\n\n    /**\n     * Whether the tooltip will try to reposition itself\n     * if there isn't room for it in its current position.\n     * @default false\n     */\n    useSmartPositioning?: boolean;\n}\n\n@PureRender\nexport class Tooltip extends React.Component<ITooltipProps, {}> {\n    public static defaultProps: ITooltipProps = {\n        className: \"\",\n        content: \"\",\n        hoverCloseDelay: 0,\n        hoverOpenDelay: 150,\n        isDisabled: false,\n        position: Position.TOP,\n        rootElementTag: \"span\",\n        tooltipClassName: \"\",\n        transitionDuration: 100,\n        useSmartArrowPositioning: true,\n        useSmartPositioning: false,\n    };\n\n    public displayName = \"Blueprint.Tooltip\";\n\n    public render(): JSX.Element {\n        const { children, intent, tooltipClassName } = this.props;\n        const classes = classNames(Classes.TOOLTIP, Classes.intentClass(intent), tooltipClassName);\n\n        return (\n            <Popover\n                {...this.props}\n                arrowSize={22}\n                autoFocus={false}\n                canEscapeKeyClose={false}\n                enforceFocus={false}\n                interactionKind={PopoverInteractionKind.HOVER_TARGET_ONLY}\n                lazy={true}\n                popoverClassName={classes}\n                transitionDuration={200}\n            >\n                {children}\n            </Popover>\n        );\n    }\n}\n\nexport const TooltipFactory = React.createFactory(Tooltip);\n"],"sourceRoot":"/source/"}