{"version":3,"sources":["../../common/src/utils/crypto.ts","logo.svg","../../common/src/styles/AlfaTheme.ts","../../common/src/assets/Alfa_black.png","../../common/src/utils/Styles.ts","../../common/src/sections/Common/Header.tsx","../../common/src/assets/harpa.jpg","../../common/src/utils/DateConstants.ts","../../common/src/routes/routes.ts","../../common/src/sections/Common/Banner.tsx","../../common/src/sections/Common/Common.tsx","../../common/src/utils/AuthRouter.tsx","../../common/src/utils/utils.ts","../../common/src/components/Spinner.tsx","../../common/src/components/EnhancedTable.tsx","../../common/src/components/EntityCard.tsx","../../common/src/assets/fjarfestar_login_alfa.jpg","../../common/src/pages/Login.tsx","services/Service.ts","../../common/src/components/Message.tsx","../../common/src/utils/UseAsync.tsx","Pages/MyInvestments.tsx","../../common/src/components/PageMenu.tsx","Sections/InvestmentDocuments.tsx","Pages/InvestmentPage.tsx","App.tsx","reportWebVitals.ts","index.tsx"],"names":["generateHashString","loginHint","uniqueString","Date","now","toString","crypto","createHash","update","digest","calculateVcode","hashString","hash","Buffer","from","code","slice","readUInt16BE","String","padStart","headingFont","AlfaTheme","responsiveFontSizes","createTheme","spacing","palette","primary","main","secondary","error","overrides","MuiDialogActions","root","justifyContent","MuiSelect","textAlign","select","undefined","MuiExpansionPanelSummary","content","margin","MuiStepper","maxWidth","MuiFormLabel","paddingBottom","fontWeight","color","asterisk","MuiCardContent","padding","MuiInputBase","height","border","borderRadius","multiline","MuiButton","textTransform","paddingLeft","paddingRight","paddingTop","MuiExpansionPanel","MuiIconButton","MuiTypography","typography","fontFamily","h1","fontSize","h2","h3","h4","h5","h6","wrapperClass","HeaderComponent","props","handleMenuClose","setState","anchorElement","state","userName","this","user","name","length","names","split","className","classes","header","Grid","container","direction","item","xs","to","link","src","logo","alt","alignItems","actions","Button","onClick","ev","persist","currentTarget","endIcon","size","label","accountButton","iconSizeLarge","downArrowIcon","Menu","id","anchorEl","getContentAnchorEl","open","Boolean","onClose","anchorOrigin","vertical","horizontal","transformOrigin","MenuItem","logOut","React","withStyles","breakpoints","createStyles","lineHeight","display","verticalAlign","maxHeight","width","marginLeft","searchIcon","translate","borderColor","fontWeightBold","months","daysOfWeek","investmentPageParamDict","boardRoutes","nextMeeting","allMeetings","materials","investmentRoutes","commonRoutes","params","token","errorMessage","Banner","today","banner","welcome","Card","style","backgroundColor","elevation","CardContent","path","onRenderDefaultHeader","Hidden","xsDown","date","getDay","Typography","variant","component","getDate","getMonth","getFullYear","EntityHeader","entityName","useParams","theme","backgroundImage","image","backgroundSize","backgroundRepeat","willChange","backgroundPosition","transform","up","down","alpha","borderTop","borderBottom","CommonPageElements","children","Header","AuthRoute","isLoggedIn","history","createBrowserHistory","useStyles","makeStyles","spinnerContainer","Spinner","Container","CircularProgress","descendingComparator","a","b","orderBy","getComparator","order","stableSort","array","comparator","stabilizedThis","map","el","index","sort","EnhancedTableHead","columns","onRequestSort","disableSort","TableHead","TableRow","headCell","idx","TableCell","align","numeric","disablePadding","sortDirection","TableSortLabel","active","property","event","visuallyHidden","useToolbarStyles","highlight","type","lighten","light","text","dark","title","flex","EnhancedTableToolbar","numSelected","Toolbar","join","Tooltip","IconButton","paper","marginBottom","table","clip","overflow","position","top","EnhancedTableRows","downloadlink","items","isSelected","idCol","handleClick","itm","isItemSelected","labelId","ITM","ITM2","corrurl","hasOwnProperty","downloadUrl","role","tabIndex","selected","cursor","col","onRender","key","get","scope","href","underline","textDecoration","EnhancedTable","explicitID","groupByKey","useState","setOrder","setOrderBy","openGroups","setOpenGroups","useMemo","Error","groups","reduce","curr","currGroupTitle","group","find","grp","Title","push","localeCompare","indexOf","Paper","TableContainer","Table","rowCount","TableBody","isOpen","Fragment","hover","groupToCloseName","filter","groupName","newOpenGroups","concat","openGroup","colSpan","Collapse","in","timeout","unmountOnExit","objectFit","flexDirection","board","raised","square","CardActionArea","CardMedia","imageUrl","BootstrapInput","marginTop","input","background","transition","transitions","create","boxShadow","InputBase","minWidth","leftImage","loginPageImage","flexBasis","flexGrow","cardContainer","card","media","font","borderadius","linkText","bottomText","setToken","_prepLogin","prepareLogin","query","URLSearchParams","useLocation","search","setError","loginAuthId","setLoginAuthId","pinHash","setPinHash","setLoginHint","selectedEidMethod","setSelectedEidMethod","prepLogin","useCallback","then","r","useEffect","console","log","mdDown","Snackbar","autoHideDuration","message","CardActions","method","action","FormControl","fullWidth","InputLabel","htmlFor","Select","defaultValue","onChange","e","target","value","option","TextField","hidden","Input","disabled","Box","smDown","mdUp","tokenStorageKey","Service","onUnauth","onUnauthorizedError","getUserIfLoggedIn","localStorage","getItem","payload","jwt","decode","exp","tokenIsExpired","parseToken","setTokenAndGetUser","setItem","removeItem","getInvestments","getInvestmentByName","investmentName","investmentArray","investment","getInvestmentDocuments","investmentId","url","fetch","headers","ContentType","Authorization","res","status","json","body","statusText","subMessage","internalError","useAsync","asyncFunction","immediate","setStatus","setValue","execute","response","catch","setSelectedInvestment","investments","wrap","rootPath","links","page","ListLink","icon","isDirect","isDefaultSelected","renderLink","forwardRef","itemProps","ref","ListItem","button","ListItemIcon","ListItemText","List","documents","initializeFileTypeIcons","Icon","getFileTypeIconProps","extension","docIcon","imageFileType","uri","fileName","document","createElement","download","appendChild","click","removeChild","downloadFromUrl","setErrorToast","isLoading","setIsLoading","wrappedGetInvDocs","useRouteMatch","App","service","shouldNavigate","selectedInvestment","setTimeout","clearErrorToast","logIn","handleUnauthorizedRequest","ThemeProvider","Common","rel","Component","reportWebVitals","onPerfEntry","Function","getCLS","getFID","getFCP","getLCP","getTTFB","ReactDOM","render","getElementById"],"mappings":"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","file":"static/js/main.c993c57b.chunk.js","sourcesContent":["// When in doubt, use ts-ignore\n// eslint-disable-next-line @typescript-eslint/ban-ts-comment\n// @ts-ignore\nimport crypto from 'crypto-browserify';\n\nexport const generateHashString = (loginHint: string) => {\n // Create a unique string by combining the loginHint and current time\n const uniqueString = loginHint + Date.now().toString();\n\n // Calculate the SHA256 hash of the unique string\n const sha256Hash = crypto.createHash('sha512').update(uniqueString).digest('base64');\n\n return sha256Hash;\n};\n\nexport const calculateVcode = (hashString: string) => {\n const hash = Buffer.from(hashString, 'base64');\n const sha256Hash = crypto.createHash('sha256').update(hash).digest();\n\n const lastTwoBytes = sha256Hash.slice(-2);\n const code = lastTwoBytes.readUInt16BE(0);\n\n return String(code % 10000).padStart(4, '0');\n};","export default __webpack_public_path__ + \"static/media/logo.6ce24c58.svg\";","import { createTheme, responsiveFontSizes } from \"@material-ui/core/styles\";\n\nlet headingFont = \"'Arial Black', 'Arial Bold', Gadget, sans-serif\";\n\nexport const AlfaTheme = responsiveFontSizes(\n createTheme({\n spacing: 8,\n palette: {\n primary: {\n main: \"rgb(212, 38, 38)\",\n },\n secondary: {\n main: \"rgb(12, 9, 10)\",\n },\n error: {\n main: \"rgb(126, 135, 140)\",\n },\n },\n overrides: {\n MuiDialogActions: {\n root: {\n justifyContent: \"space-around\",\n },\n },\n MuiSelect: {\n root: {\n textAlign: \"start\",\n },\n select: {\n \"&:focus\": {\n \"background-color\": undefined,\n },\n },\n },\n MuiExpansionPanelSummary: {\n content: {\n \"&$expanded\": {\n margin: undefined,\n },\n },\n },\n MuiStepper: {\n root: {\n maxWidth: \"1200px\",\n margin: \"auto\",\n },\n },\n MuiFormLabel: {\n root: {\n textAlign: \"start\",\n paddingBottom: \"25px\",\n fontWeight: \"bold\",\n color: \"#000000\",\n },\n asterisk: {\n color: \"#FF0050\",\n },\n },\n // MuiCard: {\n // root: {\n // // border: \"1px solid #E6E6EC\",\n // },\n // },\n MuiCardContent: {\n root: {\n padding: \"15px\",\n },\n },\n MuiInputBase: {\n root: {\n height: \"48px\",\n border: \"solid 1px #CCCCD8\",\n borderRadius: \"5px\",\n },\n multiline: {\n height: \"inherit\",\n },\n },\n MuiButton: {\n root: {\n textTransform: \"none\",\n paddingLeft: \"48px\",\n paddingRight: \"48px\",\n paddingTop: \"12px\",\n paddingBottom: \"12px\",\n },\n },\n MuiExpansionPanel: {\n root: {\n \"&$expanded\": {\n margin: undefined,\n },\n },\n },\n MuiIconButton: {\n root: {\n padding: \"5px\",\n },\n },\n MuiTypography: {},\n },\n typography: {\n fontFamily: \"Arial, Helvetica, sans-serif\",\n h1: {\n fontFamily: headingFont,\n fontSize: \"2.25rem\",\n },\n h2: {\n fontFamily: headingFont,\n fontSize: \"2.3rem\",\n },\n h3: {\n fontFamily: headingFont,\n fontSize: \"2rem\",\n },\n h4: {\n fontFamily: headingFont,\n },\n h5: {\n fontFamily: headingFont,\n },\n h6: {\n fontFamily: headingFont,\n },\n },\n })\n);\n","export default __webpack_public_path__ + \"static/media/Alfa_black.2e2cdbe8.png\";","import { Theme } from \"@material-ui/core/styles\";\n\nexport const wrapperClass = {\n wrapperClass: {\n maxWidth: 1240,\n margin: \"0 auto\",\n padding: \"0px 16px\",\n },\n};\n\nexport const spinnerContainer = (theme: Theme) => ({\n spinnerContainer: {\n width: \"fit-content\",\n paddingTop: theme.spacing(5),\n },\n});\n","import * as React from \"react\";\n\nimport {\n Grid,\n // Typography,\n Theme,\n createStyles,\n WithStyles,\n withStyles,\n Button,\n Menu,\n MenuItem,\n} from \"@material-ui/core\";\n\nimport DownArrowIcon from \"@material-ui/icons/KeyboardArrowDown\";\n// import SearchIcon from \"@material-ui/icons/Search\";\n\nimport logo from \"../../assets/Alfa_black.png\";\nimport { wrapperClass } from \"../../utils/Styles\";\nimport { Link } from \"react-router-dom\";\nimport { User } from \"../../models/User\";\n\nconst styles = ({ palette, spacing, breakpoints, typography }: Theme) =>\n createStyles({\n header: {\n paddingTop: spacing(0.5),\n paddingBottom: spacing(0.5),\n },\n link: {\n lineHeight: \"2.5rem\",\n },\n logo: {\n display: \"inline-block\",\n verticalAlign: \"middle\",\n maxHeight: 35,\n },\n actions: {\n width: \"fit-content\",\n },\n accountButton: {\n fontSize: \"1rem\",\n },\n downArrowIcon: {\n marginLeft: \"0px\",\n \"& > svg:first-child\": {\n fontSize: \"2rem\",\n },\n },\n searchIcon: {\n paddingTop: \"6px\",\n },\n translate: {\n border: \"3px solid\",\n borderColor: palette.primary.main,\n display: \"block\",\n width: \"22px\",\n // height: \"26px\",\n lineHeight: \"20px\",\n textAlign: \"center\",\n color: palette.primary.main,\n fontSize: 14,\n fontWeight: typography.fontWeightBold,\n },\n ...wrapperClass,\n });\n\nexport interface IHeaderProps extends WithStyles {\n user: User | undefined;\n logOut: () => void;\n}\n\nexport interface IHeaderState {\n anchorElement: HTMLElement | undefined;\n}\n\nclass HeaderComponent extends React.Component {\n constructor(props: IHeaderProps) {\n super(props);\n\n this.state = {\n anchorElement: undefined,\n };\n }\n\n public render(): React.ReactElement {\n // TODO: Endurskoða mögulega sérstaklega m.t.t. minni skjáa\n let userName = this.props.user?.name || \"\";\n if (userName.length > 15) {\n let names = userName.split(\" \");\n if (names[0].length < 15) {\n userName = names[0];\n } else if (names[names.length - 1].length < 15) {\n userName = names[names.length - 1];\n } else {\n userName = \"User\";\n }\n }\n\n return (\n
\n
\n \n \n \n \n \n \n \n \n {/* TODO: Render as icon on small screen */}\n {\n ev.persist();\n this.setState({ anchorElement: ev.currentTarget });\n }}\n endIcon={}\n size=\"large\"\n classes={{\n label: this.props.classes.accountButton,\n iconSizeLarge: this.props.classes.downArrowIcon,\n }}\n >\n {userName}\n \n \n {/* Profile\n My account */}\n Logout\n \n \n {/* \n \n */}\n {/* \n EN\n */}\n \n \n
\n
\n );\n }\n\n private handleMenuClose = () => {\n this.setState({ anchorElement: undefined });\n };\n}\n\nexport default withStyles(styles)(HeaderComponent);\n","export default __webpack_public_path__ + \"static/media/harpa.464b3886.jpg\";","export const icelandicMonths = [\n \"Janúar\",\n \"Febrúar\",\n \"Mars\",\n \"Apríl\",\n \"Maí\",\n \"Júní\",\n \"Júlí\",\n \"Ágúst\",\n \"September\",\n \"Október\",\n \"Nóvember\",\n \"Desember\",\n];\n\nexport const months = [\n \"January\",\n \"February\",\n \"March\",\n \"April\",\n \"May\",\n \"June\",\n \"July\",\n \"August\",\n \"September\",\n \"October\",\n \"November\",\n \"December\",\n];\n\nexport const icelandicDaysOfWeek = [\n \"Sunnudagur\",\n \"Mánudagur\",\n \"Þriðjudagur\",\n \"Miðvikudagur\",\n \"Fimmtudagur\",\n \"Föstudagur\",\n \"Laugardagur\",\n];\n\nexport const daysOfWeek = [\"Sunday\", \"Monday\", \"Tuesday\", \"Wednesday\", \"Thursday\", \"Friday\", \"Saturday\"];\n","export interface PageParams {\n page: string;\n}\n\nexport interface BoardPageParams extends PageParams {\n boardName: string;\n}\n\nexport const boardPageParamDict: {\n page: keyof Pick;\n board: keyof Pick;\n} = {\n page: \"page\",\n board: \"boardName\",\n};\n\nexport interface InvestmentPageParams extends PageParams {\n investmentName: string;\n}\n\nexport const investmentPageParamDict: {\n page: keyof Pick;\n investment: keyof Pick;\n} = {\n page: \"page\",\n investment: \"investmentName\",\n};\n\nexport const boardRoutes = {\n boards: { root: \"boards\", nextMeeting: \"next\", allMeetings: \"all-meetings\", materials: \"materials\" },\n};\n\nexport const investmentRoutes = {\n investments: { root: \"investments\", materials: \"materials\" },\n};\n\nexport const commonRoutes = {\n login: { root: \"login\", params: { token: \"token\", errorMessage: \"errMsg\" } },\n};\n","import * as React from \"react\";\n\nimport {\n Grid,\n Theme,\n createStyles,\n WithStyles,\n withStyles,\n Hidden,\n Card,\n CardContent,\n Typography,\n alpha,\n} from \"@material-ui/core\";\n\nimport image from \"../../assets/harpa.jpg\";\nimport { wrapperClass } from \"../../utils/Styles\";\nimport { months, daysOfWeek } from \"../../utils/DateConstants\";\nimport { Route, useParams, Switch } from \"react-router-dom\";\nimport { boardRoutes, investmentRoutes } from \"../../routes/routes\";\n\nconst styles = (theme: Theme) =>\n createStyles({\n banner: {\n // paddingTop: spacing(2),\n backgroundImage: `url(${image})`,\n backgroundSize: \"cover\",\n backgroundRepeat: \"no-repeat\",\n willChange: \"transform\",\n backgroundPosition: \"50% 63%\",\n transform: \"translate3d(0px, 0px, 0px)\",\n // [theme.breakpoints.down(\"sm\")]: {\n // height: \"150px\",\n // },\n [theme.breakpoints.up(\"md\")]: {\n height: \"200px\",\n },\n },\n container: {\n height: \"100%\",\n },\n welcome: {\n paddingTop: theme.spacing(4),\n [theme.breakpoints.up(\"md\")]: {\n height: \"80%\",\n },\n [theme.breakpoints.down(\"md\")]: {\n paddingTop: theme.spacing(1),\n },\n backgroundColor: alpha(theme.palette.primary.main, 0.75),\n color: \"white\",\n paddingLeft: theme.spacing(2),\n paddingRight: theme.spacing(5),\n },\n date: {\n height: \"100%\",\n width: \"fit-content\",\n backgroundColor: \"white\",\n padding: `0 ${theme.spacing(4)}px`,\n borderTop: `2px solid rgba(232, 232, 232, 0.75)`,\n borderBottom: `2px solid rgba(232, 232, 232, 0.75)`,\n // borderBottom: `2px solid ${darken(theme.palette.secondary.main, 0.05)}`,\n color: theme.palette.secondary.main,\n margin: 0,\n },\n ...wrapperClass,\n });\n\nexport interface BannerProps extends WithStyles {\n onRenderDefaultHeader: () => JSX.Element;\n}\n\nexport interface BannerState {\n today: Date;\n}\n\nclass Banner extends React.Component {\n constructor(props: BannerProps) {\n super(props);\n this.state = { today: new Date() };\n }\n\n public render(): React.ReactElement {\n return (\n
\n \n \n \n \n \n \n \n \n \n {this.props.onRenderDefaultHeader()}\n \n \n \n \n \n \n {/* TODO: Skoða að setja inn klukku - make-ar sense fyrir fundi */}\n {daysOfWeek[this.state.today.getDay()]}\n \n \n {this.state.today.getDate()}\n \n \n {`${\n months[this.state.today.getMonth()]\n }, ${this.state.today.getFullYear()}`}\n \n \n \n
\n \n );\n }\n}\n\nconst EntityHeader: React.FunctionComponent<{}> = () => {\n let { entityName } = useParams<{ entityName: string }>();\n return {entityName};\n};\n\nexport default withStyles(styles)(Banner);\n","import * as React from \"react\";\nimport Header from \"./Header\";\nimport Banner, { BannerProps } from \"./Banner\";\nimport { User } from \"../../models/User\";\n\nexport interface ICommonPageElementsProps {\n onRenderDefaultHeader: BannerProps[\"onRenderDefaultHeader\"];\n user: User | undefined;\n logOut: () => void;\n}\n\nexport interface ICommonPageElementsState {}\n\nconst CommonPageElements: React.FunctionComponent = ({\n children,\n onRenderDefaultHeader,\n user,\n logOut,\n}) => {\n return (\n <>\n {user !== undefined && (\n <>\n
\n \n \n )}\n {children}\n \n );\n};\n\nexport default CommonPageElements;\n","import * as React from \"react\";\nimport { RouteProps, Redirect, Route } from \"react-router-dom\";\n\ninterface IAuthRouteProps extends RouteProps {\n isLoggedIn: boolean;\n}\n\nexport default class AuthRoute extends React.Component {\n public render(): React.ReactElement {\n return this.props.isLoggedIn ? : ;\n }\n}\n","import { createBrowserHistory } from \"history\";\nimport { useLocation } from \"react-router-dom\";\nimport { daysOfWeek, months } from \"./DateConstants\";\n\nexport function sleep(ms: number) {\n return new Promise((resolve) => setTimeout(resolve, ms));\n}\n\nexport let history = createBrowserHistory();\n\nexport const getIcelandicTime = (date: Date) =>\n date.toLocaleTimeString(\"is-IS\", { hour12: false, hour: \"2-digit\", minute: \"2-digit\" });\n\nexport const getIcelandicDate = (date: Date) =>\n `${daysOfWeek[date.getDay()]}, ${date.getDate()}. ${months[date.getMonth()]}`;\n\nexport const downloadFromUrl = (uri: string, fileName: string) => {\n let link = document.createElement(\"a\");\n link.download = fileName;\n link.href = uri;\n document.body.appendChild(link);\n link.click();\n document.body.removeChild(link);\n};\n\nexport const useQuery = () => {\n return new URLSearchParams(useLocation().search);\n};\n","import { CircularProgress, Container } from \"@material-ui/core\";\nimport { makeStyles } from \"@material-ui/core/styles\";\nimport { Theme } from \"@material-ui/core/styles/createTheme\";\nimport withStyles, { WithStyles } from \"@material-ui/styles/withStyles\";\nimport { spinnerContainer } from \"../utils/Styles\";\n\n// const styles = (theme: Theme) =>\n// createStyles({\n// ...spinnerContainer(theme),\n// });\n\ninterface SpinnerProps {}\n\nconst useStyles = makeStyles((theme) => ({\n ...spinnerContainer(theme),\n}));\n\nfunction Spinner() {\n const classes = useStyles();\n return (\n \n \n \n );\n}\n\nexport default Spinner;\n","import React, { ReactText } from \"react\";\n\nimport Table from \"@material-ui/core/Table\";\nimport TableHead from \"@material-ui/core/TableHead\";\nimport TableRow from \"@material-ui/core/TableRow\";\nimport TableCell from \"@material-ui/core/TableCell\";\nimport TableSortLabel from \"@material-ui/core/TableSortLabel\";\nimport Toolbar from \"@material-ui/core/Toolbar\";\nimport Typography from \"@material-ui/core/Typography\";\nimport Tooltip from \"@material-ui/core/Tooltip\";\nimport IconButton from \"@material-ui/core/IconButton\";\nimport DeleteIcon from \"@material-ui/icons/Delete\";\nimport { useState } from \"react\";\nimport { Link as DLink, Paper } from \"@material-ui/core\";\nimport { Link } from \"react-router-dom\";\nimport TableContainer from \"@material-ui/core/TableContainer\";\nimport TableBody from \"@material-ui/core/TableBody\";\nimport KeyboardArrowDownIcon from \"@material-ui/icons/KeyboardArrowDown\";\nimport KeyboardArrowUpIcon from \"@material-ui/icons/KeyboardArrowUp\";\n\nimport { createStyles, lighten, makeStyles } from \"@material-ui/core/styles\";\nimport { Theme } from \"@material-ui/core/styles/createTheme\";\nimport { useMemo } from \"react\";\nimport get from \"lodash.get\";\n\nimport find from \"lodash.find\";\nimport Collapse from \"@material-ui/core/Collapse\";\nimport { IBasicEntity, IDocument } from \"../models/Entities\";\n\n// export interface ImplicitEnhancedTableProps {\n// items: T[];\n// columns: Column[];\n// idCol: undefined;\n// }\n\n// export interface ExplicitEnhancedTableProps {\nexport interface EnhancedTableProps {\n downloadlink?: boolean;\n items: T[];\n columns: Column[];\n idCol?: keyof T;\n title: string;\n groupByKey?: keyof T;\n onClick: (event: React.MouseEvent, item: T) => void;\n // groupByValues?: any[]; TODO: Maybe implement\n disableSort?: boolean;\n}\n\n// export type EnhancedTableProps = T extends { ID: number } TODO: Get to work\n// ? ImplicitEnhancedTableProps\n// : ExplicitEnhancedTableProps;\n\ninterface Column {\n id: Extract;\n label: string;\n numeric?: boolean;\n disablePadding?: boolean;\n onRender?: (item: T, key: Column[\"id\"]) => JSX.Element | React.ReactText;\n}\n\nfunction descendingComparator(a: T, b: T, orderBy: keyof T) {\n if (b[orderBy] < a[orderBy]) {\n return -1;\n }\n if (b[orderBy] > a[orderBy]) {\n return 1;\n }\n return 0;\n}\n\ntype Order = \"asc\" | \"desc\";\n\nfunction getComparator(\n order: Order,\n orderBy: Key\n): (a: T, b: T) => number {\n return order === \"desc\"\n ? (a, b) => descendingComparator(a, b, orderBy)\n : (a, b) => -descendingComparator(a, b, orderBy);\n}\n\nfunction stableSort(array: T[], comparator: (a: T, b: T) => number) {\n const stabilizedThis = array.map((el, index) => [el, index] as [T, number]);\n stabilizedThis.sort((a, b) => {\n const order = comparator(a[0], b[0]);\n if (order !== 0) return order;\n return a[1] - b[1];\n });\n return stabilizedThis.map((el) => el[0]);\n}\n\ninterface TableHeaderProps {\n classes: ReturnType;\n columns: Column[];\n numSelected: number;\n onRequestSort: (event: React.MouseEvent, property: Extract) => void;\n // onSelectAllClick: (event: React.ChangeEvent) => void;\n order: Order;\n orderBy: Extract;\n rowCount: number;\n disableSort?: boolean;\n}\n\nfunction EnhancedTableHead(props: TableHeaderProps) {\n const {\n classes,\n columns,\n // onSelectAllClick,\n order,\n orderBy,\n // numSelected,\n // rowCount,\n onRequestSort,\n disableSort = false,\n } = props;\n const createSortHandler =\n (property: Extract) => (event: React.MouseEvent) => {\n onRequestSort(event, property);\n };\n\n return (\n \n \n {/* */}\n {/* 0 && numSelected < rowCount}\n checked={rowCount > 0 && numSelected === rowCount}\n onChange={onSelectAllClick}\n inputProps={{ \"aria-label\": \"select all desserts\" }}\n /> */}\n {/* */}\n {columns.map((headCell, idx) => (\n \n {!disableSort && (\n \n {headCell.label}\n {orderBy === headCell.id ? (\n \n {order === \"desc\"\n ? \"sorted descending\"\n : \"sorted ascending\"}\n \n ) : null}\n \n )}\n {disableSort && headCell.label}\n \n ))}\n \n \n );\n}\n\nconst useToolbarStyles = makeStyles((theme: Theme) =>\n createStyles({\n root: {\n paddingLeft: theme.spacing(2),\n paddingRight: theme.spacing(1),\n },\n highlight:\n theme.palette.type === \"light\"\n ? {\n color: theme.palette.secondary.main,\n backgroundColor: lighten(theme.palette.secondary.light, 0.85),\n }\n : {\n color: theme.palette.text.primary,\n backgroundColor: theme.palette.secondary.dark,\n },\n title: {\n flex: \"1 1 100%\",\n },\n })\n);\n\ninterface EnhancedTableToolbarProps {\n numSelected: number;\n title: string;\n}\n\nconst EnhancedTableToolbar = (props: EnhancedTableToolbarProps) => {\n const classes = useToolbarStyles();\n const { numSelected, title } = props;\n\n return (\n 0 ? classes.highlight : \"\"].join(\" \")}>\n {numSelected > 0 ? (\n \n {numSelected} selected\n \n ) : (\n \n {title}\n \n )}\n {\n numSelected > 0 && (\n \n \n \n \n \n )\n // : (\n // \n // \n // \n // \n // \n // )\n }\n \n );\n};\n\nconst useStyles = makeStyles((theme: Theme) =>\n createStyles({\n root: {\n width: \"100%\",\n },\n paper: {\n width: \"100%\",\n marginBottom: theme.spacing(2),\n },\n table: {\n // [theme.breakpoints.down(\"md\")]: {\n // backgroundColor: theme.palette.primary.main,\n // },\n },\n visuallyHidden: {\n border: 0,\n clip: \"rect(0 0 0 0)\",\n height: 1,\n margin: -1,\n overflow: \"hidden\",\n padding: 0,\n position: \"absolute\",\n top: 20,\n width: 1,\n },\n })\n);\n\ninterface EnhancedTableRowsProps {\n downloadlink?: boolean;\n items: T[];\n order: Order;\n orderBy: Extract;\n isSelected: (name: T[keyof T]) => boolean;\n idCol: keyof T;\n handleClick: (event: React.MouseEvent, item: T) => void;\n columns: Column[];\n}\n\nfunction EnhancedTableRows({\n downloadlink,\n items,\n order,\n orderBy,\n isSelected,\n idCol,\n handleClick,\n columns,\n}: EnhancedTableRowsProps) {\n return (\n <>\n {/* TODO: Sort items Memo-ically? */}\n {stableSort(items, getComparator(order, orderBy)).map((itm, index) => {\n const isItemSelected = isSelected(itm[idCol]);\n const labelId = `enhanced-table-checkbox-${index}`;\n // console.log(\"itm, \", itm);\n const ITM = itm as unknown as IBasicEntity;\n const ITM2 = itm as unknown as IDocument;\n // const ITM2 = itm as IBasicEntity;\n // console.log(ITM.title);\n // console.log(ITM2.title);\n var corrurl = \"\";\n if (itm.hasOwnProperty(\"title\")) {\n corrurl = `/investments/${ITM.title}`;\n } else {\n corrurl = ITM2.downloadUrl ? ITM2.downloadUrl : \"\";\n }\n\n return (\n {\n // if (itm.hasOwnProperty(\"title\")) {\n // return ;\n // }\n // return ;\n // }}\n // underline=\"none\"\n // hover\n onClick={(event: React.MouseEvent) => handleClick(event, itm)}\n role=\"checkbox\"\n aria-checked={isItemSelected}\n tabIndex={-1}\n // Todo: Type-a betur!\n key={itm[idCol] as any as string}\n selected={isItemSelected}\n style={{ cursor: \"pointer\" }}\n >\n {columns.map((col, idx) => {\n const onRender: Column[\"onRender\"] =\n col.onRender ??\n (((itm: T, key: string) => get(itm, key)) as any as (\n itm: T,\n key: string\n ) => ReactText);\n\n return (\n \n {downloadlink ? (\n \n {onRender(itm, col.id)}\n \n ) : (\n \n {onRender(itm, col.id)}\n \n )}\n \n );\n })}\n \n );\n })}\n \n );\n}\n// const CorrectLink = (url: string, downloadlink?: boolean,{children}): any => {\n// if (downloadlink) {\n// return ;\n// } else {\n// return ;\n// }\n// };\n\nfunction EnhancedTable(props: EnhancedTableProps) {\n const classes = useStyles();\n const {\n downloadlink,\n columns,\n items,\n idCol: explicitID,\n title,\n groupByKey,\n onClick,\n disableSort = false,\n } = props;\n const [order, setOrder] = useState(\"asc\");\n const [orderBy, setOrderBy] = useState>(\n columns[0].id as Extract\n );\n const [openGroups, setOpenGroups] = useState([]);\n const [selected, setSelected] = useState([]);\n const idCol: keyof T = useMemo(() => {\n if (explicitID) {\n return explicitID;\n }\n if (items[0]?.hasOwnProperty(\"ID\")) {\n return \"ID\" as keyof T;\n } else throw new Error(\"No ID given for \");\n }, [items, explicitID]);\n\n const groups: { Title: string; items: T[] }[] | undefined = useMemo(() => {\n if (!groupByKey) return undefined;\n return items\n .reduce<{ Title: string; items: T[] }[]>((groups, curr, idx) => {\n // TODO: Improve typing\n let currGroupTitle: string =\n (curr[groupByKey] as any as { title: string })?.title || \"Other\";\n\n let group: { Title: string; items: T[] } | undefined = find(\n groups,\n (grp) => grp.Title === currGroupTitle\n );\n\n if (!group) {\n group = { Title: currGroupTitle, items: [] };\n groups.push(group);\n }\n\n group.items.push(curr);\n return groups;\n }, [])\n .sort((a, b) =>\n a.Title === \"Other\" ? 1 : b.Title === \"Other\" ? -1 : a.Title.localeCompare(b.Title)\n );\n }, [items, groupByKey]);\n\n const openGroup = (groupName: string) => {\n let newOpenGroups = openGroups.concat(groupName);\n setOpenGroups(newOpenGroups);\n };\n\n const closeGroup = (groupToCloseName: string) => {\n setOpenGroups(openGroups.filter((groupName) => groupName !== groupToCloseName));\n };\n\n const handleRequestSort = (\n event: React.MouseEvent,\n property: Extract\n ) => {\n const isAsc = orderBy === property && order === \"asc\";\n setOrder(isAsc ? \"desc\" : \"asc\");\n setOrderBy(property);\n };\n\n // const handleSelectAllClick = (event: React.ChangeEvent) => {\n // if (event.target.checked) {\n // //@ts-ignore\n // const newSelecteds = items.map((n) => n[idCol]);\n // setSelected(newSelecteds);\n // return;\n // }\n // setSelected([]);\n // };\n\n // const handleClick = (event: React.MouseEvent, name: T[keyof T]) => {\n // const selectedIndex = selected.indexOf(name);\n // let newSelected: any[] = [];\n\n // if (selectedIndex === -1) {\n // newSelected = newSelected.concat(selected, name);\n // } else if (selectedIndex === 0) {\n // newSelected = newSelected.concat(selected.slice(1));\n // } else if (selectedIndex === selected.length - 1) {\n // newSelected = newSelected.concat(selected.slice(0, -1));\n // } else if (selectedIndex > 0) {\n // newSelected = newSelected.concat(selected.slice(0, selectedIndex), selected.slice(selectedIndex + 1));\n // }\n\n // setSelected(newSelected);\n // };\n\n const isSelected = (name: T[keyof T]) => selected.indexOf(name) !== -1;\n\n return (\n
\n \n \n \n \n \n \n {groups &&\n groups.map((grp) => {\n let isOpen = openGroups.indexOf(grp.Title) !== -1;\n return (\n \n \n isOpen\n ? closeGroup(grp.Title)\n : openGroup(grp.Title)\n }\n key={`${grp.Title}-header`}\n >\n \n \n {isOpen ? (\n \n ) : (\n \n )}\n \n \n \n {grp.Title} ({grp.items.length})\n \n \n \n \n \n {/* TODO: Style with actual colors and theme */}\n \n \n \n \n \n \n \n \n \n );\n })}\n {!groups && (\n \n )}\n \n \n \n \n
\n );\n}\n\nexport default EnhancedTable;\n","import { Card, CardActionArea, CardContent, CardMedia, Typography } from \"@material-ui/core\";\nimport Container from \"@material-ui/core/Box\";\nimport createStyles from \"@material-ui/core/styles/createStyles\";\nimport { Theme } from \"@material-ui/core/styles/createTheme\";\nimport withStyles, { WithStyles } from \"@material-ui/styles/withStyles\";\n\nimport { IBasicEntity } from \"../models/Entities\";\n\nconst styles = (theme: Theme) =>\n createStyles({\n root: {},\n image: {\n height: 80,\n padding: `${theme.spacing(4)}px ${theme.spacing(0)}px`,\n objectFit: \"contain\",\n display: \"flex\",\n flexDirection: \"column\",\n justifyContent: \"center\",\n },\n });\n\nexport interface EntityCardProps extends WithStyles {\n board: T;\n onClick: (board: T, shouldNavigate?: boolean) => void;\n}\n\nfunction UnwrappedEntityCard({ classes, board, onClick }: EntityCardProps) {\n return (\n \n {\n onClick(board, true);\n }}\n >\n \n \n \n {/* TODO: Endurskoða hvort Alfa vilji texta */}\n {/* \n {board.Title}\n */}\n \n \n );\n}\n\nexport const EntityCard = withStyles(styles)(UnwrappedEntityCard);\n","export default __webpack_public_path__ + \"static/media/fjarfestar_login_alfa.5fb0ef3c.jpg\";","import { Theme } from \"@material-ui/core/styles/createTheme\";\nimport withStyles, { WithStyles } from \"@material-ui/styles/withStyles\";\nimport { createStyles, alpha } from \"@material-ui/core/styles\";\n\nimport { useCallback } from \"react\";\nimport { Card, CardActions, CardContent, CardMedia, Hidden, Typography, Button, MenuItem, TextField, FormControl, InputLabel, Select, InputBase, Input, CircularProgress, Box } from \"@material-ui/core\";\n\nimport logo from \"../assets/Alfa_black.png\";\nimport loginPageImage from \"../assets/fjarfestar_login_alfa.jpg\";\n\nimport { history, useQuery } from \"../utils/utils\";\nimport { useEffect } from \"react\";\nimport { commonRoutes } from \"../routes/routes\";\nimport { useState } from \"react\";\nimport Snackbar from \"@material-ui/core/Snackbar\";\nimport { generateHashString, calculateVcode } from \"../utils/crypto\";\n\nconst BootstrapInput = withStyles((theme: Theme) =>\n createStyles({\n root: {\n 'label + &': {\n marginTop: theme.spacing(2),\n },\n },\n input: {\n borderRadius: 4,\n position: 'relative',\n backgroundColor: theme.palette.background.paper,\n fontSize: 16,\n padding: '10px 26px 10px 12px',\n transition: theme.transitions.create(['border-color', 'box-shadow']),\n // Use the system font instead of the default Roboto font.\n fontFamily: [\n '-apple-system',\n 'BlinkMacSystemFont',\n '\"Segoe UI\"',\n 'Roboto',\n '\"Helvetica Neue\"',\n 'Arial',\n 'sans-serif',\n '\"Apple Color Emoji\"',\n '\"Segoe UI Emoji\"',\n '\"Segoe UI Symbol\"',\n ].join(','),\n '&:focus': {\n borderRadius: 4,\n borderColor: '#80bdff',\n boxShadow: '0 0 0 0.2rem rgba(0,123,255,.25)',\n },\n },\n }),\n)(InputBase);\nconst styles = (theme: Theme) =>\n createStyles({\n root: {\n display: \"flex\",\n flex: \"1 0 auto\",\n width: \"100%\",\n minWidth: \"100%\",\n height: \"100vh\",\n alignItems: \"center\",\n justifyContent: \"center\",\n },\n leftImage: {\n height: \"100%\",\n background: `linear-gradient(0deg, ${alpha(theme.palette.secondary.main, 0.25)}, ${alpha(\n theme.palette.secondary.main,\n 0.25\n )}), url(\"${loginPageImage}\")`,\n backgroundSize: \"cover\",\n backgroundPosition: \"left\",\n flexBasis: 0,\n flexGrow: 5,\n },\n cardContainer: {\n padding: theme.spacing(3),\n flexBasis: 0,\n flexGrow: 5,\n },\n card: {\n backgroundColor: \"#fff\",\n maxWidth: 500,\n padding: 32,\n margin: \"auto\",\n textAlign: \"center\",\n // boxShadow:\n // \"0 8px 10px -5px rgb(0 0 0 / 20%), 0 16px 24px 2px rgb(0 0 0 / 14%), 0 6px 30px 5px rgb(0 0 0 / 12%)\",\n },\n media: {\n height: 70,\n objectFit: \"contain\",\n marginBottom: theme.spacing(4),\n },\n header: {\n paddingBottom: theme.spacing(3),\n [theme.breakpoints.down(\"md\")]: {\n fontWeight: \"800\",\n font: \"Arial\",\n },\n },\n text: {\n maxWidth: 400,\n margin: \"auto\",\n },\n actions: {\n justifyContent: \"center\",\n paddingTop: theme.spacing(2),\n },\n link: {\n display: \"flex\",\n flexDirection: \"column\",\n justifyContent: \"center\",\n alignItems: \"center\",\n border: `3px solid ${theme.palette.primary.main}`,\n padding: `${theme.spacing(2)}px ${theme.spacing(5)}px ${theme.spacing(1)}px`,\n cursor: \"pointer\",\n // background: \"#f7f7f7\",\n borderadius: 2,\n color: theme.palette.primary.main,\n fontWeight: 600,\n \"&:hover\": {\n textDecoration: \"none\",\n },\n },\n image: {\n maxHeight: 24,\n },\n linkText: {\n paddingTop: theme.spacing(1),\n },\n bottomText: {\n paddingTop: theme.spacing(6),\n },\n });\n\nexport interface LoginProps extends WithStyles {\n setToken: (token: string) => void;\n prepareLogin: () => Promise<{ id: string }>;\n}\n\nfunction Login({ classes, setToken, prepareLogin: _prepLogin }: LoginProps) {\n const query = useQuery();\n const [error, setError] = useState(query.get(commonRoutes.login.params.errorMessage));\n const [loginAuthId, setLoginAuthId] = useState();\n\n const [pinHash, setPinHash] = useState();\n const [loginHint, setLoginHint] = useState('');\n const [selectedEidMethod, setSelectedEidMethod] = useState(\"sim\");\n\n const prepLogin = useCallback(() => {\n _prepLogin().then((r) => setLoginAuthId(r.id));\n }, [_prepLogin, setLoginAuthId]);\n\n useEffect(() => {\n const token = query.get(commonRoutes.login.params.token);\n\n if (token) {\n setToken(token);\n } else if (!loginAuthId) {\n prepLogin();\n }\n\n if (error && query.get(commonRoutes.login.params.errorMessage)) {\n history.push(`/${commonRoutes.login.root}`);\n }\n }, [query, setToken, error, loginAuthId, prepLogin]);\n\n console.log(\"Render \");\n // TODO: Skoða bug á lágum skjám\n\n return (\n
\n \n
\n
\n {error && (\n {\n setError(null);\n }}\n message={error}\n />\n )}\n
\n \n \n \n \n Investor Portal\n \n
\n Welcome to the Alfa Framtak Investor Portal. Login to access your data.\n
\n
\n \n
\n
\n \n Tegund auðkenningu\n ) => setSelectedEidMethod(e.target.value as string)}\n input={}\n >\n {[\n { value: \"sim\", label: \"Rafræn skilríki\" },\n { value: \"app\", label: \"Auðkennisapp\" },\n ].map((option) => (\n \n {option.label}\n \n ))}\n \n \n <>\n
\n
\n \n Alfa Framtak ehf. | Lágmúli 9, 108 Reykjavík | All rights reserved\n \n Alfa Framtak ehf.
Lágmúli 9, 108 Reykjavík
All rights reserved\n
\n
\n
\n
\n
\n );\n}\n\nexport default withStyles(styles)(Login);\n","import { IInvestment, IInvestmentDocuments } from \"../models/Investments\";\n\nimport { User } from \"@ozio-alfa/common/src/models/User\";\nimport { JWTPayload } from \"@ozio-alfa/common/src/models/JWT\";\n\nimport jwt from \"jsonwebtoken\";\n\nconst tokenStorageKey = \"token\";\n\nexport default class Service {\n protected isLoggedIn: boolean = false;\n private token: string | undefined = undefined;\n private onUnauthorizedError: () => void;\n\n constructor(onUnauth: () => void) {\n this.onUnauthorizedError = onUnauth;\n }\n\n public getUserIfLoggedIn: () => User | undefined = () => {\n let token: string | null | undefined = this.token || localStorage.getItem(tokenStorageKey);\n if (!token) {\n return undefined;\n } else {\n if (tokenIsExpired(token)) {\n // TODO: refresh token?\n return undefined;\n } else if (this.token !== token) {\n this.token = token;\n }\n }\n return this.parseToken(this.token);\n };\n\n public setTokenAndGetUser: (token: string) => User = (token) => {\n this.token = token;\n localStorage.setItem(tokenStorageKey, token);\n return this.parseToken(token);\n };\n\n private parseToken: (token: string) => User = (token) => {\n try {\n const payload: JWTPayload = jwt.decode(token) as JWTPayload;\n return { name: payload.name };\n } catch (e) {\n console.error(e);\n throw e;\n }\n };\n\n public prepareLogin = () => {\n return this.get<{ id: string }>(\"/prepareLogin\");\n };\n\n public logOut: () => void = () => {\n localStorage.removeItem(tokenStorageKey);\n this.token = undefined;\n };\n\n private get(url: string): Promise {\n return fetch(`/api${url}`, {\n method: \"GET\",\n headers: {\n ContentType: \"application/json\",\n Authorization: `Bearer ${this.token}`,\n // TODO: TEST ONLY\n // Authorization: `Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIwNDEwODI1Njk5IiwibmFtZSI6IsOTbGkgw412YXJzc29uIiwiaW52ZXN0b3JJZCI6IjEiLCJleHAiOjE2MzA0MjU3MDh9.sOPXFT0HzzYnsh-w0SG68KMw2tzWcpCb0p3r14Du1xQ`,\n },\n }).then(async (res) => {\n if (res.status === 401) {\n this.onUnauthorizedError();\n } else if (res.status !== 200) {\n return res.json().then((body) => {\n throw new Error(body?.message || res.statusText || \"Something went wrong\");\n });\n } else {\n return res.json();\n }\n });\n }\n\n public getInvestments: () => Promise = () => {\n // TODO: Parse img src\n return this.get(\"/investor/funds\");\n };\n\n public getInvestmentByName: (investmentName: string) => Promise = async (investmentName) => {\n return this.get(`/investor/funds?name=${investmentName}`).then((investmentArray) => {\n let investment = investmentArray[0];\n if (investment === undefined) throw new Error(\"Investment not found\");\n return investment;\n });\n };\n\n public getInvestmentDocuments: (investmentId: number) => Promise = async (investmentId) => {\n return this.get(`/investor/funds/${investmentId}/documents`);\n };\n}\nfunction tokenIsExpired(token: string) {\n const payload = jwt.decode(token) as JWTPayload;\n return !payload?.exp || Date.now() > payload.exp * 1000;\n}\n","import Container from \"@material-ui/core/Container\";\nimport createStyles from \"@material-ui/core/styles/createStyles\";\nimport { Theme } from \"@material-ui/core/styles/createTheme\";\nimport Typography from \"@material-ui/core/Typography\";\nimport withStyles, { WithStyles } from \"@material-ui/styles/withStyles\";\n\nconst styles = (theme: Theme) =>\n createStyles({\n message: {\n width: \"fit-content\",\n margin: \"auto\",\n padding: theme.spacing(3),\n paddingBottom: 0,\n },\n subMessage: {\n width: \"fit-content\",\n margin: \"auto\",\n padding: theme.spacing(1),\n paddingBottom: 0,\n },\n });\n\nexport interface MessageProps extends WithStyles {\n message: string;\n internalError?: string | Error;\n}\n\nfunction Message({ classes, message, internalError }: MessageProps) {\n return (\n
\n \n \n {message}\n \n {internalError && (\n \n Internal Error: {typeof internalError === \"string\" ? internalError : internalError.message}\n \n )}\n \n
\n );\n}\n\nexport default withStyles(styles)(Message);\n","import { useState, useEffect, useCallback } from \"react\";\n// Usage\n// function App() {\n// const { execute, status, value, error } = useAsync(myFunction, false);\n// return (\n//
\n// {status === \"idle\" &&
Start your journey by clicking a button
}\n// {status === \"success\" &&
{value}
}\n// {status === \"error\" &&
{error}
}\n// \n//
\n// );\n// }\n// An async function for testing our hook.\n// Will be successful 50% of the time.\n// const myFunction = (): Promise => {\n// return new Promise((resolve, reject) => {\n// setTimeout(() => {\n// const rnd = Math.random() * 10;\n// rnd <= 5 ? resolve(\"Submitted successfully 🙌\") : reject(\"Oh no there was an error 😞\");\n// }, 2000);\n// });\n// };\n// Hook\nexport const useAsync = (asyncFunction: () => Promise, immediate = true) => {\n const [status, setStatus] = useState<\"idle\" | \"pending\" | \"success\" | \"error\">(\"idle\");\n const [value, setValue] = useState(null);\n const [error, setError] = useState(null);\n // The execute function wraps asyncFunction and\n // handles setting state for pending, value, and error.\n // useCallback ensures the below useEffect is not called\n // on every render, but only if asyncFunction changes.\n const execute = useCallback(() => {\n setStatus(\"pending\");\n setValue(null);\n setError(null);\n return asyncFunction()\n .then((response: any) => {\n setValue(response);\n setStatus(\"success\");\n })\n .catch((error: any) => {\n setError(error);\n setStatus(\"error\");\n });\n }, [asyncFunction]);\n // Call execute if we want to fire it right away.\n // Otherwise execute can be called later, such as\n // in an onClick handler.\n useEffect(() => {\n if (immediate) {\n execute();\n }\n }, [execute, immediate]);\n return { execute, status, value, error };\n};\n","import { Grid, Typography } from \"@material-ui/core\";\n\nimport createStyles from \"@material-ui/core/styles/createStyles\";\nimport { Theme } from \"@material-ui/core/styles/createTheme\";\nimport withStyles, { WithStyles } from \"@material-ui/styles/withStyles\";\nimport { EntityCardProps } from \"@ozio-alfa/common/src/components/EntityCard\";\nimport { wrapperClass } from \"@ozio-alfa/common/src/utils/Styles\";\nimport Message from \"@ozio-alfa/common/src/components/Message\";\n\nimport { IInvestment } from \"../models/Investments\";\nimport { EnhancedTable, Spinner } from \"@ozio-alfa/common\";\nimport { useAsync } from \"@ozio-alfa/common/src/utils/UseAsync\";\nimport Container from \"@material-ui/core/Container\";\n\nconst styles = (theme: Theme) =>\n createStyles({\n wrapperClass: {\n ...wrapperClass.wrapperClass,\n paddingTop: theme.spacing(2),\n },\n message: {\n width: \"fit-content\",\n margin: \"auto\",\n padding: theme.spacing(3),\n paddingBottom: 0,\n },\n });\n\nexport interface MyInvestmentsProps extends WithStyles {\n getInvestments: () => Promise;\n setSelectedInvestment: EntityCardProps[\"onClick\"];\n}\n\nfunction MyInvestments({ classes, getInvestments, setSelectedInvestment }: MyInvestmentsProps) {\n const { status, value: investments, error } = useAsync(getInvestments);\n\n return (\n
\n \n {status === \"pending\" && }\n {status === \"success\" && investments && investments.length > 0 && (\n {\n // downloadFromUrl(item.downloadUrl, item.name);\n setSelectedInvestment(item, false);\n }}\n disableSort={true}\n />\n // <>\n )}\n {status === \"success\" && investments && investments.length === 0 && (\n \n \n We found no investments for you\n \n \n )}\n {status === \"error\" && (\n \n )}\n \n
\n );\n}\n\nexport default withStyles(styles)(MyInvestments);\n","import React from \"react\";\nimport { Theme } from \"@material-ui/core/styles/createTheme\";\nimport createStyles from \"@material-ui/core/styles/createStyles\";\nimport withStyles, { WithStyles } from \"@material-ui/styles/withStyles\";\n\nimport List from \"@material-ui/core/List\";\nimport ListItem from \"@material-ui/core/ListItem\";\nimport ListItemIcon from \"@material-ui/core/ListItemIcon\";\nimport ListItemText from \"@material-ui/core/ListItemText\";\nimport Paper from \"@material-ui/core/Paper\";\n\nimport { Link as RouterLink, LinkProps as RouterLinkProps, useParams } from \"react-router-dom\";\n\nimport { BoardPageParams } from \"../routes/routes\";\n\nconst styles = (theme: Theme) =>\n createStyles({\n root: {\n paddingTop: theme.spacing(1),\n },\n });\n\nexport interface PageMenuProps extends WithStyles {\n // E.g. 'boards/umbreyting 1'\n rootPath: string;\n links: ListItemLinkProps[];\n}\n\ninterface ListItemLinkProps {\n icon: React.ReactElement;\n text: string;\n to: string;\n isDirect?: boolean;\n isDefaultSelected?: boolean;\n}\n\nfunction PageMenu({ classes, rootPath, links }: PageMenuProps) {\n let { page } = useParams();\n\n function ListLink(props: ListItemLinkProps) {\n const { icon, text, to, isDirect, isDefaultSelected } = props;\n\n const renderLink = React.useMemo(\n () =>\n React.forwardRef>((itemProps, ref) => (\n \n )),\n [to]\n );\n\n return (\n
  • \n \n {icon ? {icon} : null}\n \n \n
  • \n );\n }\n\n return (\n
    \n \n \n {links.map((link) => (\n \n ))}\n {/* } isDirect />\n } isDefaultSelected />\n } />\n // } />\n } /> */}\n \n \n
    \n );\n}\n\nexport default withStyles(styles)(PageMenu);\n","import { Theme } from \"@material-ui/core/styles/createTheme\";\nimport withStyles, { WithStyles } from \"@material-ui/styles/withStyles\";\nimport { createStyles } from \"@material-ui/core/styles\";\n\nimport { Spinner, EnhancedTable } from \"@ozio-alfa/common\";\nimport { useAsync } from \"@ozio-alfa/common/src/utils/UseAsync\";\nimport { getFileTypeIconProps, initializeFileTypeIcons } from \"@fluentui/react-file-type-icons\";\nimport { IInvestmentDocuments } from \"../models/Investments\";\nimport { downloadFromUrl } from \"@ozio-alfa/common/src/utils/utils\";\nimport Message from \"@ozio-alfa/common/src/components/Message\";\n// import { Icon } from \"@material-ui/core\";\nimport { Icon } from \"@fluentui/react/lib/Icon\";\nimport { useEffect } from \"react\";\n\nconst styles = (theme: Theme) =>\n createStyles({\n root: {\n margin: `${theme.spacing(4)}px auto`,\n marginLeft: theme.spacing(3),\n flexGrow: 1,\n display: \"flex\",\n justifyContent: \"center\",\n [theme.breakpoints.down(\"md\")]: {\n width: \"100%\",\n margin: 0,\n },\n },\n });\n\nexport interface InvestmentDocumentsProps extends WithStyles {\n getInvestmentDocuments: () => Promise;\n}\n\nfunction InvestmentDocuments({ classes, getInvestmentDocuments }: InvestmentDocumentsProps) {\n const { status, value: documents, error } = useAsync(getInvestmentDocuments);\n useEffect(() => {\n initializeFileTypeIcons(undefined);\n }, []);\n console.log(\"Render \");\n\n return (\n
    \n {status === \"pending\" && }\n {status === \"success\" && documents && documents.length !== 0 && (\n (\n \n ),\n disablePadding: true,\n },\n { id: \"name\", disablePadding: false, label: \"Name\" },\n // TODO: Discuss columns\n // { id: \"uniqueId\", label: \"ID\" }\n ]}\n idCol={\"uniqueId\"}\n groupByKey={\"type\"}\n onClick={(ev, item) => {\n downloadFromUrl(item.downloadUrl, item.name);\n }}\n disableSort={true}\n />\n )}\n {status === \"success\" && (!documents || (documents && documents.length === 0)) && (\n \n )}\n {status === \"error\" && (\n \n )}\n
    \n );\n}\n\nexport default withStyles(styles)(InvestmentDocuments);\n","import { useCallback, useState } from \"react\";\nimport { useEffect } from \"react\";\n\nimport { Switch, useParams, useRouteMatch, Route } from \"react-router-dom\";\n\nimport Grid from \"@material-ui/core/Grid\";\nimport Container from \"@material-ui/core/Container\";\nimport createStyles from \"@material-ui/core/styles/createStyles\";\nimport { Theme } from \"@material-ui/core/styles/createTheme\";\nimport withStyles, { WithStyles } from \"@material-ui/styles/withStyles\";\n\nimport HomeIcon from \"@material-ui/icons/Home\";\n\nimport { wrapperClass } from \"@ozio-alfa/common/src/utils/Styles\";\nimport { history, Spinner } from \"@ozio-alfa/common\";\nimport { InvestmentPageParams, investmentRoutes } from \"@ozio-alfa/common/src/routes/routes\";\nimport PageMenu from \"@ozio-alfa/common/src/components/PageMenu\";\nimport { IInvestment, IInvestmentDocuments } from \"../models/Investments\";\nimport InvestmentDocuments from \"../Sections/InvestmentDocuments\";\n\nconst styles = (theme: Theme) =>\n createStyles({\n ...wrapperClass,\n });\n\nexport interface BoardPageProps extends WithStyles {\n investment: IInvestment | undefined;\n setSelectedInvestment: (board: IInvestment | string) => Promise;\n getInvestmentDocuments: (investmentId: IInvestment[\"id\"]) => Promise;\n setErrorToast: (errorMessage: string) => void;\n}\n\nfunction InvestmentPage({\n classes,\n investment,\n setSelectedInvestment,\n getInvestmentDocuments,\n setErrorToast,\n}: BoardPageProps) {\n // const { status, value: investments, error } = useAsync(getInvestments);\n\n let [isLoading, setIsLoading] = useState(!investment);\n // let [error, setError] = useState(\"\");\n\n const wrappedGetInvDocs = useCallback(\n () => getInvestmentDocuments(investment?.id || 0),\n [investment, getInvestmentDocuments]\n );\n\n let { investmentName } = useParams();\n\n let { path } = useRouteMatch();\n\n useEffect(() => {\n if (!investment) {\n setSelectedInvestment(investmentName)\n .then(() => {\n setIsLoading(false);\n })\n .catch((error: string | Error) => {\n console.error(typeof error === \"string\" ? error : error.message);\n setErrorToast(`There was an error finding: '${investmentName}'`);\n setIsLoading(false);\n history.push(\"/\");\n });\n }\n }, [investment, setSelectedInvestment, setIsLoading, investmentName, setErrorToast]);\n\n console.log(\"Render \");\n\n return (\n \n {(isLoading || !investmentName) && (\n <>\n {isLoading && }\n {!isLoading && !investmentName && (\n \n {/* TODO: Handle errors */}\n 404: Investment not found\n \n )}\n \n )}\n {!isLoading && investment && (\n <>\n ,\n isDirect: true,\n },\n ]}\n />\n \n \n \n \n \n \n )}\n \n );\n}\n\nexport default withStyles(styles)(InvestmentPage);\n","// Ársreikningar\n// Árshlutaskýrslur\n// Fréttabréf\n// Innkallanir\n// Annað\n\nimport React from \"react\";\nimport logo from \"./logo.svg\";\n\nimport { Router, Switch, Route, Redirect } from \"react-router-dom\";\nimport { ThemeProvider } from \"@material-ui/core\";\n\nimport { AlfaTheme, CommonPageElements, AuthRoute, history } from \"@ozio-alfa/common\";\nimport Login from \"@ozio-alfa/common/src/pages/Login\";\nimport { User } from \"@ozio-alfa/common/src/models/User\";\n\nimport { commonRoutes, investmentPageParamDict, investmentRoutes } from \"@ozio-alfa/common/src/routes/routes\";\n\nimport Service from \"./services/Service\";\n\nimport Typography from \"@material-ui/core/Typography\";\nimport MyInvestments from \"./Pages/MyInvestments\";\nimport { IInvestment } from \"./models/Investments\";\nimport InvestmentPage from \"./Pages/InvestmentPage\";\nimport Snackbar from \"@material-ui/core/Snackbar\";\n\ninterface IAppState {\n user: User | undefined;\n selectedInvestment: IInvestment | undefined;\n error: string;\n}\n\ninterface IAppProps {}\n\nclass App extends React.Component {\n private service: Service;\n\n constructor(props: IAppProps) {\n super(props);\n\n this.service = new Service(this.handleUnauthorizedRequest);\n\n this.state = {\n user: this.service.getUserIfLoggedIn(),\n selectedInvestment: undefined,\n error: \"\",\n };\n }\n\n private setSelectedInvestment = async (investment: IInvestment | string, shouldNavigate: boolean = false) => {\n let selectedInvestment: IInvestment =\n typeof investment === \"string\" ? await this.service.getInvestmentByName(investment) : investment;\n\n this.setState({ selectedInvestment }, () => {\n shouldNavigate && history.push(`/${investmentRoutes.investments.root}/${selectedInvestment.title}`);\n });\n };\n\n private setErrorToast = (errorMessage: string) => {\n this.setState({ error: errorMessage }, () => {\n setTimeout(this.clearErrorToast, 6000);\n });\n };\n\n private clearErrorToast = () => this.setState({ error: \"\" });\n\n private logIn = (token: string) => {\n let user = this.service.setTokenAndGetUser(token);\n this.setState({ user }, () => {\n history.push(`/`);\n });\n };\n\n private logOut = () => {\n this.service.logOut();\n this.setState({ user: undefined }, () => {\n history.push(`/${commonRoutes.login.root}`);\n });\n };\n\n private handleUnauthorizedRequest = () => {\n this.setState({ user: undefined }, () => {\n history.push(\n `/${commonRoutes.login.root}?${commonRoutes.login.params.errorMessage}=Your session has expired, please login again`\n );\n });\n };\n\n public render() {\n console.log(\"Render \");\n\n return (\n \n \n (\n <>\n Investor Portal\n {/* \n Welcome to Alfa Framtak's investor portal\n */}\n \n )}\n user={this.state.user}\n logOut={this.logOut}\n >\n {this.state.error && (\n \n )}\n \n \n {this.state.user !== undefined && }\n \n \n \n
    \n
    \n \"logo\"\n

    \n Edit src/App.tsx and save to reload.\n

    \n \n Learn React\n \n
    \n
    \n
    \n \n \n \n \n \n \n
    \n \n
    \n
    \n );\n }\n}\n\nexport default App;\n","import { ReportHandler } from 'web-vitals';\n\nconst reportWebVitals = (onPerfEntry?: ReportHandler) => {\n if (onPerfEntry && onPerfEntry instanceof Function) {\n import('web-vitals').then(({ getCLS, getFID, getFCP, getLCP, getTTFB }) => {\n getCLS(onPerfEntry);\n getFID(onPerfEntry);\n getFCP(onPerfEntry);\n getLCP(onPerfEntry);\n getTTFB(onPerfEntry);\n });\n }\n};\n\nexport default reportWebVitals;\n","import React from \"react\";\nimport ReactDOM from \"react-dom\";\nimport \"./index.css\";\nimport App from \"./App\";\nimport reportWebVitals from \"./reportWebVitals\";\n\nReactDOM.render(\n // \n ,\n // ,\n document.getElementById(\"root\")\n);\n\n// If you want to start measuring performance in your app, pass a function\n// to log results (for example: reportWebVitals(console.log))\n// or send to an analytics endpoint. Learn more: https://bit.ly/CRA-vitals\nreportWebVitals();\n"],"sourceRoot":""}