{"version":3,"sources":["components/loading-spinner.tsx","app-context-provider.tsx","helpers/api-helpers.tsx","helpers/layout-helpers.tsx","contexts/Lang.jsx","components/side-menu.js","components/top-menu.js","assets/images/Arrow-Down.svg","components/page-header.tsx","helpers/style-helpers.tsx","pages/home.tsx","components/Img.tsx","components/file-component.tsx","components/page-grid.tsx","components/section-title.tsx","components/filetype-selector.tsx","assets/images/download-arrow.svg","components/download-bar.tsx","pages/file-archive.tsx","pages/font-archive.tsx","pages/standard-page.tsx","components/font-component.tsx","components/photo-component.tsx","pages/archive-category.tsx","pages/categorised-archve.tsx","helpers/helpers.tsx","components/color-component.tsx","assets/images/fileIcons/png.svg","assets/images/fileIcons/jpg.svg","assets/images/fileIcons/eps.svg","assets/images/fileIcons/pdf.svg","assets/images/fileIcons/ai.svg","components/file-icon.tsx","components/solid-icon-download-link.tsx","components/label-component.tsx","components/code-component.tsx","pages/photo-archive.tsx","pages/standard-section.tsx","components/text-component.tsx","components/component-switcher.tsx","components/floating-arrow.jsx","nav/main-logo.tsx","App.tsx","serviceWorker.ts","index.tsx"],"names":["LoadingSpinner","loadingStyle","position","height","width","fontSize","display","alignItems","justifyContent","rollerStyle","divStyle","animation","transformOrigin","baseStyle","borderRadius","background","margin","baseDelay","this","className","style","animationDelay","top","left","React","Component","AppContext","getStyles","id","a","fetch","mode","cache","headers","req","json","css","getDataById","data","getChildren","Ids","Format","filename","updateCallback","doneCallback","method","body","JSON","stringify","response","reader","getReader","contentLength","get","console","log","undefined","receivedLength","chunks","read","done","value","push","length","recievedPercent","toFixed","split","mime","require","blob","Blob","type","lookup","url","window","URL","createObjectURL","FileSaver","saveAs","generateSectionId","section","title","toLowerCase","join","inView","node","getBoundingClientRect","inViewBottom","bottom","innerHeight","createCategories","items","component","categories","forEach","item","tags","tag","newTag","heading","itemChildren","key","Object","values","LangContext","createContext","LangProvider","children","useState","globalPageData","setGlobalPageData","useEffect","nodeId","document","querySelector","getAttribute","parseInt","then","r","Provider","SideMenu","pages","useContext","mobileNav","toggleMobileNav","currentSection","setCurrentSection","onScroll","e","sections","querySelectorAll","siteIntro","sectionChildren","childSection","addEventListener","removeEventListener","classList","add","remove","MenuItems","reduce","results","page","targetId","href","sideMenuTitle","childItem","childTargetId","childClass","childHref","size","onClick","dangerouslySetInnerHTML","__html","velgKategori","showItems","TopMenu","color","map","index","motion","li","initial","opacity","animate","_extends","assign","target","i","arguments","source","prototype","hasOwnProperty","call","apply","_objectWithoutProperties","excluded","sourceKeys","keys","indexOf","_objectWithoutPropertiesLoose","getOwnPropertySymbols","sourceSymbolKeys","propertyIsEnumerable","_ref2","d","transform","fill","SvgArrowDown","_ref","svgRef","titleId","props","xmlns","viewBox","ref","ForwardRef","PageHeader","context","state","hovering","mouseEnter","bind","mouseLeave","mouseMove","setState","h1Style","styles","bodyText","dark","h2Style","vibrant","descrpitionStyle","preventDefaultTouchmoveEvent","onSwiped","onSwipe","subtitle","description","renderHeaderButton","contextType","ColorType","Home","pageBodyRef","createRef","backgroundStyle","backgroundColor","light","muted","Img","allProps","loading","alt","FileComponent","downloadFile","event","previewImages","image","src","previewImageUrl","selected","file","preventDefault","stopPropagation","wrapper","createElement","lightbox","bottomUi","resetBtn","closeBtn","img","innerText","contains","removeChild","appendChild","mouseX","mouseY","mouseTX","mouseTY","panning","ts","scale","rotate","translate","x","y","zoomable","setTransform","steps","onwheel","func","rec","clientX","clientY","delta","wheelDelta","deltaY","m","offsetWidth","offsetHeight","onmousedown","cursor","onmouseup","onmousemove","createLightbox","onMouseOver","disableDownload","boxShadow","darkBg","backgroundImage","process","hideTitle","PageGrid","deviceWidth","innerWidth","limit","listen","useCallback","s","columns","gridStyle","gridTemplateColumns","childrenLength","childrenArray","child","textAlign","lastInnAlle","SectionTitle","AllowedFileDownloadTypes","FileTypeSelector","setSelectedFileType","replace","toUpperCase","original","stroke","strokeWidth","SvgDownloadArrow","DownloadBar","downloadStatus","setDownloadStatus","selectedFileType","fileLabel","isMulti","duration","selectedItems","downloadMulti","downloadSingle","enableConversions","lastesNedIOriginalformat","charAt","slice","extension","toString","valgteFiler","disabled","getZip","slug","marginBottom","trykkForALasteNed","AnimatePresence","span","transition","deSelectAll","fjernValgteFiler","icon","faUndo","filerGjoresKlare","lasterNed","AllowedFileConversions","FileArchive","includes","enableDownloads","filter","mainTitle","pageDescription","cat","FontArchive","currentRef","prevActiveElement","selectedCategory","activeElement","current","arrowTop","arrowStyle","catClass","switchCategory","faArrowRight","Array","isArray","f","c","StandardPage","trykkPaFargenForAKopiereFargekoden","trykkPaPileneForAEndreFargekode","FontComponent","fontStyle","fontFamily","fontFamilyName","previewStyle","previewImage","maxWidth","liveFontLocation","usageRestrictions","externalSourceText","externalSourceLink","rel","fontenKanLastesNedHer","faExternalLinkAlt","PhotoComponent","originalImage","altText","PureComponent","ArchiveCategory","btoa","fitContent","CategorisedArchive","renderCategories","iosCopyToClipboard","copyInput","setAttribute","el","getElementById","oldContentEditable","contentEditable","oldReadOnly","readOnly","range","createRange","selectNodeContents","getSelection","removeAllRanges","addRange","setSelectionRange","execCommand","copyToClipboard","message","delay","listener","clipboardData","setData","modal","modalMsg","innerHTML","onclick","setTimeout","ColorComponent","viewing","label","HEX","showColorsList","showCopyToClipboard","copyColor","v","bgColor","override","generateColor","alpha","tintRgb","rgb","factor","tint","g","b","hexToRgb","simpleColorConverter","hex6","to","tinted","rgbBg","hex","pantone","result","CMYK","RGB","RAL","availableColors","find","currentIndex","dotStyle","ac","showOpacityPalette","onMouseEnter","mouseIn","onMouseLeave","mouseOut","copy","faCopy","nextColor","faChevronUp","faChevronDown","preserveAspectRatio","xlinkHref","_ref3","SvgPng","xmlnsXlink","SvgJpg","SvgEps","SvgPdf","SvgAi","fileIconIndex","png","jpg","eps","pdf","ai","FileIcon","FileIconSvg","name","SolidIconDownloadLink","download","link","fileName","click","revokeObjectURL","buttonStyle","buttonColors","marginRight","hoverStyle","iconStyle","buttonText","hoverText","LabelComponent","downloadLabel","downloadButtonText","fileExtension","downloadButtonIcon","fileUrl","showPreviews","filePath","CodeComponent","show","codeRef","alert","code","PhotoArchive","singlePhotos","collections","col","photos","photo","isSelected","selectItem","deselectItem","some","StandardSection","TextComponent","textContent","PageContainer","pageTypeKey","Kunde","LogoArchive","BackgroundArchive","IllustrationArchive","BusinessCardArchive","LetterheadArchive","PpttemplateArchive","LabelArchive","ColorPaletteArchive","EmailSignatureArchive","Section","componentTypeKey","pageId","getData","ChildComponent","totalItems","showCheckbox","FloatingArrow","header","menu","firstLink","headerTitle","lastLeft","right","minTop","firstLeft","firstTop","scrollTop","percentScrolled","Math","floor","menuItem","zIndex","MainLogo","LogoUrl","pageData","mainLogo","App","toggleNav","base","navOpen","pageTree","cssVars","showFloatingArrow","getContext","stylesheet","styleObject","prevState","keyName","allowRepeat","onKeyDown","w","open","focus","Helmet","cssText","charSet","favicon","sizes","globalFont","bakgrunnsbilde","pagePreTitle","marginTop","pageTitle","categoryIntroText","email","Fragment","scrollTo","Boolean","location","hostname","match","root","dataset","ReactDOM","render","navigator","serviceWorker","ready","registration","unregister","catch","error"],"mappings":"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","file":"static/js/main.8499e222.chunk.js","sourcesContent":["import React from 'react';\n\nclass LoadingSpinner extends React.Component {\n private loadingStyle: any = {\n position: 'absolute',\n height: '100%',\n width: '100%',\n fontSize: '1rem',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center'\n };\n\n private rollerStyle: any = {\n display: 'inline-block',\n position: 'relative',\n width: '8em',\n height: '8em'\n };\n\n private divStyle: any = {\n animation: 'lds-roller 1.2s cubic-bezier(0.5, 0, 0.5, 1) infinite',\n transformOrigin: '4em 4em'\n };\n\n private baseStyle: any = {\n position: 'absolute',\n display: 'block',\n width: '0.7em',\n height: '0.7em',\n borderRadius: '50%',\n background: 'black',\n margin: '-0.4em 0 0 - 0.4em',\n };\n\n private baseDelay: number = 0.036;\n\n\n render() {\n this.baseStyle.background = 'black';\n\n return (\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n );\n }\n}\n \nexport default LoadingSpinner;\n ","import * as React from \"react\";\nimport { FileItem, PageProps } from './components/component-switcher';\n\nexport interface AppColors {\n textColors: ColorSet;\n defaultColors: ColorSet;\n buttonColors: ColorSet;\n}\n\nexport interface ColorSet {\n primaryColor: string;\n secondaryColor: string;\n accentColor: string;\n}\n\nexport interface AppContextInterface {\n id: number;\n mainLogo?: FileItem;\n title?: string;\n pageTree: PageTree | null;\n styles: AppStyles | null;\n children?: any[];\n pageData?: any;\n currentSection?: string;\n\n}\n\n\nexport interface PageTree extends PageProps {\n mainLogo: string;\n}\n\nexport interface StyleSet {\n light: string;\n dark: string;\n muted: string;\n vibrant: string;\n}\n\nexport interface AppStyles {\n heading: StyleSet;\n bodyText: StyleSet;\n default: StyleSet;\n buttonColors: StyleSet;\n background: StyleSet;\n}\n\nconst ctxt = React.createContext(null);\n\nexport const AppContext = ctxt;\n\n","import { PageTree, AppStyles } from \"../app-context-provider\";\nimport FileSaver from \"file-saver\";\n\nexport interface StylesResponse {\n styleObject: AppStyles;\n stylesheet: string;\n}\n\nexport async function getPageTree(host: string): Promise {\n const req = await fetch(\"/headless/pagetree?domain=\" + host, {\n mode: \"no-cors\", // no-cors, *cors, same-origin\n cache: \"no-cache\", // *default, no-cache, reload, force-cache, only-if-cached\n headers: {\n \"Content-Type\": \"application/json\",\n // 'Content-Type': 'application/x-www-form-urlencoded',\n },\n });\n\n const tree = await req.json();\n\n return tree;\n}\n\nexport async function getStyles(id: number): Promise {\n const req = await fetch(\"/headless/cssVars?id=\" + id, {\n mode: \"no-cors\", // no-cors, *cors, same-origin\n cache: \"no-cache\", // *default, no-cache, reload, force-cache, only-if-cached\n headers: {\n \"Content-Type\": \"application/json\",\n // 'Content-Type': 'application/x-www-form-urlencoded',\n },\n });\n\n const css = await req.json();\n\n return css;\n}\n\nexport function getHost(): string {\n if (typeof window === undefined) {\n return \"\";\n }\n\n const host = window.location.hostname.split(\":\")[0];\n return host;\n}\n\nexport async function getData(host: string): Promise {\n const req = await fetch(\"/headless/pagedata?domain=\" + host, {\n mode: \"no-cors\", // no-cors, *cors, same-origin\n cache: \"no-cache\", // *default, no-cache, reload, force-cache, only-if-cached\n headers: {\n \"Content-Type\": \"application/json\",\n // 'Content-Type': 'application/x-www-form-urlencoded',\n },\n });\n\n const data = await req.json();\n\n return data;\n}\n\nexport async function getDataById(id: number): Promise {\n const req = await fetch(\"/headless/pagedata?id=\" + id, {\n mode: \"no-cors\", // no-cors, *cors, same-origin\n cache: \"no-cache\", // *default, no-cache, reload, force-cache, only-if-cached\n headers: {\n \"Content-Type\": \"application/json\",\n // 'Content-Type': 'application/x-www-form-urlencoded',\n },\n });\n\n const data = await req.json();\n\n return data;\n}\n\nexport async function getChildren(id: number): Promise {\n const req = await fetch(\"/headless/children?id=\" + id, {\n mode: \"no-cors\", // no-cors, *cors, same-origin\n cache: \"no-cache\", // *default, no-cache, reload, force-cache, only-if-cached\n headers: {\n \"Content-Type\": \"application/json\",\n // 'Content-Type': 'application/x-www-form-urlencoded',\n },\n });\n\n const data = await req.json();\n\n return data;\n}\n\nexport async function convertImage(id: number): Promise {\n const req = await fetch(\"/headless/images/fromfile?id=\" + id, {\n mode: \"no-cors\", // no-cors, *cors, same-origin\n cache: \"no-cache\", // *default, no-cache, reload, force-cache, only-if-cached\n headers: {\n \"Content-Type\": \"application/json\",\n // 'Content-Type': 'application/x-www-form-urlencoded',\n },\n });\n\n console.log(req);\n const data = await req.json();\n\n return data;\n}\n\nexport async function getZip(\n Ids: number[],\n Format: string,\n filename: string,\n updateCallback: Function,\n doneCallback: Function\n): Promise {\n const data = { Ids, Format };\n\n const response = await fetch(\"/zip/fromids\", {\n method: \"POST\", // *GET, POST, PUT, DELETE, etc.\n //mode: 'no-cors', // no-cors, *cors, same-origin\n cache: \"no-cache\", // *default, no-cache, reload, force-cache, only-if-cached\n headers: {\n \"Content-Type\": \"application/json\",\n // 'Content-Type': 'application/x-www-form-urlencoded',\n },\n body: JSON.stringify(data), // body data type must match \"Content-Type\" header\n });\n\n //const result = await req.blob();\n\n const reader = response?.body?.getReader();\n // Step 2: get total length\n const contentLength = +response.headers.get(\"Content-Length\")!;\n console.log(contentLength);\n if (reader !== undefined) {\n let receivedLength = 0; // received that many bytes at the moment\n let chunks = []; // array of received binary chunks (comprises the body)\n\n // infinite loop while the body is downloading\n while (true) {\n // done is true for the last chunk\n // value is Uint8Array of the chunk bytes\n const { done, value } = await reader.read();\n\n if (value === undefined) {\n break;\n }\n\n chunks.push(value);\n receivedLength += value.length;\n const recievedPercent = (receivedLength / contentLength) * 100;\n\n if (typeof updateCallback === \"function\") {\n updateCallback(recievedPercent.toFixed(0));\n }\n\n if (done) {\n break;\n }\n }\n if (typeof doneCallback === \"function\") {\n doneCallback();\n }\n console.log(response.headers.get(\"content-disposition\")?.split(\".\"));\n\n // let a = document.createElement(\"a\");\n // document.body.appendChild(a);\n // let blob = new Blob(chunks);\n // let url = window.URL.createObjectURL(blob);\n // a.href = url;\n // a.download =\n // filename +\n // (Ids.length > 1\n // ? \".zip\"\n // : \".\" +\n // response.headers.get(\"content-disposition\")?.split(\".\")[1]);\n // a.click();\n // document.body.removeChild(a);\n // window.URL.revokeObjectURL(url);\n let mime = require(\"mime-types\");\n const blob = new Blob(chunks, {\n type: `${mime.lookup(\n \".\" + response.headers.get(\"content-disposition\")?.split(\".\")[1]\n )}`,\n });\n const url = window.URL.createObjectURL(blob);\n\n FileSaver.saveAs(\n url,\n `${filename}${\n Ids.length > 1\n ? \".zip\"\n : \".\" +\n response.headers.get(\"content-disposition\")?.split(\".\")[1]\n }`\n );\n\n // this.setState({ downloadStatus: 0 });\n }\n\n // var myHeaders = new Headers();\n // myHeaders.append(\"Content-Type\", \"application/json\");\n\n // var raw = JSON.stringify({ \"Ids\": [1473, 1469], \"Format\": \"jpg\" });\n\n // var requestOptions: RequestInit = {\n // method: 'POST',\n // headers: myHeaders,\n // body: raw,\n // redirect: 'follow', // manual, *follow, error\n // mode: 'no-cors', // no-cors, *cors, same-origin\n // cache: 'no-cache', // *default, no-cache, reload, force-cache, only-if-cached\n // };\n\n // const req = await fetch(\"/zip/fromids\", requestOptions)\n // const result = await req.blob();\n}\n","import React from 'react';\nimport anime from 'animejs';\nimport { PageProps } from '../components/component-switcher';\nimport {\n // CategorisedArchiveProps,\n CategorisedItem,\n} from '../pages/categorised-archve';\nimport { ArchiveCategoryProps } from '../pages/archive-category';\n\nexport function generateSectionId(section: PageProps) {\n return section.title.toLowerCase().split(' ').join('-');\n}\n\nexport function scrollTo(ref: React.RefObject, duration: number): void {\n if (!ref || !ref.current) {\n return;\n }\n\n //account for the menubar height\n let menuHeight = 73;\n let padding = 25;\n let offset: number = menuHeight + padding;\n\n let rect = ref.current.getBoundingClientRect();\n let scollingEl = document.querySelector('.container');\n if (scollingEl === null) {\n return;\n }\n let top = rect.top - offset + scollingEl.scrollTop;\n\n anime({\n targets: scollingEl,\n duration: duration,\n easing: 'easeOutQuad',\n scrollTop: top,\n });\n}\n\nexport function scrollToTop(): void {\n let scollingEl = document.querySelector('.container');\n if (scollingEl === null) {\n return;\n }\n\n anime({\n targets: scollingEl,\n duration: 300,\n easing: 'easeOutQuad',\n scrollTop: 0,\n });\n}\n\nexport function inView(node: any) {\n if (node === undefined) {\n return false;\n }\n\n let clientRect = node.getBoundingClientRect();\n // if (node.id === 'typografi') {\n // console.log(node, clientRect);\n // }\n // var mid = 0;\n if (clientRect.top < 500) {\n return true;\n } else return false;\n}\n\nexport function inViewBottom(node: any) {\n if (node === undefined) {\n return false;\n }\n\n let clientRect = node.getBoundingClientRect();\n const bottom = clientRect.bottom;\n if (bottom < window.innerHeight && bottom > 0) {\n return true;\n }\n\n //if (clientRect.bottom > window.scrollY) {\n // item.viewed = true;\n // return true;\n //}\n\n return false;\n}\n\nexport function hasCategories(items: any[]) {\n items?.forEach((item: CategorisedItem) => {\n if (item.tags?.length > 0) {\n return true;\n }\n });\n\n return false;\n}\n\nexport function createCategories(\n items: any[],\n component: any\n): ArchiveCategoryProps[] {\n let categories: { [id: string]: ArchiveCategoryProps } = {};\n items?.forEach((item: any) => {\n if (!item.tags || item.tags.length === 0) {\n if (categories['noCategory'] === undefined) {\n categories['noCategory'] = {\n itemChildren: [],\n component,\n ...item,\n key: 'noCategory',\n };\n }\n categories['noCategory'].itemChildren.push(item);\n } else {\n item.tags?.forEach((tag: string) => {\n if (categories[tag] === undefined) {\n let newTag: ArchiveCategoryProps = {\n heading: tag,\n itemChildren: [],\n component,\n ...item,\n key: tag,\n };\n categories[tag] = newTag;\n }\n\n categories[tag].itemChildren.push(item);\n });\n }\n });\n\n return Object.values(categories);\n}\n","import React, { createContext, useEffect, useState } from 'react';\n\nimport { getDataById } from '../helpers/api-helpers';\nexport const LangContext = createContext();\nexport const LangProvider = ({ children }) => {\n const [globalPageData, setGlobalPageData] = useState(null);\n useEffect(() => {\n let nodeId = document.querySelector(\"#root\")?.getAttribute(\"data-node-id\");\n if (nodeId) {\n let id = parseInt(nodeId);\n getDataById(id).then(r => setGlobalPageData(r));\n }\n }, []);\n\n return (\n {children}\n );\n};\n","import { generateSectionId } from '../helpers/layout-helpers';\nimport React, { useState, useEffect, useContext } from 'react';\nimport AnchorLink from 'react-anchor-link-smooth-scroll';\nimport { inView, inViewBottom } from '../helpers/layout-helpers';\n\n// External components\nimport { HiMenu } from 'react-icons/hi';\nimport { LangContext } from '../contexts/Lang';\n\nexport default function SideMenu({ pages }) {\n const { globalPageData } = useContext(LangContext);\n const [mobileNav, toggleMobileNav] = useState(false);\n const [currentSection, setCurrentSection] = useState('site-intro');\n const onScroll = (e) => {\n const sections = document.querySelectorAll('.can-scroll-to');\n const siteIntro = document.querySelector('header');\n if (!sections) return;\n\n if (siteIntro && inViewBottom(siteIntro)) {\n return setCurrentSection('site-intro');\n }\n\n sections.forEach((section) => {\n //switch to children if theres nested sections\n // console.log(section, inView(section));\n if (inView(section)) {\n const sectionChildren = section.querySelectorAll('.can-scroll-to');\n // setCurrentSection(section.id);\n if (sectionChildren?.length > 0) {\n sectionChildren.forEach((childSection) => {\n if (inView(childSection)) {\n return setCurrentSection(childSection.id);\n }\n });\n } else {\n return setCurrentSection(section.id);\n }\n }\n });\n };\n\n useEffect(() => {\n window.addEventListener('scroll', onScroll);\n return () => window.removeEventListener('scroll', onScroll);\n }, []);\n\n useEffect(() => {\n if (mobileNav) {\n document.body.classList.add('no-scroll');\n } else if (!mobileNav) {\n document.body.classList.remove('no-scroll');\n }\n }, [mobileNav]);\n\n const MenuItems = () =>\n pages?.reduce((results, page) => {\n const targetId = generateSectionId(page);\n const href = '#' + targetId;\n let className = 'item';\n if (targetId === currentSection) {\n className += ' active';\n }\n if (page?.sideMenuTitle) {\n results.push(\n
  • \n \n {page.sideMenuTitle}\n \n
  • \n );\n }\n if (page.children && page.children.length > 0) {\n page.children.forEach((childItem) => {\n if (childItem?.sideMenuTitle) {\n const childTargetId = generateSectionId(childItem);\n\n let childClass = 'sub-item';\n if (childTargetId === currentSection) {\n childClass += ' active';\n }\n const childHref = '#' + childTargetId;\n results.push(\n
  • \n \n {childItem.sideMenuTitle}\n \n
  • \n );\n }\n });\n }\n return results;\n }, []);\n return (\n <>\n toggleMobileNav(!mobileNav)}\n />\n toggleMobileNav(!mobileNav)}>\n
      \n
    • \n 0\n ? globalPageData.velgKategori\n : 'Velg kategori'\n }`,\n }}>
    \n \n
    \n \n
    \n
    \n \n
    \n \n \n \n );\n}\n","import { generateSectionId } from '../helpers/layout-helpers';\nimport React from 'react';\n// import { AppContext } from \"../app-context-provider\";\n// import { buttonStyle, ColorType } from \"../helpers/style-helpers\";\nimport AnchorLink from 'react-anchor-link-smooth-scroll';\nimport { motion } from 'framer-motion';\n// import LoadingSpinner from '../components/loading-spinner';\nexport default function TopMenu({ pages, color }) {\n // const appContext = useContext(AppContext);\n return (\n
      \n {pages?.map(\n (page, index) => (\n // document.getElementById(generateSectionId(page)) ? (\n\n <>\n \n \n {page.title}\n \n \n {/* {document.getElementById(generateSectionId(page)) !==null ? (\n \n \n {page.title}\n \n \n ) : (\n \n )} */}\n \n )\n //)\n // : (\n // index === 0 && (\n // \n //
      \n // \n //
      \n //

      \n // Laster inn kategorier\n //

      \n //
      \n // )\n // )\n )}\n
    \n );\n}\n","function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport * as React from \"react\";\n\nvar _ref2 = /*#__PURE__*/React.createElement(\"path\", {\n id: \"Path_709\",\n \"data-name\": \"Path 709\",\n d: \"M2518.418,491.674l-1.043-1.043-10.721,10.721V481.186h-1.473v20.167l-10.72-10.721-1.043,1.043,12.5,12.5Zm-24.479,14.017H2517.9v-1.473h-23.957Z\",\n transform: \"translate(-2493.418 -481.186)\",\n fill: \"#00beb6\"\n});\n\nfunction SvgArrowDown(_ref, svgRef) {\n var title = _ref.title,\n titleId = _ref.titleId,\n props = _objectWithoutProperties(_ref, [\"title\", \"titleId\"]);\n\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n width: 25,\n height: 24.505,\n viewBox: \"0 0 25 24.505\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, _ref2);\n}\n\nvar ForwardRef = /*#__PURE__*/React.forwardRef(SvgArrowDown);\nexport default __webpack_public_path__ + \"static/media/Arrow-Down.2c6e2e53.svg\";\nexport { ForwardRef as ReactComponent };","import React, { Context } from 'react';\nimport { PageProps } from '../components/component-switcher';\nimport { AppContext, AppContextInterface } from '../app-context-provider';\nimport { ReactComponent as ArrowDown } from '../assets/images/Arrow-Down.svg';\nimport { Swipeable, EventData } from 'react-swipeable';\n\nexport interface PageHeaderProps extends PageProps {\n pageBodyRef: React.RefObject;\n}\n\nexport interface PageHeaderState {\n hovering: boolean;\n}\n\nclass PageHeader extends React.Component {\n static contextType: Context = AppContext;\n context!: AppContextInterface;\n state: PageHeaderState = {\n hovering: false,\n };\n\n constructor(props: PageHeaderProps) {\n super(props);\n this.mouseEnter = this.mouseEnter.bind(this);\n this.mouseLeave = this.mouseLeave.bind(this);\n this.mouseMove = this.mouseMove.bind(this);\n this.onClick = this.onClick.bind(this);\n }\n\n mouseEnter() {\n this.setState({ hovering: true });\n }\n\n mouseLeave() {\n this.setState({ hovering: false });\n }\n mouseMove() {\n if (!this.state.hovering) {\n this.setState({ hovering: true });\n }\n }\n onClick() {\n // if (this.props.BodyRef === null) {\n // return;\n // }\n // scrollTo(this.propsBodyRef, 300);\n }\n\n onSwipe(e: EventData) {\n // if (e.dir === \"Up\") {\n // scrollTo(this.propsBodyRef, 300);\n // }\n // if (e.dir === \"Left\") {\n // this.props.history.push(this.props.nextPage.url);\n // scrollToTop();\n // }\n // if (e.dir === \"Right\") {\n // this.props.history.push(this.props.prevPage.url);\n // scrollToTop();\n // }\n }\n\n renderHeaderButton() {\n // let nextLink = this.props.nextPage ? this.props.nextPage.url : '/';\n // let nextLinkText = this.props.nextPage ? this.props.nextPage.name : 'Home';\n\n // let buttonText = `Go to ${nextLinkText}`;\n // let buttonIcon = \n // if (this.props?.data === null || this.props?.data?.children?.length === 0) {\n // return (\n // \n // );\n // }\n\n return (\n \n );\n }\n\n render() {\n let h1Style = { color: this.context.styles?.bodyText.dark };\n let h2Style = { color: this.context.styles?.bodyText.vibrant };\n let descrpitionStyle = { color: this.context.styles?.bodyText.dark };\n\n return (\n \n

    {this.props.title}

    \n

    {this.props.subtitle}

    \n \n {this.renderHeaderButton()}\n \n );\n }\n}\n\nexport default PageHeader;\n","import { AppStyles } from '../app-context-provider';\nimport { CSSProperties } from 'react';\n\nexport enum ColorType {\n dark,\n light,\n muted,\n vibrant,\n}\n\nexport function buttonStyle(\n styles: AppStyles | null,\n type: ColorType\n): CSSProperties {\n let style: CSSProperties;\n switch (type) {\n case ColorType.dark:\n style = {\n backgroundColor: styles?.buttonColors.dark,\n color: styles?.buttonColors.light,\n };\n break;\n case ColorType.light:\n style = {\n backgroundColor: styles?.buttonColors.light,\n color: styles?.buttonColors.dark,\n };\n break;\n\n case ColorType.muted:\n style = {\n backgroundColor: styles?.buttonColors.vibrant,\n color: styles?.buttonColors.dark,\n };\n break;\n\n case ColorType.vibrant:\n style = {\n backgroundColor: styles?.buttonColors.muted,\n color: styles?.buttonColors.dark,\n };\n break;\n default:\n style = {};\n }\n\n style.textDecoration = 'none';\n style.border = 'none';\n style.padding = '0.75em 1.5em';\n style.cursor = 'pointer';\n style.fontWeight = 'bold';\n\n return style;\n}\n\nexport function backgroundStyle(\n styles: AppStyles | null,\n type: ColorType\n): CSSProperties {\n let style: CSSProperties;\n switch (type) {\n case ColorType.dark:\n style = {\n backgroundColor: styles?.background.dark,\n color: styles?.bodyText.light,\n };\n break;\n case ColorType.light:\n style = {\n backgroundColor: styles?.background.light,\n color: styles?.bodyText.dark,\n };\n break;\n\n case ColorType.muted:\n style = {\n backgroundColor: styles?.background.vibrant,\n color: styles?.bodyText.muted,\n };\n break;\n\n case ColorType.vibrant:\n style = {\n backgroundColor: styles?.background.muted,\n color: styles?.bodyText.vibrant,\n };\n break;\n default:\n style = {};\n }\n\n return style;\n}\n\nexport function rounded(): CSSProperties {\n return {\n borderRadius: '15px',\n };\n}\n\nexport function shadow(styles: AppStyles | null): CSSProperties {\n return {\n boxShadow: 'rgb(0, 0, 0, 15%) 10px 10px 50px 0px',\n };\n}\n","import React from 'react';\nimport { PageProps } from '../components/component-switcher';\nimport PageHeader from '../components/page-header';\n\nclass Home extends React.Component {\n pageBodyRef: React.RefObject = React.createRef();\n\n render() {\n let className = `home ${this.props.title.toLowerCase()}`;\n\n return (\n
    \n \n
    \n );\n }\n}\n \n export default Home;\n ","import React from 'react';\nimport './Img.css';\nconst Img = (props: any) => {\n let allProps = {\n ...props,\n };\n\n return (\n <>\n {props.alt}\n \n );\n};\n\nexport default Img;\n","import React, { Context } from 'react';\nimport { AppContext, AppContextInterface } from '../app-context-provider';\nimport { FileItem } from '../components/component-switcher';\nimport {\n backgroundStyle,\n ColorType,\n rounded,\n shadow,\n} from '../helpers/style-helpers';\nimport Img from './Img';\nimport { ImZoomIn } from 'react-icons/im';\nimport './Lightbox.css';\n\nexport interface FileComponentState {}\nclass FileComponent extends React.Component {\n static contextType: Context = AppContext;\n static context: AppContextInterface;\n state: FileComponentState = {};\n\n constructor(props: FileItem) {\n super(props);\n this.downloadFile = this.downloadFile.bind(this);\n }\n\n public downloadFile(event: React.MouseEvent): void {\n console.log(event);\n }\n\n public showPreviews() {\n return this.props.previewImages?.map((image) => (\n \n ));\n }\n\n render() {\n // let downloadButtonIcon = \n // let fileName = this.props.title + this.props.fileExtension;\n let className = 'component file-component selectable';\n if (this.props.selected) {\n className += ' selected';\n }\n\n // Was causing re-render of image\n\n // let Comp = ({ onClick }: any) => (\n // \n //
    \n // \n //
    \n\n // {this.props.description ? (\n // \n // ) : (\n //

    {this.props.title}

    \n // )}\n // \n // {/*\n //
    \n // \n\n // \n //
    */}\n //
    \n // );\n\n const createLightbox = (src: string) => {\n let wrapper = document.createElement('div');\n let lightbox = document.createElement('div');\n let bottomUi = document.createElement('div');\n let resetBtn = document.createElement('button');\n let closeBtn = document.createElement('button');\n let img = document.createElement('img');\n closeBtn.classList.add('lightbox-close-btn');\n resetBtn.classList.add('lightbox-reset-btn');\n bottomUi.classList.add('lightbox__bottom-ui');\n wrapper.classList.add('lightbox-wrapper');\n lightbox.classList.add('lightbox');\n img.classList.add('lightbox__img');\n img.src = src;\n closeBtn.innerText = 'Close';\n resetBtn.innerText = 'Reset';\n const remove = () => {\n if (document.body.contains(wrapper)) {\n document.body.removeChild(wrapper);\n document.body.classList.remove('noscroll');\n }\n };\n wrapper.addEventListener('click', (e) => {\n if (e.target === wrapper) {\n remove();\n }\n // remove();\n });\n closeBtn.addEventListener('click', (e) => {\n remove();\n });\n lightbox.appendChild(img);\n wrapper.appendChild(lightbox);\n bottomUi.appendChild(closeBtn);\n bottomUi.appendChild(resetBtn);\n wrapper.appendChild(bottomUi);\n document.body.appendChild(wrapper);\n document.body.classList.add('noscroll');\n document.body.addEventListener('keydown', (e) => {\n if (e.key === 'Escape') {\n remove();\n }\n });\n // wrapper.addEventListener(\n // 'wheel',\n // function (e) {\n // let currentScale = lightbox.style.transform.match(/scale\\((.*)\\)/);\n // let currentScaleVal = 1;\n // if (Array.isArray(currentScale)) {\n // currentScaleVal = parseInt(currentScale[1]);\n // }\n // let scale = (e.deltaY * -1) / 100 + currentScaleVal;\n // console.log(currentScale);\n // lightbox.style.transform = `scale(${scale})`;\n // },\n // false\n // );\n let mouseX = 0;\n let mouseY = 0;\n let mouseTX = 0;\n let mouseTY = 0;\n let panning = false;\n\n const ts = {\n scale: 1,\n rotate: 0,\n translate: {\n x: 0,\n y: 0,\n },\n };\n\n let zoomable = lightbox;\n zoomable.onwheel = function (event: any) {\n resetBtn.classList.add('visible');\n event.preventDefault();\n //need more handling to avoid fast scrolls\n var func = zoomable.onwheel;\n zoomable.onwheel = null;\n\n let rec = zoomable.getBoundingClientRect();\n let x = (event.clientX - rec.x) / ts.scale;\n let y = (event.clientY - rec.y) / ts.scale;\n\n let delta = event.wheelDelta ? event.wheelDelta : -event.deltaY;\n ts.scale = delta > 0 ? ts.scale + 0.2 : ts.scale - 0.2;\n\n //let m = (ts.scale - 1) / 2;\n let m = delta > 0 ? 0.1 : -0.1;\n ts.translate.x += -x * m * 2 + zoomable.offsetWidth * m;\n ts.translate.y += -y * m * 2 + zoomable.offsetHeight * m;\n\n setTransform();\n zoomable.onwheel = func;\n };\n\n zoomable.onmousedown = function (event) {\n event.preventDefault();\n panning = true;\n zoomable.style.cursor = 'grabbing';\n mouseX = event.clientX;\n mouseY = event.clientY;\n mouseTX = ts.translate.x;\n mouseTY = ts.translate.y;\n };\n\n zoomable.onmouseup = function (event) {\n panning = false;\n zoomable.style.cursor = 'grab';\n };\n\n zoomable.onmousemove = function (event) {\n event.preventDefault();\n // let rec = zoomable.getBoundingClientRect();\n\n const x = event.clientX;\n const y = event.clientY;\n // let pointX = x - startX;\n // let pointY = y - startY;\n if (panning) {\n resetBtn.classList.add('visible');\n }\n if (!panning) {\n return;\n }\n ts.translate.x = mouseTX + (x - mouseX);\n ts.translate.y = mouseTY + (y - mouseY);\n setTransform();\n };\n\n function setTransform() {\n const steps = `translate(${ts.translate.x}px,${ts.translate.y}px) scale(${ts.scale}) translate3d(0,0,0)`;\n //console.log(steps);\n zoomable.style.transform = steps;\n }\n function reset() {\n resetBtn.classList.remove('visible');\n ts.scale = 1;\n ts.translate = {\n x: 0,\n y: 0,\n };\n zoomable.style.transform = 'none';\n }\n resetBtn.addEventListener('click', reset);\n setTransform();\n };\n\n return (\n <>\n
    \n {this.props.file && (\n {\n e.preventDefault();\n e.stopPropagation();\n // this.props.file.id\n // this.props.file.url\n // this.props.description\n createLightbox(this.props.file.url);\n }}\n onMouseOver={(e) => {\n e.preventDefault();\n e.stopPropagation();\n }}>\n \n
    \n )}\n {\n !this.props.disableDownload && this.props.onClick(this.props.id);\n }}\n className={`${className}`}\n style={{\n ...backgroundStyle(this.context.styles, ColorType.light),\n ...rounded(),\n ...shadow(this.context.styles),\n color: this.props.darkBg ? 'var(--heading-light)' : '',\n }}>\n \n
    \n {this.props.file && (\n \n )}\n {/* \n
    \n \n \n \n
    */}\n
    \n
    \n
    \n {!this.props.hideTitle &&\n (this.props.description ? (\n \n ) : (\n <>\n

    {this.props.title}

    \n \n ))}\n \n // \n // !this.props.disableDownload &&\n // this.props.onClick(this.props.id)\n // }\n // />\n );\n }\n}\n\nexport default FileComponent;\n","// import React, { Context } from 'react';\n// import { AppContext, AppContextInterface } from '../app-context-provider';\n// export interface PageGridProps {\n// columns?: number;\n// fitContent?: boolean;\n// className?: string;\n// childrenLength?: any;\n// childrenArray?: any[];\n// }\n\n// class PageGrid extends React.Component {\n// static contextType: Context = AppContext;\n// public context!: AppContextInterface;\n// public state = { deviceWidth: window.innerWidth, limit: 15 };\n\n// constructor(props: any) {\n// super(props);\n// this.listen = this.listen.bind(this);\n// }\n\n// componentDidMount() {\n// window.addEventListener('resize', this.listen);\n// }\n\n// componentWillUnmount() {\n// window.removeEventListener('resize', this.listen);\n// }\n\n// listen() {\n// this.setState({ deviceWidth: window.innerWidth });\n// }\n\n// getColumns() {\n// return this.props.columns || 5;\n// }\n// render() {\n// let columns = this.getColumns();\n// let gridStyle = {\n// gridTemplateColumns: `repeat(${columns}, 1fr)`,\n// };\n\n// let className = 'section-grid';\n// if (this.props.className) {\n// className += ' ' + this.props.className;\n// }\n\n// return (\n// <>\n// {/*
    {JSON.stringify(this.props.columns, null, 1)}
    */}\n// 15 ? 'section-grid--many-items' : ''\n// }`}>\n// {this.props.childrenArray?.map(\n// (child, index) =>\n// index < this.state.limit && (\n//
    {child}
    \n// )\n// )}\n// {this.props.children}\n//
    \n//
    \n// {this.props.childrenArray?.length &&\n// this.state.limit < this.props.childrenArray.length && (\n// \n// this.setState({\n// deviceWidth: window.innerWidth,\n// limit: this?.props?.childrenArray?.length,\n// })\n// }>\n// {/* Last inn alle */}\n// Load all\n// \n// )}\n//
    \n// \n// );\n// }\n// }\n\n// export default PageGrid;\nimport React, { useState, useEffect, useCallback, useContext } from 'react';\nimport { LangContext } from '../contexts/Lang';\nexport interface PageGridProps {\n columns?: number;\n fitContent?: boolean;\n className?: string;\n childrenLength?: any;\n childrenArray?: any[];\n children?: any;\n}\nconst PageGrid = (props: PageGridProps) => {\n const { globalPageData } = useContext(LangContext);\n const [state, setState] = useState({\n deviceWidth: window.innerWidth,\n limit: 15,\n });\n const listen = useCallback(() => {\n setState((s) => {\n return {\n ...s,\n deviceWidth: window.innerWidth,\n };\n });\n }, [setState]);\n useEffect(() => {\n window.addEventListener('resize', listen);\n return () => {\n window.removeEventListener('resize', listen);\n };\n }, [listen]);\n const getColumns = () => {\n return props.columns || 5;\n };\n let columns = getColumns();\n let gridStyle = {\n gridTemplateColumns: `repeat(${columns}, 1fr)`,\n };\n\n let className = 'section-grid';\n if (props.className) {\n className += ' ' + props.className;\n }\n return (\n <>\n 15 ? 'section-grid--many-items' : ''\n }`}>\n {props.childrenArray?.map(\n (child, index) =>\n index < state.limit && (\n
    {child}
    \n )\n )}\n {props.children}\n
    \n
    \n {props.childrenArray?.length &&\n state.limit < props.childrenArray.length && (\n \n setState({\n deviceWidth: window.innerWidth,\n limit: props?.childrenArray?.length || 0,\n })\n }>\n {globalPageData.lastInnAlle || 'Last inn alle'}\n \n )}\n
    \n \n );\n};\n\nexport default PageGrid;\n","import React from \"react\";\n\nexport default function SectionTitle({ title }: { title?: string }) {\n if (!title) {\n return null;\n }\n return (\n \n );\n}\n","import React from 'react';\n\nexport interface DownloadBarProps {\n selected: string;\n setSelectedFileType: any;\n original?: string;\n}\n\nexport const AllowedFileDownloadTypes = ['original', '.jpg', '.png', '.pdf'];\n\nexport default function FileTypeSelector(props: DownloadBarProps) {\n return (\n
    \n {AllowedFileDownloadTypes.map((item) => {\n let className = 'switch';\n if (item === props.selected) {\n className += ' selected';\n }\n return (\n props.setSelectedFileType(item)}\n className={className}>\n {item.replace('.', '').toUpperCase()}{' '}\n {item === 'original' ? props.original : ''}\n
    \n );\n })}\n
    \n );\n}\n","function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport * as React from \"react\";\n\nvar _ref2 = /*#__PURE__*/React.createElement(\"g\", {\n id: \"Group_1559\",\n \"data-name\": \"Group 1559\",\n transform: \"translate(-1549.906 -4003.155)\"\n}, /*#__PURE__*/React.createElement(\"path\", {\n id: \"Icon_awesome-arrow-down\",\n \"data-name\": \"Icon awesome-arrow-down\",\n d: \"M21.526,12.129l1.151,1.151a1.239,1.239,0,0,1,0,1.758L12.6,25.119a1.239,1.239,0,0,1-1.758,0L.763,15.038a1.239,1.239,0,0,1,0-1.758l1.151-1.151a1.246,1.246,0,0,1,1.779.021L9.646,18.4V3.495A1.242,1.242,0,0,1,10.891,2.25H12.55a1.242,1.242,0,0,1,1.245,1.245V18.4l5.953-6.249A1.237,1.237,0,0,1,21.526,12.129Z\",\n transform: \"translate(1554.758 4000.905)\"\n}), /*#__PURE__*/React.createElement(\"path\", {\n id: \"Path_4196\",\n \"data-name\": \"Path 4196\",\n d: \"M3067.906,1407h33.145\",\n transform: \"translate(-1518 2629.967)\",\n fill: \"none\",\n stroke: \"#000\",\n strokeWidth: 5\n}));\n\nfunction SvgDownloadArrow(_ref, svgRef) {\n var title = _ref.title,\n titleId = _ref.titleId,\n props = _objectWithoutProperties(_ref, [\"title\", \"titleId\"]);\n\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n width: 33.145,\n height: 36.312,\n viewBox: \"0 0 33.145 36.312\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, _ref2);\n}\n\nvar ForwardRef = /*#__PURE__*/React.forwardRef(SvgDownloadArrow);\nexport default __webpack_public_path__ + \"static/media/download-arrow.698d6b24.svg\";\nexport { ForwardRef as ReactComponent };","import { faUndo } from '@fortawesome/free-solid-svg-icons';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { useContext, useState } from 'react';\n// import { AppContext } from \"../app-context-provider\";\nimport React from 'react';\n// import { buttonStyle, ColorType } from \"../helpers/style-helpers\";\nimport FileTypeSelector from './filetype-selector';\nimport { getZip } from '../helpers/api-helpers';\nimport { ReactComponent as DownloadButton } from '../assets/images/download-arrow.svg';\n// import LoadingSpinner from \"./loading-spinner\";\nimport AnimateHeight from 'react-animate-height';\nimport { FaRegHandPointer } from 'react-icons/fa';\nimport { motion, AnimatePresence } from 'framer-motion';\nimport { LangContext } from '../contexts/Lang';\nexport interface DownloadBarProps {\n selectedItems: any[];\n deSelectAll?: any;\n enableConversions: boolean;\n isMulti: boolean;\n}\n\nexport const FileDownloadTypes = {};\n\nexport default function DownloadBar(props: DownloadBarProps) {\n const [downloadStatus, setDownloadStatus]: [number | null, Function] =\n useState(null);\n // const appContext = useContext(AppContext);\n const [selectedFileType, setSelectedFileType] = useState('original');\n const fileLabel = props.isMulti ? 'filene' : 'filen';\n const { globalPageData } = useContext(LangContext);\n return (\n
    \n \n
    \n
    \n
    \n {/* \n */}\n \n \n
    \n

    \n {props.isMulti && (\n <>\n {globalPageData.downloadMulti ||\n 'Klikk på filene du ønsker å laste ned:'}\n \n )}\n {!props.isMulti && (\n <>\n {globalPageData.downloadSingle ||\n 'Klikk på filen du ønsker å laste ned:'}\n \n )}\n

    \n
    \n {!props.enableConversions && (\n

    \n {globalPageData.lastesNedIOriginalformat ||\n fileLabel.charAt(0).toUpperCase() +\n fileLabel.slice(1) +\n ' lastes ned i originalformat'}\n

    \n )}\n
    \n \n \n
    \n {props.enableConversions && (\n 0\n ? '(' +\n props.selectedItems\n .map((item, index) =>\n index === 0 ? '.' + item.file?.extension : ''\n )\n .toString()\n .replace(/,/g, '') +\n ')'\n : ''\n }\n selected={selectedFileType}\n />\n )}\n\n {downloadStatus === null && (\n
    \n
    \n {props.isMulti && (\n
    \n \n
    \n )}\n 1\n ? 'download-zip-button-multiple'\n : 'download-zip-button-single'\n }`}\n disabled={downloadStatus !== null}\n onClick={() => {\n setDownloadStatus(0);\n getZip(\n props.selectedItems.map((item) => item.file?.id),\n selectedFileType,\n props.selectedItems\n .map((item) => item.file?.slug)\n .toString(),\n (recievedPercent: number) => {\n console.log(recievedPercent);\n setDownloadStatus(recievedPercent);\n },\n () => setDownloadStatus(null)\n );\n }}>\n {/* {props.selectedItems.length > 1 ? Download all as .zip : Download file} */}\n \n \n
    \n
    \n {!props.isMulti && (\n
    \n \n {globalPageData.trykkForALasteNed ||\n 'Trykk for å laste ned:'}\n \n
    \n {props.selectedItems.map((item) => (\n \n {item.title +\n (selectedFileType.toLowerCase() === 'original'\n ? '.' + item.file?.extension\n : selectedFileType)}\n \n ))}\n
    \n
    \n )}\n {props.isMulti && (\n \n {props.selectedItems.map(\n (item, index) =>\n item && (\n \n {item.title}\n {selectedFileType.toLowerCase() === 'original'\n ? '.' + item.file?.extension\n : selectedFileType}\n \n )\n )}\n \n )}\n\n
    \n \n {globalPageData.fjernValgteFiler || 'Fjern valgte filer'}\n \n \n
    \n
    \n
    \n )}\n {downloadStatus === 0 && (\n

    \n {globalPageData.filerGjoresKlare ||\n 'Filene dine gjøres klar for nedlasting, vennligst vent et øyeblikk.'}\n

    \n )}\n {downloadStatus !== null && downloadStatus > 0 && (\n \n {globalPageData.lasterNed || 'Laster ned...'}\n {downloadStatus}%\n \n )}\n
    \n \n
    \n );\n}\n","import React from 'react';\nimport { PageProps, FileItem } from '../components/component-switcher';\nimport FileComponent from '../components/file-component';\nimport PageGrid from '../components/page-grid';\nimport SectionTitle from '../components/section-title';\nimport { createCategories, generateSectionId } from '../helpers/layout-helpers';\nimport DownloadBar from '../components/download-bar';\nexport interface FilePage extends PageProps {\n itemChildren: FileItem[];\n}\n\nexport interface FileArchiveState {\n selectedItems: FileItem[];\n}\n\nexport const AllowedFileConversions = ['LogoArchive'];\n\nclass FileArchive extends React.Component {\n // constructor(props: any) {\n // super(props);\n // }\n\n render() {\n let className = `file-archive ${this.props.type.toLowerCase()}`;\n if (this.props.sideMenuTitle) {\n className += ' can-scroll-to';\n }\n let Component = this.props.component || FileComponent;\n let categories = createCategories(this.props.itemChildren, Component);\n let enableConversions = AllowedFileConversions.includes(this.props.type);\n let enableDownloads =\n this.props.itemChildren.filter((item: any) => {\n return !item.disableDownload;\n })?.length > 0;\n return (\n
    \n \n {this.props.pageDescription && (\n \n )}\n {enableDownloads && (\n 1}\n enableConversions={enableConversions}\n {...this.props}\n selectedItems={this.props.selectedItems || []}\n />\n )}\n item.itemChildren.length\n )}\n childrenArray={categories.reduce((results: any[], cat) => {\n // if (cat.heading) {\n // results.push(\n // \n // {cat.heading}\n // \n // );\n // }\n cat.itemChildren.forEach((props: any) => {\n props.hideTitle = this.props.hideTitle;\n props.childrenLength = cat.itemChildren.length;\n\n results.push(\n \n \n
    \n );\n });\n\n return results;\n }, [])}\n />\n \n );\n }\n}\n\nexport default FileArchive;\n","import { faArrowRight } from '@fortawesome/free-solid-svg-icons';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport React from 'react';\nimport { PageProps } from '../components/component-switcher';\nimport { FontComponentProps } from '../components/font-component';\n// import PageGrid from \"../components/page-grid\";\nimport SectionTitle from '../components/section-title';\nimport { createCategories, generateSectionId } from '../helpers/layout-helpers';\n\nexport interface FontArchiveState {\n selectedCategory: FontComponentProps | any;\n arrowTop?: number;\n}\n\nclass FontArchive extends React.Component {\n constructor(props: PageProps) {\n super(props);\n const categories = createCategories(\n this.props.itemChildren || [],\n this.props.component\n );\n const state = props.itemChildren\n ? { selectedCategory: categories[0] }\n : { selectedCategory: {} };\n this.state = state;\n }\n\n public currentRef = React.createRef();\n public prevActiveElement = null;\n\n componentDidUpdate() {\n let activeElement = this.currentRef.current?.querySelector('.active');\n if (this.prevActiveElement !== activeElement) {\n this.prevActiveElement = activeElement;\n\n const top =\n activeElement.getBoundingClientRect().top -\n this.currentRef.current?.getBoundingClientRect().top +\n activeElement.getBoundingClientRect().height / 2;\n this.setState({ arrowTop: top });\n }\n }\n scrollToPageBody() {}\n\n switchCategory(cat: any) {\n this.setState({ selectedCategory: cat });\n }\n\n render() {\n let className = `page-container standard-section ${this.props.type.toLowerCase()}`;\n let Component = this.props.component;\n if (this.props.sideMenuTitle) {\n className += ' can-scroll-to';\n }\n\n const categories = createCategories(\n this.props.itemChildren || [],\n Component\n );\n let arrowStyle = { top: this.state.arrowTop || 0 };\n return (\n
    \n \n {this.props.pageDescription && (\n \n )}\n
    \n
    \n
      \n {categories.map((cat) => {\n let catClass = '';\n const isActive = this.state.selectedCategory.key === cat.key;\n if (isActive) {\n catClass += 'active';\n }\n return (\n this.switchCategory(cat)}>\n {cat.heading}\n \n );\n })}\n \n
    \n
    \n
    \n {this.state.selectedCategory?.itemChildren?.map(\n (item: any) =>\n Component && (\n <>\n f.id === item.id)\n ?.map((c: any) => c?.description)\n : null,\n }}\n />\n \n )\n )}\n
    \n
    \n
    \n );\n }\n}\n\nexport default FontArchive;\n","import React, { useContext } from 'react';\nimport { PageProps } from '../components/component-switcher';\nimport PageGrid from '../components/page-grid';\nimport SectionTitle from '../components/section-title';\nimport { generateSectionId } from '../helpers/layout-helpers';\nimport { FaRegHandPointer } from 'react-icons/fa';\nimport { HiSelector } from 'react-icons/hi';\nimport { LangContext } from '../contexts/Lang';\n\nconst StandardPage = (props: PageProps) => {\n // scrollToPageBody()\n let className = `page-container standard-section ${props.type.toLowerCase()}`;\n let Component = props.component;\n if (props.sideMenuTitle) {\n className += ' can-scroll-to';\n }\n\n const { globalPageData } = useContext(LangContext);\n\n return (\n
    \n \n {props.pageDescription && (\n \n )}\n {props.type === 'ColorPaletteArchive' && (\n <>\n
    \n
    \n
    \n \n \n \n \n
    \n

    \n {globalPageData.trykkPaFargenForAKopiereFargekoden ||\n 'Trykk på fargen for å kopiere fargekoden'}\n

    \n
    \n
    \n
    \n \n
    \n

    \n {globalPageData.trykkPaPileneForAEndreFargekode ||\n 'Trykk på pilene for å endre fargekode'}\n

    \n
    \n
    \n \n )}\n \n {props.itemChildren?.map(\n (props) => Component && \n )}\n \n
    \n );\n};\n\nexport default StandardPage;\n","import { faExternalLinkAlt } from '@fortawesome/free-solid-svg-icons';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport React, { useContext } from 'react';\n// import { AppContext, AppContextInterface } from '../app-context-provider';\nimport { PageItem } from '../components/component-switcher';\nimport Img from './Img';\n// import mediaQuery from '../media-query';\nimport { LangContext } from '../contexts/Lang';\n\nexport interface FontComponentProps extends PageItem {\n externalSourceText: string;\n externalSourceLink: string;\n fontFamilyName: string;\n liveFontLocation: string;\n usageRestrictions: string;\n accreditationRequirements: string;\n previewImage: Array<{\n id: number;\n key: string;\n slug: string;\n url: string;\n title: string;\n umbracoExtension: string;\n type: string;\n }>;\n}\n\nexport interface FontComponentState {}\n\nconst FontComponent = (props: FontComponentProps) => {\n const { globalPageData } = useContext(LangContext);\n let fontStyle = { fontFamily: `${props.fontFamilyName}` };\n\n // \n\n //let textstring = \"ABCČĆDĐEFGHIJKLMNOPQRSŠTUVWXYZŽabcčćdđefghijklmnopqrsštuvwxyzžАБВГҐДЂЕЁЄЖЗЅИІЇЙЈКЛЉМНЊОПРСТЋУЎФХЦЧЏШЩЪЫЬЭЮЯабвгґдђеёєжзѕиіїйјклљмнњопрстћуўфхцчџшщъыьэюяΑΒΓΔΕΖΗΘΙΚΛΜΝΞΟΠΡΣΤΥΦΧΨΩαβγδεζηθικλμνξοπρστυφχψωάΆέΈέΉίϊΐΊόΌύΰϋΎΫΏĂÂÊÔƠƯăâêôơư1234567890‘?’“!”(%)[#]{@}/&\\\\<-+÷×=>®©$€£¥¢:;,.*\";\n let previewStyle: React.CSSProperties = {\n ...fontStyle,\n };\n // if (props.liveFontLocation) {\n // let body = document.body;\n // let link = document.createElement('link');\n // link.setAttribute('href', props.liveFontLocation);\n // link.setAttribute('ref', 'stylesheet');\n // body.appendChild(link);\n // }\n return (\n
    \n

    {props.title}

    \n {props.description[0]?.replace(/(<([^>]+)>)/gi, '') !== props.title && (\n \n )}\n {props.previewImage?.length > 0 ? (\n props.previewImage?.map((img) => (\n {img.title}\n ))\n ) : (\n <>\n {props.liveFontLocation && (\n
    \n
    Aa
    \n

    ABCDEFGHIJKLMNOPQRSTUVWXYZÆØÅ

    \n

    abcdefghijklmnopqrstuvwxyzæøå

    \n

    1234567890

    \n
    \n )}\n \n )}\n\n \n\n
    \n \n {props.externalSourceLink && (\n \n \n {globalPageData.fontenKanLastesNedHer ||\n 'Fonten kan lastes ned her'}{' '}\n \n \n \n )}\n
    \n
    \n );\n};\n\n// class FontComponent extends React.Component<\n// FontComponentProps,\n// FontComponentState\n// > {\n// static contextType: Context = AppContext;\n// public context!: AppContextInterface;\n// state: FontComponentState = {};\n\n// constructor(props: FontComponentProps) {\n// super(props);\n// this.downloadFile = this.downloadFile.bind(this);\n// }\n\n// public downloadFile(event: React.MouseEvent): void {\n// console.log(event);\n// }\n\n// render() {\n// let fontStyle = { fontFamily: `${this.props.fontFamilyName}` };\n\n// // \n\n// //let textstring = \"ABCČĆDĐEFGHIJKLMNOPQRSŠTUVWXYZŽabcčćdđefghijklmnopqrsštuvwxyzžАБВГҐДЂЕЁЄЖЗЅИІЇЙЈКЛЉМНЊОПРСТЋУЎФХЦЧЏШЩЪЫЬЭЮЯабвгґдђеёєжзѕиіїйјклљмнњопрстћуўфхцчџшщъыьэюяΑΒΓΔΕΖΗΘΙΚΛΜΝΞΟΠΡΣΤΥΦΧΨΩαβγδεζηθικλμνξοπρστυφχψωάΆέΈέΉίϊΐΊόΌύΰϋΎΫΏĂÂÊÔƠƯăâêôơư1234567890‘?’“!”(%)[#]{@}/&\\\\<-+÷×=>®©$€£¥¢:;,.*\";\n// let previewStyle: React.CSSProperties = {\n// ...fontStyle,\n// };\n// // if (this.props.liveFontLocation) {\n// // let body = document.body;\n// // let link = document.createElement('link');\n// // link.setAttribute('href', this.props.liveFontLocation);\n// // link.setAttribute('ref', 'stylesheet');\n// // body.appendChild(link);\n// // }\n// return (\n//
    \n//

    {this.props.title}

    \n// {this.props.description[0]?.replace(/(<([^>]+)>)/gi, '') !==\n// this.props.title && (\n// \n// )}\n// {this.props.previewImage?.length > 0 ? (\n// this.props.previewImage?.map((img) => (\n// {img.title}\n// ))\n// ) : (\n// <>\n// {this.props.liveFontLocation && (\n//
    \n//
    Aa
    \n//

    ABCDEFGHIJKLMNOPQRSTUVWXYZÆØÅ

    \n//

    abcdefghijklmnopqrstuvwxyzæøå

    \n//

    1234567890

    \n//
    \n// )}\n// \n// )}\n\n// \n\n//
    \n// \n// {this.props.externalSourceLink && (\n// \n// Fonten kan lastes ned her\n// \n// \n// )}\n//
    \n//
    \n// );\n// }\n// }\n\nexport default FontComponent;\n","import React, { Context } from 'react';\nimport { AppContext, AppContextInterface } from '../app-context-provider';\nimport { PageItem } from '../components/component-switcher';\nimport Img from './Img';\n\nexport interface PhotoComponentProps extends PageItem {\n styleTags: string[];\n url: string;\n id: number;\n altText: string;\n selected: boolean;\n onClick: any;\n originalImage: any;\n}\n\nexport interface PhotoComponentState {}\n\nclass PhotoComponent extends React.PureComponent<\n PhotoComponentProps,\n PhotoComponentState\n> {\n static contextType: Context = AppContext;\n public context!: AppContextInterface;\n state: PhotoComponentState = {};\n\n render() {\n if (!this.props.url) {\n return null;\n }\n return (\n this.props.onClick(this.props.id)}>\n \n {!this.props.hideTitle &&

    {this.props.title}

    }\n \n {/* */}\n \n );\n }\n}\n\nexport default PhotoComponent;\n","import React, { Context } from 'react';\nimport { AppContextInterface, AppContext } from '../app-context-provider';\nimport { CategorisedItem } from './categorised-archve';\nimport PageGrid from '../components/page-grid';\nimport { PhotoComponentProps } from '../components/photo-component';\n// import { PageProps } from '../components/component-switcher';\n\nexport interface StyleTag {\n name: string;\n items: PhotoComponentProps[];\n}\n\nexport interface ArchiveCategoryProps {\n component?: React.ComponentType;\n slug?: string;\n heading?: string;\n key: string;\n itemChildren: CategorisedItem[];\n columns?: number;\n fitContent?: boolean;\n}\n\nclass ArchiveCategory extends React.Component {\n pageBodyRef: React.RefObject = React.createRef();\n static contextType: Context = AppContext;\n public context!: AppContextInterface;\n\n renderItems() {\n if (this.props.component === undefined) {\n return null;\n }\n\n let Component = this.props.component;\n\n return this.props.itemChildren?.map((item) => );\n }\n\n render() {\n let key = window.btoa(this.props.key);\n return (\n
    \n {this.props.heading && (\n \n

    {this.props.heading}

    \n
    \n )}\n \n {this.props.children}\n \n \n );\n }\n}\n\nexport default ArchiveCategory;\n","import React, { Context } from \"react\";\nimport {\n PageItem,\n PageData,\n PageProps,\n} from \"../components/component-switcher\";\nimport { AppContextInterface, AppContext } from \"../app-context-provider\";\nimport ArchiveCategory, { ArchiveCategoryProps } from \"./archive-category\";\nimport SectionTitle from \"../components/section-title\";\nimport { generateSectionId, createCategories } from \"../helpers/layout-helpers\";\n\nexport interface CategorisedArchiveData extends PageData {\n children: CategorisedItem[];\n}\n\nexport interface CategorisedArchiveProps extends PageProps {\n page: CategorisedPage;\n columns: number;\n component: React.ComponentType;\n hideTitle: boolean;\n fitContent: boolean;\n itemChildren: CategorisedItem[];\n}\n\nexport interface CategorisedPage extends PageProps {\n data: CategorisedArchiveData;\n}\n\nexport interface CategorisedItem extends PageItem {\n tags: string[];\n}\n\nexport interface CategorisedPageState {\n columns: number;\n}\n\nclass CategorisedArchive extends React.Component {\n pageBodyRef: React.RefObject = React.createRef();\n static contextType: Context = AppContext;\n public context!: AppContextInterface;\n public state: CategorisedPageState = { columns: 3 };\n\n renderCategories() {\n let categories: ArchiveCategoryProps[] = createCategories(\n this.props.itemChildren,\n this.props.component\n );\n if (categories.length === 0) {\n let newTag: ArchiveCategoryProps = { ...this.props };\n return [];\n }\n return categories.map(\n (tag) => \n //let tagHeading =

    Photo Style:

    \n //let tagSubHeading =

    {tag.name}

    \n //elements.push(tagHeading);\n //elements.push(tagSubHeading);\n //elements.push({tag.items.map((item: PhotoItem) => ) } );\n );\n }\n\n render() {\n let className = `${this.props.type.toLowerCase()}`;\n if (this.props.sideMenuTitle) {\n className += \" can-scroll-to\";\n }\n return (\n
    \n \n {this.renderCategories()}\n
    \n );\n }\n}\n\nexport default CategorisedArchive;\n","function iosCopyToClipboard(data: string) {\n let id = 'copyInput';\n let copyInput = document.createElement('input');\n copyInput.setAttribute('type', 'text');\n copyInput.setAttribute('value', data);\n copyInput.id = id;\n document.body.appendChild(copyInput);\n const el = document.getElementById(id) as HTMLInputElement;\n if (el !== undefined && el !== null) {\n var oldContentEditable = el.contentEditable,\n oldReadOnly = el.readOnly,\n range = document.createRange();\n el.readOnly = false;\n range.selectNodeContents(el);\n\n var s = window.getSelection();\n s?.removeAllRanges();\n s?.addRange(range);\n\n el.setSelectionRange(0, 999999); // A big number, to cover anything that could be inside the element.\n\n el.contentEditable = oldContentEditable;\n el.readOnly = oldReadOnly;\n\n document.execCommand('copy');\n document.body.removeChild(copyInput);\n }\n}\nexport function copyToClipboard(\n data: string,\n message?: string,\n delay: number = 1000\n) {\n let listener = (e: any) => {\n e.clipboardData.setData('text/html', data);\n e.clipboardData.setData('text/plain', data);\n e.preventDefault();\n };\n\n /* let code = document.createElement('textarea');\n code.innerHTML = this.props.item.code;\n document.body.appendChild(code);\n code.select();*/\n document.addEventListener('copy', listener);\n document.execCommand('copy');\n document.removeEventListener('copy', listener);\n //document.body.removeChild(code);\n // alert(message || \"\");\n\n // IOS specific\n iosCopyToClipboard(data);\n\n // Message user using modal\n let modal = document.createElement('div');\n modal.classList.add('modal');\n modal.setAttribute('id', 'modal');\n let modalMsg = document.createElement('div');\n modalMsg.innerHTML = message || '';\n modal.appendChild(modalMsg);\n modal.onclick = () => {\n modal.classList.remove('modal-visible');\n };\n document.body.appendChild(modal);\n if (document.getElementById('modal')) {\n setTimeout(() => {\n modal.classList.add('modal-visible');\n }, 100);\n setTimeout(() => {\n modal.classList.remove('modal-visible');\n }, delay);\n setTimeout(() => {\n document.body.removeChild(modal);\n }, delay + 2000);\n }\n}\n\nexport const cmyk2rgb = function (\n c: number,\n m: number,\n y: number,\n k: number,\n normalized: boolean\n) {\n c = c / 100;\n m = m / 100;\n y = y / 100;\n k = k / 100;\n\n c = c * (1 - k) + k;\n m = m * (1 - k) + k;\n y = y * (1 - k) + k;\n\n var r = 1 - c;\n var g = 1 - m;\n var b = 1 - y;\n\n if (!normalized) {\n r = Math.round(255 * r);\n g = Math.round(255 * g);\n b = Math.round(255 * b);\n }\n\n return {\n r: r,\n g: g,\n b: b,\n };\n};\n","import React, { Context } from 'react';\nimport { AppContext, AppContextInterface } from '../app-context-provider';\nimport { PageItem } from '../components/component-switcher';\nimport {\n backgroundStyle,\n ColorType,\n rounded,\n shadow,\n} from '../helpers/style-helpers';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport {\n faChevronDown,\n faChevronUp,\n faCopy,\n} from '@fortawesome/free-solid-svg-icons';\nimport { copyToClipboard } from '../helpers/helpers';\nimport simpleColorConverter from 'simple-color-converter';\n\nexport interface ColorComponentProps extends PageItem {\n CMYK: string;\n HEX: string;\n RGB: string;\n RAL: string;\n pantone: string;\n showOpacityPalette: boolean;\n}\n\nexport interface ColorComponentState {\n viewing: ViewingColor;\n showColorsList: boolean;\n showCopyToClipboard: boolean;\n}\n\nexport interface ViewingColor {\n label: string;\n value: string;\n}\nclass ColorComponent extends React.Component<\n ColorComponentProps,\n ColorComponentState\n> {\n static contextType: Context = AppContext;\n public context!: AppContextInterface;\n public state: ColorComponentState = {\n viewing: { label: 'HEX', value: this.props.HEX },\n showColorsList: false,\n showCopyToClipboard: false,\n };\n\n availableColors() {\n let result = [];\n if (this.props.CMYK) {\n result.push({ label: 'CMYK', value: this.props.CMYK });\n }\n if (this.props.HEX) {\n result.push({ label: 'HEX', value: this.props.HEX });\n }\n if (this.props.RGB) {\n result.push({ label: 'RGB', value: this.props.RGB });\n }\n if (this.props.pantone) {\n result.push({ label: 'Pantone', value: this.props.pantone });\n }\n if (this.props.RAL) {\n result.push({ label: 'RAL', value: this.props.RAL });\n }\n return result;\n }\n\n nextColor(e: any) {\n e.stopPropagation();\n const availableColors = this.availableColors();\n let current = availableColors.find(\n (item) => item.label === this.state.viewing.label\n );\n if (current) {\n let currentIndex = availableColors.indexOf(current);\n currentIndex++;\n const length = availableColors.length;\n if (currentIndex > length - 1) {\n this.setState({ viewing: availableColors[0] });\n } else {\n this.setState({ viewing: availableColors[currentIndex] });\n }\n }\n }\n\n prevColor(e: any) {\n e.stopPropagation();\n\n const availableColors = this.availableColors();\n let current = availableColors.find(\n (item) => item.label === this.state.viewing.label\n );\n if (current) {\n let currentIndex = availableColors.indexOf(current);\n currentIndex--;\n const length = availableColors.length;\n if (currentIndex < 0) {\n this.setState({ viewing: availableColors[length - 1] });\n } else {\n this.setState({ viewing: availableColors[currentIndex] });\n }\n }\n }\n\n mouseIn() {\n this.setState({ showCopyToClipboard: true });\n }\n mouseOut() {\n this.setState({ showCopyToClipboard: false });\n }\n\n copy(e: any) {\n const data = this.state.viewing;\n let color = e.target.style.backgroundColor;\n // if (data.label === 'HEX') {\n // color = `${data.value}`;\n // }\n // if (data.label === 'RGB') {\n // color = `rgb(${data.value.replace(/\\./g, ',')})`;\n // }\n copyToClipboard(\n data.value,\n `

    ${this.state.viewing.label}

    \n ${this.state.viewing.value}

    copied.

    `\n );\n }\n copyColor = (\n v: string,\n bgColor?: string,\n override: boolean = false,\n delay?: number\n ) =>\n copyToClipboard(\n v,\n override\n ? v\n : `

    ${v}

    \n ${v}

    copied.

    `,\n delay\n );\n generateColor = (color: string | undefined, alpha: number = 1) => {\n // function hexToRgb(hex: string) {\n // var result = /^#?([a-f\\d]{2})([a-f\\d]{2})([a-f\\d]{2})$/i.exec(hex);\n // return result\n // ? {\n // r: parseInt(result[1], 16),\n // g: parseInt(result[2], 16),\n // b: parseInt(result[3], 16),\n // }\n // : null;\n // }\n const tintRgb = (\n rgb: { r: number; g: number; b: number } | null,\n factor: number\n ) => {\n if (rgb !== null) {\n let tint = 1 - factor;\n let tintedR = (rgb.r + (255 - rgb.r) * tint).toFixed(0);\n let tintedG = (rgb.g + (255 - rgb.g) * tint).toFixed(0);\n let tintedB = (rgb.b + (255 - rgb.b) * tint).toFixed(0);\n return { r: tintedR, g: tintedG, b: tintedB };\n }\n };\n // function valueToHex(v: number) {\n // var hex = v.toString(16);\n\n // return hex;\n // }\n // function rgbToHex(r: number, g: number, b: number) {\n // return valueToHex(r) + valueToHex(g) + valueToHex(b);\n // }\n // function rgb2cmyk(r: number, g: number, b: number) {\n // var computedC = 0;\n // var computedM = 0;\n // var computedY = 0;\n // var computedK = 0;\n\n // //remove spaces from input RGB values, convert to int\n // var r = parseInt(('' + r).replace(/\\s/g, ''), 10);\n // var g = parseInt(('' + g).replace(/\\s/g, ''), 10);\n // var b = parseInt(('' + b).replace(/\\s/g, ''), 10);\n\n // if (\n // r == null ||\n // g == null ||\n // b == null ||\n // isNaN(r) ||\n // isNaN(g) ||\n // isNaN(b)\n // ) {\n // alert('Please enter numeric RGB values!');\n // return;\n // }\n // if (r < 0 || g < 0 || b < 0 || r > 255 || g > 255 || b > 255) {\n // alert('RGB values must be in the range 0 to 255.');\n // return;\n // }\n\n // // BLACK\n // if (r == 0 && g == 0 && b == 0) {\n // computedK = 1;\n // return [0, 0, 0, 1];\n // }\n\n // computedC = 1 - r / 255;\n // computedM = 1 - g / 255;\n // computedY = 1 - b / 255;\n\n // var minCMY = Math.min(computedC, Math.min(computedM, computedY));\n // computedC = (computedC - minCMY) / (1 - minCMY);\n // computedM = (computedM - minCMY) / (1 - minCMY);\n // computedY = (computedY - minCMY) / (1 - minCMY);\n // computedK = minCMY;\n\n // return [\n // computedC * 100,\n // computedM * 100,\n // computedY * 100,\n // computedK * 100,\n // ];\n // }\n if (typeof color === 'string') {\n var hexToRgb = new simpleColorConverter({\n hex6: color,\n to: 'rgb',\n });\n let tinted = tintRgb(hexToRgb.color, alpha);\n if (tinted) {\n let rgbBg = `rgb(${tinted.r},${tinted.g},${tinted.b})`;\n if (this.state.viewing.label === 'RGB') {\n let rgb = `${tinted.r} - ${tinted.g} - ${tinted.b}`;\n this.copyColor(rgb, rgbBg);\n }\n if (this.state.viewing.label === 'HEX') {\n let hex = new simpleColorConverter({\n rgb: tinted,\n to: 'hex6',\n });\n this.copyColor(`#${hex.color}`, rgbBg);\n }\n console.log(this.state.viewing.label);\n if (this.state.viewing.label === 'Pantone') {\n if (alpha === 1) {\n this.copyColor(this.state.viewing.value, rgbBg);\n } else {\n let pantone = new simpleColorConverter({\n rgb: tinted,\n to: 'pantone',\n });\n // this.copyColor(`${pantone.color}`, rgbBg);\n\n this.copyColor(\n `

    Try ${pantone.color},
    or contact for accurate
    Pantone color.

    `,\n rgbBg,\n true,\n 3000\n );\n }\n }\n if (this.state.viewing.label === 'CMYK') {\n if (alpha === 1) {\n this.copyColor(this.state.viewing.value, rgbBg);\n } else {\n this.copyColor(\n `

    Same color,
    just with ${(alpha * 100).toFixed(\n 0\n )}% alpha

    `,\n rgbBg,\n true,\n 1500\n );\n // let cmyk = new simpleColorConverter({\n // rgb: tinted,\n // to: 'cmyk',\n // });\n // let c = cmyk.color?.c;\n // let m = cmyk.color?.m;\n // let y = cmyk.color?.y;\n // let k = cmyk.color?.k;\n // this.copyColor(`${c} - ${m} - ${y} - ${k}`, rgbBg);\n }\n }\n }\n // let rgb = hexToRgb(color);\n // let tintedRgb = tintRgb(rgb);\n // if (tintedRgb) {\n // let r = Number(tintedRgb?.r);\n // let g = Number(tintedRgb?.g);\n // let b = Number(tintedRgb?.b);\n // // console.log(this.state);\n // if (this.state.viewing.label === 'HEX') {\n // let hex = rgbToHex(r, g, b);\n // if (tint_factor === 1) {\n // this.copyColor(this.state.viewing.value, this.state.viewing.value);\n // } else {\n // this.copyColor(`#${hex.toUpperCase()}`, `#${hex.toUpperCase()}`);\n // }\n // }\n // if (this.state.viewing.label === 'RGB') {\n // console.log(color);\n // // this.copyColor(`${r} - ${g} - ${b}`, `rgb(${r},${g},${b})`);\n // }\n // if (this.state.viewing.label === 'CMYK') {\n // let cmyk = rgb2cmyk(r, g, b);\n // let c = cmyk ? cmyk[0] : '';\n // let m = cmyk ? cmyk[1] : '';\n // let y = cmyk ? cmyk[2] : '';\n // let k = cmyk ? cmyk[3] : '';\n\n // this.copyColor(this.state.viewing.value, this.state.viewing.value);\n // // if (tint_factor === 1) {\n // // this.copyColor(this.state.viewing.value, this.state.viewing.value);\n // // } else {\n // // this.copyColor(\n // // `${c} - ${m} - ${y} - ${k}`,\n // // this.state.viewing.value\n // // );\n // // }\n // }\n // }\n }\n };\n\n render() {\n let dotStyle: React.CSSProperties = {\n backgroundColor: this.props.HEX,\n width: '100%',\n cursor: 'pointer',\n };\n const ac = this.availableColors();\n let className = 'color-component';\n if (this.props.showOpacityPalette) {\n className += ' with-opacity';\n }\n return (\n \n \n \n \n \n \n {this.props.showOpacityPalette && (\n
    \n this.generateColor(dotStyle.backgroundColor, 1)}\n />\n this.generateColor(dotStyle.backgroundColor, 0.75)}\n />\n this.generateColor(dotStyle.backgroundColor, 0.55)}\n />\n this.generateColor(dotStyle.backgroundColor, 0.25)}\n />\n
    \n )}\n\n 1 ? 'type-selector--selectable' : ''\n }`}>\n

    {this.props.title}

    \n
    \n \n \n
    \n {/* \n
      \n
    • {this.props.title}
    • \n {this.props.CMYK && this.state.viewing !== 'CMYK' &&
    • this.setState({viewing: 'CMYK'})}>CMYK
    • }\n {this.props.RGB && this.state.viewing !== 'RGB' &&
    • this.setState({viewing: 'RGB'})}>RGB
    • }\n {this.props.HEX && this.state.viewing !== 'HEX' &&
    • this.setState({viewing: 'HEX'})}>Hexcode
    • }\n {this.props.pantone && this.state.viewing !== 'Pantone' &&
    • this.setState({viewing: 'Pantone'})}>Pantone
    • }\n
    */}\n \n \n );\n }\n}\n\nexport default ColorComponent;\n","function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport * as React from \"react\";\n\nvar _ref2 = /*#__PURE__*/React.createElement(\"defs\", null, /*#__PURE__*/React.createElement(\"pattern\", {\n id: \"pattern\",\n preserveAspectRatio: \"none\",\n width: \"100%\",\n height: \"100%\",\n viewBox: \"0 0 198 224\"\n}, /*#__PURE__*/React.createElement(\"image\", {\n width: 198,\n height: 224,\n xlinkHref: \"\"\n})));\n\nvar _ref3 = /*#__PURE__*/React.createElement(\"rect\", {\n id: \"Image_4\",\n \"data-name\": \"Image 4\",\n width: 22,\n height: 25,\n fill: \"url(#pattern)\"\n});\n\nfunction SvgPng(_ref, svgRef) {\n var title = _ref.title,\n titleId = _ref.titleId,\n props = _objectWithoutProperties(_ref, [\"title\", \"titleId\"]);\n\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n xmlnsXlink: \"http://www.w3.org/1999/xlink\",\n width: 22,\n height: 25,\n viewBox: \"0 0 22 25\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, _ref2, _ref3);\n}\n\nvar ForwardRef = /*#__PURE__*/React.forwardRef(SvgPng);\nexport default __webpack_public_path__ + \"static/media/png.81431311.svg\";\nexport { ForwardRef as ReactComponent };","function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport * as React from \"react\";\n\nvar _ref2 = /*#__PURE__*/React.createElement(\"defs\", null, /*#__PURE__*/React.createElement(\"pattern\", {\n id: \"pattern\",\n preserveAspectRatio: \"none\",\n width: \"100%\",\n height: \"100%\",\n viewBox: \"0 0 159 205\"\n}, /*#__PURE__*/React.createElement(\"image\", {\n width: 159,\n height: 205,\n xlinkHref: \"\"\n})));\n\nvar _ref3 = /*#__PURE__*/React.createElement(\"rect\", {\n id: \"Image_5\",\n \"data-name\": \"Image 5\",\n width: 19,\n height: 25,\n fill: \"url(#pattern)\"\n});\n\nfunction SvgJpg(_ref, svgRef) {\n var title = _ref.title,\n titleId = _ref.titleId,\n props = _objectWithoutProperties(_ref, [\"title\", \"titleId\"]);\n\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n xmlnsXlink: \"http://www.w3.org/1999/xlink\",\n width: 19,\n height: 25,\n viewBox: \"0 0 19 25\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, _ref2, _ref3);\n}\n\nvar ForwardRef = /*#__PURE__*/React.forwardRef(SvgJpg);\nexport default __webpack_public_path__ + \"static/media/jpg.ac3c302a.svg\";\nexport { ForwardRef as ReactComponent };","function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport * as React from \"react\";\n\nvar _ref2 = /*#__PURE__*/React.createElement(\"defs\", null, /*#__PURE__*/React.createElement(\"pattern\", {\n id: \"pattern\",\n preserveAspectRatio: \"none\",\n width: \"100%\",\n height: \"100%\",\n viewBox: \"0 0 192 199\"\n}, /*#__PURE__*/React.createElement(\"image\", {\n width: 192,\n height: 199,\n xlinkHref: \"\"\n})));\n\nvar _ref3 = /*#__PURE__*/React.createElement(\"rect\", {\n id: \"Image_3\",\n \"data-name\": \"Image 3\",\n width: 24,\n height: 25,\n fill: \"url(#pattern)\"\n});\n\nfunction SvgEps(_ref, svgRef) {\n var title = _ref.title,\n titleId = _ref.titleId,\n props = _objectWithoutProperties(_ref, [\"title\", \"titleId\"]);\n\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n xmlnsXlink: \"http://www.w3.org/1999/xlink\",\n width: 24,\n height: 25,\n viewBox: \"0 0 24 25\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, _ref2, _ref3);\n}\n\nvar ForwardRef = /*#__PURE__*/React.forwardRef(SvgEps);\nexport default __webpack_public_path__ + \"static/media/eps.b2c7e5a9.svg\";\nexport { ForwardRef as ReactComponent };","function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport * as React from \"react\";\n\nvar _ref2 = /*#__PURE__*/React.createElement(\"defs\", null, /*#__PURE__*/React.createElement(\"pattern\", {\n id: \"pattern\",\n preserveAspectRatio: \"none\",\n width: \"100%\",\n height: \"100%\",\n viewBox: \"0 0 203 249\"\n}, /*#__PURE__*/React.createElement(\"image\", {\n width: 203,\n height: 249,\n xlinkHref: \"\"\n})));\n\nvar _ref3 = /*#__PURE__*/React.createElement(\"rect\", {\n id: \"Image_6\",\n \"data-name\": \"Image 6\",\n width: 20,\n height: 25,\n fill: \"url(#pattern)\"\n});\n\nfunction SvgPdf(_ref, svgRef) {\n var title = _ref.title,\n titleId = _ref.titleId,\n props = _objectWithoutProperties(_ref, [\"title\", \"titleId\"]);\n\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n xmlnsXlink: \"http://www.w3.org/1999/xlink\",\n width: 20,\n height: 25,\n viewBox: \"0 0 20 25\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, _ref2, _ref3);\n}\n\nvar ForwardRef = /*#__PURE__*/React.forwardRef(SvgPdf);\nexport default __webpack_public_path__ + \"static/media/pdf.fe1f5985.svg\";\nexport { ForwardRef as ReactComponent };","function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nimport * as React from \"react\";\n\nvar _ref2 = /*#__PURE__*/React.createElement(\"defs\", null, /*#__PURE__*/React.createElement(\"pattern\", {\n id: \"pattern\",\n preserveAspectRatio: \"none\",\n width: \"100%\",\n height: \"100%\",\n viewBox: \"0 0 240 208\"\n}, /*#__PURE__*/React.createElement(\"image\", {\n width: 240,\n height: 208,\n xlinkHref: \"\"\n})));\n\nvar _ref3 = /*#__PURE__*/React.createElement(\"rect\", {\n id: \"Image_1\",\n \"data-name\": \"Image 1\",\n width: 29,\n height: 25,\n fill: \"url(#pattern)\"\n});\n\nfunction SvgAi(_ref, svgRef) {\n var title = _ref.title,\n titleId = _ref.titleId,\n props = _objectWithoutProperties(_ref, [\"title\", \"titleId\"]);\n\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n xmlnsXlink: \"http://www.w3.org/1999/xlink\",\n width: 29,\n height: 25,\n viewBox: \"0 0 29 25\",\n ref: svgRef,\n \"aria-labelledby\": titleId\n }, props), title ? /*#__PURE__*/React.createElement(\"title\", {\n id: titleId\n }, title) : null, _ref2, _ref3);\n}\n\nvar ForwardRef = /*#__PURE__*/React.forwardRef(SvgAi);\nexport default __webpack_public_path__ + \"static/media/ai.0032b857.svg\";\nexport { ForwardRef as ReactComponent };","import React, { Context } from 'react';\nimport { AppContext, AppContextInterface } from '../app-context-provider';\nimport { ReactComponent as png } from '../assets/images/fileIcons/png.svg';\nimport { ReactComponent as jpg } from '../assets/images/fileIcons/jpg.svg';\nimport { ReactComponent as eps } from '../assets/images/fileIcons/eps.svg';\nimport { ReactComponent as pdf } from '../assets/images/fileIcons/pdf.svg';\nimport { ReactComponent as ai } from '../assets/images/fileIcons/ai.svg';\nexport interface FileIconProps {\n name: string;\n}\n\nexport const fileIconIndex: any = { png, jpg, eps, pdf, ai };\n\nclass FileIcon extends React.Component {\n static contextType: Context = AppContext;\n static context: AppContextInterface;\n\n render() {\n let FileIconSvg = fileIconIndex[this.props.name?.replace('.', '')];\n if (!FileIconSvg) {\n return null;\n }\n return ();\n }\n}\n\nexport default FileIcon;\n","import React, { Context } from 'react';\nimport { AppContext, AppContextInterface } from '../app-context-provider';\nimport { SolidIconLinkProps, SolidIconButtonState } from './solid-icon-Link';\n\nexport interface SolidIconDownloadState extends SolidIconButtonState {\n downloadStatus: number;\n\n}\nexport interface DownloadProps extends SolidIconLinkProps {\n fileName: string;\n}\nclass SolidIconDownloadLink extends React.Component {\n static contextType: Context = AppContext;\n public context!: AppContextInterface;\n public state: SolidIconDownloadState = {\n hovering: false,\n downloadStatus: 0\n }\n\n constructor(props: DownloadProps) {\n super(props);\n this.mouseEnter = this.mouseEnter.bind(this);\n this.mouseLeave = this.mouseLeave.bind(this);\n this.download = this.download.bind(this);\n }\n\n mouseEnter() {\n this.setState({ hovering: true });\n }\n\n mouseLeave() {\n this.setState({ hovering: false });\n\n }\n\n async download() {\n this.setState({ downloadStatus: 1,hovering: false });\n\n let response = await fetch(this.props.link, { mode: 'no-cors' });\n const reader = response?.body?.getReader();\n // Step 2: get total length\n const contentLength = +response.headers.get('Content-Length')!;\n\n if (reader !== undefined) {\n let receivedLength = 0; // received that many bytes at the moment\n let chunks = []; // array of received binary chunks (comprises the body)\n \n\n // infinite loop while the body is downloading\n while (true) {\n // done is true for the last chunk\n // value is Uint8Array of the chunk bytes\n const { done, value } = await reader.read();\n\n if (value === undefined) {\n break;\n }\n\n this.setState({ downloadStatus: (receivedLength / contentLength) * 100 });\n chunks.push(value);\n receivedLength += value.length;\n\n if (done) {\n this.setState({ downloadStatus: 0 });\n break;\n }\n\n }\n\n\n let a = document.createElement(\"a\");\n document.body.appendChild(a);\n let blob = new Blob(chunks);\n let url = window.URL.createObjectURL(blob);\n a.href = url;\n a.download = this.props.fileName;\n a.click();\n document.body.removeChild(a);\n window.URL.revokeObjectURL(url);\n this.setState({ downloadStatus: 0 });\n\n }\n }\n\n render() {\n\n let buttonStyle = { backgroundColor: this.context.styles?.buttonColors.dark, color: 'white', marginRight: '0.5em' };\n let hoverStyle: any = {\n color: 'white',\n marginRight: '0.5em',\n position: 'absolute',\n transition: 'all .3s ease',\n backgroundColor: this.context.styles?.buttonColors.dark\n }\n if (this.state.hovering) {\n hoverStyle.transform = 'translateX(0%)';\n hoverStyle.opacity = '1';\n } else {\n hoverStyle.transform = 'translateX(-100%)';\n hoverStyle.opacity = '0';\n }\n let iconStyle = {\n backgroundColor: this.state.hovering || this.state.downloadStatus !== 0 ? this.context.styles?.buttonColors.vibrant : this.context.styles?.buttonColors.dark,\n ...this.props.iconStyle\n };\n \n return (\n \n );\n }\n}\n \nexport default SolidIconDownloadLink;\n ","import React, { Context } from 'react';\nimport { AppContext, AppContextInterface } from '../app-context-provider';\nimport LabelIcon from './file-icon';\nimport { ReactComponent as ArrowDown } from '../assets/images/Arrow-Down.svg';\nimport { FileItem } from '../components/component-switcher';\nimport SolidIconDownloadLink from './solid-icon-download-link';\nimport Img from './Img';\n\nexport interface LabelComponentProps {\n item: FileItem;\n}\n\nexport interface LabelComponentState {}\n\nclass LabelComponent extends React.Component<\n LabelComponentProps,\n LabelComponentState\n> {\n static contextType: Context = AppContext;\n static context: AppContextInterface;\n state: LabelComponentState = {};\n\n constructor(props: LabelComponentProps) {\n super(props);\n this.downloadLabel = this.downloadLabel.bind(this);\n }\n\n public downloadLabel(event: React.MouseEvent): void {\n console.log(event);\n }\n\n public showPreviews() {\n return this.props.item.previewImages?.map((image) => (\n \n ));\n }\n\n render() {\n let downloadButtonText = (\n \n Download  \n {this.props.item.fileExtension}\n \n );\n let downloadButtonIcon = ;\n let fileName = this.props.item.title + this.props.item.fileExtension;\n\n return (\n
    \n
    \n {this.props.item.fileUrl !== undefined &&\n this.props.item.fileUrl !== '' ? (\n \n ) : (\n this.showPreviews()\n )}\n
    \n\n

    {this.props.item.title}

    \n \n\n
    \n \n \n
    \n
    \n );\n }\n}\n\nexport default LabelComponent;\n","import React, { Context, RefObject } from 'react';\nimport { AppContext, AppContextInterface } from '../app-context-provider';\nimport { PageItem } from '../components/component-switcher';\nimport { ReactComponent as Arrow } from '../assets/images/Arrow-Down.svg';\n\nexport interface CodeItem extends PageItem {\n description: string;\n code: string;\n}\n\nexport interface CodeComponentProps {\n item: CodeItem;\n}\n\nexport interface CodeComponentState {\n show: boolean;\n}\n\n\n\nclass CodeComponent extends React.Component {\n static contextType: Context = AppContext;\n static context: AppContextInterface;\n state: CodeComponentState = {\n show: false,\n }\n public codeRef: RefObject = React.createRef();\n\n\n toggle() {\n this.setState((state) => ({ show: !state.show }))\n }\n copyToClipboard() {\n let listener = (e: any) => {\n\n e.clipboardData.setData(\"text/html\", document.querySelector('.code-preview')?.innerHTML);\n e.clipboardData.setData(\"text/plain\", document.querySelector('.code-preview')?.innerHTML);\n e.preventDefault();\n }\n\n /* let code = document.createElement('textarea');\n code.innerHTML = this.props.item.code;\n document.body.appendChild(code);\n code.select();*/\n document.addEventListener(\"copy\", listener);\n document.execCommand(\"copy\");\n document.removeEventListener(\"copy\", listener);\n //document.body.removeChild(code);\n alert(\"Copied to clipboard\")\n\n\n\n }\n\n render() {\n\n return (\n
    \n

    \n\n

    \n \n
    \n\n
    \n\n\n
    \n );\n }\n}\n\nexport default CodeComponent;\n /*\n \n {this.state.show && {this.props.item.code} }\n\n*/","import React, { Context } from \"react\";\nimport { AppContextInterface, AppContext } from \"../app-context-provider\";\nimport ArchiveCategory, { ArchiveCategoryProps } from \"./archive-category\";\nimport SectionTitle from \"../components/section-title\";\nimport { createCategories, generateSectionId } from \"../helpers/layout-helpers\";\nimport { CategorisedArchiveProps } from \"./categorised-archve\";\n\nexport interface PhotoArchiveProps extends CategorisedArchiveProps {\n columns: number;\n component: React.ComponentType;\n fitContent: boolean;\n}\n\nexport interface PhotoArchiveState {\n columns: number;\n selectedItems: any[];\n}\n\nclass PhotoArchive extends React.Component {\n pageBodyRef: React.RefObject = React.createRef();\n static contextType: Context = AppContext;\n public context!: AppContextInterface;\n public state: PhotoArchiveState = { columns: 3, selectedItems: [] };\n\n componentDidMount() {\n if (this.state.columns !== this.props.columns) {\n this.setState({ columns: this.props.columns });\n }\n }\n\n renderCategories() {\n const singlePhotos = this.props.itemChildren?.filter(\n (item) => item.type === \"Photo\"\n );\n const collections = this.props.itemChildren?.filter(\n (item) => item.type === \"PhotoCollection\"\n );\n let categories: ArchiveCategoryProps[] = createCategories(\n singlePhotos!,\n this.props.component\n );\n let results = [];\n\n collections?.forEach((col: any) => {\n let newTag: ArchiveCategoryProps = { heading: col.title, ...col };\n console.log(col)\n results.push([\n \n {col.photos.map((photo: any) => {\n const Component = this.props.component;\n return (\n \n );\n })}\n ,\n ]);\n });\n\n if (results.length === 0) {\n let newTag: ArchiveCategoryProps = { ...this.props };\n results.push([\n \n {singlePhotos.map((photo: any) => {\n const Component = this.props.component;\n return (\n \n );\n })}\n ,\n ]);\n } else {\n categories?.forEach((col: any) => {\n let newTag: ArchiveCategoryProps = {\n heading: col.title,\n ...col,\n };\n results.push([\n \n {col.photos.map((photo: any) => {\n const Component = this.props.component;\n return (\n \n );\n })}\n ,\n ]);\n });\n }\n\n return results;\n }\n\n addColumn() {\n let columns = this.state.columns + 1;\n if (columns > 4) {\n columns = 4;\n }\n this.setState({ columns });\n }\n\n removeColumn() {\n let columns = this.state.columns - 1;\n if (columns < 1) {\n columns = 1;\n }\n this.setState({ columns });\n }\n\n selectItem(id: number) {\n const item = this.props.itemChildren.find((item) => item.id === id);\n if (!item) {\n return;\n }\n this.setState({ selectedItems: [...this.state.selectedItems, item] });\n }\n\n deselectItem(id: number) {\n this.setState({\n selectedItems: this.state.selectedItems.filter(\n (item) => item.id !== id\n ),\n });\n }\n\n onClick(id: number) {\n if (this.isSelected(id)) {\n this.selectItem(id);\n } else {\n this.deselectItem(id);\n }\n }\n\n isSelected(id: number) {\n return this.state.selectedItems.some((item) => item.id === id);\n }\n\n render() {\n let className = `page-container ${this.props.type.toLowerCase()}`;\n // let maxColumns = mediaQuery.isDesktop() ? 4 : 2;\n if (this.props.sideMenuTitle) {\n className += \" can-scroll-to\";\n }\n\n let key = window.btoa(this.props.slug);\n return (\n \n \n {this.props.pageDescription && (\n \n )}\n {/*
    \n \n\n
    \n \n {this.state.columns}\n \n
    \n
    */}\n {this.renderCategories()}\n\n
    \n );\n }\n}\n\nexport default PhotoArchive;\n","import React from 'react';\nimport { PageProps } from '../components/component-switcher';\n// import PageGrid from \"../components/page-grid\";\nimport SectionTitle from '../components/section-title';\nimport { generateSectionId } from '../helpers/layout-helpers';\nimport ComponentSwitcher from '../components/component-switcher';\n\nclass StandardSection extends React.Component {\n render() {\n let className = `page-container standard-section ${this.props.type.toLowerCase()} has-children`;\n if (this.props.sideMenuTitle) {\n className += ' can-scroll-to';\n }\n return (\n
    \n {this.props.mainTitle && }\n {this.props.itemChildren?.map((section: any) => (\n \n ))}\n
    \n );\n }\n}\n\nexport default StandardSection;\n","import React, { Context } from \"react\";\nimport { AppContext, AppContextInterface } from \"../app-context-provider\";\nimport { PageItem } from \"./component-switcher\";\nimport SectionTitle from \"./section-title\";\n\nexport interface TextComponentProps {\n item: PageItem;\n textContent: string;\n mainTitle: string;\n}\n\nexport interface TextComponentState {}\n\nclass TextComponent extends React.Component<\n TextComponentProps,\n TextComponentState\n> {\n static contextType: Context = AppContext;\n public context!: AppContextInterface;\n state: TextComponentState = {};\n\n // constructor(props: TextComponentProps) {\n // super(props);\n // }\n\n render() {\n return (\n
    \n \n \n
    \n );\n }\n}\n\nexport default TextComponent;\n","import React from 'react';\nimport Home from '../pages/home';\nimport FileArchive from '../pages/file-archive';\nimport FontArchive from '../pages/font-archive';\nimport { RouteComponentProps } from 'react-router-dom';\nimport StandardPage from '../pages/standard-page';\nimport FontComponent from './font-component';\nimport FileComponent from './file-component';\nimport PhotoComponent from './photo-component';\nimport CategorisedArchive from '../pages/categorised-archve';\n// import BusinessCardComponent from \"./business-card-component\";\nimport ColorComponent from './color-component';\nimport LabelComponent from './label-component';\nimport CodeComponent from './code-component';\nimport PhotoArchive from '../pages/photo-archive';\nimport { getChildren, getDataById } from '../helpers/api-helpers';\nimport LoadingSpinner from './loading-spinner';\nimport { hasCategories } from '../helpers/layout-helpers';\nimport StandardSection from '../pages/standard-section';\nimport TextComponent from '../components/text-component';\n// export interface Page {\n// nodeId: string;\n// pageTitle: string;\n// pageSubtitle: string;\n// pageDescription: string;\n// pageContent: string;\n// name: string;\n// url: string;\n// type: string;\n// key: string;\n// data: PageData;\n// }\n\nexport interface PageData {\n children: PageItem[];\n}\n\nexport interface PageItem {\n id: number;\n description: string;\n usageRestrictions: string;\n accreditationRequirements: string;\n key: string;\n type?: string;\n selected?: boolean;\n onClick?: any;\n showCheckbox?: boolean;\n hideTitle: boolean;\n title?: string;\n}\n\nexport interface PreviewImage {\n previewImageUrl: string;\n previewImageId: number;\n key: string;\n}\nexport interface FileItem extends PageItem {\n filePath: string;\n fileUrl: string;\n file: any;\n darkBg: boolean;\n disableDownload?: boolean;\n fileExtension: string;\n hideTitle: boolean;\n previewImages: PreviewImage[];\n}\n\nexport interface PageProps extends RouteComponentProps {\n id: number;\n key: string;\n slug: string;\n title: string;\n type: string;\n url: string;\n pageContent: any;\n subtitle: string;\n description: string;\n treeChildren?: PageProps[];\n itemChildren?: PageItem[];\n component?: React.ComponentType;\n selectedItems?: any[];\n deSelectAll?: any;\n mainTitle?: string;\n pageDescription?: string;\n sideMenuTitle?: string;\n columns?: number;\n hideTitle: boolean;\n}\n\nexport interface ComponentSwitcherState {\n loading: boolean;\n data: any;\n itemChildren?: PageItem[];\n selectedItems: PageItem[];\n}\n\nclass PageContainer extends React.Component {\n constructor(props: PageProps) {\n super(props);\n this.state = { loading: true, data: null, selectedItems: [] };\n this.selectItem = this.selectItem.bind(this);\n this.deselectItem = this.deselectItem.bind(this);\n this.onClick = this.onClick.bind(this);\n this.isSelected = this.isSelected.bind(this);\n this.deSelectAll = this.deSelectAll.bind(this);\n }\n\n async getData(pageId: number) {\n const data = await getDataById(pageId);\n const itemChildren = await getChildren(data.id);\n let state: ComponentSwitcherState = {\n data,\n loading: false,\n itemChildren,\n selectedItems: [],\n };\n if (itemChildren && itemChildren.length === 1) {\n state.selectedItems = itemChildren;\n }\n this.setState(state);\n }\n\n pageTypeKey: any = {\n Kunde: Home,\n LogoArchive: FileArchive,\n FontArchive: FontArchive,\n PhotoArchive: PhotoArchive,\n BackgroundArchive: StandardPage,\n IllustrationArchive: FileArchive,\n BusinessCardArchive: FileArchive,\n LetterheadArchive: FileArchive,\n PpttemplateArchive: FileArchive,\n LabelArchive: StandardPage,\n ColorPaletteArchive: (props: any) =>\n hasCategories(props.itemChildren) ? (\n \n ) : (\n \n ),\n EmailSignatureArchive: StandardPage,\n Section: StandardSection,\n TextComponent: (props: any) => ,\n };\n\n componentTypeKey: any = {\n Kunde: Home,\n LogoArchive: FileComponent,\n FontArchive: FontComponent,\n PhotoArchive: PhotoComponent,\n BackgroundArchive: FileComponent,\n IllustrationArchive: FileComponent,\n BusinessCardArchive: FileComponent,\n LetterheadArchive: FileComponent,\n PpttemplateArchive: FileComponent,\n LabelArchive: LabelComponent,\n EmailSignatureArchive: CodeComponent,\n ColorPaletteArchive: ColorComponent,\n TextComponent: TextComponent,\n };\n\n componentDidMount() {\n // window.addEventListener(\"media-query-resize\", () => this.forceUpdate);\n this.getData(this.props.id);\n }\n\n componentWillUnmount() {\n // window.removeEventListener(\n // \"media-query-resize\",\n // () => this.forceUpdate\n // );\n }\n\n selectItem(id: number) {\n const item = this.state.itemChildren?.find((item) => item.id === id);\n if (!item) {\n return;\n }\n this.setState({ selectedItems: [...this.state.selectedItems, item] });\n }\n\n deselectItem(id: number) {\n this.setState({\n selectedItems: this.state.selectedItems.filter((item) => item.id !== id),\n });\n }\n\n onClick(id: number) {\n if (this.isSelected(id)) {\n this.deselectItem(id);\n } else {\n this.selectItem(id);\n }\n }\n\n isSelected(id: number) {\n return this.state.selectedItems.some((item) => item.id === id);\n }\n\n deSelectAll() {\n this.setState({ selectedItems: [] });\n }\n\n // renderChildComponents(ChildComponent: any) {\n // if (ChildComponent === undefined) {\n // return null;\n // }\n // const children = this.state.itemChildren?.map(item => {\n // item.selected = this.isSelected(item.id);\n // item.onClick = this.onClick.bind(this);\n // return item;\n // })\n // return children?.map((item: PageItem) => (\n // \n // ));\n // }\n\n render() {\n let Component = this.pageTypeKey[this.props.type];\n let ChildComponent = this.componentTypeKey[this.props.type];\n if (this.state.loading) {\n return ;\n }\n\n const children = this.state.itemChildren?.map((item) => {\n let totalItems = this.state.itemChildren?.length;\n if (totalItems) {\n item.selected = this.isSelected(item.id);\n item.onClick = this.onClick;\n item.selected = this.isSelected(item.id);\n item.hideTitle = this.props.hideTitle;\n item.showCheckbox =\n this.state.selectedItems.length > 0 && totalItems > 1;\n }\n return item;\n });\n\n return (\n \n );\n }\n}\n\nexport default PageContainer;\n","// import { faArrowDown } from \"@fortawesome/free-solid-svg-icons\";\n// import { FontAwesomeIcon } from \"@fortawesome/react-fontawesome\";\nimport React, { useEffect, useState } from \"react\";\nimport { inView, inViewBottom } from \"../helpers/layout-helpers\";\n\nimport { BsArrowDown } from 'react-icons/bs';\n\nexport default function FloatingArrow() {\n const [currentSection, setCurrentSection] = useState(\"\");\n // const [currentScrollY, setScrollY] = useState(0);\n const onScroll = (e) => {\n // setScrollY(window.scrollY);\n const sections = document.querySelectorAll(\".can-scroll-to\");\n const siteIntro = document.querySelector(\"header\");\n if (!sections) return;\n\n if (siteIntro && inViewBottom(siteIntro)) {\n setCurrentSection(\"site-intro\");\n return;\n }\n\n sections.forEach((section) => {\n //switch to children if theres nested sections\n\n if (inView(section)) {\n const sectionChildren =\n section.querySelectorAll(\".can-scroll-to\");\n if (sectionChildren?.length > 0) {\n sectionChildren.forEach((childSection) => {\n if (inView(childSection)) {\n setCurrentSection(childSection.id);\n return;\n }\n });\n } else {\n setCurrentSection(section.id);\n return;\n }\n }\n });\n };\n\n useEffect(() => {\n setTimeout(() => setCurrentSection(\"site-intro\"), 1000);\n window.addEventListener(\"scroll\", onScroll);\n return () => {\n window.removeEventListener(\"scroll\", onScroll);\n };\n }, []);\n\n\n let style = { position: \"fixed\", height: \"1.25em\" };\n let header = document.querySelector(\"header\");\n let siteIntro = header?.querySelector(\".site-intro\");\n let menu = document.querySelector(\".side-menu\");\n let firstLink = menu?.querySelector(\"a\");\n let headerTitle = header?.querySelector(\"h1\");\n let lastLeft = firstLink?.getBoundingClientRect().right + 25;\n let minTop = firstLink?.getBoundingClientRect().top;\n let firstLeft = siteIntro?.getBoundingClientRect().width / 2;\n let firstTop = headerTitle?.getBoundingClientRect().bottom + 35;\n if (currentSection === \"site-intro\" && header) {\n let scrollTop = header?.getBoundingClientRect().top || 0;\n let height = header?.getBoundingClientRect().height || 0;\n let percentScrolled = ((height + scrollTop) / height) * 100;\n let left = lastLeft + ((firstLeft - lastLeft) / 100) * percentScrolled;\n let top = minTop + ((firstTop - minTop) / 100) * percentScrolled;\n let rotate = Math.floor(0.9 * (100 - percentScrolled));\n style.top = top;\n style.left = left;\n style.transform = `rotate(-${rotate}deg)`;\n style.fontSize = 1 + percentScrolled * 0.02 + \"em\";\n // } else if (currentSection?.classList.contains('fontarchive')) {\n // const menuItem = currentSection.querySelector('.category-selector .active') || firstLink;\n // style.transition = previousTarget === menuItem ? 'none' : 'all .3s ease';\n // style.left = menuItem?.getBoundingClientRect()?.right + 25;\n // style.top = menuItem?.getBoundingClientRect()?.top;\n // style.transform = 'rotate(-90deg)';\n } else {\n const menuItem =\n document.querySelector(\".side-menu .active\") || firstLink;\n style.transition = \"all .260s ease\";\n style.left = menuItem?.getBoundingClientRect()?.right + 25 || 0;\n style.top = menuItem?.getBoundingClientRect()?.top || 0;\n style.transform = \"rotate(-90deg)\";\n style.fontSize = 1 + \"em\";\n style.zIndex = \"20\";\n }\n\n style.opacity = currentSection === \"\" ? 0 : 1;\n\n return (\n\n \n \n \n );\n}\n","import React from 'react';\nimport { AppContextInterface, AppContext } from '../app-context-provider';\nimport Img from '../components/Img';\n\nclass MainLogo extends React.Component {\n static contextType = AppContext;\n context!: AppContextInterface;\n\n render() {\n let LogoUrl = this.context.pageData?.mainLogo?.file?.url;\n return (\n
    \n Main logo for customer\n
    \n );\n }\n}\n\nexport default MainLogo;\n","import React, { MouseEvent } from 'react';\nimport './styles/App.scss';\nimport LoadingSpinner from './components/loading-spinner';\nimport { AppContext, AppContextInterface } from './app-context-provider';\nimport { Helmet } from 'react-helmet';\nimport { getStyles, getChildren, getDataById } from './helpers/api-helpers';\nimport SideMenu from './components/side-menu';\nimport TopMenu from './components/top-menu';\nimport ComponentSwitcher from './components/component-switcher';\nimport { inView, inViewBottom } from './helpers/layout-helpers';\nimport FloatingArrow from './components/floating-arrow';\nimport MainLogo from './nav/main-logo';\nimport Hotkeys from 'react-hot-keys';\nimport { BsArrowUp } from 'react-icons/bs';\n\nexport interface AppProps {\n nodeId: number;\n}\n\nexport interface MenuItem {}\n\nexport interface AppState extends AppContextInterface {\n loading: boolean;\n navOpen: boolean;\n base: string;\n cssVars: string;\n showFloatingArrow: boolean;\n}\n\nclass App extends React.Component {\n constructor(props: AppProps) {\n super(props);\n\n this.toggleNav = this.toggleNav.bind(this);\n this.onScroll = this.onScroll.bind(this);\n let base = document.querySelector('base');\n this.state = {\n base: base?.href || '',\n id: 0,\n loading: true,\n navOpen: false,\n styles: null,\n pageTree: null,\n cssVars: '',\n currentSection: 'site-intro',\n showFloatingArrow: false,\n };\n }\n\n public state: AppState;\n\n componentDidMount() {\n this.getContext();\n\n window.addEventListener('scroll', this.onScroll);\n setTimeout(() => {\n this.setState({ showFloatingArrow: true });\n }, 2000);\n }\n\n componentWillUnmount() {\n window.removeEventListener('scroll', this.onScroll);\n }\n\n async getContext() {\n const styles = await getStyles(this.props.nodeId);\n const pageData = await getDataById(this.props.nodeId);\n const children = await getChildren(pageData.id);\n // console.log(pageData);\n this.setState({\n loading: false,\n cssVars: styles.stylesheet,\n styles: styles.styleObject,\n pageData,\n children,\n });\n }\n\n toggleNav(event: MouseEvent): void {\n this.setState((prevState) => ({\n navOpen: !prevState.navOpen,\n }));\n }\n\n onScroll(e: any) {\n const sections = document.querySelectorAll('.can-scroll-to');\n const siteIntro = document.querySelector('header');\n if (!sections) return;\n\n if (siteIntro && inViewBottom(siteIntro)) {\n return this.setState({ currentSection: 'site-intro' });\n }\n\n sections.forEach((section) => {\n //switch to children if theres nested sections\n\n if (inView(section)) {\n const sectionChildren = section.querySelectorAll('.can-scroll-to');\n if (sectionChildren?.length > 0) {\n sectionChildren.forEach((childSection) => {\n if (inView(childSection)) {\n return this.setState({\n currentSection: childSection.id,\n });\n }\n });\n } else {\n return this.setState({ currentSection: section.id });\n }\n }\n });\n }\n\n // createLinks(): JSX.Element[] {\n // return this.state.customerData!.pages.slice(1, this.state.customerData!.pages?.length).map((page: Page) => {\n // return {page.name}\n // })\n // }\n\n render() {\n if (this.state.loading) {\n return ;\n }\n\n return (\n \n {\n const w = window.open(\n `https://github.com/aksellsor/07_cra_designmanual/actions`,\n '_blank'\n );\n\n if (w) {\n w.focus(); // okay now\n }\n }}>\n {\n const w = window.open(\n `https://digitalprofilmanual.no/umbraco#/content/content/edit/${document\n .querySelector('[data-node-id]')\n ?.getAttribute('data-node-id')}`,\n '_blank'\n );\n\n if (w) {\n w.focus(); // okay now\n }\n }}>\n \n \n {this.state.pageData?.title}\n \n );\n }\n}\n\nexport default App;\n","// This optional code is used to register a service worker.\n// register() is not called by default.\n\n// This lets the app load faster on subsequent visits in production, and gives\n// it offline capabilities. However, it also means that developers (and users)\n// will only see deployed updates on subsequent visits to a page, after all the\n// existing tabs open on the page have been closed, since previously cached\n// resources are updated in the background.\n\n// To learn more about the benefits of this model and instructions on how to\n// opt-in, read https://bit.ly/CRA-PWA\n\nconst isLocalhost = Boolean(\n window.location.hostname === 'localhost' ||\n // [::1] is the IPv6 localhost address.\n window.location.hostname === '[::1]' ||\n // 127.0.0.0/8 are considered localhost for IPv4.\n window.location.hostname.match(\n /^127(?:\\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}$/\n )\n);\n\ntype Config = {\n onSuccess?: (registration: ServiceWorkerRegistration) => void;\n onUpdate?: (registration: ServiceWorkerRegistration) => void;\n};\n\nexport function register(config?: Config) {\n if (process.env.NODE_ENV === 'production' && 'serviceWorker' in navigator) {\n // The URL constructor is available in all browsers that support SW.\n const publicUrl = new URL(\n process.env.PUBLIC_URL,\n window.location.href\n );\n if (publicUrl.origin !== window.location.origin) {\n // Our service worker won't work if PUBLIC_URL is on a different origin\n // from what our page is served on. This might happen if a CDN is used to\n // serve assets; see https://github.com/facebook/create-react-app/issues/2374\n return;\n }\n\n window.addEventListener('load', () => {\n const swUrl = `${process.env.PUBLIC_URL}/service-worker.js`;\n\n if (isLocalhost) {\n // This is running on localhost. Let's check if a service worker still exists or not.\n checkValidServiceWorker(swUrl, config);\n\n // Add some additional logging to localhost, pointing developers to the\n // service worker/PWA documentation.\n navigator.serviceWorker.ready.then(() => {\n console.log(\n 'This web app is being served cache-first by a service ' +\n 'worker. To learn more, visit https://bit.ly/CRA-PWA'\n );\n });\n } else {\n // Is not localhost. Just register service worker\n registerValidSW(swUrl, config);\n }\n });\n }\n}\n\nfunction registerValidSW(swUrl: string, config?: Config) {\n navigator.serviceWorker\n .register(swUrl)\n .then(registration => {\n registration.onupdatefound = () => {\n const installingWorker = registration.installing;\n if (installingWorker == null) {\n return;\n }\n installingWorker.onstatechange = () => {\n if (installingWorker.state === 'installed') {\n if (navigator.serviceWorker.controller) {\n // At this point, the updated precached content has been fetched,\n // but the previous service worker will still serve the older\n // content until all client tabs are closed.\n console.log(\n 'New content is available and will be used when all ' +\n 'tabs for this page are closed. See https://bit.ly/CRA-PWA.'\n );\n\n // Execute callback\n if (config && config.onUpdate) {\n config.onUpdate(registration);\n }\n } else {\n // At this point, everything has been precached.\n // It's the perfect time to display a\n // \"Content is cached for offline use.\" message.\n console.log('Content is cached for offline use.');\n\n // Execute callback\n if (config && config.onSuccess) {\n config.onSuccess(registration);\n }\n }\n }\n };\n };\n })\n .catch(error => {\n console.error('Error during service worker registration:', error);\n });\n}\n\nfunction checkValidServiceWorker(swUrl: string, config?: Config) {\n // Check if the service worker can be found. If it can't reload the page.\n fetch(swUrl, {\n headers: { 'Service-Worker': 'script' }\n })\n .then(response => {\n // Ensure service worker exists, and that we really are getting a JS file.\n const contentType = response.headers.get('content-type');\n if (\n response.status === 404 ||\n (contentType != null && contentType.indexOf('javascript') === -1)\n ) {\n // No service worker found. Probably a different app. Reload the page.\n navigator.serviceWorker.ready.then(registration => {\n registration.unregister().then(() => {\n window.location.reload();\n });\n });\n } else {\n // Service worker found. Proceed as normal.\n registerValidSW(swUrl, config);\n }\n })\n .catch(() => {\n console.log(\n 'No internet connection found. App is running in offline mode.'\n );\n });\n}\n\nexport function unregister() {\n if ('serviceWorker' in navigator) {\n navigator.serviceWorker.ready\n .then(registration => {\n registration.unregister();\n })\n .catch(error => {\n console.error(error.message);\n });\n }\n}\n","import React from 'react';\nimport ReactDOM from 'react-dom';\nimport App from './App';\nimport { LangProvider } from './contexts/Lang';\nimport * as serviceWorker from './serviceWorker';\n\nlet root = document.getElementById('root');\nlet nodeId: number = parseInt(root?.dataset?.nodeId || '');\nReactDOM.render(\n \n \n ,\n root\n);\n\n// If you want your app to work offline and load faster, you can change\n// unregister() to register() below. Note this comes with some pitfalls.\n// Learn more about service workers: https://bit.ly/CRA-PWA\nserviceWorker.unregister();\n"],"sourceRoot":""}