Socket
Socket
Sign inDemoInstall

@blueprintjs/core

Package Overview
Dependencies
5
Maintainers
1
Versions
293
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

Comparing version 0.1.0 to 1.0.0

7

dist/components/editable-text/editableText.js

@@ -77,3 +77,6 @@ /*

var value = event.target.value;
_this.setState({ value: value });
// state value should be updated only when uncontrolled
if (_this.props.value == null) {
_this.setState({ value: value });
}
utils_1.safeInvoke(_this.props.onChange, value);

@@ -240,2 +243,2 @@ };

//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/components/editable-text/editableText.tsx"],"names":[],"mappings":"AAAA;;;GAGG;;;;;;;;;;;;;;;;;;;;;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,IAAY,IAAI,WAAM,mBAAmB,CAAC,CAAA;AAE1C,sBAAkC,oBAAoB,CAAC,CAAA;AA8EvD,IAAM,YAAY,GAAG,EAAE,CAAC;AAGxB;IAAkC,gCAAuD;IAyBrF,sBAAmB,KAA0B,EAAE,OAAa;QAzBhE,iBAkMC;QAxKO,kBAAM,KAAK,EAAE,OAAO,CAAC,CAAC;QAdlB,gBAAW,GAAG;YAClB,OAAO,EAAE,UAAC,WAA4B;gBAClC,KAAI,CAAC,YAAY,GAAG,WAAW,CAAC;YACpC,CAAC;YACD,KAAK,EAAE,UAAC,KAA6C;gBACjD,EAAE,CAAC,CAAC,KAAK,IAAI,IAAI,CAAC,CAAC,CAAC;oBAChB,KAAK,CAAC,KAAK,EAAE,CAAC;oBACN,iCAAM,CAAiB;oBAC/B,KAAK,CAAC,iBAAiB,CAAC,KAAI,CAAC,KAAK,CAAC,gBAAgB,GAAG,CAAC,GAAG,QAAM,EAAE,QAAM,CAAC,CAAC;gBAC9E,CAAC;YACL,CAAC;SACJ,CAAC;QAgFK,kBAAa,GAAG;YACX,qCAAS,CAAgB;YACjC,KAAI,CAAC,QAAQ,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC,CAAC;YACtD,oFAAoF;YACpF,kBAAU,CAAC,KAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;YAC3C,kBAAU,CAAC,KAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;QAC/C,CAAC,CAAC;QAEK,kBAAa,GAAG;YACnB,EAAE,CAAC,CAAC,KAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC;gBACf,6BAAK,CAAgB;gBAC7B,KAAI,CAAC,QAAQ,CAAC;oBACV,SAAS,EAAE,KAAK;oBAChB,SAAS,EAAE,KAAK;iBACnB,CAAC,CAAC;gBACH,kBAAU,CAAC,KAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;gBACvC,kBAAU,CAAC,KAAI,CAAC,KAAK,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;YAC5C,CAAC;YAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,KAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC;gBAC9B,KAAI,CAAC,QAAQ,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;YACvC,CAAC;QACL,CAAC,CAAC;QAEM,gBAAW,GAAG;YAClB,EAAE,CAAC,CAAC,CAAC,KAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC;gBACvB,KAAI,CAAC,QAAQ,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;YACvC,CAAC;QACL,CAAC,CAAC;QAEM,qBAAgB,GAAG,UAAC,KAAmC;YAC3D,IAAM,KAAK,GAAI,KAAK,CAAC,MAA2B,CAAC,KAAK,CAAC;YACvD,KAAI,CAAC,QAAQ,CAAC,EAAE,YAAK,EAAE,CAAC,CAAC;YACzB,kBAAU,CAAC,KAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;QAC3C,CAAC,CAAC;QAEM,mBAAc,GAAG,UAAC,EAA6D;gBAA3D,oBAAO,EAAE,oBAAO,EAAE,gBAAK;YAC/C,EAAE,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK,IAAI,CAAC,CAAC,KAAI,CAAC,KAAK,CAAC,SAAS,IAAI,OAAO,IAAI,OAAO,CAAC,CAAC,CAAC,CAAC;gBACxE,KAAI,CAAC,aAAa,EAAE,CAAC;YACzB,CAAC;YAAC,IAAI,CAAC,EAAE,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;gBAC/B,KAAI,CAAC,aAAa,EAAE,CAAC;YACzB,CAAC;QACL,CAAC,CAAC;QAnHE,IAAI,CAAC,KAAK,GAAG;YACT,WAAW,EAAE,CAAC;YACd,UAAU,EAAE,CAAC;YACb,SAAS,EAAE,KAAK,CAAC,SAAS,KAAK,IAAI,IAAI,KAAK,CAAC,QAAQ,KAAK,KAAK;YAC/D,SAAS,EAAE,QAAQ,CAAC,KAAK,CAAC;YAC1B,KAAK,EAAE,QAAQ,CAAC,KAAK,CAAC;SACzB,CAAC;IACN,CAAC;IAEM,6BAAM,GAAb;QACI,IAAA,eAA0C,EAAlC,sBAAQ,EAAE,wBAAS,CAAgB;QAC3C,IAAM,KAAK,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QAC/E,IAAM,QAAQ,GAAG,CAAC,KAAK,IAAI,IAAI,IAAI,KAAK,KAAK,EAAE,CAAC,CAAC;QAEjD,IAAM,OAAO,GAAG,UAAU,CACtB,OAAO,CAAC,aAAa,EACrB,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,EACtC;YACI,GAAC,OAAO,CAAC,QAAQ,CAAC,GAAE,QAAQ;YAC5B,yBAAqB,GAAE,IAAI,CAAC,KAAK,CAAC,SAAS;YAC3C,6BAAyB,GAAE,CAAC,QAAQ;YACpC,kBAAc,GAAE,SAAS;;SAC5B,EACD,IAAI,CAAC,KAAK,CAAC,SAAS,CACvB,CAAC;QAEF,IAAI,YAAiC,CAAC;QACtC,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;YACZ,qDAAqD;YACrD,iFAAiF;YACjF,YAAY,GAAG,EAAE,MAAM,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,GAAG,IAAI,EAAE,CAAC;QACrF,CAAC;QAAC,IAAI,CAAC,CAAC;YACJ,sEAAsE;YACtE,YAAY,GAAG;gBACX,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,WAAW;gBAC9B,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,WAAW,IAAI,IAAI,GAAM,IAAI,CAAC,KAAK,CAAC,WAAW,OAAI,GAAG,IAAI;gBACjF,QAAQ,EAAE,IAAI,CAAC,KAAK,CAAC,QAAQ;aAChC,CAAC;QACN,CAAC;QAED,oFAAoF;QACpF,sEAAsE;QACtE,IAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,IAAI,QAAQ,GAAG,IAAI,GAAG,CAAC,CAAC;QAC7D,MAAM,CAAC,CACH,qBAAC,GAAG,IAAC,SAAS,EAAE,OAAQ,EAAC,OAAO,EAAE,IAAI,CAAC,WAAY,EAAC,QAAQ,EAAE,QAAS;YAClE,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAE;YAC9B,qBAAC,IAAI,IAAC,SAAS,EAAC,qBAAqB,EAAC,GAAG,EAAE,IAAI,CAAC,WAAW,CAAC,OAAQ,EAAC,KAAK,EAAE,YAAa,GACpF,QAAQ,GAAG,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,WAAY,CACxC,CACL,CACT,CAAC;;IACN,CAAC;IAEM,wCAAiB,GAAxB;QACI,IAAI,CAAC,qBAAqB,EAAE,CAAC;IACjC,CAAC;IAEM,yCAAkB,GAAzB,UAA0B,CAAqB,EAAE,SAA6B;QAC1E,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC;YAC/C,kBAAU,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QAClC,CAAC;QACD,IAAI,CAAC,qBAAqB,EAAE,CAAC;IACjC,CAAC;IAEM,gDAAyB,GAAhC,UAAiC,SAA6B;QAC1D,IAAM,KAAK,GAAuB,EAAE,KAAK,EAAE,QAAQ,CAAC,SAAS,CAAC,EAAE,CAAC;QACjE,EAAE,CAAC,CAAC,SAAS,CAAC,SAAS,IAAI,IAAI,CAAC,CAAE,CAAC;YAC/B,KAAK,CAAC,SAAS,GAAG,SAAS,CAAC,SAAS,CAAC;QAC1C,CAAC;QACD,EAAE,CAAC,CAAC,SAAS,CAAC,QAAQ,IAAI,CAAC,SAAS,CAAC,QAAQ,IAAI,IAAI,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;YAC5E,KAAK,CAAC,SAAS,GAAG,KAAK,CAAC;QAC5B,CAAC;QACD,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACzB,CAAC;IA4CO,uCAAgB,GAAxB,UAAyB,KAAa;QAC1B,oCAAS,CAAgB;QACjC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC;YACxB,MAAM,CAAC,SAAS,CAAC;QACrB,CAAC;QACD,IAAM,KAAK,GAA4D;YACnE,SAAS,EAAE,mBAAmB;YAC9B,MAAM,EAAE,IAAI,CAAC,aAAa;YAC1B,QAAQ,EAAE,IAAI,CAAC,gBAAgB;YAC/B,SAAS,EAAE,IAAI,CAAC,cAAc;YAC9B,GAAG,EAAE,IAAI,CAAC,WAAW,CAAC,KAAK;YAC3B,KAAK,EAAE;gBACH,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,WAAW;gBAC9B,UAAU,EAAE,CAAC,SAAS,IAAI,IAAI,CAAC,KAAK,CAAC,WAAW,IAAI,IAAI,GAAM,IAAI,CAAC,KAAK,CAAC,WAAW,OAAI,GAAG,IAAI;gBAC/F,KAAK,EAAE,SAAS,GAAG,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU;aACpD;YACD,YAAK;SACR,CAAC;QACF,MAAM,CAAC,SAAS,GAAG,qBAAC,QAAQ,gBAAK,KAAK,EAAI,GAAG,qBAAC,KAAK,aAAC,IAAI,EAAC,MAAM,GAAK,KAAK,EAAI,CAAC;IAClF,CAAC;IAEO,4CAAqB,GAA7B;QACI,EAAE,CAAC,CAAC,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,CAAC,CAAC;YAC5B,IAAA,eAA8D,EAAtD,sBAAQ,EAAE,sBAAQ,EAAE,sBAAQ,EAAE,wBAAS,CAAgB;YAC/D,IAAA,sBAAiF,EAA3E,kCAAa,EAAE,gCAAY,EAAE,4BAAW,EAAE,4BAAW,CAAuB;YAClF,IAAM,UAAU,GAAG,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YACpD,iEAAiE;YACjE,4EAA4E;YAC5E,EAAE,CAAC,CAAC,SAAS,IAAI,IAAI,CAAC,KAAK,CAAC,SAAS,IAAI,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;gBAC/D,cAAY,IAAI,UAAU,CAAC;YAC/B,CAAC;YACD,EAAE,CAAC,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC,CAAC;gBACjB,wEAAwE;gBACxE,cAAY,GAAG,aAAK,CAAC,cAAY,EAAE,QAAQ,GAAG,UAAU,EAAE,QAAQ,GAAG,UAAU,CAAC,CAAC;YACrF,CAAC;YACD,+FAA+F;YAC/F,kGAAkG;YAClG,cAAY,GAAG,IAAI,CAAC,GAAG,CAAC,cAAY,EAAE,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,EAAE,aAAa,CAAC,eAAa,CAAC,CAAC,CAAC;YACxG,qEAAqE;YACrE,IAAI,CAAC,QAAQ,CAAC;gBACV,WAAW,EAAE,cAAY;gBACzB,UAAU,EAAE,IAAI,CAAC,GAAG,CAAC,WAAW,GAAG,YAAY,EAAE,QAAQ,CAAC;aAC7D,CAAC,CAAC;YACH,gFAAgF;YAChF,EAAE,CAAC,CAAC,SAAS,IAAI,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC;gBACpC,UAAU,CAAC,cAAM,OAAA,eAAa,CAAC,KAAK,CAAC,MAAM,GAAM,cAAY,OAAI,EAAhD,CAAgD,CAAC,CAAC;YACvE,CAAC;QACL,CAAC;IACL,CAAC;IAhMa,yBAAY,GAAuB;QAC7C,YAAY,EAAE,EAAE;QAChB,QAAQ,EAAE,KAAK;QACf,QAAQ,EAAE,QAAQ;QAClB,QAAQ,EAAE,CAAC;QACX,QAAQ,EAAE,EAAE;QACZ,SAAS,EAAE,KAAK;QAChB,WAAW,EAAE,eAAe;KAC/B,CAAC;IAVN;QAAC,UAAU;oBAAA;IAmMX,mBAAC;AAAD,CAlMA,AAkMC,CAlMiC,KAAK,CAAC,SAAS,GAkMhD;AAlMY,oBAAY,eAkMxB,CAAA;AAED,kBAAkB,KAAyB;IACvC,MAAM,CAAC,KAAK,CAAC,KAAK,IAAI,IAAI,GAAG,KAAK,CAAC,YAAY,GAAG,KAAK,CAAC,KAAK,CAAC;AAClE,CAAC;AAED,qBAAqB,OAAoB;IACrC,IAAM,QAAQ,GAAG,gBAAgB,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC;IACpD,MAAM,CAAC,QAAQ,KAAK,EAAE,GAAG,CAAC,GAAG,QAAQ,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;AACrE,CAAC;AAED,uBAAuB,OAAoB;IACvC,wCAAwC;IACxC,IAAI,UAAU,GAAG,QAAQ,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IACjF,oEAAoE;IACpE,EAAE,CAAC,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;QACpB,mDAAmD;QACnD,IAAM,IAAI,GAAG,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;QAC5C,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC;QACxB,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAC1B,IAAM,gBAAgB,GAAG,OAAO,CAAC,YAAY,CAAC;QAC9C,IAAI,CAAC,SAAS,GAAG,UAAU,CAAC;QAC5B,IAAM,gBAAgB,GAAG,OAAO,CAAC,YAAY,CAAC;QAC9C,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAC1B,kCAAkC;QAClC,UAAU,GAAG,gBAAgB,GAAG,gBAAgB,CAAC;IACrD,CAAC;IACD,MAAM,CAAC,UAAU,CAAC;AACtB,CAAC;AAEU,2BAAmB,GAAG,KAAK,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC","file":"components/editable-text/editableText.js","sourcesContent":["/*\n * Copyright 2016 Palantir Technologies, Inc. All rights reserved.\n * Licensed under the Apache License, Version 2.0 - http://www.apache.org/licenses/LICENSE-2.0\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 * as Keys from \"../../common/keys\";\nimport { IIntentProps, IProps } from \"../../common/props\";\nimport { clamp, safeInvoke } from \"../../common/utils\";\n\nexport interface IEditableTextProps extends IIntentProps, IProps {\n    /** Default text value of uncontrolled input. */\n    defaultValue?: string;\n\n    /**\n     * Whether the text can be edited.\n     * @default false\n     */\n    disabled?: boolean;\n\n    /** Whether the component is currently being edited. */\n    isEditing?: boolean;\n\n    /** Minimum width in pixels of the input, when not `multiline`. */\n    minWidth?: number;\n\n    /**\n     * Whether the component supports multiple lines of text.\n     * This prop should not be changed during the component's lifetime.\n     * @default false\n     */\n    multiline?: boolean;\n\n    /**\n     * Maximum number of lines before scrolling begins, when `multiline`.\n     */\n    maxLines?: number;\n\n    /**\n     * Minimum number of lines (essentially minimum height), when `multiline`.\n     * @default 1\n     */\n    minLines?: number;\n\n    /**\n     * Placeholder text when there is no value.\n     * @default \"Click to Edit\"\n     */\n    placeholder?: string;\n\n    /**\n     * Whether the entire text field should be selected on focus.\n     * If false, the cursor is placed at the end of the text.\n     * @default false\n     */\n    selectAllOnFocus?: boolean;\n\n    /** Text value of controlled input. */\n    value?: string;\n\n    /** Callback invoked when user cancels input with the `esc` key. Receives last confirmed value. */\n    onCancel?(value: string): void;\n\n    /** Callback invoked when user changes input in any way. */\n    onChange?(value: string): void;\n\n    /** Callback invoked when user confirms value with `enter` key or by blurring input. */\n    onConfirm?(value: string): void;\n\n    /** Callback invoked after the user enters edit mode. */\n    onEdit?(): void;\n}\n\nexport interface IEditableTextState {\n    /** Pixel height of the input, measured from span size */\n    inputHeight?: number;\n    /** Pixel width of the input, measured from span size */\n    inputWidth?: number;\n    /** Whether the value is currently being edited */\n    isEditing?: boolean;\n    /** The last confirmed value */\n    lastValue?: string;\n    /** The controlled input value, may be different from prop during editing */\n    value?: string;\n}\n\nconst BUFFER_WIDTH = 30;\n\n@PureRender\nexport class EditableText extends React.Component<IEditableTextProps, IEditableTextState> {\n    public static defaultProps: IEditableTextProps = {\n        defaultValue: \"\",\n        disabled: false,\n        maxLines: Infinity,\n        minLines: 1,\n        minWidth: 80,\n        multiline: false,\n        placeholder: \"Click to Edit\",\n    };\n\n    private valueElement: HTMLSpanElement;\n    private refHandlers = {\n        content: (spanElement: HTMLSpanElement) => {\n            this.valueElement = spanElement;\n        },\n        input: (input: HTMLInputElement | HTMLTextAreaElement) => {\n            if (input != null) {\n                input.focus();\n                const { length } = input.value;\n                input.setSelectionRange(this.props.selectAllOnFocus ? 0 : length, length);\n            }\n        },\n    };\n\n    public constructor(props?: IEditableTextProps, context?: any) {\n        super(props, context);\n\n        this.state = {\n            inputHeight: 0,\n            inputWidth: 0,\n            isEditing: props.isEditing === true && props.disabled === false,\n            lastValue: getValue(props),\n            value: getValue(props),\n        };\n    }\n\n    public render() {\n        const { disabled, multiline } = this.props;\n        const value = (this.props.value == null ? this.state.value : this.props.value);\n        const hasValue = (value != null && value !== \"\");\n\n        const classes = classNames(\n            Classes.EDITABLE_TEXT,\n            Classes.intentClass(this.props.intent),\n            {\n                [Classes.DISABLED]: disabled,\n                \"pt-editable-editing\": this.state.isEditing,\n                \"pt-editable-placeholder\": !hasValue,\n                \"pt-multiline\": multiline,\n            },\n            this.props.className\n        );\n\n        let contentStyle: React.CSSProperties;\n        if (multiline) {\n            // set height only in multiline mode when not editing\n            // otherwise we're measuring this element to determine appropriate height of text\n            contentStyle = { height: !this.state.isEditing ? this.state.inputHeight : null };\n        } else {\n            // minWidth only applies in single line mode (multiline == width 100%)\n            contentStyle = {\n                height: this.state.inputHeight,\n                lineHeight: this.state.inputHeight != null ? `${this.state.inputHeight}px` : null,\n                minWidth: this.props.minWidth,\n            };\n        }\n\n        // make enclosing div focusable when not editing, so it can still be tabbed to focus\n        // (when editing, input itself is focusable so div doesn't need to be)\n        const tabIndex = this.state.isEditing || disabled ? null : 0;\n        return (\n            <div className={classes} onFocus={this.handleFocus} tabIndex={tabIndex}>\n                {this.maybeRenderInput(value)}\n                <span className=\"pt-editable-content\" ref={this.refHandlers.content} style={contentStyle}>\n                    {hasValue ? value : this.props.placeholder}\n                </span>\n            </div>\n        );\n    }\n\n    public componentDidMount() {\n        this.updateInputDimensions();\n    }\n\n    public componentDidUpdate(_: IEditableTextProps, prevState: IEditableTextState) {\n        if (this.state.isEditing && !prevState.isEditing) {\n            safeInvoke(this.props.onEdit);\n        }\n        this.updateInputDimensions();\n    }\n\n    public componentWillReceiveProps(nextProps: IEditableTextProps) {\n        const state: IEditableTextState = { value: getValue(nextProps) };\n        if (nextProps.isEditing != null)  {\n            state.isEditing = nextProps.isEditing;\n        }\n        if (nextProps.disabled || (nextProps.disabled == null && this.props.disabled)) {\n            state.isEditing = false;\n        }\n        this.setState(state);\n    }\n\n    public cancelEditing = () => {\n        const { lastValue } = this.state;\n        this.setState({ isEditing: false, value: lastValue });\n        // invoke onCancel after onChange so consumers' onCancel can override their onChange\n        safeInvoke(this.props.onChange, lastValue);\n        safeInvoke(this.props.onCancel, lastValue);\n    };\n\n    public toggleEditing = () => {\n        if (this.state.isEditing) {\n            const { value } = this.state;\n            this.setState({\n                isEditing: false,\n                lastValue: value,\n            });\n            safeInvoke(this.props.onChange, value);\n            safeInvoke(this.props.onConfirm, value);\n        } else if (!this.props.disabled) {\n            this.setState({ isEditing: true });\n        }\n    };\n\n    private handleFocus = () => {\n        if (!this.props.disabled) {\n            this.setState({ isEditing: true });\n        }\n    };\n\n    private handleTextChange = (event: React.FormEvent<HTMLElement>) => {\n        const value = (event.target as HTMLInputElement).value;\n        this.setState({ value });\n        safeInvoke(this.props.onChange, value);\n    };\n\n    private handleKeyEvent = ({ ctrlKey, metaKey, which }: React.KeyboardEvent<HTMLElement>) => {\n        if (which === Keys.ENTER && (!this.props.multiline || ctrlKey || metaKey)) {\n            this.toggleEditing();\n        } else if (which === Keys.ESCAPE) {\n            this.cancelEditing();\n        }\n    };\n\n    private maybeRenderInput(value: string) {\n        const { multiline } = this.props;\n        if (!this.state.isEditing) {\n            return undefined;\n        }\n        const props: React.HTMLProps<HTMLInputElement | HTMLTextAreaElement> = {\n            className: \"pt-editable-input\",\n            onBlur: this.toggleEditing,\n            onChange: this.handleTextChange,\n            onKeyDown: this.handleKeyEvent,\n            ref: this.refHandlers.input,\n            style: {\n                height: this.state.inputHeight,\n                lineHeight: !multiline && this.state.inputHeight != null ? `${this.state.inputHeight}px` : null,\n                width: multiline ? \"100%\" : this.state.inputWidth,\n            },\n            value,\n        };\n        return multiline ? <textarea {...props} /> : <input type=\"text\" {...props} />;\n    }\n\n    private updateInputDimensions() {\n        if (this.valueElement != null) {\n            const { maxLines, minLines, minWidth, multiline } = this.props;\n            let { parentElement, scrollHeight, scrollWidth, textContent } = this.valueElement;\n            const lineHeight = getLineHeight(this.valueElement);\n            // add one line to computed <span> height if text ends in newline\n            // because <span> collapses that trailing whitespace but <textarea> shows it\n            if (multiline && this.state.isEditing && /\\n$/.test(textContent)) {\n                scrollHeight += lineHeight;\n            }\n            if (lineHeight > 0) {\n                // line height could be 0 if the isNaN block from getLineHeight kicks in\n                scrollHeight = clamp(scrollHeight, minLines * lineHeight, maxLines * lineHeight);\n            }\n            // Chrome's input caret height misaligns text so the line-height must be larger than font-size.\n            // The computed scrollHeight must also account for a larger inherited line-height from the parent.\n            scrollHeight = Math.max(scrollHeight, getFontSize(this.valueElement) + 1, getLineHeight(parentElement));\n            // IE11 needs a small buffer so text does not shift prior to resizing\n            this.setState({\n                inputHeight: scrollHeight,\n                inputWidth: Math.max(scrollWidth + BUFFER_WIDTH, minWidth),\n            });\n            // synchronizes the ::before pseudo-element's height while editing for Chrome 53\n            if (multiline && this.state.isEditing) {\n                setTimeout(() => parentElement.style.height = `${scrollHeight}px`);\n            }\n        }\n    }\n}\n\nfunction getValue(props: IEditableTextProps) {\n    return props.value == null ? props.defaultValue : props.value;\n}\n\nfunction getFontSize(element: HTMLElement) {\n    const fontSize = getComputedStyle(element).fontSize;\n    return fontSize === \"\" ? 0 : parseInt(fontSize.slice(0, -2), 10);\n}\n\nfunction getLineHeight(element: HTMLElement) {\n    // getComputedStyle() => 18.0001px => 18\n    let lineHeight = parseInt(getComputedStyle(element).lineHeight.slice(0, -2), 10);\n    // this check will be true if line-height is a keyword like \"normal\"\n    if (isNaN(lineHeight)) {\n        // @see http://stackoverflow.com/a/18430767/6342931\n        const line = document.createElement(\"span\");\n        line.innerHTML = \"<br>\";\n        element.appendChild(line);\n        const singleLineHeight = element.offsetHeight;\n        line.innerHTML = \"<br><br>\";\n        const doubleLineHeight = element.offsetHeight;\n        element.removeChild(line);\n        // this can return 0 in edge cases\n        lineHeight = doubleLineHeight - singleLineHeight;\n    }\n    return lineHeight;\n}\n\nexport var EditableTextFactory = React.createFactory(EditableText);\n"],"sourceRoot":"/source/"}
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/components/editable-text/editableText.tsx"],"names":[],"mappings":"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","file":"components/editable-text/editableText.js","sourcesContent":["/*\n * Copyright 2016 Palantir Technologies, Inc. All rights reserved.\n * Licensed under the Apache License, Version 2.0 - http://www.apache.org/licenses/LICENSE-2.0\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 * as Keys from \"../../common/keys\";\nimport { IIntentProps, IProps } from \"../../common/props\";\nimport { clamp, safeInvoke } from \"../../common/utils\";\n\nexport interface IEditableTextProps extends IIntentProps, IProps {\n    /** Default text value of uncontrolled input. */\n    defaultValue?: string;\n\n    /**\n     * Whether the text can be edited.\n     * @default false\n     */\n    disabled?: boolean;\n\n    /** Whether the component is currently being edited. */\n    isEditing?: boolean;\n\n    /** Minimum width in pixels of the input, when not `multiline`. */\n    minWidth?: number;\n\n    /**\n     * Whether the component supports multiple lines of text.\n     * This prop should not be changed during the component's lifetime.\n     * @default false\n     */\n    multiline?: boolean;\n\n    /**\n     * Maximum number of lines before scrolling begins, when `multiline`.\n     */\n    maxLines?: number;\n\n    /**\n     * Minimum number of lines (essentially minimum height), when `multiline`.\n     * @default 1\n     */\n    minLines?: number;\n\n    /**\n     * Placeholder text when there is no value.\n     * @default \"Click to Edit\"\n     */\n    placeholder?: string;\n\n    /**\n     * Whether the entire text field should be selected on focus.\n     * If false, the cursor is placed at the end of the text.\n     * @default false\n     */\n    selectAllOnFocus?: boolean;\n\n    /** Text value of controlled input. */\n    value?: string;\n\n    /** Callback invoked when user cancels input with the `esc` key. Receives last confirmed value. */\n    onCancel?(value: string): void;\n\n    /** Callback invoked when user changes input in any way. */\n    onChange?(value: string): void;\n\n    /** Callback invoked when user confirms value with `enter` key or by blurring input. */\n    onConfirm?(value: string): void;\n\n    /** Callback invoked after the user enters edit mode. */\n    onEdit?(): void;\n}\n\nexport interface IEditableTextState {\n    /** Pixel height of the input, measured from span size */\n    inputHeight?: number;\n    /** Pixel width of the input, measured from span size */\n    inputWidth?: number;\n    /** Whether the value is currently being edited */\n    isEditing?: boolean;\n    /** The last confirmed value */\n    lastValue?: string;\n    /** The controlled input value, may be different from prop during editing */\n    value?: string;\n}\n\nconst BUFFER_WIDTH = 30;\n\n@PureRender\nexport class EditableText extends React.Component<IEditableTextProps, IEditableTextState> {\n    public static defaultProps: IEditableTextProps = {\n        defaultValue: \"\",\n        disabled: false,\n        maxLines: Infinity,\n        minLines: 1,\n        minWidth: 80,\n        multiline: false,\n        placeholder: \"Click to Edit\",\n    };\n\n    private valueElement: HTMLSpanElement;\n    private refHandlers = {\n        content: (spanElement: HTMLSpanElement) => {\n            this.valueElement = spanElement;\n        },\n        input: (input: HTMLInputElement | HTMLTextAreaElement) => {\n            if (input != null) {\n                input.focus();\n                const { length } = input.value;\n                input.setSelectionRange(this.props.selectAllOnFocus ? 0 : length, length);\n            }\n        },\n    };\n\n    public constructor(props?: IEditableTextProps, context?: any) {\n        super(props, context);\n\n        this.state = {\n            inputHeight: 0,\n            inputWidth: 0,\n            isEditing: props.isEditing === true && props.disabled === false,\n            lastValue: getValue(props),\n            value: getValue(props),\n        };\n    }\n\n    public render() {\n        const { disabled, multiline } = this.props;\n        const value = (this.props.value == null ? this.state.value : this.props.value);\n        const hasValue = (value != null && value !== \"\");\n\n        const classes = classNames(\n            Classes.EDITABLE_TEXT,\n            Classes.intentClass(this.props.intent),\n            {\n                [Classes.DISABLED]: disabled,\n                \"pt-editable-editing\": this.state.isEditing,\n                \"pt-editable-placeholder\": !hasValue,\n                \"pt-multiline\": multiline,\n            },\n            this.props.className\n        );\n\n        let contentStyle: React.CSSProperties;\n        if (multiline) {\n            // set height only in multiline mode when not editing\n            // otherwise we're measuring this element to determine appropriate height of text\n            contentStyle = { height: !this.state.isEditing ? this.state.inputHeight : null };\n        } else {\n            // minWidth only applies in single line mode (multiline == width 100%)\n            contentStyle = {\n                height: this.state.inputHeight,\n                lineHeight: this.state.inputHeight != null ? `${this.state.inputHeight}px` : null,\n                minWidth: this.props.minWidth,\n            };\n        }\n\n        // make enclosing div focusable when not editing, so it can still be tabbed to focus\n        // (when editing, input itself is focusable so div doesn't need to be)\n        const tabIndex = this.state.isEditing || disabled ? null : 0;\n        return (\n            <div className={classes} onFocus={this.handleFocus} tabIndex={tabIndex}>\n                {this.maybeRenderInput(value)}\n                <span className=\"pt-editable-content\" ref={this.refHandlers.content} style={contentStyle}>\n                    {hasValue ? value : this.props.placeholder}\n                </span>\n            </div>\n        );\n    }\n\n    public componentDidMount() {\n        this.updateInputDimensions();\n    }\n\n    public componentDidUpdate(_: IEditableTextProps, prevState: IEditableTextState) {\n        if (this.state.isEditing && !prevState.isEditing) {\n            safeInvoke(this.props.onEdit);\n        }\n        this.updateInputDimensions();\n    }\n\n    public componentWillReceiveProps(nextProps: IEditableTextProps) {\n        const state: IEditableTextState = { value: getValue(nextProps) };\n        if (nextProps.isEditing != null)  {\n            state.isEditing = nextProps.isEditing;\n        }\n        if (nextProps.disabled || (nextProps.disabled == null && this.props.disabled)) {\n            state.isEditing = false;\n        }\n        this.setState(state);\n    }\n\n    public cancelEditing = () => {\n        const { lastValue } = this.state;\n        this.setState({ isEditing: false, value: lastValue });\n        // invoke onCancel after onChange so consumers' onCancel can override their onChange\n        safeInvoke(this.props.onChange, lastValue);\n        safeInvoke(this.props.onCancel, lastValue);\n    };\n\n    public toggleEditing = () => {\n        if (this.state.isEditing) {\n            const { value } = this.state;\n            this.setState({\n                isEditing: false,\n                lastValue: value,\n            });\n            safeInvoke(this.props.onChange, value);\n            safeInvoke(this.props.onConfirm, value);\n        } else if (!this.props.disabled) {\n            this.setState({ isEditing: true });\n        }\n    };\n\n    private handleFocus = () => {\n        if (!this.props.disabled) {\n            this.setState({ isEditing: true });\n        }\n    };\n\n    private handleTextChange = (event: React.FormEvent<HTMLElement>) => {\n        const value = (event.target as HTMLInputElement).value;\n        // state value should be updated only when uncontrolled\n        if (this.props.value == null) { this.setState({ value }); }\n        safeInvoke(this.props.onChange, value);\n    };\n\n    private handleKeyEvent = ({ ctrlKey, metaKey, which }: React.KeyboardEvent<HTMLElement>) => {\n        if (which === Keys.ENTER && (!this.props.multiline || ctrlKey || metaKey)) {\n            this.toggleEditing();\n        } else if (which === Keys.ESCAPE) {\n            this.cancelEditing();\n        }\n    };\n\n    private maybeRenderInput(value: string) {\n        const { multiline } = this.props;\n        if (!this.state.isEditing) {\n            return undefined;\n        }\n        const props: React.HTMLProps<HTMLInputElement | HTMLTextAreaElement> = {\n            className: \"pt-editable-input\",\n            onBlur: this.toggleEditing,\n            onChange: this.handleTextChange,\n            onKeyDown: this.handleKeyEvent,\n            ref: this.refHandlers.input,\n            style: {\n                height: this.state.inputHeight,\n                lineHeight: !multiline && this.state.inputHeight != null ? `${this.state.inputHeight}px` : null,\n                width: multiline ? \"100%\" : this.state.inputWidth,\n            },\n            value,\n        };\n        return multiline ? <textarea {...props} /> : <input type=\"text\" {...props} />;\n    }\n\n    private updateInputDimensions() {\n        if (this.valueElement != null) {\n            const { maxLines, minLines, minWidth, multiline } = this.props;\n            let { parentElement, scrollHeight, scrollWidth, textContent } = this.valueElement;\n            const lineHeight = getLineHeight(this.valueElement);\n            // add one line to computed <span> height if text ends in newline\n            // because <span> collapses that trailing whitespace but <textarea> shows it\n            if (multiline && this.state.isEditing && /\\n$/.test(textContent)) {\n                scrollHeight += lineHeight;\n            }\n            if (lineHeight > 0) {\n                // line height could be 0 if the isNaN block from getLineHeight kicks in\n                scrollHeight = clamp(scrollHeight, minLines * lineHeight, maxLines * lineHeight);\n            }\n            // Chrome's input caret height misaligns text so the line-height must be larger than font-size.\n            // The computed scrollHeight must also account for a larger inherited line-height from the parent.\n            scrollHeight = Math.max(scrollHeight, getFontSize(this.valueElement) + 1, getLineHeight(parentElement));\n            // IE11 needs a small buffer so text does not shift prior to resizing\n            this.setState({\n                inputHeight: scrollHeight,\n                inputWidth: Math.max(scrollWidth + BUFFER_WIDTH, minWidth),\n            });\n            // synchronizes the ::before pseudo-element's height while editing for Chrome 53\n            if (multiline && this.state.isEditing) {\n                setTimeout(() => parentElement.style.height = `${scrollHeight}px`);\n            }\n        }\n    }\n}\n\nfunction getValue(props: IEditableTextProps) {\n    return props.value == null ? props.defaultValue : props.value;\n}\n\nfunction getFontSize(element: HTMLElement) {\n    const fontSize = getComputedStyle(element).fontSize;\n    return fontSize === \"\" ? 0 : parseInt(fontSize.slice(0, -2), 10);\n}\n\nfunction getLineHeight(element: HTMLElement) {\n    // getComputedStyle() => 18.0001px => 18\n    let lineHeight = parseInt(getComputedStyle(element).lineHeight.slice(0, -2), 10);\n    // this check will be true if line-height is a keyword like \"normal\"\n    if (isNaN(lineHeight)) {\n        // @see http://stackoverflow.com/a/18430767/6342931\n        const line = document.createElement(\"span\");\n        line.innerHTML = \"<br>\";\n        element.appendChild(line);\n        const singleLineHeight = element.offsetHeight;\n        line.innerHTML = \"<br><br>\";\n        const doubleLineHeight = element.offsetHeight;\n        element.removeChild(line);\n        // this can return 0 in edge cases\n        lineHeight = doubleLineHeight - singleLineHeight;\n    }\n    return lineHeight;\n}\n\nexport var EditableTextFactory = React.createFactory(EditableText);\n"],"sourceRoot":"/source/"}

