All Downloads are FREE. Search and download functionalities are using the official Maven repository.

theme.keycloak.v2.admin.resources.assets.Droppable-BQdKpouo.js.map Maven / Gradle / Ivy

There is a newer version: 26.0.7
Show newest version
{"version":3,"file":"Droppable-BQdKpouo.js","sources":["../../../../../node_modules/.pnpm/@[email protected][email protected][email protected][email protected]/node_modules/@patternfly/react-core/dist/esm/components/DataList/DataListControl.js","../../../../../node_modules/.pnpm/@[email protected][email protected][email protected][email protected]/node_modules/@patternfly/react-core/dist/esm/components/DataList/DataListDragButton.js","../../../../../node_modules/.pnpm/@[email protected][email protected][email protected][email protected]/node_modules/@patternfly/react-core/dist/esm/components/DragDrop/DragDrop.js","../../../../../node_modules/.pnpm/@[email protected]/node_modules/@patternfly/react-styles/css/components/DragDrop/drag-drop.mjs","../../../../../node_modules/.pnpm/@[email protected][email protected][email protected][email protected]/node_modules/@patternfly/react-core/dist/esm/components/DragDrop/DroppableContext.js","../../../../../node_modules/.pnpm/@[email protected]/node_modules/@patternfly/react-tokens/dist/esm/c_draggable_m_dragging_BackgroundColor.js","../../../../../node_modules/.pnpm/@[email protected][email protected][email protected][email protected]/node_modules/@patternfly/react-core/dist/esm/components/DragDrop/Draggable.js","../../../../../node_modules/.pnpm/@[email protected][email protected][email protected][email protected]/node_modules/@patternfly/react-core/dist/esm/components/DragDrop/Droppable.js"],"sourcesContent":["import { __rest } from \"tslib\";\nimport * as React from 'react';\nimport { css } from '@patternfly/react-styles';\nimport styles from '@patternfly/react-styles/css/components/DataList/data-list.mjs';\nexport const DataListControl = (_a) => {\n    var { children, className = '' } = _a, props = __rest(_a, [\"children\", \"className\"]);\n    return (React.createElement(\"div\", Object.assign({ className: css(styles.dataListItemControl, className) }, props), children));\n};\nDataListControl.displayName = 'DataListControl';\n//# sourceMappingURL=DataListControl.js.map","import { __rest } from \"tslib\";\nimport * as React from 'react';\nimport { css } from '@patternfly/react-styles';\nimport styles from '@patternfly/react-styles/css/components/DataList/data-list.mjs';\nimport GripVerticalIcon from '@patternfly/react-icons/dist/esm/icons/grip-vertical-icon';\nexport const DataListDragButton = (_a) => {\n    var { className = '', isDisabled = false } = _a, props = __rest(_a, [\"className\", \"isDisabled\"]);\n    return (React.createElement(\"button\", Object.assign({ className: css(styles.dataListItemDraggableButton, isDisabled && styles.modifiers.disabled, className), type: \"button\", disabled: isDisabled }, props),\n        React.createElement(\"span\", { className: css(styles.dataListItemDraggableIcon) },\n            React.createElement(GripVerticalIcon, null))));\n};\nDataListDragButton.displayName = 'DataListDragButton';\n//# sourceMappingURL=DataListDragButton.js.map","import * as React from 'react';\nexport const DragDropContext = React.createContext({\n    onDrag: (_source) => true,\n    onDragMove: (_source, _dest) => { },\n    onDrop: (_source, _dest) => false\n});\nexport const DragDrop = ({ children, onDrag = () => true, onDragMove = () => { }, onDrop = () => false }) => (React.createElement(DragDropContext.Provider, { value: { onDrag, onDragMove, onDrop } }, children));\nDragDrop.displayName = 'DragDrop';\n//# sourceMappingURL=DragDrop.js.map","import './drag-drop.css';\nexport default {\n  \"draggable\": \"pf-v5-c-draggable\",\n  \"droppable\": \"pf-v5-c-droppable\",\n  \"modifiers\": {\n    \"dragging\": \"pf-m-dragging\",\n    \"dragOutside\": \"pf-m-drag-outside\"\n  },\n  \"themeDark\": \"pf-v5-theme-dark\"\n};","import * as React from 'react';\nexport const DroppableContext = React.createContext({\n    zone: 'defaultDroppableZone',\n    droppableId: 'defaultDroppableId'\n});\n//# sourceMappingURL=DroppableContext.js.map","export const c_draggable_m_dragging_BackgroundColor = {\n  \"name\": \"--pf-v5-c-draggable--m-dragging--BackgroundColor\",\n  \"value\": \"#fff\",\n  \"var\": \"var(--pf-v5-c-draggable--m-dragging--BackgroundColor)\"\n};\nexport default c_draggable_m_dragging_BackgroundColor;","import { __rest } from \"tslib\";\nimport * as React from 'react';\nimport { css } from '@patternfly/react-styles';\nimport styles from '@patternfly/react-styles/css/components/DragDrop/drag-drop.mjs';\nimport { DroppableContext } from './DroppableContext';\nimport { DragDropContext } from './DragDrop';\nimport cssDraggingBackgroundColor from '@patternfly/react-tokens/dist/esm/c_draggable_m_dragging_BackgroundColor';\n// Browsers really like being different from each other.\nfunction getDefaultBackground() {\n    const div = document.createElement('div');\n    document.head.appendChild(div);\n    const bg = window.getComputedStyle(div).backgroundColor;\n    document.head.removeChild(div);\n    return bg;\n}\nfunction getInheritedBackgroundColor(el) {\n    const defaultStyle = getDefaultBackground();\n    const backgroundColor = window.getComputedStyle(el).backgroundColor;\n    if (backgroundColor !== defaultStyle) {\n        return backgroundColor;\n    }\n    else if (!el.parentElement) {\n        return defaultStyle;\n    }\n    return getInheritedBackgroundColor(el.parentElement);\n}\nfunction removeBlankDiv(node) {\n    if (node.getAttribute('blankDiv') === 'true') {\n        // eslint-disable-next-line @typescript-eslint/prefer-for-of\n        for (let i = 0; i < node.children.length; i++) {\n            const child = node.children[i];\n            if (child.getAttribute('blankDiv') === 'true') {\n                node.removeChild(child);\n                node.setAttribute('blankDiv', 'false');\n                break;\n            }\n        }\n    }\n}\n// Reset per-element state\nfunction resetDroppableItem(droppableItem) {\n    removeBlankDiv(droppableItem.node);\n    droppableItem.node.classList.remove(styles.modifiers.dragging);\n    droppableItem.node.classList.remove(styles.modifiers.dragOutside);\n    droppableItem.draggableNodes.forEach((n, i) => {\n        n.style.transform = '';\n        n.style.transition = '';\n        droppableItem.draggableNodesRects[i] = n.getBoundingClientRect();\n    });\n}\nfunction overlaps(ev, rect) {\n    return (ev.clientX > rect.x && ev.clientX < rect.x + rect.width && ev.clientY > rect.y && ev.clientY < rect.y + rect.height);\n}\nexport const Draggable = (_a) => {\n    var { className, children, style: styleProp = {}, hasNoWrapper = false } = _a, props = __rest(_a, [\"className\", \"children\", \"style\", \"hasNoWrapper\"]);\n    /* eslint-disable prefer-const */\n    let [style, setStyle] = React.useState(styleProp);\n    /* eslint-enable prefer-const */\n    const [isDragging, setIsDragging] = React.useState(false);\n    const [isValidDrag, setIsValidDrag] = React.useState(true);\n    const { zone, droppableId } = React.useContext(DroppableContext);\n    const { onDrag, onDragMove, onDrop } = React.useContext(DragDropContext);\n    // Some state is better just to leave as vars passed around between various callbacks\n    // You can only drag around one item at a time anyways...\n    let startX = 0;\n    let startY = 0;\n    let index = null; // Index of this draggable\n    let hoveringDroppable;\n    let hoveringIndex = null;\n    let mouseMoveListener;\n    let mouseUpListener;\n    // Makes it so dragging the _bottom_ of the item over the halfway of another moves it\n    let startYOffset = 0;\n    // After item returning to where it started animation completes\n    const onTransitionEnd = (_ev) => {\n        if (isDragging) {\n            setIsDragging(false);\n            setStyle(styleProp);\n        }\n    };\n    function getSourceAndDest() {\n        const hoveringDroppableId = hoveringDroppable ? hoveringDroppable.getAttribute('data-pf-droppableid') : null;\n        const source = {\n            droppableId,\n            index\n        };\n        const dest = hoveringDroppableId !== null && hoveringIndex !== null\n            ? {\n                droppableId: hoveringDroppableId,\n                index: hoveringIndex\n            }\n            : undefined;\n        return { source, dest, hoveringDroppableId };\n    }\n    const onMouseUpWhileDragging = (droppableItems) => {\n        droppableItems.forEach(resetDroppableItem);\n        document.removeEventListener('mousemove', mouseMoveListener);\n        document.removeEventListener('mouseup', mouseUpListener);\n        document.removeEventListener('contextmenu', mouseUpListener);\n        const { source, dest, hoveringDroppableId } = getSourceAndDest();\n        const consumerReordered = onDrop(source, dest);\n        if (consumerReordered && droppableId === hoveringDroppableId) {\n            setIsDragging(false);\n            setStyle(styleProp);\n        }\n        else if (!consumerReordered) {\n            // Animate item returning to where it started\n            setStyle(Object.assign(Object.assign({}, style), { transition: 'transform 0.5s cubic-bezier(0.2, 1, 0.1, 1) 0s', transform: '', background: styleProp.background, boxShadow: styleProp.boxShadow }));\n        }\n    };\n    // This is where the magic happens\n    const onMouseMoveWhileDragging = (ev, droppableItems, blankDivRect) => {\n        // Compute each time what droppable node we are hovering over\n        hoveringDroppable = null;\n        droppableItems.forEach((droppableItem) => {\n            const { node, rect, isDraggingHost, draggableNodes, draggableNodesRects } = droppableItem;\n            if (overlaps(ev, rect)) {\n                // Add valid dropzone style\n                node.classList.remove(styles.modifiers.dragOutside);\n                hoveringDroppable = node;\n                // Check if we need to add a blank div row\n                if (node.getAttribute('blankDiv') !== 'true' && !isDraggingHost) {\n                    const blankDiv = document.createElement('div');\n                    blankDiv.setAttribute('blankDiv', 'true'); // Makes removing easier\n                    let blankDivPos = -1;\n                    for (let i = 0; i < draggableNodes.length; i++) {\n                        const childRect = draggableNodesRects[i];\n                        const isLast = i === draggableNodes.length - 1;\n                        const startOverlaps = childRect.y >= startY - startYOffset;\n                        if ((startOverlaps || isLast) && blankDivPos === -1) {\n                            if (isLast && !startOverlaps) {\n                                draggableNodes[i].after(blankDiv);\n                            }\n                            else {\n                                draggableNodes[i].before(blankDiv);\n                            }\n                            blankDiv.style.height = `${blankDivRect.height}px`;\n                            blankDiv.style.width = `${blankDivRect.width}px`;\n                            node.setAttribute('blankDiv', 'true'); // Makes removing easier\n                            blankDivPos = i;\n                        }\n                        if (blankDivPos !== -1) {\n                            childRect.y += blankDivRect.height;\n                        }\n                    }\n                    // Insert so drag + drop behavior matches single-list case\n                    draggableNodes.splice(blankDivPos, 0, blankDiv);\n                    draggableNodesRects.splice(blankDivPos, 0, blankDivRect);\n                    // Extend hitbox of droppable zone\n                    rect.height += blankDivRect.height;\n                }\n            }\n            else {\n                resetDroppableItem(droppableItem);\n                node.classList.add(styles.modifiers.dragging);\n                node.classList.add(styles.modifiers.dragOutside);\n            }\n        });\n        // Move hovering draggable and style it based on cursor position\n        setStyle(Object.assign(Object.assign({}, style), { transform: `translate(${ev.pageX - startX}px, ${ev.pageY - startY}px)` }));\n        setIsValidDrag(Boolean(hoveringDroppable));\n        // Iterate through sibling draggable nodes to reposition them and store correct hoveringIndex for onDrop\n        hoveringIndex = null;\n        if (hoveringDroppable) {\n            const { draggableNodes, draggableNodesRects } = droppableItems.find((item) => item.node === hoveringDroppable);\n            let lastTranslate = 0;\n            draggableNodes.forEach((n, i) => {\n                n.style.transition = 'transform 0.5s cubic-bezier(0.2, 1, 0.1, 1) 0s';\n                const rect = draggableNodesRects[i];\n                const halfway = rect.y + rect.height / 2;\n                let translateY = 0;\n                // Use offset for more interactive translations\n                if (startY < halfway && ev.pageY + (blankDivRect.height - startYOffset) > halfway) {\n                    translateY -= blankDivRect.height;\n                }\n                else if (startY >= halfway && ev.pageY - startYOffset <= halfway) {\n                    translateY += blankDivRect.height;\n                }\n                // Clever way to find item currently hovering over\n                if ((translateY <= lastTranslate && translateY < 0) || (translateY > lastTranslate && translateY > 0)) {\n                    hoveringIndex = i;\n                }\n                n.style.transform = `translate(0, ${translateY}px`;\n                lastTranslate = translateY;\n            });\n        }\n        const { source, dest } = getSourceAndDest();\n        onDragMove(source, dest);\n    };\n    const onDragStart = (ev) => {\n        // Default HTML drag and drop doesn't allow us to change what the thing\n        // being dragged looks like. Because of this we'll use prevent the default\n        // and use `mouseMove` and `mouseUp` instead\n        ev.preventDefault();\n        if (isDragging) {\n            // still in animation\n            return;\n        }\n        // Cache droppable and draggable nodes and their bounding rects\n        const dragging = ev.target;\n        const rect = dragging.getBoundingClientRect();\n        const droppableNodes = Array.from(document.querySelectorAll(`[data-pf-droppable=\"${zone}\"]`));\n        const droppableItems = droppableNodes.reduce((acc, cur) => {\n            cur.classList.add(styles.modifiers.dragging);\n            const draggableNodes = Array.from(cur.querySelectorAll(`[data-pf-draggable-zone=\"${zone}\"]`));\n            const isDraggingHost = cur.contains(dragging);\n            if (isDraggingHost) {\n                index = draggableNodes.indexOf(dragging);\n            }\n            const droppableItem = {\n                node: cur,\n                rect: cur.getBoundingClientRect(),\n                isDraggingHost,\n                // We don't want styles to apply to the left behind div in onMouseMoveWhileDragging\n                draggableNodes: draggableNodes.map((node) => (node === dragging ? node.cloneNode(false) : node)),\n                draggableNodesRects: draggableNodes.map((node) => node.getBoundingClientRect())\n            };\n            acc.push(droppableItem);\n            return acc;\n        }, []);\n        if (!onDrag({ droppableId, index })) {\n            // Consumer disallowed drag\n            droppableItems.forEach((item) => resetDroppableItem(item));\n            return;\n        }\n        // Set initial style so future style mods take effect\n        style = Object.assign(Object.assign({}, style), { top: rect.y, left: rect.x, width: rect.width, height: rect.height, [cssDraggingBackgroundColor.name]: getInheritedBackgroundColor(dragging), position: 'fixed', zIndex: 5000 });\n        setStyle(style);\n        // Store event details\n        startX = ev.pageX;\n        startY = ev.pageY;\n        startYOffset = startY - rect.y;\n        setIsDragging(true);\n        mouseMoveListener = (ev) => onMouseMoveWhileDragging(ev, droppableItems, rect);\n        mouseUpListener = () => onMouseUpWhileDragging(droppableItems);\n        document.addEventListener('mousemove', mouseMoveListener);\n        document.addEventListener('mouseup', mouseUpListener);\n        // Comment out this line to debug while dragging by right clicking\n        // document.addEventListener('contextmenu', mouseUpListener);\n    };\n    const childProps = Object.assign({ 'data-pf-draggable-zone': isDragging ? null : zone, draggable: true, className: css(styles.draggable, isDragging && styles.modifiers.dragging, !isValidDrag && styles.modifiers.dragOutside, className), onDragStart,\n        onTransitionEnd,\n        style }, props);\n    return (React.createElement(React.Fragment, null,\n        isDragging && (React.createElement(\"div\", Object.assign({ draggable: true }, props, { style: Object.assign(Object.assign({}, styleProp), { visibility: 'hidden' }) }), children)),\n        hasNoWrapper ? (React.cloneElement(children, childProps)) : (React.createElement(\"div\", Object.assign({}, childProps), children))));\n};\nDraggable.displayName = 'Draggable';\n//# sourceMappingURL=Draggable.js.map","import { __rest } from \"tslib\";\nimport * as React from 'react';\nimport { css } from '@patternfly/react-styles';\nimport styles from '@patternfly/react-styles/css/components/DragDrop/drag-drop.mjs';\nimport { DroppableContext } from './DroppableContext';\nexport const Droppable = (_a) => {\n    var { className, children, zone = 'defaultZone', droppableId = 'defaultId', hasNoWrapper = false } = _a, props = __rest(_a, [\"className\", \"children\", \"zone\", \"droppableId\", \"hasNoWrapper\"]);\n    const childProps = Object.assign({ 'data-pf-droppable': zone, 'data-pf-droppableid': droppableId, \n        // if has no wrapper is set, don't overwrite children className with the className prop\n        className: hasNoWrapper && React.Children.count(children) === 1\n            ? css(styles.droppable, className, children.props.className)\n            : css(styles.droppable, className) }, props);\n    return (React.createElement(DroppableContext.Provider, { value: { zone, droppableId } }, hasNoWrapper ? (React.cloneElement(children, childProps)) : (React.createElement(\"div\", Object.assign({}, childProps), children))));\n};\nDroppable.displayName = 'Droppable';\n//# sourceMappingURL=Droppable.js.map"],"names":["DataListControl","_a","children","className","props","__rest","React","css","styles","DataListDragButton","isDisabled","GripVerticalIcon","DragDropContext","_source","_dest","DragDrop","onDrag","onDragMove","onDrop","DroppableContext","c_draggable_m_dragging_BackgroundColor","getDefaultBackground","div","bg","getInheritedBackgroundColor","el","defaultStyle","backgroundColor","removeBlankDiv","node","i","child","resetDroppableItem","droppableItem","n","overlaps","ev","rect","Draggable","styleProp","hasNoWrapper","style","setStyle","isDragging","setIsDragging","isValidDrag","setIsValidDrag","zone","droppableId","startX","startY","index","hoveringDroppable","hoveringIndex","mouseMoveListener","mouseUpListener","startYOffset","onTransitionEnd","_ev","getSourceAndDest","hoveringDroppableId","onMouseUpWhileDragging","droppableItems","source","dest","consumerReordered","onMouseMoveWhileDragging","blankDivRect","isDraggingHost","draggableNodes","draggableNodesRects","blankDiv","blankDivPos","childRect","isLast","startOverlaps","item","lastTranslate","halfway","translateY","onDragStart","dragging","acc","cur","cssDraggingBackgroundColor","childProps","Droppable"],"mappings":"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","x_google_ignoreList":[0,1,2,3,4,5,6,7]}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy