UNPKG

@blueprintjs/core

Version:
68 lines 2.81 kB
/* * Copyright 2017 Palantir Technologies, Inc. All rights reserved. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ import * as tslib_1 from "tslib"; import classNames from "classnames"; import * as React from "react"; import { polyfill } from "react-lifecycles-compat"; import { AbstractPureComponent2, Classes, DISPLAYNAME_PREFIX, Intent, } from "../../common"; import { H4 } from "../html/html"; import { Icon } from "../icon/icon"; var Callout = /** @class */ (function (_super) { tslib_1.__extends(Callout, _super); function Callout() { return _super !== null && _super.apply(this, arguments) || this; } Callout.prototype.render = function () { var _a; var _b = this.props, className = _b.className, children = _b.children, icon = _b.icon, intent = _b.intent, title = _b.title, htmlProps = tslib_1.__rest(_b, ["className", "children", "icon", "intent", "title"]); var iconName = this.getIconName(icon, intent); var classes = classNames(Classes.CALLOUT, Classes.intentClass(intent), (_a = {}, _a[Classes.CALLOUT_ICON] = iconName != null, _a), className); return (React.createElement("div", tslib_1.__assign({ className: classes }, htmlProps), iconName && React.createElement(Icon, { icon: iconName, iconSize: Icon.SIZE_LARGE }), title && React.createElement(H4, null, title), children)); }; Callout.prototype.getIconName = function (icon, intent) { // 1. no icon if (icon === null) { return undefined; } // 2. defined iconName prop if (icon !== undefined) { return icon; } // 3. default intent icon switch (intent) { case Intent.DANGER: return "error"; case Intent.PRIMARY: return "info-sign"; case Intent.WARNING: return "warning-sign"; case Intent.SUCCESS: return "tick"; default: return undefined; } }; Callout.displayName = DISPLAYNAME_PREFIX + ".Callout"; Callout = tslib_1.__decorate([ polyfill ], Callout); return Callout; }(AbstractPureComponent2)); export { Callout }; //# sourceMappingURL=callout.js.map