{"version":3,"file":"static/chunks/pages/research/publication-5eef4a5eed10ce08.js","mappings":"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","sources":["webpack://_N_E/./node_modules/@mui/material/esm/Skeleton/Skeleton.js","webpack://_N_E/./node_modules/@mui/material/esm/Skeleton/skeletonClasses.js","webpack://_N_E/./node_modules/@mui/material/esm/styles/cssUtils.js","webpack://_N_E/?995b","webpack://_N_E/./component/MoreResources.jsx","webpack://_N_E/./component/NextBreadcrumbs.jsx","webpack://_N_E/./component/TabPanel.jsx","webpack://_N_E/./node_modules/uuid/dist/esm-browser/native.js","webpack://_N_E/./node_modules/uuid/dist/esm-browser/rng.js","webpack://_N_E/./node_modules/uuid/dist/esm-browser/stringify.js","webpack://_N_E/./node_modules/uuid/dist/esm-browser/v4.js","webpack://_N_E/./component/ReusableTabs.jsx","webpack://_N_E/./pages/research/publication.js","webpack://_N_E/"],"sourcesContent":["import _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nconst _excluded = [\"animation\", \"className\", \"component\", \"height\", \"style\", \"variant\", \"width\"];\nlet _ = t => t,\n _t,\n _t2,\n _t3,\n _t4;\nimport * as React from 'react';\nimport clsx from 'clsx';\nimport PropTypes from 'prop-types';\nimport { keyframes, css } from '@mui/system';\nimport { unstable_composeClasses as composeClasses } from '@mui/base';\nimport { alpha, unstable_getUnit as getUnit, unstable_toUnitless as toUnitless } from '../styles';\nimport styled from '../styles/styled';\nimport useThemeProps from '../styles/useThemeProps';\nimport { getSkeletonUtilityClass } from './skeletonClasses';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nconst useUtilityClasses = ownerState => {\n const {\n classes,\n variant,\n animation,\n hasChildren,\n width,\n height\n } = ownerState;\n const slots = {\n root: ['root', variant, animation, hasChildren && 'withChildren', hasChildren && !width && 'fitContent', hasChildren && !height && 'heightAuto']\n };\n return composeClasses(slots, getSkeletonUtilityClass, classes);\n};\nconst pulseKeyframe = keyframes(_t || (_t = _`\n 0% {\n opacity: 1;\n }\n\n 50% {\n opacity: 0.4;\n }\n\n 100% {\n opacity: 1;\n }\n`));\nconst waveKeyframe = keyframes(_t2 || (_t2 = _`\n 0% {\n transform: translateX(-100%);\n }\n\n 50% {\n /* +0.5s of delay between each loop */\n transform: translateX(100%);\n }\n\n 100% {\n transform: translateX(100%);\n }\n`));\nconst SkeletonRoot = styled('span', {\n name: 'MuiSkeleton',\n slot: 'Root',\n overridesResolver: (props, styles) => {\n const {\n ownerState\n } = props;\n return [styles.root, styles[ownerState.variant], ownerState.animation !== false && styles[ownerState.animation], ownerState.hasChildren && styles.withChildren, ownerState.hasChildren && !ownerState.width && styles.fitContent, ownerState.hasChildren && !ownerState.height && styles.heightAuto];\n }\n})(({\n theme,\n ownerState\n}) => {\n const radiusUnit = getUnit(theme.shape.borderRadius) || 'px';\n const radiusValue = toUnitless(theme.shape.borderRadius);\n return _extends({\n display: 'block',\n // Create a \"on paper\" color with sufficient contrast retaining the color\n backgroundColor: theme.vars ? theme.vars.palette.Skeleton.bg : alpha(theme.palette.text.primary, theme.palette.mode === 'light' ? 0.11 : 0.13),\n height: '1.2em'\n }, ownerState.variant === 'text' && {\n marginTop: 0,\n marginBottom: 0,\n height: 'auto',\n transformOrigin: '0 55%',\n transform: 'scale(1, 0.60)',\n borderRadius: `${radiusValue}${radiusUnit}/${Math.round(radiusValue / 0.6 * 10) / 10}${radiusUnit}`,\n '&:empty:before': {\n content: '\"\\\\00a0\"'\n }\n }, ownerState.variant === 'circular' && {\n borderRadius: '50%'\n }, ownerState.variant === 'rounded' && {\n borderRadius: (theme.vars || theme).shape.borderRadius\n }, ownerState.hasChildren && {\n '& > *': {\n visibility: 'hidden'\n }\n }, ownerState.hasChildren && !ownerState.width && {\n maxWidth: 'fit-content'\n }, ownerState.hasChildren && !ownerState.height && {\n height: 'auto'\n });\n}, ({\n ownerState\n}) => ownerState.animation === 'pulse' && css(_t3 || (_t3 = _`\n animation: ${0} 1.5s ease-in-out 0.5s infinite;\n `), pulseKeyframe), ({\n ownerState,\n theme\n}) => ownerState.animation === 'wave' && css(_t4 || (_t4 = _`\n position: relative;\n overflow: hidden;\n\n /* Fix bug in Safari https://bugs.webkit.org/show_bug.cgi?id=68196 */\n -webkit-mask-image: -webkit-radial-gradient(white, black);\n\n &::after {\n animation: ${0} 1.6s linear 0.5s infinite;\n background: linear-gradient(\n 90deg,\n transparent,\n ${0},\n transparent\n );\n content: '';\n position: absolute;\n transform: translateX(-100%); /* Avoid flash during server-side hydration */\n bottom: 0;\n left: 0;\n right: 0;\n top: 0;\n }\n `), waveKeyframe, (theme.vars || theme).palette.action.hover));\nconst Skeleton = /*#__PURE__*/React.forwardRef(function Skeleton(inProps, ref) {\n const props = useThemeProps({\n props: inProps,\n name: 'MuiSkeleton'\n });\n const {\n animation = 'pulse',\n className,\n component = 'span',\n height,\n style,\n variant = 'text',\n width\n } = props,\n other = _objectWithoutPropertiesLoose(props, _excluded);\n const ownerState = _extends({}, props, {\n animation,\n component,\n variant,\n hasChildren: Boolean(other.children)\n });\n const classes = useUtilityClasses(ownerState);\n return /*#__PURE__*/_jsx(SkeletonRoot, _extends({\n as: component,\n ref: ref,\n className: clsx(classes.root, className),\n ownerState: ownerState\n }, other, {\n style: _extends({\n width,\n height\n }, style)\n }));\n});\nprocess.env.NODE_ENV !== \"production\" ? Skeleton.propTypes /* remove-proptypes */ = {\n // ----------------------------- Warning --------------------------------\n // | These PropTypes are generated from the TypeScript type definitions |\n // | To update them edit the d.ts file and run \"yarn proptypes\" |\n // ----------------------------------------------------------------------\n /**\n * The animation.\n * If `false` the animation effect is disabled.\n * @default 'pulse'\n */\n animation: PropTypes.oneOf(['pulse', 'wave', false]),\n /**\n * Optional children to infer width and height from.\n */\n children: PropTypes.node,\n /**\n * Override or extend the styles applied to the component.\n */\n classes: PropTypes.object,\n /**\n * @ignore\n */\n className: PropTypes.string,\n /**\n * The component used for the root node.\n * Either a string to use a HTML element or a component.\n */\n component: PropTypes.elementType,\n /**\n * Height of the skeleton.\n * Useful when you don't want to adapt the skeleton to a text element but for instance a card.\n */\n height: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n /**\n * @ignore\n */\n style: PropTypes.object,\n /**\n * The system prop that allows defining system overrides as well as additional CSS styles.\n */\n sx: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.func, PropTypes.object, PropTypes.bool])), PropTypes.func, PropTypes.object]),\n /**\n * The type of content that will be rendered.\n * @default 'text'\n */\n variant: PropTypes /* @typescript-to-proptypes-ignore */.oneOfType([PropTypes.oneOf(['circular', 'rectangular', 'rounded', 'text']), PropTypes.string]),\n /**\n * Width of the skeleton.\n * Useful when the skeleton is inside an inline element with no width of its own.\n */\n width: PropTypes.oneOfType([PropTypes.number, PropTypes.string])\n} : void 0;\nexport default Skeleton;","import { unstable_generateUtilityClasses as generateUtilityClasses } from '@mui/utils';\nimport generateUtilityClass from '../generateUtilityClass';\nexport function getSkeletonUtilityClass(slot) {\n return generateUtilityClass('MuiSkeleton', slot);\n}\nconst skeletonClasses = generateUtilityClasses('MuiSkeleton', ['root', 'text', 'rectangular', 'rounded', 'circular', 'pulse', 'wave', 'withChildren', 'fitContent', 'heightAuto']);\nexport default skeletonClasses;","export function isUnitless(value) {\n return String(parseFloat(value)).length === String(value).length;\n}\n\n// Ported from Compass\n// https://github.com/Compass/compass/blob/master/core/stylesheets/compass/typography/_units.scss\n// Emulate the sass function \"unit\"\nexport function getUnit(input) {\n return String(input).match(/[\\d.\\-+]*\\s*(.*)/)[1] || '';\n}\n\n// Emulate the sass function \"unitless\"\nexport function toUnitless(length) {\n return parseFloat(length);\n}\n\n// Convert any CSS or value to any another.\n// From https://github.com/KyleAMathews/convert-css-length\nexport function convertLength(baseFontSize) {\n return (length, toUnit) => {\n const fromUnit = getUnit(length);\n\n // Optimize for cases where `from` and `to` units are accidentally the same.\n if (fromUnit === toUnit) {\n return length;\n }\n\n // Convert input length to pixels.\n let pxLength = toUnitless(length);\n if (fromUnit !== 'px') {\n if (fromUnit === 'em') {\n pxLength = toUnitless(length) * toUnitless(baseFontSize);\n } else if (fromUnit === 'rem') {\n pxLength = toUnitless(length) * toUnitless(baseFontSize);\n }\n }\n\n // Convert length in pixels to the output unit\n let outputLength = pxLength;\n if (toUnit !== 'px') {\n if (toUnit === 'em') {\n outputLength = pxLength / toUnitless(baseFontSize);\n } else if (toUnit === 'rem') {\n outputLength = pxLength / toUnitless(baseFontSize);\n } else {\n return length;\n }\n }\n return parseFloat(outputLength.toFixed(5)) + toUnit;\n };\n}\nexport function alignProperty({\n size,\n grid\n}) {\n const sizeBelow = size - size % grid;\n const sizeAbove = sizeBelow + grid;\n return size - sizeBelow < sizeAbove - size ? sizeBelow : sizeAbove;\n}\n\n// fontGrid finds a minimal grid (in rem) for the fontSize values so that the\n// lineHeight falls under a x pixels grid, 4px in the case of Material Design,\n// without changing the relative line height\nexport function fontGrid({\n lineHeight,\n pixels,\n htmlFontSize\n}) {\n return pixels / (lineHeight * htmlFontSize);\n}\n\n/**\n * generate a responsive version of a given CSS property\n * @example\n * responsiveProperty({\n * cssProperty: 'fontSize',\n * min: 15,\n * max: 20,\n * unit: 'px',\n * breakpoints: [300, 600],\n * })\n *\n * // this returns\n *\n * {\n * fontSize: '15px',\n * '@media (min-width:300px)': {\n * fontSize: '17.5px',\n * },\n * '@media (min-width:600px)': {\n * fontSize: '20px',\n * },\n * }\n * @param {Object} params\n * @param {string} params.cssProperty - The CSS property to be made responsive\n * @param {number} params.min - The smallest value of the CSS property\n * @param {number} params.max - The largest value of the CSS property\n * @param {string} [params.unit] - The unit to be used for the CSS property\n * @param {Array.number} [params.breakpoints] - An array of breakpoints\n * @param {number} [params.alignStep] - Round scaled value to fall under this grid\n * @returns {Object} responsive styles for {params.cssProperty}\n */\nexport function responsiveProperty({\n cssProperty,\n min,\n max,\n unit = 'rem',\n breakpoints = [600, 900, 1200],\n transform = null\n}) {\n const output = {\n [cssProperty]: `${min}${unit}`\n };\n const factor = (max - min) / breakpoints[breakpoints.length - 1];\n breakpoints.forEach(breakpoint => {\n let value = min + factor * breakpoint;\n if (transform !== null) {\n value = transform(value);\n }\n output[`@media (min-width:${breakpoint}px)`] = {\n [cssProperty]: `${Math.round(value * 10000) / 10000}${unit}`\n };\n });\n return output;\n}","\n (window.__NEXT_P = window.__NEXT_P || []).push([\n \"/research/publication\",\n function () {\n return require(\"private-next-pages/research/publication.js\");\n }\n ]);\n if(module.hot) {\n module.hot.dispose(function () {\n window.__NEXT_P.push([\"/research/publication\"])\n });\n }\n ","import {\n Card,\n CardContent,\n CardMedia,\n Typography,\n CardActionArea,\n Container,\n Grid,\n} from \"@mui/material\";\nimport moment from \"moment-timezone\";\nimport { useState, useEffect } from \"react\";\n\nconst SHOW_RESOURCES = 3;\n\nconst getInitials = (name, separator = \" \") => {\n return name\n .split(separator)\n .map((part) => part[0]?.toUpperCase() || \"\")\n .join(\"\");\n};\n\nconst truncateContent = (content, maxLength) => {\n const text = content.replace(/<[^>]+>/g, \"\"); // Strip HTML tags\n return text.length > maxLength ? `${text.substring(0, maxLength)}...` : text;\n};\n\nconst MoreResources = ({ filterId = [] }) => {\n const [resources, setResources] = useState([]);\n const [hasFetched, setHasFetched] = useState(false);\n\n useEffect(() => {\n if (!hasFetched) {\n const fetchResources = async () => {\n try {\n const response = await fetch(\"/api/getBlogPosts\");\n const data = await response.json();\n const filteredResources = data\n .filter((item) => !filterId.includes(item.id))\n .sort(() => 0.5 - Math.random())\n .slice(0, SHOW_RESOURCES);\n setResources(filteredResources);\n } catch (error) {\n console.error(\"Failed to fetch resources:\", error);\n }\n };\n\n fetchResources();\n setHasFetched(true); // Ensure fetch only happens once\n }\n }, [filterId, hasFetched]); // `filterId` ensures the fetch updates if `filterId` changes\n\n return (\n \n \n Read Next\n \n \n {resources.map((resource, idx) => (\n \n \n \n {resource.images?.length > 0 ? (\n \n ) : (\n \n )}\n \n \n {resource.title}\n \n \n {resource.author.displayName ||\n getInitials(resource.author.name)}\n \n \n {console.log(JSON.stringify(resource))}\n \n \n {moment(resource.published).fromNow()}\n \n \n \n \n \n ))}\n \n \n );\n};\n\nexport default MoreResources;\n","import React, { useEffect, useState } from \"react\";\nimport { useRouter } from \"next/router\";\nimport Link from \"next/link\";\nimport { Breadcrumbs, Typography } from \"@mui/material\";\nimport { ConvertPathText } from \"./Utils/utils\";\n\nconst NextBreadcrumbs = ({ title }) => {\n const router = useRouter();\n const [breadcrumbs, setBreadcrumbs] = useState(null);\n\n useEffect(() => {\n if (router) {\n const linkPath = router.asPath.split(\"/\");\n linkPath.shift();\n const pathArray = linkPath.map((path, i) => {\n return {\n breadcrumb: path,\n href: \"/\" + linkPath.slice(0, i + 1).join(\"/\"),\n };\n });\n setBreadcrumbs(pathArray);\n }\n }, [router]);\n\n if (!breadcrumbs) {\n return null;\n }\n const breadcrumbsLength = breadcrumbs.length;\n return (\n \n \n Home\n \n {breadcrumbs.map((breadcrumb, i) => {\n // const text = convertBreadcrumb(breadcrumb.breadcrumb);\n const text = ConvertPathText(breadcrumb.breadcrumb);\n if (breadcrumbsLength - 1 == i) {\n return (\n \n {title ? title : text}\n \n );\n }\n return (\n \n {text}\n \n );\n })}\n \n );\n};\n\nexport default NextBreadcrumbs;\n","import { Box } from \"@mui/material\";\nimport React from \"react\";\n\nexport default function TabPanel(props) {\n const { children, value, index, ...other } = props;\n\n return (\n