UNPKG

typescript-windows

Version:

Typescript React components for draggable and resizable windows.

213 lines (171 loc) 25.6 kB
"use strict"; function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); } Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _react = _interopRequireWildcard(require("react")); var _reactUseDimensions = _interopRequireDefault(require("react-use-dimensions")); var _reactJss = require("react-jss"); var _useBreakpoint2 = _interopRequireDefault(require("use-breakpoint")); var _useGrids2 = require("../utils/useGrids"); var _getLocalStorage = require("../utils/getLocalStorage"); var _setLocalStorage = require("../utils/setLocalStorage"); var _styles = require("./styles"); var _WindowsProvider = require("./WindowsProvider"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; } function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); } function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && Symbol.iterator in Object(iter)) return Array.from(iter); } function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); } function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); } function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; } function _iterableToArrayLimit(arr, i) { if (typeof Symbol === "undefined" || !(Symbol.iterator in Object(arr))) return; var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } var Windows = function Windows(props) { var id = props.id, background = props.background, children = props.children, taskbar = props.taskbar, taskbarLocation = props.taskbarLocation, step = props.step, breakPoints = props.breakPoints, gridsCount = props.gridsCount, gridsGap = props.gridsGap, styles = props.styles; var classes = (0, _styles.useStyles)(styles, taskbarLocation)(); var _useGrids = (0, _useGrids2.useGrids)(gridsCount, gridsGap), gridsWidth = _useGrids.gridsWidth, gridsHeight = _useGrids.gridsHeight; var _useDimensions = (0, _reactUseDimensions.default)(), _useDimensions2 = _slicedToArray(_useDimensions, 2), headerRef = _useDimensions2[0], headerHeight = _useDimensions2[1].height; var _useContext = (0, _react.useContext)(_WindowsProvider.StateContext), state = _useContext.state, setState = _useContext.setState; var _useBreakpoint = (0, _useBreakpoint2.default)(breakPoints, "desktop"), breakpoint = _useBreakpoint.breakpoint; var dBoxMinimizes = children.reduce(function (total, item) { var _item$props = item.props, id = _item$props.id, startMinimized = _item$props.startMinimized; startMinimized.tablet = startMinimized.tablet === undefined ? startMinimized.mobile : startMinimized.tablet; startMinimized.desktop = startMinimized.desktop === undefined ? startMinimized.tablet : startMinimized.desktop; return _objectSpread(_objectSpread({}, total), {}, _defineProperty({}, id, startMinimized)); }, {}); var iWindowSizes = (0, _getLocalStorage.getLocalStorage)(id, "sizes", {}); var iWindowZIndexes = (0, _getLocalStorage.getLocalStorage)(id, "zIndexes", {}); var iWindowLocations = (0, _getLocalStorage.getLocalStorage)(id, "locations", {}); var iWindowMaximizes = (0, _getLocalStorage.getLocalStorage)(id, "maximizes", {}); var iWindowMinimizes = (0, _getLocalStorage.getLocalStorage)(id, "minimizes", dBoxMinimizes); var _useState = (0, _react.useState)(iWindowSizes), _useState2 = _slicedToArray(_useState, 2), windowSizes = _useState2[0], setWindowSizes = _useState2[1]; var _useState3 = (0, _react.useState)(iWindowZIndexes), _useState4 = _slicedToArray(_useState3, 2), windowZIndexes = _useState4[0], setWindowZIndexes = _useState4[1]; var _useState5 = (0, _react.useState)(iWindowLocations), _useState6 = _slicedToArray(_useState5, 2), windowLocations = _useState6[0], setWindowLocations = _useState6[1]; var _useState7 = (0, _react.useState)(iWindowMaximizes), _useState8 = _slicedToArray(_useState7, 2), windowMaximizes = _useState8[0], setWindowMaximizes = _useState8[1]; var _useState9 = (0, _react.useState)(iWindowMinimizes), _useState10 = _slicedToArray(_useState9, 2), windowMinimizes = _useState10[0], setWindowMinimizes = _useState10[1]; var _useState11 = (0, _react.useState)([]), _useState12 = _slicedToArray(_useState11, 2), taskbarItemsIn = _useState12[0], setTaskbarItemsIn = _useState12[1]; var _useState13 = (0, _react.useState)([]), _useState14 = _slicedToArray(_useState13, 2), taskbarItemsOut = _useState14[0], setTaskbarItemsOut = _useState14[1]; (0, _react.useEffect)(function () { (0, _setLocalStorage.setLocalStorage)(id, "sizes", windowSizes); }, [id, windowSizes]); (0, _react.useEffect)(function () { (0, _setLocalStorage.setLocalStorage)(id, "zIndexes", windowZIndexes); }, [id, windowZIndexes]); (0, _react.useEffect)(function () { (0, _setLocalStorage.setLocalStorage)(id, "locations", windowLocations); }, [id, windowLocations]); (0, _react.useEffect)(function () { (0, _setLocalStorage.setLocalStorage)(id, "maximizes", windowMaximizes); }, [id, windowMaximizes]); (0, _react.useEffect)(function () { (0, _setLocalStorage.setLocalStorage)(id, "minimizes", windowMinimizes); }, [id, windowMinimizes]); (0, _react.useEffect)(function () { setState(_objectSpread(_objectSpread({}, state), {}, { taskbar: taskbar, step: step, breakPoints: breakPoints, gridsGap: gridsGap, gridsWidth: gridsWidth, gridsHeight: gridsHeight, headerRef: headerRef, headerHeight: headerHeight, windowSizes: windowSizes, windowZIndexes: windowZIndexes, windowLocations: windowLocations, windowMaximizes: windowMaximizes, windowMinimizes: windowMinimizes, setWindowSizes: setWindowSizes, setWindowZIndexes: setWindowZIndexes, setWindowLocations: setWindowLocations, setWindowMaximizes: setWindowMaximizes, setWindowMinimizes: setWindowMinimizes })); var taskbarItemsIn = []; var taskbarItemsOut = []; children.forEach(function (window) { if (windowMinimizes[window.props.id][breakpoint] && taskbar) { taskbarItemsIn = [].concat(_toConsumableArray(taskbarItemsIn), [window]); } else { taskbarItemsOut = [].concat(_toConsumableArray(taskbarItemsOut), [window]); } }); setTaskbarItemsIn(taskbarItemsIn); setTaskbarItemsOut(taskbarItemsOut); // eslint-disable-next-line react-hooks/exhaustive-deps }, [windowSizes, windowZIndexes, windowLocations, windowMaximizes, windowMinimizes, gridsWidth, gridsHeight, headerHeight]); return /*#__PURE__*/_react.default.createElement(_reactJss.ThemeProvider, { theme: {} }, /*#__PURE__*/_react.default.createElement("div", { id: id, className: classes["tw-windows"] }, /*#__PURE__*/_react.default.createElement("div", { className: "tw-background" }, background), taskbarItemsOut, /*#__PURE__*/_react.default.createElement("div", { className: "tw-taskbar" }, taskbarItemsIn))); }; Windows.defaultProps = { background: null, taskbar: true, taskbarLocation: "bottom", step: 1, breakPoints: { mobile: 0, tablet: 600, desktop: 1280 }, gridsGap: 10, gridsCount: 12 }; var _default = Windows; exports.default = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/Windows.tsx"],"names":["Windows","props","id","background","children","taskbar","taskbarLocation","step","breakPoints","gridsCount","gridsGap","styles","classes","gridsWidth","gridsHeight","headerRef","headerHeight","height","StateContext","state","setState","breakpoint","dBoxMinimizes","reduce","total","item","startMinimized","tablet","undefined","mobile","desktop","iWindowSizes","iWindowZIndexes","iWindowLocations","iWindowMaximizes","iWindowMinimizes","windowSizes","setWindowSizes","windowZIndexes","setWindowZIndexes","windowLocations","setWindowLocations","windowMaximizes","setWindowMaximizes","windowMinimizes","setWindowMinimizes","taskbarItemsIn","setTaskbarItemsIn","taskbarItemsOut","setTaskbarItemsOut","forEach","window","defaultProps"],"mappings":"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","sourcesContent":["import React, { useEffect, useState, useContext } from \"react\";\r\nimport useDimensions from \"react-use-dimensions\";\r\nimport { ThemeProvider, DefaultTheme } from \"react-jss\";\r\nimport useBreakpoint from \"use-breakpoint\";\r\n\r\nimport { useGrids } from \"../utils/useGrids\";\r\nimport { getLocalStorage } from \"../utils/getLocalStorage\";\r\nimport { setLocalStorage } from \"../utils/setLocalStorage\";\r\nimport { useStyles } from \"./styles\";\r\nimport { StateContext } from \"./WindowsProvider\";\r\nimport { Styles, BreakPoints, TaskbarLocation } from \"./index.d\";\r\n\r\nexport interface Props {\r\n  id: string;\r\n  background: JSX.Element | null;\r\n  children: JSX.Element[];\r\n  taskbar: boolean;\r\n  taskbarLocation: TaskbarLocation;\r\n  step: number;\r\n  breakPoints: BreakPoints;\r\n  gridsGap: number;\r\n  gridsCount: number;\r\n  styles?: Partial<Styles>;\r\n}\r\n\r\nconst Windows = (props: Props) => {\r\n  const {\r\n    id,\r\n    background,\r\n    children,\r\n    taskbar,\r\n    taskbarLocation,\r\n    step,\r\n    breakPoints,\r\n    gridsCount,\r\n    gridsGap,\r\n    styles,\r\n  } = props;\r\n\r\n  const classes = useStyles(styles, taskbarLocation)();\r\n  const { gridsWidth, gridsHeight } = useGrids(gridsCount, gridsGap);\r\n  const [headerRef, { height: headerHeight }] = useDimensions();\r\n  const { state, setState } = useContext(StateContext);\r\n  const { breakpoint } = useBreakpoint(breakPoints, \"desktop\");\r\n\r\n  const dBoxMinimizes = children.reduce((total: object, item: JSX.Element) => {\r\n    const { id, startMinimized } = item.props;\r\n\r\n    startMinimized.tablet =\r\n      startMinimized.tablet === undefined\r\n        ? startMinimized.mobile\r\n        : startMinimized.tablet;\r\n\r\n    startMinimized.desktop =\r\n      startMinimized.desktop === undefined\r\n        ? startMinimized.tablet\r\n        : startMinimized.desktop;\r\n\r\n    return { ...total, [id]: startMinimized };\r\n  }, {});\r\n\r\n  const iWindowSizes = getLocalStorage(id, \"sizes\", {});\r\n  const iWindowZIndexes = getLocalStorage(id, \"zIndexes\", {});\r\n  const iWindowLocations = getLocalStorage(id, \"locations\", {});\r\n  const iWindowMaximizes = getLocalStorage(id, \"maximizes\", {});\r\n  const iWindowMinimizes = getLocalStorage(id, \"minimizes\", dBoxMinimizes);\r\n\r\n  const [windowSizes, setWindowSizes] = useState(iWindowSizes);\r\n  const [windowZIndexes, setWindowZIndexes] = useState(iWindowZIndexes);\r\n  const [windowLocations, setWindowLocations] = useState(iWindowLocations);\r\n  const [windowMaximizes, setWindowMaximizes] = useState(iWindowMaximizes);\r\n  const [windowMinimizes, setWindowMinimizes] = useState(iWindowMinimizes);\r\n  const [taskbarItemsIn, setTaskbarItemsIn] = useState<JSX.Element[]>([]);\r\n  const [taskbarItemsOut, setTaskbarItemsOut] = useState<JSX.Element[]>([]);\r\n\r\n  useEffect(() => {\r\n    setLocalStorage(id, \"sizes\", windowSizes);\r\n  }, [id, windowSizes]);\r\n\r\n  useEffect(() => {\r\n    setLocalStorage(id, \"zIndexes\", windowZIndexes);\r\n  }, [id, windowZIndexes]);\r\n\r\n  useEffect(() => {\r\n    setLocalStorage(id, \"locations\", windowLocations);\r\n  }, [id, windowLocations]);\r\n\r\n  useEffect(() => {\r\n    setLocalStorage(id, \"maximizes\", windowMaximizes);\r\n  }, [id, windowMaximizes]);\r\n\r\n  useEffect(() => {\r\n    setLocalStorage(id, \"minimizes\", windowMinimizes);\r\n  }, [id, windowMinimizes]);\r\n\r\n  useEffect(() => {\r\n    setState({\r\n      ...state,\r\n      taskbar,\r\n      step,\r\n      breakPoints,\r\n      gridsGap,\r\n      gridsWidth,\r\n      gridsHeight,\r\n      headerRef,\r\n      headerHeight,\r\n      windowSizes,\r\n      windowZIndexes,\r\n      windowLocations,\r\n      windowMaximizes,\r\n      windowMinimizes,\r\n      setWindowSizes,\r\n      setWindowZIndexes,\r\n      setWindowLocations,\r\n      setWindowMaximizes,\r\n      setWindowMinimizes,\r\n    });\r\n\r\n    let taskbarItemsIn: JSX.Element[] = [];\r\n    let taskbarItemsOut: JSX.Element[] = [];\r\n\r\n    children.forEach((window) => {\r\n      if (windowMinimizes[window.props.id][breakpoint] && taskbar) {\r\n        taskbarItemsIn = [...taskbarItemsIn, window];\r\n      } else {\r\n        taskbarItemsOut = [...taskbarItemsOut, window];\r\n      }\r\n    });\r\n\r\n    setTaskbarItemsIn(taskbarItemsIn);\r\n    setTaskbarItemsOut(taskbarItemsOut);\r\n    // eslint-disable-next-line react-hooks/exhaustive-deps\r\n  }, [\r\n    windowSizes,\r\n    windowZIndexes,\r\n    windowLocations,\r\n    windowMaximizes,\r\n    windowMinimizes,\r\n    gridsWidth,\r\n    gridsHeight,\r\n    headerHeight,\r\n  ]);\r\n\r\n  return (\r\n    <ThemeProvider theme={{} as DefaultTheme}>\r\n      <div id={id} className={classes[\"tw-windows\"]}>\r\n        <div className=\"tw-background\">{background}</div>\r\n\r\n        {taskbarItemsOut}\r\n\r\n        <div className=\"tw-taskbar\">{taskbarItemsIn}</div>\r\n      </div>\r\n    </ThemeProvider>\r\n  );\r\n};\r\n\r\nWindows.defaultProps = {\r\n  background: null,\r\n  taskbar: true,\r\n  taskbarLocation: \"bottom\",\r\n  step: 1,\r\n  breakPoints: { mobile: 0, tablet: 600, desktop: 1280 },\r\n  gridsGap: 10,\r\n  gridsCount: 12,\r\n} as Partial<Props>;\r\n\r\nexport default Windows;\r\n"]}