@@ -47,2 +47,3 @@ /// <reference types="react" />

componentDidMount(): void;
componentDidUpdate(_: ITabsProps, prevState: ITabsState): void;
componentWillUnmount(): void;

@@ -49,0 +50,0 @@ protected validateProps(props: ITabsProps & {

@@ -95,3 +95,2 @@ /*

var index = tabElement.parentElement.queryAll(TAB_CSS_SELECTOR).indexOf(tabElement);
_this.moveIndicator(tabElement);
_this.setSelectedTabIndex(index);

@@ -106,3 +105,8 @@ }

Tabs.prototype.componentWillReceiveProps = function (newProps) {
this.setState(this.getStateFromProps(newProps));
var newState = this.getStateFromProps(newProps);
var newIndex = newState.selectedTabIndex;
if (newIndex !== this.state.selectedTabIndex) {
this.setSelectedTabIndex(newIndex);
}
this.setState(newState);
};

@@ -114,2 +118,11 @@ Tabs.prototype.componentDidMount = function () {

};
Tabs.prototype.componentDidUpdate = function (_, prevState) {
var _this = this;
var newIndex = this.state.selectedTabIndex;
if (newIndex !== prevState.selectedTabIndex) {
var tabElement_1 = react_dom_1.findDOMNode(this.refs[("tabs-" + newIndex)]);
// need to measure on the next frame in case the Tab children simultaneously change
this.moveTimeout = setTimeout(function () { return _this.moveIndicator(tabElement_1); });
}
};
Tabs.prototype.componentWillUnmount = function () {

@@ -305,2 +318,2 @@ clearTimeout(this.moveTimeout);

//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/components/tabs/tabs.tsx"],"names":[],"mappings":"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","file":"components/tabs/tabs.js","sourcesContent":["/*\n * Copyright 2015 Palantir Technologies, Inc. All rights reserved.\n * Licensed under the Apache License, Version 2.0 - http://www.apache.org/licenses/LICENSE-2.0\n */\n\nimport * as classNames from \"classnames\";\nimport * as PureRender from \"pure-render-decorator\";\nimport * as React from \"react\";\nimport { findDOMNode } from \"react-dom\";\n\nimport { AbstractComponent } from \"../../common/abstractComponent\";\nimport * as Classes from \"../../common/classes\";\nimport * as Errors from \"../../common/errors\";\nimport * as Keys from \"../../common/keys\";\nimport { IProps } from \"../../common/props\";\nimport * as Utils from \"../../common/utils\";\n\nimport { ITabProps, Tab } from \"./tab\";\nimport { ITabListProps, TabList } from \"./tabList\";\nimport { ITabPanelProps, TabPanel } from \"./tabPanel\";\n\nexport interface ITabsProps extends IProps {\n    /**\n     * The index of the initially selected tab when this component renders.\n     * This prop has no effect if `selectedTabIndex` is also provided.\n     * @default 0\n     */\n    initialSelectedTabIndex?: number;\n\n    /**\n     * The index of the currently selected tab.\n     * Use this prop if you want to explicitly control the currently displayed panel\n     * yourself with the `onChange` event handler.\n     * If this prop is left undefined, the component changes tab panels automatically\n     * when tabs are clicked.\n     */\n    selectedTabIndex?: number;\n\n    /**\n     * A callback function that is invoked when tabs in the tab list are clicked.\n     */\n    onChange?(selectedTabIndex: number, prevSelectedTabIndex: number): void;\n}\n\nexport interface ITabsState {\n    /**\n     * The list of CSS rules to use on the indicator wrapper of the tab list.\n     */\n    indicatorWrapperStyle?: React.CSSProperties;\n\n    /**\n     * The index of the currently selected tab.\n     * If a prop with the same name is set, this bit of state simply aliases the prop.\n     */\n    selectedTabIndex?: number;\n}\n\nconst TAB_CSS_SELECTOR = \"li[role=tab]\";\n\n@PureRender\nexport class Tabs extends AbstractComponent<ITabsProps, ITabsState> {\n    public static defaultProps: ITabsProps = {\n        initialSelectedTabIndex: 0,\n    };\n\n    public displayName = \"Blueprint.Tabs\";\n    // state is initialized in the constructor but getStateFromProps needs state defined\n    public state: ITabsState = {};\n\n    private panelIds: string[] = [];\n    private tabIds: string[] = [];\n\n    private moveTimeout: number;\n\n    constructor(props?: ITabsProps, context?: any) {\n        super(props, context);\n        this.state = this.getStateFromProps(this.props);\n    }\n\n    public render() {\n        return (\n            <div\n                className={classNames(Classes.TABS, this.props.className)}\n                onClick={this.handleClick}\n                onKeyPress={this.handleKeyPress}\n                onKeyDown={this.handleKeyDown}\n            >\n                {this.getChildren()}\n            </div>\n        );\n    }\n\n    public componentWillReceiveProps(newProps: ITabsProps) {\n        this.setState(this.getStateFromProps(newProps));\n    }\n\n    public componentDidMount() {\n        const selectedTab = findDOMNode(this.refs[`tabs-${this.state.selectedTabIndex}`]) as HTMLElement;\n        this.moveTimeout = setTimeout(() => this.moveIndicator(selectedTab));\n    }\n\n    public componentWillUnmount() {\n        clearTimeout(this.moveTimeout);\n    }\n\n    protected validateProps(props: ITabsProps & {children?: React.ReactNode}) {\n        if (React.Children.count(props.children) > 0) {\n            const child = React.Children.toArray(props.children)[0] as React.ReactElement<any>;\n            if (child != null && child.type !== TabList) {\n                throw new Error(Errors.TABS_FIRST_CHILD);\n            }\n\n            if (this.getTabsCount() !== this.getPanelsCount()) {\n                throw new Error(Errors.TABS_MISMATCH);\n            }\n        }\n    }\n\n    private handleClick = (e: React.SyntheticEvent<HTMLDivElement>) => {\n        this.handleTabSelectingEvent(e);\n    }\n\n    private handleKeyPress = (e: React.KeyboardEvent<HTMLDivElement>) => {\n        const insideTab = (e.target as HTMLElement).closest(`.${Classes.TAB}`) != null;\n        if (insideTab && (e.which === Keys.SPACE || e.which === Keys.ENTER)) {\n            e.preventDefault();\n            this.handleTabSelectingEvent(e);\n        }\n    }\n\n    private handleKeyDown = (e: React.KeyboardEvent<HTMLDivElement>) => {\n        // don't want to handle keyDown events inside a tab panel\n        const insideTabList = (e.target as HTMLElement).closest(`.${Classes.TAB_LIST}`) != null;\n        if (!insideTabList) { return; }\n\n        const focusedTabIndex = this.getFocusedTabIndex();\n        if (focusedTabIndex === -1) { return; }\n\n        if (e.which === Keys.ARROW_LEFT) {\n            e.preventDefault();\n\n            // find previous tab that isn't disabled\n            let newTabIndex = focusedTabIndex - 1;\n            let tabIsDisabled = this.isTabDisabled(newTabIndex);\n\n            while (tabIsDisabled && newTabIndex !== -1) {\n                newTabIndex--;\n                tabIsDisabled = this.isTabDisabled(newTabIndex);\n            }\n\n            if (newTabIndex !== -1) {\n                this.focusTab(newTabIndex);\n            }\n        } else if (e.which === Keys.ARROW_RIGHT) {\n            e.preventDefault();\n\n            // find next tab that isn't disabled\n            const tabsCount = this.getTabsCount();\n\n            let newTabIndex = focusedTabIndex + 1;\n            let tabIsDisabled = this.isTabDisabled(newTabIndex);\n\n            while (tabIsDisabled && newTabIndex !== tabsCount) {\n                newTabIndex++;\n                tabIsDisabled = this.isTabDisabled(newTabIndex);\n            }\n\n            if (newTabIndex !== tabsCount) {\n                this.focusTab(newTabIndex);\n            }\n        }\n    }\n\n    private handleTabSelectingEvent = (e: React.SyntheticEvent<HTMLDivElement>) => {\n        const tabElement = (e.target as HTMLElement).closest(TAB_CSS_SELECTOR) as HTMLElement;\n\n        // select only if Tab is one of us and is enabled\n        if (tabElement != null\n                && this.tabIds.indexOf(tabElement.id) >= 0\n                && tabElement.getAttribute(\"aria-disabled\") !== \"true\") {\n            const index = tabElement.parentElement.queryAll(TAB_CSS_SELECTOR).indexOf(tabElement);\n\n            this.moveIndicator(tabElement);\n            this.setSelectedTabIndex(index);\n        }\n    }\n\n    /**\n     * Calculate the new height, width, and position of the tab indicator.\n     * Store the CSS values so the transition animation can start.\n     */\n    private moveIndicator({ clientHeight, clientWidth, offsetLeft, offsetTop }: HTMLElement) {\n        const indicatorWrapperStyle = {\n            height: clientHeight,\n            transform: `translateX(${Math.floor(offsetLeft)}px) translateY(${Math.floor(offsetTop)}px)`,\n            width: clientWidth,\n        };\n        this.setState({ indicatorWrapperStyle });\n    }\n\n    /**\n     * Most of the component logic lives here. We clone the children provided by the user to set up refs,\n     * accessibility attributes, and selection props correctly.\n     */\n    private getChildren() {\n        for (let unassignedTabs = this.getTabsCount() - this.tabIds.length; unassignedTabs > 0; unassignedTabs--) {\n            this.tabIds.push(generateTabId());\n            this.panelIds.push(generatePanelId());\n        }\n\n        let childIndex = 0;\n        return React.Children.map(this.props.children, (child: React.ReactElement<any>) => {\n            let result: React.ReactElement<any>;\n\n            // can be null if conditionally rendering TabList / TabPanel\n            if (child == null) {\n                return null;\n            }\n\n            if (childIndex === 0) {\n                // clone TabList / Tab elements\n                result = this.cloneTabList(child);\n            } else {\n                const tabPanelIndex = childIndex - 1;\n                const shouldRenderTabPanel = this.state.selectedTabIndex === tabPanelIndex;\n                result = shouldRenderTabPanel ? this.cloneTabPanel(child, tabPanelIndex) : null;\n            }\n\n            childIndex++;\n            return result;\n        });\n    }\n\n    private cloneTabList(child: React.ReactElement<ITabListProps & {children?: React.ReactNode}>) {\n        let tabIndex = 0;\n        const tabs = React.Children.map(child.props.children, (tab: React.ReactElement<any>) => {\n            // can be null if conditionally rendering Tab\n            if (tab == null) {\n                return null;\n            }\n\n            const clonedTab = React.cloneElement(tab, {\n                id: this.tabIds[tabIndex],\n                isSelected: this.state.selectedTabIndex === tabIndex,\n                panelId: this.panelIds[tabIndex],\n                ref: `tabs-${tabIndex}`,\n            } as ITabProps);\n            tabIndex++;\n            return clonedTab;\n        });\n        return React.cloneElement(child, {\n            children: tabs,\n            indicatorWrapperStyle: this.state.indicatorWrapperStyle,\n            ref: \"tablist\",\n        } as ITabListProps);\n    }\n\n    private cloneTabPanel(child: React.ReactElement<any>, tabIndex: number) {\n        return React.cloneElement(child, {\n            id: this.panelIds[tabIndex],\n            isSelected: this.state.selectedTabIndex === tabIndex,\n            ref: `panels-${tabIndex}`,\n            tabId: this.tabIds[tabIndex],\n        } as ITabPanelProps);\n    }\n\n    private focusTab(index: number) {\n        const ref = `tabs-${index}`;\n        const tab = findDOMNode(this.refs[ref]) as HTMLElement;\n        tab.focus();\n    }\n\n    private getFocusedTabIndex() {\n        const focusedElement = document.activeElement;\n        if (focusedElement != null && focusedElement.classList.contains(Classes.TAB)) {\n            const tabId = focusedElement.id;\n            return this.tabIds.indexOf(tabId);\n        }\n        return -1;\n    }\n\n    private getTabs() {\n        if (this.props.children == null) {\n            return [];\n        }\n        let tabs: React.ReactElement<ITabProps>[] = [];\n        if (React.Children.count(this.props.children) > 0) {\n            const firstChild = React.Children.toArray(this.props.children)[0] as React.ReactElement<any>;\n            if (firstChild != null) {\n                React.Children.forEach(firstChild.props.children, (tabListChild: React.ReactElement<any>) => {\n                    if (tabListChild.type === Tab) {\n                        tabs.push(tabListChild);\n                    }\n                });\n            }\n        }\n        return tabs;\n    }\n\n    private getTabsCount() {\n        return this.getTabs().length;\n    }\n\n    private getPanelsCount() {\n        if (this.props.children == null) {\n            return 0;\n        }\n\n        let index = 0;\n        let panelCount = 0;\n        React.Children.forEach(this.props.children, (child: React.ReactElement<any>) => {\n            if (child.type === TabPanel) {\n                panelCount++;\n            }\n            index++;\n        });\n\n        return panelCount;\n    }\n\n    private getStateFromProps(props: ITabsProps): ITabsState {\n        const { selectedTabIndex, initialSelectedTabIndex } = props;\n\n        if (this.isValidTabIndex(selectedTabIndex)) {\n            return { selectedTabIndex };\n        } else if (this.isValidTabIndex(initialSelectedTabIndex) && this.state.selectedTabIndex == null) {\n            return { selectedTabIndex: initialSelectedTabIndex };\n        } else {\n            return this.state;\n        }\n    }\n\n    private isTabDisabled(index: number) {\n        const tab = this.getTabs()[index];\n        return tab != null && tab.props.isDisabled;\n    }\n\n    private isValidTabIndex(index: number) {\n        return index != null && index >= 0 && index < this.getTabsCount();\n    }\n\n    /**\n     * Updates the component's state if uncontrolled and calls onChange.\n     */\n    private setSelectedTabIndex(index: number) {\n        if (index === this.state.selectedTabIndex || !this.isValidTabIndex(index)) {\n            return;\n        }\n\n        const prevSelectedIndex = this.state.selectedTabIndex;\n\n        if (this.props.selectedTabIndex == null) {\n            this.setState({\n                selectedTabIndex: index,\n            });\n        }\n\n        if (Utils.isFunction(this.props.onChange)) {\n            this.props.onChange(index, prevSelectedIndex);\n        }\n    }\n}\n\nlet tabCount = 0;\nfunction generateTabId() {\n    return `pt-tab-${tabCount++}`;\n}\n\nlet panelCount = 0;\nfunction generatePanelId() {\n    return `pt-tab-panel-${panelCount++}`;\n}\n\nexport var TabsFactory = React.createFactory(Tabs);\n"],"sourceRoot":"/source/"}
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/components/tabs/tabs.tsx"],"names":[],"mappings":"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","file":"components/tabs/tabs.js","sourcesContent":["/*\n * Copyright 2015 Palantir Technologies, Inc. All rights reserved.\n * Licensed under the Apache License, Version 2.0 - http://www.apache.org/licenses/LICENSE-2.0\n */\n\nimport * as classNames from \"classnames\";\nimport * as PureRender from \"pure-render-decorator\";\nimport * as React from \"react\";\nimport { findDOMNode } from \"react-dom\";\n\nimport { AbstractComponent } from \"../../common/abstractComponent\";\nimport * as Classes from \"../../common/classes\";\nimport * as Errors from \"../../common/errors\";\nimport * as Keys from \"../../common/keys\";\nimport { IProps } from \"../../common/props\";\nimport * as Utils from \"../../common/utils\";\n\nimport { ITabProps, Tab } from \"./tab\";\nimport { ITabListProps, TabList } from \"./tabList\";\nimport { ITabPanelProps, TabPanel } from \"./tabPanel\";\n\nexport interface ITabsProps extends IProps {\n    /**\n     * The index of the initially selected tab when this component renders.\n     * This prop has no effect if `selectedTabIndex` is also provided.\n     * @default 0\n     */\n    initialSelectedTabIndex?: number;\n\n    /**\n     * The index of the currently selected tab.\n     * Use this prop if you want to explicitly control the currently displayed panel\n     * yourself with the `onChange` event handler.\n     * If this prop is left undefined, the component changes tab panels automatically\n     * when tabs are clicked.\n     */\n    selectedTabIndex?: number;\n\n    /**\n     * A callback function that is invoked when tabs in the tab list are clicked.\n     */\n    onChange?(selectedTabIndex: number, prevSelectedTabIndex: number): void;\n}\n\nexport interface ITabsState {\n    /**\n     * The list of CSS rules to use on the indicator wrapper of the tab list.\n     */\n    indicatorWrapperStyle?: React.CSSProperties;\n\n    /**\n     * The index of the currently selected tab.\n     * If a prop with the same name is set, this bit of state simply aliases the prop.\n     */\n    selectedTabIndex?: number;\n}\n\nconst TAB_CSS_SELECTOR = \"li[role=tab]\";\n\n@PureRender\nexport class Tabs extends AbstractComponent<ITabsProps, ITabsState> {\n    public static defaultProps: ITabsProps = {\n        initialSelectedTabIndex: 0,\n    };\n\n    public displayName = \"Blueprint.Tabs\";\n    // state is initialized in the constructor but getStateFromProps needs state defined\n    public state: ITabsState = {};\n\n    private panelIds: string[] = [];\n    private tabIds: string[] = [];\n\n    private moveTimeout: number;\n\n    constructor(props?: ITabsProps, context?: any) {\n        super(props, context);\n        this.state = this.getStateFromProps(this.props);\n    }\n\n    public render() {\n        return (\n            <div\n                className={classNames(Classes.TABS, this.props.className)}\n                onClick={this.handleClick}\n                onKeyPress={this.handleKeyPress}\n                onKeyDown={this.handleKeyDown}\n            >\n                {this.getChildren()}\n            </div>\n        );\n    }\n\n    public componentWillReceiveProps(newProps: ITabsProps) {\n        const newState = this.getStateFromProps(newProps);\n        const newIndex = newState.selectedTabIndex;\n        if (newIndex !== this.state.selectedTabIndex) {\n            this.setSelectedTabIndex(newIndex);\n        }\n        this.setState(newState);\n    }\n\n    public componentDidMount() {\n        const selectedTab = findDOMNode(this.refs[`tabs-${this.state.selectedTabIndex}`]) as HTMLElement;\n        this.moveTimeout = setTimeout(() => this.moveIndicator(selectedTab));\n    }\n\n    public componentDidUpdate(_: ITabsProps, prevState: ITabsState) {\n        const newIndex = this.state.selectedTabIndex;\n        if (newIndex !== prevState.selectedTabIndex) {\n            const tabElement = findDOMNode(this.refs[`tabs-${newIndex}`]) as HTMLElement;\n            // need to measure on the next frame in case the Tab children simultaneously change\n            this.moveTimeout = setTimeout(() => this.moveIndicator(tabElement));\n        }\n    }\n\n    public componentWillUnmount() {\n        clearTimeout(this.moveTimeout);\n    }\n\n    protected validateProps(props: ITabsProps & {children?: React.ReactNode}) {\n        if (React.Children.count(props.children) > 0) {\n            const child = React.Children.toArray(props.children)[0] as React.ReactElement<any>;\n            if (child != null && child.type !== TabList) {\n                throw new Error(Errors.TABS_FIRST_CHILD);\n            }\n\n            if (this.getTabsCount() !== this.getPanelsCount()) {\n                throw new Error(Errors.TABS_MISMATCH);\n            }\n        }\n    }\n\n    private handleClick = (e: React.SyntheticEvent<HTMLDivElement>) => {\n        this.handleTabSelectingEvent(e);\n    }\n\n    private handleKeyPress = (e: React.KeyboardEvent<HTMLDivElement>) => {\n        const insideTab = (e.target as HTMLElement).closest(`.${Classes.TAB}`) != null;\n        if (insideTab && (e.which === Keys.SPACE || e.which === Keys.ENTER)) {\n            e.preventDefault();\n            this.handleTabSelectingEvent(e);\n        }\n    }\n\n    private handleKeyDown = (e: React.KeyboardEvent<HTMLDivElement>) => {\n        // don't want to handle keyDown events inside a tab panel\n        const insideTabList = (e.target as HTMLElement).closest(`.${Classes.TAB_LIST}`) != null;\n        if (!insideTabList) { return; }\n\n        const focusedTabIndex = this.getFocusedTabIndex();\n        if (focusedTabIndex === -1) { return; }\n\n        if (e.which === Keys.ARROW_LEFT) {\n            e.preventDefault();\n\n            // find previous tab that isn't disabled\n            let newTabIndex = focusedTabIndex - 1;\n            let tabIsDisabled = this.isTabDisabled(newTabIndex);\n\n            while (tabIsDisabled && newTabIndex !== -1) {\n                newTabIndex--;\n                tabIsDisabled = this.isTabDisabled(newTabIndex);\n            }\n\n            if (newTabIndex !== -1) {\n                this.focusTab(newTabIndex);\n            }\n        } else if (e.which === Keys.ARROW_RIGHT) {\n            e.preventDefault();\n\n            // find next tab that isn't disabled\n            const tabsCount = this.getTabsCount();\n\n            let newTabIndex = focusedTabIndex + 1;\n            let tabIsDisabled = this.isTabDisabled(newTabIndex);\n\n            while (tabIsDisabled && newTabIndex !== tabsCount) {\n                newTabIndex++;\n                tabIsDisabled = this.isTabDisabled(newTabIndex);\n            }\n\n            if (newTabIndex !== tabsCount) {\n                this.focusTab(newTabIndex);\n            }\n        }\n    }\n\n    private handleTabSelectingEvent = (e: React.SyntheticEvent<HTMLDivElement>) => {\n        const tabElement = (e.target as HTMLElement).closest(TAB_CSS_SELECTOR) as HTMLElement;\n\n        // select only if Tab is one of us and is enabled\n        if (tabElement != null\n                && this.tabIds.indexOf(tabElement.id) >= 0\n                && tabElement.getAttribute(\"aria-disabled\") !== \"true\") {\n            const index = tabElement.parentElement.queryAll(TAB_CSS_SELECTOR).indexOf(tabElement);\n\n            this.setSelectedTabIndex(index);\n        }\n    }\n\n    /**\n     * Calculate the new height, width, and position of the tab indicator.\n     * Store the CSS values so the transition animation can start.\n     */\n    private moveIndicator({ clientHeight, clientWidth, offsetLeft, offsetTop }: HTMLElement) {\n        const indicatorWrapperStyle = {\n            height: clientHeight,\n            transform: `translateX(${Math.floor(offsetLeft)}px) translateY(${Math.floor(offsetTop)}px)`,\n            width: clientWidth,\n        };\n        this.setState({ indicatorWrapperStyle });\n    }\n\n    /**\n     * Most of the component logic lives here. We clone the children provided by the user to set up refs,\n     * accessibility attributes, and selection props correctly.\n     */\n    private getChildren() {\n        for (let unassignedTabs = this.getTabsCount() - this.tabIds.length; unassignedTabs > 0; unassignedTabs--) {\n            this.tabIds.push(generateTabId());\n            this.panelIds.push(generatePanelId());\n        }\n\n        let childIndex = 0;\n        return React.Children.map(this.props.children, (child: React.ReactElement<any>) => {\n            let result: React.ReactElement<any>;\n\n            // can be null if conditionally rendering TabList / TabPanel\n            if (child == null) {\n                return null;\n            }\n\n            if (childIndex === 0) {\n                // clone TabList / Tab elements\n                result = this.cloneTabList(child);\n            } else {\n                const tabPanelIndex = childIndex - 1;\n                const shouldRenderTabPanel = this.state.selectedTabIndex === tabPanelIndex;\n                result = shouldRenderTabPanel ? this.cloneTabPanel(child, tabPanelIndex) : null;\n            }\n\n            childIndex++;\n            return result;\n        });\n    }\n\n    private cloneTabList(child: React.ReactElement<ITabListProps & {children?: React.ReactNode}>) {\n        let tabIndex = 0;\n        const tabs = React.Children.map(child.props.children, (tab: React.ReactElement<any>) => {\n            // can be null if conditionally rendering Tab\n            if (tab == null) {\n                return null;\n            }\n\n            const clonedTab = React.cloneElement(tab, {\n                id: this.tabIds[tabIndex],\n                isSelected: this.state.selectedTabIndex === tabIndex,\n                panelId: this.panelIds[tabIndex],\n                ref: `tabs-${tabIndex}`,\n            } as ITabProps);\n            tabIndex++;\n            return clonedTab;\n        });\n        return React.cloneElement(child, {\n            children: tabs,\n            indicatorWrapperStyle: this.state.indicatorWrapperStyle,\n            ref: \"tablist\",\n        } as ITabListProps);\n    }\n\n    private cloneTabPanel(child: React.ReactElement<any>, tabIndex: number) {\n        return React.cloneElement(child, {\n            id: this.panelIds[tabIndex],\n            isSelected: this.state.selectedTabIndex === tabIndex,\n            ref: `panels-${tabIndex}`,\n            tabId: this.tabIds[tabIndex],\n        } as ITabPanelProps);\n    }\n\n    private focusTab(index: number) {\n        const ref = `tabs-${index}`;\n        const tab = findDOMNode(this.refs[ref]) as HTMLElement;\n        tab.focus();\n    }\n\n    private getFocusedTabIndex() {\n        const focusedElement = document.activeElement;\n        if (focusedElement != null && focusedElement.classList.contains(Classes.TAB)) {\n            const tabId = focusedElement.id;\n            return this.tabIds.indexOf(tabId);\n        }\n        return -1;\n    }\n\n    private getTabs() {\n        if (this.props.children == null) {\n            return [];\n        }\n        let tabs: React.ReactElement<ITabProps>[] = [];\n        if (React.Children.count(this.props.children) > 0) {\n            const firstChild = React.Children.toArray(this.props.children)[0] as React.ReactElement<any>;\n            if (firstChild != null) {\n                React.Children.forEach(firstChild.props.children, (tabListChild: React.ReactElement<any>) => {\n                    if (tabListChild.type === Tab) {\n                        tabs.push(tabListChild);\n                    }\n                });\n            }\n        }\n        return tabs;\n    }\n\n    private getTabsCount() {\n        return this.getTabs().length;\n    }\n\n    private getPanelsCount() {\n        if (this.props.children == null) {\n            return 0;\n        }\n\n        let index = 0;\n        let panelCount = 0;\n        React.Children.forEach(this.props.children, (child: React.ReactElement<any>) => {\n            if (child.type === TabPanel) {\n                panelCount++;\n            }\n            index++;\n        });\n\n        return panelCount;\n    }\n\n    private getStateFromProps(props: ITabsProps): ITabsState {\n        const { selectedTabIndex, initialSelectedTabIndex } = props;\n\n        if (this.isValidTabIndex(selectedTabIndex)) {\n            return { selectedTabIndex };\n        } else if (this.isValidTabIndex(initialSelectedTabIndex) && this.state.selectedTabIndex == null) {\n            return { selectedTabIndex: initialSelectedTabIndex };\n        } else {\n            return this.state;\n        }\n    }\n\n    private isTabDisabled(index: number) {\n        const tab = this.getTabs()[index];\n        return tab != null && tab.props.isDisabled;\n    }\n\n    private isValidTabIndex(index: number) {\n        return index != null && index >= 0 && index < this.getTabsCount();\n    }\n\n    /**\n     * Updates the component's state if uncontrolled and calls onChange.\n     */\n    private setSelectedTabIndex(index: number) {\n        if (index === this.state.selectedTabIndex || !this.isValidTabIndex(index)) {\n            return;\n        }\n\n        const prevSelectedIndex = this.state.selectedTabIndex;\n\n        if (this.props.selectedTabIndex == null) {\n            this.setState({\n                selectedTabIndex: index,\n            });\n        }\n\n        if (Utils.isFunction(this.props.onChange)) {\n            this.props.onChange(index, prevSelectedIndex);\n        }\n    }\n}\n\nlet tabCount = 0;\nfunction generateTabId() {\n    return `pt-tab-${tabCount++}`;\n}\n\nlet panelCount = 0;\nfunction generatePanelId() {\n    return `pt-tab-panel-${panelCount++}`;\n}\n\nexport var TabsFactory = React.createFactory(Tabs);\n"],"sourceRoot":"/source/"}
{
"name": "@blueprintjs/core",
"version": "0.1.0",
"version": "1.0.0",
"main": "dist/index.js",

@@ -5,0 +5,0 @@ "typings": "dist/index.d.ts",

@@ -1,10 +0,15 @@

Blueprint v2
------------
<img height="204" src="https://cloud.githubusercontent.com/assets/464822/20228152/d3f36dc2-a804-11e6-80ff-51ada2d13ea7.png">
> Palantir's CSS framework & UI library for web applications.
# [Blueprint](http://blueprintjs.com/) Core Components
## Usage
Blueprint is a React UI toolkit for the Web.
This package contains the core set of UI components as CSS and React code.
## Installation
```
npm install --save @blueprintjs/core
```
### [Full Documentation](http://blueprintjs.com/docs) | [Source Code](https://github.com/palantir/blueprint)

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Packages

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc