UNPKG

@blueprintjs/core

Version:
84 lines (82 loc) 12.3 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 classNames = require("classnames"); var React = require("react"); var abstractComponent_1 = require("../../common/abstractComponent"); var Classes = require("../../common/classes"); var Errors = require("../../common/errors"); var overlay_1 = require("../overlay/overlay"); var Dialog = (function (_super) { __extends(Dialog, _super); function Dialog() { _super.apply(this, arguments); this.displayName = "Blueprint.Dialog"; } Dialog.prototype.render = function () { return (React.createElement(overlay_1.Overlay, __assign({}, this.props, {className: classNames((_a = {}, _a[Classes.OVERLAY_SCROLL_CONTAINER] = !this.props.inline, _a)), hasBackdrop: true}), React.createElement("div", {className: classNames(Classes.DIALOG, this.props.className), style: this.props.style}, this.maybeRenderHeader(), this.props.children) )); var _a; }; Dialog.prototype.validateProps = function (props) { if (props.title == null) { if (props.iconName != null) { console.error(Errors.WARNING_DIALOG_NO_HEADER_ICON); } if (props.isCloseButtonShown != null) { console.error(Errors.WARNING_DIALOG_NO_HEADER_CLOSE_BUTTON); } } }; Dialog.prototype.maybeRenderCloseButton = function () { // for now, show close button if prop is undefined or null // this gives us a behavior as if the default value were `true` if (this.props.isCloseButtonShown !== false) { var classes = classNames(Classes.DIALOG_CLOSE_BUTTON, Classes.iconClass("small-cross")); return React.createElement("button", {"aria-label": "Close", className: classes, onClick: this.props.onClose}); } else { return undefined; } }; Dialog.prototype.maybeRenderHeader = function () { if (this.props.title == null) { return undefined; } var maybeIcon; if (this.props.iconName != null) { maybeIcon = React.createElement("span", {className: classNames(Classes.ICON_LARGE, Classes.iconClass(this.props.iconName))}); } return (React.createElement("div", {className: Classes.DIALOG_HEADER}, maybeIcon, React.createElement("h5", null, this.props.title), this.maybeRenderCloseButton())); }; Dialog.defaultProps = { isOpen: false, }; return Dialog; }(abstractComponent_1.AbstractComponent)); exports.Dialog = Dialog; exports.DialogFactory = React.createFactory(Dialog); //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/components/dialog/dialog.tsx"],"names":[],"mappings":"AAAA;;;;;GAKG;;;;;;;;;;;;;;;AAEH,IAAY,UAAU,WAAM,YAAY,CAAC,CAAA;AACzC,IAAY,KAAK,WAAM,OAAO,CAAC,CAAA;AAE/B,kCAAkC,gCAAgC,CAAC,CAAA;AACnE,IAAY,OAAO,WAAM,sBAAsB,CAAC,CAAA;AAChD,IAAY,MAAM,WAAM,qBAAqB,CAAC,CAAA;AAE9C,wBAA2D,oBAAoB,CAAC,CAAA;AA2ChF;IAA4B,0BAAmC;IAA/D;QAA4B,8BAAmC;QAKpD,gBAAW,GAAG,kBAAkB,CAAC;IAwD5C,CAAC;IAtDU,uBAAM,GAAb;QACI,MAAM,CAAC,CACH,oBAAC,iBAAO,eACA,IAAI,CAAC,KAAK,GACd,SAAS,EAAE,UAAU,CAAC,UAAE,GAAC,OAAO,CAAC,wBAAwB,CAAC,GAAE,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,KAAE,CAAE,EAClF,WAAW,EAAE,IAAK;YAElB,qBAAC,GAAG,IAAC,SAAS,EAAE,UAAU,CAAC,OAAO,CAAC,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,SAAS,CAAE,EAAC,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,KAAM;gBACrF,IAAI,CAAC,iBAAiB,EAAG;gBACzB,IAAI,CAAC,KAAK,CAAC,QAAS,CACnB;SACA,CACb,CAAC;;IACN,CAAC;IAES,8BAAa,GAAvB,UAAwB,KAAmB;QACvC,EAAE,CAAC,CAAC,KAAK,CAAC,KAAK,IAAI,IAAI,CAAC,CAAC,CAAC;YACtB,EAAE,CAAC,CAAC,KAAK,CAAC,QAAQ,IAAI,IAAI,CAAC,CAAC,CAAC;gBACzB,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,6BAA6B,CAAC,CAAC;YACxD,CAAC;YACD,EAAE,CAAC,CAAC,KAAK,CAAC,kBAAkB,IAAI,IAAI,CAAC,CAAC,CAAC;gBACnC,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,qCAAqC,CAAC,CAAC;YAChE,CAAC;QACL,CAAC;IACL,CAAC;IAEO,uCAAsB,GAA9B;QACI,0DAA0D;QAC1D,+DAA+D;QAC/D,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,kBAAkB,KAAK,KAAK,CAAC,CAAC,CAAC;YAC1C,IAAM,OAAO,GAAG,UAAU,CAAC,OAAO,CAAC,mBAAmB,EAAE,OAAO,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC,CAAC;YAC1F,MAAM,CAAC,qBAAC,MAAM,KAAC,UAAU,GAAC,OAAO,EAAC,SAAS,EAAE,OAAQ,EAAC,OAAO,EAAE,IAAI,CAAC,KAAK,CAAC,OAAQ,EAAG,CAAC;QAC1F,CAAC;QAAC,IAAI,CAAC,CAAC;YACJ,MAAM,CAAC,SAAS,CAAC;QACrB,CAAC;IACL,CAAC;IAEO,kCAAiB,GAAzB;QACI,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,IAAI,CAAC,CAAC,CAAC;YAC3B,MAAM,CAAC,SAAS,CAAC;QACrB,CAAC;QAED,IAAI,SAAsB,CAAC;QAC3B,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,IAAI,IAAI,CAAC,CAAC,CAAC;YAC9B,SAAS,GAAG,qBAAC,IAAI,IAAC,SAAS,EAAE,UAAU,CAAC,OAAO,CAAC,UAAU,EAAE,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAE,EAAG,CAAC;QAC5G,CAAC;QACD,MAAM,CAAC,CACH,qBAAC,GAAG,IAAC,SAAS,EAAE,OAAO,CAAC,aAAc;YACjC,SAAU;YACX,qBAAC,EAAE,SAAE,IAAI,CAAC,KAAK,CAAC,KAAM,CAAK;YAC1B,IAAI,CAAC,sBAAsB,EAAG,CAC7B,CACT,CAAC;IACN,CAAC;IA3Da,mBAAY,GAAiB;QACvC,MAAM,EAAE,KAAK;KAChB,CAAC;IA0DN,aAAC;AAAD,CA7DA,AA6DC,CA7D2B,qCAAiB,GA6D5C;AA7DY,cAAM,SA6DlB,CAAA;AAEY,qBAAa,GAAG,KAAK,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC","file":"components/dialog/dialog.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 React from \"react\";\n\nimport { AbstractComponent } from \"../../common/abstractComponent\";\nimport * as Classes from \"../../common/classes\";\nimport * as Errors from \"../../common/errors\";\nimport { IProps } from \"../../common/props\";\nimport { IBackdropProps, IOverlayableProps, Overlay } from \"../overlay/overlay\";\n\nexport interface IDialogProps extends IOverlayableProps, IBackdropProps, IProps {\n    /**\n     * Toggles the visibility of the overlay and its children.\n     * This prop is required because the component is controlled.\n     */\n    isOpen: boolean;\n\n    /**\n     * Dialog always has a backdrop so this prop is excluded from the public API.\n     * @internal\n     */\n    hasBackdrop?: boolean;\n\n    /**\n     * Name of icon (the part after `pt-icon-`) to appear in the dialog's header.\n     * Note that the header will only be rendered if `title` is provided.\n     */\n    iconName?: string;\n\n    /**\n     * Whether to show the close \"X\" button in the dialog's header.\n     * Note that the header will only be rendered if `title` is provided.\n     * @default true\n     */\n    isCloseButtonShown?: boolean;\n\n    /**\n     * CSS Styles to apply to the .pt-dialog element.\n     * @default {}\n     */\n    style?: React.CSSProperties;\n\n    /**\n     * Title of dialog.\n     * If provided, a `.pt-dialog-header` element will be rendered inside the dialog\n     * before any children elements.\n     * In version 3.0, this prop will be required.\n     */\n    title?: string | JSX.Element;\n}\n\nexport class Dialog extends AbstractComponent<IDialogProps, {}> {\n    public static defaultProps: IDialogProps = {\n        isOpen: false,\n    };\n\n    public displayName = \"Blueprint.Dialog\";\n\n    public render() {\n        return (\n            <Overlay\n                {...this.props}\n                className={classNames({ [Classes.OVERLAY_SCROLL_CONTAINER]: !this.props.inline })}\n                hasBackdrop={true}\n            >\n                <div className={classNames(Classes.DIALOG, this.props.className)} style={this.props.style}>\n                    {this.maybeRenderHeader()}\n                    {this.props.children}\n                </div>\n            </Overlay>\n        );\n    }\n\n    protected validateProps(props: IDialogProps) {\n        if (props.title == null) {\n            if (props.iconName != null) {\n                console.error(Errors.WARNING_DIALOG_NO_HEADER_ICON);\n            }\n            if (props.isCloseButtonShown != null) {\n                console.error(Errors.WARNING_DIALOG_NO_HEADER_CLOSE_BUTTON);\n            }\n        }\n    }\n\n    private maybeRenderCloseButton() {\n        // for now, show close button if prop is undefined or null\n        // this gives us a behavior as if the default value were `true`\n        if (this.props.isCloseButtonShown !== false) {\n            const classes = classNames(Classes.DIALOG_CLOSE_BUTTON, Classes.iconClass(\"small-cross\"));\n            return <button aria-label=\"Close\" className={classes} onClick={this.props.onClose} />;\n        } else {\n            return undefined;\n        }\n    }\n\n    private maybeRenderHeader() {\n        if (this.props.title == null) {\n            return undefined;\n        }\n\n        let maybeIcon: JSX.Element;\n        if (this.props.iconName != null) {\n            maybeIcon = <span className={classNames(Classes.ICON_LARGE, Classes.iconClass(this.props.iconName))} />;\n        }\n        return (\n            <div className={Classes.DIALOG_HEADER}>\n                {maybeIcon}\n                <h5>{this.props.title}</h5>\n                {this.maybeRenderCloseButton()}\n            </div>\n        );\n    }\n}\n\nexport const DialogFactory = React.createFactory(Dialog);\n"],"sourceRoot":"/source/"}