@launchmenu/core
Version:
An environment for visual keyboard controlled applets
187 lines • 16.1 kB
JavaScript
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
}) : (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 });
exports.StackView = void 0;
const react_1 = __importStar(require("react"));
const Transition_1 = require("./transitions/Transition");
const getViewStackItemElement_1 = require("./getViewStackItemElement");
const uuid_1 = require("uuid");
const findStackChanges_1 = require("../../../context/findStackChanges");
const model_react_1 = require("model-react");
/**
* Retrieves the view for a given stack item
* @param item The item to get the view for
* @returns THe view
*/
function getView(item) {
if ("close" in item.value)
return;
let view;
if ("view" in item.value)
view = item.value.view;
else
view = item.value;
return view;
}
/**
* Updates the children array, replacing, adding or removing children
* @param items The new items array
* @param prevItems The old items array
* @param children The children list to modify
* @param defaultTransitions The default transitions to be used
* @param skipOpening Whether to skip opening animation for the new items
*/
function updateChildren(items, prevItems, children, defaultTransitions, skipOpening) {
const { added, removed, updated } = findStackChanges_1.findStackChanges(prevItems, items);
const childMap = {};
children.forEach(item => {
if (item.element)
childMap[item.id] = item;
});
updated.forEach(({ index, oldItem, newItem }) => {
const child = childMap[oldItem.ID];
const view = getView(newItem);
if (child && view)
child.element = view;
});
removed.forEach(({ item }) => {
const child = childMap[item.ID];
if (child)
child.element = undefined;
});
added.forEach(({ index, item }) => {
if ("close" in item.value)
return;
// Find the index to add the item at
let childIndex;
if (index > 0) {
const itemBefore = items[index - 1];
childIndex = children.findIndex(({ id }) => id == itemBefore.ID) + 1;
}
else {
childIndex = 0;
}
const view = getView(item);
const { transparent, transitions } = "transparent" in item.value || "transitions" in item.value
? item.value
: { transparent: false, transitions: {} };
// Add the child or replace a previous child
const currentChild = children[childIndex];
if (currentChild && currentChild.element == undefined && !currentChild.closing) {
currentChild.element = view;
currentChild.id = item.ID;
currentChild.wasTransparent =
currentChild.wasTransparent || currentChild.transparent;
currentChild.transparent = transparent !== null && transparent !== void 0 ? transparent : false;
currentChild.transitions = { ...defaultTransitions, ...transitions };
}
else {
children.splice(childIndex, 0, {
key: uuid_1.v4(),
id: item.ID,
element: view,
closing: false,
opening: skipOpening ? false : true,
wasTransparent: false,
transparent: transparent !== null && transparent !== void 0 ? transparent : false,
transitions: { ...defaultTransitions, ...transitions },
skipOpening,
});
}
});
removed.forEach(({ item }) => {
const child = children.find(({ id, closing, element }) => id == item.ID && !closing && !element);
if (child)
child.closing = true;
});
}
/**
* Visualizes a stack of views
*/
exports.StackView = react_1.memo(({ stackGetter, smartHide = true, ChangeTransitionComp, CloseTransitionComp, OpenTransitionComp, }) => {
var _a;
// Retrieve the items
const [h] = model_react_1.useDataHook();
const items = stackGetter(h);
const prevItems = react_1.useRef();
// Keep track of the children to render
const childrenRef = react_1.useRef([]);
// Update the elements to render when the items array changes
if (prevItems.current != items) {
updateChildren(items, (_a = prevItems.current) !== null && _a !== void 0 ? _a : [], childrenRef.current, {
Open: OpenTransitionComp !== null && OpenTransitionComp !== void 0 ? OpenTransitionComp : Transition_1.defaultTransitions.Open,
Change: ChangeTransitionComp !== null && ChangeTransitionComp !== void 0 ? ChangeTransitionComp : Transition_1.defaultTransitions.Change,
Close: CloseTransitionComp !== null && CloseTransitionComp !== void 0 ? CloseTransitionComp : Transition_1.defaultTransitions.Close,
}, prevItems.current == undefined);
prevItems.current = items;
}
// Handle transition changes
const [_, _forceUpdate] = react_1.useState(false);
const forceUpdate = () => _forceUpdate(a => !a);
const onClose = (key) => {
const children = childrenRef.current;
const index = children.findIndex(({ key: k }) => k == key);
if (index != -1) {
children.splice(index, 1);
forceUpdate();
}
};
const onOpen = (key) => {
const children = childrenRef.current;
const child = children.find(({ key: k }) => k == key);
if (child) {
child.opening = false;
forceUpdate();
}
};
const onChange = (key) => {
const children = childrenRef.current;
const child = children.find(({ key: k }) => k == key);
if (child) {
child.wasTransparent = false;
forceUpdate();
}
};
// Find the first index that needs to be rendered
const children = childrenRef.current;
let firstOpaqueIndex = smartHide ? children.length : 0;
let childTransparent = true;
while (childTransparent && --firstOpaqueIndex >= 0) {
const child = children[firstOpaqueIndex];
childTransparent =
child.opening ||
child.closing ||
child.transparent ||
child.wasTransparent;
}
// Render the children
return (react_1.default.createElement(react_1.default.Fragment, null, childrenRef.current.map(({ key, id, element, transitions, skipOpening }, index) => {
const props = {
key: id,
onTop: index == childrenRef.current.length,
stack: items,
index,
};
const el = element && getViewStackItemElement_1.getViewStackItemElement(element, props);
return (react_1.default.createElement(Transition_1.Transition, { key: key, hidden: index < firstOpaqueIndex, onClose: () => onClose(key), onChange: () => onChange(key), onOpen: () => onOpen(key), skipMountAnimation: skipOpening, ChangeTransitionComp: transitions.Change, CloseTransitionComp: transitions.Close, OpenTransitionComp: transitions.Open }, el));
})));
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"StackView.js","sourceRoot":"","sources":["../../../../src/components/context/stacks/StackView.tsx"],"names":[],"mappings":"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"}
;