@redocly/theme
Version:
Shared UI components lib
69 lines • 3.27 kB
JavaScript
;
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;
};
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.ToggleSubtitle = exports.ToggleWrapper = void 0;
exports.CodeToggle = CodeToggle;
const react_1 = __importStar(require("react"));
const styled_components_1 = __importDefault(require("styled-components"));
const contexts_1 = require("../../../core/contexts");
const CodeStep_1 = require("../../../markdoc/components/CodeWalkthrough/CodeStep");
const Switch_1 = require("../../../components/Switch/Switch");
function CodeToggle(props) {
const { id, label, description, children } = props;
const { getControlState, changeControlState } = (0, react_1.useContext)(contexts_1.CodeWalkthroughControlsStateContext);
const toggleState = getControlState(id);
if (!(toggleState && toggleState.render && typeof toggleState.value === 'boolean')) {
return null;
}
const checked = toggleState.value;
return (react_1.default.createElement(exports.ToggleWrapper, { "data-component-name": "Markdoc/CodeWalkthrough/CodeToggle" },
react_1.default.createElement(ToggleContentWrapper, null,
react_1.default.createElement(exports.ToggleSubtitle, null,
react_1.default.createElement(Switch_1.Switch, { value: checked, onChange: (newValue) => changeControlState(id, newValue) }),
react_1.default.createElement("div", null, label)),
description ? (react_1.default.createElement("div", null, description.map((paragraph, idx) => (react_1.default.createElement(react_1.default.Fragment, { key: idx }, paragraph))))) : null),
checked ? children : null));
}
exports.ToggleWrapper = styled_components_1.default.div `
${CodeStep_1.StepWrapper} {
margin-left: 0;
}
`;
exports.ToggleSubtitle = styled_components_1.default.div `
display: flex;
gap: var(--spacing-sm);
align-items: center;
font-weight: var(--font-weight-bold);
`;
const ToggleContentWrapper = styled_components_1.default.div `
display: flex;
flex-direction: column;
gap: var(--spacing-xs);
padding: var(--spacing-xs) 0;
`;
//# sourceMappingURL=CodeToggle.js.map