UNPKG

office-ui-fabric-react

Version:

Reusable React components for building experiences for Office 365.

82 lines 4.89 kB
import * as tslib_1 from "tslib"; import * as React from 'react'; import { Coachmark } from '../Coachmark'; import { TeachingBubbleContent } from 'office-ui-fabric-react/lib/TeachingBubble'; import { DefaultButton } from 'office-ui-fabric-react/lib/Button'; import { Dropdown } from 'office-ui-fabric-react/lib/Dropdown'; import { BaseComponent, classNamesFunction, createRef } from 'office-ui-fabric-react/lib/Utilities'; var CoachmarkBasicExample = /** @class */ (function (_super) { tslib_1.__extends(CoachmarkBasicExample, _super); function CoachmarkBasicExample(props) { var _this = _super.call(this, props) || this; _this._targetButton = createRef(); _this._onDismiss = function () { _this.setState({ isCoachmarkVisible: false }); }; _this._onDropdownChange = function (event, option) { _this.setState({ coachmarkPosition: option.data }); }; _this._onShowMenuClicked = function () { _this.setState({ isCoachmarkVisible: !_this.state.isCoachmarkVisible }); }; _this.state = { isCoachmarkVisible: false, coachmarkPosition: 7 /* bottomAutoEdge */ }; return _this; } CoachmarkBasicExample.prototype.render = function () { var isCoachmarkVisible = this.state.isCoachmarkVisible; var getClassNames = classNamesFunction(); var classNames = getClassNames(function () { return { dropdownContainer: { maxWidth: '400px' }, buttonContainer: { marginTop: '30px', display: 'inline-block' } }; }, {}); var buttonProps = { text: 'Try it' }; var buttonProps2 = { text: 'Try it again' }; return (React.createElement("div", { className: classNames.root }, React.createElement("div", { className: classNames.dropdownContainer }, React.createElement(Dropdown, { label: "Coachmark position", defaultSelectedKey: "H", onFocus: this._onDismiss, options: [ { key: 'A', text: 'Top Left Edge', data: 0 /* topLeftEdge */ }, { key: 'B', text: 'Top Center', data: 1 /* topCenter */ }, { key: 'C', text: 'Top Right Edge', data: 2 /* topRightEdge */ }, { key: 'D', text: 'Top Auto Edge', data: 3 /* topAutoEdge */ }, { key: 'E', text: 'Bottom Left Edge', data: 4 /* bottomLeftEdge */ }, { key: 'F', text: 'Bottom Center', data: 5 /* bottomCenter */ }, { key: 'G', text: 'Bottom Right Edge', data: 6 /* bottomRightEdge */ }, { key: 'H', text: 'Bottom Auto Edge', data: 7 /* bottomAutoEdge */ }, { key: 'I', text: 'Left Top Edge', data: 8 /* leftTopEdge */ }, { key: 'J', text: 'Left Center', data: 9 /* leftCenter */ }, { key: 'K', text: 'Left Bottom Edge', data: 10 /* leftBottomEdge */ }, { key: 'L', text: 'Right Top Edge', data: 11 /* rightTopEdge */ }, { key: 'M', text: 'Right Center', data: 12 /* rightCenter */ }, { key: 'N', text: 'Right Bottom Edge', data: 13 /* rightBottomEdge */ } ], onChange: this._onDropdownChange })), React.createElement("div", { className: classNames.buttonContainer, ref: this._targetButton }, React.createElement(DefaultButton, { onClick: this._onShowMenuClicked, text: isCoachmarkVisible ? 'Hide Coachmark' : 'Show Coachmark' })), isCoachmarkVisible && (React.createElement(Coachmark, { target: this._targetButton.current, positioningContainerProps: { directionalHint: this.state.coachmarkPosition }, ariaAlertText: "A Coachmark has appeared", ariaDescribedBy: 'coachmark-desc1', ariaLabelledBy: 'coachmark-label1', ariaDescribedByText: 'Press enter or alt + C to open the Coachmark notification', ariaLabelledByText: 'Coachmark notification' }, React.createElement(TeachingBubbleContent, { headline: "Example Title", hasCloseIcon: true, closeButtonAriaLabel: "Close", primaryButtonProps: buttonProps, secondaryButtonProps: buttonProps2, onDismiss: this._onDismiss, ariaDescribedBy: 'example-description1', ariaLabelledBy: 'example-label1' }, "Welcome to the land of Coachmarks!"))))); }; return CoachmarkBasicExample; }(BaseComponent)); export { CoachmarkBasicExample }; //# sourceMappingURL=Coachmark.Basic.Example.js.map