@cimpress/react-components
Version:
React components to support the MCP styleguide
109 lines • 5.64 kB
JavaScript
"use strict";
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
Object.defineProperty(exports, "__esModule", { value: true });
const react_1 = __importStar(require("react"));
const react_components_1 = require("@cimpress/react-components");
class SpinnerDemo extends react_1.Component {
constructor() {
super(...arguments);
Object.defineProperty(this, "state", {
enumerable: true,
configurable: true,
writable: true,
value: {
spinnerHidden: false,
showFullPage: false,
offset: 0,
}
});
Object.defineProperty(this, "toggleFullPage", {
enumerable: true,
configurable: true,
writable: true,
value: () => {
this.setState(prevState => ({ showFullPage: !prevState.showFullPage }));
}
});
Object.defineProperty(this, "toggleSlowSpinner", {
enumerable: true,
configurable: true,
writable: true,
value: () => {
this.setState(prevState => ({ spinnerHidden: !prevState.spinnerHidden }));
}
});
Object.defineProperty(this, "handleSpinnerOffset", {
enumerable: true,
configurable: true,
writable: true,
value: offset => {
this.setState(prevState => ({ offset: (offset + prevState.offset) % 1 }));
}
});
}
render() {
const { spinnerHidden, offset } = this.state;
return (react_1.default.createElement("div", null,
react_1.default.createElement("div", { className: "row" },
react_1.default.createElement("div", { className: "col-md-4" },
"Large (default) Size (72px):",
react_1.default.createElement(react_components_1.Spinner, null)),
react_1.default.createElement("div", { className: "col-md-4" },
"Medium (38px):",
react_1.default.createElement(react_components_1.Spinner, { size: "medium" })),
react_1.default.createElement("div", { className: "col-md-4" },
"Small Size (16px):",
react_1.default.createElement(react_components_1.Spinner, { size: "small" }))),
react_1.default.createElement("div", { className: "row", style: { paddingTop: '15px' } },
react_1.default.createElement("div", { className: "col-md-4" },
"Default Duration (2):",
react_1.default.createElement(react_components_1.Spinner, null)),
react_1.default.createElement("div", { className: "col-md-4" },
react_1.default.createElement("div", null, "Full Page Center:"),
react_1.default.createElement("button", { onClick: this.toggleFullPage, className: "btn btn-primary" }, "Show spinner"),
this.state.showFullPage ? react_1.default.createElement(react_components_1.Spinner, { fullPage: true }) : ''),
react_1.default.createElement("div", { className: "col-md-4" },
"Fast Duration (1):",
react_1.default.createElement(react_components_1.Spinner, { duration: 1 }))),
react_1.default.createElement("div", { className: "row", style: { paddingTop: '15px' } },
react_1.default.createElement("div", { className: "col-md-4" },
react_1.default.createElement("div", null, "Slow Duration (8):"),
react_1.default.createElement("div", null, "Utilize the offset feature to minimize jitter."),
spinnerHidden ? (react_1.default.createElement("div", { style: {
height: '72px',
width: '72px',
fontSize: '22px',
color: react_components_1.colors.platinum,
display: 'flex',
justifyContent: 'center',
alignItems: 'center',
} },
Math.round(this.state.offset * 100),
"%")) : (react_1.default.createElement(react_components_1.Spinner, { duration: 8, offset: offset, handleOffset: this.handleSpinnerOffset })),
react_1.default.createElement("button", { onClick: this.toggleSlowSpinner, className: "btn btn-primary" }, this.state.spinnerHidden ? 'Reveal' : 'Hide')))));
}
}
exports.default = SpinnerDemo;
//# sourceMappingURL=spinner.js.map