diff --git a/lib/interviewer/containers/HyperList/HyperList.js b/lib/interviewer/containers/HyperList/HyperList.js
index 9a9ada351..e6bdc2ecb 100644
--- a/lib/interviewer/containers/HyperList/HyperList.js
+++ b/lib/interviewer/containers/HyperList/HyperList.js
@@ -1,7 +1,7 @@
import cx from 'classnames';
import { AnimatePresence, motion } from 'framer-motion';
import PropTypes from 'prop-types';
-import React, { useContext, useMemo } from 'react';
+import React, { useContext, useMemo, useCallback } from 'react';
import AutoSizer from 'react-virtualized-auto-sizer';
import { VariableSizeList as List } from 'react-window';
import { compose } from 'recompose';
@@ -10,6 +10,7 @@ import {
DropTarget,
MonitorDropTarget,
} from '../../behaviours/DragAndDrop';
+import { renderToString } from 'next/dist/compiled/react-dom/cjs/react-dom-server-legacy.browser.development';
const LargeRosterNotice = () => (
(
+
+
+
+ ),
+ [ItemComponent],
+ );
+
const getItemSize = (item, listWidth) => {
if (!listWidth) {
return 0;
}
- // const itemData = items[item];
- // const { props } = itemData;
+ const itemData = items[item];
+ const { props } = itemData;
+ const newHiddenSizingEl = document.createElement('div');
+
+ newHiddenSizingEl.style.position = 'absolute';
+ newHiddenSizingEl.style.top = '0';
+ newHiddenSizingEl.style.width = `${listWidth - GUTTER_SIZE * 2 - 14}px`; // Additional 14 for scrollbar
+ newHiddenSizingEl.style.pointerEvents = 'none';
- // const sizingElement = simpleRenderToString(
- //
- //
- //
,
- // );
- // const height = sizingElement.clientHeight;
+ newHiddenSizingEl.style.visibility = 'hidden';
- // return height + GUTTER_SIZE;
+ document.body.appendChild(newHiddenSizingEl);
+ newHiddenSizingEl.innerHTML = renderToString(
);
+ const height = newHiddenSizingEl.clientHeight;
+ document.body.removeChild(newHiddenSizingEl);
- return 200;
+ return height + GUTTER_SIZE;
};
// If placeholder is provider it supersedes everything