UNPKG

infinity-forge

Version:
71 lines 3.16 kB
"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 () { var ownKeys = function(o) { ownKeys = Object.getOwnPropertyNames || function (o) { var ar = []; for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k; return ar; }; return ownKeys(o); }; return function (mod) { if (mod && mod.__esModule) return mod; var result = {}; if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]); __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.SideBar = SideBar; var jsx_runtime_1 = require("react/jsx-runtime"); var react_1 = require("react"); var react_dom_1 = __importDefault(require("react-dom")); var S = __importStar(require("./styles.js")); function SideBar(_a) { var children = _a.children, maxWidth = _a.maxWidth, open = _a.open, setOpen = _a.setOpen, _b = _a.direction, direction = _b === void 0 ? 'right' : _b, overlay = _a.overlay; var _c = (0, react_1.useState)(false), mounted = _c[0], setMounted = _c[1]; (0, react_1.useEffect)(function () { // Garantir que o componente só será montado no lado do cliente setMounted(true); return function () { return setMounted(false); }; }, []); var handleClose = function () { if (overlay) { setOpen(false); } }; var handleContentClick = function (event) { event.stopPropagation(); }; if (!mounted) { // Evitar renderização no lado do servidor return null; } var portalTarget = document.getElementById('__next'); if (!portalTarget) { console.error('Elemento #__next não encontrado para montar o portal'); return null; } return react_dom_1.default.createPortal((0, jsx_runtime_1.jsx)(S.SideBar, { "$overlay": overlay, "$open": open, "$maxWidth": maxWidth, "$direction": direction, onClick: handleClose, className: 'side_bar_infinity_forge', children: (0, jsx_runtime_1.jsx)("aside", { onClick: handleContentClick, className: 'content', children: open && children }) }), portalTarget); } //# sourceMappingURL=index.js.map