@blueprintjs/core
Version:
Core styles & components
108 lines (106 loc) • 15 kB
JavaScript
/*
* Copyright 2016 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
*/
;
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 utils_1 = require("../../common/utils");
var buttons_1 = require("../button/buttons");
var Toast = (function (_super) {
__extends(Toast, _super);
function Toast() {
var _this = this;
_super.apply(this, arguments);
this.displayName = "Blueprint.Toast";
this.handleActionClick = function (e) {
utils_1.safeInvoke(_this.props.action.onClick, e);
_this.triggerDismiss(false);
};
this.handleCloseClick = function () { return _this.triggerDismiss(false); };
this.startTimeout = function () {
if (_this.props.timeout > 0) {
_this.timeoutId = setTimeout(function () { return _this.triggerDismiss(true); }, _this.props.timeout);
}
};
this.clearTimeout = function () {
clearTimeout(_this.timeoutId);
_this.timeoutId = null;
};
}
Toast.prototype.render = function () {
var _a = this.props, className = _a.className, intent = _a.intent, message = _a.message;
return (React.createElement("div", {className: classNames(Classes.TOAST, Classes.intentClass(intent), className), onBlur: this.startTimeout, onFocus: this.clearTimeout, onMouseEnter: this.clearTimeout, onMouseLeave: this.startTimeout},
this.maybeRenderIcon(),
React.createElement("span", {className: Classes.TOAST_MESSAGE}, message),
React.createElement("div", {className: classNames(Classes.BUTTON_GROUP, Classes.MINIMAL)},
this.maybeRenderActionButton(),
React.createElement(buttons_1.Button, {iconName: "cross", onClick: this.handleCloseClick}))));
};
Toast.prototype.componentDidMount = function () {
this.startTimeout();
};
Toast.prototype.componentDidUpdate = function (prevProps) {
if (prevProps.timeout <= 0 && this.props.timeout > 0) {
this.startTimeout();
}
else if (prevProps.timeout > 0 && this.props.timeout <= 0) {
this.clearTimeout();
}
};
Toast.prototype.componentWillUnmount = function () {
this.clearTimeout();
};
Toast.prototype.maybeRenderActionButton = function () {
var action = this.props.action;
return action == null ? undefined : React.createElement(buttons_1.Button, __assign({}, action, {intent: null, onClick: this.handleActionClick}));
};
Toast.prototype.maybeRenderIcon = function () {
var iconName = this.props.iconName;
if (iconName == null) {
return undefined;
}
else {
return React.createElement("span", {className: classNames(Classes.ICON_STANDARD, Classes.iconClass(iconName))});
}
};
Toast.prototype.triggerDismiss = function (didTimeoutExpire) {
utils_1.safeInvoke(this.props.onDismiss, didTimeoutExpire);
this.clearTimeout();
};
Toast.defaultProps = {
className: "",
message: "",
timeout: 5000,
};
Toast = __decorate([
PureRender
], Toast);
return Toast;
}(React.Component));
exports.Toast = Toast;
exports.ToastFactory = React.createFactory(Toast);
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/components/toast/toast.tsx"],"names":[],"mappings":"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","file":"components/toast/toast.js","sourcesContent":["/*\n * Copyright 2016 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 { IActionProps, IIntentProps, IProps } from \"../../common/props\";\nimport { safeInvoke } from \"../../common/utils\";\nimport { Button } from \"../button/buttons\";\n\nexport interface IToastProps extends IProps, IIntentProps {\n    /**\n     * Action to display in a minimal button. The toast is dismissed automatically when the\n     * user clicks the action button. Note that the `intent` prop is ignored (the action button\n     * cannot have its own intent color that might conflict with the toast's intent). Omit this\n     * prop to omit the action button.\n     */\n    action?: IActionProps;\n\n    /** Name of icon to appear before message. Specify only the part of the name after `pt-icon-`. */\n    iconName?: string;\n\n    /** Message to display in the body of the toast. */\n    message: string | JSX.Element;\n\n    /**\n     * Callback invoked when the toast is dismissed, either by the user or by the timeout.\n     * The value of the argument indicates whether the toast was closed because the timeout expired.\n     */\n    onDismiss?: (didTimeoutExpire: boolean) => void;\n\n    /**\n     * Milliseconds to wait before automatically dismissing toast.\n     * Providing a value <= 0 will disable the timeout (this is discouraged).\n     * @default 5000\n     */\n    timeout?: number;\n}\n\n@PureRender\nexport class Toast extends React.Component<IToastProps, {}> {\n    public static defaultProps: IToastProps = {\n        className: \"\",\n        message: \"\",\n        timeout: 5000,\n    };\n\n    public displayName = \"Blueprint.Toast\";\n\n    private timeoutId: number;\n\n    public render(): JSX.Element {\n        const { className, intent, message } = this.props;\n        return (\n            <div\n                className={classNames(Classes.TOAST, Classes.intentClass(intent), className)}\n                onBlur={this.startTimeout}\n                onFocus={this.clearTimeout}\n                onMouseEnter={this.clearTimeout}\n                onMouseLeave={this.startTimeout}\n            >\n                {this.maybeRenderIcon()}\n                <span className={Classes.TOAST_MESSAGE}>{message}</span>\n                <div className={classNames(Classes.BUTTON_GROUP, Classes.MINIMAL)}>\n                    {this.maybeRenderActionButton()}\n                    <Button iconName=\"cross\" onClick={this.handleCloseClick} />\n                </div>\n            </div>\n        );\n    }\n\n    public componentDidMount() {\n        this.startTimeout();\n    }\n\n    public componentDidUpdate(prevProps: IToastProps) {\n        if (prevProps.timeout <= 0 && this.props.timeout > 0) {\n            this.startTimeout();\n        } else if (prevProps.timeout > 0 && this.props.timeout <= 0) {\n            this.clearTimeout();\n        }\n    }\n\n    public componentWillUnmount() {\n        this.clearTimeout();\n    }\n\n    private maybeRenderActionButton() {\n        const { action } = this.props;\n        return action == null ? undefined : <Button {...action} intent={null} onClick={this.handleActionClick} />;\n    }\n\n    private maybeRenderIcon() {\n        const { iconName } = this.props;\n        if (iconName == null) {\n            return undefined;\n        } else {\n            return <span className={classNames(Classes.ICON_STANDARD, Classes.iconClass(iconName))} />;\n        }\n    }\n\n    private handleActionClick = (e: React.MouseEvent<HTMLButtonElement>) => {\n        safeInvoke(this.props.action.onClick, e);\n        this.triggerDismiss(false);\n    }\n\n    private handleCloseClick = () => this.triggerDismiss(false);\n\n    private triggerDismiss(didTimeoutExpire: boolean) {\n        safeInvoke(this.props.onDismiss, didTimeoutExpire);\n        this.clearTimeout();\n    }\n\n    private startTimeout = () => {\n        if (this.props.timeout > 0) {\n            this.timeoutId = setTimeout(() => this.triggerDismiss(true), this.props.timeout);\n        }\n    }\n\n    private clearTimeout = () => {\n        clearTimeout(this.timeoutId);\n        this.timeoutId = null;\n    }\n}\n\nexport const ToastFactory = React.createFactory(Toast);\n"],"sourceRoot":"/source/"}