{"version":3,"sources":["components/Buttons/index.js","config.js","store.js","components/ErrorBoundaryFallback/index.js","modules/attachments/fileSize.js","lib/forms/Form/index.js","lib/forms/TextInput/index.js","lib/forms/File/index.js","lib/forms/Recaptcha/messages.js","lib/forms/Recaptcha/index.js","lib/forms/Radio/index.js","lib/forms/Toggle/index.js","lib/forms/DatePicker/index.js","lib/forms/Select/index.js","lib/forms/errorHandler.js","modules/auth/fetch.js","modules/auth/model.js","modules/auth/components/PrivateRoute/index.js","modules/auth/components/TokenManager/index.js","layouts/AdministrationLayout/Header.js","layouts/AdministrationLayout/messages.js","layouts/AdministrationLayout/elements.js","layouts/AdministrationLayout/index.js","modules/api/Fetch.js","modules/api/request.js","components/ErrorBoundaryFallback/messages.js","components/Typography/Headings.js","components/Loader/index.js","components/Badge/index.js","components/Logo/HK_RGB_ligg_payoff.png","lib/Loadable.js","modules/localization/translations/actions.js","modules/localization/translations/form.js","modules/localization/index.js","components/Logo/index.js","components/Responsive/index.js","icons.js","layouts/Header/index.js","layouts/PublicLayout/index.js","routes/Admin/Login/components/LoginForm/messages.js","routes/Admin/Login/components/LoginForm/index.js","routes/Admin/Login/messages.js","routes/Admin/Login/index.js","layouts/LoginLayout/index.js","App.js","serviceWorker.js","modules/localization/LanguageProvider.js","index.js"],"names":["Button","styled","button","props","fullWidth","space","is","theme","colors","primary","styledBy","small","color","tiny","PlainButton","settings","global","COLLABORATION_PORTAL","getApiRoot","apiRoot","getReCaptchaSiteKey","reCaptcha","siteKey","store","configureStore","persistPlugin","createRematchPersist","whitelist","throttle","version","init","plugins","models","auth","authModel","ErrorBoundaryFallback","componentStack","error","messages","heading","errorInstruction","style","whiteSpace","location","pathname","toString","ATTACHMENT_MAX_SIZE","ATTACHMENTS_TOTAL_MAX_SIZE","bytesToMB","bytes","defineMessages","totalMaxSizeExceeded","id","defaultMessage","attachmentFileSizeExceeded","validateSize","formatMessage","d","total","value","reduce","acc","curr","size","FormElement","div","FieldError","attrs","my","LabelText","span","Input","input","primaryLighter","TextArea","withComponent","onKeyDownSpaceProgationEventFix","e","keyCode","stopPropagation","nativeEvent","stopImmediatePropagation","onClickSpaceProgagationEventFix","TextInput","React","forwardRef","ref","className","field","form","touched","errors","type","label","multiLine","innerRef","onKeyDown","onClick","name","defaultProps","StyledDropZone","Dropzone","FileList","ul","File","injectIntl","setFieldValue","dropZoneText","intl","preventDefault","onDrop","filesToUpload","concat","onDropRejected","files","message","map","x","join","maxSize","toast","autoClose","Array","isArray","file","key","preview","filter","icon","expired","RecaptchaField","setFieldError","sitekey","verifyCallback","response","expiredCallback","propTypes","intlShape","PropTypes","string","object","isRequired","RadioButton","onChange","onBlur","Radio","checked","RadioButtonGroup","children","Toggle","toggle","event","Component","SelectInput","select","Select","options","emptyOption","errorHandler","values","actions","console","log","data","status","headers","request","setSubmitting","login","username","password","body","userAuthSelector","state","isAuthed","token","decoded","sub","firstName","lastName","userTokenSelector","setToken","raw","jwtDecode","model","reducers","onLoginSuccess","onTokenRenewed","onTokenExpired","logout","effects","dispatch","onLogout","payload","rootState","info","translations","loggedOut","renewToken","tokenState","tokenResponse","tokenExpired","PrivateRouteConnected","connect","component","rest","render","to","TokenManager","userToken","scheduleRenewal","exp","prevProps","prevState","_","get","this","unscheduleRenewal","expiresAt","timeAhead","timeUntilRenewal","tokenExpiresAt","now","moment","utc","unix","isTokenExpired","add","renewTimeout","setTimeout","clearTimeout","Divider","PageTitle","h2","Username","HeaderWrapper","primaryDarker","PrintFriendlyContactInfo","Flex","Header","width","ml","Logo","PageTitleContext","Consumer","title","alignItems","marginLeft","display","mr","applications","collaborationPrograms","messageTemplates","budgetOverview","users","PageWrapper","SidebarToggler","Sidebar","StyledMotionDrawer","Drawer","NavigationList","NavigationItem","li","createContext","pageTitle","setPageTitle","AsyncApplicationsOverview","Loadable","loader","AsyncApplicationDetails","AsyncCollaborationPrograms","AsyncCollaborationProgramDetails","AsynMessageTemplates","AsynSettingsPage","AsyncBudgetOverviewPage","AsyncUsersOverviewPage","AdministrationLayout","setState","onSetOpen","isOpen","drawerIsOpen","closeDrawer","padding","FallbackComponent","path","Provider","open","renderNavItems","height","order","renderMain","textAlign","maxWidth","VigiloFetch","skipAuth","url","beforeFetch","afterFetch","onError","query","suppressError","finalHeaders","Pragma","Expires","queries","qs","stringify","urlWithApiroot","JSON","getState","Authorization","failed","isFunction","validationErrors","fetchPolicy","defaultOptions","endpoint","verb","Accept","Object","assign","callURL","requestConfig","method","undefined","responseType","axios","as","AdminPageTitle","AdminPageTitleWrapper","Badge","Math","floor","NameBadge","initials","module","exports","loadable","pMinDelay","fallBack","active","saved","save","send","sent","submit","delete","cancel","attachments","addLocaleData","enLocaleData","nbLocaleData","formatTranslationMessages","locale","defaultFormattedMessages","enTranslationMessages","keys","formattedMessages","formattedMessage","translationMessages","en","nb","nbTranslationMessages","src","logo","alt","Desktop","minWidth","Small","fontawesome","library","faMinusCircle","faTimesCircle","faPaste","faEdit","faBars","faPaperclip","faChartBar","faEnvelope","faFileAlt","faClipboard","faSignOutAlt","faUsers","Fragment","marginBottom","AsyncLandingpage","AsyncSubmitApplicationPage","FeedbackPage","media","greaterThan","PublicLayout","exact","loginLabel","usernameLabel","passwordLabel","invalidLoginMessage","LoginForm","initialValues","validationSchema","Yup","shape","required","onSubmit","then","catch","setErrors","isSubmitting","mt","disabled","func","LoginPage","history","push","header","LoginLayout","mixin","pascalCase","flow","camelCase","upperFirst","GlobalStyle","createGlobalStyle","App","Boolean","window","hostname","match","LanguageProvider","setLocale","mixed","number","min","max","less","more","notEqual","positive","negative","integer","email","length","setYupLocale","Children","only","PureComponent","persistor","persistStore","ReactDOM","primaryMedium","document","getElementById","Intl","Promise","resolve","all","err","navigator","serviceWorker","ready","registration","unregister"],"mappings":"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","file":"static/js/main.43d899d3.chunk.js","sourcesContent":["import styled from \"styled-components\";\r\nimport is from \"styled-is\";\r\nimport { space } from \"styled-system\";\r\nimport styledBy from \"styled-by\";\r\n\r\nconst Button = styled.button`\r\n border: 0;\r\n display: inline-block;\r\n margin-bottom: 0;\r\n text-align: center;\r\n vertical-align: middle;\r\n touch-action: manipulation;\r\n cursor: pointer;\r\n background-image: none;\r\n white-space: nowrap;\r\n padding: 10px 12px;\r\n font-size: 16px;\r\n line-height: 1.42857143;\r\n border-radius: 0;\r\n user-select: none;\r\n transition: background-color 350ms;\r\n background-color: #919191;\r\n color: #fff;\r\n width: ${props => (props.fullWidth === true ? \"100%\" : \"auto\")};\r\n ${space};\r\n\r\n ${is(\"primary\")`\r\n background-color: ${props => props.theme.colors.primary};\r\n color: #fff;\r\n `};\r\n\r\n ${is(\"danger\")`\r\n background-color: #db2828;\r\n color: #fff;\r\n\r\n &:hover {\r\n background-color: #d01919;\r\n }\r\n `};\r\n\r\n ${styledBy(\"size\", {\r\n small: ({ theme, color }) => `\r\n padding: 8px 8px;\r\n font-size: 14px;\r\n `,\r\n tiny: ({ theme, color }) => `\r\n padding: 6px 8px;\r\n font-size: 12px;\r\n `\r\n })};\r\n\r\n &[disabled] {\r\n cursor: not-allowed;\r\n opacity: 0.65;\r\n box-shadow: none;\r\n }\r\n\r\n @media print {\r\n display: none;\r\n }\r\n`;\r\n\r\nexport const PlainButton = styled.button`\r\n border: 0;\r\n background: none;\r\n cursor: pointer;\r\n color: inherit;\r\n ${space};\r\n`;\r\n\r\nexport { Button };\r\n","const globalConfig = global.COLLABORATION_PORTAL;\r\nconst settings = globalConfig.settings;\r\n\r\nexport function getApiRoot() {\r\n return settings.apiRoot;\r\n}\r\n\r\nexport function getReCaptchaSiteKey() {\r\n return settings.reCaptcha.siteKey;\r\n}\r\n","import { init } from \"@rematch/core\";\r\nimport { model as authModel } from \"modules/auth\";\r\nimport createRematchPersist from \"@rematch/persist\";\r\n\r\nlet store;\r\n\r\nexport const configureStore = () => {\r\n if (store) {\r\n return store;\r\n }\r\n\r\n const persistPlugin = createRematchPersist({\r\n whitelist: [\"auth\"],\r\n throttle: 15,\r\n version: 2\r\n });\r\n\r\n store = init({\r\n plugins: [persistPlugin],\r\n models: {\r\n auth: authModel\r\n }\r\n });\r\n\r\n return store;\r\n};\r\n","import React from \"react\";\r\nimport { FormattedMessage } from \"react-intl\";\r\nimport messages from \"./messages\";\r\n\r\nconst ErrorBoundaryFallback = ({ componentStack, error }) => (\r\n
\r\n

\r\n \r\n

\r\n

\r\n \r\n

\r\n\r\n
\r\n Route: {global.location.pathname}\r\n
\r\n {error && error.toString()}\r\n
\r\n {componentStack}\r\n
\r\n
\r\n);\r\n\r\nexport default ErrorBoundaryFallback;\r\n","import { defineMessages } from \"react-intl\";\r\n\r\n/** Max size per individual attachment (bytes) */\r\nexport const ATTACHMENT_MAX_SIZE = 10 * 10 ** 6; // 10 MB\r\n\r\n/** Max allowed sum of all attachments' file size (bytes) */\r\nexport const ATTACHMENTS_TOTAL_MAX_SIZE = 10 * 10 ** 6; // 10 MB\r\n\r\nexport const bytesToMB = (bytes) => bytes / 10 ** 6;\r\n\r\nexport const messages = defineMessages({\r\n totalMaxSizeExceeded: {\r\n id: \"app.attachments.totalMaxSizeExceeded\",\r\n defaultMessage:\r\n \"Sum of attachment file sizes exceeds allowed total ({total})\",\r\n },\r\n attachmentFileSizeExceeded: {\r\n id: \"app.attachments.attachmentFileSizeExceeded\",\r\n defaultMessage: \"Files ({files}) exceeds allowed max size ({maxSize})\",\r\n },\r\n});\r\n\r\nexport const validateSize = (formatMessage) => [\r\n \"is-valid-size\",\r\n (d) =>\r\n formatMessage(messages.totalMaxSizeExceeded, {\r\n total: `${bytesToMB(ATTACHMENTS_TOTAL_MAX_SIZE)} MB`,\r\n }),\r\n (value) => {\r\n const sumFileSizes = value.reduce((acc, curr) => acc + curr.size, 0);\r\n\r\n return sumFileSizes < ATTACHMENTS_TOTAL_MAX_SIZE;\r\n },\r\n];\r\n","import styled from \"styled-components\";\r\nimport { space } from \"styled-system\";\r\n\r\nexport const FormElement = styled.div`\r\n margin-bottom: 15px;\r\n`;\r\n\r\nexport const FieldError = styled.div.attrs({ my: 1 })`\r\n color: #e30000;\r\n ${space};\r\n`;\r\n\r\nexport const LabelText = styled.span`\r\n font-weight: 300;\r\n padding-bottom: 5px;\r\n display: block;\r\n color: #555;\r\n font-size: 16px;\r\n`;\r\n","import React from \"react\";\r\nimport styled from \"styled-components\";\r\nimport { FormElement, LabelText, FieldError } from \"../Form\";\r\n\r\nexport const Input = styled.input`\r\n border: 3px solid ${(props) => props.theme.colors.primaryLighter};\r\n display: block;\r\n padding: 12px;\r\n width: 100%;\r\n max-width: 100%;\r\n`;\r\n\r\nexport const TextArea = Input.withComponent(\"textarea\");\r\n\r\n// Prevents space keydown/click event from propagating to parent elements\r\n// Fixes issue with pressing space/click triggering opening dropdown in the background of modal instead of typing space in the input\r\nconst onKeyDownSpaceProgationEventFix = (e) => {\r\n if (e.keyCode === 32) {\r\n e.stopPropagation();\r\n e.nativeEvent.stopImmediatePropagation();\r\n } else {\r\n return null;\r\n }\r\n};\r\n\r\nconst onClickSpaceProgagationEventFix = (e) => {\r\n e.stopPropagation();\r\n e.nativeEvent.stopImmediatePropagation();\r\n};\r\n\r\nconst TextInput = React.forwardRef(\r\n (\r\n {\r\n className,\r\n field,\r\n form: { touched, errors },\r\n type,\r\n label,\r\n multiLine,\r\n innerRef,\r\n ...props\r\n },\r\n ref\r\n ) => (\r\n \r\n \r\n \r\n )\r\n);\r\n\r\nTextInput.defaultProps = {\r\n type: \"text\",\r\n multiLine: false,\r\n};\r\n\r\nexport { TextInput };\r\n","import React from \"react\";\r\nimport styled from \"styled-components\";\r\nimport Dropzone from \"react-dropzone\";\r\nimport { FormElement, FieldError, LabelText } from \"../Form\";\r\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\r\nimport {\r\n ATTACHMENT_MAX_SIZE,\r\n messages,\r\n bytesToMB,\r\n} from \"modules/attachments/fileSize\";\r\nimport { injectIntl } from \"react-intl\";\r\nimport { toast } from \"react-toastify\";\r\n\r\nconst PlainButton = styled.button`\r\n padding: 0;\r\n margin: 0;\r\n border: 0;\r\n background: none;\r\n cursor: pointer;\r\n`;\r\n\r\nconst StyledDropZone = styled(Dropzone)`\r\n width: 100%;\r\n height: 50px;\r\n border: 3px dashed ${(props) => props.theme.colors.primaryLighter};\r\n display: flex;\r\n flex-direction: column;\r\n justify-content: center;\r\n align-items: center;\r\n padding: 10px;\r\n transition: background-color 200ms;\r\n cursor: pointer;\r\n margin: 10px 0px;\r\n color: #444;\r\n\r\n &:hover {\r\n background-color: rgba(0, 0, 0, 0.1);\r\n }\r\n`;\r\n\r\nconst FileList = styled.ul`\r\n margin: 0;\r\n padding: 0;\r\n list-style: none;\r\n`;\r\n\r\nconst File = injectIntl(\r\n ({\r\n className,\r\n field,\r\n form: { touched, errors, setFieldValue },\r\n label,\r\n dropZoneText,\r\n intl: { formatMessage },\r\n ...props\r\n }) => (\r\n \r\n \r\n\r\n {field.value && Array.isArray(field.value) && (\r\n \r\n {field.value.map((file) => {\r\n return (\r\n
  • \r\n {\r\n setFieldValue(\r\n field.name,\r\n field.value.filter((x) => x !== file)\r\n );\r\n }}\r\n >\r\n {\" \"}\r\n {file.name}\r\n \r\n
  • \r\n );\r\n })}\r\n
    \r\n )}\r\n
    \r\n )\r\n);\r\n\r\nexport { File };\r\n","import { defineMessages } from \"react-intl\";\r\n\r\nexport default defineMessages({\r\n expired: {\r\n id: \"app.form.recaptcha.expired\",\r\n defaultMessage: \"Expired. Please re-verify.\"\r\n },\r\n label: {\r\n id: \"app.form.recaptcha.label\",\r\n defaultMessage: \"Are you a robot?\"\r\n }\r\n});\r\n","import React from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport Recaptcha from \"react-recaptcha\";\r\nimport { injectIntl, intlShape } from \"react-intl\";\r\nimport { getReCaptchaSiteKey } from \"config.js\";\r\nimport { FormElement, LabelText, FieldError } from \"../Form\";\r\nimport messages from \"./messages\";\r\n\r\nconst RecaptchaField = injectIntl(\r\n ({\r\n className,\r\n field,\r\n intl: { formatMessage },\r\n form: { touched, errors, setFieldValue, setFieldError },\r\n label,\r\n ...props\r\n }) => (\r\n \r\n \r\n \r\n )\r\n);\r\n\r\nRecaptchaField.propTypes = {\r\n intl: intlShape,\r\n label: PropTypes.string,\r\n className: PropTypes.string,\r\n field: PropTypes.object.isRequired,\r\n form: PropTypes.object.isRequired\r\n};\r\n\r\nexport { RecaptchaField };\r\n","import React from \"react\";\r\nimport { FormElement, LabelText, FieldError } from \"../Form\";\r\nimport { Radio } from \"semantic-ui-react\";\r\n\r\nexport const RadioButton = ({\r\n field: { name, value, onChange, onBlur },\r\n id,\r\n label,\r\n className,\r\n ...props\r\n}) => {\r\n return (\r\n
    \r\n \r\n
    \r\n );\r\n};\r\n\r\nexport const RadioButtonGroup = ({\r\n value,\r\n error,\r\n touched,\r\n id,\r\n label,\r\n className,\r\n children\r\n}) => {\r\n return (\r\n \r\n {label}\r\n {children}\r\n {touched && error && {error}}\r\n \r\n );\r\n};\r\n","import React from \"react\";\r\nimport { FieldError } from \"../Form\";\r\nimport { Radio } from \"semantic-ui-react\";\r\n\r\nexport const Toggle = ({\r\n field: { name, value, onChange, onBlur },\r\n id,\r\n form,\r\n label,\r\n className,\r\n ...props\r\n}) => {\r\n return (\r\n
    \r\n {\r\n form.setFieldValue(name, !value);\r\n }}\r\n onBlur={onBlur}\r\n label={label}\r\n {...props}\r\n />\r\n\r\n {form.touched[name] && form.errors[name] && (\r\n {form.errors[name]}\r\n )}\r\n
    \r\n );\r\n};\r\n","import React from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport DayPickerInput from \"react-day-picker/DayPickerInput\";\r\nimport { FormElement, LabelText, FieldError } from \"../Form\";\r\nimport { Input } from \"../TextInput\";\r\n\r\n// Hack for styled-component's inner ref thingie\r\nclass InputWithFocus extends React.Component {\r\n focus = () => {\r\n this.input.focus();\r\n };\r\n\r\n render() {\r\n return (this.input = el)} {...this.props} />;\r\n }\r\n}\r\n\r\nexport const DatePicker = ({\r\n className,\r\n field,\r\n form: { touched, errors, setFieldValue, setFieldError },\r\n label,\r\n ...props\r\n}) => (\r\n \r\n \r\n \r\n);\r\n\r\nDatePicker.propTypes = {\r\n label: PropTypes.string,\r\n className: PropTypes.string,\r\n field: PropTypes.object.isRequired,\r\n form: PropTypes.object.isRequired\r\n};\r\n","import React from \"react\";\r\nimport styled from \"styled-components\";\r\nimport { FormElement, LabelText, FieldError } from \"../Form\";\r\n\r\nexport const SelectInput = styled.select`\r\n border: 3px solid ${(props) => props.theme.colors.primaryLighter};\r\n display: block;\r\n padding: 12px;\r\n width: 100%;\r\n max-width: 100%;\r\n -webkit-appearance: none;\r\n border-radius: 0;\r\n background-color: #fff;\r\n\r\n background-image: linear-gradient(45deg, transparent 50%, gray 50%),\r\n linear-gradient(135deg, gray 50%, transparent 50%),\r\n linear-gradient(to right, #ccc, #ccc);\r\n background-position: calc(100% - 20px) calc(1em + 2px),\r\n calc(100% - 15px) calc(1em + 2px), calc(100% - 2.5em) 0.5em;\r\n background-size: 5px 5px, 5px 5px, 1px 1.5em;\r\n background-repeat: no-repeat;\r\n\r\n &:focus {\r\n background-image: linear-gradient(45deg, green 50%, transparent 50%),\r\n linear-gradient(135deg, transparent 50%, green 50%),\r\n linear-gradient(to right, #ccc, #ccc);\r\n background-position: calc(100% - 15px) 1em, calc(100% - 20px) 1em,\r\n calc(100% - 2.5em) 0.5em;\r\n background-size: 5px 5px, 5px 5px, 1px 1.5em;\r\n background-repeat: no-repeat;\r\n }\r\n\r\n &:disabled {\r\n cursor: not-allowed;\r\n background-color: #cbcbcb;\r\n }\r\n`;\r\n\r\nconst Select = ({\r\n className,\r\n field,\r\n form: { touched, errors },\r\n type,\r\n label,\r\n options,\r\n emptyOption,\r\n ...props\r\n}) => (\r\n \r\n \r\n \r\n);\r\n\r\nexport { Select };\r\n","import { toast } from \"react-toastify\";\r\n\r\nexport const errorHandler = (error, values, actions) => {\r\n if (error.response) {\r\n // Check if validation error type if not, proably just toast it\r\n console.log(error.response.data);\r\n console.log(error.response.status);\r\n console.log(error.response.headers);\r\n toast.error(error.message, {\r\n autoClose: false\r\n });\r\n } else if (error.request) {\r\n toast.error(error.message);\r\n } else {\r\n toast.error(error.message);\r\n }\r\n\r\n actions.setSubmitting(false);\r\n};\r\n","import { request } from \"modules/api\";\r\n\r\nexport const login = (username, password) =>\r\n request(\"/admin/token\", \"POST\", {\r\n body: { username, password }\r\n });\r\n\r\nexport const refreshToken = token =>\r\n request(\"/admin/token\", \"POST\", {\r\n body: { token }\r\n });\r\n","import React from \"react\";\r\nimport { toast } from \"react-toastify\";\r\nimport { FormattedMessage } from \"react-intl\";\r\nimport { translations } from \"modules/localization\";\r\nimport { refreshToken } from \"./fetch\";\r\nimport jwtDecode from \"jwt-decode\";\r\n\r\nexport const userAuthSelector = state => ({\r\n isAuthed: state.auth.token !== null,\r\n username: state.auth.token !== null ? state.auth.token.decoded.sub : null,\r\n firstName:\r\n state.auth.token !== null ? state.auth.token.decoded.firstName : null,\r\n lastName: state.auth.token !== null ? state.auth.token.decoded.lastName : null\r\n});\r\n\r\nexport const userTokenSelector = state => state.auth.token;\r\n\r\nconst setToken = (state, token) => ({\r\n ...state,\r\n token: {\r\n raw: token,\r\n decoded: jwtDecode(token)\r\n }\r\n});\r\n\r\nexport const model = {\r\n state: {\r\n token: null\r\n },\r\n reducers: {\r\n onLoginSuccess(state, token) {\r\n return setToken(state, token);\r\n },\r\n onTokenRenewed(state, token) {\r\n return setToken(state, token);\r\n },\r\n onTokenExpired(state) {\r\n return {\r\n ...state,\r\n token: null\r\n };\r\n },\r\n logout(state) {\r\n return {\r\n ...state,\r\n token: null\r\n };\r\n }\r\n },\r\n effects: dispatch => ({\r\n onLogout(payload, rootState) {\r\n dispatch.auth.logout();\r\n toast.info();\r\n },\r\n async renewToken(payload, rootState) {\r\n const tokenState = userTokenSelector(rootState);\r\n\r\n if (tokenState !== null) {\r\n try {\r\n const tokenResponse = await refreshToken(tokenState.raw);\r\n dispatch.auth.onTokenRenewed(tokenResponse.data.token);\r\n } catch (error) {\r\n dispatch.auth.onTokenExpired();\r\n }\r\n }\r\n },\r\n tokenExpired() {\r\n dispatch.auth.onTokenExpired();\r\n }\r\n })\r\n};\r\n","import React from \"react\";\r\nimport { Route, Redirect } from \"react-router-dom\";\r\nimport { connect } from \"react-redux\";\r\nimport { userAuthSelector } from \"modules/auth\";\r\n\r\nexport const PrivateRoute = ({ component: Component, auth, ...rest }) => (\r\n \r\n auth.isAuthed === true ? (\r\n \r\n ) : (\r\n \r\n )\r\n }\r\n />\r\n);\r\n\r\nexport const PrivateRouteConnected = connect(state => ({\r\n auth: userAuthSelector(state)\r\n}))(PrivateRoute);\r\n","import React from \"react\";\r\nimport _ from \"lodash\";\r\nimport PropTypes from \"prop-types\";\r\nimport { connect } from \"react-redux\";\r\nimport { userTokenSelector } from \"modules/auth\";\r\nimport moment from \"moment\";\r\n\r\nexport const isTokenExpired = expiresAt =>\r\n moment.unix(expiresAt).utc() < moment.utc();\r\n\r\nexport const getTimeUntilRenewal = timeAhead => tokenExpiresAt => {\r\n const now = moment.utc();\r\n\r\n const timeUntilExpiration = moment.unix(tokenExpiresAt).utc() - now;\r\n\r\n return timeUntilExpiration - timeAhead;\r\n};\r\n\r\nclass TokenManager extends React.Component {\r\n static propTypes = {\r\n userToken: PropTypes.object\r\n };\r\n\r\n constructor(props) {\r\n super(props);\r\n\r\n const { userToken } = props;\r\n\r\n // Schedule renewal of existing token\r\n if (userToken) {\r\n this.scheduleRenewal(userToken.decoded.exp);\r\n }\r\n }\r\n\r\n componentDidUpdate(prevProps, prevState) {\r\n // We have nothing to renew. User probably logged out.\r\n if (_.get(this.props, \"userToken\", null) === null) {\r\n // Clear any pending scheduled renewal\r\n return this.unscheduleRenewal();\r\n }\r\n\r\n // New token, schedule new renewal\r\n if (\r\n _.get(prevProps, \"userToken.raw\") !== _.get(this.props, \"userToken.raw\")\r\n ) {\r\n // Clear any previous token's scheduled renewal\r\n this.unscheduleRenewal();\r\n\r\n // Schedule renewal of new token\r\n this.scheduleRenewal(this.props.userToken.decoded.exp);\r\n }\r\n }\r\n\r\n scheduleRenewal(expiresAt) {\r\n const { renewToken } = this.props;\r\n\r\n // Start renewal 1 minute before a token expires\r\n const timeAheadOfExpiration = 60 * 1000;\r\n\r\n // Time in milliseconds until the token expires\r\n const timeUntilRenewal = getTimeUntilRenewal(timeAheadOfExpiration)(\r\n expiresAt\r\n );\r\n\r\n // Token has expired\r\n if (isTokenExpired(expiresAt)) {\r\n return this.props.tokenExpired();\r\n }\r\n\r\n // Scheduling renewal\r\n console.log(\r\n \"Scheduling token renewal at\",\r\n moment()\r\n .add(timeUntilRenewal, \"ms\")\r\n .toString()\r\n );\r\n\r\n this.renewTimeout = setTimeout(() => renewToken(), timeUntilRenewal);\r\n }\r\n\r\n unscheduleRenewal() {\r\n clearTimeout(this.renewTimeout);\r\n }\r\n\r\n render() {\r\n return null;\r\n }\r\n}\r\n\r\nTokenManager = connect(\r\n state => ({\r\n userToken: userTokenSelector(state)\r\n }),\r\n dispatch => ({\r\n renewToken: () => dispatch.auth.renewToken(),\r\n tokenExpired: () => dispatch.auth.tokenExpired()\r\n })\r\n)(TokenManager);\r\n\r\nexport { TokenManager };\r\n","import React from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport styled from \"styled-components\";\r\nimport { Link } from \"react-router-dom\";\r\nimport { Flex, Box } from \"@rebass/grid\";\r\nimport { PlainButton } from \"components/Buttons\";\r\nimport { connect } from \"react-redux\";\r\nimport { userAuthSelector } from \"modules/auth\";\r\nimport { NameBadge } from \"components/Badge\";\r\nimport { Small } from \"components/Responsive\";\r\nimport { Logo } from \"components/Logo\";\r\nimport { FormattedMessage } from \"react-intl\";\r\nimport { translations } from \"modules/localization\";\r\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\r\nimport { PageTitleContext } from \"./index\";\r\n\r\nconst Divider = styled.div`\r\n display: flex;\r\n height: 100%;\r\n width: 1px;\r\n margin: -10px 10px -10px 10px;\r\n border-right: 1px solid rgba(0, 0, 0, 0.9);\r\n`;\r\n\r\nconst PageTitle = styled.h2`\r\n color: #fff;\r\n font-weight: 500;\r\n`;\r\n\r\nconst Username = styled.span`\r\n font-size: 17px;\r\n`;\r\n\r\nconst HeaderWrapper = styled.div`\r\n background-color: ${(props) => props.theme.colors.primaryDarker};\r\n color: #fff;\r\n padding: 10px 20px;\r\n box-shadow: 0 0 12px rgba(0, 0, 0, 0.5);\r\n`;\r\n\r\nconst PrintFriendlyContactInfo = styled(Flex)`\r\n @media print {\r\n display: none;\r\n }\r\n`;\r\n\r\nclass Header extends React.Component {\r\n static propTypes = {\r\n isAuthed: PropTypes.bool.isRequired,\r\n firstName: PropTypes.string,\r\n lastName: PropTypes.string,\r\n onLogout: PropTypes.func.isRequired,\r\n };\r\n\r\n render() {\r\n const { isAuthed, firstName, lastName, onLogout } = this.props;\r\n\r\n return (\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n {(data) => {data.title}}\r\n \r\n \r\n\r\n \r\n \r\n {isAuthed && (\r\n \r\n {\" \"}\r\n \r\n {firstName} {lastName}\r\n {\" \"}\r\n \r\n \r\n {\" \"}\r\n \r\n \r\n \r\n )}\r\n \r\n \r\n \r\n \r\n );\r\n }\r\n}\r\n\r\nHeader = connect(\r\n (state) => ({\r\n isAuthed: userAuthSelector(state).isAuthed,\r\n firstName: userAuthSelector(state).firstName,\r\n lastName: userAuthSelector(state).lastName,\r\n }),\r\n (dispatch) => ({\r\n onLogout: () => dispatch.auth.onLogout(),\r\n })\r\n)(Header);\r\n\r\nexport { Header };\r\n","import { defineMessages } from \"react-intl\";\r\n\r\nexport default defineMessages({\r\n applications: {\r\n id: \"app.AdministrationLayout.nav.applications\",\r\n defaultMessage: \"Applications\"\r\n },\r\n collaborationPrograms: {\r\n id: \"app.AdministrationLayout.nav.collaborationPrograms\",\r\n defaultMessage: \"Collaboration programs\"\r\n },\r\n messageTemplates: {\r\n id: \"app.AdministrationLayout.nav.messageTemplates\",\r\n defaultMessage: \"Message templates\"\r\n },\r\n settings: {\r\n id: \"app.AdministrationLayout.nav.settings\",\r\n defaultMessage: \"Settings\"\r\n },\r\n budgetOverview: {\r\n id: \"app.AdministrationLayout.nav.budgetOverview\",\r\n defaultMessage: \"Budget overview\"\r\n },\r\n users: {\r\n id: \"app.AdministrationLayout.nav.users\",\r\n defaultMessage: \"Users\"\r\n }\r\n});\r\n","import styled from \"styled-components\";\r\nimport Drawer from \"react-motion-drawer\";\r\n\r\nexport const PageWrapper = styled.div`\r\n width: 100%;\r\n`;\r\n\r\nexport const SidebarToggler = styled.button`\r\n position: absolute;\r\n top: 10px;\r\n left: 10px;\r\n background: 0;\r\n border: 0;\r\n font-size: 28px;\r\n cursor: pointer;\r\n color: #fff;\r\n`;\r\n\r\nexport const Sidebar = styled.div`\r\n background-color: ${props => props.theme.colors.primaryLighter};\r\n height: 100%;\r\n`;\r\n\r\nexport const StyledMotionDrawer = styled(Drawer)`\r\n color: #333;\r\n background-color: ${props => props.theme.colors.primaryLighter};\r\n`;\r\n\r\nexport const NavigationList = styled.ul`\r\n margin: 0;\r\n padding: 0;\r\n list-style: none;\r\n`;\r\n\r\nexport const NavigationItem = styled.li`\r\n a {\r\n display: block;\r\n text-decoration: none;\r\n font-size: 16px;\r\n padding: 20px;\r\n color: #333;\r\n\r\n &:hover,\r\n &.active {\r\n background-color: ${props => props.theme.colors.primaryDarker};\r\n color: #fff;\r\n }\r\n }\r\n`;\r\n","import React from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { Route, Switch, NavLink, Redirect } from \"react-router-dom\";\r\nimport { PrivateRoute } from \"modules/auth\";\r\nimport { Loadable } from \"lib/Loadable\";\r\nimport { Logo } from \"components/Logo\";\r\nimport { Header } from \"./Header\";\r\nimport { Flex, Box } from \"@rebass/grid\";\r\nimport { Small, Desktop } from \"components/Responsive\";\r\nimport { FormattedMessage } from \"react-intl\";\r\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\r\nimport messages from \"./messages\";\r\nimport {\r\n NavigationItem,\r\n NavigationList,\r\n Sidebar,\r\n PageWrapper,\r\n StyledMotionDrawer,\r\n SidebarToggler,\r\n} from \"./elements\";\r\n\r\nimport ErrorBoundary from \"react-error-boundary\";\r\nimport ErrorBoundaryFallback from \"components/ErrorBoundaryFallback\";\r\n\r\nexport const PageTitleContext = React.createContext({\r\n pageTitle: null,\r\n setPageTitle: () => null,\r\n});\r\n\r\nconst AsyncApplicationsOverview = Loadable({\r\n loader: () => import(\"routes/Admin/ApplicationsOverview\"),\r\n});\r\n\r\nconst AsyncApplicationDetails = Loadable({\r\n loader: () => import(\"routes/Admin/ApplicationDetails\"),\r\n});\r\n\r\nconst AsyncCollaborationPrograms = Loadable({\r\n loader: () => import(\"routes/Admin/CollaborationPrograms\"),\r\n});\r\n\r\nconst AsyncCollaborationProgramDetails = Loadable({\r\n loader: () => import(\"routes/Admin/CollaborationProgramDetails\"),\r\n});\r\n\r\nconst AsynMessageTemplates = Loadable({\r\n loader: () => import(\"routes/Admin/MessageTemplates\"),\r\n});\r\n\r\nconst AsynSettingsPage = Loadable({\r\n loader: () => import(\"routes/Admin/Settings\"),\r\n});\r\n\r\nconst AsyncBudgetOverviewPage = Loadable({\r\n loader: () => import(\"routes/Admin/BudgetOverview\"),\r\n});\r\n\r\nconst AsyncUsersOverviewPage = Loadable({\r\n loader: () => import(\"routes/Admin/UsersOverview\"),\r\n});\r\n\r\nclass AdministrationLayout extends React.Component {\r\n static propTypes = {\r\n children: PropTypes.any,\r\n };\r\n\r\n constructor(props) {\r\n super(props);\r\n\r\n this.state = {\r\n drawerIsOpen: false,\r\n pageTitle: {\r\n title: null,\r\n setPageTitle: this.setPageTitle,\r\n },\r\n };\r\n }\r\n\r\n setPageTitle = (title) =>\r\n this.setState({\r\n pageTitle: { title: title, setPageTitle: this.setPageTitle },\r\n });\r\n\r\n onSetOpen = (isOpen) => this.setState({ drawerIsOpen: isOpen });\r\n closeDrawer = () => this.onSetOpen(false);\r\n\r\n renderNavItems() {\r\n return (\r\n \r\n \r\n \r\n {\" \"}\r\n \r\n \r\n \r\n\r\n \r\n \r\n {\" \"}\r\n \r\n \r\n \r\n\r\n \r\n \r\n {\" \"}\r\n \r\n \r\n \r\n\r\n \r\n \r\n {\" \"}\r\n \r\n \r\n \r\n\r\n \r\n \r\n {\" \"}\r\n \r\n \r\n \r\n \r\n \r\n {\" \"}\r\n \r\n \r\n \r\n \r\n );\r\n }\r\n\r\n renderMain() {\r\n return (\r\n
    \r\n \r\n \r\n {/* Applications */}\r\n \r\n\r\n \r\n\r\n \r\n\r\n {/* Collaboration programs */}\r\n \r\n \r\n\r\n \r\n\r\n \r\n \r\n\r\n {/* Default route when nothing matches */}\r\n }\r\n />\r\n \r\n \r\n
    \r\n );\r\n }\r\n\r\n render() {\r\n return (\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n
    \r\n
    \r\n \r\n this.onSetOpen(true)}>\r\n \r\n \r\n \r\n
    \r\n {this.renderMain()}\r\n \r\n\r\n \r\n \r\n \r\n
    \r\n \r\n
    \r\n\r\n \r\n
    \r\n
    \r\n
    \r\n \r\n \r\n \r\n );\r\n }\r\n}\r\n\r\nexport { AdministrationLayout };\r\n","import React, { Component } from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { Fetch } from \"react-request\";\r\nimport qs from \"qs\";\r\nimport _ from \"lodash\";\r\nimport { toast } from \"react-toastify\";\r\nimport { getApiRoot } from \"config.js\";\r\nimport { configureStore } from \"store\";\r\nimport { userTokenSelector } from \"modules/auth\";\r\n\r\nconst apiVersion = \"1.0\";\r\n\r\n// Wrapper for react-request's Fetch in order to easily use with Vigilo API\r\nclass VigiloFetch extends Component {\r\n static propTypes = {\r\n skipAuth: PropTypes.bool,\r\n // If true then it won't show errors in toaster notification\r\n suppressError: PropTypes.bool,\r\n url: PropTypes.string,\r\n headers: PropTypes.object,\r\n onError: PropTypes.func,\r\n query: PropTypes.object,\r\n };\r\n\r\n static defaultProps = {\r\n skipAuth: false,\r\n suppressError: false,\r\n headers: {},\r\n query: {},\r\n };\r\n\r\n render() {\r\n const {\r\n skipAuth,\r\n url,\r\n beforeFetch,\r\n afterFetch,\r\n onError,\r\n query,\r\n headers,\r\n suppressError,\r\n ...props\r\n } = this.props;\r\n\r\n const finalHeaders = {\r\n \"Content-Type\": \"application/json\",\r\n \"Cache-control\": \"no-cache\",\r\n Pragma: \"no-cache\",\r\n Expires: 0,\r\n ...headers,\r\n };\r\n\r\n const queries = qs.stringify({\r\n ...query,\r\n \"api-version\": apiVersion,\r\n });\r\n\r\n const finalBeforeFetch = (options) => {\r\n const {\r\n init: { body },\r\n } = options;\r\n\r\n if (finalHeaders[\"Content-Type\"] === \"application/json\" && body) {\r\n // eslint-disable-next-line\r\n options.init.body = JSON.stringify(body);\r\n }\r\n\r\n // Add Authorization header\r\n if (skipAuth === false) {\r\n const store = configureStore();\r\n const tokenState = userTokenSelector(store.getState());\r\n\r\n if (tokenState !== null) {\r\n options.init.headers = {\r\n ...options.init.headers,\r\n Authorization: `Bearer ${tokenState.raw}`,\r\n };\r\n }\r\n }\r\n\r\n if (beforeFetch) {\r\n beforeFetch(options);\r\n }\r\n };\r\n\r\n const finalAfterFetch = (options) => {\r\n if (afterFetch) {\r\n afterFetch(options);\r\n }\r\n\r\n if (options.failed) {\r\n if (_.isFunction(onError)) {\r\n onError(options);\r\n } else if (suppressError === false) {\r\n if (\r\n options.error &&\r\n options.error.name &&\r\n options.error.name === \"AbortError\"\r\n ) {\r\n console.log(\"Request aborted\");\r\n } else {\r\n const response = options.response;\r\n console.log(response);\r\n let message = _.get(response, \"data.Message\", null);\r\n\r\n const validationErrors = _.get(response, \"data.validationErrors\");\r\n\r\n if (Array.isArray(validationErrors)) {\r\n message += validationErrors.map((x) => x.message).join(\". \");\r\n }\r\n\r\n if (!message) {\r\n message = `${_.get(\r\n response,\r\n \"statusText\",\r\n _.get(options, \"error.message\")\r\n )}: ${options.url}`;\r\n }\r\n\r\n toast.error(message);\r\n }\r\n }\r\n }\r\n };\r\n\r\n const urlWithApiroot = `${getApiRoot()}${url}?${queries}`;\r\n\r\n return (\r\n \r\n );\r\n }\r\n}\r\n\r\nexport { VigiloFetch as Fetch };\r\n","import axios from \"axios\";\r\nimport { getApiRoot } from \"config.js\";\r\nimport { configureStore } from \"store\";\r\nimport { userTokenSelector } from \"modules/auth\";\r\n\r\nconst defaultOptions = {\r\n skipAuth: false\r\n};\r\n\r\nexport function request(endpoint, verb, options = {}) {\r\n let headers = {\r\n Accept: \"application/json\",\r\n \"Content-Type\": \"application/json\"\r\n };\r\n\r\n if (options.headers) {\r\n headers = Object.assign({}, headers, options.headers);\r\n }\r\n\r\n options = { ...defaultOptions, ...options }; // eslint-disable-line no-param-reassign\r\n\r\n if (options.skipAuth === false) {\r\n const store = configureStore();\r\n const tokenState = userTokenSelector(store.getState());\r\n\r\n if (tokenState !== null) {\r\n headers[\"Authorization\"] = `Bearer ${tokenState.raw}`;\r\n }\r\n }\r\n\r\n let callURL = getApiRoot() + endpoint + \"?api-version=1.0\";\r\n if (options.query) {\r\n callURL = `${callURL}&${options.query}`;\r\n }\r\n\r\n const requestConfig = {\r\n method: verb,\r\n url: callURL,\r\n data: options.body ? options.body : undefined,\r\n headers,\r\n responseType: options.responseType ? options.responseType : undefined\r\n };\r\n\r\n return axios(requestConfig);\r\n}\r\n","import { defineMessages } from \"react-intl\";\r\n\r\nexport default defineMessages({\r\n heading: {\r\n id: \"app.components.ErrorBoundaryFallback.heading\",\r\n defaultMessage: \"Something went wrong :(\"\r\n },\r\n errorInstruction: {\r\n id: \"app.components.ErrorBoundaryFallback.errorInstruction\",\r\n defaultMessage: \"Details below can be helpful when you contact support.\"\r\n }\r\n});\r\n","import React from \"react\";\r\nimport { Header } from \"semantic-ui-react\";\r\nimport { PageTitleContext } from \"layouts/AdministrationLayout\";\r\n\r\nexport const PageTitle = props =>
    ;\r\nexport { Header };\r\n\r\nclass AdminPageTitle extends React.Component {\r\n componentDidMount() {\r\n this.props.setPageTitle(this.props.children);\r\n }\r\n\r\n render() {\r\n return null;\r\n }\r\n}\r\n\r\nconst AdminPageTitleWrapper = props => (\r\n \r\n {data => }\r\n \r\n);\r\n\r\nexport { AdminPageTitleWrapper as AdminPageTitle };\r\n","export { Loader } from 'semantic-ui-react'\r\n","import React from \"react\";\r\nimport styled from \"styled-components\";\r\nimport initials from \"initials\";\r\nimport { space } from \"styled-system\";\r\n\r\nconst Badge = styled.div`\r\n border-radius: 100%;\r\n width: ${props => props.size}px;\r\n height: ${props => props.size}px;\r\n font-size: ${props => Math.floor(props.size / 3)}px;\r\n font-family: Helvetica, Arial, sans-serif;\r\n text-transform: uppercase;\r\n text-align: center;\r\n line-height: ${props => props.size}px;\r\n display: inline-block;\r\n background-color: #ebf5f7;\r\n color: #333;\r\n ${space};\r\n`;\r\n\r\nexport const NameBadge = ({ name, icon, ...props }) => (\r\n \r\n {name && initials(name)}\r\n {icon && icon}\r\n \r\n);\r\n","module.exports = __webpack_public_path__ + \"static/media/HK_RGB_ligg_payoff.7ce9a945.png\";","import React from \"react\";\r\nimport { Loader } from \"components/Loader\";\r\nimport loadable from \"@loadable/component\";\r\nimport pMinDelay from \"p-min-delay\";\r\n\r\n// Lazy load components\r\n// Loadable({ loader: () => import(\"./SomeComponent\" )})\r\nexport const Loadable = ({ loader }) =>\r\n loadable(() => pMinDelay(loader(), 300), { fallBack: });\r\n","import { defineMessages } from \"react-intl\";\r\n\r\nexport default defineMessages({\r\n saved: {\r\n id: \"app.localization.actions.saved\",\r\n defaultMessage: \"Saved\"\r\n },\r\n save: {\r\n id: \"app.localization.actions.save\",\r\n defaultMessage: \"Save\"\r\n },\r\n send: {\r\n id: \"app.localization.actions.send\",\r\n defaultMessage: \"Send\"\r\n },\r\n sent: {\r\n id: \"app.localization.actions.sent\",\r\n defaultMessage: \"Sent\"\r\n },\r\n submit: {\r\n id: \"app.localization.actions.submit\",\r\n defaultMessage: \"Submit\"\r\n },\r\n delete: {\r\n id: \"app.localization.actions.delete\",\r\n defaultMessage: \"Delete\"\r\n },\r\n filter: {\r\n id: \"app.localization.actions.filter\",\r\n defaultMessage: \"Filter\"\r\n },\r\n login: {\r\n id: \"app.localization.actions.login\",\r\n defaultMessage: \"Login\"\r\n },\r\n logout: {\r\n id: \"app.localization.actions.logout\",\r\n defaultMessage: \"Logut\"\r\n },\r\n loggedOut: {\r\n id: \"app.localization.actions.loggedOut\",\r\n defaultMessage: \"Logged out\"\r\n },\r\n cancel: {\r\n id: \"app.localization.actions.cancel\",\r\n defaultMessage: \"Cancel\"\r\n }\r\n});\r\n","import { defineMessages } from \"react-intl\";\r\n\r\nexport default defineMessages({\r\n attachments: {\r\n id: \"app.localization.form.attachments\",\r\n defaultMessage: \"Attachments\"\r\n },\r\n maxSize: {\r\n id: \"app.localization.form.maxSize\",\r\n defaultMessage: \"Max {maxSize}\"\r\n }\r\n});\r\n","import { addLocaleData } from \"react-intl\";\r\nimport enLocaleData from \"react-intl/locale-data/en\";\r\nimport nbLocaleData from \"react-intl/locale-data/nb\";\r\nimport * as translations from \"./translations\";\r\n\r\nimport enTranslationMessages from \"../../translations/en.json\";\r\nimport nbTranslationMessages from \"../../translations/nb.json\";\r\n\r\naddLocaleData(enLocaleData);\r\naddLocaleData(nbLocaleData);\r\n\r\nexport const DEFAULT_LOCALE = \"en\";\r\n\r\nexport const appLocales = [\"en\", \"nb\"];\r\n\r\nexport const formatTranslationMessages = (locale, messages) => {\r\n const defaultFormattedMessages =\r\n locale !== DEFAULT_LOCALE\r\n ? formatTranslationMessages(DEFAULT_LOCALE, enTranslationMessages)\r\n : {};\r\n\r\n return Object.keys(messages).reduce((formattedMessages, key) => {\r\n const formattedMessage =\r\n !messages[key] && locale !== DEFAULT_LOCALE\r\n ? defaultFormattedMessages[key]\r\n : messages[key];\r\n return Object.assign(formattedMessages, { [key]: formattedMessage });\r\n }, {});\r\n};\r\n\r\nexport const translationMessages = {\r\n en: formatTranslationMessages(\"en\", enTranslationMessages),\r\n nb: formatTranslationMessages(\"nb\", nbTranslationMessages)\r\n};\r\n\r\nexport { translations };\r\n","import React from \"react\";\r\nimport logo from \"./HK_RGB_ligg_payoff.png\";\r\n\r\nexport const Logo = (props) => (\r\n \"Haugaland\r\n);\r\n","import React from \"react\";\r\nimport Responsive from \"react-responsive\";\r\n\r\nexport const Desktop = props => ;\r\nexport const Tablet = props => (\r\n \r\n);\r\nexport const Small = props => ;\r\nexport const Mobile = props => ;\r\nexport const Default = props => ;\r\n","/*\r\n Add needed font awesome icons here.\r\n*/\r\nimport fontawesome from \"@fortawesome/fontawesome\";\r\n\r\nimport {\r\n faPaste,\r\n faBars,\r\n faPaperclip,\r\n faSignOutAlt,\r\n faUsers,\r\n faMinusCircle,\r\n faTimesCircle,\r\n} from \"@fortawesome/free-solid-svg-icons\";\r\n\r\nimport { faEdit } from \"@fortawesome/free-regular-svg-icons\";\r\nimport { faChartBar } from \"@fortawesome/free-regular-svg-icons\";\r\nimport { faEnvelope } from \"@fortawesome/free-regular-svg-icons\";\r\nimport { faFileAlt } from \"@fortawesome/free-regular-svg-icons\";\r\nimport { faClipboard } from \"@fortawesome/free-regular-svg-icons\";\r\n\r\nfontawesome.library.add(\r\n faMinusCircle,\r\n faTimesCircle,\r\n faPaste,\r\n faEdit,\r\n faBars,\r\n faPaperclip,\r\n faChartBar,\r\n faEnvelope,\r\n faFileAlt,\r\n faChartBar,\r\n faClipboard,\r\n faSignOutAlt,\r\n faUsers\r\n);\r\n","import React from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport styled from \"styled-components\";\r\nimport { Link } from \"react-router-dom\";\r\nimport { Flex, Box } from \"@rebass/grid\";\r\nimport { Button } from \"components/Buttons\";\r\nimport { connect } from \"react-redux\";\r\nimport { userAuthSelector } from \"modules/auth\";\r\nimport { Small, Desktop } from \"components/Responsive\";\r\nimport { Logo } from \"components/Logo\";\r\nimport { FormattedMessage } from \"react-intl\";\r\nimport { translations } from \"modules/localization\";\r\nimport { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\r\n\r\nconst Username = styled.span`\r\n font-size: 17px;\r\n color: #555;\r\n`;\r\n\r\nconst PrintFriendlyContactInfo = styled(Flex)`\r\n @media print {\r\n display: none;\r\n }\r\n`;\r\n\r\nclass Header extends React.Component {\r\n static propTypes = {\r\n isAuthed: PropTypes.bool.isRequired,\r\n firstName: PropTypes.string,\r\n lastName: PropTypes.string,\r\n onLogout: PropTypes.func.isRequired,\r\n };\r\n\r\n render() {\r\n const { isAuthed, firstName, lastName, onLogout } = this.props;\r\n\r\n return (\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n {isAuthed && (\r\n \r\n \r\n {firstName} {lastName}\r\n {\" \"}\r\n \r\n \r\n )}\r\n \r\n \r\n \r\n \r\n );\r\n }\r\n}\r\n\r\nHeader = connect(\r\n (state) => ({\r\n isAuthed: userAuthSelector(state).isAuthed,\r\n firstName: userAuthSelector(state).firstName,\r\n lastName: userAuthSelector(state).lastName,\r\n }),\r\n (dispatch) => ({\r\n onLogout: () => dispatch.auth.onLogout(),\r\n })\r\n)(Header);\r\n\r\nexport { Header };\r\n","import React from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport styled from \"styled-components\";\r\nimport { Route, Switch } from \"react-router-dom\";\r\nimport { Loadable } from \"lib/Loadable\";\r\nimport media from \"styled-media-query\";\r\nimport ErrorBoundary from \"react-error-boundary\";\r\nimport ErrorBoundaryFallback from \"components/ErrorBoundaryFallback\";\r\nimport { Header } from \"../Header\";\r\n\r\nconst AsyncLandingpage = Loadable({\r\n loader: () => import(\"routes/Applicant/LandingPage\")\r\n});\r\n\r\nconst AsyncSubmitApplicationPage = Loadable({\r\n loader: () => import(\"routes/Applicant/SubmitApplication\")\r\n});\r\n\r\nconst FeedbackPage = Loadable({\r\n loader: () => import(\"routes/Applicant/Feedback\")\r\n});\r\n\r\nconst PageWrapper = styled.div`\r\n width: 100%;\r\n padding: 20px;\r\n\r\n ${media.greaterThan(\"large\")`\r\n width: 960px;\r\n margin: 20px auto;\r\n padding: 0px;\r\n `};\r\n`;\r\n\r\nclass PublicLayout extends React.Component {\r\n static propTypes = {\r\n children: PropTypes.any\r\n };\r\n\r\n render() {\r\n return (\r\n \r\n
    \r\n
    \r\n
    \r\n
    \r\n \r\n \r\n \r\n\r\n \r\n\r\n \r\n \r\n \r\n
    \r\n \r\n );\r\n }\r\n}\r\n\r\nexport { PublicLayout };\r\n","import { defineMessages } from \"react-intl\";\r\n\r\nexport default defineMessages({\r\n loginLabel: {\r\n id: \"app.route.Login.LoginForm.loginLabel\",\r\n defaultMessage: \"Login\"\r\n },\r\n usernameLabel: {\r\n id: \"app.route.Login.LoginForm.usernameLabel\",\r\n defaultMessage: \"Username\"\r\n },\r\n passwordLabel: {\r\n id: \"app.route.Login.LoginForm.passwordLabel\",\r\n defaultMessage: \"Password\"\r\n },\r\n invalidLoginMessage: {\r\n id: \"app.route.Login.invalidLoginMessage\",\r\n defaultMessage: \"Wrong username and/or password\"\r\n }\r\n});\r\n","import React from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { Formik, Form, Field } from \"formik\";\r\nimport { TextInput, errorHandler } from \"lib/forms\";\r\nimport * as Yup from \"yup\";\r\nimport { Button } from \"components/Buttons\";\r\nimport { injectIntl, intlShape } from \"react-intl\";\r\nimport { login } from \"modules/auth\";\r\nimport messages from \"./messages\";\r\n\r\nconst LoginForm = injectIntl(\r\n ({ intl: { formatMessage }, setToken, onLoginSuccess, ...props }) => (\r\n \r\n Yup.object().shape({\r\n username: Yup.string()\r\n .label(formatMessage(messages.usernameLabel))\r\n .required(),\r\n password: Yup.string()\r\n .label(formatMessage(messages.passwordLabel))\r\n .required()\r\n })\r\n }\r\n onSubmit={(values, actions) => {\r\n actions.setSubmitting(true);\r\n\r\n login(values.username, values.password)\r\n .then(response => {\r\n actions.setSubmitting(false);\r\n\r\n setToken(response.data.token);\r\n onLoginSuccess();\r\n })\r\n .catch(error => {\r\n if (error.response && error.response.status === 401) {\r\n actions.setErrors({\r\n password: formatMessage(messages.invalidLoginMessage)\r\n });\r\n } else {\r\n errorHandler(error, values, actions);\r\n }\r\n actions.setSubmitting(false);\r\n });\r\n }}\r\n render={({ values, isSubmitting }) => (\r\n
    \r\n \r\n \r\n\r\n
    \r\n \r\n {formatMessage(messages.loginLabel)}\r\n \r\n
    \r\n \r\n )}\r\n {...props}\r\n />\r\n )\r\n);\r\n\r\nLoginForm.propTypes = {\r\n intl: intlShape,\r\n onLoginSuccess: PropTypes.func.isRequired\r\n};\r\n\r\nexport { LoginForm };\r\n","import { defineMessages } from \"react-intl\";\r\n\r\nexport default defineMessages({\r\n pageTitle: {\r\n id: \"app.route.Login.pageTitle\",\r\n defaultMessage: \"Login\"\r\n }\r\n});\r\n","import React from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { LoginForm } from \"./components/LoginForm\";\r\nimport { FormattedMessage } from \"react-intl\";\r\nimport { PageTitle } from \"components/Typography/Headings\";\r\nimport { connect } from \"react-redux\";\r\nimport { Redirect } from \"react-router-dom\";\r\nimport { userAuthSelector } from \"modules/auth\";\r\nimport messages from \"./messages\";\r\n\r\nclass LoginPage extends React.Component {\r\n static propTypes = {\r\n isAuthed: PropTypes.bool.isRequired\r\n };\r\n\r\n render() {\r\n const { onLoginSuccess, isAuthed } = this.props;\r\n\r\n return (\r\n \r\n \r\n \r\n \r\n\r\n {!isAuthed && (\r\n this.props.history.push(\"/admin\")}\r\n />\r\n )}\r\n\r\n {isAuthed && }\r\n \r\n );\r\n }\r\n}\r\n\r\nexport default connect(\r\n state => ({\r\n isAuthed: userAuthSelector(state).isAuthed\r\n }),\r\n dispatch => ({\r\n onLoginSuccess: token => dispatch.auth.onLoginSuccess(token)\r\n })\r\n)(LoginPage);\r\n","import React from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport styled from \"styled-components\";\r\nimport { Route, Switch } from \"react-router-dom\";\r\nimport { Link } from \"react-router-dom\";\r\nimport media from \"styled-media-query\";\r\nimport { Logo } from \"components/Logo\";\r\nimport LoginPage from \"routes/Admin/Login\";\r\n\r\nconst Header = styled.header`\r\n text-align: center;\r\n margin-bottom: 50px;\r\n`;\r\n\r\nconst PageWrapper = styled.div`\r\n width: 100%;\r\n padding: 20px;\r\n\r\n ${media.greaterThan(\"large\")`\r\n width: 360px;\r\n margin: 20px auto;\r\n padding: 0px;\r\n `};\r\n`;\r\n\r\nclass LoginLayout extends React.Component {\r\n static propTypes = {\r\n children: PropTypes.any,\r\n };\r\n\r\n render() {\r\n return (\r\n \r\n
    \r\n \r\n \r\n \r\n
    \r\n
    \r\n \r\n \r\n \r\n
    \r\n
    \r\n );\r\n }\r\n}\r\n\r\nexport { LoginLayout };\r\n","import React, { Component } from \"react\";\r\nimport { BrowserRouter as Router, Route, Switch } from \"react-router-dom\";\r\nimport { createGlobalStyle } from \"styled-components\";\r\nimport { ToastContainer } from \"react-toastify\";\r\nimport _ from \"lodash\";\r\n\r\n// Third party CSS\r\nimport \"normalize.css/normalize.css\";\r\nimport \"react-table/react-table.css\";\r\nimport \"react-toastify/dist/ReactToastify.css\";\r\nimport \"react-day-picker/lib/style.css\";\r\nimport \"semantic-ui-css/semantic.min.css\";\r\n\r\nimport \"./icons\";\r\nimport { TokenManager } from \"modules/auth\";\r\nimport { PublicLayout } from \"./layouts/PublicLayout\";\r\nimport { AdministrationLayout } from \"./layouts/AdministrationLayout\";\r\nimport { LoginLayout } from \"./layouts/LoginLayout\";\r\n\r\n_.mixin({ pascalCase: _.flow(_.camelCase, _.upperFirst) });\r\n\r\nconst GlobalStyle = createGlobalStyle`\r\n * {\r\n box-sizing: border-box;\r\n }\r\n\r\n body {\r\n font-family: \"Lucida Grande\", \"PT Sans\", sans-serif;\r\n min-height: 100vh;\r\n display: flex;\r\n flex-direction: column;\r\n }\r\n\r\n #root {\r\n display: flex;\r\n flex-direction: column;\r\n flex: 1;\r\n }\r\n\r\n @media print {\r\n button {\r\n display: none;\r\n }\r\n }\r\n`;\r\n\r\nclass App extends Component {\r\n render() {\r\n return (\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n\r\n \r\n \r\n \r\n \r\n );\r\n }\r\n}\r\n\r\nexport default App;\r\n","// This optional code is used to register a service worker.\r\n// register() is not called by default.\r\n\r\n// This lets the app load faster on subsequent visits in production, and gives\r\n// it offline capabilities. However, it also means that developers (and users)\r\n// will only see deployed updates on subsequent visits to a page, after all the\r\n// existing tabs open on the page have been closed, since previously cached\r\n// resources are updated in the background.\r\n\r\n// To learn more about the benefits of this model and instructions on how to\r\n// opt-in, read https://bit.ly/CRA-PWA\r\n\r\nconst isLocalhost = Boolean(\r\n window.location.hostname === \"localhost\" ||\r\n // [::1] is the IPv6 localhost address.\r\n window.location.hostname === \"[::1]\" ||\r\n // 127.0.0.0/8 are considered localhost for IPv4.\r\n window.location.hostname.match(\r\n /^127(?:\\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}$/\r\n )\r\n);\r\n\r\nexport function register(config) {\r\n if (process.env.NODE_ENV === \"production\" && \"serviceWorker\" in navigator) {\r\n // The URL constructor is available in all browsers that support SW.\r\n const publicUrl = new URL(process.env.PUBLIC_URL, window.location.href);\r\n if (publicUrl.origin !== window.location.origin) {\r\n // Our service worker won't work if PUBLIC_URL is on a different origin\r\n // from what our page is served on. This might happen if a CDN is used to\r\n // serve assets; see https://github.com/facebook/create-react-app/issues/2374\r\n return;\r\n }\r\n\r\n window.addEventListener(\"load\", () => {\r\n const swUrl = `${process.env.PUBLIC_URL}/service-worker.js`;\r\n\r\n if (isLocalhost) {\r\n // This is running on localhost. Let's check if a service worker still exists or not.\r\n checkValidServiceWorker(swUrl, config);\r\n\r\n // Add some additional logging to localhost, pointing developers to the\r\n // service worker/PWA documentation.\r\n navigator.serviceWorker.ready.then(() => {\r\n console.log(\r\n \"This web app is being served cache-first by a service \" +\r\n \"worker. To learn more, visit https://bit.ly/CRA-PWA\"\r\n );\r\n });\r\n } else {\r\n // Is not localhost. Just register service worker\r\n registerValidSW(swUrl, config);\r\n }\r\n });\r\n }\r\n}\r\n\r\nfunction registerValidSW(swUrl, config) {\r\n navigator.serviceWorker\r\n .register(swUrl)\r\n .then((registration) => {\r\n registration.onupdatefound = () => {\r\n const installingWorker = registration.installing;\r\n if (installingWorker == null) {\r\n return;\r\n }\r\n installingWorker.onstatechange = () => {\r\n if (installingWorker.state === \"installed\") {\r\n if (navigator.serviceWorker.controller) {\r\n // At this point, the updated precached content has been fetched,\r\n // but the previous service worker will still serve the older\r\n // content until all client tabs are closed.\r\n console.log(\r\n \"New content is available and will be used when all \" +\r\n \"tabs for this page are closed. See https://bit.ly/CRA-PWA.\"\r\n );\r\n\r\n // Execute callback\r\n if (config && config.onUpdate) {\r\n config.onUpdate(registration);\r\n }\r\n } else {\r\n // At this point, everything has been precached.\r\n // It's the perfect time to display a\r\n // \"Content is cached for offline use.\" message.\r\n console.log(\"Content is cached for offline use.\");\r\n\r\n // Execute callback\r\n if (config && config.onSuccess) {\r\n config.onSuccess(registration);\r\n }\r\n }\r\n }\r\n };\r\n };\r\n })\r\n .catch((error) => {\r\n console.error(\"Error during service worker registration:\", error);\r\n });\r\n}\r\n\r\nfunction checkValidServiceWorker(swUrl, config) {\r\n // Check if the service worker can be found. If it can't reload the page.\r\n fetch(swUrl, {\r\n headers: { \"Service-Worker\": \"script\" },\r\n })\r\n .then((response) => {\r\n // Ensure service worker exists, and that we really are getting a JS file.\r\n const contentType = response.headers.get(\"content-type\");\r\n if (\r\n response.status === 404 ||\r\n (contentType != null && contentType.indexOf(\"javascript\") === -1)\r\n ) {\r\n // No service worker found. Probably a different app. Reload the page.\r\n navigator.serviceWorker.ready.then((registration) => {\r\n registration.unregister().then(() => {\r\n window.location.reload();\r\n });\r\n });\r\n } else {\r\n // Service worker found. Proceed as normal.\r\n registerValidSW(swUrl, config);\r\n }\r\n })\r\n .catch(() => {\r\n console.log(\r\n \"No internet connection found. App is running in offline mode.\"\r\n );\r\n });\r\n}\r\n\r\nexport function unregister() {\r\n if (\"serviceWorker\" in navigator) {\r\n navigator.serviceWorker.ready\r\n .then((registration) => {\r\n registration.unregister();\r\n })\r\n .catch((error) => {\r\n console.error(error.message);\r\n });\r\n }\r\n}\r\n","import React from \"react\";\r\nimport PropTypes from \"prop-types\";\r\nimport { IntlProvider } from \"react-intl\";\r\nimport { setLocale } from \"yup\";\r\nimport moment from \"moment\";\r\nimport \"moment/locale/nb\";\r\n\r\nexport class LanguageProvider extends React.PureComponent {\r\n setYupLocale() {\r\n setLocale({\r\n mixed: {\r\n // eslint-disable-next-line\r\n required: \"${path} er påkrevd\"\r\n },\r\n number: {\r\n /* eslint-disable */\r\n min: \"${path} må være større enn eller lik ${min}\",\r\n max: \"${path} må være mindre enn eller lik ${max}\",\r\n less: \"${path} må være mindre enn ${less}\",\r\n more: \"${path} må være større enn ${more}\",\r\n notEqual: \"${path} kan ikke være lik ${notEqual}\",\r\n positive: \"${path} må være et positivt tall\",\r\n negative: \"${path} må være et negativt tall\",\r\n integer: \"${path} må være et heltall\"\r\n },\r\n string: {\r\n // eslint-disable-next-line\r\n email: \"${path} må være en gyldig e-postadresse\",\r\n min: \"${path} må minst ha ${min} tegn\",\r\n max: \"${path} kan maks ha ${max} tegn\",\r\n length: \"${path} må ha ${length} tegn\"\r\n }\r\n });\r\n }\r\n\r\n componentDidMount() {\r\n this.setYupLocale();\r\n moment.locale(\"nb\");\r\n }\r\n\r\n render() {\r\n return (\r\n \r\n {React.Children.only(this.props.children)}\r\n \r\n );\r\n }\r\n}\r\n\r\nLanguageProvider.propTypes = {\r\n locale: PropTypes.string,\r\n messages: PropTypes.object,\r\n children: PropTypes.element.isRequired\r\n};\r\n\r\nexport default LanguageProvider;\r\n","import \"./polyfill\";\r\nimport React from \"react\";\r\nimport ReactDOM from \"react-dom\";\r\nimport App from \"./App\";\r\nimport * as serviceWorker from \"./serviceWorker\";\r\nimport { translationMessages } from \"modules/localization\";\r\nimport LanguageProvider from \"modules/localization/LanguageProvider\";\r\nimport { Provider } from \"react-redux\";\r\nimport { configureStore } from \"./store\";\r\nimport { PersistGate } from \"redux-persist/lib/integration/react\";\r\nimport { persistStore } from \"redux-persist\";\r\nimport { ThemeProvider } from \"styled-components\";\r\nimport ErrorBoundary from \"react-error-boundary\";\r\nimport ErrorBoundaryFallback from \"components/ErrorBoundaryFallback\";\r\n\r\nconst store = configureStore();\r\nconst persistor = persistStore(store);\r\n\r\nconst render = (messages) => {\r\n ReactDOM.render(\r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n \r\n ,\r\n document.getElementById(\"root\")\r\n );\r\n};\r\n\r\n// Chunked polyfill for browsers without Intl support\r\nif (!window.Intl) {\r\n new Promise((resolve) => {\r\n resolve(import(\"intl\"));\r\n })\r\n .then(() =>\r\n Promise.all([\r\n import(\"intl/locale-data/jsonp/en.js\"),\r\n import(\"intl/locale-data/jsonp/nb.js\"),\r\n ])\r\n )\r\n .then(() => render(translationMessages))\r\n .catch((err) => {\r\n throw err;\r\n });\r\n} else {\r\n render(translationMessages);\r\n}\r\n\r\n// If you want your app to work offline and load faster, you can change\r\n// unregister() to register() below. Note this comes with some pitfalls.\r\n// Learn more about service workers: https://bit.ly/CRA-PWA\r\nserviceWorker.unregister();\r\n"],"sourceRoot":""}